forked from TrueCloudLab/frostfs-api-go
[#140] sdk: Define checksum type
Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
parent
e0c34a51f2
commit
5902f96f3e
2 changed files with 114 additions and 0 deletions
74
pkg/checksum.go
Normal file
74
pkg/checksum.go
Normal file
|
@ -0,0 +1,74 @@
|
|||
package pkg
|
||||
|
||||
import (
|
||||
"crypto/sha256"
|
||||
|
||||
"github.com/nspcc-dev/neofs-api-go/v2/refs"
|
||||
)
|
||||
|
||||
// Checksum represents v2-compatible checksum.
|
||||
type Checksum refs.Checksum
|
||||
|
||||
// ChecksumType represents the enumeration
|
||||
// of checksum types.
|
||||
type ChecksumType uint8
|
||||
|
||||
const (
|
||||
// ChecksumUnknown is an undefined checksum type.
|
||||
ChecksumUnknown ChecksumType = iota
|
||||
|
||||
// ChecksumSHA256 is a SHA256 checksum type.
|
||||
ChecksumSHA256
|
||||
|
||||
// ChecksumTZ is a Tillich-Zemor checksum type.
|
||||
ChecksumTZ
|
||||
)
|
||||
|
||||
// NewChecksumFromV2 wraps v2 Checksum message to Checksum.
|
||||
func NewChecksumFromV2(cV2 *refs.Checksum) *Checksum {
|
||||
return (*Checksum)(cV2)
|
||||
}
|
||||
|
||||
// NewVersion creates and initializes blank Version.
|
||||
//
|
||||
// Works similar as NewVersionFromV2(new(Version)).
|
||||
func NewChecksum() *Checksum {
|
||||
return NewChecksumFromV2(new(refs.Checksum))
|
||||
}
|
||||
|
||||
// GetType returns checksum type.
|
||||
func (c *Checksum) GetType() ChecksumType {
|
||||
switch (*refs.Checksum)(c).GetType() {
|
||||
case refs.SHA256:
|
||||
return ChecksumSHA256
|
||||
case refs.TillichZemor:
|
||||
return ChecksumTZ
|
||||
default:
|
||||
return ChecksumUnknown
|
||||
}
|
||||
}
|
||||
|
||||
// GetSum returns checksum bytes.
|
||||
func (c *Checksum) GetSum() []byte {
|
||||
return (*refs.Checksum)(c).GetSum()
|
||||
}
|
||||
|
||||
// SetSHA256 sets checksum to SHA256 hash.
|
||||
func (c *Checksum) SetSHA256(v [sha256.Size]byte) {
|
||||
checksum := (*refs.Checksum)(c)
|
||||
|
||||
checksum.SetType(refs.SHA256)
|
||||
checksum.SetSum(v[:])
|
||||
}
|
||||
|
||||
// SetTillichZemor sets checksum to Tillich-Zemor hash.
|
||||
func (c *Checksum) SetTillichZemor(v [64]byte) {
|
||||
checksum := (*refs.Checksum)(c)
|
||||
|
||||
checksum.SetType(refs.TillichZemor)
|
||||
checksum.SetSum(v[:])
|
||||
}
|
||||
|
||||
func (c *Checksum) ToV2() *refs.Checksum {
|
||||
return (*refs.Checksum)(c)
|
||||
}
|
40
pkg/checksum_test.go
Normal file
40
pkg/checksum_test.go
Normal file
|
@ -0,0 +1,40 @@
|
|||
package pkg
|
||||
|
||||
import (
|
||||
"crypto/rand"
|
||||
"crypto/sha256"
|
||||
"testing"
|
||||
|
||||
"github.com/nspcc-dev/neofs-api-go/v2/refs"
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestChecksum(t *testing.T) {
|
||||
c := NewChecksum()
|
||||
|
||||
cSHA256 := [sha256.Size]byte{}
|
||||
_, _ = rand.Read(cSHA256[:])
|
||||
|
||||
c.SetSHA256(cSHA256)
|
||||
|
||||
require.Equal(t, ChecksumSHA256, c.GetType())
|
||||
require.Equal(t, cSHA256[:], c.GetSum())
|
||||
|
||||
cV2 := c.ToV2()
|
||||
|
||||
require.Equal(t, refs.SHA256, cV2.GetType())
|
||||
require.Equal(t, cSHA256[:], cV2.GetSum())
|
||||
|
||||
cTZ := [64]byte{}
|
||||
_, _ = rand.Read(cSHA256[:])
|
||||
|
||||
c.SetTillichZemor(cTZ)
|
||||
|
||||
require.Equal(t, ChecksumTZ, c.GetType())
|
||||
require.Equal(t, cTZ[:], c.GetSum())
|
||||
|
||||
cV2 = c.ToV2()
|
||||
|
||||
require.Equal(t, refs.TillichZemor, cV2.GetType())
|
||||
require.Equal(t, cTZ[:], cV2.GetSum())
|
||||
}
|
Loading…
Reference in a new issue