[#60] object/transformer: Set creation epoch number in new objects

Set value of CreationEpoch object field to the value from network State.

Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
Leonard Lyubich 2020-10-21 18:11:19 +03:00 committed by Alex Vanin
parent 7c081e4f15
commit b627814dd8

View file

@ -6,6 +6,7 @@ import (
"github.com/nspcc-dev/neofs-api-go/pkg" "github.com/nspcc-dev/neofs-api-go/pkg"
objectSDK "github.com/nspcc-dev/neofs-api-go/pkg/object" objectSDK "github.com/nspcc-dev/neofs-api-go/pkg/object"
"github.com/nspcc-dev/neofs-api-go/pkg/token" "github.com/nspcc-dev/neofs-api-go/pkg/token"
"github.com/nspcc-dev/neofs-node/pkg/core/netmap"
"github.com/nspcc-dev/neofs-node/pkg/core/object" "github.com/nspcc-dev/neofs-node/pkg/core/object"
"github.com/pkg/errors" "github.com/pkg/errors"
) )
@ -25,6 +26,8 @@ type FormatterParams struct {
NextTarget ObjectTarget NextTarget ObjectTarget
SessionToken *token.SessionToken SessionToken *token.SessionToken
NetworkState netmap.State
} }
// NewFormatTarget returns ObjectTarget instance that finalizes object structure // NewFormatTarget returns ObjectTarget instance that finalizes object structure
@ -36,6 +39,7 @@ type FormatterParams struct {
// - sets version to current SDK version; // - sets version to current SDK version;
// - sets payload size to the total length of all written chunks; // - sets payload size to the total length of all written chunks;
// - sets session token; // - sets session token;
// - sets number of creation epoch;
// - calculates and sets verification fields (ID, Signature). // - calculates and sets verification fields (ID, Signature).
func NewFormatTarget(p *FormatterParams) ObjectTarget { func NewFormatTarget(p *FormatterParams) ObjectTarget {
return &formatter{ return &formatter{
@ -58,9 +62,12 @@ func (f *formatter) Write(p []byte) (n int, err error) {
} }
func (f *formatter) Close() (*AccessIdentifiers, error) { func (f *formatter) Close() (*AccessIdentifiers, error) {
curEpoch := f.prm.NetworkState.CurrentEpoch()
f.obj.SetVersion(pkg.SDKVersion()) f.obj.SetVersion(pkg.SDKVersion())
f.obj.SetPayloadSize(f.sz) f.obj.SetPayloadSize(f.sz)
f.obj.SetSessionToken(f.prm.SessionToken) f.obj.SetSessionToken(f.prm.SessionToken)
f.obj.SetCreationEpoch(curEpoch)
var parID *objectSDK.ID var parID *objectSDK.ID
@ -68,6 +75,7 @@ func (f *formatter) Close() (*AccessIdentifiers, error) {
rawPar := objectSDK.NewRawFromV2(par.ToV2()) rawPar := objectSDK.NewRawFromV2(par.ToV2())
rawPar.SetSessionToken(f.prm.SessionToken) rawPar.SetSessionToken(f.prm.SessionToken)
rawPar.SetCreationEpoch(curEpoch)
if err := objectSDK.SetIDWithSignature(f.prm.Key, rawPar); err != nil { if err := objectSDK.SetIDWithSignature(f.prm.Key, rawPar); err != nil {
return nil, errors.Wrap(err, "could not finalize parent object") return nil, errors.Wrap(err, "could not finalize parent object")