From 981e8ee718739d9bfc32e57521307b8174547604 Mon Sep 17 00:00:00 2001 From: donchate Date: Fri, 30 Jul 2021 16:18:43 +0000 Subject: [PATCH 1/2] exception handling --- plugins/JsonRPCServer.js | 170 ++++++++++++++++++++++----------------- 1 file changed, 95 insertions(+), 75 deletions(-) diff --git a/plugins/JsonRPCServer.js b/plugins/JsonRPCServer.js index 2559b808..3a829101 100644 --- a/plugins/JsonRPCServer.js +++ b/plugins/JsonRPCServer.js @@ -29,29 +29,37 @@ function blockchainRPC() { } }, getBlockInfo: async (args, callback) => { - const { blockNumber } = args; - - if (Number.isInteger(blockNumber)) { - const block = await database.getBlockInfo(blockNumber); - callback(null, block); - } else { - callback({ - code: 400, - message: 'missing or wrong parameters: blockNumber is required', - }, null); + try { + const { blockNumber } = args; + + if (Number.isInteger(blockNumber)) { + const block = await database.getBlockInfo(blockNumber); + callback(null, block); + } else { + callback({ + code: 400, + message: 'missing or wrong parameters: blockNumber is required', + }, null); + } + } catch (error) { + callback(error, null); } }, getTransactionInfo: async (args, callback) => { - const { txid } = args; - - if (txid && typeof txid === 'string') { - const transaction = await database.getTransactionInfo(txid); - callback(null, transaction); - } else { - callback({ - code: 400, - message: 'missing or wrong parameters: txid is required', - }, null); + try { + const { txid } = args; + + if (txid && typeof txid === 'string') { + const transaction = await database.getTransactionInfo(txid); + callback(null, transaction); + } else { + callback({ + code: 400, + message: 'missing or wrong parameters: txid is required', + }, null); + } + } catch (error) { + callback(error, null); } }, getStatus: async (args, callback) => { @@ -88,72 +96,84 @@ function blockchainRPC() { function contractsRPC() { return { getContract: async (args, callback) => { - const { name } = args; - - if (name && typeof name === 'string') { - const contract = await database.findContract({ name }); - callback(null, contract); - } else { - callback({ - code: 400, - message: 'missing or wrong parameters: contract is required', - }, null); + try { + const { name } = args; + + if (name && typeof name === 'string') { + const contract = await database.findContract({ name }); + callback(null, contract); + } else { + callback({ + code: 400, + message: 'missing or wrong parameters: contract is required', + }, null); + } + } catch (error) { + callback(error, null); } }, findOne: async (args, callback) => { - const { contract, table, query } = args; - - if (contract && typeof contract === 'string' - && table && typeof table === 'string' - && query && typeof query === 'object') { - const result = await database.findOne({ - contract, - table, - query, - }); - - callback(null, result); - } else { - callback({ - code: 400, - message: 'missing or wrong parameters: contract and tableName are required', - }, null); + try { + const { contract, table, query } = args; + + if (contract && typeof contract === 'string' + && table && typeof table === 'string' + && query && typeof query === 'object') { + const result = await database.findOne({ + contract, + table, + query, + }); + + callback(null, result); + } else { + callback({ + code: 400, + message: 'missing or wrong parameters: contract and tableName are required', + }, null); + } + } catch (error) { + callback(error, null); } }, find: async (args, callback) => { - const { - contract, - table, - query, - limit, - offset, - indexes, - } = args; - - if (contract && typeof contract === 'string' - && table && typeof table === 'string' - && query && typeof query === 'object') { - const lim = limit || 1000; - const off = offset || 0; - const ind = indexes || []; - - const result = await database.find({ + try { + const { contract, table, query, - limit: lim, - offset: off, - indexes: ind, - }); - - callback(null, result); - } else { - callback({ - code: 400, - message: 'missing or wrong parameters: contract and tableName are required', - }, null); + limit, + offset, + indexes, + } = args; + + if (contract && typeof contract === 'string' + && table && typeof table === 'string' + && query && typeof query === 'object') { + const lim = limit || 1000; + const off = offset || 0; + const ind = indexes || []; + + const result = await database.find({ + contract, + table, + query, + limit: lim, + offset: off, + indexes: ind, + }); + + callback(null, result); + } else { + callback({ + code: 400, + message: 'missing or wrong parameters: contract and tableName are required', + }, null); + } + } catch (error) { + callback(error, null); } }, }; From 42e7b990a00fd72bc96b0e10fccc6a4333921dfa Mon Sep 17 00:00:00 2001 From: donchate Date: Mon, 2 Aug 2021 06:35:14 +0000 Subject: [PATCH 2/2] also catch for P2P RPC --- plugins/P2P.js | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/plugins/P2P.js b/plugins/P2P.js index f66f0689..c0c3add7 100644 --- a/plugins/P2P.js +++ b/plugins/P2P.js @@ -444,7 +444,13 @@ const proposeRoundHandler = async (args, callback) => { function p2p() { return { - proposeRoundHash: (args, callback) => proposeRoundHandler(args, callback), + proposeRoundHash: (args, callback) => { + try { + proposeRoundHandler(args, callback); + } catch (error) { + callback(error, null); + } + }, }; }