@launchdarkly/js-client-sdk 0.5.3 → 0.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.cts CHANGED
@@ -1,6 +1,6 @@
1
- import { B as BrowserOptions, L as LDClient } from './common-DPjctgS7.cjs';
2
- export { a as LDIdentifyOptions, b as basicLogger } from './common-DPjctgS7.cjs';
3
- export { AutoEnvAttributes, BasicLogger, BasicLoggerOptions, EvaluationSeriesContext, EvaluationSeriesData, Hook, HookMetadata, IdentifySeriesContext, IdentifySeriesData, IdentifySeriesResult, IdentifySeriesStatus, LDContext, LDContextCommon, LDContextMeta, LDEvaluationDetail, LDEvaluationDetailTyped, LDEvaluationReason, LDFlagSet, LDFlagValue, LDInspection, LDLogLevel, LDLogger, LDMultiKindContext, LDSingleKindContext, LDTimeoutError } from '@launchdarkly/js-client-sdk-common';
1
+ import { B as BrowserOptions, L as LDClient } from './common-Duna6UXR.cjs';
2
+ export { b as LDIdentifyOptions, a as LDPlugin, c as basicLogger } from './common-Duna6UXR.cjs';
3
+ export { AutoEnvAttributes, BasicLogger, BasicLoggerOptions, EvaluationSeriesContext, EvaluationSeriesData, Hook, HookMetadata, IdentifySeriesContext, IdentifySeriesData, IdentifySeriesResult, IdentifySeriesStatus, LDContext, LDContextCommon, LDContextMeta, LDEvaluationDetail, LDEvaluationDetailTyped, LDEvaluationReason, LDFlagSet, LDFlagValue, LDInspection, LDLogLevel, LDLogger, LDMultiKindContext, LDPluginApplicationMetadata, LDPluginBase, LDPluginEnvironmentMetadata, LDPluginMetadata, LDPluginSdkMetadata, LDSingleKindContext, LDTimeoutError, TrackSeriesContext } from '@launchdarkly/js-client-sdk-common';
4
4
 
5
5
  /**
6
6
  * Creates an instance of the LaunchDarkly client.
package/dist/index.d.ts CHANGED
@@ -1,6 +1,6 @@
1
- import { B as BrowserOptions, L as LDClient } from './common-DPjctgS7.js';
2
- export { a as LDIdentifyOptions, b as basicLogger } from './common-DPjctgS7.js';
3
- export { AutoEnvAttributes, BasicLogger, BasicLoggerOptions, EvaluationSeriesContext, EvaluationSeriesData, Hook, HookMetadata, IdentifySeriesContext, IdentifySeriesData, IdentifySeriesResult, IdentifySeriesStatus, LDContext, LDContextCommon, LDContextMeta, LDEvaluationDetail, LDEvaluationDetailTyped, LDEvaluationReason, LDFlagSet, LDFlagValue, LDInspection, LDLogLevel, LDLogger, LDMultiKindContext, LDSingleKindContext, LDTimeoutError } from '@launchdarkly/js-client-sdk-common';
1
+ import { B as BrowserOptions, L as LDClient } from './common-Duna6UXR.js';
2
+ export { b as LDIdentifyOptions, a as LDPlugin, c as basicLogger } from './common-Duna6UXR.js';
3
+ export { AutoEnvAttributes, BasicLogger, BasicLoggerOptions, EvaluationSeriesContext, EvaluationSeriesData, Hook, HookMetadata, IdentifySeriesContext, IdentifySeriesData, IdentifySeriesResult, IdentifySeriesStatus, LDContext, LDContextCommon, LDContextMeta, LDEvaluationDetail, LDEvaluationDetailTyped, LDEvaluationReason, LDFlagSet, LDFlagValue, LDInspection, LDLogLevel, LDLogger, LDMultiKindContext, LDPluginApplicationMetadata, LDPluginBase, LDPluginEnvironmentMetadata, LDPluginMetadata, LDPluginSdkMetadata, LDSingleKindContext, LDTimeoutError, TrackSeriesContext } from '@launchdarkly/js-client-sdk-common';
4
4
 
5
5
  /**
6
6
  * Creates an instance of the LaunchDarkly client.
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- var Di=Object.defineProperty,ki=Object.defineProperties;var xi=Object.getOwnPropertyDescriptors;var ht=Object.getOwnPropertySymbols;var Ie=Object.prototype.hasOwnProperty,Ne=Object.prototype.propertyIsEnumerable;var Re=(i,t,e)=>t in i?Di(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,g=(i,t)=>{for(var e in t||(t={}))Ie.call(t,e)&&Re(i,e,t[e]);if(ht)for(var e of ht(t))Ne.call(t,e)&&Re(i,e,t[e]);return i},b=(i,t)=>ki(i,xi(t));var Nt=(i,t)=>{var e={};for(var n in i)Ie.call(i,n)&&t.indexOf(n)<0&&(e[n]=i[n]);if(i!=null&&ht)for(var n of ht(i))t.indexOf(n)<0&&Ne.call(i,n)&&(e[n]=i[n]);return e};function Si(i){return`/${i.replace(/~/g,"~0").replace(/\//g,"~1")}`}function je(i){return i.indexOf("~")?i.replace(/~1/g,"/").replace(/~0/g,"~"):i}function Li(i){return(i.startsWith("/")?i.substring(1):i).split("/").map(e=>je(e))}function Ai(i){return!i.startsWith("/")}function Ci(i){return!i.match(/\/\/|(^\/.*~[^0|^1])|~$/)}var C=class{constructor(t,e=!1){if(e){let n=t;this.a=[n],this.isValid=n!=="",this.redactionName=n.startsWith("/")?Si(n):n}else{if(this.redactionName=t,t===""||t==="/"||!Ci(t)){this.isValid=!1,this.a=[];return}Ai(t)?this.a=[t]:t.indexOf("/",1)<0?this.a=[je(t.slice(1))]:this.a=Li(t),this.a[0]==="_meta"?this.isValid=!1:this.isValid=!0}}get(t){let{a: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.a[t]}get depth(){return this.a.length}get isKind(){return this.a.length===1&&this.a[0]==="kind"}compare(t){return this.depth===t.depth&&this.a.every((e,n)=>e===t.getComponent(n))}};C.InvalidReference=new C("");var Ut=class{is(t){if(Array.isArray(t))return!1;let n=typeof t;return n==="function"||n==="object"}getType(){return"factory method or object"}},O=class{constructor(t,e){this.dt=t,this.typeOf=typeof e}is(t){return Array.isArray(t)?!1:typeof t===this.typeOf}getType(){return this.dt}},gt=class{constructor(t,e){this.dt=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.dt}},K=class extends O{constructor(t){super(`number with minimum value of ${t}`,0),this.min=t}is(t){return typeof t===this.typeOf&&t>=this.min}},pt=class extends O{constructor(t){super(`string matching ${t}`,""),this.expression=t}is(t){return typeof t=="string"&&!!t.match(this.expression)}},Ft=class{is(t){return typeof t=="function"}getType(){return"function"}},jt=class{is(t){return typeof t=="boolean"||typeof t=="undefined"||t===null}getType(){return"boolean | undefined | null"}},Oi=/^\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d(\.\d\d*)?(Z|[-+]\d\d(:\d\d)?)/,Bt=class{is(t){return typeof t=="number"||typeof t=="string"&&Oi.test(t)}getType(){return"date"}},Ht=class extends pt{constructor(){super(/^(\w|\.|-)+$/)}is(t){return super.is(t)&&t!=="kind"}},l=class{static createTypeArray(t,e){return new gt(t,e)}static numberWithMin(t){return new K(t)}static stringMatchingRegex(t){return new pt(t)}};l.String=new O("string","");l.Number=new O("number",0);l.ObjectOrFactory=new Ut;l.Object=new O("object",{});l.StringArray=new gt("string[]","");l.Boolean=new O("boolean",!0);l.Function=new Ft;l.Date=new Bt;l.Kind=new Ht;l.NullableBoolean=new jt;function Be(i){return"kind"in i?l.String.is(i.kind)&&i.kind!=="multi":!1}function He(i){return"kind"in i?l.String.is(i.kind)&&i.kind==="multi":!1}function Ve(i){return!("kind"in i)||i.kind===null||i.kind===void 0}var Vt="user";function Me(i){return i.includes("%")||i.includes(":")?i.replace(/%/g,"%25").replace(/:/g,"%3A"):i}function $i(i){return i&&l.Object.is(i)}function Pe(i){return l.Kind.is(i)}function Ue(i){return l.String.is(i)&&i!==""}function Mt(i,t=!1){return i?i.map(e=>new C(e,t)):[]}function Ti(i){return i!=null}function Ri(i){let t=b(g({},i.custom||[]),{kind:"user",key:String(i.key)});if(Ti(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 k=class i{constructor(t,e,n){this.w=!1,this.q=!1,this.Vt=!1,this.x={},this.kind=e,this.valid=t,this.message=n}static g(t,e){return new i(!1,t,e)}static De(t,e){if(!(!e||!t.isValid))return t.depth===1&&t.getComponent(0)==="anonymous"?!!(e!=null&&e.anonymous):t.get(e)}_t(t){if(this.w)return this.x[t];if(this.kind===t)return this.S}static ke(t){let e=Object.keys(t).filter(c=>c!=="kind"),n=e.every(Pe);if(!e.length)return i.g("multi","A multi-kind context must contain at least one kind");if(!n)return i.g("multi","Context contains invalid kinds");let s={},r=!0,a=e.reduce((c,u)=>{var d;let h=t[u];return $i(h)?(c[u]=h,s[u]=Mt((d=h._meta)==null?void 0:d.privateAttributes)):r=!1,c},{});if(!r)return i.g("multi","Context contained contexts that were not objects");if(!Object.values(a).every(c=>Ue(c.key)))return i.g("multi","Context contained invalid keys");if(e.length===1){let c=e[0],u=new i(!0,c);return u.S=b(g({},a[c]),{kind:c}),u.J=s,u.q=c==="user",u}let o=new i(!0,t.kind);return o.x=a,o.J=s,o.w=!0,o}static xe(t){var c;let{key:e,kind:n}=t,s=Pe(n),r=Ue(e);if(!s)return i.g(n!=null?n:"unknown","The kind was not valid for the context");if(!r)return i.g(n,"The key for the context was not valid");let a=Mt((c=t._meta)==null?void 0:c.privateAttributes),o=new i(!0,n);return o.q=n==="user",o.S=t,o.J={[n]:a},o}static Se(t){if(!(t.key!==void 0&&t.key!==null))return i.g("user","The key for the context was not valid");let n=new i(!0,"user");return n.q=!0,n.Vt=!0,n.S=Ri(t),n.J={user:Mt(t.privateAttributeNames,!0)},n}static fromLDContext(t){return t?Be(t)?i.xe(t):He(t)?i.ke(t):Ve(t)?i.Se(t):i.g("unknown","Context was not of a valid kind"):i.g("unknown","No context specified. Returning default value")}static toLDContext(t){if(!t.valid)return;let e=t.getContexts();if(!t.w)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=Vt){return t.isKind?this.kinds:i.De(t,this._t(e))}key(t=Vt){var e;return(e=this._t(t))==null?void 0:e.key}get isMultiKind(){return this.w}get canonicalKey(){return this.q?this.S.key:this.w?Object.keys(this.x).sort().map(t=>`${t}:${Me(this.x[t].key)}`).join(":"):`${this.kind}:${Me(this.S.key)}`}get kinds(){return this.w?Object.keys(this.x):[this.kind]}get kindsAndKeys(){return this.w?Object.entries(this.x).reduce((t,[e,n])=>(t[e]=n.key,t),{}):{[this.kind]:this.S.key}}privateAttributes(t){var e;return((e=this.J)==null?void 0:e[t])||[]}getContexts(){return this.w?Object.entries(this.x):[[this.kind,this.S]]}get legacy(){return this.Vt}};k.UserKind=Vt;var Ii=["key","kind","_meta","anonymous"].map(i=>new C(i,!0)),Ni=["name","ip","firstName","lastName","email","avatar","country"];function Mi(i,t){return i.depth===t.length&&t.every((e,n)=>e===i.getComponent(n))}function Pi(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=>Mi(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 _t=class{constructor(t,e){this.Le=t,this.Ae=e}filter(t,e=!1){let n=t.getContexts();if(n.length===1)return this.Kt(t,n[0][1],n[0][0],e);let s={kind:"multi"};return n.forEach(([r,a])=>{s[r]=this.Kt(t,a,r,e)}),s}Ce(t,e,n,s){return(s?Object.keys(e).map(r=>new C(r,!0)):[...this.Ae,...t.privateAttributes(n)]).filter(r=>!Ii.some(a=>a.compare(r)))}Kt(t,e,n,s){let r=this.Le||s&&e.anonymous===!0,{cloned:a,excluded:o}=Pi(e,this.Ce(t,e,n,r));return t.legacy&&Ni.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}},w;(function(i){i.Unknown="UNKNOWN",i.NetworkError="NETWORK_ERROR",i.ErrorResponse="ERROR_RESPONSE",i.InvalidData="INVALID_DATA"})(w||(w={}));var I=class extends Error{constructor(t,e,n,s=!0){super(e),this.kind=t,this.status=n,this.name="LaunchDarklyPollingError",this.recoverable=s}},F=class extends Error{constructor(t,e,n,s=!0){super(e),this.kind=t,this.code=n,this.name="LaunchDarklyStreamingError",this.recoverable=s}},j;(function(i){i[i.Disabled=0]="Disabled",i[i.Enabled=1]="Enabled"})(j||(j={}));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 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 Ui(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(Number(i))}function Fi(i){return typeof i=="symbol"?"NaN":typeof i=="bigint"?`${i}n`:String(parseInt(i,10))}function ji(i){return typeof i=="symbol"?"NaN":String(parseFloat(i))}var dt={s:i=>U(i),d:i=>Ui(i),i:i=>Fi(i),f:i=>ji(i),j:i=>U(i),o:i=>U(i),O:i=>U(i),c:()=>""};function Kt(...i){var e;let t=i.shift();if(l.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 dt&&i.length){let c=i.shift();n+=(e=dt[o])==null?void 0:e.call(dt,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 Bi=["debug","info","warn","error","none"],N=class i{static get(){return new i({})}constructor(t){var e,n,s;if(this.Oe=(n=v[(e=t.level)!=null?e:"info"])!=null?n:v.info,this.$e=(s=t.name)!=null?s:"LaunchDarkly",this.Gt=t.formatter,typeof t.destination=="object")this.qt={[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.qt={[v.debug]:r,[v.info]:r,[v.warn]:r,[v.error]:r}}}Te(...t){var e;try{return this.Gt?(e=this.Gt)==null?void 0:e.call(this,...t):Kt(...t)}catch(n){return Kt(...t)}}Re(t,e){try{t(e)}catch(n){console.error(e)}}p(t,e){var n;if(t>=this.Oe){let s=`${Bi[t]}: [${this.$e}]`;try{let r=(n=this.qt)==null?void 0:n[t];r?this.Re(r,`${s} ${this.Te(...e)}`):console.error(...e)}catch(r){console.error(...e)}}}error(...t){this.p(v.error,t)}warn(...t){this.p(v.warn,t)}info(...t){this.p(v.info,t)}debug(...t){this.p(v.debug,t)}},Hi={error:l.Function,warn:l.Function,info:l.Function,debug:l.Function},G=class{constructor(t,e){Object.entries(Hi).forEach(([n,s])=>{if(!s.is(t[n]))throw new Error(`Provided logger instance must support logger.${n}(...) method`)}),this.t=t,this.Ie=e}p(t,e){try{this.t[t](...e)}catch(n){this.Ie[t](...e)}}error(...t){this.p("error",t)}warn(...t){this.p("warn",t)}info(...t){this.p("info",t)}debug(...t){this.p("debug",t)}},ne=i=>{let t=new N({level:"info",destination:console.error,formatter:Kt});return i?new G(i,t):t},D=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`}},Vi=/^(\w|\.|-)+$/,_i=l.stringMatchingRegex(Vi),Ki={is:(i,t)=>_i.is(i)?i.length>64?{valid:!1,message:D.tagValueTooLong(t)}:{valid:!0}:{valid:!1,message:D.invalidTagValue(t)}},mt=class{constructor(t){let e={},n=t==null?void 0:t.application,s=t==null?void 0:t.logger;n&&Object.entries(n).forEach(([a,o])=>{if(o!=null){let{valid:c,message:u}=Ki.is(o,`application.${a}`);c?a==="versionName"?e["application-version-name"]=[o]:e[`application-${a}`]=[o]:s==null||s.warn(u)}});let r=Object.keys(e);r.length&&(this.value=r.sort().flatMap(a=>e[a].sort().map(o=>`${a}/${o}`)).join(" "))}},yt=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 Pt(i){return i.replace(/\/+$/,"")}function se(i){return i.replace(/^\/+/,"").replace(/\?$/,"")}var M=class i{constructor(t,e,n=i.DEFAULT_EVENTS,s="/bulk",r="/diagnostic",a=!0,o){this.streaming=Pt(t),this.polling=Pt(e),this.events=Pt(n),this.analyticsEventPath=s,this.diagnosticEventPath=r,this.includeAuthorizationHeader=a,this.payloadFilterKey=o}};M.DEFAULT_EVENTS="https://events.launchdarkly.com";function re(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=se(t),s=[...e];return i.payloadFilterKey&&s.push({key:"filter",value:i.payloadFilterKey}),re(`${i.streaming}/${n}`,s)}function Ke(i,t,e){let n=se(t),s=[...e];return i.payloadFilterKey&&s.push({key:"filter",value:i.payloadFilterKey}),re(`${i.polling}/${n}`,s)}function Fe(i,t,e){let n=se(t);return re(`${i.events}/${n}`,e)}var q=class extends Error{constructor(t){super(t),this.name="LaunchDarklyUnexpectedResponseError"}},J=class extends Error{constructor(t){super(t),this.name="LaunchDarklyClientError"}},Gt=class extends Error{constructor(t){super(t),this.name="LaunchDarklyTimeoutError"}};function z(i){return i>=400&&i<500?i===400||i===408||i===429:!0}function Gi(i){return i===413?!0:z(i)}function ae(i){return i==null?i:JSON.parse(JSON.stringify(i))}function bt(i){return Math.trunc(i*1e3)}var qi=i=>JSON.stringify(i)==="{}",Dt=(i,t)=>i&&Object.entries(i).reduce((e,[n,s])=>(s&&!qi(s)&&!(t!=null&&t.includes(n))&&(e[n]=typeof s=="object"?Dt(s,t):s),e),{});function _(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(!_(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(!_(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(!_(i[r],t[r]))return!1}return!0}return i!==i&&t!==t}function Ge(i,t,e,n=!0,s="user-agent"){let{userAgentBase:r,version:a,wrapperName:o,wrapperVersion:c}=t.sdkData(),u={[s]:`${r!=null?r:"NodeJSClient"}/${a}`};return n&&(u.authorization=i),o&&(u["x-launchdarkly-wrapper"]=c?`${o}/${c}`:o),e!=null&&e.value&&(u["x-launchdarkly-tags"]=e.value),u}function H(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 qe({status:i}){return i?z(i):!0}var oe=(i,t)=>t.btoa(i).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"");var Ji=async(i=1e3)=>new Promise(t=>{setTimeout(t,i)}),Je=(i,t)=>new Promise((e,n)=>{setTimeout(()=>{let s=`${t} timed out after ${i} seconds.`;n(new Gt(s))},i*1e3)}),qt=class{constructor(t,e,n){this.r=e,this.Ne=n,this.ft=[],this.Jt=Date.now(),this.Wt=this.Jt,this.zt={diagnosticId:e.crypto.randomUUID(),sdkKeySuffix:t.length>6?t.substring(t.length-6):t}}createInitEvent(){var n,s,r;let t=this.r.info.sdkData(),e=this.r.info.platformData();return{kind:"diagnostic-init",id:this.zt,creationDate:this.Jt,sdk:t,configuration:this.Ne,platform:g({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.ft.push(s)}createStatsEventAndReset(t,e,n){let s=Date.now(),r={kind:"diagnostic",id:this.zt,creationDate:s,dataSinceDate:this.Wt,droppedEvents:t,deduplicatedUsers:e,eventsInLastBatch:n,streamInits:this.ft};return this.ft=[],this.Wt=s,r}},Jt;(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"})(Jt||(Jt={}));var Wi=Jt,vt=class{static invalidMetricValue(t){return`The track function was called with a non-numeric "metricValue" (${t}), only numeric metric values are supported.`}};vt.MissingContextKeyNoEvent="Context was unspecified or had no key; event will not be sent";var Wt=class{constructor(t,e){let{basicConfiguration:n,platform:s}=t,{serviceEndpoints:{analyticsEventPath:r,diagnosticEventPath:a}}=n,{crypto:o,requests:c}=s;this.Me=g({},e),this.Yt=Fe(n.serviceEndpoints,r,[]),this.Pe=Fe(n.serviceEndpoints,a,[]),this.E=c,this.Ue=o}async W(t,e,n,s){let r={status:R.Succeeded},a=b(g({},this.Me),{"content-type":"application/json"});n&&(a["x-launchdarkly-payload-id"]=n,a["x-launchDarkly-event-schema"]="4");let o;try{let{status:c,headers:u}=await this.E.fetch(e,{headers:a,body:JSON.stringify(t),compressBodyIfPossible:!0,method:"POST",keepalive:!0}),h=Date.parse(u.get("date")||"");if(h&&(r.serverTime=h),c<=204)return r;if(o=new q(H({status:c,message:"some events were dropped"},"event posting")),!z(c))return Gi(c)?r.status=R.Failed:r.status=R.FailedAndMustShutDown,r.error=o,r}catch(c){o=c}return o&&!s?(r.status=R.Failed,r.error=o,r):(await Ji(),this.W(t,this.Yt,n,!1))}async sendEventData(t,e){let n=t===B.AnalyticsEvents?this.Ue.randomUUID():void 0,s=t===B.AnalyticsEvents?this.Yt:this.Pe;return this.W(e,s,n,!0)}};function zt(i){return i.kind==="feature"}function zi(i){return i.kind==="identify"}function Yi(i){return i.kind==="migration_op"}var Yt=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 Xi(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(){this.P=0,this.z=0,this.Y={},this.X={}}summarizeEvent(t){if(zt(t)&&!t.excludeFromSummaries){let e=Xi(t),n=this.Y[e],s=this.X[t.key];s||(s=new Set,this.X[t.key]=s),t.context.kinds.forEach(r=>s.add(r)),n?n.increment():this.Y[e]=new Yt(1,t.key,t.value,t.default,t.version,t.variation),(this.P===0||t.creationDate<this.P)&&(this.P=t.creationDate),t.creationDate>this.z&&(this.z=t.creationDate)}}getSummary(){let t=Object.values(this.Y).reduce((e,n)=>{let s=e[n.key];s||(s={default:n.default,counters:[],contextKinds:[...this.X[n.key]]},e[n.key]=s);let r={value:n.value,count:n.count};return n.variation!==void 0&&n.variation!==null&&(r.variation=n.variation),n.version!==void 0&&n.version!==null?r.version=n.version:r.unknown=!0,s.counters.push(r),e},{});return{startDate:this.P,endDate:this.z,features:t,kind:"summary"}}clearSummary(){this.P=0,this.z=0,this.Y={},this.X={}}},Zt=class extends Error{constructor(t){super(t),this.name="LaunchDarklyInvalidSDKKeyError"}};function ft(i){let t=Math.trunc(i);return t===1?!0:t===0?!1:Math.floor(Math.random()*t)===0}var Qt=class{constructor(t,e,n,s,r,a=!0){this.n=t,this.Z=s,this.m=r,this.gt=new Xt,this.Q=[],this.Xt=0,this.pt=0,this.mt=0,this.yt=!1,this.Zt=0,this.vt=!1,this.wt=null,this.Fe=t.eventsCapacity,this.t=e.basicConfiguration.logger,this.Qt=new Wt(e,n),this.tt=new _t(t.allAttributesPrivate,t.privateAttributes.map(o=>new C(o))),a&&this.start()}start(){var t,e;if(((t=this.Z)==null?void 0:t.flushInterval)!==void 0&&(this.wt=setInterval(()=>{var n;(n=this.Z)==null||n.flush()},this.Z.flushInterval*1e3)),this.je=setInterval(async()=>{var n;try{await this.flush()}catch(s){(n=this.t)==null||n.debug(`Flush failed: ${s}`)}},this.n.flushInterval*1e3),this.m){let n=this.m.createInitEvent();this.te(n),this.ee=setInterval(()=>{let s=this.m.createStatsEventAndReset(this.pt,this.mt,this.Zt);this.pt=0,this.mt=0,this.te(s)},this.n.diagnosticRecordingInterval*1e3)}(e=this.t)==null||e.debug("Started EventProcessor.")}te(t){this.Qt.sendEventData(B.DiagnosticEvent,t)}close(){clearInterval(this.je),this.wt&&clearInterval(this.wt),this.ee&&clearInterval(this.ee)}async flush(){var n;if(this.vt)throw new Zt("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.Q;this.Q=[];let e=this.gt.getSummary();this.gt.clearSummary(),Object.keys(e.features).length&&t.push(e),t.length&&(this.Zt=t.length,(n=this.t)==null||n.debug("Flushing %d events",t.length),await this.W(t))}sendEvent(t){var c;if(this.vt)return;if(Yi(t)){if(ft(t.samplingRatio)){let u=b(g({},t),{context:t.context?this.tt.filter(t.context):void 0});u.samplingRatio===1&&delete u.samplingRatio,this.et(u)}return}this.gt.summarizeEvent(t);let e=zt(t),n=e&&t.trackEvents||!e,s=this.Be(t),r=zi(t),a=(c=this.Z)==null?void 0:c.processContext(t.context);a||r||(this.mt+=1),a&&!r&&this.et(this.Et({kind:"index",creationDate:t.creationDate,context:t.context,samplingRatio:1},!1)),n&&ft(t.samplingRatio)&&this.et(this.Et(t,!1)),s&&ft(t.samplingRatio)&&this.et(this.Et(t,!0))}Et(t,e){switch(t.kind){case"feature":{let n={kind:e?"debug":"feature",creationDate:t.creationDate,context:this.tt.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.tt.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.tt.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}}et(t){var e;this.Q.length<this.Fe?(this.Q.push(t),this.yt=!1):(this.yt||(this.yt=!0,(e=this.t)==null||e.warn("Exceeded event queue capacity. Increase capacity to avoid dropping events.")),this.pt+=1)}Be(t){return zt(t)&&t.debugEventsUntilDate&&t.debugEventsUntilDate>this.Xt&&t.debugEventsUntilDate>Date.now()}async W(t){let e=await this.Qt.sendEventData(B.AnalyticsEvents,t);if(e.status===R.FailedAndMustShutDown&&(this.vt=!0),e.serverTime&&(this.Xt=e.serverTime),e.error)throw e.error}},wt=class{constructor(t,e,n,s,r=1,a){this.context=t,this.key=e,this.data=n,this.metricValue=s,this.samplingRatio=r,this.url=a,this.kind="custom",this.creationDate=Date.now(),this.context=t}},W=class{constructor(t,e,n,s,r,a,o,c,u,h,d,f,p=1){this.withReasons=t,this.context=e,this.key=n,this.samplingRatio=p,this.kind="feature",this.creationDate=Date.now(),this.value=s,this.default=r,a!==void 0&&(this.version=a),o!==void 0&&(this.variation=o),c!==void 0&&(this.trackEvents=c),u!==void 0&&(this.prereqOf=u),h!==void 0&&(this.reason=h),d!==void 0&&(this.debugEventsUntilDate=d),f!==void 0&&(this.excludeFromSummaries=f)}},Et=class{constructor(t,e=1){this.context=t,this.samplingRatio=e,this.kind="identify",this.creationDate=Date.now()}},te=class{close(){}async flush(){}sendEvent(){}},ee=class{constructor(t){this.bt=t}evalEvent(t){var e;return new W(this.bt,t.context,t.flagKey,t.value,t.defaultVal,t.version,(e=t.variation)!=null?e:void 0,t.trackEvents||t.addExperimentData,t.prereqOfFlagKey,this.bt||t.addExperimentData?t.reason:void 0,t.debugEventsUntilDate,t.excludeFromSummaries,t.samplingRatio)}unknownFlagEvent(t,e,n){return new W(this.bt,n,t,e,e,void 0,void 0,void 0,void 0,void 0,void 0,void 0,void 0)}identifyEvent(t){return new Et(t,1)}customEvent(t,e,n,s,r=1){return new wt(e,t,n!=null?n:void 0,s!=null?s:void 0,r)}},ie=class{constructor(t,e,n,s){this.He=e,this.u=n,this.t=s,this.e=[],this.L=void 0,this.U=void 0,this.it=[],this.Ve=r=>{if(this.F(),!r.payloads.length)return;let a=r.payloads[0];switch(a==null?void 0:a.code){case"xfer-full":this.U=!0;break;case"xfer-changes":case"none":this.U=!1;break;default:return}this.L=a==null?void 0:a.id},this._e=r=>{var o;if(!this.L||!r.kind||!r.key||!r.version||!r.object)return;let a=this.Ke(r.kind,r.object);if(!a){(o=this.t)==null||o.warn(`Unable to prcoess object for kind: '${r.kind}'`);return}this.it.push({kind:r.kind,key:r.key,version:r.version,object:a})},this.Ge=r=>{!this.L||!r.kind||!r.key||!r.version||this.it.push({kind:r.kind,key:r.key,version:r.version,deleted:!0})},this.qe=r=>{if(!this.L||!r.state||!r.version||this.U===void 0){this.F();return}let a={id:this.L,version:r.version,state:r.state,basis:this.U,updates:this.it};this.e.forEach(o=>o(a)),this.F()},this.Je=r=>{var a;(a=this.t)==null||a.info(`Goodbye was received from the LaunchDarkly connection with reason: ${r.reason}.`),this.F()},this.We=r=>{var a;(a=this.t)==null||a.info(`An issue was encountered receiving updates for payload ${this.L} with reason: ${r.reason}. Automatic retry will occur.`),this.F()},this.A(t,"server-intent",this.Ve),this.A(t,"put-object",this._e),this.A(t,"delete-object",this.Ge),this.A(t,"payload-transferred",this.qe),this.A(t,"goodbye",this.Je),this.A(t,"error",this.We)}addPayloadListener(t){this.e.push(t)}removePayloadListener(t){let e=this.e.indexOf(t,0);e>-1&&this.e.splice(e,1)}A(t,e,n){t.addEventListener(e,async s=>{var r,a,o,c,u;if(s!=null&&s.data){(r=this.t)==null||r.debug(`Received ${e} event. Data is ${s.data}`);try{n(JSON.parse(s.data))}catch(h){(a=this.t)==null||a.error(`Stream received data that was unable to be processed in "${e}" message`),(o=this.t)==null||o.debug(`Data follows: ${s.data}`),(c=this.u)==null||c.call(this,w.InvalidData,"Malformed data in event stream")}}else(u=this.u)==null||u.call(this,w.Unknown,"Unexpected message from event stream")})}Ke(t,e){var n,s;return(s=(n=this.He)[t])==null?void 0:s.call(n,e)}F(){this.L=void 0,this.U=void 0,this.it=[]}};function Zi(i){if(i){let t=Object.keys(i).find(e=>e.toLowerCase()==="x-ld-envid");if(t)return{environmentId:i[t]}}}var L=Object.freeze({__proto__:null,ClientMessages:vt,DiagnosticsManager:qt,ErrorKinds:Wi,EventFactoryBase:ee,EventProcessor:Qt,InputCustomEvent:wt,InputEvalEvent:W,InputIdentifyEvent:Et,NullEventProcessor:te,PayloadReader:ie,initMetadataFromHeaders:Zi,isLegacyUser:Ve,isMultiKind:He,isSingleKind:Be,shouldSample:ft});var E;(function(i){i.Initializing="INITIALIZING",i.Valid="VALID",i.Interrupted="INTERRUPTED",i.SetOffline="SET_OFFLINE",i.Closed="CLOSED"})(E||(E={}));function tn(i){return i>=200&&i<=299}var kt=class extends Error{constructor(t,e){super(t),this.status=e,this.name="LaunchDarklyRequestError"}},de=class{constructor(t,e,n,s,r){this.E=t,this.ze=e,this.nt=n,this.Ye=s,this.Xe=r}async requestPayload(){let t;try{let e=await this.E.fetch(this.ze,{method:this.Ye,headers:this.nt,body:this.Xe});if(tn(e.status))return await e.text();t=e.status}catch(e){throw new kt(e==null?void 0:e.message)}throw new kt(`Unexpected status code: ${t}`,t)}};function Se(i,t,e,n,s,r,a,o,c,u){let h,d="GET",f=g({},r);c&&(d="REPORT",f["content-type"]="application/json",h=i);let p=c?e.pathReport(s,i):e.pathGet(s,i),m=[...a!=null?a:[]];o&&m.push({key:"withReasons",value:"true"}),u&&m.push({key:"h",value:u});let y=Ke(t,p,m);return new de(n,y,f,d,h)}var en={logger:l.Object,maxCachedContexts:l.numberWithMin(0),baseUri:l.String,streamUri:l.String,eventsUri:l.String,capacity:l.numberWithMin(1),diagnosticRecordingInterval:l.numberWithMin(2),flushInterval:l.numberWithMin(2),streamInitialReconnectDelay:l.numberWithMin(0),allAttributesPrivate:l.Boolean,debug:l.Boolean,diagnosticOptOut:l.Boolean,withReasons:l.Boolean,sendEvents:l.Boolean,pollInterval:l.numberWithMin(30),useReport:l.Boolean,privateAttributes:l.StringArray,applicationInfo:l.Object,wrapperName:l.String,wrapperVersion:l.String,payloadFilterKey:l.stringMatchingRegex(/^[a-zA-Z0-9](\w|\.|-)*$/),hooks:l.createTypeArray("Hook[]",{}),inspectors:l.createTypeArray("LDInspection",{})},nn=60*5,Ze="https://clientsdk.launchdarkly.com",Qe="https://clientstream.launchdarkly.com";function sn(i){return i instanceof G?i:ne(i)}var fe=class{constructor(t={},e={}){var s,r,a;this.logger=ne(),this.baseUri=Ze,this.eventsUri=M.DEFAULT_EVENTS,this.streamUri=Qe,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=nn,this.hooks=[],this.inspectors=[],this.logger=sn(t.logger),this.Ze(t).forEach(o=>this.logger.warn(o)),this.serviceEndpoints=new M(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 mt({application:this.applicationInfo,logger:this.logger}),this.userAgentHeaderName=(r=e.userAgentHeaderName)!=null?r:"user-agent",this.trackEventModifier=(a=e.trackEventModifier)!=null?a:o=>o}Ze(t){let e=[];return Object.entries(t).forEach(([n,s])=>{let r=en[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(D.wrongOptionTypeBoolean(n,typeof s)),this[n]=!!s;else if(a==="boolean | undefined | null")e.push(D.wrongOptionTypeBoolean(n,typeof s)),typeof s!="boolean"&&typeof s!="undefined"&&s!==null&&(this[n]=!!s);else if(r instanceof K&&l.Number.is(s)){let{min:o}=r;e.push(D.optionBelowMinimum(n,s,o)),this[n]=o}else e.push(D.wrongOptionType(n,r.getType(),typeof s))}else e.push(D.unknownOption(n))}),e}};async function ti(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 ei=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 ii(i){return async t=>ti(i.createHash("sha256").update(t),"base64")}var x=async i=>i;async function X(i){return(await Promise.all(i.map(e=>e.transform(e.value)))).join("_")}async function rn(i,t){return X([{value:"LaunchDarkly",transform:x},{value:t,transform:ii(i)}])}async function an(i){return X([{value:"LaunchDarkly",transform:x},{value:"AnonymousKeys",transform:x},{value:i,transform:x}])}async function on(i){return X([{value:"LaunchDarkly",transform:x},{value:"ContextKeys",transform:x},{value:i,transform:x}])}async function cn(i){return X([{value:i,transform:x},{value:"ContextIndex",transform:x}])}async function We(i,t,e){return X([{value:t,transform:x},{value:e.canonicalKey,transform:ii(i)}])}var{isLegacyUser:un,isSingleKind:ce,isMultiKind:ze}=L,ni="1.0",ln=i=>{let n=i,{kind:t}=n,e=Nt(n,["kind"]);return{kind:"multi",[t]:e}},hn=async({crypto:i,info:t},{applicationInfo:e})=>{var a;let{ld_application:n}=t.platformData(),s=(a=Dt(n))!=null?a:{},r=(e==null?void 0:e.id)||(s==null?void 0:s.id);if(r){let o=(e==null?void 0:e.version)||(s==null?void 0:s.version),c=(e==null?void 0:e.name)||(s==null?void 0:s.name),u=(e==null?void 0:e.versionName)||(s==null?void 0:s.versionName);return s=g(g(g(b(g({},s),{id:r}),o?{version:o}:{}),c?{name:c}:{}),u?{versionName:u}:{}),s.key=await ti(i.createHash("sha256").update(r),"base64"),s.envAttributesVersion=s.envAttributesVersion||ni,s}},dn=async i=>{var o,c,u,h;let{ld_device:t,os:e}=i.info.platformData(),n=(o=Dt(t))!=null?o:{},s=(e==null?void 0:e.name)||((c=n.os)==null?void 0:c.name),r=(e==null?void 0:e.version)||((u=n.os)==null?void 0:u.version),a=(h=n.os)==null?void 0:h.family;if((s||r||a)&&(n.os=g(g(g({},s?{name:s}:{}),r?{version:r}:{}),a?{family:a}:{})),Object.keys(n).filter(d=>d!=="key"&&d!=="envAttributesVersion").length){let d=await on("ld_device");return n.key=await ei(d,i),n.envAttributesVersion=n.envAttributesVersion||ni,n}},fn=async(i,t,e)=>{if(un(i))return i;let n,s;if(ce(i)&&i.kind!=="ld_application"||ze(i)&&!i.ld_application?n=await hn(t,e):e.logger.warn("Not adding ld_application environment attributes because it already exists."),ce(i)&&i.kind!=="ld_device"||ze(i)&&!i.ld_device?s=await dn(t):e.logger.warn("Not adding ld_device environment attributes because it already exists."),n||s){let r=ce(i)?ln(i):i;return g(g(g({},r),n?{ld_application:n}:{}),s?{ld_device:s}:{})}return i},{isLegacyUser:gn,isMultiKind:pn,isSingleKind:mn}=L,Le=async(i,t,e)=>{let{anonymous:n,key:s}=t;if(n&&!s){let r=await an(i);t.key=await ei(r,e)}},yn=async(i,t)=>{await Le(i.kind,i,t)},vn=async(i,t)=>{let s=i,{kind:e}=s,n=Nt(s,["kind"]);return Promise.all(Object.entries(n).map(([r,a])=>Le(r,a,t)))},wn=async(i,t)=>{await Le("user",i,t)},En=async(i,t)=>{let e=ae(i);return mn(e)&&await yn(e,t),pn(e)&&await vn(e,t),gn(e)&&await wn(e,t),e},bn=i=>({customBaseURI:i.serviceEndpoints.polling!==Ze,customStreamURI:i.serviceEndpoints.streaming!==Qe,customEventsURI:i.serviceEndpoints.events!==M.DEFAULT_EVENTS,eventsCapacity:i.capacity,eventsFlushIntervalMillis:bt(i.flushInterval),reconnectTimeMillis:bt(i.streamInitialReconnectDelay),diagnosticRecordingIntervalMillis:bt(i.diagnosticRecordingInterval),allAttributesPrivate:i.allAttributesPrivate,usingSecureMode:!1,bootstrapMode:!1}),Dn=(i,t,e)=>{if(t.sendEvents&&!t.diagnosticOptOut)return new L.DiagnosticsManager(i,e,bn(t))};function ue(i,t){return{value:t!=null?t:null,variationIndex:null,reason:{kind:"ERROR",errorKind:i}}}function Ye(i,t,e){return{value:i,variationIndex:t!=null?t:null,reason:e!=null?e:null}}var kn=(i,t,e,n,s)=>{if(t.sendEvents)return new L.EventProcessor(b(g({},t),{eventsCapacity:t.capacity}),new yt(i,t,e),n,void 0,s,!1)},xt=class extends L.EventFactoryBase{evalEventClient(t,e,n,s,r,a){let{trackEvents:o,debugEventsUntilDate:c,trackReason:u,flagVersion:h,version:d,variation:f}=s;return super.evalEvent({addExperimentData:u,context:r,debugEventsUntilDate:c,defaultVal:n,flagKey:t,reason:a,trackEvents:!!o,value:e,variation:f,version:h!=null?h: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)):[]}},ge=class{constructor(t,e,n,s,r,a,o=()=>Date.now()){this.r=t,this.Dt=e,this.Qe=n,this.l=s,this.b=r,this.t=a,this.st=o,this.ie=cn(this.Dt)}async init(t,e){this.b.init(t,e),await this.ne(t)}async upsert(t,e,n){return this.b.upsert(t,e,n)?(await this.ne(t),!0):!1}async loadCached(t){var s,r,a,o;let e=await We(this.r.crypto,this.Dt,t),n=await((s=this.r.storage)==null?void 0:s.get(e));if(n==null){if(n=await((r=this.r.storage)==null?void 0:r.get(t.canonicalKey)),n==null)return!1;await((a=this.r.storage)==null?void 0:a.set(e,n)),await((o=this.r.storage)==null?void 0:o.clear(t.canonicalKey))}try{let c=JSON.parse(n),u=Object.entries(c).reduce((h,[d,f])=>(h[d]={version:f.version,flag:f},h),{});return this.b.initCached(t,u),this.t.debug("Loaded cached flag evaluations from persistent storage"),!0}catch(c){return this.t.warn(`Could not load cached flag evaluations from persistent storage: ${c.message}`),!1}}async ti(){var e;if(this.C!==void 0)return this.C;let t=await((e=this.r.storage)==null?void 0:e.get(await this.ie));if(!t)return this.C=new Y,this.C;try{this.C=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.C=new Y}return this.C}async ne(t){var c,u;let e=await this.ti(),n=await We(this.r.crypto,this.Dt,t);e.notice(n,this.st());let s=e.prune(this.Qe);await Promise.all(s.map(async h=>{var d;return(d=this.r.storage)==null?void 0:d.clear(h.id)})),await((c=this.r.storage)==null?void 0:c.set(await this.ie,e.toJson()));let r=this.l.getAll(),a=Object.entries(r).reduce((h,[d,f])=>(f.flag!==null&&f.flag!==void 0&&(h[d]=f.flag),h),{}),o=JSON.stringify(a);await((u=this.r.storage)==null?void 0:u.set(n,o))}},pe=class{constructor(){this.B={}}init(t){this.B=Object.entries(t).reduce((e,[n,s])=>(e[n]=s,e),{})}insertOrUpdate(t,e){this.B[t]=e}get(t){if(Object.prototype.hasOwnProperty.call(this.B,t))return this.B[t]}getAll(){return this.B}};function xn(i,t){let e=[];return Object.entries(i).forEach(([n,s])=>{let r=t[n];(!r||!_(s,r))&&e.push(n)}),Object.keys(t).forEach(n=>{i[n]||e.push(n)}),e}var me=class{constructor(t,e){this.H=new Array,this.l=t,this.t=e}init(t,e){this.se=t.canonicalKey;let n=this.l.getAll();this.l.init(e);let s=xn(n,e);s.length>0&&this.H.forEach(r=>{try{r(t,s,"init")}catch(a){}})}initCached(t,e){this.se!==t.canonicalKey&&this.init(t,e)}upsert(t,e,n){if(this.se!==t.canonicalKey)return this.t.warn("Received an update for an inactive context."),!1;let s=this.l.get(e);return s!==void 0&&s.version>=n.version?!1:(this.l.insertOrUpdate(e,n),this.H.forEach(r=>{try{r(t,[e],"patch")}catch(a){}}),!0)}on(t){this.H.push(t)}off(t){let e=this.H.indexOf(t);e>-1&&this.H.splice(e,1)}},ye=class{constructor(t,e,n,s,r=()=>Date.now()){this.l=new pe,this.b=new me(this.l,s),this.kt=this.ei(t,e,n,s,r)}async ei(t,e,n,s,r=()=>Date.now()){let a=await rn(t.crypto,e);return new ge(t,a,n,this.l,this.b,s,r)}get(t){return this.l.get(t)}getAll(){return this.l.getAll()}setBootstrap(t,e){this.b.init(t,e)}async init(t,e){return(await this.kt).init(t,e)}async upsert(t,e,n){return(await this.kt).upsert(t,e,n)}async loadCached(t){return(await this.kt).loadCached(t)}on(t){this.b.on(t)}off(t){this.b.off(t)}},Xe="unknown hook",si="beforeEvaluation",ri="afterEvaluation";function At(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 Ct(i,t){try{return t.getMetadata().name||Xe}catch(e){return i.error("Exception thrown getting metadata for hook. Unable to get hook name."),Xe}}function Sn(i,t,e){return t.map(n=>At(i,si,Ct(i,n),()=>{var s,r;return(r=(s=n==null?void 0:n.beforeEvaluation)==null?void 0:s.call(n,e,{}))!=null?r:{}},{}))}function Ln(i,t,e,n,s){for(let r=t.length-1;r>=0;r-=1){let a=t[r],o=n[r];At(i,ri,Ct(i,a),()=>{var c,u;return(u=(c=a==null?void 0:a.afterEvaluation)==null?void 0:c.call(a,e,o,s))!=null?u:{}},{})}}function An(i,t,e){return t.map(n=>At(i,si,Ct(i,n),()=>{var s,r;return(r=(s=n==null?void 0:n.beforeIdentify)==null?void 0:s.call(n,e,{}))!=null?r:{}},{}))}function Cn(i,t,e,n,s){for(let r=t.length-1;r>=0;r-=1){let a=t[r],o=n[r];At(i,ri,Ct(i,a),()=>{var c,u;return(u=(c=a==null?void 0:a.afterIdentify)==null?void 0:c.call(a,e,o,s))!=null?u:{}},{})}}var ve=class{constructor(t,e){this.t=t,this.V=[],this.V.push(...e)}withEvaluation(t,e,n,s){if(this.V.length===0)return s();let r=[...this.V],a={flagKey:t,context:e,defaultValue:n},o=Sn(this.t,r,a),c=s();return Ln(this.t,r,a,o,c),c}identify(t,e){let n=[...this.V],s={context:t,timeout:e},r=An(this.t,n,s);return a=>{Cn(this.t,n,s,r,a)}}addHook(t){this.V.push(t)}};function On(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 $n(i,t){return`an inspector: "${t}" of an invalid type (${i}) was configured`}function Tn(i,t){return`an inspector: "${t}" of type: "${i}" generated an exception`}function Rn(i,t){let e=!1,n={method:(...s)=>{try{i.method(...s)}catch(r){e||(e=!0,t.warn(Tn(n.type,n.name)))}},type:i.type,name:i.name,synchronous:i.synchronous};return n}var ai="flag-used",oi="flag-details-changed",ci="flag-detail-changed",ui="client-identity-changed",In=[ai,oi,ci,ui];function Nn(i,t){let e=In.includes(i.type)&&i.method&&typeof i.method=="function";return e||t.warn($n(i.type,i.name)),e}var we=class{constructor(t,e){this.$=[];let n=t.filter(s=>Nn(s,e));this.$=n.map(s=>Rn(s,e))}hasInspectors(){return this.$.length!==0}onFlagUsed(t,e,n){this.$.forEach(s=>{s.type===ai&&s.method(t,e,n)})}onFlagsChanged(t){this.$.forEach(e=>{e.type===oi&&e.method(t)})}onFlagChanged(t,e){this.$.forEach(n=>{n.type===ci&&n.method(t,e)})}onIdentityChanged(t){this.$.forEach(e=>{e.type===ui&&e.method(t)})}},Ee=class{constructor(t){this.t=t,this.e=new Map}on(t,e){var n;this.e.has(t)?(n=this.e.get(t))==null||n.push(e):this.e.set(t,[e])}off(t,e){let n=this.e.get(t);if(n){if(e){let s=n.filter(r=>r!==e);s.length===0?this.e.delete(t):this.e.set(t,s);return}this.e.delete(t)}}ii(t,e,...n){var s;try{t(...n)}catch(r){(s=this.t)==null||s.error(`Encountered error invoking handler for "${e}", detail: "${r}"`)}}emit(t,...e){let n=this.e.get(t);n==null||n.forEach(s=>this.ii(s,t,...e))}eventNames(){return[...this.e.keys()]}listenerCount(t){var e,n;return(n=(e=this.e.get(t))==null?void 0:e.length)!=null?n:0}},{ClientMessages:le,ErrorKinds:he}=L,Mn=5,St=class{constructor(t,e,n,s,r,a){if(this.sdkKey=t,this.autoEnvAttributes=e,this.platform=n,this.xt=15,this.D=new xt(!1),this.rt=new xt(!0),this.St=!1,!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.n=new fe(s,a),this.logger=this.n.logger,this.re=Ge(this.sdkKey,this.platform.info,this.n.tags,this.n.serviceEndpoints.includeAuthorizationHeader,this.n.userAgentHeaderName),this.y=new ye(this.platform,t,this.n.maxCachedContexts,this.n.logger),this.m=Dn(t,this.n,n),this.h=kn(t,this.n,n,this.re,this.m),this.emitter=new Ee,this.emitter.on("error",(o,c)=>{this.logger.error(`error: ${c}, context: ${JSON.stringify(o)}`)}),this.y.on((o,c,u)=>{this.ni(c,u);let h=k.toLDContext(o);this.emitter.emit("change",h,c),c.forEach(d=>{this.emitter.emit(`change:${d}`,h)})}),this.dataManager=r(this.y,this.n,this.re,this.emitter,this.m),this.T=new ve(this.logger,this.n.hooks),this._=new we(this.n.inspectors,this.logger),this._.hasInspectors()&&this.T.addHook(On(this._))}allFlags(){return Object.entries(this.y.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.h)==null||t.close(),this.dataManager.close(),this.logger.debug("Closed event processor and data source.")}async flush(){var t;try{await((t=this.h)==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.v?ae(this.v):void 0}getInternalContext(){return this.R}si(t,e){let n,s,r=new Promise((c,u)=>{n=c,s=u});if(e)return{identifyPromise:r,identifyResolve:n,identifyReject:s};let a=Je(t,"identify");return{identifyPromise:Promise.race([a,r]).catch(c=>{throw c.message.includes("timed out")&&this.logger.error(`identify error: ${c}`),c}),identifyResolve:n,identifyReject:s}}async identify(t,e){var d,f;let n=(d=e==null?void 0:e.timeout)!=null?d:Mn,s=(e==null?void 0:e.timeout)===void 0&&(e==null?void 0:e.noTimeout)===!0;n>this.xt&&this.logger.warn(`The identify function was called with a timeout greater than ${this.xt} seconds. We recommend a timeout of less than ${this.xt} seconds.`);let r=await En(t,this.platform);this.autoEnvAttributes===j.Enabled&&(r=await fn(r,this.platform,this.n));let a=k.fromLDContext(r);if(!a.valid){let p=new Error("Context was unspecified or had no key");return this.emitter.emit("error",r,p),Promise.reject(p)}this.v=r,this.R=a,(f=this.h)==null||f.sendEvent(this.D.identifyEvent(this.R));let{identifyPromise:o,identifyResolve:c,identifyReject:u}=this.si(n,s);this.logger.debug(`Identifying ${JSON.stringify(this.R)}`);let h=this.T.identify(r,e==null?void 0:e.timeout);return await this.dataManager.identify(c,u,a,e),o.then(p=>(h({status:"completed"}),p),p=>{throw h({status:"error"}),p})}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.R||!this.R.valid){this.logger.warn(le.MissingContextKeyNoEvent);return}n!==void 0&&!l.Number.is(n)&&((s=this.logger)==null||s.warn(le.invalidMetricValue(typeof n))),(r=this.h)==null||r.sendEvent(this.n.trackEventModifier(this.D.customEvent(t,this.R,e,n)))}at(t,e,n,s){var f,p,m;if(!this.v)return this.logger.debug(le.MissingContextKeyNoEvent),ue(he.UserNotSpecified,e);let r=k.fromLDContext(this.v),a=this.y.get(t);if(a===void 0||a.flag.deleted){let y=e!=null?e:null,S=new J(`Unknown feature flag "${t}"; returning default value ${y}.`);return this.emitter.emit("error",this.v,S),(f=this.h)==null||f.sendEvent(this.D.unknownFlagEvent(t,y,r)),ue(he.FlagNotFound,e)}let{reason:o,value:c,variation:u,prerequisites:h}=a.flag;if(s){let[y,S]=s(c);if(!y){(p=this.h)==null||p.sendEvent(n.evalEventClient(t,e,e,a.flag,r,o));let P=new J(`Wrong type "${S}" for feature flag "${t}"; returning default value`);return this.emitter.emit("error",this.v,P),ue(he.WrongType,e)}}let d=Ye(c,u,o);return c==null&&(this.logger.debug("Result value is null. Providing default value."),d.value=e),h==null||h.forEach(y=>{this.at(y,void 0,this.D)}),(m=this.h)==null||m.sendEvent(n.evalEventClient(t,c,e,a.flag,r,o)),d}variation(t,e){let{value:n}=this.T.withEvaluation(t,this.v,e,()=>this.at(t,e,this.D));return n}variationDetail(t,e){return this.T.withEvaluation(t,this.v,e,()=>this.at(t,e,this.rt))}I(t,e,n,s){return this.T.withEvaluation(t,this.v,e,()=>this.at(t,e,n,s))}boolVariation(t,e){return this.I(t,e,this.D,n=>[l.Boolean.is(n),l.Boolean.getType()]).value}jsonVariation(t,e){return this.variation(t,e)}numberVariation(t,e){return this.I(t,e,this.D,n=>[l.Number.is(n),l.Number.getType()]).value}stringVariation(t,e){return this.I(t,e,this.D,n=>[l.String.is(n),l.String.getType()]).value}boolVariationDetail(t,e){return this.I(t,e,this.rt,n=>[l.Boolean.is(n),l.Boolean.getType()])}numberVariationDetail(t,e){return this.I(t,e,this.rt,n=>[l.Number.is(n),l.Number.getType()])}stringVariationDetail(t,e){return this.I(t,e,this.rt,n=>[l.String.is(n),l.String.getType()])}jsonVariationDetail(t,e){return this.variationDetail(t,e)}addHook(t){this.T.addHook(t)}setEventSendingEnabled(t,e){var n,s,r,a;this.St!==t&&(this.St=t,t?(this.logger.debug("Starting event processor"),(n=this.h)==null||n.start()):e?((s=this.logger)==null||s.debug("Flushing event processor before disabling."),this.flush().then(()=>{var o,c;this.St||((o=this.logger)==null||o.debug("Stopping event processor."),(c=this.h)==null||c.close())})):((r=this.logger)==null||r.debug("Stopping event processor."),(a=this.h)==null||a.close()))}sendEvent(t){var e;(e=this.h)==null||e.sendEvent(t)}ni(t,e){if(!this._.hasInspectors())return;let n={};t.forEach(s=>{let r=this.y.get(s);if(r!=null&&r.flag&&!r.flag.deleted){let{reason:a,value:o,variation:c}=r.flag;n[s]=Ye(o,c,a)}else n[s]={value:void 0,reason:null,variationIndex:null}}),e==="init"?this._.onFlagsChanged(n):e==="patch"&&Object.entries(n).forEach(([s,r])=>{this._.onFlagChanged(s,r)})}},be=class{constructor(t,e,n){this.y=t,this.Lt=e,this.t=n}async handlePut(t,e){this.t.debug(`Got PUT: ${Object.keys(e)}`);let n=Object.entries(e).reduce((s,[r,a])=>(s[r]={version:a.version,flag:a},s),{});await this.y.init(t,n),this.Lt.requestStateUpdate(E.Valid)}async handlePatch(t,e){this.t.debug(`Got PATCH ${JSON.stringify(e,null,2)}`),this.y.upsert(t,e.key,{version:e.version,flag:e})}async handleDelete(t,e){this.t.debug(`Got DELETE ${JSON.stringify(e,null,2)}`),this.y.upsert(t,e.key,{version:e.version,flag:b(g({},e),{deleted:!0,flagVersion:0,value:void 0,variation:0,trackEvents:!1})})}handleStreamingError(t){this.Lt.reportError(t.kind,t.message,t.code,t.recoverable)}handlePollingError(t){this.Lt.reportError(t.kind,t.message,t.status,t.recoverable)}},De=class{constructor(t,e=()=>Date.now()){this.ri=t,this.ot=E.Closed,this.ae=e(),this.st=e}get status(){return{state:this.ot,stateSince:this.ae,lastError:this.ai}}oe(t,e=!1){let n=t===E.Interrupted&&this.ot===E.Initializing?E.Initializing:t,s=this.ot!==n;s&&(this.ot=n,this.ae=this.st()),(s||e)&&this.ri.emit("dataSourceStatus",this.status)}requestStateUpdate(t){this.oe(t)}reportError(t,e,n,s=!1){let r={kind:t,message:e,statusCode:n,time:this.st()};this.ai=r,this.oe(s?E.Interrupted:E.Closed,!0)}},ke=class{constructor(t,e,n,s,r){this.oi=t,this.ci=e,this.ui=n,this.u=s,this.t=r,this.ce=!1}async ue(){var r,a,o,c,u,h,d;if(this.ce)return;let t=f=>{var p,m,y;(p=this.t)==null||p.error("Polling received invalid data"),(m=this.t)==null||m.debug(`Invalid JSON follows: ${f}`),(y=this.u)==null||y.call(this,new I(w.InvalidData,"Malformed JSON data in polling response"))};(r=this.t)==null||r.debug("Polling LaunchDarkly for feature flag updates");let e=Date.now();try{let f=await this.oi.requestPayload();try{let p=JSON.parse(f);try{(a=this.ui)==null||a.call(this,p)}catch(m){(o=this.t)==null||o.error(`Exception from data handler: ${m}`)}}catch(p){t(f)}}catch(f){let p=f;if(p.status!==void 0&&!z(p.status)){(c=this.t)==null||c.error(H(f,"polling request")),(u=this.u)==null||u.call(this,new I(w.ErrorResponse,p.message,p.status));return}(h=this.t)==null||h.error(H(f,"polling request","will retry"))}let n=Date.now()-e,s=Math.max(this.ci*1e3-n,0);(d=this.t)==null||d.debug("Elapsed: %d ms, sleeping for %d ms",n,s),this.At=setTimeout(()=>{this.ue()},s)}start(){this.ue()}stop(){this.At&&(clearTimeout(this.At),this.At=void 0),this.ce=!0}close(){this.stop()}},Pn=(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 F(w.InvalidData,"Malformed JSON data in event stream"))},xe=class{constructor(t,e,n,s,r,a,o,c,u){var f;this.li=t,this.Ct=e,this.e=n,this.E=s,this.hi=a,this.m=o,this.u=c,this.t=u;let h;e.useReport&&!s.getEventSourceCapabilities().customMethod?h=e.paths.pathPing(r,t):h=e.useReport?e.paths.pathReport(r,t):e.paths.pathGet(r,t);let d=[...(f=e.queryParameters)!=null?f:[]];this.Ct.withReasons&&d.push({key:"withReasons",value:"true"}),this.E=s,this.nt=g({},e.baseHeaders),this.t=u,this.di=_e(e.serviceEndpoints,h,d)}le(){this.ct=Date.now()}Ot(t){this.ct&&this.m&&this.m.recordStreamInit(this.ct,!t,Date.now()-this.ct),this.ct=void 0}fi(t){var e,n,s;return qe(t)?((s=this.t)==null||s.warn(H(t,"streaming request","will retry")),this.Ot(!1),this.le(),!0):(this.Ot(!1),(e=this.u)==null||e.call(this,new F(w.ErrorResponse,t.message,t.status,!1)),(n=this.t)==null||n.error(H(t,"streaming request")),!1)}start(){this.le();let t;this.Ct.useReport?(this.nt["content-type"]="application/json",t={method:"REPORT",body:this.li}):t={};let e=this.E.createEventSource(this.di,b(g({headers:this.nt},t),{errorFilter:n=>this.fi(n),initialRetryDelayMillis:this.Ct.initialRetryDelayMillis,readTimeoutMillis:5*60*1e3,retryResetIntervalMillis:60*1e3}));this.he=e,e.onclose=()=>{var n;(n=this.t)==null||n.info("Closed LaunchDarkly stream connection")},e.onerror=()=>{},e.onopen=()=>{var n;(n=this.t)==null||n.info("Opened LaunchDarkly stream connection")},e.onretrying=n=>{var s;(s=this.t)==null||s.info(`Will retry stream connection in ${n.delayMillis} milliseconds`)},this.e.forEach(({deserializeData:n,processJson:s},r)=>{e.addEventListener(r,a=>{var o,c;if((o=this.t)==null||o.debug(`Received ${r} event`),a!=null&&a.data){this.Ot(!0);let{data:u}=a,h=n(u);if(!h){Pn(r,u,this.t,this.u);return}s(h)}else(c=this.u)==null||c.call(this,new F(w.InvalidData,"Unexpected payload from event stream"))})}),e.addEventListener("ping",async()=>{var n,s,r,a,o,c,u;(n=this.t)==null||n.debug("Got PING, going to poll LaunchDarkly for feature flag updates");try{let h=await this.hi.requestPayload();try{let d=JSON.parse(h);try{(s=this.e.get("put"))==null||s.processJson(d)}catch(f){(r=this.t)==null||r.error(`Exception from data handler: ${f}`)}}catch(d){(a=this.t)==null||a.error("Polling after ping received invalid data"),(o=this.t)==null||o.debug(`Invalid JSON follows: ${h}`),(c=this.u)==null||c.call(this,new I(w.InvalidData,"Malformed JSON data in ping polling response"))}}catch(h){let d=h;(u=this.u)==null||u.call(this,new I(w.ErrorResponse,d.message,d.status))}})}stop(){var t;(t=this.he)==null||t.close(),this.he=void 0}close(){this.stop()}},Lt=class{constructor(t,e,n,s,r,a,o,c,u){this.platform=t,this.flagManager=e,this.credential=n,this.config=s,this.getPollingPaths=r,this.getStreamingPaths=a,this.baseHeaders=o,this.emitter=c,this.diagnosticsManager=u,this.closed=!1,this.logger=s.logger,this.dataSourceStatusManager=new De(c),this.N=new be(e,this.dataSourceStatusManager,this.config.logger)}setConnectionParams(t){this.gi=t}createPollingProcessor(t,e,n,s,r){let a=new ke(n,this.config.pollInterval,async o=>{await this.N.handlePut(e,o),s==null||s()},o=>{this.emitter.emit("error",t,o),this.N.handlePollingError(o),r==null||r(o)},this.logger);this.updateProcessor=this.de(a,this.dataSourceStatusManager)}createStreamingProcessor(t,e,n,s,r){var o;let a=new xe(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.gi)==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.N.handleStreamingError(c),r==null||r(c)},this.logger);this.updateProcessor=this.de(a,this.dataSourceStatusManager)}createStreamListeners(t,e){let n=new Map;return n.set("put",{deserializeData:JSON.parse,processJson:async s=>{await this.N.handlePut(t,s),e==null||e()}}),n.set("patch",{deserializeData:JSON.parse,processJson:async s=>{this.N.handlePatch(t,s)}}),n.set("delete",{deserializeData:JSON.parse,processJson:async s=>{this.N.handleDelete(t,s)}}),n}de(t,e){return{start:()=>{e.requestStateUpdate(E.Initializing),t.start()},stop:()=>{t.stop(),e.requestStateUpdate(E.Closed)},close:()=>{t.close(),e.requestStateUpdate(E.Closed)}}}close(){var t;(t=this.updateProcessor)==null||t.close(),this.closed=!0}};function Ot(){return typeof document!==void 0}function Ae(){return typeof window!==void 0}function $t(i,t,e){return Ot()?(document.addEventListener(i,t,e),()=>{document.removeEventListener(i,t,e)}):()=>{}}function Tt(i,t,e){return Ot()?(window.addEventListener(i,t,e),()=>{window.removeEventListener(i,t,e)}):()=>{}}function A(){return Ae()?window.location.href:""}function li(){return Ae()?window.location.search:""}function hi(){return Ae()?window.location.hash:""}function di(){if(typeof crypto!==void 0)return crypto;throw Error("Access to a web crypto API is required")}function fi(){return Ot()?document.visibilityState:"visibile"}function gi(i){if(Ot())return document.querySelectorAll(i)}function pi(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=g({value:t[o]},r[o]):c={value:t[o],version:0},a[o]={version:c.version,flag:c}}}),a}var Un="[BrowserDataManager]",Z=class extends Lt{constructor(e,n,s,r,a,o,c,u,h,d){super(e,n,s,r,o,c,u,h,d);this.Oi=a;this.K=void 0;this.$t=!1;this.K=a.streaming}k(e,...n){this.logger.debug(`${Un} ${e}`,...n)}async identify(e,n,s,r){if(this.closed){this.k("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.Tt=a==null?void 0:a.hash,a!=null&&a.bootstrap?this.pi(s,a.bootstrap,e):(await this.flagManager.loadCached(s)&&this.k("Identify - Flags loaded from cache. Continuing to initialize via a poll."),await this.mi(s,e,n)),this.Rt()}async mi(e,n,s){var r,a;try{this.dataSourceStatusManager.requestStateUpdate(E.Initializing);let o=JSON.stringify(k.toLDContext(e)),u=await Se(o,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.Tt).requestPayload();try{let d=this.createStreamListeners(e,n).get("put");d.processJson(d.deserializeData(u))}catch(h){this.dataSourceStatusManager.reportError(w.InvalidData,(r=h.message)!=null?r:"Could not parse poll response")}}catch(o){this.dataSourceStatusManager.reportError(w.NetworkError,(a=o.message)!=null?a:"unexpected network error",o.status),s(o)}}pi(e,n,s){this.flagManager.setBootstrap(e,pi(this.logger,n)),this.k("Identify - Initialization completed from bootstrap"),s()}setForcedStreaming(e){this.K=e,this.Rt()}setAutomaticStreamingState(e){this.$t=e,this.Rt()}Rt(){let e=this.K||this.$t&&this.K===void 0;this.k(`Updating streaming state. forced(${this.K}) automatic(${this.$t})`),e?this.yi():this.vi()}vi(){var e;this.updateProcessor&&this.k("Stopping update processor."),(e=this.updateProcessor)==null||e.close(),this.updateProcessor=void 0}yi(){if(this.updateProcessor){this.k("Update processor already active. Not changing state.");return}if(!this.context){this.k("Context not set, not starting update processor.");return}this.k("Starting update processor."),this.wi(this.context)}wi(e,n,s){var c;let r=k.toLDContext(e);(c=this.updateProcessor)==null||c.close();let a=JSON.stringify(k.toLDContext(e)),o=Se(a,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.Tt);this.createStreamingProcessor(r,e,o,n,s),this.updateProcessor.start()}};function mi(i){let e=$t("visibilitychange",()=>{fi()==="hidden"&&i()}),n=Tt("pagehide",i);return()=>{e(),n()}}function Q(i){if(typeof i!="string")throw new TypeError("Expected a string");return i.replace(/[|\\{}()[\]^$+*?.]/g,"\\$&").replace(/-/g,"\\x2d")}function Fn(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(`^${Q(i.url)}/?$`).test(t);case"canonical":return new RegExp(`^${Q(i.url)}/?$`).test(r);case"substring":return new RegExp(`.*${Q(i.substring)}.*$`).test(r);case"regex":return new RegExp(i.pattern).test(r);default:return!1}}function jn(i,t){let e=[];return t.forEach(n=>{let s=i.target,{selector:r}=n,a=gi(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 tt=class{constructor(t,e){let n=t.filter(a=>{var o;return(o=a.urls)==null?void 0:o.some(c=>Fn(c,A(),li(),hi()))}),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=>{jn(o,r).forEach(c=>{e(c)})};this.fe=$t("click",a)}}close(){var t;(t=this.fe)==null||t.call(this)}};var Bn=300,Rt=class{constructor(t){this.It=A();let e=()=>{let s=A();s!==this.It&&(this.It=s,t())};this.Nt=setInterval(e,Bn);let n=Tt("popstate",e);this.ge=()=>{n()}}close(){var t;this.Nt&&clearInterval(this.Nt),(t=this.ge)==null||t.call(this)}};var et=class{constructor(t,e,n,s,r,a=o=>new Rt(o)){this.E=e;this.Di=s;this.bi=r;this.ut=[];this.me=!1;this.lt=`${n}/sdk/goals/${t}`,this.pe=a(()=>{this.Pt()})}async initialize(){await this.Ei(),this.Pt()}startTracking(){this.me=!0,this.Pt()}Pt(){var t;this.me&&((t=this.Mt)==null||t.close(),this.ut&&this.ut.length&&(this.Mt=new tt(this.ut,e=>{this.bi(A(),e)})))}async Ei(){try{let t=await this.E.fetch(this.lt);this.ut=await t.json()}catch(t){this.Di(new q(`Encountered error fetching goals: ${t}`))}}close(){var t,e;(t=this.pe)==null||t.close(),(e=this.Mt)==null||e.close()}};function yi(i){return i.kind==="click"}var Hn=2,vi={fetchGoals:!0,eventUrlTransformer:i=>i,streaming:void 0},Vn={fetchGoals:l.Boolean,eventUrlTransformer:l.Function,streaming:l.Boolean};function _n(i){var e;let t=g({},i);return(e=t.flushInterval)!=null||(t.flushInterval=Hn),t}function wi(i){let t=_n(i);return Object.keys(vi).forEach(e=>{delete t[e]}),t}function Ce(i,t){let e=g({},vi);return Object.entries(Vn).forEach(n=>{let[s,r]=n,a=i[s];a!==void 0&&(r.is(a)?e[s]=a:t.warn(D.wrongOptionType(s,r.getType(),typeof a)))}),e}var it=class{constructor(t,e){this.ki=t;this.ye=[];switch(e){case"sha1":this.Ut="SHA-1";break;case"sha256":this.Ut="SHA-256";break;default:throw new Error(`Algorithm is not supported ${e}`)}}async asyncDigest(t){let e=this.ye.join(""),n=new TextEncoder().encode(e),s=await this.ki.subtle.digest(this.Ut,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.ye.push(t),this}};var Kn={start:0,end:3},Gn={start:4,end:5},Oe={start:6,end:7},$e={start:8,end:8},qn={start:9,end:9},Jn={start:10,end:15};function Wn(){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 V(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 zn(i){return i[$e.start]=(i[$e.start]|128)&191,i[Oe.start]=i[Oe.start]&15|64,`${V(i,Kn)}-${V(i,Gn)}-${V(i,Oe)}-${V(i,$e)}${V(i,qn)}-${V(i,Jn)}`}function Yn(){let i=Wn();return zn(i)}function Te(){return typeof crypto!==void 0&&typeof crypto.randomUUID=="function"?crypto.randomUUID():Yn()}var nt=class{createHash(t){return new it(di(),t)}randomUUID(){return Te()}};function Xn(i){let t=Array.from(i,e=>String.fromCodePoint(e)).join("");return btoa(t)}var st=class{btoa(t){return Xn(new TextEncoder().encode(t))}};var rt=class{platformData(){return{name:"JS"}}sdkData(){return{name:"@launchdarkly/js-client-sdk",version:"0.0.0",userAgentBase:"JSClient"}}};var at=class{constructor(t,e,n=Math.random){this.Li=e;this.Si=n;this.Ft=0;this.jt=Math.max(1,t),this.ve=Math.ceil(Math.log2(3e4/this.jt))}G(){let t=Math.min(this.Ft,this.ve),e=this.jt*2**t;return Math.min(e,3e4)}xi(t){return t-Math.trunc(this.Si()*.5*t)}success(t=Date.now()){this.ht=t}fail(t=Date.now()){this.ht!==void 0&&t-this.ht>this.Li&&(this.Ft=0),this.ht=void 0;let e=this.xi(this.G());return this.Ft+=1,e}};var ot=class{constructor(t,e){this.lt=t;this.e={};this.G=new at(e.initialRetryDelayMillis,e.retryResetIntervalMillis),this.we=e.errorFilter,this.Ee()}Ee(){this.M=new EventSource(this.lt),this.M.onopen=()=>{var t;this.G.success(),(t=this.onopen)==null||t.call(this)},this.M.onerror=t=>{var e;this.Ai(t),(e=this.onerror)==null||e.call(this,t)},Object.entries(this.e).forEach(([t,e])=>{e.forEach(n=>{var s;(s=this.M)==null||s.addEventListener(t,n)})})}addEventListener(t,e){var n,s,r;(s=(n=this.e)[t])!=null||(n[t]=[]),this.e[t].push(e),(r=this.M)==null||r.addEventListener(t,e)}close(){var t,e;clearTimeout(this.Bt),this.Bt=void 0,(t=this.M)==null||t.close(),(e=this.onclose)==null||e.call(this)}Ci(t){var e;(e=this.onretrying)==null||e.call(this,{delayMillis:t}),this.Bt=setTimeout(()=>{this.Ee()},t)}Ai(t){this.close(),!(t.status&&typeof t.status=="number"&&!this.we(t))&&this.Ci(this.G.fail())}};var ct=class{fetch(t,e){return fetch(t,e)}createEventSource(t,e){return new ot(t,e)}getEventSourceCapabilities(){return{customMethod:!1,readTimeout:!1,headers:!1}}};function Ei(){return typeof localStorage!="undefined"}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 lt=class{constructor(t){this.encoding=new st;this.info=new rt;this.crypto=new nt;this.requests=new ct;Ei()&&(this.storage=new ut(t))}};var It=class extends St{constructor(t,e,n={},s){var p;let{logger:r,debug:a}=n,o=r!=null?r:new N({destination:{debug:console.debug,info:console.info,warn:console.warn,error:console.error},level:a?"debug":"info"}),c=(p=n.baseUri)!=null?p:"https://clientsdk.launchdarkly.com",u=s!=null?s:new lt(o),h=Ce(n,o),d=wi(b(g({},n),{logger:o})),{eventUrlTransformer:f}=h;super(t,e,u,d,(m,y,S,P,bi)=>new Z(u,m,t,y,h,()=>({pathGet($,T){return`/sdk/evalx/${t}/contexts/${oe(T,$)}`},pathReport($,T){return`/sdk/evalx/${t}/context`},pathPing($,T){throw new Error("Ping for polling unsupported.")}}),()=>({pathGet($,T){return`/eval/${t}/${oe(T,$)}`},pathReport($,T){return`/eval/${t}`},pathPing($,T){return`/ping/${t}`}}),S,P,bi),{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,f(A()))}),this.setEventSendingEnabled(!0,!1),h.fetchGoals&&(this.Ht=new et(t,u.requests,c,m=>{o.error(m.message)},(m,y)=>{let S=this.getInternalContext();if(!S)return;let P=f(m);yi(y)?this.sendEvent({kind:"click",url:P,samplingRatio:1,key:y.key,creationDate:Date.now(),context:S,selector:y.selector}):this.sendEvent({kind:"pageview",url:P,samplingRatio:1,key:y.key,creationDate:Date.now(),context:S})}),this.Ht.initialize(),h.automaticBackgroundHandling&&mi(()=>this.flush()))}async identify(t,e){var n;await super.identify(t,e),(n=this.Ht)==null||n.startTracking()}setStreaming(t){this.dataManager.setForcedStreaming(t)}be(){this.dataManager.setAutomaticStreamingState(!!this.emitter.listenerCount("change"))}on(t,e){super.on(t,e),this.be()}off(t,e){super.off(t,e),this.be()}};function Tr(i){return new N(i)}function Pr(i,t){return new It(i,j.Disabled,t)}export{Tr as basicLogger,Pr as initialize};
1
+ var Ci=Object.defineProperty,Ii=Object.defineProperties;var Oi=Object.getOwnPropertyDescriptors;var dt=Object.getOwnPropertySymbols;var Ue=Object.prototype.hasOwnProperty,Fe=Object.prototype.propertyIsEnumerable;var Re=(i,t,e)=>t in i?Ci(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,p=(i,t)=>{for(var e in t||(t={}))Ue.call(t,e)&&Re(i,e,t[e]);if(dt)for(var e of dt(t))Fe.call(t,e)&&Re(i,e,t[e]);return i},b=(i,t)=>Ii(i,Oi(t));var Ht=(i,t)=>{var e={};for(var s in i)Ue.call(i,s)&&t.indexOf(s)<0&&(e[s]=i[s]);if(i!=null&&dt)for(var s of dt(i))t.indexOf(s)<0&&Fe.call(i,s)&&(e[s]=i[s]);return e};function $i(i){return`/${i.replace(/~/g,"~0").replace(/\//g,"~1")}`}function ze(i){return i.indexOf("~")?i.replace(/~1/g,"/").replace(/~0/g,"~"):i}function Ni(i){return(i.startsWith("/")?i.substring(1):i).split("/").map(e=>ze(e))}function Pi(i){return!i.startsWith("/")}function Mi(i){return!i.match(/\/\/|(^\/.*~[^0|^1])|~$/)}var T=class{constructor(t,e=!1){if(e){let s=t;this.h=[s],this.isValid=s!=="",this.redactionName=s.startsWith("/")?$i(s):s}else{if(this.redactionName=t,t===""||t==="/"||!Mi(t)){this.isValid=!1,this.h=[];return}Pi(t)?this.h=[t]:t.indexOf("/",1)<0?this.h=[ze(t.slice(1))]:this.h=Ni(t),this.h[0]==="_meta"?this.isValid=!1:this.isValid=!0}}get(t){let{h:e,isValid:s}=this;if(!s)return;let n=t;for(let r=0;r<e.length;r+=1){let a=e[r];if(n!=null&&Object.prototype.hasOwnProperty.call(n,a)&&typeof n=="object"&&!Array.isArray(n))n=n[a];else return}return n}getComponent(t){return this.h[t]}get depth(){return this.h.length}get isKind(){return this.h.length===1&&this.h[0]==="kind"}compare(t){return this.depth===t.depth&&this.h.every((e,s)=>e===t.getComponent(s))}get components(){return[...this.h]}};T.InvalidReference=new T("");var Vt=class{is(t){if(Array.isArray(t))return!1;let s=typeof t;return s==="function"||s==="object"}getType(){return"factory method or object"}},C=class{constructor(t,e){this.Et=t,this.typeOf=typeof e}is(t){return Array.isArray(t)?!1:typeof t===this.typeOf}getType(){return this.Et}},gt=class{constructor(t,e){this.Et=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.Et}},G=class extends C{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 C{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"}},Gt=class{is(t){return typeof t=="boolean"||typeof t=="undefined"||t===null}getType(){return"boolean | undefined | null"}},Ri=/^\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d(\.\d\d*)?(Z|[-+]\d\d(:\d\d)?)/,Kt=class{is(t){return typeof t=="number"||typeof t=="string"&&Ri.test(t)}getType(){return"date"}},zt=class extends mt{constructor(){super(/^(\w|\.|-)+$/)}is(t){return super.is(t)&&t!=="kind"}},l=class{static createTypeArray(t,e){return new gt(t,e)}static numberWithMin(t){return new G(t)}static stringMatchingRegex(t){return new mt(t)}};l.String=new C("string","");l.Number=new C("number",0);l.ObjectOrFactory=new Vt;l.Object=new C("object",{});l.StringArray=new gt("string[]","");l.Boolean=new C("boolean",!0);l.Function=new _t;l.Date=new Kt;l.Kind=new zt;l.NullableBoolean=new Gt;function Je(i){return"kind"in i?l.String.is(i.kind)&&i.kind!=="multi":!1}function qe(i){return"kind"in i?l.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(n=>yt(n,[...t,i])).map(n=>n===void 0?"null":n).join(",")}]`:`{${Object.keys(i).sort().map(s=>{let n=yt(i[s],[...t,i]);if(n!==void 0)return`${JSON.stringify(s)}:${n}`}).filter(s=>s!==void 0).join(",")}}`}var Jt="user";function He(i){return i.includes("%")||i.includes(":")?i.replace(/%/g,"%25").replace(/:/g,"%3A"):i}function Ui(i){return i&&l.Object.is(i)}function je(i){return l.Kind.is(i)}function Be(i){return l.String.is(i)&&i!==""}function jt(i,t=!1){return i?i.map(e=>new T(e,t)):[]}function Fi(i){return i!=null}function Hi(i){let t=b(p({},i.custom||[]),{kind:"user",key:String(i.key)});if(Fi(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 D=class i{constructor(t,e,s){this.x=!1,this.st=!1,this.te=!1,this.$={},this.kind=e,this.valid=t,this.message=s}static w(t,e){return new i(!1,t,e)}static Ue(t,e){if(!(!e||!t.isValid))return t.depth===1&&t.getComponent(0)==="anonymous"?!!(e!=null&&e.anonymous):t.get(e)}ee(t){if(this.x)return this.$[t];if(this.kind===t)return this.u}static Fe(t){let e=Object.keys(t).filter(c=>c!=="kind"),s=e.every(je);if(!e.length)return i.w("multi","A multi-kind context must contain at least one kind");if(!s)return i.w("multi","Context contains invalid kinds");let n={},r=!0,a=e.reduce((c,h)=>{var d;let u=t[h];return Ui(u)?(c[h]=u,n[h]=jt((d=u._meta)==null?void 0:d.privateAttributes)):r=!1,c},{});if(!r)return i.w("multi","Context contained contexts that were not objects");if(!Object.values(a).every(c=>Be(c.key)))return i.w("multi","Context contained invalid keys");if(e.length===1){let c=e[0],h=new i(!0,c);return h.u=b(p({},a[c]),{kind:c}),h.nt=n,h.st=c==="user",h}let o=new i(!0,t.kind);return o.$=a,o.nt=n,o.x=!0,o}static He(t){var c;let{key:e,kind:s}=t,n=je(s),r=Be(e);if(!n)return i.w(s!=null?s:"unknown","The kind was not valid for the context");if(!r)return i.w(s,"The key for the context was not valid");let a=jt((c=t._meta)==null?void 0:c.privateAttributes),o=new i(!0,s);return o.st=s==="user",o.u=t,o.nt={[s]:a},o}static je(t){if(!(t.key!==void 0&&t.key!==null))return i.w("user","The key for the context was not valid");let s=new i(!0,"user");return s.st=!0,s.te=!0,s.u=Hi(t),s.nt={user:jt(t.privateAttributeNames,!0)},s}static fromLDContext(t){return t?Je(t)?i.He(t):qe(t)?i.Fe(t):We(t)?i.je(t):i.w("unknown","Context was not of a valid kind"):i.w("unknown","No context specified. Returning default value")}static toLDContext(t){if(!t.valid)return;let e=t.getContexts();if(!t.x)return e[0][1];let s={kind:"multi"};return e.forEach(n=>{let r=n[0],a=n[1];s[r]=a}),s}valueForKind(t,e=Jt){return t.isKind?this.kinds:i.Ue(t,this.ee(e))}key(t=Jt){var e;return(e=this.ee(t))==null?void 0:e.key}get isMultiKind(){return this.x}get canonicalKey(){return this.st?this.u.key:this.x?Object.keys(this.$).sort().map(t=>`${t}:${He(this.$[t].key)}`).join(":"):`${this.kind}:${He(this.u.key)}`}get kinds(){return this.x?Object.keys(this.$):[this.kind]}get kindsAndKeys(){return this.x?Object.entries(this.$).reduce((t,[e,s])=>(t[e]=s.key,t),{}):{[this.kind]:this.u.key}}privateAttributes(t){var e;return((e=this.nt)==null?void 0:e[t])||[]}getContexts(){return this.x?Object.entries(this.$):[[this.kind,this.u]]}get legacy(){return this.te}canonicalUnfilteredJson(){if(this.valid){if(this.bt)return this.bt;try{this.bt=yt(i.toLDContext(this))}catch(t){}return this.bt}}};D.UserKind=Jt;var ji=["key","kind","_meta","anonymous"].map(i=>new T(i,!0)),Bi=["name","ip","firstName","lastName","email","avatar","country"];function Vi(i,t){return i.depth===t.length&&t.every((e,s)=>e===i.getComponent(s))}function _i(i,t){let e=[],s={},n=[];for(e.push(...Object.keys(i).map(r=>({key:r,ptr:[r],source:i,parent:s,visited:[i]})));e.length;){let r=e.pop(),a=t.find(o=>Vi(o,r.ptr));if(a)n.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:s,excluded:n.sort()}}var qt=class{constructor(t,e){this.Be=t,this.Ve=e}filter(t,e=!1){let s=t.getContexts();if(s.length===1)return this.ie(t,s[0][1],s[0][0],e);let n={kind:"multi"};return s.forEach(([r,a])=>{n[r]=this.ie(t,a,r,e)}),n}_e(t,e,s,n){return(n?Object.keys(e).map(r=>new T(r,!0)):[...this.Ve,...t.privateAttributes(s)]).filter(r=>!ji.some(a=>a.compare(r)))}ie(t,e,s,n){let r=this.Be||n&&e.anonymous===!0,{cloned:a,excluded:o}=_i(e,this._e(t,e,s,r));return t.legacy&&Bi.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}},Ve=30*1e3,Gi=.5,vt=class{constructor(t,e,s=Math.random){this.Ge=e,this.Ke=s,this.kt=0,this.se=Math.max(1,t),this.ze=Math.ceil(Math.log2(Ve/this.se))}S(){let t=Math.min(this.kt,this.ze),e=this.se*2**t;return Math.min(e,Ve)}Je(t){return t-Math.trunc(this.Ke()*Gi*t)}success(t=Date.now()){this.Dt=t}fail(t=Date.now()){this.Dt!==void 0&&t-this.Dt>this.Ge&&(this.kt=0),this.Dt=void 0;let e=this.Je(this.S());return this.kt+=1,e}};var _e;(function(i){i[i.Valid=0]="Valid",i[i.Initializing=1]="Initializing",i[i.Interrupted=2]="Interrupted",i[i.Closed=3]="Closed"})(_e||(_e={}));var fn=2*60*1e3,pn=5*60*1e3;var w;(function(i){i.Unknown="UNKNOWN",i.NetworkError="NETWORK_ERROR",i.ErrorResponse="ERROR_RESPONSE",i.InvalidData="INVALID_DATA"})(w||(w={}));var N=class extends Error{constructor(t,e,s,n=!0){super(e),this.kind=t,this.status=s,this.name="LaunchDarklyPollingError",this.recoverable=n}},F=class extends Error{constructor(t,e,s,n=!0){super(e),this.kind=t,this.code=s,this.name="LaunchDarklyStreamingError",this.recoverable=n}},H;(function(i){i[i.Disabled=0]="Disabled",i[i.Enabled=1]="Enabled"})(H||(H={}));var j;(function(i){i[i.AnalyticsEvents=0]="AnalyticsEvents",i[i.DiagnosticEvent=1]="DiagnosticEvent"})(j||(j={}));var $;(function(i){i[i.Succeeded=0]="Succeeded",i[i.Failed=1]="Failed",i[i.FailedAndMustShutDown=2]="FailedAndMustShutDown"})($||($={}));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 Ki(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 Ji(i){return typeof i=="symbol"?"NaN":String(parseFloat(i))}var ft={s:i=>U(i),d:i=>Ki(i),i:i=>zi(i),f:i=>Ji(i),j:i=>U(i),o:i=>U(i),O:i=>U(i),c:()=>""};function Wt(...i){var e;let t=i.shift();if(l.String.is(t)){let s="",n=0;for(;n<t.length;){let r=t.charAt(n);if(r==="%"){if(n+1<t.length){let o=t.charAt(n+1);if(o in ft&&i.length){let c=i.shift();s+=(e=ft[o])==null?void 0:e.call(ft,c)}else o==="%"?s+="%":s+=`%${o}`;n+=2}}else s+=r,n+=1}return i.length&&(s.length&&(s+=" "),s+=i.map(U).join(" ")),s}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 qi=["debug","info","warn","error","none"],P=class i{static get(){return new i({})}constructor(t){var e,s,n;if(this.ei=(s=v[(e=t.level)!=null?e:"info"])!=null?s:v.info,this.ii=(n=t.name)!=null?n:"LaunchDarkly",this.oe=t.formatter,typeof t.destination=="object")this.ce={[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.ce={[v.debug]:r,[v.info]:r,[v.warn]:r,[v.error]:r}}}si(...t){var e;try{return this.oe?(e=this.oe)==null?void 0:e.call(this,...t):Wt(...t)}catch(s){return Wt(...t)}}ni(t,e){try{t(e)}catch(s){console.error(e)}}E(t,e){var s;if(t>=this.ei){let n=`${qi[t]}: [${this.ii}]`;try{let r=(s=this.ce)==null?void 0:s[t];r?this.ni(r,`${n} ${this.si(...e)}`):console.error(...e)}catch(r){console.error(...e)}}}error(...t){this.E(v.error,t)}warn(...t){this.E(v.warn,t)}info(...t){this.E(v.info,t)}debug(...t){this.E(v.debug,t)}},Wi={error:l.Function,warn:l.Function,info:l.Function,debug:l.Function},K=class{constructor(t,e){Object.entries(Wi).forEach(([s,n])=>{if(!n.is(t[s]))throw new Error(`Provided logger instance must support logger.${s}(...) method`)}),this.t=t,this.ri=e}E(t,e){try{this.t[t](...e)}catch(s){this.ri[t](...e)}}error(...t){this.E("error",t)}warn(...t){this.E("warn",t)}info(...t){this.E("info",t)}debug(...t){this.E("debug",t)}},oe=i=>{let t=new P({level:"info",destination:console.error,formatter:Wt});return i?new K(i,t):t},k=class{static deprecated(t,e){return`"${t}" is deprecated, please use "${e}"`}static optionBelowMinimum(t,e,s){return`Config option "${t}" had invalid value of ${e}, using minimum of ${s} instead`}static unknownOption(t){return`Ignoring unknown config option "${t}"`}static wrongOptionType(t,e,s){return`Config option "${t}" should be of type ${e}, got ${s}, 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`}},Yi=/^(\w|\.|-)+$/,Zi=l.stringMatchingRegex(Yi),Xi={is:(i,t)=>Zi.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={},s=t==null?void 0:t.application,n=t==null?void 0:t.logger;s&&Object.entries(s).forEach(([a,o])=>{if(o!=null){let{valid:c,message:h}=Xi.is(o,`application.${a}`);c?a==="versionName"?e["application-version-name"]=[o]:e[`application-${a}`]=[o]:n==null||n.warn(h)}});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,s){this.platform=s,this.basicConfiguration={tags:e.tags,logger:e.logger,offline:e.offline,serviceEndpoints:e.serviceEndpoints,sdkKey:t}}};function Bt(i){return i.replace(/\/+$/,"")}function ce(i){return i.replace(/^\/+/,"").replace(/\?$/,"")}var M=class i{constructor(t,e,s=i.DEFAULT_EVENTS,n="/bulk",r="/diagnostic",a=!0,o){this.streaming=Bt(t),this.polling=Bt(e),this.events=Bt(s),this.analyticsEventPath=n,this.diagnosticEventPath=r,this.includeAuthorizationHeader=a,this.payloadFilterKey=o}};M.DEFAULT_EVENTS="https://events.launchdarkly.com";function he(i,t){if(t.length===0)return i;let e=t.map(({key:s,value:n})=>`${s}=${n}`);return`${i}?${e.join("&")}`}function Ye(i,t,e){let s=ce(t),n=[...e];return i.payloadFilterKey&&n.push({key:"filter",value:i.payloadFilterKey}),he(`${i.streaming}/${s}`,n)}function Ze(i,t,e){let s=ce(t),n=[...e];return i.payloadFilterKey&&n.push({key:"filter",value:i.payloadFilterKey}),he(`${i.polling}/${s}`,n)}function Ge(i,t,e){let s=ce(t);return he(`${i.events}/${s}`,e)}var z=class extends Error{constructor(t){super(t),this.name="LaunchDarklyUnexpectedResponseError"}},J=class extends Error{constructor(t){super(t),this.name="LaunchDarklyClientError"}},Yt=class extends Error{constructor(t){super(t),this.name="LaunchDarklyTimeoutError"}};function W(i){return i>=400&&i<500?i===400||i===408||i===429:!0}function Qi(i){return i===413?!0:W(i)}function le(i){return i==null?i:JSON.parse(JSON.stringify(i))}function Tt(i){return Math.trunc(i*1e3)}var ts=i=>JSON.stringify(i)==="{}",Ct=(i,t)=>i&&Object.entries(i).reduce((e,[s,n])=>(n&&!ts(n)&&!(t!=null&&t.includes(s))&&(e[s]=typeof n=="object"?Ct(n,t):n),e),{});function _(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,s,n;if(Array.isArray(i)){if(e=i.length,e!=t.length)return!1;for(s=e;s--!==0;)if(!_(i[s],t[s]))return!1;return!0}if(i instanceof Map&&t instanceof Map){if(i.size!==t.size)return!1;for(s of i.entries())if(!t.has(s[0]))return!1;for(s of i.entries())if(!_(s[1],t.get(s[0])))return!1;return!0}if(i instanceof Set&&t instanceof Set){if(i.size!==t.size)return!1;for(s of i.entries())if(!t.has(s[0]))return!1;return!0}if(ArrayBuffer.isView(i)&&ArrayBuffer.isView(t)){if(e=i.length,e!=t.length)return!1;for(s=e;s--!==0;)if(i[s]!==t[s])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(n=Object.keys(i),e=n.length,e!==Object.keys(t).length)return!1;for(s=e;s--!==0;)if(!Object.prototype.hasOwnProperty.call(t,n[s]))return!1;for(s=e;s--!==0;){var r=n[s];if(!_(i[r],t[r]))return!1}return!0}return i!==i&&t!==t}function Xe(i,t,e,s=!0,n="user-agent"){let{userAgentBase:r,version:a,wrapperName:o,wrapperVersion:c}=t.sdkData(),h={[n]:`${r!=null?r:"NodeJSClient"}/${a}`};return s&&(h.authorization=i),o&&(h["x-launchdarkly-wrapper"]=c?`${o}/${c}`:o),e!=null&&e.value&&(h["x-launchdarkly-tags"]=e.value),h}function B(i,t,e){let s;i.status?s=`error ${i.status}${i.status===401?" (invalid SDK key)":""}`:s=`I/O error (${i.message||"unknown error"})`;let n=e!=null?e:"giving up permanently";return`Received ${s} for ${t} - ${n}`}function Qe({status:i}){return i?W(i):!0}var ue=(i,t)=>t.btoa(i).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"");var es=async(i=1e3)=>new Promise(t=>{setTimeout(t,i)}),ti=(i,t)=>new Promise((e,s)=>{setTimeout(()=>{let n=`${t} timed out after ${i} seconds.`;s(new Yt(n))},i*1e3)}),Zt=class{constructor(t,e,s){this.a=e,this.ai=s,this.Lt=[],this.he=Date.now(),this.le=this.he,this.ue={diagnosticId:e.crypto.randomUUID(),sdkKeySuffix:t.length>6?t.substring(t.length-6):t}}createInitEvent(){var s,n,r;let t=this.a.info.sdkData(),e=this.a.info.platformData();return{kind:"diagnostic-init",id:this.ue,creationDate:this.he,sdk:t,configuration:this.ai,platform:p({name:e.name,osArch:(s=e.os)==null?void 0:s.arch,osName:(n=e.os)==null?void 0:n.name,osVersion:(r=e.os)==null?void 0:r.version},e.additional||{})}}recordStreamInit(t,e,s){let n={timestamp:t,failed:e,durationMillis:s};this.Lt.push(n)}createStatsEventAndReset(t,e,s){let n=Date.now(),r={kind:"diagnostic",id:this.ue,creationDate:n,dataSinceDate:this.le,droppedEvents:t,deduplicatedUsers:e,eventsInLastBatch:s,streamInits:this.Lt};return this.Lt=[],this.le=n,r}},Xt;(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"})(Xt||(Xt={}));var is=Xt,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 Qt=class{constructor(t,e){let{basicConfiguration:s,platform:n}=t,{serviceEndpoints:{analyticsEventPath:r,diagnosticEventPath:a}}=s,{crypto:o,requests:c}=n;this.oi=p({},e),this.de=Ge(s.serviceEndpoints,r,[]),this.ci=Ge(s.serviceEndpoints,a,[]),this.A=c,this.hi=o}async rt(t,e,s,n){let r={status:$.Succeeded},a=b(p({},this.oi),{"content-type":"application/json"});s&&(a["x-launchdarkly-payload-id"]=s,a["x-launchDarkly-event-schema"]="4");let o;try{let{status:c,headers:h}=await this.A.fetch(e,{headers:a,body:JSON.stringify(t),compressBodyIfPossible:!0,method:"POST",keepalive:!0}),u=Date.parse(h.get("date")||"");if(u&&(r.serverTime=u),c<=204)return r;if(o=new z(B({status:c,message:"some events were dropped"},"event posting")),!W(c))return Qi(c)?r.status=$.Failed:r.status=$.FailedAndMustShutDown,r.error=o,r}catch(c){o=c}return o&&!n?(r.status=$.Failed,r.error=o,r):(await es(),this.rt(t,this.de,s,!1))}async sendEventData(t,e){let s=t===j.AnalyticsEvents?this.hi.randomUUID():void 0,n=t===j.AnalyticsEvents?this.de:this.ci;return this.rt(e,n,s,!0)}};function kt(i){return i.kind==="feature"}function ss(i){return i.kind==="identify"}function ns(i){return i.kind==="migration_op"}var te=class{constructor(t,e,s,n,r,a){this.count=t,this.key=e,this.value=s,this.version=r,this.variation=a,this.default=n}increment(){this.count+=1}};function rs(i){return`${i.key}:${i.variation!==null&&i.variation!==void 0?i.variation:""}:${i.version!==null&&i.version!==void 0?i.version:""}`}var Dt=class{constructor(t=!1,e){this.li=t,this.b=e,this.Y=0,this.at=0,this.ot={},this.ct={}}summarizeEvent(t){if(kt(t)&&!t.excludeFromSummaries){this.u||(this.u=t.context);let e=rs(t),s=this.ot[e],n=this.ct[t.key];n||(n=new Set,this.ct[t.key]=n),t.context.kinds.forEach(r=>n.add(r)),s?s.increment():this.ot[e]=new te(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.at&&(this.at=t.creationDate)}}getSummary(){var s;let t=Object.values(this.ot).reduce((n,r)=>{let a=n[r.key];a||(a={default:r.default,counters:[],contextKinds:[...this.ct[r.key]]},n[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),n},{}),e={startDate:this.Y,endDate:this.at,features:t,kind:"summary",context:this.u!==void 0&&this.li?(s=this.b)==null?void 0:s.filter(this.u):void 0};return this.ui(),e}ui(){this.Y=0,this.at=0,this.ot={},this.ct={}}},ee=class extends Error{constructor(t){super(t),this.name="LaunchDarklyInvalidSDKKeyError"}},ie=class{constructor(t,e){this.b=t,this.t=e,this.Z={}}summarizeEvent(t){var e;if(kt(t)){let s=t.context.canonicalUnfilteredJson();if(!s){t.context.valid&&((e=this.t)==null||e.error("Unable to serialize context, likely the context contains a cycle."));return}let n=this.Z[s];n||(this.Z[s]=new Dt(!0,this.b),n=this.Z[s]),n.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 as(i){return i.getSummaries!==void 0}var se=class{constructor(t,e,s,n,r,a=!0,o=!1){this.e=t,this.ht=n,this.k=r,this.lt=[],this.fe=0,this.At=0,this.Tt=0,this.Ct=!1,this.pe=0,this.It=!1,this.Ot=null,this.di=t.eventsCapacity,this.t=e.basicConfiguration.logger,this.ge=new Qt(e,s),this.b=new qt(t.allAttributesPrivate,t.privateAttributes.map(c=>new T(c))),o?this.X=new ie(this.b,this.t):this.X=new Dt,a&&this.start()}start(){var t,e;if(((t=this.ht)==null?void 0:t.flushInterval)!==void 0&&(this.Ot=setInterval(()=>{var s;(s=this.ht)==null||s.flush()},this.ht.flushInterval*1e3)),this.fi=setInterval(async()=>{var s;try{await this.flush()}catch(n){(s=this.t)==null||s.debug(`Flush failed: ${n}`)}},this.e.flushInterval*1e3),this.k){let s=this.k.createInitEvent();this.me(s),this.ye=setInterval(()=>{let n=this.k.createStatsEventAndReset(this.At,this.Tt,this.pe);this.At=0,this.Tt=0,this.me(n)},this.e.diagnosticRecordingInterval*1e3)}(e=this.t)==null||e.debug("Started EventProcessor.")}me(t){this.ge.sendEventData(j.DiagnosticEvent,t)}close(){clearInterval(this.fi),this.Ot&&clearInterval(this.Ot),this.ye&&clearInterval(this.ye)}async flush(){var e;if(this.It)throw new ee("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=[],as(this.X))this.X.getSummaries().forEach(n=>{Object.keys(n.features).length&&t.push(n)});else{let s=this.X.getSummary();Object.keys(s.features).length&&t.push(s)}t.length&&(this.pe=t.length,(e=this.t)==null||e.debug("Flushing %d events",t.length),await this.rt(t))}sendEvent(t){var c;if(this.It)return;if(ns(t)){if(pt(t.samplingRatio)){let h=b(p({},t),{context:t.context?this.b.filter(t.context):void 0});h.samplingRatio===1&&delete h.samplingRatio,this.ut(h)}return}this.X.summarizeEvent(t);let e=kt(t),s=e&&t.trackEvents||!e,n=this.pi(t),r=ss(t),a=(c=this.ht)==null?void 0:c.processContext(t.context);a||r||(this.Tt+=1),a&&!r&&this.ut(this.$t({kind:"index",creationDate:t.creationDate,context:t.context,samplingRatio:1},!1)),s&&pt(t.samplingRatio)&&this.ut(this.$t(t,!1)),n&&pt(t.samplingRatio)&&this.ut(this.$t(t,!0))}$t(t,e){switch(t.kind){case"feature":{let s={kind:e?"debug":"feature",creationDate:t.creationDate,context:this.b.filter(t.context,!e),key:t.key,value:t.value,default:t.default};return t.samplingRatio!==1&&(s.samplingRatio=t.samplingRatio),t.prereqOf&&(s.prereqOf=t.prereqOf),t.variation!==void 0&&(s.variation=t.variation),t.version!==void 0&&(s.version=t.version),t.reason&&(s.reason=t.reason),s}case"index":case"identify":{let s={kind:t.kind,creationDate:t.creationDate,context:this.b.filter(t.context)};return t.samplingRatio!==1&&(s.samplingRatio=t.samplingRatio),s}case"custom":{let s={kind:"custom",creationDate:t.creationDate,key:t.key,context:this.b.filter(t.context)};return t.samplingRatio!==1&&(s.samplingRatio=t.samplingRatio),t.data!==void 0&&(s.data=t.data),t.metricValue!==void 0&&(s.metricValue=t.metricValue),t.url!==void 0&&(s.url=t.url),s}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.di?(this.lt.push(t),this.Ct=!1):(this.Ct||(this.Ct=!0,(e=this.t)==null||e.warn("Exceeded event queue capacity. Increase capacity to avoid dropping events.")),this.At+=1)}pi(t){return kt(t)&&t.debugEventsUntilDate&&t.debugEventsUntilDate>this.fe&&t.debugEventsUntilDate>Date.now()}async rt(t){let e=await this.ge.sendEventData(j.AnalyticsEvents,t);if(e.status===$.FailedAndMustShutDown&&(this.It=!0),e.serverTime&&(this.fe=e.serverTime),e.error)throw e.error}},xt=class{constructor(t,e,s,n,r=1,a){this.context=t,this.key=e,this.data=s,this.metricValue=n,this.samplingRatio=r,this.url=a,this.kind="custom",this.creationDate=Date.now(),this.context=t}},q=class{constructor(t,e,s,n,r,a,o,c,h,u,d,f,g=1){this.withReasons=t,this.context=e,this.key=s,this.samplingRatio=g,this.kind="feature",this.creationDate=Date.now(),this.value=n,this.default=r,a!==void 0&&(this.version=a),o!==void 0&&(this.variation=o),c!==void 0&&(this.trackEvents=c),h!==void 0&&(this.prereqOf=h),u!==void 0&&(this.reason=u),d!==void 0&&(this.debugEventsUntilDate=d),f!==void 0&&(this.excludeFromSummaries=f)}},St=class{constructor(t,e=1){this.context=t,this.samplingRatio=e,this.kind="identify",this.creationDate=Date.now()}},ne=class{close(){}async flush(){}sendEvent(){}},re=class{constructor(t){this.Nt=t}evalEvent(t){var e;return new q(this.Nt,t.context,t.flagKey,t.value,t.defaultVal,t.version,(e=t.variation)!=null?e:void 0,t.trackEvents||t.addExperimentData,t.prereqOfFlagKey,this.Nt||t.addExperimentData?t.reason:void 0,t.debugEventsUntilDate,t.excludeFromSummaries,t.samplingRatio)}unknownFlagEvent(t,e,s){return new q(this.Nt,s,t,e,e,void 0,void 0,void 0,void 0,void 0,void 0,void 0,void 0)}identifyEvent(t){return new St(t,1)}customEvent(t,e,s,n,r=1){return new xt(e,t,s!=null?s:void 0,n!=null?n:void 0,r)}},Lt=class{constructor(t,e,s){this.gi=t,this.l=e,this.t=s,this.n=[],this.N=void 0,this.H=!1,this.B=[],this.mi=n=>{if(this.Pt(),!n.payloads.length)return;let r=n.payloads[0];switch(r==null?void 0:r.code){case"xfer-full":this.H=!0;break;case"xfer-changes":this.H=!1;break;case"none":this.H=!1,this.yi(r);break;default:return}this.N=r==null?void 0:r.id},this.vi=n=>{var a;if(!this.N||!n.kind||!n.key||!n.version||!n.object)return;let r=this.wi(n.kind,n.object);if(!r){(a=this.t)==null||a.warn(`Unable to process object for kind: '${n.kind}'`);return}this.B.push({kind:n.kind,key:n.key,version:n.version,object:r})},this.Ei=n=>{!this.N||!n.kind||!n.key||!n.version||this.B.push({kind:n.kind,key:n.key,version:n.version,deleted:!0})},this.yi=n=>{if(!n.id||!n.target)return;let r={id:n.id,version:n.target,basis:!1,updates:[]};this.n.forEach(a=>a(r)),this.ve()},this.bi=n=>{if(!this.N||!n.state||!n.version){this.Pt();return}let r={id:this.N,version:n.version,state:n.state,basis:this.H,updates:this.B};this.n.forEach(a=>a(r)),this.ve()},this.ki=n=>{var r;(r=this.t)==null||r.info(`Goodbye was received from the LaunchDarkly connection with reason: ${n.reason}.`),this.Pt()},this.Di=n=>{var r;(r=this.t)==null||r.info(`An issue was encountered receiving updates for payload ${this.N} with reason: ${n.reason}.`),this.xi()}}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.mi(e.data);break}case"put-object":{this.vi(e.data);break}case"delete-object":{this.Ei(e.data);break}case"payload-transferred":{this.bi(e.data);break}case"goodbye":{this.ki(e.data);break}case"error":{this.Di(e.data);break}}})}wi(t,e){var s,n;return(n=(s=this.gi)[t])==null?void 0:n.call(s,e)}ve(){this.H=!1,this.B=[]}xi(){this.B=[]}Pt(){this.N=void 0,this.H=!1,this.B=[]}},ae=class{constructor(t,e,s,n){this.l=s,this.t=n,this.V(t,"server-intent"),this.V(t,"put-object"),this.V(t,"delete-object"),this.V(t,"payload-transferred"),this.V(t,"goodbye"),this.V(t,"error"),this.Mt=new Lt(e,s,n)}addPayloadListener(t){this.Mt.addPayloadListener(t)}removePayloadListener(t){this.Mt.removePayloadListener(t)}V(t,e){t.addEventListener(e,async s=>{var n,r,a,o,c;if(s!=null&&s.data){(n=this.t)==null||n.debug(`Received ${e} event. Data is ${s.data}`);try{this.Mt.processEvents([{event:e,data:JSON.parse(s.data)}])}catch(h){(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: ${s.data}`),(o=this.l)==null||o.call(this,w.InvalidData,"Malformed data in EventStream.")}}else(c=this.l)==null||c.call(this,w.Unknown,"Event from EventStream missing data.")})}};function os(i){if(i){let t=Object.keys(i).find(e=>e.toLowerCase()==="x-ld-envid");if(t)return{environmentId:i[t]}}}var Ke="unknown plugin";function At(i,t){try{return t.getMetadata().name||Ke}catch(e){return i.error("Exception thrown getting metadata for plugin. Unable to get plugin name."),Ke}}function cs(i,t,e){let s=[];return e.forEach(n=>{var r;try{let a=(r=n.getHooks)==null?void 0:r.call(n,t);a===void 0?i.error(`Plugin ${At(i,n)} returned undefined from getHooks.`):a&&a.length>0&&s.push(...a)}catch(a){i.error(`Exception thrown getting hooks for plugin ${At(i,n)}. Unable to get hooks.`)}}),s}function hs(i,t,e,s){s.forEach(n=>{try{n.register(e,t)}catch(r){i.error(`Exception thrown registering plugin ${At(i,n)}.`)}})}var x=Object.freeze({__proto__:null,ClientMessages:bt,DiagnosticsManager:Zt,ErrorKinds:is,EventFactoryBase:re,EventProcessor:se,InputCustomEvent:xt,InputEvalEvent:q,InputIdentifyEvent:St,NullEventProcessor:ne,PayloadProcessor:Lt,PayloadStreamReader:ae,canonicalize:yt,initMetadataFromHeaders:os,isLegacyUser:We,isMultiKind:qe,isSingleKind:Je,safeGetHooks:cs,safeGetName:At,safeRegisterPlugins:hs,shouldSample:pt});var E;(function(i){i.Initializing="INITIALIZING",i.Valid="VALID",i.Interrupted="INTERRUPTED",i.SetOffline="SET_OFFLINE",i.Closed="CLOSED"})(E||(E={}));function us(i){return i>=200&&i<=299}var It=class extends Error{constructor(t,e){super(t),this.status=e,this.name="LaunchDarklyRequestError"}},me=class{constructor(t,e,s,n,r){this.A=t,this.Si=e,this.dt=s,this.Li=n,this.Ai=r}async requestPayload(){let t;try{let e=await this.A.fetch(this.Si,{method:this.Li,headers:this.dt,body:this.Ai});if(us(e.status))return await e.text();t=e.status}catch(e){throw new It(e==null?void 0:e.message)}throw new It(`Unexpected status code: ${t}`,t)}};function Ce(i,t,e,s,n,r,a,o,c,h){let u,d="GET",f=p({},r);c&&(d="REPORT",f["content-type"]="application/json",u=i);let g=c?e.pathReport(n,i):e.pathGet(n,i),m=[...a!=null?a:[]];o&&m.push({key:"withReasons",value:"true"}),h&&m.push({key:"h",value:h});let y=Ze(t,g,m);return new me(s,y,f,d,u)}var ds={logger:l.Object,maxCachedContexts:l.numberWithMin(0),baseUri:l.String,streamUri:l.String,eventsUri:l.String,capacity:l.numberWithMin(1),diagnosticRecordingInterval:l.numberWithMin(2),flushInterval:l.numberWithMin(2),streamInitialReconnectDelay:l.numberWithMin(0),allAttributesPrivate:l.Boolean,debug:l.Boolean,diagnosticOptOut:l.Boolean,withReasons:l.Boolean,sendEvents:l.Boolean,pollInterval:l.numberWithMin(30),useReport:l.Boolean,privateAttributes:l.StringArray,applicationInfo:l.Object,wrapperName:l.String,wrapperVersion:l.String,payloadFilterKey:l.stringMatchingRegex(/^[a-zA-Z0-9](\w|\.|-)*$/),hooks:l.createTypeArray("Hook[]",{}),inspectors:l.createTypeArray("LDInspection",{})},fs=60*5,ri="https://clientsdk.launchdarkly.com",ai="https://clientstream.launchdarkly.com";function ps(i){return i instanceof K?i:oe(i)}var ye=class{constructor(t={},e={getImplementationHooks:()=>[],credentialType:"mobileKey"}){var n,r,a;this.logger=oe(),this.baseUri=ri,this.eventsUri=M.DEFAULT_EVENTS,this.streamUri=ai,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=fs,this.hooks=[],this.inspectors=[],this.logger=ps(t.logger),this.Ti(t).forEach(o=>this.logger.warn(o)),this.serviceEndpoints=new M(this.streamUri,this.baseUri,this.eventsUri,e.analyticsEventPath,e.diagnosticEventPath,e.includeAuthorizationHeader,t.payloadFilterKey),this.useReport=(n=t.useReport)!=null?n:!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}Ti(t){let e=[];return Object.entries(t).forEach(([s,n])=>{let r=ds[s];if(r)if(r.is(n))s==="logger"||(this[s]=n!=null?n:void 0);else{let a=r.getType();if(a==="boolean")e.push(k.wrongOptionTypeBoolean(s,typeof n)),this[s]=!!n;else if(a==="boolean | undefined | null")e.push(k.wrongOptionTypeBoolean(s,typeof n)),typeof n!="boolean"&&typeof n!="undefined"&&n!==null&&(this[s]=!!n);else if(r instanceof G&&l.Number.is(n)){let{min:o}=r;e.push(k.optionBelowMinimum(s,n,o)),this[s]=o}else e.push(k.wrongOptionType(s,r.getType(),typeof n))}else e.push(k.unknownOption(s))}),e}};async function oi(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 ci=async(i,{crypto:t,storage:e})=>{let s=await(e==null?void 0:e.get(i));return s||(s=t.randomUUID(),await(e==null?void 0:e.set(i,s))),s};function hi(i){return async t=>oi(i.createHash("sha256").update(t),"base64")}var S=async i=>i;async function Z(i){return(await Promise.all(i.map(e=>e.transform(e.value)))).join("_")}async function gs(i,t){return Z([{value:"LaunchDarkly",transform:S},{value:t,transform:hi(i)}])}async function ms(i){return Z([{value:"LaunchDarkly",transform:S},{value:"AnonymousKeys",transform:S},{value:i,transform:S}])}async function ys(i){return Z([{value:"LaunchDarkly",transform:S},{value:"ContextKeys",transform:S},{value:i,transform:S}])}async function vs(i){return Z([{value:i,transform:S},{value:"ContextIndex",transform:S}])}async function ei(i,t,e){return Z([{value:t,transform:S},{value:e.canonicalKey,transform:hi(i)}])}var{isLegacyUser:ws,isSingleKind:de,isMultiKind:ii}=x,li="1.0",Es=i=>{let s=i,{kind:t}=s,e=Ht(s,["kind"]);return{kind:"multi",[t]:e}},bs=async({crypto:i,info:t},{applicationInfo:e})=>{var a;let{ld_application:s}=t.platformData(),n=(a=Ct(s))!=null?a:{},r=(e==null?void 0:e.id)||(n==null?void 0:n.id);if(r){let o=(e==null?void 0:e.version)||(n==null?void 0:n.version),c=(e==null?void 0:e.name)||(n==null?void 0:n.name),h=(e==null?void 0:e.versionName)||(n==null?void 0:n.versionName);return n=p(p(p(b(p({},n),{id:r}),o?{version:o}:{}),c?{name:c}:{}),h?{versionName:h}:{}),n.key=await oi(i.createHash("sha256").update(r),"base64"),n.envAttributesVersion=n.envAttributesVersion||li,n}},ks=async i=>{var o,c,h,u;let{ld_device:t,os:e}=i.info.platformData(),s=(o=Ct(t))!=null?o:{},n=(e==null?void 0:e.name)||((c=s.os)==null?void 0:c.name),r=(e==null?void 0:e.version)||((h=s.os)==null?void 0:h.version),a=(u=s.os)==null?void 0:u.family;if((n||r||a)&&(s.os=p(p(p({},n?{name:n}:{}),r?{version:r}:{}),a?{family:a}:{})),Object.keys(s).filter(d=>d!=="key"&&d!=="envAttributesVersion").length){let d=await ys("ld_device");return s.key=await ci(d,i),s.envAttributesVersion=s.envAttributesVersion||li,s}},Ds=async(i,t,e)=>{if(ws(i))return i;let s,n;if(de(i)&&i.kind!=="ld_application"||ii(i)&&!i.ld_application?s=await bs(t,e):e.logger.warn("Not adding ld_application environment attributes because it already exists."),de(i)&&i.kind!=="ld_device"||ii(i)&&!i.ld_device?n=await ks(t):e.logger.warn("Not adding ld_device environment attributes because it already exists."),s||n){let r=de(i)?Es(i):i;return p(p(p({},r),s?{ld_application:s}:{}),n?{ld_device:n}:{})}return i},{isLegacyUser:xs,isMultiKind:Ss,isSingleKind:Ls}=x,Ie=async(i,t,e)=>{let{anonymous:s,key:n}=t;if(s&&!n){let r=await ms(i);t.key=await ci(r,e)}},As=async(i,t)=>{await Ie(i.kind,i,t)},Ts=async(i,t)=>{let n=i,{kind:e}=n,s=Ht(n,["kind"]);return Promise.all(Object.entries(s).map(([r,a])=>Ie(r,a,t)))},Cs=async(i,t)=>{await Ie("user",i,t)},Is=async(i,t)=>{let e=le(i);return Ls(e)&&await As(e,t),Ss(e)&&await Ts(e,t),xs(e)&&await Cs(e,t),e},Os=i=>({customBaseURI:i.serviceEndpoints.polling!==ri,customStreamURI:i.serviceEndpoints.streaming!==ai,customEventsURI:i.serviceEndpoints.events!==M.DEFAULT_EVENTS,eventsCapacity:i.capacity,eventsFlushIntervalMillis:Tt(i.flushInterval),reconnectTimeMillis:Tt(i.streamInitialReconnectDelay),diagnosticRecordingIntervalMillis:Tt(i.diagnosticRecordingInterval),allAttributesPrivate:i.allAttributesPrivate,usingSecureMode:!1,bootstrapMode:!1}),$s=(i,t,e)=>{if(t.sendEvents&&!t.diagnosticOptOut)return new x.DiagnosticsManager(i,e,Os(t))};function fe(i,t){return{value:t!=null?t:null,variationIndex:null,reason:{kind:"ERROR",errorKind:i}}}function si(i,t,e){return{value:i,variationIndex:t!=null?t:null,reason:e!=null?e:null}}var Ns=(i,t,e,s,n)=>{if(t.sendEvents)return new x.EventProcessor(b(p({},t),{eventsCapacity:t.capacity}),new Et(i,t,e),s,void 0,n,!1,!0)},Ot=class extends x.EventFactoryBase{evalEventClient(t,e,s,n,r,a){let{trackEvents:o,debugEventsUntilDate:c,trackReason:h,flagVersion:u,version:d,variation:f}=n;return super.evalEvent({addExperimentData:h,context:r,debugEventsUntilDate:c,defaultVal:s,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(s){}return e}toJson(){return JSON.stringify(this.container)}notice(t,e){let s=this.container.index.find(n=>n.id===t);s===void 0?this.container.index.push({id:t,timestamp:e}):s.timestamp=e}prune(t){let e=Math.max(t,0);return this.container.index.length>e?(this.container.index.sort((s,n)=>s.timestamp-n.timestamp),this.container.index.splice(0,this.container.index.length-e)):[]}},ve=class{constructor(t,e,s,n,r,a,o=()=>Date.now()){this.a=t,this.Rt=e,this.Ci=s,this.m=n,this.T=r,this.t=a,this.ft=o,this.we=vs(this.Rt)}async init(t,e){this.T.init(t,e),await this.Ee(t)}async upsert(t,e,s){return this.T.upsert(t,e,s)?(await this.Ee(t),!0):!1}async loadCached(t){var n,r,a,o;let e=await ei(this.a.crypto,this.Rt,t),s=await((n=this.a.storage)==null?void 0:n.get(e));if(s==null){if(s=await((r=this.a.storage)==null?void 0:r.get(t.canonicalKey)),s==null)return!1;await((a=this.a.storage)==null?void 0:a.set(e,s)),await((o=this.a.storage)==null?void 0:o.clear(t.canonicalKey))}try{let c=JSON.parse(s),h=Object.entries(c).reduce((u,[d,f])=>(u[d]={version:f.version,flag:f},u),{});return this.T.initCached(t,h),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 Ii(){var e;if(this._!==void 0)return this._;let t=await((e=this.a.storage)==null?void 0:e.get(await this.we));if(!t)return this._=new Y,this._;try{this._=Y.fromJson(t),this.t.debug("Loaded context index from persistent storage")}catch(s){this.t.warn(`Could not load index from persistent storage: ${s.message}`),this._=new Y}return this._}async Ee(t){var c,h;let e=await this.Ii(),s=await ei(this.a.crypto,this.Rt,t);e.notice(s,this.ft());let n=e.prune(this.Ci);await Promise.all(n.map(async u=>{var d;return(d=this.a.storage)==null?void 0:d.clear(u.id)})),await((c=this.a.storage)==null?void 0:c.set(await this.we,e.toJson()));let r=this.m.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((h=this.a.storage)==null?void 0:h.set(s,o))}},we=class{constructor(){this.Q={}}init(t){this.Q=Object.entries(t).reduce((e,[s,n])=>(e[s]=n,e),{})}insertOrUpdate(t,e){this.Q[t]=e}get(t){if(Object.prototype.hasOwnProperty.call(this.Q,t))return this.Q[t]}getAll(){return this.Q}};function Ps(i,t){let e=[];return Object.entries(i).forEach(([s,n])=>{let r=t[s];(!r||!_(n,r))&&e.push(s)}),Object.keys(t).forEach(s=>{i[s]||e.push(s)}),e}var Ee=class{constructor(t,e){this.tt=new Array,this.m=t,this.t=e}init(t,e){this.be=t.canonicalKey;let s=this.m.getAll();this.m.init(e);let n=Ps(s,e);n.length>0&&this.tt.forEach(r=>{try{r(t,n,"init")}catch(a){}})}initCached(t,e){this.be!==t.canonicalKey&&this.init(t,e)}upsert(t,e,s){if(this.be!==t.canonicalKey)return this.t.warn("Received an update for an inactive context."),!1;let n=this.m.get(e);return n!==void 0&&n.version>=s.version?!1:(this.m.insertOrUpdate(e,s),this.tt.forEach(r=>{try{r(t,[e],"patch")}catch(a){}}),!0)}on(t){this.tt.push(t)}off(t){let e=this.tt.indexOf(t);e>-1&&this.tt.splice(e,1)}},be=class{constructor(t,e,s,n,r=()=>Date.now()){this.m=new we,this.T=new Ee(this.m,n),this.Ut=this.Oi(t,e,s,n,r)}async Oi(t,e,s,n,r=()=>Date.now()){let a=await gs(t.crypto,e);return new ve(t,a,s,this.m,this.T,n,r)}get(t){return this.m.get(t)}getAll(){return this.m.getAll()}setBootstrap(t,e){this.T.init(t,e)}async init(t,e){return(await this.Ut).init(t,e)}async upsert(t,e,s){return(await this.Ut).upsert(t,e,s)}async loadCached(t){return(await this.Ut).loadCached(t)}on(t){this.T.on(t)}off(t){this.T.off(t)}},ni="unknown hook",ui="beforeEvaluation",di="afterEvaluation",Ms="afterTrack";function X(i,t,e,s,n){try{return s()}catch(r){return i==null||i.error(`An error was encountered in "${t}" of the "${e}" hook: ${r}`),n}}function Q(i,t){try{return t.getMetadata().name||ni}catch(e){return i.error("Exception thrown getting metadata for hook. Unable to get hook name."),ni}}function Rs(i,t,e){return t.map(s=>X(i,ui,Q(i,s),()=>{var n,r;return(r=(n=s==null?void 0:s.beforeEvaluation)==null?void 0:n.call(s,e,{}))!=null?r:{}},{}))}function Us(i,t,e,s,n){for(let r=t.length-1;r>=0;r-=1){let a=t[r],o=s[r];X(i,di,Q(i,a),()=>{var c,h;return(h=(c=a==null?void 0:a.afterEvaluation)==null?void 0:c.call(a,e,o,n))!=null?h:{}},{})}}function Fs(i,t,e){return t.map(s=>X(i,ui,Q(i,s),()=>{var n,r;return(r=(n=s==null?void 0:s.beforeIdentify)==null?void 0:n.call(s,e,{}))!=null?r:{}},{}))}function Hs(i,t,e,s,n){for(let r=t.length-1;r>=0;r-=1){let a=t[r],o=s[r];X(i,di,Q(i,a),()=>{var c,h;return(h=(c=a==null?void 0:a.afterIdentify)==null?void 0:c.call(a,e,o,n))!=null?h:{}},{})}}function js(i,t,e){for(let s=t.length-1;s>=0;s-=1){let n=t[s];X(i,Ms,Q(i,n),()=>{var r;return(r=n==null?void 0:n.afterTrack)==null?void 0:r.call(n,e)},void 0)}}var ke=class{constructor(t,e){this.t=t,this.P=[],this.P.push(...e)}withEvaluation(t,e,s,n){if(this.P.length===0)return n();let r=[...this.P],a={flagKey:t,context:e,defaultValue:s},o=Rs(this.t,r,a),c=n();return Us(this.t,r,a,o,c),c}identify(t,e){let s=[...this.P],n={context:t,timeout:e},r=Fs(this.t,s,n);return a=>{Hs(this.t,s,n,r,a)}}addHook(t){this.P.push(t)}afterTrack(t){if(this.P.length===0)return;let e=[...this.P];js(this.t,e,t)}};function Bs(i){return{getMetadata(){return{name:"LaunchDarkly-Inspector-Adapter"}},afterEvaluation:(t,e,s)=>(i.onFlagUsed(t.flagKey,s,t.context),e),afterIdentify(t,e,s){return i.onIdentityChanged(t.context),e}}}function Vs(i,t){return`an inspector: "${t}" of an invalid type (${i}) was configured`}function _s(i,t){return`an inspector: "${t}" of type: "${i}" generated an exception`}function Gs(i,t){let e=!1,s={method:(...n)=>{try{i.method(...n)}catch(r){e||(e=!0,t.warn(_s(s.type,s.name)))}},type:i.type,name:i.name,synchronous:i.synchronous};return s}var fi="flag-used",pi="flag-details-changed",gi="flag-detail-changed",mi="client-identity-changed",Ks=[fi,pi,gi,mi];function zs(i,t){let e=Ks.includes(i.type)&&i.method&&typeof i.method=="function";return e||t.warn(Vs(i.type,i.name)),e}var De=class{constructor(t,e){this.G=[];let s=t.filter(n=>zs(n,e));this.G=s.map(n=>Gs(n,e))}hasInspectors(){return this.G.length!==0}onFlagUsed(t,e,s){this.G.forEach(n=>{n.type===fi&&n.method(t,e,s)})}onFlagsChanged(t){this.G.forEach(e=>{e.type===pi&&e.method(t)})}onFlagChanged(t,e){this.G.forEach(s=>{s.type===gi&&s.method(t,e)})}onIdentityChanged(t){this.G.forEach(e=>{e.type===mi&&e.method(t)})}},xe=class{constructor(t){this.t=t,this.n=new Map}on(t,e){var s;this.n.has(t)?(s=this.n.get(t))==null||s.push(e):this.n.set(t,[e])}off(t,e){let s=this.n.get(t);if(s){if(e){let n=s.filter(r=>r!==e);n.length===0?this.n.delete(t):this.n.set(t,n);return}this.n.delete(t)}}$i(t,e,...s){var n;try{t(...s)}catch(r){(n=this.t)==null||n.error(`Encountered error invoking handler for "${e}", detail: "${r}"`)}}emit(t,...e){let s=this.n.get(t);s==null||s.forEach(n=>this.$i(n,t,...e))}eventNames(){return[...this.n.keys()]}listenerCount(t){var e,s;return(s=(e=this.n.get(t))==null?void 0:e.length)!=null?s:0}};function Js(i,t,e){let s=t.info.sdkData(),n;e.applicationInfo&&(e.applicationInfo.id&&(n=n!=null?n:{},n.id=e.applicationInfo.id),e.applicationInfo.version&&(n=n!=null?n:{},n.version=e.applicationInfo.version),e.applicationInfo.name&&(n=n!=null?n:{},n.name=e.applicationInfo.name),e.applicationInfo.versionName&&(n=n!=null?n:{},n.versionName=e.applicationInfo.versionName));let r={name:s.userAgentBase,version:s.version};s.wrapperName&&(r.wrapperName=s.wrapperName),s.wrapperVersion&&(r.wrapperVersion=s.wrapperVersion);let a={sdk:r,[e.credentialType]:i};return n&&(a.application=n),a}var{ClientMessages:pe,ErrorKinds:ge}=x,qs=5,$t=class{constructor(t,e,s,n,r,a){if(this.sdkKey=t,this.autoEnvAttributes=e,this.platform=s,this.Ft=15,this.C=new Ot(!1),this.pt=new Ot(!0),this.Ht=!1,!t)throw new Error("You must configure the client with a client-side SDK key");if(!s.encoding)throw new Error("Platform must implement Encoding because btoa is required.");this.e=new ye(n,a),this.logger=this.e.logger,this.ke=Xe(this.sdkKey,this.platform.info,this.e.tags,this.e.serviceEndpoints.includeAuthorizationHeader,this.e.userAgentHeaderName),this.D=new be(this.platform,t,this.e.maxCachedContexts,this.e.logger),this.k=$s(t,this.e,s),this.y=Ns(t,this.e,s,this.ke,this.k),this.emitter=new xe,this.emitter.on("error",(c,h)=>{this.logger.error(`error: ${h}, context: ${JSON.stringify(c)}`)}),this.D.on((c,h,u)=>{this.Ni(h,u);let d=D.toLDContext(c);this.emitter.emit("change",d,h),h.forEach(f=>{this.emitter.emit(`change:${f}`,d)})}),this.dataManager=r(this.D,this.e,this.ke,this.emitter,this.k);let o=[...this.e.hooks];this.environmentMetadata=Js(this.sdkKey,this.platform,this.e),this.e.getImplementationHooks(this.environmentMetadata).forEach(c=>{o.push(c)}),this.M=new ke(this.logger,o),this.et=new De(this.e.inspectors,this.logger),this.et.hasInspectors()&&this.M.addHook(Bs(this.et))}allFlags(){return Object.entries(this.D.getAll()).reduce((e,[s,n])=>(n.flag!==null&&n.flag!==void 0&&!n.flag.deleted&&(e[s]=n.flag.value),e),{})}async close(){var t;await this.flush(),(t=this.y)==null||t.close(),this.dataManager.close(),this.logger.debug("Closed event processor and data source.")}async flush(){var t;try{await((t=this.y)==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.v?le(this.v):void 0}getInternalContext(){return this.K}Pi(t,e){let s,n,r=new Promise((c,h)=>{s=c,n=h});if(e)return{identifyPromise:r,identifyResolve:s,identifyReject:n};let a=ti(t,"identify");return{identifyPromise:Promise.race([a,r]).catch(c=>{throw c.message.includes("timed out")&&this.logger.error(`identify error: ${c}`),c}),identifyResolve:s,identifyReject:n}}async identify(t,e){var d,f;let s=(d=e==null?void 0:e.timeout)!=null?d:qs,n=(e==null?void 0:e.timeout)===void 0&&(e==null?void 0:e.noTimeout)===!0;s>this.Ft&&this.logger.warn(`The identify function was called with a timeout greater than ${this.Ft} seconds. We recommend a timeout of less than ${this.Ft} seconds.`);let r=await Is(t,this.platform);this.autoEnvAttributes===H.Enabled&&(r=await Ds(r,this.platform,this.e));let a=D.fromLDContext(r);if(!a.valid){let g=new Error("Context was unspecified or had no key");return this.emitter.emit("error",r,g),Promise.reject(g)}this.v=r,this.K=a,(f=this.y)==null||f.sendEvent(this.C.identifyEvent(this.K));let{identifyPromise:o,identifyResolve:c,identifyReject:h}=this.Pi(s,n);this.logger.debug(`Identifying ${JSON.stringify(this.K)}`);let u=this.M.identify(r,e==null?void 0:e.timeout);return await this.dataManager.identify(c,h,a,e),o.then(g=>(u({status:"completed"}),g),g=>{throw u({status:"error"}),g})}on(t,e){this.emitter.on(t,e)}off(t,e){this.emitter.off(t,e)}track(t,e,s){var n,r;if(!this.K||!this.K.valid){this.logger.warn(pe.MissingContextKeyNoEvent);return}s!==void 0&&!l.Number.is(s)&&((n=this.logger)==null||n.warn(pe.invalidMetricValue(typeof s))),(r=this.y)==null||r.sendEvent(this.e.trackEventModifier(this.C.customEvent(t,this.K,e,s))),this.M.afterTrack({key:t,context:this.v,data:e,metricValue:s})}gt(t,e,s,n){var f,g,m;if(!this.v)return this.logger.debug(pe.MissingContextKeyNoEvent),fe(ge.UserNotSpecified,e);let r=D.fromLDContext(this.v),a=this.D.get(t);if(a===void 0||a.flag.deleted){let y=e!=null?e:null,L=new J(`Unknown feature flag "${t}"; returning default value ${y}.`);return this.emitter.emit("error",this.v,L),(f=this.y)==null||f.sendEvent(this.C.unknownFlagEvent(t,y,r)),fe(ge.FlagNotFound,e)}let{reason:o,value:c,variation:h,prerequisites:u}=a.flag;if(n){let[y,L]=n(c);if(!y){(g=this.y)==null||g.sendEvent(s.evalEventClient(t,e,e,a.flag,r,o));let R=new J(`Wrong type "${L}" for feature flag "${t}"; returning default value`);return this.emitter.emit("error",this.v,R),fe(ge.WrongType,e)}}let d=si(c,h,o);return c==null&&(this.logger.debug("Result value is null. Providing default value."),d.value=e),u==null||u.forEach(y=>{this.gt(y,void 0,this.C)}),(m=this.y)==null||m.sendEvent(s.evalEventClient(t,c,e,a.flag,r,o)),d}variation(t,e){let{value:s}=this.M.withEvaluation(t,this.v,e,()=>this.gt(t,e,this.C));return s}variationDetail(t,e){return this.M.withEvaluation(t,this.v,e,()=>this.gt(t,e,this.pt))}z(t,e,s,n){return this.M.withEvaluation(t,this.v,e,()=>this.gt(t,e,s,n))}boolVariation(t,e){return this.z(t,e,this.C,s=>[l.Boolean.is(s),l.Boolean.getType()]).value}jsonVariation(t,e){return this.variation(t,e)}numberVariation(t,e){return this.z(t,e,this.C,s=>[l.Number.is(s),l.Number.getType()]).value}stringVariation(t,e){return this.z(t,e,this.C,s=>[l.String.is(s),l.String.getType()]).value}boolVariationDetail(t,e){return this.z(t,e,this.pt,s=>[l.Boolean.is(s),l.Boolean.getType()])}numberVariationDetail(t,e){return this.z(t,e,this.pt,s=>[l.Number.is(s),l.Number.getType()])}stringVariationDetail(t,e){return this.z(t,e,this.pt,s=>[l.String.is(s),l.String.getType()])}jsonVariationDetail(t,e){return this.variationDetail(t,e)}addHook(t){this.M.addHook(t)}setEventSendingEnabled(t,e){var s,n,r,a;this.Ht!==t&&(this.Ht=t,t?(this.logger.debug("Starting event processor"),(s=this.y)==null||s.start()):e?((n=this.logger)==null||n.debug("Flushing event processor before disabling."),this.flush().then(()=>{var o,c;this.Ht||((o=this.logger)==null||o.debug("Stopping event processor."),(c=this.y)==null||c.close())})):((r=this.logger)==null||r.debug("Stopping event processor."),(a=this.y)==null||a.close()))}sendEvent(t){var e;(e=this.y)==null||e.sendEvent(t)}Ni(t,e){if(!this.et.hasInspectors())return;let s={};t.forEach(n=>{let r=this.D.get(n);if(r!=null&&r.flag&&!r.flag.deleted){let{reason:a,value:o,variation:c}=r.flag;s[n]=si(o,c,a)}else s[n]={value:void 0,reason:null,variationIndex:null}}),e==="init"?this.et.onFlagsChanged(s):e==="patch"&&Object.entries(s).forEach(([n,r])=>{this.et.onFlagChanged(n,r)})}},Se=class{constructor(t,e,s){this.D=t,this.jt=e,this.t=s}async handlePut(t,e){this.t.debug(`Got PUT: ${Object.keys(e)}`);let s=Object.entries(e).reduce((n,[r,a])=>(n[r]={version:a.version,flag:a},n),{});await this.D.init(t,s),this.jt.requestStateUpdate(E.Valid)}async handlePatch(t,e){this.t.debug(`Got PATCH ${JSON.stringify(e,null,2)}`),this.D.upsert(t,e.key,{version:e.version,flag:e})}async handleDelete(t,e){this.t.debug(`Got DELETE ${JSON.stringify(e,null,2)}`),this.D.upsert(t,e.key,{version:e.version,flag:b(p({},e),{deleted:!0,flagVersion:0,value:void 0,variation:0,trackEvents:!1})})}handleStreamingError(t){this.jt.reportError(t.kind,t.message,t.code,t.recoverable)}handlePollingError(t){this.jt.reportError(t.kind,t.message,t.status,t.recoverable)}},Le=class{constructor(t,e=()=>Date.now()){this.Mi=t,this.mt=E.Closed,this.De=e(),this.ft=e}get status(){return{state:this.mt,stateSince:this.De,lastError:this.Ri}}xe(t,e=!1){let s=t===E.Interrupted&&this.mt===E.Initializing?E.Initializing:t,n=this.mt!==s;n&&(this.mt=s,this.De=this.ft()),(n||e)&&this.Mi.emit("dataSourceStatus",this.status)}requestStateUpdate(t){this.xe(t)}reportError(t,e,s,n=!1){let r={kind:t,message:e,statusCode:s,time:this.ft()};this.Ri=r,this.xe(n?E.Interrupted:E.Closed,!0)}},Ae=class{constructor(t,e,s,n,r){this.Ui=t,this.Fi=e,this.Hi=s,this.l=n,this.t=r,this.R=!1}async Se(){var r,a,o,c,h,u,d;if(this.R)return;let t=f=>{var g,m,y;(g=this.t)==null||g.error("Polling received invalid data"),(m=this.t)==null||m.debug(`Invalid JSON follows: ${f}`),(y=this.l)==null||y.call(this,new N(w.InvalidData,"Malformed JSON data in polling response"))};(r=this.t)==null||r.debug("Polling LaunchDarkly for feature flag updates");let e=Date.now();try{let f=await this.Ui.requestPayload();try{let g=JSON.parse(f);try{(a=this.Hi)==null||a.call(this,g)}catch(m){(o=this.t)==null||o.error(`Exception from data handler: ${m}`)}}catch(g){t(f)}}catch(f){let g=f;if(g.status!==void 0&&!W(g.status)){(c=this.t)==null||c.error(B(f,"polling request")),(h=this.l)==null||h.call(this,new N(w.ErrorResponse,g.message,g.status));return}(u=this.t)==null||u.error(B(f,"polling request","will retry"))}let s=Date.now()-e,n=Math.max(this.Fi*1e3-s,0);(d=this.t)==null||d.debug("Elapsed: %d ms, sleeping for %d ms",s,n),this.Bt=setTimeout(()=>{this.Se()},n)}start(){this.Se()}stop(){this.Bt&&(clearTimeout(this.Bt),this.Bt=void 0),this.R=!0}close(){this.stop()}},Ws=(i,t,e,s)=>{e==null||e.error(`Stream received invalid data in "${i}" message`),e==null||e.debug(`Invalid JSON follows: ${t}`),s==null||s(new F(w.InvalidData,"Malformed JSON data in event stream"))},Te=class{constructor(t,e,s,n,r,a,o,c,h){var f;this.ji=t,this.Vt=e,this.n=s,this.A=n,this.Bi=a,this.k=o,this.l=c,this.t=h;let u;e.useReport&&!n.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.Vt.withReasons&&d.push({key:"withReasons",value:"true"}),this.A=n,this.dt=p({},e.baseHeaders),this.t=h,this.Vi=Ye(e.serviceEndpoints,u,d)}Le(){this.yt=Date.now()}_t(t){this.yt&&this.k&&this.k.recordStreamInit(this.yt,!t,Date.now()-this.yt),this.yt=void 0}_i(t){var e,s,n;return Qe(t)?((n=this.t)==null||n.warn(B(t,"streaming request","will retry")),this._t(!1),this.Le(),!0):(this._t(!1),(e=this.l)==null||e.call(this,new F(w.ErrorResponse,t.message,t.status,!1)),(s=this.t)==null||s.error(B(t,"streaming request")),!1)}start(){this.Le();let t;this.Vt.useReport?(this.dt["content-type"]="application/json",t={method:"REPORT",body:this.ji}):t={};let e=this.A.createEventSource(this.Vi,b(p({headers:this.dt},t),{errorFilter:s=>this._i(s),initialRetryDelayMillis:this.Vt.initialRetryDelayMillis,readTimeoutMillis:5*60*1e3,retryResetIntervalMillis:60*1e3}));this.Ae=e,e.onclose=()=>{var s;(s=this.t)==null||s.info("Closed LaunchDarkly stream connection")},e.onerror=()=>{},e.onopen=()=>{var s;(s=this.t)==null||s.info("Opened LaunchDarkly stream connection")},e.onretrying=s=>{var n;(n=this.t)==null||n.info(`Will retry stream connection in ${s.delayMillis} milliseconds`)},this.n.forEach(({deserializeData:s,processJson:n},r)=>{e.addEventListener(r,a=>{var o,c;if((o=this.t)==null||o.debug(`Received ${r} event`),a!=null&&a.data){this._t(!0);let{data:h}=a,u=s(h);if(!u){Ws(r,h,this.t,this.l);return}n(u)}else(c=this.l)==null||c.call(this,new F(w.InvalidData,"Unexpected payload from event stream"))})}),e.addEventListener("ping",async()=>{var s,n,r,a,o,c,h;(s=this.t)==null||s.debug("Got PING, going to poll LaunchDarkly for feature flag updates");try{let u=await this.Bi.requestPayload();try{let d=JSON.parse(u);try{(n=this.n.get("put"))==null||n.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.l)==null||c.call(this,new N(w.InvalidData,"Malformed JSON data in ping polling response"))}}catch(u){let d=u;(h=this.l)==null||h.call(this,new N(w.ErrorResponse,d.message,d.status))}})}stop(){var t;(t=this.Ae)==null||t.close(),this.Ae=void 0}close(){this.stop()}},Nt=class{constructor(t,e,s,n,r,a,o,c,h){this.platform=t,this.flagManager=e,this.credential=s,this.config=n,this.getPollingPaths=r,this.getStreamingPaths=a,this.baseHeaders=o,this.emitter=c,this.diagnosticsManager=h,this.closed=!1,this.logger=n.logger,this.dataSourceStatusManager=new Le(c),this.J=new Se(e,this.dataSourceStatusManager,this.config.logger)}setConnectionParams(t){this.Gi=t}createPollingProcessor(t,e,s,n,r){let a=new Ae(s,this.config.pollInterval,async o=>{await this.J.handlePut(e,o),n==null||n()},o=>{this.emitter.emit("error",t,o),this.J.handlePollingError(o),r==null||r(o)},this.logger);this.updateProcessor=this.Te(a,this.dataSourceStatusManager)}createStreamingProcessor(t,e,s,n,r){var o;let a=new Te(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.Gi)==null?void 0:o.queryParameters},this.createStreamListeners(e,n),this.platform.requests,this.platform.encoding,s,this.diagnosticsManager,c=>{this.emitter.emit("error",t,c),this.J.handleStreamingError(c),r==null||r(c)},this.logger);this.updateProcessor=this.Te(a,this.dataSourceStatusManager)}createStreamListeners(t,e){let s=new Map;return s.set("put",{deserializeData:JSON.parse,processJson:async n=>{await this.J.handlePut(t,n),e==null||e()}}),s.set("patch",{deserializeData:JSON.parse,processJson:async n=>{this.J.handlePatch(t,n)}}),s.set("delete",{deserializeData:JSON.parse,processJson:async n=>{this.J.handleDelete(t,n)}}),s}Te(t,e){return{start:()=>{e.requestStateUpdate(E.Initializing),t.start()},stop:()=>{t.stop(),e.requestStateUpdate(E.Closed)},close:()=>{t.close(),e.requestStateUpdate(E.Closed)}}}close(){var t;(t=this.updateProcessor)==null||t.close(),this.closed=!0}};function Pt(){return typeof document!==void 0}function Oe(){return typeof window!==void 0}function Mt(i,t,e){return Pt()?(document.addEventListener(i,t,e),()=>{document.removeEventListener(i,t,e)}):()=>{}}function Rt(i,t,e){return Pt()?(window.addEventListener(i,t,e),()=>{window.removeEventListener(i,t,e)}):()=>{}}function A(){return Oe()?window.location.href:""}function yi(){return Oe()?window.location.search:""}function vi(){return Oe()?window.location.hash:""}function wi(){if(typeof crypto!==void 0)return crypto;throw Error("Access to a web crypto API is required")}function Ei(){return Pt()?document.visibilityState:"visibile"}function bi(i){if(Pt())return document.querySelectorAll(i)}function ki(i,t){let e=Object.keys(t),s="$flagsState",n="$valid",r=t[s];!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[n]===!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!==s&&o!==n){let c;r&&r[o]?c=p({value:t[o]},r[o]):c={value:t[o],version:0},a[o]={version:c.version,flag:c}}}),a}var Ys="[BrowserDataManager]",tt=class extends Nt{constructor(e,s,n,r,a,o,c,h,u,d){super(e,s,n,r,o,c,h,u,d);this.ss=a;this.it=void 0;this.Gt=!1;this.it=a.streaming}I(e,...s){this.logger.debug(`${Ys} ${e}`,...s)}async identify(e,s,n,r){if(this.closed){this.I("Identify called after data manager was closed.");return}this.context=n;let a=r;a!=null&&a.hash?this.setConnectionParams({queryParameters:[{key:"h",value:a.hash}]}):this.setConnectionParams(),this.Kt=a==null?void 0:a.hash,a!=null&&a.bootstrap?this.Ki(n,a.bootstrap,e):(await this.flagManager.loadCached(n)&&this.I("Identify - Flags loaded from cache. Continuing to initialize via a poll."),await this.zi(n,e,s)),this.zt()}async zi(e,s,n){var r,a;try{this.dataSourceStatusManager.requestStateUpdate(E.Initializing);let o=JSON.stringify(D.toLDContext(e)),h=await Ce(o,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.Kt).requestPayload();try{let d=this.createStreamListeners(e,s).get("put");d.processJson(d.deserializeData(h))}catch(u){this.dataSourceStatusManager.reportError(w.InvalidData,(r=u.message)!=null?r:"Could not parse poll response")}}catch(o){this.dataSourceStatusManager.reportError(w.NetworkError,(a=o.message)!=null?a:"unexpected network error",o.status),n(o)}}Ki(e,s,n){this.flagManager.setBootstrap(e,ki(this.logger,s)),this.I("Identify - Initialization completed from bootstrap"),n()}setForcedStreaming(e){this.it=e,this.zt()}setAutomaticStreamingState(e){this.Gt=e,this.zt()}zt(){let e=this.it||this.Gt&&this.it===void 0;this.I(`Updating streaming state. forced(${this.it}) automatic(${this.Gt})`),e?this.Ji():this.qi()}qi(){var e;this.updateProcessor&&this.I("Stopping update processor."),(e=this.updateProcessor)==null||e.close(),this.updateProcessor=void 0}Ji(){if(this.updateProcessor){this.I("Update processor already active. Not changing state.");return}if(!this.context){this.I("Context not set, not starting update processor.");return}this.I("Starting update processor."),this.Wi(this.context)}Wi(e,s,n){var c;let r=D.toLDContext(e);(c=this.updateProcessor)==null||c.close();let a=JSON.stringify(D.toLDContext(e)),o=Ce(a,this.config.serviceEndpoints,this.getPollingPaths(),this.platform.requests,this.platform.encoding,this.baseHeaders,[],this.config.withReasons,this.config.useReport,this.Kt);this.createStreamingProcessor(r,e,o,s,n),this.updateProcessor.start()}};function Di(i){let e=Mt("visibilitychange",()=>{Ei()==="hidden"&&i()}),s=Rt("pagehide",i);return()=>{e(),s()}}function et(i){if(typeof i!="string")throw new TypeError("Expected a string");return i.replace(/[|\\{}()[\]^$+*?.]/g,"\\$&").replace(/-/g,"\\x2d")}function Zs(i,t,e,s){let r=((i.kind==="substring"||i.kind==="regex")&&s.includes("/")?t:t.replace(s,"")).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 Xs(i,t){let e=[];return t.forEach(s=>{let n=i.target,{selector:r}=s,a=bi(r);for(;n&&(a!=null&&a.length);){for(let o=0;o<a.length;o+=1)if(n===a[o]){e.push(s);break}n=n.parentNode}}),e}var it=class{constructor(t,e){let s=t.filter(a=>{var o;return(o=a.urls)==null?void 0:o.some(c=>Zs(c,A(),yi(),vi()))}),n=s.filter(a=>a.kind==="pageview"),r=s.filter(a=>a.kind==="click");if(n.forEach(a=>e(a)),r.length){let a=o=>{Xs(o,r).forEach(c=>{e(c)})};this.Ce=Mt("click",a)}}close(){var t;(t=this.Ce)==null||t.call(this)}};var Qs=300,Ut=class{constructor(t){this.Jt=A();let e=()=>{let n=A();n!==this.Jt&&(this.Jt=n,t())};this.qt=setInterval(e,Qs);let s=Rt("popstate",e);this.Ie=()=>{s()}}close(){var t;this.qt&&clearInterval(this.qt),(t=this.Ie)==null||t.call(this)}};var st=class{constructor(t,e,s,n,r,a=o=>new Ut(o)){this.A=e;this.Xi=n;this.Zi=r;this.vt=[];this.$e=!1;this.wt=`${s}/sdk/goals/${t}`,this.Oe=a(()=>{this.Yt()})}async initialize(){await this.Yi(),this.Yt()}startTracking(){this.$e=!0,this.Yt()}Yt(){var t;this.$e&&((t=this.Wt)==null||t.close(),this.vt&&this.vt.length&&(this.Wt=new it(this.vt,e=>{this.Zi(A(),e)})))}async Yi(){try{let t=await this.A.fetch(this.wt);this.vt=await t.json()}catch(t){this.Xi(new z(`Encountered error fetching goals: ${t}`))}}close(){var t,e;(t=this.Oe)==null||t.close(),(e=this.Wt)==null||e.close()}};function xi(i){return i.kind==="click"}var tn=2,Si={fetchGoals:!0,eventUrlTransformer:i=>i,streaming:void 0,plugins:[]},en={fetchGoals:l.Boolean,eventUrlTransformer:l.Function,streaming:l.Boolean,plugins:l.createTypeArray("LDPlugin",{})};function sn(i){var e;let t=p({},i);return(e=t.flushInterval)!=null||(t.flushInterval=tn),t}function Li(i){let t=sn(i);return Object.keys(Si).forEach(e=>{delete t[e]}),t}function $e(i,t){let e=p({},Si);return Object.entries(en).forEach(s=>{let[n,r]=s,a=i[n];a!==void 0&&(r.is(a)?e[n]=a:t.warn(k.wrongOptionType(n,r.getType(),typeof a)))}),e}var nt=class{constructor(t,e){this.Qi=t;this.Ne=[];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.Ne.join(""),s=new TextEncoder().encode(e),n=await this.Qi.subtle.digest(this.Zt,s);switch(t){case"base64":return btoa(String.fromCharCode(...new Uint8Array(n)));case"hex":return[...new Uint8Array(n)].map(r=>r.toString(16).padStart(2,"0")).join("");default:throw new Error(`Encoding is not supported ${t}`)}}update(t){return this.Ne.push(t),this}};var nn={start:0,end:3},rn={start:4,end:5},Ne={start:6,end:7},Pe={start:8,end:8},an={start:9,end:9},on={start:10,end:15};function cn(){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 V(i,t){let e="";for(let s=t.start;s<=t.end;s+=1)e+=i[s].toString(16).padStart(2,"0");return e}function hn(i){return i[Pe.start]=(i[Pe.start]|128)&191,i[Ne.start]=i[Ne.start]&15|64,`${V(i,nn)}-${V(i,rn)}-${V(i,Ne)}-${V(i,Pe)}${V(i,an)}-${V(i,on)}`}function ln(){let i=cn();return hn(i)}function Me(){return typeof crypto!==void 0&&typeof crypto.randomUUID=="function"?crypto.randomUUID():ln()}var rt=class{createHash(t){return new nt(wi(),t)}randomUUID(){return Me()}};function un(i){let t=Array.from(i,e=>String.fromCodePoint(e)).join("");return btoa(t)}var at=class{btoa(t){return un(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:"0.0.0",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.wt=t;this.n={};this.S=new vt(e.initialRetryDelayMillis,e.retryResetIntervalMillis),this.Pe=e.errorFilter,this.Me()}Me(){this.q=new EventSource(this.wt),this.q.onopen=()=>{var t;this.S.success(),(t=this.onopen)==null||t.call(this)},this.q.onerror=t=>{var e;this.ts(t),(e=this.onerror)==null||e.call(this,t)},Object.entries(this.n).forEach(([t,e])=>{e.forEach(s=>{var n;(n=this.q)==null||n.addEventListener(t,s)})})}addEventListener(t,e){var s,n,r;(n=(s=this.n)[t])!=null||(s[t]=[]),this.n[t].push(e),(r=this.q)==null||r.addEventListener(t,e)}close(){var t,e;clearTimeout(this.Xt),this.Xt=void 0,(t=this.q)==null||t.close(),(e=this.onclose)==null||e.call(this)}es(t){var e;(e=this.onretrying)==null||e.call(this,{delayMillis:t}),this.Xt=setTimeout(()=>{this.Me()},t)}ts(t){this.close(),!(t.status&&typeof t.status=="number"&&!this.Pe(t))&&this.es(this.S.fail())}};var ht=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 Ai(){return typeof localStorage!="undefined"}var lt=class{constructor(t){this.t=t}async clear(t){var e;try{localStorage.removeItem(t)}catch(s){(e=this.t)==null||e.error(`Error clearing key from localStorage: ${t}, reason: ${s}`)}}async get(t){var e;try{let s=localStorage.getItem(t);return s!=null?s:null}catch(s){return(e=this.t)==null||e.error(`Error getting key from localStorage: ${t}, reason: ${s}`),null}}async set(t,e){var s;try{localStorage.setItem(t,e)}catch(n){(s=this.t)==null||s.error(`Error setting key in localStorage: ${t}, reason: ${n}`)}}};var ut=class{constructor(t,e){this.encoding=new at;this.crypto=new rt;this.requests=new ht;Ai()&&(this.storage=new lt(t)),this.info=new ot(e)}};var Ft=class extends $t{constructor(t,e,s={},n){var g;let{logger:r,debug:a}=s,o=r!=null?r:new P({destination:{debug:console.debug,info:console.info,warn:console.warn,error:console.error},level:a?"debug":"info"}),c=(g=s.baseUri)!=null?g:"https://clientsdk.launchdarkly.com",h=n!=null?n:new ut(o,s),u=$e(s,o),d=Li(b(p({},s),{logger:o})),{eventUrlTransformer:f}=u;super(t,e,h,d,(m,y,L,R,Ti)=>new tt(h,m,t,y,u,()=>({pathGet(I,O){return`/sdk/evalx/${t}/contexts/${ue(O,I)}`},pathReport(I,O){return`/sdk/evalx/${t}/context`},pathPing(I,O){throw new Error("Ping for polling unsupported.")}}),()=>({pathGet(I,O){return`/eval/${t}/${ue(O,I)}`},pathReport(I,O){return`/eval/${t}`},pathPing(I,O){return`/ping/${t}`}}),L,R,Ti),{analyticsEventPath:`/events/bulk/${t}`,diagnosticEventPath:`/events/diagnostic/${t}`,includeAuthorizationHeader:!1,highTimeoutThreshold:5,userAgentHeaderName:"x-launchdarkly-user-agent",trackEventModifier:m=>new x.InputCustomEvent(m.context,m.key,m.data,m.metricValue,m.samplingRatio,f(A())),getImplementationHooks:m=>x.safeGetHooks(o,m,u.plugins),credentialType:"clientSideId"}),this.setEventSendingEnabled(!0,!1),u.fetchGoals&&(this.Qt=new st(t,h.requests,c,m=>{o.error(m.message)},(m,y)=>{let L=this.getInternalContext();if(!L)return;let R=f(m);xi(y)?this.sendEvent({kind:"click",url:R,samplingRatio:1,key:y.key,creationDate:Date.now(),context:L,selector:y.selector}):this.sendEvent({kind:"pageview",url:R,samplingRatio:1,key:y.key,creationDate:Date.now(),context:L})}),this.Qt.initialize(),u.automaticBackgroundHandling&&Di(()=>this.flush())),x.safeRegisterPlugins(o,this.environmentMetadata,this,u.plugins)}async identify(t,e){var s;await super.identify(t,e),(s=this.Qt)==null||s.startTracking()}setStreaming(t){this.dataManager.setForcedStreaming(t)}Re(){this.dataManager.setAutomaticStreamingState(!!this.emitter.listenerCount("change"))}on(t,e){super.on(t,e),this.Re()}off(t,e){super.off(t,e),this.Re()}};function Zr(i){return new P(i)}function ea(i,t){return new Ft(i,H.Disabled,t)}export{Zr as basicLogger,ea as initialize};
2
2
  //# sourceMappingURL=index.js.map