Skip to content

Latest commit

 

History

History
510 lines (356 loc) · 27.8 KB

API.md

File metadata and controls

510 lines (356 loc) · 27.8 KB

revaultd API

revaultd exposes a JSON-RPC 2.0 interface over a Unix Domain socket.

Note that all addresses are bech32-encoded version 0 native Segwit scriptPubKeys.

Command Description
getinfo Display general information
getrevocationtxs Retrieve the Revault revocation transactions to sign
getunvaulttx Retrieve the Revault unvault transaction to sign
getspendtx Retrieve the Revault spend transaction to sign
listpresignedtransactions List presigned transactions of a confirmed vault
listonchaintransactions List broadcast transactions of a vault
listvaults Display a paginated list of vaults
revocationtxs Give back the revocation transactions signed
unvaulttx Give back the unvault transaction signed
updatespendtx Store or update the stored Spend transaction
delspendtx Delete a stored Spend transaction
setspendtx Announce and broadcast this Spend transaction
listspendtxs List all stored Spend transactions
gethistory Retrieve history of funds
emergency Broadcast all Emergency signed transactions

Reference

General

getinfo

Display general information about the current daemon state.

Response

Field Type Description
blockheight integer Current block height
network string Answer can be mainnet, testnet, regtest
sync float The synchronization progress as percentage (0 < sync < 1)
version string Version following the SimVer format
vaults integer Current number of vaults (unconfirmed are included)
managers_threshold integer Number of managers needed for spending the unvault_tx

getdepositaddress

Get an address to build a deposit transaction.

Response

Field Type Description
index string (optional) Get a deposit address for a specific derivation index

Response

Field Type Description
address string An address for the N-of-N multisig deposit script

Vault

Vault statuses

Order Value Description
0 unconfirmed The vault's deposit transaction is less than 6 blocks-deep in the chain
1 funded The vault is initiated by a deposit transaction
2 securing We signed and shared the revocation transactions signatures for this vault
3 secured Everyone signed and shared the revocation transactions signatures for this vault
4 activating We signed and shared the Unvault transaction signature for this vault
5 active Everyone signed and shared the Unvault transaction signature for this vault
6 unvaulting The vault has its unvault tx broadcasted
7 unvaulted The vault has its unvault tx confirmed
8 cancelling The vault has its cancel tx broadcasted, funds are sent to an other vault
9 cancelled The vault has its cancel tx confirmed, funds are in an other vault
4 / 8 emergency_vaulting The vault has its emergency tx broadcasted, funds are sent to the Deep Emergency Vault
5 / 9 emergency_vaulted The vault has its emergency tx confirmed, funds are in the Deep Emergency Vault
8 spendable The vault has its unvault tx timelock expired and can be spent
9 spending The vault has a spending tx broadcasted
10 spent The vault has a spending tx confirmed, the vault is spent

Vault resource

Field Type Description
amount int Amount of the vault in satoshis
blockheight int Blockheight of the deposit transaction block
received_at int Timestamp of the deposit transaction reception time
status string Status of the vault (see vault statuses)
txid string Deposit txid of the vault deposit transaction
updated_at int Timestamp of the last status change
vout int Index of the deposit output in the deposit transaction.

Note that the scriptPubKey is implicitly known as we have the vault output Miniscript descriptor.

listvaults

The listvaults RPC command displays a list of vaults optionally filtered by either status or deposit outpoints.

Request

Parameter Type Description
status string array Vault status -- optional, see vault statuses for possible values
outpoints string array Vault IDs -- optional, filter the list with the given vault Outpoints

Response

Field Type Description
vaults array of vault resource Vaults filtered by status

listpresignedtransactions

List the presigned transactions for a list of given confirmed vaults. Will error if any of the vaults is unknown or not at least funded.

The output PSBTs may be unsigned, partially signed, or finalized (depending on each vault's state).

Parameter Type Description
outpoints string array Vault IDs -- optional, filter the list with the given vault Outpoints

Response

Field Type Description
presigned_transactions array of presigned txs Each vault's presigned transactions as PSBTs

Presigned txs

Field Type Description
vault_outpoint presigned_tx The vault deposit transaction outpoint.
unvault presigned_tx The Unvaulting transaction
cancel presigned_tx The Cancel transaction
emergency presigned_tx The Emergency transaction, or null if we are not a stakeholder
unvault_emergency presigned_tx The Unvault Emergency transaction, or null if we are not a stakeholder

Presigned tx

Field Type Description
psbt string The presigned transaction as a base64-encoded PSBT
hex string or null If fully-signed, the presigned transaction as a hex-encoded Bitcoin transaction

listonchaintransactions

List the transactions related to a list of vaults that were broadcast on the Bitcoin network (hence they may be unconfirmed). Will error if any of the vaults is unknown.

Parameter Type Description
outpoints string array Vault IDs -- optional, filter the list with the given vault Outpoints

Response

Field Type Description
onchain_transactions array of onchain txs Each vault's onchain transactions

Onchain txs

Field Type Description
vault_outpoint string The vault deposit transaction outpoint.
deposit wallet tx The deposit transaction, always there since vault exists
unvault wallet tx or null The Unvault transaction
cancel wallet tx or null The Cancel transaction
emergency wallet tx or null The Emergency transaction
unvault_emergency wallet tx or null The Unvault Emergency transaction
spend wallet tx or null The Spend transaction

Wallet tx

Field Type Description
blockheight int or null Height of the block containing the transaction, null if unconfirmed
hex string Hexadecimal of the network-serialized transaction
received_at int Transaction reception date as the number of seconds since UNIX epoch

getrevocationtxs

The getrevocationtxs RPC Command builds and returns the (unsigned) revocation transactions corresponding to a given vault. The call will fail if the outpoint does not refer to a known and confirmed (funded) vault.

Request

Parameter Type Description
outpoint string Deposit outpoint of the vault

Response

Field Type Description
cancel_tx string Base64-encoded Cancel transaction PSBT
emergency_tx string Base64-encoded Emergency transaction PSBT
emergency_unvault_tx string Base64-encoded Unvault Emergency transaction PSBT

revocationtxs

Hand signed PSBTs to the daemon. The PSBT may comport multiple signatures, but the call will error if the signature for "our" key is not part of this set.
See the flows for more information.

Request

Field Type Description
outpoint string Deposit outpoint of the vault
cancel_tx string Base64-encoded Cancel transaction PSBT
emergency_tx string Base64-encoded Emergency transaction PSBT
emergency_unvault_tx string Base64-encoded Unvault Emergency transaction PSBT

Response

None; the result field will be set to the empty object {}. Any value should be disregarded for forward compatibility.

getunvaulttx

The getunvaulttx RPC Command builds and returns the unvault transaction of the given vault.

Request

Parameter Type Description
outpoint string Deposit outpoint of the vault to activate

Response

Field Type Description
unvault_tx string Base64-encoded Unvault transaction PSBT

unvaulttx

Hand signed Unvault PSBT to the daemon. The PSBT may comport multiple signatures, but the call will error if the signature for "our" key is not part of this set.
Will error if the vault is not secured, or already active.
See the flows for more information.

Request

Field Type Description
outpoint string Deposit outpoint of the vault to activate
unvault_tx string Base64-encoded Unvault transaction PSBT

Response

None; the result field will be set to the empty object {}. Any value should be disregarded for forward compatibility.

getspendtx

The getspendtx RPC Command builds and returns the spend transaction given a set of vaults to spend.

Request

Parameter Type Description
outpoints string array Vault deposit outpoints -- vaults must be active
outputs map of string to int Map of Bitcoin addresses to amount
feerate int Target feerate for the transaction

Fee is deducted from the total amount of the vaults spent minus the total amount of the output.

feerate is tolerated to end up 10% below the target, or above if we can't create a change output.

Mind the addition of the CPFP output we do, which must be taken into account by the feerate.

Response

Field Type Description
spend_tx string Base64-encoded Spend transaction PSBT

updatespendtx

The updatespendtx RPC Command stores or update the stored Spend transaction with the given one.

Request

Field Type Description
spend_tx string Base64-encoded Spend transaction PSBT

Response

None; the result field will be set to the empty object {}. Any value should be disregarded for forward compatibility.

delspendtx

Request

Field Type Description
spend_txid string Hex encoded txid of the Spend transaction to delete

Response

None; the result field will be set to the empty object {}. Any value should be disregarded for forward compatibility.

listspendtxs

Request

Field Type Description
status array Array of Spend status
Spend status

Please note that this status refers only to the Spend transaction, with regarding to the signatures and the broadcast status. You'll have to manually fetch the vaults statuses if you want to know, for example, if the vault was canceled or not.

Value Description
non_final The Spend transaction is not final, we are awaiting signatures either from managers or cosigners
pending The transaction is not broadcasted to the Bitcoin network
broadcasted The Spend transaction has been broadcasted

Response

Field Type Description
spend_txs array Array of Spend transaction resources
Spend transaction resources
Field Type Description
deposit_outpoints string array Array of the deposit outpoints of the vaults this transaction spends
psbt string Base64-encoded Spend transaction PSBT
change_index integer Index of the change output, might be null
cpfp_index integer Index of the CPFP outputs

change_index and cpfp_index indicate the index of the change (if any) and CPFP outputs in the outputs array as created by getspendtransaction. This does not aim to tag all the outputs paying to either a CPFP or a Deposit descriptor, as that would be impossible to guarantee. If two outputs pay to the change, the index of the last one will be returned. If two outputs pay to the CPFP address, the index of the first one will be returned.

setspendtx

Request

Field Type Description
spend_txid string Txid of the Spend transaction to use

Response

None; the result field will be set to the empty object {}. Any value should be disregarded for forward compatibility.

gethistory

gethistory retrieves a paginated list of accounting events.

Aiming at giving an accounting point of view, the amounts returned by this call are the total of inflows and outflows net of any change amount (that is technically a transaction output, but not a cash outflow).

Request

Field Type Description
cursor int Timestamp of the date to retrieve events after
limit int Number of events to retrieve
kind string array Type of the events to retrieve, can be deposit, cancel, spend

Response

Field Type Description
events array Array of Event resource
Event Resource
Field Type Description
kind string Type of the event, can be deposit, cancel, spend
date int Timestamp of the event
amount int Absolute amount in satoshis that is entering or exiting the wallet
fee int Fee of the event transaction

emergency

Request

Field Type Description

Response

None; the result field will be set to the empty object {}. Any value should be disregarded for forward compatibility.

User flows

Stakeholder flows

Sign the revocation transactions

 HSM                  client                    revaultd
  +                      +                          +
  |                      |                          |
  |                      | +--+listvaults deposit+> |
  |                      | <--------vaults+-------+ |
  |                      |                          |
  |                      | +--getrevocationtxs----> |
  |                      | <----psbts-------------+ |
  |                      |                          |
  | <----sign emer-----+ |                          |
  | +------sig---------> |                          |
  |                      |                          |
  | <---sign cancel----+ |                          |
  | +------sig---------> |                          |
  |                      |                          |
  | <+sign unvault_emer+ |                          |
  | +------sig---------> |                          |
  |                      | +---revocationtxs------> |
  |                      |                          |
  +                      | +--+listvaults secure+-> |  // check if the watchtowers has the
                         | <--------vaults+-------+ |  // revocation transactions
                         +                          +

Sign the Unvault transaction

HSM                  client                      revaultd
 +                      +                          +
 |                      |                          |
 |                      | +---listvaults active--> |
 |                      | <--------vaults--------+ |
 |                      |                          |
 |                      | +--getunvaulttx--------> |
 |                      | <----psbt--------------+ |
 |                      |                          |
 | <----sign unvault--+ |                          |
 | +------sig---------> |                          |
 |                      | +----unvaulttx---------> |
 |                      |                          |
 +                      | +---listvaults active--> |  // check if the other stakeholders
                        | <--------vaults--------+ |  // have signed the unvault tx too
                        +                          +

Manager flow

HSM                client                      revaultd
  +                      +                          +
  |                      | +---listvaults active--> |
  |                      | <-------vaults---------+ |
  |                      |                          |
  |                      | +-------getspendtx-----> |
  |                      | <-----psbt or wt nack--+ |
  | <----sign spend tx-+ |                          |
  | +------sig---------> |                          |
  +                      |                          |
                         |                          |
client 2                 |                          |
  +                      |                          |
  | <---sign psbt------+ |                          |
  | +-----psbt---------> |                          |
  +                      | +---spendtx------------> | // if ack, cosign server sign
                         | <---OK or wt nack------+ | // then daemon broadcasts tx
                         |                          |
                         | +--listvaults----------> | // check vaults are spent
                         + ^------vaults----------+ +