[#128] sdk: Implement owner ID type
Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
parent
1c3e69721b
commit
c9d38aa2e1
2 changed files with 79 additions and 0 deletions
52
pkg/owner/id.go
Normal file
52
pkg/owner/id.go
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
package owner
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/sha256"
|
||||||
|
|
||||||
|
"github.com/nspcc-dev/neofs-api-go/pkg/refs"
|
||||||
|
refsV2 "github.com/nspcc-dev/neofs-api-go/v2/refs"
|
||||||
|
"github.com/pkg/errors"
|
||||||
|
)
|
||||||
|
|
||||||
|
// ID represents owner identifier that
|
||||||
|
// supports different type of values.
|
||||||
|
type ID struct {
|
||||||
|
val []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetNeo3Wallet sets owner identifier value to NEO3 wallet address.
|
||||||
|
func (id *ID) SetNeo3Wallet(v *refs.NEO3Wallet) {
|
||||||
|
if id != nil {
|
||||||
|
id.val = v.Bytes()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToV2 returns the v2 owner ID message.
|
||||||
|
func (id *ID) ToV2() *refsV2.OwnerID {
|
||||||
|
if id != nil {
|
||||||
|
idV2 := new(refsV2.OwnerID)
|
||||||
|
idV2.SetValue(id.val)
|
||||||
|
|
||||||
|
return idV2
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func IDFromV2(idV2 *refsV2.OwnerID) (*ID, error) {
|
||||||
|
if idV2 == nil {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
val := idV2.GetValue()
|
||||||
|
if ln := len(val); ln != 25 {
|
||||||
|
return nil, errors.Errorf(
|
||||||
|
"could not convert %T to %T: expected length %d, received %d",
|
||||||
|
idV2, (*ID)(nil), sha256.Size, ln,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
return &ID{
|
||||||
|
val: val,
|
||||||
|
}, nil
|
||||||
|
}
|
27
pkg/owner/id_test.go
Normal file
27
pkg/owner/id_test.go
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
package owner
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/rand"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/nspcc-dev/neofs-api-go/pkg/refs"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestIDV2(t *testing.T) {
|
||||||
|
id := new(ID)
|
||||||
|
|
||||||
|
wallet := new(refs.NEO3Wallet)
|
||||||
|
|
||||||
|
_, err := rand.Read(wallet.Bytes())
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
id.SetNeo3Wallet(wallet)
|
||||||
|
|
||||||
|
idV2 := id.ToV2()
|
||||||
|
|
||||||
|
id2, err := IDFromV2(idV2)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
require.Equal(t, id, id2)
|
||||||
|
}
|
Loading…
Reference in a new issue