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": [
|
||||
{"denomination": 1, "count": 100},
|
||||
{"denomination": 20, "count": 100}
|
||||
],
|
||||
"cartridges": [1, 20],
|
||||
"virtualCartridges": [5]
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,5 +1,7 @@
|
|||
'use strict';
|
||||
|
||||
var fs = require('fs');
|
||||
|
||||
var _ = require('lodash');
|
||||
var async = require('async');
|
||||
var logger = require('./logger');
|
||||
|
|
@ -35,6 +37,13 @@ var reapTxInterval = null;
|
|||
|
||||
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
|
||||
exports.init = function init(databaseHandle) {
|
||||
if (!databaseHandle) {
|
||||
|
|
@ -187,6 +196,36 @@ exports.logEvent = function event(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) {
|
||||
var transactionFee = cachedConfig.exchanges.settings.transactionFee;
|
||||
walletPlugin.sendBitcoins(toAddress, satoshis, transactionFee, cb);
|
||||
|
|
|
|||
|
|
@ -10,9 +10,11 @@ var _ = require('lodash');
|
|||
|
||||
var logger = require('./logger');
|
||||
|
||||
/*
|
||||
function inspect(rec) {
|
||||
console.log(util.inspect(rec, {depth: null, colors: true}));
|
||||
}
|
||||
*/
|
||||
|
||||
function isUniqueViolation(err) {
|
||||
return err.code === '23505';
|
||||
|
|
@ -503,7 +505,7 @@ function insertDispense(client, session, tx, transactionId, counts, cb) {
|
|||
|
||||
exports.addDispense = function addDispense(session, tx) {
|
||||
connect(function(cerr, client, done) {
|
||||
if (cerr) return logger.error(cerr);
|
||||
if (cerr) return;
|
||||
|
||||
async.waterfall([
|
||||
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');
|
||||
connect(function(err, client, done) {
|
||||
|
|
|
|||
|
|
@ -1,6 +1,5 @@
|
|||
'use strict';
|
||||
|
||||
var fs = require('fs');
|
||||
var logger = require('./logger');
|
||||
|
||||
var mock = false;
|
||||
|
|
@ -18,13 +17,6 @@ module.exports = {
|
|||
var STALE_TICKER = 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) {
|
||||
var rateRec = plugins.getDeviceRate();
|
||||
var balanceRec = plugins.getBalance();
|
||||
|
|
@ -59,9 +51,9 @@ function poll(req, res) {
|
|||
var fiatCommission = config.exchanges.settings.fiatCommission ||
|
||||
config.exchanges.settings.commission;
|
||||
|
||||
console.log('DEBUG0');
|
||||
plugins.dispenseStatus(session(req), function(err, dispenseStatus) {
|
||||
plugins.pollQueries(session(req), function(err, results) {
|
||||
if (err) return logger.error(err);
|
||||
var cartridges = results.cartridges;
|
||||
var response = {
|
||||
err: null,
|
||||
rate: rate * config.exchanges.settings.commission,
|
||||
|
|
@ -69,7 +61,7 @@ function poll(req, res) {
|
|||
fiat: fiatBalance,
|
||||
locale: config.brain.locale,
|
||||
txLimit: parseInt(complianceSettings.maximum.limit, 10),
|
||||
dispenseStatus: dispenseStatus,
|
||||
dispenseStatus: results.dispenseStatus,
|
||||
idVerificationEnabled: complianceSettings.idVerificationEnabled,
|
||||
cartridges: cartridges,
|
||||
twoWayMode: cartridges ? true : false
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue