diff --git a/AISKULight/Tests/Unit/src/AISKULightSize.Tests.ts b/AISKULight/Tests/Unit/src/AISKULightSize.Tests.ts index f94307637..d80a8821e 100644 --- a/AISKULight/Tests/Unit/src/AISKULightSize.Tests.ts +++ b/AISKULight/Tests/Unit/src/AISKULightSize.Tests.ts @@ -2,8 +2,8 @@ import { AITestClass, Assert } from "@microsoft/ai-test-framework"; import * as pako from "pako"; export class AISKULightSizeCheck extends AITestClass { - private readonly MAX_RAW_SIZE = 81; - private readonly MAX_BUNDLE_SIZE = 81; + private readonly MAX_RAW_SIZE = 82; + private readonly MAX_BUNDLE_SIZE = 82; private readonly MAX_RAW_DEFLATE_SIZE = 34; private readonly MAX_BUNDLE_DEFLATE_SIZE = 34; private readonly rawFilePath = "../dist/es5/applicationinsights-web-basic.min.js"; diff --git a/channels/applicationinsights-channel-js/Tests/Unit/src/Sender.tests.ts b/channels/applicationinsights-channel-js/Tests/Unit/src/Sender.tests.ts index 55f925680..b311baac4 100644 --- a/channels/applicationinsights-channel-js/Tests/Unit/src/Sender.tests.ts +++ b/channels/applicationinsights-channel-js/Tests/Unit/src/Sender.tests.ts @@ -3,7 +3,7 @@ import { Sender } from "../../../src/Sender"; import { IOfflineListener, createOfflineListener } from "@microsoft/applicationinsights-common"; import { EnvelopeCreator } from '../../../src/EnvelopeCreator'; import { Exception, CtxTagKeys, isBeaconApiSupported, DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH, utlCanUseSessionStorage, utlGetSessionStorage, utlSetSessionStorage } from "@microsoft/applicationinsights-common"; -import { ITelemetryItem, AppInsightsCore, ITelemetryPlugin, DiagnosticLogger, NotificationManager, SendRequestReason, _eInternalMessageId, getGlobalInst, safeGetLogger, getJSON, isString, isArray, arrForEach, isBeaconsSupported, IXHROverride, IPayloadData, isFetchSupported} from "@microsoft/applicationinsights-core-js"; +import { ITelemetryItem, AppInsightsCore, ITelemetryPlugin, DiagnosticLogger, NotificationManager, SendRequestReason, _eInternalMessageId, getGlobalInst, safeGetLogger, getJSON, isString, isArray, arrForEach, isBeaconsSupported, IXHROverride, IPayloadData, isFetchSupported, TransportType, getWindow} from "@microsoft/applicationinsights-core-js"; import { ArraySendBuffer, SessionStorageSendBuffer } from "../../../src/SendBuffer"; import { ISenderConfig } from "../../../src/Interfaces"; @@ -1091,54 +1091,339 @@ export class SenderTests extends AITestClass { } }); + this.testCase({ - name: 'BeaconAPI is not used when isBeaconApiDisabled flag is false but payload size is over 64k, fall off to xhr sender', - useFakeTimers: true, + name: 'Unload Transport Type: User provide fetch in unloadtransports, but it is disabled, so we should use beacon', + test: () => { + let window = getWindow(); + let fakeXMLHttpRequest = (window as any).XMLHttpRequest; + let fetchstub = this.sandbox.stub((window as any), "fetch"); + + let sendBeaconCalled = false; + this.hookSendBeacon((url: string) => { + sendBeaconCalled = true; + return true; + }); + + let config = { + endpointUrl: "https//: test", + emitLineDelimitedJson: false, + maxBatchInterval: 15000, + maxBatchSizeInBytes: 102400, + disableTelemetry: false, + enableSessionStorageBuffer: true, + isRetryDisabled: false, + isBeaconApiDisabled: false, + disableXhr: false, + onunloadDisableFetch: true, + onunloadDisableBeacon: false, + instrumentationKey:"key", + namePrefix: "", + samplingPercentage: 100, + customHeaders: [{header:"header",value:"val" }], + convertUndefined: "", + eventsLimitInMem: 10000, + unloadTransports: [TransportType.Fetch] + } as ISenderConfig; + + const sender = new Sender(); + const cr = new AppInsightsCore(); + var coreConfig = { + instrumentationKey: "", + extensionConfig: {[sender.identifier]: config} + }; + + cr.initialize(coreConfig, [sender]); + + this.onDone(() => { + sender.teardown(); + }); + + const telemetryItem: ITelemetryItem = { + name: 'fake item', + iKey: 'iKey', + baseType: 'some type', + baseData: {} + }; + + QUnit.assert.ok(isBeaconApiSupported(), "Beacon API is supported"); + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API was not called before"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender was not called before"); + + try { + sender.processTelemetry(telemetryItem, null); + sender.onunloadFlush(); + } catch(e) { + QUnit.assert.ok(false); + } + + QUnit.assert.equal(true, sendBeaconCalled, "Beacon API should be called"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender is not called"); + QUnit.assert.ok(!fetchstub.called, "fetch sender is blocked"); + // store it back + (window as any).XMLHttpRequest = fakeXMLHttpRequest; + } + }); + + this.testCase({ + name: 'Unload Transport Type: User provide fetch in unloadtransports, we should use fetch', + test: () => { + let window = getWindow(); + let fakeXMLHttpRequest = (window as any).XMLHttpRequest; + let fetchstub = this.sandbox.stub((window as any), "fetch"); + + let sendBeaconCalled = false; + this.hookSendBeacon((url: string) => { + sendBeaconCalled = true; + return true; + }); + + let config = { + endpointUrl: "https//: test", + emitLineDelimitedJson: false, + maxBatchInterval: 15000, + maxBatchSizeInBytes: 102400, + disableTelemetry: false, + enableSessionStorageBuffer: true, + isRetryDisabled: false, + isBeaconApiDisabled: false, + disableXhr: false, + onunloadDisableFetch: false, + onunloadDisableBeacon: false, + instrumentationKey:"key", + namePrefix: "", + samplingPercentage: 100, + customHeaders: [{header:"header",value:"val" }], + convertUndefined: "", + eventsLimitInMem: 10000, + unloadTransports: [TransportType.Fetch] + } as ISenderConfig; + + const sender = new Sender(); + const cr = new AppInsightsCore(); + var coreConfig = { + instrumentationKey: "", + extensionConfig: {[sender.identifier]: config} + }; + + cr.initialize(coreConfig, [sender]); + + this.onDone(() => { + sender.teardown(); + }); + + const telemetryItem: ITelemetryItem = { + name: 'fake item', + iKey: 'iKey', + baseType: 'some type', + baseData: {} + }; + + QUnit.assert.ok(isBeaconApiSupported(), "Beacon API is supported"); + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API was not called before"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender was not called before"); + + try { + sender.processTelemetry(telemetryItem, null); + sender.onunloadFlush(); + } catch(e) { + QUnit.assert.ok(false); + } + + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API should not be called"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender is not called"); + QUnit.assert.ok(fetchstub.called, "fetch sender is called"); + // store it back + (window as any).XMLHttpRequest = fakeXMLHttpRequest; + } + }); + + + this.testCase({ + name: 'Unload Transport Type: User provide beacon in unloadtransports, we should use beacon', test: () => { + let window = getWindow(); + let fakeXMLHttpRequest = (window as any).XMLHttpRequest; + let fetchstub = this.sandbox.stub((window as any), "fetch"); + + let sendBeaconCalled = false; + this.hookSendBeacon((url: string) => { + sendBeaconCalled = true; + return true; + }); + + let config = { + endpointUrl: "https//: test", + emitLineDelimitedJson: false, + maxBatchInterval: 15000, + maxBatchSizeInBytes: 102400, + disableTelemetry: false, + enableSessionStorageBuffer: true, + isRetryDisabled: false, + isBeaconApiDisabled: false, + disableXhr: false, + onunloadDisableFetch: false, + onunloadDisableBeacon: false, + instrumentationKey:"key", + namePrefix: "", + samplingPercentage: 100, + customHeaders: [{header:"header",value:"val" }], + convertUndefined: "", + eventsLimitInMem: 10000, + unloadTransports: [TransportType.Beacon] + } as ISenderConfig; + + const sender = new Sender(); + const cr = new AppInsightsCore(); + var coreConfig = { + instrumentationKey: "", + extensionConfig: {[sender.identifier]: config} + }; + + cr.initialize(coreConfig, [sender]); + + this.onDone(() => { + sender.teardown(); + }); + + const telemetryItem: ITelemetryItem = { + name: 'fake item', + iKey: 'iKey', + baseType: 'some type', + baseData: {} + }; + + QUnit.assert.ok(isBeaconApiSupported(), "Beacon API is supported"); + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API was not called before"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender was not called before"); + + try { + sender.processTelemetry(telemetryItem, null); + sender.onunloadFlush(); + } catch(e) { + QUnit.assert.ok(false); + } + + QUnit.assert.equal(true, sendBeaconCalled, "Beacon API should be called"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender is not called"); + QUnit.assert.ok(!fetchstub.called, "fetch sender is not called"); + // store it back + (window as any).XMLHttpRequest = fakeXMLHttpRequest; + } + }); + + this.testCase({ + name: 'Transport Type: isBeaconApiDisabled is true and User provide beacon in transports, we should still block beacon', + test: () => { + let window = getWindow(); + let fakeXMLHttpRequest = (window as any).XMLHttpRequest; + let fetchstub = this.sandbox.stub((window as any), "fetch"); + let sendBeaconCalled = false; this.hookSendBeacon((url: string) => { sendBeaconCalled = true; return false; }); + let config = { + endpointUrl: "https//: test", + emitLineDelimitedJson: false, + maxBatchInterval: 15000, + maxBatchSizeInBytes: 102400, + disableTelemetry: false, + enableSessionStorageBuffer: true, + isRetryDisabled: false, + isBeaconApiDisabled: true, + disableXhr: false, + onunloadDisableFetch: false, + onunloadDisableBeacon: false, + instrumentationKey:"key", + namePrefix: "", + samplingPercentage: 100, + customHeaders: [{header:"header",value:"val" }], + convertUndefined: "", + eventsLimitInMem: 10000, + transports: [TransportType.Beacon] + } as ISenderConfig; + const sender = new Sender(); const cr = new AppInsightsCore(); - cr["logger"] = new DiagnosticLogger(); - const MAX_PROPERTIES_SIZE = 8000; - const payload = new Array(MAX_PROPERTIES_SIZE).join('a'); + var coreConfig = { + instrumentationKey: "", + extensionConfig: {[sender.identifier]: config} + }; + + cr.initialize(coreConfig, [sender]); - sender.initialize({ - instrumentationKey: 'abc', - isBeaconApiDisabled: false - }, cr, []); this.onDone(() => { sender.teardown(); }); - const telemetryItems: ITelemetryItem[] = []; - for (let i = 0; i < 8; i ++) { - const telemetryItem: ITelemetryItem = { - name: 'fake item', - iKey: 'iKey', - baseType: 'some type', - baseData: {}, - data: { - properties: { - payload - } - } - }; - telemetryItems[i] = telemetryItem; + const telemetryItem: ITelemetryItem = { + name: 'fake item', + iKey: 'iKey', + baseType: 'some type', + baseData: {} + }; + + QUnit.assert.ok(isBeaconApiSupported(), "Beacon API is supported"); + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API was not called before"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender was not called before"); + + try { + sender.processTelemetry(telemetryItem, null); + sender.flush(); + } catch(e) { + QUnit.assert.ok(false); } + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API is blocked, Beacon API should not be called"); + QUnit.assert.equal(1, this._getXhrRequests().length, "xhr sender is called"); + QUnit.assert.ok(!fetchstub.called, "fetch sender is not called"); + // store it back + (window as any).XMLHttpRequest = fakeXMLHttpRequest; + } + }); + this.testCase({ + name: 'Transport Type: isBeaconApiDisabled is false and User provide beacon in transports, we should pick beacon', + useFakeTimers: true, + test: () => { + let sendBeaconCalled = false; + this.hookSendBeacon((url: string) => { + sendBeaconCalled = true; + return true; + }); + let config = { + isBeaconApiDisabled: false, + disableXhr: false, + transports: [TransportType.Beacon] + } as ISenderConfig; + + const sender = new Sender(); + const cr = new AppInsightsCore(); + var coreConfig = { + instrumentationKey: "", + extensionConfig: {[sender.identifier]: config} + }; + + cr.initialize(coreConfig, [sender]); + + this.onDone(() => { + sender.teardown(); + }); + const telemetryItem: ITelemetryItem = { + name: 'fake item', + iKey: 'iKey', + baseType: 'some type', + baseData: {} + }; + QUnit.assert.ok(isBeaconApiSupported(), "Beacon API is supported"); QUnit.assert.equal(false, sendBeaconCalled, "Beacon API was not called before"); QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender was not called before"); try { - for (let i = 0; i < 8; i++) { - sender.processTelemetry(telemetryItems[i], null); - } + sender.processTelemetry(telemetryItem, null); sender.flush(); } catch(e) { QUnit.assert.ok(false); @@ -1146,15 +1431,163 @@ export class SenderTests extends AITestClass { this.clock.tick(15000); - QUnit.assert.equal(true, sendBeaconCalled, "Beacon API is enabled but payload is over size, Beacon API is called"); - QUnit.assert.ok(this._getXhrRequests().length > 0, "xhr sender is called when payload is over size"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender is not called when Beacon API is enabled"); + QUnit.assert.equal(true, sendBeaconCalled, "Beacon API is enabled, Beacon API is called"); + } + }); + + + + this.testCase({ + name: 'Transport Type: disableXhr is false, and user provide xhr in transports', + test: () => { + let window = getWindow(); + let fakeXMLHttpRequest = (window as any).XMLHttpRequest; + let fetchstub = this.sandbox.stub((window as any), "fetch"); + + let sendBeaconCalled = false; + this.hookSendBeacon((url: string) => { + sendBeaconCalled = true; + return false; + }); + + let config = { + endpointUrl: "https//: test", + emitLineDelimitedJson: false, + maxBatchInterval: 15000, + maxBatchSizeInBytes: 102400, + disableTelemetry: false, + enableSessionStorageBuffer: true, + isRetryDisabled: false, + isBeaconApiDisabled:true, + disableXhr: false, + onunloadDisableFetch: false, + onunloadDisableBeacon: false, + instrumentationKey:"key", + namePrefix: "", + samplingPercentage: 100, + customHeaders: [{header:"header",value:"val" }], + convertUndefined: "", + eventsLimitInMem: 10000, + transports: [TransportType.Xhr] + } as ISenderConfig; + + const sender = new Sender(); + const cr = new AppInsightsCore(); + var coreConfig = { + instrumentationKey: "", + extensionConfig: {[sender.identifier]: config} + }; + + cr.initialize(coreConfig, [sender]); + + this.onDone(() => { + sender.teardown(); + }); + + const telemetryItem: ITelemetryItem = { + name: 'fake item', + iKey: 'iKey', + baseType: 'some type', + baseData: {} + }; + + QUnit.assert.ok(isBeaconApiSupported(), "Beacon API is supported"); + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API was not called before"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender was not called before"); + + try { + sender.processTelemetry(telemetryItem, null); + sender.flush(); + } catch(e) { + QUnit.assert.ok(false); + } + + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API is disabled, Beacon API is not called"); + QUnit.assert.equal(1, this._getXhrRequests().length, "xhr sender is called"); + QUnit.assert.ok(!fetchstub.called, "fetch sender is not called"); + // store it back + (window as any).XMLHttpRequest = fakeXMLHttpRequest; + } + }); + + this.testCase({ + name: 'Transport Type: disableXhr is false, but user provide fetch in transports', + test: () => { + let window = getWindow(); + let fakeXMLHttpRequest = (window as any).XMLHttpRequest; + let fetchstub = this.sandbox.stub((window as any), "fetch"); + + let sendBeaconCalled = false; + this.hookSendBeacon((url: string) => { + sendBeaconCalled = true; + return false; + }); + + let config = { + endpointUrl: "https//: test", + emitLineDelimitedJson: false, + maxBatchInterval: 15000, + maxBatchSizeInBytes: 102400, + disableTelemetry: false, + enableSessionStorageBuffer: true, + isRetryDisabled: false, + isBeaconApiDisabled:true, + disableXhr: false, + onunloadDisableFetch: false, + onunloadDisableBeacon: false, + instrumentationKey:"key", + namePrefix: "", + samplingPercentage: 100, + customHeaders: [{header:"header",value:"val" }], + convertUndefined: "", + eventsLimitInMem: 10000, + transports: [TransportType.Fetch] + } as ISenderConfig; + + const sender = new Sender(); + const cr = new AppInsightsCore(); + var coreConfig = { + instrumentationKey: "", + extensionConfig: {[sender.identifier]: config} + }; + + cr.initialize(coreConfig, [sender]); + + this.onDone(() => { + sender.teardown(); + }); + + const telemetryItem: ITelemetryItem = { + name: 'fake item', + iKey: 'iKey', + baseType: 'some type', + baseData: {} + }; + + QUnit.assert.ok(isBeaconApiSupported(), "Beacon API is supported"); + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API was not called before"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender was not called before"); + + try { + sender.processTelemetry(telemetryItem, null); + sender.flush(); + } catch(e) { + QUnit.assert.ok(false); + } + + QUnit.assert.equal(false, sendBeaconCalled, "Beacon API is disabled, Beacon API is not called"); + QUnit.assert.equal(0, this._getXhrRequests().length, "xhr sender is not called"); + QUnit.assert.ok(fetchstub.called, "fetch sender is called"); + // store it back + (window as any).XMLHttpRequest = fakeXMLHttpRequest; } }); this.testCase({ name: 'FetchAPI is used when isBeaconApiDisabled flag is true and disableXhr flag is true , use fetch sender.', test: () => { - let window = getGlobalInst("window"); + let window = getWindow(); let fakeXMLHttpRequest = (window as any).XMLHttpRequest; let fetchstub = this.sandbox.stub((window as any), "fetch"); @@ -1205,7 +1638,7 @@ export class SenderTests extends AITestClass { this.testCase({ name: 'FetchAPI is used when isBeaconApiDisabled flag is true and XMLHttpRequest is not supported, use fetch sender.', test: () => { - let window = getGlobalInst("window"); + let window = getWindow(); let fakeXMLHttpRequest = (window as any).XMLHttpRequest; (window as any).XMLHttpRequest = undefined; let fetchstub = this.sandbox.stub((window as any), "fetch"); diff --git a/channels/applicationinsights-channel-js/src/Interfaces.ts b/channels/applicationinsights-channel-js/src/Interfaces.ts index fc88e2ce6..cb9ad6cca 100644 --- a/channels/applicationinsights-channel-js/src/Interfaces.ts +++ b/channels/applicationinsights-channel-js/src/Interfaces.ts @@ -115,6 +115,19 @@ export interface ISenderConfig { * @since 3.0.4 */ alwaysUseXhrOverride?: boolean; + + /** + * [Optional] Either an array or single value identifying the requested TransportType type that should be used. + * This is used during initialization to identify the requested send transport, it will be ignored if a httpXHROverride is provided. + */ + transports?: number | number[]; + + /** + * [Optional] Either an array or single value identifying the requested TransportType type(s) that should be used during unload or events + * marked as sendBeacon. This is used during initialization to identify the requested send transport, it will be ignored if a httpXHROverride + * is provided and alwaysUseXhrOverride is true. + */ + unloadTransports?: number | number[]; } export interface IBackendResponse { diff --git a/channels/applicationinsights-channel-js/src/Sender.ts b/channels/applicationinsights-channel-js/src/Sender.ts index 038f6ede9..ae52000da 100644 --- a/channels/applicationinsights-channel-js/src/Sender.ts +++ b/channels/applicationinsights-channel-js/src/Sender.ts @@ -15,7 +15,7 @@ import { useXDomainRequest } from "@microsoft/applicationinsights-core-js"; import { IPromise, createPromise, doAwaitResponse } from "@nevware21/ts-async"; -import { ITimerHandler, isString, isTruthy, objDeepFreeze, objDefine, scheduleTimeout } from "@nevware21/ts-utils"; +import { ITimerHandler, isNumber, isString, isTruthy, objDeepFreeze, objDefine, scheduleTimeout } from "@nevware21/ts-utils"; import { DependencyEnvelopeCreator, EventEnvelopeCreator, ExceptionEnvelopeCreator, MetricEnvelopeCreator, PageViewEnvelopeCreator, PageViewPerformanceEnvelopeCreator, TraceEnvelopeCreator @@ -53,6 +53,17 @@ function isOverrideFn(httpXHROverride: any) { return httpXHROverride && httpXHROverride.sendPOST; } +function _prependTransports(theTransports: TransportType[], newTransports: TransportType | TransportType[]) { + if (newTransports) { + if (isNumber(newTransports)) { + theTransports = [newTransports as TransportType].concat(theTransports); + } else if (isArray(newTransports)) { + theTransports = newTransports.concat(theTransports); + } + } + return theTransports; +} + const defaultAppInsightsChannelConfig: IConfigDefaults = objDeepFreeze({ // Use the default value (handles empty string in the configuration) endpointUrl: cfgDfValidate(isTruthy, DEFAULT_BREEZE_ENDPOINT + DEFAULT_BREEZE_PATH), @@ -74,7 +85,8 @@ const defaultAppInsightsChannelConfig: IConfigDefaults = objDeepF eventsLimitInMem: 10000, bufferOverride: false, httpXHROverride: { isVal: isOverrideFn, v:UNDEFINED_VALUE }, - alwaysUseXhrOverride: cfgDfBoolean() + alwaysUseXhrOverride: cfgDfBoolean(), + transports: UNDEFINED_VALUE }); function _chkSampling(value: number) { @@ -159,6 +171,8 @@ export class Sender extends BaseTelemetryPlugin implements IChannelControls { let _orgEndpointUrl: string; let _maxBatchSizeInBytes: number; let _beaconSupported: boolean; + let _beaconOnUnloadSupported: boolean; + let _beaconNormalSupported: boolean; let _customHeaders: Array<{header: string, value: string}>; let _disableTelemetry: boolean; let _instrumentationKey: string; @@ -281,6 +295,9 @@ export class Sender extends BaseTelemetryPlugin implements IChannelControls { _maxBatchSizeInBytes = senderConfig.maxBatchSizeInBytes; _beaconSupported = (senderConfig.onunloadDisableBeacon === false || senderConfig.isBeaconApiDisabled === false) && isBeaconsSupported(); + _beaconOnUnloadSupported = senderConfig.onunloadDisableBeacon === false && isBeaconsSupported(); + _beaconNormalSupported = senderConfig.isBeaconApiDisabled === false && isBeaconsSupported(); + _alwaysUseCustomSend = senderConfig.alwaysUseXhrOverride; _disableXhr = !!senderConfig.disableXhr; @@ -348,21 +365,20 @@ export class Sender extends BaseTelemetryPlugin implements IChannelControls { let customInterface = senderConfig.httpXHROverride; let httpInterface: IXHROverride = null; let syncInterface: IXHROverride = null; - httpInterface = _getSenderInterface([TransportType.Xhr, TransportType.Fetch], false); + + // User requested transport(s) values > Beacon > Fetch > XHR + // Beacon would be filtered out if user has set disableBeaconApi to true at _getSenderInterface + let theTransports: TransportType[] = _prependTransports([TransportType.Beacon, TransportType.Xhr, TransportType.Fetch], senderConfig.transports); + + httpInterface = _getSenderInterface(theTransports, false); let xhrInterface = { sendPOST: _xhrSender} as IXHROverride; _xhrSend = (payload: string[], isAsync: boolean) => { return _doSend(xhrInterface, payload, isAsync); }; - - if (!senderConfig.isBeaconApiDisabled && isBeaconsSupported()) { - // Config is set to always used beacon sending - httpInterface = _getSenderInterface([TransportType.Beacon], false); - } - httpInterface = _alwaysUseCustomSend? customInterface : (httpInterface || customInterface || xhrInterface); - + _self._sender = (payload: string[], isAsync: boolean) => { return _doSend(httpInterface, payload, isAsync); }; @@ -371,9 +387,17 @@ export class Sender extends BaseTelemetryPlugin implements IChannelControls { // Try and use the fetch with keepalive _syncUnloadSender = _fetchKeepAliveSender; } - syncInterface = _alwaysUseCustomSend? customInterface : (_getSenderInterface([TransportType.Beacon, TransportType.Xhr], true) || customInterface); + + let syncTransports: TransportType[] = _prependTransports([TransportType.Beacon, TransportType.Xhr], senderConfig.unloadTransports); + if (!_fetchKeepAlive){ + // remove fetch from theTransports + syncTransports = syncTransports.filter(transport => transport !== TransportType.Fetch); + } - if ((_alwaysUseCustomSend || !_syncUnloadSender) && syncInterface) { + syncInterface = _getSenderInterface(syncTransports, true); + syncInterface = _alwaysUseCustomSend? customInterface : (syncInterface || customInterface); + + if ((_alwaysUseCustomSend || senderConfig.unloadTransports || !_syncUnloadSender) && syncInterface) { _syncUnloadSender = (payload: string[], isAsync: boolean) => { return _doSend(syncInterface, payload, isAsync); }; @@ -655,7 +679,7 @@ export class Sender extends BaseTelemetryPlugin implements IChannelControls { } } else if (transportType === TransportType.Fetch && isFetchSupported(syncSupport)) { sendPostFunc = _fetchSender; - } else if (isBeaconsSupported() && transportType === TransportType.Beacon) { + } else if (transportType === TransportType.Beacon && (syncSupport ? _beaconOnUnloadSupported : _beaconNormalSupported)) { sendPostFunc = _beaconSender; } diff --git a/common/config/rush/npm-shrinkwrap.json b/common/config/rush/npm-shrinkwrap.json index 0e6c3ce97..707121151 100644 --- a/common/config/rush/npm-shrinkwrap.json +++ b/common/config/rush/npm-shrinkwrap.json @@ -282,9 +282,9 @@ "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" }, "node_modules/@microsoft/api-extractor": { - "version": "7.38.2", - "resolved": "https://registry.npmjs.org/@microsoft/api-extractor/-/api-extractor-7.38.2.tgz", - "integrity": "sha512-JOARuhTwOcOMIU0O2czscoJy3ddVzIRhSA9/7T1ALuZSNphgWsPk+Bv4E7AnBDmTV4pP4lBNLtCxEHjjpWaytQ==", + "version": "7.38.3", + "resolved": "https://registry.npmjs.org/@microsoft/api-extractor/-/api-extractor-7.38.3.tgz", + "integrity": "sha512-xt9iYyC5f39281j77JTA9C3ISJpW1XWkCcnw+2vM78CPnro6KhPfwQdPDfwS5JCPNuq0grm8cMdPUOPvrchDWw==", "dependencies": { "@microsoft/api-extractor-model": "7.28.2", "@microsoft/tsdoc": "0.14.2", @@ -1487,16 +1487,16 @@ } }, "node_modules/@typescript-eslint/eslint-plugin": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.10.0.tgz", - "integrity": "sha512-uoLj4g2OTL8rfUQVx2AFO1hp/zja1wABJq77P6IclQs6I/m9GLrm7jCdgzZkvWdDCQf1uEvoa8s8CupsgWQgVg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.11.0.tgz", + "integrity": "sha512-uXnpZDc4VRjY4iuypDBKzW1rz9T5YBBK0snMn8MaTSNd2kMlj50LnLBABELjJiOL5YHk7ZD8hbSpI9ubzqYI0w==", "peer": true, "dependencies": { "@eslint-community/regexpp": "^4.5.1", - "@typescript-eslint/scope-manager": "6.10.0", - "@typescript-eslint/type-utils": "6.10.0", - "@typescript-eslint/utils": "6.10.0", - "@typescript-eslint/visitor-keys": "6.10.0", + "@typescript-eslint/scope-manager": "6.11.0", + "@typescript-eslint/type-utils": "6.11.0", + "@typescript-eslint/utils": "6.11.0", + "@typescript-eslint/visitor-keys": "6.11.0", "debug": "^4.3.4", "graphemer": "^1.4.0", "ignore": "^5.2.4", @@ -1522,15 +1522,15 @@ } }, "node_modules/@typescript-eslint/parser": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.10.0.tgz", - "integrity": "sha512-+sZwIj+s+io9ozSxIWbNB5873OSdfeBEH/FR0re14WLI6BaKuSOnnwCJ2foUiu8uXf4dRp1UqHP0vrZ1zXGrog==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.11.0.tgz", + "integrity": "sha512-+whEdjk+d5do5nxfxx73oanLL9ghKO3EwM9kBCkUtWMRwWuPaFv9ScuqlYfQ6pAD6ZiJhky7TZ2ZYhrMsfMxVQ==", "peer": true, "dependencies": { - "@typescript-eslint/scope-manager": "6.10.0", - "@typescript-eslint/types": "6.10.0", - "@typescript-eslint/typescript-estree": "6.10.0", - "@typescript-eslint/visitor-keys": "6.10.0", + "@typescript-eslint/scope-manager": "6.11.0", + "@typescript-eslint/types": "6.11.0", + "@typescript-eslint/typescript-estree": "6.11.0", + "@typescript-eslint/visitor-keys": "6.11.0", "debug": "^4.3.4" }, "engines": { @@ -1550,13 +1550,13 @@ } }, "node_modules/@typescript-eslint/scope-manager": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.10.0.tgz", - "integrity": "sha512-TN/plV7dzqqC2iPNf1KrxozDgZs53Gfgg5ZHyw8erd6jd5Ta/JIEcdCheXFt9b1NYb93a1wmIIVW/2gLkombDg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.11.0.tgz", + "integrity": "sha512-0A8KoVvIURG4uhxAdjSaxy8RdRE//HztaZdG8KiHLP8WOXSk0vlF7Pvogv+vlJA5Rnjj/wDcFENvDaHb+gKd1A==", "peer": true, "dependencies": { - "@typescript-eslint/types": "6.10.0", - "@typescript-eslint/visitor-keys": "6.10.0" + "@typescript-eslint/types": "6.11.0", + "@typescript-eslint/visitor-keys": "6.11.0" }, "engines": { "node": "^16.0.0 || >=18.0.0" @@ -1567,13 +1567,13 @@ } }, "node_modules/@typescript-eslint/type-utils": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.10.0.tgz", - "integrity": "sha512-wYpPs3hgTFblMYwbYWPT3eZtaDOjbLyIYuqpwuLBBqhLiuvJ+9sEp2gNRJEtR5N/c9G1uTtQQL5AhV0fEPJYcg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.11.0.tgz", + "integrity": "sha512-nA4IOXwZtqBjIoYrJcYxLRO+F9ri+leVGoJcMW1uqr4r1Hq7vW5cyWrA43lFbpRvQ9XgNrnfLpIkO3i1emDBIA==", "peer": true, "dependencies": { - "@typescript-eslint/typescript-estree": "6.10.0", - "@typescript-eslint/utils": "6.10.0", + "@typescript-eslint/typescript-estree": "6.11.0", + "@typescript-eslint/utils": "6.11.0", "debug": "^4.3.4", "ts-api-utils": "^1.0.1" }, @@ -1594,9 +1594,9 @@ } }, "node_modules/@typescript-eslint/types": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.10.0.tgz", - "integrity": "sha512-36Fq1PWh9dusgo3vH7qmQAj5/AZqARky1Wi6WpINxB6SkQdY5vQoT2/7rW7uBIsPDcvvGCLi4r10p0OJ7ITAeg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.11.0.tgz", + "integrity": "sha512-ZbEzuD4DwEJxwPqhv3QULlRj8KYTAnNsXxmfuUXFCxZmO6CF2gM/y+ugBSAQhrqaJL3M+oe4owdWunaHM6beqA==", "peer": true, "engines": { "node": "^16.0.0 || >=18.0.0" @@ -1607,13 +1607,13 @@ } }, "node_modules/@typescript-eslint/typescript-estree": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.10.0.tgz", - "integrity": "sha512-ek0Eyuy6P15LJVeghbWhSrBCj/vJpPXXR+EpaRZqou7achUWL8IdYnMSC5WHAeTWswYQuP2hAZgij/bC9fanBg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.11.0.tgz", + "integrity": "sha512-Aezzv1o2tWJwvZhedzvD5Yv7+Lpu1by/U1LZ5gLc4tCx8jUmuSCMioPFRjliN/6SJIvY6HpTtJIWubKuYYYesQ==", "peer": true, "dependencies": { - "@typescript-eslint/types": "6.10.0", - "@typescript-eslint/visitor-keys": "6.10.0", + "@typescript-eslint/types": "6.11.0", + "@typescript-eslint/visitor-keys": "6.11.0", "debug": "^4.3.4", "globby": "^11.1.0", "is-glob": "^4.0.3", @@ -1634,17 +1634,17 @@ } }, "node_modules/@typescript-eslint/utils": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.10.0.tgz", - "integrity": "sha512-v+pJ1/RcVyRc0o4wAGux9x42RHmAjIGzPRo538Z8M1tVx6HOnoQBCX/NoadHQlZeC+QO2yr4nNSFWOoraZCAyg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.11.0.tgz", + "integrity": "sha512-p23ibf68fxoZy605dc0dQAEoUsoiNoP3MD9WQGiHLDuTSOuqoTsa4oAy+h3KDkTcxbbfOtUjb9h3Ta0gT4ug2g==", "peer": true, "dependencies": { "@eslint-community/eslint-utils": "^4.4.0", "@types/json-schema": "^7.0.12", "@types/semver": "^7.5.0", - "@typescript-eslint/scope-manager": "6.10.0", - "@typescript-eslint/types": "6.10.0", - "@typescript-eslint/typescript-estree": "6.10.0", + "@typescript-eslint/scope-manager": "6.11.0", + "@typescript-eslint/types": "6.11.0", + "@typescript-eslint/typescript-estree": "6.11.0", "semver": "^7.5.4" }, "engines": { @@ -1659,12 +1659,12 @@ } }, "node_modules/@typescript-eslint/visitor-keys": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.10.0.tgz", - "integrity": "sha512-xMGluxQIEtOM7bqFCo+rCMh5fqI+ZxV5RUUOa29iVPz1OgCZrtc7rFnz5cLUazlkPKYqX+75iuDq7m0HQ48nCg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.11.0.tgz", + "integrity": "sha512-+SUN/W7WjBr05uRxPggJPSzyB8zUpaYo2hByKasWbqr3PM8AXfZt8UHdNpBS1v9SA62qnSSMF3380SwDqqprgQ==", "peer": true, "dependencies": { - "@typescript-eslint/types": "6.10.0", + "@typescript-eslint/types": "6.11.0", "eslint-visitor-keys": "^3.4.1" }, "engines": { @@ -2086,9 +2086,9 @@ } }, "node_modules/caniuse-lite": { - "version": "1.0.30001561", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001561.tgz", - "integrity": "sha512-NTt0DNoKe958Q0BE0j0c1V9jbUzhBxHIEJy7asmGrpE0yG63KTV7PLHPnK2E1O9RsQrQ081I3NLuXGS6zht3cw==", + "version": "1.0.30001562", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001562.tgz", + "integrity": "sha512-kfte3Hym//51EdX4239i+Rmp20EsLIYGdPkERegTgU19hQWCRhsRFGKHTliUlsry53tv17K7n077Kqa0WJU4ng==", "funding": [ { "type": "opencollective", @@ -2471,9 +2471,9 @@ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" }, "node_modules/electron-to-chromium": { - "version": "1.4.580", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.580.tgz", - "integrity": "sha512-T5q3pjQon853xxxHUq3ZP68ZpvJHuSMY2+BZaW3QzjS4HvNuvsMmZ/+lU+nCrftre1jFZ+OSlExynXWBihnXzw==" + "version": "1.4.586", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.586.tgz", + "integrity": "sha512-qMa+E6yf1fNQbg3G66pHLXeJUP5CCCzNat1VPczOZOqgI2w4u+8y9sQnswMdGs5m4C1rOePq37EVBr/nsPQY7w==" }, "node_modules/encodeurl": { "version": "1.0.2", @@ -2938,9 +2938,9 @@ } }, "node_modules/flat-cache": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.1.1.tgz", - "integrity": "sha512-/qM2b3LUIaIgviBQovTLvijfyOQXPtSRnRK26ksj2J7rzPIecePUIpJsZ4T02Qg+xiAEKIs5K8dsHEd+VaKa/Q==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", "peer": true, "dependencies": { "flatted": "^3.2.9", @@ -2948,7 +2948,7 @@ "rimraf": "^3.0.2" }, "engines": { - "node": ">=12.0.0" + "node": "^10.12.0 || >=12.0.0" } }, "node_modules/flat-cache/node_modules/glob": { @@ -3641,9 +3641,9 @@ ] }, "node_modules/ignore": { - "version": "5.2.4", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", - "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", + "integrity": "sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==", "engines": { "node": ">= 4" } @@ -6264,9 +6264,9 @@ "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" }, "@microsoft/api-extractor": { - "version": "7.38.2", - "resolved": "https://registry.npmjs.org/@microsoft/api-extractor/-/api-extractor-7.38.2.tgz", - "integrity": "sha512-JOARuhTwOcOMIU0O2czscoJy3ddVzIRhSA9/7T1ALuZSNphgWsPk+Bv4E7AnBDmTV4pP4lBNLtCxEHjjpWaytQ==", + "version": "7.38.3", + "resolved": "https://registry.npmjs.org/@microsoft/api-extractor/-/api-extractor-7.38.3.tgz", + "integrity": "sha512-xt9iYyC5f39281j77JTA9C3ISJpW1XWkCcnw+2vM78CPnro6KhPfwQdPDfwS5JCPNuq0grm8cMdPUOPvrchDWw==", "requires": { "@microsoft/api-extractor-model": "7.28.2", "@microsoft/tsdoc": "0.14.2", @@ -7343,16 +7343,16 @@ } }, "@typescript-eslint/eslint-plugin": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.10.0.tgz", - "integrity": "sha512-uoLj4g2OTL8rfUQVx2AFO1hp/zja1wABJq77P6IclQs6I/m9GLrm7jCdgzZkvWdDCQf1uEvoa8s8CupsgWQgVg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.11.0.tgz", + "integrity": "sha512-uXnpZDc4VRjY4iuypDBKzW1rz9T5YBBK0snMn8MaTSNd2kMlj50LnLBABELjJiOL5YHk7ZD8hbSpI9ubzqYI0w==", "peer": true, "requires": { "@eslint-community/regexpp": "^4.5.1", - "@typescript-eslint/scope-manager": "6.10.0", - "@typescript-eslint/type-utils": "6.10.0", - "@typescript-eslint/utils": "6.10.0", - "@typescript-eslint/visitor-keys": "6.10.0", + "@typescript-eslint/scope-manager": "6.11.0", + "@typescript-eslint/type-utils": "6.11.0", + "@typescript-eslint/utils": "6.11.0", + "@typescript-eslint/visitor-keys": "6.11.0", "debug": "^4.3.4", "graphemer": "^1.4.0", "ignore": "^5.2.4", @@ -7362,54 +7362,54 @@ } }, "@typescript-eslint/parser": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.10.0.tgz", - "integrity": "sha512-+sZwIj+s+io9ozSxIWbNB5873OSdfeBEH/FR0re14WLI6BaKuSOnnwCJ2foUiu8uXf4dRp1UqHP0vrZ1zXGrog==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.11.0.tgz", + "integrity": "sha512-+whEdjk+d5do5nxfxx73oanLL9ghKO3EwM9kBCkUtWMRwWuPaFv9ScuqlYfQ6pAD6ZiJhky7TZ2ZYhrMsfMxVQ==", "peer": true, "requires": { - "@typescript-eslint/scope-manager": "6.10.0", - "@typescript-eslint/types": "6.10.0", - "@typescript-eslint/typescript-estree": "6.10.0", - "@typescript-eslint/visitor-keys": "6.10.0", + "@typescript-eslint/scope-manager": "6.11.0", + "@typescript-eslint/types": "6.11.0", + "@typescript-eslint/typescript-estree": "6.11.0", + "@typescript-eslint/visitor-keys": "6.11.0", "debug": "^4.3.4" } }, "@typescript-eslint/scope-manager": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.10.0.tgz", - "integrity": "sha512-TN/plV7dzqqC2iPNf1KrxozDgZs53Gfgg5ZHyw8erd6jd5Ta/JIEcdCheXFt9b1NYb93a1wmIIVW/2gLkombDg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.11.0.tgz", + "integrity": "sha512-0A8KoVvIURG4uhxAdjSaxy8RdRE//HztaZdG8KiHLP8WOXSk0vlF7Pvogv+vlJA5Rnjj/wDcFENvDaHb+gKd1A==", "peer": true, "requires": { - "@typescript-eslint/types": "6.10.0", - "@typescript-eslint/visitor-keys": "6.10.0" + "@typescript-eslint/types": "6.11.0", + "@typescript-eslint/visitor-keys": "6.11.0" } }, "@typescript-eslint/type-utils": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.10.0.tgz", - "integrity": "sha512-wYpPs3hgTFblMYwbYWPT3eZtaDOjbLyIYuqpwuLBBqhLiuvJ+9sEp2gNRJEtR5N/c9G1uTtQQL5AhV0fEPJYcg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.11.0.tgz", + "integrity": "sha512-nA4IOXwZtqBjIoYrJcYxLRO+F9ri+leVGoJcMW1uqr4r1Hq7vW5cyWrA43lFbpRvQ9XgNrnfLpIkO3i1emDBIA==", "peer": true, "requires": { - "@typescript-eslint/typescript-estree": "6.10.0", - "@typescript-eslint/utils": "6.10.0", + "@typescript-eslint/typescript-estree": "6.11.0", + "@typescript-eslint/utils": "6.11.0", "debug": "^4.3.4", "ts-api-utils": "^1.0.1" } }, "@typescript-eslint/types": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.10.0.tgz", - "integrity": "sha512-36Fq1PWh9dusgo3vH7qmQAj5/AZqARky1Wi6WpINxB6SkQdY5vQoT2/7rW7uBIsPDcvvGCLi4r10p0OJ7ITAeg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.11.0.tgz", + "integrity": "sha512-ZbEzuD4DwEJxwPqhv3QULlRj8KYTAnNsXxmfuUXFCxZmO6CF2gM/y+ugBSAQhrqaJL3M+oe4owdWunaHM6beqA==", "peer": true }, "@typescript-eslint/typescript-estree": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.10.0.tgz", - "integrity": "sha512-ek0Eyuy6P15LJVeghbWhSrBCj/vJpPXXR+EpaRZqou7achUWL8IdYnMSC5WHAeTWswYQuP2hAZgij/bC9fanBg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.11.0.tgz", + "integrity": "sha512-Aezzv1o2tWJwvZhedzvD5Yv7+Lpu1by/U1LZ5gLc4tCx8jUmuSCMioPFRjliN/6SJIvY6HpTtJIWubKuYYYesQ==", "peer": true, "requires": { - "@typescript-eslint/types": "6.10.0", - "@typescript-eslint/visitor-keys": "6.10.0", + "@typescript-eslint/types": "6.11.0", + "@typescript-eslint/visitor-keys": "6.11.0", "debug": "^4.3.4", "globby": "^11.1.0", "is-glob": "^4.0.3", @@ -7418,27 +7418,27 @@ } }, "@typescript-eslint/utils": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.10.0.tgz", - "integrity": "sha512-v+pJ1/RcVyRc0o4wAGux9x42RHmAjIGzPRo538Z8M1tVx6HOnoQBCX/NoadHQlZeC+QO2yr4nNSFWOoraZCAyg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.11.0.tgz", + "integrity": "sha512-p23ibf68fxoZy605dc0dQAEoUsoiNoP3MD9WQGiHLDuTSOuqoTsa4oAy+h3KDkTcxbbfOtUjb9h3Ta0gT4ug2g==", "peer": true, "requires": { "@eslint-community/eslint-utils": "^4.4.0", "@types/json-schema": "^7.0.12", "@types/semver": "^7.5.0", - "@typescript-eslint/scope-manager": "6.10.0", - "@typescript-eslint/types": "6.10.0", - "@typescript-eslint/typescript-estree": "6.10.0", + "@typescript-eslint/scope-manager": "6.11.0", + "@typescript-eslint/types": "6.11.0", + "@typescript-eslint/typescript-estree": "6.11.0", "semver": "^7.5.4" } }, "@typescript-eslint/visitor-keys": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.10.0.tgz", - "integrity": "sha512-xMGluxQIEtOM7bqFCo+rCMh5fqI+ZxV5RUUOa29iVPz1OgCZrtc7rFnz5cLUazlkPKYqX+75iuDq7m0HQ48nCg==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.11.0.tgz", + "integrity": "sha512-+SUN/W7WjBr05uRxPggJPSzyB8zUpaYo2hByKasWbqr3PM8AXfZt8UHdNpBS1v9SA62qnSSMF3380SwDqqprgQ==", "peer": true, "requires": { - "@typescript-eslint/types": "6.10.0", + "@typescript-eslint/types": "6.11.0", "eslint-visitor-keys": "^3.4.1" } }, @@ -7729,9 +7729,9 @@ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" }, "caniuse-lite": { - "version": "1.0.30001561", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001561.tgz", - "integrity": "sha512-NTt0DNoKe958Q0BE0j0c1V9jbUzhBxHIEJy7asmGrpE0yG63KTV7PLHPnK2E1O9RsQrQ081I3NLuXGS6zht3cw==" + "version": "1.0.30001562", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001562.tgz", + "integrity": "sha512-kfte3Hym//51EdX4239i+Rmp20EsLIYGdPkERegTgU19hQWCRhsRFGKHTliUlsry53tv17K7n077Kqa0WJU4ng==" }, "chalk": { "version": "4.1.2", @@ -8011,9 +8011,9 @@ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" }, "electron-to-chromium": { - "version": "1.4.580", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.580.tgz", - "integrity": "sha512-T5q3pjQon853xxxHUq3ZP68ZpvJHuSMY2+BZaW3QzjS4HvNuvsMmZ/+lU+nCrftre1jFZ+OSlExynXWBihnXzw==" + "version": "1.4.586", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.586.tgz", + "integrity": "sha512-qMa+E6yf1fNQbg3G66pHLXeJUP5CCCzNat1VPczOZOqgI2w4u+8y9sQnswMdGs5m4C1rOePq37EVBr/nsPQY7w==" }, "encodeurl": { "version": "1.0.2", @@ -8381,9 +8381,9 @@ "integrity": "sha512-lNaHNVymajmk0OJMBn8fVUAU1BtDeKIqKoVhk4xAALB57aALg6b4W0MfJ/cUE0g9YBXy5XhSlPIpYIJ7HaY/3Q==" }, "flat-cache": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.1.1.tgz", - "integrity": "sha512-/qM2b3LUIaIgviBQovTLvijfyOQXPtSRnRK26ksj2J7rzPIecePUIpJsZ4T02Qg+xiAEKIs5K8dsHEd+VaKa/Q==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", "peer": true, "requires": { "flatted": "^3.2.9", @@ -8891,9 +8891,9 @@ "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" }, "ignore": { - "version": "5.2.4", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", - "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==" + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", + "integrity": "sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==" }, "import-fresh": { "version": "3.3.0",