2017-06-27 20:25:36 -07:00
|
|
|
const logger = require('winston');
|
2018-03-16 10:34:26 -07:00
|
|
|
const db = require('../models/index');
|
2018-01-23 12:08:53 -08:00
|
|
|
|
2017-06-27 20:25:36 -07:00
|
|
|
module.exports = {
|
2017-07-12 15:30:31 -07:00
|
|
|
postToStats (action, url, ipAddress, name, claimId, result) {
|
2017-09-07 11:46:06 -07:00
|
|
|
logger.debug('action:', action);
|
2017-06-29 17:52:37 -07:00
|
|
|
// make sure the result is a string
|
|
|
|
if (result && (typeof result !== 'string')) {
|
|
|
|
result = result.toString();
|
|
|
|
}
|
2017-07-19 15:42:56 -07:00
|
|
|
// make sure the ip address(es) are a string
|
2017-06-29 17:52:37 -07:00
|
|
|
if (ipAddress && (typeof ipAddress !== 'string')) {
|
|
|
|
ipAddress = ipAddress.toString();
|
|
|
|
}
|
2017-07-12 15:30:31 -07:00
|
|
|
db.File
|
|
|
|
.findOne({where: { name, claimId }})
|
|
|
|
.then(file => {
|
|
|
|
// create record in the db
|
|
|
|
let FileId;
|
|
|
|
if (file) {
|
|
|
|
FileId = file.dataValues.id;
|
|
|
|
} else {
|
|
|
|
FileId = null;
|
|
|
|
}
|
|
|
|
return db.Request
|
|
|
|
.create({
|
|
|
|
action,
|
|
|
|
url,
|
|
|
|
ipAddress,
|
|
|
|
result,
|
|
|
|
FileId,
|
|
|
|
});
|
|
|
|
})
|
|
|
|
.catch(error => {
|
2017-09-13 15:59:29 -07:00
|
|
|
logger.error('Sequelize error >>', error);
|
2017-07-12 15:30:31 -07:00
|
|
|
});
|
2017-06-29 17:52:37 -07:00
|
|
|
},
|
2017-06-27 20:25:36 -07:00
|
|
|
};
|