Compare commits
5 Commits
Author | SHA1 | Date | |
---|---|---|---|
cbff9646c7 | |||
c3f8d53f09 | |||
b01201ca50 | |||
5a0298dda5 | |||
97b74760d9 |
.eslintignore.eslintrc.jsoncns.tsindex.ts
.gitea/workflows
.husky
docker-compose.ymljest.config.jspackage.jsonsrc
cmds
cns-cmds
account-cmds
account.tsauction-cmds
auction.tsauthority-cmds
authority.tsbond-cmds
bond.tsname-cmds
name.tsrecord-cmds
record.tsstatus.tstokens-cmds
tokens.tsutil
test
tsconfig.jsonyarn.lock
5
.eslintignore
Normal file
5
.eslintignore
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# Don't lint node_modules.
|
||||||
|
node_modules
|
||||||
|
|
||||||
|
# Don't lint build output.
|
||||||
|
dist
|
21
.eslintrc.json
Normal file
21
.eslintrc.json
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"env": {
|
||||||
|
"node": true
|
||||||
|
},
|
||||||
|
"extends": [
|
||||||
|
"semistandard",
|
||||||
|
"plugin:@typescript-eslint/recommended"
|
||||||
|
],
|
||||||
|
"parser": "@typescript-eslint/parser",
|
||||||
|
"parserOptions": {
|
||||||
|
"ecmaVersion": 12,
|
||||||
|
"sourceType": "module"
|
||||||
|
},
|
||||||
|
"plugins": [
|
||||||
|
"@typescript-eslint"
|
||||||
|
],
|
||||||
|
"rules": {
|
||||||
|
"indent": ["error", 2, { "SwitchCase": 1 }],
|
||||||
|
"@typescript-eslint/no-explicit-any": "off"
|
||||||
|
}
|
||||||
|
}
|
28
.gitea/workflows/lint.yml
Normal file
28
.gitea/workflows/lint.yml
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
name: Lint
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
lint:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
node-version: [18.x]
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- name: Download yarn
|
||||||
|
run: |
|
||||||
|
curl -fsSL -o /usr/local/bin/yarn https://github.com/yarnpkg/yarn/releases/download/v1.22.21/yarn-1.22.21.js
|
||||||
|
chmod +x /usr/local/bin/yarn
|
||||||
|
- name: Use Node.js ${{ matrix.node-version }}
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: ${{ matrix.node-version }}
|
||||||
|
- run: yarn
|
||||||
|
- name: Linter check
|
||||||
|
run: yarn lint
|
@ -12,10 +12,29 @@ env:
|
|||||||
DOCKER_HOST: unix:///var/run/dind.sock
|
DOCKER_HOST: unix:///var/run/dind.sock
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
sdk_tests:
|
cli_tests:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
node-version: [18.x]
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
|
- name: Download yarn
|
||||||
|
run: |
|
||||||
|
curl -fsSL -o /usr/local/bin/yarn https://github.com/yarnpkg/yarn/releases/download/v1.22.21/yarn-1.22.21.js
|
||||||
|
chmod +x /usr/local/bin/yarn
|
||||||
|
- name: Use Node.js ${{ matrix.node-version }}
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: ${{ matrix.node-version }}
|
||||||
|
- name: Set registry
|
||||||
|
run: npm config set @cerc-io:registry https://git.vdb.to/api/packages/cerc-io/npm/
|
||||||
|
|
||||||
|
- name: Install dependencies and build
|
||||||
|
run: yarn && yarn build
|
||||||
|
- name: Install registry-cli
|
||||||
|
run: yarn global add file:$PWD
|
||||||
|
|
||||||
- name: Checkout laconicd
|
- name: Checkout laconicd
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
@ -23,23 +42,17 @@ jobs:
|
|||||||
repository: cerc-io/laconicd
|
repository: cerc-io/laconicd
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
ref: main
|
ref: main
|
||||||
- name: Environment
|
|
||||||
run: ls -tlh && env
|
- name: Build laconicd container
|
||||||
- name: Start dockerd
|
working-directory: ./laconicd/tests/sdk_tests
|
||||||
run: |
|
|
||||||
dockerd -H $DOCKER_HOST --userland-proxy=false &
|
|
||||||
sleep 5
|
|
||||||
- name: build registry-cli container
|
|
||||||
run: docker build -t cerc/laconic-registry-cli:local-test --build-arg CERC_NPM_URL=https://git.vdb.to/api/packages/cerc-io/npm/ --build-arg CERC_NPM_AUTH_TOKEN="${{ secrets.CICD_PUBLISH_TOKEN }}" .
|
|
||||||
- name: build containers scripts
|
|
||||||
working-directory: laconicd/tests/sdk_tests
|
|
||||||
run: ./build-laconicd-container.sh
|
run: ./build-laconicd-container.sh
|
||||||
- name: start laconicd container
|
- name: Start laconicd container
|
||||||
working-directory: laconicd/tests/sdk_tests
|
env:
|
||||||
|
TEST_AUCTION_ENABLED: true
|
||||||
run: docker compose up laconicd -d
|
run: docker compose up laconicd -d
|
||||||
|
|
||||||
- name: Run registry-cli demo commands in registry-cli container
|
- name: Run registry-cli tests
|
||||||
run : ls -tla
|
run: ./test/run-tests.sh
|
||||||
- name: stop containers
|
|
||||||
working-directory: laconicd/tests/sdk_tests
|
- name: Stop containers
|
||||||
run: docker compose down
|
run: docker compose down
|
||||||
|
1
.husky/pre-commit
Normal file
1
.husky/pre-commit
Normal file
@ -0,0 +1 @@
|
|||||||
|
yarn lint
|
@ -1,28 +1,25 @@
|
|||||||
services:
|
services:
|
||||||
laconicd:
|
laconicd:
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
image: cerc-io/laconicd:local-test
|
image: cerc/laconicd:local
|
||||||
command: ["sh", "/docker-entrypoint-scripts.d/create-fixturenet.sh"]
|
command: ["sh", "/docker-entrypoint-scripts.d/create-fixturenet.sh"]
|
||||||
|
environment:
|
||||||
|
- TEST_AUCTION_ENABLED
|
||||||
|
- TEST_REGISTRY_EXPIRY
|
||||||
|
- LOGLEVEL
|
||||||
volumes:
|
volumes:
|
||||||
- laconicd/init.sh:/docker-entrypoint-scripts.d/create-fixturenet.sh
|
- ./laconicd/init.sh:/docker-entrypoint-scripts.d/create-fixturenet.sh
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD", "curl", "-v", "http://127.0.0.1:6060"]
|
test: ["CMD", "curl", "-v", "http://127.0.0.1:6060"]
|
||||||
interval: 1s
|
interval: 1s
|
||||||
timeout: 5s
|
timeout: 5s
|
||||||
retries: 30
|
retries: 30
|
||||||
ports:
|
ports:
|
||||||
- "6060"
|
- "9473:9473"
|
||||||
- "26657"
|
- "1317:1317"
|
||||||
- "26656"
|
|
||||||
- "9473"
|
|
||||||
- "8545"
|
|
||||||
- "8546"
|
|
||||||
- "9090"
|
|
||||||
- "9091"
|
|
||||||
- "1317"
|
|
||||||
|
|
||||||
cli-test-runner:
|
cli-test-runner:
|
||||||
image: cerc/laconic-registry-cli:local-test
|
image: cerc/laconic-registry-cli:local
|
||||||
depends_on:
|
depends_on:
|
||||||
laconicd:
|
laconicd:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
|
6
jest.config.js
Normal file
6
jest.config.js
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
/** @type {import('ts-jest/dist/types').InitialOptionsTsJest} */
|
||||||
|
module.exports = {
|
||||||
|
preset: 'ts-jest',
|
||||||
|
testEnvironment: 'node',
|
||||||
|
setupFiles: ['dotenv/config']
|
||||||
|
};
|
22
package.json
22
package.json
@ -1,30 +1,46 @@
|
|||||||
{
|
{
|
||||||
"name": "@cerc-io/laconic-registry-cli",
|
"name": "@cerc-io/laconic-registry-cli",
|
||||||
"version": "0.1.7",
|
"version": "0.1.10",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"repository": "git@github.com:cerc-io/laconic-registry-cli.git",
|
"repository": "git@github.com:cerc-io/laconic-registry-cli.git",
|
||||||
"author": "",
|
"author": "",
|
||||||
"license": "UNLICENSED",
|
"license": "UNLICENSED",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/fs-extra": "^9.0.13",
|
"@types/fs-extra": "^9.0.13",
|
||||||
|
"@types/jest": "^27.4.1",
|
||||||
"@types/js-yaml": "^4.0.5",
|
"@types/js-yaml": "^4.0.5",
|
||||||
"@types/lodash": "^4.14.182",
|
"@types/lodash": "^4.14.182",
|
||||||
"@types/node": "^17.0.25",
|
"@types/node": "^17.0.25",
|
||||||
"@types/yargs": "^17.0.10",
|
"@types/yargs": "^17.0.10",
|
||||||
|
"@typescript-eslint/eslint-plugin": "^5.47.1",
|
||||||
|
"@typescript-eslint/parser": "^5.47.1",
|
||||||
|
"dotenv": "^16.3.2",
|
||||||
|
"eslint": "^8.35.0",
|
||||||
|
"eslint-config-semistandard": "^15.0.1",
|
||||||
|
"eslint-config-standard": "^16.0.3",
|
||||||
|
"eslint-plugin-import": "^2.27.5",
|
||||||
|
"eslint-plugin-node": "^11.1.0",
|
||||||
|
"eslint-plugin-promise": "^5.1.0",
|
||||||
|
"eslint-plugin-standard": "^5.0.0",
|
||||||
|
"husky": "^9.0.2",
|
||||||
|
"jest": "29.0.0",
|
||||||
|
"ts-jest": "^29.0.2",
|
||||||
"typescript": "^4.6.3"
|
"typescript": "^4.6.3"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@cerc-io/laconic-sdk": "^0.1.15",
|
||||||
"fs-extra": "^10.1.0",
|
"fs-extra": "^10.1.0",
|
||||||
"@cerc-io/laconic-sdk": "^0.1.13",
|
|
||||||
"js-yaml": "^3.14.1",
|
"js-yaml": "^3.14.1",
|
||||||
"lodash": "^4.17.21",
|
"lodash": "^4.17.21",
|
||||||
"lodash-clean": "^2.2.3",
|
"lodash-clean": "^2.2.3",
|
||||||
"yargs": "^17.4.1"
|
"yargs": "^17.4.1"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
"test": "jest --runInBand --verbose test/cli.test.ts",
|
||||||
"lint": "eslint .",
|
"lint": "eslint .",
|
||||||
"clean": "rm -rf ./dist",
|
"clean": "rm -rf ./dist",
|
||||||
"build": "tsc"
|
"build": "tsc",
|
||||||
|
"prepare": "husky"
|
||||||
},
|
},
|
||||||
"bin": {
|
"bin": {
|
||||||
"laconic": "bin/laconic"
|
"laconic": "bin/laconic"
|
||||||
|
@ -11,7 +11,7 @@ export const desc = 'Get account.';
|
|||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
let address = argv.address as string;
|
let address = argv.address as string;
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -24,5 +24,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const result = await registry.getAccounts([address]);
|
const result = await registry.getAccounts([address]);
|
||||||
|
|
||||||
queryOutput(result,argv.output);
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -7,4 +7,4 @@ export const desc = 'Account operations.';
|
|||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('account-cmds')
|
return yargs.commandDir('account-cmds')
|
||||||
.demandCommand();
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -21,7 +21,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
assert(quantity, 'Invalid token quantity.');
|
assert(quantity, 'Invalid token quantity.');
|
||||||
assert(denom, 'Invalid token type.');
|
assert(denom, 'Invalid token type.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -43,7 +43,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
|
|
||||||
const result = await registry.commitBid({ auctionId, commitHash }, privateKey, fee);
|
const result = await registry.commitBid({ auctionId, commitHash }, privateKey, fee);
|
||||||
const revealFile = `{"reveal_file":"${revealFilePath}"}`
|
const revealFile = `{"reveal_file":"${revealFilePath}"}`;
|
||||||
|
|
||||||
txOutput(result,revealFile,argv.output,argv.verbose)
|
txOutput(result, revealFile, argv.output, argv.verbose);
|
||||||
}
|
};
|
||||||
|
@ -16,7 +16,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
assert(auctionId, 'Invalid auction ID.');
|
assert(auctionId, 'Invalid auction ID.');
|
||||||
assert(filePath, 'Invalid reveal file path.');
|
assert(filePath, 'Invalid reveal file path.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -28,7 +28,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
|
|
||||||
const reveal = fs.readFileSync(path.resolve(filePath));
|
const reveal = fs.readFileSync(path.resolve(filePath));
|
||||||
const result = await registry.revealBid({ auctionId, reveal: reveal.toString('hex') }, privateKey, fee);
|
const result = await registry.revealBid({ auctionId, reveal: reveal.toString('hex') }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
|
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
}
|
};
|
||||||
|
@ -6,10 +6,10 @@ export const desc = 'Auction bid operations.';
|
|||||||
|
|
||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.options({
|
return yargs.options({
|
||||||
'auction-id': { type: 'string' },
|
'auction-id': { type: 'string' },
|
||||||
'type': { type: 'string' },
|
type: { type: 'string' },
|
||||||
'quantity': { type: 'string' },
|
quantity: { type: 'string' },
|
||||||
'file-path': { type: 'string' }
|
'file-path': { type: 'string' }
|
||||||
}).commandDir('bid-cmds')
|
}).commandDir('bid-cmds')
|
||||||
.demandCommand();
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -12,7 +12,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const { id, config } = argv;
|
const { id, config } = argv;
|
||||||
assert(id, 'Invalid auction ID.');
|
assert(id, 'Invalid auction ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(config as string)
|
const { services: { cns: cnsConfig } } = getConfig(config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -21,5 +21,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const result = await registry.getAuctionsByIds([id as string]);
|
const result = await registry.getAuctionsByIds([id as string]);
|
||||||
|
|
||||||
queryOutput(result,argv.output)
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -7,4 +7,4 @@ export const desc = 'Auction operations.';
|
|||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('auction-cmds')
|
return yargs.commandDir('auction-cmds')
|
||||||
.demandCommand();
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -14,7 +14,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
assert(name, 'Invalid authority name.');
|
assert(name, 'Invalid authority name.');
|
||||||
assert(bondId, 'Invalid Bond ID.');
|
assert(bondId, 'Invalid Bond ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -24,7 +24,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.setAuthorityBond({ name, bondId }, privateKey, fee);
|
const result = await registry.setAuthorityBond({ name, bondId }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
|
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
}
|
};
|
||||||
|
@ -7,4 +7,4 @@ export const desc = 'Authority bond operations.';
|
|||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('bond-cmds')
|
return yargs.commandDir('bond-cmds')
|
||||||
.demandCommand();
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -13,14 +13,14 @@ export const builder = {
|
|||||||
type: 'string',
|
type: 'string',
|
||||||
default: ''
|
default: ''
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const name = argv.name as string;
|
const name = argv.name as string;
|
||||||
const owner = argv.owner as string;
|
const owner = argv.owner as string;
|
||||||
assert(name, 'Invalid authority name.');
|
assert(name, 'Invalid authority name.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -31,6 +31,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.reserveAuthority({ name, owner }, privateKey, fee);
|
const result = await registry.reserveAuthority({ name, owner }, privateKey, fee);
|
||||||
|
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
}
|
};
|
||||||
|
@ -12,7 +12,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const name = argv.name as string;
|
const name = argv.name as string;
|
||||||
assert(name, 'Invalid authority name.');
|
assert(name, 'Invalid authority name.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -21,5 +21,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const result = await registry.lookupAuthorities([name], true);
|
const result = await registry.lookupAuthorities([name], true);
|
||||||
|
|
||||||
queryOutput(result,argv.output)
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -7,4 +7,4 @@ export const desc = 'Name authority operations.';
|
|||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('authority-cmds')
|
return yargs.commandDir('authority-cmds')
|
||||||
.demandCommand();
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees ,txOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'associate';
|
export const command = 'associate';
|
||||||
|
|
||||||
@ -12,7 +12,7 @@ export const builder = {
|
|||||||
'bond-id': {
|
'bond-id': {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const id = argv.id as string;
|
const id = argv.id as string;
|
||||||
@ -20,7 +20,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
assert(id, 'Invalid Record ID.');
|
assert(id, 'Invalid Record ID.');
|
||||||
assert(bondId, 'Invalid Bond ID.');
|
assert(bondId, 'Invalid Bond ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -30,7 +30,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.associateBond({ recordId: id, bondId }, privateKey, fee);
|
const result = await registry.associateBond({ recordId: id, bondId }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -2,17 +2,17 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees,txOutput } from '../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'cancel';
|
export const command = 'cancel';
|
||||||
|
|
||||||
export const desc = 'Cancel bond.';
|
export const desc = 'Cancel bond.';
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const id = argv.id as string
|
const id = argv.id as string;
|
||||||
assert(id, 'Invalid Bond ID.');
|
assert(id, 'Invalid Bond ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -22,7 +22,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.cancelBond({ id }, privateKey, fee);
|
const result = await registry.cancelBond({ id }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees ,txOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'create';
|
export const command = 'create';
|
||||||
|
|
||||||
@ -15,17 +15,17 @@ export const builder = {
|
|||||||
quantity: {
|
quantity: {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const { config, verbose } = argv;
|
const { config } = argv;
|
||||||
const denom = argv.type as string;
|
const denom = argv.type as string;
|
||||||
const amount = argv.quantity as string;
|
const amount = argv.quantity as string;
|
||||||
|
|
||||||
assert(denom, 'Invalid Type.');
|
assert(denom, 'Invalid Type.');
|
||||||
assert(amount, 'Invalid Quantity.');
|
assert(amount, 'Invalid Quantity.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(config as string)
|
const { services: { cns: cnsConfig } } = getConfig(config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -36,8 +36,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const bondId = await registry.getNextBondId(privateKey);
|
const bondId = await registry.getNextBondId(privateKey);
|
||||||
const result = await registry.createBond({ denom, amount }, privateKey, fee);
|
const result = await registry.createBond({ denom, amount }, privateKey, fee);
|
||||||
const jsonString=`{"bondId":"${bondId}"}`
|
const jsonString = `{"bondId":"${bondId}"}`;
|
||||||
|
|
||||||
txOutput(result,jsonString,argv.output,argv.verbose)
|
txOutput(result, jsonString, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees ,txOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'dissociate';
|
export const command = 'dissociate';
|
||||||
|
|
||||||
@ -12,7 +12,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const id = argv.id as string;
|
const id = argv.id as string;
|
||||||
assert(id, 'Invalid Record ID.');
|
assert(id, 'Invalid Record ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -22,7 +22,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.dissociateBond({ recordId: id }, privateKey, fee);
|
const result = await registry.dissociateBond({ recordId: id }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo ,queryOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, queryOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'get';
|
export const command = 'get';
|
||||||
|
|
||||||
@ -12,7 +12,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const { id, config } = argv;
|
const { id, config } = argv;
|
||||||
console.assert(id, 'Bond Id is required.');
|
console.assert(id, 'Bond Id is required.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(config as string)
|
const { services: { cns: cnsConfig } } = getConfig(config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -22,5 +22,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
|
|
||||||
const result = await registry.getBondsByIds([id as string]);
|
const result = await registry.getBondsByIds([id as string]);
|
||||||
|
|
||||||
queryOutput(result,argv.output)
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo ,queryOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, queryOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'list';
|
export const command = 'list';
|
||||||
|
|
||||||
@ -12,10 +12,10 @@ export const builder = {
|
|||||||
owner: {
|
owner: {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -26,5 +26,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const { owner } = argv;
|
const { owner } = argv;
|
||||||
const result = await registry.queryBonds({ owner });
|
const result = await registry.queryBonds({ owner });
|
||||||
|
|
||||||
queryOutput(result,argv.output)
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees,txOutput } from '../../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../../util';
|
||||||
|
|
||||||
export const command = 'dissociate';
|
export const command = 'dissociate';
|
||||||
|
|
||||||
@ -12,13 +12,13 @@ export const builder = {
|
|||||||
'bond-id': {
|
'bond-id': {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const bondId = argv.bondId as string;
|
const bondId = argv.bondId as string;
|
||||||
assert(bondId, 'Invalid Bond ID.');
|
assert(bondId, 'Invalid Bond ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -28,7 +28,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.dissociateRecords({ bondId }, privateKey, fee);
|
const result = await registry.dissociateRecords({ bondId }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees ,txOutput} from '../../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../../util';
|
||||||
|
|
||||||
export const command = 'reassociate';
|
export const command = 'reassociate';
|
||||||
|
|
||||||
@ -15,7 +15,7 @@ export const builder = {
|
|||||||
'new-bond-id': {
|
'new-bond-id': {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const oldBondId = argv.oldBondId as string;
|
const oldBondId = argv.oldBondId as string;
|
||||||
@ -23,7 +23,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
assert(oldBondId, 'Invalid Old Bond ID.');
|
assert(oldBondId, 'Invalid Old Bond ID.');
|
||||||
assert(newBondId, 'Invalid New Bond ID.');
|
assert(newBondId, 'Invalid New Bond ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -33,7 +33,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.reassociateRecords({ oldBondId, newBondId }, privateKey, fee);
|
const result = await registry.reassociateRecords({ oldBondId, newBondId }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -7,4 +7,4 @@ export const desc = 'Bond records operations.';
|
|||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('records-cmds')
|
return yargs.commandDir('records-cmds')
|
||||||
.demandCommand();
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -2,8 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees ,txOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../util';
|
||||||
import { isNil } from 'lodash';
|
|
||||||
|
|
||||||
export const command = 'refill';
|
export const command = 'refill';
|
||||||
|
|
||||||
@ -16,18 +15,18 @@ export const builder = {
|
|||||||
quantity: {
|
quantity: {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const denom = argv.type as string;
|
const denom = argv.type as string;
|
||||||
const amount = argv.quantity as string;
|
const amount = argv.quantity as string;
|
||||||
const id = argv.id as string
|
const id = argv.id as string;
|
||||||
|
|
||||||
assert(id, 'Invalid Bond ID.');
|
assert(id, 'Invalid Bond ID.');
|
||||||
assert(denom, 'Invalid Type.');
|
assert(denom, 'Invalid Type.');
|
||||||
assert(amount, 'Invalid Quantity.');
|
assert(amount, 'Invalid Quantity.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -37,7 +36,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.refillBond({ id, denom, amount }, privateKey, fee);
|
const result = await registry.refillBond({ id, denom, amount }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees,txOutput } from '../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'withdraw';
|
export const command = 'withdraw';
|
||||||
|
|
||||||
@ -15,18 +15,18 @@ export const builder = {
|
|||||||
quantity: {
|
quantity: {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const denom = argv.type as string;
|
const denom = argv.type as string;
|
||||||
const amount = argv.quantity as string;
|
const amount = argv.quantity as string;
|
||||||
const id = argv.id as string
|
const id = argv.id as string;
|
||||||
|
|
||||||
assert(id, 'Invalid Bond ID.');
|
assert(id, 'Invalid Bond ID.');
|
||||||
assert(denom, 'Invalid Type.');
|
assert(denom, 'Invalid Type.');
|
||||||
assert(amount, 'Invalid Quantity.');
|
assert(amount, 'Invalid Quantity.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -36,7 +36,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.withdrawBond({ id, denom, amount }, privateKey, fee);
|
const result = await registry.withdrawBond({ id, denom, amount }, privateKey, fee);
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -7,4 +7,4 @@ export const desc = 'Bonds operations.';
|
|||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('bond-cmds')
|
return yargs.commandDir('bond-cmds')
|
||||||
.demandCommand();
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees ,txOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'delete [name]';
|
export const command = 'delete [name]';
|
||||||
|
|
||||||
@ -12,7 +12,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const name = argv.name as string;
|
const name = argv.name as string;
|
||||||
assert(name, 'Invalid Name.');
|
assert(name, 'Invalid Name.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -23,7 +23,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.deleteName({ crn: name }, privateKey, fee);
|
const result = await registry.deleteName({ crn: name }, privateKey, fee);
|
||||||
|
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo ,queryOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, queryOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'lookup [name]';
|
export const command = 'lookup [name]';
|
||||||
|
|
||||||
@ -12,13 +12,13 @@ export const builder = {
|
|||||||
history: {
|
history: {
|
||||||
type: 'boolean'
|
type: 'boolean'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const name = argv.name as string;
|
const name = argv.name as string;
|
||||||
assert(name, 'Invalid Name.');
|
assert(name, 'Invalid Name.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -27,5 +27,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const result = await registry.lookupNames([name], argv.history as boolean);
|
const result = await registry.lookupNames([name], argv.history as boolean);
|
||||||
|
|
||||||
queryOutput(result,argv.output)
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -12,7 +12,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const name = argv.name as string;
|
const name = argv.name as string;
|
||||||
assert(name, 'Invalid Name.');
|
assert(name, 'Invalid Name.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -24,4 +24,4 @@ export const handler = async (argv: Arguments) => {
|
|||||||
result = result.filter((v: any) => v);
|
result = result.filter((v: any) => v);
|
||||||
|
|
||||||
queryOutput(result, argv.output);
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo, getGasAndFees,txOutput } from '../../../util';
|
import { getConfig, getConnectionInfo, getGasAndFees, txOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'set [name] [id]';
|
export const command = 'set [name] [id]';
|
||||||
|
|
||||||
@ -14,7 +14,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
assert(name, 'Invalid Name.');
|
assert(name, 'Invalid Name.');
|
||||||
assert(id, 'Invalid Record ID.');
|
assert(id, 'Invalid Record ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -25,7 +25,6 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.setName({ crn: name, cid: id }, privateKey, fee);
|
const result = await registry.setName({ crn: name, cid: id }, privateKey, fee);
|
||||||
|
|
||||||
const success = `{"success":${result.code==0}}`
|
const success = `{"success":${result.code === 0}}`;
|
||||||
txOutput(result,success,argv.output,argv.verbose)
|
txOutput(result, success, argv.output, argv.verbose);
|
||||||
|
};
|
||||||
}
|
|
||||||
|
@ -6,5 +6,5 @@ export const desc = 'Name operations.';
|
|||||||
|
|
||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('name-cmds')
|
return yargs.commandDir('name-cmds')
|
||||||
.demandCommand()
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo ,queryOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, queryOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'get';
|
export const command = 'get';
|
||||||
|
|
||||||
@ -12,7 +12,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const { id, config } = argv;
|
const { id, config } = argv;
|
||||||
assert(id, 'Invalid Record ID.');
|
assert(id, 'Invalid Record ID.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(config as string)
|
const { services: { cns: cnsConfig } } = getConfig(config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -21,5 +21,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
const result = await registry.getRecordsByIds([id as string]);
|
const result = await registry.getRecordsByIds([id as string]);
|
||||||
|
|
||||||
queryOutput(result,argv.output)
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { Arguments } from 'yargs';
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
|
|
||||||
import { getConfig, getConnectionInfo ,queryOutput} from '../../../util';
|
import { getConfig, getConnectionInfo, queryOutput } from '../../../util';
|
||||||
|
|
||||||
export const command = 'list';
|
export const command = 'list';
|
||||||
|
|
||||||
@ -25,17 +25,17 @@ export const builder = {
|
|||||||
type: 'boolean',
|
type: 'boolean',
|
||||||
default: false
|
default: false
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
const { type, name, bondId, owner, all } = argv;
|
const { type, name, bondId, owner, all } = argv;
|
||||||
const filters: any = {};
|
const filters: any = {};
|
||||||
|
|
||||||
const filterArgs = argv._.slice(3);
|
const filterArgs = argv._.slice(3);
|
||||||
for (let i = 0; i < filterArgs.length-1; i+=2) {
|
for (let i = 0; i < filterArgs.length - 1; i += 2) {
|
||||||
filters[String(filterArgs[i]).replace(/^-+/,"")] = filterArgs[i+1];
|
filters[String(filterArgs[i]).replace(/^-+/, '')] = filterArgs[i + 1];
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
@ -44,7 +44,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
|
|
||||||
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
const registry = new Registry(gqlEndpoint, restEndpoint, chainId);
|
||||||
|
|
||||||
let result = await registry.queryRecords({...filters, type, name}, all as boolean);
|
let result = await registry.queryRecords({ ...filters, type, name }, all as boolean);
|
||||||
|
|
||||||
// Apply ex post filters.
|
// Apply ex post filters.
|
||||||
if (bondId) {
|
if (bondId) {
|
||||||
@ -55,5 +55,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
result = result.filter((v: any) => v.owners?.find((e: string) => e === owner));
|
result = result.filter((v: any) => v.owners?.find((e: string) => e === owner));
|
||||||
}
|
}
|
||||||
|
|
||||||
queryOutput(result, argv.output)
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import { Arguments } from 'yargs';
|
import { Arguments } from 'yargs';
|
||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import path from 'path';
|
|
||||||
import yaml from 'js-yaml';
|
import yaml from 'js-yaml';
|
||||||
import fs from 'fs';
|
import fs from 'fs';
|
||||||
import { Registry } from '@cerc-io/laconic-sdk';
|
import { Registry } from '@cerc-io/laconic-sdk';
|
||||||
@ -14,12 +13,12 @@ export const desc = 'Register record.';
|
|||||||
export const builder = {
|
export const builder = {
|
||||||
'bond-id': {
|
'bond-id': {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
},
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const { txKey, filename, verbose, config } = argv;
|
const { txKey, filename, config } = argv;
|
||||||
const { services: { cns: cnsConfig } } = getConfig(config as string)
|
const { services: { cns: cnsConfig } } = getConfig(config as string);
|
||||||
const { restEndpoint, gqlEndpoint, userKey, bondId, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, userKey, bondId, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
|
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
@ -39,7 +38,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
|
|
||||||
// Convert sub-objects (other than arrays) to a JSON automatically.
|
// Convert sub-objects (other than arrays) to a JSON automatically.
|
||||||
for (const [k, v] of Object.entries(record)) {
|
for (const [k, v] of Object.entries(record)) {
|
||||||
if (v && typeof v === "object" && !Array.isArray(v)) {
|
if (v && typeof v === 'object' && !Array.isArray(v)) {
|
||||||
record[k] = JSON.stringify(v);
|
record[k] = JSON.stringify(v);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -48,5 +47,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
const result = await registry.setRecord({ privateKey: userKey, record, bondId }, txKey as string, fee);
|
const result = await registry.setRecord({ privateKey: userKey, record, bondId }, txKey as string, fee);
|
||||||
|
|
||||||
txOutput(result,JSON.stringify(result.data,undefined,2),argv.output,argv.verbose)
|
txOutput(result, JSON.stringify(result.data, undefined, 2), argv.output, argv.verbose);
|
||||||
}
|
};
|
||||||
|
@ -6,6 +6,6 @@ export const desc = 'Record operations.';
|
|||||||
|
|
||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('record-cmds')
|
return yargs.commandDir('record-cmds')
|
||||||
.parserConfiguration({'unknown-options-as-args': true})
|
.parserConfiguration({ 'unknown-options-as-args': true })
|
||||||
.demandCommand()
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -9,7 +9,7 @@ export const command = 'status';
|
|||||||
export const desc = 'Get CNS status.';
|
export const desc = 'Get CNS status.';
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const { services: { cns } } = getConfig(argv.config as string)
|
const { services: { cns } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cns);
|
const { restEndpoint, gqlEndpoint, chainId } = getConnectionInfo(argv, cns);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -19,4 +19,4 @@ export const handler = async (argv: Arguments) => {
|
|||||||
|
|
||||||
const result = await registry.getStatus();
|
const result = await registry.getStatus();
|
||||||
console.log(JSON.stringify(result, undefined, 2));
|
console.log(JSON.stringify(result, undefined, 2));
|
||||||
}
|
};
|
||||||
|
@ -15,7 +15,7 @@ export const builder = {
|
|||||||
quantity: {
|
quantity: {
|
||||||
type: 'string'
|
type: 'string'
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
export const handler = async (argv: Arguments) => {
|
export const handler = async (argv: Arguments) => {
|
||||||
const destinationAddress = argv.address as string;
|
const destinationAddress = argv.address as string;
|
||||||
@ -26,7 +26,7 @@ export const handler = async (argv: Arguments) => {
|
|||||||
assert(denom, 'Invalid Type.');
|
assert(denom, 'Invalid Type.');
|
||||||
assert(amount, 'Invalid Quantity.');
|
assert(amount, 'Invalid Quantity.');
|
||||||
|
|
||||||
const { services: { cns: cnsConfig } } = getConfig(argv.config as string)
|
const { services: { cns: cnsConfig } } = getConfig(argv.config as string);
|
||||||
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
const { restEndpoint, gqlEndpoint, privateKey, chainId } = getConnectionInfo(argv, cnsConfig);
|
||||||
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
assert(restEndpoint, 'Invalid CNS REST endpoint.');
|
||||||
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
assert(gqlEndpoint, 'Invalid CNS GQL endpoint.');
|
||||||
@ -40,5 +40,5 @@ export const handler = async (argv: Arguments) => {
|
|||||||
const fee = getGasAndFees(argv, cnsConfig);
|
const fee = getGasAndFees(argv, cnsConfig);
|
||||||
await registry.sendCoins({ denom, amount, destinationAddress }, privateKey, fee);
|
await registry.sendCoins({ denom, amount, destinationAddress }, privateKey, fee);
|
||||||
const result = await registry.getAccounts([fromAddress, destinationAddress]);
|
const result = await registry.getAccounts([fromAddress, destinationAddress]);
|
||||||
queryOutput(result,argv.output)
|
queryOutput(result, argv.output);
|
||||||
}
|
};
|
||||||
|
@ -7,4 +7,4 @@ export const desc = 'Tokens operations.';
|
|||||||
exports.builder = (yargs: yargs.Argv) => {
|
exports.builder = (yargs: yargs.Argv) => {
|
||||||
return yargs.commandDir('tokens-cmds')
|
return yargs.commandDir('tokens-cmds')
|
||||||
.demandCommand();
|
.demandCommand();
|
||||||
}
|
};
|
||||||
|
@ -11,13 +11,13 @@ exports.builder = (yargs: yargs.Argv) => {
|
|||||||
'tx-key': { type: 'string' },
|
'tx-key': { type: 'string' },
|
||||||
'bond-id': { type: 'string' },
|
'bond-id': { type: 'string' },
|
||||||
'chain-id': { type: 'string' },
|
'chain-id': { type: 'string' },
|
||||||
'filename': { alias: 'f' },
|
filename: { alias: 'f' },
|
||||||
'id': { type: 'string' },
|
id: { type: 'string' },
|
||||||
'address': { type: 'string' },
|
address: { type: 'string' },
|
||||||
'gas': { type: 'string' },
|
gas: { type: 'string' },
|
||||||
'fees': { type: 'string' }
|
fees: { type: 'string' }
|
||||||
})
|
})
|
||||||
.commandDir('cns-cmds')
|
.commandDir('cns-cmds')
|
||||||
.demandCommand()
|
.demandCommand()
|
||||||
.help()
|
.help();
|
||||||
}
|
};
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import yargs from 'yargs/yargs';
|
import yargs from 'yargs/yargs';
|
||||||
import { hideBin } from 'yargs/helpers';
|
import { hideBin } from 'yargs/helpers';
|
||||||
|
|
||||||
|
// eslint-disable-next-line no-unused-expressions
|
||||||
yargs(hideBin(process.argv))
|
yargs(hideBin(process.argv))
|
||||||
.options({
|
.options({
|
||||||
verbose: {
|
verbose: {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { Arguments } from "yargs";
|
import { Arguments } from 'yargs';
|
||||||
import clean from 'lodash-clean';
|
import clean from 'lodash-clean';
|
||||||
|
|
||||||
export const getConnectionInfo = (argv: Arguments, config: any) => {
|
export const getConnectionInfo = (argv: Arguments, config: any) => {
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
import yaml from 'js-yaml'
|
import yaml from 'js-yaml';
|
||||||
import fs from 'fs'
|
import fs from 'fs';
|
||||||
import path from 'path'
|
import path from 'path';
|
||||||
|
|
||||||
export const getConfig = (configFilePath: string): any => {
|
export const getConfig = (configFilePath: string): any => {
|
||||||
const resolvedFilePath = path.resolve(process.cwd(), configFilePath);
|
const resolvedFilePath = path.resolve(process.cwd(), configFilePath);
|
||||||
const configFile = fs.readFileSync(resolvedFilePath, 'utf-8')
|
const configFile = fs.readFileSync(resolvedFilePath, 'utf-8');
|
||||||
return yaml.load(configFile);
|
return yaml.load(configFile);
|
||||||
};
|
};
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
/* eslint-disable @typescript-eslint/no-unused-vars */
|
||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { Arguments } from 'yargs';
|
import { Arguments } from 'yargs';
|
||||||
|
|
||||||
|
@ -1,22 +1,22 @@
|
|||||||
|
|
||||||
export const txOutput = (result:any,msg:string,output:unknown,verbose:unknown) => {
|
export const txOutput = (result:any, msg:string, output:unknown, verbose:unknown) => {
|
||||||
if (output=="json"){
|
if (output === 'json') {
|
||||||
console.log(verbose ? JSON.parse(JSON.stringify(result)) : JSON.parse(msg));
|
console.log(verbose ? JSON.parse(JSON.stringify(result)) : JSON.parse(msg));
|
||||||
} else {
|
} else {
|
||||||
console.log(verbose ? JSON.stringify(result,undefined,2) : msg);
|
console.log(verbose ? JSON.stringify(result, undefined, 2) : msg);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
export const queryOutput = (result: any, output: unknown) => {
|
export const queryOutput = (result: any, output: unknown) => {
|
||||||
if (output=="json"){
|
if (output === 'json') {
|
||||||
console.log(JSON.parse(JSON.stringify(result)));
|
console.log(JSON.parse(JSON.stringify(result)));
|
||||||
} else {
|
} else {
|
||||||
console.log(JSON.stringify(result, (key, value) => {
|
console.log(JSON.stringify(result, (key, value) => {
|
||||||
try {
|
try {
|
||||||
return JSON.parse(value)
|
return JSON.parse(value);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
}, 2));
|
}, 2));
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
528
test/cli.test.ts
Normal file
528
test/cli.test.ts
Normal file
@ -0,0 +1,528 @@
|
|||||||
|
import fs from 'fs';
|
||||||
|
import assert from 'assert';
|
||||||
|
import { spawnSync } from 'child_process';
|
||||||
|
|
||||||
|
import {
|
||||||
|
CHAIN_ID,
|
||||||
|
TOKEN_TYPE,
|
||||||
|
AUCTION_COMMIT_DURATION,
|
||||||
|
AUCTION_REVEAL_DURATION,
|
||||||
|
delay,
|
||||||
|
checkResultAndRetrieveOutput,
|
||||||
|
createBond,
|
||||||
|
getBondObj,
|
||||||
|
getAccountObj,
|
||||||
|
getRecordObj,
|
||||||
|
getAuthorityObj,
|
||||||
|
getAuctionObj,
|
||||||
|
getBidObj
|
||||||
|
} from './helpers';
|
||||||
|
|
||||||
|
describe('Test laconic CLI commands', () => {
|
||||||
|
test('laconic', async () => {
|
||||||
|
const result = spawnSync('laconic');
|
||||||
|
expect(result.status).toBe(1);
|
||||||
|
|
||||||
|
const output = result.stdout.toString().trim();
|
||||||
|
const errorOutput = result.stderr.toString().trim();
|
||||||
|
|
||||||
|
// Expect error with usage string
|
||||||
|
expect(output).toBe('');
|
||||||
|
expect(errorOutput).toContain('laconic <command>');
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns']);
|
||||||
|
expect(result.status).toBe(1);
|
||||||
|
|
||||||
|
const output = result.stdout.toString().trim();
|
||||||
|
const errorOutput = result.stderr.toString().trim();
|
||||||
|
|
||||||
|
// Expect error with usage string
|
||||||
|
expect(output).toBe('');
|
||||||
|
expect(errorOutput).toContain('laconic cns');
|
||||||
|
expect(errorOutput).toContain('CNS tools');
|
||||||
|
expect(errorOutput).toContain('Commands:');
|
||||||
|
});
|
||||||
|
|
||||||
|
// TODO: Break up tests into separate files
|
||||||
|
// TODO: Add tests for CNS commands with all available flags
|
||||||
|
|
||||||
|
describe('laconic CNS commands', () => {
|
||||||
|
const testAccount = process.env.TEST_ACCOUNT;
|
||||||
|
assert(testAccount, 'TEST_ACCOUNT not set in env');
|
||||||
|
const testAccount2 = 'ethm1vc62ysqu504at932jjq8pwrqgjt67rx6ggn5yu';
|
||||||
|
const initialAccountBalance = Number('100000000000000000000000000');
|
||||||
|
|
||||||
|
const testAuthorityName = 'laconic';
|
||||||
|
const testRecordFilePath = 'test/data/watcher-record.yml';
|
||||||
|
let testAuctionId: string, testRecordId: string, testRecordBondId: string;
|
||||||
|
|
||||||
|
test('laconic cns status', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'status']);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expect output object to have CNS status props
|
||||||
|
expect(outputObj).toHaveProperty('version');
|
||||||
|
expect(outputObj).toHaveProperty('node');
|
||||||
|
expect(outputObj).toHaveProperty('node.network', CHAIN_ID);
|
||||||
|
expect(outputObj).toHaveProperty('sync');
|
||||||
|
expect(Number(outputObj.sync.latest_block_height)).toBeGreaterThan(0);
|
||||||
|
expect(outputObj).toHaveProperty('validator');
|
||||||
|
expect(outputObj).toHaveProperty('validators');
|
||||||
|
expect(outputObj).toHaveProperty('num_peers');
|
||||||
|
expect(outputObj).toHaveProperty('peers');
|
||||||
|
expect(outputObj).toHaveProperty('disk_usage');
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Bond operations', () => {
|
||||||
|
const bondOwner = testAccount;
|
||||||
|
let bondBalance = 1000000000;
|
||||||
|
let bondId: string;
|
||||||
|
|
||||||
|
test('laconic cns bond create --type <type> --quantity <quantity> --gas <gas> --fees <fees>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'create', '--type', TOKEN_TYPE, '--quantity', bondBalance.toString(), '--gas', '200000', '--fees', `200000${TOKEN_TYPE}`]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expect output object to have resultant bond id
|
||||||
|
expect(outputObj.bondId).toBeDefined();
|
||||||
|
|
||||||
|
bondId = outputObj.bondId;
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns bond list', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'list']);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected bond
|
||||||
|
const expectedBond = getBondObj({ id: bondId, owner: bondOwner, balance: bondBalance });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toEqual(expectedBond);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns bond list --owner <owner_address>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'list', '--owner', bondOwner]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected bond
|
||||||
|
const expectedBond = getBondObj({ id: bondId, owner: bondOwner, balance: bondBalance });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toEqual(expectedBond);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns bond get --id <bond_id>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'get', '--id', bondId]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected bond
|
||||||
|
const expectedBond = getBondObj({ id: bondId, owner: bondOwner, balance: bondBalance });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toEqual(expectedBond);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns bond refill --id <bond_id> --type <type> --quantity <quantity>', async () => {
|
||||||
|
const bondRefillAmount = 1000;
|
||||||
|
bondBalance += bondRefillAmount;
|
||||||
|
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'refill', '--id', bondId, '--type', TOKEN_TYPE, '--quantity', bondRefillAmount.toString()]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
// Check updated bond
|
||||||
|
const bondResult = spawnSync('laconic', ['cns', 'bond', 'get', '--id', bondId]);
|
||||||
|
const bondOutputObj = checkResultAndRetrieveOutput(bondResult);
|
||||||
|
|
||||||
|
// Expected bond
|
||||||
|
const expectedBond = getBondObj({ id: bondId, owner: bondOwner, balance: bondBalance });
|
||||||
|
|
||||||
|
expect(bondOutputObj.length).toEqual(1);
|
||||||
|
expect(bondOutputObj[0]).toEqual(expectedBond);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns bond withdraw --id <bond_id> --type <type> --quantity <quantity>', async () => {
|
||||||
|
const bondWithdrawAmount = 500;
|
||||||
|
bondBalance -= bondWithdrawAmount;
|
||||||
|
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'withdraw', '--id', bondId, '--type', TOKEN_TYPE, '--quantity', bondWithdrawAmount.toString()]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
// Check updated bond
|
||||||
|
const bondResult = spawnSync('laconic', ['cns', 'bond', 'get', '--id', bondId]);
|
||||||
|
const bondOutputObj = checkResultAndRetrieveOutput(bondResult);
|
||||||
|
|
||||||
|
// Expected bond
|
||||||
|
const expectedBond = getBondObj({ id: bondId, owner: bondOwner, balance: bondBalance });
|
||||||
|
|
||||||
|
// Expect balance to be deducted
|
||||||
|
expect(bondOutputObj.length).toEqual(1);
|
||||||
|
expect(bondOutputObj[0]).toEqual(expectedBond);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns bond cancel --id <bond_id>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'cancel', '--id', bondId]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
// Check updated bond
|
||||||
|
const bondResult = spawnSync('laconic', ['cns', 'bond', 'get', '--id', bondId]);
|
||||||
|
const bondOutputObj = checkResultAndRetrieveOutput(bondResult);
|
||||||
|
|
||||||
|
// Expect empty object
|
||||||
|
expect(bondOutputObj.length).toEqual(1);
|
||||||
|
expect(bondOutputObj[0]).toEqual({ id: '', owner: '', balance: [] });
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Account and tokens operations', () => {
|
||||||
|
let balanceBeforeSend: number;
|
||||||
|
|
||||||
|
test('laconic cns account get --address <account_address>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'account', 'get', '--address', testAccount]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected account
|
||||||
|
const expectedAccount = getAccountObj({ address: testAccount });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toMatchObject(expectedAccount);
|
||||||
|
expect(outputObj[0].number).toBeDefined();
|
||||||
|
expect(outputObj[0].sequence).toBeDefined();
|
||||||
|
|
||||||
|
balanceBeforeSend = Number(outputObj[0].balance[0].quantity);
|
||||||
|
expect(balanceBeforeSend).toBeGreaterThan(0);
|
||||||
|
expect(balanceBeforeSend).toBeLessThan(initialAccountBalance);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns tokens send --address <account_address> --type <token_type> --quantity <quantity>', async () => {
|
||||||
|
const sendAmount = 1000000000;
|
||||||
|
const balanceAfterSend = balanceBeforeSend - sendAmount;
|
||||||
|
|
||||||
|
const result = spawnSync('laconic', ['cns', 'tokens', 'send', '--address', testAccount2, '--type', TOKEN_TYPE, '--quantity', sendAmount.toString()]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected acconts
|
||||||
|
const expectedAccounts = [
|
||||||
|
getAccountObj({ address: testAccount, balance: balanceAfterSend }),
|
||||||
|
getAccountObj({ address: testAccount2, balance: sendAmount })
|
||||||
|
];
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(2);
|
||||||
|
expect(outputObj).toMatchObject(expectedAccounts);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Record operations', () => {
|
||||||
|
const gas = 250000;
|
||||||
|
const bondBalance = 1000000000;
|
||||||
|
|
||||||
|
test('laconic cns record publish --filename <record_file> --bond-id <bond_id> --gas <gas>', async () => {
|
||||||
|
// Create a new bond to be associated with the record
|
||||||
|
({ bondId: testRecordBondId } = createBond(bondBalance));
|
||||||
|
|
||||||
|
const result = spawnSync('laconic', ['cns', 'record', 'publish', '--filename', testRecordFilePath, '--bond-id', testRecordBondId, '--gas', gas.toString()]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expect output object to resultant bond id
|
||||||
|
expect(outputObj.id).toBeDefined();
|
||||||
|
|
||||||
|
testRecordId = outputObj.id;
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns record list', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'record', 'list']);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected record
|
||||||
|
const expectedRecord = getRecordObj(testRecordFilePath, { bondId: testRecordBondId, recordId: testRecordId, names: null });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toMatchObject(expectedRecord);
|
||||||
|
expect(outputObj[0].createTime).toBeDefined();
|
||||||
|
expect(outputObj[0].expiryTime).toBeDefined();
|
||||||
|
expect(outputObj[0].owners).toBeDefined();
|
||||||
|
expect(outputObj[0].owners.length).toEqual(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns record get --id <record_id>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'record', 'get', '--id', testRecordId]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected record
|
||||||
|
const expectedRecord = getRecordObj(testRecordFilePath, { bondId: testRecordBondId, recordId: testRecordId, names: null });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toMatchObject(expectedRecord);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Bond records operations', () => {
|
||||||
|
let testRecordBondId2: string;
|
||||||
|
|
||||||
|
test('laconic cns bond dissociate --id <record_id>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'dissociate', '--id', testRecordId]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
const recordResult = spawnSync('laconic', ['cns', 'record', 'get', '--id', testRecordId]);
|
||||||
|
const recordOutputObj = checkResultAndRetrieveOutput(recordResult);
|
||||||
|
|
||||||
|
// Expected record
|
||||||
|
const expectedRecord = getRecordObj(testRecordFilePath, { bondId: '', recordId: testRecordId, names: null });
|
||||||
|
|
||||||
|
expect(recordOutputObj.length).toEqual(1);
|
||||||
|
expect(recordOutputObj[0]).toMatchObject(expectedRecord);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns bond associate --id <record_id> --bond-id <bond_id>', async () => {
|
||||||
|
// Create a new bond to be associated with the record
|
||||||
|
({ bondId: testRecordBondId2 } = createBond(bondBalance));
|
||||||
|
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'associate', '--id', testRecordId, '--bond-id', testRecordBondId2]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
const recordResult = spawnSync('laconic', ['cns', 'record', 'get', '--id', testRecordId]);
|
||||||
|
const recordOutputObj = checkResultAndRetrieveOutput(recordResult);
|
||||||
|
|
||||||
|
// Expected record
|
||||||
|
const expectedRecord = getRecordObj(testRecordFilePath, { bondId: testRecordBondId2, recordId: testRecordId, names: null });
|
||||||
|
|
||||||
|
expect(recordOutputObj.length).toEqual(1);
|
||||||
|
expect(recordOutputObj[0]).toMatchObject(expectedRecord);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns bond records reassociate --old-bond-id <old_bond_id> --new-bond-id <new_bond_id>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'records', 'reassociate', '--old-bond-id', testRecordBondId2, '--new-bond-id', testRecordBondId]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
const recordResult = spawnSync('laconic', ['cns', 'record', 'get', '--id', testRecordId]);
|
||||||
|
const recordOutputObj = checkResultAndRetrieveOutput(recordResult);
|
||||||
|
|
||||||
|
// Expected record
|
||||||
|
const expectedRecord = getRecordObj(testRecordFilePath, { bondId: testRecordBondId, recordId: testRecordId, names: null });
|
||||||
|
|
||||||
|
expect(recordOutputObj.length).toEqual(1);
|
||||||
|
expect(recordOutputObj[0]).toMatchObject(expectedRecord);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Name authority operations (pre auction)', () => {
|
||||||
|
test('laconic cns authority reserve <authority_name>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'authority', 'reserve', testAuthorityName]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expect result
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns authority whois <authority_name>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'authority', 'whois', testAuthorityName]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected authority (still in auction)
|
||||||
|
const expectedAuthority = getAuthorityObj({ owner: '', status: 'auction', auction: getAuctionObj({ owner: testAccount }) });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toMatchObject(expectedAuthority);
|
||||||
|
expect(outputObj[0].expiryTime).toBeDefined();
|
||||||
|
expect(outputObj[0].height).toBeGreaterThan(0);
|
||||||
|
|
||||||
|
testAuctionId = outputObj[0].auction.id;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Auction operations', () => {
|
||||||
|
const bidAmount = 25000000;
|
||||||
|
let bidRevealFilePath: string;
|
||||||
|
|
||||||
|
test('laconic cns auction get <auction_id>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'auction', 'get', testAuctionId]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected auction (still in commit stage)
|
||||||
|
const expectedAuction = getAuctionObj({ owner: testAccount, status: 'commit' });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toMatchObject(expectedAuction);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns auction bid commit <auction_id> <quantity> <type>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'auction', 'bid', 'commit', testAuctionId, bidAmount.toString(), TOKEN_TYPE]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj.reveal_file).toBeDefined();
|
||||||
|
|
||||||
|
bidRevealFilePath = outputObj.reveal_file;
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns auction bid reveal <auction_id> <file_path>', async () => {
|
||||||
|
// Wait for auction commits duration (60s)
|
||||||
|
await delay(AUCTION_COMMIT_DURATION * 1000);
|
||||||
|
|
||||||
|
const auctionResult = spawnSync('laconic', ['cns', 'auction', 'get', testAuctionId]);
|
||||||
|
const auctionOutputObj = checkResultAndRetrieveOutput(auctionResult);
|
||||||
|
|
||||||
|
const expectedAuction = getAuctionObj({ owner: testAccount, status: 'reveal' });
|
||||||
|
const expectedBid = getBidObj({ bidder: testAccount });
|
||||||
|
|
||||||
|
expect(auctionOutputObj[0]).toMatchObject(expectedAuction);
|
||||||
|
expect(auctionOutputObj[0].bids[0]).toMatchObject(expectedBid);
|
||||||
|
|
||||||
|
// Reveal bid
|
||||||
|
const result = spawnSync('laconic', ['cns', 'auction', 'bid', 'reveal', testAuctionId, bidRevealFilePath]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
const revealObject = JSON.parse(fs.readFileSync(bidRevealFilePath, 'utf8'));
|
||||||
|
expect(revealObject).toMatchObject({
|
||||||
|
chainId: CHAIN_ID,
|
||||||
|
auctionId: testAuctionId,
|
||||||
|
bidderAddress: testAccount,
|
||||||
|
bidAmount: `${bidAmount}aphoton`
|
||||||
|
});
|
||||||
|
}, (AUCTION_COMMIT_DURATION + 5) * 1000);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Name authority operations (post auction)', () => {
|
||||||
|
const testSubAuthorityName = 'echo.laconic';
|
||||||
|
const testSubAuthorityName2 = 'kube.laconic';
|
||||||
|
|
||||||
|
test('laconic cns authority whois <authority_name>', async () => {
|
||||||
|
// Wait for auction reveals duration (60s)
|
||||||
|
await delay(AUCTION_REVEAL_DURATION * 1000);
|
||||||
|
|
||||||
|
const result = spawnSync('laconic', ['cns', 'authority', 'whois', testAuthorityName]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected authority (active)
|
||||||
|
const expectedAuthority = getAuthorityObj({ owner: testAccount, status: 'active', auction: null });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toMatchObject(expectedAuthority);
|
||||||
|
}, (AUCTION_REVEAL_DURATION + 5) * 1000);
|
||||||
|
|
||||||
|
test('laconic cns authority bond set laconic <bond_id>', async () => {
|
||||||
|
// Create a new bond to be set on the authority
|
||||||
|
const bondBalance = 1000000000;
|
||||||
|
const { bondId } = createBond(bondBalance);
|
||||||
|
|
||||||
|
const result = spawnSync('laconic', ['cns', 'authority', 'bond', 'set', testAuthorityName, bondId]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
// Check updated authority
|
||||||
|
const authorityResult = spawnSync('laconic', ['cns', 'authority', 'whois', testAuthorityName]);
|
||||||
|
const authorityOutputObj = checkResultAndRetrieveOutput(authorityResult);
|
||||||
|
|
||||||
|
// Expected authority (active with bond)
|
||||||
|
const expectedAuthority = getAuthorityObj({ owner: testAccount, status: 'active', auction: null, bondId: bondId });
|
||||||
|
|
||||||
|
expect(authorityOutputObj.length).toEqual(1);
|
||||||
|
expect(authorityOutputObj[0]).toMatchObject(expectedAuthority);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns authority reserve <sub_authority> (same owner)', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'authority', 'reserve', testSubAuthorityName]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
// Check updated authority
|
||||||
|
const authorityResult = spawnSync('laconic', ['cns', 'authority', 'whois', testSubAuthorityName]);
|
||||||
|
const authorityOutputObj = checkResultAndRetrieveOutput(authorityResult);
|
||||||
|
|
||||||
|
// Expected authority (active with bond)
|
||||||
|
const expectedAuthority = getAuthorityObj({ owner: testAccount, status: 'active', auction: null });
|
||||||
|
|
||||||
|
expect(authorityOutputObj.length).toEqual(1);
|
||||||
|
expect(authorityOutputObj[0]).toMatchObject(expectedAuthority);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns authority reserve <sub_authority> --owner <owner_address> (different owner)', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'authority', 'reserve', testSubAuthorityName2, '--owner', testAccount2]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
// Check updated authority
|
||||||
|
const authorityResult = spawnSync('laconic', ['cns', 'authority', 'whois', testSubAuthorityName2]);
|
||||||
|
const authorityOutputObj = checkResultAndRetrieveOutput(authorityResult);
|
||||||
|
|
||||||
|
// Expected authority (active with bond)
|
||||||
|
const expectedAuthority = getAuthorityObj({ owner: testAccount2, status: 'active', auction: null });
|
||||||
|
|
||||||
|
expect(authorityOutputObj.length).toEqual(1);
|
||||||
|
expect(authorityOutputObj[0]).toMatchObject(expectedAuthority);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Name operations', () => {
|
||||||
|
const testName = 'crn://laconic/watcher/erc20';
|
||||||
|
|
||||||
|
test('laconic cns name set <name> <record_id>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'name', 'set', testName, testRecordId]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns name lookup <name>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'name', 'lookup', testName]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toMatchObject({ latest: { id: testRecordId } });
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns name resolve <name>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'name', 'resolve', testName]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected resolved record
|
||||||
|
const expectedRecord = getRecordObj(testRecordFilePath, { bondId: testRecordBondId, recordId: testRecordId, names: [testName] });
|
||||||
|
|
||||||
|
expect(outputObj.length).toEqual(1);
|
||||||
|
expect(outputObj[0]).toMatchObject(expectedRecord);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('laconic cns name delete <name>', async () => {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'name', 'delete', testName]);
|
||||||
|
const outputObj = checkResultAndRetrieveOutput(result);
|
||||||
|
|
||||||
|
// Expected output
|
||||||
|
expect(outputObj).toEqual({ success: true });
|
||||||
|
|
||||||
|
// Check that name doesn't resolve
|
||||||
|
const resolveResult = spawnSync('laconic', ['cns', 'name', 'resolve', testName]);
|
||||||
|
const resolveOutputObj = checkResultAndRetrieveOutput(resolveResult);
|
||||||
|
expect(resolveOutputObj.length).toEqual(0);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
7
test/data/watcher-record.yml
Normal file
7
test/data/watcher-record.yml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
record:
|
||||||
|
type: WebsiteRegistrationRecord
|
||||||
|
url: 'https://cerc.io'
|
||||||
|
repo_registration_record_cid: QmSnuWmxptJZdLJpKRarxBMS2Ju2oANVrgbr2xWbie9b2D
|
||||||
|
build_artifact_cid: QmP8jTG1m9GSDJLCbeWhVSVgEzCPPwXRdCRuJtQ5Tz9Kc9
|
||||||
|
tls_cert_cid: QmbWqxBEKC3P8tqsKc98xmWNzrzDtRLMiMPL8wBuTGsMnR
|
||||||
|
version: 1.0.23
|
121
test/helpers.ts
Normal file
121
test/helpers.ts
Normal file
@ -0,0 +1,121 @@
|
|||||||
|
import fs from 'fs';
|
||||||
|
import yaml from 'js-yaml';
|
||||||
|
import { SpawnSyncReturns, spawnSync } from 'child_process';
|
||||||
|
|
||||||
|
export const CHAIN_ID = 'laconic_9000-1';
|
||||||
|
export const TOKEN_TYPE = 'aphoton';
|
||||||
|
|
||||||
|
export const AUCTION_FEES = {
|
||||||
|
commit: 1000000,
|
||||||
|
reveal: 1000000,
|
||||||
|
minimumBid: 5000000
|
||||||
|
};
|
||||||
|
export const AUCTION_COMMIT_DURATION = 60; // 60s
|
||||||
|
export const AUCTION_REVEAL_DURATION = 60; // 60s
|
||||||
|
|
||||||
|
export function checkResultAndRetrieveOutput (result: SpawnSyncReturns<Buffer>): any {
|
||||||
|
expect(result.status).toBe(0);
|
||||||
|
|
||||||
|
const errorOutput = result.stderr.toString().trim();
|
||||||
|
expect(errorOutput).toBe('');
|
||||||
|
|
||||||
|
const output = result.stdout.toString().trim();
|
||||||
|
expect(output.length).toBeGreaterThan(0);
|
||||||
|
|
||||||
|
return JSON.parse(output);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function createBond (quantity: number): { bondId: string } {
|
||||||
|
const result = spawnSync('laconic', ['cns', 'bond', 'create', '--type', TOKEN_TYPE, '--quantity', quantity.toString(), '--gas', '200000', '--fees', `200000${TOKEN_TYPE}`]);
|
||||||
|
const output = result.stdout.toString().trim();
|
||||||
|
|
||||||
|
return JSON.parse(output);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getBondObj (params: { id: string, owner: string, balance: number}): any {
|
||||||
|
return {
|
||||||
|
id: params.id,
|
||||||
|
owner: params.owner,
|
||||||
|
balance: [
|
||||||
|
{
|
||||||
|
type: TOKEN_TYPE,
|
||||||
|
quantity: params.balance
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getAccountObj (params: { address: string, balance?: number }): any {
|
||||||
|
const balanceObj: any = { type: TOKEN_TYPE };
|
||||||
|
if (params.balance) {
|
||||||
|
balanceObj.quantity = params.balance;
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
address: params.address,
|
||||||
|
balance: [balanceObj]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getRecordObj (recordFilePath: string, params: { bondId: string, recordId: string, names: any }): any {
|
||||||
|
const recordContent = yaml.load(fs.readFileSync(recordFilePath, 'utf8')) as any;
|
||||||
|
|
||||||
|
return {
|
||||||
|
id: params.recordId,
|
||||||
|
names: params.names,
|
||||||
|
bondId: params.bondId,
|
||||||
|
attributes: recordContent.record
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getAuthorityObj (params: { owner: string, status: string, auction: any, bondId?: string }): any {
|
||||||
|
return {
|
||||||
|
ownerAddress: params.owner,
|
||||||
|
status: params.status,
|
||||||
|
bondId: params.bondId || '',
|
||||||
|
auction: params.auction
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getAuctionObj (params: { owner: string, status?: string }): any {
|
||||||
|
return {
|
||||||
|
status: params.status || 'commit',
|
||||||
|
ownerAddress: params.owner,
|
||||||
|
commitFee: {
|
||||||
|
type: TOKEN_TYPE,
|
||||||
|
quantity: AUCTION_FEES.commit
|
||||||
|
},
|
||||||
|
revealFee: {
|
||||||
|
type: TOKEN_TYPE,
|
||||||
|
quantity: AUCTION_FEES.reveal
|
||||||
|
},
|
||||||
|
minimumBid: {
|
||||||
|
type: TOKEN_TYPE,
|
||||||
|
quantity: AUCTION_FEES.minimumBid
|
||||||
|
},
|
||||||
|
winnerAddress: ''
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getBidObj (params: { bidder: string, status?: string }): any {
|
||||||
|
return {
|
||||||
|
bidderAddress: params.bidder,
|
||||||
|
status: params.status || 'commit',
|
||||||
|
commitFee: {
|
||||||
|
type: TOKEN_TYPE,
|
||||||
|
quantity: AUCTION_FEES.commit
|
||||||
|
},
|
||||||
|
revealFee: {
|
||||||
|
type: TOKEN_TYPE,
|
||||||
|
quantity: AUCTION_FEES.reveal
|
||||||
|
},
|
||||||
|
bidAmount: {
|
||||||
|
type: '',
|
||||||
|
quantity: 0
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function delay (ms: number): Promise<any> {
|
||||||
|
return new Promise((resolve) => setTimeout(resolve, ms));
|
||||||
|
}
|
34
test/run-tests.sh
Executable file
34
test/run-tests.sh
Executable file
@ -0,0 +1,34 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Get the key from laconicd
|
||||||
|
laconicd_key=$(yes | docker compose exec laconicd laconicd keys export mykey --unarmored-hex --unsafe)
|
||||||
|
|
||||||
|
# Get the fixturenet account address
|
||||||
|
laconicd_account_address=$(docker compose exec laconicd laconicd keys list | awk '/- address:/ {print $3}')
|
||||||
|
|
||||||
|
# Set parameters for the test suite
|
||||||
|
cosmos_chain_id=laconic_9000-1
|
||||||
|
laconicd_rest_endpoint=http://127.0.0.1:1317
|
||||||
|
laconicd_gql_endpoint=http://127.0.0.1:9473/api
|
||||||
|
|
||||||
|
# Create the required config
|
||||||
|
config_file="config.yml"
|
||||||
|
config=$(cat <<EOL
|
||||||
|
services:
|
||||||
|
cns:
|
||||||
|
restEndpoint: $laconicd_rest_endpoint
|
||||||
|
gqlEndpoint: $laconicd_gql_endpoint
|
||||||
|
userKey: $laconicd_key
|
||||||
|
bondId:
|
||||||
|
chainId: $cosmos_chain_id
|
||||||
|
gas: 200000
|
||||||
|
fees: 200000aphoton
|
||||||
|
EOL
|
||||||
|
)
|
||||||
|
echo "$config" > "$config_file"
|
||||||
|
|
||||||
|
# Wait for the laconid endpoint to come up
|
||||||
|
docker compose exec laconicd sh -c "curl --retry 10 --retry-delay 3 --retry-connrefused http://127.0.0.1:9473/api"
|
||||||
|
|
||||||
|
# Run tests
|
||||||
|
TEST_ACCOUNT=$laconicd_account_address yarn test
|
@ -97,5 +97,7 @@
|
|||||||
/* Completeness */
|
/* Completeness */
|
||||||
// "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */
|
// "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */
|
||||||
"skipLibCheck": true /* Skip type checking all .d.ts files. */
|
"skipLibCheck": true /* Skip type checking all .d.ts files. */
|
||||||
}
|
},
|
||||||
|
"include": ["src"],
|
||||||
|
"exclude": ["test"]
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user