2017-06-27 20:25:36 -07:00
|
|
|
const logger = require('winston');
|
2017-06-29 17:52:37 -07:00
|
|
|
const ua = require('universal-analytics');
|
|
|
|
const config = require('config');
|
2017-06-27 20:25:36 -07:00
|
|
|
const db = require('../models');
|
2017-06-29 17:52:37 -07:00
|
|
|
const googleApiKey = config.get('AnalyticsConfig.GoogleId');
|
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-07-05 09:26:22 -07:00
|
|
|
sendGoogleAnalytics (action, headers, ip, originalUrl) {
|
2017-06-29 17:52:37 -07:00
|
|
|
const visitorId = ip.replace(/\./g, '-');
|
|
|
|
const visitor = ua(googleApiKey, visitorId, { strictCidFormat: false, https: true });
|
2017-07-05 09:26:22 -07:00
|
|
|
let params;
|
2017-06-29 17:52:37 -07:00
|
|
|
switch (action) {
|
2017-08-03 21:59:22 -07:00
|
|
|
case 'SERVE':
|
2017-07-05 09:26:22 -07:00
|
|
|
params = {
|
|
|
|
ec : 'serve',
|
|
|
|
ea : originalUrl,
|
|
|
|
uip: ip,
|
|
|
|
ua : headers['user-agent'],
|
|
|
|
ul : headers['accept-language'],
|
|
|
|
};
|
2017-06-29 17:52:37 -07:00
|
|
|
break;
|
2017-08-03 21:59:22 -07:00
|
|
|
case 'PUBLISH':
|
2017-07-05 09:26:22 -07:00
|
|
|
params = {
|
|
|
|
ec : 'publish',
|
|
|
|
ea : originalUrl,
|
|
|
|
uip: ip,
|
|
|
|
ua : headers['user-agent'],
|
|
|
|
ul : headers['accept-language'],
|
|
|
|
};
|
2017-06-29 17:52:37 -07:00
|
|
|
break;
|
|
|
|
default: break;
|
|
|
|
}
|
2017-07-05 09:26:22 -07:00
|
|
|
visitor.event(params, (err) => {
|
|
|
|
if (err) {
|
|
|
|
logger.error('Google Analytics Event Error >>', err);
|
|
|
|
}
|
|
|
|
});
|
2017-06-29 17:52:37 -07:00
|
|
|
},
|
2017-07-10 17:51:29 -07:00
|
|
|
getTrendingClaims (startDate) {
|
2017-07-12 15:30:31 -07:00
|
|
|
logger.debug('retrieving trending requests');
|
2017-07-30 11:24:12 -07:00
|
|
|
return new Promise((resolve, reject) => {
|
2017-07-12 15:30:31 -07:00
|
|
|
// get the raw requests data
|
2017-09-07 12:36:03 -07:00
|
|
|
db.getTrendingClaims(startDate)
|
2017-08-15 15:35:03 -07:00
|
|
|
.then(results => {
|
2017-09-11 12:10:41 -07:00
|
|
|
if (results) {
|
|
|
|
results.forEach(element => {
|
|
|
|
const fileExtenstion = element.fileType.substring(element.fileType.lastIndexOf('/') + 1);
|
|
|
|
element['showUrlLong'] = `/${element.claimId}/${element.name}`;
|
|
|
|
element['directUrlLong'] = `/${element.claimId}/${element.name}.${fileExtenstion}`;
|
|
|
|
element['directUrlShort'] = `/${element.claimId}/${element.name}.${fileExtenstion}`;
|
|
|
|
element['contentType'] = element.fileType;
|
2017-10-05 15:14:50 -07:00
|
|
|
element['thumbnail'] = 'https://spee.ch/assets/img/video_thumb_default.png';
|
2017-09-11 12:10:41 -07:00
|
|
|
});
|
|
|
|
}
|
2017-08-15 15:35:03 -07:00
|
|
|
resolve(results);
|
|
|
|
})
|
|
|
|
.catch(error => {
|
2017-09-13 15:59:29 -07:00
|
|
|
logger.error('sequelize error >>', error);
|
2017-08-15 15:35:03 -07:00
|
|
|
reject(error);
|
|
|
|
});
|
2017-07-10 17:51:29 -07:00
|
|
|
});
|
|
|
|
},
|
2017-09-07 12:24:40 -07:00
|
|
|
getRecentClaims () {
|
2017-08-24 16:09:04 -07:00
|
|
|
logger.debug('retrieving most recent claims');
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
// get the raw requests data
|
2017-10-31 17:19:26 -07:00
|
|
|
db.File.getRecentClaims()
|
2017-08-24 16:09:04 -07:00
|
|
|
.then(results => {
|
|
|
|
resolve(results);
|
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
logger.error('sequelize error', error);
|
|
|
|
reject(error);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
2017-06-27 20:25:36 -07:00
|
|
|
};
|