forked from TrueCloudLab/frostfs-node
79 lines
1.7 KiB
Go
79 lines
1.7 KiB
Go
package netmap
|
|
|
|
import (
|
|
"crypto/elliptic"
|
|
"errors"
|
|
"fmt"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/morph/event"
|
|
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
|
"github.com/nspcc-dev/neo-go/pkg/vm/opcode"
|
|
)
|
|
|
|
var errNilPubKey = errors.New("could not parse public key: public key is nil")
|
|
|
|
func (s *UpdatePeer) setPublicKey(v []byte) (err error) {
|
|
if v == nil {
|
|
return errNilPubKey
|
|
}
|
|
|
|
s.PubKey, err = keys.NewPublicKeyFromBytes(v, elliptic.P256())
|
|
if err != nil {
|
|
return fmt.Errorf("could not parse public key: %w", err)
|
|
}
|
|
|
|
return
|
|
}
|
|
|
|
const (
|
|
// UpdateStateNotaryEvent is method name for netmap state updating
|
|
// operations in `Netmap` contract. Is used as identificator for
|
|
// notary delete container requests.
|
|
UpdateStateNotaryEvent = "updateState"
|
|
)
|
|
|
|
// ParseUpdatePeerNotary from NotaryEvent into netmap event structure.
|
|
func ParseUpdatePeerNotary(ne event.NotaryEvent) (event.Event, error) {
|
|
var (
|
|
ev UpdatePeer
|
|
err error
|
|
|
|
currCode opcode.Opcode
|
|
)
|
|
|
|
fieldNum := 0
|
|
|
|
for _, op := range ne.Params() {
|
|
currCode = op.Code()
|
|
|
|
switch {
|
|
case fieldNum == 0 && opcode.PUSHDATA1 <= currCode && currCode <= opcode.PUSHDATA4:
|
|
err = ev.setPublicKey(op.Param())
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
fieldNum++
|
|
case fieldNum == 1:
|
|
state, err := event.IntFromOpcode(op)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
err = ev.decodeState(state)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
fieldNum++
|
|
case fieldNum == expectedItemNumUpdatePeer:
|
|
return nil, event.UnexpectedArgNumErr(UpdateStateNotaryEvent)
|
|
default:
|
|
return nil, event.UnexpectedOpcode(UpdateStateNotaryEvent, currCode)
|
|
}
|
|
}
|
|
|
|
ev.Request = ne.Raw()
|
|
|
|
return ev, nil
|
|
}
|