forked from TrueCloudLab/frostfs-node
[#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:
parent
7c081e4f15
commit
b627814dd8
1 changed files with 8 additions and 0 deletions
|
@ -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")
|
||||||
|
|
Loading…
Reference in a new issue