Browse Source

seed storage

custom-ac-example
pbca26 7 years ago
parent
commit
da961d736a
  1. 1
      main.js
  2. 59
      routes/shepherd/pin.js

1
main.js

@ -290,6 +290,7 @@ function createWindow(status, hideLoadingWindow) {
}; };
mainWindow.nnVoteChain = 'VOTE2018'; mainWindow.nnVoteChain = 'VOTE2018';
mainWindow.checkStringEntropy = shepherd.checkStringEntropy; mainWindow.checkStringEntropy = shepherd.checkStringEntropy;
mainWindow.pinAccess = false;
/*for (let i = 0; i < process.argv.length; i++) { /*for (let i = 0; i < process.argv.length; i++) {
if (process.argv[i].indexOf('nvote') > -1) { if (process.argv[i].indexOf('nvote') > -1) {

59
routes/shepherd/pin.js

@ -1,5 +1,9 @@
const fs = require('fs-extra'); const fs = require('fs-extra');
const aes256 = require('nodejs-aes256'); const aes256 = require('nodejs-aes256');
const passwdStrength = require('passwd-strength');
const bitcoin = require('bitcoinjs-lib');
const sha256 = require('js-sha256');
const bigi = require('bigi');
module.exports = (shepherd) => { module.exports = (shepherd) => {
/* /*
@ -9,36 +13,51 @@ module.exports = (shepherd) => {
shepherd.post('/encryptkey', (req, res, next) => { shepherd.post('/encryptkey', (req, res, next) => {
if (shepherd.checkToken(req.body.token)) { if (shepherd.checkToken(req.body.token)) {
if (req.body.key && if (req.body.key &&
req.body.string && req.body.string) {
req.body.pubkey) {
const encryptedString = aes256.encrypt(req.body.key, req.body.string);
// test pin security
// - at least 1 char in upper case
// - at least 1 digit
// - at least one special character
// - min length 8
const _pin = req.body.key; const _pin = req.body.key;
const _pinTest = _pin.match('^(?=.*[A-Z])(?=.*[^<>{}\"/|;:.,~!?@#$%^=&*\\]\\\\()\\[_+]*$)(?=.*[0-9])(?=.*[a-z]).{8}$'); const hash = sha256.create().update(req.body.string);
let bytes = hash.array();
bytes[0] &= 248;
bytes[31] &= 127;
bytes[31] |= 64;
const d = bigi.fromBuffer(bytes);
const keyPair = new bitcoin.ECPair(d, null, { network: shepherd.getNetworkData('btc') });
const keys = {
pub: keyPair.getAddress(),
priv: keyPair.toWIF(),
};
const pubkey = keyPair.getAddress();
fs.writeFile(`${shepherd.agamaDir}/shepherd/pin/${req.body.pubkey}.pin`, encryptedString, (err) => { if (passwdStrength(_pin) < 29) {
if (err) { shepherd.log('seed storage weak pin!');
shepherd.log('error writing pin file');
}
const returnObj = { const returnObj = {
msg: 'success', msg: 'error',
result: encryptedString, result: false,
}; };
res.end(JSON.stringify(returnObj)); res.end(JSON.stringify(returnObj));
}); } else {
const encryptedString = aes256.encrypt(req.body.key, req.body.string);
fs.writeFile(`${shepherd.agamaDir}/shepherd/pin/${pubkey}.pin`, encryptedString, (err) => {
if (err) {
shepherd.log('error writing pin file');
}
const returnObj = {
msg: 'success',
result: pubkey,
};
res.end(JSON.stringify(returnObj));
});
}
} else { } else {
const _paramsList = [ const _paramsList = [
'key', 'key',
'string', 'string'
'pubkey'
]; ];
let errorObj = { let errorObj = {
msg: 'error', msg: 'error',

Loading…
Cancel
Save