addons/isl-server/src/analytics/serverSideTracker.tsblame
View source
b69ab311/**
b69ab312 * Copyright (c) Meta Platforms, Inc. and affiliates.
b69ab313 *
b69ab314 * This source code is licensed under the MIT license found in the
b69ab315 * LICENSE file in the root directory of this source tree.
b69ab316 */
b69ab317
b69ab318import type {Repository} from '../Repository';
b69ab319import type {Logger} from '../logger';
b69ab3110import type {ServerPlatform} from '../serverPlatform';
b69ab3111import type {ApplicationInfo, FullTrackData, TrackDataWithEventName} from './types';
b69ab3112
b69ab3113import {Internal} from '../Internal';
b69ab3114import {generateAnalyticsInfo} from './environment';
b69ab3115import {Tracker} from './tracker';
b69ab3116
b69ab3117export type ServerSideTracker = Tracker<ServerSideContext>;
b69ab3118
b69ab3119class ServerSideContext {
b69ab3120 constructor(
b69ab3121 public logger: Logger,
b69ab3122 public data: ApplicationInfo,
b69ab3123 ) {}
b69ab3124
b69ab3125 public setRepo(repo: Repository | undefined): void {
b69ab3126 this.data.repo = repo?.codeReviewProvider?.getSummaryName();
b69ab3127 }
b69ab3128}
b69ab3129
b69ab3130const noOp = (_data: FullTrackData, _logger: Logger) => {
b69ab3131 /* In open source builds, analytics tracking is completely disabled/removed. */
b69ab3132};
b69ab3133
b69ab3134/**
b69ab3135 * Creates a Tracker which includes server-side-only cached application data like platform, username, etc,
b69ab3136 * and sends data to the underlying analytics engine outside of ISL.
b69ab3137 * This can not be global since two client connections may have different cached data.
b69ab3138 */
b69ab3139export function makeServerSideTracker(
b69ab3140 logger: Logger,
b69ab3141 platform: ServerPlatform,
b69ab3142 version: string,
b69ab3143 // prettier-ignore
b69ab3144 writeToServer =
b69ab3145 Internal.trackToScribe ??
b69ab3146 noOp,
b69ab3147): ServerSideTracker {
b69ab3148 const analyticsInfo = generateAnalyticsInfo(platform.platformName, version, platform.sessionId);
b69ab3149 logger.info('Setup analytics, session: ', analyticsInfo.sessionId);
b69ab3150 return new Tracker(
b69ab3151 (data: TrackDataWithEventName, context: ServerSideContext) => {
b69ab3152 const {logger} = context;
b69ab3153 // log track event, since tracking events can be used as datapoints when reviewing logs
b69ab3154 logger.log(
b69ab3155 '[track]',
b69ab3156 data.eventName,
b69ab3157 data.errorName ?? '',
b69ab3158 data.extras != null ? JSON.stringify(data.extras) : '',
b69ab3159 );
b69ab3160 writeToServer({...data, ...context.data}, logger);
b69ab3161 },
b69ab3162 new ServerSideContext(logger, analyticsInfo),
b69ab3163 );
b69ab3164}