Skip to content

Permissionless-Software-Foundation/ipfs-bch-wallet-service

Repository files navigation

ipfs-bch-wallet-service

js-standard-style semantic-release

This is a censorship-resistant, IPFS-based microservice that provides access for wallets to access the Bitcoin Cash (BCH) blockchain. It leverages bch-js.

About This Repository

This repository is forked from the ipfs-service-provider repository. That code has been customized to provide BCH blockchain access for wallets. This server-side node.js app provides both REST API over HTTP and JSON RPC over IPFS endpoints for wallets to access the blockchain through.

As part of the end-to-end testing, a virtual client can be started that will interrogate every endpoint provided by this API server. This client can be forked by developers to write their own apps that use this IPFS-based service.

Roadmap

This repository is one step in a longer path. Here are the major milestones of this path:

  • Add wallet-based calls to ipfs-bch-wallet-service (this repository).
  • Create a miniature version of bch-js that makes calls over JSON RPC (bch-js-ipfs).
  • Given a variable, minimal-slp-wallet could call bch-js or bch-js-ipfs for network calls.
  • Fork slp-cli-wallet and add daemon feature to spin up IPFS node and work with bch-js-ipfs.

Requirements

  • node ^20.16.0
  • npm ^10.8.1
  • Docker ^24.0.7
  • Docker Compose ^1.27.4

Installation

Development Environment

Note: This software now uses an external go-ipfs IPFS node. The instructions below have not been updated to reflect this.

A development environment will allow you modify the code on-the-fly and contribute to the code base of this repository. PM2 is recommended for running this code base as an IPFS Circuit Relay.

git clone https://github.com/Permissionless-Software-Foundation/ipfs-bch-wallet-service
cd ipfs-bch-wallet-service
./install-mongo.sh
npm install
cd shell-scripts
./ipfs-bch-wallet-service.sh

Production Environment

The docker directory contains a Dockerfile for building a production deployment.

docker-compose pull
docker-compose up -d
  • You can bring the containers down with docker-compose down
  • You can bring the containers back up with docker-compose up -d.

Configuration

This program is intended to started with a Bash shell script. In that script, you can set the following environment variables:

# The instance of bch-api to connect to.
export APISERVER=http://172.17.0.1:3000/v5/

Configuration

This app is intended to be started via a bash shell script. See the environment variables used to configure this app in the config/env/common.js file.

File Structure

The file layout of this repository follows the file layout of Clean Architecture. Understaning the principles laid out this article will help developers navigate the code base.

Usage

  • npm start Start server on live mode
  • npm run docs Generate API documentation
  • npm test Run mocha tests

Documentation

API documentation is written inline and generated by apidoc. Docs can be generated with this command:

  • npm run docs

Visit http://localhost:5020/ to view docs

There is additional developer documentation in the dev-docs directory.

Dependencies

IPFS

Snapshots pinned to IPFS will be listed here.

License

MIT

a

About

IPFS and REST service providing blockchain access needed by a wallet.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages