@launchdarkly/js-client-sdk 0.10.0 → 0.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +40 -0
- package/dist/{common-Cn2MjelZ.d.cts → common-B4wKbl6r.d.cts} +55 -1
- package/dist/{common-Cn2MjelZ.d.ts → common-B4wKbl6r.d.ts} +55 -1
- package/dist/compat.cjs +1 -1
- package/dist/compat.cjs.map +1 -1
- package/dist/compat.d.cts +6 -6
- package/dist/compat.d.ts +6 -6
- package/dist/compat.js +1 -1
- package/dist/compat.js.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +37 -11
- package/dist/index.d.ts +37 -11
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/metafile-cjs.json +1 -1
- package/dist/metafile-esm.json +1 -1
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,45 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [0.12.0](https://github.com/launchdarkly/js-core/compare/js-client-sdk-v0.11.0...js-client-sdk-v0.12.0) (2026-01-06)
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
### Features
|
|
7
|
+
|
|
8
|
+
* add legacy storage key cleanup functionality ([#1043](https://github.com/launchdarkly/js-core/issues/1043)) ([fe4725e](https://github.com/launchdarkly/js-core/commit/fe4725e24917fe795cee448383b4fe8fa8b4b56f))
|
|
9
|
+
* add waitForInitialization to RN SDK ([#1048](https://github.com/launchdarkly/js-core/issues/1048)) ([13ce456](https://github.com/launchdarkly/js-core/commit/13ce456d9e3a5bcf043734f757415d4856034257))
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
### Dependencies
|
|
13
|
+
|
|
14
|
+
* The following workspace dependencies were updated
|
|
15
|
+
* dependencies
|
|
16
|
+
* @launchdarkly/js-client-sdk-common bumped from 1.16.0 to 1.17.0
|
|
17
|
+
|
|
18
|
+
## [0.11.0](https://github.com/launchdarkly/js-core/compare/js-client-sdk-v0.10.0...js-client-sdk-v0.11.0) (2025-12-18)
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
### ⚠ BREAKING CHANGES
|
|
22
|
+
|
|
23
|
+
* align browser v4 intialization flow to specs ([#1040](https://github.com/launchdarkly/js-core/issues/1040))
|
|
24
|
+
|
|
25
|
+
### Features
|
|
26
|
+
|
|
27
|
+
* adding support for debug override plugins ([#1033](https://github.com/launchdarkly/js-core/issues/1033)) ([17f5e7d](https://github.com/launchdarkly/js-core/commit/17f5e7d7d11d502d54a6ccf88aea6bec3e4b775c))
|
|
28
|
+
* allow clients to evaluate bootstrapped flags when not ready ([#1036](https://github.com/launchdarkly/js-core/issues/1036)) ([9b4542a](https://github.com/launchdarkly/js-core/commit/9b4542a722e5d19e123e860faef113d134dad47c))
|
|
29
|
+
* implement `waitForInitialization` for browser sdk 4.x ([#1028](https://github.com/launchdarkly/js-core/issues/1028)) ([156532a](https://github.com/launchdarkly/js-core/commit/156532aea3ec39635dab21dbab125c81fc31a3f5))
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
### Code Refactoring
|
|
33
|
+
|
|
34
|
+
* align browser v4 intialization flow to specs ([#1040](https://github.com/launchdarkly/js-core/issues/1040)) ([eff6a55](https://github.com/launchdarkly/js-core/commit/eff6a55163508bee4f2dec574ad256f88ec513d6))
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
### Dependencies
|
|
38
|
+
|
|
39
|
+
* The following workspace dependencies were updated
|
|
40
|
+
* dependencies
|
|
41
|
+
* @launchdarkly/js-client-sdk-common bumped from 1.15.2 to 1.16.0
|
|
42
|
+
|
|
3
43
|
## [0.10.0](https://github.com/launchdarkly/js-core/compare/js-client-sdk-v0.9.1...js-client-sdk-v0.10.0) (2025-12-09)
|
|
4
44
|
|
|
5
45
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { LDIdentifyOptions, LDClient as LDClient$1, LDContext, LDIdentifyResult, LDPluginBase, Hook, LDOptions, BasicLoggerOptions, LDLogger } from '@launchdarkly/js-client-sdk-common';
|
|
1
|
+
import { LDIdentifyOptions, LDClient as LDClient$1, LDContext, LDIdentifyResult, LDWaitForInitializationOptions, LDWaitForInitializationResult, LDPluginBase, Hook, LDOptions, BasicLoggerOptions, LDLogger } from '@launchdarkly/js-client-sdk-common';
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
4
|
* @property sheddable - If true, the identify operation will be sheddable. This means that if multiple identify operations are done, without
|
|
@@ -29,6 +29,19 @@ interface BrowserIdentifyOptions extends Omit<LDIdentifyOptions, 'waitForNetwork
|
|
|
29
29
|
bootstrap?: unknown;
|
|
30
30
|
}
|
|
31
31
|
|
|
32
|
+
interface LDStartOptions extends LDWaitForInitializationOptions {
|
|
33
|
+
/**
|
|
34
|
+
* Optional bootstrap data to use for the identify operation. If {@link LDIdentifyOptions.bootstrap} is provided, it will be ignored.
|
|
35
|
+
*/
|
|
36
|
+
bootstrap?: unknown;
|
|
37
|
+
/**
|
|
38
|
+
* Optional identify options to use for the identify operation. See {@link LDIdentifyOptions} for more information.
|
|
39
|
+
*
|
|
40
|
+
* @remarks
|
|
41
|
+
* Since the first identify option should never be sheddable, we omit the sheddable option from the interface to avoid confusion.
|
|
42
|
+
*/
|
|
43
|
+
identifyOptions?: Omit<BrowserIdentifyOptions, 'sheddable'>;
|
|
44
|
+
}
|
|
32
45
|
/**
|
|
33
46
|
*
|
|
34
47
|
* The LaunchDarkly SDK client object.
|
|
@@ -81,6 +94,47 @@ type LDClient = Omit<LDClient$1, 'setConnectionMode' | 'getConnectionMode' | 'ge
|
|
|
81
94
|
* @ignore Implementation Note: Browser implementation has different options.
|
|
82
95
|
*/
|
|
83
96
|
identify(pristineContext: LDContext, identifyOptions?: BrowserIdentifyOptions): Promise<LDIdentifyResult>;
|
|
97
|
+
/**
|
|
98
|
+
* Returns a Promise that tracks the client's initialization state.
|
|
99
|
+
*
|
|
100
|
+
* The Promise will be resolved to a {@link LDWaitForInitializationResult} object containing the
|
|
101
|
+
* status of the waitForInitialization operation.
|
|
102
|
+
*
|
|
103
|
+
* @example
|
|
104
|
+
* This example shows use of async/await syntax for specifying handlers:
|
|
105
|
+
* ```
|
|
106
|
+
* const result = await client.waitForInitialization({ timeout: 5 });
|
|
107
|
+
*
|
|
108
|
+
* if (result.status === 'complete') {
|
|
109
|
+
* doSomethingWithSuccessfullyInitializedClient();
|
|
110
|
+
* } else if (result.status === 'failed') {
|
|
111
|
+
* doSomethingForFailedStartup(result.error);
|
|
112
|
+
* } else if (result.status === 'timeout') {
|
|
113
|
+
* doSomethingForTimedOutStartup();
|
|
114
|
+
* }
|
|
115
|
+
* ```
|
|
116
|
+
*
|
|
117
|
+
* @remarks
|
|
118
|
+
* You can also use event listeners ({@link on}) for the same purpose: the event `"initialized"`
|
|
119
|
+
* indicates success, and `"error"` indicates an error.
|
|
120
|
+
*
|
|
121
|
+
* @param options
|
|
122
|
+
* Optional configuration. Please see {@link LDWaitForInitializationOptions}.
|
|
123
|
+
*
|
|
124
|
+
* @returns
|
|
125
|
+
* A Promise that will be resolved to a {@link LDWaitForInitializationResult} object containing the
|
|
126
|
+
* status of the waitForInitialization operation.
|
|
127
|
+
*/
|
|
128
|
+
waitForInitialization(options?: LDWaitForInitializationOptions): Promise<LDWaitForInitializationResult>;
|
|
129
|
+
/**
|
|
130
|
+
* Starts the client and returns a promise that resolves to the initialization result.
|
|
131
|
+
*
|
|
132
|
+
* The promise will resolve to a {@link LDWaitForInitializationResult} object containing the
|
|
133
|
+
* status of the waitForInitialization operation.
|
|
134
|
+
*
|
|
135
|
+
* @param options Optional configuration. Please see {@link LDStartOptions}.
|
|
136
|
+
*/
|
|
137
|
+
start(options?: LDStartOptions): Promise<LDWaitForInitializationResult>;
|
|
84
138
|
};
|
|
85
139
|
|
|
86
140
|
/**
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { LDIdentifyOptions, LDClient as LDClient$1, LDContext, LDIdentifyResult, LDPluginBase, Hook, LDOptions, BasicLoggerOptions, LDLogger } from '@launchdarkly/js-client-sdk-common';
|
|
1
|
+
import { LDIdentifyOptions, LDClient as LDClient$1, LDContext, LDIdentifyResult, LDWaitForInitializationOptions, LDWaitForInitializationResult, LDPluginBase, Hook, LDOptions, BasicLoggerOptions, LDLogger } from '@launchdarkly/js-client-sdk-common';
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
4
|
* @property sheddable - If true, the identify operation will be sheddable. This means that if multiple identify operations are done, without
|
|
@@ -29,6 +29,19 @@ interface BrowserIdentifyOptions extends Omit<LDIdentifyOptions, 'waitForNetwork
|
|
|
29
29
|
bootstrap?: unknown;
|
|
30
30
|
}
|
|
31
31
|
|
|
32
|
+
interface LDStartOptions extends LDWaitForInitializationOptions {
|
|
33
|
+
/**
|
|
34
|
+
* Optional bootstrap data to use for the identify operation. If {@link LDIdentifyOptions.bootstrap} is provided, it will be ignored.
|
|
35
|
+
*/
|
|
36
|
+
bootstrap?: unknown;
|
|
37
|
+
/**
|
|
38
|
+
* Optional identify options to use for the identify operation. See {@link LDIdentifyOptions} for more information.
|
|
39
|
+
*
|
|
40
|
+
* @remarks
|
|
41
|
+
* Since the first identify option should never be sheddable, we omit the sheddable option from the interface to avoid confusion.
|
|
42
|
+
*/
|
|
43
|
+
identifyOptions?: Omit<BrowserIdentifyOptions, 'sheddable'>;
|
|
44
|
+
}
|
|
32
45
|
/**
|
|
33
46
|
*
|
|
34
47
|
* The LaunchDarkly SDK client object.
|
|
@@ -81,6 +94,47 @@ type LDClient = Omit<LDClient$1, 'setConnectionMode' | 'getConnectionMode' | 'ge
|
|
|
81
94
|
* @ignore Implementation Note: Browser implementation has different options.
|
|
82
95
|
*/
|
|
83
96
|
identify(pristineContext: LDContext, identifyOptions?: BrowserIdentifyOptions): Promise<LDIdentifyResult>;
|
|
97
|
+
/**
|
|
98
|
+
* Returns a Promise that tracks the client's initialization state.
|
|
99
|
+
*
|
|
100
|
+
* The Promise will be resolved to a {@link LDWaitForInitializationResult} object containing the
|
|
101
|
+
* status of the waitForInitialization operation.
|
|
102
|
+
*
|
|
103
|
+
* @example
|
|
104
|
+
* This example shows use of async/await syntax for specifying handlers:
|
|
105
|
+
* ```
|
|
106
|
+
* const result = await client.waitForInitialization({ timeout: 5 });
|
|
107
|
+
*
|
|
108
|
+
* if (result.status === 'complete') {
|
|
109
|
+
* doSomethingWithSuccessfullyInitializedClient();
|
|
110
|
+
* } else if (result.status === 'failed') {
|
|
111
|
+
* doSomethingForFailedStartup(result.error);
|
|
112
|
+
* } else if (result.status === 'timeout') {
|
|
113
|
+
* doSomethingForTimedOutStartup();
|
|
114
|
+
* }
|
|
115
|
+
* ```
|
|
116
|
+
*
|
|
117
|
+
* @remarks
|
|
118
|
+
* You can also use event listeners ({@link on}) for the same purpose: the event `"initialized"`
|
|
119
|
+
* indicates success, and `"error"` indicates an error.
|
|
120
|
+
*
|
|
121
|
+
* @param options
|
|
122
|
+
* Optional configuration. Please see {@link LDWaitForInitializationOptions}.
|
|
123
|
+
*
|
|
124
|
+
* @returns
|
|
125
|
+
* A Promise that will be resolved to a {@link LDWaitForInitializationResult} object containing the
|
|
126
|
+
* status of the waitForInitialization operation.
|
|
127
|
+
*/
|
|
128
|
+
waitForInitialization(options?: LDWaitForInitializationOptions): Promise<LDWaitForInitializationResult>;
|
|
129
|
+
/**
|
|
130
|
+
* Starts the client and returns a promise that resolves to the initialization result.
|
|
131
|
+
*
|
|
132
|
+
* The promise will resolve to a {@link LDWaitForInitializationResult} object containing the
|
|
133
|
+
* status of the waitForInitialization operation.
|
|
134
|
+
*
|
|
135
|
+
* @param options Optional configuration. Please see {@link LDStartOptions}.
|
|
136
|
+
*/
|
|
137
|
+
start(options?: LDStartOptions): Promise<LDWaitForInitializationResult>;
|
|
84
138
|
};
|
|
85
139
|
|
|
86
140
|
/**
|
package/dist/compat.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var mt=Object.defineProperty,ji=Object.defineProperties,Hi=Object.getOwnPropertyDescriptor,Bi=Object.getOwnPropertyDescriptors,Ki=Object.getOwnPropertyNames,gt=Object.getOwnPropertySymbols;var Gt=Object.prototype.hasOwnProperty,Ge=Object.prototype.propertyIsEnumerable;var Ke=(i,t,e)=>t in i?mt(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,p=(i,t)=>{for(var e in t||(t={}))Gt.call(t,e)&&Ke(i,e,t[e]);if(gt)for(var e of gt(t))Ge.call(t,e)&&Ke(i,e,t[e]);return i},b=(i,t)=>ji(i,Bi(t));var zt=(i,t)=>{var e={};for(var n in i)Gt.call(i,n)&&t.indexOf(n)<0&&(e[n]=i[n]);if(i!=null&>)for(var n of gt(i))t.indexOf(n)<0&&Ge.call(i,n)&&(e[n]=i[n]);return e};var Gi=(i,t)=>{for(var e in t)mt(i,e,{get:t[e],enumerable:!0})},zi=(i,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Ki(t))!Gt.call(i,s)&&s!==e&&mt(i,s,{get:()=>t[s],enumerable:!(n=Hi(t,s))||n.enumerable});return i};var _i=i=>zi(mt({},"__esModule",{value:!0}),i);var Ns={};Gi(Ns,{basicLogger:()=>Ps,initialize:()=>Is});module.exports=_i(Ns);function Ji(i){return`/${i.replace(/~/g,"~0").replace(/\//g,"~1")}`}function Qe(i){return i.indexOf("~")?i.replace(/~1/g,"/").replace(/~0/g,"~"):i}function qi(i){return(i.startsWith("/")?i.substring(1):i).split("/").map(e=>Qe(e))}function Wi(i){return!i.startsWith("/")}function Yi(i){return!i.match(/\/\/|(^\/.*~[^0|^1])|~$/)}var A=class{constructor(t,e=!1){if(e){let n=t;this.p=[n],this.isValid=n!=="",this.redactionName=n.startsWith("/")?Ji(n):n}else{if(this.redactionName=t,t===""||t==="/"||!Yi(t)){this.isValid=!1,this.p=[];return}Wi(t)?this.p=[t]:t.indexOf("/",1)<0?this.p=[Qe(t.slice(1))]:this.p=qi(t),this.p[0]==="_meta"?this.isValid=!1:this.isValid=!0}}get(t){let{p:e,isValid:n}=this;if(!n)return;let s=t;for(let r=0;r<e.length;r+=1){let a=e[r];if(s!=null&&Object.prototype.hasOwnProperty.call(s,a)&&typeof s=="object"&&!Array.isArray(s))s=s[a];else return}return s}getComponent(t){return this.p[t]}get depth(){return this.p.length}get isKind(){return this.p.length===1&&this.p[0]==="kind"}compare(t){return this.depth===t.depth&&this.p.every((e,n)=>e===t.getComponent(n))}get components(){return[...this.p]}};A.InvalidReference=new A("");var qt=class{is(t){if(Array.isArray(t))return!1;let n=typeof t;return n==="function"||n==="object"}getType(){return"factory method or object"}},P=class{constructor(t,e){this.kt=t,this.typeOf=typeof e}is(t){return Array.isArray(t)?!1:typeof t===this.typeOf}getType(){return this.kt}},wt=class{constructor(t,e){this.kt=t,this.typeOf=typeof e}is(t){return Array.isArray(t)?t.length>0?t.every(e=>typeof e===this.typeOf):!0:!1}getType(){return this.kt}},z=class extends P{constructor(t){super(`number with minimum value of ${t}`,0),this.min=t}is(t){return typeof t===this.typeOf&&t>=this.min}},Et=class extends P{constructor(t){super(`string matching ${t}`,""),this.expression=t}is(t){return typeof t=="string"&&!!t.match(this.expression)}},Wt=class{is(t){return typeof t=="function"}getType(){return"function"}},Yt=class{is(t){return typeof t=="boolean"||typeof t=="undefined"||t===null}getType(){return"boolean | undefined | null"}},Zi=/^\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d(\.\d\d*)?(Z|[-+]\d\d(:\d\d)?)/,Zt=class{is(t){return typeof t=="number"||typeof t=="string"&&Zi.test(t)}getType(){return"date"}},Xt=class extends Et{constructor(){super(/^(\w|\.|-)+$/)}is(t){return super.is(t)&&t!=="kind"}},h=class{static createTypeArray(t,e){return new wt(t,e)}static numberWithMin(t){return new z(t)}static stringMatchingRegex(t){return new Et(t)}};h.String=new P("string","");h.Number=new P("number",0);h.ObjectOrFactory=new qt;h.Object=new P("object",{});h.StringArray=new wt("string[]","");h.Boolean=new P("boolean",!0);h.Function=new Wt;h.Date=new Zt;h.Kind=new Xt;h.NullableBoolean=new Yt;function ti(i){return"kind"in i?h.String.is(i.kind)&&i.kind!=="multi":!1}function ei(i){return"kind"in i?h.String.is(i.kind)&&i.kind==="multi":!1}function ii(i){return!("kind"in i)||i.kind===null||i.kind===void 0}function Dt(i,t=[]){if(i===null||typeof i!="object")return JSON.stringify(i);if(t.includes(i))throw new Error("Cycle detected");return Array.isArray(i)?`[${i.map(s=>Dt(s,[...t,i])).map(s=>s===void 0?"null":s).join(",")}]`:`{${Object.keys(i).sort().map(n=>{let s=Dt(i[n],[...t,i]);if(s!==void 0)return`${JSON.stringify(n)}:${s}`}).filter(n=>n!==void 0).join(",")}}`}var Qt="user";function ze(i){return i.includes("%")||i.includes(":")?i.replace(/%/g,"%25").replace(/:/g,"%3A"):i}function Xi(i){return i&&h.Object.is(i)}function _e(i){return h.Kind.is(i)}function Je(i){return h.String.is(i)&&i!==""}function _t(i,t=!1){return i?i.map(e=>new A(e,t)):[]}function Qi(i){return i!=null}function tn(i){let t=b(p({},i.custom||[]),{kind:"user",key:String(i.key)});if(Qi(i.anonymous)){let e=!!i.anonymous;delete t.anonymous,t.anonymous=e}return i.name!==null&&i.name!==void 0&&(t.name=i.name),i.ip!==null&&i.ip!==void 0&&(t.ip=i.ip),i.firstName!==null&&i.firstName!==void 0&&(t.firstName=i.firstName),i.lastName!==null&&i.lastName!==void 0&&(t.lastName=i.lastName),i.email!==null&&i.email!==void 0&&(t.email=i.email),i.avatar!==null&&i.avatar!==void 0&&(t.avatar=i.avatar),i.country!==null&&i.country!==void 0&&(t.country=i.country),i.privateAttributeNames!==null&&i.privateAttributeNames!==void 0&&(t._meta={privateAttributes:i.privateAttributeNames}),t}var x=class i{constructor(t,e,n){this.T=!1,this.at=!1,this.re=!1,this.R={},this.kind=e,this.valid=t,this.message=n}static b(t,e){return new i(!1,t,e)}static We(t,e){if(!(!e||!t.isValid))return t.depth===1&&t.getComponent(0)==="anonymous"?!!(e!=null&&e.anonymous):t.get(e)}ae(t){if(this.T)return this.R[t];if(this.kind===t)return this.m}static Ye(t){let e=Object.keys(t).filter(c=>c!=="kind"),n=e.every(_e);if(!e.length)return i.b("multi","A multi-kind context must contain at least one kind");if(!n)return i.b("multi","Context contains invalid kinds");let s={},r=!0,a=e.reduce((c,u)=>{var d;let l=t[u];return Xi(l)?(c[u]=l,s[u]=_t((d=l._meta)==null?void 0:d.privateAttributes)):r=!1,c},{});if(!r)return i.b("multi","Context contained contexts that were not objects");if(!Object.values(a).every(c=>Je(c.key)))return i.b("multi","Context contained invalid keys");if(e.length===1){let c=e[0],u=new i(!0,c);return u.m=b(p({},a[c]),{kind:c}),u.ot=s,u.at=c==="user",u}let o=new i(!0,t.kind);return o.R=a,o.ot=s,o.T=!0,o}static Ze(t){var c;let{key:e,kind:n}=t,s=_e(n),r=Je(e);if(!s)return i.b(n!=null?n:"unknown","The kind was not valid for the context");if(!r)return i.b(n,"The key for the context was not valid");let a=_t((c=t._meta)==null?void 0:c.privateAttributes),o=new i(!0,n);return o.at=n==="user",o.m=t,o.ot={[n]:a},o}static Xe(t){if(!(t.key!==void 0&&t.key!==null))return i.b("user","The key for the context was not valid");let n=new i(!0,"user");return n.at=!0,n.re=!0,n.m=tn(t),n.ot={user:_t(t.privateAttributeNames,!0)},n}static fromLDContext(t){return t?ti(t)?i.Ze(t):ei(t)?i.Ye(t):ii(t)?i.Xe(t):i.b("unknown","Context was not of a valid kind"):i.b("unknown","No context specified. Returning default value")}static toLDContext(t){if(!t.valid)return;let e=t.getContexts();if(!t.T)return e[0][1];let n={kind:"multi"};return e.forEach(s=>{let r=s[0],a=s[1];n[r]=a}),n}valueForKind(t,e=Qt){return t.isKind?this.kinds:i.We(t,this.ae(e))}key(t=Qt){var e;return(e=this.ae(t))==null?void 0:e.key}get isMultiKind(){return this.T}get canonicalKey(){return this.at?this.m.key:this.T?Object.keys(this.R).sort().map(t=>`${t}:${ze(this.R[t].key)}`).join(":"):`${this.kind}:${ze(this.m.key)}`}get kinds(){return this.T?Object.keys(this.R):[this.kind]}get kindsAndKeys(){return this.T?Object.entries(this.R).reduce((t,[e,n])=>(t[e]=n.key,t),{}):{[this.kind]:this.m.key}}privateAttributes(t){var e;return((e=this.ot)==null?void 0:e[t])||[]}getContexts(){return this.T?Object.entries(this.R):[[this.kind,this.m]]}get legacy(){return this.re}canonicalUnfilteredJson(){if(this.valid){if(this.xt)return this.xt;try{this.xt=Dt(i.toLDContext(this))}catch(t){}return this.xt}}};x.UserKind=Qt;var en=["key","kind","_meta","anonymous"].map(i=>new A(i,!0)),nn=["name","ip","firstName","lastName","email","avatar","country"];function sn(i,t){return i.depth===t.length&&t.every((e,n)=>e===i.getComponent(n))}function rn(i,t){let e=[],n={},s=[];for(e.push(...Object.keys(i).map(r=>({key:r,ptr:[r],source:i,parent:n,visited:[i]})));e.length;){let r=e.pop(),a=t.find(o=>sn(o,r.ptr));if(a)s.push(a.redactionName);else{let o=r.source[r.key];o===null?r.parent[r.key]=o:Array.isArray(o)?r.parent[r.key]=[...o]:typeof o=="object"?r.visited.includes(o)||(r.parent[r.key]={},e.push(...Object.keys(o).map(c=>({key:c,ptr:[...r.ptr,c],source:o,parent:r.parent[r.key],visited:[...r.visited,o]})))):r.parent[r.key]=o}}return{cloned:n,excluded:s.sort()}}var te=class{constructor(t,e){this.Qe=t,this.ti=e}filter(t,e=!1){let n=t.getContexts();if(n.length===1)return this.oe(t,n[0][1],n[0][0],e);let s={kind:"multi"};return n.forEach(([r,a])=>{s[r]=this.oe(t,a,r,e)}),s}ei(t,e,n,s){return(s?Object.keys(e).map(r=>new A(r,!0)):[...this.ti,...t.privateAttributes(n)]).filter(r=>!en.some(a=>a.compare(r)))}oe(t,e,n,s){let r=this.Qe||s&&e.anonymous===!0,{cloned:a,excluded:o}=rn(e,this.ei(t,e,n,r));return t.legacy&&nn.forEach(c=>{c in a&&(a[c]=String(a[c]))}),o.length&&(a._meta||(a._meta={}),a._meta.redactedAttributes=o),a._meta&&(delete a._meta.privateAttributes,Object.keys(a._meta).length===0&&delete a._meta),a}},qe=30*1e3,an=.5,bt=class{constructor(t,e,n=Math.random){this.ii=e,this.ni=n,this.Lt=0,this.ce=Math.max(1,t),this.si=Math.ceil(Math.log2(qe/this.ce))}A(){let t=Math.min(this.Lt,this.si),e=this.ce*2**t;return Math.min(e,qe)}ri(t){return t-Math.trunc(this.ni()*an*t)}success(t=Date.now()){this.St=t}fail(t=Date.now()){this.St!==void 0&&t-this.St>this.ii&&(this.Lt=0),this.St=void 0;let e=this.ri(this.A());return this.Lt+=1,e}};var We;(function(i){i[i.Valid=0]="Valid",i[i.Initializing=1]="Initializing",i[i.Interrupted=2]="Interrupted",i[i.Closed=3]="Closed"})(We||(We={}));var M=class extends Error{constructor(t,e,n,s=!0){super(e),this.kind=t,this.status=n,this.name="LaunchDarklyPollingError",this.recoverable=s}},j=class extends Error{constructor(t,e,n,s=!0){super(e),this.kind=t,this.code=n,this.name="LaunchDarklyStreamingError",this.recoverable=s}};var $s=120*1e3,Ms=300*1e3;var w;(function(i){i.Unknown="UNKNOWN",i.NetworkError="NETWORK_ERROR",i.ErrorResponse="ERROR_RESPONSE",i.InvalidData="INVALID_DATA"})(w||(w={}));var H;(function(i){i[i.Disabled=0]="Disabled",i[i.Enabled=1]="Enabled"})(H||(H={}));var B;(function(i){i[i.AnalyticsEvents=0]="AnalyticsEvents",i[i.DiagnosticEvent=1]="DiagnosticEvent"})(B||(B={}));var $;(function(i){i[i.Succeeded=0]="Succeeded",i[i.Failed=1]="Failed",i[i.FailedAndMustShutDown=2]="FailedAndMustShutDown"})($||($={}));function V(i){if(typeof i=="string")return i;if(i===void 0)return"undefined";if(i===null)return"null";if(Object.prototype.hasOwnProperty.call(i,"toString"))try{return i.toString()}catch(t){}if(typeof i=="bigint")return`${i}n`;try{return JSON.stringify(i)}catch(t){return t instanceof TypeError&&t.message.indexOf("circular")>=0?"[Circular]":"[Not Stringifiable]"}}function on(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(Number(i))}function cn(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(parseInt(i,10))}function un(i){return typeof i=="symbol"?"NaN":String(parseFloat(i))}var yt={s:i=>V(i),d:i=>on(i),i:i=>cn(i),f:i=>un(i),j:i=>V(i),o:i=>V(i),O:i=>V(i),c:()=>""};function ee(...i){var e;let t=i.shift();if(h.String.is(t)){let n="",s=0;for(;s<t.length;){let r=t.charAt(s);if(r==="%"){if(s+1<t.length){let o=t.charAt(s+1);if(o in yt&&i.length){let c=i.shift();n+=(e=yt[o])==null?void 0:e.call(yt,c)}else o==="%"?n+="%":n+=`%${o}`;s+=2}}else n+=r,s+=1}return i.length&&(n.length&&(n+=" "),n+=i.map(V).join(" ")),n}return i.map(V).join(" ")}var v;(function(i){i[i.debug=0]="debug",i[i.info=1]="info",i[i.warn=2]="warn",i[i.error=3]="error",i[i.none=4]="none"})(v||(v={}));var ln=["debug","info","warn","error","none"],R=class i{static get(){return new i({})}constructor(t){var e,n,s;if(this.fi=(n=v[(e=t.level)!=null?e:"info"])!=null?n:v.info,this.pi=(s=t.name)!=null?s:"LaunchDarkly",this.fe=t.formatter,typeof t.destination=="object")this.pe={[v.debug]:t.destination.debug,[v.info]:t.destination.info,[v.warn]:t.destination.warn,[v.error]:t.destination.error};else if(typeof t.destination=="function"){let{destination:r}=t;this.pe={[v.debug]:r,[v.info]:r,[v.warn]:r,[v.error]:r}}}gi(...t){var e;try{return this.fe?(e=this.fe)==null?void 0:e.call(this,...t):ee(...t)}catch(n){return ee(...t)}}mi(t,e){try{t(e)}catch(n){console.error(e)}}k(t,e){var n;if(t>=this.fi){let s=`${ln[t]}: [${this.pi}]`;try{let r=(n=this.pe)==null?void 0:n[t];r?this.mi(r,`${s} ${this.gi(...e)}`):console.error(...e)}catch(r){console.error(...e)}}}error(...t){this.k(v.error,t)}warn(...t){this.k(v.warn,t)}info(...t){this.k(v.info,t)}debug(...t){this.k(v.debug,t)}},hn={error:h.Function,warn:h.Function,info:h.Function,debug:h.Function},_=class{constructor(t,e){Object.entries(hn).forEach(([n,s])=>{if(!s.is(t[n]))throw new Error(`Provided logger instance must support logger.${n}(...) method`)}),this.t=t,this.yi=e}k(t,e){try{this.t[t](...e)}catch(n){this.yi[t](...e)}}error(...t){this.k("error",t)}warn(...t){this.k("warn",t)}info(...t){this.k("info",t)}debug(...t){this.k("debug",t)}},de=i=>{let t=new R({level:"info",destination:console.error,formatter:ee});return i?new _(i,t):t},k=class{static deprecated(t,e){return`"${t}" is deprecated, please use "${e}"`}static optionBelowMinimum(t,e,n){return`Config option "${t}" had invalid value of ${e}, using minimum of ${n} instead`}static unknownOption(t){return`Ignoring unknown config option "${t}"`}static wrongOptionType(t,e,n){return`Config option "${t}" should be of type ${e}, got ${n}, using default value`}static wrongOptionTypeBoolean(t,e){return`Config option "${t}" should be a boolean, got ${e}, converting to boolean`}static invalidTagValue(t){return`Config option "${t}" must only contain letters, numbers, ., _ or -.`}static tagValueTooLong(t){return`Value of "${t}" was longer than 64 characters and was discarded.`}static partialEndpoint(t){return`You have set custom uris without specifying the ${t} URI; connections may not work properly`}},dn=/^(\w|\.|-)+$/,fn=h.stringMatchingRegex(dn),pn={is:(i,t)=>fn.is(i)?i.length>64?{valid:!1,message:k.tagValueTooLong(t)}:{valid:!0}:{valid:!1,message:k.invalidTagValue(t)}},kt=class{constructor(t){let e={},n=t==null?void 0:t.application,s=t==null?void 0:t.logger;n&&Object.entries(n).forEach(([a,o])=>{if(o!=null){let{valid:c,message:u}=pn.is(o,`application.${a}`);c?a==="versionName"?e["application-version-name"]=[o]:e[`application-${a}`]=[o]:s==null||s.warn(u)}});let r=Object.keys(e);r.length&&(this.value=r.sort().flatMap(a=>e[a].sort().map(o=>`${a}/${o}`)).join(" "))}},xt=class{constructor(t,e,n){this.platform=n,this.basicConfiguration={tags:e.tags,logger:e.logger,offline:e.offline,serviceEndpoints:e.serviceEndpoints,sdkKey:t}}};function Jt(i){return i.replace(/\/+$/,"")}function fe(i){return i.replace(/^\/+/,"").replace(/\?$/,"")}var F=class i{constructor(t,e,n=i.DEFAULT_EVENTS,s="/bulk",r="/diagnostic",a=!0,o){this.streaming=Jt(t),this.polling=Jt(e),this.events=Jt(n),this.analyticsEventPath=s,this.diagnosticEventPath=r,this.includeAuthorizationHeader=a,this.payloadFilterKey=o}};F.DEFAULT_EVENTS="https://events.launchdarkly.com";function pe(i,t=[]){if(t.length===0)return i;let e=t.map(({key:n,value:s})=>`${n}=${s}`);return`${i}?${e.join("&")}`}function ni(i,t,e){let n=fe(t),s=[...e];return i.payloadFilterKey&&s.push({key:"filter",value:i.payloadFilterKey}),pe(`${i.streaming}/${n}`,s)}function si(i,t,e=[]){let n=fe(t),s=[...e];return i.payloadFilterKey&&s.push({key:"filter",value:i.payloadFilterKey}),pe(`${i.polling}/${n}`,s)}function Ye(i,t,e=[]){let n=fe(t);return pe(`${i.events}/${n}`,e)}var J=class extends Error{constructor(t){super(t),this.name="LaunchDarklyUnexpectedResponseError"}},q=class extends Error{constructor(t){super(t),this.name="LaunchDarklyClientError"}},C=class extends Error{constructor(t){super(t),this.name="LaunchDarklyTimeoutError"}};function Y(i){return i>=400&&i<500?i===400||i===408||i===429:!0}function gn(i){return i===413?!0:Y(i)}function ri(i,t){let e,n;return{promise:new Promise((r,a)=>{n=r,e=setTimeout(()=>{let o=`${t} timed out after ${i} seconds.`;a(new C(o))},i*1e3)}),cancel:()=>{n(),clearTimeout(e)}}}function ge(i){return i==null?i:JSON.parse(JSON.stringify(i))}function Nt(i){return Math.trunc(i*1e3)}var mn=i=>JSON.stringify(i)==="{}",Ot=(i,t)=>i&&Object.entries(i).reduce((e,[n,s])=>(s&&!mn(s)&&!(t!=null&&t.includes(n))&&(e[n]=typeof s=="object"?Ot(s,t):s),e),{});function G(i,t){if(i===t)return!0;if(i&&t&&typeof i=="object"&&typeof t=="object"){if(i.constructor!==t.constructor)return!1;var e,n,s;if(Array.isArray(i)){if(e=i.length,e!=t.length)return!1;for(n=e;n--!==0;)if(!G(i[n],t[n]))return!1;return!0}if(i instanceof Map&&t instanceof Map){if(i.size!==t.size)return!1;for(n of i.entries())if(!t.has(n[0]))return!1;for(n of i.entries())if(!G(n[1],t.get(n[0])))return!1;return!0}if(i instanceof Set&&t instanceof Set){if(i.size!==t.size)return!1;for(n of i.entries())if(!t.has(n[0]))return!1;return!0}if(ArrayBuffer.isView(i)&&ArrayBuffer.isView(t)){if(e=i.length,e!=t.length)return!1;for(n=e;n--!==0;)if(i[n]!==t[n])return!1;return!0}if(i.constructor===RegExp)return i.source===t.source&&i.flags===t.flags;if(i.valueOf!==Object.prototype.valueOf)return i.valueOf()===t.valueOf();if(i.toString!==Object.prototype.toString)return i.toString()===t.toString();if(s=Object.keys(i),e=s.length,e!==Object.keys(t).length)return!1;for(n=e;n--!==0;)if(!Object.prototype.hasOwnProperty.call(t,s[n]))return!1;for(n=e;n--!==0;){var r=s[n];if(!G(i[r],t[r]))return!1}return!0}return i!==i&&t!==t}function ai(i,t,e,n=!0,s="user-agent"){let{userAgentBase:r,version:a,wrapperName:o,wrapperVersion:c}=t.sdkData(),u={[s]:`${r!=null?r:"NodeJSClient"}/${a}`};return n&&(u.authorization=i),o&&(u["x-launchdarkly-wrapper"]=c?`${o}/${c}`:o),e!=null&&e.value&&(u["x-launchdarkly-tags"]=e.value),u}function I(i,t,e){let n;i.status?n=`error ${i.status}${i.status===401?" (invalid SDK key)":""}`:n=`I/O error (${i.message||"unknown error"})`;let s=e!=null?e:"giving up permanently";return`Received ${n} for ${t} - ${s}`}function $t({status:i}){return i?Y(i):!0}var me=(i,t)=>t.btoa(i).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"");var ye=async(i=1e3)=>new Promise(t=>{setTimeout(t,i)});var ie=class{constructor(t,e,n){this.h=e,this.vi=n,this.At=[],this.ge=Date.now(),this.me=this.ge,this.ye={diagnosticId:e.crypto.randomUUID(),sdkKeySuffix:t.length>6?t.substring(t.length-6):t}}createInitEvent(){var n,s,r;let t=this.h.info.sdkData(),e=this.h.info.platformData();return{kind:"diagnostic-init",id:this.ye,creationDate:this.ge,sdk:t,configuration:this.vi,platform:p({name:e.name,osArch:(n=e.os)==null?void 0:n.arch,osName:(s=e.os)==null?void 0:s.name,osVersion:(r=e.os)==null?void 0:r.version},e.additional||{})}}recordStreamInit(t,e,n){let s={timestamp:t,failed:e,durationMillis:n};this.At.push(s)}createStatsEventAndReset(t,e,n){let s=Date.now(),r={kind:"diagnostic",id:this.ye,creationDate:s,dataSinceDate:this.me,droppedEvents:t,deduplicatedUsers:e,eventsInLastBatch:n,streamInits:this.At};return this.At=[],this.me=s,r}},ne;(function(i){i.MalformedFlag="MALFORMED_FLAG",i.UserNotSpecified="USER_NOT_SPECIFIED",i.FlagNotFound="FLAG_NOT_FOUND",i.ClientNotReady="CLIENT_NOT_READY",i.WrongType="WRONG_TYPE"})(ne||(ne={}));var yn=ne,Lt=class{static invalidMetricValue(t){return`The track function was called with a non-numeric "metricValue" (${t}), only numeric metric values are supported.`}};Lt.MissingContextKeyNoEvent="Context was unspecified or had no key; event will not be sent";var se=class{constructor(t,e){let{basicConfiguration:n,platform:s}=t,{serviceEndpoints:{analyticsEventPath:r,diagnosticEventPath:a}}=n,{crypto:o,requests:c}=s;this.wi=p({},e),this.ve=Ye(n.serviceEndpoints,r,[]),this.Ei=Ye(n.serviceEndpoints,a,[]),this.I=c,this.Di=o}async ct(t,e,n,s){let r={status:$.Succeeded},a=b(p({},this.wi),{"content-type":"application/json"});n&&(a["x-launchdarkly-payload-id"]=n,a["x-launchDarkly-event-schema"]="4");let o;try{let{status:c,headers:u}=await this.I.fetch(e,{headers:a,body:JSON.stringify(t),compressBodyIfPossible:!0,method:"POST",keepalive:!0}),l=Date.parse(u.get("date")||"");if(l&&(r.serverTime=l),c<=204)return r;if(o=new J(I({status:c,message:"some events were dropped"},"event posting")),!Y(c))return gn(c)?r.status=$.Failed:r.status=$.FailedAndMustShutDown,r.error=o,r}catch(c){o=c}return o&&!s?(r.status=$.Failed,r.error=o,r):(await ye(),this.ct(t,this.ve,n,!1))}async sendEventData(t,e){let n=t===B.AnalyticsEvents?this.Di.randomUUID():void 0,s=t===B.AnalyticsEvents?this.ve:this.Ei;return this.ct(e,s,n,!0)}};function St(i){return i.kind==="feature"}function vn(i){return i.kind==="identify"}function wn(i){return i.kind==="migration_op"}var re=class{constructor(t,e,n,s,r,a){this.count=t,this.key=e,this.value=n,this.version=r,this.variation=a,this.default=s}increment(){this.count+=1}};function En(i){return`${i.key}:${i.variation!==null&&i.variation!==void 0?i.variation:""}:${i.version!==null&&i.version!==void 0?i.version:""}`}var Ct=class{constructor(t=!1,e){this.bi=t,this.x=e,this.X=0,this.ut=0,this.lt={},this.ht={}}summarizeEvent(t){if(St(t)&&!t.excludeFromSummaries){this.m||(this.m=t.context);let e=En(t),n=this.lt[e],s=this.ht[t.key];s||(s=new Set,this.ht[t.key]=s),t.context.kinds.forEach(r=>s.add(r)),n?n.increment():this.lt[e]=new re(1,t.key,t.value,t.default,t.version,t.variation),(this.X===0||t.creationDate<this.X)&&(this.X=t.creationDate),t.creationDate>this.ut&&(this.ut=t.creationDate)}}getSummary(){var n;let t=Object.values(this.lt).reduce((s,r)=>{let a=s[r.key];a||(a={default:r.default,counters:[],contextKinds:[...this.ht[r.key]]},s[r.key]=a);let o={value:r.value,count:r.count};return r.variation!==void 0&&r.variation!==null&&(o.variation=r.variation),r.version!==void 0&&r.version!==null?o.version=r.version:o.unknown=!0,a.counters.push(o),s},{}),e={startDate:this.X,endDate:this.ut,features:t,kind:"summary",context:this.m!==void 0&&this.bi?(n=this.x)==null?void 0:n.filter(this.m):void 0};return this.ki(),e}ki(){this.X=0,this.ut=0,this.lt={},this.ht={}}},ae=class extends Error{constructor(t){super(t),this.name="LaunchDarklyInvalidSDKKeyError"}},oe=class{constructor(t,e){this.x=t,this.t=e,this.Q={}}summarizeEvent(t){var e;if(St(t)){let n=t.context.canonicalUnfilteredJson();if(!n){t.context.valid&&((e=this.t)==null||e.error("Unable to serialize context, likely the context contains a cycle."));return}let s=this.Q[n];s||(this.Q[n]=new Ct(!0,this.x),s=this.Q[n]),s.summarizeEvent(t)}}getSummaries(){let t=this.Q;return this.Q={},Object.values(t).map(e=>e.getSummary())}};function vt(i){let t=Math.trunc(i);return t===1?!0:t===0?!1:Math.floor(Math.random()*t)===0}function Dn(i){return i.getSummaries!==void 0}var ce=class{constructor(t,e,n,s,r,a=!0,o=!1){this.r=t,this.dt=s,this.L=r,this.ft=[],this.we=0,this.Pt=0,this.It=0,this.Nt=!1,this.Ee=0,this.Ot=!1,this.$t=null,this.xi=t.eventsCapacity,this.t=e.basicConfiguration.logger,this.De=new se(e,n),this.x=new te(t.allAttributesPrivate,t.privateAttributes.map(c=>new A(c))),o?this.tt=new oe(this.x,this.t):this.tt=new Ct,a&&this.start()}start(){var t,e;if(((t=this.dt)==null?void 0:t.flushInterval)!==void 0&&(this.$t=setInterval(()=>{var n;(n=this.dt)==null||n.flush()},this.dt.flushInterval*1e3)),this.Li=setInterval(async()=>{var n;try{await this.flush()}catch(s){(n=this.t)==null||n.debug(`Flush failed: ${s}`)}},this.r.flushInterval*1e3),this.L){let n=this.L.createInitEvent();this.be(n),this.ke=setInterval(()=>{let s=this.L.createStatsEventAndReset(this.Pt,this.It,this.Ee);this.Pt=0,this.It=0,this.be(s)},this.r.diagnosticRecordingInterval*1e3)}(e=this.t)==null||e.debug("Started EventProcessor.")}be(t){this.De.sendEventData(B.DiagnosticEvent,t)}close(){clearInterval(this.Li),this.$t&&clearInterval(this.$t),this.ke&&clearInterval(this.ke)}async flush(){var e;if(this.Ot)throw new ae("Events cannot be posted because a permanent error has been encountered. This is most likely an invalid SDK key. The specific error information is logged independently.");let t=this.ft;if(this.ft=[],Dn(this.tt))this.tt.getSummaries().forEach(s=>{Object.keys(s.features).length&&t.push(s)});else{let n=this.tt.getSummary();Object.keys(n.features).length&&t.push(n)}t.length&&(this.Ee=t.length,(e=this.t)==null||e.debug("Flushing %d events",t.length),await this.ct(t))}sendEvent(t){var c;if(this.Ot)return;if(wn(t)){if(vt(t.samplingRatio)){let u=b(p({},t),{context:t.context?this.x.filter(t.context):void 0});u.samplingRatio===1&&delete u.samplingRatio,this.pt(u)}return}this.tt.summarizeEvent(t);let e=St(t),n=e&&t.trackEvents||!e,s=this.Si(t),r=vn(t),a=(c=this.dt)==null?void 0:c.processContext(t.context);a||r||(this.It+=1),a&&!r&&this.pt(this.Mt({kind:"index",creationDate:t.creationDate,context:t.context,samplingRatio:1},!1)),n&&vt(t.samplingRatio)&&this.pt(this.Mt(t,!1)),s&&vt(t.samplingRatio)&&this.pt(this.Mt(t,!0))}Mt(t,e){switch(t.kind){case"feature":{let n={kind:e?"debug":"feature",creationDate:t.creationDate,context:this.x.filter(t.context,!e),key:t.key,value:t.value,default:t.default};return t.samplingRatio!==1&&(n.samplingRatio=t.samplingRatio),t.prereqOf&&(n.prereqOf=t.prereqOf),t.variation!==void 0&&(n.variation=t.variation),t.version!==void 0&&(n.version=t.version),t.reason&&(n.reason=t.reason),n}case"index":case"identify":{let n={kind:t.kind,creationDate:t.creationDate,context:this.x.filter(t.context)};return t.samplingRatio!==1&&(n.samplingRatio=t.samplingRatio),n}case"custom":{let n={kind:"custom",creationDate:t.creationDate,key:t.key,context:this.x.filter(t.context)};return t.samplingRatio!==1&&(n.samplingRatio=t.samplingRatio),t.data!==void 0&&(n.data=t.data),t.metricValue!==void 0&&(n.metricValue=t.metricValue),t.url!==void 0&&(n.url=t.url),n}case"click":return{kind:"click",creationDate:t.creationDate,contextKeys:t.context.kindsAndKeys,key:t.key,url:t.url,selector:t.selector};case"pageview":return{kind:"pageview",creationDate:t.creationDate,contextKeys:t.context.kindsAndKeys,key:t.key,url:t.url};default:return t}}pt(t){var e;this.ft.length<this.xi?(this.ft.push(t),this.Nt=!1):(this.Nt||(this.Nt=!0,(e=this.t)==null||e.warn("Exceeded event queue capacity. Increase capacity to avoid dropping events.")),this.Pt+=1)}Si(t){return St(t)&&t.debugEventsUntilDate&&t.debugEventsUntilDate>this.we&&t.debugEventsUntilDate>Date.now()}async ct(t){let e=await this.De.sendEventData(B.AnalyticsEvents,t);if(e.status===$.FailedAndMustShutDown&&(this.Ot=!0),e.serverTime&&(this.we=e.serverTime),e.error)throw e.error}},Tt=class{constructor(t,e,n,s,r=1,a){this.context=t,this.key=e,this.data=n,this.metricValue=s,this.samplingRatio=r,this.url=a,this.kind="custom",this.creationDate=Date.now(),this.context=t}},W=class{constructor(t,e,n,s,r,a,o,c,u,l,d,f,m=1){this.withReasons=t,this.context=e,this.key=n,this.samplingRatio=m,this.kind="feature",this.creationDate=Date.now(),this.value=s,this.default=r,a!==void 0&&(this.version=a),o!==void 0&&(this.variation=o),c!==void 0&&(this.trackEvents=c),u!==void 0&&(this.prereqOf=u),l!==void 0&&(this.reason=l),d!==void 0&&(this.debugEventsUntilDate=d),f!==void 0&&(this.excludeFromSummaries=f)}},At=class{constructor(t,e=1){this.context=t,this.samplingRatio=e,this.kind="identify",this.creationDate=Date.now()}},ue=class{close(){}async flush(){}sendEvent(){}},le=class{constructor(t){this.Rt=t}evalEvent(t){var e;return new W(this.Rt,t.context,t.flagKey,t.value,t.defaultVal,t.version,(e=t.variation)!=null?e:void 0,t.trackEvents||t.addExperimentData,t.prereqOfFlagKey,this.Rt||t.addExperimentData?t.reason:void 0,t.debugEventsUntilDate,t.excludeFromSummaries,t.samplingRatio)}unknownFlagEvent(t,e,n){return new W(this.Rt,n,t,e,e,void 0,void 0,void 0,void 0,void 0,void 0,void 0,void 0)}identifyEvent(t){return new At(t,1)}customEvent(t,e,n,s,r=1){return new Tt(e,t,n!=null?n:void 0,s!=null?s:void 0,r)}},Ze="FDv1Fallback";function bn(i){return{Ci:i,xe:"",useSelector(t){return this.xe=t,this},processFullTransfer(t){let e=[{event:"server-intent",data:{payloads:[{id:Ze,target:1,intentCode:"xfer-full",reason:"payload-missing"}]}}];Object.entries((t==null?void 0:t.flags)||[]).forEach(([n,s])=>{e.push({event:"put-object",data:{kind:"flag",key:n,version:s.version||1,object:s}})}),Object.entries((t==null?void 0:t.segments)||[]).forEach(([n,s])=>{e.push({event:"put-object",data:{kind:"segment",key:n,version:s.version||1,object:s}})}),e.push({event:"payload-transferred",data:{state:this.xe,version:1,id:Ze}}),this.Ci.processEvents(e)}}}var Pt=class{constructor(t,e,n){this.Ti=t,this.g=e,this.t=n,this.e=[],this.F=void 0,this.K=!1,this.G=[],this.Ai=s=>{var a;if(this.Ft(),!s.payloads.length)return;let r=s.payloads[0];switch(r==null?void 0:r.intentCode){case"xfer-full":this.K=!0;break;case"xfer-changes":this.K=!1;break;case"none":this.K=!1,this.Pi(r);break;default:(a=this.t)==null||a.warn(`Unable to process intent code '${r==null?void 0:r.intentCode}'.`);return}this.F=r==null?void 0:r.id},this.Ii=s=>{var a;if(!this.F||!s.kind||!s.key||!s.version||!s.object)return;let r=this.Ni(s.kind,s.object);if(!r){(a=this.t)==null||a.warn(`Unable to process object for kind: '${s.kind}'`);return}this.G.push({kind:s.kind,key:s.key,version:s.version,object:r})},this.Oi=s=>{!this.F||!s.kind||!s.key||!s.version||this.G.push({kind:s.kind,key:s.key,version:s.version,deleted:!0})},this.Pi=s=>{if(!s.id||!s.target)return;let r={id:s.id,version:s.target,basis:!1,updates:[]};this.e.forEach(a=>a(r)),this.Le()},this.$i=s=>{if(!this.F||s.state===null||s.state===void 0||!s.version){this.Ft();return}let r={id:this.F,version:s.version,state:s.state,basis:this.K,updates:this.G};this.e.forEach(a=>a(r)),this.Le()},this.Mi=s=>{var r;(r=this.t)==null||r.info(`Goodbye was received from the LaunchDarkly connection with reason: ${s.reason}.`),this.Ft()},this.Ri=s=>{var r;(r=this.t)==null||r.info(`An issue was encountered receiving updates for payload ${this.F} with reason: ${s.reason}.`),this.Fi()}}addPayloadListener(t){this.e.push(t)}removePayloadListener(t){let e=this.e.indexOf(t,0);e>-1&&this.e.splice(e,1)}processEvents(t){t.forEach(e=>{switch(e.event){case"server-intent":{this.Ai(e.data);break}case"put-object":{this.Ii(e.data);break}case"delete-object":{this.Oi(e.data);break}case"payload-transferred":{this.$i(e.data);break}case"goodbye":{this.Mi(e.data);break}case"error":{this.Ri(e.data);break}}})}Ni(t,e){var n,s;return(s=(n=this.Ti)[t])==null?void 0:s.call(n,e)}Le(){this.K=!1,this.G=[]}Fi(){this.G=[]}Ft(){this.F=void 0,this.K=!1,this.G=[]}},he=class{constructor(t,e,n,s){this.g=n,this.t=s,this.z(t,"server-intent"),this.z(t,"put-object"),this.z(t,"delete-object"),this.z(t,"payload-transferred"),this.z(t,"goodbye"),this.z(t,"error"),this.Ut=new Pt(e,n,s)}addPayloadListener(t){this.Ut.addPayloadListener(t)}removePayloadListener(t){this.Ut.removePayloadListener(t)}z(t,e){t.addEventListener(e,async n=>{var s,r,a,o,c;if(n!=null&&n.data){(s=this.t)==null||s.debug(`Received ${e} event. Data is ${n.data}`);try{this.Ut.processEvents([{event:e,data:JSON.parse(n.data)}])}catch(u){(r=this.t)==null||r.error(`Stream received data that was unable to be processed in "${e}" message`),(a=this.t)==null||a.debug(`Data follows: ${n.data}`),(o=this.g)==null||o.call(this,w.InvalidData,"Malformed data in EventStream.")}}else(c=this.g)==null||c.call(this,w.Unknown,"Event from EventStream missing data.")})}};function kn(i){if(i){let t=Object.keys(i).find(e=>e.toLowerCase()==="x-ld-envid");if(t)return{environmentId:i[t]}}}var Xe="unknown plugin";function It(i,t){try{return t.getMetadata().name||Xe}catch(e){return i.error("Exception thrown getting metadata for plugin. Unable to get plugin name."),Xe}}function xn(i,t,e){let n=[];return e.forEach(s=>{var r;try{let a=(r=s.getHooks)==null?void 0:r.call(s,t);a===void 0?i.error(`Plugin ${It(i,s)} returned undefined from getHooks.`):a&&a.length>0&&n.push(...a)}catch(a){i.error(`Exception thrown getting hooks for plugin ${It(i,s)}. Unable to get hooks.`)}}),n}function Ln(i,t,e,n){n.forEach(s=>{try{s.register(e,t)}catch(r){i.error(`Exception thrown registering plugin ${It(i,s)}.`)}})}var L=Object.freeze({__proto__:null,ClientMessages:Lt,DiagnosticsManager:ie,ErrorKinds:yn,EventFactoryBase:le,EventProcessor:ce,FDv1PayloadAdaptor:bn,InputCustomEvent:Tt,InputEvalEvent:W,InputIdentifyEvent:At,NullEventProcessor:ue,PayloadProcessor:Pt,PayloadStreamReader:he,canonicalize:Dt,initMetadataFromHeaders:kn,isLegacyUser:ii,isMultiKind:ei,isSingleKind:ti,safeGetHooks:xn,safeGetName:It,safeRegisterPlugins:Ln,shouldSample:vt});var E;(function(i){i.Initializing="INITIALIZING",i.Valid="VALID",i.Interrupted="INTERRUPTED",i.SetOffline="SET_OFFLINE",i.Closed="CLOSED"})(E||(E={}));function Cn(i){return i>=200&&i<=299}var Mt=class extends Error{constructor(t,e){super(t),this.status=e,this.name="LaunchDarklyRequestError"}},be=class{constructor(t,e,n,s,r){this.I=t,this.Ui=e,this.gt=n,this.Vi=s,this.ji=r}async requestPayload(){let t;try{let e=await this.I.fetch(this.Ui,{method:this.Vi,headers:this.gt,body:this.ji});if(Cn(e.status))return await e.text();t=e.status}catch(e){throw new Mt(e==null?void 0:e.message)}throw new Mt(`Unexpected status code: ${t}`,t)}};function Me(i,t,e,n,s,r,a,o,c,u){let l,d="GET",f=p({},r);c&&(d="REPORT",f["content-type"]="application/json",l=i);let m=c?e.pathReport(s,i):e.pathGet(s,i),g=[...a!=null?a:[]];o&&g.push({key:"withReasons",value:"true"}),u&&g.push({key:"h",value:u});let y=si(t,m,g);return new be(n,y,f,d,l)}var oi=new Error("Task has already been executed or shed. This is likely an implementation error. The task will not be executed again.");function Tn(i,t,e=!1){let n,s=new Promise(o=>{n=(c,u)=>{var l;try{(l=i.after)==null||l.call(i,c,u)}catch(d){t==null||t.error(`Error in after callback: ${d}`)}o(c)}}),r=i.before?i.before():Promise.resolve(void 0),a=!1;return{execute:()=>{a&&(t==null||t.error(oi)),a=!0,r.then(o=>{i.execute(o).then(c=>n({status:"complete",result:c},o)).catch(c=>n({status:"error",error:c},o))}).catch(o=>{t==null||t.error(o),n({status:"error",error:o},void 0)})},shed:()=>{a&&(t==null||t.error(oi)),a=!0,r.then(o=>{n({status:"shed"},o)})},promise:s,sheddable:e}}function An(i){let t,e=[];function n(){if(!t&&e.length>0){let s=e.shift();t=s.promise.finally(()=>{t=void 0,n()}),s.execute()}}return{execute(s,r=!1){var o,c;let a=Tn(s,i,r);return t?((o=e[e.length-1])!=null&&o.sheddable&&((c=e.pop())==null||c.shed()),e.push(a)):(t=a.promise.finally(()=>{t=void 0,n()}),a.execute()),a.promise},pendingCount(){return e.length}}}var Pn={logger:h.Object,maxCachedContexts:h.numberWithMin(0),baseUri:h.String,streamUri:h.String,eventsUri:h.String,capacity:h.numberWithMin(1),diagnosticRecordingInterval:h.numberWithMin(2),flushInterval:h.numberWithMin(2),streamInitialReconnectDelay:h.numberWithMin(0),allAttributesPrivate:h.Boolean,debug:h.Boolean,diagnosticOptOut:h.Boolean,withReasons:h.Boolean,sendEvents:h.Boolean,pollInterval:h.numberWithMin(30),useReport:h.Boolean,privateAttributes:h.StringArray,applicationInfo:h.Object,wrapperName:h.String,wrapperVersion:h.String,payloadFilterKey:h.stringMatchingRegex(/^[a-zA-Z0-9](\w|\.|-)*$/),hooks:h.createTypeArray("Hook[]",{}),inspectors:h.createTypeArray("LDInspection",{})},In=300,pi="https://clientsdk.launchdarkly.com",gi="https://clientstream.launchdarkly.com";function Nn(i){return i instanceof _?i:de(i)}var ke=class{constructor(t={},e={getImplementationHooks:()=>[],credentialType:"mobileKey"}){var s,r,a;this.logger=de(),this.baseUri=pi,this.eventsUri=F.DEFAULT_EVENTS,this.streamUri=gi,this.maxCachedContexts=5,this.capacity=100,this.diagnosticRecordingInterval=900,this.flushInterval=30,this.streamInitialReconnectDelay=1,this.allAttributesPrivate=!1,this.debug=!1,this.diagnosticOptOut=!1,this.sendEvents=!0,this.sendLDHeaders=!0,this.useReport=!1,this.withReasons=!1,this.privateAttributes=[],this.pollInterval=In,this.hooks=[],this.inspectors=[],this.logger=Nn(t.logger),this.Hi(t).forEach(o=>this.logger.warn(o)),this.serviceEndpoints=new F(this.streamUri,this.baseUri,this.eventsUri,e.analyticsEventPath,e.diagnosticEventPath,e.includeAuthorizationHeader,t.payloadFilterKey),this.useReport=(s=t.useReport)!=null?s:!1,this.tags=new kt({application:this.applicationInfo,logger:this.logger}),this.userAgentHeaderName=(r=e.userAgentHeaderName)!=null?r:"user-agent",this.trackEventModifier=(a=e.trackEventModifier)!=null?a:(o=>o),this.credentialType=e.credentialType,this.getImplementationHooks=e.getImplementationHooks}Hi(t){let e=[];return Object.entries(t).forEach(([n,s])=>{let r=Pn[n];if(r)if(r.is(s))n==="logger"||(this[n]=s!=null?s:void 0);else{let a=r.getType();if(a==="boolean")e.push(k.wrongOptionTypeBoolean(n,typeof s)),this[n]=!!s;else if(a==="boolean | undefined | null")e.push(k.wrongOptionTypeBoolean(n,typeof s)),typeof s!="boolean"&&typeof s!="undefined"&&s!==null&&(this[n]=!!s);else if(r instanceof z&&h.Number.is(s)){let{min:o}=r;e.push(k.optionBelowMinimum(n,s,o)),this[n]=o}else e.push(k.wrongOptionType(n,r.getType(),typeof s))}else e.push(k.unknownOption(n))}),e}};async function mi(i,t){if(i.digest)return i.digest(t);if(i.asyncDigest)return i.asyncDigest(t);throw new Error("Platform must implement digest or asyncDigest")}var yi=async(i,{crypto:t,storage:e})=>{let n=await(e==null?void 0:e.get(i));return n||(n=t.randomUUID(),await(e==null?void 0:e.set(i,n))),n};function vi(i){return async t=>mi(i.createHash("sha256").update(t),"base64")}var S=async i=>i;async function X(i){return(await Promise.all(i.map(e=>e.transform(e.value)))).join("_")}async function On(i,t){return X([{value:"LaunchDarkly",transform:S},{value:t,transform:vi(i)}])}async function $n(i){return X([{value:"LaunchDarkly",transform:S},{value:"AnonymousKeys",transform:S},{value:i,transform:S}])}async function Mn(i){return X([{value:"LaunchDarkly",transform:S},{value:"ContextKeys",transform:S},{value:i,transform:S}])}async function Rn(i){return X([{value:i,transform:S},{value:"ContextIndex",transform:S}])}async function ci(i,t,e){return X([{value:t,transform:S},{value:e.canonicalKey,transform:vi(i)}])}var{isLegacyUser:Fn,isSingleKind:ve,isMultiKind:ui}=L,wi="1.0",Un=i=>{let n=i,{kind:t}=n,e=zt(n,["kind"]);return{kind:"multi",[t]:e}},Vn=async({crypto:i,info:t},{applicationInfo:e})=>{var a;let{ld_application:n}=t.platformData(),s=(a=Ot(n))!=null?a:{},r=(e==null?void 0:e.id)||(s==null?void 0:s.id);if(r){let o=(e==null?void 0:e.version)||(s==null?void 0:s.version),c=(e==null?void 0:e.name)||(s==null?void 0:s.name),u=(e==null?void 0:e.versionName)||(s==null?void 0:s.versionName);return s=p(p(p(b(p({},s),{id:r}),o?{version:o}:{}),c?{name:c}:{}),u?{versionName:u}:{}),s.key=await mi(i.createHash("sha256").update(r),"base64"),s.envAttributesVersion=s.envAttributesVersion||wi,s}},jn=async i=>{var o,c,u,l;let{ld_device:t,os:e}=i.info.platformData(),n=(o=Ot(t))!=null?o:{},s=(e==null?void 0:e.name)||((c=n.os)==null?void 0:c.name),r=(e==null?void 0:e.version)||((u=n.os)==null?void 0:u.version),a=(l=n.os)==null?void 0:l.family;if((s||r||a)&&(n.os=p(p(p({},s?{name:s}:{}),r?{version:r}:{}),a?{family:a}:{})),Object.keys(n).filter(d=>d!=="key"&&d!=="envAttributesVersion").length){let d=await Mn("ld_device");return n.key=await yi(d,i),n.envAttributesVersion=n.envAttributesVersion||wi,n}},Hn=async(i,t,e)=>{if(Fn(i))return i;let n,s;if(ve(i)&&i.kind!=="ld_application"||ui(i)&&!i.ld_application?n=await Vn(t,e):e.logger.warn("Not adding ld_application environment attributes because it already exists."),ve(i)&&i.kind!=="ld_device"||ui(i)&&!i.ld_device?s=await jn(t):e.logger.warn("Not adding ld_device environment attributes because it already exists."),n||s){let r=ve(i)?Un(i):i;return p(p(p({},r),n?{ld_application:n}:{}),s?{ld_device:s}:{})}return i},{isLegacyUser:Bn,isMultiKind:Kn,isSingleKind:Gn}=L,Re=async(i,t,e)=>{let{anonymous:n,key:s}=t;if(n&&!s){let r=await $n(i);t.key=await yi(r,e)}},zn=async(i,t)=>{await Re(i.kind,i,t)},_n=async(i,t)=>{let s=i,{kind:e}=s,n=zt(s,["kind"]);return Promise.all(Object.entries(n).map(([r,a])=>Re(r,a,t)))},Jn=async(i,t)=>{await Re("user",i,t)},qn=async(i,t)=>{let e=ge(i);return Gn(e)&&await zn(e,t),Kn(e)&&await _n(e,t),Bn(e)&&await Jn(e,t),e},Wn=i=>({customBaseURI:i.serviceEndpoints.polling!==pi,customStreamURI:i.serviceEndpoints.streaming!==gi,customEventsURI:i.serviceEndpoints.events!==F.DEFAULT_EVENTS,eventsCapacity:i.capacity,eventsFlushIntervalMillis:Nt(i.flushInterval),reconnectTimeMillis:Nt(i.streamInitialReconnectDelay),diagnosticRecordingIntervalMillis:Nt(i.diagnosticRecordingInterval),allAttributesPrivate:i.allAttributesPrivate,usingSecureMode:!1,bootstrapMode:!1}),Yn=(i,t,e)=>{if(t.sendEvents&&!t.diagnosticOptOut)return new L.DiagnosticsManager(i,e,Wn(t))};function we(i,t){return{value:t!=null?t:null,variationIndex:null,reason:{kind:"ERROR",errorKind:i}}}function li(i,t,e){return{value:i,variationIndex:t!=null?t:null,reason:e!=null?e:null}}var Zn=(i,t,e,n,s)=>{if(t.sendEvents)return new L.EventProcessor(b(p({},t),{eventsCapacity:t.capacity}),new xt(i,t,e),n,void 0,s,!1,!0)},Rt=class extends L.EventFactoryBase{evalEventClient(t,e,n,s,r,a){let{trackEvents:o,debugEventsUntilDate:c,trackReason:u,flagVersion:l,version:d,variation:f}=s;return super.evalEvent({addExperimentData:u,context:r,debugEventsUntilDate:c,defaultVal:n,flagKey:t,reason:a,trackEvents:!!o,value:e,variation:f,version:l!=null?l:d})}},Z=class i{constructor(){this.container={index:new Array}}static fromJson(t){let e=new i;try{e.container=JSON.parse(t)}catch(n){}return e}toJson(){return JSON.stringify(this.container)}notice(t,e){let n=this.container.index.find(s=>s.id===t);n===void 0?this.container.index.push({id:t,timestamp:e}):n.timestamp=e}prune(t){let e=Math.max(t,0);return this.container.index.length>e?(this.container.index.sort((n,s)=>n.timestamp-s.timestamp),this.container.index.splice(0,this.container.index.length-e)):[]}},xe=class{constructor(t,e,n,s,r,a,o=()=>Date.now()){this.h=t,this.Vt=e,this.Bi=n,this.v=s,this.N=r,this.t=a,this.mt=o,this.Se=Rn(this.Vt)}async init(t,e){this.N.init(t,e),await this.Ce(t)}async upsert(t,e,n){return this.N.upsert(t,e,n)?(await this.Ce(t),!0):!1}async loadCached(t){var s,r,a,o;let e=await ci(this.h.crypto,this.Vt,t),n=await((s=this.h.storage)==null?void 0:s.get(e));if(n==null){if(n=await((r=this.h.storage)==null?void 0:r.get(t.canonicalKey)),n==null)return!1;await((a=this.h.storage)==null?void 0:a.set(e,n)),await((o=this.h.storage)==null?void 0:o.clear(t.canonicalKey))}try{let c=JSON.parse(n),u=Object.entries(c).reduce((l,[d,f])=>(l[d]={version:f.version,flag:f},l),{});return this.N.initCached(t,u),this.t.debug("Loaded cached flag evaluations from persistent storage"),!0}catch(c){return this.t.warn(`Could not load cached flag evaluations from persistent storage: ${c.message}`),!1}}async Ki(){var e;if(this._!==void 0)return this._;let t=await((e=this.h.storage)==null?void 0:e.get(await this.Se));if(!t)return this._=new Z,this._;try{this._=Z.fromJson(t),this.t.debug("Loaded context index from persistent storage")}catch(n){this.t.warn(`Could not load index from persistent storage: ${n.message}`),this._=new Z}return this._}async Ce(t){var c,u;let e=await this.Ki(),n=await ci(this.h.crypto,this.Vt,t);e.notice(n,this.mt());let s=e.prune(this.Bi);await Promise.all(s.map(async l=>{var d;return(d=this.h.storage)==null?void 0:d.clear(l.id)})),await((c=this.h.storage)==null?void 0:c.set(await this.Se,e.toJson()));let r=this.v.getAll(),a=Object.entries(r).reduce((l,[d,f])=>(f.flag!==null&&f.flag!==void 0&&(l[d]=f.flag),l),{}),o=JSON.stringify(a);await((u=this.h.storage)==null?void 0:u.set(n,o))}},Le=class{constructor(){this.et={}}init(t){this.et=Object.entries(t).reduce((e,[n,s])=>(e[n]=s,e),{})}insertOrUpdate(t,e){this.et[t]=e}get(t){if(Object.prototype.hasOwnProperty.call(this.et,t))return this.et[t]}getAll(){return this.et}};function Xn(i,t){let e=[];return Object.entries(i).forEach(([n,s])=>{let r=t[n];(!r||!G(s,r))&&e.push(n)}),Object.keys(t).forEach(n=>{i[n]||e.push(n)}),e}var Se=class{constructor(t,e){this.it=new Array,this.v=t,this.t=e}init(t,e){this.Te=t.canonicalKey;let n=this.v.getAll();this.v.init(e);let s=Xn(n,e);s.length>0&&this.it.forEach(r=>{try{r(t,s,"init")}catch(a){}})}initCached(t,e){this.Te!==t.canonicalKey&&this.init(t,e)}upsert(t,e,n){if(this.Te!==t.canonicalKey)return this.t.warn("Received an update for an inactive context."),!1;let s=this.v.get(e);return s!==void 0&&s.version>=n.version?!1:(this.v.insertOrUpdate(e,n),this.it.forEach(r=>{try{r(t,[e],"patch")}catch(a){}}),!0)}on(t){this.it.push(t)}off(t){let e=this.it.indexOf(t);e>-1&&this.it.splice(e,1)}},Ce=class{constructor(t,e,n,s,r=()=>Date.now()){this.v=new Le,this.N=new Se(this.v,s),this.jt=this.Gi(t,e,n,s,r)}async Gi(t,e,n,s,r=()=>Date.now()){let a=await On(t.crypto,e);return new xe(t,a,n,this.v,this.N,s,r)}get(t){return this.v.get(t)}getAll(){return this.v.getAll()}setBootstrap(t,e){this.N.init(t,e)}async init(t,e){return(await this.jt).init(t,e)}async upsert(t,e,n){return(await this.jt).upsert(t,e,n)}async loadCached(t){return(await this.jt).loadCached(t)}on(t){this.N.on(t)}off(t){this.N.off(t)}},hi="unknown hook",Ei="beforeEvaluation",Di="afterEvaluation",Qn="afterTrack";function Q(i,t,e,n,s){try{return n()}catch(r){return i==null||i.error(`An error was encountered in "${t}" of the "${e}" hook: ${r}`),s}}function tt(i,t){try{return t.getMetadata().name||hi}catch(e){return i.error("Exception thrown getting metadata for hook. Unable to get hook name."),hi}}function ts(i,t,e){return t.map(n=>Q(i,Ei,tt(i,n),()=>{var s,r;return(r=(s=n==null?void 0:n.beforeEvaluation)==null?void 0:s.call(n,e,{}))!=null?r:{}},{}))}function es(i,t,e,n,s){for(let r=t.length-1;r>=0;r-=1){let a=t[r],o=n[r];Q(i,Di,tt(i,a),()=>{var c,u;return(u=(c=a==null?void 0:a.afterEvaluation)==null?void 0:c.call(a,e,o,s))!=null?u:{}},{})}}function is(i,t,e){return t.map(n=>Q(i,Ei,tt(i,n),()=>{var s,r;return(r=(s=n==null?void 0:n.beforeIdentify)==null?void 0:s.call(n,e,{}))!=null?r:{}},{}))}function ns(i,t,e,n,s){for(let r=t.length-1;r>=0;r-=1){let a=t[r],o=n[r];Q(i,Di,tt(i,a),()=>{var c,u;return(u=(c=a==null?void 0:a.afterIdentify)==null?void 0:c.call(a,e,o,s))!=null?u:{}},{})}}function ss(i,t,e){for(let n=t.length-1;n>=0;n-=1){let s=t[n];Q(i,Qn,tt(i,s),()=>{var r;return(r=s==null?void 0:s.afterTrack)==null?void 0:r.call(s,e)},void 0)}}var Te=class{constructor(t,e){this.t=t,this.U=[],this.U.push(...e)}withEvaluation(t,e,n,s){if(this.U.length===0)return s();let r=[...this.U],a={flagKey:t,context:e,defaultValue:n},o=ts(this.t,r,a),c=s();return es(this.t,r,a,o,c),c}identify(t,e){let n=[...this.U],s={context:t,timeout:e},r=is(this.t,n,s);return a=>{ns(this.t,n,s,r,a)}}addHook(t){this.U.push(t)}afterTrack(t){if(this.U.length===0)return;let e=[...this.U];ss(this.t,e,t)}};function rs(i){return{getMetadata(){return{name:"LaunchDarkly-Inspector-Adapter"}},afterEvaluation:(t,e,n)=>(i.onFlagUsed(t.flagKey,n,t.context),e),afterIdentify(t,e,n){return i.onIdentityChanged(t.context),e}}}function as(i,t){return`an inspector: "${t}" of an invalid type (${i}) was configured`}function os(i,t){return`an inspector: "${t}" of type: "${i}" generated an exception`}function cs(i,t){let e=!1,n={method:(...s)=>{try{i.method(...s)}catch(r){e||(e=!0,t.warn(os(n.type,n.name)))}},type:i.type,name:i.name,synchronous:i.synchronous};return n}var bi="flag-used",ki="flag-details-changed",xi="flag-detail-changed",Li="client-identity-changed",us=[bi,ki,xi,Li];function ls(i,t){let e=us.includes(i.type)&&i.method&&typeof i.method=="function";return e||t.warn(as(i.type,i.name)),e}var Ae=class{constructor(t,e){this.J=[];let n=t.filter(s=>ls(s,e));this.J=n.map(s=>cs(s,e))}hasInspectors(){return this.J.length!==0}onFlagUsed(t,e,n){this.J.forEach(s=>{s.type===bi&&s.method(t,e,n)})}onFlagsChanged(t){this.J.forEach(e=>{e.type===ki&&e.method(t)})}onFlagChanged(t,e){this.J.forEach(n=>{n.type===xi&&n.method(t,e)})}onIdentityChanged(t){this.J.forEach(e=>{e.type===Li&&e.method(t)})}},Pe=class{constructor(t){this.t=t,this.e=new Map}on(t,e){var n;this.e.has(t)?(n=this.e.get(t))==null||n.push(e):this.e.set(t,[e])}off(t,e){let n=this.e.get(t);if(n){if(e){let s=n.filter(r=>r!==e);s.length===0?this.e.delete(t):this.e.set(t,s);return}this.e.delete(t)}}Ht(t,e,...n){var s;try{t(...n)}catch(r){(s=this.t)==null||s.error(`Encountered error invoking handler for "${e}", detail: "${r}"`)}}emit(t,...e){let n=this.e.get(t);n==null||n.forEach(s=>this.Ht(s,t,...e))}eventNames(){return[...this.e.keys()]}listenerCount(t){var e,n;return(n=(e=this.e.get(t))==null?void 0:e.length)!=null?n:0}};function hs(i,t,e){let n=t.info.sdkData(),s;e.applicationInfo&&(e.applicationInfo.id&&(s=s!=null?s:{},s.id=e.applicationInfo.id),e.applicationInfo.version&&(s=s!=null?s:{},s.version=e.applicationInfo.version),e.applicationInfo.name&&(s=s!=null?s:{},s.name=e.applicationInfo.name),e.applicationInfo.versionName&&(s=s!=null?s:{},s.versionName=e.applicationInfo.versionName));let r={name:n.userAgentBase,version:n.version};n.wrapperName&&(r.wrapperName=n.wrapperName),n.wrapperVersion&&(r.wrapperVersion=n.wrapperVersion);let a={sdk:r,[e.credentialType]:i};return s&&(a.application=s),a}var{ClientMessages:Ee,ErrorKinds:De}=L,ds=5,Ft=class{constructor(t,e,n,s,r,a){if(this.sdkKey=t,this.autoEnvAttributes=e,this.platform=n,this.Bt=15,this.$=new Rt(!1),this.yt=new Rt(!0),this.Kt=!1,this.zi=An(),!t)throw new Error("You must configure the client with a client-side SDK key");if(!n.encoding)throw new Error("Platform must implement Encoding because btoa is required.");this.r=new ke(s,a),this.logger=this.r.logger,this.Ae=ai(this.sdkKey,this.platform.info,this.r.tags,this.r.serviceEndpoints.includeAuthorizationHeader,this.r.userAgentHeaderName),this.S=new Ce(this.platform,t,this.r.maxCachedContexts,this.r.logger),this.L=Yn(t,this.r,n),this.w=Zn(t,this.r,n,this.Ae,this.L),this.emitter=new Pe,this.emitter.on("error",(c,u)=>{this.logger.error(`error: ${u}, context: ${JSON.stringify(c)}`)}),this.S.on((c,u,l)=>{this._i(u,l);let d=x.toLDContext(c);this.emitter.emit("change",d,u),u.forEach(f=>{this.emitter.emit(`change:${f}`,d)})}),this.dataManager=r(this.S,this.r,this.Ae,this.emitter,this.L);let o=[...this.r.hooks];this.environmentMetadata=hs(this.sdkKey,this.platform,this.r),this.r.getImplementationHooks(this.environmentMetadata).forEach(c=>{o.push(c)}),this.V=new Te(this.logger,o),this.nt=new Ae(this.r.inspectors,this.logger),this.nt.hasInspectors()&&this.V.addHook(rs(this.nt))}allFlags(){return Object.entries(this.S.getAll()).reduce((e,[n,s])=>(s.flag!==null&&s.flag!==void 0&&!s.flag.deleted&&(e[n]=s.flag.value),e),{})}async close(){var t;await this.flush(),(t=this.w)==null||t.close(),this.dataManager.close(),this.logger.debug("Closed event processor and data source.")}async flush(){var t;try{await((t=this.w)==null?void 0:t.flush()),this.logger.debug("Successfully flushed event processor.")}catch(e){return this.logger.error(`Error flushing event processor: ${e}.`),{error:e,result:!1}}return{result:!0}}getContext(){return this.D?ge(this.D):void 0}getInternalContext(){return this.q}Ji(){let t,e;return{identifyPromise:new Promise((s,r)=>{t=s,e=r}),identifyResolve:t,identifyReject:e}}async identify(t,e){let n=await this.identifyResult(t,e);if(n.status==="error")throw n.error;if(n.status==="timeout"){let s=new C(`identify timed out after ${n.timeout} seconds.`);throw this.logger.error(s.message),s}}async identifyResult(t,e){var o,c;let n=(o=e==null?void 0:e.timeout)!=null?o:ds,s=(e==null?void 0:e.timeout)===void 0&&(e==null?void 0:e.noTimeout)===!0;n>this.Bt&&this.logger.warn(`The identify function was called with a timeout greater than ${this.Bt} seconds. We recommend a timeout of less than ${this.Bt} seconds.`);let r=this.zi.execute({before:async()=>{let u=await qn(t,this.platform);this.autoEnvAttributes===H.Enabled&&(u=await Hn(u,this.platform,this.r));let l=x.fromLDContext(u);if(l.valid){let d=this.V.identify(u,e==null?void 0:e.timeout);return{context:u,checkedContext:l,afterIdentify:d}}return{context:u,checkedContext:l}},execute:async u=>{var y;let{context:l,checkedContext:d}=u;if(!d.valid){let D=new Error("Context was unspecified or had no key");return this.emitter.emit("error",l,D),Promise.reject(D)}this.D=l,this.q=d,(y=this.w)==null||y.sendEvent(this.$.identifyEvent(this.q));let{identifyPromise:f,identifyResolve:m,identifyReject:g}=this.Ji();return this.logger.debug(`Identifying ${JSON.stringify(this.q)}`),await this.dataManager.identify(m,g,d,e),f},after:async(u,l)=>{var d,f,m;u.status==="complete"?(d=l==null?void 0:l.afterIdentify)==null||d.call(l,{status:"completed"}):u.status==="shed"?(f=l==null?void 0:l.afterIdentify)==null||f.call(l,{status:"shed"}):u.status==="error"&&((m=l==null?void 0:l.afterIdentify)==null||m.call(l,{status:"error"}))}},(c=e==null?void 0:e.sheddable)!=null?c:!1).then(u=>u.status==="error"?{status:"error",error:u.error}:u.status==="shed"?{status:"shed"}:{status:"completed"});if(s)return r;let a=new Promise(u=>{setTimeout(()=>{u({status:"timeout",timeout:n})},n*1e3)});return Promise.race([r,a])}on(t,e){this.emitter.on(t,e)}off(t,e){this.emitter.off(t,e)}track(t,e,n){var s,r;if(!this.q||!this.q.valid){this.logger.warn(Ee.MissingContextKeyNoEvent);return}n!==void 0&&!h.Number.is(n)&&((s=this.logger)==null||s.warn(Ee.invalidMetricValue(typeof n))),(r=this.w)==null||r.sendEvent(this.r.trackEventModifier(this.$.customEvent(t,this.q,e,n))),this.V.afterTrack({key:t,context:this.D,data:e,metricValue:n})}vt(t,e,n,s){var f,m,g;if(!this.D)return this.logger.debug(Ee.MissingContextKeyNoEvent),we(De.UserNotSpecified,e);let r=x.fromLDContext(this.D),a=this.S.get(t);if(a===void 0||a.flag.deleted){let y=e!=null?e:null,D=new q(`Unknown feature flag "${t}"; returning default value ${y}.`);return this.emitter.emit("error",this.D,D),(f=this.w)==null||f.sendEvent(this.$.unknownFlagEvent(t,y,r)),we(De.FlagNotFound,e)}let{reason:o,value:c,variation:u,prerequisites:l}=a.flag;if(s){let[y,D]=s(c);if(!y){(m=this.w)==null||m.sendEvent(n.evalEventClient(t,e,e,a.flag,r,o));let U=new q(`Wrong type "${D}" for feature flag "${t}"; returning default value`);return this.emitter.emit("error",this.D,U),we(De.WrongType,e)}}let d=li(c,u,o);return c==null&&(this.logger.debug("Result value is null. Providing default value."),d.value=e),l==null||l.forEach(y=>{this.vt(y,void 0,this.$)}),(g=this.w)==null||g.sendEvent(n.evalEventClient(t,c,e,a.flag,r,o)),d}variation(t,e){let{value:n}=this.V.withEvaluation(t,this.D,e,()=>this.vt(t,e,this.$));return n}variationDetail(t,e){return this.V.withEvaluation(t,this.D,e,()=>this.vt(t,e,this.yt))}W(t,e,n,s){return this.V.withEvaluation(t,this.D,e,()=>this.vt(t,e,n,s))}boolVariation(t,e){return this.W(t,e,this.$,n=>[h.Boolean.is(n),h.Boolean.getType()]).value}jsonVariation(t,e){return this.variation(t,e)}numberVariation(t,e){return this.W(t,e,this.$,n=>[h.Number.is(n),h.Number.getType()]).value}stringVariation(t,e){return this.W(t,e,this.$,n=>[h.String.is(n),h.String.getType()]).value}boolVariationDetail(t,e){return this.W(t,e,this.yt,n=>[h.Boolean.is(n),h.Boolean.getType()])}numberVariationDetail(t,e){return this.W(t,e,this.yt,n=>[h.Number.is(n),h.Number.getType()])}stringVariationDetail(t,e){return this.W(t,e,this.yt,n=>[h.String.is(n),h.String.getType()])}jsonVariationDetail(t,e){return this.variationDetail(t,e)}addHook(t){this.V.addHook(t)}setEventSendingEnabled(t,e){var n,s,r,a;this.Kt!==t&&(this.Kt=t,t?(this.logger.debug("Starting event processor"),(n=this.w)==null||n.start()):e?((s=this.logger)==null||s.debug("Flushing event processor before disabling."),this.flush().then(()=>{var o,c;this.Kt||((o=this.logger)==null||o.debug("Stopping event processor."),(c=this.w)==null||c.close())})):((r=this.logger)==null||r.debug("Stopping event processor."),(a=this.w)==null||a.close()))}sendEvent(t){var e;(e=this.w)==null||e.sendEvent(t)}_i(t,e){if(!this.nt.hasInspectors())return;let n={};t.forEach(s=>{let r=this.S.get(s);if(r!=null&&r.flag&&!r.flag.deleted){let{reason:a,value:o,variation:c}=r.flag;n[s]=li(o,c,a)}else n[s]={value:void 0,reason:null,variationIndex:null}}),e==="init"?this.nt.onFlagsChanged(n):e==="patch"&&Object.entries(n).forEach(([s,r])=>{this.nt.onFlagChanged(s,r)})}},Ie=class{constructor(t,e,n){this.S=t,this.Gt=e,this.t=n}async handlePut(t,e){this.t.debug(`Got PUT: ${Object.keys(e)}`);let n=Object.entries(e).reduce((s,[r,a])=>(s[r]={version:a.version,flag:a},s),{});await this.S.init(t,n),this.Gt.requestStateUpdate(E.Valid)}async handlePatch(t,e){this.t.debug(`Got PATCH ${JSON.stringify(e,null,2)}`),this.S.upsert(t,e.key,{version:e.version,flag:e})}async handleDelete(t,e){this.t.debug(`Got DELETE ${JSON.stringify(e,null,2)}`),this.S.upsert(t,e.key,{version:e.version,flag:b(p({},e),{deleted:!0,flagVersion:0,value:void 0,variation:0,trackEvents:!1})})}handleStreamingError(t){this.Gt.reportError(t.kind,t.message,t.code,t.recoverable)}handlePollingError(t){this.Gt.reportError(t.kind,t.message,t.status,t.recoverable)}},Ne=class{constructor(t,e=()=>Date.now()){this.M=t,this.wt=E.Closed,this.Pe=e(),this.mt=e}get status(){return{state:this.wt,stateSince:this.Pe,lastError:this.qi}}Ie(t,e=!1){let n=t===E.Interrupted&&this.wt===E.Initializing?E.Initializing:t,s=this.wt!==n;s&&(this.wt=n,this.Pe=this.mt()),(s||e)&&this.M.emit("dataSourceStatus",this.status)}requestStateUpdate(t){this.Ie(t)}reportError(t,e,n,s=!1){let r={kind:t,message:e,statusCode:n,time:this.mt()};this.qi=r,this.Ie(s?E.Interrupted:E.Closed,!0)}};function di(i){i==null||i.debug("Poll completed after the processor was closed. Skipping processing.")}var Oe=class{constructor(t,e,n,s,r){this.Wi=t,this.Yi=e,this.Zi=n,this.g=s,this.t=r,this.u=!1}async Ne(){var r,a,o,c,u,l,d;if(this.u)return;let t=f=>{var m,g,y;(m=this.t)==null||m.error("Polling received invalid data"),(g=this.t)==null||g.debug(`Invalid JSON follows: ${f}`),(y=this.g)==null||y.call(this,new M(w.InvalidData,"Malformed JSON data in polling response"))};(r=this.t)==null||r.debug("Polling LaunchDarkly for feature flag updates");let e=Date.now();try{let f=await this.Wi.requestPayload();try{if(this.u){di(this.t);return}let m=JSON.parse(f);try{(a=this.Zi)==null||a.call(this,m)}catch(g){(o=this.t)==null||o.error(`Exception from data handler: ${g}`)}}catch(m){t(f)}}catch(f){if(this.u){di(this.t);return}let m=f;if(m.status!==void 0&&!Y(m.status)){(c=this.t)==null||c.error(I(f,"polling request")),(u=this.g)==null||u.call(this,new M(w.ErrorResponse,m.message,m.status));return}(l=this.t)==null||l.error(I(f,"polling request","will retry"))}let n=Date.now()-e,s=Math.max(this.Yi*1e3-n,0);(d=this.t)==null||d.debug("Elapsed: %d ms, sleeping for %d ms",n,s),this.zt=setTimeout(()=>{this.Ne()},s)}start(){this.Ne()}stop(){this.zt&&(clearTimeout(this.zt),this.zt=void 0),this.u=!0}close(){this.stop()}},fs=(i,t,e,n)=>{e==null||e.error(`Stream received invalid data in "${i}" message`),e==null||e.debug(`Invalid JSON follows: ${t}`),n==null||n(new j(w.InvalidData,"Malformed JSON data in event stream"))};function ps(i,t){t==null||t.debug(`Received ${i} event after processor was closed. Skipping processing.`)}function fi(i){i==null||i.debug("Ping completed after processor was closed. Skipping processing.")}var $e=class{constructor(t,e,n,s,r,a,o,c,u){var f;this.Xi=t,this._t=e,this.e=n,this.I=s,this.Qi=a,this.L=o,this.g=c,this.t=u,this.u=!1;let l;e.useReport&&!s.getEventSourceCapabilities().customMethod?l=e.paths.pathPing(r,t):l=e.useReport?e.paths.pathReport(r,t):e.paths.pathGet(r,t);let d=[...(f=e.queryParameters)!=null?f:[]];this._t.withReasons&&d.push({key:"withReasons",value:"true"}),this.I=s,this.gt=p({},e.baseHeaders),this.t=u,this.tn=ni(e.serviceEndpoints,l,d)}Oe(){this.Et=Date.now()}Jt(t){this.Et&&this.L&&this.L.recordStreamInit(this.Et,!t,Date.now()-this.Et),this.Et=void 0}en(t){var e,n,s;return $t(t)?((s=this.t)==null||s.warn(I(t,"streaming request","will retry")),this.Jt(!1),this.Oe(),!0):(this.Jt(!1),(e=this.g)==null||e.call(this,new j(w.ErrorResponse,t.message,t.status,!1)),(n=this.t)==null||n.error(I(t,"streaming request")),!1)}start(){this.Oe();let t;this._t.useReport?(this.gt["content-type"]="application/json",t={method:"REPORT",body:this.Xi}):t={};let e=this.I.createEventSource(this.tn,b(p({headers:this.gt},t),{errorFilter:n=>this.en(n),initialRetryDelayMillis:this._t.initialRetryDelayMillis,readTimeoutMillis:300*1e3,retryResetIntervalMillis:60*1e3}));this.$e=e,e.onclose=()=>{var n;(n=this.t)==null||n.info("Closed LaunchDarkly stream connection")},e.onerror=()=>{},e.onopen=()=>{var n;(n=this.t)==null||n.info("Opened LaunchDarkly stream connection")},e.onretrying=n=>{var s;(s=this.t)==null||s.info(`Will retry stream connection in ${n.delayMillis} milliseconds`)},this.e.forEach(({deserializeData:n,processJson:s},r)=>{e.addEventListener(r,a=>{var o,c;if(this.u){ps(r,this.t);return}if((o=this.t)==null||o.debug(`Received ${r} event`),a!=null&&a.data){this.Jt(!0);let{data:u}=a,l=n(u);if(!l){fs(r,u,this.t,this.g);return}s(l)}else(c=this.g)==null||c.call(this,new j(w.InvalidData,"Unexpected payload from event stream"))})}),e.addEventListener("ping",async()=>{var n,s,r,a,o,c,u;(n=this.t)==null||n.debug("Got PING, going to poll LaunchDarkly for feature flag updates");try{let l=await this.Qi.requestPayload();try{if(this.u){fi(this.t);return}let d=JSON.parse(l);try{(s=this.e.get("put"))==null||s.processJson(d)}catch(f){(r=this.t)==null||r.error(`Exception from data handler: ${f}`)}}catch(d){(a=this.t)==null||a.error("Polling after ping received invalid data"),(o=this.t)==null||o.debug(`Invalid JSON follows: ${l}`),(c=this.g)==null||c.call(this,new M(w.InvalidData,"Malformed JSON data in ping polling response"))}}catch(l){if(this.u){fi(this.t);return}let d=l;(u=this.g)==null||u.call(this,new M(w.ErrorResponse,d.message,d.status))}})}stop(){var t;(t=this.$e)==null||t.close(),this.$e=void 0,this.u=!0}close(){this.stop()}},Ut=class{constructor(t,e,n,s,r,a,o,c,u){this.platform=t,this.flagManager=e,this.credential=n,this.config=s,this.getPollingPaths=r,this.getStreamingPaths=a,this.baseHeaders=o,this.emitter=c,this.diagnosticsManager=u,this.closed=!1,this.logger=s.logger,this.dataSourceStatusManager=new Ne(c),this.Y=new Ie(e,this.dataSourceStatusManager,this.config.logger)}setConnectionParams(t){this.nn=t}createPollingProcessor(t,e,n,s,r){let a=new Oe(n,this.config.pollInterval,async o=>{await this.Y.handlePut(e,o),s==null||s()},o=>{this.emitter.emit("error",t,o),this.Y.handlePollingError(o),r==null||r(o)},this.logger);this.updateProcessor=this.Me(a,this.dataSourceStatusManager)}createStreamingProcessor(t,e,n,s,r){var o;let a=new $e(JSON.stringify(t),{credential:this.credential,serviceEndpoints:this.config.serviceEndpoints,paths:this.getStreamingPaths(),baseHeaders:this.baseHeaders,initialRetryDelayMillis:this.config.streamInitialReconnectDelay*1e3,withReasons:this.config.withReasons,useReport:this.config.useReport,queryParameters:(o=this.nn)==null?void 0:o.queryParameters},this.createStreamListeners(e,s),this.platform.requests,this.platform.encoding,n,this.diagnosticsManager,c=>{this.emitter.emit("error",t,c),this.Y.handleStreamingError(c),r==null||r(c)},this.logger);this.updateProcessor=this.Me(a,this.dataSourceStatusManager)}createStreamListeners(t,e){let n=new Map;return n.set("put",{deserializeData:JSON.parse,processJson:async s=>{await this.Y.handlePut(t,s),e==null||e()}}),n.set("patch",{deserializeData:JSON.parse,processJson:async s=>{this.Y.handlePatch(t,s)}}),n.set("delete",{deserializeData:JSON.parse,processJson:async s=>{this.Y.handleDelete(t,s)}}),n}Me(t,e){return{start:()=>{e.requestStateUpdate(E.Initializing),t.start()},stop:()=>{t.stop(),e.requestStateUpdate(E.Closed)},close:()=>{t.close(),e.requestStateUpdate(E.Closed)}}}close(){var t;(t=this.updateProcessor)==null||t.close(),this.closed=!0}};function Vt(){return typeof document!==void 0}function Fe(){return typeof window!==void 0}function jt(i,t,e){return Vt()?(document.addEventListener(i,t,e),()=>{document.removeEventListener(i,t,e)}):()=>{}}function Ht(i,t,e){return Vt()?(window.addEventListener(i,t,e),()=>{window.removeEventListener(i,t,e)}):()=>{}}function T(){return Fe()?window.location.href:""}function Si(){return Fe()?window.location.search:""}function Ci(){return Fe()?window.location.hash:""}function Ti(){if(typeof crypto!==void 0)return crypto;throw Error("Access to a web crypto API is required")}function Ai(){return Vt()?document.visibilityState:"visibile"}function Pi(i){if(Vt())return document.querySelectorAll(i)}function Ii(i,t){let e=Object.keys(t),n="$flagsState",s="$valid",r=t[n];!r&&e.length&&i.warn("LaunchDarkly client was initialized with bootstrap data that did not include flag metadata. Events may not be sent correctly."),t[s]===!1&&i.warn("LaunchDarkly bootstrap data is not available because the back end could not read the flags.");let a={};return e.forEach(o=>{if(o!==n&&o!==s){let c;r&&r[o]?c=p({value:t[o]},r[o]):c={value:t[o],version:0},a[o]={version:c.version,flag:c}}}),a}var gs="[BrowserDataManager]",et=class extends Ut{constructor(e,n,s,r,a,o,c,u,l,d){super(e,n,s,r,o,c,u,l,d);this.vn=a;this.st=void 0;this.qt=!1;this.st=a.streaming}C(e,...n){this.logger.debug(`${gs} ${e}`,...n)}async identify(e,n,s,r){if(this.closed){this.C("Identify called after data manager was closed.");return}this.context=s;let a=r;a!=null&&a.hash?this.setConnectionParams({queryParameters:[{key:"h",value:a.hash}]}):this.setConnectionParams(),this.Wt=a==null?void 0:a.hash,a!=null&&a.bootstrap?this.sn(s,a.bootstrap,e):(await this.flagManager.loadCached(s)&&this.C("Identify - Flags loaded from cache. Continuing to initialize via a poll."),await this.rn(s,e,n)),this.Yt()}async an(e){let n=JSON.stringify(x.toLDContext(e)),s=Me(n,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.Wt),r=3,a;for(let o=0;o<=r;o+=1)try{return await s.requestPayload()}catch(c){if(!$t(c))throw c;a=c,o<r&&(this.C(I(c,"initial poll request","will retry")),await ye(1e3))}throw a}async rn(e,n,s){var r,a;try{this.dataSourceStatusManager.requestStateUpdate(E.Initializing);let o=await this.an(e);try{let u=this.createStreamListeners(e,n).get("put");u.processJson(u.deserializeData(o))}catch(c){this.dataSourceStatusManager.reportError(w.InvalidData,(r=c.message)!=null?r:"Could not parse poll response")}}catch(o){this.dataSourceStatusManager.reportError(w.NetworkError,(a=o.message)!=null?a:"unexpected network error",o.status),s(o)}}sn(e,n,s){this.flagManager.setBootstrap(e,Ii(this.logger,n)),this.C("Identify - Initialization completed from bootstrap"),s()}setForcedStreaming(e){this.st=e,this.Yt()}setAutomaticStreamingState(e){this.qt=e,this.Yt()}Yt(){let e=this.st||this.qt&&this.st===void 0;this.C(`Updating streaming state. forced(${this.st}) automatic(${this.qt})`),e?this.cn():this.un()}un(){var e;this.updateProcessor&&this.C("Stopping update processor."),(e=this.updateProcessor)==null||e.close(),this.updateProcessor=void 0}cn(){if(this.updateProcessor){this.C("Update processor already active. Not changing state.");return}if(!this.context){this.C("Context not set, not starting update processor.");return}this.C("Starting update processor."),this.ln(this.context)}ln(e,n,s){var c;let r=x.toLDContext(e);(c=this.updateProcessor)==null||c.close();let a=JSON.stringify(x.toLDContext(e)),o=Me(a,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.Wt);this.createStreamingProcessor(r,e,o,n,s),this.updateProcessor.start()}};function Ni(i){let e=jt("visibilitychange",()=>{Ai()==="hidden"&&i()}),n=Ht("pagehide",i);return()=>{e(),n()}}function it(i){if(typeof i!="string")throw new TypeError("Expected a string");return i.replace(/[|\\{}()[\]^$+*?.]/g,"\\$&").replace(/-/g,"\\x2d")}function ms(i,t,e,n){let r=((i.kind==="substring"||i.kind==="regex")&&n.includes("/")?t:t.replace(n,"")).replace(e,"");switch(i.kind){case"exact":return new RegExp(`^${it(i.url)}/?$`).test(t);case"canonical":return new RegExp(`^${it(i.url)}/?$`).test(r);case"substring":return new RegExp(`.*${it(i.substring)}.*$`).test(r);case"regex":return new RegExp(i.pattern).test(r);default:return!1}}function ys(i,t){let e=[];return t.forEach(n=>{let s=i.target,{selector:r}=n,a=Pi(r);for(;s&&(a!=null&&a.length);){for(let o=0;o<a.length;o+=1)if(s===a[o]){e.push(n);break}s=s.parentNode}}),e}var nt=class{constructor(t,e){let n=t.filter(a=>{var o;return(o=a.urls)==null?void 0:o.some(c=>ms(c,T(),Si(),Ci()))}),s=n.filter(a=>a.kind==="pageview"),r=n.filter(a=>a.kind==="click");if(s.forEach(a=>e(a)),r.length){let a=o=>{ys(o,r).forEach(c=>{e(c)})};this.Re=jt("click",a)}}close(){var t;(t=this.Re)==null||t.call(this)}};var vs=300,Bt=class{constructor(t){this.Zt=T();let e=()=>{let s=T();s!==this.Zt&&(this.Zt=s,t())};this.Xt=setInterval(e,vs);let n=Ht("popstate",e);this.Fe=()=>{n()}}close(){var t;this.Xt&&clearInterval(this.Xt),(t=this.Fe)==null||t.call(this)}};var st=class{constructor(t,e,n,s,r,a=o=>new Bt(o)){this.I=e;this.fn=s;this.dn=r;this.Dt=[];this.Ve=!1;this.bt=`${n}/sdk/goals/${t}`,this.Ue=a(()=>{this.te()})}async initialize(){await this.hn(),this.te()}startTracking(){this.Ve=!0,this.te()}te(){var t;this.Ve&&((t=this.Qt)==null||t.close(),this.Dt&&this.Dt.length&&(this.Qt=new nt(this.Dt,e=>{this.dn(T(),e)})))}async hn(){try{let t=await this.I.fetch(this.bt);this.Dt=await t.json()}catch(t){this.fn(new J(`Encountered error fetching goals: ${t}`))}}close(){var t,e;(t=this.Ue)==null||t.close(),(e=this.Qt)==null||e.close()}};function Oi(i){return i.kind==="click"}var ws=2,$i={fetchGoals:!0,eventUrlTransformer:i=>i,streaming:void 0,plugins:[]},Es={fetchGoals:h.Boolean,eventUrlTransformer:h.Function,streaming:h.Boolean,plugins:h.createTypeArray("LDPlugin",{})};function Ds(i){var e;let t=p({},i);return(e=t.flushInterval)!=null||(t.flushInterval=ws),t}function Mi(i){let t=Ds(i);return Object.keys($i).forEach(e=>{delete t[e]}),t}function Ue(i,t){let e=p({},$i);return Object.entries(Es).forEach(n=>{let[s,r]=n,a=i[s];a!==void 0&&(r.is(a)?e[s]=a:t.warn(k.wrongOptionType(s,r.getType(),typeof a)))}),e}var rt=class{constructor(t,e){this.pn=t;this.je=[];switch(e){case"sha1":this.ee="SHA-1";break;case"sha256":this.ee="SHA-256";break;default:throw new Error(`Algorithm is not supported ${e}`)}}async asyncDigest(t){let e=this.je.join(""),n=new TextEncoder().encode(e),s=await this.pn.subtle.digest(this.ee,n);switch(t){case"base64":return btoa(String.fromCharCode(...new Uint8Array(s)));case"hex":return[...new Uint8Array(s)].map(r=>r.toString(16).padStart(2,"0")).join("");default:throw new Error(`Encoding is not supported ${t}`)}}update(t){return this.je.push(t),this}};var bs={start:0,end:3},ks={start:4,end:5},Ve={start:6,end:7},je={start:8,end:8},xs={start:9,end:9},Ls={start:10,end:15};function Ss(){if(crypto&&crypto.getRandomValues){let t=new Uint8Array(16);return crypto.getRandomValues(t),[...t.values()]}let i=[];for(let t=0;t<16;t+=1)i.push(Math.floor(Math.random()*256));return i}function K(i,t){let e="";for(let n=t.start;n<=t.end;n+=1)e+=i[n].toString(16).padStart(2,"0");return e}function Cs(i){return i[je.start]=(i[je.start]|128)&191,i[Ve.start]=i[Ve.start]&15|64,`${K(i,bs)}-${K(i,ks)}-${K(i,Ve)}-${K(i,je)}${K(i,xs)}-${K(i,Ls)}`}function Ts(){let i=Ss();return Cs(i)}function He(){return typeof crypto!==void 0&&typeof crypto.randomUUID=="function"?crypto.randomUUID():Ts()}var at=class{createHash(t){return new rt(Ti(),t)}randomUUID(){return He()}};function As(i){let t=Array.from(i,e=>String.fromCodePoint(e)).join("");return btoa(t)}var ot=class{btoa(t){return As(new TextEncoder().encode(t))}};var ct=class{constructor(t){this.r=t}platformData(){return{name:"JS"}}sdkData(){let t={name:"@launchdarkly/js-client-sdk",version:"0.10.0",userAgentBase:"JSClient"};return this.r.wrapperName&&(t.wrapperName=this.r.wrapperName),this.r.wrapperVersion&&(t.wrapperVersion=this.r.wrapperVersion),t}};var ut=class{constructor(t,e){this.bt=t;this.e={};this.A=new bt(e.initialRetryDelayMillis,e.retryResetIntervalMillis),this.He=e.errorFilter,this.Be()}Be(){this.Z=new EventSource(this.bt),this.Z.onopen=()=>{var t;this.A.success(),(t=this.onopen)==null||t.call(this)},this.Z.onerror=t=>{var e;this.gn(t),(e=this.onerror)==null||e.call(this,t)},Object.entries(this.e).forEach(([t,e])=>{e.forEach(n=>{var s;(s=this.Z)==null||s.addEventListener(t,n)})})}addEventListener(t,e){var n,s,r;(s=(n=this.e)[t])!=null||(n[t]=[]),this.e[t].push(e),(r=this.Z)==null||r.addEventListener(t,e)}close(){var t,e;clearTimeout(this.ie),this.ie=void 0,(t=this.Z)==null||t.close(),(e=this.onclose)==null||e.call(this)}mn(t){var e;(e=this.onretrying)==null||e.call(this,{delayMillis:t}),this.ie=setTimeout(()=>{this.Be()},t)}gn(t){this.close(),!(t.status&&typeof t.status=="number"&&!this.He(t))&&this.mn(this.A.fail())}};var lt=class{fetch(t,e){return fetch(t,e)}createEventSource(t,e){return new ut(t,e)}getEventSourceCapabilities(){return{customMethod:!1,readTimeout:!1,headers:!1}}};function Ri(){return typeof localStorage!="undefined"}var ht=class{constructor(t){this.t=t}async clear(t){var e;try{localStorage.removeItem(t)}catch(n){(e=this.t)==null||e.error(`Error clearing key from localStorage: ${t}, reason: ${n}`)}}async get(t){var e;try{let n=localStorage.getItem(t);return n!=null?n:null}catch(n){return(e=this.t)==null||e.error(`Error getting key from localStorage: ${t}, reason: ${n}`),null}}async set(t,e){var n;try{localStorage.setItem(t,e)}catch(s){(n=this.t)==null||n.error(`Error setting key in localStorage: ${t}, reason: ${s}`)}}};var dt=class{constructor(t,e){this.encoding=new ot;this.crypto=new at;this.requests=new lt;Ri()&&(this.storage=new ht(t)),this.info=new ct(e)}};var Be=class extends Ft{constructor(t,e,n={},s){var m;let{logger:r,debug:a}=n,o=r!=null?r:new R({destination:{debug:console.debug,info:console.info,warn:console.warn,error:console.error},level:a?"debug":"info"}),c=(m=n.baseUri)!=null?m:"https://clientsdk.launchdarkly.com",u=s!=null?s:new dt(o,n),l=Ue(n,o),d=Mi(b(p({},n),{logger:o})),{eventUrlTransformer:f}=l;super(t,e,u,d,(g,y,D,U,Vi)=>new et(u,g,t,y,l,()=>({pathGet(N,O){return`/sdk/evalx/${t}/contexts/${me(O,N)}`},pathReport(N,O){return`/sdk/evalx/${t}/context`},pathPing(N,O){throw new Error("Ping for polling unsupported.")}}),()=>({pathGet(N,O){return`/eval/${t}/${me(O,N)}`},pathReport(N,O){return`/eval/${t}`},pathPing(N,O){return`/ping/${t}`}}),D,U,Vi),{analyticsEventPath:`/events/bulk/${t}`,diagnosticEventPath:`/events/diagnostic/${t}`,includeAuthorizationHeader:!1,highTimeoutThreshold:5,userAgentHeaderName:"x-launchdarkly-user-agent",trackEventModifier:g=>new L.InputCustomEvent(g.context,g.key,g.data,g.metricValue,g.samplingRatio,f(T())),getImplementationHooks:g=>L.safeGetHooks(o,g,l.plugins),credentialType:"clientSideId"}),this.setEventSendingEnabled(!0,!1),this.Ke=l.plugins,l.fetchGoals&&(this.ne=new st(t,u.requests,c,g=>{o.error(g.message)},(g,y)=>{let D=this.getInternalContext();if(!D)return;let U=f(g);Oi(y)?this.sendEvent({kind:"click",url:U,samplingRatio:1,key:y.key,creationDate:Date.now(),context:D,selector:y.selector}):this.sendEvent({kind:"pageview",url:U,samplingRatio:1,key:y.key,creationDate:Date.now(),context:D})}),this.ne.initialize(),l.automaticBackgroundHandling&&Ni(()=>this.flush()))}registerPlugins(t){L.safeRegisterPlugins(this.logger,this.environmentMetadata,t,this.Ke||[])}async identify(t,e){return super.identify(t,e)}async identifyResult(t,e){var r;let n=p({},e);(e==null?void 0:e.sheddable)===void 0&&(n.sheddable=!0);let s=await super.identifyResult(t,n);return(r=this.ne)==null||r.startTracking(),s}setStreaming(t){this.dataManager.setForcedStreaming(t)}Ge(){this.dataManager.setAutomaticStreamingState(!!this.emitter.listenerCount("change"))}on(t,e){super.on(t,e),this.Ge()}off(t,e){super.off(t,e),this.Ge()}};function Fi(i,t,e={},n){let s=new Be(i,t,e,n),r={variation:(a,o)=>s.variation(a,o),variationDetail:(a,o)=>s.variationDetail(a,o),boolVariation:(a,o)=>s.boolVariation(a,o),boolVariationDetail:(a,o)=>s.boolVariationDetail(a,o),numberVariation:(a,o)=>s.numberVariation(a,o),numberVariationDetail:(a,o)=>s.numberVariationDetail(a,o),stringVariation:(a,o)=>s.stringVariation(a,o),stringVariationDetail:(a,o)=>s.stringVariationDetail(a,o),jsonVariation:(a,o)=>s.jsonVariation(a,o),jsonVariationDetail:(a,o)=>s.jsonVariationDetail(a,o),track:(a,o,c)=>s.track(a,o,c),on:(a,o)=>s.on(a,o),off:(a,o)=>s.off(a,o),flush:()=>s.flush(),setStreaming:a=>s.setStreaming(a),identify:(a,o)=>s.identifyResult(a,o),getContext:()=>s.getContext(),close:()=>s.close(),allFlags:()=>s.allFlags(),addHook:a=>s.addHook(a),logger:s.logger};return s.registerPlugins(r),r}var Ui=["ready","failed","initialized"],ft=class{constructor(t){this.n=t;this.e=new Map}on(t,e){var n;Ui.includes(t)?this.e.has(t)?(n=this.e.get(t))==null||n.push(e):this.e.set(t,[e]):this.n.on(t,e)}off(t,e){if(Ui.includes(t)){let n=this.e.get(t);if(!n)return;if(e){let s=n.filter(r=>r!==e);s.length===0?this.e.delete(t):this.e.set(t,s);return}this.e.delete(t)}else this.n.off(t,e)}Ht(t,e,...n){try{t(...n)}catch(s){this.n.logger.error(`Encountered error invoking handler for "${e}", detail: "${s}"`)}}emit(t,...e){let n=this.e.get(t);n==null||n.forEach(s=>this.Ht(s,t,...e))}eventNames(){return[...this.e.keys()]}listenerCount(t){var e,n;return(n=(e=this.e.get(t))==null?void 0:e.length)!=null?n:0}};function Kt(i,t){let e=i.then(n=>(t&&setTimeout(()=>{t(null,n)},0),n),n=>{if(t)setTimeout(()=>{t(n,null)},0);else return Promise.reject(n)});return t?void 0:e}var pt=class{constructor(t,e,n){this.se="initializing";let s=n==null?void 0:n.bootstrap,r=n==null?void 0:n.hash,a=p({},n);delete a.bootstrap,delete a.hash,this.n=Fi(t,H.Disabled,n),this.M=new ft(this.n),this.logger=this.n.logger,this.yn(e,s,r)}async yn(t,e,n){var s,r;try{let a=await this.n.identify(t,{noTimeout:!0,bootstrap:e,hash:n,sheddable:!1});if(a.status==="error")throw a.error;if(a.status==="timeout")throw new C("Identify timed out");this.se="success",(s=this.ze)==null||s.call(this),this.M.emit("initialized")}catch(a){this.Je=a,this.se="failure",(r=this._e)==null||r.call(this,a),this.M.emit("failed",a)}this.M.emit("ready")}allFlags(){return this.n.allFlags()}boolVariation(t,e){return this.n.boolVariation(t,e)}boolVariationDetail(t,e){return this.n.boolVariationDetail(t,e)}jsonVariation(t,e){return this.n.jsonVariation(t,e)}jsonVariationDetail(t,e){return this.n.jsonVariationDetail(t,e)}numberVariation(t,e){return this.n.numberVariation(t,e)}numberVariationDetail(t,e){return this.n.numberVariationDetail(t,e)}off(t,e){this.M.off(t,e)}on(t,e){this.M.on(t,e)}stringVariation(t,e){return this.n.stringVariation(t,e)}stringVariationDetail(t,e){return this.n.stringVariationDetail(t,e)}track(t,e,n){this.n.track(t,e,n)}variation(t,e){return this.n.variation(t,e)}variationDetail(t,e){return this.n.variationDetail(t,e)}addHook(t){this.n.addHook(t)}setStreaming(t){this.n.setStreaming(t)}identify(t,e,n){return Kt(this.n.identify(t,{hash:e,sheddable:!1}).then(s=>{if(s.status==="error")throw s.error;if(s.status==="timeout")throw new C("Identify timed out");return this.allFlags()}),n)}close(t){return Kt(this.n.close().then(),t)}flush(t){return Kt(this.n.flush().then(()=>{}),t)}getContext(){return this.n.getContext()}waitForInitialization(t){var e;if(this.rt)return this.qe(this.rt,t);switch(this.se){case"success":return Promise.resolve();case"failure":return Promise.reject(this.Je);case"initializing":break;default:throw new Error("Unexpected initialization state. This represents an implementation error in the SDK.")}return t===void 0&&((e=this.logger)==null||e.warn("The waitForInitialization function was called without a timeout specified. In a future version a default timeout will be applied.")),this.rt||(this.rt=new Promise((n,s)=>{this.ze=n,this._e=s})),this.qe(this.rt,t)}async waitUntilReady(){try{await this.waitForInitialization()}catch(t){}}qe(t,e){if(e){let n=ri(e,"waitForInitialization");return Promise.race([t.then(()=>n.cancel()),n.promise]).catch(s=>{var r;throw s instanceof C&&((r=this.logger)==null||r.error(s.message)),s})}return t}};function Ps(i){return new R(i)}function Is(i,t,e){return new pt(i,t,e)}0&&(module.exports={basicLogger,initialize});
|
|
1
|
+
"use strict";var yt=Object.defineProperty,ji=Object.defineProperties,zi=Object.getOwnPropertyDescriptor,Hi=Object.getOwnPropertyDescriptors,Bi=Object.getOwnPropertyNames,mt=Object.getOwnPropertySymbols;var _t=Object.prototype.hasOwnProperty,Be=Object.prototype.propertyIsEnumerable;var He=(i,t,e)=>t in i?yt(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,g=(i,t)=>{for(var e in t||(t={}))_t.call(t,e)&&He(i,e,t[e]);if(mt)for(var e of mt(t))Be.call(t,e)&&He(i,e,t[e]);return i},D=(i,t)=>ji(i,Hi(t));var Jt=(i,t)=>{var e={};for(var n in i)_t.call(i,n)&&t.indexOf(n)<0&&(e[n]=i[n]);if(i!=null&&mt)for(var n of mt(i))t.indexOf(n)<0&&Be.call(i,n)&&(e[n]=i[n]);return e};var Ki=(i,t)=>{for(var e in t)yt(i,e,{get:t[e],enumerable:!0})},Gi=(i,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of Bi(t))!_t.call(i,r)&&r!==e&&yt(i,r,{get:()=>t[r],enumerable:!(n=zi(t,r))||n.enumerable});return i};var Wi=i=>Gi(yt({},"__esModule",{value:!0}),i);var Fr={};Ki(Fr,{basicLogger:()=>$r,initialize:()=>Nr});module.exports=Wi(Fr);function _i(i){return`/${i.replace(/~/g,"~0").replace(/\//g,"~1")}`}function Xe(i){return i.indexOf("~")?i.replace(/~1/g,"/").replace(/~0/g,"~"):i}function Ji(i){return(i.startsWith("/")?i.substring(1):i).split("/").map(e=>Xe(e))}function qi(i){return!i.startsWith("/")}function Yi(i){return!i.match(/\/\/|(^\/.*~[^0|^1])|~$/)}var A=class{constructor(t,e=!1){if(e){let n=t;this.m=[n],this.isValid=n!=="",this.redactionName=n.startsWith("/")?_i(n):n}else{if(this.redactionName=t,t===""||t==="/"||!Yi(t)){this.isValid=!1,this.m=[];return}qi(t)?this.m=[t]:t.indexOf("/",1)<0?this.m=[Xe(t.slice(1))]:this.m=Ji(t),this.m[0]==="_meta"?this.isValid=!1:this.isValid=!0}}get(t){let{m:e,isValid:n}=this;if(!n)return;let r=t;for(let s=0;s<e.length;s+=1){let a=e[s];if(r!=null&&Object.prototype.hasOwnProperty.call(r,a)&&typeof r=="object"&&!Array.isArray(r))r=r[a];else return}return r}getComponent(t){return this.m[t]}get depth(){return this.m.length}get isKind(){return this.m.length===1&&this.m[0]==="kind"}compare(t){return this.depth===t.depth&&this.m.every((e,n)=>e===t.getComponent(n))}get components(){return[...this.m]}};A.InvalidReference=new A("");var Zt=class{is(t){if(Array.isArray(t))return!1;let n=typeof t;return n==="function"||n==="object"}getType(){return"factory method or object"}},O=class{constructor(t,e){this.bt=t,this.typeOf=typeof e}is(t){return Array.isArray(t)?!1:typeof t===this.typeOf}getType(){return this.bt}},Et=class{constructor(t,e){this.bt=t,this.typeOf=typeof e}is(t){return Array.isArray(t)?t.length>0?t.every(e=>typeof e===this.typeOf):!0:!1}getType(){return this.bt}},W=class extends O{constructor(t){super(`number with minimum value of ${t}`,0),this.min=t}is(t){return typeof t===this.typeOf&&t>=this.min}},Dt=class extends O{constructor(t){super(`string matching ${t}`,""),this.expression=t}is(t){return typeof t=="string"&&!!t.match(this.expression)}},Xt=class{is(t){return typeof t=="function"}getType(){return"function"}},Qt=class{is(t){return typeof t=="boolean"||typeof t=="undefined"||t===null}getType(){return"boolean | undefined | null"}},Zi=/^\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d(\.\d\d*)?(Z|[-+]\d\d(:\d\d)?)/,te=class{is(t){return typeof t=="number"||typeof t=="string"&&Zi.test(t)}getType(){return"date"}},ee=class extends Dt{constructor(){super(/^(\w|\.|-)+$/)}is(t){return super.is(t)&&t!=="kind"}},h=class{static createTypeArray(t,e){return new Et(t,e)}static numberWithMin(t){return new W(t)}static stringMatchingRegex(t){return new Dt(t)}};h.String=new O("string","");h.Number=new O("number",0);h.ObjectOrFactory=new Zt;h.Object=new O("object",{});h.StringArray=new Et("string[]","");h.Boolean=new O("boolean",!0);h.Function=new Xt;h.Date=new te;h.Kind=new ee;h.NullableBoolean=new Qt;function Qe(i){return"kind"in i?h.String.is(i.kind)&&i.kind!=="multi":!1}function ti(i){return"kind"in i?h.String.is(i.kind)&&i.kind==="multi":!1}function ei(i){return!("kind"in i)||i.kind===null||i.kind===void 0}function bt(i,t=[]){if(i===null||typeof i!="object")return JSON.stringify(i);if(t.includes(i))throw new Error("Cycle detected");return Array.isArray(i)?`[${i.map(r=>bt(r,[...t,i])).map(r=>r===void 0?"null":r).join(",")}]`:`{${Object.keys(i).sort().map(n=>{let r=bt(i[n],[...t,i]);if(r!==void 0)return`${JSON.stringify(n)}:${r}`}).filter(n=>n!==void 0).join(",")}}`}var ie="user";function Ke(i){return i.includes("%")||i.includes(":")?i.replace(/%/g,"%25").replace(/:/g,"%3A"):i}function Xi(i){return i&&h.Object.is(i)}function Ge(i){return h.Kind.is(i)}function We(i){return h.String.is(i)&&i!==""}function qt(i,t=!1){return i?i.map(e=>new A(e,t)):[]}function Qi(i){return i!=null}function tn(i){let t=D(g({},i.custom||[]),{kind:"user",key:String(i.key)});if(Qi(i.anonymous)){let e=!!i.anonymous;delete t.anonymous,t.anonymous=e}return i.name!==null&&i.name!==void 0&&(t.name=i.name),i.ip!==null&&i.ip!==void 0&&(t.ip=i.ip),i.firstName!==null&&i.firstName!==void 0&&(t.firstName=i.firstName),i.lastName!==null&&i.lastName!==void 0&&(t.lastName=i.lastName),i.email!==null&&i.email!==void 0&&(t.email=i.email),i.avatar!==null&&i.avatar!==void 0&&(t.avatar=i.avatar),i.country!==null&&i.country!==void 0&&(t.country=i.country),i.privateAttributeNames!==null&&i.privateAttributeNames!==void 0&&(t._meta={privateAttributes:i.privateAttributeNames}),t}var S=class i{constructor(t,e,n){this.I=!1,this.st=!1,this.oe=!1,this.M={},this.kind=e,this.valid=t,this.message=n}static x(t,e){return new i(!1,t,e)}static qe(t,e){if(!(!e||!t.isValid))return t.depth===1&&t.getComponent(0)==="anonymous"?!!(e!=null&&e.anonymous):t.get(e)}ce(t){if(this.I)return this.M[t];if(this.kind===t)return this.v}static Ye(t){let e=Object.keys(t).filter(c=>c!=="kind"),n=e.every(Ge);if(!e.length)return i.x("multi","A multi-kind context must contain at least one kind");if(!n)return i.x("multi","Context contains invalid kinds");let r={},s=!0,a=e.reduce((c,l)=>{var d;let u=t[l];return Xi(u)?(c[l]=u,r[l]=qt((d=u._meta)==null?void 0:d.privateAttributes)):s=!1,c},{});if(!s)return i.x("multi","Context contained contexts that were not objects");if(!Object.values(a).every(c=>We(c.key)))return i.x("multi","Context contained invalid keys");if(e.length===1){let c=e[0],l=new i(!0,c);return l.v=D(g({},a[c]),{kind:c}),l.at=r,l.st=c==="user",l}let o=new i(!0,t.kind);return o.M=a,o.at=r,o.I=!0,o}static Ze(t){var c;let{key:e,kind:n}=t,r=Ge(n),s=We(e);if(!r)return i.x(n!=null?n:"unknown","The kind was not valid for the context");if(!s)return i.x(n,"The key for the context was not valid");let a=qt((c=t._meta)==null?void 0:c.privateAttributes),o=new i(!0,n);return o.st=n==="user",o.v=t,o.at={[n]:a},o}static Xe(t){if(!(t.key!==void 0&&t.key!==null))return i.x("user","The key for the context was not valid");let n=new i(!0,"user");return n.st=!0,n.oe=!0,n.v=tn(t),n.at={user:qt(t.privateAttributeNames,!0)},n}static fromLDContext(t){return t?Qe(t)?i.Ze(t):ti(t)?i.Ye(t):ei(t)?i.Xe(t):i.x("unknown","Context was not of a valid kind"):i.x("unknown","No context specified. Returning default value")}static toLDContext(t){if(!t.valid)return;let e=t.getContexts();if(!t.I)return e[0][1];let n={kind:"multi"};return e.forEach(r=>{let s=r[0],a=r[1];n[s]=a}),n}valueForKind(t,e=ie){return t.isKind?this.kinds:i.qe(t,this.ce(e))}key(t=ie){var e;return(e=this.ce(t))==null?void 0:e.key}get isMultiKind(){return this.I}get canonicalKey(){return this.st?this.v.key:this.I?Object.keys(this.M).sort().map(t=>`${t}:${Ke(this.M[t].key)}`).join(":"):`${this.kind}:${Ke(this.v.key)}`}get kinds(){return this.I?Object.keys(this.M):[this.kind]}get kindsAndKeys(){return this.I?Object.entries(this.M).reduce((t,[e,n])=>(t[e]=n.key,t),{}):{[this.kind]:this.v.key}}privateAttributes(t){var e;return((e=this.at)==null?void 0:e[t])||[]}getContexts(){return this.I?Object.entries(this.M):[[this.kind,this.v]]}get legacy(){return this.oe}canonicalUnfilteredJson(){if(this.valid){if(this.kt)return this.kt;try{this.kt=bt(i.toLDContext(this))}catch(t){}return this.kt}}};S.UserKind=ie;var en=["key","kind","_meta","anonymous"].map(i=>new A(i,!0)),nn=["name","ip","firstName","lastName","email","avatar","country"];function rn(i,t){return i.depth===t.length&&t.every((e,n)=>e===i.getComponent(n))}function sn(i,t){let e=[],n={},r=[];for(e.push(...Object.keys(i).map(s=>({key:s,ptr:[s],source:i,parent:n,visited:[i]})));e.length;){let s=e.pop(),a=t.find(o=>rn(o,s.ptr));if(a)r.push(a.redactionName);else{let o=s.source[s.key];o===null?s.parent[s.key]=o:Array.isArray(o)?s.parent[s.key]=[...o]:typeof o=="object"?s.visited.includes(o)||(s.parent[s.key]={},e.push(...Object.keys(o).map(c=>({key:c,ptr:[...s.ptr,c],source:o,parent:s.parent[s.key],visited:[...s.visited,o]})))):s.parent[s.key]=o}}return{cloned:n,excluded:r.sort()}}var ne=class{constructor(t,e){this.Qe=t,this.ti=e}filter(t,e=!1){let n=t.getContexts();if(n.length===1)return this.le(t,n[0][1],n[0][0],e);let r={kind:"multi"};return n.forEach(([s,a])=>{r[s]=this.le(t,a,s,e)}),r}ei(t,e,n,r){return(r?Object.keys(e).map(s=>new A(s,!0)):[...this.ti,...t.privateAttributes(n)]).filter(s=>!en.some(a=>a.compare(s)))}le(t,e,n,r){let s=this.Qe||r&&e.anonymous===!0,{cloned:a,excluded:o}=sn(e,this.ei(t,e,n,s));return t.legacy&&nn.forEach(c=>{c in a&&(a[c]=String(a[c]))}),o.length&&(a._meta||(a._meta={}),a._meta.redactedAttributes=o),a._meta&&(delete a._meta.privateAttributes,Object.keys(a._meta).length===0&&delete a._meta),a}},_e=30*1e3,an=.5,kt=class{constructor(t,e,n=Math.random){this.ii=e,this.ni=n,this.xt=0,this.ue=Math.max(1,t),this.ri=Math.ceil(Math.log2(_e/this.ue))}T(){let t=Math.min(this.xt,this.ri),e=this.ue*2**t;return Math.min(e,_e)}si(t){return t-Math.trunc(this.ni()*an*t)}success(t=Date.now()){this.Lt=t}fail(t=Date.now()){this.Lt!==void 0&&t-this.Lt>this.ii&&(this.xt=0),this.Lt=void 0;let e=this.si(this.T());return this.xt+=1,e}};var Je;(function(i){i[i.Valid=0]="Valid",i[i.Initializing=1]="Initializing",i[i.Interrupted=2]="Interrupted",i[i.Closed=3]="Closed"})(Je||(Je={}));var R=class extends Error{constructor(t,e,n,r=!0){super(e),this.kind=t,this.status=n,this.name="LaunchDarklyPollingError",this.recoverable=r}},j=class extends Error{constructor(t,e,n,r=!0){super(e),this.kind=t,this.code=n,this.name="LaunchDarklyStreamingError",this.recoverable=r}};var Mr=120*1e3,Ur=300*1e3;var w;(function(i){i.Unknown="UNKNOWN",i.NetworkError="NETWORK_ERROR",i.ErrorResponse="ERROR_RESPONSE",i.InvalidData="INVALID_DATA"})(w||(w={}));var z;(function(i){i[i.Disabled=0]="Disabled",i[i.Enabled=1]="Enabled"})(z||(z={}));var H;(function(i){i[i.AnalyticsEvents=0]="AnalyticsEvents",i[i.DiagnosticEvent=1]="DiagnosticEvent"})(H||(H={}));var F;(function(i){i[i.Succeeded=0]="Succeeded",i[i.Failed=1]="Failed",i[i.FailedAndMustShutDown=2]="FailedAndMustShutDown"})(F||(F={}));function V(i){if(typeof i=="string")return i;if(i===void 0)return"undefined";if(i===null)return"null";if(Object.prototype.hasOwnProperty.call(i,"toString"))try{return i.toString()}catch(t){}if(typeof i=="bigint")return`${i}n`;try{return JSON.stringify(i)}catch(t){return t instanceof TypeError&&t.message.indexOf("circular")>=0?"[Circular]":"[Not Stringifiable]"}}function on(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(Number(i))}function cn(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(parseInt(i,10))}function ln(i){return typeof i=="symbol"?"NaN":String(parseFloat(i))}var vt={s:i=>V(i),d:i=>on(i),i:i=>cn(i),f:i=>ln(i),j:i=>V(i),o:i=>V(i),O:i=>V(i),c:()=>""};function re(...i){var e;let t=i.shift();if(h.String.is(t)){let n="",r=0;for(;r<t.length;){let s=t.charAt(r);if(s==="%"){if(r+1<t.length){let o=t.charAt(r+1);if(o in vt&&i.length){let c=i.shift();n+=(e=vt[o])==null?void 0:e.call(vt,c)}else o==="%"?n+="%":n+=`%${o}`;r+=2}}else n+=s,r+=1}return i.length&&(n.length&&(n+=" "),n+=i.map(V).join(" ")),n}return i.map(V).join(" ")}var v;(function(i){i[i.debug=0]="debug",i[i.info=1]="info",i[i.warn=2]="warn",i[i.error=3]="error",i[i.none=4]="none"})(v||(v={}));var un=["debug","info","warn","error","none"],M=class i{static get(){return new i({})}constructor(t){var e,n,r;if(this.fi=(n=v[(e=t.level)!=null?e:"info"])!=null?n:v.info,this.gi=(r=t.name)!=null?r:"LaunchDarkly",this.pe=t.formatter,typeof t.destination=="object")this.me={[v.debug]:t.destination.debug,[v.info]:t.destination.info,[v.warn]:t.destination.warn,[v.error]:t.destination.error};else if(typeof t.destination=="function"){let{destination:s}=t;this.me={[v.debug]:s,[v.info]:s,[v.warn]:s,[v.error]:s}}}pi(...t){var e;try{return this.pe?(e=this.pe)==null?void 0:e.call(this,...t):re(...t)}catch(n){return re(...t)}}mi(t,e){try{t(e)}catch(n){console.error(e)}}L(t,e){var n;if(t>=this.fi){let r=`${un[t]}: [${this.gi}]`;try{let s=(n=this.me)==null?void 0:n[t];s?this.mi(s,`${r} ${this.pi(...e)}`):console.error(...e)}catch(s){console.error(...e)}}}error(...t){this.L(v.error,t)}warn(...t){this.L(v.warn,t)}info(...t){this.L(v.info,t)}debug(...t){this.L(v.debug,t)}},hn={error:h.Function,warn:h.Function,info:h.Function,debug:h.Function},_=class{constructor(t,e){Object.entries(hn).forEach(([n,r])=>{if(!r.is(t[n]))throw new Error(`Provided logger instance must support logger.${n}(...) method`)}),this.t=t,this.yi=e}L(t,e){try{this.t[t](...e)}catch(n){this.yi[t](...e)}}error(...t){this.L("error",t)}warn(...t){this.L("warn",t)}info(...t){this.L("info",t)}debug(...t){this.L("debug",t)}},pe=i=>{let t=new M({level:"info",destination:console.error,formatter:re});return i?new _(i,t):t},b=class{static deprecated(t,e){return`"${t}" is deprecated, please use "${e}"`}static optionBelowMinimum(t,e,n){return`Config option "${t}" had invalid value of ${e}, using minimum of ${n} instead`}static unknownOption(t){return`Ignoring unknown config option "${t}"`}static wrongOptionType(t,e,n){return`Config option "${t}" should be of type ${e}, got ${n}, using default value`}static wrongOptionTypeBoolean(t,e){return`Config option "${t}" should be a boolean, got ${e}, converting to boolean`}static invalidTagValue(t){return`Config option "${t}" must only contain letters, numbers, ., _ or -.`}static tagValueTooLong(t){return`Value of "${t}" was longer than 64 characters and was discarded.`}static partialEndpoint(t){return`You have set custom uris without specifying the ${t} URI; connections may not work properly`}},dn=/^(\w|\.|-)+$/,fn=h.stringMatchingRegex(dn),gn={is:(i,t)=>fn.is(i)?i.length>64?{valid:!1,message:b.tagValueTooLong(t)}:{valid:!0}:{valid:!1,message:b.invalidTagValue(t)}},xt=class{constructor(t){let e={},n=t==null?void 0:t.application,r=t==null?void 0:t.logger;n&&Object.entries(n).forEach(([a,o])=>{if(o!=null){let{valid:c,message:l}=gn.is(o,`application.${a}`);c?a==="versionName"?e["application-version-name"]=[o]:e[`application-${a}`]=[o]:r==null||r.warn(l)}});let s=Object.keys(e);s.length&&(this.value=s.sort().flatMap(a=>e[a].sort().map(o=>`${a}/${o}`)).join(" "))}},Lt=class{constructor(t,e,n){this.platform=n,this.basicConfiguration={tags:e.tags,logger:e.logger,offline:e.offline,serviceEndpoints:e.serviceEndpoints,sdkKey:t}}};function Yt(i){return i.replace(/\/+$/,"")}function me(i){return i.replace(/^\/+/,"").replace(/\?$/,"")}var U=class i{constructor(t,e,n=i.DEFAULT_EVENTS,r="/bulk",s="/diagnostic",a=!0,o){this.streaming=Yt(t),this.polling=Yt(e),this.events=Yt(n),this.analyticsEventPath=r,this.diagnosticEventPath=s,this.includeAuthorizationHeader=a,this.payloadFilterKey=o}};U.DEFAULT_EVENTS="https://events.launchdarkly.com";function ye(i,t=[]){if(t.length===0)return i;let e=t.map(({key:n,value:r})=>`${n}=${r}`);return`${i}?${e.join("&")}`}function ii(i,t,e){let n=me(t),r=[...e];return i.payloadFilterKey&&r.push({key:"filter",value:i.payloadFilterKey}),ye(`${i.streaming}/${n}`,r)}function ni(i,t,e=[]){let n=me(t),r=[...e];return i.payloadFilterKey&&r.push({key:"filter",value:i.payloadFilterKey}),ye(`${i.polling}/${n}`,r)}function qe(i,t,e=[]){let n=me(t);return ye(`${i.events}/${n}`,e)}var J=class extends Error{constructor(t){super(t),this.name="LaunchDarklyUnexpectedResponseError"}},q=class extends Error{constructor(t){super(t),this.name="LaunchDarklyClientError"}},I=class extends Error{constructor(t){super(t),this.name="LaunchDarklyTimeoutError"}};function Z(i){return i>=400&&i<500?i===400||i===408||i===429:!0}function pn(i){return i===413?!0:Z(i)}function $t(i,t){let e,n;return{promise:new Promise((s,a)=>{n=s,e=setTimeout(()=>{let o=`${t} timed out after ${i} seconds.`;a(new I(o))},i*1e3)}),cancel:()=>{n(),clearTimeout(e)}}}function ve(i){return i==null?i:JSON.parse(JSON.stringify(i))}function Nt(i){return Math.trunc(i*1e3)}var mn=i=>JSON.stringify(i)==="{}",Ft=(i,t)=>i&&Object.entries(i).reduce((e,[n,r])=>(r&&!mn(r)&&!(t!=null&&t.includes(n))&&(e[n]=typeof r=="object"?Ft(r,t):r),e),{});function G(i,t){if(i===t)return!0;if(i&&t&&typeof i=="object"&&typeof t=="object"){if(i.constructor!==t.constructor)return!1;var e,n,r;if(Array.isArray(i)){if(e=i.length,e!=t.length)return!1;for(n=e;n--!==0;)if(!G(i[n],t[n]))return!1;return!0}if(i instanceof Map&&t instanceof Map){if(i.size!==t.size)return!1;for(n of i.entries())if(!t.has(n[0]))return!1;for(n of i.entries())if(!G(n[1],t.get(n[0])))return!1;return!0}if(i instanceof Set&&t instanceof Set){if(i.size!==t.size)return!1;for(n of i.entries())if(!t.has(n[0]))return!1;return!0}if(ArrayBuffer.isView(i)&&ArrayBuffer.isView(t)){if(e=i.length,e!=t.length)return!1;for(n=e;n--!==0;)if(i[n]!==t[n])return!1;return!0}if(i.constructor===RegExp)return i.source===t.source&&i.flags===t.flags;if(i.valueOf!==Object.prototype.valueOf)return i.valueOf()===t.valueOf();if(i.toString!==Object.prototype.toString)return i.toString()===t.toString();if(r=Object.keys(i),e=r.length,e!==Object.keys(t).length)return!1;for(n=e;n--!==0;)if(!Object.prototype.hasOwnProperty.call(t,r[n]))return!1;for(n=e;n--!==0;){var s=r[n];if(!G(i[s],t[s]))return!1}return!0}return i!==i&&t!==t}function ri(i,t,e,n=!0,r="user-agent"){let{userAgentBase:s,version:a,wrapperName:o,wrapperVersion:c}=t.sdkData(),l={[r]:`${s!=null?s:"NodeJSClient"}/${a}`};return n&&(l.authorization=i),o&&(l["x-launchdarkly-wrapper"]=c?`${o}/${c}`:o),e!=null&&e.value&&(l["x-launchdarkly-tags"]=e.value),l}function $(i,t,e){let n;i.status?n=`error ${i.status}${i.status===401?" (invalid SDK key)":""}`:n=`I/O error (${i.message||"unknown error"})`;let r=e!=null?e:"giving up permanently";return`Received ${n} for ${t} - ${r}`}function Rt({status:i}){return i?Z(i):!0}var we=(i,t)=>t.btoa(i).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"");var Ee=async(i=1e3)=>new Promise(t=>{setTimeout(t,i)});var se=class{constructor(t,e,n){this.p=e,this.vi=n,this.Pt=[],this.ye=Date.now(),this.ve=this.ye,this.we={diagnosticId:e.crypto.randomUUID(),sdkKeySuffix:t.length>6?t.substring(t.length-6):t}}createInitEvent(){var n,r,s;let t=this.p.info.sdkData(),e=this.p.info.platformData();return{kind:"diagnostic-init",id:this.we,creationDate:this.ye,sdk:t,configuration:this.vi,platform:g({name:e.name,osArch:(n=e.os)==null?void 0:n.arch,osName:(r=e.os)==null?void 0:r.name,osVersion:(s=e.os)==null?void 0:s.version},e.additional||{})}}recordStreamInit(t,e,n){let r={timestamp:t,failed:e,durationMillis:n};this.Pt.push(r)}createStatsEventAndReset(t,e,n){let r=Date.now(),s={kind:"diagnostic",id:this.we,creationDate:r,dataSinceDate:this.ve,droppedEvents:t,deduplicatedUsers:e,eventsInLastBatch:n,streamInits:this.Pt};return this.Pt=[],this.ve=r,s}},ae;(function(i){i.MalformedFlag="MALFORMED_FLAG",i.UserNotSpecified="USER_NOT_SPECIFIED",i.FlagNotFound="FLAG_NOT_FOUND",i.ClientNotReady="CLIENT_NOT_READY",i.WrongType="WRONG_TYPE"})(ae||(ae={}));var yn=ae,St=class{static invalidMetricValue(t){return`The track function was called with a non-numeric "metricValue" (${t}), only numeric metric values are supported.`}};St.MissingContextKeyNoEvent="Context was unspecified or had no key; event will not be sent";var oe=class{constructor(t,e){let{basicConfiguration:n,platform:r}=t,{serviceEndpoints:{analyticsEventPath:s,diagnosticEventPath:a}}=n,{crypto:o,requests:c}=r;this.wi=g({},e),this.Ee=qe(n.serviceEndpoints,s,[]),this.Ei=qe(n.serviceEndpoints,a,[]),this.$=c,this.Di=o}async ot(t,e,n,r){let s={status:F.Succeeded},a=D(g({},this.wi),{"content-type":"application/json"});n&&(a["x-launchdarkly-payload-id"]=n,a["x-launchDarkly-event-schema"]="4");let o;try{let{status:c,headers:l}=await this.$.fetch(e,{headers:a,body:JSON.stringify(t),compressBodyIfPossible:!0,method:"POST",keepalive:!0}),u=Date.parse(l.get("date")||"");if(u&&(s.serverTime=u),c<=204)return s;if(o=new J($({status:c,message:"some events were dropped"},"event posting")),!Z(c))return pn(c)?s.status=F.Failed:s.status=F.FailedAndMustShutDown,s.error=o,s}catch(c){o=c}return o&&!r?(s.status=F.Failed,s.error=o,s):(await Ee(),this.ot(t,this.Ee,n,!1))}async sendEventData(t,e){let n=t===H.AnalyticsEvents?this.Di.randomUUID():void 0,r=t===H.AnalyticsEvents?this.Ee:this.Ei;return this.ot(e,r,n,!0)}};function Ct(i){return i.kind==="feature"}function vn(i){return i.kind==="identify"}function wn(i){return i.kind==="migration_op"}var ce=class{constructor(t,e,n,r,s,a){this.count=t,this.key=e,this.value=n,this.version=s,this.variation=a,this.default=r}increment(){this.count+=1}};function En(i){return`${i.key}:${i.variation!==null&&i.variation!==void 0?i.variation:""}:${i.version!==null&&i.version!==void 0?i.version:""}`}var Pt=class{constructor(t=!1,e){this.bi=t,this.S=e,this.X=0,this.ct=0,this.lt={},this.ut={}}summarizeEvent(t){if(Ct(t)&&!t.excludeFromSummaries){this.v||(this.v=t.context);let e=En(t),n=this.lt[e],r=this.ut[t.key];r||(r=new Set,this.ut[t.key]=r),t.context.kinds.forEach(s=>r.add(s)),n?n.increment():this.lt[e]=new ce(1,t.key,t.value,t.default,t.version,t.variation),(this.X===0||t.creationDate<this.X)&&(this.X=t.creationDate),t.creationDate>this.ct&&(this.ct=t.creationDate)}}getSummary(){var n;let t=Object.values(this.lt).reduce((r,s)=>{let a=r[s.key];a||(a={default:s.default,counters:[],contextKinds:[...this.ut[s.key]]},r[s.key]=a);let o={value:s.value,count:s.count};return s.variation!==void 0&&s.variation!==null&&(o.variation=s.variation),s.version!==void 0&&s.version!==null?o.version=s.version:o.unknown=!0,a.counters.push(o),r},{}),e={startDate:this.X,endDate:this.ct,features:t,kind:"summary",context:this.v!==void 0&&this.bi?(n=this.S)==null?void 0:n.filter(this.v):void 0};return this.ki(),e}ki(){this.X=0,this.ct=0,this.lt={},this.ut={}}},le=class extends Error{constructor(t){super(t),this.name="LaunchDarklyInvalidSDKKeyError"}},ue=class{constructor(t,e){this.S=t,this.t=e,this.Q={}}summarizeEvent(t){var e;if(Ct(t)){let n=t.context.canonicalUnfilteredJson();if(!n){t.context.valid&&((e=this.t)==null||e.error("Unable to serialize context, likely the context contains a cycle."));return}let r=this.Q[n];r||(this.Q[n]=new Pt(!0,this.S),r=this.Q[n]),r.summarizeEvent(t)}}getSummaries(){let t=this.Q;return this.Q={},Object.values(t).map(e=>e.getSummary())}};function wt(i){let t=Math.trunc(i);return t===1?!0:t===0?!1:Math.floor(Math.random()*t)===0}function Dn(i){return i.getSummaries!==void 0}var he=class{constructor(t,e,n,r,s,a=!0,o=!1){this.r=t,this.ht=r,this.C=s,this.dt=[],this.De=0,this.It=0,this.Tt=0,this.At=!1,this.be=0,this.Ot=!1,this.$t=null,this.xi=t.eventsCapacity,this.t=e.basicConfiguration.logger,this.ke=new oe(e,n),this.S=new ne(t.allAttributesPrivate,t.privateAttributes.map(c=>new A(c))),o?this.tt=new ue(this.S,this.t):this.tt=new Pt,a&&this.start()}start(){var t,e;if(((t=this.ht)==null?void 0:t.flushInterval)!==void 0&&(this.$t=setInterval(()=>{var n;(n=this.ht)==null||n.flush()},this.ht.flushInterval*1e3)),this.Li=setInterval(async()=>{var n;try{await this.flush()}catch(r){(n=this.t)==null||n.debug(`Flush failed: ${r}`)}},this.r.flushInterval*1e3),this.C){let n=this.C.createInitEvent();this.xe(n),this.Le=setInterval(()=>{let r=this.C.createStatsEventAndReset(this.It,this.Tt,this.be);this.It=0,this.Tt=0,this.xe(r)},this.r.diagnosticRecordingInterval*1e3)}(e=this.t)==null||e.debug("Started EventProcessor.")}xe(t){this.ke.sendEventData(H.DiagnosticEvent,t)}close(){clearInterval(this.Li),this.$t&&clearInterval(this.$t),this.Le&&clearInterval(this.Le)}async flush(){var e;if(this.Ot)throw new le("Events cannot be posted because a permanent error has been encountered. This is most likely an invalid SDK key. The specific error information is logged independently.");let t=this.dt;if(this.dt=[],Dn(this.tt))this.tt.getSummaries().forEach(r=>{Object.keys(r.features).length&&t.push(r)});else{let n=this.tt.getSummary();Object.keys(n.features).length&&t.push(n)}t.length&&(this.be=t.length,(e=this.t)==null||e.debug("Flushing %d events",t.length),await this.ot(t))}sendEvent(t){var c;if(this.Ot)return;if(wn(t)){if(wt(t.samplingRatio)){let l=D(g({},t),{context:t.context?this.S.filter(t.context):void 0});l.samplingRatio===1&&delete l.samplingRatio,this.ft(l)}return}this.tt.summarizeEvent(t);let e=Ct(t),n=e&&t.trackEvents||!e,r=this.Si(t),s=vn(t),a=(c=this.ht)==null?void 0:c.processContext(t.context);a||s||(this.Tt+=1),a&&!s&&this.ft(this.Nt({kind:"index",creationDate:t.creationDate,context:t.context,samplingRatio:1},!1)),n&&wt(t.samplingRatio)&&this.ft(this.Nt(t,!1)),r&&wt(t.samplingRatio)&&this.ft(this.Nt(t,!0))}Nt(t,e){switch(t.kind){case"feature":{let n={kind:e?"debug":"feature",creationDate:t.creationDate,context:this.S.filter(t.context,!e),key:t.key,value:t.value,default:t.default};return t.samplingRatio!==1&&(n.samplingRatio=t.samplingRatio),t.prereqOf&&(n.prereqOf=t.prereqOf),t.variation!==void 0&&(n.variation=t.variation),t.version!==void 0&&(n.version=t.version),t.reason&&(n.reason=t.reason),n}case"index":case"identify":{let n={kind:t.kind,creationDate:t.creationDate,context:this.S.filter(t.context)};return t.samplingRatio!==1&&(n.samplingRatio=t.samplingRatio),n}case"custom":{let n={kind:"custom",creationDate:t.creationDate,key:t.key,context:this.S.filter(t.context)};return t.samplingRatio!==1&&(n.samplingRatio=t.samplingRatio),t.data!==void 0&&(n.data=t.data),t.metricValue!==void 0&&(n.metricValue=t.metricValue),t.url!==void 0&&(n.url=t.url),n}case"click":return{kind:"click",creationDate:t.creationDate,contextKeys:t.context.kindsAndKeys,key:t.key,url:t.url,selector:t.selector};case"pageview":return{kind:"pageview",creationDate:t.creationDate,contextKeys:t.context.kindsAndKeys,key:t.key,url:t.url};default:return t}}ft(t){var e;this.dt.length<this.xi?(this.dt.push(t),this.At=!1):(this.At||(this.At=!0,(e=this.t)==null||e.warn("Exceeded event queue capacity. Increase capacity to avoid dropping events.")),this.It+=1)}Si(t){return Ct(t)&&t.debugEventsUntilDate&&t.debugEventsUntilDate>this.De&&t.debugEventsUntilDate>Date.now()}async ot(t){let e=await this.ke.sendEventData(H.AnalyticsEvents,t);if(e.status===F.FailedAndMustShutDown&&(this.Ot=!0),e.serverTime&&(this.De=e.serverTime),e.error)throw e.error}},It=class{constructor(t,e,n,r,s=1,a){this.context=t,this.key=e,this.data=n,this.metricValue=r,this.samplingRatio=s,this.url=a,this.kind="custom",this.creationDate=Date.now(),this.context=t}},Y=class{constructor(t,e,n,r,s,a,o,c,l,u,d,f,m=1){this.withReasons=t,this.context=e,this.key=n,this.samplingRatio=m,this.kind="feature",this.creationDate=Date.now(),this.value=r,this.default=s,a!==void 0&&(this.version=a),o!==void 0&&(this.variation=o),c!==void 0&&(this.trackEvents=c),l!==void 0&&(this.prereqOf=l),u!==void 0&&(this.reason=u),d!==void 0&&(this.debugEventsUntilDate=d),f!==void 0&&(this.excludeFromSummaries=f)}},Tt=class{constructor(t,e=1){this.context=t,this.samplingRatio=e,this.kind="identify",this.creationDate=Date.now()}},de=class{close(){}async flush(){}sendEvent(){}},fe=class{constructor(t){this.Ft=t}evalEvent(t){var e;return new Y(this.Ft,t.context,t.flagKey,t.value,t.defaultVal,t.version,(e=t.variation)!=null?e:void 0,t.trackEvents||t.addExperimentData,t.prereqOfFlagKey,this.Ft||t.addExperimentData?t.reason:void 0,t.debugEventsUntilDate,t.excludeFromSummaries,t.samplingRatio)}unknownFlagEvent(t,e,n){return new Y(this.Ft,n,t,e,e,void 0,void 0,void 0,void 0,void 0,void 0,void 0,void 0)}identifyEvent(t){return new Tt(t,1)}customEvent(t,e,n,r,s=1){return new It(e,t,n!=null?n:void 0,r!=null?r:void 0,s)}},Ye="FDv1Fallback";function bn(i){return{Ci:i,Se:"",useSelector(t){return this.Se=t,this},processFullTransfer(t){let e=[{event:"server-intent",data:{payloads:[{id:Ye,target:1,intentCode:"xfer-full",reason:"payload-missing"}]}}];Object.entries((t==null?void 0:t.flags)||[]).forEach(([n,r])=>{e.push({event:"put-object",data:{kind:"flag",key:n,version:r.version||1,object:r}})}),Object.entries((t==null?void 0:t.segments)||[]).forEach(([n,r])=>{e.push({event:"put-object",data:{kind:"segment",key:n,version:r.version||1,object:r}})}),e.push({event:"payload-transferred",data:{state:this.Se,version:1,id:Ye}}),this.Ci.processEvents(e)}}}var At=class{constructor(t,e,n){this.Pi=t,this.y=e,this.t=n,this.e=[],this.U=void 0,this.K=!1,this.G=[],this.Ii=r=>{var a;if(this.Rt(),!r.payloads.length)return;let s=r.payloads[0];switch(s==null?void 0:s.intentCode){case"xfer-full":this.K=!0;break;case"xfer-changes":this.K=!1;break;case"none":this.K=!1,this.Ti(s);break;default:(a=this.t)==null||a.warn(`Unable to process intent code '${s==null?void 0:s.intentCode}'.`);return}this.U=s==null?void 0:s.id},this.Ai=r=>{var a;if(!this.U||!r.kind||!r.key||!r.version||!r.object)return;let s=this.Oi(r.kind,r.object);if(!s){(a=this.t)==null||a.warn(`Unable to process object for kind: '${r.kind}'`);return}this.G.push({kind:r.kind,key:r.key,version:r.version,object:s})},this.$i=r=>{!this.U||!r.kind||!r.key||!r.version||this.G.push({kind:r.kind,key:r.key,version:r.version,deleted:!0})},this.Ti=r=>{if(!r.id||!r.target)return;let s={id:r.id,version:r.target,basis:!1,updates:[]};this.e.forEach(a=>a(s)),this.Ce()},this.Ni=r=>{if(!this.U||r.state===null||r.state===void 0||!r.version){this.Rt();return}let s={id:this.U,version:r.version,state:r.state,basis:this.K,updates:this.G};this.e.forEach(a=>a(s)),this.Ce()},this.Fi=r=>{var s;(s=this.t)==null||s.info(`Goodbye was received from the LaunchDarkly connection with reason: ${r.reason}.`),this.Rt()},this.Ri=r=>{var s;(s=this.t)==null||s.info(`An issue was encountered receiving updates for payload ${this.U} with reason: ${r.reason}.`),this.Mi()}}addPayloadListener(t){this.e.push(t)}removePayloadListener(t){let e=this.e.indexOf(t,0);e>-1&&this.e.splice(e,1)}processEvents(t){t.forEach(e=>{switch(e.event){case"server-intent":{this.Ii(e.data);break}case"put-object":{this.Ai(e.data);break}case"delete-object":{this.$i(e.data);break}case"payload-transferred":{this.Ni(e.data);break}case"goodbye":{this.Fi(e.data);break}case"error":{this.Ri(e.data);break}}})}Oi(t,e){var n,r;return(r=(n=this.Pi)[t])==null?void 0:r.call(n,e)}Ce(){this.K=!1,this.G=[]}Mi(){this.G=[]}Rt(){this.U=void 0,this.K=!1,this.G=[]}},ge=class{constructor(t,e,n,r){this.y=n,this.t=r,this.W(t,"server-intent"),this.W(t,"put-object"),this.W(t,"delete-object"),this.W(t,"payload-transferred"),this.W(t,"goodbye"),this.W(t,"error"),this.Mt=new At(e,n,r)}addPayloadListener(t){this.Mt.addPayloadListener(t)}removePayloadListener(t){this.Mt.removePayloadListener(t)}W(t,e){t.addEventListener(e,async n=>{var r,s,a,o,c;if(n!=null&&n.data){(r=this.t)==null||r.debug(`Received ${e} event. Data is ${n.data}`);try{this.Mt.processEvents([{event:e,data:JSON.parse(n.data)}])}catch(l){(s=this.t)==null||s.error(`Stream received data that was unable to be processed in "${e}" message`),(a=this.t)==null||a.debug(`Data follows: ${n.data}`),(o=this.y)==null||o.call(this,w.InvalidData,"Malformed data in EventStream.")}}else(c=this.y)==null||c.call(this,w.Unknown,"Event from EventStream missing data.")})}};function kn(i){if(i){let t=Object.keys(i).find(e=>e.toLowerCase()==="x-ld-envid");if(t)return{environmentId:i[t]}}}var Ze="unknown plugin";function Ot(i,t){try{return t.getMetadata().name||Ze}catch(e){return i.error("Exception thrown getting metadata for plugin. Unable to get plugin name."),Ze}}function xn(i,t,e){let n=[];return e.forEach(r=>{var s;try{let a=(s=r.getHooks)==null?void 0:s.call(r,t);a===void 0?i.error(`Plugin ${Ot(i,r)} returned undefined from getHooks.`):a&&a.length>0&&n.push(...a)}catch(a){i.error(`Exception thrown getting hooks for plugin ${Ot(i,r)}. Unable to get hooks.`)}}),n}function Ln(i,t,e,n){n.forEach(r=>{try{r.register(e,t)}catch(s){i.error(`Exception thrown registering plugin ${Ot(i,r)}.`)}})}var k=Object.freeze({__proto__:null,ClientMessages:St,DiagnosticsManager:se,ErrorKinds:yn,EventFactoryBase:fe,EventProcessor:he,FDv1PayloadAdaptor:bn,InputCustomEvent:It,InputEvalEvent:Y,InputIdentifyEvent:Tt,NullEventProcessor:de,PayloadProcessor:At,PayloadStreamReader:ge,canonicalize:bt,initMetadataFromHeaders:kn,isLegacyUser:ei,isMultiKind:ti,isSingleKind:Qe,safeGetHooks:xn,safeGetName:Ot,safeRegisterPlugins:Ln,shouldSample:wt});var E;(function(i){i.Initializing="INITIALIZING",i.Valid="VALID",i.Interrupted="INTERRUPTED",i.SetOffline="SET_OFFLINE",i.Closed="CLOSED"})(E||(E={}));function Cn(i){return i>=200&&i<=299}var Mt=class extends Error{constructor(t,e){super(t),this.status=e,this.name="LaunchDarklyRequestError"}},be=class{constructor(t,e,n,r,s){this.$=t,this.Ui=e,this.gt=n,this.Vi=r,this.ji=s}async requestPayload(){let t;try{let e=await this.$.fetch(this.Ui,{method:this.Vi,headers:this.gt,body:this.ji});if(Cn(e.status))return await e.text();t=e.status}catch(e){throw new Mt(e==null?void 0:e.message)}throw new Mt(`Unexpected status code: ${t}`,t)}};function $e(i,t,e,n,r,s,a,o,c,l){let u,d="GET",f=g({},s);c&&(d="REPORT",f["content-type"]="application/json",u=i);let m=c?e.pathReport(r,i):e.pathGet(r,i),p=[...a!=null?a:[]];o&&p.push({key:"withReasons",value:"true"}),l&&p.push({key:"h",value:l});let y=ni(t,m,p);return new be(n,y,f,d,u)}var si=new Error("Task has already been executed or shed. This is likely an implementation error. The task will not be executed again.");function Pn(i,t,e=!1){let n,r=new Promise(o=>{n=(c,l)=>{var u;try{(u=i.after)==null||u.call(i,c,l)}catch(d){t==null||t.error(`Error in after callback: ${d}`)}o(c)}}),s=i.before?i.before():Promise.resolve(void 0),a=!1;return{execute:()=>{a&&(t==null||t.error(si)),a=!0,s.then(o=>{i.execute(o).then(c=>n({status:"complete",result:c},o)).catch(c=>n({status:"error",error:c},o))}).catch(o=>{t==null||t.error(o),n({status:"error",error:o},void 0)})},shed:()=>{a&&(t==null||t.error(si)),a=!0,s.then(o=>{n({status:"shed"},o)})},promise:r,sheddable:e}}function In(i){let t,e=[];function n(){if(!t&&e.length>0){let r=e.shift();t=r.promise.finally(()=>{t=void 0,n()}),r.execute()}}return{execute(r,s=!1){var o,c;let a=Pn(r,i,s);return t?((o=e[e.length-1])!=null&&o.sheddable&&((c=e.pop())==null||c.shed()),e.push(a)):(t=a.promise.finally(()=>{t=void 0,n()}),a.execute()),a.promise},pendingCount(){return e.length}}}var Tn={logger:h.Object,maxCachedContexts:h.numberWithMin(0),baseUri:h.String,streamUri:h.String,eventsUri:h.String,capacity:h.numberWithMin(1),diagnosticRecordingInterval:h.numberWithMin(2),flushInterval:h.numberWithMin(2),streamInitialReconnectDelay:h.numberWithMin(0),allAttributesPrivate:h.Boolean,debug:h.Boolean,diagnosticOptOut:h.Boolean,withReasons:h.Boolean,sendEvents:h.Boolean,pollInterval:h.numberWithMin(30),useReport:h.Boolean,privateAttributes:h.StringArray,applicationInfo:h.Object,wrapperName:h.String,wrapperVersion:h.String,payloadFilterKey:h.stringMatchingRegex(/^[a-zA-Z0-9](\w|\.|-)*$/),hooks:h.createTypeArray("Hook[]",{}),inspectors:h.createTypeArray("LDInspection",{}),cleanOldPersistentData:h.Boolean},An=300,pi="https://clientsdk.launchdarkly.com",mi="https://clientstream.launchdarkly.com";function On(i){return i instanceof _?i:pe(i)}var ke=class{constructor(t={},e={getImplementationHooks:()=>[],credentialType:"mobileKey"}){var r,s,a;this.logger=pe(),this.baseUri=pi,this.eventsUri=U.DEFAULT_EVENTS,this.streamUri=mi,this.maxCachedContexts=5,this.capacity=100,this.diagnosticRecordingInterval=900,this.flushInterval=30,this.streamInitialReconnectDelay=1,this.allAttributesPrivate=!1,this.debug=!1,this.diagnosticOptOut=!1,this.sendEvents=!0,this.sendLDHeaders=!0,this.useReport=!1,this.withReasons=!1,this.privateAttributes=[],this.pollInterval=An,this.hooks=[],this.inspectors=[],this.logger=On(t.logger),this.zi(t).forEach(o=>this.logger.warn(o)),this.serviceEndpoints=new U(this.streamUri,this.baseUri,this.eventsUri,e.analyticsEventPath,e.diagnosticEventPath,e.includeAuthorizationHeader,t.payloadFilterKey),this.useReport=(r=t.useReport)!=null?r:!1,this.tags=new xt({application:this.applicationInfo,logger:this.logger}),this.userAgentHeaderName=(s=e.userAgentHeaderName)!=null?s:"user-agent",this.trackEventModifier=(a=e.trackEventModifier)!=null?a:(o=>o),this.credentialType=e.credentialType,this.getImplementationHooks=e.getImplementationHooks}zi(t){let e=[];return Object.entries(t).forEach(([n,r])=>{let s=Tn[n];if(s)if(s.is(r))n==="logger"||(this[n]=r!=null?r:void 0);else{let a=s.getType();if(a==="boolean")e.push(b.wrongOptionTypeBoolean(n,typeof r)),this[n]=!!r;else if(a==="boolean | undefined | null")e.push(b.wrongOptionTypeBoolean(n,typeof r)),typeof r!="boolean"&&typeof r!="undefined"&&r!==null&&(this[n]=!!r);else if(s instanceof W&&h.Number.is(r)){let{min:o}=s;e.push(b.optionBelowMinimum(n,r,o)),this[n]=o}else e.push(b.wrongOptionType(n,s.getType(),typeof r))}else e.push(b.unknownOption(n))}),e}};async function yi(i,t){if(i.digest)return i.digest(t);if(i.asyncDigest)return i.asyncDigest(t);throw new Error("Platform must implement digest or asyncDigest")}var vi=async(i,{crypto:t,storage:e})=>{let n=await(e==null?void 0:e.get(i));return n||(n=t.randomUUID(),await(e==null?void 0:e.set(i,n))),n};function wi(i){return async t=>yi(i.createHash("sha256").update(t),"base64")}var C=async i=>i;async function Q(i){return(await Promise.all(i.map(e=>e.transform(e.value)))).join("_")}async function $n(i,t){return Q([{value:"LaunchDarkly",transform:C},{value:t,transform:wi(i)}])}async function Nn(i){return Q([{value:"LaunchDarkly",transform:C},{value:"AnonymousKeys",transform:C},{value:i,transform:C}])}async function Fn(i){return Q([{value:"LaunchDarkly",transform:C},{value:"ContextKeys",transform:C},{value:i,transform:C}])}async function Rn(i){return Q([{value:i,transform:C},{value:"ContextIndex",transform:C}])}async function ai(i,t,e){return Q([{value:t,transform:C},{value:e.canonicalKey,transform:wi(i)}])}var{isLegacyUser:Mn,isSingleKind:De,isMultiKind:oi}=k,Ei="1.0",Un=i=>{let n=i,{kind:t}=n,e=Jt(n,["kind"]);return{kind:"multi",[t]:e}},Vn=async({crypto:i,info:t},{applicationInfo:e})=>{var a;let{ld_application:n}=t.platformData(),r=(a=Ft(n))!=null?a:{},s=(e==null?void 0:e.id)||(r==null?void 0:r.id);if(s){let o=(e==null?void 0:e.version)||(r==null?void 0:r.version),c=(e==null?void 0:e.name)||(r==null?void 0:r.name),l=(e==null?void 0:e.versionName)||(r==null?void 0:r.versionName);return r=g(g(g(D(g({},r),{id:s}),o?{version:o}:{}),c?{name:c}:{}),l?{versionName:l}:{}),r.key=await yi(i.createHash("sha256").update(s),"base64"),r.envAttributesVersion=r.envAttributesVersion||Ei,r}},jn=async i=>{var o,c,l,u;let{ld_device:t,os:e}=i.info.platformData(),n=(o=Ft(t))!=null?o:{},r=(e==null?void 0:e.name)||((c=n.os)==null?void 0:c.name),s=(e==null?void 0:e.version)||((l=n.os)==null?void 0:l.version),a=(u=n.os)==null?void 0:u.family;if((r||s||a)&&(n.os=g(g(g({},r?{name:r}:{}),s?{version:s}:{}),a?{family:a}:{})),Object.keys(n).filter(d=>d!=="key"&&d!=="envAttributesVersion").length){let d=await Fn("ld_device");return n.key=await vi(d,i),n.envAttributesVersion=n.envAttributesVersion||Ei,n}},zn=async(i,t,e)=>{if(Mn(i))return i;let n,r;if(De(i)&&i.kind!=="ld_application"||oi(i)&&!i.ld_application?n=await Vn(t,e):e.logger.warn("Not adding ld_application environment attributes because it already exists."),De(i)&&i.kind!=="ld_device"||oi(i)&&!i.ld_device?r=await jn(t):e.logger.warn("Not adding ld_device environment attributes because it already exists."),n||r){let s=De(i)?Un(i):i;return g(g(g({},s),n?{ld_application:n}:{}),r?{ld_device:r}:{})}return i};function Hn(){let i,t;return{set(e,n){i=e,t=n},getContext(){return t},getUnwrappedContext(){return i},newIdentificationPromise(){let e,n;return{identifyPromise:new Promise((s,a)=>{e=s,n=a}),identifyResolve:e,identifyReject:n}},hasContext(){return t!==void 0},hasValidContext(){return this.hasContext()&&t.valid}}}var{isLegacyUser:Bn,isMultiKind:Kn,isSingleKind:Gn}=k,Ne=async(i,t,e)=>{let{anonymous:n,key:r}=t;if(n&&!r){let s=await Nn(i);t.key=await vi(s,e)}},Wn=async(i,t)=>{await Ne(i.kind,i,t)},_n=async(i,t)=>{let r=i,{kind:e}=r,n=Jt(r,["kind"]);return Promise.all(Object.entries(n).map(([s,a])=>Ne(s,a,t)))},Jn=async(i,t)=>{await Ne("user",i,t)},qn=async(i,t)=>{let e=ve(i);return Gn(e)&&await Wn(e,t),Kn(e)&&await _n(e,t),Bn(e)&&await Jn(e,t),e},Yn=i=>({customBaseURI:i.serviceEndpoints.polling!==pi,customStreamURI:i.serviceEndpoints.streaming!==mi,customEventsURI:i.serviceEndpoints.events!==U.DEFAULT_EVENTS,eventsCapacity:i.capacity,eventsFlushIntervalMillis:Nt(i.flushInterval),reconnectTimeMillis:Nt(i.streamInitialReconnectDelay),diagnosticRecordingIntervalMillis:Nt(i.diagnosticRecordingInterval),allAttributesPrivate:i.allAttributesPrivate,usingSecureMode:!1,bootstrapMode:!1}),Zn=(i,t,e)=>{if(t.sendEvents&&!t.diagnosticOptOut)return new k.DiagnosticsManager(i,e,Yn(t))};function ci(i,t){return{value:t!=null?t:null,variationIndex:null,reason:{kind:"ERROR",errorKind:i}}}function li(i,t,e){return{value:i,variationIndex:t!=null?t:null,reason:e!=null?e:null}}var Xn=(i,t,e,n,r)=>{if(t.sendEvents)return new k.EventProcessor(D(g({},t),{eventsCapacity:t.capacity}),new Lt(i,t,e),n,void 0,r,!1,!0)},Ut=class extends k.EventFactoryBase{evalEventClient(t,e,n,r,s,a){let{trackEvents:o,debugEventsUntilDate:c,trackReason:l,flagVersion:u,version:d,variation:f}=r;return super.evalEvent({addExperimentData:l,context:s,debugEventsUntilDate:c,defaultVal:n,flagKey:t,reason:a,trackEvents:!!o,value:e,variation:f,version:u!=null?u:d})}},X=class i{constructor(){this.container={index:new Array}}static fromJson(t){let e=new i;try{e.container=JSON.parse(t)}catch(n){}return e}toJson(){return JSON.stringify(this.container)}notice(t,e){let n=this.container.index.find(r=>r.id===t);n===void 0?this.container.index.push({id:t,timestamp:e}):n.timestamp=e}prune(t){let e=Math.max(t,0);return this.container.index.length>e?(this.container.index.sort((n,r)=>n.timestamp-r.timestamp),this.container.index.splice(0,this.container.index.length-e)):[]}},xe=class{constructor(t,e,n,r,s,a,o=()=>Date.now()){this.p=t,this.Ut=e,this.Hi=n,this.N=r,this.E=s,this.t=a,this.pt=o,this.Pe=Rn(this.Ut)}async init(t,e){this.E.init(t,e),await this.Ie(t)}async upsert(t,e,n){return this.E.upsert(t,e,n)?(await this.Ie(t),!0):!1}async loadCached(t){var r,s,a,o;let e=await ai(this.p.crypto,this.Ut,t),n=await((r=this.p.storage)==null?void 0:r.get(e));if(n==null){if(n=await((s=this.p.storage)==null?void 0:s.get(t.canonicalKey)),n==null)return!1;await((a=this.p.storage)==null?void 0:a.set(e,n)),await((o=this.p.storage)==null?void 0:o.clear(t.canonicalKey))}try{let c=JSON.parse(n),l=Object.entries(c).reduce((u,[d,f])=>(u[d]={version:f.version,flag:f},u),{});return this.E.initCached(t,l),this.t.debug("Loaded cached flag evaluations from persistent storage"),!0}catch(c){return this.t.warn(`Could not load cached flag evaluations from persistent storage: ${c.message}`),!1}}async Bi(){var e;if(this._!==void 0)return this._;let t=await((e=this.p.storage)==null?void 0:e.get(await this.Pe));if(!t)return this._=new X,this._;try{this._=X.fromJson(t),this.t.debug("Loaded context index from persistent storage")}catch(n){this.t.warn(`Could not load index from persistent storage: ${n.message}`),this._=new X}return this._}async Ie(t){var c,l;let e=await this.Bi(),n=await ai(this.p.crypto,this.Ut,t);e.notice(n,this.pt());let r=e.prune(this.Hi);await Promise.all(r.map(async u=>{var d;return(d=this.p.storage)==null?void 0:d.clear(u.id)})),await((c=this.p.storage)==null?void 0:c.set(await this.Pe,e.toJson()));let s=this.N.getAll(),a=Object.entries(s).reduce((u,[d,f])=>(f.flag!==null&&f.flag!==void 0&&(u[d]=f.flag),u),{}),o=JSON.stringify(a);await((l=this.p.storage)==null?void 0:l.set(n,o))}};function Qn(){let i={};return{init(t){i=Object.entries(t).reduce((e,[n,r])=>(e[n]=r,e),{})},insertOrUpdate(t,e){i[t]=e},get(t){if(Object.prototype.hasOwnProperty.call(i,t))return i[t]},getAll(){return i}}}function tr(i,t){let e=[];return Object.entries(i).forEach(([n,r])=>{let s=t[n];(!s||!G(r,s))&&e.push(n)}),Object.keys(t).forEach(n=>{i[n]||e.push(n)}),e}function er(i,t){let e=i,n=t,r,s=new Array;return{handleFlagChanges(a,o){r?s.forEach(c=>{try{c(r,a,o)}catch(l){}}):n.warn("Received a change event without an active context. Changes will not be propagated.")},init(a,o){r=a;let c=e.getAll();e.init(o);let l=tr(c,o);l.length>0&&this.handleFlagChanges(l,"init")},initCached(a,o){(r==null?void 0:r.canonicalKey)!==a.canonicalKey&&this.init(a,o)},upsert(a,o,c){if((r==null?void 0:r.canonicalKey)!==a.canonicalKey)return n.warn("Received an update for an inactive context."),!1;let l=e.get(o);return l!==void 0&&l.version>=c.version?!1:(e.insertOrUpdate(o,c),this.handleFlagChanges([o],"patch"),!0)},on(a){s.push(a)},off(a){let o=s.indexOf(a);o>-1&&s.splice(o,1)}}}var Le=class{constructor(t,e,n,r,s=()=>Date.now()){this.N=Qn(),this.E=er(this.N,r),this.Vt=this.Ki(t,e,n,r,s)}async Ki(t,e,n,r,s=()=>Date.now()){let a=await $n(t.crypto,e);return new xe(t,a,n,this.N,this.E,r,s)}get(t){return this.a&&Object.prototype.hasOwnProperty.call(this.a,t)?this.jt(this.a[t]):this.N.get(t)}getAll(){return this.a?g(g({},this.N.getAll()),Object.entries(this.a).reduce((t,[e,n])=>(t[e]=this.jt(n),t),{})):this.N.getAll()}presetFlags(t){this.N.init(t)}setBootstrap(t,e){this.E.init(t,e)}async init(t,e){return(await this.Vt).init(t,e)}async upsert(t,e,n){return(await this.Vt).upsert(t,e,n)}async loadCached(t){return(await this.Vt).loadCached(t)}on(t){this.E.on(t)}off(t){this.E.off(t)}jt(t){return{flag:{value:t,version:0},version:0}}setOverride(t,e){this.a||(this.a={}),this.a[t]=e,this.E.handleFlagChanges([t],"override")}removeOverride(t){!this.a||!Object.prototype.hasOwnProperty.call(this.a,t)||(delete this.a[t],Object.keys(this.a).length===0&&(this.a=void 0),this.E.handleFlagChanges([t],"override"))}clearAllOverrides(){if(this.a){let t=g({},this.a);this.a=void 0,this.E.handleFlagChanges(Object.keys(t),"override")}}getAllOverrides(){if(!this.a)return{};let t={};return Object.entries(this.a).forEach(([e,n])=>{t[e]=this.jt(n)}),t}getDebugOverride(){return{setOverride:this.setOverride.bind(this),removeOverride:this.removeOverride.bind(this),clearAllOverrides:this.clearAllOverrides.bind(this),getAllOverrides:this.getAllOverrides.bind(this)}}},ui="unknown hook",Di="beforeEvaluation",bi="afterEvaluation",ir="afterTrack";function tt(i,t,e,n,r){try{return n()}catch(s){return i==null||i.error(`An error was encountered in "${t}" of the "${e}" hook: ${s}`),r}}function et(i,t){try{return t.getMetadata().name||ui}catch(e){return i.error("Exception thrown getting metadata for hook. Unable to get hook name."),ui}}function nr(i,t,e){return t.map(n=>tt(i,Di,et(i,n),()=>{var r,s;return(s=(r=n==null?void 0:n.beforeEvaluation)==null?void 0:r.call(n,e,{}))!=null?s:{}},{}))}function rr(i,t,e,n,r){for(let s=t.length-1;s>=0;s-=1){let a=t[s],o=n[s];tt(i,bi,et(i,a),()=>{var c,l;return(l=(c=a==null?void 0:a.afterEvaluation)==null?void 0:c.call(a,e,o,r))!=null?l:{}},{})}}function sr(i,t,e){return t.map(n=>tt(i,Di,et(i,n),()=>{var r,s;return(s=(r=n==null?void 0:n.beforeIdentify)==null?void 0:r.call(n,e,{}))!=null?s:{}},{}))}function ar(i,t,e,n,r){for(let s=t.length-1;s>=0;s-=1){let a=t[s],o=n[s];tt(i,bi,et(i,a),()=>{var c,l;return(l=(c=a==null?void 0:a.afterIdentify)==null?void 0:c.call(a,e,o,r))!=null?l:{}},{})}}function or(i,t,e){for(let n=t.length-1;n>=0;n-=1){let r=t[n];tt(i,ir,et(i,r),()=>{var s;return(s=r==null?void 0:r.afterTrack)==null?void 0:s.call(r,e)},void 0)}}var Se=class{constructor(t,e){this.t=t,this.V=[],this.V.push(...e)}withEvaluation(t,e,n,r){if(this.V.length===0)return r();let s=[...this.V],a={flagKey:t,context:e,defaultValue:n},o=nr(this.t,s,a),c=r();return rr(this.t,s,a,o,c),c}identify(t,e){let n=[...this.V],r={context:t,timeout:e},s=sr(this.t,n,r);return a=>{ar(this.t,n,r,s,a)}}addHook(t){this.V.push(t)}afterTrack(t){if(this.V.length===0)return;let e=[...this.V];or(this.t,e,t)}};function cr(i){return{getMetadata(){return{name:"LaunchDarkly-Inspector-Adapter"}},afterEvaluation:(t,e,n)=>(i.onFlagUsed(t.flagKey,n,t.context),e),afterIdentify(t,e,n){return i.onIdentityChanged(t.context),e}}}function lr(i,t){return`an inspector: "${t}" of an invalid type (${i}) was configured`}function ur(i,t){return`an inspector: "${t}" of type: "${i}" generated an exception`}function hr(i,t){let e=!1,n={method:(...r)=>{try{i.method(...r)}catch(s){e||(e=!0,t.warn(ur(n.type,n.name)))}},type:i.type,name:i.name,synchronous:i.synchronous};return n}var ki="flag-used",xi="flag-details-changed",Li="flag-detail-changed",Si="client-identity-changed",dr=[ki,xi,Li,Si];function fr(i,t){let e=dr.includes(i.type)&&i.method&&typeof i.method=="function";return e||t.warn(lr(i.type,i.name)),e}var Ce=class{constructor(t,e){this.J=[];let n=t.filter(r=>fr(r,e));this.J=n.map(r=>hr(r,e))}hasInspectors(){return this.J.length!==0}onFlagUsed(t,e,n){this.J.forEach(r=>{r.type===ki&&r.method(t,e,n)})}onFlagsChanged(t){this.J.forEach(e=>{e.type===xi&&e.method(t)})}onFlagChanged(t,e){this.J.forEach(n=>{n.type===Li&&n.method(t,e)})}onIdentityChanged(t){this.J.forEach(e=>{e.type===Si&&e.method(t)})}},Pe=class{constructor(t){this.t=t,this.e=new Map}on(t,e){var n;this.e.has(t)?(n=this.e.get(t))==null||n.push(e):this.e.set(t,[e])}off(t,e){let n=this.e.get(t);if(n){if(e){let r=n.filter(s=>s!==e);r.length===0?this.e.delete(t):this.e.set(t,r);return}this.e.delete(t)}}zt(t,e,...n){var r;try{t(...n)}catch(s){(r=this.t)==null||r.error(`Encountered error invoking handler for "${e}", detail: "${s}"`)}}emit(t,...e){let n=this.e.get(t);n==null||n.forEach(r=>this.zt(r,t,...e))}eventNames(){return[...this.e.keys()]}listenerCount(t){var e,n;return(n=(e=this.e.get(t))==null?void 0:e.length)!=null?n:0}};function gr(i,t,e){let n=t.info.sdkData(),r;e.applicationInfo&&(e.applicationInfo.id&&(r=r!=null?r:{},r.id=e.applicationInfo.id),e.applicationInfo.version&&(r=r!=null?r:{},r.version=e.applicationInfo.version),e.applicationInfo.name&&(r=r!=null?r:{},r.name=e.applicationInfo.name),e.applicationInfo.versionName&&(r=r!=null?r:{},r.versionName=e.applicationInfo.versionName));let s={name:n.userAgentBase,version:n.version};n.wrapperName&&(s.wrapperName=n.wrapperName),n.wrapperVersion&&(s.wrapperVersion=n.wrapperVersion);let a={sdk:s,[e.credentialType]:i};return r&&(a.application=r),a}var{ClientMessages:hi,ErrorKinds:di}=k,pr=5,Vt=class{constructor(t,e,n,r,s,a){if(this.sdkKey=t,this.autoEnvAttributes=e,this.platform=n,this.l=Hn(),this.Ht=15,this.F=new Ut(!1),this.mt=new Ut(!0),this.Bt=!1,this.Gi=In(),!t)throw new Error("You must configure the client with a client-side SDK key");if(!n.encoding)throw new Error("Platform must implement Encoding because btoa is required.");this.r=new ke(r,a),this.logger=this.r.logger,this.Te=ri(this.sdkKey,this.platform.info,this.r.tags,this.r.serviceEndpoints.includeAuthorizationHeader,this.r.userAgentHeaderName),this.D=new Le(this.platform,t,this.r.maxCachedContexts,this.r.logger),this.C=Zn(t,this.r,n),this.b=Xn(t,this.r,n,this.Te,this.C),this.emitter=new Pe,this.emitter.on("error",(c,l)=>{this.logger.error(`error: ${l}, context: ${JSON.stringify(c)}`)}),this.D.on((c,l,u)=>{this.Wi(l,u);let d=S.toLDContext(c);this.emitter.emit("change",d,l),l.forEach(f=>{this.emitter.emit(`change:${f}`,d)})}),this.dataManager=s(this.D,this.r,this.Te,this.emitter,this.C);let o=[...this.r.hooks];if(this.environmentMetadata=gr(this.sdkKey,this.platform,this.r),this.r.getImplementationHooks(this.environmentMetadata).forEach(c=>{o.push(c)}),this.z=new Se(this.logger,o),this.et=new Ce(this.r.inspectors,this.logger),this.et.hasInspectors()&&this.z.addHook(cr(this.et)),r.cleanOldPersistentData&&(a!=null&&a.getLegacyStorageKeys)&&this.platform.storage)try{this.logger.debug("Cleaning old persistent data."),Promise.all(a.getLegacyStorageKeys().map(c=>{var l;return(l=this.platform.storage)==null?void 0:l.clear(c)})).catch(c=>{this.logger.error(`Error cleaning old persistent data: ${c}`)}).finally(()=>{this.logger.debug("Cleaned old persistent data.")})}catch(c){this.logger.error(`Error cleaning old persistent data: ${c}`)}}allFlags(){return Object.entries(this.D.getAll()).reduce((e,[n,r])=>(r.flag!==null&&r.flag!==void 0&&!r.flag.deleted&&(e[n]=r.flag.value),e),{})}async close(){var t;await this.flush(),(t=this.b)==null||t.close(),this.dataManager.close(),this.logger.debug("Closed event processor and data source.")}async flush(){var t;try{await((t=this.b)==null?void 0:t.flush()),this.logger.debug("Successfully flushed event processor.")}catch(e){return this.logger.error(`Error flushing event processor: ${e}.`),{error:e,result:!1}}return{result:!0}}getContext(){return this.l.hasContext()?ve(this.l.getUnwrappedContext()):void 0}getInternalContext(){return this.l.getContext()}presetFlags(t){this.D.presetFlags(t)}async identify(t,e){let n=await this.identifyResult(t,e);if(n.status==="error")throw n.error;if(n.status==="timeout"){let r=new I(`identify timed out after ${n.timeout} seconds.`);throw this.logger.error(r.message),r}}async identifyResult(t,e){var o,c;let n=(o=e==null?void 0:e.timeout)!=null?o:pr,r=(e==null?void 0:e.timeout)===void 0&&(e==null?void 0:e.noTimeout)===!0;n>this.Ht&&this.logger.warn(`The identify function was called with a timeout greater than ${this.Ht} seconds. We recommend a timeout of less than ${this.Ht} seconds.`);let s=this.Gi.execute({before:async()=>{let l=await qn(t,this.platform);this.autoEnvAttributes===z.Enabled&&(l=await zn(l,this.platform,this.r));let u=S.fromLDContext(l);if(u.valid){let d=this.z.identify(l,e==null?void 0:e.timeout);return{context:l,checkedContext:u,afterIdentify:d}}return{context:l,checkedContext:u}},execute:async l=>{var y;let{context:u,checkedContext:d}=l;if(!d.valid){let x=new Error("Context was unspecified or had no key");return this.emitter.emit("error",u,x),Promise.reject(x)}this.l.set(u,d),(y=this.b)==null||y.sendEvent(this.F.identifyEvent(d));let{identifyPromise:f,identifyResolve:m,identifyReject:p}=this.l.newIdentificationPromise();return this.logger.debug(`Identifying ${JSON.stringify(d)}`),await this.dataManager.identify(m,p,d,e),f},after:async(l,u)=>{var d,f,m;l.status==="complete"?(d=u==null?void 0:u.afterIdentify)==null||d.call(u,{status:"completed"}):l.status==="shed"?(f=u==null?void 0:u.afterIdentify)==null||f.call(u,{status:"shed"}):l.status==="error"&&((m=u==null?void 0:u.afterIdentify)==null||m.call(u,{status:"error"}))}},(c=e==null?void 0:e.sheddable)!=null?c:!1).then(l=>{if(l.status==="error"){let d={status:"error",error:l.error};return this.maybeSetInitializationResult({status:"failed",error:l.error}),d}if(l.status==="shed")return{status:"shed"};let u={status:"completed"};return this.maybeSetInitializationResult({status:"complete"}),u});if(r)return s;let a=new Promise(l=>{setTimeout(()=>{l({status:"timeout",timeout:n})},n*1e3)});return Promise.race([s,a])}maybeSetInitializationResult(t){this.initializeResult===void 0&&(this.initializeResult=t,this.emitter.emit("ready"),t.status==="complete"&&this.emitter.emit("initialized"),this.initResolve&&(this.initResolve(t),this.initResolve=void 0))}waitForInitialization(t){var n;let e=(n=t==null?void 0:t.timeout)!=null?n:5;return this.initializeResult?Promise.resolve(this.initializeResult):this.initializedPromise?this.promiseWithTimeout(this.initializedPromise,e):(this.initializedPromise||(this.initializedPromise=new Promise(r=>{this.initResolve=r})),this.promiseWithTimeout(this.initializedPromise,e))}promiseWithTimeout(t,e){let n=$t(e,"waitForInitialization");return Promise.race([t.then(r=>(n.cancel(),r)),n.promise.then(()=>({status:"complete"})).catch(()=>({status:"timeout"}))]).catch(r=>{var s;return(s=this.logger)==null||s.error(r.message),{status:"failed",error:r}})}on(t,e){this.emitter.on(t,e)}off(t,e){this.emitter.off(t,e)}track(t,e,n){var r,s;if(!this.l.hasValidContext()){this.logger.warn(hi.MissingContextKeyNoEvent);return}n!==void 0&&!h.Number.is(n)&&((r=this.logger)==null||r.warn(hi.invalidMetricValue(typeof n))),(s=this.b)==null||s.sendEvent(this.r.trackEventModifier(this.F.customEvent(t,this.l.getContext(),e,n))),this.z.afterTrack({key:t,context:this.l.getUnwrappedContext(),data:e,metricValue:n})}yt(t,e,n,r){var m,p,y,x;let s=this.l.hasContext();s||(m=this.logger)==null||m.warn("Flag evaluation called before client is fully initialized, data from this evaulation could be stale.");let a=this.l.getContext(),o=this.D.get(t);if(o===void 0||o.flag.deleted){let L=e!=null?e:null,K=new q(`Unknown feature flag "${t}"; returning default value ${L}.`);return this.emitter.emit("error",this.l.getUnwrappedContext(),K),s&&((p=this.b)==null||p.sendEvent(this.F.unknownFlagEvent(t,L,a))),ci(di.FlagNotFound,e)}let{reason:c,value:l,variation:u,prerequisites:d}=o.flag;if(r){let[L,K]=r(l);if(!L){s&&((y=this.b)==null||y.sendEvent(n.evalEventClient(t,e,e,o.flag,a,c)));let P=new q(`Wrong type "${K}" for feature flag "${t}"; returning default value`);return this.emitter.emit("error",this.l.getUnwrappedContext(),P),ci(di.WrongType,e)}}let f=li(l,u,c);return l==null&&(this.logger.debug("Result value is null. Providing default value."),f.value=e),d==null||d.forEach(L=>{this.yt(L,void 0,this.F)}),s&&((x=this.b)==null||x.sendEvent(n.evalEventClient(t,l,e,o.flag,a,c))),f}variation(t,e){let{value:n}=this.z.withEvaluation(t,this.l.getUnwrappedContext(),e,()=>this.yt(t,e,this.F));return n}variationDetail(t,e){return this.z.withEvaluation(t,this.l.getUnwrappedContext(),e,()=>this.yt(t,e,this.mt))}q(t,e,n,r){return this.z.withEvaluation(t,this.l.getUnwrappedContext(),e,()=>this.yt(t,e,n,r))}boolVariation(t,e){return this.q(t,e,this.F,n=>[h.Boolean.is(n),h.Boolean.getType()]).value}jsonVariation(t,e){return this.variation(t,e)}numberVariation(t,e){return this.q(t,e,this.F,n=>[h.Number.is(n),h.Number.getType()]).value}stringVariation(t,e){return this.q(t,e,this.F,n=>[h.String.is(n),h.String.getType()]).value}boolVariationDetail(t,e){return this.q(t,e,this.mt,n=>[h.Boolean.is(n),h.Boolean.getType()])}numberVariationDetail(t,e){return this.q(t,e,this.mt,n=>[h.Number.is(n),h.Number.getType()])}stringVariationDetail(t,e){return this.q(t,e,this.mt,n=>[h.String.is(n),h.String.getType()])}jsonVariationDetail(t,e){return this.variationDetail(t,e)}addHook(t){this.z.addHook(t)}setEventSendingEnabled(t,e){var n,r,s,a;this.Bt!==t&&(this.Bt=t,t?(this.logger.debug("Starting event processor"),(n=this.b)==null||n.start()):e?((r=this.logger)==null||r.debug("Flushing event processor before disabling."),this.flush().then(()=>{var o,c;this.Bt||((o=this.logger)==null||o.debug("Stopping event processor."),(c=this.b)==null||c.close())})):((s=this.logger)==null||s.debug("Stopping event processor."),(a=this.b)==null||a.close()))}sendEvent(t){var e;(e=this.b)==null||e.sendEvent(t)}getDebugOverrides(){var t,e;return(e=(t=this.D).getDebugOverride)==null?void 0:e.call(t)}Wi(t,e){if(!this.et.hasInspectors())return;let n={};t.forEach(r=>{let s=this.D.get(r);if(s!=null&&s.flag&&!s.flag.deleted){let{reason:a,value:o,variation:c}=s.flag;n[r]=li(o,c,a)}else n[r]={value:void 0,reason:null,variationIndex:null}}),e==="init"?this.et.onFlagsChanged(n):e==="patch"&&Object.entries(n).forEach(([r,s])=>{this.et.onFlagChanged(r,s)})}};function Ci(i,t,e){e.forEach(n=>{var r;try{(r=n.registerDebug)==null||r.call(n,t)}catch(s){i.error(`Exception thrown registering plugin ${k.safeGetName(i,n)}.`)}})}var Ie=class{constructor(t,e,n){this.D=t,this.Kt=e,this.t=n}async handlePut(t,e){this.t.debug(`Got PUT: ${Object.keys(e)}`);let n=Object.entries(e).reduce((r,[s,a])=>(r[s]={version:a.version,flag:a},r),{});await this.D.init(t,n),this.Kt.requestStateUpdate(E.Valid)}async handlePatch(t,e){this.t.debug(`Got PATCH ${JSON.stringify(e,null,2)}`),this.D.upsert(t,e.key,{version:e.version,flag:e})}async handleDelete(t,e){this.t.debug(`Got DELETE ${JSON.stringify(e,null,2)}`),this.D.upsert(t,e.key,{version:e.version,flag:D(g({},e),{deleted:!0,flagVersion:0,value:void 0,variation:0,trackEvents:!1})})}handleStreamingError(t){this.Kt.reportError(t.kind,t.message,t.code,t.recoverable)}handlePollingError(t){this.Kt.reportError(t.kind,t.message,t.status,t.recoverable)}},Te=class{constructor(t,e=()=>Date.now()){this.R=t,this.vt=E.Closed,this.Ae=e(),this.pt=e}get status(){return{state:this.vt,stateSince:this.Ae,lastError:this._i}}Oe(t,e=!1){let n=t===E.Interrupted&&this.vt===E.Initializing?E.Initializing:t,r=this.vt!==n;r&&(this.vt=n,this.Ae=this.pt()),(r||e)&&this.R.emit("dataSourceStatus",this.status)}requestStateUpdate(t){this.Oe(t)}reportError(t,e,n,r=!1){let s={kind:t,message:e,statusCode:n,time:this.pt()};this._i=s,this.Oe(r?E.Interrupted:E.Closed,!0)}};function fi(i){i==null||i.debug("Poll completed after the processor was closed. Skipping processing.")}var Ae=class{constructor(t,e,n,r,s){this.Ji=t,this.qi=e,this.Yi=n,this.y=r,this.t=s,this.h=!1}async $e(){var s,a,o,c,l,u,d;if(this.h)return;let t=f=>{var m,p,y;(m=this.t)==null||m.error("Polling received invalid data"),(p=this.t)==null||p.debug(`Invalid JSON follows: ${f}`),(y=this.y)==null||y.call(this,new R(w.InvalidData,"Malformed JSON data in polling response"))};(s=this.t)==null||s.debug("Polling LaunchDarkly for feature flag updates");let e=Date.now();try{let f=await this.Ji.requestPayload();try{if(this.h){fi(this.t);return}let m=JSON.parse(f);try{(a=this.Yi)==null||a.call(this,m)}catch(p){(o=this.t)==null||o.error(`Exception from data handler: ${p}`)}}catch(m){t(f)}}catch(f){if(this.h){fi(this.t);return}let m=f;if(m.status!==void 0&&!Z(m.status)){(c=this.t)==null||c.error($(f,"polling request")),(l=this.y)==null||l.call(this,new R(w.ErrorResponse,m.message,m.status));return}(u=this.t)==null||u.error($(f,"polling request","will retry"))}let n=Date.now()-e,r=Math.max(this.qi*1e3-n,0);(d=this.t)==null||d.debug("Elapsed: %d ms, sleeping for %d ms",n,r),this.Gt=setTimeout(()=>{this.$e()},r)}start(){this.$e()}stop(){this.Gt&&(clearTimeout(this.Gt),this.Gt=void 0),this.h=!0}close(){this.stop()}},mr=(i,t,e,n)=>{e==null||e.error(`Stream received invalid data in "${i}" message`),e==null||e.debug(`Invalid JSON follows: ${t}`),n==null||n(new j(w.InvalidData,"Malformed JSON data in event stream"))};function yr(i,t){t==null||t.debug(`Received ${i} event after processor was closed. Skipping processing.`)}function gi(i){i==null||i.debug("Ping completed after processor was closed. Skipping processing.")}var Oe=class{constructor(t,e,n,r,s,a,o,c,l){var f;this.Zi=t,this.Wt=e,this.e=n,this.$=r,this.Xi=a,this.C=o,this.y=c,this.t=l,this.h=!1;let u;e.useReport&&!r.getEventSourceCapabilities().customMethod?u=e.paths.pathPing(s,t):u=e.useReport?e.paths.pathReport(s,t):e.paths.pathGet(s,t);let d=[...(f=e.queryParameters)!=null?f:[]];this.Wt.withReasons&&d.push({key:"withReasons",value:"true"}),this.$=r,this.gt=g({},e.baseHeaders),this.t=l,this.Qi=ii(e.serviceEndpoints,u,d)}Ne(){this.wt=Date.now()}_t(t){this.wt&&this.C&&this.C.recordStreamInit(this.wt,!t,Date.now()-this.wt),this.wt=void 0}tn(t){var e,n,r;return Rt(t)?((r=this.t)==null||r.warn($(t,"streaming request","will retry")),this._t(!1),this.Ne(),!0):(this._t(!1),(e=this.y)==null||e.call(this,new j(w.ErrorResponse,t.message,t.status,!1)),(n=this.t)==null||n.error($(t,"streaming request")),!1)}start(){this.Ne();let t;this.Wt.useReport?(this.gt["content-type"]="application/json",t={method:"REPORT",body:this.Zi}):t={};let e=this.$.createEventSource(this.Qi,D(g({headers:this.gt},t),{errorFilter:n=>this.tn(n),initialRetryDelayMillis:this.Wt.initialRetryDelayMillis,readTimeoutMillis:300*1e3,retryResetIntervalMillis:60*1e3}));this.Fe=e,e.onclose=()=>{var n;(n=this.t)==null||n.info("Closed LaunchDarkly stream connection")},e.onerror=()=>{},e.onopen=()=>{var n;(n=this.t)==null||n.info("Opened LaunchDarkly stream connection")},e.onretrying=n=>{var r;(r=this.t)==null||r.info(`Will retry stream connection in ${n.delayMillis} milliseconds`)},this.e.forEach(({deserializeData:n,processJson:r},s)=>{e.addEventListener(s,a=>{var o,c;if(this.h){yr(s,this.t);return}if((o=this.t)==null||o.debug(`Received ${s} event`),a!=null&&a.data){this._t(!0);let{data:l}=a,u=n(l);if(!u){mr(s,l,this.t,this.y);return}r(u)}else(c=this.y)==null||c.call(this,new j(w.InvalidData,"Unexpected payload from event stream"))})}),e.addEventListener("ping",async()=>{var n,r,s,a,o,c,l;(n=this.t)==null||n.debug("Got PING, going to poll LaunchDarkly for feature flag updates");try{let u=await this.Xi.requestPayload();try{if(this.h){gi(this.t);return}let d=JSON.parse(u);try{(r=this.e.get("put"))==null||r.processJson(d)}catch(f){(s=this.t)==null||s.error(`Exception from data handler: ${f}`)}}catch(d){(a=this.t)==null||a.error("Polling after ping received invalid data"),(o=this.t)==null||o.debug(`Invalid JSON follows: ${u}`),(c=this.y)==null||c.call(this,new R(w.InvalidData,"Malformed JSON data in ping polling response"))}}catch(u){if(this.h){gi(this.t);return}let d=u;(l=this.y)==null||l.call(this,new R(w.ErrorResponse,d.message,d.status))}})}stop(){var t;(t=this.Fe)==null||t.close(),this.Fe=void 0,this.h=!0}close(){this.stop()}},jt=class{constructor(t,e,n,r,s,a,o,c,l){this.platform=t,this.flagManager=e,this.credential=n,this.config=r,this.getPollingPaths=s,this.getStreamingPaths=a,this.baseHeaders=o,this.emitter=c,this.diagnosticsManager=l,this.closed=!1,this.logger=r.logger,this.dataSourceStatusManager=new Te(c),this.Y=new Ie(e,this.dataSourceStatusManager,this.config.logger)}setConnectionParams(t){this.en=t}createPollingProcessor(t,e,n,r,s){let a=new Ae(n,this.config.pollInterval,async o=>{await this.Y.handlePut(e,o),r==null||r()},o=>{this.emitter.emit("error",t,o),this.Y.handlePollingError(o),s==null||s(o)},this.logger);this.updateProcessor=this.Re(a,this.dataSourceStatusManager)}createStreamingProcessor(t,e,n,r,s){var o;let a=new Oe(JSON.stringify(t),{credential:this.credential,serviceEndpoints:this.config.serviceEndpoints,paths:this.getStreamingPaths(),baseHeaders:this.baseHeaders,initialRetryDelayMillis:this.config.streamInitialReconnectDelay*1e3,withReasons:this.config.withReasons,useReport:this.config.useReport,queryParameters:(o=this.en)==null?void 0:o.queryParameters},this.createStreamListeners(e,r),this.platform.requests,this.platform.encoding,n,this.diagnosticsManager,c=>{this.emitter.emit("error",t,c),this.Y.handleStreamingError(c),s==null||s(c)},this.logger);this.updateProcessor=this.Re(a,this.dataSourceStatusManager)}createStreamListeners(t,e){let n=new Map;return n.set("put",{deserializeData:JSON.parse,processJson:async r=>{await this.Y.handlePut(t,r),e==null||e()}}),n.set("patch",{deserializeData:JSON.parse,processJson:async r=>{this.Y.handlePatch(t,r)}}),n.set("delete",{deserializeData:JSON.parse,processJson:async r=>{this.Y.handleDelete(t,r)}}),n}Re(t,e){return{start:()=>{e.requestStateUpdate(E.Initializing),t.start()},stop:()=>{t.stop(),e.requestStateUpdate(E.Closed)},close:()=>{t.close(),e.requestStateUpdate(E.Closed)}}}close(){var t;(t=this.updateProcessor)==null||t.close(),this.closed=!0}};function zt(i,t){let e=Object.keys(t),n="$flagsState",r="$valid",s=t[n];!s&&e.length&&i.warn("LaunchDarkly client was initialized with bootstrap data that did not include flag metadata. Events may not be sent correctly."),t[r]===!1&&i.warn("LaunchDarkly bootstrap data is not available because the back end could not read the flags.");let a={};return e.forEach(o=>{if(o!==n&&o!==r){let c;s&&s[o]?c=g({value:t[o]},s[o]):c={value:t[o],version:0},a[o]={version:c.version,flag:c}}}),a}function Ht(){return typeof document!==void 0}function Fe(){return typeof window!==void 0}function Bt(i,t,e){return Ht()?(document.addEventListener(i,t,e),()=>{document.removeEventListener(i,t,e)}):()=>{}}function Kt(i,t,e){return Ht()?(window.addEventListener(i,t,e),()=>{window.removeEventListener(i,t,e)}):()=>{}}function T(){return Fe()?window.location.href:""}function Pi(){return Fe()?window.location.search:""}function Ii(){return Fe()?window.location.hash:""}function Ti(){if(typeof crypto!==void 0)return crypto;throw Error("Access to a web crypto API is required")}function Ai(){return Ht()?document.visibilityState:"visibile"}function Oi(i){if(Ht())return document.querySelectorAll(i)}var vr="[BrowserDataManager]",it=class extends jt{constructor(e,n,r,s,a,o,c,l,u,d){super(e,n,r,s,o,c,l,u,d);this.yn=a;this.it=void 0;this.Jt=!1;this.it=a.streaming}P(e,...n){this.logger.debug(`${vr} ${e}`,...n)}async identify(e,n,r,s){if(this.closed){this.P("Identify called after data manager was closed.");return}this.context=r;let a=s;a!=null&&a.hash?this.setConnectionParams({queryParameters:[{key:"h",value:a.hash}]}):this.setConnectionParams(),this.qt=a==null?void 0:a.hash,a!=null&&a.bootstrap?this.nn(r,a.bootstrap,e):(await this.flagManager.loadCached(r)&&this.P("Identify - Flags loaded from cache. Continuing to initialize via a poll."),await this.rn(r,e,n)),this.Yt()}async sn(e){let n=JSON.stringify(S.toLDContext(e)),r=$e(n,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.qt),s=3,a;for(let o=0;o<=s;o+=1)try{return await r.requestPayload()}catch(c){if(!Rt(c))throw c;a=c,o<s&&(this.P($(c,"initial poll request","will retry")),await Ee(1e3))}throw a}async rn(e,n,r){var s,a;try{this.dataSourceStatusManager.requestStateUpdate(E.Initializing);let o=await this.sn(e);try{let l=this.createStreamListeners(e,n).get("put");l.processJson(l.deserializeData(o))}catch(c){this.dataSourceStatusManager.reportError(w.InvalidData,(s=c.message)!=null?s:"Could not parse poll response")}}catch(o){this.dataSourceStatusManager.reportError(w.NetworkError,(a=o.message)!=null?a:"unexpected network error",o.status),r(o)}}nn(e,n,r){this.flagManager.setBootstrap(e,zt(this.logger,n)),this.P("Identify - Initialization completed from bootstrap"),r()}setForcedStreaming(e){this.it=e,this.Yt()}setAutomaticStreamingState(e){this.Jt=e,this.Yt()}Yt(){let e=this.it||this.Jt&&this.it===void 0;this.P(`Updating streaming state. forced(${this.it}) automatic(${this.Jt})`),e?this.an():this.cn()}cn(){var e;this.updateProcessor&&this.P("Stopping update processor."),(e=this.updateProcessor)==null||e.close(),this.updateProcessor=void 0}an(){if(this.updateProcessor){this.P("Update processor already active. Not changing state.");return}if(!this.context){this.P("Context not set, not starting update processor.");return}this.P("Starting update processor."),this.ln(this.context)}ln(e,n,r){var c;let s=S.toLDContext(e);(c=this.updateProcessor)==null||c.close();let a=JSON.stringify(S.toLDContext(e)),o=$e(a,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.qt);this.createStreamingProcessor(s,e,o,n,r),this.updateProcessor.start()}};function $i(i){let e=Bt("visibilitychange",()=>{Ai()==="hidden"&&i()}),n=Kt("pagehide",i);return()=>{e(),n()}}function nt(i){if(typeof i!="string")throw new TypeError("Expected a string");return i.replace(/[|\\{}()[\]^$+*?.]/g,"\\$&").replace(/-/g,"\\x2d")}function wr(i,t,e,n){let s=((i.kind==="substring"||i.kind==="regex")&&n.includes("/")?t:t.replace(n,"")).replace(e,"");switch(i.kind){case"exact":return new RegExp(`^${nt(i.url)}/?$`).test(t);case"canonical":return new RegExp(`^${nt(i.url)}/?$`).test(s);case"substring":return new RegExp(`.*${nt(i.substring)}.*$`).test(s);case"regex":return new RegExp(i.pattern).test(s);default:return!1}}function Er(i,t){let e=[];return t.forEach(n=>{let r=i.target,{selector:s}=n,a=Oi(s);for(;r&&(a!=null&&a.length);){for(let o=0;o<a.length;o+=1)if(r===a[o]){e.push(n);break}r=r.parentNode}}),e}var rt=class{constructor(t,e){let n=t.filter(a=>{var o;return(o=a.urls)==null?void 0:o.some(c=>wr(c,T(),Pi(),Ii()))}),r=n.filter(a=>a.kind==="pageview"),s=n.filter(a=>a.kind==="click");if(r.forEach(a=>e(a)),s.length){let a=o=>{Er(o,s).forEach(c=>{e(c)})};this.Me=Bt("click",a)}}close(){var t;(t=this.Me)==null||t.call(this)}};var Dr=300,Gt=class{constructor(t){this.Zt=T();let e=()=>{let r=T();r!==this.Zt&&(this.Zt=r,t())};this.Xt=setInterval(e,Dr);let n=Kt("popstate",e);this.Ue=()=>{n()}}close(){var t;this.Xt&&clearInterval(this.Xt),(t=this.Ue)==null||t.call(this)}};var st=class{constructor(t,e,n,r,s,a=o=>new Gt(o)){this.$=e;this.dn=r;this.hn=s;this.Et=[];this.je=!1;this.Dt=`${n}/sdk/goals/${t}`,this.Ve=a(()=>{this.te()})}async initialize(){await this.un(),this.te()}startTracking(){this.je=!0,this.te()}te(){var t;this.je&&((t=this.Qt)==null||t.close(),this.Et&&this.Et.length&&(this.Qt=new rt(this.Et,e=>{this.hn(T(),e)})))}async un(){try{let t=await this.$.fetch(this.Dt);this.Et=await t.json()}catch(t){this.dn(new J(`Encountered error fetching goals: ${t}`))}}close(){var t,e;(t=this.Ve)==null||t.close(),(e=this.Qt)==null||e.close()}};function Ni(i){return i.kind==="click"}var br=2,Fi={fetchGoals:!0,eventUrlTransformer:i=>i,streaming:void 0,plugins:[]},kr={fetchGoals:h.Boolean,eventUrlTransformer:h.Function,streaming:h.Boolean,plugins:h.createTypeArray("LDPlugin",{})};function xr(i){var e;let t=g({},i);return(e=t.flushInterval)!=null||(t.flushInterval=br),t}function Ri(i){let t=xr(i);return Object.keys(Fi).forEach(e=>{delete t[e]}),t}function Re(i,t){let e=g({},Fi);return Object.entries(kr).forEach(n=>{let[r,s]=n,a=i[r];a!==void 0&&(s.is(a)?e[r]=a:t.warn(b.wrongOptionType(r,s.getType(),typeof a)))}),e}var at=class{constructor(t,e){this.fn=t;this.ze=[];switch(e){case"sha1":this.ee="SHA-1";break;case"sha256":this.ee="SHA-256";break;default:throw new Error(`Algorithm is not supported ${e}`)}}async asyncDigest(t){let e=this.ze.join(""),n=new TextEncoder().encode(e),r=await this.fn.subtle.digest(this.ee,n);switch(t){case"base64":return btoa(String.fromCharCode(...new Uint8Array(r)));case"hex":return[...new Uint8Array(r)].map(s=>s.toString(16).padStart(2,"0")).join("");default:throw new Error(`Encoding is not supported ${t}`)}}update(t){return this.ze.push(t),this}};var Lr={start:0,end:3},Sr={start:4,end:5},Me={start:6,end:7},Ue={start:8,end:8},Cr={start:9,end:9},Pr={start:10,end:15};function Ir(){if(crypto&&crypto.getRandomValues){let t=new Uint8Array(16);return crypto.getRandomValues(t),[...t.values()]}let i=[];for(let t=0;t<16;t+=1)i.push(Math.floor(Math.random()*256));return i}function B(i,t){let e="";for(let n=t.start;n<=t.end;n+=1)e+=i[n].toString(16).padStart(2,"0");return e}function Tr(i){return i[Ue.start]=(i[Ue.start]|128)&191,i[Me.start]=i[Me.start]&15|64,`${B(i,Lr)}-${B(i,Sr)}-${B(i,Me)}-${B(i,Ue)}${B(i,Cr)}-${B(i,Pr)}`}function Ar(){let i=Ir();return Tr(i)}function Ve(){return typeof crypto!==void 0&&typeof crypto.randomUUID=="function"?crypto.randomUUID():Ar()}var ot=class{createHash(t){return new at(Ti(),t)}randomUUID(){return Ve()}};function Or(i){let t=Array.from(i,e=>String.fromCodePoint(e)).join("");return btoa(t)}var ct=class{btoa(t){return Or(new TextEncoder().encode(t))}};var lt=class{constructor(t){this.r=t}platformData(){return{name:"JS"}}sdkData(){let t={name:"@launchdarkly/js-client-sdk",version:"0.12.0",userAgentBase:"JSClient"};return this.r.wrapperName&&(t.wrapperName=this.r.wrapperName),this.r.wrapperVersion&&(t.wrapperVersion=this.r.wrapperVersion),t}};var ut=class{constructor(t,e){this.Dt=t;this.e={};this.T=new kt(e.initialRetryDelayMillis,e.retryResetIntervalMillis),this.He=e.errorFilter,this.Be()}Be(){this.Z=new EventSource(this.Dt),this.Z.onopen=()=>{var t;this.T.success(),(t=this.onopen)==null||t.call(this)},this.Z.onerror=t=>{var e;this.gn(t),(e=this.onerror)==null||e.call(this,t)},Object.entries(this.e).forEach(([t,e])=>{e.forEach(n=>{var r;(r=this.Z)==null||r.addEventListener(t,n)})})}addEventListener(t,e){var n,r,s;(r=(n=this.e)[t])!=null||(n[t]=[]),this.e[t].push(e),(s=this.Z)==null||s.addEventListener(t,e)}close(){var t,e;clearTimeout(this.ie),this.ie=void 0,(t=this.Z)==null||t.close(),(e=this.onclose)==null||e.call(this)}pn(t){var e;(e=this.onretrying)==null||e.call(this,{delayMillis:t}),this.ie=setTimeout(()=>{this.Be()},t)}gn(t){this.close(),!(t.status&&typeof t.status=="number"&&!this.He(t))&&this.pn(this.T.fail())}};var ht=class{fetch(t,e){return fetch(t,e)}createEventSource(t,e){return new ut(t,e)}getEventSourceCapabilities(){return{customMethod:!1,readTimeout:!1,headers:!1}}};function je(){return typeof localStorage!="undefined"}function Mi(){if(!je())return[];let i=[];for(let t=0;t<localStorage.length;t+=1){let e=localStorage.key(t);e&&i.push(e)}return i}var dt=class{constructor(t){this.t=t}async clear(t){var e;try{localStorage.removeItem(t)}catch(n){(e=this.t)==null||e.error(`Error clearing key from localStorage: ${t}, reason: ${n}`)}}async get(t){var e;try{let n=localStorage.getItem(t);return n!=null?n:null}catch(n){return(e=this.t)==null||e.error(`Error getting key from localStorage: ${t}, reason: ${n}`),null}}async set(t,e){var n;try{localStorage.setItem(t,e)}catch(r){(n=this.t)==null||n.error(`Error setting key in localStorage: ${t}, reason: ${r}`)}}};var ft=class{constructor(t,e){this.encoding=new ct;this.crypto=new ot;this.requests=new ht;je()&&(this.storage=new dt(t)),this.info=new lt(e)}};var ze=class extends Vt{constructor(t,e,n={},r){var m;let{logger:s,debug:a}=n,o=s!=null?s:new M({destination:{debug:console.debug,info:console.info,warn:console.warn,error:console.error},level:a?"debug":"info"}),c=(m=n.baseUri)!=null?m:"https://clientsdk.launchdarkly.com",l=r!=null?r:new ft(o,n),u=Re(n,o),d=Ri(D(g({},n),{logger:o})),{eventUrlTransformer:f}=u;super(t,e,l,d,(p,y,x,L,K)=>new it(l,p,t,y,u,()=>({pathGet(P,N){return`/sdk/evalx/${t}/contexts/${we(N,P)}`},pathReport(P,N){return`/sdk/evalx/${t}/context`},pathPing(P,N){throw new Error("Ping for polling unsupported.")}}),()=>({pathGet(P,N){return`/eval/${t}/${we(N,P)}`},pathReport(P,N){return`/eval/${t}`},pathPing(P,N){return`/ping/${t}`}}),x,L,K),{getLegacyStorageKeys:()=>Mi().filter(p=>p.startsWith(`ld:${t}:`)),analyticsEventPath:`/events/bulk/${t}`,diagnosticEventPath:`/events/diagnostic/${t}`,includeAuthorizationHeader:!1,highTimeoutThreshold:5,userAgentHeaderName:"x-launchdarkly-user-agent",trackEventModifier:p=>new k.InputCustomEvent(p.context,p.key,p.data,p.metricValue,p.samplingRatio,f(T())),getImplementationHooks:p=>k.safeGetHooks(o,p,u.plugins),credentialType:"clientSideId"}),this.setEventSendingEnabled(!0,!1),this.re=u.plugins,u.fetchGoals&&(this.ne=new st(t,l.requests,c,p=>{o.error(p.message)},(p,y)=>{let x=this.getInternalContext();if(!x)return;let L=f(p);Ni(y)?this.sendEvent({kind:"click",url:L,samplingRatio:1,key:y.key,creationDate:Date.now(),context:x,selector:y.selector}):this.sendEvent({kind:"pageview",url:L,samplingRatio:1,key:y.key,creationDate:Date.now(),context:x})}),this.ne.initialize(),u.automaticBackgroundHandling&&$i(()=>this.flush()))}registerPlugins(t){k.safeRegisterPlugins(this.logger,this.environmentMetadata,t,this.re||[]);let e=this.getDebugOverrides();e&&Ci(this.logger,e,this.re||[])}setInitialContext(t){this.se=t}async identify(t,e){return super.identify(t,e)}async identifyResult(t,e){var s;if(!this.nt)return this.logger.error("Client must be started before it can identify a context, did you forget to call start()?"),{status:"error",error:new Error("Identify called before start")};let n=g({},e);(e==null?void 0:e.sheddable)===void 0&&(n.sheddable=!0);let r=await super.identifyResult(t,n);return(s=this.ne)==null||s.startTracking(),r}start(t){var n,r;if(this.initializeResult)return Promise.resolve(this.initializeResult);if(this.nt)return this.nt;if(!this.se)return this.logger.error("Initial context not set"),Promise.resolve({status:"failed",error:new Error("Initial context not set")});let e=D(g({},(n=t==null?void 0:t.identifyOptions)!=null?n:{}),{sheddable:!1});if(t!=null&&t.bootstrap&&!e.bootstrap&&(e.bootstrap=t.bootstrap),e!=null&&e.bootstrap)try{let s=zt(this.logger,e.bootstrap);this.presetFlags(s)}catch(s){this.logger.error("Failed to bootstrap data",s)}return this.initializedPromise||(this.initializedPromise=new Promise(s=>{this.initResolve=s})),this.nt=this.promiseWithTimeout(this.initializedPromise,(r=t==null?void 0:t.timeout)!=null?r:5),this.identifyResult(this.se,e),this.nt}setStreaming(t){this.dataManager.setForcedStreaming(t)}Ke(){this.dataManager.setAutomaticStreamingState(!!this.emitter.listenerCount("change"))}on(t,e){super.on(t,e),this.Ke()}off(t,e){super.off(t,e),this.Ke()}};function Ui(i,t,e,n={},r){let s=new ze(i,e,n,r);s.setInitialContext(t);let a={variation:(o,c)=>s.variation(o,c),variationDetail:(o,c)=>s.variationDetail(o,c),boolVariation:(o,c)=>s.boolVariation(o,c),boolVariationDetail:(o,c)=>s.boolVariationDetail(o,c),numberVariation:(o,c)=>s.numberVariation(o,c),numberVariationDetail:(o,c)=>s.numberVariationDetail(o,c),stringVariation:(o,c)=>s.stringVariation(o,c),stringVariationDetail:(o,c)=>s.stringVariationDetail(o,c),jsonVariation:(o,c)=>s.jsonVariation(o,c),jsonVariationDetail:(o,c)=>s.jsonVariationDetail(o,c),track:(o,c,l)=>s.track(o,c,l),on:(o,c)=>s.on(o,c),off:(o,c)=>s.off(o,c),flush:()=>s.flush(),setStreaming:o=>s.setStreaming(o),identify:(o,c)=>s.identifyResult(o,c),getContext:()=>s.getContext(),close:()=>s.close(),allFlags:()=>s.allFlags(),addHook:o=>s.addHook(o),waitForInitialization:o=>s.waitForInitialization(o),logger:s.logger,start:o=>s.start(o)};return s.registerPlugins(a),a}var Vi=["ready","failed","initialized"],gt=class{constructor(t){this.n=t;this.e=new Map}on(t,e){var n;Vi.includes(t)?this.e.has(t)?(n=this.e.get(t))==null||n.push(e):this.e.set(t,[e]):this.n.on(t,e)}off(t,e){if(Vi.includes(t)){let n=this.e.get(t);if(!n)return;if(e){let r=n.filter(s=>s!==e);r.length===0?this.e.delete(t):this.e.set(t,r);return}this.e.delete(t)}else this.n.off(t,e)}zt(t,e,...n){try{t(...n)}catch(r){this.n.logger.error(`Encountered error invoking handler for "${e}", detail: "${r}"`)}}emit(t,...e){let n=this.e.get(t);n==null||n.forEach(r=>this.zt(r,t,...e))}eventNames(){return[...this.e.keys()]}listenerCount(t){var e,n;return(n=(e=this.e.get(t))==null?void 0:e.length)!=null?n:0}};function Wt(i,t){let e=i.then(n=>(t&&setTimeout(()=>{t(null,n)},0),n),n=>{if(t)setTimeout(()=>{t(n,null)},0);else return Promise.reject(n)});return t?void 0:e}var pt=class{constructor(t,e,n){this.ae="initializing";let r=n==null?void 0:n.bootstrap,s=n==null?void 0:n.hash,a=g({},n);delete a.bootstrap,delete a.hash,this.n=Ui(t,e,z.Disabled,n),this.R=new gt(this.n),this.logger=this.n.logger,this.n.start(),this.mn(e,r,s)}async mn(t,e,n){var r,s;try{let a=await this.n.identify(t,{noTimeout:!0,bootstrap:e,hash:n,sheddable:!1});if(a.status==="error")throw a.error;if(a.status==="timeout")throw new I("Identify timed out");this.ae="success",(r=this.Ge)==null||r.call(this),this.R.emit("initialized")}catch(a){this._e=a,this.ae="failure",(s=this.We)==null||s.call(this,a),this.R.emit("failed",a)}this.R.emit("ready")}allFlags(){return this.n.allFlags()}boolVariation(t,e){return this.n.boolVariation(t,e)}boolVariationDetail(t,e){return this.n.boolVariationDetail(t,e)}jsonVariation(t,e){return this.n.jsonVariation(t,e)}jsonVariationDetail(t,e){return this.n.jsonVariationDetail(t,e)}numberVariation(t,e){return this.n.numberVariation(t,e)}numberVariationDetail(t,e){return this.n.numberVariationDetail(t,e)}off(t,e){this.R.off(t,e)}on(t,e){this.R.on(t,e)}stringVariation(t,e){return this.n.stringVariation(t,e)}stringVariationDetail(t,e){return this.n.stringVariationDetail(t,e)}track(t,e,n){this.n.track(t,e,n)}variation(t,e){return this.n.variation(t,e)}variationDetail(t,e){return this.n.variationDetail(t,e)}addHook(t){this.n.addHook(t)}setStreaming(t){this.n.setStreaming(t)}identify(t,e,n){return Wt(this.n.identify(t,{hash:e,sheddable:!1}).then(r=>{if(r.status==="error")throw r.error;if(r.status==="timeout")throw new I("Identify timed out");return this.allFlags()}),n)}close(t){return Wt(this.n.close().then(),t)}flush(t){return Wt(this.n.flush().then(()=>{}),t)}getContext(){return this.n.getContext()}waitForInitialization(t){var e;if(this.rt)return this.Je(this.rt,t);switch(this.ae){case"success":return Promise.resolve();case"failure":return Promise.reject(this._e);case"initializing":break;default:throw new Error("Unexpected initialization state. This represents an implementation error in the SDK.")}return t===void 0&&((e=this.logger)==null||e.warn("The waitForInitialization function was called without a timeout specified. In a future version a default timeout will be applied.")),this.rt||(this.rt=new Promise((n,r)=>{this.Ge=n,this.We=r})),this.Je(this.rt,t)}async waitUntilReady(){try{await this.waitForInitialization()}catch(t){}}Je(t,e){if(e){let n=$t(e,"waitForInitialization");return Promise.race([t.then(()=>n.cancel()),n.promise]).catch(r=>{var s;throw r instanceof I&&((s=this.logger)==null||s.error(r.message)),r})}return t}};function $r(i){return new M(i)}function Nr(i,t,e){return new pt(i,t,e)}0&&(module.exports={basicLogger,initialize});
|
|
2
2
|
//# sourceMappingURL=compat.cjs.map
|