@configdirector/client-sdk 0.1.5 → 0.1.6

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.
@@ -0,0 +1,2 @@
1
+ import{createEventSource as e}from"eventsource-client";var t=class{constructor(){this.handlerMap=new Map}on(e,t){let n=this.handlerMap.get(e);n?n.push(t):this.handlerMap.set(e,[t])}once(e,t){let n=this;function r(i){n.off(e,r),t.apply(n,i)}this.on(e,r)}off(e,t){let n=this.handlerMap.get(e);if(n)if(t){let e=n.indexOf(t);e>=0&&n.splice(e,1)}else this.handlerMap.set(e,[])}clear(){this.handlerMap.clear()}emit(e,t){let n=this.handlerMap.get(e);n&&n.slice().map(e=>e(t))}},n=class e extends Error{constructor(t,n){super(t),this.name=`ConfigDirectorConnectionError`,this.status=n,Object.setPrototypeOf(this,e.prototype)}},r=class e extends Error{constructor(t){super(t),this.name=`ConfigDirectorValidationError`,Object.setPrototypeOf(this,e.prototype)}};const i=e=>{if(e instanceof DOMException){if(e.name===`NotAllowedError`)return!0}else if(e instanceof TypeError)return!0;return!1};var a=class{constructor(e){this.options=e,this.eventEmitter=new t,this.options=e,this.logger=e.logger,this.url=new URL(`sse/v1`,e.baseUrl)}async connect(t,n){this.eventSource&&this.close();let r,i,a=async(e,t)=>{let n=await fetch(e,t);return r=n.status,n.ok||(i=await n.text()),n},o=new Promise((n,o)=>{this.eventSource=e({url:this.url,fetch:a,method:`POST`,headers:{"Content-Type":`application/json`},body:JSON.stringify({givenContext:t,metaContext:this.options.metaContext,clientSdkKey:this.options.clientSdkKey}),onMessage:({data:e})=>{this.dispatchMessage(e)},onConnect:()=>{r&&this.isStatusFatal(r)?(this.close(),o(this.prepareFatalError(r,i))):(this.logger.debug(`[EventSourceTransport] Connected, status: %s`,r),n(this))},onScheduleReconnect:e=>{r&&this.isStatusFatal(r)?(this.close(),o(this.prepareFatalError(r,i))):this.logger.warn(`[EventSourceTransport] Scheduling reconnect in ${e.delay}. Response status: ${r}`)},onDisconnect:()=>{this.logger.debug(`[EventSourceTransport] Disconnected`)}})});return Promise.race([o,new Promise(e=>{setTimeout(()=>e(this),n)})])}dispatchMessage(e){try{let t=JSON.parse(e);this.eventEmitter.emit(`configSetReceived`,t)}catch(e){this.logger.error(`[EventSourceTransport] Error parsing and dispatching config data update: `,e)}}prepareFatalError(e,t){let r=e??0;return new n(`${`Connection failed with status: ${e??`unknown`}`}${(t?.trim()?.length??0)>0?` (${t})`:``}. This is an unrecoverable error, will not attempt to reconnect.`,r)}isStatusFatal(e){return!!e&&e>=400&&e<500}on(e,t){this.eventEmitter.on(e,t)}off(e,t){this.eventEmitter.off(e,t)}clear(){this.eventEmitter.clear()}close(){this.eventSource?.close()}dispose(){this.close(),this.clear()}};const o=e=>{let t=typeof e;if(t===`object`)try{return e.constructor?.name??t}catch{return t}else if(t===`function`)try{let n=e.name;return n?`function: ${n}`:t}catch{return t}return t},s=e=>e===`number`||e===`bigint`,c=(e,t)=>{let n=e.value,r=o(t);if(!n)return{parsedValue:t,requestedType:r,usedDefault:!0,reason:`value-missing`};if(typeof t==`string`)return{parsedValue:n,requestedType:r,usedDefault:!1,reason:`found-match`};if(typeof t==`boolean`&&e.type===`boolean`){let e=l(n),i=typeof e==`boolean`;return{parsedValue:i?e:t,requestedType:r,usedDefault:!i,reason:i?`found-match`:`invalid-boolean`}}if(s(typeof t)&&e.type===`integer`){let e=u(n),i=typeof e==`number`;return{parsedValue:i?e:t,requestedType:r,usedDefault:!i,reason:i?`found-match`:`invalid-number`}}if(s(typeof t)&&(e.type===`float`||e.type===`enum`)){let e=d(n),i=typeof e==`number`;return{parsedValue:i?e:t,requestedType:r,usedDefault:!i,reason:i?`found-match`:`invalid-number`}}return{parsedValue:n,requestedType:r,usedDefault:!1,reason:`found-match`}},l=e=>{if(!e)return;let t=e.toLowerCase();if(!(t!=`true`&&t!=`false`))return t===`true`},u=e=>{if(!e)return;let t=Number.parseInt(e);if(!(isNaN(t)||!isFinite(t)))return t},d=e=>{if(!e)return;let t=Number.parseFloat(e);if(!(isNaN(t)||!isFinite(t)))return t},f={off:-1,error:0,warn:1,info:2,debug:3},p=()=>{let e={year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,timeZoneName:`short`};try{return new Intl.DateTimeFormat(void 0,{...e,fractionalSecondDigits:3})}catch{return new Intl.DateTimeFormat(void 0,e)}};var m=class{constructor(e,t){this.level=e,this.decorator=t,this.level=e,this.decorator=t,this.dateFormatter=p()}debug(e,...t){this.log(console.debug,`debug`,e,...t)}info(e,...t){this.log(console.info,`info`,e,...t)}warn(e,...t){this.log(console.warn,`warn`,e,...t)}error(e,...t){this.log(console.error,`error`,e,...t)}log(e,t,n,...r){f[this.level]>=f[t]&&e(`[${this.dateFormatter.format(new Date)}] ${this.decorator?.decorateMessage(n)}`,...r)}},h=class{decorateMessage(e){return`[ConfigDirector:js-client-sdk] ${e}`}};const g=(e,t)=>new m(e??`warn`,t??new h);var _=class{aggregate(e){if(e.events.length==0)return[];let t=new Map;for(let n of e.events){let e=JSON.stringify(n),r=t.get(e)?.count||0;t.set(e,{event:n,count:r+1})}return Array.from(t).map(([,t])=>({startTime:e.startTime,endTime:e.endTime,count:t.count,event:t.event}))}},v=class{constructor(e){this._events=[],this._droppedEventCount=0,this.limit=e??1e3}get events(){return this._events}get reachedLimit(){return this._events.length>=this.limit}get droppedEventCount(){return this._droppedEventCount}push(...e){this.startTime||=new Date;let t=Math.max(0,e.length-this.limit),n=e.slice(t,e.length);if(this._droppedEventCount+=t,this._events.length+n.length>this.limit){let e=this._events.length+n.length-this.limit;this._events.splice(0,e),this._droppedEventCount+=e}return this._events.push(...n)}takeSnapshot(){let e=new Date,t=this.startTime??e,n=this._events.splice(0),r=this._droppedEventCount;return this.startTime=void 0,this._droppedEventCount=0,{startTime:t,endTime:e,events:n,droppedCount:r}}clear(){this._events=[],this.startTime=void 0,this._droppedEventCount=0}},y=class{constructor(e){this.executeRequests=!0,this.sdkKey=e.sdkKey,this.logger=e.logger,this.url=new URL(`telemetry/v1`,e.baseUrl)}report({discreteEvents:e,aggregatedEvents:t,droppedEvents:n}){if(!this.executeRequests)return{success:!1,fatalError:!0};let r={clientSdkKey:this.sdkKey,discreteEvents:e,aggregatedEvents:t,droppedEvents:n};if(this.isReportEmpty(r))return{success:!0,fatalError:!1};let i=this.sendReport(r);return i.fatalError&&(this.executeRequests=!1),i}isReportEmpty(e){return this.isEventListEmpty(e.discreteEvents)&&this.isEventListEmpty(e.aggregatedEvents)&&this.isDroppedEventsEmpty(e.droppedEvents)}isDroppedEventsEmpty(e){if(!e)return!0;let t=Object.keys(e);if(t.length==0)return!0;for(let n of t)if((e[n]??0)>0)return!1;return!0}isEventListEmpty(e){let t=Object.keys(e);if(t.length==0)return!0;for(let n of t)if((e[n]?.length??0)>0)return!1;return!0}sendReport(e){try{return{success:navigator.sendBeacon(this.url,JSON.stringify(e)),fatalError:!1}}catch(e){return this.logger.warn(`[EventReporter] Fatal error attempting to send telemetry data: ${e}. No more telemetry data will be sent.`),{success:!1,fatalError:!0}}}};const b=e=>x(new TextEncoder().encode(e)).toString(16).padStart(8,`0`),x=e=>{let t=5381;for(let n=0;n<e.length;n++)t=(t<<5)+t+e[n],t>>>=0;return t};var S=class{constructor(e){this.evaluationEventQueue=new v,this.aggregator=new _,this.collectEvents=!0,this.logger=e.logger,this.reporter=new y(e),this.flushIntervalDelay=3e4,this.flushTimeout=setTimeout(()=>this.flushAndScheduleNext(),5e3);try{document.addEventListener(`visibilitychange`,()=>{document.visibilityState===`hidden`&&this.flush()})}catch(e){this.logger.warn(`[TelemetryEventCollector] Could not configure 'visibilitychange' listener: `,e)}}evaluatedConfig(e){this.collectEvents&&this.evaluationEventQueue.push(this.sanitizeEvaluatedConfigEvent(e))}sanitizeEvaluatedConfigEvent(e){return{key:e.key,type:e.type,defaultValue:this.sanitizeValue(e.defaultValue,e.type),requestedType:e.requestedType,evaluatedValue:this.sanitizeValue(e.evaluatedValue,e.type),usedDefault:e.usedDefault,evaluationReason:e.evaluationReason}}sanitizeValue(e,t){if(t===`json`)try{return b(JSON.stringify(e))}catch{return e.toString().slice(0,500)}return e.toString().slice(0,500)}flushAndScheduleNext(){this.flush().fatalError?(this.collectEvents=!1,this.close(),this.logger.warn(`[TelemetryEventCollector] Received a fatal error from telemetry collection. No longer collecting events.`)):this.flushTimeout=setTimeout(()=>this.flushAndScheduleNext(),this.flushIntervalDelay)}flush(){let e=this.evaluationEventQueue.takeSnapshot();return this.reporter.report({discreteEvents:{},aggregatedEvents:{evaluatedConfig:this.aggregator.aggregate(e)},droppedEvents:{evaluatedConfig:e.droppedCount}})}close(){this.collectEvents=!1,clearTimeout(this.flushTimeout),this.flush(),this.evaluationEventQueue.clear()}dispose(){this.close()}};const C=async(e,t,n,r)=>{let i=new AbortController,a=setTimeout(()=>{r.debug(`[fetchWithTimeout] Reached timeout, aborting request`),i.abort()},e);try{let e=await fetch(t,{...n,signal:i.signal});return clearTimeout(a),e}catch(e){throw r.warn(`[fetchWithTimeout] Fetch error: `,e),clearTimeout(a),e}};var w=class{constructor(e){this.options=e,this.eventEmitter=new t,this.fatalError=!1,this.options=e,this.logger=e.logger,this.url=new URL(`pull/v1`,e.baseUrl)}async connect(e,t){if(this.fatalError)return this.logger.warn(`[PullTransport] There was a prior unrecoverable error. Ignoring attempt to reconnect.`),this;try{let r=await C(t,this.url,{method:`POST`,headers:{"Content-Type":`application/json`},body:JSON.stringify({givenContext:e,metaContext:this.options.metaContext,clientSdkKey:this.options.clientSdkKey})},this.logger);if(!r.ok)throw this.isStatusFatal(r.status)?(this.fatalError=!0,this.prepareFatalResponseStatusError(r.status,await r.text())):new n(`Connection failed with status: ${r.status}`,r.status);let i=JSON.parse(await r.text());return this.eventEmitter.emit(`configSetReceived`,i),this}catch(e){throw i(e)?(this.fatalError=!0,new n(`Connection failed with fatal error: ${e}. This is an unrecoverable error, retry attempts will be ignored.`)):e instanceof SyntaxError?new n(`Failed to parse the response from the server: ${e}`):new n(`Connection failed with error: ${e}.`)}}prepareFatalResponseStatusError(e,t){let r=e??0;return new n(`${`Connection failed with status: ${e??`unknown`}`}${(t?.trim()?.length??0)>0?` (${t})`:``}. This is an unrecoverable error, retry attempts will be ignored.`,r)}isStatusFatal(e){return!!e&&e>=400&&e<500}on(e,t){this.eventEmitter.on(e,t)}off(e,t){this.eventEmitter.off(e,t)}clear(){this.eventEmitter.clear()}close(){}dispose(){this.close(),this.clear()}};const T=new URL(`https://client-sdk-api.configdirector.com`);var E=class{constructor(e,n,r){this.handlersMap=new Map,this.eventEmitter=new t,this.ready=!1,this.logger=r?.logger??g(),this.timeout=r?.connection?.timeout??3e3;let i=this.parseUrl(r?.connection?.url)??T;this.streaming=r?.connection?.streaming!==!1;let o=this.streaming?a:w;this.usageEventCollector=new S({sdkKey:e,logger:this.logger,baseUrl:i}),this.transport=new o({clientSdkKey:e,baseUrl:i,metaContext:{...r?.metadata,sdkName:n.sdkName,sdkVersion:n.sdkVersion,userAgent:navigator?.userAgent},logger:this.logger}),this.transport.on(`configSetReceived`,e=>{this.readyResolve?.();let t=Object.keys(e.configs);!this.configSet||e.kind==`full`?(this.configSet=e,this.eventEmitter.emit(`configsUpdated`,{keys:t}),this.updateWatchers(e.configs)):(this.configSet.configs={...this.configSet.configs,...e.configs},this.eventEmitter.emit(`configsUpdated`,{keys:t}),this.updateWatchers(e.configs)),this.logger.debug(`[ConfigDirectorClient] ConfigSet updated from server:`,{keys:t})})}async initialize(e){await this.connectToTransport(e,`initialization`)}async updateContext(e){await this.connectToTransport(e,`context update`)}async connectToTransport(e,t){try{this.ready=!1,this.readyPromise=new Promise(e=>{this.readyResolve=e}).then(()=>{this.ready=!0,this.eventEmitter.emit(`clientReady`,{action:t}),this.logger.debug(`[ConfigDirectorClient] Received initial payload from the server, client is ready`)});let n=new Date().getTime();await this.transport.connect(e??{},this.timeout),this.currentContext=e;let r=new Date().getTime()-n,i=this.timeout-r;if(i>0&&await Promise.race([this.readyPromise,new Promise(e=>{setTimeout(()=>e(),i)})]),!this.ready){let e=this.streaming?`The client will continue to retry since there were no fatal errors detected. Configs will return the default value until the connection succeeds.`:`Since the client was configured without streaming, configs may not update and always return the default value.`;this.logger.warn(`[ConfigDirectorClient] Timed out waiting for ${t} after ${this.timeout}ms. ${e}`)}}catch(e){this.logger.error(`[ConfigDirectorClient] An error occurred during ${t}: `,e)}}updateWatchers(e){Object.values(e).forEach(e=>this.updateWatchersForConfig(e))}updateWatchersForConfig(e){this.handlersMap.get(e.key)?.forEach(t=>{let n=this.getValueFromConfigState(e.key,e,t.defaultValue);t.handler(n)})}watch(e,t,n){this.validateDefaultValue(t);let r=this.handlersMap.get(e),i={handler:n,defaultValue:t,requestedType:typeof t};return r?r.push(i):this.handlersMap.set(e,[i]),()=>this.unwatch(e,n)}unwatch(e,t){let n=this.handlersMap.get(e);if(n)if(t){let e=n.findIndex(e=>e.handler==t);e>=0&&n?.splice(e,1)}else n.splice(0)}getValue(e,t){this.validateDefaultValue(t);let n=this.configSet?.configs[e];return this.getValueFromConfigState(e,n,t)}getValueFromConfigState(e,t,n){if(!t)return this.logger.debug(`[ConfigDirectorClient] No config state found for '${e}', returning default value '${n}'`),this.usageEventCollector.evaluatedConfig({contextId:this.currentContext?.id,key:e,defaultValue:n,requestedType:o(n),evaluatedValue:n,usedDefault:!0,evaluationReason:`config-state-missing`}),n;let r=c(t,n);return this.usageEventCollector.evaluatedConfig({contextId:this.currentContext?.id,key:e,defaultValue:n,requestedType:r.requestedType,evaluatedValue:r.parsedValue,usedDefault:r.usedDefault,evaluationReason:r.reason}),this.logger.debug(`[ConfigDirectorClient] Evaluated '${e}' to '${r.parsedValue}'`),r.parsedValue}parseUrl(e){if(e)try{return new URL(e)}catch(t){throw new r(`Invalid base URL '${e}'. Parsing failed: ${t}`)}}validateDefaultValue(e){if(e==null)throw new r(`Invalid default value. The default value for a config must be defined and non-null.`);if(typeof e==`function`)throw new r(`Invalid default value. The default value for a config cannot be a function.`)}get isReady(){return this.ready}on(e,t){this.eventEmitter.on(e,t)}off(e,t){this.eventEmitter.off(e,t)}clear(){this.logger.debug(`[ConfigDirectorClient] clear() has been called, removing all observers`),this.eventEmitter.clear(),this.handlersMap.clear()}unwatchAll(){this.handlersMap.clear()}close(){this.logger.debug(`[ConfigDirectorClient] close() has been called, closing connection to server`),this.transport.close(),this.ready=!1}dispose(){this.clear(),this.close()}};const D=(e,t)=>new E(e,{sdkName:`js-client-sdk`,sdkVersion:`0.1.6`},t),O=(e,t)=>g(e,t);export{D as createClient,O as createConsoleLogger};
2
+ //# sourceMappingURL=configdirector-client.mjs.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@configdirector/client-sdk",
3
- "version": "0.1.5",
3
+ "version": "0.1.6",
4
4
  "description": "Javascript client SDK for ConfigDirector. ConfigDirector is a remote configuration and feature flag service.",
5
5
  "license": "MIT",
6
6
  "author": "ConfigDirector",
@@ -17,31 +17,30 @@
17
17
  "homepage": "https://www.configdirector.com",
18
18
  "repository": {
19
19
  "type": "git",
20
- "url": "https://github.com/configdirector/js-client-sdk"
20
+ "url": "https://github.com/ConfigDirector/js-sdks"
21
21
  },
22
22
  "type": "module",
23
23
  "exports": {
24
24
  ".": {
25
25
  "require": {
26
- "types": "./dist/configdirector-client.d.ts",
27
- "default": "./dist/configdirector-client.cjs.js"
26
+ "types": "./dist/configdirector-client.d.cts",
27
+ "default": "./dist/configdirector-client.cjs"
28
28
  },
29
29
  "default": {
30
- "types": "./dist/configdirector-client.d.ts",
31
- "default": "./dist/configdirector-client.es.js"
30
+ "types": "./dist/configdirector-client.d.mts",
31
+ "default": "./dist/configdirector-client.mjs"
32
32
  }
33
33
  }
34
34
  },
35
35
  "files": [
36
36
  "dist/*.js",
37
- "dist/*.js.map",
38
- "dist/*client.d.ts"
37
+ "dist/*-client.d.ts"
39
38
  ],
40
- "types": "dist/configdirector-client.d.ts",
41
- "browser": "dist/configdirector-client.es.js",
42
- "module": "dist/configdirector-client.es.js",
39
+ "types": "dist/configdirector-client.d.mts",
40
+ "browser": "dist/configdirector-client.mjs",
41
+ "module": "dist/configdirector-client.mjs",
43
42
  "scripts": {
44
- "build": "rimraf dist/** && rollup -c rollup.config.js",
43
+ "build": "tsdown",
45
44
  "clean": "rimraf dist/**",
46
45
  "lint": "eslint .",
47
46
  "test": "vitest",
@@ -66,9 +65,11 @@
66
65
  "rimraf": "^6.1.2",
67
66
  "rollup": "^4.57.1",
68
67
  "rollup-plugin-dts": "^6.3.0",
68
+ "tsdown": "^0.21.0-beta.2",
69
69
  "tslib": "^2.8.1",
70
70
  "typescript": "^5.9.3",
71
71
  "typescript-eslint": "^8.54.0",
72
+ "vite-tsconfig-paths": "^6.1.1",
72
73
  "vitest": "^4.0.18"
73
74
  }
74
75
  }
@@ -1,2 +0,0 @@
1
- "use strict";var t=function(e,n){return t=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])},t(e,n)};function e(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Class extends value "+String(n)+" is not a constructor or null");function r(){this.constructor=e}t(e,n),e.prototype=null===n?Object.create(n):(r.prototype=n.prototype,new r)}var n=function(){return n=Object.assign||function(t){for(var e,n=1,r=arguments.length;n<r;n++)for(var o in e=arguments[n])Object.prototype.hasOwnProperty.call(e,o)&&(t[o]=e[o]);return t},n.apply(this,arguments)};function r(t,e,n,r){return new(n||(n=Promise))(function(o,i){function a(t){try{u(r.next(t))}catch(t){i(t)}}function s(t){try{u(r.throw(t))}catch(t){i(t)}}function u(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n(function(t){t(e)})).then(a,s)}u((r=r.apply(t,e||[])).next())})}function o(t,e){var n,r,o,i={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]},a=Object.create(("function"==typeof Iterator?Iterator:Object).prototype);return a.next=s(0),a.throw=s(1),a.return=s(2),"function"==typeof Symbol&&(a[Symbol.iterator]=function(){return this}),a;function s(s){return function(u){return function(s){if(n)throw new TypeError("Generator is already executing.");for(;a&&(a=0,s[0]&&(i=0)),i;)try{if(n=1,r&&(o=2&s[0]?r.return:s[0]?r.throw||((o=r.return)&&o.call(r),0):r.next)&&!(o=o.call(r,s[1])).done)return o;switch(r=0,o&&(s=[2&s[0],o.value]),s[0]){case 0:case 1:o=s;break;case 4:return i.label++,{value:s[1],done:!1};case 5:i.label++,r=s[1],s=[0];continue;case 7:s=i.ops.pop(),i.trys.pop();continue;default:if(!(o=i.trys,(o=o.length>0&&o[o.length-1])||6!==s[0]&&2!==s[0])){i=0;continue}if(3===s[0]&&(!o||s[1]>o[0]&&s[1]<o[3])){i.label=s[1];break}if(6===s[0]&&i.label<o[1]){i.label=o[1],o=s;break}if(o&&i.label<o[2]){i.label=o[2],i.ops.push(s);break}o[2]&&i.ops.pop(),i.trys.pop();continue}s=e.call(t,i)}catch(t){s=[6,t],r=0}finally{n=o=0}if(5&s[0])throw s[1];return{value:s[0]?s[1]:void 0,done:!0}}([s,u])}}}function i(t,e,n){if(n||2===arguments.length)for(var r,o=0,i=e.length;o<i;o++)!r&&o in e||(r||(r=Array.prototype.slice.call(e,0,o)),r[o]=e[o]);return t.concat(r||Array.prototype.slice.call(e))}"function"==typeof SuppressedError&&SuppressedError;var a=function(){function t(){this.handlerMap=new Map}return t.prototype.on=function(t,e){var n=this.handlerMap.get(t);n?n.push(e):this.handlerMap.set(t,[e])},t.prototype.once=function(t,e){var n=this;this.on(t,function r(o){n.off(t,r),e.apply(n,o)})},t.prototype.off=function(t,e){var n=this.handlerMap.get(t);if(n)if(e){var r=n.indexOf(e);r>=0&&n.splice(r,1)}else this.handlerMap.set(t,[])},t.prototype.clear=function(){this.handlerMap.clear()},t.prototype.emit=function(t,e){var n=this.handlerMap.get(t);n&&n.slice().map(function(t){return t(e)})},t}();class s extends Error{constructor(t,e){super(t),this.name="ParseError",this.type=e.type,this.field=e.field,this.value=e.value,this.line=e.line}}function u(t){}function c(t){if("function"==typeof t)throw new TypeError("`callbacks` must be an object, got a function instead. Did you mean `{onEvent: fn}`?");const{onEvent:e=u,onError:n=u,onRetry:r=u,onComment:o}=t;let i,a="",c=!0,l="",f="";function d(t){if(""===t)return l.length>0&&e({id:i,event:f||void 0,data:l.endsWith("\n")?l.slice(0,-1):l}),i=void 0,l="",void(f="");if(t.startsWith(":"))return void(o&&o(t.slice(t.startsWith(": ")?2:1)));const n=t.indexOf(":");if(-1!==n){const e=t.slice(0,n),r=" "===t[n+1]?2:1;return void p(e,t.slice(n+r),t)}p(t,"",t)}function p(t,e,o){switch(t){case"event":f=e;break;case"data":l=`${l}${e}\n`;break;case"id":i=e.includes("\0")?void 0:e;break;case"retry":/^\d+$/.test(e)?r(parseInt(e,10)):n(new s(`Invalid \`retry\` value: "${e}"`,{type:"invalid-retry",value:e,line:o}));break;default:n(new s(`Unknown field "${t.length>20?`${t.slice(0,20)}…`:t}"`,{type:"unknown-field",field:t,value:e,line:o}))}}return{feed:function(t){const e=c?t.replace(/^\xEF\xBB\xBF/,""):t,[n,r]=function(t){const e=[];let n="",r=0;for(;r<t.length;){const o=t.indexOf("\r",r),i=t.indexOf("\n",r);let a=-1;if(-1!==o&&-1!==i?a=Math.min(o,i):-1!==o?a=o===t.length-1?-1:o:-1!==i&&(a=i),-1===a){n=t.slice(r);break}{const n=t.slice(r,a);e.push(n),r=a+1,"\r"===t[r-1]&&"\n"===t[r]&&r++}}return[e,n]}(`${a}${e}`);for(const t of n)d(t);a=r,c=!1},reset:function(t={}){a&&t.consume&&d(a),c=!0,i=void 0,l="",f="",a=""}}}const l="connecting",f="closed",d=()=>{};function p(t,{getStream:e}){const n="string"==typeof t||t instanceof URL?{url:t}:t,{onMessage:r,onComment:o=d,onConnect:i=d,onDisconnect:a=d,onScheduleReconnect:s=d}=n,{fetch:u,url:p,initialLastEventId:h}=function(t){const e=t.fetch||globalThis.fetch;if(!function(t){return"function"==typeof t}(e))throw new Error("No fetch implementation provided, and one was not found on the global object.");if("function"!=typeof AbortController)throw new Error("Missing AbortController implementation");const{url:n,initialLastEventId:r}=t;if("string"!=typeof n&&!(n instanceof URL))throw new Error("Invalid URL provided - must be string or URL instance");if("string"!=typeof r&&void 0!==r)throw new Error("Invalid initialLastEventId provided - must be string or undefined");return{fetch:e,url:n,initialLastEventId:r}}(n),v={...n.headers},g=[],y=r?[r]:[],m=c({onEvent:function(t){"string"==typeof t.id&&(T=t.id),e=t,y.forEach(t=>t(e));var e},onRetry:function(t){S=t},onComment:o});let w,b,E=p.toString(),C=new AbortController,T=h,S=2e3,x=f;return k(),{close:D,connect:k,[Symbol.iterator]:()=>{throw new Error("EventSource does not support synchronous iteration. Use `for await` instead.")},[Symbol.asyncIterator]:function(){const t=[],e=[];const n=function(n){const r=t.shift();r?r({value:n,done:!1}):e.push(n)};function r(){for(y.splice(y.indexOf(n),1);t.shift(););for(;e.shift(););}return g.push(function(){const e=t.shift();e&&(e({done:!0,value:void 0}),r())}),y.push(n),{next(){return x===f?this.return():new Promise(n=>{const r=e.shift();r?n({value:r,done:!1}):t.push(n)})},return:()=>(r(),Promise.resolve({done:!0,value:void 0})),throw:t=>(r(),Promise.reject(t)),[Symbol.asyncIterator](){return this}}},get lastEventId(){return T},get url(){return E},get readyState(){return x}};function k(){w||(x=l,C=new AbortController,w=u(p,function(){const{mode:t,credentials:e,body:r,method:o,redirect:i,referrer:a,referrerPolicy:s}=n,u={Accept:"text/event-stream",...v,...T?{"Last-Event-ID":T}:void 0};return{mode:t,credentials:e,body:r,method:o,redirect:i,referrer:a,referrerPolicy:s,headers:u,cache:"no-store",signal:C.signal}}()).then(O).catch(t=>{w=null,"AbortError"!==t.name&&"aborted"!==t.type&&!C.signal.aborted&&R()}))}function D(){x=f,C.abort(),m.reset(),clearTimeout(b),g.forEach(t=>t())}function R(){s({delay:S}),!C.signal.aborted&&(x=l,b=setTimeout(k,S))}async function O(t){i(),m.reset();const{body:n,redirected:r,status:o}=t;if(204===o)return a(),void D();if(!n)throw new Error("Missing response body");r&&(E=t.url);const s=e(n),u=new TextDecoder,c=s.getReader();let l=!0;x="open";do{const{done:t,value:e}=await c.read();e&&m.feed(u.decode(e,{stream:!t})),t&&(l=!1,w=null,m.reset(),R(),a())}while(l)}}const h={getStream:function(t){if(!(t instanceof ReadableStream))throw new Error("Invalid stream, expected a web ReadableStream");return t}};var v=function(t){function n(e,r){var o=t.call(this,e)||this;return o.name="ConfigDirectorConnectionError",o.status=r,Object.setPrototypeOf(o,n.prototype),o}return e(n,t),n}(Error),g=function(t){function n(e){var r=t.call(this,e)||this;return r.name="ConfigDirectorValidationError",Object.setPrototypeOf(r,n.prototype),r}return e(n,t),n}(Error),y=function(){function t(t){this.options=t,this.eventEmitter=new a,this.options=t,this.logger=t.logger,this.url=new URL("sse/v1",t.baseUrl)}return t.prototype.connect=function(t,e){return r(this,void 0,void 0,function(){var n,i,a,s,u=this;return o(this,function(c){return this.eventSource&&this.close(),n=void 0,i=void 0,a=function(t,e){return r(u,void 0,void 0,function(){var r;return o(this,function(o){switch(o.label){case 0:return[4,fetch(t,e)];case 1:return r=o.sent(),n=r.status,r.ok?[3,3]:[4,r.text()];case 2:i=o.sent(),o.label=3;case 3:return[2,r]}})})},s=new Promise(function(e,r){var o;u.eventSource=(o={url:u.url,fetch:a,method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({givenContext:t,metaContext:u.options.metaContext,clientSdkKey:u.options.clientSdkKey}),onMessage:function(t){var e=t.data;u.dispatchMessage(e)},onConnect:function(){n&&u.isStatusFatal(n)?(u.close(),r(u.prepareFatalError(n,i))):(u.logger.debug("[EventSourceTransport] Connected, status: %s",n),e(u))},onScheduleReconnect:function(t){n&&u.isStatusFatal(n)?(u.close(),r(u.prepareFatalError(n,i))):u.logger.warn("[EventSourceTransport] Scheduling reconnect in ".concat(t.delay,". Response status: ").concat(n))},onDisconnect:function(){u.logger.debug("[EventSourceTransport] Disconnected")}},p(o,h))}),[2,Promise.race([s,new Promise(function(t){setTimeout(function(){return t(u)},e)})])]})})},t.prototype.dispatchMessage=function(t){try{var e=JSON.parse(t);this.eventEmitter.emit("configSetReceived",e)}catch(t){this.logger.error("[EventSourceTransport] Error parsing and dispatching config data update: ",t)}},t.prototype.prepareFatalError=function(t,e){var n,r,o=null!=t?t:0,i="Connection failed with status: ".concat(null!=t?t:"unknown"),a=(null!==(r=null===(n=null==e?void 0:e.trim())||void 0===n?void 0:n.length)&&void 0!==r?r:0)>0?" (".concat(e,")"):"",s="".concat(i).concat(a,". This is an unrecoverable error, will not attempt to reconnect.");return new v(s,o)},t.prototype.isStatusFatal=function(t){return!!t&&t>=400&&t<500},t.prototype.on=function(t,e){this.eventEmitter.on(t,e)},t.prototype.off=function(t,e){this.eventEmitter.off(t,e)},t.prototype.clear=function(){this.eventEmitter.clear()},t.prototype.close=function(){var t;null===(t=this.eventSource)||void 0===t||t.close()},t.prototype.dispose=function(){this.close(),this.clear()},t}(),m=function(t){var e,n,r=typeof t;if("object"===r)try{return null!==(n=null===(e=t.constructor)||void 0===e?void 0:e.name)&&void 0!==n?n:r}catch(t){return r}else if("function"===r)try{var o=t.name;return o?"function: ".concat(o):r}catch(t){return r}return r},w=function(t){return"number"===t||"bigint"===t},b=function(t){if(t){var e=t.toLowerCase();if("true"==e||"false"==e)return"true"===e}},E=function(t){if(t){var e=Number.parseInt(t);if(!isNaN(e)&&isFinite(e))return e}},C=function(t){if(t){var e=Number.parseFloat(t);if(!isNaN(e)&&isFinite(e))return e}},T={off:-1,error:0,warn:1,info:2,debug:3},S=function(){function t(t,e){this.level=t,this.decorator=e,this.level=t,this.decorator=e,this.dateFormatter=function(){var t={year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",timeZoneName:"short"};try{return new Intl.DateTimeFormat(void 0,n(n({},t),{fractionalSecondDigits:3}))}catch(e){return new Intl.DateTimeFormat(void 0,t)}}()}return t.prototype.debug=function(t){for(var e=[],n=1;n<arguments.length;n++)e[n-1]=arguments[n];this.log.apply(this,i([console.debug,"debug",t],e,!1))},t.prototype.info=function(t){for(var e=[],n=1;n<arguments.length;n++)e[n-1]=arguments[n];this.log.apply(this,i([console.info,"info",t],e,!1))},t.prototype.warn=function(t){for(var e=[],n=1;n<arguments.length;n++)e[n-1]=arguments[n];this.log.apply(this,i([console.warn,"warn",t],e,!1))},t.prototype.error=function(t){for(var e=[],n=1;n<arguments.length;n++)e[n-1]=arguments[n];this.log.apply(this,i([console.error,"error",t],e,!1))},t.prototype.log=function(t,e,n){for(var r,o=[],a=3;a<arguments.length;a++)o[a-3]=arguments[a];T[this.level]>=T[e]&&t.apply(void 0,i(["[".concat(this.dateFormatter.format(new Date),"] ").concat(null===(r=this.decorator)||void 0===r?void 0:r.decorateMessage(n))],o,!1))},t}(),x=function(){function t(){}return t.prototype.decorateMessage=function(t){return"[ConfigDirector:js-client-sdk] ".concat(t)},t}(),k=function(t,e){return new S(null!=t?t:"warn",null!=e?e:new x)},D=function(){function t(){}return t.prototype.aggregate=function(t){var e;if(0==t.events.length)return[];for(var n=new Map,r=0,o=t.events;r<o.length;r++){var i=o[r],a=JSON.stringify(i),s=(null===(e=n.get(a))||void 0===e?void 0:e.count)||0;n.set(a,{event:i,count:s+1})}return Array.from(n).map(function(e){var n=e[1];return{startTime:t.startTime,endTime:t.endTime,count:n.count,event:n.event}})},t}(),R=function(){function t(t){this._events=[],this._droppedEventCount=0,this.limit=null!=t?t:1e3}return Object.defineProperty(t.prototype,"events",{get:function(){return this._events},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"reachedLimit",{get:function(){return this._events.length>=this.limit},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"droppedEventCount",{get:function(){return this._droppedEventCount},enumerable:!1,configurable:!0}),t.prototype.push=function(){for(var t,e=[],n=0;n<arguments.length;n++)e[n]=arguments[n];this.startTime||(this.startTime=new Date);var r=Math.max(0,e.length-this.limit),o=e.slice(r,e.length);if(this._droppedEventCount+=r,this._events.length+o.length>this.limit){var i=this._events.length+o.length-this.limit;this._events.splice(0,i),this._droppedEventCount+=i}return(t=this._events).push.apply(t,o)},t.prototype.takeSnapshot=function(){var t,e=new Date,n=null!==(t=this.startTime)&&void 0!==t?t:e,r=this._events.splice(0),o=this._droppedEventCount;return this.startTime=void 0,this._droppedEventCount=0,{startTime:n,endTime:e,events:r,droppedCount:o}},t.prototype.clear=function(){this._events=[],this.startTime=void 0,this._droppedEventCount=0},t}(),O=function(){function t(t){this.executeRequests=!0,this.sdkKey=t.sdkKey,this.logger=t.logger,this.url=new URL("telemetry/v1",t.baseUrl)}return t.prototype.report=function(t){var e=t.discreteEvents,n=t.aggregatedEvents,r=t.droppedEvents;if(!this.executeRequests)return{success:!1,fatalError:!0};var o={clientSdkKey:this.sdkKey,discreteEvents:e,aggregatedEvents:n,droppedEvents:r};if(this.isReportEmpty(o))return{success:!0,fatalError:!1};var i=this.sendReport(o);return i.fatalError&&(this.executeRequests=!1),i},t.prototype.isReportEmpty=function(t){return this.isEventListEmpty(t.discreteEvents)&&this.isEventListEmpty(t.aggregatedEvents)&&this.isDroppedEventsEmpty(t.droppedEvents)},t.prototype.isDroppedEventsEmpty=function(t){var e;if(!t)return!0;var n=Object.keys(t);if(0==n.length)return!0;for(var r=0,o=n;r<o.length;r++){if((null!==(e=t[o[r]])&&void 0!==e?e:0)>0)return!1}return!0},t.prototype.isEventListEmpty=function(t){var e,n,r=Object.keys(t);if(0==r.length)return!0;for(var o=0,i=r;o<i.length;o++){if((null!==(n=null===(e=t[i[o]])||void 0===e?void 0:e.length)&&void 0!==n?n:0)>0)return!1}return!0},t.prototype.sendReport=function(t){try{return{success:navigator.sendBeacon(this.url,JSON.stringify(t)),fatalError:!1}}catch(t){return this.logger.warn("[EventReporter] Fatal error attempting to send telemetry data: ".concat(t,". No more telemetry data will be sent.")),{success:!1,fatalError:!0}}},t}(),V=function(t){for(var e=5381,n=0;n<t.length;n++)e=(e<<5)+e+t[n],e>>>=0;return e},M=function(){function t(t){var e=this;this.evaluationEventQueue=new R,this.aggregator=new D,this.collectEvents=!0,this.logger=t.logger,this.reporter=new O(t),this.flushIntervalDelay=3e4;this.flushTimeout=setTimeout(function(){return e.flushAndScheduleNext()},5e3);try{document.addEventListener("visibilitychange",function(){"hidden"===document.visibilityState&&e.flush()})}catch(t){this.logger.warn("[TelemetryEventCollector] Could not configure 'visibilitychange' listener: ",t)}}return t.prototype.evaluatedConfig=function(t){this.collectEvents&&this.evaluationEventQueue.push(this.sanitizeEvaluatedConfigEvent(t))},t.prototype.sanitizeEvaluatedConfigEvent=function(t){return{key:t.key,type:t.type,defaultValue:this.sanitizeValue(t.defaultValue,t.type),requestedType:t.requestedType,evaluatedValue:this.sanitizeValue(t.evaluatedValue,t.type),usedDefault:t.usedDefault,evaluationReason:t.evaluationReason}},t.prototype.sanitizeValue=function(t,e){if("json"===e)try{var n=JSON.stringify(t);return r=n,V((new TextEncoder).encode(r)).toString(16).padStart(8,"0")}catch(e){return t.toString().slice(0,500)}var r;return t.toString().slice(0,500)},t.prototype.flushAndScheduleNext=function(){var t=this;this.flush().fatalError?(this.collectEvents=!1,this.close(),this.logger.warn("[TelemetryEventCollector] Received a fatal error from telemetry collection. No longer collecting events.")):this.flushTimeout=setTimeout(function(){return t.flushAndScheduleNext()},this.flushIntervalDelay)},t.prototype.flush=function(){var t=this.evaluationEventQueue.takeSnapshot();return this.reporter.report({discreteEvents:{},aggregatedEvents:{evaluatedConfig:this.aggregator.aggregate(t)},droppedEvents:{evaluatedConfig:t.droppedCount}})},t.prototype.close=function(){this.collectEvents=!1,clearTimeout(this.flushTimeout),this.flush(),this.evaluationEventQueue.clear()},t.prototype.dispose=function(){this.close()},t}(),P=function(t,e,i,a){return r(void 0,void 0,void 0,function(){var r,s,u,c;return o(this,function(o){switch(o.label){case 0:r=new AbortController,s=setTimeout(function(){a.debug("[fetchWithTimeout] Reached timeout, aborting request"),r.abort()},t),o.label=1;case 1:return o.trys.push([1,3,,4]),[4,fetch(e,n(n({},i),{signal:r.signal}))];case 2:return u=o.sent(),clearTimeout(s),[2,u];case 3:throw c=o.sent(),a.warn("[fetchWithTimeout] Fetch error: ",c),clearTimeout(s),c;case 4:return[2]}})})},F=function(){function t(t){this.options=t,this.eventEmitter=new a,this.fatalError=!1,this.options=t,this.logger=t.logger,this.url=new URL("pull/v1",t.baseUrl)}return t.prototype.connect=function(t,e){return r(this,void 0,void 0,function(){var n,r,i,a,s,u,c;return o(this,function(o){switch(o.label){case 0:if(this.fatalError)return this.logger.warn("[PullTransport] There was a prior unrecoverable error. Ignoring attempt to reconnect."),[2,this];o.label=1;case 1:return o.trys.push([1,7,,8]),[4,P(e,this.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({givenContext:t,metaContext:this.options.metaContext,clientSdkKey:this.options.clientSdkKey})},this.logger)];case 2:return(n=o.sent()).ok?[3,5]:this.isStatusFatal(n.status)?(this.fatalError=!0,r=this.prepareFatalResponseStatusError,i=[n.status],[4,n.text()]):[3,4];case 3:throw r.apply(this,i.concat([o.sent()]));case 4:throw new v("Connection failed with status: ".concat(n.status),n.status);case 5:return u=(s=JSON).parse,[4,n.text()];case 6:return a=u.apply(s,[o.sent()]),this.eventEmitter.emit("configSetReceived",a),[2,this];case 7:throw function(t){if(t instanceof DOMException){if("NotAllowedError"===t.name)return!0}else if(t instanceof TypeError)return!0;return!1}(c=o.sent())?(this.fatalError=!0,new v("Connection failed with fatal error: ".concat(c,". This is an unrecoverable error, retry attempts will be ignored."))):c instanceof SyntaxError?new v("Failed to parse the response from the server: ".concat(c)):new v("Connection failed with error: ".concat(c,"."));case 8:return[2]}})})},t.prototype.prepareFatalResponseStatusError=function(t,e){var n,r,o=null!=t?t:0,i="Connection failed with status: ".concat(null!=t?t:"unknown"),a=(null!==(r=null===(n=null==e?void 0:e.trim())||void 0===n?void 0:n.length)&&void 0!==r?r:0)>0?" (".concat(e,")"):"",s="".concat(i).concat(a,". This is an unrecoverable error, retry attempts will be ignored.");return new v(s,o)},t.prototype.isStatusFatal=function(t){return!!t&&t>=400&&t<500},t.prototype.on=function(t,e){this.eventEmitter.on(t,e)},t.prototype.off=function(t,e){this.eventEmitter.off(t,e)},t.prototype.clear=function(){this.eventEmitter.clear()},t.prototype.close=function(){},t.prototype.dispose=function(){this.close(),this.clear()},t}(),I=new URL("https://client-sdk-api.configdirector.com"),j=function(){function t(t,e){var r,o,i,s,u,c,l=this;this.handlersMap=new Map,this.eventEmitter=new a,this.ready=!1,this.logger=null!==(r=null==e?void 0:e.logger)&&void 0!==r?r:k(),this.timeout=null!==(i=null===(o=null==e?void 0:e.connection)||void 0===o?void 0:o.timeout)&&void 0!==i?i:3e3;var f=null!==(u=this.parseUrl(null===(s=null==e?void 0:e.connection)||void 0===s?void 0:s.url))&&void 0!==u?u:I;this.streaming=!1!==(null===(c=null==e?void 0:e.connection)||void 0===c?void 0:c.streaming);var d=this.streaming?y:F;this.usageEventCollector=new M({sdkKey:t,logger:this.logger,baseUrl:f}),this.transport=new d({clientSdkKey:t,baseUrl:f,metaContext:n(n({},null==e?void 0:e.metadata),{sdkName:"js-client-sdk",sdkVersion:"0.1.5",userAgent:null===navigator||void 0===navigator?void 0:navigator.userAgent}),logger:this.logger}),this.transport.on("configSetReceived",function(t){var e;null===(e=l.readyResolve)||void 0===e||e.call(l);var r=Object.keys(t.configs);l.configSet&&"full"!=t.kind?(l.configSet.configs=n(n({},l.configSet.configs),t.configs),l.eventEmitter.emit("configsUpdated",{keys:r}),l.updateWatchers(t.configs)):(l.configSet=t,l.eventEmitter.emit("configsUpdated",{keys:r}),l.updateWatchers(t.configs)),l.logger.debug("[ConfigDirectorClient] ConfigSet updated from server:",{keys:r})})}return t.prototype.initialize=function(t){return r(this,void 0,void 0,function(){return o(this,function(e){switch(e.label){case 0:return[4,this.connectToTransport(t,"initialization")];case 1:return e.sent(),[2]}})})},t.prototype.updateContext=function(t){return r(this,void 0,void 0,function(){return o(this,function(e){switch(e.label){case 0:return[4,this.connectToTransport(t,"context update")];case 1:return e.sent(),[2]}})})},t.prototype.connectToTransport=function(t,e){return r(this,void 0,void 0,function(){var n,r,i,a,s,u=this;return o(this,function(o){switch(o.label){case 0:return o.trys.push([0,4,,5]),this.ready=!1,this.readyPromise=new Promise(function(t){u.readyResolve=t}).then(function(){u.ready=!0,u.eventEmitter.emit("clientReady",{action:e}),u.logger.debug("[ConfigDirectorClient] Received initial payload from the server, client is ready")}),n=(new Date).getTime(),[4,this.transport.connect(null!=t?t:{},this.timeout)];case 1:return o.sent(),this.currentContext=t,r=(new Date).getTime()-n,(i=this.timeout-r)>0?[4,Promise.race([this.readyPromise,new Promise(function(t){setTimeout(function(){return t()},i)})])]:[3,3];case 2:o.sent(),o.label=3;case 3:return this.ready||(a=this.streaming?"The client will continue to retry since there were no fatal errors detected. Configs will return the default value until the connection succeeds.":"Since the client was configured without streaming, configs may not update and always return the default value.",this.logger.warn("[ConfigDirectorClient] Timed out waiting for ".concat(e," after ").concat(this.timeout,"ms. ").concat(a))),[3,5];case 4:return s=o.sent(),this.logger.error("[ConfigDirectorClient] An error occurred during ".concat(e,": "),s),[3,5];case 5:return[2]}})})},t.prototype.updateWatchers=function(t){var e=this;Object.values(t).forEach(function(t){return e.updateWatchersForConfig(t)})},t.prototype.updateWatchersForConfig=function(t){var e,n=this;null===(e=this.handlersMap.get(t.key))||void 0===e||e.forEach(function(e){var r=n.getValueFromConfigState(t.key,t,e.defaultValue);e.handler(r)})},t.prototype.watch=function(t,e,n){var r=this;this.validateDefaultValue(e);var o=this.handlersMap.get(t),i={handler:n,defaultValue:e,requestedType:typeof e};return o?o.push(i):this.handlersMap.set(t,[i]),function(){return r.unwatch(t,n)}},t.prototype.unwatch=function(t,e){var n=this.handlersMap.get(t);if(n)if(e){var r=n.findIndex(function(t){return t.handler==e});r>=0&&(null==n||n.splice(r,1))}else n.splice(0)},t.prototype.getValue=function(t,e){var n;this.validateDefaultValue(e);var r=null===(n=this.configSet)||void 0===n?void 0:n.configs[t];return this.getValueFromConfigState(t,r,e)},t.prototype.getValueFromConfigState=function(t,e,n){var r,o;if(!e)return this.logger.debug("[ConfigDirectorClient] No config state found for '".concat(t,"', returning default value '").concat(n,"'")),this.usageEventCollector.evaluatedConfig({contextId:null===(r=this.currentContext)||void 0===r?void 0:r.id,key:t,defaultValue:n,requestedType:m(n),evaluatedValue:n,usedDefault:!0,evaluationReason:"config-state-missing"}),n;var i=function(t,e){var n,r,o=t.value,i=m(e);if(!o)return{parsedValue:e,requestedType:i,usedDefault:!0,reason:"value-missing"};if("string"==typeof e)return{parsedValue:o,requestedType:i,usedDefault:!1,reason:"found-match"};if("boolean"==typeof e&&"boolean"===t.type){var a=b(o),s="boolean"==typeof a;return{parsedValue:s?a:e,requestedType:i,usedDefault:!s,reason:s?"found-match":"invalid-boolean"}}return w(typeof e)&&"integer"===t.type?{parsedValue:(r="number"==typeof(n=E(o)))?n:e,requestedType:i,usedDefault:!r,reason:r?"found-match":"invalid-number"}:!w(typeof e)||"float"!==t.type&&"enum"!==t.type?{parsedValue:o,requestedType:i,usedDefault:!1,reason:"found-match"}:{parsedValue:(r="number"==typeof(n=C(o)))?n:e,requestedType:i,usedDefault:!r,reason:r?"found-match":"invalid-number"}}(e,n);return this.usageEventCollector.evaluatedConfig({contextId:null===(o=this.currentContext)||void 0===o?void 0:o.id,key:t,defaultValue:n,requestedType:i.requestedType,evaluatedValue:i.parsedValue,usedDefault:i.usedDefault,evaluationReason:i.reason}),this.logger.debug("[ConfigDirectorClient] Evaluated '".concat(t,"' to '").concat(i.parsedValue,"'")),i.parsedValue},t.prototype.parseUrl=function(t){if(t)try{return new URL(t)}catch(e){throw new g("Invalid base URL '".concat(t,"'. Parsing failed: ").concat(e))}},t.prototype.validateDefaultValue=function(t){if(null==t)throw new g("Invalid default value. The default value for a config must be defined and non-null.");if("function"==typeof t)throw new g("Invalid default value. The default value for a config cannot be a function.")},Object.defineProperty(t.prototype,"isReady",{get:function(){return this.ready},enumerable:!1,configurable:!0}),t.prototype.on=function(t,e){this.eventEmitter.on(t,e)},t.prototype.off=function(t,e){this.eventEmitter.off(t,e)},t.prototype.clear=function(){this.logger.debug("[ConfigDirectorClient] clear() has been called, removing all observers"),this.eventEmitter.clear(),this.handlersMap.clear()},t.prototype.unwatchAll=function(){this.handlersMap.clear()},t.prototype.close=function(){this.logger.debug("[ConfigDirectorClient] close() has been called, closing connection to server"),this.transport.close(),this.ready=!1},t.prototype.dispose=function(){this.clear(),this.close()},t}();exports.createClient=function(t,e){return new j(t,e)},exports.createConsoleLogger=function(t,e){return k(t,e)};
2
- //# sourceMappingURL=configdirector-client.cjs.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"configdirector-client.cjs.js","sources":["../node_modules/tslib/tslib.es6.js","../../src/Emitter.ts","../node_modules/eventsource-parser/dist/index.js","../node_modules/eventsource-client/dist/default.esm.js","../../src/errors.ts","../../src/StreamingTransport.ts","../../src/value-parser.ts","../../src/logger.ts","../../src/telemetry/EventAggregator.ts","../../src/telemetry/EventQueue.ts","../../src/telemetry/EventReporter.ts","../../src/telemetry/utils.ts","../../src/telemetry/TelemetryEventCollector.ts","../../src/fetchWithTimeout.ts","../../src/PullTransport.ts","../../src/DefaultConfigDirectorClient.ts","../../src/index.ts"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","type EventType = string | symbol;\ntype EventsRecord = Record<EventType, any>;\n\ntype Handler<TEventsRecord extends EventsRecord, TKey extends keyof TEventsRecord> = (\n payload: TEventsRecord[TKey],\n) => void;\n\nexport interface EventProvider<TEventsRecord extends EventsRecord> {\n on<TName extends keyof TEventsRecord>(name: TName, handler: Handler<TEventsRecord, TName>): void;\n off<TName extends keyof TEventsRecord>(name: TName, handler?: Handler<TEventsRecord, TName>): void;\n clear(): void;\n}\n\nexport class Emitter<TEventsRecord extends EventsRecord> implements EventProvider<TEventsRecord> {\n private handlerMap: Map<keyof TEventsRecord, Array<(payload: any) => void>> = new Map();\n\n on<TName extends keyof TEventsRecord>(name: TName, handler: Handler<TEventsRecord, TName>) {\n const handlers = this.handlerMap.get(name);\n if (handlers) {\n handlers.push(handler);\n } else {\n this.handlerMap.set(name, [handler]);\n }\n }\n\n once<TName extends keyof TEventsRecord>(name: TName, handler: Handler<TEventsRecord, TName>) {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const self = this;\n function onceHandler(payload: TEventsRecord[keyof TEventsRecord]) {\n self.off(name, onceHandler);\n handler.apply(self, payload);\n }\n this.on(name, onceHandler);\n }\n\n off<TName extends keyof TEventsRecord>(name: TName, handler?: Handler<TEventsRecord, TName>) {\n const handlers = this.handlerMap.get(name);\n if (!handlers) {\n return;\n }\n\n if (handler) {\n const listenerIndex = handlers.indexOf(handler);\n if (listenerIndex >= 0) {\n handlers.splice(listenerIndex, 1);\n }\n } else {\n this.handlerMap.set(name, []);\n }\n }\n\n clear() {\n this.handlerMap.clear();\n }\n\n emit<TName extends keyof TEventsRecord>(name: TName, payload: TEventsRecord[TName]) {\n const handlers = this.handlerMap.get(name);\n if (!handlers) {\n return;\n }\n\n handlers.slice().map((h) => h(payload));\n }\n}\n","class ParseError extends Error {\n constructor(message, options) {\n super(message), this.name = \"ParseError\", this.type = options.type, this.field = options.field, this.value = options.value, this.line = options.line;\n }\n}\nfunction noop(_arg) {\n}\nfunction createParser(callbacks) {\n if (typeof callbacks == \"function\")\n throw new TypeError(\n \"`callbacks` must be an object, got a function instead. Did you mean `{onEvent: fn}`?\"\n );\n const { onEvent = noop, onError = noop, onRetry = noop, onComment } = callbacks;\n let incompleteLine = \"\", isFirstChunk = !0, id, data = \"\", eventType = \"\";\n function feed(newChunk) {\n const chunk = isFirstChunk ? newChunk.replace(/^\\xEF\\xBB\\xBF/, \"\") : newChunk, [complete, incomplete] = splitLines(`${incompleteLine}${chunk}`);\n for (const line of complete)\n parseLine(line);\n incompleteLine = incomplete, isFirstChunk = !1;\n }\n function parseLine(line) {\n if (line === \"\") {\n dispatchEvent();\n return;\n }\n if (line.startsWith(\":\")) {\n onComment && onComment(line.slice(line.startsWith(\": \") ? 2 : 1));\n return;\n }\n const fieldSeparatorIndex = line.indexOf(\":\");\n if (fieldSeparatorIndex !== -1) {\n const field = line.slice(0, fieldSeparatorIndex), offset = line[fieldSeparatorIndex + 1] === \" \" ? 2 : 1, value = line.slice(fieldSeparatorIndex + offset);\n processField(field, value, line);\n return;\n }\n processField(line, \"\", line);\n }\n function processField(field, value, line) {\n switch (field) {\n case \"event\":\n eventType = value;\n break;\n case \"data\":\n data = `${data}${value}\n`;\n break;\n case \"id\":\n id = value.includes(\"\\0\") ? void 0 : value;\n break;\n case \"retry\":\n /^\\d+$/.test(value) ? onRetry(parseInt(value, 10)) : onError(\n new ParseError(`Invalid \\`retry\\` value: \"${value}\"`, {\n type: \"invalid-retry\",\n value,\n line\n })\n );\n break;\n default:\n onError(\n new ParseError(\n `Unknown field \"${field.length > 20 ? `${field.slice(0, 20)}\\u2026` : field}\"`,\n { type: \"unknown-field\", field, value, line }\n )\n );\n break;\n }\n }\n function dispatchEvent() {\n data.length > 0 && onEvent({\n id,\n event: eventType || void 0,\n // If the data buffer's last character is a U+000A LINE FEED (LF) character,\n // then remove the last character from the data buffer.\n data: data.endsWith(`\n`) ? data.slice(0, -1) : data\n }), id = void 0, data = \"\", eventType = \"\";\n }\n function reset(options = {}) {\n incompleteLine && options.consume && parseLine(incompleteLine), isFirstChunk = !0, id = void 0, data = \"\", eventType = \"\", incompleteLine = \"\";\n }\n return { feed, reset };\n}\nfunction splitLines(chunk) {\n const lines = [];\n let incompleteLine = \"\", searchIndex = 0;\n for (; searchIndex < chunk.length; ) {\n const crIndex = chunk.indexOf(\"\\r\", searchIndex), lfIndex = chunk.indexOf(`\n`, searchIndex);\n let lineEnd = -1;\n if (crIndex !== -1 && lfIndex !== -1 ? lineEnd = Math.min(crIndex, lfIndex) : crIndex !== -1 ? crIndex === chunk.length - 1 ? lineEnd = -1 : lineEnd = crIndex : lfIndex !== -1 && (lineEnd = lfIndex), lineEnd === -1) {\n incompleteLine = chunk.slice(searchIndex);\n break;\n } else {\n const line = chunk.slice(searchIndex, lineEnd);\n lines.push(line), searchIndex = lineEnd + 1, chunk[searchIndex - 1] === \"\\r\" && chunk[searchIndex] === `\n` && searchIndex++;\n }\n }\n return [lines, incompleteLine];\n}\nexport {\n ParseError,\n createParser\n};\n//# sourceMappingURL=index.js.map\n","import { createParser } from \"eventsource-parser\";\nconst CONNECTING = \"connecting\", OPEN = \"open\", CLOSED = \"closed\", noop = () => {\n};\nfunction createEventSource$1(optionsOrUrl, { getStream: getStream2 }) {\n const options = typeof optionsOrUrl == \"string\" || optionsOrUrl instanceof URL ? { url: optionsOrUrl } : optionsOrUrl, {\n onMessage,\n onComment = noop,\n onConnect = noop,\n onDisconnect = noop,\n onScheduleReconnect = noop\n } = options, { fetch, url, initialLastEventId } = validate(options), requestHeaders = { ...options.headers }, onCloseSubscribers = [], subscribers = onMessage ? [onMessage] : [], emit = (event) => subscribers.forEach((fn) => fn(event)), parser = createParser({ onEvent, onRetry, onComment });\n let request, currentUrl = url.toString(), controller = new AbortController(), lastEventId = initialLastEventId, reconnectMs = 2e3, reconnectTimer, readyState = CLOSED;\n return connect(), {\n close,\n connect,\n [Symbol.iterator]: () => {\n throw new Error(\n \"EventSource does not support synchronous iteration. Use `for await` instead.\"\n );\n },\n [Symbol.asyncIterator]: getEventIterator,\n get lastEventId() {\n return lastEventId;\n },\n get url() {\n return currentUrl;\n },\n get readyState() {\n return readyState;\n }\n };\n function connect() {\n request || (readyState = CONNECTING, controller = new AbortController(), request = fetch(url, getRequestOptions()).then(onFetchResponse).catch((err) => {\n request = null, !(err.name === \"AbortError\" || err.type === \"aborted\" || controller.signal.aborted) && scheduleReconnect();\n }));\n }\n function close() {\n readyState = CLOSED, controller.abort(), parser.reset(), clearTimeout(reconnectTimer), onCloseSubscribers.forEach((fn) => fn());\n }\n function getEventIterator() {\n const pullQueue = [], pushQueue = [];\n function pullValue() {\n return new Promise((resolve) => {\n const value = pushQueue.shift();\n value ? resolve({ value, done: !1 }) : pullQueue.push(resolve);\n });\n }\n const pushValue = function(value) {\n const resolve = pullQueue.shift();\n resolve ? resolve({ value, done: !1 }) : pushQueue.push(value);\n };\n function unsubscribe() {\n for (subscribers.splice(subscribers.indexOf(pushValue), 1); pullQueue.shift(); )\n ;\n for (; pushQueue.shift(); )\n ;\n }\n function onClose() {\n const resolve = pullQueue.shift();\n resolve && (resolve({ done: !0, value: void 0 }), unsubscribe());\n }\n return onCloseSubscribers.push(onClose), subscribers.push(pushValue), {\n next() {\n return readyState === CLOSED ? this.return() : pullValue();\n },\n return() {\n return unsubscribe(), Promise.resolve({ done: !0, value: void 0 });\n },\n throw(error) {\n return unsubscribe(), Promise.reject(error);\n },\n [Symbol.asyncIterator]() {\n return this;\n }\n };\n }\n function scheduleReconnect() {\n onScheduleReconnect({ delay: reconnectMs }), !controller.signal.aborted && (readyState = CONNECTING, reconnectTimer = setTimeout(connect, reconnectMs));\n }\n async function onFetchResponse(response) {\n onConnect(), parser.reset();\n const { body, redirected, status } = response;\n if (status === 204) {\n onDisconnect(), close();\n return;\n }\n if (!body)\n throw new Error(\"Missing response body\");\n redirected && (currentUrl = response.url);\n const stream = getStream2(body), decoder = new TextDecoder(), reader = stream.getReader();\n let open = !0;\n readyState = OPEN;\n do {\n const { done, value } = await reader.read();\n value && parser.feed(decoder.decode(value, { stream: !done })), done && (open = !1, request = null, parser.reset(), scheduleReconnect(), onDisconnect());\n } while (open);\n }\n function onEvent(msg) {\n typeof msg.id == \"string\" && (lastEventId = msg.id), emit(msg);\n }\n function onRetry(ms) {\n reconnectMs = ms;\n }\n function getRequestOptions() {\n const { mode, credentials, body, method, redirect, referrer, referrerPolicy } = options, headers = { Accept: \"text/event-stream\", ...requestHeaders, ...lastEventId ? { \"Last-Event-ID\": lastEventId } : void 0 };\n return {\n mode,\n credentials,\n body,\n method,\n redirect,\n referrer,\n referrerPolicy,\n headers,\n cache: \"no-store\",\n signal: controller.signal\n };\n }\n}\nfunction validate(options) {\n const fetch = options.fetch || globalThis.fetch;\n if (!isFetchLike(fetch))\n throw new Error(\"No fetch implementation provided, and one was not found on the global object.\");\n if (typeof AbortController != \"function\")\n throw new Error(\"Missing AbortController implementation\");\n const { url, initialLastEventId } = options;\n if (typeof url != \"string\" && !(url instanceof URL))\n throw new Error(\"Invalid URL provided - must be string or URL instance\");\n if (typeof initialLastEventId != \"string\" && initialLastEventId !== void 0)\n throw new Error(\"Invalid initialLastEventId provided - must be string or undefined\");\n return { fetch, url, initialLastEventId };\n}\nfunction isFetchLike(fetch) {\n return typeof fetch == \"function\";\n}\nconst defaultAbstractions = {\n getStream\n};\nfunction createEventSource(optionsOrUrl) {\n return createEventSource$1(optionsOrUrl, defaultAbstractions);\n}\nfunction getStream(body) {\n if (!(body instanceof ReadableStream))\n throw new Error(\"Invalid stream, expected a web ReadableStream\");\n return body;\n}\nexport {\n CLOSED,\n CONNECTING,\n OPEN,\n createEventSource\n};\n//# sourceMappingURL=default.esm.js.map\n","export class ConfigDirectorConnectionError extends Error {\n public override readonly name: string = \"ConfigDirectorConnectionError\";\n public readonly status?: number;\n\n constructor(message: string, status?: number) {\n super(message);\n this.status = status;\n\n Object.setPrototypeOf(this, ConfigDirectorConnectionError.prototype);\n }\n}\n\nexport class ConfigDirectorValidationError extends Error {\n public override readonly name: string = \"ConfigDirectorValidationError\";\n\n constructor(message: string) {\n super(message);\n\n Object.setPrototypeOf(this, ConfigDirectorValidationError.prototype);\n }\n}\n\nexport const isFetchErrorFatal = (fetchError: any): boolean => {\n if (fetchError instanceof DOMException) {\n const domError = fetchError as DOMException;\n if (domError.name === \"NotAllowedError\") {\n return true;\n }\n } else if (fetchError instanceof TypeError) {\n return true;\n }\n\n return false;\n};\n","import { createEventSource, type EventSourceClient } from \"eventsource-client\";\nimport type {\n ConfigDirectorContext,\n ConfigDirectorLogger,\n Transport,\n TransportEvents,\n TransportOptions,\n} from \"./types\";\nimport { Emitter } from \"./Emitter\";\nimport { ConfigDirectorConnectionError } from \"./errors\";\n\nexport class StreamingTransport implements Transport {\n private logger: ConfigDirectorLogger;\n private eventSource: EventSourceClient | undefined;\n private eventEmitter = new Emitter<TransportEvents>();\n private url: URL;\n\n constructor(private readonly options: TransportOptions) {\n this.options = options;\n this.logger = options.logger;\n this.url = new URL(\"sse/v1\", options.baseUrl);\n }\n\n public async connect(context: ConfigDirectorContext, timeout: number): Promise<this> {\n if (this.eventSource) {\n this.close();\n }\n\n let responseStatus: number | undefined = undefined;\n let errorBody: string | undefined = undefined;\n\n const customFetch = async (url: string | URL | Request, init?: RequestInit | undefined) => {\n const response = await fetch(url, init);\n responseStatus = response.status;\n if (!response.ok) {\n errorBody = await response.text();\n }\n return response;\n };\n\n const eventSourcePromise = new Promise<this>((resolve, reject) => {\n this.eventSource = createEventSource({\n url: this.url,\n fetch: customFetch,\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n givenContext: context,\n metaContext: this.options.metaContext,\n clientSdkKey: this.options.clientSdkKey,\n }),\n\n onMessage: ({ data }) => {\n this.dispatchMessage(data);\n },\n onConnect: () => {\n if (responseStatus && this.isStatusFatal(responseStatus)) {\n this.close();\n reject(this.prepareFatalError(responseStatus, errorBody));\n } else {\n this.logger.debug(\"[EventSourceTransport] Connected, status: %s\", responseStatus);\n resolve(this);\n }\n },\n onScheduleReconnect: (info: { delay: number }) => {\n if (responseStatus && this.isStatusFatal(responseStatus)) {\n this.close();\n reject(this.prepareFatalError(responseStatus, errorBody));\n } else {\n this.logger.warn(\n `[EventSourceTransport] Scheduling reconnect in ${info.delay}. Response status: ${responseStatus}`,\n );\n }\n },\n onDisconnect: () => {\n this.logger.debug(\"[EventSourceTransport] Disconnected\");\n },\n });\n });\n return Promise.race([\n eventSourcePromise,\n new Promise<this>((resolve) => {\n setTimeout(() => resolve(this), timeout);\n }),\n ]);\n }\n\n private dispatchMessage(data: string) {\n try {\n const json = JSON.parse(data);\n this.eventEmitter.emit(\"configSetReceived\", json);\n } catch (error) {\n this.logger.error(\"[EventSourceTransport] Error parsing and dispatching config data update: \", error);\n }\n }\n\n private prepareFatalError(\n responseStatus: number,\n errorBody: string | undefined,\n ): ConfigDirectorConnectionError {\n const status = responseStatus ?? 0;\n const headline = `Connection failed with status: ${responseStatus ?? \"unknown\"}`;\n const serverBody = (errorBody?.trim()?.length ?? 0) > 0 ? ` (${errorBody})` : \"\";\n const message = `${headline}${serverBody}. This is an unrecoverable error, will not attempt to reconnect.`;\n return new ConfigDirectorConnectionError(message, status);\n }\n\n private isStatusFatal(status: number | undefined): boolean {\n return !!status && status >= 400 && status < 500;\n }\n\n public on<TName extends keyof TransportEvents>(\n name: TName,\n handler: (payload: TransportEvents[TName]) => void,\n ): void {\n this.eventEmitter.on(name, handler);\n }\n\n public off<TName extends keyof TransportEvents>(\n name: TName,\n handler?: ((payload: TransportEvents[TName]) => void) | undefined,\n ): void {\n this.eventEmitter.off(name, handler);\n }\n\n public clear(): void {\n this.eventEmitter.clear();\n }\n\n public close() {\n this.eventSource?.close();\n }\n\n public dispose(): void {\n this.close();\n this.clear();\n }\n}\n","import type { ConfigState, ConfigValueType, EvaluationReason } from \"./types\";\n\ntype NativeType =\n | \"string\"\n | \"number\"\n | \"bigint\"\n | \"boolean\"\n | \"symbol\"\n | \"undefined\"\n | \"object\"\n | \"function\";\n\ntype ParseResult<T extends ConfigValueType> = {\n parsedValue: T;\n requestedType: NativeType | string;\n usedDefault: boolean;\n reason: EvaluationReason;\n};\n\nexport const getRequestedType = <T extends ConfigValueType>(defaultValue: T): string => {\n const baseType = typeof defaultValue;\n if (baseType === \"object\") {\n try {\n return (defaultValue as object).constructor?.name ?? baseType;\n } catch {\n return baseType;\n }\n } else if (baseType === \"function\") {\n try {\n const functionName = (defaultValue as any).name;\n return functionName ? `function: ${functionName}` : baseType;\n } catch {\n return baseType;\n }\n }\n return baseType;\n};\n\nconst isNumericNativeType = (requestedType: NativeType): boolean => {\n return requestedType === \"number\" || requestedType === \"bigint\";\n};\n\nexport const parseConfigValue = <T extends ConfigValueType>(\n configState: ConfigState,\n defaultValue: T,\n): ParseResult<T> => {\n const value = configState.value;\n const requestedType = getRequestedType(defaultValue);\n\n if (!value) {\n return {\n parsedValue: defaultValue as T,\n requestedType,\n usedDefault: true,\n reason: \"value-missing\",\n };\n }\n\n if (typeof defaultValue === \"string\") {\n return {\n parsedValue: value as T,\n requestedType,\n usedDefault: false,\n reason: \"found-match\",\n };\n }\n\n if (typeof defaultValue === \"boolean\" && configState.type === \"boolean\") {\n const boolValue = parseConfigBoolean(value);\n const hasBoolean = typeof boolValue === \"boolean\";\n return {\n parsedValue: (hasBoolean ? boolValue : defaultValue) as T,\n requestedType,\n usedDefault: !hasBoolean,\n reason: hasBoolean ? \"found-match\" : \"invalid-boolean\",\n };\n }\n\n if (isNumericNativeType(typeof defaultValue) && configState.type === \"integer\") {\n const numValue = parseConfigInteger(value);\n const hasNumber = typeof numValue === \"number\";\n return {\n parsedValue: (hasNumber ? numValue : defaultValue) as T,\n requestedType,\n usedDefault: !hasNumber,\n reason: hasNumber ? \"found-match\" : \"invalid-number\",\n };\n }\n if (isNumericNativeType(typeof defaultValue) && (configState.type === \"float\" || configState.type === \"enum\" )) {\n const numValue = parseConfigFloat(value);\n const hasNumber = typeof numValue === \"number\";\n return {\n parsedValue: (hasNumber ? numValue : defaultValue) as T,\n requestedType,\n usedDefault: !hasNumber,\n reason: hasNumber ? \"found-match\" : \"invalid-number\",\n };\n }\n\n return {\n parsedValue: value as T,\n requestedType,\n usedDefault: false,\n reason: \"found-match\",\n };\n};\n\nconst parseConfigBoolean = (value: string): boolean | undefined => {\n if (!value) {\n return;\n }\n const lowerValue = value.toLowerCase();\n if (lowerValue != \"true\" && lowerValue != \"false\") {\n return;\n }\n return lowerValue === \"true\";\n};\n\nconst parseConfigInteger = (value: string): number | undefined => {\n if (!value) {\n return;\n }\n const num = Number.parseInt(value);\n if (isNaN(num) || !isFinite(num)) {\n return;\n }\n return num;\n};\n\nconst parseConfigFloat = (value: string): number | undefined => {\n if (!value) {\n return;\n }\n const num = Number.parseFloat(value);\n if (isNaN(num) || !isFinite(num)) {\n return;\n }\n return num;\n};\n","import { ConfigDirectorLogger, ConfigDirectorLogMessageDecorator, ConfigDirectorLoggingLevel } from \"./types\";\n\nconst LEVELS: Record<ConfigDirectorLoggingLevel, number> = {\n off: -1,\n error: 0,\n warn: 1,\n info: 2,\n debug: 3,\n};\n\nconst buildDateFormatter = () => {\n const baseOptions: Intl.DateTimeFormatOptions = {\n year: \"numeric\",\n month: \"2-digit\",\n day: \"2-digit\",\n hour: \"2-digit\",\n minute: \"2-digit\",\n second: \"2-digit\",\n timeZoneName: \"short\",\n };\n\n try {\n return new Intl.DateTimeFormat(\n undefined,\n { ...baseOptions, fractionalSecondDigits: 3 } as Intl.DateTimeFormatOptions,\n );\n } catch {\n return new Intl.DateTimeFormat(undefined, baseOptions);\n }\n};\n\nexport class DefaultConsoleLogger implements ConfigDirectorLogger {\n private readonly dateFormatter;\n\n constructor(private readonly level: ConfigDirectorLoggingLevel, private readonly decorator: ConfigDirectorLogMessageDecorator) {\n this.level = level;\n this.decorator = decorator;\n this.dateFormatter = buildDateFormatter();\n }\n\n debug(message: string, ...args: any): void {\n this.log(console.debug, \"debug\", message, ...args);\n }\n\n info(message: string, ...args: any): void {\n this.log(console.info, \"info\", message, ...args);\n }\n\n warn(message: string, ...args: any): void {\n this.log(console.warn, \"warn\", message, ...args);\n }\n\n error(message: string, ...args: any): void {\n this.log(console.error, \"error\", message, ...args);\n }\n\n private log(loggerFunction: (...args: any) => void, level: ConfigDirectorLoggingLevel, message: string, ...args: any) {\n if (LEVELS[this.level] >= LEVELS[level]) {\n loggerFunction(`[${this.dateFormatter.format(new Date())}] ${this.decorator?.decorateMessage(message)}`, ...args);\n }\n }\n}\n\nclass LogMessageDecorator implements ConfigDirectorLogMessageDecorator {\n decorateMessage(message: string): string {\n return `[ConfigDirector:js-client-sdk] ${message}`;\n }\n}\n\nexport const createDefaultLogger = (\n level?: ConfigDirectorLoggingLevel,\n messageDecorator?: ConfigDirectorLogMessageDecorator,\n) => {\n return new DefaultConsoleLogger(level ?? \"warn\", messageDecorator ?? new LogMessageDecorator());\n};\n","import { AggregatedEvent, EventQueueSnapshot, ReportableEvent } from \"./types\";\n\nexport class EventAggregator {\n public aggregate<T extends ReportableEvent>(snapshot: EventQueueSnapshot<T>): AggregatedEvent<T>[] {\n if (snapshot.events.length == 0) {\n return [];\n }\n\n const map = new Map<string, { event: T; count: number }>();\n for (const event of snapshot.events) {\n const serializedEvent = JSON.stringify(event);\n const count = map.get(serializedEvent)?.count || 0;\n map.set(serializedEvent, { event, count: count + 1 });\n }\n return Array.from(map).map(([, v]) => {\n return {\n startTime: snapshot.startTime,\n endTime: snapshot.endTime,\n count: v.count,\n event: v.event,\n };\n });\n }\n}\n","import { EventQueueSnapshot, ReportableEvent } from \"./types\";\n\nexport class EventQueue<T extends ReportableEvent> {\n private readonly limit: number;\n private startTime?: Date;\n private _events: T[] = [];\n private _droppedEventCount = 0;\n\n constructor(limit?: number) {\n this.limit = limit ?? 1_000;\n }\n\n public get events(): T[] {\n return this._events;\n }\n\n public get reachedLimit(): boolean {\n return this._events.length >= this.limit;\n }\n\n public get droppedEventCount(): number {\n return this._droppedEventCount;\n }\n\n public push(...newEvents: T[]) {\n if (!this.startTime) {\n this.startTime = new Date();\n }\n\n const newEventsCountToDrop = Math.max(0, newEvents.length - this.limit);\n const eventsToPush = newEvents.slice(newEventsCountToDrop, newEvents.length);\n this._droppedEventCount += newEventsCountToDrop;\n if (this._events.length + eventsToPush.length > this.limit) {\n const eventCountToDrop = this._events.length + eventsToPush.length - this.limit;\n this._events.splice(0, eventCountToDrop);\n this._droppedEventCount += eventCountToDrop;\n }\n return this._events.push(...eventsToPush);\n }\n\n public takeSnapshot(): EventQueueSnapshot<T> {\n const endTime = new Date();\n const startTime = this.startTime ?? endTime;\n const eventsSnapshot = this._events.splice(0);\n const droppedCount = this._droppedEventCount;\n this.startTime = undefined;\n this._droppedEventCount = 0;\n return {\n startTime,\n endTime,\n events: eventsSnapshot,\n droppedCount,\n };\n }\n\n public clear() {\n this._events = [];\n this.startTime = undefined;\n this._droppedEventCount = 0;\n }\n}\n","import { ConfigDirectorLogger } from \"../types\";\nimport {\n AggregatedEventList,\n DiscreteEventList,\n DroppedEvents,\n EventReport,\n ReporterResponse,\n} from \"./types\";\n\nexport type EventReporterOptions = {\n sdkKey: string;\n logger: ConfigDirectorLogger;\n baseUrl: URL;\n};\n\nexport class EventReporter {\n private readonly sdkKey: string;\n private readonly logger: ConfigDirectorLogger;\n private readonly url: URL;\n private executeRequests = true;\n\n constructor(options: EventReporterOptions) {\n this.sdkKey = options.sdkKey;\n this.logger = options.logger;\n this.url = new URL(\"telemetry/v1\", options.baseUrl);\n }\n\n public report({\n discreteEvents,\n aggregatedEvents,\n droppedEvents,\n }: {\n discreteEvents: DiscreteEventList;\n aggregatedEvents: AggregatedEventList;\n droppedEvents?: DroppedEvents;\n }): ReporterResponse {\n if (!this.executeRequests) {\n return { success: false, fatalError: true };\n }\n\n const eventReport: EventReport = {\n clientSdkKey: this.sdkKey,\n discreteEvents,\n aggregatedEvents,\n droppedEvents,\n };\n if (this.isReportEmpty(eventReport)) {\n return { success: true, fatalError: false };\n }\n\n const response = this.sendReport(eventReport);\n if (response.fatalError) {\n this.executeRequests = false;\n }\n return response;\n }\n\n private isReportEmpty(eventReport: EventReport) {\n return (\n this.isEventListEmpty(eventReport.discreteEvents) &&\n this.isEventListEmpty(eventReport.aggregatedEvents) &&\n this.isDroppedEventsEmpty(eventReport.droppedEvents)\n );\n }\n\n private isDroppedEventsEmpty(droppedEvents?: DroppedEvents): boolean {\n if (!droppedEvents) {\n return true;\n }\n const keys = Object.keys(droppedEvents);\n if (keys.length == 0) {\n return true;\n }\n\n for (const key of keys) {\n if ((droppedEvents[key] ?? 0) > 0) {\n return false;\n }\n }\n\n return true;\n }\n\n private isEventListEmpty<T extends Record<string | symbol, any[]>>(eventList: T): boolean {\n const keys = Object.keys(eventList);\n if (keys.length == 0) {\n return true;\n }\n\n for (const key of keys) {\n if ((eventList[key]?.length ?? 0) > 0) {\n return false;\n }\n }\n\n return true;\n }\n\n private sendReport(eventReport: EventReport): ReporterResponse {\n try {\n const result = navigator.sendBeacon(this.url, JSON.stringify(eventReport));\n return { success: result, fatalError: false };\n } catch (beaconError) {\n this.logger.warn(\n `[EventReporter] Fatal error attempting to send telemetry data: ${beaconError}. No more telemetry data will be sent.`,\n );\n return { success: false, fatalError: true };\n }\n }\n}\n","export const djb2Hash = (data: string): string => {\n const hash = djb2(new TextEncoder().encode(data));\n\treturn hash.toString(16).padStart(8, \"0\");\n};\n\nconst djb2 = (bytes: Uint8Array): number => {\n let hash = 5381;\n\t\tfor (let i = 0; i < bytes.length; i++) {\n\t\t\thash = ((hash << 5) + hash) + bytes[i];\n\t\t\thash = hash >>> 0;\n\t\t}\n return hash;\n};\n","import { ConfigDirectorLogger, ConfigType, ConfigValueType } from \"../types\";\nimport { EventAggregator } from \"./EventAggregator\";\nimport { EventQueue } from \"./EventQueue\";\nimport { EventReporter } from \"./EventReporter\";\nimport { EvaluatedConfigEvent } from \"./telemetry-events\";\nimport { djb2Hash } from \"./utils\";\n\nconst CONFIG_VALUE_MAX_LENGTH = 500;\n\nexport type TelemetryEventCollectorOptions = {\n sdkKey: string;\n logger: ConfigDirectorLogger;\n baseUrl: URL;\n};\n\nexport class TelemetryEventCollector {\n private readonly logger: ConfigDirectorLogger;\n private readonly reporter: EventReporter;\n private evaluationEventQueue: EventQueue<EvaluatedConfigEvent<string>> = new EventQueue();\n private readonly aggregator: EventAggregator = new EventAggregator();\n private flushIntervalDelay: number;\n private flushTimeout: ReturnType<typeof setTimeout>;\n private collectEvents = true;\n\n constructor(options: TelemetryEventCollectorOptions) {\n this.logger = options.logger;\n this.reporter = new EventReporter(options);\n this.flushIntervalDelay = 30_000;\n const initialDelay = 5_000;\n this.flushTimeout = setTimeout(() => this.flushAndScheduleNext(), initialDelay);\n try {\n document.addEventListener(\"visibilitychange\", () => {\n if (document.visibilityState === \"hidden\") {\n this.flush();\n }\n });\n } catch (error) {\n this.logger.warn(\"[TelemetryEventCollector] Could not configure 'visibilitychange' listener: \", error);\n }\n }\n\n public evaluatedConfig<T extends ConfigValueType>(event: EvaluatedConfigEvent<T>): void {\n if (!this.collectEvents) {\n return;\n }\n\n this.evaluationEventQueue.push(this.sanitizeEvaluatedConfigEvent(event));\n }\n\n private sanitizeEvaluatedConfigEvent<T extends ConfigValueType>(\n event: EvaluatedConfigEvent<T>,\n ): EvaluatedConfigEvent<string> {\n return {\n key: event.key,\n type: event.type,\n defaultValue: this.sanitizeValue(event.defaultValue, event.type),\n requestedType: event.requestedType,\n evaluatedValue: this.sanitizeValue(event.evaluatedValue, event.type),\n usedDefault: event.usedDefault,\n evaluationReason: event.evaluationReason,\n };\n }\n\n private sanitizeValue<T extends ConfigValueType>(value: T, type?: ConfigType): string {\n if (type === \"json\") {\n try {\n const json = JSON.stringify(value);\n return djb2Hash(json);\n } catch {\n return value.toString().slice(0, CONFIG_VALUE_MAX_LENGTH);\n }\n }\n\n return value.toString().slice(0, CONFIG_VALUE_MAX_LENGTH);\n }\n\n private flushAndScheduleNext() {\n const response = this.flush();\n if (response.fatalError) {\n this.collectEvents = false;\n this.close();\n this.logger.warn(\n \"[TelemetryEventCollector] Received a fatal error from telemetry collection. No longer collecting events.\",\n );\n } else {\n this.flushTimeout = setTimeout(() => this.flushAndScheduleNext(), this.flushIntervalDelay);\n }\n }\n\n private flush() {\n const evaluationSnapshot = this.evaluationEventQueue.takeSnapshot();\n const response = this.reporter.report({\n discreteEvents: {},\n aggregatedEvents: {\n evaluatedConfig: this.aggregator.aggregate(evaluationSnapshot),\n },\n droppedEvents: {\n evaluatedConfig: evaluationSnapshot.droppedCount,\n },\n });\n return response;\n }\n\n public close() {\n this.collectEvents = false;\n clearTimeout(this.flushTimeout);\n this.flush();\n this.evaluationEventQueue.clear();\n }\n\n public dispose() {\n this.close();\n }\n}\n","import { ConfigDirectorLogger } from \"./types\";\n\nexport const fetchWithTimeout = async (\n timeout: number,\n resource: string | URL | Request,\n options: RequestInit | undefined,\n logger: ConfigDirectorLogger,\n) => {\n const abortController = new AbortController();\n const abortTimeoutId = setTimeout(() => {\n logger.debug(\"[fetchWithTimeout] Reached timeout, aborting request\");\n abortController.abort();\n }, timeout);\n\n try {\n const response = await fetch(resource, {\n ...options,\n signal: abortController.signal,\n });\n clearTimeout(abortTimeoutId);\n return response;\n } catch (error) {\n logger.warn(\"[fetchWithTimeout] Fetch error: \", error);\n clearTimeout(abortTimeoutId);\n throw error;\n }\n};\n","import type {\n ConfigDirectorContext,\n ConfigDirectorLogger,\n Transport,\n TransportEvents,\n TransportOptions,\n} from \"./types\";\nimport { Emitter } from \"./Emitter\";\nimport { ConfigDirectorConnectionError, isFetchErrorFatal } from \"./errors\";\nimport { fetchWithTimeout } from \"./fetchWithTimeout\";\n\nexport class PullTransport implements Transport {\n private logger: ConfigDirectorLogger;\n private eventEmitter = new Emitter<TransportEvents>();\n private url: URL;\n private fatalError = false;\n\n constructor(private readonly options: TransportOptions) {\n this.options = options;\n this.logger = options.logger;\n this.url = new URL(\"pull/v1\", options.baseUrl);\n }\n\n public async connect(context: ConfigDirectorContext, timeout: number): Promise<this> {\n if (this.fatalError) {\n this.logger.warn(\n \"[PullTransport] There was a prior unrecoverable error. Ignoring attempt to reconnect.\",\n );\n return this;\n }\n\n try {\n const response = await fetchWithTimeout(timeout, this.url, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n givenContext: context,\n metaContext: this.options.metaContext,\n clientSdkKey: this.options.clientSdkKey,\n }),\n }, this.logger);\n\n if (!response.ok) {\n if (this.isStatusFatal(response.status)) {\n this.fatalError = true;\n throw this.prepareFatalResponseStatusError(response.status, await response.text());\n } else {\n throw new ConfigDirectorConnectionError(\n `Connection failed with status: ${response.status}`,\n response.status,\n );\n }\n }\n\n const json = JSON.parse(await response.text());\n this.eventEmitter.emit(\"configSetReceived\", json);\n return this;\n } catch (fetchError) {\n if (isFetchErrorFatal(fetchError)) {\n this.fatalError = true;\n throw new ConfigDirectorConnectionError(\n `Connection failed with fatal error: ${fetchError}. This is an unrecoverable error, retry attempts will be ignored.`,\n );\n } else if (fetchError instanceof SyntaxError) {\n throw new ConfigDirectorConnectionError(\n `Failed to parse the response from the server: ${fetchError}`,\n );\n } else {\n throw new ConfigDirectorConnectionError(`Connection failed with error: ${fetchError}.`);\n }\n }\n }\n\n private prepareFatalResponseStatusError(\n responseStatus: number,\n errorBody: string | undefined,\n ): ConfigDirectorConnectionError {\n const status = responseStatus ?? 0;\n const headline = `Connection failed with status: ${responseStatus ?? \"unknown\"}`;\n const serverBody = (errorBody?.trim()?.length ?? 0) > 0 ? ` (${errorBody})` : \"\";\n const message = `${headline}${serverBody}. This is an unrecoverable error, retry attempts will be ignored.`;\n return new ConfigDirectorConnectionError(message, status);\n }\n\n private isStatusFatal(status: number | undefined): boolean {\n return !!status && status >= 400 && status < 500;\n }\n\n public on<TName extends keyof TransportEvents>(\n name: TName,\n handler: (payload: TransportEvents[TName]) => void,\n ): void {\n this.eventEmitter.on(name, handler);\n }\n\n public off<TName extends keyof TransportEvents>(\n name: TName,\n handler?: ((payload: TransportEvents[TName]) => void) | undefined,\n ): void {\n this.eventEmitter.off(name, handler);\n }\n\n public clear(): void {\n this.eventEmitter.clear();\n }\n\n public close() {}\n\n public dispose(): void {\n this.close();\n this.clear();\n }\n}\n","import { Emitter } from \"./Emitter\";\nimport { StreamingTransport } from \"./StreamingTransport\";\nimport { getRequestedType, parseConfigValue } from \"./value-parser\";\nimport {\n ConfigSet,\n ConfigState,\n ConfigStateMap,\n ConfigDirectorContext,\n ConfigDirectorClientOptions,\n ConfigDirectorClient,\n ClientEvents,\n WatchHandler,\n ConfigValueType,\n ConfigDirectorLogger,\n Transport,\n ClientConnectAction,\n} from \"./types\";\nimport { createDefaultLogger } from \"./logger\";\nimport { TelemetryEventCollector } from \"./telemetry\";\nimport { ConfigDirectorValidationError } from \"./errors\";\nimport { PullTransport } from \"./PullTransport\";\n\nconst defaultBaseUrl = new URL(\"https://client-sdk-api.configdirector.com\");\n\ntype WatchHandlerWithOptions<T extends ConfigValueType> = {\n handler: WatchHandler<T>;\n defaultValue: T;\n requestedType: string;\n};\n\nexport class DefaultConfigDirectorClient implements ConfigDirectorClient {\n private logger: ConfigDirectorLogger;\n private usageEventCollector: TelemetryEventCollector;\n private configSet: ConfigSet | undefined;\n private handlersMap: Map<string, WatchHandlerWithOptions<any>[]> = new Map();\n private transport: Transport;\n private eventEmitter = new Emitter<ClientEvents>();\n private timeout: number;\n private ready = false;\n private readyPromise: Promise<void> | undefined;\n private readyResolve: (() => void) | undefined;\n private currentContext?: ConfigDirectorContext;\n private streaming: boolean;\n\n constructor(clientSdkKey: string, clientOptions?: ConfigDirectorClientOptions) {\n this.logger = clientOptions?.logger ?? createDefaultLogger();\n this.timeout = clientOptions?.connection?.timeout ?? 3_000;\n const baseUrl = this.parseUrl(clientOptions?.connection?.url) ?? defaultBaseUrl;\n this.streaming = clientOptions?.connection?.streaming === false ? false : true;\n const transportConstructor = this.streaming ? StreamingTransport : PullTransport;\n this.usageEventCollector = new TelemetryEventCollector({\n sdkKey: clientSdkKey,\n logger: this.logger,\n baseUrl,\n });\n this.transport = new transportConstructor({\n clientSdkKey,\n baseUrl,\n metaContext: {\n ...clientOptions?.metadata,\n sdkName: \"js-client-sdk\",\n sdkVersion: \"__VERSION__\",\n userAgent: navigator?.userAgent,\n },\n logger: this.logger,\n });\n\n this.transport.on(\"configSetReceived\", (configSet: ConfigSet) => {\n this.readyResolve?.();\n const configKeys = Object.keys(configSet.configs);\n if (!this.configSet || configSet.kind == \"full\") {\n this.configSet = configSet;\n this.eventEmitter.emit(\"configsUpdated\", { keys: configKeys });\n this.updateWatchers(configSet.configs);\n } else {\n this.configSet.configs = {\n ...this.configSet.configs,\n ...configSet.configs,\n };\n this.eventEmitter.emit(\"configsUpdated\", { keys: configKeys });\n this.updateWatchers(configSet.configs);\n }\n this.logger.debug(\"[ConfigDirectorClient] ConfigSet updated from server:\", { keys: configKeys });\n });\n }\n\n public async initialize(context?: ConfigDirectorContext) {\n await this.connectToTransport(context, \"initialization\");\n }\n\n public async updateContext(context: ConfigDirectorContext) {\n await this.connectToTransport(context, \"context update\");\n }\n\n private async connectToTransport(context: ConfigDirectorContext | undefined, caller: ClientConnectAction) {\n try {\n this.ready = false;\n this.readyPromise = new Promise<void>((resolve) => {\n this.readyResolve = resolve;\n }).then(() => {\n this.ready = true;\n this.eventEmitter.emit(\"clientReady\", { action: caller });\n this.logger.debug(\"[ConfigDirectorClient] Received initial payload from the server, client is ready\");\n });\n const startTime = new Date().getTime();\n await this.transport.connect(context ?? {}, this.timeout);\n this.currentContext = context;\n const elapsedTime = (new Date().getTime() - startTime);\n const remainingTimeout = this.timeout - elapsedTime;\n if (remainingTimeout > 0) {\n await Promise.race([\n this.readyPromise,\n new Promise<void>((resolve) => {\n setTimeout(() => resolve(), remainingTimeout);\n }),\n ]);\n }\n if (!this.ready) {\n const warningDetails = this.streaming\n ? \"The client will continue to retry since there were no fatal errors detected. Configs will return the default value until the connection succeeds.\"\n : \"Since the client was configured without streaming, configs may not update and always return the default value.\";\n this.logger.warn(\n `[ConfigDirectorClient] Timed out waiting for ${caller} after ${this.timeout}ms. ${warningDetails}`,\n );\n }\n } catch (error) {\n this.logger.error(`[ConfigDirectorClient] An error occurred during ${caller}: `, error);\n }\n }\n\n private updateWatchers(configsMap: ConfigStateMap) {\n Object.values(configsMap).forEach((v) => this.updateWatchersForConfig(v));\n }\n\n private updateWatchersForConfig(configState: ConfigState) {\n this.handlersMap.get(configState.key)?.forEach((h) => {\n const value = this.getValueFromConfigState(configState.key, configState, h.defaultValue);\n h.handler(value);\n });\n }\n\n public watch<T extends ConfigValueType>(configKey: string, defaultValue: T, callback: WatchHandler<T>) {\n this.validateDefaultValue(defaultValue);\n\n const handlers = this.handlersMap.get(configKey);\n const handlerWithOptions = { handler: callback, defaultValue, requestedType: typeof defaultValue };\n if (handlers) {\n handlers.push(handlerWithOptions);\n } else {\n this.handlersMap.set(configKey, [handlerWithOptions]);\n }\n\n return () => this.unwatch(configKey, callback);\n }\n\n public unwatch<T extends ConfigValueType>(configKey: string, callback?: WatchHandler<T>) {\n const handlers = this.handlersMap.get(configKey);\n if (!handlers) {\n return;\n }\n\n if (callback) {\n const index = handlers.findIndex((h) => h.handler == callback);\n if (index >= 0) {\n handlers?.splice(index, 1);\n }\n } else {\n handlers.splice(0);\n }\n }\n\n public getValue<T extends ConfigValueType>(configKey: string, defaultValue: T): T {\n this.validateDefaultValue(defaultValue);\n\n const configState = this.configSet?.configs[configKey];\n return this.getValueFromConfigState(configKey, configState, defaultValue);\n }\n\n private getValueFromConfigState<T extends ConfigValueType>(\n configKey: string,\n configState: ConfigState | undefined,\n defaultValue: T,\n ): T {\n if (!configState) {\n this.logger.debug(\n `[ConfigDirectorClient] No config state found for '${configKey}', returning default value '${defaultValue}'`,\n );\n this.usageEventCollector.evaluatedConfig({\n contextId: this.currentContext?.id,\n key: configKey,\n defaultValue: defaultValue,\n requestedType: getRequestedType(defaultValue),\n evaluatedValue: defaultValue,\n usedDefault: true,\n evaluationReason: \"config-state-missing\",\n });\n return defaultValue;\n }\n\n const parseResult = parseConfigValue<T>(configState, defaultValue);\n this.usageEventCollector.evaluatedConfig({\n contextId: this.currentContext?.id,\n key: configKey,\n defaultValue: defaultValue,\n requestedType: parseResult.requestedType,\n evaluatedValue: parseResult.parsedValue,\n usedDefault: parseResult.usedDefault,\n evaluationReason: parseResult.reason,\n });\n this.logger.debug(`[ConfigDirectorClient] Evaluated '${configKey}' to '${parseResult.parsedValue}'`);\n return parseResult.parsedValue;\n }\n\n private parseUrl(url: string | undefined): URL | undefined {\n if (!url) {\n return;\n }\n\n try {\n return new URL(url);\n } catch (error) {\n throw new ConfigDirectorValidationError(`Invalid base URL '${url}'. Parsing failed: ${error}`);\n }\n }\n\n private validateDefaultValue<T extends ConfigValueType>(defaultValue: T) {\n if (defaultValue === undefined || defaultValue === null) {\n throw new ConfigDirectorValidationError(\n \"Invalid default value. The default value for a config must be defined and non-null.\",\n );\n }\n\n if (typeof defaultValue === \"function\") {\n throw new ConfigDirectorValidationError(\n \"Invalid default value. The default value for a config cannot be a function.\",\n );\n }\n }\n\n public get isReady(): boolean {\n return this.ready;\n }\n\n public on<T extends keyof ClientEvents>(eventName: T, handler: (event: ClientEvents[T]) => void): void {\n this.eventEmitter.on(eventName, handler);\n }\n\n public off<T extends keyof ClientEvents>(eventName: T, handler?: (payload: ClientEvents[T]) => void) {\n this.eventEmitter.off(eventName, handler);\n }\n\n public clear() {\n this.logger.debug(\"[ConfigDirectorClient] clear() has been called, removing all observers\");\n this.eventEmitter.clear();\n this.handlersMap.clear();\n }\n\n public unwatchAll() {\n this.handlersMap.clear();\n }\n\n public close() {\n this.logger.debug(\"[ConfigDirectorClient] close() has been called, closing connection to server\");\n this.transport.close();\n this.ready = false;\n }\n\n public dispose() {\n this.clear();\n this.close();\n }\n}\n","import { DefaultConfigDirectorClient } from \"./DefaultConfigDirectorClient\";\nimport { createDefaultLogger } from \"./logger\";\nimport {\n ConfigDirectorClientOptions,\n ConfigDirectorClient,\n ConfigDirectorLoggingLevel,\n ConfigDirectorLogMessageDecorator,\n} from \"./types\";\n\nexport type {\n ConfigDirectorClient,\n ConfigDirectorClientOptions,\n ConfigDirectorContext,\n ConfigValueType,\n ConfigDirectorLogger,\n ConfigDirectorLoggingLevel,\n ConfigDirectorLogMessageDecorator,\n} from \"./types\";\n\nexport type { ConfigDirectorConnectionError, ConfigDirectorValidationError } from \"./errors\";\n\n/**\n * Creates a `ConfigDirectorClient` object with the given `clientSdkKey` and optional\n * `clientOptions`. The returned client needs to be initialized before it is ready to serve\n * config values.\n *\n * @param clientSdkKey The client SDK key obtained from the ConfigDirector dashboard\n * @param clientOptions {@link ConfigDirectorClientOptions} options for the client (optional)\n * @returns A {@link ConfigDirectorClient} object\n *\n * @example\n * import { createClient } from \"@configdirector/client-sdk\";\n * const client = createClient(\"YOUR-SDK-KEY\");\n * await client.initialize();\n */\nexport const createClient = (\n clientSdkKey: string,\n clientOptions?: ConfigDirectorClientOptions,\n): ConfigDirectorClient => {\n return new DefaultConfigDirectorClient(clientSdkKey, clientOptions);\n};\n\nexport const createConsoleLogger = (\n level: ConfigDirectorLoggingLevel,\n messageDecorator?: ConfigDirectorLogMessageDecorator,\n) => {\n return createDefaultLogger(level, messageDecorator);\n};\n"],"names":["extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","__extends","TypeError","String","__","this","constructor","create","__assign","assign","t","s","i","n","arguments","length","apply","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","__generator","body","f","y","_","label","sent","trys","ops","g","Iterator","verb","Symbol","iterator","v","op","pop","push","__spreadArray","to","from","pack","ar","l","slice","concat","SuppressedError","Emitter","handlerMap","Map","on","name","handler","handlers","get","set","once","self","onceHandler","payload","off","listenerIndex","indexOf","splice","clear","emit","map","h","ParseError","Error","message","options","super","type","field","line","noop","_arg","createParser","callbacks","onEvent","onError","onRetry","onComment","id","incompleteLine","isFirstChunk","data","eventType","parseLine","event","endsWith","startsWith","fieldSeparatorIndex","offset","processField","includes","test","parseInt","feed","newChunk","chunk","replace","complete","incomplete","lines","searchIndex","crIndex","lfIndex","lineEnd","Math","min","splitLines","reset","consume","CONNECTING","CLOSED","createEventSource$1","optionsOrUrl","getStream","getStream2","URL","url","onMessage","onConnect","onDisconnect","onScheduleReconnect","fetch","initialLastEventId","globalThis","isFetchLike","AbortController","validate","requestHeaders","headers","onCloseSubscribers","subscribers","parser","msg","lastEventId","forEach","fn","ms","reconnectMs","request","reconnectTimer","currentUrl","toString","controller","readyState","connect","close","asyncIterator","pullQueue","pushQueue","pushValue","shift","unsubscribe","return","throw","error","mode","credentials","method","redirect","referrer","referrerPolicy","Accept","cache","signal","getRequestOptions","onFetchResponse","catch","err","aborted","scheduleReconnect","abort","clearTimeout","delay","setTimeout","async","response","redirected","status","stream","decoder","TextDecoder","reader","getReader","open","read","decode","defaultAbstractions","ReadableStream","ConfigDirectorConnectionError","_super","_this","ConfigDirectorValidationError","StreamingTransport","eventEmitter","logger","baseUrl","context","timeout","eventSource","responseStatus","undefined","errorBody","customFetch","init","_a","ok","text","eventSourcePromise","JSON","stringify","givenContext","metaContext","clientSdkKey","dispatchMessage","isStatusFatal","prepareFatalError","debug","info","warn","race","json","parse","headline","serverBody","_b","trim","dispose","getRequestedType","defaultValue","baseType","_c","functionName","_d","isNumericNativeType","requestedType","parseConfigBoolean","lowerValue","toLowerCase","parseConfigInteger","num","Number","isNaN","isFinite","parseConfigFloat","parseFloat","LEVELS","DefaultConsoleLogger","level","decorator","dateFormatter","baseOptions","year","month","day","hour","minute","second","timeZoneName","Intl","DateTimeFormat","fractionalSecondDigits","buildDateFormatter","args","_i","log","console","loggerFunction","format","Date","decorateMessage","LogMessageDecorator","createDefaultLogger","messageDecorator","EventAggregator","aggregate","snapshot","events","event_1","serializedEvent","count","startTime","endTime","EventQueue","limit","_events","_droppedEventCount","defineProperty","newEvents","newEventsCountToDrop","max","eventsToPush","eventCountToDrop","takeSnapshot","eventsSnapshot","droppedCount","EventReporter","executeRequests","sdkKey","report","discreteEvents","aggregatedEvents","droppedEvents","success","fatalError","eventReport","isReportEmpty","sendReport","isEventListEmpty","isDroppedEventsEmpty","keys","keys_1","eventList","keys_2","navigator","sendBeacon","beaconError","djb2","bytes","hash","TelemetryEventCollector","evaluationEventQueue","aggregator","collectEvents","reporter","flushIntervalDelay","flushTimeout","flushAndScheduleNext","document","addEventListener","visibilityState","flush","evaluatedConfig","sanitizeEvaluatedConfigEvent","key","sanitizeValue","evaluatedValue","usedDefault","evaluationReason","TextEncoder","encode","padStart","evaluationSnapshot","fetchWithTimeout","resource","abortController","abortTimeoutId","error_1","PullTransport","_e","prepareFatalResponseStatusError","fetchError","DOMException","isFetchErrorFatal","fetchError_1","SyntaxError","defaultBaseUrl","DefaultConfigDirectorClient","clientOptions","handlersMap","ready","connection","parseUrl","streaming","_f","transportConstructor","usageEventCollector","transport","metadata","sdkName","sdkVersion","userAgent","configSet","readyResolve","configKeys","configs","kind","updateWatchers","initialize","connectToTransport","updateContext","caller","readyPromise","action","getTime","currentContext","elapsedTime","remainingTimeout_1","warningDetails","configsMap","values","updateWatchersForConfig","configState","getValueFromConfigState","watch","configKey","callback","validateDefaultValue","handlerWithOptions","unwatch","index","findIndex","getValue","contextId","parseResult","numValue","hasNumber","parsedValue","reason","boolValue","hasBoolean","parseConfigValue","eventName","unwatchAll"],"mappings":"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","x_google_ignoreList":[0,2,3]}