Unchained is a multi-blockchain backend interface with three main goals:
- Provide a common interface to multiple blockchains
- Provide additional information not always accessible from the node directly
- Provide realtime updates about blockchain transactions (pending and confirmed)
- Project Details
- Helpful Docs
- Coin Stack Components
- Notes
- Local Networking
- Docker-Compose Local Dev Instructions
- Kubernetes Local Dev Instructions
- Node - coin specific node daemon providing historical blockchain data (ex. bitcoind, geth, etc)
- Indexer - optional service that indexes transaction and balance history by address, or any other applicable information, if not provided by the node directly
- Ingester (TO BE REMOVED) - ingests blockchain data providing:
- websocket notification of any newly confirmed or pending transactions
- stream of historical transaction history
- additional parsing logic not provided by the indexer or node
- API - provides a base set of functionality via REST and WebSocket that can be extended with coin specific logic
With Ingester (TO BE REMOVED)
With Indexer | No Indexer |
---|---|
- The ethereum coinstack is used in all examples. If you wish to run a different coinstack, just replace
ethereum
with the coinstack name you wish to run - All paths are relative to the root unchained project directory (ex.
unchained/[go|node]/{path}
) - All
pulumi
commands should be run in apulumi/
directory (ex.pulumi/
,coinstacks/ethereum/pulumi/
)
We use traefik as a reverse-proxy to expose all of our docker containers. Traefik is exposed at port 80
. Traefik Dashboard is exposed at port 8080
Traefik routes requests based on host name. which includes the coinstack name. For Example:
api.bitcoin.localhost
mongo.bitcoin.localhost
rabbit-admin.bitcoin.localhost
- Each language subdirectory has setup requirements before running a coinstack locally
- Both
go
andnode
module have linter installed in git pre-commit hook. To set up the hook:cd node && yarn
- Install docker-compose
-
unchained/node/packages/client
generates a typescript client for each coinstack using the generatedswagger.json
files. To ensure everything successfully builds, make the golang coinstacks first:cd go && make
-
Start the reverse proxy and any common service (ex. hot reloading):
docker-compose up -d
Note:
-d
runs the containers in daemon (background) mode. If you want to see logs,-d
can be omitted. -
Start a coinstack:
cd node/coinstacks/ethereum && docker-compose up
-
If only developing on the API:
cd node/coinstacks/ethereum && docker-compose up api
-
-
Visit http://api.ethereum.localhost/docs to view the OpenAPI documentation for the API
-
Tear down a coinstack (including docker volumes):
cd node/coinstacks/ethereum && docker-compose down -v
- If you are running Docker Desktop and see any
SIGKILL
errors, increase your resource limits in the Resources Tab