-
Notifications
You must be signed in to change notification settings - Fork 214
Expand file tree
/
Copy pathopentelemetry-server.js
More file actions
103 lines (90 loc) · 3.14 KB
/
opentelemetry-server.js
File metadata and controls
103 lines (90 loc) · 3.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
* Copyright (c) 2025, Salesforce, Inc.
* All rights reserved.
* SPDX-License-Identifier: BSD-3-Clause
* For full license text, see the LICENSE file in the repo root or https://opensource.org/licenses/BSD-3-Clause
*/
import {NodeTracerProvider} from '@opentelemetry/sdk-trace-node'
import {SimpleSpanProcessor} from '@opentelemetry/sdk-trace-base'
import {B3Propagator} from '@opentelemetry/propagator-b3'
import {Resource} from '@opentelemetry/resources'
import {propagation} from '@opentelemetry/api'
import logger from '../../utils/logger-instance'
const DEFAULT_SERVICE_NAME = 'pwa-kit-react-sdk'
let provider = null
/**
* Initialize OpenTelemetry tracing for server-side rendering
* @param {Object} options
* @param {string} [options.serviceName]
* @param {string} [options.serviceVersion]
* @param {boolean} [options.enabled]
* @returns {NodeTracerProvider|null}
*/
export const initializeServerTracing = (options = {}) => {
const {
serviceName = process.env.OTEL_SERVICE_NAME || DEFAULT_SERVICE_NAME,
serviceVersion = process.env.npm_package_version,
enabled = process.env.OTEL_SDK_ENABLED === 'true'
} = options
// If tracing is disabled, return null without initializing
if (!enabled) {
return null
}
try {
// Build resource attributes
const resourceAttributes = {
'service.name': serviceName
}
// Add service version if provided
if (serviceVersion) {
resourceAttributes['service.version'] = serviceVersion
}
// Initialize the tracer provider
provider = new NodeTracerProvider({
resource: new Resource(resourceAttributes),
spanProcessor: new SimpleSpanProcessor()
})
// Add B3 propagator
propagation.setGlobalPropagator(new B3Propagator())
provider.register()
return provider
} catch (error) {
// Log errors from OpenTelemetry initialization
logger.error('Failed to initialize OpenTelemetry provider', {
namespace: 'opentelemetry-server.initializeServerTracing',
additionalProperties: {error: error.message}
})
return null
}
}
/**
* Shutdown OpenTelemetry tracing and clean up resources
* @returns {Promise<void>}
*/
export const shutdownServerTracing = async () => {
if (provider) {
try {
await provider.shutdown()
provider = null // Clean up after successful shutdown
} catch (error) {
logger.warn('Failed to shutdown OpenTelemetry provider', {
namespace: 'opentelemetry-server.shutdownServerTracing',
additionalProperties: {error: error.message}
})
}
}
}
/**
* Get the current OpenTelemetry provider instance
* @returns {NodeTracerProvider|null} The current provider or null if not initialized
*/
export const getServerTracingProvider = () => {
return provider
}
/**
* Check if OpenTelemetry tracing is currently initialized
* @returns {boolean} True if tracing is initialized, false otherwise
*/
export const isServerTracingInitialized = () => {
return provider !== null
}