lamassu-server/lib/cash-out/cash-out-actions.js
Sérgio Salgado 3c1a58da4a feat: start working on backend support for dynamic cassette number
fix: multiple small fixes to both the front and back-end multi-cassette support
2021-09-13 18:53:53 +01:00

58 lines
1.7 KiB
JavaScript

const _ = require('lodash/fp')
const pgp = require('pg-promise')()
module.exports = {logDispense, logActionById, logAction, logError}
function logDispense (t, tx) {
const baseRec = {error: tx.error, error_code: tx.errorCode}
const rec = _.merge(mapDispense(tx), baseRec)
const action = _.isEmpty(tx.error) ? 'dispense' : 'dispenseError'
return logAction(t, action, rec, tx)
}
function logActionById (t, action, _rec, txId) {
const rec = _.assign(_rec, {action, tx_id: txId, redeem: false})
const sql = pgp.helpers.insert(rec, null, 'cash_out_actions')
return t.none(sql)
}
function logAction (t, action, _rec, tx) {
const rec = _.assign(_rec, {action, tx_id: tx.id, redeem: !!tx.redeem, device_id: tx.deviceId})
const sql = pgp.helpers.insert(rec, null, 'cash_out_actions')
return t.none(sql)
.then(_.constant(tx))
}
function logError (t, action, err, tx) {
return logAction(t, action, {
error: err.message,
error_code: err.name
}, tx)
}
function mapDispense (tx) {
const bills = tx.bills
if (_.isEmpty(bills)) return {}
return {
provisioned_1: bills[0].provisioned,
provisioned_2: bills[1].provisioned,
provisioned_3: bills[2].provisioned,
provisioned_4: bills[3].provisioned,
dispensed_1: bills[0].dispensed,
dispensed_2: bills[1].dispensed,
dispensed_3: bills[2].dispensed,
dispensed_4: bills[3].dispensed,
rejected_1: bills[0].rejected,
rejected_2: bills[1].rejected,
rejected_3: bills[2].rejected,
rejected_4: bills[3].rejected,
denomination_1: bills[0].denomination,
denomination_2: bills[1].denomination,
denomination_3: bills[2].denomination,
denomination_4: bills[3].denomination
}
}