2018-02-16 00:47:52 -08:00
|
|
|
// @flow
|
2018-09-23 23:44:42 -04:00
|
|
|
import { Lbryio } from 'lbryinc';
|
2019-04-01 10:30:19 -04:00
|
|
|
import ReactGA from 'react-ga';
|
2019-04-09 17:21:00 -04:00
|
|
|
import { history } from './store';
|
2019-05-14 16:35:49 -04:00
|
|
|
// @if TARGET='app'
|
2019-08-14 12:28:13 -04:00
|
|
|
import Native from 'native';
|
2019-05-14 16:35:49 -04:00
|
|
|
import ElectronCookies from '@exponent/electron-cookies';
|
|
|
|
// @endif
|
2018-02-16 00:47:52 -08:00
|
|
|
|
2019-06-19 20:57:51 -04:00
|
|
|
const isProduction = process.env.NODE_ENV === 'production';
|
2019-09-02 14:08:29 -04:00
|
|
|
const devInternalApis = process.env.LBRY_API_URL;
|
2019-11-04 13:36:37 -05:00
|
|
|
const LBRY_TV_MINUS_PIRATE_BAY_UA_ID = 'UA-60403362-16';
|
|
|
|
const LBRY_TV_UA_ID = 'UA-60403362-12';
|
|
|
|
const DESKTOP_UA_ID = 'UA-60403362-13';
|
2019-11-07 10:33:00 -05:00
|
|
|
const SECOND_TRACKER_NAME = 'tracker2';
|
2019-11-04 13:36:37 -05:00
|
|
|
|
|
|
|
// @if TARGET='app'
|
|
|
|
ElectronCookies.enable({
|
|
|
|
origin: 'https://lbry.tv',
|
|
|
|
});
|
|
|
|
// @endif
|
2019-06-19 20:57:51 -04:00
|
|
|
|
2018-02-16 00:47:52 -08:00
|
|
|
type Analytics = {
|
2019-04-01 10:30:19 -04:00
|
|
|
pageView: string => void,
|
2018-02-23 17:24:00 -07:00
|
|
|
setUser: Object => void,
|
|
|
|
toggle: (boolean, ?boolean) => void,
|
2019-09-18 14:41:20 -04:00
|
|
|
apiLogView: (string, string, string, ?number, ?() => void) => Promise<any>,
|
2019-10-16 17:36:50 -04:00
|
|
|
apiLogPublish: (ChannelClaim | StreamClaim) => void,
|
2019-07-21 19:35:59 -04:00
|
|
|
tagFollowEvent: (string, boolean, string) => void,
|
2019-08-14 12:28:13 -04:00
|
|
|
emailProvidedEvent: () => void,
|
|
|
|
emailVerifiedEvent: () => void,
|
|
|
|
rewardEligibleEvent: () => void,
|
2019-10-02 14:20:25 -04:00
|
|
|
startupEvent: () => void,
|
|
|
|
readyEvent: number => void,
|
2019-11-04 10:55:02 -05:00
|
|
|
openUrlEvent: string => void,
|
2018-02-23 17:24:00 -07:00
|
|
|
};
|
2018-02-16 00:47:52 -08:00
|
|
|
|
2019-10-16 17:36:50 -04:00
|
|
|
type LogPublishParams = {
|
2019-10-14 19:17:24 -04:00
|
|
|
uri: string,
|
|
|
|
claim_id: string,
|
|
|
|
outpoint: string,
|
2019-10-11 21:55:54 -04:00
|
|
|
channel_claim_id?: string,
|
|
|
|
};
|
|
|
|
|
2019-04-01 10:30:19 -04:00
|
|
|
let analyticsEnabled: boolean = true;
|
2018-02-16 00:47:52 -08:00
|
|
|
const analytics: Analytics = {
|
2019-04-01 10:30:19 -04:00
|
|
|
pageView: path => {
|
2018-02-23 17:24:00 -07:00
|
|
|
if (analyticsEnabled) {
|
2019-11-07 10:33:00 -05:00
|
|
|
ReactGA.pageview(path, [SECOND_TRACKER_NAME]);
|
2018-02-16 00:47:52 -08:00
|
|
|
}
|
|
|
|
},
|
2019-07-21 22:28:49 -04:00
|
|
|
setUser: userId => {
|
|
|
|
if (analyticsEnabled && userId) {
|
2019-08-14 12:28:13 -04:00
|
|
|
ReactGA.set({
|
|
|
|
userId,
|
|
|
|
});
|
|
|
|
|
|
|
|
// @if TARGET='app'
|
|
|
|
Native.getAppVersionInfo().then(({ localVersion }) => {
|
2019-08-14 23:09:34 -04:00
|
|
|
sendGaEvent('Desktop-Version', localVersion);
|
2019-07-21 22:28:49 -04:00
|
|
|
});
|
2019-08-14 12:28:13 -04:00
|
|
|
// @endif
|
2019-07-21 22:28:49 -04:00
|
|
|
}
|
2018-02-16 01:16:50 -08:00
|
|
|
},
|
2019-04-01 10:30:19 -04:00
|
|
|
toggle: (enabled: boolean): void => {
|
2019-04-14 01:48:11 -04:00
|
|
|
// Always collect analytics on lbry.tv
|
|
|
|
// @if TARGET='app'
|
2018-02-16 01:16:50 -08:00
|
|
|
analyticsEnabled = enabled;
|
2019-04-14 01:48:11 -04:00
|
|
|
// @endif
|
2018-02-23 17:24:00 -07:00
|
|
|
},
|
2019-08-13 23:04:08 -04:00
|
|
|
apiLogView: (uri, outpoint, claimId, timeToStart) => {
|
2019-09-18 14:41:20 -04:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
if (analyticsEnabled && (isProduction || devInternalApis)) {
|
|
|
|
const params: {
|
|
|
|
uri: string,
|
|
|
|
outpoint: string,
|
|
|
|
claim_id: string,
|
|
|
|
time_to_start?: number,
|
|
|
|
} = {
|
|
|
|
uri,
|
|
|
|
outpoint,
|
|
|
|
claim_id: claimId,
|
|
|
|
};
|
2018-08-03 11:54:10 -04:00
|
|
|
|
2019-09-18 14:41:20 -04:00
|
|
|
// lbry.tv streams from AWS so we don't care about the time to start
|
|
|
|
if (timeToStart && !IS_WEB) {
|
|
|
|
params.time_to_start = timeToStart;
|
|
|
|
}
|
2018-08-03 11:54:10 -04:00
|
|
|
|
2019-09-18 14:41:20 -04:00
|
|
|
resolve(Lbryio.call('file', 'view', params));
|
|
|
|
} else {
|
|
|
|
resolve();
|
|
|
|
}
|
|
|
|
});
|
2018-03-07 21:07:42 -08:00
|
|
|
},
|
2019-02-05 13:36:40 -05:00
|
|
|
apiLogSearch: () => {
|
2019-06-19 20:57:51 -04:00
|
|
|
if (analyticsEnabled && isProduction) {
|
2019-02-05 13:36:40 -05:00
|
|
|
Lbryio.call('event', 'search');
|
|
|
|
}
|
|
|
|
},
|
2019-10-16 17:36:50 -04:00
|
|
|
apiLogPublish: (claimResult: ChannelClaim | StreamClaim) => {
|
2019-10-11 21:55:54 -04:00
|
|
|
if (analyticsEnabled && isProduction) {
|
|
|
|
const { permanent_url: uri, claim_id: claimId, txid, nout, signing_channel: signingChannel } = claimResult;
|
|
|
|
let channelClaimId;
|
|
|
|
if (signingChannel) {
|
|
|
|
channelClaimId = signingChannel.claim_id;
|
|
|
|
}
|
|
|
|
const outpoint = `${txid}:${nout}`;
|
2019-10-16 17:36:50 -04:00
|
|
|
const params: LogPublishParams = { uri, claim_id: claimId, outpoint };
|
2019-10-11 21:55:54 -04:00
|
|
|
if (channelClaimId) {
|
|
|
|
params['channel_claim_id'] = channelClaimId;
|
|
|
|
}
|
2019-10-16 17:36:50 -04:00
|
|
|
Lbryio.call('event', 'publish', params);
|
2019-10-11 21:55:54 -04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2019-02-21 17:45:17 -05:00
|
|
|
apiSearchFeedback: (query, vote) => {
|
2019-06-19 20:57:51 -04:00
|
|
|
if (isProduction) {
|
|
|
|
// We don't need to worry about analytics enabled here because users manually click on the button to provide feedback
|
|
|
|
Lbryio.call('feedback', 'search', { query, vote });
|
|
|
|
}
|
2019-02-21 17:45:17 -05:00
|
|
|
},
|
2019-07-21 19:35:59 -04:00
|
|
|
tagFollowEvent: (tag, following, location) => {
|
2019-08-14 23:09:34 -04:00
|
|
|
sendGaEvent(following ? 'Tag-Follow' : 'Tag-Unfollow', tag);
|
2019-07-21 19:35:59 -04:00
|
|
|
},
|
2019-07-08 16:54:58 -04:00
|
|
|
channelBlockEvent: (uri, blocked, location) => {
|
2019-08-14 23:09:34 -04:00
|
|
|
sendGaEvent(blocked ? 'Channel-Hidden' : 'Channel-Unhidden', uri);
|
2019-07-08 16:54:58 -04:00
|
|
|
},
|
2019-08-14 12:28:13 -04:00
|
|
|
emailProvidedEvent: () => {
|
2019-08-14 23:09:34 -04:00
|
|
|
sendGaEvent('Engagement', 'Email-Provided');
|
2019-08-14 12:28:13 -04:00
|
|
|
},
|
|
|
|
emailVerifiedEvent: () => {
|
2019-08-14 23:09:34 -04:00
|
|
|
sendGaEvent('Engagement', 'Email-Verified');
|
2019-08-14 12:28:13 -04:00
|
|
|
},
|
|
|
|
rewardEligibleEvent: () => {
|
2019-08-14 23:09:34 -04:00
|
|
|
sendGaEvent('Engagement', 'Reward-Eligible');
|
2019-08-14 12:28:13 -04:00
|
|
|
},
|
2019-11-04 10:55:02 -05:00
|
|
|
openUrlEvent: (url: string) => {
|
|
|
|
sendGaEvent('Engagement', 'Open-Url', url);
|
|
|
|
},
|
2019-10-02 14:20:25 -04:00
|
|
|
startupEvent: () => {
|
|
|
|
sendGaEvent('Startup', 'Startup');
|
|
|
|
},
|
|
|
|
readyEvent: (timeToReady: number) => {
|
|
|
|
sendGaEvent('Startup', 'App-Ready');
|
|
|
|
sendGaTimingEvent('Startup', 'App-Ready', timeToReady);
|
|
|
|
},
|
2018-02-23 17:24:00 -07:00
|
|
|
};
|
2018-02-16 00:47:52 -08:00
|
|
|
|
2019-11-04 10:55:02 -05:00
|
|
|
function sendGaEvent(category, action, label) {
|
2019-08-14 23:09:34 -04:00
|
|
|
if (analyticsEnabled && isProduction) {
|
2019-11-07 10:33:00 -05:00
|
|
|
ReactGA.event(
|
|
|
|
{
|
|
|
|
category,
|
|
|
|
action,
|
|
|
|
...(label ? { label } : {}),
|
|
|
|
},
|
|
|
|
[SECOND_TRACKER_NAME]
|
|
|
|
);
|
2019-08-14 23:09:34 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-02 14:20:25 -04:00
|
|
|
function sendGaTimingEvent(category: string, action: string, timeInMs: number) {
|
|
|
|
if (analyticsEnabled && isProduction) {
|
2019-11-07 10:33:00 -05:00
|
|
|
ReactGA.timing(
|
|
|
|
{
|
|
|
|
category,
|
|
|
|
variable: action,
|
|
|
|
value: timeInMs,
|
|
|
|
},
|
|
|
|
[SECOND_TRACKER_NAME]
|
|
|
|
);
|
2019-10-02 14:20:25 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-04 13:36:37 -05:00
|
|
|
let gaTrackers = [];
|
2019-04-11 14:22:47 -04:00
|
|
|
|
2019-11-04 13:36:37 -05:00
|
|
|
if (!IS_WEB) {
|
|
|
|
gaTrackers.push({
|
|
|
|
trackingId: DESKTOP_UA_ID,
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
gaTrackers.push({
|
|
|
|
trackingId: LBRY_TV_UA_ID,
|
|
|
|
});
|
|
|
|
|
|
|
|
const { search } = window.location;
|
|
|
|
const urlParams = new URLSearchParams(search);
|
2019-11-06 12:18:15 -05:00
|
|
|
const isPirateBayUser = urlParams.get('utm_source') === 'PB';
|
2019-11-04 13:36:37 -05:00
|
|
|
|
|
|
|
if (!isPirateBayUser) {
|
|
|
|
gaTrackers.push({
|
|
|
|
trackingId: LBRY_TV_MINUS_PIRATE_BAY_UA_ID,
|
2019-11-07 10:33:00 -05:00
|
|
|
gaOptions: {
|
|
|
|
name: SECOND_TRACKER_NAME,
|
|
|
|
},
|
2019-11-04 13:36:37 -05:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2019-05-14 16:35:49 -04:00
|
|
|
|
2019-11-04 13:36:37 -05:00
|
|
|
ReactGA.initialize(gaTrackers, {
|
2019-04-09 17:21:00 -04:00
|
|
|
testMode: process.env.NODE_ENV !== 'production',
|
2019-05-14 16:35:49 -04:00
|
|
|
cookieDomain: 'auto',
|
2019-10-02 14:20:25 -04:00
|
|
|
siteSpeedSampleRate: 100,
|
2019-08-14 23:09:34 -04:00
|
|
|
// un-comment to see events as they are sent to google
|
|
|
|
// debug: true,
|
2019-04-09 17:21:00 -04:00
|
|
|
});
|
2019-04-01 10:30:19 -04:00
|
|
|
|
|
|
|
// Manually call the first page view
|
2019-04-09 17:21:00 -04:00
|
|
|
// React Router doesn't include this on `history.listen`
|
2019-07-09 12:18:06 -04:00
|
|
|
// @if TARGET='web'
|
2019-04-09 17:21:00 -04:00
|
|
|
analytics.pageView(window.location.pathname + window.location.search);
|
2019-07-09 12:18:06 -04:00
|
|
|
// @endif
|
2019-04-01 10:30:19 -04:00
|
|
|
|
2019-05-14 16:35:49 -04:00
|
|
|
// @if TARGET='app'
|
|
|
|
ReactGA.set({ checkProtocolTask: null });
|
|
|
|
ReactGA.set({ location: 'https://lbry.tv' });
|
|
|
|
analytics.pageView(window.location.pathname.split('.html')[1] + window.location.search || '/');
|
|
|
|
// @endif;
|
|
|
|
|
2019-04-01 10:30:19 -04:00
|
|
|
// Listen for url changes and report
|
2019-04-09 17:21:00 -04:00
|
|
|
// This will include search queries
|
|
|
|
history.listen(location => {
|
2019-04-14 23:49:50 -04:00
|
|
|
const { pathname, search } = location;
|
2019-04-14 01:48:11 -04:00
|
|
|
|
2019-04-14 23:49:50 -04:00
|
|
|
const page = `${pathname}${search}`;
|
|
|
|
analytics.pageView(page);
|
2019-04-09 17:21:00 -04:00
|
|
|
});
|
2019-04-01 10:30:19 -04:00
|
|
|
|
2018-02-16 00:47:52 -08:00
|
|
|
export default analytics;
|