/flare-rosetta

Go Flare Rosetta implementation

Primary LanguageGo

go-flare-rosetta

System Requirements

  • go version 1.18.5
  • gcc, g++ and jq
  • CPU: Equivalent of 8 AWS vCPU
  • RAM: 16 GiB
  • Storage: 1TB
  • OS: Ubuntu 18.04/20.04 or macOS >= 10.15 (Catalina)

Launch a Costwo testnet or Flare mainnet Node

From the flare-rosetta/ repo, run:

git clone https://github.com/flare-foundation/go-flare.git

Build the node:

cd go-flare/avalanchego && ./scripts/build.sh && cd -

Costwo Testnet

./go-flare/avalanchego/build/avalanchego --network-id=costwo --http-host= \
  --bootstrap-ips="$(curl -m 10 -sX POST \
    --data '{ "jsonrpc":"2.0", "id":1, "method":"info.getNodeIP" }' \
    -H 'content-type:application/json;' https://coston2.flare.network/ext/info \
    | jq -r ".result.ip")" \
  --bootstrap-ids="$(curl -m 10 -sX POST \
    --data '{ "jsonrpc":"2.0", "id":1, "method":"info.getNodeID" }' \
    -H 'content-type:application/json;' https://coston2.flare.network/ext/info \
    | jq -r ".result.nodeID")" \
    --chain-config-dir=$(pwd)/server/rosetta-cli-conf/costwo/

Flare Mainnet

./go-flare/avalanchego/build/avalanchego --network-id=flare --http-host= \
  --bootstrap-ips="$(curl -m 10 -sX POST \
    --data '{ "jsonrpc":"2.0", "id":1, "method":"info.getNodeIP" }' \
    -H 'content-type:application/json;' https://flare.flare.network/ext/info \
    | jq -r ".result.ip")" \
  --bootstrap-ids="$(curl -m 10 -sX POST \
    --data '{ "jsonrpc":"2.0", "id":1, "method":"info.getNodeID" }' \
    -H 'content-type:application/json;' https://flare.flare.network/ext/info \
    | jq -r ".result.nodeID")" \
    --chain-config-dir=$(pwd)/server/rosetta-cli-conf/flare/

Launch Rosetta

The following scripts use local RPC endpoints for the Flare and Costwo networks, these can be changed by editing the "rpc_endpoint" field in server/rosetta-cli-conf/flare/server-config.json and server/rosetta-cli-conf/costwo/server-config.json.

Costwo Testnet

./scripts/rosetta-server.sh costwo

Flare Mainnet

./scripts/rosetta-server.sh flare

Testing

Install the rosetta-cli: https://github.com/coinbase/rosetta-cli#installation

Test requirements: a fully-synced Costwo or Flare node using the above config, and a connected Flare Rosetta server.

Costwo Testnet

check:data

./scripts/rosetta-cli.sh costwo data

The pre-funded account's private key required for the following test will be provided separately.

check:construction

./scripts/rosetta-cli.sh costwo construction

Flare Mainnet

check:data

./scripts/rosetta-cli.sh flare data

Run via Container

Environment variables

Name Default Description
DEBUG false Set to true to enable debug mode. Prints every executed command, sets --log-level=debug
HTTP_HOST 0.0.0.0 The bind address of the service
HTTP_PORT 9650 The port on which the API is served
STAKING_PORT 9651 The staking port for bootstrapping nodes
PUBLIC_IP (empty) The public IP of the service
DB_DIR /data The database directory location
DB_TYPE leveldb The database type to be used
BOOTSTRAP_IPS (empty) A list of bootstrap server ips; ref --bootstrap-ips-string
BOOTSTRAP_IDS (empty) A list of bootstrap server ids; ref --bootstrap-ids-string
CHAIN_CONFIG_DIR /app/conf/${NETWORK_ID} Chain configuration directory for flare
LOG_DIR /app/logs Logging directory
LOG_LEVEL warn Logging level. If explicitly set (not default) also overwrites DEBUG setting it to debug.
NETWORK_ID costwo The network id. The common ids are flare and costwo
AUTOCONFIGURE_BOOTSTRAP_ENDPOINT_RETRY 0 How many times, with delay of 10 seconds, should we retry contacting the bootstrap node. Handy when a node will bootstrap from another parallel-start node.
AUTOCONFIGURE_BOOTSTRAP_ENDPOINT (empty) Endpoint used for bootstrapping. Ex. https://coston2.flare.network/ext/info, https://flare.flare.network/ext/info
FLARE_LOCAL_TXS_ENABLED false Set to true when running a one-node setup (ex. localflare). Docs about local-txs-enabled-boolean.
FLARE_EXTRA_ARGUMENTS Extra arguments passed to flare binary
ROSETTA_FLARE_ENDPOINT http://127.0.0.1:9650 go-flare HTTP endpoint used by rosetta
ROSETTA_CONFIG_PATH /app/conf/${NETWORK_ID}/server-config.json Configuration path used by rosetta
STAKING_ENABLED true set it to false to make avalanchego sample all nodes, not just validators. Read Disabling staking! Avalanchego docs: --staking-enabled.
MODE online Run rosetta in online or offline mode
START_ROSETTA_SERVER_AFTER_BOOTSTRAP false Waits for go-flare to fully bootstrap before launching rosetta-server

Ports

Default port Used for Configurable ?
9650 go-flare API With HTTP_PORT env var
9651 go-flare staking With STAKING_PORT env var
8080 rosetta API No

Volumes

Default path Used for Configurable ?
/data go-flare chain database With DB_DIR env var
/app/logs go-flare logs With LOG_DIR env var
/app/flare/config/${NETWORK_ID} go-flare configuration folder With CHAIN_CONFIG_DIR env var

Config folders in rosetta-cli-conf also contain the Rosetta server config server-config.json. The used location of this config file can be overwritted with ROSETTA_CONFIG_PATH environment variable.

Disabling staking

Disabling Proof of Stake is dangerous! Read the avalanchego documentation. If you want to proceed with disabled staking you will also need to confirm this setting as it is a dangerous one.

Confirming dangerous settings

To confirm dangrous settings set the environment variable YES_I_REALLY_KNOW_WHAT_I_AM_DOING to "i have read the documentation" with spaces replaced with minuses.

Build image

cd server
docker build --progress=plain -t my-local-flare-rosetta-image .

Flare

docker run -d -p 8080:8080 -p 9650:9650 -p 9651:9651 -e NETWORK_ID=flare -v /my/host/dir/flare/db:/data my-local-flare-rosetta-image

Coston2

docker run -d -p 8080:8080 -p 9650:9650 -p 9651:9651 -e NETWORK_ID=costwo -v /my/host/dir/costwo/db:/data my-local-flare-rosetta-image

You can override the default configuration files by mounting to /app/conf. See server/rosetta-cli-conf for the expected folder structure.

You can find more information on running a go-flare node in our official documentation.

Offline and online node

docker run -d -p 8080:8080 -p 9650:9650 -p 9651:9651 -e NETWORK_ID=costwo -e MODE=online -v /my/host/dir/costwo/db_online:/data my-local-flare-rosetta-image
docker run -d -p 8081:8080 -p 19650:9650 -p 19651:9651 -e NETWORK_ID=costwo -e MODE=offline -v /my/host/dir/costwo/db_offline:/data my-local-flare-rosetta-image

Modify cli config in server/rosetta-cli-conf/config.json -> construction.offline_url to point to the offline node.