get cartridge counts from db
This commit is contained in:
parent
238d4bd879
commit
209272eb26
4 changed files with 63 additions and 16 deletions
|
|
@ -1,7 +1,4 @@
|
||||||
{
|
{
|
||||||
"cartridges": [
|
"cartridges": [1, 20],
|
||||||
{"denomination": 1, "count": 100},
|
|
||||||
{"denomination": 20, "count": 100}
|
|
||||||
],
|
|
||||||
"virtualCartridges": [5]
|
"virtualCartridges": [5]
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,7 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
var fs = require('fs');
|
||||||
|
|
||||||
var _ = require('lodash');
|
var _ = require('lodash');
|
||||||
var async = require('async');
|
var async = require('async');
|
||||||
var logger = require('./logger');
|
var logger = require('./logger');
|
||||||
|
|
@ -35,6 +37,13 @@ var reapTxInterval = null;
|
||||||
|
|
||||||
var tradesQueue = [];
|
var tradesQueue = [];
|
||||||
|
|
||||||
|
var cartridges = null;
|
||||||
|
try {
|
||||||
|
cartridges = JSON.parse(fs.readFileSync('./cartridges.json'));
|
||||||
|
} catch (ex) {
|
||||||
|
logger.warn('No cartridges.json file found: ' + ex.message);
|
||||||
|
}
|
||||||
|
|
||||||
// that's basically a constructor
|
// that's basically a constructor
|
||||||
exports.init = function init(databaseHandle) {
|
exports.init = function init(databaseHandle) {
|
||||||
if (!databaseHandle) {
|
if (!databaseHandle) {
|
||||||
|
|
@ -187,6 +196,36 @@ exports.logEvent = function event(session, rawEvent) {
|
||||||
db.recordDeviceEvent(session, rawEvent);
|
db.recordDeviceEvent(session, rawEvent);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
function buildCartridges(counts) {
|
||||||
|
if (!cartridges) return null;
|
||||||
|
return {
|
||||||
|
cartridges: [
|
||||||
|
{
|
||||||
|
denomination: cartridges.cartridges[0],
|
||||||
|
count: counts[0]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
denomination: cartridges.cartridges[1],
|
||||||
|
count: counts[1]
|
||||||
|
},
|
||||||
|
],
|
||||||
|
virtualCartridges: cartridges.virtualCartridges
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
exports.pollQueries = function pollQueries(session, cb) {
|
||||||
|
async.parallel([
|
||||||
|
async.apply(db.dispenseStatus, session),
|
||||||
|
async.apply(db.cartridgeCounts, session)
|
||||||
|
], function(err, results) {
|
||||||
|
if (err) return cb(err);
|
||||||
|
return cb(null, {
|
||||||
|
dispenseStatus: results[0],
|
||||||
|
cartridges: buildCartridges(results[1])
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
function _sendBitcoins(toAddress, satoshis, cb) {
|
function _sendBitcoins(toAddress, satoshis, cb) {
|
||||||
var transactionFee = cachedConfig.exchanges.settings.transactionFee;
|
var transactionFee = cachedConfig.exchanges.settings.transactionFee;
|
||||||
walletPlugin.sendBitcoins(toAddress, satoshis, transactionFee, cb);
|
walletPlugin.sendBitcoins(toAddress, satoshis, transactionFee, cb);
|
||||||
|
|
|
||||||
|
|
@ -10,9 +10,11 @@ var _ = require('lodash');
|
||||||
|
|
||||||
var logger = require('./logger');
|
var logger = require('./logger');
|
||||||
|
|
||||||
|
/*
|
||||||
function inspect(rec) {
|
function inspect(rec) {
|
||||||
console.log(util.inspect(rec, {depth: null, colors: true}));
|
console.log(util.inspect(rec, {depth: null, colors: true}));
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
function isUniqueViolation(err) {
|
function isUniqueViolation(err) {
|
||||||
return err.code === '23505';
|
return err.code === '23505';
|
||||||
|
|
@ -503,7 +505,7 @@ function insertDispense(client, session, tx, transactionId, counts, cb) {
|
||||||
|
|
||||||
exports.addDispense = function addDispense(session, tx) {
|
exports.addDispense = function addDispense(session, tx) {
|
||||||
connect(function(cerr, client, done) {
|
connect(function(cerr, client, done) {
|
||||||
if (cerr) return logger.error(cerr);
|
if (cerr) return;
|
||||||
|
|
||||||
async.waterfall([
|
async.waterfall([
|
||||||
async.apply(insertIncoming, client, session, tx, 0, tx.fiat,
|
async.apply(insertIncoming, client, session, tx, 0, tx.fiat,
|
||||||
|
|
@ -517,6 +519,23 @@ exports.addDispense = function addDispense(session, tx) {
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
exports.cartridgeCounts = function cartridgeCounts(session, cb) {
|
||||||
|
connect(function(cerr, client, done) {
|
||||||
|
if (cerr) return cb(cerr);
|
||||||
|
var sql = 'SELECT count1, count2 FROM dispenses ' +
|
||||||
|
'WHERE device_fingerprint=$1 ' +
|
||||||
|
'ORDER BY id DESC LIMIT 1';
|
||||||
|
query(client, sql, [session.fingerprint], function(err, results) {
|
||||||
|
done();
|
||||||
|
if (err) return cb(err);
|
||||||
|
var counts = results.rows.length === 1 ?
|
||||||
|
[results.rows[0].count1, results.rows[0].count2] :
|
||||||
|
[0, 0];
|
||||||
|
cb(null, counts);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
exports.init('postgres://lamassu:lamassu@localhost/lamassu');
|
exports.init('postgres://lamassu:lamassu@localhost/lamassu');
|
||||||
connect(function(err, client, done) {
|
connect(function(err, client, done) {
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,5 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var fs = require('fs');
|
|
||||||
var logger = require('./logger');
|
var logger = require('./logger');
|
||||||
|
|
||||||
var mock = false;
|
var mock = false;
|
||||||
|
|
@ -18,13 +17,6 @@ module.exports = {
|
||||||
var STALE_TICKER = 180000;
|
var STALE_TICKER = 180000;
|
||||||
var STALE_BALANCE = 180000;
|
var STALE_BALANCE = 180000;
|
||||||
|
|
||||||
var cartridges = null;
|
|
||||||
try {
|
|
||||||
cartridges = JSON.parse(fs.readFileSync('./cartridges.json'));
|
|
||||||
} catch (ex) {
|
|
||||||
logger.warn('No cartridges.json file found: ' + ex.message);
|
|
||||||
}
|
|
||||||
|
|
||||||
function poll(req, res) {
|
function poll(req, res) {
|
||||||
var rateRec = plugins.getDeviceRate();
|
var rateRec = plugins.getDeviceRate();
|
||||||
var balanceRec = plugins.getBalance();
|
var balanceRec = plugins.getBalance();
|
||||||
|
|
@ -59,9 +51,9 @@ function poll(req, res) {
|
||||||
var fiatCommission = config.exchanges.settings.fiatCommission ||
|
var fiatCommission = config.exchanges.settings.fiatCommission ||
|
||||||
config.exchanges.settings.commission;
|
config.exchanges.settings.commission;
|
||||||
|
|
||||||
console.log('DEBUG0');
|
plugins.pollQueries(session(req), function(err, results) {
|
||||||
plugins.dispenseStatus(session(req), function(err, dispenseStatus) {
|
|
||||||
if (err) return logger.error(err);
|
if (err) return logger.error(err);
|
||||||
|
var cartridges = results.cartridges;
|
||||||
var response = {
|
var response = {
|
||||||
err: null,
|
err: null,
|
||||||
rate: rate * config.exchanges.settings.commission,
|
rate: rate * config.exchanges.settings.commission,
|
||||||
|
|
@ -69,7 +61,7 @@ function poll(req, res) {
|
||||||
fiat: fiatBalance,
|
fiat: fiatBalance,
|
||||||
locale: config.brain.locale,
|
locale: config.brain.locale,
|
||||||
txLimit: parseInt(complianceSettings.maximum.limit, 10),
|
txLimit: parseInt(complianceSettings.maximum.limit, 10),
|
||||||
dispenseStatus: dispenseStatus,
|
dispenseStatus: results.dispenseStatus,
|
||||||
idVerificationEnabled: complianceSettings.idVerificationEnabled,
|
idVerificationEnabled: complianceSettings.idVerificationEnabled,
|
||||||
cartridges: cartridges,
|
cartridges: cartridges,
|
||||||
twoWayMode: cartridges ? true : false
|
twoWayMode: cartridges ? true : false
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue