|
@ -95,10 +95,15 @@ if (os.platform() === 'win32') { |
|
|
|
|
|
|
|
|
shepherd.appConfigSchema = _appConfig.schema; |
|
|
shepherd.appConfigSchema = _appConfig.schema; |
|
|
shepherd.defaultAppConfig = Object.assign({}, shepherd.appConfig); |
|
|
shepherd.defaultAppConfig = Object.assign({}, shepherd.appConfig); |
|
|
|
|
|
shepherd.kmdMainPassiveMode = false; |
|
|
|
|
|
|
|
|
shepherd.coindInstanceRegistry = coindInstanceRegistry; |
|
|
shepherd.coindInstanceRegistry = coindInstanceRegistry; |
|
|
|
|
|
|
|
|
shepherd.startKMDNative = function(selection, isManual) { |
|
|
shepherd.startKMDNative = function(selection, isManual) { |
|
|
|
|
|
if (isManual) { |
|
|
|
|
|
shepherd.kmdMainPassiveMode = true; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
if (selection === 'KMD') { |
|
|
if (selection === 'KMD') { |
|
|
const herdData = { |
|
|
const herdData = { |
|
|
'ac_name': 'komodod', |
|
|
'ac_name': 'komodod', |
|
@ -220,7 +225,12 @@ shepherd.post('/native/dashboard/update', function(req, res, next) { |
|
|
_type === 'public' ? 'getaddressesbyaccount' : 'z_listaddresses', |
|
|
_type === 'public' ? 'getaddressesbyaccount' : 'z_listaddresses', |
|
|
[''] |
|
|
[''] |
|
|
).then(function(_json) { |
|
|
).then(function(_json) { |
|
|
|
|
|
if (_json === 'Work queue depth exceeded' || |
|
|
|
|
|
!_json) { |
|
|
|
|
|
resolve({ error: 'daemon is busy' }); |
|
|
|
|
|
} else { |
|
|
resolve(JSON.parse(_json).result); |
|
|
resolve(JSON.parse(_json).result); |
|
|
|
|
|
} |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
})) |
|
|
})) |
|
@ -340,12 +350,22 @@ shepherd.post('/native/dashboard/update', function(req, res, next) { |
|
|
|
|
|
|
|
|
_bitcoinRPC(coin, 'listunspent') |
|
|
_bitcoinRPC(coin, 'listunspent') |
|
|
.then(function(__json) { |
|
|
.then(function(__json) { |
|
|
|
|
|
if (__json === 'Work queue depth exceeded' || |
|
|
|
|
|
!__json) { |
|
|
|
|
|
const returnObj = { |
|
|
|
|
|
msg: 'success', |
|
|
|
|
|
result: _returnObj, |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
res.end(JSON.stringify(returnObj)); |
|
|
|
|
|
} else { |
|
|
_returnObj.listunspent = JSON.parse(__json); |
|
|
_returnObj.listunspent = JSON.parse(__json); |
|
|
|
|
|
|
|
|
calcBalance( |
|
|
calcBalance( |
|
|
result, |
|
|
result, |
|
|
JSON.parse(__json).result |
|
|
JSON.parse(__json).result |
|
|
); |
|
|
); |
|
|
|
|
|
} |
|
|
}); |
|
|
}); |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
@ -375,7 +395,8 @@ shepherd.post('/native/dashboard/update', function(req, res, next) { |
|
|
headers: { |
|
|
headers: { |
|
|
'Content-Type': 'application/json', |
|
|
'Content-Type': 'application/json', |
|
|
}, |
|
|
}, |
|
|
body: JSON.stringify({ payload: _payload }) |
|
|
body: JSON.stringify({ payload: _payload }), |
|
|
|
|
|
timeout: 5000, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
request(options, function(error, response, body) { |
|
|
request(options, function(error, response, body) { |
|
@ -391,13 +412,27 @@ shepherd.post('/native/dashboard/update', function(req, res, next) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Promise.all(_promiseStack.map((_call, index) => { |
|
|
Promise.all(_promiseStack.map((_call, index) => { |
|
|
|
|
|
let _params; |
|
|
|
|
|
if (_call === 'listtransactions') { |
|
|
|
|
|
_params = [ |
|
|
|
|
|
'', |
|
|
|
|
|
300, |
|
|
|
|
|
0 |
|
|
|
|
|
]; |
|
|
|
|
|
} |
|
|
return new Promise((resolve, reject) => { |
|
|
return new Promise((resolve, reject) => { |
|
|
_bitcoinRPC( |
|
|
_bitcoinRPC( |
|
|
_coin, |
|
|
_coin, |
|
|
_call |
|
|
_call, |
|
|
|
|
|
_params |
|
|
) |
|
|
) |
|
|
.then(function(json) { |
|
|
.then(function(json) { |
|
|
|
|
|
if (json === 'Work queue depth exceeded' || |
|
|
|
|
|
!json) { |
|
|
|
|
|
_returnObj[_call] = { error: 'daemon is busy' }; |
|
|
|
|
|
} else { |
|
|
_returnObj[_call] = JSON.parse(json); |
|
|
_returnObj[_call] = JSON.parse(json); |
|
|
|
|
|
} |
|
|
resolve(json); |
|
|
resolve(json); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|