The most common use case for indexers is to react on a transaction sent to a specific contract or a list of contracts.
This project is trying to provide an example of the indexer described about. It's simple yet doing the necessary stuff. In this example we don't use any external storage (like database or files) to keep track for the transactions to keep the example as simple as possible.
We've tried to put the explanatory comments in the code to help developers to extend this example according to their needs.
Please refer to NEAR Indexer for Explorer to find an inspiration for extending the indexer.
Assuming we want to watch for transactions where a receiver account id is one of the provided in a list.
We pass the list of account ids (or contracts it is the same) via argument --accounts
.
We want to catch all successfull transactions sent to one of the accounts from the list.
In the demo we'll just look for them and log them but it might and probably should be extended based on your needs.
Before you proceed, make sure you have the following software installed:
Clone this repository and open the project folder
$ git clone git@github.com:khorolets/indexer-tx-watcher-example.git
$ cd indexer-tx-watcher-example
To connect NEAR Indexer for Explorer to the specific chain you need to have necessary configs, you can generate it as follows:
localnet
(recommended to start with)$ cargo build --release $ ./target/release/indexer-tx-watcher-example --home-dir ~/.near/localnet init --chain-id localnet
testnet
(once you've adjusted and extended the example for your needs)$ cargo build --release $ ./target/release/indexer-tx-watcher-example --home-dir ~/.near/testnet init --chain-id testnet --download-config --download-genesis
The above code will download the official genesis config and generate necessary configs.
NB! According to changes in nearcore
config generation we don't fill all the necessary fields in the config file.
While this issue is open near/nearcore#3156 you need to download config you want and replace the generated one manually.
Configs for the specified network are in the --home-dir
provided folder. We need to ensure that NEAR Indexer for Explorer follows
all the necessary shards, so "tracked_shards"
parameters in ~/.near/localnet/config.json
needs to be configured properly.
For example, with a single shared network, you just add the shards numbers you need to the list:
...
"tracked_shards": [0],
...
$ ./target/release/indexer-tx-watcher-example --home-dir ~/.near/localnet run --accounts mycoolcontract.near,myanothercoolcontract.near
Provide your contracts list after --accounts
key separated with comma (,
) avoid spaces
Whenever you run the indexer for any network except localnet
you'll need to sync with the network. This is required because it's a natural behavior of nearcore
node and the indexer is a wrapper for the regular nearcore
node. In order to work and index the data your node must be synced with the network. This process can take a while, so we suggest to download a fresh backup of the data
folder and put it in you --home-dir
of your choice (by default it is ~/.near
)
Running your indexer node on top of a backup data will reduce the time of syncing process because your node will download only missing data and it will take reasonable time.
All the backups can be downloaded from the public S3 bucket which contains latest daily snapshots:
It's not necessary but in order to index everything in the network it is better to do it from the genesis. nearcore
node is running in non-archival mode by default. That means that the node keeps data only for 5 last epochs. In order to index data from the genesis we need to turn the node in archival mode.
To do it we need to update config.json
located in --home-dir
or your choice (by default it is ~/.near
).
Find next keys in the config and update them as following:
{
...
"archive": true,
"tracked_shards": [0],
...
}
The syncing process in archival mode can take a lot of time, so it's better to download a backup provided by NEAR and put it in your data
folder. After that your node will need to sync only missing data and it should take reasonable time.
All the backups can be downloaded from the public S3 bucket which contains latest daily snapshots:
See this article for reference