@interopio/otel 0.0.11 → 0.0.13
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.
- package/README.md +9 -1
- package/dist/builder.d.ts +19 -0
- package/dist/builder.js +75 -0
- package/dist/builder.js.map +1 -0
- package/dist/container.d.ts +14 -0
- package/dist/container.js +51 -0
- package/dist/container.js.map +1 -0
- package/dist/index.d.ts +13 -0
- package/dist/index.js +27 -0
- package/dist/index.js.map +1 -0
- package/dist/logger/log4jsWrapper.d.ts +13 -0
- package/dist/logger/log4jsWrapper.js +54 -0
- package/dist/logger/log4jsWrapper.js.map +1 -0
- package/dist/logger/null.d.ts +9 -0
- package/dist/logger/null.js +25 -0
- package/dist/logger/null.js.map +1 -0
- package/dist/logger/types.d.ts +17 -0
- package/dist/logger/types.js +3 -0
- package/dist/logger/types.js.map +1 -0
- package/dist/logs/types.d.ts +6 -0
- package/dist/logs/types.js +3 -0
- package/dist/logs/types.js.map +1 -0
- package/dist/metrics/builder.d.ts +20 -0
- package/dist/metrics/builder.js +63 -0
- package/dist/metrics/builder.js.map +1 -0
- package/dist/metrics/dependencies/builder.d.ts +29 -0
- package/dist/metrics/dependencies/builder.js +87 -0
- package/dist/metrics/dependencies/builder.js.map +1 -0
- package/dist/metrics/dependencies/types.d.ts +91 -0
- package/dist/metrics/dependencies/types.js +3 -0
- package/dist/metrics/dependencies/types.js.map +1 -0
- package/dist/metrics/factory/builder.d.ts +31 -0
- package/dist/metrics/factory/builder.js +198 -0
- package/dist/metrics/factory/builder.js.map +1 -0
- package/dist/metrics/factory/factory.d.ts +10 -0
- package/dist/metrics/factory/factory.js +33 -0
- package/dist/metrics/factory/factory.js.map +1 -0
- package/dist/metrics/factory/types.d.ts +5 -0
- package/dist/metrics/factory/types.js +3 -0
- package/dist/metrics/factory/types.js.map +1 -0
- package/dist/metrics/manager.d.ts +23 -0
- package/dist/metrics/manager.js +120 -0
- package/dist/metrics/manager.js.map +1 -0
- package/dist/metrics/meter/lazyProvider.d.ts +11 -0
- package/dist/metrics/meter/lazyProvider.js +23 -0
- package/dist/metrics/meter/lazyProvider.js.map +1 -0
- package/dist/metrics/meter/providerFactory.d.ts +6 -0
- package/dist/metrics/meter/providerFactory.js +34 -0
- package/dist/metrics/meter/providerFactory.js.map +1 -0
- package/dist/metrics/meter/types.d.ts +14 -0
- package/dist/metrics/meter/types.js +3 -0
- package/dist/metrics/meter/types.js.map +1 -0
- package/dist/metrics/metrics/application/count.d.ts +21 -0
- package/dist/metrics/metrics/application/count.js +62 -0
- package/dist/metrics/metrics/application/count.js.map +1 -0
- package/dist/metrics/metrics/application/cpu.d.ts +12 -0
- package/dist/metrics/metrics/application/cpu.js +40 -0
- package/dist/metrics/metrics/application/cpu.js.map +1 -0
- package/dist/metrics/metrics/application/crash.d.ts +18 -0
- package/dist/metrics/metrics/application/crash.js +46 -0
- package/dist/metrics/metrics/application/crash.js.map +1 -0
- package/dist/metrics/metrics/application/duration.d.ts +7 -0
- package/dist/metrics/metrics/application/duration.js +19 -0
- package/dist/metrics/metrics/application/duration.js.map +1 -0
- package/dist/metrics/metrics/application/durationBase.d.ts +22 -0
- package/dist/metrics/metrics/application/durationBase.js +97 -0
- package/dist/metrics/metrics/application/durationBase.js.map +1 -0
- package/dist/metrics/metrics/application/error.d.ts +18 -0
- package/dist/metrics/metrics/application/error.js +46 -0
- package/dist/metrics/metrics/application/error.js.map +1 -0
- package/dist/metrics/metrics/application/memory.d.ts +13 -0
- package/dist/metrics/metrics/application/memory.js +41 -0
- package/dist/metrics/metrics/application/memory.js.map +1 -0
- package/dist/metrics/metrics/application/started.d.ts +18 -0
- package/dist/metrics/metrics/application/started.js +46 -0
- package/dist/metrics/metrics/application/started.js.map +1 -0
- package/dist/metrics/metrics/application/startup.d.ts +18 -0
- package/dist/metrics/metrics/application/startup.js +46 -0
- package/dist/metrics/metrics/application/startup.js.map +1 -0
- package/dist/metrics/metrics/application/stopped.d.ts +18 -0
- package/dist/metrics/metrics/application/stopped.js +46 -0
- package/dist/metrics/metrics/application/stopped.js.map +1 -0
- package/dist/metrics/metrics/base/base.d.ts +17 -0
- package/dist/metrics/metrics/base/base.js +71 -0
- package/dist/metrics/metrics/base/base.js.map +1 -0
- package/dist/metrics/metrics/base/gauge.d.ts +18 -0
- package/dist/metrics/metrics/base/gauge.js +61 -0
- package/dist/metrics/metrics/base/gauge.js.map +1 -0
- package/dist/metrics/metrics/base/null.d.ts +10 -0
- package/dist/metrics/metrics/base/null.js +22 -0
- package/dist/metrics/metrics/base/null.js.map +1 -0
- package/dist/metrics/metrics/base/observable.d.ts +20 -0
- package/dist/metrics/metrics/base/observable.js +69 -0
- package/dist/metrics/metrics/base/observable.js.map +1 -0
- package/dist/metrics/metrics/base/types.d.ts +31 -0
- package/dist/metrics/metrics/base/types.js +3 -0
- package/dist/metrics/metrics/base/types.js.map +1 -0
- package/dist/metrics/metrics/layout/startup.d.ts +18 -0
- package/dist/metrics/metrics/layout/startup.js +46 -0
- package/dist/metrics/metrics/layout/startup.js.map +1 -0
- package/dist/metrics/metrics/platform/error.d.ts +18 -0
- package/dist/metrics/metrics/platform/error.js +46 -0
- package/dist/metrics/metrics/platform/error.js.map +1 -0
- package/dist/metrics/metrics/platform/startup.d.ts +18 -0
- package/dist/metrics/metrics/platform/startup.js +58 -0
- package/dist/metrics/metrics/platform/startup.js.map +1 -0
- package/dist/metrics/metrics/system/cpu.d.ts +14 -0
- package/dist/metrics/metrics/system/cpu.js +46 -0
- package/dist/metrics/metrics/system/cpu.js.map +1 -0
- package/dist/metrics/metrics/system/memory.d.ts +14 -0
- package/dist/metrics/metrics/system/memory.js +47 -0
- package/dist/metrics/metrics/system/memory.js.map +1 -0
- package/dist/metrics/metrics/workspace/count.d.ts +21 -0
- package/dist/metrics/metrics/workspace/count.js +62 -0
- package/dist/metrics/metrics/workspace/count.js.map +1 -0
- package/dist/metrics/metrics/workspace/startup.d.ts +9 -0
- package/dist/metrics/metrics/workspace/startup.js +12 -0
- package/dist/metrics/metrics/workspace/startup.js.map +1 -0
- package/dist/metrics/metrics/workspace/stopped.d.ts +18 -0
- package/dist/metrics/metrics/workspace/stopped.js +46 -0
- package/dist/metrics/metrics/workspace/stopped.js.map +1 -0
- package/dist/metrics/settings/builder.d.ts +24 -0
- package/dist/metrics/settings/builder.js +115 -0
- package/dist/metrics/settings/builder.js.map +1 -0
- package/dist/metrics/settings/default.d.ts +30 -0
- package/dist/metrics/settings/default.js +121 -0
- package/dist/metrics/settings/default.js.map +1 -0
- package/dist/metrics/settings/types.d.ts +14 -0
- package/dist/metrics/settings/types.js +3 -0
- package/dist/metrics/settings/types.js.map +1 -0
- package/dist/metrics/types.d.ts +16 -0
- package/dist/metrics/types.js +3 -0
- package/dist/metrics/types.js.map +1 -0
- package/dist/metrics/utils/nullMetricsManager.d.ts +6 -0
- package/dist/metrics/utils/nullMetricsManager.js +11 -0
- package/dist/metrics/utils/nullMetricsManager.js.map +1 -0
- package/dist/metrics/utils/nullPerfProvider.d.ts +7 -0
- package/dist/metrics/utils/nullPerfProvider.js +19 -0
- package/dist/metrics/utils/nullPerfProvider.js.map +1 -0
- package/dist/traces/builder.d.ts +15 -0
- package/dist/traces/builder.js +39 -0
- package/dist/traces/builder.js.map +1 -0
- package/dist/traces/ioInsightsSampler.d.ts +16 -0
- package/dist/traces/ioInsightsSampler.js +123 -0
- package/dist/traces/ioInsightsSampler.js.map +1 -0
- package/dist/traces/manager.d.ts +19 -0
- package/dist/traces/manager.js +151 -0
- package/dist/traces/manager.js.map +1 -0
- package/dist/traces/nullTracesManager.d.ts +6 -0
- package/dist/traces/nullTracesManager.js +23 -0
- package/dist/traces/nullTracesManager.js.map +1 -0
- package/dist/traces/tracingState.d.ts +28 -0
- package/dist/traces/tracingState.js +103 -0
- package/dist/traces/tracingState.js.map +1 -0
- package/dist/traces/types.d.ts +96 -0
- package/dist/traces/types.js +14 -0
- package/dist/traces/types.js.map +1 -0
- package/dist/traces/utils/index.d.ts +13 -0
- package/dist/traces/utils/index.js +119 -0
- package/dist/traces/utils/index.js.map +1 -0
- package/dist/types.d.ts +20 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/nullManager.d.ts +7 -0
- package/dist/utils/nullManager.js +21 -0
- package/dist/utils/nullManager.js.map +1 -0
- package/dist/validation/builder.d.ts +4 -0
- package/dist/validation/builder.js +12 -0
- package/dist/validation/builder.js.map +1 -0
- package/dist/validation/container.d.ts +4 -0
- package/dist/validation/container.js +14 -0
- package/dist/validation/container.js.map +1 -0
- package/dist/validation/metrics/application/count.d.ts +7 -0
- package/dist/validation/metrics/application/count.js +21 -0
- package/dist/validation/metrics/application/count.js.map +1 -0
- package/dist/validation/metrics/application/duration.d.ts +6 -0
- package/dist/validation/metrics/application/duration.js +17 -0
- package/dist/validation/metrics/application/duration.js.map +1 -0
- package/dist/validation/metrics/application/error.d.ts +6 -0
- package/dist/validation/metrics/application/error.js +16 -0
- package/dist/validation/metrics/application/error.js.map +1 -0
- package/dist/validation/metrics/application/started.d.ts +6 -0
- package/dist/validation/metrics/application/started.js +16 -0
- package/dist/validation/metrics/application/started.js.map +1 -0
- package/dist/validation/metrics/application/startupHistogram.d.ts +6 -0
- package/dist/validation/metrics/application/startupHistogram.js +18 -0
- package/dist/validation/metrics/application/startupHistogram.js.map +1 -0
- package/dist/validation/metrics/application/stopped.d.ts +6 -0
- package/dist/validation/metrics/application/stopped.js +16 -0
- package/dist/validation/metrics/application/stopped.js.map +1 -0
- package/dist/validation/metrics/base/base.d.ts +5 -0
- package/dist/validation/metrics/base/base.js +22 -0
- package/dist/validation/metrics/base/base.js.map +1 -0
- package/dist/validation/metrics/base/gauge.d.ts +6 -0
- package/dist/validation/metrics/base/gauge.js +12 -0
- package/dist/validation/metrics/base/gauge.js.map +1 -0
- package/dist/validation/metrics/builder.d.ts +4 -0
- package/dist/validation/metrics/builder.js +13 -0
- package/dist/validation/metrics/builder.js.map +1 -0
- package/dist/validation/metrics/factory.d.ts +4 -0
- package/dist/validation/metrics/factory.js +13 -0
- package/dist/validation/metrics/factory.js.map +1 -0
- package/dist/validation/metrics/factoryBuilder.d.ts +5 -0
- package/dist/validation/metrics/factoryBuilder.js +23 -0
- package/dist/validation/metrics/factoryBuilder.js.map +1 -0
- package/dist/validation/metrics/layout/startupHistogram.d.ts +6 -0
- package/dist/validation/metrics/layout/startupHistogram.js +18 -0
- package/dist/validation/metrics/layout/startupHistogram.js.map +1 -0
- package/dist/validation/metrics/manager.d.ts +4 -0
- package/dist/validation/metrics/manager.js +15 -0
- package/dist/validation/metrics/manager.js.map +1 -0
- package/dist/validation/metrics/meterFactory.d.ts +4 -0
- package/dist/validation/metrics/meterFactory.js +16 -0
- package/dist/validation/metrics/meterFactory.js.map +1 -0
- package/dist/validation/metrics/perf.d.ts +8 -0
- package/dist/validation/metrics/perf.js +41 -0
- package/dist/validation/metrics/perf.js.map +1 -0
- package/dist/validation/metrics/platform/crash.d.ts +6 -0
- package/dist/validation/metrics/platform/crash.js +16 -0
- package/dist/validation/metrics/platform/crash.js.map +1 -0
- package/dist/validation/metrics/platform/error.d.ts +6 -0
- package/dist/validation/metrics/platform/error.js +15 -0
- package/dist/validation/metrics/platform/error.js.map +1 -0
- package/dist/validation/metrics/platform/startup.d.ts +6 -0
- package/dist/validation/metrics/platform/startup.js +18 -0
- package/dist/validation/metrics/platform/startup.js.map +1 -0
- package/dist/validation/metrics/settingsBuilder.d.ts +4 -0
- package/dist/validation/metrics/settingsBuilder.js +22 -0
- package/dist/validation/metrics/settingsBuilder.js.map +1 -0
- package/dist/validation/metrics/workspace/count.d.ts +7 -0
- package/dist/validation/metrics/workspace/count.js +21 -0
- package/dist/validation/metrics/workspace/count.js.map +1 -0
- package/dist/validation/metrics/workspace/stopped.d.ts +6 -0
- package/dist/validation/metrics/workspace/stopped.js +16 -0
- package/dist/validation/metrics/workspace/stopped.js.map +1 -0
- package/dist/validation/traces/attributeData.d.ts +3 -0
- package/dist/validation/traces/attributeData.js +18 -0
- package/dist/validation/traces/attributeData.js.map +1 -0
- package/dist/validation/traces/filter.d.ts +4 -0
- package/dist/validation/traces/filter.js +12 -0
- package/dist/validation/traces/filter.js.map +1 -0
- package/dist/validation/traces/manager.d.ts +4 -0
- package/dist/validation/traces/manager.js +12 -0
- package/dist/validation/traces/manager.js.map +1 -0
- package/dist/validation/traces/withSpan.d.ts +4 -0
- package/dist/validation/traces/withSpan.js +18 -0
- package/dist/validation/traces/withSpan.js.map +1 -0
- package/dist/validation/validator.d.ts +4 -0
- package/dist/validation/validator.js +15 -0
- package/dist/validation/validator.js.map +1 -0
- package/package.json +12 -4
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.NullTracesManager = void 0;
|
|
13
|
+
const nullManager_1 = require("../utils/nullManager");
|
|
14
|
+
class NullTracesManager extends nullManager_1.NullManager {
|
|
15
|
+
extractTracingPropagationInfo() {
|
|
16
|
+
return undefined;
|
|
17
|
+
}
|
|
18
|
+
withSpan() {
|
|
19
|
+
return __awaiter(this, void 0, void 0, function* () { });
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
exports.NullTracesManager = NullTracesManager;
|
|
23
|
+
//# sourceMappingURL=nullTracesManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nullTracesManager.js","sourceRoot":"","sources":["../../src/traces/nullTracesManager.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,sDAAmD;AAGnD,MAAa,iBAAkB,SAAQ,yBAA2B;IAChE,6BAA6B;QAC3B,OAAO,SAAS,CAAC;IACnB,CAAC;IACK,QAAQ;8DAAmB,CAAC;KAAA;CACnC;AALD,8CAKC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { Logger } from "../logger/types";
|
|
3
|
+
import { AttributeData, PropagationInfo, PropagationInfoCarrier, TracingState as ITracingState, Verbosity } from "./types";
|
|
4
|
+
import { Span, SpanContext, Exception, TimeInput, Attributes, SpanStatus } from "@opentelemetry/api";
|
|
5
|
+
export declare class TracingState implements ITracingState {
|
|
6
|
+
source: string;
|
|
7
|
+
level: keyof typeof Verbosity;
|
|
8
|
+
span: Span;
|
|
9
|
+
private logger;
|
|
10
|
+
private version;
|
|
11
|
+
constructor(source: string, level: keyof typeof Verbosity, span: Span, logger: Logger, version: string, spanTimeoutMs: number | undefined);
|
|
12
|
+
endSpan(timedOut?: boolean): Promise<void>;
|
|
13
|
+
get enabled(): boolean;
|
|
14
|
+
private hasEnded;
|
|
15
|
+
private _timeoutId;
|
|
16
|
+
get timeoutId(): NodeJS.Timeout | undefined;
|
|
17
|
+
private spanContextField;
|
|
18
|
+
get id(): string;
|
|
19
|
+
setStatus(status: SpanStatus): Span;
|
|
20
|
+
addEvent(name: string, attributesOrStartTime?: Attributes | TimeInput, startTime?: TimeInput): Span;
|
|
21
|
+
recordException(exception: Exception, time?: TimeInput): void;
|
|
22
|
+
isRecording(): boolean;
|
|
23
|
+
updateName(name: string): Span;
|
|
24
|
+
spanContext(): SpanContext;
|
|
25
|
+
addData(level: Verbosity | keyof typeof Verbosity, data: AttributeData): Promise<void>;
|
|
26
|
+
getPropagationInfo(): PropagationInfo;
|
|
27
|
+
injectPropagationInfo(carrier: PropagationInfoCarrier): void;
|
|
28
|
+
}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TracingState = void 0;
|
|
4
|
+
const types_1 = require("./types");
|
|
5
|
+
const api_1 = require("@opentelemetry/api");
|
|
6
|
+
const utils_1 = require("./utils");
|
|
7
|
+
class TracingState {
|
|
8
|
+
constructor(source, level, span, logger, version, spanTimeoutMs) {
|
|
9
|
+
this.source = source;
|
|
10
|
+
this.level = level;
|
|
11
|
+
this.span = span;
|
|
12
|
+
this.logger = logger;
|
|
13
|
+
this.version = version;
|
|
14
|
+
this.hasEnded = false;
|
|
15
|
+
this.spanContextField = span.spanContext();
|
|
16
|
+
if (spanTimeoutMs && spanTimeoutMs >= 0) {
|
|
17
|
+
this._timeoutId = setTimeout(() => {
|
|
18
|
+
this.endSpan(true);
|
|
19
|
+
}, spanTimeoutMs);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
endSpan(timedOut) {
|
|
23
|
+
var _a, _b;
|
|
24
|
+
if (this.hasEnded) {
|
|
25
|
+
(_a = this.logger) === null || _a === void 0 ? void 0 : _a.debug(`Span ended more than once: ${this.source}`);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
try {
|
|
29
|
+
this.hasEnded = true;
|
|
30
|
+
if (timedOut) {
|
|
31
|
+
(_b = this.logger) === null || _b === void 0 ? void 0 : _b.debug(`Span timed out and was automatically ended: ${this.source}`);
|
|
32
|
+
this.span.setStatus({
|
|
33
|
+
code: api_1.SpanStatusCode.ERROR,
|
|
34
|
+
message: "Span timed out",
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
clearTimeout(this.timeoutId);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
finally {
|
|
42
|
+
this.span.end();
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return Promise.resolve();
|
|
46
|
+
}
|
|
47
|
+
get enabled() {
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
get timeoutId() {
|
|
51
|
+
return this._timeoutId;
|
|
52
|
+
}
|
|
53
|
+
get id() {
|
|
54
|
+
return this.spanContextField.spanId;
|
|
55
|
+
}
|
|
56
|
+
setStatus(status) {
|
|
57
|
+
return this.span.setStatus.call(this.span, status);
|
|
58
|
+
}
|
|
59
|
+
addEvent(name, attributesOrStartTime, startTime) {
|
|
60
|
+
return this.span.addEvent.call(this.span, name, attributesOrStartTime, startTime);
|
|
61
|
+
}
|
|
62
|
+
recordException(exception, time) {
|
|
63
|
+
this.span.recordException.call(this.span, exception, time);
|
|
64
|
+
}
|
|
65
|
+
isRecording() {
|
|
66
|
+
return this.span.isRecording.call(this.span);
|
|
67
|
+
}
|
|
68
|
+
updateName(name) {
|
|
69
|
+
return this.span.updateName.call(this.span, name);
|
|
70
|
+
}
|
|
71
|
+
spanContext() {
|
|
72
|
+
return this.span.spanContext.call(this.span);
|
|
73
|
+
}
|
|
74
|
+
addData(level, data) {
|
|
75
|
+
if (typeof level === "string") {
|
|
76
|
+
level = types_1.Verbosity[level];
|
|
77
|
+
}
|
|
78
|
+
// todo vnikolov: log
|
|
79
|
+
if (level >= types_1.Verbosity[this.level]) {
|
|
80
|
+
(0, utils_1.saveDataInAttribute)(data, this.span);
|
|
81
|
+
}
|
|
82
|
+
return Promise.resolve();
|
|
83
|
+
}
|
|
84
|
+
getPropagationInfo() {
|
|
85
|
+
// vnikolov: check if this works with SDK
|
|
86
|
+
// Answer: nope, because we're using base SDK
|
|
87
|
+
// const propagationInfo: PropagationInfo = {};
|
|
88
|
+
// https://www.w3.org/TR/trace-context/#tracestate-field
|
|
89
|
+
const propagationInfo = {
|
|
90
|
+
traceparent: `${this.version}-${this.spanContextField.traceId}-${this.spanContextField.spanId}-0${this.spanContextField.traceFlags}`,
|
|
91
|
+
// TODO vnikolov: check if this needs to be populated
|
|
92
|
+
tracestate: this.spanContextField.traceState && String(this.spanContextField.traceState),
|
|
93
|
+
};
|
|
94
|
+
// this is a NOOP because we're using base SDK
|
|
95
|
+
api_1.propagation.inject(api_1.context.active(), propagationInfo);
|
|
96
|
+
return propagationInfo;
|
|
97
|
+
}
|
|
98
|
+
injectPropagationInfo(carrier) {
|
|
99
|
+
carrier.__interopIOTracePropagationInfo = this.getPropagationInfo();
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
exports.TracingState = TracingState;
|
|
103
|
+
//# sourceMappingURL=tracingState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tracingState.js","sourceRoot":"","sources":["../../src/traces/tracingState.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { Span, TracerProvider } from "@opentelemetry/api";
|
|
3
|
+
import { Logger } from "../logger/types";
|
|
4
|
+
import { Manager } from "../types";
|
|
5
|
+
export interface TracesManager extends Manager<TracesSettings> {
|
|
6
|
+
extractTracingPropagationInfo(propagationInfoCarrier: PropagationInfo | PropagationInfoCarrier): PropagationInfo | undefined;
|
|
7
|
+
withSpan(source: string, callback: WithSpanCallback): Promise<ReturnType<WithSpanCallback>>;
|
|
8
|
+
withSpan(source: string, tracingContext: TracingContext, callback: WithSpanCallback): Promise<ReturnType<WithSpanCallback>>;
|
|
9
|
+
withSpan(source: string, tracingContext: TracingContext, propagationInfo: PropagationInfo | PropagationInfoCarrier, callback: WithSpanCallback): Promise<ReturnType<WithSpanCallback>>;
|
|
10
|
+
}
|
|
11
|
+
export type WithSpanCallback = (tracingState: TracingState) => any | Promise<any>;
|
|
12
|
+
export interface PropagationInfo {
|
|
13
|
+
traceparent?: string;
|
|
14
|
+
tracestate?: string;
|
|
15
|
+
}
|
|
16
|
+
export interface PropagationInfoCarrier {
|
|
17
|
+
__interopIOTracePropagationInfo?: PropagationInfo;
|
|
18
|
+
}
|
|
19
|
+
export interface TracingState {
|
|
20
|
+
enabled: boolean;
|
|
21
|
+
level: keyof typeof Verbosity;
|
|
22
|
+
addData(level: Verbosity | keyof typeof Verbosity, data: AttributeData): Promise<void>;
|
|
23
|
+
source: string;
|
|
24
|
+
id?: string;
|
|
25
|
+
timeoutId?: NodeJS.Timeout;
|
|
26
|
+
endSpan(): Promise<void>;
|
|
27
|
+
span: Span | null;
|
|
28
|
+
getPropagationInfo: () => PropagationInfo | null;
|
|
29
|
+
injectPropagationInfo: (carrier: PropagationInfoCarrier & object) => void;
|
|
30
|
+
setStatus?: Span["setStatus"];
|
|
31
|
+
addEvent?: Span["addEvent"];
|
|
32
|
+
recordException?: Span["recordException"];
|
|
33
|
+
isRecording?: Span["isRecording"];
|
|
34
|
+
updateName?: Span["updateName"];
|
|
35
|
+
spanContext?: Span["spanContext"];
|
|
36
|
+
}
|
|
37
|
+
export type AttributeArray = Array<null | undefined | string> | Array<null | undefined | number> | Array<null | undefined | boolean>;
|
|
38
|
+
export interface AttributeData {
|
|
39
|
+
[key: string]: string | number | boolean | undefined | AttributeArray | unknown[] | object;
|
|
40
|
+
}
|
|
41
|
+
export interface TracingContext {
|
|
42
|
+
app?: string;
|
|
43
|
+
user?: string;
|
|
44
|
+
serviceName?: string;
|
|
45
|
+
[key: string]: string | number | undefined;
|
|
46
|
+
}
|
|
47
|
+
export declare enum Verbosity {
|
|
48
|
+
OFF = 0,
|
|
49
|
+
LOWEST = 1,
|
|
50
|
+
DIAGNOSTIC = 2,
|
|
51
|
+
DEBUG = 3,
|
|
52
|
+
INFO = 4,
|
|
53
|
+
WARN = 5,
|
|
54
|
+
HIGHEST = 6
|
|
55
|
+
}
|
|
56
|
+
export interface Filter {
|
|
57
|
+
source: string;
|
|
58
|
+
level: keyof typeof Verbosity;
|
|
59
|
+
enable?: boolean;
|
|
60
|
+
context: {
|
|
61
|
+
[key: string]: string | number | boolean;
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
export interface TracesDefaultsSettings {
|
|
65
|
+
enabled?: boolean;
|
|
66
|
+
level?: keyof typeof Verbosity;
|
|
67
|
+
sample?: number | boolean;
|
|
68
|
+
}
|
|
69
|
+
export interface TracesSettings {
|
|
70
|
+
enabled: boolean;
|
|
71
|
+
url?: string;
|
|
72
|
+
console?: boolean;
|
|
73
|
+
filters?: Filter[];
|
|
74
|
+
sampling?: SamplingSettings;
|
|
75
|
+
default?: TracesDefaultsSettings;
|
|
76
|
+
spanTimeoutMs?: number;
|
|
77
|
+
serviceName?: string;
|
|
78
|
+
user?: string;
|
|
79
|
+
addContextToTrace?: boolean;
|
|
80
|
+
}
|
|
81
|
+
export interface SamplingSettings {
|
|
82
|
+
attributes?: {
|
|
83
|
+
[key: string]: string | number;
|
|
84
|
+
};
|
|
85
|
+
context?: {
|
|
86
|
+
[key: string]: string | number;
|
|
87
|
+
};
|
|
88
|
+
sample: number | boolean;
|
|
89
|
+
}
|
|
90
|
+
export interface TracesManagerBuilder {
|
|
91
|
+
build(): TracesManager;
|
|
92
|
+
withLogger(logger: Logger): this;
|
|
93
|
+
withSettings(settings: TracesSettings): this;
|
|
94
|
+
withTracingContextGetter(tracingContextGetter?: () => TracingContext): this;
|
|
95
|
+
withTracerProvider(tracerProvider: TracerProvider): this;
|
|
96
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Verbosity = void 0;
|
|
4
|
+
var Verbosity;
|
|
5
|
+
(function (Verbosity) {
|
|
6
|
+
Verbosity[Verbosity["OFF"] = 0] = "OFF";
|
|
7
|
+
Verbosity[Verbosity["LOWEST"] = 1] = "LOWEST";
|
|
8
|
+
Verbosity[Verbosity["DIAGNOSTIC"] = 2] = "DIAGNOSTIC";
|
|
9
|
+
Verbosity[Verbosity["DEBUG"] = 3] = "DEBUG";
|
|
10
|
+
Verbosity[Verbosity["INFO"] = 4] = "INFO";
|
|
11
|
+
Verbosity[Verbosity["WARN"] = 5] = "WARN";
|
|
12
|
+
Verbosity[Verbosity["HIGHEST"] = 6] = "HIGHEST";
|
|
13
|
+
})(Verbosity = exports.Verbosity || (exports.Verbosity = {}));
|
|
14
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/traces/types.ts"],"names":[],"mappings":";;;AAoEA,IAAY,SAQX;AARD,WAAY,SAAS;IACnB,uCAAG,CAAA;IACH,6CAAM,CAAA;IACN,qDAAU,CAAA;IACV,2CAAK,CAAA;IACL,yCAAI,CAAA;IACJ,yCAAI,CAAA;IACJ,+CAAO,CAAA;AACT,CAAC,EARW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAQpB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { TracerProvider } from "@opentelemetry/api";
|
|
2
|
+
import { AttributeData, Filter, TracingContext } from "../types";
|
|
3
|
+
import { Span } from "@opentelemetry/api";
|
|
4
|
+
export declare const isSpanEnabled: (match: any, defaultMatch: any) => any;
|
|
5
|
+
export declare const isFilterMatch: (filter: Filter, context: TracingContext, source: string) => boolean;
|
|
6
|
+
export declare const setTracerProvider: (provider?: TracerProvider, settings?: {
|
|
7
|
+
serviceName: string;
|
|
8
|
+
url: string;
|
|
9
|
+
console?: boolean;
|
|
10
|
+
}) => void;
|
|
11
|
+
export declare const saveDataInAttribute: (data: AttributeData, otelSpan: Span) => void;
|
|
12
|
+
export declare const replacePlaceHolders: (settings: any, context: any) => any;
|
|
13
|
+
export declare const isFunctionType: (variable: unknown) => boolean;
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isFunctionType = exports.replacePlaceHolders = exports.saveDataInAttribute = exports.setTracerProvider = exports.isFilterMatch = exports.isSpanEnabled = void 0;
|
|
4
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
5
|
+
const exporter_trace_otlp_http_1 = require("@opentelemetry/exporter-trace-otlp-http");
|
|
6
|
+
const sdk_trace_base_1 = require("@opentelemetry/sdk-trace-base");
|
|
7
|
+
const resources_1 = require("@opentelemetry/resources");
|
|
8
|
+
const filter_1 = require("../../validation/traces/filter");
|
|
9
|
+
const attributeData_1 = require("../../validation/traces/attributeData");
|
|
10
|
+
const isSpanEnabled = (match, defaultMatch) => {
|
|
11
|
+
let enabled;
|
|
12
|
+
if (match) {
|
|
13
|
+
if (match.enabled === undefined) {
|
|
14
|
+
enabled = true;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
enabled = match.enabled;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
else if (defaultMatch) {
|
|
21
|
+
enabled = defaultMatch.enabled;
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
enabled = false;
|
|
25
|
+
}
|
|
26
|
+
return enabled;
|
|
27
|
+
};
|
|
28
|
+
exports.isSpanEnabled = isSpanEnabled;
|
|
29
|
+
const isFilterMatch = (filter, context, source) => {
|
|
30
|
+
let isMatch = true;
|
|
31
|
+
if (filter) {
|
|
32
|
+
const validator = new filter_1.TracesFilterValidator();
|
|
33
|
+
validator.validate(filter);
|
|
34
|
+
}
|
|
35
|
+
if (filter.source && !source.startsWith(filter.source + ".") && source !== filter.source) {
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
if (!filter.context) {
|
|
39
|
+
return true;
|
|
40
|
+
}
|
|
41
|
+
for (const key of Object.keys(filter.context)) {
|
|
42
|
+
if (context[key] !== filter.context[key]) {
|
|
43
|
+
isMatch = false;
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return isMatch;
|
|
48
|
+
};
|
|
49
|
+
exports.isFilterMatch = isFilterMatch;
|
|
50
|
+
const setTracerProvider = (provider, settings) => {
|
|
51
|
+
if (!provider && !settings) {
|
|
52
|
+
// TODO vnikolov throw
|
|
53
|
+
throw new Error();
|
|
54
|
+
}
|
|
55
|
+
if (!provider) {
|
|
56
|
+
const btProvider = (provider = new sdk_trace_base_1.BasicTracerProvider({
|
|
57
|
+
resource: new resources_1.Resource({
|
|
58
|
+
"service.name": `${settings === null || settings === void 0 ? void 0 : settings.serviceName}`,
|
|
59
|
+
}),
|
|
60
|
+
}));
|
|
61
|
+
// Configure span processor to send spans to the exporter
|
|
62
|
+
// vnikolov TODO: add options to configure span processors AND exporters
|
|
63
|
+
// or to prepopulate them
|
|
64
|
+
btProvider.addSpanProcessor(new sdk_trace_base_1.BatchSpanProcessor((settings === null || settings === void 0 ? void 0 : settings.console)
|
|
65
|
+
? new sdk_trace_base_1.ConsoleSpanExporter()
|
|
66
|
+
: new exporter_trace_otlp_http_1.OTLPTraceExporter({
|
|
67
|
+
// url: "https://jaeger-otlp-http.interop.io/v1/traces",
|
|
68
|
+
// url: "http://localhost:4318/v1/traces",
|
|
69
|
+
url: settings === null || settings === void 0 ? void 0 : settings.url,
|
|
70
|
+
// optional - collection of custom headers to be sent with each request, empty by default
|
|
71
|
+
})));
|
|
72
|
+
}
|
|
73
|
+
if (provider.register) {
|
|
74
|
+
provider.register();
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
exports.setTracerProvider = setTracerProvider;
|
|
78
|
+
const isAttributeArray = (value) => {
|
|
79
|
+
if (!Array.isArray(value)) {
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
return value.every((item) => item === null ||
|
|
83
|
+
item === undefined ||
|
|
84
|
+
typeof item === "string" ||
|
|
85
|
+
typeof item === "number" ||
|
|
86
|
+
typeof item === "boolean");
|
|
87
|
+
};
|
|
88
|
+
const saveDataInAttribute = (data, otelSpan) => {
|
|
89
|
+
const validator = new attributeData_1.TracesAttributeDataValidator();
|
|
90
|
+
validator.validate(data);
|
|
91
|
+
for (const [key, value] of Object.entries(data)) {
|
|
92
|
+
const isObject = Boolean(value && typeof value === "object");
|
|
93
|
+
const isValidPrimitiveValue = typeof value === "number" || typeof value === "string" || typeof value === "boolean";
|
|
94
|
+
if (isAttributeArray(value) || isValidPrimitiveValue) {
|
|
95
|
+
otelSpan.setAttribute(key, value);
|
|
96
|
+
}
|
|
97
|
+
else if (isObject) {
|
|
98
|
+
otelSpan.setAttribute(key, JSON.stringify(value));
|
|
99
|
+
}
|
|
100
|
+
// vnikolov todo: what about symbol, bigint?
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
exports.saveDataInAttribute = saveDataInAttribute;
|
|
104
|
+
const replacePlaceHolders = (settings, context) => {
|
|
105
|
+
const regex = /([$][a-zA-Z0-9]+)/g;
|
|
106
|
+
const toParse = JSON.stringify(settings).replace(regex, (m) => {
|
|
107
|
+
const key = m.replace("$", "");
|
|
108
|
+
const dollarVar = context[key];
|
|
109
|
+
if (dollarVar !== undefined) {
|
|
110
|
+
return JSON.stringify(dollarVar).replace(/^"/, "").replace(/"$/, "");
|
|
111
|
+
}
|
|
112
|
+
return m;
|
|
113
|
+
});
|
|
114
|
+
return JSON.parse(toParse);
|
|
115
|
+
};
|
|
116
|
+
exports.replacePlaceHolders = replacePlaceHolders;
|
|
117
|
+
const isFunctionType = (variable) => typeof variable === "function";
|
|
118
|
+
exports.isFunctionType = isFunctionType;
|
|
119
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/traces/utils/index.ts"],"names":[],"mappings":"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"}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { TracesManager, TracesSettings } from "./traces/types";
|
|
2
|
+
import { LogsManager, LogsSettings } from "./logs/types";
|
|
3
|
+
import { MetricsSettings } from "./metrics/settings/types";
|
|
4
|
+
import { MetricsManager } from "./metrics/types";
|
|
5
|
+
export interface Container extends Manager<Settings> {
|
|
6
|
+
traces: TracesManager;
|
|
7
|
+
metrics: MetricsManager;
|
|
8
|
+
logs: LogsManager;
|
|
9
|
+
}
|
|
10
|
+
export interface Manager<TSettings> {
|
|
11
|
+
settings: TSettings;
|
|
12
|
+
started: boolean;
|
|
13
|
+
start(): Promise<void>;
|
|
14
|
+
stop(): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
export interface Settings {
|
|
17
|
+
traces: TracesSettings;
|
|
18
|
+
metrics: MetricsSettings;
|
|
19
|
+
logs: LogsSettings;
|
|
20
|
+
}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NullManager = void 0;
|
|
4
|
+
class NullManager {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.started = false;
|
|
7
|
+
}
|
|
8
|
+
get settings() {
|
|
9
|
+
return {};
|
|
10
|
+
}
|
|
11
|
+
start() {
|
|
12
|
+
this.started = true;
|
|
13
|
+
return Promise.resolve();
|
|
14
|
+
}
|
|
15
|
+
stop() {
|
|
16
|
+
this.started = false;
|
|
17
|
+
return Promise.resolve();
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.NullManager = NullManager;
|
|
21
|
+
//# sourceMappingURL=nullManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nullManager.js","sourceRoot":"","sources":["../../src/utils/nullManager.ts"],"names":[],"mappings":";;;AAEA,MAAa,WAAW;IAAxB;QACW,YAAO,GAAY,KAAK,CAAC;IAepC,CAAC;IAbG,IAAW,QAAQ;QACf,OAAO,EAAe,CAAC;IAC3B,CAAC;IAEM,KAAK;QACR,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IAEM,IAAI;QACP,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;CACJ;AAhBD,kCAgBC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BuilderValidator = void 0;
|
|
4
|
+
const validator_1 = require("./validator");
|
|
5
|
+
class BuilderValidator {
|
|
6
|
+
validate(builder) {
|
|
7
|
+
validator_1.Validator.throwIfNullOrUndefined(builder, "builder");
|
|
8
|
+
validator_1.Validator.throwIfNullOrUndefined(builder.logger, "logger");
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.BuilderValidator = BuilderValidator;
|
|
12
|
+
//# sourceMappingURL=builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder.js","sourceRoot":"","sources":["../../src/validation/builder.ts"],"names":[],"mappings":";;;AACA,2CAAwC;AAExC,MAAa,gBAAgB;IAClB,QAAQ,CAAC,OAAgB;QAC5B,qBAAS,CAAC,sBAAsB,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QACrD,qBAAS,CAAC,sBAAsB,CAAC,OAAO,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IAC/D,CAAC;CACJ;AALD,4CAKC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ContainerValidator = void 0;
|
|
4
|
+
const validator_1 = require("./validator");
|
|
5
|
+
class ContainerValidator {
|
|
6
|
+
validate(container) {
|
|
7
|
+
validator_1.Validator.throwIfNullOrUndefined(container, "container");
|
|
8
|
+
validator_1.Validator.throwIfNullOrUndefined(container.settings, "metrics");
|
|
9
|
+
validator_1.Validator.throwIfNullOrUndefined(container.traces, "traces");
|
|
10
|
+
validator_1.Validator.throwIfNullOrUndefined(container.logs, "logs");
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.ContainerValidator = ContainerValidator;
|
|
14
|
+
//# sourceMappingURL=container.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/validation/container.ts"],"names":[],"mappings":";;;AACA,2CAAwC;AAExC,MAAa,kBAAkB;IACpB,QAAQ,CAAC,SAAoB;QAChC,qBAAS,CAAC,sBAAsB,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;QACzD,qBAAS,CAAC,sBAAsB,CAAC,SAAS,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAChE,qBAAS,CAAC,sBAAsB,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAC7D,qBAAS,CAAC,sBAAsB,CAAC,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC7D,CAAC;CACJ;AAPD,gDAOC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ApplicationCountMetric } from "../../../metrics/metrics/application/count";
|
|
2
|
+
import { InstanceActionHandlerArgs } from "../../../metrics/dependencies/types";
|
|
3
|
+
export declare class ApplicationCountMetricValidator {
|
|
4
|
+
validate(metric: ApplicationCountMetric): void;
|
|
5
|
+
validateInstanceStarted(args: InstanceActionHandlerArgs): void;
|
|
6
|
+
validateInstanceStopped(args: InstanceActionHandlerArgs): void;
|
|
7
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ApplicationCountMetricValidator = void 0;
|
|
4
|
+
const validator_1 = require("../../validator");
|
|
5
|
+
class ApplicationCountMetricValidator {
|
|
6
|
+
validate(metric) {
|
|
7
|
+
validator_1.Validator.throwIfNullOrUndefined(metric, "metric");
|
|
8
|
+
validator_1.Validator.throwIfNullOrUndefined(metric.instanceStartedHandler, "instanceStartedHandler");
|
|
9
|
+
validator_1.Validator.throwIfNullOrUndefined(metric.instanceStoppedHandler, "instanceStoppedHandler");
|
|
10
|
+
}
|
|
11
|
+
validateInstanceStarted(args) {
|
|
12
|
+
validator_1.Validator.throwIfNullOrUndefined(args, "args");
|
|
13
|
+
validator_1.Validator.throwIfNullOrUndefined(args.application, "application");
|
|
14
|
+
}
|
|
15
|
+
validateInstanceStopped(args) {
|
|
16
|
+
validator_1.Validator.throwIfNullOrUndefined(args, "args");
|
|
17
|
+
validator_1.Validator.throwIfNullOrUndefined(args.application, "application");
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.ApplicationCountMetricValidator = ApplicationCountMetricValidator;
|
|
21
|
+
//# sourceMappingURL=count.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"count.js","sourceRoot":"","sources":["../../../../src/validation/metrics/application/count.ts"],"names":[],"mappings":";;;AAEA,+CAA4C;AAE5C,MAAa,+BAA+B;IACjC,QAAQ,CAAC,MAA8B;QAC1C,qBAAS,CAAC,sBAAsB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QACnD,qBAAS,CAAC,sBAAsB,CAAC,MAAM,CAAC,sBAAsB,EAAE,wBAAwB,CAAC,CAAC;QAC1F,qBAAS,CAAC,sBAAsB,CAAC,MAAM,CAAC,sBAAsB,EAAE,wBAAwB,CAAC,CAAC;IAC9F,CAAC;IAEM,uBAAuB,CAAC,IAA+B;QAC1D,qBAAS,CAAC,sBAAsB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC/C,qBAAS,CAAC,sBAAsB,CAAC,IAAI,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;IACtE,CAAC;IAEM,uBAAuB,CAAC,IAA+B;QAC1D,qBAAS,CAAC,sBAAsB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC/C,qBAAS,CAAC,sBAAsB,CAAC,IAAI,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;IACtE,CAAC;CACJ;AAhBD,0EAgBC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ApplicationDurationMetricBase } from "../../../metrics/metrics/application/durationBase";
|
|
2
|
+
import { InstanceFocusedHandlerArgs } from "../../../metrics/dependencies/types";
|
|
3
|
+
export declare class ApplicationDurationMetricValidator {
|
|
4
|
+
validate(metric: ApplicationDurationMetricBase): void;
|
|
5
|
+
validateFocusChanged(args: InstanceFocusedHandlerArgs): void;
|
|
6
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ApplicationDurationMetricValidator = void 0;
|
|
4
|
+
const validator_1 = require("../../validator");
|
|
5
|
+
class ApplicationDurationMetricValidator {
|
|
6
|
+
validate(metric) {
|
|
7
|
+
validator_1.Validator.throwIfNullOrUndefined(metric, "metric");
|
|
8
|
+
validator_1.Validator.throwIfNullOrUndefined(metric.instanceFocusHandler, "instanceFocusHandler");
|
|
9
|
+
}
|
|
10
|
+
validateFocusChanged(args) {
|
|
11
|
+
validator_1.Validator.throwIfNullOrUndefined(args, "args");
|
|
12
|
+
validator_1.Validator.throwIfNullOrUndefined(args.application, "application");
|
|
13
|
+
validator_1.Validator.throwIfNullOrUndefined(args.focused, "focused");
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.ApplicationDurationMetricValidator = ApplicationDurationMetricValidator;
|
|
17
|
+
//# sourceMappingURL=duration.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"duration.js","sourceRoot":"","sources":["../../../../src/validation/metrics/application/duration.ts"],"names":[],"mappings":";;;AAEA,+CAA4C;AAE5C,MAAa,kCAAkC;IACpC,QAAQ,CAAC,MAAqC;QACjD,qBAAS,CAAC,sBAAsB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QACnD,qBAAS,CAAC,sBAAsB,CAAC,MAAM,CAAC,oBAAoB,EAAE,sBAAsB,CAAC,CAAC;IAC1F,CAAC;IAEM,oBAAoB,CAAC,IAAgC;QACxD,qBAAS,CAAC,sBAAsB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC/C,qBAAS,CAAC,sBAAsB,CAAC,IAAI,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;QAClE,qBAAS,CAAC,sBAAsB,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;IAC9D,CAAC;CACJ;AAXD,gFAWC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ApplicationErrorMetric } from "../../../metrics/metrics/application/error";
|
|
2
|
+
import { InstanceErrorHandlerArgs } from "../../../metrics/dependencies/types";
|
|
3
|
+
export declare class ApplicationErrorMetricValidator {
|
|
4
|
+
validate(metric: ApplicationErrorMetric): void;
|
|
5
|
+
validateApplicationError(args: InstanceErrorHandlerArgs): void;
|
|
6
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ApplicationErrorMetricValidator = void 0;
|
|
4
|
+
const validator_1 = require("../../validator");
|
|
5
|
+
class ApplicationErrorMetricValidator {
|
|
6
|
+
validate(metric) {
|
|
7
|
+
validator_1.Validator.throwIfNullOrUndefined(metric, "metric");
|
|
8
|
+
validator_1.Validator.throwIfNullOrUndefined(metric.instanceErrorHandler, "appErrorHandler");
|
|
9
|
+
}
|
|
10
|
+
validateApplicationError(args) {
|
|
11
|
+
validator_1.Validator.throwIfNullOrUndefined(args, "args");
|
|
12
|
+
validator_1.Validator.throwIfNullOrUndefined(args.application, "application");
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.ApplicationErrorMetricValidator = ApplicationErrorMetricValidator;
|
|
16
|
+
//# sourceMappingURL=error.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error.js","sourceRoot":"","sources":["../../../../src/validation/metrics/application/error.ts"],"names":[],"mappings":";;;AAEA,+CAA4C;AAE5C,MAAa,+BAA+B;IACjC,QAAQ,CAAC,MAA8B;QAC1C,qBAAS,CAAC,sBAAsB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QACnD,qBAAS,CAAC,sBAAsB,CAAC,MAAM,CAAC,oBAAoB,EAAE,iBAAiB,CAAC,CAAC;IACrF,CAAC;IAEM,wBAAwB,CAAC,IAA8B;QAC1D,qBAAS,CAAC,sBAAsB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC/C,qBAAS,CAAC,sBAAsB,CAAC,IAAI,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;IACtE,CAAC;CACJ;AAVD,0EAUC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ApplicationStartedMetric } from "../../../metrics/metrics/application/started";
|
|
2
|
+
import { InstanceActionHandlerArgs } from "../../../metrics/dependencies/types";
|
|
3
|
+
export declare class ApplicationStartedMetricValidator {
|
|
4
|
+
validate(metric: ApplicationStartedMetric): void;
|
|
5
|
+
validateInstanceStarted(args: InstanceActionHandlerArgs): void;
|
|
6
|
+
}
|