laconic-registry-cli/demo/README.md

112 lines
2.9 KiB
Markdown
Raw Normal View History

2024-05-08 09:51:23 +00:00
# Registry Demo
## Setup
* Run the laconicd chain:
```bash
# In laconcid
make install
./scripts/init.sh clean
```
* Create and populate `config.yml` following [config.example.yml](./config.example.yml):
```bash
2024-05-09 05:50:14 +00:00
cp config.example.yml config.yml
2024-05-09 06:26:57 +00:00
# Change the gas value in config.yml
# gas: 500000
# Get user key and set it to userKey in config.yml
2024-05-08 09:51:23 +00:00
laconicd keys export alice --unarmored-hex --unsafe --keyring-backend test --home ~/.laconicd
# Create a bond
laconicd tx bond create 100000000000photon --fees 100photon --from alice
2024-05-09 06:26:57 +00:00
# Get the bond id and set it to bondId in config.yml
2024-05-08 09:51:23 +00:00
laconicd query bond list
```
* Install the CLI:
```bash
yarn && yarn build
yarn global add file:$PWD
```
## Run
* Publish records from [`demo/records`](./demo/records):
2024-05-08 09:51:23 +00:00
```bash
# Publishes records and corresponding 'deployment' records
2024-05-09 06:26:57 +00:00
2024-05-09 05:32:24 +00:00
# In laconic-registry-cli
2024-05-09 06:26:57 +00:00
# Use records dir path for '--records' as required
yarn ts-node demo/scripts/publish-records.ts --config config.yml --records demo/records
2024-05-08 09:51:23 +00:00
```
### Example
* Query for `ajna-watcher` deployment(s):
* Find the `WatcherRecord` for `ajna-watcher`:
```bash
WATCHER_RECORD_ID=$(laconic registry record list --all --type WatcherRecord --name ajna-watcher | jq -r '.[].id')
```
* Find corresponding deployment(s):
```bash
laconic registry record list --all --type WatcherDeploymentRecord watcher $WATCHER_RECORD_ID
# Get the deployment URL(s)
laconic registry record list --all --type WatcherDeploymentRecord watcher $WATCHER_RECORD_ID | jq -r '.[].attributes.url'
2024-05-09 06:54:32 +00:00
# Expected output:
https://ajna-watcher-endpoint.example.com
2024-05-08 09:51:23 +00:00
```
2024-05-08 14:00:55 +00:00
* Query for `sushiswap-v3-subgraph` deployment(s):
* Find the `SubgraphRecord` for `sushiswap-v3-subgraph`:
```bash
SUBGRAPH_RECORD_ID=$(laconic registry record list --all --type SubgraphRecord --name sushiswap-v3-subgraph | jq -r '.[].id')
```
* Find corresponding deployment(s):
```bash
laconic registry record list --all --type SubgraphDeploymentRecord subgraph $SUBGRAPH_RECORD_ID
# Get the deployment URL(s)
laconic registry record list --all --type SubgraphDeploymentRecord subgraph $SUBGRAPH_RECORD_ID | jq -r '.[].attributes.url'
2024-05-09 06:54:32 +00:00
# Expected output:
# https://sushiswap-v3-subgraph-endpoint.example.com
2024-05-08 14:00:55 +00:00
```
2024-05-09 05:32:24 +00:00
* Query for `geth` service deployment(s):
2024-05-08 14:00:55 +00:00
2024-05-09 05:32:24 +00:00
* Find the `ServiceRecord` for `geth`:
2024-05-08 14:00:55 +00:00
```bash
2024-05-09 05:32:24 +00:00
SERVICE_RECORD_ID=$(laconic registry record list --all --type ServiceRecord --name geth | jq -r '.[].id')
2024-05-08 14:00:55 +00:00
```
* Find corresponding deployment(s):
```bash
laconic registry record list --all --type ServiceDeploymentRecord service $SERVICE_RECORD_ID
# Get the deployment URL(s)
laconic registry record list --all --type ServiceDeploymentRecord service $SERVICE_RECORD_ID | jq -r '.[].attributes.url'
2024-05-09 06:54:32 +00:00
# Expected output:
# https://geth-rpc-endpoint-1.example.com
# https://geth-rpc-endpoint-2.example.com
2024-05-08 14:00:55 +00:00
```