Refactor customers API
* Use lodash camelize * Modify enhanceOverrideFields (fp) * Fix for sql timestamp * Fetch all existing users at once in populateOverrideUsernames * Modify populateOverrideUsernames (fp) * Break format function into computeStatus, camelize
This commit is contained in:
parent
e907f8a70a
commit
c77bb53f8f
2 changed files with 65 additions and 34 deletions
|
|
@ -1,14 +1,16 @@
|
|||
const db = require('./db')
|
||||
const uuid = require('uuid')
|
||||
const Pgp = require('pg-promise')()
|
||||
const _ = require('lodash/fp')
|
||||
|
||||
const db = require('./db')
|
||||
const BN = require('./bn')
|
||||
const anonymous = require('../lib/constants').anonymousCustomer
|
||||
const NUM_RESULTS = 20
|
||||
const camelize = require('camelize')
|
||||
const Pgp = require('pg-promise')()
|
||||
const camelize = _.mapKeys(_.camelCase)
|
||||
const complianceOverrides = require('./compliance_overrides')
|
||||
const users = require('./users')
|
||||
|
||||
const NUM_RESULTS = 20
|
||||
|
||||
function add (customer) {
|
||||
const sql = 'insert into customers (id, phone, phone_at) values ($1, $2, now()) returning *'
|
||||
return db.one(sql, [uuid.v4(), customer.phone])
|
||||
|
|
@ -44,13 +46,17 @@ function update (id, data, userToken) {
|
|||
' where id=$1 returning *'
|
||||
return db.one(sql, [id])
|
||||
.then(addComplianceOverrides(id, updateData, userToken))
|
||||
.then(format)
|
||||
.then(populateOverrideUsernames)
|
||||
.then(computeStatus)
|
||||
.then(camelize)
|
||||
}
|
||||
|
||||
function getById (id, userToken) {
|
||||
const sql = 'select * from customers where id=$1'
|
||||
return db.oneOrNone(sql, [id])
|
||||
.then(format)
|
||||
.then(populateOverrideUsernames)
|
||||
.then(computeStatus)
|
||||
.then(camelize)
|
||||
}
|
||||
|
||||
function getDailyVolume (id) {
|
||||
|
|
@ -97,15 +103,15 @@ function getComplianceTypes () {
|
|||
* @returns {object} fields enhanced with *_by and *_at fields
|
||||
*/
|
||||
function enhanceOverrideFields (fields, userToken) {
|
||||
if (!userToken) return fields
|
||||
if (!userToken) return _.extend(fields, {})
|
||||
// Populate with computedFields (user who overrode and overriden timestamps date)
|
||||
_.each(field => {
|
||||
if (fields[field + '_override']) {
|
||||
fields[field + '_override_by'] = userToken
|
||||
fields[field + '_override_at'] = new Date().toISOString()
|
||||
}
|
||||
}, getComplianceTypes())
|
||||
return fields
|
||||
return _.reduce(_.assign, {}, _.map((type) => {
|
||||
return (fields[type + '_override']) ? {
|
||||
[type + '_override']: fields[type + '_override'],
|
||||
[type + '_override_by']: userToken,
|
||||
[type + '_override_at']: 'now()^'
|
||||
} : {}
|
||||
}, getComplianceTypes()))
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -137,19 +143,22 @@ function addComplianceOverrides (id, customer, userToken) {
|
|||
|
||||
// Save all the updated override fields
|
||||
return Promise.all(_.map(complianceOverrides.add, _.compact(overrides)))
|
||||
.then(() => customer)
|
||||
}
|
||||
|
||||
/**
|
||||
* Format and populate fields
|
||||
* for customer record
|
||||
* Compute status field
|
||||
*
|
||||
* @name format
|
||||
* Status field indicates the last
|
||||
* compliance user has verified
|
||||
*
|
||||
* @name computeStatus
|
||||
* @function
|
||||
*
|
||||
* @param {object} Customer object
|
||||
* @returns {object} Customer camelized & populated with computed fields
|
||||
* @returns {object} Customer populated with status field
|
||||
*/
|
||||
function format (customer) {
|
||||
function computeStatus (customer) {
|
||||
if (!customer) return null
|
||||
/**
|
||||
* Populate with status field
|
||||
|
|
@ -168,14 +177,15 @@ function format (customer) {
|
|||
label: 'ID card image',
|
||||
value: customer.id_card_image_at
|
||||
}])
|
||||
customer.status = status.label
|
||||
return populateOverrideUsernames(customer)
|
||||
.then(camelize)
|
||||
|
||||
return _.extend(customer, {
|
||||
status: status.label
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* Populate the customer object with user names
|
||||
* for override fields
|
||||
* for override fields ( fields ending with _override_by )
|
||||
*
|
||||
* @name populateOverrideUsernames
|
||||
* @function
|
||||
|
|
@ -184,15 +194,24 @@ function format (customer) {
|
|||
* @returns {promise} Customer with populated *by_name fields
|
||||
*/
|
||||
function populateOverrideUsernames (customer) {
|
||||
return Promise.all(_.map(field => {
|
||||
return users.get(customer[field + '_override_by'])
|
||||
.then(user => {
|
||||
// just add the name to the customer object
|
||||
customer[field + '_override_by_name'] = (user) ? user.name : null
|
||||
return null
|
||||
})
|
||||
}, getComplianceTypes()))
|
||||
.then(() => customer)
|
||||
const fieldsToUpdate = _.map(field => {
|
||||
return {
|
||||
token: customer[field + '_override_by'],
|
||||
field: field + '_override_by_name'
|
||||
}
|
||||
}, getComplianceTypes())
|
||||
const queryTokens = _.map('token', fieldsToUpdate)
|
||||
|
||||
return users.getByIds(queryTokens)
|
||||
.then(usersList => {
|
||||
return _.map(userField => {
|
||||
const user = _.find({token: userField.token}, usersList)
|
||||
return {
|
||||
[userField.field]: user ? user.name : null
|
||||
}
|
||||
}, fieldsToUpdate)
|
||||
})
|
||||
.then(_.reduce(_.extend, customer))
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -209,7 +228,11 @@ function batch () {
|
|||
where id != $1
|
||||
order by created desc limit $2`
|
||||
return db.any(sql, [ anonymous.uuid, NUM_RESULTS ])
|
||||
.then(customers => Promise.all(_.map(format, customers)))
|
||||
.then(customers => Promise.all(_.map(customer => {
|
||||
return populateOverrideUsernames(customer)
|
||||
.then(computeStatus)
|
||||
.then(camelize)
|
||||
}, customers)))
|
||||
}
|
||||
|
||||
module.exports = { add, get, batch, getById, update }
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue