forked from TrueCloudLab/frostfs-node
88459963fb
Use key storage in object services in order to sign requests with private session key within user session. Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
62 lines
1.3 KiB
Go
62 lines
1.3 KiB
Go
package putsvc
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/nspcc-dev/neofs-api-go/pkg/client"
|
|
"github.com/nspcc-dev/neofs-api-go/pkg/token"
|
|
"github.com/nspcc-dev/neofs-node/pkg/core/object"
|
|
"github.com/nspcc-dev/neofs-node/pkg/network"
|
|
"github.com/nspcc-dev/neofs-node/pkg/services/object/util"
|
|
"github.com/nspcc-dev/neofs-node/pkg/services/object_manager/transformer"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
type remoteTarget struct {
|
|
transformer.ObjectTarget
|
|
|
|
ctx context.Context
|
|
|
|
keyStorage *util.KeyStorage
|
|
|
|
token *token.SessionToken
|
|
|
|
addr *network.Address
|
|
|
|
obj *object.Object
|
|
}
|
|
|
|
func (t *remoteTarget) WriteHeader(obj *object.RawObject) error {
|
|
t.obj = obj.Object()
|
|
|
|
return nil
|
|
}
|
|
|
|
func (t *remoteTarget) Close() (*transformer.AccessIdentifiers, error) {
|
|
key, err := t.keyStorage.GetKey(t.token)
|
|
if err != nil {
|
|
return nil, errors.Wrapf(err, "(%T) could not receive private key", t)
|
|
}
|
|
|
|
addr := t.addr.NetAddr()
|
|
|
|
c, err := client.New(key,
|
|
client.WithAddress(addr),
|
|
)
|
|
if err != nil {
|
|
return nil, errors.Wrapf(err, "(%T) could not create SDK client %s", t, addr)
|
|
}
|
|
|
|
id, err := c.PutObject(t.ctx, new(client.PutObjectParams).
|
|
WithObject(
|
|
t.obj.SDK(),
|
|
),
|
|
client.WithTTL(1), // FIXME: use constant
|
|
)
|
|
if err != nil {
|
|
return nil, errors.Wrapf(err, "(%T) could not put object to %s", t, addr)
|
|
}
|
|
|
|
return new(transformer.AccessIdentifiers).
|
|
WithSelfID(id), nil
|
|
}
|