mirror of
https://github.com/cerc-io/watcher-ts
synced 2025-01-08 12:28:05 +00:00
Demo to deploy contract and make transactions
This commit is contained in:
parent
ba73cd24c2
commit
ed75a4dc82
@ -67,6 +67,8 @@
|
|||||||
|
|
||||||
## Run
|
## Run
|
||||||
|
|
||||||
|
Follow the steps below or follow the [Demo](./demo.md)
|
||||||
|
|
||||||
* Run the watcher:
|
* Run the watcher:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
|
193
packages/moby-mask-watcher/demo.md
Normal file
193
packages/moby-mask-watcher/demo.md
Normal file
@ -0,0 +1,193 @@
|
|||||||
|
# Demo
|
||||||
|
|
||||||
|
* Clone the [stack-orchestrator](https://github.com/vulcanize/stack-orchestrator) repo.
|
||||||
|
|
||||||
|
* Checkout the `develop` branch in stack-orchestrator repo.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git checkout develop
|
||||||
|
```
|
||||||
|
|
||||||
|
* Create a `config.sh` file.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd stack-orchestrator/helper-scripts
|
||||||
|
./create-config.sh
|
||||||
|
```
|
||||||
|
|
||||||
|
* Setup the required repositories.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
./setup-repositories.sh -p ssh
|
||||||
|
```
|
||||||
|
|
||||||
|
* Checkout [v4 release](https://github.com/vulcanize/go-ethereum/releases/tag/v1.10.19-statediff-4.0.3-alpha) in go-ethereum repo. The path for go-ethereum is specified by `vulcanize_go_ethereum` variable in `config.sh` file created in stack-orchestrator repo.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# In go-ethereum repo.
|
||||||
|
git checkout v1.10.19-statediff-4.0.3-alpha
|
||||||
|
```
|
||||||
|
|
||||||
|
* To run the stack-orchestrator, the docker-compose version used is:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose version
|
||||||
|
|
||||||
|
# docker-compose version 1.29.2, build 5becea4c
|
||||||
|
```
|
||||||
|
|
||||||
|
* Run the stack-orchestrator
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd stack-orchestrator/helper-scripts
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
./wrapper.sh -f true \
|
||||||
|
-m true \
|
||||||
|
-s v4 \
|
||||||
|
-l latest \
|
||||||
|
-v remove \
|
||||||
|
-p ../config.sh
|
||||||
|
```
|
||||||
|
|
||||||
|
* Run the IPFS (go-ipfs version 0.12.2) daemon:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
ipfs daemon
|
||||||
|
|
||||||
|
# API server listening on /ip4/127.0.0.1/tcp/5001
|
||||||
|
```
|
||||||
|
The IPFS API address can be seen in the output.
|
||||||
|
|
||||||
|
* In the [config file](./environments/local.toml) update the `server.ipfsApiAddr` config with the IPFS API address.
|
||||||
|
|
||||||
|
* Create a postgres12 database for the watcher:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo su - postgres
|
||||||
|
|
||||||
|
# If database already exists
|
||||||
|
# dropdb moby-mask-watcher
|
||||||
|
|
||||||
|
createdb moby-mask-watcher
|
||||||
|
```
|
||||||
|
|
||||||
|
* Create database for the job queue and enable the `pgcrypto` extension on them (https://github.com/timgit/pg-boss/blob/master/docs/usage.md#intro):
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# If database already exists
|
||||||
|
# dropdb moby-mask-watcher-job-queue
|
||||||
|
|
||||||
|
createdb moby-mask-watcher-job-queue
|
||||||
|
```
|
||||||
|
|
||||||
|
```
|
||||||
|
postgres@tesla:~$ psql -U postgres -h localhost moby-mask-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.
|
||||||
|
|
||||||
|
moby-mask-watcher-job-queue=# CREATE EXTENSION pgcrypto;
|
||||||
|
CREATE EXTENSION
|
||||||
|
moby-mask-watcher-job-queue=# exit
|
||||||
|
```
|
||||||
|
|
||||||
|
* In the [config file](./environments/local.toml) update the `database` connection settings.
|
||||||
|
|
||||||
|
* In `graph-watcher` repo, install and build packages:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
yarn && yarn build
|
||||||
|
```
|
||||||
|
|
||||||
|
* Change directory to `packages/moby-mask-watcher/` and run the watcher:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
yarn server
|
||||||
|
```
|
||||||
|
|
||||||
|
* Clone the [MobyMask](https://github.com/vulcanize/MobyMask) repo.
|
||||||
|
|
||||||
|
* Checkout to the branch with changes for using this watcher:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# In MobyMask repo.
|
||||||
|
git checkout ng-use-watcher
|
||||||
|
```
|
||||||
|
|
||||||
|
* Run yarn to install the packages
|
||||||
|
|
||||||
|
```bash
|
||||||
|
yarn
|
||||||
|
```
|
||||||
|
|
||||||
|
* Deploy the contract:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd packages/hardhat
|
||||||
|
|
||||||
|
yarn deploy
|
||||||
|
# deploying "PhisherRegistry" (tx: 0xaebeb2e883ece1f679304ec46f5dc61ca74f9e168427268a7dfa8802195b8de0)...: deployed at <MOBY_ADDRESS> with 2306221 gas
|
||||||
|
# $ hardhat run scripts/publish.js
|
||||||
|
# ✅ Published contracts to the subgraph package.
|
||||||
|
# Done in 14.28s.
|
||||||
|
```
|
||||||
|
|
||||||
|
Export the address of the deployed contract to a shell variable for later use:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
export MOBY_ADDRESS="<MOBY_ADDRESS>"
|
||||||
|
```
|
||||||
|
|
||||||
|
* Update isPhiser and isMember lists with names
|
||||||
|
|
||||||
|
```bash
|
||||||
|
yarn claimPhisher --contract $MOBY_ADDRESS --name phisherName
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
yarn claimMember --contract $MOBY_ADDRESS --name memberName
|
||||||
|
```
|
||||||
|
|
||||||
|
* Check the names in the watcher GraphQL playground http://localhost:3010/graphql
|
||||||
|
|
||||||
|
* Get the latest block
|
||||||
|
|
||||||
|
```graphql
|
||||||
|
query {
|
||||||
|
latestBlock {
|
||||||
|
hash
|
||||||
|
number
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
* Check the `isPhisher` and `isMember` maps
|
||||||
|
|
||||||
|
```graphql
|
||||||
|
query {
|
||||||
|
isPhisher(
|
||||||
|
blockHash: "LATEST_BLOCK_HASH"
|
||||||
|
contractAddress: "MOBY_ADDRESS",
|
||||||
|
key0: "phisherName"
|
||||||
|
) {
|
||||||
|
value
|
||||||
|
proof {
|
||||||
|
data
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
isMember(
|
||||||
|
blockHash: "LATEST_BLOCK_HASH"
|
||||||
|
contractAddress: "MOBY_ADDRESS",
|
||||||
|
key0: "memberName"
|
||||||
|
) {
|
||||||
|
value
|
||||||
|
proof {
|
||||||
|
data
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
@ -790,6 +790,13 @@ export class Indexer implements IPLDIndexerInterface {
|
|||||||
return this._baseIndexer.getAncestorAtDepth(blockHash, depth);
|
return this._baseIndexer.getAncestorAtDepth(blockHash, depth);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Get latest block using eth client.
|
||||||
|
async getLatestBlock (): Promise<BlockHeight> {
|
||||||
|
const { block } = await this._ethClient.getBlockByHash();
|
||||||
|
|
||||||
|
return block;
|
||||||
|
}
|
||||||
|
|
||||||
getEntityTypesMap (): Map<string, { [key: string]: string }> {
|
getEntityTypesMap (): Map<string, { [key: string]: string }> {
|
||||||
return this._entityTypesMap;
|
return this._entityTypesMap;
|
||||||
}
|
}
|
||||||
|
@ -126,6 +126,12 @@ export const createResolvers = async (indexer: Indexer, eventWatcher: EventWatch
|
|||||||
const ipldBlock = await indexer.getPrevIPLDBlock(blockHash, contractAddress, kind);
|
const ipldBlock = await indexer.getPrevIPLDBlock(blockHash, contractAddress, kind);
|
||||||
|
|
||||||
return ipldBlock && ipldBlock.block.isComplete ? indexer.getResultIPLDBlock(ipldBlock) : undefined;
|
return ipldBlock && ipldBlock.block.isComplete ? indexer.getResultIPLDBlock(ipldBlock) : undefined;
|
||||||
|
},
|
||||||
|
|
||||||
|
latestBlock: async () => {
|
||||||
|
log('latestBlock');
|
||||||
|
|
||||||
|
return indexer.getLatestBlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -4,6 +4,11 @@ scalar BigDecimal
|
|||||||
|
|
||||||
scalar Bytes
|
scalar Bytes
|
||||||
|
|
||||||
|
type Block_height {
|
||||||
|
hash: Bytes
|
||||||
|
number: Int
|
||||||
|
}
|
||||||
|
|
||||||
type Proof {
|
type Proof {
|
||||||
data: String!
|
data: String!
|
||||||
}
|
}
|
||||||
@ -93,6 +98,7 @@ type Query {
|
|||||||
isMember(blockHash: String!, contractAddress: String!, key0: String!): ResultBoolean!
|
isMember(blockHash: String!, contractAddress: String!, key0: String!): ResultBoolean!
|
||||||
getStateByCID(cid: String!): ResultIPLDBlock
|
getStateByCID(cid: String!): ResultIPLDBlock
|
||||||
getState(blockHash: String!, contractAddress: String!, kind: String): ResultIPLDBlock
|
getState(blockHash: String!, contractAddress: String!, kind: String): ResultIPLDBlock
|
||||||
|
latestBlock: Block_height
|
||||||
}
|
}
|
||||||
|
|
||||||
type Mutation {
|
type Mutation {
|
||||||
|
Loading…
Reference in New Issue
Block a user