@wertzui/ngx-restworld-client 14.0.0 → 14.1.0
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/esm2022/lib/services/opentelemetry.service.mjs +80 -5
- package/fesm2022/wertzui-ngx-restworld-client.mjs +79 -4
- package/fesm2022/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/lib/services/opentelemetry.service.d.ts +6 -1
- package/lib/services/opentelemetry.service.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -8,10 +8,73 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
import * as i1 from "./settings.service";
|
|
9
9
|
export class OpenTelemetryService {
|
|
10
10
|
_settingsService;
|
|
11
|
+
_defaultInputConfigs = {
|
|
12
|
+
"@opentelemetry/instrumentation-xml-http-request": {
|
|
13
|
+
propagateTraceHeaderCorsUrls: /.*/,
|
|
14
|
+
applyCustomAttributesOnSpan: (span, xhr) => {
|
|
15
|
+
span.setAttribute("client.address", window.location.href);
|
|
16
|
+
span.setAttribute("client.port", window.location.port);
|
|
17
|
+
span.setAttribute("browser.language", navigator.language);
|
|
18
|
+
if (URL.canParse(xhr.responseURL)) {
|
|
19
|
+
const url = new URL(xhr.responseURL);
|
|
20
|
+
span.setAttribute("url.domain", url.hostname);
|
|
21
|
+
span.setAttribute("url.full", url.href);
|
|
22
|
+
span.setAttribute("url.path", url.pathname);
|
|
23
|
+
span.setAttribute("url.port", url.port);
|
|
24
|
+
span.setAttribute("url.scheme", url.protocol.replace(":", ""));
|
|
25
|
+
if (url.search)
|
|
26
|
+
span.setAttribute("url.query", url.search.replace("?", ""));
|
|
27
|
+
if ("name" in span && typeof span.name === "string") {
|
|
28
|
+
span.updateName(span.name + " " + (url.pathname.startsWith("/") ? url.pathname.substring(1) : url.pathname));
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
"@opentelemetry/instrumentation-fetch": {
|
|
34
|
+
propagateTraceHeaderCorsUrls: /.*/,
|
|
35
|
+
applyCustomAttributesOnSpan: (span, request) => {
|
|
36
|
+
span.setAttribute("client.address", window.location.href);
|
|
37
|
+
span.setAttribute("client.port", window.location.port);
|
|
38
|
+
span.setAttribute("browser.language", navigator.language);
|
|
39
|
+
if ("url" in request && typeof request.url === "string" && URL.canParse(request.url)) {
|
|
40
|
+
const url = new URL(request.url);
|
|
41
|
+
span.setAttribute("url.domain", url.hostname);
|
|
42
|
+
span.setAttribute("url.full", url.href);
|
|
43
|
+
span.setAttribute("url.path", url.pathname);
|
|
44
|
+
span.setAttribute("url.port", url.port);
|
|
45
|
+
span.setAttribute("url.scheme", url.protocol.replace(":", ""));
|
|
46
|
+
if (url.search)
|
|
47
|
+
span.setAttribute("url.query", url.search.replace("?", ""));
|
|
48
|
+
if ("name" in span && typeof span.name === "string") {
|
|
49
|
+
span.updateName(span.name + " " + (url.pathname.startsWith("/") ? url.pathname.substring(1) : url.pathname));
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
"@opentelemetry/instrumentation-user-interaction": {
|
|
55
|
+
enabled: false,
|
|
56
|
+
shouldPreventSpanCreation: (eventType, element, span) => {
|
|
57
|
+
const shouldCreate = this._lastLocation !== window.location.href ||
|
|
58
|
+
Date.now() - this._lastTime > 1000 ||
|
|
59
|
+
this._lastElement !== element ||
|
|
60
|
+
//(eventType === "click" && (element.tagName === "A" || element.tagName === "Button")) ||
|
|
61
|
+
(eventType === "submit");
|
|
62
|
+
if (shouldCreate) {
|
|
63
|
+
this._lastLocation = window.location.href;
|
|
64
|
+
this._lastTime = Date.now();
|
|
65
|
+
this._lastElement = element;
|
|
66
|
+
}
|
|
67
|
+
return !shouldCreate;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
_lastElement = null;
|
|
72
|
+
_lastTime = 0;
|
|
73
|
+
_lastLocation = null;
|
|
11
74
|
constructor(_settingsService) {
|
|
12
75
|
this._settingsService = _settingsService;
|
|
13
76
|
}
|
|
14
|
-
async initialize() {
|
|
77
|
+
async initialize(configureOptions) {
|
|
15
78
|
await this._settingsService.ensureInitialized();
|
|
16
79
|
const clientSettings = this._settingsService.settings;
|
|
17
80
|
if (!clientSettings)
|
|
@@ -35,8 +98,9 @@ export class OpenTelemetryService {
|
|
|
35
98
|
return [key, value];
|
|
36
99
|
}));
|
|
37
100
|
}
|
|
101
|
+
const traceExporterEndpoint = exporterEndpoint.endsWith("/") ? exporterEndpoint + "v1/traces" : exporterEndpoint + "/v1/traces";
|
|
38
102
|
const otlpExporterConfiguration = {
|
|
39
|
-
url:
|
|
103
|
+
url: traceExporterEndpoint,
|
|
40
104
|
headers: headersObj,
|
|
41
105
|
compression: "gzip",
|
|
42
106
|
};
|
|
@@ -56,11 +120,22 @@ export class OpenTelemetryService {
|
|
|
56
120
|
}
|
|
57
121
|
if (serviceName)
|
|
58
122
|
provider.resource.attributes['service.name'] = serviceName;
|
|
123
|
+
// apply given options
|
|
124
|
+
let config;
|
|
125
|
+
if (typeof configureOptions === 'function') {
|
|
126
|
+
config = configureOptions(this._defaultInputConfigs);
|
|
127
|
+
}
|
|
128
|
+
else if (typeof configureOptions === 'object') {
|
|
129
|
+
config = configureOptions;
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
config = this._defaultInputConfigs;
|
|
133
|
+
}
|
|
59
134
|
// Registering instrumentations
|
|
60
135
|
registerInstrumentations({
|
|
61
136
|
instrumentations: [
|
|
62
|
-
getWebAutoInstrumentations()
|
|
63
|
-
]
|
|
137
|
+
getWebAutoInstrumentations(config),
|
|
138
|
+
]
|
|
64
139
|
});
|
|
65
140
|
}
|
|
66
141
|
static GetSampler(tracesSampler, tracesSamplerArg) {
|
|
@@ -92,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
92
167
|
providedIn: "root"
|
|
93
168
|
}]
|
|
94
169
|
}], ctorParameters: () => [{ type: i1.SettingsService }] });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"opentelemetry.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-restworld-client/src/lib/services/opentelemetry.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport { registerInstrumentations } from '@opentelemetry/instrumentation';\r\nimport { AlwaysOffSampler, AlwaysOnSampler, BatchSpanProcessor, ConsoleSpanExporter, ParentBasedSampler, SimpleSpanProcessor, TraceIdRatioBasedSampler, WebTracerProvider } from '@opentelemetry/sdk-trace-web';\r\nimport { SettingsService } from \"./settings.service\";\r\nimport { ZoneContextManager } from \"@opentelemetry/context-zone\";\r\nimport { getWebAutoInstrumentations } from \"@opentelemetry/auto-instrumentations-web\";\r\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-http\";\r\nimport { CompressionAlgorithm } from '@opentelemetry/otlp-exporter-base';\r\n\r\n@Injectable({\r\n  providedIn: \"root\"\r\n})\r\nexport class OpenTelemetryService {\r\n  constructor(private readonly _settingsService: SettingsService) {\r\n  }\r\n\r\n  async initialize(): Promise<void> {\r\n    await this._settingsService.ensureInitialized();\r\n\r\n    const clientSettings = this._settingsService.settings;\r\n    if (!clientSettings)\r\n      throw new Error('Settings are not loaded yet.');\r\n\r\n    const exporterEndpoint = clientSettings.extensions[\"OTEL_EXPORTER_OTLP_ENDPOINT\"];\r\n    const exporterHeaders = clientSettings.extensions[\"OTEL_EXPORTER_OTLP_HEADERS\"];\r\n    const serviceName = clientSettings.extensions[\"OTEL_SERVICE_NAME\"];\r\n    const resourceAttributes = clientSettings.extensions[\"OTEL_RESOURCE_ATTRIBUTES\"];\r\n    const tracesSampler = clientSettings.extensions[\"OTEL_TRACES_SAMPLER\"];\r\n    const tracesSamplerArg = clientSettings.extensions[\"OTEL_TRACES_SAMPLER_ARG\"];\r\n\r\n    const provider = new WebTracerProvider({ sampler: OpenTelemetryService.GetSampler(tracesSampler, tracesSamplerArg) });\r\n\r\n    if (!exporterEndpoint)\r\n      provider.addSpanProcessor(new SimpleSpanProcessor(new ConsoleSpanExporter()));\r\n    else {\r\n      let headersObj = {};\r\n      if (exporterHeaders) {\r\n        headersObj = Object.fromEntries(\r\n          exporterHeaders\r\n            .split(\",\")\r\n            .map((header: string) => {\r\n              const [key, value] = header.split(\"=\");\r\n              return [key, value];\r\n            }));\r\n      }\r\n\r\n      const otlpExporterConfiguration = {\r\n        url: exporterEndpoint,\r\n        headers: headersObj,\r\n        compression: \"gzip\" as CompressionAlgorithm,\r\n      };\r\n\r\n      provider.addSpanProcessor(new BatchSpanProcessor(new OTLPTraceExporter(otlpExporterConfiguration)));\r\n    }\r\n\r\n    provider.register({\r\n      // Changing default contextManager to use ZoneContextManager - supports asynchronous operations - optional\r\n      contextManager: new ZoneContextManager(),\r\n    });\r\n\r\n    if (resourceAttributes) {\r\n      resourceAttributes\r\n        .split(\",\")\r\n        .map((attribute: string) => {\r\n          const [key, value] = attribute.split(\"=\");\r\n          provider.resource.attributes[key] = value;\r\n        });\r\n    }\r\n\r\n    if (serviceName)\r\n      provider.resource.attributes['service.name'] = serviceName;\r\n\r\n    // Registering instrumentations\r\n    registerInstrumentations({\r\n      instrumentations: [\r\n        getWebAutoInstrumentations()\r\n      ],\r\n    });\r\n  }\r\n\r\n  private static GetSampler(tracesSampler?: string, tracesSamplerArg?: string) {\r\n    switch (tracesSampler) {\r\n      case \"always_on\":\r\n        return new AlwaysOnSampler();\r\n      case \"always_off\":\r\n        return new AlwaysOffSampler();\r\n      case \"traceidratio\":\r\n        const ratio = Number.parseFloat(tracesSamplerArg ?? \"1\");\r\n        return new TraceIdRatioBasedSampler(ratio);\r\n      case \"parentbased_always_on\":\r\n        return new ParentBasedSampler({ root: new AlwaysOnSampler() });\r\n      case \"parentbased_always_off\":\r\n        return new ParentBasedSampler({ root: new AlwaysOffSampler() });\r\n      case \"parentbased_traceidratio\":\r\n        const ratio2 = Number.parseFloat(tracesSamplerArg ?? \"1\");\r\n        return new ParentBasedSampler({ root: new TraceIdRatioBasedSampler(ratio2) });\r\n      default:\r\n        return new AlwaysOnSampler();\r\n    }\r\n  }\r\n}\r\n"]}
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"opentelemetry.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-restworld-client/src/lib/services/opentelemetry.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport { registerInstrumentations } from '@opentelemetry/instrumentation';\r\nimport { AlwaysOffSampler, AlwaysOnSampler, BatchSpanProcessor, ConsoleSpanExporter, ParentBasedSampler, SimpleSpanProcessor, TraceIdRatioBasedSampler, WebTracerProvider } from '@opentelemetry/sdk-trace-web';\r\nimport { SettingsService } from \"./settings.service\";\r\nimport { ZoneContextManager } from \"@opentelemetry/context-zone\";\r\nimport { InstrumentationConfigMap, getWebAutoInstrumentations } from \"@opentelemetry/auto-instrumentations-web\";\r\nimport { OTLPTraceExporter } from \"@opentelemetry/exporter-trace-otlp-http\";\r\nimport { CompressionAlgorithm } from '@opentelemetry/otlp-exporter-base';\r\nimport { Context, ContextManager, ROOT_CONTEXT, createContextKey } from \"@opentelemetry/api\";\r\n\r\n@Injectable({\r\n  providedIn: \"root\"\r\n})\r\nexport class OpenTelemetryService {\r\n\r\n  private readonly _defaultInputConfigs: InstrumentationConfigMap = {\r\n    \"@opentelemetry/instrumentation-xml-http-request\": {\r\n      propagateTraceHeaderCorsUrls: /.*/,\r\n      applyCustomAttributesOnSpan: (span, xhr) => {\r\n        span.setAttribute(\"client.address\", window.location.href);\r\n        span.setAttribute(\"client.port\", window.location.port);\r\n        span.setAttribute(\"browser.language\", navigator.language);\r\n        if (URL.canParse(xhr.responseURL)) {\r\n          const url = new URL(xhr.responseURL);\r\n          span.setAttribute(\"url.domain\", url.hostname);\r\n          span.setAttribute(\"url.full\", url.href);\r\n          span.setAttribute(\"url.path\", url.pathname);\r\n          span.setAttribute(\"url.port\", url.port);\r\n          span.setAttribute(\"url.scheme\", url.protocol.replace(\":\", \"\"));\r\n          if (url.search)\r\n            span.setAttribute(\"url.query\", url.search.replace(\"?\", \"\"));\r\n\r\n          if (\"name\" in span && typeof span.name === \"string\") {\r\n            span.updateName(span.name + \" \" + (url.pathname.startsWith(\"/\") ? url.pathname.substring(1) : url.pathname));\r\n          }\r\n        }\r\n      }\r\n    },\r\n    \"@opentelemetry/instrumentation-fetch\": {\r\n      propagateTraceHeaderCorsUrls: /.*/,\r\n      applyCustomAttributesOnSpan: (span, request) => {\r\n        span.setAttribute(\"client.address\", window.location.href);\r\n        span.setAttribute(\"client.port\", window.location.port);\r\n        span.setAttribute(\"browser.language\", navigator.language);\r\n        if (\"url\" in request && typeof request.url === \"string\" && URL.canParse(request.url)) {\r\n          const url = new URL(request.url);\r\n          span.setAttribute(\"url.domain\", url.hostname);\r\n          span.setAttribute(\"url.full\", url.href);\r\n          span.setAttribute(\"url.path\", url.pathname);\r\n          span.setAttribute(\"url.port\", url.port);\r\n          span.setAttribute(\"url.scheme\", url.protocol.replace(\":\", \"\"));\r\n          if (url.search)\r\n            span.setAttribute(\"url.query\", url.search.replace(\"?\", \"\"));\r\n\r\n          if (\"name\" in span && typeof span.name === \"string\") {\r\n            span.updateName(span.name + \" \" + (url.pathname.startsWith(\"/\") ? url.pathname.substring(1) : url.pathname));\r\n          }\r\n        }\r\n      }\r\n    },\r\n    \"@opentelemetry/instrumentation-user-interaction\": {\r\n      enabled: false,\r\n      shouldPreventSpanCreation: (eventType, element, span) => {\r\n        const shouldCreate =\r\n          this._lastLocation !== window.location.href ||\r\n          Date.now() - this._lastTime > 1000 ||\r\n          this._lastElement !== element ||\r\n          //(eventType === \"click\" && (element.tagName === \"A\" || element.tagName === \"Button\")) ||\r\n          (eventType === \"submit\");\r\n\r\n        if (shouldCreate) {\r\n          this._lastLocation = window.location.href;\r\n          this._lastTime = Date.now();\r\n          this._lastElement = element;\r\n        }\r\n\r\n        return !shouldCreate;\r\n      }\r\n    }\r\n  };\r\n\r\n  private _lastElement: HTMLElement | null = null;\r\n  private _lastTime: number = 0;\r\n  private _lastLocation: string | null = null;\r\n\r\n  constructor(private readonly _settingsService: SettingsService) {\r\n  }\r\n\r\n  async initialize(configureOptions?: InstrumentationConfigMap | ((inputConfigs: InstrumentationConfigMap) => InstrumentationConfigMap)): Promise<void> {\r\n    await this._settingsService.ensureInitialized();\r\n\r\n    const clientSettings = this._settingsService.settings;\r\n    if (!clientSettings)\r\n      throw new Error('Settings are not loaded yet.');\r\n\r\n    const exporterEndpoint = clientSettings.extensions[\"OTEL_EXPORTER_OTLP_ENDPOINT\"];\r\n    const exporterHeaders = clientSettings.extensions[\"OTEL_EXPORTER_OTLP_HEADERS\"];\r\n    const serviceName = clientSettings.extensions[\"OTEL_SERVICE_NAME\"];\r\n    const resourceAttributes = clientSettings.extensions[\"OTEL_RESOURCE_ATTRIBUTES\"];\r\n    const tracesSampler = clientSettings.extensions[\"OTEL_TRACES_SAMPLER\"];\r\n    const tracesSamplerArg = clientSettings.extensions[\"OTEL_TRACES_SAMPLER_ARG\"];\r\n\r\n    const provider = new WebTracerProvider({ sampler: OpenTelemetryService.GetSampler(tracesSampler, tracesSamplerArg) });\r\n\r\n    if (!exporterEndpoint)\r\n      provider.addSpanProcessor(new SimpleSpanProcessor(new ConsoleSpanExporter()));\r\n    else {\r\n      let headersObj = {};\r\n      if (exporterHeaders) {\r\n        headersObj = Object.fromEntries(\r\n          exporterHeaders\r\n            .split(\",\")\r\n            .map((header: string) => {\r\n              const [key, value] = header.split(\"=\");\r\n              return [key, value];\r\n            }));\r\n      }\r\n\r\n      const traceExporterEndpoint = exporterEndpoint.endsWith(\"/\") ? exporterEndpoint + \"v1/traces\" : exporterEndpoint + \"/v1/traces\";\r\n\r\n      const otlpExporterConfiguration = {\r\n        url: traceExporterEndpoint,\r\n        headers: headersObj,\r\n        compression: \"gzip\" as CompressionAlgorithm,\r\n      };\r\n\r\n      provider.addSpanProcessor(new BatchSpanProcessor(new OTLPTraceExporter(otlpExporterConfiguration)));\r\n    }\r\n\r\n    provider.register({\r\n      // Changing default contextManager to use ZoneContextManager - supports asynchronous operations - optional\r\n      contextManager: new ZoneContextManager(),\r\n    });\r\n\r\n    if (resourceAttributes) {\r\n      resourceAttributes\r\n        .split(\",\")\r\n        .map((attribute: string) => {\r\n          const [key, value] = attribute.split(\"=\");\r\n          provider.resource.attributes[key] = value;\r\n        });\r\n    }\r\n\r\n    if (serviceName)\r\n      provider.resource.attributes['service.name'] = serviceName;\r\n\r\n    // apply given options\r\n    let config;\r\n    if (typeof configureOptions === 'function') {\r\n      config = configureOptions(this._defaultInputConfigs);\r\n    }\r\n    else if (typeof configureOptions === 'object') {\r\n      config = configureOptions;\r\n    }\r\n    else {\r\n      config = this._defaultInputConfigs;\r\n    }\r\n\r\n    // Registering instrumentations\r\n    registerInstrumentations({\r\n      instrumentations: [\r\n        getWebAutoInstrumentations(config),\r\n      ]\r\n    });\r\n  }\r\n\r\n  private static GetSampler(tracesSampler?: string, tracesSamplerArg?: string) {\r\n    switch (tracesSampler) {\r\n      case \"always_on\":\r\n        return new AlwaysOnSampler();\r\n      case \"always_off\":\r\n        return new AlwaysOffSampler();\r\n      case \"traceidratio\":\r\n        const ratio = Number.parseFloat(tracesSamplerArg ?? \"1\");\r\n        return new TraceIdRatioBasedSampler(ratio);\r\n      case \"parentbased_always_on\":\r\n        return new ParentBasedSampler({ root: new AlwaysOnSampler() });\r\n      case \"parentbased_always_off\":\r\n        return new ParentBasedSampler({ root: new AlwaysOffSampler() });\r\n      case \"parentbased_traceidratio\":\r\n        const ratio2 = Number.parseFloat(tracesSamplerArg ?? \"1\");\r\n        return new ParentBasedSampler({ root: new TraceIdRatioBasedSampler(ratio2) });\r\n      default:\r\n        return new AlwaysOnSampler();\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -3339,10 +3339,73 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
3339
3339
|
|
|
3340
3340
|
class OpenTelemetryService {
|
|
3341
3341
|
_settingsService;
|
|
3342
|
+
_defaultInputConfigs = {
|
|
3343
|
+
"@opentelemetry/instrumentation-xml-http-request": {
|
|
3344
|
+
propagateTraceHeaderCorsUrls: /.*/,
|
|
3345
|
+
applyCustomAttributesOnSpan: (span, xhr) => {
|
|
3346
|
+
span.setAttribute("client.address", window.location.href);
|
|
3347
|
+
span.setAttribute("client.port", window.location.port);
|
|
3348
|
+
span.setAttribute("browser.language", navigator.language);
|
|
3349
|
+
if (URL.canParse(xhr.responseURL)) {
|
|
3350
|
+
const url = new URL(xhr.responseURL);
|
|
3351
|
+
span.setAttribute("url.domain", url.hostname);
|
|
3352
|
+
span.setAttribute("url.full", url.href);
|
|
3353
|
+
span.setAttribute("url.path", url.pathname);
|
|
3354
|
+
span.setAttribute("url.port", url.port);
|
|
3355
|
+
span.setAttribute("url.scheme", url.protocol.replace(":", ""));
|
|
3356
|
+
if (url.search)
|
|
3357
|
+
span.setAttribute("url.query", url.search.replace("?", ""));
|
|
3358
|
+
if ("name" in span && typeof span.name === "string") {
|
|
3359
|
+
span.updateName(span.name + " " + (url.pathname.startsWith("/") ? url.pathname.substring(1) : url.pathname));
|
|
3360
|
+
}
|
|
3361
|
+
}
|
|
3362
|
+
}
|
|
3363
|
+
},
|
|
3364
|
+
"@opentelemetry/instrumentation-fetch": {
|
|
3365
|
+
propagateTraceHeaderCorsUrls: /.*/,
|
|
3366
|
+
applyCustomAttributesOnSpan: (span, request) => {
|
|
3367
|
+
span.setAttribute("client.address", window.location.href);
|
|
3368
|
+
span.setAttribute("client.port", window.location.port);
|
|
3369
|
+
span.setAttribute("browser.language", navigator.language);
|
|
3370
|
+
if ("url" in request && typeof request.url === "string" && URL.canParse(request.url)) {
|
|
3371
|
+
const url = new URL(request.url);
|
|
3372
|
+
span.setAttribute("url.domain", url.hostname);
|
|
3373
|
+
span.setAttribute("url.full", url.href);
|
|
3374
|
+
span.setAttribute("url.path", url.pathname);
|
|
3375
|
+
span.setAttribute("url.port", url.port);
|
|
3376
|
+
span.setAttribute("url.scheme", url.protocol.replace(":", ""));
|
|
3377
|
+
if (url.search)
|
|
3378
|
+
span.setAttribute("url.query", url.search.replace("?", ""));
|
|
3379
|
+
if ("name" in span && typeof span.name === "string") {
|
|
3380
|
+
span.updateName(span.name + " " + (url.pathname.startsWith("/") ? url.pathname.substring(1) : url.pathname));
|
|
3381
|
+
}
|
|
3382
|
+
}
|
|
3383
|
+
}
|
|
3384
|
+
},
|
|
3385
|
+
"@opentelemetry/instrumentation-user-interaction": {
|
|
3386
|
+
enabled: false,
|
|
3387
|
+
shouldPreventSpanCreation: (eventType, element, span) => {
|
|
3388
|
+
const shouldCreate = this._lastLocation !== window.location.href ||
|
|
3389
|
+
Date.now() - this._lastTime > 1000 ||
|
|
3390
|
+
this._lastElement !== element ||
|
|
3391
|
+
//(eventType === "click" && (element.tagName === "A" || element.tagName === "Button")) ||
|
|
3392
|
+
(eventType === "submit");
|
|
3393
|
+
if (shouldCreate) {
|
|
3394
|
+
this._lastLocation = window.location.href;
|
|
3395
|
+
this._lastTime = Date.now();
|
|
3396
|
+
this._lastElement = element;
|
|
3397
|
+
}
|
|
3398
|
+
return !shouldCreate;
|
|
3399
|
+
}
|
|
3400
|
+
}
|
|
3401
|
+
};
|
|
3402
|
+
_lastElement = null;
|
|
3403
|
+
_lastTime = 0;
|
|
3404
|
+
_lastLocation = null;
|
|
3342
3405
|
constructor(_settingsService) {
|
|
3343
3406
|
this._settingsService = _settingsService;
|
|
3344
3407
|
}
|
|
3345
|
-
async initialize() {
|
|
3408
|
+
async initialize(configureOptions) {
|
|
3346
3409
|
await this._settingsService.ensureInitialized();
|
|
3347
3410
|
const clientSettings = this._settingsService.settings;
|
|
3348
3411
|
if (!clientSettings)
|
|
@@ -3366,8 +3429,9 @@ class OpenTelemetryService {
|
|
|
3366
3429
|
return [key, value];
|
|
3367
3430
|
}));
|
|
3368
3431
|
}
|
|
3432
|
+
const traceExporterEndpoint = exporterEndpoint.endsWith("/") ? exporterEndpoint + "v1/traces" : exporterEndpoint + "/v1/traces";
|
|
3369
3433
|
const otlpExporterConfiguration = {
|
|
3370
|
-
url:
|
|
3434
|
+
url: traceExporterEndpoint,
|
|
3371
3435
|
headers: headersObj,
|
|
3372
3436
|
compression: "gzip",
|
|
3373
3437
|
};
|
|
@@ -3387,11 +3451,22 @@ class OpenTelemetryService {
|
|
|
3387
3451
|
}
|
|
3388
3452
|
if (serviceName)
|
|
3389
3453
|
provider.resource.attributes['service.name'] = serviceName;
|
|
3454
|
+
// apply given options
|
|
3455
|
+
let config;
|
|
3456
|
+
if (typeof configureOptions === 'function') {
|
|
3457
|
+
config = configureOptions(this._defaultInputConfigs);
|
|
3458
|
+
}
|
|
3459
|
+
else if (typeof configureOptions === 'object') {
|
|
3460
|
+
config = configureOptions;
|
|
3461
|
+
}
|
|
3462
|
+
else {
|
|
3463
|
+
config = this._defaultInputConfigs;
|
|
3464
|
+
}
|
|
3390
3465
|
// Registering instrumentations
|
|
3391
3466
|
registerInstrumentations({
|
|
3392
3467
|
instrumentations: [
|
|
3393
|
-
getWebAutoInstrumentations()
|
|
3394
|
-
]
|
|
3468
|
+
getWebAutoInstrumentations(config),
|
|
3469
|
+
]
|
|
3395
3470
|
});
|
|
3396
3471
|
}
|
|
3397
3472
|
static GetSampler(tracesSampler, tracesSamplerArg) {
|