Skip to content

Commit

Permalink
exception handling
Browse files Browse the repository at this point in the history
  • Loading branch information
donchate committed Jul 30, 2021
1 parent 6bc2921 commit 981e8ee
Showing 1 changed file with 95 additions and 75 deletions.
170 changes: 95 additions & 75 deletions plugins/JsonRPCServer.js
Original file line number Diff line number Diff line change
Expand Up @@ -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) => {
Expand Down Expand Up @@ -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);
}
},
};
Expand Down

0 comments on commit 981e8ee

Please sign in to comment.