@multiplayer-app/session-recorder-common 2.0.17-alpha.7 → 2.0.17-alpha.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/package.json +1 -1
  2. package/dist/esm/tsconfig.esm.tsbuildinfo +0 -1
  3. package/dist/esnext/tsconfig.esnext.tsbuildinfo +0 -1
  4. package/docs/img/header-js.png +0 -0
  5. package/eslint.config.js +0 -226
  6. package/src/SessionRecorderIdGenerator.ts +0 -70
  7. package/src/SessionRecorderTraceIdRatioBasedSampler.ts +0 -89
  8. package/src/constants/constants.base.ts +0 -111
  9. package/src/constants/constants.browser.ts +0 -1
  10. package/src/constants/constants.node.ts +0 -5
  11. package/src/exporters/SessionRecorderBrowserTraceExporter.ts +0 -196
  12. package/src/exporters/SessionRecorderGrpcLogsExporter.ts +0 -52
  13. package/src/exporters/SessionRecorderGrpcTraceExporter.ts +0 -50
  14. package/src/exporters/SessionRecorderHttpLogsExporter.ts +0 -58
  15. package/src/exporters/SessionRecorderHttpTraceExporter.ts +0 -68
  16. package/src/exporters/SessionRecorderLogsExporterWrapper.ts +0 -36
  17. package/src/exporters/SessionRecorderTraceExporterWrapper.ts +0 -36
  18. package/src/exporters/index-browser.ts +0 -1
  19. package/src/exporters/index-node.ts +0 -6
  20. package/src/exporters/index.ts +0 -7
  21. package/src/index-browser.ts +0 -6
  22. package/src/index-node.ts +0 -7
  23. package/src/index.ts +0 -7
  24. package/src/instrumentations/SessionRecorderHttpInstrumentationHooksNode.ts +0 -356
  25. package/src/instrumentations/index-node.ts +0 -1
  26. package/src/sdk/capture-exception.ts +0 -102
  27. package/src/sdk/id-generator.ts +0 -17
  28. package/src/sdk/index.ts +0 -8
  29. package/src/sdk/is-gzip.ts +0 -7
  30. package/src/sdk/mask.ts +0 -161
  31. package/src/sdk/save-continuous-deb-session.ts +0 -28
  32. package/src/sdk/schemify.ts +0 -57
  33. package/src/sdk/set-attribute.ts +0 -210
  34. package/src/sdk/set-resource-attributes.ts +0 -9
  35. package/src/type/crash-buffer.ts +0 -64
  36. package/src/type/index.ts +0 -4
  37. package/src/type/session-type.enum.ts +0 -20
  38. package/src/type/session.ts +0 -84
  39. package/src/type/user-type.enum.ts +0 -5
  40. package/tsconfig.base.es5.json +0 -8
  41. package/tsconfig.base.esm.json +0 -7
  42. package/tsconfig.base.esnext.json +0 -10
  43. package/tsconfig.base.json +0 -38
  44. package/tsconfig.esm.json +0 -12
  45. package/tsconfig.esnext.json +0 -12
  46. package/tsconfig.json +0 -25
@@ -1,52 +0,0 @@
1
- import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-proto'
2
- import {
3
- MULTIPLAYER_OTEL_DEFAULT_LOGS_EXPORTER_GRPC_URL,
4
- MULTIPLAYER_TRACE_DEBUG_PREFIX,
5
- MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX,
6
- } from '../constants/constants.base'
7
-
8
- export interface SessionRecorderGrpcLogsExporterConfig {
9
- /** The URL to send logs to. Defaults to MULTIPLAYER_OTEL_DEFAULT_LOGS_EXPORTER_GRPC_URL */
10
- url?: string
11
- /** API key for authentication. Required. */
12
- apiKey: string
13
- /** Timeout for gRPC requests in milliseconds. Defaults to 30000 */
14
- timeoutMillis?: number
15
- }
16
-
17
- /**
18
- * gRPC logs exporter for Session Recorder
19
- * Exports logs via gRPC to Multiplayer's OTLP endpoint
20
- * Only exports logs with trace IDs starting with Multiplayer prefixes
21
- * Note: API key authentication may need to be handled at the gRPC client level
22
- */
23
- export class SessionRecorderGrpcLogsExporter extends OTLPLogExporter {
24
- constructor(config: SessionRecorderGrpcLogsExporterConfig) {
25
- const {
26
- url = MULTIPLAYER_OTEL_DEFAULT_LOGS_EXPORTER_GRPC_URL,
27
- timeoutMillis = 30000,
28
- } = config
29
-
30
- super({
31
- url,
32
- timeoutMillis,
33
- })
34
- }
35
-
36
- override export(logs: any[], resultCallback: (result: { code: number }) => void): void {
37
- // Filter logs to only include those with Multiplayer trace prefixes
38
- const filteredLogs = logs.filter(log => {
39
- const traceId = log.spanContext?.traceId || log.traceId
40
- return traceId && (traceId.startsWith(MULTIPLAYER_TRACE_DEBUG_PREFIX) ||
41
- traceId.startsWith(MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX))
42
- })
43
-
44
- // Only proceed if there are filtered logs
45
- if (filteredLogs.length === 0) {
46
- resultCallback({ code: 0 })
47
- return
48
- }
49
-
50
- super.export(filteredLogs, resultCallback)
51
- }
52
- }
@@ -1,50 +0,0 @@
1
- import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-proto'
2
- import {
3
- MULTIPLAYER_OTEL_DEFAULT_TRACES_EXPORTER_GRPC_URL,
4
- MULTIPLAYER_TRACE_DEBUG_PREFIX,
5
- MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX,
6
- } from '../constants/constants.base'
7
-
8
- export interface SessionRecorderGrpcTraceExporterConfig {
9
- /** The URL to send traces to. Defaults to MULTIPLAYER_OTEL_DEFAULT_TRACES_EXPORTER_GRPC_URL */
10
- url?: string
11
- /** API key for authentication. Required. */
12
- apiKey: string
13
- /** Timeout for gRPC requests in milliseconds. Defaults to 30000 */
14
- timeoutMillis?: number
15
- }
16
-
17
- /**
18
- * gRPC trace exporter for Session Recorder
19
- * Exports traces via gRPC to Multiplayer's OTLP endpoint
20
- * Only exports spans with trace IDs starting with Multiplayer prefixes
21
- * Note: API key authentication may need to be handled at the gRPC client level
22
- */
23
- export class SessionRecorderGrpcTraceExporter extends OTLPTraceExporter {
24
- constructor(config: SessionRecorderGrpcTraceExporterConfig) {
25
- const {
26
- url = MULTIPLAYER_OTEL_DEFAULT_TRACES_EXPORTER_GRPC_URL,
27
- timeoutMillis = 30000,
28
- } = config
29
-
30
- super({
31
- url,
32
- timeoutMillis,
33
- })
34
- }
35
-
36
- override export(spans: any[], resultCallback: (result: { code: number }) => void): void {
37
- const filteredSpans = spans.filter(span => {
38
- const traceId = span.spanContext().traceId
39
- return traceId.startsWith(MULTIPLAYER_TRACE_DEBUG_PREFIX) ||
40
- traceId.startsWith(MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX)
41
- })
42
-
43
- if (filteredSpans.length === 0) {
44
- resultCallback({ code: 0 })
45
- return
46
- }
47
-
48
- super.export(filteredSpans, resultCallback)
49
- }
50
- }
@@ -1,58 +0,0 @@
1
- import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http'
2
- import {
3
- MULTIPLAYER_OTEL_DEFAULT_LOGS_EXPORTER_HTTP_URL,
4
- MULTIPLAYER_TRACE_DEBUG_PREFIX,
5
- MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX,
6
- } from '../constants/constants.base'
7
-
8
- export interface SessionRecorderHttpLogsExporterConfig {
9
- /** The URL to send logs to. Defaults to MULTIPLAYER_OTEL_DEFAULT_LOGS_EXPORTER_HTTP_URL */
10
- url?: string
11
- /** API key for authentication. Required. */
12
- apiKey: string
13
- /** Timeout for HTTP requests in milliseconds. Defaults to 30000 */
14
- timeoutMillis?: number
15
- /** Whether to keep the connection alive. Defaults to true */
16
- keepAlive?: boolean
17
- /** Maximum number of concurrent requests. Defaults to 20 */
18
- concurrencyLimit?: number
19
- }
20
-
21
- export class SessionRecorderHttpLogsExporter extends OTLPLogExporter {
22
- constructor(config: SessionRecorderHttpLogsExporterConfig) {
23
- const {
24
- url = MULTIPLAYER_OTEL_DEFAULT_LOGS_EXPORTER_HTTP_URL,
25
- apiKey,
26
- timeoutMillis = 30000,
27
- keepAlive = true,
28
- concurrencyLimit = 20,
29
- } = config
30
-
31
- super({
32
- url,
33
- headers: {
34
- 'Content-Type': 'application/json',
35
- 'User-Agent': '@multiplayer-app/session-recorder-common/1.0.0',
36
- 'authorization': apiKey,
37
- },
38
- timeoutMillis,
39
- keepAlive,
40
- concurrencyLimit,
41
- })
42
- }
43
-
44
- override export(logs: any[], resultCallback: (result: { code: number }) => void): void {
45
- const filteredLogs = logs.filter(log => {
46
- const traceId = log.spanContext?.traceId || log.traceId
47
- return traceId && (traceId.startsWith(MULTIPLAYER_TRACE_DEBUG_PREFIX) ||
48
- traceId.startsWith(MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX))
49
- })
50
-
51
- if (filteredLogs.length === 0) {
52
- resultCallback({ code: 0 })
53
- return
54
- }
55
-
56
- super.export(filteredLogs, resultCallback)
57
- }
58
- }
@@ -1,68 +0,0 @@
1
- import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http'
2
- import {
3
- MULTIPLAYER_OTEL_DEFAULT_TRACES_EXPORTER_HTTP_URL,
4
- MULTIPLAYER_TRACE_DEBUG_PREFIX,
5
- MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX,
6
- } from '../constants/constants.base'
7
-
8
- export interface SessionRecorderHttpTraceExporterConfig {
9
- /** The URL to send traces to. Defaults to MULTIPLAYER_OTEL_DEFAULT_TRACES_EXPORTER_HTTP_URL */
10
- url?: string
11
- /** API key for authentication. Required. */
12
- apiKey: string
13
- /** Timeout for HTTP requests in milliseconds. Defaults to 30000 */
14
- timeoutMillis?: number
15
- /** Whether to keep the connection alive. Defaults to true */
16
- keepAlive?: boolean
17
- /** Maximum number of concurrent requests. Defaults to 20 */
18
- concurrencyLimit?: number
19
- }
20
-
21
- /**
22
- * HTTP trace exporter for Session Recorder
23
- * Exports traces via HTTP to Multiplayer's OTLP endpoint
24
- * Only exports spans with trace IDs starting with Multiplayer prefixes
25
- */
26
- export class SessionRecorderHttpTraceExporter extends OTLPTraceExporter {
27
- constructor(config: SessionRecorderHttpTraceExporterConfig) {
28
- const {
29
- url = MULTIPLAYER_OTEL_DEFAULT_TRACES_EXPORTER_HTTP_URL,
30
- apiKey,
31
- timeoutMillis = 30000,
32
- keepAlive = true,
33
- concurrencyLimit = 20,
34
- } = config
35
-
36
- super({
37
- url,
38
- headers: {
39
- 'Content-Type': 'application/json',
40
- 'User-Agent': '@multiplayer-app/session-recorder-common/1.0.0',
41
- ...apiKey
42
- ? { 'Authorization': apiKey }
43
- : {},
44
- },
45
- timeoutMillis,
46
- keepAlive,
47
- concurrencyLimit,
48
- })
49
- }
50
-
51
- override export(
52
- spans: any[],
53
- resultCallback: (result: { code: number }) => void,
54
- ): void {
55
- const filteredSpans = spans.filter(span => {
56
- const traceId = span.spanContext().traceId
57
- return traceId.startsWith(MULTIPLAYER_TRACE_DEBUG_PREFIX) ||
58
- traceId.startsWith(MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX)
59
- })
60
-
61
- if (filteredSpans.length === 0) {
62
- resultCallback({ code: 0 })
63
- return
64
- }
65
-
66
- super.export(filteredSpans, resultCallback)
67
- }
68
- }
@@ -1,36 +0,0 @@
1
- import { SdkLogRecord, LogRecordExporter } from '@opentelemetry/sdk-logs'
2
- import {
3
- MULTIPLAYER_TRACE_DEBUG_PREFIX,
4
- MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX,
5
- } from '../constants/constants.base'
6
-
7
- export interface SessionRecorderLogsExporterWrapperConfig {
8
- exporter: LogRecordExporter
9
- }
10
-
11
- export class SessionRecorderLogsExporterWrapper implements LogRecordExporter {
12
- private readonly exporter: LogRecordExporter
13
-
14
- constructor(config: SessionRecorderLogsExporterWrapperConfig) {
15
- this.exporter = config.exporter
16
- }
17
-
18
- export(logs: SdkLogRecord[], resultCallback: (result: { code: number }) => void): void {
19
- const filteredLogs = logs.filter(log => {
20
- const traceId = log.spanContext?.traceId
21
- return !traceId || (!traceId.startsWith(MULTIPLAYER_TRACE_DEBUG_PREFIX) &&
22
- !traceId.startsWith(MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX))
23
- })
24
-
25
- if (filteredLogs.length === 0) {
26
- resultCallback({ code: 0 })
27
- return
28
- }
29
-
30
- this.exporter.export(filteredLogs, resultCallback)
31
- }
32
-
33
- shutdown(): Promise<void> {
34
- return this.exporter.shutdown()
35
- }
36
- }
@@ -1,36 +0,0 @@
1
- import { ReadableSpan, SpanExporter } from '@opentelemetry/sdk-trace-base'
2
- import {
3
- MULTIPLAYER_TRACE_DEBUG_PREFIX,
4
- MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX,
5
- } from '../constants/constants.base'
6
-
7
- export interface SessionRecorderTraceExporterWrapperConfig {
8
- exporter: SpanExporter
9
- }
10
-
11
- export class SessionRecorderTraceExporterWrapper implements SpanExporter {
12
- private readonly exporter: SpanExporter
13
-
14
- constructor(config: SessionRecorderTraceExporterWrapperConfig) {
15
- this.exporter = config.exporter
16
- }
17
-
18
- export(spans: ReadableSpan[], resultCallback: (result: { code: number }) => void): void {
19
- const filteredSpans = spans.filter(span => {
20
- const traceId = span.spanContext().traceId
21
- return !traceId.startsWith(MULTIPLAYER_TRACE_DEBUG_PREFIX) &&
22
- !traceId.startsWith(MULTIPLAYER_TRACE_CONTINUOUS_DEBUG_PREFIX)
23
- })
24
-
25
- if (filteredSpans.length === 0) {
26
- resultCallback({ code: 0 })
27
- return
28
- }
29
-
30
- this.exporter.export(filteredSpans, resultCallback)
31
- }
32
-
33
- shutdown(): Promise<void> {
34
- return this.exporter.shutdown()
35
- }
36
- }
@@ -1 +0,0 @@
1
- export * from './SessionRecorderBrowserTraceExporter'
@@ -1,6 +0,0 @@
1
- export * from './SessionRecorderHttpTraceExporter'
2
- export * from './SessionRecorderHttpLogsExporter'
3
- export * from './SessionRecorderGrpcTraceExporter'
4
- export * from './SessionRecorderGrpcLogsExporter'
5
- export * from './SessionRecorderTraceExporterWrapper'
6
- export * from './SessionRecorderLogsExporterWrapper'
@@ -1,7 +0,0 @@
1
- export * from './SessionRecorderHttpTraceExporter'
2
- export * from './SessionRecorderHttpLogsExporter'
3
- export * from './SessionRecorderGrpcTraceExporter'
4
- export * from './SessionRecorderGrpcLogsExporter'
5
- export * from './SessionRecorderBrowserTraceExporter'
6
- export * from './SessionRecorderTraceExporterWrapper'
7
- export * from './SessionRecorderLogsExporterWrapper'
@@ -1,6 +0,0 @@
1
- export * from './constants/constants.browser'
2
- export { SessionRecorderIdGenerator } from './SessionRecorderIdGenerator'
3
- export { SessionRecorderTraceIdRatioBasedSampler } from './SessionRecorderTraceIdRatioBasedSampler'
4
- export * as SessionRecorderSdk from './sdk'
5
- export * from './type'
6
- export * from './exporters/index-browser'
package/src/index-node.ts DELETED
@@ -1,7 +0,0 @@
1
- export * from './constants/constants.node'
2
- export { SessionRecorderHttpInstrumentationHooksNode } from './instrumentations/SessionRecorderHttpInstrumentationHooksNode'
3
- export { SessionRecorderIdGenerator } from './SessionRecorderIdGenerator'
4
- export { SessionRecorderTraceIdRatioBasedSampler } from './SessionRecorderTraceIdRatioBasedSampler'
5
- export * as SessionRecorderSdk from './sdk'
6
- export * from './type'
7
- export * from './exporters/index-node'
package/src/index.ts DELETED
@@ -1,7 +0,0 @@
1
- export * from './constants/constants.node'
2
- export { SessionRecorderIdGenerator } from './SessionRecorderIdGenerator'
3
- export { SessionRecorderTraceIdRatioBasedSampler } from './SessionRecorderTraceIdRatioBasedSampler'
4
- export * as SessionRecorderSdk from './sdk'
5
- export * from './type'
6
- export * from './exporters'
7
- export * from './instrumentations/index-node'