forked from TrueCloudLab/frostfs-api-go
[#265] pkg/reputation: Implement PeerID and Trust types
Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
parent
51d443c6fc
commit
009f704377
5 changed files with 205 additions and 0 deletions
29
pkg/reputation/peer.go
Normal file
29
pkg/reputation/peer.go
Normal file
|
@ -0,0 +1,29 @@
|
|||
package reputation
|
||||
|
||||
// PeerID represents peer ID compatible with NeoFS API v2.
|
||||
type PeerID []byte
|
||||
|
||||
// NewPeerID creates and returns blank PeerID.
|
||||
func NewPeerID() *PeerID {
|
||||
return PeerIDFromV2(nil)
|
||||
}
|
||||
|
||||
// PeerIDFromV2 converts bytes slice to PeerID.
|
||||
func PeerIDFromV2(data []byte) *PeerID {
|
||||
return (*PeerID)(&data)
|
||||
}
|
||||
|
||||
// SetBytes sets bytes of peer ID.
|
||||
func (x *PeerID) SetBytes(v []byte) {
|
||||
*x = v
|
||||
}
|
||||
|
||||
// Bytes returns bytes of peer ID.
|
||||
func (x PeerID) Bytes() []byte {
|
||||
return x
|
||||
}
|
||||
|
||||
// ToV2 converts PeerID to byte slice.
|
||||
func (x PeerID) ToV2() []byte {
|
||||
return x
|
||||
}
|
18
pkg/reputation/peer_test.go
Normal file
18
pkg/reputation/peer_test.go
Normal file
|
@ -0,0 +1,18 @@
|
|||
package reputation_test
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/nspcc-dev/neofs-api-go/pkg/reputation"
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestPeerID(t *testing.T) {
|
||||
peerID := reputation.NewPeerID()
|
||||
|
||||
data := []byte{1, 2, 3}
|
||||
peerID.SetBytes(data)
|
||||
require.Equal(t, data, peerID.Bytes())
|
||||
|
||||
require.Equal(t, peerID, reputation.PeerIDFromV2(peerID.ToV2()))
|
||||
}
|
22
pkg/reputation/test/generate.go
Normal file
22
pkg/reputation/test/generate.go
Normal file
|
@ -0,0 +1,22 @@
|
|||
package reputationtest
|
||||
|
||||
import (
|
||||
"github.com/nspcc-dev/neofs-api-go/pkg/reputation"
|
||||
crypto "github.com/nspcc-dev/neofs-crypto"
|
||||
"github.com/nspcc-dev/neofs-crypto/test"
|
||||
)
|
||||
|
||||
func GeneratePeerID() *reputation.PeerID {
|
||||
v := reputation.NewPeerID()
|
||||
v.SetBytes(crypto.MarshalPublicKey(&test.DecodeKey(-1).PublicKey))
|
||||
|
||||
return v
|
||||
}
|
||||
|
||||
func GenerateTrust() *reputation.Trust {
|
||||
v := reputation.NewTrust()
|
||||
v.SetPeer(GeneratePeerID())
|
||||
v.SetValue(1.5)
|
||||
|
||||
return v
|
||||
}
|
95
pkg/reputation/trust.go
Normal file
95
pkg/reputation/trust.go
Normal file
|
@ -0,0 +1,95 @@
|
|||
package reputation
|
||||
|
||||
import (
|
||||
"github.com/nspcc-dev/neofs-api-go/v2/reputation"
|
||||
)
|
||||
|
||||
// Trust represents peer's trust compatible with NeoFS API v2.
|
||||
type Trust reputation.Trust
|
||||
|
||||
// NewTrust creates and returns blank Trust.
|
||||
func NewTrust() *Trust {
|
||||
return TrustFromV2(new(reputation.Trust))
|
||||
}
|
||||
|
||||
// TrustFromV2 converts NeoFS API v2
|
||||
// reputation.Trust message structure to Trust.
|
||||
func TrustFromV2(t *reputation.Trust) *Trust {
|
||||
return (*Trust)(t)
|
||||
}
|
||||
|
||||
// ToV2 converts Trust to NeoFS API v2
|
||||
// reputation.Trust message structure.
|
||||
func (x *Trust) ToV2() *reputation.Trust {
|
||||
return (*reputation.Trust)(x)
|
||||
}
|
||||
|
||||
// TrustsToV2 converts slice of Trust's to slice of
|
||||
// NeoFS API v2 reputation.Trust message structures.
|
||||
func TrustsToV2(xs []*Trust) (res []*reputation.Trust) {
|
||||
if xs != nil {
|
||||
res = make([]*reputation.Trust, 0, len(xs))
|
||||
|
||||
for i := range xs {
|
||||
res = append(res, xs[i].ToV2())
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// SetPeer sets trusted peer ID.
|
||||
func (x *Trust) SetPeer(id *PeerID) {
|
||||
(*reputation.Trust)(x).
|
||||
SetPeer(id.ToV2())
|
||||
}
|
||||
|
||||
// Peer returns trusted peer ID.
|
||||
func (x *Trust) Peer() *PeerID {
|
||||
return PeerIDFromV2(
|
||||
(*reputation.Trust)(x).GetPeer(),
|
||||
)
|
||||
}
|
||||
|
||||
// SetValue sets trust value.
|
||||
func (x *Trust) SetValue(val float64) {
|
||||
(*reputation.Trust)(x).
|
||||
SetValue(val)
|
||||
}
|
||||
|
||||
// Value returns trust value.
|
||||
func (x *Trust) Value() float64 {
|
||||
return (*reputation.Trust)(x).
|
||||
GetValue()
|
||||
}
|
||||
|
||||
// Marshal marshals Trust into a protobuf binary form.
|
||||
//
|
||||
// Buffer is allocated when the argument is empty.
|
||||
// Otherwise, the first buffer is used.
|
||||
func (x *Trust) Marshal(b ...[]byte) ([]byte, error) {
|
||||
var buf []byte
|
||||
if len(b) > 0 {
|
||||
buf = b[0]
|
||||
}
|
||||
|
||||
return (*reputation.Trust)(x).StableMarshal(buf)
|
||||
}
|
||||
|
||||
// Unmarshal unmarshals protobuf binary representation of Trust.
|
||||
func (x *Trust) Unmarshal(data []byte) error {
|
||||
return (*reputation.Trust)(x).
|
||||
Unmarshal(data)
|
||||
}
|
||||
|
||||
// MarshalJSON encodes Trust to protobuf JSON format.
|
||||
func (x *Trust) MarshalJSON() ([]byte, error) {
|
||||
return (*reputation.Trust)(x).
|
||||
MarshalJSON()
|
||||
}
|
||||
|
||||
// UnmarshalJSON decodes Trust from protobuf JSON format.
|
||||
func (x *Trust) UnmarshalJSON(data []byte) error {
|
||||
return (*reputation.Trust)(x).
|
||||
UnmarshalJSON(data)
|
||||
}
|
41
pkg/reputation/trust_test.go
Normal file
41
pkg/reputation/trust_test.go
Normal file
|
@ -0,0 +1,41 @@
|
|||
package reputation_test
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/nspcc-dev/neofs-api-go/pkg/reputation"
|
||||
reputationtest "github.com/nspcc-dev/neofs-api-go/pkg/reputation/test"
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestTrust(t *testing.T) {
|
||||
trust := reputation.NewTrust()
|
||||
|
||||
id := reputationtest.GeneratePeerID()
|
||||
trust.SetPeer(id)
|
||||
require.Equal(t, id, trust.Peer())
|
||||
|
||||
val := 1.5
|
||||
trust.SetValue(val)
|
||||
require.Equal(t, val, trust.Value())
|
||||
|
||||
t.Run("binary encoding", func(t *testing.T) {
|
||||
trust := reputationtest.GenerateTrust()
|
||||
data, err := trust.Marshal()
|
||||
require.NoError(t, err)
|
||||
|
||||
trust2 := reputation.NewTrust()
|
||||
require.NoError(t, trust2.Unmarshal(data))
|
||||
require.Equal(t, trust, trust2)
|
||||
})
|
||||
|
||||
t.Run("JSON encoding", func(t *testing.T) {
|
||||
trust := reputationtest.GenerateTrust()
|
||||
data, err := trust.MarshalJSON()
|
||||
require.NoError(t, err)
|
||||
|
||||
trust2 := reputation.NewTrust()
|
||||
require.NoError(t, trust2.UnmarshalJSON(data))
|
||||
require.Equal(t, trust, trust2)
|
||||
})
|
||||
}
|
Loading…
Reference in a new issue