@carnesen/bitcoind
A Node.js library for managing the bitcoin server process bitcoind
Install
$ npm install @carnesen/bitcoind
The package includes runtime JavaScript files suitable for Node.js >=8 as well as the corresponding TypeScript type declarations.
Usage
Here is a little TypeScript Node.js script that spawns bitcoind
:
// example.ts
import { spawn } from '@carnesen/bitcoind';
const bitcoinHome = '/usr/local/bitcoin-0.17.1';
(async () => {
try {
await spawn({ bitcoinHome });
process.exit(0);
} catch (ex) {
console.log(ex);
process.exit(1);
}
})()
Running this script looks like:
$ ts-node example.ts
2019-01-24T03:57:07Z Bitcoin Core version v0.17.1 (release build)
2019-01-24T03:57:07Z InitParameterInteraction: parameter interaction: -whitelistforcerelay=1 -> setting -whitelistrelay=1
2019-01-24T03:57:07Z Validating signatures for all blocks.
...
The bitcoind
child process inherits the Node.js parent's stdout, stdin, and stderr. So in non-daemon mode when bitcoind
logs to the terminal, so does the parent.
API
spawn({bitcoinHome, configFilePath}): Promise<void>
Reads a bitcoin configuration file and spawns bitcoind
as a child process
bitcoinHome?
string
. If not provided, bitcoind
must be on your PATH
. If provided, absolute path of a directory where the bitcoin server software is installed. By convention, bitcoind
must be located at `${bitcoinHome}/bin/bitcoind`
.
configFilePath?
string
. Defaults to the platform-dependent location where the bitcoin server software looks for its configuration file, e.g. '~/.bitcoin/bitcoin.conf'
on Linux. Before spawning bitcoind
, spawnBitcoin
reads the configuration file and modifies its behavior slightly based on what it finds. If the configuration does not specify daemon
as true
, the spawnBitcoin
kills the child bitcoind
process if the parent Node.js process exits. Also if daemon
is not set to true
(1), bitcoind
exiting is always considered an error even if it exits with status code 0 (success).
Promise<void>
Represents the running bitcoind
child. If there is an error spawning the child or if the child exits for any reason, the promise rejects. The only exception to that rule is if daemon
is set to true
and the child's exit status is 0 (success). In that case the promise resolves.
More information
This library has a number of unit tests with >95% coverage. Check out the tests directory for more examples of how it works. If you encounter any bugs or have any questions or feature requests, please don't hesitate to file an issue or submit a pull request on this project's repository on GitHub.
Related
-
@carnesen/bitcoind-cli: A Node.js CLI and library for managing the bitcoin server process
bitcoind
-
@carnesen/bitcoin-config: A Node.js library for bitcoin server software configuration