2020-01-30 11:41:24 +00:00
# Protocol Documentation
< a name = "top" > < / a >
## Table of Contents
- [session/service.proto ](#session/service.proto )
2024-04-03 08:21:40 +00:00
- Services
2024-11-06 11:59:06 +00:00
- [SessionService ](#frost.fs.session.SessionService )
2024-09-02 12:03:58 +00:00
2020-01-30 11:41:24 +00:00
- Messages
2024-11-06 11:59:06 +00:00
- [CreateRequest ](#frost.fs.session.CreateRequest )
- [CreateRequest.Body ](#frost.fs.session.CreateRequest.Body )
- [CreateResponse ](#frost.fs.session.CreateResponse )
- [CreateResponse.Body ](#frost.fs.session.CreateResponse.Body )
2024-09-02 12:03:58 +00:00
2020-01-30 11:41:24 +00:00
2020-08-18 13:51:28 +00:00
- [session/types.proto ](#session/types.proto )
- Messages
2024-11-06 11:59:06 +00:00
- [ContainerSessionContext ](#frost.fs.session.ContainerSessionContext )
- [ObjectSessionContext ](#frost.fs.session.ObjectSessionContext )
- [ObjectSessionContext.Target ](#frost.fs.session.ObjectSessionContext.Target )
- [RequestMetaHeader ](#frost.fs.session.RequestMetaHeader )
- [RequestVerificationHeader ](#frost.fs.session.RequestVerificationHeader )
- [ResponseMetaHeader ](#frost.fs.session.ResponseMetaHeader )
- [ResponseVerificationHeader ](#frost.fs.session.ResponseVerificationHeader )
- [SessionToken ](#frost.fs.session.SessionToken )
- [SessionToken.Body ](#frost.fs.session.SessionToken.Body )
- [SessionToken.Body.TokenLifetime ](#frost.fs.session.SessionToken.Body.TokenLifetime )
- [XHeader ](#frost.fs.session.XHeader )
2024-09-02 12:03:58 +00:00
2020-08-18 13:51:28 +00:00
2020-01-30 11:41:24 +00:00
- [Scalar Value Types ](#scalar-value-types )
< a name = "session/service.proto" > < / a >
< p align = "right" > < a href = "#top" > Top< / a > < / p >
## session/service.proto
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.SessionService" > < / a >
2020-01-30 11:41:24 +00:00
2024-11-06 11:59:06 +00:00
### Service "frost.fs.session.SessionService"
2020-10-16 11:40:12 +00:00
`SessionService` allows to establish a temporary trust relationship between
two peer nodes and generate a `SessionToken` as the proof of trust to be
attached in requests for further verification. Please see corresponding
2024-09-05 13:27:53 +00:00
section of FrostFS Technical Specification for details.
2020-01-30 11:41:24 +00:00
```
2020-05-07 15:44:23 +00:00
rpc Create(CreateRequest) returns (CreateResponse);
2020-01-30 11:41:24 +00:00
```
#### Method Create
2022-06-21 11:32:14 +00:00
Open a new session between two peers.
2020-01-30 11:41:24 +00:00
2021-11-12 16:10:39 +00:00
Statuses:
- **OK** (0, SECTION_SUCCESS):
session has been successfully opened;
- Common failures (SECTION_FAILURE_COMMON).
2020-01-30 11:41:24 +00:00
| Name | Input | Output |
| ---- | ----- | ------ |
2024-11-06 11:59:06 +00:00
| Create | [CreateRequest ](#frost.fs.session.CreateRequest ) | [CreateResponse ](#frost.fs.session.CreateResponse ) |
2020-01-30 11:41:24 +00:00
<!-- end services -->
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.CreateRequest" > < / a >
2020-01-30 11:41:24 +00:00
### Message CreateRequest
2020-10-16 11:40:12 +00:00
Information necessary for opening a session.
2020-01-30 11:41:24 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| body | [CreateRequest.Body ](#frost.fs.session.CreateRequest.Body ) | | Body of a create session token request message. |
| meta_header | [RequestMetaHeader ](#frost.fs.session.RequestMetaHeader ) | | Carries request meta information. Header data is used only to regulate message transport and does not affect request execution. |
| verify_header | [RequestVerificationHeader ](#frost.fs.session.RequestVerificationHeader ) | | Carries request verification information. This header is used to authenticate the nodes of the message route and check the correctness of transmission. |
2020-01-30 11:41:24 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.CreateRequest.Body" > < / a >
2020-08-11 15:49:56 +00:00
### Message CreateRequest.Body
2020-10-16 11:40:12 +00:00
Session creation request body
2020-08-11 15:49:56 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| owner_id | [frost.fs.refs.OwnerID ](#frost.fs.refs.OwnerID ) | | Session initiating user's or node's key derived `OwnerID` |
2020-10-16 11:40:12 +00:00
| expiration | [uint64 ](#uint64 ) | | Session expiration `Epoch` |
2020-08-11 15:49:56 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.CreateResponse" > < / a >
2020-01-30 11:41:24 +00:00
### Message CreateResponse
2020-10-16 11:40:12 +00:00
Information about the opened session.
2020-01-30 11:41:24 +00:00
2020-08-11 15:49:56 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| body | [CreateResponse.Body ](#frost.fs.session.CreateResponse.Body ) | | Body of create session token response message. |
| meta_header | [ResponseMetaHeader ](#frost.fs.session.ResponseMetaHeader ) | | Carries response meta information. Header data is used only to regulate message transport and does not affect request execution. |
| verify_header | [ResponseVerificationHeader ](#frost.fs.session.ResponseVerificationHeader ) | | Carries response verification information. This header is used to authenticate the nodes of the message route and check the correctness of transmission. |
2020-08-11 15:49:56 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.CreateResponse.Body" > < / a >
2020-08-11 15:49:56 +00:00
### Message CreateResponse.Body
2020-10-16 11:40:12 +00:00
Session creation response body
2020-08-11 15:49:56 +00:00
2020-01-30 11:41:24 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2020-10-16 11:40:12 +00:00
| id | [bytes ](#bytes ) | | Identifier of a newly created session |
| session_key | [bytes ](#bytes ) | | Public key used for session |
2020-01-30 11:41:24 +00:00
<!-- end messages -->
<!-- end enums -->
2020-08-18 13:51:28 +00:00
< a name = "session/types.proto" > < / a >
< p align = "right" > < a href = "#top" > Top< / a > < / p >
## session/types.proto
<!-- end services -->
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.ContainerSessionContext" > < / a >
2021-06-03 12:34:19 +00:00
### Message ContainerSessionContext
Context information for Session Tokens related to ContainerService requests.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| verb | [ContainerSessionContext.Verb ](#frost.fs.session.ContainerSessionContext.Verb ) | | Type of request for which the token is issued |
2021-06-03 12:34:19 +00:00
| wildcard | [bool ](#bool ) | | Spreads the action to all owner containers. If set, container_id field is ignored. |
2024-11-06 11:59:06 +00:00
| container_id | [frost.fs.refs.ContainerID ](#frost.fs.refs.ContainerID ) | | Particular container to which the action applies. Ignored if wildcard flag is set. |
2021-06-03 12:34:19 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.ObjectSessionContext" > < / a >
2020-08-18 13:51:28 +00:00
### Message ObjectSessionContext
Context information for Session Tokens related to ObjectService requests
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| verb | [ObjectSessionContext.Verb ](#frost.fs.session.ObjectSessionContext.Verb ) | | Type of request for which the token is issued |
| target | [ObjectSessionContext.Target ](#frost.fs.session.ObjectSessionContext.Target ) | | Object session target. MUST be correctly formed and set. If `objects` field is not empty, then the session applies only to these elements, otherwise, to all objects from the specified container. |
2022-09-23 14:57:44 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.ObjectSessionContext.Target" > < / a >
2022-09-23 14:57:44 +00:00
### Message ObjectSessionContext.Target
Carries objects involved in the object session.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| container | [frost.fs.refs.ContainerID ](#frost.fs.refs.ContainerID ) | | Indicates which container the session is spread to. Field MUST be set and correct. |
| objects | [frost.fs.refs.ObjectID ](#frost.fs.refs.ObjectID ) | repeated | Indicates which objects the session is spread to. Objects are expected to be stored in the FrostFS container referenced by `container` field. Each element MUST have correct format. |
2020-08-18 13:51:28 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.RequestMetaHeader" > < / a >
2020-08-19 14:00:23 +00:00
### Message RequestMetaHeader
2020-10-16 11:40:12 +00:00
Meta information attached to the request. When forwarded between peers,
request meta headers are folded in matryoshka style.
2020-08-19 14:00:23 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| version | [frost.fs.refs.Version ](#frost.fs.refs.Version ) | | Peer's API version used |
2020-10-16 11:40:12 +00:00
| epoch | [uint64 ](#uint64 ) | | Peer's local epoch number. Set to 0 if unknown. |
| ttl | [uint32 ](#uint32 ) | | Maximum number of intermediate nodes in the request route |
2024-11-06 11:59:06 +00:00
| x_headers | [XHeader ](#frost.fs.session.XHeader ) | repeated | Request X-Headers |
| session_token | [SessionToken ](#frost.fs.session.SessionToken ) | | Session token within which the request is sent |
| bearer_token | [frost.fs.acl.BearerToken ](#frost.fs.acl.BearerToken ) | | `BearerToken` with eACL overrides for the request |
| origin | [RequestMetaHeader ](#frost.fs.session.RequestMetaHeader ) | | `RequestMetaHeader` of the origin request |
2024-09-05 13:27:53 +00:00
| magic_number | [uint64 ](#uint64 ) | | FrostFS network magic. Must match the value for the network that the server belongs to. |
2020-08-19 14:00:23 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.RequestVerificationHeader" > < / a >
2020-08-19 14:00:23 +00:00
### Message RequestVerificationHeader
2022-06-21 11:32:14 +00:00
Verification info for the request signed by all intermediate nodes.
2020-08-19 14:00:23 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| body_signature | [frost.fs.refs.Signature ](#frost.fs.refs.Signature ) | | Request Body signature. Should be generated once by the request initiator. |
| meta_signature | [frost.fs.refs.Signature ](#frost.fs.refs.Signature ) | | Request Meta signature is added and signed by each intermediate node |
| origin_signature | [frost.fs.refs.Signature ](#frost.fs.refs.Signature ) | | Signature of previous hops |
| origin | [RequestVerificationHeader ](#frost.fs.session.RequestVerificationHeader ) | | Chain of previous hops signatures |
2020-08-19 14:00:23 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.ResponseMetaHeader" > < / a >
2020-08-19 14:00:23 +00:00
### Message ResponseMetaHeader
Information about the response
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| version | [frost.fs.refs.Version ](#frost.fs.refs.Version ) | | Peer's API version used |
2020-10-16 11:40:12 +00:00
| epoch | [uint64 ](#uint64 ) | | Peer's local epoch number |
| ttl | [uint32 ](#uint32 ) | | Maximum number of intermediate nodes in the request route |
2024-11-06 11:59:06 +00:00
| x_headers | [XHeader ](#frost.fs.session.XHeader ) | repeated | Response X-Headers |
| origin | [ResponseMetaHeader ](#frost.fs.session.ResponseMetaHeader ) | | `ResponseMetaHeader` of the origin request |
| status | [frost.fs.status.Status ](#frost.fs.status.Status ) | | Status return |
2020-08-19 14:00:23 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.ResponseVerificationHeader" > < / a >
2020-08-19 14:00:23 +00:00
### Message ResponseVerificationHeader
2022-06-21 11:32:14 +00:00
Verification info for the response signed by all intermediate nodes
2020-08-19 14:00:23 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| body_signature | [frost.fs.refs.Signature ](#frost.fs.refs.Signature ) | | Response Body signature. Should be generated once by an answering node. |
| meta_signature | [frost.fs.refs.Signature ](#frost.fs.refs.Signature ) | | Response Meta signature is added and signed by each intermediate node |
| origin_signature | [frost.fs.refs.Signature ](#frost.fs.refs.Signature ) | | Signature of previous hops |
| origin | [ResponseVerificationHeader ](#frost.fs.session.ResponseVerificationHeader ) | | Chain of previous hops signatures |
2020-08-19 14:00:23 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.SessionToken" > < / a >
2020-08-18 13:51:28 +00:00
### Message SessionToken
2024-09-05 13:27:53 +00:00
FrostFS Session Token.
2020-08-18 13:51:28 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2024-11-06 11:59:06 +00:00
| body | [SessionToken.Body ](#frost.fs.session.SessionToken.Body ) | | Session Token contains the proof of trust between peers to be attached in requests for further verification. Please see corresponding section of FrostFS Technical Specification for details. |
| signature | [frost.fs.refs.Signature ](#frost.fs.refs.Signature ) | | Signature of `SessionToken` information |
2020-08-18 13:51:28 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.SessionToken.Body" > < / a >
2020-08-18 13:51:28 +00:00
### Message SessionToken.Body
2020-10-16 11:40:12 +00:00
Session Token body
2020-08-18 13:51:28 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2020-10-16 11:40:12 +00:00
| id | [bytes ](#bytes ) | | Token identifier is a valid UUIDv4 in binary form |
2024-11-06 11:59:06 +00:00
| owner_id | [frost.fs.refs.OwnerID ](#frost.fs.refs.OwnerID ) | | Identifier of the session initiator |
| lifetime | [SessionToken.Body.TokenLifetime ](#frost.fs.session.SessionToken.Body.TokenLifetime ) | | Lifetime of the session |
2020-10-16 11:40:12 +00:00
| session_key | [bytes ](#bytes ) | | Public key used in session |
2024-11-06 11:59:06 +00:00
| object | [ObjectSessionContext ](#frost.fs.session.ObjectSessionContext ) | | ObjectService session context |
| container | [ContainerSessionContext ](#frost.fs.session.ContainerSessionContext ) | | ContainerService session context |
2020-08-18 13:51:28 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.SessionToken.Body.TokenLifetime" > < / a >
2020-08-18 13:51:28 +00:00
### Message SessionToken.Body.TokenLifetime
2020-12-11 07:20:21 +00:00
Lifetime parameters of the token. Field names taken from rfc7519.
2020-08-18 13:51:28 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| exp | [uint64 ](#uint64 ) | | Expiration Epoch |
| nbf | [uint64 ](#uint64 ) | | Not valid before Epoch |
| iat | [uint64 ](#uint64 ) | | Issued at Epoch |
2020-08-19 14:00:23 +00:00
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.XHeader" > < / a >
2020-08-19 14:00:23 +00:00
### Message XHeader
2024-03-05 09:36:58 +00:00
Extended headers for Request/Response. They may contain any user-defined
headers to be interpreted on application level.
2021-02-11 13:13:07 +00:00
2024-03-05 09:36:58 +00:00
Key name must be a unique valid UTF-8 string. Value can't be empty. Requests
or Responses with duplicated header names or headers with empty values will
be considered invalid.
2021-02-11 13:13:07 +00:00
2024-11-06 11:59:06 +00:00
There are some "well-known" headers starting with
`__SYSTEM__` prefix that affect system behaviour:
2021-02-11 13:13:07 +00:00
2023-03-14 07:24:35 +00:00
* [ __SYSTEM__NETMAP_EPOCH ] \
2021-02-11 13:13:07 +00:00
Netmap epoch to use for object placement calculation. The `value` is string
encoded `uint64` in decimal presentation. If set to '0' or not set, the
current epoch only will be used.
2023-03-14 07:24:35 +00:00
* [ __SYSTEM__NETMAP_LOOKUP_DEPTH ] \
2021-02-11 13:13:07 +00:00
If object can't be found using current epoch's netmap, this header limits
2022-06-21 11:32:14 +00:00
how many past epochs the node can look up through. The `value` is string
2024-03-05 09:36:58 +00:00
encoded `uint64` in decimal presentation. If set to '0' or not set, only
the current epoch will be used.
2020-08-19 14:00:23 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2020-10-16 11:40:12 +00:00
| key | [string ](#string ) | | Key of the X-Header |
| value | [string ](#string ) | | Value of the X-Header |
2020-08-19 14:00:23 +00:00
2020-08-18 13:51:28 +00:00
<!-- end messages -->
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.ContainerSessionContext.Verb" > < / a >
2021-06-03 12:34:19 +00:00
### ContainerSessionContext.Verb
Container request verbs
| Name | Number | Description |
| ---- | ------ | ----------- |
| VERB_UNSPECIFIED | 0 | Unknown verb |
| PUT | 1 | Refers to container.Put RPC call |
| DELETE | 2 | Refers to container.Delete RPC call |
| SETEACL | 3 | Refers to container.SetExtendedACL RPC call |
2024-11-06 11:59:06 +00:00
< a name = "frost.fs.session.ObjectSessionContext.Verb" > < / a >
2020-08-18 13:51:28 +00:00
### ObjectSessionContext.Verb
Object request verbs
| Name | Number | Description |
| ---- | ------ | ----------- |
| VERB_UNSPECIFIED | 0 | Unknown verb |
| PUT | 1 | Refers to object.Put RPC call |
| GET | 2 | Refers to object.Get RPC call |
| HEAD | 3 | Refers to object.Head RPC call |
| SEARCH | 4 | Refers to object.Search RPC call |
| DELETE | 5 | Refers to object.Delete RPC call |
| RANGE | 6 | Refers to object.GetRange RPC call |
| RANGEHASH | 7 | Refers to object.GetRangeHash RPC call |
2024-08-05 17:43:00 +00:00
| PATCH | 8 | Refers to object.Patch RPC call |
2020-08-18 13:51:28 +00:00
<!-- end enums -->
2020-01-30 11:41:24 +00:00
## Scalar Value Types
| .proto Type | Notes | C++ Type | Java Type | Python Type |
| ----------- | ----- | -------- | --------- | ----------- |
| < a name = "double" / > double | | double | double | float |
| < a name = "float" / > float | | float | float | float |
| < a name = "int32" / > int32 | Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint32 instead. | int32 | int | int |
| < a name = "int64" / > int64 | Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint64 instead. | int64 | long | int/long |
| < a name = "uint32" / > uint32 | Uses variable-length encoding. | uint32 | int | int/long |
| < a name = "uint64" / > uint64 | Uses variable-length encoding. | uint64 | long | int/long |
| < a name = "sint32" / > sint32 | Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int32s. | int32 | int | int |
| < a name = "sint64" / > sint64 | Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int64s. | int64 | long | int/long |
| < a name = "fixed32" / > fixed32 | Always four bytes. More efficient than uint32 if values are often greater than 2^28. | uint32 | int | int |
| < a name = "fixed64" / > fixed64 | Always eight bytes. More efficient than uint64 if values are often greater than 2^56. | uint64 | long | int/long |
| < a name = "sfixed32" / > sfixed32 | Always four bytes. | int32 | int | int |
| < a name = "sfixed64" / > sfixed64 | Always eight bytes. | int64 | long | int/long |
| < a name = "bool" / > bool | | bool | boolean | boolean |
| < a name = "string" / > string | A string must always contain UTF-8 encoded or 7-bit ASCII text. | string | String | str/unicode |
| < a name = "bytes" / > bytes | May contain any arbitrary sequence of bytes. | string | ByteString | str |