spee.ch/helpers/statsHelpers.js

96 lines
3 KiB
JavaScript
Raw Normal View History

2018-01-23 14:45:54 -08:00
const constants = require('../constants');
const logger = require('winston');
const ua = require('universal-analytics');
2017-11-06 15:18:45 -08:00
const config = require('../config/speechConfig.js');
const googleApiKey = config.analytics.googleId;
2018-01-23 12:08:53 -08:00
const db = require('../models');
module.exports = {
2018-01-23 12:47:10 -08:00
createPublishTimingEventParams (publishDurration, ip, headers, label) {
return {
userTimingCategory : 'lbrynet',
userTimingVariableName: 'publish',
userTimingTime : publishDurration,
userTimingLabel : label,
uip : ip,
ua : headers['user-agent'],
ul : headers['accept-language'],
};
},
2017-07-12 15:30:31 -07:00
postToStats (action, url, ipAddress, name, claimId, result) {
logger.debug('action:', action);
// 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
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
});
},
2018-01-22 16:14:05 -08:00
sendGoogleAnalyticsEvent (action, headers, ip, originalUrl) {
const visitorId = ip.replace(/\./g, '-');
const visitor = ua(googleApiKey, visitorId, { strictCidFormat: false, https: true });
2017-07-05 09:26:22 -07:00
let params;
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'],
};
break;
2018-01-22 16:14:05 -08:00
default: break;
}
visitor.event(params, (err) => {
if (err) {
logger.error('Google Analytics Event Error >>', err);
}
});
},
sendGoogleAnalyticsTiming (action, headers, ip, originalUrl, startTime, endTime) {
const visitorId = ip.replace(/\./g, '-');
const visitor = ua(googleApiKey, visitorId, { strictCidFormat: false, https: true });
2018-01-23 12:08:53 -08:00
const durration = endTime - startTime;
2018-01-22 16:14:05 -08:00
let params;
switch (action) {
2018-01-23 12:08:53 -08:00
case constants.PUBLISH_ANONYMOUS_CLAIM:
case constants.PUBLISH_IN_CHANNEL_CLAIM:
logger.verbose(`${action} completed successfully in ${durration}ms`);
2018-01-23 12:47:10 -08:00
params = module.exports.createPublishTimingEventParams(durration, ip, headers, action);
break;
default: break;
}
2018-01-22 16:14:05 -08:00
visitor.timing(params, (err) => {
2017-07-05 09:26:22 -07:00
if (err) {
logger.error('Google Analytics Event Error >>', err);
}
2018-01-23 12:08:53 -08:00
logger.debug(`${action} timing event successfully sent to google analytics`);
2017-07-05 09:26:22 -07:00
});
},
};