[#834] neofs-adm: Use committee signature when updating alphabet contract

Signed-off-by: Alex Vanin <alexey@nspcc.ru>
This commit is contained in:
Alex Vanin 2021-09-21 15:19:22 +03:00 committed by Alex Vanin
parent 6b3a9e6fcc
commit d996004d80

View file

@ -158,6 +158,13 @@ func (c *initializeContext) deployContracts(method string) error {
Account: acc.Contract.ScriptHash(),
Scopes: transaction.CalledByEntry,
}
if method == "migrate" {
signer = transaction.Signer{
Account: c.CommitteeAcc.Contract.ScriptHash(),
Scopes: transaction.CalledByEntry,
}
}
res, err := c.Client.InvokeFunction(invokeHash, method, params, []transaction.Signer{signer})
if err != nil {
return fmt.Errorf("can't deploy alphabet #%d contract: %w", i, err)
@ -166,6 +173,11 @@ func (c *initializeContext) deployContracts(method string) error {
return fmt.Errorf("can't deploy alpabet #%d contract: %s", i, res.FaultException)
}
if method == "migrate" {
if err := c.sendCommitteeTx(res.Script, res.GasConsumed); err != nil {
return err
}
} else {
h, err := c.Client.SignAndPushInvocationTx(res.Script, acc, -1, 0, []client.SignerAccount{{
Signer: signer,
Account: acc,
@ -176,6 +188,7 @@ func (c *initializeContext) deployContracts(method string) error {
c.Hashes = append(c.Hashes, h)
}
}
for _, ctrName := range contractList {
cs := c.Contracts[ctrName]