2021-07-06 14:35:40 +00:00
|
|
|
# Uniswap Watcher
|
|
|
|
|
2021-07-14 12:30:26 +00:00
|
|
|
## Setup
|
|
|
|
|
|
|
|
Create a postgres12 database for the job queue:
|
|
|
|
|
|
|
|
```
|
|
|
|
sudo su - postgres
|
|
|
|
createdb uni-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 uni-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.
|
|
|
|
|
|
|
|
uni-watcher-job-queue=# CREATE EXTENSION pgcrypto;
|
|
|
|
CREATE EXTENSION
|
|
|
|
uni-watcher-job-queue=# exit
|
|
|
|
```
|
|
|
|
|
|
|
|
Create a postgres12 database for the address watcher:
|
|
|
|
|
|
|
|
```
|
|
|
|
sudo su - postgres
|
|
|
|
createdb uni-watcher
|
|
|
|
```
|
|
|
|
|
|
|
|
Update `environments/local.toml` with database connection settings for both the databases.
|
|
|
|
|
|
|
|
|
|
|
|
## Run
|
|
|
|
|
2021-09-02 04:57:56 +00:00
|
|
|
Build files:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ yarn build
|
|
|
|
```
|
|
|
|
|
2021-07-06 14:35:40 +00:00
|
|
|
Run the server:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ yarn server
|
2021-09-02 04:57:56 +00:00
|
|
|
|
|
|
|
# For development.
|
|
|
|
$ yarn server:dev
|
|
|
|
|
|
|
|
# For specifying config file.
|
|
|
|
$ yarn server -f environments/local.toml
|
2021-07-06 14:35:40 +00:00
|
|
|
```
|
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
Start the job runner:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ yarn job-runner
|
2021-09-02 04:57:56 +00:00
|
|
|
|
|
|
|
# For development.
|
|
|
|
$ yarn job-runner:dev
|
|
|
|
|
|
|
|
# For specifying config file.
|
|
|
|
$ yarn job-runner -f environments/local.toml
|
2021-07-16 11:05:49 +00:00
|
|
|
```
|
|
|
|
|
2021-07-06 14:35:40 +00:00
|
|
|
Start watching the factory contract:
|
|
|
|
|
2021-09-02 04:57:56 +00:00
|
|
|
```bash
|
|
|
|
$ yarn watch:contract --address 0xContractAddress --kind <contract-kind> --startingBlock <start-block>
|
|
|
|
|
|
|
|
# For specifying config file.
|
|
|
|
$ yarn watch:contract -f environments/local.toml --address 0xContractAddress --kind <contract-kind> --startingBlock <start-block>
|
|
|
|
```
|
|
|
|
|
2021-07-06 14:35:40 +00:00
|
|
|
Example:
|
|
|
|
|
|
|
|
```bash
|
2021-07-07 05:40:10 +00:00
|
|
|
$ yarn watch:contract --address 0xfE0034a874c2707c23F91D7409E9036F5e08ac34 --kind factory --startingBlock 100
|
2021-07-06 14:35:40 +00:00
|
|
|
```
|
|
|
|
|
2021-07-15 11:57:10 +00:00
|
|
|
Start watching the NonFungiblePositionManager contract:
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ yarn watch:contract --address 0xB171168C0df9457Ff3E3D795aE25Bf4f41e2FFE3 --kind nfpm --startingBlock 100
|
|
|
|
```
|
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
To fill a block range:
|
2021-07-07 05:40:10 +00:00
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
```bash
|
2021-09-02 04:57:56 +00:00
|
|
|
yarn fill --startBlock <from-block> --endBlock <to-block>
|
|
|
|
|
|
|
|
# For specifying config file.
|
|
|
|
$ yarn fill -f environments/local.toml --startBlock <from-block> --endBlock <to-block>
|
2021-07-16 11:05:49 +00:00
|
|
|
```
|
2021-07-07 05:40:10 +00:00
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
Example:
|
2021-07-07 05:40:10 +00:00
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
```bash
|
|
|
|
$ yarn fill --startBlock 1000 --endBlock 2000
|
|
|
|
```
|
2021-07-07 05:40:10 +00:00
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
## Test
|
2021-07-07 05:40:10 +00:00
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
To test the watchers locally:
|
2021-07-07 05:40:10 +00:00
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
* Deploy the Uniswap contracts
|
|
|
|
* Watch the Factory and NonFungiblePositionManager contracts
|
|
|
|
* Send transactions to trigger events
|
2021-07-14 12:30:26 +00:00
|
|
|
|
2021-07-16 11:05:49 +00:00
|
|
|
See https://github.com/vulcanize/uniswap-v3-periphery/blob/watcher-ts/demo.md for instructions.
|
2021-07-30 14:20:56 +00:00
|
|
|
|
|
|
|
### Smoke test
|
|
|
|
|
|
|
|
To run a smoke test:
|
|
|
|
|
|
|
|
* Start the server and the job-runner.
|
2021-08-10 11:02:35 +00:00
|
|
|
* To build contracts for tests, run the command below in root of the repository:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ yarn build:contracts
|
|
|
|
```
|
|
|
|
|
2021-07-30 14:20:56 +00:00
|
|
|
* Run:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ yarn smoke-test
|
|
|
|
```
|