A Node.js library for creating Haven Apps using RPC or WebAssembly
- Supports wallet and daemon RPC clients.
- Supports client-side wallets in Node.js or the browser using WebAssembly.
- Supports multisig, view-only, and offline wallets.
- Wallet types are interchangeable by conforming to a common interface.
- Uses a clearly defined data model and API specification intended to be intuitive and robust.
- Query wallet transactions, transfers, and outputs by their properties.
- Fetch and process binary data from the daemon (e.g. raw blocks).
- Receive notifications when blocks are added to the chain or when wallets sync, send, or receive.
- Over 250 passing Mocha tests.
- Architecture
- Sample code
- Using monero-javascript in your project
- Building WebAssembly binaries from source
- Developer guide
- Running tests
- See also
- License
- Donations
Build Node.js or browser applications using RPC or WebAssembly bindings to monero-project/monero. Wallet implementations are interchangeable by conforming to a common interface, MoneroWallet.js.
This code introduces the API used in monero-javascript. See the JSDocs, API specification, or Mocha tests for more detail.
// import library
const monerojs = require("monero-javascript");
// connect to a daemon
let daemon = monerojs.connectToDaemonRpc("http://localhost:38081", "superuser", "abctesting123");
let height = await daemon.getHeight(); // 1523651
let feeEstimate = await daemon.getFeeEstimate(); // 1014313512
let txsInPool = await daemon.getTxPool(); // get transactions in the pool
// open wallet on monero-wallet-rpc
let walletRpc = monerojs.connectToWalletRpc("http://localhost:38083", "rpc_user", "abc123");
await walletRpc.openWallet("sample_wallet_rpc", "supersecretpassword123");
let primaryAddress = await walletRpc.getPrimaryAddress(); // 555zgduFhmKd2o8rPUz...
let balance = await walletRpc.getBalance(); // 533648366742
let txs = await walletRpc.getTxs(); // get transactions containing transfers to/from the wallet
// create wallet from mnemonic phrase using WebAssembly bindings to Monero Core
let walletWasm = await monerojs.createWalletWasm({
path: "sample_wallet_wasm",
password: "supersecretpassword123",
networkType: "stagenet",
serverUri: "http://localhost:38081",
serverUsername: "superuser",
serverPassword: "abctesting123",
mnemonic: "hefty value scenic...",
restoreHeight: 573936,
});
// synchronize with progress notifications
await walletWasm.sync(new class extends monerojs.MoneroWalletListener {
onSyncProgress(height, startHeight, endHeight, percentDone, message) {
// feed a progress bar?
}
});
// synchronize in the background
await walletWasm.startSyncing();
// listen for incoming transfers
let fundsReceived = false;
await walletWasm.addListener(new class extends monerojs.MoneroWalletListener {
onOutputReceived(output) {
let amount = output.getAmount();
let txHash = output.getTx().getHash();
fundsReceived = true;
}
});
// send funds from RPC wallet to WebAssembly wallet
let createdTx = await walletRpc.createTx({
accountIndex: 0,
address: await walletWasm.getAddress(1, 0),
amount: "250000000000", // send 0.25 XMR (denominated in atomic units)
relay: false // create transaction and relay to the network if true
});
let fee = createdTx.getFee(); // "Are you sure you want to send... ?"
await walletRpc.relayTx(createdTx); // relay the transaction
// recipient receives unconfirmed funds within 10 seconds
await new Promise(function(resolve) { setTimeout(resolve, 10000); });
assert(fundsReceived);
// save and close WebAssembly wallet
await walletWasm.close(true);
cd your_project
ormkdir your_project && cd your_project && npm init
npm install monero-javascript
- Add
require("monero-javascript")
to your application code.
- Download and install Monero CLI.
- Start monero-daemon-rpc, e.g.:
./monerod --stagenet
(or use a remote daemon). - Start monero-wallet-rpc, e.g.:
./monero-wallet-rpc --daemon-address http://localhost:38081 --stagenet --rpc-bind-port 38083 --rpc-login rpc_user:abc123 --wallet-dir ./
This project uses WebAssembly to package and execute Monero's source code for use in a browser or other WebAssembly-supported environments.
Compiled WebAssembly binaries are committed to ./dist for convenience, but these files can be built independently from source code:
- Install and activate emscripten
- Clone emscripten repository:
git clone https://github.com/emscripten-core/emsdk.git
cd emsdk
git pull && ./emsdk install latest-upstream && ./emsdk activate latest-upstream && source ./emsdk_env.sh
export EMSCRIPTEN=/absolute/path/to/emsdk/upstream/emscripten
(change for your system)
- Clone emscripten repository:
- Clone monero-javascript repository:
git clone https://github.com/monero-ecosystem/monero-javascript.git
cd monero-javascript
./bin/build_all.sh
- Installing prerequisites
- Getting started part 1: creating a Node.js application
- Getting started part 2: creating a web application
- Creating wallets
- The data model: blocks, transactions, transfers, and outputs
- Getting transactions, transfers, and outputs
- Sending funds
- Multisig wallets
- View-only and offline wallets
- HTTPS and self-signed certificates
- Clone the project repository:
git clone https://github.com/monero-ecosystem/monero-javascript.git
cd monero-javascript
- Start RPC servers:
- Download and install Monero CLI.
- Start monero-daemon-rpc, e.g.:
./monerod --stagenet
(or use a remote daemon). - Start monero-wallet-rpc, e.g.:
./monero-wallet-rpc --daemon-address http://localhost:38081 --stagenet --rpc-bind-port 38083 --rpc-login rpc_user:abc123 --wallet-dir ./
- Configure the appropriate RPC endpoints and authentication by modifying
WALLET_RPC_CONFIG
andDAEMON_RPC_CONFIG
in TestUtils.js.
- Run all tests:
npm test
- Run tests by their description:
node_modules/mocha/bin/mocha src/test/TestAll --grep "Can get transactions" --timeout 2000000
./bin/build_browser_tests.sh
- Access http://localhost:9100/tests.html in a browser
This project is licensed under MIT.
If this library brings you value, please consider donating.
46FR1GKVqFNQnDiFkH7AuzbUBrGQwz2VdaXTDD4jcjRE8YkkoTYTmZ2Vohsz9gLSqkj5EM6ai9Q7sBoX4FPPYJdGKQQXPVz