forked from TrueCloudLab/frostfs-node
[#525] morph/container: Parse session token, key and signature in Get
`Get` method of `Container` contract returns binary session token, key and signature along with container. Provide `Signature`, `PublicKey` and `SessionToken` getters from `GetValues` structure. Parse and set all values in `Client.Get` methods. Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
parent
461fcfcf19
commit
b9b369dd5b
1 changed files with 41 additions and 1 deletions
|
@ -16,6 +16,12 @@ type GetArgs struct {
|
||||||
// returned by get container test invoke.
|
// returned by get container test invoke.
|
||||||
type GetValues struct {
|
type GetValues struct {
|
||||||
cnr []byte // container in a binary form
|
cnr []byte // container in a binary form
|
||||||
|
|
||||||
|
signature []byte // RFC-6979 signature of container
|
||||||
|
|
||||||
|
publicKey []byte // public key of the container signer
|
||||||
|
|
||||||
|
token []byte // token of the session within which the container was created
|
||||||
}
|
}
|
||||||
|
|
||||||
// SetCID sets the container identifier
|
// SetCID sets the container identifier
|
||||||
|
@ -30,6 +36,22 @@ func (g *GetValues) Container() []byte {
|
||||||
return g.cnr
|
return g.cnr
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Signature returns RFC-6979 signature of the container.
|
||||||
|
func (g *GetValues) Signature() []byte {
|
||||||
|
return g.signature
|
||||||
|
}
|
||||||
|
|
||||||
|
// PublicKey returns public key related to signature.
|
||||||
|
func (g *GetValues) PublicKey() []byte {
|
||||||
|
return g.publicKey
|
||||||
|
}
|
||||||
|
|
||||||
|
// SessionToken returns token of the session within which
|
||||||
|
// the container was created in a NeoFS API binary format.
|
||||||
|
func (g *GetValues) SessionToken() []byte {
|
||||||
|
return g.token
|
||||||
|
}
|
||||||
|
|
||||||
// Get performs the test invoke of get container
|
// Get performs the test invoke of get container
|
||||||
// method of NeoFS Container contract.
|
// method of NeoFS Container contract.
|
||||||
func (c *Client) Get(args GetArgs) (*GetValues, error) {
|
func (c *Client) Get(args GetArgs) (*GetValues, error) {
|
||||||
|
@ -57,7 +79,25 @@ func (c *Client) Get(args GetArgs) (*GetValues, error) {
|
||||||
return nil, fmt.Errorf("could not get byte array of container (%s): %w", c.getMethod, err)
|
return nil, fmt.Errorf("could not get byte array of container (%s): %w", c.getMethod, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sig, err := client.BytesFromStackItem(arr[1])
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("could not get byte array of container signature (%s): %w", c.getMethod, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub, err := client.BytesFromStackItem(arr[2])
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("could not get byte array of public key (%s): %w", c.getMethod, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
tok, err := client.BytesFromStackItem(arr[3])
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("could not get byte array of session token (%s): %w", c.getMethod, err)
|
||||||
|
}
|
||||||
|
|
||||||
return &GetValues{
|
return &GetValues{
|
||||||
cnr: cnrBytes,
|
cnr: cnrBytes,
|
||||||
|
signature: sig,
|
||||||
|
publicKey: pub,
|
||||||
|
token: tok,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue