You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Dan Janosik 1dfd9d1fcd
Merge pull request #239 from cd2357/patch-2
4 years ago
.github Create codeql-analysis.yml 4 years ago
app Update Fun with bounty P2SH addresses from 2013 4 years ago
bin More work related to #219 5 years ago
docs Update Server-Setup.md 4 years ago
public rename 5 years ago
raw Versioning for misc/support assets 5 years ago
routes file rename for consistency 5 years ago
views updated urls for lnd-admin and btcpay 4 years ago
.env-sample Working toward medium-size update v1.2.0: 5 years ago
.gitattributes for LF line endings for CSS/JS files, WIP #103 6 years ago
.gitignore Check public/css/radial-progress.css into git (refs #93) 6 years ago
CHANGELOG.md release incoming 5 years ago
Dockerfile Use Docker multistage build to reduce image size 5 years ago
LICENSE copyright 5 years ago
README.md Update README.md 5 years ago
app.js rename typo 5 years ago
npm-shrinkwrap.json fix 4 low severity node vulnerability 5 years ago
package.json 2.0.2 5 years ago
roadmap.md release incoming 5 years ago

README.md

BTC RPC Explorer

homepage

npm version NPM downloads

Simple, database-free Bitcoin blockchain explorer, via RPC to Bitcoin Core.

This is a simple, self-hosted explorer for the Bitcoin blockchain, driven by RPC calls to your own Bitcoin node. It is easy to run and can be connected to other tools (like ElectrumX) to achieve a full-featured explorer.

Whatever reasons one may have for running a full node (trustlessness, technical curiosity, supporting the network, etc) it's helpful to appreciate the "fullness" of your node. With this explorer, you can explore not just the blockchain database, but also explore the functional capabilities of your own node.

Live demo available at: https://explorer.btc21.org

Features

  • Network Summary dashboard
  • View details of blocks, transactions, and addresses
  • Analysis tools for viewing stats on blocks, transactions, and miner activity
  • See raw JSON content from bitcoind used to generate most pages
  • Search by transaction ID, block hash/height, and address
  • Optional transaction history for addresses by querying from ElectrumX, blockchain.com, blockchair.com, or blockcypher.com
  • Mempool summary, with fee, size, and age breakdowns
  • RPC command browser and terminal

Changelog / Release notes

See CHANGELOG.md.

Getting started

Prerequisites

  1. Install and run a full, archiving node - instructions. Ensure that your bitcoin node has full transaction indexing enabled (txindex=1) and the RPC server enabled (server=1).
  2. Synchronize your node with the Bitcoin network (you can use this tool while your node is still sychronizing, but some pages may fail).
  3. Install a "recent" version of Node.js (8+ recommended).

Install / Run

If you're running on mainnet with the default datadir and port, the default configuration should Just Work. Otherwise, see the Configuration section below.

Install via npm:

npm install -g btc-rpc-explorer
btc-rpc-explorer

Run from source:

  1. git clone git@github.com:janoside/btc-rpc-explorer.git
  2. npm install
  3. npm start

Using either method (npm install or run from source), after startup open http://127.0.0.1:3002/

Configuration

Configuration options may be set via environment variables or CLI arguments.

Configuration with environment variables

To configure with environment variables, you need to create one of the 2 following files and enter values in it:

  1. ~/.config/btc-rpc-explorer.env
  2. .env in the working directory for btc-rpc-explorer

In either case, refer to .env-sample for a list of the options and formatting details.

Configuration with CLI args

For configuring with CLI arguments, run btc-rpc-explorer --help for the full list of options. An example execution is:

btc-rpc-explorer --port 8080 --bitcoind-port 18443 --bitcoind-cookie ~/.bitcoin/regtest/.cookie

Demo site settings

To match the features visible on the demo site at https://explorer.btc21.org you'll need to set the following non-default configuration values:

BTCEXP_DEMO=true 		# enables some demo/informational aspects of the site
BTCEXP_NO_RATES=false		# enables querying of exchange rate data
BTCEXP_SLOW_DEVICE_MODE=false	# enables resource-intensive tasks (UTXO set query, 24hr volume querying) that are inappropriate for "slow" devices

Run via Docker

  1. docker build -t btc-rpc-explorer .
  2. docker run -p 3002:3002 -it btc-rpc-explorer

Reverse proxy with HTTPS

See instructions here for using nginx+certbot (letsencrypt) for an HTTPS-accessible, reverse-proxied site.

Support

If you get value from this project, please consider supporting my continued work with a donation. Any and all donations are truly appreciated.