Cardano Addresses
This module provides mnemonic (backup phrase) creation, and conversion of a mnemonic to seed for wallet restoration, and address derivation functionalities.
Haddock API documentation is available here.
CLI documentation is available here
cardano-addresses is officially supported on the following operating systems:
- Linux - Ubuntu 20.04+, Debian 11+, Fedora 38+, and other major distributions
- macOS - version 11 (Big Sur) and later
- Windows - Windows 10 and Windows 11
cardano-addresses comes with CLI for Linux, MacOS and Windows. See releases to get respective pre-compiled binaries. There is also straightforward way to build Docker image.
Prerequisites: Install Nix with flakes enabled.
nix developInside the development shell:
# building
cabal build all
# testing
cabal test cardano-addresses:unit
# installing executable locally
cabal install cardano-address# Build the Linux x86_64 binary
nix build .
# Run the built binary
./result/bin/cardano-address# Linux x86_64
nix build .
# Darwin x86_64
nix build .#packages.x86_64-darwin.default
# Darwin aarch64 (Apple Silicon)
nix build .#packages.aarch64-darwin.default
# Linux aarch64
nix build .#packages.aarch64-linux.default
# Linux x86_64 to Windows (cross-compilation)
nix build .#packages.x86_64-linux.defaultnix build .#packages.x86_64-linux.docker-image
docker load < resultWe have now fixed cross-compilation (from Linux to Windows) by replacing runtime git call in System.Git.TH with CPP macro (ie., GITREV) defaulting to "unknown" but allowing overriding via -DGITREV as below:
cabal build all --ghc-option=-DGITREV=\"$(git rev-parse HEAD)\"cabal build all
cabal haddock
cabal sdistNote: Make sure proper version is set in cardano-addresses.cabal
Please make sure you have just installed as justfile is used for building Docker image.
just clean-build-dockerUse the auto-remove flag --rm when running commands.
docker run --rm cardano-address recovery-phrase generate --size 15Use the interactive flag -i when piping stdin:
echo "addr1gqtnpvdhqrtpd4g424fcaq7k0ufuzyadt7djygf8qdyzevuph3wczvf2dwyx5u" | docker run --rm -i cardano-addresses address inspectJavascript support was discontinued and dropped. One could look at the following now:
Alternatively one could lean back on release 3.9.0 where Javascript was still present.
The library compiles to WebAssembly via GHC's WASM backend, producing a single cardano-addresses.wasm binary that runs in the browser or any WASI runtime.
nix build github:IntersectMBO/cardano-addresses#wasm
ls result/cardano-addresses.wasm # 7.0MBThe binary reads JSON from stdin and writes JSON to stdout. A cmd field selects the operation:
# Address inspection
echo '{"cmd":"inspect","address":"addr1..."}' | wasmtime result/cardano-addresses.wasm
# Key derivation (CIP-1852 Shelley)
echo '{"cmd":"derive","mnemonic":"word1 word2 ...","path":"1852H/1815H/0H/0/0"}' | wasmtime result/cardano-addresses.wasm
# Address construction
echo '{"cmd":"make-address","type":"enterprise","network":"testnet","payment_key":"hex..."}' | wasmtime result/cardano-addresses.wasm
# Ed25519 signing and verification
echo '{"cmd":"sign","key":"hex...","message":"hex..."}' | wasmtime result/cardano-addresses.wasm
echo '{"cmd":"verify","key":"hex...","message":"hex...","signature":"hex..."}' | wasmtime result/cardano-addresses.wasm
# Legacy bootstrap addresses (Byron/Icarus)
echo '{"cmd":"bootstrap-address","style":"icarus-from-mnemonic","protocol_magic":764824073,...}' | wasmtime result/cardano-addresses.wasmUse @bjorn3/browser_wasi_shim to run the WASM binary client-side:
import { WASI, File, OpenFile, ConsoleStdout } from "@bjorn3/browser_wasi_shim";
const mod = await WebAssembly.compile(await (await fetch("cardano-addresses.wasm")).arrayBuffer());
async function call(input) {
let out = "";
const fds = [
new OpenFile(new File(new TextEncoder().encode(input))),
ConsoleStdout.lineBuffered(l => out += l + "\n"),
ConsoleStdout.lineBuffered(() => {}),
];
const wasi = new WASI([], [], fds, { debug: false });
wasi.start(await WebAssembly.instantiate(mod, { wasi_snapshot_preview1: wasi.wasiImport }));
return JSON.parse(out.trim());
}Benchmarked: ~9ms compile (one-time), ~3ms per Shelley call, ~13ms for legacy.
A live demo is available at: https://IntersectMBO.github.io/cardano-addresses/browser/
Downstream flakes consume the WASM as a package:
{
inputs.cardano-addresses.url = "github:IntersectMBO/cardano-addresses";
outputs = { cardano-addresses, ... }: {
packages.wasm = cardano-addresses.packages.x86_64-linux.wasm;
# result/cardano-addresses.wasm
};
}Pull requests are welcome.
When creating a pull request, please make sure that your code adheres to our coding standards.
