You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

3.1 KiB

Scheduled PushTX

Schedule the delayed push of an ordered list of transactions (used for programmable Ricochet).

POST /pushtx/schedule

Parameters must be passed in the body of the request as json encoded arguments.

Parameters

  • script - ScriptStep[] - An array of ScriptStep objects defining the script.

ScriptStep structure

  • hop - integer - Index of this step in the script. Transactions are pushed by ascending order of hop values.

  • nlocktime - integer - Height of the block after which the transaction should be pushed to the network. This value shouldn't be set too far in the future (default tolerance is currently the height of current tip + 18 blocks). If step A has a hop value higher than step B, then step A MUST have a nlocktime greater than or equal to the nlocktime of step B. If step A and step B have the same hop value, then they MAY HAVE different nlocktime values.

  • tx - string - The raw transaction hex for the transaction to be pushed during this step. The transaction MUST HAVE its nLockTime field filled with the height of a block. The height of the block MUST BE equal to the value of the nlocktime field of the ScriptStep object.

  • strict_mode_vouts (optional) - int[] - An array of outpoints indices. A strict verification is enforced on these outpoints before the transaction is pushed. Strict mode checks that addresses associated to these outputs aren't reused. If verifications fail, the scheduled push is aborted and an error is returned.

Examples

Ricochet-like script


tx0 -- tx1 -- tx2 -- tx3 -- tx4

POST /pushtx/schedule

Request Body (JSON-encoded)
{
  "script": [{
    "hop": 0,
    "nlocktime": 549817,
    "tx": "<tx0_raw_hex>",
    "strict_mode_vouts": [0,1]
  }, {
    "hop": 1,
    "nlocktime": 549818,
    "tx": "<tx1_raw_hex>"
  }, {
    "hop": 2,
    "nlocktime": 549820,
    "tx": "<tx2_raw_hex>"
  }, {
    "hop": 3,
    "nlocktime": 549823,
    "tx": "<tx3_raw_hex>"
  },  {
    "hop": 4,
    "nlocktime": 549824,
    "tx": "<tx4_raw_hex>"
  }]
}

Serialized script with 2 parallel branches

       -- tx1 -- tx3 ---------
tx0 --|                       |-- tx5
       -- tx2 --------- tx4 --


POST /pushtx/schedule

Request Body (JSON-encoded)
{
  "script": [{
    "hop": 0,
    "nlocktime": 549817,
    "tx": "<tx0_raw_hex>"
  }, {
    "hop": 1,
    "nlocktime": 549818,
    "tx": "<tx1_raw_hex>"
  }, {
    "hop": 1,
    "nlocktime": 549818,
    "tx": "<tx2_raw_hex>"
  }, {
    "hop": 2,
    "nlocktime": 549819,
    "tx": "<tx3_raw_hex>"
  }, {
    "hop": 2,
    "nlocktime": 549820,
    "tx": "<tx4_raw_hex>"
  }, {
    "hop": 3,
    "nlocktime": 549821,
    "tx": "<tx5_raw_hex>"
  }]
}

Success

Status code 200 with JSON response:

{
  "status": "ok"
}

Failure

Status code 400 with JSON response:

{
  "status": "error",
  "error": "<error message>"
}

or status code 200 with JSON response:

{
  "status": "error",
  "error": {
    "message": [{
      "txid": "<txid>",
      "hop": <hop>,
      "vouts": [<vout>]
    }, ...],
    "code": "VIOLATION_STRICT_MODE_VOUTS"
  }
}