7c02a2e251
- Update `neofs-sdk-go`: v0.0.0-20211230072947-1fe37df88f80 => v0.0.0-20220113123743-7f3162110659 - Add client interface that duplicates SDK's client behaviour and new `MultiAddressClient` interface that has method that iterates over wrapped clients. - Also start using simple client mode that does not require parsing statuses outside the SDK library. Signed-off-by: Pavel Karpy <carpawell@nspcc.ru>
113 lines
2.3 KiB
Go
113 lines
2.3 KiB
Go
package internal
|
|
|
|
import (
|
|
"crypto/ecdsa"
|
|
"io"
|
|
|
|
"github.com/nspcc-dev/neofs-sdk-go/client"
|
|
cid "github.com/nspcc-dev/neofs-sdk-go/container/id"
|
|
"github.com/nspcc-dev/neofs-sdk-go/object"
|
|
"github.com/nspcc-dev/neofs-sdk-go/owner"
|
|
"github.com/nspcc-dev/neofs-sdk-go/session"
|
|
"github.com/nspcc-dev/neofs-sdk-go/token"
|
|
)
|
|
|
|
// here are small structures with public setters to share between parameter structures
|
|
|
|
type commonPrm struct {
|
|
cli *client.Client
|
|
|
|
privKey *ecdsa.PrivateKey
|
|
}
|
|
|
|
// SetClient sets base client for NeoFS API communication.
|
|
func (x *commonPrm) SetClient(cli *client.Client) {
|
|
x.cli = cli
|
|
}
|
|
|
|
// SetKey sets private key to sign the request(s).
|
|
func (x *commonPrm) SetKey(key *ecdsa.PrivateKey) {
|
|
x.privKey = key
|
|
}
|
|
|
|
type ownerIDPrm struct {
|
|
ownerID *owner.ID
|
|
}
|
|
|
|
// SetOwner sets identifier of NeoFS user.
|
|
func (x *ownerIDPrm) SetOwner(id *owner.ID) {
|
|
x.ownerID = id
|
|
}
|
|
|
|
type containerIDPrm struct {
|
|
cnrID *cid.ID
|
|
}
|
|
|
|
// SetContainerID sets container identifier.
|
|
func (x *containerIDPrm) SetContainerID(id *cid.ID) {
|
|
x.cnrID = id
|
|
}
|
|
|
|
type sessionTokenPrm struct {
|
|
sessionToken *session.Token
|
|
}
|
|
|
|
// SetSessionToken sets token of the session within which request should be sent.
|
|
func (x *sessionTokenPrm) SetSessionToken(tok *session.Token) {
|
|
x.sessionToken = tok
|
|
}
|
|
|
|
type bearerTokenPrm struct {
|
|
bearerToken *token.BearerToken
|
|
}
|
|
|
|
// SetBearerToken sets bearer token to be attached to the request.
|
|
func (x *bearerTokenPrm) SetBearerToken(tok *token.BearerToken) {
|
|
x.bearerToken = tok
|
|
}
|
|
|
|
type objectAddressPrm struct {
|
|
objAddr *object.Address
|
|
}
|
|
|
|
func (x *objectAddressPrm) SetAddress(addr *object.Address) {
|
|
x.objAddr = addr
|
|
}
|
|
|
|
type rawPrm struct {
|
|
raw bool
|
|
}
|
|
|
|
// SetRawFlag sets flag of raw request.
|
|
func (x *rawPrm) SetRawFlag(raw bool) {
|
|
x.raw = raw
|
|
}
|
|
|
|
type payloadWriterPrm struct {
|
|
wrt io.Writer
|
|
}
|
|
|
|
// SetPayloadWriter sets writer of the object payload.
|
|
func (x *payloadWriterPrm) SetPayloadWriter(wrt io.Writer) {
|
|
x.wrt = wrt
|
|
}
|
|
|
|
type commonObjectPrm struct {
|
|
commonPrm
|
|
sessionTokenPrm
|
|
bearerTokenPrm
|
|
|
|
opts []client.CallOption
|
|
}
|
|
|
|
// SetTTL sets request TTL value.
|
|
func (x *commonObjectPrm) SetTTL(ttl uint32) {
|
|
x.opts = append(x.opts, client.WithTTL(ttl))
|
|
}
|
|
|
|
// SetXHeaders sets request X-Headers.
|
|
func (x *commonObjectPrm) SetXHeaders(xhdrs []*session.XHeader) {
|
|
for _, xhdr := range xhdrs {
|
|
x.opts = append(x.opts, client.WithXHeader(xhdr))
|
|
}
|
|
}
|