Skip to main content

Oasis Web3 Gateway for your EVM ParaTime

This guide will walk you through the steps needed to set up the Oasis Web3 gateway for EVM-compatible ParaTimes, such as Emerald and Sapphire.

caution

Each ParaTime requires its own instance of the Web3 gateway!

Prerequisites

Hardware

In addition to the minimum hardware requirements for running the Oasis node, the following should be added for running the Web3 gateway:

  • CPU:
    • Minimum: 2.0 GHz x86-64 CPU
    • Recommended: 2.0 GHz x86-64 CPU with 2 cores/vCPUs
  • Memory:
    • Minimum: 4 GB of ECC RAM
    • Recommended: 8 GB of ECC RAM
  • Storage:
    • Minimum: 300 GB of SSD or NVMe fast storage
    • Recommended: 500 GB of SSD or NVMe fast storage
info

To put the figures above into perspective, the Web3 gateway for Emerald with PostgreSQL encountered 210 GB of database growth in ~5 months between Nov 18, 2021 and Apr 11, 2022 (since the Emerald Mainnet launch).

Oasis ParaTime Client Node

The Web3 gateway requires a locally deployed ParaTime-enabled Oasis Node. First, follow the Oasis ParaTime client node guide on how to configure the Oasis client node with one or more ParaTimes. Always use the exact combination of the Oasis node/ParaTime versions as published on the Network Parameters page (Mainnet, Testnet).

Apart from the transactions that happen on-chain and produce some effects, there are also a number of read-only queries implemented in the Oasis protocol and EVM. Some of them may be quite resource-hungry such as simulating EVM calls and are disabled by default to avoid DDOS attacks. If your Oasis node instance will only be used by you and your Web3 gateway(s), you can safely enable expensive transactions by adding the following to your Oasis node config:

config.yml
# ... sections not relevant are omitted ...
runtime:
mode: client
paths:
- {{ emerald_bundle_path }}
- {{ sapphire_bundle_path }}

config:
"{{ emerald_paratime_id }}":
estimate_gas_by_simulating_contracts: true
allowed_queries:
- all_expensive: true
"{{ sapphire_paratime_id }}":
estimate_gas_by_simulating_contracts: true
allowed_queries:
- all_expensive: true

In the config above replace {{ ... }} placeholders with actual ParaTime IDs:

  • {{ emerald_paratime_id }}:
    • Emerald on Mainnet: 000000000000000000000000000000000000000000000000e2eaa99fc008f87f
    • Emerald on Testnet: 00000000000000000000000000000000000000000000000072c8215e60d5bca7
  • {{ sapphire_paratime_id }}:
    • Sapphire on Mainnet: 000000000000000000000000000000000000000000000000f80306c9858e7279
    • Sapphire on Testnet: 000000000000000000000000000000000000000000000000a6d1e3ebf60dff6c

PostgreSQL

The Web3 gateway stores blockchain data in a PostgreSQL database version 13.3 or higher. Install it by following instructions specific to your operating system and environment.

Because each ParaTime requires its own instance of the Web3 gateway, you will have to create a separate database and a separate user for each Web3 instance.

Download Oasis Web3 Gateway

Check the required version of the Web3 gateway for the network you will be deploying it to: Mainnet, Testnet. Next, download the Oasis-provided binaries from the official GitHub repository.

Alternatively, you can download the source release and compile it yourself. Consult the README.md file for more information.

Running the Web3 Gateway

Copy the content below to the config file of your Web3 gateway.

gateway.yml
# Uncomment the runtime_id below.
runtime_id: {{ paratime_id }}
# Path to your internal.sock file in the root Oasis node datadir.
node_address: "unix:{{ oasis_node_unix_socket }}"

# By default, we index the entire blockchain history.
# If you are low on disk space or you use the gateway just for submitting transactions, enable
# pruning below.
enable_pruning: false
pruning_step: 100000
indexing_start: 0

log:
level: debug
format: json

database:
# Change host and port, if PostgreSQL is running somewhere else.
host: "127.0.0.1"
port: 5432
# Enter your database name, username and password.
db: {{ postgresql_db }}
user: {{ postgresql_user }}
password: {{ postgresql_password }}
dial_timeout: 5
read_timeout: 10
write_timeout: 5
max_open_conns: 0

gateway:
chain_id: {{ chain_id }}
http:
# Change host to your external IP address if you have users accessing Web3 from the outside.
host: "localhost"
# Use different port for each Web3 gateway instance, if all run locally.
port: 8545
cors: ["*"]
ws:
# Change host to your external IP address if you have users accessing Web3 from the outside.
host: "localhost"
# Use different port for each Web3 gateway instance, if all run locally.
port: 8546
origins: ["*"]
method_limits:
get_logs_max_rounds: 100

Use the following placeholder values:

  • {{ paratime_id }}: The ID of the Emerald or Sapphire ParaTime which you are configuring the Web3 gateway for (see above).
  • {{ oasis_node_unix_socket }}: Path to the internal.sock file created by the Oasis node.
  • {{ postgresql_db }}, {{ postgresql_user }}, {{ postgresql_password }}: Database name and credentials for your PostgreSQL database.
  • {{ chain_id }}: The chain ID of your EVM network:
tip

All configuration settings can also be set via environment variables. For example, instead of setting up the database password in the config file above you can export:

DATABASE__PASSWORD=your_password_here

To start the Web3 gateway invoke:

./oasis-web3-gateway --config gateway.yml

The Web3 gateway will connect to your Oasis node and start indexing available blocks (i.e. from the last network upgrade). This may — depending on your hardware and the size of the blockchain — take hours.

If your database contains any tables populated by the previous version of the Web3 gateway, migration scripts will automatically be applied upon startup.

If you want to migrate the database separately, run:

./oasis-web3-gateway migrate-db --config gateway.yml
caution

Above, we are invoking the oasis-web3-gateway process directly from the shell, so you can quickly start using it. If you are setting up a production environment, you should configure the Web3 gateway as a system service and register it in the service manager for your platform.

Metrics

Web3 Gateway can report a number of metrics to Prometheus server. Metrics collection is not enabled by default. Enable metrics by configuring the monitoring section in the config file of the Web3 gateway.

gateway.yml
...
# Existing fields omitted ...
gateway:
# Existing fields omitted ...
monitoring:
host: "localhost"
# Use different port for each Web3 gateway instance, if all run locally.
port: 9999

Oasis Web3 Gateway reports metrics starting with oasis_web3_gateway_.

The following metrics are currently reported:

NameTypeDescriptionLabelsPackage
oasis_web3_gateway_gas_oracle_node_min_priceGaugeMin gas price queried from the node.gas
oasis_web3_gateway_gas_oracle_computed_priceGaugeComputed recommended gas price based on recent full blocks. -1 if none (no recent full blocks).gas
oasis_web3_gateway_cache_hitsGaugeNumber of cache hits.cacheindexer
oasis_web3_gateway_cache_missesGaugeNumber of cache misses.cacheindexer
oasis_web3_gateway_cache_hit_ratioGaugePercent of Hits over all accesses (Hits + Misses).cacheindexer
oasis_web3_gateway_block_indexedGaugeIndexed block heights.indexer
oasis_web3_gateway_block_prunedGaugePruned block heights.indexer
oasis_web3_gateway_indexer_healthGauge1 if gateway indexer healthcheck is reporting as healthy, 0 otherwise.indexer
oasis_web3_gateway_subscription_secondsHistogramHistogram for the eth subscription API subscriptions duration.method_namerpc/eth/filters
oasis_web3_gateway_subscription_inflightGaugeNumber of concurrent eth inflight subscriptions.method_namerpc/eth/filters
oasis_web3_gateway_api_request_heightsHistogramHistogram of eth API request heights (difference from the latest height).method_namerpc/eth/metrics
oasis_web3_gateway_signed_queriesCounterNumber of eth_call signed queries.rpc/eth/metrics
oasis_web3_gateway_api_secondsHistogramHistogram for the eth API requests duration.method_namerpc/metrics
oasis_web3_gateway_api_requestCounterCounter for API requests.method_namerpc/metrics
oasis_web3_gateway_api_failureCounterCounter for API request failures.method_namerpc/metrics
oasis_web3_gateway_api_successCounterCounter for API successful requests.method_namerpc/metrics
oasis_web3_gateway_api_inflightGaugeNumber of inflight API request.method_namerpc/metrics
oasis_web3_gateway_healthGauge1 if gateway healthcheck is reporting as healthy, 0 otherwise.server
oasis_web3_gateway_psql_query_secondsHistogramHistogram for the postgresql query duration.querystorage/psql

Archive Web3 Gateway

Each Oasis Web3 gateway can only connect to and synchronize blocks from a single Oasis node instance. To enable access to older EVM blocks, you can configure the Web3 gateway to behave as a proxy to another — archive — instance of the Web3 gateway.

First, set up an instance of the Oasis archive node. Then, repeat the similar process of setting up a Web3 gateway as you would normally do, but configure it to use the newly set up Oasis archive node.

Suppose the archive instances of the Web3 gateway and Oasis nodes are up and running and the archive Web3 gateway is listening on the local port 8543. Enable the proxy for historical blocks by adding the following to your (live) Web3 gateway config and restart it:

gateway.yml
# URI of an archive web3 gateway instance for servicing historical queries.
archive_uri: 'http://localhost:8543'

If a query requires information on the block which isn't stored in the live version of the Web3 gateway, the gateway will pass the query to the configured archive instance and return the obtained result.

info

Historical estimate gas calls are not supported.

Troubleshooting

Wipe state to force a complete reindex

If you encounter database or hardware issues, you may need to wipe the database and reindex all blocks. First, run the truncate-db subcommand:

oasis-web3-gateway truncate-db --config gateway.yml --unsafe

Then, execute the oasis-web3-gateway normally to start reindexing the blocks.

danger

This will wipe all existing state in the PostgreSQL database and can lead to extended downtime while the Web3 Gateway is reindexing the blocks.

See also