Real-time json cache server for blockchain data
Note: Please use develop
branch for contributing.
Welcome to the server code for Giveth's dapp. The dapp uses feathers as a cache for its blockchain transactions. By utilizing websockets on both the blockchain and client devices, we can receive and push updates simultaneously to all users in real time.
- Click Star on this repo near the top-right corner of this web page (if you want to).
- Join our slack if you haven't already.
- Fork this repo by clicking Fork button in top-right corner of this web page. Continue to follow instruction steps from your own feathers-giveth repo.
- The rest of these steps must be done from your machine's command line. Clone your own "feathers-giveth" repo. Copy the link from the "Clone or download" button near the top right of this repo's home page.
git clone {paste your own repo link here}
- Change directories to feathers-giveth:
cd feathers-giveth
- Make sure you have NodeJS (v8.4.0 or higher), yarn (v0.27.5 or higher), and npm (5.4.1 or higher) installed.
- Install dependencies from within feathers-giveth directory:
npm install
- note: due to a bug in yarn,
yarn install
currently does not work
- note: due to a bug in yarn,
The feathers server will need to connect to an ethereum node via websockets. Typically this will be a local TestRPC instance.
The configuration param blockchain.nodeUrl
is used to establish a connection. The default nodeUrl is ws://localhost:8545
-
We need to deploy any contract to that we intened to call. NOTE: The following cmd will clear the
data
dir, thus starting off in a clean state.yarn deploy-local
-
We provide an easy way to start the bridge & 2 ganache-cli instances.
yarn start:networks
-
Since the bridge & ganache-cli is now running, open a new terminal window and navigate to the same feathers-giveth directory.
-
Start your app
yarn start
If you run into errors like wallet balance not loading, it is very likely that Ganache is stuck
netstat -vanp tcp | grep 8545
Find the process that is listening on *.8545
and 127.0.0.1.8545
and kill it with kill -9 PID
(which is in the last colomn)
Video tutorial walkthrough here: https://tinyurl.com/y9lx6jrl
-
Start a production server
yarn serve
The feathers-giveth/scripts
directory contains a few scripts to help development.
deploy.js
- deploys a new vault & liquidPledging contract
getState.js
- prints the current state of the deployed vault & liquidPledging contracts.
confirm.js
- confirms any payments that are pending in the vault
Simply run yarn test
and all your tests in the test/
directory will be run.
You can control the logging level with the LOG_LEVEL
env variable. Available levels can be found at: https://github.com/winstonjs/winston/tree/2.x#logging-levels
To enable debug logging simply start the server with LOG_LEVEL=debug yarn start
Each of these services are available via rest or websockets:
campaigns
dacs
donations
donationsHistory
milestones
uploads
users
If the server is using default configurations, you can see data for any of these services through your web browser at http://localhost:3030/SERVICE_NAME
For more info on how to work with feathers checkout out their docs on service methods, service events, and database querying.
Also feel free to reach out to us on slack for any help or to share ideas.