spee.ch/server/utils/googleAnalytics.js

72 lines
2.4 KiB
JavaScript
Raw Normal View History

2019-04-18 17:51:21 +02:00
const logger = require('winston');
const ua = require('universal-analytics');
const { analytics : { googleId }, details: { title } } = require('@config/siteConfig');
2018-02-15 20:00:51 +01:00
2018-06-06 01:24:27 +02:00
const createServeEventParams = (headers, ip, originalUrl) => {
2018-02-15 20:00:51 +01:00
return {
2019-04-18 17:51:21 +02:00
eventCategory : 'client requests',
eventAction : 'serve request',
eventLabel : originalUrl,
ipOverride : ip,
2018-02-15 22:18:22 +01:00
userAgentOverride: headers['user-agent'],
2019-04-18 17:51:21 +02:00
documentReferrer : headers['referer'],
2018-02-15 20:00:51 +01:00
};
2018-06-06 01:24:27 +02:00
};
2018-02-15 20:00:51 +01:00
2018-06-06 03:01:29 +02:00
const createTimingEventParams = (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 {
2019-04-18 17:51:21 +02:00
userTimingCategory : category,
userTimingVariableName: variable,
2019-04-18 17:51:21 +02:00
userTimingTime : duration,
userTimingLabel : label,
2018-02-15 20:00:51 +01:00
};
2018-06-06 01:24:27 +02:00
};
2018-02-15 20:00:51 +01:00
2018-06-06 01:24:27 +02:00
const sendGoogleAnalyticsEvent = (ip, params) => {
if (!googleId) {
return logger.debug('Skipping analytics event because no GoogleId present in configs');
}
2018-02-15 20:00:51 +01:00
const visitorId = ip.replace(/\./g, '-');
const visitor = ua(googleId, visitorId, { strictCidFormat: false, https: true });
2019-04-18 17:51:21 +02:00
visitor.event(params, (err) => {
2018-02-15 20:00:51 +01:00
if (err) {
2018-06-06 01:24:27 +02:00
return logger.error('Google Analytics Event Error >>', err);
2018-02-15 20:00:51 +01:00
}
2018-06-07 00:59:30 +02:00
logger.debug(`Event successfully sent to google analytics`, params);
2018-02-15 20:00:51 +01:00
});
2018-06-06 01:24:27 +02:00
};
2018-02-15 20:00:51 +01:00
2018-06-06 03:01:29 +02:00
const sendGoogleAnalyticsTiming = (siteTitle, params) => {
if (!googleId) {
return logger.debug('Skipping analytics timing because no GoogleId present in configs');
}
2018-06-06 03:01:29 +02:00
const visitor = ua(googleId, siteTitle, { strictCidFormat: false, https: true });
2019-04-18 17:51:21 +02:00
visitor.timing(params, (err) => {
2018-02-15 20:00:51 +01:00
if (err) {
2018-06-06 01:24:27 +02:00
return logger.error('Google Analytics Event Error >>', err);
2018-02-15 20:00:51 +01:00
}
2018-06-07 00:59:30 +02:00
logger.debug(`Event successfully sent to google analytics`, params);
2018-02-15 20:00:51 +01:00
});
2018-06-06 01:24:27 +02:00
};
2019-04-18 17:51:21 +02:00
const sendGAServeEvent = (headers, ip, originalUrl) => {
const params = createServeEventParams(headers, ip, originalUrl);
sendGoogleAnalyticsEvent(ip, params);
2018-06-06 01:24:27 +02:00
};
2019-04-18 17:51:21 +02:00
const sendGATimingEvent = (category, variable, label, startTime, endTime) => {
2018-06-06 03:01:29 +02:00
const params = createTimingEventParams(category, variable, label, startTime, endTime);
sendGoogleAnalyticsTiming(title, params);
2018-06-06 01:24:27 +02:00
};
2019-04-18 17:51:21 +02:00
const chooseGaLbrynetPublishLabel = ({ channel_name: channelName, channel_id: channelId }) => {
return (channelName || channelId ? 'PUBLISH_IN_CHANNEL_CLAIM' : 'PUBLISH_ANONYMOUS_CLAIM');
};
module.exports = {
sendGAServeEvent,
sendGATimingEvent,
chooseGaLbrynetPublishLabel,
2018-02-15 20:00:51 +01:00
};