forked from hyperledger-archives/burrow
/
jobs_governance.go
65 lines (55 loc) · 1.77 KB
/
jobs_governance.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
package jobs
import (
"fmt"
"github.com/hyperledger/burrow/logging"
"github.com/hyperledger/burrow/txs/payload"
"github.com/hyperledger/burrow/crypto"
"github.com/hyperledger/burrow/deploy/def"
"github.com/hyperledger/burrow/deploy/util"
"github.com/hyperledger/burrow/execution/evm/abi"
)
func FormulateUpdateAccountJob(gov *def.UpdateAccount, account string, client *def.Client, logger *logging.Logger) (*payload.GovTx, []*abi.Variable, error) {
gov.Source = useDefault(gov.Source, account)
perms := make([]string, len(gov.Permissions))
for i, p := range gov.Permissions {
perms[i] = string(p)
}
arg := &def.GovArg{
Input: gov.Source,
Sequence: gov.Sequence,
Power: gov.Power,
Native: gov.Native,
Roles: gov.Roles,
Permissions: perms,
}
newAccountMatch := def.NewKeyRegex.FindStringSubmatch(gov.Target)
if len(newAccountMatch) > 0 {
keyName, curveType := def.KeyNameCurveType(newAccountMatch)
publicKey, err := client.CreateKey(keyName, curveType, logger)
if err != nil {
return nil, nil, fmt.Errorf("could not create key for new account: %v", err)
}
arg.Address = publicKey.GetAddress().String()
arg.PublicKey = publicKey.String()
} else if len(gov.Target) == crypto.AddressHexLength {
arg.Address = gov.Target
} else {
arg.PublicKey = gov.Target
}
tx, err := client.UpdateAccount(arg, logger)
if err != nil {
return nil, nil, err
}
return tx, util.Variables(arg), nil
}
func UpdateAccountJob(gov *def.UpdateAccount, account string, tx *payload.GovTx, client *def.Client, logger *logging.Logger) error {
txe, err := client.SignAndBroadcast(tx, logger)
if err != nil {
return util.ChainErrorHandler(account, err, logger)
}
util.ReadTxSignAndBroadcast(txe, err, logger)
if err != nil {
return err
}
return nil
}