From 6855aefb9f8fbaec08c994cebb6c49320361772b Mon Sep 17 00:00:00 2001 From: pbca26 Date: Thu, 14 Dec 2017 18:59:13 +0300 Subject: [PATCH 1/4] spv uncompressed wif --- routes/shepherd/electrum/auth.js | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/routes/shepherd/electrum/auth.js b/routes/shepherd/electrum/auth.js index 4f763cd..9351529 100644 --- a/routes/shepherd/electrum/auth.js +++ b/routes/shepherd/electrum/auth.js @@ -2,18 +2,19 @@ module.exports = (shepherd) => { shepherd.post('/electrum/login', (req, res, next) => { for (let key in shepherd.electrumServers) { const _abbr = shepherd.electrumServers[key].abbr; + const _seed = req.body.seed; let keys; - if (req.body.seed.length === 52 && - req.body.seed.indexOf(' ') === -1 && - req.body.seed.match(/^[a-zA-Z0-9]*$/)) { - let key = shepherd.bitcoinJS.ECPair.fromWIF(req.body.seed, shepherd.electrumJSNetworks.komodo); + if ((_seed.length === 51 || _seed.length === 52) && + _seed.indexOf(' ') === -1 && + _seed.match(/^[a-zA-Z0-9]*$/)) { + let key = shepherd.bitcoinJS.ECPair.fromWIF(_seed, shepherd.electrumJSNetworks.komodo); keys = { priv: key.toWIF(), pub: key.getAddress(), }; } else { - keys = shepherd.seedToWif(req.body.seed, shepherd.findNetworkObj(_abbr), req.body.iguana, req.body.old); + keys = shepherd.seedToWif(_seed, shepherd.findNetworkObj(_abbr), req.body.iguana); } shepherd.electrumKeys[_abbr] = { From d33f0cd2c08aa50538dd4a6b61ba19353d6edf17 Mon Sep 17 00:00:00 2001 From: pbca26 Date: Thu, 14 Dec 2017 22:28:05 +0300 Subject: [PATCH 2/4] minor cleanup --- main.js | 4 +- routes/ports.js | 1 + routes/shepherd.js | 4 + routes/shepherd/daemonControl.js | 9 ++ routes/shepherd/explorer/overview.js | 130 ++++++++++++++++++++ routes/shepherd/explorer/remoteExplorers.js | 21 ++++ routes/shepherd/pin.js | 17 +-- routes/shepherd/rpc.js | 11 +- 8 files changed, 184 insertions(+), 13 deletions(-) create mode 100644 routes/shepherd/explorer/overview.js create mode 100644 routes/shepherd/explorer/remoteExplorers.js diff --git a/main.js b/main.js index 8ed979e..b15f04a 100644 --- a/main.js +++ b/main.js @@ -146,6 +146,7 @@ guiapp.use('/shepherd', shepherd); const server = require('http').createServer(guiapp); const io = require('socket.io').listen(server); +const _zcashParamsExist = shepherd.zcashParamsExist(); let willQuitApp = false; let mainWindow; let loadingWindow; @@ -153,7 +154,6 @@ let appCloseWindow; let appSettingsWindow; let closeAppAfterLoading = false; let forceQuitApp = false; -const _zcashParamsExist = shepherd.zcashParamsExist(); module.exports = guiapp; let agamaIcon; @@ -278,7 +278,7 @@ if (process.argv.indexOf('dexonly') > -1) { app.on('ready', createLoadingWindow); setTimeout(() => { createWindow('open', true); - }, 100); + }, 500); } else { app.on('ready', createLoadingWindow); } diff --git a/routes/ports.js b/routes/ports.js index 05526fc..2fce5ca 100644 --- a/routes/ports.js +++ b/routes/ports.js @@ -1,5 +1,6 @@ const assetChainPorts = { 'komodod': '7771', + 'markermaker': '7783', 'CHIPS': '57776', 'SUPERNET': '11341', 'REVS': '10196', diff --git a/routes/shepherd.js b/routes/shepherd.js index e192537..ee070b7 100644 --- a/routes/shepherd.js +++ b/routes/shepherd.js @@ -28,6 +28,7 @@ shepherd.setconf = require('../private/setconf.js'); shepherd.nativeCoind = require('./nativeCoind.js'); shepherd.nativeCoindList = {}; shepherd.assetChainPorts = require('./ports.js'); +shepherd.assetChainPortsDefault = require('./ports.js'); shepherd._appConfig = require('./appConfig.js'); shepherd.coindInstanceRegistry = {}; @@ -128,6 +129,9 @@ shepherd = require('./shepherd/auth.js')(shepherd); shepherd = require('./shepherd/coins.js')(shepherd); shepherd = require('./shepherd/coindWalletKeys.js')(shepherd); +// explorer +// shepherd = require('./shepherd/explorer/overview.js')(shepherd); + shepherd.printDirs(); // default route diff --git a/routes/shepherd/daemonControl.js b/routes/shepherd/daemonControl.js index ecefa36..32f0c91 100644 --- a/routes/shepherd/daemonControl.js +++ b/routes/shepherd/daemonControl.js @@ -99,14 +99,23 @@ module.exports = (shepherd) => { if (_coindCustomPort[1]) { shepherd.assetChainPorts[data.ac_name] = _coindCustomPort[1]; + shepherd.rpcConf[data.ac_name === 'komodod' ? 'KMD' : data.ac_name].port = _coindCustomPort[1]; shepherd.log(`${data.ac_name} custom port ${_coindCustomPort[1]}`); } else { + shepherd.assetChainPorts[data.ac_name] = shepherd.assetChainPortsDefault[data.ac_name]; + shepherd.rpcConf[data.ac_name === 'komodod' ? 'KMD' : data.ac_name].port = shepherd.assetChainPortsDefault[data.ac_name]; shepherd.log(`${data.ac_name} port ${shepherd.assetChainPorts[data.ac_name]}`); } } else { + shepherd.assetChainPorts[data.ac_name] = shepherd.assetChainPortsDefault[data.ac_name]; + shepherd.rpcConf[data.ac_name === 'komodod' ? 'KMD' : data.ac_name].port = shepherd.assetChainPortsDefault[data.ac_name]; shepherd.log(`${data.ac_name} port ${shepherd.assetChainPorts[data.ac_name]}`); } } catch (e) { + if (shepherd.rpcConf[data.ac_name === 'komodod' ? 'KMD' : data.ac_name]) { + shepherd.rpcConf[data.ac_name === 'komodod' ? 'KMD' : data.ac_name].port = shepherd.assetChainPortsDefault[data.ac_name]; + } + shepherd.assetChainPorts[data.ac_name] = shepherd.assetChainPortsDefault[data.ac_name]; shepherd.log(`${data.ac_name} port ${shepherd.assetChainPorts[data.ac_name]}`); } diff --git a/routes/shepherd/explorer/overview.js b/routes/shepherd/explorer/overview.js new file mode 100644 index 0000000..ca67cf8 --- /dev/null +++ b/routes/shepherd/explorer/overview.js @@ -0,0 +1,130 @@ +const remoteExplorers = require('./remoteExplorers'); +const request = require('request'); +const fs = require('fs-extra'); +const path = require('path'); + +let remoteExplorersArray = []; + +for (let key in remoteExplorers) { + remoteExplorersArray.push(key); +} + +const sortByDate = (data, sortKey) => { + return data.sort(function(b, a) { + if (a[sortKey] < b[sortKey]) { + return -1; + } + + if (a[sortKey] > b[sortKey]) { + return 1; + } + + return 0; + }); +} + +module.exports = (shepherd) => { + shepherd.get('/explorer/overview', (req, res, next) => { + if (req.query.coin) { + const options = { + url: `${remoteExplorers[req.query.coin]}/ext/getlasttxs/0.00000001`, + method: 'GET', + }; + + request(options, (error, response, body) => { + const _parsedBody = JSON.parse(body); + + if (response && + response.statusCode && + response.statusCode === 200) { + res.end(body); + } else { + res.end(body ? body : JSON.stringify({ + result: 'error', + error: { + code: -777, + message: `unable to retrieve remote data from remoteExplorers[req.query.coin]`, + }, + })); + } + }); + } else { + Promise.all(remoteExplorersArray.map((coin, index) => { + shepherd.log(`explorer ${coin} overview`); + + return new Promise((resolve, reject) => { + const options = { + url: `${remoteExplorers[coin]}/ext/getlasttxs/0.00000001`, + method: 'GET', + }; + + request(options, (error, response, body) => { + if (response && + response.statusCode && + response.statusCode === 200) { + resolve({ + coin, + result: body, + }); + } else { + resolve({ + coin, + result: 'unable to get lasttx' + }); + } + }); + }); + })) + .then(result => { + const returnObj = { + msg: 'success', + result, + }; + + res.end(JSON.stringify(returnObj)); + + /*if (result && + result.length) { + } else { + const returnObj = { + msg: 'success', + result: _returnObj, + }; + + res.end(JSON.stringify(returnObj)); + }*/ + }); + } + }); + + shepherd.get('/explorer/overview/test', (req, res, next) => { + const testFileLocation = path.join(__dirname, '../explorer/test.json'); + const testFile = fs.readJsonSync(testFileLocation, { throws: false }); + const resSizeLimit = 1000; + let items = []; + + for (let i = 0; i < testFile.result.length; i++) { + const _parseData = JSON.parse(testFile.result[i].result).data; + + for (let j = 0; j < _parseData.length; j++) { + items.push({ + coin: testFile.result[i].coin, + txid: _parseData[j].txid, + blockhash: _parseData[j].blockhash, + blockindex: _parseData[j].blockindex, + timestamp: _parseData[j].timestamp, + total: _parseData[j].total, + vout: _parseData[j].vout, + vin: _parseData[j].vin, + }); + } + } + + items = sortByDate(items, 'timestamp'); + items = items.slice(0, resSizeLimit + 1); + + res.end(JSON.stringify(items)); + }); + + return shepherd; +}; \ No newline at end of file diff --git a/routes/shepherd/explorer/remoteExplorers.js b/routes/shepherd/explorer/remoteExplorers.js new file mode 100644 index 0000000..a7fee6d --- /dev/null +++ b/routes/shepherd/explorer/remoteExplorers.js @@ -0,0 +1,21 @@ +const remoteExplorers = { + KMD: 'http://kmd.komodochainz.info', + MSHARK: 'http://MSHARK.explorer.supernet.org', + REVS: 'http://revs.explorer.supernet.org', + SUPERNET: 'http://SUPERNET.explorer.supernet.org', + DEX: 'http://DEX.explorer.supernet.org', + PANGEA: 'http://PANGEA.explorer.supernet.org', + JUMBLR: 'http://JUMBLR.explorer.supernet.org', + BET: 'http://BET.explorer.supernet.org', + CRYPTO: 'http://CRYPTO.explorer.supernet.org', + HODL: 'http://HODL.explorer.supernet.org', + SHARK: 'http://SHARK.explorer.supernet.org', + BOTS: 'http://BOTS.explorer.supernet.org', + MGW: 'http://MGW.explorer.supernet.org', + WLC: 'http://WIRELESS.explorer.supernet.org', + CHIPS: 'http://CHIPS1.explorer.supernet.org', + COQUI: 'https://explorer.coqui.cash', + MNZ: 'https://www.mnzexplorer.com', +}; + +module.exports = remoteExplorers; \ No newline at end of file diff --git a/routes/shepherd/pin.js b/routes/shepherd/pin.js index 20a47c7..6776b6c 100644 --- a/routes/shepherd/pin.js +++ b/routes/shepherd/pin.js @@ -1,3 +1,6 @@ +const fs = require('fs-extra'); +const aes256 = require('nodejs-aes256'); + module.exports = (shepherd) => { /* * type: POST @@ -7,7 +10,7 @@ module.exports = (shepherd) => { if (req.body.key && req.body.string && req.body.pubkey) { - const encryptedString = shepherd.aes256.encrypt(req.body.key, req.body.string); + const encryptedString = aes256.encrypt(req.body.key, req.body.string); // test pin security // - at least 1 char in upper case @@ -18,7 +21,7 @@ module.exports = (shepherd) => { const _pin = req.body.key; const _pinTest = _pin.match('^(?=.*[A-Z])(?=.*[^<>{}\"/|;:.,~!?@#$%^=&*\\]\\\\()\\[_+]*$)(?=.*[0-9])(?=.*[a-z]).{8}$'); - shepherd.fs.writeFile(`${shepherd.agamaDir}/shepherd/pin/${req.body.pubkey}.pin`, encryptedString, (err) => { + fs.writeFile(`${shepherd.agamaDir}/shepherd/pin/${req.body.pubkey}.pin`, encryptedString, (err) => { if (err) { shepherd.log('error writing pin file'); } @@ -56,8 +59,8 @@ module.exports = (shepherd) => { shepherd.post('/decryptkey', (req, res, next) => { if (req.body.key && req.body.pubkey) { - if (shepherd.fs.existsSync(`${shepherd.agamaDir}/shepherd/pin/${req.body.pubkey}.pin`)) { - shepherd.fs.readFile(`${shepherd.agamaDir}/shepherd/pin/${req.body.pubkey}.pin`, 'utf8', (err, data) => { + if (fs.existsSync(`${shepherd.agamaDir}/shepherd/pin/${req.body.pubkey}.pin`)) { + fs.readFile(`${shepherd.agamaDir}/shepherd/pin/${req.body.pubkey}.pin`, 'utf8', (err, data) => { if (err) { const errorObj = { msg: 'error', @@ -66,7 +69,7 @@ module.exports = (shepherd) => { res.end(JSON.stringify(errorObj)); } else { - const encryptedKey = shepherd.aes256.decrypt(req.body.key, data); + const encryptedKey = aes256.decrypt(req.body.key, data); // test if stored encrypted passphrase is decrypted correctly // if not then the key is wrong const _regexTest = encryptedKey.match(/^[0-9a-zA-Z ]+$/g); @@ -106,8 +109,8 @@ module.exports = (shepherd) => { }); shepherd.get('/getpinlist', (req, res, next) => { - if (shepherd.fs.existsSync(`${shepherd.agamaDir}/shepherd/pin`)) { - shepherd.fs.readdir(`${shepherd.agamaDir}/shepherd/pin`, (err, items) => { + if (fs.existsSync(`${shepherd.agamaDir}/shepherd/pin`)) { + fs.readdir(`${shepherd.agamaDir}/shepherd/pin`, (err, items) => { let _pins = []; for (let i = 0; i < items.length; i++) { diff --git a/routes/shepherd/rpc.js b/routes/shepherd/rpc.js index 40d55e4..5a89a45 100644 --- a/routes/shepherd/rpc.js +++ b/routes/shepherd/rpc.js @@ -1,3 +1,6 @@ +const fs = require('fs-extra'); +const os = require('os'); + module.exports = (shepherd) => { shepherd.getConf = (chain) => { let _confLocation = chain === 'komodod' ? `${shepherd.komodoDir}/komodo.conf` : `${shepherd.komodoDir}/${chain}/${chain}.conf`; @@ -6,15 +9,15 @@ module.exports = (shepherd) => { // any coind if (chain) { if (shepherd.nativeCoindList[chain.toLowerCase()]) { - const _osHome = shepherd.os.platform === 'win32' ? process.env.APPDATA : process.env.HOME; + const _osHome = os.platform === 'win32' ? process.env.APPDATA : process.env.HOME; let coindDebugLogLocation = `${_osHome}/.${shepherd.nativeCoindList[chain.toLowerCase()].bin.toLowerCase()}/debug.log`; _confLocation = `${_osHome}/.${shepherd.nativeCoindList[chain.toLowerCase()].bin.toLowerCase()}/${shepherd.nativeCoindList[chain.toLowerCase()].bin.toLowerCase()}.conf`; } - if (shepherd.fs.existsSync(_confLocation)) { + if (fs.existsSync(_confLocation)) { let _port = shepherd.assetChainPorts[chain]; - const _rpcConf = shepherd.fs.readFileSync(_confLocation, 'utf8'); + const _rpcConf = fs.readFileSync(_confLocation, 'utf8'); // any coind if (shepherd.nativeCoindList[chain.toLowerCase()]) { @@ -85,7 +88,7 @@ module.exports = (shepherd) => { if (_cmd === 'debug' && _chain !== 'CHIPS') { if (shepherd.nativeCoindList[_chain.toLowerCase()]) { - const _osHome = shepherd.os.platform === 'win32' ? process.env.APPDATA : process.env.HOME; + const _osHome = os.platform === 'win32' ? process.env.APPDATA : process.env.HOME; let coindDebugLogLocation; if (_chain === 'CHIPS') { From 26c826cda4edb6cd40a1560a177187cd75a67d03 Mon Sep 17 00:00:00 2001 From: pbca26 Date: Thu, 14 Dec 2017 23:30:50 +0300 Subject: [PATCH 3/4] version bump --- version | 2 +- version_build | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/version b/version index 3e5329e..97d8e39 100644 --- a/version +++ b/version @@ -1,3 +1,3 @@ -version=0.2.0.25d +version=0.2.0.25e type=e-beta minversion=0.2.0.2 \ No newline at end of file diff --git a/version_build b/version_build index 53bb56e..857b972 100644 --- a/version_build +++ b/version_build @@ -1 +1 @@ -0.2.0.25d-beta \ No newline at end of file +0.2.0.25e-beta \ No newline at end of file From 3a542f3dd12cde8df21b80d8c14b05507b91e8c7 Mon Sep 17 00:00:00 2001 From: pbca26 Date: Fri, 15 Dec 2017 16:43:40 +0300 Subject: [PATCH 4/4] missing bip39 module in package.json --- package.json | 1 + routes/shepherd/explorer/overview.js | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/package.json b/package.json index d48ff2c..017b863 100644 --- a/package.json +++ b/package.json @@ -28,6 +28,7 @@ "dependencies": { "adm-zip": "^0.4.7", "arch": "^2.1.0", + "bip39": "^2.4.0", "bitcoinjs-lib": "^3.2.0", "bluebird": "^3.4.7", "body-parser": "^1.15.2", diff --git a/routes/shepherd/explorer/overview.js b/routes/shepherd/explorer/overview.js index ca67cf8..5b514ea 100644 --- a/routes/shepherd/explorer/overview.js +++ b/routes/shepherd/explorer/overview.js @@ -69,7 +69,7 @@ module.exports = (shepherd) => { } else { resolve({ coin, - result: 'unable to get lasttx' + result: 'unable to get lasttx', }); } });