2022-04-11 06:30:22 +00:00
|
|
|
package user
|
|
|
|
|
|
|
|
import (
|
2023-04-25 08:31:27 +00:00
|
|
|
"fmt"
|
2022-04-11 06:30:22 +00:00
|
|
|
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
2023-04-25 08:31:27 +00:00
|
|
|
neofscrypto "github.com/nspcc-dev/neofs-sdk-go/crypto"
|
2022-04-11 06:30:22 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// IDFromKey forms the ID using script hash calculated for the given key.
|
2023-04-25 08:31:27 +00:00
|
|
|
func IDFromKey(id *ID, key []byte) error {
|
|
|
|
var pk keys.PublicKey
|
|
|
|
if err := pk.DecodeBytes(key); err != nil {
|
|
|
|
return fmt.Errorf("IDFromKey %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
id.SetScriptHash(pk.GetScriptHash())
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// IDFromSigner forms the ID using script hash calculated for the given key.
|
|
|
|
func IDFromSigner(id *ID, signer neofscrypto.Signer) error {
|
|
|
|
public := signer.Public()
|
|
|
|
|
|
|
|
key := make([]byte, public.MaxEncodedSize())
|
|
|
|
key = key[:public.Encode(key)]
|
|
|
|
|
|
|
|
return IDFromKey(id, key)
|
2022-04-11 06:30:22 +00:00
|
|
|
}
|