# Scheduled PushTX Schedule the delayed push of an ordered list of transactions (used for programmable Ricochet). ``` POST /pushtx/schedule ``` ## 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. ### Examples Ricochet-like script ``` tx0 -- tx1 -- tx2 -- tx3 -- tx4 POST /pushtx/schedule Request Body (JSON-encoded) { "script": [{ "hop": 0, "nlocktime": 549817, "tx": "" }, { "hop": 1, "nlocktime": 549818, "tx": "" }, { "hop": 2, "nlocktime": 549820, "tx": "" }, { "hop": 3, "nlocktime": 549823, "tx": "" }, { "hop": 4, "nlocktime": 549824, "tx": "" }] } ``` 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": "" }, { "hop": 1, "nlocktime": 549818, "tx": "" }, { "hop": 1, "nlocktime": 549818, "tx": "" }, { "hop": 2, "nlocktime": 549819, "tx": "" }, { "hop": 2, "nlocktime": 549820, "tx": "" }, { "hop": 3, "nlocktime": 549821, "tx": "" }] } ``` #### Success Status code 200 with JSON response: ```json { "status": "ok" } ``` #### Failure Status code 400 with JSON response: ```json { "status": "error", "error": "" } ```