2018-02-15 20:00:51 +01:00
|
|
|
const logger = require('winston');
|
|
|
|
const ua = require('universal-analytics');
|
2018-03-16 18:34:26 +01:00
|
|
|
const { analytics : { googleId }, details: { title } } = require('../../config/siteConfig.js');
|
2018-02-15 20:00:51 +01:00
|
|
|
|
|
|
|
function createServeEventParams (headers, ip, originalUrl) {
|
|
|
|
return {
|
2018-02-15 22:18:22 +01:00
|
|
|
eventCategory : 'client requests',
|
|
|
|
eventAction : 'serve request',
|
|
|
|
eventLabel : originalUrl,
|
|
|
|
ipOverride : ip,
|
|
|
|
userAgentOverride: headers['user-agent'],
|
2018-05-25 18:34:09 +02:00
|
|
|
documentReferrer : headers['referer'],
|
2018-02-15 20:00:51 +01:00
|
|
|
};
|
2018-05-25 18:34:09 +02:00
|
|
|
}
|
2018-02-15 20:00:51 +01:00
|
|
|
|
2018-03-06 18:02:42 +01:00
|
|
|
function createPublishTimingEventParams (category, variable, label, startTime, endTime) {
|
2018-03-07 01:23:21 +01:00
|
|
|
const duration = endTime - startTime;
|
2018-02-15 20:00:51 +01:00
|
|
|
return {
|
2018-03-06 18:02:42 +01:00
|
|
|
userTimingCategory : category,
|
|
|
|
userTimingVariableName: variable,
|
2018-03-07 01:23:21 +01:00
|
|
|
userTimingTime : duration,
|
2018-02-15 20:00:51 +01:00
|
|
|
userTimingLabel : label,
|
|
|
|
};
|
2018-05-25 18:34:09 +02:00
|
|
|
}
|
2018-02-15 20:00:51 +01:00
|
|
|
|
|
|
|
function sendGoogleAnalyticsEvent (ip, params) {
|
|
|
|
const visitorId = ip.replace(/\./g, '-');
|
2018-03-06 18:02:42 +01:00
|
|
|
const visitor = ua(googleId, visitorId, { strictCidFormat: false, https: true });
|
2018-02-15 20:00:51 +01:00
|
|
|
visitor.event(params, (err) => {
|
|
|
|
if (err) {
|
|
|
|
logger.error('Google Analytics Event Error >>', err);
|
|
|
|
}
|
2018-05-25 18:34:09 +02:00
|
|
|
logger.debug(`Event successfully sent to google analytics`);
|
2018-02-15 20:00:51 +01:00
|
|
|
});
|
2018-05-25 18:34:09 +02:00
|
|
|
}
|
2018-02-15 20:00:51 +01:00
|
|
|
|
2018-03-06 18:02:42 +01:00
|
|
|
function sendGoogleAnalyticsTiming (visitorId, params) {
|
|
|
|
const visitor = ua(googleId, visitorId, { strictCidFormat: false, https: true });
|
2018-02-15 20:00:51 +01:00
|
|
|
visitor.timing(params, (err) => {
|
|
|
|
if (err) {
|
|
|
|
logger.error('Google Analytics Event Error >>', err);
|
|
|
|
}
|
|
|
|
logger.debug(`Timing event successfully sent to google analytics`);
|
|
|
|
});
|
2018-05-25 18:34:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function sendGAServeEvent (headers, ip, originalUrl) {
|
|
|
|
logger.debug('headers:', headers);
|
|
|
|
const params = createServeEventParams(headers, ip, originalUrl);
|
|
|
|
sendGoogleAnalyticsEvent(ip, params);
|
|
|
|
}
|
|
|
|
|
|
|
|
function sendGATimingEvent (category, variable, label, startTime, endTime) {
|
|
|
|
const params = createPublishTimingEventParams(category, variable, label, startTime, endTime);
|
|
|
|
sendGoogleAnalyticsTiming(title, params);
|
|
|
|
}
|
|
|
|
|
|
|
|
function chooseGaLbrynetPublishLabel ({ channel_name: channelName, channel_id: channelId }) {
|
|
|
|
return (channelName || channelId ? 'PUBLISH_IN_CHANNEL_CLAIM' : 'PUBLISH_ANONYMOUS_CLAIM');
|
|
|
|
}
|
2018-02-15 20:00:51 +01:00
|
|
|
|
|
|
|
module.exports = {
|
2018-05-25 18:34:09 +02:00
|
|
|
sendGAServeEvent,
|
|
|
|
sendGATimingEvent,
|
|
|
|
chooseGaLbrynetPublishLabel,
|
2018-02-15 20:00:51 +01:00
|
|
|
};
|