From fcf7da488e4fd7255d9ecdb0ab2fa5adeeb0833e Mon Sep 17 00:00:00 2001 From: Rishi Panthee Date: Sun, 24 Jul 2022 22:49:06 -0400 Subject: [PATCH 1/2] Add verification to witness register broadcast --- witness_action.js | 56 +++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 54 insertions(+), 2 deletions(-) diff --git a/witness_action.js b/witness_action.js index 1a584de..e3b2632 100644 --- a/witness_action.js +++ b/witness_action.js @@ -1,4 +1,5 @@ require('dotenv').config(); +const axios = require('axios'); const dhive = require('@hiveio/dhive'); const program = require('commander'); const packagejson = require('./package.json'); @@ -16,6 +17,53 @@ const { const extRPCNodePort = Number(String(process.env.RPCNODEPORT)) || rpcNodePort; const extP2PPort = Number(String(process.env.P2PPORT)) || p2pPort; +program + .option('-v, --verify', 'verify transaction on hive-engine', false) + .option('-e, --engineNode [url]', 'verify with given hive-engine node', 'https://api.hive-engine.com/rpc') + .parse(process.argv); + +let { engineNode } = program; +const { verify } = program; + +engineNode = engineNode.replace(/\/$/, ''); + +function awaitValidation(trxID, tries = 1) { + axios.post(`${engineNode}/blockchain`, { + jsonrpc: '2.0', id: 0, method: 'getTransactionInfo', params: { txid: trxID }, + }).then((res) => { + if (res.data.result) { + const parsedLogs = JSON.parse(res.data.result.logs); + if (parsedLogs.errors) { + // eslint-disable-next-line no-console + console.log(`Failed registration with reason "${parsedLogs.errors[0]}", your trx id: ${trxID}`); + } else { + // eslint-disable-next-line no-console + console.log(`Successfully registered, transaction id is ${trxID}`); + } + } else { + if (tries >= 4) { + // eslint-disable-next-line no-console + console.log(`Successful broadcast but could not verify, trx id: ${trxID}`); + return; + } + setTimeout(() => { + awaitValidation(trxID, tries + 1); + }, 4000); + } + }).catch((err) => { + // eslint-disable-next-line no-console + console.log(err); + if (tries >= 4) { + // eslint-disable-next-line no-console + console.log(`Successful broadcast but could not verify, trx id: ${trxID}`); + return; + } + setTimeout(() => { + awaitValidation(trxID, tries + 1); + }, 4000); + }); +} + function broadcastWitnessAction(contractAction, contractPayload) { const client = new dhive.Client(streamNodes[0]); const transaction = { @@ -30,8 +78,12 @@ function broadcastWitnessAction(contractAction, contractPayload) { }; client.broadcast.json(transaction, privateSigningKey).then((res) => { - // eslint-disable-next-line no-console - console.log(`Successful, trx id: ${res.id}`); + if (verify) { + awaitValidation(res.id); + } else { + // eslint-disable-next-line no-console + console.log(`Successful, trx id: ${res.id}`); + } }).catch((err) => { // eslint-disable-next-line no-console console.error('Error', err); From 3f256ac9773771338af4b309234a1539ff88cbfa Mon Sep 17 00:00:00 2001 From: Rishi Panthee Date: Sun, 24 Jul 2022 22:54:43 -0400 Subject: [PATCH 2/2] Fix grammer to be for both register and unregister --- witness_action.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/witness_action.js b/witness_action.js index e3b2632..4dbbcfa 100644 --- a/witness_action.js +++ b/witness_action.js @@ -35,10 +35,10 @@ function awaitValidation(trxID, tries = 1) { const parsedLogs = JSON.parse(res.data.result.logs); if (parsedLogs.errors) { // eslint-disable-next-line no-console - console.log(`Failed registration with reason "${parsedLogs.errors[0]}", your trx id: ${trxID}`); + console.log(`Failed action with reason "${parsedLogs.errors[0]}", your trx id: ${trxID}`); } else { // eslint-disable-next-line no-console - console.log(`Successfully registered, transaction id is ${trxID}`); + console.log(`Successfull, transaction id is ${trxID}`); } } else { if (tries >= 4) {