New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@descope/web-js-sdk

Package Overview
Dependencies
Maintainers
4
Versions
252
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@descope/web-js-sdk - npm Package Compare versions

Comparing version 0.1.0-alpha.14 to 0.1.0-alpha.15

2

dist/cjs/index.cjs.js

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

"use strict";var e=require("tslib"),t=require("@descope/core-js-sdk"),n=require("@fingerprintjs/fingerprintjs-pro"),a=require("js-cookie");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var i=s(t),r=s(a);const o="undefined"!=typeof window,l=o&&localStorage.getItem("fingerprint.public.key")||"A9aCLRHzKCv3uL69oqDr",c=o&&(null===localStorage||void 0===localStorage?void 0:localStorage.getItem("fingerprint.endpoint.url"))||"https://fp.descope.com",u=(e="",t="")=>({vsid:e,vrid:t}),d=(e=!1)=>{const t=localStorage.getItem("fp");if(!t)return null;const n=JSON.parse(t);return(new Date).getTime()>n.expiry&&!e?null:n.value},g=async e=>{try{if(d())return;const t=(Date.now().toString(36)+Math.random().toString(36).substring(2)+Math.random().toString(36).substring(2)).substring(0,27),a=n.load({apiKey:e||l,endpoint:c}),s=await a,{requestId:i}=await s.get({linkedId:t});(e=>{const t={value:e,expiry:(new Date).getTime()+864e5};localStorage.setItem("fp",JSON.stringify(t))})(u(t,i))}catch(e){global.FB_DEBUG&&console.error(e)}};var p,f,h,w,v;const b=e=>Object.assign({},e);class S{constructor(t){p.add(this),f.set(this,void 0),h.set(this,{}),w.set(this,0),e.__classPrivateFieldSet(this,f,t,"f")}get current(){return b(e.__classPrivateFieldGet(this,f,"f"))}update(t){const n=t;if(!((e,t)=>{const n=e&&Object.getOwnPropertyNames(e)||[],a=t&&Object.getOwnPropertyNames(t)||[];if(n.length!==a.length)return!1;for(let a=0;a<n.length;a+=1){const s=n[a];if(e[s]!==t[s])return!1}return!0})(e.__classPrivateFieldGet(this,f,"f"),n)){const t=e.__classPrivateFieldGet(this,f,"f");e.__classPrivateFieldSet(this,f,n,"f"),Object.freeze(e.__classPrivateFieldGet(this,f,"f")),setTimeout((()=>{Object.values(e.__classPrivateFieldGet(this,h,"f")).forEach((e=>e(b(n),t)))}),0)}}subscribe(t){e.__classPrivateFieldSet(this,w,e.__classPrivateFieldGet(this,w,"f")+1,"f"),e.__classPrivateFieldGet(this,h,"f")[e.__classPrivateFieldGet(this,w,"f")]=t;const n=e.__classPrivateFieldGet(this,w,"f");return()=>e.__classPrivateFieldGet(this,p,"m",v).call(this,n.toString())}unsubscribeAll(){e.__classPrivateFieldSet(this,h,{},"f")}}f=new WeakMap,h=new WeakMap,w=new WeakMap,p=new WeakSet,v=function(t){!!e.__classPrivateFieldGet(this,h,"f")[t]&&delete e.__classPrivateFieldGet(this,h,"f")[t]};let _=[];function y(e,t,n){const a=function(e){const t=e.split(".");try{if(3===t.length){const t=JSON.parse(window.atob(e.split(".")[1]));if(t.exp)return new Date(1e3*t.exp)}}catch(e){}return null}(t);if(a){let t;for(;t=_.pop();)clearTimeout(t);const s=a.getTime()-2e4-(new Date).getTime(),i=setTimeout((()=>{e(n)}),s);_.push(i)}}function m(e,t,n){!function(e,{cookiePath:t,cookieDomain:n,cookieExpiration:a}){e&&r.default.set("DS",e,{path:t,domain:n,expires:a,sameSite:"None",secure:!0})}(e,n),function(e){localStorage&&e&&localStorage.setItem("DSR",e)}(t)}function O(){return localStorage?null===localStorage||void 0===localStorage?void 0:localStorage.getItem("DSR"):""}async function k(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=P(n.publicKey.challenge),n.publicKey.user.id=P(n.publicKey.user.id),null===(t=n.publicKey.excludeCredentials)||void 0===t||t.forEach((e=>{e.id=P(e.id)})),n}(e),n=await navigator.credentials.create(t);return a=n,JSON.stringify(Object.assign(Object.assign({},a),{rawId:T(a.rawId),response:Object.assign(Object.assign({},a.response),{attestationObject:T(a.response.attestationObject),clientDataJSON:T(a.response.clientDataJSON)})}));var a}async function I(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=P(n.publicKey.challenge),null===(t=n.publicKey.allowCredentials)||void 0===t||t.forEach((e=>{e.id=P(e.id)})),n}(e),n=await navigator.credentials.get(t);return a=n,JSON.stringify(Object.assign(Object.assign({},a),{rawId:T(a.rawId),response:Object.assign(Object.assign({},a.response),{authenticatorData:T(a.response.authenticatorData),clientDataJSON:T(a.response.clientDataJSON),signature:T(a.response.signature),userHandle:a.response.userHandle?T(a.response.userHandle):void 0})}));var a}async function j(e=!1){if(!o)return Promise.resolve(!1);const t=!!(PublicKeyCredential&&navigator.credentials&&navigator.credentials.create&&navigator.credentials.get);return t&&e&&PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable?PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable():t}function P(e){const t=e.replace(/_/g,"/").replace(/-/g,"+");return Uint8Array.from(atob(t),(e=>e.charCodeAt(0))).buffer}function T(e){return btoa(String.fromCharCode.apply(null,new Uint8Array(e))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}module.exports=t=>{var{autoRefresh:n=!0,persistTokens:a=!0,fpKey:s,fpLoad:l}=t,c=e.__rest(t,["autoRefresh","persistTokens","fpKey","fpLoad"]);o?l&&g(s).catch((()=>null)):console.warn("Fingerprint is a client side only capability and will not work when running in the server");const p=c;let f,h;const w=new S({sessionToken:""}),v=new S({});p.hooks={beforeRequest:e=>null==f?void 0:f(e),afterRequest:(e,t)=>null==h?void 0:h(e,t)};const b=i.default(p),_=(P=b,{async signUp(e,t){const n=await P.webauthn.signUp.start(e,window.location.origin,t),a=await k(n.data.options);return await P.webauthn.signUp.finish(n.data.transactionId,a)},async signIn(e){const t=await P.webauthn.signIn.start(e,window.location.origin),n=await I(t.data.options);return await P.webauthn.signIn.finish(t.data.transactionId,n)},async signUpOrIn(e){var t;const n=await P.webauthn.signUpOrIn.start(e,window.location.origin);if(null===(t=n.data)||void 0===t?void 0:t.create){const e=await k(n.data.options);return await P.webauthn.signUp.finish(n.data.transactionId,e)}{const e=await I(n.data.options);return await P.webauthn.signIn.finish(n.data.transactionId,e)}},async update(e,t){const n=await P.webauthn.update.start(e,window.location.origin,t),a=await k(n.data.options);return await P.webauthn.update.finish(n.data.transactionId,a)},helpers:{create:k,get:I,isSupported:j}});var P;const T=Object.assign(Object.assign({},b),{flow:Object.assign(Object.assign({},b.flow),{start:async(e,t,n,a)=>{const s=await _.helpers.isSupported(),i=null===localStorage||void 0===localStorage?void 0:localStorage.getItem("dls_last_user_external_id"),r={tenant:null==a?void 0:a.tenant,redirectUrl:window.location.href,deviceInfo:{webAuthnSupport:s}};return i&&(r.lastUser={externalId:i}),b.flow.start(e,t,n,r)}}),webauthn:_,onSessionTokenChange:e=>{var t;const n=null===(t=w.current)||void 0===t?void 0:t.sessionToken;return n&&e(n),w.subscribe((({sessionToken:t})=>{e(t)}))},onUserChange:e=>{const t=v.current;return t&&Object.entries(t).length>0&&e(t),v.subscribe((t=>{e(t)}))},getRefreshToken:O});return o?(n&&["logout","logoutAll"].forEach((e=>{const t=b[e];T[e]=(...e)=>{const n=O(),a=[(null==e?void 0:e.shift())||n,...e],s=t(...a);return localStorage&&localStorage.removeItem("DSR"),r.default.remove("DS"),o&&(null===localStorage||void 0===localStorage||localStorage.removeItem("dls_last_user_external_id")),w.update({sessionToken:""}),s}})),f=e=>(e.body&&(e.body.fpData=d(!0)||u()),!e.token&&a&&(e.token=O()),e.headers=Object.assign(Object.assign({},e.headers),{"x-descope-sdk-name":"web-js","x-descope-sdk-version":"0.1.0-alpha.14"}),e),T.me=async(...e)=>{var t;const n=await b.me(...e);if(n.ok){const e=await(null===(t=n.response)||void 0===t?void 0:t.clone().json());v.update(e)}return n},(n||a)&&(h=(t,s)=>{!async function(t,n,a,s){var i;try{if(401===n.status)return a.sessionToken.update({sessionToken:""}),void a.user.update({});const r=await(null==n?void 0:n.json());if(r){const n=function(e){return(null==e?void 0:e.authInfo)||e||{}}(r),{sessionJwt:l,refreshJwt:c,user:u}=n,d=e.__rest(n,["sessionJwt","refreshJwt","user"]);if(s.persistTokens&&m(l,c,d),l&&a.sessionToken.update({sessionToken:l}),u){const e=null===(i=null==u?void 0:u.externalIds)||void 0===i?void 0:i[0];o&&e&&(null===localStorage||void 0===localStorage||localStorage.setItem("dls_last_user_external_id",e)),a.user.update(u)}l&&c&&s.autoRefresh&&y(t,l,c)}}catch(e){console.error("Could not set tokens from body",e)}}(T.refresh,s,{sessionToken:w,user:v},{autoRefresh:n,persistTokens:a})}),n&&O()&&T.refresh(),T):(console.warn("Storing auth tokens in local storage and cookies are a client side only capabilities and will not be done when running in the server"),T)};
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("tslib"),t=require("@descope/core-js-sdk"),n=require("@fingerprintjs/fingerprintjs-pro"),a=require("js-cookie");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(t),i=s(a);const r="undefined"!=typeof window,l=r&&localStorage.getItem("fingerprint.public.key")||"A9aCLRHzKCv3uL69oqDr",c=r&&(null===localStorage||void 0===localStorage?void 0:localStorage.getItem("fingerprint.endpoint.url"))||"https://fp.descope.com",u=(e="",t="")=>({vsid:e,vrid:t}),d=(e=!1)=>{const t=localStorage.getItem("fp");if(!t)return null;const n=JSON.parse(t);return(new Date).getTime()>n.expiry&&!e?null:n.value},g=async e=>{try{if(d())return;const t=(Date.now().toString(36)+Math.random().toString(36).substring(2)+Math.random().toString(36).substring(2)).substring(0,27),a=n.load({apiKey:e||l,endpoint:c}),s=await a,{requestId:o}=await s.get({linkedId:t});(e=>{const t={value:e,expiry:(new Date).getTime()+864e5};localStorage.setItem("fp",JSON.stringify(t))})(u(t,o))}catch(e){global.FB_DEBUG&&console.error(e)}};var p,f,h,v,w;const b=e=>Object.assign({},e);class S{constructor(t){p.add(this),f.set(this,void 0),h.set(this,{}),v.set(this,0),e.__classPrivateFieldSet(this,f,t,"f")}get current(){return b(e.__classPrivateFieldGet(this,f,"f"))}update(t){const n=t;if(!((e,t)=>{const n=e&&Object.getOwnPropertyNames(e)||[],a=t&&Object.getOwnPropertyNames(t)||[];if(n.length!==a.length)return!1;for(let a=0;a<n.length;a+=1){const s=n[a];if(e[s]!==t[s])return!1}return!0})(e.__classPrivateFieldGet(this,f,"f"),n)){const t=e.__classPrivateFieldGet(this,f,"f");e.__classPrivateFieldSet(this,f,n,"f"),Object.freeze(e.__classPrivateFieldGet(this,f,"f")),setTimeout((()=>{Object.values(e.__classPrivateFieldGet(this,h,"f")).forEach((e=>e(b(n),t)))}),0)}}subscribe(t){e.__classPrivateFieldSet(this,v,e.__classPrivateFieldGet(this,v,"f")+1,"f"),e.__classPrivateFieldGet(this,h,"f")[e.__classPrivateFieldGet(this,v,"f")]=t;const n=e.__classPrivateFieldGet(this,v,"f");return()=>e.__classPrivateFieldGet(this,p,"m",w).call(this,n.toString())}unsubscribeAll(){e.__classPrivateFieldSet(this,h,{},"f")}}f=new WeakMap,h=new WeakMap,v=new WeakMap,p=new WeakSet,w=function(t){!!e.__classPrivateFieldGet(this,h,"f")[t]&&delete e.__classPrivateFieldGet(this,h,"f")[t]};let _=[];function y(e,t,n){const a=function(e){const t=e.split(".");try{if(3===t.length){const t=JSON.parse(window.atob(e.split(".")[1]));if(t.exp)return new Date(1e3*t.exp)}}catch(e){}return null}(t);if(a){let t;for(;t=_.pop();)clearTimeout(t);const s=a.getTime()-2e4-(new Date).getTime(),o=setTimeout((()=>{e(n)}),s);_.push(o)}}async function k(t,n,a,s){var o;try{if(401===n.status)return a.sessionToken.update({sessionToken:""}),void a.user.update({});const l=await(null==n?void 0:n.json());if(l){const n=function(e){return(null==e?void 0:e.authInfo)||e||{}}(l),{sessionJwt:c,refreshJwt:u,user:d}=n,g=e.__rest(n,["sessionJwt","refreshJwt","user"]);if(s.persistTokens&&(function(e,{cookiePath:t,cookieDomain:n,cookieExpiration:a},s){e&&(s?i.default.set("DS",e,{path:t,domain:n,expires:a,sameSite:"None",secure:!0}):localStorage&&localStorage.setItem("DS",e))}(c,g,s.sessionTokenViaCookie),function(e){localStorage&&e&&localStorage.setItem("DSR",e)}(u)),c&&a.sessionToken.update({sessionToken:c}),d){const e=null===(o=null==d?void 0:d.externalIds)||void 0===o?void 0:o[0];r&&e&&(null===localStorage||void 0===localStorage||localStorage.setItem("dls_last_user_external_id",e)),a.user.update(d)}c&&u&&s.autoRefresh&&y(t,c,u)}}catch(e){console.error("Could not set tokens from body",e)}}function m(){return localStorage?null===localStorage||void 0===localStorage?void 0:localStorage.getItem("DSR"):""}async function O(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=T(n.publicKey.challenge),n.publicKey.user.id=T(n.publicKey.user.id),null===(t=n.publicKey.excludeCredentials)||void 0===t||t.forEach((e=>{e.id=T(e.id)})),n}(e),n=await navigator.credentials.create(t);return a=n,JSON.stringify(Object.assign(Object.assign({},a),{rawId:P(a.rawId),response:Object.assign(Object.assign({},a.response),{attestationObject:P(a.response.attestationObject),clientDataJSON:P(a.response.clientDataJSON)})}));var a}async function I(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=T(n.publicKey.challenge),null===(t=n.publicKey.allowCredentials)||void 0===t||t.forEach((e=>{e.id=T(e.id)})),n}(e),n=await navigator.credentials.get(t);return a=n,JSON.stringify(Object.assign(Object.assign({},a),{rawId:P(a.rawId),response:Object.assign(Object.assign({},a.response),{authenticatorData:P(a.response.authenticatorData),clientDataJSON:P(a.response.clientDataJSON),signature:P(a.response.signature),userHandle:a.response.userHandle?P(a.response.userHandle):void 0})}));var a}async function j(e=!1){if(!r)return Promise.resolve(!1);const t=!!(PublicKeyCredential&&navigator.credentials&&navigator.credentials.create&&navigator.credentials.get);return t&&e&&PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable?PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable():t}function T(e){const t=e.replace(/_/g,"/").replace(/-/g,"+");return Uint8Array.from(atob(t),(e=>e.charCodeAt(0))).buffer}function P(e){return btoa(String.fromCharCode.apply(null,new Uint8Array(e))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}exports.default=t=>{var{autoRefresh:n=!0,persistTokens:a=!0,sessionTokenViaCookie:s,fpKey:l,fpLoad:c}=t,p=e.__rest(t,["autoRefresh","persistTokens","sessionTokenViaCookie","fpKey","fpLoad"]);r?c&&g(l).catch((()=>null)):console.warn("Fingerprint is a client side only capability and will not work when running in the server");const f=p;let h,v;const w=new S({sessionToken:""}),b=new S({});f.hooks={beforeRequest:e=>null==h?void 0:h(e),afterRequest:(e,t)=>null==v?void 0:v(e,t)};const _=o.default(f),y=(T=_,{async signUp(e,t){const n=await T.webauthn.signUp.start(e,window.location.origin,t),a=await O(n.data.options);return await T.webauthn.signUp.finish(n.data.transactionId,a)},async signIn(e){const t=await T.webauthn.signIn.start(e,window.location.origin),n=await I(t.data.options);return await T.webauthn.signIn.finish(t.data.transactionId,n)},async signUpOrIn(e){var t;const n=await T.webauthn.signUpOrIn.start(e,window.location.origin);if(null===(t=n.data)||void 0===t?void 0:t.create){const e=await O(n.data.options);return await T.webauthn.signUp.finish(n.data.transactionId,e)}{const e=await I(n.data.options);return await T.webauthn.signIn.finish(n.data.transactionId,e)}},async update(e,t){const n=await T.webauthn.update.start(e,window.location.origin,t),a=await O(n.data.options);return await T.webauthn.update.finish(n.data.transactionId,a)},helpers:{create:O,get:I,isSupported:j}});var T;const P=Object.assign(Object.assign({},_),{flow:Object.assign(Object.assign({},_.flow),{start:async(e,t,n,a)=>{const s=await y.helpers.isSupported(),o=null===localStorage||void 0===localStorage?void 0:localStorage.getItem("dls_last_user_external_id"),i={tenant:null==a?void 0:a.tenant,redirectUrl:window.location.href,deviceInfo:{webAuthnSupport:s}};return o&&(i.lastUser={externalId:o}),_.flow.start(e,t,n,i)}}),webauthn:y,onSessionTokenChange:e=>{var t;const n=null===(t=w.current)||void 0===t?void 0:t.sessionToken;return n&&e(n),w.subscribe((({sessionToken:t})=>{e(t)}))},onUserChange:e=>{const t=b.current;return t&&Object.entries(t).length>0&&e(t),b.subscribe((t=>{e(t)}))},getRefreshToken:m});return r?(n&&["logout","logoutAll"].forEach((e=>{const t=_[e];P[e]=(...e)=>{const n=m(),a=[(null==e?void 0:e.shift())||n,...e],s=t(...a);return null===localStorage||void 0===localStorage||localStorage.removeItem("DSR"),null===localStorage||void 0===localStorage||localStorage.removeItem("DS"),i.default.remove("DS"),r&&(null===localStorage||void 0===localStorage||localStorage.removeItem("dls_last_user_external_id")),w.update({sessionToken:""}),s}})),h=e=>(e.body&&(e.body.fpData=d(!0)||u()),!e.token&&a&&(e.token=m()),e.headers=Object.assign(Object.assign({},e.headers),{"x-descope-sdk-name":"web-js","x-descope-sdk-version":"0.1.0-alpha.15"}),e),P.me=async(...e)=>{var t;const n=await _.me(...e);if(n.ok){const e=await(null===(t=n.response)||void 0===t?void 0:t.clone().json());b.update(e)}return n},(n||a)&&(v=(e,t)=>{k(P.refresh,t,{sessionToken:w,user:b},{autoRefresh:n,persistTokens:a,sessionTokenViaCookie:s})}),n&&m()&&P.refresh(),P):(console.warn("Storing auth tokens in local storage and cookies are a client side only capabilities and will not be done when running in the server"),P)},exports.getSessionToken=function(){return i.default.get("DS")||(null===localStorage||void 0===localStorage?void 0:localStorage.getItem("DS"))||""};
//# sourceMappingURL=index.cjs.js.map

@@ -8,2 +8,3 @@ import * as _descope_core_js_sdk from '@descope/core-js-sdk';

persistTokens?: boolean;
sessionTokenViaCookie?: boolean;
};

@@ -13,2 +14,7 @@

declare function getRefreshToken(): string;
/**
* Return the session token. first try to get from cookie, and fallback to local storage
* See sessionTokenViaCookie option for more details about session token location
*/
declare function getSessionToken(): string;

@@ -22,2 +28,3 @@ /** Configuration arguments which include the Descope core SDK args and fingerprint configuration.

};
/**

@@ -27,3 +34,3 @@ * Wrapper around DescopeSDK to handle fingerprint.js and storage of JWT tokens in cookies and localStorage,

*/
declare const _default: ({ autoRefresh, persistTokens, fpKey, fpLoad, ...args }: WebJSSDKArgs) => {
declare const _default: ({ autoRefresh, persistTokens, sessionTokenViaCookie, fpKey, fpLoad, ...args }: WebJSSDKArgs) => {
flow: {

@@ -244,2 +251,2 @@ start: (flowId: string, interactionId?: string, input?: Record<string, FormDataEntryValue>, options?: {

export { WebJSSDKArgs, _default as default };
export { WebJSSDKArgs, _default as default, getSessionToken };

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

import{__classPrivateFieldSet as e,__classPrivateFieldGet as t,__rest as n}from"tslib";import a from"@descope/core-js-sdk";import{load as o}from"@fingerprintjs/fingerprintjs-pro";import s from"js-cookie";const i="undefined"!=typeof window,r=i&&localStorage.getItem("fingerprint.public.key")||"A9aCLRHzKCv3uL69oqDr",l=i&&(null===localStorage||void 0===localStorage?void 0:localStorage.getItem("fingerprint.endpoint.url"))||"https://fp.descope.com",c=(e="",t="")=>({vsid:e,vrid:t}),u=(e=!1)=>{const t=localStorage.getItem("fp");if(!t)return null;const n=JSON.parse(t);return(new Date).getTime()>n.expiry&&!e?null:n.value},d=async e=>{try{if(u())return;const t=(Date.now().toString(36)+Math.random().toString(36).substring(2)+Math.random().toString(36).substring(2)).substring(0,27),n=o({apiKey:e||r,endpoint:l}),a=await n,{requestId:s}=await a.get({linkedId:t});(e=>{const t={value:e,expiry:(new Date).getTime()+864e5};localStorage.setItem("fp",JSON.stringify(t))})(c(t,s))}catch(e){global.FB_DEBUG&&console.error(e)}};var g,p,f,h,w;const b=e=>Object.assign({},e);class v{constructor(t){g.add(this),p.set(this,void 0),f.set(this,{}),h.set(this,0),e(this,p,t,"f")}get current(){return b(t(this,p,"f"))}update(n){const a=n;if(!((e,t)=>{const n=e&&Object.getOwnPropertyNames(e)||[],a=t&&Object.getOwnPropertyNames(t)||[];if(n.length!==a.length)return!1;for(let a=0;a<n.length;a+=1){const o=n[a];if(e[o]!==t[o])return!1}return!0})(t(this,p,"f"),a)){const n=t(this,p,"f");e(this,p,a,"f"),Object.freeze(t(this,p,"f")),setTimeout((()=>{Object.values(t(this,f,"f")).forEach((e=>e(b(a),n)))}),0)}}subscribe(n){e(this,h,t(this,h,"f")+1,"f"),t(this,f,"f")[t(this,h,"f")]=n;const a=t(this,h,"f");return()=>t(this,g,"m",w).call(this,a.toString())}unsubscribeAll(){e(this,f,{},"f")}}p=new WeakMap,f=new WeakMap,h=new WeakMap,g=new WeakSet,w=function(e){!!t(this,f,"f")[e]&&delete t(this,f,"f")[e]};let S=[];function y(e,t,n){const a=function(e){const t=e.split(".");try{if(3===t.length){const t=JSON.parse(window.atob(e.split(".")[1]));if(t.exp)return new Date(1e3*t.exp)}}catch(e){}return null}(t);if(a){let t;for(;t=S.pop();)clearTimeout(t);const o=a.getTime()-2e4-(new Date).getTime(),s=setTimeout((()=>{e(n)}),o);S.push(s)}}function m(e,t,n){!function(e,{cookiePath:t,cookieDomain:n,cookieExpiration:a}){e&&s.set("DS",e,{path:t,domain:n,expires:a,sameSite:"None",secure:!0})}(e,n),function(e){localStorage&&e&&localStorage.setItem("DSR",e)}(t)}function O(){return localStorage?null===localStorage||void 0===localStorage?void 0:localStorage.getItem("DSR"):""}async function k(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=T(n.publicKey.challenge),n.publicKey.user.id=T(n.publicKey.user.id),null===(t=n.publicKey.excludeCredentials)||void 0===t||t.forEach((e=>{e.id=T(e.id)})),n}(e),n=await navigator.credentials.create(t);return a=n,JSON.stringify(Object.assign(Object.assign({},a),{rawId:D(a.rawId),response:Object.assign(Object.assign({},a.response),{attestationObject:D(a.response.attestationObject),clientDataJSON:D(a.response.clientDataJSON)})}));var a}async function I(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=T(n.publicKey.challenge),null===(t=n.publicKey.allowCredentials)||void 0===t||t.forEach((e=>{e.id=T(e.id)})),n}(e),n=await navigator.credentials.get(t);return a=n,JSON.stringify(Object.assign(Object.assign({},a),{rawId:D(a.rawId),response:Object.assign(Object.assign({},a.response),{authenticatorData:D(a.response.authenticatorData),clientDataJSON:D(a.response.clientDataJSON),signature:D(a.response.signature),userHandle:a.response.userHandle?D(a.response.userHandle):void 0})}));var a}async function j(e=!1){if(!i)return Promise.resolve(!1);const t=!!(PublicKeyCredential&&navigator.credentials&&navigator.credentials.create&&navigator.credentials.get);return t&&e&&PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable?PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable():t}function T(e){const t=e.replace(/_/g,"/").replace(/-/g,"+");return Uint8Array.from(atob(t),(e=>e.charCodeAt(0))).buffer}function D(e){return btoa(String.fromCharCode.apply(null,new Uint8Array(e))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}var x=e=>{var{autoRefresh:t=!0,persistTokens:o=!0,fpKey:r,fpLoad:l}=e,g=n(e,["autoRefresh","persistTokens","fpKey","fpLoad"]);i?l&&d(r).catch((()=>null)):console.warn("Fingerprint is a client side only capability and will not work when running in the server");const p=g;let f,h;const w=new v({sessionToken:""}),b=new v({});p.hooks={beforeRequest:e=>null==f?void 0:f(e),afterRequest:(e,t)=>null==h?void 0:h(e,t)};const S=a(p),T=(D=S,{async signUp(e,t){const n=await D.webauthn.signUp.start(e,window.location.origin,t),a=await k(n.data.options);return await D.webauthn.signUp.finish(n.data.transactionId,a)},async signIn(e){const t=await D.webauthn.signIn.start(e,window.location.origin),n=await I(t.data.options);return await D.webauthn.signIn.finish(t.data.transactionId,n)},async signUpOrIn(e){var t;const n=await D.webauthn.signUpOrIn.start(e,window.location.origin);if(null===(t=n.data)||void 0===t?void 0:t.create){const e=await k(n.data.options);return await D.webauthn.signUp.finish(n.data.transactionId,e)}{const e=await I(n.data.options);return await D.webauthn.signIn.finish(n.data.transactionId,e)}},async update(e,t){const n=await D.webauthn.update.start(e,window.location.origin,t),a=await k(n.data.options);return await D.webauthn.update.finish(n.data.transactionId,a)},helpers:{create:k,get:I,isSupported:j}});var D;const x=Object.assign(Object.assign({},S),{flow:Object.assign(Object.assign({},S.flow),{start:async(e,t,n,a)=>{const o=await T.helpers.isSupported(),s=null===localStorage||void 0===localStorage?void 0:localStorage.getItem("dls_last_user_external_id"),i={tenant:null==a?void 0:a.tenant,redirectUrl:window.location.href,deviceInfo:{webAuthnSupport:o}};return s&&(i.lastUser={externalId:s}),S.flow.start(e,t,n,i)}}),webauthn:T,onSessionTokenChange:e=>{var t;const n=null===(t=w.current)||void 0===t?void 0:t.sessionToken;return n&&e(n),w.subscribe((({sessionToken:t})=>{e(t)}))},onUserChange:e=>{const t=b.current;return t&&Object.entries(t).length>0&&e(t),b.subscribe((t=>{e(t)}))},getRefreshToken:O});return i?(t&&["logout","logoutAll"].forEach((e=>{const t=S[e];x[e]=(...e)=>{const n=O(),a=[(null==e?void 0:e.shift())||n,...e],o=t(...a);return localStorage&&localStorage.removeItem("DSR"),s.remove("DS"),i&&(null===localStorage||void 0===localStorage||localStorage.removeItem("dls_last_user_external_id")),w.update({sessionToken:""}),o}})),f=e=>(e.body&&(e.body.fpData=u(!0)||c()),!e.token&&o&&(e.token=O()),e.headers=Object.assign(Object.assign({},e.headers),{"x-descope-sdk-name":"web-js","x-descope-sdk-version":"0.1.0-alpha.14"}),e),x.me=async(...e)=>{var t;const n=await S.me(...e);if(n.ok){const e=await(null===(t=n.response)||void 0===t?void 0:t.clone().json());b.update(e)}return n},(t||o)&&(h=(e,a)=>{!async function(e,t,a,o){var s;try{if(401===t.status)return a.sessionToken.update({sessionToken:""}),void a.user.update({});const r=await(null==t?void 0:t.json());if(r){const t=function(e){return(null==e?void 0:e.authInfo)||e||{}}(r),{sessionJwt:l,refreshJwt:c,user:u}=t,d=n(t,["sessionJwt","refreshJwt","user"]);if(o.persistTokens&&m(l,c,d),l&&a.sessionToken.update({sessionToken:l}),u){const e=null===(s=null==u?void 0:u.externalIds)||void 0===s?void 0:s[0];i&&e&&(null===localStorage||void 0===localStorage||localStorage.setItem("dls_last_user_external_id",e)),a.user.update(u)}l&&c&&o.autoRefresh&&y(e,l,c)}}catch(e){console.error("Could not set tokens from body",e)}}(x.refresh,a,{sessionToken:w,user:b},{autoRefresh:t,persistTokens:o})}),t&&O()&&x.refresh(),x):(console.warn("Storing auth tokens in local storage and cookies are a client side only capabilities and will not be done when running in the server"),x)};export{x as default};
import{__classPrivateFieldSet as e,__classPrivateFieldGet as t,__rest as n}from"tslib";import a from"@descope/core-js-sdk";import{load as o}from"@fingerprintjs/fingerprintjs-pro";import s from"js-cookie";const i="undefined"!=typeof window,r=i&&localStorage.getItem("fingerprint.public.key")||"A9aCLRHzKCv3uL69oqDr",l=i&&(null===localStorage||void 0===localStorage?void 0:localStorage.getItem("fingerprint.endpoint.url"))||"https://fp.descope.com",c=(e="",t="")=>({vsid:e,vrid:t}),u=(e=!1)=>{const t=localStorage.getItem("fp");if(!t)return null;const n=JSON.parse(t);return(new Date).getTime()>n.expiry&&!e?null:n.value},d=async e=>{try{if(u())return;const t=(Date.now().toString(36)+Math.random().toString(36).substring(2)+Math.random().toString(36).substring(2)).substring(0,27),n=o({apiKey:e||r,endpoint:l}),a=await n,{requestId:s}=await a.get({linkedId:t});(e=>{const t={value:e,expiry:(new Date).getTime()+864e5};localStorage.setItem("fp",JSON.stringify(t))})(c(t,s))}catch(e){global.FB_DEBUG&&console.error(e)}};var g,p,f,h,w;const b=e=>Object.assign({},e);class v{constructor(t){g.add(this),p.set(this,void 0),f.set(this,{}),h.set(this,0),e(this,p,t,"f")}get current(){return b(t(this,p,"f"))}update(n){const a=n;if(!((e,t)=>{const n=e&&Object.getOwnPropertyNames(e)||[],a=t&&Object.getOwnPropertyNames(t)||[];if(n.length!==a.length)return!1;for(let a=0;a<n.length;a+=1){const o=n[a];if(e[o]!==t[o])return!1}return!0})(t(this,p,"f"),a)){const n=t(this,p,"f");e(this,p,a,"f"),Object.freeze(t(this,p,"f")),setTimeout((()=>{Object.values(t(this,f,"f")).forEach((e=>e(b(a),n)))}),0)}}subscribe(n){e(this,h,t(this,h,"f")+1,"f"),t(this,f,"f")[t(this,h,"f")]=n;const a=t(this,h,"f");return()=>t(this,g,"m",w).call(this,a.toString())}unsubscribeAll(){e(this,f,{},"f")}}p=new WeakMap,f=new WeakMap,h=new WeakMap,g=new WeakSet,w=function(e){!!t(this,f,"f")[e]&&delete t(this,f,"f")[e]};let S=[];function m(e,t,n){const a=function(e){const t=e.split(".");try{if(3===t.length){const t=JSON.parse(window.atob(e.split(".")[1]));if(t.exp)return new Date(1e3*t.exp)}}catch(e){}return null}(t);if(a){let t;for(;t=S.pop();)clearTimeout(t);const o=a.getTime()-2e4-(new Date).getTime(),s=setTimeout((()=>{e(n)}),o);S.push(s)}}async function y(e,t,a,o){var r;try{if(401===t.status)return a.sessionToken.update({sessionToken:""}),void a.user.update({});const l=await(null==t?void 0:t.json());if(l){const t=function(e){return(null==e?void 0:e.authInfo)||e||{}}(l),{sessionJwt:c,refreshJwt:u,user:d}=t,g=n(t,["sessionJwt","refreshJwt","user"]);if(o.persistTokens&&(function(e,{cookiePath:t,cookieDomain:n,cookieExpiration:a},o){e&&(o?s.set("DS",e,{path:t,domain:n,expires:a,sameSite:"None",secure:!0}):localStorage&&localStorage.setItem("DS",e))}(c,g,o.sessionTokenViaCookie),function(e){localStorage&&e&&localStorage.setItem("DSR",e)}(u)),c&&a.sessionToken.update({sessionToken:c}),d){const e=null===(r=null==d?void 0:d.externalIds)||void 0===r?void 0:r[0];i&&e&&(null===localStorage||void 0===localStorage||localStorage.setItem("dls_last_user_external_id",e)),a.user.update(d)}c&&u&&o.autoRefresh&&m(e,c,u)}}catch(e){console.error("Could not set tokens from body",e)}}function k(){return localStorage?null===localStorage||void 0===localStorage?void 0:localStorage.getItem("DSR"):""}function O(){return s.get("DS")||(null===localStorage||void 0===localStorage?void 0:localStorage.getItem("DS"))||""}async function I(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=D(n.publicKey.challenge),n.publicKey.user.id=D(n.publicKey.user.id),null===(t=n.publicKey.excludeCredentials)||void 0===t||t.forEach((e=>{e.id=D(e.id)})),n}(e),n=await navigator.credentials.create(t);return a=n,JSON.stringify(Object.assign(Object.assign({},a),{rawId:C(a.rawId),response:Object.assign(Object.assign({},a.response),{attestationObject:C(a.response.attestationObject),clientDataJSON:C(a.response.clientDataJSON)})}));var a}async function j(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=D(n.publicKey.challenge),null===(t=n.publicKey.allowCredentials)||void 0===t||t.forEach((e=>{e.id=D(e.id)})),n}(e),n=await navigator.credentials.get(t);return a=n,JSON.stringify(Object.assign(Object.assign({},a),{rawId:C(a.rawId),response:Object.assign(Object.assign({},a.response),{authenticatorData:C(a.response.authenticatorData),clientDataJSON:C(a.response.clientDataJSON),signature:C(a.response.signature),userHandle:a.response.userHandle?C(a.response.userHandle):void 0})}));var a}async function T(e=!1){if(!i)return Promise.resolve(!1);const t=!!(PublicKeyCredential&&navigator.credentials&&navigator.credentials.create&&navigator.credentials.get);return t&&e&&PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable?PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable():t}function D(e){const t=e.replace(/_/g,"/").replace(/-/g,"+");return Uint8Array.from(atob(t),(e=>e.charCodeAt(0))).buffer}function C(e){return btoa(String.fromCharCode.apply(null,new Uint8Array(e))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}var x=e=>{var{autoRefresh:t=!0,persistTokens:o=!0,sessionTokenViaCookie:r,fpKey:l,fpLoad:g}=e,p=n(e,["autoRefresh","persistTokens","sessionTokenViaCookie","fpKey","fpLoad"]);i?g&&d(l).catch((()=>null)):console.warn("Fingerprint is a client side only capability and will not work when running in the server");const f=p;let h,w;const b=new v({sessionToken:""}),S=new v({});f.hooks={beforeRequest:e=>null==h?void 0:h(e),afterRequest:(e,t)=>null==w?void 0:w(e,t)};const m=a(f),O=(D=m,{async signUp(e,t){const n=await D.webauthn.signUp.start(e,window.location.origin,t),a=await I(n.data.options);return await D.webauthn.signUp.finish(n.data.transactionId,a)},async signIn(e){const t=await D.webauthn.signIn.start(e,window.location.origin),n=await j(t.data.options);return await D.webauthn.signIn.finish(t.data.transactionId,n)},async signUpOrIn(e){var t;const n=await D.webauthn.signUpOrIn.start(e,window.location.origin);if(null===(t=n.data)||void 0===t?void 0:t.create){const e=await I(n.data.options);return await D.webauthn.signUp.finish(n.data.transactionId,e)}{const e=await j(n.data.options);return await D.webauthn.signIn.finish(n.data.transactionId,e)}},async update(e,t){const n=await D.webauthn.update.start(e,window.location.origin,t),a=await I(n.data.options);return await D.webauthn.update.finish(n.data.transactionId,a)},helpers:{create:I,get:j,isSupported:T}});var D;const C=Object.assign(Object.assign({},m),{flow:Object.assign(Object.assign({},m.flow),{start:async(e,t,n,a)=>{const o=await O.helpers.isSupported(),s=null===localStorage||void 0===localStorage?void 0:localStorage.getItem("dls_last_user_external_id"),i={tenant:null==a?void 0:a.tenant,redirectUrl:window.location.href,deviceInfo:{webAuthnSupport:o}};return s&&(i.lastUser={externalId:s}),m.flow.start(e,t,n,i)}}),webauthn:O,onSessionTokenChange:e=>{var t;const n=null===(t=b.current)||void 0===t?void 0:t.sessionToken;return n&&e(n),b.subscribe((({sessionToken:t})=>{e(t)}))},onUserChange:e=>{const t=S.current;return t&&Object.entries(t).length>0&&e(t),S.subscribe((t=>{e(t)}))},getRefreshToken:k});return i?(t&&["logout","logoutAll"].forEach((e=>{const t=m[e];C[e]=(...e)=>{const n=k(),a=[(null==e?void 0:e.shift())||n,...e],o=t(...a);return null===localStorage||void 0===localStorage||localStorage.removeItem("DSR"),null===localStorage||void 0===localStorage||localStorage.removeItem("DS"),s.remove("DS"),i&&(null===localStorage||void 0===localStorage||localStorage.removeItem("dls_last_user_external_id")),b.update({sessionToken:""}),o}})),h=e=>(e.body&&(e.body.fpData=u(!0)||c()),!e.token&&o&&(e.token=k()),e.headers=Object.assign(Object.assign({},e.headers),{"x-descope-sdk-name":"web-js","x-descope-sdk-version":"0.1.0-alpha.15"}),e),C.me=async(...e)=>{var t;const n=await m.me(...e);if(n.ok){const e=await(null===(t=n.response)||void 0===t?void 0:t.clone().json());S.update(e)}return n},(t||o)&&(w=(e,n)=>{y(C.refresh,n,{sessionToken:b,user:S},{autoRefresh:t,persistTokens:o,sessionTokenViaCookie:r})}),t&&k()&&C.refresh(),C):(console.warn("Storing auth tokens in local storage and cookies are a client side only capabilities and will not be done when running in the server"),C)};export{x as default,O as getSessionToken};
//# sourceMappingURL=index.esm.js.map

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

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e="undefined"!=typeof globalThis?globalThis:e||self).descopeSdk=t()}(this,(function(){"use strict";var e=function(){return e=Object.assign||function(e){for(var t,n=1,r=arguments.length;n<r;n++)for(var o in t=arguments[n])Object.prototype.hasOwnProperty.call(t,o)&&(e[o]=t[o]);return e},e.apply(this,arguments)};function t(e,t){var n={};for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var o=0;for(r=Object.getOwnPropertySymbols(e);o<r.length;o++)t.indexOf(r[o])<0&&Object.prototype.propertyIsEnumerable.call(e,r[o])&&(n[r[o]]=e[r[o]])}return n}function n(e,t,n,r){if("a"===n&&!r)throw new TypeError("Private accessor was defined without a getter");if("function"==typeof t?e!==t||!r:!t.has(e))throw new TypeError("Cannot read private member from an object whose class did not declare it");return"m"===n?r:"a"===n?r.call(e):r?r.value:t.get(e)}function r(e,t,n,r,o){if("m"===r)throw new TypeError("Private method is not writable");if("a"===r&&!o)throw new TypeError("Private accessor was defined without a setter");if("function"==typeof t?e!==t||!o:!t.has(e))throw new TypeError("Cannot write private member to an object whose class did not declare it");return"a"===r?o.call(e,n):o?o.value=n:t.set(e,n),n}function o(e){this.message=e}o.prototype=new Error,o.prototype.name="InvalidCharacterError";var i="undefined"!=typeof window&&window.atob&&window.atob.bind(window)||function(e){var t=String(e).replace(/=+$/,"");if(t.length%4==1)throw new o("'atob' failed: The string to be decoded is not correctly encoded.");for(var n,r,i=0,a=0,s="";r=t.charAt(a++);~r&&(n=i%4?64*n+r:r,i++%4)?s+=String.fromCharCode(255&n>>(-2*i&6)):0)r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(r);return s};function a(e){this.message=e}function s(e,t){if("string"!=typeof e)throw new a("Invalid token specified");var n=!0===(t=t||{}).header?0:1;try{return JSON.parse(function(e){var t=e.replace(/-/g,"+").replace(/_/g,"/");switch(t.length%4){case 0:break;case 2:t+="==";break;case 3:t+="=";break;default:throw"Illegal base64url string!"}try{return function(e){return decodeURIComponent(i(e).replace(/(.)/g,(function(e,t){var n=t.charCodeAt(0).toString(16).toUpperCase();return n.length<2&&(n="0"+n),"%"+n})))}(t)}catch(e){return i(t)}}(e.split(".")[n]))}catch(e){throw new a("Invalid token specified: "+e.message)}}a.prototype=new Error,a.prototype.name="InvalidTokenError";var c="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},u="__lodash_hash_undefined__",l="[object Function]",d="[object GeneratorFunction]",p=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,f=/^\w*$/,h=/^\./,g=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,v=/\\(\\)?/g,y=/^\[object .+?Constructor\]$/,b="object"==typeof c&&c&&c.Object===Object&&c,w="object"==typeof self&&self&&self.Object===Object&&self,m=b||w||Function("return this")();var k,O=Array.prototype,I=Function.prototype,j=Object.prototype,S=m["__core-js_shared__"],_=(k=/[^.]+$/.exec(S&&S.keys&&S.keys.IE_PROTO||""))?"Symbol(src)_1."+k:"",x=I.toString,P=j.hasOwnProperty,U=j.toString,T=RegExp("^"+x.call(P).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$"),E=m.Symbol,R=O.splice,C=F(m,"Map"),A=F(Object,"create"),D=E?E.prototype:void 0,q=D?D.toString:void 0;function J(e){var t=-1,n=e?e.length:0;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}function $(e){var t=-1,n=e?e.length:0;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}function K(e){var t=-1,n=e?e.length:0;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}function M(e,t){for(var n,r,o=e.length;o--;)if((n=e[o][0])===(r=t)||n!=n&&r!=r)return o;return-1}function N(e,t){var n;t=function(e,t){if(W(e))return!1;var n=typeof e;if("number"==n||"symbol"==n||"boolean"==n||null==e||Z(e))return!0;return f.test(e)||!p.test(e)||null!=t&&e in Object(t)}(t,e)?[t]:W(n=t)?n:z(n);for(var r=0,o=t.length;null!=e&&r<o;)e=e[H(t[r++])];return r&&r==o?e:void 0}function L(e){if(!G(e)||(t=e,_&&_ in t))return!1;var t,n=function(e){var t=G(e)?U.call(e):"";return t==l||t==d}(e)||function(e){var t=!1;if(null!=e&&"function"!=typeof e.toString)try{t=!!(e+"")}catch(e){}return t}(e)?T:y;return n.test(function(e){if(null!=e){try{return x.call(e)}catch(e){}try{return e+""}catch(e){}}return""}(e))}function B(e,t){var n,r,o=e.__data__;return("string"==(r=typeof(n=t))||"number"==r||"symbol"==r||"boolean"==r?"__proto__"!==n:null===n)?o["string"==typeof t?"string":"hash"]:o.map}function F(e,t){var n=function(e,t){return null==e?void 0:e[t]}(e,t);return L(n)?n:void 0}J.prototype.clear=function(){this.__data__=A?A(null):{}},J.prototype.delete=function(e){return this.has(e)&&delete this.__data__[e]},J.prototype.get=function(e){var t=this.__data__;if(A){var n=t[e];return n===u?void 0:n}return P.call(t,e)?t[e]:void 0},J.prototype.has=function(e){var t=this.__data__;return A?void 0!==t[e]:P.call(t,e)},J.prototype.set=function(e,t){return this.__data__[e]=A&&void 0===t?u:t,this},$.prototype.clear=function(){this.__data__=[]},$.prototype.delete=function(e){var t=this.__data__,n=M(t,e);return!(n<0)&&(n==t.length-1?t.pop():R.call(t,n,1),!0)},$.prototype.get=function(e){var t=this.__data__,n=M(t,e);return n<0?void 0:t[n][1]},$.prototype.has=function(e){return M(this.__data__,e)>-1},$.prototype.set=function(e,t){var n=this.__data__,r=M(n,e);return r<0?n.push([e,t]):n[r][1]=t,this},K.prototype.clear=function(){this.__data__={hash:new J,map:new(C||$),string:new J}},K.prototype.delete=function(e){return B(this,e).delete(e)},K.prototype.get=function(e){return B(this,e).get(e)},K.prototype.has=function(e){return B(this,e).has(e)},K.prototype.set=function(e,t){return B(this,e).set(e,t),this};var z=V((function(e){var t;e=null==(t=e)?"":function(e){if("string"==typeof e)return e;if(Z(e))return q?q.call(e):"";var t=e+"";return"0"==t&&1/e==-1/0?"-0":t}(t);var n=[];return h.test(e)&&n.push(""),e.replace(g,(function(e,t,r,o){n.push(r?o.replace(v,"$1"):t||e)})),n}));function H(e){if("string"==typeof e||Z(e))return e;var t=e+"";return"0"==t&&1/e==-1/0?"-0":t}function V(e,t){if("function"!=typeof e||t&&"function"!=typeof t)throw new TypeError("Expected a function");var n=function(){var r=arguments,o=t?t.apply(this,r):r[0],i=n.cache;if(i.has(o))return i.get(o);var a=e.apply(this,r);return n.cache=i.set(o,a),a};return n.cache=new(V.Cache||K),n}V.Cache=K;var W=Array.isArray;function G(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function Z(e){return"symbol"==typeof e||function(e){return!!e&&"object"==typeof e}(e)&&"[object Symbol]"==U.call(e)}var Q=function(e,t,n){var r=null==e?void 0:N(e,t);return void 0===r?n:r},X="/v1/auth/accesskey/exchange",Y="/v1/auth/otp/verify",ee="/v1/auth/otp/signin",te="/v1/auth/otp/signup",ne={email:"/v1/auth/otp/update/email",phone:"/v1/auth/otp/update/phone"},re="/v1/auth/otp/signup-in",oe="/v1/auth/magiclink/verify",ie="/v1/auth/magiclink/signin",ae="/v1/auth/magiclink/signup",se={email:"/v1/auth/magiclink/update/email",phone:"/v1/auth/magiclink/update/phone"},ce="/v1/auth/magiclink/signup-in",ue="/v1/auth/enchantedlink/verify",le="/v1/auth/enchantedlink/signin",de="/v1/auth/enchantedlink/signup",pe="/v1/auth/enchantedlink/pending-session",fe={email:"/v1/auth/enchantedlink/update/email"},he="/v1/auth/enchantedlink/signup-in",ge="/v1/auth/oauth/authorize",ve="/v1/auth/oauth/exchange",ye="/v1/auth/saml/authorize",be="/v1/auth/saml/exchange",we="/v1/auth/totp/verify",me="/v1/auth/totp/signup",ke="/v1/user/totp/update",Oe={start:"/v1/auth/webauthn/signup/start",finish:"/v1/auth/webauthn/signup/finish"},Ie={start:"/v1/auth/webauthn/signin/start",finish:"/v1/auth/webauthn/signin/finish"},je={start:"/v1/auth/webauthn/signup-in/start"},Se={start:"v1/auth/webauthn/update/start",finish:"/v1/auth/webauthn/update/finish"},_e="/v1/flow/start",xe="/v1/flow/next";const Pe=()=>{const e={};return{headers(t){const n="function"==typeof t.entries?Object.fromEntries(t.entries()):t;return e.Headers=JSON.stringify(n),this},body(t){return e.Body=t,this},url(t){return e.Url=t.toString(),this},method(t){return e.Method=t,this},title(t){return e.Title=t,this},status(t){return e.Status=t,this},build:()=>Object.keys(e).flatMap((t=>e[t]?[`${"Title"!==t?`${t}: `:""}${e[t]}`]:[])).join("\n")}};var Ue;!function(e){e.get="GET",e.delete="DELETE",e.post="POST",e.put="PUT"}(Ue||(Ue={}));const Te=(...e)=>new Headers(e.reduce(((e,t)=>{const n=(e=>Array.isArray(e)?e:e instanceof Headers?Array.from(e.entries()):e?Object.entries(e):[])(t);return n.reduce(((t,[n,r])=>(e[n]=r,e)),e),e}),{})),Ee=e=>void 0===e?void 0:JSON.stringify(e),Re=(e,t="")=>{let n=e;return t&&(n=n+":"+t),{Authorization:`Bearer ${n}`}},Ce=({baseUrl:e,projectId:t,baseConfig:n,logger:r,hooks:o,cookiePolicy:i})=>{const a=((e,t)=>{const n=t||fetch;if(!n)throw new Error("fetch is not defined");return e?async(...t)=>{e.log((e=>Pe().title("Request").url(e[0]).method(e[1].method).headers(e[1].headers).body(e[1].body).build())(t));const r=await n(...t);return e[r.ok?"log":"error"](await(async e=>{const t=await(e.clone?e.clone().text():e.text());return e.text=()=>Promise.resolve(t),e.json=()=>Promise.resolve(JSON.parse(t)),Pe().title("Response").url(e.url.toString()).status(`${e.status} ${e.statusText}`).headers(e.headers).body(t).build()})(r)),r}:n})(r),s=async r=>{const s=(null==o?void 0:o.beforeRequest)?o.beforeRequest(r):r,{path:c,body:u,headers:l,queryParams:d,method:p,token:f}=s,h=await a((({path:e,baseUrl:t,queryParams:n})=>{const r=new URL(e,t);return n&&(r.search=new URLSearchParams(n).toString()),r})({path:c,baseUrl:e,queryParams:d}),{headers:Te(Re(t,f),{"x-descope-sdk-name":"core-js","x-descope-sdk-version":"0.0.41-alpha.34"},(null==n?void 0:n.baseHeaders)||{},l),method:p,body:Ee(u),credentials:i||"include"});return(null==o?void 0:o.afterRequest)&&o.afterRequest(r,null==h?void 0:h.clone()),h};return{get:(e,{headers:t,queryParams:n,token:r}={})=>s({path:e,headers:t,queryParams:n,body:void 0,method:Ue.get,token:r}),post:(e,t,{headers:n,queryParams:r,token:o}={})=>s({path:e,headers:n,queryParams:r,body:t,method:Ue.post,token:o}),put:(e,t,{headers:n,queryParams:r,token:o}={})=>s({path:e,headers:n,queryParams:r,body:t,method:Ue.put,token:o}),delete:(e,t,{headers:n,queryParams:r,token:o}={})=>s({path:e,headers:n,queryParams:r,body:t,method:Ue.delete,token:o})}};function Ae(e,t,n){var r;let o=De(e);t&&(o=null===(r=o.tenants)||void 0===r?void 0:r[t]);const i=o[n];return Array.isArray(i)?i:[]}function De(e){if("string"!=typeof e||!e)throw new Error("Invalid token provided");return s(e)}function qe(e){const{exp:t}=De(e);return(new Date).getTime()/1e3>t}function Je(e,t){return Ae(e,t,"permissions")}function $e(e,t){return Ae(e,t,"roles")}const Ke=(...e)=>e.join("/").replace(/\/{2,}/g,"/");async function Me(e,t){const n=await e,r={code:n.status,ok:n.ok,response:n},o=await n.clone().json();return n.ok?r.data=t?t(o):o:r.error=o,r}const Ne=(e,t)=>(n=t)=>t=>!e(t)&&n.replace("{val}",t),Le=(...e)=>({validate:t=>(e.forEach((e=>{const n=e(t);if(n)throw new Error(n)})),!0)}),Be=e=>t=>e.test(t),Fe=Be(/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*$/),ze=Be(/^\+[1-9]{1}[0-9]{3,14}$/),He=Ne(Fe,'"{val}" is not a valid email'),Ve=Ne(ze,'"{val}" is not a valid phone number'),We=Ne((1,e=>e.length>=1),"Minimum length is 1");const Ge=Ne((e=>"string"==typeof e),"Input is not a string"),Ze=(...e)=>t=>(...n)=>(e.forEach(((e,t)=>Le(...e).validate(n[t]))),t(...n)),Qe=e=>[Ge(`"${e}" must be a string`),We(`"${e}" must not be empty`)],Xe=e=>[Ge(`"${e}" must be a string`),He()],Ye=e=>[Ge(`"${e}" must be a string`),Ve()],et=Ze(Qe("accessKey")),tt=e=>({exchange:et((t=>Me(e.post(X,{},{token:t}))))});var nt,rt,ot,it,at;!function(e){e.sms="sms",e.whatsapp="whatsapp"}(nt||(nt={})),function(e){e.email="email",e.sms="sms",e.whatsapp="whatsapp"}(rt||(rt={})),function(e){e.waiting="waiting",e.running="running",e.completed="completed",e.failed="failed"}(ot||(ot={})),function(e){e.signUp="signup",e.signIn="signin",e.verify="verify"}(it||(it={})),function(e){e.signUp="signup",e.signIn="signin",e.verify="verify",e.updatePhone="updatePhone"}(at||(at={}));const st=Qe("identifier"),ct=Ze(st,Qe("code")),ut=Ze(st),lt=Ze(st,Ye("phone")),dt=Ze(st,Xe("email")),pt=e=>({verify:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:ct(((t,r)=>Me(e.post(Ke(Y,n),{code:r,externalId:t}))))})),{}),signIn:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:ut(((t,r,o)=>Me(e.post(Ke(ee,n),{externalId:t,loginOptions:r},{token:o}))))})),{}),signUp:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:ut(((t,r)=>Me(e.post(Ke(te,n),{externalId:t,user:r}))))})),{}),signUpOrIn:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:ut((t=>Me(e.post(Ke(re,n),{externalId:t}))))})),{}),update:{email:dt(((t,n,r)=>Me(e.post(ne.email,{externalId:t,email:n},{token:r})))),phone:Object.keys(nt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:lt(((t,r,o)=>Me(e.post(Ke(ne.phone,n),{externalId:t,phone:r},{token:o}))))})),{})}}),ft=Qe("identifier"),ht=Qe("uri"),gt=Ze(Qe("token")),vt=Ze(ft,ht),yt=Ze(ft,Ye("phone"),ht),bt=Ze(ft,Xe("email"),ht),wt=e=>({verify:gt((t=>Me(e.post(oe,{token:t})))),signIn:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:vt(((t,r,o,i)=>Me(e.post(Ke(ie,n),{externalId:t,URI:r,loginOptions:o},{token:i}))))})),{}),signUp:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:vt(((t,r,o)=>Me(e.post(Ke(ae,n),{externalId:t,URI:r,user:o}))))})),{}),signUpOrIn:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:vt(((t,r)=>Me(e.post(Ke(ce,n),{externalId:t,URI:r}))))})),{}),update:{email:bt(((t,n,r,o)=>Me(e.post(se.email,{externalId:t,email:n,URI:r},{token:o})))),phone:Object.keys(nt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:yt(((t,r,o,i)=>Me(e.post(Ke(se.phone,n),{externalId:t,phone:r,URI:o},{token:i}))))})),{})}}),mt=Qe("identifier"),kt=Qe("uri"),Ot=Ze(Qe("token")),It=Ze(mt,kt),jt=Ze(Qe("pendingRef")),St=Ze(mt,Xe("email"),kt),_t=e=>({verify:Ot((t=>Me(e.post(ue,{token:t})))),signIn:It(((t,n,r,o)=>Me(e.post(Ke(le,rt.email),{externalId:t,URI:n,loginOptions:r},{token:o})))),signUpOrIn:It(((t,n)=>Me(e.post(Ke(he,rt.email),{externalId:t,URI:n})))),signUp:It(((t,n,r)=>Me(e.post(Ke(de,rt.email),{externalId:t,URI:n,user:r})))),waitForSession:jt(((t,n)=>new Promise((r=>{const{pollingIntervalMs:o,timeoutMs:i}=(({pollingIntervalMs:e=1e3,timeoutMs:t=6e5}={})=>({pollingIntervalMs:Math.max(e||1e3,1e3),timeoutMs:Math.min(t||6e5,6e5)}))(n);let a;const s=setInterval((async()=>{const n=await e.post(pe,{pendingRef:t});n.ok&&(clearInterval(s),a&&clearTimeout(a),r(Me(Promise.resolve(n))))}),o);a=setTimeout((()=>{r({error:{message:`Session polling timeout exceeded: ${i}ms`,errorCode:"0"},ok:!1}),clearInterval(s)}),i)})))),update:{email:St(((t,n,r,o)=>Me(e.post(fe.email,{externalId:t,email:n,URI:r},{token:o}))))}});var xt;!function(e){e.facebook="facebook",e.github="github",e.google="google",e.microsoft="microsoft",e.gitlab="gitlab",e.apple="apple"}(xt||(xt={}));const Pt=Ze(Qe("code")),Ut=e=>({start:Object.keys(xt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:async(t,{redirect:r=!1}={},o,i)=>{const a=await e.post(ge,o||{},{queryParams:Object.assign({provider:n},t&&{redirectURL:t}),token:i});if(!r||!a.ok)return Me(Promise.resolve(a));const{url:s}=await a.json();window.location.href=s}})),{}),exchange:Pt((t=>Me(e.post(ve,{code:t}))))}),Tt=Ze(Qe("flowId")),Et=Ze(Qe("executionId"),Qe("stepId"),Qe("interactionId")),Rt=e=>({start:Tt(((t,n,r,o)=>Me(e.post(_e,{flowId:t,options:o,interactionId:n,input:r})))),next:Et(((t,n,r,o)=>Me(e.post(xe,{executionId:t,stepId:n,interactionId:r,input:o}))))}),Ct=Ze(Qe("tenant")),At=Ze(Qe("code")),Dt=e=>({start:Ct((async(t,n,{redirect:r=!1}={},o,i)=>{const a=await e.post(ye,o||{},{queryParams:{tenant:t,redirectURL:n},token:i});if(!r||!a.ok)return Me(Promise.resolve(a));const{url:s}=await a.json();window.location.href=s})),exchange:At((t=>Me(e.post(be,{code:t}))))}),qt=Qe("identifier"),Jt=Ze(qt,Qe("code")),$t=Ze(qt),Kt=Ze(qt),Mt=e=>({signUp:$t(((t,n)=>Me(e.post(me,{externalId:t,user:n})))),verify:Jt(((t,n,r,o)=>Me(e.post(we,{externalId:t,code:n,loginOptions:r},{token:o})))),update:Kt(((t,n)=>Me(e.post(ke,{externalId:t},{token:n}))))}),Nt=Qe("identifier"),Lt=Qe("origin"),Bt=Ze(Nt,Lt,Qe("name")),Ft=Ze(Nt,Lt),zt=Ze(Nt,Lt,Qe("token")),Ht=Ze(Qe("transactionId"),Qe("response")),Vt=e=>({signUp:{start:Bt(((t,n,r)=>Me(e.post(Oe.start,{user:{externalId:t,name:r},origin:n})))),finish:Ht(((t,n)=>Me(e.post(Oe.finish,{transactionId:t,response:n}))))},signIn:{start:Ft(((t,n,r,o)=>Me(e.post(Ie.start,{externalId:t,origin:n,loginOptions:r},{token:o})))),finish:Ht(((t,n)=>Me(e.post(Ie.finish,{transactionId:t,response:n}))))},signUpOrIn:{start:Ft(((t,n)=>Me(e.post(je.start,{externalId:t,origin:n}))))},update:{start:zt(((t,n,r)=>Me(e.post(Se.start,{externalId:t,origin:n},{token:r})))),finish:Ht(((t,n)=>Me(e.post(Se.finish,{transactionId:t,response:n}))))}}),Wt=Ze(Qe("token"));var Gt;const Zt=Ze([("projectId",Gt=Qe("projectId"),Ne(((e,t)=>e=>Le(...t).validate(Q(e,"projectId")))(0,Gt))())])((({projectId:e,logger:t,baseUrl:n,hooks:r,cookiePolicy:o})=>{return i=Ce({baseUrl:n||"https://api.descope.com",projectId:e,logger:t,hooks:r,cookiePolicy:o}),{accessKey:tt(i),otp:pt(i),magicLink:wt(i),enchantedLink:_t(i),oauth:Ut(i),saml:Dt(i),totp:Mt(i),webauthn:Vt(i),flow:Rt(i),refresh:e=>Me(i.post("/v1/auth/refresh",{},{token:e})),logout:e=>Me(i.post("/v1/auth/logout",{},{token:e})),logoutAll:e=>Me(i.post("/v1/auth/logoutall",{},{token:e})),me:e=>Me(i.get("/v1/auth/me",{token:e})),isJwtExpired:Wt(qe),getJwtPermissions:Wt(Je),getJwtRoles:Wt($e),httpClient:i};var i}));Zt.DeliveryMethods=rt;const Qt="undefined"!=typeof window,Xt=Qt&&localStorage.getItem("fingerprint.public.key")||"A9aCLRHzKCv3uL69oqDr",Yt=Qt&&(null===localStorage||void 0===localStorage?void 0:localStorage.getItem("fingerprint.endpoint.url"))||"https://fp.descope.com",en="dls_last_user_external_id";function tn(e,t){var n=[];return function(e,t){var n,r,o=(r=function(){for(var e=0,t=0,n=arguments.length;t<n;t++)e+=arguments[t].length;var r=Array(e),o=0;for(t=0;t<n;t++)for(var i=arguments[t],a=0,s=i.length;a<s;a++,o++)r[o]=i[a];return r}(e),{current:function(){return r[0]},postpone:function(){var e=r.shift();void 0!==e&&r.push(e)},exclude:function(){r.shift()}}),i=(100,3e3,n=0,function(){return Math.random()*Math.min(3e3,100*Math.pow(2,n++))}),a=o.current();if(void 0===a)return Promise.reject(new TypeError("The list of script URL patterns is empty"));var s=function(e,n){return t(e).catch((function(e){if(n+1>=5)throw e;!function(e){if(!(e instanceof Error))return!1;var t=e.message;return"Blocked by CSP"===t||"9319"===t}(e)?o.postpone():o.exclude();var t,r=o.current();if(void 0===r)throw e;return(t=i(),new Promise((function(e){return setTimeout(e,t)}))).then((function(){return s(r,n+1)}))}))};return s(a,0)}(e,(function(e){var r=new Date,o=function(){return n.push({url:e,startedAt:r,finishedAt:new Date})},i=t(e);return i.then(o,o),i})).then((function(e){return[e,{attempts:n}]}))}var nn="Failed to load the JS script of the agent";function rn(n){var r;n.scriptUrlPattern;var o=n.token,i=n.apiKey,a=void 0===i?o:i,s=t(n,["scriptUrlPattern","token","apiKey"]),c=null!==(r=function(e,t){return function(e,t){return Object.prototype.hasOwnProperty.call(e,t)}(e,t)?e[t]:void 0}(n,"scriptUrlPattern"))&&void 0!==r?r:"https://fpnpmcdn.net/v<version>/<apiKey>/loader_v<loaderVersion>.js";return Promise.resolve().then((function(){if(!a||"string"!=typeof a)throw new Error("API key required");return tn(function(e,t){return(Array.isArray(e)?e:[e]).map((function(e){return function(e,t){var n=encodeURIComponent;return e.replace(/<[^<>]+>/g,(function(e){return"<version>"===e?"3":"<apiKey>"===e?n(t):"<loaderVersion>"===e?n("3.8.1"):e}))}(String(e),t)}))}(c,a),on).catch(sn)})).then((function(t){var n=t[0],r=t[1];return n.load(e(e({},s),{ldi:r}))}))}function on(e){return function(e,t,n,r){var o,i=document,a="securitypolicyviolation",s=function(t){var n=new URL(e,location.href),r=t.blockedURI;r!==n.href&&r!==n.protocol.slice(0,-1)&&r!==n.origin||(o=t,c())};i.addEventListener(a,s);var c=function(){return i.removeEventListener(a,s)};return Promise.resolve().then(t).then((function(e){return c(),e}),(function(e){return new Promise((function(e){return setTimeout(e)})).then((function(){if(c(),o)return function(){throw new Error("Blocked by CSP")}();throw e}))}))}(e,(function(){return function(e){return new Promise((function(t,n){var r=document.createElement("script"),o=function(){var e;return null===(e=r.parentNode)||void 0===e?void 0:e.removeChild(r)},i=document.head||document.getElementsByTagName("head")[0];r.onload=function(){o(),t()},r.onerror=function(){o(),n(new Error(nn))},r.async=!0,r.src=e,i.appendChild(r)}))}(e)})).then(an)}function an(){var e=window,t="__fpjs_p_l_b",n=e[t];if(function(e,t){var n,r=null===(n=Object.getOwnPropertyDescriptor)||void 0===n?void 0:n.call(Object,e,t);(null==r?void 0:r.configurable)?delete e[t]:r&&!r.writable||(e[t]=void 0)}(e,t),"function"!=typeof(null==n?void 0:n.load))throw new Error("9319");return n}function sn(e){throw e instanceof Error&&"9319"===e.message?new Error(nn):e}const cn=(e="",t="")=>({vsid:e,vrid:t}),un=(e=!1)=>{const t=localStorage.getItem("fp");if(!t)return null;const n=JSON.parse(t);return(new Date).getTime()>n.expiry&&!e?null:n.value},ln=async e=>{try{if(un())return;const t=(Date.now().toString(36)+Math.random().toString(36).substring(2)+Math.random().toString(36).substring(2)).substring(0,27),n=rn({apiKey:e||Xt,endpoint:Yt}),r=await n,{requestId:o}=await r.get({linkedId:t});(e=>{const t={value:e,expiry:(new Date).getTime()+864e5};localStorage.setItem("fp",JSON.stringify(t))})(cn(t,o))}catch(e){global.FB_DEBUG&&console.error(e)}};var dn,pn,fn,hn,gn;const vn=e=>Object.assign({},e);class yn{constructor(e){dn.add(this),pn.set(this,void 0),fn.set(this,{}),hn.set(this,0),r(this,pn,e,"f")}get current(){return vn(n(this,pn,"f"))}update(e){const t=e;if(!((e,t)=>{const n=e&&Object.getOwnPropertyNames(e)||[],r=t&&Object.getOwnPropertyNames(t)||[];if(n.length!==r.length)return!1;for(let r=0;r<n.length;r+=1){const o=n[r];if(e[o]!==t[o])return!1}return!0})(n(this,pn,"f"),t)){const e=n(this,pn,"f");r(this,pn,t,"f"),Object.freeze(n(this,pn,"f")),setTimeout((()=>{Object.values(n(this,fn,"f")).forEach((n=>n(vn(t),e)))}),0)}}subscribe(e){r(this,hn,n(this,hn,"f")+1,"f"),n(this,fn,"f")[n(this,hn,"f")]=e;const t=n(this,hn,"f");return()=>n(this,dn,"m",gn).call(this,t.toString())}unsubscribeAll(){r(this,fn,{},"f")}}
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).Descope={})}(this,(function(e){"use strict";var t=function(){return t=Object.assign||function(e){for(var t,n=1,r=arguments.length;n<r;n++)for(var o in t=arguments[n])Object.prototype.hasOwnProperty.call(t,o)&&(e[o]=t[o]);return e},t.apply(this,arguments)};function n(e,t){var n={};for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var o=0;for(r=Object.getOwnPropertySymbols(e);o<r.length;o++)t.indexOf(r[o])<0&&Object.prototype.propertyIsEnumerable.call(e,r[o])&&(n[r[o]]=e[r[o]])}return n}function r(e,t,n,r){if("a"===n&&!r)throw new TypeError("Private accessor was defined without a getter");if("function"==typeof t?e!==t||!r:!t.has(e))throw new TypeError("Cannot read private member from an object whose class did not declare it");return"m"===n?r:"a"===n?r.call(e):r?r.value:t.get(e)}function o(e,t,n,r,o){if("m"===r)throw new TypeError("Private method is not writable");if("a"===r&&!o)throw new TypeError("Private accessor was defined without a setter");if("function"==typeof t?e!==t||!o:!t.has(e))throw new TypeError("Cannot write private member to an object whose class did not declare it");return"a"===r?o.call(e,n):o?o.value=n:t.set(e,n),n}function i(e){this.message=e}i.prototype=new Error,i.prototype.name="InvalidCharacterError";var a="undefined"!=typeof window&&window.atob&&window.atob.bind(window)||function(e){var t=String(e).replace(/=+$/,"");if(t.length%4==1)throw new i("'atob' failed: The string to be decoded is not correctly encoded.");for(var n,r,o=0,a=0,s="";r=t.charAt(a++);~r&&(n=o%4?64*n+r:r,o++%4)?s+=String.fromCharCode(255&n>>(-2*o&6)):0)r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(r);return s};function s(e){this.message=e}function c(e,t){if("string"!=typeof e)throw new s("Invalid token specified");var n=!0===(t=t||{}).header?0:1;try{return JSON.parse(function(e){var t=e.replace(/-/g,"+").replace(/_/g,"/");switch(t.length%4){case 0:break;case 2:t+="==";break;case 3:t+="=";break;default:throw"Illegal base64url string!"}try{return function(e){return decodeURIComponent(a(e).replace(/(.)/g,(function(e,t){var n=t.charCodeAt(0).toString(16).toUpperCase();return n.length<2&&(n="0"+n),"%"+n})))}(t)}catch(e){return a(t)}}(e.split(".")[n]))}catch(e){throw new s("Invalid token specified: "+e.message)}}s.prototype=new Error,s.prototype.name="InvalidTokenError";var u="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},l="__lodash_hash_undefined__",d="[object Function]",p="[object GeneratorFunction]",f=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,h=/^\w*$/,g=/^\./,v=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,y=/\\(\\)?/g,b=/^\[object .+?Constructor\]$/,w="object"==typeof u&&u&&u.Object===Object&&u,m="object"==typeof self&&self&&self.Object===Object&&self,k=w||m||Function("return this")();var I,O=Array.prototype,j=Function.prototype,S=Object.prototype,_=k["__core-js_shared__"],x=(I=/[^.]+$/.exec(_&&_.keys&&_.keys.IE_PROTO||""))?"Symbol(src)_1."+I:"",P=j.toString,U=S.hasOwnProperty,T=S.toString,C=RegExp("^"+P.call(U).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$"),E=k.Symbol,R=O.splice,A=z(k,"Map"),D=z(Object,"create"),q=E?E.prototype:void 0,J=q?q.toString:void 0;function $(e){var t=-1,n=e?e.length:0;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}function M(e){var t=-1,n=e?e.length:0;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}function K(e){var t=-1,n=e?e.length:0;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}function N(e,t){for(var n,r,o=e.length;o--;)if((n=e[o][0])===(r=t)||n!=n&&r!=r)return o;return-1}function L(e,t){var n;t=function(e,t){if(G(e))return!1;var n=typeof e;if("number"==n||"symbol"==n||"boolean"==n||null==e||Q(e))return!0;return h.test(e)||!f.test(e)||null!=t&&e in Object(t)}(t,e)?[t]:G(n=t)?n:H(n);for(var r=0,o=t.length;null!=e&&r<o;)e=e[V(t[r++])];return r&&r==o?e:void 0}function B(e){if(!Z(e)||(t=e,x&&x in t))return!1;var t,n=function(e){var t=Z(e)?T.call(e):"";return t==d||t==p}(e)||function(e){var t=!1;if(null!=e&&"function"!=typeof e.toString)try{t=!!(e+"")}catch(e){}return t}(e)?C:b;return n.test(function(e){if(null!=e){try{return P.call(e)}catch(e){}try{return e+""}catch(e){}}return""}(e))}function F(e,t){var n,r,o=e.__data__;return("string"==(r=typeof(n=t))||"number"==r||"symbol"==r||"boolean"==r?"__proto__"!==n:null===n)?o["string"==typeof t?"string":"hash"]:o.map}function z(e,t){var n=function(e,t){return null==e?void 0:e[t]}(e,t);return B(n)?n:void 0}$.prototype.clear=function(){this.__data__=D?D(null):{}},$.prototype.delete=function(e){return this.has(e)&&delete this.__data__[e]},$.prototype.get=function(e){var t=this.__data__;if(D){var n=t[e];return n===l?void 0:n}return U.call(t,e)?t[e]:void 0},$.prototype.has=function(e){var t=this.__data__;return D?void 0!==t[e]:U.call(t,e)},$.prototype.set=function(e,t){return this.__data__[e]=D&&void 0===t?l:t,this},M.prototype.clear=function(){this.__data__=[]},M.prototype.delete=function(e){var t=this.__data__,n=N(t,e);return!(n<0)&&(n==t.length-1?t.pop():R.call(t,n,1),!0)},M.prototype.get=function(e){var t=this.__data__,n=N(t,e);return n<0?void 0:t[n][1]},M.prototype.has=function(e){return N(this.__data__,e)>-1},M.prototype.set=function(e,t){var n=this.__data__,r=N(n,e);return r<0?n.push([e,t]):n[r][1]=t,this},K.prototype.clear=function(){this.__data__={hash:new $,map:new(A||M),string:new $}},K.prototype.delete=function(e){return F(this,e).delete(e)},K.prototype.get=function(e){return F(this,e).get(e)},K.prototype.has=function(e){return F(this,e).has(e)},K.prototype.set=function(e,t){return F(this,e).set(e,t),this};var H=W((function(e){var t;e=null==(t=e)?"":function(e){if("string"==typeof e)return e;if(Q(e))return J?J.call(e):"";var t=e+"";return"0"==t&&1/e==-1/0?"-0":t}(t);var n=[];return g.test(e)&&n.push(""),e.replace(v,(function(e,t,r,o){n.push(r?o.replace(y,"$1"):t||e)})),n}));function V(e){if("string"==typeof e||Q(e))return e;var t=e+"";return"0"==t&&1/e==-1/0?"-0":t}function W(e,t){if("function"!=typeof e||t&&"function"!=typeof t)throw new TypeError("Expected a function");var n=function(){var r=arguments,o=t?t.apply(this,r):r[0],i=n.cache;if(i.has(o))return i.get(o);var a=e.apply(this,r);return n.cache=i.set(o,a),a};return n.cache=new(W.Cache||K),n}W.Cache=K;var G=Array.isArray;function Z(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function Q(e){return"symbol"==typeof e||function(e){return!!e&&"object"==typeof e}(e)&&"[object Symbol]"==T.call(e)}var X=function(e,t,n){var r=null==e?void 0:L(e,t);return void 0===r?n:r},Y="/v1/auth/accesskey/exchange",ee="/v1/auth/otp/verify",te="/v1/auth/otp/signin",ne="/v1/auth/otp/signup",re={email:"/v1/auth/otp/update/email",phone:"/v1/auth/otp/update/phone"},oe="/v1/auth/otp/signup-in",ie="/v1/auth/magiclink/verify",ae="/v1/auth/magiclink/signin",se="/v1/auth/magiclink/signup",ce={email:"/v1/auth/magiclink/update/email",phone:"/v1/auth/magiclink/update/phone"},ue="/v1/auth/magiclink/signup-in",le="/v1/auth/enchantedlink/verify",de="/v1/auth/enchantedlink/signin",pe="/v1/auth/enchantedlink/signup",fe="/v1/auth/enchantedlink/pending-session",he={email:"/v1/auth/enchantedlink/update/email"},ge="/v1/auth/enchantedlink/signup-in",ve="/v1/auth/oauth/authorize",ye="/v1/auth/oauth/exchange",be="/v1/auth/saml/authorize",we="/v1/auth/saml/exchange",me="/v1/auth/totp/verify",ke="/v1/auth/totp/signup",Ie="/v1/user/totp/update",Oe={start:"/v1/auth/webauthn/signup/start",finish:"/v1/auth/webauthn/signup/finish"},je={start:"/v1/auth/webauthn/signin/start",finish:"/v1/auth/webauthn/signin/finish"},Se={start:"/v1/auth/webauthn/signup-in/start"},_e={start:"v1/auth/webauthn/update/start",finish:"/v1/auth/webauthn/update/finish"},xe="/v1/flow/start",Pe="/v1/flow/next";const Ue=()=>{const e={};return{headers(t){const n="function"==typeof t.entries?Object.fromEntries(t.entries()):t;return e.Headers=JSON.stringify(n),this},body(t){return e.Body=t,this},url(t){return e.Url=t.toString(),this},method(t){return e.Method=t,this},title(t){return e.Title=t,this},status(t){return e.Status=t,this},build:()=>Object.keys(e).flatMap((t=>e[t]?[`${"Title"!==t?`${t}: `:""}${e[t]}`]:[])).join("\n")}};var Te;!function(e){e.get="GET",e.delete="DELETE",e.post="POST",e.put="PUT"}(Te||(Te={}));const Ce=(...e)=>new Headers(e.reduce(((e,t)=>{const n=(e=>Array.isArray(e)?e:e instanceof Headers?Array.from(e.entries()):e?Object.entries(e):[])(t);return n.reduce(((t,[n,r])=>(e[n]=r,e)),e),e}),{})),Ee=e=>void 0===e?void 0:JSON.stringify(e),Re=(e,t="")=>{let n=e;return t&&(n=n+":"+t),{Authorization:`Bearer ${n}`}},Ae=({baseUrl:e,projectId:t,baseConfig:n,logger:r,hooks:o,cookiePolicy:i})=>{const a=((e,t)=>{const n=t||fetch;if(!n)throw new Error("fetch is not defined");return e?async(...t)=>{e.log((e=>Ue().title("Request").url(e[0]).method(e[1].method).headers(e[1].headers).body(e[1].body).build())(t));const r=await n(...t);return e[r.ok?"log":"error"](await(async e=>{const t=await(e.clone?e.clone().text():e.text());return e.text=()=>Promise.resolve(t),e.json=()=>Promise.resolve(JSON.parse(t)),Ue().title("Response").url(e.url.toString()).status(`${e.status} ${e.statusText}`).headers(e.headers).body(t).build()})(r)),r}:n})(r),s=async r=>{const s=(null==o?void 0:o.beforeRequest)?o.beforeRequest(r):r,{path:c,body:u,headers:l,queryParams:d,method:p,token:f}=s,h=await a((({path:e,baseUrl:t,queryParams:n})=>{const r=new URL(e,t);return n&&(r.search=new URLSearchParams(n).toString()),r})({path:c,baseUrl:e,queryParams:d}),{headers:Ce(Re(t,f),{"x-descope-sdk-name":"core-js","x-descope-sdk-version":"0.0.41-alpha.34"},(null==n?void 0:n.baseHeaders)||{},l),method:p,body:Ee(u),credentials:i||"include"});return(null==o?void 0:o.afterRequest)&&o.afterRequest(r,null==h?void 0:h.clone()),h};return{get:(e,{headers:t,queryParams:n,token:r}={})=>s({path:e,headers:t,queryParams:n,body:void 0,method:Te.get,token:r}),post:(e,t,{headers:n,queryParams:r,token:o}={})=>s({path:e,headers:n,queryParams:r,body:t,method:Te.post,token:o}),put:(e,t,{headers:n,queryParams:r,token:o}={})=>s({path:e,headers:n,queryParams:r,body:t,method:Te.put,token:o}),delete:(e,t,{headers:n,queryParams:r,token:o}={})=>s({path:e,headers:n,queryParams:r,body:t,method:Te.delete,token:o})}};function De(e,t,n){var r;let o=qe(e);t&&(o=null===(r=o.tenants)||void 0===r?void 0:r[t]);const i=o[n];return Array.isArray(i)?i:[]}function qe(e){if("string"!=typeof e||!e)throw new Error("Invalid token provided");return c(e)}function Je(e){const{exp:t}=qe(e);return(new Date).getTime()/1e3>t}function $e(e,t){return De(e,t,"permissions")}function Me(e,t){return De(e,t,"roles")}const Ke=(...e)=>e.join("/").replace(/\/{2,}/g,"/");async function Ne(e,t){const n=await e,r={code:n.status,ok:n.ok,response:n},o=await n.clone().json();return n.ok?r.data=t?t(o):o:r.error=o,r}const Le=(e,t)=>(n=t)=>t=>!e(t)&&n.replace("{val}",t),Be=(...e)=>({validate:t=>(e.forEach((e=>{const n=e(t);if(n)throw new Error(n)})),!0)}),Fe=e=>t=>e.test(t),ze=Fe(/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*$/),He=Fe(/^\+[1-9]{1}[0-9]{3,14}$/),Ve=Le(ze,'"{val}" is not a valid email'),We=Le(He,'"{val}" is not a valid phone number'),Ge=Le((1,e=>e.length>=1),"Minimum length is 1");const Ze=Le((e=>"string"==typeof e),"Input is not a string"),Qe=(...e)=>t=>(...n)=>(e.forEach(((e,t)=>Be(...e).validate(n[t]))),t(...n)),Xe=e=>[Ze(`"${e}" must be a string`),Ge(`"${e}" must not be empty`)],Ye=e=>[Ze(`"${e}" must be a string`),Ve()],et=e=>[Ze(`"${e}" must be a string`),We()],tt=Qe(Xe("accessKey")),nt=e=>({exchange:tt((t=>Ne(e.post(Y,{},{token:t}))))});var rt,ot,it,at,st;!function(e){e.sms="sms",e.whatsapp="whatsapp"}(rt||(rt={})),function(e){e.email="email",e.sms="sms",e.whatsapp="whatsapp"}(ot||(ot={})),function(e){e.waiting="waiting",e.running="running",e.completed="completed",e.failed="failed"}(it||(it={})),function(e){e.signUp="signup",e.signIn="signin",e.verify="verify"}(at||(at={})),function(e){e.signUp="signup",e.signIn="signin",e.verify="verify",e.updatePhone="updatePhone"}(st||(st={}));const ct=Xe("identifier"),ut=Qe(ct,Xe("code")),lt=Qe(ct),dt=Qe(ct,et("phone")),pt=Qe(ct,Ye("email")),ft=e=>({verify:Object.keys(ot).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:ut(((t,r)=>Ne(e.post(Ke(ee,n),{code:r,externalId:t}))))})),{}),signIn:Object.keys(ot).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:lt(((t,r,o)=>Ne(e.post(Ke(te,n),{externalId:t,loginOptions:r},{token:o}))))})),{}),signUp:Object.keys(ot).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:lt(((t,r)=>Ne(e.post(Ke(ne,n),{externalId:t,user:r}))))})),{}),signUpOrIn:Object.keys(ot).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:lt((t=>Ne(e.post(Ke(oe,n),{externalId:t}))))})),{}),update:{email:pt(((t,n,r)=>Ne(e.post(re.email,{externalId:t,email:n},{token:r})))),phone:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:dt(((t,r,o)=>Ne(e.post(Ke(re.phone,n),{externalId:t,phone:r},{token:o}))))})),{})}}),ht=Xe("identifier"),gt=Xe("uri"),vt=Qe(Xe("token")),yt=Qe(ht,gt),bt=Qe(ht,et("phone"),gt),wt=Qe(ht,Ye("email"),gt),mt=e=>({verify:vt((t=>Ne(e.post(ie,{token:t})))),signIn:Object.keys(ot).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:yt(((t,r,o,i)=>Ne(e.post(Ke(ae,n),{externalId:t,URI:r,loginOptions:o},{token:i}))))})),{}),signUp:Object.keys(ot).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:yt(((t,r,o)=>Ne(e.post(Ke(se,n),{externalId:t,URI:r,user:o}))))})),{}),signUpOrIn:Object.keys(ot).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:yt(((t,r)=>Ne(e.post(Ke(ue,n),{externalId:t,URI:r}))))})),{}),update:{email:wt(((t,n,r,o)=>Ne(e.post(ce.email,{externalId:t,email:n,URI:r},{token:o})))),phone:Object.keys(rt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:bt(((t,r,o,i)=>Ne(e.post(Ke(ce.phone,n),{externalId:t,phone:r,URI:o},{token:i}))))})),{})}}),kt=Xe("identifier"),It=Xe("uri"),Ot=Qe(Xe("token")),jt=Qe(kt,It),St=Qe(Xe("pendingRef")),_t=Qe(kt,Ye("email"),It),xt=e=>({verify:Ot((t=>Ne(e.post(le,{token:t})))),signIn:jt(((t,n,r,o)=>Ne(e.post(Ke(de,ot.email),{externalId:t,URI:n,loginOptions:r},{token:o})))),signUpOrIn:jt(((t,n)=>Ne(e.post(Ke(ge,ot.email),{externalId:t,URI:n})))),signUp:jt(((t,n,r)=>Ne(e.post(Ke(pe,ot.email),{externalId:t,URI:n,user:r})))),waitForSession:St(((t,n)=>new Promise((r=>{const{pollingIntervalMs:o,timeoutMs:i}=(({pollingIntervalMs:e=1e3,timeoutMs:t=6e5}={})=>({pollingIntervalMs:Math.max(e||1e3,1e3),timeoutMs:Math.min(t||6e5,6e5)}))(n);let a;const s=setInterval((async()=>{const n=await e.post(fe,{pendingRef:t});n.ok&&(clearInterval(s),a&&clearTimeout(a),r(Ne(Promise.resolve(n))))}),o);a=setTimeout((()=>{r({error:{message:`Session polling timeout exceeded: ${i}ms`,errorCode:"0"},ok:!1}),clearInterval(s)}),i)})))),update:{email:_t(((t,n,r,o)=>Ne(e.post(he.email,{externalId:t,email:n,URI:r},{token:o}))))}});var Pt;!function(e){e.facebook="facebook",e.github="github",e.google="google",e.microsoft="microsoft",e.gitlab="gitlab",e.apple="apple"}(Pt||(Pt={}));const Ut=Qe(Xe("code")),Tt=e=>({start:Object.keys(Pt).reduce(((t,n)=>Object.assign(Object.assign({},t),{[n]:async(t,{redirect:r=!1}={},o,i)=>{const a=await e.post(ve,o||{},{queryParams:Object.assign({provider:n},t&&{redirectURL:t}),token:i});if(!r||!a.ok)return Ne(Promise.resolve(a));const{url:s}=await a.json();window.location.href=s}})),{}),exchange:Ut((t=>Ne(e.post(ye,{code:t}))))}),Ct=Qe(Xe("flowId")),Et=Qe(Xe("executionId"),Xe("stepId"),Xe("interactionId")),Rt=e=>({start:Ct(((t,n,r,o)=>Ne(e.post(xe,{flowId:t,options:o,interactionId:n,input:r})))),next:Et(((t,n,r,o)=>Ne(e.post(Pe,{executionId:t,stepId:n,interactionId:r,input:o}))))}),At=Qe(Xe("tenant")),Dt=Qe(Xe("code")),qt=e=>({start:At((async(t,n,{redirect:r=!1}={},o,i)=>{const a=await e.post(be,o||{},{queryParams:{tenant:t,redirectURL:n},token:i});if(!r||!a.ok)return Ne(Promise.resolve(a));const{url:s}=await a.json();window.location.href=s})),exchange:Dt((t=>Ne(e.post(we,{code:t}))))}),Jt=Xe("identifier"),$t=Qe(Jt,Xe("code")),Mt=Qe(Jt),Kt=Qe(Jt),Nt=e=>({signUp:Mt(((t,n)=>Ne(e.post(ke,{externalId:t,user:n})))),verify:$t(((t,n,r,o)=>Ne(e.post(me,{externalId:t,code:n,loginOptions:r},{token:o})))),update:Kt(((t,n)=>Ne(e.post(Ie,{externalId:t},{token:n}))))}),Lt=Xe("identifier"),Bt=Xe("origin"),Ft=Qe(Lt,Bt,Xe("name")),zt=Qe(Lt,Bt),Ht=Qe(Lt,Bt,Xe("token")),Vt=Qe(Xe("transactionId"),Xe("response")),Wt=e=>({signUp:{start:Ft(((t,n,r)=>Ne(e.post(Oe.start,{user:{externalId:t,name:r},origin:n})))),finish:Vt(((t,n)=>Ne(e.post(Oe.finish,{transactionId:t,response:n}))))},signIn:{start:zt(((t,n,r,o)=>Ne(e.post(je.start,{externalId:t,origin:n,loginOptions:r},{token:o})))),finish:Vt(((t,n)=>Ne(e.post(je.finish,{transactionId:t,response:n}))))},signUpOrIn:{start:zt(((t,n)=>Ne(e.post(Se.start,{externalId:t,origin:n}))))},update:{start:Ht(((t,n,r)=>Ne(e.post(_e.start,{externalId:t,origin:n},{token:r})))),finish:Vt(((t,n)=>Ne(e.post(_e.finish,{transactionId:t,response:n}))))}}),Gt=Qe(Xe("token"));var Zt;const Qt=Qe([("projectId",Zt=Xe("projectId"),Le(((e,t)=>e=>Be(...t).validate(X(e,"projectId")))(0,Zt))())])((({projectId:e,logger:t,baseUrl:n,hooks:r,cookiePolicy:o})=>{return i=Ae({baseUrl:n||"https://api.descope.com",projectId:e,logger:t,hooks:r,cookiePolicy:o}),{accessKey:nt(i),otp:ft(i),magicLink:mt(i),enchantedLink:xt(i),oauth:Tt(i),saml:qt(i),totp:Nt(i),webauthn:Wt(i),flow:Rt(i),refresh:e=>Ne(i.post("/v1/auth/refresh",{},{token:e})),logout:e=>Ne(i.post("/v1/auth/logout",{},{token:e})),logoutAll:e=>Ne(i.post("/v1/auth/logoutall",{},{token:e})),me:e=>Ne(i.get("/v1/auth/me",{token:e})),isJwtExpired:Gt(Je),getJwtPermissions:Gt($e),getJwtRoles:Gt(Me),httpClient:i};var i}));Qt.DeliveryMethods=ot;const Xt="undefined"!=typeof window,Yt=Xt&&localStorage.getItem("fingerprint.public.key")||"A9aCLRHzKCv3uL69oqDr",en=Xt&&(null===localStorage||void 0===localStorage?void 0:localStorage.getItem("fingerprint.endpoint.url"))||"https://fp.descope.com",tn="dls_last_user_external_id";function nn(e,t){var n=[];return function(e,t){var n,r,o=(r=function(){for(var e=0,t=0,n=arguments.length;t<n;t++)e+=arguments[t].length;var r=Array(e),o=0;for(t=0;t<n;t++)for(var i=arguments[t],a=0,s=i.length;a<s;a++,o++)r[o]=i[a];return r}(e),{current:function(){return r[0]},postpone:function(){var e=r.shift();void 0!==e&&r.push(e)},exclude:function(){r.shift()}}),i=(100,3e3,n=0,function(){return Math.random()*Math.min(3e3,100*Math.pow(2,n++))}),a=o.current();if(void 0===a)return Promise.reject(new TypeError("The list of script URL patterns is empty"));var s=function(e,n){return t(e).catch((function(e){if(n+1>=5)throw e;!function(e){if(!(e instanceof Error))return!1;var t=e.message;return"Blocked by CSP"===t||"9319"===t}(e)?o.postpone():o.exclude();var t,r=o.current();if(void 0===r)throw e;return(t=i(),new Promise((function(e){return setTimeout(e,t)}))).then((function(){return s(r,n+1)}))}))};return s(a,0)}(e,(function(e){var r=new Date,o=function(){return n.push({url:e,startedAt:r,finishedAt:new Date})},i=t(e);return i.then(o,o),i})).then((function(e){return[e,{attempts:n}]}))}var rn="Failed to load the JS script of the agent";function on(e){var r;e.scriptUrlPattern;var o=e.token,i=e.apiKey,a=void 0===i?o:i,s=n(e,["scriptUrlPattern","token","apiKey"]),c=null!==(r=function(e,t){return function(e,t){return Object.prototype.hasOwnProperty.call(e,t)}(e,t)?e[t]:void 0}(e,"scriptUrlPattern"))&&void 0!==r?r:"https://fpnpmcdn.net/v<version>/<apiKey>/loader_v<loaderVersion>.js";return Promise.resolve().then((function(){if(!a||"string"!=typeof a)throw new Error("API key required");return nn(function(e,t){return(Array.isArray(e)?e:[e]).map((function(e){return function(e,t){var n=encodeURIComponent;return e.replace(/<[^<>]+>/g,(function(e){return"<version>"===e?"3":"<apiKey>"===e?n(t):"<loaderVersion>"===e?n("3.8.1"):e}))}(String(e),t)}))}(c,a),an).catch(cn)})).then((function(e){var n=e[0],r=e[1];return n.load(t(t({},s),{ldi:r}))}))}function an(e){return function(e,t,n,r){var o,i=document,a="securitypolicyviolation",s=function(t){var n=new URL(e,location.href),r=t.blockedURI;r!==n.href&&r!==n.protocol.slice(0,-1)&&r!==n.origin||(o=t,c())};i.addEventListener(a,s);var c=function(){return i.removeEventListener(a,s)};return Promise.resolve().then(t).then((function(e){return c(),e}),(function(e){return new Promise((function(e){return setTimeout(e)})).then((function(){if(c(),o)return function(){throw new Error("Blocked by CSP")}();throw e}))}))}(e,(function(){return function(e){return new Promise((function(t,n){var r=document.createElement("script"),o=function(){var e;return null===(e=r.parentNode)||void 0===e?void 0:e.removeChild(r)},i=document.head||document.getElementsByTagName("head")[0];r.onload=function(){o(),t()},r.onerror=function(){o(),n(new Error(rn))},r.async=!0,r.src=e,i.appendChild(r)}))}(e)})).then(sn)}function sn(){var e=window,t="__fpjs_p_l_b",n=e[t];if(function(e,t){var n,r=null===(n=Object.getOwnPropertyDescriptor)||void 0===n?void 0:n.call(Object,e,t);(null==r?void 0:r.configurable)?delete e[t]:r&&!r.writable||(e[t]=void 0)}(e,t),"function"!=typeof(null==n?void 0:n.load))throw new Error("9319");return n}function cn(e){throw e instanceof Error&&"9319"===e.message?new Error(rn):e}const un=(e="",t="")=>({vsid:e,vrid:t}),ln=(e=!1)=>{const t=localStorage.getItem("fp");if(!t)return null;const n=JSON.parse(t);return(new Date).getTime()>n.expiry&&!e?null:n.value},dn=async e=>{try{if(ln())return;const t=(Date.now().toString(36)+Math.random().toString(36).substring(2)+Math.random().toString(36).substring(2)).substring(0,27),n=on({apiKey:e||Yt,endpoint:en}),r=await n,{requestId:o}=await r.get({linkedId:t});(e=>{const t={value:e,expiry:(new Date).getTime()+864e5};localStorage.setItem("fp",JSON.stringify(t))})(un(t,o))}catch(e){global.FB_DEBUG&&console.error(e)}};var pn,fn,hn,gn,vn;const yn=e=>Object.assign({},e);class bn{constructor(e){pn.add(this),fn.set(this,void 0),hn.set(this,{}),gn.set(this,0),o(this,fn,e,"f")}get current(){return yn(r(this,fn,"f"))}update(e){const t=e;if(!((e,t)=>{const n=e&&Object.getOwnPropertyNames(e)||[],r=t&&Object.getOwnPropertyNames(t)||[];if(n.length!==r.length)return!1;for(let r=0;r<n.length;r+=1){const o=n[r];if(e[o]!==t[o])return!1}return!0})(r(this,fn,"f"),t)){const e=r(this,fn,"f");o(this,fn,t,"f"),Object.freeze(r(this,fn,"f")),setTimeout((()=>{Object.values(r(this,hn,"f")).forEach((n=>n(yn(t),e)))}),0)}}subscribe(e){o(this,gn,r(this,gn,"f")+1,"f"),r(this,hn,"f")[r(this,gn,"f")]=e;const t=r(this,gn,"f");return()=>r(this,pn,"m",vn).call(this,t.toString())}unsubscribeAll(){o(this,hn,{},"f")}}
/*! js-cookie v3.0.1 | MIT */
function bn(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)e[r]=n[r]}return e}pn=new WeakMap,fn=new WeakMap,hn=new WeakMap,dn=new WeakSet,gn=function(e){!!n(this,fn,"f")[e]&&delete n(this,fn,"f")[e]};var wn=function e(t,n){function r(e,r,o){if("undefined"!=typeof document){"number"==typeof(o=bn({},n,o)).expires&&(o.expires=new Date(Date.now()+864e5*o.expires)),o.expires&&(o.expires=o.expires.toUTCString()),e=encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);var i="";for(var a in o)o[a]&&(i+="; "+a,!0!==o[a]&&(i+="="+o[a].split(";")[0]));return document.cookie=e+"="+t.write(r,e)+i}}return Object.create({set:r,get:function(e){if("undefined"!=typeof document&&(!arguments.length||e)){for(var n=document.cookie?document.cookie.split("; "):[],r={},o=0;o<n.length;o++){var i=n[o].split("="),a=i.slice(1).join("=");try{var s=decodeURIComponent(i[0]);if(r[s]=t.read(a,s),e===s)break}catch(e){}}return e?r[e]:r}},remove:function(e,t){r(e,"",bn({},t,{expires:-1}))},withAttributes:function(t){return e(this.converter,bn({},this.attributes,t))},withConverter:function(t){return e(bn({},this.converter,t),this.attributes)}},{attributes:{value:Object.freeze(n)},converter:{value:Object.freeze(t)}})}({read:function(e){return'"'===e[0]&&(e=e.slice(1,-1)),e.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent)},write:function(e){return encodeURIComponent(e).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,decodeURIComponent)}},{path:"/"});const mn="DSR";let kn=[];function On(e,t,n){const r=function(e){const t=e.split(".");try{if(3===t.length){const t=JSON.parse(window.atob(e.split(".")[1]));if(t.exp)return new Date(1e3*t.exp)}}catch(e){}return null}(t);if(r){let t;for(;t=kn.pop();)clearTimeout(t);const o=r.getTime()-2e4-(new Date).getTime(),i=setTimeout((()=>{e(n)}),o);kn.push(i)}}function In(e,t,n){!function(e,{cookiePath:t,cookieDomain:n,cookieExpiration:r}){e&&wn.set("DS",e,{path:t,domain:n,expires:r,sameSite:"None",secure:!0})}(e,n),function(e){localStorage&&e&&localStorage.setItem(mn,e)}(t)}function jn(){return localStorage?null===localStorage||void 0===localStorage?void 0:localStorage.getItem(mn):""}async function Sn(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=Pn(n.publicKey.challenge),n.publicKey.user.id=Pn(n.publicKey.user.id),null===(t=n.publicKey.excludeCredentials)||void 0===t||t.forEach((e=>{e.id=Pn(e.id)})),n}(e),n=await navigator.credentials.create(t);return r=n,JSON.stringify(Object.assign(Object.assign({},r),{rawId:Un(r.rawId),response:Object.assign(Object.assign({},r.response),{attestationObject:Un(r.response.attestationObject),clientDataJSON:Un(r.response.clientDataJSON)})}));var r}async function _n(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=Pn(n.publicKey.challenge),null===(t=n.publicKey.allowCredentials)||void 0===t||t.forEach((e=>{e.id=Pn(e.id)})),n}(e),n=await navigator.credentials.get(t);return r=n,JSON.stringify(Object.assign(Object.assign({},r),{rawId:Un(r.rawId),response:Object.assign(Object.assign({},r.response),{authenticatorData:Un(r.response.authenticatorData),clientDataJSON:Un(r.response.clientDataJSON),signature:Un(r.response.signature),userHandle:r.response.userHandle?Un(r.response.userHandle):void 0})}));var r}async function xn(e=!1){if(!Qt)return Promise.resolve(!1);const t=!!(PublicKeyCredential&&navigator.credentials&&navigator.credentials.create&&navigator.credentials.get);return t&&e&&PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable?PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable():t}function Pn(e){const t=e.replace(/_/g,"/").replace(/-/g,"+");return Uint8Array.from(atob(t),(e=>e.charCodeAt(0))).buffer}function Un(e){return btoa(String.fromCharCode.apply(null,new Uint8Array(e))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}return e=>{var{autoRefresh:n=!0,persistTokens:r=!0,fpKey:o,fpLoad:i}=e,a=t(e,["autoRefresh","persistTokens","fpKey","fpLoad"]);Qt?i&&ln(o).catch((()=>null)):console.warn("Fingerprint is a client side only capability and will not work when running in the server");const s=a;let c,u;const l=new yn({sessionToken:""}),d=new yn({});s.hooks={beforeRequest:e=>null==c?void 0:c(e),afterRequest:(e,t)=>null==u?void 0:u(e,t)};const p=Zt(s),f=(h=p,{async signUp(e,t){const n=await h.webauthn.signUp.start(e,window.location.origin,t),r=await Sn(n.data.options);return await h.webauthn.signUp.finish(n.data.transactionId,r)},async signIn(e){const t=await h.webauthn.signIn.start(e,window.location.origin),n=await _n(t.data.options);return await h.webauthn.signIn.finish(t.data.transactionId,n)},async signUpOrIn(e){var t;const n=await h.webauthn.signUpOrIn.start(e,window.location.origin);if(null===(t=n.data)||void 0===t?void 0:t.create){const e=await Sn(n.data.options);return await h.webauthn.signUp.finish(n.data.transactionId,e)}{const e=await _n(n.data.options);return await h.webauthn.signIn.finish(n.data.transactionId,e)}},async update(e,t){const n=await h.webauthn.update.start(e,window.location.origin,t),r=await Sn(n.data.options);return await h.webauthn.update.finish(n.data.transactionId,r)},helpers:{create:Sn,get:_n,isSupported:xn}});var h;const g=Object.assign(Object.assign({},p),{flow:Object.assign(Object.assign({},p.flow),{start:async(e,t,n,r)=>{const o=await f.helpers.isSupported(),i=null===localStorage||void 0===localStorage?void 0:localStorage.getItem(en),a={tenant:null==r?void 0:r.tenant,redirectUrl:window.location.href,deviceInfo:{webAuthnSupport:o}};return i&&(a.lastUser={externalId:i}),p.flow.start(e,t,n,a)}}),webauthn:f,onSessionTokenChange:e=>{var t;const n=null===(t=l.current)||void 0===t?void 0:t.sessionToken;return n&&e(n),l.subscribe((({sessionToken:t})=>{e(t)}))},onUserChange:e=>{const t=d.current;return t&&Object.entries(t).length>0&&e(t),d.subscribe((t=>{e(t)}))},getRefreshToken:jn});return Qt?(n&&["logout","logoutAll"].forEach((e=>{const t=p[e];g[e]=(...e)=>{const n=jn(),r=[(null==e?void 0:e.shift())||n,...e],o=t(...r);return localStorage&&localStorage.removeItem(mn),wn.remove("DS"),Qt&&(null===localStorage||void 0===localStorage||localStorage.removeItem(en)),l.update({sessionToken:""}),o}})),c=e=>(e.body&&(e.body.fpData=un(!0)||cn()),!e.token&&r&&(e.token=jn()),e.headers=Object.assign(Object.assign({},e.headers),{"x-descope-sdk-name":"web-js","x-descope-sdk-version":"0.1.0-alpha.14"}),e),g.me=async(...e)=>{var t;const n=await p.me(...e);if(n.ok){const e=await(null===(t=n.response)||void 0===t?void 0:t.clone().json());d.update(e)}return n},(n||r)&&(u=(e,o)=>{!async function(e,n,r,o){var i;try{if(401===n.status)return r.sessionToken.update({sessionToken:""}),void r.user.update({});const a=await(null==n?void 0:n.json());if(a){const n=function(e){return(null==e?void 0:e.authInfo)||e||{}}(a),{sessionJwt:s,refreshJwt:c,user:u}=n,l=t(n,["sessionJwt","refreshJwt","user"]);if(o.persistTokens&&In(s,c,l),s&&r.sessionToken.update({sessionToken:s}),u){const e=null===(i=null==u?void 0:u.externalIds)||void 0===i?void 0:i[0];Qt&&e&&(null===localStorage||void 0===localStorage||localStorage.setItem(en,e)),r.user.update(u)}s&&c&&o.autoRefresh&&On(e,s,c)}}catch(e){console.error("Could not set tokens from body",e)}}(g.refresh,o,{sessionToken:l,user:d},{autoRefresh:n,persistTokens:r})}),n&&jn()&&g.refresh(),g):(console.warn("Storing auth tokens in local storage and cookies are a client side only capabilities and will not be done when running in the server"),g)}}));
function wn(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)e[r]=n[r]}return e}fn=new WeakMap,hn=new WeakMap,gn=new WeakMap,pn=new WeakSet,vn=function(e){!!r(this,hn,"f")[e]&&delete r(this,hn,"f")[e]};var mn=function e(t,n){function r(e,r,o){if("undefined"!=typeof document){"number"==typeof(o=wn({},n,o)).expires&&(o.expires=new Date(Date.now()+864e5*o.expires)),o.expires&&(o.expires=o.expires.toUTCString()),e=encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);var i="";for(var a in o)o[a]&&(i+="; "+a,!0!==o[a]&&(i+="="+o[a].split(";")[0]));return document.cookie=e+"="+t.write(r,e)+i}}return Object.create({set:r,get:function(e){if("undefined"!=typeof document&&(!arguments.length||e)){for(var n=document.cookie?document.cookie.split("; "):[],r={},o=0;o<n.length;o++){var i=n[o].split("="),a=i.slice(1).join("=");try{var s=decodeURIComponent(i[0]);if(r[s]=t.read(a,s),e===s)break}catch(e){}}return e?r[e]:r}},remove:function(e,t){r(e,"",wn({},t,{expires:-1}))},withAttributes:function(t){return e(this.converter,wn({},this.attributes,t))},withConverter:function(t){return e(wn({},this.converter,t),this.attributes)}},{attributes:{value:Object.freeze(n)},converter:{value:Object.freeze(t)}})}({read:function(e){return'"'===e[0]&&(e=e.slice(1,-1)),e.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent)},write:function(e){return encodeURIComponent(e).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,decodeURIComponent)}},{path:"/"});const kn="DS",In="DSR";let On=[];function jn(e,t,n){const r=function(e){const t=e.split(".");try{if(3===t.length){const t=JSON.parse(window.atob(e.split(".")[1]));if(t.exp)return new Date(1e3*t.exp)}}catch(e){}return null}(t);if(r){let t;for(;t=On.pop();)clearTimeout(t);const o=r.getTime()-2e4-(new Date).getTime(),i=setTimeout((()=>{e(n)}),o);On.push(i)}}async function Sn(e,t,r,o){var i;try{if(401===t.status)return r.sessionToken.update({sessionToken:""}),void r.user.update({});const a=await(null==t?void 0:t.json());if(a){const t=function(e){return(null==e?void 0:e.authInfo)||e||{}}(a),{sessionJwt:s,refreshJwt:c,user:u}=t,l=n(t,["sessionJwt","refreshJwt","user"]);if(o.persistTokens&&(function(e,{cookiePath:t,cookieDomain:n,cookieExpiration:r},o){e&&(o?mn.set(kn,e,{path:t,domain:n,expires:r,sameSite:"None",secure:!0}):localStorage&&localStorage.setItem(kn,e))}(s,l,o.sessionTokenViaCookie),function(e){localStorage&&e&&localStorage.setItem(In,e)}(c)),s&&r.sessionToken.update({sessionToken:s}),u){const e=null===(i=null==u?void 0:u.externalIds)||void 0===i?void 0:i[0];Xt&&e&&(null===localStorage||void 0===localStorage||localStorage.setItem(tn,e)),r.user.update(u)}s&&c&&o.autoRefresh&&jn(e,s,c)}}catch(e){console.error("Could not set tokens from body",e)}}function _n(){return localStorage?null===localStorage||void 0===localStorage?void 0:localStorage.getItem(In):""}async function xn(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=Tn(n.publicKey.challenge),n.publicKey.user.id=Tn(n.publicKey.user.id),null===(t=n.publicKey.excludeCredentials)||void 0===t||t.forEach((e=>{e.id=Tn(e.id)})),n}(e),n=await navigator.credentials.create(t);return r=n,JSON.stringify(Object.assign(Object.assign({},r),{rawId:Cn(r.rawId),response:Object.assign(Object.assign({},r.response),{attestationObject:Cn(r.response.attestationObject),clientDataJSON:Cn(r.response.clientDataJSON)})}));var r}async function Pn(e){const t=function(e){var t;const n=JSON.parse(e);return n.publicKey.challenge=Tn(n.publicKey.challenge),null===(t=n.publicKey.allowCredentials)||void 0===t||t.forEach((e=>{e.id=Tn(e.id)})),n}(e),n=await navigator.credentials.get(t);return r=n,JSON.stringify(Object.assign(Object.assign({},r),{rawId:Cn(r.rawId),response:Object.assign(Object.assign({},r.response),{authenticatorData:Cn(r.response.authenticatorData),clientDataJSON:Cn(r.response.clientDataJSON),signature:Cn(r.response.signature),userHandle:r.response.userHandle?Cn(r.response.userHandle):void 0})}));var r}async function Un(e=!1){if(!Xt)return Promise.resolve(!1);const t=!!(PublicKeyCredential&&navigator.credentials&&navigator.credentials.create&&navigator.credentials.get);return t&&e&&PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable?PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable():t}function Tn(e){const t=e.replace(/_/g,"/").replace(/-/g,"+");return Uint8Array.from(atob(t),(e=>e.charCodeAt(0))).buffer}function Cn(e){return btoa(String.fromCharCode.apply(null,new Uint8Array(e))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}e.createSdk=e=>{var{autoRefresh:t=!0,persistTokens:r=!0,sessionTokenViaCookie:o,fpKey:i,fpLoad:a}=e,s=n(e,["autoRefresh","persistTokens","sessionTokenViaCookie","fpKey","fpLoad"]);Xt?a&&dn(i).catch((()=>null)):console.warn("Fingerprint is a client side only capability and will not work when running in the server");const c=s;let u,l;const d=new bn({sessionToken:""}),p=new bn({});c.hooks={beforeRequest:e=>null==u?void 0:u(e),afterRequest:(e,t)=>null==l?void 0:l(e,t)};const f=Qt(c),h=(g=f,{async signUp(e,t){const n=await g.webauthn.signUp.start(e,window.location.origin,t),r=await xn(n.data.options);return await g.webauthn.signUp.finish(n.data.transactionId,r)},async signIn(e){const t=await g.webauthn.signIn.start(e,window.location.origin),n=await Pn(t.data.options);return await g.webauthn.signIn.finish(t.data.transactionId,n)},async signUpOrIn(e){var t;const n=await g.webauthn.signUpOrIn.start(e,window.location.origin);if(null===(t=n.data)||void 0===t?void 0:t.create){const e=await xn(n.data.options);return await g.webauthn.signUp.finish(n.data.transactionId,e)}{const e=await Pn(n.data.options);return await g.webauthn.signIn.finish(n.data.transactionId,e)}},async update(e,t){const n=await g.webauthn.update.start(e,window.location.origin,t),r=await xn(n.data.options);return await g.webauthn.update.finish(n.data.transactionId,r)},helpers:{create:xn,get:Pn,isSupported:Un}});var g;const v=Object.assign(Object.assign({},f),{flow:Object.assign(Object.assign({},f.flow),{start:async(e,t,n,r)=>{const o=await h.helpers.isSupported(),i=null===localStorage||void 0===localStorage?void 0:localStorage.getItem(tn),a={tenant:null==r?void 0:r.tenant,redirectUrl:window.location.href,deviceInfo:{webAuthnSupport:o}};return i&&(a.lastUser={externalId:i}),f.flow.start(e,t,n,a)}}),webauthn:h,onSessionTokenChange:e=>{var t;const n=null===(t=d.current)||void 0===t?void 0:t.sessionToken;return n&&e(n),d.subscribe((({sessionToken:t})=>{e(t)}))},onUserChange:e=>{const t=p.current;return t&&Object.entries(t).length>0&&e(t),p.subscribe((t=>{e(t)}))},getRefreshToken:_n});return Xt?(t&&["logout","logoutAll"].forEach((e=>{const t=f[e];v[e]=(...e)=>{const n=_n(),r=[(null==e?void 0:e.shift())||n,...e],o=t(...r);return null===localStorage||void 0===localStorage||localStorage.removeItem(In),null===localStorage||void 0===localStorage||localStorage.removeItem(kn),mn.remove(kn),Xt&&(null===localStorage||void 0===localStorage||localStorage.removeItem(tn)),d.update({sessionToken:""}),o}})),u=e=>(e.body&&(e.body.fpData=ln(!0)||un()),!e.token&&r&&(e.token=_n()),e.headers=Object.assign(Object.assign({},e.headers),{"x-descope-sdk-name":"web-js","x-descope-sdk-version":"0.1.0-alpha.15"}),e),v.me=async(...e)=>{var t;const n=await f.me(...e);if(n.ok){const e=await(null===(t=n.response)||void 0===t?void 0:t.clone().json());p.update(e)}return n},(t||r)&&(l=(e,n)=>{Sn(v.refresh,n,{sessionToken:d,user:p},{autoRefresh:t,persistTokens:r,sessionTokenViaCookie:o})}),t&&_n()&&v.refresh(),v):(console.warn("Storing auth tokens in local storage and cookies are a client side only capabilities and will not be done when running in the server"),v)},e.getSessionToken=function(){return mn.get(kn)||(null===localStorage||void 0===localStorage?void 0:localStorage.getItem(kn))||""},Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=index.umd.js.map
{
"name": "@descope/web-js-sdk",
"version": "0.1.0-alpha.14",
"version": "0.1.0-alpha.15",
"main": "dist/cjs/index.cjs.js",

@@ -52,3 +52,3 @@ "module": "dist/index.esm.js",

"@typescript-eslint/parser": "^5.33.1",
"eslint": "8.28.0",
"eslint": "8.29.0",
"eslint-config-airbnb-typescript": "17.0.0",

@@ -55,0 +55,0 @@ "eslint-config-prettier": "8.5.0",

@@ -16,3 +16,3 @@ # @descope/web-js-sdk

```js
import descopeSdk from '@descope/web-js-sdk';
import descopeSdk, { getSessionToken } from '@descope/web-js-sdk';

@@ -31,2 +31,6 @@ const myProjectId = 'xxx';

sdk.otp.signIn.email(userIdentifier);
// Get session token
// can be used to pass token to server on header
const sessionToken = getSessionToken();
```

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

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