forked from TrueCloudLab/frostfs-node
[#505] neofsid: Implement wrapper over contract client
Implement wrapper over NeoFS ID contact's client which allows to which allows you to conveniently interact with the contract. Implement `AccountKeys` method for getting a list of keys by account ID. Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
parent
68b469a79d
commit
eb26f92678
2 changed files with 61 additions and 0 deletions
23
pkg/morph/client/neofsid/wrapper/client.go
Normal file
23
pkg/morph/client/neofsid/wrapper/client.go
Normal file
|
@ -0,0 +1,23 @@
|
|||
package neofsid
|
||||
|
||||
import (
|
||||
"github.com/nspcc-dev/neofs-node/pkg/morph/client/neofsid"
|
||||
)
|
||||
|
||||
// ClientWrapper is a wrapper over NeoFS ID contract
|
||||
// client which provides convenient methods for
|
||||
// working with a contract.
|
||||
//
|
||||
// Working ClientWrapper must be created via Wrap.
|
||||
type ClientWrapper neofsid.Client
|
||||
|
||||
// Wrap creates, initializes and returns the ClientWrapper instance.
|
||||
//
|
||||
// If c is nil, panic occurs.
|
||||
func Wrap(c *neofsid.Client) *ClientWrapper {
|
||||
if c == nil {
|
||||
panic("neofs ID client is nil")
|
||||
}
|
||||
|
||||
return (*ClientWrapper)(c)
|
||||
}
|
38
pkg/morph/client/neofsid/wrapper/keys.go
Normal file
38
pkg/morph/client/neofsid/wrapper/keys.go
Normal file
|
@ -0,0 +1,38 @@
|
|||
package neofsid
|
||||
|
||||
import (
|
||||
"crypto/elliptic"
|
||||
"fmt"
|
||||
|
||||
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
||||
"github.com/nspcc-dev/neofs-api-go/pkg/owner"
|
||||
"github.com/nspcc-dev/neofs-node/pkg/morph/client/neofsid"
|
||||
)
|
||||
|
||||
// AccountKeys requests public keys of NeoFS account from NeoFS ID contract.
|
||||
func (x *ClientWrapper) AccountKeys(id *owner.ID) (keys.PublicKeys, error) {
|
||||
var args neofsid.KeyListingArgs
|
||||
|
||||
args.SetOwnerID(id.ToV2().GetValue())
|
||||
|
||||
res, err := (*neofsid.Client)(x).AccountKeys(args)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
binKeys := res.Keys()
|
||||
ks := make(keys.PublicKeys, 0, len(binKeys))
|
||||
|
||||
curve := elliptic.P256()
|
||||
|
||||
for i := range binKeys {
|
||||
k, err := keys.NewPublicKeyFromBytes(binKeys[i], curve)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("received invalid key: %w", err)
|
||||
}
|
||||
|
||||
ks = append(ks, k)
|
||||
}
|
||||
|
||||
return ks, nil
|
||||
}
|
Loading…
Reference in a new issue