@launchdarkly/js-client-sdk 4.1.1 → 4.2.1

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