@launchdarkly/js-client-sdk 0.9.1 → 0.11.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 +32 -0
- package/dist/{common-Cn2MjelZ.d.cts → common-ekJnfmSx.d.cts} +103 -0
- package/dist/{common-Cn2MjelZ.d.ts → common-ekJnfmSx.d.ts} +103 -0
- 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/dist/compat.d.cts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { LDContext, LDFlagSet } from '@launchdarkly/js-client-sdk-common';
|
|
2
|
-
export { AutoEnvAttributes, BasicLogger, BasicLoggerOptions, EvaluationSeriesContext, EvaluationSeriesData, Hook, HookMetadata, IdentifySeriesContext, IdentifySeriesData, IdentifySeriesResult, IdentifySeriesStatus, LDContext, LDContextCommon, LDContextMeta, LDEvaluationDetail, LDEvaluationDetailTyped, LDEvaluationReason, LDFlagSet, LDFlagValue, LDIdentifyError, LDIdentifyResult, LDIdentifyShed, LDIdentifySuccess, LDIdentifyTimeout, LDInspection, LDLogLevel, LDLogger, LDMultiKindContext, LDPluginApplicationMetadata, LDPluginBase, LDPluginEnvironmentMetadata, LDPluginMetadata, LDPluginSdkMetadata, LDSingleKindContext, LDTimeoutError, TrackSeriesContext } from '@launchdarkly/js-client-sdk-common';
|
|
3
|
-
import { L as LDClient$1, B as BrowserOptions } from './common-
|
|
4
|
-
export { b as LDIdentifyOptions, c as basicLogger } from './common-
|
|
2
|
+
export { AutoEnvAttributes, BasicLogger, BasicLoggerOptions, EvaluationSeriesContext, EvaluationSeriesData, Hook, HookMetadata, IdentifySeriesContext, IdentifySeriesData, IdentifySeriesResult, IdentifySeriesStatus, LDContext, LDContextCommon, LDContextMeta, LDDebugOverride, LDEvaluationDetail, LDEvaluationDetailTyped, LDEvaluationReason, LDFlagSet, LDFlagValue, LDIdentifyError, LDIdentifyResult, LDIdentifyShed, LDIdentifySuccess, LDIdentifyTimeout, LDInspection, LDLogLevel, LDLogger, LDMultiKindContext, LDPluginApplicationMetadata, LDPluginBase, LDPluginEnvironmentMetadata, LDPluginMetadata, LDPluginSdkMetadata, LDSingleKindContext, LDTimeoutError, TrackSeriesContext } from '@launchdarkly/js-client-sdk-common';
|
|
3
|
+
import { L as LDClient$1, B as BrowserOptions } from './common-ekJnfmSx.cjs';
|
|
4
|
+
export { b as LDIdentifyOptions, c as basicLogger } from './common-ekJnfmSx.cjs';
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* Compatibility interface. This interface extends the base LDCLient interface with functions
|
|
@@ -13,7 +13,7 @@ export { b as LDIdentifyOptions, c as basicLogger } from './common-Cn2MjelZ.cjs'
|
|
|
13
13
|
* incorrect. Any function which optionally returned a promise based on a callback had incorrect
|
|
14
14
|
* typings. Those have been corrected in this implementation.
|
|
15
15
|
*/
|
|
16
|
-
interface LDClient extends Omit<LDClient$1, 'close' | 'flush' | 'identify' | 'identifyResult'> {
|
|
16
|
+
interface LDClient extends Omit<LDClient$1, 'close' | 'flush' | 'identify' | 'identifyResult' | 'waitForInitialization' | 'setInitialContext' | 'start'> {
|
|
17
17
|
/**
|
|
18
18
|
* Identifies a context to LaunchDarkly.
|
|
19
19
|
*
|
|
@@ -159,7 +159,7 @@ interface LDOptions extends BrowserOptions {
|
|
|
159
159
|
|
|
160
160
|
/**
|
|
161
161
|
* Creates an instance of the LaunchDarkly client. This version of initialization is for
|
|
162
|
-
* improved backwards compatibility. In general the `
|
|
162
|
+
* improved backwards compatibility. In general the `createClient` function from the root packge
|
|
163
163
|
* should be used instead of the one in the `/compat` module.
|
|
164
164
|
*
|
|
165
165
|
* The client will begin attempting to connect to LaunchDarkly as soon as it is created. To
|
|
@@ -192,6 +192,6 @@ interface LDOptions extends BrowserOptions {
|
|
|
192
192
|
* @return
|
|
193
193
|
* The new client instance.
|
|
194
194
|
*/
|
|
195
|
-
declare function initialize(envKey: string, context: LDContext, options?: LDOptions): LDClient
|
|
195
|
+
declare function initialize(envKey: string, context: LDContext, options?: LDOptions): Omit<LDClient, 'start' | 'setInitialContext'>;
|
|
196
196
|
|
|
197
197
|
export { type LDClient, type LDOptions, initialize };
|
package/dist/compat.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { LDContext, LDFlagSet } from '@launchdarkly/js-client-sdk-common';
|
|
2
|
-
export { AutoEnvAttributes, BasicLogger, BasicLoggerOptions, EvaluationSeriesContext, EvaluationSeriesData, Hook, HookMetadata, IdentifySeriesContext, IdentifySeriesData, IdentifySeriesResult, IdentifySeriesStatus, LDContext, LDContextCommon, LDContextMeta, LDEvaluationDetail, LDEvaluationDetailTyped, LDEvaluationReason, LDFlagSet, LDFlagValue, LDIdentifyError, LDIdentifyResult, LDIdentifyShed, LDIdentifySuccess, LDIdentifyTimeout, LDInspection, LDLogLevel, LDLogger, LDMultiKindContext, LDPluginApplicationMetadata, LDPluginBase, LDPluginEnvironmentMetadata, LDPluginMetadata, LDPluginSdkMetadata, LDSingleKindContext, LDTimeoutError, TrackSeriesContext } from '@launchdarkly/js-client-sdk-common';
|
|
3
|
-
import { L as LDClient$1, B as BrowserOptions } from './common-
|
|
4
|
-
export { b as LDIdentifyOptions, c as basicLogger } from './common-
|
|
2
|
+
export { AutoEnvAttributes, BasicLogger, BasicLoggerOptions, EvaluationSeriesContext, EvaluationSeriesData, Hook, HookMetadata, IdentifySeriesContext, IdentifySeriesData, IdentifySeriesResult, IdentifySeriesStatus, LDContext, LDContextCommon, LDContextMeta, LDDebugOverride, LDEvaluationDetail, LDEvaluationDetailTyped, LDEvaluationReason, LDFlagSet, LDFlagValue, LDIdentifyError, LDIdentifyResult, LDIdentifyShed, LDIdentifySuccess, LDIdentifyTimeout, LDInspection, LDLogLevel, LDLogger, LDMultiKindContext, LDPluginApplicationMetadata, LDPluginBase, LDPluginEnvironmentMetadata, LDPluginMetadata, LDPluginSdkMetadata, LDSingleKindContext, LDTimeoutError, TrackSeriesContext } from '@launchdarkly/js-client-sdk-common';
|
|
3
|
+
import { L as LDClient$1, B as BrowserOptions } from './common-ekJnfmSx.js';
|
|
4
|
+
export { b as LDIdentifyOptions, c as basicLogger } from './common-ekJnfmSx.js';
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* Compatibility interface. This interface extends the base LDCLient interface with functions
|
|
@@ -13,7 +13,7 @@ export { b as LDIdentifyOptions, c as basicLogger } from './common-Cn2MjelZ.js';
|
|
|
13
13
|
* incorrect. Any function which optionally returned a promise based on a callback had incorrect
|
|
14
14
|
* typings. Those have been corrected in this implementation.
|
|
15
15
|
*/
|
|
16
|
-
interface LDClient extends Omit<LDClient$1, 'close' | 'flush' | 'identify' | 'identifyResult'> {
|
|
16
|
+
interface LDClient extends Omit<LDClient$1, 'close' | 'flush' | 'identify' | 'identifyResult' | 'waitForInitialization' | 'setInitialContext' | 'start'> {
|
|
17
17
|
/**
|
|
18
18
|
* Identifies a context to LaunchDarkly.
|
|
19
19
|
*
|
|
@@ -159,7 +159,7 @@ interface LDOptions extends BrowserOptions {
|
|
|
159
159
|
|
|
160
160
|
/**
|
|
161
161
|
* Creates an instance of the LaunchDarkly client. This version of initialization is for
|
|
162
|
-
* improved backwards compatibility. In general the `
|
|
162
|
+
* improved backwards compatibility. In general the `createClient` function from the root packge
|
|
163
163
|
* should be used instead of the one in the `/compat` module.
|
|
164
164
|
*
|
|
165
165
|
* The client will begin attempting to connect to LaunchDarkly as soon as it is created. To
|
|
@@ -192,6 +192,6 @@ interface LDOptions extends BrowserOptions {
|
|
|
192
192
|
* @return
|
|
193
193
|
* The new client instance.
|
|
194
194
|
*/
|
|
195
|
-
declare function initialize(envKey: string, context: LDContext, options?: LDOptions): LDClient
|
|
195
|
+
declare function initialize(envKey: string, context: LDContext, options?: LDOptions): Omit<LDClient, 'start' | 'setInitialContext'>;
|
|
196
196
|
|
|
197
197
|
export { type LDClient, type LDOptions, initialize };
|
package/dist/compat.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var Ui=Object.defineProperty,Vi=Object.defineProperties;var ji=Object.getOwnPropertyDescriptors;var gt=Object.getOwnPropertySymbols;var je=Object.prototype.hasOwnProperty,He=Object.prototype.propertyIsEnumerable;var Ve=(i,t,e)=>t in i?Ui(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,p=(i,t)=>{for(var e in t||(t={}))je.call(t,e)&&Ve(i,e,t[e]);if(gt)for(var e of gt(t))He.call(t,e)&&Ve(i,e,t[e]);return i},b=(i,t)=>Vi(i,ji(t));var Bt=(i,t)=>{var e={};for(var n in i)je.call(i,n)&&t.indexOf(n)<0&&(e[n]=i[n]);if(i!=null&>)for(var n of gt(i))t.indexOf(n)<0&&He.call(i,n)&&(e[n]=i[n]);return e};function Hi(i){return`/${i.replace(/~/g,"~0").replace(/\//g,"~1")}`}function Ye(i){return i.indexOf("~")?i.replace(/~1/g,"/").replace(/~0/g,"~"):i}function Bi(i){return(i.startsWith("/")?i.substring(1):i).split("/").map(e=>Ye(e))}function Ki(i){return!i.startsWith("/")}function Gi(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("/")?Hi(n):n}else{if(this.redactionName=t,t===""||t==="/"||!Gi(t)){this.isValid=!1,this.p=[];return}Ki(t)?this.p=[t]:t.indexOf("/",1)<0?this.p=[Ye(t.slice(1))]:this.p=Bi(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 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"}},I=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}},vt=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 I{constructor(t){super(`number with minimum value of ${t}`,0),this.min=t}is(t){return typeof t===this.typeOf&&t>=this.min}},wt=class extends I{constructor(t){super(`string matching ${t}`,""),this.expression=t}is(t){return typeof t=="string"&&!!t.match(this.expression)}},_t=class{is(t){return typeof t=="function"}getType(){return"function"}},Jt=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)?)/,qt=class{is(t){return typeof t=="number"||typeof t=="string"&&zi.test(t)}getType(){return"date"}},Wt=class extends wt{constructor(){super(/^(\w|\.|-)+$/)}is(t){return super.is(t)&&t!=="kind"}},h=class{static createTypeArray(t,e){return new vt(t,e)}static numberWithMin(t){return new z(t)}static stringMatchingRegex(t){return new wt(t)}};h.String=new I("string","");h.Number=new I("number",0);h.ObjectOrFactory=new zt;h.Object=new I("object",{});h.StringArray=new vt("string[]","");h.Boolean=new I("boolean",!0);h.Function=new _t;h.Date=new qt;h.Kind=new Wt;h.NullableBoolean=new Jt;function Ze(i){return"kind"in i?h.String.is(i.kind)&&i.kind!=="multi":!1}function Xe(i){return"kind"in i?h.String.is(i.kind)&&i.kind==="multi":!1}function Qe(i){return!("kind"in i)||i.kind===null||i.kind===void 0}function Et(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=>Et(s,[...t,i])).map(s=>s===void 0?"null":s).join(",")}]`:`{${Object.keys(i).sort().map(n=>{let s=Et(i[n],[...t,i]);if(s!==void 0)return`${JSON.stringify(n)}:${s}`}).filter(n=>n!==void 0).join(",")}}`}var Yt="user";function Be(i){return i.includes("%")||i.includes(":")?i.replace(/%/g,"%25").replace(/:/g,"%3A"):i}function _i(i){return i&&h.Object.is(i)}function Ke(i){return h.Kind.is(i)}function Ge(i){return h.String.is(i)&&i!==""}function Kt(i,t=!1){return i?i.map(e=>new A(e,t)):[]}function Ji(i){return i!=null}function qi(i){let t=b(p({},i.custom||[]),{kind:"user",key:String(i.key)});if(Ji(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.C=!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.C)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(Ke);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 _i(l)?(c[u]=l,s[u]=Kt((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=>Ge(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.C=!0,o}static Ze(t){var c;let{key:e,kind:n}=t,s=Ke(n),r=Ge(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=Kt((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=qi(t),n.ot={user:Kt(t.privateAttributeNames,!0)},n}static fromLDContext(t){return t?Ze(t)?i.Ze(t):Xe(t)?i.Ye(t):Qe(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.C)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=Yt){return t.isKind?this.kinds:i.We(t,this.ae(e))}key(t=Yt){var e;return(e=this.ae(t))==null?void 0:e.key}get isMultiKind(){return this.C}get canonicalKey(){return this.at?this.m.key:this.C?Object.keys(this.R).sort().map(t=>`${t}:${Be(this.R[t].key)}`).join(":"):`${this.kind}:${Be(this.m.key)}`}get kinds(){return this.C?Object.keys(this.R):[this.kind]}get kindsAndKeys(){return this.C?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.C?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=Et(i.toLDContext(this))}catch(t){}return this.xt}}};x.UserKind=Yt;var Wi=["key","kind","_meta","anonymous"].map(i=>new A(i,!0)),Yi=["name","ip","firstName","lastName","email","avatar","country"];function Zi(i,t){return i.depth===t.length&&t.every((e,n)=>e===i.getComponent(n))}function Xi(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=>Zi(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 Zt=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=>!Wi.some(a=>a.compare(r)))}oe(t,e,n,s){let r=this.Qe||s&&e.anonymous===!0,{cloned:a,excluded:o}=Xi(e,this.ei(t,e,n,r));return t.legacy&&Yi.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}},ze=30*1e3,Qi=.5,Dt=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(ze/this.ce))}T(){let t=Math.min(this.Lt,this.si),e=this.ce*2**t;return Math.min(e,ze)}ri(t){return t-Math.trunc(this.ni()*Qi*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.T());return this.Lt+=1,e}};var _e;(function(i){i[i.Valid=0]="Valid",i[i.Initializing=1]="Initializing",i[i.Interrupted=2]="Interrupted",i[i.Closed=3]="Closed"})(_e||(_e={}));var $=class extends Error{constructor(t,e,n,s=!0){super(e),this.kind=t,this.status=n,this.name="LaunchDarklyPollingError",this.recoverable=s}},V=class extends Error{constructor(t,e,n,s=!0){super(e),this.kind=t,this.code=n,this.name="LaunchDarklyStreamingError",this.recoverable=s}};var Ss=120*1e3,Cs=300*1e3;var w;(function(i){i.Unknown="UNKNOWN",i.NetworkError="NETWORK_ERROR",i.ErrorResponse="ERROR_RESPONSE",i.InvalidData="INVALID_DATA"})(w||(w={}));var j;(function(i){i[i.Disabled=0]="Disabled",i[i.Enabled=1]="Enabled"})(j||(j={}));var H;(function(i){i[i.AnalyticsEvents=0]="AnalyticsEvents",i[i.DiagnosticEvent=1]="DiagnosticEvent"})(H||(H={}));var O;(function(i){i[i.Succeeded=0]="Succeeded",i[i.Failed=1]="Failed",i[i.FailedAndMustShutDown=2]="FailedAndMustShutDown"})(O||(O={}));function U(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 tn(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(Number(i))}function en(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(parseInt(i,10))}function nn(i){return typeof i=="symbol"?"NaN":String(parseFloat(i))}var mt={s:i=>U(i),d:i=>tn(i),i:i=>en(i),f:i=>nn(i),j:i=>U(i),o:i=>U(i),O:i=>U(i),c:()=>""};function Xt(...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 mt&&i.length){let c=i.shift();n+=(e=mt[o])==null?void 0:e.call(mt,c)}else o==="%"?n+="%":n+=`%${o}`;s+=2}}else n+=r,s+=1}return i.length&&(n.length&&(n+=" "),n+=i.map(U).join(" ")),n}return i.map(U).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 sn=["debug","info","warn","error","none"],M=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):Xt(...t)}catch(n){return Xt(...t)}}mi(t,e){try{t(e)}catch(n){console.error(e)}}k(t,e){var n;if(t>=this.fi){let s=`${sn[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)}},rn={error:h.Function,warn:h.Function,info:h.Function,debug:h.Function},_=class{constructor(t,e){Object.entries(rn).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)}},ue=i=>{let t=new M({level:"info",destination:console.error,formatter:Xt});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`}},an=/^(\w|\.|-)+$/,on=h.stringMatchingRegex(an),cn={is:(i,t)=>on.is(i)?i.length>64?{valid:!1,message:k.tagValueTooLong(t)}:{valid:!0}:{valid:!1,message:k.invalidTagValue(t)}},bt=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}=cn.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(" "))}},kt=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 Gt(i){return i.replace(/\/+$/,"")}function le(i){return i.replace(/^\/+/,"").replace(/\?$/,"")}var R=class i{constructor(t,e,n=i.DEFAULT_EVENTS,s="/bulk",r="/diagnostic",a=!0,o){this.streaming=Gt(t),this.polling=Gt(e),this.events=Gt(n),this.analyticsEventPath=s,this.diagnosticEventPath=r,this.includeAuthorizationHeader=a,this.payloadFilterKey=o}};R.DEFAULT_EVENTS="https://events.launchdarkly.com";function he(i,t=[]){if(t.length===0)return i;let e=t.map(({key:n,value:s})=>`${n}=${s}`);return`${i}?${e.join("&")}`}function ti(i,t,e){let n=le(t),s=[...e];return i.payloadFilterKey&&s.push({key:"filter",value:i.payloadFilterKey}),he(`${i.streaming}/${n}`,s)}function ei(i,t,e=[]){let n=le(t),s=[...e];return i.payloadFilterKey&&s.push({key:"filter",value:i.payloadFilterKey}),he(`${i.polling}/${n}`,s)}function Je(i,t,e=[]){let n=le(t);return he(`${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 un(i){return i===413?!0:Y(i)}function ii(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 de(i){return i==null?i:JSON.parse(JSON.stringify(i))}function Pt(i){return Math.trunc(i*1e3)}var ln=i=>JSON.stringify(i)==="{}",Nt=(i,t)=>i&&Object.entries(i).reduce((e,[n,s])=>(s&&!ln(s)&&!(t!=null&&t.includes(n))&&(e[n]=typeof s=="object"?Nt(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 ni(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 B(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 si({status:i}){return i?Y(i):!0}var fe=(i,t)=>t.btoa(i).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"");var hn=async(i=1e3)=>new Promise(t=>{setTimeout(t,i)});var Qt=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}},te;(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"})(te||(te={}));var dn=te,xt=class{static invalidMetricValue(t){return`The track function was called with a non-numeric "metricValue" (${t}), only numeric metric values are supported.`}};xt.MissingContextKeyNoEvent="Context was unspecified or had no key; event will not be sent";var ee=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=Je(n.serviceEndpoints,r,[]),this.Ei=Je(n.serviceEndpoints,a,[]),this.I=c,this.Di=o}async ct(t,e,n,s){let r={status:O.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(B({status:c,message:"some events were dropped"},"event posting")),!Y(c))return un(c)?r.status=O.Failed:r.status=O.FailedAndMustShutDown,r.error=o,r}catch(c){o=c}return o&&!s?(r.status=O.Failed,r.error=o,r):(await hn(),this.ct(t,this.ve,n,!1))}async sendEventData(t,e){let n=t===H.AnalyticsEvents?this.Di.randomUUID():void 0,s=t===H.AnalyticsEvents?this.ve:this.Ei;return this.ct(e,s,n,!0)}};function Lt(i){return i.kind==="feature"}function fn(i){return i.kind==="identify"}function pn(i){return i.kind==="migration_op"}var ie=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 gn(i){return`${i.key}:${i.variation!==null&&i.variation!==void 0?i.variation:""}:${i.version!==null&&i.version!==void 0?i.version:""}`}var St=class{constructor(t=!1,e){this.bi=t,this.x=e,this.X=0,this.ut=0,this.lt={},this.ht={}}summarizeEvent(t){if(Lt(t)&&!t.excludeFromSummaries){this.m||(this.m=t.context);let e=gn(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 ie(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={}}},ne=class extends Error{constructor(t){super(t),this.name="LaunchDarklyInvalidSDKKeyError"}},se=class{constructor(t,e){this.x=t,this.t=e,this.Q={}}summarizeEvent(t){var e;if(Lt(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 St(!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 yt(i){let t=Math.trunc(i);return t===1?!0:t===0?!1:Math.floor(Math.random()*t)===0}function mn(i){return i.getSummaries!==void 0}var re=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.It=0,this.Pt=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 ee(e,n),this.x=new Zt(t.allAttributesPrivate,t.privateAttributes.map(c=>new A(c))),o?this.tt=new se(this.x,this.t):this.tt=new St,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.It,this.Pt,this.Ee);this.It=0,this.Pt=0,this.be(s)},this.r.diagnosticRecordingInterval*1e3)}(e=this.t)==null||e.debug("Started EventProcessor.")}be(t){this.De.sendEventData(H.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 ne("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=[],mn(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(pn(t)){if(yt(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=Lt(t),n=e&&t.trackEvents||!e,s=this.Si(t),r=fn(t),a=(c=this.dt)==null?void 0:c.processContext(t.context);a||r||(this.Pt+=1),a&&!r&&this.pt(this.Mt({kind:"index",creationDate:t.creationDate,context:t.context,samplingRatio:1},!1)),n&&yt(t.samplingRatio)&&this.pt(this.Mt(t,!1)),s&&yt(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.It+=1)}Si(t){return Lt(t)&&t.debugEventsUntilDate&&t.debugEventsUntilDate>this.we&&t.debugEventsUntilDate>Date.now()}async ct(t){let e=await this.De.sendEventData(H.AnalyticsEvents,t);if(e.status===O.FailedAndMustShutDown&&(this.Ot=!0),e.serverTime&&(this.we=e.serverTime),e.error)throw e.error}},Ct=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)}},Tt=class{constructor(t,e=1){this.context=t,this.samplingRatio=e,this.kind="identify",this.creationDate=Date.now()}},ae=class{close(){}async flush(){}sendEvent(){}},oe=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 Tt(t,1)}customEvent(t,e,n,s,r=1){return new Ct(e,t,n!=null?n:void 0,s!=null?s:void 0,r)}},qe="FDv1Fallback";function yn(i){return{Ci:i,xe:"",useSelector(t){return this.xe=t,this},processFullTransfer(t){let e=[{event:"server-intent",data:{payloads:[{id:qe,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:qe}}),this.Ci.processEvents(e)}}}var At=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.Ii(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.Pi=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.Ii=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.Pi(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=[]}},ce=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 At(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 vn(i){if(i){let t=Object.keys(i).find(e=>e.toLowerCase()==="x-ld-envid");if(t)return{environmentId:i[t]}}}var We="unknown plugin";function It(i,t){try{return t.getMetadata().name||We}catch(e){return i.error("Exception thrown getting metadata for plugin. Unable to get plugin name."),We}}function wn(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 En(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:xt,DiagnosticsManager:Qt,ErrorKinds:dn,EventFactoryBase:oe,EventProcessor:re,FDv1PayloadAdaptor:yn,InputCustomEvent:Ct,InputEvalEvent:W,InputIdentifyEvent:Tt,NullEventProcessor:ae,PayloadProcessor:At,PayloadStreamReader:ce,canonicalize:Et,initMetadataFromHeaders:vn,isLegacyUser:Qe,isMultiKind:Xe,isSingleKind:Ze,safeGetHooks:wn,safeGetName:It,safeRegisterPlugins:En,shouldSample:yt});var E;(function(i){i.Initializing="INITIALIZING",i.Valid="VALID",i.Interrupted="INTERRUPTED",i.SetOffline="SET_OFFLINE",i.Closed="CLOSED"})(E||(E={}));function bn(i){return i>=200&&i<=299}var Ot=class extends Error{constructor(t,e){super(t),this.status=e,this.name="LaunchDarklyRequestError"}},ve=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(bn(e.status))return await e.text();t=e.status}catch(e){throw new Ot(e==null?void 0:e.message)}throw new Ot(`Unexpected status code: ${t}`,t)}};function Pe(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=ei(t,m,g);return new ve(n,y,f,d,l)}var ri=new Error("Task has already been executed or shed. This is likely an implementation error. The task will not be executed again.");function kn(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(ri)),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(ri)),a=!0,r.then(o=>{n({status:"shed"},o)})},promise:s,sheddable:e}}function xn(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=kn(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 Ln={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",{})},Sn=300,di="https://clientsdk.launchdarkly.com",fi="https://clientstream.launchdarkly.com";function Cn(i){return i instanceof _?i:ue(i)}var we=class{constructor(t={},e={getImplementationHooks:()=>[],credentialType:"mobileKey"}){var s,r,a;this.logger=ue(),this.baseUri=di,this.eventsUri=R.DEFAULT_EVENTS,this.streamUri=fi,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=Sn,this.hooks=[],this.inspectors=[],this.logger=Cn(t.logger),this.Hi(t).forEach(o=>this.logger.warn(o)),this.serviceEndpoints=new R(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 bt({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=Ln[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 pi(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 gi=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 mi(i){return async t=>pi(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 Tn(i,t){return X([{value:"LaunchDarkly",transform:S},{value:t,transform:mi(i)}])}async function An(i){return X([{value:"LaunchDarkly",transform:S},{value:"AnonymousKeys",transform:S},{value:i,transform:S}])}async function In(i){return X([{value:"LaunchDarkly",transform:S},{value:"ContextKeys",transform:S},{value:i,transform:S}])}async function Pn(i){return X([{value:i,transform:S},{value:"ContextIndex",transform:S}])}async function ai(i,t,e){return X([{value:t,transform:S},{value:e.canonicalKey,transform:mi(i)}])}var{isLegacyUser:Nn,isSingleKind:pe,isMultiKind:oi}=L,yi="1.0",On=i=>{let n=i,{kind:t}=n,e=Bt(n,["kind"]);return{kind:"multi",[t]:e}},$n=async({crypto:i,info:t},{applicationInfo:e})=>{var a;let{ld_application:n}=t.platformData(),s=(a=Nt(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 pi(i.createHash("sha256").update(r),"base64"),s.envAttributesVersion=s.envAttributesVersion||yi,s}},Mn=async i=>{var o,c,u,l;let{ld_device:t,os:e}=i.info.platformData(),n=(o=Nt(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 In("ld_device");return n.key=await gi(d,i),n.envAttributesVersion=n.envAttributesVersion||yi,n}},Rn=async(i,t,e)=>{if(Nn(i))return i;let n,s;if(pe(i)&&i.kind!=="ld_application"||oi(i)&&!i.ld_application?n=await $n(t,e):e.logger.warn("Not adding ld_application environment attributes because it already exists."),pe(i)&&i.kind!=="ld_device"||oi(i)&&!i.ld_device?s=await Mn(t):e.logger.warn("Not adding ld_device environment attributes because it already exists."),n||s){let r=pe(i)?On(i):i;return p(p(p({},r),n?{ld_application:n}:{}),s?{ld_device:s}:{})}return i},{isLegacyUser:Fn,isMultiKind:Un,isSingleKind:Vn}=L,Ne=async(i,t,e)=>{let{anonymous:n,key:s}=t;if(n&&!s){let r=await An(i);t.key=await gi(r,e)}},jn=async(i,t)=>{await Ne(i.kind,i,t)},Hn=async(i,t)=>{let s=i,{kind:e}=s,n=Bt(s,["kind"]);return Promise.all(Object.entries(n).map(([r,a])=>Ne(r,a,t)))},Bn=async(i,t)=>{await Ne("user",i,t)},Kn=async(i,t)=>{let e=de(i);return Vn(e)&&await jn(e,t),Un(e)&&await Hn(e,t),Fn(e)&&await Bn(e,t),e},Gn=i=>({customBaseURI:i.serviceEndpoints.polling!==di,customStreamURI:i.serviceEndpoints.streaming!==fi,customEventsURI:i.serviceEndpoints.events!==R.DEFAULT_EVENTS,eventsCapacity:i.capacity,eventsFlushIntervalMillis:Pt(i.flushInterval),reconnectTimeMillis:Pt(i.streamInitialReconnectDelay),diagnosticRecordingIntervalMillis:Pt(i.diagnosticRecordingInterval),allAttributesPrivate:i.allAttributesPrivate,usingSecureMode:!1,bootstrapMode:!1}),zn=(i,t,e)=>{if(t.sendEvents&&!t.diagnosticOptOut)return new L.DiagnosticsManager(i,e,Gn(t))};function ge(i,t){return{value:t!=null?t:null,variationIndex:null,reason:{kind:"ERROR",errorKind:i}}}function ci(i,t,e){return{value:i,variationIndex:t!=null?t:null,reason:e!=null?e:null}}var _n=(i,t,e,n,s)=>{if(t.sendEvents)return new L.EventProcessor(b(p({},t),{eventsCapacity:t.capacity}),new kt(i,t,e),n,void 0,s,!1,!0)},$t=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)):[]}},Ee=class{constructor(t,e,n,s,r,a,o=()=>Date.now()){this.h=t,this.Vt=e,this.Bi=n,this.v=s,this.P=r,this.t=a,this.mt=o,this.Se=Pn(this.Vt)}async init(t,e){this.P.init(t,e),await this.Ce(t)}async upsert(t,e,n){return this.P.upsert(t,e,n)?(await this.Ce(t),!0):!1}async loadCached(t){var s,r,a,o;let e=await ai(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.P.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 ai(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))}},De=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 Jn(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 be=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=Jn(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)}},ke=class{constructor(t,e,n,s,r=()=>Date.now()){this.v=new De,this.P=new be(this.v,s),this.jt=this.Gi(t,e,n,s,r)}async Gi(t,e,n,s,r=()=>Date.now()){let a=await Tn(t.crypto,e);return new Ee(t,a,n,this.v,this.P,s,r)}get(t){return this.v.get(t)}getAll(){return this.v.getAll()}setBootstrap(t,e){this.P.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.P.on(t)}off(t){this.P.off(t)}},ui="unknown hook",vi="beforeEvaluation",wi="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||ui}catch(e){return i.error("Exception thrown getting metadata for hook. Unable to get hook name."),ui}}function Wn(i,t,e){return t.map(n=>Q(i,vi,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 Yn(i,t,e,n,s){for(let r=t.length-1;r>=0;r-=1){let a=t[r],o=n[r];Q(i,wi,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 Zn(i,t,e){return t.map(n=>Q(i,vi,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 Xn(i,t,e,n,s){for(let r=t.length-1;r>=0;r-=1){let a=t[r],o=n[r];Q(i,wi,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 Qn(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 xe=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=Wn(this.t,r,a),c=s();return Yn(this.t,r,a,o,c),c}identify(t,e){let n=[...this.U],s={context:t,timeout:e},r=Zn(this.t,n,s);return a=>{Xn(this.t,n,s,r,a)}}addHook(t){this.U.push(t)}afterTrack(t){if(this.U.length===0)return;let e=[...this.U];Qn(this.t,e,t)}};function ts(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 es(i,t){return`an inspector: "${t}" of an invalid type (${i}) was configured`}function is(i,t){return`an inspector: "${t}" of type: "${i}" generated an exception`}function ns(i,t){let e=!1,n={method:(...s)=>{try{i.method(...s)}catch(r){e||(e=!0,t.warn(is(n.type,n.name)))}},type:i.type,name:i.name,synchronous:i.synchronous};return n}var Ei="flag-used",Di="flag-details-changed",bi="flag-detail-changed",ki="client-identity-changed",ss=[Ei,Di,bi,ki];function rs(i,t){let e=ss.includes(i.type)&&i.method&&typeof i.method=="function";return e||t.warn(es(i.type,i.name)),e}var Le=class{constructor(t,e){this.J=[];let n=t.filter(s=>rs(s,e));this.J=n.map(s=>ns(s,e))}hasInspectors(){return this.J.length!==0}onFlagUsed(t,e,n){this.J.forEach(s=>{s.type===Ei&&s.method(t,e,n)})}onFlagsChanged(t){this.J.forEach(e=>{e.type===Di&&e.method(t)})}onFlagChanged(t,e){this.J.forEach(n=>{n.type===bi&&n.method(t,e)})}onIdentityChanged(t){this.J.forEach(e=>{e.type===ki&&e.method(t)})}},Se=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 as(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:me,ErrorKinds:ye}=L,os=5,Mt=class{constructor(t,e,n,s,r,a){if(this.sdkKey=t,this.autoEnvAttributes=e,this.platform=n,this.Bt=15,this.N=new $t(!1),this.yt=new $t(!0),this.Kt=!1,this.zi=xn(),!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 we(s,a),this.logger=this.r.logger,this.Ae=ni(this.sdkKey,this.platform.info,this.r.tags,this.r.serviceEndpoints.includeAuthorizationHeader,this.r.userAgentHeaderName),this.S=new ke(this.platform,t,this.r.maxCachedContexts,this.r.logger),this.L=zn(t,this.r,n),this.w=_n(t,this.r,n,this.Ae,this.L),this.emitter=new Se,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=as(this.sdkKey,this.platform,this.r),this.r.getImplementationHooks(this.environmentMetadata).forEach(c=>{o.push(c)}),this.V=new xe(this.logger,o),this.nt=new Le(this.r.inspectors,this.logger),this.nt.hasInspectors()&&this.V.addHook(ts(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?de(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:os,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 Kn(t,this.platform);this.autoEnvAttributes===j.Enabled&&(u=await Rn(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.N.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(me.MissingContextKeyNoEvent);return}n!==void 0&&!h.Number.is(n)&&((s=this.logger)==null||s.warn(me.invalidMetricValue(typeof n))),(r=this.w)==null||r.sendEvent(this.r.trackEventModifier(this.N.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(me.MissingContextKeyNoEvent),ge(ye.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.N.unknownFlagEvent(t,y,r)),ge(ye.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 F=new q(`Wrong type "${D}" for feature flag "${t}"; returning default value`);return this.emitter.emit("error",this.D,F),ge(ye.WrongType,e)}}let d=ci(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.N)}),(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.N));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,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,n=>[h.Number.is(n),h.Number.getType()]).value}stringVariation(t,e){return this.W(t,e,this.N,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]=ci(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)})}},Ce=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)}},Te=class{constructor(t,e=()=>Date.now()){this.$=t,this.wt=E.Closed,this.Ie=e(),this.mt=e}get status(){return{state:this.wt,stateSince:this.Ie,lastError:this.qi}}Pe(t,e=!1){let n=t===E.Interrupted&&this.wt===E.Initializing?E.Initializing:t,s=this.wt!==n;s&&(this.wt=n,this.Ie=this.mt()),(s||e)&&this.$.emit("dataSourceStatus",this.status)}requestStateUpdate(t){this.Pe(t)}reportError(t,e,n,s=!1){let r={kind:t,message:e,statusCode:n,time:this.mt()};this.qi=r,this.Pe(s?E.Interrupted:E.Closed,!0)}};function li(i){i==null||i.debug("Poll completed after the processor was closed. Skipping processing.")}var Ae=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 $(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){li(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){li(this.t);return}let m=f;if(m.status!==void 0&&!Y(m.status)){(c=this.t)==null||c.error(B(f,"polling request")),(u=this.g)==null||u.call(this,new $(w.ErrorResponse,m.message,m.status));return}(l=this.t)==null||l.error(B(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()}},cs=(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 V(w.InvalidData,"Malformed JSON data in event stream"))};function us(i,t){t==null||t.debug(`Received ${i} event after processor was closed. Skipping processing.`)}function hi(i){i==null||i.debug("Ping completed after processor was closed. Skipping processing.")}var Ie=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=ti(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 si(t)?((s=this.t)==null||s.warn(B(t,"streaming request","will retry")),this.Jt(!1),this.Oe(),!0):(this.Jt(!1),(e=this.g)==null||e.call(this,new V(w.ErrorResponse,t.message,t.status,!1)),(n=this.t)==null||n.error(B(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){us(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){cs(r,u,this.t,this.g);return}s(l)}else(c=this.g)==null||c.call(this,new V(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){hi(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 $(w.InvalidData,"Malformed JSON data in ping polling response"))}}catch(l){if(this.u){hi(this.t);return}let d=l;(u=this.g)==null||u.call(this,new $(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()}},Rt=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 Te(c),this.Y=new Ce(e,this.dataSourceStatusManager,this.config.logger)}setConnectionParams(t){this.nn=t}createPollingProcessor(t,e,n,s,r){let a=new Ae(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 Ie(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 Ft(){return typeof document!==void 0}function Oe(){return typeof window!==void 0}function Ut(i,t,e){return Ft()?(document.addEventListener(i,t,e),()=>{document.removeEventListener(i,t,e)}):()=>{}}function Vt(i,t,e){return Ft()?(window.addEventListener(i,t,e),()=>{window.removeEventListener(i,t,e)}):()=>{}}function T(){return Oe()?window.location.href:""}function xi(){return Oe()?window.location.search:""}function Li(){return Oe()?window.location.hash:""}function Si(){if(typeof crypto!==void 0)return crypto;throw Error("Access to a web crypto API is required")}function Ci(){return Ft()?document.visibilityState:"visibile"}function Ti(i){if(Ft())return document.querySelectorAll(i)}function Ai(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 ls="[BrowserDataManager]",et=class extends Rt{constructor(e,n,s,r,a,o,c,u,l,d){super(e,n,s,r,o,c,u,l,d);this.yn=a;this.st=void 0;this.qt=!1;this.st=a.streaming}M(e,...n){this.logger.debug(`${ls} ${e}`,...n)}async identify(e,n,s,r){if(this.closed){this.M("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.M("Identify - Flags loaded from cache. Continuing to initialize via a poll."),await this.rn(s,e,n)),this.Yt()}async rn(e,n,s){var r,a;try{this.dataSourceStatusManager.requestStateUpdate(E.Initializing);let o=JSON.stringify(x.toLDContext(e)),u=await Pe(o,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.Wt).requestPayload();try{let d=this.createStreamListeners(e,n).get("put");d.processJson(d.deserializeData(u))}catch(l){this.dataSourceStatusManager.reportError(w.InvalidData,(r=l.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,Ai(this.logger,n)),this.M("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.M(`Updating streaming state. forced(${this.st}) automatic(${this.qt})`),e?this.an():this.cn()}cn(){var e;this.updateProcessor&&this.M("Stopping update processor."),(e=this.updateProcessor)==null||e.close(),this.updateProcessor=void 0}an(){if(this.updateProcessor){this.M("Update processor already active. Not changing state.");return}if(!this.context){this.M("Context not set, not starting update processor.");return}this.M("Starting update processor."),this.un(this.context)}un(e,n,s){var c;let r=x.toLDContext(e);(c=this.updateProcessor)==null||c.close();let a=JSON.stringify(x.toLDContext(e)),o=Pe(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 Ii(i){let e=Ut("visibilitychange",()=>{Ci()==="hidden"&&i()}),n=Vt("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 hs(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 ds(i,t){let e=[];return t.forEach(n=>{let s=i.target,{selector:r}=n,a=Ti(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=>hs(c,T(),xi(),Li()))}),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=>{ds(o,r).forEach(c=>{e(c)})};this.Re=Ut("click",a)}}close(){var t;(t=this.Re)==null||t.call(this)}};var fs=300,jt=class{constructor(t){this.Zt=T();let e=()=>{let s=T();s!==this.Zt&&(this.Zt=s,t())};this.Xt=setInterval(e,fs);let n=Vt("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 jt(o)){this.I=e;this.dn=s;this.hn=r;this.Dt=[];this.Ve=!1;this.bt=`${n}/sdk/goals/${t}`,this.Ue=a(()=>{this.te()})}async initialize(){await this.ln(),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.hn(T(),e)})))}async ln(){try{let t=await this.I.fetch(this.bt);this.Dt=await t.json()}catch(t){this.dn(new J(`Encountered error fetching goals: ${t}`))}}close(){var t,e;(t=this.Ue)==null||t.close(),(e=this.Qt)==null||e.close()}};function Pi(i){return i.kind==="click"}var ps=2,Ni={fetchGoals:!0,eventUrlTransformer:i=>i,streaming:void 0,plugins:[]},gs={fetchGoals:h.Boolean,eventUrlTransformer:h.Function,streaming:h.Boolean,plugins:h.createTypeArray("LDPlugin",{})};function ms(i){var e;let t=p({},i);return(e=t.flushInterval)!=null||(t.flushInterval=ps),t}function Oi(i){let t=ms(i);return Object.keys(Ni).forEach(e=>{delete t[e]}),t}function $e(i,t){let e=p({},Ni);return Object.entries(gs).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.fn=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.fn.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 ys={start:0,end:3},vs={start:4,end:5},Me={start:6,end:7},Re={start:8,end:8},ws={start:9,end:9},Es={start:10,end:15};function Ds(){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 bs(i){return i[Re.start]=(i[Re.start]|128)&191,i[Me.start]=i[Me.start]&15|64,`${K(i,ys)}-${K(i,vs)}-${K(i,Me)}-${K(i,Re)}${K(i,ws)}-${K(i,Es)}`}function ks(){let i=Ds();return bs(i)}function Fe(){return typeof crypto!==void 0&&typeof crypto.randomUUID=="function"?crypto.randomUUID():ks()}var at=class{createHash(t){return new rt(Si(),t)}randomUUID(){return Fe()}};function xs(i){let t=Array.from(i,e=>String.fromCodePoint(e)).join("");return btoa(t)}var ot=class{btoa(t){return xs(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.9.1",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.T=new Dt(e.initialRetryDelayMillis,e.retryResetIntervalMillis),this.He=e.errorFilter,this.Be()}Be(){this.Z=new EventSource(this.bt),this.Z.onopen=()=>{var t;this.T.success(),(t=this.onopen)==null||t.call(this)},this.Z.onerror=t=>{var e;this.pn(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)}gn(t){var e;(e=this.onretrying)==null||e.call(this,{delayMillis:t}),this.ie=setTimeout(()=>{this.Be()},t)}pn(t){this.close(),!(t.status&&typeof t.status=="number"&&!this.He(t))&&this.gn(this.T.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 $i(){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;$i()&&(this.storage=new ht(t)),this.info=new ct(e)}};var Ue=class extends Mt{constructor(t,e,n={},s){var m;let{logger:r,debug:a}=n,o=r!=null?r: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",u=s!=null?s:new dt(o,n),l=$e(n,o),d=Oi(b(p({},n),{logger:o})),{eventUrlTransformer:f}=l;super(t,e,u,d,(g,y,D,F,Fi)=>new et(u,g,t,y,l,()=>({pathGet(P,N){return`/sdk/evalx/${t}/contexts/${fe(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}/${fe(N,P)}`},pathReport(P,N){return`/eval/${t}`},pathPing(P,N){return`/ping/${t}`}}),D,F,Fi),{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 F=f(g);Pi(y)?this.sendEvent({kind:"click",url:F,samplingRatio:1,key:y.key,creationDate:Date.now(),context:D,selector:y.selector}):this.sendEvent({kind:"pageview",url:F,samplingRatio:1,key:y.key,creationDate:Date.now(),context:D})}),this.ne.initialize(),l.automaticBackgroundHandling&&Ii(()=>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 Mi(i,t,e={},n){let s=new Ue(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 Ri=["ready","failed","initialized"],ft=class{constructor(t){this.n=t;this.e=new Map}on(t,e){var n;Ri.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(Ri.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 Ht(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=Mi(t,j.Disabled,n),this.$=new ft(this.n),this.logger=this.n.logger,this.mn(e,s,r)}async mn(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.$.emit("initialized")}catch(a){this.Je=a,this.se="failure",(r=this._e)==null||r.call(this,a),this.$.emit("failed",a)}this.$.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.$.off(t,e)}on(t,e){this.$.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 Ht(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 Ht(this.n.close().then(),t)}flush(t){return Ht(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=ii(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 Aa(i){return new M(i)}function Na(i,t,e){return new pt(i,t,e)}export{Aa as basicLogger,Na as initialize};
|
|
1
|
+
var ji=Object.defineProperty,Hi=Object.defineProperties;var zi=Object.getOwnPropertyDescriptors;var mt=Object.getOwnPropertySymbols;var ze=Object.prototype.hasOwnProperty,Be=Object.prototype.propertyIsEnumerable;var He=(i,t,e)=>t in i?ji(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,p=(i,t)=>{for(var e in t||(t={}))ze.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)=>Hi(i,zi(t));var Wt=(i,t)=>{var e={};for(var n in i)ze.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};function Bi(i){return`/${i.replace(/~/g,"~0").replace(/\//g,"~1")}`}function Xe(i){return i.indexOf("~")?i.replace(/~1/g,"/").replace(/~0/g,"~"):i}function Gi(i){return(i.startsWith("/")?i.substring(1):i).split("/").map(e=>Xe(e))}function Ki(i){return!i.startsWith("/")}function Wi(i){return!i.match(/\/\/|(^\/.*~[^0|^1])|~$/)}var O=class{constructor(t,e=!1){if(e){let n=t;this.v=[n],this.isValid=n!=="",this.redactionName=n.startsWith("/")?Bi(n):n}else{if(this.redactionName=t,t===""||t==="/"||!Wi(t)){this.isValid=!1,this.v=[];return}Ki(t)?this.v=[t]:t.indexOf("/",1)<0?this.v=[Xe(t.slice(1))]:this.v=Gi(t),this.v[0]==="_meta"?this.isValid=!1:this.isValid=!0}}get(t){let{v: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.v[t]}get depth(){return this.v.length}get isKind(){return this.v.length===1&&this.v[0]==="kind"}compare(t){return this.depth===t.depth&&this.v.every((e,n)=>e===t.getComponent(n))}get components(){return[...this.v]}};O.InvalidReference=new O("");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"}},A=class{constructor(t,e){this.It=t,this.typeOf=typeof e}is(t){return Array.isArray(t)?!1:typeof t===this.typeOf}getType(){return this.It}},wt=class{constructor(t,e){this.It=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.It}},W=class extends A{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 A{constructor(t){super(`string matching ${t}`,""),this.expression=t}is(t){return typeof t=="string"&&!!t.match(this.expression)}},Yt=class{is(t){return typeof t=="function"}getType(){return"function"}},Zt=class{is(t){return typeof t=="boolean"||typeof t=="undefined"||t===null}getType(){return"boolean | undefined | null"}},_i=/^\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d(\.\d\d*)?(Z|[-+]\d\d(:\d\d)?)/,Xt=class{is(t){return typeof t=="number"||typeof t=="string"&&_i.test(t)}getType(){return"date"}},Qt=class extends Et{constructor(){super(/^(\w|\.|-)+$/)}is(t){return super.is(t)&&t!=="kind"}},u=class{static createTypeArray(t,e){return new wt(t,e)}static numberWithMin(t){return new W(t)}static stringMatchingRegex(t){return new Et(t)}};u.String=new A("string","");u.Number=new A("number",0);u.ObjectOrFactory=new qt;u.Object=new A("object",{});u.StringArray=new wt("string[]","");u.Boolean=new A("boolean",!0);u.Function=new Yt;u.Date=new Xt;u.Kind=new Qt;u.NullableBoolean=new Zt;function Qe(i){return"kind"in i?u.String.is(i.kind)&&i.kind!=="multi":!1}function ti(i){return"kind"in i?u.String.is(i.kind)&&i.kind==="multi":!1}function ei(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(r=>Dt(r,[...t,i])).map(r=>r===void 0?"null":r).join(",")}]`:`{${Object.keys(i).sort().map(n=>{let r=Dt(i[n],[...t,i]);if(r!==void 0)return`${JSON.stringify(n)}:${r}`}).filter(n=>n!==void 0).join(",")}}`}var te="user";function Ge(i){return i.includes("%")||i.includes(":")?i.replace(/%/g,"%25").replace(/:/g,"%3A"):i}function Ji(i){return i&&u.Object.is(i)}function Ke(i){return u.Kind.is(i)}function We(i){return u.String.is(i)&&i!==""}function _t(i,t=!1){return i?i.map(e=>new O(e,t)):[]}function qi(i){return i!=null}function Yi(i){let t=D(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 S=class i{constructor(t,e,n){this.A=!1,this.lt=!1,this.fe=!1,this.V={},this.kind=e,this.valid=t,this.message=n}static S(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)}pe(t){if(this.A)return this.V[t];if(this.kind===t)return this.E}static ti(t){let e=Object.keys(t).filter(c=>c!=="kind"),n=e.every(Ke);if(!e.length)return i.S("multi","A multi-kind context must contain at least one kind");if(!n)return i.S("multi","Context contains invalid kinds");let r={},s=!0,a=e.reduce((c,l)=>{var d;let h=t[l];return Ji(h)?(c[l]=h,r[l]=_t((d=h._meta)==null?void 0:d.privateAttributes)):s=!1,c},{});if(!s)return i.S("multi","Context contained contexts that were not objects");if(!Object.values(a).every(c=>We(c.key)))return i.S("multi","Context contained invalid keys");if(e.length===1){let c=e[0],l=new i(!0,c);return l.E=D(p({},a[c]),{kind:c}),l.ht=r,l.lt=c==="user",l}let o=new i(!0,t.kind);return o.V=a,o.ht=r,o.A=!0,o}static ei(t){var c;let{key:e,kind:n}=t,r=Ke(n),s=We(e);if(!r)return i.S(n!=null?n:"unknown","The kind was not valid for the context");if(!s)return i.S(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.lt=n==="user",o.E=t,o.ht={[n]:a},o}static ii(t){if(!(t.key!==void 0&&t.key!==null))return i.S("user","The key for the context was not valid");let n=new i(!0,"user");return n.lt=!0,n.fe=!0,n.E=Yi(t),n.ht={user:_t(t.privateAttributeNames,!0)},n}static fromLDContext(t){return t?Qe(t)?i.ei(t):ti(t)?i.ti(t):ei(t)?i.ii(t):i.S("unknown","Context was not of a valid kind"):i.S("unknown","No context specified. Returning default value")}static toLDContext(t){if(!t.valid)return;let e=t.getContexts();if(!t.A)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=te){return t.isKind?this.kinds:i.Qe(t,this.pe(e))}key(t=te){var e;return(e=this.pe(t))==null?void 0:e.key}get isMultiKind(){return this.A}get canonicalKey(){return this.lt?this.E.key:this.A?Object.keys(this.V).sort().map(t=>`${t}:${Ge(this.V[t].key)}`).join(":"):`${this.kind}:${Ge(this.E.key)}`}get kinds(){return this.A?Object.keys(this.V):[this.kind]}get kindsAndKeys(){return this.A?Object.entries(this.V).reduce((t,[e,n])=>(t[e]=n.key,t),{}):{[this.kind]:this.E.key}}privateAttributes(t){var e;return((e=this.ht)==null?void 0:e[t])||[]}getContexts(){return this.A?Object.entries(this.V):[[this.kind,this.E]]}get legacy(){return this.fe}canonicalUnfilteredJson(){if(this.valid){if(this.Pt)return this.Pt;try{this.Pt=Dt(i.toLDContext(this))}catch(t){}return this.Pt}}};S.UserKind=te;var Zi=["key","kind","_meta","anonymous"].map(i=>new O(i,!0)),Xi=["name","ip","firstName","lastName","email","avatar","country"];function Qi(i,t){return i.depth===t.length&&t.every((e,n)=>e===i.getComponent(n))}function tn(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=>Qi(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 ee=class{constructor(t,e){this.ni=t,this.ri=e}filter(t,e=!1){let n=t.getContexts();if(n.length===1)return this.ge(t,n[0][1],n[0][0],e);let r={kind:"multi"};return n.forEach(([s,a])=>{r[s]=this.ge(t,a,s,e)}),r}si(t,e,n,r){return(r?Object.keys(e).map(s=>new O(s,!0)):[...this.ri,...t.privateAttributes(n)]).filter(s=>!Zi.some(a=>a.compare(s)))}ge(t,e,n,r){let s=this.ni||r&&e.anonymous===!0,{cloned:a,excluded:o}=tn(e,this.si(t,e,n,s));return t.legacy&&Xi.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,en=.5,bt=class{constructor(t,e,n=Math.random){this.ai=e,this.oi=n,this.Tt=0,this.me=Math.max(1,t),this.ci=Math.ceil(Math.log2(_e/this.me))}N(){let t=Math.min(this.Tt,this.ci),e=this.me*2**t;return Math.min(e,_e)}li(t){return t-Math.trunc(this.oi()*en*t)}success(t=Date.now()){this.Ot=t}fail(t=Date.now()){this.Ot!==void 0&&t-this.Ot>this.ai&&(this.Tt=0),this.Ot=void 0;let e=this.li(this.N());return this.Tt+=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 M=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 Ir=120*1e3,Pr=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 z;(function(i){i[i.AnalyticsEvents=0]="AnalyticsEvents",i[i.DiagnosticEvent=1]="DiagnosticEvent"})(z||(z={}));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 nn(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(Number(i))}function rn(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(parseInt(i,10))}function sn(i){return typeof i=="symbol"?"NaN":String(parseFloat(i))}var yt={s:i=>V(i),d:i=>nn(i),i:i=>rn(i),f:i=>sn(i),j:i=>V(i),o:i=>V(i),O:i=>V(i),c:()=>""};function ie(...i){var e;let t=i.shift();if(u.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 yt&&i.length){let c=i.shift();n+=(e=yt[o])==null?void 0:e.call(yt,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 an=["debug","info","warn","error","none"],R=class i{static get(){return new i({})}constructor(t){var e,n,r;if(this.yi=(n=v[(e=t.level)!=null?e:"info"])!=null?n:v.info,this.vi=(r=t.name)!=null?r:"LaunchDarkly",this.De=t.formatter,typeof t.destination=="object")this.be={[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.be={[v.debug]:s,[v.info]:s,[v.warn]:s,[v.error]:s}}}wi(...t){var e;try{return this.De?(e=this.De)==null?void 0:e.call(this,...t):ie(...t)}catch(n){return ie(...t)}}Ei(t,e){try{t(e)}catch(n){console.error(e)}}C(t,e){var n;if(t>=this.yi){let r=`${an[t]}: [${this.vi}]`;try{let s=(n=this.be)==null?void 0:n[t];s?this.Ei(s,`${r} ${this.wi(...e)}`):console.error(...e)}catch(s){console.error(...e)}}}error(...t){this.C(v.error,t)}warn(...t){this.C(v.warn,t)}info(...t){this.C(v.info,t)}debug(...t){this.C(v.debug,t)}},on={error:u.Function,warn:u.Function,info:u.Function,debug:u.Function},_=class{constructor(t,e){Object.entries(on).forEach(([n,r])=>{if(!r.is(t[n]))throw new Error(`Provided logger instance must support logger.${n}(...) method`)}),this.t=t,this.Di=e}C(t,e){try{this.t[t](...e)}catch(n){this.Di[t](...e)}}error(...t){this.C("error",t)}warn(...t){this.C("warn",t)}info(...t){this.C("info",t)}debug(...t){this.C("debug",t)}},fe=i=>{let t=new R({level:"info",destination:console.error,formatter:ie});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`}},cn=/^(\w|\.|-)+$/,ln=u.stringMatchingRegex(cn),hn={is:(i,t)=>ln.is(i)?i.length>64?{valid:!1,message:b.tagValueTooLong(t)}:{valid:!0}:{valid:!1,message:b.invalidTagValue(t)}},kt=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}=hn.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(" "))}},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 pe(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=Jt(t),this.polling=Jt(e),this.events=Jt(n),this.analyticsEventPath=r,this.diagnosticEventPath=s,this.includeAuthorizationHeader=a,this.payloadFilterKey=o}};U.DEFAULT_EVENTS="https://events.launchdarkly.com";function ge(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=pe(t),r=[...e];return i.payloadFilterKey&&r.push({key:"filter",value:i.payloadFilterKey}),ge(`${i.streaming}/${n}`,r)}function ni(i,t,e=[]){let n=pe(t),r=[...e];return i.payloadFilterKey&&r.push({key:"filter",value:i.payloadFilterKey}),ge(`${i.polling}/${n}`,r)}function qe(i,t,e=[]){let n=pe(t);return ge(`${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"}},P=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 un(i){return i===413?!0:Z(i)}function At(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 P(o))},i*1e3)}),cancel:()=>{n(),clearTimeout(e)}}}function me(i){return i==null?i:JSON.parse(JSON.stringify(i))}function Nt(i){return Math.trunc(i*1e3)}var dn=i=>JSON.stringify(i)==="{}",$t=(i,t)=>i&&Object.entries(i).reduce((e,[n,r])=>(r&&!dn(r)&&!(t!=null&&t.includes(n))&&(e[n]=typeof r=="object"?$t(r,t):r),e),{});function K(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(!K(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(!K(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(!K(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 N(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 Ft({status:i}){return i?Z(i):!0}var ye=(i,t)=>t.btoa(i).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"");var ve=async(i=1e3)=>new Promise(t=>{setTimeout(t,i)});var ne=class{constructor(t,e,n){this.m=e,this.bi=n,this.$t=[],this.ke=Date.now(),this.xe=this.ke,this.Le={diagnosticId:e.crypto.randomUUID(),sdkKeySuffix:t.length>6?t.substring(t.length-6):t}}createInitEvent(){var n,r,s;let t=this.m.info.sdkData(),e=this.m.info.platformData();return{kind:"diagnostic-init",id:this.Le,creationDate:this.ke,sdk:t,configuration:this.bi,platform:p({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.$t.push(r)}createStatsEventAndReset(t,e,n){let r=Date.now(),s={kind:"diagnostic",id:this.Le,creationDate:r,dataSinceDate:this.xe,droppedEvents:t,deduplicatedUsers:e,eventsInLastBatch:n,streamInits:this.$t};return this.$t=[],this.xe=r,s}},re;(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"})(re||(re={}));var fn=re,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:r}=t,{serviceEndpoints:{analyticsEventPath:s,diagnosticEventPath:a}}=n,{crypto:o,requests:c}=r;this.ki=p({},e),this.Se=qe(n.serviceEndpoints,s,[]),this.xi=qe(n.serviceEndpoints,a,[]),this.F=c,this.Li=o}async ut(t,e,n,r){let s={status:F.Succeeded},a=D(p({},this.ki),{"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.F.fetch(e,{headers:a,body:JSON.stringify(t),compressBodyIfPossible:!0,method:"POST",keepalive:!0}),h=Date.parse(l.get("date")||"");if(h&&(s.serverTime=h),c<=204)return s;if(o=new J(N({status:c,message:"some events were dropped"},"event posting")),!Z(c))return un(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 ve(),this.ut(t,this.Se,n,!1))}async sendEventData(t,e){let n=t===z.AnalyticsEvents?this.Li.randomUUID():void 0,r=t===z.AnalyticsEvents?this.Se:this.xi;return this.ut(e,r,n,!0)}};function St(i){return i.kind==="feature"}function pn(i){return i.kind==="identify"}function gn(i){return i.kind==="migration_op"}var ae=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 mn(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.Si=t,this.I=e,this.it=0,this.dt=0,this.ft={},this.pt={}}summarizeEvent(t){if(St(t)&&!t.excludeFromSummaries){this.E||(this.E=t.context);let e=mn(t),n=this.ft[e],r=this.pt[t.key];r||(r=new Set,this.pt[t.key]=r),t.context.kinds.forEach(s=>r.add(s)),n?n.increment():this.ft[e]=new ae(1,t.key,t.value,t.default,t.version,t.variation),(this.it===0||t.creationDate<this.it)&&(this.it=t.creationDate),t.creationDate>this.dt&&(this.dt=t.creationDate)}}getSummary(){var n;let t=Object.values(this.ft).reduce((r,s)=>{let a=r[s.key];a||(a={default:s.default,counters:[],contextKinds:[...this.pt[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.it,endDate:this.dt,features:t,kind:"summary",context:this.E!==void 0&&this.Si?(n=this.I)==null?void 0:n.filter(this.E):void 0};return this.Ci(),e}Ci(){this.it=0,this.dt=0,this.ft={},this.pt={}}},oe=class extends Error{constructor(t){super(t),this.name="LaunchDarklyInvalidSDKKeyError"}},ce=class{constructor(t,e){this.I=t,this.t=e,this.nt={}}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 r=this.nt[n];r||(this.nt[n]=new Ct(!0,this.I),r=this.nt[n]),r.summarizeEvent(t)}}getSummaries(){let t=this.nt;return this.nt={},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 yn(i){return i.getSummaries!==void 0}var le=class{constructor(t,e,n,r,s,a=!0,o=!1){this.r=t,this.gt=r,this.P=s,this.mt=[],this.Ce=0,this.Ft=0,this.Mt=0,this.Rt=!1,this.Ie=0,this.Ut=!1,this.Vt=null,this.Ii=t.eventsCapacity,this.t=e.basicConfiguration.logger,this.Pe=new se(e,n),this.I=new ee(t.allAttributesPrivate,t.privateAttributes.map(c=>new O(c))),o?this.rt=new ce(this.I,this.t):this.rt=new Ct,a&&this.start()}start(){var t,e;if(((t=this.gt)==null?void 0:t.flushInterval)!==void 0&&(this.Vt=setInterval(()=>{var n;(n=this.gt)==null||n.flush()},this.gt.flushInterval*1e3)),this.Pi=setInterval(async()=>{var n;try{await this.flush()}catch(r){(n=this.t)==null||n.debug(`Flush failed: ${r}`)}},this.r.flushInterval*1e3),this.P){let n=this.P.createInitEvent();this.Te(n),this.Oe=setInterval(()=>{let r=this.P.createStatsEventAndReset(this.Ft,this.Mt,this.Ie);this.Ft=0,this.Mt=0,this.Te(r)},this.r.diagnosticRecordingInterval*1e3)}(e=this.t)==null||e.debug("Started EventProcessor.")}Te(t){this.Pe.sendEventData(z.DiagnosticEvent,t)}close(){clearInterval(this.Pi),this.Vt&&clearInterval(this.Vt),this.Oe&&clearInterval(this.Oe)}async flush(){var e;if(this.Ut)throw new oe("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.mt;if(this.mt=[],yn(this.rt))this.rt.getSummaries().forEach(r=>{Object.keys(r.features).length&&t.push(r)});else{let n=this.rt.getSummary();Object.keys(n.features).length&&t.push(n)}t.length&&(this.Ie=t.length,(e=this.t)==null||e.debug("Flushing %d events",t.length),await this.ut(t))}sendEvent(t){var c;if(this.Ut)return;if(gn(t)){if(vt(t.samplingRatio)){let l=D(p({},t),{context:t.context?this.I.filter(t.context):void 0});l.samplingRatio===1&&delete l.samplingRatio,this.yt(l)}return}this.rt.summarizeEvent(t);let e=St(t),n=e&&t.trackEvents||!e,r=this.Ti(t),s=pn(t),a=(c=this.gt)==null?void 0:c.processContext(t.context);a||s||(this.Mt+=1),a&&!s&&this.yt(this.jt({kind:"index",creationDate:t.creationDate,context:t.context,samplingRatio:1},!1)),n&&vt(t.samplingRatio)&&this.yt(this.jt(t,!1)),r&&vt(t.samplingRatio)&&this.yt(this.jt(t,!0))}jt(t,e){switch(t.kind){case"feature":{let n={kind:e?"debug":"feature",creationDate:t.creationDate,context:this.I.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.I.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.I.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}}yt(t){var e;this.mt.length<this.Ii?(this.mt.push(t),this.Rt=!1):(this.Rt||(this.Rt=!0,(e=this.t)==null||e.warn("Exceeded event queue capacity. Increase capacity to avoid dropping events.")),this.Ft+=1)}Ti(t){return St(t)&&t.debugEventsUntilDate&&t.debugEventsUntilDate>this.Ce&&t.debugEventsUntilDate>Date.now()}async ut(t){let e=await this.Pe.sendEventData(z.AnalyticsEvents,t);if(e.status===F.FailedAndMustShutDown&&(this.Ut=!0),e.serverTime&&(this.Ce=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,h,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),h!==void 0&&(this.reason=h),d!==void 0&&(this.debugEventsUntilDate=d),f!==void 0&&(this.excludeFromSummaries=f)}},Pt=class{constructor(t,e=1){this.context=t,this.samplingRatio=e,this.kind="identify",this.creationDate=Date.now()}},he=class{close(){}async flush(){}sendEvent(){}},ue=class{constructor(t){this.Ht=t}evalEvent(t){var e;return new Y(this.Ht,t.context,t.flagKey,t.value,t.defaultVal,t.version,(e=t.variation)!=null?e:void 0,t.trackEvents||t.addExperimentData,t.prereqOfFlagKey,this.Ht||t.addExperimentData?t.reason:void 0,t.debugEventsUntilDate,t.excludeFromSummaries,t.samplingRatio)}unknownFlagEvent(t,e,n){return new Y(this.Ht,n,t,e,e,void 0,void 0,void 0,void 0,void 0,void 0,void 0,void 0)}identifyEvent(t){return new Pt(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 vn(i){return{Oi:i,Ae:"",useSelector(t){return this.Ae=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.Ae,version:1,id:Ye}}),this.Oi.processEvents(e)}}}var Tt=class{constructor(t,e,n){this.Ai=t,this.w=e,this.t=n,this.e=[],this.H=void 0,this._=!1,this.J=[],this.Ni=r=>{var a;if(this.zt(),!r.payloads.length)return;let s=r.payloads[0];switch(s==null?void 0:s.intentCode){case"xfer-full":this._=!0;break;case"xfer-changes":this._=!1;break;case"none":this._=!1,this.$i(s);break;default:(a=this.t)==null||a.warn(`Unable to process intent code '${s==null?void 0:s.intentCode}'.`);return}this.H=s==null?void 0:s.id},this.Fi=r=>{var a;if(!this.H||!r.kind||!r.key||!r.version||!r.object)return;let s=this.Mi(r.kind,r.object);if(!s){(a=this.t)==null||a.warn(`Unable to process object for kind: '${r.kind}'`);return}this.J.push({kind:r.kind,key:r.key,version:r.version,object:s})},this.Ri=r=>{!this.H||!r.kind||!r.key||!r.version||this.J.push({kind:r.kind,key:r.key,version:r.version,deleted:!0})},this.$i=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.Ne()},this.Ui=r=>{if(!this.H||r.state===null||r.state===void 0||!r.version){this.zt();return}let s={id:this.H,version:r.version,state:r.state,basis:this._,updates:this.J};this.e.forEach(a=>a(s)),this.Ne()},this.Vi=r=>{var s;(s=this.t)==null||s.info(`Goodbye was received from the LaunchDarkly connection with reason: ${r.reason}.`),this.zt()},this.ji=r=>{var s;(s=this.t)==null||s.info(`An issue was encountered receiving updates for payload ${this.H} with reason: ${r.reason}.`),this.Hi()}}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.Ni(e.data);break}case"put-object":{this.Fi(e.data);break}case"delete-object":{this.Ri(e.data);break}case"payload-transferred":{this.Ui(e.data);break}case"goodbye":{this.Vi(e.data);break}case"error":{this.ji(e.data);break}}})}Mi(t,e){var n,r;return(r=(n=this.Ai)[t])==null?void 0:r.call(n,e)}Ne(){this._=!1,this.J=[]}Hi(){this.J=[]}zt(){this.H=void 0,this._=!1,this.J=[]}},de=class{constructor(t,e,n,r){this.w=n,this.t=r,this.q(t,"server-intent"),this.q(t,"put-object"),this.q(t,"delete-object"),this.q(t,"payload-transferred"),this.q(t,"goodbye"),this.q(t,"error"),this.Bt=new Tt(e,n,r)}addPayloadListener(t){this.Bt.addPayloadListener(t)}removePayloadListener(t){this.Bt.removePayloadListener(t)}q(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.Bt.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.w)==null||o.call(this,w.InvalidData,"Malformed data in EventStream.")}}else(c=this.w)==null||c.call(this,w.Unknown,"Event from EventStream missing data.")})}};function wn(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 En(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 Dn(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:Lt,DiagnosticsManager:ne,ErrorKinds:fn,EventFactoryBase:ue,EventProcessor:le,FDv1PayloadAdaptor:vn,InputCustomEvent:It,InputEvalEvent:Y,InputIdentifyEvent:Pt,NullEventProcessor:he,PayloadProcessor:Tt,PayloadStreamReader:de,canonicalize:Dt,initMetadataFromHeaders:wn,isLegacyUser:ei,isMultiKind:ti,isSingleKind:Qe,safeGetHooks:En,safeGetName:Ot,safeRegisterPlugins:Dn,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 kn(i){return i>=200&&i<=299}var Mt=class extends Error{constructor(t,e){super(t),this.status=e,this.name="LaunchDarklyRequestError"}},Ee=class{constructor(t,e,n,r,s){this.F=t,this.zi=e,this.vt=n,this.Bi=r,this.Gi=s}async requestPayload(){let t;try{let e=await this.F.fetch(this.zi,{method:this.Bi,headers:this.vt,body:this.Gi});if(kn(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 Ne(i,t,e,n,r,s,a,o,c,l){let h,d="GET",f=p({},s);c&&(d="REPORT",f["content-type"]="application/json",h=i);let m=c?e.pathReport(r,i):e.pathGet(r,i),g=[...a!=null?a:[]];o&&g.push({key:"withReasons",value:"true"}),l&&g.push({key:"h",value:l});let y=ni(t,m,g);return new Ee(n,y,f,d,h)}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 xn(i,t,e=!1){let n,r=new Promise(o=>{n=(c,l)=>{var h;try{(h=i.after)==null||h.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 Ln(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=xn(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 Sn={logger:u.Object,maxCachedContexts:u.numberWithMin(0),baseUri:u.String,streamUri:u.String,eventsUri:u.String,capacity:u.numberWithMin(1),diagnosticRecordingInterval:u.numberWithMin(2),flushInterval:u.numberWithMin(2),streamInitialReconnectDelay:u.numberWithMin(0),allAttributesPrivate:u.Boolean,debug:u.Boolean,diagnosticOptOut:u.Boolean,withReasons:u.Boolean,sendEvents:u.Boolean,pollInterval:u.numberWithMin(30),useReport:u.Boolean,privateAttributes:u.StringArray,applicationInfo:u.Object,wrapperName:u.String,wrapperVersion:u.String,payloadFilterKey:u.stringMatchingRegex(/^[a-zA-Z0-9](\w|\.|-)*$/),hooks:u.createTypeArray("Hook[]",{}),inspectors:u.createTypeArray("LDInspection",{})},Cn=300,gi="https://clientsdk.launchdarkly.com",mi="https://clientstream.launchdarkly.com";function In(i){return i instanceof _?i:fe(i)}var De=class{constructor(t={},e={getImplementationHooks:()=>[],credentialType:"mobileKey"}){var r,s,a;this.logger=fe(),this.baseUri=gi,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=Cn,this.hooks=[],this.inspectors=[],this.logger=In(t.logger),this.Ki(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 kt({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}Ki(t){let e=[];return Object.entries(t).forEach(([n,r])=>{let s=Sn[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&&u.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 Pn(i,t){return Q([{value:"LaunchDarkly",transform:C},{value:t,transform:wi(i)}])}async function Tn(i){return Q([{value:"LaunchDarkly",transform:C},{value:"AnonymousKeys",transform:C},{value:i,transform:C}])}async function On(i){return Q([{value:"LaunchDarkly",transform:C},{value:"ContextKeys",transform:C},{value:i,transform:C}])}async function An(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:Nn,isSingleKind:we,isMultiKind:oi}=k,Ei="1.0",$n=i=>{let n=i,{kind:t}=n,e=Wt(n,["kind"]);return{kind:"multi",[t]:e}},Fn=async({crypto:i,info:t},{applicationInfo:e})=>{var a;let{ld_application:n}=t.platformData(),r=(a=$t(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=p(p(p(D(p({},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}},Mn=async i=>{var o,c,l,h;let{ld_device:t,os:e}=i.info.platformData(),n=(o=$t(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=(h=n.os)==null?void 0:h.family;if((r||s||a)&&(n.os=p(p(p({},r?{name:r}:{}),s?{version:s}:{}),a?{family:a}:{})),Object.keys(n).filter(d=>d!=="key"&&d!=="envAttributesVersion").length){let d=await On("ld_device");return n.key=await vi(d,i),n.envAttributesVersion=n.envAttributesVersion||Ei,n}},Rn=async(i,t,e)=>{if(Nn(i))return i;let n,r;if(we(i)&&i.kind!=="ld_application"||oi(i)&&!i.ld_application?n=await Fn(t,e):e.logger.warn("Not adding ld_application environment attributes because it already exists."),we(i)&&i.kind!=="ld_device"||oi(i)&&!i.ld_device?r=await Mn(t):e.logger.warn("Not adding ld_device environment attributes because it already exists."),n||r){let s=we(i)?$n(i):i;return p(p(p({},s),n?{ld_application:n}:{}),r?{ld_device:r}:{})}return i};function Un(){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:Vn,isMultiKind:jn,isSingleKind:Hn}=k,$e=async(i,t,e)=>{let{anonymous:n,key:r}=t;if(n&&!r){let s=await Tn(i);t.key=await vi(s,e)}},zn=async(i,t)=>{await $e(i.kind,i,t)},Bn=async(i,t)=>{let r=i,{kind:e}=r,n=Wt(r,["kind"]);return Promise.all(Object.entries(n).map(([s,a])=>$e(s,a,t)))},Gn=async(i,t)=>{await $e("user",i,t)},Kn=async(i,t)=>{let e=me(i);return Hn(e)&&await zn(e,t),jn(e)&&await Bn(e,t),Vn(e)&&await Gn(e,t),e},Wn=i=>({customBaseURI:i.serviceEndpoints.polling!==gi,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}),_n=(i,t,e)=>{if(t.sendEvents&&!t.diagnosticOptOut)return new k.DiagnosticsManager(i,e,Wn(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 Jn=(i,t,e,n,r)=>{if(t.sendEvents)return new k.EventProcessor(D(p({},t),{eventsCapacity:t.capacity}),new xt(i,t,e),n,void 0,r,!1,!0)},Rt=class extends k.EventFactoryBase{evalEventClient(t,e,n,r,s,a){let{trackEvents:o,debugEventsUntilDate:c,trackReason:l,flagVersion:h,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:h!=null?h: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)):[]}},be=class{constructor(t,e,n,r,s,a,o=()=>Date.now()){this.m=t,this.Gt=e,this.Wi=n,this.y=r,this.b=s,this.t=a,this.wt=o,this.$e=An(this.Gt)}async init(t,e){this.b.init(t,e),await this.Fe(t)}async upsert(t,e,n){return this.b.upsert(t,e,n)?(await this.Fe(t),!0):!1}async loadCached(t){var r,s,a,o;let e=await ai(this.m.crypto,this.Gt,t),n=await((r=this.m.storage)==null?void 0:r.get(e));if(n==null){if(n=await((s=this.m.storage)==null?void 0:s.get(t.canonicalKey)),n==null)return!1;await((a=this.m.storage)==null?void 0:a.set(e,n)),await((o=this.m.storage)==null?void 0:o.clear(t.canonicalKey))}try{let c=JSON.parse(n),l=Object.entries(c).reduce((h,[d,f])=>(h[d]={version:f.version,flag:f},h),{});return this.b.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 _i(){var e;if(this.Y!==void 0)return this.Y;let t=await((e=this.m.storage)==null?void 0:e.get(await this.$e));if(!t)return this.Y=new X,this.Y;try{this.Y=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.Y=new X}return this.Y}async Fe(t){var c,l;let e=await this._i(),n=await ai(this.m.crypto,this.Gt,t);e.notice(n,this.wt());let r=e.prune(this.Wi);await Promise.all(r.map(async h=>{var d;return(d=this.m.storage)==null?void 0:d.clear(h.id)})),await((c=this.m.storage)==null?void 0:c.set(await this.$e,e.toJson()));let s=this.y.getAll(),a=Object.entries(s).reduce((h,[d,f])=>(f.flag!==null&&f.flag!==void 0&&(h[d]=f.flag),h),{}),o=JSON.stringify(a);await((l=this.m.storage)==null?void 0:l.set(n,o))}},ke=class{constructor(){this.st={}}init(t){this.st=Object.entries(t).reduce((e,[n,r])=>(e[n]=r,e),{})}insertOrUpdate(t,e){this.st[t]=e}get(t){if(Object.prototype.hasOwnProperty.call(this.st,t))return this.st[t]}getAll(){return this.st}};function qn(i,t){let e=[];return Object.entries(i).forEach(([n,r])=>{let s=t[n];(!s||!K(r,s))&&e.push(n)}),Object.keys(t).forEach(n=>{i[n]||e.push(n)}),e}var xe=class{constructor(t,e){this.Et=new Array,this.y=t,this.t=e}handleFlagChanges(t,e){this.Dt?this.Et.forEach(n=>{try{n(this.Dt,t,e)}catch(r){}}):this.t.warn("Received a change event without an active context. Changes will not be propagated.")}init(t,e){this.Dt=t;let n=this.y.getAll();this.y.init(e);let r=qn(n,e);r.length>0&&this.handleFlagChanges(r,"init")}initCached(t,e){var n;((n=this.Dt)==null?void 0:n.canonicalKey)!==t.canonicalKey&&this.init(t,e)}upsert(t,e,n){var s;if(((s=this.Dt)==null?void 0:s.canonicalKey)!==t.canonicalKey)return this.t.warn("Received an update for an inactive context."),!1;let r=this.y.get(e);return r!==void 0&&r.version>=n.version?!1:(this.y.insertOrUpdate(e,n),this.handleFlagChanges([e],"patch"),!0)}on(t){this.Et.push(t)}off(t){let e=this.Et.indexOf(t);e>-1&&this.Et.splice(e,1)}},Le=class{constructor(t,e,n,r,s=()=>Date.now()){this.y=new ke,this.b=new xe(this.y,r),this.Kt=this.Ji(t,e,n,r,s)}async Ji(t,e,n,r,s=()=>Date.now()){let a=await Pn(t.crypto,e);return new be(t,a,n,this.y,this.b,r,s)}get(t){return this.a&&Object.prototype.hasOwnProperty.call(this.a,t)?this.Wt(this.a[t]):this.y.get(t)}getAll(){return this.a?p(p({},this.y.getAll()),Object.entries(this.a).reduce((t,[e,n])=>(t[e]=this.Wt(n),t),{})):this.y.getAll()}presetFlags(t){this.y.init(t)}setBootstrap(t,e){this.b.init(t,e)}async init(t,e){return(await this.Kt).init(t,e)}async upsert(t,e,n){return(await this.Kt).upsert(t,e,n)}async loadCached(t){return(await this.Kt).loadCached(t)}on(t){this.b.on(t)}off(t){this.b.off(t)}Wt(t){return{flag:{value:t,version:0},version:0}}setOverride(t,e){this.a||(this.a={}),this.a[t]=e,this.b.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.b.handleFlagChanges([t],"override"))}clearAllOverrides(){if(this.a){let t=p({},this.a);this.a=void 0,this.b.handleFlagChanges(Object.keys(t),"override")}}getAllOverrides(){if(!this.a)return{};let t={};return Object.entries(this.a).forEach(([e,n])=>{t[e]=this.Wt(n)}),t}getDebugOverride(){return{setOverride:this.setOverride.bind(this),removeOverride:this.removeOverride.bind(this),clearAllOverrides:this.clearAllOverrides.bind(this),getAllOverrides:this.getAllOverrides.bind(this)}}},hi="unknown hook",Di="beforeEvaluation",bi="afterEvaluation",Yn="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||hi}catch(e){return i.error("Exception thrown getting metadata for hook. Unable to get hook name."),hi}}function Zn(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 Xn(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 Qn(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 tr(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 er(i,t,e){for(let n=t.length-1;n>=0;n-=1){let r=t[n];tt(i,Yn,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.z=[],this.z.push(...e)}withEvaluation(t,e,n,r){if(this.z.length===0)return r();let s=[...this.z],a={flagKey:t,context:e,defaultValue:n},o=Zn(this.t,s,a),c=r();return Xn(this.t,s,a,o,c),c}identify(t,e){let n=[...this.z],r={context:t,timeout:e},s=Qn(this.t,n,r);return a=>{tr(this.t,n,r,s,a)}}addHook(t){this.z.push(t)}afterTrack(t){if(this.z.length===0)return;let e=[...this.z];er(this.t,e,t)}};function ir(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 nr(i,t){return`an inspector: "${t}" of an invalid type (${i}) was configured`}function rr(i,t){return`an inspector: "${t}" of type: "${i}" generated an exception`}function sr(i,t){let e=!1,n={method:(...r)=>{try{i.method(...r)}catch(s){e||(e=!0,t.warn(rr(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",ar=[ki,xi,Li,Si];function or(i,t){let e=ar.includes(i.type)&&i.method&&typeof i.method=="function";return e||t.warn(nr(i.type,i.name)),e}var Ce=class{constructor(t,e){this.Z=[];let n=t.filter(r=>or(r,e));this.Z=n.map(r=>sr(r,e))}hasInspectors(){return this.Z.length!==0}onFlagUsed(t,e,n){this.Z.forEach(r=>{r.type===ki&&r.method(t,e,n)})}onFlagsChanged(t){this.Z.forEach(e=>{e.type===xi&&e.method(t)})}onFlagChanged(t,e){this.Z.forEach(n=>{n.type===Li&&n.method(t,e)})}onIdentityChanged(t){this.Z.forEach(e=>{e.type===Si&&e.method(t)})}},Ie=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)}}_t(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._t(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 cr(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:ui,ErrorKinds:di}=k,lr=5,Ut=class{constructor(t,e,n,r,s,a){if(this.sdkKey=t,this.autoEnvAttributes=e,this.platform=n,this.l=Un(),this.Jt=15,this.M=new Rt(!1),this.bt=new Rt(!0),this.qt=!1,this.qi=Ln(),!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 De(r,a),this.logger=this.r.logger,this.Me=ri(this.sdkKey,this.platform.info,this.r.tags,this.r.serviceEndpoints.includeAuthorizationHeader,this.r.userAgentHeaderName),this.k=new Le(this.platform,t,this.r.maxCachedContexts,this.r.logger),this.P=_n(t,this.r,n),this.x=Jn(t,this.r,n,this.Me,this.P),this.emitter=new Ie,this.emitter.on("error",(c,l)=>{this.logger.error(`error: ${l}, context: ${JSON.stringify(c)}`)}),this.k.on((c,l,h)=>{this.Yi(l,h);let d=S.toLDContext(c);this.emitter.emit("change",d,l),l.forEach(f=>{this.emitter.emit(`change:${f}`,d)})}),this.dataManager=s(this.k,this.r,this.Me,this.emitter,this.P);let o=[...this.r.hooks];this.environmentMetadata=cr(this.sdkKey,this.platform,this.r),this.r.getImplementationHooks(this.environmentMetadata).forEach(c=>{o.push(c)}),this.B=new Se(this.logger,o),this.at=new Ce(this.r.inspectors,this.logger),this.at.hasInspectors()&&this.B.addHook(ir(this.at))}allFlags(){return Object.entries(this.k.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.x)==null||t.close(),this.dataManager.close(),this.logger.debug("Closed event processor and data source.")}async flush(){var t;try{await((t=this.x)==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()?me(this.l.getUnwrappedContext()):void 0}getInternalContext(){return this.l.getContext()}presetFlags(t){this.k.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 P(`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:lr,r=(e==null?void 0:e.timeout)===void 0&&(e==null?void 0:e.noTimeout)===!0;n>this.Jt&&this.logger.warn(`The identify function was called with a timeout greater than ${this.Jt} seconds. We recommend a timeout of less than ${this.Jt} seconds.`);let s=this.qi.execute({before:async()=>{let l=await Kn(t,this.platform);this.autoEnvAttributes===H.Enabled&&(l=await Rn(l,this.platform,this.r));let h=S.fromLDContext(l);if(h.valid){let d=this.B.identify(l,e==null?void 0:e.timeout);return{context:l,checkedContext:h,afterIdentify:d}}return{context:l,checkedContext:h}},execute:async l=>{var y;let{context:h,checkedContext:d}=l;if(!d.valid){let x=new Error("Context was unspecified or had no key");return this.emitter.emit("error",h,x),Promise.reject(x)}this.l.set(h,d),(y=this.x)==null||y.sendEvent(this.M.identifyEvent(d));let{identifyPromise:f,identifyResolve:m,identifyReject:g}=this.l.newIdentificationPromise();return this.logger.debug(`Identifying ${JSON.stringify(d)}`),await this.dataManager.identify(m,g,d,e),f},after:async(l,h)=>{var d,f,m;l.status==="complete"?(d=h==null?void 0:h.afterIdentify)==null||d.call(h,{status:"completed"}):l.status==="shed"?(f=h==null?void 0:h.afterIdentify)==null||f.call(h,{status:"shed"}):l.status==="error"&&((m=h==null?void 0:h.afterIdentify)==null||m.call(h,{status:"error"}))}},(c=e==null?void 0:e.sheddable)!=null?c:!1).then(l=>l.status==="error"?{status:"error",error:l.error}:l.status==="shed"?{status:"shed"}:(this.emitter.emit("initialized"),{status:"completed"}));if(r)return s;let a=new Promise(l=>{setTimeout(()=>{l({status:"timeout",timeout:n})},n*1e3)});return Promise.race([s,a])}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(ui.MissingContextKeyNoEvent);return}n!==void 0&&!u.Number.is(n)&&((r=this.logger)==null||r.warn(ui.invalidMetricValue(typeof n))),(s=this.x)==null||s.sendEvent(this.r.trackEventModifier(this.M.customEvent(t,this.l.getContext(),e,n))),this.B.afterTrack({key:t,context:this.l.getUnwrappedContext(),data:e,metricValue:n})}kt(t,e,n,r){var m,g,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.k.get(t);if(o===void 0||o.flag.deleted){let L=e!=null?e:null,G=new q(`Unknown feature flag "${t}"; returning default value ${L}.`);return this.emitter.emit("error",this.l.getUnwrappedContext(),G),s&&((g=this.x)==null||g.sendEvent(this.M.unknownFlagEvent(t,L,a))),ci(di.FlagNotFound,e)}let{reason:c,value:l,variation:h,prerequisites:d}=o.flag;if(r){let[L,G]=r(l);if(!L){s&&((y=this.x)==null||y.sendEvent(n.evalEventClient(t,e,e,o.flag,a,c)));let I=new q(`Wrong type "${G}" for feature flag "${t}"; returning default value`);return this.emitter.emit("error",this.l.getUnwrappedContext(),I),ci(di.WrongType,e)}}let f=li(l,h,c);return l==null&&(this.logger.debug("Result value is null. Providing default value."),f.value=e),d==null||d.forEach(L=>{this.kt(L,void 0,this.M)}),s&&((x=this.x)==null||x.sendEvent(n.evalEventClient(t,l,e,o.flag,a,c))),f}variation(t,e){let{value:n}=this.B.withEvaluation(t,this.l.getUnwrappedContext(),e,()=>this.kt(t,e,this.M));return n}variationDetail(t,e){return this.B.withEvaluation(t,this.l.getUnwrappedContext(),e,()=>this.kt(t,e,this.bt))}X(t,e,n,r){return this.B.withEvaluation(t,this.l.getUnwrappedContext(),e,()=>this.kt(t,e,n,r))}boolVariation(t,e){return this.X(t,e,this.M,n=>[u.Boolean.is(n),u.Boolean.getType()]).value}jsonVariation(t,e){return this.variation(t,e)}numberVariation(t,e){return this.X(t,e,this.M,n=>[u.Number.is(n),u.Number.getType()]).value}stringVariation(t,e){return this.X(t,e,this.M,n=>[u.String.is(n),u.String.getType()]).value}boolVariationDetail(t,e){return this.X(t,e,this.bt,n=>[u.Boolean.is(n),u.Boolean.getType()])}numberVariationDetail(t,e){return this.X(t,e,this.bt,n=>[u.Number.is(n),u.Number.getType()])}stringVariationDetail(t,e){return this.X(t,e,this.bt,n=>[u.String.is(n),u.String.getType()])}jsonVariationDetail(t,e){return this.variationDetail(t,e)}addHook(t){this.B.addHook(t)}setEventSendingEnabled(t,e){var n,r,s,a;this.qt!==t&&(this.qt=t,t?(this.logger.debug("Starting event processor"),(n=this.x)==null||n.start()):e?((r=this.logger)==null||r.debug("Flushing event processor before disabling."),this.flush().then(()=>{var o,c;this.qt||((o=this.logger)==null||o.debug("Stopping event processor."),(c=this.x)==null||c.close())})):((s=this.logger)==null||s.debug("Stopping event processor."),(a=this.x)==null||a.close()))}sendEvent(t){var e;(e=this.x)==null||e.sendEvent(t)}getDebugOverrides(){var t,e;return(e=(t=this.k).getDebugOverride)==null?void 0:e.call(t)}Yi(t,e){if(!this.at.hasInspectors())return;let n={};t.forEach(r=>{let s=this.k.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.at.onFlagsChanged(n):e==="patch"&&Object.entries(n).forEach(([r,s])=>{this.at.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 Pe=class{constructor(t,e,n){this.k=t,this.Yt=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.k.init(t,n),this.Yt.requestStateUpdate(E.Valid)}async handlePatch(t,e){this.t.debug(`Got PATCH ${JSON.stringify(e,null,2)}`),this.k.upsert(t,e.key,{version:e.version,flag:e})}async handleDelete(t,e){this.t.debug(`Got DELETE ${JSON.stringify(e,null,2)}`),this.k.upsert(t,e.key,{version:e.version,flag:D(p({},e),{deleted:!0,flagVersion:0,value:void 0,variation:0,trackEvents:!1})})}handleStreamingError(t){this.Yt.reportError(t.kind,t.message,t.code,t.recoverable)}handlePollingError(t){this.Yt.reportError(t.kind,t.message,t.status,t.recoverable)}},Te=class{constructor(t,e=()=>Date.now()){this.R=t,this.xt=E.Closed,this.Re=e(),this.wt=e}get status(){return{state:this.xt,stateSince:this.Re,lastError:this.Zi}}Ue(t,e=!1){let n=t===E.Interrupted&&this.xt===E.Initializing?E.Initializing:t,r=this.xt!==n;r&&(this.xt=n,this.Re=this.wt()),(r||e)&&this.R.emit("dataSourceStatus",this.status)}requestStateUpdate(t){this.Ue(t)}reportError(t,e,n,r=!1){let s={kind:t,message:e,statusCode:n,time:this.wt()};this.Zi=s,this.Ue(r?E.Interrupted:E.Closed,!0)}};function fi(i){i==null||i.debug("Poll completed after the processor was closed. Skipping processing.")}var Oe=class{constructor(t,e,n,r,s){this.Xi=t,this.Qi=e,this.tn=n,this.w=r,this.t=s,this.p=!1}async Ve(){var s,a,o,c,l,h,d;if(this.p)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.w)==null||y.call(this,new M(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.Xi.requestPayload();try{if(this.p){fi(this.t);return}let m=JSON.parse(f);try{(a=this.tn)==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.p){fi(this.t);return}let m=f;if(m.status!==void 0&&!Z(m.status)){(c=this.t)==null||c.error(N(f,"polling request")),(l=this.w)==null||l.call(this,new M(w.ErrorResponse,m.message,m.status));return}(h=this.t)==null||h.error(N(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.Zt=setTimeout(()=>{this.Ve()},r)}start(){this.Ve()}stop(){this.Zt&&(clearTimeout(this.Zt),this.Zt=void 0),this.p=!0}close(){this.stop()}},hr=(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 ur(i,t){t==null||t.debug(`Received ${i} event after processor was closed. Skipping processing.`)}function pi(i){i==null||i.debug("Ping completed after processor was closed. Skipping processing.")}var Ae=class{constructor(t,e,n,r,s,a,o,c,l){var f;this.en=t,this.Xt=e,this.e=n,this.F=r,this.nn=a,this.P=o,this.w=c,this.t=l,this.p=!1;let h;e.useReport&&!r.getEventSourceCapabilities().customMethod?h=e.paths.pathPing(s,t):h=e.useReport?e.paths.pathReport(s,t):e.paths.pathGet(s,t);let d=[...(f=e.queryParameters)!=null?f:[]];this.Xt.withReasons&&d.push({key:"withReasons",value:"true"}),this.F=r,this.vt=p({},e.baseHeaders),this.t=l,this.rn=ii(e.serviceEndpoints,h,d)}je(){this.Lt=Date.now()}Qt(t){this.Lt&&this.P&&this.P.recordStreamInit(this.Lt,!t,Date.now()-this.Lt),this.Lt=void 0}sn(t){var e,n,r;return Ft(t)?((r=this.t)==null||r.warn(N(t,"streaming request","will retry")),this.Qt(!1),this.je(),!0):(this.Qt(!1),(e=this.w)==null||e.call(this,new j(w.ErrorResponse,t.message,t.status,!1)),(n=this.t)==null||n.error(N(t,"streaming request")),!1)}start(){this.je();let t;this.Xt.useReport?(this.vt["content-type"]="application/json",t={method:"REPORT",body:this.en}):t={};let e=this.F.createEventSource(this.rn,D(p({headers:this.vt},t),{errorFilter:n=>this.sn(n),initialRetryDelayMillis:this.Xt.initialRetryDelayMillis,readTimeoutMillis:300*1e3,retryResetIntervalMillis:60*1e3}));this.He=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.p){ur(s,this.t);return}if((o=this.t)==null||o.debug(`Received ${s} event`),a!=null&&a.data){this.Qt(!0);let{data:l}=a,h=n(l);if(!h){hr(s,l,this.t,this.w);return}r(h)}else(c=this.w)==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 h=await this.nn.requestPayload();try{if(this.p){pi(this.t);return}let d=JSON.parse(h);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: ${h}`),(c=this.w)==null||c.call(this,new M(w.InvalidData,"Malformed JSON data in ping polling response"))}}catch(h){if(this.p){pi(this.t);return}let d=h;(l=this.w)==null||l.call(this,new M(w.ErrorResponse,d.message,d.status))}})}stop(){var t;(t=this.He)==null||t.close(),this.He=void 0,this.p=!0}close(){this.stop()}},Vt=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.Q=new Pe(e,this.dataSourceStatusManager,this.config.logger)}setConnectionParams(t){this.an=t}createPollingProcessor(t,e,n,r,s){let a=new Oe(n,this.config.pollInterval,async o=>{await this.Q.handlePut(e,o),r==null||r()},o=>{this.emitter.emit("error",t,o),this.Q.handlePollingError(o),s==null||s(o)},this.logger);this.updateProcessor=this.ze(a,this.dataSourceStatusManager)}createStreamingProcessor(t,e,n,r,s){var o;let a=new Ae(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.an)==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.Q.handleStreamingError(c),s==null||s(c)},this.logger);this.updateProcessor=this.ze(a,this.dataSourceStatusManager)}createStreamListeners(t,e){let n=new Map;return n.set("put",{deserializeData:JSON.parse,processJson:async r=>{await this.Q.handlePut(t,r),e==null||e()}}),n.set("patch",{deserializeData:JSON.parse,processJson:async r=>{this.Q.handlePatch(t,r)}}),n.set("delete",{deserializeData:JSON.parse,processJson:async r=>{this.Q.handleDelete(t,r)}}),n}ze(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 jt(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=p({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 zt(i,t,e){return Ht()?(document.addEventListener(i,t,e),()=>{document.removeEventListener(i,t,e)}):()=>{}}function Bt(i,t,e){return Ht()?(window.addEventListener(i,t,e),()=>{window.removeEventListener(i,t,e)}):()=>{}}function T(){return Fe()?window.location.href:""}function Ii(){return Fe()?window.location.search:""}function Pi(){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 Oi(){return Ht()?document.visibilityState:"visibile"}function Ai(i){if(Ht())return document.querySelectorAll(i)}var dr="[BrowserDataManager]",it=class extends Vt{constructor(e,n,r,s,a,o,c,l,h,d){super(e,n,r,s,o,c,l,h,d);this.Dn=a;this.ot=void 0;this.te=!1;this.ot=a.streaming}T(e,...n){this.logger.debug(`${dr} ${e}`,...n)}async identify(e,n,r,s){if(this.closed){this.T("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.ee=a==null?void 0:a.hash,a!=null&&a.bootstrap?this.cn(r,a.bootstrap,e):(await this.flagManager.loadCached(r)&&this.T("Identify - Flags loaded from cache. Continuing to initialize via a poll."),await this.ln(r,e,n)),this.ie()}async hn(e){let n=JSON.stringify(S.toLDContext(e)),r=Ne(n,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.ee),s=3,a;for(let o=0;o<=s;o+=1)try{return await r.requestPayload()}catch(c){if(!Ft(c))throw c;a=c,o<s&&(this.T(N(c,"initial poll request","will retry")),await ve(1e3))}throw a}async ln(e,n,r){var s,a;try{this.dataSourceStatusManager.requestStateUpdate(E.Initializing);let o=await this.hn(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)}}cn(e,n,r){this.flagManager.setBootstrap(e,jt(this.logger,n)),this.T("Identify - Initialization completed from bootstrap"),r()}setForcedStreaming(e){this.ot=e,this.ie()}setAutomaticStreamingState(e){this.te=e,this.ie()}ie(){let e=this.ot||this.te&&this.ot===void 0;this.T(`Updating streaming state. forced(${this.ot}) automatic(${this.te})`),e?this.un():this.dn()}dn(){var e;this.updateProcessor&&this.T("Stopping update processor."),(e=this.updateProcessor)==null||e.close(),this.updateProcessor=void 0}un(){if(this.updateProcessor){this.T("Update processor already active. Not changing state.");return}if(!this.context){this.T("Context not set, not starting update processor.");return}this.T("Starting update processor."),this.fn(this.context)}fn(e,n,r){var c;let s=S.toLDContext(e);(c=this.updateProcessor)==null||c.close();let a=JSON.stringify(S.toLDContext(e)),o=Ne(a,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.ee);this.createStreamingProcessor(s,e,o,n,r),this.updateProcessor.start()}};function Ni(i){let e=zt("visibilitychange",()=>{Oi()==="hidden"&&i()}),n=Bt("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 fr(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 pr(i,t){let e=[];return t.forEach(n=>{let r=i.target,{selector:s}=n,a=Ai(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=>fr(c,T(),Ii(),Pi()))}),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=>{pr(o,s).forEach(c=>{e(c)})};this.Be=zt("click",a)}}close(){var t;(t=this.Be)==null||t.call(this)}};var gr=300,Gt=class{constructor(t){this.ne=T();let e=()=>{let r=T();r!==this.ne&&(this.ne=r,t())};this.re=setInterval(e,gr);let n=Bt("popstate",e);this.Ge=()=>{n()}}close(){var t;this.re&&clearInterval(this.re),(t=this.Ge)==null||t.call(this)}};var st=class{constructor(t,e,n,r,s,a=o=>new Gt(o)){this.F=e;this.mn=r;this.gn=s;this.St=[];this.We=!1;this.Ct=`${n}/sdk/goals/${t}`,this.Ke=a(()=>{this.ae()})}async initialize(){await this.pn(),this.ae()}startTracking(){this.We=!0,this.ae()}ae(){var t;this.We&&((t=this.se)==null||t.close(),this.St&&this.St.length&&(this.se=new rt(this.St,e=>{this.gn(T(),e)})))}async pn(){try{let t=await this.F.fetch(this.Ct);this.St=await t.json()}catch(t){this.mn(new J(`Encountered error fetching goals: ${t}`))}}close(){var t,e;(t=this.Ke)==null||t.close(),(e=this.se)==null||e.close()}};function $i(i){return i.kind==="click"}var mr=2,Fi={fetchGoals:!0,eventUrlTransformer:i=>i,streaming:void 0,plugins:[]},yr={fetchGoals:u.Boolean,eventUrlTransformer:u.Function,streaming:u.Boolean,plugins:u.createTypeArray("LDPlugin",{})};function vr(i){var e;let t=p({},i);return(e=t.flushInterval)!=null||(t.flushInterval=mr),t}function Mi(i){let t=vr(i);return Object.keys(Fi).forEach(e=>{delete t[e]}),t}function Me(i,t){let e=p({},Fi);return Object.entries(yr).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.yn=t;this._e=[];switch(e){case"sha1":this.oe="SHA-1";break;case"sha256":this.oe="SHA-256";break;default:throw new Error(`Algorithm is not supported ${e}`)}}async asyncDigest(t){let e=this._e.join(""),n=new TextEncoder().encode(e),r=await this.yn.subtle.digest(this.oe,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._e.push(t),this}};var wr={start:0,end:3},Er={start:4,end:5},Re={start:6,end:7},Ue={start:8,end:8},Dr={start:9,end:9},br={start:10,end:15};function kr(){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 xr(i){return i[Ue.start]=(i[Ue.start]|128)&191,i[Re.start]=i[Re.start]&15|64,`${B(i,wr)}-${B(i,Er)}-${B(i,Re)}-${B(i,Ue)}${B(i,Dr)}-${B(i,br)}`}function Lr(){let i=kr();return xr(i)}function Ve(){return typeof crypto!==void 0&&typeof crypto.randomUUID=="function"?crypto.randomUUID():Lr()}var ot=class{createHash(t){return new at(Ti(),t)}randomUUID(){return Ve()}};function Sr(i){let t=Array.from(i,e=>String.fromCodePoint(e)).join("");return btoa(t)}var ct=class{btoa(t){return Sr(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.11.0",userAgentBase:"JSClient"};return this.r.wrapperName&&(t.wrapperName=this.r.wrapperName),this.r.wrapperVersion&&(t.wrapperVersion=this.r.wrapperVersion),t}};var ht=class{constructor(t,e){this.Ct=t;this.e={};this.N=new bt(e.initialRetryDelayMillis,e.retryResetIntervalMillis),this.Je=e.errorFilter,this.qe()}qe(){this.tt=new EventSource(this.Ct),this.tt.onopen=()=>{var t;this.N.success(),(t=this.onopen)==null||t.call(this)},this.tt.onerror=t=>{var e;this.vn(t),(e=this.onerror)==null||e.call(this,t)},Object.entries(this.e).forEach(([t,e])=>{e.forEach(n=>{var r;(r=this.tt)==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.tt)==null||s.addEventListener(t,e)}close(){var t,e;clearTimeout(this.ce),this.ce=void 0,(t=this.tt)==null||t.close(),(e=this.onclose)==null||e.call(this)}wn(t){var e;(e=this.onretrying)==null||e.call(this,{delayMillis:t}),this.ce=setTimeout(()=>{this.qe()},t)}vn(t){this.close(),!(t.status&&typeof t.status=="number"&&!this.Je(t))&&this.wn(this.N.fail())}};var ut=class{fetch(t,e){return fetch(t,e)}createEventSource(t,e){return new ht(t,e)}getEventSourceCapabilities(){return{customMethod:!1,readTimeout:!1,headers:!1}}};function Ri(){return typeof localStorage!="undefined"}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 ut;Ri()&&(this.storage=new dt(t)),this.info=new lt(e)}};var je=class extends Ut{constructor(t,e,n={},r){var m;let{logger:s,debug:a}=n,o=s!=null?s: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",l=r!=null?r:new ft(o,n),h=Me(n,o),d=Mi(D(p({},n),{logger:o})),{eventUrlTransformer:f}=h;super(t,e,l,d,(g,y,x,L,G)=>new it(l,g,t,y,h,()=>({pathGet(I,$){return`/sdk/evalx/${t}/contexts/${ye($,I)}`},pathReport(I,$){return`/sdk/evalx/${t}/context`},pathPing(I,$){throw new Error("Ping for polling unsupported.")}}),()=>({pathGet(I,$){return`/eval/${t}/${ye($,I)}`},pathReport(I,$){return`/eval/${t}`},pathPing(I,$){return`/ping/${t}`}}),x,L,G),{analyticsEventPath:`/events/bulk/${t}`,diagnosticEventPath:`/events/diagnostic/${t}`,includeAuthorizationHeader:!1,highTimeoutThreshold:5,userAgentHeaderName:"x-launchdarkly-user-agent",trackEventModifier:g=>new k.InputCustomEvent(g.context,g.key,g.data,g.metricValue,g.samplingRatio,f(T())),getImplementationHooks:g=>k.safeGetHooks(o,g,h.plugins),credentialType:"clientSideId"}),this.setEventSendingEnabled(!0,!1),this.he=h.plugins,h.fetchGoals&&(this.le=new st(t,l.requests,c,g=>{o.error(g.message)},(g,y)=>{let x=this.getInternalContext();if(!x)return;let L=f(g);$i(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.le.initialize(),h.automaticBackgroundHandling&&Ni(()=>this.flush()))}registerPlugins(t){k.safeRegisterPlugins(this.logger,this.environmentMetadata,t,this.he||[]);let e=this.getDebugOverrides();e&&Ci(this.logger,e,this.he||[])}setInitialContext(t){this.ue=t}async identify(t,e){return super.identify(t,e)}async identifyResult(t,e){var s,a,o;if(!this.ct)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=p({},e);(e==null?void 0:e.sheddable)===void 0&&(n.sheddable=!0);let r=await super.identifyResult(t,n);return r.status==="completed"?(this.U={status:"complete"},(s=this.G)==null||s.call(this,this.U)):r.status==="error"&&(this.U={status:"failed",error:r.error},(a=this.G)==null||a.call(this,this.U)),(o=this.le)==null||o.startTracking(),r}start(t){var n,r;if(this.U)return Promise.resolve(this.U);if(this.ct)return this.ct;if(!this.ue)return this.logger.error("Initial context not set"),Promise.resolve({status:"failed",error:new Error("Initial context not set")});let e=D(p({},(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=jt(this.logger,e.bootstrap);this.presetFlags(s)}catch(s){this.logger.error("Failed to bootstrap data",s)}return this.h||(this.h=new Promise(s=>{this.G=s})),this.ct=this.et(this.h,(r=t==null?void 0:t.timeout)!=null?r:5),this.identifyResult(this.ue,e),this.ct}waitForInitialization(t){var n;let e=(n=t==null?void 0:t.timeout)!=null?n:5;return this.U?Promise.resolve(this.U):this.h?this.et(this.h,e):(this.h||(this.h=new Promise(r=>{this.G=r})),this.et(this.h,e))}et(t,e){let n=At(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}})}setStreaming(t){this.dataManager.setForcedStreaming(t)}Ye(){this.dataManager.setAutomaticStreamingState(!!this.emitter.listenerCount("change"))}on(t,e){super.on(t,e),this.Ye()}off(t,e){super.off(t,e),this.Ye()}};function Ui(i,t,e,n={},r){let s=new je(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"],pt=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)}_t(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._t(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 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 gt=class{constructor(t,e,n){this.de="initializing";let r=n==null?void 0:n.bootstrap,s=n==null?void 0:n.hash,a=p({},n);delete a.bootstrap,delete a.hash,this.n=Ui(t,e,H.Disabled,n),this.R=new pt(this.n),this.logger=this.n.logger,this.n.start(),this.En(e,r,s)}async En(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 P("Identify timed out");this.de="success",(r=this.G)==null||r.call(this),this.R.emit("initialized")}catch(a){this.Xe=a,this.de="failure",(s=this.Ze)==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 Kt(this.n.identify(t,{hash:e,sheddable:!1}).then(r=>{if(r.status==="error")throw r.error;if(r.status==="timeout")throw new P("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.h)return this.et(this.h,t);switch(this.de){case"success":return Promise.resolve();case"failure":return Promise.reject(this.Xe);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.h||(this.h=new Promise((n,r)=>{this.G=n,this.Ze=r})),this.et(this.h,t)}async waitUntilReady(){try{await this.waitForInitialization()}catch(t){}}et(t,e){if(e){let n=At(e,"waitForInitialization");return Promise.race([t.then(()=>n.cancel()),n.promise]).catch(r=>{var s;throw r instanceof P&&((s=this.logger)==null||s.error(r.message)),r})}return t}};function Aa(i){return new R(i)}function Fa(i,t,e){return new gt(i,t,e)}export{Aa as basicLogger,Fa as initialize};
|
|
2
2
|
//# sourceMappingURL=compat.js.map
|