Browse Source

seed to wif api

v0.25
pbca26 7 years ago
parent
commit
92914b9ad2
  1. 2
      package.json
  2. 292
      routes/shepherd.js

2
package.json

@ -25,6 +25,7 @@
"bitcoinjs-lib": "^3.2.0", "bitcoinjs-lib": "^3.2.0",
"bluebird": "^3.4.7", "bluebird": "^3.4.7",
"body-parser": "^1.15.2", "body-parser": "^1.15.2",
"coinkey": "^2.0.0",
"electron": "1.6.5", "electron": "1.6.5",
"express": "^4.14.0", "express": "^4.14.0",
"fix-path": "^2.1.0", "fix-path": "^2.1.0",
@ -35,6 +36,7 @@
"ps-node": "^0.1.5", "ps-node": "^0.1.5",
"remote-file-size": "^3.0.3", "remote-file-size": "^3.0.3",
"request": "^2.80.0", "request": "^2.80.0",
"sha256": "^0.2.0",
"socket.io": "^1.7.3" "socket.io": "^1.7.3"
} }
} }

292
routes/shepherd.js

@ -20,8 +20,11 @@ const remoteFileSize = require('remote-file-size');
const Promise = require('bluebird'); const Promise = require('bluebird');
const {shell} = require('electron'); const {shell} = require('electron');
const {execFile} = require('child_process'); const {execFile} = require('child_process');
const sha256 = require('sha256');
const CoinKey = require('coinkey')
const bitcoinJS = require('bitcoinjs-lib');
const fixPath = require('fix-path'); const fixPath = require('fix-path');
var ps = require('ps-node'); var ps = require('ps-node');
var setconf = require('../private/setconf.js'); var setconf = require('../private/setconf.js');
var nativeCoind = require('./nativeCoind.js'); var nativeCoind = require('./nativeCoind.js');
@ -33,6 +36,7 @@ var guiLog = {};
var rpcConf = {}; var rpcConf = {};
var appRuntimeLog = []; var appRuntimeLog = [];
var lockDownAddCoin = false; var lockDownAddCoin = false;
var electrumCoins = {};
const electrumJSCore = require('./electrumjs/electrumjs.core.js'); const electrumJSCore = require('./electrumjs/electrumjs.core.js');
const electrumJSNetworks = require('./electrumjs/electrumjs.networks.js'); const electrumJSNetworks = require('./electrumjs/electrumjs.networks.js');
@ -48,83 +52,97 @@ const electrumServers = {
port: 50011, port: 50011,
proto: 'tcp', proto: 'tcp',
txfee: 10000, txfee: 10000,
abbr: 'KMD',
}, },
dogecoin: { // !estimatefee dogecoin: { // !estimatefee
address: '173.212.225.176', address: '173.212.225.176',
port: 50015, port: 50015,
proto: 'tcp', proto: 'tcp',
txfee: 100000000, txfee: 100000000,
abbr: 'DOGE',
}, },
viacoin: { // !estimatefee viacoin: { // !estimatefee
address: 'vialectrum.bitops.me', address: 'vialectrum.bitops.me',
port: 50002, port: 50002,
proto: 'ssl', proto: 'ssl',
txfee: 100000, txfee: 100000,
abbr: 'VIA',
}, },
vertcoin: { vertcoin: {
address: '173.212.225.176', address: '173.212.225.176',
port: 50088, port: 50088,
proto: 'tcp', proto: 'tcp',
txfee: 100000, txfee: 100000,
abbr: 'VTC',
}, },
namecoin: { namecoin: {
address: '173.212.225.176', address: '173.212.225.176',
port: 50036, port: 50036,
proto: 'tcp', proto: 'tcp',
txfee: 100000, txfee: 100000,
abbr: 'NMC',
}, },
monacoin: { // !estimatefee monacoin: { // !estimatefee
address: '173.212.225.176', address: '173.212.225.176',
port: 50002, port: 50002,
proto: 'tcp', proto: 'tcp',
txfee: 100000, txfee: 100000,
abbr: 'MONA',
}, },
litecoin: { litecoin: {
address: '173.212.225.176', address: '173.212.225.176',
port: 50012, port: 50012,
proto: 'tcp', proto: 'tcp',
txfee: 10000, txfee: 10000,
abbr: 'LTC',
}, },
faircoin: { faircoin: {
address: '173.212.225.176', address: '173.212.225.176',
port: 50005, port: 50005,
proto: 'tcp', proto: 'tcp',
txfee: 1000000, txfee: 1000000,
abbr: 'FAIR',
}, },
digibyte: { digibyte: {
address: '173.212.225.176', address: '173.212.225.176',
port: 50022, port: 50022,
proto: 'tcp', proto: 'tcp',
txfee: 100000, txfee: 100000,
abbr: 'DGB',
}, },
dash: { dash: {
address: '173.212.225.176', address: '173.212.225.176',
port: 50098, port: 50098,
proto: 'tcp', proto: 'tcp',
txfee: 10000, txfee: 10000,
abbr: 'DASH',
}, },
crown: { crown: {
address: '173.212.225.176', address: '173.212.225.176',
port: 50041, port: 50041,
proto: 'tcp', proto: 'tcp',
txfee: 10000, txfee: 10000,
abbr: 'CRW',
}, },
bitcoin: { bitcoin: {
address: '173.212.225.176', address: '173.212.225.176',
port: 50001, port: 50001,
proto: 'tcp', proto: 'tcp',
abbr: 'BTC',
}, },
argentum: { // !estimatefee argentum: { // !estimatefee
address: '173.212.225.176', address: '173.212.225.176',
port: 50081, port: 50081,
proto: 'tcp', proto: 'tcp',
txfee: 50000, txfee: 50000,
abbr: 'ARG',
}, },
chips: { // !estimatefee chips: { // !estimatefee
address: '173.212.225.176', address: '173.212.225.176',
port: 50076, port: 50076,
proto: 'tcp', proto: 'tcp',
txfee: 10000, txfee: 10000,
abbr: 'CHIPS',
}, },
}; };
@ -134,8 +152,6 @@ let blockchain = {
}, },
} }
const bitcoinJS = require('bitcoinjs-lib');
shepherd.appConfig = _appConfig.config; shepherd.appConfig = _appConfig.config;
if (os.platform() === 'darwin') { if (os.platform() === 'darwin') {
@ -197,6 +213,169 @@ shepherd.kmdMainPassiveMode = false;
shepherd.coindInstanceRegistry = coindInstanceRegistry; shepherd.coindInstanceRegistry = coindInstanceRegistry;
shepherd.seedToWif = function(seed, network, iguana) {
const bytes = sha256(seed, { asBytes: true });
if (iguana) {
bytes[0] &= 248;
bytes[31] &= 127;
bytes[31] |= 64;
}
function toHexString(byteArray) {
return Array.from(byteArray, function(byte) {
return ('0' + (byte & 0xFF).toString(16)).slice(-2);
}).join('');
}
const hex = toHexString(bytes);
const key = new CoinKey(new Buffer(hex, 'hex'), {
private: electrumJSNetworks[network].wif,
public: electrumJSNetworks[network].pubKeyHash,
});
key.compressed = true;
console.log('seedtowif priv key' + key.privateWif);
console.log('seedtowif pub key' + key.publicAddress);
return {
priv: key.privateWif,
pub: key.publicAddress,
};
}
shepherd.get('/electrum/seedtowif', function(req, res, next) {
const keys = shepherd.seedToWif(req.query.seed, req.query.network, req.query.iguana);
const successObj = {
msg: 'success',
result: {
keys,
},
};
res.end(JSON.stringify(successObj));
});
shepherd.get('/electrum/login', function(req, res, next) {
const keys = shepherd.seedToWif(req.query.seed, req.query.network, req.query.iguana);
electrumCoins[coin].priv = keys.priv;
electrumCoins[coin].pub = keys.pub;
const successObj = {
msg: 'success',
result: 'true'
};
res.end(JSON.stringify(successObj));
});
shepherd.get('/electrum/bip39/seed', function(req, res, next) {
// TODO
var bip39 = require('bip39'); // npm i -S bip39
var crypto = require('crypto');
// what you describe as 'seed'
var randomBytes = crypto.randomBytes(16); // 128 bits is enough
// your 12 word phrase
var mnemonic = bip39.entropyToMnemonic(randomBytes.toString('hex'));
// what is accurately described as the wallet seed
// var seed = bip39.mnemonicToSeed(mnemonic) // you'll use this in #3 below
var seed = bip39.mnemonicToSeed(req.query.seed);
console.log(seed);
const successObj = {
msg: 'success',
result: {
servers: electrumServers,
},
};
res.end(JSON.stringify(successObj));
console.log(bitcoinJS.networks.komodo);
var hdMaster = bitcoinJS.HDNode.fromSeedBuffer(seed, electrumJSNetworks.komodo); // seed from above
var key1 = hdMaster.derivePath('m/0');
var key2 = hdMaster.derivePath('m/1');
console.log(hdMaster);
console.log(key1.keyPair.toWIF());
console.log(key1.keyPair.getAddress());
console.log(key2.keyPair.toWIF());
var hdnode = bitcoinJS.HDNode.fromSeedBuffer(seed, electrumJSNetworks.komodo).deriveHardened(0).derive(0).derive(1);
console.log('Address: ' + hdnode.getAddress());
console.log('Private key (WIF): ' + hdnode.keyPair.toWIF());
});
shepherd.get('/electrum/servers', function(req, res, next) {
const successObj = {
msg: 'success',
result: {
servers: electrumServers,
},
};
res.end(JSON.stringify(successObj));
});
shepherd.addElectrumCoin = function(coin, serverID) {
for (let key in electrumServers) {
if (electrumServers[key].abbr === coin) {
electrumCoins[coin] = {
name: key,
abbr: coin,
server: {
ip: electrumServers[key].address,
port: electrumServers[key].port,
},
};
return true;
}
}
}
shepherd.removeElectrumCoin = function(coin, serverID) {
// TODO
}
shepherd.get('/electrum/coins/add', function(req, res, next) {
const result = shepherd.addElectrumCoin(req.query.coin);
const successObj = {
msg: 'success',
result,
};
res.end(JSON.stringify(successObj));
});
shepherd.get('/electrum/coins', function(req, res, next) {
let _electrumCoins = Object.assign({}, electrumCoins);
for (let key in electrumServers) {
if (_electrumCoins[key].wif) {
_electrumCoins[key].wif = null;
_electrumCoins[key].priv = null;
}
}
const successObj = {
msg: 'success',
result: _electrumCoins,
};
res.end(JSON.stringify(successObj));
});
shepherd.get('/electrum/getbalance', function(req, res, next) { shepherd.get('/electrum/getbalance', function(req, res, next) {
const ecl = new electrumJSCore(electrumServers[req.query.network].port, electrumServers[req.query.network].address, electrumServers[req.query.network].proto); // tcp or tls const ecl = new electrumJSCore(electrumServers[req.query.network].port, electrumServers[req.query.network].address, electrumServers[req.query.network].proto); // tcp or tls
@ -207,14 +386,14 @@ shepherd.get('/electrum/getbalance', function(req, res, next) {
console.log('electrum getbalance ==>'); console.log('electrum getbalance ==>');
console.log(0.00000001 * json.confirmed); console.log(0.00000001 * json.confirmed);
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
balance: 0.00000001 * json.confirmed, balance: 0.00000001 * json.confirmed,
}, },
}; };
res.end(JSON.stringify(successObj)); res.end(JSON.stringify(successObj));
}); });
}); });
@ -229,14 +408,14 @@ shepherd.get('/electrum/listtransactions', function(req, res, next) {
console.log('electrum listtransactions ==>'); console.log('electrum listtransactions ==>');
console.log(json); console.log(json);
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
listtransactions: json, listtransactions: json,
}, },
}; };
res.end(JSON.stringify(successObj)); res.end(JSON.stringify(successObj));
}); });
} else { } else {
// !expensive call! // !expensive call!
@ -288,8 +467,8 @@ shepherd.get('/electrum/listtransactions', function(req, res, next) {
console.log(_rawtx); console.log(_rawtx);
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
listtransactions: _rawtx, listtransactions: _rawtx,
}, },
}; };
@ -324,8 +503,8 @@ shepherd.get('/electrum/listtransactions', function(req, res, next) {
console.log(_rawtx); console.log(_rawtx);
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
listtransactions: _rawtx, listtransactions: _rawtx,
}, },
}; };
@ -355,8 +534,8 @@ shepherd.get('/electrum/gettransaction', function(req, res, next) {
console.log(json); console.log(json);
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
gettransaction: json, gettransaction: json,
}, },
}; };
@ -421,8 +600,8 @@ shepherd.get('/electrum/getblockinfo', function(req, res, next) {
shepherd.electrumGetBlockInfo(req.query.height, req.query.network) shepherd.electrumGetBlockInfo(req.query.height, req.query.network)
.then(function(json) { .then(function(json) {
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
getblockinfo: json, getblockinfo: json,
}, },
}; };
@ -451,8 +630,8 @@ shepherd.get('/electrum/getcurrentblock', function(req, res, next) {
shepherd.electrumGetCurrentBlock(req.query.network) shepherd.electrumGetCurrentBlock(req.query.network)
.then(function(json) { .then(function(json) {
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
getcurrentblock: json, getcurrentblock: json,
}, },
}; };
@ -486,7 +665,7 @@ shepherd.get('/electrum/formatlisttransactions', function(req, res, next) {
} }
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
result, result,
}; };
@ -502,8 +681,8 @@ shepherd.get('/electrum/decoderawtx', function(req, res, next) {
if (req.query.parseonly || if (req.query.parseonly ||
decodedTx.inputs[0].txid === '0000000000000000000000000000000000000000000000000000000000000000') { decodedTx.inputs[0].txid === '0000000000000000000000000000000000000000000000000000000000000000') {
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
decodedTx: { decodedTx: {
network: decodedTx.network, network: decodedTx.network,
format: decodedTx.format, format: decodedTx.format,
@ -527,8 +706,8 @@ shepherd.get('/electrum/decoderawtx', function(req, res, next) {
const decodedVin = electrumJSTxDecoder(json, _network); const decodedVin = electrumJSTxDecoder(json, _network);
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
decodedTx: { decodedTx: {
network: decodedTx.network, network: decodedTx.network,
format: decodedTx.format, format: decodedTx.format,
@ -589,8 +768,8 @@ shepherd.get('/electrum/txbuildtest', function(req, res, next) {
); );
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
rawtx: rawtx, rawtx: rawtx,
}, },
}; };
@ -642,8 +821,8 @@ shepherd.get('/electrum/subset', function(req, res, next) {
const _utxoSet = shepherd.findUtxoSet(null, Number(req.query.target) + Number(electrumServers[req.query.network].txfee)); // target + txfee const _utxoSet = shepherd.findUtxoSet(null, Number(req.query.target) + Number(electrumServers[req.query.network].txfee)); // target + txfee
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
utxoSet: _utxoSet.set, utxoSet: _utxoSet.set,
change: _utxoSet.change, change: _utxoSet.change,
}, },
@ -704,8 +883,8 @@ shepherd.get('/electrum/createrawtx', function(req, res, next) {
if (!push) { if (!push) {
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
utxoSet: _utxoSet.set, utxoSet: _utxoSet.set,
change: _utxoSet.change, change: _utxoSet.change,
wif, wif,
@ -727,8 +906,8 @@ shepherd.get('/electrum/createrawtx', function(req, res, next) {
ecl.close(); ecl.close();
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
utxoSet: _utxoSet.set, utxoSet: _utxoSet.set,
change: _utxoSet.change, change: _utxoSet.change,
wif, wif,
@ -790,8 +969,8 @@ shepherd.get('/electrum/pushtx', function(req, res, next) {
console.log(json); console.log(json);
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
txid: json, txid: json,
}, },
}; };
@ -810,8 +989,8 @@ shepherd.get('/electrum/listunspent', function(req, res, next) {
console.log('electrum listunspent ==>'); console.log('electrum listunspent ==>');
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
listunspent: json, listunspent: json,
}, },
}; };
@ -830,8 +1009,8 @@ shepherd.get('/electrum/estimatefee', function(req, res, next) {
console.log('electrum estimatefee ==>'); console.log('electrum estimatefee ==>');
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': { result: {
estimatefee: json, estimatefee: json,
}, },
}; };
@ -866,8 +1045,8 @@ shepherd.estimateFee = function(type) {
*/ */
shepherd.get('/coind/list', function(req, res, next) { shepherd.get('/coind/list', function(req, res, next) {
const successObj = { const successObj = {
'msg': 'success', msg: 'success',
'result': shepherd.nativeCoindList, result: shepherd.nativeCoindList,
}; };
res.end(JSON.stringify(successObj)); res.end(JSON.stringify(successObj));
@ -939,8 +1118,8 @@ shepherd.startKMDNative = function(selection, isManual) {
'Content-Type': 'application/json', 'Content-Type': 'application/json',
}, },
body: JSON.stringify({ body: JSON.stringify({
'herd': 'komodod', herd: 'komodod',
'options': herdData, options: herdData,
}) })
}; };
@ -989,8 +1168,8 @@ shepherd.startKMDNative = function(selection, isManual) {
'Content-Type': 'application/json', 'Content-Type': 'application/json',
}, },
body: JSON.stringify({ body: JSON.stringify({
'herd': 'komodod', herd: 'komodod',
'options': herdData[i], options: herdData[i],
}) })
}; };
@ -1075,7 +1254,8 @@ shepherd.post('/native/dashboard/update', function(req, res, next) {
}); });
})) }))
.then(result => { .then(result => {
if (result[0] && result[0].length) { if (result[0] &&
result[0].length) {
function calcBalance(result, json) { function calcBalance(result, json) {
if (json && if (json &&
json.length) { json.length) {
@ -2824,6 +3004,11 @@ shepherd.setVar = function(_name, _body) {
shepherd.get('/InstantDEX/allcoins', function(req, res, next) { shepherd.get('/InstantDEX/allcoins', function(req, res, next) {
let successObj; let successObj;
let nativeCoindList = []; let nativeCoindList = [];
let electrumCoinsList = [];
for (let key in electrumCoins) {
electrumCoinsList.push(electrumCoins[key].abbr);
}
for (let key in coindInstanceRegistry) { for (let key in coindInstanceRegistry) {
nativeCoindList.push(key === 'komodod' ? 'KMD' : key); nativeCoindList.push(key === 'komodod' ? 'KMD' : key);
@ -2831,6 +3016,7 @@ shepherd.get('/InstantDEX/allcoins', function(req, res, next) {
successObj = { successObj = {
native: nativeCoindList, native: nativeCoindList,
spv: electrumCoinsList,
}; };
res.end(JSON.stringify(successObj)); res.end(JSON.stringify(successObj));

Loading…
Cancel
Save