@dynatrace/rum-javascript-sdk 1.329.2

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 (115) hide show
  1. package/LICENSE +174 -0
  2. package/README.md +402 -0
  3. package/dist/api/constants.d.ts +1 -0
  4. package/dist/api/constants.js +2 -0
  5. package/dist/api/dynatrace-error.d.ts +3 -0
  6. package/dist/api/dynatrace-error.js +7 -0
  7. package/dist/api/global-adapter.d.ts +1 -0
  8. package/dist/api/global-adapter.js +4 -0
  9. package/dist/api/index.d.ts +65 -0
  10. package/dist/api/index.js +110 -0
  11. package/dist/api/logging.d.ts +2 -0
  12. package/dist/api/logging.js +8 -0
  13. package/dist/api/promises/index.d.ts +85 -0
  14. package/dist/api/promises/index.js +104 -0
  15. package/dist/api/promises/user-actions.d.ts +35 -0
  16. package/dist/api/promises/user-actions.js +48 -0
  17. package/dist/api/promises/wait-for-agent.d.ts +2 -0
  18. package/dist/api/promises/wait-for-agent.js +77 -0
  19. package/dist/api/promises/wait-for-send-exception-event.d.ts +9 -0
  20. package/dist/api/promises/wait-for-send-exception-event.js +18 -0
  21. package/dist/api/promises/wait-for-user-actions.d.ts +9 -0
  22. package/dist/api/promises/wait-for-user-actions.js +18 -0
  23. package/dist/api/type-guards/is-valid-agent.d.ts +2 -0
  24. package/dist/api/type-guards/is-valid-agent.js +4 -0
  25. package/dist/api/user-actions.d.ts +62 -0
  26. package/dist/api/user-actions.js +99 -0
  27. package/dist/testing/install.d.ts +15 -0
  28. package/dist/testing/install.js +19 -0
  29. package/dist/testing/test.d.ts +111 -0
  30. package/dist/testing/test.js +229 -0
  31. package/dist/types/api/dynatrace-api-types.d.ts +319 -0
  32. package/dist/types/api/dynatrace-api-types.js +7 -0
  33. package/dist/types/api/index.d.ts +1 -0
  34. package/dist/types/api/index.js +2 -0
  35. package/dist/types/index-typedoc.d.ts +31 -0
  36. package/dist/types/index-typedoc.js +32 -0
  37. package/dist/types/index.d.ts +11 -0
  38. package/dist/types/index.js +5 -0
  39. package/dist/types/internal/beacon-query.d.ts +29 -0
  40. package/dist/types/internal/beacon-query.js +32 -0
  41. package/dist/types/internal/data-dt-config-scope.d.ts +10 -0
  42. package/dist/types/internal/data-dt-config-scope.js +12 -0
  43. package/dist/types/internal/feature-hashes.d.ts +19 -0
  44. package/dist/types/internal/feature-hashes.js +22 -0
  45. package/dist/types/internal/index.d.ts +3 -0
  46. package/dist/types/internal/index.js +4 -0
  47. package/dist/types/rum-events/event-context/event-context.d.ts +364 -0
  48. package/dist/types/rum-events/event-context/event-context.js +106 -0
  49. package/dist/types/rum-events/event-context/index.d.ts +1 -0
  50. package/dist/types/rum-events/event-context/index.js +2 -0
  51. package/dist/types/rum-events/event-updates.d.ts +4 -0
  52. package/dist/types/rum-events/event-updates.js +2 -0
  53. package/dist/types/rum-events/index.d.ts +19 -0
  54. package/dist/types/rum-events/index.js +20 -0
  55. package/dist/types/rum-events/json-event.d.ts +84 -0
  56. package/dist/types/rum-events/json-event.js +2 -0
  57. package/dist/types/rum-events/rum-biz-event.d.ts +10 -0
  58. package/dist/types/rum-events/rum-biz-event.js +15 -0
  59. package/dist/types/rum-events/rum-event.d.ts +13 -0
  60. package/dist/types/rum-events/rum-event.js +3 -0
  61. package/dist/types/rum-events/rum-internal-selfmonitoring-event.d.ts +114 -0
  62. package/dist/types/rum-events/rum-internal-selfmonitoring-event.js +99 -0
  63. package/dist/types/rum-events/rum-long-task-event.d.ts +18 -0
  64. package/dist/types/rum-events/rum-long-task-event.js +10 -0
  65. package/dist/types/rum-events/rum-page-summary-event.d.ts +370 -0
  66. package/dist/types/rum-events/rum-page-summary-event.js +184 -0
  67. package/dist/types/rum-events/rum-selfmonitoring-event.d.ts +39 -0
  68. package/dist/types/rum-events/rum-selfmonitoring-event.js +32 -0
  69. package/dist/types/rum-events/rum-session-properties-event.d.ts +9 -0
  70. package/dist/types/rum-events/rum-session-properties-event.js +3 -0
  71. package/dist/types/rum-events/rum-standalone-csp-rule-violation-event.d.ts +16 -0
  72. package/dist/types/rum-events/rum-standalone-csp-rule-violation-event.js +3 -0
  73. package/dist/types/rum-events/rum-standalone-exception-event.d.ts +16 -0
  74. package/dist/types/rum-events/rum-standalone-exception-event.js +2 -0
  75. package/dist/types/rum-events/rum-standalone-navigation-event.d.ts +23 -0
  76. package/dist/types/rum-events/rum-standalone-navigation-event.js +6 -0
  77. package/dist/types/rum-events/rum-user-action-event.d.ts +187 -0
  78. package/dist/types/rum-events/rum-user-action-event.js +78 -0
  79. package/dist/types/rum-events/rum-user-interaction-event.d.ts +302 -0
  80. package/dist/types/rum-events/rum-user-interaction-event.js +131 -0
  81. package/dist/types/rum-events/rum-visibility-change-event.d.ts +15 -0
  82. package/dist/types/rum-events/rum-visibility-change-event.js +6 -0
  83. package/dist/types/rum-events/rum-web-request-event.d.ts +269 -0
  84. package/dist/types/rum-events/rum-web-request-event.js +143 -0
  85. package/dist/types/rum-events/schema-versions.d.ts +4 -0
  86. package/dist/types/rum-events/schema-versions.js +5 -0
  87. package/dist/types/rum-events/shared-namespaces-and-fields/csp-fields.d.ts +38 -0
  88. package/dist/types/rum-events/shared-namespaces-and-fields/csp-fields.js +23 -0
  89. package/dist/types/rum-events/shared-namespaces-and-fields/exception-fields.d.ts +26 -0
  90. package/dist/types/rum-events/shared-namespaces-and-fields/exception-fields.js +19 -0
  91. package/dist/types/rum-events/shared-namespaces-and-fields/general-rum-error-fields.d.ts +66 -0
  92. package/dist/types/rum-events/shared-namespaces-and-fields/general-rum-error-fields.js +66 -0
  93. package/dist/types/rum-events/shared-namespaces-and-fields/general-rum-event-fields.d.ts +142 -0
  94. package/dist/types/rum-events/shared-namespaces-and-fields/general-rum-event-fields.js +98 -0
  95. package/dist/types/rum-events/shared-namespaces-and-fields/http-namespace.d.ts +16 -0
  96. package/dist/types/rum-events/shared-namespaces-and-fields/http-namespace.js +11 -0
  97. package/dist/types/rum-events/shared-namespaces-and-fields/index.d.ts +9 -0
  98. package/dist/types/rum-events/shared-namespaces-and-fields/index.js +10 -0
  99. package/dist/types/rum-events/shared-namespaces-and-fields/navigation-fields.d.ts +48 -0
  100. package/dist/types/rum-events/shared-namespaces-and-fields/navigation-fields.js +47 -0
  101. package/dist/types/rum-events/shared-namespaces-and-fields/page-source-fields.d.ts +9 -0
  102. package/dist/types/rum-events/shared-namespaces-and-fields/page-source-fields.js +5 -0
  103. package/dist/types/rum-events/shared-namespaces-and-fields/request-fields.d.ts +14 -0
  104. package/dist/types/rum-events/shared-namespaces-and-fields/request-fields.js +10 -0
  105. package/dist/types/rum-events/shared-namespaces-and-fields/view-source-fields.d.ts +14 -0
  106. package/dist/types/rum-events/shared-namespaces-and-fields/view-source-fields.js +9 -0
  107. package/dist/types/user-actions/index.d.ts +3 -0
  108. package/dist/types/user-actions/index.js +4 -0
  109. package/dist/types/user-actions/user-action-end-event.d.ts +28 -0
  110. package/dist/types/user-actions/user-action-end-event.js +2 -0
  111. package/dist/types/user-actions/user-action-start-options.d.ts +23 -0
  112. package/dist/types/user-actions/user-action-start-options.js +2 -0
  113. package/dist/types/user-actions/user-action-tracker.d.ts +72 -0
  114. package/dist/types/user-actions/user-action-tracker.js +2 -0
  115. package/package.json +115 -0
@@ -0,0 +1,319 @@
1
+ import type { ApiCreatedEventPropertiesEvent, ApiCreatedSessionPropertiesEvent, JSONEvent, JSONObject } from "../rum-events/json-event.js";
2
+ import type { EventContext } from "../rum-events/event-context/event-context.js";
3
+ import type { UserActionStartOptions } from "../user-actions/user-action-start-options.js";
4
+ import type { UserActionTracker } from "../user-actions/user-action-tracker.js";
5
+ /**
6
+ * A method which deactivates behavior when invoked.
7
+ * See the returning method's API for more details.
8
+ *
9
+ * @inline
10
+ * @ignore
11
+ */
12
+ export type Unsubscriber = () => void;
13
+ /**
14
+ * The configuration object provided to the runHealthCheck API.
15
+ *
16
+ * @see runHealthCheck
17
+ * @inline
18
+ * @ignore
19
+ */
20
+ export interface HealthCheckConfig {
21
+ logVerbose?: boolean;
22
+ returnDiagnosticData?: boolean;
23
+ runDetailedOverrideCheck?: boolean;
24
+ }
25
+ /**
26
+ * @category API
27
+ */
28
+ export declare namespace dynatrace {
29
+ /**
30
+ * Sends an event with the provided fields.
31
+ *
32
+ * @example
33
+ * ```typescript
34
+ * dynatrace.sendEvent({
35
+ * "event_properties.prop": "value",
36
+ * "duration": 123,
37
+ * "event_properties.url": "www.dynatrace.com",
38
+ * "event_properties.id": "123456789",
39
+ * });
40
+ *
41
+ * // Using context:
42
+ * document.addEventListener("load", (event) => {
43
+ * dynatrace.sendEvent({
44
+ * "event_properties.prop": "value",
45
+ * "duration": 123,
46
+ * "event_properties.url": "www.dynatrace.com",
47
+ * "event_properties.id": "123456789",
48
+ * }, event); // add the event context here
49
+ * });
50
+ *```
51
+ * @param fields Must be a valid JSON object and cannot contain functions, undefined, Infinity and NaN as
52
+ * values, otherwise they will be replaced with null. The `fields` need to be serializable
53
+ * using JSON.stringify. The resulting event will contain the provided `fields`, and is
54
+ * modified with additional properties, thus also empty objects are valid. Only properties
55
+ * prefixed with `event_properties.`, the `duration` property and the `start_time` property are
56
+ * allowed. String properties are limited to 5000 characters, exceeding characters are cut off.
57
+ * All event property keys must contain only alphabetic characters, numbers,
58
+ * underscores or dots. Each dot must be followed by an alphabetic character. Each underscore
59
+ * must be followed by an alphabetic character or number.
60
+ * @param eventContext An optional context (see {@link dynatrace.addEventModifier}) that can be used to manipulate the
61
+ * result event within the modification callback.
62
+ */
63
+ function sendEvent(fields: ApiCreatedEventPropertiesEvent, eventContext?: unknown): void;
64
+ /**
65
+ * Send a Business Event.
66
+ *
67
+ * With sendBizEvent, you can report a business event. These standalone events are being sent detached from user
68
+ * actions or sessions.
69
+ *
70
+ * Note: Business events are currently only supported on Dynatrace SaaS deployments.
71
+ *
72
+ * @example
73
+ * ```typescript
74
+ * dynatrace.sendBizEvent("type", {
75
+ * prop: "value",
76
+ * name: "biz event name",
77
+ * timestamp: 123,
78
+ * url: "www.dynatrace.com",
79
+ * page_id: "123456789",
80
+ * "window.orientation": "diagonal"
81
+ * });
82
+ *
83
+ * // Using context:
84
+ * document.addEventListener("load", (event) => {
85
+ * dynatrace.sendBizEvent("type", {
86
+ * prop: "value",
87
+ * name: "biz event name",
88
+ * timestamp: 123,
89
+ * url: "www.dynatrace.com",
90
+ * page_id: "123456789",
91
+ * "window.orientation": "diagonal"
92
+ * }, event); // add the event context here
93
+ * });
94
+ *```
95
+ *
96
+ * @internal
97
+ * @param type Mandatory event type
98
+ * @param fields Must be a valid JSON object and cannot contain functions, undefined, Infinity and NaN as
99
+ * values, otherwise they will be replaced with null. The `fields` need to be serializable
100
+ * using JSON.stringify. The resulting event will be populated with `fields` parameter, and
101
+ * modified with additional properties, thus also empty objects are valid.
102
+ * @param eventContext An optional context (see {@link dynatrace.addEventModifier}) that can be used to manipulate the
103
+ * result event within the modification callback. Will be provided as CustomEventContext TODO
104
+ */
105
+ function sendBizEvent(type: string, fields: JSONObject, eventContext?: unknown): void;
106
+ /**
107
+ * Modifies future events with the provided modifier function. Returning a non-object or `null` discards this event
108
+ * and prevents future mutator functions to be executed.
109
+ *
110
+ * Certain reserved fields and namespaces can’t be modified in any way (added, removed or overridden), while others are open for modification.
111
+ * See the public documentation for a detailed list of reserved/open fields (link will be added in the future).
112
+ *
113
+ * The context differs based on the processed event and availability of data.
114
+ * For events sent with {@link dynatrace.sendEvent}, the optionally provided context will be provided as custom context.
115
+ * The context object contains a "type" and optionally a "sub_type" parameter, which can be used to distinguish them.
116
+ *
117
+ * @example
118
+ * ```typescript
119
+ * dynatrace.addEventModifier(function (event) {
120
+ * if (event["event.type"] !== "click") {
121
+ * return event;
122
+ * }
123
+ * return {
124
+ * ...event,
125
+ * "event_properties.prop": "value",
126
+ * "url.full": "www.dynatrace.com",
127
+ * "view.detected_name": "123456789",
128
+ * }
129
+ * });
130
+ *
131
+ * // Using context:
132
+ * dynatrace.addEventModifier(function (event, context) {
133
+ * if (event["event.type"] !== "click") {
134
+ * return event;
135
+ * }
136
+ * if (context?.additionalData) {
137
+ * return {
138
+ * ...event,
139
+ * "event_properties.extra_data": `received extra data: ${context.additionalData}`
140
+ * };
141
+ * }
142
+ * return event;
143
+ * });
144
+ *
145
+ * // Discarding an event:
146
+ * dynatrace.addEventModifier(function (event) {
147
+ * if (event["event.type"] === "click") {
148
+ * return null;
149
+ * }
150
+ * return event;
151
+ * });
152
+ * ```
153
+ *
154
+ * @param eventModifier The modifier function to modify a given (readonly) JSONEvent. It receives an optional context
155
+ * depending on the type of event, if available. The returned event must be a new object, otherwise
156
+ * modification will be ignored. Modification is only allowed for fields declared in
157
+ * {@link AllowedModificationFields}.
158
+ * @returns The unsubscriber function to turn off event modification.
159
+ */
160
+ function addEventModifier(eventModifier: (jsonEvent: Readonly<JSONEvent>, eventContext?: EventContext) => JSONEvent | null): Unsubscriber;
161
+ /**
162
+ * If not already enabled, dynamically loads the Health Check module which will read accumulated health check data
163
+ * and present it in the browser developer tools console.
164
+ *
165
+ * @param config The optional configuration object for the health check.
166
+ * @param config.logVerbose If true, verbose information is included in the health check.
167
+ * @param config.returnDiagnosticData If true, the diagnostic data is returned as array instead of just being logged.
168
+ * @param config.runDetailedOverrideCheck if true, additional information will be logged to the console for overridden native APIs.
169
+ * @returns A promise that settles as soon as the health check has been performed.
170
+ */
171
+ function runHealthCheck(config?: HealthCheckConfig): Promise<unknown[] | undefined>;
172
+ /**
173
+ * Enables debug logging.
174
+ *
175
+ * @internal not public yet
176
+ * @param loggingInformation An object that specifies what should be logged
177
+ * @returns A promise that settles as soon as debug logging has been enabled
178
+ */
179
+ function enableDebugLogging(loggingInformation: Record<string, boolean>): Promise<void> | void;
180
+ /**
181
+ * Use to identify individual users across different browsers, devices, and user sessions.
182
+ *
183
+ * @param value The name of the user. For example, use a name, userid, or your user's email address.
184
+ *
185
+ * @example
186
+ * ```typescript
187
+ * dynatrace.identifyUser("john.doe@example.com");
188
+ * ```
189
+ */
190
+ function identifyUser(value: string): void;
191
+ /**
192
+ * Sends a sessionPropertyEvent.
193
+ *
194
+ * @example
195
+ * ```typescript
196
+ * dynatrace.sendSessionPropertyEvent({
197
+ * "session_properties.some_custom": true,
198
+ * "session_properties.my_id": "m123456",
199
+ * "session_properties.my_other_id_2": "x123",
200
+ * "session_properties.my_fully_other.id3": "id007",
201
+ * });
202
+ *```
203
+ * @param fields Must be a valid JSON object and cannot contain functions, undefined, Infinity and NaN as
204
+ * values, otherwise they will be replaced with null. The `fields` need to be serializable
205
+ * using JSON.stringify. The resulting event will be populated with `fields` parameter, and
206
+ * is modified with additional properties, thus also empty objects are valid. Only properties
207
+ * prefixed with `session_properties.`, the `duration` property and the `start_time` property are
208
+ * allowed. String properties are limited to 5000 characters, exceeding characters are cut off. All
209
+ * session property keys must contain only alphabetic characters, numbers, underscores or
210
+ * dots. Each dot must be followed by an alphabetic character. Each underscore must be followed by an
211
+ * alphabetic character or number.
212
+ */
213
+ function sendSessionPropertyEvent(fields: ApiCreatedSessionPropertiesEvent): void;
214
+ /**
215
+ * This function is only available if the Error module is enabled
216
+ *
217
+ * @param error Must be a valid instance of the Error class. If an invalid value is provided, the error will not be processed or sent.
218
+ * @param fields Optional: Must be a valid JSON object and cannot contain functions, undefined, Infinity and NaN as
219
+ * values, otherwise they will be replaced with null. The `fields` need to be serializable
220
+ * using JSON.stringify. The resulting event will contain the provided `fields`, and is
221
+ * modified with additional properties, thus also empty objects are valid. Only properties
222
+ * prefixed with `event_properties.`, the `duration` property and the `start_time` property are
223
+ * allowed. String properties are limited to 5000 characters, exceeding characters are cut off.
224
+ * All event property keys must contain only alphabetic characters, numbers,
225
+ * underscores or dots. Each dot must be followed by an alphabetic character. Each underscore
226
+ * must be followed by an alphabetic character or number.
227
+ */
228
+ let sendExceptionEvent: ((error: Error, fields?: ApiCreatedEventPropertiesEvent) => void) | undefined;
229
+ /**
230
+ * This property is `undefined` if the User Actions module is disabled.
231
+ *
232
+ * @experimental
233
+ */
234
+ let userActions: UserActions | undefined;
235
+ }
236
+ /**
237
+ * @experimental
238
+ * @category User Actions
239
+ */
240
+ export interface UserActions {
241
+ /**
242
+ * Creates a new controllable user action.
243
+ *
244
+ * @example
245
+ * ```typescript
246
+ * const userAction = dynatrace.userActions.create({ autoClose: false });
247
+ * const unsubscribe = userAction.subscribe(currentUserAction => {
248
+ * console.log(`User action would have been completed due to ${currentUserAction.completeReason}`, event);
249
+ * });
250
+ * // execute user actions
251
+ * userAction.finish();
252
+ * unsubscribe();
253
+ * ```
254
+ *
255
+ * @experimental
256
+ * @param options An optional options object to configure the user action.
257
+ * @param options.autoClose If true, automatically stops the user action using RUM JavaScript user action rules.
258
+ * If false, the user action remains active until the next call to `create(...)` or to `userAction.finish()`.
259
+ * @returns An `UserActionTracker` object that can be started and finished, or `undefined` if the user action module is not enabled.
260
+ */
261
+ create(this: void, options?: UserActionStartOptions): UserActionTracker;
262
+ /**
263
+ * Subscribes to user actions.
264
+ *
265
+ * @example
266
+ * ```typescript
267
+ * const unsubscribe = dynatrace.userActions?.subscribe(userAction => {
268
+ * // Disable automatic userAction completion
269
+ * userAction.autoClose = false;
270
+ * // Execute some requests or mutations, then finish the user action
271
+ * userAction.finish();
272
+ * });
273
+ * // Some time later if you don't want to listen to userActions anymore
274
+ * unsubscribe();
275
+ * ```
276
+ *
277
+ * @experimental
278
+ * @param subscriber A callback function that is called whenever Dynatrace creates a new user action.
279
+ * @returns An unsubscriber function to remove the subscription.
280
+ */
281
+ subscribe(this: void, subscriber: (userAction: UserActionTracker) => void): Unsubscriber;
282
+ /**
283
+ * Disables automatic user action detection. Useful in case it interferes with manual user action handling.
284
+ *
285
+ * @example
286
+ * ```typescript
287
+ * dynatrace.userActions?.setAutomaticDetection(false);
288
+ *
289
+ * async function handleClick(router) {
290
+ * const userAction = dynatrace.userActions?.create({ autoClose: false });
291
+ * // this would normally create an user action that would finish this manual user action
292
+ * await router.redirect("home");
293
+ * userAction.finish();
294
+ * }
295
+ * ```
296
+ *
297
+ * @experimental
298
+ * @param automaticDetection If false, disables automatic user action detection, otherwise enables it.
299
+ */
300
+ setAutomaticDetection(this: void, automaticDetection: boolean): void;
301
+ /**
302
+ * The current user action, or `undefined` if no user action is in progress.
303
+ *
304
+ * @experimental
305
+ * @example
306
+ * ```typescript
307
+ * async function postMessageChannel(message, channel) {
308
+ * const currentUserAction = dynatrace.userActions?.current;
309
+ * if (currentUserAction) {
310
+ * currentUserAction.autoClose = false;
311
+ * }
312
+ * const response = await channel.send(message);
313
+ * currentUserAction?.finish();
314
+ * return response;
315
+ * }
316
+ * ```
317
+ */
318
+ current: UserActionTracker | undefined;
319
+ }
@@ -0,0 +1,7 @@
1
+ /**
2
+ * @category API
3
+ */
4
+ export var dynatrace;
5
+ (function (dynatrace) {
6
+ })(dynatrace || (dynatrace = {}));
7
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynatrace-api-types.js","sourceRoot":"","sources":["../../../source/types/api/dynatrace-api-types.ts"],"names":[],"mappings":"AAgCA;;GAEG;AACH,MAAM,KAAW,SAAS,CAwNzB;AAxND,WAAiB,SAAS;AAwN1B,CAAC,EAxNgB,SAAS,KAAT,SAAS,QAwNzB","sourcesContent":["import type {\n    ApiCreatedEventPropertiesEvent,\n    ApiCreatedSessionPropertiesEvent,\n    JSONEvent,\n    JSONObject\n} from \"../rum-events/json-event.js\";\nimport type { EventContext } from \"../rum-events/event-context/event-context.js\";\nimport type { UserActionStartOptions } from \"../user-actions/user-action-start-options.js\";\nimport type { UserActionTracker } from \"../user-actions/user-action-tracker.js\";\n\n/**\n * A method which deactivates behavior when invoked.\n * See the returning method's API for more details.\n *\n * @inline\n * @ignore\n */\nexport type Unsubscriber = () => void;\n\n/**\n * The configuration object provided to the runHealthCheck API.\n *\n * @see runHealthCheck\n * @inline\n * @ignore\n */\nexport interface HealthCheckConfig {\n    logVerbose?: boolean;\n    returnDiagnosticData?: boolean;\n    runDetailedOverrideCheck?: boolean;\n}\n\n/**\n * @category API\n */\nexport namespace dynatrace {\n    /**\n     * Sends an event with the provided fields.\n     *\n     * @example\n     * ```typescript\n     * dynatrace.sendEvent({\n     *     \"event_properties.prop\": \"value\",\n     *     \"duration\": 123,\n     *     \"event_properties.url\": \"www.dynatrace.com\",\n     *     \"event_properties.id\": \"123456789\",\n     * });\n     *\n     * // Using context:\n     * document.addEventListener(\"load\", (event) => {\n     *     dynatrace.sendEvent({\n     *          \"event_properties.prop\": \"value\",\n     *          \"duration\": 123,\n     *          \"event_properties.url\": \"www.dynatrace.com\",\n     *          \"event_properties.id\": \"123456789\",\n     *     }, event); // add the event context here\n     * });\n     *```\n     * @param fields       Must be a valid JSON object and cannot contain functions, undefined, Infinity and NaN as\n     *                     values, otherwise they will be replaced with null. The `fields` need to be serializable\n     *                     using JSON.stringify. The resulting event will contain the provided `fields`, and is\n     *                     modified with additional properties, thus also empty objects are valid. Only properties\n     *                     prefixed with `event_properties.`, the `duration` property and the `start_time` property are\n     *                     allowed. String properties are limited to 5000 characters, exceeding characters are cut off.\n     *                     All event property keys must contain only alphabetic characters, numbers,\n     *                     underscores or dots. Each dot must be followed by an alphabetic character. Each underscore\n     *                     must be followed by an alphabetic character or number.\n     * @param eventContext An optional context (see {@link dynatrace.addEventModifier}) that can be used to manipulate the\n     *                     result event within the modification callback.\n     */\n    export declare function sendEvent(fields: ApiCreatedEventPropertiesEvent, eventContext?: unknown): void;\n\n    /**\n     * Send a Business Event.\n     *\n     * With sendBizEvent, you can report a business event. These standalone events are being sent detached from user\n     * actions or sessions.\n     *\n     * Note: Business events are currently only supported on Dynatrace SaaS deployments.\n     *\n     * @example\n     * ```typescript\n     * dynatrace.sendBizEvent(\"type\", {\n     *     prop: \"value\",\n     *     name: \"biz event name\",\n     *     timestamp: 123,\n     *     url: \"www.dynatrace.com\",\n     *     page_id: \"123456789\",\n     *     \"window.orientation\": \"diagonal\"\n     * });\n     *\n     * // Using context:\n     * document.addEventListener(\"load\", (event) => {\n     *     dynatrace.sendBizEvent(\"type\", {\n     *         prop: \"value\",\n     *         name: \"biz event name\",\n     *         timestamp: 123,\n     *         url: \"www.dynatrace.com\",\n     *         page_id: \"123456789\",\n     *         \"window.orientation\": \"diagonal\"\n     *     }, event); // add the event context here\n     * });\n     *```\n     *\n     * @internal\n     * @param type         Mandatory event type\n     * @param fields       Must be a valid JSON object and cannot contain functions, undefined, Infinity and NaN as\n     *                     values, otherwise they will be replaced with null. The `fields` need to be serializable\n     *                     using JSON.stringify. The resulting event will be populated with `fields` parameter, and\n     *                     modified with additional properties, thus also empty objects are valid.\n     * @param eventContext An optional context (see {@link dynatrace.addEventModifier}) that can be used to manipulate the\n     *                     result event within the modification callback. Will be provided as CustomEventContext TODO\n     */\n    export declare function sendBizEvent(type: string, fields: JSONObject, eventContext?: unknown): void;\n\n    /**\n     * Modifies future events with the provided modifier function. Returning a non-object or `null` discards this event\n     * and prevents future mutator functions to be executed.\n     *\n     * Certain reserved fields and namespaces can’t be modified in any way (added, removed or overridden), while others are open for modification.\n     * See the public documentation for a detailed list of reserved/open fields (link will be added in the future).\n     *\n     * The context differs based on the processed event and availability of data.\n     * For events sent with {@link dynatrace.sendEvent}, the optionally provided context will be provided as custom context.\n     * The context object contains a \"type\" and optionally a \"sub_type\" parameter, which can be used to distinguish them.\n     *\n     * @example\n     * ```typescript\n     * dynatrace.addEventModifier(function (event) {\n     *     if (event[\"event.type\"] !== \"click\") {\n     *         return event;\n     *     }\n     *     return {\n     *         ...event,\n     *         \"event_properties.prop\": \"value\",\n     *         \"url.full\": \"www.dynatrace.com\",\n     *         \"view.detected_name\": \"123456789\",\n     *     }\n     * });\n     *\n     * // Using context:\n     * dynatrace.addEventModifier(function (event, context) {\n     *     if (event[\"event.type\"] !== \"click\") {\n     *         return event;\n     *     }\n     *     if (context?.additionalData) {\n     *         return {\n     *           ...event,\n     *           \"event_properties.extra_data\": `received extra data: ${context.additionalData}`\n     *         };\n     *     }\n     *     return event;\n     * });\n     *\n     * // Discarding an event:\n     * dynatrace.addEventModifier(function (event) {\n     *   if (event[\"event.type\"] === \"click\") {\n     *     return null;\n     *   }\n     *   return event;\n     * });\n     * ```\n     *\n     * @param eventModifier The modifier function to modify a given (readonly) JSONEvent. It receives an optional context\n     *                      depending on the type of event, if available. The returned event must be a new object, otherwise\n     *                      modification will be ignored. Modification is only allowed for fields declared in\n     *                      {@link AllowedModificationFields}.\n     * @returns             The unsubscriber function to turn off event modification.\n     */\n    export declare function addEventModifier(eventModifier: (jsonEvent: Readonly<JSONEvent>, eventContext?: EventContext) => JSONEvent | null): Unsubscriber;\n\n    /**\n     * If not already enabled, dynamically loads the Health Check module which will read accumulated health check data\n     * and present it in the browser developer tools console.\n     *\n     * @param config                          The optional configuration object for the health check.\n     * @param config.logVerbose               If true, verbose information is included in the health check.\n     * @param config.returnDiagnosticData     If true, the diagnostic data is returned as array instead of just being logged.\n     * @param config.runDetailedOverrideCheck if true, additional information will be logged to the console for overridden native APIs.\n     * @returns                               A promise that settles as soon as the health check has been performed.\n     */\n    export declare function runHealthCheck(config?: HealthCheckConfig): Promise<unknown[] | undefined>;\n\n    /**\n     * Enables debug logging.\n     *\n     * @internal not public yet\n     * @param    loggingInformation An object that specifies what should be logged\n     * @returns                     A promise that settles as soon as debug logging has been enabled\n     */\n    // eslint-disable-next-line @dynatrace/dem-eslint-rules/correct-null-void-undefined -- necessary, because we override the function after loading the healthcheck module\n    export declare function enableDebugLogging(loggingInformation: Record<string, boolean>): Promise<void> | void;\n\n    /**\n     * Use to identify individual users across different browsers, devices, and user sessions.\n     *\n     * @param value The name of the user. For example, use a name, userid, or your user's email address.\n     *\n     * @example\n     * ```typescript\n     * dynatrace.identifyUser(\"john.doe@example.com\");\n     * ```\n     */\n    export declare function identifyUser(value: string): void;\n\n    /**\n     * Sends a sessionPropertyEvent.\n     *\n     * @example\n     * ```typescript\n     * dynatrace.sendSessionPropertyEvent({\n     *     \"session_properties.some_custom\": true,\n     *     \"session_properties.my_id\": \"m123456\",\n     *     \"session_properties.my_other_id_2\": \"x123\",\n     *     \"session_properties.my_fully_other.id3\": \"id007\",\n     * });\n     *```\n     * @param fields Must be a valid JSON object and cannot contain functions, undefined, Infinity and NaN as\n     *               values, otherwise they will be replaced with null. The `fields` need to be serializable\n     *               using JSON.stringify. The resulting event will be populated with `fields` parameter, and\n     *               is modified with additional properties, thus also empty objects are valid. Only properties\n     *               prefixed with `session_properties.`, the `duration` property and the `start_time` property are\n     *               allowed. String properties are limited to 5000 characters, exceeding characters are cut off. All\n     *               session property keys must contain only alphabetic characters, numbers, underscores or\n     *               dots. Each dot must be followed by an alphabetic character. Each underscore must be followed by an\n     *               alphabetic character or number.\n     */\n    export declare function sendSessionPropertyEvent(fields: ApiCreatedSessionPropertiesEvent): void;\n\n    /**\n     * This function is only available if the Error module is enabled\n     *\n     * @param error  Must be a valid instance of the Error class. If an invalid value is provided, the error will not be processed or sent.\n     * @param fields Optional: Must be a valid JSON object and cannot contain functions, undefined, Infinity and NaN as\n     *               values, otherwise they will be replaced with null. The `fields` need to be serializable\n     *               using JSON.stringify. The resulting event will contain the provided `fields`, and is\n     *               modified with additional properties, thus also empty objects are valid. Only properties\n     *               prefixed with `event_properties.`, the `duration` property and the `start_time` property are\n     *               allowed. String properties are limited to 5000 characters, exceeding characters are cut off.\n     *               All event property keys must contain only alphabetic characters, numbers,\n     *               underscores or dots. Each dot must be followed by an alphabetic character. Each underscore\n     *               must be followed by an alphabetic character or number.\n     */\n    export declare let sendExceptionEvent: ((error: Error, fields?: ApiCreatedEventPropertiesEvent) => void) | undefined;\n\n    /**\n     * This property is `undefined` if the User Actions module is disabled.\n     *\n     * @experimental\n     */\n    export declare let userActions: UserActions | undefined;\n}\n\n/**\n * @experimental\n * @category User Actions\n */\nexport interface UserActions {\n    /**\n     * Creates a new controllable user action.\n     *\n     * @example\n     * ```typescript\n     * const userAction = dynatrace.userActions.create({ autoClose: false });\n     * const unsubscribe = userAction.subscribe(currentUserAction => {\n     *     console.log(`User action would have been completed due to ${currentUserAction.completeReason}`, event);\n     * });\n     * // execute user actions\n     * userAction.finish();\n     * unsubscribe();\n     * ```\n     *\n     * @experimental\n     * @param options           An optional options object to configure the user action.\n     * @param options.autoClose If true, automatically stops the user action using RUM JavaScript user action rules.\n     *                          If false, the user action remains active until the next call to `create(...)` or to `userAction.finish()`.\n     * @returns                 An `UserActionTracker` object that can be started and finished, or `undefined` if the user action module is not enabled.\n     */\n    create(this: void, options?: UserActionStartOptions): UserActionTracker;\n\n    /**\n     * Subscribes to user actions.\n     *\n     * @example\n     * ```typescript\n     * const unsubscribe = dynatrace.userActions?.subscribe(userAction => {\n     *     // Disable automatic userAction completion\n     *     userAction.autoClose = false;\n     *     // Execute some requests or mutations, then finish the user action\n     *     userAction.finish();\n     * });\n     * // Some time later if you don't want to listen to userActions anymore\n     * unsubscribe();\n     * ```\n     *\n     * @experimental\n     * @param subscriber A callback function that is called whenever Dynatrace creates a new user action.\n     * @returns          An unsubscriber function to remove the subscription.\n     */\n    subscribe(this: void, subscriber: (userAction: UserActionTracker) => void): Unsubscriber;\n\n    /**\n     * Disables automatic user action detection. Useful in case it interferes with manual user action handling.\n     *\n     * @example\n     * ```typescript\n     * dynatrace.userActions?.setAutomaticDetection(false);\n     *\n     * async function handleClick(router) {\n     *     const userAction = dynatrace.userActions?.create({ autoClose: false });\n     *     // this would normally create an user action that would finish this manual user action\n     *     await router.redirect(\"home\");\n     *     userAction.finish();\n     * }\n     * ```\n     *\n     * @experimental\n     * @param automaticDetection If false, disables automatic user action detection, otherwise enables it.\n     */\n    setAutomaticDetection(this: void, automaticDetection: boolean): void;\n\n    /**\n     * The current user action, or `undefined` if no user action is in progress.\n     *\n     * @experimental\n     * @example\n     * ```typescript\n     * async function postMessageChannel(message, channel) {\n     *   const currentUserAction = dynatrace.userActions?.current;\n     *   if (currentUserAction) {\n     *      currentUserAction.autoClose = false;\n     *   }\n     *   const response = await channel.send(message);\n     *   currentUserAction?.finish();\n     *   return response;\n     * }\n     * ```\n     */\n    current: UserActionTracker | undefined;\n}\n"]}
@@ -0,0 +1 @@
1
+ export * from "./dynatrace-api-types.js";
@@ -0,0 +1,2 @@
1
+ export * from "./dynatrace-api-types.js";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zb3VyY2UvdHlwZXMvYXBpL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9keW5hdHJhY2UtYXBpLXR5cGVzLmpzXCI7XG4iXX0=
@@ -0,0 +1,31 @@
1
+ export * from "./api/dynatrace-api-types.js";
2
+ export * from "./user-actions/user-action-tracker.js";
3
+ export * from "./user-actions/user-action-end-event.js";
4
+ export * from "./user-actions/user-action-start-options.js";
5
+ export * from "./rum-events/event-context/event-context.js";
6
+ export * from "./rum-events/rum-event.js";
7
+ export * from "./rum-events/event-updates.js";
8
+ export * from "./rum-events/json-event.js";
9
+ export * from "./rum-events/rum-biz-event.js";
10
+ export * from "./rum-events/schema-versions.js";
11
+ export * from "./rum-events/rum-user-action-event.js";
12
+ export * from "./rum-events/rum-long-task-event.js";
13
+ export * from "./rum-events/rum-web-request-event.js";
14
+ export * from "./rum-events/rum-page-summary-event.js";
15
+ export * from "./rum-events/rum-selfmonitoring-event.js";
16
+ export * from "./rum-events/rum-user-interaction-event.js";
17
+ export * from "./rum-events/rum-visibility-change-event.js";
18
+ export * from "./rum-events/rum-session-properties-event.js";
19
+ export * from "./rum-events/rum-standalone-exception-event.js";
20
+ export * from "./rum-events/rum-standalone-navigation-event.js";
21
+ export * from "./rum-events/rum-internal-selfmonitoring-event.js";
22
+ export * from "./rum-events/rum-standalone-csp-rule-violation-event.js";
23
+ export * from "./rum-events/shared-namespaces-and-fields/csp-fields.js";
24
+ export * from "./rum-events/shared-namespaces-and-fields/http-namespace.js";
25
+ export * from "./rum-events/shared-namespaces-and-fields/request-fields.js";
26
+ export * from "./rum-events/shared-namespaces-and-fields/exception-fields.js";
27
+ export * from "./rum-events/shared-namespaces-and-fields/navigation-fields.js";
28
+ export * from "./rum-events/shared-namespaces-and-fields/page-source-fields.js";
29
+ export * from "./rum-events/shared-namespaces-and-fields/view-source-fields.js";
30
+ export * from "./rum-events/shared-namespaces-and-fields/general-rum-error-fields.js";
31
+ export * from "./rum-events/shared-namespaces-and-fields/general-rum-event-fields.js";
@@ -0,0 +1,32 @@
1
+ export * from "./api/dynatrace-api-types.js";
2
+ export * from "./user-actions/user-action-tracker.js";
3
+ export * from "./user-actions/user-action-end-event.js";
4
+ export * from "./user-actions/user-action-start-options.js";
5
+ export * from "./rum-events/event-context/event-context.js";
6
+ export * from "./rum-events/rum-event.js";
7
+ export * from "./rum-events/event-updates.js";
8
+ export * from "./rum-events/json-event.js";
9
+ export * from "./rum-events/rum-biz-event.js";
10
+ export * from "./rum-events/schema-versions.js";
11
+ export * from "./rum-events/rum-user-action-event.js";
12
+ export * from "./rum-events/rum-long-task-event.js";
13
+ export * from "./rum-events/rum-web-request-event.js";
14
+ export * from "./rum-events/rum-page-summary-event.js";
15
+ export * from "./rum-events/rum-selfmonitoring-event.js";
16
+ export * from "./rum-events/rum-user-interaction-event.js";
17
+ export * from "./rum-events/rum-visibility-change-event.js";
18
+ export * from "./rum-events/rum-session-properties-event.js";
19
+ export * from "./rum-events/rum-standalone-exception-event.js";
20
+ export * from "./rum-events/rum-standalone-navigation-event.js";
21
+ export * from "./rum-events/rum-internal-selfmonitoring-event.js";
22
+ export * from "./rum-events/rum-standalone-csp-rule-violation-event.js";
23
+ export * from "./rum-events/shared-namespaces-and-fields/csp-fields.js";
24
+ export * from "./rum-events/shared-namespaces-and-fields/http-namespace.js";
25
+ export * from "./rum-events/shared-namespaces-and-fields/request-fields.js";
26
+ export * from "./rum-events/shared-namespaces-and-fields/exception-fields.js";
27
+ export * from "./rum-events/shared-namespaces-and-fields/navigation-fields.js";
28
+ export * from "./rum-events/shared-namespaces-and-fields/page-source-fields.js";
29
+ export * from "./rum-events/shared-namespaces-and-fields/view-source-fields.js";
30
+ export * from "./rum-events/shared-namespaces-and-fields/general-rum-error-fields.js";
31
+ export * from "./rum-events/shared-namespaces-and-fields/general-rum-event-fields.js";
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXgtdHlwZWRvYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NvdXJjZS90eXBlcy9pbmRleC10eXBlZG9jLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLDZEQUE2RCxDQUFDO0FBQzVFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsaUVBQWlFLENBQUM7QUFDaEYsY0FBYyxpRUFBaUUsQ0FBQztBQUNoRixjQUFjLHVFQUF1RSxDQUFDO0FBQ3RGLGNBQWMsdUVBQXVFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hcGkvZHluYXRyYWNlLWFwaS10eXBlcy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXNlci1hY3Rpb25zL3VzZXItYWN0aW9uLXRyYWNrZXIuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3VzZXItYWN0aW9ucy91c2VyLWFjdGlvbi1lbmQtZXZlbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3VzZXItYWN0aW9ucy91c2VyLWFjdGlvbi1zdGFydC1vcHRpb25zLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL2V2ZW50LWNvbnRleHQvZXZlbnQtY29udGV4dC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9ydW0tZXZlbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvZXZlbnQtdXBkYXRlcy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9qc29uLWV2ZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL3J1bS1iaXotZXZlbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvc2NoZW1hLXZlcnNpb25zLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL3J1bS11c2VyLWFjdGlvbi1ldmVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9ydW0tbG9uZy10YXNrLWV2ZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL3J1bS13ZWItcmVxdWVzdC1ldmVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9ydW0tcGFnZS1zdW1tYXJ5LWV2ZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL3J1bS1zZWxmbW9uaXRvcmluZy1ldmVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9ydW0tdXNlci1pbnRlcmFjdGlvbi1ldmVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9ydW0tdmlzaWJpbGl0eS1jaGFuZ2UtZXZlbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvcnVtLXNlc3Npb24tcHJvcGVydGllcy1ldmVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9ydW0tc3RhbmRhbG9uZS1leGNlcHRpb24tZXZlbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvcnVtLXN0YW5kYWxvbmUtbmF2aWdhdGlvbi1ldmVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9ydW0taW50ZXJuYWwtc2VsZm1vbml0b3JpbmctZXZlbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvcnVtLXN0YW5kYWxvbmUtY3NwLXJ1bGUtdmlvbGF0aW9uLWV2ZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL3NoYXJlZC1uYW1lc3BhY2VzLWFuZC1maWVsZHMvY3NwLWZpZWxkcy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVtLWV2ZW50cy9zaGFyZWQtbmFtZXNwYWNlcy1hbmQtZmllbGRzL2h0dHAtbmFtZXNwYWNlLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL3NoYXJlZC1uYW1lc3BhY2VzLWFuZC1maWVsZHMvcmVxdWVzdC1maWVsZHMuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvc2hhcmVkLW5hbWVzcGFjZXMtYW5kLWZpZWxkcy9leGNlcHRpb24tZmllbGRzLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL3NoYXJlZC1uYW1lc3BhY2VzLWFuZC1maWVsZHMvbmF2aWdhdGlvbi1maWVsZHMuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvc2hhcmVkLW5hbWVzcGFjZXMtYW5kLWZpZWxkcy9wYWdlLXNvdXJjZS1maWVsZHMuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvc2hhcmVkLW5hbWVzcGFjZXMtYW5kLWZpZWxkcy92aWV3LXNvdXJjZS1maWVsZHMuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvc2hhcmVkLW5hbWVzcGFjZXMtYW5kLWZpZWxkcy9nZW5lcmFsLXJ1bS1lcnJvci1maWVsZHMuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bS1ldmVudHMvc2hhcmVkLW5hbWVzcGFjZXMtYW5kLWZpZWxkcy9nZW5lcmFsLXJ1bS1ldmVudC1maWVsZHMuanNcIjtcbiJdfQ==
@@ -0,0 +1,11 @@
1
+ import type { dynatrace as DtApi } from "./api/dynatrace-api-types.js";
2
+ declare global {
3
+ var dynatrace: typeof DtApi | undefined;
4
+ interface Window {
5
+ dynatrace: typeof DtApi | undefined;
6
+ }
7
+ }
8
+ export * from "./user-actions/index.js";
9
+ export * from "./api/index.js";
10
+ export * from "./rum-events/index.js";
11
+ export * from "./internal/index.js";
@@ -0,0 +1,5 @@
1
+ export * from "./user-actions/index.js";
2
+ export * from "./api/index.js";
3
+ export * from "./rum-events/index.js";
4
+ export * from "./internal/index.js";
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zb3VyY2UvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU0EsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgZHluYXRyYWNlIGFzIER0QXBpIH0gZnJvbSBcIi4vYXBpL2R5bmF0cmFjZS1hcGktdHlwZXMuanNcIjtcblxuZGVjbGFyZSBnbG9iYWwge1xuICAgIHZhciBkeW5hdHJhY2U6IHR5cGVvZiBEdEFwaSB8IHVuZGVmaW5lZDsgLy8gTk9TT05BUlxuICAgIGludGVyZmFjZSBXaW5kb3cge1xuICAgICAgICBkeW5hdHJhY2U6IHR5cGVvZiBEdEFwaSB8IHVuZGVmaW5lZDtcbiAgICB9XG59XG5cbmV4cG9ydCAqIGZyb20gXCIuL3VzZXItYWN0aW9ucy9pbmRleC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vYXBpL2luZGV4LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW0tZXZlbnRzL2luZGV4LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pbnRlcm5hbC9pbmRleC5qc1wiO1xuIl19
@@ -0,0 +1,29 @@
1
+ /**
2
+ * @internal
3
+ */
4
+ export declare const enum BeaconQueryKeys {
5
+ APPLICATION_ID = "ai",
6
+ BEACON_TYPE = "ty",
7
+ BODY_CRC = "bc",
8
+ CONFIGURATION_REVISION = "cr",
9
+ CONTENT_TYPE = "cy",
10
+ END = "end",
11
+ ENVIRONMENT = "en",
12
+ FRONTEND_AGENT_VERSION = "av",
13
+ PROTOCOL_VERSION = "pv",
14
+ QUERY_CRC = "qc",
15
+ SENDING_CAUSE = "sc",
16
+ SENDING_STRATEGY = "ss",
17
+ TIMESTAMP = "st"
18
+ }
19
+ /**
20
+ * @internal
21
+ */
22
+ export declare const enum OptionalBeaconQueryKeys {
23
+ COMPRESSION = "co",
24
+ DT_ADK = "da",// unused until further notice
25
+ PRIORITY = "pr",
26
+ RETRY_COUNT = "rc",
27
+ RETRY_REASON = "rr",
28
+ SESSION_INFORMATION = "si"
29
+ }
@@ -0,0 +1,32 @@
1
+ /**
2
+ * @internal
3
+ */
4
+ export var BeaconQueryKeys;
5
+ (function (BeaconQueryKeys) {
6
+ BeaconQueryKeys["APPLICATION_ID"] = "ai";
7
+ BeaconQueryKeys["BEACON_TYPE"] = "ty";
8
+ BeaconQueryKeys["BODY_CRC"] = "bc";
9
+ BeaconQueryKeys["CONFIGURATION_REVISION"] = "cr";
10
+ BeaconQueryKeys["CONTENT_TYPE"] = "cy";
11
+ BeaconQueryKeys["END"] = "end";
12
+ BeaconQueryKeys["ENVIRONMENT"] = "en";
13
+ BeaconQueryKeys["FRONTEND_AGENT_VERSION"] = "av";
14
+ BeaconQueryKeys["PROTOCOL_VERSION"] = "pv";
15
+ BeaconQueryKeys["QUERY_CRC"] = "qc";
16
+ BeaconQueryKeys["SENDING_CAUSE"] = "sc";
17
+ BeaconQueryKeys["SENDING_STRATEGY"] = "ss";
18
+ BeaconQueryKeys["TIMESTAMP"] = "st";
19
+ })(BeaconQueryKeys || (BeaconQueryKeys = {}));
20
+ /**
21
+ * @internal
22
+ */
23
+ export var OptionalBeaconQueryKeys;
24
+ (function (OptionalBeaconQueryKeys) {
25
+ OptionalBeaconQueryKeys["COMPRESSION"] = "co";
26
+ OptionalBeaconQueryKeys["DT_ADK"] = "da";
27
+ OptionalBeaconQueryKeys["PRIORITY"] = "pr";
28
+ OptionalBeaconQueryKeys["RETRY_COUNT"] = "rc";
29
+ OptionalBeaconQueryKeys["RETRY_REASON"] = "rr";
30
+ OptionalBeaconQueryKeys["SESSION_INFORMATION"] = "si";
31
+ })(OptionalBeaconQueryKeys || (OptionalBeaconQueryKeys = {}));
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmVhY29uLXF1ZXJ5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc291cmNlL3R5cGVzL2ludGVybmFsL2JlYWNvbi1xdWVyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBTixJQUFrQixlQWNqQjtBQWRELFdBQWtCLGVBQWU7SUFDN0Isd0NBQXFCLENBQUE7SUFDckIscUNBQWtCLENBQUE7SUFDbEIsa0NBQWUsQ0FBQTtJQUNmLGdEQUE2QixDQUFBO0lBQzdCLHNDQUFtQixDQUFBO0lBQ25CLDhCQUFXLENBQUE7SUFDWCxxQ0FBa0IsQ0FBQTtJQUNsQixnREFBNkIsQ0FBQTtJQUM3QiwwQ0FBdUIsQ0FBQTtJQUN2QixtQ0FBZ0IsQ0FBQTtJQUNoQix1Q0FBb0IsQ0FBQTtJQUNwQiwwQ0FBdUIsQ0FBQTtJQUN2QixtQ0FBZ0IsQ0FBQTtBQUNwQixDQUFDLEVBZGlCLGVBQWUsS0FBZixlQUFlLFFBY2hDO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLENBQU4sSUFBa0IsdUJBT2pCO0FBUEQsV0FBa0IsdUJBQXVCO0lBQ3JDLDZDQUFrQixDQUFBO0lBQ2xCLHdDQUFhLENBQUE7SUFDYiwwQ0FBZSxDQUFBO0lBQ2YsNkNBQWtCLENBQUE7SUFDbEIsOENBQW1CLENBQUE7SUFDbkIscURBQTBCLENBQUE7QUFDOUIsQ0FBQyxFQVBpQix1QkFBdUIsS0FBdkIsdUJBQXVCLFFBT3hDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGNvbnN0IGVudW0gQmVhY29uUXVlcnlLZXlzIHtcbiAgICBBUFBMSUNBVElPTl9JRCA9IFwiYWlcIixcbiAgICBCRUFDT05fVFlQRSA9IFwidHlcIixcbiAgICBCT0RZX0NSQyA9IFwiYmNcIixcbiAgICBDT05GSUdVUkFUSU9OX1JFVklTSU9OID0gXCJjclwiLFxuICAgIENPTlRFTlRfVFlQRSA9IFwiY3lcIixcbiAgICBFTkQgPSBcImVuZFwiLFxuICAgIEVOVklST05NRU5UID0gXCJlblwiLFxuICAgIEZST05URU5EX0FHRU5UX1ZFUlNJT04gPSBcImF2XCIsXG4gICAgUFJPVE9DT0xfVkVSU0lPTiA9IFwicHZcIixcbiAgICBRVUVSWV9DUkMgPSBcInFjXCIsXG4gICAgU0VORElOR19DQVVTRSA9IFwic2NcIixcbiAgICBTRU5ESU5HX1NUUkFURUdZID0gXCJzc1wiLFxuICAgIFRJTUVTVEFNUCA9IFwic3RcIlxufVxuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY29uc3QgZW51bSBPcHRpb25hbEJlYWNvblF1ZXJ5S2V5cyB7XG4gICAgQ09NUFJFU1NJT04gPSBcImNvXCIsXG4gICAgRFRfQURLID0gXCJkYVwiLCAvLyB1bnVzZWQgdW50aWwgZnVydGhlciBub3RpY2VcbiAgICBQUklPUklUWSA9IFwicHJcIixcbiAgICBSRVRSWV9DT1VOVCA9IFwicmNcIixcbiAgICBSRVRSWV9SRUFTT04gPSBcInJyXCIsXG4gICAgU0VTU0lPTl9JTkZPUk1BVElPTiA9IFwic2lcIlxufVxuIl19
@@ -0,0 +1,10 @@
1
+ /**
2
+ * @internal
3
+ */
4
+ export declare const enum DataDtConfigScope {
5
+ APP_CONFIG = "data-appconfig",
6
+ BASE_CONFIG = "data-config",
7
+ DEBUG_CONFIG = "data-debugconfig",
8
+ ENV_CONFIG = "data-envconfig",
9
+ SYNTHETIC_CONFIG = "data-syntheticconfig"
10
+ }
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @internal
3
+ */
4
+ export var DataDtConfigScope;
5
+ (function (DataDtConfigScope) {
6
+ DataDtConfigScope["APP_CONFIG"] = "data-appconfig";
7
+ DataDtConfigScope["BASE_CONFIG"] = "data-config";
8
+ DataDtConfigScope["DEBUG_CONFIG"] = "data-debugconfig";
9
+ DataDtConfigScope["ENV_CONFIG"] = "data-envconfig";
10
+ DataDtConfigScope["SYNTHETIC_CONFIG"] = "data-syntheticconfig";
11
+ })(DataDtConfigScope || (DataDtConfigScope = {}));
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1kdC1jb25maWctc2NvcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zb3VyY2UvdHlwZXMvaW50ZXJuYWwvZGF0YS1kdC1jb25maWctc2NvcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxNQUFNLENBQU4sSUFBa0IsaUJBTWpCO0FBTkQsV0FBa0IsaUJBQWlCO0lBQy9CLGtEQUE2QixDQUFBO0lBQzdCLGdEQUEyQixDQUFBO0lBQzNCLHNEQUFpQyxDQUFBO0lBQ2pDLGtEQUE2QixDQUFBO0lBQzdCLDhEQUF5QyxDQUFBO0FBQzdDLENBQUMsRUFOaUIsaUJBQWlCLEtBQWpCLGlCQUFpQixRQU1sQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBjb25zdCBlbnVtIERhdGFEdENvbmZpZ1Njb3BlIHtcbiAgICBBUFBfQ09ORklHID0gXCJkYXRhLWFwcGNvbmZpZ1wiLFxuICAgIEJBU0VfQ09ORklHID0gXCJkYXRhLWNvbmZpZ1wiLFxuICAgIERFQlVHX0NPTkZJRyA9IFwiZGF0YS1kZWJ1Z2NvbmZpZ1wiLFxuICAgIEVOVl9DT05GSUcgPSBcImRhdGEtZW52Y29uZmlnXCIsXG4gICAgU1lOVEhFVElDX0NPTkZJRyA9IFwiZGF0YS1zeW50aGV0aWNjb25maWdcIlxufVxuIl19
@@ -0,0 +1,19 @@
1
+ /**
2
+ * @internal
3
+ */
4
+ export declare const enum FeatureHashes {
5
+ F1_CORE_GEN3 = "1",
6
+ F3_HEALTH_CHECK = "3",
7
+ F5_ERRORS = "5",
8
+ F8_FETCH_DETECTION = "8",
9
+ F9_PAGE_SUMMARY = "9",
10
+ FH_TEST_HELPER = "H",
11
+ FM_METADATA_CAPTURING = "M",
12
+ FP_NAVIGATION = "P",
13
+ FR_RESOURCE_TIMINGS = "R",
14
+ Fs_SESSIONS = "s",
15
+ FT_USER_ACTIONS = "T",
16
+ FU_USER_INTERACTION = "U",
17
+ FX_XHR_DETECTION = "X",
18
+ FY_SYNTHETIC = "Y"
19
+ }
@@ -0,0 +1,22 @@
1
+ /**
2
+ * @internal
3
+ */
4
+ export var FeatureHashes;
5
+ (function (FeatureHashes) {
6
+ FeatureHashes["F1_CORE_GEN3"] = "1";
7
+ FeatureHashes["F3_HEALTH_CHECK"] = "3";
8
+ FeatureHashes["F5_ERRORS"] = "5";
9
+ FeatureHashes["F8_FETCH_DETECTION"] = "8";
10
+ FeatureHashes["F9_PAGE_SUMMARY"] = "9";
11
+ FeatureHashes["FH_TEST_HELPER"] = "H";
12
+ FeatureHashes["FM_METADATA_CAPTURING"] = "M";
13
+ FeatureHashes["FP_NAVIGATION"] = "P";
14
+ FeatureHashes["FR_RESOURCE_TIMINGS"] = "R";
15
+ // eslint-disable-next-line @typescript-eslint/naming-convention -- need to follow feature hash name
16
+ FeatureHashes["Fs_SESSIONS"] = "s";
17
+ FeatureHashes["FT_USER_ACTIONS"] = "T";
18
+ FeatureHashes["FU_USER_INTERACTION"] = "U";
19
+ FeatureHashes["FX_XHR_DETECTION"] = "X";
20
+ FeatureHashes["FY_SYNTHETIC"] = "Y";
21
+ })(FeatureHashes || (FeatureHashes = {}));
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVhdHVyZS1oYXNoZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zb3VyY2UvdHlwZXMvaW50ZXJuYWwvZmVhdHVyZS1oYXNoZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxNQUFNLENBQU4sSUFBa0IsYUFnQmpCO0FBaEJELFdBQWtCLGFBQWE7SUFDM0IsbUNBQWtCLENBQUE7SUFDbEIsc0NBQXFCLENBQUE7SUFDckIsZ0NBQWUsQ0FBQTtJQUNmLHlDQUF3QixDQUFBO0lBQ3hCLHNDQUFxQixDQUFBO0lBQ3JCLHFDQUFvQixDQUFBO0lBQ3BCLDRDQUEyQixDQUFBO0lBQzNCLG9DQUFtQixDQUFBO0lBQ25CLDBDQUF5QixDQUFBO0lBQ3pCLG9HQUFvRztJQUNwRyxrQ0FBaUIsQ0FBQTtJQUNqQixzQ0FBcUIsQ0FBQTtJQUNyQiwwQ0FBeUIsQ0FBQTtJQUN6Qix1Q0FBc0IsQ0FBQTtJQUN0QixtQ0FBa0IsQ0FBQTtBQUN0QixDQUFDLEVBaEJpQixhQUFhLEtBQWIsYUFBYSxRQWdCOUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY29uc3QgZW51bSBGZWF0dXJlSGFzaGVzIHtcbiAgICBGMV9DT1JFX0dFTjMgPSBcIjFcIixcbiAgICBGM19IRUFMVEhfQ0hFQ0sgPSBcIjNcIixcbiAgICBGNV9FUlJPUlMgPSBcIjVcIixcbiAgICBGOF9GRVRDSF9ERVRFQ1RJT04gPSBcIjhcIixcbiAgICBGOV9QQUdFX1NVTU1BUlkgPSBcIjlcIixcbiAgICBGSF9URVNUX0hFTFBFUiA9IFwiSFwiLFxuICAgIEZNX01FVEFEQVRBX0NBUFRVUklORyA9IFwiTVwiLFxuICAgIEZQX05BVklHQVRJT04gPSBcIlBcIixcbiAgICBGUl9SRVNPVVJDRV9USU1JTkdTID0gXCJSXCIsXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvbiAtLSBuZWVkIHRvIGZvbGxvdyBmZWF0dXJlIGhhc2ggbmFtZVxuICAgIEZzX1NFU1NJT05TID0gXCJzXCIsXG4gICAgRlRfVVNFUl9BQ1RJT05TID0gXCJUXCIsXG4gICAgRlVfVVNFUl9JTlRFUkFDVElPTiA9IFwiVVwiLFxuICAgIEZYX1hIUl9ERVRFQ1RJT04gPSBcIlhcIixcbiAgICBGWV9TWU5USEVUSUMgPSBcIllcIlxufVxuIl19
@@ -0,0 +1,3 @@
1
+ export * from "./beacon-query.js";
2
+ export * from "./data-dt-config-scope.js";
3
+ export * from "./feature-hashes.js";
@@ -0,0 +1,4 @@
1
+ export * from "./beacon-query.js";
2
+ export * from "./data-dt-config-scope.js";
3
+ export * from "./feature-hashes.js";
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zb3VyY2UvdHlwZXMvaW50ZXJuYWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMscUJBQXFCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9iZWFjb24tcXVlcnkuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RhdGEtZHQtY29uZmlnLXNjb3BlLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9mZWF0dXJlLWhhc2hlcy5qc1wiO1xuIl19