Piratewallet Lightclient Library and CLI interface (with modifications to support Qortal cross-chain trades)
Go to file
2022-08-07 16:55:38 +01:00
.github/workflows Fix github actions build 2020-04-04 08:48:31 -07:00
cli Implement support for detection of diversified addressess 2021-11-16 07:27:32 -08:00
docker port to pirate 2021-03-03 21:12:13 -08:00
lib Updated coin checkpoints location. 2022-08-07 16:55:38 +01:00
res Add --dangerous support 2020-02-04 10:06:23 -08:00
zcash-params Embed sapling params 2019-09-30 12:13:43 -07:00
.gitignore Add Cargo lock 2019-12-02 10:44:06 -08:00
bip39bug.md update copy 2019-10-20 13:14:34 -07:00
Cargo.lock Implement support for detection of diversified addressess 2021-11-16 07:27:32 -08:00
Cargo.toml Refactor into cargo workspace 2019-10-22 13:21:18 -07:00
coin-checkpoint.json Added checkpoint for block 2000000 2022-08-07 16:49:14 +01:00
mkrelease.sh Correctly gen version 2020-04-30 17:57:20 -07:00
README.md newline cleanup 2020-08-05 21:55:33 -07:00
rust-toolchain set toolchain version 2022-04-25 22:36:32 -07:00

Zecwallet CLI - A command line ZecWallet light client.

zecwallet-cli is a command line ZecWallet light client. To use it, download the latest binary from the releases page and run ./zecwallet-cli

This will launch the interactive prompt. Type help to get a list of commands

Running in non-interactive mode:

You can also run zecwallet-cli in non-interactive mode by passing the command you want to run as an argument. For example, zecwallet-cli addresses will list all wallet addresses and exit. Run zecwallet-cli help to see a list of all commands.

Privacy

  • While all the keys and transaction detection happens on the client, the server can learn what blocks contain your shielded transactions.
  • The server also learns other metadata about you like your ip address etc...
  • Also remember that t-addresses don't provide any privacy protection.

Notes:

  • If you want to run your own server, please see zecwallet lightwalletd, and then run ./zecwallet-cli --server http://127.0.0.1:9067.
  • The log file is in ~/.zero/zerowallet-light-wallet.debug.log. Wallet is stored in ~/.zero/zerowallet-light-wallet.dat

Note Management

Zecwallet-CLI does automatic note and utxo management, which means it doesn't allow you to manually select which address to send outgoing transactions from. It follows these principles:

  • Defaults to sending shielded transactions, even if you're sending to a transparent address
  • Sapling funds need at least 5 confirmations before they can be spent
  • Can select funds from multiple shielded addresses in the same transaction
  • Will automatically shield your transparent funds at the first opportunity
    • When sending an outgoing transaction to a shielded address, Zecwallet-CLI can decide to use the transaction to additionally shield your transparent funds (i.e., send your transparent funds to your own shielded address in the same transaction)

Compiling from source

Pre-requisites

  • Rust v1.37 or higher.
    • Run rustup update to get the latest version of Rust if you already have it installed
  • Rustfmt
    • Run rustup component add rustfmt to add rustfmt
  • Build tools
    • Please install the build tools for your platform. On Ubuntu sudo apt install build-essential gcc
git clone https://github.com/adityapk00/zecwallet-light-cli.git
cargo build --release
./target/release/zecwallet-cli

Options

Here are some CLI arguments you can pass to zecwallet-cli. Please run zecwallet-cli --help for the full list.

  • --server: Connect to a custom zecwallet lightwalletd server.
    • Example: ./zecwallet-cli --server 127.0.0.1:9067
  • --seed: Restore a wallet from a seed phrase. Note that this will fail if there is an existing wallet. Delete (or move) any existing wallet to restore from the 24-word seed phrase
    • Example: ./zecwallet-cli --seed "twenty four words seed phrase"
  • --recover: Attempt to recover the seed phrase from a corrupted wallet