Callback request format
Request header
To successfully process requests coming from Acronis API Callback Gateway, your callback handler must check the following headers, which are sent with each request:
AuthorizationAn authorization header containing a JWT (JSON Web Token) signed by Acronis. The value format isBearer <jwt>
, where<jwt>
is the JWT.See Request verification for more details. X-CyberApp-AuthAn authentication header containing the base64-encoded credentials from your cloud.The credentials format is<identity>:<secrets>
, where<identity>
is an identity registered in your service (such as a username, API client ID, etc.) in plain text format and<secrets>
is a JSON text (such as{\"<model_property>\": <value>}
) containing secrets (such as passwords, private keys, etc.) that are used to authenticate the identity.See UI builder for more details.Note
To parse X-CyberApp-Auth correctly, your callback handler must implement a function that splits the credentials into two parts at the first colon (:
). The left part must be interpreted as plain text and the right part as JSON.You can use the following Python script as a reference:from base64 import b64decode import json # Decode the request header credentials = b64decode(request.headers['X-CyberApp-Auth']).decode() # Find the first colon position sep_pos = credentials.index(':') # Collect the <identity> part as plain text identity = credentials[:sep_pos] # Collect the <secrets> part and load as JSON secrets = json.loads(credentials[sep_pos + 1:])For more details on authentication handling, see our callback handler example here.
X-CyberApp-ExtraA header containing extra data specified by you.The data is formatted as a base64-encoded JSON text.For example, if extra data was not provided, the header will contain thee30=
base64-encoded string, which is decoded to the{}
JSON string and can be parsed with a JSON parser.
Request body
Callback requests sent by Acronis API Callback Gateway include the following fields, which the callback handler must process:
Field |
Type |
Description |
---|---|---|
|
string |
The callback request identifier. The callback handler can verify whether this identifier matches the one defined for this callback. Example: |
|
string |
The request UUID. |
|
string |
The date the request was made, in RFC3339 format. |
|
object |
Contains information about the context of the request. |
|
string |
The callback identifier. The callback handler must use this identifier to identify which action needs to be done and which responses can be provided. Example: |
|
string |
The endpoint identifier. The callback handler can use this identifier to verify whether the request was intended for the endpoint where it is located. |
|
string |
An identifier of the Acronis tenant ID from which the request was made. The callback handler may use this tenant ID to perform actions or return the data in the scope of the provided tenant ID. |
|
string |
The URL of the Acronis data center from which the request was made. |
|
object |
An object containing the data structure specified for the callback request. This is optional. |