HTTP interface for Stream Transactions
Stream Transactions allow you to perform a multi-document transaction with individual begin and commit/abort commands
For an introduction to this transaction type, see Stream Transactions.
To use a Stream Transaction, a client first sends the configuration of the transaction to the ArangoDB server.
action attribute is supported.The Stream Transaction API works in conjunction with other APIs in ArangoDB.
To use the transaction for a supported operation a client needs to specify
the transaction identifier in the x-arango-trx-id HTTP header on each request.
This automatically causes these operations to use the specified transaction.
Supported transactional API operations include:
- All operations in the Document API
- Get the number of documents via the Collection API
- Truncate a collection via the Collection API
- Create an AQL cursor via the Cursor API
- Handle nodes and edges of managed graphs (General Graph / Gharial API)
Begin a Stream Transaction
Begin a Stream Transaction that allows clients to call selected APIs over a short period of time, referencing the transaction ID, and have the server execute the operations transactionally.
Committing or aborting a running transaction must be done by the client. It is bad practice to not commit or abort a transaction once you are done using it. It forces the server to keep resources and collection locks until the entire transaction times out.
The transaction description must be passed in the body of the POST request. If the transaction can be started on the server, HTTP 201 is returned.
For successfully started transactions, the returned JSON object has the following properties:
- error: boolean flag to indicate if an error occurred (- falsein this case)
- code: the HTTP status code
- result: result containing- id: the identifier of the transaction
- status: containing the string ‘running’
 
If the transaction specification is either missing or malformed, the server responds with HTTP 400 or HTTP 404.
The body of the response then contains a JSON object with additional error details. The object has the following attributes:
- error: boolean flag to indicate that an error occurred (- truein this case)
- code: the HTTP status code
- errorNum: the server error number
- errorMessage: a descriptive error message
- x-arango-allow-dirty-read boolean- Set this header to - trueto allow the Coordinator to ask any shard replica for the data, not only the shard leader. This may result in “dirty reads”.- This header decides about dirty reads for the entire transaction. Individual read operations, that are performed as part of the transaction, cannot override it. 
- collections* object- Must be a JSON object that can have one or all sub-attributes - read,- writeor- exclusive, each being an array of collection names or a single collection name as string. Collections that will be written to in the transaction must be declared with the- writeor- exclusiveattribute or it will fail, whereas non-declared collections from which is solely read will be added lazily.
- skipFastLockRound boolean (default:- false)- Whether to disable fast locking for write operations. - Skipping the fast lock round can be faster overall if there are many concurrent Stream Transactions queued that all try to lock the same collection exclusively. It avoids deadlocking and retrying which can occur with the fast locking by guaranteeing a deterministic locking order at the expense of each actual locking operation taking longer. - Fast locking should not be skipped for read-only Stream Transactions because it degrades performance if there are no concurrent transactions that use exclusive locks on the same collection. 
Examples
Executing a transaction on a single collection
curl -X POST --header 'accept: application/json' --data-binary @- --dump - 'http://localhost:8529/_api/transaction/begin' <<'EOF'
{
  "collections": {
    "write": "products"
  }
}
EOFShow output
HTTP/1.1 201 Created
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 69
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "code" : 201, 
  "error" : false, 
  "result" : { 
    "id" : "72735", 
    "status" : "running" 
  } 
}Referring to a non-existing collection
curl -X POST --header 'accept: application/json' --data-binary @- --dump - 'http://localhost:8529/_api/transaction/begin' <<'EOF'
{
  "collections": {
    "read": "products"
  }
}
EOFShow output
HTTP/1.1 404 Not Found
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 97
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "code" : 404, 
  "error" : true, 
  "errorMessage" : "collection or view not found: products", 
  "errorNum" : 1203 
}Get the status of a Stream Transaction
The result is an object describing the status of the transaction. It has at least the following attributes:
- id: the identifier of the transaction
- status: the status of the transaction. One of “running”, “committed” or “aborted”.
Examples
Get transaction status
curl --header 'accept: application/json' --dump - 'http://localhost:8529/_api/transaction/72746'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 69
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "code" : 200, 
  "error" : false, 
  "result" : { 
    "id" : "72746", 
    "status" : "running" 
  } 
}Commit a Stream Transaction
Commit a running server-side transaction. Committing is an idempotent operation. It is not an error to commit a transaction more than once.
If the transaction can be committed, HTTP 200 is returned. The returned JSON object has the following properties:
- error: boolean flag to indicate if an error occurred (- falsein this case)
- code: the HTTP status code
- result: result containing- id: the identifier of the transaction
- status: containing the string ‘committed’
 
If the transaction cannot be found, committing is not allowed or the transaction was aborted, the server responds with HTTP 400, HTTP 404 or HTTP 409.
The body of the response then contains a JSON object with additional error details. The object has the following attributes:
- error: boolean flag to indicate that an error occurred (- truein this case)
- code: the HTTP status code
- errorNum: the server error number
- errorMessage: a descriptive error message
Examples
Committing a transaction:
curl -X PUT --header 'accept: application/json' --dump - 'http://localhost:8529/_api/transaction/72756'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 71
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "code" : 200, 
  "error" : false, 
  "result" : { 
    "id" : "72756", 
    "status" : "committed" 
  } 
}Abort a Stream Transaction
Abort a running server-side transaction. Aborting is an idempotent operation. It is not an error to abort a transaction more than once.
If the transaction can be aborted, HTTP 200 is returned. The returned JSON object has the following properties:
- error: boolean flag to indicate if an error occurred (- falsein this case)
- code: the HTTP status code
- result: result containing- id: the identifier of the transaction
- status: containing the string ‘aborted’
 
If the transaction cannot be found, aborting is not allowed or the transaction was already committed, the server responds with HTTP 400, HTTP 404 or HTTP 409.
The body of the response then contains a JSON object with additional error details. The object has the following attributes:
- error: boolean flag to indicate that an error occurred (- truein this case)
- code: the HTTP status code
- errorNum: the server error number
- errorMessage: a descriptive error message
Examples
Aborting a transaction:
curl -X DELETE --header 'accept: application/json' --dump - 'http://localhost:8529/_api/transaction/72766'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 69
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "code" : 200, 
  "error" : false, 
  "result" : { 
    "id" : "72766", 
    "status" : "aborted" 
  } 
}List the running Stream Transactions
The result is an object with the transactions attribute, which contains
an array of transactions.
In a cluster, the array contains the transactions from all Coordinators.
Each array entry contains an object with the following attributes:
- id: the transaction’s id
- state: the transaction’s status
Examples
Get currently running transactions
curl --header 'accept: application/json' --dump - 'http://localhost:8529/_api/transaction'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 51
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "transactions" : [ 
    { 
      "id" : "72776", 
      "state" : "running" 
    } 
  ] 
}
