UNPKG

@grafana/faro-web-tracing

Version:
42 lines 1.86 kB
import { SpanKind } from '@opentelemetry/api'; import { faro, UserActionState } from '@grafana/faro-web-sdk'; // There is very rare race condition that would result in span being attached to different user action. As shown in the diagram below. // The scenario is the following // // 1. User action (id = 1) starts // 2. Things happen for a given amount of time // 3. User action ends // 4. Span processor starts // 5. A new user action (id = 2) starts // 6. Span processor tries to attach the `faro.user.action` attributes based on the state of the current user action which is id = 2. // // This ultimately depends on the processing delay of the span processor which deems this race condition highly unlikely. export class FaroUserActionSpanProcessor { constructor(processor) { this.processor = processor; } forceFlush() { return this.processor.forceFlush(); } onStart(span, parentContext) { const userAction = faro.api.getActiveUserAction(); if (userAction && (userAction === null || userAction === void 0 ? void 0 : userAction.getState()) === UserActionState.Started && span.kind === SpanKind.CLIENT) { if (!span.attributes['faro.action.user.name']) { span.attributes['faro.action.user.name'] = userAction === null || userAction === void 0 ? void 0 : userAction.name; } if (!span.attributes['faro.action.user.parentId']) { span.attributes['faro.action.user.parentId'] = userAction === null || userAction === void 0 ? void 0 : userAction.parentId; } } this.processor.onStart(span, parentContext); } onEnd(span) { this.processor.onEnd(span); } shutdown() { return this.processor.shutdown(); } } //# sourceMappingURL=faroUserActionSpanProcessor.js.map