-
Notifications
You must be signed in to change notification settings - Fork 217
Wallet command line interface
The CLI is a proxy to the wallet server, which is required for most commands. Commands are turned into corresponding API calls, and submitted to an up-and-running server. Some commands do not require an active server and can be run "offline". (e.g. 'recovery-phrase generate')
The wallet command-line interface (abbrev. CLI) is a tool that provides a convenient way of using the cardano-wallet HTTP Application Programming Interface (abbrev. API). The wallet API is an HTTP service used to manage wallets, make payments, and update wallet data such as addresses and keys, for instance. The wallet CLI can start the wallet server, or run a number of commands on a running server, and supports most functions of the API itself.
The intended audience of the CLI are users who run a wallet API server outside of Daedalus and work with the cardano-wallet API directly - these include application developers, stake pool operators, and exchanges.
CLI commands allow you to make and track changes while maintaining the wallet API. The wallet CLI converts commands into corresponding API calls, submits them to a running server and display the server's responses in a readable way into the terminal.
-
Install cardano-node by following instruction on the release notes.
-
Download the
byronGenesis.json
initial configuration file from Cardano configurations.
You can explore the wallet CLI with:
$ cardano-wallet --help
Then, you can use a list of commands for various purposes, such as:
- list, create, update, or delete wallets
- create, submit, forget, or track fees in regards to transactions
- list, create, and import wallet addresses
- view network information and parameters
- manage private and public keys
Each sub-command will also provide some additional help when passed --help
. For example:
$ cardano-wallet transaction --help
Usage: cardano-wallet COMMAND Cardano Wallet Command-Line Interface (CLI) Available OPTIONS: -h | --help Available COMMANDS: serve Serve an HTTP API that listens for commands/actions. recovery-phrase generate Generate an English recovery phrase wallet list List all known wallets create from-recovery-phrase Create a new wallet using a recovery-phrase get Fetch a particular wallet utxo Get a wallet's UTxO distribution update passphrase Update a wallet's master passphrase name Update a wallet's name delete Forget a wallet and its metadata transaction create Create a transaction from a known wallet fees Estimate fees for a transaction list List the transactions associated with a wallet submit Submit an externally-signed transaction forget Forget a pending transaction with specified id get Get a transaction with specified id address list List all known addresses of a wallet create Create a new random address. import Import a random address generated elsewhere. network information View network information parameters View network parameters clock View NTP offset key from-recovery-phrase Convert a recovery phrase to an extended private key child Derive child keys from a parent public or private key public Get the public counterpart of a private key inspect Show information about a key stake-pool list List all known stake pools version Show the program's current version
ℹ️ The CLI commands for
wallet
,transaction
andaddress
only output valid JSON onstdout
. So you may redirect the output to a file with>
or pipe it into utility softwares likejq
!
💝 For bash/zsh auto-completion, put the following script in your
/etc/bash_completion.d
:cardano-wallet.sh
_cardano-wallet() { local CMDLINE local IFS=$'\n' CMDLINE=(--bash-completion-index $COMP_CWORD) for arg in ${COMP_WORDS[@]}; do CMDLINE=(${CMDLINE[@]} --bash-completion-word $arg) done COMPREPLY=( $(cardano-wallet "${CMDLINE[@]}") ) } complete -o filenames -F _cardano-wallet cardano-wallet
Serve API that listens for commands/actions. Before launching user should start cardano-node
.
cardano-wallet serve --help-tracing Show help for tracing options --listen-address HOST Specification of which host to the bind API server to. Can be an IPv[46] address, hostname, or '*'. (default: 127.0.0.1) --random-port serve wallet API on any available port (conflicts with --port) --port INT port used for serving the wallet API. (default: 8090) --tls-ca-cert FILE A x.509 Certificate Authority (CA) certificate. --tls-sv-cert FILE A x.509 Server (SV) certificate. --tls-sv-key FILE The RSA Server key which signed the x.509 server certificate. --node-socket FILE Path to the node's domain socket (POSIX) or pipe name (Windows). --mainnet Use Cardano mainnet protocol --testnet FILE Path to the byron genesis data in JSON format. --staging FILE Path to the byron genesis data in JSON format. --database DIR use this directory for storing wallets. Run in-memory otherwise. --sync-tolerance DURATION time duration within which we consider being synced with the network. Expressed in seconds with a trailing 's'. (default: 300s) --shutdown-handler Enable the clean shutdown handler (exits when stdin is closed) --log-level SEVERITY Global minimum severity for a message to be logged. Individual tracers severities still need to be configured independently. Defaults to "DEBUG". --trace-NAME SEVERITY Individual component severity for 'NAME'. See --help-tracing for details and available tracers.
In order to start the wallet server, you'll need to provide at least the path to cardano-node's socket/pipe and a target network. That socket is automatically created when starting a cardano-node and it exists so long as the node remains running.
We also recommend to pass a --database
option pointing to a directory on the file-system; without this option, the wallet will maintain a state in-memory which will vanish once stopped.
By default, the wallet runs on a single core which is sufficient for most 'normal users'. Application running larger wallets like exchanges should configure the server to use multiple cores for some database blocking operations may have a visible negative effect on the overall server behavior. This can be achieved by providing specific runtime flags to the serve command delimited by +RTS <flags> -RTS
. To configure the how much cores are available to the server, use the -N
flag. For example, to configure 2 cores do:
cardano-wallet serve ... +RTS -N2 -RTS
Using +RTS -N4 -RTS
will tell the server to use 4 cores. Note that there's little performance benefits between 2 and 4 cores for server running a single wallet, but there are visible performance improvements from 1 to 2.
On POSIX systems (i.e. Linux and macOS), a UNIX domain socket is used for communication between the cardano-wallet and cardano-node processes.
On these systems, the --node-socket
argument must be a path to a socket file. Note that there is a limitation on socket path lengths of about 100 characters or so.
On Windows systems, a Named Pipe is used instead.
Windows Named Pipes do not have filenames. So on Windows systems, the --node-socket
argument must be a pipe name. Pipe names are a string of the form \\.\pipe\name
. For example, \\.\pipe\cardano-wallet
.
cardano-wallet serve \
--mainnet \
--node-socket CARDANO_NODE_SOCKET_PATH_OR_PIPE \
--database ./wallets-mainnet
Note that for testnets, a byron genesis file is required (see pre-requisites), even though the network is in the shelley era. This is because the chain is synced from the beginning of the first era.
cardano-wallet serve \
--testnet testnet-byron-genesis.json \
--node-socket CARDANO_NODE_SOCKET_PATH_OR_PIPE \
--database ./wallets-testnet
serve
accepts extra command-line arguments for logging (also called "tracing"). Use --help-tracing
to show the
options, the tracer names, and the possible log levels.
cardano-wallet serve --help-tracing
Additional tracing options:
--log-level SEVERITY Global minimum severity for a message to be logged.
Defaults to "DEBUG" unless otherwise configured.
--trace-NAME=off Disable logging on the given tracer.
--trace-NAME=SEVERITY Set the minimum logging severity for the given
tracer. Defaults to "INFO".
The possible log levels (lowest to highest) are:
debug info notice warning error critical alert emergency
The possible tracers are:
application About start-up logic and the server's surroundings.
api-server About the HTTP API requests and responses.
wallet-engine About background wallet workers events and core wallet engine.
wallet-db About database operations of each wallet.
pools-engine About the background worker monitoring stake pools and stake pools engine.
pools-db About database operations on stake pools.
ntp-client About ntp-client.
network About network communication with the node.
Use these options to enable debug-level tracing for certain components of the wallet. For example, to log all database queries for the wallet databases, use:
$ cardano-wallet serve --trace-wallet-db=debug ...
cardano-wallet recovery-phrase generate [--size=INT]
Generates an English recovery phrase.
$ cardano-wallet recovery-phrase generate
These words will be used to create a wallet later. You may also ask for a specific number of words using the --size
option:
$ cardano-wallet recovery-phrase generate --size 21
cardano-wallet wallet list [--port=INT]
Lists all your wallets:
$ cardano-wallet wallet list
cardano-wallet wallet create from-recovery-phrase [--port=INT] <name> [--address-pool-gap=INT]
Create a new wallet using a sequential address scheme. This is an interactive command that will prompt you for recovery-phrase words and password.
$ cardano-wallet wallet create "My Wallet"
Please enter a 15–24 word recovery-phrase sentence: <enter generated recovery-phrase here>
(Enter a blank line if you do not wish to use a second factor.)
Please enter a 9–12 word recovery-phrase second factor: <skip or enter new recovery-phrase here>
Please enter a passphrase: ****************
Enter the passphrase a second time: ****************
after this your new wallet will be created
cardano-wallet wallet get [--port=INT] WALLET_ID
Fetches the wallet with specified wallet id:
$ cardano-wallet wallet get 2512a00e9653fe49a44a5886202e24d77eeb998f
cardano-wallet wallet utxo [--port=INT] WALLET_ID
Visualize a wallet's UTxO distribution in the form of an histrogram with a logarithmic scale. The distribution's data is returned by the API in a JSON format, e.g.:
{
"distribution": {
"10": 1,
"100": 0,
"1000": 8,
"10000": 14,
"100000": 32,
"1000000": 3,
"10000000": 0,
"100000000": 12,
"1000000000": 0,
"10000000000": 0,
"100000000000": 0,
"1000000000000": 0,
"10000000000000": 0,
"100000000000000": 0,
"1000000000000000": 0,
"10000000000000000": 0,
"45000000000000000": 0
}
}
which could be plotted as:
│
100 ─
│
│ ┌───┐
10 ─ ┌───┐ │ │ ┌───┐
│ ┌───┐ │ │ │ │ │ │
│ │ │ │ │ │ │ ┌───┐ │ │
1 ─ ┌───┐ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ ╷ │ │ ╷ │ │ ╷ ╷ │ │ ╷
└─┘ └─│───────│─┘ └─│─┘ └─│─┘ └─│─┘ └─│───────│─┘ └──────│────────────
10μ₳ 100μ₳ 1000μ₳ 0.1₳ 1₳ 10₳ 100₳ 1000₳
cardano-wallet wallet update name [--port=INT] WALLET_ID STRING
Updates name of a wallet given wallet id:
$ cardano-wallet wallet update name 2512a00e9653fe49a44a5886202e24d77eeb998f NewName
cardano-wallet wallet update passphrase [--port=INT] WALLET_ID
Interactive prompt to update the wallet master's passphrase (old passphrase required).
$ cardano-wallet wallet update passphrase 2512a00e9653fe49a44a5886202e24d77eeb998f
Please enter your current passphrase: **********
Please enter a new passphrase: **********
Enter the passphrase a second time: **********
cardano-wallet wallet delete [--port=INT] WALLET_ID
Deletes wallet with specified wallet id:
$ cardano-wallet wallet delete 2512a00e9653fe49a44a5886202e24d77eeb998f
cardano-wallet transaction create [--port=INT] WALLET_ID [--metadata=JSON] [--ttl=SECONDS] --payment=PAYMENT...
Creates and submits a new transaction:
$ cardano-wallet transaction create 2512a00e9653fe49a44a5886202e24d77eeb998f \
--payment [email protected] \
--payment [email protected] \
--metadata '{ "0":{ "string":"cardano" } }'
This creates a transaction that sends 22 lovelace to Ae2tdPwUPEZ...nRtbfw6EHRv1D
and 5 lovelace to Ae2tdPwUPEZ7...pVwEPhKwseVvf
from wallet with id 2512a00e9653fe49a44a5886202e24d77eeb998f.
For more information about the --metadata
option, see TxMetadata.
cardano-wallet transaction fees [--port=INT] WALLET_ID [--metadata=JSON] [--ttl=SECONDS] --payment=PAYMENT...
Estimates fee for a given transaction:
$ cardano-wallet transaction fees 2512a00e9653fe49a44a5886202e24d77eeb998f \
--payment [email protected] \
--payment [email protected] \
--metadata '{ "0":{ "string":"cardano" } }'
This estimates fees for a transaction that sends 22 lovelace to Ae2tdPwUPEZ...nRtbfw6EHRv1D
and 5 lovelace to Ae2tdPwUPEZ7...pVwEPhKwseVvf
from wallet with id 2512a00e9653fe49a44a5886202e24d77eeb998f.
cardano-wallet transaction list [--port INT] WALLET_ID [--start TIME] [--end TIME] [--order ORDER]
List all incoming and outgoing transactions for the wallet:
$ cardano-wallet transaction list 2512a00e9653fe49a44a5886202e24d77eeb998f \
--start 2018-09-25T10:15:00Z \
--end 2019-11-21T10:15:00Z \
--order ascending
This lists all transactions between 2018-09-25T10:15:00Z
and 2019-11-21T10:15:00Z
in ascending
order.
cardano-wallet transaction submit [--port INT] BINARY_BLOB
Submit transaction prepared and signed outside of the wallet:
$ cardano-wallet transaction submit 00bf02010200000...d21942304
Sends transaction identified by a hex-encoded BINARY_BLOB of externally-signed transaction.
cardano-wallet transaction forget [--port INT] WALLET_ID TRANSACTION_ID
Forget pending transaction for a given wallet:
$ cardano-wallet transaction forget 2512a00e9653fe49a44a5886202e24d77eeb998f 3e6ec12da4414aa0781ff8afa9717ae53ee8cb4aa55d622f65bc62619a4f7b12
cardano-wallet transaction get [--port INT] WALLET_ID TRANSACTION_ID
Get a transaction with the specified id:
$ cardano-wallet transaction get 2512a00e9653fe49a44a5886202e24d77eeb998f 3e6ec12da4414aa0781ff8afa9717ae53ee8cb4aa55d622f65bc62619a4f7b12
cardano-wallet address list [--port=INT] WALLET_ID [--state=STRING]
List all known (used or not) addresses and their corresponding status.
$ cardano-wallet list addresses 2512a00e9653fe49a44a5886202e24d77eeb998f
cardano-wallet address create [--port INT] [--address-index INDEX] WALLET_ID
Create new address for random wallet.
$ cardano-wallet address create 03f4c150aa4626e28d02be95f31d3c79df344877
Please enter your passphrase: *****************
Ok.
{
"state": "unused",
"id": "2w1sdSJu3GVgr1ic6aP3CEwZo9GAhLzigdBvCGY4JzEDRbWV4HUNpZdHf2n5fV41dGjPpisDX77BztujAJ1Xs38zS8aXvN7Qxoe"
}
cardano-wallet address import [--port INT] WALLET_ID ADDRESS
Import address belonging to random wallet.
cardano-wallet network information [--port=INT]
View network information and syncing progress between the node and the blockchain.
$ cardano-wallet network information
cardano-wallet network parameters [--port=INT] EPOCH_NUMBER
View network parameters. EPOCH_NUMBER can be latest
or valid epoch number (not later than the current one), ie., 0
, 1
, .. .
$ cardano-wallet network parameters latest
cardano-wallet network clock
View NTP offset for cardano-wallet server in microseconds.
$ cardano-wallet network clock
Ok.
{
"status": "available",
"offset": {
"quantity": -30882,
"unit": "microsecond"
}
}
⚠️ At this stage the command is not supported on Windows platform. Invoked on Windows will returnstatus: unavailable
in the response message.
Extract the root extended private key from a recovery phrase. New recovery phrases can be generated using recovery-phrase generate
.
Usage: cardano-wallet key from-recovery-phrase ([--base16] | [--base58] | [--bech32]) STYLE Convert a recovery phrase to an extended private key Available options: -h,--help Show this help text STYLE Byron | Icarus | Jormungandr | Shelley The recovery phrase is read from stdin.
Example:
$ cardano-wallet recovery-phrase generate | cardano-wallet key from-recovery-phrase Icarus
xprv12qaxje8hr7fc0t99q94jfnnfexvma22m0urhxgenafqmvw4qda0c8v9rtmk3fpxy9f2g004xj76v4jpd69a40un7sszdnw58qv527zlegvapwaee47uu724q4us4eurh52m027kk0602judjjw58gffvcqzkv2hs
Derive child key from root private key. The parent key is read from standard input.
Usage: cardano-wallet key child ([--base16] | [--base58] | [--bech32]) [--legacy] DERIVATION-PATH Derive child keys from a parent public/private key Available options: -h,--help Show this help text DERIVATION-PATH Slash-separated derivation path. Hardened indexes are marked with a 'H' (e.g. 1852H/1815H/0H/0). The parent key is read from stdin.
$ cardano-wallet recovery-phrase generate | cardano-wallet key from-recovery-phrase Icarus > root.xprv
$ cat root.xprv | cardano-wallet key child 44H/1815H/0H/0
xprv13parrg5g83utetrwsp563w7hps2chu8mwcwqcrzehql67w9k73fq8utx6m8kgjlhle8claexrtcu068jgwl9zj5jyce6wn2k340ahpmglnq6x8zkt7plaqjgads0nvmj5ahav35m0ss8q95djl0dcee59vvwkaya
Extract the public key of an extended private key. Keys can be obtained using key from-recovery-phrase
and key child
.
Usage: cardano-wallet-jormungandr key public ([--base16] | [--base58] | [--bech32]) Get the public counterpart of a private key Available options: -h,--help Show this help text The private key is read from stdin.
$ cardano-wallet recovery-phrase generate | cardano-wallet key from-recovery-phrase Icarus > root.xprv
$ cat root.xprv | cardano-wallet key public
xpub1le8gm0m5cesjzzjqlza4476yncp0yk2jve7cce8ejk9cxjjdama24hudzqkrxy4daxwmlfq6ynczj338r7f5kzs43xs2fkmktekd4fgnc8q98
Usage: cardano-wallet-jormungandr key inspect Show information about a key Available options: -h,--help Show this help text The parent key is read from stdin.
Usage: cardano-wallet stake-pool list [--port INT] [--stake STAKE] List all known stake pools. Available options: -h,--help Show this help text --port INT port used for serving the wallet API. (default: 8090) --stake STAKE The stake you intend to delegate, which affects the rewards and the ranking of pools.
cardano-wallet version
Show the software version.