Skip to content

money-god/geb-subgraph

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GEB subgraph

A Graph protocol subgraph for GEB

git clone https://github.com/money-god/geb-subgraph
cd geb-subgraph
git submodule update --init --recursive

Deploy on the hosted service

First, set the addresses of the smart contracts you want to index in config/kovan.json or config/mainnet.json.

Then, open a terminal and run:

npm install -D

# To run once with the token from the dashboard
npm run auth <GRAPH AUTH TOKEN>

# For kovan testnet
npm run deploy-hosted-kovan
# For mainnet
npm run deploy-hosted-mainnet

Local development

First, start a blockchain node on localhost:8545 (Ganache, Parity POA, etc..) configure the smart contract addresses in config/test.json.

Configure the docker/.env to:

POSTGRES_PASSWORD=1234

# For MacOS
ETHEREUM_RPC=http://host.docker.internal:8545/

#For Linux
ETHEREUM_RPC=http://172.17.0.1:8545/

NETWORK=test

Run:

cd docker
docker-compose up -d

Then access the GraphQL endpoints using:

http://localhost/subgraphs/name/tai (HTTP queries)

Production Graph node deployment

Run a graph node on a live chain (Ethereum Mainnet, Kovan etc..), deploy to subgraph on the node, expose the graphQL endpoint. Frist, configure the smart contract addresses in config/kovan.json or config/mainnet.json.

Configure the docker/.env to:

# Set an actual password
POSTGRES_PASSWORD=1234

# Ethereum node RPC endpoint (i.g: infura)
ETHEREUM_RPC=https://kovan.infura.io/v3/<API_KEY>/

# Set to mainnet or kovan
NETWORK=kovan

# Name of the subgraph on the graph node.
SUBGRAPH_NAME=tai

Then run the following commands:

cd graph-node
docker-compose up -d

These will start the Graph node, an IPFS node, a Postgress DB and then it will deploy the subgraph on the Graph node.

About

The Graph protocol subgraph for TAI

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 94.7%
  • Shell 3.8%
  • JavaScript 1.3%
  • Dockerfile 0.2%