aboutsummaryrefslogtreecommitdiffstats
path: root/packages/testnet-faucets/src/ts/id_management.ts
diff options
context:
space:
mode:
authorBrandon Millman <brandon.millman@gmail.com>2018-01-27 01:40:42 +0800
committerBrandon Millman <brandon.millman@gmail.com>2018-01-31 03:36:39 +0800
commit44162811bd57afb89e5d052a2d9db25007cc1463 (patch)
tree44a02e5ec79a097ce2105eef04ab6accddd5d1f4 /packages/testnet-faucets/src/ts/id_management.ts
parent2bcb7d56394c43acd68d1823092de2ad047abc6d (diff)
downloaddexon-sol-tools-44162811bd57afb89e5d052a2d9db25007cc1463.tar
dexon-sol-tools-44162811bd57afb89e5d052a2d9db25007cc1463.tar.gz
dexon-sol-tools-44162811bd57afb89e5d052a2d9db25007cc1463.tar.bz2
dexon-sol-tools-44162811bd57afb89e5d052a2d9db25007cc1463.tar.lz
dexon-sol-tools-44162811bd57afb89e5d052a2d9db25007cc1463.tar.xz
dexon-sol-tools-44162811bd57afb89e5d052a2d9db25007cc1463.tar.zst
dexon-sol-tools-44162811bd57afb89e5d052a2d9db25007cc1463.zip
Add order signing and dispensing ability to faucet
Diffstat (limited to 'packages/testnet-faucets/src/ts/id_management.ts')
-rw-r--r--packages/testnet-faucets/src/ts/id_management.ts16
1 files changed, 15 insertions, 1 deletions
diff --git a/packages/testnet-faucets/src/ts/id_management.ts b/packages/testnet-faucets/src/ts/id_management.ts
index db9b610a3..b088e6cf8 100644
--- a/packages/testnet-faucets/src/ts/id_management.ts
+++ b/packages/testnet-faucets/src/ts/id_management.ts
@@ -1,8 +1,10 @@
import EthereumTx = require('ethereumjs-tx');
+import * as ethUtil from 'ethereumjs-util';
+import * as _ from 'lodash';
import { configs } from './configs';
-type Callback = (err: Error | null, accounts: any) => void;
+type Callback = (err: Error | null, result: any) => void;
export const idManagement = {
getAccounts(callback: Callback) {
@@ -18,4 +20,16 @@ export const idManagement = {
const rawTx = `0x${tx.serialize().toString('hex')}`;
callback(null, rawTx);
},
+ signMessage(message: object, callback: Callback) {
+ const data = _.get(message, 'data');
+ if (_.isUndefined(data)) {
+ callback(new Error('No data to sign'), null);
+ }
+ const privateKeyBuffer = new Buffer(configs.DISPENSER_PRIVATE_KEY as string, 'hex');
+ const dataBuff = ethUtil.toBuffer(data);
+ const msgHashBuff = ethUtil.hashPersonalMessage(dataBuff);
+ const sig = ethUtil.ecsign(msgHashBuff, privateKeyBuffer);
+ const rpcSig = ethUtil.toRpcSig(sig.v, sig.r, sig.s);
+ callback(null, rpcSig);
+ },
};