2021-07-16 11:05:49 +00:00
|
|
|
# ERC20 Watcher
|
|
|
|
|
|
|
|
## Setup
|
|
|
|
|
2021-09-21 11:13:55 +00:00
|
|
|
Create a postgres12 database for the job queue:
|
2021-07-16 11:05:49 +00:00
|
|
|
|
2021-09-21 11:13:55 +00:00
|
|
|
```
|
|
|
|
sudo su - postgres
|
|
|
|
createdb erc20-watcher-job-queue
|
|
|
|
```
|
|
|
|
|
|
|
|
Enable the `pgcrypto` extension on the job queue database (https://github.com/timgit/pg-boss/blob/master/docs/usage.md#intro).
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
```
|
|
|
|
postgres@tesla:~$ psql -U postgres -h localhost erc20-watcher-job-queue
|
|
|
|
Password for user postgres:
|
|
|
|
psql (12.7 (Ubuntu 12.7-1.pgdg18.04+1))
|
|
|
|
SSL connection (protocol: TLSv1.3, cipher: TLS_AES_256_GCM_SHA384, bits: 256, compression: off)
|
|
|
|
Type "help" for help.
|
|
|
|
|
|
|
|
erc20-watcher-job-queue=# CREATE EXTENSION pgcrypto;
|
|
|
|
CREATE EXTENSION
|
|
|
|
erc20-watcher-job-queue=# exit
|
|
|
|
```
|
|
|
|
|
|
|
|
Create a postgres12 database for the erc20 watcher:
|
2021-07-16 11:05:49 +00:00
|
|
|
|
|
|
|
```
|
|
|
|
sudo su - postgres
|
|
|
|
createdb erc20-watcher
|
|
|
|
```
|
|
|
|
|
2021-09-21 11:13:55 +00:00
|
|
|
Update `environments/local.toml` with database connection settings for both the databases.
|
2022-05-23 13:24:14 +00:00
|
|
|
```toml
|
|
|
|
[database]
|
|
|
|
type = "postgres"
|
|
|
|
host = "localhost"
|
|
|
|
port = 5432
|
|
|
|
database = "erc20-watcher"
|
|
|
|
username = "postgres"
|
|
|
|
password = "postgres"
|
|
|
|
|
|
|
|
[jobQueue]
|
|
|
|
dbConnectionString = "postgres://postgres:postgres@localhost/erc20-watcher-job-queue"
|
|
|
|
```
|
|
|
|
|
2022-06-08 06:43:52 +00:00
|
|
|
Update the `upstream` config in `environments/local.toml`. Provide the `ipld-eth-server` GQL and RPC API endpoints.
|
2022-05-23 13:24:14 +00:00
|
|
|
```toml
|
|
|
|
[upstream]
|
|
|
|
[upstream.ethServer]
|
|
|
|
gqlApiEndpoint = "http://127.0.0.1:8082/graphql"
|
|
|
|
rpcProviderEndpoint = "http://127.0.0.1:8081"
|
|
|
|
```
|
2021-09-21 11:13:55 +00:00
|
|
|
|
2022-05-23 13:24:14 +00:00
|
|
|
Ensure that watcher is of active kind. Update the kind in `server` config to active.
|
|
|
|
```toml
|
|
|
|
[server]
|
|
|
|
kind = "active"
|
|
|
|
```
|
2021-07-16 11:05:49 +00:00
|
|
|
|
|
|
|
## Run
|
|
|
|
|
2022-11-28 13:24:09 +00:00
|
|
|
Follow the steps below or follow the [Demo](./demo.md)
|
|
|
|
|
2021-09-02 04:57:56 +00:00
|
|
|
Build files:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
yarn build
|
|
|
|
```
|
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
Run the watcher:
|
|
|
|
|
2022-11-25 06:01:20 +00:00
|
|
|
Start the job runner:
|
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
```bash
|
2022-11-25 06:01:20 +00:00
|
|
|
$ yarn job-runner
|
2021-09-02 04:57:56 +00:00
|
|
|
|
|
|
|
# For development.
|
2022-11-25 06:01:20 +00:00
|
|
|
$ yarn job-runner:dev
|
2021-09-02 04:57:56 +00:00
|
|
|
|
|
|
|
# For specifying config file.
|
2022-11-25 06:01:20 +00:00
|
|
|
$ yarn job-runner -f environments/local.toml
|
2021-09-21 11:13:55 +00:00
|
|
|
```
|
|
|
|
|
2022-11-25 06:01:20 +00:00
|
|
|
Start the server:
|
2021-09-21 11:13:55 +00:00
|
|
|
|
|
|
|
```bash
|
2022-11-25 06:01:20 +00:00
|
|
|
$ yarn server
|
2021-09-21 11:13:55 +00:00
|
|
|
|
|
|
|
# For development.
|
2022-11-25 06:01:20 +00:00
|
|
|
$ yarn server:dev
|
2021-09-21 11:13:55 +00:00
|
|
|
|
|
|
|
# For specifying config file.
|
2022-11-25 06:01:20 +00:00
|
|
|
$ yarn server -f environments/local.toml
|
2021-07-16 11:05:49 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
GQL console: http://localhost:3001/graphql
|
|
|
|
|
2022-05-23 13:24:14 +00:00
|
|
|
Deploy an ERC20 token:
|
|
|
|
```bash
|
|
|
|
$ yarn token:deploy
|
|
|
|
```
|
|
|
|
|
2021-09-21 11:13:55 +00:00
|
|
|
Start watching a token:
|
|
|
|
|
|
|
|
```bash
|
2022-11-28 13:24:09 +00:00
|
|
|
$ yarn watch:contract --address 0xTokenAddress --startingBlock <start-block> --kind ERC20 --checkpoint false
|
2021-09-21 11:13:55 +00:00
|
|
|
|
|
|
|
# For specifying config file.
|
2022-11-28 13:24:09 +00:00
|
|
|
$ yarn watch:contract -f environments/local.toml --address 0xTokenAddress --startingBlock <start-block> --kind ERC20 --checkpoint false
|
2021-09-21 11:13:55 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
```bash
|
2022-11-28 13:24:09 +00:00
|
|
|
$ yarn watch:contract --address 0xfE0034a874c2707c23F91D7409E9036F5e08ac34 --startingBlock 100 --kind ERC20 --checkpoint false
|
2021-09-21 11:13:55 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
To fill a block range:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
yarn fill --startBlock <from-block> --endBlock <to-block>
|
|
|
|
|
|
|
|
# For specifying config file.
|
|
|
|
$ yarn fill -f environments/local.toml --startBlock <from-block> --endBlock <to-block>
|
|
|
|
```
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ yarn fill --startBlock 1000 --endBlock 2000
|
|
|
|
```
|
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
### Example GQL Queries
|
|
|
|
|
|
|
|
```text
|
|
|
|
{
|
|
|
|
name(blockHash: "0x5ef95c9847f15179b64fa57994355623f899aca097ad779421b8dff866a8b9c3", token: "0x1ca7c995f8eF0A2989BbcE08D5B7Efe50A584aa1") {
|
|
|
|
value
|
|
|
|
proof {
|
|
|
|
data
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
symbol(blockHash: "0x5ef95c9847f15179b64fa57994355623f899aca097ad779421b8dff866a8b9c3", token: "0x1ca7c995f8eF0A2989BbcE08D5B7Efe50A584aa1") {
|
|
|
|
value
|
|
|
|
proof {
|
|
|
|
data
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
totalSupply(blockHash: "0x5ef95c9847f15179b64fa57994355623f899aca097ad779421b8dff866a8b9c3", token: "0x1ca7c995f8eF0A2989BbcE08D5B7Efe50A584aa1") {
|
|
|
|
value
|
|
|
|
proof {
|
|
|
|
data
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
balanceOf(blockHash: "0x5ef95c9847f15179b64fa57994355623f899aca097ad779421b8dff866a8b9c3", token: "0x1ca7c995f8eF0A2989BbcE08D5B7Efe50A584aa1", owner: "0xDC7d7A8920C8Eecc098da5B7522a5F31509b5Bfc") {
|
|
|
|
value
|
|
|
|
proof {
|
|
|
|
data
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
allowance(blockHash: "0x81ed2b04af35b1b276281c37243212731202d5a191a27d07b22a605fd442998d", token: "0x1ca7c995f8eF0A2989BbcE08D5B7Efe50A584aa1", owner: "0xDC7d7A8920C8Eecc098da5B7522a5F31509b5Bfc", spender: "0xCA6D29232D1435D8198E3E5302495417dD073d61") {
|
|
|
|
value
|
|
|
|
proof {
|
|
|
|
data
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
events(blockHash: "0x3441ba476dff95c58528afe754ceec659e0ef8ff1b59244ec4545f4f9784a51c", token: "0x1ca7c995f8eF0A2989BbcE08D5B7Efe50A584aa1") {
|
|
|
|
event {
|
|
|
|
__typename
|
|
|
|
... on TransferEvent {
|
|
|
|
from
|
|
|
|
to
|
|
|
|
value
|
|
|
|
}
|
|
|
|
... on ApprovalEvent {
|
|
|
|
owner
|
|
|
|
spender
|
|
|
|
value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
proof {
|
|
|
|
data
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|