Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@harnessio/ff-javascript-client-sdk

Package Overview
Dependencies
Maintainers
6
Versions
113
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@harnessio/ff-javascript-client-sdk - npm Package Compare versions

Comparing version 1.17.1-rc.2 to 1.17.1-rc.3

2

dist/sdk.cjs.js

@@ -1,1 +0,1 @@

var we=Object.create;var x=Object.defineProperty,Ce=Object.defineProperties,Ae=Object.getOwnPropertyDescriptor,Oe=Object.getOwnPropertyDescriptors,Fe=Object.getOwnPropertyNames,ae=Object.getOwnPropertySymbols,xe=Object.getPrototypeOf,oe=Object.prototype.hasOwnProperty,Ve=Object.prototype.propertyIsEnumerable;var re=(n,e,a)=>e in n?x(n,e,{enumerable:!0,configurable:!0,writable:!0,value:a}):n[e]=a,T=(n,e)=>{for(var a in e||(e={}))oe.call(e,a)&&re(n,a,e[a]);if(ae)for(var a of ae(e))Ve.call(e,a)&&re(n,a,e[a]);return n},U=(n,e)=>Ce(n,Oe(e));var ke=(n,e)=>{for(var a in e)x(n,a,{get:e[a],enumerable:!0})},se=(n,e,a,l)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Fe(e))!oe.call(n,o)&&o!==a&&x(n,o,{get:()=>e[o],enumerable:!(l=Ae(e,o))||l.enumerable});return n};var le=(n,e,a)=>(a=n!=null?we(xe(n)):{},se(e||!n||!n.__esModule?x(a,"default",{value:n,enumerable:!0}):a,n)),Ne=n=>se(x({},"__esModule",{value:!0}),n);var C=(n,e,a)=>new Promise((l,o)=>{var f=b=>{try{S(a.next(b))}catch(c){o(c)}},v=b=>{try{S(a.throw(b))}catch(c){o(c)}},S=b=>b.done?l(b.value):Promise.resolve(b.value).then(f,v);S((a=a.apply(n,e)).next())});var $e={};ke($e,{Event:()=>M,initialize:()=>Le});module.exports=Ne($e);var me=le(require("jwt-decode")),Ee=le(require("mitt"));var M=(h=>(h.READY="ready",h.CONNECTED="connected",h.DISCONNECTED="disconnected",h.FLAGS_LOADED="flags loaded",h.CACHE_LOADED="cache loaded",h.CHANGED="changed",h.ERROR="error",h.ERROR_METRICS="metrics error",h.ERROR_AUTH="auth error",h.ERROR_FETCH_FLAGS="fetch flags error",h.ERROR_FETCH_FLAG="fetch flag error",h.ERROR_STREAM="stream error",h))(M||{});var _e={debug:!1,baseUrl:"https://config.ff.harness.io/api/1.0",eventUrl:"https://events.ff.harness.io/api/1.0",eventsSyncInterval:6e4,pollingInterval:6e4,streamEnabled:!0,allAttributesPrivate:!1,privateAttributeNames:[],cache:!1},ce=n=>{let e=T(T({},_e),n);return e.pollingEnabled===void 0&&(e.pollingEnabled=e.streamEnabled),e},y=(n,...e)=>console.error(`[FF-SDK] ${n}`,...e),j=(n,e=!0)=>{e?setTimeout(n,0):n()},P=(n,e)=>Math.round(Math.random()*(e-n)+n);function W(n){return"HARNESS_FF_CACHE_"+n}function H(n,e={}){let a=W(n),l=parseInt(window.localStorage.getItem(a+".ts"));if(e!=null&&e.ttl&&!isNaN(l)&&l+e.ttl<Date.now())return Me(n),[];let o=window.localStorage.getItem(a);if(o)try{return JSON.parse(o)}catch(f){}return[]}function L(n,e){let a=W(n);window.localStorage.setItem(a,JSON.stringify(e)),window.localStorage.setItem(a+".ts",Date.now().toString())}function de(n,e){let a=H(n),l=a.find(({flag:o})=>o===e.flag);l?Object.assign(l,e):a.push(e),L(n,a)}function ue(n,e){let a=H(n),l=a.findIndex(({flag:o})=>o===e);l>-1&&(a.splice(l,1),L(n,a))}function Me(n){let e=W(n);window.localStorage.removeItem(e),window.localStorage.removeItem(e+".ts")}function J(n){return function(...a){let[l,o]=n(a);return fetch(l,o)}}var fe=3e4,$=class{constructor(e,a,l,o,f,v,S){this.closed=!1;this.eventBus=e,this.configurations=a,this.url=l,this.apiKey=o,this.standardHeaders=f,this.eventCallback=S,this.fallbackPoller=v}start(){let e=c=>{c.toString().split(/\r?\n/).forEach(a)},a=c=>{if(c.startsWith("data:")){let D=JSON.parse(c.substring(5));this.logDebug("Received event from stream: ",D),this.eventCallback(D)}},l=()=>{this.logDebug("Stream connected"),this.eventBus.emit("connected")},o=()=>{clearInterval(this.readTimeoutCheckerId);let c=P(1e3,1e4);this.logDebug("Stream disconnected, will reconnect in "+c+"ms"),this.eventBus.emit("disconnected"),setTimeout(()=>this.start(),c)},f=c=>{c&&y("Stream has issue",c),this.fallBackToPolling(),this.eventBus.emit("stream error",c),this.eventBus.emit("error",c),o()},v=T({"Cache-Control":"no-cache",Accept:"text/event-stream","API-Key":this.apiKey},this.standardHeaders);this.logDebug("SSE HTTP start request",this.url),this.xhr=new XMLHttpRequest,this.xhr.open("GET",this.url);for(let[c,D]of Object.entries(v))this.xhr.setRequestHeader(c,D);this.xhr.timeout=24*60*60*1e3,this.xhr.onerror=()=>{f("XMLHttpRequest error on SSE stream")},this.xhr.onabort=()=>{this.logDebug("SSE aborted"),this.closed||f(null)},this.xhr.ontimeout=()=>{f("SSE timeout")},this.xhr.onload=()=>{if(this.xhr.status>=400&&this.xhr.status<=599){f(`HTTP code ${this.xhr.status}`);return}l()};let S=0,b=Date.now();this.xhr.onprogress=()=>{this.stopFallBackPolling(),b=Date.now();let c=this.xhr.responseText.slice(S);S+=c.length,this.logDebug("SSE GOT: "+c),e(c)},this.readTimeoutCheckerId=setInterval(()=>{b<Date.now()-fe&&(y("SSE read timeout"),this.xhr.abort())},fe),this.xhr.send()}close(){this.closed=!0,this.xhr&&this.xhr.abort(),clearInterval(this.readTimeoutCheckerId),this.stopFallBackPolling()}fallBackToPolling(){!this.fallbackPoller.isPolling()&&this.configurations.pollingEnabled&&(this.logDebug("Falling back to polling mode while stream recovers"),this.fallbackPoller.start())}stopFallBackPolling(){this.fallbackPoller.isPolling()&&(this.logDebug("Stopping fallback polling mode"),this.fallbackPoller.stop())}logDebug(e,...a){this.configurations.debug&&console.debug(`[FF-SDK] Streaming: ${e}`,...a)}};function ge(n,e,a,l,o){let f=n in a,v=f?a[n]:e;return f&&l(n,v),o?{value:v,isDefaultValue:!f}:v}var V=class{constructor(e,a){this.fetchFlagsFn=e;this.configurations=a;this.maxAttempts=5}start(){if(this.isPolling()){this.logDebug("Already polling.");return}this.isRunning=!0,this.logDebug(`Starting poller, first poll will be in ${this.configurations.pollingInterval}ms`),this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)}poll(){this.attemptFetch().finally(()=>{this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)})}attemptFetch(){return C(this,null,function*(){for(let e=1;e<=this.maxAttempts;e++){let a=yield this.fetchFlagsFn();if(!a){this.logDebug(`Successfully polled for flag updates, next poll in ${this.configurations.pollingInterval}ms. `);return}if(y("Error when polling for flag updates",a),e>=this.maxAttempts){this.logDebug(`Maximum attempts reached for polling for flags. Next poll in ${this.configurations.pollingInterval}ms.`);return}this.logDebug(`Polling for flags attempt #${e} failed. Remaining attempts: ${this.maxAttempts-e}`,a);let l=P(1e3,1e4);yield new Promise(o=>setTimeout(o,l))}})}stop(){this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=void 0,this.isRunning=!1,this.logDebug("Polling stopped"))}isPolling(){return this.isRunning}logDebug(e,...a){this.configurations.debug&&console.debug(`[FF-SDK] Poller: ${e}`,...a)}};var be="1.16.0",pe=`Javascript ${be} Client`,Pe=500,He=globalThis.fetch,Y=!!globalThis.Proxy,X=n=>{let{value:e}=n;try{switch(n.kind.toLowerCase()){case"int":case"number":e=Number(e);break;case"boolean":e=e.toString().toLowerCase()==="true";break;case"json":e=JSON.parse(e);break}}catch(a){y(a)}return e},Le=(n,e,a)=>{let l=!1,o,f,v,S,b,c,D=!0,F={},h=J(t=>t),z=0,Q=!1,k=()=>{D=!1},N=()=>{D=!0},R=[],d=(0,Ee.default)(),u=ce(a);u.eventsSyncInterval<6e4&&(u.eventsSyncInterval=6e4),u.pollingInterval<6e4&&(u.pollingInterval=6e4);let E=(t,...i)=>{u.debug&&console.debug(`[FF-SDK] ${t}`,...i)},G=t=>{if(D){let i=Date.now();i-t.lastAccessed>Pe&&(t.count++,t.lastAccessed=i)}};globalThis.onbeforeunload=()=>{R.length&&globalThis.localStorage&&(k(),globalThis.localStorage.HARNESS_FF_METRICS=JSON.stringify(R),N())};let Re=(t,i)=>C(void 0,null,function*(){return(yield(yield He(`${i.baseUrl}/client/auth`,{method:"POST",headers:{"Content-Type":"application/json","Harness-SDK-Info":pe},body:JSON.stringify({apiKey:t,target:U(T({},e),{identifier:String(e.identifier)})})})).json()).authToken}),B=0,K=()=>{if(R.length){E("Sending metrics...",{metrics:R,evaluations:I});let t={metricsData:R.map(i=>({timestamp:Date.now(),count:i.count,metricsType:"FFMETRICS",attributes:[{key:"featureIdentifier",value:i.featureIdentifier},{key:"featureName",value:i.featureIdentifier},{key:"variationIdentifier",value:i.variationIdentifier},{key:"target",value:e.identifier},{key:"SDK_NAME",value:"JavaScript"},{key:"SDK_LANGUAGE",value:"JavaScript"},{key:"SDK_TYPE",value:"client"},{key:"SDK_VERSION",value:be}]}))};h(`${u.eventUrl}/metrics/${o}?cluster=${f}`,{method:"POST",headers:T({"Content-Type":"application/json"},F),body:JSON.stringify(t)}).then(()=>{R=[],B=0}).catch(i=>{B++&&(R=[],B=0),E(i),d.emit("metrics error",i)}).finally(()=>{c=window.setTimeout(K,u.eventsSyncInterval)})}else c=window.setTimeout(K,u.eventsSyncInterval)},I={},Se=t=>{E("Sending event for",t.flag),Y?d.emit("changed",new Proxy(t,{get(i,s){var p;if(D&&i.hasOwnProperty(s)&&s==="value"){let m=i.flag,r=t.value,g=R.find(O=>O.featureIdentifier===m&&O.featureValue===r);g?(G(g),g.variationIdentifier=((p=I[m])==null?void 0:p.identifier)||""):R.push({featureIdentifier:m,featureValue:String(r),variationIdentifier:I[m].identifier||"",count:1,lastAccessed:Date.now()}),E("Metrics event: Flag",s,"has been read with value via stream update",r)}return s==="value"?X(t):t[s]}})):d.emit("changed",{deleted:t.deleted,flag:t.flag,value:X(t)})},Z=function(){return Y?new Proxy({},{get(t,i){var p,m,r;let s=t[i];if(D&&t.hasOwnProperty(i)){let g=t[i],O=R.find(ne=>ne.featureIdentifier===i&&g===ne.featureValue);O?(O.variationIdentifier=((p=I[i])==null?void 0:p.identifier)||"",G(O)):R.push({featureIdentifier:i,featureValue:g,variationIdentifier:((m=I[i])==null?void 0:m.identifier)||"",count:1,lastAccessed:Date.now()}),E("Metrics event: Flag:",i,"has been read with value:",g,"variationIdentifier:",(r=I[i])==null?void 0:r.identifier)}return s}}):{}},w=Z();Re(n,u).then(t=>C(void 0,null,function*(){if(l)return;b=t;let i=(0,me.default)(t);if(F={Authorization:`Bearer ${b}`,"Harness-AccountID":i.accountID,"Harness-EnvironmentID":i.environmentIdentifier,"Harness-SDK-Info":pe},E("Authenticated",i),globalThis.localStorage&&globalThis.localStorage.HARNESS_FF_METRICS)try{delete globalThis.localStorage.HARNESS_FF_METRICS,E("Picking up metrics from previous session")}catch(m){}c=window.setTimeout(K,u.eventsSyncInterval),o=i.environment,f=i.clusterIdentifier;let s=!!Object.keys(I).length;if((yield _())||E("Fetch all flags ok",w),!l){if(u.streamEnabled?(E("Streaming mode enabled"),Ie()):u.pollingEnabled?(E("Polling mode enabled"),ye()):E("Streaming and polling mode disabled"),!s){k();let m=T({},w);N(),d.emit("ready",m)}Q=!0}})).catch(t=>{y("Authentication error: ",t),d.emit("auth error",t),d.emit("error",t)});let _=()=>C(void 0,null,function*(){try{let t=yield h(`${u.baseUrl}/client/env/${o}/target/${e.identifier}/evaluations?cluster=${f}`,{headers:F});if(t.ok){let i=yield t.json();i.forEach(A),d.emit("flags loaded",i)}else y("Features fetch operation error: ",t),d.emit("fetch flags error",t),d.emit("error",t)}catch(t){return y("Features fetch operation error: ",t),d.emit("fetch flags error",t),d.emit("error",t),t}}),ee=t=>C(void 0,null,function*(){try{let i=yield h(`${u.baseUrl}/client/env/${o}/target/${e.identifier}/evaluations/${t}?cluster=${f}`,{headers:F});if(i.ok){let s=yield i.json();A(s)}else y("Feature fetch operation error: ",i),d.emit("fetch flag error",i),d.emit("error",i)}catch(i){y("Feature fetch operation error: ",i),d.emit("fetch flag error",i),d.emit("error",i)}}),A=t=>{k();let i=X(t);i!==w[t.flag]&&(E("Flag variation has changed for ",t.identifier),w[t.flag]=i,I[t.flag]=U(T({},t),{value:i}),Se(t)),N()};S=new V(_,u);let Ie=()=>{let t=r=>{switch(r.event){case"create":s(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):setTimeout(()=>ee(r.identifier),1e3);break;case"patch":s(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):ee(r.identifier);break;case"delete":delete w[r.identifier],d.emit("changed",{flag:r.identifier,value:void 0,deleted:!0}),E("Evaluation deleted",{message:r,storage:w});break}},i=r=>!(!r||!r.flag||!r.identifier||!r.kind||!r.value),s=r=>!(!r||r.length==0||!r.every(g=>i(g))),p=r=>{r.event==="patch"&&(s(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):_())},m=`${u.baseUrl}/stream?cluster=${f}`;v=new $(d,u,m,n,F,S,r=>{r.domain==="flag"?t(r):r.domain==="target-segment"&&p(r)}),v.start()},ye=()=>{S.start()},q=(t,i)=>d.on(t,i),De=(t,i)=>{t?d.off(t,i):te()},Te=(t,i)=>{var r;if(!D||Y||i===void 0)return;let s=i,p=t,m=R.find(g=>g.featureIdentifier===p&&g.featureValue===s);m?(G(m),m.variationIdentifier=((r=I[p])==null?void 0:r.identifier)||""):R.push({featureIdentifier:p,featureValue:s,count:1,variationIdentifier:I[p].identifier||"",lastAccessed:Date.now()})},te=()=>{l=!0,E("Closing event stream"),w=Z(),I={},clearTimeout(c),d.all.clear(),typeof(v==null?void 0:v.close)=="function"&&v.close()},ie=(t,i=!0)=>{t.length&&j(()=>{let s=!!Object.keys(I).length;if(t.forEach(A),!s){k();let p=T({},w);N(),d.emit("ready",p)}},i)};if(u.cache&&"localStorage"in window){let t=!0,i=H(e.identifier,typeof u.cache=="boolean"?{}:u.cache);i!=null&&i.length&&j(()=>{E("loading from cache",i),ie(i,!1),d.emit("cache loaded",i)}),q("flags loaded",s=>{L(e.identifier,s),t=!1}),q("changed",s=>{t||(s.deleted?ue(e.identifier,s.flag):de(e.identifier,s))})}return{on:q,off:De,close:te,setEvaluations:ie,registerAPIRequestMiddleware:t=>{h=J(t)},refreshEvaluations:()=>{Q&&!l&&Date.now()-z>=6e4&&(_(),z=Date.now())},variation:(t,i,s=!1)=>ge(t,i,w,Te,s)}};0&&(module.exports={Event,initialize});
var we=Object.create;var x=Object.defineProperty,Ce=Object.defineProperties,Ae=Object.getOwnPropertyDescriptor,Oe=Object.getOwnPropertyDescriptors,Fe=Object.getOwnPropertyNames,ae=Object.getOwnPropertySymbols,xe=Object.getPrototypeOf,oe=Object.prototype.hasOwnProperty,Ve=Object.prototype.propertyIsEnumerable;var re=(n,e,a)=>e in n?x(n,e,{enumerable:!0,configurable:!0,writable:!0,value:a}):n[e]=a,T=(n,e)=>{for(var a in e||(e={}))oe.call(e,a)&&re(n,a,e[a]);if(ae)for(var a of ae(e))Ve.call(e,a)&&re(n,a,e[a]);return n},U=(n,e)=>Ce(n,Oe(e));var ke=(n,e)=>{for(var a in e)x(n,a,{get:e[a],enumerable:!0})},se=(n,e,a,l)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Fe(e))!oe.call(n,o)&&o!==a&&x(n,o,{get:()=>e[o],enumerable:!(l=Ae(e,o))||l.enumerable});return n};var le=(n,e,a)=>(a=n!=null?we(xe(n)):{},se(e||!n||!n.__esModule?x(a,"default",{value:n,enumerable:!0}):a,n)),Ne=n=>se(x({},"__esModule",{value:!0}),n);var C=(n,e,a)=>new Promise((l,o)=>{var f=R=>{try{b(a.next(R))}catch(c){o(c)}},v=R=>{try{b(a.throw(R))}catch(c){o(c)}},b=R=>R.done?l(R.value):Promise.resolve(R.value).then(f,v);b((a=a.apply(n,e)).next())});var $e={};ke($e,{Event:()=>M,initialize:()=>Le});module.exports=Ne($e);var me=le(require("jwt-decode")),Ee=le(require("mitt"));var M=(h=>(h.READY="ready",h.CONNECTED="connected",h.DISCONNECTED="disconnected",h.FLAGS_LOADED="flags loaded",h.CACHE_LOADED="cache loaded",h.CHANGED="changed",h.ERROR="error",h.ERROR_METRICS="metrics error",h.ERROR_AUTH="auth error",h.ERROR_FETCH_FLAGS="fetch flags error",h.ERROR_FETCH_FLAG="fetch flag error",h.ERROR_STREAM="stream error",h))(M||{});var _e={debug:!1,baseUrl:"https://config.ff.harness.io/api/1.0",eventUrl:"https://events.ff.harness.io/api/1.0",eventsSyncInterval:6e4,pollingInterval:6e4,streamEnabled:!0,allAttributesPrivate:!1,privateAttributeNames:[],cache:!1},ce=n=>{let e=T(T({},_e),n);return e.pollingEnabled===void 0&&(e.pollingEnabled=e.streamEnabled),e},y=(n,...e)=>console.error(`[FF-SDK] ${n}`,...e),j=(n,e=!0)=>{e?setTimeout(n,0):n()},P=(n,e)=>Math.round(Math.random()*(e-n)+n);function W(n){return"HARNESS_FF_CACHE_"+n}function H(n,e={}){let a=W(n),l=parseInt(window.localStorage.getItem(a+".ts"));if(e!=null&&e.ttl&&!isNaN(l)&&l+e.ttl<Date.now())return Me(n),[];let o=window.localStorage.getItem(a);if(o)try{return JSON.parse(o)}catch(f){}return[]}function L(n,e){let a=W(n);window.localStorage.setItem(a,JSON.stringify(e)),window.localStorage.setItem(a+".ts",Date.now().toString())}function de(n,e){let a=H(n),l=a.find(({flag:o})=>o===e.flag);l?Object.assign(l,e):a.push(e),L(n,a)}function ue(n,e){let a=H(n),l=a.findIndex(({flag:o})=>o===e);l>-1&&(a.splice(l,1),L(n,a))}function Me(n){let e=W(n);window.localStorage.removeItem(e),window.localStorage.removeItem(e+".ts")}function J(n){return function(...a){let[l,o]=n(a);return fetch(l,o)}}var fe=3e4,$=class{constructor(e,a,l,o,f,v,b){this.closed=!1;this.eventBus=e,this.configurations=a,this.url=l,this.apiKey=o,this.standardHeaders=f,this.eventCallback=b,this.fallbackPoller=v}start(){let e=c=>{c.toString().split(/\r?\n/).forEach(a)},a=c=>{if(c.startsWith("data:")){let D=JSON.parse(c.substring(5));this.logDebug("Received event from stream: ",D),this.eventCallback(D)}},l=()=>{this.logDebug("Stream connected"),this.eventBus.emit("connected")},o=()=>{clearInterval(this.readTimeoutCheckerId);let c=P(1e3,1e4);this.logDebug("Stream disconnected, will reconnect in "+c+"ms"),this.eventBus.emit("disconnected"),setTimeout(()=>this.start(),c)},f=c=>{c&&y("Stream has issue",c),this.fallBackToPolling(),this.eventBus.emit("stream error",c),this.eventBus.emit("error",c),o()},v=T({"Cache-Control":"no-cache",Accept:"text/event-stream","API-Key":this.apiKey},this.standardHeaders);this.logDebug("SSE HTTP start request",this.url),this.xhr=new XMLHttpRequest,this.xhr.open("GET",this.url);for(let[c,D]of Object.entries(v))this.xhr.setRequestHeader(c,D);this.xhr.timeout=24*60*60*1e3,this.xhr.onerror=()=>{f("XMLHttpRequest error on SSE stream")},this.xhr.onabort=()=>{this.logDebug("SSE aborted"),this.closed||f(null)},this.xhr.ontimeout=()=>{f("SSE timeout")},this.xhr.onload=()=>{if(this.xhr.status>=400&&this.xhr.status<=599){f(`HTTP code ${this.xhr.status}`);return}l()};let b=0,R=Date.now();this.xhr.onprogress=()=>{this.stopFallBackPolling(),R=Date.now();let c=this.xhr.responseText.slice(b);b+=c.length,this.logDebug("SSE GOT: "+c),e(c)},this.readTimeoutCheckerId=setInterval(()=>{R<Date.now()-fe&&(y("SSE read timeout"),this.xhr.abort())},fe),this.xhr.send()}close(){this.closed=!0,this.xhr&&this.xhr.abort(),clearInterval(this.readTimeoutCheckerId),this.stopFallBackPolling()}fallBackToPolling(){!this.fallbackPoller.isPolling()&&this.configurations.pollingEnabled&&(this.logDebug("Falling back to polling mode while stream recovers"),this.fallbackPoller.start())}stopFallBackPolling(){this.fallbackPoller.isPolling()&&(this.logDebug("Stopping fallback polling mode"),this.fallbackPoller.stop())}logDebug(e,...a){this.configurations.debug&&console.debug(`[FF-SDK] Streaming: ${e}`,...a)}};function ge(n,e,a,l,o){let f=n in a,v=f?a[n]:e;return f&&l(n,v),o?{value:v,isDefaultValue:!f}:v}var V=class{constructor(e,a){this.fetchFlagsFn=e;this.configurations=a;this.maxAttempts=5}start(){if(this.isPolling()){this.logDebug("Already polling.");return}this.isRunning=!0,this.logDebug(`Starting poller, first poll will be in ${this.configurations.pollingInterval}ms`),this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)}poll(){this.attemptFetch().finally(()=>{this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)})}attemptFetch(){return C(this,null,function*(){for(let e=1;e<=this.maxAttempts;e++){let a=yield this.fetchFlagsFn();if(!a){this.logDebug(`Successfully polled for flag updates, next poll in ${this.configurations.pollingInterval}ms. `);return}if(y("Error when polling for flag updates",a),e>=this.maxAttempts){this.logDebug(`Maximum attempts reached for polling for flags. Next poll in ${this.configurations.pollingInterval}ms.`);return}this.logDebug(`Polling for flags attempt #${e} failed. Remaining attempts: ${this.maxAttempts-e}`,a);let l=P(1e3,1e4);yield new Promise(o=>setTimeout(o,l))}})}stop(){this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=void 0,this.isRunning=!1,this.logDebug("Polling stopped"))}isPolling(){return this.isRunning}logDebug(e,...a){this.configurations.debug&&console.debug(`[FF-SDK] Poller: ${e}`,...a)}};var be="1.16.0",pe=`Javascript ${be} Client`,Pe=500,He=globalThis.fetch,Y=!!globalThis.Proxy,X=n=>{let{value:e}=n;try{switch(n.kind.toLowerCase()){case"int":case"number":e=Number(e);break;case"boolean":e=e.toString().toLowerCase()==="true";break;case"json":e=JSON.parse(e);break}}catch(a){y(a)}return e},Le=(n,e,a)=>{let l=!1,o,f,v,b,R,c,D=!0,F={},h=J(t=>t),z=0,Q=!1,k=()=>{D=!1},N=()=>{D=!0},S=[],d=(0,Ee.default)(),u=ce(a);u.eventsSyncInterval<6e4&&(u.eventsSyncInterval=6e4),u.pollingInterval<6e4&&(u.pollingInterval=6e4);let p=(t,...i)=>{u.debug&&console.debug(`[FF-SDK] ${t}`,...i)},G=t=>{if(D){let i=Date.now();i-t.lastAccessed>Pe&&(t.count++,t.lastAccessed=i)}};globalThis.onbeforeunload=()=>{S.length&&globalThis.localStorage&&(k(),globalThis.localStorage.HARNESS_FF_METRICS=JSON.stringify(S),N())};let Re=(t,i)=>C(void 0,null,function*(){return(yield(yield He(`${i.baseUrl}/client/auth`,{method:"POST",headers:{"Content-Type":"application/json","Harness-SDK-Info":pe},body:JSON.stringify({apiKey:t,target:U(T({},e),{identifier:String(e.identifier)})})})).json()).authToken}),B=0,K=()=>{if(S.length){p("Sending metrics...",{metrics:S,evaluations:I});let t={metricsData:S.map(i=>({timestamp:Date.now(),count:i.count,metricsType:"FFMETRICS",attributes:[{key:"featureIdentifier",value:i.featureIdentifier},{key:"featureName",value:i.featureIdentifier},{key:"variationIdentifier",value:i.variationIdentifier},{key:"target",value:e.identifier},{key:"SDK_NAME",value:"JavaScript"},{key:"SDK_LANGUAGE",value:"JavaScript"},{key:"SDK_TYPE",value:"client"},{key:"SDK_VERSION",value:be}]}))};h(`${u.eventUrl}/metrics/${o}?cluster=${f}`,{method:"POST",headers:T({"Content-Type":"application/json"},F),body:JSON.stringify(t)}).then(()=>{S=[],B=0}).catch(i=>{B++&&(S=[],B=0),p(i),d.emit("metrics error",i)}).finally(()=>{c=window.setTimeout(K,u.eventsSyncInterval)})}else c=window.setTimeout(K,u.eventsSyncInterval)},I={},Se=t=>{p("Sending event for",t.flag),Y?d.emit("changed",new Proxy(t,{get(i,s){var m;if(D&&i.hasOwnProperty(s)&&s==="value"){let E=i.flag,r=t.value,g=S.find(O=>O.featureIdentifier===E&&O.featureValue===r);g?(G(g),g.variationIdentifier=((m=I[E])==null?void 0:m.identifier)||""):S.push({featureIdentifier:E,featureValue:String(r),variationIdentifier:I[E].identifier||"",count:1,lastAccessed:Date.now()}),p("Metrics event: Flag",s,"has been read with value via stream update",r)}return s==="value"?X(t):t[s]}})):d.emit("changed",{deleted:t.deleted,flag:t.flag,value:X(t)})},Z=function(){return Y?new Proxy({},{get(t,i){var m,E,r;let s=t[i];if(D&&t.hasOwnProperty(i)){let g=t[i],O=S.find(ne=>ne.featureIdentifier===i&&g===ne.featureValue);O?(O.variationIdentifier=((m=I[i])==null?void 0:m.identifier)||"",G(O)):S.push({featureIdentifier:i,featureValue:g,variationIdentifier:((E=I[i])==null?void 0:E.identifier)||"",count:1,lastAccessed:Date.now()}),p("Metrics event: Flag:",i,"has been read with value:",g,"variationIdentifier:",(r=I[i])==null?void 0:r.identifier)}return s}}):{}},w=Z();Re(n,u).then(t=>C(void 0,null,function*(){if(l)return;R=t;let i=(0,me.default)(t);if(F={Authorization:`Bearer ${R}`,"Harness-AccountID":i.accountID,"Harness-EnvironmentID":i.environmentIdentifier,"Harness-SDK-Info":pe},p("Authenticated",i),globalThis.localStorage&&globalThis.localStorage.HARNESS_FF_METRICS)try{delete globalThis.localStorage.HARNESS_FF_METRICS,p("Picking up metrics from previous session")}catch(E){}c=window.setTimeout(K,u.eventsSyncInterval),o=i.environment,f=i.clusterIdentifier;let s=!!Object.keys(I).length;if((yield _())||p("Fetch all flags ok",w),!l){if(u.streamEnabled?(p("Streaming mode enabled"),Ie()):u.pollingEnabled?(p("Polling mode enabled"),ye()):p("Streaming and polling mode disabled"),!s){k();let E=T({},w);N(),d.emit("ready",E)}Q=!0}})).catch(t=>{y("Authentication error: ",t),d.emit("auth error",t),d.emit("error",t)});let _=()=>C(void 0,null,function*(){try{let t=yield h(`${u.baseUrl}/client/env/${o}/target/${e.identifier}/evaluations?cluster=${f}`,{headers:F});if(t.ok){let i=yield t.json();i.forEach(A),d.emit("flags loaded",i)}else y("Features fetch operation error: ",t),d.emit("fetch flags error",t),d.emit("error",t)}catch(t){return y("Features fetch operation error: ",t),d.emit("fetch flags error",t),d.emit("error",t),t}}),ee=t=>C(void 0,null,function*(){try{let i=yield h(`${u.baseUrl}/client/env/${o}/target/${e.identifier}/evaluations/${t}?cluster=${f}`,{headers:F});if(i.ok){let s=yield i.json();A(s)}else y("Feature fetch operation error: ",i),d.emit("fetch flag error",i),d.emit("error",i)}catch(i){y("Feature fetch operation error: ",i),d.emit("fetch flag error",i),d.emit("error",i)}}),A=t=>{k();let i=X(t);i!==w[t.flag]&&(p("Flag variation has changed for ",t.identifier),w[t.flag]=i,I[t.flag]=U(T({},t),{value:i}),Se(t)),N()};b=new V(_,u);let Ie=()=>{let t=r=>{switch(r.event){case"create":s(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):setTimeout(()=>ee(r.identifier),1e3);break;case"patch":s(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):ee(r.identifier);break;case"delete":delete w[r.identifier],d.emit("changed",{flag:r.identifier,value:void 0,deleted:!0}),p("Evaluation deleted",{message:r,storage:w});break}},i=r=>!(!r||!r.flag||!r.identifier||!r.kind||!r.value),s=r=>!(!r||r.length==0||!r.every(g=>i(g))),m=r=>{r.event==="patch"&&(s(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):_())},E=`${u.baseUrl}/stream?cluster=${f}`;v=new $(d,u,E,n,F,b,r=>{r.domain==="flag"?t(r):r.domain==="target-segment"&&m(r)}),v.start()},ye=()=>{b.start()},q=(t,i)=>d.on(t,i),De=(t,i)=>{t?d.off(t,i):te()},Te=(t,i)=>{var r;if(!D||Y||i===void 0)return;let s=i,m=t,E=S.find(g=>g.featureIdentifier===m&&g.featureValue===s);E?(G(E),E.variationIdentifier=((r=I[m])==null?void 0:r.identifier)||""):S.push({featureIdentifier:m,featureValue:s,count:1,variationIdentifier:I[m].identifier||"",lastAccessed:Date.now()})},te=()=>{l=!0,u.streamEnabled&&(p("Closing event stream"),typeof(v==null?void 0:v.close)=="function"&&v.close(),d.all.clear()),u.pollingEnabled&&b.isPolling()&&(p("Closing Poller"),b.stop()),w=Z(),I={},clearTimeout(c)},ie=(t,i=!0)=>{t.length&&j(()=>{let s=!!Object.keys(I).length;if(t.forEach(A),!s){k();let m=T({},w);N(),d.emit("ready",m)}},i)};if(u.cache&&"localStorage"in window){let t=!0,i=H(e.identifier,typeof u.cache=="boolean"?{}:u.cache);i!=null&&i.length&&j(()=>{p("loading from cache",i),ie(i,!1),d.emit("cache loaded",i)}),q("flags loaded",s=>{L(e.identifier,s),t=!1}),q("changed",s=>{t||(s.deleted?ue(e.identifier,s.flag):de(e.identifier,s))})}return{on:q,off:De,close:te,setEvaluations:ie,registerAPIRequestMiddleware:t=>{h=J(t)},refreshEvaluations:()=>{Q&&!l&&Date.now()-z>=6e4&&(_(),z=Date.now())},variation:(t,i,s=!1)=>ge(t,i,w,Te,s)}};0&&(module.exports={Event,initialize});

@@ -1,1 +0,1 @@

var HarnessFFSDK=(()=>{var _=Object.defineProperty,De=Object.defineProperties,Ae=Object.getOwnPropertyDescriptor,Oe=Object.getOwnPropertyDescriptors,xe=Object.getOwnPropertyNames,oe=Object.getOwnPropertySymbols;var le=Object.prototype.hasOwnProperty,Fe=Object.prototype.propertyIsEnumerable;var se=(t,e,i)=>e in t?_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:i}):t[e]=i,T=(t,e)=>{for(var i in e||(e={}))le.call(e,i)&&se(t,i,e[i]);if(oe)for(var i of oe(e))Fe.call(e,i)&&se(t,i,e[i]);return t},j=(t,e)=>De(t,Oe(e));var ke=(t,e)=>{for(var i in e)_(t,i,{get:e[i],enumerable:!0})},Ve=(t,e,i,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of xe(e))!le.call(t,s)&&s!==i&&_(t,s,{get:()=>e[s],enumerable:!(r=Ae(e,s))||r.enumerable});return t};var Ne=t=>Ve(_({},"__esModule",{value:!0}),t);var D=(t,e,i)=>new Promise((r,s)=>{var d=b=>{try{S(i.next(b))}catch(c){s(c)}},g=b=>{try{S(i.throw(b))}catch(c){s(c)}},S=b=>b.done?r(b.value):Promise.resolve(b.value).then(d,g);S((i=i.apply(t,e)).next())});var Be={};ke(Be,{Event:()=>P,initialize:()=>Ge});function J(t){this.message=t}J.prototype=new Error,J.prototype.name="InvalidCharacterError";var ce=typeof window!="undefined"&&window.atob&&window.atob.bind(window)||function(t){var e=String(t).replace(/=+$/,"");if(e.length%4==1)throw new J("'atob' failed: The string to be decoded is not correctly encoded.");for(var i,r,s=0,d=0,g="";r=e.charAt(d++);~r&&(i=s%4?64*i+r:r,s++%4)?g+=String.fromCharCode(255&i>>(-2*s&6)):0)r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(r);return g};function _e(t){var e=t.replace(/-/g,"+").replace(/_/g,"/");switch(e.length%4){case 0:break;case 2:e+="==";break;case 3:e+="=";break;default:throw"Illegal base64url string!"}try{return function(i){return decodeURIComponent(ce(i).replace(/(.)/g,function(r,s){var d=s.charCodeAt(0).toString(16).toUpperCase();return d.length<2&&(d="0"+d),"%"+d}))}(e)}catch(i){return ce(e)}}function M(t){this.message=t}function Me(t,e){if(typeof t!="string")throw new M("Invalid token specified");var i=(e=e||{}).header===!0?0:1;try{return JSON.parse(_e(t.split(".")[i]))}catch(r){throw new M("Invalid token specified: "+r.message)}}M.prototype=new Error,M.prototype.name="InvalidTokenError";var de=Me;function ue(t){return{all:t=t||new Map,on:function(e,i){var r=t.get(e);r&&r.push(i)||t.set(e,[i])},off:function(e,i){var r=t.get(e);r&&r.splice(r.indexOf(i)>>>0,1)},emit:function(e,i){(t.get(e)||[]).slice().map(function(r){r(i)}),(t.get("*")||[]).slice().map(function(r){r(e,i)})}}}var P=(p=>(p.READY="ready",p.CONNECTED="connected",p.DISCONNECTED="disconnected",p.FLAGS_LOADED="flags loaded",p.CACHE_LOADED="cache loaded",p.CHANGED="changed",p.ERROR="error",p.ERROR_METRICS="metrics error",p.ERROR_AUTH="auth error",p.ERROR_FETCH_FLAGS="fetch flags error",p.ERROR_FETCH_FLAG="fetch flag error",p.ERROR_STREAM="stream error",p))(P||{});var Pe={debug:!1,baseUrl:"https://config.ff.harness.io/api/1.0",eventUrl:"https://events.ff.harness.io/api/1.0",eventsSyncInterval:6e4,pollingInterval:6e4,streamEnabled:!0,allAttributesPrivate:!1,privateAttributeNames:[],cache:!1},fe=t=>{let e=T(T({},Pe),t);return e.pollingEnabled===void 0&&(e.pollingEnabled=e.streamEnabled),e},w=(t,...e)=>console.error(`[FF-SDK] ${t}`,...e),W=(t,e=!0)=>{e?setTimeout(t,0):t()},H=(t,e)=>Math.round(Math.random()*(e-t)+t);function Y(t){return"HARNESS_FF_CACHE_"+t}function L(t,e={}){let i=Y(t),r=parseInt(window.localStorage.getItem(i+".ts"));if(e!=null&&e.ttl&&!isNaN(r)&&r+e.ttl<Date.now())return He(t),[];let s=window.localStorage.getItem(i);if(s)try{return JSON.parse(s)}catch(d){}return[]}function $(t,e){let i=Y(t);window.localStorage.setItem(i,JSON.stringify(e)),window.localStorage.setItem(i+".ts",Date.now().toString())}function ge(t,e){let i=L(t),r=i.find(({flag:s})=>s===e.flag);r?Object.assign(r,e):i.push(e),$(t,i)}function he(t,e){let i=L(t),r=i.findIndex(({flag:s})=>s===e);r>-1&&(i.splice(r,1),$(t,i))}function He(t){let e=Y(t);window.localStorage.removeItem(e),window.localStorage.removeItem(e+".ts")}function X(t){return function(...i){let[r,s]=t(i);return fetch(r,s)}}var pe=3e4,G=class{constructor(e,i,r,s,d,g,S){this.closed=!1;this.eventBus=e,this.configurations=i,this.url=r,this.apiKey=s,this.standardHeaders=d,this.eventCallback=S,this.fallbackPoller=g}start(){let e=c=>{c.toString().split(/\r?\n/).forEach(i)},i=c=>{if(c.startsWith("data:")){let y=JSON.parse(c.substring(5));this.logDebug("Received event from stream: ",y),this.eventCallback(y)}},r=()=>{this.logDebug("Stream connected"),this.eventBus.emit("connected")},s=()=>{clearInterval(this.readTimeoutCheckerId);let c=H(1e3,1e4);this.logDebug("Stream disconnected, will reconnect in "+c+"ms"),this.eventBus.emit("disconnected"),setTimeout(()=>this.start(),c)},d=c=>{c&&w("Stream has issue",c),this.fallBackToPolling(),this.eventBus.emit("stream error",c),this.eventBus.emit("error",c),s()},g=T({"Cache-Control":"no-cache",Accept:"text/event-stream","API-Key":this.apiKey},this.standardHeaders);this.logDebug("SSE HTTP start request",this.url),this.xhr=new XMLHttpRequest,this.xhr.open("GET",this.url);for(let[c,y]of Object.entries(g))this.xhr.setRequestHeader(c,y);this.xhr.timeout=24*60*60*1e3,this.xhr.onerror=()=>{d("XMLHttpRequest error on SSE stream")},this.xhr.onabort=()=>{this.logDebug("SSE aborted"),this.closed||d(null)},this.xhr.ontimeout=()=>{d("SSE timeout")},this.xhr.onload=()=>{if(this.xhr.status>=400&&this.xhr.status<=599){d(`HTTP code ${this.xhr.status}`);return}r()};let S=0,b=Date.now();this.xhr.onprogress=()=>{this.stopFallBackPolling(),b=Date.now();let c=this.xhr.responseText.slice(S);S+=c.length,this.logDebug("SSE GOT: "+c),e(c)},this.readTimeoutCheckerId=setInterval(()=>{b<Date.now()-pe&&(w("SSE read timeout"),this.xhr.abort())},pe),this.xhr.send()}close(){this.closed=!0,this.xhr&&this.xhr.abort(),clearInterval(this.readTimeoutCheckerId),this.stopFallBackPolling()}fallBackToPolling(){!this.fallbackPoller.isPolling()&&this.configurations.pollingEnabled&&(this.logDebug("Falling back to polling mode while stream recovers"),this.fallbackPoller.start())}stopFallBackPolling(){this.fallbackPoller.isPolling()&&(this.logDebug("Stopping fallback polling mode"),this.fallbackPoller.stop())}logDebug(e,...i){this.configurations.debug&&console.debug(`[FF-SDK] Streaming: ${e}`,...i)}};function ve(t,e,i,r,s){let d=t in i,g=d?i[t]:e;return d&&r(t,g),s?{value:g,isDefaultValue:!d}:g}var F=class{constructor(e,i){this.fetchFlagsFn=e;this.configurations=i;this.maxAttempts=5}start(){if(this.isPolling()){this.logDebug("Already polling.");return}this.isRunning=!0,this.logDebug(`Starting poller, first poll will be in ${this.configurations.pollingInterval}ms`),this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)}poll(){this.attemptFetch().finally(()=>{this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)})}attemptFetch(){return D(this,null,function*(){for(let e=1;e<=this.maxAttempts;e++){let i=yield this.fetchFlagsFn();if(!i){this.logDebug(`Successfully polled for flag updates, next poll in ${this.configurations.pollingInterval}ms. `);return}if(w("Error when polling for flag updates",i),e>=this.maxAttempts){this.logDebug(`Maximum attempts reached for polling for flags. Next poll in ${this.configurations.pollingInterval}ms.`);return}this.logDebug(`Polling for flags attempt #${e} failed. Remaining attempts: ${this.maxAttempts-e}`,i);let r=H(1e3,1e4);yield new Promise(s=>setTimeout(s,r))}})}stop(){this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=void 0,this.isRunning=!1,this.logDebug("Polling stopped"))}isPolling(){return this.isRunning}logDebug(e,...i){this.configurations.debug&&console.debug(`[FF-SDK] Poller: ${e}`,...i)}};var Re="1.16.0",be=`Javascript ${Re} Client`,Le=500,$e=globalThis.fetch,z=!!globalThis.Proxy,Q=t=>{let{value:e}=t;try{switch(t.kind.toLowerCase()){case"int":case"number":e=Number(e);break;case"boolean":e=e.toString().toLowerCase()==="true";break;case"json":e=JSON.parse(e);break}}catch(i){w(i)}return e},Ge=(t,e,i)=>{let r=!1,s,d,g,S,b,c,y=!0,x={},p=X(n=>n),Z=0,ee=!1,k=()=>{y=!1},V=()=>{y=!0},R=[],u=ue(),f=fe(i);f.eventsSyncInterval<6e4&&(f.eventsSyncInterval=6e4),f.pollingInterval<6e4&&(f.pollingInterval=6e4);let E=(n,...a)=>{f.debug&&console.debug(`[FF-SDK] ${n}`,...a)},B=n=>{if(y){let a=Date.now();a-n.lastAccessed>Le&&(n.count++,n.lastAccessed=a)}};globalThis.onbeforeunload=()=>{R.length&&globalThis.localStorage&&(k(),globalThis.localStorage.HARNESS_FF_METRICS=JSON.stringify(R),V())};let Se=(n,a)=>D(void 0,null,function*(){return(yield(yield $e(`${a.baseUrl}/client/auth`,{method:"POST",headers:{"Content-Type":"application/json","Harness-SDK-Info":be},body:JSON.stringify({apiKey:n,target:j(T({},e),{identifier:String(e.identifier)})})})).json()).authToken}),K=0,U=()=>{if(R.length){E("Sending metrics...",{metrics:R,evaluations:I});let n={metricsData:R.map(a=>({timestamp:Date.now(),count:a.count,metricsType:"FFMETRICS",attributes:[{key:"featureIdentifier",value:a.featureIdentifier},{key:"featureName",value:a.featureIdentifier},{key:"variationIdentifier",value:a.variationIdentifier},{key:"target",value:e.identifier},{key:"SDK_NAME",value:"JavaScript"},{key:"SDK_LANGUAGE",value:"JavaScript"},{key:"SDK_TYPE",value:"client"},{key:"SDK_VERSION",value:Re}]}))};p(`${f.eventUrl}/metrics/${s}?cluster=${d}`,{method:"POST",headers:T({"Content-Type":"application/json"},x),body:JSON.stringify(n)}).then(()=>{R=[],K=0}).catch(a=>{K++&&(R=[],K=0),E(a),u.emit("metrics error",a)}).finally(()=>{c=window.setTimeout(U,f.eventsSyncInterval)})}else c=window.setTimeout(U,f.eventsSyncInterval)},I={},Ie=n=>{E("Sending event for",n.flag),z?u.emit("changed",new Proxy(n,{get(a,l){var v;if(y&&a.hasOwnProperty(l)&&l==="value"){let m=a.flag,o=n.value,h=R.find(O=>O.featureIdentifier===m&&O.featureValue===o);h?(B(h),h.variationIdentifier=((v=I[m])==null?void 0:v.identifier)||""):R.push({featureIdentifier:m,featureValue:String(o),variationIdentifier:I[m].identifier||"",count:1,lastAccessed:Date.now()}),E("Metrics event: Flag",l,"has been read with value via stream update",o)}return l==="value"?Q(n):n[l]}})):u.emit("changed",{deleted:n.deleted,flag:n.flag,value:Q(n)})},te=function(){return z?new Proxy({},{get(n,a){var v,m,o;let l=n[a];if(y&&n.hasOwnProperty(a)){let h=n[a],O=R.find(re=>re.featureIdentifier===a&&h===re.featureValue);O?(O.variationIdentifier=((v=I[a])==null?void 0:v.identifier)||"",B(O)):R.push({featureIdentifier:a,featureValue:h,variationIdentifier:((m=I[a])==null?void 0:m.identifier)||"",count:1,lastAccessed:Date.now()}),E("Metrics event: Flag:",a,"has been read with value:",h,"variationIdentifier:",(o=I[a])==null?void 0:o.identifier)}return l}}):{}},C=te();Se(t,f).then(n=>D(void 0,null,function*(){if(r)return;b=n;let a=de(n);if(x={Authorization:`Bearer ${b}`,"Harness-AccountID":a.accountID,"Harness-EnvironmentID":a.environmentIdentifier,"Harness-SDK-Info":be},E("Authenticated",a),globalThis.localStorage&&globalThis.localStorage.HARNESS_FF_METRICS)try{delete globalThis.localStorage.HARNESS_FF_METRICS,E("Picking up metrics from previous session")}catch(m){}c=window.setTimeout(U,f.eventsSyncInterval),s=a.environment,d=a.clusterIdentifier;let l=!!Object.keys(I).length;if((yield N())||E("Fetch all flags ok",C),!r){if(f.streamEnabled?(E("Streaming mode enabled"),we()):f.pollingEnabled?(E("Polling mode enabled"),ye()):E("Streaming and polling mode disabled"),!l){k();let m=T({},C);V(),u.emit("ready",m)}ee=!0}})).catch(n=>{w("Authentication error: ",n),u.emit("auth error",n),u.emit("error",n)});let N=()=>D(void 0,null,function*(){try{let n=yield p(`${f.baseUrl}/client/env/${s}/target/${e.identifier}/evaluations?cluster=${d}`,{headers:x});if(n.ok){let a=yield n.json();a.forEach(A),u.emit("flags loaded",a)}else w("Features fetch operation error: ",n),u.emit("fetch flags error",n),u.emit("error",n)}catch(n){return w("Features fetch operation error: ",n),u.emit("fetch flags error",n),u.emit("error",n),n}}),ie=n=>D(void 0,null,function*(){try{let a=yield p(`${f.baseUrl}/client/env/${s}/target/${e.identifier}/evaluations/${n}?cluster=${d}`,{headers:x});if(a.ok){let l=yield a.json();A(l)}else w("Feature fetch operation error: ",a),u.emit("fetch flag error",a),u.emit("error",a)}catch(a){w("Feature fetch operation error: ",a),u.emit("fetch flag error",a),u.emit("error",a)}}),A=n=>{k();let a=Q(n);a!==C[n.flag]&&(E("Flag variation has changed for ",n.identifier),C[n.flag]=a,I[n.flag]=j(T({},n),{value:a}),Ie(n)),V()};S=new F(N,f);let we=()=>{let n=o=>{switch(o.event){case"create":l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):setTimeout(()=>ie(o.identifier),1e3);break;case"patch":l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):ie(o.identifier);break;case"delete":delete C[o.identifier],u.emit("changed",{flag:o.identifier,value:void 0,deleted:!0}),E("Evaluation deleted",{message:o,storage:C});break}},a=o=>!(!o||!o.flag||!o.identifier||!o.kind||!o.value),l=o=>!(!o||o.length==0||!o.every(h=>a(h))),v=o=>{o.event==="patch"&&(l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):N())},m=`${f.baseUrl}/stream?cluster=${d}`;g=new G(u,f,m,t,x,S,o=>{o.domain==="flag"?n(o):o.domain==="target-segment"&&v(o)}),g.start()},ye=()=>{S.start()},q=(n,a)=>u.on(n,a),Te=(n,a)=>{n?u.off(n,a):ne()},Ce=(n,a)=>{var o;if(!y||z||a===void 0)return;let l=a,v=n,m=R.find(h=>h.featureIdentifier===v&&h.featureValue===l);m?(B(m),m.variationIdentifier=((o=I[v])==null?void 0:o.identifier)||""):R.push({featureIdentifier:v,featureValue:l,count:1,variationIdentifier:I[v].identifier||"",lastAccessed:Date.now()})},ne=()=>{r=!0,E("Closing event stream"),C=te(),I={},clearTimeout(c),u.all.clear(),typeof(g==null?void 0:g.close)=="function"&&g.close()},ae=(n,a=!0)=>{n.length&&W(()=>{let l=!!Object.keys(I).length;if(n.forEach(A),!l){k();let v=T({},C);V(),u.emit("ready",v)}},a)};if(f.cache&&"localStorage"in window){let n=!0,a=L(e.identifier,typeof f.cache=="boolean"?{}:f.cache);a!=null&&a.length&&W(()=>{E("loading from cache",a),ae(a,!1),u.emit("cache loaded",a)}),q("flags loaded",l=>{$(e.identifier,l),n=!1}),q("changed",l=>{n||(l.deleted?he(e.identifier,l.flag):ge(e.identifier,l))})}return{on:q,off:Te,close:ne,setEvaluations:ae,registerAPIRequestMiddleware:n=>{p=X(n)},refreshEvaluations:()=>{ee&&!r&&Date.now()-Z>=6e4&&(N(),Z=Date.now())},variation:(n,a,l=!1)=>ve(n,a,C,Ce,l)}};return Ne(Be);})();
var HarnessFFSDK=(()=>{var _=Object.defineProperty,De=Object.defineProperties,Ae=Object.getOwnPropertyDescriptor,Oe=Object.getOwnPropertyDescriptors,xe=Object.getOwnPropertyNames,oe=Object.getOwnPropertySymbols;var le=Object.prototype.hasOwnProperty,Fe=Object.prototype.propertyIsEnumerable;var se=(t,e,i)=>e in t?_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:i}):t[e]=i,C=(t,e)=>{for(var i in e||(e={}))le.call(e,i)&&se(t,i,e[i]);if(oe)for(var i of oe(e))Fe.call(e,i)&&se(t,i,e[i]);return t},j=(t,e)=>De(t,Oe(e));var ke=(t,e)=>{for(var i in e)_(t,i,{get:e[i],enumerable:!0})},Ve=(t,e,i,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of xe(e))!le.call(t,s)&&s!==i&&_(t,s,{get:()=>e[s],enumerable:!(r=Ae(e,s))||r.enumerable});return t};var Ne=t=>Ve(_({},"__esModule",{value:!0}),t);var D=(t,e,i)=>new Promise((r,s)=>{var d=R=>{try{b(i.next(R))}catch(c){s(c)}},g=R=>{try{b(i.throw(R))}catch(c){s(c)}},b=R=>R.done?r(R.value):Promise.resolve(R.value).then(d,g);b((i=i.apply(t,e)).next())});var Be={};ke(Be,{Event:()=>P,initialize:()=>Ge});function J(t){this.message=t}J.prototype=new Error,J.prototype.name="InvalidCharacterError";var ce=typeof window!="undefined"&&window.atob&&window.atob.bind(window)||function(t){var e=String(t).replace(/=+$/,"");if(e.length%4==1)throw new J("'atob' failed: The string to be decoded is not correctly encoded.");for(var i,r,s=0,d=0,g="";r=e.charAt(d++);~r&&(i=s%4?64*i+r:r,s++%4)?g+=String.fromCharCode(255&i>>(-2*s&6)):0)r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(r);return g};function _e(t){var e=t.replace(/-/g,"+").replace(/_/g,"/");switch(e.length%4){case 0:break;case 2:e+="==";break;case 3:e+="=";break;default:throw"Illegal base64url string!"}try{return function(i){return decodeURIComponent(ce(i).replace(/(.)/g,function(r,s){var d=s.charCodeAt(0).toString(16).toUpperCase();return d.length<2&&(d="0"+d),"%"+d}))}(e)}catch(i){return ce(e)}}function M(t){this.message=t}function Me(t,e){if(typeof t!="string")throw new M("Invalid token specified");var i=(e=e||{}).header===!0?0:1;try{return JSON.parse(_e(t.split(".")[i]))}catch(r){throw new M("Invalid token specified: "+r.message)}}M.prototype=new Error,M.prototype.name="InvalidTokenError";var de=Me;function ue(t){return{all:t=t||new Map,on:function(e,i){var r=t.get(e);r&&r.push(i)||t.set(e,[i])},off:function(e,i){var r=t.get(e);r&&r.splice(r.indexOf(i)>>>0,1)},emit:function(e,i){(t.get(e)||[]).slice().map(function(r){r(i)}),(t.get("*")||[]).slice().map(function(r){r(e,i)})}}}var P=(p=>(p.READY="ready",p.CONNECTED="connected",p.DISCONNECTED="disconnected",p.FLAGS_LOADED="flags loaded",p.CACHE_LOADED="cache loaded",p.CHANGED="changed",p.ERROR="error",p.ERROR_METRICS="metrics error",p.ERROR_AUTH="auth error",p.ERROR_FETCH_FLAGS="fetch flags error",p.ERROR_FETCH_FLAG="fetch flag error",p.ERROR_STREAM="stream error",p))(P||{});var Pe={debug:!1,baseUrl:"https://config.ff.harness.io/api/1.0",eventUrl:"https://events.ff.harness.io/api/1.0",eventsSyncInterval:6e4,pollingInterval:6e4,streamEnabled:!0,allAttributesPrivate:!1,privateAttributeNames:[],cache:!1},fe=t=>{let e=C(C({},Pe),t);return e.pollingEnabled===void 0&&(e.pollingEnabled=e.streamEnabled),e},w=(t,...e)=>console.error(`[FF-SDK] ${t}`,...e),W=(t,e=!0)=>{e?setTimeout(t,0):t()},H=(t,e)=>Math.round(Math.random()*(e-t)+t);function Y(t){return"HARNESS_FF_CACHE_"+t}function L(t,e={}){let i=Y(t),r=parseInt(window.localStorage.getItem(i+".ts"));if(e!=null&&e.ttl&&!isNaN(r)&&r+e.ttl<Date.now())return He(t),[];let s=window.localStorage.getItem(i);if(s)try{return JSON.parse(s)}catch(d){}return[]}function $(t,e){let i=Y(t);window.localStorage.setItem(i,JSON.stringify(e)),window.localStorage.setItem(i+".ts",Date.now().toString())}function ge(t,e){let i=L(t),r=i.find(({flag:s})=>s===e.flag);r?Object.assign(r,e):i.push(e),$(t,i)}function he(t,e){let i=L(t),r=i.findIndex(({flag:s})=>s===e);r>-1&&(i.splice(r,1),$(t,i))}function He(t){let e=Y(t);window.localStorage.removeItem(e),window.localStorage.removeItem(e+".ts")}function X(t){return function(...i){let[r,s]=t(i);return fetch(r,s)}}var pe=3e4,G=class{constructor(e,i,r,s,d,g,b){this.closed=!1;this.eventBus=e,this.configurations=i,this.url=r,this.apiKey=s,this.standardHeaders=d,this.eventCallback=b,this.fallbackPoller=g}start(){let e=c=>{c.toString().split(/\r?\n/).forEach(i)},i=c=>{if(c.startsWith("data:")){let y=JSON.parse(c.substring(5));this.logDebug("Received event from stream: ",y),this.eventCallback(y)}},r=()=>{this.logDebug("Stream connected"),this.eventBus.emit("connected")},s=()=>{clearInterval(this.readTimeoutCheckerId);let c=H(1e3,1e4);this.logDebug("Stream disconnected, will reconnect in "+c+"ms"),this.eventBus.emit("disconnected"),setTimeout(()=>this.start(),c)},d=c=>{c&&w("Stream has issue",c),this.fallBackToPolling(),this.eventBus.emit("stream error",c),this.eventBus.emit("error",c),s()},g=C({"Cache-Control":"no-cache",Accept:"text/event-stream","API-Key":this.apiKey},this.standardHeaders);this.logDebug("SSE HTTP start request",this.url),this.xhr=new XMLHttpRequest,this.xhr.open("GET",this.url);for(let[c,y]of Object.entries(g))this.xhr.setRequestHeader(c,y);this.xhr.timeout=24*60*60*1e3,this.xhr.onerror=()=>{d("XMLHttpRequest error on SSE stream")},this.xhr.onabort=()=>{this.logDebug("SSE aborted"),this.closed||d(null)},this.xhr.ontimeout=()=>{d("SSE timeout")},this.xhr.onload=()=>{if(this.xhr.status>=400&&this.xhr.status<=599){d(`HTTP code ${this.xhr.status}`);return}r()};let b=0,R=Date.now();this.xhr.onprogress=()=>{this.stopFallBackPolling(),R=Date.now();let c=this.xhr.responseText.slice(b);b+=c.length,this.logDebug("SSE GOT: "+c),e(c)},this.readTimeoutCheckerId=setInterval(()=>{R<Date.now()-pe&&(w("SSE read timeout"),this.xhr.abort())},pe),this.xhr.send()}close(){this.closed=!0,this.xhr&&this.xhr.abort(),clearInterval(this.readTimeoutCheckerId),this.stopFallBackPolling()}fallBackToPolling(){!this.fallbackPoller.isPolling()&&this.configurations.pollingEnabled&&(this.logDebug("Falling back to polling mode while stream recovers"),this.fallbackPoller.start())}stopFallBackPolling(){this.fallbackPoller.isPolling()&&(this.logDebug("Stopping fallback polling mode"),this.fallbackPoller.stop())}logDebug(e,...i){this.configurations.debug&&console.debug(`[FF-SDK] Streaming: ${e}`,...i)}};function ve(t,e,i,r,s){let d=t in i,g=d?i[t]:e;return d&&r(t,g),s?{value:g,isDefaultValue:!d}:g}var F=class{constructor(e,i){this.fetchFlagsFn=e;this.configurations=i;this.maxAttempts=5}start(){if(this.isPolling()){this.logDebug("Already polling.");return}this.isRunning=!0,this.logDebug(`Starting poller, first poll will be in ${this.configurations.pollingInterval}ms`),this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)}poll(){this.attemptFetch().finally(()=>{this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)})}attemptFetch(){return D(this,null,function*(){for(let e=1;e<=this.maxAttempts;e++){let i=yield this.fetchFlagsFn();if(!i){this.logDebug(`Successfully polled for flag updates, next poll in ${this.configurations.pollingInterval}ms. `);return}if(w("Error when polling for flag updates",i),e>=this.maxAttempts){this.logDebug(`Maximum attempts reached for polling for flags. Next poll in ${this.configurations.pollingInterval}ms.`);return}this.logDebug(`Polling for flags attempt #${e} failed. Remaining attempts: ${this.maxAttempts-e}`,i);let r=H(1e3,1e4);yield new Promise(s=>setTimeout(s,r))}})}stop(){this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=void 0,this.isRunning=!1,this.logDebug("Polling stopped"))}isPolling(){return this.isRunning}logDebug(e,...i){this.configurations.debug&&console.debug(`[FF-SDK] Poller: ${e}`,...i)}};var Re="1.16.0",be=`Javascript ${Re} Client`,Le=500,$e=globalThis.fetch,z=!!globalThis.Proxy,Q=t=>{let{value:e}=t;try{switch(t.kind.toLowerCase()){case"int":case"number":e=Number(e);break;case"boolean":e=e.toString().toLowerCase()==="true";break;case"json":e=JSON.parse(e);break}}catch(i){w(i)}return e},Ge=(t,e,i)=>{let r=!1,s,d,g,b,R,c,y=!0,x={},p=X(n=>n),Z=0,ee=!1,k=()=>{y=!1},V=()=>{y=!0},S=[],u=ue(),f=fe(i);f.eventsSyncInterval<6e4&&(f.eventsSyncInterval=6e4),f.pollingInterval<6e4&&(f.pollingInterval=6e4);let v=(n,...a)=>{f.debug&&console.debug(`[FF-SDK] ${n}`,...a)},B=n=>{if(y){let a=Date.now();a-n.lastAccessed>Le&&(n.count++,n.lastAccessed=a)}};globalThis.onbeforeunload=()=>{S.length&&globalThis.localStorage&&(k(),globalThis.localStorage.HARNESS_FF_METRICS=JSON.stringify(S),V())};let Se=(n,a)=>D(void 0,null,function*(){return(yield(yield $e(`${a.baseUrl}/client/auth`,{method:"POST",headers:{"Content-Type":"application/json","Harness-SDK-Info":be},body:JSON.stringify({apiKey:n,target:j(C({},e),{identifier:String(e.identifier)})})})).json()).authToken}),K=0,U=()=>{if(S.length){v("Sending metrics...",{metrics:S,evaluations:I});let n={metricsData:S.map(a=>({timestamp:Date.now(),count:a.count,metricsType:"FFMETRICS",attributes:[{key:"featureIdentifier",value:a.featureIdentifier},{key:"featureName",value:a.featureIdentifier},{key:"variationIdentifier",value:a.variationIdentifier},{key:"target",value:e.identifier},{key:"SDK_NAME",value:"JavaScript"},{key:"SDK_LANGUAGE",value:"JavaScript"},{key:"SDK_TYPE",value:"client"},{key:"SDK_VERSION",value:Re}]}))};p(`${f.eventUrl}/metrics/${s}?cluster=${d}`,{method:"POST",headers:C({"Content-Type":"application/json"},x),body:JSON.stringify(n)}).then(()=>{S=[],K=0}).catch(a=>{K++&&(S=[],K=0),v(a),u.emit("metrics error",a)}).finally(()=>{c=window.setTimeout(U,f.eventsSyncInterval)})}else c=window.setTimeout(U,f.eventsSyncInterval)},I={},Ie=n=>{v("Sending event for",n.flag),z?u.emit("changed",new Proxy(n,{get(a,l){var m;if(y&&a.hasOwnProperty(l)&&l==="value"){let E=a.flag,o=n.value,h=S.find(O=>O.featureIdentifier===E&&O.featureValue===o);h?(B(h),h.variationIdentifier=((m=I[E])==null?void 0:m.identifier)||""):S.push({featureIdentifier:E,featureValue:String(o),variationIdentifier:I[E].identifier||"",count:1,lastAccessed:Date.now()}),v("Metrics event: Flag",l,"has been read with value via stream update",o)}return l==="value"?Q(n):n[l]}})):u.emit("changed",{deleted:n.deleted,flag:n.flag,value:Q(n)})},te=function(){return z?new Proxy({},{get(n,a){var m,E,o;let l=n[a];if(y&&n.hasOwnProperty(a)){let h=n[a],O=S.find(re=>re.featureIdentifier===a&&h===re.featureValue);O?(O.variationIdentifier=((m=I[a])==null?void 0:m.identifier)||"",B(O)):S.push({featureIdentifier:a,featureValue:h,variationIdentifier:((E=I[a])==null?void 0:E.identifier)||"",count:1,lastAccessed:Date.now()}),v("Metrics event: Flag:",a,"has been read with value:",h,"variationIdentifier:",(o=I[a])==null?void 0:o.identifier)}return l}}):{}},T=te();Se(t,f).then(n=>D(void 0,null,function*(){if(r)return;R=n;let a=de(n);if(x={Authorization:`Bearer ${R}`,"Harness-AccountID":a.accountID,"Harness-EnvironmentID":a.environmentIdentifier,"Harness-SDK-Info":be},v("Authenticated",a),globalThis.localStorage&&globalThis.localStorage.HARNESS_FF_METRICS)try{delete globalThis.localStorage.HARNESS_FF_METRICS,v("Picking up metrics from previous session")}catch(E){}c=window.setTimeout(U,f.eventsSyncInterval),s=a.environment,d=a.clusterIdentifier;let l=!!Object.keys(I).length;if((yield N())||v("Fetch all flags ok",T),!r){if(f.streamEnabled?(v("Streaming mode enabled"),we()):f.pollingEnabled?(v("Polling mode enabled"),ye()):v("Streaming and polling mode disabled"),!l){k();let E=C({},T);V(),u.emit("ready",E)}ee=!0}})).catch(n=>{w("Authentication error: ",n),u.emit("auth error",n),u.emit("error",n)});let N=()=>D(void 0,null,function*(){try{let n=yield p(`${f.baseUrl}/client/env/${s}/target/${e.identifier}/evaluations?cluster=${d}`,{headers:x});if(n.ok){let a=yield n.json();a.forEach(A),u.emit("flags loaded",a)}else w("Features fetch operation error: ",n),u.emit("fetch flags error",n),u.emit("error",n)}catch(n){return w("Features fetch operation error: ",n),u.emit("fetch flags error",n),u.emit("error",n),n}}),ie=n=>D(void 0,null,function*(){try{let a=yield p(`${f.baseUrl}/client/env/${s}/target/${e.identifier}/evaluations/${n}?cluster=${d}`,{headers:x});if(a.ok){let l=yield a.json();A(l)}else w("Feature fetch operation error: ",a),u.emit("fetch flag error",a),u.emit("error",a)}catch(a){w("Feature fetch operation error: ",a),u.emit("fetch flag error",a),u.emit("error",a)}}),A=n=>{k();let a=Q(n);a!==T[n.flag]&&(v("Flag variation has changed for ",n.identifier),T[n.flag]=a,I[n.flag]=j(C({},n),{value:a}),Ie(n)),V()};b=new F(N,f);let we=()=>{let n=o=>{switch(o.event){case"create":l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):setTimeout(()=>ie(o.identifier),1e3);break;case"patch":l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):ie(o.identifier);break;case"delete":delete T[o.identifier],u.emit("changed",{flag:o.identifier,value:void 0,deleted:!0}),v("Evaluation deleted",{message:o,storage:T});break}},a=o=>!(!o||!o.flag||!o.identifier||!o.kind||!o.value),l=o=>!(!o||o.length==0||!o.every(h=>a(h))),m=o=>{o.event==="patch"&&(l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):N())},E=`${f.baseUrl}/stream?cluster=${d}`;g=new G(u,f,E,t,x,b,o=>{o.domain==="flag"?n(o):o.domain==="target-segment"&&m(o)}),g.start()},ye=()=>{b.start()},q=(n,a)=>u.on(n,a),Ce=(n,a)=>{n?u.off(n,a):ne()},Te=(n,a)=>{var o;if(!y||z||a===void 0)return;let l=a,m=n,E=S.find(h=>h.featureIdentifier===m&&h.featureValue===l);E?(B(E),E.variationIdentifier=((o=I[m])==null?void 0:o.identifier)||""):S.push({featureIdentifier:m,featureValue:l,count:1,variationIdentifier:I[m].identifier||"",lastAccessed:Date.now()})},ne=()=>{r=!0,f.streamEnabled&&(v("Closing event stream"),typeof(g==null?void 0:g.close)=="function"&&g.close(),u.all.clear()),f.pollingEnabled&&b.isPolling()&&(v("Closing Poller"),b.stop()),T=te(),I={},clearTimeout(c)},ae=(n,a=!0)=>{n.length&&W(()=>{let l=!!Object.keys(I).length;if(n.forEach(A),!l){k();let m=C({},T);V(),u.emit("ready",m)}},a)};if(f.cache&&"localStorage"in window){let n=!0,a=L(e.identifier,typeof f.cache=="boolean"?{}:f.cache);a!=null&&a.length&&W(()=>{v("loading from cache",a),ae(a,!1),u.emit("cache loaded",a)}),q("flags loaded",l=>{$(e.identifier,l),n=!1}),q("changed",l=>{n||(l.deleted?he(e.identifier,l.flag):ge(e.identifier,l))})}return{on:q,off:Ce,close:ne,setEvaluations:ae,registerAPIRequestMiddleware:n=>{p=X(n)},refreshEvaluations:()=>{ee&&!r&&Date.now()-Z>=6e4&&(N(),Z=Date.now())},variation:(n,a,l=!1)=>ve(n,a,T,Te,l)}};return Ne(Be);})();

@@ -1,1 +0,1 @@

var Te=Object.defineProperty,Ce=Object.defineProperties;var De=Object.getOwnPropertyDescriptors;var re=Object.getOwnPropertySymbols;var Ae=Object.prototype.hasOwnProperty,Oe=Object.prototype.propertyIsEnumerable;var oe=(n,e,a)=>e in n?Te(n,e,{enumerable:!0,configurable:!0,writable:!0,value:a}):n[e]=a,T=(n,e)=>{for(var a in e||(e={}))Ae.call(e,a)&&oe(n,a,e[a]);if(re)for(var a of re(e))Oe.call(e,a)&&oe(n,a,e[a]);return n},U=(n,e)=>Ce(n,De(e));var D=(n,e,a)=>new Promise((r,s)=>{var d=b=>{try{S(a.next(b))}catch(c){s(c)}},g=b=>{try{S(a.throw(b))}catch(c){s(c)}},S=b=>b.done?r(b.value):Promise.resolve(b.value).then(d,g);S((a=a.apply(n,e)).next())});function q(n){this.message=n}q.prototype=new Error,q.prototype.name="InvalidCharacterError";var se=typeof window!="undefined"&&window.atob&&window.atob.bind(window)||function(n){var e=String(n).replace(/=+$/,"");if(e.length%4==1)throw new q("'atob' failed: The string to be decoded is not correctly encoded.");for(var a,r,s=0,d=0,g="";r=e.charAt(d++);~r&&(a=s%4?64*a+r:r,s++%4)?g+=String.fromCharCode(255&a>>(-2*s&6)):0)r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(r);return g};function xe(n){var e=n.replace(/-/g,"+").replace(/_/g,"/");switch(e.length%4){case 0:break;case 2:e+="==";break;case 3:e+="=";break;default:throw"Illegal base64url string!"}try{return function(a){return decodeURIComponent(se(a).replace(/(.)/g,function(r,s){var d=s.charCodeAt(0).toString(16).toUpperCase();return d.length<2&&(d="0"+d),"%"+d}))}(e)}catch(a){return se(e)}}function _(n){this.message=n}function Fe(n,e){if(typeof n!="string")throw new _("Invalid token specified");var a=(e=e||{}).header===!0?0:1;try{return JSON.parse(xe(n.split(".")[a]))}catch(r){throw new _("Invalid token specified: "+r.message)}}_.prototype=new Error,_.prototype.name="InvalidTokenError";var le=Fe;function ce(n){return{all:n=n||new Map,on:function(e,a){var r=n.get(e);r&&r.push(a)||n.set(e,[a])},off:function(e,a){var r=n.get(e);r&&r.splice(r.indexOf(a)>>>0,1)},emit:function(e,a){(n.get(e)||[]).slice().map(function(r){r(a)}),(n.get("*")||[]).slice().map(function(r){r(e,a)})}}}var j=(p=>(p.READY="ready",p.CONNECTED="connected",p.DISCONNECTED="disconnected",p.FLAGS_LOADED="flags loaded",p.CACHE_LOADED="cache loaded",p.CHANGED="changed",p.ERROR="error",p.ERROR_METRICS="metrics error",p.ERROR_AUTH="auth error",p.ERROR_FETCH_FLAGS="fetch flags error",p.ERROR_FETCH_FLAG="fetch flag error",p.ERROR_STREAM="stream error",p))(j||{});var ke={debug:!1,baseUrl:"https://config.ff.harness.io/api/1.0",eventUrl:"https://events.ff.harness.io/api/1.0",eventsSyncInterval:6e4,pollingInterval:6e4,streamEnabled:!0,allAttributesPrivate:!1,privateAttributeNames:[],cache:!1},de=n=>{let e=T(T({},ke),n);return e.pollingEnabled===void 0&&(e.pollingEnabled=e.streamEnabled),e},w=(n,...e)=>console.error(`[FF-SDK] ${n}`,...e),J=(n,e=!0)=>{e?setTimeout(n,0):n()},M=(n,e)=>Math.round(Math.random()*(e-n)+n);function W(n){return"HARNESS_FF_CACHE_"+n}function P(n,e={}){let a=W(n),r=parseInt(window.localStorage.getItem(a+".ts"));if(e!=null&&e.ttl&&!isNaN(r)&&r+e.ttl<Date.now())return Ve(n),[];let s=window.localStorage.getItem(a);if(s)try{return JSON.parse(s)}catch(d){}return[]}function H(n,e){let a=W(n);window.localStorage.setItem(a,JSON.stringify(e)),window.localStorage.setItem(a+".ts",Date.now().toString())}function ue(n,e){let a=P(n),r=a.find(({flag:s})=>s===e.flag);r?Object.assign(r,e):a.push(e),H(n,a)}function fe(n,e){let a=P(n),r=a.findIndex(({flag:s})=>s===e);r>-1&&(a.splice(r,1),H(n,a))}function Ve(n){let e=W(n);window.localStorage.removeItem(e),window.localStorage.removeItem(e+".ts")}function Y(n){return function(...a){let[r,s]=n(a);return fetch(r,s)}}var ge=3e4,L=class{constructor(e,a,r,s,d,g,S){this.closed=!1;this.eventBus=e,this.configurations=a,this.url=r,this.apiKey=s,this.standardHeaders=d,this.eventCallback=S,this.fallbackPoller=g}start(){let e=c=>{c.toString().split(/\r?\n/).forEach(a)},a=c=>{if(c.startsWith("data:")){let y=JSON.parse(c.substring(5));this.logDebug("Received event from stream: ",y),this.eventCallback(y)}},r=()=>{this.logDebug("Stream connected"),this.eventBus.emit("connected")},s=()=>{clearInterval(this.readTimeoutCheckerId);let c=M(1e3,1e4);this.logDebug("Stream disconnected, will reconnect in "+c+"ms"),this.eventBus.emit("disconnected"),setTimeout(()=>this.start(),c)},d=c=>{c&&w("Stream has issue",c),this.fallBackToPolling(),this.eventBus.emit("stream error",c),this.eventBus.emit("error",c),s()},g=T({"Cache-Control":"no-cache",Accept:"text/event-stream","API-Key":this.apiKey},this.standardHeaders);this.logDebug("SSE HTTP start request",this.url),this.xhr=new XMLHttpRequest,this.xhr.open("GET",this.url);for(let[c,y]of Object.entries(g))this.xhr.setRequestHeader(c,y);this.xhr.timeout=24*60*60*1e3,this.xhr.onerror=()=>{d("XMLHttpRequest error on SSE stream")},this.xhr.onabort=()=>{this.logDebug("SSE aborted"),this.closed||d(null)},this.xhr.ontimeout=()=>{d("SSE timeout")},this.xhr.onload=()=>{if(this.xhr.status>=400&&this.xhr.status<=599){d(`HTTP code ${this.xhr.status}`);return}r()};let S=0,b=Date.now();this.xhr.onprogress=()=>{this.stopFallBackPolling(),b=Date.now();let c=this.xhr.responseText.slice(S);S+=c.length,this.logDebug("SSE GOT: "+c),e(c)},this.readTimeoutCheckerId=setInterval(()=>{b<Date.now()-ge&&(w("SSE read timeout"),this.xhr.abort())},ge),this.xhr.send()}close(){this.closed=!0,this.xhr&&this.xhr.abort(),clearInterval(this.readTimeoutCheckerId),this.stopFallBackPolling()}fallBackToPolling(){!this.fallbackPoller.isPolling()&&this.configurations.pollingEnabled&&(this.logDebug("Falling back to polling mode while stream recovers"),this.fallbackPoller.start())}stopFallBackPolling(){this.fallbackPoller.isPolling()&&(this.logDebug("Stopping fallback polling mode"),this.fallbackPoller.stop())}logDebug(e,...a){this.configurations.debug&&console.debug(`[FF-SDK] Streaming: ${e}`,...a)}};function he(n,e,a,r,s){let d=n in a,g=d?a[n]:e;return d&&r(n,g),s?{value:g,isDefaultValue:!d}:g}var F=class{constructor(e,a){this.fetchFlagsFn=e;this.configurations=a;this.maxAttempts=5}start(){if(this.isPolling()){this.logDebug("Already polling.");return}this.isRunning=!0,this.logDebug(`Starting poller, first poll will be in ${this.configurations.pollingInterval}ms`),this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)}poll(){this.attemptFetch().finally(()=>{this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)})}attemptFetch(){return D(this,null,function*(){for(let e=1;e<=this.maxAttempts;e++){let a=yield this.fetchFlagsFn();if(!a){this.logDebug(`Successfully polled for flag updates, next poll in ${this.configurations.pollingInterval}ms. `);return}if(w("Error when polling for flag updates",a),e>=this.maxAttempts){this.logDebug(`Maximum attempts reached for polling for flags. Next poll in ${this.configurations.pollingInterval}ms.`);return}this.logDebug(`Polling for flags attempt #${e} failed. Remaining attempts: ${this.maxAttempts-e}`,a);let r=M(1e3,1e4);yield new Promise(s=>setTimeout(s,r))}})}stop(){this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=void 0,this.isRunning=!1,this.logDebug("Polling stopped"))}isPolling(){return this.isRunning}logDebug(e,...a){this.configurations.debug&&console.debug(`[FF-SDK] Poller: ${e}`,...a)}};var Ee="1.16.0",me=`Javascript ${Ee} Client`,Ne=500,_e=globalThis.fetch,X=!!globalThis.Proxy,z=n=>{let{value:e}=n;try{switch(n.kind.toLowerCase()){case"int":case"number":e=Number(e);break;case"boolean":e=e.toString().toLowerCase()==="true";break;case"json":e=JSON.parse(e);break}}catch(a){w(a)}return e},gt=(n,e,a)=>{let r=!1,s,d,g,S,b,c,y=!0,x={},p=Y(t=>t),Q=0,Z=!1,k=()=>{y=!1},V=()=>{y=!0},R=[],u=ce(),f=de(a);f.eventsSyncInterval<6e4&&(f.eventsSyncInterval=6e4),f.pollingInterval<6e4&&(f.pollingInterval=6e4);let E=(t,...i)=>{f.debug&&console.debug(`[FF-SDK] ${t}`,...i)},$=t=>{if(y){let i=Date.now();i-t.lastAccessed>Ne&&(t.count++,t.lastAccessed=i)}};globalThis.onbeforeunload=()=>{R.length&&globalThis.localStorage&&(k(),globalThis.localStorage.HARNESS_FF_METRICS=JSON.stringify(R),V())};let be=(t,i)=>D(void 0,null,function*(){return(yield(yield _e(`${i.baseUrl}/client/auth`,{method:"POST",headers:{"Content-Type":"application/json","Harness-SDK-Info":me},body:JSON.stringify({apiKey:t,target:U(T({},e),{identifier:String(e.identifier)})})})).json()).authToken}),G=0,B=()=>{if(R.length){E("Sending metrics...",{metrics:R,evaluations:I});let t={metricsData:R.map(i=>({timestamp:Date.now(),count:i.count,metricsType:"FFMETRICS",attributes:[{key:"featureIdentifier",value:i.featureIdentifier},{key:"featureName",value:i.featureIdentifier},{key:"variationIdentifier",value:i.variationIdentifier},{key:"target",value:e.identifier},{key:"SDK_NAME",value:"JavaScript"},{key:"SDK_LANGUAGE",value:"JavaScript"},{key:"SDK_TYPE",value:"client"},{key:"SDK_VERSION",value:Ee}]}))};p(`${f.eventUrl}/metrics/${s}?cluster=${d}`,{method:"POST",headers:T({"Content-Type":"application/json"},x),body:JSON.stringify(t)}).then(()=>{R=[],G=0}).catch(i=>{G++&&(R=[],G=0),E(i),u.emit("metrics error",i)}).finally(()=>{c=window.setTimeout(B,f.eventsSyncInterval)})}else c=window.setTimeout(B,f.eventsSyncInterval)},I={},Re=t=>{E("Sending event for",t.flag),X?u.emit("changed",new Proxy(t,{get(i,l){var v;if(y&&i.hasOwnProperty(l)&&l==="value"){let m=i.flag,o=t.value,h=R.find(O=>O.featureIdentifier===m&&O.featureValue===o);h?($(h),h.variationIdentifier=((v=I[m])==null?void 0:v.identifier)||""):R.push({featureIdentifier:m,featureValue:String(o),variationIdentifier:I[m].identifier||"",count:1,lastAccessed:Date.now()}),E("Metrics event: Flag",l,"has been read with value via stream update",o)}return l==="value"?z(t):t[l]}})):u.emit("changed",{deleted:t.deleted,flag:t.flag,value:z(t)})},ee=function(){return X?new Proxy({},{get(t,i){var v,m,o;let l=t[i];if(y&&t.hasOwnProperty(i)){let h=t[i],O=R.find(ae=>ae.featureIdentifier===i&&h===ae.featureValue);O?(O.variationIdentifier=((v=I[i])==null?void 0:v.identifier)||"",$(O)):R.push({featureIdentifier:i,featureValue:h,variationIdentifier:((m=I[i])==null?void 0:m.identifier)||"",count:1,lastAccessed:Date.now()}),E("Metrics event: Flag:",i,"has been read with value:",h,"variationIdentifier:",(o=I[i])==null?void 0:o.identifier)}return l}}):{}},C=ee();be(n,f).then(t=>D(void 0,null,function*(){if(r)return;b=t;let i=le(t);if(x={Authorization:`Bearer ${b}`,"Harness-AccountID":i.accountID,"Harness-EnvironmentID":i.environmentIdentifier,"Harness-SDK-Info":me},E("Authenticated",i),globalThis.localStorage&&globalThis.localStorage.HARNESS_FF_METRICS)try{delete globalThis.localStorage.HARNESS_FF_METRICS,E("Picking up metrics from previous session")}catch(m){}c=window.setTimeout(B,f.eventsSyncInterval),s=i.environment,d=i.clusterIdentifier;let l=!!Object.keys(I).length;if((yield N())||E("Fetch all flags ok",C),!r){if(f.streamEnabled?(E("Streaming mode enabled"),Se()):f.pollingEnabled?(E("Polling mode enabled"),Ie()):E("Streaming and polling mode disabled"),!l){k();let m=T({},C);V(),u.emit("ready",m)}Z=!0}})).catch(t=>{w("Authentication error: ",t),u.emit("auth error",t),u.emit("error",t)});let N=()=>D(void 0,null,function*(){try{let t=yield p(`${f.baseUrl}/client/env/${s}/target/${e.identifier}/evaluations?cluster=${d}`,{headers:x});if(t.ok){let i=yield t.json();i.forEach(A),u.emit("flags loaded",i)}else w("Features fetch operation error: ",t),u.emit("fetch flags error",t),u.emit("error",t)}catch(t){return w("Features fetch operation error: ",t),u.emit("fetch flags error",t),u.emit("error",t),t}}),te=t=>D(void 0,null,function*(){try{let i=yield p(`${f.baseUrl}/client/env/${s}/target/${e.identifier}/evaluations/${t}?cluster=${d}`,{headers:x});if(i.ok){let l=yield i.json();A(l)}else w("Feature fetch operation error: ",i),u.emit("fetch flag error",i),u.emit("error",i)}catch(i){w("Feature fetch operation error: ",i),u.emit("fetch flag error",i),u.emit("error",i)}}),A=t=>{k();let i=z(t);i!==C[t.flag]&&(E("Flag variation has changed for ",t.identifier),C[t.flag]=i,I[t.flag]=U(T({},t),{value:i}),Re(t)),V()};S=new F(N,f);let Se=()=>{let t=o=>{switch(o.event){case"create":l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):setTimeout(()=>te(o.identifier),1e3);break;case"patch":l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):te(o.identifier);break;case"delete":delete C[o.identifier],u.emit("changed",{flag:o.identifier,value:void 0,deleted:!0}),E("Evaluation deleted",{message:o,storage:C});break}},i=o=>!(!o||!o.flag||!o.identifier||!o.kind||!o.value),l=o=>!(!o||o.length==0||!o.every(h=>i(h))),v=o=>{o.event==="patch"&&(l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):N())},m=`${f.baseUrl}/stream?cluster=${d}`;g=new L(u,f,m,n,x,S,o=>{o.domain==="flag"?t(o):o.domain==="target-segment"&&v(o)}),g.start()},Ie=()=>{S.start()},K=(t,i)=>u.on(t,i),we=(t,i)=>{t?u.off(t,i):ie()},ye=(t,i)=>{var o;if(!y||X||i===void 0)return;let l=i,v=t,m=R.find(h=>h.featureIdentifier===v&&h.featureValue===l);m?($(m),m.variationIdentifier=((o=I[v])==null?void 0:o.identifier)||""):R.push({featureIdentifier:v,featureValue:l,count:1,variationIdentifier:I[v].identifier||"",lastAccessed:Date.now()})},ie=()=>{r=!0,E("Closing event stream"),C=ee(),I={},clearTimeout(c),u.all.clear(),typeof(g==null?void 0:g.close)=="function"&&g.close()},ne=(t,i=!0)=>{t.length&&J(()=>{let l=!!Object.keys(I).length;if(t.forEach(A),!l){k();let v=T({},C);V(),u.emit("ready",v)}},i)};if(f.cache&&"localStorage"in window){let t=!0,i=P(e.identifier,typeof f.cache=="boolean"?{}:f.cache);i!=null&&i.length&&J(()=>{E("loading from cache",i),ne(i,!1),u.emit("cache loaded",i)}),K("flags loaded",l=>{H(e.identifier,l),t=!1}),K("changed",l=>{t||(l.deleted?fe(e.identifier,l.flag):ue(e.identifier,l))})}return{on:K,off:we,close:ie,setEvaluations:ne,registerAPIRequestMiddleware:t=>{p=Y(t)},refreshEvaluations:()=>{Z&&!r&&Date.now()-Q>=6e4&&(N(),Q=Date.now())},variation:(t,i,l=!1)=>he(t,i,C,ye,l)}};export{j as Event,gt as initialize};
var Ce=Object.defineProperty,Te=Object.defineProperties;var De=Object.getOwnPropertyDescriptors;var re=Object.getOwnPropertySymbols;var Ae=Object.prototype.hasOwnProperty,Oe=Object.prototype.propertyIsEnumerable;var oe=(n,e,a)=>e in n?Ce(n,e,{enumerable:!0,configurable:!0,writable:!0,value:a}):n[e]=a,C=(n,e)=>{for(var a in e||(e={}))Ae.call(e,a)&&oe(n,a,e[a]);if(re)for(var a of re(e))Oe.call(e,a)&&oe(n,a,e[a]);return n},U=(n,e)=>Te(n,De(e));var D=(n,e,a)=>new Promise((r,s)=>{var d=R=>{try{b(a.next(R))}catch(c){s(c)}},g=R=>{try{b(a.throw(R))}catch(c){s(c)}},b=R=>R.done?r(R.value):Promise.resolve(R.value).then(d,g);b((a=a.apply(n,e)).next())});function q(n){this.message=n}q.prototype=new Error,q.prototype.name="InvalidCharacterError";var se=typeof window!="undefined"&&window.atob&&window.atob.bind(window)||function(n){var e=String(n).replace(/=+$/,"");if(e.length%4==1)throw new q("'atob' failed: The string to be decoded is not correctly encoded.");for(var a,r,s=0,d=0,g="";r=e.charAt(d++);~r&&(a=s%4?64*a+r:r,s++%4)?g+=String.fromCharCode(255&a>>(-2*s&6)):0)r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(r);return g};function xe(n){var e=n.replace(/-/g,"+").replace(/_/g,"/");switch(e.length%4){case 0:break;case 2:e+="==";break;case 3:e+="=";break;default:throw"Illegal base64url string!"}try{return function(a){return decodeURIComponent(se(a).replace(/(.)/g,function(r,s){var d=s.charCodeAt(0).toString(16).toUpperCase();return d.length<2&&(d="0"+d),"%"+d}))}(e)}catch(a){return se(e)}}function _(n){this.message=n}function Fe(n,e){if(typeof n!="string")throw new _("Invalid token specified");var a=(e=e||{}).header===!0?0:1;try{return JSON.parse(xe(n.split(".")[a]))}catch(r){throw new _("Invalid token specified: "+r.message)}}_.prototype=new Error,_.prototype.name="InvalidTokenError";var le=Fe;function ce(n){return{all:n=n||new Map,on:function(e,a){var r=n.get(e);r&&r.push(a)||n.set(e,[a])},off:function(e,a){var r=n.get(e);r&&r.splice(r.indexOf(a)>>>0,1)},emit:function(e,a){(n.get(e)||[]).slice().map(function(r){r(a)}),(n.get("*")||[]).slice().map(function(r){r(e,a)})}}}var j=(p=>(p.READY="ready",p.CONNECTED="connected",p.DISCONNECTED="disconnected",p.FLAGS_LOADED="flags loaded",p.CACHE_LOADED="cache loaded",p.CHANGED="changed",p.ERROR="error",p.ERROR_METRICS="metrics error",p.ERROR_AUTH="auth error",p.ERROR_FETCH_FLAGS="fetch flags error",p.ERROR_FETCH_FLAG="fetch flag error",p.ERROR_STREAM="stream error",p))(j||{});var ke={debug:!1,baseUrl:"https://config.ff.harness.io/api/1.0",eventUrl:"https://events.ff.harness.io/api/1.0",eventsSyncInterval:6e4,pollingInterval:6e4,streamEnabled:!0,allAttributesPrivate:!1,privateAttributeNames:[],cache:!1},de=n=>{let e=C(C({},ke),n);return e.pollingEnabled===void 0&&(e.pollingEnabled=e.streamEnabled),e},w=(n,...e)=>console.error(`[FF-SDK] ${n}`,...e),J=(n,e=!0)=>{e?setTimeout(n,0):n()},M=(n,e)=>Math.round(Math.random()*(e-n)+n);function W(n){return"HARNESS_FF_CACHE_"+n}function P(n,e={}){let a=W(n),r=parseInt(window.localStorage.getItem(a+".ts"));if(e!=null&&e.ttl&&!isNaN(r)&&r+e.ttl<Date.now())return Ve(n),[];let s=window.localStorage.getItem(a);if(s)try{return JSON.parse(s)}catch(d){}return[]}function H(n,e){let a=W(n);window.localStorage.setItem(a,JSON.stringify(e)),window.localStorage.setItem(a+".ts",Date.now().toString())}function ue(n,e){let a=P(n),r=a.find(({flag:s})=>s===e.flag);r?Object.assign(r,e):a.push(e),H(n,a)}function fe(n,e){let a=P(n),r=a.findIndex(({flag:s})=>s===e);r>-1&&(a.splice(r,1),H(n,a))}function Ve(n){let e=W(n);window.localStorage.removeItem(e),window.localStorage.removeItem(e+".ts")}function Y(n){return function(...a){let[r,s]=n(a);return fetch(r,s)}}var ge=3e4,L=class{constructor(e,a,r,s,d,g,b){this.closed=!1;this.eventBus=e,this.configurations=a,this.url=r,this.apiKey=s,this.standardHeaders=d,this.eventCallback=b,this.fallbackPoller=g}start(){let e=c=>{c.toString().split(/\r?\n/).forEach(a)},a=c=>{if(c.startsWith("data:")){let y=JSON.parse(c.substring(5));this.logDebug("Received event from stream: ",y),this.eventCallback(y)}},r=()=>{this.logDebug("Stream connected"),this.eventBus.emit("connected")},s=()=>{clearInterval(this.readTimeoutCheckerId);let c=M(1e3,1e4);this.logDebug("Stream disconnected, will reconnect in "+c+"ms"),this.eventBus.emit("disconnected"),setTimeout(()=>this.start(),c)},d=c=>{c&&w("Stream has issue",c),this.fallBackToPolling(),this.eventBus.emit("stream error",c),this.eventBus.emit("error",c),s()},g=C({"Cache-Control":"no-cache",Accept:"text/event-stream","API-Key":this.apiKey},this.standardHeaders);this.logDebug("SSE HTTP start request",this.url),this.xhr=new XMLHttpRequest,this.xhr.open("GET",this.url);for(let[c,y]of Object.entries(g))this.xhr.setRequestHeader(c,y);this.xhr.timeout=24*60*60*1e3,this.xhr.onerror=()=>{d("XMLHttpRequest error on SSE stream")},this.xhr.onabort=()=>{this.logDebug("SSE aborted"),this.closed||d(null)},this.xhr.ontimeout=()=>{d("SSE timeout")},this.xhr.onload=()=>{if(this.xhr.status>=400&&this.xhr.status<=599){d(`HTTP code ${this.xhr.status}`);return}r()};let b=0,R=Date.now();this.xhr.onprogress=()=>{this.stopFallBackPolling(),R=Date.now();let c=this.xhr.responseText.slice(b);b+=c.length,this.logDebug("SSE GOT: "+c),e(c)},this.readTimeoutCheckerId=setInterval(()=>{R<Date.now()-ge&&(w("SSE read timeout"),this.xhr.abort())},ge),this.xhr.send()}close(){this.closed=!0,this.xhr&&this.xhr.abort(),clearInterval(this.readTimeoutCheckerId),this.stopFallBackPolling()}fallBackToPolling(){!this.fallbackPoller.isPolling()&&this.configurations.pollingEnabled&&(this.logDebug("Falling back to polling mode while stream recovers"),this.fallbackPoller.start())}stopFallBackPolling(){this.fallbackPoller.isPolling()&&(this.logDebug("Stopping fallback polling mode"),this.fallbackPoller.stop())}logDebug(e,...a){this.configurations.debug&&console.debug(`[FF-SDK] Streaming: ${e}`,...a)}};function he(n,e,a,r,s){let d=n in a,g=d?a[n]:e;return d&&r(n,g),s?{value:g,isDefaultValue:!d}:g}var F=class{constructor(e,a){this.fetchFlagsFn=e;this.configurations=a;this.maxAttempts=5}start(){if(this.isPolling()){this.logDebug("Already polling.");return}this.isRunning=!0,this.logDebug(`Starting poller, first poll will be in ${this.configurations.pollingInterval}ms`),this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)}poll(){this.attemptFetch().finally(()=>{this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)})}attemptFetch(){return D(this,null,function*(){for(let e=1;e<=this.maxAttempts;e++){let a=yield this.fetchFlagsFn();if(!a){this.logDebug(`Successfully polled for flag updates, next poll in ${this.configurations.pollingInterval}ms. `);return}if(w("Error when polling for flag updates",a),e>=this.maxAttempts){this.logDebug(`Maximum attempts reached for polling for flags. Next poll in ${this.configurations.pollingInterval}ms.`);return}this.logDebug(`Polling for flags attempt #${e} failed. Remaining attempts: ${this.maxAttempts-e}`,a);let r=M(1e3,1e4);yield new Promise(s=>setTimeout(s,r))}})}stop(){this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=void 0,this.isRunning=!1,this.logDebug("Polling stopped"))}isPolling(){return this.isRunning}logDebug(e,...a){this.configurations.debug&&console.debug(`[FF-SDK] Poller: ${e}`,...a)}};var Ee="1.16.0",me=`Javascript ${Ee} Client`,Ne=500,_e=globalThis.fetch,X=!!globalThis.Proxy,z=n=>{let{value:e}=n;try{switch(n.kind.toLowerCase()){case"int":case"number":e=Number(e);break;case"boolean":e=e.toString().toLowerCase()==="true";break;case"json":e=JSON.parse(e);break}}catch(a){w(a)}return e},gt=(n,e,a)=>{let r=!1,s,d,g,b,R,c,y=!0,x={},p=Y(t=>t),Q=0,Z=!1,k=()=>{y=!1},V=()=>{y=!0},S=[],u=ce(),f=de(a);f.eventsSyncInterval<6e4&&(f.eventsSyncInterval=6e4),f.pollingInterval<6e4&&(f.pollingInterval=6e4);let v=(t,...i)=>{f.debug&&console.debug(`[FF-SDK] ${t}`,...i)},$=t=>{if(y){let i=Date.now();i-t.lastAccessed>Ne&&(t.count++,t.lastAccessed=i)}};globalThis.onbeforeunload=()=>{S.length&&globalThis.localStorage&&(k(),globalThis.localStorage.HARNESS_FF_METRICS=JSON.stringify(S),V())};let be=(t,i)=>D(void 0,null,function*(){return(yield(yield _e(`${i.baseUrl}/client/auth`,{method:"POST",headers:{"Content-Type":"application/json","Harness-SDK-Info":me},body:JSON.stringify({apiKey:t,target:U(C({},e),{identifier:String(e.identifier)})})})).json()).authToken}),G=0,B=()=>{if(S.length){v("Sending metrics...",{metrics:S,evaluations:I});let t={metricsData:S.map(i=>({timestamp:Date.now(),count:i.count,metricsType:"FFMETRICS",attributes:[{key:"featureIdentifier",value:i.featureIdentifier},{key:"featureName",value:i.featureIdentifier},{key:"variationIdentifier",value:i.variationIdentifier},{key:"target",value:e.identifier},{key:"SDK_NAME",value:"JavaScript"},{key:"SDK_LANGUAGE",value:"JavaScript"},{key:"SDK_TYPE",value:"client"},{key:"SDK_VERSION",value:Ee}]}))};p(`${f.eventUrl}/metrics/${s}?cluster=${d}`,{method:"POST",headers:C({"Content-Type":"application/json"},x),body:JSON.stringify(t)}).then(()=>{S=[],G=0}).catch(i=>{G++&&(S=[],G=0),v(i),u.emit("metrics error",i)}).finally(()=>{c=window.setTimeout(B,f.eventsSyncInterval)})}else c=window.setTimeout(B,f.eventsSyncInterval)},I={},Re=t=>{v("Sending event for",t.flag),X?u.emit("changed",new Proxy(t,{get(i,l){var m;if(y&&i.hasOwnProperty(l)&&l==="value"){let E=i.flag,o=t.value,h=S.find(O=>O.featureIdentifier===E&&O.featureValue===o);h?($(h),h.variationIdentifier=((m=I[E])==null?void 0:m.identifier)||""):S.push({featureIdentifier:E,featureValue:String(o),variationIdentifier:I[E].identifier||"",count:1,lastAccessed:Date.now()}),v("Metrics event: Flag",l,"has been read with value via stream update",o)}return l==="value"?z(t):t[l]}})):u.emit("changed",{deleted:t.deleted,flag:t.flag,value:z(t)})},ee=function(){return X?new Proxy({},{get(t,i){var m,E,o;let l=t[i];if(y&&t.hasOwnProperty(i)){let h=t[i],O=S.find(ae=>ae.featureIdentifier===i&&h===ae.featureValue);O?(O.variationIdentifier=((m=I[i])==null?void 0:m.identifier)||"",$(O)):S.push({featureIdentifier:i,featureValue:h,variationIdentifier:((E=I[i])==null?void 0:E.identifier)||"",count:1,lastAccessed:Date.now()}),v("Metrics event: Flag:",i,"has been read with value:",h,"variationIdentifier:",(o=I[i])==null?void 0:o.identifier)}return l}}):{}},T=ee();be(n,f).then(t=>D(void 0,null,function*(){if(r)return;R=t;let i=le(t);if(x={Authorization:`Bearer ${R}`,"Harness-AccountID":i.accountID,"Harness-EnvironmentID":i.environmentIdentifier,"Harness-SDK-Info":me},v("Authenticated",i),globalThis.localStorage&&globalThis.localStorage.HARNESS_FF_METRICS)try{delete globalThis.localStorage.HARNESS_FF_METRICS,v("Picking up metrics from previous session")}catch(E){}c=window.setTimeout(B,f.eventsSyncInterval),s=i.environment,d=i.clusterIdentifier;let l=!!Object.keys(I).length;if((yield N())||v("Fetch all flags ok",T),!r){if(f.streamEnabled?(v("Streaming mode enabled"),Se()):f.pollingEnabled?(v("Polling mode enabled"),Ie()):v("Streaming and polling mode disabled"),!l){k();let E=C({},T);V(),u.emit("ready",E)}Z=!0}})).catch(t=>{w("Authentication error: ",t),u.emit("auth error",t),u.emit("error",t)});let N=()=>D(void 0,null,function*(){try{let t=yield p(`${f.baseUrl}/client/env/${s}/target/${e.identifier}/evaluations?cluster=${d}`,{headers:x});if(t.ok){let i=yield t.json();i.forEach(A),u.emit("flags loaded",i)}else w("Features fetch operation error: ",t),u.emit("fetch flags error",t),u.emit("error",t)}catch(t){return w("Features fetch operation error: ",t),u.emit("fetch flags error",t),u.emit("error",t),t}}),te=t=>D(void 0,null,function*(){try{let i=yield p(`${f.baseUrl}/client/env/${s}/target/${e.identifier}/evaluations/${t}?cluster=${d}`,{headers:x});if(i.ok){let l=yield i.json();A(l)}else w("Feature fetch operation error: ",i),u.emit("fetch flag error",i),u.emit("error",i)}catch(i){w("Feature fetch operation error: ",i),u.emit("fetch flag error",i),u.emit("error",i)}}),A=t=>{k();let i=z(t);i!==T[t.flag]&&(v("Flag variation has changed for ",t.identifier),T[t.flag]=i,I[t.flag]=U(C({},t),{value:i}),Re(t)),V()};b=new F(N,f);let Se=()=>{let t=o=>{switch(o.event){case"create":l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):setTimeout(()=>te(o.identifier),1e3);break;case"patch":l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):te(o.identifier);break;case"delete":delete T[o.identifier],u.emit("changed",{flag:o.identifier,value:void 0,deleted:!0}),v("Evaluation deleted",{message:o,storage:T});break}},i=o=>!(!o||!o.flag||!o.identifier||!o.kind||!o.value),l=o=>!(!o||o.length==0||!o.every(h=>i(h))),m=o=>{o.event==="patch"&&(l(o.evaluations)?o.evaluations.forEach(h=>{A(h)}):N())},E=`${f.baseUrl}/stream?cluster=${d}`;g=new L(u,f,E,n,x,b,o=>{o.domain==="flag"?t(o):o.domain==="target-segment"&&m(o)}),g.start()},Ie=()=>{b.start()},K=(t,i)=>u.on(t,i),we=(t,i)=>{t?u.off(t,i):ie()},ye=(t,i)=>{var o;if(!y||X||i===void 0)return;let l=i,m=t,E=S.find(h=>h.featureIdentifier===m&&h.featureValue===l);E?($(E),E.variationIdentifier=((o=I[m])==null?void 0:o.identifier)||""):S.push({featureIdentifier:m,featureValue:l,count:1,variationIdentifier:I[m].identifier||"",lastAccessed:Date.now()})},ie=()=>{r=!0,f.streamEnabled&&(v("Closing event stream"),typeof(g==null?void 0:g.close)=="function"&&g.close(),u.all.clear()),f.pollingEnabled&&b.isPolling()&&(v("Closing Poller"),b.stop()),T=ee(),I={},clearTimeout(c)},ne=(t,i=!0)=>{t.length&&J(()=>{let l=!!Object.keys(I).length;if(t.forEach(A),!l){k();let m=C({},T);V(),u.emit("ready",m)}},i)};if(f.cache&&"localStorage"in window){let t=!0,i=P(e.identifier,typeof f.cache=="boolean"?{}:f.cache);i!=null&&i.length&&J(()=>{v("loading from cache",i),ne(i,!1),u.emit("cache loaded",i)}),K("flags loaded",l=>{H(e.identifier,l),t=!1}),K("changed",l=>{t||(l.deleted?fe(e.identifier,l.flag):ue(e.identifier,l))})}return{on:K,off:we,close:ie,setEvaluations:ne,registerAPIRequestMiddleware:t=>{p=Y(t)},refreshEvaluations:()=>{Z&&!r&&Date.now()-Q>=6e4&&(N(),Q=Date.now())},variation:(t,i,l=!1)=>he(t,i,T,ye,l)}};export{j as Event,gt as initialize};

@@ -1,1 +0,1 @@

var Re=Object.defineProperty,Se=Object.defineProperties;var Ie=Object.getOwnPropertyDescriptors;var ne=Object.getOwnPropertySymbols;var ye=Object.prototype.hasOwnProperty,De=Object.prototype.propertyIsEnumerable;var ae=(a,e,n)=>e in a?Re(a,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):a[e]=n,T=(a,e)=>{for(var n in e||(e={}))ye.call(e,n)&&ae(a,n,e[n]);if(ne)for(var n of ne(e))De.call(e,n)&&ae(a,n,e[n]);return a},K=(a,e)=>Se(a,Ie(e));var C=(a,e,n)=>new Promise((l,c)=>{var f=b=>{try{S(n.next(b))}catch(s){c(s)}},v=b=>{try{S(n.throw(b))}catch(s){c(s)}},S=b=>b.done?l(b.value):Promise.resolve(b.value).then(f,v);S((n=n.apply(a,e)).next())});import Ce from"jwt-decode";import Ae from"mitt";var q=(h=>(h.READY="ready",h.CONNECTED="connected",h.DISCONNECTED="disconnected",h.FLAGS_LOADED="flags loaded",h.CACHE_LOADED="cache loaded",h.CHANGED="changed",h.ERROR="error",h.ERROR_METRICS="metrics error",h.ERROR_AUTH="auth error",h.ERROR_FETCH_FLAGS="fetch flags error",h.ERROR_FETCH_FLAG="fetch flag error",h.ERROR_STREAM="stream error",h))(q||{});var Te={debug:!1,baseUrl:"https://config.ff.harness.io/api/1.0",eventUrl:"https://events.ff.harness.io/api/1.0",eventsSyncInterval:6e4,pollingInterval:6e4,streamEnabled:!0,allAttributesPrivate:!1,privateAttributeNames:[],cache:!1},re=a=>{let e=T(T({},Te),a);return e.pollingEnabled===void 0&&(e.pollingEnabled=e.streamEnabled),e},y=(a,...e)=>console.error(`[FF-SDK] ${a}`,...e),U=(a,e=!0)=>{e?setTimeout(a,0):a()},_=(a,e)=>Math.round(Math.random()*(e-a)+a);function j(a){return"HARNESS_FF_CACHE_"+a}function M(a,e={}){let n=j(a),l=parseInt(window.localStorage.getItem(n+".ts"));if(e!=null&&e.ttl&&!isNaN(l)&&l+e.ttl<Date.now())return we(a),[];let c=window.localStorage.getItem(n);if(c)try{return JSON.parse(c)}catch(f){}return[]}function P(a,e){let n=j(a);window.localStorage.setItem(n,JSON.stringify(e)),window.localStorage.setItem(n+".ts",Date.now().toString())}function oe(a,e){let n=M(a),l=n.find(({flag:c})=>c===e.flag);l?Object.assign(l,e):n.push(e),P(a,n)}function se(a,e){let n=M(a),l=n.findIndex(({flag:c})=>c===e);l>-1&&(n.splice(l,1),P(a,n))}function we(a){let e=j(a);window.localStorage.removeItem(e),window.localStorage.removeItem(e+".ts")}function W(a){return function(...n){let[l,c]=a(n);return fetch(l,c)}}var le=3e4,H=class{constructor(e,n,l,c,f,v,S){this.closed=!1;this.eventBus=e,this.configurations=n,this.url=l,this.apiKey=c,this.standardHeaders=f,this.eventCallback=S,this.fallbackPoller=v}start(){let e=s=>{s.toString().split(/\r?\n/).forEach(n)},n=s=>{if(s.startsWith("data:")){let D=JSON.parse(s.substring(5));this.logDebug("Received event from stream: ",D),this.eventCallback(D)}},l=()=>{this.logDebug("Stream connected"),this.eventBus.emit("connected")},c=()=>{clearInterval(this.readTimeoutCheckerId);let s=_(1e3,1e4);this.logDebug("Stream disconnected, will reconnect in "+s+"ms"),this.eventBus.emit("disconnected"),setTimeout(()=>this.start(),s)},f=s=>{s&&y("Stream has issue",s),this.fallBackToPolling(),this.eventBus.emit("stream error",s),this.eventBus.emit("error",s),c()},v=T({"Cache-Control":"no-cache",Accept:"text/event-stream","API-Key":this.apiKey},this.standardHeaders);this.logDebug("SSE HTTP start request",this.url),this.xhr=new XMLHttpRequest,this.xhr.open("GET",this.url);for(let[s,D]of Object.entries(v))this.xhr.setRequestHeader(s,D);this.xhr.timeout=24*60*60*1e3,this.xhr.onerror=()=>{f("XMLHttpRequest error on SSE stream")},this.xhr.onabort=()=>{this.logDebug("SSE aborted"),this.closed||f(null)},this.xhr.ontimeout=()=>{f("SSE timeout")},this.xhr.onload=()=>{if(this.xhr.status>=400&&this.xhr.status<=599){f(`HTTP code ${this.xhr.status}`);return}l()};let S=0,b=Date.now();this.xhr.onprogress=()=>{this.stopFallBackPolling(),b=Date.now();let s=this.xhr.responseText.slice(S);S+=s.length,this.logDebug("SSE GOT: "+s),e(s)},this.readTimeoutCheckerId=setInterval(()=>{b<Date.now()-le&&(y("SSE read timeout"),this.xhr.abort())},le),this.xhr.send()}close(){this.closed=!0,this.xhr&&this.xhr.abort(),clearInterval(this.readTimeoutCheckerId),this.stopFallBackPolling()}fallBackToPolling(){!this.fallbackPoller.isPolling()&&this.configurations.pollingEnabled&&(this.logDebug("Falling back to polling mode while stream recovers"),this.fallbackPoller.start())}stopFallBackPolling(){this.fallbackPoller.isPolling()&&(this.logDebug("Stopping fallback polling mode"),this.fallbackPoller.stop())}logDebug(e,...n){this.configurations.debug&&console.debug(`[FF-SDK] Streaming: ${e}`,...n)}};function ce(a,e,n,l,c){let f=a in n,v=f?n[a]:e;return f&&l(a,v),c?{value:v,isDefaultValue:!f}:v}var x=class{constructor(e,n){this.fetchFlagsFn=e;this.configurations=n;this.maxAttempts=5}start(){if(this.isPolling()){this.logDebug("Already polling.");return}this.isRunning=!0,this.logDebug(`Starting poller, first poll will be in ${this.configurations.pollingInterval}ms`),this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)}poll(){this.attemptFetch().finally(()=>{this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)})}attemptFetch(){return C(this,null,function*(){for(let e=1;e<=this.maxAttempts;e++){let n=yield this.fetchFlagsFn();if(!n){this.logDebug(`Successfully polled for flag updates, next poll in ${this.configurations.pollingInterval}ms. `);return}if(y("Error when polling for flag updates",n),e>=this.maxAttempts){this.logDebug(`Maximum attempts reached for polling for flags. Next poll in ${this.configurations.pollingInterval}ms.`);return}this.logDebug(`Polling for flags attempt #${e} failed. Remaining attempts: ${this.maxAttempts-e}`,n);let l=_(1e3,1e4);yield new Promise(c=>setTimeout(c,l))}})}stop(){this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=void 0,this.isRunning=!1,this.logDebug("Polling stopped"))}isPolling(){return this.isRunning}logDebug(e,...n){this.configurations.debug&&console.debug(`[FF-SDK] Poller: ${e}`,...n)}};var ge="1.16.0",fe=`Javascript ${ge} Client`,Oe=500,Fe=globalThis.fetch,J=!!globalThis.Proxy,Y=a=>{let{value:e}=a;try{switch(a.kind.toLowerCase()){case"int":case"number":e=Number(e);break;case"boolean":e=e.toString().toLowerCase()==="true";break;case"json":e=JSON.parse(e);break}}catch(n){y(n)}return e},ot=(a,e,n)=>{let l=!1,c,f,v,S,b,s,D=!0,F={},h=W(t=>t),X=0,z=!1,V=()=>{D=!1},k=()=>{D=!0},R=[],d=Ae(),u=re(n);u.eventsSyncInterval<6e4&&(u.eventsSyncInterval=6e4),u.pollingInterval<6e4&&(u.pollingInterval=6e4);let E=(t,...i)=>{u.debug&&console.debug(`[FF-SDK] ${t}`,...i)},L=t=>{if(D){let i=Date.now();i-t.lastAccessed>Oe&&(t.count++,t.lastAccessed=i)}};globalThis.onbeforeunload=()=>{R.length&&globalThis.localStorage&&(V(),globalThis.localStorage.HARNESS_FF_METRICS=JSON.stringify(R),k())};let he=(t,i)=>C(void 0,null,function*(){return(yield(yield Fe(`${i.baseUrl}/client/auth`,{method:"POST",headers:{"Content-Type":"application/json","Harness-SDK-Info":fe},body:JSON.stringify({apiKey:t,target:K(T({},e),{identifier:String(e.identifier)})})})).json()).authToken}),$=0,G=()=>{if(R.length){E("Sending metrics...",{metrics:R,evaluations:I});let t={metricsData:R.map(i=>({timestamp:Date.now(),count:i.count,metricsType:"FFMETRICS",attributes:[{key:"featureIdentifier",value:i.featureIdentifier},{key:"featureName",value:i.featureIdentifier},{key:"variationIdentifier",value:i.variationIdentifier},{key:"target",value:e.identifier},{key:"SDK_NAME",value:"JavaScript"},{key:"SDK_LANGUAGE",value:"JavaScript"},{key:"SDK_TYPE",value:"client"},{key:"SDK_VERSION",value:ge}]}))};h(`${u.eventUrl}/metrics/${c}?cluster=${f}`,{method:"POST",headers:T({"Content-Type":"application/json"},F),body:JSON.stringify(t)}).then(()=>{R=[],$=0}).catch(i=>{$++&&(R=[],$=0),E(i),d.emit("metrics error",i)}).finally(()=>{s=window.setTimeout(G,u.eventsSyncInterval)})}else s=window.setTimeout(G,u.eventsSyncInterval)},I={},ve=t=>{E("Sending event for",t.flag),J?d.emit("changed",new Proxy(t,{get(i,o){var p;if(D&&i.hasOwnProperty(o)&&o==="value"){let m=i.flag,r=t.value,g=R.find(O=>O.featureIdentifier===m&&O.featureValue===r);g?(L(g),g.variationIdentifier=((p=I[m])==null?void 0:p.identifier)||""):R.push({featureIdentifier:m,featureValue:String(r),variationIdentifier:I[m].identifier||"",count:1,lastAccessed:Date.now()}),E("Metrics event: Flag",o,"has been read with value via stream update",r)}return o==="value"?Y(t):t[o]}})):d.emit("changed",{deleted:t.deleted,flag:t.flag,value:Y(t)})},Q=function(){return J?new Proxy({},{get(t,i){var p,m,r;let o=t[i];if(D&&t.hasOwnProperty(i)){let g=t[i],O=R.find(ie=>ie.featureIdentifier===i&&g===ie.featureValue);O?(O.variationIdentifier=((p=I[i])==null?void 0:p.identifier)||"",L(O)):R.push({featureIdentifier:i,featureValue:g,variationIdentifier:((m=I[i])==null?void 0:m.identifier)||"",count:1,lastAccessed:Date.now()}),E("Metrics event: Flag:",i,"has been read with value:",g,"variationIdentifier:",(r=I[i])==null?void 0:r.identifier)}return o}}):{}},w=Q();he(a,u).then(t=>C(void 0,null,function*(){if(l)return;b=t;let i=Ce(t);if(F={Authorization:`Bearer ${b}`,"Harness-AccountID":i.accountID,"Harness-EnvironmentID":i.environmentIdentifier,"Harness-SDK-Info":fe},E("Authenticated",i),globalThis.localStorage&&globalThis.localStorage.HARNESS_FF_METRICS)try{delete globalThis.localStorage.HARNESS_FF_METRICS,E("Picking up metrics from previous session")}catch(m){}s=window.setTimeout(G,u.eventsSyncInterval),c=i.environment,f=i.clusterIdentifier;let o=!!Object.keys(I).length;if((yield N())||E("Fetch all flags ok",w),!l){if(u.streamEnabled?(E("Streaming mode enabled"),pe()):u.pollingEnabled?(E("Polling mode enabled"),me()):E("Streaming and polling mode disabled"),!o){V();let m=T({},w);k(),d.emit("ready",m)}z=!0}})).catch(t=>{y("Authentication error: ",t),d.emit("auth error",t),d.emit("error",t)});let N=()=>C(void 0,null,function*(){try{let t=yield h(`${u.baseUrl}/client/env/${c}/target/${e.identifier}/evaluations?cluster=${f}`,{headers:F});if(t.ok){let i=yield t.json();i.forEach(A),d.emit("flags loaded",i)}else y("Features fetch operation error: ",t),d.emit("fetch flags error",t),d.emit("error",t)}catch(t){return y("Features fetch operation error: ",t),d.emit("fetch flags error",t),d.emit("error",t),t}}),Z=t=>C(void 0,null,function*(){try{let i=yield h(`${u.baseUrl}/client/env/${c}/target/${e.identifier}/evaluations/${t}?cluster=${f}`,{headers:F});if(i.ok){let o=yield i.json();A(o)}else y("Feature fetch operation error: ",i),d.emit("fetch flag error",i),d.emit("error",i)}catch(i){y("Feature fetch operation error: ",i),d.emit("fetch flag error",i),d.emit("error",i)}}),A=t=>{V();let i=Y(t);i!==w[t.flag]&&(E("Flag variation has changed for ",t.identifier),w[t.flag]=i,I[t.flag]=K(T({},t),{value:i}),ve(t)),k()};S=new x(N,u);let pe=()=>{let t=r=>{switch(r.event){case"create":o(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):setTimeout(()=>Z(r.identifier),1e3);break;case"patch":o(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):Z(r.identifier);break;case"delete":delete w[r.identifier],d.emit("changed",{flag:r.identifier,value:void 0,deleted:!0}),E("Evaluation deleted",{message:r,storage:w});break}},i=r=>!(!r||!r.flag||!r.identifier||!r.kind||!r.value),o=r=>!(!r||r.length==0||!r.every(g=>i(g))),p=r=>{r.event==="patch"&&(o(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):N())},m=`${u.baseUrl}/stream?cluster=${f}`;v=new H(d,u,m,a,F,S,r=>{r.domain==="flag"?t(r):r.domain==="target-segment"&&p(r)}),v.start()},me=()=>{S.start()},B=(t,i)=>d.on(t,i),Ee=(t,i)=>{t?d.off(t,i):ee()},be=(t,i)=>{var r;if(!D||J||i===void 0)return;let o=i,p=t,m=R.find(g=>g.featureIdentifier===p&&g.featureValue===o);m?(L(m),m.variationIdentifier=((r=I[p])==null?void 0:r.identifier)||""):R.push({featureIdentifier:p,featureValue:o,count:1,variationIdentifier:I[p].identifier||"",lastAccessed:Date.now()})},ee=()=>{l=!0,E("Closing event stream"),w=Q(),I={},clearTimeout(s),d.all.clear(),typeof(v==null?void 0:v.close)=="function"&&v.close()},te=(t,i=!0)=>{t.length&&U(()=>{let o=!!Object.keys(I).length;if(t.forEach(A),!o){V();let p=T({},w);k(),d.emit("ready",p)}},i)};if(u.cache&&"localStorage"in window){let t=!0,i=M(e.identifier,typeof u.cache=="boolean"?{}:u.cache);i!=null&&i.length&&U(()=>{E("loading from cache",i),te(i,!1),d.emit("cache loaded",i)}),B("flags loaded",o=>{P(e.identifier,o),t=!1}),B("changed",o=>{t||(o.deleted?se(e.identifier,o.flag):oe(e.identifier,o))})}return{on:B,off:Ee,close:ee,setEvaluations:te,registerAPIRequestMiddleware:t=>{h=W(t)},refreshEvaluations:()=>{z&&!l&&Date.now()-X>=6e4&&(N(),X=Date.now())},variation:(t,i,o=!1)=>ce(t,i,w,be,o)}};export{q as Event,ot as initialize};
var Re=Object.defineProperty,Se=Object.defineProperties;var Ie=Object.getOwnPropertyDescriptors;var ne=Object.getOwnPropertySymbols;var ye=Object.prototype.hasOwnProperty,De=Object.prototype.propertyIsEnumerable;var ae=(a,e,n)=>e in a?Re(a,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):a[e]=n,T=(a,e)=>{for(var n in e||(e={}))ye.call(e,n)&&ae(a,n,e[n]);if(ne)for(var n of ne(e))De.call(e,n)&&ae(a,n,e[n]);return a},K=(a,e)=>Se(a,Ie(e));var C=(a,e,n)=>new Promise((l,c)=>{var f=R=>{try{b(n.next(R))}catch(s){c(s)}},v=R=>{try{b(n.throw(R))}catch(s){c(s)}},b=R=>R.done?l(R.value):Promise.resolve(R.value).then(f,v);b((n=n.apply(a,e)).next())});import Ce from"jwt-decode";import Ae from"mitt";var q=(h=>(h.READY="ready",h.CONNECTED="connected",h.DISCONNECTED="disconnected",h.FLAGS_LOADED="flags loaded",h.CACHE_LOADED="cache loaded",h.CHANGED="changed",h.ERROR="error",h.ERROR_METRICS="metrics error",h.ERROR_AUTH="auth error",h.ERROR_FETCH_FLAGS="fetch flags error",h.ERROR_FETCH_FLAG="fetch flag error",h.ERROR_STREAM="stream error",h))(q||{});var Te={debug:!1,baseUrl:"https://config.ff.harness.io/api/1.0",eventUrl:"https://events.ff.harness.io/api/1.0",eventsSyncInterval:6e4,pollingInterval:6e4,streamEnabled:!0,allAttributesPrivate:!1,privateAttributeNames:[],cache:!1},re=a=>{let e=T(T({},Te),a);return e.pollingEnabled===void 0&&(e.pollingEnabled=e.streamEnabled),e},y=(a,...e)=>console.error(`[FF-SDK] ${a}`,...e),U=(a,e=!0)=>{e?setTimeout(a,0):a()},_=(a,e)=>Math.round(Math.random()*(e-a)+a);function j(a){return"HARNESS_FF_CACHE_"+a}function M(a,e={}){let n=j(a),l=parseInt(window.localStorage.getItem(n+".ts"));if(e!=null&&e.ttl&&!isNaN(l)&&l+e.ttl<Date.now())return we(a),[];let c=window.localStorage.getItem(n);if(c)try{return JSON.parse(c)}catch(f){}return[]}function P(a,e){let n=j(a);window.localStorage.setItem(n,JSON.stringify(e)),window.localStorage.setItem(n+".ts",Date.now().toString())}function oe(a,e){let n=M(a),l=n.find(({flag:c})=>c===e.flag);l?Object.assign(l,e):n.push(e),P(a,n)}function se(a,e){let n=M(a),l=n.findIndex(({flag:c})=>c===e);l>-1&&(n.splice(l,1),P(a,n))}function we(a){let e=j(a);window.localStorage.removeItem(e),window.localStorage.removeItem(e+".ts")}function W(a){return function(...n){let[l,c]=a(n);return fetch(l,c)}}var le=3e4,H=class{constructor(e,n,l,c,f,v,b){this.closed=!1;this.eventBus=e,this.configurations=n,this.url=l,this.apiKey=c,this.standardHeaders=f,this.eventCallback=b,this.fallbackPoller=v}start(){let e=s=>{s.toString().split(/\r?\n/).forEach(n)},n=s=>{if(s.startsWith("data:")){let D=JSON.parse(s.substring(5));this.logDebug("Received event from stream: ",D),this.eventCallback(D)}},l=()=>{this.logDebug("Stream connected"),this.eventBus.emit("connected")},c=()=>{clearInterval(this.readTimeoutCheckerId);let s=_(1e3,1e4);this.logDebug("Stream disconnected, will reconnect in "+s+"ms"),this.eventBus.emit("disconnected"),setTimeout(()=>this.start(),s)},f=s=>{s&&y("Stream has issue",s),this.fallBackToPolling(),this.eventBus.emit("stream error",s),this.eventBus.emit("error",s),c()},v=T({"Cache-Control":"no-cache",Accept:"text/event-stream","API-Key":this.apiKey},this.standardHeaders);this.logDebug("SSE HTTP start request",this.url),this.xhr=new XMLHttpRequest,this.xhr.open("GET",this.url);for(let[s,D]of Object.entries(v))this.xhr.setRequestHeader(s,D);this.xhr.timeout=24*60*60*1e3,this.xhr.onerror=()=>{f("XMLHttpRequest error on SSE stream")},this.xhr.onabort=()=>{this.logDebug("SSE aborted"),this.closed||f(null)},this.xhr.ontimeout=()=>{f("SSE timeout")},this.xhr.onload=()=>{if(this.xhr.status>=400&&this.xhr.status<=599){f(`HTTP code ${this.xhr.status}`);return}l()};let b=0,R=Date.now();this.xhr.onprogress=()=>{this.stopFallBackPolling(),R=Date.now();let s=this.xhr.responseText.slice(b);b+=s.length,this.logDebug("SSE GOT: "+s),e(s)},this.readTimeoutCheckerId=setInterval(()=>{R<Date.now()-le&&(y("SSE read timeout"),this.xhr.abort())},le),this.xhr.send()}close(){this.closed=!0,this.xhr&&this.xhr.abort(),clearInterval(this.readTimeoutCheckerId),this.stopFallBackPolling()}fallBackToPolling(){!this.fallbackPoller.isPolling()&&this.configurations.pollingEnabled&&(this.logDebug("Falling back to polling mode while stream recovers"),this.fallbackPoller.start())}stopFallBackPolling(){this.fallbackPoller.isPolling()&&(this.logDebug("Stopping fallback polling mode"),this.fallbackPoller.stop())}logDebug(e,...n){this.configurations.debug&&console.debug(`[FF-SDK] Streaming: ${e}`,...n)}};function ce(a,e,n,l,c){let f=a in n,v=f?n[a]:e;return f&&l(a,v),c?{value:v,isDefaultValue:!f}:v}var x=class{constructor(e,n){this.fetchFlagsFn=e;this.configurations=n;this.maxAttempts=5}start(){if(this.isPolling()){this.logDebug("Already polling.");return}this.isRunning=!0,this.logDebug(`Starting poller, first poll will be in ${this.configurations.pollingInterval}ms`),this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)}poll(){this.attemptFetch().finally(()=>{this.timeoutId=setTimeout(()=>this.poll(),this.configurations.pollingInterval)})}attemptFetch(){return C(this,null,function*(){for(let e=1;e<=this.maxAttempts;e++){let n=yield this.fetchFlagsFn();if(!n){this.logDebug(`Successfully polled for flag updates, next poll in ${this.configurations.pollingInterval}ms. `);return}if(y("Error when polling for flag updates",n),e>=this.maxAttempts){this.logDebug(`Maximum attempts reached for polling for flags. Next poll in ${this.configurations.pollingInterval}ms.`);return}this.logDebug(`Polling for flags attempt #${e} failed. Remaining attempts: ${this.maxAttempts-e}`,n);let l=_(1e3,1e4);yield new Promise(c=>setTimeout(c,l))}})}stop(){this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=void 0,this.isRunning=!1,this.logDebug("Polling stopped"))}isPolling(){return this.isRunning}logDebug(e,...n){this.configurations.debug&&console.debug(`[FF-SDK] Poller: ${e}`,...n)}};var ge="1.16.0",fe=`Javascript ${ge} Client`,Oe=500,Fe=globalThis.fetch,J=!!globalThis.Proxy,Y=a=>{let{value:e}=a;try{switch(a.kind.toLowerCase()){case"int":case"number":e=Number(e);break;case"boolean":e=e.toString().toLowerCase()==="true";break;case"json":e=JSON.parse(e);break}}catch(n){y(n)}return e},ot=(a,e,n)=>{let l=!1,c,f,v,b,R,s,D=!0,F={},h=W(t=>t),X=0,z=!1,V=()=>{D=!1},k=()=>{D=!0},S=[],d=Ae(),u=re(n);u.eventsSyncInterval<6e4&&(u.eventsSyncInterval=6e4),u.pollingInterval<6e4&&(u.pollingInterval=6e4);let p=(t,...i)=>{u.debug&&console.debug(`[FF-SDK] ${t}`,...i)},L=t=>{if(D){let i=Date.now();i-t.lastAccessed>Oe&&(t.count++,t.lastAccessed=i)}};globalThis.onbeforeunload=()=>{S.length&&globalThis.localStorage&&(V(),globalThis.localStorage.HARNESS_FF_METRICS=JSON.stringify(S),k())};let he=(t,i)=>C(void 0,null,function*(){return(yield(yield Fe(`${i.baseUrl}/client/auth`,{method:"POST",headers:{"Content-Type":"application/json","Harness-SDK-Info":fe},body:JSON.stringify({apiKey:t,target:K(T({},e),{identifier:String(e.identifier)})})})).json()).authToken}),$=0,G=()=>{if(S.length){p("Sending metrics...",{metrics:S,evaluations:I});let t={metricsData:S.map(i=>({timestamp:Date.now(),count:i.count,metricsType:"FFMETRICS",attributes:[{key:"featureIdentifier",value:i.featureIdentifier},{key:"featureName",value:i.featureIdentifier},{key:"variationIdentifier",value:i.variationIdentifier},{key:"target",value:e.identifier},{key:"SDK_NAME",value:"JavaScript"},{key:"SDK_LANGUAGE",value:"JavaScript"},{key:"SDK_TYPE",value:"client"},{key:"SDK_VERSION",value:ge}]}))};h(`${u.eventUrl}/metrics/${c}?cluster=${f}`,{method:"POST",headers:T({"Content-Type":"application/json"},F),body:JSON.stringify(t)}).then(()=>{S=[],$=0}).catch(i=>{$++&&(S=[],$=0),p(i),d.emit("metrics error",i)}).finally(()=>{s=window.setTimeout(G,u.eventsSyncInterval)})}else s=window.setTimeout(G,u.eventsSyncInterval)},I={},ve=t=>{p("Sending event for",t.flag),J?d.emit("changed",new Proxy(t,{get(i,o){var m;if(D&&i.hasOwnProperty(o)&&o==="value"){let E=i.flag,r=t.value,g=S.find(O=>O.featureIdentifier===E&&O.featureValue===r);g?(L(g),g.variationIdentifier=((m=I[E])==null?void 0:m.identifier)||""):S.push({featureIdentifier:E,featureValue:String(r),variationIdentifier:I[E].identifier||"",count:1,lastAccessed:Date.now()}),p("Metrics event: Flag",o,"has been read with value via stream update",r)}return o==="value"?Y(t):t[o]}})):d.emit("changed",{deleted:t.deleted,flag:t.flag,value:Y(t)})},Q=function(){return J?new Proxy({},{get(t,i){var m,E,r;let o=t[i];if(D&&t.hasOwnProperty(i)){let g=t[i],O=S.find(ie=>ie.featureIdentifier===i&&g===ie.featureValue);O?(O.variationIdentifier=((m=I[i])==null?void 0:m.identifier)||"",L(O)):S.push({featureIdentifier:i,featureValue:g,variationIdentifier:((E=I[i])==null?void 0:E.identifier)||"",count:1,lastAccessed:Date.now()}),p("Metrics event: Flag:",i,"has been read with value:",g,"variationIdentifier:",(r=I[i])==null?void 0:r.identifier)}return o}}):{}},w=Q();he(a,u).then(t=>C(void 0,null,function*(){if(l)return;R=t;let i=Ce(t);if(F={Authorization:`Bearer ${R}`,"Harness-AccountID":i.accountID,"Harness-EnvironmentID":i.environmentIdentifier,"Harness-SDK-Info":fe},p("Authenticated",i),globalThis.localStorage&&globalThis.localStorage.HARNESS_FF_METRICS)try{delete globalThis.localStorage.HARNESS_FF_METRICS,p("Picking up metrics from previous session")}catch(E){}s=window.setTimeout(G,u.eventsSyncInterval),c=i.environment,f=i.clusterIdentifier;let o=!!Object.keys(I).length;if((yield N())||p("Fetch all flags ok",w),!l){if(u.streamEnabled?(p("Streaming mode enabled"),pe()):u.pollingEnabled?(p("Polling mode enabled"),me()):p("Streaming and polling mode disabled"),!o){V();let E=T({},w);k(),d.emit("ready",E)}z=!0}})).catch(t=>{y("Authentication error: ",t),d.emit("auth error",t),d.emit("error",t)});let N=()=>C(void 0,null,function*(){try{let t=yield h(`${u.baseUrl}/client/env/${c}/target/${e.identifier}/evaluations?cluster=${f}`,{headers:F});if(t.ok){let i=yield t.json();i.forEach(A),d.emit("flags loaded",i)}else y("Features fetch operation error: ",t),d.emit("fetch flags error",t),d.emit("error",t)}catch(t){return y("Features fetch operation error: ",t),d.emit("fetch flags error",t),d.emit("error",t),t}}),Z=t=>C(void 0,null,function*(){try{let i=yield h(`${u.baseUrl}/client/env/${c}/target/${e.identifier}/evaluations/${t}?cluster=${f}`,{headers:F});if(i.ok){let o=yield i.json();A(o)}else y("Feature fetch operation error: ",i),d.emit("fetch flag error",i),d.emit("error",i)}catch(i){y("Feature fetch operation error: ",i),d.emit("fetch flag error",i),d.emit("error",i)}}),A=t=>{V();let i=Y(t);i!==w[t.flag]&&(p("Flag variation has changed for ",t.identifier),w[t.flag]=i,I[t.flag]=K(T({},t),{value:i}),ve(t)),k()};b=new x(N,u);let pe=()=>{let t=r=>{switch(r.event){case"create":o(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):setTimeout(()=>Z(r.identifier),1e3);break;case"patch":o(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):Z(r.identifier);break;case"delete":delete w[r.identifier],d.emit("changed",{flag:r.identifier,value:void 0,deleted:!0}),p("Evaluation deleted",{message:r,storage:w});break}},i=r=>!(!r||!r.flag||!r.identifier||!r.kind||!r.value),o=r=>!(!r||r.length==0||!r.every(g=>i(g))),m=r=>{r.event==="patch"&&(o(r.evaluations)?r.evaluations.forEach(g=>{A(g)}):N())},E=`${u.baseUrl}/stream?cluster=${f}`;v=new H(d,u,E,a,F,b,r=>{r.domain==="flag"?t(r):r.domain==="target-segment"&&m(r)}),v.start()},me=()=>{b.start()},B=(t,i)=>d.on(t,i),Ee=(t,i)=>{t?d.off(t,i):ee()},be=(t,i)=>{var r;if(!D||J||i===void 0)return;let o=i,m=t,E=S.find(g=>g.featureIdentifier===m&&g.featureValue===o);E?(L(E),E.variationIdentifier=((r=I[m])==null?void 0:r.identifier)||""):S.push({featureIdentifier:m,featureValue:o,count:1,variationIdentifier:I[m].identifier||"",lastAccessed:Date.now()})},ee=()=>{l=!0,u.streamEnabled&&(p("Closing event stream"),typeof(v==null?void 0:v.close)=="function"&&v.close(),d.all.clear()),u.pollingEnabled&&b.isPolling()&&(p("Closing Poller"),b.stop()),w=Q(),I={},clearTimeout(s)},te=(t,i=!0)=>{t.length&&U(()=>{let o=!!Object.keys(I).length;if(t.forEach(A),!o){V();let m=T({},w);k(),d.emit("ready",m)}},i)};if(u.cache&&"localStorage"in window){let t=!0,i=M(e.identifier,typeof u.cache=="boolean"?{}:u.cache);i!=null&&i.length&&U(()=>{p("loading from cache",i),te(i,!1),d.emit("cache loaded",i)}),B("flags loaded",o=>{P(e.identifier,o),t=!1}),B("changed",o=>{t||(o.deleted?se(e.identifier,o.flag):oe(e.identifier,o))})}return{on:B,off:Ee,close:ee,setEvaluations:te,registerAPIRequestMiddleware:t=>{h=W(t)},refreshEvaluations:()=>{z&&!l&&Date.now()-X>=6e4&&(N(),X=Date.now())},variation:(t,i,o=!1)=>ce(t,i,w,be,o)}};export{q as Event,ot as initialize};
{
"name": "@harnessio/ff-javascript-client-sdk",
"version": "1.17.1-rc.2",
"version": "1.17.1-rc.3",
"author": "Harness",

@@ -5,0 +5,0 @@ "license": "Apache-2.0",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc