Skip to content

A (local) REST API that proxies BCH wallet services delivered over IPFS (global).

License

Notifications You must be signed in to change notification settings

FullStack-cash/ipfs-bch-wallet-consumer

 
 

Repository files navigation

free-bch.fullstack.cash

This fork of ipfs-bch-wallet-consumer is used to power free-bch.fullstack.cash REST API.

This master branch is left unchanged, to pull in changes from the parent repository. The production branch is what is deployed to production for free-bch.fullstack.cash.

ipfs-bch-wallet-consumer

js-standard-style semantic-release

This is a REST API server based on Koa. It's essentially a mirror image of ipfs-bch-wallet-service. Where ipfs-bch-wallet-service is intended to be coupled to bch-api to provide blockchain service, ipfs-bch-wallet-consumer provides a localized REST API for consuming that blockchain service.

When started, this web server starts an IPFS node and connects to an ipfs-bch-wallet-service server over the IPFS network. It then pipes that connection over its own localized REST API.

Requirements

  • node ^14.18.2
  • npm ^8.3.0
  • Docker ^20.10.8
  • 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-service-provider
cd ipfs-service-provider
./install-mongo-sh
sudo npm install -g node-pre-gyp
npm install
./ipfs-service-provider.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 back up with docker-compose up -d.

Operation Notes

  • There is a memory leak in the version of js-ipfs. The app is currently configured to shut down every 8 hours to flush memory. It relies on a process manager like pm2, Docker, or systemd to restart the app after it shuts down, in order to ensure continuous operation.

  • The PSF network operates as a private network. It does not connect or interact with the wider PSF network, relying instead on gateways to bridge the two networks, when they need to share content. This improves the performance and experience for everyone in the PSF network. To join the network, you'll need to add the swarm.key file to the IPFS data folder.

  • Instructions on setting up IPFS private networks.

  • For external installations, the swarm.key file will typically go in ~/.ipfs/swarm.key

  • For production Docker containers, the key would go in ipfs-service-provider/production/data/go-ipfs/data/swarm.key

Structure

The file layout of this repository differs from the koa-api-boilerplate. Instead, it follows the file layout of Clean Architecture.

Usage

  • npm start Start server on live mode
  • npm run docs Generate API documentation
  • npm test Run mocha tests
  • docker-compose build Build a 'production' Docker container
  • docker-compose up Run the docker container

Documentation

API documentation is written inline and generated by apidoc.

Visit http://localhost:5000/docs/ 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

About

A (local) REST API that proxies BCH wallet services delivered over IPFS (global).

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 97.5%
  • Other 2.5%