forked from open-telemetry/opentelemetry-js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstrumentation.ts
127 lines (110 loc) · 3.3 KB
/
instrumentation.ts
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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/*
* Copyright The OpenTelemetry Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import {
diag,
DiagLogger,
trace,
Tracer,
TracerProvider,
} from '@opentelemetry/api';
import { Meter, MeterProvider, metrics } from '@opentelemetry/api-metrics';
import * as shimmer from 'shimmer';
import { InstrumentationModuleDefinition } from './platform/node';
import * as types from './types';
/**
* Base abstract internal class for instrumenting node and web plugins
*/
export abstract class InstrumentationAbstract<T = any>
implements types.Instrumentation {
protected _config: types.InstrumentationConfig;
private _tracer: Tracer;
private _meter: Meter;
protected _diag: DiagLogger;
constructor(
public readonly instrumentationName: string,
public readonly instrumentationVersion: string,
config: types.InstrumentationConfig = {}
) {
this._config = {
enabled: true,
...config,
};
this._diag = diag.createComponentLogger({
namespace: instrumentationName,
});
this._tracer = trace.getTracer(instrumentationName, instrumentationVersion);
this._meter = metrics.getMeter(instrumentationName, instrumentationVersion);
}
/* Api to wrap instrumented method */
protected _wrap = shimmer.wrap;
/* Api to unwrap instrumented methods */
protected _unwrap = shimmer.unwrap;
/* Api to mass wrap instrumented method */
protected _massWrap = shimmer.massWrap;
/* Api to mass unwrap instrumented methods */
protected _massUnwrap = shimmer.massUnwrap;
/* Returns meter */
protected get meter(): Meter {
return this._meter;
}
/**
* Sets MeterProvider to this plugin
* @param meterProvider
*/
public setMeterProvider(meterProvider: MeterProvider) {
this._meter = meterProvider.getMeter(
this.instrumentationName,
this.instrumentationVersion
);
}
/* Returns InstrumentationConfig */
public getConfig() {
return this._config;
}
/**
* Sets InstrumentationConfig to this plugin
* @param InstrumentationConfig
*/
public setConfig(config: types.InstrumentationConfig = {}) {
this._config = Object.assign({}, config);
}
/**
* Sets TraceProvider to this plugin
* @param tracerProvider
*/
public setTracerProvider(tracerProvider: TracerProvider) {
this._tracer = tracerProvider.getTracer(
this.instrumentationName,
this.instrumentationVersion
);
}
/* Returns tracer */
protected get tracer(): Tracer {
return this._tracer;
}
/* Disable plugin */
public abstract enable(): void;
/* Enable plugin */
public abstract disable(): void;
/**
* Init method in which plugin should define _modules and patches for
* methods
*/
protected abstract init():
| InstrumentationModuleDefinition<T>
| InstrumentationModuleDefinition<T>[]
| void;
}