🦀 Ocean Protocol Subgraph
Go to file
dependabot[bot] cfa3d81445
Bump eslint from 7.24.0 to 7.25.0 ()
Bumps [eslint](https://github.com/eslint/eslint) from 7.24.0 to 7.25.0.
- [Release notes](https://github.com/eslint/eslint/releases)
- [Changelog](https://github.com/eslint/eslint/blob/master/CHANGELOG.md)
- [Commits](https://github.com/eslint/eslint/compare/v7.24.0...v7.25.0)

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2021-05-05 16:06:46 +02:00
.github use main barge () 2021-04-16 11:06:12 +03:00
abis add FixedRateExchange () 2021-03-10 23:36:51 +02:00
docker Activate dependabot, build tweaks, green CI () 2021-02-09 11:13:31 +01:00
scripts add integration tests () 2021-04-13 18:10:03 +03:00
src add moonbeamalpha () 2021-04-16 14:47:03 +03:00
test/integration add integration tests () 2021-04-13 18:10:03 +03:00
.eslintrc Bump eslint-config-prettier from 7.2.0 to 8.0.0 () 2021-02-23 16:54:15 +01:00
.gitignore Activate dependabot, build tweaks, green CI () 2021-02-09 11:13:31 +01:00
.prettierrc project setup fixes () 2020-12-11 11:37:09 +01:00
CHANGELOG.md Release 1.1.1 2021-04-16 04:49:01 -07:00
LICENSE Initial commit 2020-11-19 08:15:23 +01:00
package-lock.json Bump eslint from 7.24.0 to 7.25.0 () 2021-05-05 16:06:46 +02:00
package.json Bump eslint from 7.24.0 to 7.25.0 () 2021-05-05 16:06:46 +02:00
README.md Issue 92 readme improvements () 2021-04-21 11:58:27 +03:00
schema.graphql add block to dt orders () 2021-03-25 10:44:50 +02:00
subgraph.moonbeamalpha.yaml add moonbeamalpha () 2021-04-16 14:47:03 +03:00
subgraph.polygon.yaml add FixedRateExchange () 2021-03-10 23:36:51 +02:00
subgraph.rinkeby.yaml add FixedRateExchange () 2021-03-10 23:36:51 +02:00
subgraph.ropsten.yaml add FixedRateExchange () 2021-03-10 23:36:51 +02:00
subgraph.yaml add FixedRateExchange () 2021-03-10 23:36:51 +02:00
tsconfig.json project setup fixes () 2020-12-11 11:37:09 +01:00

banner

ocean-subgraph

🦀 Ocean Protocol Subgraph

Build Status js oceanprotocol

🏄 Get Started

This subgraph is deployed under /subgraphs/name/oceanprotocol/ocean-subgraph/ namespace for all networks the Ocean Protocol contracts are deployed to:

🧶 Example Queries

All pools

{
  pools(orderBy: oceanReserve, orderDirection: desc) {
    consumePrice
    datatokenReserve
    oceanReserve
    spotPrice
    swapFee
    transactionCount
  }
}

All datatokens

{
  datatokens(orderBy: createTime, orderDirection: desc) {
    address
    symbol
    name
    cap
    supply
    publisher
    holderCount
  }
}

All pool transactions for a given user

{
  poolTransactions(
    where: { userAddressStr: $userAddress }
    orderBy: timestamp
    orderDirection: desc
  ) {
    poolAddressStr
  }
}

Note: all ETH addresses like $userAddress in above example need to be passed in lowercase.

🦑 Development

First, clone the repo and install dependencies:

git clone https://github.com/oceanprotocol/ocean-subgraph/
cd ocean-subgraph
npm i

Developing and testing any change requires them to be deployed against a locally running graph-node and some other components running in Docker. Make sure you have Docker and Docker Compose installed on your machine, then prepare the Docker setup:

cd docker
./setup.sh

Then add your Infura key as environment variable with a .env file, and start everything up with Docker Compose:

# create .env and modify
cp .env.example .env

docker-compose --env-file .env up

The default network for development is set to Rinkeby. If you want to switch to another network you have to modify the docker/docker-compose.yml file within environment.ethereum.

You now have a local graph-node running and can start deploying your changes to it. To do so, follow the Deployment instructions.

🦑 Development on Barge

Clone (barge)[https://github.com/oceanprotocol/barge] and run it in another terminal:

git clone https://github.com/oceanprotocol/barge.git
cd barge
./start_ocean.sh --with-thegraph

If you have cloned Barge previously, make sure you are using the latest version by running git pull.

Clone the repo and install dependencies:

git clone https://github.com/oceanprotocol/ocean-subgraph/
cd ocean-subgraph
npm i

Generate the subgraph

npm run bargesetup

To deploy a subgraph connected to Barge, use:

npm run create:local-barge
npm run deploy:local-barge

You now have a local graph-node running on http://localhost:9000

🧪 Testing

To run the integration tests locally, first start up barge by following the instructions above, then run the following terminal commands from the ocean-subgraph folder:

export ADDRESS_FILE="${HOME}/.ocean/ocean-contracts/artifacts/address.json"
npm run test-integration

Code Style

For linting and auto-formatting you can use from the root of the project:

# lint all js with eslint
npm run lint

# auto format all js & css with prettier, taking all configs into account
npm run format

🛳 Releases

Releases are managed semi-automatically. They are always manually triggered from a developer's machine with release scripts. From a clean main branch you can run the release task bumping the version accordingly based on semantic versioning:

npm run release

The task does the following:

  • bumps the project version in package.json, package-lock.json
  • auto-generates and updates the CHANGELOG.md file from commit messages
  • creates a Git tag
  • commits and pushes everything
  • creates a GitHub release with commit messages as description
  • Git tag push will trigger Travis to do a npm release

For the GitHub releases steps a GitHub personal access token, exported as GITHUB_TOKEN is required. Setup

⬆️ Deployment

Do the following to deploy the ocean-subgraph to a graph-node running locally, pointed against mainnet:

npm run codegen

# deploy
npm run create:local
npm run deploy:local

To deploy a subgraph connected to Rinkeby or Ropsten test networks, use instead:

# Rinkeby
npm run create:local-rinkeby
npm run deploy:local-rinkeby

# Ropsten
npm run create:local-ropsten
npm run deploy:local-ropsten

You can edit the event handler code and then run npm run deploy:local, with some caveats:

  • Running deploy will fail if the code has no changes
  • Sometimes deploy will fail no matter what, in this case:
    • Stop the docker-compose run (docker-compose down or Ctrl+C) This should stop the graph-node, ipfs and postgres containers
    • Delete the ipfs and postgres folders in /docker/data (rm -rf ./docker/data/*)
    • Run docker-compose up to restart graph-node, ipfs and postgres
    • Run npm run create:local to create the ocean-subgraph
    • Run npm run deploy:local to deploy the ocean-subgraph

To deploy to one of the remote nodes run by Ocean, you can do port-forwarding and the above :local commands will work as is.

🏛 License

Copyright ((C)) 2021 Ocean Protocol Foundation

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.