authhero 5.1.0 → 5.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/authhero.cjs CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var t9=Object.create;var W1=Object.defineProperty;var n9=Object.getOwnPropertyDescriptor;var i9=Object.getOwnPropertyNames;var r9=Object.getPrototypeOf,o9=Object.prototype.hasOwnProperty;var s9=(e,t,n,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of i9(t))!o9.call(e,r)&&r!==n&&W1(e,r,{get:()=>t[r],enumerable:!(i=n9(t,r))||i.enumerable});return e};var a9=(e,t,n)=>(n=e!=null?t9(r9(e)):{},s9(t||!e||!e.__esModule?W1(n,"default",{value:e,enumerable:!0}):n,e));Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("@hono/zod-openapi");var z=class extends Error{res;status;constructor(e=500,t){super(t?.message,{cause:t?.cause}),this.res=t?.res,this.status=e}getResponse(){return this.res?new Response(this.res.body,{status:this.status,headers:this.res.headers}):new Response(this.message,{status:this.status})}};const Te=e=>typeof e=="string",Oc=()=>{let e,t;const n=new Promise((i,r)=>{e=i,t=r});return n.resolve=e,n.reject=t,n},J1=e=>e==null?"":""+e,c9=(e,t,n)=>{e.forEach(i=>{t[i]&&(n[i]=t[i])})},l9=/###/g,Y1=e=>e&&e.indexOf("###")>-1?e.replace(l9,"."):e,Q1=e=>!e||Te(e),Il=(e,t,n)=>{const i=Te(t)?t.split("."):t;let r=0;for(;r<i.length-1;){if(Q1(e))return{};const o=Y1(i[r]);!e[o]&&n&&(e[o]=new n),Object.prototype.hasOwnProperty.call(e,o)?e=e[o]:e={},++r}return Q1(e)?{}:{obj:e,k:Y1(i[r])}},Z1=(e,t,n)=>{const{obj:i,k:r}=Il(e,t,Object);if(i!==void 0||t.length===1){i[r]=n;return}let o=t[t.length-1],a=t.slice(0,t.length-1),c=Il(e,a,Object);for(;c.obj===void 0&&a.length;)o=`${a[a.length-1]}.${o}`,a=a.slice(0,a.length-1),c=Il(e,a,Object),c?.obj&&typeof c.obj[`${c.k}.${o}`]<"u"&&(c.obj=void 0);c.obj[`${c.k}.${o}`]=n},d9=(e,t,n,i)=>{const{obj:r,k:o}=Il(e,t,Object);r[o]=r[o]||[],r[o].push(n)},Sp=(e,t)=>{const{obj:n,k:i}=Il(e,t);if(n&&Object.prototype.hasOwnProperty.call(n,i))return n[i]},u9=(e,t,n)=>{const i=Sp(e,n);return i!==void 0?i:Sp(t,n)},gx=(e,t,n)=>{for(const i in t)i!=="__proto__"&&i!=="constructor"&&(i in e?Te(e[i])||e[i]instanceof String||Te(t[i])||t[i]instanceof String?n&&(e[i]=t[i]):gx(e[i],t[i],n):e[i]=t[i]);return e},wo=e=>e.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g,"\\$&");var p9={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;","/":"&#x2F;"};const f9=e=>Te(e)?e.replace(/[&<>"'\/]/g,t=>p9[t]):e;class h9{constructor(t){this.capacity=t,this.regExpMap=new Map,this.regExpQueue=[]}getRegExp(t){const n=this.regExpMap.get(t);if(n!==void 0)return n;const i=new RegExp(t);return this.regExpQueue.length===this.capacity&&this.regExpMap.delete(this.regExpQueue.shift()),this.regExpMap.set(t,i),this.regExpQueue.push(t),i}}const g9=[" ",",","?","!",";"],m9=new h9(20),y9=(e,t,n)=>{t=t||"",n=n||"";const i=g9.filter(a=>t.indexOf(a)<0&&n.indexOf(a)<0);if(i.length===0)return!0;const r=m9.getRegExp(`(${i.map(a=>a==="?"?"\\?":a).join("|")})`);let o=!r.test(e);if(!o){const a=e.indexOf(n);a>0&&!r.test(e.substring(0,a))&&(o=!0)}return o},yy=(e,t,n=".")=>{if(!e)return;if(e[t])return Object.prototype.hasOwnProperty.call(e,t)?e[t]:void 0;const i=t.split(n);let r=e;for(let o=0;o<i.length;){if(!r||typeof r!="object")return;let a,c="";for(let l=o;l<i.length;++l)if(l!==o&&(c+=n),c+=i[l],a=r[c],a!==void 0){if(["string","number","boolean"].indexOf(typeof a)>-1&&l<i.length-1)continue;o+=l-o+1;break}r=a}return r},Ul=e=>e?.replace(/_/g,"-"),_9={type:"logger",log(e){this.output("log",e)},warn(e){this.output("warn",e)},error(e){this.output("error",e)},output(e,t){console?.[e]?.apply?.(console,t)}};class Ep{constructor(t,n={}){this.init(t,n)}init(t,n={}){this.prefix=n.prefix||"i18next:",this.logger=t||_9,this.options=n,this.debug=n.debug}log(...t){return this.forward(t,"log","",!0)}warn(...t){return this.forward(t,"warn","",!0)}error(...t){return this.forward(t,"error","")}deprecate(...t){return this.forward(t,"warn","WARNING DEPRECATED: ",!0)}forward(t,n,i,r){return r&&!this.debug?null:(Te(t[0])&&(t[0]=`${i}${this.prefix} ${t[0]}`),this.logger[n](t))}create(t){return new Ep(this.logger,{prefix:`${this.prefix}:${t}:`,...this.options})}clone(t){return t=t||this.options,t.prefix=t.prefix||this.prefix,new Ep(this.logger,t)}}var Pi=new Ep;class mh{constructor(){this.observers={}}on(t,n){return t.split(" ").forEach(i=>{this.observers[i]||(this.observers[i]=new Map);const r=this.observers[i].get(n)||0;this.observers[i].set(n,r+1)}),this}off(t,n){if(this.observers[t]){if(!n){delete this.observers[t];return}this.observers[t].delete(n)}}emit(t,...n){this.observers[t]&&Array.from(this.observers[t].entries()).forEach(([r,o])=>{for(let a=0;a<o;a++)r(...n)}),this.observers["*"]&&Array.from(this.observers["*"].entries()).forEach(([r,o])=>{for(let a=0;a<o;a++)r.apply(r,[t,...n])})}}class X1 extends mh{constructor(t,n={ns:["translation"],defaultNS:"translation"}){super(),this.data=t||{},this.options=n,this.options.keySeparator===void 0&&(this.options.keySeparator="."),this.options.ignoreJSONStructure===void 0&&(this.options.ignoreJSONStructure=!0)}addNamespaces(t){this.options.ns.indexOf(t)<0&&this.options.ns.push(t)}removeNamespaces(t){const n=this.options.ns.indexOf(t);n>-1&&this.options.ns.splice(n,1)}getResource(t,n,i,r={}){const o=r.keySeparator!==void 0?r.keySeparator:this.options.keySeparator,a=r.ignoreJSONStructure!==void 0?r.ignoreJSONStructure:this.options.ignoreJSONStructure;let c;t.indexOf(".")>-1?c=t.split("."):(c=[t,n],i&&(Array.isArray(i)?c.push(...i):Te(i)&&o?c.push(...i.split(o)):c.push(i)));const l=Sp(this.data,c);return!l&&!n&&!i&&t.indexOf(".")>-1&&(t=c[0],n=c[1],i=c.slice(2).join(".")),l||!a||!Te(i)?l:yy(this.data?.[t]?.[n],i,o)}addResource(t,n,i,r,o={silent:!1}){const a=o.keySeparator!==void 0?o.keySeparator:this.options.keySeparator;let c=[t,n];i&&(c=c.concat(a?i.split(a):i)),t.indexOf(".")>-1&&(c=t.split("."),r=n,n=c[1]),this.addNamespaces(n),Z1(this.data,c,r),o.silent||this.emit("added",t,n,i,r)}addResources(t,n,i,r={silent:!1}){for(const o in i)(Te(i[o])||Array.isArray(i[o]))&&this.addResource(t,n,o,i[o],{silent:!0});r.silent||this.emit("added",t,n,i)}addResourceBundle(t,n,i,r,o,a={silent:!1,skipCopy:!1}){let c=[t,n];t.indexOf(".")>-1&&(c=t.split("."),r=i,i=n,n=c[1]),this.addNamespaces(n);let l=Sp(this.data,c)||{};a.skipCopy||(i=JSON.parse(JSON.stringify(i))),r?gx(l,i,o):l={...l,...i},Z1(this.data,c,l),a.silent||this.emit("added",t,n,i)}removeResourceBundle(t,n){this.hasResourceBundle(t,n)&&delete this.data[t][n],this.removeNamespaces(n),this.emit("removed",t,n)}hasResourceBundle(t,n){return this.getResource(t,n)!==void 0}getResourceBundle(t,n){return n||(n=this.options.defaultNS),this.getResource(t,n)}getDataByLanguage(t){return this.data[t]}hasLanguageSomeTranslations(t){const n=this.getDataByLanguage(t);return!!(n&&Object.keys(n)||[]).find(r=>n[r]&&Object.keys(n[r]).length>0)}toJSON(){return this.data}}var mx={processors:{},addPostProcessor(e){this.processors[e.name]=e},handle(e,t,n,i,r){return e.forEach(o=>{t=this.processors[o]?.process(t,n,i,r)??t}),t}};const yx=Symbol("i18next/PATH_KEY");function w9(){const e=[],t=Object.create(null);let n;return t.get=(i,r)=>(n?.revoke?.(),r===yx?e:(e.push(r),n=Proxy.revocable(i,t),n.proxy)),Proxy.revocable(Object.create(null),t).proxy}function _a(e,t){const{[yx]:n}=e(w9()),i=t?.keySeparator??".",r=t?.nsSeparator??":";if(n.length>1&&r){const o=t?.ns,a=Array.isArray(o)?o:null;if(a&&a.length>1&&a.slice(1).includes(n[0]))return`${n[0]}${r}${n.slice(1).join(i)}`}return n.join(i)}const e2={},tm=e=>!Te(e)&&typeof e!="boolean"&&typeof e!="number";class xp extends mh{constructor(t,n={}){super(),c9(["resourceStore","languageUtils","pluralResolver","interpolator","backendConnector","i18nFormat","utils"],t,this),this.options=n,this.options.keySeparator===void 0&&(this.options.keySeparator="."),this.logger=Pi.create("translator")}changeLanguage(t){t&&(this.language=t)}exists(t,n={interpolation:{}}){const i={...n};if(t==null)return!1;const r=this.resolve(t,i);if(r?.res===void 0)return!1;const o=tm(r.res);return!(i.returnObjects===!1&&o)}extractFromKey(t,n){let i=n.nsSeparator!==void 0?n.nsSeparator:this.options.nsSeparator;i===void 0&&(i=":");const r=n.keySeparator!==void 0?n.keySeparator:this.options.keySeparator;let o=n.ns||this.options.defaultNS||[];const a=i&&t.indexOf(i)>-1,c=!this.options.userDefinedKeySeparator&&!n.keySeparator&&!this.options.userDefinedNsSeparator&&!n.nsSeparator&&!y9(t,i,r);if(a&&!c){const l=t.match(this.interpolator.nestingRegexp);if(l&&l.length>0)return{key:t,namespaces:Te(o)?[o]:o};const d=t.split(i);(i!==r||i===r&&this.options.ns.indexOf(d[0])>-1)&&(o=d.shift()),t=d.join(r)}return{key:t,namespaces:Te(o)?[o]:o}}translate(t,n,i){let r=typeof n=="object"?{...n}:n;if(typeof r!="object"&&this.options.overloadTranslationOptionHandler&&(r=this.options.overloadTranslationOptionHandler(arguments)),typeof r=="object"&&(r={...r}),r||(r={}),t==null)return"";typeof t=="function"&&(t=_a(t,{...this.options,...r})),Array.isArray(t)||(t=[String(t)]),t=t.map(O=>typeof O=="function"?_a(O,{...this.options,...r}):String(O));const o=r.returnDetails!==void 0?r.returnDetails:this.options.returnDetails,a=r.keySeparator!==void 0?r.keySeparator:this.options.keySeparator,{key:c,namespaces:l}=this.extractFromKey(t[t.length-1],r),d=l[l.length-1];let u=r.nsSeparator!==void 0?r.nsSeparator:this.options.nsSeparator;u===void 0&&(u=":");const p=r.lng||this.language,f=r.appendNamespaceToCIMode||this.options.appendNamespaceToCIMode;if(p?.toLowerCase()==="cimode")return f?o?{res:`${d}${u}${c}`,usedKey:c,exactUsedKey:c,usedLng:p,usedNS:d,usedParams:this.getUsedParamsDetails(r)}:`${d}${u}${c}`:o?{res:c,usedKey:c,exactUsedKey:c,usedLng:p,usedNS:d,usedParams:this.getUsedParamsDetails(r)}:c;const h=this.resolve(t,r);let g=h?.res;const m=h?.usedKey||c,_=h?.exactUsedKey||c,w=["[object Number]","[object Function]","[object RegExp]"],y=r.joinArrays!==void 0?r.joinArrays:this.options.joinArrays,b=!this.i18nFormat||this.i18nFormat.handleAsObject,A=r.count!==void 0&&!Te(r.count),v=xp.hasDefaultValue(r),k=A?this.pluralResolver.getSuffix(p,r.count,r):"",x=r.ordinal&&A?this.pluralResolver.getSuffix(p,r.count,{ordinal:!1}):"",I=A&&!r.ordinal&&r.count===0,$=I&&r[`defaultValue${this.options.pluralSeparator}zero`]||r[`defaultValue${k}`]||r[`defaultValue${x}`]||r.defaultValue;let N=g;b&&!g&&v&&(N=$);const T=tm(N),P=Object.prototype.toString.apply(N);if(b&&N&&T&&w.indexOf(P)<0&&!(Te(y)&&Array.isArray(N))){if(!r.returnObjects&&!this.options.returnObjects){this.options.returnedObjectHandler||this.logger.warn("accessing an object - but returnObjects options is not enabled!");const O=this.options.returnedObjectHandler?this.options.returnedObjectHandler(m,N,{...r,ns:l}):`key '${c} (${this.language})' returned an object instead of string.`;return o?(h.res=O,h.usedParams=this.getUsedParamsDetails(r),h):O}if(a){const O=Array.isArray(N),j=O?[]:{},F=O?_:m;for(const L in N)if(Object.prototype.hasOwnProperty.call(N,L)){const M=`${F}${a}${L}`;v&&!g?j[L]=this.translate(M,{...r,defaultValue:tm($)?$[L]:void 0,joinArrays:!1,ns:l}):j[L]=this.translate(M,{...r,joinArrays:!1,ns:l}),j[L]===M&&(j[L]=N[L])}g=j}}else if(b&&Te(y)&&Array.isArray(g))g=g.join(y),g&&(g=this.extendTranslation(g,t,r,i));else{let O=!1,j=!1;!this.isValidLookup(g)&&v&&(O=!0,g=$),this.isValidLookup(g)||(j=!0,g=c);const L=(r.missingKeyNoValueFallbackToKey||this.options.missingKeyNoValueFallbackToKey)&&j?void 0:g,M=v&&$!==g&&this.options.updateMissing;if(j||O||M){if(this.logger.log(M?"updateKey":"missingKey",p,d,c,M?$:g),a){const Q=this.resolve(c,{...r,keySeparator:!1});Q&&Q.res&&this.logger.warn("Seems the loaded translations were in flat JSON format instead of nested. Either set keySeparator: false on init or make sure your translations are published in nested format.")}let H=[];const W=this.languageUtils.getFallbackCodes(this.options.fallbackLng,r.lng||this.language);if(this.options.saveMissingTo==="fallback"&&W&&W[0])for(let Q=0;Q<W.length;Q++)H.push(W[Q]);else this.options.saveMissingTo==="all"?H=this.languageUtils.toResolveHierarchy(r.lng||this.language):H.push(r.lng||this.language);const te=(Q,ee,K)=>{const ke=v&&K!==g?K:L;this.options.missingKeyHandler?this.options.missingKeyHandler(Q,d,ee,ke,M,r):this.backendConnector?.saveMissing&&this.backendConnector.saveMissing(Q,d,ee,ke,M,r),this.emit("missingKey",Q,d,ee,g)};this.options.saveMissing&&(this.options.saveMissingPlurals&&A?H.forEach(Q=>{const ee=this.pluralResolver.getSuffixes(Q,r);I&&r[`defaultValue${this.options.pluralSeparator}zero`]&&ee.indexOf(`${this.options.pluralSeparator}zero`)<0&&ee.push(`${this.options.pluralSeparator}zero`),ee.forEach(K=>{te([Q],c+K,r[`defaultValue${K}`]||$)})}):te(H,c,$))}g=this.extendTranslation(g,t,r,h,i),j&&g===c&&this.options.appendNamespaceToMissingKey&&(g=`${d}${u}${c}`),(j||O)&&this.options.parseMissingKeyHandler&&(g=this.options.parseMissingKeyHandler(this.options.appendNamespaceToMissingKey?`${d}${u}${c}`:c,O?g:void 0,r))}return o?(h.res=g,h.usedParams=this.getUsedParamsDetails(r),h):g}extendTranslation(t,n,i,r,o){if(this.i18nFormat?.parse)t=this.i18nFormat.parse(t,{...this.options.interpolation.defaultVariables,...i},i.lng||this.language||r.usedLng,r.usedNS,r.usedKey,{resolved:r});else if(!i.skipInterpolation){i.interpolation&&this.interpolator.init({...i,interpolation:{...this.options.interpolation,...i.interpolation}});const l=Te(t)&&(i?.interpolation?.skipOnVariables!==void 0?i.interpolation.skipOnVariables:this.options.interpolation.skipOnVariables);let d;if(l){const p=t.match(this.interpolator.nestingRegexp);d=p&&p.length}let u=i.replace&&!Te(i.replace)?i.replace:i;if(this.options.interpolation.defaultVariables&&(u={...this.options.interpolation.defaultVariables,...u}),t=this.interpolator.interpolate(t,u,i.lng||this.language||r.usedLng,i),l){const p=t.match(this.interpolator.nestingRegexp),f=p&&p.length;d<f&&(i.nest=!1)}!i.lng&&r&&r.res&&(i.lng=this.language||r.usedLng),i.nest!==!1&&(t=this.interpolator.nest(t,(...p)=>o?.[0]===p[0]&&!i.context?(this.logger.warn(`It seems you are nesting recursively key: ${p[0]} in key: ${n[0]}`),null):this.translate(...p,n),i)),i.interpolation&&this.interpolator.reset()}const a=i.postProcess||this.options.postProcess,c=Te(a)?[a]:a;return t!=null&&c?.length&&i.applyPostProcessor!==!1&&(t=mx.handle(c,t,n,this.options&&this.options.postProcessPassResolved?{i18nResolved:{...r,usedParams:this.getUsedParamsDetails(i)},...i}:i,this)),t}resolve(t,n={}){let i,r,o,a,c;return Te(t)&&(t=[t]),Array.isArray(t)&&(t=t.map(l=>typeof l=="function"?_a(l,{...this.options,...n}):l)),t.forEach(l=>{if(this.isValidLookup(i))return;const d=this.extractFromKey(l,n),u=d.key;r=u;let p=d.namespaces;this.options.fallbackNS&&(p=p.concat(this.options.fallbackNS));const f=n.count!==void 0&&!Te(n.count),h=f&&!n.ordinal&&n.count===0,g=n.context!==void 0&&(Te(n.context)||typeof n.context=="number")&&n.context!=="",m=n.lngs?n.lngs:this.languageUtils.toResolveHierarchy(n.lng||this.language,n.fallbackLng);p.forEach(_=>{this.isValidLookup(i)||(c=_,!e2[`${m[0]}-${_}`]&&this.utils?.hasLoadedNamespace&&!this.utils?.hasLoadedNamespace(c)&&(e2[`${m[0]}-${_}`]=!0,this.logger.warn(`key "${r}" for languages "${m.join(", ")}" won't get resolved as namespace "${c}" was not yet loaded`,"This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!")),m.forEach(w=>{if(this.isValidLookup(i))return;a=w;const y=[u];if(this.i18nFormat?.addLookupKeys)this.i18nFormat.addLookupKeys(y,u,w,_,n);else{let A;f&&(A=this.pluralResolver.getSuffix(w,n.count,n));const v=`${this.options.pluralSeparator}zero`,k=`${this.options.pluralSeparator}ordinal${this.options.pluralSeparator}`;if(f&&(n.ordinal&&A.indexOf(k)===0&&y.push(u+A.replace(k,this.options.pluralSeparator)),y.push(u+A),h&&y.push(u+v)),g){const x=`${u}${this.options.contextSeparator||"_"}${n.context}`;y.push(x),f&&(n.ordinal&&A.indexOf(k)===0&&y.push(x+A.replace(k,this.options.pluralSeparator)),y.push(x+A),h&&y.push(x+v))}}let b;for(;b=y.pop();)this.isValidLookup(i)||(o=b,i=this.getResource(w,_,b,n))}))})}),{res:i,usedKey:r,exactUsedKey:o,usedLng:a,usedNS:c}}isValidLookup(t){return t!==void 0&&!(!this.options.returnNull&&t===null)&&!(!this.options.returnEmptyString&&t==="")}getResource(t,n,i,r={}){return this.i18nFormat?.getResource?this.i18nFormat.getResource(t,n,i,r):this.resourceStore.getResource(t,n,i,r)}getUsedParamsDetails(t={}){const n=["defaultValue","ordinal","context","replace","lng","lngs","fallbackLng","ns","keySeparator","nsSeparator","returnObjects","returnDetails","joinArrays","postProcess","interpolation"],i=t.replace&&!Te(t.replace);let r=i?t.replace:t;if(i&&typeof t.count<"u"&&(r.count=t.count),this.options.interpolation.defaultVariables&&(r={...this.options.interpolation.defaultVariables,...r}),!i){r={...r};for(const o of n)delete r[o]}return r}static hasDefaultValue(t){const n="defaultValue";for(const i in t)if(Object.prototype.hasOwnProperty.call(t,i)&&n===i.substring(0,n.length)&&t[i]!==void 0)return!0;return!1}}class t2{constructor(t){this.options=t,this.supportedLngs=this.options.supportedLngs||!1,this.logger=Pi.create("languageUtils")}getScriptPartFromCode(t){if(t=Ul(t),!t||t.indexOf("-")<0)return null;const n=t.split("-");return n.length===2||(n.pop(),n[n.length-1].toLowerCase()==="x")?null:this.formatLanguageCode(n.join("-"))}getLanguagePartFromCode(t){if(t=Ul(t),!t||t.indexOf("-")<0)return t;const n=t.split("-");return this.formatLanguageCode(n[0])}formatLanguageCode(t){if(Te(t)&&t.indexOf("-")>-1){let n;try{n=Intl.getCanonicalLocales(t)[0]}catch{}return n&&this.options.lowerCaseLng&&(n=n.toLowerCase()),n||(this.options.lowerCaseLng?t.toLowerCase():t)}return this.options.cleanCode||this.options.lowerCaseLng?t.toLowerCase():t}isSupportedCode(t){return(this.options.load==="languageOnly"||this.options.nonExplicitSupportedLngs)&&(t=this.getLanguagePartFromCode(t)),!this.supportedLngs||!this.supportedLngs.length||this.supportedLngs.indexOf(t)>-1}getBestMatchFromCodes(t){if(!t)return null;let n;return t.forEach(i=>{if(n)return;const r=this.formatLanguageCode(i);(!this.options.supportedLngs||this.isSupportedCode(r))&&(n=r)}),!n&&this.options.supportedLngs&&t.forEach(i=>{if(n)return;const r=this.getScriptPartFromCode(i);if(this.isSupportedCode(r))return n=r;const o=this.getLanguagePartFromCode(i);if(this.isSupportedCode(o))return n=o;n=this.options.supportedLngs.find(a=>{if(a===o)return a;if(!(a.indexOf("-")<0&&o.indexOf("-")<0)&&(a.indexOf("-")>0&&o.indexOf("-")<0&&a.substring(0,a.indexOf("-"))===o||a.indexOf(o)===0&&o.length>1))return a})}),n||(n=this.getFallbackCodes(this.options.fallbackLng)[0]),n}getFallbackCodes(t,n){if(!t)return[];if(typeof t=="function"&&(t=t(n)),Te(t)&&(t=[t]),Array.isArray(t))return t;if(!n)return t.default||[];let i=t[n];return i||(i=t[this.getScriptPartFromCode(n)]),i||(i=t[this.formatLanguageCode(n)]),i||(i=t[this.getLanguagePartFromCode(n)]),i||(i=t.default),i||[]}toResolveHierarchy(t,n){const i=this.getFallbackCodes((n===!1?[]:n)||this.options.fallbackLng||[],t),r=[],o=a=>{a&&(this.isSupportedCode(a)?r.push(a):this.logger.warn(`rejecting language code not found in supportedLngs: ${a}`))};return Te(t)&&(t.indexOf("-")>-1||t.indexOf("_")>-1)?(this.options.load!=="languageOnly"&&o(this.formatLanguageCode(t)),this.options.load!=="languageOnly"&&this.options.load!=="currentOnly"&&o(this.getScriptPartFromCode(t)),this.options.load!=="currentOnly"&&o(this.getLanguagePartFromCode(t))):Te(t)&&o(this.formatLanguageCode(t)),i.forEach(a=>{r.indexOf(a)<0&&o(this.formatLanguageCode(a))}),r}}const n2={zero:0,one:1,two:2,few:3,many:4,other:5},i2={select:e=>e===1?"one":"other",resolvedOptions:()=>({pluralCategories:["one","other"]})};class b9{constructor(t,n={}){this.languageUtils=t,this.options=n,this.logger=Pi.create("pluralResolver"),this.pluralRulesCache={}}clearCache(){this.pluralRulesCache={}}getRule(t,n={}){const i=Ul(t==="dev"?"en":t),r=n.ordinal?"ordinal":"cardinal",o=JSON.stringify({cleanedCode:i,type:r});if(o in this.pluralRulesCache)return this.pluralRulesCache[o];let a;try{a=new Intl.PluralRules(i,{type:r})}catch{if(typeof Intl>"u")return this.logger.error("No Intl support, please use an Intl polyfill!"),i2;if(!t.match(/-|_/))return i2;const l=this.languageUtils.getLanguagePartFromCode(t);a=this.getRule(l,n)}return this.pluralRulesCache[o]=a,a}needsPlural(t,n={}){let i=this.getRule(t,n);return i||(i=this.getRule("dev",n)),i?.resolvedOptions().pluralCategories.length>1}getPluralFormsOfKey(t,n,i={}){return this.getSuffixes(t,i).map(r=>`${n}${r}`)}getSuffixes(t,n={}){let i=this.getRule(t,n);return i||(i=this.getRule("dev",n)),i?i.resolvedOptions().pluralCategories.sort((r,o)=>n2[r]-n2[o]).map(r=>`${this.options.prepend}${n.ordinal?`ordinal${this.options.prepend}`:""}${r}`):[]}getSuffix(t,n,i={}){const r=this.getRule(t,i);return r?`${this.options.prepend}${i.ordinal?`ordinal${this.options.prepend}`:""}${r.select(n)}`:(this.logger.warn(`no plural rule found for: ${t}`),this.getSuffix("dev",n,i))}}const r2=(e,t,n,i=".",r=!0)=>{let o=u9(e,t,n);return!o&&r&&Te(n)&&(o=yy(e,n,i),o===void 0&&(o=yy(t,n,i))),o},nm=e=>e.replace(/\$/g,"$$$$");class o2{constructor(t={}){this.logger=Pi.create("interpolator"),this.options=t,this.format=t?.interpolation?.format||(n=>n),this.init(t)}init(t={}){t.interpolation||(t.interpolation={escapeValue:!0});const{escape:n,escapeValue:i,useRawValueToEscape:r,prefix:o,prefixEscaped:a,suffix:c,suffixEscaped:l,formatSeparator:d,unescapeSuffix:u,unescapePrefix:p,nestingPrefix:f,nestingPrefixEscaped:h,nestingSuffix:g,nestingSuffixEscaped:m,nestingOptionsSeparator:_,maxReplaces:w,alwaysFormat:y}=t.interpolation;this.escape=n!==void 0?n:f9,this.escapeValue=i!==void 0?i:!0,this.useRawValueToEscape=r!==void 0?r:!1,this.prefix=o?wo(o):a||"{{",this.suffix=c?wo(c):l||"}}",this.formatSeparator=d||",",this.unescapePrefix=u?"":p||"-",this.unescapeSuffix=this.unescapePrefix?"":u||"",this.nestingPrefix=f?wo(f):h||wo("$t("),this.nestingSuffix=g?wo(g):m||wo(")"),this.nestingOptionsSeparator=_||",",this.maxReplaces=w||1e3,this.alwaysFormat=y!==void 0?y:!1,this.resetRegExp()}reset(){this.options&&this.init(this.options)}resetRegExp(){const t=(n,i)=>n?.source===i?(n.lastIndex=0,n):new RegExp(i,"g");this.regexp=t(this.regexp,`${this.prefix}(.+?)${this.suffix}`),this.regexpUnescape=t(this.regexpUnescape,`${this.prefix}${this.unescapePrefix}(.+?)${this.unescapeSuffix}${this.suffix}`),this.nestingRegexp=t(this.nestingRegexp,`${this.nestingPrefix}((?:[^()"']+|"[^"]*"|'[^']*'|\\((?:[^()]|"[^"]*"|'[^']*')*\\))*?)${this.nestingSuffix}`)}interpolate(t,n,i,r){let o,a,c;const l=this.options&&this.options.interpolation&&this.options.interpolation.defaultVariables||{},d=h=>{if(h.indexOf(this.formatSeparator)<0){const w=r2(n,l,h,this.options.keySeparator,this.options.ignoreJSONStructure);return this.alwaysFormat?this.format(w,void 0,i,{...r,...n,interpolationkey:h}):w}const g=h.split(this.formatSeparator),m=g.shift().trim(),_=g.join(this.formatSeparator).trim();return this.format(r2(n,l,m,this.options.keySeparator,this.options.ignoreJSONStructure),_,i,{...r,...n,interpolationkey:m})};this.resetRegExp();const u=r?.missingInterpolationHandler||this.options.missingInterpolationHandler,p=r?.interpolation?.skipOnVariables!==void 0?r.interpolation.skipOnVariables:this.options.interpolation.skipOnVariables;return[{regex:this.regexpUnescape,safeValue:h=>nm(h)},{regex:this.regexp,safeValue:h=>this.escapeValue?nm(this.escape(h)):nm(h)}].forEach(h=>{for(c=0;o=h.regex.exec(t);){const g=o[1].trim();if(a=d(g),a===void 0)if(typeof u=="function"){const _=u(t,o,r);a=Te(_)?_:""}else if(r&&Object.prototype.hasOwnProperty.call(r,g))a="";else if(p){a=o[0];continue}else this.logger.warn(`missed to pass in variable ${g} for interpolating ${t}`),a="";else!Te(a)&&!this.useRawValueToEscape&&(a=J1(a));const m=h.safeValue(a);if(t=t.replace(o[0],m),p?(h.regex.lastIndex+=a.length,h.regex.lastIndex-=o[0].length):h.regex.lastIndex=0,c++,c>=this.maxReplaces)break}}),t}nest(t,n,i={}){let r,o,a;const c=(l,d)=>{const u=this.nestingOptionsSeparator;if(l.indexOf(u)<0)return l;const p=l.split(new RegExp(`${wo(u)}[ ]*{`));let f=`{${p[1]}`;l=p[0],f=this.interpolate(f,a);const h=f.match(/'/g),g=f.match(/"/g);((h?.length??0)%2===0&&!g||(g?.length??0)%2!==0)&&(f=f.replace(/'/g,'"'));try{a=JSON.parse(f),d&&(a={...d,...a})}catch(m){return this.logger.warn(`failed parsing options string in nesting for key ${l}`,m),`${l}${u}${f}`}return a.defaultValue&&a.defaultValue.indexOf(this.prefix)>-1&&delete a.defaultValue,l};for(;r=this.nestingRegexp.exec(t);){let l=[];a={...i},a=a.replace&&!Te(a.replace)?a.replace:a,a.applyPostProcessor=!1,delete a.defaultValue;const d=/{.*}/.test(r[1])?r[1].lastIndexOf("}")+1:r[1].indexOf(this.formatSeparator);if(d!==-1&&(l=r[1].slice(d).split(this.formatSeparator).map(u=>u.trim()).filter(Boolean),r[1]=r[1].slice(0,d)),o=n(c.call(this,r[1].trim(),a),a),o&&r[0]===t&&!Te(o))return o;Te(o)||(o=J1(o)),o||(this.logger.warn(`missed to resolve ${r[1]} for nesting ${t}`),o=""),l.length&&(o=l.reduce((u,p)=>this.format(u,p,i.lng,{...i,interpolationkey:r[1].trim()}),o.trim())),t=t.replace(r[0],o),this.regexp.lastIndex=0}return t}}const v9=e=>{let t=e.toLowerCase().trim();const n={};if(e.indexOf("(")>-1){const i=e.split("(");t=i[0].toLowerCase().trim();const r=i[1].substring(0,i[1].length-1);t==="currency"&&r.indexOf(":")<0?n.currency||(n.currency=r.trim()):t==="relativetime"&&r.indexOf(":")<0?n.range||(n.range=r.trim()):r.split(";").forEach(a=>{if(a){const[c,...l]=a.split(":"),d=l.join(":").trim().replace(/^'+|'+$/g,""),u=c.trim();n[u]||(n[u]=d),d==="false"&&(n[u]=!1),d==="true"&&(n[u]=!0),isNaN(d)||(n[u]=parseInt(d,10))}})}return{formatName:t,formatOptions:n}},s2=e=>{const t={};return(n,i,r)=>{let o=r;r&&r.interpolationkey&&r.formatParams&&r.formatParams[r.interpolationkey]&&r[r.interpolationkey]&&(o={...o,[r.interpolationkey]:void 0});const a=i+JSON.stringify(o);let c=t[a];return c||(c=e(Ul(i),r),t[a]=c),c(n)}},A9=e=>(t,n,i)=>e(Ul(n),i)(t);class k9{constructor(t={}){this.logger=Pi.create("formatter"),this.options=t,this.init(t)}init(t,n={interpolation:{}}){this.formatSeparator=n.interpolation.formatSeparator||",";const i=n.cacheInBuiltFormats?s2:A9;this.formats={number:i((r,o)=>{const a=new Intl.NumberFormat(r,{...o});return c=>a.format(c)}),currency:i((r,o)=>{const a=new Intl.NumberFormat(r,{...o,style:"currency"});return c=>a.format(c)}),datetime:i((r,o)=>{const a=new Intl.DateTimeFormat(r,{...o});return c=>a.format(c)}),relativetime:i((r,o)=>{const a=new Intl.RelativeTimeFormat(r,{...o});return c=>a.format(c,o.range||"day")}),list:i((r,o)=>{const a=new Intl.ListFormat(r,{...o});return c=>a.format(c)})}}add(t,n){this.formats[t.toLowerCase().trim()]=n}addCached(t,n){this.formats[t.toLowerCase().trim()]=s2(n)}format(t,n,i,r={}){const o=n.split(this.formatSeparator);if(o.length>1&&o[0].indexOf("(")>1&&o[0].indexOf(")")<0&&o.find(c=>c.indexOf(")")>-1)){const c=o.findIndex(l=>l.indexOf(")")>-1);o[0]=[o[0],...o.splice(1,c)].join(this.formatSeparator)}return o.reduce((c,l)=>{const{formatName:d,formatOptions:u}=v9(l);if(this.formats[d]){let p=c;try{const f=r?.formatParams?.[r.interpolationkey]||{},h=f.locale||f.lng||r.locale||r.lng||i;p=this.formats[d](c,h,{...u,...r,...f})}catch(f){this.logger.warn(f)}return p}else this.logger.warn(`there was no format function for ${d}`);return c},t)}}const S9=(e,t)=>{e.pending[t]!==void 0&&(delete e.pending[t],e.pendingCount--)};class E9 extends mh{constructor(t,n,i,r={}){super(),this.backend=t,this.store=n,this.services=i,this.languageUtils=i.languageUtils,this.options=r,this.logger=Pi.create("backendConnector"),this.waitingReads=[],this.maxParallelReads=r.maxParallelReads||10,this.readingCalls=0,this.maxRetries=r.maxRetries>=0?r.maxRetries:5,this.retryTimeout=r.retryTimeout>=1?r.retryTimeout:350,this.state={},this.queue=[],this.backend?.init?.(i,r.backend,r)}queueLoad(t,n,i,r){const o={},a={},c={},l={};return t.forEach(d=>{let u=!0;n.forEach(p=>{const f=`${d}|${p}`;!i.reload&&this.store.hasResourceBundle(d,p)?this.state[f]=2:this.state[f]<0||(this.state[f]===1?a[f]===void 0&&(a[f]=!0):(this.state[f]=1,u=!1,a[f]===void 0&&(a[f]=!0),o[f]===void 0&&(o[f]=!0),l[p]===void 0&&(l[p]=!0)))}),u||(c[d]=!0)}),(Object.keys(o).length||Object.keys(a).length)&&this.queue.push({pending:a,pendingCount:Object.keys(a).length,loaded:{},errors:[],callback:r}),{toLoad:Object.keys(o),pending:Object.keys(a),toLoadLanguages:Object.keys(c),toLoadNamespaces:Object.keys(l)}}loaded(t,n,i){const r=t.split("|"),o=r[0],a=r[1];n&&this.emit("failedLoading",o,a,n),!n&&i&&this.store.addResourceBundle(o,a,i,void 0,void 0,{skipCopy:!0}),this.state[t]=n?-1:2,n&&i&&(this.state[t]=0);const c={};this.queue.forEach(l=>{d9(l.loaded,[o],a),S9(l,t),n&&l.errors.push(n),l.pendingCount===0&&!l.done&&(Object.keys(l.loaded).forEach(d=>{c[d]||(c[d]={});const u=l.loaded[d];u.length&&u.forEach(p=>{c[d][p]===void 0&&(c[d][p]=!0)})}),l.done=!0,l.errors.length?l.callback(l.errors):l.callback())}),this.emit("loaded",c),this.queue=this.queue.filter(l=>!l.done)}read(t,n,i,r=0,o=this.retryTimeout,a){if(!t.length)return a(null,{});if(this.readingCalls>=this.maxParallelReads){this.waitingReads.push({lng:t,ns:n,fcName:i,tried:r,wait:o,callback:a});return}this.readingCalls++;const c=(d,u)=>{if(this.readingCalls--,this.waitingReads.length>0){const p=this.waitingReads.shift();this.read(p.lng,p.ns,p.fcName,p.tried,p.wait,p.callback)}if(d&&u&&r<this.maxRetries){setTimeout(()=>{this.read.call(this,t,n,i,r+1,o*2,a)},o);return}a(d,u)},l=this.backend[i].bind(this.backend);if(l.length===2){try{const d=l(t,n);d&&typeof d.then=="function"?d.then(u=>c(null,u)).catch(c):c(null,d)}catch(d){c(d)}return}return l(t,n,c)}prepareLoading(t,n,i={},r){if(!this.backend)return this.logger.warn("No backend was added via i18next.use. Will not load resources."),r&&r();Te(t)&&(t=this.languageUtils.toResolveHierarchy(t)),Te(n)&&(n=[n]);const o=this.queueLoad(t,n,i,r);if(!o.toLoad.length)return o.pending.length||r(),null;o.toLoad.forEach(a=>{this.loadOne(a)})}load(t,n,i){this.prepareLoading(t,n,{},i)}reload(t,n,i){this.prepareLoading(t,n,{reload:!0},i)}loadOne(t,n=""){const i=t.split("|"),r=i[0],o=i[1];this.read(r,o,"read",void 0,void 0,(a,c)=>{a&&this.logger.warn(`${n}loading namespace ${o} for language ${r} failed`,a),!a&&c&&this.logger.log(`${n}loaded namespace ${o} for language ${r}`,c),this.loaded(t,a,c)})}saveMissing(t,n,i,r,o,a={},c=()=>{}){if(this.services?.utils?.hasLoadedNamespace&&!this.services?.utils?.hasLoadedNamespace(n)){this.logger.warn(`did not save key "${i}" as the namespace "${n}" was not yet loaded`,"This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!");return}if(!(i==null||i==="")){if(this.backend?.create){const l={...a,isUpdate:o},d=this.backend.create.bind(this.backend);if(d.length<6)try{let u;d.length===5?u=d(t,n,i,r,l):u=d(t,n,i,r),u&&typeof u.then=="function"?u.then(p=>c(null,p)).catch(c):c(null,u)}catch(u){c(u)}else d(t,n,i,r,c,l)}!t||!t[0]||this.store.addResource(t[0],n,i,r)}}}const im=()=>({debug:!1,initAsync:!0,ns:["translation"],defaultNS:["translation"],fallbackLng:["dev"],fallbackNS:!1,supportedLngs:!1,nonExplicitSupportedLngs:!1,load:"all",preload:!1,simplifyPluralSuffix:!0,keySeparator:".",nsSeparator:":",pluralSeparator:"_",contextSeparator:"_",partialBundledLanguages:!1,saveMissing:!1,updateMissing:!1,saveMissingTo:"fallback",saveMissingPlurals:!0,missingKeyHandler:!1,missingInterpolationHandler:!1,postProcess:!1,postProcessPassResolved:!1,returnNull:!1,returnEmptyString:!0,returnObjects:!1,joinArrays:!1,returnedObjectHandler:!1,parseMissingKeyHandler:!1,appendNamespaceToMissingKey:!1,appendNamespaceToCIMode:!1,overloadTranslationOptionHandler:e=>{let t={};if(typeof e[1]=="object"&&(t=e[1]),Te(e[1])&&(t.defaultValue=e[1]),Te(e[2])&&(t.tDescription=e[2]),typeof e[2]=="object"||typeof e[3]=="object"){const n=e[3]||e[2];Object.keys(n).forEach(i=>{t[i]=n[i]})}return t},interpolation:{escapeValue:!0,format:e=>e,prefix:"{{",suffix:"}}",formatSeparator:",",unescapePrefix:"-",nestingPrefix:"$t(",nestingSuffix:")",nestingOptionsSeparator:",",maxReplaces:1e3,skipOnVariables:!0},cacheInBuiltFormats:!0}),a2=e=>(Te(e.ns)&&(e.ns=[e.ns]),Te(e.fallbackLng)&&(e.fallbackLng=[e.fallbackLng]),Te(e.fallbackNS)&&(e.fallbackNS=[e.fallbackNS]),e.supportedLngs?.indexOf?.("cimode")<0&&(e.supportedLngs=e.supportedLngs.concat(["cimode"])),typeof e.initImmediate=="boolean"&&(e.initAsync=e.initImmediate),e),Eu=()=>{},x9=e=>{Object.getOwnPropertyNames(Object.getPrototypeOf(e)).forEach(n=>{typeof e[n]=="function"&&(e[n]=e[n].bind(e))})},_x="__i18next_supportNoticeShown",C9=()=>!!(typeof globalThis<"u"&&globalThis[_x]||typeof process<"u"&&process.env&&process.env.I18NEXT_NO_SUPPORT_NOTICE||typeof process<"u"&&process.env&&process.env.NODE_ENV==="production"),T9=()=>{typeof globalThis<"u"&&(globalThis[_x]=!0)},$9=e=>!!(e?.modules?.backend?.name?.indexOf("Locize")>0||e?.modules?.backend?.constructor?.name?.indexOf("Locize")>0||e?.options?.backend?.backends&&e.options.backend.backends.some(t=>t?.name?.indexOf("Locize")>0||t?.constructor?.name?.indexOf("Locize")>0)||e?.options?.backend?.projectId||e?.options?.backend?.backendOptions&&e.options.backend.backendOptions.some(t=>t?.projectId));class zl extends mh{constructor(t={},n){if(super(),this.options=a2(t),this.services={},this.logger=Pi,this.modules={external:[]},x9(this),n&&!this.isInitialized&&!t.isClone){if(!this.options.initAsync)return this.init(t,n),this;setTimeout(()=>{this.init(t,n)},0)}}init(t={},n){this.isInitializing=!0,typeof t=="function"&&(n=t,t={}),t.defaultNS==null&&t.ns&&(Te(t.ns)?t.defaultNS=t.ns:t.ns.indexOf("translation")<0&&(t.defaultNS=t.ns[0]));const i=im();this.options={...i,...this.options,...a2(t)},this.options.interpolation={...i.interpolation,...this.options.interpolation},t.keySeparator!==void 0&&(this.options.userDefinedKeySeparator=t.keySeparator),t.nsSeparator!==void 0&&(this.options.userDefinedNsSeparator=t.nsSeparator),typeof this.options.overloadTranslationOptionHandler!="function"&&(this.options.overloadTranslationOptionHandler=i.overloadTranslationOptionHandler),this.options.showSupportNotice!==!1&&!$9(this)&&!C9()&&(typeof console<"u"&&typeof console.info<"u"&&console.info("🌐 i18next is made possible by our own product, Locize — consider powering your project with managed localization (AI, CDN, integrations): https://locize.com 💙"),T9());const r=d=>d?typeof d=="function"?new d:d:null;if(!this.options.isClone){this.modules.logger?Pi.init(r(this.modules.logger),this.options):Pi.init(null,this.options);let d;this.modules.formatter?d=this.modules.formatter:d=k9;const u=new t2(this.options);this.store=new X1(this.options.resources,this.options);const p=this.services;p.logger=Pi,p.resourceStore=this.store,p.languageUtils=u,p.pluralResolver=new b9(u,{prepend:this.options.pluralSeparator,simplifyPluralSuffix:this.options.simplifyPluralSuffix}),this.options.interpolation.format&&this.options.interpolation.format!==i.interpolation.format&&this.logger.deprecate("init: you are still using the legacy format function, please use the new approach: https://www.i18next.com/translation-function/formatting"),d&&(!this.options.interpolation.format||this.options.interpolation.format===i.interpolation.format)&&(p.formatter=r(d),p.formatter.init&&p.formatter.init(p,this.options),this.options.interpolation.format=p.formatter.format.bind(p.formatter)),p.interpolator=new o2(this.options),p.utils={hasLoadedNamespace:this.hasLoadedNamespace.bind(this)},p.backendConnector=new E9(r(this.modules.backend),p.resourceStore,p,this.options),p.backendConnector.on("*",(h,...g)=>{this.emit(h,...g)}),this.modules.languageDetector&&(p.languageDetector=r(this.modules.languageDetector),p.languageDetector.init&&p.languageDetector.init(p,this.options.detection,this.options)),this.modules.i18nFormat&&(p.i18nFormat=r(this.modules.i18nFormat),p.i18nFormat.init&&p.i18nFormat.init(this)),this.translator=new xp(this.services,this.options),this.translator.on("*",(h,...g)=>{this.emit(h,...g)}),this.modules.external.forEach(h=>{h.init&&h.init(this)})}if(this.format=this.options.interpolation.format,n||(n=Eu),this.options.fallbackLng&&!this.services.languageDetector&&!this.options.lng){const d=this.services.languageUtils.getFallbackCodes(this.options.fallbackLng);d.length>0&&d[0]!=="dev"&&(this.options.lng=d[0])}!this.services.languageDetector&&!this.options.lng&&this.logger.warn("init: no languageDetector is used and no lng is defined"),["getResource","hasResourceBundle","getResourceBundle","getDataByLanguage"].forEach(d=>{this[d]=(...u)=>this.store[d](...u)}),["addResource","addResources","addResourceBundle","removeResourceBundle"].forEach(d=>{this[d]=(...u)=>(this.store[d](...u),this)});const c=Oc(),l=()=>{const d=(u,p)=>{this.isInitializing=!1,this.isInitialized&&!this.initializedStoreOnce&&this.logger.warn("init: i18next is already initialized. You should call init just once!"),this.isInitialized=!0,this.options.isClone||this.logger.log("initialized",this.options),this.emit("initialized",this.options),c.resolve(p),n(u,p)};if(this.languages&&!this.isInitialized)return d(null,this.t.bind(this));this.changeLanguage(this.options.lng,d)};return this.options.resources||!this.options.initAsync?l():setTimeout(l,0),c}loadResources(t,n=Eu){let i=n;const r=Te(t)?t:this.language;if(typeof t=="function"&&(i=t),!this.options.resources||this.options.partialBundledLanguages){if(r?.toLowerCase()==="cimode"&&(!this.options.preload||this.options.preload.length===0))return i();const o=[],a=c=>{if(!c||c==="cimode")return;this.services.languageUtils.toResolveHierarchy(c).forEach(d=>{d!=="cimode"&&o.indexOf(d)<0&&o.push(d)})};r?a(r):this.services.languageUtils.getFallbackCodes(this.options.fallbackLng).forEach(l=>a(l)),this.options.preload?.forEach?.(c=>a(c)),this.services.backendConnector.load(o,this.options.ns,c=>{!c&&!this.resolvedLanguage&&this.language&&this.setResolvedLanguage(this.language),i(c)})}else i(null)}reloadResources(t,n,i){const r=Oc();return typeof t=="function"&&(i=t,t=void 0),typeof n=="function"&&(i=n,n=void 0),t||(t=this.languages),n||(n=this.options.ns),i||(i=Eu),this.services.backendConnector.reload(t,n,o=>{r.resolve(),i(o)}),r}use(t){if(!t)throw new Error("You are passing an undefined module! Please check the object you are passing to i18next.use()");if(!t.type)throw new Error("You are passing a wrong module! Please check the object you are passing to i18next.use()");return t.type==="backend"&&(this.modules.backend=t),(t.type==="logger"||t.log&&t.warn&&t.error)&&(this.modules.logger=t),t.type==="languageDetector"&&(this.modules.languageDetector=t),t.type==="i18nFormat"&&(this.modules.i18nFormat=t),t.type==="postProcessor"&&mx.addPostProcessor(t),t.type==="formatter"&&(this.modules.formatter=t),t.type==="3rdParty"&&this.modules.external.push(t),this}setResolvedLanguage(t){if(!(!t||!this.languages)&&!(["cimode","dev"].indexOf(t)>-1)){for(let n=0;n<this.languages.length;n++){const i=this.languages[n];if(!(["cimode","dev"].indexOf(i)>-1)&&this.store.hasLanguageSomeTranslations(i)){this.resolvedLanguage=i;break}}!this.resolvedLanguage&&this.languages.indexOf(t)<0&&this.store.hasLanguageSomeTranslations(t)&&(this.resolvedLanguage=t,this.languages.unshift(t))}}changeLanguage(t,n){this.isLanguageChangingTo=t;const i=Oc();this.emit("languageChanging",t);const r=c=>{this.language=c,this.languages=this.services.languageUtils.toResolveHierarchy(c),this.resolvedLanguage=void 0,this.setResolvedLanguage(c)},o=(c,l)=>{l?this.isLanguageChangingTo===t&&(r(l),this.translator.changeLanguage(l),this.isLanguageChangingTo=void 0,this.emit("languageChanged",l),this.logger.log("languageChanged",l)):this.isLanguageChangingTo=void 0,i.resolve((...d)=>this.t(...d)),n&&n(c,(...d)=>this.t(...d))},a=c=>{!t&&!c&&this.services.languageDetector&&(c=[]);const l=Te(c)?c:c&&c[0],d=this.store.hasLanguageSomeTranslations(l)?l:this.services.languageUtils.getBestMatchFromCodes(Te(c)?[c]:c);d&&(this.language||r(d),this.translator.language||this.translator.changeLanguage(d),this.services.languageDetector?.cacheUserLanguage?.(d)),this.loadResources(d,u=>{o(u,d)})};return!t&&this.services.languageDetector&&!this.services.languageDetector.async?a(this.services.languageDetector.detect()):!t&&this.services.languageDetector&&this.services.languageDetector.async?this.services.languageDetector.detect.length===0?this.services.languageDetector.detect().then(a):this.services.languageDetector.detect(a):a(t),i}getFixedT(t,n,i){const r=(o,a,...c)=>{let l;typeof a!="object"?l=this.options.overloadTranslationOptionHandler([o,a].concat(c)):l={...a},l.lng=l.lng||r.lng,l.lngs=l.lngs||r.lngs,l.ns=l.ns||r.ns,l.keyPrefix!==""&&(l.keyPrefix=l.keyPrefix||i||r.keyPrefix);const d={...this.options,...l};typeof l.keyPrefix=="function"&&(l.keyPrefix=_a(l.keyPrefix,d));const u=this.options.keySeparator||".";let p;return l.keyPrefix&&Array.isArray(o)?p=o.map(f=>(typeof f=="function"&&(f=_a(f,d)),`${l.keyPrefix}${u}${f}`)):(typeof o=="function"&&(o=_a(o,d)),p=l.keyPrefix?`${l.keyPrefix}${u}${o}`:o),this.t(p,l)};return Te(t)?r.lng=t:r.lngs=t,r.ns=n,r.keyPrefix=i,r}t(...t){return this.translator?.translate(...t)}exists(...t){return this.translator?.exists(...t)}setDefaultNamespace(t){this.options.defaultNS=t}hasLoadedNamespace(t,n={}){if(!this.isInitialized)return this.logger.warn("hasLoadedNamespace: i18next was not initialized",this.languages),!1;if(!this.languages||!this.languages.length)return this.logger.warn("hasLoadedNamespace: i18n.languages were undefined or empty",this.languages),!1;const i=n.lng||this.resolvedLanguage||this.languages[0],r=this.options?this.options.fallbackLng:!1,o=this.languages[this.languages.length-1];if(i.toLowerCase()==="cimode")return!0;const a=(c,l)=>{const d=this.services.backendConnector.state[`${c}|${l}`];return d===-1||d===0||d===2};if(n.precheck){const c=n.precheck(this,a);if(c!==void 0)return c}return!!(this.hasResourceBundle(i,t)||!this.services.backendConnector.backend||this.options.resources&&!this.options.partialBundledLanguages||a(i,t)&&(!r||a(o,t)))}loadNamespaces(t,n){const i=Oc();return this.options.ns?(Te(t)&&(t=[t]),t.forEach(r=>{this.options.ns.indexOf(r)<0&&this.options.ns.push(r)}),this.loadResources(r=>{i.resolve(),n&&n(r)}),i):(n&&n(),Promise.resolve())}loadLanguages(t,n){const i=Oc();Te(t)&&(t=[t]);const r=this.options.preload||[],o=t.filter(a=>r.indexOf(a)<0&&this.services.languageUtils.isSupportedCode(a));return o.length?(this.options.preload=r.concat(o),this.loadResources(a=>{i.resolve(),n&&n(a)}),i):(n&&n(),Promise.resolve())}dir(t){if(t||(t=this.resolvedLanguage||(this.languages?.length>0?this.languages[0]:this.language)),!t)return"rtl";try{const r=new Intl.Locale(t);if(r&&r.getTextInfo){const o=r.getTextInfo();if(o&&o.direction)return o.direction}}catch{}const n=["ar","shu","sqr","ssh","xaa","yhd","yud","aao","abh","abv","acm","acq","acw","acx","acy","adf","ads","aeb","aec","afb","ajp","apc","apd","arb","arq","ars","ary","arz","auz","avl","ayh","ayl","ayn","ayp","bbz","pga","he","iw","ps","pbt","pbu","pst","prp","prd","ug","ur","ydd","yds","yih","ji","yi","hbo","men","xmn","fa","jpr","peo","pes","prs","dv","sam","ckb"],i=this.services?.languageUtils||new t2(im());return t.toLowerCase().indexOf("-latn")>1?"ltr":n.indexOf(i.getLanguagePartFromCode(t))>-1||t.toLowerCase().indexOf("-arab")>1?"rtl":"ltr"}static createInstance(t={},n){const i=new zl(t,n);return i.createInstance=zl.createInstance,i}cloneInstance(t={},n=Eu){const i=t.forkResourceStore;i&&delete t.forkResourceStore;const r={...this.options,...t,isClone:!0},o=new zl(r);if((t.debug!==void 0||t.prefix!==void 0)&&(o.logger=o.logger.clone(t)),["store","services","language"].forEach(c=>{o[c]=this[c]}),o.services={...this.services},o.services.utils={hasLoadedNamespace:o.hasLoadedNamespace.bind(o)},i){const c=Object.keys(this.store.data).reduce((l,d)=>(l[d]={...this.store.data[d]},l[d]=Object.keys(l[d]).reduce((u,p)=>(u[p]={...l[d][p]},u),l[d]),l),{});o.store=new X1(c,r),o.services.resourceStore=o.store}if(t.interpolation){const l={...im().interpolation,...this.options.interpolation,...t.interpolation},d={...r,interpolation:l};o.services.interpolator=new o2(d)}return o.translator=new xp(o.services,r),o.translator.on("*",(c,...l)=>{o.emit(c,...l)}),o.init(r,n),o.translator.options=r,o.translator.backendConnector.services.utils={hasLoadedNamespace:o.hasLoadedNamespace.bind(o)},o}toJSON(){return{options:this.options,store:this.store,language:this.language,languages:this.languages,resolvedLanguage:this.resolvedLanguage}}}const U=zl.createInstance();U.createInstance;U.dir;U.init;U.loadResources;U.reloadResources;U.use;U.changeLanguage;U.getFixedT;const oe=U.t;U.exists;U.setDefaultNamespace;U.hasLoadedNamespace;U.loadNamespaces;U.loadLanguages;const Un=s.z.object({created_at:s.z.string(),updated_at:s.z.string()}),qw=s.z.object({id:s.z.string(),version:s.z.string().optional()}),Hw=s.z.object({name:s.z.string(),version:s.z.string()}),Vw=s.z.object({name:s.z.string(),value:s.z.string().optional()}),ql=s.z.object({name:s.z.string().max(255),code:s.z.string().max(1e5),supported_triggers:s.z.array(qw).optional(),runtime:s.z.string().max(50).optional(),dependencies:s.z.array(Hw).optional(),secrets:s.z.array(Vw).optional(),is_system:s.z.boolean().optional(),inherit:s.z.boolean().optional()}),I9=ql.partial().extend({status:s.z.enum(["draft","built"]).optional(),deployed_at:s.z.string().optional()}),nr=ql.extend({id:s.z.string(),tenant_id:s.z.string(),status:s.z.enum(["draft","built"]).default("built"),deployed_at:s.z.string().optional(),secrets:s.z.array(s.z.object({name:s.z.string(),value:s.z.string().optional()})).optional(),...Un.shape}),wx=s.z.string(),Kw=s.z.enum(["unspecified","pending","final","partial","canceled","suspended"]),bx=s.z.object({id:s.z.string(),msg:s.z.string(),url:s.z.string().optional()}),Gw=s.z.object({action_name:s.z.string(),error:bx.nullable(),started_at:s.z.string(),ended_at:s.z.string()}),vx=s.z.object({level:s.z.enum(["log","info","warn","error","debug"]),message:s.z.string()}),Ww=s.z.array(s.z.object({action_name:s.z.string(),lines:s.z.array(vx)})),Ax=s.z.object({id:s.z.string(),tenant_id:s.z.string(),trigger_id:wx,status:Kw,results:s.z.array(Gw),logs:Ww.optional(),created_at:s.z.string(),updated_at:s.z.string()}),z9=Ax.omit({tenant_id:!0,created_at:!0,updated_at:!0}),kx=s.z.object({action_id:s.z.string(),code:s.z.string().max(1e5),runtime:s.z.string().max(50).optional(),dependencies:s.z.array(Hw).optional(),secrets:s.z.array(Vw).optional(),supported_triggers:s.z.array(qw).optional(),deployed:s.z.boolean().default(!0)}),yh=kx.extend({id:s.z.string(),tenant_id:s.z.string(),number:s.z.number().int(),...Un.shape}),Sx=s.z.enum(["user_action","admin_action","system","api"]),Ex=s.z.object({type:s.z.enum(["user","admin","system","api_key","client_credentials"]),id:s.z.string().optional(),email:s.z.string().optional(),org_id:s.z.string().optional(),org_name:s.z.string().optional(),scopes:s.z.array(s.z.string()).optional(),client_id:s.z.string().optional()}),xx=s.z.object({type:s.z.string(),id:s.z.string(),before:s.z.record(s.z.unknown()).optional(),after:s.z.record(s.z.unknown()).optional(),diff:s.z.record(s.z.object({old:s.z.unknown(),new:s.z.unknown()})).optional()}),Cx=s.z.object({method:s.z.string(),path:s.z.string(),query:s.z.record(s.z.string()).optional(),body:s.z.unknown().optional(),ip:s.z.string(),user_agent:s.z.string().optional(),correlation_id:s.z.string().optional()}),Tx=s.z.object({status_code:s.z.number(),body:s.z.unknown().optional()}),$x=s.z.object({country_code:s.z.string(),city_name:s.z.string(),latitude:s.z.string(),longitude:s.z.string(),time_zone:s.z.string(),continent_code:s.z.string()}),Ix=s.z.object({name:s.z.string(),version:s.z.string(),env:s.z.record(s.z.string()).optional()}),zx=s.z.object({tenant_id:s.z.string(),event_type:s.z.string(),log_type:s.z.string(),description:s.z.string().optional(),category:Sx,actor:Ex,target:xx,request:Cx,response:Tx.optional(),connection:s.z.string().optional(),strategy:s.z.string().optional(),strategy_type:s.z.string().optional(),audience:s.z.string().optional(),scope:s.z.string().optional(),location:$x.optional(),auth0_client:Ix.optional(),hostname:s.z.string(),is_mobile:s.z.boolean().optional(),timestamp:s.z.string()}),Px=zx.extend({id:s.z.string()}),P9=s.z.enum(["AUTH0","EMAIL","REDIRECT"]),N9=s.z.enum(["CREATE_USER","GET_USER","UPDATE_USER","SEND_REQUEST","SEND_EMAIL"]),j9=s.z.enum(["VERIFY_EMAIL"]),Nx=s.z.object({require_mx_record:s.z.boolean().optional(),block_aliases:s.z.boolean().optional(),block_free_emails:s.z.boolean().optional(),block_disposable_emails:s.z.boolean().optional(),blocklist:s.z.array(s.z.string()).optional(),allowlist:s.z.array(s.z.string()).optional()}),jx=s.z.object({id:s.z.string(),alias:s.z.string().max(100).optional(),type:s.z.literal("AUTH0"),action:s.z.literal("UPDATE_USER"),allow_failure:s.z.boolean().optional(),mask_output:s.z.boolean().optional(),params:s.z.object({connection_id:s.z.string().optional(),user_id:s.z.string(),changes:s.z.record(s.z.string(),s.z.any())})}),Ox=s.z.object({id:s.z.string(),alias:s.z.string().max(100).optional(),type:s.z.literal("EMAIL"),action:s.z.literal("VERIFY_EMAIL"),allow_failure:s.z.boolean().optional(),mask_output:s.z.boolean().optional(),params:s.z.object({email:s.z.string(),rules:Nx.optional()})}),Fx=s.z.enum(["change-email","account","custom"]),Rx=s.z.object({id:s.z.string(),alias:s.z.string().max(100).optional(),type:s.z.literal("REDIRECT"),action:s.z.literal("REDIRECT_USER"),allow_failure:s.z.boolean().optional(),mask_output:s.z.boolean().optional(),params:s.z.object({target:Fx.openapi({description:"The predefined target to redirect to, or 'custom' for a custom URL"}),custom_url:s.z.string().optional().openapi({description:"Custom URL to redirect to when target is 'custom'"})})}),Dx=s.z.union([jx,Ox,Rx]),Cp=s.z.object({name:s.z.string().min(1).max(150).openapi({description:"The name of the flow"}),actions:s.z.array(Dx).optional().default([]).openapi({description:"The list of actions to execute in sequence"})}),oa=Cp.extend({...Un.shape,id:s.z.string().openapi({description:"Unique identifier for the flow",example:"af_12tMpdJ3iek7svMyZkSh5M"})}),O9=s.z.object({page:s.z.string().min(0).optional().default("0").transform(e=>parseInt(e,10)).openapi({description:"The page number where 0 is the first page"}),per_page:s.z.string().min(1).optional().default("10").transform(e=>parseInt(e,10)).openapi({description:"The number of items per page"}),include_totals:s.z.string().optional().default("false").transform(e=>e==="true").openapi({description:"If the total number of items should be included in the response"}),sort:s.z.string().regex(/^.+:(-1|1)$/).optional().openapi({description:"A property that should have the format 'string:-1' or 'string:1'"}),q:s.z.string().optional().openapi({description:"A lucene query string used to filter the results"})}),xt=s.z.object({start:s.z.number(),limit:s.z.number(),length:s.z.number(),total:s.z.number().optional()}),Bx=s.z.object({email:s.z.string().optional(),email_verified:s.z.boolean().optional(),name:s.z.string().optional(),username:s.z.string().optional(),given_name:s.z.string().optional(),phone_number:s.z.string().optional(),phone_verified:s.z.boolean().optional(),family_name:s.z.string().optional()}).catchall(s.z.any()),Tp=s.z.object({connection:s.z.string(),user_id:s.z.string(),provider:s.z.string(),isSocial:s.z.boolean(),email:s.z.string().optional(),email_verified:s.z.boolean().optional(),phone_number:s.z.string().optional(),phone_verified:s.z.boolean().optional(),username:s.z.string().optional(),access_token:s.z.string().optional(),access_token_secret:s.z.string().optional(),refresh_token:s.z.string().optional(),profileData:Bx.optional()}),Lx=s.z.object({formatted:s.z.string().optional(),street_address:s.z.string().optional(),locality:s.z.string().optional(),region:s.z.string().optional(),postal_code:s.z.string().optional(),country:s.z.string().optional()}).optional(),_h=s.z.object({email:s.z.string().optional().transform(e=>e&&e.toLowerCase()),username:s.z.string().refine(e=>!e.includes("@"),{message:'Usernames must not contain "@". Use the email field for email addresses.'}).optional(),phone_number:s.z.string().optional(),phone_verified:s.z.boolean().optional(),given_name:s.z.string().optional(),family_name:s.z.string().optional(),nickname:s.z.string().optional(),name:s.z.string().optional(),picture:s.z.string().optional(),locale:s.z.string().optional(),linked_to:s.z.string().optional(),profileData:s.z.string().optional(),user_id:s.z.string().optional(),app_metadata:s.z.any().default({}).optional(),user_metadata:s.z.any().default({}).optional(),middle_name:s.z.string().optional(),preferred_username:s.z.string().optional(),profile:s.z.string().optional(),website:s.z.string().optional(),gender:s.z.string().optional(),birthdate:s.z.string().optional(),zoneinfo:s.z.string().optional(),address:Lx}),$p=_h.extend({email_verified:s.z.boolean().default(!1),verify_email:s.z.boolean().optional(),last_ip:s.z.string().optional(),last_login:s.z.string().optional(),user_id:s.z.string().optional(),provider:s.z.string().optional(),connection:s.z.string(),is_social:s.z.boolean().optional(),registration_completed_at:s.z.string().optional(),password:s.z.object({hash:s.z.string(),algorithm:s.z.string()}).optional()}),Jw=s.z.object({...$p.omit({password:!0}).shape,...Un.shape,user_id:s.z.string(),provider:s.z.string(),is_social:s.z.boolean(),email:s.z.string().optional(),login_count:s.z.number().default(0),identities:s.z.array(Tp).optional()}),Nn=Jw.omit({registration_completed_at:!0}),F9=_h.extend({login_count:s.z.number(),multifactor:s.z.array(s.z.string()).optional(),last_ip:s.z.string().optional(),last_login:s.z.string().optional(),user_id:s.z.string()}).catchall(s.z.any());let R9="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict",D9=(e=21)=>{let t="",n=crypto.getRandomValues(new Uint8Array(e|=0));for(;e--;)t+=R9[n[e]&63];return t};const Ip=s.z.object({client_id:s.z.string().optional().openapi({description:"ID of this client. Generated server-side if omitted (Auth0 behavior)."}),name:s.z.string().min(1).openapi({description:"Name of this client (min length: 1 character, does not allow < or >)."}),description:s.z.string().max(140).optional().openapi({description:"Free text description of this client (max length: 140 characters)."}),global:s.z.boolean().default(!1).openapi({description:"Whether this is your global 'All Applications' client representing legacy tenant settings (true) or a regular client (false)."}),client_secret:s.z.string().default(()=>D9()).optional().openapi({description:"Client secret (which you must not make public)."}),app_type:s.z.enum(["native","spa","regular_web","non_interactive","resource_server","express_configuration","rms","box","cloudbees","concur","dropbox","mscrm","echosign","egnyte","newrelic","office365","salesforce","sentry","sharepoint","slack","springcm","zendesk","zoom","sso_integration","oag"]).default("regular_web").optional().openapi({description:"The type of application this client represents"}),logo_uri:s.z.string().url().optional().openapi({description:"URL of the logo to display for this client. Recommended size is 150x150 pixels."}),is_first_party:s.z.boolean().default(!1).openapi({description:"Whether this client a first party client (true) or not (false)."}),oidc_conformant:s.z.boolean().default(!0).openapi({description:"Whether this client conforms to strict OIDC specifications (true) or uses legacy features (false)."}),auth0_conformant:s.z.boolean().default(!0).openapi({description:"Whether this client follows Auth0-compatible behavior (true) or strict OIDC behavior (false). When true, profile/email claims are included in the ID token when scopes are requested. When false, these claims are only available from the userinfo endpoint (strict OIDC 5.4 compliance)."}),callbacks:s.z.array(s.z.string()).default([]).optional().openapi({description:"Comma-separated list of URLs whitelisted for Auth0 to use as a callback to the client after authentication."}),allowed_origins:s.z.array(s.z.string()).default([]).optional().openapi({description:"Comma-separated list of URLs allowed to make requests from JavaScript to Auth0 API (typically used with CORS). By default, all your callback URLs will be allowed. This field allows you to enter other origins if necessary. You can also use wildcards at the subdomain level (e.g., https://*.contoso.com). Query strings and hash information are not taken into account when validating these URLs."}),web_origins:s.z.array(s.z.string()).default([]).optional().openapi({description:"Comma-separated list of allowed origins for use with Cross-Origin Authentication, Device Flow, and web message response mode."}),client_aliases:s.z.array(s.z.string()).default([]).optional().openapi({description:"List of audiences/realms for SAML protocol. Used by the wsfed addon."}),allowed_clients:s.z.array(s.z.string()).default([]).optional().openapi({description:"List of allow clients and API ids that are allowed to make delegation requests. Empty means all all your clients are allowed."}),connections:s.z.array(s.z.string()).default([]).optional().openapi({description:"List of connection IDs enabled for this client. The order determines the display order on the login page."}),allowed_logout_urls:s.z.array(s.z.string()).default([]).optional().openapi({description:"Comma-separated list of URLs that are valid to redirect to after logout from Auth0. Wildcards are allowed for subdomains."}),session_transfer:s.z.record(s.z.any()).default({}).optional().openapi({description:"Native to Web SSO Configuration"}),oidc_logout:s.z.record(s.z.any()).default({}).optional().openapi({description:"Configuration for OIDC backchannel logout"}),grant_types:s.z.array(s.z.string()).default([]).optional().openapi({description:"List of grant types supported for this application. Can include authorization_code, implicit, refresh_token, client_credentials, password, http://auth0.com/oauth/grant-type/password-realm, http://auth0.com/oauth/grant-type/mfa-oob, http://auth0.com/oauth/grant-type/mfa-otp, http://auth0.com/oauth/grant-type/mfa-recovery-code, urn:openid:params:grant-type:ciba, and urn:ietf:params:oauth:grant-type:device_code."}),jwt_configuration:s.z.record(s.z.any()).default({}).optional().openapi({description:"Configuration related to JWTs for the client."}),signing_keys:s.z.array(s.z.record(s.z.any())).default([]).optional().openapi({description:"Signing certificates associated with this client."}),encryption_key:s.z.record(s.z.any()).default({}).optional().openapi({description:"Encryption used for WsFed responses with this client."}),sso:s.z.boolean().default(!1).openapi({description:"Applies only to SSO clients and determines whether Auth0 will handle Single Sign On (true) or whether the Identity Provider will (false)."}),sso_disabled:s.z.boolean().default(!1).openapi({description:"Whether Single Sign On is disabled for this client. When true, existing SSO sessions will not be reused and users must authenticate every time."}),cross_origin_authentication:s.z.boolean().default(!1).openapi({description:"Whether this client can be used to make cross-origin authentication requests (true) or it is not allowed to make such requests (false)."}),cross_origin_loc:s.z.string().url().optional().openapi({description:"URL of the location in your site where the cross origin verification takes place for the cross-origin auth flow when performing Auth in your own domain instead of Auth0 hosted login page."}),custom_login_page_on:s.z.boolean().default(!1).openapi({description:"Whether a custom login page is to be used (true) or the default provided login page (false)."}),custom_login_page:s.z.string().optional().openapi({description:"The content (HTML, CSS, JS) of the custom login page."}),custom_login_page_preview:s.z.string().optional().openapi({description:"The content (HTML, CSS, JS) of the custom login page. (Used on Previews)"}),form_template:s.z.string().optional().openapi({description:"HTML form template to be used for WS-Federation."}),addons:s.z.record(s.z.any()).default({}).optional().openapi({description:"Addons enabled for this client and their associated configurations."}),token_endpoint_auth_method:s.z.enum(["none","client_secret_post","client_secret_basic","client_secret_jwt","private_key_jwt"]).default("client_secret_basic").optional().openapi({description:"Defines the requested authentication method for the token endpoint. `none` (public client), `client_secret_post` / `client_secret_basic` (HTTP POST / Basic), `client_secret_jwt` (RFC 7523 HMAC assertion using client_secret), or `private_key_jwt` (RFC 7523 asymmetric assertion verified against the client's `jwks` / `jwks_uri`)."}),client_metadata:s.z.record(s.z.string().max(255)).default({}).optional().openapi({description:'Metadata associated with the client, in the form of an object with string values (max 255 chars). Maximum of 10 metadata properties allowed. Field names (max 255 chars) are alphanumeric and may only include the following special characters: :,-+=_*?"/()<>@ [Tab][Space]'}),hide_sign_up_disabled_error:s.z.boolean().default(!1).optional().openapi({description:"Enumeration-safe variant of the connection-level `disable_signup` flag. When a signup is blocked by the password connection and this is true, the identifier screen does not reveal that an email is unknown — it advances to the OTP/password challenge as if the account existed and fails at credential check. Mitigates email enumeration at the cost of UX: users without an account see a generic credential failure instead of an explicit signup-disabled message."}),mobile:s.z.record(s.z.any()).default({}).optional().openapi({description:"Additional configuration for native mobile apps."}),initiate_login_uri:s.z.string().url().optional().openapi({description:"Initiate login uri, must be https"}),native_social_login:s.z.record(s.z.any()).default({}).optional(),refresh_token:s.z.object({rotation_type:s.z.enum(["rotating","non-rotating"]).optional().openapi({description:"Whether refresh tokens for this client are rotated on every exchange (Auth0 'rotating' behavior) or kept stable (legacy non-rotating). Defaults to 'non-rotating' when unset."}),leeway:s.z.number().int().min(0).max(600).optional().openapi({description:"Seconds after a parent token's first rotation during which presenting it again still mints a fresh sibling child instead of triggering reuse-detection. Defaults to 30s when unset."}),expiration_type:s.z.enum(["expiring","non-expiring"]).optional().openapi({description:"Auth0-compatible: whether refresh tokens expire."}),token_lifetime:s.z.number().int().min(0).optional().openapi({description:"Auth0-compatible: refresh-token absolute lifetime in seconds."}),infinite_token_lifetime:s.z.boolean().optional().openapi({description:"Auth0-compatible: when true, refresh tokens have no absolute expiry."}),idle_token_lifetime:s.z.number().int().min(0).optional().openapi({description:"Auth0-compatible: refresh-token idle (sliding) lifetime in seconds."}),infinite_idle_token_lifetime:s.z.boolean().optional().openapi({description:"Auth0-compatible: when true, refresh tokens have no idle expiry."})}).default({}).optional().openapi({description:"Refresh token configuration"}),default_organization:s.z.record(s.z.any()).default({}).optional().openapi({description:"Defines the default Organization ID and flows"}),organization_usage:s.z.enum(["deny","allow","require"]).default("deny").optional().openapi({description:"Defines how to proceed during an authentication transaction with regards an organization. Can be deny (default), allow or require."}),organization_require_behavior:s.z.enum(["no_prompt","pre_login_prompt","post_login_prompt"]).default("no_prompt").optional().openapi({description:"Defines how to proceed during an authentication transaction when client.organization_usage: 'require'. Can be no_prompt (default), pre_login_prompt or post_login_prompt. post_login_prompt requires oidc_conformant: true."}),client_authentication_methods:s.z.record(s.z.any()).default({}).optional().openapi({description:"Defines client authentication methods."}),require_pushed_authorization_requests:s.z.boolean().default(!1).openapi({description:"Makes the use of Pushed Authorization Requests mandatory for this client"}),require_proof_of_possession:s.z.boolean().default(!1).openapi({description:"Makes the use of Proof-of-Possession mandatory for this client"}),signed_request_object:s.z.record(s.z.any()).default({}).optional().openapi({description:"JWT-secured Authorization Requests (JAR) settings."}),compliance_level:s.z.enum(["none","fapi1_adv_pkj_par","fapi1_adv_mtls_par","fapi2_sp_pkj_mtls","fapi2_sp_mtls_mtls"]).optional().openapi({description:"Defines the compliance level for this client, which may restrict it's capabilities"}),par_request_expiry:s.z.number().optional().openapi({description:"Specifies how long, in seconds, a Pushed Authorization Request URI remains valid"}),token_quota:s.z.record(s.z.any()).default({}).optional(),owner_user_id:s.z.string().optional().openapi({description:"User ID of the consenting user when this client was created via IAT-gated Dynamic Client Registration. NULL for clients created via the Management API or open DCR."}),registration_type:s.z.enum(["manual","open_dcr","iat_dcr"]).optional().openapi({description:"Provenance of this client. `manual` = Management API; `open_dcr` = RFC 7591 without IAT; `iat_dcr` = RFC 7591 with an Initial Access Token."}),registration_metadata:s.z.record(s.z.any()).default({}).optional().openapi({description:"Arbitrary metadata captured at Dynamic Client Registration time that isn't a first-class client field (e.g. integration_type, domain). Also stores `iat_constraints` for clients created via IAT so RFC 7592 PUT can enforce field immutability."}),user_linking_mode:s.z.enum(["builtin","off"]).optional().openapi({description:"Per-client override for the built-in email-based user-linking path. `builtin` runs the legacy in-process linking at user creation/email update. `off` disables the legacy path; linking only happens if the tenant has enabled the `account-linking` template hook. When unset, the service-level `userLinkingMode` default applies."})}),Lo=s.z.object({created_at:s.z.string(),updated_at:s.z.string(),...Ip.shape,client_id:s.z.string()}),zp=s.z.object({client_id:s.z.string().min(1).openapi({description:"ID of the client."}),audience:s.z.string().min(1).openapi({description:"The audience (API identifier) of this client grant."}),scope:s.z.array(s.z.string()).optional().openapi({description:"Scopes allowed for this client grant."}),organization_usage:s.z.enum(["deny","allow","require"]).optional().openapi({description:"Defines whether organizations can be used with client credentials exchanges for this grant."}),allow_any_organization:s.z.boolean().optional().openapi({description:"If enabled, any organization can be used with this grant. If disabled (default), the grant must be explicitly assigned to the desired organizations."}),is_system:s.z.boolean().optional().openapi({description:"If enabled, this grant is a special grant created by Auth0. It cannot be modified or deleted directly."}),subject_type:s.z.enum(["client","user"]).optional().openapi({description:"The type of application access the client grant allows. Use of this field is subject to the applicable Free Trial terms in Okta's Master Subscription Agreement."}),authorization_details_types:s.z.array(s.z.string()).optional().openapi({description:"Types of authorization_details allowed for this client grant. Use of this field is subject to the applicable Free Trial terms in Okta's Master Subscription Agreement."})}),Mo=s.z.object({id:s.z.string().openapi({description:"ID of the client grant."}),...zp.shape,created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),B9=s.z.array(Mo),Mx=s.z.enum(["iat","rat"]),Ux=s.z.object({id:s.z.string(),token_hash:s.z.string(),type:Mx,client_id:s.z.string().optional(),sub:s.z.string().optional(),constraints:s.z.record(s.z.unknown()).optional(),single_use:s.z.boolean().default(!1),expires_at:s.z.string().optional()}),L9=s.z.object({created_at:s.z.string(),used_at:s.z.string().optional(),revoked_at:s.z.string().optional(),...Ux.shape}),bs=s.z.object({x:s.z.number(),y:s.z.number()});var Yw=(e=>(e.RICH_TEXT="RICH_TEXT",e.NEXT_BUTTON="NEXT_BUTTON",e.BACK_BUTTON="BACK_BUTTON",e.SUBMIT_BUTTON="SUBMIT_BUTTON",e.DIVIDER="DIVIDER",e.TEXT="TEXT",e.EMAIL="EMAIL",e.PASSWORD="PASSWORD",e.NUMBER="NUMBER",e.PHONE="PHONE",e.DATE="DATE",e.CHECKBOX="CHECKBOX",e.RADIO="RADIO",e.SELECT="SELECT",e.HIDDEN="HIDDEN",e.LEGAL="LEGAL",e))(Yw||{}),Qw=(e=>(e.BLOCK="BLOCK",e.FIELD="FIELD",e))(Qw||{});const wh=s.z.object({id:s.z.string(),category:s.z.nativeEnum(Qw),type:s.z.nativeEnum(Yw)}),qx=wh.extend({category:s.z.literal("BLOCK"),type:s.z.literal("RICH_TEXT"),config:s.z.object({content:s.z.string()}).passthrough()}),Hx=wh.extend({category:s.z.literal("BLOCK"),type:s.z.union([s.z.literal("NEXT_BUTTON"),s.z.literal("BACK_BUTTON"),s.z.literal("SUBMIT_BUTTON")]),config:s.z.object({text:s.z.string()}).passthrough()}),Vx=wh.extend({category:s.z.literal("FIELD"),type:s.z.literal("LEGAL"),required:s.z.boolean().optional(),sensitive:s.z.boolean().optional(),config:s.z.object({text:s.z.string()}).passthrough()}),Kx=wh.extend({category:s.z.literal("FIELD"),type:s.z.union([s.z.literal("TEXT"),s.z.literal("EMAIL"),s.z.literal("PASSWORD"),s.z.literal("NUMBER"),s.z.literal("PHONE"),s.z.literal("DATE"),s.z.literal("CHECKBOX"),s.z.literal("RADIO"),s.z.literal("SELECT"),s.z.literal("HIDDEN")]),required:s.z.boolean().optional(),sensitive:s.z.boolean().optional(),config:s.z.object({label:s.z.string().optional(),placeholder:s.z.string().optional()}).passthrough()}),Gx=s.z.object({id:s.z.string(),category:s.z.string(),type:s.z.string()}).passthrough(),Wx=s.z.union([qx,Hx,Vx,Kx,Gx]);var Jx=(e=>(e.STEP="STEP",e.FLOW="FLOW",e.CONDITION="CONDITION",e.ACTION="ACTION",e))(Jx||{});const Yx=s.z.object({id:s.z.string(),type:s.z.literal("STEP"),coordinates:bs,alias:s.z.string().optional(),config:s.z.object({components:s.z.array(Wx),next_node:s.z.string()}).passthrough()}),Qx=s.z.object({id:s.z.string(),type:s.z.literal("FLOW"),coordinates:bs,alias:s.z.string().optional(),config:s.z.object({flow_id:s.z.string(),next_node:s.z.string()})}),Zx=s.z.object({id:s.z.string(),type:s.z.literal("ACTION"),coordinates:bs,alias:s.z.string().optional(),config:s.z.object({action_type:s.z.enum(["REDIRECT"]).openapi({description:"The type of action to perform"}),target:s.z.enum(["change-email","account","custom"]).openapi({description:"The predefined target to redirect to"}),custom_url:s.z.string().optional().openapi({description:"Custom URL when target is 'custom'"}),next_node:s.z.string().openapi({description:"The next node to navigate to after action (for non-redirect actions)"})}).passthrough()}),Xx=s.z.object({id:s.z.string(),type:s.z.string(),coordinates:bs}).passthrough(),eC=s.z.union([Yx,Qx,Zx,Xx]),tC=s.z.object({next_node:s.z.string(),coordinates:bs}).passthrough(),nC=s.z.object({resume_flow:s.z.boolean().optional(),coordinates:bs}).passthrough(),iC=s.z.object({id:s.z.string(),name:s.z.string(),languages:s.z.object({primary:s.z.string()}).passthrough(),nodes:s.z.array(eC),start:tC,ending:nC,created_at:s.z.string(),updated_at:s.z.string(),links:s.z.object({sdkSrc:s.z.string().optional(),sdk_src:s.z.string().optional()}).passthrough()}).passthrough(),M9=iC.omit({id:!0,created_at:!0,updated_at:!0});var xn=(e=>(e.TOKEN="token",e.ID_TOKEN="id_token",e.TOKEN_ID_TOKEN="id_token token",e.CODE="code",e.CODE_ID_TOKEN="code id_token",e.CODE_TOKEN="code token",e.CODE_ID_TOKEN_TOKEN="code id_token token",e))(xn||{}),mt=(e=>(e.QUERY="query",e.FRAGMENT="fragment",e.FORM_POST="form_post",e.WEB_MESSAGE="web_message",e.SAML_POST="saml_post",e))(mt||{}),bh=(e=>(e.S256="S256",e.Plain="plain",e))(bh||{});const c2=s.z.union([s.z.null(),s.z.object({essential:s.z.boolean().optional(),value:s.z.unknown().optional(),values:s.z.array(s.z.unknown()).optional()})]).nullable(),Zw=s.z.object({userinfo:s.z.record(s.z.string(),c2).optional(),id_token:s.z.record(s.z.string(),c2).optional()}),Hl=s.z.object({client_id:s.z.string(),act_as:s.z.string().optional(),response_type:s.z.nativeEnum(xn).optional(),response_mode:s.z.nativeEnum(mt).optional(),redirect_uri:s.z.string().optional(),audience:s.z.string().optional(),organization:s.z.string().optional(),state:s.z.string().optional(),nonce:s.z.string().optional(),scope:s.z.string().optional(),prompt:s.z.string().optional(),code_challenge_method:s.z.nativeEnum(bh).optional(),code_challenge:s.z.string().optional(),username:s.z.string().optional(),ui_locales:s.z.string().optional(),max_age:s.z.number().optional(),acr_values:s.z.string().optional(),claims:Zw.optional(),vendor_id:s.z.string().optional()}),rp=s.z.object({colors:s.z.object({primary:s.z.string(),page_background:s.z.union([s.z.string(),s.z.object({type:s.z.string().optional(),start:s.z.string().optional(),end:s.z.string().optional(),angle_deg:s.z.number().optional()})]).optional()}).optional(),logo_url:s.z.string().optional(),favicon_url:s.z.string().optional(),powered_by_logo_url:s.z.string().optional(),font:s.z.object({url:s.z.string()}).optional(),dark_mode:s.z.enum(["dark","light","auto"]).optional()}),rC=s.z.enum(["password_reset","email_verification","otp","mfa_otp","authorization_code","oauth2_state","ticket"]),oC=s.z.object({code_id:s.z.string().openapi({description:"The code that will be used in for instance an email verification flow"}),login_id:s.z.string().openapi({description:"The id of the login session that the code is connected to"}),connection_id:s.z.string().optional().openapi({description:"The connection that the code is connected to"}),code_type:rC,code_verifier:s.z.string().optional().openapi({description:"The code verifier used in PKCE in outbound flows"}),code_challenge:s.z.string().optional().openapi({description:"The code challenge used in PKCE in outbound flows"}),code_challenge_method:s.z.enum(["plain","S256"]).optional().openapi({description:"The code challenge method used in PKCE in outbound flows"}),redirect_uri:s.z.string().optional().openapi({description:"The redirect URI associated with the code"}),otp:s.z.string().optional().openapi({description:"The one-time password value for OTP-based flows"}),nonce:s.z.string().optional().openapi({description:"The nonce value used for security in OIDC flows"}),state:s.z.string().optional().openapi({description:"The state parameter used for CSRF protection in OAuth flows"}),expires_at:s.z.string(),used_at:s.z.string().optional(),user_id:s.z.string().optional()}),U9=s.z.object({...oC.shape,created_at:s.z.string()}),sC=s.z.object({kid:s.z.string().optional(),team_id:s.z.string().optional(),realms:s.z.string().optional(),authentication_method:s.z.string().optional(),client_id:s.z.string().optional(),client_secret:s.z.string().optional(),app_secret:s.z.string().optional(),scope:s.z.string().optional(),authorization_endpoint:s.z.string().optional(),token_endpoint:s.z.string().optional(),userinfo_endpoint:s.z.string().optional(),jwks_uri:s.z.string().optional(),discovery_url:s.z.string().optional(),issuer:s.z.string().optional(),token_endpoint_auth_method:s.z.enum(["client_secret_basic","client_secret_post"]).optional(),provider:s.z.string().optional(),from:s.z.string().optional(),twilio_sid:s.z.string().optional(),twilio_token:s.z.string().optional(),icon_url:s.z.string().optional(),domain_aliases:s.z.array(s.z.string()).optional(),callback_url:s.z.string().url().optional(),passwordPolicy:s.z.enum(["none","low","fair","good","excellent"]).optional(),password_complexity_options:s.z.object({min_length:s.z.number().optional()}).optional(),password_history:s.z.object({enable:s.z.boolean().optional(),size:s.z.number().optional()}).optional(),password_no_personal_info:s.z.object({enable:s.z.boolean().optional()}).optional(),password_dictionary:s.z.object({enable:s.z.boolean().optional(),dictionary:s.z.array(s.z.string()).optional()}).optional(),disable_signup:s.z.boolean().optional(),brute_force_protection:s.z.boolean().optional(),import_mode:s.z.boolean().optional(),configuration:s.z.object({token_endpoint:s.z.string().optional(),userinfo_endpoint:s.z.string().optional(),client_id:s.z.string().optional(),client_secret:s.z.string().optional()}).optional(),attributes:s.z.object({email:s.z.object({identifier:s.z.object({active:s.z.boolean().optional()}).optional(),signup:s.z.object({status:s.z.enum(["required","optional","disabled"]).optional(),verification:s.z.object({active:s.z.boolean().optional()}).optional()}).optional(),validation:s.z.object({allowed:s.z.boolean().optional()}).optional(),unique:s.z.boolean().optional(),profile_required:s.z.boolean().optional(),verification_method:s.z.enum(["link","code"]).optional()}).optional(),username:s.z.object({identifier:s.z.object({active:s.z.boolean().optional()}).optional(),signup:s.z.object({status:s.z.enum(["required","optional","disabled"]).optional()}).optional(),validation:s.z.object({max_length:s.z.number().optional(),min_length:s.z.number().optional(),allowed_types:s.z.object({email:s.z.boolean().optional(),phone_number:s.z.boolean().optional()}).optional()}).optional(),profile_required:s.z.boolean().optional()}).optional(),phone_number:s.z.object({identifier:s.z.object({active:s.z.boolean().optional()}).optional(),signup:s.z.object({status:s.z.enum(["required","optional","disabled"]).optional()}).optional()}).optional()}).optional(),authentication_methods:s.z.object({password:s.z.object({enabled:s.z.boolean().optional()}).optional(),passkey:s.z.object({enabled:s.z.boolean().optional()}).optional()}).optional(),passkey_options:s.z.object({challenge_ui:s.z.enum(["both","autofill","button"]).optional(),local_enrollment_enabled:s.z.boolean().optional(),progressive_enrollment_enabled:s.z.boolean().optional()}).optional(),requires_username:s.z.boolean().optional(),validation:s.z.object({username:s.z.object({min:s.z.number().optional(),max:s.z.number().optional()}).optional()}).optional(),set_user_root_attributes:s.z.enum(["on_each_login","on_first_login","never_on_login"]).optional()});function _y(e){if(e!==null){if(Array.isArray(e))return e.filter(t=>t!==null).map(_y);if(e&&typeof e=="object"){const t={};for(const[n,i]of Object.entries(e))i!==null&&(t[n]=_y(i));return t}return e}}const Pp=s.z.object({id:s.z.string().optional(),name:s.z.string(),display_name:s.z.string().optional(),strategy:s.z.string(),options:s.z.preprocess(e=>e===null?{}:_y(e),sC).default({}),enabled_clients:s.z.array(s.z.string()).default([]).optional(),response_type:s.z.custom().optional(),response_mode:s.z.custom().optional(),is_domain_connection:s.z.boolean().optional(),show_as_button:s.z.boolean().optional(),metadata:s.z.record(s.z.any()).optional(),is_system:s.z.boolean().optional()}),Lr=s.z.object({id:s.z.string(),created_at:s.z.string().transform(e=>e===null?"":e),updated_at:s.z.string().transform(e=>e===null?"":e)}).extend(Pp.shape),Xw=s.z.object({domain:s.z.string(),custom_domain_id:s.z.string().optional(),type:s.z.enum(["auth0_managed_certs","self_managed_certs"]),verification_method:s.z.enum(["txt"]).optional(),tls_policy:s.z.enum(["recommended"]).optional(),custom_client_ip_header:s.z.enum(["true-client-ip","cf-connecting-ip","x-forwarded-for","x-azure-clientip","null"]).optional(),domain_metadata:s.z.record(s.z.string().max(255)).optional()}),aC=s.z.discriminatedUnion("name",[s.z.object({name:s.z.literal("txt"),record:s.z.string(),domain:s.z.string()}),s.z.object({name:s.z.literal("http"),http_body:s.z.string(),http_url:s.z.string()})]),Fr=s.z.object({...Xw.shape,custom_domain_id:s.z.string(),primary:s.z.boolean(),status:s.z.enum(["disabled","pending","pending_verification","ready"]),origin_domain_name:s.z.string().optional(),verification:s.z.object({methods:s.z.array(aC)}).optional(),tls_policy:s.z.string().optional()}),q9=Fr.extend({tenant_id:s.z.string()}),eb=s.z.object({id:s.z.string(),order:s.z.number().optional(),visible:s.z.boolean().optional().default(!0)}),ao=eb.extend({category:s.z.literal("BLOCK").optional()}),H9=ao.extend({type:s.z.literal("DIVIDER"),config:s.z.object({text:s.z.string().optional()}).optional()}),V9=ao.extend({type:s.z.literal("HTML"),config:s.z.object({content:s.z.string().optional()}).optional()}),K9=ao.extend({type:s.z.literal("IMAGE"),config:s.z.object({src:s.z.string().optional(),alt:s.z.string().optional(),width:s.z.number().optional(),height:s.z.number().optional()}).optional()}),G9=ao.extend({type:s.z.literal("JUMP_BUTTON"),config:s.z.object({text:s.z.string().optional(),target_step:s.z.string().optional()})}),W9=ao.extend({type:s.z.literal("RESEND_BUTTON"),config:s.z.object({text:s.z.string().optional(),resend_action:s.z.string().optional()})}),J9=ao.extend({type:s.z.literal("NEXT_BUTTON"),config:s.z.object({text:s.z.string().optional()})}),Y9=ao.extend({type:s.z.literal("PREVIOUS_BUTTON"),config:s.z.object({text:s.z.string().optional()})}),Q9=ao.extend({type:s.z.literal("RICH_TEXT"),config:s.z.object({content:s.z.string().optional()}).optional()}),tb=eb.extend({category:s.z.literal("WIDGET").optional(),label:s.z.string().min(1).optional(),hint:s.z.string().min(1).max(500).optional(),required:s.z.boolean().optional(),sensitive:s.z.boolean().optional()}),Z9=tb.extend({type:s.z.literal("AUTH0_VERIFIABLE_CREDENTIALS"),config:s.z.object({credential_type:s.z.string().optional()})}),X9=tb.extend({type:s.z.literal("GMAPS_ADDRESS"),config:s.z.object({api_key:s.z.string().optional()})}),ej=tb.extend({type:s.z.literal("RECAPTCHA"),config:s.z.object({site_key:s.z.string().optional()})}),qt=eb.extend({category:s.z.literal("FIELD").optional(),label:s.z.string().min(1).optional(),hint:s.z.string().min(1).max(500).optional(),messages:s.z.array(s.z.object({id:s.z.number().optional(),text:s.z.string(),type:s.z.enum(["info","error","success","warning"])})).optional(),required:s.z.boolean().optional(),sensitive:s.z.boolean().optional()}),tj=qt.extend({type:s.z.literal("BOOLEAN"),config:s.z.object({default_value:s.z.boolean().optional()}).optional()}),nj=qt.extend({type:s.z.literal("CARDS"),config:s.z.object({options:s.z.array(s.z.object({value:s.z.string(),label:s.z.string(),description:s.z.string().optional(),image:s.z.string().optional()})).optional(),multi_select:s.z.boolean().optional()}).optional()}),ij=qt.extend({type:s.z.literal("CHOICE"),config:s.z.object({options:s.z.array(s.z.object({value:s.z.string(),label:s.z.string()})).optional(),display:s.z.enum(["radio","checkbox"]).optional(),multiple:s.z.boolean().optional(),default_value:s.z.union([s.z.string(),s.z.array(s.z.string())]).optional()}).optional()}),rj=qt.extend({type:s.z.literal("CUSTOM"),config:s.z.object({component:s.z.string().optional(),props:s.z.record(s.z.any()).optional(),schema:s.z.record(s.z.any()).optional(),code:s.z.string().optional()})}),oj=qt.extend({type:s.z.literal("DATE"),config:s.z.object({format:s.z.string().optional(),min:s.z.string().optional(),max:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),sj=qt.extend({type:s.z.literal("DROPDOWN"),config:s.z.object({options:s.z.array(s.z.object({value:s.z.string(),label:s.z.string()})).optional(),placeholder:s.z.string().optional(),searchable:s.z.boolean().optional(),multiple:s.z.boolean().optional(),default_value:s.z.union([s.z.string(),s.z.array(s.z.string())]).optional()}).optional()}),aj=qt.extend({type:s.z.literal("EMAIL"),config:s.z.object({placeholder:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),cj=qt.extend({type:s.z.literal("FILE"),config:s.z.object({accept:s.z.string().optional(),max_size:s.z.number().optional(),multiple:s.z.boolean().optional()}).optional()}),lj=qt.extend({type:s.z.literal("LEGAL"),config:s.z.object({text:s.z.string(),html:s.z.boolean().optional()}).optional()}),dj=qt.extend({type:s.z.literal("NUMBER"),config:s.z.object({placeholder:s.z.string().optional(),min:s.z.number().optional(),max:s.z.number().optional(),step:s.z.number().optional(),default_value:s.z.string().optional()}).optional()}),uj=qt.extend({type:s.z.literal("PASSWORD"),config:s.z.object({placeholder:s.z.string().optional(),min_length:s.z.number().optional(),show_toggle:s.z.boolean().optional(),forgot_password_link:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),pj=qt.extend({type:s.z.literal("PAYMENT"),config:s.z.object({provider:s.z.string().optional(),currency:s.z.string().optional()}).optional()}),fj=qt.extend({type:s.z.literal("SOCIAL"),config:s.z.object({providers:s.z.array(s.z.string()).optional(),provider_details:s.z.array(s.z.object({name:s.z.string(),strategy:s.z.string().optional(),display_name:s.z.string().optional(),icon_url:s.z.string().optional(),href:s.z.string().optional()})).optional()}).optional()}),hj=qt.extend({type:s.z.literal("TEL"),config:s.z.object({placeholder:s.z.string().optional(),default_country:s.z.string().optional(),default_value:s.z.string().optional(),allow_email:s.z.boolean().optional()}).optional()}),gj=qt.extend({type:s.z.literal("TEXT"),config:s.z.object({placeholder:s.z.string().optional(),multiline:s.z.boolean().optional(),max_length:s.z.number().optional(),default_value:s.z.string().optional()}).optional()}),mj=qt.extend({type:s.z.literal("COUNTRY"),config:s.z.object({placeholder:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),yj=qt.extend({type:s.z.literal("URL"),config:s.z.object({placeholder:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),cC=s.z.discriminatedUnion("type",[H9,V9,K9,G9,W9,J9,Y9,Q9]),lC=s.z.discriminatedUnion("type",[Z9,X9,ej]),dC=s.z.discriminatedUnion("type",[tj,nj,ij,mj,rj,oj,sj,aj,cj,lj,dj,uj,pj,fj,hj,gj,yj]),nb=s.z.union([cC,lC,dC]),ib=new Set(["BOOLEAN","CARDS","CHOICE","COUNTRY","DATE","DROPDOWN","EMAIL","LEGAL","NUMBER","PASSWORD","TEL","TEXT","URL"]),_j=s.z.object({id:s.z.string(),type:s.z.literal("submit"),label:s.z.string(),className:s.z.string().optional(),disabled:s.z.boolean().optional().default(!1),order:s.z.number().optional(),visible:s.z.boolean().optional().default(!0),customizations:s.z.record(s.z.string(),s.z.any()).optional()}),Vl=s.z.object({x:s.z.number(),y:s.z.number()}),wj=s.z.object({id:s.z.string(),type:s.z.literal("FLOW"),coordinates:Vl,alias:s.z.string().min(1).max(150).optional(),config:s.z.object({flow_id:s.z.string().max(30),next_node:s.z.string().optional()})}),bj=s.z.object({id:s.z.string(),type:s.z.literal("ROUTER"),coordinates:Vl,alias:s.z.string().min(1).max(150),config:s.z.object({rules:s.z.array(s.z.object({id:s.z.string(),alias:s.z.string().min(1).max(150).optional(),condition:s.z.any(),next_node:s.z.string()})),fallback:s.z.string()})}),vj=s.z.object({id:s.z.string(),type:s.z.literal("STEP"),coordinates:Vl,alias:s.z.string().min(1).max(150).optional(),config:s.z.object({components:s.z.array(nb),next_node:s.z.string().optional()})}),uC=s.z.discriminatedUnion("type",[wj,bj,vj]),Np=s.z.object({name:s.z.string().openapi({description:"The name of the form"}),messages:s.z.object({errors:s.z.record(s.z.string(),s.z.any()).optional(),custom:s.z.record(s.z.string(),s.z.any()).optional()}).optional(),languages:s.z.object({primary:s.z.string().optional(),default:s.z.string().optional()}).optional(),translations:s.z.record(s.z.string(),s.z.any()).optional(),nodes:s.z.array(uC).optional(),start:s.z.object({hidden_fields:s.z.array(s.z.object({key:s.z.string(),value:s.z.string()})).optional(),next_node:s.z.string().optional(),coordinates:Vl.optional()}).optional(),ending:s.z.object({redirection:s.z.object({delay:s.z.number().optional(),target:s.z.string().optional()}).optional(),after_submit:s.z.object({flow_id:s.z.string().optional()}).optional(),coordinates:Vl.optional(),resume_flow:s.z.boolean().optional()}).optional(),style:s.z.object({css:s.z.string().optional()}).optional(),links:s.z.object({sdkSrc:s.z.string().optional(),sdk_src:s.z.string().optional()}).optional()}).openapi({description:"Schema for flow-based forms (matches Auth0 Forms structure)"}),sa=s.z.object({...Un.shape,...Np.shape,id:s.z.string()}),pC=s.z.object({id:s.z.number().optional(),text:s.z.string(),type:s.z.enum(["info","error","success","warning"])}),fC=s.z.object({id:s.z.string().optional(),text:s.z.string(),href:s.z.string(),linkText:s.z.string().optional()}),Aj=s.z.object({name:s.z.string().optional(),action:s.z.string(),method:s.z.enum(["POST","GET"]),title:s.z.string().optional(),description:s.z.string().optional(),components:s.z.array(nb),messages:s.z.array(pC).optional(),links:s.z.array(fC).optional(),footer:s.z.string().optional()});function kj(e){return e.category==="BLOCK"}function Sj(e){return e.category==="WIDGET"}function Ej(e){return e.category==="FIELD"}const hC=s.z.enum(["pre-user-registration","post-user-registration","post-user-login","post-user-update","validate-registration-username","pre-user-deletion","post-user-deletion"]),gC=s.z.enum(["pre-user-registration","post-user-registration","post-user-login","validate-registration-username","pre-user-deletion","post-user-deletion"]),mC=s.z.enum(["post-user-login","post-user-registration","post-user-update","credentials-exchange"]),yC=s.z.enum(["post-user-login","credentials-exchange","pre-user-registration","post-user-registration"]),rb=s.z.enum(["ensure-username","set-preferred-username","account-linking"]),xj={"ensure-username":{name:"Ensure Username",description:"Automatically assigns a username to users who sign in without one. Creates a linked username account for social/email users.",trigger_ids:["post-user-login"]},"set-preferred-username":{name:"Set Preferred Username",description:"Sets the preferred_username claim on tokens based on the username from the primary or linked user.",trigger_ids:["credentials-exchange"]},"account-linking":{name:"Account Linking",description:"Links a user to an existing primary account with the same verified email. Idempotent — safe to run on every login, registration, and email update.",trigger_ids:["post-user-login","post-user-registration","post-user-update"]}},co={enabled:s.z.boolean().default(!1),synchronous:s.z.boolean().default(!1),priority:s.z.number().optional(),hook_id:s.z.string().optional(),metadata:s.z.record(s.z.unknown()).optional()},Cj=s.z.object({...co,trigger_id:hC,url:s.z.string()}),Tj=s.z.object({...co,trigger_id:gC,form_id:s.z.string()}),$j=s.z.object({...co,trigger_id:mC,template_id:rb}),Ij=s.z.object({...co,trigger_id:yC,code_id:s.z.string()}),wy=s.z.union([Cj,Tj,$j,Ij]),zj=s.z.object({...co,trigger_id:hC,...Un.shape,hook_id:s.z.string(),url:s.z.string()}),Pj=s.z.object({...co,trigger_id:gC,...Un.shape,hook_id:s.z.string(),form_id:s.z.string()}),Nj=s.z.object({...co,trigger_id:mC,...Un.shape,hook_id:s.z.string(),template_id:rb}),jj=s.z.object({...co,trigger_id:yC,...Un.shape,hook_id:s.z.string(),code_id:s.z.string()}),aa=s.z.union([zj,Pj,Nj,jj]),jp=s.z.object({code:s.z.string().max(1e5),secrets:s.z.record(s.z.string()).optional()}),ob=jp.extend({id:s.z.string(),tenant_id:s.z.string(),...Un.shape}),_C=s.z.object({name:s.z.string().optional()}),wC=s.z.object({email:s.z.string().optional()}),sb=s.z.object({organization_id:s.z.string().max(50),inviter:_C,invitee:wC,invitation_url:s.z.string().url(),client_id:s.z.string(),connection_id:s.z.string().optional(),app_metadata:s.z.record(s.z.any()).default({}).optional(),user_metadata:s.z.record(s.z.any()).default({}).optional(),ttl_sec:s.z.number().int().max(2592e3).default(604800).optional(),roles:s.z.array(s.z.string()).default([]).optional(),send_invitation_email:s.z.boolean().default(!0).optional()}),Pl=s.z.object({id:s.z.string(),organization_id:s.z.string().max(50),created_at:s.z.string().datetime(),expires_at:s.z.string().datetime(),ticket_id:s.z.string().optional()}).extend(sb.shape),vh=s.z.object({alg:s.z.enum(["RS256","RS384","RS512","ES256","ES384","ES512","HS256","HS384","HS512"]),kid:s.z.string(),kty:s.z.enum(["RSA","EC","oct"]),use:s.z.enum(["sig","enc"]).optional(),n:s.z.string().optional(),e:s.z.string().optional(),crv:s.z.string().optional(),x:s.z.string().optional(),y:s.z.string().optional(),x5t:s.z.string().optional(),x5c:s.z.array(s.z.string()).optional()}).superRefine((e,t)=>{if(e.kty==="RSA")for(const n of["n","e"])e[n]||t.addIssue({code:s.z.ZodIssueCode.custom,path:[n],message:`RSA JWK is missing required member '${n}'`});else if(e.kty==="EC")for(const n of["crv","x","y"])e[n]||t.addIssue({code:s.z.ZodIssueCode.custom,path:[n],message:`EC JWK is missing required member '${n}'`})}),Op=s.z.object({keys:s.z.array(vh)}),by=s.z.object({issuer:s.z.string(),authorization_endpoint:s.z.string(),token_endpoint:s.z.string(),userinfo_endpoint:s.z.string(),jwks_uri:s.z.string(),registration_endpoint:s.z.string().optional(),revocation_endpoint:s.z.string(),end_session_endpoint:s.z.string().optional(),scopes_supported:s.z.array(s.z.string()),response_types_supported:s.z.array(s.z.string()),grant_types_supported:s.z.array(s.z.string()).optional(),code_challenge_methods_supported:s.z.array(s.z.string()),response_modes_supported:s.z.array(s.z.string()),subject_types_supported:s.z.array(s.z.string()),id_token_signing_alg_values_supported:s.z.array(s.z.string()),token_endpoint_auth_methods_supported:s.z.array(s.z.string()),claims_supported:s.z.array(s.z.string()),request_uri_parameter_supported:s.z.boolean(),request_parameter_supported:s.z.boolean(),claims_parameter_supported:s.z.boolean().optional(),request_object_signing_alg_values_supported:s.z.array(s.z.string()).optional(),token_endpoint_auth_signing_alg_values_supported:s.z.array(s.z.string())});var ve=(e=>(e.PENDING="pending",e.AUTHENTICATED="authenticated",e.AWAITING_EMAIL_VERIFICATION="awaiting_email_verification",e.AWAITING_MFA="awaiting_mfa",e.AWAITING_HOOK="awaiting_hook",e.AWAITING_CONTINUATION="awaiting_continuation",e.COMPLETED="completed",e.FAILED="failed",e.EXPIRED="expired",e))(ve||{});const bC=s.z.nativeEnum(ve),vC=s.z.object({strategy:s.z.string(),strategy_type:s.z.string()}),AC=s.z.object({csrf_token:s.z.string(),auth0Client:s.z.string().optional(),authParams:Hl,expires_at:s.z.string(),deleted_at:s.z.string().optional(),ip:s.z.string().optional(),useragent:s.z.string().optional(),session_id:s.z.string().optional(),authorization_url:s.z.string().optional(),state:bC.optional().default("pending"),state_data:s.z.string().optional(),failure_reason:s.z.string().optional(),user_id:s.z.string().optional(),auth_connection:s.z.string().optional(),auth_strategy:vC.optional(),authenticated_at:s.z.string().optional()}).openapi({description:"This represents a login sesion"}),Oj=s.z.object({...AC.shape,id:s.z.string().openapi({description:"This is is used as the state in the universal login"}),created_at:s.z.string(),updated_at:s.z.string()}),R={ACLS_SUMMARY:"acls_summary",ACTIONS_EXECUTION_FAILED:"actions_execution_failed",API_LIMIT:"api_limit",API_LIMIT_WARNING:"api_limit_warning",APPI:"appi",CIBA_EXCHANGE_FAILED:"ciba_exchange_failed",CIBA_EXCHANGE_SUCCEEDED:"ciba_exchange_succeeded",CIBA_START_FAILED:"ciba_start_failed",CIBA_START_SUCCEEDED:"ciba_start_succeeded",CODE_LINK_SENT:"cls",CODE_SENT:"cs",DEPRECATION_NOTICE:"depnote",FAILED_LOGIN:"f",FAILED_BY_CONNECTOR:"fc",FAILED_CHANGE_EMAIL:"fce",FAILED_BY_CORS:"fco",FAILED_CROSS_ORIGIN_AUTHENTICATION:"fcoa",FAILED_CHANGE_PASSWORD:"fcp",FAILED_POST_CHANGE_PASSWORD_HOOK:"fcph",FAILED_CHANGE_PHONE_NUMBER:"fcpn",FAILED_CHANGE_PASSWORD_REQUEST:"fcpr",FAILED_CONNECTOR_PROVISIONING:"fcpro",FAILED_CHANGE_USERNAME:"fcu",FAILED_DELEGATION:"fd",FAILED_DEVICE_ACTIVATION:"fdeac",FAILED_DEVICE_AUTHORIZATION_REQUEST:"fdeaz",USER_CANCELED_DEVICE_CONFIRMATION:"fdecc",FAILED_USER_DELETION:"fdu",FAILED_EXCHANGE_AUTHORIZATION_CODE_FOR_ACCESS_TOKEN:"feacft",FAILED_EXCHANGE_ACCESS_TOKEN_FOR_CLIENT_CREDENTIALS:"feccft",FAILED_EXCHANGE_CUSTOM_TOKEN:"fecte",FAILED_EXCHANGE_DEVICE_CODE_FOR_ACCESS_TOKEN:"fede",FAILED_FEDERATED_LOGOUT:"federated_logout_failed",FAILED_EXCHANGE_NATIVE_SOCIAL_LOGIN:"fens",FAILED_EXCHANGE_PASSWORD_OOB_FOR_ACCESS_TOKEN:"feoobft",FAILED_EXCHANGE_PASSWORD_OTP_FOR_ACCESS_TOKEN:"feotpft",FAILED_EXCHANGE_PASSWORD_FOR_ACCESS_TOKEN:"fepft",FAILED_EXCHANGE_PASSWORDLESS_OTP_FOR_ACCESS_TOKEN:"fepotpft",FAILED_EXCHANGE_PASSWORD_MFA_RECOVERY_FOR_ACCESS_TOKEN:"fercft",FAILED_EXCHANGE_ROTATING_REFRESH_TOKEN:"ferrt",FAILED_EXCHANGE_REFRESH_TOKEN_FOR_ACCESS_TOKEN:"fertft",FAILED_HOOK:"fh",FAILED_IMPERSONATION:"fimp",FAILED_INVITE_ACCEPT:"fi",FAILED_LOGOUT:"flo",FLOWS_EXECUTION_COMPLETED:"flows_execution_completed",FLOWS_EXECUTION_FAILED:"flows_execution_failed",FAILED_SENDING_NOTIFICATION:"fn",FORMS_SUBMISSION_FAILED:"forms_submission_failed",FORMS_SUBMISSION_SUCCEEDED:"forms_submission_succeeded",FAILED_LOGIN_INCORRECT_PASSWORD:"fp",FAILED_PUSHED_AUTHORIZATION_REQUEST:"fpar",FAILED_POST_USER_REGISTRATION_HOOK:"fpurh",FAILED_SIGNUP:"fs",FAILED_SILENT_AUTH:"fsa",FAILED_LOGIN_INVALID_EMAIL_USERNAME:"fu",FAILED_USERS_IMPORT:"fui",FAILED_VERIFICATION_EMAIL:"fv",FAILED_VERIFICATION_EMAIL_REQUEST:"fvr",EMAIL_VERIFICATION_CONFIRMED:"gd_auth_email_verification",EMAIL_VERIFICATION_FAILED:"gd_auth_fail_email_verification",MFA_AUTH_FAILED:"gd_auth_failed",MFA_AUTH_REJECTED:"gd_auth_rejected",MFA_AUTH_SUCCESS:"gd_auth_succeed",MFA_ENROLLMENT_COMPLETE:"gd_enrollment_complete",TOO_MANY_MFA_FAILURES:"gd_otp_rate_limit_exceed",MFA_RECOVERY_FAILED:"gd_recovery_failed",MFA_RECOVERY_RATE_LIMIT_EXCEED:"gd_recovery_rate_limit_exceed",MFA_RECOVERY_SUCCESS:"gd_recovery_succeed",MFA_EMAIL_SENT:"gd_send_email",EMAIL_VERIFICATION_SENT:"gd_send_email_verification",EMAIL_VERIFICATION_SEND_FAILURE:"gd_send_email_verification_failure",PUSH_NOTIFICATION_SENT:"gd_send_pn",ERROR_SENDING_MFA_PUSH_NOTIFICATION:"gd_send_pn_failure",MFA_SMS_SENT:"gd_send_sms",ERROR_SENDING_MFA_SMS:"gd_send_sms_failure",MFA_VOICE_CALL_SUCCESS:"gd_send_voice",MFA_VOICE_CALL_FAILED:"gd_send_voice_failure",SECOND_FACTOR_STARTED:"gd_start_auth",MFA_ENROLL_STARTED:"gd_start_enroll",MFA_ENROLLMENT_FAILED:"gd_start_enroll_failed",GUARDIAN_TENANT_UPDATE:"gd_tenant_update",UNENROLL_DEVICE_ACCOUNT:"gd_unenroll",UPDATE_DEVICE_ACCOUNT:"gd_update_device_account",WEBAUTHN_CHALLENGE_FAILED:"gd_webauthn_challenge_failed",WEBAUTHN_ENROLLMENT_FAILED:"gd_webauthn_enrollment_failed",FAILED_KMS_API_OPERATION:"kms_key_management_failure",SUCCESS_KMS_API_OPERATION:"kms_key_management_success",KMS_KEY_STATE_CHANGED:"kms_key_state_changed",TOO_MANY_CALLS_TO_DELEGATION:"limit_delegation",BLOCKED_IP_ADDRESS:"limit_mu",BLOCKED_ACCOUNT_IP:"limit_sul",BLOCKED_ACCOUNT_EMAIL:"limit_wc",MFA_REQUIRED:"mfar",MANAGEMENT_API_READ_OPERATION:"mgmt_api_read",FAILED_AUTHENTICATION_METHOD_OPERATION_MY_ACCOUNT:"my_account_authentication_method_failed",SUCCESSFUL_AUTHENTICATION_METHOD_OPERATION_MY_ACCOUNT:"my_account_authentication_method_succeeded",FAILED_OIDC_BACKCHANNEL_LOGOUT:"oidc_backchannel_logout_failed",SUCCESSFUL_OIDC_BACKCHANNEL_LOGOUT:"oidc_backchannel_logout_succeeded",ORGANIZATION_MEMBER_ADDED:"organization_member_added",PASSKEY_CHALLENGE_FAILED:"passkey_challenge_failed",PASSKEY_CHALLENGE_STARTED:"passkey_challenge_started",PRE_LOGIN_ASSESSMENT:"pla",BREACHED_PASSWORD:"pwd_leak",BREACHED_PASSWORD_ON_RESET:"reset_pwd_leak",SUCCESS_RESOURCE_CLEANUP:"resource_cleanup",RICH_CONSENTS_ACCESS_ERROR:"rich_consents_access_error",SUCCESS_LOGIN:"s",SUCCESS_API_OPERATION:"sapi",FAILED_API_OPERATION:"fapi",SUCCESS_CHANGE_EMAIL:"sce",SUCCESS_CROSS_ORIGIN_AUTHENTICATION:"scoa",SUCCESS_CHANGE_PASSWORD:"scp",SUCCESS_CHANGE_PHONE_NUMBER:"scpn",SUCCESS_CHANGE_PASSWORD_REQUEST:"scpr",SUCCESS_CHANGE_USERNAME:"scu",SUCCESS_CREDENTIAL_VALIDATION:"scv",SUCCESS_DELEGATION:"sd",SUCCESS_USER_DELETION:"sdu",SUCCESS_EXCHANGE_AUTHORIZATION_CODE_FOR_ACCESS_TOKEN:"seacft",SUCCESS_EXCHANGE_ACCESS_TOKEN_FOR_CLIENT_CREDENTIALS:"seccft",SUCCESS_EXCHANGE_CUSTOM_TOKEN:"secte",SUCCESS_EXCHANGE_DEVICE_CODE_FOR_ACCESS_TOKEN:"sede",SUCCESS_EXCHANGE_NATIVE_SOCIAL_LOGIN:"sens",SUCCESS_EXCHANGE_PASSWORD_OOB_FOR_ACCESS_TOKEN:"seoobft",SUCCESS_EXCHANGE_PASSWORD_OTP_FOR_ACCESS_TOKEN:"seotpft",SUCCESS_EXCHANGE_PASSWORD_FOR_ACCESS_TOKEN:"sepft",SUCCESS_EXCHANGE_PASSKEY_OOB_FOR_ACCESS_TOKEN:"sepkoobft",SUCCESS_EXCHANGE_PASSKEY_OTP_FOR_ACCESS_TOKEN:"sepkotpft",SUCCESS_EXCHANGE_PASSKEY_MFA_RECOVERY_FOR_ACCESS_TOKEN:"sepkrcft",SUCCESS_EXCHANGE_PASSWORD_MFA_RECOVERY_FOR_ACCESS_TOKEN:"sercft",SUCCESS_EXCHANGE_REFRESH_TOKEN_FOR_ACCESS_TOKEN:"sertft",SUCCESS_IMPERSONATION:"simp",SUCCESSFULLY_ACCEPTED_USER_INVITE:"si",BREACHED_PASSWORD_ON_SIGNUP:"signup_pwd_leak",SUCCESS_LOGOUT:"slo",SUCCESS_HOOK:"sh",SUCCESS_REVOCATION:"srrt",SUCCESS_SIGNUP:"ss",FAILED_SS_SSO_OPERATION:"ss_sso_failure",INFORMATION_FROM_SS_SSO_OPERATION:"ss_sso_info",SUCCESS_SS_SSO_OPERATION:"ss_sso_success",SUCCESS_SILENT_AUTH:"ssa",SUCCESSFUL_SCIM_OPERATION:"sscim",SUCCESSFULLY_IMPORTED_USERS:"sui",SUCCESS_VERIFICATION_EMAIL:"sv",SUCCESS_VERIFICATION_EMAIL_REQUEST:"svr",MAX_AMOUNT_OF_AUTHENTICATORS:"too_many_records",USER_LOGIN_BLOCK_RELEASED:"ublkdu",FAILED_UNIVERSAL_LOGOUT:"universal_logout_failed",SUCCESSFUL_UNIVERSAL_LOGOUT:"universal_logout_succeeded",WARNING_DURING_LOGIN:"w",WARNING_SENDING_NOTIFICATION:"wn",WARNING_USER_MANAGEMENT:"wum"},Fj=s.z.string().refine(e=>Object.values(R).includes(e),{message:"Invalid log type"}),kC=s.z.object({name:s.z.string(),version:s.z.string(),env:s.z.object({node:s.z.string().optional()}).optional()}),SC=s.z.object({country_code:s.z.string().length(2),city_name:s.z.string(),latitude:s.z.string(),longitude:s.z.string(),time_zone:s.z.string(),continent_code:s.z.string()}),EC=s.z.object({type:Fj,date:s.z.string(),description:s.z.string().optional(),ip:s.z.string().optional(),user_agent:s.z.string().optional(),details:s.z.any().optional(),isMobile:s.z.boolean(),user_id:s.z.string().optional(),user_name:s.z.string().optional(),connection:s.z.string().optional(),connection_id:s.z.string().optional(),client_id:s.z.string().optional(),client_name:s.z.string().optional(),audience:s.z.string().optional(),scope:s.z.string().optional(),strategy:s.z.string().optional(),strategy_type:s.z.string().optional(),hostname:s.z.string().optional(),auth0_client:kC.optional(),log_id:s.z.string().optional(),location_info:SC.optional()}),Ia=s.z.object({...EC.shape,log_id:s.z.string()}),xC=s.z.enum(["http","eventbridge","eventgrid","splunk","datadog","sumo"]),ab=s.z.enum(["active","paused","suspended"]),CC=s.z.object({type:s.z.string(),name:s.z.string()}),cb=s.z.object({name:s.z.string(),type:xC,status:ab.optional(),sink:s.z.record(s.z.string(),s.z.unknown()),filters:s.z.array(CC).optional(),isPriority:s.z.boolean().optional()}),Gs=cb.extend({id:s.z.string(),status:ab,created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),TC=s.z.enum(["auth0","cognito","okta","oidc"]),$C=s.z.object({domain:s.z.string(),client_id:s.z.string(),client_secret:s.z.string(),audience:s.z.string().optional(),scope:s.z.string().optional()}),Fp=s.z.object({id:s.z.string().optional(),name:s.z.string(),provider:TC,connection:s.z.string(),enabled:s.z.boolean().default(!0),credentials:$C}),vy=s.z.object({id:s.z.string(),created_at:s.z.string(),updated_at:s.z.string()}).extend(Fp.shape),ca=s.z.object({enabled:s.z.boolean().optional(),shields:s.z.array(s.z.string()).optional(),admin_notification_frequency:s.z.array(s.z.string()).optional(),method:s.z.string().optional(),stage:s.z.object({"pre-user-registration":s.z.object({shields:s.z.array(s.z.string()).optional()}).optional(),"pre-change-password":s.z.object({shields:s.z.array(s.z.string()).optional()}).optional()}).optional()}),la=s.z.object({enabled:s.z.boolean().optional(),shields:s.z.array(s.z.string()).optional(),allowlist:s.z.array(s.z.string()).optional(),mode:s.z.string().optional(),max_attempts:s.z.number().optional()}),da=s.z.object({enabled:s.z.boolean().optional(),shields:s.z.array(s.z.string()).optional(),allowlist:s.z.array(s.z.string()).optional(),stage:s.z.object({"pre-login":s.z.object({max_attempts:s.z.number().optional(),rate:s.z.number().optional()}).optional(),"pre-user-registration":s.z.object({max_attempts:s.z.number().optional(),rate:s.z.number().optional()}).optional()}).optional()}),IC=s.z.object({breached_password_detection:ca.optional(),brute_force_protection:la.optional(),suspicious_ip_throttling:da.optional()}),zC=s.z.object({id:s.z.string().optional(),user_id:s.z.string(),password:s.z.string(),algorithm:s.z.enum(["bcrypt","argon2id"]).default("argon2id"),is_current:s.z.boolean().default(!0)}),Rj=zC.extend({id:s.z.string(),created_at:s.z.string(),updated_at:s.z.string()}),PC=s.z.object({initial_user_agent:s.z.string().describe("First user agent of the device from which this user logged in"),initial_ip:s.z.string().describe("First IP address associated with this session"),initial_asn:s.z.string().describe("First autonomous system number associated with this session"),last_user_agent:s.z.string().describe("Last user agent of the device from which this user logged in"),last_ip:s.z.string().describe("Last IP address from which this user logged in"),last_asn:s.z.string().describe("Last autonomous system number from which this user logged in")}),NC=s.z.object({id:s.z.string(),revoked_at:s.z.string().optional(),used_at:s.z.string().optional(),user_id:s.z.string().describe("The user ID associated with the session"),expires_at:s.z.string().optional(),login_session_id:s.z.string(),idle_expires_at:s.z.string().optional(),device:PC.describe("Metadata related to the device used in the session"),clients:s.z.array(s.z.string()).describe("List of client details for the session")}),Ah=s.z.object({created_at:s.z.string(),updated_at:s.z.string(),authenticated_at:s.z.string(),last_interaction_at:s.z.string(),...NC.shape}),Ay=s.z.object({kid:s.z.string().openapi({description:"The key id of the signing key"}),tenant_id:s.z.string().optional().openapi({description:"The tenant the key belongs to. Omitted means the key is shared / control-plane scoped."}),cert:s.z.string().openapi({description:"The public certificate of the signing key"}),fingerprint:s.z.string().openapi({description:"The cert fingerprint"}),thumbprint:s.z.string().openapi({description:"The cert thumbprint"}),pkcs7:s.z.string().optional().openapi({description:"The private key in pkcs7 format"}),current:s.z.boolean().optional().openapi({description:"True if the key is the current key"}),next:s.z.boolean().optional().openapi({description:"True if the key is the next key"}),previous:s.z.boolean().optional().openapi({description:"True if the key is the previous key"}),current_since:s.z.string().optional().openapi({description:"The date and time when the key became the current key"}),current_until:s.z.string().optional().openapi({description:"The date and time when the current key was rotated"}),revoked:s.z.boolean().optional().openapi({description:"True if the key is revoked"}),revoked_at:s.z.string().optional().openapi({description:"The date and time when the key was revoked"}),connection:s.z.string().optional().openapi({description:"The connection identifier associated with the key"}),type:s.z.enum(["jwt_signing","saml_encryption"]).openapi({description:"The type of the signing key"})}),lb=s.z.object({id:s.z.string().optional(),audience:s.z.string(),friendly_name:s.z.string(),picture_url:s.z.string().optional(),support_email:s.z.string().optional(),support_url:s.z.string().optional(),sender_email:s.z.string().email(),sender_name:s.z.string(),session_lifetime:s.z.number().optional(),idle_session_lifetime:s.z.number().optional(),ephemeral_session_lifetime:s.z.number().optional(),idle_ephemeral_session_lifetime:s.z.number().optional(),session_cookie:s.z.object({mode:s.z.enum(["persistent","non-persistent"]).optional()}).optional(),allowed_logout_urls:s.z.array(s.z.string()).optional(),default_redirection_uri:s.z.string().optional(),default_client_id:s.z.string().optional(),enabled_locales:s.z.array(s.z.string()).optional(),default_directory:s.z.string().optional(),error_page:s.z.object({html:s.z.string().optional(),show_log_link:s.z.boolean().optional(),url:s.z.string().optional()}).nullish(),flags:s.z.object({allow_changing_enable_sso:s.z.boolean().optional(),allow_legacy_delegation_grant_types:s.z.boolean().optional(),allow_legacy_ro_grant_types:s.z.boolean().optional(),allow_legacy_tokeninfo_endpoint:s.z.boolean().optional(),change_pwd_flow_v1:s.z.boolean().optional(),custom_domains_provisioning:s.z.boolean().optional(),dashboard_insights_view:s.z.boolean().optional(),dashboard_log_streams_next:s.z.boolean().optional(),disable_clickjack_protection_headers:s.z.boolean().optional(),disable_fields_map_fix:s.z.boolean().optional(),disable_impersonation:s.z.boolean().optional(),disable_management_api_sms_obfuscation:s.z.boolean().optional(),enable_adfs_waad_email_verification:s.z.boolean().optional(),enable_apis_section:s.z.boolean().optional(),enable_client_connections:s.z.boolean().optional(),enable_custom_domain_in_emails:s.z.boolean().optional(),enable_dynamic_client_registration:s.z.boolean().optional(),dcr_require_initial_access_token:s.z.boolean().optional(),dcr_allowed_grant_types:s.z.array(s.z.string()).optional(),allow_http_return_to:s.z.array(s.z.string().refine(e=>{try{const t=new URL(e);return t.protocol==="http:"&&(t.pathname===""||t.pathname==="/")&&!t.search&&!t.hash&&e===t.origin}catch{return!1}},{message:"must be a fully-qualified http origin (scheme + host + port, no path)"})).optional(),enable_idtoken_api2:s.z.boolean().optional(),enable_legacy_logs_search_v2:s.z.boolean().optional(),enable_legacy_profile:s.z.boolean().optional(),enable_pipeline2:s.z.boolean().optional(),enable_public_signup_user_exists_error:s.z.boolean().optional(),enable_sso:s.z.boolean().optional(),enforce_client_authentication_on_passwordless_start:s.z.boolean().optional(),genai_trial:s.z.boolean().optional(),improved_signup_bot_detection_in_classic:s.z.boolean().optional(),mfa_show_factor_list_on_enrollment:s.z.boolean().optional(),no_disclose_enterprise_connections:s.z.boolean().optional(),remove_alg_from_jwks:s.z.boolean().optional(),revoke_refresh_token_grant:s.z.boolean().optional(),trust_azure_adfs_email_verified_connection_property:s.z.boolean().optional(),use_scope_descriptions_for_consent:s.z.boolean().optional(),inherit_global_permissions_in_organizations:s.z.boolean().optional()}).optional(),sandbox_version:s.z.string().optional(),legacy_sandbox_version:s.z.string().optional(),sandbox_versions_available:s.z.array(s.z.string()).optional(),change_password:s.z.object({enabled:s.z.boolean().optional(),html:s.z.string().optional()}).optional(),guardian_mfa_page:s.z.object({enabled:s.z.boolean().optional(),html:s.z.string().optional()}).optional(),device_flow:s.z.object({charset:s.z.enum(["base20","digits"]).optional(),mask:s.z.string().max(20).optional()}).optional(),default_token_quota:s.z.object({clients:s.z.object({client_credentials:s.z.record(s.z.any()).optional()}).optional(),organizations:s.z.object({client_credentials:s.z.record(s.z.any()).optional()}).optional()}).nullish(),default_audience:s.z.string().optional(),default_organization:s.z.string().optional(),sessions:s.z.object({oidc_logout_prompt_enabled:s.z.boolean().optional()}).optional(),oidc_logout:s.z.object({rp_logout_end_session_endpoint_discovery:s.z.boolean().optional()}).optional(),allow_organization_name_in_authentication_api:s.z.boolean().optional(),customize_mfa_in_postlogin_action:s.z.boolean().optional(),acr_values_supported:s.z.array(s.z.string()).optional(),mtls:s.z.object({enable_endpoint_aliases:s.z.boolean().optional()}).nullish(),pushed_authorization_requests_supported:s.z.boolean().optional(),authorization_response_iss_parameter_supported:s.z.boolean().optional(),attack_protection:IC.optional(),mfa:s.z.object({policy:s.z.enum(["never","always"]).default("never").optional(),factors:s.z.object({sms:s.z.boolean().default(!1),otp:s.z.boolean().default(!1),email:s.z.boolean().default(!1),push_notification:s.z.boolean().default(!1),webauthn_roaming:s.z.boolean().default(!1),webauthn_platform:s.z.boolean().default(!1),recovery_code:s.z.boolean().default(!1),duo:s.z.boolean().default(!1)}).optional(),sms_provider:s.z.object({provider:s.z.enum(["twilio","vonage","aws_sns","phone_message_hook"]).optional()}).optional(),twilio:s.z.object({sid:s.z.string().optional(),auth_token:s.z.string().optional(),from:s.z.string().optional(),messaging_service_sid:s.z.string().optional()}).optional(),phone_message:s.z.object({message:s.z.string().optional()}).optional()}).optional()}),Rp=s.z.object({created_at:s.z.string().nullable().transform(e=>e??""),updated_at:s.z.string().nullable().transform(e=>e??""),...lb.shape,id:s.z.string()});var tn=(e=>(e.RefreshToken="refresh_token",e.AuthorizationCode="authorization_code",e.ClientCredential="client_credentials",e.Passwordless="passwordless",e.Password="password",e.OTP="http://auth0.com/oauth/grant-type/passwordless/otp",e))(tn||{});const db=s.z.object({access_token:s.z.string(),id_token:s.z.string().optional(),scope:s.z.string().optional(),state:s.z.string().optional(),refresh_token:s.z.string().optional(),token_type:s.z.string(),expires_in:s.z.number()});s.z.object({code:s.z.string(),state:s.z.string().optional()});const jC=s.z.object({button_border_radius:s.z.number(),button_border_weight:s.z.number(),buttons_style:s.z.enum(["pill","rounded","sharp"]),input_border_radius:s.z.number(),input_border_weight:s.z.number(),inputs_style:s.z.enum(["pill","rounded","sharp"]),show_widget_shadow:s.z.boolean(),widget_border_weight:s.z.number(),widget_corner_radius:s.z.number()}),OC=s.z.object({base_focus_color:s.z.string(),base_hover_color:s.z.string(),body_text:s.z.string(),captcha_widget_theme:s.z.enum(["auto","dark","light"]),error:s.z.string(),header:s.z.string(),icons:s.z.string(),input_background:s.z.string(),input_border:s.z.string(),input_filled_text:s.z.string(),input_labels_placeholders:s.z.string(),links_focused_components:s.z.string(),primary_button:s.z.string(),primary_button_label:s.z.string(),secondary_button_border:s.z.string(),secondary_button_label:s.z.string(),success:s.z.string(),widget_background:s.z.string(),widget_border:s.z.string()}),$o=s.z.object({bold:s.z.boolean(),size:s.z.number()}),FC=s.z.object({body_text:$o,buttons_text:$o,font_url:s.z.string(),input_labels:$o,links:$o,links_style:s.z.enum(["normal","underlined"]),reference_text_size:s.z.number(),subtitle:$o,title:$o}),RC=s.z.object({background_color:s.z.string(),background_image_url:s.z.string(),page_layout:s.z.enum(["center","left","right"]),logo_placement:s.z.enum(["widget","chip","none"]).optional()}),DC=s.z.object({header_text_alignment:s.z.enum(["center","left","right"]),logo_height:s.z.number(),logo_position:s.z.enum(["center","left","none","right"]),logo_url:s.z.string(),social_buttons_layout:s.z.enum(["bottom","top"])}),BC=s.z.object({borders:jC,colors:OC,displayName:s.z.string(),fonts:FC,page_background:RC,widget:DC}),op=BC.extend({themeId:s.z.string()}),Wo=s.z.object({universal_login_experience:s.z.enum(["new","classic"]).default("new"),identifier_first:s.z.boolean().default(!0),password_first:s.z.boolean().default(!1),webauthn_platform_first_factor:s.z.boolean()}),Ws=s.z.object({name:s.z.string(),enabled:s.z.boolean().optional().default(!0),default_from_address:s.z.string().optional(),credentials:s.z.record(s.z.string(),s.z.unknown()),settings:s.z.object({}).optional()}),ub=s.z.enum(["verify_email","verify_email_by_code","reset_email","reset_email_by_code","welcome_email","blocked_account","stolen_credentials","enrollment_email","mfa_oob_code","change_password","password_reset","user_invitation"]),Rr=s.z.object({template:ub,body:s.z.string(),from:s.z.string(),subject:s.z.string(),syntax:s.z.literal("liquid").default("liquid"),resultUrl:s.z.string().optional(),urlLifetimeInSeconds:s.z.number().int().nonnegative().optional(),includeEmailInRedirect:s.z.boolean().default(!1),enabled:s.z.boolean().default(!0)}),pb=s.z.object({id:s.z.string(),login_id:s.z.string(),user_id:s.z.string(),client_id:s.z.string(),expires_at:s.z.string().optional(),idle_expires_at:s.z.string().optional(),last_exchanged_at:s.z.string().optional(),device:PC,resource_servers:s.z.array(s.z.object({audience:s.z.string(),scopes:s.z.string()})),rotating:s.z.boolean(),token_lookup:s.z.string().optional(),token_hash:s.z.string().optional(),family_id:s.z.string().optional(),rotated_to:s.z.string().optional(),rotated_at:s.z.string().optional()}),Dj=s.z.object({created_at:s.z.string(),revoked_at:s.z.string().optional(),...pb.shape}),Bj=s.z.object({to:s.z.string(),message:s.z.string()}),Lj=s.z.object({name:s.z.string(),options:s.z.object({})}),LC=s.z.object({value:s.z.string(),description:s.z.string().optional()}),MC=s.z.object({token_dialect:s.z.enum(["access_token","access_token_authz"]).optional(),enforce_policies:s.z.boolean().optional(),allow_skipping_userinfo:s.z.boolean().optional(),skip_userinfo:s.z.boolean().optional(),persist_client_authorization:s.z.boolean().optional(),enable_introspection_endpoint:s.z.boolean().optional(),mtls:s.z.object({bound_access_tokens:s.z.boolean().optional()}).optional()}),Dp=s.z.object({id:s.z.string().optional(),name:s.z.string(),identifier:s.z.string(),scopes:s.z.array(LC).optional(),signing_alg:s.z.string().optional(),signing_secret:s.z.string().optional(),token_lifetime:s.z.number().default(86400),token_lifetime_for_web:s.z.number().default(7200),skip_consent_for_verifiable_first_party_clients:s.z.boolean().optional(),allow_offline_access:s.z.boolean().optional(),verificationKey:s.z.string().optional(),options:MC.optional(),is_system:s.z.boolean().optional(),metadata:s.z.record(s.z.any()).optional()}),Uo=s.z.object({...Dp.shape,created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),Mj=s.z.array(Uo),UC=s.z.object({role_id:s.z.string(),resource_server_identifier:s.z.string(),permission_name:s.z.string()}),fb=s.z.object({...UC.shape,created_at:s.z.string()}),qC=s.z.array(fb),HC=s.z.object({user_id:s.z.string(),resource_server_identifier:s.z.string(),permission_name:s.z.string(),organization_id:s.z.string().optional()}),VC=s.z.object({...HC.shape,tenant_id:s.z.string(),created_at:s.z.string().optional()}),Uj=s.z.array(VC),KC=s.z.object({user_id:s.z.string(),resource_server_identifier:s.z.string(),resource_server_name:s.z.string(),permission_name:s.z.string(),description:s.z.string().nullable().optional(),created_at:s.z.string().optional(),organization_id:s.z.string().optional()}),GC=s.z.array(KC),WC=s.z.object({user_id:s.z.string(),role_id:s.z.string(),organization_id:s.z.string().optional()}),JC=s.z.object({...WC.shape,tenant_id:s.z.string(),created_at:s.z.string().optional()}),qj=s.z.array(JC),Bp=s.z.object({id:s.z.string().optional().openapi({description:"The unique identifier of the role. If not provided, one will be generated."}),name:s.z.string().min(1).max(50).openapi({description:"The name of the role. Cannot include '<' or '>'"}),description:s.z.string().max(255).optional().openapi({description:"The description of the role"}),is_system:s.z.boolean().optional(),metadata:s.z.record(s.z.any()).optional().openapi({description:"Metadata associated with the role. Can be used to control sync behavior in multi-tenancy scenarios."})}),qo=Bp.extend({id:s.z.string().openapi({description:"The unique identifier of the role"}),created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),Lp=s.z.array(qo),YC=s.z.object({logo_url:s.z.string().optional().openapi({description:"URL of the organization's logo"}),colors:s.z.object({primary:s.z.string().optional().openapi({description:"Primary color in hex format (e.g., #FF0000)"}),page_background:s.z.string().optional().openapi({description:"Page background color in hex format (e.g., #FFFFFF)"})}).optional()}).optional(),QC=s.z.object({connection_id:s.z.string().openapi({description:"ID of the connection"}),assign_membership_on_login:s.z.boolean().default(!1).openapi({description:"Whether to assign membership to the organization on login"}),show_as_button:s.z.boolean().default(!0).openapi({description:"Whether to show this connection as a button in the login screen"}),is_signup_enabled:s.z.boolean().default(!0).openapi({description:"Whether signup is enabled for this connection"})}),ZC=s.z.object({client_credentials:s.z.object({enforce:s.z.boolean().default(!1).openapi({description:"Whether to enforce token quota limits"}),per_day:s.z.number().min(0).default(0).openapi({description:"Maximum tokens per day (0 = unlimited)"}),per_hour:s.z.number().min(0).default(0).openapi({description:"Maximum tokens per hour (0 = unlimited)"})}).optional()}).optional(),Mp=s.z.object({id:s.z.string().optional(),name:s.z.string().min(1).regex(/^[a-z0-9_-]+$/,{message:"Organization name must be lowercase and can only contain letters, numbers, hyphens, and underscores"}).openapi({description:"The name of the organization. Must be lowercase and can only contain letters, numbers, hyphens, and underscores."}),display_name:s.z.string().optional().openapi({description:"The display name of the organization"}),branding:YC,metadata:s.z.record(s.z.any()).default({}).optional().openapi({description:"Custom metadata for the organization"}),enabled_connections:s.z.array(QC).default([]).optional().openapi({description:"List of enabled connections for the organization"}),token_quota:ZC}),Mr=s.z.object({...Mp.shape,...Un.shape,id:s.z.string(),name:s.z.string().min(1).openapi({description:"The name of the organization"})}),Up=s.z.object({connection_id:s.z.string().openapi({description:"ID of the tenant-level connection to enable for the org."}),assign_membership_on_login:s.z.boolean().optional().default(!1),show_as_button:s.z.boolean().optional().default(!0),is_signup_enabled:s.z.boolean().optional().default(!0)}),ua=s.z.object({...Up.shape,connection:s.z.object({name:s.z.string().optional(),strategy:s.z.string().optional()}).optional(),created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),Hj=s.z.array(ua),XC=s.z.object({user_id:s.z.string().openapi({description:"ID of the user"}),organization_id:s.z.string().openapi({description:"ID of the organization"})}),Vj=s.z.object({...XC.shape,...Un.shape,id:s.z.string()}),Kj=s.z.object({idle_session_lifetime:s.z.number().default(72),session_lifetime:s.z.number().default(168),session_cookie:s.z.object({mode:s.z.enum(["persistent","non-persistent"]).optional()}).optional(),enable_client_connections:s.z.boolean().optional(),default_redirection_uri:s.z.string().optional(),enabled_locales:s.z.array(s.z.string()).optional(),default_directory:s.z.string().optional(),error_page:s.z.object({html:s.z.string().optional(),show_log_link:s.z.boolean().optional(),url:s.z.string().optional()}).optional(),flags:s.z.object({allow_legacy_delegation_grant_types:s.z.boolean().optional(),allow_legacy_ro_grant_types:s.z.boolean().optional(),allow_legacy_tokeninfo_endpoint:s.z.boolean().optional(),disable_clickjack_protection_headers:s.z.boolean().optional(),enable_apis_section:s.z.boolean().optional(),enable_client_connections:s.z.boolean().optional(),enable_custom_domain_in_emails:s.z.boolean().optional(),enable_dynamic_client_registration:s.z.boolean().optional(),enable_idtoken_api2:s.z.boolean().optional(),enable_legacy_logs_search_v2:s.z.boolean().optional(),enable_legacy_profile:s.z.boolean().optional(),enable_pipeline2:s.z.boolean().optional(),enable_public_signup_user_exists_error:s.z.boolean().optional(),use_scope_descriptions_for_consent:s.z.boolean().optional(),disable_management_api_sms_obfuscation:s.z.boolean().optional(),enable_adfs_waad_email_verification:s.z.boolean().optional(),revoke_refresh_token_grant:s.z.boolean().optional(),dashboard_log_streams_next:s.z.boolean().optional(),dashboard_insights_view:s.z.boolean().optional(),disable_fields_map_fix:s.z.boolean().optional(),mfa_show_factor_list_on_enrollment:s.z.boolean().optional()}).optional(),friendly_name:s.z.string().optional(),picture_url:s.z.string().optional(),support_email:s.z.string().optional(),support_url:s.z.string().optional(),sandbox_version:s.z.string().optional(),sandbox_versions_available:s.z.array(s.z.string()).optional(),change_password:s.z.object({enabled:s.z.boolean(),html:s.z.string()}).optional(),guardian_mfa_page:s.z.object({enabled:s.z.boolean(),html:s.z.string()}).optional(),default_audience:s.z.string().optional(),default_organization:s.z.string().optional(),sessions:s.z.object({oidc_logout_prompt_enabled:s.z.boolean().optional()}).optional(),mfa:s.z.object({policy:s.z.enum(["never","always"]).default("never").optional(),factors:s.z.object({sms:s.z.boolean().default(!1),otp:s.z.boolean().default(!1),email:s.z.boolean().default(!1),push_notification:s.z.boolean().default(!1),webauthn_roaming:s.z.boolean().default(!1),webauthn_platform:s.z.boolean().default(!1),recovery_code:s.z.boolean().default(!1),duo:s.z.boolean().default(!1)}).optional(),sms_provider:s.z.object({provider:s.z.enum(["twilio","vonage","aws_sns","phone_message_hook"]).optional()}).optional(),twilio:s.z.object({sid:s.z.string().optional(),auth_token:s.z.string().optional(),from:s.z.string().optional(),messaging_service_sid:s.z.string().optional()}).optional(),phone_message:s.z.object({message:s.z.string().optional()}).optional()}).optional()}),eT=s.z.object({date:s.z.string().openapi({description:"Date these events occurred in ISO 8601 format",example:"2025-12-19"}),logins:s.z.number().openapi({description:"Number of logins on this date",example:150}),signups:s.z.number().openapi({description:"Number of signups on this date",example:25}),leaked_passwords:s.z.number().openapi({description:"Number of breached-password detections on this date (subscription required)",example:0}),updated_at:s.z.string().openapi({description:"Date and time this stats entry was last updated in ISO 8601 format",example:"2025-12-19T10:30:00.000Z"}),created_at:s.z.string().openapi({description:"Approximate date and time the first event occurred in ISO 8601 format",example:"2025-12-19T00:00:00.000Z"})}),Gj=s.z.number().openapi({description:"Number of active users in the last 30 days",example:1234}),Wj=s.z.enum(["active-users","logins","signups","refresh-tokens","sessions"]),Jj=s.z.enum(["hour","day","week","month"]),Yj=s.z.enum(["time","connection","client_id","user_type","event"]),Qj=s.z.enum(["password","social","passwordless","enterprise"]),tT=s.z.object({name:s.z.string(),type:s.z.string()}),nT=s.z.object({elapsed:s.z.number(),rows_read:s.z.number().optional(),bytes_read:s.z.number().optional()}),iT=s.z.object({meta:s.z.array(tT),data:s.z.array(s.z.record(s.z.string(),s.z.any())),rows:s.z.number(),rows_before_limit_at_least:s.z.number().optional(),statistics:nT.optional()}),pa=s.z.enum(["login","login-id","login-password","signup","signup-id","signup-password","reset-password","consent","mfa","mfa-push","mfa-otp","mfa-voice","mfa-phone","mfa-webauthn","mfa-email","mfa-recovery-code","status","device-flow","email-verification","email-otp-challenge","organizations","invitation","common","passkeys","captcha","custom-form","login-passwordless","mfa-login-options"]),No=s.z.record(s.z.string(),s.z.record(s.z.string(),s.z.string())).openapi({type:"object",additionalProperties:{type:"object",additionalProperties:{type:"string"}}}),Zj=s.z.object({prompt:pa,language:s.z.string(),custom_text:No}),Z={EMAIL:"email",SMS:"sms",USERNAME_PASSWORD:"Username-Password-Authentication",GOOGLE_OAUTH2:"google-oauth2",APPLE:"apple",FACEBOOK:"facebook",GITHUB:"github",MICROSOFT:"microsoft",VIPPS:"vipps",OIDC:"oidc",OAUTH2:"oauth2",SAMLP:"samlp",WAAD:"waad",ADFS:"adfs"},Gt={DATABASE:"database",SOCIAL:"social",PASSWORDLESS:"passwordless"},rT=s.z.enum(["phone","totp","email","push","webauthn-roaming","webauthn-platform","passkey"]),oT=s.z.object({user_id:s.z.string(),type:rT,phone_number:s.z.string().optional(),totp_secret:s.z.string().optional(),credential_id:s.z.string().optional(),public_key:s.z.string().optional(),sign_count:s.z.number().int().nonnegative().optional(),credential_backed_up:s.z.boolean().optional(),transports:s.z.array(s.z.string()).optional(),friendly_name:s.z.string().optional(),confirmed:s.z.boolean().default(!1)});function sT(e,t){e.type==="phone"&&!e.phone_number&&t.addIssue({code:s.z.ZodIssueCode.custom,message:"phone_number is required when type is 'phone'",path:["phone_number"]}),e.type==="totp"&&!e.totp_secret&&t.addIssue({code:s.z.ZodIssueCode.custom,message:"totp_secret is required when type is 'totp'",path:["totp_secret"]}),["webauthn-roaming","webauthn-platform","passkey"].includes(e.type)&&(e.credential_id||t.addIssue({code:s.z.ZodIssueCode.custom,message:`credential_id is required when type is '${e.type}'`,path:["credential_id"]}),e.public_key||t.addIssue({code:s.z.ZodIssueCode.custom,message:`public_key is required when type is '${e.type}'`,path:["public_key"]}))}const Xj=oT.superRefine(sT),eO=s.z.object({...oT.shape,id:s.z.string(),created_at:s.z.string(),updated_at:s.z.string()}).superRefine(sT);function tO(e){const[t,n]=e.split("|");if(!t||!n)throw new Error(`Invalid user_id: ${e}`);return{connection:t,id:n}}function nO(e){const{primary:t,secondaries:n,syncMethods:i=["create","rawCreate","update","remove","delete","set"]}=e,r={get(o,a){if(typeof a=="symbol")return o[a];const c=o[a];return typeof c!="function"?c:i.includes(a)?async(...l)=>{const d=await c.apply(o,l),u=[];for(const p of n){const f=p.adapter[a];if(typeof f!="function")continue;const h=(async()=>{try{await f.apply(p.adapter,l)}catch(g){try{p.onError?p.onError(g,a,l):console.error(`Passthrough adapter: secondary write failed for ${a}:`,g)}catch(m){console.error(`Passthrough adapter: onError handler threw for ${a}:`,m)}}})();p.blocking&&u.push(h)}return u.length>0&&await Promise.all(u),d}:c.bind(o)}};return new Proxy(t,r)}function iO(e){return e}function vs(e){var t,n,i,r,o,a,c,l,d,u,p,f;const h=e?.options;if(!h)return{usernameIdentifierActive:!1,emailIdentifierActive:!0,usernameMinLength:1,usernameMaxLength:15};const g=h.attributes;if(g){const m=((n=(t=g.username)==null?void 0:t.identifier)==null?void 0:n.active)===!0,_=((r=(i=g.email)==null?void 0:i.identifier)==null?void 0:r.active)!==!1,w=((a=(o=g.username)==null?void 0:o.validation)==null?void 0:a.min_length)??1,y=((l=(c=g.username)==null?void 0:c.validation)==null?void 0:l.max_length)??15;return{usernameIdentifierActive:m,emailIdentifierActive:_,usernameMinLength:w,usernameMaxLength:y}}return{usernameIdentifierActive:h.requires_username===!0,emailIdentifierActive:!0,usernameMinLength:((u=(d=h.validation)==null?void 0:d.username)==null?void 0:u.min)??1,usernameMaxLength:((f=(p=h.validation)==null?void 0:p.username)==null?void 0:f.max)??15}}function qp(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}var rO={deno:"Deno",bun:"Bun",workerd:"Cloudflare-Workers",node:"Node.js"},hb=()=>{const e=globalThis;if(typeof navigator<"u"&&typeof navigator.userAgent=="string"){for(const[n,i]of Object.entries(rO))if(oO(i))return n}return typeof e?.EdgeRuntime=="string"?"edge-light":e?.fastly!==void 0?"fastly":e?.process?.release?.name==="node"?"node":"other"},oO=e=>navigator.userAgent.startsWith(e);function kh(e,t){if(hb()==="workerd")try{e.executionCtx.waitUntil(t);return}catch{}const n=t.then(()=>{},r=>{console.error("waitUntil promise error:",r)});let i;try{i=e.var?.backgroundPromises}catch{i=void 0}if(!Array.isArray(i)){if(typeof e.set!="function")return;i=[],e.set("backgroundPromises",i)}i.push(n)}async function sO(e){const t=e.var.backgroundPromises;if(!Array.isArray(t)||t.length===0)return;const n=t.splice(0,t.length);await Promise.all(n)}function aO(e){return[...e].reduce((t,[n,i])=>({...t,[n]:i}),{})}const cO=new Set(["password","password_hash","client_secret","signing_keys","credentials","encryption_key","otp_secret"]);function ky(e){if(!e)return;const t={};for(const[n,i]of Object.entries(e))cO.has(n)?t[n]="[REDACTED]":t[n]=i;return t}function aT(e){return e&&typeof e=="object"&&!Array.isArray(e)?ky(e):e}function lO(e,t){if(!e||!t)return;const n={},i=new Set([...Object.keys(e),...Object.keys(t)]);for(const r of i){const o=e[r],a=t[r];JSON.stringify(o)!==JSON.stringify(a)&&(n[r]={old:o,new:a})}return Object.keys(n).length>0?n:void 0}function dO(e,t){return e.var.user_id||t.actorUserId?"admin_action":t.userId?"user_action":e.var.client_id?"api":"system"}function cT(e,t,n){const i=e.env.outbox?.captureEntityState!==!1,r=i?ky(n.beforeState):void 0,o=i?ky(n.afterState):void 0;return{tenant_id:t,event_type:n.targetType?`${n.targetType}.${uO(e.req.method)}`:n.type,log_type:n.type,description:n.description,category:dO(e,n),actor:{type:e.var.user_id||n.actorUserId?"admin":n.userId?"user":e.var.client_id?"client_credentials":"system",id:e.var.user_id||n.actorUserId||n.userId||void 0,email:e.var.username||void 0,org_id:e.var.organization_id||e.var.user?.org_id||void 0,org_name:e.var.org_name||e.var.user?.org_name||void 0,scopes:e.var.user?.scope?e.var.user.scope.split(" "):void 0,client_id:e.var.client_id||void 0},target:{type:n.targetType||"unknown",id:n.targetId||n.userId||e.var.user_id||"",before:r,after:o,diff:lO(r,o)},request:{method:e.req.method,path:e.req.path,query:e.req.queries()?Object.fromEntries(Object.entries(e.req.queries()).map(([a,c])=>[a,Array.isArray(c)?c.join(","):c])):void 0,body:aT(n.body||e.var.body||void 0),ip:e.var.ip||"",user_agent:e.var.useragent||void 0},response:n.response?{status_code:n.response.statusCode,body:n.response.body}:void 0,connection:n.connection||e.var.connection||void 0,strategy:n.strategy||void 0,strategy_type:n.strategy_type||void 0,audience:n.audience||void 0,scope:n.scope||void 0,hostname:e.var.host||"",is_mobile:!1,auth0_client:e.var.auth0_client,timestamp:new Date().toISOString()}}function uO(e){switch(e){case"POST":return"created";case"PATCH":case"PUT":return"updated";case"DELETE":return"deleted";default:return"accessed"}}async function B(e,t,n){const i={};if(e.req.raw?.headers){const o=aO(e.req.raw.headers);for(const[a,c]of Object.entries(o))i[a.toLowerCase()]=c}if(e.env.outbox?.enabled&&e.env.data.outbox){const o=cT(e,t,n),a=e.env.data.outbox.create(t,o),c=e.var.outboxEventPromises||[];c.push(a),e.set("outboxEventPromises",c);return}const r=async()=>{let o;if(e.env.data.geo)try{o=await e.env.data.geo.getGeoInfo(i)||void 0}catch(c){console.warn("Failed to get geo information:",c)}const a={type:n.type,description:n.description||"",ip:e.var.ip,user_agent:e.var.useragent||"",auth0_client:e.var.auth0_client,date:new Date().toISOString(),details:n.details||{request:{method:e.req.method,path:e.req.path,qs:e.req.queries(),body:aT(n.body||e.var.body||"")},...n.response&&{response:n.response}},isMobile:!1,client_id:e.var.client_id,client_name:"",user_id:n.userId||e.var.user_id||"",hostname:e.var.host||"",user_name:e.var.username||"",connection_id:"",connection:n.connection||e.var.connection||"",strategy:n.strategy||"",strategy_type:n.strategy_type||"",audience:n.audience||"",scope:n.scope||"",location_info:o};await e.env.data.logs.create(t,a)};n.waitForCompletion?await r():kh(e,r())}async function lT(e,t,n,i){if(!e.env.outbox?.enabled||!t.outbox)return;const r=cT(e,n,i);return t.outbox.create(n,r)}const dt=s.z.object({page:s.z.string().min(0).optional().default("0").transform(e=>parseInt(e,10)).openapi({description:"Page index of the results to return. First page is 0."}),per_page:s.z.string().min(1).optional().default("10").transform(e=>parseInt(e,10)).openapi({description:"Number of results per page. Defaults to 50."}),include_totals:s.z.string().optional().default("false").transform(e=>e==="true").openapi({description:"Return results inside an object that contains the total result count (true) or as a direct array of results (false, default)."}),from:s.z.string().optional().openapi({description:"Optional Id from which to start selection."}),take:s.z.string().optional().transform(e=>e?parseInt(e,10):void 0).openapi({description:"Number of results per page. Defaults to 50."}),sort:s.z.string().regex(/^.+:(-1|1)$/).optional().openapi({description:"Field to sort by. Use field:order where order is 1 for ascending and -1 for descending. e.g. created_at:1."}),q:s.z.string().optional().openapi({description:"A lucene query string used to filter the results"})});function St(e){if(!e)return;const[t,n]=e.split(":"),i=n==="1"?"asc":"desc";if(!(!t||!i))return{sort_by:t,sort_order:i}}const pO=xt.extend({actions:s.z.array(nr)}),fO={"post-login":"post-user-login"};function hO(e){return fO[e]||e}const gO=s.z.object({versions:s.z.array(yh)}),mO=xt.extend({versions:s.z.array(yh)});function xu(e,t,n,i){return e.actionVersions.create(t,{action_id:n.id,code:n.code,runtime:n.runtime,secrets:n.secrets,dependencies:n.dependencies,supported_triggers:n.supported_triggers,deployed:i})}const yO=new s.OpenAPIHono().openapi(s.createRoute({tags:["actions"],method:"get",path:"/",request:{query:dt,headers:s.z.object({"tenant-id":s.z.string().optional()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:s.z.union([s.z.array(nr),pO])}},description:"List of actions"}}}),async e=>{const{page:t,per_page:n,include_totals:i,sort:r,q:o}=e.req.valid("query"),a=await e.env.data.actions.list(e.var.tenant_id,{page:t,per_page:n,include_totals:i,sort:St(r),q:o}),c=a.actions.map(l=>({...l,secrets:l.secrets?.map(d=>({name:d.name}))}));return i?e.json({...a,actions:c}):e.json(c)}).openapi(s.createRoute({tags:["actions"],method:"post",path:"/",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),body:{content:{"application/json":{schema:ql}}}},security:[{Bearer:["create:actions","auth:write"]}],responses:{201:{content:{"application/json":{schema:nr}},description:"The created action"}}}),async e=>{const t=e.req.valid("json"),n=await e.env.data.actions.create(e.var.tenant_id,t);let i=!1;if(e.env.codeExecutor?.deploy)try{await e.env.codeExecutor.deploy(n.id,t.code),i=!0}catch(r){await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to deploy action ${n.id}: ${r instanceof Error?r.message:String(r)}`})}else i=!0;return await xu(e.env.data,e.var.tenant_id,n,i),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Create action",targetType:"action",targetId:n.id}),e.json(n,{status:201})}).openapi(s.createRoute({tags:["actions"],method:"get",path:"/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:nr}},description:"An action"},404:{description:"Action not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=await e.env.data.actions.get(e.var.tenant_id,t);if(!n)throw new z(404,{message:"Action not found"});return e.json({...n,secrets:n.secrets?.map(i=>({name:i.name}))})}).openapi(s.createRoute({tags:["actions"],method:"patch",path:"/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()}),body:{content:{"application/json":{schema:ql.partial()}}}},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:nr}},description:"The updated action"},404:{description:"Action not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=e.req.valid("json");if(!await e.env.data.actions.update(e.var.tenant_id,t,n))throw new z(404,{message:"Action not found"});const r=await e.env.data.actions.get(e.var.tenant_id,t);if(!r)throw new z(404,{message:"Action not found"});if(n.code!==void 0&&e.env.codeExecutor?.deploy){let o=!1;try{await e.env.codeExecutor.deploy(t,n.code),o=!0}catch(a){await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to deploy action ${t}: ${a instanceof Error?a.message:String(a)}`})}await xu(e.env.data,e.var.tenant_id,r,o)}return await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Update action",targetType:"action",targetId:t}),e.json({...r,secrets:r.secrets?.map(o=>({name:o.name}))})}).openapi(s.createRoute({tags:["actions"],method:"delete",path:"/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["delete:actions","auth:write"]}],responses:{200:{description:"Action deleted"},404:{description:"Action not found"},409:{description:"Action is bound to a trigger and cannot be deleted"}}}),async e=>{const{id:t}=e.req.valid("param");if((await e.env.data.hooks.list(e.var.tenant_id,{q:`code_id:"${t}"`})).hooks.length>0)throw new z(409,{message:"Action is bound to a trigger. Remove the binding before deleting."});if(!await e.env.data.actions.remove(e.var.tenant_id,t))throw new z(404,{message:"Action not found"});if(await e.env.data.actionVersions.removeForAction(e.var.tenant_id,t),e.env.codeExecutor?.remove)try{await e.env.codeExecutor.remove(t)}catch(r){await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to remove action worker ${t}: ${r instanceof Error?r.message:String(r)}`})}return await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Delete action",targetType:"action",targetId:t}),e.text("OK")}).openapi(s.createRoute({tags:["actions"],method:"post",path:"/{id}/deploy",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:nr}},description:"The deployed action"},404:{description:"Action not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=await e.env.data.actions.get(e.var.tenant_id,t);if(!n)throw new z(404,{message:"Action not found"});if(e.env.codeExecutor?.deploy)try{await e.env.codeExecutor.deploy(t,n.code)}catch(i){throw await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to deploy action ${t}: ${i instanceof Error?i.message:String(i)}`}),new z(500,{message:`Deployment failed: ${i instanceof Error?i.message:String(i)}`})}return await e.env.data.actions.update(e.var.tenant_id,t,{status:"built",deployed_at:new Date().toISOString()}),await xu(e.env.data,e.var.tenant_id,n,!0),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Deploy action",targetType:"action",targetId:t}),e.json({...n,status:"built",secrets:n.secrets?.map(i=>({name:i.name}))})}).openapi(s.createRoute({tags:["actions"],method:"get",path:"/{actionId}/versions",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({actionId:s.z.string()}),query:dt},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:s.z.union([gO,mO])}},description:"List of action versions"},404:{description:"Action not found"}}}),async e=>{const{actionId:t}=e.req.valid("param"),{page:n,per_page:i,include_totals:r,sort:o}=e.req.valid("query");if(!await e.env.data.actions.get(e.var.tenant_id,t))throw new z(404,{message:"Action not found"});const c=await e.env.data.actionVersions.list(e.var.tenant_id,t,{page:n,per_page:i,include_totals:r,sort:St(o)}),l=c.versions.map(d=>({...d,secrets:d.secrets?.map(u=>({name:u.name}))}));return r?e.json({...c,versions:l}):e.json({versions:l})}).openapi(s.createRoute({tags:["actions"],method:"get",path:"/{actionId}/versions/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({actionId:s.z.string(),id:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:yh}},description:"Action version"},404:{description:"Action version not found"}}}),async e=>{const{actionId:t,id:n}=e.req.valid("param"),i=await e.env.data.actionVersions.get(e.var.tenant_id,t,n);if(!i)throw new z(404,{message:"Action version not found"});return e.json({...i,secrets:i.secrets?.map(r=>({name:r.name}))})}).openapi(s.createRoute({tags:["actions"],method:"post",path:"/{actionId}/versions/{id}/deploy",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({actionId:s.z.string(),id:s.z.string()})},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:nr}},description:"The action after rollback"},404:{description:"Action version not found"}}}),async e=>{const{actionId:t,id:n}=e.req.valid("param"),i=await e.env.data.actionVersions.get(e.var.tenant_id,t,n);if(!i)throw new z(404,{message:"Action version not found"});if(e.env.codeExecutor?.deploy)try{await e.env.codeExecutor.deploy(t,i.code)}catch(o){throw await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to roll back action ${t} to version ${n}: ${o instanceof Error?o.message:String(o)}`}),new z(500,{message:`Rollback failed: ${o instanceof Error?o.message:String(o)}`})}await e.env.data.actions.update(e.var.tenant_id,t,{code:i.code,runtime:i.runtime,secrets:i.secrets,dependencies:i.dependencies,supported_triggers:i.supported_triggers,status:"built",deployed_at:new Date().toISOString()});const r=await e.env.data.actions.get(e.var.tenant_id,t);if(!r)throw new z(404,{message:"Action not found"});return await xu(e.env.data,e.var.tenant_id,r,!0),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:`Roll back action to version ${i.number}`,targetType:"action",targetId:t}),e.json({...r,secrets:r.secrets?.map(o=>({name:o.name}))})}).openapi(s.createRoute({tags:["actions"],method:"post",path:"/{id}/test",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()}),body:{content:{"application/json":{schema:s.z.object({trigger_id:s.z.string().optional(),event:s.z.record(s.z.unknown()).optional()})}}}},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:s.z.object({success:s.z.boolean(),error:s.z.string().optional(),duration_ms:s.z.number(),api_calls:s.z.array(s.z.object({method:s.z.string(),args:s.z.array(s.z.unknown())})),logs:s.z.array(s.z.object({level:s.z.enum(["log","info","warn","error","debug"]),message:s.z.string()}))})}},description:"Test run result"},404:{description:"Action not found"},503:{description:"Code executor not configured"}}}),async e=>{const{id:t}=e.req.valid("param"),n=e.req.valid("json"),i=e.env.codeExecutor;if(!i)throw new z(503,{message:"Code executor not configured"});const r=await e.env.data.actions.get(e.var.tenant_id,t);if(!r)throw new z(404,{message:"Action not found"});const o=n.trigger_id??r.supported_triggers?.[0]?.id??"post-login",a=hO(o),c=r.secrets?.reduce((d,u)=>(u.value!==void 0&&(d[u.name]=u.value),d),{}),l=await i.execute({code:r.code,hookCodeId:r.id,triggerId:a,event:{...n.event??{},secrets:c??{}},timeoutMs:5e3});return e.json({success:l.success,error:l.error,duration_ms:l.durationMs,api_calls:l.apiCalls,logs:l.logs??[]})}),_O=s.z.object({id:s.z.string(),trigger_id:s.z.string(),status:Kw,results:s.z.array(Gw),created_at:s.z.string(),updated_at:s.z.string()}),wO=s.z.object({logs:Ww}),bO=new s.OpenAPIHono().openapi(s.createRoute({tags:["actions"],method:"get",path:"/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:_O}},description:"Action execution"},404:{description:"Execution not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=await e.env.data.actionExecutions.get(e.var.tenant_id,t);if(!n)throw new z(404,{message:"Execution not found"});return e.json({id:n.id,trigger_id:n.trigger_id,status:n.status,results:n.results,created_at:n.created_at,updated_at:n.updated_at})}).openapi(s.createRoute({tags:["actions"],method:"get",path:"/{id}/logs",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:wO}},description:"Captured console output for the execution"},404:{description:"Execution not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=await e.env.data.actionExecutions.get(e.var.tenant_id,t);if(!n)throw new z(404,{message:"Execution not found"});return e.json({logs:n.logs??[]})});let vO="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict",AO=e=>crypto.getRandomValues(new Uint8Array(e)),kO=(e,t,n)=>{let i=256-256%e.length;if(i===256){let o=e.length-1;return(a=t)=>{if(!a)return"";let c="";for(;;){let l=n(a),d=a;for(;d--;)if(c+=e[l[d]&o],c.length>=a)return c}}}let r=Math.ceil(1.6*256*t/i);return(o=t)=>{if(!o)return"";let a="";for(;;){let c=n(r),l=r;for(;l--;)if(c[l]<i&&(a+=e[c[l]%e.length],a.length>=o))return a}}},dT=(e,t=21)=>kO(e,t|0,AO),Le=(e=21)=>{let t="",n=crypto.getRandomValues(new Uint8Array(e|=0));for(;e--;)t+=vO[n[e]&63];return t};const SO=17,EO={organization:"org_",connection:"con_",action:"act_",hook:"h_",rule:"rul_",resource_server:"api_",guardian_factor:"gfa_",invite:"inv_",flow:"af_"};function Sh(e){const i=dT("0123456789abcdefghijklmnopqrstuvwxyz",SO)();return`${EO[e]}${i}`}function xO(){return Sh("organization")}function CO(){return Sh("connection")}function uT(){return Sh("hook")}function TO(){return Sh("invite")}const pT={"post-login":"post-user-login","credentials-exchange":"credentials-exchange","pre-user-registration":"pre-user-registration","post-user-registration":"post-user-registration"},$O=Object.fromEntries(Object.entries(pT).map(([e,t])=>[t,e]));function l2(e){return pT[e]||e}function d2(e){return $O[e]||e}const IO=s.z.object({type:s.z.enum(["action_id","action_name"]).optional(),value:s.z.string().optional(),id:s.z.string().optional(),name:s.z.string().optional()}),zO=s.z.object({ref:IO,display_name:s.z.string().optional()}),PO=s.z.object({id:s.z.string(),trigger_id:s.z.string(),display_name:s.z.string(),action:nr,created_at:s.z.string(),updated_at:s.z.string()}),u2=s.z.object({bindings:s.z.array(PO)}),NO=new s.OpenAPIHono().openapi(s.createRoute({tags:["actions"],method:"get",path:"/{triggerId}/bindings",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({triggerId:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:u2}},description:"Trigger bindings"}}}),async e=>{const{triggerId:t}=e.req.valid("param"),n=l2(t),r=(await e.env.data.hooks.list(e.var.tenant_id,{q:`trigger_id:"${n}"`,per_page:100})).hooks.filter(a=>"code_id"in a&&a.code_id).sort((a,c)=>(c.priority||0)-(a.priority||0)),o=[];for(const a of r){const c=a.code_id,l=await e.env.data.actions.get(e.var.tenant_id,c);l&&o.push({id:a.hook_id,trigger_id:d2(a.trigger_id),display_name:l.name,action:{...l,secrets:l.secrets?.map(d=>({name:d.name}))},created_at:a.created_at,updated_at:a.updated_at})}return e.json({bindings:o})}).openapi(s.createRoute({tags:["actions"],method:"patch",path:"/{triggerId}/bindings",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({triggerId:s.z.string()}),body:{content:{"application/json":{schema:s.z.object({bindings:s.z.array(zO)})}}}},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:u2}},description:"Updated trigger bindings"}}}),async e=>{const{triggerId:t}=e.req.valid("param"),{bindings:n}=e.req.valid("json"),i=l2(t),r=await e.env.data.hooks.list(e.var.tenant_id,{q:`trigger_id:"${i}"`,per_page:100});for(const a of r.hooks)"code_id"in a&&a.code_id&&await e.env.data.hooks.remove(e.var.tenant_id,a.hook_id);const o=[];for(let a=0;a<n.length;a++){const c=n[a];let l=c.ref.id;if(!l&&c.ref.type==="action_id"&&c.ref.value)l=c.ref.value;else if(!l&&c.ref.type==="action_name"&&c.ref.value){const p=c.ref.value,f=100;let h=0;for(;;){const g=await e.env.data.actions.list(e.var.tenant_id,{page:h,per_page:f,include_totals:!1}),m=g.actions.find(_=>_.name===p);if(m){l=m.id;break}if(g.actions.length<f)break;h++}}if(!l)throw new z(400,{message:`Binding at index ${a} must reference an action via ref.id or ref.value`});const d=await e.env.data.actions.get(e.var.tenant_id,l);if(!d)throw new z(404,{message:`Action ${l} not found`});const u=await e.env.data.hooks.create(e.var.tenant_id,{hook_id:uT(),trigger_id:i,code_id:l,enabled:!0,synchronous:!0,priority:n.length-a});o.push({id:u.hook_id,trigger_id:d2(u.trigger_id),display_name:c.display_name||d.name,action:{...d,secrets:d.secrets?.map(p=>({name:p.name}))},created_at:u.created_at,updated_at:u.updated_at})}return await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:`Update trigger bindings for ${t}`,targetType:"action"}),e.json({bindings:o})}),Kl={themeId:"default",borders:{button_border_radius:8,button_border_weight:1,buttons_style:"pill",input_border_radius:8,input_border_weight:1,inputs_style:"pill",show_widget_shadow:!0,widget_border_weight:1,widget_corner_radius:16},colors:{base_focus_color:"#7D68F4",base_hover_color:"#A091F2",body_text:"#000000",captcha_widget_theme:"auto",error:"#FC5A5A",header:"#000000",icons:"#666666",input_background:"#FFFFFF",input_border:"#8E8CA0",input_filled_text:"#000000",input_labels_placeholders:"#88869F",links_focused_components:"#7D68F4",primary_button:"#7D68F4",primary_button_label:"#FFFFFF",secondary_button_border:"#8E8CA0",secondary_button_label:"#000000",success:"#36BF76",widget_background:"#FFFFFF",widget_border:"#8E8CA0"},displayName:"Default Theme",fonts:{body_text:{bold:!1,size:100},buttons_text:{bold:!0,size:100},font_url:"https://assets.sesamy.com/fonts/khteka/WOFF2/KHTeka-Regular.woff2",input_labels:{bold:!1,size:100},links:{bold:!0,size:100},links_style:"normal",reference_text_size:16,subtitle:{bold:!1,size:100},title:{bold:!0,size:150}},page_background:{background_color:"#F8F9FB",background_image_url:"",page_layout:"center"},widget:{logo_url:"",header_text_alignment:"center",logo_height:36,logo_position:"center",social_buttons_layout:"bottom"}};function gb(e,t){const n=structuredClone(e);function i(r,o){for(const a in o)o[a]!==void 0&&typeof o[a]=="object"&&!Array.isArray(o[a])&&typeof r[a]=="object"&&r[a]!==null?i(r[a],o[a]):r[a]=o[a];return r}return i(n,t)}const jO=new s.OpenAPIHono().openapi(s.createRoute({tags:["branding"],method:"get",path:"/default",request:{headers:s.z.object({"tenant-id":s.z.string().optional()})},security:[{Bearer:["read:branding","auth:read"]}],responses:{200:{content:{"application/json":{schema:op}},description:"Default theme settings"}}}),async e=>{const t=await e.env.data.themes.get(e.var.tenant_id,"default");return t?e.json(t):e.json(Kl)}).openapi(s.createRoute({tags:["branding"],method:"patch",path:"/default",request:{body:{content:{"application/json":{schema:op.deepPartial()}}},headers:s.z.object({"tenant-id":s.z.string().optional()})},security:[{Bearer:["update:branding","auth:write"]}],responses:{200:{content:{"application/json":{schema:op}},description:"Updated theme settings"}}}),async e=>{const t=e.req.valid("json"),n=await e.env.data.themes.get(e.var.tenant_id,"default"),r=gb(n||Kl,t);return n?await e.env.data.themes.update(e.var.tenant_id,"default",r):await e.env.data.themes.create(e.var.tenant_id,r,"default"),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Update Theme",targetType:"theme",targetId:"default",...n?{beforeState:n}:{},afterState:r}),e.json({...r,themeId:"default"})}),p2={colors:{primary:"#7D68F4",page_background:{type:"solid",start:"#F8F9FB",end:"#F8F9FB",angle_deg:0}},logo_url:"https://assets.sesamy.com/static/images/sesamy/logos/sesamy_logo_black.svg",favicon_url:"https://assets.sesamy.com/images/favicon.ico",font:{url:"https://assets.sesamy.com/fonts/khteka/WOFF2/KHTeka-Regular.woff2"}};var OO={Stringify:1},Yr=(e,t)=>{const n=new String(e);return n.isEscaped=!0,n.callbacks=t,n},FO=/[&<>'"]/,RO=async(e,t)=>{let n="";t||=[];const i=await Promise.all(e);for(let r=i.length-1;n+=i[r],r--,!(r<0);r--){let o=i[r];typeof o=="object"&&t.push(...o.callbacks||[]);const a=o.isEscaped;if(o=await(typeof o=="object"?o.toString():o),typeof o=="object"&&t.push(...o.callbacks||[]),o.isEscaped??a)n+=o;else{const c=[n];wa(o,c),n=c[0]}}return Yr(n,t)},wa=(e,t)=>{const n=e.search(FO);if(n===-1){t[0]+=e;return}let i,r,o=0;for(r=n;r<e.length;r++){switch(e.charCodeAt(r)){case 34:i="&quot;";break;case 39:i="&#39;";break;case 38:i="&amp;";break;case 60:i="&lt;";break;case 62:i="&gt;";break;default:continue}t[0]+=e.substring(o,r)+i,o=r+1}t[0]+=e.substring(o,r)},DO=e=>{const t=e.callbacks;if(!t?.length)return e;const n=[e],i={};return t.forEach(r=>r({phase:OO.Stringify,buffer:n,context:i})),n[0]},mb=Symbol("RENDERER"),Sy=Symbol("ERROR_HANDLER"),ut=Symbol("STASH"),fT=Symbol("INTERNAL"),BO=Symbol("MEMO"),Hp=Symbol("PERMALINK"),f2=e=>(e[fT]=!0,e),hT=e=>({value:t,children:n})=>{if(!n)return;const i={children:[{tag:f2(()=>{e.push(t)}),props:{}}]};Array.isArray(n)?i.children.push(...n.flat()):i.children.push(n),i.children.push({tag:f2(()=>{e.pop()}),props:{}});const r={tag:"",props:i,type:""};return r[Sy]=o=>{throw e.pop(),o},r},gT=e=>{const t=[e],n=hT(t);return n.values=t,n.Provider=n,za.push(n),n},za=[],mT=e=>{const t=[e],n=(i=>{t.push(i.value);let r;try{r=i.children?(Array.isArray(i.children)?new AT("",{},i.children):i.children).toString():""}catch(o){throw t.pop(),o}return r instanceof Promise?r.finally(()=>t.pop()).then(o=>Yr(o,o.callbacks)):(t.pop(),Yr(r))});return n.values=t,n.Provider=n,n[mb]=hT(t),za.push(n),n},cc=e=>e.values.at(-1),Vp={title:[],script:["src"],style:["data-href"],link:["href"],meta:["name","httpEquiv","charset","itemProp"]},Ey={},jo="data-precedence",yT=e=>e.rel==="stylesheet"&&"precedence"in e,_T=(e,t)=>e==="link"?t:Vp[e].length>0,zd=e=>Array.isArray(e)?e:[e],h2=new WeakMap,g2=(e,t,n,i)=>({buffer:r,context:o})=>{if(!r)return;const a=h2.get(o)||{};h2.set(o,a);const c=a[e]||=[];let l=!1;const d=Vp[e],u=_T(e,i!==void 0);if(u){e:for(const[,p]of c)if(!(e==="link"&&!(p.rel==="stylesheet"&&p[jo]!==void 0))){for(const f of d)if((p?.[f]??null)===n?.[f]){l=!0;break e}}}if(l?r[0]=r[0].replaceAll(t,""):u||e==="link"?c.push([t,n,i]):c.unshift([t,n,i]),r[0].indexOf("</head>")!==-1){let p;if(e==="link"||i!==void 0){const f=[];p=c.map(([h,,g],m)=>{if(g===void 0)return[h,Number.MAX_SAFE_INTEGER,m];let _=f.indexOf(g);return _===-1&&(f.push(g),_=f.length-1),[h,_,m]}).sort((h,g)=>h[1]-g[1]||h[2]-g[2]).map(([h])=>h)}else p=c.map(([f])=>f);p.forEach(f=>{r[0]=r[0].replaceAll(f,"")}),r[0]=r[0].replace(/(?=<\/head>)/,p.join(""))}},Pd=(e,t,n)=>Yr(new li(e,n,zd(t??[])).toString()),Nd=(e,t,n,i)=>{if("itemProp"in n)return Pd(e,t,n);let{precedence:r,blocking:o,...a}=n;r=i?r??"":void 0,i&&(a[jo]=r);const c=new li(e,a,zd(t||[])).toString();return c instanceof Promise?c.then(l=>Yr(c,[...l.callbacks||[],g2(e,l,a,r)])):Yr(c,[g2(e,c,a,r)])},LO=({children:e,...t})=>{const n=yb();if(n){const i=cc(n);if(i==="svg"||i==="head")return new li("title",t,zd(e??[]))}return Nd("title",e,t,!1)},MO=({children:e,...t})=>{const n=yb();return["src","async"].some(i=>!t[i])||n&&cc(n)==="head"?Pd("script",e,t):Nd("script",e,t,!1)},UO=({children:e,...t})=>["href","precedence"].every(n=>n in t)?(t["data-href"]=t.href,delete t.href,Nd("style",e,t,!0)):Pd("style",e,t),qO=({children:e,...t})=>["onLoad","onError"].some(n=>n in t)||t.rel==="stylesheet"&&(!("precedence"in t)||"disabled"in t)?Pd("link",e,t):Nd("link",e,t,yT(t)),HO=({children:e,...t})=>{const n=yb();return n&&cc(n)==="head"?Pd("meta",e,t):Nd("meta",e,t,!1)},wT=(e,{children:t,...n})=>new li(e,n,zd(t??[])),VO=e=>(typeof e.action=="function"&&(e.action=Hp in e.action?e.action[Hp]:void 0),wT("form",e)),bT=(e,t)=>(typeof t.formAction=="function"&&(t.formAction=Hp in t.formAction?t.formAction[Hp]:void 0),wT(e,t)),KO=e=>bT("input",e),GO=e=>bT("button",e);const rm=Object.freeze(Object.defineProperty({__proto__:null,button:GO,form:VO,input:KO,link:qO,meta:HO,script:MO,style:UO,title:LO},Symbol.toStringTag,{value:"Module"}));var WO=new Map([["className","class"],["htmlFor","for"],["crossOrigin","crossorigin"],["httpEquiv","http-equiv"],["itemProp","itemprop"],["fetchPriority","fetchpriority"],["noModule","nomodule"],["formAction","formaction"]]),Kp=e=>WO.get(e)||e,JO=/[\s"'<>/=`\\\x00-\x1f\x7f-\x9f]/,om=new Set,m2=1024,YO=/^[!?]|[\s"'<>/=`\\\x00-\x1f\x7f-\x9f]/,y2=new Set,QO=256,Gl=(e,t,n)=>{e.size>=t&&e.clear(),e.add(n)},ZO=e=>y2.has(e)?!0:typeof e!="string"?!1:e.length===0?!0:YO.test(e)?!1:(Gl(y2,QO,e),!0),XO=e=>{if(om.has(e))return!0;const t=e.length;if(t===0)return!1;for(let n=0;n<t;n++){const i=e.charCodeAt(n);if(!(i>=97&&i<=122||i>=65&&i<=90||i>=48&&i<=57||i===45||i===95||i===46||i===58))return JO.test(e)?!1:(Gl(om,m2,e),!0)}return Gl(om,m2,e),!0},eF=/[\s"'():;\\/\[\]{}\x00-\x1f\x7f-\x9f]/,sm=new Set,_2=1024,tF=e=>{if(sm.has(e))return!0;const t=e.length;if(t===0)return!1;for(let n=0;n<t;n++){const i=e.charCodeAt(n);if(!(i>=97&&i<=122||i>=65&&i<=90||i>=48&&i<=57||i===45||i===95))return eF.test(e)?!1:(Gl(sm,_2,e),!0)}return Gl(sm,_2,e),!0},nF=/[;"'\\/\[\](){}]/,iF=e=>{if(!nF.test(e))return!1;let t=0;const n=[];for(let i=0,r=e.length;i<r;i++){const o=e.charCodeAt(i);if(o===92){if(i===r-1)return!0;i++}else if(t!==0){if(o===10||o===12||o===13)return!0;o===t&&(t=0)}else if(o===47&&e.charCodeAt(i+1)===42){const a=e.indexOf("*/",i+2);if(a===-1)return!0;i=a+1}else if(o===34||o===39)t=o;else if(o===40)n.push(41);else if(o===91)n.push(93);else{if(o===123||o===125)return!0;if(o===41||o===93){if(n[n.length-1]!==o)return!0;n.pop()}else if(o===59&&n.length===0)return!0}}return t!==0||n.length!==0},vT=(e,t)=>{for(const[n,i]of Object.entries(e)){const r=n[0]==="-"||!/[A-Z]/.test(n)?n:n.replace(/[A-Z]/g,a=>`-${a.toLowerCase()}`);if(!tF(r))continue;if(i==null){t(r,null);continue}let o;if(typeof i=="number")o=r.match(/^(?:a|border-im|column(?:-c|s)|flex(?:$|-[^b])|grid-(?:ar|[^a])|font-w|li|or|sca|st|ta|wido|z)|ty$/)?`${i}`:`${i}px`;else if(typeof i=="string"){if(iF(i))continue;o=i}else continue;t(r,o)}},Wl=void 0,yb=()=>Wl,rF=e=>/[A-Z]/.test(e)&&e.match(/^(?:al|basel|clip(?:Path|Rule)$|co|do|fill|fl|fo|gl|let|lig|i|marker[EMS]|o|pai|pointe|sh|st[or]|text[^L]|tr|u|ve|w)/)?e.replace(/([A-Z])/g,"-$1").toLowerCase():e,oF=["area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr"],sF=["allowfullscreen","async","autofocus","autoplay","checked","controls","default","defer","disabled","download","formnovalidate","hidden","inert","ismap","itemscope","loop","multiple","muted","nomodule","novalidate","open","playsinline","readonly","required","reversed","selected"],_b=(e,t)=>{for(let n=0,i=e.length;n<i;n++){const r=e[n];if(typeof r=="string")wa(r,t);else{if(typeof r=="boolean"||r===null||r===void 0)continue;r instanceof li?r.toStringToBuffer(t):typeof r=="number"||r.isEscaped?t[0]+=r:r instanceof Promise?t.unshift("",r):_b(r,t)}}},li=class{tag;props;key;children;isEscaped=!0;localContexts;constructor(e,t,n){if(typeof e!="function"&&!ZO(e))throw new Error(`Invalid JSX tag name: ${e}`);this.tag=e,this.props=t,this.children=n}get type(){return this.tag}get ref(){return this.props.ref||null}toString(){const e=[""];this.localContexts?.forEach(([t,n])=>{t.values.push(n)});try{this.toStringToBuffer(e)}finally{this.localContexts?.forEach(([t])=>{t.values.pop()})}return e.length===1?"callbacks"in e?DO(Yr(e[0],e.callbacks)).toString():e[0]:RO(e,e.callbacks)}toStringToBuffer(e){const t=this.tag,n=this.props;let{children:i}=this;e[0]+=`<${t}`;const r=t==="svg"||Wl&&cc(Wl)==="svg"?o=>rF(Kp(o)):o=>Kp(o);for(let[o,a]of Object.entries(n))if(o=r(o),!!XO(o)&&o!=="children"){if(o==="style"&&typeof a=="object"){let c="";vT(a,(l,d)=>{d!=null&&(c+=`${c?";":""}${l}:${d}`)}),e[0]+=' style="',wa(c,e),e[0]+='"'}else if(typeof a=="string")e[0]+=` ${o}="`,wa(a,e),e[0]+='"';else if(a!=null)if(typeof a=="number"||a.isEscaped)e[0]+=` ${o}="${a}"`;else if(typeof a=="boolean"&&sF.includes(o))a&&(e[0]+=` ${o}=""`);else if(o==="dangerouslySetInnerHTML"){if(i.length>0)throw new Error("Can only set one of `children` or `props.dangerouslySetInnerHTML`.");i=[Yr(a.__html)]}else if(a instanceof Promise)e[0]+=` ${o}="`,e.unshift('"',a);else if(typeof a=="function"){if(!o.startsWith("on")&&o!=="ref")throw new Error(`Invalid prop '${o}' of type 'function' supplied to '${t}'.`)}else e[0]+=` ${o}="`,wa(a.toString(),e),e[0]+='"'}if(oF.includes(t)&&i.length===0){e[0]+="/>";return}e[0]+=">",_b(i,e),e[0]+=`</${t}>`}},am=class extends li{toStringToBuffer(e){const{children:t}=this,n={...this.props};t.length&&(n.children=t.length===1?t[0]:t);const i=this.tag.call(null,n);if(!(typeof i=="boolean"||i==null))if(i instanceof Promise)if(za.length===0)e.unshift("",i);else{const r=za.map(o=>[o,o.values.at(-1)]);e.unshift("",i.then(o=>(o instanceof li&&(o.localContexts=r),o)))}else i instanceof li?i.toStringToBuffer(e):typeof i=="number"||i.isEscaped?(e[0]+=i,i.callbacks&&(e.callbacks||=[],e.callbacks.push(...i.callbacks))):wa(i,e)}},AT=class extends li{toStringToBuffer(e){_b(this.children,e)}},aF=(e,t,...n)=>{t??={},n.length&&(t.children=n.length===1?n[0]:n);const i=t.key;delete t.key;const r=sp(e,t,n);return r.key=i,r},w2=!1,sp=(e,t,n)=>{if(!w2){for(const i in Ey)rm[i][mb]=Ey[i];w2=!0}return typeof e=="function"?new am(e,t,n):rm[e]?new am(rm[e],t,n):e==="svg"||e==="head"?(Wl||=mT(""),new li(e,t,[new am(Wl,{value:e},n)])):new li(e,t,n)},Pa=({children:e})=>new AT("",{children:e},Array.isArray(e)?e:e?[e]:[]),cF=(e,t,...n)=>{let i;if(n.length>0)i=n;else{const r=e.props.children;i=Array.isArray(r)?r:[r]}return aF(e.tag,{...e.props,...t},...i)};function S(e,t,n){let i;if(!t||!("children"in t))i=sp(e,t,[]);else{const r=t.children;i=Array.isArray(r)?sp(e,t,r):sp(e,t,[r])}return i.key=n,i}function Ie(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#x27;")}function lF(e){return e.replace(/\\/g,"\\\\").replace(/"/g,'\\"').replace(/'/g,"\\'").replace(/\(/g,"\\(").replace(/\)/g,"\\)").replace(/\n/g,"").replace(/\r/g,"").replace(/\t/g,"")}function gn(e){if(!e)return"";try{const t=new URL(e);return["http:","https:","data:"].includes(t.protocol)?Ie(e):""}catch{return e.startsWith("/")?Ie(e):""}}function hn(e){return e&&/^(#[0-9a-fA-F]{3,8}|rgba?\([^)]+\)|hsla?\([^)]+\)|[a-zA-Z]+)$/.test(e.trim())?e.trim():""}function dF(e){if(!e)return"#f5f5f5";if(typeof e=="string")return hn(e)||"#f5f5f5";const{type:t,start:n,end:i,angle_deg:r}=e;if(t==="linear-gradient"&&n&&i){const o=hn(n),a=hn(i);if(o&&a)return`linear-gradient(${typeof r=="number"?r:180}deg, ${o}, ${a})`}if(n){const o=hn(n);if(o)return o}return"#f5f5f5"}function kT(e,t){if(e?.background_image_url){const n=gn(e.background_image_url);if(n)return`${hn(e.background_color)||"#f5f5f5"} url("${lF(n)}") center / cover no-repeat`}if(e?.background_color){const n=hn(e.background_color);if(n)return n}return dF(t)}var uF=(e,t)=>{try{return t(e)}catch{return e.replace(/(?:%[0-9A-Fa-f]{2})+/g,n=>{try{return t(n)}catch{return n}})}},pF=decodeURIComponent,ST=/^[\w!#$%&'*.^`|~+-]+$/,fF=/^[ !#-:<-[\]-~]*$/,b2=e=>{let t=0,n=e.length;for(;t<n;){const i=e.charCodeAt(t);if(i!==32&&i!==9)break;t++}for(;n>t;){const i=e.charCodeAt(n-1);if(i!==32&&i!==9)break;n--}return t===0&&n===e.length?e:e.slice(t,n)},hF=(e,t)=>{if(e.indexOf(t)===-1)return{};const n=e.split(";"),i={};for(const r of n){const o=r.indexOf("=");if(o===-1)continue;const a=b2(r.substring(0,o));if(t!==a||!ST.test(a))continue;let c=b2(r.substring(o+1));if(c.startsWith('"')&&c.endsWith('"')&&(c=c.slice(1,-1)),fF.test(c)){i[a]=c.indexOf("%")!==-1?uF(c,pF):c;break}}return i},gF=(e,t,n={})=>{if(!ST.test(e))throw new Error("Invalid cookie name");let i=`${e}=${t}`;if(e.startsWith("__Secure-")&&!n.secure)throw new Error("__Secure- Cookie must have Secure attributes");if(e.startsWith("__Host-")){if(!n.secure)throw new Error("__Host- Cookie must have Secure attributes");if(n.path!=="/")throw new Error('__Host- Cookie must have Path attributes with "/"');if(n.domain)throw new Error("__Host- Cookie must not have Domain attributes")}for(const r of["domain","path"])if(n[r]&&/[;\r\n]/.test(n[r]))throw new Error(`${r} must not contain ";", "\\r", or "\\n"`);if(n&&typeof n.maxAge=="number"&&n.maxAge>=0){if(n.maxAge>3456e4)throw new Error("Cookies Max-Age SHOULD NOT be greater than 400 days (34560000 seconds) in duration.");i+=`; Max-Age=${n.maxAge|0}`}if(n.domain&&n.prefix!=="host"&&(i+=`; Domain=${n.domain}`),n.path&&(i+=`; Path=${n.path}`),n.expires){if(n.expires.getTime()-Date.now()>3456e7)throw new Error("Cookies Expires SHOULD NOT be greater than 400 days (34560000 seconds) in the future.");i+=`; Expires=${n.expires.toUTCString()}`}if(n.httpOnly&&(i+="; HttpOnly"),n.secure&&(i+="; Secure"),n.sameSite&&(i+=`; SameSite=${n.sameSite.charAt(0).toUpperCase()+n.sameSite.slice(1)}`),n.priority&&(i+=`; Priority=${n.priority.charAt(0).toUpperCase()+n.priority.slice(1)}`),n.partitioned){if(!n.secure)throw new Error("Partitioned Cookie must have Secure attributes");i+="; Partitioned"}return i},cm=(e,t,n)=>(t=encodeURIComponent(t),gF(e,t,n)),mF=(e,t,n)=>{const i=e.req.raw.headers.get("Cookie");{if(!i)return;let r=t;return hF(i,r)[r]}},yF=(e,t,n)=>{let i;return n?.prefix==="secure"?i=cm("__Secure-"+e,t,{path:"/",...n,secure:!0}):n?.prefix==="host"?i=cm("__Host-"+e,t,{...n,path:"/",secure:!0,domain:void 0}):i=cm(e,t,{path:"/",...n}),i},v2=(e,t,n,i)=>{const r=yF(t,n,i);e.header("Set-Cookie",r,{append:!0})};const Jl="mp6l9wpb",ET={common:{alertListTitle:"Upozornění",backText:"Vrátit se zpět",cancelText:"Zrušit",closeText:"Zavřít",contactSupportText:"Potřebujete pomoc?",continueText:"Pokračovat",copyrightText:"© ${currentYear} ${companyName}",errorText:"Něco se pokazilo. Zkuste to prosím znovu.",hidePasswordText:"Skrýt heslo",loadingText:"Načítání...",orText:"nebo",privacyPolicyText:"Zásady ochrany osobních údajů",showPasswordText:"Zobrazit heslo",termsOfServiceText:"Podmínky služby",termsShortText:"Podmínky",tryAgainText:"Zkusit znovu"}},xT={consent:{buttonText:"Přijmout",cancelButtonText:"Zamítnout",description:"${clientName} žádá o přístup k vašemu účtu",pageTitle:"Autorizace | ${clientName}",scopesTitle:"Tímto povolíte ${clientName}:",title:"Autorizovat ${clientName}"}},CT={invitation:{acceptButtonText:"Přijmout pozvánku",description:"${inviterName} vás pozval(a), abyste se připojili k ${organizationName} na ${clientName}",pageTitle:"Pozvánka | ${clientName}",title:"Byli jste pozváni"}},TT={login:{alertListTitle:"Upozornění",buttonText:"Pokračovat",description:"Přihlaste se k ${clientName}.",editEmailText:"Upravit",emailPlaceholder:"E-mailová adresa",enterACodeBtn:"Přihlásit se kódem",federatedConnectionButtonText:"Pokračovat s ${connectionName}",footerLinkText:"Zaregistrujte se",footerText:"Nemáte účet?",forgotPasswordText:"Zapomněli jste heslo?",hidePasswordText:"Skrýt heslo",invalidEmail:"Neplatný e-mail",invalidIdentifier:"Neplatný e-mail nebo uživatelské jméno",invitationDescription:"Přihlaste se pro přijetí pozvánky od ${inviterName} k připojení k ${companyName} na ${clientName}.",invitationTitle:"Byli jste pozváni!",logoAltText:"${companyName}","no-email":"Zadejte prosím e-mailovou adresu","no-password":"Heslo je povinné",pageTitle:"Přihlášení | ${clientName}",passwordLoginNotAvailable:"Přihlášení heslem není k dispozici",passwordPlaceholder:"Heslo",phonePlaceholder:"Telefonní číslo",separatorText:"nebo",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",showPasswordText:"Zobrazit heslo",signupActionLinkText:"${footerLinkText}",signupActionText:"${footerText}",title:"Vítejte",tooManyFailedLogins:"Příliš mnoho neúspěšných pokusů o přihlášení. Zkuste to prosím později.",unverifiedEmail:"Před přihlášením prosím ověřte svou e-mailovou adresu",userAccountDoesNotExist:"Uživatelský účet neexistuje",usernamePlaceholder:"Uživatelské jméno nebo e-mailová adresa",usernameTooLong:"Uživatelské jméno musí mít nejvýše ${max} znaků",usernameTooShort:"Uživatelské jméno musí mít alespoň ${min} znaků",wrongCredentials:"Nesprávné uživatelské jméno nebo heslo",passkeyButtonText:"Přihlásit se pomocí passkey"}},$T={mfa:{backupCodeText:"Použít záložní kód",description:"Zvolte metodu ověření",pageTitle:"Vícefaktorové ověření | ${clientName}",title:"Ověřte svou identitu"}},IT={"passkey-enrollment-nudge":{title:"Zabezpečte svůj účet pomocí passkey",description:"Passkey používají biometrii nebo PIN vašeho zařízení k rychlejšímu a bezpečnějšímu přihlášení.",enrollButtonText:"Nastavit passkey",snoozeButtonText:"Možná později",optOutLinkText:"Nezobrazovat znovu",pageTitle:"Nastavení Passkey | ${clientName}"},"passkey-enrollment":{title:"Vytvořte svůj passkey",description:"Postupujte podle pokynů prohlížeče a vytvořte passkey pro tento účet.",errorMessage:"Vytvoření passkey se nezdařilo. Zkuste to prosím znovu.",cancelLinkText:"Prozatím přeskočit",retryButtonText:"Zkusit znovu",enrollmentComplete:"Váš passkey byl úspěšně nastaven. Tuto stránku můžete zavřít.",pageTitle:"Vytvoření Passkey | ${clientName}"},"passkey-challenge":{title:"Přihlásit se pomocí passkey",description:"Postupujte podle pokynů prohlížeče k ověření vaší identity.",errorMessage:"Ověření pomocí passkey selhalo. Zkuste to prosím znovu.",cancelLinkText:"Zpět na přihlášení",retryButtonText:"Zkusit znovu",pageTitle:"Přihlášení pomocí passkey | ${clientName}"}},zT={organizations:{description:"Vyberte, ke které organizaci se chcete přihlásit",pageTitle:"Výběr organizace | ${clientName}",searchPlaceholder:"Hledat organizace",title:"Vyberte svou organizaci"}},PT={signup:{buttonText:"Pokračovat",confirmPasswordPlaceholder:"Potvrzení hesla",description:"Zaregistrujte se a pokračujte","email-already-exists":"Tento e-mail je již zaregistrován",emailPlaceholder:"E-mailová adresa",federatedConnectionButtonText:"Pokračovat s ${connectionName}",hidePasswordText:"Skrýt heslo","invalid-email-format":"Neplatný e-mail",loginActionLinkText:"Přihlásit se",loginActionText:"Už máte účet?","no-email":"Zadejte prosím e-mailovou adresu","no-password":"Heslo je povinné","no-username":"Uživatelské jméno je povinné",pageTitle:"Registrace | ${clientName}",passwordPlaceholder:"Heslo",passwordsDidntMatch:"Hesla se neshodují",phonePlaceholder:"Telefonní číslo",privacyPolicyLinkText:"Zásady ochrany osobních údajů",separatorText:"nebo",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",showPasswordText:"Zobrazit heslo",termsOfServiceLinkText:"Podmínky služby",termsText:"Registrací souhlasíte s našimi",title:"Vytvořte svůj účet","username-already-exists":"Toto uživatelské jméno je již obsazeno",usernamePlaceholder:"Uživatelské jméno",verifyEmailText:"Zkontrolujte prosím svůj e-mail pro ověření účtu"}},NT={status:{continueButtonText:"Pokračovat",errorTitle:"Chyba",pageTitle:"Stav | ${clientName}",successTitle:"Hotovo",title:"Stav"}},_F={common:ET,consent:xT,"device-flow":{"device-flow":{buttonText:"Pokračovat",codePlaceholder:"Zadejte kód",description:"Zadejte kód zobrazený na vašem zařízení","expired-code":"Platnost kódu vypršela","invalid-code":"Zadaný kód je neplatný",pageTitle:"Aktivace zařízení | ${clientName}",title:"Aktivujte své zařízení"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Přihlásit se",codeLabel:"Ověřovací kód",codePlaceholder:"Zadejte kód",defaultDescription:"Zadejte ověřovací kód zaslaný na váš e-mail",description:"Odeslali jsme kód na ${email}","invalid-code":"Neplatný kód",noCode:"Zadejte prosím ověřovací kód",pageTitle:"Zadejte kód | ${clientName}",resendText:"Opětovné odeslání kódu",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",title:"Zkontrolujte svůj e-mail",unexpectedError:"Došlo k neočekávané chybě"}},"email-verification":{"email-verification":{description:"Odeslali jsme e-mail na ${email}",pageTitle:"Ověření e-mailu | ${clientName}",resendText:"Opětovné odeslání kódu",successDescription:"Váš e-mail byl úspěšně ověřen.",successTitle:"E-mail ověřen",title:"Ověření e-mailu"}},invitation:CT,login:TT,"login-id":{"login-id":{alertListTitle:"Upozornění","auth0-users-validation":"Něco se pokazilo, zkuste to prosím později","authentication-failure":"Omlouváme se, při pokusu o přihlášení se něco pokazilo",buttonText:"Pokračovat","captcha-client-failure":"Nepodařilo se načíst bezpečnostní výzvu. Zkuste to prosím znovu. (Kód chyby: #{errorCode})","captcha-validation-failure":"Omlouváme se, při ověřování captcha došlo k chybě. Zkuste to prosím znovu.",captchaCodePlaceholder:"Zadejte kód zobrazený výše","custom-script-error-code":"Něco se pokazilo, zkuste to prosím později.",description:"Přihlaste se k ${clientName}.",editEmailText:"Upravit",emailPlaceholder:"E-mailová adresa",federatedConnectionButtonText:"Pokračovat s ${connectionName}",footerLinkText:"Zaregistrujte se",footerText:"Nemáte účet?",forgotPasswordText:"Zapomněli jste heslo?",hidePasswordText:"Skrýt heslo","invalid-captcha":"Vyřešte úlohu, abyste ověřili, že nejste robot.","invalid-code":"Neplatný kód","invalid-connection":"Neplatné připojení","invalid-email-format":"Neplatný e-mail","invalid-email-phone":"Zadejte platnou e-mailovou adresu nebo telefonní číslo. Telefonní čísla musí obsahovat předvolbu země.","invalid-email-phone-username":"Zadejte platnou e-mailovou adresu, telefonní číslo nebo uživatelské jméno. Telefonní čísla musí obsahovat předvolbu země.","invalid-email-username":"Zadejte platnou e-mailovou adresu nebo uživatelské jméno","invalid-expired-code":"Neplatný nebo vypršelý uživatelský kód","invalid-login-id":"Zadáno neplatné přihlašovací ID","invalid-phone-username":"Zadejte platné telefonní číslo nebo uživatelské jméno. Telefonní čísla musí obsahovat předvolbu země.","invalid-recaptcha":"Zaškrtněte políčko, abyste ověřili, že nejste robot.","invalid-username":"Uživatelské jméno může obsahovat pouze alfanumerické znaky nebo: '${characters}'. Uživatelské jméno musí mít ${min} až ${max} znaků.",invitationDescription:"Přihlaste se pro přijetí pozvánky od ${inviterName} k připojení k ${companyName} na ${clientName}.",invitationTitle:"Byli jste pozváni!","ip-blocked":"Zjistili jsme podezřelé přihlašovací chování a další pokusy budou blokovány. Kontaktujte prosím administrátora.",logoAltText:"${companyName}","no-db-connection":"Neplatné připojení","no-email":"Zadejte prosím e-mailovou adresu","no-email-phone":"Je vyžadována e-mailová adresa nebo telefonní číslo","no-email-phone-username":"Je vyžadováno telefonní číslo, uživatelské jméno nebo e-mailová adresa","no-email-username":"Je vyžadována e-mailová adresa nebo uživatelské jméno","no-password":"Heslo je povinné","no-phone":"Zadejte prosím telefonní číslo","no-phone-username":"Je vyžadováno telefonní číslo nebo uživatelské jméno","no-username":"Uživatelské jméno je povinné",pageTitle:"Přihlášení | ${clientName}","password-breached":"Zjistili jsme potenciální bezpečnostní problém s tímto účtem. Pro ochranu vašeho účtu jsme toto přihlášení zablokovali. Pro pokračování prosím resetujte své heslo.",passwordPlaceholder:"Heslo",phoneOrEmailPlaceholder:"E-mail nebo telefonní číslo",phoneOrUsernameOrEmailPlaceholder:"Telefon, uživatelské jméno nebo e-mail",phoneOrUsernamePlaceholder:"Telefonní číslo nebo uživatelské jméno",phonePlaceholder:"Telefonní číslo","same-user-login":"Příliš mnoho pokusů o přihlášení pro tohoto uživatele. Počkejte prosím a zkuste to znovu později.",selectCountryCode:"Vyberte předvolbu země, aktuálně nastaveno na ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"nebo",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",showPasswordText:"Zobrazit heslo",signupActionLinkText:"${footerLinkText}",signupActionText:"${footerText}",termsAndConditionsTemplate:'Pokračováním souhlasíte s našimi <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Podmínkami a pravidly</a>.',title:"Vítejte","user-blocked":"Váš účet byl zablokován po několika po sobě jdoucích neúspěšných pokusech o přihlášení.",userAccountDoesNotExist:"Uživatelský účet neexistuje",usernameOnlyPlaceholder:"Uživatelské jméno",usernameOrEmailPlaceholder:"Uživatelské jméno nebo e-mailová adresa",usernamePlaceholder:"Uživatelské jméno nebo e-mailová adresa",usernameTooLong:"Uživatelské jméno musí mít nejvýše ${max} znaků",usernameTooShort:"Uživatelské jméno musí mít alespoň ${min} znaků","wrong-credentials":"Nesprávné uživatelské jméno nebo heslo","wrong-email-credentials":"Nesprávný e-mail nebo heslo","wrong-email-phone-credentials":"Nesprávná e-mailová adresa, telefonní číslo nebo heslo. Telefonní čísla musí obsahovat předvolbu země.","wrong-email-phone-username-credentials":"Nesprávná e-mailová adresa, telefonní číslo, uživatelské jméno nebo heslo. Telefonní čísla musí obsahovat předvolbu země.","wrong-email-username-credentials":"Nesprávná e-mailová adresa, uživatelské jméno nebo heslo","wrong-phone-credentials":"Nesprávné telefonní číslo nebo heslo","wrong-phone-username-credentials":"Nesprávné telefonní číslo, uživatelské jméno nebo heslo. Telefonní čísla musí obsahovat předvolbu země.","wrong-username-credentials":"Nesprávné uživatelské jméno nebo heslo",passkeyButtonText:"Přihlásit se pomocí passkey"}},"login-password":{"login-password":{buttonText:"Přihlásit se",description:"Přihlaste se k ${clientName}",forgotPasswordText:"Zapomněli jste heslo?",hidePasswordText:"Skrýt heslo","no-password":"Heslo je povinné",pageTitle:"Přihlášení | ${clientName}","password-breached":"Zjistili jsme potenciální bezpečnostní problém s tímto účtem. Pro ochranu vašeho účtu jsme toto přihlášení zablokovali. Pro pokračování prosím resetujte své heslo.",passwordPlaceholder:"Heslo",showPasswordText:"Zobrazit heslo",signingInAs:"Přihlášení jako ${email}",title:"Zadejte heslo",unverifiedEmail:"Před přihlášením prosím ověřte svou e-mailovou adresu","user-blocked":"Váš účet byl zablokován po několika po sobě jdoucích neúspěšných pokusech o přihlášení.","wrong-credentials":"Nesprávné heslo"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-mailová adresa",authMethodEmailOrPhone:"e-mail nebo telefonní číslo",authMethodPhone:"telefonní číslo",description:"Přihlaste se pomocí ${authMethod}",emailOrPhonePlaceholder:"E-mailová adresa nebo telefonní číslo",emailPlaceholder:"E-mailová adresa",invalidEmail:"Zadejte prosím platnou e-mailovou adresu",invalidIdentifier:"Zadejte prosím platnou e-mailovou adresu nebo telefonní číslo",invalidPhone:"Zadejte prosím platné telefonní číslo s předvolbou země",noEmail:"Zadejte prosím svou e-mailovou adresu",noPhone:"Zadejte prosím své telefonní číslo",phonePlaceholder:"Telefonní číslo",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",title:"Přihlásit se kódem",userAccountDoesNotExist:"Uživatelský účet neexistuje"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Klikněte na odkaz ve svém e-mailu pro přihlášení",description:"Odeslali jsme odkaz na ${username}. Kliknutím na něj se přihlásíte.",resendText:"Odeslat odkaz znovu",spamText:"Nedostali jste e-mail? Zkontrolujte složku nevyžádané pošty.",title:"Zkontrolujte svůj e-mail"}},mfa:$T,"mfa-email":{"mfa-email":{buttonText:"Pokračovat",codePlaceholder:"Zadejte kód",description:"Odeslali jsme kód na ${email}","invalid-code":"Zadaný kód je neplatný",pageTitle:"Ověření e-mailem | ${clientName}",resendText:"Opětovné odeslání kódu",title:"Zkontrolujte svůj e-mail"}},"mfa-otp":{"mfa-otp":{buttonText:"Pokračovat",codePlaceholder:"Zadejte kód",description:"Zadejte šestimístný kód z vaší ověřovací aplikace","invalid-code":"Zadaný kód je neplatný",pageTitle:"Zadejte kód | ${clientName}",title:"Zadejte svůj kód"},"mfa-totp-enrollment":{title:"Nastavit ověřovací aplikaci",description:"Naskenujte QR kód níže pomocí ověřovací aplikace a poté zadejte šestimístný kód pro ověření",secretLabel:"Nebo zadejte tento kód ručně:",codePlaceholder:"Zadejte kód",continueButtonText:"Ověřit a aktivovat","invalid-code":"Zadaný kód je neplatný. Zkuste to prosím znovu.","transaction-not-found":"Platnost vaší registrace vypršela, budete muset začít znovu.",pageTitle:"Nastavení ověřovací aplikace | ${clientName}",unexpectedError:"Něco se pokazilo. Zkuste to prosím znovu.",enrollmentComplete:"Registrace MFA je dokončena. Tuto stránku můžete zavřít."},"mfa-totp-challenge":{title:"Ověřte svou identitu",description:"Zadejte šestimístný kód z vaší ověřovací aplikace",codePlaceholder:"Zadejte kód",continueButtonText:"Pokračovat","invalid-code":"Zadaný kód je neplatný","transaction-not-found":"Platnost vaší registrace vypršela, budete muset začít znovu.",unexpectedError:"Něco se pokazilo. Zkuste to prosím znovu.",pageTitle:"Ověření identity | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Použijte své telefonní číslo pro přihlášení | ${clientName}",title:"Ověřte svou identitu",description:"Odeslali jsme kód na ${phoneNumber}",continueButtonText:"Pokračovat",changePhoneText:"Zvolte jiné telefonní číslo.",smsButtonText:"Textová zpráva",voiceButtonText:"Hlasový hovor",chooseMessageTypeText:"Jak chcete kód přijmout?",pickAuthenticatorText:"Zkusit jinou metodu",logoAltText:"${companyName}",codePlaceholder:"Zadejte kód","send-sms-failed":"Při odesílání SMS došlo k problému","send-voice-failed":"Při uskutečnění hlasového hovoru došlo k problému","invalid-phone-format":"Telefonní číslo může obsahovat pouze číslice.","invalid-phone":"Zdá se, že vaše telefonní číslo není platné. Zkontrolujte a zkuste to znovu.","too-many-sms":"Překročili jste maximální počet telefonních zpráv za hodinu. Počkejte pár minut a zkuste to znovu.","too-many-voice":"Překročili jste maximální počet hlasových hovorů za hodinu. Počkejte pár minut a zkuste to znovu.","transaction-not-found":"Vaše registrační transakce vypršela, budete muset začít znovu.","no-phone":"Zadejte telefonní číslo",noCode:"Zadejte ověřovací kód",invalidCode:"Zadaný kód je neplatný. Zkuste to znovu.",unexpectedError:"Něco se pokazilo. Zkuste to znovu.",resendSuccess:"Odeslali jsme nový kód na váš telefon",enrollmentComplete:"Registrace MFA je dokončena. Tuto stránku můžete zavřít."},"mfa-phone-enrollment":{pageTitle:"Zadejte své telefonní číslo pro přihlášení pomocí telefonního kódu | ${clientName}",title:"Zabezpečte svůj účet",description:"Zadejte kód země a telefonní číslo, na které můžeme odeslat 6místný kód:",continueButtonText:"Pokračovat",smsButtonText:"Textová zpráva",voiceButtonText:"Hlasový hovor",chooseMessageTypeText:"Jak chcete kód přijmout?",pickAuthenticatorText:"Zkusit jinou metodu",placeholder:"Zadejte své telefonní číslo",logoAltText:"${companyName}",selectCountryCode:"Vyberte kód země, aktuálně nastaveno na ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Při odesílání SMS došlo k problému","send-voice-failed":"Při uskutečnění hlasového hovoru došlo k problému","sms-authenticator-error":"Nepodařilo se odeslat SMS. Zkuste to prosím později.","invalid-phone-format":"Telefonní číslo může obsahovat pouze číslice.","invalid-phone":"Zdá se, že vaše telefonní číslo není platné. Zkontrolujte a zkuste to znovu.","too-many-sms":"Překročili jste maximální počet telefonních zpráv za hodinu. Počkejte pár minut a zkuste to znovu.","too-many-voice":"Překročili jste maximální počet hlasových hovorů za hodinu. Počkejte pár minut a zkuste to znovu.","transaction-not-found":"Vaše registrační transakce vypršela, budete muset začít znovu.","no-phone":"Zadejte telefonní číslo","phone-is-too-short":"Telefonní číslo je příliš krátké","phone-is-too-long":"Telefonní číslo je příliš dlouhé"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Vyberte metodu ověření | ${clientName}",title:"Vyberte způsob ověření",description:"Zvolte, jak chcete ověřit svou identitu",authenticatorAppLabel:"Autentizační aplikace",authenticatorAppDescription:"Použijte autentizační aplikaci k získání ověřovacího kódu",smsLabel:"Textová zpráva",smsDescription:"Nechte si zaslat ověřovací kód na telefon",passkeyLabel:"Passkey",passkeyDescription:"Použijte biometrii zařízení nebo bezpečnostní klíč"}},"mfa-push":{"mfa-push":{description:"Odeslali jsme oznámení na vaše zařízení",pageTitle:"Push oznámení | ${clientName}",resendText:"Odeslat oznámení znovu",title:"Schvalte požadavek",useCodeText:"Zadat kód ručně"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Pokračovat",codePlaceholder:"Záložní kód",description:"Zadejte jeden z vašich záložních kódů","invalid-code":"Zadaný záložní kód je neplatný",pageTitle:"Záložní kód | ${clientName}",title:"Zadejte záložní kód"}},"mfa-voice":{"mfa-voice":{buttonText:"Zavolat mi",codePlaceholder:"Zadejte kód",description:"Zavoláme na ${phoneNumber} s vaším kódem","invalid-code":"Zadaný kód je neplatný",pageTitle:"Hlasový hovor | ${clientName}",title:"Přijmout telefonní hovor"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Zkusit znovu",description:"Vložte svůj bezpečnostní klíč a postupujte podle pokynů",pageTitle:"Bezpečnostní klíč | ${clientName}",title:"Použijte svůj bezpečnostní klíč"}},passkeys:IT,organizations:zT,"reset-password":{"reset-password":{backToLoginText:"Zpět na přihlášení",buttonText:"Pokračovat",codeExpired:"Platnost kódu pro obnovení hesla vypršela. Požádejte prosím o nový.",confirmPasswordLabel:"Potvrzení hesla",confirmPasswordPlaceholder:"Potvrzení hesla",description:"Zadejte svůj e-mail pro obnovení hesla",emailPlaceholder:"E-mailová adresa",failed:"Obnovení hesla se nezdařilo. Zkuste to prosím znovu.","invalid-email-format":"Neplatný e-mail","no-email":"Zadejte prosím e-mailovou adresu",pageTitle:"Obnovení hesla | ${clientName}",passwordLabel:"Nové heslo",passwordPlaceholder:"Nové heslo",passwordTooWeak:"Heslo je příliš slabé",passwordsDidntMatch:"Hesla se neshodují",successDescription:"Odkaz na obnovení hesla jsme odeslali na vaši e-mailovou adresu.",successTitle:"Zkontrolujte svůj e-mail",title:"Zapomněli jste heslo?","user-not-found":"Uživatel nenalezen"},"reset-password-code":{backToLoginText:"Zpět na přihlášení",buttonText:"Obnovit heslo",codeLabel:"Kód pro obnovení",codePlaceholder:"Zadejte 6místný kód",confirmPasswordLabel:"Potvrzení hesla",confirmPasswordPlaceholder:"Potvrzení hesla",defaultDescription:"Zadejte kód zaslaný na váš e-mail a zvolte nové heslo",description:"Odeslali jsme kód na ${email}",failed:"Obnovení hesla se nezdařilo. Zkuste to prosím znovu.",invalidCode:"Zadaný kód je neplatný nebo vypršel",noCode:"Zadejte prosím kód pro obnovení",pageTitle:"Zadejte kód pro obnovení | ${clientName}",passwordLabel:"Nové heslo",passwordPlaceholder:"Nové heslo",passwordTooWeak:"Heslo je příliš slabé",passwordsDidntMatch:"Hesla se neshodují",resendFailed:"Nepodařilo se znovu odeslat kód. Zkuste to prosím znovu.",resendSuccess:"Nový kód byl odeslán na váš e-mail",resendText:"Odeslat kód znovu",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",title:"Zadejte kód pro obnovení"}},signup:PT,"signup-id":{"signup-id":{buttonText:"Pokračovat",description:"Zaregistrujte se a pokračujte","email-already-exists":"Tento e-mail je již zaregistrován",emailPlaceholder:"E-mailová adresa",federatedConnectionButtonText:"Pokračovat s ${connectionName}","invalid-email-format":"Neplatný e-mail",loginActionLinkText:"Přihlásit se",loginActionText:"Už máte účet?","no-email":"Zadejte prosím e-mailovou adresu",pageTitle:"Registrace | ${clientName}",phonePlaceholder:"Telefonní číslo",separatorText:"nebo",title:"Vytvořte svůj účet",usernamePlaceholder:"Uživatelské jméno"}},"signup-password":{"signup-password":{buttonText:"Pokračovat",description:"Zaregistrujte se a pokračujte",hidePasswordText:"Skrýt heslo","no-password":"Heslo je povinné",pageTitle:"Registrace | ${clientName}","password-policy-not-met":"Heslo nesplňuje požadavky","password-too-weak":"Heslo je příliš slabé",passwordPlaceholder:"Heslo",showPasswordText:"Zobrazit heslo",title:"Vytvořte své heslo"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Pokračovat",codeLabel:"Ověřovací kód",codePlaceholder:"Zadejte kód",defaultDescription:"Zadejte ověřovací kód zaslaný na váš telefon",description:"Odeslali jsme kód na ${username}","invalid-code":"Neplatný kód",noCode:"Zadejte prosím ověřovací kód",pageTitle:"Zadejte kód | ${clientName}",resendText:"Opětovné odeslání kódu",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",title:"Zkontrolujte svůj telefon",unexpectedError:"Došlo k neočekávané chybě"}},status:NT},wF=Object.freeze(Object.defineProperty({__proto__:null,common:ET,consent:xT,default:_F,invitation:CT,login:TT,mfa:$T,organizations:zT,passkeys:IT,signup:PT,status:NT},Symbol.toStringTag,{value:"Module"})),jT={common:{alertListTitle:"Advarsler",backText:"Gå tilbage",cancelText:"Gå tilbage",closeText:"Luk",contactSupportText:"Har du brug for hjælp?",continueText:"Fortsæt",copyrightText:"© ${currentYear} ${companyName}",errorText:"Noget gik galt. Prøv venligst igen.",hidePasswordText:"Skjul adgangskode",loadingText:"Indlæser...",orText:"eller",privacyPolicyText:"Privatlivspolitik",showPasswordText:"Vis adgangskode",termsOfServiceText:"Servicevilkår",termsShortText:"Vilkår",tryAgainText:"Prøv igen"}},OT={consent:{buttonText:"Acceptér",cancelButtonText:"Afvis",description:"${clientName} anmoder om adgang til din konto",pageTitle:"Godkend | ${clientName}",scopesTitle:"Dette vil give ${clientName} tilladelse til at:",title:"Godkend ${clientName}"}},FT={invitation:{acceptButtonText:"Acceptér invitation",description:"${inviterName} har inviteret dig til at deltage i ${organizationName} på ${clientName}",pageTitle:"Invitation | ${clientName}",title:"Du er blevet inviteret"}},RT={login:{alertListTitle:"Advarsler",buttonText:"Fortsæt",description:"Log ind på ${clientName}.",editEmailText:"Rediger",emailPlaceholder:"E-mail-adresse",enterACodeBtn:"Log ind med en kode",federatedConnectionButtonText:"Fortsæt med ${connectionName}",footerLinkText:"Tilmeld dig",footerText:"Har du ikke en konto?",forgotPasswordText:"Har du glemt din adgangskode?",hidePasswordText:"Skjul adgangskode",invalidEmail:"Ugyldig e-mail",invalidIdentifier:"Ugyldig e-mail eller brugernavn",invitationDescription:"Log ind for at acceptere ${inviterName}s invitation til at deltage i ${companyName} på ${clientName}.",invitationTitle:"Du er blevet inviteret!",logoAltText:"${companyName}","no-email":"Indtast venligst en e-mailadresse","no-password":"Adgangskode er påkrævet",pageTitle:"Log ind | ${clientName}",passwordLoginNotAvailable:"Adgangskodegodkendelse er ikke tilgængelig",passwordPlaceholder:"Adgangskode",phonePlaceholder:"Telefonnummer",separatorText:"eller",sessionExpired:"Din session er udløbet. Prøv venligst igen.",showPasswordText:"Vis adgangskode",signupActionLinkText:"Tilmeld dig",signupActionText:"Har du ikke en konto?",title:"Velkommen",tooManyFailedLogins:"For mange mislykkede loginforsøg. Prøv venligst igen senere.",unverifiedEmail:"Bekræft venligst din e-mailadresse, før du logger ind",userAccountDoesNotExist:"Brugerkontoen findes ikke",usernamePlaceholder:"Brugernavn eller e-mailadresse",usernameTooLong:"Brugernavnet må højst være ${max} tegn",usernameTooShort:"Brugernavnet skal være mindst ${min} tegn",wrongCredentials:"Forkert brugernavn eller adgangskode",passkeyButtonText:"Log ind med passkey"}},DT={mfa:{backupCodeText:"Brug backupkode",description:"Vælg en bekræftelsesmetode",pageTitle:"Multifaktorgodkendelse | ${clientName}",title:"Bekræft din identitet"}},BT={"passkey-enrollment-nudge":{title:"Sikr din konto med en adgangsnøgle",description:"Adgangsnøgler bruger din enheds biometri eller PIN til at logge dig ind hurtigere og mere sikkert.",enrollButtonText:"Konfigurer adgangsnøgle",snoozeButtonText:"Måske senere",optOutLinkText:"Vis ikke dette igen",pageTitle:"Konfigurer Adgangsnøgle | ${clientName}"},"passkey-enrollment":{title:"Opret din adgangsnøgle",description:"Følg anvisningerne fra din browser for at oprette en adgangsnøgle til denne konto.",errorMessage:"Oprettelse af adgangsnøgle mislykkedes. Prøv venligst igen.",cancelLinkText:"Spring over for nu",retryButtonText:"Prøv igen",enrollmentComplete:"Din adgangsnøgle er konfigureret. Du kan lukke denne side.",pageTitle:"Opret Adgangsnøgle | ${clientName}"},"passkey-challenge":{title:"Log ind med passkey",description:"Følg anvisningerne fra din browser for at bekræfte din identitet.",errorMessage:"Godkendelse med passkey mislykkedes. Prøv venligst igen.",cancelLinkText:"Tilbage til login",retryButtonText:"Prøv igen",pageTitle:"Log ind med passkey | ${clientName}"}},LT={organizations:{description:"Vælg hvilken organisation du vil logge ind på",pageTitle:"Vælg organisation | ${clientName}",searchPlaceholder:"Søg organisationer",title:"Vælg din organisation"}},MT={signup:{buttonText:"Tilmelding",confirmPasswordPlaceholder:"Bekræft adgangskode",description:"Vælg en adgangskode med en blanding af store og små bogstaver, tal og symboler.","email-already-exists":"E-mailen er allerede optaget",emailPlaceholder:"E-mail-adresse",federatedConnectionButtonText:"Fortsæt med ${connectionName}",hidePasswordText:"Skjul adgangskode","invalid-email-format":"Ugyldig e-mail",loginActionLinkText:"Log ind",loginActionText:"Har du allerede en konto?","no-email":"Indtast venligst en e-mailadresse","no-password":"Adgangskode er påkrævet","no-username":"Brugernavn er påkrævet",pageTitle:"Tilmeld dig | ${clientName}",passwordPlaceholder:"Adgangskode",passwordsDidntMatch:"Adgangskoderne matcher ikke",phonePlaceholder:"Telefonnummer",privacyPolicyLinkText:"Privatlivspolitik",separatorText:"eller",sessionExpired:"Din session er udløbet. Prøv venligst igen.",showPasswordText:"Vis adgangskode",termsOfServiceLinkText:"Servicevilkår",termsText:"Ved at tilmelde dig accepterer du vores",title:"Vælg adgangskode","username-already-exists":"Dette brugernavn er allerede taget",usernamePlaceholder:"Brugernavn",verifyEmailText:"Tjek venligst din e-mail for at bekræfte din konto"}},UT={status:{continueButtonText:"Fortsæt",errorTitle:"Fejl",pageTitle:"Status | ${clientName}",successTitle:"Succes",title:"Status"}},bF={common:jT,consent:OT,"device-flow":{"device-flow":{buttonText:"Fortsæt",codePlaceholder:"Indtast kode",description:"Indtast koden, der vises på din enhed","expired-code":"Koden er udløbet","invalid-code":"Den indtastede kode er ugyldig",pageTitle:"Enhedsaktivering | ${clientName}",title:"Aktivér din enhed"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Log ind",codeLabel:"Bekræftelseskode",codePlaceholder:"Indtast kode",defaultDescription:"Indtast bekræftelseskoden, der blev sendt til din e-mail",description:"Vi sendte en kode til ${email}","invalid-code":"Ugyldig kode",noCode:"Indtast venligst bekræftelseskoden",pageTitle:"Indtast kode | ${clientName}",resendText:"Send koden igen",sessionExpired:"Din session er udløbet. Prøv venligst igen.",title:"Tjek din e-mail",unexpectedError:"Der opstod en uventet fejl"}},"email-verification":{"email-verification":{description:"Vi sendte en e-mail til ${email}",pageTitle:"Bekræft e-mail | ${clientName}",resendText:"Send koden igen",successDescription:"Din e-mail er blevet bekræftet.",successTitle:"E-mail bekræftet",title:"Bekræft din e-mail"}},invitation:FT,login:RT,"login-id":{"login-id":{alertListTitle:"Advarsler","auth0-users-validation":"Noget gik galt, prøv venligst igen senere","authentication-failure":"Vi beklager, noget gik galt under loginforsøget",buttonText:"Fortsæt","captcha-client-failure":"Vi kunne ikke indlæse sikkerhedsudfordringen. Prøv venligst igen. (Fejlkode: #{errorCode})","captcha-validation-failure":"Vi beklager, noget gik galt under validering af captcha-svaret. Prøv venligst igen.",captchaCodePlaceholder:"Indtast koden vist ovenfor","custom-script-error-code":"Noget gik galt, prøv venligst igen senere.",description:"Log ind på ${clientName}.",editEmailText:"Rediger",emailPlaceholder:"E-mail-adresse",federatedConnectionButtonText:"Fortsæt med ${connectionName}",footerLinkText:"Tilmeld dig",footerText:"Har du ikke en konto?",forgotPasswordText:"Har du glemt din adgangskode?",hidePasswordText:"Skjul adgangskode","invalid-captcha":"Løs sikkerhedsspørgsmålet for at bekræfte, at du ikke er en robot.","invalid-code":"Ugyldig kode","invalid-connection":"Ugyldig forbindelse","invalid-email-format":"Ugyldig e-mail","invalid-email-phone":"Indtast en gyldig e-mailadresse eller telefonnummer. Telefonnumre skal inkludere landekoden.","invalid-email-phone-username":"Indtast en gyldig e-mailadresse, telefonnummer eller brugernavn. Telefonnumre skal inkludere landekoden.","invalid-email-username":"Indtast en gyldig e-mailadresse eller brugernavn","invalid-expired-code":"Ugyldig eller udløbet brugerkode","invalid-login-id":"Ugyldigt login-ID indtastet","invalid-phone-username":"Indtast et gyldigt telefonnummer eller brugernavn. Telefonnumre skal inkludere landekoden.","invalid-recaptcha":"Markér afkrydsningsfeltet for at bekræfte, at du ikke er en robot.","invalid-username":"Brugernavnet kan kun indeholde alfanumeriske tegn eller: '${characters}'. Brugernavnet skal være mellem ${min} og ${max} tegn.",invitationDescription:"Log ind for at acceptere ${inviterName}s invitation til at deltage i ${companyName} på ${clientName}.",invitationTitle:"Du er blevet inviteret!","ip-blocked":"Vi har registreret mistænkelig loginadfærd, og yderligere forsøg vil blive blokeret. Kontakt venligst administratoren.",logoAltText:"${companyName}","no-db-connection":"Ugyldig forbindelse","no-email":"Indtast venligst en e-mailadresse","no-email-phone":"E-mailadresse eller telefonnummer er påkrævet","no-email-phone-username":"Telefonnummer, brugernavn eller e-mailadresse er påkrævet","no-email-username":"E-mailadresse eller brugernavn er påkrævet","no-password":"Adgangskode er påkrævet","no-phone":"Indtast venligst et telefonnummer","no-phone-username":"Telefonnummer eller brugernavn er påkrævet","no-username":"Brugernavn er påkrævet",pageTitle:"Log ind | ${clientName}","password-breached":"Vi har registreret et potentielt sikkerhedsproblem med denne konto. For at beskytte din konto har vi forhindret dette login. Nulstil venligst din adgangskode for at fortsætte.",passwordPlaceholder:"Adgangskode",phoneOrEmailPlaceholder:"E-mail eller telefonnummer",phoneOrUsernameOrEmailPlaceholder:"Telefon, brugernavn eller e-mail",phoneOrUsernamePlaceholder:"Telefonnummer eller brugernavn",phonePlaceholder:"Telefonnummer","same-user-login":"For mange loginforsøg for denne bruger. Vent venligst, og prøv igen senere.",selectCountryCode:"Vælg landekode, i øjeblikket sat til ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"eller",sessionExpired:"Din session er udløbet. Prøv venligst igen.",showPasswordText:"Vis adgangskode",signupActionLinkText:"Tilmeld dig",signupActionText:"Har du ikke en konto?",termsAndConditionsTemplate:'Ved at fortsætte accepterer du vores <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Vilkår og betingelser</a>.',title:"Velkommen","user-blocked":"Din konto er blevet blokeret efter flere på hinanden følgende loginforsøg.",userAccountDoesNotExist:"Brugerkontoen findes ikke",usernameOnlyPlaceholder:"Brugernavn",usernameOrEmailPlaceholder:"Brugernavn eller e-mailadresse",usernamePlaceholder:"Brugernavn",usernameTooLong:"Brugernavnet må højst være ${max} tegn",usernameTooShort:"Brugernavnet skal være mindst ${min} tegn","wrong-credentials":"Forkert brugernavn eller adgangskode","wrong-email-credentials":"Forkert e-mail eller adgangskode","wrong-email-phone-credentials":"Forkert e-mailadresse, telefonnummer eller adgangskode. Telefonnumre skal inkludere landekoden.","wrong-email-phone-username-credentials":"Forkert e-mailadresse, telefonnummer, brugernavn eller adgangskode. Telefonnumre skal inkludere landekoden.","wrong-email-username-credentials":"Forkert e-mailadresse, brugernavn eller adgangskode","wrong-phone-credentials":"Forkert telefonnummer eller adgangskode","wrong-phone-username-credentials":"Forkert telefonnummer, brugernavn eller adgangskode. Telefonnumre skal inkludere landekoden.","wrong-username-credentials":"Forkert brugernavn eller adgangskode",passkeyButtonText:"Log ind med passkey"}},"login-password":{"login-password":{buttonText:"Log ind",description:"Indtast din e-mailadresse og adgangskode for at logge ind.",forgotPasswordText:"Har du glemt din adgangskode?",hidePasswordText:"Skjul adgangskode","no-password":"Adgangskode er påkrævet",pageTitle:"Log ind | ${clientName}","password-breached":"Vi har registreret et potentielt sikkerhedsproblem med denne konto. For at beskytte din konto har vi forhindret dette login. Nulstil venligst din adgangskode for at fortsætte.",passwordPlaceholder:"Adgangskode",showPasswordText:"Vis adgangskode",signingInAs:"Logger ind som ${email}",title:"Indtast adgangskode",unverifiedEmail:"Bekræft venligst din e-mailadresse, før du logger ind","user-blocked":"Din konto er blevet blokeret efter flere på hinanden følgende loginforsøg.","wrong-credentials":"Forkert adgangskode"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-mail",authMethodEmailOrPhone:"e-mail eller telefonnummer",authMethodPhone:"telefonnummer",description:"Log ind med din ${authMethod}",emailOrPhonePlaceholder:"E-mailadresse eller telefonnummer",emailPlaceholder:"E-mail-adresse",invalidEmail:"Indtast venligst en gyldig e-mailadresse",invalidIdentifier:"Indtast venligst en gyldig e-mailadresse eller telefonnummer",invalidPhone:"Indtast venligst et gyldigt telefonnummer med landekode",noEmail:"Indtast venligst din e-mailadresse",noPhone:"Indtast venligst dit telefonnummer",phonePlaceholder:"Telefonnummer",sessionExpired:"Din session er udløbet. Prøv venligst igen.",title:"Log ind med en kode",userAccountDoesNotExist:"Brugerkontoen findes ikke"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Klik på linket i din e-mail for at logge ind",description:"Vi sendte et link til ${username}. Klik på det for at logge ind.",resendText:"Send link igen",spamText:"Har du ikke modtaget e-mailen? Tjek din spam-mappe.",title:"Tjek din e-mail"}},mfa:DT,"mfa-email":{"mfa-email":{buttonText:"Fortsæt",codePlaceholder:"Indtast kode",description:"Vi sendte en kode til ${email}","invalid-code":"Den indtastede kode er ugyldig",pageTitle:"E-mailbekræftelse | ${clientName}",resendText:"Send kode igen",title:"Tjek din e-mail"}},"mfa-otp":{"mfa-otp":{buttonText:"Fortsæt",codePlaceholder:"Indtast kode",description:"Indtast den 6-cifrede kode fra din autentificeringsapp","invalid-code":"Den indtastede kode er ugyldig",pageTitle:"Indtast kode | ${clientName}",title:"Indtast din kode"},"mfa-totp-enrollment":{title:"Opsæt autentificeringsapp",description:"Scan QR-koden nedenfor med din autentificeringsapp, og indtast derefter den 6-cifrede kode for at bekræfte",secretLabel:"Eller indtast denne kode manuelt:",codePlaceholder:"Indtast kode",continueButtonText:"Bekræft og aktiver","invalid-code":"Den indtastede kode er ugyldig. Prøv venligst igen.","transaction-not-found":"Din tilmeldingssession er udløbet. Du skal starte forfra.",pageTitle:"Opsæt autentificeringsapp | ${clientName}",unexpectedError:"Noget gik galt. Prøv venligst igen.",enrollmentComplete:"MFA-tilmeldingen er fuldført. Du kan lukke denne side."},"mfa-totp-challenge":{title:"Bekræft din identitet",description:"Indtast den 6-cifrede kode fra din autentificeringsapp",codePlaceholder:"Indtast kode",continueButtonText:"Fortsæt","invalid-code":"Den indtastede kode er ugyldig","transaction-not-found":"Din session er udløbet. Du skal starte forfra.",unexpectedError:"Noget gik galt. Prøv venligst igen.",pageTitle:"Bekræft identitet | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Brug dit telefonnummer til at logge ind | ${clientName}",title:"Bekræft din identitet",description:"Vi sendte en kode til ${phoneNumber}",continueButtonText:"Fortsæt",changePhoneText:"Vælg et andet telefonnummer.",smsButtonText:"SMS",voiceButtonText:"Taleopkald",chooseMessageTypeText:"Hvordan vil du modtage koden?",pickAuthenticatorText:"Prøv en anden metode",logoAltText:"${companyName}",codePlaceholder:"Indtast kode","send-sms-failed":"Der opstod et problem med at sende SMS'en","send-voice-failed":"Der opstod et problem med at foretage taleopkaldet","invalid-phone-format":"Telefonnummeret kan kun indeholde cifre.","invalid-phone":"Det ser ud til, at dit telefonnummer ikke er gyldigt. Kontrollér og prøv igen.","too-many-sms":"Du har overskredet det maksimale antal telefonbeskeder pr. time. Vent et par minutter og prøv igen.","too-many-voice":"Du har overskredet det maksimale antal telefonopkald pr. time. Vent et par minutter og prøv igen.","transaction-not-found":"Din registreringstransaktion er udløbet, du skal starte forfra.","no-phone":"Indtast et telefonnummer",noCode:"Indtast bekræftelseskoden",invalidCode:"Den indtastede kode er ugyldig. Prøv igen.",unexpectedError:"Noget gik galt. Prøv igen.",resendSuccess:"Vi sendte en ny kode til din telefon",enrollmentComplete:"MFA-tilmeldingen er fuldført. Du kan lukke denne side."},"mfa-phone-enrollment":{pageTitle:"Indtast dit telefonnummer for at logge ind med en telefonkode | ${clientName}",title:"Sikre din konto",description:"Indtast din landekode og telefonnummer, som vi kan sende en 6-cifret kode til:",continueButtonText:"Fortsæt",smsButtonText:"SMS",voiceButtonText:"Taleopkald",chooseMessageTypeText:"Hvordan vil du modtage koden?",pickAuthenticatorText:"Prøv en anden metode",placeholder:"Indtast dit telefonnummer",logoAltText:"${companyName}",selectCountryCode:"Vælg landekode, i øjeblikket sat til ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Der opstod et problem med at sende SMS'en","send-voice-failed":"Der opstod et problem med at foretage taleopkaldet","sms-authenticator-error":"Vi kunne ikke sende SMS'en. Prøv igen senere.","invalid-phone-format":"Telefonnummeret kan kun indeholde cifre.","invalid-phone":"Det ser ud til, at dit telefonnummer ikke er gyldigt. Kontrollér og prøv igen.","too-many-sms":"Du har overskredet det maksimale antal telefonbeskeder pr. time. Vent et par minutter og prøv igen.","too-many-voice":"Du har overskredet det maksimale antal telefonopkald pr. time. Vent et par minutter og prøv igen.","transaction-not-found":"Din registreringstransaktion er udløbet, du skal starte forfra.","no-phone":"Indtast et telefonnummer","phone-is-too-short":"Telefonnummeret er for kort","phone-is-too-long":"Telefonnummeret er for langt"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Vælg bekræftelsesmetode | ${clientName}",title:"Vælg din bekræftelsesmetode",description:"Vælg hvordan du vil bekræfte din identitet",authenticatorAppLabel:"Godkendelsesapp",authenticatorAppDescription:"Brug din godkendelsesapp til at få en bekræftelseskode",smsLabel:"Sms-besked",smsDescription:"Få en bekræftelseskode sendt til din telefon",passkeyLabel:"Adgangsnøgle",passkeyDescription:"Brug din enheds biometri eller sikkerhedsnøgle"}},"mfa-push":{"mfa-push":{description:"Vi sendte en notifikation til din enhed",pageTitle:"Push-notifikation | ${clientName}",resendText:"Send notifikation igen",title:"Godkend anmodningen",useCodeText:"Indtast kode manuelt"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Fortsæt",codePlaceholder:"Gendannelseskode",description:"Indtast en af dine gendannelseskoder","invalid-code":"Den indtastede gendannelseskode er ugyldig",pageTitle:"Gendannelseskode | ${clientName}",title:"Indtast gendannelseskode"}},"mfa-voice":{"mfa-voice":{buttonText:"Ring til mig",codePlaceholder:"Indtast kode",description:"Vi ringer til ${phoneNumber} med din kode","invalid-code":"Den indtastede kode er ugyldig",pageTitle:"Taleopkald | ${clientName}",title:"Modtag et telefonopkald"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Prøv igen",description:"Indsæt din sikkerhedsnøgle og følg instruktionerne",pageTitle:"Sikkerhedsnøgle | ${clientName}",title:"Brug din sikkerhedsnøgle"}},passkeys:BT,organizations:LT,"reset-password":{"reset-password":{backToLoginText:"Gå tilbage",buttonText:"Send e-mail til nulstilling af adgangskode",codeExpired:"Din kode til nulstilling af adgangskode er udløbet. Anmod venligst om en ny.",confirmPasswordLabel:"Bekræft adgangskode",confirmPasswordPlaceholder:"Bekræft adgangskode",description:"Klik på knappen nedenfor, så sender vi instruktioner om, hvordan du nulstiller din adgangskode.",emailPlaceholder:"E-mail-adresse",failed:"Nulstilling af adgangskode mislykkedes. Prøv venligst igen.","invalid-email-format":"Ugyldig e-mail","no-email":"Indtast venligst en e-mailadresse",pageTitle:"Nulstil adgangskode | ${clientName}",passwordLabel:"Ny adgangskode",passwordPlaceholder:"Ny adgangskode",passwordTooWeak:"Adgangskoden er for svag",passwordsDidntMatch:"Adgangskoderne matcher ikke",successDescription:"Vi har sendt et link til nulstilling af adgangskode til din e-mailadresse.",successTitle:"E-mail til nulstilling af adgangskode sendt",title:"Har du glemt din adgangskode?","user-not-found":"Bruger ikke fundet"},"reset-password-code":{backToLoginText:"Tilbage til login",buttonText:"Nulstil adgangskode",codeLabel:"Nulstillingskode",codePlaceholder:"Indtast 6-cifret kode",confirmPasswordLabel:"Bekræft adgangskode",confirmPasswordPlaceholder:"Bekræft adgangskode",defaultDescription:"Indtast koden sendt til din e-mail og vælg en ny adgangskode",description:"Vi sendte en kode til ${email}",failed:"Nulstilling af adgangskode mislykkedes. Prøv venligst igen.",invalidCode:"Den indtastede kode er ugyldig eller udløbet",noCode:"Indtast venligst nulstillingskoden",pageTitle:"Indtast nulstillingskode | ${clientName}",passwordLabel:"Ny adgangskode",passwordPlaceholder:"Ny adgangskode",passwordTooWeak:"Adgangskoden er for svag",passwordsDidntMatch:"Adgangskoderne matcher ikke",resendFailed:"Kunne ikke sende koden igen. Prøv igen.",resendSuccess:"En ny kode er blevet sendt til din e-mail",resendText:"Send kode igen",sessionExpired:"Din session er udløbet. Prøv venligst igen.",title:"Indtast nulstillingskode"}},signup:MT,"signup-id":{"signup-id":{buttonText:"Fortsæt",description:"Vælg en adgangskode med en blanding af store og små bogstaver, tal og symboler.","email-already-exists":"E-mailen er allerede optaget",emailPlaceholder:"E-mail-adresse",federatedConnectionButtonText:"Fortsæt med ${connectionName}","invalid-email-format":"Ugyldig e-mail",loginActionLinkText:"Log ind",loginActionText:"Har du allerede en konto?","no-email":"Indtast venligst en e-mailadresse",pageTitle:"Tilmeld dig | ${clientName}",phonePlaceholder:"Telefonnummer",separatorText:"eller",title:"Vælg adgangskode",usernamePlaceholder:"Brugernavn"}},"signup-password":{"signup-password":{buttonText:"Fortsæt",description:"Vælg en adgangskode med en blanding af store og små bogstaver, tal og symboler.",hidePasswordText:"Skjul adgangskode","no-password":"Adgangskode er påkrævet",pageTitle:"Tilmeld dig | ${clientName}","password-policy-not-met":"Adgangskoden opfylder ikke kravene","password-too-weak":"Adgangskoden er for svag",passwordPlaceholder:"Adgangskode",showPasswordText:"Vis adgangskode",title:"Vælg adgangskode"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Log ind",codeLabel:"Bekræftelseskode",codePlaceholder:"Indtast kode",defaultDescription:"Indtast bekræftelseskoden, der blev sendt til din telefon",description:"Vi sendte en kode til ${username}","invalid-code":"Ugyldig kode",noCode:"Indtast venligst bekræftelseskoden",pageTitle:"Indtast kode | ${clientName}",resendText:"Send koden igen",sessionExpired:"Din session er udløbet. Prøv venligst igen.",title:"Tjek din telefon",unexpectedError:"Der opstod en uventet fejl"}},status:UT},vF=Object.freeze(Object.defineProperty({__proto__:null,common:jT,consent:OT,default:bF,invitation:FT,login:RT,mfa:DT,organizations:LT,passkeys:BT,signup:MT,status:UT},Symbol.toStringTag,{value:"Module"})),qT={common:{alertListTitle:"Alerts",backText:"Back",cancelText:"Cancel",closeText:"Close",contactSupportText:"Contact Support",continueText:"Continue",copyrightText:"© ${currentYear} ${companyName}",errorText:"An error occurred",hidePasswordText:"Hide password",loadingText:"Loading...",orText:"or",privacyPolicyText:"Privacy Policy",showPasswordText:"Show password",termsOfServiceText:"Terms of Service",termsShortText:"Terms",tryAgainText:"Try again"}},HT={consent:{buttonText:"Accept",cancelButtonText:"Deny",description:"${clientName} is requesting access to your account",pageTitle:"Authorize | ${clientName}",scopesTitle:"This will allow ${clientName} to:",title:"Authorize ${clientName}"}},VT={invitation:{acceptButtonText:"Accept invitation",description:"${inviterName} has invited you to join ${organizationName} on ${clientName}",pageTitle:"Invitation | ${clientName}",title:"You've been invited"}},KT={login:{alertListTitle:"Alerts",buttonText:"Continue",description:"Log in to ${clientName}.",editEmailText:"Edit",emailPlaceholder:"Email address",enterACodeBtn:"Sign in with a code",federatedConnectionButtonText:"Continue with ${connectionName}",footerLinkText:"Sign up",footerText:"Don't have an account?",forgotPasswordText:"Forgot password?",hidePasswordText:"Hide password",invalidEmail:"Invalid email",invalidIdentifier:"Invalid email or username",invitationDescription:"Log in to accept ${inviterName}'s invitation to join ${companyName} on ${clientName}.",invitationTitle:"You've Been Invited!",logoAltText:"${companyName}","no-email":"Please enter an email address","no-password":"Password is required",pageTitle:"Log in | ${clientName}",passwordLoginNotAvailable:"Password authentication is not available",passwordPlaceholder:"Password",phonePlaceholder:"Phone number",separatorText:"Or",sessionExpired:"Your session has expired. Please try again.",showPasswordText:"Show password",signupActionLinkText:"Sign up",signupActionText:"Don't have an account?",title:"Welcome",tooManyFailedLogins:"Too many failed login attempts. Please try again later.",unverifiedEmail:"Please verify your email address before logging in",userAccountDoesNotExist:"User account does not exist",usernamePlaceholder:"Username or email address",usernameTooLong:"Username must be ${max} characters or less",usernameTooShort:"Username must be at least ${min} characters",passkeyButtonText:"Sign in with a passkey",wrongCredentials:"Wrong username or password"}},GT={mfa:{backupCodeText:"Use backup code",description:"Choose a verification method",pageTitle:"Multi-Factor Authentication | ${clientName}",title:"Verify your identity"}},WT={"passkey-enrollment-nudge":{title:"Secure your account with a passkey",description:"Passkeys use your device's biometrics or PIN to sign you in faster and more securely.",enrollButtonText:"Set up passkey",snoozeButtonText:"Maybe later",optOutLinkText:"Don't show this again",pageTitle:"Set Up Passkey | ${clientName}"},"passkey-enrollment":{title:"Create your passkey",description:"Follow the prompts from your browser to create a passkey for this account.",errorMessage:"Failed to create passkey. Please try again.",cancelLinkText:"Skip for now",retryButtonText:"Try again",enrollmentComplete:"Your passkey has been set up successfully. You can close this page.",pageTitle:"Create Passkey | ${clientName}"},"passkey-challenge":{title:"Sign in with a passkey",description:"Follow the prompts from your browser to verify your identity.",errorMessage:"Passkey authentication failed. Please try again.",cancelLinkText:"Back to login",retryButtonText:"Try again",pageTitle:"Sign In with Passkey | ${clientName}"}},JT={organizations:{description:"Choose which organization to log in to",pageTitle:"Select Organization | ${clientName}",searchPlaceholder:"Search organizations",title:"Select your organization"}},YT={signup:{buttonText:"Continue",confirmPasswordPlaceholder:"Confirm password",description:"Sign up to continue","email-already-exists":"This email is already registered",emailPlaceholder:"Email address",federatedConnectionButtonText:"Continue with ${connectionName}",hidePasswordText:"Hide password","invalid-email-format":"Email is not valid.",loginActionLinkText:"Log in",loginActionText:"Already have an account?","no-email":"Please enter an email address","no-password":"Password is required","no-username":"Username is required",pageTitle:"Sign up | ${clientName}",passwordPlaceholder:"Password",passwordsDidntMatch:"Passwords don't match",phonePlaceholder:"Phone number",privacyPolicyLinkText:"Privacy Policy",separatorText:"Or",sessionExpired:"Your session has expired. Please try again.",showPasswordText:"Show password",termsOfServiceLinkText:"Terms of Service",termsText:"By signing up, you agree to our",title:"Create your account","username-already-exists":"This username is already taken",usernamePlaceholder:"Username",verifyEmailText:"Please check your email to verify your account"}},QT={status:{continueButtonText:"Continue",errorTitle:"Error",pageTitle:"Status | ${clientName}",successTitle:"Success",title:"Status"}},AF={common:qT,consent:HT,"device-flow":{"device-flow":{buttonText:"Continue",codePlaceholder:"Enter code",description:"Enter the code shown on your device","expired-code":"The code has expired","invalid-code":"The code you entered is invalid",pageTitle:"Device Activation | ${clientName}",title:"Activate your device"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Continue",codeLabel:"Verification Code",codePlaceholder:"Enter code",defaultDescription:"Enter the verification code sent to your email",description:"We sent a code to ${email}","invalid-code":"The code you entered is invalid",noCode:"Please enter the verification code",pageTitle:"Enter Code | ${clientName}",resendText:"Resend code",sessionExpired:"Your session has expired. Please try again.",title:"Check your email",unexpectedError:"An unexpected error occurred"}},"email-verification":{"email-verification":{description:"We sent an email to ${email}",pageTitle:"Verify Email | ${clientName}",resendText:"Resend email",successDescription:"Your email has been verified successfully.",successTitle:"Email verified",title:"Verify your email"}},invitation:VT,login:KT,"login-id":{"login-id":{alertListTitle:"Alerts","auth0-users-validation":"Something went wrong, please try again later","authentication-failure":"We are sorry, something went wrong when attempting to log in",buttonText:"Continue","captcha-client-failure":"We couldn't load the security challenge. Please try again. (Error code: #{errorCode})","captcha-validation-failure":"We are sorry, something went wrong while validating the captcha response. Please try again.",captchaCodePlaceholder:"Enter the code shown above","custom-script-error-code":"Something went wrong, please try again later.",description:"Log in to ${clientName}.",editEmailText:"Edit",emailPlaceholder:"Email address",federatedConnectionButtonText:"Continue with ${connectionName}",footerLinkText:"Sign up",footerText:"Don't have an account?",forgotPasswordText:"Forgot password?",hidePasswordText:"Hide password","invalid-captcha":"Solve the challenge question to verify you are not a robot.","invalid-code":"The code you entered is invalid","invalid-connection":"Invalid connection","invalid-email-format":"Email is not valid.","invalid-email-phone":"Enter a valid email address or phone number. Phone numbers must include the country code.","invalid-email-phone-username":"Enter a valid email address, phone number or username. Phone numbers must include the country code.","invalid-email-username":"Enter a valid email address or username","invalid-expired-code":"Invalid or expired user code","invalid-login-id":"Invalid Login ID entered","invalid-phone-username":"Enter a valid phone number or username. Phone numbers must include the country code.","invalid-recaptcha":"Select the checkbox to verify you are not a robot.","invalid-username":"Username can only contain alphanumeric characters or: '${characters}'. Username should have between ${min} and ${max} characters.",invitationDescription:"Log in to accept ${inviterName}'s invitation to join ${companyName} on ${clientName}.",invitationTitle:"You've Been Invited!","ip-blocked":"We have detected suspicious login behavior and further attempts will be blocked. Please contact the administrator.",logoAltText:"${companyName}","no-db-connection":"Invalid connection","no-email":"Please enter an email address","no-email-phone":"Email address or phone number is required","no-email-phone-username":"Phone number, username, or email address is required","no-email-username":"Email address or username is required","no-password":"Password is required","no-phone":"Please enter a phone number","no-phone-username":"Phone number or username is required","no-username":"Username is required",pageTitle:"Log in | ${clientName}","password-breached":"We have detected a potential security issue with this account. To protect your account, we have prevented this login. Please reset your password to proceed.",passwordPlaceholder:"Password",phoneOrEmailPlaceholder:"Phone number or Email address",phoneOrUsernameOrEmailPlaceholder:"Phone or Username or Email",phoneOrUsernamePlaceholder:"Phone Number or Username",phonePlaceholder:"Phone number","same-user-login":"Too many login attempts for this user. Please wait, and try again later.",selectCountryCode:"Select country code, currently set to ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"Or",sessionExpired:"Your session has expired. Please try again.",showPasswordText:"Show password",signupActionLinkText:"Sign up",signupActionText:"Don't have an account?",termsAndConditionsTemplate:'By continuing, you agree to our <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Terms and Conditions</a>.',title:"Welcome","user-blocked":"Your account has been blocked after multiple consecutive login attempts.",userAccountDoesNotExist:"User account does not exist",usernameOnlyPlaceholder:"Username",usernameOrEmailPlaceholder:"Username or Email address",usernamePlaceholder:"Username or email address",usernameTooLong:"Username must be ${max} characters or less",usernameTooShort:"Username must be at least ${min} characters","wrong-credentials":"Wrong username or password","wrong-email-credentials":"Wrong email or password","wrong-email-phone-credentials":"Incorrect email address, phone number, or password. Phone numbers must include the country code.","wrong-email-phone-username-credentials":"Incorrect email address, phone number, username, or password. Phone numbers must include the country code.","wrong-email-username-credentials":"Incorrect email address, username, or password","wrong-phone-credentials":"Incorrect phone number or password","wrong-phone-username-credentials":"Incorrect phone number, username or password. Phone numbers must include the country code.",passkeyButtonText:"Sign in with a passkey","wrong-username-credentials":"Incorrect username or password"}},"login-password":{"login-password":{buttonText:"Continue",description:"Log in to ${clientName}",forgotPasswordText:"Forgot password?",hidePasswordText:"Hide password","no-password":"Password is required",pageTitle:"Log in | ${clientName}","password-breached":"We have detected a potential security issue with this account. To protect your account, we have prevented this login. Please reset your password to proceed.",passwordPlaceholder:"Password",showPasswordText:"Show password",signingInAs:"Signing in as ${email}",title:"Enter your password",unverifiedEmail:"Please verify your email address before logging in","user-blocked":"Your account has been blocked after multiple consecutive login attempts.","wrong-credentials":"Wrong password"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"email",authMethodEmailOrPhone:"email or phone number",authMethodPhone:"phone number",description:"Sign in using your ${authMethod}",emailOrPhonePlaceholder:"Email address or phone number",emailPlaceholder:"Email address",invalidEmail:"Please enter a valid email address",invalidIdentifier:"Please enter a valid email address or phone number",invalidPhone:"Please enter a valid phone number with country code",noEmail:"Please enter your email address",noPhone:"Please enter your phone number",phonePlaceholder:"Phone number",sessionExpired:"Your session has expired. Please try again.",title:"Sign in with a code",userAccountDoesNotExist:"User account does not exist"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Click the link in your email to sign in",description:"We sent a link to ${username}. Click it to sign in.",resendText:"Resend link",spamText:"Didn't receive the email? Check your spam folder.",title:"Check your email"}},mfa:GT,"mfa-email":{"mfa-email":{buttonText:"Continue",codePlaceholder:"Enter code",description:"We sent a code to ${email}","invalid-code":"The code you entered is invalid",pageTitle:"Email Verification | ${clientName}",resendText:"Resend code",title:"Check your email"}},"mfa-otp":{"mfa-otp":{buttonText:"Continue",codePlaceholder:"Enter code",description:"Enter the 6-digit code from your authenticator app","invalid-code":"The code you entered is invalid",pageTitle:"Enter Code | ${clientName}",title:"Enter your code"},"mfa-totp-enrollment":{title:"Set up authenticator",description:"Scan the QR code below with your authenticator app, then enter the 6-digit code to verify",secretLabel:"Or enter this code manually:",codePlaceholder:"Enter code",continueButtonText:"Verify & Activate","invalid-code":"The code you entered is invalid. Please try again.","transaction-not-found":"Your enrollment transaction expired, you will need to start again.",unexpectedError:"Something went wrong. Please try again.",pageTitle:"Set up Authenticator | ${clientName}",enrollmentComplete:"MFA enrollment is complete. You can close this page."},"mfa-totp-challenge":{title:"Verify your identity",description:"Enter the 6-digit code from your authenticator app",codePlaceholder:"Enter code",continueButtonText:"Continue","invalid-code":"The code you entered is invalid","transaction-not-found":"Your enrollment transaction expired, you will need to start again.",unexpectedError:"Something went wrong. Please try again.",pageTitle:"Verify Identity | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Use your phone number to log in | ${clientName}",title:"Verify Your Identity",description:"We sent a code to ${phoneNumber}",continueButtonText:"Continue",changePhoneText:"Choose another phone number.",smsButtonText:"Text message",voiceButtonText:"Voice call",chooseMessageTypeText:"How do you want to receive the code?",pickAuthenticatorText:"Try another method",logoAltText:"${companyName}",codePlaceholder:"Enter code","send-sms-failed":"There was a problem sending the SMS","send-voice-failed":"There was a problem making the voice call","invalid-phone-format":"Phone number can only include digits.","invalid-phone":"It seems that your phone number is not valid. Please check and retry.","too-many-sms":"You have exceeded the maximum number of phone messages per hour. Wait a few minutes and try again.","too-many-voice":"You have exceeded the maximum number of phone messages per hour. Wait a few minutes and try again.","transaction-not-found":"Your enrollment transaction expired, you will need to start again.","no-phone":"Please enter a phone number",noCode:"Please enter the verification code",invalidCode:"The code you entered is invalid. Please try again.",unexpectedError:"Something went wrong. Please try again.",resendSuccess:"We sent a new code to your phone",enrollmentComplete:"MFA enrollment is complete. You can close this page."},"mfa-phone-enrollment":{pageTitle:"Enter your phone number to log in using a phone code | ${clientName}",title:"Secure Your Account",description:"Enter your country code and phone number to which we can send a 6-digit code:",continueButtonText:"Continue",smsButtonText:"Text message",voiceButtonText:"Voice call",chooseMessageTypeText:"How do you want to receive the code?",pickAuthenticatorText:"Try another method",placeholder:"Enter your phone number",logoAltText:"${companyName}",selectCountryCode:"Select country code, currently set to ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"There was a problem sending the SMS","send-voice-failed":"There was a problem making the voice call","sms-authenticator-error":"We couldn't send the SMS. Please try again later.","invalid-phone-format":"Phone number can only include digits.","invalid-phone":"It seems that your phone number is not valid. Please check and retry.","too-many-sms":"You have exceeded the maximum number of phone messages per hour. Wait a few minutes and try again.","too-many-voice":"You have exceeded the maximum number of phone messages per hour. Wait a few minutes and try again.","transaction-not-found":"Your enrollment transaction expired, you will need to start again.","no-phone":"Please enter a phone number","phone-is-too-short":"Phone number is too short","phone-is-too-long":"Phone number is too long"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Choose Verification Method | ${clientName}",title:"Choose your verification method",description:"Select how you'd like to verify your identity",authenticatorAppLabel:"Authenticator App",authenticatorAppDescription:"Use your authenticator app to get a verification code",smsLabel:"Text Message",smsDescription:"Get a verification code sent to your phone",passkeyLabel:"Passkey",passkeyDescription:"Use your device's biometrics or security key"}},"mfa-push":{"mfa-push":{description:"We sent a notification to your device",pageTitle:"Push Notification | ${clientName}",resendText:"Resend notification",title:"Approve the request",useCodeText:"Enter code manually"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Continue",codePlaceholder:"Recovery code",description:"Enter one of your recovery codes","invalid-code":"The recovery code you entered is invalid",pageTitle:"Recovery Code | ${clientName}",title:"Enter recovery code"}},"mfa-voice":{"mfa-voice":{buttonText:"Call me",codePlaceholder:"Enter code",description:"We will call ${phoneNumber} with your code","invalid-code":"The code you entered is invalid",pageTitle:"Voice Call | ${clientName}",title:"Receive a phone call"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Try again",description:"Insert your security key and follow the instructions",pageTitle:"Security Key | ${clientName}",title:"Use your security key"}},passkeys:WT,organizations:JT,"reset-password":{"reset-password":{backToLoginText:"Back to login",buttonText:"Continue",codeExpired:"Your password reset code has expired. Please request a new one.",confirmPasswordLabel:"Confirm Password",confirmPasswordPlaceholder:"Confirm password",description:"Enter your email to reset your password",emailPlaceholder:"Email address",failed:"Password reset failed. Please try again.","invalid-email-format":"Email is not valid.","no-email":"Please enter an email address",pageTitle:"Reset Password | ${clientName}",passwordLabel:"New Password",passwordPlaceholder:"New password",passwordTooWeak:"Password is too weak",passwordsDidntMatch:"Passwords don't match",successDescription:"We have sent a password reset link to your email address.",successTitle:"Check your email",title:"Forgot your password?","user-not-found":"User not found"},"reset-password-code":{backToLoginText:"Back to login",buttonText:"Reset Password",codeLabel:"Reset Code",codePlaceholder:"Enter 6-digit code",confirmPasswordLabel:"Confirm Password",confirmPasswordPlaceholder:"Confirm password",defaultDescription:"Enter the code sent to your email and choose a new password",description:"We sent a code to ${email}",failed:"Password reset failed. Please try again.",invalidCode:"The code you entered is invalid or has expired",noCode:"Please enter the reset code",pageTitle:"Enter Reset Code | ${clientName}",passwordLabel:"New Password",passwordPlaceholder:"New password",passwordTooWeak:"Password is too weak",passwordsDidntMatch:"Passwords don't match",resendFailed:"Failed to resend the code. Please try again.",resendSuccess:"A new code has been sent to your email",resendText:"Resend code",sessionExpired:"Your session has expired. Please try again.",title:"Enter reset code"}},signup:YT,"signup-id":{"signup-id":{buttonText:"Continue",description:"Sign up to continue","email-already-exists":"This email is already registered",emailPlaceholder:"Email address",federatedConnectionButtonText:"Continue with ${connectionName}","invalid-email-format":"Email is not valid.",loginActionLinkText:"Log in",loginActionText:"Already have an account?","no-email":"Please enter an email address",pageTitle:"Sign up | ${clientName}",phonePlaceholder:"Phone number",separatorText:"Or",title:"Create your account",usernamePlaceholder:"Username"}},"signup-password":{"signup-password":{buttonText:"Continue",description:"Sign up to continue",hidePasswordText:"Hide password","no-password":"Password is required",pageTitle:"Sign up | ${clientName}","password-policy-not-met":"Password does not meet the requirements","password-too-weak":"Password is too weak",passwordPlaceholder:"Password",showPasswordText:"Show password",title:"Create your password"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Continue",codeLabel:"Verification Code",codePlaceholder:"Enter code",defaultDescription:"Enter the verification code sent to your phone",description:"We sent a code to ${username}","invalid-code":"The code you entered is invalid",noCode:"Please enter the verification code",pageTitle:"Enter Code | ${clientName}",resendText:"Resend code",sessionExpired:"Your session has expired. Please try again.",title:"Check your phone",unexpectedError:"An unexpected error occurred"}},status:QT},kF=Object.freeze(Object.defineProperty({__proto__:null,common:qT,consent:HT,default:AF,invitation:VT,login:KT,mfa:GT,organizations:JT,passkeys:WT,signup:YT,status:QT},Symbol.toStringTag,{value:"Module"})),ZT={common:{alertListTitle:"Ilmoitukset",backText:"Palaa takaisin",cancelText:"Palaa takaisin",closeText:"Sulje",contactSupportText:"Tarvitsetko apua?",continueText:"Jatka",copyrightText:"© ${currentYear} ${companyName}",errorText:"Jokin meni pieleen. Yritä uudelleen.",hidePasswordText:"Piilota salasana",loadingText:"Ladataan...",orText:"tai",privacyPolicyText:"Tietosuojakäytäntö",showPasswordText:"Näytä salasana",termsOfServiceText:"Käyttöehdot",termsShortText:"Ehdot",tryAgainText:"Yritä uudelleen"}},XT={consent:{buttonText:"Hyväksy",cancelButtonText:"Hylkää",description:"${clientName} pyytää pääsyä tilillesi",pageTitle:"Valtuuta | ${clientName}",scopesTitle:"Tämä sallii sovelluksen ${clientName}:",title:"Valtuuta ${clientName}"}},e$={invitation:{acceptButtonText:"Hyväksy kutsu",description:"${inviterName} on kutsunut sinut liittymään organisaatioon ${organizationName} palvelussa ${clientName}",pageTitle:"Kutsu | ${clientName}",title:"Sinut on kutsuttu"}},t$={login:{alertListTitle:"Ilmoitukset",buttonText:"Jatka",description:"Kirjaudu sisään ${clientName}.",editEmailText:"Muokkaa",emailPlaceholder:"Sähköpostiosoite",enterACodeBtn:"Kirjaudu koodilla",federatedConnectionButtonText:"Jatka palvelulla ${connectionName}",footerLinkText:"Rekisteröidy",footerText:"Eikö sinulla ole tiliä?",forgotPasswordText:"Unohditko salasanan?",hidePasswordText:"Piilota salasana",invalidEmail:"Virheellinen sähköpostiosoite",invalidIdentifier:"Virheellinen sähköpostiosoite tai käyttäjänimi",invitationDescription:"Kirjaudu sisään hyväksyäksesi käyttäjän ${inviterName} kutsun liittyä palveluun ${companyName} sovelluksessa ${clientName}.",invitationTitle:"Sinut on kutsuttu!",logoAltText:"${companyName}","no-email":"Sähköpostiosoite vaaditaan","no-password":"Salasana vaaditaan",pageTitle:"Kirjaudu sisään | ${clientName}",passwordLoginNotAvailable:"Salasanakirjautuminen ei ole käytettävissä",passwordPlaceholder:"Salasana",phonePlaceholder:"Puhelinnumero",separatorText:"tai",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",showPasswordText:"Näytä salasana",signupActionLinkText:"Rekisteröidy",signupActionText:"Eikö sinulla ole tiliä?",title:"Tervetuloa",tooManyFailedLogins:"Liian monta epäonnistunutta kirjautumisyritystä. Yritä myöhemmin uudelleen.",unverifiedEmail:"Vahvista sähköpostiosoitteesi ennen kirjautumista",userAccountDoesNotExist:"Käyttäjätiliä ei ole olemassa",usernamePlaceholder:"Käyttäjänimi tai sähköpostiosoite",usernameTooLong:"Käyttäjänimen on oltava enintään ${max} merkkiä",usernameTooShort:"Käyttäjänimen on oltava vähintään ${min} merkkiä",wrongCredentials:"Väärä käyttäjänimi tai salasana",passkeyButtonText:"Kirjaudu sisään passkey:llä"}},n$={mfa:{backupCodeText:"Käytä varakoodia",description:"Valitse vahvistusmenetelmä",pageTitle:"Monivaiheinen tunnistautuminen | ${clientName}",title:"Vahvista henkilöllisyytesi"}},i$={"passkey-enrollment-nudge":{title:"Suojaa tilisi tunnistautumisavaimella",description:"Tunnistautumisavaimet käyttävät laitteesi biometriikkaa tai PIN-koodia kirjautuaksesi nopeammin ja turvallisemmin.",enrollButtonText:"Määritä tunnistautumisavain",snoozeButtonText:"Ehkä myöhemmin",optOutLinkText:"Älä näytä tätä uudelleen",pageTitle:"Määritä Tunnistautumisavain | ${clientName}"},"passkey-enrollment":{title:"Luo tunnistautumisavain",description:"Seuraa selaimesi ohjeita luodaksesi tunnistautumisavaimen tälle tilille.",errorMessage:"Tunnistautumisavaimen luominen epäonnistui. Yritä uudelleen.",cancelLinkText:"Ohita toistaiseksi",retryButtonText:"Yritä uudelleen",enrollmentComplete:"Tunnistautumisavaimesi on määritetty onnistuneesti. Voit sulkea tämän sivun.",pageTitle:"Luo Tunnistautumisavain | ${clientName}"},"passkey-challenge":{title:"Kirjaudu sisään passkey:llä",description:"Noudata selaimesi ohjeita henkilöllisyytesi vahvistamiseksi.",errorMessage:"Passkey-todennus epäonnistui. Yritä uudelleen.",cancelLinkText:"Takaisin kirjautumiseen",retryButtonText:"Yritä uudelleen",pageTitle:"Kirjaudu sisään passkey:llä | ${clientName}"}},r$={organizations:{description:"Valitse organisaatio, johon haluat kirjautua",pageTitle:"Valitse organisaatio | ${clientName}",searchPlaceholder:"Hae organisaatioita",title:"Valitse organisaatiosi"}},o$={signup:{buttonText:"Rekisteröityminen",confirmPasswordPlaceholder:"Vahvista salasana",description:"Valitse salasana, jossa on isoja ja pieniä kirjaimia, numeroita ja symboleja.","email-already-exists":"Sähköposti on jo varattu",emailPlaceholder:"Sähköpostiosoite",federatedConnectionButtonText:"Jatka palvelulla ${connectionName}",hidePasswordText:"Piilota salasana","invalid-email-format":"Virheellinen sähköpostiosoite",loginActionLinkText:"Kirjaudu sisään",loginActionText:"Onko sinulla jo tili?","no-email":"Sähköpostiosoite vaaditaan","no-password":"Salasana vaaditaan","no-username":"Käyttäjänimi vaaditaan",pageTitle:"Rekisteröidy | ${clientName}",passwordPlaceholder:"Salasana",passwordsDidntMatch:"Salasanat eivät täsmää",phonePlaceholder:"Puhelinnumero",privacyPolicyLinkText:"Tietosuojakäytäntö",separatorText:"tai",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",showPasswordText:"Näytä salasana",termsOfServiceLinkText:"Käyttöehdot",termsText:"Rekisteröitymällä hyväksyt",title:"Valitse salasana","username-already-exists":"Tämä käyttäjänimi on jo varattu",usernamePlaceholder:"Käyttäjänimi",verifyEmailText:"Tarkista sähköpostisi vahvistaaksesi tilisi"}},s$={status:{continueButtonText:"Jatka",errorTitle:"Virhe",pageTitle:"Tila | ${clientName}",successTitle:"Onnistui",title:"Tila"}},SF={common:ZT,consent:XT,"device-flow":{"device-flow":{buttonText:"Jatka",codePlaceholder:"Syötä koodi",description:"Syötä laitteessasi näkyvä koodi","expired-code":"Koodi on vanhentunut","invalid-code":"Syöttämäsi koodi on virheellinen",pageTitle:"Laitteen aktivointi | ${clientName}",title:"Aktivoi laitteesi"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Kirjaudu sisään",codeLabel:"Vahvistuskoodi",codePlaceholder:"Syötä koodi",defaultDescription:"Syötä sähköpostiisi lähetetty vahvistuskoodi",description:"Lähetimme koodin osoitteeseen ${email}","invalid-code":"Virheellinen koodi",noCode:"Syötä vahvistuskoodi",pageTitle:"Syötä koodi | ${clientName}",resendText:"Lähetä koodi uudelleen",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",title:"Tarkista sähköpostisi",unexpectedError:"Odottamaton virhe tapahtui"}},"email-verification":{"email-verification":{description:"Lähetimme sähköpostin osoitteeseen ${email}",pageTitle:"Vahvista sähköposti | ${clientName}",resendText:"Lähetä koodi uudelleen",successDescription:"Sähköpostiosoitteesi on vahvistettu onnistuneesti.",successTitle:"Sähköposti vahvistettu",title:"Vahvista sähköpostiosoitteesi"}},invitation:e$,login:t$,"login-id":{"login-id":{alertListTitle:"Ilmoitukset","auth0-users-validation":"Jokin meni pieleen, yritä myöhemmin uudelleen","authentication-failure":"Valitettavasti jokin meni pieleen kirjautumisyrityksen aikana",buttonText:"Jatka","captcha-client-failure":"Turvatarkistuksen lataaminen epäonnistui. Yritä uudelleen. (Virhekoodi: #{errorCode})","captcha-validation-failure":"Valitettavasti jokin meni pieleen captcha-vastauksen tarkistuksessa. Yritä uudelleen.",captchaCodePlaceholder:"Syötä yllä näkyvä koodi","custom-script-error-code":"Jokin meni pieleen, yritä myöhemmin uudelleen.",description:"Kirjaudu sisään ${clientName}.",editEmailText:"Muokkaa",emailPlaceholder:"Sähköpostiosoite",federatedConnectionButtonText:"Jatka palvelulla ${connectionName}",footerLinkText:"Rekisteröidy",footerText:"Eikö sinulla ole tiliä?",forgotPasswordText:"Unohditko salasanan?",hidePasswordText:"Piilota salasana","invalid-captcha":"Ratkaise haaste varmistaaksesi, ettet ole robotti.","invalid-code":"Virheellinen koodi","invalid-connection":"Virheellinen yhteys","invalid-email-format":"Virheellinen sähköpostiosoite","invalid-email-phone":"Syötä kelvollinen sähköpostiosoite tai puhelinnumero. Puhelinnumeron tulee sisältää maatunnus.","invalid-email-phone-username":"Syötä kelvollinen sähköpostiosoite, puhelinnumero tai käyttäjänimi. Puhelinnumeron tulee sisältää maatunnus.","invalid-email-username":"Syötä kelvollinen sähköpostiosoite tai käyttäjänimi","invalid-expired-code":"Virheellinen tai vanhentunut käyttäjäkoodi","invalid-login-id":"Virheellinen kirjautumistunnus","invalid-phone-username":"Syötä kelvollinen puhelinnumero tai käyttäjänimi. Puhelinnumeron tulee sisältää maatunnus.","invalid-recaptcha":"Valitse valintaruutu varmistaaksesi, ettet ole robotti.","invalid-username":"Käyttäjänimi voi sisältää vain aakkosnumeerisia merkkejä tai: '${characters}'. Käyttäjänimen tulee olla ${min}–${max} merkkiä.",invitationDescription:"Kirjaudu sisään hyväksyäksesi käyttäjän ${inviterName} kutsun liittyä palveluun ${companyName} sovelluksessa ${clientName}.",invitationTitle:"Sinut on kutsuttu!","ip-blocked":"Olemme havainneet epäilyttävää kirjautumiskäyttäytymistä ja lisäyritykset estetään. Ota yhteyttä ylläpitäjään.",logoAltText:"${companyName}","no-db-connection":"Virheellinen yhteys","no-email":"Sähköpostiosoite vaaditaan","no-email-phone":"Sähköpostiosoite tai puhelinnumero vaaditaan","no-email-phone-username":"Puhelinnumero, käyttäjänimi tai sähköpostiosoite vaaditaan","no-email-username":"Sähköpostiosoite tai käyttäjänimi vaaditaan","no-password":"Salasana vaaditaan","no-phone":"Syötä puhelinnumero","no-phone-username":"Puhelinnumero tai käyttäjänimi vaaditaan","no-username":"Käyttäjänimi vaaditaan",pageTitle:"Kirjaudu sisään | ${clientName}","password-breached":"Olemme havainneet mahdollisen tietoturvaongelman tässä tilissä. Tilisi suojaamiseksi olemme estäneet tämän kirjautumisen. Vaihda salasanasi jatkaaksesi.",passwordPlaceholder:"Salasana",phoneOrEmailPlaceholder:"Sähköposti tai puhelinnumero",phoneOrUsernameOrEmailPlaceholder:"Puhelin, käyttäjänimi tai sähköposti",phoneOrUsernamePlaceholder:"Puhelinnumero tai käyttäjänimi",phonePlaceholder:"Puhelinnumero","same-user-login":"Liian monta kirjautumisyritystä tälle käyttäjälle. Odota hetki ja yritä myöhemmin uudelleen.",selectCountryCode:"Valitse maakoodi, tällä hetkellä ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"tai",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",showPasswordText:"Näytä salasana",signupActionLinkText:"Rekisteröidy",signupActionText:"Eikö sinulla ole tiliä?",termsAndConditionsTemplate:'Jatkamalla hyväksyt <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Käyttöehdot</a>.',title:"Tervetuloa","user-blocked":"Tilisi on estetty useiden peräkkäisten kirjautumisyritysten jälkeen.",userAccountDoesNotExist:"Käyttäjätiliä ei ole olemassa",usernameOnlyPlaceholder:"Käyttäjänimi",usernameOrEmailPlaceholder:"Käyttäjänimi tai sähköpostiosoite",usernamePlaceholder:"Käyttäjänimi",usernameTooLong:"Käyttäjänimen on oltava enintään ${max} merkkiä",usernameTooShort:"Käyttäjänimen on oltava vähintään ${min} merkkiä","wrong-credentials":"Väärä käyttäjänimi tai salasana","wrong-email-credentials":"Väärä sähköpostiosoite tai salasana","wrong-email-phone-credentials":"Virheellinen sähköpostiosoite, puhelinnumero tai salasana. Puhelinnumeron tulee sisältää maatunnus.","wrong-email-phone-username-credentials":"Virheellinen sähköpostiosoite, puhelinnumero, käyttäjänimi tai salasana. Puhelinnumeron tulee sisältää maatunnus.","wrong-email-username-credentials":"Virheellinen sähköpostiosoite, käyttäjänimi tai salasana","wrong-phone-credentials":"Virheellinen puhelinnumero tai salasana","wrong-phone-username-credentials":"Virheellinen puhelinnumero, käyttäjänimi tai salasana. Puhelinnumeron tulee sisältää maatunnus.","wrong-username-credentials":"Virheellinen käyttäjänimi tai salasana",passkeyButtonText:"Kirjaudu sisään passkey:llä"}},"login-password":{"login-password":{buttonText:"Kirjaudu sisään",description:"Anna sähköpostiosoitteesi ja salasanasi kirjautuaksesi sisään.",forgotPasswordText:"Unohditko salasanan?",hidePasswordText:"Piilota salasana","no-password":"Salasana vaaditaan",pageTitle:"Kirjaudu sisään | ${clientName}","password-breached":"Olemme havainneet mahdollisen tietoturvaongelman tässä tilissä. Tilisi suojaamiseksi olemme estäneet tämän kirjautumisen. Vaihda salasanasi jatkaaksesi.",passwordPlaceholder:"Salasana",showPasswordText:"Näytä salasana",signingInAs:"Kirjaudutaan käyttäjänä ${email}",title:"Anna salasana",unverifiedEmail:"Vahvista sähköpostiosoitteesi ennen kirjautumista","user-blocked":"Tilisi on estetty useiden peräkkäisten kirjautumisyritysten jälkeen.","wrong-credentials":"Väärä salasana"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"sähköposti",authMethodEmailOrPhone:"sähköposti tai puhelinnumero",authMethodPhone:"puhelinnumero",description:"Kirjaudu sisään käyttämällä ${authMethod}",emailOrPhonePlaceholder:"Sähköpostiosoite tai puhelinnumero",emailPlaceholder:"Sähköpostiosoite",invalidEmail:"Syötä kelvollinen sähköpostiosoite",invalidIdentifier:"Syötä kelvollinen sähköpostiosoite tai puhelinnumero",invalidPhone:"Syötä kelvollinen puhelinnumero maatunnuksella",noEmail:"Syötä sähköpostiosoitteesi",noPhone:"Syötä puhelinnumerosi",phonePlaceholder:"Puhelinnumero",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",title:"Kirjaudu koodilla",userAccountDoesNotExist:"Käyttäjätiliä ei ole olemassa"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Napsauta sähköpostissasi olevaa linkkiä kirjautuaksesi sisään",description:"Lähetimme linkin osoitteeseen ${username}. Napsauta sitä kirjautuaksesi.",resendText:"Lähetä linkki uudelleen",spamText:"Etkö saanut sähköpostia? Tarkista roskapostikansiosi.",title:"Tarkista sähköpostisi"}},mfa:n$,"mfa-email":{"mfa-email":{buttonText:"Jatka",codePlaceholder:"Syötä koodi",description:"Lähetimme koodin osoitteeseen ${email}","invalid-code":"Syöttämäsi koodi on virheellinen",pageTitle:"Sähköpostivahvistus | ${clientName}",resendText:"Lähetä koodi uudelleen",title:"Tarkista sähköpostisi"}},"mfa-otp":{"mfa-otp":{buttonText:"Jatka",codePlaceholder:"Syötä koodi",description:"Syötä 6-numeroinen koodi todentajasovelluksestasi","invalid-code":"Syöttämäsi koodi on virheellinen",pageTitle:"Syötä koodi | ${clientName}",title:"Syötä koodisi"},"mfa-totp-enrollment":{title:"Ota todentajasovellus käyttöön",description:"Skannaa alla oleva QR-koodi todentajasovelluksellasi ja syötä sitten 6-numeroinen koodi vahvistaaksesi",secretLabel:"Tai syötä tämä koodi manuaalisesti:",codePlaceholder:"Syötä koodi",continueButtonText:"Vahvista ja aktivoi","invalid-code":"Syöttämäsi koodi on virheellinen. Yritä uudelleen.","transaction-not-found":"Rekisteröintitapahtumasi on vanhentunut, sinun täytyy aloittaa alusta.",pageTitle:"Ota todentaja käyttöön | ${clientName}",unexpectedError:"Jokin meni pieleen. Yritä uudelleen.",enrollmentComplete:"MFA-rekisteröinti on valmis. Voit sulkea tämän sivun."},"mfa-totp-challenge":{title:"Vahvista henkilöllisyytesi",description:"Syötä 6-numeroinen koodi todentajasovelluksestasi",codePlaceholder:"Syötä koodi",continueButtonText:"Jatka","invalid-code":"Syöttämäsi koodi on virheellinen","transaction-not-found":"Rekisteröintitapahtumasi on vanhentunut, sinun täytyy aloittaa alusta.",unexpectedError:"Jokin meni pieleen. Yritä uudelleen.",pageTitle:"Vahvista henkilöllisyys | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Käytä puhelinnumeroasi kirjautumiseen | ${clientName}",title:"Vahvista henkilöllisyytesi",description:"Lähetimme koodin numeroon ${phoneNumber}",continueButtonText:"Jatka",changePhoneText:"Valitse toinen puhelinnumero.",smsButtonText:"Tekstiviesti",voiceButtonText:"Äänipuhelu",chooseMessageTypeText:"Miten haluat vastaanottaa koodin?",pickAuthenticatorText:"Kokeile toista menetelmää",logoAltText:"${companyName}",codePlaceholder:"Syötä koodi","send-sms-failed":"Tekstiviestin lähettämisessä oli ongelma","send-voice-failed":"Äänipuhelun soittamisessa oli ongelma","invalid-phone-format":"Puhelinnumero voi sisältää vain numeroita.","invalid-phone":"Puhelinnumerosi ei vaikuta olevan kelvollinen. Tarkista ja yritä uudelleen.","too-many-sms":"Olet ylittänyt tunnin enimmäismäärän puhelinviestejä. Odota muutama minuutti ja yritä uudelleen.","too-many-voice":"Olet ylittänyt tunnin enimmäismäärän puhelinviestejä. Odota muutama minuutti ja yritä uudelleen.","transaction-not-found":"Rekisteröintitapahtumasi on vanhentunut, sinun täytyy aloittaa alusta.","no-phone":"Syötä puhelinnumero",noCode:"Syötä vahvistuskoodi",invalidCode:"Antamasi koodi on virheellinen. Yritä uudelleen.",unexpectedError:"Jokin meni pieleen. Yritä uudelleen.",resendSuccess:"Lähetimme uuden koodin puhelimeesi",enrollmentComplete:"MFA-rekisteröinti on valmis. Voit sulkea tämän sivun."},"mfa-phone-enrollment":{pageTitle:"Syötä puhelinnumerosi kirjautuaksesi puhelinkoodilla | ${clientName}",title:"Suojaa tilisi",description:"Syötä maakoodisi ja puhelinnumero, johon voimme lähettää 6-numeroisen koodin:",continueButtonText:"Jatka",smsButtonText:"Tekstiviesti",voiceButtonText:"Äänipuhelu",chooseMessageTypeText:"Miten haluat vastaanottaa koodin?",pickAuthenticatorText:"Kokeile toista menetelmää",placeholder:"Syötä puhelinnumerosi",logoAltText:"${companyName}",selectCountryCode:"Valitse maakoodi, tällä hetkellä asetettu ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Tekstiviestin lähettämisessä oli ongelma","send-voice-failed":"Äänipuhelun soittamisessa oli ongelma","sms-authenticator-error":"Emme pystyneet lähettämään tekstiviestiä. Yritä myöhemmin uudelleen.","invalid-phone-format":"Puhelinnumero voi sisältää vain numeroita.","invalid-phone":"Puhelinnumerosi ei vaikuta olevan kelvollinen. Tarkista ja yritä uudelleen.","too-many-sms":"Olet ylittänyt tunnin enimmäismäärän puhelinviestejä. Odota muutama minuutti ja yritä uudelleen.","too-many-voice":"Olet ylittänyt tunnin enimmäismäärän puhelinviestejä. Odota muutama minuutti ja yritä uudelleen.","transaction-not-found":"Rekisteröintitapahtumasi on vanhentunut, sinun täytyy aloittaa alusta.","no-phone":"Syötä puhelinnumero","phone-is-too-short":"Puhelinnumero on liian lyhyt","phone-is-too-long":"Puhelinnumero on liian pitkä"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Valitse vahvistusmenetelmä | ${clientName}",title:"Valitse vahvistusmenetelmä",description:"Valitse, miten haluat vahvistaa henkilöllisyytesi",authenticatorAppLabel:"Todennussovellus",authenticatorAppDescription:"Käytä todennussovellusta vahvistuskoodin saamiseksi",smsLabel:"Tekstiviesti",smsDescription:"Saat vahvistuskoodin puhelimeesi tekstiviestillä",passkeyLabel:"Tunnistautumisavain",passkeyDescription:"Käytä laitteesi biometriikkaa tai suojausavainta"}},"mfa-push":{"mfa-push":{description:"Lähetimme ilmoituksen laitteellesi",pageTitle:"Push-ilmoitus | ${clientName}",resendText:"Lähetä ilmoitus uudelleen",title:"Hyväksy pyyntö",useCodeText:"Syötä koodi manuaalisesti"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Jatka",codePlaceholder:"Palautuskoodi",description:"Syötä yksi palautuskoodeistasi","invalid-code":"Syöttämäsi palautuskoodi on virheellinen",pageTitle:"Palautuskoodi | ${clientName}",title:"Syötä palautuskoodi"}},"mfa-voice":{"mfa-voice":{buttonText:"Soita minulle",codePlaceholder:"Syötä koodi",description:"Soitamme numeroon ${phoneNumber} ja kerromme koodisi","invalid-code":"Syöttämäsi koodi on virheellinen",pageTitle:"Äänipuhelu | ${clientName}",title:"Vastaanota puhelu"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Yritä uudelleen",description:"Aseta turva-avaimesi ja seuraa ohjeita",pageTitle:"Turva-avain | ${clientName}",title:"Käytä turva-avaintasi"}},passkeys:i$,organizations:r$,"reset-password":{"reset-password":{backToLoginText:"Palaa takaisin",buttonText:"Lähetä salasanan palautussähköposti",codeExpired:"Salasanan palautuskoodisi on vanhentunut. Pyydä uusi koodi.",confirmPasswordLabel:"Vahvista salasana",confirmPasswordPlaceholder:"Vahvista salasana",description:"Napsauta alla olevaa painiketta, niin lähetämme ohjeet salasanasi palauttamiseen.",emailPlaceholder:"Sähköpostiosoite",failed:"Salasanan vaihto epäonnistui. Yritä uudelleen.","invalid-email-format":"Virheellinen sähköpostiosoite","no-email":"Sähköpostiosoite vaaditaan",pageTitle:"Vaihda salasana | ${clientName}",passwordLabel:"Uusi salasana",passwordPlaceholder:"Uusi salasana",passwordTooWeak:"Salasana on liian heikko",passwordsDidntMatch:"Salasanat eivät täsmää",successDescription:"Olemme lähettäneet salasanan palautuslinkin sähköpostiosoitteeseesi.",successTitle:"Salasanan palautussähköposti lähetetty",title:"Unohditko salasanan?","user-not-found":"Käyttäjää ei löytynyt"},"reset-password-code":{backToLoginText:"Takaisin kirjautumiseen",buttonText:"Vaihda salasana",codeLabel:"Palautuskoodi",codePlaceholder:"Syötä 6-numeroinen koodi",confirmPasswordLabel:"Vahvista salasana",confirmPasswordPlaceholder:"Vahvista salasana",defaultDescription:"Syötä sähköpostiisi lähetetty koodi ja valitse uusi salasana",description:"Lähetimme koodin osoitteeseen ${email}",failed:"Salasanan vaihto epäonnistui. Yritä uudelleen.",invalidCode:"Syöttämäsi koodi on virheellinen tai vanhentunut",noCode:"Syötä palautuskoodi",pageTitle:"Syötä palautuskoodi | ${clientName}",passwordLabel:"Uusi salasana",passwordPlaceholder:"Uusi salasana",passwordTooWeak:"Salasana on liian heikko",passwordsDidntMatch:"Salasanat eivät täsmää",resendFailed:"Koodin uudelleenlähetys epäonnistui. Yritä uudelleen.",resendSuccess:"Uusi koodi on lähetetty sähköpostiisi",resendText:"Lähetä koodi uudelleen",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",title:"Syötä palautuskoodi"}},signup:o$,"signup-id":{"signup-id":{buttonText:"Jatka",description:"Valitse salasana, jossa on isoja ja pieniä kirjaimia, numeroita ja symboleja.","email-already-exists":"Sähköposti on jo varattu",emailPlaceholder:"Sähköpostiosoite",federatedConnectionButtonText:"Jatka palvelulla ${connectionName}","invalid-email-format":"Virheellinen sähköpostiosoite",loginActionLinkText:"Kirjaudu sisään",loginActionText:"Onko sinulla jo tili?","no-email":"Sähköpostiosoite vaaditaan",pageTitle:"Rekisteröidy | ${clientName}",phonePlaceholder:"Puhelinnumero",separatorText:"tai",title:"Valitse salasana",usernamePlaceholder:"Käyttäjänimi"}},"signup-password":{"signup-password":{buttonText:"Jatka",description:"Valitse salasana, jossa on isoja ja pieniä kirjaimia, numeroita ja symboleja.",hidePasswordText:"Piilota salasana","no-password":"Salasana vaaditaan",pageTitle:"Rekisteröidy | ${clientName}","password-policy-not-met":"Salasana ei täytä vaatimuksia","password-too-weak":"Salasana on liian heikko",passwordPlaceholder:"Salasana",showPasswordText:"Näytä salasana",title:"Valitse salasana"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Jatka",codeLabel:"Vahvistuskoodi",codePlaceholder:"Syötä koodi",defaultDescription:"Syötä puhelimeesi lähetetty vahvistuskoodi",description:"Lähetimme koodin käyttäjälle ${username}","invalid-code":"Virheellinen koodi",noCode:"Syötä vahvistuskoodi",pageTitle:"Syötä koodi | ${clientName}",resendText:"Lähetä koodi uudelleen",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",title:"Tarkista puhelimesi",unexpectedError:"Odottamaton virhe tapahtui"}},status:s$},EF=Object.freeze(Object.defineProperty({__proto__:null,common:ZT,consent:XT,default:SF,invitation:e$,login:t$,mfa:n$,organizations:r$,passkeys:i$,signup:o$,status:s$},Symbol.toStringTag,{value:"Module"})),a$={common:{alertListTitle:"Avvisi",backText:"Torna indietro",cancelText:"Annulla",closeText:"Chiudi",contactSupportText:"Contatta l'assistenza",continueText:"Continua",copyrightText:"© ${currentYear} ${companyName}",errorText:"Si è verificato un errore",hidePasswordText:"Nascondi password",loadingText:"Caricamento...",orText:"o",privacyPolicyText:"Informativa sulla privacy",showPasswordText:"Mostra password",termsOfServiceText:"Termini di servizio",termsShortText:"Termini",tryAgainText:"Riprova"}},c$={consent:{buttonText:"Accetta",cancelButtonText:"Rifiuta",description:"${clientName} richiede l'accesso al tuo account",pageTitle:"Autorizza | ${clientName}",scopesTitle:"Questo permetterà a ${clientName} di:",title:"Autorizza ${clientName}"}},l$={invitation:{acceptButtonText:"Accetta invito",description:"${inviterName} ti ha invitato a unirti a ${organizationName} su ${clientName}",pageTitle:"Invito | ${clientName}",title:"Sei stato invitato"}},d$={login:{alertListTitle:"Avvisi",buttonText:"Continua",description:"Accedi a ${clientName}.",editEmailText:"Modifica",emailPlaceholder:"Indirizzo e-mail",enterACodeBtn:"Accedi con un codice",federatedConnectionButtonText:"Continua con ${connectionName}",footerLinkText:"Iscriviti",footerText:"Non hai un account?",forgotPasswordText:"Hai dimenticato la password?",hidePasswordText:"Nascondi password",invalidEmail:"Email non valida",invalidIdentifier:"Email o nome utente non valido",invitationDescription:"Accedi per accettare l'invito di ${inviterName} a unirti a ${companyName} su ${clientName}.",invitationTitle:"Sei stato invitato!",logoAltText:"${companyName}","no-email":"Inserisci un indirizzo email","no-password":"La password è obbligatoria",pageTitle:"Accedi | ${clientName}",passwordLoginNotAvailable:"L'autenticazione con password non è disponibile",passwordPlaceholder:"Password",phonePlaceholder:"Numero di telefono",separatorText:"o",sessionExpired:"La sessione è scaduta. Riprova.",showPasswordText:"Mostra password",signupActionLinkText:"Iscriviti",signupActionText:"Non hai un account?",title:"Benvenuto",tooManyFailedLogins:"Troppi tentativi di accesso falliti. Riprova più tardi.",unverifiedEmail:"Verifica il tuo indirizzo email prima di accedere",userAccountDoesNotExist:"L'account utente non esiste",usernamePlaceholder:"Nome utente o indirizzo email",usernameTooLong:"Il nome utente deve avere al massimo ${max} caratteri",usernameTooShort:"Il nome utente deve avere almeno ${min} caratteri",wrongCredentials:"Nome utente o password errati",passkeyButtonText:"Accedi con una passkey"}},u$={mfa:{backupCodeText:"Usa codice di backup",description:"Scegli un metodo di verifica",pageTitle:"Autenticazione a più fattori | ${clientName}",title:"Verifica la tua identità"}},p$={"passkey-enrollment-nudge":{title:"Proteggi il tuo account con una passkey",description:"Le passkey utilizzano la biometria o il PIN del tuo dispositivo per accedere più velocemente e in modo più sicuro.",enrollButtonText:"Configura passkey",snoozeButtonText:"Forse più tardi",optOutLinkText:"Non mostrare più",pageTitle:"Configura Passkey | ${clientName}"},"passkey-enrollment":{title:"Crea la tua passkey",description:"Segui le istruzioni del browser per creare una passkey per questo account.",errorMessage:"Creazione della passkey non riuscita. Riprova.",cancelLinkText:"Salta per ora",retryButtonText:"Riprova",enrollmentComplete:"La tua passkey è stata configurata con successo. Puoi chiudere questa pagina.",pageTitle:"Crea Passkey | ${clientName}"},"passkey-challenge":{title:"Accedi con passkey",description:"Segui le istruzioni del browser per verificare la tua identità.",errorMessage:"Autenticazione con passkey non riuscita. Riprova.",cancelLinkText:"Torna al login",retryButtonText:"Riprova",pageTitle:"Accedi con passkey | ${clientName}"}},f$={organizations:{description:"Scegli a quale organizzazione accedere",pageTitle:"Seleziona organizzazione | ${clientName}",searchPlaceholder:"Cerca organizzazioni",title:"Seleziona la tua organizzazione"}},h$={signup:{buttonText:"Iscriviti",confirmPasswordPlaceholder:"Conferma password",description:"Registrati per continuare","email-already-exists":"Questa email è già registrata",emailPlaceholder:"Indirizzo e-mail",federatedConnectionButtonText:"Continua con ${connectionName}",hidePasswordText:"Nascondi password","invalid-email-format":"Email non valida",loginActionLinkText:"Accedi",loginActionText:"Hai già un account?","no-email":"Inserisci un indirizzo email","no-password":"La password è obbligatoria","no-username":"Il nome utente è obbligatorio",pageTitle:"Registrati | ${clientName}",passwordPlaceholder:"Password",passwordsDidntMatch:"Le password non corrispondono",phonePlaceholder:"Numero di telefono",privacyPolicyLinkText:"Informativa sulla privacy",separatorText:"o",sessionExpired:"La sessione è scaduta. Riprova.",showPasswordText:"Mostra password",termsOfServiceLinkText:"Termini di servizio",termsText:"Registrandoti, accetti i nostri",title:"Crea il tuo account","username-already-exists":"Questo nome utente è già in uso",usernamePlaceholder:"Nome utente",verifyEmailText:"Controlla la tua email per verificare il tuo account"}},g$={status:{continueButtonText:"Continua",errorTitle:"Errore",pageTitle:"Stato | ${clientName}",successTitle:"Operazione riuscita",title:"Stato"}},xF={common:a$,consent:c$,"device-flow":{"device-flow":{buttonText:"Continua",codePlaceholder:"Inserisci il codice",description:"Inserisci il codice mostrato sul tuo dispositivo","expired-code":"Il codice è scaduto","invalid-code":"Il codice inserito non è valido",pageTitle:"Attivazione dispositivo | ${clientName}",title:"Attiva il tuo dispositivo"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Continua",codeLabel:"Codice di verifica",codePlaceholder:"Inserisci il codice",defaultDescription:"Inserisci il codice di verifica inviato alla tua email",description:"Abbiamo inviato un codice a ${email}","invalid-code":"Codice non valido",noCode:"Inserisci il codice di verifica",pageTitle:"Inserisci il codice | ${clientName}",resendText:"Reinvio del codice",sessionExpired:"La sessione è scaduta. Riprova.",title:"Controlla la tua email",unexpectedError:"Si è verificato un errore imprevisto"}},"email-verification":{"email-verification":{description:"Abbiamo inviato un'email a ${email}",pageTitle:"Verifica email | ${clientName}",resendText:"Reinvia email",successDescription:"La tua email è stata verificata con successo.",successTitle:"Email verificata",title:"Verificare l'e-mail"}},invitation:l$,login:d$,"login-id":{"login-id":{alertListTitle:"Avvisi","auth0-users-validation":"Qualcosa è andato storto, riprova più tardi","authentication-failure":"Siamo spiacenti, si è verificato un errore durante il tentativo di accesso",buttonText:"Continua","captcha-client-failure":"Non è stato possibile caricare la verifica di sicurezza. Riprova. (Codice errore: #{errorCode})","captcha-validation-failure":"Siamo spiacenti, si è verificato un errore durante la convalida della risposta captcha. Riprova.",captchaCodePlaceholder:"Inserisci il codice mostrato sopra","custom-script-error-code":"Qualcosa è andato storto, riprova più tardi.",description:"Accedi a ${clientName}.",editEmailText:"Modifica",emailPlaceholder:"Indirizzo e-mail",federatedConnectionButtonText:"Continua con ${connectionName}",footerLinkText:"Iscriviti",footerText:"Non hai un account?",forgotPasswordText:"Hai dimenticato la password?",hidePasswordText:"Nascondi password","invalid-captcha":"Risolvi la domanda di verifica per confermare che non sei un robot.","invalid-code":"Codice non valido","invalid-connection":"Connessione non valida","invalid-email-format":"Email non valida","invalid-email-phone":"Inserisci un indirizzo email o un numero di telefono valido. I numeri di telefono devono includere il prefisso internazionale.","invalid-email-phone-username":"Inserisci un indirizzo email, un numero di telefono o un nome utente valido. I numeri di telefono devono includere il prefisso internazionale.","invalid-email-username":"Inserisci un indirizzo email o un nome utente valido","invalid-expired-code":"Codice utente non valido o scaduto","invalid-login-id":"ID di accesso non valido","invalid-phone-username":"Inserisci un numero di telefono o un nome utente valido. I numeri di telefono devono includere il prefisso internazionale.","invalid-recaptcha":"Seleziona la casella per confermare che non sei un robot.","invalid-username":"Il nome utente può contenere solo caratteri alfanumerici o: '${characters}'. Il nome utente deve avere tra ${min} e ${max} caratteri.",invitationDescription:"Accedi per accettare l'invito di ${inviterName} a unirti a ${companyName} su ${clientName}.",invitationTitle:"Sei stato invitato!","ip-blocked":"Abbiamo rilevato un comportamento di accesso sospetto e ulteriori tentativi saranno bloccati. Contatta l'amministratore.",logoAltText:"${companyName}","no-db-connection":"Connessione non valida","no-email":"Inserisci un indirizzo email","no-email-phone":"È richiesto un indirizzo email o un numero di telefono","no-email-phone-username":"È richiesto un numero di telefono, un nome utente o un indirizzo email","no-email-username":"È richiesto un indirizzo email o un nome utente","no-password":"La password è obbligatoria","no-phone":"Inserisci un numero di telefono","no-phone-username":"È richiesto un numero di telefono o un nome utente","no-username":"Il nome utente è obbligatorio",pageTitle:"Accedi | ${clientName}","password-breached":"Abbiamo rilevato un potenziale problema di sicurezza con questo account. Per proteggere il tuo account, abbiamo impedito questo accesso. Reimposta la password per procedere.",passwordPlaceholder:"Password",phoneOrEmailPlaceholder:"Indirizzo e-mail o numero di telefono",phoneOrUsernameOrEmailPlaceholder:"Telefono, nome utente o email",phoneOrUsernamePlaceholder:"Numero di telefono o nome utente",phonePlaceholder:"Numero di telefono","same-user-login":"Troppi tentativi di accesso per questo utente. Attendi e riprova più tardi.",selectCountryCode:"Seleziona prefisso paese, attualmente impostato su ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"o",sessionExpired:"La sessione è scaduta. Riprova.",showPasswordText:"Mostra password",signupActionLinkText:"Iscriviti",signupActionText:"Non hai un account?",termsAndConditionsTemplate:'Continuando, accetti i nostri <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Termini e condizioni</a>.',title:"Benvenuto","user-blocked":"Il tuo account è stato bloccato dopo diversi tentativi di accesso consecutivi.",userAccountDoesNotExist:"L'account utente non esiste",usernameOnlyPlaceholder:"Nome utente",usernameOrEmailPlaceholder:"Nome utente o indirizzo email",usernamePlaceholder:"Nome utente",usernameTooLong:"Il nome utente deve avere al massimo ${max} caratteri",usernameTooShort:"Il nome utente deve avere almeno ${min} caratteri","wrong-credentials":"Nome utente o password errati","wrong-email-credentials":"Email o password errati","wrong-email-phone-credentials":"Indirizzo email, numero di telefono o password errati. I numeri di telefono devono includere il prefisso internazionale.","wrong-email-phone-username-credentials":"Indirizzo email, numero di telefono, nome utente o password errati. I numeri di telefono devono includere il prefisso internazionale.","wrong-email-username-credentials":"Indirizzo email, nome utente o password errati","wrong-phone-credentials":"Numero di telefono o password errati","wrong-phone-username-credentials":"Numero di telefono, nome utente o password errati. I numeri di telefono devono includere il prefisso internazionale.","wrong-username-credentials":"Nome utente o password errati",passkeyButtonText:"Accedi con una passkey"}},"login-password":{"login-password":{buttonText:"Accedi",description:"Accedi a ${clientName}",forgotPasswordText:"Hai dimenticato la password?",hidePasswordText:"Nascondi password","no-password":"La password è obbligatoria",pageTitle:"Accedi | ${clientName}","password-breached":"Abbiamo rilevato un potenziale problema di sicurezza con questo account. Per proteggere il tuo account, abbiamo impedito questo accesso. Reimposta la password per procedere.",passwordPlaceholder:"Password",showPasswordText:"Mostra password",signingInAs:"Accesso come ${email}",title:"Inserire la password",unverifiedEmail:"Verifica il tuo indirizzo email prima di accedere","user-blocked":"Il tuo account è stato bloccato dopo diversi tentativi di accesso consecutivi.","wrong-credentials":"Password errata"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"email",authMethodEmailOrPhone:"email o numero di telefono",authMethodPhone:"numero di telefono",description:"Accedi usando il tuo ${authMethod}",emailOrPhonePlaceholder:"Indirizzo email o numero di telefono",emailPlaceholder:"Indirizzo e-mail",invalidEmail:"Inserisci un indirizzo email valido",invalidIdentifier:"Inserisci un indirizzo email o un numero di telefono valido",invalidPhone:"Inserisci un numero di telefono valido con il prefisso internazionale",noEmail:"Inserisci il tuo indirizzo email",noPhone:"Inserisci il tuo numero di telefono",phonePlaceholder:"Numero di telefono",sessionExpired:"La sessione è scaduta. Riprova.",title:"Accedi con un codice",userAccountDoesNotExist:"L'account utente non esiste"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Clicca il link nella tua email per accedere",description:"Abbiamo inviato un link a ${username}. Cliccalo per accedere.",resendText:"Reinvia link",spamText:"Non hai ricevuto l'email? Controlla la cartella spam.",title:"Controlla la tua email"}},mfa:u$,"mfa-email":{"mfa-email":{buttonText:"Continua",codePlaceholder:"Inserisci il codice",description:"Abbiamo inviato un codice a ${email}","invalid-code":"Il codice inserito non è valido",pageTitle:"Verifica email | ${clientName}",resendText:"Reinvia codice",title:"Controlla la tua email"}},"mfa-otp":{"mfa-otp":{buttonText:"Continua",codePlaceholder:"Inserisci il codice",description:"Inserisci il codice a 6 cifre dalla tua app di autenticazione","invalid-code":"Il codice inserito non è valido",pageTitle:"Inserisci il codice | ${clientName}",title:"Inserisci il tuo codice"},"mfa-totp-enrollment":{title:"Configura l'autenticatore",description:"Scansiona il codice QR qui sotto con la tua app di autenticazione, poi inserisci il codice a 6 cifre per verificare",secretLabel:"Oppure inserisci questo codice manualmente:",codePlaceholder:"Inserisci il codice",continueButtonText:"Verifica e attiva","invalid-code":"Il codice inserito non è valido. Riprova.","transaction-not-found":"La tua transazione di registrazione è scaduta, dovrai ricominciare.",pageTitle:"Configura autenticatore | ${clientName}",unexpectedError:"Qualcosa è andato storto. Riprova.",enrollmentComplete:"La registrazione MFA è completata. Puoi chiudere questa pagina."},"mfa-totp-challenge":{title:"Verifica la tua identità",description:"Inserisci il codice a 6 cifre dalla tua app di autenticazione",codePlaceholder:"Inserisci il codice",continueButtonText:"Continua","invalid-code":"Il codice inserito non è valido","transaction-not-found":"La tua transazione di registrazione è scaduta, dovrai ricominciare.",unexpectedError:"Qualcosa è andato storto. Riprova.",pageTitle:"Verifica identità | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Usa il tuo numero di telefono per accedere | ${clientName}",title:"Verifica la tua identità",description:"Abbiamo inviato un codice a ${phoneNumber}",continueButtonText:"Continua",changePhoneText:"Scegli un altro numero di telefono.",smsButtonText:"Messaggio di testo",voiceButtonText:"Chiamata vocale",chooseMessageTypeText:"Come vuoi ricevere il codice?",pickAuthenticatorText:"Prova un altro metodo",logoAltText:"${companyName}",codePlaceholder:"Inserisci il codice","send-sms-failed":"Si è verificato un problema nell'invio dell'SMS","send-voice-failed":"Si è verificato un problema nell'effettuare la chiamata vocale","invalid-phone-format":"Il numero di telefono può contenere solo cifre.","invalid-phone":"Sembra che il tuo numero di telefono non sia valido. Controlla e riprova.","too-many-sms":"Hai superato il numero massimo di messaggi telefonici all'ora. Attendi qualche minuto e riprova.","too-many-voice":"Hai superato il numero massimo di messaggi telefonici all'ora. Attendi qualche minuto e riprova.","transaction-not-found":"La tua transazione di registrazione è scaduta, dovrai ricominciare.","no-phone":"Inserisci un numero di telefono",noCode:"Inserisci il codice di verifica",invalidCode:"Il codice inserito non è valido. Riprova.",unexpectedError:"Qualcosa è andato storto. Riprova.",resendSuccess:"Abbiamo inviato un nuovo codice al tuo telefono",enrollmentComplete:"La registrazione MFA è completata. Puoi chiudere questa pagina."},"mfa-phone-enrollment":{pageTitle:"Inserisci il tuo numero di telefono per accedere con un codice telefonico | ${clientName}",title:"Proteggi il tuo account",description:"Inserisci il prefisso del paese e il numero di telefono a cui possiamo inviare un codice a 6 cifre:",continueButtonText:"Continua",smsButtonText:"Messaggio di testo",voiceButtonText:"Chiamata vocale",chooseMessageTypeText:"Come vuoi ricevere il codice?",pickAuthenticatorText:"Prova un altro metodo",placeholder:"Inserisci il tuo numero di telefono",logoAltText:"${companyName}",selectCountryCode:"Seleziona prefisso paese, attualmente impostato su ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Si è verificato un problema nell'invio dell'SMS","send-voice-failed":"Si è verificato un problema nell'effettuare la chiamata vocale","sms-authenticator-error":"Non siamo riusciti a inviare l'SMS. Riprova più tardi.","invalid-phone-format":"Il numero di telefono può contenere solo cifre.","invalid-phone":"Sembra che il tuo numero di telefono non sia valido. Controlla e riprova.","too-many-sms":"Hai superato il numero massimo di messaggi telefonici all'ora. Attendi qualche minuto e riprova.","too-many-voice":"Hai superato il numero massimo di messaggi telefonici all'ora. Attendi qualche minuto e riprova.","transaction-not-found":"La tua transazione di registrazione è scaduta, dovrai ricominciare.","no-phone":"Inserisci un numero di telefono","phone-is-too-short":"Il numero di telefono è troppo corto","phone-is-too-long":"Il numero di telefono è troppo lungo"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Scegli il metodo di verifica | ${clientName}",title:"Scegli il metodo di verifica",description:"Seleziona come vuoi verificare la tua identità",authenticatorAppLabel:"App di autenticazione",authenticatorAppDescription:"Usa la tua app di autenticazione per ottenere un codice di verifica",smsLabel:"Messaggio di testo",smsDescription:"Ricevi un codice di verifica inviato al tuo telefono",passkeyLabel:"Passkey",passkeyDescription:"Usa la biometria del tuo dispositivo o una chiave di sicurezza"}},"mfa-push":{"mfa-push":{description:"Abbiamo inviato una notifica al tuo dispositivo",pageTitle:"Notifica push | ${clientName}",resendText:"Reinvia notifica",title:"Approva la richiesta",useCodeText:"Inserisci il codice manualmente"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Continua",codePlaceholder:"Codice di recupero",description:"Inserisci uno dei tuoi codici di recupero","invalid-code":"Il codice di recupero inserito non è valido",pageTitle:"Codice di recupero | ${clientName}",title:"Inserisci il codice di recupero"}},"mfa-voice":{"mfa-voice":{buttonText:"Chiamami",codePlaceholder:"Inserisci il codice",description:"Chiameremo ${phoneNumber} con il tuo codice","invalid-code":"Il codice inserito non è valido",pageTitle:"Chiamata vocale | ${clientName}",title:"Ricevi una telefonata"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Riprova",description:"Inserisci la tua chiave di sicurezza e segui le istruzioni",pageTitle:"Chiave di sicurezza | ${clientName}",title:"Usa la tua chiave di sicurezza"}},passkeys:p$,organizations:f$,"reset-password":{"reset-password":{backToLoginText:"Torna al login",buttonText:"Continua",codeExpired:"Il codice di reimpostazione della password è scaduto. Richiedine uno nuovo.",confirmPasswordLabel:"Conferma password",confirmPasswordPlaceholder:"Conferma password",description:"Inserisci la tua email per reimpostare la password",emailPlaceholder:"Indirizzo e-mail",failed:"Reimpostazione della password non riuscita. Riprova.","invalid-email-format":"Email non valida","no-email":"Inserisci un indirizzo email",pageTitle:"Reimposta password | ${clientName}",passwordLabel:"Nuova password",passwordPlaceholder:"Nuova password",passwordTooWeak:"La password è troppo debole",passwordsDidntMatch:"Le password non corrispondono",successDescription:"Abbiamo inviato un link per reimpostare la password al tuo indirizzo email.",successTitle:"Controlla la tua email",title:"Hai dimenticato la password?","user-not-found":"Utente non trovato"},"reset-password-code":{backToLoginText:"Torna al login",buttonText:"Reimposta password",codeLabel:"Codice di reimpostazione",codePlaceholder:"Inserisci il codice a 6 cifre",confirmPasswordLabel:"Conferma password",confirmPasswordPlaceholder:"Conferma password",defaultDescription:"Inserisci il codice inviato alla tua email e scegli una nuova password",description:"Abbiamo inviato un codice a ${email}",failed:"Reimpostazione della password non riuscita. Riprova.",invalidCode:"Il codice inserito non è valido o è scaduto",noCode:"Inserisci il codice di reimpostazione",pageTitle:"Inserisci il codice di reimpostazione | ${clientName}",passwordLabel:"Nuova password",passwordPlaceholder:"Nuova password",passwordTooWeak:"La password è troppo debole",passwordsDidntMatch:"Le password non corrispondono",resendFailed:"Impossibile reinviare il codice. Riprova.",resendSuccess:"Un nuovo codice è stato inviato alla tua email",resendText:"Reinvia codice",sessionExpired:"La sessione è scaduta. Riprova.",title:"Inserisci il codice di reimpostazione"}},signup:h$,"signup-id":{"signup-id":{buttonText:"Continua",description:"Registrati per continuare","email-already-exists":"Questa email è già registrata",emailPlaceholder:"Indirizzo e-mail",federatedConnectionButtonText:"Continua con ${connectionName}","invalid-email-format":"Email non valida",loginActionLinkText:"Accedi",loginActionText:"Hai già un account?","no-email":"Inserisci un indirizzo email",pageTitle:"Registrati | ${clientName}",phonePlaceholder:"Numero di telefono",separatorText:"o",title:"Crea il tuo account",usernamePlaceholder:"Nome utente"}},"signup-password":{"signup-password":{buttonText:"Continua",description:"Registrati per continuare",hidePasswordText:"Nascondi password","no-password":"La password è obbligatoria",pageTitle:"Registrati | ${clientName}","password-policy-not-met":"La password non soddisfa i requisiti","password-too-weak":"La password è troppo debole",passwordPlaceholder:"Password",showPasswordText:"Mostra password",title:"Crea la tua password"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Continua",codeLabel:"Codice di verifica",codePlaceholder:"Inserisci il codice",defaultDescription:"Inserisci il codice di verifica inviato al tuo telefono",description:"Abbiamo inviato un codice a ${username}","invalid-code":"Codice non valido",noCode:"Inserisci il codice di verifica",pageTitle:"Inserisci il codice | ${clientName}",resendText:"Reinvia codice",sessionExpired:"La sessione è scaduta. Riprova.",title:"Controlla il tuo telefono",unexpectedError:"Si è verificato un errore imprevisto"}},status:g$},CF=Object.freeze(Object.defineProperty({__proto__:null,common:a$,consent:c$,default:xF,invitation:l$,login:d$,mfa:u$,organizations:f$,passkeys:p$,signup:h$,status:g$},Symbol.toStringTag,{value:"Module"})),m$={common:{alertListTitle:"Varsler",backText:"Gå tilbake",cancelText:"Avbryt",closeText:"Lukk",contactSupportText:"Kontakt kundestøtte",continueText:"Fortsett",copyrightText:"© ${currentYear} ${companyName}",errorText:"Det oppstod en feil",hidePasswordText:"Skjul passord",loadingText:"Laster...",orText:"eller",privacyPolicyText:"Personvernerklæring",showPasswordText:"Vis passord",termsOfServiceText:"Vilkår for bruk",termsShortText:"Vilkår",tryAgainText:"Prøv igjen"}},y$={consent:{buttonText:"Godta",cancelButtonText:"Avslå",description:"${clientName} ber om tilgang til kontoen din",pageTitle:"Godkjenn | ${clientName}",scopesTitle:"Dette vil gi ${clientName} tillatelse til å:",title:"Godkjenn ${clientName}"}},_$={invitation:{acceptButtonText:"Godta invitasjon",description:"${inviterName} har invitert deg til å bli med i ${organizationName} på ${clientName}",pageTitle:"Invitasjon | ${clientName}",title:"Du har blitt invitert"}},w$={login:{alertListTitle:"Varsler",buttonText:"Fortsett",description:"Logg inn på ${clientName}.",editEmailText:"Rediger",emailPlaceholder:"E-postadresse",enterACodeBtn:"Logg inn med en kode",federatedConnectionButtonText:"Fortsett med ${connectionName}",footerLinkText:"Registrer deg",footerText:"Har du ikke en konto?",forgotPasswordText:"Har du glemt passordet?",hidePasswordText:"Skjul passord",invalidEmail:"Ugyldig e-postadresse",invalidIdentifier:"Ugyldig e-postadresse eller brukernavn",invitationDescription:"Logg inn for å godta ${inviterName} sin invitasjon til å bli med i ${companyName} på ${clientName}.",invitationTitle:"Du har blitt invitert!",logoAltText:"${companyName}","no-email":"Vennligst oppgi en e-postadresse","no-password":"Passord er påkrevd",pageTitle:"Logg inn | ${clientName}",passwordLoginNotAvailable:"Passordautentisering er ikke tilgjengelig",passwordPlaceholder:"Passord",phonePlaceholder:"Telefonnummer",separatorText:"eller",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",showPasswordText:"Vis passord",signupActionLinkText:"Registrer deg",signupActionText:"Har du ikke en konto?",title:"Velkommen",tooManyFailedLogins:"For mange mislykkede innloggingsforsøk. Vennligst prøv igjen senere.",unverifiedEmail:"Vennligst bekreft e-postadressen din før du logger inn",userAccountDoesNotExist:"Brukerkontoen finnes ikke",usernamePlaceholder:"Brukernavn eller e-postadresse",usernameTooLong:"Brukernavnet må være ${max} tegn eller færre",usernameTooShort:"Brukernavnet må være minst ${min} tegn",wrongCredentials:"Feil brukernavn eller passord",passkeyButtonText:"Logg inn med passkey"}},b$={mfa:{backupCodeText:"Bruk reservekode",description:"Velg en bekreftelsesmetode",pageTitle:"Flerfaktorautentisering | ${clientName}",title:"Bekreft identiteten din"}},v$={"passkey-enrollment-nudge":{title:"Sikre kontoen din med en passnøkkel",description:"Passnøkler bruker enhetens biometri eller PIN-kode for å logge deg inn raskere og sikrere.",enrollButtonText:"Sett opp passnøkkel",snoozeButtonText:"Kanskje senere",optOutLinkText:"Ikke vis dette igjen",pageTitle:"Sett Opp Passnøkkel | ${clientName}"},"passkey-enrollment":{title:"Opprett passnøkkelen din",description:"Følg instruksjonene fra nettleseren for å opprette en passnøkkel for denne kontoen.",errorMessage:"Kunne ikke opprette passnøkkel. Vennligst prøv igjen.",cancelLinkText:"Hopp over for nå",retryButtonText:"Prøv igjen",enrollmentComplete:"Passnøkkelen din er konfigurert. Du kan lukke denne siden.",pageTitle:"Opprett Passnøkkel | ${clientName}"},"passkey-challenge":{title:"Logg inn med passkey",description:"Følg instruksjonene fra nettleseren for å bekrefte identiteten din.",errorMessage:"Autentisering med passkey mislyktes. Vennligst prøv igjen.",cancelLinkText:"Tilbake til innlogging",retryButtonText:"Prøv igjen",pageTitle:"Logg inn med passkey | ${clientName}"}},A$={organizations:{description:"Velg hvilken organisasjon du vil logge inn på",pageTitle:"Velg organisasjon | ${clientName}",searchPlaceholder:"Søk etter organisasjoner",title:"Velg din organisasjon"}},k$={signup:{buttonText:"Registrer deg",confirmPasswordPlaceholder:"Bekreft passord",description:"Registrer deg for å fortsette","email-already-exists":"E-postadressen er allerede registrert",emailPlaceholder:"E-postadresse",federatedConnectionButtonText:"Fortsett med ${connectionName}",hidePasswordText:"Skjul passord","invalid-email-format":"Ugyldig e-postadresse",loginActionLinkText:"Logg inn",loginActionText:"Har du allerede en konto?","no-email":"Vennligst oppgi en e-postadresse","no-password":"Passord er påkrevd","no-username":"Brukernavn er påkrevd",pageTitle:"Registrer deg | ${clientName}",passwordPlaceholder:"Passord",passwordsDidntMatch:"Passordene samsvarer ikke",phonePlaceholder:"Telefonnummer",privacyPolicyLinkText:"Personvernerklæring",separatorText:"eller",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",showPasswordText:"Vis passord",termsOfServiceLinkText:"Vilkår for bruk",termsText:"Ved å registrere deg godtar du våre",title:"Opprett kontoen din","username-already-exists":"Dette brukernavnet er allerede tatt",usernamePlaceholder:"Brukernavn",verifyEmailText:"Sjekk e-posten din for å bekrefte kontoen"}},S$={status:{continueButtonText:"Fortsett",errorTitle:"Feil",pageTitle:"Status | ${clientName}",successTitle:"Vellykket",title:"Status"}},TF={common:m$,consent:y$,"device-flow":{"device-flow":{buttonText:"Fortsett",codePlaceholder:"Skriv inn kode",description:"Skriv inn koden som vises på enheten din","expired-code":"Koden har utløpt","invalid-code":"Koden du skrev inn er ugyldig",pageTitle:"Enhetsaktivering | ${clientName}",title:"Aktiver enheten din"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Fortsett",codeLabel:"Bekreftelseskode",codePlaceholder:"Skriv inn kode",defaultDescription:"Skriv inn bekreftelseskoden som ble sendt til e-posten din",description:"Vi sendte en kode til ${email}","invalid-code":"Ugyldig kode",noCode:"Vennligst skriv inn bekreftelseskoden",pageTitle:"Skriv inn kode | ${clientName}",resendText:"Send kode på nytt",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",title:"Sjekk e-posten din",unexpectedError:"En uventet feil oppstod"}},"email-verification":{"email-verification":{description:"Vi sendte en e-post til ${email}",pageTitle:"Bekreft e-post | ${clientName}",resendText:"Send e-post på nytt",successDescription:"E-postadressen din er bekreftet.",successTitle:"E-post bekreftet",title:"Bekreft e-posten din"}},invitation:_$,login:w$,"login-id":{"login-id":{alertListTitle:"Varsler","auth0-users-validation":"Noe gikk galt, vennligst prøv igjen senere","authentication-failure":"Beklager, noe gikk galt under innloggingsforsøket",buttonText:"Fortsett","captcha-client-failure":"Vi kunne ikke laste sikkerhetsutfordringen. Vennligst prøv igjen. (Feilkode: #{errorCode})","captcha-validation-failure":"Beklager, noe gikk galt under validering av captcha-svaret. Vennligst prøv igjen.",captchaCodePlaceholder:"Skriv inn koden som vises ovenfor","custom-script-error-code":"Noe gikk galt, vennligst prøv igjen senere.",description:"Logg inn på ${clientName}.",editEmailText:"Rediger",emailPlaceholder:"E-postadresse",federatedConnectionButtonText:"Fortsett med ${connectionName}",footerLinkText:"Registrer deg",footerText:"Har du ikke en konto?",forgotPasswordText:"Har du glemt passordet?",hidePasswordText:"Skjul passord","invalid-captcha":"Løs utfordringen for å bekrefte at du ikke er en robot.","invalid-code":"Ugyldig kode","invalid-connection":"Ugyldig tilkobling","invalid-email-format":"Ugyldig e-postadresse","invalid-email-phone":"Skriv inn en gyldig e-postadresse eller telefonnummer. Telefonnumre må inkludere landskode.","invalid-email-phone-username":"Skriv inn en gyldig e-postadresse, telefonnummer eller brukernavn. Telefonnumre må inkludere landskode.","invalid-email-username":"Skriv inn en gyldig e-postadresse eller brukernavn","invalid-expired-code":"Ugyldig eller utløpt brukerkode","invalid-login-id":"Ugyldig innloggings-ID","invalid-phone-username":"Skriv inn et gyldig telefonnummer eller brukernavn. Telefonnumre må inkludere landskode.","invalid-recaptcha":"Kryss av i boksen for å bekrefte at du ikke er en robot.","invalid-username":"Brukernavnet kan bare inneholde alfanumeriske tegn eller: '${characters}'. Brukernavnet må ha mellom ${min} og ${max} tegn.",invitationDescription:"Logg inn for å godta ${inviterName} sin invitasjon til å bli med i ${companyName} på ${clientName}.",invitationTitle:"Du har blitt invitert!","ip-blocked":"Vi har oppdaget mistenkelig innloggingsaktivitet, og videre forsøk vil bli blokkert. Vennligst kontakt administratoren.",logoAltText:"${companyName}","no-db-connection":"Ugyldig tilkobling","no-email":"Vennligst oppgi en e-postadresse","no-email-phone":"E-postadresse eller telefonnummer er påkrevd","no-email-phone-username":"Telefonnummer, brukernavn eller e-postadresse er påkrevd","no-email-username":"E-postadresse eller brukernavn er påkrevd","no-password":"Passord er påkrevd","no-phone":"Vennligst oppgi et telefonnummer","no-phone-username":"Telefonnummer eller brukernavn er påkrevd","no-username":"Brukernavn er påkrevd",pageTitle:"Logg inn | ${clientName}","password-breached":"Vi har oppdaget et potensielt sikkerhetsproblem med denne kontoen. For å beskytte kontoen din har vi forhindret denne innloggingen. Vennligst tilbakestill passordet ditt for å fortsette.",passwordPlaceholder:"Passord",phoneOrEmailPlaceholder:"E-post eller telefonnummer",phoneOrUsernameOrEmailPlaceholder:"Telefon, brukernavn eller e-post",phoneOrUsernamePlaceholder:"Telefonnummer eller brukernavn",phonePlaceholder:"Telefonnummer","same-user-login":"For mange innloggingsforsøk for denne brukeren. Vennligst vent og prøv igjen senere.",selectCountryCode:"Velg landskode, for øyeblikket satt til ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"eller",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",showPasswordText:"Vis passord",signupActionLinkText:"Registrer deg",signupActionText:"Har du ikke en konto?",termsAndConditionsTemplate:'Ved å fortsette godtar du våre <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">vilkår</a>.',title:"Velkommen","user-blocked":"Kontoen din har blitt blokkert etter flere påfølgende innloggingsforsøk.",userAccountDoesNotExist:"Brukerkontoen finnes ikke",usernameOnlyPlaceholder:"Brukernavn",usernameOrEmailPlaceholder:"Brukernavn eller e-postadresse",usernamePlaceholder:"Brukernavn eller e-postadresse",usernameTooLong:"Brukernavnet må være ${max} tegn eller færre",usernameTooShort:"Brukernavnet må være minst ${min} tegn","wrong-credentials":"Feil brukernavn eller passord","wrong-email-credentials":"Feil e-postadresse eller passord","wrong-email-phone-credentials":"Feil e-postadresse, telefonnummer eller passord. Telefonnumre må inkludere landskode.","wrong-email-phone-username-credentials":"Feil e-postadresse, telefonnummer, brukernavn eller passord. Telefonnumre må inkludere landskode.","wrong-email-username-credentials":"Feil e-postadresse, brukernavn eller passord","wrong-phone-credentials":"Feil telefonnummer eller passord","wrong-phone-username-credentials":"Feil telefonnummer, brukernavn eller passord. Telefonnumre må inkludere landskode.","wrong-username-credentials":"Feil brukernavn eller passord",passkeyButtonText:"Logg inn med passkey"}},"login-password":{"login-password":{buttonText:"Logg inn",description:"Logg inn på ${clientName}",forgotPasswordText:"Har du glemt passordet?",hidePasswordText:"Skjul passord","no-password":"Passord er påkrevd",pageTitle:"Logg inn | ${clientName}","password-breached":"Vi har oppdaget et potensielt sikkerhetsproblem med denne kontoen. For å beskytte kontoen din har vi forhindret denne innloggingen. Vennligst tilbakestill passordet ditt for å fortsette.",passwordPlaceholder:"Passord",showPasswordText:"Vis passord",signingInAs:"Logger inn som ${email}",title:"Oppgi passord",unverifiedEmail:"Vennligst bekreft e-postadressen din før du logger inn","user-blocked":"Kontoen din har blitt blokkert etter flere påfølgende innloggingsforsøk.","wrong-credentials":"Feil passord"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-post",authMethodEmailOrPhone:"e-post eller telefonnummer",authMethodPhone:"telefonnummer",description:"Logg inn med din ${authMethod}",emailOrPhonePlaceholder:"E-postadresse eller telefonnummer",emailPlaceholder:"E-postadresse",invalidEmail:"Vennligst oppgi en gyldig e-postadresse",invalidIdentifier:"Vennligst oppgi en gyldig e-postadresse eller telefonnummer",invalidPhone:"Vennligst oppgi et gyldig telefonnummer med landskode",noEmail:"Vennligst oppgi e-postadressen din",noPhone:"Vennligst oppgi telefonnummeret ditt",phonePlaceholder:"Telefonnummer",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",title:"Logg inn med en kode",userAccountDoesNotExist:"Brukerkontoen finnes ikke"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Klikk på lenken i e-posten for å logge inn",description:"Vi sendte en lenke til ${username}. Klikk på den for å logge inn.",resendText:"Send lenke på nytt",spamText:"Fikk du ikke e-posten? Sjekk søppelpostmappen.",title:"Sjekk e-posten din"}},mfa:b$,"mfa-email":{"mfa-email":{buttonText:"Fortsett",codePlaceholder:"Skriv inn kode",description:"Vi sendte en kode til ${email}","invalid-code":"Koden du skrev inn er ugyldig",pageTitle:"E-postbekreftelse | ${clientName}",resendText:"Send kode på nytt",title:"Sjekk e-posten din"}},"mfa-otp":{"mfa-otp":{buttonText:"Fortsett",codePlaceholder:"Skriv inn kode",description:"Skriv inn den 6-sifrede koden fra autentiseringsappen din","invalid-code":"Koden du skrev inn er ugyldig",pageTitle:"Skriv inn kode | ${clientName}",title:"Skriv inn koden din"},"mfa-totp-enrollment":{title:"Sett opp autentisering",description:"Skann QR-koden nedenfor med autentiseringsappen din, og skriv deretter inn den 6-sifrede koden for å verifisere",secretLabel:"Eller skriv inn denne koden manuelt:",codePlaceholder:"Skriv inn kode",continueButtonText:"Bekreft og aktiver","invalid-code":"Koden du skrev inn er ugyldig. Vennligst prøv igjen.","transaction-not-found":"Registreringsøkten din har utløpt, du må starte på nytt.",pageTitle:"Sett opp autentisering | ${clientName}",unexpectedError:"Noe gikk galt. Vennligst prøv igjen.",enrollmentComplete:"MFA-registreringen er fullført. Du kan lukke denne siden."},"mfa-totp-challenge":{title:"Bekreft identiteten din",description:"Skriv inn den 6-sifrede koden fra autentiseringsappen din",codePlaceholder:"Skriv inn kode",continueButtonText:"Fortsett","invalid-code":"Koden du skrev inn er ugyldig","transaction-not-found":"Registreringsøkten din har utløpt, du må starte på nytt.",unexpectedError:"Noe gikk galt. Vennligst prøv igjen.",pageTitle:"Bekreft identitet | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Bruk telefonnummeret ditt for å logge inn | ${clientName}",title:"Bekreft identiteten din",description:"Vi sendte en kode til ${phoneNumber}",continueButtonText:"Fortsett",changePhoneText:"Velg et annet telefonnummer.",smsButtonText:"Tekstmelding",voiceButtonText:"Taleanrop",chooseMessageTypeText:"Hvordan vil du motta koden?",pickAuthenticatorText:"Prøv en annen metode",logoAltText:"${companyName}",codePlaceholder:"Skriv inn kode","send-sms-failed":"Det oppstod et problem med å sende SMS-en","send-voice-failed":"Det oppstod et problem med å ringe taleanropet","invalid-phone-format":"Telefonnummeret kan bare inneholde sifre.","invalid-phone":"Det ser ut som telefonnummeret ditt ikke er gyldig. Sjekk og prøv igjen.","too-many-sms":"Du har overskredet maksimalt antall telefonmeldinger per time. Vent noen minutter og prøv igjen.","too-many-voice":"Du har overskredet maksimalt antall telefonmeldinger per time. Vent noen minutter og prøv igjen.","transaction-not-found":"Registreringstransaksjonen din har utløpt, du må starte på nytt.","no-phone":"Skriv inn et telefonnummer",noCode:"Vennligst skriv inn bekreftelseskoden",invalidCode:"Koden du skrev inn er ugyldig. Prøv igjen.",unexpectedError:"Noe gikk galt. Prøv igjen.",resendSuccess:"Vi sendte en ny kode til telefonen din",enrollmentComplete:"MFA-registreringen er fullført. Du kan lukke denne siden."},"mfa-phone-enrollment":{pageTitle:"Skriv inn telefonnummeret ditt for å logge inn med en telefonkode | ${clientName}",title:"Sikre kontoen din",description:"Skriv inn landskoden og telefonnummeret vi kan sende en 6-sifret kode til:",continueButtonText:"Fortsett",smsButtonText:"Tekstmelding",voiceButtonText:"Taleanrop",chooseMessageTypeText:"Hvordan vil du motta koden?",pickAuthenticatorText:"Prøv en annen metode",placeholder:"Skriv inn telefonnummeret ditt",logoAltText:"${companyName}",selectCountryCode:"Velg landskode, for øyeblikket satt til ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Det oppstod et problem med å sende SMS-en","send-voice-failed":"Det oppstod et problem med å ringe taleanropet","sms-authenticator-error":"Vi kunne ikke sende SMS-en. Prøv igjen senere.","invalid-phone-format":"Telefonnummeret kan bare inneholde sifre.","invalid-phone":"Det ser ut som telefonnummeret ditt ikke er gyldig. Sjekk og prøv igjen.","too-many-sms":"Du har overskredet maksimalt antall telefonmeldinger per time. Vent noen minutter og prøv igjen.","too-many-voice":"Du har overskredet maksimalt antall telefonmeldinger per time. Vent noen minutter og prøv igjen.","transaction-not-found":"Registreringstransaksjonen din har utløpt, du må starte på nytt.","no-phone":"Skriv inn et telefonnummer","phone-is-too-short":"Telefonnummeret er for kort","phone-is-too-long":"Telefonnummeret er for langt"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Velg bekreftelsesmetode | ${clientName}",title:"Velg bekreftelsesmetode",description:"Velg hvordan du vil bekrefte identiteten din",authenticatorAppLabel:"Autentiseringsapp",authenticatorAppDescription:"Bruk autentiseringsappen din for å få en bekreftelseskode",smsLabel:"Tekstmelding",smsDescription:"Få en bekreftelseskode sendt til telefonen din",passkeyLabel:"Passnøkkel",passkeyDescription:"Bruk enhetens biometri eller sikkerhetsnøkkel"}},"mfa-push":{"mfa-push":{description:"Vi sendte en varsling til enheten din",pageTitle:"Push-varsling | ${clientName}",resendText:"Send varsling på nytt",title:"Godkjenn forespørselen",useCodeText:"Skriv inn kode manuelt"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Fortsett",codePlaceholder:"Gjenopprettingskode",description:"Skriv inn en av gjenopprettingskodene dine","invalid-code":"Gjenopprettingskoden du skrev inn er ugyldig",pageTitle:"Gjenopprettingskode | ${clientName}",title:"Skriv inn gjenopprettingskode"}},"mfa-voice":{"mfa-voice":{buttonText:"Ring meg",codePlaceholder:"Skriv inn kode",description:"Vi ringer ${phoneNumber} med koden din","invalid-code":"Koden du skrev inn er ugyldig",pageTitle:"Taleanrop | ${clientName}",title:"Motta en telefonsamtale"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Prøv igjen",description:"Sett inn sikkerhetsnøkkelen din og følg instruksjonene",pageTitle:"Sikkerhetsnøkkel | ${clientName}",title:"Bruk sikkerhetsnøkkelen din"}},passkeys:v$,organizations:A$,"reset-password":{"reset-password":{backToLoginText:"Tilbake til innlogging",buttonText:"Fortsett",codeExpired:"Koden for tilbakestilling av passord har utløpt. Vennligst be om en ny.",confirmPasswordLabel:"Bekreft passord",confirmPasswordPlaceholder:"Bekreft passord",description:"Oppgi e-postadressen din for å tilbakestille passordet",emailPlaceholder:"E-postadresse",failed:"Tilbakestilling av passord mislyktes. Vennligst prøv igjen.","invalid-email-format":"Ugyldig e-postadresse","no-email":"Vennligst oppgi en e-postadresse",pageTitle:"Tilbakestill passord | ${clientName}",passwordLabel:"Nytt passord",passwordPlaceholder:"Nytt passord",passwordTooWeak:"Passordet er for svakt",passwordsDidntMatch:"Passordene samsvarer ikke",successDescription:"Vi har sendt en lenke for tilbakestilling av passord til e-postadressen din.",successTitle:"Sjekk e-posten din",title:"Har du glemt passordet?","user-not-found":"Brukeren ble ikke funnet"},"reset-password-code":{backToLoginText:"Tilbake til innlogging",buttonText:"Tilbakestill passord",codeLabel:"Tilbakestillingskode",codePlaceholder:"Skriv inn 6-sifret kode",confirmPasswordLabel:"Bekreft passord",confirmPasswordPlaceholder:"Bekreft passord",defaultDescription:"Skriv inn koden som ble sendt til e-posten din og velg et nytt passord",description:"Vi sendte en kode til ${email}",failed:"Tilbakestilling av passord mislyktes. Vennligst prøv igjen.",invalidCode:"Koden du skrev inn er ugyldig eller har utløpt",noCode:"Vennligst skriv inn tilbakestillingskoden",pageTitle:"Skriv inn tilbakestillingskode | ${clientName}",passwordLabel:"Nytt passord",passwordPlaceholder:"Nytt passord",passwordTooWeak:"Passordet er for svakt",passwordsDidntMatch:"Passordene samsvarer ikke",resendFailed:"Kunne ikke sende koden på nytt. Vennligst prøv igjen.",resendSuccess:"En ny kode har blitt sendt til e-posten din",resendText:"Send kode på nytt",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",title:"Skriv inn tilbakestillingskode"}},signup:k$,"signup-id":{"signup-id":{buttonText:"Fortsett",description:"Registrer deg for å fortsette","email-already-exists":"E-postadressen er allerede registrert",emailPlaceholder:"E-postadresse",federatedConnectionButtonText:"Fortsett med ${connectionName}","invalid-email-format":"Ugyldig e-postadresse",loginActionLinkText:"Logg inn",loginActionText:"Har du allerede en konto?","no-email":"Vennligst oppgi en e-postadresse",pageTitle:"Registrer deg | ${clientName}",phonePlaceholder:"Telefonnummer",separatorText:"eller",title:"Opprett kontoen din",usernamePlaceholder:"Brukernavn"}},"signup-password":{"signup-password":{buttonText:"Fortsett",description:"Opprett et passord for å fortsette",hidePasswordText:"Skjul passord","no-password":"Passord er påkrevd",pageTitle:"Registrer deg | ${clientName}","password-policy-not-met":"Passordet oppfyller ikke kravene","password-too-weak":"Passordet er for svakt",passwordPlaceholder:"Passord",showPasswordText:"Vis passord",title:"Opprett passordet ditt"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Fortsett",codeLabel:"Bekreftelseskode",codePlaceholder:"Skriv inn kode",defaultDescription:"Skriv inn bekreftelseskoden som ble sendt til telefonen din",description:"Vi sendte en kode til ${username}","invalid-code":"Ugyldig kode",noCode:"Vennligst skriv inn bekreftelseskoden",pageTitle:"Skriv inn kode | ${clientName}",resendText:"Send kode på nytt",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",title:"Sjekk telefonen din",unexpectedError:"En uventet feil oppstod"}},status:S$},$F=Object.freeze(Object.defineProperty({__proto__:null,common:m$,consent:y$,default:TF,invitation:_$,login:w$,mfa:b$,organizations:A$,passkeys:v$,signup:k$,status:S$},Symbol.toStringTag,{value:"Module"})),E$={common:{alertListTitle:"Powiadomienia",backText:"Wróć",cancelText:"Anuluj",closeText:"Zamknij",contactSupportText:"Potrzebujesz pomocy?",continueText:"Kontynuuj",copyrightText:"© ${currentYear} ${companyName}",errorText:"Coś poszło nie tak. Spróbuj ponownie.",hidePasswordText:"Ukryj hasło",loadingText:"Ładowanie...",orText:"lub",privacyPolicyText:"Polityka prywatności",showPasswordText:"Pokaż hasło",termsOfServiceText:"Regulamin",termsShortText:"Zasady",tryAgainText:"Spróbuj ponownie"}},x$={consent:{buttonText:"Zaakceptuj",cancelButtonText:"Odmów",description:"${clientName} prosi o dostęp do Twojego konta",pageTitle:"Autoryzacja | ${clientName}",scopesTitle:"Umożliwi to ${clientName}:",title:"Autoryzuj ${clientName}"}},C$={invitation:{acceptButtonText:"Przyjmij zaproszenie",description:"${inviterName} zaprosił Cię do dołączenia do ${organizationName} w ${clientName}",pageTitle:"Zaproszenie | ${clientName}",title:"Otrzymałeś zaproszenie"}},T$={login:{alertListTitle:"Powiadomienia",buttonText:"Kontynuuj",description:"Zaloguj się do ${clientName}.",editEmailText:"Edytuj",emailPlaceholder:"Adres e-mail",enterACodeBtn:"Zaloguj się kodem",federatedConnectionButtonText:"Kontynuuj z ${connectionName}",footerLinkText:"Zarejestruj się",footerText:"Nie masz konta?",forgotPasswordText:"Zapomniałeś hasła?",hidePasswordText:"Ukryj hasło",invalidEmail:"Nieprawidłowy adres e-mail",invalidIdentifier:"Nieprawidłowy adres e-mail lub nazwa użytkownika",invitationDescription:"Zaloguj się, aby przyjąć zaproszenie od ${inviterName} do dołączenia do ${companyName} w ${clientName}.",invitationTitle:"Otrzymałeś zaproszenie!",logoAltText:"${companyName}","no-email":"Wprowadź adres e-mail","no-password":"Hasło jest wymagane",pageTitle:"Logowanie | ${clientName}",passwordLoginNotAvailable:"Logowanie hasłem jest niedostępne",passwordPlaceholder:"Hasło",phonePlaceholder:"Numer telefonu",separatorText:"lub",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",showPasswordText:"Pokaż hasło",signupActionLinkText:"Zarejestruj się",signupActionText:"Nie masz konta?",title:"Witamy",tooManyFailedLogins:"Zbyt wiele nieudanych prób logowania. Spróbuj ponownie później.",unverifiedEmail:"Zweryfikuj swój adres e-mail przed zalogowaniem",userAccountDoesNotExist:"Konto użytkownika nie istnieje",usernamePlaceholder:"Nazwa użytkownika lub adres e-mail",usernameTooLong:"Nazwa użytkownika musi mieć maksymalnie ${max} znaków",usernameTooShort:"Nazwa użytkownika musi mieć co najmniej ${min} znaków",wrongCredentials:"Nieprawidłowa nazwa użytkownika lub hasło",passkeyButtonText:"Zaloguj się za pomocą passkey"}},$$={mfa:{backupCodeText:"Użyj kodu zapasowego",description:"Wybierz metodę weryfikacji",pageTitle:"Uwierzytelnianie wieloskładnikowe | ${clientName}",title:"Zweryfikuj swoją tożsamość"}},I$={"passkey-enrollment-nudge":{title:"Zabezpiecz swoje konto kluczem dostępu",description:"Klucze dostępu wykorzystują biometrię lub PIN urządzenia, aby logować się szybciej i bezpieczniej.",enrollButtonText:"Skonfiguruj klucz dostępu",snoozeButtonText:"Może później",optOutLinkText:"Nie pokazuj ponownie",pageTitle:"Konfiguracja Klucza Dostępu | ${clientName}"},"passkey-enrollment":{title:"Utwórz klucz dostępu",description:"Postępuj zgodnie z instrukcjami przeglądarki, aby utworzyć klucz dostępu dla tego konta.",errorMessage:"Nie udało się utworzyć klucza dostępu. Spróbuj ponownie.",cancelLinkText:"Pomiń na razie",retryButtonText:"Spróbuj ponownie",enrollmentComplete:"Twój klucz dostępu został pomyślnie skonfigurowany. Możesz zamknąć tę stronę.",pageTitle:"Tworzenie Klucza Dostępu | ${clientName}"},"passkey-challenge":{title:"Zaloguj się za pomocą passkey",description:"Postępuj zgodnie z instrukcjami przeglądarki, aby zweryfikować swoją tożsamość.",errorMessage:"Uwierzytelnianie za pomocą passkey nie powiodło się. Spróbuj ponownie.",cancelLinkText:"Powrót do logowania",retryButtonText:"Spróbuj ponownie",pageTitle:"Logowanie za pomocą passkey | ${clientName}"}},z$={organizations:{description:"Wybierz organizację, do której chcesz się zalogować",pageTitle:"Wybierz organizację | ${clientName}",searchPlaceholder:"Szukaj organizacji",title:"Wybierz swoją organizację"}},P$={signup:{buttonText:"Zarejestruj się",confirmPasswordPlaceholder:"Potwierdź hasło",description:"Zarejestruj się, aby kontynuować","email-already-exists":"Ten adres e-mail jest już zarejestrowany",emailPlaceholder:"Adres e-mail",federatedConnectionButtonText:"Kontynuuj z ${connectionName}",hidePasswordText:"Ukryj hasło","invalid-email-format":"Nieprawidłowy adres e-mail",loginActionLinkText:"Zaloguj się",loginActionText:"Masz już konto?","no-email":"Wprowadź adres e-mail","no-password":"Hasło jest wymagane","no-username":"Nazwa użytkownika jest wymagana",pageTitle:"Rejestracja | ${clientName}",passwordPlaceholder:"Hasło",passwordsDidntMatch:"Hasła nie są zgodne",phonePlaceholder:"Numer telefonu",privacyPolicyLinkText:"Polityka prywatności",separatorText:"lub",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",showPasswordText:"Pokaż hasło",termsOfServiceLinkText:"Regulamin",termsText:"Rejestrując się, akceptujesz nasz",title:"Utwórz konto","username-already-exists":"Ta nazwa użytkownika jest już zajęta",usernamePlaceholder:"Nazwa użytkownika",verifyEmailText:"Sprawdź swoją pocztę, aby zweryfikować konto"}},N$={status:{continueButtonText:"Kontynuuj",errorTitle:"Błąd",pageTitle:"Status | ${clientName}",successTitle:"Sukces",title:"Status"}},IF={common:E$,consent:x$,"device-flow":{"device-flow":{buttonText:"Kontynuuj",codePlaceholder:"Wprowadź kod",description:"Wprowadź kod wyświetlony na Twoim urządzeniu","expired-code":"Kod wygasł","invalid-code":"Wprowadzony kod jest nieprawidłowy",pageTitle:"Aktywacja urządzenia | ${clientName}",title:"Aktywuj swoje urządzenie"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Kontynuuj",codeLabel:"Kod weryfikacyjny",codePlaceholder:"Wprowadź kod",defaultDescription:"Wprowadź kod weryfikacyjny wysłany na Twój adres e-mail",description:"Wysłaliśmy kod na ${email}","invalid-code":"Nieprawidłowy kod",noCode:"Wprowadź kod weryfikacyjny",pageTitle:"Wprowadź kod | ${clientName}",resendText:"Wyślij ponownie kod",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",title:"Sprawdź swoją pocztę",unexpectedError:"Wystąpił nieoczekiwany błąd"}},"email-verification":{"email-verification":{description:"Wysłaliśmy wiadomość na ${email}",pageTitle:"Weryfikacja e-mail | ${clientName}",resendText:"Wyślij ponownie e-mail",successDescription:"Twój adres e-mail został pomyślnie zweryfikowany.",successTitle:"E-mail zweryfikowany",title:"Zweryfikuj swój adres e-mail"}},invitation:C$,login:T$,"login-id":{"login-id":{alertListTitle:"Powiadomienia","auth0-users-validation":"Coś poszło nie tak, spróbuj ponownie później","authentication-failure":"Przepraszamy, wystąpił błąd podczas logowania",buttonText:"Kontynuuj","captcha-client-failure":"Nie udało się załadować weryfikacji bezpieczeństwa. Spróbuj ponownie. (Kod błędu: #{errorCode})","captcha-validation-failure":"Przepraszamy, wystąpił błąd podczas weryfikacji captcha. Spróbuj ponownie.",captchaCodePlaceholder:"Wprowadź kod widoczny powyżej","custom-script-error-code":"Coś poszło nie tak, spróbuj ponownie później.",description:"Zaloguj się do ${clientName}.",editEmailText:"Edytuj",emailPlaceholder:"Adres e-mail",federatedConnectionButtonText:"Kontynuuj z ${connectionName}",footerLinkText:"Zarejestruj się",footerText:"Nie masz konta?",forgotPasswordText:"Zapomniałeś hasła?",hidePasswordText:"Ukryj hasło","invalid-captcha":"Rozwiąż zadanie, aby potwierdzić, że nie jesteś robotem.","invalid-code":"Nieprawidłowy kod","invalid-connection":"Nieprawidłowe połączenie","invalid-email-format":"Nieprawidłowy adres e-mail","invalid-email-phone":"Wprowadź prawidłowy adres e-mail lub numer telefonu. Numery telefonów muszą zawierać kod kraju.","invalid-email-phone-username":"Wprowadź prawidłowy adres e-mail, numer telefonu lub nazwę użytkownika. Numery telefonów muszą zawierać kod kraju.","invalid-email-username":"Wprowadź prawidłowy adres e-mail lub nazwę użytkownika","invalid-expired-code":"Nieprawidłowy lub wygasły kod użytkownika","invalid-login-id":"Wprowadzono nieprawidłowy identyfikator logowania","invalid-phone-username":"Wprowadź prawidłowy numer telefonu lub nazwę użytkownika. Numery telefonów muszą zawierać kod kraju.","invalid-recaptcha":"Zaznacz pole wyboru, aby potwierdzić, że nie jesteś robotem.","invalid-username":"Nazwa użytkownika może zawierać tylko znaki alfanumeryczne lub: '${characters}'. Nazwa użytkownika powinna mieć od ${min} do ${max} znaków.",invitationDescription:"Zaloguj się, aby przyjąć zaproszenie od ${inviterName} do dołączenia do ${companyName} w ${clientName}.",invitationTitle:"Otrzymałeś zaproszenie!","ip-blocked":"Wykryliśmy podejrzaną aktywność logowania i dalsze próby zostaną zablokowane. Skontaktuj się z administratorem.",logoAltText:"${companyName}","no-db-connection":"Nieprawidłowe połączenie","no-email":"Wprowadź adres e-mail","no-email-phone":"Adres e-mail lub numer telefonu jest wymagany","no-email-phone-username":"Numer telefonu, nazwa użytkownika lub adres e-mail jest wymagany","no-email-username":"Adres e-mail lub nazwa użytkownika jest wymagany","no-password":"Hasło jest wymagane","no-phone":"Wprowadź numer telefonu","no-phone-username":"Numer telefonu lub nazwa użytkownika jest wymagany","no-username":"Nazwa użytkownika jest wymagana",pageTitle:"Logowanie | ${clientName}","password-breached":"Wykryliśmy potencjalny problem z bezpieczeństwem tego konta. Aby chronić Twoje konto, zablokowano to logowanie. Zresetuj hasło, aby kontynuować.",passwordPlaceholder:"Hasło",phoneOrEmailPlaceholder:"E-mail lub numer telefonu",phoneOrUsernameOrEmailPlaceholder:"Telefon, nazwa użytkownika lub e-mail",phoneOrUsernamePlaceholder:"Numer telefonu lub nazwa użytkownika",phonePlaceholder:"Numer telefonu","same-user-login":"Zbyt wiele prób logowania dla tego użytkownika. Poczekaj chwilę i spróbuj ponownie.",selectCountryCode:"Wybierz kod kraju, aktualnie ustawiony na ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"lub",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",showPasswordText:"Pokaż hasło",signupActionLinkText:"Zarejestruj się",signupActionText:"Nie masz konta?",termsAndConditionsTemplate:'Kontynuując, akceptujesz nasze <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Zasady i warunki</a>.',title:"Witamy","user-blocked":"Twoje konto zostało zablokowane po wielu kolejnych nieudanych próbach logowania.",userAccountDoesNotExist:"Konto użytkownika nie istnieje",usernameOnlyPlaceholder:"Nazwa użytkownika",usernameOrEmailPlaceholder:"Nazwa użytkownika lub adres e-mail",usernamePlaceholder:"Nazwa użytkownika",usernameTooLong:"Nazwa użytkownika musi mieć maksymalnie ${max} znaków",usernameTooShort:"Nazwa użytkownika musi mieć co najmniej ${min} znaków","wrong-credentials":"Nieprawidłowa nazwa użytkownika lub hasło","wrong-email-credentials":"Nieprawidłowy adres e-mail lub hasło","wrong-email-phone-credentials":"Nieprawidłowy adres e-mail, numer telefonu lub hasło. Numery telefonów muszą zawierać kod kraju.","wrong-email-phone-username-credentials":"Nieprawidłowy adres e-mail, numer telefonu, nazwa użytkownika lub hasło. Numery telefonów muszą zawierać kod kraju.","wrong-email-username-credentials":"Nieprawidłowy adres e-mail, nazwa użytkownika lub hasło","wrong-phone-credentials":"Nieprawidłowy numer telefonu lub hasło","wrong-phone-username-credentials":"Nieprawidłowy numer telefonu, nazwa użytkownika lub hasło. Numery telefonów muszą zawierać kod kraju.","wrong-username-credentials":"Nieprawidłowa nazwa użytkownika lub hasło",passkeyButtonText:"Zaloguj się za pomocą passkey"}},"login-password":{"login-password":{buttonText:"Zaloguj się",description:"Zaloguj się do ${clientName}",forgotPasswordText:"Zapomniałeś hasła?",hidePasswordText:"Ukryj hasło","no-password":"Hasło jest wymagane",pageTitle:"Logowanie | ${clientName}","password-breached":"Wykryliśmy potencjalny problem z bezpieczeństwem tego konta. Aby chronić Twoje konto, zablokowano to logowanie. Zresetuj hasło, aby kontynuować.",passwordPlaceholder:"Hasło",showPasswordText:"Pokaż hasło",signingInAs:"Logujesz się jako ${email}",title:"Wprowadź hasło",unverifiedEmail:"Zweryfikuj swój adres e-mail przed zalogowaniem","user-blocked":"Twoje konto zostało zablokowane po wielu kolejnych nieudanych próbach logowania.","wrong-credentials":"Nieprawidłowe hasło"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-mail",authMethodEmailOrPhone:"e-mail lub numer telefonu",authMethodPhone:"numer telefonu",description:"Zaloguj się za pomocą swojego ${authMethod}",emailOrPhonePlaceholder:"Adres e-mail lub numer telefonu",emailPlaceholder:"Adres e-mail",invalidEmail:"Wprowadź prawidłowy adres e-mail",invalidIdentifier:"Wprowadź prawidłowy adres e-mail lub numer telefonu",invalidPhone:"Wprowadź prawidłowy numer telefonu z kodem kraju",noEmail:"Wprowadź swój adres e-mail",noPhone:"Wprowadź swój numer telefonu",phonePlaceholder:"Numer telefonu",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",title:"Zaloguj się kodem",userAccountDoesNotExist:"Konto użytkownika nie istnieje"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Kliknij link w wiadomości e-mail, aby się zalogować",description:"Wysłaliśmy link na ${username}. Kliknij go, aby się zalogować.",resendText:"Wyślij ponownie link",spamText:"Nie otrzymałeś wiadomości? Sprawdź folder spam.",title:"Sprawdź swoją pocztę"}},mfa:$$,"mfa-email":{"mfa-email":{buttonText:"Kontynuuj",codePlaceholder:"Wprowadź kod",description:"Wysłaliśmy kod na ${email}","invalid-code":"Wprowadzony kod jest nieprawidłowy",pageTitle:"Weryfikacja e-mail | ${clientName}",resendText:"Wyślij ponownie kod",title:"Sprawdź swoją pocztę"}},"mfa-otp":{"mfa-otp":{buttonText:"Kontynuuj",codePlaceholder:"Wprowadź kod",description:"Wprowadź 6-cyfrowy kod z aplikacji uwierzytelniającej","invalid-code":"Wprowadzony kod jest nieprawidłowy",pageTitle:"Wprowadź kod | ${clientName}",title:"Wprowadź swój kod"},"mfa-totp-enrollment":{title:"Skonfiguruj aplikację uwierzytelniającą",description:"Zeskanuj poniższy kod QR za pomocą aplikacji uwierzytelniającej, a następnie wprowadź 6-cyfrowy kod w celu weryfikacji",secretLabel:"Lub wprowadź ten kod ręcznie:",codePlaceholder:"Wprowadź kod",continueButtonText:"Zweryfikuj i aktywuj","invalid-code":"Wprowadzony kod jest nieprawidłowy. Spróbuj ponownie.","transaction-not-found":"Twoja transakcja rejestracji wygasła, musisz zacząć od nowa.",pageTitle:"Konfiguracja uwierzytelniania | ${clientName}",unexpectedError:"Coś poszło nie tak. Spróbuj ponownie.",enrollmentComplete:"Rejestracja MFA została zakończona. Możesz zamknąć tę stronę."},"mfa-totp-challenge":{title:"Zweryfikuj swoją tożsamość",description:"Wprowadź 6-cyfrowy kod z aplikacji uwierzytelniającej",codePlaceholder:"Wprowadź kod",continueButtonText:"Kontynuuj","invalid-code":"Wprowadzony kod jest nieprawidłowy","transaction-not-found":"Twoja transakcja rejestracji wygasła, musisz zacząć od nowa.",unexpectedError:"Coś poszło nie tak. Spróbuj ponownie.",pageTitle:"Weryfikacja tożsamości | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Użyj swojego numeru telefonu, aby się zalogować | ${clientName}",title:"Zweryfikuj swoją tożsamość",description:"Wysłaliśmy kod na ${phoneNumber}",continueButtonText:"Kontynuuj",changePhoneText:"Wybierz inny numer telefonu.",smsButtonText:"Wiadomość tekstowa",voiceButtonText:"Połączenie głosowe",chooseMessageTypeText:"Jak chcesz otrzymać kod?",pickAuthenticatorText:"Wypróbuj inną metodę",logoAltText:"${companyName}",codePlaceholder:"Wpisz kod","send-sms-failed":"Wystąpił problem z wysłaniem SMS-a","send-voice-failed":"Wystąpił problem z wykonaniem połączenia głosowego","invalid-phone-format":"Numer telefonu może zawierać tylko cyfry.","invalid-phone":"Wygląda na to, że Twój numer telefonu jest nieprawidłowy. Sprawdź i spróbuj ponownie.","too-many-sms":"Przekroczono maksymalną liczbę wiadomości telefonicznych na godzinę. Poczekaj kilka minut i spróbuj ponownie.","too-many-voice":"Przekroczono maksymalną liczbę połączeń telefonicznych na godzinę. Poczekaj kilka minut i spróbuj ponownie.","transaction-not-found":"Twoja transakcja rejestracji wygasła, musisz zacząć od nowa.","no-phone":"Wpisz numer telefonu",noCode:"Wprowadź kod weryfikacyjny",invalidCode:"Wprowadzony kod jest nieprawidłowy. Spróbuj ponownie.",unexpectedError:"Coś poszło nie tak. Spróbuj ponownie.",resendSuccess:"Wysłaliśmy nowy kod na Twój telefon",enrollmentComplete:"Rejestracja MFA została zakończona. Możesz zamknąć tę stronę."},"mfa-phone-enrollment":{pageTitle:"Wpisz swój numer telefonu, aby zalogować się kodem telefonicznym | ${clientName}",title:"Zabezpiecz swoje konto",description:"Wpisz kod kraju i numer telefonu, na który możemy wysłać 6-cyfrowy kod:",continueButtonText:"Kontynuuj",smsButtonText:"Wiadomość tekstowa",voiceButtonText:"Połączenie głosowe",chooseMessageTypeText:"Jak chcesz otrzymać kod?",pickAuthenticatorText:"Wypróbuj inną metodę",placeholder:"Wpisz swój numer telefonu",logoAltText:"${companyName}",selectCountryCode:"Wybierz kod kraju, aktualnie ustawiony na ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Wystąpił problem z wysłaniem SMS-a","send-voice-failed":"Wystąpił problem z wykonaniem połączenia głosowego","sms-authenticator-error":"Nie udało się wysłać SMS-a. Spróbuj ponownie później.","invalid-phone-format":"Numer telefonu może zawierać tylko cyfry.","invalid-phone":"Wygląda na to, że Twój numer telefonu jest nieprawidłowy. Sprawdź i spróbuj ponownie.","too-many-sms":"Przekroczono maksymalną liczbę wiadomości telefonicznych na godzinę. Poczekaj kilka minut i spróbuj ponownie.","too-many-voice":"Przekroczono maksymalną liczbę połączeń telefonicznych na godzinę. Poczekaj kilka minut i spróbuj ponownie.","transaction-not-found":"Twoja transakcja rejestracji wygasła, musisz zacząć od nowa.","no-phone":"Wpisz numer telefonu","phone-is-too-short":"Numer telefonu jest za krótki","phone-is-too-long":"Numer telefonu jest za długi"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Wybierz metodę weryfikacji | ${clientName}",title:"Wybierz metodę weryfikacji",description:"Wybierz, w jaki sposób chcesz zweryfikować swoją tożsamość",authenticatorAppLabel:"Aplikacja uwierzytelniająca",authenticatorAppDescription:"Użyj aplikacji uwierzytelniającej, aby uzyskać kod weryfikacyjny",smsLabel:"Wiadomość tekstowa",smsDescription:"Otrzymaj kod weryfikacyjny wysłany na swój telefon",passkeyLabel:"Klucz dostępu",passkeyDescription:"Użyj biometrii urządzenia lub klucza bezpieczeństwa"}},"mfa-push":{"mfa-push":{description:"Wysłaliśmy powiadomienie na Twoje urządzenie",pageTitle:"Powiadomienie push | ${clientName}",resendText:"Wyślij ponownie powiadomienie",title:"Zatwierdź żądanie",useCodeText:"Wprowadź kod ręcznie"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Kontynuuj",codePlaceholder:"Kod odzyskiwania",description:"Wprowadź jeden z kodów odzyskiwania","invalid-code":"Wprowadzony kod odzyskiwania jest nieprawidłowy",pageTitle:"Kod odzyskiwania | ${clientName}",title:"Wprowadź kod odzyskiwania"}},"mfa-voice":{"mfa-voice":{buttonText:"Zadzwoń do mnie",codePlaceholder:"Wprowadź kod",description:"Zadzwonimy na ${phoneNumber} z Twoim kodem","invalid-code":"Wprowadzony kod jest nieprawidłowy",pageTitle:"Połączenie głosowe | ${clientName}",title:"Odbierz połączenie telefoniczne"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Spróbuj ponownie",description:"Włóż klucz bezpieczeństwa i postępuj zgodnie z instrukcjami",pageTitle:"Klucz bezpieczeństwa | ${clientName}",title:"Użyj klucza bezpieczeństwa"}},passkeys:I$,organizations:z$,"reset-password":{"reset-password":{backToLoginText:"Wróć do logowania",buttonText:"Kontynuuj",codeExpired:"Kod resetu hasła wygasł. Poproś o nowy.",confirmPasswordLabel:"Potwierdź hasło",confirmPasswordPlaceholder:"Potwierdź hasło",description:"Wprowadź swój adres e-mail, aby zresetować hasło",emailPlaceholder:"Adres e-mail",failed:"Reset hasła nie powiódł się. Spróbuj ponownie.","invalid-email-format":"Nieprawidłowy adres e-mail","no-email":"Wprowadź adres e-mail",pageTitle:"Resetowanie hasła | ${clientName}",passwordLabel:"Nowe hasło",passwordPlaceholder:"Nowe hasło",passwordTooWeak:"Hasło jest zbyt słabe",passwordsDidntMatch:"Hasła nie są zgodne",successDescription:"Wysłaliśmy link do resetowania hasła na Twój adres e-mail.",successTitle:"Sprawdź swoją pocztę",title:"Zapomniałeś hasła?","user-not-found":"Nie znaleziono użytkownika"},"reset-password-code":{backToLoginText:"Wróć do logowania",buttonText:"Zresetuj hasło",codeLabel:"Kod resetowania",codePlaceholder:"Wprowadź 6-cyfrowy kod",confirmPasswordLabel:"Potwierdź hasło",confirmPasswordPlaceholder:"Potwierdź hasło",defaultDescription:"Wprowadź kod wysłany na Twój e-mail i wybierz nowe hasło",description:"Wysłaliśmy kod na ${email}",failed:"Reset hasła nie powiódł się. Spróbuj ponownie.",invalidCode:"Wprowadzony kod jest nieprawidłowy lub wygasł",noCode:"Wprowadź kod resetowania",pageTitle:"Wprowadź kod resetowania | ${clientName}",passwordLabel:"Nowe hasło",passwordPlaceholder:"Nowe hasło",passwordTooWeak:"Hasło jest zbyt słabe",passwordsDidntMatch:"Hasła nie są zgodne",resendFailed:"Nie udało się ponownie wysłać kodu. Spróbuj ponownie.",resendSuccess:"Nowy kod został wysłany na Twój e-mail",resendText:"Wyślij kod ponownie",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",title:"Wprowadź kod resetowania"}},signup:P$,"signup-id":{"signup-id":{buttonText:"Kontynuuj",description:"Zarejestruj się, aby kontynuować","email-already-exists":"Ten adres e-mail jest już zarejestrowany",emailPlaceholder:"Adres e-mail",federatedConnectionButtonText:"Kontynuuj z ${connectionName}","invalid-email-format":"Nieprawidłowy adres e-mail",loginActionLinkText:"Zaloguj się",loginActionText:"Masz już konto?","no-email":"Wprowadź adres e-mail",pageTitle:"Rejestracja | ${clientName}",phonePlaceholder:"Numer telefonu",separatorText:"lub",title:"Utwórz konto",usernamePlaceholder:"Nazwa użytkownika"}},"signup-password":{"signup-password":{buttonText:"Kontynuuj",description:"Utwórz swoje hasło",hidePasswordText:"Ukryj hasło","no-password":"Hasło jest wymagane",pageTitle:"Rejestracja | ${clientName}","password-policy-not-met":"Hasło nie spełnia wymagań","password-too-weak":"Hasło jest zbyt słabe",passwordPlaceholder:"Hasło",showPasswordText:"Pokaż hasło",title:"Utwórz hasło"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Kontynuuj",codeLabel:"Kod weryfikacyjny",codePlaceholder:"Wprowadź kod",defaultDescription:"Wprowadź kod weryfikacyjny wysłany na Twój telefon",description:"Wysłaliśmy kod na ${username}","invalid-code":"Nieprawidłowy kod",noCode:"Wprowadź kod weryfikacyjny",pageTitle:"Wprowadź kod | ${clientName}",resendText:"Wyślij ponownie kod",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",title:"Sprawdź swój telefon",unexpectedError:"Wystąpił nieoczekiwany błąd"}},status:N$},zF=Object.freeze(Object.defineProperty({__proto__:null,common:E$,consent:x$,default:IF,invitation:C$,login:T$,mfa:$$,organizations:z$,passkeys:I$,signup:P$,status:N$},Symbol.toStringTag,{value:"Module"})),j$={common:{alertListTitle:"Meddelanden",backText:"Gå tillbaka",cancelText:"Gå tillbaka",closeText:"Stäng",contactSupportText:"Behöver du hjälp?",continueText:"Fortsätt",copyrightText:"© ${currentYear} ${companyName}",errorText:"Något gick fel. Vänligen försök igen.",hidePasswordText:"Dölj lösenord",loadingText:"Laddar...",orText:"eller",privacyPolicyText:"Integritetspolicy",showPasswordText:"Visa lösenord",termsOfServiceText:"Användarvillkor",termsShortText:"Villkor",tryAgainText:"Försök igen"}},O$={consent:{buttonText:"Godkänn",cancelButtonText:"Neka",description:"${clientName} begär åtkomst till ditt konto",pageTitle:"Auktorisera | ${clientName}",scopesTitle:"Detta ger ${clientName} tillåtelse att:",title:"Auktorisera ${clientName}"}},F$={invitation:{acceptButtonText:"Acceptera inbjudan",description:"${inviterName} har bjudit in dig att gå med i ${organizationName} på ${clientName}",pageTitle:"Inbjudan | ${clientName}",title:"Du har blivit inbjuden"}},R$={login:{alertListTitle:"Meddelanden",buttonText:"Fortsätt",description:"Logga in på ${clientName}.",editEmailText:"Redigera",emailPlaceholder:"E-postadress",enterACodeBtn:"Logga in med en kod",federatedConnectionButtonText:"Fortsätt med ${connectionName}",footerLinkText:"Registrera dig",footerText:"Har du inget konto?",forgotPasswordText:"Har du glömt lösenordet?",hidePasswordText:"Dölj lösenord",invalidEmail:"Ogiltig e-postadress",invalidIdentifier:"Ogiltig e-postadress eller användarnamn",invitationDescription:"Logga in för att acceptera ${inviterName}s inbjudan att gå med i ${companyName} på ${clientName}.",invitationTitle:"Du har blivit inbjuden!",logoAltText:"${companyName}","no-email":"Vänligen ange en e-postadress","no-password":"Lösenord krävs",pageTitle:"Logga in | ${clientName}",passwordLoginNotAvailable:"Lösenordsinloggning är inte tillgänglig",passwordPlaceholder:"Lösenord",phonePlaceholder:"Telefonnummer",separatorText:"eller",sessionExpired:"Din session har gått ut. Försök igen.",showPasswordText:"Visa lösenord",signupActionLinkText:"Registrera dig",signupActionText:"Har du inget konto?",title:"Välkommen",tooManyFailedLogins:"För många misslyckade inloggningsförsök. Försök igen senare.",unverifiedEmail:"Verifiera din e-postadress innan du loggar in",userAccountDoesNotExist:"Användarkontot finns inte",usernamePlaceholder:"Användarnamn eller e-postadress",usernameTooLong:"Användarnamnet får vara högst ${max} tecken",usernameTooShort:"Användarnamnet måste vara minst ${min} tecken",wrongCredentials:"Fel användarnamn eller lösenord",passkeyButtonText:"Logga in med passkey"}},D$={mfa:{backupCodeText:"Använd reservkod",description:"Välj en verifieringsmetod",pageTitle:"Multifaktorautentisering | ${clientName}",title:"Verifiera din identitet"}},B$={"passkey-enrollment-nudge":{title:"Skydda ditt konto med en nyckel",description:"Nycklar använder enhetens biometri eller PIN-kod för att logga in snabbare och säkrare.",enrollButtonText:"Konfigurera nyckel",snoozeButtonText:"Kanske senare",optOutLinkText:"Visa inte detta igen",pageTitle:"Konfigurera Nyckel | ${clientName}"},"passkey-enrollment":{title:"Skapa din nyckel",description:"Följ anvisningarna från din webbläsare för att skapa en nyckel för detta konto.",errorMessage:"Det gick inte att skapa nyckeln. Försök igen.",cancelLinkText:"Hoppa över för nu",retryButtonText:"Försök igen",enrollmentComplete:"Din nyckel har konfigurerats. Du kan stänga denna sida.",pageTitle:"Skapa Nyckel | ${clientName}"},"passkey-challenge":{title:"Logga in med passkey",description:"Följ instruktionerna från din webbläsare för att verifiera din identitet.",errorMessage:"Autentisering med passkey misslyckades. Försök igen.",cancelLinkText:"Tillbaka till inloggning",retryButtonText:"Försök igen",pageTitle:"Logga in med passkey | ${clientName}"}},L$={organizations:{description:"Välj vilken organisation du vill logga in på",pageTitle:"Välj organisation | ${clientName}",searchPlaceholder:"Sök organisationer",title:"Välj din organisation"}},M$={signup:{buttonText:"Registrera dig",confirmPasswordPlaceholder:"Bekräfta lösenord",description:"Välj ett lösenord med en blandning av stora och små bokstäver, siffror och symboler.","email-already-exists":"E-postadressen är redan upptagen",emailPlaceholder:"E-postadress",federatedConnectionButtonText:"Fortsätt med ${connectionName}",hidePasswordText:"Dölj lösenord","invalid-email-format":"Ogiltig e-postadress",loginActionLinkText:"Logga in",loginActionText:"Har du redan ett konto?","no-email":"Vänligen ange en e-postadress","no-password":"Lösenord krävs","no-username":"Användarnamn krävs",pageTitle:"Registrera dig | ${clientName}",passwordPlaceholder:"Lösenord",passwordsDidntMatch:"Lösenorden matchar inte",phonePlaceholder:"Telefonnummer",privacyPolicyLinkText:"Integritetspolicy",separatorText:"eller",sessionExpired:"Din session har gått ut. Försök igen.",showPasswordText:"Visa lösenord",termsOfServiceLinkText:"Användarvillkor",termsText:"Genom att registrera dig godkänner du våra",title:"Välj lösenord","username-already-exists":"Användarnamnet är redan taget",usernamePlaceholder:"Användarnamn",verifyEmailText:"Kontrollera din e-post för att verifiera ditt konto"}},U$={status:{continueButtonText:"Fortsätt",errorTitle:"Fel",pageTitle:"Status | ${clientName}",successTitle:"Klart",title:"Status"}},PF={common:j$,consent:O$,"device-flow":{"device-flow":{buttonText:"Fortsätt",codePlaceholder:"Ange kod",description:"Ange koden som visas på din enhet","expired-code":"Koden har gått ut","invalid-code":"Koden du angav är ogiltig",pageTitle:"Enhetsaktivering | ${clientName}",title:"Aktivera din enhet"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Logga in",codeLabel:"Verifieringskod",codePlaceholder:"Ange kod",defaultDescription:"Ange verifieringskoden som skickades till din e-post",description:"Vi skickade en kod till ${email}","invalid-code":"Ogiltig kod",noCode:"Ange verifieringskoden",pageTitle:"Ange kod | ${clientName}",resendText:"Skicka koden igen",sessionExpired:"Din session har gått ut. Försök igen.",title:"Kolla din e-post",unexpectedError:"Ett oväntat fel uppstod"}},"email-verification":{"email-verification":{description:"Vi skickade ett e-postmeddelande till ${email}",pageTitle:"Verifiera e-post | ${clientName}",resendText:"Skicka koden igen",successDescription:"Din e-postadress har verifierats.",successTitle:"E-post verifierad",title:"Ange engångskod"}},invitation:F$,login:R$,"login-id":{"login-id":{alertListTitle:"Meddelanden","auth0-users-validation":"Något gick fel, försök igen senare","authentication-failure":"Vi beklagar, något gick fel vid inloggningsförsöket",buttonText:"Fortsätt","captcha-client-failure":"Vi kunde inte ladda säkerhetsutmaningen. Försök igen. (Felkod: #{errorCode})","captcha-validation-failure":"Vi beklagar, något gick fel vid validering av captcha-svaret. Försök igen.",captchaCodePlaceholder:"Ange koden som visas ovan","custom-script-error-code":"Något gick fel, försök igen senare.",description:"Logga in på ${clientName}.",editEmailText:"Redigera",emailPlaceholder:"E-postadress",federatedConnectionButtonText:"Fortsätt med ${connectionName}",footerLinkText:"Registrera dig",footerText:"Har du inget konto?",forgotPasswordText:"Har du glömt lösenordet?",hidePasswordText:"Dölj lösenord","invalid-captcha":"Lös utmaningen för att verifiera att du inte är en robot.","invalid-code":"Ogiltig kod","invalid-connection":"Ogiltig anslutning","invalid-email-format":"Ogiltig e-postadress","invalid-email-phone":"Ange en giltig e-postadress eller telefonnummer. Telefonnummer måste innehålla landskod.","invalid-email-phone-username":"Ange en giltig e-postadress, telefonnummer eller användarnamn. Telefonnummer måste innehålla landskod.","invalid-email-username":"Ange en giltig e-postadress eller användarnamn","invalid-expired-code":"Ogiltig eller utgången användarkod","invalid-login-id":"Ogiltigt inloggnings-ID angivet","invalid-phone-username":"Ange ett giltigt telefonnummer eller användarnamn. Telefonnummer måste innehålla landskod.","invalid-recaptcha":"Markera kryssrutan för att verifiera att du inte är en robot.","invalid-username":"Användarnamn kan bara innehålla alfanumeriska tecken eller: '${characters}'. Användarnamn ska vara mellan ${min} och ${max} tecken.",invitationDescription:"Logga in för att acceptera ${inviterName}s inbjudan att gå med i ${companyName} på ${clientName}.",invitationTitle:"Du har blivit inbjuden!","ip-blocked":"Vi har upptäckt misstänkt inloggningsaktivitet och ytterligare försök kommer att blockeras. Kontakta administratören.",logoAltText:"${companyName}","no-db-connection":"Ogiltig anslutning","no-email":"Vänligen ange en e-postadress","no-email-phone":"E-postadress eller telefonnummer krävs","no-email-phone-username":"Telefonnummer, användarnamn eller e-postadress krävs","no-email-username":"E-postadress eller användarnamn krävs","no-password":"Lösenord krävs","no-phone":"Ange ett telefonnummer","no-phone-username":"Telefonnummer eller användarnamn krävs","no-username":"Användarnamn krävs",pageTitle:"Logga in | ${clientName}","password-breached":"Vi har upptäckt ett potentiellt säkerhetsproblem med detta konto. För att skydda ditt konto har vi förhindrat denna inloggning. Återställ ditt lösenord för att fortsätta.",passwordPlaceholder:"Lösenord",phoneOrEmailPlaceholder:"E-post eller telefonnummer",phoneOrUsernameOrEmailPlaceholder:"Telefon, användarnamn eller e-post",phoneOrUsernamePlaceholder:"Telefonnummer eller användarnamn",phonePlaceholder:"Telefonnummer","same-user-login":"För många inloggningsförsök för denna användare. Vänta en stund och försök igen.",selectCountryCode:"Välj landskod, för närvarande inställd på ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"eller",sessionExpired:"Din session har gått ut. Försök igen.",showPasswordText:"Visa lösenord",signupActionLinkText:"Registrera dig",signupActionText:"Har du inget konto?",termsAndConditionsTemplate:'Genom att fortsätta godkänner du våra <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Villkor</a>.',title:"Välkommen","user-blocked":"Ditt konto har blockerats efter flera misslyckade inloggningsförsök i rad.",userAccountDoesNotExist:"Användarkontot finns inte",usernameOnlyPlaceholder:"Användarnamn",usernameOrEmailPlaceholder:"Användarnamn eller e-postadress",usernamePlaceholder:"Användarnamn",usernameTooLong:"Användarnamnet får vara högst ${max} tecken",usernameTooShort:"Användarnamnet måste vara minst ${min} tecken","wrong-credentials":"Fel användarnamn eller lösenord","wrong-email-credentials":"Fel e-postadress eller lösenord","wrong-email-phone-credentials":"Fel e-postadress, telefonnummer eller lösenord. Telefonnummer måste innehålla landskod.","wrong-email-phone-username-credentials":"Fel e-postadress, telefonnummer, användarnamn eller lösenord. Telefonnummer måste innehålla landskod.","wrong-email-username-credentials":"Fel e-postadress, användarnamn eller lösenord","wrong-phone-credentials":"Fel telefonnummer eller lösenord","wrong-phone-username-credentials":"Fel telefonnummer, användarnamn eller lösenord. Telefonnummer måste innehålla landskod.","wrong-username-credentials":"Fel användarnamn eller lösenord",passkeyButtonText:"Logga in med passkey"}},"login-password":{"login-password":{buttonText:"Logga in",description:"Ange din e-postadress och ditt lösenord för att logga in.",forgotPasswordText:"Har du glömt lösenordet?",hidePasswordText:"Dölj lösenord","no-password":"Lösenord krävs",pageTitle:"Logga in | ${clientName}","password-breached":"Vi har upptäckt ett potentiellt säkerhetsproblem med detta konto. För att skydda ditt konto har vi förhindrat denna inloggning. Återställ ditt lösenord för att fortsätta.",passwordPlaceholder:"Lösenord",showPasswordText:"Visa lösenord",signingInAs:"Loggar in som ${email}",title:"Ange lösenord",unverifiedEmail:"Verifiera din e-postadress innan du loggar in","user-blocked":"Ditt konto har blockerats efter flera misslyckade inloggningsförsök i rad.","wrong-credentials":"Fel lösenord"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-post",authMethodEmailOrPhone:"e-post eller telefonnummer",authMethodPhone:"telefonnummer",description:"Logga in med din ${authMethod}",emailOrPhonePlaceholder:"E-postadress eller telefonnummer",emailPlaceholder:"E-postadress",invalidEmail:"Ange en giltig e-postadress",invalidIdentifier:"Ange en giltig e-postadress eller telefonnummer",invalidPhone:"Ange ett giltigt telefonnummer med landskod",noEmail:"Ange din e-postadress",noPhone:"Ange ditt telefonnummer",phonePlaceholder:"Telefonnummer",sessionExpired:"Din session har gått ut. Försök igen.",title:"Logga in med en kod",userAccountDoesNotExist:"Användarkontot finns inte"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Klicka på länken i ditt e-postmeddelande för att logga in",description:"Vi skickade en länk till ${username}. Klicka på den för att logga in.",resendText:"Skicka länken igen",spamText:"Fick du inte e-postmeddelandet? Kolla din skräppost.",title:"Kolla din e-post"}},mfa:D$,"mfa-email":{"mfa-email":{buttonText:"Fortsätt",codePlaceholder:"Ange kod",description:"Vi skickade en kod till ${email}","invalid-code":"Koden du angav är ogiltig",pageTitle:"E-postverifiering | ${clientName}",resendText:"Skicka koden igen",title:"Kolla din e-post"}},"mfa-otp":{"mfa-otp":{buttonText:"Fortsätt",codePlaceholder:"Ange kod",description:"Ange den 6-siffriga koden från din autentiseringsapp","invalid-code":"Koden du angav är ogiltig",pageTitle:"Ange kod | ${clientName}",title:"Ange din kod"},"mfa-totp-enrollment":{title:"Konfigurera autentiseringsapp",description:"Skanna QR-koden nedan med din autentiseringsapp och ange sedan den 6-siffriga koden för att verifiera",secretLabel:"Eller ange denna kod manuellt:",codePlaceholder:"Ange kod",continueButtonText:"Verifiera och aktivera","invalid-code":"Koden du angav är ogiltig. Försök igen.","transaction-not-found":"Din registreringstransaktion har gått ut, du behöver börja om.",pageTitle:"Konfigurera autentiseringsapp | ${clientName}",unexpectedError:"Något gick fel. Försök igen.",enrollmentComplete:"MFA-registreringen är klar. Du kan stänga denna sida."},"mfa-totp-challenge":{title:"Verifiera din identitet",description:"Ange den 6-siffriga koden från din autentiseringsapp",codePlaceholder:"Ange kod",continueButtonText:"Fortsätt","invalid-code":"Koden du angav är ogiltig","transaction-not-found":"Din registreringstransaktion har gått ut, du behöver börja om.",unexpectedError:"Något gick fel. Försök igen.",pageTitle:"Verifiera identitet | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Använd ditt telefonnummer för att logga in | ${clientName}",title:"Verifiera din identitet",description:"Vi skickade en kod till ${phoneNumber}",continueButtonText:"Fortsätt",changePhoneText:"Välj ett annat telefonnummer.",smsButtonText:"SMS",voiceButtonText:"Röstsamtal",chooseMessageTypeText:"Hur vill du ta emot koden?",pickAuthenticatorText:"Prova en annan metod",logoAltText:"${companyName}",codePlaceholder:"Ange kod","send-sms-failed":"Det gick inte att skicka SMS:et","send-voice-failed":"Det gick inte att ringa röstsamtalet","invalid-phone-format":"Telefonnumret kan bara innehålla siffror.","invalid-phone":"Det verkar som att ditt telefonnummer inte är giltigt. Kontrollera och försök igen.","too-many-sms":"Du har överskridit det maximala antalet telefonmeddelanden per timme. Vänta några minuter och försök igen.","too-many-voice":"Du har överskridit det maximala antalet telefonmeddelanden per timme. Vänta några minuter och försök igen.","transaction-not-found":"Din registreringstransaktion har gått ut, du behöver börja om.","no-phone":"Ange ett telefonnummer",noCode:"Ange verifieringskoden",invalidCode:"Koden du angav är ogiltig. Försök igen.",unexpectedError:"Något gick fel. Försök igen.",resendSuccess:"Vi skickade en ny kod till din telefon",enrollmentComplete:"MFA-registreringen är klar. Du kan stänga denna sida."},"mfa-phone-enrollment":{pageTitle:"Ange ditt telefonnummer för att logga in med en telefonkod | ${clientName}",title:"Säkra ditt konto",description:"Ange din landskod och telefonnummer som vi kan skicka en 6-siffrig kod till:",continueButtonText:"Fortsätt",smsButtonText:"SMS",voiceButtonText:"Röstsamtal",chooseMessageTypeText:"Hur vill du ta emot koden?",pickAuthenticatorText:"Prova en annan metod",placeholder:"Ange ditt telefonnummer",logoAltText:"${companyName}",selectCountryCode:"Välj landskod, för närvarande inställd på ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Det gick inte att skicka SMS:et","send-voice-failed":"Det gick inte att ringa röstsamtalet","sms-authenticator-error":"Vi kunde inte skicka SMS:et. Försök igen senare.","invalid-phone-format":"Telefonnumret kan bara innehålla siffror.","invalid-phone":"Det verkar som att ditt telefonnummer inte är giltigt. Kontrollera och försök igen.","too-many-sms":"Du har överskridit det maximala antalet telefonmeddelanden per timme. Vänta några minuter och försök igen.","too-many-voice":"Du har överskridit det maximala antalet telefonmeddelanden per timme. Vänta några minuter och försök igen.","transaction-not-found":"Din registreringstransaktion har gått ut, du behöver börja om.","no-phone":"Ange ett telefonnummer","phone-is-too-short":"Telefonnumret är för kort","phone-is-too-long":"Telefonnumret är för långt"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Välj verifieringsmetod | ${clientName}",title:"Välj din verifieringsmetod",description:"Välj hur du vill verifiera din identitet",authenticatorAppLabel:"Autentiseringsapp",authenticatorAppDescription:"Använd din autentiseringsapp för att få en verifieringskod",smsLabel:"Sms",smsDescription:"Få en verifieringskod skickad till din telefon",passkeyLabel:"Lösenordsnyckel",passkeyDescription:"Använd din enhets biometri eller säkerhetsnyckel"}},"mfa-push":{"mfa-push":{description:"Vi skickade en notis till din enhet",pageTitle:"Push-notis | ${clientName}",resendText:"Skicka notisen igen",title:"Godkänn förfrågan",useCodeText:"Ange kod manuellt"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Fortsätt",codePlaceholder:"Återställningskod",description:"Ange en av dina återställningskoder","invalid-code":"Återställningskoden du angav är ogiltig",pageTitle:"Återställningskod | ${clientName}",title:"Ange återställningskod"}},"mfa-voice":{"mfa-voice":{buttonText:"Ring mig",codePlaceholder:"Ange kod",description:"Vi ringer ${phoneNumber} med din kod","invalid-code":"Koden du angav är ogiltig",pageTitle:"Röstsamtal | ${clientName}",title:"Ta emot ett telefonsamtal"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Försök igen",description:"Sätt in din säkerhetsnyckel och följ instruktionerna",pageTitle:"Säkerhetsnyckel | ${clientName}",title:"Använd din säkerhetsnyckel"}},passkeys:B$,organizations:L$,"reset-password":{"reset-password":{backToLoginText:"Gå tillbaka",buttonText:"Skicka",codeExpired:"Din kod för lösenordsåterställning har gått ut. Begär en ny.",confirmPasswordLabel:"Bekräfta lösenord",confirmPasswordPlaceholder:"Bekräfta lösenord",description:"Klicka på knappen nedan så skickar vi instruktioner om hur du återställer ditt lösenord.",emailPlaceholder:"E-postadress",failed:"Lösenordsåterställningen misslyckades. Försök igen.","invalid-email-format":"Ogiltig e-postadress","no-email":"Vänligen ange en e-postadress",pageTitle:"Återställ lösenord | ${clientName}",passwordLabel:"Nytt lösenord",passwordPlaceholder:"Nytt lösenord",passwordTooWeak:"Lösenordet är för svagt",passwordsDidntMatch:"Lösenorden matchar inte",successDescription:"Vi har skickat en länk för lösenordsåterställning till din e-postadress.",successTitle:"Vi har skickat ett e-postmeddelande med instruktioner om hur du återställer ditt lösenord till den e-postadress du angav.",title:"Har du glömt lösenordet?","user-not-found":"Användaren hittades inte"},"reset-password-code":{backToLoginText:"Tillbaka till inloggning",buttonText:"Återställ lösenord",codeLabel:"Återställningskod",codePlaceholder:"Ange 6-siffrig kod",confirmPasswordLabel:"Bekräfta lösenord",confirmPasswordPlaceholder:"Bekräfta lösenord",defaultDescription:"Ange koden som skickades till din e-post och välj ett nytt lösenord",description:"Vi skickade en kod till ${email}",failed:"Lösenordsåterställningen misslyckades. Försök igen.",invalidCode:"Koden du angav är ogiltig eller har gått ut",noCode:"Vänligen ange återställningskoden",pageTitle:"Ange återställningskod | ${clientName}",passwordLabel:"Nytt lösenord",passwordPlaceholder:"Nytt lösenord",passwordTooWeak:"Lösenordet är för svagt",passwordsDidntMatch:"Lösenorden matchar inte",resendFailed:"Kunde inte skicka koden igen. Försök igen.",resendSuccess:"En ny kod har skickats till din e-post",resendText:"Skicka koden igen",sessionExpired:"Din session har gått ut. Försök igen.",title:"Ange återställningskod"}},signup:M$,"signup-id":{"signup-id":{buttonText:"Fortsätt",description:"Välj ett lösenord med en blandning av stora och små bokstäver, siffror och symboler.","email-already-exists":"E-postadressen är redan upptagen",emailPlaceholder:"E-postadress",federatedConnectionButtonText:"Fortsätt med ${connectionName}","invalid-email-format":"Ogiltig e-postadress",loginActionLinkText:"Logga in",loginActionText:"Har du redan ett konto?","no-email":"Vänligen ange en e-postadress",pageTitle:"Registrera dig | ${clientName}",phonePlaceholder:"Telefonnummer",separatorText:"eller",title:"Välj lösenord",usernamePlaceholder:"Användarnamn"}},"signup-password":{"signup-password":{buttonText:"Fortsätt",description:"Välj ett lösenord med en blandning av stora och små bokstäver, siffror och symboler.",hidePasswordText:"Dölj lösenord","no-password":"Lösenord krävs",pageTitle:"Registrera dig | ${clientName}","password-policy-not-met":"Lösenordet uppfyller inte kraven","password-too-weak":"Lösenordet är för svagt",passwordPlaceholder:"Lösenord",showPasswordText:"Visa lösenord",title:"Välj lösenord"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Fortsätt",codeLabel:"Verifieringskod",codePlaceholder:"Ange kod",defaultDescription:"Ange verifieringskoden som skickades till din telefon",description:"Vi skickade en kod till ${username}","invalid-code":"Ogiltig kod",noCode:"Ange verifieringskoden",pageTitle:"Ange kod | ${clientName}",resendText:"Skicka koden igen",sessionExpired:"Din session har gått ut. Försök igen.",title:"Kolla din telefon",unexpectedError:"Ett oväntat fel uppstod"}},status:U$},NF=Object.freeze(Object.defineProperty({__proto__:null,common:j$,consent:O$,default:PF,invitation:F$,login:R$,mfa:D$,organizations:L$,passkeys:B$,signup:M$,status:U$},Symbol.toStringTag,{value:"Module"})),q$=["cs","da","en","fi","it","nb","pl","sv"],Gp="en",jF={cs:"Čeština",da:"Dansk",en:"English",fi:"Suomi",it:"Italiano",nb:"Norsk",pl:"Polski",sv:"Svenska"},OF=jF;function FF(e){return OF[e]??e}const RF=Object.assign({"../../locales/cs.json":wF,"../../locales/da.json":vF,"../../locales/en.json":kF,"../../locales/fi.json":EF,"../../locales/it.json":CF,"../../locales/nb.json":$F,"../../locales/pl.json":zF,"../../locales/sv.json":NF}),Yl={};for(const[e,t]of Object.entries(RF)){const n=e.match(/\/(\w+)\.json$/)?.[1];n&&(Yl[n]=t.default||t)}const H$={},A2=Yl[Gp];if(A2)for(const[e,t]of Object.entries(A2))for(const[n,i]of Object.entries(t)){const r={};for(const o of Object.keys(i))r[o]=s.z.string();H$[`${e}.${n}`]=s.z.object(r)}function DF(e,t){if(!t)return e;let n=e;for(const[i,r]of Object.entries(t))if(r!==void 0){const o=i.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");n=n.replace(new RegExp(`\\$\\{${o}\\}`,"g"),String(r)).replace(new RegExp(`#\\{${o}\\}`,"g"),String(r)).replace(new RegExp(`\\{${o}\\}`,"g"),String(r))}return n}function BF(e){const t=e.split("-")[0]?.toLowerCase()||Gp;return q$.includes(t)?t:Gp}function Ce(e,t,n,i){const r=BF(n),o=Yl[Gp]?.[e]?.[t]??{},a=Yl[r]?.[e]?.[t]??{},c={...o,...a},l=i?.[t]??{},d={...c,...l},u=H$[`${e}.${t}`];if(u){const h=u.safeParse(d);h.success||console.warn(`[i18n] Missing translations for ${e}.${t} (${r}):`,h.error.issues.map(g=>g.path.join(".")).join(", "))}const p={};for(const[h,g]of Object.entries(d))p[h]=m=>DF(g,m);return{m:new Proxy(p,{get:(h,g)=>h[g]??(()=>g)}),locale:r}}function LF(e){const t=e?.language?.split("-")[0]?.toLowerCase(),n=[];for(const[i,r]of Object.entries(Yl))if(!(t&&i!==t))for(const[o,a]of Object.entries(r))e?.prompt&&o!==e.prompt||n.push({prompt:o,language:i,custom_text:a});return n}function lc(e,t){const n=mF(e,"ah-dark-mode");if(n==="dark"||n==="light"||n==="auto")return n;const i=t?.dark_mode;return i==="dark"||i==="light"||i==="auto"?i:"auto"}const Wp={"--ah-color-text":"#f9fafb","--ah-color-text-muted":"#9ca3af","--ah-color-text-label":"#d1d5db","--ah-color-header":"#f9fafb","--ah-color-bg":"#1f2937","--ah-color-bg-hover":"#374151","--ah-color-bg-muted":"#374151","--ah-color-bg-disabled":"#4b5563","--ah-color-input-bg":"#374151","--ah-color-border":"#4b5563","--ah-color-border-hover":"#6b7280","--ah-color-border-muted":"#374151","--ah-color-error-bg":"rgba(220,38,38,0.2)","--ah-color-success-bg":"rgba(22,163,74,0.2)","--ah-color-link":"#60a5fa"};function V$(e){const t=e.replace("#",""),n=parseInt(t,16);return[n>>16&255,n>>8&255,n&255]}function k2(e){const[t,n,i]=V$(e).map(r=>{const o=r/255;return o<=.04045?o/12.92:Math.pow((o+.055)/1.055,2.4)});return .2126*t+.7152*n+.0722*i}function Ni(e,t){const n=k2(e),i=k2(t);return(Math.max(n,i)+.05)/(Math.min(n,i)+.05)}function K$(e,t){const[n,i,r]=V$(e),o=a=>Math.min(255,Math.round(a+(255-a)*t)).toString(16).padStart(2,"0");return`#${o(n)}${o(i)}${o(r)}`}function S2(e,t){const n={...Wp};if(t){const r=Wp["--ah-color-bg"];if(Ni(t,r)<3){let d=t;for(let u=1;u<=10&&(d=K$(t,u*.1),!(Ni(d,r)>=3));u++);n["--ah-color-primary"]=d,n["--ah-color-primary-hover"]=d}const o=1.35,a=n["--ah-color-primary"]||t,c=Ni(a,"#ffffff"),l=Ni(a,"#000000");n["--ah-color-text-on-primary"]=l>c*o?"#000000":"#ffffff"}const i=Object.entries(n).map(([r,o])=>`${r}: ${o} !important`).join("; ");return`${e} { ${i}; }`}const MF="(function(btn){var h=document.documentElement;var cur=h.classList.contains('ah-dark-mode')?'dark':h.classList.contains('ah-light-mode')?'light':'auto';var next=cur==='auto'?'dark':cur==='dark'?'light':'auto';h.classList.remove('ah-dark-mode','ah-light-mode');if(next==='dark'){h.classList.add('ah-dark-mode');h.setAttribute('data-mode','dark')}else if(next==='light'){h.classList.add('ah-light-mode');h.setAttribute('data-mode','light')}else{h.removeAttribute('data-mode')}btn.querySelector('.icon-sun').style.display=next==='light'?'block':'none';btn.querySelector('.icon-moon').style.display=next==='dark'?'block':'none';btn.querySelector('.icon-auto').style.display=next==='auto'?'block':'none';document.cookie='ah-dark-mode='+next+';path=/;max-age=31536000;SameSite=Lax';if(window.__ahDarkMode){window.__ahDarkMode(next)}})(this)",UF="var p=new URLSearchParams(window.location.search);p.set('ui_locales',this.value);window.location.search=p.toString()";function G$({logoUrl:e,clientName:t}){const n=e?gn(e):null;return S("div",{class:"ah-chip ah-chip-logo","data-ah-slot":"top-left",children:n?S("img",{src:n,alt:t}):S("span",{class:"ah-logo-text",children:t})})}function W$({darkMode:e}){return S("button",{type:"button","aria-label":"Toggle dark mode",onclick:MF,children:[S("svg",{class:"icon-auto",width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.2","stroke-linecap":"round","stroke-linejoin":"round",style:e==="auto"?void 0:"display:none",children:[S("circle",{cx:"12",cy:"12",r:"9"}),S("path",{d:"M12 3a9 9 0 0 1 0 18",fill:"currentColor"})]}),S("svg",{class:"icon-sun",width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.2","stroke-linecap":"round","stroke-linejoin":"round",style:e==="light"?void 0:"display:none",children:[S("circle",{cx:"12",cy:"12",r:"5"}),S("line",{x1:"12",y1:"1",x2:"12",y2:"3"}),S("line",{x1:"12",y1:"21",x2:"12",y2:"23"}),S("line",{x1:"4.22",y1:"4.22",x2:"5.64",y2:"5.64"}),S("line",{x1:"18.36",y1:"18.36",x2:"19.78",y2:"19.78"}),S("line",{x1:"1",y1:"12",x2:"3",y2:"12"}),S("line",{x1:"21",y1:"12",x2:"23",y2:"12"})]}),S("svg",{class:"icon-moon",width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.2","stroke-linecap":"round","stroke-linejoin":"round",style:e==="dark"?void 0:"display:none",children:S("path",{d:"M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z"})})]})}function J$({language:e,availableLanguages:t}){return!t||t.length<2?null:S("div",{class:"ah-lang",children:[S("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.2","stroke-linecap":"round","stroke-linejoin":"round",children:[S("circle",{cx:"12",cy:"12",r:"10"}),S("path",{d:"M2 12h20"}),S("path",{d:"M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"})]}),S("select",{"aria-label":"Language",onchange:UF,children:t.map(n=>S("option",{value:n,selected:n===e,children:FF(n)}))})]})}function Y$({darkMode:e,language:t,availableLanguages:n}){return S("div",{class:"ah-chip ah-chip-settings","data-ah-slot":"top-right",children:[S(W$,{darkMode:e}),n&&S(J$,{language:t,availableLanguages:n})]})}function Q$({url:e,href:t,alt:n,height:i}){const r=gn(e),o=t?gn(t):null;if(!r)return null;const a=S("img",{src:r,alt:n||"",height:i||18});return S("div",{class:"ah-chip ah-chip-trust","data-ah-slot":"bottom-left",children:o?S("a",{href:o,target:"_blank",rel:"noopener noreferrer",children:a}):a})}function Z$({termsAndConditionsUrl:e,language:t}){if(!e)return null;const{m:n}=Ce("common","common",t||"en");return S("div",{class:"ah-chip-legal","data-ah-slot":"bottom-right",children:S("a",{href:e,target:"_blank",rel:"noopener noreferrer",children:n.termsShortText()})})}function X$(e,t){const n=[],i=hn(e?.colors?.primary);i&&n.push(`--ah-color-primary: ${i}`);const r=hn(t?.colors?.primary_button)||i;if(r){const a=Ni(r,"#ffffff"),l=Ni(r,"#000000")>a*1.35?"#000000":"#ffffff";n.push(`--ah-color-text-on-primary: ${l}`)}return n.length>0?n.join("; ")+"; width: clamp(320px, 100%, 400px);":"width: clamp(320px, 100%, 400px);"}function qF(e){const{primaryColor:t,themePrimary:n,widgetBackground:i}=e;return`
1
+ "use strict";var t9=Object.create;var W1=Object.defineProperty;var n9=Object.getOwnPropertyDescriptor;var i9=Object.getOwnPropertyNames;var r9=Object.getPrototypeOf,o9=Object.prototype.hasOwnProperty;var s9=(e,t,n,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of i9(t))!o9.call(e,r)&&r!==n&&W1(e,r,{get:()=>t[r],enumerable:!(i=n9(t,r))||i.enumerable});return e};var a9=(e,t,n)=>(n=e!=null?t9(r9(e)):{},s9(t||!e||!e.__esModule?W1(n,"default",{value:e,enumerable:!0}):n,e));Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("@hono/zod-openapi");var z=class extends Error{res;status;constructor(e=500,t){super(t?.message,{cause:t?.cause}),this.res=t?.res,this.status=e}getResponse(){return this.res?new Response(this.res.body,{status:this.status,headers:this.res.headers}):new Response(this.message,{status:this.status})}};const Te=e=>typeof e=="string",Oc=()=>{let e,t;const n=new Promise((i,r)=>{e=i,t=r});return n.resolve=e,n.reject=t,n},J1=e=>e==null?"":""+e,c9=(e,t,n)=>{e.forEach(i=>{t[i]&&(n[i]=t[i])})},l9=/###/g,Y1=e=>e&&e.indexOf("###")>-1?e.replace(l9,"."):e,Q1=e=>!e||Te(e),Il=(e,t,n)=>{const i=Te(t)?t.split("."):t;let r=0;for(;r<i.length-1;){if(Q1(e))return{};const o=Y1(i[r]);!e[o]&&n&&(e[o]=new n),Object.prototype.hasOwnProperty.call(e,o)?e=e[o]:e={},++r}return Q1(e)?{}:{obj:e,k:Y1(i[r])}},Z1=(e,t,n)=>{const{obj:i,k:r}=Il(e,t,Object);if(i!==void 0||t.length===1){i[r]=n;return}let o=t[t.length-1],a=t.slice(0,t.length-1),c=Il(e,a,Object);for(;c.obj===void 0&&a.length;)o=`${a[a.length-1]}.${o}`,a=a.slice(0,a.length-1),c=Il(e,a,Object),c?.obj&&typeof c.obj[`${c.k}.${o}`]<"u"&&(c.obj=void 0);c.obj[`${c.k}.${o}`]=n},d9=(e,t,n,i)=>{const{obj:r,k:o}=Il(e,t,Object);r[o]=r[o]||[],r[o].push(n)},Sp=(e,t)=>{const{obj:n,k:i}=Il(e,t);if(n&&Object.prototype.hasOwnProperty.call(n,i))return n[i]},u9=(e,t,n)=>{const i=Sp(e,n);return i!==void 0?i:Sp(t,n)},gx=(e,t,n)=>{for(const i in t)i!=="__proto__"&&i!=="constructor"&&(i in e?Te(e[i])||e[i]instanceof String||Te(t[i])||t[i]instanceof String?n&&(e[i]=t[i]):gx(e[i],t[i],n):e[i]=t[i]);return e},wo=e=>e.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g,"\\$&");var p9={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;","/":"&#x2F;"};const f9=e=>Te(e)?e.replace(/[&<>"'\/]/g,t=>p9[t]):e;class h9{constructor(t){this.capacity=t,this.regExpMap=new Map,this.regExpQueue=[]}getRegExp(t){const n=this.regExpMap.get(t);if(n!==void 0)return n;const i=new RegExp(t);return this.regExpQueue.length===this.capacity&&this.regExpMap.delete(this.regExpQueue.shift()),this.regExpMap.set(t,i),this.regExpQueue.push(t),i}}const g9=[" ",",","?","!",";"],m9=new h9(20),y9=(e,t,n)=>{t=t||"",n=n||"";const i=g9.filter(a=>t.indexOf(a)<0&&n.indexOf(a)<0);if(i.length===0)return!0;const r=m9.getRegExp(`(${i.map(a=>a==="?"?"\\?":a).join("|")})`);let o=!r.test(e);if(!o){const a=e.indexOf(n);a>0&&!r.test(e.substring(0,a))&&(o=!0)}return o},yy=(e,t,n=".")=>{if(!e)return;if(e[t])return Object.prototype.hasOwnProperty.call(e,t)?e[t]:void 0;const i=t.split(n);let r=e;for(let o=0;o<i.length;){if(!r||typeof r!="object")return;let a,c="";for(let l=o;l<i.length;++l)if(l!==o&&(c+=n),c+=i[l],a=r[c],a!==void 0){if(["string","number","boolean"].indexOf(typeof a)>-1&&l<i.length-1)continue;o+=l-o+1;break}r=a}return r},Ul=e=>e?.replace(/_/g,"-"),_9={type:"logger",log(e){this.output("log",e)},warn(e){this.output("warn",e)},error(e){this.output("error",e)},output(e,t){console?.[e]?.apply?.(console,t)}};class Ep{constructor(t,n={}){this.init(t,n)}init(t,n={}){this.prefix=n.prefix||"i18next:",this.logger=t||_9,this.options=n,this.debug=n.debug}log(...t){return this.forward(t,"log","",!0)}warn(...t){return this.forward(t,"warn","",!0)}error(...t){return this.forward(t,"error","")}deprecate(...t){return this.forward(t,"warn","WARNING DEPRECATED: ",!0)}forward(t,n,i,r){return r&&!this.debug?null:(Te(t[0])&&(t[0]=`${i}${this.prefix} ${t[0]}`),this.logger[n](t))}create(t){return new Ep(this.logger,{prefix:`${this.prefix}:${t}:`,...this.options})}clone(t){return t=t||this.options,t.prefix=t.prefix||this.prefix,new Ep(this.logger,t)}}var Pi=new Ep;class mh{constructor(){this.observers={}}on(t,n){return t.split(" ").forEach(i=>{this.observers[i]||(this.observers[i]=new Map);const r=this.observers[i].get(n)||0;this.observers[i].set(n,r+1)}),this}off(t,n){if(this.observers[t]){if(!n){delete this.observers[t];return}this.observers[t].delete(n)}}emit(t,...n){this.observers[t]&&Array.from(this.observers[t].entries()).forEach(([r,o])=>{for(let a=0;a<o;a++)r(...n)}),this.observers["*"]&&Array.from(this.observers["*"].entries()).forEach(([r,o])=>{for(let a=0;a<o;a++)r.apply(r,[t,...n])})}}class X1 extends mh{constructor(t,n={ns:["translation"],defaultNS:"translation"}){super(),this.data=t||{},this.options=n,this.options.keySeparator===void 0&&(this.options.keySeparator="."),this.options.ignoreJSONStructure===void 0&&(this.options.ignoreJSONStructure=!0)}addNamespaces(t){this.options.ns.indexOf(t)<0&&this.options.ns.push(t)}removeNamespaces(t){const n=this.options.ns.indexOf(t);n>-1&&this.options.ns.splice(n,1)}getResource(t,n,i,r={}){const o=r.keySeparator!==void 0?r.keySeparator:this.options.keySeparator,a=r.ignoreJSONStructure!==void 0?r.ignoreJSONStructure:this.options.ignoreJSONStructure;let c;t.indexOf(".")>-1?c=t.split("."):(c=[t,n],i&&(Array.isArray(i)?c.push(...i):Te(i)&&o?c.push(...i.split(o)):c.push(i)));const l=Sp(this.data,c);return!l&&!n&&!i&&t.indexOf(".")>-1&&(t=c[0],n=c[1],i=c.slice(2).join(".")),l||!a||!Te(i)?l:yy(this.data?.[t]?.[n],i,o)}addResource(t,n,i,r,o={silent:!1}){const a=o.keySeparator!==void 0?o.keySeparator:this.options.keySeparator;let c=[t,n];i&&(c=c.concat(a?i.split(a):i)),t.indexOf(".")>-1&&(c=t.split("."),r=n,n=c[1]),this.addNamespaces(n),Z1(this.data,c,r),o.silent||this.emit("added",t,n,i,r)}addResources(t,n,i,r={silent:!1}){for(const o in i)(Te(i[o])||Array.isArray(i[o]))&&this.addResource(t,n,o,i[o],{silent:!0});r.silent||this.emit("added",t,n,i)}addResourceBundle(t,n,i,r,o,a={silent:!1,skipCopy:!1}){let c=[t,n];t.indexOf(".")>-1&&(c=t.split("."),r=i,i=n,n=c[1]),this.addNamespaces(n);let l=Sp(this.data,c)||{};a.skipCopy||(i=JSON.parse(JSON.stringify(i))),r?gx(l,i,o):l={...l,...i},Z1(this.data,c,l),a.silent||this.emit("added",t,n,i)}removeResourceBundle(t,n){this.hasResourceBundle(t,n)&&delete this.data[t][n],this.removeNamespaces(n),this.emit("removed",t,n)}hasResourceBundle(t,n){return this.getResource(t,n)!==void 0}getResourceBundle(t,n){return n||(n=this.options.defaultNS),this.getResource(t,n)}getDataByLanguage(t){return this.data[t]}hasLanguageSomeTranslations(t){const n=this.getDataByLanguage(t);return!!(n&&Object.keys(n)||[]).find(r=>n[r]&&Object.keys(n[r]).length>0)}toJSON(){return this.data}}var mx={processors:{},addPostProcessor(e){this.processors[e.name]=e},handle(e,t,n,i,r){return e.forEach(o=>{t=this.processors[o]?.process(t,n,i,r)??t}),t}};const yx=Symbol("i18next/PATH_KEY");function w9(){const e=[],t=Object.create(null);let n;return t.get=(i,r)=>(n?.revoke?.(),r===yx?e:(e.push(r),n=Proxy.revocable(i,t),n.proxy)),Proxy.revocable(Object.create(null),t).proxy}function _a(e,t){const{[yx]:n}=e(w9()),i=t?.keySeparator??".",r=t?.nsSeparator??":";if(n.length>1&&r){const o=t?.ns,a=Array.isArray(o)?o:null;if(a&&a.length>1&&a.slice(1).includes(n[0]))return`${n[0]}${r}${n.slice(1).join(i)}`}return n.join(i)}const e2={},tm=e=>!Te(e)&&typeof e!="boolean"&&typeof e!="number";class xp extends mh{constructor(t,n={}){super(),c9(["resourceStore","languageUtils","pluralResolver","interpolator","backendConnector","i18nFormat","utils"],t,this),this.options=n,this.options.keySeparator===void 0&&(this.options.keySeparator="."),this.logger=Pi.create("translator")}changeLanguage(t){t&&(this.language=t)}exists(t,n={interpolation:{}}){const i={...n};if(t==null)return!1;const r=this.resolve(t,i);if(r?.res===void 0)return!1;const o=tm(r.res);return!(i.returnObjects===!1&&o)}extractFromKey(t,n){let i=n.nsSeparator!==void 0?n.nsSeparator:this.options.nsSeparator;i===void 0&&(i=":");const r=n.keySeparator!==void 0?n.keySeparator:this.options.keySeparator;let o=n.ns||this.options.defaultNS||[];const a=i&&t.indexOf(i)>-1,c=!this.options.userDefinedKeySeparator&&!n.keySeparator&&!this.options.userDefinedNsSeparator&&!n.nsSeparator&&!y9(t,i,r);if(a&&!c){const l=t.match(this.interpolator.nestingRegexp);if(l&&l.length>0)return{key:t,namespaces:Te(o)?[o]:o};const d=t.split(i);(i!==r||i===r&&this.options.ns.indexOf(d[0])>-1)&&(o=d.shift()),t=d.join(r)}return{key:t,namespaces:Te(o)?[o]:o}}translate(t,n,i){let r=typeof n=="object"?{...n}:n;if(typeof r!="object"&&this.options.overloadTranslationOptionHandler&&(r=this.options.overloadTranslationOptionHandler(arguments)),typeof r=="object"&&(r={...r}),r||(r={}),t==null)return"";typeof t=="function"&&(t=_a(t,{...this.options,...r})),Array.isArray(t)||(t=[String(t)]),t=t.map(O=>typeof O=="function"?_a(O,{...this.options,...r}):String(O));const o=r.returnDetails!==void 0?r.returnDetails:this.options.returnDetails,a=r.keySeparator!==void 0?r.keySeparator:this.options.keySeparator,{key:c,namespaces:l}=this.extractFromKey(t[t.length-1],r),d=l[l.length-1];let u=r.nsSeparator!==void 0?r.nsSeparator:this.options.nsSeparator;u===void 0&&(u=":");const p=r.lng||this.language,f=r.appendNamespaceToCIMode||this.options.appendNamespaceToCIMode;if(p?.toLowerCase()==="cimode")return f?o?{res:`${d}${u}${c}`,usedKey:c,exactUsedKey:c,usedLng:p,usedNS:d,usedParams:this.getUsedParamsDetails(r)}:`${d}${u}${c}`:o?{res:c,usedKey:c,exactUsedKey:c,usedLng:p,usedNS:d,usedParams:this.getUsedParamsDetails(r)}:c;const h=this.resolve(t,r);let g=h?.res;const m=h?.usedKey||c,_=h?.exactUsedKey||c,w=["[object Number]","[object Function]","[object RegExp]"],y=r.joinArrays!==void 0?r.joinArrays:this.options.joinArrays,b=!this.i18nFormat||this.i18nFormat.handleAsObject,A=r.count!==void 0&&!Te(r.count),v=xp.hasDefaultValue(r),k=A?this.pluralResolver.getSuffix(p,r.count,r):"",x=r.ordinal&&A?this.pluralResolver.getSuffix(p,r.count,{ordinal:!1}):"",I=A&&!r.ordinal&&r.count===0,$=I&&r[`defaultValue${this.options.pluralSeparator}zero`]||r[`defaultValue${k}`]||r[`defaultValue${x}`]||r.defaultValue;let N=g;b&&!g&&v&&(N=$);const T=tm(N),P=Object.prototype.toString.apply(N);if(b&&N&&T&&w.indexOf(P)<0&&!(Te(y)&&Array.isArray(N))){if(!r.returnObjects&&!this.options.returnObjects){this.options.returnedObjectHandler||this.logger.warn("accessing an object - but returnObjects options is not enabled!");const O=this.options.returnedObjectHandler?this.options.returnedObjectHandler(m,N,{...r,ns:l}):`key '${c} (${this.language})' returned an object instead of string.`;return o?(h.res=O,h.usedParams=this.getUsedParamsDetails(r),h):O}if(a){const O=Array.isArray(N),j=O?[]:{},F=O?_:m;for(const L in N)if(Object.prototype.hasOwnProperty.call(N,L)){const M=`${F}${a}${L}`;v&&!g?j[L]=this.translate(M,{...r,defaultValue:tm($)?$[L]:void 0,joinArrays:!1,ns:l}):j[L]=this.translate(M,{...r,joinArrays:!1,ns:l}),j[L]===M&&(j[L]=N[L])}g=j}}else if(b&&Te(y)&&Array.isArray(g))g=g.join(y),g&&(g=this.extendTranslation(g,t,r,i));else{let O=!1,j=!1;!this.isValidLookup(g)&&v&&(O=!0,g=$),this.isValidLookup(g)||(j=!0,g=c);const L=(r.missingKeyNoValueFallbackToKey||this.options.missingKeyNoValueFallbackToKey)&&j?void 0:g,M=v&&$!==g&&this.options.updateMissing;if(j||O||M){if(this.logger.log(M?"updateKey":"missingKey",p,d,c,M?$:g),a){const Q=this.resolve(c,{...r,keySeparator:!1});Q&&Q.res&&this.logger.warn("Seems the loaded translations were in flat JSON format instead of nested. Either set keySeparator: false on init or make sure your translations are published in nested format.")}let H=[];const W=this.languageUtils.getFallbackCodes(this.options.fallbackLng,r.lng||this.language);if(this.options.saveMissingTo==="fallback"&&W&&W[0])for(let Q=0;Q<W.length;Q++)H.push(W[Q]);else this.options.saveMissingTo==="all"?H=this.languageUtils.toResolveHierarchy(r.lng||this.language):H.push(r.lng||this.language);const te=(Q,ee,K)=>{const ke=v&&K!==g?K:L;this.options.missingKeyHandler?this.options.missingKeyHandler(Q,d,ee,ke,M,r):this.backendConnector?.saveMissing&&this.backendConnector.saveMissing(Q,d,ee,ke,M,r),this.emit("missingKey",Q,d,ee,g)};this.options.saveMissing&&(this.options.saveMissingPlurals&&A?H.forEach(Q=>{const ee=this.pluralResolver.getSuffixes(Q,r);I&&r[`defaultValue${this.options.pluralSeparator}zero`]&&ee.indexOf(`${this.options.pluralSeparator}zero`)<0&&ee.push(`${this.options.pluralSeparator}zero`),ee.forEach(K=>{te([Q],c+K,r[`defaultValue${K}`]||$)})}):te(H,c,$))}g=this.extendTranslation(g,t,r,h,i),j&&g===c&&this.options.appendNamespaceToMissingKey&&(g=`${d}${u}${c}`),(j||O)&&this.options.parseMissingKeyHandler&&(g=this.options.parseMissingKeyHandler(this.options.appendNamespaceToMissingKey?`${d}${u}${c}`:c,O?g:void 0,r))}return o?(h.res=g,h.usedParams=this.getUsedParamsDetails(r),h):g}extendTranslation(t,n,i,r,o){if(this.i18nFormat?.parse)t=this.i18nFormat.parse(t,{...this.options.interpolation.defaultVariables,...i},i.lng||this.language||r.usedLng,r.usedNS,r.usedKey,{resolved:r});else if(!i.skipInterpolation){i.interpolation&&this.interpolator.init({...i,interpolation:{...this.options.interpolation,...i.interpolation}});const l=Te(t)&&(i?.interpolation?.skipOnVariables!==void 0?i.interpolation.skipOnVariables:this.options.interpolation.skipOnVariables);let d;if(l){const p=t.match(this.interpolator.nestingRegexp);d=p&&p.length}let u=i.replace&&!Te(i.replace)?i.replace:i;if(this.options.interpolation.defaultVariables&&(u={...this.options.interpolation.defaultVariables,...u}),t=this.interpolator.interpolate(t,u,i.lng||this.language||r.usedLng,i),l){const p=t.match(this.interpolator.nestingRegexp),f=p&&p.length;d<f&&(i.nest=!1)}!i.lng&&r&&r.res&&(i.lng=this.language||r.usedLng),i.nest!==!1&&(t=this.interpolator.nest(t,(...p)=>o?.[0]===p[0]&&!i.context?(this.logger.warn(`It seems you are nesting recursively key: ${p[0]} in key: ${n[0]}`),null):this.translate(...p,n),i)),i.interpolation&&this.interpolator.reset()}const a=i.postProcess||this.options.postProcess,c=Te(a)?[a]:a;return t!=null&&c?.length&&i.applyPostProcessor!==!1&&(t=mx.handle(c,t,n,this.options&&this.options.postProcessPassResolved?{i18nResolved:{...r,usedParams:this.getUsedParamsDetails(i)},...i}:i,this)),t}resolve(t,n={}){let i,r,o,a,c;return Te(t)&&(t=[t]),Array.isArray(t)&&(t=t.map(l=>typeof l=="function"?_a(l,{...this.options,...n}):l)),t.forEach(l=>{if(this.isValidLookup(i))return;const d=this.extractFromKey(l,n),u=d.key;r=u;let p=d.namespaces;this.options.fallbackNS&&(p=p.concat(this.options.fallbackNS));const f=n.count!==void 0&&!Te(n.count),h=f&&!n.ordinal&&n.count===0,g=n.context!==void 0&&(Te(n.context)||typeof n.context=="number")&&n.context!=="",m=n.lngs?n.lngs:this.languageUtils.toResolveHierarchy(n.lng||this.language,n.fallbackLng);p.forEach(_=>{this.isValidLookup(i)||(c=_,!e2[`${m[0]}-${_}`]&&this.utils?.hasLoadedNamespace&&!this.utils?.hasLoadedNamespace(c)&&(e2[`${m[0]}-${_}`]=!0,this.logger.warn(`key "${r}" for languages "${m.join(", ")}" won't get resolved as namespace "${c}" was not yet loaded`,"This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!")),m.forEach(w=>{if(this.isValidLookup(i))return;a=w;const y=[u];if(this.i18nFormat?.addLookupKeys)this.i18nFormat.addLookupKeys(y,u,w,_,n);else{let A;f&&(A=this.pluralResolver.getSuffix(w,n.count,n));const v=`${this.options.pluralSeparator}zero`,k=`${this.options.pluralSeparator}ordinal${this.options.pluralSeparator}`;if(f&&(n.ordinal&&A.indexOf(k)===0&&y.push(u+A.replace(k,this.options.pluralSeparator)),y.push(u+A),h&&y.push(u+v)),g){const x=`${u}${this.options.contextSeparator||"_"}${n.context}`;y.push(x),f&&(n.ordinal&&A.indexOf(k)===0&&y.push(x+A.replace(k,this.options.pluralSeparator)),y.push(x+A),h&&y.push(x+v))}}let b;for(;b=y.pop();)this.isValidLookup(i)||(o=b,i=this.getResource(w,_,b,n))}))})}),{res:i,usedKey:r,exactUsedKey:o,usedLng:a,usedNS:c}}isValidLookup(t){return t!==void 0&&!(!this.options.returnNull&&t===null)&&!(!this.options.returnEmptyString&&t==="")}getResource(t,n,i,r={}){return this.i18nFormat?.getResource?this.i18nFormat.getResource(t,n,i,r):this.resourceStore.getResource(t,n,i,r)}getUsedParamsDetails(t={}){const n=["defaultValue","ordinal","context","replace","lng","lngs","fallbackLng","ns","keySeparator","nsSeparator","returnObjects","returnDetails","joinArrays","postProcess","interpolation"],i=t.replace&&!Te(t.replace);let r=i?t.replace:t;if(i&&typeof t.count<"u"&&(r.count=t.count),this.options.interpolation.defaultVariables&&(r={...this.options.interpolation.defaultVariables,...r}),!i){r={...r};for(const o of n)delete r[o]}return r}static hasDefaultValue(t){const n="defaultValue";for(const i in t)if(Object.prototype.hasOwnProperty.call(t,i)&&n===i.substring(0,n.length)&&t[i]!==void 0)return!0;return!1}}class t2{constructor(t){this.options=t,this.supportedLngs=this.options.supportedLngs||!1,this.logger=Pi.create("languageUtils")}getScriptPartFromCode(t){if(t=Ul(t),!t||t.indexOf("-")<0)return null;const n=t.split("-");return n.length===2||(n.pop(),n[n.length-1].toLowerCase()==="x")?null:this.formatLanguageCode(n.join("-"))}getLanguagePartFromCode(t){if(t=Ul(t),!t||t.indexOf("-")<0)return t;const n=t.split("-");return this.formatLanguageCode(n[0])}formatLanguageCode(t){if(Te(t)&&t.indexOf("-")>-1){let n;try{n=Intl.getCanonicalLocales(t)[0]}catch{}return n&&this.options.lowerCaseLng&&(n=n.toLowerCase()),n||(this.options.lowerCaseLng?t.toLowerCase():t)}return this.options.cleanCode||this.options.lowerCaseLng?t.toLowerCase():t}isSupportedCode(t){return(this.options.load==="languageOnly"||this.options.nonExplicitSupportedLngs)&&(t=this.getLanguagePartFromCode(t)),!this.supportedLngs||!this.supportedLngs.length||this.supportedLngs.indexOf(t)>-1}getBestMatchFromCodes(t){if(!t)return null;let n;return t.forEach(i=>{if(n)return;const r=this.formatLanguageCode(i);(!this.options.supportedLngs||this.isSupportedCode(r))&&(n=r)}),!n&&this.options.supportedLngs&&t.forEach(i=>{if(n)return;const r=this.getScriptPartFromCode(i);if(this.isSupportedCode(r))return n=r;const o=this.getLanguagePartFromCode(i);if(this.isSupportedCode(o))return n=o;n=this.options.supportedLngs.find(a=>{if(a===o)return a;if(!(a.indexOf("-")<0&&o.indexOf("-")<0)&&(a.indexOf("-")>0&&o.indexOf("-")<0&&a.substring(0,a.indexOf("-"))===o||a.indexOf(o)===0&&o.length>1))return a})}),n||(n=this.getFallbackCodes(this.options.fallbackLng)[0]),n}getFallbackCodes(t,n){if(!t)return[];if(typeof t=="function"&&(t=t(n)),Te(t)&&(t=[t]),Array.isArray(t))return t;if(!n)return t.default||[];let i=t[n];return i||(i=t[this.getScriptPartFromCode(n)]),i||(i=t[this.formatLanguageCode(n)]),i||(i=t[this.getLanguagePartFromCode(n)]),i||(i=t.default),i||[]}toResolveHierarchy(t,n){const i=this.getFallbackCodes((n===!1?[]:n)||this.options.fallbackLng||[],t),r=[],o=a=>{a&&(this.isSupportedCode(a)?r.push(a):this.logger.warn(`rejecting language code not found in supportedLngs: ${a}`))};return Te(t)&&(t.indexOf("-")>-1||t.indexOf("_")>-1)?(this.options.load!=="languageOnly"&&o(this.formatLanguageCode(t)),this.options.load!=="languageOnly"&&this.options.load!=="currentOnly"&&o(this.getScriptPartFromCode(t)),this.options.load!=="currentOnly"&&o(this.getLanguagePartFromCode(t))):Te(t)&&o(this.formatLanguageCode(t)),i.forEach(a=>{r.indexOf(a)<0&&o(this.formatLanguageCode(a))}),r}}const n2={zero:0,one:1,two:2,few:3,many:4,other:5},i2={select:e=>e===1?"one":"other",resolvedOptions:()=>({pluralCategories:["one","other"]})};class b9{constructor(t,n={}){this.languageUtils=t,this.options=n,this.logger=Pi.create("pluralResolver"),this.pluralRulesCache={}}clearCache(){this.pluralRulesCache={}}getRule(t,n={}){const i=Ul(t==="dev"?"en":t),r=n.ordinal?"ordinal":"cardinal",o=JSON.stringify({cleanedCode:i,type:r});if(o in this.pluralRulesCache)return this.pluralRulesCache[o];let a;try{a=new Intl.PluralRules(i,{type:r})}catch{if(typeof Intl>"u")return this.logger.error("No Intl support, please use an Intl polyfill!"),i2;if(!t.match(/-|_/))return i2;const l=this.languageUtils.getLanguagePartFromCode(t);a=this.getRule(l,n)}return this.pluralRulesCache[o]=a,a}needsPlural(t,n={}){let i=this.getRule(t,n);return i||(i=this.getRule("dev",n)),i?.resolvedOptions().pluralCategories.length>1}getPluralFormsOfKey(t,n,i={}){return this.getSuffixes(t,i).map(r=>`${n}${r}`)}getSuffixes(t,n={}){let i=this.getRule(t,n);return i||(i=this.getRule("dev",n)),i?i.resolvedOptions().pluralCategories.sort((r,o)=>n2[r]-n2[o]).map(r=>`${this.options.prepend}${n.ordinal?`ordinal${this.options.prepend}`:""}${r}`):[]}getSuffix(t,n,i={}){const r=this.getRule(t,i);return r?`${this.options.prepend}${i.ordinal?`ordinal${this.options.prepend}`:""}${r.select(n)}`:(this.logger.warn(`no plural rule found for: ${t}`),this.getSuffix("dev",n,i))}}const r2=(e,t,n,i=".",r=!0)=>{let o=u9(e,t,n);return!o&&r&&Te(n)&&(o=yy(e,n,i),o===void 0&&(o=yy(t,n,i))),o},nm=e=>e.replace(/\$/g,"$$$$");class o2{constructor(t={}){this.logger=Pi.create("interpolator"),this.options=t,this.format=t?.interpolation?.format||(n=>n),this.init(t)}init(t={}){t.interpolation||(t.interpolation={escapeValue:!0});const{escape:n,escapeValue:i,useRawValueToEscape:r,prefix:o,prefixEscaped:a,suffix:c,suffixEscaped:l,formatSeparator:d,unescapeSuffix:u,unescapePrefix:p,nestingPrefix:f,nestingPrefixEscaped:h,nestingSuffix:g,nestingSuffixEscaped:m,nestingOptionsSeparator:_,maxReplaces:w,alwaysFormat:y}=t.interpolation;this.escape=n!==void 0?n:f9,this.escapeValue=i!==void 0?i:!0,this.useRawValueToEscape=r!==void 0?r:!1,this.prefix=o?wo(o):a||"{{",this.suffix=c?wo(c):l||"}}",this.formatSeparator=d||",",this.unescapePrefix=u?"":p||"-",this.unescapeSuffix=this.unescapePrefix?"":u||"",this.nestingPrefix=f?wo(f):h||wo("$t("),this.nestingSuffix=g?wo(g):m||wo(")"),this.nestingOptionsSeparator=_||",",this.maxReplaces=w||1e3,this.alwaysFormat=y!==void 0?y:!1,this.resetRegExp()}reset(){this.options&&this.init(this.options)}resetRegExp(){const t=(n,i)=>n?.source===i?(n.lastIndex=0,n):new RegExp(i,"g");this.regexp=t(this.regexp,`${this.prefix}(.+?)${this.suffix}`),this.regexpUnescape=t(this.regexpUnescape,`${this.prefix}${this.unescapePrefix}(.+?)${this.unescapeSuffix}${this.suffix}`),this.nestingRegexp=t(this.nestingRegexp,`${this.nestingPrefix}((?:[^()"']+|"[^"]*"|'[^']*'|\\((?:[^()]|"[^"]*"|'[^']*')*\\))*?)${this.nestingSuffix}`)}interpolate(t,n,i,r){let o,a,c;const l=this.options&&this.options.interpolation&&this.options.interpolation.defaultVariables||{},d=h=>{if(h.indexOf(this.formatSeparator)<0){const w=r2(n,l,h,this.options.keySeparator,this.options.ignoreJSONStructure);return this.alwaysFormat?this.format(w,void 0,i,{...r,...n,interpolationkey:h}):w}const g=h.split(this.formatSeparator),m=g.shift().trim(),_=g.join(this.formatSeparator).trim();return this.format(r2(n,l,m,this.options.keySeparator,this.options.ignoreJSONStructure),_,i,{...r,...n,interpolationkey:m})};this.resetRegExp();const u=r?.missingInterpolationHandler||this.options.missingInterpolationHandler,p=r?.interpolation?.skipOnVariables!==void 0?r.interpolation.skipOnVariables:this.options.interpolation.skipOnVariables;return[{regex:this.regexpUnescape,safeValue:h=>nm(h)},{regex:this.regexp,safeValue:h=>this.escapeValue?nm(this.escape(h)):nm(h)}].forEach(h=>{for(c=0;o=h.regex.exec(t);){const g=o[1].trim();if(a=d(g),a===void 0)if(typeof u=="function"){const _=u(t,o,r);a=Te(_)?_:""}else if(r&&Object.prototype.hasOwnProperty.call(r,g))a="";else if(p){a=o[0];continue}else this.logger.warn(`missed to pass in variable ${g} for interpolating ${t}`),a="";else!Te(a)&&!this.useRawValueToEscape&&(a=J1(a));const m=h.safeValue(a);if(t=t.replace(o[0],m),p?(h.regex.lastIndex+=a.length,h.regex.lastIndex-=o[0].length):h.regex.lastIndex=0,c++,c>=this.maxReplaces)break}}),t}nest(t,n,i={}){let r,o,a;const c=(l,d)=>{const u=this.nestingOptionsSeparator;if(l.indexOf(u)<0)return l;const p=l.split(new RegExp(`${wo(u)}[ ]*{`));let f=`{${p[1]}`;l=p[0],f=this.interpolate(f,a);const h=f.match(/'/g),g=f.match(/"/g);((h?.length??0)%2===0&&!g||(g?.length??0)%2!==0)&&(f=f.replace(/'/g,'"'));try{a=JSON.parse(f),d&&(a={...d,...a})}catch(m){return this.logger.warn(`failed parsing options string in nesting for key ${l}`,m),`${l}${u}${f}`}return a.defaultValue&&a.defaultValue.indexOf(this.prefix)>-1&&delete a.defaultValue,l};for(;r=this.nestingRegexp.exec(t);){let l=[];a={...i},a=a.replace&&!Te(a.replace)?a.replace:a,a.applyPostProcessor=!1,delete a.defaultValue;const d=/{.*}/.test(r[1])?r[1].lastIndexOf("}")+1:r[1].indexOf(this.formatSeparator);if(d!==-1&&(l=r[1].slice(d).split(this.formatSeparator).map(u=>u.trim()).filter(Boolean),r[1]=r[1].slice(0,d)),o=n(c.call(this,r[1].trim(),a),a),o&&r[0]===t&&!Te(o))return o;Te(o)||(o=J1(o)),o||(this.logger.warn(`missed to resolve ${r[1]} for nesting ${t}`),o=""),l.length&&(o=l.reduce((u,p)=>this.format(u,p,i.lng,{...i,interpolationkey:r[1].trim()}),o.trim())),t=t.replace(r[0],o),this.regexp.lastIndex=0}return t}}const v9=e=>{let t=e.toLowerCase().trim();const n={};if(e.indexOf("(")>-1){const i=e.split("(");t=i[0].toLowerCase().trim();const r=i[1].substring(0,i[1].length-1);t==="currency"&&r.indexOf(":")<0?n.currency||(n.currency=r.trim()):t==="relativetime"&&r.indexOf(":")<0?n.range||(n.range=r.trim()):r.split(";").forEach(a=>{if(a){const[c,...l]=a.split(":"),d=l.join(":").trim().replace(/^'+|'+$/g,""),u=c.trim();n[u]||(n[u]=d),d==="false"&&(n[u]=!1),d==="true"&&(n[u]=!0),isNaN(d)||(n[u]=parseInt(d,10))}})}return{formatName:t,formatOptions:n}},s2=e=>{const t={};return(n,i,r)=>{let o=r;r&&r.interpolationkey&&r.formatParams&&r.formatParams[r.interpolationkey]&&r[r.interpolationkey]&&(o={...o,[r.interpolationkey]:void 0});const a=i+JSON.stringify(o);let c=t[a];return c||(c=e(Ul(i),r),t[a]=c),c(n)}},A9=e=>(t,n,i)=>e(Ul(n),i)(t);class k9{constructor(t={}){this.logger=Pi.create("formatter"),this.options=t,this.init(t)}init(t,n={interpolation:{}}){this.formatSeparator=n.interpolation.formatSeparator||",";const i=n.cacheInBuiltFormats?s2:A9;this.formats={number:i((r,o)=>{const a=new Intl.NumberFormat(r,{...o});return c=>a.format(c)}),currency:i((r,o)=>{const a=new Intl.NumberFormat(r,{...o,style:"currency"});return c=>a.format(c)}),datetime:i((r,o)=>{const a=new Intl.DateTimeFormat(r,{...o});return c=>a.format(c)}),relativetime:i((r,o)=>{const a=new Intl.RelativeTimeFormat(r,{...o});return c=>a.format(c,o.range||"day")}),list:i((r,o)=>{const a=new Intl.ListFormat(r,{...o});return c=>a.format(c)})}}add(t,n){this.formats[t.toLowerCase().trim()]=n}addCached(t,n){this.formats[t.toLowerCase().trim()]=s2(n)}format(t,n,i,r={}){const o=n.split(this.formatSeparator);if(o.length>1&&o[0].indexOf("(")>1&&o[0].indexOf(")")<0&&o.find(c=>c.indexOf(")")>-1)){const c=o.findIndex(l=>l.indexOf(")")>-1);o[0]=[o[0],...o.splice(1,c)].join(this.formatSeparator)}return o.reduce((c,l)=>{const{formatName:d,formatOptions:u}=v9(l);if(this.formats[d]){let p=c;try{const f=r?.formatParams?.[r.interpolationkey]||{},h=f.locale||f.lng||r.locale||r.lng||i;p=this.formats[d](c,h,{...u,...r,...f})}catch(f){this.logger.warn(f)}return p}else this.logger.warn(`there was no format function for ${d}`);return c},t)}}const S9=(e,t)=>{e.pending[t]!==void 0&&(delete e.pending[t],e.pendingCount--)};class E9 extends mh{constructor(t,n,i,r={}){super(),this.backend=t,this.store=n,this.services=i,this.languageUtils=i.languageUtils,this.options=r,this.logger=Pi.create("backendConnector"),this.waitingReads=[],this.maxParallelReads=r.maxParallelReads||10,this.readingCalls=0,this.maxRetries=r.maxRetries>=0?r.maxRetries:5,this.retryTimeout=r.retryTimeout>=1?r.retryTimeout:350,this.state={},this.queue=[],this.backend?.init?.(i,r.backend,r)}queueLoad(t,n,i,r){const o={},a={},c={},l={};return t.forEach(d=>{let u=!0;n.forEach(p=>{const f=`${d}|${p}`;!i.reload&&this.store.hasResourceBundle(d,p)?this.state[f]=2:this.state[f]<0||(this.state[f]===1?a[f]===void 0&&(a[f]=!0):(this.state[f]=1,u=!1,a[f]===void 0&&(a[f]=!0),o[f]===void 0&&(o[f]=!0),l[p]===void 0&&(l[p]=!0)))}),u||(c[d]=!0)}),(Object.keys(o).length||Object.keys(a).length)&&this.queue.push({pending:a,pendingCount:Object.keys(a).length,loaded:{},errors:[],callback:r}),{toLoad:Object.keys(o),pending:Object.keys(a),toLoadLanguages:Object.keys(c),toLoadNamespaces:Object.keys(l)}}loaded(t,n,i){const r=t.split("|"),o=r[0],a=r[1];n&&this.emit("failedLoading",o,a,n),!n&&i&&this.store.addResourceBundle(o,a,i,void 0,void 0,{skipCopy:!0}),this.state[t]=n?-1:2,n&&i&&(this.state[t]=0);const c={};this.queue.forEach(l=>{d9(l.loaded,[o],a),S9(l,t),n&&l.errors.push(n),l.pendingCount===0&&!l.done&&(Object.keys(l.loaded).forEach(d=>{c[d]||(c[d]={});const u=l.loaded[d];u.length&&u.forEach(p=>{c[d][p]===void 0&&(c[d][p]=!0)})}),l.done=!0,l.errors.length?l.callback(l.errors):l.callback())}),this.emit("loaded",c),this.queue=this.queue.filter(l=>!l.done)}read(t,n,i,r=0,o=this.retryTimeout,a){if(!t.length)return a(null,{});if(this.readingCalls>=this.maxParallelReads){this.waitingReads.push({lng:t,ns:n,fcName:i,tried:r,wait:o,callback:a});return}this.readingCalls++;const c=(d,u)=>{if(this.readingCalls--,this.waitingReads.length>0){const p=this.waitingReads.shift();this.read(p.lng,p.ns,p.fcName,p.tried,p.wait,p.callback)}if(d&&u&&r<this.maxRetries){setTimeout(()=>{this.read.call(this,t,n,i,r+1,o*2,a)},o);return}a(d,u)},l=this.backend[i].bind(this.backend);if(l.length===2){try{const d=l(t,n);d&&typeof d.then=="function"?d.then(u=>c(null,u)).catch(c):c(null,d)}catch(d){c(d)}return}return l(t,n,c)}prepareLoading(t,n,i={},r){if(!this.backend)return this.logger.warn("No backend was added via i18next.use. Will not load resources."),r&&r();Te(t)&&(t=this.languageUtils.toResolveHierarchy(t)),Te(n)&&(n=[n]);const o=this.queueLoad(t,n,i,r);if(!o.toLoad.length)return o.pending.length||r(),null;o.toLoad.forEach(a=>{this.loadOne(a)})}load(t,n,i){this.prepareLoading(t,n,{},i)}reload(t,n,i){this.prepareLoading(t,n,{reload:!0},i)}loadOne(t,n=""){const i=t.split("|"),r=i[0],o=i[1];this.read(r,o,"read",void 0,void 0,(a,c)=>{a&&this.logger.warn(`${n}loading namespace ${o} for language ${r} failed`,a),!a&&c&&this.logger.log(`${n}loaded namespace ${o} for language ${r}`,c),this.loaded(t,a,c)})}saveMissing(t,n,i,r,o,a={},c=()=>{}){if(this.services?.utils?.hasLoadedNamespace&&!this.services?.utils?.hasLoadedNamespace(n)){this.logger.warn(`did not save key "${i}" as the namespace "${n}" was not yet loaded`,"This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!");return}if(!(i==null||i==="")){if(this.backend?.create){const l={...a,isUpdate:o},d=this.backend.create.bind(this.backend);if(d.length<6)try{let u;d.length===5?u=d(t,n,i,r,l):u=d(t,n,i,r),u&&typeof u.then=="function"?u.then(p=>c(null,p)).catch(c):c(null,u)}catch(u){c(u)}else d(t,n,i,r,c,l)}!t||!t[0]||this.store.addResource(t[0],n,i,r)}}}const im=()=>({debug:!1,initAsync:!0,ns:["translation"],defaultNS:["translation"],fallbackLng:["dev"],fallbackNS:!1,supportedLngs:!1,nonExplicitSupportedLngs:!1,load:"all",preload:!1,simplifyPluralSuffix:!0,keySeparator:".",nsSeparator:":",pluralSeparator:"_",contextSeparator:"_",partialBundledLanguages:!1,saveMissing:!1,updateMissing:!1,saveMissingTo:"fallback",saveMissingPlurals:!0,missingKeyHandler:!1,missingInterpolationHandler:!1,postProcess:!1,postProcessPassResolved:!1,returnNull:!1,returnEmptyString:!0,returnObjects:!1,joinArrays:!1,returnedObjectHandler:!1,parseMissingKeyHandler:!1,appendNamespaceToMissingKey:!1,appendNamespaceToCIMode:!1,overloadTranslationOptionHandler:e=>{let t={};if(typeof e[1]=="object"&&(t=e[1]),Te(e[1])&&(t.defaultValue=e[1]),Te(e[2])&&(t.tDescription=e[2]),typeof e[2]=="object"||typeof e[3]=="object"){const n=e[3]||e[2];Object.keys(n).forEach(i=>{t[i]=n[i]})}return t},interpolation:{escapeValue:!0,format:e=>e,prefix:"{{",suffix:"}}",formatSeparator:",",unescapePrefix:"-",nestingPrefix:"$t(",nestingSuffix:")",nestingOptionsSeparator:",",maxReplaces:1e3,skipOnVariables:!0},cacheInBuiltFormats:!0}),a2=e=>(Te(e.ns)&&(e.ns=[e.ns]),Te(e.fallbackLng)&&(e.fallbackLng=[e.fallbackLng]),Te(e.fallbackNS)&&(e.fallbackNS=[e.fallbackNS]),e.supportedLngs?.indexOf?.("cimode")<0&&(e.supportedLngs=e.supportedLngs.concat(["cimode"])),typeof e.initImmediate=="boolean"&&(e.initAsync=e.initImmediate),e),Eu=()=>{},x9=e=>{Object.getOwnPropertyNames(Object.getPrototypeOf(e)).forEach(n=>{typeof e[n]=="function"&&(e[n]=e[n].bind(e))})},_x="__i18next_supportNoticeShown",C9=()=>!!(typeof globalThis<"u"&&globalThis[_x]||typeof process<"u"&&process.env&&process.env.I18NEXT_NO_SUPPORT_NOTICE||typeof process<"u"&&process.env&&process.env.NODE_ENV==="production"),T9=()=>{typeof globalThis<"u"&&(globalThis[_x]=!0)},$9=e=>!!(e?.modules?.backend?.name?.indexOf("Locize")>0||e?.modules?.backend?.constructor?.name?.indexOf("Locize")>0||e?.options?.backend?.backends&&e.options.backend.backends.some(t=>t?.name?.indexOf("Locize")>0||t?.constructor?.name?.indexOf("Locize")>0)||e?.options?.backend?.projectId||e?.options?.backend?.backendOptions&&e.options.backend.backendOptions.some(t=>t?.projectId));class zl extends mh{constructor(t={},n){if(super(),this.options=a2(t),this.services={},this.logger=Pi,this.modules={external:[]},x9(this),n&&!this.isInitialized&&!t.isClone){if(!this.options.initAsync)return this.init(t,n),this;setTimeout(()=>{this.init(t,n)},0)}}init(t={},n){this.isInitializing=!0,typeof t=="function"&&(n=t,t={}),t.defaultNS==null&&t.ns&&(Te(t.ns)?t.defaultNS=t.ns:t.ns.indexOf("translation")<0&&(t.defaultNS=t.ns[0]));const i=im();this.options={...i,...this.options,...a2(t)},this.options.interpolation={...i.interpolation,...this.options.interpolation},t.keySeparator!==void 0&&(this.options.userDefinedKeySeparator=t.keySeparator),t.nsSeparator!==void 0&&(this.options.userDefinedNsSeparator=t.nsSeparator),typeof this.options.overloadTranslationOptionHandler!="function"&&(this.options.overloadTranslationOptionHandler=i.overloadTranslationOptionHandler),this.options.showSupportNotice!==!1&&!$9(this)&&!C9()&&(typeof console<"u"&&typeof console.info<"u"&&console.info("🌐 i18next is made possible by our own product, Locize — consider powering your project with managed localization (AI, CDN, integrations): https://locize.com 💙"),T9());const r=d=>d?typeof d=="function"?new d:d:null;if(!this.options.isClone){this.modules.logger?Pi.init(r(this.modules.logger),this.options):Pi.init(null,this.options);let d;this.modules.formatter?d=this.modules.formatter:d=k9;const u=new t2(this.options);this.store=new X1(this.options.resources,this.options);const p=this.services;p.logger=Pi,p.resourceStore=this.store,p.languageUtils=u,p.pluralResolver=new b9(u,{prepend:this.options.pluralSeparator,simplifyPluralSuffix:this.options.simplifyPluralSuffix}),this.options.interpolation.format&&this.options.interpolation.format!==i.interpolation.format&&this.logger.deprecate("init: you are still using the legacy format function, please use the new approach: https://www.i18next.com/translation-function/formatting"),d&&(!this.options.interpolation.format||this.options.interpolation.format===i.interpolation.format)&&(p.formatter=r(d),p.formatter.init&&p.formatter.init(p,this.options),this.options.interpolation.format=p.formatter.format.bind(p.formatter)),p.interpolator=new o2(this.options),p.utils={hasLoadedNamespace:this.hasLoadedNamespace.bind(this)},p.backendConnector=new E9(r(this.modules.backend),p.resourceStore,p,this.options),p.backendConnector.on("*",(h,...g)=>{this.emit(h,...g)}),this.modules.languageDetector&&(p.languageDetector=r(this.modules.languageDetector),p.languageDetector.init&&p.languageDetector.init(p,this.options.detection,this.options)),this.modules.i18nFormat&&(p.i18nFormat=r(this.modules.i18nFormat),p.i18nFormat.init&&p.i18nFormat.init(this)),this.translator=new xp(this.services,this.options),this.translator.on("*",(h,...g)=>{this.emit(h,...g)}),this.modules.external.forEach(h=>{h.init&&h.init(this)})}if(this.format=this.options.interpolation.format,n||(n=Eu),this.options.fallbackLng&&!this.services.languageDetector&&!this.options.lng){const d=this.services.languageUtils.getFallbackCodes(this.options.fallbackLng);d.length>0&&d[0]!=="dev"&&(this.options.lng=d[0])}!this.services.languageDetector&&!this.options.lng&&this.logger.warn("init: no languageDetector is used and no lng is defined"),["getResource","hasResourceBundle","getResourceBundle","getDataByLanguage"].forEach(d=>{this[d]=(...u)=>this.store[d](...u)}),["addResource","addResources","addResourceBundle","removeResourceBundle"].forEach(d=>{this[d]=(...u)=>(this.store[d](...u),this)});const c=Oc(),l=()=>{const d=(u,p)=>{this.isInitializing=!1,this.isInitialized&&!this.initializedStoreOnce&&this.logger.warn("init: i18next is already initialized. You should call init just once!"),this.isInitialized=!0,this.options.isClone||this.logger.log("initialized",this.options),this.emit("initialized",this.options),c.resolve(p),n(u,p)};if(this.languages&&!this.isInitialized)return d(null,this.t.bind(this));this.changeLanguage(this.options.lng,d)};return this.options.resources||!this.options.initAsync?l():setTimeout(l,0),c}loadResources(t,n=Eu){let i=n;const r=Te(t)?t:this.language;if(typeof t=="function"&&(i=t),!this.options.resources||this.options.partialBundledLanguages){if(r?.toLowerCase()==="cimode"&&(!this.options.preload||this.options.preload.length===0))return i();const o=[],a=c=>{if(!c||c==="cimode")return;this.services.languageUtils.toResolveHierarchy(c).forEach(d=>{d!=="cimode"&&o.indexOf(d)<0&&o.push(d)})};r?a(r):this.services.languageUtils.getFallbackCodes(this.options.fallbackLng).forEach(l=>a(l)),this.options.preload?.forEach?.(c=>a(c)),this.services.backendConnector.load(o,this.options.ns,c=>{!c&&!this.resolvedLanguage&&this.language&&this.setResolvedLanguage(this.language),i(c)})}else i(null)}reloadResources(t,n,i){const r=Oc();return typeof t=="function"&&(i=t,t=void 0),typeof n=="function"&&(i=n,n=void 0),t||(t=this.languages),n||(n=this.options.ns),i||(i=Eu),this.services.backendConnector.reload(t,n,o=>{r.resolve(),i(o)}),r}use(t){if(!t)throw new Error("You are passing an undefined module! Please check the object you are passing to i18next.use()");if(!t.type)throw new Error("You are passing a wrong module! Please check the object you are passing to i18next.use()");return t.type==="backend"&&(this.modules.backend=t),(t.type==="logger"||t.log&&t.warn&&t.error)&&(this.modules.logger=t),t.type==="languageDetector"&&(this.modules.languageDetector=t),t.type==="i18nFormat"&&(this.modules.i18nFormat=t),t.type==="postProcessor"&&mx.addPostProcessor(t),t.type==="formatter"&&(this.modules.formatter=t),t.type==="3rdParty"&&this.modules.external.push(t),this}setResolvedLanguage(t){if(!(!t||!this.languages)&&!(["cimode","dev"].indexOf(t)>-1)){for(let n=0;n<this.languages.length;n++){const i=this.languages[n];if(!(["cimode","dev"].indexOf(i)>-1)&&this.store.hasLanguageSomeTranslations(i)){this.resolvedLanguage=i;break}}!this.resolvedLanguage&&this.languages.indexOf(t)<0&&this.store.hasLanguageSomeTranslations(t)&&(this.resolvedLanguage=t,this.languages.unshift(t))}}changeLanguage(t,n){this.isLanguageChangingTo=t;const i=Oc();this.emit("languageChanging",t);const r=c=>{this.language=c,this.languages=this.services.languageUtils.toResolveHierarchy(c),this.resolvedLanguage=void 0,this.setResolvedLanguage(c)},o=(c,l)=>{l?this.isLanguageChangingTo===t&&(r(l),this.translator.changeLanguage(l),this.isLanguageChangingTo=void 0,this.emit("languageChanged",l),this.logger.log("languageChanged",l)):this.isLanguageChangingTo=void 0,i.resolve((...d)=>this.t(...d)),n&&n(c,(...d)=>this.t(...d))},a=c=>{!t&&!c&&this.services.languageDetector&&(c=[]);const l=Te(c)?c:c&&c[0],d=this.store.hasLanguageSomeTranslations(l)?l:this.services.languageUtils.getBestMatchFromCodes(Te(c)?[c]:c);d&&(this.language||r(d),this.translator.language||this.translator.changeLanguage(d),this.services.languageDetector?.cacheUserLanguage?.(d)),this.loadResources(d,u=>{o(u,d)})};return!t&&this.services.languageDetector&&!this.services.languageDetector.async?a(this.services.languageDetector.detect()):!t&&this.services.languageDetector&&this.services.languageDetector.async?this.services.languageDetector.detect.length===0?this.services.languageDetector.detect().then(a):this.services.languageDetector.detect(a):a(t),i}getFixedT(t,n,i){const r=(o,a,...c)=>{let l;typeof a!="object"?l=this.options.overloadTranslationOptionHandler([o,a].concat(c)):l={...a},l.lng=l.lng||r.lng,l.lngs=l.lngs||r.lngs,l.ns=l.ns||r.ns,l.keyPrefix!==""&&(l.keyPrefix=l.keyPrefix||i||r.keyPrefix);const d={...this.options,...l};typeof l.keyPrefix=="function"&&(l.keyPrefix=_a(l.keyPrefix,d));const u=this.options.keySeparator||".";let p;return l.keyPrefix&&Array.isArray(o)?p=o.map(f=>(typeof f=="function"&&(f=_a(f,d)),`${l.keyPrefix}${u}${f}`)):(typeof o=="function"&&(o=_a(o,d)),p=l.keyPrefix?`${l.keyPrefix}${u}${o}`:o),this.t(p,l)};return Te(t)?r.lng=t:r.lngs=t,r.ns=n,r.keyPrefix=i,r}t(...t){return this.translator?.translate(...t)}exists(...t){return this.translator?.exists(...t)}setDefaultNamespace(t){this.options.defaultNS=t}hasLoadedNamespace(t,n={}){if(!this.isInitialized)return this.logger.warn("hasLoadedNamespace: i18next was not initialized",this.languages),!1;if(!this.languages||!this.languages.length)return this.logger.warn("hasLoadedNamespace: i18n.languages were undefined or empty",this.languages),!1;const i=n.lng||this.resolvedLanguage||this.languages[0],r=this.options?this.options.fallbackLng:!1,o=this.languages[this.languages.length-1];if(i.toLowerCase()==="cimode")return!0;const a=(c,l)=>{const d=this.services.backendConnector.state[`${c}|${l}`];return d===-1||d===0||d===2};if(n.precheck){const c=n.precheck(this,a);if(c!==void 0)return c}return!!(this.hasResourceBundle(i,t)||!this.services.backendConnector.backend||this.options.resources&&!this.options.partialBundledLanguages||a(i,t)&&(!r||a(o,t)))}loadNamespaces(t,n){const i=Oc();return this.options.ns?(Te(t)&&(t=[t]),t.forEach(r=>{this.options.ns.indexOf(r)<0&&this.options.ns.push(r)}),this.loadResources(r=>{i.resolve(),n&&n(r)}),i):(n&&n(),Promise.resolve())}loadLanguages(t,n){const i=Oc();Te(t)&&(t=[t]);const r=this.options.preload||[],o=t.filter(a=>r.indexOf(a)<0&&this.services.languageUtils.isSupportedCode(a));return o.length?(this.options.preload=r.concat(o),this.loadResources(a=>{i.resolve(),n&&n(a)}),i):(n&&n(),Promise.resolve())}dir(t){if(t||(t=this.resolvedLanguage||(this.languages?.length>0?this.languages[0]:this.language)),!t)return"rtl";try{const r=new Intl.Locale(t);if(r&&r.getTextInfo){const o=r.getTextInfo();if(o&&o.direction)return o.direction}}catch{}const n=["ar","shu","sqr","ssh","xaa","yhd","yud","aao","abh","abv","acm","acq","acw","acx","acy","adf","ads","aeb","aec","afb","ajp","apc","apd","arb","arq","ars","ary","arz","auz","avl","ayh","ayl","ayn","ayp","bbz","pga","he","iw","ps","pbt","pbu","pst","prp","prd","ug","ur","ydd","yds","yih","ji","yi","hbo","men","xmn","fa","jpr","peo","pes","prs","dv","sam","ckb"],i=this.services?.languageUtils||new t2(im());return t.toLowerCase().indexOf("-latn")>1?"ltr":n.indexOf(i.getLanguagePartFromCode(t))>-1||t.toLowerCase().indexOf("-arab")>1?"rtl":"ltr"}static createInstance(t={},n){const i=new zl(t,n);return i.createInstance=zl.createInstance,i}cloneInstance(t={},n=Eu){const i=t.forkResourceStore;i&&delete t.forkResourceStore;const r={...this.options,...t,isClone:!0},o=new zl(r);if((t.debug!==void 0||t.prefix!==void 0)&&(o.logger=o.logger.clone(t)),["store","services","language"].forEach(c=>{o[c]=this[c]}),o.services={...this.services},o.services.utils={hasLoadedNamespace:o.hasLoadedNamespace.bind(o)},i){const c=Object.keys(this.store.data).reduce((l,d)=>(l[d]={...this.store.data[d]},l[d]=Object.keys(l[d]).reduce((u,p)=>(u[p]={...l[d][p]},u),l[d]),l),{});o.store=new X1(c,r),o.services.resourceStore=o.store}if(t.interpolation){const l={...im().interpolation,...this.options.interpolation,...t.interpolation},d={...r,interpolation:l};o.services.interpolator=new o2(d)}return o.translator=new xp(o.services,r),o.translator.on("*",(c,...l)=>{o.emit(c,...l)}),o.init(r,n),o.translator.options=r,o.translator.backendConnector.services.utils={hasLoadedNamespace:o.hasLoadedNamespace.bind(o)},o}toJSON(){return{options:this.options,store:this.store,language:this.language,languages:this.languages,resolvedLanguage:this.resolvedLanguage}}}const U=zl.createInstance();U.createInstance;U.dir;U.init;U.loadResources;U.reloadResources;U.use;U.changeLanguage;U.getFixedT;const oe=U.t;U.exists;U.setDefaultNamespace;U.hasLoadedNamespace;U.loadNamespaces;U.loadLanguages;const Un=s.z.object({created_at:s.z.string(),updated_at:s.z.string()}),qw=s.z.object({id:s.z.string(),version:s.z.string().optional()}),Hw=s.z.object({name:s.z.string(),version:s.z.string()}),Vw=s.z.object({name:s.z.string(),value:s.z.string().optional()}),ql=s.z.object({name:s.z.string().max(255),code:s.z.string().max(1e5),supported_triggers:s.z.array(qw).optional(),runtime:s.z.string().max(50).optional(),dependencies:s.z.array(Hw).optional(),secrets:s.z.array(Vw).optional(),is_system:s.z.boolean().optional(),inherit:s.z.boolean().optional()}),I9=ql.partial().extend({status:s.z.enum(["draft","built"]).optional(),deployed_at:s.z.string().optional()}),nr=ql.extend({id:s.z.string(),tenant_id:s.z.string(),status:s.z.enum(["draft","built"]).default("built"),deployed_at:s.z.string().optional(),secrets:s.z.array(s.z.object({name:s.z.string(),value:s.z.string().optional()})).optional(),...Un.shape}),wx=s.z.string(),Kw=s.z.enum(["unspecified","pending","final","partial","canceled","suspended"]),bx=s.z.object({id:s.z.string(),msg:s.z.string(),url:s.z.string().optional()}),Gw=s.z.object({action_name:s.z.string(),error:bx.nullable(),started_at:s.z.string(),ended_at:s.z.string()}),vx=s.z.object({level:s.z.enum(["log","info","warn","error","debug"]),message:s.z.string()}),Ww=s.z.array(s.z.object({action_name:s.z.string(),lines:s.z.array(vx)})),Ax=s.z.object({id:s.z.string(),tenant_id:s.z.string(),trigger_id:wx,status:Kw,results:s.z.array(Gw),logs:Ww.optional(),created_at:s.z.string(),updated_at:s.z.string()}),z9=Ax.omit({tenant_id:!0,created_at:!0,updated_at:!0}),kx=s.z.object({action_id:s.z.string(),code:s.z.string().max(1e5),runtime:s.z.string().max(50).optional(),dependencies:s.z.array(Hw).optional(),secrets:s.z.array(Vw).optional(),supported_triggers:s.z.array(qw).optional(),deployed:s.z.boolean().default(!0)}),yh=kx.extend({id:s.z.string(),tenant_id:s.z.string(),number:s.z.number().int(),...Un.shape}),Sx=s.z.enum(["user_action","admin_action","system","api"]),Ex=s.z.object({type:s.z.enum(["user","admin","system","api_key","client_credentials"]),id:s.z.string().optional(),email:s.z.string().optional(),org_id:s.z.string().optional(),org_name:s.z.string().optional(),scopes:s.z.array(s.z.string()).optional(),client_id:s.z.string().optional()}),xx=s.z.object({type:s.z.string(),id:s.z.string(),before:s.z.record(s.z.unknown()).optional(),after:s.z.record(s.z.unknown()).optional(),diff:s.z.record(s.z.object({old:s.z.unknown(),new:s.z.unknown()})).optional()}),Cx=s.z.object({method:s.z.string(),path:s.z.string(),query:s.z.record(s.z.string()).optional(),body:s.z.unknown().optional(),ip:s.z.string(),user_agent:s.z.string().optional(),correlation_id:s.z.string().optional()}),Tx=s.z.object({status_code:s.z.number(),body:s.z.unknown().optional()}),$x=s.z.object({country_code:s.z.string(),city_name:s.z.string(),latitude:s.z.string(),longitude:s.z.string(),time_zone:s.z.string(),continent_code:s.z.string()}),Ix=s.z.object({name:s.z.string(),version:s.z.string(),env:s.z.record(s.z.string()).optional()}),zx=s.z.object({tenant_id:s.z.string(),event_type:s.z.string(),log_type:s.z.string(),description:s.z.string().optional(),category:Sx,actor:Ex,target:xx,request:Cx,response:Tx.optional(),connection:s.z.string().optional(),strategy:s.z.string().optional(),strategy_type:s.z.string().optional(),audience:s.z.string().optional(),scope:s.z.string().optional(),location:$x.optional(),auth0_client:Ix.optional(),hostname:s.z.string(),is_mobile:s.z.boolean().optional(),timestamp:s.z.string()}),Px=zx.extend({id:s.z.string()}),P9=s.z.enum(["AUTH0","EMAIL","REDIRECT"]),N9=s.z.enum(["CREATE_USER","GET_USER","UPDATE_USER","SEND_REQUEST","SEND_EMAIL"]),j9=s.z.enum(["VERIFY_EMAIL"]),Nx=s.z.object({require_mx_record:s.z.boolean().optional(),block_aliases:s.z.boolean().optional(),block_free_emails:s.z.boolean().optional(),block_disposable_emails:s.z.boolean().optional(),blocklist:s.z.array(s.z.string()).optional(),allowlist:s.z.array(s.z.string()).optional()}),jx=s.z.object({id:s.z.string(),alias:s.z.string().max(100).optional(),type:s.z.literal("AUTH0"),action:s.z.literal("UPDATE_USER"),allow_failure:s.z.boolean().optional(),mask_output:s.z.boolean().optional(),params:s.z.object({connection_id:s.z.string().optional(),user_id:s.z.string(),changes:s.z.record(s.z.string(),s.z.any())})}),Ox=s.z.object({id:s.z.string(),alias:s.z.string().max(100).optional(),type:s.z.literal("EMAIL"),action:s.z.literal("VERIFY_EMAIL"),allow_failure:s.z.boolean().optional(),mask_output:s.z.boolean().optional(),params:s.z.object({email:s.z.string(),rules:Nx.optional()})}),Fx=s.z.enum(["change-email","account","custom"]),Rx=s.z.object({id:s.z.string(),alias:s.z.string().max(100).optional(),type:s.z.literal("REDIRECT"),action:s.z.literal("REDIRECT_USER"),allow_failure:s.z.boolean().optional(),mask_output:s.z.boolean().optional(),params:s.z.object({target:Fx.openapi({description:"The predefined target to redirect to, or 'custom' for a custom URL"}),custom_url:s.z.string().optional().openapi({description:"Custom URL to redirect to when target is 'custom'"})})}),Dx=s.z.union([jx,Ox,Rx]),Cp=s.z.object({name:s.z.string().min(1).max(150).openapi({description:"The name of the flow"}),actions:s.z.array(Dx).optional().default([]).openapi({description:"The list of actions to execute in sequence"})}),oa=Cp.extend({...Un.shape,id:s.z.string().openapi({description:"Unique identifier for the flow",example:"af_12tMpdJ3iek7svMyZkSh5M"})}),O9=s.z.object({page:s.z.string().min(0).optional().default("0").transform(e=>parseInt(e,10)).openapi({description:"The page number where 0 is the first page"}),per_page:s.z.string().min(1).optional().default("10").transform(e=>parseInt(e,10)).openapi({description:"The number of items per page"}),include_totals:s.z.string().optional().default("false").transform(e=>e==="true").openapi({description:"If the total number of items should be included in the response"}),sort:s.z.string().regex(/^.+:(-1|1)$/).optional().openapi({description:"A property that should have the format 'string:-1' or 'string:1'"}),q:s.z.string().optional().openapi({description:"A lucene query string used to filter the results"})}),xt=s.z.object({start:s.z.number(),limit:s.z.number(),length:s.z.number(),total:s.z.number().optional()}),Bx=s.z.object({email:s.z.string().optional(),email_verified:s.z.boolean().optional(),name:s.z.string().optional(),username:s.z.string().optional(),given_name:s.z.string().optional(),phone_number:s.z.string().optional(),phone_verified:s.z.boolean().optional(),family_name:s.z.string().optional()}).catchall(s.z.any()),Tp=s.z.object({connection:s.z.string(),user_id:s.z.string(),provider:s.z.string(),isSocial:s.z.boolean(),email:s.z.string().optional(),email_verified:s.z.boolean().optional(),phone_number:s.z.string().optional(),phone_verified:s.z.boolean().optional(),username:s.z.string().optional(),access_token:s.z.string().optional(),access_token_secret:s.z.string().optional(),refresh_token:s.z.string().optional(),profileData:Bx.optional()}),Lx=s.z.object({formatted:s.z.string().optional(),street_address:s.z.string().optional(),locality:s.z.string().optional(),region:s.z.string().optional(),postal_code:s.z.string().optional(),country:s.z.string().optional()}).optional(),_h=s.z.object({email:s.z.string().optional().transform(e=>e&&e.toLowerCase()),username:s.z.string().refine(e=>!e.includes("@"),{message:'Usernames must not contain "@". Use the email field for email addresses.'}).optional(),phone_number:s.z.string().optional(),phone_verified:s.z.boolean().optional(),given_name:s.z.string().optional(),family_name:s.z.string().optional(),nickname:s.z.string().optional(),name:s.z.string().optional(),picture:s.z.string().optional(),locale:s.z.string().optional(),linked_to:s.z.string().optional(),profileData:s.z.string().optional(),user_id:s.z.string().optional(),app_metadata:s.z.any().default({}).optional(),user_metadata:s.z.any().default({}).optional(),middle_name:s.z.string().optional(),preferred_username:s.z.string().optional(),profile:s.z.string().optional(),website:s.z.string().optional(),gender:s.z.string().optional(),birthdate:s.z.string().optional(),zoneinfo:s.z.string().optional(),address:Lx}),$p=_h.extend({email_verified:s.z.boolean().default(!1),verify_email:s.z.boolean().optional(),last_ip:s.z.string().optional(),last_login:s.z.string().optional(),user_id:s.z.string().optional(),provider:s.z.string().optional(),connection:s.z.string(),is_social:s.z.boolean().optional(),registration_completed_at:s.z.string().optional(),password:s.z.object({hash:s.z.string(),algorithm:s.z.string()}).optional()}),Jw=s.z.object({...$p.omit({password:!0}).shape,...Un.shape,user_id:s.z.string(),provider:s.z.string(),is_social:s.z.boolean(),email:s.z.string().optional(),login_count:s.z.number().default(0),identities:s.z.array(Tp).optional()}),Nn=Jw.omit({registration_completed_at:!0}),F9=_h.extend({login_count:s.z.number(),multifactor:s.z.array(s.z.string()).optional(),last_ip:s.z.string().optional(),last_login:s.z.string().optional(),user_id:s.z.string()}).catchall(s.z.any());let R9="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict",D9=(e=21)=>{let t="",n=crypto.getRandomValues(new Uint8Array(e|=0));for(;e--;)t+=R9[n[e]&63];return t};const Ip=s.z.object({client_id:s.z.string().optional().openapi({description:"ID of this client. Generated server-side if omitted (Auth0 behavior)."}),name:s.z.string().min(1).openapi({description:"Name of this client (min length: 1 character, does not allow < or >)."}),description:s.z.string().max(140).optional().openapi({description:"Free text description of this client (max length: 140 characters)."}),global:s.z.boolean().default(!1).openapi({description:"Whether this is your global 'All Applications' client representing legacy tenant settings (true) or a regular client (false)."}),client_secret:s.z.string().default(()=>D9()).optional().openapi({description:"Client secret (which you must not make public)."}),app_type:s.z.enum(["native","spa","regular_web","non_interactive","resource_server","express_configuration","rms","box","cloudbees","concur","dropbox","mscrm","echosign","egnyte","newrelic","office365","salesforce","sentry","sharepoint","slack","springcm","zendesk","zoom","sso_integration","oag"]).default("regular_web").optional().openapi({description:"The type of application this client represents"}),logo_uri:s.z.string().url().optional().openapi({description:"URL of the logo to display for this client. Recommended size is 150x150 pixels."}),is_first_party:s.z.boolean().default(!1).openapi({description:"Whether this client a first party client (true) or not (false)."}),oidc_conformant:s.z.boolean().default(!0).openapi({description:"Whether this client conforms to strict OIDC specifications (true) or uses legacy features (false)."}),auth0_conformant:s.z.boolean().default(!0).openapi({description:"Whether this client follows Auth0-compatible behavior (true) or strict OIDC behavior (false). When true, profile/email claims are included in the ID token when scopes are requested. When false, these claims are only available from the userinfo endpoint (strict OIDC 5.4 compliance)."}),callbacks:s.z.array(s.z.string()).default([]).optional().openapi({description:"Comma-separated list of URLs whitelisted for Auth0 to use as a callback to the client after authentication."}),allowed_origins:s.z.array(s.z.string()).default([]).optional().openapi({description:"Comma-separated list of URLs allowed to make requests from JavaScript to Auth0 API (typically used with CORS). By default, all your callback URLs will be allowed. This field allows you to enter other origins if necessary. You can also use wildcards at the subdomain level (e.g., https://*.contoso.com). Query strings and hash information are not taken into account when validating these URLs."}),web_origins:s.z.array(s.z.string()).default([]).optional().openapi({description:"Comma-separated list of allowed origins for use with Cross-Origin Authentication, Device Flow, and web message response mode."}),client_aliases:s.z.array(s.z.string()).default([]).optional().openapi({description:"List of audiences/realms for SAML protocol. Used by the wsfed addon."}),allowed_clients:s.z.array(s.z.string()).default([]).optional().openapi({description:"List of allow clients and API ids that are allowed to make delegation requests. Empty means all all your clients are allowed."}),connections:s.z.array(s.z.string()).default([]).optional().openapi({description:"List of connection IDs enabled for this client. The order determines the display order on the login page."}),allowed_logout_urls:s.z.array(s.z.string()).default([]).optional().openapi({description:"Comma-separated list of URLs that are valid to redirect to after logout from Auth0. Wildcards are allowed for subdomains."}),session_transfer:s.z.record(s.z.any()).default({}).optional().openapi({description:"Native to Web SSO Configuration"}),oidc_logout:s.z.record(s.z.any()).default({}).optional().openapi({description:"Configuration for OIDC backchannel logout"}),grant_types:s.z.array(s.z.string()).default([]).optional().openapi({description:"List of grant types supported for this application. Can include authorization_code, implicit, refresh_token, client_credentials, password, http://auth0.com/oauth/grant-type/password-realm, http://auth0.com/oauth/grant-type/mfa-oob, http://auth0.com/oauth/grant-type/mfa-otp, http://auth0.com/oauth/grant-type/mfa-recovery-code, urn:openid:params:grant-type:ciba, and urn:ietf:params:oauth:grant-type:device_code."}),jwt_configuration:s.z.record(s.z.any()).default({}).optional().openapi({description:"Configuration related to JWTs for the client."}),signing_keys:s.z.array(s.z.record(s.z.any())).default([]).optional().openapi({description:"Signing certificates associated with this client."}),encryption_key:s.z.record(s.z.any()).default({}).optional().openapi({description:"Encryption used for WsFed responses with this client."}),sso:s.z.boolean().default(!1).openapi({description:"Applies only to SSO clients and determines whether Auth0 will handle Single Sign On (true) or whether the Identity Provider will (false)."}),sso_disabled:s.z.boolean().default(!1).openapi({description:"Whether Single Sign On is disabled for this client. When true, existing SSO sessions will not be reused and users must authenticate every time."}),cross_origin_authentication:s.z.boolean().default(!1).openapi({description:"Whether this client can be used to make cross-origin authentication requests (true) or it is not allowed to make such requests (false)."}),cross_origin_loc:s.z.string().url().optional().openapi({description:"URL of the location in your site where the cross origin verification takes place for the cross-origin auth flow when performing Auth in your own domain instead of Auth0 hosted login page."}),custom_login_page_on:s.z.boolean().default(!1).openapi({description:"Whether a custom login page is to be used (true) or the default provided login page (false)."}),custom_login_page:s.z.string().optional().openapi({description:"The content (HTML, CSS, JS) of the custom login page."}),custom_login_page_preview:s.z.string().optional().openapi({description:"The content (HTML, CSS, JS) of the custom login page. (Used on Previews)"}),form_template:s.z.string().optional().openapi({description:"HTML form template to be used for WS-Federation."}),addons:s.z.record(s.z.any()).default({}).optional().openapi({description:"Addons enabled for this client and their associated configurations."}),token_endpoint_auth_method:s.z.enum(["none","client_secret_post","client_secret_basic","client_secret_jwt","private_key_jwt"]).default("client_secret_basic").optional().openapi({description:"Defines the requested authentication method for the token endpoint. `none` (public client), `client_secret_post` / `client_secret_basic` (HTTP POST / Basic), `client_secret_jwt` (RFC 7523 HMAC assertion using client_secret), or `private_key_jwt` (RFC 7523 asymmetric assertion verified against the client's `jwks` / `jwks_uri`)."}),client_metadata:s.z.record(s.z.string().max(255)).default({}).optional().openapi({description:'Metadata associated with the client, in the form of an object with string values (max 255 chars). Maximum of 10 metadata properties allowed. Field names (max 255 chars) are alphanumeric and may only include the following special characters: :,-+=_*?"/()<>@ [Tab][Space]'}),hide_sign_up_disabled_error:s.z.boolean().default(!1).optional().openapi({description:"Enumeration-safe variant of the connection-level `disable_signup` flag. When a signup is blocked by the password connection and this is true, the identifier screen does not reveal that an email is unknown — it advances to the OTP/password challenge as if the account existed and fails at credential check. Mitigates email enumeration at the cost of UX: users without an account see a generic credential failure instead of an explicit signup-disabled message."}),mobile:s.z.record(s.z.any()).default({}).optional().openapi({description:"Additional configuration for native mobile apps."}),initiate_login_uri:s.z.string().url().optional().openapi({description:"Initiate login uri, must be https"}),native_social_login:s.z.record(s.z.any()).default({}).optional(),refresh_token:s.z.object({rotation_type:s.z.enum(["rotating","non-rotating"]).optional().openapi({description:"Whether refresh tokens for this client are rotated on every exchange (Auth0 'rotating' behavior) or kept stable (legacy non-rotating). Defaults to 'non-rotating' when unset."}),leeway:s.z.number().int().min(0).max(600).optional().openapi({description:"Seconds after a parent token's first rotation during which presenting it again still mints a fresh sibling child instead of triggering reuse-detection. Defaults to 30s when unset."}),expiration_type:s.z.enum(["expiring","non-expiring"]).optional().openapi({description:"Auth0-compatible: whether refresh tokens expire."}),token_lifetime:s.z.number().int().min(0).optional().openapi({description:"Auth0-compatible: refresh-token absolute lifetime in seconds."}),infinite_token_lifetime:s.z.boolean().optional().openapi({description:"Auth0-compatible: when true, refresh tokens have no absolute expiry."}),idle_token_lifetime:s.z.number().int().min(0).optional().openapi({description:"Auth0-compatible: refresh-token idle (sliding) lifetime in seconds."}),infinite_idle_token_lifetime:s.z.boolean().optional().openapi({description:"Auth0-compatible: when true, refresh tokens have no idle expiry."})}).default({}).optional().openapi({description:"Refresh token configuration"}),default_organization:s.z.record(s.z.any()).default({}).optional().openapi({description:"Defines the default Organization ID and flows"}),organization_usage:s.z.enum(["deny","allow","require"]).default("deny").optional().openapi({description:"Defines how to proceed during an authentication transaction with regards an organization. Can be deny (default), allow or require."}),organization_require_behavior:s.z.enum(["no_prompt","pre_login_prompt","post_login_prompt"]).default("no_prompt").optional().openapi({description:"Defines how to proceed during an authentication transaction when client.organization_usage: 'require'. Can be no_prompt (default), pre_login_prompt or post_login_prompt. post_login_prompt requires oidc_conformant: true."}),client_authentication_methods:s.z.record(s.z.any()).default({}).optional().openapi({description:"Defines client authentication methods."}),require_pushed_authorization_requests:s.z.boolean().default(!1).openapi({description:"Makes the use of Pushed Authorization Requests mandatory for this client"}),require_proof_of_possession:s.z.boolean().default(!1).openapi({description:"Makes the use of Proof-of-Possession mandatory for this client"}),signed_request_object:s.z.record(s.z.any()).default({}).optional().openapi({description:"JWT-secured Authorization Requests (JAR) settings."}),compliance_level:s.z.enum(["none","fapi1_adv_pkj_par","fapi1_adv_mtls_par","fapi2_sp_pkj_mtls","fapi2_sp_mtls_mtls"]).optional().openapi({description:"Defines the compliance level for this client, which may restrict it's capabilities"}),par_request_expiry:s.z.number().optional().openapi({description:"Specifies how long, in seconds, a Pushed Authorization Request URI remains valid"}),token_quota:s.z.record(s.z.any()).default({}).optional(),owner_user_id:s.z.string().optional().openapi({description:"User ID of the consenting user when this client was created via IAT-gated Dynamic Client Registration. NULL for clients created via the Management API or open DCR."}),registration_type:s.z.enum(["manual","open_dcr","iat_dcr"]).optional().openapi({description:"Provenance of this client. `manual` = Management API; `open_dcr` = RFC 7591 without IAT; `iat_dcr` = RFC 7591 with an Initial Access Token."}),registration_metadata:s.z.record(s.z.any()).default({}).optional().openapi({description:"Arbitrary metadata captured at Dynamic Client Registration time that isn't a first-class client field (e.g. integration_type, domain). Also stores `iat_constraints` for clients created via IAT so RFC 7592 PUT can enforce field immutability."}),user_linking_mode:s.z.enum(["builtin","off"]).optional().openapi({description:"Per-client override for the built-in email-based user-linking path. `builtin` runs the legacy in-process linking at user creation/email update. `off` disables the legacy path; linking only happens if the tenant has enabled the `account-linking` template hook. When unset, the service-level `userLinkingMode` default applies."})}),Lo=s.z.object({created_at:s.z.string(),updated_at:s.z.string(),...Ip.shape,client_id:s.z.string()}),zp=s.z.object({client_id:s.z.string().min(1).openapi({description:"ID of the client."}),audience:s.z.string().min(1).openapi({description:"The audience (API identifier) of this client grant."}),scope:s.z.array(s.z.string()).optional().openapi({description:"Scopes allowed for this client grant."}),organization_usage:s.z.enum(["deny","allow","require"]).optional().openapi({description:"Defines whether organizations can be used with client credentials exchanges for this grant."}),allow_any_organization:s.z.boolean().optional().openapi({description:"If enabled, any organization can be used with this grant. If disabled (default), the grant must be explicitly assigned to the desired organizations."}),is_system:s.z.boolean().optional().openapi({description:"If enabled, this grant is a special grant created by Auth0. It cannot be modified or deleted directly."}),subject_type:s.z.enum(["client","user"]).optional().openapi({description:"The type of application access the client grant allows. Use of this field is subject to the applicable Free Trial terms in Okta's Master Subscription Agreement."}),authorization_details_types:s.z.array(s.z.string()).optional().openapi({description:"Types of authorization_details allowed for this client grant. Use of this field is subject to the applicable Free Trial terms in Okta's Master Subscription Agreement."})}),Mo=s.z.object({id:s.z.string().openapi({description:"ID of the client grant."}),...zp.shape,created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),B9=s.z.array(Mo),Mx=s.z.enum(["iat","rat"]),Ux=s.z.object({id:s.z.string(),token_hash:s.z.string(),type:Mx,client_id:s.z.string().optional(),sub:s.z.string().optional(),constraints:s.z.record(s.z.unknown()).optional(),single_use:s.z.boolean().default(!1),expires_at:s.z.string().optional()}),L9=s.z.object({created_at:s.z.string(),used_at:s.z.string().optional(),revoked_at:s.z.string().optional(),...Ux.shape}),bs=s.z.object({x:s.z.number(),y:s.z.number()});var Yw=(e=>(e.RICH_TEXT="RICH_TEXT",e.NEXT_BUTTON="NEXT_BUTTON",e.BACK_BUTTON="BACK_BUTTON",e.SUBMIT_BUTTON="SUBMIT_BUTTON",e.DIVIDER="DIVIDER",e.TEXT="TEXT",e.EMAIL="EMAIL",e.PASSWORD="PASSWORD",e.NUMBER="NUMBER",e.PHONE="PHONE",e.DATE="DATE",e.CHECKBOX="CHECKBOX",e.RADIO="RADIO",e.SELECT="SELECT",e.HIDDEN="HIDDEN",e.LEGAL="LEGAL",e))(Yw||{}),Qw=(e=>(e.BLOCK="BLOCK",e.FIELD="FIELD",e))(Qw||{});const wh=s.z.object({id:s.z.string(),category:s.z.nativeEnum(Qw),type:s.z.nativeEnum(Yw)}),qx=wh.extend({category:s.z.literal("BLOCK"),type:s.z.literal("RICH_TEXT"),config:s.z.object({content:s.z.string()}).passthrough()}),Hx=wh.extend({category:s.z.literal("BLOCK"),type:s.z.union([s.z.literal("NEXT_BUTTON"),s.z.literal("BACK_BUTTON"),s.z.literal("SUBMIT_BUTTON")]),config:s.z.object({text:s.z.string()}).passthrough()}),Vx=wh.extend({category:s.z.literal("FIELD"),type:s.z.literal("LEGAL"),required:s.z.boolean().optional(),sensitive:s.z.boolean().optional(),config:s.z.object({text:s.z.string()}).passthrough()}),Kx=wh.extend({category:s.z.literal("FIELD"),type:s.z.union([s.z.literal("TEXT"),s.z.literal("EMAIL"),s.z.literal("PASSWORD"),s.z.literal("NUMBER"),s.z.literal("PHONE"),s.z.literal("DATE"),s.z.literal("CHECKBOX"),s.z.literal("RADIO"),s.z.literal("SELECT"),s.z.literal("HIDDEN")]),required:s.z.boolean().optional(),sensitive:s.z.boolean().optional(),config:s.z.object({label:s.z.string().optional(),placeholder:s.z.string().optional()}).passthrough()}),Gx=s.z.object({id:s.z.string(),category:s.z.string(),type:s.z.string()}).passthrough(),Wx=s.z.union([qx,Hx,Vx,Kx,Gx]);var Jx=(e=>(e.STEP="STEP",e.FLOW="FLOW",e.CONDITION="CONDITION",e.ACTION="ACTION",e))(Jx||{});const Yx=s.z.object({id:s.z.string(),type:s.z.literal("STEP"),coordinates:bs,alias:s.z.string().optional(),config:s.z.object({components:s.z.array(Wx),next_node:s.z.string()}).passthrough()}),Qx=s.z.object({id:s.z.string(),type:s.z.literal("FLOW"),coordinates:bs,alias:s.z.string().optional(),config:s.z.object({flow_id:s.z.string(),next_node:s.z.string()})}),Zx=s.z.object({id:s.z.string(),type:s.z.literal("ACTION"),coordinates:bs,alias:s.z.string().optional(),config:s.z.object({action_type:s.z.enum(["REDIRECT"]).openapi({description:"The type of action to perform"}),target:s.z.enum(["change-email","account","custom"]).openapi({description:"The predefined target to redirect to"}),custom_url:s.z.string().optional().openapi({description:"Custom URL when target is 'custom'"}),next_node:s.z.string().openapi({description:"The next node to navigate to after action (for non-redirect actions)"})}).passthrough()}),Xx=s.z.object({id:s.z.string(),type:s.z.string(),coordinates:bs}).passthrough(),eC=s.z.union([Yx,Qx,Zx,Xx]),tC=s.z.object({next_node:s.z.string(),coordinates:bs}).passthrough(),nC=s.z.object({resume_flow:s.z.boolean().optional(),coordinates:bs}).passthrough(),iC=s.z.object({id:s.z.string(),name:s.z.string(),languages:s.z.object({primary:s.z.string()}).passthrough(),nodes:s.z.array(eC),start:tC,ending:nC,created_at:s.z.string(),updated_at:s.z.string(),links:s.z.object({sdkSrc:s.z.string().optional(),sdk_src:s.z.string().optional()}).passthrough()}).passthrough(),M9=iC.omit({id:!0,created_at:!0,updated_at:!0});var xn=(e=>(e.TOKEN="token",e.ID_TOKEN="id_token",e.TOKEN_ID_TOKEN="id_token token",e.CODE="code",e.CODE_ID_TOKEN="code id_token",e.CODE_TOKEN="code token",e.CODE_ID_TOKEN_TOKEN="code id_token token",e))(xn||{}),mt=(e=>(e.QUERY="query",e.FRAGMENT="fragment",e.FORM_POST="form_post",e.WEB_MESSAGE="web_message",e.SAML_POST="saml_post",e))(mt||{}),bh=(e=>(e.S256="S256",e.Plain="plain",e))(bh||{});const c2=s.z.union([s.z.null(),s.z.object({essential:s.z.boolean().optional(),value:s.z.unknown().optional(),values:s.z.array(s.z.unknown()).optional()})]).nullable(),Zw=s.z.object({userinfo:s.z.record(s.z.string(),c2).optional(),id_token:s.z.record(s.z.string(),c2).optional()}),Hl=s.z.object({client_id:s.z.string(),act_as:s.z.string().optional(),response_type:s.z.nativeEnum(xn).optional(),response_mode:s.z.nativeEnum(mt).optional(),redirect_uri:s.z.string().optional(),audience:s.z.string().optional(),organization:s.z.string().optional(),state:s.z.string().optional(),nonce:s.z.string().optional(),scope:s.z.string().optional(),prompt:s.z.string().optional(),code_challenge_method:s.z.nativeEnum(bh).optional(),code_challenge:s.z.string().optional(),username:s.z.string().optional(),ui_locales:s.z.string().optional(),max_age:s.z.number().optional(),acr_values:s.z.string().optional(),claims:Zw.optional(),vendor_id:s.z.string().optional()}),rp=s.z.object({colors:s.z.object({primary:s.z.string(),page_background:s.z.union([s.z.string(),s.z.object({type:s.z.string().optional(),start:s.z.string().optional(),end:s.z.string().optional(),angle_deg:s.z.number().optional()})]).optional()}).optional(),logo_url:s.z.string().optional(),favicon_url:s.z.string().optional(),powered_by_logo_url:s.z.string().optional(),font:s.z.object({url:s.z.string()}).optional(),dark_mode:s.z.enum(["dark","light","auto"]).optional()}),rC=s.z.enum(["password_reset","email_verification","otp","mfa_otp","authorization_code","oauth2_state","ticket"]),oC=s.z.object({code_id:s.z.string().openapi({description:"The code that will be used in for instance an email verification flow"}),login_id:s.z.string().openapi({description:"The id of the login session that the code is connected to"}),connection_id:s.z.string().optional().openapi({description:"The connection that the code is connected to"}),code_type:rC,code_verifier:s.z.string().optional().openapi({description:"The code verifier used in PKCE in outbound flows"}),code_challenge:s.z.string().optional().openapi({description:"The code challenge used in PKCE in outbound flows"}),code_challenge_method:s.z.enum(["plain","S256"]).optional().openapi({description:"The code challenge method used in PKCE in outbound flows"}),redirect_uri:s.z.string().optional().openapi({description:"The redirect URI associated with the code"}),otp:s.z.string().optional().openapi({description:"The one-time password value for OTP-based flows"}),nonce:s.z.string().optional().openapi({description:"The nonce value used for security in OIDC flows"}),state:s.z.string().optional().openapi({description:"The state parameter used for CSRF protection in OAuth flows"}),expires_at:s.z.string(),used_at:s.z.string().optional(),user_id:s.z.string().optional()}),U9=s.z.object({...oC.shape,created_at:s.z.string()}),sC=s.z.object({kid:s.z.string().optional(),team_id:s.z.string().optional(),realms:s.z.string().optional(),authentication_method:s.z.string().optional(),client_id:s.z.string().optional(),client_secret:s.z.string().optional(),app_secret:s.z.string().optional(),scope:s.z.string().optional(),authorization_endpoint:s.z.string().optional(),token_endpoint:s.z.string().optional(),userinfo_endpoint:s.z.string().optional(),jwks_uri:s.z.string().optional(),discovery_url:s.z.string().optional(),issuer:s.z.string().optional(),token_endpoint_auth_method:s.z.enum(["client_secret_basic","client_secret_post"]).optional(),provider:s.z.string().optional(),from:s.z.string().optional(),twilio_sid:s.z.string().optional(),twilio_token:s.z.string().optional(),icon_url:s.z.string().optional(),domain_aliases:s.z.array(s.z.string()).optional(),callback_url:s.z.string().url().optional(),passwordPolicy:s.z.enum(["none","low","fair","good","excellent"]).optional(),password_complexity_options:s.z.object({min_length:s.z.number().optional()}).optional(),password_history:s.z.object({enable:s.z.boolean().optional(),size:s.z.number().optional()}).optional(),password_no_personal_info:s.z.object({enable:s.z.boolean().optional()}).optional(),password_dictionary:s.z.object({enable:s.z.boolean().optional(),dictionary:s.z.array(s.z.string()).optional()}).optional(),disable_signup:s.z.boolean().optional(),brute_force_protection:s.z.boolean().optional(),import_mode:s.z.boolean().optional(),configuration:s.z.object({token_endpoint:s.z.string().optional(),userinfo_endpoint:s.z.string().optional(),client_id:s.z.string().optional(),client_secret:s.z.string().optional()}).optional(),attributes:s.z.object({email:s.z.object({identifier:s.z.object({active:s.z.boolean().optional()}).optional(),signup:s.z.object({status:s.z.enum(["required","optional","disabled"]).optional(),verification:s.z.object({active:s.z.boolean().optional()}).optional()}).optional(),validation:s.z.object({allowed:s.z.boolean().optional()}).optional(),unique:s.z.boolean().optional(),profile_required:s.z.boolean().optional(),verification_method:s.z.enum(["link","code"]).optional()}).optional(),username:s.z.object({identifier:s.z.object({active:s.z.boolean().optional()}).optional(),signup:s.z.object({status:s.z.enum(["required","optional","disabled"]).optional()}).optional(),validation:s.z.object({max_length:s.z.number().optional(),min_length:s.z.number().optional(),allowed_types:s.z.object({email:s.z.boolean().optional(),phone_number:s.z.boolean().optional()}).optional()}).optional(),profile_required:s.z.boolean().optional()}).optional(),phone_number:s.z.object({identifier:s.z.object({active:s.z.boolean().optional()}).optional(),signup:s.z.object({status:s.z.enum(["required","optional","disabled"]).optional()}).optional()}).optional()}).optional(),authentication_methods:s.z.object({password:s.z.object({enabled:s.z.boolean().optional()}).optional(),passkey:s.z.object({enabled:s.z.boolean().optional()}).optional()}).optional(),passkey_options:s.z.object({challenge_ui:s.z.enum(["both","autofill","button"]).optional(),local_enrollment_enabled:s.z.boolean().optional(),progressive_enrollment_enabled:s.z.boolean().optional()}).optional(),requires_username:s.z.boolean().optional(),validation:s.z.object({username:s.z.object({min:s.z.number().optional(),max:s.z.number().optional()}).optional()}).optional(),set_user_root_attributes:s.z.enum(["on_each_login","on_first_login","never_on_login"]).optional()});function _y(e){if(e!==null){if(Array.isArray(e))return e.filter(t=>t!==null).map(_y);if(e&&typeof e=="object"){const t={};for(const[n,i]of Object.entries(e))i!==null&&(t[n]=_y(i));return t}return e}}const Pp=s.z.object({id:s.z.string().optional(),name:s.z.string(),display_name:s.z.string().optional(),strategy:s.z.string(),options:s.z.preprocess(e=>e===null?{}:_y(e),sC).default({}),enabled_clients:s.z.array(s.z.string()).default([]).optional(),response_type:s.z.custom().optional(),response_mode:s.z.custom().optional(),is_domain_connection:s.z.boolean().optional(),show_as_button:s.z.boolean().optional(),metadata:s.z.record(s.z.any()).optional(),is_system:s.z.boolean().optional()}),Lr=s.z.object({id:s.z.string(),created_at:s.z.string().transform(e=>e===null?"":e),updated_at:s.z.string().transform(e=>e===null?"":e)}).extend(Pp.shape),Xw=s.z.object({domain:s.z.string(),custom_domain_id:s.z.string().optional(),type:s.z.enum(["auth0_managed_certs","self_managed_certs"]),verification_method:s.z.enum(["txt"]).optional(),tls_policy:s.z.enum(["recommended"]).optional(),custom_client_ip_header:s.z.enum(["true-client-ip","cf-connecting-ip","x-forwarded-for","x-azure-clientip","null"]).optional(),domain_metadata:s.z.record(s.z.string().max(255)).optional()}),aC=s.z.discriminatedUnion("name",[s.z.object({name:s.z.literal("txt"),record:s.z.string(),domain:s.z.string()}),s.z.object({name:s.z.literal("http"),http_body:s.z.string(),http_url:s.z.string()})]),Fr=s.z.object({...Xw.shape,custom_domain_id:s.z.string(),primary:s.z.boolean(),status:s.z.enum(["disabled","pending","pending_verification","ready"]),origin_domain_name:s.z.string().optional(),verification:s.z.object({methods:s.z.array(aC)}).optional(),tls_policy:s.z.string().optional()}),q9=Fr.extend({tenant_id:s.z.string()}),eb=s.z.object({id:s.z.string(),order:s.z.number().optional(),visible:s.z.boolean().optional().default(!0)}),ao=eb.extend({category:s.z.literal("BLOCK").optional()}),H9=ao.extend({type:s.z.literal("DIVIDER"),config:s.z.object({text:s.z.string().optional()}).optional()}),V9=ao.extend({type:s.z.literal("HTML"),config:s.z.object({content:s.z.string().optional()}).optional()}),K9=ao.extend({type:s.z.literal("IMAGE"),config:s.z.object({src:s.z.string().optional(),alt:s.z.string().optional(),width:s.z.number().optional(),height:s.z.number().optional()}).optional()}),G9=ao.extend({type:s.z.literal("JUMP_BUTTON"),config:s.z.object({text:s.z.string().optional(),target_step:s.z.string().optional()})}),W9=ao.extend({type:s.z.literal("RESEND_BUTTON"),config:s.z.object({text:s.z.string().optional(),resend_action:s.z.string().optional()})}),J9=ao.extend({type:s.z.literal("NEXT_BUTTON"),config:s.z.object({text:s.z.string().optional()})}),Y9=ao.extend({type:s.z.literal("PREVIOUS_BUTTON"),config:s.z.object({text:s.z.string().optional()})}),Q9=ao.extend({type:s.z.literal("RICH_TEXT"),config:s.z.object({content:s.z.string().optional()}).optional()}),tb=eb.extend({category:s.z.literal("WIDGET").optional(),label:s.z.string().min(1).optional(),hint:s.z.string().min(1).max(500).optional(),required:s.z.boolean().optional(),sensitive:s.z.boolean().optional()}),Z9=tb.extend({type:s.z.literal("AUTH0_VERIFIABLE_CREDENTIALS"),config:s.z.object({credential_type:s.z.string().optional()})}),X9=tb.extend({type:s.z.literal("GMAPS_ADDRESS"),config:s.z.object({api_key:s.z.string().optional()})}),ej=tb.extend({type:s.z.literal("RECAPTCHA"),config:s.z.object({site_key:s.z.string().optional()})}),qt=eb.extend({category:s.z.literal("FIELD").optional(),label:s.z.string().min(1).optional(),hint:s.z.string().min(1).max(500).optional(),messages:s.z.array(s.z.object({id:s.z.number().optional(),text:s.z.string(),type:s.z.enum(["info","error","success","warning"])})).optional(),required:s.z.boolean().optional(),sensitive:s.z.boolean().optional()}),tj=qt.extend({type:s.z.literal("BOOLEAN"),config:s.z.object({default_value:s.z.boolean().optional()}).optional()}),nj=qt.extend({type:s.z.literal("CARDS"),config:s.z.object({options:s.z.array(s.z.object({value:s.z.string(),label:s.z.string(),description:s.z.string().optional(),image:s.z.string().optional()})).optional(),multi_select:s.z.boolean().optional()}).optional()}),ij=qt.extend({type:s.z.literal("CHOICE"),config:s.z.object({options:s.z.array(s.z.object({value:s.z.string(),label:s.z.string()})).optional(),display:s.z.enum(["radio","checkbox"]).optional(),multiple:s.z.boolean().optional(),default_value:s.z.union([s.z.string(),s.z.array(s.z.string())]).optional()}).optional()}),rj=qt.extend({type:s.z.literal("CUSTOM"),config:s.z.object({component:s.z.string().optional(),props:s.z.record(s.z.any()).optional(),schema:s.z.record(s.z.any()).optional(),code:s.z.string().optional()})}),oj=qt.extend({type:s.z.literal("DATE"),config:s.z.object({format:s.z.string().optional(),min:s.z.string().optional(),max:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),sj=qt.extend({type:s.z.literal("DROPDOWN"),config:s.z.object({options:s.z.array(s.z.object({value:s.z.string(),label:s.z.string()})).optional(),placeholder:s.z.string().optional(),searchable:s.z.boolean().optional(),multiple:s.z.boolean().optional(),default_value:s.z.union([s.z.string(),s.z.array(s.z.string())]).optional()}).optional()}),aj=qt.extend({type:s.z.literal("EMAIL"),config:s.z.object({placeholder:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),cj=qt.extend({type:s.z.literal("FILE"),config:s.z.object({accept:s.z.string().optional(),max_size:s.z.number().optional(),multiple:s.z.boolean().optional()}).optional()}),lj=qt.extend({type:s.z.literal("LEGAL"),config:s.z.object({text:s.z.string(),html:s.z.boolean().optional()}).optional()}),dj=qt.extend({type:s.z.literal("NUMBER"),config:s.z.object({placeholder:s.z.string().optional(),min:s.z.number().optional(),max:s.z.number().optional(),step:s.z.number().optional(),default_value:s.z.string().optional()}).optional()}),uj=qt.extend({type:s.z.literal("PASSWORD"),config:s.z.object({placeholder:s.z.string().optional(),min_length:s.z.number().optional(),show_toggle:s.z.boolean().optional(),forgot_password_link:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),pj=qt.extend({type:s.z.literal("PAYMENT"),config:s.z.object({provider:s.z.string().optional(),currency:s.z.string().optional()}).optional()}),fj=qt.extend({type:s.z.literal("SOCIAL"),config:s.z.object({providers:s.z.array(s.z.string()).optional(),provider_details:s.z.array(s.z.object({name:s.z.string(),strategy:s.z.string().optional(),display_name:s.z.string().optional(),icon_url:s.z.string().optional(),href:s.z.string().optional()})).optional()}).optional()}),hj=qt.extend({type:s.z.literal("TEL"),config:s.z.object({placeholder:s.z.string().optional(),default_country:s.z.string().optional(),default_value:s.z.string().optional(),allow_email:s.z.boolean().optional()}).optional()}),gj=qt.extend({type:s.z.literal("TEXT"),config:s.z.object({placeholder:s.z.string().optional(),multiline:s.z.boolean().optional(),max_length:s.z.number().optional(),default_value:s.z.string().optional()}).optional()}),mj=qt.extend({type:s.z.literal("COUNTRY"),config:s.z.object({placeholder:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),yj=qt.extend({type:s.z.literal("URL"),config:s.z.object({placeholder:s.z.string().optional(),default_value:s.z.string().optional()}).optional()}),cC=s.z.discriminatedUnion("type",[H9,V9,K9,G9,W9,J9,Y9,Q9]),lC=s.z.discriminatedUnion("type",[Z9,X9,ej]),dC=s.z.discriminatedUnion("type",[tj,nj,ij,mj,rj,oj,sj,aj,cj,lj,dj,uj,pj,fj,hj,gj,yj]),nb=s.z.union([cC,lC,dC]),ib=new Set(["BOOLEAN","CARDS","CHOICE","COUNTRY","DATE","DROPDOWN","EMAIL","LEGAL","NUMBER","PASSWORD","TEL","TEXT","URL"]),_j=s.z.object({id:s.z.string(),type:s.z.literal("submit"),label:s.z.string(),className:s.z.string().optional(),disabled:s.z.boolean().optional().default(!1),order:s.z.number().optional(),visible:s.z.boolean().optional().default(!0),customizations:s.z.record(s.z.string(),s.z.any()).optional()}),Vl=s.z.object({x:s.z.number(),y:s.z.number()}),wj=s.z.object({id:s.z.string(),type:s.z.literal("FLOW"),coordinates:Vl,alias:s.z.string().min(1).max(150).optional(),config:s.z.object({flow_id:s.z.string().max(30),next_node:s.z.string().optional()})}),bj=s.z.object({id:s.z.string(),type:s.z.literal("ROUTER"),coordinates:Vl,alias:s.z.string().min(1).max(150),config:s.z.object({rules:s.z.array(s.z.object({id:s.z.string(),alias:s.z.string().min(1).max(150).optional(),condition:s.z.any(),next_node:s.z.string()})),fallback:s.z.string()})}),vj=s.z.object({id:s.z.string(),type:s.z.literal("STEP"),coordinates:Vl,alias:s.z.string().min(1).max(150).optional(),config:s.z.object({components:s.z.array(nb),next_node:s.z.string().optional()})}),uC=s.z.discriminatedUnion("type",[wj,bj,vj]),Np=s.z.object({name:s.z.string().openapi({description:"The name of the form"}),messages:s.z.object({errors:s.z.record(s.z.string(),s.z.any()).optional(),custom:s.z.record(s.z.string(),s.z.any()).optional()}).optional(),languages:s.z.object({primary:s.z.string().optional(),default:s.z.string().optional()}).optional(),translations:s.z.record(s.z.string(),s.z.any()).optional(),nodes:s.z.array(uC).optional(),start:s.z.object({hidden_fields:s.z.array(s.z.object({key:s.z.string(),value:s.z.string()})).optional(),next_node:s.z.string().optional(),coordinates:Vl.optional()}).optional(),ending:s.z.object({redirection:s.z.object({delay:s.z.number().optional(),target:s.z.string().optional()}).optional(),after_submit:s.z.object({flow_id:s.z.string().optional()}).optional(),coordinates:Vl.optional(),resume_flow:s.z.boolean().optional()}).optional(),style:s.z.object({css:s.z.string().optional()}).optional(),links:s.z.object({sdkSrc:s.z.string().optional(),sdk_src:s.z.string().optional()}).optional()}).openapi({description:"Schema for flow-based forms (matches Auth0 Forms structure)"}),sa=s.z.object({...Un.shape,...Np.shape,id:s.z.string()}),pC=s.z.object({id:s.z.number().optional(),text:s.z.string(),type:s.z.enum(["info","error","success","warning"])}),fC=s.z.object({id:s.z.string().optional(),text:s.z.string(),href:s.z.string(),linkText:s.z.string().optional()}),Aj=s.z.object({name:s.z.string().optional(),action:s.z.string(),method:s.z.enum(["POST","GET"]),title:s.z.string().optional(),description:s.z.string().optional(),components:s.z.array(nb),messages:s.z.array(pC).optional(),links:s.z.array(fC).optional(),footer:s.z.string().optional()});function kj(e){return e.category==="BLOCK"}function Sj(e){return e.category==="WIDGET"}function Ej(e){return e.category==="FIELD"}const hC=s.z.enum(["pre-user-registration","post-user-registration","post-user-login","post-user-update","validate-registration-username","pre-user-deletion","post-user-deletion"]),gC=s.z.enum(["pre-user-registration","post-user-registration","post-user-login","validate-registration-username","pre-user-deletion","post-user-deletion"]),mC=s.z.enum(["post-user-login","post-user-registration","post-user-update","credentials-exchange"]),yC=s.z.enum(["post-user-login","credentials-exchange","pre-user-registration","post-user-registration"]),rb=s.z.enum(["ensure-username","set-preferred-username","account-linking"]),xj={"ensure-username":{name:"Ensure Username",description:"Automatically assigns a username to users who sign in without one. Creates a linked username account for social/email users.",trigger_ids:["post-user-login"]},"set-preferred-username":{name:"Set Preferred Username",description:"Sets the preferred_username claim on tokens based on the username from the primary or linked user.",trigger_ids:["credentials-exchange"]},"account-linking":{name:"Account Linking",description:"Links a user to an existing primary account with the same verified email. Idempotent — safe to run on every login, registration, and email update.",trigger_ids:["post-user-login","post-user-registration","post-user-update"]}},co={enabled:s.z.boolean().default(!1),synchronous:s.z.boolean().default(!1),priority:s.z.number().optional(),hook_id:s.z.string().optional(),metadata:s.z.record(s.z.unknown()).optional()},Cj=s.z.object({...co,trigger_id:hC,url:s.z.string()}),Tj=s.z.object({...co,trigger_id:gC,form_id:s.z.string()}),$j=s.z.object({...co,trigger_id:mC,template_id:rb}),Ij=s.z.object({...co,trigger_id:yC,code_id:s.z.string()}),wy=s.z.union([Cj,Tj,$j,Ij]),zj=s.z.object({...co,trigger_id:hC,...Un.shape,hook_id:s.z.string(),url:s.z.string()}),Pj=s.z.object({...co,trigger_id:gC,...Un.shape,hook_id:s.z.string(),form_id:s.z.string()}),Nj=s.z.object({...co,trigger_id:mC,...Un.shape,hook_id:s.z.string(),template_id:rb}),jj=s.z.object({...co,trigger_id:yC,...Un.shape,hook_id:s.z.string(),code_id:s.z.string()}),aa=s.z.union([zj,Pj,Nj,jj]),jp=s.z.object({code:s.z.string().max(1e5),secrets:s.z.record(s.z.string()).optional()}),ob=jp.extend({id:s.z.string(),tenant_id:s.z.string(),...Un.shape}),_C=s.z.object({name:s.z.string().optional()}),wC=s.z.object({email:s.z.string().optional()}),sb=s.z.object({organization_id:s.z.string().max(50),inviter:_C,invitee:wC,invitation_url:s.z.string().url(),client_id:s.z.string(),connection_id:s.z.string().optional(),app_metadata:s.z.record(s.z.any()).default({}).optional(),user_metadata:s.z.record(s.z.any()).default({}).optional(),ttl_sec:s.z.number().int().max(2592e3).default(604800).optional(),roles:s.z.array(s.z.string()).default([]).optional(),send_invitation_email:s.z.boolean().default(!0).optional()}),Pl=s.z.object({id:s.z.string(),organization_id:s.z.string().max(50),created_at:s.z.string().datetime(),expires_at:s.z.string().datetime(),ticket_id:s.z.string().optional()}).extend(sb.shape),vh=s.z.object({alg:s.z.enum(["RS256","RS384","RS512","ES256","ES384","ES512","HS256","HS384","HS512"]),kid:s.z.string(),kty:s.z.enum(["RSA","EC","oct"]),use:s.z.enum(["sig","enc"]).optional(),n:s.z.string().optional(),e:s.z.string().optional(),crv:s.z.string().optional(),x:s.z.string().optional(),y:s.z.string().optional(),x5t:s.z.string().optional(),x5c:s.z.array(s.z.string()).optional()}).superRefine((e,t)=>{if(e.kty==="RSA")for(const n of["n","e"])e[n]||t.addIssue({code:s.z.ZodIssueCode.custom,path:[n],message:`RSA JWK is missing required member '${n}'`});else if(e.kty==="EC")for(const n of["crv","x","y"])e[n]||t.addIssue({code:s.z.ZodIssueCode.custom,path:[n],message:`EC JWK is missing required member '${n}'`})}),Op=s.z.object({keys:s.z.array(vh)}),by=s.z.object({issuer:s.z.string(),authorization_endpoint:s.z.string(),token_endpoint:s.z.string(),userinfo_endpoint:s.z.string(),jwks_uri:s.z.string(),registration_endpoint:s.z.string().optional(),revocation_endpoint:s.z.string(),end_session_endpoint:s.z.string().optional(),scopes_supported:s.z.array(s.z.string()),response_types_supported:s.z.array(s.z.string()),grant_types_supported:s.z.array(s.z.string()).optional(),code_challenge_methods_supported:s.z.array(s.z.string()),response_modes_supported:s.z.array(s.z.string()),subject_types_supported:s.z.array(s.z.string()),id_token_signing_alg_values_supported:s.z.array(s.z.string()),token_endpoint_auth_methods_supported:s.z.array(s.z.string()),claims_supported:s.z.array(s.z.string()),request_uri_parameter_supported:s.z.boolean(),request_parameter_supported:s.z.boolean(),claims_parameter_supported:s.z.boolean().optional(),request_object_signing_alg_values_supported:s.z.array(s.z.string()).optional(),token_endpoint_auth_signing_alg_values_supported:s.z.array(s.z.string())});var ve=(e=>(e.PENDING="pending",e.AUTHENTICATED="authenticated",e.AWAITING_EMAIL_VERIFICATION="awaiting_email_verification",e.AWAITING_MFA="awaiting_mfa",e.AWAITING_HOOK="awaiting_hook",e.AWAITING_CONTINUATION="awaiting_continuation",e.COMPLETED="completed",e.FAILED="failed",e.EXPIRED="expired",e))(ve||{});const bC=s.z.nativeEnum(ve),vC=s.z.object({strategy:s.z.string(),strategy_type:s.z.string()}),AC=s.z.object({csrf_token:s.z.string(),auth0Client:s.z.string().optional(),authParams:Hl,expires_at:s.z.string(),deleted_at:s.z.string().optional(),ip:s.z.string().optional(),useragent:s.z.string().optional(),session_id:s.z.string().optional(),authorization_url:s.z.string().optional(),state:bC.optional().default("pending"),state_data:s.z.string().optional(),failure_reason:s.z.string().optional(),user_id:s.z.string().optional(),auth_connection:s.z.string().optional(),auth_strategy:vC.optional(),authenticated_at:s.z.string().optional()}).openapi({description:"This represents a login sesion"}),Oj=s.z.object({...AC.shape,id:s.z.string().openapi({description:"This is is used as the state in the universal login"}),created_at:s.z.string(),updated_at:s.z.string()}),R={ACLS_SUMMARY:"acls_summary",ACTIONS_EXECUTION_FAILED:"actions_execution_failed",API_LIMIT:"api_limit",API_LIMIT_WARNING:"api_limit_warning",APPI:"appi",CIBA_EXCHANGE_FAILED:"ciba_exchange_failed",CIBA_EXCHANGE_SUCCEEDED:"ciba_exchange_succeeded",CIBA_START_FAILED:"ciba_start_failed",CIBA_START_SUCCEEDED:"ciba_start_succeeded",CODE_LINK_SENT:"cls",CODE_SENT:"cs",DEPRECATION_NOTICE:"depnote",FAILED_LOGIN:"f",FAILED_BY_CONNECTOR:"fc",FAILED_CHANGE_EMAIL:"fce",FAILED_BY_CORS:"fco",FAILED_CROSS_ORIGIN_AUTHENTICATION:"fcoa",FAILED_CHANGE_PASSWORD:"fcp",FAILED_POST_CHANGE_PASSWORD_HOOK:"fcph",FAILED_CHANGE_PHONE_NUMBER:"fcpn",FAILED_CHANGE_PASSWORD_REQUEST:"fcpr",FAILED_CONNECTOR_PROVISIONING:"fcpro",FAILED_CHANGE_USERNAME:"fcu",FAILED_DELEGATION:"fd",FAILED_DEVICE_ACTIVATION:"fdeac",FAILED_DEVICE_AUTHORIZATION_REQUEST:"fdeaz",USER_CANCELED_DEVICE_CONFIRMATION:"fdecc",FAILED_USER_DELETION:"fdu",FAILED_EXCHANGE_AUTHORIZATION_CODE_FOR_ACCESS_TOKEN:"feacft",FAILED_EXCHANGE_ACCESS_TOKEN_FOR_CLIENT_CREDENTIALS:"feccft",FAILED_EXCHANGE_CUSTOM_TOKEN:"fecte",FAILED_EXCHANGE_DEVICE_CODE_FOR_ACCESS_TOKEN:"fede",FAILED_FEDERATED_LOGOUT:"federated_logout_failed",FAILED_EXCHANGE_NATIVE_SOCIAL_LOGIN:"fens",FAILED_EXCHANGE_PASSWORD_OOB_FOR_ACCESS_TOKEN:"feoobft",FAILED_EXCHANGE_PASSWORD_OTP_FOR_ACCESS_TOKEN:"feotpft",FAILED_EXCHANGE_PASSWORD_FOR_ACCESS_TOKEN:"fepft",FAILED_EXCHANGE_PASSWORDLESS_OTP_FOR_ACCESS_TOKEN:"fepotpft",FAILED_EXCHANGE_PASSWORD_MFA_RECOVERY_FOR_ACCESS_TOKEN:"fercft",FAILED_EXCHANGE_ROTATING_REFRESH_TOKEN:"ferrt",FAILED_EXCHANGE_REFRESH_TOKEN_FOR_ACCESS_TOKEN:"fertft",FAILED_HOOK:"fh",FAILED_IMPERSONATION:"fimp",FAILED_INVITE_ACCEPT:"fi",FAILED_LOGOUT:"flo",FLOWS_EXECUTION_COMPLETED:"flows_execution_completed",FLOWS_EXECUTION_FAILED:"flows_execution_failed",FAILED_SENDING_NOTIFICATION:"fn",FORMS_SUBMISSION_FAILED:"forms_submission_failed",FORMS_SUBMISSION_SUCCEEDED:"forms_submission_succeeded",FAILED_LOGIN_INCORRECT_PASSWORD:"fp",FAILED_PUSHED_AUTHORIZATION_REQUEST:"fpar",FAILED_POST_USER_REGISTRATION_HOOK:"fpurh",FAILED_SIGNUP:"fs",FAILED_SILENT_AUTH:"fsa",FAILED_LOGIN_INVALID_EMAIL_USERNAME:"fu",FAILED_USERS_IMPORT:"fui",FAILED_VERIFICATION_EMAIL:"fv",FAILED_VERIFICATION_EMAIL_REQUEST:"fvr",EMAIL_VERIFICATION_CONFIRMED:"gd_auth_email_verification",EMAIL_VERIFICATION_FAILED:"gd_auth_fail_email_verification",MFA_AUTH_FAILED:"gd_auth_failed",MFA_AUTH_REJECTED:"gd_auth_rejected",MFA_AUTH_SUCCESS:"gd_auth_succeed",MFA_ENROLLMENT_COMPLETE:"gd_enrollment_complete",TOO_MANY_MFA_FAILURES:"gd_otp_rate_limit_exceed",MFA_RECOVERY_FAILED:"gd_recovery_failed",MFA_RECOVERY_RATE_LIMIT_EXCEED:"gd_recovery_rate_limit_exceed",MFA_RECOVERY_SUCCESS:"gd_recovery_succeed",MFA_EMAIL_SENT:"gd_send_email",EMAIL_VERIFICATION_SENT:"gd_send_email_verification",EMAIL_VERIFICATION_SEND_FAILURE:"gd_send_email_verification_failure",PUSH_NOTIFICATION_SENT:"gd_send_pn",ERROR_SENDING_MFA_PUSH_NOTIFICATION:"gd_send_pn_failure",MFA_SMS_SENT:"gd_send_sms",ERROR_SENDING_MFA_SMS:"gd_send_sms_failure",MFA_VOICE_CALL_SUCCESS:"gd_send_voice",MFA_VOICE_CALL_FAILED:"gd_send_voice_failure",SECOND_FACTOR_STARTED:"gd_start_auth",MFA_ENROLL_STARTED:"gd_start_enroll",MFA_ENROLLMENT_FAILED:"gd_start_enroll_failed",GUARDIAN_TENANT_UPDATE:"gd_tenant_update",UNENROLL_DEVICE_ACCOUNT:"gd_unenroll",UPDATE_DEVICE_ACCOUNT:"gd_update_device_account",WEBAUTHN_CHALLENGE_FAILED:"gd_webauthn_challenge_failed",WEBAUTHN_ENROLLMENT_FAILED:"gd_webauthn_enrollment_failed",FAILED_KMS_API_OPERATION:"kms_key_management_failure",SUCCESS_KMS_API_OPERATION:"kms_key_management_success",KMS_KEY_STATE_CHANGED:"kms_key_state_changed",TOO_MANY_CALLS_TO_DELEGATION:"limit_delegation",BLOCKED_IP_ADDRESS:"limit_mu",BLOCKED_ACCOUNT_IP:"limit_sul",BLOCKED_ACCOUNT_EMAIL:"limit_wc",MFA_REQUIRED:"mfar",MANAGEMENT_API_READ_OPERATION:"mgmt_api_read",FAILED_AUTHENTICATION_METHOD_OPERATION_MY_ACCOUNT:"my_account_authentication_method_failed",SUCCESSFUL_AUTHENTICATION_METHOD_OPERATION_MY_ACCOUNT:"my_account_authentication_method_succeeded",FAILED_OIDC_BACKCHANNEL_LOGOUT:"oidc_backchannel_logout_failed",SUCCESSFUL_OIDC_BACKCHANNEL_LOGOUT:"oidc_backchannel_logout_succeeded",ORGANIZATION_MEMBER_ADDED:"organization_member_added",PASSKEY_CHALLENGE_FAILED:"passkey_challenge_failed",PASSKEY_CHALLENGE_STARTED:"passkey_challenge_started",PRE_LOGIN_ASSESSMENT:"pla",BREACHED_PASSWORD:"pwd_leak",BREACHED_PASSWORD_ON_RESET:"reset_pwd_leak",SUCCESS_RESOURCE_CLEANUP:"resource_cleanup",RICH_CONSENTS_ACCESS_ERROR:"rich_consents_access_error",SUCCESS_LOGIN:"s",SUCCESS_API_OPERATION:"sapi",FAILED_API_OPERATION:"fapi",SUCCESS_CHANGE_EMAIL:"sce",SUCCESS_CROSS_ORIGIN_AUTHENTICATION:"scoa",SUCCESS_CHANGE_PASSWORD:"scp",SUCCESS_CHANGE_PHONE_NUMBER:"scpn",SUCCESS_CHANGE_PASSWORD_REQUEST:"scpr",SUCCESS_CHANGE_USERNAME:"scu",SUCCESS_CREDENTIAL_VALIDATION:"scv",SUCCESS_DELEGATION:"sd",SUCCESS_USER_DELETION:"sdu",SUCCESS_EXCHANGE_AUTHORIZATION_CODE_FOR_ACCESS_TOKEN:"seacft",SUCCESS_EXCHANGE_ACCESS_TOKEN_FOR_CLIENT_CREDENTIALS:"seccft",SUCCESS_EXCHANGE_CUSTOM_TOKEN:"secte",SUCCESS_EXCHANGE_DEVICE_CODE_FOR_ACCESS_TOKEN:"sede",SUCCESS_EXCHANGE_NATIVE_SOCIAL_LOGIN:"sens",SUCCESS_EXCHANGE_PASSWORD_OOB_FOR_ACCESS_TOKEN:"seoobft",SUCCESS_EXCHANGE_PASSWORD_OTP_FOR_ACCESS_TOKEN:"seotpft",SUCCESS_EXCHANGE_PASSWORD_FOR_ACCESS_TOKEN:"sepft",SUCCESS_EXCHANGE_PASSKEY_OOB_FOR_ACCESS_TOKEN:"sepkoobft",SUCCESS_EXCHANGE_PASSKEY_OTP_FOR_ACCESS_TOKEN:"sepkotpft",SUCCESS_EXCHANGE_PASSKEY_MFA_RECOVERY_FOR_ACCESS_TOKEN:"sepkrcft",SUCCESS_EXCHANGE_PASSWORD_MFA_RECOVERY_FOR_ACCESS_TOKEN:"sercft",SUCCESS_EXCHANGE_REFRESH_TOKEN_FOR_ACCESS_TOKEN:"sertft",SUCCESS_IMPERSONATION:"simp",SUCCESSFULLY_ACCEPTED_USER_INVITE:"si",BREACHED_PASSWORD_ON_SIGNUP:"signup_pwd_leak",SUCCESS_LOGOUT:"slo",SUCCESS_HOOK:"sh",SUCCESS_REVOCATION:"srrt",SUCCESS_SIGNUP:"ss",FAILED_SS_SSO_OPERATION:"ss_sso_failure",INFORMATION_FROM_SS_SSO_OPERATION:"ss_sso_info",SUCCESS_SS_SSO_OPERATION:"ss_sso_success",SUCCESS_SILENT_AUTH:"ssa",SUCCESSFUL_SCIM_OPERATION:"sscim",SUCCESSFULLY_IMPORTED_USERS:"sui",SUCCESS_VERIFICATION_EMAIL:"sv",SUCCESS_VERIFICATION_EMAIL_REQUEST:"svr",MAX_AMOUNT_OF_AUTHENTICATORS:"too_many_records",USER_LOGIN_BLOCK_RELEASED:"ublkdu",FAILED_UNIVERSAL_LOGOUT:"universal_logout_failed",SUCCESSFUL_UNIVERSAL_LOGOUT:"universal_logout_succeeded",WARNING_DURING_LOGIN:"w",WARNING_SENDING_NOTIFICATION:"wn",WARNING_USER_MANAGEMENT:"wum"},Fj=s.z.string().refine(e=>Object.values(R).includes(e),{message:"Invalid log type"}),kC=s.z.object({name:s.z.string(),version:s.z.string(),env:s.z.object({node:s.z.string().optional()}).optional()}),SC=s.z.object({country_code:s.z.string().length(2),city_name:s.z.string(),latitude:s.z.string(),longitude:s.z.string(),time_zone:s.z.string(),continent_code:s.z.string()}),EC=s.z.object({type:Fj,date:s.z.string(),description:s.z.string().optional(),ip:s.z.string().optional(),user_agent:s.z.string().optional(),details:s.z.any().optional(),isMobile:s.z.boolean(),user_id:s.z.string().optional(),user_name:s.z.string().optional(),connection:s.z.string().optional(),connection_id:s.z.string().optional(),client_id:s.z.string().optional(),client_name:s.z.string().optional(),audience:s.z.string().optional(),scope:s.z.string().optional(),strategy:s.z.string().optional(),strategy_type:s.z.string().optional(),hostname:s.z.string().optional(),auth0_client:kC.optional(),log_id:s.z.string().optional(),location_info:SC.optional()}),Ia=s.z.object({...EC.shape,log_id:s.z.string()}),xC=s.z.enum(["http","eventbridge","eventgrid","splunk","datadog","sumo"]),ab=s.z.enum(["active","paused","suspended"]),CC=s.z.object({type:s.z.string(),name:s.z.string()}),cb=s.z.object({name:s.z.string(),type:xC,status:ab.optional(),sink:s.z.record(s.z.string(),s.z.unknown()),filters:s.z.array(CC).optional(),isPriority:s.z.boolean().optional()}),Gs=cb.extend({id:s.z.string(),status:ab,created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),TC=s.z.enum(["auth0","cognito","okta","oidc"]),$C=s.z.object({domain:s.z.string(),client_id:s.z.string(),client_secret:s.z.string(),audience:s.z.string().optional(),scope:s.z.string().optional()}),Fp=s.z.object({id:s.z.string().optional(),name:s.z.string(),provider:TC,connection:s.z.string(),enabled:s.z.boolean().default(!0),credentials:$C}),vy=s.z.object({id:s.z.string(),created_at:s.z.string(),updated_at:s.z.string()}).extend(Fp.shape),ca=s.z.object({enabled:s.z.boolean().optional(),shields:s.z.array(s.z.string()).optional(),admin_notification_frequency:s.z.array(s.z.string()).optional(),method:s.z.string().optional(),stage:s.z.object({"pre-user-registration":s.z.object({shields:s.z.array(s.z.string()).optional()}).optional(),"pre-change-password":s.z.object({shields:s.z.array(s.z.string()).optional()}).optional()}).optional()}),la=s.z.object({enabled:s.z.boolean().optional(),shields:s.z.array(s.z.string()).optional(),allowlist:s.z.array(s.z.string()).optional(),mode:s.z.string().optional(),max_attempts:s.z.number().optional()}),da=s.z.object({enabled:s.z.boolean().optional(),shields:s.z.array(s.z.string()).optional(),allowlist:s.z.array(s.z.string()).optional(),stage:s.z.object({"pre-login":s.z.object({max_attempts:s.z.number().optional(),rate:s.z.number().optional()}).optional(),"pre-user-registration":s.z.object({max_attempts:s.z.number().optional(),rate:s.z.number().optional()}).optional()}).optional()}),IC=s.z.object({breached_password_detection:ca.optional(),brute_force_protection:la.optional(),suspicious_ip_throttling:da.optional()}),zC=s.z.object({id:s.z.string().optional(),user_id:s.z.string(),password:s.z.string(),algorithm:s.z.enum(["bcrypt","argon2id"]).default("argon2id"),is_current:s.z.boolean().default(!0)}),Rj=zC.extend({id:s.z.string(),created_at:s.z.string(),updated_at:s.z.string()}),PC=s.z.object({initial_user_agent:s.z.string().describe("First user agent of the device from which this user logged in"),initial_ip:s.z.string().describe("First IP address associated with this session"),initial_asn:s.z.string().describe("First autonomous system number associated with this session"),last_user_agent:s.z.string().describe("Last user agent of the device from which this user logged in"),last_ip:s.z.string().describe("Last IP address from which this user logged in"),last_asn:s.z.string().describe("Last autonomous system number from which this user logged in")}),NC=s.z.object({id:s.z.string(),revoked_at:s.z.string().optional(),used_at:s.z.string().optional(),user_id:s.z.string().describe("The user ID associated with the session"),expires_at:s.z.string().optional(),login_session_id:s.z.string(),idle_expires_at:s.z.string().optional(),device:PC.describe("Metadata related to the device used in the session"),clients:s.z.array(s.z.string()).describe("List of client details for the session")}),Ah=s.z.object({created_at:s.z.string(),updated_at:s.z.string(),authenticated_at:s.z.string(),last_interaction_at:s.z.string(),...NC.shape}),Ay=s.z.object({kid:s.z.string().openapi({description:"The key id of the signing key"}),tenant_id:s.z.string().optional().openapi({description:"The tenant the key belongs to. Omitted means the key is shared / control-plane scoped."}),cert:s.z.string().openapi({description:"The public certificate of the signing key"}),fingerprint:s.z.string().openapi({description:"The cert fingerprint"}),thumbprint:s.z.string().openapi({description:"The cert thumbprint"}),pkcs7:s.z.string().optional().openapi({description:"The private key in pkcs7 format"}),current:s.z.boolean().optional().openapi({description:"True if the key is the current key"}),next:s.z.boolean().optional().openapi({description:"True if the key is the next key"}),previous:s.z.boolean().optional().openapi({description:"True if the key is the previous key"}),current_since:s.z.string().optional().openapi({description:"The date and time when the key became the current key"}),current_until:s.z.string().optional().openapi({description:"The date and time when the current key was rotated"}),revoked:s.z.boolean().optional().openapi({description:"True if the key is revoked"}),revoked_at:s.z.string().optional().openapi({description:"The date and time when the key was revoked"}),connection:s.z.string().optional().openapi({description:"The connection identifier associated with the key"}),type:s.z.enum(["jwt_signing","saml_encryption"]).openapi({description:"The type of the signing key"})}),lb=s.z.object({id:s.z.string().optional(),audience:s.z.string(),friendly_name:s.z.string(),picture_url:s.z.string().optional(),support_email:s.z.string().optional(),support_url:s.z.string().optional(),sender_email:s.z.string().email(),sender_name:s.z.string(),session_lifetime:s.z.number().optional(),idle_session_lifetime:s.z.number().optional(),ephemeral_session_lifetime:s.z.number().optional(),idle_ephemeral_session_lifetime:s.z.number().optional(),session_cookie:s.z.object({mode:s.z.enum(["persistent","non-persistent"]).optional()}).optional(),allowed_logout_urls:s.z.array(s.z.string()).optional(),default_redirection_uri:s.z.string().optional(),default_client_id:s.z.string().optional(),enabled_locales:s.z.array(s.z.string()).optional(),default_directory:s.z.string().optional(),error_page:s.z.object({html:s.z.string().optional(),show_log_link:s.z.boolean().optional(),url:s.z.string().optional()}).nullish(),flags:s.z.object({allow_changing_enable_sso:s.z.boolean().optional(),allow_legacy_delegation_grant_types:s.z.boolean().optional(),allow_legacy_ro_grant_types:s.z.boolean().optional(),allow_legacy_tokeninfo_endpoint:s.z.boolean().optional(),change_pwd_flow_v1:s.z.boolean().optional(),custom_domains_provisioning:s.z.boolean().optional(),dashboard_insights_view:s.z.boolean().optional(),dashboard_log_streams_next:s.z.boolean().optional(),disable_clickjack_protection_headers:s.z.boolean().optional(),disable_fields_map_fix:s.z.boolean().optional(),disable_impersonation:s.z.boolean().optional(),disable_management_api_sms_obfuscation:s.z.boolean().optional(),enable_adfs_waad_email_verification:s.z.boolean().optional(),enable_apis_section:s.z.boolean().optional(),enable_client_connections:s.z.boolean().optional(),enable_custom_domain_in_emails:s.z.boolean().optional(),enable_dynamic_client_registration:s.z.boolean().optional(),dcr_require_initial_access_token:s.z.boolean().optional(),dcr_allowed_grant_types:s.z.array(s.z.string()).optional(),allow_http_return_to:s.z.array(s.z.string().refine(e=>{try{const t=new URL(e);return t.protocol==="http:"&&(t.pathname===""||t.pathname==="/")&&!t.search&&!t.hash&&e===t.origin}catch{return!1}},{message:"must be a fully-qualified http origin (scheme + host + port, no path)"})).optional(),enable_idtoken_api2:s.z.boolean().optional(),enable_legacy_logs_search_v2:s.z.boolean().optional(),enable_legacy_profile:s.z.boolean().optional(),enable_pipeline2:s.z.boolean().optional(),enable_public_signup_user_exists_error:s.z.boolean().optional(),enable_sso:s.z.boolean().optional(),enforce_client_authentication_on_passwordless_start:s.z.boolean().optional(),genai_trial:s.z.boolean().optional(),improved_signup_bot_detection_in_classic:s.z.boolean().optional(),mfa_show_factor_list_on_enrollment:s.z.boolean().optional(),no_disclose_enterprise_connections:s.z.boolean().optional(),remove_alg_from_jwks:s.z.boolean().optional(),revoke_refresh_token_grant:s.z.boolean().optional(),trust_azure_adfs_email_verified_connection_property:s.z.boolean().optional(),use_scope_descriptions_for_consent:s.z.boolean().optional(),inherit_global_permissions_in_organizations:s.z.boolean().optional()}).optional(),sandbox_version:s.z.string().optional(),legacy_sandbox_version:s.z.string().optional(),sandbox_versions_available:s.z.array(s.z.string()).optional(),change_password:s.z.object({enabled:s.z.boolean().optional(),html:s.z.string().optional()}).optional(),guardian_mfa_page:s.z.object({enabled:s.z.boolean().optional(),html:s.z.string().optional()}).optional(),device_flow:s.z.object({charset:s.z.enum(["base20","digits"]).optional(),mask:s.z.string().max(20).optional()}).optional(),default_token_quota:s.z.object({clients:s.z.object({client_credentials:s.z.record(s.z.any()).optional()}).optional(),organizations:s.z.object({client_credentials:s.z.record(s.z.any()).optional()}).optional()}).nullish(),default_audience:s.z.string().optional(),default_organization:s.z.string().optional(),sessions:s.z.object({oidc_logout_prompt_enabled:s.z.boolean().optional()}).optional(),oidc_logout:s.z.object({rp_logout_end_session_endpoint_discovery:s.z.boolean().optional()}).optional(),allow_organization_name_in_authentication_api:s.z.boolean().optional(),customize_mfa_in_postlogin_action:s.z.boolean().optional(),acr_values_supported:s.z.array(s.z.string()).optional(),mtls:s.z.object({enable_endpoint_aliases:s.z.boolean().optional()}).nullish(),pushed_authorization_requests_supported:s.z.boolean().optional(),authorization_response_iss_parameter_supported:s.z.boolean().optional(),attack_protection:IC.optional(),mfa:s.z.object({policy:s.z.enum(["never","always"]).default("never").optional(),factors:s.z.object({sms:s.z.boolean().default(!1),otp:s.z.boolean().default(!1),email:s.z.boolean().default(!1),push_notification:s.z.boolean().default(!1),webauthn_roaming:s.z.boolean().default(!1),webauthn_platform:s.z.boolean().default(!1),recovery_code:s.z.boolean().default(!1),duo:s.z.boolean().default(!1)}).optional(),sms_provider:s.z.object({provider:s.z.enum(["twilio","vonage","aws_sns","phone_message_hook"]).optional()}).optional(),twilio:s.z.object({sid:s.z.string().optional(),auth_token:s.z.string().optional(),from:s.z.string().optional(),messaging_service_sid:s.z.string().optional()}).optional(),phone_message:s.z.object({message:s.z.string().optional()}).optional()}).optional()}),Rp=s.z.object({created_at:s.z.string().nullable().transform(e=>e??""),updated_at:s.z.string().nullable().transform(e=>e??""),...lb.shape,id:s.z.string()});var tn=(e=>(e.RefreshToken="refresh_token",e.AuthorizationCode="authorization_code",e.ClientCredential="client_credentials",e.Passwordless="passwordless",e.Password="password",e.OTP="http://auth0.com/oauth/grant-type/passwordless/otp",e))(tn||{});const db=s.z.object({access_token:s.z.string(),id_token:s.z.string().optional(),scope:s.z.string().optional(),state:s.z.string().optional(),refresh_token:s.z.string().optional(),token_type:s.z.string(),expires_in:s.z.number()});s.z.object({code:s.z.string(),state:s.z.string().optional()});const jC=s.z.object({button_border_radius:s.z.number(),button_border_weight:s.z.number(),buttons_style:s.z.enum(["pill","rounded","sharp"]),input_border_radius:s.z.number(),input_border_weight:s.z.number(),inputs_style:s.z.enum(["pill","rounded","sharp"]),show_widget_shadow:s.z.boolean(),widget_border_weight:s.z.number(),widget_corner_radius:s.z.number()}),OC=s.z.object({base_focus_color:s.z.string(),base_hover_color:s.z.string(),body_text:s.z.string(),captcha_widget_theme:s.z.enum(["auto","dark","light"]),error:s.z.string(),header:s.z.string(),icons:s.z.string(),input_background:s.z.string(),input_border:s.z.string(),input_filled_text:s.z.string(),input_labels_placeholders:s.z.string(),links_focused_components:s.z.string(),primary_button:s.z.string(),primary_button_label:s.z.string(),secondary_button_border:s.z.string(),secondary_button_label:s.z.string(),success:s.z.string(),widget_background:s.z.string(),widget_border:s.z.string()}),$o=s.z.object({bold:s.z.boolean(),size:s.z.number()}),FC=s.z.object({body_text:$o,buttons_text:$o,font_url:s.z.string(),input_labels:$o,links:$o,links_style:s.z.enum(["normal","underlined"]),reference_text_size:s.z.number(),subtitle:$o,title:$o}),RC=s.z.object({background_color:s.z.string(),background_image_url:s.z.string(),page_layout:s.z.enum(["center","left","right"]),logo_placement:s.z.enum(["widget","chip","none"]).optional()}),DC=s.z.object({header_text_alignment:s.z.enum(["center","left","right"]),logo_height:s.z.number(),logo_position:s.z.enum(["center","left","none","right"]),logo_url:s.z.string(),social_buttons_layout:s.z.enum(["bottom","top"])}),BC=s.z.object({borders:jC,colors:OC,displayName:s.z.string(),fonts:FC,page_background:RC,widget:DC}),op=BC.extend({themeId:s.z.string()}),Wo=s.z.object({universal_login_experience:s.z.enum(["new","classic"]).default("new"),identifier_first:s.z.boolean().default(!0),password_first:s.z.boolean().default(!1),webauthn_platform_first_factor:s.z.boolean()}),Ws=s.z.object({name:s.z.string(),enabled:s.z.boolean().optional().default(!0),default_from_address:s.z.string().optional(),credentials:s.z.record(s.z.string(),s.z.unknown()),settings:s.z.object({}).optional()}),ub=s.z.enum(["verify_email","verify_email_by_code","reset_email","reset_email_by_code","welcome_email","blocked_account","stolen_credentials","enrollment_email","mfa_oob_code","change_password","password_reset","user_invitation"]),Rr=s.z.object({template:ub,body:s.z.string(),from:s.z.string(),subject:s.z.string(),syntax:s.z.literal("liquid").default("liquid"),resultUrl:s.z.string().optional(),urlLifetimeInSeconds:s.z.number().int().nonnegative().optional(),includeEmailInRedirect:s.z.boolean().default(!1),enabled:s.z.boolean().default(!0)}),pb=s.z.object({id:s.z.string(),login_id:s.z.string(),user_id:s.z.string(),client_id:s.z.string(),expires_at:s.z.string().optional(),idle_expires_at:s.z.string().optional(),last_exchanged_at:s.z.string().optional(),device:PC,resource_servers:s.z.array(s.z.object({audience:s.z.string(),scopes:s.z.string()})),rotating:s.z.boolean(),token_lookup:s.z.string().optional(),token_hash:s.z.string().optional(),family_id:s.z.string().optional(),rotated_to:s.z.string().optional(),rotated_at:s.z.string().optional()}),Dj=s.z.object({created_at:s.z.string(),revoked_at:s.z.string().optional(),...pb.shape}),Bj=s.z.object({to:s.z.string(),message:s.z.string()}),Lj=s.z.object({name:s.z.string(),options:s.z.object({})}),LC=s.z.object({value:s.z.string(),description:s.z.string().optional()}),MC=s.z.object({token_dialect:s.z.enum(["access_token","access_token_authz"]).optional(),enforce_policies:s.z.boolean().optional(),allow_skipping_userinfo:s.z.boolean().optional(),skip_userinfo:s.z.boolean().optional(),persist_client_authorization:s.z.boolean().optional(),enable_introspection_endpoint:s.z.boolean().optional(),mtls:s.z.object({bound_access_tokens:s.z.boolean().optional()}).optional()}),Dp=s.z.object({id:s.z.string().optional(),name:s.z.string(),identifier:s.z.string(),scopes:s.z.array(LC).optional(),signing_alg:s.z.string().optional(),signing_secret:s.z.string().optional(),token_lifetime:s.z.number().default(86400),token_lifetime_for_web:s.z.number().default(7200),skip_consent_for_verifiable_first_party_clients:s.z.boolean().optional(),allow_offline_access:s.z.boolean().optional(),verificationKey:s.z.string().optional(),options:MC.optional(),is_system:s.z.boolean().optional(),metadata:s.z.record(s.z.any()).optional()}),Uo=s.z.object({...Dp.shape,created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),Mj=s.z.array(Uo),UC=s.z.object({role_id:s.z.string(),resource_server_identifier:s.z.string(),permission_name:s.z.string()}),fb=s.z.object({...UC.shape,created_at:s.z.string()}),qC=s.z.array(fb),HC=s.z.object({user_id:s.z.string(),resource_server_identifier:s.z.string(),permission_name:s.z.string(),organization_id:s.z.string().optional()}),VC=s.z.object({...HC.shape,tenant_id:s.z.string(),created_at:s.z.string().optional()}),Uj=s.z.array(VC),KC=s.z.object({user_id:s.z.string(),resource_server_identifier:s.z.string(),resource_server_name:s.z.string(),permission_name:s.z.string(),description:s.z.string().nullable().optional(),created_at:s.z.string().optional(),organization_id:s.z.string().optional()}),GC=s.z.array(KC),WC=s.z.object({user_id:s.z.string(),role_id:s.z.string(),organization_id:s.z.string().optional()}),JC=s.z.object({...WC.shape,tenant_id:s.z.string(),created_at:s.z.string().optional()}),qj=s.z.array(JC),Bp=s.z.object({id:s.z.string().optional().openapi({description:"The unique identifier of the role. If not provided, one will be generated."}),name:s.z.string().min(1).max(50).openapi({description:"The name of the role. Cannot include '<' or '>'"}),description:s.z.string().max(255).optional().openapi({description:"The description of the role"}),is_system:s.z.boolean().optional(),metadata:s.z.record(s.z.any()).optional().openapi({description:"Metadata associated with the role. Can be used to control sync behavior in multi-tenancy scenarios."})}),qo=Bp.extend({id:s.z.string().openapi({description:"The unique identifier of the role"}),created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),Lp=s.z.array(qo),YC=s.z.object({logo_url:s.z.string().optional().openapi({description:"URL of the organization's logo"}),colors:s.z.object({primary:s.z.string().optional().openapi({description:"Primary color in hex format (e.g., #FF0000)"}),page_background:s.z.string().optional().openapi({description:"Page background color in hex format (e.g., #FFFFFF)"})}).optional()}).optional(),QC=s.z.object({connection_id:s.z.string().openapi({description:"ID of the connection"}),assign_membership_on_login:s.z.boolean().default(!1).openapi({description:"Whether to assign membership to the organization on login"}),show_as_button:s.z.boolean().default(!0).openapi({description:"Whether to show this connection as a button in the login screen"}),is_signup_enabled:s.z.boolean().default(!0).openapi({description:"Whether signup is enabled for this connection"})}),ZC=s.z.object({client_credentials:s.z.object({enforce:s.z.boolean().default(!1).openapi({description:"Whether to enforce token quota limits"}),per_day:s.z.number().min(0).default(0).openapi({description:"Maximum tokens per day (0 = unlimited)"}),per_hour:s.z.number().min(0).default(0).openapi({description:"Maximum tokens per hour (0 = unlimited)"})}).optional()}).optional(),Mp=s.z.object({id:s.z.string().optional(),name:s.z.string().min(1).regex(/^[a-z0-9_-]+$/,{message:"Organization name must be lowercase and can only contain letters, numbers, hyphens, and underscores"}).openapi({description:"The name of the organization. Must be lowercase and can only contain letters, numbers, hyphens, and underscores."}),display_name:s.z.string().optional().openapi({description:"The display name of the organization"}),branding:YC,metadata:s.z.record(s.z.any()).default({}).optional().openapi({description:"Custom metadata for the organization"}),enabled_connections:s.z.array(QC).default([]).optional().openapi({description:"List of enabled connections for the organization"}),token_quota:ZC}),Mr=s.z.object({...Mp.shape,...Un.shape,id:s.z.string(),name:s.z.string().min(1).openapi({description:"The name of the organization"})}),Up=s.z.object({connection_id:s.z.string().openapi({description:"ID of the tenant-level connection to enable for the org."}),assign_membership_on_login:s.z.boolean().optional().default(!1),show_as_button:s.z.boolean().optional().default(!0),is_signup_enabled:s.z.boolean().optional().default(!0)}),ua=s.z.object({...Up.shape,connection:s.z.object({name:s.z.string().optional(),strategy:s.z.string().optional()}).optional(),created_at:s.z.string().optional(),updated_at:s.z.string().optional()}),Hj=s.z.array(ua),XC=s.z.object({user_id:s.z.string().openapi({description:"ID of the user"}),organization_id:s.z.string().openapi({description:"ID of the organization"})}),Vj=s.z.object({...XC.shape,...Un.shape,id:s.z.string()}),Kj=s.z.object({idle_session_lifetime:s.z.number().default(72),session_lifetime:s.z.number().default(168),session_cookie:s.z.object({mode:s.z.enum(["persistent","non-persistent"]).optional()}).optional(),enable_client_connections:s.z.boolean().optional(),default_redirection_uri:s.z.string().optional(),enabled_locales:s.z.array(s.z.string()).optional(),default_directory:s.z.string().optional(),error_page:s.z.object({html:s.z.string().optional(),show_log_link:s.z.boolean().optional(),url:s.z.string().optional()}).optional(),flags:s.z.object({allow_legacy_delegation_grant_types:s.z.boolean().optional(),allow_legacy_ro_grant_types:s.z.boolean().optional(),allow_legacy_tokeninfo_endpoint:s.z.boolean().optional(),disable_clickjack_protection_headers:s.z.boolean().optional(),enable_apis_section:s.z.boolean().optional(),enable_client_connections:s.z.boolean().optional(),enable_custom_domain_in_emails:s.z.boolean().optional(),enable_dynamic_client_registration:s.z.boolean().optional(),enable_idtoken_api2:s.z.boolean().optional(),enable_legacy_logs_search_v2:s.z.boolean().optional(),enable_legacy_profile:s.z.boolean().optional(),enable_pipeline2:s.z.boolean().optional(),enable_public_signup_user_exists_error:s.z.boolean().optional(),use_scope_descriptions_for_consent:s.z.boolean().optional(),disable_management_api_sms_obfuscation:s.z.boolean().optional(),enable_adfs_waad_email_verification:s.z.boolean().optional(),revoke_refresh_token_grant:s.z.boolean().optional(),dashboard_log_streams_next:s.z.boolean().optional(),dashboard_insights_view:s.z.boolean().optional(),disable_fields_map_fix:s.z.boolean().optional(),mfa_show_factor_list_on_enrollment:s.z.boolean().optional()}).optional(),friendly_name:s.z.string().optional(),picture_url:s.z.string().optional(),support_email:s.z.string().optional(),support_url:s.z.string().optional(),sandbox_version:s.z.string().optional(),sandbox_versions_available:s.z.array(s.z.string()).optional(),change_password:s.z.object({enabled:s.z.boolean(),html:s.z.string()}).optional(),guardian_mfa_page:s.z.object({enabled:s.z.boolean(),html:s.z.string()}).optional(),default_audience:s.z.string().optional(),default_organization:s.z.string().optional(),sessions:s.z.object({oidc_logout_prompt_enabled:s.z.boolean().optional()}).optional(),mfa:s.z.object({policy:s.z.enum(["never","always"]).default("never").optional(),factors:s.z.object({sms:s.z.boolean().default(!1),otp:s.z.boolean().default(!1),email:s.z.boolean().default(!1),push_notification:s.z.boolean().default(!1),webauthn_roaming:s.z.boolean().default(!1),webauthn_platform:s.z.boolean().default(!1),recovery_code:s.z.boolean().default(!1),duo:s.z.boolean().default(!1)}).optional(),sms_provider:s.z.object({provider:s.z.enum(["twilio","vonage","aws_sns","phone_message_hook"]).optional()}).optional(),twilio:s.z.object({sid:s.z.string().optional(),auth_token:s.z.string().optional(),from:s.z.string().optional(),messaging_service_sid:s.z.string().optional()}).optional(),phone_message:s.z.object({message:s.z.string().optional()}).optional()}).optional()}),eT=s.z.object({date:s.z.string().openapi({description:"Date these events occurred in ISO 8601 format",example:"2025-12-19"}),logins:s.z.number().openapi({description:"Number of logins on this date",example:150}),signups:s.z.number().openapi({description:"Number of signups on this date",example:25}),leaked_passwords:s.z.number().openapi({description:"Number of breached-password detections on this date (subscription required)",example:0}),updated_at:s.z.string().openapi({description:"Date and time this stats entry was last updated in ISO 8601 format",example:"2025-12-19T10:30:00.000Z"}),created_at:s.z.string().openapi({description:"Approximate date and time the first event occurred in ISO 8601 format",example:"2025-12-19T00:00:00.000Z"})}),Gj=s.z.number().openapi({description:"Number of active users in the last 30 days",example:1234}),Wj=s.z.enum(["active-users","logins","signups","refresh-tokens","sessions"]),Jj=s.z.enum(["hour","day","week","month"]),Yj=s.z.enum(["time","connection","client_id","user_type","event"]),Qj=s.z.enum(["password","social","passwordless","enterprise"]),tT=s.z.object({name:s.z.string(),type:s.z.string()}),nT=s.z.object({elapsed:s.z.number(),rows_read:s.z.number().optional(),bytes_read:s.z.number().optional()}),iT=s.z.object({meta:s.z.array(tT),data:s.z.array(s.z.record(s.z.string(),s.z.any())),rows:s.z.number(),rows_before_limit_at_least:s.z.number().optional(),statistics:nT.optional()}),pa=s.z.enum(["login","login-id","login-password","signup","signup-id","signup-password","reset-password","consent","mfa","mfa-push","mfa-otp","mfa-voice","mfa-phone","mfa-webauthn","mfa-email","mfa-recovery-code","status","device-flow","email-verification","email-otp-challenge","organizations","invitation","common","passkeys","captcha","custom-form","login-passwordless","mfa-login-options"]),No=s.z.record(s.z.string(),s.z.record(s.z.string(),s.z.string())).openapi({type:"object",additionalProperties:{type:"object",additionalProperties:{type:"string"}}}),Zj=s.z.object({prompt:pa,language:s.z.string(),custom_text:No}),Z={EMAIL:"email",SMS:"sms",USERNAME_PASSWORD:"Username-Password-Authentication",GOOGLE_OAUTH2:"google-oauth2",APPLE:"apple",FACEBOOK:"facebook",GITHUB:"github",MICROSOFT:"microsoft",VIPPS:"vipps",OIDC:"oidc",OAUTH2:"oauth2",SAMLP:"samlp",WAAD:"waad",ADFS:"adfs"},Gt={DATABASE:"database",SOCIAL:"social",PASSWORDLESS:"passwordless"},rT=s.z.enum(["phone","totp","email","push","webauthn-roaming","webauthn-platform","passkey"]),oT=s.z.object({user_id:s.z.string(),type:rT,phone_number:s.z.string().optional(),totp_secret:s.z.string().optional(),credential_id:s.z.string().optional(),public_key:s.z.string().optional(),sign_count:s.z.number().int().nonnegative().optional(),credential_backed_up:s.z.boolean().optional(),transports:s.z.array(s.z.string()).optional(),friendly_name:s.z.string().optional(),confirmed:s.z.boolean().default(!1)});function sT(e,t){e.type==="phone"&&!e.phone_number&&t.addIssue({code:s.z.ZodIssueCode.custom,message:"phone_number is required when type is 'phone'",path:["phone_number"]}),e.type==="totp"&&!e.totp_secret&&t.addIssue({code:s.z.ZodIssueCode.custom,message:"totp_secret is required when type is 'totp'",path:["totp_secret"]}),["webauthn-roaming","webauthn-platform","passkey"].includes(e.type)&&(e.credential_id||t.addIssue({code:s.z.ZodIssueCode.custom,message:`credential_id is required when type is '${e.type}'`,path:["credential_id"]}),e.public_key||t.addIssue({code:s.z.ZodIssueCode.custom,message:`public_key is required when type is '${e.type}'`,path:["public_key"]}))}const Xj=oT.superRefine(sT),eO=s.z.object({...oT.shape,id:s.z.string(),created_at:s.z.string(),updated_at:s.z.string()}).superRefine(sT);function tO(e){const[t,n]=e.split("|");if(!t||!n)throw new Error(`Invalid user_id: ${e}`);return{connection:t,id:n}}function nO(e){const{primary:t,secondaries:n,syncMethods:i=["create","rawCreate","update","remove","delete","set"]}=e,r={get(o,a){if(typeof a=="symbol")return o[a];const c=o[a];return typeof c!="function"?c:i.includes(a)?async(...l)=>{const d=await c.apply(o,l),u=[];for(const p of n){const f=p.adapter[a];if(typeof f!="function")continue;const h=(async()=>{try{await f.apply(p.adapter,l)}catch(g){try{p.onError?p.onError(g,a,l):console.error(`Passthrough adapter: secondary write failed for ${a}:`,g)}catch(m){console.error(`Passthrough adapter: onError handler threw for ${a}:`,m)}}})();p.blocking&&u.push(h)}return u.length>0&&await Promise.all(u),d}:c.bind(o)}};return new Proxy(t,r)}function iO(e){return e}function vs(e){var t,n,i,r,o,a,c,l,d,u,p,f;const h=e?.options;if(!h)return{usernameIdentifierActive:!1,emailIdentifierActive:!0,usernameMinLength:1,usernameMaxLength:15};const g=h.attributes;if(g){const m=((n=(t=g.username)==null?void 0:t.identifier)==null?void 0:n.active)===!0,_=((r=(i=g.email)==null?void 0:i.identifier)==null?void 0:r.active)!==!1,w=((a=(o=g.username)==null?void 0:o.validation)==null?void 0:a.min_length)??1,y=((l=(c=g.username)==null?void 0:c.validation)==null?void 0:l.max_length)??15;return{usernameIdentifierActive:m,emailIdentifierActive:_,usernameMinLength:w,usernameMaxLength:y}}return{usernameIdentifierActive:h.requires_username===!0,emailIdentifierActive:!0,usernameMinLength:((u=(d=h.validation)==null?void 0:d.username)==null?void 0:u.min)??1,usernameMaxLength:((f=(p=h.validation)==null?void 0:p.username)==null?void 0:f.max)??15}}function qp(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}var rO={deno:"Deno",bun:"Bun",workerd:"Cloudflare-Workers",node:"Node.js"},hb=()=>{const e=globalThis;if(typeof navigator<"u"&&typeof navigator.userAgent=="string"){for(const[n,i]of Object.entries(rO))if(oO(i))return n}return typeof e?.EdgeRuntime=="string"?"edge-light":e?.fastly!==void 0?"fastly":e?.process?.release?.name==="node"?"node":"other"},oO=e=>navigator.userAgent.startsWith(e);function kh(e,t){if(hb()==="workerd")try{e.executionCtx.waitUntil(t);return}catch{}const n=t.then(()=>{},r=>{console.error("waitUntil promise error:",r)});let i;try{i=e.var?.backgroundPromises}catch{i=void 0}if(!Array.isArray(i)){if(typeof e.set!="function")return;i=[],e.set("backgroundPromises",i)}i.push(n)}async function sO(e){const t=e.var.backgroundPromises;if(!Array.isArray(t)||t.length===0)return;const n=t.splice(0,t.length);await Promise.all(n)}function aO(e){return[...e].reduce((t,[n,i])=>({...t,[n]:i}),{})}const cO=new Set(["password","password_hash","client_secret","signing_keys","credentials","encryption_key","otp_secret"]);function ky(e){if(!e)return;const t={};for(const[n,i]of Object.entries(e))cO.has(n)?t[n]="[REDACTED]":t[n]=i;return t}function aT(e){return e&&typeof e=="object"&&!Array.isArray(e)?ky(e):e}function lO(e,t){if(!e||!t)return;const n={},i=new Set([...Object.keys(e),...Object.keys(t)]);for(const r of i){const o=e[r],a=t[r];JSON.stringify(o)!==JSON.stringify(a)&&(n[r]={old:o,new:a})}return Object.keys(n).length>0?n:void 0}function dO(e,t){return e.var.user_id||t.actorUserId?"admin_action":t.userId?"user_action":e.var.client_id?"api":"system"}function cT(e,t,n){const i=e.env.outbox?.captureEntityState!==!1,r=i?ky(n.beforeState):void 0,o=i?ky(n.afterState):void 0;return{tenant_id:t,event_type:n.targetType?`${n.targetType}.${uO(e.req.method)}`:n.type,log_type:n.type,description:n.description,category:dO(e,n),actor:{type:e.var.user_id||n.actorUserId?"admin":n.userId?"user":e.var.client_id?"client_credentials":"system",id:e.var.user_id||n.actorUserId||n.userId||void 0,email:e.var.username||void 0,org_id:e.var.organization_id||e.var.user?.org_id||void 0,org_name:e.var.org_name||e.var.user?.org_name||void 0,scopes:e.var.user?.scope?e.var.user.scope.split(" "):void 0,client_id:e.var.client_id||void 0},target:{type:n.targetType||"unknown",id:n.targetId||n.userId||e.var.user_id||"",before:r,after:o,diff:lO(r,o)},request:{method:e.req.method,path:e.req.path,query:e.req.queries()?Object.fromEntries(Object.entries(e.req.queries()).map(([a,c])=>[a,Array.isArray(c)?c.join(","):c])):void 0,body:aT(n.body||e.var.body||void 0),ip:e.var.ip||"",user_agent:e.var.useragent||void 0},response:n.response?{status_code:n.response.statusCode,body:n.response.body}:void 0,connection:n.connection||e.var.connection||void 0,strategy:n.strategy||void 0,strategy_type:n.strategy_type||void 0,audience:n.audience||void 0,scope:n.scope||void 0,hostname:e.var.host||"",is_mobile:!1,auth0_client:e.var.auth0_client,timestamp:new Date().toISOString()}}function uO(e){switch(e){case"POST":return"created";case"PATCH":case"PUT":return"updated";case"DELETE":return"deleted";default:return"accessed"}}async function B(e,t,n){const i={};if(e.req.raw?.headers){const o=aO(e.req.raw.headers);for(const[a,c]of Object.entries(o))i[a.toLowerCase()]=c}if(e.env.outbox?.enabled&&e.env.data.outbox){const o=cT(e,t,n),a=e.env.data.outbox.create(t,o),c=e.var.outboxEventPromises||[];c.push(a),e.set("outboxEventPromises",c);return}const r=async()=>{let o;if(e.env.data.geo)try{o=await e.env.data.geo.getGeoInfo(i)||void 0}catch(c){console.warn("Failed to get geo information:",c)}const a={type:n.type,description:n.description||"",ip:e.var.ip,user_agent:e.var.useragent||"",auth0_client:e.var.auth0_client,date:new Date().toISOString(),details:n.details||{request:{method:e.req.method,path:e.req.path,qs:e.req.queries(),body:aT(n.body||e.var.body||"")},...n.response&&{response:n.response}},isMobile:!1,client_id:e.var.client_id,client_name:"",user_id:n.userId||e.var.user_id||"",hostname:e.var.host||"",user_name:e.var.username||"",connection_id:"",connection:n.connection||e.var.connection||"",strategy:n.strategy||"",strategy_type:n.strategy_type||"",audience:n.audience||"",scope:n.scope||"",location_info:o};await e.env.data.logs.create(t,a)};n.waitForCompletion?await r():kh(e,r())}async function lT(e,t,n,i){if(!e.env.outbox?.enabled||!t.outbox)return;const r=cT(e,n,i);return t.outbox.create(n,r)}const dt=s.z.object({page:s.z.string().min(0).optional().default("0").transform(e=>parseInt(e,10)).openapi({description:"Page index of the results to return. First page is 0."}),per_page:s.z.string().min(1).optional().default("10").transform(e=>parseInt(e,10)).openapi({description:"Number of results per page. Defaults to 50."}),include_totals:s.z.string().optional().default("false").transform(e=>e==="true").openapi({description:"Return results inside an object that contains the total result count (true) or as a direct array of results (false, default)."}),from:s.z.string().optional().openapi({description:"Optional Id from which to start selection."}),take:s.z.string().optional().transform(e=>e?parseInt(e,10):void 0).openapi({description:"Number of results per page. Defaults to 50."}),sort:s.z.string().regex(/^.+:(-1|1)$/).optional().openapi({description:"Field to sort by. Use field:order where order is 1 for ascending and -1 for descending. e.g. created_at:1."}),q:s.z.string().optional().openapi({description:"A lucene query string used to filter the results"})});function St(e){if(!e)return;const[t,n]=e.split(":"),i=n==="1"?"asc":"desc";if(!(!t||!i))return{sort_by:t,sort_order:i}}const pO=xt.extend({actions:s.z.array(nr)}),fO={"post-login":"post-user-login"};function hO(e){return fO[e]||e}const gO=s.z.object({versions:s.z.array(yh)}),mO=xt.extend({versions:s.z.array(yh)});function xu(e,t,n,i){return e.actionVersions.create(t,{action_id:n.id,code:n.code,runtime:n.runtime,secrets:n.secrets,dependencies:n.dependencies,supported_triggers:n.supported_triggers,deployed:i})}const yO=new s.OpenAPIHono().openapi(s.createRoute({tags:["actions"],method:"get",path:"/",request:{query:dt,headers:s.z.object({"tenant-id":s.z.string().optional()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:s.z.union([s.z.array(nr),pO])}},description:"List of actions"}}}),async e=>{const{page:t,per_page:n,include_totals:i,sort:r,q:o}=e.req.valid("query"),a=await e.env.data.actions.list(e.var.tenant_id,{page:t,per_page:n,include_totals:i,sort:St(r),q:o}),c=a.actions.map(l=>({...l,secrets:l.secrets?.map(d=>({name:d.name}))}));return i?e.json({...a,actions:c}):e.json(c)}).openapi(s.createRoute({tags:["actions"],method:"post",path:"/",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),body:{content:{"application/json":{schema:ql}}}},security:[{Bearer:["create:actions","auth:write"]}],responses:{201:{content:{"application/json":{schema:nr}},description:"The created action"}}}),async e=>{const t=e.req.valid("json"),n=await e.env.data.actions.create(e.var.tenant_id,t);let i=!1;if(e.env.codeExecutor?.deploy)try{await e.env.codeExecutor.deploy(n.id,t.code),i=!0}catch(r){await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to deploy action ${n.id}: ${r instanceof Error?r.message:String(r)}`})}else i=!0;return await xu(e.env.data,e.var.tenant_id,n,i),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Create action",targetType:"action",targetId:n.id}),e.json(n,{status:201})}).openapi(s.createRoute({tags:["actions"],method:"get",path:"/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:nr}},description:"An action"},404:{description:"Action not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=await e.env.data.actions.get(e.var.tenant_id,t);if(!n)throw new z(404,{message:"Action not found"});return e.json({...n,secrets:n.secrets?.map(i=>({name:i.name}))})}).openapi(s.createRoute({tags:["actions"],method:"patch",path:"/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()}),body:{content:{"application/json":{schema:ql.partial()}}}},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:nr}},description:"The updated action"},404:{description:"Action not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=e.req.valid("json");if(!await e.env.data.actions.update(e.var.tenant_id,t,n))throw new z(404,{message:"Action not found"});const r=await e.env.data.actions.get(e.var.tenant_id,t);if(!r)throw new z(404,{message:"Action not found"});if(n.code!==void 0&&e.env.codeExecutor?.deploy){let o=!1;try{await e.env.codeExecutor.deploy(t,n.code),o=!0}catch(a){await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to deploy action ${t}: ${a instanceof Error?a.message:String(a)}`})}await xu(e.env.data,e.var.tenant_id,r,o)}return await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Update action",targetType:"action",targetId:t}),e.json({...r,secrets:r.secrets?.map(o=>({name:o.name}))})}).openapi(s.createRoute({tags:["actions"],method:"delete",path:"/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["delete:actions","auth:write"]}],responses:{200:{description:"Action deleted"},404:{description:"Action not found"},409:{description:"Action is bound to a trigger and cannot be deleted"}}}),async e=>{const{id:t}=e.req.valid("param");if((await e.env.data.hooks.list(e.var.tenant_id,{q:`code_id:"${t}"`})).hooks.length>0)throw new z(409,{message:"Action is bound to a trigger. Remove the binding before deleting."});if(!await e.env.data.actions.remove(e.var.tenant_id,t))throw new z(404,{message:"Action not found"});if(await e.env.data.actionVersions.removeForAction(e.var.tenant_id,t),e.env.codeExecutor?.remove)try{await e.env.codeExecutor.remove(t)}catch(r){await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to remove action worker ${t}: ${r instanceof Error?r.message:String(r)}`})}return await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Delete action",targetType:"action",targetId:t}),e.text("OK")}).openapi(s.createRoute({tags:["actions"],method:"post",path:"/{id}/deploy",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:nr}},description:"The deployed action"},404:{description:"Action not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=await e.env.data.actions.get(e.var.tenant_id,t);if(!n)throw new z(404,{message:"Action not found"});if(e.env.codeExecutor?.deploy)try{await e.env.codeExecutor.deploy(t,n.code)}catch(i){throw await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to deploy action ${t}: ${i instanceof Error?i.message:String(i)}`}),new z(500,{message:`Deployment failed: ${i instanceof Error?i.message:String(i)}`})}return await e.env.data.actions.update(e.var.tenant_id,t,{status:"built",deployed_at:new Date().toISOString()}),await xu(e.env.data,e.var.tenant_id,n,!0),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Deploy action",targetType:"action",targetId:t}),e.json({...n,status:"built",secrets:n.secrets?.map(i=>({name:i.name}))})}).openapi(s.createRoute({tags:["actions"],method:"get",path:"/{actionId}/versions",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({actionId:s.z.string()}),query:dt},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:s.z.union([gO,mO])}},description:"List of action versions"},404:{description:"Action not found"}}}),async e=>{const{actionId:t}=e.req.valid("param"),{page:n,per_page:i,include_totals:r,sort:o}=e.req.valid("query");if(!await e.env.data.actions.get(e.var.tenant_id,t))throw new z(404,{message:"Action not found"});const c=await e.env.data.actionVersions.list(e.var.tenant_id,t,{page:n,per_page:i,include_totals:r,sort:St(o)}),l=c.versions.map(d=>({...d,secrets:d.secrets?.map(u=>({name:u.name}))}));return r?e.json({...c,versions:l}):e.json({versions:l})}).openapi(s.createRoute({tags:["actions"],method:"get",path:"/{actionId}/versions/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({actionId:s.z.string(),id:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:yh}},description:"Action version"},404:{description:"Action version not found"}}}),async e=>{const{actionId:t,id:n}=e.req.valid("param"),i=await e.env.data.actionVersions.get(e.var.tenant_id,t,n);if(!i)throw new z(404,{message:"Action version not found"});return e.json({...i,secrets:i.secrets?.map(r=>({name:r.name}))})}).openapi(s.createRoute({tags:["actions"],method:"post",path:"/{actionId}/versions/{id}/deploy",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({actionId:s.z.string(),id:s.z.string()})},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:nr}},description:"The action after rollback"},404:{description:"Action version not found"}}}),async e=>{const{actionId:t,id:n}=e.req.valid("param"),i=await e.env.data.actionVersions.get(e.var.tenant_id,t,n);if(!i)throw new z(404,{message:"Action version not found"});if(e.env.codeExecutor?.deploy)try{await e.env.codeExecutor.deploy(t,i.code)}catch(o){throw await B(e,e.var.tenant_id,{type:R.FAILED_HOOK,description:`Failed to roll back action ${t} to version ${n}: ${o instanceof Error?o.message:String(o)}`}),new z(500,{message:`Rollback failed: ${o instanceof Error?o.message:String(o)}`})}await e.env.data.actions.update(e.var.tenant_id,t,{code:i.code,runtime:i.runtime,secrets:i.secrets,dependencies:i.dependencies,supported_triggers:i.supported_triggers,status:"built",deployed_at:new Date().toISOString()});const r=await e.env.data.actions.get(e.var.tenant_id,t);if(!r)throw new z(404,{message:"Action not found"});return await xu(e.env.data,e.var.tenant_id,r,!0),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:`Roll back action to version ${i.number}`,targetType:"action",targetId:t}),e.json({...r,secrets:r.secrets?.map(o=>({name:o.name}))})}).openapi(s.createRoute({tags:["actions"],method:"post",path:"/{id}/test",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()}),body:{content:{"application/json":{schema:s.z.object({trigger_id:s.z.string().optional(),event:s.z.record(s.z.unknown()).optional()})}}}},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:s.z.object({success:s.z.boolean(),error:s.z.string().optional(),duration_ms:s.z.number(),api_calls:s.z.array(s.z.object({method:s.z.string(),args:s.z.array(s.z.unknown())})),logs:s.z.array(s.z.object({level:s.z.enum(["log","info","warn","error","debug"]),message:s.z.string()}))})}},description:"Test run result"},404:{description:"Action not found"},503:{description:"Code executor not configured"}}}),async e=>{const{id:t}=e.req.valid("param"),n=e.req.valid("json"),i=e.env.codeExecutor;if(!i)throw new z(503,{message:"Code executor not configured"});const r=await e.env.data.actions.get(e.var.tenant_id,t);if(!r)throw new z(404,{message:"Action not found"});const o=n.trigger_id??r.supported_triggers?.[0]?.id??"post-login",a=hO(o),c=r.secrets?.reduce((d,u)=>(u.value!==void 0&&(d[u.name]=u.value),d),{}),l=await i.execute({code:r.code,hookCodeId:r.id,triggerId:a,event:{...n.event??{},secrets:c??{}},timeoutMs:5e3});return e.json({success:l.success,error:l.error,duration_ms:l.durationMs,api_calls:l.apiCalls,logs:l.logs??[]})}),_O=s.z.object({id:s.z.string(),trigger_id:s.z.string(),status:Kw,results:s.z.array(Gw),created_at:s.z.string(),updated_at:s.z.string()}),wO=s.z.object({logs:Ww}),bO=new s.OpenAPIHono().openapi(s.createRoute({tags:["actions"],method:"get",path:"/{id}",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:_O}},description:"Action execution"},404:{description:"Execution not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=await e.env.data.actionExecutions.get(e.var.tenant_id,t);if(!n)throw new z(404,{message:"Execution not found"});return e.json({id:n.id,trigger_id:n.trigger_id,status:n.status,results:n.results,created_at:n.created_at,updated_at:n.updated_at})}).openapi(s.createRoute({tags:["actions"],method:"get",path:"/{id}/logs",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({id:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:wO}},description:"Captured console output for the execution"},404:{description:"Execution not found"}}}),async e=>{const{id:t}=e.req.valid("param"),n=await e.env.data.actionExecutions.get(e.var.tenant_id,t);if(!n)throw new z(404,{message:"Execution not found"});return e.json({logs:n.logs??[]})});let vO="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict",AO=e=>crypto.getRandomValues(new Uint8Array(e)),kO=(e,t,n)=>{let i=256-256%e.length;if(i===256){let o=e.length-1;return(a=t)=>{if(!a)return"";let c="";for(;;){let l=n(a),d=a;for(;d--;)if(c+=e[l[d]&o],c.length>=a)return c}}}let r=Math.ceil(1.6*256*t/i);return(o=t)=>{if(!o)return"";let a="";for(;;){let c=n(r),l=r;for(;l--;)if(c[l]<i&&(a+=e[c[l]%e.length],a.length>=o))return a}}},dT=(e,t=21)=>kO(e,t|0,AO),Le=(e=21)=>{let t="",n=crypto.getRandomValues(new Uint8Array(e|=0));for(;e--;)t+=vO[n[e]&63];return t};const SO=17,EO={organization:"org_",connection:"con_",action:"act_",hook:"h_",rule:"rul_",resource_server:"api_",guardian_factor:"gfa_",invite:"inv_",flow:"af_"};function Sh(e){const i=dT("0123456789abcdefghijklmnopqrstuvwxyz",SO)();return`${EO[e]}${i}`}function xO(){return Sh("organization")}function CO(){return Sh("connection")}function uT(){return Sh("hook")}function TO(){return Sh("invite")}const pT={"post-login":"post-user-login","credentials-exchange":"credentials-exchange","pre-user-registration":"pre-user-registration","post-user-registration":"post-user-registration"},$O=Object.fromEntries(Object.entries(pT).map(([e,t])=>[t,e]));function l2(e){return pT[e]||e}function d2(e){return $O[e]||e}const IO=s.z.object({type:s.z.enum(["action_id","action_name"]).optional(),value:s.z.string().optional(),id:s.z.string().optional(),name:s.z.string().optional()}),zO=s.z.object({ref:IO,display_name:s.z.string().optional()}),PO=s.z.object({id:s.z.string(),trigger_id:s.z.string(),display_name:s.z.string(),action:nr,created_at:s.z.string(),updated_at:s.z.string()}),u2=s.z.object({bindings:s.z.array(PO)}),NO=new s.OpenAPIHono().openapi(s.createRoute({tags:["actions"],method:"get",path:"/{triggerId}/bindings",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({triggerId:s.z.string()})},security:[{Bearer:["read:actions","auth:read"]}],responses:{200:{content:{"application/json":{schema:u2}},description:"Trigger bindings"}}}),async e=>{const{triggerId:t}=e.req.valid("param"),n=l2(t),r=(await e.env.data.hooks.list(e.var.tenant_id,{q:`trigger_id:"${n}"`,per_page:100})).hooks.filter(a=>"code_id"in a&&a.code_id).sort((a,c)=>(c.priority||0)-(a.priority||0)),o=[];for(const a of r){const c=a.code_id,l=await e.env.data.actions.get(e.var.tenant_id,c);l&&o.push({id:a.hook_id,trigger_id:d2(a.trigger_id),display_name:l.name,action:{...l,secrets:l.secrets?.map(d=>({name:d.name}))},created_at:a.created_at,updated_at:a.updated_at})}return e.json({bindings:o})}).openapi(s.createRoute({tags:["actions"],method:"patch",path:"/{triggerId}/bindings",request:{headers:s.z.object({"tenant-id":s.z.string().optional()}),params:s.z.object({triggerId:s.z.string()}),body:{content:{"application/json":{schema:s.z.object({bindings:s.z.array(zO)})}}}},security:[{Bearer:["update:actions","auth:write"]}],responses:{200:{content:{"application/json":{schema:u2}},description:"Updated trigger bindings"}}}),async e=>{const{triggerId:t}=e.req.valid("param"),{bindings:n}=e.req.valid("json"),i=l2(t),r=await e.env.data.hooks.list(e.var.tenant_id,{q:`trigger_id:"${i}"`,per_page:100});for(const a of r.hooks)"code_id"in a&&a.code_id&&await e.env.data.hooks.remove(e.var.tenant_id,a.hook_id);const o=[];for(let a=0;a<n.length;a++){const c=n[a];let l=c.ref.id;if(!l&&c.ref.type==="action_id"&&c.ref.value)l=c.ref.value;else if(!l&&c.ref.type==="action_name"&&c.ref.value){const p=c.ref.value,f=100;let h=0;for(;;){const g=await e.env.data.actions.list(e.var.tenant_id,{page:h,per_page:f,include_totals:!1}),m=g.actions.find(_=>_.name===p);if(m){l=m.id;break}if(g.actions.length<f)break;h++}}if(!l)throw new z(400,{message:`Binding at index ${a} must reference an action via ref.id or ref.value`});const d=await e.env.data.actions.get(e.var.tenant_id,l);if(!d)throw new z(404,{message:`Action ${l} not found`});const u=await e.env.data.hooks.create(e.var.tenant_id,{hook_id:uT(),trigger_id:i,code_id:l,enabled:!0,synchronous:!0,priority:n.length-a});o.push({id:u.hook_id,trigger_id:d2(u.trigger_id),display_name:c.display_name||d.name,action:{...d,secrets:d.secrets?.map(p=>({name:p.name}))},created_at:u.created_at,updated_at:u.updated_at})}return await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:`Update trigger bindings for ${t}`,targetType:"action"}),e.json({bindings:o})}),Kl={themeId:"default",borders:{button_border_radius:8,button_border_weight:1,buttons_style:"pill",input_border_radius:8,input_border_weight:1,inputs_style:"pill",show_widget_shadow:!0,widget_border_weight:1,widget_corner_radius:16},colors:{base_focus_color:"#7D68F4",base_hover_color:"#A091F2",body_text:"#000000",captcha_widget_theme:"auto",error:"#FC5A5A",header:"#000000",icons:"#666666",input_background:"#FFFFFF",input_border:"#8E8CA0",input_filled_text:"#000000",input_labels_placeholders:"#88869F",links_focused_components:"#7D68F4",primary_button:"#7D68F4",primary_button_label:"#FFFFFF",secondary_button_border:"#8E8CA0",secondary_button_label:"#000000",success:"#36BF76",widget_background:"#FFFFFF",widget_border:"#8E8CA0"},displayName:"Default Theme",fonts:{body_text:{bold:!1,size:100},buttons_text:{bold:!0,size:100},font_url:"https://assets.sesamy.com/fonts/khteka/WOFF2/KHTeka-Regular.woff2",input_labels:{bold:!1,size:100},links:{bold:!0,size:100},links_style:"normal",reference_text_size:16,subtitle:{bold:!1,size:100},title:{bold:!0,size:150}},page_background:{background_color:"#F8F9FB",background_image_url:"",page_layout:"center"},widget:{logo_url:"",header_text_alignment:"center",logo_height:36,logo_position:"center",social_buttons_layout:"bottom"}};function gb(e,t){const n=structuredClone(e);function i(r,o){for(const a in o)o[a]!==void 0&&typeof o[a]=="object"&&!Array.isArray(o[a])&&typeof r[a]=="object"&&r[a]!==null?i(r[a],o[a]):r[a]=o[a];return r}return i(n,t)}const jO=new s.OpenAPIHono().openapi(s.createRoute({tags:["branding"],method:"get",path:"/default",request:{headers:s.z.object({"tenant-id":s.z.string().optional()})},security:[{Bearer:["read:branding","auth:read"]}],responses:{200:{content:{"application/json":{schema:op}},description:"Default theme settings"}}}),async e=>{const t=await e.env.data.themes.get(e.var.tenant_id,"default");return t?e.json(t):e.json(Kl)}).openapi(s.createRoute({tags:["branding"],method:"patch",path:"/default",request:{body:{content:{"application/json":{schema:op.deepPartial()}}},headers:s.z.object({"tenant-id":s.z.string().optional()})},security:[{Bearer:["update:branding","auth:write"]}],responses:{200:{content:{"application/json":{schema:op}},description:"Updated theme settings"}}}),async e=>{const t=e.req.valid("json"),n=await e.env.data.themes.get(e.var.tenant_id,"default"),r=gb(n||Kl,t);return n?await e.env.data.themes.update(e.var.tenant_id,"default",r):await e.env.data.themes.create(e.var.tenant_id,r,"default"),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Update Theme",targetType:"theme",targetId:"default",...n?{beforeState:n}:{},afterState:r}),e.json({...r,themeId:"default"})}),p2={colors:{primary:"#7D68F4",page_background:{type:"solid",start:"#F8F9FB",end:"#F8F9FB",angle_deg:0}},logo_url:"https://assets.sesamy.com/static/images/sesamy/logos/sesamy_logo_black.svg",favicon_url:"https://assets.sesamy.com/images/favicon.ico",font:{url:"https://assets.sesamy.com/fonts/khteka/WOFF2/KHTeka-Regular.woff2"}};var OO={Stringify:1},Yr=(e,t)=>{const n=new String(e);return n.isEscaped=!0,n.callbacks=t,n},FO=/[&<>'"]/,RO=async(e,t)=>{let n="";t||=[];const i=await Promise.all(e);for(let r=i.length-1;n+=i[r],r--,!(r<0);r--){let o=i[r];typeof o=="object"&&t.push(...o.callbacks||[]);const a=o.isEscaped;if(o=await(typeof o=="object"?o.toString():o),typeof o=="object"&&t.push(...o.callbacks||[]),o.isEscaped??a)n+=o;else{const c=[n];wa(o,c),n=c[0]}}return Yr(n,t)},wa=(e,t)=>{const n=e.search(FO);if(n===-1){t[0]+=e;return}let i,r,o=0;for(r=n;r<e.length;r++){switch(e.charCodeAt(r)){case 34:i="&quot;";break;case 39:i="&#39;";break;case 38:i="&amp;";break;case 60:i="&lt;";break;case 62:i="&gt;";break;default:continue}t[0]+=e.substring(o,r)+i,o=r+1}t[0]+=e.substring(o,r)},DO=e=>{const t=e.callbacks;if(!t?.length)return e;const n=[e],i={};return t.forEach(r=>r({phase:OO.Stringify,buffer:n,context:i})),n[0]},mb=Symbol("RENDERER"),Sy=Symbol("ERROR_HANDLER"),ut=Symbol("STASH"),fT=Symbol("INTERNAL"),BO=Symbol("MEMO"),Hp=Symbol("PERMALINK"),f2=e=>(e[fT]=!0,e),hT=e=>({value:t,children:n})=>{if(!n)return;const i={children:[{tag:f2(()=>{e.push(t)}),props:{}}]};Array.isArray(n)?i.children.push(...n.flat()):i.children.push(n),i.children.push({tag:f2(()=>{e.pop()}),props:{}});const r={tag:"",props:i,type:""};return r[Sy]=o=>{throw e.pop(),o},r},gT=e=>{const t=[e],n=hT(t);return n.values=t,n.Provider=n,za.push(n),n},za=[],mT=e=>{const t=[e],n=(i=>{t.push(i.value);let r;try{r=i.children?(Array.isArray(i.children)?new AT("",{},i.children):i.children).toString():""}catch(o){throw t.pop(),o}return r instanceof Promise?r.finally(()=>t.pop()).then(o=>Yr(o,o.callbacks)):(t.pop(),Yr(r))});return n.values=t,n.Provider=n,n[mb]=hT(t),za.push(n),n},cc=e=>e.values.at(-1),Vp={title:[],script:["src"],style:["data-href"],link:["href"],meta:["name","httpEquiv","charset","itemProp"]},Ey={},jo="data-precedence",yT=e=>e.rel==="stylesheet"&&"precedence"in e,_T=(e,t)=>e==="link"?t:Vp[e].length>0,zd=e=>Array.isArray(e)?e:[e],h2=new WeakMap,g2=(e,t,n,i)=>({buffer:r,context:o})=>{if(!r)return;const a=h2.get(o)||{};h2.set(o,a);const c=a[e]||=[];let l=!1;const d=Vp[e],u=_T(e,i!==void 0);if(u){e:for(const[,p]of c)if(!(e==="link"&&!(p.rel==="stylesheet"&&p[jo]!==void 0))){for(const f of d)if((p?.[f]??null)===n?.[f]){l=!0;break e}}}if(l?r[0]=r[0].replaceAll(t,""):u||e==="link"?c.push([t,n,i]):c.unshift([t,n,i]),r[0].indexOf("</head>")!==-1){let p;if(e==="link"||i!==void 0){const f=[];p=c.map(([h,,g],m)=>{if(g===void 0)return[h,Number.MAX_SAFE_INTEGER,m];let _=f.indexOf(g);return _===-1&&(f.push(g),_=f.length-1),[h,_,m]}).sort((h,g)=>h[1]-g[1]||h[2]-g[2]).map(([h])=>h)}else p=c.map(([f])=>f);p.forEach(f=>{r[0]=r[0].replaceAll(f,"")}),r[0]=r[0].replace(/(?=<\/head>)/,p.join(""))}},Pd=(e,t,n)=>Yr(new li(e,n,zd(t??[])).toString()),Nd=(e,t,n,i)=>{if("itemProp"in n)return Pd(e,t,n);let{precedence:r,blocking:o,...a}=n;r=i?r??"":void 0,i&&(a[jo]=r);const c=new li(e,a,zd(t||[])).toString();return c instanceof Promise?c.then(l=>Yr(c,[...l.callbacks||[],g2(e,l,a,r)])):Yr(c,[g2(e,c,a,r)])},LO=({children:e,...t})=>{const n=yb();if(n){const i=cc(n);if(i==="svg"||i==="head")return new li("title",t,zd(e??[]))}return Nd("title",e,t,!1)},MO=({children:e,...t})=>{const n=yb();return["src","async"].some(i=>!t[i])||n&&cc(n)==="head"?Pd("script",e,t):Nd("script",e,t,!1)},UO=({children:e,...t})=>["href","precedence"].every(n=>n in t)?(t["data-href"]=t.href,delete t.href,Nd("style",e,t,!0)):Pd("style",e,t),qO=({children:e,...t})=>["onLoad","onError"].some(n=>n in t)||t.rel==="stylesheet"&&(!("precedence"in t)||"disabled"in t)?Pd("link",e,t):Nd("link",e,t,yT(t)),HO=({children:e,...t})=>{const n=yb();return n&&cc(n)==="head"?Pd("meta",e,t):Nd("meta",e,t,!1)},wT=(e,{children:t,...n})=>new li(e,n,zd(t??[])),VO=e=>(typeof e.action=="function"&&(e.action=Hp in e.action?e.action[Hp]:void 0),wT("form",e)),bT=(e,t)=>(typeof t.formAction=="function"&&(t.formAction=Hp in t.formAction?t.formAction[Hp]:void 0),wT(e,t)),KO=e=>bT("input",e),GO=e=>bT("button",e);const rm=Object.freeze(Object.defineProperty({__proto__:null,button:GO,form:VO,input:KO,link:qO,meta:HO,script:MO,style:UO,title:LO},Symbol.toStringTag,{value:"Module"}));var WO=new Map([["className","class"],["htmlFor","for"],["crossOrigin","crossorigin"],["httpEquiv","http-equiv"],["itemProp","itemprop"],["fetchPriority","fetchpriority"],["noModule","nomodule"],["formAction","formaction"]]),Kp=e=>WO.get(e)||e,JO=/[\s"'<>/=`\\\x00-\x1f\x7f-\x9f]/,om=new Set,m2=1024,YO=/^[!?]|[\s"'<>/=`\\\x00-\x1f\x7f-\x9f]/,y2=new Set,QO=256,Gl=(e,t,n)=>{e.size>=t&&e.clear(),e.add(n)},ZO=e=>y2.has(e)?!0:typeof e!="string"?!1:e.length===0?!0:YO.test(e)?!1:(Gl(y2,QO,e),!0),XO=e=>{if(om.has(e))return!0;const t=e.length;if(t===0)return!1;for(let n=0;n<t;n++){const i=e.charCodeAt(n);if(!(i>=97&&i<=122||i>=65&&i<=90||i>=48&&i<=57||i===45||i===95||i===46||i===58))return JO.test(e)?!1:(Gl(om,m2,e),!0)}return Gl(om,m2,e),!0},eF=/[\s"'():;\\/\[\]{}\x00-\x1f\x7f-\x9f]/,sm=new Set,_2=1024,tF=e=>{if(sm.has(e))return!0;const t=e.length;if(t===0)return!1;for(let n=0;n<t;n++){const i=e.charCodeAt(n);if(!(i>=97&&i<=122||i>=65&&i<=90||i>=48&&i<=57||i===45||i===95))return eF.test(e)?!1:(Gl(sm,_2,e),!0)}return Gl(sm,_2,e),!0},nF=/[;"'\\/\[\](){}]/,iF=e=>{if(!nF.test(e))return!1;let t=0;const n=[];for(let i=0,r=e.length;i<r;i++){const o=e.charCodeAt(i);if(o===92){if(i===r-1)return!0;i++}else if(t!==0){if(o===10||o===12||o===13)return!0;o===t&&(t=0)}else if(o===47&&e.charCodeAt(i+1)===42){const a=e.indexOf("*/",i+2);if(a===-1)return!0;i=a+1}else if(o===34||o===39)t=o;else if(o===40)n.push(41);else if(o===91)n.push(93);else{if(o===123||o===125)return!0;if(o===41||o===93){if(n[n.length-1]!==o)return!0;n.pop()}else if(o===59&&n.length===0)return!0}}return t!==0||n.length!==0},vT=(e,t)=>{for(const[n,i]of Object.entries(e)){const r=n[0]==="-"||!/[A-Z]/.test(n)?n:n.replace(/[A-Z]/g,a=>`-${a.toLowerCase()}`);if(!tF(r))continue;if(i==null){t(r,null);continue}let o;if(typeof i=="number")o=r.match(/^(?:a|border-im|column(?:-c|s)|flex(?:$|-[^b])|grid-(?:ar|[^a])|font-w|li|or|sca|st|ta|wido|z)|ty$/)?`${i}`:`${i}px`;else if(typeof i=="string"){if(iF(i))continue;o=i}else continue;t(r,o)}},Wl=void 0,yb=()=>Wl,rF=e=>/[A-Z]/.test(e)&&e.match(/^(?:al|basel|clip(?:Path|Rule)$|co|do|fill|fl|fo|gl|let|lig|i|marker[EMS]|o|pai|pointe|sh|st[or]|text[^L]|tr|u|ve|w)/)?e.replace(/([A-Z])/g,"-$1").toLowerCase():e,oF=["area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr"],sF=["allowfullscreen","async","autofocus","autoplay","checked","controls","default","defer","disabled","download","formnovalidate","hidden","inert","ismap","itemscope","loop","multiple","muted","nomodule","novalidate","open","playsinline","readonly","required","reversed","selected"],_b=(e,t)=>{for(let n=0,i=e.length;n<i;n++){const r=e[n];if(typeof r=="string")wa(r,t);else{if(typeof r=="boolean"||r===null||r===void 0)continue;r instanceof li?r.toStringToBuffer(t):typeof r=="number"||r.isEscaped?t[0]+=r:r instanceof Promise?t.unshift("",r):_b(r,t)}}},li=class{tag;props;key;children;isEscaped=!0;localContexts;constructor(e,t,n){if(typeof e!="function"&&!ZO(e))throw new Error(`Invalid JSX tag name: ${e}`);this.tag=e,this.props=t,this.children=n}get type(){return this.tag}get ref(){return this.props.ref||null}toString(){const e=[""];this.localContexts?.forEach(([t,n])=>{t.values.push(n)});try{this.toStringToBuffer(e)}finally{this.localContexts?.forEach(([t])=>{t.values.pop()})}return e.length===1?"callbacks"in e?DO(Yr(e[0],e.callbacks)).toString():e[0]:RO(e,e.callbacks)}toStringToBuffer(e){const t=this.tag,n=this.props;let{children:i}=this;e[0]+=`<${t}`;const r=t==="svg"||Wl&&cc(Wl)==="svg"?o=>rF(Kp(o)):o=>Kp(o);for(let[o,a]of Object.entries(n))if(o=r(o),!!XO(o)&&o!=="children"){if(o==="style"&&typeof a=="object"){let c="";vT(a,(l,d)=>{d!=null&&(c+=`${c?";":""}${l}:${d}`)}),e[0]+=' style="',wa(c,e),e[0]+='"'}else if(typeof a=="string")e[0]+=` ${o}="`,wa(a,e),e[0]+='"';else if(a!=null)if(typeof a=="number"||a.isEscaped)e[0]+=` ${o}="${a}"`;else if(typeof a=="boolean"&&sF.includes(o))a&&(e[0]+=` ${o}=""`);else if(o==="dangerouslySetInnerHTML"){if(i.length>0)throw new Error("Can only set one of `children` or `props.dangerouslySetInnerHTML`.");i=[Yr(a.__html)]}else if(a instanceof Promise)e[0]+=` ${o}="`,e.unshift('"',a);else if(typeof a=="function"){if(!o.startsWith("on")&&o!=="ref")throw new Error(`Invalid prop '${o}' of type 'function' supplied to '${t}'.`)}else e[0]+=` ${o}="`,wa(a.toString(),e),e[0]+='"'}if(oF.includes(t)&&i.length===0){e[0]+="/>";return}e[0]+=">",_b(i,e),e[0]+=`</${t}>`}},am=class extends li{toStringToBuffer(e){const{children:t}=this,n={...this.props};t.length&&(n.children=t.length===1?t[0]:t);const i=this.tag.call(null,n);if(!(typeof i=="boolean"||i==null))if(i instanceof Promise)if(za.length===0)e.unshift("",i);else{const r=za.map(o=>[o,o.values.at(-1)]);e.unshift("",i.then(o=>(o instanceof li&&(o.localContexts=r),o)))}else i instanceof li?i.toStringToBuffer(e):typeof i=="number"||i.isEscaped?(e[0]+=i,i.callbacks&&(e.callbacks||=[],e.callbacks.push(...i.callbacks))):wa(i,e)}},AT=class extends li{toStringToBuffer(e){_b(this.children,e)}},aF=(e,t,...n)=>{t??={},n.length&&(t.children=n.length===1?n[0]:n);const i=t.key;delete t.key;const r=sp(e,t,n);return r.key=i,r},w2=!1,sp=(e,t,n)=>{if(!w2){for(const i in Ey)rm[i][mb]=Ey[i];w2=!0}return typeof e=="function"?new am(e,t,n):rm[e]?new am(rm[e],t,n):e==="svg"||e==="head"?(Wl||=mT(""),new li(e,t,[new am(Wl,{value:e},n)])):new li(e,t,n)},Pa=({children:e})=>new AT("",{children:e},Array.isArray(e)?e:e?[e]:[]),cF=(e,t,...n)=>{let i;if(n.length>0)i=n;else{const r=e.props.children;i=Array.isArray(r)?r:[r]}return aF(e.tag,{...e.props,...t},...i)};function S(e,t,n){let i;if(!t||!("children"in t))i=sp(e,t,[]);else{const r=t.children;i=Array.isArray(r)?sp(e,t,r):sp(e,t,[r])}return i.key=n,i}function Ie(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#x27;")}function lF(e){return e.replace(/\\/g,"\\\\").replace(/"/g,'\\"').replace(/'/g,"\\'").replace(/\(/g,"\\(").replace(/\)/g,"\\)").replace(/\n/g,"").replace(/\r/g,"").replace(/\t/g,"")}function gn(e){if(!e)return"";try{const t=new URL(e);return["http:","https:","data:"].includes(t.protocol)?Ie(e):""}catch{return e.startsWith("/")?Ie(e):""}}function hn(e){return e&&/^(#[0-9a-fA-F]{3,8}|rgba?\([^)]+\)|hsla?\([^)]+\)|[a-zA-Z]+)$/.test(e.trim())?e.trim():""}function dF(e){if(!e)return"#f5f5f5";if(typeof e=="string")return hn(e)||"#f5f5f5";const{type:t,start:n,end:i,angle_deg:r}=e;if(t==="linear-gradient"&&n&&i){const o=hn(n),a=hn(i);if(o&&a)return`linear-gradient(${typeof r=="number"?r:180}deg, ${o}, ${a})`}if(n){const o=hn(n);if(o)return o}return"#f5f5f5"}function kT(e,t){if(e?.background_image_url){const n=gn(e.background_image_url);if(n)return`${hn(e.background_color)||"#f5f5f5"} url("${lF(n)}") center / cover no-repeat`}if(e?.background_color){const n=hn(e.background_color);if(n)return n}return dF(t)}var uF=(e,t)=>{try{return t(e)}catch{return e.replace(/(?:%[0-9A-Fa-f]{2})+/g,n=>{try{return t(n)}catch{return n}})}},pF=decodeURIComponent,ST=/^[\w!#$%&'*.^`|~+-]+$/,fF=/^[ !#-:<-[\]-~]*$/,b2=e=>{let t=0,n=e.length;for(;t<n;){const i=e.charCodeAt(t);if(i!==32&&i!==9)break;t++}for(;n>t;){const i=e.charCodeAt(n-1);if(i!==32&&i!==9)break;n--}return t===0&&n===e.length?e:e.slice(t,n)},hF=(e,t)=>{if(e.indexOf(t)===-1)return{};const n=e.split(";"),i={};for(const r of n){const o=r.indexOf("=");if(o===-1)continue;const a=b2(r.substring(0,o));if(t!==a||!ST.test(a))continue;let c=b2(r.substring(o+1));if(c.startsWith('"')&&c.endsWith('"')&&(c=c.slice(1,-1)),fF.test(c)){i[a]=c.indexOf("%")!==-1?uF(c,pF):c;break}}return i},gF=(e,t,n={})=>{if(!ST.test(e))throw new Error("Invalid cookie name");let i=`${e}=${t}`;if(e.startsWith("__Secure-")&&!n.secure)throw new Error("__Secure- Cookie must have Secure attributes");if(e.startsWith("__Host-")){if(!n.secure)throw new Error("__Host- Cookie must have Secure attributes");if(n.path!=="/")throw new Error('__Host- Cookie must have Path attributes with "/"');if(n.domain)throw new Error("__Host- Cookie must not have Domain attributes")}for(const r of["domain","path"])if(n[r]&&/[;\r\n]/.test(n[r]))throw new Error(`${r} must not contain ";", "\\r", or "\\n"`);if(n&&typeof n.maxAge=="number"&&n.maxAge>=0){if(n.maxAge>3456e4)throw new Error("Cookies Max-Age SHOULD NOT be greater than 400 days (34560000 seconds) in duration.");i+=`; Max-Age=${n.maxAge|0}`}if(n.domain&&n.prefix!=="host"&&(i+=`; Domain=${n.domain}`),n.path&&(i+=`; Path=${n.path}`),n.expires){if(n.expires.getTime()-Date.now()>3456e7)throw new Error("Cookies Expires SHOULD NOT be greater than 400 days (34560000 seconds) in the future.");i+=`; Expires=${n.expires.toUTCString()}`}if(n.httpOnly&&(i+="; HttpOnly"),n.secure&&(i+="; Secure"),n.sameSite&&(i+=`; SameSite=${n.sameSite.charAt(0).toUpperCase()+n.sameSite.slice(1)}`),n.priority&&(i+=`; Priority=${n.priority.charAt(0).toUpperCase()+n.priority.slice(1)}`),n.partitioned){if(!n.secure)throw new Error("Partitioned Cookie must have Secure attributes");i+="; Partitioned"}return i},cm=(e,t,n)=>(t=encodeURIComponent(t),gF(e,t,n)),mF=(e,t,n)=>{const i=e.req.raw.headers.get("Cookie");{if(!i)return;let r=t;return hF(i,r)[r]}},yF=(e,t,n)=>{let i;return n?.prefix==="secure"?i=cm("__Secure-"+e,t,{path:"/",...n,secure:!0}):n?.prefix==="host"?i=cm("__Host-"+e,t,{...n,path:"/",secure:!0,domain:void 0}):i=cm(e,t,{path:"/",...n}),i},v2=(e,t,n,i)=>{const r=yF(t,n,i);e.header("Set-Cookie",r,{append:!0})};const Jl="mp6tm1tk",ET={common:{alertListTitle:"Upozornění",backText:"Vrátit se zpět",cancelText:"Zrušit",closeText:"Zavřít",contactSupportText:"Potřebujete pomoc?",continueText:"Pokračovat",copyrightText:"© ${currentYear} ${companyName}",errorText:"Něco se pokazilo. Zkuste to prosím znovu.",hidePasswordText:"Skrýt heslo",loadingText:"Načítání...",orText:"nebo",privacyPolicyText:"Zásady ochrany osobních údajů",showPasswordText:"Zobrazit heslo",termsOfServiceText:"Podmínky služby",termsShortText:"Podmínky",tryAgainText:"Zkusit znovu"}},xT={consent:{buttonText:"Přijmout",cancelButtonText:"Zamítnout",description:"${clientName} žádá o přístup k vašemu účtu",pageTitle:"Autorizace | ${clientName}",scopesTitle:"Tímto povolíte ${clientName}:",title:"Autorizovat ${clientName}"}},CT={invitation:{acceptButtonText:"Přijmout pozvánku",description:"${inviterName} vás pozval(a), abyste se připojili k ${organizationName} na ${clientName}",pageTitle:"Pozvánka | ${clientName}",title:"Byli jste pozváni"}},TT={login:{alertListTitle:"Upozornění",buttonText:"Pokračovat",description:"Přihlaste se k ${clientName}.",editEmailText:"Upravit",emailPlaceholder:"E-mailová adresa",enterACodeBtn:"Přihlásit se kódem",federatedConnectionButtonText:"Pokračovat s ${connectionName}",footerLinkText:"Zaregistrujte se",footerText:"Nemáte účet?",forgotPasswordText:"Zapomněli jste heslo?",hidePasswordText:"Skrýt heslo",invalidEmail:"Neplatný e-mail",invalidIdentifier:"Neplatný e-mail nebo uživatelské jméno",invitationDescription:"Přihlaste se pro přijetí pozvánky od ${inviterName} k připojení k ${companyName} na ${clientName}.",invitationTitle:"Byli jste pozváni!",logoAltText:"${companyName}","no-email":"Zadejte prosím e-mailovou adresu","no-password":"Heslo je povinné",pageTitle:"Přihlášení | ${clientName}",passwordLoginNotAvailable:"Přihlášení heslem není k dispozici",passwordPlaceholder:"Heslo",phonePlaceholder:"Telefonní číslo",separatorText:"nebo",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",showPasswordText:"Zobrazit heslo",signupActionLinkText:"${footerLinkText}",signupActionText:"${footerText}",title:"Vítejte",tooManyFailedLogins:"Příliš mnoho neúspěšných pokusů o přihlášení. Zkuste to prosím později.",unverifiedEmail:"Před přihlášením prosím ověřte svou e-mailovou adresu",userAccountDoesNotExist:"Uživatelský účet neexistuje",usernamePlaceholder:"Uživatelské jméno nebo e-mailová adresa",usernameTooLong:"Uživatelské jméno musí mít nejvýše ${max} znaků",usernameTooShort:"Uživatelské jméno musí mít alespoň ${min} znaků",wrongCredentials:"Nesprávné uživatelské jméno nebo heslo",passkeyButtonText:"Přihlásit se pomocí passkey"}},$T={mfa:{backupCodeText:"Použít záložní kód",description:"Zvolte metodu ověření",pageTitle:"Vícefaktorové ověření | ${clientName}",title:"Ověřte svou identitu"}},IT={"passkey-enrollment-nudge":{title:"Zabezpečte svůj účet pomocí passkey",description:"Passkey používají biometrii nebo PIN vašeho zařízení k rychlejšímu a bezpečnějšímu přihlášení.",enrollButtonText:"Nastavit passkey",snoozeButtonText:"Možná později",optOutLinkText:"Nezobrazovat znovu",pageTitle:"Nastavení Passkey | ${clientName}"},"passkey-enrollment":{title:"Vytvořte svůj passkey",description:"Postupujte podle pokynů prohlížeče a vytvořte passkey pro tento účet.",errorMessage:"Vytvoření passkey se nezdařilo. Zkuste to prosím znovu.",cancelLinkText:"Prozatím přeskočit",retryButtonText:"Zkusit znovu",enrollmentComplete:"Váš passkey byl úspěšně nastaven. Tuto stránku můžete zavřít.",pageTitle:"Vytvoření Passkey | ${clientName}"},"passkey-challenge":{title:"Přihlásit se pomocí passkey",description:"Postupujte podle pokynů prohlížeče k ověření vaší identity.",errorMessage:"Ověření pomocí passkey selhalo. Zkuste to prosím znovu.",cancelLinkText:"Zpět na přihlášení",retryButtonText:"Zkusit znovu",pageTitle:"Přihlášení pomocí passkey | ${clientName}"}},zT={organizations:{description:"Vyberte, ke které organizaci se chcete přihlásit",pageTitle:"Výběr organizace | ${clientName}",searchPlaceholder:"Hledat organizace",title:"Vyberte svou organizaci"}},PT={signup:{buttonText:"Pokračovat",confirmPasswordPlaceholder:"Potvrzení hesla",description:"Zaregistrujte se a pokračujte","email-already-exists":"Tento e-mail je již zaregistrován",emailPlaceholder:"E-mailová adresa",federatedConnectionButtonText:"Pokračovat s ${connectionName}",hidePasswordText:"Skrýt heslo","invalid-email-format":"Neplatný e-mail",loginActionLinkText:"Přihlásit se",loginActionText:"Už máte účet?","no-email":"Zadejte prosím e-mailovou adresu","no-password":"Heslo je povinné","no-username":"Uživatelské jméno je povinné",pageTitle:"Registrace | ${clientName}",passwordPlaceholder:"Heslo",passwordsDidntMatch:"Hesla se neshodují",phonePlaceholder:"Telefonní číslo",privacyPolicyLinkText:"Zásady ochrany osobních údajů",separatorText:"nebo",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",showPasswordText:"Zobrazit heslo",termsOfServiceLinkText:"Podmínky služby",termsText:"Registrací souhlasíte s našimi",title:"Vytvořte svůj účet","username-already-exists":"Toto uživatelské jméno je již obsazeno",usernamePlaceholder:"Uživatelské jméno",verifyEmailText:"Zkontrolujte prosím svůj e-mail pro ověření účtu"}},NT={status:{continueButtonText:"Pokračovat",errorTitle:"Chyba",pageTitle:"Stav | ${clientName}",successTitle:"Hotovo",title:"Stav"}},_F={common:ET,consent:xT,"device-flow":{"device-flow":{buttonText:"Pokračovat",codePlaceholder:"Zadejte kód",description:"Zadejte kód zobrazený na vašem zařízení","expired-code":"Platnost kódu vypršela","invalid-code":"Zadaný kód je neplatný",pageTitle:"Aktivace zařízení | ${clientName}",title:"Aktivujte své zařízení"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Přihlásit se",codeLabel:"Ověřovací kód",codePlaceholder:"Zadejte kód",defaultDescription:"Zadejte ověřovací kód zaslaný na váš e-mail",description:"Odeslali jsme kód na ${email}","invalid-code":"Neplatný kód",noCode:"Zadejte prosím ověřovací kód",pageTitle:"Zadejte kód | ${clientName}",resendText:"Opětovné odeslání kódu",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",title:"Zkontrolujte svůj e-mail",unexpectedError:"Došlo k neočekávané chybě"}},"email-verification":{"email-verification":{description:"Odeslali jsme e-mail na ${email}",pageTitle:"Ověření e-mailu | ${clientName}",resendText:"Opětovné odeslání kódu",successDescription:"Váš e-mail byl úspěšně ověřen.",successTitle:"E-mail ověřen",title:"Ověření e-mailu"}},invitation:CT,login:TT,"login-id":{"login-id":{alertListTitle:"Upozornění","auth0-users-validation":"Něco se pokazilo, zkuste to prosím později","authentication-failure":"Omlouváme se, při pokusu o přihlášení se něco pokazilo",buttonText:"Pokračovat","captcha-client-failure":"Nepodařilo se načíst bezpečnostní výzvu. Zkuste to prosím znovu. (Kód chyby: #{errorCode})","captcha-validation-failure":"Omlouváme se, při ověřování captcha došlo k chybě. Zkuste to prosím znovu.",captchaCodePlaceholder:"Zadejte kód zobrazený výše","custom-script-error-code":"Něco se pokazilo, zkuste to prosím později.",description:"Přihlaste se k ${clientName}.",editEmailText:"Upravit",emailPlaceholder:"E-mailová adresa",federatedConnectionButtonText:"Pokračovat s ${connectionName}",footerLinkText:"Zaregistrujte se",footerText:"Nemáte účet?",forgotPasswordText:"Zapomněli jste heslo?",hidePasswordText:"Skrýt heslo","invalid-captcha":"Vyřešte úlohu, abyste ověřili, že nejste robot.","invalid-code":"Neplatný kód","invalid-connection":"Neplatné připojení","invalid-email-format":"Neplatný e-mail","invalid-email-phone":"Zadejte platnou e-mailovou adresu nebo telefonní číslo. Telefonní čísla musí obsahovat předvolbu země.","invalid-email-phone-username":"Zadejte platnou e-mailovou adresu, telefonní číslo nebo uživatelské jméno. Telefonní čísla musí obsahovat předvolbu země.","invalid-email-username":"Zadejte platnou e-mailovou adresu nebo uživatelské jméno","invalid-expired-code":"Neplatný nebo vypršelý uživatelský kód","invalid-login-id":"Zadáno neplatné přihlašovací ID","invalid-phone-username":"Zadejte platné telefonní číslo nebo uživatelské jméno. Telefonní čísla musí obsahovat předvolbu země.","invalid-recaptcha":"Zaškrtněte políčko, abyste ověřili, že nejste robot.","invalid-username":"Uživatelské jméno může obsahovat pouze alfanumerické znaky nebo: '${characters}'. Uživatelské jméno musí mít ${min} až ${max} znaků.",invitationDescription:"Přihlaste se pro přijetí pozvánky od ${inviterName} k připojení k ${companyName} na ${clientName}.",invitationTitle:"Byli jste pozváni!","ip-blocked":"Zjistili jsme podezřelé přihlašovací chování a další pokusy budou blokovány. Kontaktujte prosím administrátora.",logoAltText:"${companyName}","no-db-connection":"Neplatné připojení","no-email":"Zadejte prosím e-mailovou adresu","no-email-phone":"Je vyžadována e-mailová adresa nebo telefonní číslo","no-email-phone-username":"Je vyžadováno telefonní číslo, uživatelské jméno nebo e-mailová adresa","no-email-username":"Je vyžadována e-mailová adresa nebo uživatelské jméno","no-password":"Heslo je povinné","no-phone":"Zadejte prosím telefonní číslo","no-phone-username":"Je vyžadováno telefonní číslo nebo uživatelské jméno","no-username":"Uživatelské jméno je povinné",pageTitle:"Přihlášení | ${clientName}","password-breached":"Zjistili jsme potenciální bezpečnostní problém s tímto účtem. Pro ochranu vašeho účtu jsme toto přihlášení zablokovali. Pro pokračování prosím resetujte své heslo.",passwordPlaceholder:"Heslo",phoneOrEmailPlaceholder:"E-mail nebo telefonní číslo",phoneOrUsernameOrEmailPlaceholder:"Telefon, uživatelské jméno nebo e-mail",phoneOrUsernamePlaceholder:"Telefonní číslo nebo uživatelské jméno",phonePlaceholder:"Telefonní číslo","same-user-login":"Příliš mnoho pokusů o přihlášení pro tohoto uživatele. Počkejte prosím a zkuste to znovu později.",selectCountryCode:"Vyberte předvolbu země, aktuálně nastaveno na ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"nebo",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",showPasswordText:"Zobrazit heslo",signupActionLinkText:"${footerLinkText}",signupActionText:"${footerText}",termsAndConditionsTemplate:'Pokračováním souhlasíte s našimi <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Podmínkami a pravidly</a>.',title:"Vítejte","user-blocked":"Váš účet byl zablokován po několika po sobě jdoucích neúspěšných pokusech o přihlášení.",userAccountDoesNotExist:"Uživatelský účet neexistuje",usernameOnlyPlaceholder:"Uživatelské jméno",usernameOrEmailPlaceholder:"Uživatelské jméno nebo e-mailová adresa",usernamePlaceholder:"Uživatelské jméno nebo e-mailová adresa",usernameTooLong:"Uživatelské jméno musí mít nejvýše ${max} znaků",usernameTooShort:"Uživatelské jméno musí mít alespoň ${min} znaků","wrong-credentials":"Nesprávné uživatelské jméno nebo heslo","wrong-email-credentials":"Nesprávný e-mail nebo heslo","wrong-email-phone-credentials":"Nesprávná e-mailová adresa, telefonní číslo nebo heslo. Telefonní čísla musí obsahovat předvolbu země.","wrong-email-phone-username-credentials":"Nesprávná e-mailová adresa, telefonní číslo, uživatelské jméno nebo heslo. Telefonní čísla musí obsahovat předvolbu země.","wrong-email-username-credentials":"Nesprávná e-mailová adresa, uživatelské jméno nebo heslo","wrong-phone-credentials":"Nesprávné telefonní číslo nebo heslo","wrong-phone-username-credentials":"Nesprávné telefonní číslo, uživatelské jméno nebo heslo. Telefonní čísla musí obsahovat předvolbu země.","wrong-username-credentials":"Nesprávné uživatelské jméno nebo heslo",passkeyButtonText:"Přihlásit se pomocí passkey"}},"login-password":{"login-password":{buttonText:"Přihlásit se",description:"Přihlaste se k ${clientName}",forgotPasswordText:"Zapomněli jste heslo?",hidePasswordText:"Skrýt heslo","no-password":"Heslo je povinné",pageTitle:"Přihlášení | ${clientName}","password-breached":"Zjistili jsme potenciální bezpečnostní problém s tímto účtem. Pro ochranu vašeho účtu jsme toto přihlášení zablokovali. Pro pokračování prosím resetujte své heslo.",passwordPlaceholder:"Heslo",showPasswordText:"Zobrazit heslo",signingInAs:"Přihlášení jako ${email}",title:"Zadejte heslo",unverifiedEmail:"Před přihlášením prosím ověřte svou e-mailovou adresu","user-blocked":"Váš účet byl zablokován po několika po sobě jdoucích neúspěšných pokusech o přihlášení.","wrong-credentials":"Nesprávné heslo"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-mailová adresa",authMethodEmailOrPhone:"e-mail nebo telefonní číslo",authMethodPhone:"telefonní číslo",description:"Přihlaste se pomocí ${authMethod}",emailOrPhonePlaceholder:"E-mailová adresa nebo telefonní číslo",emailPlaceholder:"E-mailová adresa",invalidEmail:"Zadejte prosím platnou e-mailovou adresu",invalidIdentifier:"Zadejte prosím platnou e-mailovou adresu nebo telefonní číslo",invalidPhone:"Zadejte prosím platné telefonní číslo s předvolbou země",noEmail:"Zadejte prosím svou e-mailovou adresu",noPhone:"Zadejte prosím své telefonní číslo",phonePlaceholder:"Telefonní číslo",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",title:"Přihlásit se kódem",userAccountDoesNotExist:"Uživatelský účet neexistuje"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Klikněte na odkaz ve svém e-mailu pro přihlášení",description:"Odeslali jsme odkaz na ${username}. Kliknutím na něj se přihlásíte.",resendText:"Odeslat odkaz znovu",spamText:"Nedostali jste e-mail? Zkontrolujte složku nevyžádané pošty.",title:"Zkontrolujte svůj e-mail"}},mfa:$T,"mfa-email":{"mfa-email":{buttonText:"Pokračovat",codePlaceholder:"Zadejte kód",description:"Odeslali jsme kód na ${email}","invalid-code":"Zadaný kód je neplatný",pageTitle:"Ověření e-mailem | ${clientName}",resendText:"Opětovné odeslání kódu",title:"Zkontrolujte svůj e-mail"}},"mfa-otp":{"mfa-otp":{buttonText:"Pokračovat",codePlaceholder:"Zadejte kód",description:"Zadejte šestimístný kód z vaší ověřovací aplikace","invalid-code":"Zadaný kód je neplatný",pageTitle:"Zadejte kód | ${clientName}",title:"Zadejte svůj kód"},"mfa-totp-enrollment":{title:"Nastavit ověřovací aplikaci",description:"Naskenujte QR kód níže pomocí ověřovací aplikace a poté zadejte šestimístný kód pro ověření",secretLabel:"Nebo zadejte tento kód ručně:",codePlaceholder:"Zadejte kód",continueButtonText:"Ověřit a aktivovat","invalid-code":"Zadaný kód je neplatný. Zkuste to prosím znovu.","transaction-not-found":"Platnost vaší registrace vypršela, budete muset začít znovu.",pageTitle:"Nastavení ověřovací aplikace | ${clientName}",unexpectedError:"Něco se pokazilo. Zkuste to prosím znovu.",enrollmentComplete:"Registrace MFA je dokončena. Tuto stránku můžete zavřít."},"mfa-totp-challenge":{title:"Ověřte svou identitu",description:"Zadejte šestimístný kód z vaší ověřovací aplikace",codePlaceholder:"Zadejte kód",continueButtonText:"Pokračovat","invalid-code":"Zadaný kód je neplatný","transaction-not-found":"Platnost vaší registrace vypršela, budete muset začít znovu.",unexpectedError:"Něco se pokazilo. Zkuste to prosím znovu.",pageTitle:"Ověření identity | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Použijte své telefonní číslo pro přihlášení | ${clientName}",title:"Ověřte svou identitu",description:"Odeslali jsme kód na ${phoneNumber}",continueButtonText:"Pokračovat",changePhoneText:"Zvolte jiné telefonní číslo.",smsButtonText:"Textová zpráva",voiceButtonText:"Hlasový hovor",chooseMessageTypeText:"Jak chcete kód přijmout?",pickAuthenticatorText:"Zkusit jinou metodu",logoAltText:"${companyName}",codePlaceholder:"Zadejte kód","send-sms-failed":"Při odesílání SMS došlo k problému","send-voice-failed":"Při uskutečnění hlasového hovoru došlo k problému","invalid-phone-format":"Telefonní číslo může obsahovat pouze číslice.","invalid-phone":"Zdá se, že vaše telefonní číslo není platné. Zkontrolujte a zkuste to znovu.","too-many-sms":"Překročili jste maximální počet telefonních zpráv za hodinu. Počkejte pár minut a zkuste to znovu.","too-many-voice":"Překročili jste maximální počet hlasových hovorů za hodinu. Počkejte pár minut a zkuste to znovu.","transaction-not-found":"Vaše registrační transakce vypršela, budete muset začít znovu.","no-phone":"Zadejte telefonní číslo",noCode:"Zadejte ověřovací kód",invalidCode:"Zadaný kód je neplatný. Zkuste to znovu.",unexpectedError:"Něco se pokazilo. Zkuste to znovu.",resendSuccess:"Odeslali jsme nový kód na váš telefon",enrollmentComplete:"Registrace MFA je dokončena. Tuto stránku můžete zavřít."},"mfa-phone-enrollment":{pageTitle:"Zadejte své telefonní číslo pro přihlášení pomocí telefonního kódu | ${clientName}",title:"Zabezpečte svůj účet",description:"Zadejte kód země a telefonní číslo, na které můžeme odeslat 6místný kód:",continueButtonText:"Pokračovat",smsButtonText:"Textová zpráva",voiceButtonText:"Hlasový hovor",chooseMessageTypeText:"Jak chcete kód přijmout?",pickAuthenticatorText:"Zkusit jinou metodu",placeholder:"Zadejte své telefonní číslo",logoAltText:"${companyName}",selectCountryCode:"Vyberte kód země, aktuálně nastaveno na ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Při odesílání SMS došlo k problému","send-voice-failed":"Při uskutečnění hlasového hovoru došlo k problému","sms-authenticator-error":"Nepodařilo se odeslat SMS. Zkuste to prosím později.","invalid-phone-format":"Telefonní číslo může obsahovat pouze číslice.","invalid-phone":"Zdá se, že vaše telefonní číslo není platné. Zkontrolujte a zkuste to znovu.","too-many-sms":"Překročili jste maximální počet telefonních zpráv za hodinu. Počkejte pár minut a zkuste to znovu.","too-many-voice":"Překročili jste maximální počet hlasových hovorů za hodinu. Počkejte pár minut a zkuste to znovu.","transaction-not-found":"Vaše registrační transakce vypršela, budete muset začít znovu.","no-phone":"Zadejte telefonní číslo","phone-is-too-short":"Telefonní číslo je příliš krátké","phone-is-too-long":"Telefonní číslo je příliš dlouhé"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Vyberte metodu ověření | ${clientName}",title:"Vyberte způsob ověření",description:"Zvolte, jak chcete ověřit svou identitu",authenticatorAppLabel:"Autentizační aplikace",authenticatorAppDescription:"Použijte autentizační aplikaci k získání ověřovacího kódu",smsLabel:"Textová zpráva",smsDescription:"Nechte si zaslat ověřovací kód na telefon",passkeyLabel:"Passkey",passkeyDescription:"Použijte biometrii zařízení nebo bezpečnostní klíč"}},"mfa-push":{"mfa-push":{description:"Odeslali jsme oznámení na vaše zařízení",pageTitle:"Push oznámení | ${clientName}",resendText:"Odeslat oznámení znovu",title:"Schvalte požadavek",useCodeText:"Zadat kód ručně"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Pokračovat",codePlaceholder:"Záložní kód",description:"Zadejte jeden z vašich záložních kódů","invalid-code":"Zadaný záložní kód je neplatný",pageTitle:"Záložní kód | ${clientName}",title:"Zadejte záložní kód"}},"mfa-voice":{"mfa-voice":{buttonText:"Zavolat mi",codePlaceholder:"Zadejte kód",description:"Zavoláme na ${phoneNumber} s vaším kódem","invalid-code":"Zadaný kód je neplatný",pageTitle:"Hlasový hovor | ${clientName}",title:"Přijmout telefonní hovor"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Zkusit znovu",description:"Vložte svůj bezpečnostní klíč a postupujte podle pokynů",pageTitle:"Bezpečnostní klíč | ${clientName}",title:"Použijte svůj bezpečnostní klíč"}},passkeys:IT,organizations:zT,"reset-password":{"reset-password":{backToLoginText:"Zpět na přihlášení",buttonText:"Pokračovat",codeExpired:"Platnost kódu pro obnovení hesla vypršela. Požádejte prosím o nový.",confirmPasswordLabel:"Potvrzení hesla",confirmPasswordPlaceholder:"Potvrzení hesla",description:"Zadejte svůj e-mail pro obnovení hesla",emailPlaceholder:"E-mailová adresa",failed:"Obnovení hesla se nezdařilo. Zkuste to prosím znovu.","invalid-email-format":"Neplatný e-mail","no-email":"Zadejte prosím e-mailovou adresu",pageTitle:"Obnovení hesla | ${clientName}",passwordLabel:"Nové heslo",passwordPlaceholder:"Nové heslo",passwordTooWeak:"Heslo je příliš slabé",passwordsDidntMatch:"Hesla se neshodují",successDescription:"Odkaz na obnovení hesla jsme odeslali na vaši e-mailovou adresu.",successTitle:"Zkontrolujte svůj e-mail",title:"Zapomněli jste heslo?","user-not-found":"Uživatel nenalezen"},"reset-password-code":{backToLoginText:"Zpět na přihlášení",buttonText:"Obnovit heslo",codeLabel:"Kód pro obnovení",codePlaceholder:"Zadejte 6místný kód",confirmPasswordLabel:"Potvrzení hesla",confirmPasswordPlaceholder:"Potvrzení hesla",defaultDescription:"Zadejte kód zaslaný na váš e-mail a zvolte nové heslo",description:"Odeslali jsme kód na ${email}",failed:"Obnovení hesla se nezdařilo. Zkuste to prosím znovu.",invalidCode:"Zadaný kód je neplatný nebo vypršel",noCode:"Zadejte prosím kód pro obnovení",pageTitle:"Zadejte kód pro obnovení | ${clientName}",passwordLabel:"Nové heslo",passwordPlaceholder:"Nové heslo",passwordTooWeak:"Heslo je příliš slabé",passwordsDidntMatch:"Hesla se neshodují",resendFailed:"Nepodařilo se znovu odeslat kód. Zkuste to prosím znovu.",resendSuccess:"Nový kód byl odeslán na váš e-mail",resendText:"Odeslat kód znovu",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",title:"Zadejte kód pro obnovení"}},signup:PT,"signup-id":{"signup-id":{buttonText:"Pokračovat",description:"Zaregistrujte se a pokračujte","email-already-exists":"Tento e-mail je již zaregistrován",emailPlaceholder:"E-mailová adresa",federatedConnectionButtonText:"Pokračovat s ${connectionName}","invalid-email-format":"Neplatný e-mail",loginActionLinkText:"Přihlásit se",loginActionText:"Už máte účet?","no-email":"Zadejte prosím e-mailovou adresu",pageTitle:"Registrace | ${clientName}",phonePlaceholder:"Telefonní číslo",separatorText:"nebo",title:"Vytvořte svůj účet",usernamePlaceholder:"Uživatelské jméno"}},"signup-password":{"signup-password":{buttonText:"Pokračovat",description:"Zaregistrujte se a pokračujte",hidePasswordText:"Skrýt heslo","no-password":"Heslo je povinné",pageTitle:"Registrace | ${clientName}","password-policy-not-met":"Heslo nesplňuje požadavky","password-too-weak":"Heslo je příliš slabé",passwordPlaceholder:"Heslo",showPasswordText:"Zobrazit heslo",title:"Vytvořte své heslo"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Pokračovat",codeLabel:"Ověřovací kód",codePlaceholder:"Zadejte kód",defaultDescription:"Zadejte ověřovací kód zaslaný na váš telefon",description:"Odeslali jsme kód na ${username}","invalid-code":"Neplatný kód",noCode:"Zadejte prosím ověřovací kód",pageTitle:"Zadejte kód | ${clientName}",resendText:"Opětovné odeslání kódu",sessionExpired:"Platnost vaší relace vypršela. Zkuste to prosím znovu.",title:"Zkontrolujte svůj telefon",unexpectedError:"Došlo k neočekávané chybě"}},status:NT},wF=Object.freeze(Object.defineProperty({__proto__:null,common:ET,consent:xT,default:_F,invitation:CT,login:TT,mfa:$T,organizations:zT,passkeys:IT,signup:PT,status:NT},Symbol.toStringTag,{value:"Module"})),jT={common:{alertListTitle:"Advarsler",backText:"Gå tilbage",cancelText:"Gå tilbage",closeText:"Luk",contactSupportText:"Har du brug for hjælp?",continueText:"Fortsæt",copyrightText:"© ${currentYear} ${companyName}",errorText:"Noget gik galt. Prøv venligst igen.",hidePasswordText:"Skjul adgangskode",loadingText:"Indlæser...",orText:"eller",privacyPolicyText:"Privatlivspolitik",showPasswordText:"Vis adgangskode",termsOfServiceText:"Servicevilkår",termsShortText:"Vilkår",tryAgainText:"Prøv igen"}},OT={consent:{buttonText:"Acceptér",cancelButtonText:"Afvis",description:"${clientName} anmoder om adgang til din konto",pageTitle:"Godkend | ${clientName}",scopesTitle:"Dette vil give ${clientName} tilladelse til at:",title:"Godkend ${clientName}"}},FT={invitation:{acceptButtonText:"Acceptér invitation",description:"${inviterName} har inviteret dig til at deltage i ${organizationName} på ${clientName}",pageTitle:"Invitation | ${clientName}",title:"Du er blevet inviteret"}},RT={login:{alertListTitle:"Advarsler",buttonText:"Fortsæt",description:"Log ind på ${clientName}.",editEmailText:"Rediger",emailPlaceholder:"E-mail-adresse",enterACodeBtn:"Log ind med en kode",federatedConnectionButtonText:"Fortsæt med ${connectionName}",footerLinkText:"Tilmeld dig",footerText:"Har du ikke en konto?",forgotPasswordText:"Har du glemt din adgangskode?",hidePasswordText:"Skjul adgangskode",invalidEmail:"Ugyldig e-mail",invalidIdentifier:"Ugyldig e-mail eller brugernavn",invitationDescription:"Log ind for at acceptere ${inviterName}s invitation til at deltage i ${companyName} på ${clientName}.",invitationTitle:"Du er blevet inviteret!",logoAltText:"${companyName}","no-email":"Indtast venligst en e-mailadresse","no-password":"Adgangskode er påkrævet",pageTitle:"Log ind | ${clientName}",passwordLoginNotAvailable:"Adgangskodegodkendelse er ikke tilgængelig",passwordPlaceholder:"Adgangskode",phonePlaceholder:"Telefonnummer",separatorText:"eller",sessionExpired:"Din session er udløbet. Prøv venligst igen.",showPasswordText:"Vis adgangskode",signupActionLinkText:"Tilmeld dig",signupActionText:"Har du ikke en konto?",title:"Velkommen",tooManyFailedLogins:"For mange mislykkede loginforsøg. Prøv venligst igen senere.",unverifiedEmail:"Bekræft venligst din e-mailadresse, før du logger ind",userAccountDoesNotExist:"Brugerkontoen findes ikke",usernamePlaceholder:"Brugernavn eller e-mailadresse",usernameTooLong:"Brugernavnet må højst være ${max} tegn",usernameTooShort:"Brugernavnet skal være mindst ${min} tegn",wrongCredentials:"Forkert brugernavn eller adgangskode",passkeyButtonText:"Log ind med passkey"}},DT={mfa:{backupCodeText:"Brug backupkode",description:"Vælg en bekræftelsesmetode",pageTitle:"Multifaktorgodkendelse | ${clientName}",title:"Bekræft din identitet"}},BT={"passkey-enrollment-nudge":{title:"Sikr din konto med en adgangsnøgle",description:"Adgangsnøgler bruger din enheds biometri eller PIN til at logge dig ind hurtigere og mere sikkert.",enrollButtonText:"Konfigurer adgangsnøgle",snoozeButtonText:"Måske senere",optOutLinkText:"Vis ikke dette igen",pageTitle:"Konfigurer Adgangsnøgle | ${clientName}"},"passkey-enrollment":{title:"Opret din adgangsnøgle",description:"Følg anvisningerne fra din browser for at oprette en adgangsnøgle til denne konto.",errorMessage:"Oprettelse af adgangsnøgle mislykkedes. Prøv venligst igen.",cancelLinkText:"Spring over for nu",retryButtonText:"Prøv igen",enrollmentComplete:"Din adgangsnøgle er konfigureret. Du kan lukke denne side.",pageTitle:"Opret Adgangsnøgle | ${clientName}"},"passkey-challenge":{title:"Log ind med passkey",description:"Følg anvisningerne fra din browser for at bekræfte din identitet.",errorMessage:"Godkendelse med passkey mislykkedes. Prøv venligst igen.",cancelLinkText:"Tilbage til login",retryButtonText:"Prøv igen",pageTitle:"Log ind med passkey | ${clientName}"}},LT={organizations:{description:"Vælg hvilken organisation du vil logge ind på",pageTitle:"Vælg organisation | ${clientName}",searchPlaceholder:"Søg organisationer",title:"Vælg din organisation"}},MT={signup:{buttonText:"Tilmelding",confirmPasswordPlaceholder:"Bekræft adgangskode",description:"Vælg en adgangskode med en blanding af store og små bogstaver, tal og symboler.","email-already-exists":"E-mailen er allerede optaget",emailPlaceholder:"E-mail-adresse",federatedConnectionButtonText:"Fortsæt med ${connectionName}",hidePasswordText:"Skjul adgangskode","invalid-email-format":"Ugyldig e-mail",loginActionLinkText:"Log ind",loginActionText:"Har du allerede en konto?","no-email":"Indtast venligst en e-mailadresse","no-password":"Adgangskode er påkrævet","no-username":"Brugernavn er påkrævet",pageTitle:"Tilmeld dig | ${clientName}",passwordPlaceholder:"Adgangskode",passwordsDidntMatch:"Adgangskoderne matcher ikke",phonePlaceholder:"Telefonnummer",privacyPolicyLinkText:"Privatlivspolitik",separatorText:"eller",sessionExpired:"Din session er udløbet. Prøv venligst igen.",showPasswordText:"Vis adgangskode",termsOfServiceLinkText:"Servicevilkår",termsText:"Ved at tilmelde dig accepterer du vores",title:"Vælg adgangskode","username-already-exists":"Dette brugernavn er allerede taget",usernamePlaceholder:"Brugernavn",verifyEmailText:"Tjek venligst din e-mail for at bekræfte din konto"}},UT={status:{continueButtonText:"Fortsæt",errorTitle:"Fejl",pageTitle:"Status | ${clientName}",successTitle:"Succes",title:"Status"}},bF={common:jT,consent:OT,"device-flow":{"device-flow":{buttonText:"Fortsæt",codePlaceholder:"Indtast kode",description:"Indtast koden, der vises på din enhed","expired-code":"Koden er udløbet","invalid-code":"Den indtastede kode er ugyldig",pageTitle:"Enhedsaktivering | ${clientName}",title:"Aktivér din enhed"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Log ind",codeLabel:"Bekræftelseskode",codePlaceholder:"Indtast kode",defaultDescription:"Indtast bekræftelseskoden, der blev sendt til din e-mail",description:"Vi sendte en kode til ${email}","invalid-code":"Ugyldig kode",noCode:"Indtast venligst bekræftelseskoden",pageTitle:"Indtast kode | ${clientName}",resendText:"Send koden igen",sessionExpired:"Din session er udløbet. Prøv venligst igen.",title:"Tjek din e-mail",unexpectedError:"Der opstod en uventet fejl"}},"email-verification":{"email-verification":{description:"Vi sendte en e-mail til ${email}",pageTitle:"Bekræft e-mail | ${clientName}",resendText:"Send koden igen",successDescription:"Din e-mail er blevet bekræftet.",successTitle:"E-mail bekræftet",title:"Bekræft din e-mail"}},invitation:FT,login:RT,"login-id":{"login-id":{alertListTitle:"Advarsler","auth0-users-validation":"Noget gik galt, prøv venligst igen senere","authentication-failure":"Vi beklager, noget gik galt under loginforsøget",buttonText:"Fortsæt","captcha-client-failure":"Vi kunne ikke indlæse sikkerhedsudfordringen. Prøv venligst igen. (Fejlkode: #{errorCode})","captcha-validation-failure":"Vi beklager, noget gik galt under validering af captcha-svaret. Prøv venligst igen.",captchaCodePlaceholder:"Indtast koden vist ovenfor","custom-script-error-code":"Noget gik galt, prøv venligst igen senere.",description:"Log ind på ${clientName}.",editEmailText:"Rediger",emailPlaceholder:"E-mail-adresse",federatedConnectionButtonText:"Fortsæt med ${connectionName}",footerLinkText:"Tilmeld dig",footerText:"Har du ikke en konto?",forgotPasswordText:"Har du glemt din adgangskode?",hidePasswordText:"Skjul adgangskode","invalid-captcha":"Løs sikkerhedsspørgsmålet for at bekræfte, at du ikke er en robot.","invalid-code":"Ugyldig kode","invalid-connection":"Ugyldig forbindelse","invalid-email-format":"Ugyldig e-mail","invalid-email-phone":"Indtast en gyldig e-mailadresse eller telefonnummer. Telefonnumre skal inkludere landekoden.","invalid-email-phone-username":"Indtast en gyldig e-mailadresse, telefonnummer eller brugernavn. Telefonnumre skal inkludere landekoden.","invalid-email-username":"Indtast en gyldig e-mailadresse eller brugernavn","invalid-expired-code":"Ugyldig eller udløbet brugerkode","invalid-login-id":"Ugyldigt login-ID indtastet","invalid-phone-username":"Indtast et gyldigt telefonnummer eller brugernavn. Telefonnumre skal inkludere landekoden.","invalid-recaptcha":"Markér afkrydsningsfeltet for at bekræfte, at du ikke er en robot.","invalid-username":"Brugernavnet kan kun indeholde alfanumeriske tegn eller: '${characters}'. Brugernavnet skal være mellem ${min} og ${max} tegn.",invitationDescription:"Log ind for at acceptere ${inviterName}s invitation til at deltage i ${companyName} på ${clientName}.",invitationTitle:"Du er blevet inviteret!","ip-blocked":"Vi har registreret mistænkelig loginadfærd, og yderligere forsøg vil blive blokeret. Kontakt venligst administratoren.",logoAltText:"${companyName}","no-db-connection":"Ugyldig forbindelse","no-email":"Indtast venligst en e-mailadresse","no-email-phone":"E-mailadresse eller telefonnummer er påkrævet","no-email-phone-username":"Telefonnummer, brugernavn eller e-mailadresse er påkrævet","no-email-username":"E-mailadresse eller brugernavn er påkrævet","no-password":"Adgangskode er påkrævet","no-phone":"Indtast venligst et telefonnummer","no-phone-username":"Telefonnummer eller brugernavn er påkrævet","no-username":"Brugernavn er påkrævet",pageTitle:"Log ind | ${clientName}","password-breached":"Vi har registreret et potentielt sikkerhedsproblem med denne konto. For at beskytte din konto har vi forhindret dette login. Nulstil venligst din adgangskode for at fortsætte.",passwordPlaceholder:"Adgangskode",phoneOrEmailPlaceholder:"E-mail eller telefonnummer",phoneOrUsernameOrEmailPlaceholder:"Telefon, brugernavn eller e-mail",phoneOrUsernamePlaceholder:"Telefonnummer eller brugernavn",phonePlaceholder:"Telefonnummer","same-user-login":"For mange loginforsøg for denne bruger. Vent venligst, og prøv igen senere.",selectCountryCode:"Vælg landekode, i øjeblikket sat til ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"eller",sessionExpired:"Din session er udløbet. Prøv venligst igen.",showPasswordText:"Vis adgangskode",signupActionLinkText:"Tilmeld dig",signupActionText:"Har du ikke en konto?",termsAndConditionsTemplate:'Ved at fortsætte accepterer du vores <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Vilkår og betingelser</a>.',title:"Velkommen","user-blocked":"Din konto er blevet blokeret efter flere på hinanden følgende loginforsøg.",userAccountDoesNotExist:"Brugerkontoen findes ikke",usernameOnlyPlaceholder:"Brugernavn",usernameOrEmailPlaceholder:"Brugernavn eller e-mailadresse",usernamePlaceholder:"Brugernavn",usernameTooLong:"Brugernavnet må højst være ${max} tegn",usernameTooShort:"Brugernavnet skal være mindst ${min} tegn","wrong-credentials":"Forkert brugernavn eller adgangskode","wrong-email-credentials":"Forkert e-mail eller adgangskode","wrong-email-phone-credentials":"Forkert e-mailadresse, telefonnummer eller adgangskode. Telefonnumre skal inkludere landekoden.","wrong-email-phone-username-credentials":"Forkert e-mailadresse, telefonnummer, brugernavn eller adgangskode. Telefonnumre skal inkludere landekoden.","wrong-email-username-credentials":"Forkert e-mailadresse, brugernavn eller adgangskode","wrong-phone-credentials":"Forkert telefonnummer eller adgangskode","wrong-phone-username-credentials":"Forkert telefonnummer, brugernavn eller adgangskode. Telefonnumre skal inkludere landekoden.","wrong-username-credentials":"Forkert brugernavn eller adgangskode",passkeyButtonText:"Log ind med passkey"}},"login-password":{"login-password":{buttonText:"Log ind",description:"Indtast din e-mailadresse og adgangskode for at logge ind.",forgotPasswordText:"Har du glemt din adgangskode?",hidePasswordText:"Skjul adgangskode","no-password":"Adgangskode er påkrævet",pageTitle:"Log ind | ${clientName}","password-breached":"Vi har registreret et potentielt sikkerhedsproblem med denne konto. For at beskytte din konto har vi forhindret dette login. Nulstil venligst din adgangskode for at fortsætte.",passwordPlaceholder:"Adgangskode",showPasswordText:"Vis adgangskode",signingInAs:"Logger ind som ${email}",title:"Indtast adgangskode",unverifiedEmail:"Bekræft venligst din e-mailadresse, før du logger ind","user-blocked":"Din konto er blevet blokeret efter flere på hinanden følgende loginforsøg.","wrong-credentials":"Forkert adgangskode"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-mail",authMethodEmailOrPhone:"e-mail eller telefonnummer",authMethodPhone:"telefonnummer",description:"Log ind med din ${authMethod}",emailOrPhonePlaceholder:"E-mailadresse eller telefonnummer",emailPlaceholder:"E-mail-adresse",invalidEmail:"Indtast venligst en gyldig e-mailadresse",invalidIdentifier:"Indtast venligst en gyldig e-mailadresse eller telefonnummer",invalidPhone:"Indtast venligst et gyldigt telefonnummer med landekode",noEmail:"Indtast venligst din e-mailadresse",noPhone:"Indtast venligst dit telefonnummer",phonePlaceholder:"Telefonnummer",sessionExpired:"Din session er udløbet. Prøv venligst igen.",title:"Log ind med en kode",userAccountDoesNotExist:"Brugerkontoen findes ikke"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Klik på linket i din e-mail for at logge ind",description:"Vi sendte et link til ${username}. Klik på det for at logge ind.",resendText:"Send link igen",spamText:"Har du ikke modtaget e-mailen? Tjek din spam-mappe.",title:"Tjek din e-mail"}},mfa:DT,"mfa-email":{"mfa-email":{buttonText:"Fortsæt",codePlaceholder:"Indtast kode",description:"Vi sendte en kode til ${email}","invalid-code":"Den indtastede kode er ugyldig",pageTitle:"E-mailbekræftelse | ${clientName}",resendText:"Send kode igen",title:"Tjek din e-mail"}},"mfa-otp":{"mfa-otp":{buttonText:"Fortsæt",codePlaceholder:"Indtast kode",description:"Indtast den 6-cifrede kode fra din autentificeringsapp","invalid-code":"Den indtastede kode er ugyldig",pageTitle:"Indtast kode | ${clientName}",title:"Indtast din kode"},"mfa-totp-enrollment":{title:"Opsæt autentificeringsapp",description:"Scan QR-koden nedenfor med din autentificeringsapp, og indtast derefter den 6-cifrede kode for at bekræfte",secretLabel:"Eller indtast denne kode manuelt:",codePlaceholder:"Indtast kode",continueButtonText:"Bekræft og aktiver","invalid-code":"Den indtastede kode er ugyldig. Prøv venligst igen.","transaction-not-found":"Din tilmeldingssession er udløbet. Du skal starte forfra.",pageTitle:"Opsæt autentificeringsapp | ${clientName}",unexpectedError:"Noget gik galt. Prøv venligst igen.",enrollmentComplete:"MFA-tilmeldingen er fuldført. Du kan lukke denne side."},"mfa-totp-challenge":{title:"Bekræft din identitet",description:"Indtast den 6-cifrede kode fra din autentificeringsapp",codePlaceholder:"Indtast kode",continueButtonText:"Fortsæt","invalid-code":"Den indtastede kode er ugyldig","transaction-not-found":"Din session er udløbet. Du skal starte forfra.",unexpectedError:"Noget gik galt. Prøv venligst igen.",pageTitle:"Bekræft identitet | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Brug dit telefonnummer til at logge ind | ${clientName}",title:"Bekræft din identitet",description:"Vi sendte en kode til ${phoneNumber}",continueButtonText:"Fortsæt",changePhoneText:"Vælg et andet telefonnummer.",smsButtonText:"SMS",voiceButtonText:"Taleopkald",chooseMessageTypeText:"Hvordan vil du modtage koden?",pickAuthenticatorText:"Prøv en anden metode",logoAltText:"${companyName}",codePlaceholder:"Indtast kode","send-sms-failed":"Der opstod et problem med at sende SMS'en","send-voice-failed":"Der opstod et problem med at foretage taleopkaldet","invalid-phone-format":"Telefonnummeret kan kun indeholde cifre.","invalid-phone":"Det ser ud til, at dit telefonnummer ikke er gyldigt. Kontrollér og prøv igen.","too-many-sms":"Du har overskredet det maksimale antal telefonbeskeder pr. time. Vent et par minutter og prøv igen.","too-many-voice":"Du har overskredet det maksimale antal telefonopkald pr. time. Vent et par minutter og prøv igen.","transaction-not-found":"Din registreringstransaktion er udløbet, du skal starte forfra.","no-phone":"Indtast et telefonnummer",noCode:"Indtast bekræftelseskoden",invalidCode:"Den indtastede kode er ugyldig. Prøv igen.",unexpectedError:"Noget gik galt. Prøv igen.",resendSuccess:"Vi sendte en ny kode til din telefon",enrollmentComplete:"MFA-tilmeldingen er fuldført. Du kan lukke denne side."},"mfa-phone-enrollment":{pageTitle:"Indtast dit telefonnummer for at logge ind med en telefonkode | ${clientName}",title:"Sikre din konto",description:"Indtast din landekode og telefonnummer, som vi kan sende en 6-cifret kode til:",continueButtonText:"Fortsæt",smsButtonText:"SMS",voiceButtonText:"Taleopkald",chooseMessageTypeText:"Hvordan vil du modtage koden?",pickAuthenticatorText:"Prøv en anden metode",placeholder:"Indtast dit telefonnummer",logoAltText:"${companyName}",selectCountryCode:"Vælg landekode, i øjeblikket sat til ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Der opstod et problem med at sende SMS'en","send-voice-failed":"Der opstod et problem med at foretage taleopkaldet","sms-authenticator-error":"Vi kunne ikke sende SMS'en. Prøv igen senere.","invalid-phone-format":"Telefonnummeret kan kun indeholde cifre.","invalid-phone":"Det ser ud til, at dit telefonnummer ikke er gyldigt. Kontrollér og prøv igen.","too-many-sms":"Du har overskredet det maksimale antal telefonbeskeder pr. time. Vent et par minutter og prøv igen.","too-many-voice":"Du har overskredet det maksimale antal telefonopkald pr. time. Vent et par minutter og prøv igen.","transaction-not-found":"Din registreringstransaktion er udløbet, du skal starte forfra.","no-phone":"Indtast et telefonnummer","phone-is-too-short":"Telefonnummeret er for kort","phone-is-too-long":"Telefonnummeret er for langt"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Vælg bekræftelsesmetode | ${clientName}",title:"Vælg din bekræftelsesmetode",description:"Vælg hvordan du vil bekræfte din identitet",authenticatorAppLabel:"Godkendelsesapp",authenticatorAppDescription:"Brug din godkendelsesapp til at få en bekræftelseskode",smsLabel:"Sms-besked",smsDescription:"Få en bekræftelseskode sendt til din telefon",passkeyLabel:"Adgangsnøgle",passkeyDescription:"Brug din enheds biometri eller sikkerhedsnøgle"}},"mfa-push":{"mfa-push":{description:"Vi sendte en notifikation til din enhed",pageTitle:"Push-notifikation | ${clientName}",resendText:"Send notifikation igen",title:"Godkend anmodningen",useCodeText:"Indtast kode manuelt"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Fortsæt",codePlaceholder:"Gendannelseskode",description:"Indtast en af dine gendannelseskoder","invalid-code":"Den indtastede gendannelseskode er ugyldig",pageTitle:"Gendannelseskode | ${clientName}",title:"Indtast gendannelseskode"}},"mfa-voice":{"mfa-voice":{buttonText:"Ring til mig",codePlaceholder:"Indtast kode",description:"Vi ringer til ${phoneNumber} med din kode","invalid-code":"Den indtastede kode er ugyldig",pageTitle:"Taleopkald | ${clientName}",title:"Modtag et telefonopkald"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Prøv igen",description:"Indsæt din sikkerhedsnøgle og følg instruktionerne",pageTitle:"Sikkerhedsnøgle | ${clientName}",title:"Brug din sikkerhedsnøgle"}},passkeys:BT,organizations:LT,"reset-password":{"reset-password":{backToLoginText:"Gå tilbage",buttonText:"Send e-mail til nulstilling af adgangskode",codeExpired:"Din kode til nulstilling af adgangskode er udløbet. Anmod venligst om en ny.",confirmPasswordLabel:"Bekræft adgangskode",confirmPasswordPlaceholder:"Bekræft adgangskode",description:"Klik på knappen nedenfor, så sender vi instruktioner om, hvordan du nulstiller din adgangskode.",emailPlaceholder:"E-mail-adresse",failed:"Nulstilling af adgangskode mislykkedes. Prøv venligst igen.","invalid-email-format":"Ugyldig e-mail","no-email":"Indtast venligst en e-mailadresse",pageTitle:"Nulstil adgangskode | ${clientName}",passwordLabel:"Ny adgangskode",passwordPlaceholder:"Ny adgangskode",passwordTooWeak:"Adgangskoden er for svag",passwordsDidntMatch:"Adgangskoderne matcher ikke",successDescription:"Vi har sendt et link til nulstilling af adgangskode til din e-mailadresse.",successTitle:"E-mail til nulstilling af adgangskode sendt",title:"Har du glemt din adgangskode?","user-not-found":"Bruger ikke fundet"},"reset-password-code":{backToLoginText:"Tilbage til login",buttonText:"Nulstil adgangskode",codeLabel:"Nulstillingskode",codePlaceholder:"Indtast 6-cifret kode",confirmPasswordLabel:"Bekræft adgangskode",confirmPasswordPlaceholder:"Bekræft adgangskode",defaultDescription:"Indtast koden sendt til din e-mail og vælg en ny adgangskode",description:"Vi sendte en kode til ${email}",failed:"Nulstilling af adgangskode mislykkedes. Prøv venligst igen.",invalidCode:"Den indtastede kode er ugyldig eller udløbet",noCode:"Indtast venligst nulstillingskoden",pageTitle:"Indtast nulstillingskode | ${clientName}",passwordLabel:"Ny adgangskode",passwordPlaceholder:"Ny adgangskode",passwordTooWeak:"Adgangskoden er for svag",passwordsDidntMatch:"Adgangskoderne matcher ikke",resendFailed:"Kunne ikke sende koden igen. Prøv igen.",resendSuccess:"En ny kode er blevet sendt til din e-mail",resendText:"Send kode igen",sessionExpired:"Din session er udløbet. Prøv venligst igen.",title:"Indtast nulstillingskode"}},signup:MT,"signup-id":{"signup-id":{buttonText:"Fortsæt",description:"Vælg en adgangskode med en blanding af store og små bogstaver, tal og symboler.","email-already-exists":"E-mailen er allerede optaget",emailPlaceholder:"E-mail-adresse",federatedConnectionButtonText:"Fortsæt med ${connectionName}","invalid-email-format":"Ugyldig e-mail",loginActionLinkText:"Log ind",loginActionText:"Har du allerede en konto?","no-email":"Indtast venligst en e-mailadresse",pageTitle:"Tilmeld dig | ${clientName}",phonePlaceholder:"Telefonnummer",separatorText:"eller",title:"Vælg adgangskode",usernamePlaceholder:"Brugernavn"}},"signup-password":{"signup-password":{buttonText:"Fortsæt",description:"Vælg en adgangskode med en blanding af store og små bogstaver, tal og symboler.",hidePasswordText:"Skjul adgangskode","no-password":"Adgangskode er påkrævet",pageTitle:"Tilmeld dig | ${clientName}","password-policy-not-met":"Adgangskoden opfylder ikke kravene","password-too-weak":"Adgangskoden er for svag",passwordPlaceholder:"Adgangskode",showPasswordText:"Vis adgangskode",title:"Vælg adgangskode"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Log ind",codeLabel:"Bekræftelseskode",codePlaceholder:"Indtast kode",defaultDescription:"Indtast bekræftelseskoden, der blev sendt til din telefon",description:"Vi sendte en kode til ${username}","invalid-code":"Ugyldig kode",noCode:"Indtast venligst bekræftelseskoden",pageTitle:"Indtast kode | ${clientName}",resendText:"Send koden igen",sessionExpired:"Din session er udløbet. Prøv venligst igen.",title:"Tjek din telefon",unexpectedError:"Der opstod en uventet fejl"}},status:UT},vF=Object.freeze(Object.defineProperty({__proto__:null,common:jT,consent:OT,default:bF,invitation:FT,login:RT,mfa:DT,organizations:LT,passkeys:BT,signup:MT,status:UT},Symbol.toStringTag,{value:"Module"})),qT={common:{alertListTitle:"Alerts",backText:"Back",cancelText:"Cancel",closeText:"Close",contactSupportText:"Contact Support",continueText:"Continue",copyrightText:"© ${currentYear} ${companyName}",errorText:"An error occurred",hidePasswordText:"Hide password",loadingText:"Loading...",orText:"or",privacyPolicyText:"Privacy Policy",showPasswordText:"Show password",termsOfServiceText:"Terms of Service",termsShortText:"Terms",tryAgainText:"Try again"}},HT={consent:{buttonText:"Accept",cancelButtonText:"Deny",description:"${clientName} is requesting access to your account",pageTitle:"Authorize | ${clientName}",scopesTitle:"This will allow ${clientName} to:",title:"Authorize ${clientName}"}},VT={invitation:{acceptButtonText:"Accept invitation",description:"${inviterName} has invited you to join ${organizationName} on ${clientName}",pageTitle:"Invitation | ${clientName}",title:"You've been invited"}},KT={login:{alertListTitle:"Alerts",buttonText:"Continue",description:"Log in to ${clientName}.",editEmailText:"Edit",emailPlaceholder:"Email address",enterACodeBtn:"Sign in with a code",federatedConnectionButtonText:"Continue with ${connectionName}",footerLinkText:"Sign up",footerText:"Don't have an account?",forgotPasswordText:"Forgot password?",hidePasswordText:"Hide password",invalidEmail:"Invalid email",invalidIdentifier:"Invalid email or username",invitationDescription:"Log in to accept ${inviterName}'s invitation to join ${companyName} on ${clientName}.",invitationTitle:"You've Been Invited!",logoAltText:"${companyName}","no-email":"Please enter an email address","no-password":"Password is required",pageTitle:"Log in | ${clientName}",passwordLoginNotAvailable:"Password authentication is not available",passwordPlaceholder:"Password",phonePlaceholder:"Phone number",separatorText:"Or",sessionExpired:"Your session has expired. Please try again.",showPasswordText:"Show password",signupActionLinkText:"Sign up",signupActionText:"Don't have an account?",title:"Welcome",tooManyFailedLogins:"Too many failed login attempts. Please try again later.",unverifiedEmail:"Please verify your email address before logging in",userAccountDoesNotExist:"User account does not exist",usernamePlaceholder:"Username or email address",usernameTooLong:"Username must be ${max} characters or less",usernameTooShort:"Username must be at least ${min} characters",passkeyButtonText:"Sign in with a passkey",wrongCredentials:"Wrong username or password"}},GT={mfa:{backupCodeText:"Use backup code",description:"Choose a verification method",pageTitle:"Multi-Factor Authentication | ${clientName}",title:"Verify your identity"}},WT={"passkey-enrollment-nudge":{title:"Secure your account with a passkey",description:"Passkeys use your device's biometrics or PIN to sign you in faster and more securely.",enrollButtonText:"Set up passkey",snoozeButtonText:"Maybe later",optOutLinkText:"Don't show this again",pageTitle:"Set Up Passkey | ${clientName}"},"passkey-enrollment":{title:"Create your passkey",description:"Follow the prompts from your browser to create a passkey for this account.",errorMessage:"Failed to create passkey. Please try again.",cancelLinkText:"Skip for now",retryButtonText:"Try again",enrollmentComplete:"Your passkey has been set up successfully. You can close this page.",pageTitle:"Create Passkey | ${clientName}"},"passkey-challenge":{title:"Sign in with a passkey",description:"Follow the prompts from your browser to verify your identity.",errorMessage:"Passkey authentication failed. Please try again.",cancelLinkText:"Back to login",retryButtonText:"Try again",pageTitle:"Sign In with Passkey | ${clientName}"}},JT={organizations:{description:"Choose which organization to log in to",pageTitle:"Select Organization | ${clientName}",searchPlaceholder:"Search organizations",title:"Select your organization"}},YT={signup:{buttonText:"Continue",confirmPasswordPlaceholder:"Confirm password",description:"Sign up to continue","email-already-exists":"This email is already registered",emailPlaceholder:"Email address",federatedConnectionButtonText:"Continue with ${connectionName}",hidePasswordText:"Hide password","invalid-email-format":"Email is not valid.",loginActionLinkText:"Log in",loginActionText:"Already have an account?","no-email":"Please enter an email address","no-password":"Password is required","no-username":"Username is required",pageTitle:"Sign up | ${clientName}",passwordPlaceholder:"Password",passwordsDidntMatch:"Passwords don't match",phonePlaceholder:"Phone number",privacyPolicyLinkText:"Privacy Policy",separatorText:"Or",sessionExpired:"Your session has expired. Please try again.",showPasswordText:"Show password",termsOfServiceLinkText:"Terms of Service",termsText:"By signing up, you agree to our",title:"Create your account","username-already-exists":"This username is already taken",usernamePlaceholder:"Username",verifyEmailText:"Please check your email to verify your account"}},QT={status:{continueButtonText:"Continue",errorTitle:"Error",pageTitle:"Status | ${clientName}",successTitle:"Success",title:"Status"}},AF={common:qT,consent:HT,"device-flow":{"device-flow":{buttonText:"Continue",codePlaceholder:"Enter code",description:"Enter the code shown on your device","expired-code":"The code has expired","invalid-code":"The code you entered is invalid",pageTitle:"Device Activation | ${clientName}",title:"Activate your device"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Continue",codeLabel:"Verification Code",codePlaceholder:"Enter code",defaultDescription:"Enter the verification code sent to your email",description:"We sent a code to ${email}","invalid-code":"The code you entered is invalid",noCode:"Please enter the verification code",pageTitle:"Enter Code | ${clientName}",resendText:"Resend code",sessionExpired:"Your session has expired. Please try again.",title:"Check your email",unexpectedError:"An unexpected error occurred"}},"email-verification":{"email-verification":{description:"We sent an email to ${email}",pageTitle:"Verify Email | ${clientName}",resendText:"Resend email",successDescription:"Your email has been verified successfully.",successTitle:"Email verified",title:"Verify your email"}},invitation:VT,login:KT,"login-id":{"login-id":{alertListTitle:"Alerts","auth0-users-validation":"Something went wrong, please try again later","authentication-failure":"We are sorry, something went wrong when attempting to log in",buttonText:"Continue","captcha-client-failure":"We couldn't load the security challenge. Please try again. (Error code: #{errorCode})","captcha-validation-failure":"We are sorry, something went wrong while validating the captcha response. Please try again.",captchaCodePlaceholder:"Enter the code shown above","custom-script-error-code":"Something went wrong, please try again later.",description:"Log in to ${clientName}.",editEmailText:"Edit",emailPlaceholder:"Email address",federatedConnectionButtonText:"Continue with ${connectionName}",footerLinkText:"Sign up",footerText:"Don't have an account?",forgotPasswordText:"Forgot password?",hidePasswordText:"Hide password","invalid-captcha":"Solve the challenge question to verify you are not a robot.","invalid-code":"The code you entered is invalid","invalid-connection":"Invalid connection","invalid-email-format":"Email is not valid.","invalid-email-phone":"Enter a valid email address or phone number. Phone numbers must include the country code.","invalid-email-phone-username":"Enter a valid email address, phone number or username. Phone numbers must include the country code.","invalid-email-username":"Enter a valid email address or username","invalid-expired-code":"Invalid or expired user code","invalid-login-id":"Invalid Login ID entered","invalid-phone-username":"Enter a valid phone number or username. Phone numbers must include the country code.","invalid-recaptcha":"Select the checkbox to verify you are not a robot.","invalid-username":"Username can only contain alphanumeric characters or: '${characters}'. Username should have between ${min} and ${max} characters.",invitationDescription:"Log in to accept ${inviterName}'s invitation to join ${companyName} on ${clientName}.",invitationTitle:"You've Been Invited!","ip-blocked":"We have detected suspicious login behavior and further attempts will be blocked. Please contact the administrator.",logoAltText:"${companyName}","no-db-connection":"Invalid connection","no-email":"Please enter an email address","no-email-phone":"Email address or phone number is required","no-email-phone-username":"Phone number, username, or email address is required","no-email-username":"Email address or username is required","no-password":"Password is required","no-phone":"Please enter a phone number","no-phone-username":"Phone number or username is required","no-username":"Username is required",pageTitle:"Log in | ${clientName}","password-breached":"We have detected a potential security issue with this account. To protect your account, we have prevented this login. Please reset your password to proceed.",passwordPlaceholder:"Password",phoneOrEmailPlaceholder:"Phone number or Email address",phoneOrUsernameOrEmailPlaceholder:"Phone or Username or Email",phoneOrUsernamePlaceholder:"Phone Number or Username",phonePlaceholder:"Phone number","same-user-login":"Too many login attempts for this user. Please wait, and try again later.",selectCountryCode:"Select country code, currently set to ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"Or",sessionExpired:"Your session has expired. Please try again.",showPasswordText:"Show password",signupActionLinkText:"Sign up",signupActionText:"Don't have an account?",termsAndConditionsTemplate:'By continuing, you agree to our <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Terms and Conditions</a>.',title:"Welcome","user-blocked":"Your account has been blocked after multiple consecutive login attempts.",userAccountDoesNotExist:"User account does not exist",usernameOnlyPlaceholder:"Username",usernameOrEmailPlaceholder:"Username or Email address",usernamePlaceholder:"Username or email address",usernameTooLong:"Username must be ${max} characters or less",usernameTooShort:"Username must be at least ${min} characters","wrong-credentials":"Wrong username or password","wrong-email-credentials":"Wrong email or password","wrong-email-phone-credentials":"Incorrect email address, phone number, or password. Phone numbers must include the country code.","wrong-email-phone-username-credentials":"Incorrect email address, phone number, username, or password. Phone numbers must include the country code.","wrong-email-username-credentials":"Incorrect email address, username, or password","wrong-phone-credentials":"Incorrect phone number or password","wrong-phone-username-credentials":"Incorrect phone number, username or password. Phone numbers must include the country code.",passkeyButtonText:"Sign in with a passkey","wrong-username-credentials":"Incorrect username or password"}},"login-password":{"login-password":{buttonText:"Continue",description:"Log in to ${clientName}",forgotPasswordText:"Forgot password?",hidePasswordText:"Hide password","no-password":"Password is required",pageTitle:"Log in | ${clientName}","password-breached":"We have detected a potential security issue with this account. To protect your account, we have prevented this login. Please reset your password to proceed.",passwordPlaceholder:"Password",showPasswordText:"Show password",signingInAs:"Signing in as ${email}",title:"Enter your password",unverifiedEmail:"Please verify your email address before logging in","user-blocked":"Your account has been blocked after multiple consecutive login attempts.","wrong-credentials":"Wrong password"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"email",authMethodEmailOrPhone:"email or phone number",authMethodPhone:"phone number",description:"Sign in using your ${authMethod}",emailOrPhonePlaceholder:"Email address or phone number",emailPlaceholder:"Email address",invalidEmail:"Please enter a valid email address",invalidIdentifier:"Please enter a valid email address or phone number",invalidPhone:"Please enter a valid phone number with country code",noEmail:"Please enter your email address",noPhone:"Please enter your phone number",phonePlaceholder:"Phone number",sessionExpired:"Your session has expired. Please try again.",title:"Sign in with a code",userAccountDoesNotExist:"User account does not exist"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Click the link in your email to sign in",description:"We sent a link to ${username}. Click it to sign in.",resendText:"Resend link",spamText:"Didn't receive the email? Check your spam folder.",title:"Check your email"}},mfa:GT,"mfa-email":{"mfa-email":{buttonText:"Continue",codePlaceholder:"Enter code",description:"We sent a code to ${email}","invalid-code":"The code you entered is invalid",pageTitle:"Email Verification | ${clientName}",resendText:"Resend code",title:"Check your email"}},"mfa-otp":{"mfa-otp":{buttonText:"Continue",codePlaceholder:"Enter code",description:"Enter the 6-digit code from your authenticator app","invalid-code":"The code you entered is invalid",pageTitle:"Enter Code | ${clientName}",title:"Enter your code"},"mfa-totp-enrollment":{title:"Set up authenticator",description:"Scan the QR code below with your authenticator app, then enter the 6-digit code to verify",secretLabel:"Or enter this code manually:",codePlaceholder:"Enter code",continueButtonText:"Verify & Activate","invalid-code":"The code you entered is invalid. Please try again.","transaction-not-found":"Your enrollment transaction expired, you will need to start again.",unexpectedError:"Something went wrong. Please try again.",pageTitle:"Set up Authenticator | ${clientName}",enrollmentComplete:"MFA enrollment is complete. You can close this page."},"mfa-totp-challenge":{title:"Verify your identity",description:"Enter the 6-digit code from your authenticator app",codePlaceholder:"Enter code",continueButtonText:"Continue","invalid-code":"The code you entered is invalid","transaction-not-found":"Your enrollment transaction expired, you will need to start again.",unexpectedError:"Something went wrong. Please try again.",pageTitle:"Verify Identity | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Use your phone number to log in | ${clientName}",title:"Verify Your Identity",description:"We sent a code to ${phoneNumber}",continueButtonText:"Continue",changePhoneText:"Choose another phone number.",smsButtonText:"Text message",voiceButtonText:"Voice call",chooseMessageTypeText:"How do you want to receive the code?",pickAuthenticatorText:"Try another method",logoAltText:"${companyName}",codePlaceholder:"Enter code","send-sms-failed":"There was a problem sending the SMS","send-voice-failed":"There was a problem making the voice call","invalid-phone-format":"Phone number can only include digits.","invalid-phone":"It seems that your phone number is not valid. Please check and retry.","too-many-sms":"You have exceeded the maximum number of phone messages per hour. Wait a few minutes and try again.","too-many-voice":"You have exceeded the maximum number of phone messages per hour. Wait a few minutes and try again.","transaction-not-found":"Your enrollment transaction expired, you will need to start again.","no-phone":"Please enter a phone number",noCode:"Please enter the verification code",invalidCode:"The code you entered is invalid. Please try again.",unexpectedError:"Something went wrong. Please try again.",resendSuccess:"We sent a new code to your phone",enrollmentComplete:"MFA enrollment is complete. You can close this page."},"mfa-phone-enrollment":{pageTitle:"Enter your phone number to log in using a phone code | ${clientName}",title:"Secure Your Account",description:"Enter your country code and phone number to which we can send a 6-digit code:",continueButtonText:"Continue",smsButtonText:"Text message",voiceButtonText:"Voice call",chooseMessageTypeText:"How do you want to receive the code?",pickAuthenticatorText:"Try another method",placeholder:"Enter your phone number",logoAltText:"${companyName}",selectCountryCode:"Select country code, currently set to ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"There was a problem sending the SMS","send-voice-failed":"There was a problem making the voice call","sms-authenticator-error":"We couldn't send the SMS. Please try again later.","invalid-phone-format":"Phone number can only include digits.","invalid-phone":"It seems that your phone number is not valid. Please check and retry.","too-many-sms":"You have exceeded the maximum number of phone messages per hour. Wait a few minutes and try again.","too-many-voice":"You have exceeded the maximum number of phone messages per hour. Wait a few minutes and try again.","transaction-not-found":"Your enrollment transaction expired, you will need to start again.","no-phone":"Please enter a phone number","phone-is-too-short":"Phone number is too short","phone-is-too-long":"Phone number is too long"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Choose Verification Method | ${clientName}",title:"Choose your verification method",description:"Select how you'd like to verify your identity",authenticatorAppLabel:"Authenticator App",authenticatorAppDescription:"Use your authenticator app to get a verification code",smsLabel:"Text Message",smsDescription:"Get a verification code sent to your phone",passkeyLabel:"Passkey",passkeyDescription:"Use your device's biometrics or security key"}},"mfa-push":{"mfa-push":{description:"We sent a notification to your device",pageTitle:"Push Notification | ${clientName}",resendText:"Resend notification",title:"Approve the request",useCodeText:"Enter code manually"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Continue",codePlaceholder:"Recovery code",description:"Enter one of your recovery codes","invalid-code":"The recovery code you entered is invalid",pageTitle:"Recovery Code | ${clientName}",title:"Enter recovery code"}},"mfa-voice":{"mfa-voice":{buttonText:"Call me",codePlaceholder:"Enter code",description:"We will call ${phoneNumber} with your code","invalid-code":"The code you entered is invalid",pageTitle:"Voice Call | ${clientName}",title:"Receive a phone call"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Try again",description:"Insert your security key and follow the instructions",pageTitle:"Security Key | ${clientName}",title:"Use your security key"}},passkeys:WT,organizations:JT,"reset-password":{"reset-password":{backToLoginText:"Back to login",buttonText:"Continue",codeExpired:"Your password reset code has expired. Please request a new one.",confirmPasswordLabel:"Confirm Password",confirmPasswordPlaceholder:"Confirm password",description:"Enter your email to reset your password",emailPlaceholder:"Email address",failed:"Password reset failed. Please try again.","invalid-email-format":"Email is not valid.","no-email":"Please enter an email address",pageTitle:"Reset Password | ${clientName}",passwordLabel:"New Password",passwordPlaceholder:"New password",passwordTooWeak:"Password is too weak",passwordsDidntMatch:"Passwords don't match",successDescription:"We have sent a password reset link to your email address.",successTitle:"Check your email",title:"Forgot your password?","user-not-found":"User not found"},"reset-password-code":{backToLoginText:"Back to login",buttonText:"Reset Password",codeLabel:"Reset Code",codePlaceholder:"Enter 6-digit code",confirmPasswordLabel:"Confirm Password",confirmPasswordPlaceholder:"Confirm password",defaultDescription:"Enter the code sent to your email and choose a new password",description:"We sent a code to ${email}",failed:"Password reset failed. Please try again.",invalidCode:"The code you entered is invalid or has expired",noCode:"Please enter the reset code",pageTitle:"Enter Reset Code | ${clientName}",passwordLabel:"New Password",passwordPlaceholder:"New password",passwordTooWeak:"Password is too weak",passwordsDidntMatch:"Passwords don't match",resendFailed:"Failed to resend the code. Please try again.",resendSuccess:"A new code has been sent to your email",resendText:"Resend code",sessionExpired:"Your session has expired. Please try again.",title:"Enter reset code"}},signup:YT,"signup-id":{"signup-id":{buttonText:"Continue",description:"Sign up to continue","email-already-exists":"This email is already registered",emailPlaceholder:"Email address",federatedConnectionButtonText:"Continue with ${connectionName}","invalid-email-format":"Email is not valid.",loginActionLinkText:"Log in",loginActionText:"Already have an account?","no-email":"Please enter an email address",pageTitle:"Sign up | ${clientName}",phonePlaceholder:"Phone number",separatorText:"Or",title:"Create your account",usernamePlaceholder:"Username"}},"signup-password":{"signup-password":{buttonText:"Continue",description:"Sign up to continue",hidePasswordText:"Hide password","no-password":"Password is required",pageTitle:"Sign up | ${clientName}","password-policy-not-met":"Password does not meet the requirements","password-too-weak":"Password is too weak",passwordPlaceholder:"Password",showPasswordText:"Show password",title:"Create your password"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Continue",codeLabel:"Verification Code",codePlaceholder:"Enter code",defaultDescription:"Enter the verification code sent to your phone",description:"We sent a code to ${username}","invalid-code":"The code you entered is invalid",noCode:"Please enter the verification code",pageTitle:"Enter Code | ${clientName}",resendText:"Resend code",sessionExpired:"Your session has expired. Please try again.",title:"Check your phone",unexpectedError:"An unexpected error occurred"}},status:QT},kF=Object.freeze(Object.defineProperty({__proto__:null,common:qT,consent:HT,default:AF,invitation:VT,login:KT,mfa:GT,organizations:JT,passkeys:WT,signup:YT,status:QT},Symbol.toStringTag,{value:"Module"})),ZT={common:{alertListTitle:"Ilmoitukset",backText:"Palaa takaisin",cancelText:"Palaa takaisin",closeText:"Sulje",contactSupportText:"Tarvitsetko apua?",continueText:"Jatka",copyrightText:"© ${currentYear} ${companyName}",errorText:"Jokin meni pieleen. Yritä uudelleen.",hidePasswordText:"Piilota salasana",loadingText:"Ladataan...",orText:"tai",privacyPolicyText:"Tietosuojakäytäntö",showPasswordText:"Näytä salasana",termsOfServiceText:"Käyttöehdot",termsShortText:"Ehdot",tryAgainText:"Yritä uudelleen"}},XT={consent:{buttonText:"Hyväksy",cancelButtonText:"Hylkää",description:"${clientName} pyytää pääsyä tilillesi",pageTitle:"Valtuuta | ${clientName}",scopesTitle:"Tämä sallii sovelluksen ${clientName}:",title:"Valtuuta ${clientName}"}},e$={invitation:{acceptButtonText:"Hyväksy kutsu",description:"${inviterName} on kutsunut sinut liittymään organisaatioon ${organizationName} palvelussa ${clientName}",pageTitle:"Kutsu | ${clientName}",title:"Sinut on kutsuttu"}},t$={login:{alertListTitle:"Ilmoitukset",buttonText:"Jatka",description:"Kirjaudu sisään ${clientName}.",editEmailText:"Muokkaa",emailPlaceholder:"Sähköpostiosoite",enterACodeBtn:"Kirjaudu koodilla",federatedConnectionButtonText:"Jatka palvelulla ${connectionName}",footerLinkText:"Rekisteröidy",footerText:"Eikö sinulla ole tiliä?",forgotPasswordText:"Unohditko salasanan?",hidePasswordText:"Piilota salasana",invalidEmail:"Virheellinen sähköpostiosoite",invalidIdentifier:"Virheellinen sähköpostiosoite tai käyttäjänimi",invitationDescription:"Kirjaudu sisään hyväksyäksesi käyttäjän ${inviterName} kutsun liittyä palveluun ${companyName} sovelluksessa ${clientName}.",invitationTitle:"Sinut on kutsuttu!",logoAltText:"${companyName}","no-email":"Sähköpostiosoite vaaditaan","no-password":"Salasana vaaditaan",pageTitle:"Kirjaudu sisään | ${clientName}",passwordLoginNotAvailable:"Salasanakirjautuminen ei ole käytettävissä",passwordPlaceholder:"Salasana",phonePlaceholder:"Puhelinnumero",separatorText:"tai",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",showPasswordText:"Näytä salasana",signupActionLinkText:"Rekisteröidy",signupActionText:"Eikö sinulla ole tiliä?",title:"Tervetuloa",tooManyFailedLogins:"Liian monta epäonnistunutta kirjautumisyritystä. Yritä myöhemmin uudelleen.",unverifiedEmail:"Vahvista sähköpostiosoitteesi ennen kirjautumista",userAccountDoesNotExist:"Käyttäjätiliä ei ole olemassa",usernamePlaceholder:"Käyttäjänimi tai sähköpostiosoite",usernameTooLong:"Käyttäjänimen on oltava enintään ${max} merkkiä",usernameTooShort:"Käyttäjänimen on oltava vähintään ${min} merkkiä",wrongCredentials:"Väärä käyttäjänimi tai salasana",passkeyButtonText:"Kirjaudu sisään passkey:llä"}},n$={mfa:{backupCodeText:"Käytä varakoodia",description:"Valitse vahvistusmenetelmä",pageTitle:"Monivaiheinen tunnistautuminen | ${clientName}",title:"Vahvista henkilöllisyytesi"}},i$={"passkey-enrollment-nudge":{title:"Suojaa tilisi tunnistautumisavaimella",description:"Tunnistautumisavaimet käyttävät laitteesi biometriikkaa tai PIN-koodia kirjautuaksesi nopeammin ja turvallisemmin.",enrollButtonText:"Määritä tunnistautumisavain",snoozeButtonText:"Ehkä myöhemmin",optOutLinkText:"Älä näytä tätä uudelleen",pageTitle:"Määritä Tunnistautumisavain | ${clientName}"},"passkey-enrollment":{title:"Luo tunnistautumisavain",description:"Seuraa selaimesi ohjeita luodaksesi tunnistautumisavaimen tälle tilille.",errorMessage:"Tunnistautumisavaimen luominen epäonnistui. Yritä uudelleen.",cancelLinkText:"Ohita toistaiseksi",retryButtonText:"Yritä uudelleen",enrollmentComplete:"Tunnistautumisavaimesi on määritetty onnistuneesti. Voit sulkea tämän sivun.",pageTitle:"Luo Tunnistautumisavain | ${clientName}"},"passkey-challenge":{title:"Kirjaudu sisään passkey:llä",description:"Noudata selaimesi ohjeita henkilöllisyytesi vahvistamiseksi.",errorMessage:"Passkey-todennus epäonnistui. Yritä uudelleen.",cancelLinkText:"Takaisin kirjautumiseen",retryButtonText:"Yritä uudelleen",pageTitle:"Kirjaudu sisään passkey:llä | ${clientName}"}},r$={organizations:{description:"Valitse organisaatio, johon haluat kirjautua",pageTitle:"Valitse organisaatio | ${clientName}",searchPlaceholder:"Hae organisaatioita",title:"Valitse organisaatiosi"}},o$={signup:{buttonText:"Rekisteröityminen",confirmPasswordPlaceholder:"Vahvista salasana",description:"Valitse salasana, jossa on isoja ja pieniä kirjaimia, numeroita ja symboleja.","email-already-exists":"Sähköposti on jo varattu",emailPlaceholder:"Sähköpostiosoite",federatedConnectionButtonText:"Jatka palvelulla ${connectionName}",hidePasswordText:"Piilota salasana","invalid-email-format":"Virheellinen sähköpostiosoite",loginActionLinkText:"Kirjaudu sisään",loginActionText:"Onko sinulla jo tili?","no-email":"Sähköpostiosoite vaaditaan","no-password":"Salasana vaaditaan","no-username":"Käyttäjänimi vaaditaan",pageTitle:"Rekisteröidy | ${clientName}",passwordPlaceholder:"Salasana",passwordsDidntMatch:"Salasanat eivät täsmää",phonePlaceholder:"Puhelinnumero",privacyPolicyLinkText:"Tietosuojakäytäntö",separatorText:"tai",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",showPasswordText:"Näytä salasana",termsOfServiceLinkText:"Käyttöehdot",termsText:"Rekisteröitymällä hyväksyt",title:"Valitse salasana","username-already-exists":"Tämä käyttäjänimi on jo varattu",usernamePlaceholder:"Käyttäjänimi",verifyEmailText:"Tarkista sähköpostisi vahvistaaksesi tilisi"}},s$={status:{continueButtonText:"Jatka",errorTitle:"Virhe",pageTitle:"Tila | ${clientName}",successTitle:"Onnistui",title:"Tila"}},SF={common:ZT,consent:XT,"device-flow":{"device-flow":{buttonText:"Jatka",codePlaceholder:"Syötä koodi",description:"Syötä laitteessasi näkyvä koodi","expired-code":"Koodi on vanhentunut","invalid-code":"Syöttämäsi koodi on virheellinen",pageTitle:"Laitteen aktivointi | ${clientName}",title:"Aktivoi laitteesi"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Kirjaudu sisään",codeLabel:"Vahvistuskoodi",codePlaceholder:"Syötä koodi",defaultDescription:"Syötä sähköpostiisi lähetetty vahvistuskoodi",description:"Lähetimme koodin osoitteeseen ${email}","invalid-code":"Virheellinen koodi",noCode:"Syötä vahvistuskoodi",pageTitle:"Syötä koodi | ${clientName}",resendText:"Lähetä koodi uudelleen",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",title:"Tarkista sähköpostisi",unexpectedError:"Odottamaton virhe tapahtui"}},"email-verification":{"email-verification":{description:"Lähetimme sähköpostin osoitteeseen ${email}",pageTitle:"Vahvista sähköposti | ${clientName}",resendText:"Lähetä koodi uudelleen",successDescription:"Sähköpostiosoitteesi on vahvistettu onnistuneesti.",successTitle:"Sähköposti vahvistettu",title:"Vahvista sähköpostiosoitteesi"}},invitation:e$,login:t$,"login-id":{"login-id":{alertListTitle:"Ilmoitukset","auth0-users-validation":"Jokin meni pieleen, yritä myöhemmin uudelleen","authentication-failure":"Valitettavasti jokin meni pieleen kirjautumisyrityksen aikana",buttonText:"Jatka","captcha-client-failure":"Turvatarkistuksen lataaminen epäonnistui. Yritä uudelleen. (Virhekoodi: #{errorCode})","captcha-validation-failure":"Valitettavasti jokin meni pieleen captcha-vastauksen tarkistuksessa. Yritä uudelleen.",captchaCodePlaceholder:"Syötä yllä näkyvä koodi","custom-script-error-code":"Jokin meni pieleen, yritä myöhemmin uudelleen.",description:"Kirjaudu sisään ${clientName}.",editEmailText:"Muokkaa",emailPlaceholder:"Sähköpostiosoite",federatedConnectionButtonText:"Jatka palvelulla ${connectionName}",footerLinkText:"Rekisteröidy",footerText:"Eikö sinulla ole tiliä?",forgotPasswordText:"Unohditko salasanan?",hidePasswordText:"Piilota salasana","invalid-captcha":"Ratkaise haaste varmistaaksesi, ettet ole robotti.","invalid-code":"Virheellinen koodi","invalid-connection":"Virheellinen yhteys","invalid-email-format":"Virheellinen sähköpostiosoite","invalid-email-phone":"Syötä kelvollinen sähköpostiosoite tai puhelinnumero. Puhelinnumeron tulee sisältää maatunnus.","invalid-email-phone-username":"Syötä kelvollinen sähköpostiosoite, puhelinnumero tai käyttäjänimi. Puhelinnumeron tulee sisältää maatunnus.","invalid-email-username":"Syötä kelvollinen sähköpostiosoite tai käyttäjänimi","invalid-expired-code":"Virheellinen tai vanhentunut käyttäjäkoodi","invalid-login-id":"Virheellinen kirjautumistunnus","invalid-phone-username":"Syötä kelvollinen puhelinnumero tai käyttäjänimi. Puhelinnumeron tulee sisältää maatunnus.","invalid-recaptcha":"Valitse valintaruutu varmistaaksesi, ettet ole robotti.","invalid-username":"Käyttäjänimi voi sisältää vain aakkosnumeerisia merkkejä tai: '${characters}'. Käyttäjänimen tulee olla ${min}–${max} merkkiä.",invitationDescription:"Kirjaudu sisään hyväksyäksesi käyttäjän ${inviterName} kutsun liittyä palveluun ${companyName} sovelluksessa ${clientName}.",invitationTitle:"Sinut on kutsuttu!","ip-blocked":"Olemme havainneet epäilyttävää kirjautumiskäyttäytymistä ja lisäyritykset estetään. Ota yhteyttä ylläpitäjään.",logoAltText:"${companyName}","no-db-connection":"Virheellinen yhteys","no-email":"Sähköpostiosoite vaaditaan","no-email-phone":"Sähköpostiosoite tai puhelinnumero vaaditaan","no-email-phone-username":"Puhelinnumero, käyttäjänimi tai sähköpostiosoite vaaditaan","no-email-username":"Sähköpostiosoite tai käyttäjänimi vaaditaan","no-password":"Salasana vaaditaan","no-phone":"Syötä puhelinnumero","no-phone-username":"Puhelinnumero tai käyttäjänimi vaaditaan","no-username":"Käyttäjänimi vaaditaan",pageTitle:"Kirjaudu sisään | ${clientName}","password-breached":"Olemme havainneet mahdollisen tietoturvaongelman tässä tilissä. Tilisi suojaamiseksi olemme estäneet tämän kirjautumisen. Vaihda salasanasi jatkaaksesi.",passwordPlaceholder:"Salasana",phoneOrEmailPlaceholder:"Sähköposti tai puhelinnumero",phoneOrUsernameOrEmailPlaceholder:"Puhelin, käyttäjänimi tai sähköposti",phoneOrUsernamePlaceholder:"Puhelinnumero tai käyttäjänimi",phonePlaceholder:"Puhelinnumero","same-user-login":"Liian monta kirjautumisyritystä tälle käyttäjälle. Odota hetki ja yritä myöhemmin uudelleen.",selectCountryCode:"Valitse maakoodi, tällä hetkellä ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"tai",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",showPasswordText:"Näytä salasana",signupActionLinkText:"Rekisteröidy",signupActionText:"Eikö sinulla ole tiliä?",termsAndConditionsTemplate:'Jatkamalla hyväksyt <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Käyttöehdot</a>.',title:"Tervetuloa","user-blocked":"Tilisi on estetty useiden peräkkäisten kirjautumisyritysten jälkeen.",userAccountDoesNotExist:"Käyttäjätiliä ei ole olemassa",usernameOnlyPlaceholder:"Käyttäjänimi",usernameOrEmailPlaceholder:"Käyttäjänimi tai sähköpostiosoite",usernamePlaceholder:"Käyttäjänimi",usernameTooLong:"Käyttäjänimen on oltava enintään ${max} merkkiä",usernameTooShort:"Käyttäjänimen on oltava vähintään ${min} merkkiä","wrong-credentials":"Väärä käyttäjänimi tai salasana","wrong-email-credentials":"Väärä sähköpostiosoite tai salasana","wrong-email-phone-credentials":"Virheellinen sähköpostiosoite, puhelinnumero tai salasana. Puhelinnumeron tulee sisältää maatunnus.","wrong-email-phone-username-credentials":"Virheellinen sähköpostiosoite, puhelinnumero, käyttäjänimi tai salasana. Puhelinnumeron tulee sisältää maatunnus.","wrong-email-username-credentials":"Virheellinen sähköpostiosoite, käyttäjänimi tai salasana","wrong-phone-credentials":"Virheellinen puhelinnumero tai salasana","wrong-phone-username-credentials":"Virheellinen puhelinnumero, käyttäjänimi tai salasana. Puhelinnumeron tulee sisältää maatunnus.","wrong-username-credentials":"Virheellinen käyttäjänimi tai salasana",passkeyButtonText:"Kirjaudu sisään passkey:llä"}},"login-password":{"login-password":{buttonText:"Kirjaudu sisään",description:"Anna sähköpostiosoitteesi ja salasanasi kirjautuaksesi sisään.",forgotPasswordText:"Unohditko salasanan?",hidePasswordText:"Piilota salasana","no-password":"Salasana vaaditaan",pageTitle:"Kirjaudu sisään | ${clientName}","password-breached":"Olemme havainneet mahdollisen tietoturvaongelman tässä tilissä. Tilisi suojaamiseksi olemme estäneet tämän kirjautumisen. Vaihda salasanasi jatkaaksesi.",passwordPlaceholder:"Salasana",showPasswordText:"Näytä salasana",signingInAs:"Kirjaudutaan käyttäjänä ${email}",title:"Anna salasana",unverifiedEmail:"Vahvista sähköpostiosoitteesi ennen kirjautumista","user-blocked":"Tilisi on estetty useiden peräkkäisten kirjautumisyritysten jälkeen.","wrong-credentials":"Väärä salasana"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"sähköposti",authMethodEmailOrPhone:"sähköposti tai puhelinnumero",authMethodPhone:"puhelinnumero",description:"Kirjaudu sisään käyttämällä ${authMethod}",emailOrPhonePlaceholder:"Sähköpostiosoite tai puhelinnumero",emailPlaceholder:"Sähköpostiosoite",invalidEmail:"Syötä kelvollinen sähköpostiosoite",invalidIdentifier:"Syötä kelvollinen sähköpostiosoite tai puhelinnumero",invalidPhone:"Syötä kelvollinen puhelinnumero maatunnuksella",noEmail:"Syötä sähköpostiosoitteesi",noPhone:"Syötä puhelinnumerosi",phonePlaceholder:"Puhelinnumero",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",title:"Kirjaudu koodilla",userAccountDoesNotExist:"Käyttäjätiliä ei ole olemassa"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Napsauta sähköpostissasi olevaa linkkiä kirjautuaksesi sisään",description:"Lähetimme linkin osoitteeseen ${username}. Napsauta sitä kirjautuaksesi.",resendText:"Lähetä linkki uudelleen",spamText:"Etkö saanut sähköpostia? Tarkista roskapostikansiosi.",title:"Tarkista sähköpostisi"}},mfa:n$,"mfa-email":{"mfa-email":{buttonText:"Jatka",codePlaceholder:"Syötä koodi",description:"Lähetimme koodin osoitteeseen ${email}","invalid-code":"Syöttämäsi koodi on virheellinen",pageTitle:"Sähköpostivahvistus | ${clientName}",resendText:"Lähetä koodi uudelleen",title:"Tarkista sähköpostisi"}},"mfa-otp":{"mfa-otp":{buttonText:"Jatka",codePlaceholder:"Syötä koodi",description:"Syötä 6-numeroinen koodi todentajasovelluksestasi","invalid-code":"Syöttämäsi koodi on virheellinen",pageTitle:"Syötä koodi | ${clientName}",title:"Syötä koodisi"},"mfa-totp-enrollment":{title:"Ota todentajasovellus käyttöön",description:"Skannaa alla oleva QR-koodi todentajasovelluksellasi ja syötä sitten 6-numeroinen koodi vahvistaaksesi",secretLabel:"Tai syötä tämä koodi manuaalisesti:",codePlaceholder:"Syötä koodi",continueButtonText:"Vahvista ja aktivoi","invalid-code":"Syöttämäsi koodi on virheellinen. Yritä uudelleen.","transaction-not-found":"Rekisteröintitapahtumasi on vanhentunut, sinun täytyy aloittaa alusta.",pageTitle:"Ota todentaja käyttöön | ${clientName}",unexpectedError:"Jokin meni pieleen. Yritä uudelleen.",enrollmentComplete:"MFA-rekisteröinti on valmis. Voit sulkea tämän sivun."},"mfa-totp-challenge":{title:"Vahvista henkilöllisyytesi",description:"Syötä 6-numeroinen koodi todentajasovelluksestasi",codePlaceholder:"Syötä koodi",continueButtonText:"Jatka","invalid-code":"Syöttämäsi koodi on virheellinen","transaction-not-found":"Rekisteröintitapahtumasi on vanhentunut, sinun täytyy aloittaa alusta.",unexpectedError:"Jokin meni pieleen. Yritä uudelleen.",pageTitle:"Vahvista henkilöllisyys | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Käytä puhelinnumeroasi kirjautumiseen | ${clientName}",title:"Vahvista henkilöllisyytesi",description:"Lähetimme koodin numeroon ${phoneNumber}",continueButtonText:"Jatka",changePhoneText:"Valitse toinen puhelinnumero.",smsButtonText:"Tekstiviesti",voiceButtonText:"Äänipuhelu",chooseMessageTypeText:"Miten haluat vastaanottaa koodin?",pickAuthenticatorText:"Kokeile toista menetelmää",logoAltText:"${companyName}",codePlaceholder:"Syötä koodi","send-sms-failed":"Tekstiviestin lähettämisessä oli ongelma","send-voice-failed":"Äänipuhelun soittamisessa oli ongelma","invalid-phone-format":"Puhelinnumero voi sisältää vain numeroita.","invalid-phone":"Puhelinnumerosi ei vaikuta olevan kelvollinen. Tarkista ja yritä uudelleen.","too-many-sms":"Olet ylittänyt tunnin enimmäismäärän puhelinviestejä. Odota muutama minuutti ja yritä uudelleen.","too-many-voice":"Olet ylittänyt tunnin enimmäismäärän puhelinviestejä. Odota muutama minuutti ja yritä uudelleen.","transaction-not-found":"Rekisteröintitapahtumasi on vanhentunut, sinun täytyy aloittaa alusta.","no-phone":"Syötä puhelinnumero",noCode:"Syötä vahvistuskoodi",invalidCode:"Antamasi koodi on virheellinen. Yritä uudelleen.",unexpectedError:"Jokin meni pieleen. Yritä uudelleen.",resendSuccess:"Lähetimme uuden koodin puhelimeesi",enrollmentComplete:"MFA-rekisteröinti on valmis. Voit sulkea tämän sivun."},"mfa-phone-enrollment":{pageTitle:"Syötä puhelinnumerosi kirjautuaksesi puhelinkoodilla | ${clientName}",title:"Suojaa tilisi",description:"Syötä maakoodisi ja puhelinnumero, johon voimme lähettää 6-numeroisen koodin:",continueButtonText:"Jatka",smsButtonText:"Tekstiviesti",voiceButtonText:"Äänipuhelu",chooseMessageTypeText:"Miten haluat vastaanottaa koodin?",pickAuthenticatorText:"Kokeile toista menetelmää",placeholder:"Syötä puhelinnumerosi",logoAltText:"${companyName}",selectCountryCode:"Valitse maakoodi, tällä hetkellä asetettu ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Tekstiviestin lähettämisessä oli ongelma","send-voice-failed":"Äänipuhelun soittamisessa oli ongelma","sms-authenticator-error":"Emme pystyneet lähettämään tekstiviestiä. Yritä myöhemmin uudelleen.","invalid-phone-format":"Puhelinnumero voi sisältää vain numeroita.","invalid-phone":"Puhelinnumerosi ei vaikuta olevan kelvollinen. Tarkista ja yritä uudelleen.","too-many-sms":"Olet ylittänyt tunnin enimmäismäärän puhelinviestejä. Odota muutama minuutti ja yritä uudelleen.","too-many-voice":"Olet ylittänyt tunnin enimmäismäärän puhelinviestejä. Odota muutama minuutti ja yritä uudelleen.","transaction-not-found":"Rekisteröintitapahtumasi on vanhentunut, sinun täytyy aloittaa alusta.","no-phone":"Syötä puhelinnumero","phone-is-too-short":"Puhelinnumero on liian lyhyt","phone-is-too-long":"Puhelinnumero on liian pitkä"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Valitse vahvistusmenetelmä | ${clientName}",title:"Valitse vahvistusmenetelmä",description:"Valitse, miten haluat vahvistaa henkilöllisyytesi",authenticatorAppLabel:"Todennussovellus",authenticatorAppDescription:"Käytä todennussovellusta vahvistuskoodin saamiseksi",smsLabel:"Tekstiviesti",smsDescription:"Saat vahvistuskoodin puhelimeesi tekstiviestillä",passkeyLabel:"Tunnistautumisavain",passkeyDescription:"Käytä laitteesi biometriikkaa tai suojausavainta"}},"mfa-push":{"mfa-push":{description:"Lähetimme ilmoituksen laitteellesi",pageTitle:"Push-ilmoitus | ${clientName}",resendText:"Lähetä ilmoitus uudelleen",title:"Hyväksy pyyntö",useCodeText:"Syötä koodi manuaalisesti"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Jatka",codePlaceholder:"Palautuskoodi",description:"Syötä yksi palautuskoodeistasi","invalid-code":"Syöttämäsi palautuskoodi on virheellinen",pageTitle:"Palautuskoodi | ${clientName}",title:"Syötä palautuskoodi"}},"mfa-voice":{"mfa-voice":{buttonText:"Soita minulle",codePlaceholder:"Syötä koodi",description:"Soitamme numeroon ${phoneNumber} ja kerromme koodisi","invalid-code":"Syöttämäsi koodi on virheellinen",pageTitle:"Äänipuhelu | ${clientName}",title:"Vastaanota puhelu"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Yritä uudelleen",description:"Aseta turva-avaimesi ja seuraa ohjeita",pageTitle:"Turva-avain | ${clientName}",title:"Käytä turva-avaintasi"}},passkeys:i$,organizations:r$,"reset-password":{"reset-password":{backToLoginText:"Palaa takaisin",buttonText:"Lähetä salasanan palautussähköposti",codeExpired:"Salasanan palautuskoodisi on vanhentunut. Pyydä uusi koodi.",confirmPasswordLabel:"Vahvista salasana",confirmPasswordPlaceholder:"Vahvista salasana",description:"Napsauta alla olevaa painiketta, niin lähetämme ohjeet salasanasi palauttamiseen.",emailPlaceholder:"Sähköpostiosoite",failed:"Salasanan vaihto epäonnistui. Yritä uudelleen.","invalid-email-format":"Virheellinen sähköpostiosoite","no-email":"Sähköpostiosoite vaaditaan",pageTitle:"Vaihda salasana | ${clientName}",passwordLabel:"Uusi salasana",passwordPlaceholder:"Uusi salasana",passwordTooWeak:"Salasana on liian heikko",passwordsDidntMatch:"Salasanat eivät täsmää",successDescription:"Olemme lähettäneet salasanan palautuslinkin sähköpostiosoitteeseesi.",successTitle:"Salasanan palautussähköposti lähetetty",title:"Unohditko salasanan?","user-not-found":"Käyttäjää ei löytynyt"},"reset-password-code":{backToLoginText:"Takaisin kirjautumiseen",buttonText:"Vaihda salasana",codeLabel:"Palautuskoodi",codePlaceholder:"Syötä 6-numeroinen koodi",confirmPasswordLabel:"Vahvista salasana",confirmPasswordPlaceholder:"Vahvista salasana",defaultDescription:"Syötä sähköpostiisi lähetetty koodi ja valitse uusi salasana",description:"Lähetimme koodin osoitteeseen ${email}",failed:"Salasanan vaihto epäonnistui. Yritä uudelleen.",invalidCode:"Syöttämäsi koodi on virheellinen tai vanhentunut",noCode:"Syötä palautuskoodi",pageTitle:"Syötä palautuskoodi | ${clientName}",passwordLabel:"Uusi salasana",passwordPlaceholder:"Uusi salasana",passwordTooWeak:"Salasana on liian heikko",passwordsDidntMatch:"Salasanat eivät täsmää",resendFailed:"Koodin uudelleenlähetys epäonnistui. Yritä uudelleen.",resendSuccess:"Uusi koodi on lähetetty sähköpostiisi",resendText:"Lähetä koodi uudelleen",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",title:"Syötä palautuskoodi"}},signup:o$,"signup-id":{"signup-id":{buttonText:"Jatka",description:"Valitse salasana, jossa on isoja ja pieniä kirjaimia, numeroita ja symboleja.","email-already-exists":"Sähköposti on jo varattu",emailPlaceholder:"Sähköpostiosoite",federatedConnectionButtonText:"Jatka palvelulla ${connectionName}","invalid-email-format":"Virheellinen sähköpostiosoite",loginActionLinkText:"Kirjaudu sisään",loginActionText:"Onko sinulla jo tili?","no-email":"Sähköpostiosoite vaaditaan",pageTitle:"Rekisteröidy | ${clientName}",phonePlaceholder:"Puhelinnumero",separatorText:"tai",title:"Valitse salasana",usernamePlaceholder:"Käyttäjänimi"}},"signup-password":{"signup-password":{buttonText:"Jatka",description:"Valitse salasana, jossa on isoja ja pieniä kirjaimia, numeroita ja symboleja.",hidePasswordText:"Piilota salasana","no-password":"Salasana vaaditaan",pageTitle:"Rekisteröidy | ${clientName}","password-policy-not-met":"Salasana ei täytä vaatimuksia","password-too-weak":"Salasana on liian heikko",passwordPlaceholder:"Salasana",showPasswordText:"Näytä salasana",title:"Valitse salasana"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Jatka",codeLabel:"Vahvistuskoodi",codePlaceholder:"Syötä koodi",defaultDescription:"Syötä puhelimeesi lähetetty vahvistuskoodi",description:"Lähetimme koodin käyttäjälle ${username}","invalid-code":"Virheellinen koodi",noCode:"Syötä vahvistuskoodi",pageTitle:"Syötä koodi | ${clientName}",resendText:"Lähetä koodi uudelleen",sessionExpired:"Istuntosi on vanhentunut. Yritä uudelleen.",title:"Tarkista puhelimesi",unexpectedError:"Odottamaton virhe tapahtui"}},status:s$},EF=Object.freeze(Object.defineProperty({__proto__:null,common:ZT,consent:XT,default:SF,invitation:e$,login:t$,mfa:n$,organizations:r$,passkeys:i$,signup:o$,status:s$},Symbol.toStringTag,{value:"Module"})),a$={common:{alertListTitle:"Avvisi",backText:"Torna indietro",cancelText:"Annulla",closeText:"Chiudi",contactSupportText:"Contatta l'assistenza",continueText:"Continua",copyrightText:"© ${currentYear} ${companyName}",errorText:"Si è verificato un errore",hidePasswordText:"Nascondi password",loadingText:"Caricamento...",orText:"o",privacyPolicyText:"Informativa sulla privacy",showPasswordText:"Mostra password",termsOfServiceText:"Termini di servizio",termsShortText:"Termini",tryAgainText:"Riprova"}},c$={consent:{buttonText:"Accetta",cancelButtonText:"Rifiuta",description:"${clientName} richiede l'accesso al tuo account",pageTitle:"Autorizza | ${clientName}",scopesTitle:"Questo permetterà a ${clientName} di:",title:"Autorizza ${clientName}"}},l$={invitation:{acceptButtonText:"Accetta invito",description:"${inviterName} ti ha invitato a unirti a ${organizationName} su ${clientName}",pageTitle:"Invito | ${clientName}",title:"Sei stato invitato"}},d$={login:{alertListTitle:"Avvisi",buttonText:"Continua",description:"Accedi a ${clientName}.",editEmailText:"Modifica",emailPlaceholder:"Indirizzo e-mail",enterACodeBtn:"Accedi con un codice",federatedConnectionButtonText:"Continua con ${connectionName}",footerLinkText:"Iscriviti",footerText:"Non hai un account?",forgotPasswordText:"Hai dimenticato la password?",hidePasswordText:"Nascondi password",invalidEmail:"Email non valida",invalidIdentifier:"Email o nome utente non valido",invitationDescription:"Accedi per accettare l'invito di ${inviterName} a unirti a ${companyName} su ${clientName}.",invitationTitle:"Sei stato invitato!",logoAltText:"${companyName}","no-email":"Inserisci un indirizzo email","no-password":"La password è obbligatoria",pageTitle:"Accedi | ${clientName}",passwordLoginNotAvailable:"L'autenticazione con password non è disponibile",passwordPlaceholder:"Password",phonePlaceholder:"Numero di telefono",separatorText:"o",sessionExpired:"La sessione è scaduta. Riprova.",showPasswordText:"Mostra password",signupActionLinkText:"Iscriviti",signupActionText:"Non hai un account?",title:"Benvenuto",tooManyFailedLogins:"Troppi tentativi di accesso falliti. Riprova più tardi.",unverifiedEmail:"Verifica il tuo indirizzo email prima di accedere",userAccountDoesNotExist:"L'account utente non esiste",usernamePlaceholder:"Nome utente o indirizzo email",usernameTooLong:"Il nome utente deve avere al massimo ${max} caratteri",usernameTooShort:"Il nome utente deve avere almeno ${min} caratteri",wrongCredentials:"Nome utente o password errati",passkeyButtonText:"Accedi con una passkey"}},u$={mfa:{backupCodeText:"Usa codice di backup",description:"Scegli un metodo di verifica",pageTitle:"Autenticazione a più fattori | ${clientName}",title:"Verifica la tua identità"}},p$={"passkey-enrollment-nudge":{title:"Proteggi il tuo account con una passkey",description:"Le passkey utilizzano la biometria o il PIN del tuo dispositivo per accedere più velocemente e in modo più sicuro.",enrollButtonText:"Configura passkey",snoozeButtonText:"Forse più tardi",optOutLinkText:"Non mostrare più",pageTitle:"Configura Passkey | ${clientName}"},"passkey-enrollment":{title:"Crea la tua passkey",description:"Segui le istruzioni del browser per creare una passkey per questo account.",errorMessage:"Creazione della passkey non riuscita. Riprova.",cancelLinkText:"Salta per ora",retryButtonText:"Riprova",enrollmentComplete:"La tua passkey è stata configurata con successo. Puoi chiudere questa pagina.",pageTitle:"Crea Passkey | ${clientName}"},"passkey-challenge":{title:"Accedi con passkey",description:"Segui le istruzioni del browser per verificare la tua identità.",errorMessage:"Autenticazione con passkey non riuscita. Riprova.",cancelLinkText:"Torna al login",retryButtonText:"Riprova",pageTitle:"Accedi con passkey | ${clientName}"}},f$={organizations:{description:"Scegli a quale organizzazione accedere",pageTitle:"Seleziona organizzazione | ${clientName}",searchPlaceholder:"Cerca organizzazioni",title:"Seleziona la tua organizzazione"}},h$={signup:{buttonText:"Iscriviti",confirmPasswordPlaceholder:"Conferma password",description:"Registrati per continuare","email-already-exists":"Questa email è già registrata",emailPlaceholder:"Indirizzo e-mail",federatedConnectionButtonText:"Continua con ${connectionName}",hidePasswordText:"Nascondi password","invalid-email-format":"Email non valida",loginActionLinkText:"Accedi",loginActionText:"Hai già un account?","no-email":"Inserisci un indirizzo email","no-password":"La password è obbligatoria","no-username":"Il nome utente è obbligatorio",pageTitle:"Registrati | ${clientName}",passwordPlaceholder:"Password",passwordsDidntMatch:"Le password non corrispondono",phonePlaceholder:"Numero di telefono",privacyPolicyLinkText:"Informativa sulla privacy",separatorText:"o",sessionExpired:"La sessione è scaduta. Riprova.",showPasswordText:"Mostra password",termsOfServiceLinkText:"Termini di servizio",termsText:"Registrandoti, accetti i nostri",title:"Crea il tuo account","username-already-exists":"Questo nome utente è già in uso",usernamePlaceholder:"Nome utente",verifyEmailText:"Controlla la tua email per verificare il tuo account"}},g$={status:{continueButtonText:"Continua",errorTitle:"Errore",pageTitle:"Stato | ${clientName}",successTitle:"Operazione riuscita",title:"Stato"}},xF={common:a$,consent:c$,"device-flow":{"device-flow":{buttonText:"Continua",codePlaceholder:"Inserisci il codice",description:"Inserisci il codice mostrato sul tuo dispositivo","expired-code":"Il codice è scaduto","invalid-code":"Il codice inserito non è valido",pageTitle:"Attivazione dispositivo | ${clientName}",title:"Attiva il tuo dispositivo"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Continua",codeLabel:"Codice di verifica",codePlaceholder:"Inserisci il codice",defaultDescription:"Inserisci il codice di verifica inviato alla tua email",description:"Abbiamo inviato un codice a ${email}","invalid-code":"Codice non valido",noCode:"Inserisci il codice di verifica",pageTitle:"Inserisci il codice | ${clientName}",resendText:"Reinvio del codice",sessionExpired:"La sessione è scaduta. Riprova.",title:"Controlla la tua email",unexpectedError:"Si è verificato un errore imprevisto"}},"email-verification":{"email-verification":{description:"Abbiamo inviato un'email a ${email}",pageTitle:"Verifica email | ${clientName}",resendText:"Reinvia email",successDescription:"La tua email è stata verificata con successo.",successTitle:"Email verificata",title:"Verificare l'e-mail"}},invitation:l$,login:d$,"login-id":{"login-id":{alertListTitle:"Avvisi","auth0-users-validation":"Qualcosa è andato storto, riprova più tardi","authentication-failure":"Siamo spiacenti, si è verificato un errore durante il tentativo di accesso",buttonText:"Continua","captcha-client-failure":"Non è stato possibile caricare la verifica di sicurezza. Riprova. (Codice errore: #{errorCode})","captcha-validation-failure":"Siamo spiacenti, si è verificato un errore durante la convalida della risposta captcha. Riprova.",captchaCodePlaceholder:"Inserisci il codice mostrato sopra","custom-script-error-code":"Qualcosa è andato storto, riprova più tardi.",description:"Accedi a ${clientName}.",editEmailText:"Modifica",emailPlaceholder:"Indirizzo e-mail",federatedConnectionButtonText:"Continua con ${connectionName}",footerLinkText:"Iscriviti",footerText:"Non hai un account?",forgotPasswordText:"Hai dimenticato la password?",hidePasswordText:"Nascondi password","invalid-captcha":"Risolvi la domanda di verifica per confermare che non sei un robot.","invalid-code":"Codice non valido","invalid-connection":"Connessione non valida","invalid-email-format":"Email non valida","invalid-email-phone":"Inserisci un indirizzo email o un numero di telefono valido. I numeri di telefono devono includere il prefisso internazionale.","invalid-email-phone-username":"Inserisci un indirizzo email, un numero di telefono o un nome utente valido. I numeri di telefono devono includere il prefisso internazionale.","invalid-email-username":"Inserisci un indirizzo email o un nome utente valido","invalid-expired-code":"Codice utente non valido o scaduto","invalid-login-id":"ID di accesso non valido","invalid-phone-username":"Inserisci un numero di telefono o un nome utente valido. I numeri di telefono devono includere il prefisso internazionale.","invalid-recaptcha":"Seleziona la casella per confermare che non sei un robot.","invalid-username":"Il nome utente può contenere solo caratteri alfanumerici o: '${characters}'. Il nome utente deve avere tra ${min} e ${max} caratteri.",invitationDescription:"Accedi per accettare l'invito di ${inviterName} a unirti a ${companyName} su ${clientName}.",invitationTitle:"Sei stato invitato!","ip-blocked":"Abbiamo rilevato un comportamento di accesso sospetto e ulteriori tentativi saranno bloccati. Contatta l'amministratore.",logoAltText:"${companyName}","no-db-connection":"Connessione non valida","no-email":"Inserisci un indirizzo email","no-email-phone":"È richiesto un indirizzo email o un numero di telefono","no-email-phone-username":"È richiesto un numero di telefono, un nome utente o un indirizzo email","no-email-username":"È richiesto un indirizzo email o un nome utente","no-password":"La password è obbligatoria","no-phone":"Inserisci un numero di telefono","no-phone-username":"È richiesto un numero di telefono o un nome utente","no-username":"Il nome utente è obbligatorio",pageTitle:"Accedi | ${clientName}","password-breached":"Abbiamo rilevato un potenziale problema di sicurezza con questo account. Per proteggere il tuo account, abbiamo impedito questo accesso. Reimposta la password per procedere.",passwordPlaceholder:"Password",phoneOrEmailPlaceholder:"Indirizzo e-mail o numero di telefono",phoneOrUsernameOrEmailPlaceholder:"Telefono, nome utente o email",phoneOrUsernamePlaceholder:"Numero di telefono o nome utente",phonePlaceholder:"Numero di telefono","same-user-login":"Troppi tentativi di accesso per questo utente. Attendi e riprova più tardi.",selectCountryCode:"Seleziona prefisso paese, attualmente impostato su ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"o",sessionExpired:"La sessione è scaduta. Riprova.",showPasswordText:"Mostra password",signupActionLinkText:"Iscriviti",signupActionText:"Non hai un account?",termsAndConditionsTemplate:'Continuando, accetti i nostri <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Termini e condizioni</a>.',title:"Benvenuto","user-blocked":"Il tuo account è stato bloccato dopo diversi tentativi di accesso consecutivi.",userAccountDoesNotExist:"L'account utente non esiste",usernameOnlyPlaceholder:"Nome utente",usernameOrEmailPlaceholder:"Nome utente o indirizzo email",usernamePlaceholder:"Nome utente",usernameTooLong:"Il nome utente deve avere al massimo ${max} caratteri",usernameTooShort:"Il nome utente deve avere almeno ${min} caratteri","wrong-credentials":"Nome utente o password errati","wrong-email-credentials":"Email o password errati","wrong-email-phone-credentials":"Indirizzo email, numero di telefono o password errati. I numeri di telefono devono includere il prefisso internazionale.","wrong-email-phone-username-credentials":"Indirizzo email, numero di telefono, nome utente o password errati. I numeri di telefono devono includere il prefisso internazionale.","wrong-email-username-credentials":"Indirizzo email, nome utente o password errati","wrong-phone-credentials":"Numero di telefono o password errati","wrong-phone-username-credentials":"Numero di telefono, nome utente o password errati. I numeri di telefono devono includere il prefisso internazionale.","wrong-username-credentials":"Nome utente o password errati",passkeyButtonText:"Accedi con una passkey"}},"login-password":{"login-password":{buttonText:"Accedi",description:"Accedi a ${clientName}",forgotPasswordText:"Hai dimenticato la password?",hidePasswordText:"Nascondi password","no-password":"La password è obbligatoria",pageTitle:"Accedi | ${clientName}","password-breached":"Abbiamo rilevato un potenziale problema di sicurezza con questo account. Per proteggere il tuo account, abbiamo impedito questo accesso. Reimposta la password per procedere.",passwordPlaceholder:"Password",showPasswordText:"Mostra password",signingInAs:"Accesso come ${email}",title:"Inserire la password",unverifiedEmail:"Verifica il tuo indirizzo email prima di accedere","user-blocked":"Il tuo account è stato bloccato dopo diversi tentativi di accesso consecutivi.","wrong-credentials":"Password errata"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"email",authMethodEmailOrPhone:"email o numero di telefono",authMethodPhone:"numero di telefono",description:"Accedi usando il tuo ${authMethod}",emailOrPhonePlaceholder:"Indirizzo email o numero di telefono",emailPlaceholder:"Indirizzo e-mail",invalidEmail:"Inserisci un indirizzo email valido",invalidIdentifier:"Inserisci un indirizzo email o un numero di telefono valido",invalidPhone:"Inserisci un numero di telefono valido con il prefisso internazionale",noEmail:"Inserisci il tuo indirizzo email",noPhone:"Inserisci il tuo numero di telefono",phonePlaceholder:"Numero di telefono",sessionExpired:"La sessione è scaduta. Riprova.",title:"Accedi con un codice",userAccountDoesNotExist:"L'account utente non esiste"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Clicca il link nella tua email per accedere",description:"Abbiamo inviato un link a ${username}. Cliccalo per accedere.",resendText:"Reinvia link",spamText:"Non hai ricevuto l'email? Controlla la cartella spam.",title:"Controlla la tua email"}},mfa:u$,"mfa-email":{"mfa-email":{buttonText:"Continua",codePlaceholder:"Inserisci il codice",description:"Abbiamo inviato un codice a ${email}","invalid-code":"Il codice inserito non è valido",pageTitle:"Verifica email | ${clientName}",resendText:"Reinvia codice",title:"Controlla la tua email"}},"mfa-otp":{"mfa-otp":{buttonText:"Continua",codePlaceholder:"Inserisci il codice",description:"Inserisci il codice a 6 cifre dalla tua app di autenticazione","invalid-code":"Il codice inserito non è valido",pageTitle:"Inserisci il codice | ${clientName}",title:"Inserisci il tuo codice"},"mfa-totp-enrollment":{title:"Configura l'autenticatore",description:"Scansiona il codice QR qui sotto con la tua app di autenticazione, poi inserisci il codice a 6 cifre per verificare",secretLabel:"Oppure inserisci questo codice manualmente:",codePlaceholder:"Inserisci il codice",continueButtonText:"Verifica e attiva","invalid-code":"Il codice inserito non è valido. Riprova.","transaction-not-found":"La tua transazione di registrazione è scaduta, dovrai ricominciare.",pageTitle:"Configura autenticatore | ${clientName}",unexpectedError:"Qualcosa è andato storto. Riprova.",enrollmentComplete:"La registrazione MFA è completata. Puoi chiudere questa pagina."},"mfa-totp-challenge":{title:"Verifica la tua identità",description:"Inserisci il codice a 6 cifre dalla tua app di autenticazione",codePlaceholder:"Inserisci il codice",continueButtonText:"Continua","invalid-code":"Il codice inserito non è valido","transaction-not-found":"La tua transazione di registrazione è scaduta, dovrai ricominciare.",unexpectedError:"Qualcosa è andato storto. Riprova.",pageTitle:"Verifica identità | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Usa il tuo numero di telefono per accedere | ${clientName}",title:"Verifica la tua identità",description:"Abbiamo inviato un codice a ${phoneNumber}",continueButtonText:"Continua",changePhoneText:"Scegli un altro numero di telefono.",smsButtonText:"Messaggio di testo",voiceButtonText:"Chiamata vocale",chooseMessageTypeText:"Come vuoi ricevere il codice?",pickAuthenticatorText:"Prova un altro metodo",logoAltText:"${companyName}",codePlaceholder:"Inserisci il codice","send-sms-failed":"Si è verificato un problema nell'invio dell'SMS","send-voice-failed":"Si è verificato un problema nell'effettuare la chiamata vocale","invalid-phone-format":"Il numero di telefono può contenere solo cifre.","invalid-phone":"Sembra che il tuo numero di telefono non sia valido. Controlla e riprova.","too-many-sms":"Hai superato il numero massimo di messaggi telefonici all'ora. Attendi qualche minuto e riprova.","too-many-voice":"Hai superato il numero massimo di messaggi telefonici all'ora. Attendi qualche minuto e riprova.","transaction-not-found":"La tua transazione di registrazione è scaduta, dovrai ricominciare.","no-phone":"Inserisci un numero di telefono",noCode:"Inserisci il codice di verifica",invalidCode:"Il codice inserito non è valido. Riprova.",unexpectedError:"Qualcosa è andato storto. Riprova.",resendSuccess:"Abbiamo inviato un nuovo codice al tuo telefono",enrollmentComplete:"La registrazione MFA è completata. Puoi chiudere questa pagina."},"mfa-phone-enrollment":{pageTitle:"Inserisci il tuo numero di telefono per accedere con un codice telefonico | ${clientName}",title:"Proteggi il tuo account",description:"Inserisci il prefisso del paese e il numero di telefono a cui possiamo inviare un codice a 6 cifre:",continueButtonText:"Continua",smsButtonText:"Messaggio di testo",voiceButtonText:"Chiamata vocale",chooseMessageTypeText:"Come vuoi ricevere il codice?",pickAuthenticatorText:"Prova un altro metodo",placeholder:"Inserisci il tuo numero di telefono",logoAltText:"${companyName}",selectCountryCode:"Seleziona prefisso paese, attualmente impostato su ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Si è verificato un problema nell'invio dell'SMS","send-voice-failed":"Si è verificato un problema nell'effettuare la chiamata vocale","sms-authenticator-error":"Non siamo riusciti a inviare l'SMS. Riprova più tardi.","invalid-phone-format":"Il numero di telefono può contenere solo cifre.","invalid-phone":"Sembra che il tuo numero di telefono non sia valido. Controlla e riprova.","too-many-sms":"Hai superato il numero massimo di messaggi telefonici all'ora. Attendi qualche minuto e riprova.","too-many-voice":"Hai superato il numero massimo di messaggi telefonici all'ora. Attendi qualche minuto e riprova.","transaction-not-found":"La tua transazione di registrazione è scaduta, dovrai ricominciare.","no-phone":"Inserisci un numero di telefono","phone-is-too-short":"Il numero di telefono è troppo corto","phone-is-too-long":"Il numero di telefono è troppo lungo"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Scegli il metodo di verifica | ${clientName}",title:"Scegli il metodo di verifica",description:"Seleziona come vuoi verificare la tua identità",authenticatorAppLabel:"App di autenticazione",authenticatorAppDescription:"Usa la tua app di autenticazione per ottenere un codice di verifica",smsLabel:"Messaggio di testo",smsDescription:"Ricevi un codice di verifica inviato al tuo telefono",passkeyLabel:"Passkey",passkeyDescription:"Usa la biometria del tuo dispositivo o una chiave di sicurezza"}},"mfa-push":{"mfa-push":{description:"Abbiamo inviato una notifica al tuo dispositivo",pageTitle:"Notifica push | ${clientName}",resendText:"Reinvia notifica",title:"Approva la richiesta",useCodeText:"Inserisci il codice manualmente"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Continua",codePlaceholder:"Codice di recupero",description:"Inserisci uno dei tuoi codici di recupero","invalid-code":"Il codice di recupero inserito non è valido",pageTitle:"Codice di recupero | ${clientName}",title:"Inserisci il codice di recupero"}},"mfa-voice":{"mfa-voice":{buttonText:"Chiamami",codePlaceholder:"Inserisci il codice",description:"Chiameremo ${phoneNumber} con il tuo codice","invalid-code":"Il codice inserito non è valido",pageTitle:"Chiamata vocale | ${clientName}",title:"Ricevi una telefonata"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Riprova",description:"Inserisci la tua chiave di sicurezza e segui le istruzioni",pageTitle:"Chiave di sicurezza | ${clientName}",title:"Usa la tua chiave di sicurezza"}},passkeys:p$,organizations:f$,"reset-password":{"reset-password":{backToLoginText:"Torna al login",buttonText:"Continua",codeExpired:"Il codice di reimpostazione della password è scaduto. Richiedine uno nuovo.",confirmPasswordLabel:"Conferma password",confirmPasswordPlaceholder:"Conferma password",description:"Inserisci la tua email per reimpostare la password",emailPlaceholder:"Indirizzo e-mail",failed:"Reimpostazione della password non riuscita. Riprova.","invalid-email-format":"Email non valida","no-email":"Inserisci un indirizzo email",pageTitle:"Reimposta password | ${clientName}",passwordLabel:"Nuova password",passwordPlaceholder:"Nuova password",passwordTooWeak:"La password è troppo debole",passwordsDidntMatch:"Le password non corrispondono",successDescription:"Abbiamo inviato un link per reimpostare la password al tuo indirizzo email.",successTitle:"Controlla la tua email",title:"Hai dimenticato la password?","user-not-found":"Utente non trovato"},"reset-password-code":{backToLoginText:"Torna al login",buttonText:"Reimposta password",codeLabel:"Codice di reimpostazione",codePlaceholder:"Inserisci il codice a 6 cifre",confirmPasswordLabel:"Conferma password",confirmPasswordPlaceholder:"Conferma password",defaultDescription:"Inserisci il codice inviato alla tua email e scegli una nuova password",description:"Abbiamo inviato un codice a ${email}",failed:"Reimpostazione della password non riuscita. Riprova.",invalidCode:"Il codice inserito non è valido o è scaduto",noCode:"Inserisci il codice di reimpostazione",pageTitle:"Inserisci il codice di reimpostazione | ${clientName}",passwordLabel:"Nuova password",passwordPlaceholder:"Nuova password",passwordTooWeak:"La password è troppo debole",passwordsDidntMatch:"Le password non corrispondono",resendFailed:"Impossibile reinviare il codice. Riprova.",resendSuccess:"Un nuovo codice è stato inviato alla tua email",resendText:"Reinvia codice",sessionExpired:"La sessione è scaduta. Riprova.",title:"Inserisci il codice di reimpostazione"}},signup:h$,"signup-id":{"signup-id":{buttonText:"Continua",description:"Registrati per continuare","email-already-exists":"Questa email è già registrata",emailPlaceholder:"Indirizzo e-mail",federatedConnectionButtonText:"Continua con ${connectionName}","invalid-email-format":"Email non valida",loginActionLinkText:"Accedi",loginActionText:"Hai già un account?","no-email":"Inserisci un indirizzo email",pageTitle:"Registrati | ${clientName}",phonePlaceholder:"Numero di telefono",separatorText:"o",title:"Crea il tuo account",usernamePlaceholder:"Nome utente"}},"signup-password":{"signup-password":{buttonText:"Continua",description:"Registrati per continuare",hidePasswordText:"Nascondi password","no-password":"La password è obbligatoria",pageTitle:"Registrati | ${clientName}","password-policy-not-met":"La password non soddisfa i requisiti","password-too-weak":"La password è troppo debole",passwordPlaceholder:"Password",showPasswordText:"Mostra password",title:"Crea la tua password"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Continua",codeLabel:"Codice di verifica",codePlaceholder:"Inserisci il codice",defaultDescription:"Inserisci il codice di verifica inviato al tuo telefono",description:"Abbiamo inviato un codice a ${username}","invalid-code":"Codice non valido",noCode:"Inserisci il codice di verifica",pageTitle:"Inserisci il codice | ${clientName}",resendText:"Reinvia codice",sessionExpired:"La sessione è scaduta. Riprova.",title:"Controlla il tuo telefono",unexpectedError:"Si è verificato un errore imprevisto"}},status:g$},CF=Object.freeze(Object.defineProperty({__proto__:null,common:a$,consent:c$,default:xF,invitation:l$,login:d$,mfa:u$,organizations:f$,passkeys:p$,signup:h$,status:g$},Symbol.toStringTag,{value:"Module"})),m$={common:{alertListTitle:"Varsler",backText:"Gå tilbake",cancelText:"Avbryt",closeText:"Lukk",contactSupportText:"Kontakt kundestøtte",continueText:"Fortsett",copyrightText:"© ${currentYear} ${companyName}",errorText:"Det oppstod en feil",hidePasswordText:"Skjul passord",loadingText:"Laster...",orText:"eller",privacyPolicyText:"Personvernerklæring",showPasswordText:"Vis passord",termsOfServiceText:"Vilkår for bruk",termsShortText:"Vilkår",tryAgainText:"Prøv igjen"}},y$={consent:{buttonText:"Godta",cancelButtonText:"Avslå",description:"${clientName} ber om tilgang til kontoen din",pageTitle:"Godkjenn | ${clientName}",scopesTitle:"Dette vil gi ${clientName} tillatelse til å:",title:"Godkjenn ${clientName}"}},_$={invitation:{acceptButtonText:"Godta invitasjon",description:"${inviterName} har invitert deg til å bli med i ${organizationName} på ${clientName}",pageTitle:"Invitasjon | ${clientName}",title:"Du har blitt invitert"}},w$={login:{alertListTitle:"Varsler",buttonText:"Fortsett",description:"Logg inn på ${clientName}.",editEmailText:"Rediger",emailPlaceholder:"E-postadresse",enterACodeBtn:"Logg inn med en kode",federatedConnectionButtonText:"Fortsett med ${connectionName}",footerLinkText:"Registrer deg",footerText:"Har du ikke en konto?",forgotPasswordText:"Har du glemt passordet?",hidePasswordText:"Skjul passord",invalidEmail:"Ugyldig e-postadresse",invalidIdentifier:"Ugyldig e-postadresse eller brukernavn",invitationDescription:"Logg inn for å godta ${inviterName} sin invitasjon til å bli med i ${companyName} på ${clientName}.",invitationTitle:"Du har blitt invitert!",logoAltText:"${companyName}","no-email":"Vennligst oppgi en e-postadresse","no-password":"Passord er påkrevd",pageTitle:"Logg inn | ${clientName}",passwordLoginNotAvailable:"Passordautentisering er ikke tilgjengelig",passwordPlaceholder:"Passord",phonePlaceholder:"Telefonnummer",separatorText:"eller",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",showPasswordText:"Vis passord",signupActionLinkText:"Registrer deg",signupActionText:"Har du ikke en konto?",title:"Velkommen",tooManyFailedLogins:"For mange mislykkede innloggingsforsøk. Vennligst prøv igjen senere.",unverifiedEmail:"Vennligst bekreft e-postadressen din før du logger inn",userAccountDoesNotExist:"Brukerkontoen finnes ikke",usernamePlaceholder:"Brukernavn eller e-postadresse",usernameTooLong:"Brukernavnet må være ${max} tegn eller færre",usernameTooShort:"Brukernavnet må være minst ${min} tegn",wrongCredentials:"Feil brukernavn eller passord",passkeyButtonText:"Logg inn med passkey"}},b$={mfa:{backupCodeText:"Bruk reservekode",description:"Velg en bekreftelsesmetode",pageTitle:"Flerfaktorautentisering | ${clientName}",title:"Bekreft identiteten din"}},v$={"passkey-enrollment-nudge":{title:"Sikre kontoen din med en passnøkkel",description:"Passnøkler bruker enhetens biometri eller PIN-kode for å logge deg inn raskere og sikrere.",enrollButtonText:"Sett opp passnøkkel",snoozeButtonText:"Kanskje senere",optOutLinkText:"Ikke vis dette igjen",pageTitle:"Sett Opp Passnøkkel | ${clientName}"},"passkey-enrollment":{title:"Opprett passnøkkelen din",description:"Følg instruksjonene fra nettleseren for å opprette en passnøkkel for denne kontoen.",errorMessage:"Kunne ikke opprette passnøkkel. Vennligst prøv igjen.",cancelLinkText:"Hopp over for nå",retryButtonText:"Prøv igjen",enrollmentComplete:"Passnøkkelen din er konfigurert. Du kan lukke denne siden.",pageTitle:"Opprett Passnøkkel | ${clientName}"},"passkey-challenge":{title:"Logg inn med passkey",description:"Følg instruksjonene fra nettleseren for å bekrefte identiteten din.",errorMessage:"Autentisering med passkey mislyktes. Vennligst prøv igjen.",cancelLinkText:"Tilbake til innlogging",retryButtonText:"Prøv igjen",pageTitle:"Logg inn med passkey | ${clientName}"}},A$={organizations:{description:"Velg hvilken organisasjon du vil logge inn på",pageTitle:"Velg organisasjon | ${clientName}",searchPlaceholder:"Søk etter organisasjoner",title:"Velg din organisasjon"}},k$={signup:{buttonText:"Registrer deg",confirmPasswordPlaceholder:"Bekreft passord",description:"Registrer deg for å fortsette","email-already-exists":"E-postadressen er allerede registrert",emailPlaceholder:"E-postadresse",federatedConnectionButtonText:"Fortsett med ${connectionName}",hidePasswordText:"Skjul passord","invalid-email-format":"Ugyldig e-postadresse",loginActionLinkText:"Logg inn",loginActionText:"Har du allerede en konto?","no-email":"Vennligst oppgi en e-postadresse","no-password":"Passord er påkrevd","no-username":"Brukernavn er påkrevd",pageTitle:"Registrer deg | ${clientName}",passwordPlaceholder:"Passord",passwordsDidntMatch:"Passordene samsvarer ikke",phonePlaceholder:"Telefonnummer",privacyPolicyLinkText:"Personvernerklæring",separatorText:"eller",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",showPasswordText:"Vis passord",termsOfServiceLinkText:"Vilkår for bruk",termsText:"Ved å registrere deg godtar du våre",title:"Opprett kontoen din","username-already-exists":"Dette brukernavnet er allerede tatt",usernamePlaceholder:"Brukernavn",verifyEmailText:"Sjekk e-posten din for å bekrefte kontoen"}},S$={status:{continueButtonText:"Fortsett",errorTitle:"Feil",pageTitle:"Status | ${clientName}",successTitle:"Vellykket",title:"Status"}},TF={common:m$,consent:y$,"device-flow":{"device-flow":{buttonText:"Fortsett",codePlaceholder:"Skriv inn kode",description:"Skriv inn koden som vises på enheten din","expired-code":"Koden har utløpt","invalid-code":"Koden du skrev inn er ugyldig",pageTitle:"Enhetsaktivering | ${clientName}",title:"Aktiver enheten din"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Fortsett",codeLabel:"Bekreftelseskode",codePlaceholder:"Skriv inn kode",defaultDescription:"Skriv inn bekreftelseskoden som ble sendt til e-posten din",description:"Vi sendte en kode til ${email}","invalid-code":"Ugyldig kode",noCode:"Vennligst skriv inn bekreftelseskoden",pageTitle:"Skriv inn kode | ${clientName}",resendText:"Send kode på nytt",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",title:"Sjekk e-posten din",unexpectedError:"En uventet feil oppstod"}},"email-verification":{"email-verification":{description:"Vi sendte en e-post til ${email}",pageTitle:"Bekreft e-post | ${clientName}",resendText:"Send e-post på nytt",successDescription:"E-postadressen din er bekreftet.",successTitle:"E-post bekreftet",title:"Bekreft e-posten din"}},invitation:_$,login:w$,"login-id":{"login-id":{alertListTitle:"Varsler","auth0-users-validation":"Noe gikk galt, vennligst prøv igjen senere","authentication-failure":"Beklager, noe gikk galt under innloggingsforsøket",buttonText:"Fortsett","captcha-client-failure":"Vi kunne ikke laste sikkerhetsutfordringen. Vennligst prøv igjen. (Feilkode: #{errorCode})","captcha-validation-failure":"Beklager, noe gikk galt under validering av captcha-svaret. Vennligst prøv igjen.",captchaCodePlaceholder:"Skriv inn koden som vises ovenfor","custom-script-error-code":"Noe gikk galt, vennligst prøv igjen senere.",description:"Logg inn på ${clientName}.",editEmailText:"Rediger",emailPlaceholder:"E-postadresse",federatedConnectionButtonText:"Fortsett med ${connectionName}",footerLinkText:"Registrer deg",footerText:"Har du ikke en konto?",forgotPasswordText:"Har du glemt passordet?",hidePasswordText:"Skjul passord","invalid-captcha":"Løs utfordringen for å bekrefte at du ikke er en robot.","invalid-code":"Ugyldig kode","invalid-connection":"Ugyldig tilkobling","invalid-email-format":"Ugyldig e-postadresse","invalid-email-phone":"Skriv inn en gyldig e-postadresse eller telefonnummer. Telefonnumre må inkludere landskode.","invalid-email-phone-username":"Skriv inn en gyldig e-postadresse, telefonnummer eller brukernavn. Telefonnumre må inkludere landskode.","invalid-email-username":"Skriv inn en gyldig e-postadresse eller brukernavn","invalid-expired-code":"Ugyldig eller utløpt brukerkode","invalid-login-id":"Ugyldig innloggings-ID","invalid-phone-username":"Skriv inn et gyldig telefonnummer eller brukernavn. Telefonnumre må inkludere landskode.","invalid-recaptcha":"Kryss av i boksen for å bekrefte at du ikke er en robot.","invalid-username":"Brukernavnet kan bare inneholde alfanumeriske tegn eller: '${characters}'. Brukernavnet må ha mellom ${min} og ${max} tegn.",invitationDescription:"Logg inn for å godta ${inviterName} sin invitasjon til å bli med i ${companyName} på ${clientName}.",invitationTitle:"Du har blitt invitert!","ip-blocked":"Vi har oppdaget mistenkelig innloggingsaktivitet, og videre forsøk vil bli blokkert. Vennligst kontakt administratoren.",logoAltText:"${companyName}","no-db-connection":"Ugyldig tilkobling","no-email":"Vennligst oppgi en e-postadresse","no-email-phone":"E-postadresse eller telefonnummer er påkrevd","no-email-phone-username":"Telefonnummer, brukernavn eller e-postadresse er påkrevd","no-email-username":"E-postadresse eller brukernavn er påkrevd","no-password":"Passord er påkrevd","no-phone":"Vennligst oppgi et telefonnummer","no-phone-username":"Telefonnummer eller brukernavn er påkrevd","no-username":"Brukernavn er påkrevd",pageTitle:"Logg inn | ${clientName}","password-breached":"Vi har oppdaget et potensielt sikkerhetsproblem med denne kontoen. For å beskytte kontoen din har vi forhindret denne innloggingen. Vennligst tilbakestill passordet ditt for å fortsette.",passwordPlaceholder:"Passord",phoneOrEmailPlaceholder:"E-post eller telefonnummer",phoneOrUsernameOrEmailPlaceholder:"Telefon, brukernavn eller e-post",phoneOrUsernamePlaceholder:"Telefonnummer eller brukernavn",phonePlaceholder:"Telefonnummer","same-user-login":"For mange innloggingsforsøk for denne brukeren. Vennligst vent og prøv igjen senere.",selectCountryCode:"Velg landskode, for øyeblikket satt til ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"eller",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",showPasswordText:"Vis passord",signupActionLinkText:"Registrer deg",signupActionText:"Har du ikke en konto?",termsAndConditionsTemplate:'Ved å fortsette godtar du våre <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">vilkår</a>.',title:"Velkommen","user-blocked":"Kontoen din har blitt blokkert etter flere påfølgende innloggingsforsøk.",userAccountDoesNotExist:"Brukerkontoen finnes ikke",usernameOnlyPlaceholder:"Brukernavn",usernameOrEmailPlaceholder:"Brukernavn eller e-postadresse",usernamePlaceholder:"Brukernavn eller e-postadresse",usernameTooLong:"Brukernavnet må være ${max} tegn eller færre",usernameTooShort:"Brukernavnet må være minst ${min} tegn","wrong-credentials":"Feil brukernavn eller passord","wrong-email-credentials":"Feil e-postadresse eller passord","wrong-email-phone-credentials":"Feil e-postadresse, telefonnummer eller passord. Telefonnumre må inkludere landskode.","wrong-email-phone-username-credentials":"Feil e-postadresse, telefonnummer, brukernavn eller passord. Telefonnumre må inkludere landskode.","wrong-email-username-credentials":"Feil e-postadresse, brukernavn eller passord","wrong-phone-credentials":"Feil telefonnummer eller passord","wrong-phone-username-credentials":"Feil telefonnummer, brukernavn eller passord. Telefonnumre må inkludere landskode.","wrong-username-credentials":"Feil brukernavn eller passord",passkeyButtonText:"Logg inn med passkey"}},"login-password":{"login-password":{buttonText:"Logg inn",description:"Logg inn på ${clientName}",forgotPasswordText:"Har du glemt passordet?",hidePasswordText:"Skjul passord","no-password":"Passord er påkrevd",pageTitle:"Logg inn | ${clientName}","password-breached":"Vi har oppdaget et potensielt sikkerhetsproblem med denne kontoen. For å beskytte kontoen din har vi forhindret denne innloggingen. Vennligst tilbakestill passordet ditt for å fortsette.",passwordPlaceholder:"Passord",showPasswordText:"Vis passord",signingInAs:"Logger inn som ${email}",title:"Oppgi passord",unverifiedEmail:"Vennligst bekreft e-postadressen din før du logger inn","user-blocked":"Kontoen din har blitt blokkert etter flere påfølgende innloggingsforsøk.","wrong-credentials":"Feil passord"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-post",authMethodEmailOrPhone:"e-post eller telefonnummer",authMethodPhone:"telefonnummer",description:"Logg inn med din ${authMethod}",emailOrPhonePlaceholder:"E-postadresse eller telefonnummer",emailPlaceholder:"E-postadresse",invalidEmail:"Vennligst oppgi en gyldig e-postadresse",invalidIdentifier:"Vennligst oppgi en gyldig e-postadresse eller telefonnummer",invalidPhone:"Vennligst oppgi et gyldig telefonnummer med landskode",noEmail:"Vennligst oppgi e-postadressen din",noPhone:"Vennligst oppgi telefonnummeret ditt",phonePlaceholder:"Telefonnummer",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",title:"Logg inn med en kode",userAccountDoesNotExist:"Brukerkontoen finnes ikke"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Klikk på lenken i e-posten for å logge inn",description:"Vi sendte en lenke til ${username}. Klikk på den for å logge inn.",resendText:"Send lenke på nytt",spamText:"Fikk du ikke e-posten? Sjekk søppelpostmappen.",title:"Sjekk e-posten din"}},mfa:b$,"mfa-email":{"mfa-email":{buttonText:"Fortsett",codePlaceholder:"Skriv inn kode",description:"Vi sendte en kode til ${email}","invalid-code":"Koden du skrev inn er ugyldig",pageTitle:"E-postbekreftelse | ${clientName}",resendText:"Send kode på nytt",title:"Sjekk e-posten din"}},"mfa-otp":{"mfa-otp":{buttonText:"Fortsett",codePlaceholder:"Skriv inn kode",description:"Skriv inn den 6-sifrede koden fra autentiseringsappen din","invalid-code":"Koden du skrev inn er ugyldig",pageTitle:"Skriv inn kode | ${clientName}",title:"Skriv inn koden din"},"mfa-totp-enrollment":{title:"Sett opp autentisering",description:"Skann QR-koden nedenfor med autentiseringsappen din, og skriv deretter inn den 6-sifrede koden for å verifisere",secretLabel:"Eller skriv inn denne koden manuelt:",codePlaceholder:"Skriv inn kode",continueButtonText:"Bekreft og aktiver","invalid-code":"Koden du skrev inn er ugyldig. Vennligst prøv igjen.","transaction-not-found":"Registreringsøkten din har utløpt, du må starte på nytt.",pageTitle:"Sett opp autentisering | ${clientName}",unexpectedError:"Noe gikk galt. Vennligst prøv igjen.",enrollmentComplete:"MFA-registreringen er fullført. Du kan lukke denne siden."},"mfa-totp-challenge":{title:"Bekreft identiteten din",description:"Skriv inn den 6-sifrede koden fra autentiseringsappen din",codePlaceholder:"Skriv inn kode",continueButtonText:"Fortsett","invalid-code":"Koden du skrev inn er ugyldig","transaction-not-found":"Registreringsøkten din har utløpt, du må starte på nytt.",unexpectedError:"Noe gikk galt. Vennligst prøv igjen.",pageTitle:"Bekreft identitet | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Bruk telefonnummeret ditt for å logge inn | ${clientName}",title:"Bekreft identiteten din",description:"Vi sendte en kode til ${phoneNumber}",continueButtonText:"Fortsett",changePhoneText:"Velg et annet telefonnummer.",smsButtonText:"Tekstmelding",voiceButtonText:"Taleanrop",chooseMessageTypeText:"Hvordan vil du motta koden?",pickAuthenticatorText:"Prøv en annen metode",logoAltText:"${companyName}",codePlaceholder:"Skriv inn kode","send-sms-failed":"Det oppstod et problem med å sende SMS-en","send-voice-failed":"Det oppstod et problem med å ringe taleanropet","invalid-phone-format":"Telefonnummeret kan bare inneholde sifre.","invalid-phone":"Det ser ut som telefonnummeret ditt ikke er gyldig. Sjekk og prøv igjen.","too-many-sms":"Du har overskredet maksimalt antall telefonmeldinger per time. Vent noen minutter og prøv igjen.","too-many-voice":"Du har overskredet maksimalt antall telefonmeldinger per time. Vent noen minutter og prøv igjen.","transaction-not-found":"Registreringstransaksjonen din har utløpt, du må starte på nytt.","no-phone":"Skriv inn et telefonnummer",noCode:"Vennligst skriv inn bekreftelseskoden",invalidCode:"Koden du skrev inn er ugyldig. Prøv igjen.",unexpectedError:"Noe gikk galt. Prøv igjen.",resendSuccess:"Vi sendte en ny kode til telefonen din",enrollmentComplete:"MFA-registreringen er fullført. Du kan lukke denne siden."},"mfa-phone-enrollment":{pageTitle:"Skriv inn telefonnummeret ditt for å logge inn med en telefonkode | ${clientName}",title:"Sikre kontoen din",description:"Skriv inn landskoden og telefonnummeret vi kan sende en 6-sifret kode til:",continueButtonText:"Fortsett",smsButtonText:"Tekstmelding",voiceButtonText:"Taleanrop",chooseMessageTypeText:"Hvordan vil du motta koden?",pickAuthenticatorText:"Prøv en annen metode",placeholder:"Skriv inn telefonnummeret ditt",logoAltText:"${companyName}",selectCountryCode:"Velg landskode, for øyeblikket satt til ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Det oppstod et problem med å sende SMS-en","send-voice-failed":"Det oppstod et problem med å ringe taleanropet","sms-authenticator-error":"Vi kunne ikke sende SMS-en. Prøv igjen senere.","invalid-phone-format":"Telefonnummeret kan bare inneholde sifre.","invalid-phone":"Det ser ut som telefonnummeret ditt ikke er gyldig. Sjekk og prøv igjen.","too-many-sms":"Du har overskredet maksimalt antall telefonmeldinger per time. Vent noen minutter og prøv igjen.","too-many-voice":"Du har overskredet maksimalt antall telefonmeldinger per time. Vent noen minutter og prøv igjen.","transaction-not-found":"Registreringstransaksjonen din har utløpt, du må starte på nytt.","no-phone":"Skriv inn et telefonnummer","phone-is-too-short":"Telefonnummeret er for kort","phone-is-too-long":"Telefonnummeret er for langt"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Velg bekreftelsesmetode | ${clientName}",title:"Velg bekreftelsesmetode",description:"Velg hvordan du vil bekrefte identiteten din",authenticatorAppLabel:"Autentiseringsapp",authenticatorAppDescription:"Bruk autentiseringsappen din for å få en bekreftelseskode",smsLabel:"Tekstmelding",smsDescription:"Få en bekreftelseskode sendt til telefonen din",passkeyLabel:"Passnøkkel",passkeyDescription:"Bruk enhetens biometri eller sikkerhetsnøkkel"}},"mfa-push":{"mfa-push":{description:"Vi sendte en varsling til enheten din",pageTitle:"Push-varsling | ${clientName}",resendText:"Send varsling på nytt",title:"Godkjenn forespørselen",useCodeText:"Skriv inn kode manuelt"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Fortsett",codePlaceholder:"Gjenopprettingskode",description:"Skriv inn en av gjenopprettingskodene dine","invalid-code":"Gjenopprettingskoden du skrev inn er ugyldig",pageTitle:"Gjenopprettingskode | ${clientName}",title:"Skriv inn gjenopprettingskode"}},"mfa-voice":{"mfa-voice":{buttonText:"Ring meg",codePlaceholder:"Skriv inn kode",description:"Vi ringer ${phoneNumber} med koden din","invalid-code":"Koden du skrev inn er ugyldig",pageTitle:"Taleanrop | ${clientName}",title:"Motta en telefonsamtale"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Prøv igjen",description:"Sett inn sikkerhetsnøkkelen din og følg instruksjonene",pageTitle:"Sikkerhetsnøkkel | ${clientName}",title:"Bruk sikkerhetsnøkkelen din"}},passkeys:v$,organizations:A$,"reset-password":{"reset-password":{backToLoginText:"Tilbake til innlogging",buttonText:"Fortsett",codeExpired:"Koden for tilbakestilling av passord har utløpt. Vennligst be om en ny.",confirmPasswordLabel:"Bekreft passord",confirmPasswordPlaceholder:"Bekreft passord",description:"Oppgi e-postadressen din for å tilbakestille passordet",emailPlaceholder:"E-postadresse",failed:"Tilbakestilling av passord mislyktes. Vennligst prøv igjen.","invalid-email-format":"Ugyldig e-postadresse","no-email":"Vennligst oppgi en e-postadresse",pageTitle:"Tilbakestill passord | ${clientName}",passwordLabel:"Nytt passord",passwordPlaceholder:"Nytt passord",passwordTooWeak:"Passordet er for svakt",passwordsDidntMatch:"Passordene samsvarer ikke",successDescription:"Vi har sendt en lenke for tilbakestilling av passord til e-postadressen din.",successTitle:"Sjekk e-posten din",title:"Har du glemt passordet?","user-not-found":"Brukeren ble ikke funnet"},"reset-password-code":{backToLoginText:"Tilbake til innlogging",buttonText:"Tilbakestill passord",codeLabel:"Tilbakestillingskode",codePlaceholder:"Skriv inn 6-sifret kode",confirmPasswordLabel:"Bekreft passord",confirmPasswordPlaceholder:"Bekreft passord",defaultDescription:"Skriv inn koden som ble sendt til e-posten din og velg et nytt passord",description:"Vi sendte en kode til ${email}",failed:"Tilbakestilling av passord mislyktes. Vennligst prøv igjen.",invalidCode:"Koden du skrev inn er ugyldig eller har utløpt",noCode:"Vennligst skriv inn tilbakestillingskoden",pageTitle:"Skriv inn tilbakestillingskode | ${clientName}",passwordLabel:"Nytt passord",passwordPlaceholder:"Nytt passord",passwordTooWeak:"Passordet er for svakt",passwordsDidntMatch:"Passordene samsvarer ikke",resendFailed:"Kunne ikke sende koden på nytt. Vennligst prøv igjen.",resendSuccess:"En ny kode har blitt sendt til e-posten din",resendText:"Send kode på nytt",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",title:"Skriv inn tilbakestillingskode"}},signup:k$,"signup-id":{"signup-id":{buttonText:"Fortsett",description:"Registrer deg for å fortsette","email-already-exists":"E-postadressen er allerede registrert",emailPlaceholder:"E-postadresse",federatedConnectionButtonText:"Fortsett med ${connectionName}","invalid-email-format":"Ugyldig e-postadresse",loginActionLinkText:"Logg inn",loginActionText:"Har du allerede en konto?","no-email":"Vennligst oppgi en e-postadresse",pageTitle:"Registrer deg | ${clientName}",phonePlaceholder:"Telefonnummer",separatorText:"eller",title:"Opprett kontoen din",usernamePlaceholder:"Brukernavn"}},"signup-password":{"signup-password":{buttonText:"Fortsett",description:"Opprett et passord for å fortsette",hidePasswordText:"Skjul passord","no-password":"Passord er påkrevd",pageTitle:"Registrer deg | ${clientName}","password-policy-not-met":"Passordet oppfyller ikke kravene","password-too-weak":"Passordet er for svakt",passwordPlaceholder:"Passord",showPasswordText:"Vis passord",title:"Opprett passordet ditt"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Fortsett",codeLabel:"Bekreftelseskode",codePlaceholder:"Skriv inn kode",defaultDescription:"Skriv inn bekreftelseskoden som ble sendt til telefonen din",description:"Vi sendte en kode til ${username}","invalid-code":"Ugyldig kode",noCode:"Vennligst skriv inn bekreftelseskoden",pageTitle:"Skriv inn kode | ${clientName}",resendText:"Send kode på nytt",sessionExpired:"Økten din har utløpt. Vennligst prøv igjen.",title:"Sjekk telefonen din",unexpectedError:"En uventet feil oppstod"}},status:S$},$F=Object.freeze(Object.defineProperty({__proto__:null,common:m$,consent:y$,default:TF,invitation:_$,login:w$,mfa:b$,organizations:A$,passkeys:v$,signup:k$,status:S$},Symbol.toStringTag,{value:"Module"})),E$={common:{alertListTitle:"Powiadomienia",backText:"Wróć",cancelText:"Anuluj",closeText:"Zamknij",contactSupportText:"Potrzebujesz pomocy?",continueText:"Kontynuuj",copyrightText:"© ${currentYear} ${companyName}",errorText:"Coś poszło nie tak. Spróbuj ponownie.",hidePasswordText:"Ukryj hasło",loadingText:"Ładowanie...",orText:"lub",privacyPolicyText:"Polityka prywatności",showPasswordText:"Pokaż hasło",termsOfServiceText:"Regulamin",termsShortText:"Zasady",tryAgainText:"Spróbuj ponownie"}},x$={consent:{buttonText:"Zaakceptuj",cancelButtonText:"Odmów",description:"${clientName} prosi o dostęp do Twojego konta",pageTitle:"Autoryzacja | ${clientName}",scopesTitle:"Umożliwi to ${clientName}:",title:"Autoryzuj ${clientName}"}},C$={invitation:{acceptButtonText:"Przyjmij zaproszenie",description:"${inviterName} zaprosił Cię do dołączenia do ${organizationName} w ${clientName}",pageTitle:"Zaproszenie | ${clientName}",title:"Otrzymałeś zaproszenie"}},T$={login:{alertListTitle:"Powiadomienia",buttonText:"Kontynuuj",description:"Zaloguj się do ${clientName}.",editEmailText:"Edytuj",emailPlaceholder:"Adres e-mail",enterACodeBtn:"Zaloguj się kodem",federatedConnectionButtonText:"Kontynuuj z ${connectionName}",footerLinkText:"Zarejestruj się",footerText:"Nie masz konta?",forgotPasswordText:"Zapomniałeś hasła?",hidePasswordText:"Ukryj hasło",invalidEmail:"Nieprawidłowy adres e-mail",invalidIdentifier:"Nieprawidłowy adres e-mail lub nazwa użytkownika",invitationDescription:"Zaloguj się, aby przyjąć zaproszenie od ${inviterName} do dołączenia do ${companyName} w ${clientName}.",invitationTitle:"Otrzymałeś zaproszenie!",logoAltText:"${companyName}","no-email":"Wprowadź adres e-mail","no-password":"Hasło jest wymagane",pageTitle:"Logowanie | ${clientName}",passwordLoginNotAvailable:"Logowanie hasłem jest niedostępne",passwordPlaceholder:"Hasło",phonePlaceholder:"Numer telefonu",separatorText:"lub",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",showPasswordText:"Pokaż hasło",signupActionLinkText:"Zarejestruj się",signupActionText:"Nie masz konta?",title:"Witamy",tooManyFailedLogins:"Zbyt wiele nieudanych prób logowania. Spróbuj ponownie później.",unverifiedEmail:"Zweryfikuj swój adres e-mail przed zalogowaniem",userAccountDoesNotExist:"Konto użytkownika nie istnieje",usernamePlaceholder:"Nazwa użytkownika lub adres e-mail",usernameTooLong:"Nazwa użytkownika musi mieć maksymalnie ${max} znaków",usernameTooShort:"Nazwa użytkownika musi mieć co najmniej ${min} znaków",wrongCredentials:"Nieprawidłowa nazwa użytkownika lub hasło",passkeyButtonText:"Zaloguj się za pomocą passkey"}},$$={mfa:{backupCodeText:"Użyj kodu zapasowego",description:"Wybierz metodę weryfikacji",pageTitle:"Uwierzytelnianie wieloskładnikowe | ${clientName}",title:"Zweryfikuj swoją tożsamość"}},I$={"passkey-enrollment-nudge":{title:"Zabezpiecz swoje konto kluczem dostępu",description:"Klucze dostępu wykorzystują biometrię lub PIN urządzenia, aby logować się szybciej i bezpieczniej.",enrollButtonText:"Skonfiguruj klucz dostępu",snoozeButtonText:"Może później",optOutLinkText:"Nie pokazuj ponownie",pageTitle:"Konfiguracja Klucza Dostępu | ${clientName}"},"passkey-enrollment":{title:"Utwórz klucz dostępu",description:"Postępuj zgodnie z instrukcjami przeglądarki, aby utworzyć klucz dostępu dla tego konta.",errorMessage:"Nie udało się utworzyć klucza dostępu. Spróbuj ponownie.",cancelLinkText:"Pomiń na razie",retryButtonText:"Spróbuj ponownie",enrollmentComplete:"Twój klucz dostępu został pomyślnie skonfigurowany. Możesz zamknąć tę stronę.",pageTitle:"Tworzenie Klucza Dostępu | ${clientName}"},"passkey-challenge":{title:"Zaloguj się za pomocą passkey",description:"Postępuj zgodnie z instrukcjami przeglądarki, aby zweryfikować swoją tożsamość.",errorMessage:"Uwierzytelnianie za pomocą passkey nie powiodło się. Spróbuj ponownie.",cancelLinkText:"Powrót do logowania",retryButtonText:"Spróbuj ponownie",pageTitle:"Logowanie za pomocą passkey | ${clientName}"}},z$={organizations:{description:"Wybierz organizację, do której chcesz się zalogować",pageTitle:"Wybierz organizację | ${clientName}",searchPlaceholder:"Szukaj organizacji",title:"Wybierz swoją organizację"}},P$={signup:{buttonText:"Zarejestruj się",confirmPasswordPlaceholder:"Potwierdź hasło",description:"Zarejestruj się, aby kontynuować","email-already-exists":"Ten adres e-mail jest już zarejestrowany",emailPlaceholder:"Adres e-mail",federatedConnectionButtonText:"Kontynuuj z ${connectionName}",hidePasswordText:"Ukryj hasło","invalid-email-format":"Nieprawidłowy adres e-mail",loginActionLinkText:"Zaloguj się",loginActionText:"Masz już konto?","no-email":"Wprowadź adres e-mail","no-password":"Hasło jest wymagane","no-username":"Nazwa użytkownika jest wymagana",pageTitle:"Rejestracja | ${clientName}",passwordPlaceholder:"Hasło",passwordsDidntMatch:"Hasła nie są zgodne",phonePlaceholder:"Numer telefonu",privacyPolicyLinkText:"Polityka prywatności",separatorText:"lub",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",showPasswordText:"Pokaż hasło",termsOfServiceLinkText:"Regulamin",termsText:"Rejestrując się, akceptujesz nasz",title:"Utwórz konto","username-already-exists":"Ta nazwa użytkownika jest już zajęta",usernamePlaceholder:"Nazwa użytkownika",verifyEmailText:"Sprawdź swoją pocztę, aby zweryfikować konto"}},N$={status:{continueButtonText:"Kontynuuj",errorTitle:"Błąd",pageTitle:"Status | ${clientName}",successTitle:"Sukces",title:"Status"}},IF={common:E$,consent:x$,"device-flow":{"device-flow":{buttonText:"Kontynuuj",codePlaceholder:"Wprowadź kod",description:"Wprowadź kod wyświetlony na Twoim urządzeniu","expired-code":"Kod wygasł","invalid-code":"Wprowadzony kod jest nieprawidłowy",pageTitle:"Aktywacja urządzenia | ${clientName}",title:"Aktywuj swoje urządzenie"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Kontynuuj",codeLabel:"Kod weryfikacyjny",codePlaceholder:"Wprowadź kod",defaultDescription:"Wprowadź kod weryfikacyjny wysłany na Twój adres e-mail",description:"Wysłaliśmy kod na ${email}","invalid-code":"Nieprawidłowy kod",noCode:"Wprowadź kod weryfikacyjny",pageTitle:"Wprowadź kod | ${clientName}",resendText:"Wyślij ponownie kod",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",title:"Sprawdź swoją pocztę",unexpectedError:"Wystąpił nieoczekiwany błąd"}},"email-verification":{"email-verification":{description:"Wysłaliśmy wiadomość na ${email}",pageTitle:"Weryfikacja e-mail | ${clientName}",resendText:"Wyślij ponownie e-mail",successDescription:"Twój adres e-mail został pomyślnie zweryfikowany.",successTitle:"E-mail zweryfikowany",title:"Zweryfikuj swój adres e-mail"}},invitation:C$,login:T$,"login-id":{"login-id":{alertListTitle:"Powiadomienia","auth0-users-validation":"Coś poszło nie tak, spróbuj ponownie później","authentication-failure":"Przepraszamy, wystąpił błąd podczas logowania",buttonText:"Kontynuuj","captcha-client-failure":"Nie udało się załadować weryfikacji bezpieczeństwa. Spróbuj ponownie. (Kod błędu: #{errorCode})","captcha-validation-failure":"Przepraszamy, wystąpił błąd podczas weryfikacji captcha. Spróbuj ponownie.",captchaCodePlaceholder:"Wprowadź kod widoczny powyżej","custom-script-error-code":"Coś poszło nie tak, spróbuj ponownie później.",description:"Zaloguj się do ${clientName}.",editEmailText:"Edytuj",emailPlaceholder:"Adres e-mail",federatedConnectionButtonText:"Kontynuuj z ${connectionName}",footerLinkText:"Zarejestruj się",footerText:"Nie masz konta?",forgotPasswordText:"Zapomniałeś hasła?",hidePasswordText:"Ukryj hasło","invalid-captcha":"Rozwiąż zadanie, aby potwierdzić, że nie jesteś robotem.","invalid-code":"Nieprawidłowy kod","invalid-connection":"Nieprawidłowe połączenie","invalid-email-format":"Nieprawidłowy adres e-mail","invalid-email-phone":"Wprowadź prawidłowy adres e-mail lub numer telefonu. Numery telefonów muszą zawierać kod kraju.","invalid-email-phone-username":"Wprowadź prawidłowy adres e-mail, numer telefonu lub nazwę użytkownika. Numery telefonów muszą zawierać kod kraju.","invalid-email-username":"Wprowadź prawidłowy adres e-mail lub nazwę użytkownika","invalid-expired-code":"Nieprawidłowy lub wygasły kod użytkownika","invalid-login-id":"Wprowadzono nieprawidłowy identyfikator logowania","invalid-phone-username":"Wprowadź prawidłowy numer telefonu lub nazwę użytkownika. Numery telefonów muszą zawierać kod kraju.","invalid-recaptcha":"Zaznacz pole wyboru, aby potwierdzić, że nie jesteś robotem.","invalid-username":"Nazwa użytkownika może zawierać tylko znaki alfanumeryczne lub: '${characters}'. Nazwa użytkownika powinna mieć od ${min} do ${max} znaków.",invitationDescription:"Zaloguj się, aby przyjąć zaproszenie od ${inviterName} do dołączenia do ${companyName} w ${clientName}.",invitationTitle:"Otrzymałeś zaproszenie!","ip-blocked":"Wykryliśmy podejrzaną aktywność logowania i dalsze próby zostaną zablokowane. Skontaktuj się z administratorem.",logoAltText:"${companyName}","no-db-connection":"Nieprawidłowe połączenie","no-email":"Wprowadź adres e-mail","no-email-phone":"Adres e-mail lub numer telefonu jest wymagany","no-email-phone-username":"Numer telefonu, nazwa użytkownika lub adres e-mail jest wymagany","no-email-username":"Adres e-mail lub nazwa użytkownika jest wymagany","no-password":"Hasło jest wymagane","no-phone":"Wprowadź numer telefonu","no-phone-username":"Numer telefonu lub nazwa użytkownika jest wymagany","no-username":"Nazwa użytkownika jest wymagana",pageTitle:"Logowanie | ${clientName}","password-breached":"Wykryliśmy potencjalny problem z bezpieczeństwem tego konta. Aby chronić Twoje konto, zablokowano to logowanie. Zresetuj hasło, aby kontynuować.",passwordPlaceholder:"Hasło",phoneOrEmailPlaceholder:"E-mail lub numer telefonu",phoneOrUsernameOrEmailPlaceholder:"Telefon, nazwa użytkownika lub e-mail",phoneOrUsernamePlaceholder:"Numer telefonu lub nazwa użytkownika",phonePlaceholder:"Numer telefonu","same-user-login":"Zbyt wiele prób logowania dla tego użytkownika. Poczekaj chwilę i spróbuj ponownie.",selectCountryCode:"Wybierz kod kraju, aktualnie ustawiony na ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"lub",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",showPasswordText:"Pokaż hasło",signupActionLinkText:"Zarejestruj się",signupActionText:"Nie masz konta?",termsAndConditionsTemplate:'Kontynuując, akceptujesz nasze <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Zasady i warunki</a>.',title:"Witamy","user-blocked":"Twoje konto zostało zablokowane po wielu kolejnych nieudanych próbach logowania.",userAccountDoesNotExist:"Konto użytkownika nie istnieje",usernameOnlyPlaceholder:"Nazwa użytkownika",usernameOrEmailPlaceholder:"Nazwa użytkownika lub adres e-mail",usernamePlaceholder:"Nazwa użytkownika",usernameTooLong:"Nazwa użytkownika musi mieć maksymalnie ${max} znaków",usernameTooShort:"Nazwa użytkownika musi mieć co najmniej ${min} znaków","wrong-credentials":"Nieprawidłowa nazwa użytkownika lub hasło","wrong-email-credentials":"Nieprawidłowy adres e-mail lub hasło","wrong-email-phone-credentials":"Nieprawidłowy adres e-mail, numer telefonu lub hasło. Numery telefonów muszą zawierać kod kraju.","wrong-email-phone-username-credentials":"Nieprawidłowy adres e-mail, numer telefonu, nazwa użytkownika lub hasło. Numery telefonów muszą zawierać kod kraju.","wrong-email-username-credentials":"Nieprawidłowy adres e-mail, nazwa użytkownika lub hasło","wrong-phone-credentials":"Nieprawidłowy numer telefonu lub hasło","wrong-phone-username-credentials":"Nieprawidłowy numer telefonu, nazwa użytkownika lub hasło. Numery telefonów muszą zawierać kod kraju.","wrong-username-credentials":"Nieprawidłowa nazwa użytkownika lub hasło",passkeyButtonText:"Zaloguj się za pomocą passkey"}},"login-password":{"login-password":{buttonText:"Zaloguj się",description:"Zaloguj się do ${clientName}",forgotPasswordText:"Zapomniałeś hasła?",hidePasswordText:"Ukryj hasło","no-password":"Hasło jest wymagane",pageTitle:"Logowanie | ${clientName}","password-breached":"Wykryliśmy potencjalny problem z bezpieczeństwem tego konta. Aby chronić Twoje konto, zablokowano to logowanie. Zresetuj hasło, aby kontynuować.",passwordPlaceholder:"Hasło",showPasswordText:"Pokaż hasło",signingInAs:"Logujesz się jako ${email}",title:"Wprowadź hasło",unverifiedEmail:"Zweryfikuj swój adres e-mail przed zalogowaniem","user-blocked":"Twoje konto zostało zablokowane po wielu kolejnych nieudanych próbach logowania.","wrong-credentials":"Nieprawidłowe hasło"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-mail",authMethodEmailOrPhone:"e-mail lub numer telefonu",authMethodPhone:"numer telefonu",description:"Zaloguj się za pomocą swojego ${authMethod}",emailOrPhonePlaceholder:"Adres e-mail lub numer telefonu",emailPlaceholder:"Adres e-mail",invalidEmail:"Wprowadź prawidłowy adres e-mail",invalidIdentifier:"Wprowadź prawidłowy adres e-mail lub numer telefonu",invalidPhone:"Wprowadź prawidłowy numer telefonu z kodem kraju",noEmail:"Wprowadź swój adres e-mail",noPhone:"Wprowadź swój numer telefonu",phonePlaceholder:"Numer telefonu",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",title:"Zaloguj się kodem",userAccountDoesNotExist:"Konto użytkownika nie istnieje"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Kliknij link w wiadomości e-mail, aby się zalogować",description:"Wysłaliśmy link na ${username}. Kliknij go, aby się zalogować.",resendText:"Wyślij ponownie link",spamText:"Nie otrzymałeś wiadomości? Sprawdź folder spam.",title:"Sprawdź swoją pocztę"}},mfa:$$,"mfa-email":{"mfa-email":{buttonText:"Kontynuuj",codePlaceholder:"Wprowadź kod",description:"Wysłaliśmy kod na ${email}","invalid-code":"Wprowadzony kod jest nieprawidłowy",pageTitle:"Weryfikacja e-mail | ${clientName}",resendText:"Wyślij ponownie kod",title:"Sprawdź swoją pocztę"}},"mfa-otp":{"mfa-otp":{buttonText:"Kontynuuj",codePlaceholder:"Wprowadź kod",description:"Wprowadź 6-cyfrowy kod z aplikacji uwierzytelniającej","invalid-code":"Wprowadzony kod jest nieprawidłowy",pageTitle:"Wprowadź kod | ${clientName}",title:"Wprowadź swój kod"},"mfa-totp-enrollment":{title:"Skonfiguruj aplikację uwierzytelniającą",description:"Zeskanuj poniższy kod QR za pomocą aplikacji uwierzytelniającej, a następnie wprowadź 6-cyfrowy kod w celu weryfikacji",secretLabel:"Lub wprowadź ten kod ręcznie:",codePlaceholder:"Wprowadź kod",continueButtonText:"Zweryfikuj i aktywuj","invalid-code":"Wprowadzony kod jest nieprawidłowy. Spróbuj ponownie.","transaction-not-found":"Twoja transakcja rejestracji wygasła, musisz zacząć od nowa.",pageTitle:"Konfiguracja uwierzytelniania | ${clientName}",unexpectedError:"Coś poszło nie tak. Spróbuj ponownie.",enrollmentComplete:"Rejestracja MFA została zakończona. Możesz zamknąć tę stronę."},"mfa-totp-challenge":{title:"Zweryfikuj swoją tożsamość",description:"Wprowadź 6-cyfrowy kod z aplikacji uwierzytelniającej",codePlaceholder:"Wprowadź kod",continueButtonText:"Kontynuuj","invalid-code":"Wprowadzony kod jest nieprawidłowy","transaction-not-found":"Twoja transakcja rejestracji wygasła, musisz zacząć od nowa.",unexpectedError:"Coś poszło nie tak. Spróbuj ponownie.",pageTitle:"Weryfikacja tożsamości | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Użyj swojego numeru telefonu, aby się zalogować | ${clientName}",title:"Zweryfikuj swoją tożsamość",description:"Wysłaliśmy kod na ${phoneNumber}",continueButtonText:"Kontynuuj",changePhoneText:"Wybierz inny numer telefonu.",smsButtonText:"Wiadomość tekstowa",voiceButtonText:"Połączenie głosowe",chooseMessageTypeText:"Jak chcesz otrzymać kod?",pickAuthenticatorText:"Wypróbuj inną metodę",logoAltText:"${companyName}",codePlaceholder:"Wpisz kod","send-sms-failed":"Wystąpił problem z wysłaniem SMS-a","send-voice-failed":"Wystąpił problem z wykonaniem połączenia głosowego","invalid-phone-format":"Numer telefonu może zawierać tylko cyfry.","invalid-phone":"Wygląda na to, że Twój numer telefonu jest nieprawidłowy. Sprawdź i spróbuj ponownie.","too-many-sms":"Przekroczono maksymalną liczbę wiadomości telefonicznych na godzinę. Poczekaj kilka minut i spróbuj ponownie.","too-many-voice":"Przekroczono maksymalną liczbę połączeń telefonicznych na godzinę. Poczekaj kilka minut i spróbuj ponownie.","transaction-not-found":"Twoja transakcja rejestracji wygasła, musisz zacząć od nowa.","no-phone":"Wpisz numer telefonu",noCode:"Wprowadź kod weryfikacyjny",invalidCode:"Wprowadzony kod jest nieprawidłowy. Spróbuj ponownie.",unexpectedError:"Coś poszło nie tak. Spróbuj ponownie.",resendSuccess:"Wysłaliśmy nowy kod na Twój telefon",enrollmentComplete:"Rejestracja MFA została zakończona. Możesz zamknąć tę stronę."},"mfa-phone-enrollment":{pageTitle:"Wpisz swój numer telefonu, aby zalogować się kodem telefonicznym | ${clientName}",title:"Zabezpiecz swoje konto",description:"Wpisz kod kraju i numer telefonu, na który możemy wysłać 6-cyfrowy kod:",continueButtonText:"Kontynuuj",smsButtonText:"Wiadomość tekstowa",voiceButtonText:"Połączenie głosowe",chooseMessageTypeText:"Jak chcesz otrzymać kod?",pickAuthenticatorText:"Wypróbuj inną metodę",placeholder:"Wpisz swój numer telefonu",logoAltText:"${companyName}",selectCountryCode:"Wybierz kod kraju, aktualnie ustawiony na ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Wystąpił problem z wysłaniem SMS-a","send-voice-failed":"Wystąpił problem z wykonaniem połączenia głosowego","sms-authenticator-error":"Nie udało się wysłać SMS-a. Spróbuj ponownie później.","invalid-phone-format":"Numer telefonu może zawierać tylko cyfry.","invalid-phone":"Wygląda na to, że Twój numer telefonu jest nieprawidłowy. Sprawdź i spróbuj ponownie.","too-many-sms":"Przekroczono maksymalną liczbę wiadomości telefonicznych na godzinę. Poczekaj kilka minut i spróbuj ponownie.","too-many-voice":"Przekroczono maksymalną liczbę połączeń telefonicznych na godzinę. Poczekaj kilka minut i spróbuj ponownie.","transaction-not-found":"Twoja transakcja rejestracji wygasła, musisz zacząć od nowa.","no-phone":"Wpisz numer telefonu","phone-is-too-short":"Numer telefonu jest za krótki","phone-is-too-long":"Numer telefonu jest za długi"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Wybierz metodę weryfikacji | ${clientName}",title:"Wybierz metodę weryfikacji",description:"Wybierz, w jaki sposób chcesz zweryfikować swoją tożsamość",authenticatorAppLabel:"Aplikacja uwierzytelniająca",authenticatorAppDescription:"Użyj aplikacji uwierzytelniającej, aby uzyskać kod weryfikacyjny",smsLabel:"Wiadomość tekstowa",smsDescription:"Otrzymaj kod weryfikacyjny wysłany na swój telefon",passkeyLabel:"Klucz dostępu",passkeyDescription:"Użyj biometrii urządzenia lub klucza bezpieczeństwa"}},"mfa-push":{"mfa-push":{description:"Wysłaliśmy powiadomienie na Twoje urządzenie",pageTitle:"Powiadomienie push | ${clientName}",resendText:"Wyślij ponownie powiadomienie",title:"Zatwierdź żądanie",useCodeText:"Wprowadź kod ręcznie"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Kontynuuj",codePlaceholder:"Kod odzyskiwania",description:"Wprowadź jeden z kodów odzyskiwania","invalid-code":"Wprowadzony kod odzyskiwania jest nieprawidłowy",pageTitle:"Kod odzyskiwania | ${clientName}",title:"Wprowadź kod odzyskiwania"}},"mfa-voice":{"mfa-voice":{buttonText:"Zadzwoń do mnie",codePlaceholder:"Wprowadź kod",description:"Zadzwonimy na ${phoneNumber} z Twoim kodem","invalid-code":"Wprowadzony kod jest nieprawidłowy",pageTitle:"Połączenie głosowe | ${clientName}",title:"Odbierz połączenie telefoniczne"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Spróbuj ponownie",description:"Włóż klucz bezpieczeństwa i postępuj zgodnie z instrukcjami",pageTitle:"Klucz bezpieczeństwa | ${clientName}",title:"Użyj klucza bezpieczeństwa"}},passkeys:I$,organizations:z$,"reset-password":{"reset-password":{backToLoginText:"Wróć do logowania",buttonText:"Kontynuuj",codeExpired:"Kod resetu hasła wygasł. Poproś o nowy.",confirmPasswordLabel:"Potwierdź hasło",confirmPasswordPlaceholder:"Potwierdź hasło",description:"Wprowadź swój adres e-mail, aby zresetować hasło",emailPlaceholder:"Adres e-mail",failed:"Reset hasła nie powiódł się. Spróbuj ponownie.","invalid-email-format":"Nieprawidłowy adres e-mail","no-email":"Wprowadź adres e-mail",pageTitle:"Resetowanie hasła | ${clientName}",passwordLabel:"Nowe hasło",passwordPlaceholder:"Nowe hasło",passwordTooWeak:"Hasło jest zbyt słabe",passwordsDidntMatch:"Hasła nie są zgodne",successDescription:"Wysłaliśmy link do resetowania hasła na Twój adres e-mail.",successTitle:"Sprawdź swoją pocztę",title:"Zapomniałeś hasła?","user-not-found":"Nie znaleziono użytkownika"},"reset-password-code":{backToLoginText:"Wróć do logowania",buttonText:"Zresetuj hasło",codeLabel:"Kod resetowania",codePlaceholder:"Wprowadź 6-cyfrowy kod",confirmPasswordLabel:"Potwierdź hasło",confirmPasswordPlaceholder:"Potwierdź hasło",defaultDescription:"Wprowadź kod wysłany na Twój e-mail i wybierz nowe hasło",description:"Wysłaliśmy kod na ${email}",failed:"Reset hasła nie powiódł się. Spróbuj ponownie.",invalidCode:"Wprowadzony kod jest nieprawidłowy lub wygasł",noCode:"Wprowadź kod resetowania",pageTitle:"Wprowadź kod resetowania | ${clientName}",passwordLabel:"Nowe hasło",passwordPlaceholder:"Nowe hasło",passwordTooWeak:"Hasło jest zbyt słabe",passwordsDidntMatch:"Hasła nie są zgodne",resendFailed:"Nie udało się ponownie wysłać kodu. Spróbuj ponownie.",resendSuccess:"Nowy kod został wysłany na Twój e-mail",resendText:"Wyślij kod ponownie",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",title:"Wprowadź kod resetowania"}},signup:P$,"signup-id":{"signup-id":{buttonText:"Kontynuuj",description:"Zarejestruj się, aby kontynuować","email-already-exists":"Ten adres e-mail jest już zarejestrowany",emailPlaceholder:"Adres e-mail",federatedConnectionButtonText:"Kontynuuj z ${connectionName}","invalid-email-format":"Nieprawidłowy adres e-mail",loginActionLinkText:"Zaloguj się",loginActionText:"Masz już konto?","no-email":"Wprowadź adres e-mail",pageTitle:"Rejestracja | ${clientName}",phonePlaceholder:"Numer telefonu",separatorText:"lub",title:"Utwórz konto",usernamePlaceholder:"Nazwa użytkownika"}},"signup-password":{"signup-password":{buttonText:"Kontynuuj",description:"Utwórz swoje hasło",hidePasswordText:"Ukryj hasło","no-password":"Hasło jest wymagane",pageTitle:"Rejestracja | ${clientName}","password-policy-not-met":"Hasło nie spełnia wymagań","password-too-weak":"Hasło jest zbyt słabe",passwordPlaceholder:"Hasło",showPasswordText:"Pokaż hasło",title:"Utwórz hasło"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Kontynuuj",codeLabel:"Kod weryfikacyjny",codePlaceholder:"Wprowadź kod",defaultDescription:"Wprowadź kod weryfikacyjny wysłany na Twój telefon",description:"Wysłaliśmy kod na ${username}","invalid-code":"Nieprawidłowy kod",noCode:"Wprowadź kod weryfikacyjny",pageTitle:"Wprowadź kod | ${clientName}",resendText:"Wyślij ponownie kod",sessionExpired:"Twoja sesja wygasła. Spróbuj ponownie.",title:"Sprawdź swój telefon",unexpectedError:"Wystąpił nieoczekiwany błąd"}},status:N$},zF=Object.freeze(Object.defineProperty({__proto__:null,common:E$,consent:x$,default:IF,invitation:C$,login:T$,mfa:$$,organizations:z$,passkeys:I$,signup:P$,status:N$},Symbol.toStringTag,{value:"Module"})),j$={common:{alertListTitle:"Meddelanden",backText:"Gå tillbaka",cancelText:"Gå tillbaka",closeText:"Stäng",contactSupportText:"Behöver du hjälp?",continueText:"Fortsätt",copyrightText:"© ${currentYear} ${companyName}",errorText:"Något gick fel. Vänligen försök igen.",hidePasswordText:"Dölj lösenord",loadingText:"Laddar...",orText:"eller",privacyPolicyText:"Integritetspolicy",showPasswordText:"Visa lösenord",termsOfServiceText:"Användarvillkor",termsShortText:"Villkor",tryAgainText:"Försök igen"}},O$={consent:{buttonText:"Godkänn",cancelButtonText:"Neka",description:"${clientName} begär åtkomst till ditt konto",pageTitle:"Auktorisera | ${clientName}",scopesTitle:"Detta ger ${clientName} tillåtelse att:",title:"Auktorisera ${clientName}"}},F$={invitation:{acceptButtonText:"Acceptera inbjudan",description:"${inviterName} har bjudit in dig att gå med i ${organizationName} på ${clientName}",pageTitle:"Inbjudan | ${clientName}",title:"Du har blivit inbjuden"}},R$={login:{alertListTitle:"Meddelanden",buttonText:"Fortsätt",description:"Logga in på ${clientName}.",editEmailText:"Redigera",emailPlaceholder:"E-postadress",enterACodeBtn:"Logga in med en kod",federatedConnectionButtonText:"Fortsätt med ${connectionName}",footerLinkText:"Registrera dig",footerText:"Har du inget konto?",forgotPasswordText:"Har du glömt lösenordet?",hidePasswordText:"Dölj lösenord",invalidEmail:"Ogiltig e-postadress",invalidIdentifier:"Ogiltig e-postadress eller användarnamn",invitationDescription:"Logga in för att acceptera ${inviterName}s inbjudan att gå med i ${companyName} på ${clientName}.",invitationTitle:"Du har blivit inbjuden!",logoAltText:"${companyName}","no-email":"Vänligen ange en e-postadress","no-password":"Lösenord krävs",pageTitle:"Logga in | ${clientName}",passwordLoginNotAvailable:"Lösenordsinloggning är inte tillgänglig",passwordPlaceholder:"Lösenord",phonePlaceholder:"Telefonnummer",separatorText:"eller",sessionExpired:"Din session har gått ut. Försök igen.",showPasswordText:"Visa lösenord",signupActionLinkText:"Registrera dig",signupActionText:"Har du inget konto?",title:"Välkommen",tooManyFailedLogins:"För många misslyckade inloggningsförsök. Försök igen senare.",unverifiedEmail:"Verifiera din e-postadress innan du loggar in",userAccountDoesNotExist:"Användarkontot finns inte",usernamePlaceholder:"Användarnamn eller e-postadress",usernameTooLong:"Användarnamnet får vara högst ${max} tecken",usernameTooShort:"Användarnamnet måste vara minst ${min} tecken",wrongCredentials:"Fel användarnamn eller lösenord",passkeyButtonText:"Logga in med passkey"}},D$={mfa:{backupCodeText:"Använd reservkod",description:"Välj en verifieringsmetod",pageTitle:"Multifaktorautentisering | ${clientName}",title:"Verifiera din identitet"}},B$={"passkey-enrollment-nudge":{title:"Skydda ditt konto med en nyckel",description:"Nycklar använder enhetens biometri eller PIN-kod för att logga in snabbare och säkrare.",enrollButtonText:"Konfigurera nyckel",snoozeButtonText:"Kanske senare",optOutLinkText:"Visa inte detta igen",pageTitle:"Konfigurera Nyckel | ${clientName}"},"passkey-enrollment":{title:"Skapa din nyckel",description:"Följ anvisningarna från din webbläsare för att skapa en nyckel för detta konto.",errorMessage:"Det gick inte att skapa nyckeln. Försök igen.",cancelLinkText:"Hoppa över för nu",retryButtonText:"Försök igen",enrollmentComplete:"Din nyckel har konfigurerats. Du kan stänga denna sida.",pageTitle:"Skapa Nyckel | ${clientName}"},"passkey-challenge":{title:"Logga in med passkey",description:"Följ instruktionerna från din webbläsare för att verifiera din identitet.",errorMessage:"Autentisering med passkey misslyckades. Försök igen.",cancelLinkText:"Tillbaka till inloggning",retryButtonText:"Försök igen",pageTitle:"Logga in med passkey | ${clientName}"}},L$={organizations:{description:"Välj vilken organisation du vill logga in på",pageTitle:"Välj organisation | ${clientName}",searchPlaceholder:"Sök organisationer",title:"Välj din organisation"}},M$={signup:{buttonText:"Registrera dig",confirmPasswordPlaceholder:"Bekräfta lösenord",description:"Välj ett lösenord med en blandning av stora och små bokstäver, siffror och symboler.","email-already-exists":"E-postadressen är redan upptagen",emailPlaceholder:"E-postadress",federatedConnectionButtonText:"Fortsätt med ${connectionName}",hidePasswordText:"Dölj lösenord","invalid-email-format":"Ogiltig e-postadress",loginActionLinkText:"Logga in",loginActionText:"Har du redan ett konto?","no-email":"Vänligen ange en e-postadress","no-password":"Lösenord krävs","no-username":"Användarnamn krävs",pageTitle:"Registrera dig | ${clientName}",passwordPlaceholder:"Lösenord",passwordsDidntMatch:"Lösenorden matchar inte",phonePlaceholder:"Telefonnummer",privacyPolicyLinkText:"Integritetspolicy",separatorText:"eller",sessionExpired:"Din session har gått ut. Försök igen.",showPasswordText:"Visa lösenord",termsOfServiceLinkText:"Användarvillkor",termsText:"Genom att registrera dig godkänner du våra",title:"Välj lösenord","username-already-exists":"Användarnamnet är redan taget",usernamePlaceholder:"Användarnamn",verifyEmailText:"Kontrollera din e-post för att verifiera ditt konto"}},U$={status:{continueButtonText:"Fortsätt",errorTitle:"Fel",pageTitle:"Status | ${clientName}",successTitle:"Klart",title:"Status"}},PF={common:j$,consent:O$,"device-flow":{"device-flow":{buttonText:"Fortsätt",codePlaceholder:"Ange kod",description:"Ange koden som visas på din enhet","expired-code":"Koden har gått ut","invalid-code":"Koden du angav är ogiltig",pageTitle:"Enhetsaktivering | ${clientName}",title:"Aktivera din enhet"}},"email-otp-challenge":{"email-otp-challenge":{buttonText:"Logga in",codeLabel:"Verifieringskod",codePlaceholder:"Ange kod",defaultDescription:"Ange verifieringskoden som skickades till din e-post",description:"Vi skickade en kod till ${email}","invalid-code":"Ogiltig kod",noCode:"Ange verifieringskoden",pageTitle:"Ange kod | ${clientName}",resendText:"Skicka koden igen",sessionExpired:"Din session har gått ut. Försök igen.",title:"Kolla din e-post",unexpectedError:"Ett oväntat fel uppstod"}},"email-verification":{"email-verification":{description:"Vi skickade ett e-postmeddelande till ${email}",pageTitle:"Verifiera e-post | ${clientName}",resendText:"Skicka koden igen",successDescription:"Din e-postadress har verifierats.",successTitle:"E-post verifierad",title:"Ange engångskod"}},invitation:F$,login:R$,"login-id":{"login-id":{alertListTitle:"Meddelanden","auth0-users-validation":"Något gick fel, försök igen senare","authentication-failure":"Vi beklagar, något gick fel vid inloggningsförsöket",buttonText:"Fortsätt","captcha-client-failure":"Vi kunde inte ladda säkerhetsutmaningen. Försök igen. (Felkod: #{errorCode})","captcha-validation-failure":"Vi beklagar, något gick fel vid validering av captcha-svaret. Försök igen.",captchaCodePlaceholder:"Ange koden som visas ovan","custom-script-error-code":"Något gick fel, försök igen senare.",description:"Logga in på ${clientName}.",editEmailText:"Redigera",emailPlaceholder:"E-postadress",federatedConnectionButtonText:"Fortsätt med ${connectionName}",footerLinkText:"Registrera dig",footerText:"Har du inget konto?",forgotPasswordText:"Har du glömt lösenordet?",hidePasswordText:"Dölj lösenord","invalid-captcha":"Lös utmaningen för att verifiera att du inte är en robot.","invalid-code":"Ogiltig kod","invalid-connection":"Ogiltig anslutning","invalid-email-format":"Ogiltig e-postadress","invalid-email-phone":"Ange en giltig e-postadress eller telefonnummer. Telefonnummer måste innehålla landskod.","invalid-email-phone-username":"Ange en giltig e-postadress, telefonnummer eller användarnamn. Telefonnummer måste innehålla landskod.","invalid-email-username":"Ange en giltig e-postadress eller användarnamn","invalid-expired-code":"Ogiltig eller utgången användarkod","invalid-login-id":"Ogiltigt inloggnings-ID angivet","invalid-phone-username":"Ange ett giltigt telefonnummer eller användarnamn. Telefonnummer måste innehålla landskod.","invalid-recaptcha":"Markera kryssrutan för att verifiera att du inte är en robot.","invalid-username":"Användarnamn kan bara innehålla alfanumeriska tecken eller: '${characters}'. Användarnamn ska vara mellan ${min} och ${max} tecken.",invitationDescription:"Logga in för att acceptera ${inviterName}s inbjudan att gå med i ${companyName} på ${clientName}.",invitationTitle:"Du har blivit inbjuden!","ip-blocked":"Vi har upptäckt misstänkt inloggningsaktivitet och ytterligare försök kommer att blockeras. Kontakta administratören.",logoAltText:"${companyName}","no-db-connection":"Ogiltig anslutning","no-email":"Vänligen ange en e-postadress","no-email-phone":"E-postadress eller telefonnummer krävs","no-email-phone-username":"Telefonnummer, användarnamn eller e-postadress krävs","no-email-username":"E-postadress eller användarnamn krävs","no-password":"Lösenord krävs","no-phone":"Ange ett telefonnummer","no-phone-username":"Telefonnummer eller användarnamn krävs","no-username":"Användarnamn krävs",pageTitle:"Logga in | ${clientName}","password-breached":"Vi har upptäckt ett potentiellt säkerhetsproblem med detta konto. För att skydda ditt konto har vi förhindrat denna inloggning. Återställ ditt lösenord för att fortsätta.",passwordPlaceholder:"Lösenord",phoneOrEmailPlaceholder:"E-post eller telefonnummer",phoneOrUsernameOrEmailPlaceholder:"Telefon, användarnamn eller e-post",phoneOrUsernamePlaceholder:"Telefonnummer eller användarnamn",phonePlaceholder:"Telefonnummer","same-user-login":"För många inloggningsförsök för denna användare. Vänta en stund och försök igen.",selectCountryCode:"Välj landskod, för närvarande inställd på ${countryName}, ${countryCode}, +${countryPrefix}",separatorText:"eller",sessionExpired:"Din session har gått ut. Försök igen.",showPasswordText:"Visa lösenord",signupActionLinkText:"Registrera dig",signupActionText:"Har du inget konto?",termsAndConditionsTemplate:'Genom att fortsätta godkänner du våra <a href="${termsAndConditionsUrl}" target="_blank" rel="noopener noreferrer">Villkor</a>.',title:"Välkommen","user-blocked":"Ditt konto har blockerats efter flera misslyckade inloggningsförsök i rad.",userAccountDoesNotExist:"Användarkontot finns inte",usernameOnlyPlaceholder:"Användarnamn",usernameOrEmailPlaceholder:"Användarnamn eller e-postadress",usernamePlaceholder:"Användarnamn",usernameTooLong:"Användarnamnet får vara högst ${max} tecken",usernameTooShort:"Användarnamnet måste vara minst ${min} tecken","wrong-credentials":"Fel användarnamn eller lösenord","wrong-email-credentials":"Fel e-postadress eller lösenord","wrong-email-phone-credentials":"Fel e-postadress, telefonnummer eller lösenord. Telefonnummer måste innehålla landskod.","wrong-email-phone-username-credentials":"Fel e-postadress, telefonnummer, användarnamn eller lösenord. Telefonnummer måste innehålla landskod.","wrong-email-username-credentials":"Fel e-postadress, användarnamn eller lösenord","wrong-phone-credentials":"Fel telefonnummer eller lösenord","wrong-phone-username-credentials":"Fel telefonnummer, användarnamn eller lösenord. Telefonnummer måste innehålla landskod.","wrong-username-credentials":"Fel användarnamn eller lösenord",passkeyButtonText:"Logga in med passkey"}},"login-password":{"login-password":{buttonText:"Logga in",description:"Ange din e-postadress och ditt lösenord för att logga in.",forgotPasswordText:"Har du glömt lösenordet?",hidePasswordText:"Dölj lösenord","no-password":"Lösenord krävs",pageTitle:"Logga in | ${clientName}","password-breached":"Vi har upptäckt ett potentiellt säkerhetsproblem med detta konto. För att skydda ditt konto har vi förhindrat denna inloggning. Återställ ditt lösenord för att fortsätta.",passwordPlaceholder:"Lösenord",showPasswordText:"Visa lösenord",signingInAs:"Loggar in som ${email}",title:"Ange lösenord",unverifiedEmail:"Verifiera din e-postadress innan du loggar in","user-blocked":"Ditt konto har blockerats efter flera misslyckade inloggningsförsök i rad.","wrong-credentials":"Fel lösenord"}},"login-passwordless":{"login-passwordless":{authMethodEmail:"e-post",authMethodEmailOrPhone:"e-post eller telefonnummer",authMethodPhone:"telefonnummer",description:"Logga in med din ${authMethod}",emailOrPhonePlaceholder:"E-postadress eller telefonnummer",emailPlaceholder:"E-postadress",invalidEmail:"Ange en giltig e-postadress",invalidIdentifier:"Ange en giltig e-postadress eller telefonnummer",invalidPhone:"Ange ett giltigt telefonnummer med landskod",noEmail:"Ange din e-postadress",noPhone:"Ange ditt telefonnummer",phonePlaceholder:"Telefonnummer",sessionExpired:"Din session har gått ut. Försök igen.",title:"Logga in med en kod",userAccountDoesNotExist:"Användarkontot finns inte"}},"magic-link-sent":{"magic-link-sent":{defaultDescription:"Klicka på länken i ditt e-postmeddelande för att logga in",description:"Vi skickade en länk till ${username}. Klicka på den för att logga in.",resendText:"Skicka länken igen",spamText:"Fick du inte e-postmeddelandet? Kolla din skräppost.",title:"Kolla din e-post"}},mfa:D$,"mfa-email":{"mfa-email":{buttonText:"Fortsätt",codePlaceholder:"Ange kod",description:"Vi skickade en kod till ${email}","invalid-code":"Koden du angav är ogiltig",pageTitle:"E-postverifiering | ${clientName}",resendText:"Skicka koden igen",title:"Kolla din e-post"}},"mfa-otp":{"mfa-otp":{buttonText:"Fortsätt",codePlaceholder:"Ange kod",description:"Ange den 6-siffriga koden från din autentiseringsapp","invalid-code":"Koden du angav är ogiltig",pageTitle:"Ange kod | ${clientName}",title:"Ange din kod"},"mfa-totp-enrollment":{title:"Konfigurera autentiseringsapp",description:"Skanna QR-koden nedan med din autentiseringsapp och ange sedan den 6-siffriga koden för att verifiera",secretLabel:"Eller ange denna kod manuellt:",codePlaceholder:"Ange kod",continueButtonText:"Verifiera och aktivera","invalid-code":"Koden du angav är ogiltig. Försök igen.","transaction-not-found":"Din registreringstransaktion har gått ut, du behöver börja om.",pageTitle:"Konfigurera autentiseringsapp | ${clientName}",unexpectedError:"Något gick fel. Försök igen.",enrollmentComplete:"MFA-registreringen är klar. Du kan stänga denna sida."},"mfa-totp-challenge":{title:"Verifiera din identitet",description:"Ange den 6-siffriga koden från din autentiseringsapp",codePlaceholder:"Ange kod",continueButtonText:"Fortsätt","invalid-code":"Koden du angav är ogiltig","transaction-not-found":"Din registreringstransaktion har gått ut, du behöver börja om.",unexpectedError:"Något gick fel. Försök igen.",pageTitle:"Verifiera identitet | ${clientName}"}},"mfa-phone":{"mfa-phone-challenge":{pageTitle:"Använd ditt telefonnummer för att logga in | ${clientName}",title:"Verifiera din identitet",description:"Vi skickade en kod till ${phoneNumber}",continueButtonText:"Fortsätt",changePhoneText:"Välj ett annat telefonnummer.",smsButtonText:"SMS",voiceButtonText:"Röstsamtal",chooseMessageTypeText:"Hur vill du ta emot koden?",pickAuthenticatorText:"Prova en annan metod",logoAltText:"${companyName}",codePlaceholder:"Ange kod","send-sms-failed":"Det gick inte att skicka SMS:et","send-voice-failed":"Det gick inte att ringa röstsamtalet","invalid-phone-format":"Telefonnumret kan bara innehålla siffror.","invalid-phone":"Det verkar som att ditt telefonnummer inte är giltigt. Kontrollera och försök igen.","too-many-sms":"Du har överskridit det maximala antalet telefonmeddelanden per timme. Vänta några minuter och försök igen.","too-many-voice":"Du har överskridit det maximala antalet telefonmeddelanden per timme. Vänta några minuter och försök igen.","transaction-not-found":"Din registreringstransaktion har gått ut, du behöver börja om.","no-phone":"Ange ett telefonnummer",noCode:"Ange verifieringskoden",invalidCode:"Koden du angav är ogiltig. Försök igen.",unexpectedError:"Något gick fel. Försök igen.",resendSuccess:"Vi skickade en ny kod till din telefon",enrollmentComplete:"MFA-registreringen är klar. Du kan stänga denna sida."},"mfa-phone-enrollment":{pageTitle:"Ange ditt telefonnummer för att logga in med en telefonkod | ${clientName}",title:"Säkra ditt konto",description:"Ange din landskod och telefonnummer som vi kan skicka en 6-siffrig kod till:",continueButtonText:"Fortsätt",smsButtonText:"SMS",voiceButtonText:"Röstsamtal",chooseMessageTypeText:"Hur vill du ta emot koden?",pickAuthenticatorText:"Prova en annan metod",placeholder:"Ange ditt telefonnummer",logoAltText:"${companyName}",selectCountryCode:"Välj landskod, för närvarande inställd på ${countryName}, ${countryCode}, +${countryPrefix}","send-sms-failed":"Det gick inte att skicka SMS:et","send-voice-failed":"Det gick inte att ringa röstsamtalet","sms-authenticator-error":"Vi kunde inte skicka SMS:et. Försök igen senare.","invalid-phone-format":"Telefonnumret kan bara innehålla siffror.","invalid-phone":"Det verkar som att ditt telefonnummer inte är giltigt. Kontrollera och försök igen.","too-many-sms":"Du har överskridit det maximala antalet telefonmeddelanden per timme. Vänta några minuter och försök igen.","too-many-voice":"Du har överskridit det maximala antalet telefonmeddelanden per timme. Vänta några minuter och försök igen.","transaction-not-found":"Din registreringstransaktion har gått ut, du behöver börja om.","no-phone":"Ange ett telefonnummer","phone-is-too-short":"Telefonnumret är för kort","phone-is-too-long":"Telefonnumret är för långt"}},"mfa-login-options":{"mfa-login-options":{pageTitle:"Välj verifieringsmetod | ${clientName}",title:"Välj din verifieringsmetod",description:"Välj hur du vill verifiera din identitet",authenticatorAppLabel:"Autentiseringsapp",authenticatorAppDescription:"Använd din autentiseringsapp för att få en verifieringskod",smsLabel:"Sms",smsDescription:"Få en verifieringskod skickad till din telefon",passkeyLabel:"Lösenordsnyckel",passkeyDescription:"Använd din enhets biometri eller säkerhetsnyckel"}},"mfa-push":{"mfa-push":{description:"Vi skickade en notis till din enhet",pageTitle:"Push-notis | ${clientName}",resendText:"Skicka notisen igen",title:"Godkänn förfrågan",useCodeText:"Ange kod manuellt"}},"mfa-recovery-code":{"mfa-recovery-code":{buttonText:"Fortsätt",codePlaceholder:"Återställningskod",description:"Ange en av dina återställningskoder","invalid-code":"Återställningskoden du angav är ogiltig",pageTitle:"Återställningskod | ${clientName}",title:"Ange återställningskod"}},"mfa-voice":{"mfa-voice":{buttonText:"Ring mig",codePlaceholder:"Ange kod",description:"Vi ringer ${phoneNumber} med din kod","invalid-code":"Koden du angav är ogiltig",pageTitle:"Röstsamtal | ${clientName}",title:"Ta emot ett telefonsamtal"}},"mfa-webauthn":{"mfa-webauthn":{buttonText:"Försök igen",description:"Sätt in din säkerhetsnyckel och följ instruktionerna",pageTitle:"Säkerhetsnyckel | ${clientName}",title:"Använd din säkerhetsnyckel"}},passkeys:B$,organizations:L$,"reset-password":{"reset-password":{backToLoginText:"Gå tillbaka",buttonText:"Skicka",codeExpired:"Din kod för lösenordsåterställning har gått ut. Begär en ny.",confirmPasswordLabel:"Bekräfta lösenord",confirmPasswordPlaceholder:"Bekräfta lösenord",description:"Klicka på knappen nedan så skickar vi instruktioner om hur du återställer ditt lösenord.",emailPlaceholder:"E-postadress",failed:"Lösenordsåterställningen misslyckades. Försök igen.","invalid-email-format":"Ogiltig e-postadress","no-email":"Vänligen ange en e-postadress",pageTitle:"Återställ lösenord | ${clientName}",passwordLabel:"Nytt lösenord",passwordPlaceholder:"Nytt lösenord",passwordTooWeak:"Lösenordet är för svagt",passwordsDidntMatch:"Lösenorden matchar inte",successDescription:"Vi har skickat en länk för lösenordsåterställning till din e-postadress.",successTitle:"Vi har skickat ett e-postmeddelande med instruktioner om hur du återställer ditt lösenord till den e-postadress du angav.",title:"Har du glömt lösenordet?","user-not-found":"Användaren hittades inte"},"reset-password-code":{backToLoginText:"Tillbaka till inloggning",buttonText:"Återställ lösenord",codeLabel:"Återställningskod",codePlaceholder:"Ange 6-siffrig kod",confirmPasswordLabel:"Bekräfta lösenord",confirmPasswordPlaceholder:"Bekräfta lösenord",defaultDescription:"Ange koden som skickades till din e-post och välj ett nytt lösenord",description:"Vi skickade en kod till ${email}",failed:"Lösenordsåterställningen misslyckades. Försök igen.",invalidCode:"Koden du angav är ogiltig eller har gått ut",noCode:"Vänligen ange återställningskoden",pageTitle:"Ange återställningskod | ${clientName}",passwordLabel:"Nytt lösenord",passwordPlaceholder:"Nytt lösenord",passwordTooWeak:"Lösenordet är för svagt",passwordsDidntMatch:"Lösenorden matchar inte",resendFailed:"Kunde inte skicka koden igen. Försök igen.",resendSuccess:"En ny kod har skickats till din e-post",resendText:"Skicka koden igen",sessionExpired:"Din session har gått ut. Försök igen.",title:"Ange återställningskod"}},signup:M$,"signup-id":{"signup-id":{buttonText:"Fortsätt",description:"Välj ett lösenord med en blandning av stora och små bokstäver, siffror och symboler.","email-already-exists":"E-postadressen är redan upptagen",emailPlaceholder:"E-postadress",federatedConnectionButtonText:"Fortsätt med ${connectionName}","invalid-email-format":"Ogiltig e-postadress",loginActionLinkText:"Logga in",loginActionText:"Har du redan ett konto?","no-email":"Vänligen ange en e-postadress",pageTitle:"Registrera dig | ${clientName}",phonePlaceholder:"Telefonnummer",separatorText:"eller",title:"Välj lösenord",usernamePlaceholder:"Användarnamn"}},"signup-password":{"signup-password":{buttonText:"Fortsätt",description:"Välj ett lösenord med en blandning av stora och små bokstäver, siffror och symboler.",hidePasswordText:"Dölj lösenord","no-password":"Lösenord krävs",pageTitle:"Registrera dig | ${clientName}","password-policy-not-met":"Lösenordet uppfyller inte kraven","password-too-weak":"Lösenordet är för svagt",passwordPlaceholder:"Lösenord",showPasswordText:"Visa lösenord",title:"Välj lösenord"}},"sms-otp-challenge":{"sms-otp-challenge":{buttonText:"Fortsätt",codeLabel:"Verifieringskod",codePlaceholder:"Ange kod",defaultDescription:"Ange verifieringskoden som skickades till din telefon",description:"Vi skickade en kod till ${username}","invalid-code":"Ogiltig kod",noCode:"Ange verifieringskoden",pageTitle:"Ange kod | ${clientName}",resendText:"Skicka koden igen",sessionExpired:"Din session har gått ut. Försök igen.",title:"Kolla din telefon",unexpectedError:"Ett oväntat fel uppstod"}},status:U$},NF=Object.freeze(Object.defineProperty({__proto__:null,common:j$,consent:O$,default:PF,invitation:F$,login:R$,mfa:D$,organizations:L$,passkeys:B$,signup:M$,status:U$},Symbol.toStringTag,{value:"Module"})),q$=["cs","da","en","fi","it","nb","pl","sv"],Gp="en",jF={cs:"Čeština",da:"Dansk",en:"English",fi:"Suomi",it:"Italiano",nb:"Norsk",pl:"Polski",sv:"Svenska"},OF=jF;function FF(e){return OF[e]??e}const RF=Object.assign({"../../locales/cs.json":wF,"../../locales/da.json":vF,"../../locales/en.json":kF,"../../locales/fi.json":EF,"../../locales/it.json":CF,"../../locales/nb.json":$F,"../../locales/pl.json":zF,"../../locales/sv.json":NF}),Yl={};for(const[e,t]of Object.entries(RF)){const n=e.match(/\/(\w+)\.json$/)?.[1];n&&(Yl[n]=t.default||t)}const H$={},A2=Yl[Gp];if(A2)for(const[e,t]of Object.entries(A2))for(const[n,i]of Object.entries(t)){const r={};for(const o of Object.keys(i))r[o]=s.z.string();H$[`${e}.${n}`]=s.z.object(r)}function DF(e,t){if(!t)return e;let n=e;for(const[i,r]of Object.entries(t))if(r!==void 0){const o=i.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");n=n.replace(new RegExp(`\\$\\{${o}\\}`,"g"),String(r)).replace(new RegExp(`#\\{${o}\\}`,"g"),String(r)).replace(new RegExp(`\\{${o}\\}`,"g"),String(r))}return n}function BF(e){const t=e.split("-")[0]?.toLowerCase()||Gp;return q$.includes(t)?t:Gp}function Ce(e,t,n,i){const r=BF(n),o=Yl[Gp]?.[e]?.[t]??{},a=Yl[r]?.[e]?.[t]??{},c={...o,...a},l=i?.[t]??{},d={...c,...l},u=H$[`${e}.${t}`];if(u){const h=u.safeParse(d);h.success||console.warn(`[i18n] Missing translations for ${e}.${t} (${r}):`,h.error.issues.map(g=>g.path.join(".")).join(", "))}const p={};for(const[h,g]of Object.entries(d))p[h]=m=>DF(g,m);return{m:new Proxy(p,{get:(h,g)=>h[g]??(()=>g)}),locale:r}}function LF(e){const t=e?.language?.split("-")[0]?.toLowerCase(),n=[];for(const[i,r]of Object.entries(Yl))if(!(t&&i!==t))for(const[o,a]of Object.entries(r))e?.prompt&&o!==e.prompt||n.push({prompt:o,language:i,custom_text:a});return n}function lc(e,t){const n=mF(e,"ah-dark-mode");if(n==="dark"||n==="light"||n==="auto")return n;const i=t?.dark_mode;return i==="dark"||i==="light"||i==="auto"?i:"auto"}const Wp={"--ah-color-text":"#f9fafb","--ah-color-text-muted":"#9ca3af","--ah-color-text-label":"#d1d5db","--ah-color-header":"#f9fafb","--ah-color-bg":"#1f2937","--ah-color-bg-hover":"#374151","--ah-color-bg-muted":"#374151","--ah-color-bg-disabled":"#4b5563","--ah-color-input-bg":"#374151","--ah-color-border":"#4b5563","--ah-color-border-hover":"#6b7280","--ah-color-border-muted":"#374151","--ah-color-error-bg":"rgba(220,38,38,0.2)","--ah-color-success-bg":"rgba(22,163,74,0.2)","--ah-color-link":"#60a5fa"};function V$(e){const t=e.replace("#",""),n=parseInt(t,16);return[n>>16&255,n>>8&255,n&255]}function k2(e){const[t,n,i]=V$(e).map(r=>{const o=r/255;return o<=.04045?o/12.92:Math.pow((o+.055)/1.055,2.4)});return .2126*t+.7152*n+.0722*i}function Ni(e,t){const n=k2(e),i=k2(t);return(Math.max(n,i)+.05)/(Math.min(n,i)+.05)}function K$(e,t){const[n,i,r]=V$(e),o=a=>Math.min(255,Math.round(a+(255-a)*t)).toString(16).padStart(2,"0");return`#${o(n)}${o(i)}${o(r)}`}function S2(e,t){const n={...Wp};if(t){const r=Wp["--ah-color-bg"];if(Ni(t,r)<3){let d=t;for(let u=1;u<=10&&(d=K$(t,u*.1),!(Ni(d,r)>=3));u++);n["--ah-color-primary"]=d,n["--ah-color-primary-hover"]=d}const o=1.35,a=n["--ah-color-primary"]||t,c=Ni(a,"#ffffff"),l=Ni(a,"#000000");n["--ah-color-text-on-primary"]=l>c*o?"#000000":"#ffffff"}const i=Object.entries(n).map(([r,o])=>`${r}: ${o} !important`).join("; ");return`${e} { ${i}; }`}const MF="(function(btn){var h=document.documentElement;var cur=h.classList.contains('ah-dark-mode')?'dark':h.classList.contains('ah-light-mode')?'light':'auto';var next=cur==='auto'?'dark':cur==='dark'?'light':'auto';h.classList.remove('ah-dark-mode','ah-light-mode');if(next==='dark'){h.classList.add('ah-dark-mode');h.setAttribute('data-mode','dark')}else if(next==='light'){h.classList.add('ah-light-mode');h.setAttribute('data-mode','light')}else{h.removeAttribute('data-mode')}btn.querySelector('.icon-sun').style.display=next==='light'?'block':'none';btn.querySelector('.icon-moon').style.display=next==='dark'?'block':'none';btn.querySelector('.icon-auto').style.display=next==='auto'?'block':'none';document.cookie='ah-dark-mode='+next+';path=/;max-age=31536000;SameSite=Lax';if(window.__ahDarkMode){window.__ahDarkMode(next)}})(this)",UF="var p=new URLSearchParams(window.location.search);p.set('ui_locales',this.value);window.location.search=p.toString()";function G$({logoUrl:e,clientName:t}){const n=e?gn(e):null;return S("div",{class:"ah-chip ah-chip-logo","data-ah-slot":"top-left",children:n?S("img",{src:n,alt:t}):S("span",{class:"ah-logo-text",children:t})})}function W$({darkMode:e}){return S("button",{type:"button","aria-label":"Toggle dark mode",onclick:MF,children:[S("svg",{class:"icon-auto",width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.2","stroke-linecap":"round","stroke-linejoin":"round",style:e==="auto"?void 0:"display:none",children:[S("circle",{cx:"12",cy:"12",r:"9"}),S("path",{d:"M12 3a9 9 0 0 1 0 18",fill:"currentColor"})]}),S("svg",{class:"icon-sun",width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.2","stroke-linecap":"round","stroke-linejoin":"round",style:e==="light"?void 0:"display:none",children:[S("circle",{cx:"12",cy:"12",r:"5"}),S("line",{x1:"12",y1:"1",x2:"12",y2:"3"}),S("line",{x1:"12",y1:"21",x2:"12",y2:"23"}),S("line",{x1:"4.22",y1:"4.22",x2:"5.64",y2:"5.64"}),S("line",{x1:"18.36",y1:"18.36",x2:"19.78",y2:"19.78"}),S("line",{x1:"1",y1:"12",x2:"3",y2:"12"}),S("line",{x1:"21",y1:"12",x2:"23",y2:"12"})]}),S("svg",{class:"icon-moon",width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.2","stroke-linecap":"round","stroke-linejoin":"round",style:e==="dark"?void 0:"display:none",children:S("path",{d:"M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z"})})]})}function J$({language:e,availableLanguages:t}){return!t||t.length<2?null:S("div",{class:"ah-lang",children:[S("svg",{width:"13",height:"13",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.2","stroke-linecap":"round","stroke-linejoin":"round",children:[S("circle",{cx:"12",cy:"12",r:"10"}),S("path",{d:"M2 12h20"}),S("path",{d:"M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"})]}),S("select",{"aria-label":"Language",onchange:UF,children:t.map(n=>S("option",{value:n,selected:n===e,children:FF(n)}))})]})}function Y$({darkMode:e,language:t,availableLanguages:n}){return S("div",{class:"ah-chip ah-chip-settings","data-ah-slot":"top-right",children:[S(W$,{darkMode:e}),n&&S(J$,{language:t,availableLanguages:n})]})}function Q$({url:e,href:t,alt:n,height:i}){const r=gn(e),o=t?gn(t):null;if(!r)return null;const a=S("img",{src:r,alt:n||"",height:i||18});return S("div",{class:"ah-chip ah-chip-trust","data-ah-slot":"bottom-left",children:o?S("a",{href:o,target:"_blank",rel:"noopener noreferrer",children:a}):a})}function Z$({termsAndConditionsUrl:e,language:t}){if(!e)return null;const{m:n}=Ce("common","common",t||"en");return S("div",{class:"ah-chip-legal","data-ah-slot":"bottom-right",children:S("a",{href:e,target:"_blank",rel:"noopener noreferrer",children:n.termsShortText()})})}function X$(e,t){const n=[],i=hn(e?.colors?.primary);i&&n.push(`--ah-color-primary: ${i}`);const r=hn(t?.colors?.primary_button)||i;if(r){const a=Ni(r,"#ffffff"),l=Ni(r,"#000000")>a*1.35?"#000000":"#ffffff";n.push(`--ah-color-text-on-primary: ${l}`)}return n.length>0?n.join("; ")+"; width: clamp(320px, 100%, 400px);":"width: clamp(320px, 100%, 400px);"}function qF(e){const{primaryColor:t,themePrimary:n,widgetBackground:i}=e;return`
2
2
  * { box-sizing: border-box; margin: 0; padding: 0; }
3
3
 
4
4
  /* ============= CHROME TOKENS =============
@@ -367,7 +367,7 @@ From `+this.originalError.stack)}static is(t){return t?.[VS]==="LiquidError"}}cl
367
367
  `)}function OJ(e){const t=de(e);this.context.memoryLimit.use(t.length);const n=new Map([["<script","<\/script>"],["<style","</style>"],["<!--","-->"],["<",">"]]);let i="",r=0;for(;r<t.length;){const o=t.indexOf("<",r);if(o<0)return i+t.slice(r);i+=t.slice(r,o);for(const[a,c]of n){if(!t.startsWith(a,o))continue;const l=t.indexOf(c,o+a.length);if(l>=0){r=l+c.length;break}n.delete(a)}if(r===o)return i+t.slice(o)}return i}var FJ=Object.freeze({__proto__:null,escape:Rg,xml_escape:zJ,escape_once:NJ,newline_to_br:jJ,strip_html:OJ});class RJ{constructor(t){this.mapping=t,this.sep="/"}exists(t){return at(this,void 0,void 0,function*(){return this.existsSync(t)})}existsSync(t){return!_t(this.mapping[t])}readFile(t){return at(this,void 0,void 0,function*(){return this.readFileSync(t)})}readFileSync(t){const n=this.mapping[t];if(_t(n))throw new Error(`ENOENT: ${t}`);return n}dirname(t){const n=t.split(this.sep);return n.pop(),n.join(this.sep)}resolve(t,n,i){if(n+=i,t===".")return n;const r=t.split(/\/+/);for(const o of n.split(this.sep))o==="."||o===""||(o===".."?(r.length>1||r[0]!=="")&&r.pop():r.push(o));return r.join(this.sep)}}const ya={root:["."],layouts:["."],partials:["."],relativeReference:!0,jekyllInclude:!1,keyValueSeparator:":",cache:void 0,extname:"",fs:SJ,dynamicPartials:!0,jsTruthy:!1,dateFormat:"%A, %B %-e, %Y at %-l:%M %P %z",locale:"",trimTagRight:!1,trimTagLeft:!1,trimOutputRight:!1,trimOutputLeft:!1,greedy:!0,tagDelimiterLeft:"{%",tagDelimiterRight:"%}",outputDelimiterLeft:"{{",outputDelimiterRight:"}}",preserveTimezones:!1,strictFilters:!1,strictVariables:!1,ownPropertyOnly:!0,lenientIf:!1,globals:{},keepOutputType:!1,operators:hJ,memoryLimit:1/0,parseLimit:1/0,renderLimit:1/0};function DJ(e){var t,n;if(e.hasOwnProperty("root")&&(e.hasOwnProperty("partials")||(e.partials=e.root),e.hasOwnProperty("layouts")||(e.layouts=e.root)),e.hasOwnProperty("cache")){let i;typeof e.cache=="number"?i=e.cache>0?new o3(e.cache):void 0:typeof e.cache=="object"?i=e.cache:i=e.cache?new o3(1024):void 0,e.cache=i}return e=Object.assign(Object.assign(Object.assign({},ya),e.jekyllInclude?{dynamicPartials:!1}:{}),e),(!e.fs.dirname||!e.fs.sep)&&e.relativeReference&&(console.warn("[LiquidJS] `fs.dirname` and `fs.sep` are required for relativeReference, set relativeReference to `false` to suppress this warning"),e.relativeReference=!1),e.root=mp(e.root),e.partials=mp(e.partials),e.layouts=mp(e.layouts),e.outputEscape=e.outputEscape&&BJ(e.outputEscape),e.locale||(e.locale=(n=(t=p8())===null||t===void 0?void 0:t().resolvedOptions().locale)!==null&&n!==void 0?n:"en-US"),e.templates&&(e.fs=new RJ(e.templates),e.relativeReference=!0,e.root=e.partials=e.layouts="."),e}function BJ(e){return e==="escape"?Rg:e==="json"?y8.json:(Jt(Tt(e),"`outputEscape` need to be of type string or function"),e)}function mp(e){let t=[];return Ut(e)&&(t=e),Pe(e)&&(t=[e]),t}function LJ(e,t){let n=!1;for(let i=0;i<e.length;i++){const r=e[i];JJ(r)&&(!n&&r.trimLeft&&MJ(e[i-1],t.greedy),$s(r)&&(r.name==="raw"?n=!0:r.name==="endraw"&&(n=!1)),!n&&r.trimRight&&UJ(e[i+1],t.greedy))}}function MJ(e,t){if(!e||!c1(e))return;const n=t?tc:c8;for(;tt[e.input.charCodeAt(e.end-1-e.trimRight)]&n;)e.trimRight++}function UJ(e,t){if(!e||!c1(e))return;const n=t?tc:c8;for(;tt[e.input.charCodeAt(e.begin+e.trimLeft)]&n;)e.trimLeft++;e.input.charAt(e.begin+e.trimLeft)===`
368
368
  `&&e.trimLeft++}let Di=class{constructor(t,n=ya.operators,i,r){this.input=t,this.file=i,this.rawBeginAt=-1,this.p=r?r[0]:0,this.N=r?r[1]:t.length,this.opTrie=JS(n),this.literalTrie=JS(d8)}readExpression(){return new lJ(this.readExpressionTokens())}*readExpressionTokens(){for(;this.p<this.N;){const t=this.readOperator();if(t){yield t;continue}const n=this.readValue();if(n){yield n;continue}return}}readOperator(){this.skipBlank();const t=this.matchTrie(this.opTrie);if(t!==-1)return new XW(this.input,this.p,this.p=t,this.file)}matchTrie(t){let n=t,i=this.p,r;for(;n[this.input[i]]&&i<this.N;)n=n[this.input[i++]],n.end&&(r=n);return!r||r.needBoundary&&hp(this.peek(i-this.p))?-1:i}readFilteredValue(){const t=this.p,n=this.readExpression();this.assert(n.valid(),`invalid value expression: ${this.snapshot()}`);const i=this.readFilters();return new sJ(n,i,this.input,t,this.p,this.file)}readFilters(){const t=[];for(;;){const n=this.readFilter();if(!n)return t;t.push(n)}}readFilter(){if(this.skipBlank(),this.end())return null;this.assert(this.read()==="|",'expected "|" before filter');const t=this.readIdentifier();if(!t.size())return this.assert(this.end(),"expected filter name"),null;const n=[];if(this.skipBlank(),this.peek()===":")do{++this.p;const i=this.readFilterArg();i&&n.push(i),this.skipBlank(),this.assert(this.end()||this.peek()===","||this.peek()==="|",()=>`unexpected character ${this.snapshot()}`)}while(this.peek()===",");else if(!(this.peek()==="|"||this.end()))throw this.error('expected ":" after filter name');return new g8(t.getText(),n,this.input,t.begin,this.p,this.file)}readFilterArg(){const t=this.readValue();if(!t)return;if(this.skipBlank(),this.peek()!==":")return t;++this.p;const n=this.readValue();return[t.getText(),n]}readTopLevelTokens(t=ya){const n=[];for(;this.p<this.N;){const i=this.readTopLevelToken(t);n.push(i)}return LJ(n,t),n}readTopLevelToken(t){const{tagDelimiterLeft:n,outputDelimiterLeft:i}=t;return this.rawBeginAt>-1?this.readEndrawOrRawContent(t):this.match(n)?this.readTagToken(t):this.match(i)?this.readOutputToken(t):this.readHTMLToken([n,i])}readHTMLToken(t){const n=this.p;for(;this.p<this.N&&!t.some(i=>this.match(i));)++this.p;return new XS(this.input,n,this.p,this.file)}readTagToken(t){const{file:n,input:i}=this,r=this.p;if(this.readToDelimiter(t.tagDelimiterRight)===-1)throw this.error(`tag ${this.snapshot(r)} not closed`,r);const o=new ZS(i,r,this.p,t,n);return o.name==="raw"&&(this.rawBeginAt=r),o}readToDelimiter(t,n=!1){for(this.skipBlank();this.p<this.N;){if(n&&this.peekType()&KS){this.readQuoted();continue}if(++this.p,this.rmatch(t))return this.p}return-1}readOutputToken(t=ya){const{file:n,input:i}=this,{outputDelimiterRight:r}=t,o=this.p;if(this.readToDelimiter(r,!0)===-1)throw this.error(`output ${this.snapshot(o)} not closed`,o);return new JW(i,o,this.p,t,n)}readEndrawOrRawContent(t){const{tagDelimiterLeft:n,tagDelimiterRight:i}=t,r=this.p;let o=this.readTo(n)-n.length;for(;this.p<this.N;){if(this.readIdentifier().getText()!=="endraw"){o=this.readTo(n)-n.length;continue}for(;this.p<=this.N;){if(this.rmatch(i)){const a=this.p;return r===o?(this.rawBeginAt=-1,new ZS(this.input,r,a,t,this.file)):(this.p=o,new XS(this.input,r,o,this.file))}if(this.rmatch(n))break;this.p++}}throw this.error(`raw ${this.snapshot(this.rawBeginAt)} not closed`,r)}readLiquidTagTokens(t=ya){const n=[];for(;this.p<this.N;){const i=this.readLiquidTagToken(t);i&&n.push(i)}return n}readLiquidTagToken(t){if(this.skipBlank(),this.end())return;const n=this.p;this.readToDelimiter(`
369
369
  `);const i=this.p;return new oJ(this.input,n,i,t,this.file)}error(t,n=this.p){return new AW(t,new Gm(this.input,n,this.N,this.file))}assert(t,n,i){if(!t)throw this.error(typeof n=="function"?n():n,i)}snapshot(t=this.p){return JSON.stringify(wW(this.input.slice(t,this.N),32))}readWord(){return this.readIdentifier()}readIdentifier(){this.skipBlank();const t=this.p;for(;!this.end()&&hp(this.peek());)++this.p;return new Gm(this.input,t,this.p,this.file)}readNonEmptyIdentifier(){const t=this.readIdentifier();return t.size()?t:void 0}readTagName(){return this.skipBlank(),this.input[this.p]==="#"?this.input.slice(this.p,++this.p):this.readIdentifier().getText()}readHashes(t){const n=[];for(;;){const i=this.readHash(t);if(!i)return n;n.push(i)}}readHash(t){this.skipBlank(),this.peek()===","&&++this.p;const n=this.p,i=this.readNonEmptyIdentifier();if(!i)return;let r;this.skipBlank();const o=Pe(t)?t:t?"=":":";return this.peek()===o&&(++this.p,r=this.readValue()),new eJ(this.input,n,this.p,i,r,this.file)}remaining(){return this.input.slice(this.p,this.N)}advance(t=1){this.p+=t}end(){return this.p>=this.N}read(){return this.input[this.p++]}readTo(t){for(;this.p<this.N;)if(++this.p,this.rmatch(t))return this.p;return-1}readValue(){this.skipBlank();const t=this.p,n=this.readLiteral()||this.readQuoted()||this.readRange()||this.readNumber(),i=this.readProperties(!n);return i.length?new t3(n,i,this.input,t,this.p):n}readScopeValue(){this.skipBlank();const t=this.p,n=this.readProperties();if(n.length)return new t3(void 0,n,this.input,t,this.p)}readProperties(t=!0){const n=[];for(;;){if(this.peek()==="["){this.p++;const i=this.readValue()||new Gm(this.input,this.p,this.p,this.file);this.assert(this.readTo("]")!==-1,"[ not closed"),n.push(i);continue}if(t&&!n.length){const i=this.readNonEmptyIdentifier();if(i){n.push(i);continue}}if(this.peek()==="."&&this.peek(1)!=="."){this.p++;const i=this.readNonEmptyIdentifier();if(!i)break;n.push(i);continue}break}return n}readNumber(){this.skipBlank();let t=!1,n=!1,i=0;for(this.peekType()&PW&&i++;this.p+i<=this.N;)if(this.peekType(i)&zW)n=!0,i++;else if(this.peek(i)==="."&&this.peek(i+1)!=="."){if(t||!n)return;t=!0,i++}else break;if(n&&!hp(this.peek(i))){const r=new YW(this.input,this.p,this.p+i,this.file);return this.advance(i),r}}readLiteral(){this.skipBlank();const t=this.matchTrie(this.literalTrie);if(t===-1)return;const n=new QW(this.input,this.p,t,this.file);return this.p=t,n}readRange(){this.skipBlank();const t=this.p;if(this.peek()!=="(")return;++this.p;const n=this.readValueOrThrow();this.skipBlank(),this.assert(this.read()==="."&&this.read()===".","invalid range syntax");const i=this.readValueOrThrow();return this.skipBlank(),this.assert(this.read()===")","invalid range syntax"),new rJ(this.input,t,this.p,n,i,this.file)}readValueOrThrow(){const t=this.readValue();return this.assert(t,()=>`unexpected token ${this.snapshot()}, value expected`),t}readQuoted(){this.skipBlank();const t=this.p;if(!(this.peekType()&KS))return;++this.p;let n=!1;for(;this.p<this.N&&(++this.p,!(this.input[this.p-1]===this.input[t]&&!n));)n?n=!1:this.input[this.p-1]==="\\"&&(n=!0);return new iJ(this.input,t,this.p,this.file)}*readFileNameTemplate(t){const{outputDelimiterLeft:n}=t,i=[","," ","\r",`
370
- `," ",n],r=new Set(i);for(;this.p<this.N&&!r.has(this.peek());)yield this.match(n)?this.readOutputToken(t):this.readHTMLToken(i)}match(t){for(let n=0;n<t.length;n++)if(t[n]!==this.input[this.p+n])return!1;return!0}rmatch(t){for(let n=0;n<t.length;n++)if(t[t.length-1-n]!==this.input[this.p-1-n])return!1;return!0}peekType(t=0){return this.p+t>=this.N?0:tt[this.input.charCodeAt(this.p+t)]}peek(t=0){return this.p+t>=this.N?"":this.input[this.p+t]}skipBlank(){for(;this.peekType()&tc;)++this.p}};class qJ{constructor(t,n){this.handlers={},this.stopRequested=!1,this.tokens=t,this.parseToken=n}on(t,n){return this.handlers[t]=n,this}trigger(t,n){const i=this.handlers[t];return i?(i.call(this,n),!0):!1}start(){this.trigger("start");let t;for(;!this.stopRequested&&(t=this.tokens.shift());){if(this.trigger("token",t)||$s(t)&&this.trigger(`tag:${t.name}`,t))continue;const n=this.parseToken(t,this.tokens);this.trigger("template",n)}return this.stopRequested||this.trigger("end"),this}stop(){return this.stopRequested=!0,this}}class a1{constructor(t){this.token=t}}class pt extends a1{constructor(t,n,i){super(t),this.name=t.name,this.liquid=i,this.tokenizer=t.tokenizer}}class Pc{constructor(t,n){this.hash={};const i=t instanceof Di?t:new Di(t,{});for(const r of i.readHashes(n))this.hash[r.name.content]=r.value}*render(t){const n={};for(const i of Object.keys(this.hash))n[i]=this.hash[i]===void 0?!0:yield Et(this.hash[i],t);return n}}function HJ(e){return class extends pt{constructor(t,n,i){super(t,n,i),Tt(e.parse)&&e.parse.call(this,t,n)}*render(t,n){const i=yield new Pc(this.token.args,t.opts.keyValueSeparator).render(t);return yield e.render.call(this,t,n,i)}}}function _8(e){return Ut(e)}class w8{constructor(t,n,i){this.token=t,this.name=t.name,this.handler=Tt(n)?n:Tt(n?.handler)?n.handler:s8,this.raw=!Tt(n)&&!!n?.raw,this.args=t.args,this.liquid=i}*render(t,n){const i=[];for(const r of this.args)_8(r)?i.push([r[0],yield Et(r[1],n)]):i.push(yield Et(r,n));return yield this.handler.apply({context:n,token:this.token,liquid:this.liquid},[t,...i])}}class Cn{constructor(t,n){this.filters=[];const i=typeof t=="string"?new Di(t,n.options.operators).readFilteredValue():t;this.initial=i.initial,this.filters=i.filters.map(r=>new w8(r,this.getFilter(n,r.name),n))}*value(t,n){n=n||t.opts.lenientIf&&this.filters.length>0&&this.filters[0].name==="default";let i=yield this.initial.evaluate(t,n);for(const r of this.filters)i=yield r.render(i,t);return i}getFilter(t,n){const i=t.filters[n];return Jt(i||!t.options.strictFilters,()=>`undefined filter: ${n}`),i}}class VJ extends a1{constructor(t,n){var i;super(t);const r=new Di(t.input,n.options.operators,t.file,t.contentRange);this.value=new Cn(r.readFilteredValue(),n);const o=this.value.filters,a=n.options.outputEscape;if(!(!((i=o[o.length-1])===null||i===void 0)&&i.raw)&&a){const c=new g8(toString.call(a),[],"",0,0);o.push(new w8(c,a,n))}}*render(t,n){const i=yield this.value.value(t,!1);n.write(i)}*arguments(){yield this.value}}class KJ extends a1{constructor(t){super(t),this.str=t.getContent()}*render(t,n){n.write(this.str)}}class ms{constructor(t,n){this.segments=t,this.location=n}toString(){return lh(this.segments,!0)}toArray(){function*t(...n){for(const i of n)i instanceof ms?yield Array.from(t(...i.segments)):yield i}return Array.from(t(...this.segments))}}class Jm{constructor(){this.map=new Map}get(t){const n=lh([t.segments[0]]);return this.map.has(n)||this.map.set(n,[]),this.map.get(n)}has(t){return this.map.has(lh([t.segments[0]]))}push(t){this.get(t).push(t)}asObject(){return Object.fromEntries(this.map)}}const b8={partials:!0};function*v8(e,t,n){const i=new Jm,r=new Jm,o=new Jm,a=new a3(new Set),c=new Set;function l(u,p){i.push(u);const f=p.alias(u);if(f!==void 0){const h=f.segments[0];Pe(h)&&!a.has(h)&&r.push(f)}else{const h=u.segments[0];Pe(h)&&!p.has(h)&&r.push(u)}for(const h of u.segments)h instanceof ms&&l(h,p)}function*d(u,p){if(u.arguments)for(const f of u.arguments())for(const h of c3(f))l(h,p);if(u.localScope)for(const f of u.localScope()){p.add(f.content),p.deleteAlias(f.content);const[h,g]=f.getPosition();o.push(new ms([f.content],{row:h,col:g,file:f.file}))}if(u.children)if(u.partialScope){const f=u.partialScope();if(f===void 0){for(const m of yield u.children(t,n))yield d(m,p);return}if(c.has(f.name))return;const h=new Set,g=f.isolated?new a3(h):p.push(h);for(const m of f.scope)if(Pe(m))h.add(m);else{const[_,w]=m;h.add(_);const y=Array.from(c3(w));y.length&&g.setAlias(_,y[0].segments)}for(const m of yield u.children(t,n))yield d(m,g),c.add(f.name);g.pop()}else{u.blockScope&&p.push(new Set(u.blockScope()));for(const f of yield u.children(t,n))yield d(f,p);u.blockScope&&p.pop()}}for(const u of e)yield d(u,a);return{variables:i.asObject(),globals:r.asObject(),locals:o.asObject()}}function Ir(e,t={}){const n=Object.assign(Object.assign({},b8),t);return sr(v8(e,n.partials,!1))}function zr(e,t={}){const n=Object.assign(Object.assign({},b8),t);return ar(v8(e,n.partials,!0))}class a3{constructor(t){this.stack=[{names:t,aliases:new Map}]}has(t){for(const n of this.stack)if(n.names.has(t))return!0;return!1}push(t){return this.stack.push({names:t,aliases:new Map}),this}pop(){var t;return(t=this.stack.pop())===null||t===void 0?void 0:t.names}add(t){this.stack[0].names.add(t)}alias(t){const n=t.segments[0];if(!Pe(n))return;const i=this.getAlias(n);if(i!==void 0)return new ms([...i,...t.segments.slice(1)],t.location)}setAlias(t,n){this.stack[this.stack.length-1].aliases.set(t,n)}deleteAlias(t){this.stack[this.stack.length-1].aliases.delete(t)}getAlias(t){for(const n of this.stack){if(n.aliases.has(t))return n.aliases.get(t);if(n.names.has(t))return}}}function*c3(e){Sn(e)?yield*Ca(e):e instanceof Cn&&(yield*GJ(e))}function*GJ(e){for(const t of e.initial.postfix)Sn(t)&&(yield*Ca(t));for(const t of e.filters)for(const n of t.args)_8(n)&&n[1]?yield*Ca(n[1]):Sn(n)&&(yield*Ca(n))}function*Ca(e){k8(e)?(yield*Ca(e.lhs),yield*Ca(e.rhs)):dh(e)&&(yield Sw(e))}function Sw(e){const t=[];let n=e.file;const i=e.props[0];n=n||i.file,Ew(i)||d3(i)||u3(i)?t.push(i.content):dh(i)&&t.push(...Sw(i).segments);for(const a of e.props.slice(1))n=n||a.file,Ew(a)||d3(a)||u3(a)?t.push(a.content):dh(a)&&t.push(Sw(a));const[r,o]=e.getPosition();return new ms(t,{row:r,col:o,file:n})}const l3=/^[\u0080-\uFFFFa-zA-Z_][\u0080-\uFFFFa-zA-Z0-9_-]*$/;function lh(e,t=!1){const n=[],i=e[0];Pe(i)&&(!t||i.match(l3)?n.push(`${i}`):n.push(`['${i}']`));for(const r of e.slice(1))r instanceof ms?n.push(`[${lh(r.segments)}]`):Pe(r)?r.match(l3)?n.push(`.${r}`):n.push(`['${r}']`):n.push(`[${r}]`);return n.join("")}var ic;(function(e){e.Partials="partials",e.Layouts="layouts",e.Root="root"})(ic||(ic={}));class WJ{constructor(t){var n,i,r,o;if(this.options=t,t.relativeReference){const c=t.fs.sep;Jt(c,"`fs.sep` is required for relative reference");const l=["."+c,".."+c,"./","../"];this.shouldLoadRelative=d=>l.some(u=>d.startsWith(u))}else this.shouldLoadRelative=c=>!1;const a=t.fs;this.contains=bw(((n=a.contains)===null||n===void 0?void 0:n.bind(a))||(()=>at(this,void 0,void 0,function*(){return!0})),((i=a.containsSync)===null||i===void 0?void 0:i.bind(a))||(()=>!0)),this.exists=bw(((r=a.exists)===null||r===void 0?void 0:r.bind(a))||(()=>at(this,void 0,void 0,function*(){return!1})),(o=a.existsSync)===null||o===void 0?void 0:o.bind(a))}*lookup(t,n,i,r){const o=this.options[n];for(const a of this.candidates(t,o,r)){let c=!1;for(const l of o)if(yield this.contains(!!i,l,a)){c=!0;break}if(c&&(yield this.exists(!!i,a)))return a}throw this.lookupError(t,o)}*candidates(t,n,i){const{fs:r,extname:o}=this.options;this.shouldLoadRelative(t)&&i&&(yield r.resolve(this.dirname(i),t,o));for(const a of n)yield r.resolve(a,t,o);if(r.fallback!==void 0){const a=r.fallback(t);a!==void 0&&(yield a)}}dirname(t){const n=this.options.fs;return Jt(n.dirname,"`fs.dirname` is required for relative reference"),n.dirname(t)}lookupError(t,n){const i=new Error("ENOENT");return i.message=`ENOENT: Failed to lookup "${t}" in "${n}"`,i.code="ENOENT",i}}let bo=class{constructor(t){var n,i;this.liquid=t,this.cache=this.liquid.options.cache,this.fs=this.liquid.options.fs,this.parseFile=this.cache?this._parseFileCached:this._parseFile,this.loader=new WJ(this.liquid.options),this.parseLimit=new Aw("parse length",t.options.parseLimit),this.readFile=bw(((n=this.fs.readFile)===null||n===void 0?void 0:n.bind(this.fs))||(()=>at(this,void 0,void 0,function*(){throw new Error("readFile not implemented")})),(i=this.fs.readFileSync)===null||i===void 0?void 0:i.bind(this.fs))}parse(t,n){t=String(t),this.parseLimit.use(t.length);const r=new Di(t,this.liquid.options.operators,n).readTopLevelTokens(this.liquid.options);return this.parseTokens(r)}parseTokens(t){let n;const i=[],r=[];for(;n=t.shift();)try{i.push(this.parseToken(n,t))}catch(o){if(this.liquid.options.catchAllErrors)r.push(o);else throw o}if(r.length)throw new a8(r);return i}parseToken(t,n){try{if($s(t)){const i=this.liquid.tags[t.name];return Jt(i,`tag "${t.name}" not found`),new i(t,n,this.liquid,this)}return YJ(t)?new VJ(t,this.liquid):new KJ(t)}catch(i){throw Ts.is(i)?i:new kW(i,t)}}parseStream(t){return new qJ(t,(n,i)=>this.parseToken(n,i))}*_parseFileCached(t,n,i=ic.Root,r){const o=this.cache,a=this.loader.shouldLoadRelative(t)?r+","+t:i+":"+t,c=yield o.read(a);if(c)return c;const l=this._parseFile(t,n,i,r),d=n?yield l:sr(l);o.write(a,d);try{return yield d}catch(u){throw o.remove(a),u}}*_parseFile(t,n,i=ic.Root,r){const o=yield this.loader.lookup(t,i,n,r);return this.parse(yield this.readFile(!!n,o),o)}};var it;(function(e){e[e.Number=1]="Number",e[e.Literal=2]="Literal",e[e.Tag=4]="Tag",e[e.Output=8]="Output",e[e.HTML=16]="HTML",e[e.Filter=32]="Filter",e[e.Hash=64]="Hash",e[e.PropertyAccess=128]="PropertyAccess",e[e.Word=256]="Word",e[e.Range=512]="Range",e[e.Quoted=1024]="Quoted",e[e.Operator=2048]="Operator",e[e.FilteredValue=4096]="FilteredValue",e[e.Delimited=12]="Delimited"})(it||(it={}));function JJ(e){return!!(vi(e)&it.Delimited)}function A8(e){return vi(e)===it.Operator}function c1(e){return vi(e)===it.HTML}function YJ(e){return vi(e)===it.Output}function $s(e){return vi(e)===it.Tag}function Ew(e){return vi(e)===it.Quoted}function d3(e){return vi(e)===it.Number}function dh(e){return vi(e)===it.PropertyAccess}function u3(e){return vi(e)===it.Word}function k8(e){return vi(e)===it.Range}function Sn(e){return(vi(e)&1667)>0}function vi(e){return e?e.kind:-1}class Ro{constructor(t={},n=ya,i={},{memoryLimit:r,renderLimit:o}={}){var a,c,l,d,u;this.scopes=[{}],this.registers={},this.breakCalled=!1,this.continueCalled=!1,this.sync=!!i.sync,this.opts=n,this.globals=(a=i.globals)!==null&&a!==void 0?a:n.globals,this.environments=jg(t)?t:Object(t),this.strictVariables=(c=i.strictVariables)!==null&&c!==void 0?c:this.opts.strictVariables,this.ownPropertyOnly=(l=i.ownPropertyOnly)!==null&&l!==void 0?l:n.ownPropertyOnly,this.memoryLimit=r??new Aw("memory alloc",(d=i.memoryLimit)!==null&&d!==void 0?d:n.memoryLimit),this.renderLimit=o??new Aw("template render",kw().now()+((u=i.renderLimit)!==null&&u!==void 0?u:n.renderLimit))}getRegister(t,n=void 0){return this.registers[t]=this.registers[t]||n}setRegister(t,n){return this.registers[t]=n}saveRegister(...t){return t.map(n=>[n,this.getRegister(n)])}restoreRegister(t){return t.forEach(([n,i])=>this.setRegister(n,i))}getAll(){return[this.globals,this.environments,...this.scopes].reduce((t,n)=>ch(t,n),{})}get(t){return this.getSync(t)}getSync(t){return ar(this._get(t))}*_get(t){const n=this.findScope(t[0]);return yield this._getFromScope(n,t)}getFromScope(t,n){return ar(this._getFromScope(t,n))}*_getFromScope(t,n,i=this.strictVariables){Pe(n)&&(n=n.split("."));for(let r=0;r<n.length;r++)if(t=yield this.readProperty(t,n[r]),i&&gW(t))throw new xW(n.slice(0,r+1).join("."));return t}push(t){return this.scopes.push(t)}pop(){return this.scopes.pop()}bottom(){return this.scopes[0]}spawn(t={}){return new Ro(t,this.opts,{sync:this.sync,globals:this.globals,strictVariables:this.strictVariables,ownPropertyOnly:this.ownPropertyOnly},{renderLimit:this.renderLimit,memoryLimit:this.memoryLimit})}findScope(t){for(let n=this.scopes.length-1;n>=0;n--){const i=this.scopes[n];if(t in i)return i}return t in this.environments?this.environments:this.globals}readProperty(t,n){if(t=t8(t),n=Be(n),_t(t))return t;if(Ut(t)&&n<0)return t[t.length+ +n];const i=QJ(t,n,this.ownPropertyOnly);return i===void 0&&t instanceof Cs?t.liquidMethodMissing(n,this):Tt(i)?i.call(t):n==="size"?eY(t):n==="first"?ZJ(t):n==="last"?XJ(t):i}}function QJ(e,t,n){if(!(n&&!i1.call(e,t)&&!(e instanceof Cs)))return e[t]}function ZJ(e){return Ut(e)?e[0]:e.first}function XJ(e){return Ut(e)?e[e.length-1]:e.last}function eY(e){if(i1.call(e,"size")||e.size!==void 0)return e.size;if(Ut(e)||Pe(e))return e.length;if(typeof e=="object")return Object.keys(e).length}var es;(function(e){e[e.OUTPUT=0]="OUTPUT",e[e.STORE=1]="STORE"})(es||(es={}));const tY=Hi(Math.abs),nY=Hi(Math.max),iY=Hi(Math.min),rY=Hi(Math.ceil),oY=Hi((e,t,n=!1)=>n?Math.floor(e/t):e/t),sY=Hi(Math.floor),aY=Hi((e,t)=>e-t),cY=Hi((e,t)=>e+t),lY=Hi((e,t)=>e%t),dY=Hi((e,t)=>e*t);function uY(e,t=0){e=ww(e),t=ww(t);const n=Math.pow(10,t),i=e*n;return Math.sign(e)*Math.round(Math.abs(i))/n}var pY=Object.freeze({__proto__:null,abs:tY,at_least:nY,at_most:iY,ceil:rY,divided_by:oY,floor:sY,minus:aY,plus:cY,modulo:lY,times:dY,round:uY});const fY=e=>decodeURIComponent(de(e)).replace(/\+/g," "),hY=e=>encodeURIComponent(de(e)).replace(/%20/g,"+"),gY=e=>encodeURIComponent(de(e)).replace(/%20/g,"+").replace(/[!'()*]/g,t=>"%"+t.charCodeAt(0).toString(16).toUpperCase()),mY=e=>encodeURI(de(e)).replace(/%5B/g,"[").replace(/%5D/g,"]"),p3=/[^\p{M}\p{L}\p{Nd}]+/ug,yY={raw:/\s+/g,default:p3,pretty:/[^\p{M}\p{L}\p{Nd}._~!$&'()+,;=@]+/ug,ascii:/[^A-Za-z0-9]+/g,latin:p3,none:null};function _Y(e,t="default",n=!1){e=de(e);const i=yY[t];return i&&(t==="latin"&&(e=wY(e)),e=e.replace(i,"-").replace(/^-|-$/g,"")),n?e:e.toLowerCase()}function wY(e){return e.replace(/[àáâãäå]/g,"a").replace(/[æ]/g,"ae").replace(/[ç]/g,"c").replace(/[èéêë]/g,"e").replace(/[ìíîï]/g,"i").replace(/[ð]/g,"d").replace(/[ñ]/g,"n").replace(/[òóôõöø]/g,"o").replace(/[ùúûü]/g,"u").replace(/[ýÿ]/g,"y").replace(/[ß]/g,"ss").replace(/[œ]/g,"oe").replace(/[þ]/g,"th").replace(/[ẞ]/g,"SS").replace(/[Œ]/g,"OE").replace(/[Þ]/g,"TH")}var bY=Object.freeze({__proto__:null,url_decode:fY,url_encode:hY,cgi_escape:gY,uri_escape:mY,slugify:_Y});const vY=Og(function(e,t){const n=Wt(e),i=_t(t)?" ":de(t),r=n.length*(1+i.length);return this.context.memoryLimit.use(r),n.join(i)}),AY=Og(e=>n8(e)?i8(e):""),kY=Og(e=>n8(e)?e[0]:""),SY=Og(function(e){const t=Wt(e);return this.context.memoryLimit.use(t.length),[...t].reverse()});function*S8(e,t,n){const i=[],r=Wt(e);this.context.memoryLimit.use(r.length);for(const o of r)i.push([o,t?yield this.context._getFromScope(o,de(t).split("."),!1):o]);return i.sort((o,a)=>n(o[1],a[1])).map(o=>o[0])}function*EY(e,t){return yield*S8.call(this,e,t,bW)}function*xY(e,t){return yield*S8.call(this,e,t,vW)}const CY=e=>e&&e.length||0;function*TY(e,t){const n=[],i=Wt(e);this.context.memoryLimit.use(i.length);for(const r of i)n.push(yield this.context._getFromScope(r,de(t),!1));return n}function*$Y(e,t){let n=0;const i=Wt(e);for(const r of i){const o=Number(t?yield this.context._getFromScope(r,de(t),!1):r);n+=Number.isNaN(o)?0:o}return n}function IY(e){const t=Wt(e);return this.context.memoryLimit.use(t.length),t.filter(n=>!_t(Be(n)))}function E8(e,t=[]){const n=Wt(e),i=Wt(t);return this.context.memoryLimit.use(n.length+i.length),n.concat(i)}function zY(e,t){return E8.call(this,e,[t])}function PY(e,t){const n=Wt(e);this.context.memoryLimit.use(n.length);const i=[...n];return i.unshift(t),i}function NY(e){const t=[...Wt(e)];return t.pop(),t}function jY(e){const t=Wt(e);this.context.memoryLimit.use(t.length);const n=[...t];return n.shift(),n}function OY(e,t,n=1){return e=Be(e),_t(e)?[]:(Ut(e)||(e=de(e)),t=t<0?e.length+t:t,this.context.memoryLimit.use(n),e.slice(t,t+n))}function x8(e){return this.context.opts.jekyllWhere?t=>nc.is(e)?ur(t,e):Ut(t)?mJ(t,e):ur(t,e):e===void 0?t=>Ko(t,this.context):t=>ur(t,e)}function*C8(e,t,n,i){const r=[];t=Wt(t),this.context.memoryLimit.use(t.length);const o=new Di(de(n)).readScopeValue();for(const c of t)r.push(yield Et(o,this.context.spawn(c)));const a=x8.call(this,i);return t.filter((c,l)=>a(r[l])===e)}function*T8(e,t,n,i){const r=[],o=new Cn(de(i),this.liquid),a=Wt(t);this.context.memoryLimit.use(a.length);for(const c of a){this.context.push({[n]:c});const l=yield o.value(this.context);this.context.pop(),l===e&&r.push(c)}return r}function*FY(e,t,n){return yield*C8.call(this,!0,e,t,n)}function*RY(e,t,n){return yield*C8.call(this,!1,e,t,n)}function*DY(e,t,n){return yield*T8.call(this,!0,e,t,n)}function*BY(e,t,n){return yield*T8.call(this,!1,e,t,n)}function*LY(e,t){const n=new Map;e=pu(e);const i=new Di(de(t)).readScopeValue();this.context.memoryLimit.use(e.length);for(const r of e){const o=yield Et(i,this.context.spawn(r));n.has(o)||n.set(o,[]),n.get(o).push(r)}return[...n.entries()].map(([r,o])=>({name:r,items:o}))}function*MY(e,t,n){const i=new Map,r=new Cn(de(n),this.liquid);e=pu(e),this.context.memoryLimit.use(e.length);for(const o of e){this.context.push({[t]:o});const a=yield r.value(this.context);this.context.pop(),i.has(a)||i.set(a,[]),i.get(a).push(o)}return[...i.entries()].map(([o,a])=>({name:o,items:a}))}function*l1(e,t,n){const i=new Di(de(t)).readScopeValue(),r=Wt(e),o=x8.call(this,n);for(let a=0;a<r.length;a++){const c=yield Et(i,this.context.spawn(r[a]));if(o(c))return[a,r[a]]}}function*d1(e,t,n){const i=new Cn(de(n),this.liquid),r=Wt(e);for(let o=0;o<r.length;o++){this.context.push({[t]:r[o]});const a=yield i.value(this.context);if(this.context.pop(),a)return[o,r[o]]}}function*UY(e,t,n){return!!(yield*l1.call(this,e,t,n))}function*qY(e,t,n){return!!(yield*d1.call(this,e,t,n))}function*HY(e,t,n){const i=yield*l1.call(this,e,t,n);return i?i[0]:void 0}function*VY(e,t,n){const i=yield*d1.call(this,e,t,n);return i?i[0]:void 0}function*KY(e,t,n){const i=yield*l1.call(this,e,t,n);return i?i[1]:void 0}function*GY(e,t,n){const i=yield*d1.call(this,e,t,n);return i?i[1]:void 0}function WY(e){return e=Wt(e),this.context.memoryLimit.use(e.length),[...new Set(e)]}function JY(e,t=1){if(e=Be(e),_t(e))return[];Ut(e)||(e=de(e)),this.context.memoryLimit.use(t);const n=[...e].sort(()=>Math.random()-.5);return t===1?n[0]:n.slice(0,t)}var YY=Object.freeze({__proto__:null,join:vY,last:AY,first:kY,reverse:SY,sort:EY,sort_natural:xY,size:CY,map:TY,sum:$Y,compact:IY,concat:E8,push:zY,unshift:PY,pop:NY,shift:jY,slice:OY,where:FY,reject:RY,where_exp:DY,reject_exp:BY,group_by:LY,group_by_exp:MY,has:UY,has_exp:qY,find_index:HY,find_index_exp:VY,find:KY,find_exp:GY,uniq:WY,sample:JY});function u1(e,t,n){var i,r;const o=((i=e?.length)!==null&&i!==void 0?i:0)+((r=n?.length)!==null&&r!==void 0?r:0);this.context.memoryLimit.use(o);const a=I8(e,this.context.opts,n);return a?(t=Be(t),t=_t(t)?this.context.opts.dateFormat:de(t),this.context.memoryLimit.use(t.length),gp(a,t,this.context.memoryLimit)):e}function QY(e){return u1.call(this,e,"%Y-%m-%dT%H:%M:%S%:z")}function ZY(e){return u1.call(this,e,"%a, %d %b %Y %H:%M:%S %z")}function XY(e,t,n){return $8.call(this,e,"%b",t,n)}function eQ(e,t,n){return $8.call(this,e,"%B",t,n)}function $8(e,t,n,i){const r=I8(e,this.context.opts);if(!r)return e;const o=this.context.memoryLimit;if(n==="ordinal"){const a=r.getDate();return i==="US"?gp(r,`${t} ${a}%q, %Y`,o):gp(r,`${a}%q ${t} %Y`,o)}return gp(r,`%d ${t} %Y`,o)}function I8(e,t,n){let i;const r=n??t.timezoneOffset,o=t.locale;if(e=Be(e),!_t(e))return e==="now"||e==="today"?i=new ri(Date.now(),o,r):Ng(e)?i=new ri(e*1e3,o,r):Pe(e)?/^\d+$/.test(e)?i=new ri(+e*1e3,o,r):t.preserveTimezones&&n===void 0?i=ri.createDateFixedToTimezone(e,o):i=new ri(e,o,r):i=new ri(e,o,r),i.valid()?i:void 0}var tQ=Object.freeze({__proto__:null,date:u1,date_to_xmlschema:QY,date_to_rfc822:ZY,date_to_string:XY,date_to_long_string:eQ});const Ym=/[\u4E00-\u9FFF\uF900-\uFAFF\u3400-\u4DBF\u3040-\u309F\u30A0-\u30FF\uAC00-\uD7AF]/gu,f3=/[^\u4E00-\u9FFF\uF900-\uFAFF\u3400-\u4DBF\u3040-\u309F\u30A0-\u30FF\uAC00-\uD7AF\s]+/gu;function nQ(e,t){Jt(arguments.length===2,"append expect 2 arguments");const n=de(e),i=de(t);return this.context.memoryLimit.use(n.length+i.length),n+i}function iQ(e,t){Jt(arguments.length===2,"prepend expect 2 arguments");const n=de(e),i=de(t);return this.context.memoryLimit.use(n.length+i.length),i+n}function rQ(e,t){const n=de(e);if(this.context.memoryLimit.use(n.length),t){t=de(t),this.context.memoryLimit.use(t.length);for(let i=0,r=new Set(t);i<n.length;i++)if(!r.has(n[i]))return n.slice(i);return""}return n.trimStart()}function oQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),t.toLowerCase()}function sQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),de(t).toUpperCase()}function aQ(e,t){const n=de(e);return t=de(t),this.context.memoryLimit.use(n.length+t.length),n.split(t).join("")}function cQ(e,t){const n=de(e);return t=de(t),this.context.memoryLimit.use(n.length+t.length),n.replace(t,"")}function lQ(e,t){const n=de(e),i=de(t);this.context.memoryLimit.use(n.length+i.length);const r=n.lastIndexOf(i);return r===-1?n:n.substring(0,r)+n.substring(r+i.length)}function dQ(e,t){if(e=de(e),this.context.memoryLimit.use(e.length),t){t=de(t),this.context.memoryLimit.use(t.length);for(let n=e.length-1,i=new Set(t);n>=0;n--)if(!i.has(e[n]))return e.slice(0,n+1);return""}return e.trimEnd()}function uQ(e,t){const n=de(e);this.context.memoryLimit.use(n.length);const i=n.split(de(t));for(;i.length&&i[i.length-1]==="";)i.pop();return i}function pQ(e,t){const n=de(e);if(this.context.memoryLimit.use(n.length),t){const i=new Set(de(t));this.context.memoryLimit.use(i.size);let r=0,o=n.length-1;for(;i.has(n[r]);)r++;for(;o>=r&&i.has(n[o]);)o--;return n.slice(r,o+1)}return n.trim()}function fQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),t.replace(/\r?\n/gm,"")}function hQ(e){return e=de(e),this.context.memoryLimit.use(e.length),e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()}function gQ(e,t,n){const i=de(e);t=de(t),n=de(n);const r=i.split(t),o=i.length+(r.length-1)*(n.length-t.length);return this.context.memoryLimit.use(o),r.join(n)}function mQ(e,t,n){const i=de(e);return t=de(t),n=de(n),this.context.memoryLimit.use(i.length+t.length+n.length),i.replace(t,()=>n)}function yQ(e,t,n){const i=de(e),r=de(t),o=de(n);this.context.memoryLimit.use(i.length+r.length+o.length);const a=i.lastIndexOf(r);return a===-1?i:i.substring(0,a)+o+i.substring(a+r.length)}function _Q(e,t=50,n="..."){const i=de(e);return n=de(n),this.context.memoryLimit.use(i.length+n.length),i.length<=t?e:i.substring(0,t-n.length)+n}function wQ(e,t=15,n="..."){const i=de(e);n=de(n),this.context.memoryLimit.use(i.length+n.length);const r=i.split(/\s+/);t<=0&&(t=1);let o=r.slice(0,t).join(" ");return r.length>=t&&(o+=n),o}function bQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),t.replace(/\s+/g," ")}function vQ(e,t){const n=de(e);if(this.context.memoryLimit.use(n.length),e=n.trim(),!e)return 0;switch(t){case"cjk":return(e.match(Ym)||[]).length+(e.match(f3)||[]).length;case"auto":return Ym.test(e)?e.match(Ym).length+(e.match(f3)||[]).length:e.split(/\s+/).length;default:return e.split(/\s+/).length}}function AQ(e,t="and"){switch(t=de(t),this.context.memoryLimit.use(e.length+t.length),e.length){case 0:return"";case 1:return e[0];case 2:return`${e[0]} ${t} ${e[1]}`;default:return`${e.slice(0,-1).join(", ")}, ${t} ${e[e.length-1]}`}}var kQ=Object.freeze({__proto__:null,append:nQ,prepend:iQ,lstrip:rQ,downcase:oQ,upcase:sQ,remove:aQ,remove_first:cQ,remove_last:lQ,rstrip:dQ,split:uQ,strip:pQ,strip_newlines:fQ,capitalize:hQ,replace:gQ,replace_first:mQ,replace_last:yQ,truncate:_Q,truncatewords:wQ,normalize_whitespace:bQ,number_of_words:vQ,array_to_sentence_string:AQ});function SQ(e){return btoa(String.fromCharCode(...new TextEncoder().encode(e)))}function EQ(e){return new TextDecoder().decode(Uint8Array.from(atob(e),t=>t.charCodeAt(0)))}function xQ(e){if(typeof Buffer<"u"&&Buffer.isBuffer(e))return this.context.memoryLimit.use(e.byteLength),e.toString("base64");const t=de(e);return this.context.memoryLimit.use(t.length),SQ(t)}function CQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),EQ(t)}var TQ=Object.freeze({__proto__:null,base64_encode:xQ,base64_decode:CQ});function z8(e){const t=new Uint8Array(e);let n="";for(let i=0;i<t.length;i++)n+=t[i].toString(16).padStart(2,"0");return n}function $Q(e){return at(this,void 0,void 0,function*(){const t=new TextEncoder().encode(e),n=yield crypto.subtle.digest("SHA-256",t);return z8(n)})}function IQ(e,t){return at(this,void 0,void 0,function*(){const n=new TextEncoder,i=yield crypto.subtle.importKey("raw",n.encode(t),{name:"HMAC",hash:"SHA-256"},!1,["sign"]),r=yield crypto.subtle.sign("HMAC",i,n.encode(e));return z8(r)})}function zQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),$Q(t)}function PQ(e,t){const n=de(e),i=de(t);return this.context.memoryLimit.use(n.length+i.length),IQ(n,i)}var NQ=Object.freeze({__proto__:null,sha256:zQ,hmac_sha256:PQ});const jQ=Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},FJ),pY),bY),YY),tQ),kQ),TQ),NQ),y8);class OQ extends pt{constructor(t,n,i){super(t,n,i),this.identifier=this.tokenizer.readIdentifier(),this.key=this.identifier.content,this.tokenizer.assert(this.key,"expected variable name"),this.tokenizer.skipBlank(),this.tokenizer.assert(this.tokenizer.peek()==="=",'expected "="'),this.tokenizer.advance(),this.value=new Cn(this.tokenizer.readFilteredValue(),this.liquid)}*render(t){t.bottom()[this.key]=yield this.value.value(t,this.liquid.options.lenientIf)}*arguments(){yield this.value}*localScope(){yield this.identifier}}const h3=["offset","limit","reversed"];class FQ extends pt{constructor(t,n,i,r){super(t,n,i);const o=this.tokenizer.readIdentifier(),a=this.tokenizer.readIdentifier(),c=this.tokenizer.readValue();if(!o.size()||a.content!=="in"||!c)throw new Error(`illegal tag: ${t.getText()}`);this.variable=o.content,this.collection=c,this.hash=new Pc(this.tokenizer,i.options.keyValueSeparator),this.templates=[],this.elseTemplates=[];let l;const d=r.parseStream(n).on("start",()=>l=this.templates).on("tag:else",u=>{ah(u.args),l=this.elseTemplates}).on("tag:endfor",u=>{ah(u.args),d.stop()}).on("template",u=>l.push(u)).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)});d.start()}*render(t,n){const i=this.liquid.renderer;let r=pu(yield Et(this.collection,t));if(!r.length){yield i.renderTemplates(this.elseTemplates,t,n);return}const o="continue-"+this.variable+"-"+this.collection.getText();t.push({continue:t.getRegister(o,{})});const a=yield this.hash.render(t);t.pop(),r=(this.liquid.options.orderedFilterParameters?Object.keys(a).filter(d=>h3.includes(d)):h3.filter(d=>a[d]!==void 0)).reduce((d,u)=>u==="offset"?DQ(d,a.offset):u==="limit"?BQ(d,a.limit):RQ(d),r),t.setRegister(o,(a.offset||0)+r.length);const l={forloop:new o1(r.length,this.collection.getText(),this.variable)};t.push(l);for(const d of r){if(l[this.variable]=d,t.continueCalled=t.breakCalled=!1,yield i.renderTemplates(this.templates,t,n),t.breakCalled)break;l.forloop.next()}t.continueCalled=t.breakCalled=!1,t.pop()}*children(){const t=this.templates.slice();return this.elseTemplates&&t.push(...this.elseTemplates),t}*arguments(){yield this.collection;for(const t of Object.values(this.hash.hash))Sn(t)&&(yield t)}blockScope(){return[this.variable,"forloop"]}}function RQ(e){return[...e].reverse()}function DQ(e,t){return e.slice(t)}function BQ(e,t){return e.slice(0,t)}class LQ extends pt{constructor(t,n,i,r){for(super(t,n,i),this.templates=[],this.identifier=this.readVariable(),this.variable=this.identifier.content;n.length;){const o=n.shift();if($s(o)&&o.name==="endcapture")return;this.templates.push(r.parseToken(o,n))}throw new Error(`tag ${t.getText()} not closed`)}readVariable(){let t=this.tokenizer.readIdentifier();if(t.content||(t=this.tokenizer.readQuoted(),t))return t;throw this.tokenizer.error("invalid capture name")}*render(t){const i=yield this.liquid.renderer.renderTemplates(this.templates,t);t.bottom()[this.variable]=i}*children(){return this.templates}*localScope(){yield this.identifier}}class MQ extends pt{constructor(t,n,i,r){super(t,n,i),this.branches=[],this.elseTemplates=[],this.value=new Cn(this.tokenizer.readFilteredValue(),this.liquid),this.elseTemplates=[];let o=[],a=0;const c=r.parseStream(n).on("tag:when",l=>{if(a>0)return;o=[];const d=[];for(;!l.tokenizer.end();)d.push(l.tokenizer.readValueOrThrow()),l.tokenizer.skipBlank(),l.tokenizer.peek()===","?l.tokenizer.readTo(","):l.tokenizer.readTo("or");this.branches.push({values:d,templates:o})}).on("tag:else",()=>{a++,o=this.elseTemplates}).on("tag:endcase",()=>c.stop()).on("template",l=>{(o!==this.elseTemplates||a===1)&&o.push(l)}).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)});c.start()}*render(t,n){const i=this.liquid.renderer,r=Be(yield this.value.value(t,t.opts.lenientIf));let o=!1;for(const a of this.branches)for(const c of a.values){const l=yield Et(c,t,t.opts.lenientIf);if(ur(r,l)){yield i.renderTemplates(a.templates,t,n),o=!0;break}}o||(yield i.renderTemplates(this.elseTemplates,t,n))}*arguments(){yield this.value,yield*this.branches.flatMap(t=>t.values)}*children(){const t=this.branches.flatMap(n=>n.templates);return this.elseTemplates&&t.push(...this.elseTemplates),t}}class UQ extends pt{constructor(t,n,i){for(super(t,n,i);n.length;){const r=n.shift();if($s(r)&&r.name==="endcomment")return}throw new Error(`tag ${t.getText()} not closed`)}render(){}}class qQ extends pt{constructor(t,n,i,r){super(t,n,i);const o=this.tokenizer;for(this.file=p1(o,this.liquid,r),this.currentFile=t.file;!o.end();){o.skipBlank();const a=o.p,c=o.readIdentifier();if((c.content==="with"||c.content==="for")&&(o.skipBlank(),o.peek()!==":")){const l=o.readValue();if(l){const d=o.p,u=o.readIdentifier();let p;u.content==="as"?p=o.readIdentifier():o.p=d,this[c.content]={value:l,alias:p&&p.content},o.skipBlank(),o.peek()===","&&o.advance();continue}}o.p=a;break}this.hash=new Pc(o,i.options.keyValueSeparator)}*render(t,n){const{liquid:i,hash:r}=this,o=yield f1(this.file,t,i);Jt(o,()=>`illegal file path "${o}"`);const a=t.spawn(),c=a.bottom();if(ch(c,yield r.render(t)),this.with){const{value:l,alias:d}=this.with;c[d||o]=yield Et(l,t)}if(this.for){const{value:l,alias:d}=this.for,u=pu(yield Et(l,t));c.forloop=new o1(u.length,l.getText(),d);for(const p of u){c[d]=p;const f=yield i._parsePartialFile(o,a.sync,this.currentFile);yield i.renderer.renderTemplates(f,a,n),c.forloop.next()}}else{const l=yield i._parsePartialFile(o,a.sync,this.currentFile);yield i.renderer.renderTemplates(l,a,n)}}*children(t,n){return t&&Pe(this.file)?yield this.liquid._parsePartialFile(this.file,n,this.currentFile):[]}partialScope(){if(Pe(this.file)){const t=Object.keys(this.hash.hash);if(this.with){const{value:n,alias:i}=this.with;Pe(i)?t.push([i,n]):Pe(this.file)&&t.push([this.file,n])}if(this.for){const{value:n,alias:i}=this.for;Pe(i)?t.push([i,n]):Pe(this.file)&&t.push([this.file,n])}return{name:this.file,isolated:!0,scope:t}}}*arguments(){for(const t of Object.values(this.hash.hash))Sn(t)&&(yield t);if(this.with){const{value:t}=this.with;Sn(t)&&(yield t)}if(this.for){const{value:t}=this.for;Sn(t)&&(yield t)}}}function p1(e,t,n){if(t.options.dynamicPartials){const o=e.readValue();if(e.assert(o,"illegal file path"),o.getText()==="none")return;if(Ew(o)){const a=n.parse(uJ(o));return g3(a)}return o}const i=[...e.readFileNameTemplate(t.options)],r=g3(n.parseTokens(i));return r==="none"?void 0:r}function g3(e){return e.length===1&&c1(e[0].token)?e[0].token.getContent():e}function*f1(e,t,n){return typeof e=="string"?e:Array.isArray(e)?n.renderer.renderTemplates(e,t):yield Et(e,t)}class HQ extends pt{constructor(t,n,i,r){super(t,n,i);const{tokenizer:o}=t;this.file=p1(o,this.liquid,r),this.currentFile=t.file;const a=o.p;o.readIdentifier().content==="with"?(o.skipBlank(),o.peek()!==":"?this.withVar=o.readValue():o.p=a):o.p=a,this.hash=new Pc(o,i.options.jekyllInclude||i.options.keyValueSeparator)}*render(t,n){const{liquid:i,hash:r,withVar:o}=this,{renderer:a}=i,c=yield f1(this.file,t,i);Jt(c,()=>`illegal file path "${c}"`);const l=t.saveRegister("blocks","blockMode");t.setRegister("blocks",{}),t.setRegister("blockMode",es.OUTPUT);const d=yield r.render(t);o&&(d[c]=yield Et(o,t));const u=yield i._parsePartialFile(c,t.sync,this.currentFile);t.push(t.opts.jekyllInclude?{include:d}:d),yield a.renderTemplates(u,t,n),t.pop(),t.restoreRegister(l)}*children(t,n){return t&&Pe(this.file)?yield this.liquid._parsePartialFile(this.file,n,this.currentFile):[]}partialScope(){if(Pe(this.file)){let t;return this.liquid.options.jekyllInclude?t=["include"]:(t=Object.keys(this.hash.hash),this.withVar&&t.push([this.file,this.withVar])),{name:this.file,isolated:!1,scope:t}}}*arguments(){yield*Object.values(this.hash.hash).filter(Sn),Sn(this.file)&&(yield this.file),Sn(this.withVar)&&(yield this.withVar)}}class VQ extends pt{constructor(t,n,i){super(t,n,i),this.identifier=this.tokenizer.readIdentifier(),this.variable=this.identifier.content}render(t,n){const i=t.environments;Ng(i[this.variable])||(i[this.variable]=0),n.write(de(--i[this.variable]))}*localScope(){yield this.identifier}}class KQ extends pt{constructor(t,n,i){super(t,n,i),this.candidates=[];const r=this.tokenizer.readValue();for(this.tokenizer.skipBlank(),r&&(this.tokenizer.peek()===":"?(this.group=r,this.tokenizer.advance()):this.candidates.push(r));!this.tokenizer.end();){const o=this.tokenizer.readValue();o&&this.candidates.push(o),this.tokenizer.readTo(",")}this.tokenizer.assert(this.candidates.length,()=>`empty candidates: "${t.getText()}"`)}*render(t,n){const r=`cycle:${yield Et(this.group,t)}:`+this.candidates.join(","),o=t.getRegister("cycle",{});let a=o[r];a===void 0&&(a=o[r]=0);const c=this.candidates[a];return a=(a+1)%this.candidates.length,o[r]=a,yield Et(c,t)}*arguments(){yield*this.candidates,this.group&&(yield this.group)}}class GQ extends pt{constructor(t,n,i,r){super(t,n,i),this.branches=[];let o=[];r.parseStream(n).on("start",()=>this.branches.push({value:new Cn(t.tokenizer.readFilteredValue(),this.liquid),templates:o=[]})).on("tag:elsif",a=>{Jt(!this.elseTemplates,"unexpected elsif after else"),this.branches.push({value:new Cn(a.tokenizer.readFilteredValue(),this.liquid),templates:o=[]})}).on("tag:else",a=>{ah(a.args),Jt(!this.elseTemplates,"duplicated else"),o=this.elseTemplates=[]}).on("tag:endif",function(a){ah(a.args),this.stop()}).on("template",a=>o.push(a)).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)}).start()}*render(t,n){const i=this.liquid.renderer;for(const{value:r,templates:o}of this.branches){const a=yield r.value(t,t.opts.lenientIf);if(Ko(a,t)){yield i.renderTemplates(o,t,n);return}}yield i.renderTemplates(this.elseTemplates||[],t,n)}*children(){const t=this.branches.flatMap(n=>n.templates);return this.elseTemplates&&t.push(...this.elseTemplates),t}arguments(){return this.branches.map(t=>t.value)}}class WQ extends pt{constructor(t,n,i){super(t,n,i),this.identifier=this.tokenizer.readIdentifier(),this.variable=this.identifier.content}render(t,n){const i=t.environments;Ng(i[this.variable])||(i[this.variable]=0);const r=i[this.variable];i[this.variable]++,n.write(de(r))}*localScope(){yield this.identifier}}class JQ extends pt{constructor(t,n,i,r){super(t,n,i),this.file=p1(this.tokenizer,this.liquid,r),this.currentFile=t.file,this.args=new Pc(this.tokenizer,i.options.keyValueSeparator),this.templates=r.parseTokens(n)}*render(t,n){const{liquid:i,args:r,file:o}=this,{renderer:a}=i;if(o===void 0){t.setRegister("blockMode",es.OUTPUT),yield a.renderTemplates(this.templates,t,n);return}const c=yield f1(this.file,t,i);Jt(c,()=>`illegal file path "${c}"`);const l=yield i._parseLayoutFile(c,t.sync,this.currentFile);t.setRegister("blockMode",es.STORE);const d=yield a.renderTemplates(this.templates,t),u=t.getRegister("blocks",{});u[""]===void 0&&(u[""]=(p,f)=>f.write(d)),t.setRegister("blockMode",es.OUTPUT),t.push(yield r.render(t)),yield a.renderTemplates(l,t,n),t.pop()}*children(t){const n=this.templates.slice();return t&&Pe(this.file)&&n.push(...yield this.liquid._parsePartialFile(this.file,!0,this.currentFile)),n}*arguments(){for(const t of Object.values(this.args.hash))Sn(t)&&(yield t);Sn(this.file)&&(yield this.file)}partialScope(){if(Pe(this.file))return{name:this.file,isolated:!1,scope:Object.keys(this.args.hash)}}}class YQ extends pt{constructor(t,n,i,r){super(t,n,i),this.templates=[];const o=/\w+/.exec(t.args);for(this.block=o?o[0]:"";n.length;){const a=n.shift();if($s(a)&&a.name==="endblock")return;const c=r.parseToken(a,n);this.templates.push(c)}throw new Error(`tag ${t.getText()} not closed`)}*render(t,n){const i=this.getBlockRender(t);t.getRegister("blockMode")===es.STORE?t.getRegister("blocks",{})[this.block]=i:yield i(new GS,n)}getBlockRender(t){const n=this,{liquid:i,templates:r}=this,o=t.getRegister("blocks",{})[this.block],a=function*(c,l){const d=t.getRegister("blockStack",[]);if(d.includes(n))throw new Error("block tag cannot be nested");d.push(n),t.push({block:c}),yield i.renderer.renderTemplates(r,t,l),t.pop(),d.pop()};return o?(c,l)=>o(new GS(d=>a(c,d)),l):a}*children(){return this.templates}blockScope(){return["block"]}}class QQ extends pt{constructor(t,n,i){for(super(t,n,i),this.tokens=[];n.length;){const r=n.shift();if($s(r)&&r.name==="endraw")return;this.tokens.push(r)}throw new Error(`tag ${t.getText()} not closed`)}render(){return this.tokens.map(t=>t.getText()).join("")}}class ZQ extends o1{constructor(t,n,i,r){super(t,i,r),this.length=t,this.cols=n}row(){return Math.floor(this.i/this.cols)+1}col0(){return this.i%this.cols}col(){return this.col0()+1}col_first(){return this.col0()===0}col_last(){return this.col()===this.cols}}class XQ extends pt{constructor(t,n,i,r){super(t,n,i);const o=this.tokenizer.readIdentifier();this.tokenizer.skipBlank();const a=this.tokenizer.readIdentifier(),c=this.tokenizer.readValue();if(a.content!=="in"||!c)throw new Error(`illegal tag: ${t.getText()}`);this.variable=o.content,this.collection=c,this.args=new Pc(this.tokenizer,i.options.keyValueSeparator),this.templates=[];let l;const d=r.parseStream(n).on("start",()=>l=this.templates).on("tag:endtablerow",()=>d.stop()).on("template",u=>l.push(u)).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)});d.start()}*render(t,n){let i=pu(yield Et(this.collection,t));const r=yield this.args.render(t),o=r.offset||0,a=r.limit===void 0?i.length:r.limit;i=i.slice(o,o+a);const c=r.cols||i.length,l=this.liquid.renderer,d=new ZQ(i.length,c,this.collection.getText(),this.variable),u={tablerowloop:d};t.push(u);for(let p=0;p<i.length;p++,d.next())u[this.variable]=i[p],d.col0()===0&&(d.row()!==1&&n.write("</tr>"),n.write(`<tr class="row${d.row()}">`)),n.write(`<td class="col${d.col()}">`),yield l.renderTemplates(this.templates,t,n),n.write("</td>");i.length&&n.write("</tr>"),t.pop()}*children(){return this.templates}*arguments(){yield this.collection;for(const t of Object.values(this.args.hash))Sn(t)&&(yield t)}blockScope(){return[this.variable,"tablerowloop"]}}class eZ extends pt{constructor(t,n,i,r){super(t,n,i),this.branches=[],this.elseTemplates=[];let o=[],a=0;r.parseStream(n).on("start",()=>this.branches.push({value:new Cn(t.tokenizer.readFilteredValue(),this.liquid),test:Fg,templates:o=[]})).on("tag:elsif",c=>{if(a>0){o=[];return}this.branches.push({value:new Cn(c.tokenizer.readFilteredValue(),this.liquid),test:Ko,templates:o=[]})}).on("tag:else",()=>{a++,o=this.elseTemplates}).on("tag:endunless",function(){this.stop()}).on("template",c=>{(o!==this.elseTemplates||a===1)&&o.push(c)}).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)}).start()}*render(t,n){const i=this.liquid.renderer;for(const{value:r,test:o,templates:a}of this.branches){const c=yield r.value(t,t.opts.lenientIf);if(o(c,t)){yield i.renderTemplates(a,t,n);return}}yield i.renderTemplates(this.elseTemplates,t,n)}*children(){const t=this.branches.flatMap(n=>n.templates);return this.elseTemplates&&t.push(...this.elseTemplates),t}arguments(){return this.branches.map(t=>t.value)}}class tZ extends pt{render(t,n){t.breakCalled=!0}}class nZ extends pt{render(t,n){t.continueCalled=!0}}class iZ extends pt{constructor(t,n,i){super(t,n,i),this.tokenizer.skipBlank(),this.tokenizer.end()||(this.value=new Cn(this.tokenizer.readFilteredValue(),this.liquid))}*render(t,n){if(!this.value)return;const i=yield this.value.value(t,!1);n.write(i)}*arguments(){this.value&&(yield this.value)}}class rZ extends pt{constructor(t,n,i,r){super(t,n,i);const o=this.tokenizer.readLiquidTagTokens(this.liquid.options);this.templates=r.parseTokens(o)}*render(t,n){yield this.liquid.renderer.renderTemplates(this.templates,t,n)}*children(){return this.templates}}class oZ extends pt{constructor(t,n,i){if(super(t,n,i),t.args.search(/\n\s*[^#\s]/g)!==-1)throw new Error("every line of an inline comment must start with a '#' character")}render(){}}const sZ={assign:OQ,for:FQ,capture:LQ,case:MQ,comment:UQ,include:HQ,render:qQ,decrement:VQ,increment:WQ,cycle:KQ,if:GQ,layout:JQ,block:YQ,raw:QQ,tablerow:XQ,unless:eZ,break:tZ,continue:nZ,echo:iZ,liquid:rZ,"#":oZ};class h1{constructor(t={}){this.renderer=new cJ,this.filters=Object.create(null),this.tags=Object.create(null),this.options=DJ(t),this.parser=new bo(this),HS(sZ,(n,i)=>this.registerTag(i,n)),HS(jQ,(n,i)=>this.registerFilter(i,n))}parse(t,n){return new bo(this).parse(t,n)}_render(t,n,i){const r=n instanceof Ro?n:new Ro(n,this.options,i);return this.renderer.renderTemplates(t,r)}render(t,n,i){return at(this,void 0,void 0,function*(){return sr(this._render(t,n,Object.assign(Object.assign({},i),{sync:!1})))})}renderSync(t,n,i){return ar(this._render(t,n,Object.assign(Object.assign({},i),{sync:!0})))}renderToNodeStream(t,n,i={}){const r=new Ro(n,this.options,i);return this.renderer.renderTemplatesToNodeStream(t,r)}_parseAndRender(t,n,i){const r=this.parse(t);return this._render(r,n,i)}parseAndRender(t,n,i){return at(this,void 0,void 0,function*(){return sr(this._parseAndRender(t,n,Object.assign(Object.assign({},i),{sync:!1})))})}parseAndRenderSync(t,n,i){return ar(this._parseAndRender(t,n,Object.assign(Object.assign({},i),{sync:!0})))}_parsePartialFile(t,n,i){return new bo(this).parseFile(t,n,ic.Partials,i)}_parseLayoutFile(t,n,i){return new bo(this).parseFile(t,n,ic.Layouts,i)}_parseFile(t,n,i,r){return new bo(this).parseFile(t,n,i,r)}parseFile(t,n){return at(this,void 0,void 0,function*(){return sr(new bo(this).parseFile(t,!1,n))})}parseFileSync(t,n){return ar(new bo(this).parseFile(t,!0,n))}*_renderFile(t,n,i){const r=yield this._parseFile(t,i.sync,i.lookupType);return yield this._render(r,n,i)}renderFile(t,n,i){return at(this,void 0,void 0,function*(){return sr(this._renderFile(t,n,Object.assign(Object.assign({},i),{sync:!1})))})}renderFileSync(t,n,i){return ar(this._renderFile(t,n,Object.assign(Object.assign({},i),{sync:!0})))}renderFileToNodeStream(t,n,i){return at(this,void 0,void 0,function*(){const r=yield this.parseFile(t);return this.renderToNodeStream(r,n,i)})}_evalValue(t,n){const i=new Cn(t,this),r=n instanceof Ro?n:new Ro(n,this.options);return i.value(r)}evalValue(t,n){return at(this,void 0,void 0,function*(){return sr(this._evalValue(t,n))})}evalValueSync(t,n){return ar(this._evalValue(t,n))}registerFilter(t,n){this.filters[t]=n}registerTag(t,n){this.tags[t]=Tt(n)?n:HJ(n)}plugin(t){return t.call(this,h1)}express(){const t=this;let n=!0;return function(i,r,o){if(n){n=!1;const a=mp(this.root);t.options.root.unshift(...a),t.options.layouts.unshift(...a),t.options.partials.unshift(...a)}t.renderFile(i,r).then(a=>o(null,a),o)}}analyze(t,n={}){return at(this,void 0,void 0,function*(){return Ir(t,n)})}analyzeSync(t,n={}){return zr(t,n)}parseAndAnalyze(t,n,i={}){return at(this,void 0,void 0,function*(){return Ir(this.parse(t,n),i)})}parseAndAnalyzeSync(t,n,i={}){return zr(this.parse(t,n),i)}variables(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Object.keys(i.variables)})}variablesSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Object.keys(i.variables)}fullVariables(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Array.from(new Set(Object.values(i.variables).flatMap(r=>r.map(o=>String(o)))))})}fullVariablesSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Array.from(new Set(Object.values(i.variables).flatMap(r=>r.map(o=>String(o)))))}variableSegments(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Array.from(Lu(Object.values(i.variables).flatMap(r=>r.map(o=>o.toArray()))))})}variableSegmentsSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Array.from(Lu(Object.values(i.variables).flatMap(r=>r.map(o=>o.toArray()))))}globalVariables(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Object.keys(i.globals)})}globalVariablesSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Object.keys(i.globals)}globalFullVariables(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Array.from(new Set(Object.values(i.globals).flatMap(r=>r.map(o=>String(o)))))})}globalFullVariablesSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Array.from(new Set(Object.values(i.globals).flatMap(r=>r.map(o=>String(o)))))}globalVariableSegments(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Array.from(Lu(Object.values(i.globals).flatMap(r=>r.map(o=>o.toArray()))))})}globalVariableSegmentsSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Array.from(Lu(Object.values(i.globals).flatMap(r=>r.map(o=>o.toArray()))))}}const aZ={reset_email:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ password_reset_title }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ password_reset_title }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ reset_password_email_click_to_reset }}</p><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="text-align:center;margin-bottom:1rem;margin-top:1rem"><tbody><tr><td><a href="{{ url }}" style="line-height:100%;text-decoration:none;display:inline-block;max-width:100%;mso-padding-alt:0px;background-color:{{ branding.primary_color }};color:#ffffff;border-radius:4px;font-size:14px;font-weight:600;padding:12px 24px;padding-top:12px;padding-right:24px;padding-bottom:12px;padding-left:24px" target="_blank"><span><!--[if mso]><i style="mso-font-width:400%;mso-text-raise:18" hidden>&#8202;&#8202;&#8202;</i><![endif]--></span><span style="max-width:100%;display:inline-block;line-height:120%;mso-padding-alt:0px;mso-text-raise:9px">{{ reset_password_email_reset }}</span><span><!--[if mso]><i style="mso-font-width:400%" hidden>&#8202;&#8202;&#8202;&#8203;</i><![endif]--></span></a></td></tr></tbody></table></td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>',reset_email_by_code:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ password_reset_title }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ password_reset_title }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ reset_password_email_click_to_reset }}</p><p style="font-size:1.875rem;line-height:1.2;font-weight:700;text-align:center;margin-bottom:1rem;margin-top:1rem;letter-spacing:0.25em">{{ code }}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);text-align:center;margin-top:16px;margin-bottom:16px">{{ code_valid_30_minutes }}</p></td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>',verify_email:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ welcome_to_your_account }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ welcome_to_your_account }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ link_email_click_to_login }}</p><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="text-align:center;margin-bottom:1rem;margin-top:1rem"><tbody><tr><td><a href="{{ url }}" style="line-height:100%;text-decoration:none;display:inline-block;max-width:100%;mso-padding-alt:0px;background-color:{{ branding.primary_color }};color:#ffffff;border-radius:4px;font-size:14px;font-weight:600;padding:12px 24px;padding-top:12px;padding-right:24px;padding-bottom:12px;padding-left:24px" target="_blank"><span><!--[if mso]><i style="mso-font-width:400%;mso-text-raise:18" hidden>&#8202;&#8202;&#8202;</i><![endif]--></span><span style="max-width:100%;display:inline-block;line-height:120%;mso-padding-alt:0px;mso-text-raise:9px">{{ link_email_login }}</span><span><!--[if mso]><i style="mso-font-width:400%" hidden>&#8202;&#8202;&#8202;&#8203;</i><![endif]--></span></a></td></tr></tbody></table>{% if code %}<p style="font-size:14px;line-height:24px;text-align:center;color:rgb(113,113,123);margin-top:1rem;margin-bottom:16px">{{ link_email_or_enter_code }}</p><p style="font-size:1.875rem;line-height:1.2;font-weight:700;text-align:center;margin-bottom:0.5rem;margin-top:0.5rem;letter-spacing:0.25em">{{ code }}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);text-align:center;margin-top:16px;margin-bottom:16px">{{ code_valid_30_minutes }}</p>{% endif %}</td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>',verify_email_by_code:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ welcome_to_your_account }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ welcome_to_your_account }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ link_email_click_to_login }}</p><p style="font-size:1.875rem;line-height:1.2;font-weight:700;text-align:center;margin-bottom:1rem;margin-top:1rem;letter-spacing:0.25em">{{ code }}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);text-align:center;margin-top:16px;margin-bottom:16px">{{ code_valid_30_minutes }}</p></td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>',welcome_email:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ welcome_to_your_account }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ welcome_to_your_account }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ welcome_body }}</p>{% if url %}<table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="text-align:center;margin-bottom:1rem;margin-top:1rem"><tbody><tr><td><a href="{{ url }}" style="line-height:100%;text-decoration:none;display:inline-block;max-width:100%;mso-padding-alt:0px;background-color:{{ branding.primary_color }};color:#ffffff;border-radius:4px;font-size:14px;font-weight:600;padding:12px 24px;padding-top:12px;padding-right:24px;padding-bottom:12px;padding-left:24px" target="_blank"><span><!--[if mso]><i style="mso-font-width:400%;mso-text-raise:18" hidden>&#8202;&#8202;&#8202;</i><![endif]--></span><span style="max-width:100%;display:inline-block;line-height:120%;mso-padding-alt:0px;mso-text-raise:9px">{{ welcome_cta }}</span><span><!--[if mso]><i style="mso-font-width:400%" hidden>&#8202;&#8202;&#8202;&#8203;</i><![endif]--></span></a></td></tr></tbody></table>{% endif %}</td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>'},cZ={reset_email:"{{ password_reset_title }}",reset_email_by_code:"{{ password_reset_title }}",verify_email:"{{ welcome_to_your_account }}",verify_email_by_code:"{{ code_email_subject }}",welcome_email:"{{ welcome_to_your_account }}"};function lZ(e){const t=aZ[e],n=cZ[e];return!t||!n?null:{subject:n,body:t}}const m3=new h1({cache:!0,strictVariables:!1,strictFilters:!1});async function dZ(e,t,n,i){const r=await e.env.data.emailTemplates.get(e.var.tenant_id,t);if(r&&r.enabled===!1)return{kind:"disabled"};const o=r?{subject:r.subject,body:r.body}:lZ(t);if(!o)return{kind:"none"};const[a,c]=await Promise.all([m3.parseAndRender(o.subject,n),m3.parseAndRender(o.body,n)]);return{kind:"rendered",email:{subject:a,html:c,from:r?.from||i}}}const P8=s.z.object({api_key:s.z.string().min(1),domain:s.z.string().min(4),region:s.z.enum(["eu"]).nullish()});class N8{fetchImpl;constructor(t={}){this.fetchImpl=t.fetchImpl??fetch}async send(t){const n=P8.parse(t.emailProvider.credentials),r=`https://${n.region==="eu"?"api.eu.mailgun.net":"api.mailgun.net"}/v3/${encodeURIComponent(n.domain)}/messages`,o=new URLSearchParams;o.append("from",t.from),o.append("to",t.to),o.append("subject",t.subject),o.append("template",t.template),o.append("h:X-Mailgun-Variables",JSON.stringify(t.data)),t.html&&o.append("html",t.html),t.text&&o.append("text",t.text);const a=btoa(`api:${n.api_key}`),c=await this.fetchImpl(r,{method:"POST",headers:{Authorization:`Basic ${a}`,"Content-Type":"application/x-www-form-urlencoded"},body:o.toString()});if(!c.ok){const l=await c.text().catch(()=>"");throw new Error(`Mailgun send failed: ${c.status} ${c.statusText} ${l.slice(0,500)}`)}}}const uZ={mailgun:()=>new N8};async function pZ(e,t){const n=await e.env.data.emailProviders.get(e.var.tenant_id);if(!n)throw new z(500,{message:"Email provider not found"});const i=uZ[n.name],r=i?i():e.env.data.emailService;if(!r)throw new z(500,{message:"Email service not configured"});try{await r.send({emailProvider:n,...t,from:t.from||n.default_from_address||`login@${e.env.ISSUER}`})}catch(o){const a=o instanceof Error?o.message:String(o);throw console.error(`[sendEmail] tenant=${e.var.tenant_id} provider=${n.name} template=${t.template} to=${t.to}: ${a}`,o),await B(e,e.var.tenant_id,{type:R.FAILED_SENDING_NOTIFICATION,description:`email send failed via ${n.name}: ${a}`.slice(0,500),details:{provider:n.name,template:t.template,to:t.to,error:a},waitForCompletion:!0}),o}}async function j8(e,t){if(!e.var.client_id)throw new z(500,{message:"Client not found"});const n=await nt(e.env,e.var.client_id),i=n.connections.find(o=>o.strategy===Z.SMS);if(!i)throw new z(500,{message:"SMS provider not found"});const r=e.env.data.smsService;if(!r)throw new z(500,{message:"SMS service not configured"});try{await r.send({options:i.options,to:t.to,from:t.from,text:t.text,template:"auth-code",data:{code:t.code,tenantName:n.tenant.friendly_name,tenantId:n.tenant.id}})}catch(o){const a=o instanceof Error?o.message:String(o);throw console.error(`[sendSms] tenant=${e.var.tenant_id} connection=${i.name} to=${t.to}: ${a}`,o),await B(e,e.var.tenant_id,{type:R.FAILED_SENDING_NOTIFICATION,description:`sms send failed via ${i.name}: ${a}`.slice(0,500),details:{connection:i.name,to:t.to,error:a},waitForCompletion:!0}),o}}async function O8(e,t){const n=await e.env.data.tenants.get(e.var.tenant_id);if(!n)throw new z(500,{message:"Tenant not found"});const i=await e.env.data.branding.get(e.var.tenant_id),r=i?.logo_url||"",o=i?.colors?.primary||"#7d68f4",a={vendorName:n.friendly_name,lng:t||"en"};return{tenant:n,logo:r,buttonColor:o,options:a}}async function Nc(e,t){const i=(await e.env.data.emailProviders.get(e.var.tenant_id))?.default_from_address||`login@${e.env.ISSUER}`,r={...t.data,tenant:{id:t.tenant.id,friendly_name:t.tenant.friendly_name,support_url:t.tenant.support_url||""},branding:{logo:t.branding.logo,primary_color:t.branding.primary_color},url:t.url,code:t.code},o=await dZ(e,t.templateName,r,i);if(o.kind==="disabled")return!1;const a=o.kind==="rendered"?o.email.subject:t.fallbackSubject,c=o.kind==="rendered"?o.email.html:t.fallbackHtml,l=o.kind==="rendered"?o.email.from:i;return await pZ(e,{to:t.to,subject:a,html:c,template:t.legacyTemplate,data:t.data,from:l}),!0}async function F8(e,t,n,i,r){const{tenant:o,logo:a,buttonColor:c,options:l}=await O8(e,r),d=`${Fn(e.env)}reset-password?state=${i}&code=${n}`,u={vendorName:o.friendly_name,logo:a,passwordResetUrl:d,supportUrl:o.support_url||"https://support.sesamy.com",buttonColor:c,password_reset_title:oe("password_reset_title",l),passwordResetTitle:oe("password_reset_title",l),reset_password_email_click_to_reset:oe("reset_password_email_click_to_reset",l),resetPasswordEmailClickToReset:oe("reset_password_email_click_to_reset",l),reset_password_email_reset:oe("reset_password_email_reset",l),resetPasswordEmailReset:oe("reset_password_email_reset",l),support_info:oe("support_info",l),supportInfo:oe("support_info",l),contact_us:oe("contact_us",l),contactUs:oe("contact_us",l),copyright:oe("copyright",l),tenantName:o.friendly_name,tenantId:o.id};await Nc(e,{to:t,templateName:"reset_email",legacyTemplate:"auth-password-reset",fallbackSubject:oe("reset_password_title",l),fallbackHtml:`Click here to reset your password: ${d}`,tenant:o,branding:{logo:a,primary_color:c},url:d,data:u}),B(e,o.id,{type:R.SUCCESS_CHANGE_PASSWORD_REQUEST,description:t})}async function fZ(e,t,n,i){const{tenant:r,logo:o,buttonColor:a,options:c}=await O8(e,i),l={code:n,vendorName:r.friendly_name,logo:o,supportUrl:r.support_url||"https://support.sesamy.com",buttonColor:a,welcomeToYourAccount:oe("password_reset_title",c),password_reset_title:oe("password_reset_title",c),linkEmailClickToLogin:oe("reset_password_email_click_to_reset",c),reset_password_email_click_to_reset:oe("reset_password_email_click_to_reset",c),linkEmailLogin:oe("reset_password_email_reset",c),reset_password_email_reset:oe("reset_password_email_reset",c),linkEmailOrEnterCode:oe("link_email_or_enter_code",{...c,code:n}),codeValid30Mins:oe("code_valid_30_minutes",c),code_valid_30_minutes:oe("code_valid_30_minutes",c),support_info:oe("support_info",c),supportInfo:oe("support_info",c),contact_us:oe("contact_us",c),contactUs:oe("contact_us",c),copyright:oe("copyright",c)};await Nc(e,{to:t,templateName:"reset_email_by_code",legacyTemplate:"auth-code",fallbackSubject:oe("reset_password_title",c),fallbackHtml:`Your password reset code is: ${n}`,tenant:r,branding:{logo:o,primary_color:a},code:n,data:l}),B(e,r.id,{type:R.SUCCESS_CHANGE_PASSWORD_REQUEST,description:t})}async function fu(e,{to:t,code:n,language:i}){const r=await e.env.data.tenants.get(e.var.tenant_id);if(!r)throw new z(500,{message:"Tenant not found"});const{connectionType:o}=go(t),a=await e.env.data.branding.get(e.var.tenant_id),c=a?.logo_url||"",l=a?.colors?.primary||"#7d68f4",d=new URL(Fn(e.env)),u={vendorName:r.friendly_name,vendorId:r.id,loginDomain:d.hostname,code:n,lng:i||"en"};if(o==="email"){const p={code:n,vendorName:r.friendly_name,logo:c,supportUrl:r.support_url||"",buttonColor:l,welcomeToYourAccount:oe("welcome_to_your_account",u),welcome_to_your_account:oe("welcome_to_your_account",u),linkEmailClickToLogin:oe("link_email_click_to_login",u),link_email_click_to_login:oe("link_email_click_to_login",u),linkEmailLogin:oe("link_email_login",u),link_email_login:oe("link_email_login",u),linkEmailOrEnterCode:oe("link_email_or_enter_code",u),link_email_or_enter_code:oe("link_email_or_enter_code",u),codeValid30Mins:oe("code_valid_30_minutes",u),code_valid_30_minutes:oe("code_valid_30_minutes",u),code_email_subject:oe("code_email_subject",u),supportInfo:oe("support_info",u),support_info:oe("support_info",u),contactUs:oe("contact_us",u),contact_us:oe("contact_us",u),copyright:oe("copyright",u)};await Nc(e,{to:t,templateName:"verify_email_by_code",legacyTemplate:"auth-code",fallbackSubject:oe("code_email_subject",u),fallbackHtml:`Click here to validate your email: ${Fn(e.env)}validate-email`,tenant:r,branding:{logo:c,primary_color:l},code:n,data:p})}else o==="sms"&&await j8(e,{to:t,text:oe("sms_code_text",u),code:n,from:r.friendly_name});B(e,r.id,{type:R.CODE_LINK_SENT,description:t})}async function hu(e,{to:t,code:n,authParams:i,language:r}){const o=await e.env.data.tenants.get(e.var.tenant_id);if(!o)throw new z(500,{message:"Tenant not found"});if(!i.redirect_uri)throw new z(400,{message:"redirect_uri is required"});const{connectionType:a}=go(t),c=await e.env.data.branding.get(e.var.tenant_id),l=c?.logo_url||"",d=c?.colors?.primary||"",u=new URL(ni(e.env));u.pathname="passwordless/verify_redirect",u.searchParams.set("verification_code",n),u.searchParams.set("connection",a),u.searchParams.set("client_id",i.client_id),u.searchParams.set("redirect_uri",i.redirect_uri),u.searchParams.set("email",t),i.response_type&&u.searchParams.set("response_type",i.response_type),i.scope&&u.searchParams.set("scope",i.scope),i.state&&u.searchParams.set("state",i.state),i.nonce&&u.searchParams.set("nonce",i.nonce),i.code_challenge&&u.searchParams.set("code_challenge",i.code_challenge),i.code_challenge_method&&u.searchParams.set("code_challenge_method",i.code_challenge_method),i.audience&&u.searchParams.set("audience",i.audience);const p={vendorName:o.friendly_name,code:n,lng:r||"en"};if(a==="email"){const f={code:n,vendorName:o.friendly_name,logo:l,supportUrl:o.support_url||"",magicLink:u.toString(),buttonColor:d,welcomeToYourAccount:oe("welcome_to_your_account",p),welcome_to_your_account:oe("welcome_to_your_account",p),linkEmailClickToLogin:oe("link_email_click_to_login",p),link_email_click_to_login:oe("link_email_click_to_login",p),linkEmailLogin:oe("link_email_login",p),link_email_login:oe("link_email_login",p),linkEmailOrEnterCode:oe("link_email_or_enter_code",p),link_email_or_enter_code:oe("link_email_or_enter_code",p),codeValid30Mins:oe("code_valid_30_minutes",p),code_valid_30_minutes:oe("code_valid_30_minutes",p),code_email_subject:oe("code_email_subject",p),supportInfo:oe("support_info",p),support_info:oe("support_info",p),contactUs:oe("contact_us",p),contact_us:oe("contact_us",p),copyright:oe("copyright",p)};await Nc(e,{to:t,templateName:"verify_email",legacyTemplate:"auth-link",fallbackSubject:oe("code_email_subject",p),fallbackHtml:`Click here to validate your email: ${u.toString()}`,tenant:o,branding:{logo:l,primary_color:d},url:u.toString(),code:n,data:f})}else if(a==="sms")await j8(e,{to:t,text:`${oe("link_sms_login",p)}: ${u.toString()}`,code:n,from:o.friendly_name});else throw new z(400,{message:"Only email and SMS connections are supported for magic links"});B(e,o.id,{type:R.CODE_LINK_SENT,description:t})}async function Dg(e,t,n){const i=await e.env.data.tenants.get(e.var.tenant_id);if(!i)throw new z(500,{message:"Tenant not found"});if(!t.email)throw new z(400,{message:"User has no email"});const r=await e.env.data.branding.get(e.var.tenant_id),o=r?.logo_url||"",a=r?.colors?.primary||"#7d68f4",c={vendorName:i.friendly_name,lng:n||"en"},l=`${Fn(e.env)}validate-email`,d={vendorName:i.friendly_name,logo:o,emailValidationUrl:l,supportUrl:i.support_url||"https://support.sesamy.com",buttonColor:a,welcomeToYourAccount:oe("welcome_to_your_account",c),welcome_to_your_account:oe("welcome_to_your_account",c),verifyEmailVerify:oe("verify_email_verify",c),verify_email_verify:oe("verify_email_verify",c),link_email_click_to_login:oe("verify_email_verify",c),link_email_login:oe("verify_email_verify",c),supportInfo:oe("support_info",c),support_info:oe("support_info",c),contactUs:oe("contact_us",c),contact_us:oe("contact_us",c),copyright:oe("copyright",c)};await Nc(e,{to:t.email,templateName:"verify_email",legacyTemplate:"auth-verify-email",fallbackSubject:oe("welcome_to_your_account",c),fallbackHtml:`Click here to validate your email: ${l}`,tenant:i,branding:{logo:o,primary_color:a},url:l,data:d})}async function hZ(e,t,n,i,r){const o=await e.env.data.tenants.get(e.var.tenant_id);if(!o)throw new z(500,{message:"Tenant not found"});const a=await e.env.data.branding.get(e.var.tenant_id),c=a?.logo_url||"",l=a?.colors?.primary||"#7d68f4",d={vendorName:o.friendly_name,lng:"en"},u=`${Fn(e.env)}signup?state=${i}&code=${n}`,p={vendorName:o.friendly_name,logo:c,signupUrl:u,setPassword:oe("set_password",d),registerPasswordAccount:oe("register_password_account",d),clickToSignUpDescription:oe("click_to_sign_up_description",d),supportUrl:o.support_url||"https://support.sesamy.com",buttonColor:l,welcomeToYourAccount:oe("welcome_to_your_account",d),welcome_to_your_account:oe("welcome_to_your_account",d),verifyEmailVerify:oe("verify_email_verify",d),verify_email_verify:oe("verify_email_verify",d),link_email_click_to_login:oe("click_to_sign_up_description",d),link_email_login:oe("set_password",d),supportInfo:oe("support_info",d),support_info:oe("support_info",d),contactUs:oe("contact_us",d),contact_us:oe("contact_us",d),copyright:oe("copyright",d)};await Nc(e,{to:t,templateName:"verify_email",legacyTemplate:"auth-pre-signup-verification",fallbackSubject:oe("register_password_account",d),fallbackHtml:`Click here to register: ${u}`,tenant:o,branding:{logo:c,primary_color:l},url:u,data:p})}const gZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["dbconnections"],method:"post",path:"/signup",request:{body:{content:{"application/json":{schema:s.z.object({client_id:s.z.string(),connection:s.z.literal(Z.USERNAME_PASSWORD),email:s.z.string().transform(e=>e.toLowerCase()),password:s.z.string()})}}}},responses:{200:{content:{"application/json":{schema:s.z.object({_id:s.z.string(),email:s.z.string().optional(),email_verified:s.z.boolean(),app_metadata:s.z.object({}),user_metadata:s.z.object({})})}},description:"Created user"}}}),async e=>{const{email:t,password:n,client_id:i}=e.req.valid("json"),r=await nt(e.env,i);e.set("client_id",r.client_id),on(e,r.tenant.id);const a=r.connections.find(h=>h.strategy===Z.USERNAME_PASSWORD)?.name||Z.USERNAME_PASSWORD,c=await Fd(e.env.data,r.tenant.id,a);try{await Od(c,{tenantId:r.tenant.id,userId:"",newPassword:n,data:e.env.data})}catch(h){throw new z(400,{message:h?.message||"Password does not meet the requirements"})}if(await hr({env:e.env,tenant_id:r.tenant.id,username:t}))throw new z(400,{message:"Invalid sign up"});const{hash:d,algorithm:u}=await Na(n),p=await fc(e.env,r.tenant.id),f=await e.env.data.users.create(r.tenant.id,{user_id:`${p}|${lo()}`,email:t,email_verified:!1,provider:p,connection:Z.USERNAME_PASSWORD,is_social:!1,password:{hash:d,algorithm:u}});e.set("user_id",f.user_id),e.set("username",f.email),e.set("connection",f.connection);try{await Dg(e,f)}catch(h){console.error("Failed to send verification email:",h)}return B(e,r.tenant.id,{type:R.SUCCESS_SIGNUP,description:"Successful signup"}),e.json({_id:f.user_id,email:f.email,email_verified:!1,app_metadata:{},user_metadata:{}})}).openapi(s.createRoute({tags:["dbconnections"],method:"post",path:"/change_password",request:{body:{content:{"application/json":{schema:s.z.object({client_id:s.z.string(),connection:s.z.literal(Z.USERNAME_PASSWORD),email:s.z.string().transform(e=>e.toLowerCase())})}}}},responses:{200:{description:"Redirect to the client's redirect uri"}}}),async e=>{const{email:t,client_id:n}=e.req.valid("json"),i=await nt(e.env,n);if(e.set("client_id",i.client_id),on(e,i.tenant.id),!await po({env:e.env,tenant_id:i.tenant.id,username:t}))return e.html("If an account with that email exists, we've sent instructions to reset your password.");const o={client_id:n,username:t,audience:i.tenant.default_audience},a=await e.env.data.loginSessions.create(i.tenant.id,{expires_at:new Date(Date.now()+no*1e3).toISOString(),authParams:o,csrf_token:Le(),ip:e.get("ip"),useragent:e.get("useragent"),auth0Client:Ri(e.get("auth0_client"))});return await F8(e,t,a.id,a.authParams.state),e.html("If an account with that email exists, we've sent instructions to reset your password.")});function Tn(){const e=new Uint8Array(6);crypto.getRandomValues(e);let t="";for(let n=0;n<6;n+=1)t+=(e[n]%10).toString();return t}const mZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["passwordless"],method:"post",path:"/start",request:{body:{content:{"application/json":{schema:s.z.union([s.z.object({connection:s.z.literal("email"),client_id:s.z.string(),email:s.z.string().transform(e=>e.toLowerCase()),send:s.z.enum(["link","code"]),authParams:Hl.omit({client_id:!0})}),s.z.object({client_id:s.z.string(),connection:s.z.literal("sms"),phone_number:s.z.string(),send:s.z.enum(["link","code"]),authParams:Hl.omit({client_id:!0})})])}}}},responses:{200:{description:"Status"}}}),async e=>{const t=e.req.valid("json"),{env:n}=e,{client_id:i,send:r,authParams:o,connection:a}=t,c=await nt(e.env,i);e.set("client_id",c.client_id),on(e,c.tenant.id);const l=a==="email"?t.email:t.phone_number,d=e.get("ip"),u=e.get("useragent"),p=e.get("auth0_client"),f=Ri(p),h=o.audience??c.tenant.default_audience,g=await n.data.loginSessions.create(c.tenant.id,{authParams:{...o,client_id:i,username:l,audience:h},expires_at:new Date(Date.now()+ka).toISOString(),csrf_token:Le(),ip:d,useragent:u,auth0Client:f}),m=await n.data.codes.create(c.tenant.id,{code_id:Tn(),code_type:"otp",login_id:g.id,expires_at:new Date(Date.now()+ka).toISOString(),redirect_uri:o.redirect_uri}),_=o?.ui_locales?.split(" ")?.map(w=>w.split("-")[0])[0];return r==="link"?await hu(e,{to:l,code:m.code_id,authParams:{...o,client_id:i,audience:h},language:_}):await fu(e,{to:l,code:m.code_id,language:_}),e.html("OK")}).openapi(s.createRoute({tags:["passwordless"],method:"get",path:"/verify_redirect",request:{query:s.z.object({scope:s.z.string(),response_type:s.z.nativeEnum(xn),redirect_uri:s.z.string(),state:s.z.string(),nonce:s.z.string().optional(),verification_code:s.z.string(),connection:s.z.string(),client_id:s.z.string(),email:s.z.string().transform(e=>e.toLowerCase()),audience:s.z.string().optional()})},responses:{302:{description:"Successful verification, redirecting to continue flow.",headers:s.z.object({Location:s.z.string().url()}).openapi({})},400:{description:"Bad Request (e.g., invalid client, invalid code, missing parameters).",content:{"application/json":{schema:s.z.object({error:s.z.string(),error_description:s.z.string().optional()})}}},500:{description:"Internal Server Error.",content:{"application/json":{schema:s.z.object({error:s.z.string(),error_description:s.z.string().optional()})}}}}}),async e=>{const{env:t}=e,{client_id:n,email:i,verification_code:r,redirect_uri:o,state:a,scope:c,audience:l,response_type:d,nonce:u}=e.req.valid("query"),p=await nt(t,n);e.set("client_id",p.client_id),on(e,p.tenant.id),e.set("connection","email");const f={client_id:n,redirect_uri:o,state:a,nonce:u,scope:c,audience:l,response_type:d};let h="Something went wrong. Please try again later.";try{const b=await uu(e,{client_id:n,username:i,otp:r,authParams:f,enforceIpCheck:!0});if(b instanceof Response)return b;if(b&&typeof b=="object"&&"access_token"in b)return e.json(b)}catch(b){const A=b;"message"in A&&typeof A.message=="string"&&(h=A.message)}const g=e.get("ip"),m=e.get("useragent"),_=e.get("auth0_client"),w=Ri(_),y=await t.data.loginSessions.create(p.tenant.id,{authParams:{...f,username:i,audience:f.audience??p.tenant.default_audience},expires_at:new Date(Date.now()+ka).toISOString(),csrf_token:Le(),ip:g,useragent:m,auth0Client:w});return e.redirect(`${Fn(e.env,e.var.custom_domain)}invalid-session?state=${y.id}&error=${encodeURIComponent(h)}`,302)});class Io extends z{_code;constructor(t,n){super(t,n),this._code=n?.code}get code(){return this._code}}async function yZ(e,t){const i=[];for(let r=0;;r++){const{connections:o}=await e.env.data.connections.list(t,{page:r,per_page:100,include_totals:!1});if(i.push(...o),o.length<100)break}return i}async function y3(e,t,n){return(await yZ(e,t)).find(r=>r.name===n)??null}function Mu(e){return typeof e=="string"?e:void 0}function _Z(e){const t=e.options&&typeof e.options=="object"?e.options.configuration:void 0;if(!t||typeof t!="object")return null;const n=t,i=Mu(n.token_endpoint),r=Mu(n.userinfo_endpoint),o=Mu(n.client_id),a=Mu(n.client_secret);return!i||!r||!o||!a?null:{tokenEndpoint:i,userinfoEndpoint:r,clientId:o,clientSecret:a}}async function _3(e){const{ctx:t,client:n,username:i,password:r,dbConnection:o,existingUser:a}=e;if(o.options?.import_mode!==!0)return null;const c=_Z(o);if(!c)return null;let l;try{l=await kV({tokenEndpoint:c.tokenEndpoint,clientId:c.clientId,clientSecret:c.clientSecret,realm:o.name,username:i,password:r})}catch(g){if(g instanceof kn)return console.warn(`Auth0 upstream ROPG failed for tenant=${n.tenant.id} realm=${o.name}: ${g.code} ${g.description??""}`),null;throw g}const d=t.env.data;let u=a;if(!u){let g;try{g=await L6(c.userinfoEndpoint,l.access_token)}catch(b){if(b instanceof kn)return console.warn(`Auth0 upstream userinfo failed for tenant=${n.tenant.id}: ${b.code} ${b.description??""}`),null;throw b}const m=i.includes("@"),_=typeof g.email=="string"?g.email:void 0,w=await fc(t.env,n.tenant.id),y=`${w}|${lo()}`;u=await d.users.create(n.tenant.id,{user_id:y,email:_??(m?i:void 0),username:m?void 0:i,name:typeof g.name=="string"?g.name:i,given_name:typeof g.given_name=="string"?g.given_name:void 0,family_name:typeof g.family_name=="string"?g.family_name:void 0,nickname:typeof g.nickname=="string"?g.nickname:void 0,picture:typeof g.picture=="string"?g.picture:void 0,email_verified:g.email_verified===!0,provider:w,connection:o.name,is_social:!1,last_ip:t.var.ip??"",last_login:new Date().toISOString(),profileData:JSON.stringify(g)})}const{hash:p,algorithm:f}=await Na(r),h=await d.passwords.get(n.tenant.id,u.user_id);return h&&await d.passwords.update(n.tenant.id,{id:h.id,user_id:u.user_id,password:h.password,algorithm:h.algorithm,is_current:!1}),await d.passwords.create(n.tenant.id,{user_id:u.user_id,password:p,algorithm:f,is_current:!0}),u}async function wZ(e,t,n){const i=n.app_metadata||{},r=i.failed_logins||[],o=Date.now(),a=[...r.filter(c=>o-c<1e3*60*5),o];i.failed_logins=a,await e.users.update(t,n.user_id,{app_metadata:i})}function bZ(e){return typeof e=="object"&&e!==null&&"allowed"in e&&typeof e.allowed=="boolean"}function vZ(e){const n=(e.app_metadata||{}).failed_logins||[],i=Date.now();return n.filter(r=>i-r<1e3*60*5)}async function R8(e,t,n,i,r=Z.USERNAME_PASSWORD){const{data:o}=e.env,{username:a}=n;if(e.set("username",a),!a)throw new V(400,{message:"Username is required"});const c=t.tenant.attack_protection?.suspicious_ip_throttling,l=e.var.ip,d=l?c?.allowlist?.includes(l):!1;if(o.rateLimit&&c?.enabled&&l&&!d){let _={allowed:!0};try{const w=await o.rateLimit.consume("pre-login",`${t.tenant.id}:${l}`);bZ(w)&&(_=w)}catch(w){console.error("Pre-login rate limit consume failed:",w)}if(!_.allowed)throw B(e,t.tenant.id,{type:R.FAILED_LOGIN,description:"Rate limit exceeded for pre-login"}),new Io(429,{message:"Too many requests",code:"TOO_MANY_REQUESTS"})}let u=await po({env:e.env,tenant_id:t.tenant.id,username:a});if(!u){const _=await y3(e,t.tenant.id,r);if(_?.options?.import_mode===!0){const w=await _3({ctx:e,client:t,username:a,password:n.password,dbConnection:_,existingUser:null});w&&(u=w)}if(!u)throw B(e,t.tenant.id,{type:R.FAILED_LOGIN_INCORRECT_PASSWORD,description:"Invalid user"}),new Io(403,{message:"User not found",code:"USER_NOT_FOUND"})}const p=u.linked_to?await o.users.get(t.tenant.id,u.linked_to):u;if(!p)throw new Io(403,{message:"User not found",code:"USER_NOT_FOUND"});if(e.set("connection",u.connection),e.set("user_id",p.user_id),vZ(p).length>=3)throw B(e,t.tenant.id,{type:R.FAILED_LOGIN,description:"Too many failed login attempts"}),new Io(403,{message:"Too many failed login attempts",code:"TOO_MANY_FAILED_LOGINS"});const h=await o.passwords.get(t.tenant.id,u.user_id);let g=h&&await dc.compare(n.password,h.password);if(!g){const _=await y3(e,t.tenant.id,u.connection);_?.options?.import_mode===!0&&await _3({ctx:e,client:t,username:a,password:n.password,dbConnection:_,existingUser:p})&&(g=!0)}if(!g)throw B(e,t.tenant.id,{type:R.FAILED_LOGIN_INCORRECT_PASSWORD,description:"Invalid password"}),wZ(o,t.tenant.id,p),new Io(403,{message:"Invalid password",code:"INVALID_PASSWORD"});if(!u.email_verified&&t.client_metadata?.email_validation==="enforced"){const _=i?.authParams?.ui_locales?.split(" ")?.map(w=>w.split("-")[0])[0];throw await Dg(e,u,_),B(e,t.tenant.id,{type:R.FAILED_LOGIN,description:"Email not verified"}),i&&await xq(e,t.tenant.id,i,"Email not verified"),new Io(403,{message:"Email not verified",code:"EMAIL_NOT_VERIFIED"})}const m=p.app_metadata||{};return m.failed_logins&&m.failed_logins.length>0&&(m.failed_logins=[],o.users.update(t.tenant.id,p.user_id,{app_metadata:m})),{client:t,authParams:n,user:p,loginSession:i}}async function gu(e,t,n,i,r,o=Z.USERNAME_PASSWORD){const a=await R8(e,t,n,i,o);return ot(e,{...a,ticketAuth:r,authConnection:e.get("connection")||Z.USERNAME_PASSWORD,authStrategy:{strategy:Z.USERNAME_PASSWORD,strategy_type:Gt.DATABASE}})}async function g1(e,t,n,i,r){await TI(e,{client:t,username:n,connection:Z.USERNAME_PASSWORD,ip:e.var.ip});let o=Tn(),a=await e.env.data.codes.get(t.tenant.id,o,"password_reset");for(;a;)o=Tn(),a=await e.env.data.codes.get(t.tenant.id,o,"password_reset");let c=i;if(!await e.env.data.loginSessions.get(t.tenant.id,i)){const u=e.get("ip"),p=e.get("useragent"),f=e.get("auth0_client"),h=Ri(f);c=(await e.env.data.loginSessions.create(t.tenant.id,{expires_at:new Date(Date.now()+D5).toISOString(),authParams:{client_id:t.client_id,username:n},csrf_token:Le(),ip:u,useragent:p,auth0Client:h})).id}const d=await e.env.data.codes.create(t.tenant.id,{code_id:o,code_type:"password_reset",login_id:c,expires_at:new Date(Date.now()+hM).toISOString()});r==="code"?await fZ(e,n,d.code_id):await F8(e,n,d.code_id,c)}const AZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["oauth"],method:"post",path:"/",request:{body:{content:{"application/json":{schema:s.z.union([s.z.object({credential_type:s.z.literal("http://auth0.com/oauth/grant-type/passwordless/otp"),otp:s.z.string(),client_id:s.z.string(),username:s.z.string().transform(e=>e.toLowerCase()),realm:s.z.enum([Z.EMAIL]),scope:s.z.string().optional()}),s.z.object({credential_type:s.z.literal("http://auth0.com/oauth/grant-type/password-realm"),client_id:s.z.string(),username:s.z.string().transform(e=>e.toLowerCase()),password:s.z.string(),realm:s.z.enum([Z.USERNAME_PASSWORD]),scope:s.z.string().optional()})])}}}},responses:{200:{description:"List of tenants"}}}),async e=>{const t=e.req.valid("json"),{client_id:n,username:i}=t;e.set("username",i);const r=await nt(e.env,n);e.set("client_id",n),on(e,r.tenant.id);const o=i.toLocaleLowerCase(),a=e.get("ip"),c=e.get("useragent"),l=e.get("auth0_client");let d;if("otp"in t)d=await uu(e,{client_id:n,username:o,otp:t.otp});else if("password"in t){const u=await e.env.data.loginSessions.create(r.tenant.id,{expires_at:new Date(Date.now()+no*1e3).toISOString(),authParams:{client_id:n,username:o,audience:r.tenant.default_audience},csrf_token:Le(),ip:a,useragent:c,auth0Client:Ri(l)});d=await gu(e,r,{username:o,password:t.password,client_id:n},u,!0,t.realm)}else throw new z(400,{message:"Code or password required"});return d});function D8(e,t){if(!e||t.length===0)return!1;const n=Qm(e)?.host??null;if(!n)return!1;for(const i of t){let r;if(i.startsWith("http://")||i.startsWith("https://")?r=Qm(i)?.host??null:r=Qm("https://"+i)?.host??null,n===r)return!0}return!1}function Qm(e){try{return new URL(e)}catch{return null}}function kZ(e,t){if(!e||t===void 0)return!1;const n=new Date(e.authenticated_at).getTime(),i=t*1e3;return Date.now()-n>i}async function SZ({ctx:e,session:t,client:n,authParams:i,connection:r,login_hint:o,screen_hint:a}){const c=new URL(e.req.url);e.var.custom_domain&&(c.hostname=e.var.custom_domain);const{ip:l,auth0_client:d,useragent:u}=e.var,p=Ri(d);kZ(t,i.max_age)&&(t=void 0);const f=i.prompt?.split(" ")??[];(f.includes("login")||f.includes("select_account"))&&(t=void 0);const h=await e.env.data.loginSessions.create(n.tenant.id,{expires_at:new Date(Date.now()+no*1e3).toISOString(),authParams:i,csrf_token:Le(),authorization_url:c.toString(),ip:l,useragent:u,auth0Client:p}),g=n.client_metadata?.universal_login_version==="2"?"/u2":"/u";if(t&&o&&a!=="login"){const m=await e.env.data.users.get(n.tenant.id,t.user_id);if(m?.email===o)return ot(e,{client:n,loginSession:h,authParams:i,user:m,existingSessionIdToLink:t.id})}if(r===Z.EMAIL&&o){const m=Tn();return await e.env.data.codes.create(n.tenant.id,{code_id:m,code_type:"otp",login_id:h.id,expires_at:new Date(Date.now()+no*1e3).toISOString(),redirect_uri:i.redirect_uri}),await hu(e,{code:m,to:o,authParams:i}),e.redirect(`${g}/login/email-otp-challenge?state=${h.id}`)}if(t&&a!=="login"){const m=await e.env.data.users.get(n.tenant.id,t.user_id);if(m)return ot(e,{client:n,loginSession:h,authParams:i,user:m,existingSessionIdToLink:t.id})}if(g==="/u2"){const m=await e.env.data.promptSettings.get(n.tenant.id),_=Wo.parse(m||{}),w=n.connections.some(y=>y.strategy===Z.USERNAME_PASSWORD);if(_.identifier_first===!1&&w)return e.redirect(`${g}/login?state=${h.id}`)}return e.redirect(`${g}/login/identifier?state=${h.id}`)}async function EZ(e,t,n){if(n===Z.USERNAME_PASSWORD)return fc(e.env,t);if(n===Z.EMAIL)return Z.EMAIL;throw new V(403,{message:"Invalid realm"})}async function xZ(e,t,n,i,r){const{env:o}=e;e.set("connection",r);const a=await o.data.codes.get(t,n,"ticket");if(!a||a.used_at)throw new V(403,{message:"Ticket not found"});const c=await o.data.loginSessions.get(t,a.login_id);if(!c||!c.authParams.username)throw new V(403,{message:"Session not found"});const l=await nt(o,c.authParams.client_id,t);e.set("client_id",c.authParams.client_id),await o.data.codes.used(t,n);const d=await EZ(e,t,r),p=l.connections.find(g=>g.name===r)?.strategy||(Xp(d)?Z.USERNAME_PASSWORD:Z.EMAIL),f=p===Z.USERNAME_PASSWORD?Gt.DATABASE:Gt.PASSWORDLESS;let h=r===Z.USERNAME_PASSWORD?await TI(e,{client:l,username:c.authParams.username,connection:r,ip:e.var.ip}):await jd(e,{username:c.authParams.username,provider:d,client:l,connection:r,isSocial:!1,ip:e.var.ip});return e.set("username",h.email||h.phone_number),e.set("user_id",h.user_id),ot(e,{authParams:{scope:c.authParams?.scope,...i},loginSession:c,user:h,client:l,authConnection:r,authStrategy:{strategy:p,strategy_type:f}})}function w3(e,t){return t===mt.QUERY?!1:t===mt.FRAGMENT?!0:e!==xn.CODE}async function CZ({ctx:e,client:t,session:n,redirect_uri:i,state:r,nonce:o,code_challenge_method:a,code_challenge:c,audience:l,scope:d,response_type:u,response_mode:p,organization:f,max_age:h}){const{env:g}=e,m=new URL(i),_=`${m.protocol}//${m.host}`,w=p===mt.WEB_MESSAGE;async function y(ne="Login required"){const ie=new Headers;if(n&&(B(e,t.tenant.id,{type:R.FAILED_SILENT_AUTH,description:ne}),$v(t.tenant.id,e.var.host).forEach(De=>{ie.append("set-cookie",De)})),w)return tw(e,_,JSON.stringify({error:"login_required",error_description:ne,state:r}),ie);const xe={error:"login_required",error_description:ne};if(r&&(xe.state=r),p===mt.FORM_POST)return Mf(i,xe,ie);const ft=new URL(i);if(w3(u,p))ft.hash=new URLSearchParams(xe).toString();else for(const[Os,De]of Object.entries(xe))ft.searchParams.set(Os,De);const zt={Location:ft.toString()},js=ie.get("set-cookie");return js&&(zt["set-cookie"]=js),new Response(null,{status:302,headers:zt})}const b=!n||n?.expires_at&&new Date(n.expires_at)<new Date||n?.idle_expires_at&&new Date(n.idle_expires_at)<new Date,A=n&&h!==void 0&&Date.now()-new Date(n.authenticated_at).getTime()>h*1e3;if(b||A)return y();const v=await g.data.users.get(t.tenant.id,n.user_id);if(!v)return console.error("User not found",n.user_id),y("User not found");const k=v.linked_to?await g.data.users.get(t.tenant.id,v.linked_to):v;if(!k)return console.error("Linked primary user not found",v.linked_to),y("User not found");e.set("user_id",k.user_id),e.set("username",k.email),e.set("connection",k.connection);let x;if(f&&(x=await g.data.organizations.get(t.tenant.id,f),!x))return y("Organization not found");const I=l;let $=d||"",N=[],T;if(I)try{const ne=await fd(e,{tenantId:t.tenant.id,clientId:t.client_id,audience:I,requestedScopes:d?.split(" ")||[],organizationId:x?.id,userId:k.user_id});$=ne.scopes.join(" "),N=ne.permissions,T=t.app_type==="spa"&&ne.token_lifetime_for_web?ne.token_lifetime_for_web:ne.token_lifetime}catch(ne){if(ne?.statusCode===403||ne?.status===403){const ie=ne?.body?.error_description||ne?.message||"Access denied";return y(ie)}throw ne}else if(x&&!(await g.data.userOrganizations.list(t.tenant.id,{q:`user_id:${k.user_id}`,per_page:1e3})).userOrganizations.some(xe=>xe.organization_id===x.id))return y("User is not a member of the specified organization");let P;n.login_session_id&&(P=(await g.data.loginSessions.get(t.tenant.id,n.login_session_id))?.auth_connection);const O=P||k.connection,j=await g.data.loginSessions.create(t.tenant.id,{csrf_token:Le(),authParams:{client_id:t.client_id,audience:l,scope:d,state:r,nonce:o,response_type:u,redirect_uri:i,organization:f,max_age:h},expires_at:new Date(Date.now()+300*1e3).toISOString(),session_id:n.id,...O?{auth_connection:O}:{},ip:e.var.ip,useragent:e.var.useragent}),F=h!==void 0?Math.floor(new Date(n.authenticated_at).getTime()/1e3):void 0,L={client:t,authParams:{client_id:t.client_id,audience:l,code_challenge_method:a,code_challenge:c,scope:$,state:r,nonce:o,response_type:u,redirect_uri:i,max_age:h},user:k,session_id:n.id,auth_time:F,permissions:N,organization:x,token_lifetime:T},M=u.split(" "),H=M.includes("code"),W=M.includes("id_token"),te=M.includes("token"),Q=H&&(W||te);let ee;if(u===xn.CODE)ee=await Gf(e,{user:k,client:t,authParams:L.authParams,login_id:j.id});else if(Q){const ne=await Gf(e,{user:k,client:t,authParams:L.authParams,login_id:j.id});ee={...await Qa(e,{...L,code:ne.code}),code:ne.code,state:ne.state}}else ee=await Qa(e,L);const K=t.tenant.idle_session_lifetime?new Date(Date.now()+t.tenant.idle_session_lifetime*60*60*1e3).toISOString():void 0;await g.data.sessions.update(t.tenant.id,n.id,{used_at:new Date().toISOString(),last_interaction_at:new Date().toISOString(),login_session_id:j.id,device:{...n.device,last_ip:e.var.ip||"",last_user_agent:e.var.useragent||""},idle_expires_at:K}),K&&await g.data.loginSessions.update(t.tenant.id,j.id,{expires_at:K}),B(e,t.tenant.id,{type:R.SUCCESS_SILENT_AUTH,description:"Successful silent authentication"});const ke=new Headers;if(Iv(t.tenant.id,n.id,e.var.host).forEach(ne=>{ke.append("set-cookie",ne)}),w)return tw(e,_,JSON.stringify({...ee,state:r}),ke);const se={},Ee=ee.code,We=ee.access_token,Je=ee.id_token;if(H&&typeof Ee=="string"&&(se.code=Ee),typeof We=="string"&&(te&&(se.access_token=We,typeof ee.token_type=="string"&&(se.token_type=ee.token_type),typeof ee.expires_in=="number"&&(se.expires_in=String(ee.expires_in))),W&&typeof Je=="string"&&(se.id_token=Je)),r&&(se.state=r),(te||W)&&d&&(se.scope=d),p===mt.FORM_POST)return Mf(i,se,ke);const Ze=new URL(i);if(w3(u,p))Ze.hash=new URLSearchParams(se).toString();else for(const[ne,ie]of Object.entries(se))Ze.searchParams.set(ne,ie);const Ue={Location:Ze.toString()},J=ke.get("set-cookie");return J&&(Ue["set-cookie"]=J),new Response(null,{status:302,headers:Ue})}const TZ=1024;function $Z(e,t){const n=e.split(":")[0]?.split(".")??[],i=t.split(":")[0]?.split(".")??[];if(n.length<2||i.length<2)return!1;const r=n.slice(-2).join("."),o=i.slice(-2).join(".");return r===o}async function IZ(e,t,n){return await e.env.data.customDomains.getByDomain(t)?!0:$Z(t,n)}async function zZ(e,t){const n=await e.env.data.loginSessions.get(e.var.tenant_id||"",t);if(!n)throw new V(403,{message:"State not found"});const i=n.authorization_url;if(i&&i.length<=TZ){let c=null;try{c=new URL(i)}catch{c=null}const l=e.var.host||"";if(c&&c.host&&c.host!==l&&await IZ(e,c.host,l)){const u=new URL("/authorize/resume",c.origin);return u.searchParams.set("state",t),new Response(null,{status:302,headers:{location:u.toString()}})}}const r=await nt(e.env,n.authParams.client_id);on(e,r.tenant.id),e.set("client_id",r.client_id);const o=n.state||ve.PENDING;if(o===ve.PENDING)throw new V(400,{error:"invalid_request",error_description:"Login session is not yet authenticated"});if(o===ve.COMPLETED)throw new V(409,{error:"invalid_request",error_description:"Login session has already been completed"});if(o===ve.FAILED)throw new V(400,{error:"access_denied",error_description:`Login session failed: ${n.failure_reason||"unknown reason"}`});if(o===ve.EXPIRED)throw new V(400,{error:"invalid_request",error_description:"Login session has expired"});if(!n.user_id)throw new V(500,{message:"Authenticated login session has no user_id"});const a=await e.env.data.users.get(r.tenant.id,n.user_id);if(!a)throw new V(500,{message:"Authenticated user not found"});return e.set("user_id",a.user_id),n.auth_connection&&e.set("connection",n.auth_connection),ot(e,{authParams:n.authParams,client:r,user:a,loginSession:n,authStrategy:n.auth_strategy,authConnection:n.auth_connection})}const PZ=new Set(["RS256","RS384","RS512","ES256","ES384","ES512"]),NZ=new Set(["HS256","HS384","HS512"]),jZ={HS256:"SHA-256",HS384:"SHA-384",HS512:"SHA-512"},OZ={name:"RSASSA-PKCS1-v1_5"},FZ={ES256:"SHA-256",ES384:"SHA-384",ES512:"SHA-512"};class jt extends Error{constructor(t,n){super(n),this.code=t,this.name="RequestObjectVerificationError"}code}function b3(e){const t=new TextDecoder().decode(Lt.decode(e,{strict:!1})),n=JSON.parse(t);if(typeof n!="object"||n===null)throw new jt("invalid_request_object","JOSE segment is not an object");return n}async function RZ(e,t,n){const i=e.split(".");if(i.length!==3)throw new jt("invalid_request_object","request object is not a 3-part JWS");const[r,o,a]=i;let c,l;try{c=b3(r),l=b3(o)}catch(p){throw p instanceof jt?p:new jt("invalid_request_object","failed to decode JOSE segments")}if(!c.alg)throw new jt("invalid_request_object","missing alg");if(c.alg==="none")throw new jt("unsupported_alg","unsigned request objects (alg=none) are not accepted");const d=new Uint8Array(new TextEncoder().encode(`${r}.${o}`)),u=new Uint8Array(Lt.decode(a,{strict:!1}));if(NZ.has(c.alg)){if(!t.client_secret)throw new jt("missing_keys","client has no client_secret for HMAC verification");const p=await crypto.subtle.importKey("raw",new Uint8Array(new TextEncoder().encode(t.client_secret)),{name:"HMAC",hash:jZ[c.alg]},!1,["verify"]);if(!await crypto.subtle.verify("HMAC",p,u,d))throw new jt("signature_invalid","HMAC signature did not verify")}else if(PZ.has(c.alg)){const p=c.alg,f=await e8(t,{fetch:n.fetch});if(f.length===0)throw new jt("missing_keys","client has no jwks/jwks_uri registered");const h=c.kid?f.filter(_=>_.kid===c.kid):f.filter(_=>v3(_,p));if(h.length===0)throw new jt("missing_keys",c.kid?`no JWK found with kid=${c.kid}`:`no JWK found for alg=${p}`);let g=!1,m=!1;for(const _ of h){if(!v3(_,p))continue;let w;try{const b=Ev(_,p);w=await crypto.subtle.importKey("jwk",_,b,!1,["verify"])}catch{continue}const y=_.kty==="EC"?{name:"ECDSA",hash:FZ[p]}:OZ;try{if(m=!0,await crypto.subtle.verify(y,w,u,d)){g=!0;break}}catch{continue}}if(!g)throw new jt(m?"signature_invalid":"missing_keys",m?`asymmetric signature did not verify (kid=${c.kid??"(none)"}, alg=${p})`:`no JWK compatible with alg=${p} (kid=${c.kid??"(none)"})`)}else throw new jt("unsupported_alg",`alg ${c.alg} is not supported`);return DZ(l,t,n),l}function v3(e,t){return!(e.alg&&e.alg!==t||t.startsWith("ES")&&e.kty!=="EC"||t.startsWith("RS")&&e.kty!=="RSA")}function DZ(e,t,n){const i=n.leewaySeconds??30,r=Math.floor((n.now?n.now():Date.now())/1e3);if(typeof e.exp!="number")throw new jt("claim_invalid","request object missing exp");if(e.exp+i<r)throw new jt("claim_invalid","request object is expired");if(typeof e.nbf=="number"&&e.nbf-i>r)throw new jt("claim_invalid","request object not yet valid");if(e.iss!==void 0&&e.iss!==t.client_id)throw new jt("claim_invalid",`iss mismatch: expected client_id ${t.client_id}, got ${String(e.iss)}`);if(e.aud!==void 0&&n.issuer){const o=e.aud;if(!(o===n.issuer||Array.isArray(o)&&o.some(c=>c===n.issuer)))throw new jt("claim_invalid",`aud claim does not match issuer ${n.issuer}`)}}const BZ=[Z.EMAIL,Z.SMS,Z.USERNAME_PASSWORD],A3=["code","id_token","token"];function LZ(e){const t=e.split(/\s+/).filter(Boolean);return t.length<=1?e:[...t].sort((n,i)=>A3.indexOf(n)-A3.indexOf(i)).join(" ")}const k3=s.z.object({client_id:s.z.string().optional(),vendor_id:s.z.string().optional(),redirect_uri:s.z.string().optional(),scope:s.z.string().optional(),state:s.z.string().optional(),prompt:s.z.string().optional(),response_mode:s.z.nativeEnum(mt).optional(),response_type:s.z.preprocess(e=>typeof e=="string"?LZ(e):e,s.z.nativeEnum(xn).optional()),audience:s.z.string().optional(),connection:s.z.string().optional(),nonce:s.z.string().optional(),max_age:s.z.string().optional(),acr_values:s.z.string().optional(),login_ticket:s.z.string().optional(),code_challenge_method:s.z.nativeEnum(bh).optional(),code_challenge:s.z.string().optional(),realm:s.z.string().optional(),auth0Client:s.z.string().optional(),organization:s.z.string().optional(),login_hint:s.z.string().optional(),screen_hint:s.z.string().optional(),ui_locales:s.z.string().optional(),claims:s.z.union([s.z.string(),s.z.record(s.z.any())]).optional()});function MZ(e){if(e==null)return;let t;if(typeof e=="string"){if(!e)return;try{t=JSON.parse(e)}catch{throw new z(400,{message:"invalid claims parameter: not valid JSON"})}}else t=e;const n=Zw.safeParse(t);if(!n.success)throw new z(400,{message:"invalid claims parameter: must be an object with optional `userinfo` and `id_token` members"});const i={};return n.data.userinfo&&Object.keys(n.data.userinfo).length>0&&(i.userinfo=n.data.userinfo),n.data.id_token&&Object.keys(n.data.id_token).length>0&&(i.id_token=n.data.id_token),i.userinfo||i.id_token?i:void 0}const UZ=new Set(["application/oauth-authz-req+jwt","application/jwt"]);async function qZ(e,t){const{status:n,body:i,contentType:r}=await X6(e,t);if(n!==200)throw new z(400,{message:`request_uri returned status ${n}`});const o=(r??"").split(";")[0]?.trim().toLowerCase()??"";if(!UZ.has(o))throw new z(400,{message:`request_uri returned unsupported content-type: ${o||"(missing)"}`});const a=i.trim();if(!a||a.split(".").length!==3)throw new z(400,{message:"request_uri did not return a JWT"});return a}const HZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["oauth"],method:"get",path:"/",request:{query:k3.extend({client_id:s.z.string(),screen_hint:s.z.string().openapi({example:"signup",description:'Optional hint for the screen to show, like "signup" or "login".'}).optional(),request:s.z.string().openapi({description:"JWT containing authorization request parameters (OpenID Connect Core Section 6.1). MUST be signed; alg=none is rejected."}).optional(),request_uri:s.z.string().url().openapi({description:"URL referencing a Request Object JWT (OpenID Connect Core Section 6.2). The URL is fetched with SSRF protection."}).optional()}).passthrough()},responses:{200:{description:"Successful authorization response. This can be an HTML page (e.g., for silent authentication iframe or universal login page) or a JSON object containing tokens (e.g., for response_mode=web_message).",content:{"text/html":{schema:s.z.string().openapi({example:"<html>...</html>"})},"application/json":{schema:db}}},302:{description:"Redirect to the client's redirect URI, an authentication page, or an external identity provider.",headers:s.z.object({Location:s.z.string().url()})},400:{description:"Bad Request. Invalid parameters or other client-side errors.",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}},403:{description:"Forbidden. The request is not allowed (e.g., invalid origin).",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}}}}),async e=>{const{env:t}=e,n=e.req.valid("query");if(n.request&&n.request_uri)throw new z(400,{message:"request and request_uri are mutually exclusive"});const i={allowPrivateHosts:t.ALLOW_PRIVATE_OUTBOUND_FETCH===!0,allowedSchemes:t.ALLOW_PRIVATE_OUTBOUND_FETCH?["http:","https:"]:["https:"]};let r=n.request;if(n.request_uri)try{r=await qZ(n.request_uri,i)}catch(Q){throw Q instanceof Fo?new z(400,{message:`request_uri rejected: ${Q.message}`}):Q}let o={},a;if(r){if(!n.client_id)throw new z(400,{message:"client_id is required to verify a request object"});a=await nt(t,n.client_id);try{const Q=await RZ(r,a,{issuer:Bn(t,e.var.custom_domain),fetch:i}),ee=k3.safeParse(Q);if(!ee.success)throw new z(400,{message:`invalid request object: ${ee.error.issues.map(K=>`${K.path.join(".")}: ${K.message}`).join("; ")}`});o=ee.data}catch(Q){throw Q instanceof jt?new z(400,{message:`invalid request object (${Q.code}): ${Q.message}`}):Q}}for(const Q of Object.keys(o)){const ee=o[Q],K=n[Q];if(ee!==void 0&&K!==void 0&&ee!==K)throw new z(400,{message:`request object and query parameter "${Q}" disagree`})}let{redirect_uri:c,scope:l,audience:d,nonce:u,response_type:p,response_mode:f,code_challenge:h,code_challenge_method:g,prompt:m,max_age:_,acr_values:w,login_hint:y,ui_locales:b,organization:A,claims:v}={...n,...o};const{client_id:k,vendor_id:x,state:I,connection:$,login_ticket:N,realm:T,screen_hint:P}={...n,...o};e.set("log","authorize");let O=MZ(v);const j=a&&a.client_id===k?a:await nt(t,k);if(e.set("client_id",j.client_id),on(e,j.tenant.id),I){const Q=await t.data.loginSessions.get(j.tenant.id,I);if(Q&&Q.state!==ve.COMPLETED&&Q.state!==ve.FAILED&&Q.state!==ve.EXPIRED){const ee=Q.authParams;c=c??ee.redirect_uri,l=l??ee.scope,d=d??ee.audience,u=u??ee.nonce,p=p??ee.response_type,f=f??ee.response_mode,h=h??ee.code_challenge,g=g??ee.code_challenge_method,m=m??ee.prompt,_=_??ee.max_age?.toString(),w=w??ee.acr_values,y=y??ee.username,b=b??ee.ui_locales,A=A??ee.organization,!O&&ee.claims&&(O=ee.claims)}}let F=c;typeof c=="string"&&(F=c.split("#")[0]);const L=e.req.header("origin");if(L&&!D8(L,j.web_origins||[]))throw new z(403,{message:`Origin ${L} not allowed`});if(!p){const Q=!!F&&nh(F,j.callbacks||[],{allowPathWildcards:!0,allowSubDomainWildcards:!0});if(F&&Q){const ee={error:"invalid_request",error_description:"Missing required parameter: response_type"};if(I&&(ee.state=I),f===mt.FORM_POST)return Mf(F,ee,new Headers);const K=new URL(F);for(const[ke,ge]of Object.entries(ee))K.searchParams.set(ke,ge);return e.redirect(K.toString())}throw new z(400,{message:"Missing required parameter: response_type"})}const M={redirect_uri:F,scope:l,state:I,client_id:k,vendor_id:x,audience:d??j.tenant.default_audience,nonce:u,prompt:m,response_type:p,response_mode:f,code_challenge:h,code_challenge_method:g,username:y,ui_locales:b,organization:A,max_age:_?parseInt(_,10):void 0,acr_values:w,claims:O};if(M.redirect_uri){const Q=j.callbacks||[];if(e.var.host&&(Q.push(`${Bn(e.env,e.var.custom_domain)}/*`),Q.push(`${Fn(e.env,e.var.custom_domain)}/*`)),!nh(M.redirect_uri,Q,{allowPathWildcards:!0,allowSubDomainWildcards:!0}))throw new z(400,{message:`Invalid redirect URI - ${M.redirect_uri}`})}let H;const W=mM(j.tenant.id,e.req.header("cookie"));for(const Q of W){const ee=await t.data.sessions.get(j.tenant.id,Q);if(ee&&!ee.revoked_at){H=ee;break}}if(j.sso_disabled&&(H=void 0),m=="none"){if(!F||!I||!p)throw new z(400,{message:"Missing required parameters for silent auth: redirect_uri, state, and response_type"});return CZ({ctx:e,session:H||void 0,redirect_uri:F,state:I,response_type:p,response_mode:f,client:j,nonce:u,code_challenge_method:g,code_challenge:h,audience:M.audience,scope:l,organization:A,max_age:_?parseInt(_,10):void 0})}if(j.connections.length===1&&j.connections[0]&&!BZ.includes(j.connections[0].strategy||""))return th(e,j,j.connections[0].name,M);if($&&$!==Z.EMAIL)return th(e,j,$,M);if(N){const Q=await xZ(e,j.tenant.id,N,M,T);return Q instanceof Response?Q:e.json(Q)}const te=await SZ({ctx:e,client:j,authParams:M,session:H||void 0,connection:$,login_hint:y,screen_hint:P});return te instanceof Response?te:e.json(te)}).openapi(s.createRoute({tags:["oauth"],method:"get",path:"/resume",request:{query:s.z.object({state:s.z.string()})},responses:{302:{description:"Redirect to the client's redirect_uri (with cookie set), to a MFA/continuation UL screen, or to the original authorization host when the browser is on the wrong custom domain.",headers:s.z.object({Location:s.z.string().url()})},400:{description:"Login session is in PENDING, FAILED, or EXPIRED state.",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}},403:{description:"Login session not found.",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}},409:{description:"Login session has already been completed (replay).",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}}}}),async e=>{const{state:t}=e.req.valid("query");return zZ(e,t)}),VZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["oauth"],method:"get",path:"/",request:{query:s.z.object({client_id:s.z.string(),redirect_url:s.z.string().optional(),login_hint:s.z.string().toLowerCase().optional(),screen_hint:s.z.enum(["account","change-email","change-phone","change-password"]).optional().default("account")})},responses:{302:{description:"Redirect to the account page with login session state or login page",headers:s.z.object({Location:s.z.string().url()})},400:{description:"Bad Request. Invalid parameters or other client-side errors.",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}}}}),async e=>{const{env:t}=e,{client_id:n,redirect_url:i,login_hint:r,screen_hint:o}=e.req.valid("query");e.set("log","account");const a=await nt(t,n);e.set("client_id",a.client_id),on(e,a.tenant.id);const c={redirect_uri:i||e.req.url,client_id:n,username:r},l=e.req.header("origin");if(l&&!D8(l,a.web_origins||[]))throw new z(403,{message:`Origin ${l} not allowed`});if(c.redirect_uri){const y=a.callbacks||[];if(e.var.host&&(y.push(`${Bn(e.env,e.var.custom_domain)}/*`),y.push(`${Fn(e.env,e.var.custom_domain)}/*`)),!nh(c.redirect_uri,y,{allowPathWildcards:!0,allowSubDomainWildcards:!0}))throw new z(400,{message:`Invalid redirect URI - ${c.redirect_uri}`})}const d=xr(a.tenant.id,e.req.header("cookie")),u=d?await t.data.sessions.get(a.tenant.id,d):void 0;let p=u&&!u.revoked_at?u:void 0;a.sso_disabled&&(p=void 0);const f=new URL(e.req.url);e.var.custom_domain&&(f.hostname=e.var.custom_domain);const{ip:h,auth0_client:g,useragent:m}=e.var,_=Ri(g),w=await t.data.loginSessions.create(a.tenant.id,{expires_at:new Date(Date.now()+no*1e3).toISOString(),authParams:c,csrf_token:Le(),authorization_url:f.toString(),ip:h,useragent:m,auth0Client:_});if(p){if(r&&(await t.data.users.get(a.tenant.id,p.user_id))?.email!==r)return e.redirect(`${Fn(e.env,e.var.custom_domain)}login/identifier?state=${encodeURIComponent(w.id)}`);if(await t.data.loginSessions.update(a.tenant.id,w.id,{session_id:p.id}),o==="change-email"){const b=new URL("/u2/account/profile",e.req.url);return b.searchParams.set("state",w.id),e.redirect(b.toString())}const y=new URL("/u2/account",e.req.url);return y.searchParams.set("state",w.id),e.redirect(y.toString())}return e.redirect(`${Fn(e.env,e.var.custom_domain)}login/identifier?state=${encodeURIComponent(w.id)}`)});function xw(e,t){if(e===t)return!0;if(e==null||t==null||typeof e!=typeof t)return!1;if(Array.isArray(e)&&Array.isArray(t)){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(!xw(e[n],t[n]))return!1;return!0}if(qp(e)&&qp(t)){const n=Object.keys(e),i=Object.keys(t);if(n.length!==i.length)return!1;for(const r of n)if(!xw(e[r],t[r]))return!1;return!0}return!1}function S3(e,t){const n={...t};if(!e)return{ok:!0,filled:n};for(const[i,r]of Object.entries(e)){const o=t[i];if(o===void 0){n[i]=r;continue}if(!xw(o,r))return{ok:!1,violation:{field:i,expected:r,got:o},filled:n}}return{ok:!0,filled:n}}const Zm=s.z.object({redirect_uris:s.z.array(s.z.string()).optional(),client_name:s.z.string().min(1).optional(),client_uri:s.z.string().url().optional(),logo_uri:s.z.string().url().optional(),tos_uri:s.z.string().url().optional(),policy_uri:s.z.string().url().optional(),contacts:s.z.array(s.z.string()).optional(),scope:s.z.string().optional(),grant_types:s.z.array(s.z.string()).optional(),response_types:s.z.array(s.z.string()).optional(),token_endpoint_auth_method:s.z.enum(["none","client_secret_basic","client_secret_post","client_secret_jwt","private_key_jwt"]).optional(),jwks_uri:s.z.string().url().optional(),jwks:s.z.record(s.z.unknown()).optional(),software_id:s.z.string().optional(),software_version:s.z.string().optional(),client_id:s.z.string().optional(),client_secret:s.z.string().optional(),audience:s.z.string().optional()}),Xm=s.z.object({client_id:s.z.string(),client_secret:s.z.string().optional(),client_id_issued_at:s.z.number().optional(),client_secret_expires_at:s.z.number().optional(),registration_access_token:s.z.string().optional(),registration_client_uri:s.z.string(),client_name:s.z.string().optional(),redirect_uris:s.z.array(s.z.string()).optional(),grant_types:s.z.array(s.z.string()).optional(),response_types:s.z.array(s.z.string()).optional(),token_endpoint_auth_method:s.z.string().optional(),logo_uri:s.z.string().optional(),client_uri:s.z.string().optional(),tos_uri:s.z.string().optional(),policy_uri:s.z.string().optional(),contacts:s.z.array(s.z.string()).optional(),scope:s.z.string().optional(),jwks_uri:s.z.string().optional(),software_id:s.z.string().optional(),software_version:s.z.string().optional()}),KZ=new Set(["redirect_uris","client_name","client_uri","logo_uri","tos_uri","policy_uri","contacts","scope","grant_types","response_types","token_endpoint_auth_method","jwks_uri","jwks","software_id","software_version","client_id","client_secret","domain","integration_type","audience"]);function GZ(e){const t=[];for(const n of["client_uri","tos_uri","policy_uri","jwks_uri","software_id","software_version"]){const i=e[n];typeof i=="string"&&i.length>0&&t.push([n,i])}return e.contacts&&Array.isArray(e.contacts)&&e.contacts.length>0&&t.push(["contacts",e.contacts.join(",")]),e.scope&&typeof e.scope=="string"&&t.push(["scope",e.scope]),t.length>0?Object.fromEntries(t):void 0}function E3(e){const t={};e.client_name!==void 0&&(t.name=e.client_name),e.redirect_uris!==void 0&&(t.callbacks=e.redirect_uris),e.grant_types!==void 0&&(t.grant_types=e.grant_types),e.token_endpoint_auth_method!==void 0&&(t.token_endpoint_auth_method=e.token_endpoint_auth_method),e.logo_uri!==void 0&&(t.logo_uri=e.logo_uri);const n=GZ(e);n&&(t.client_metadata=n);const i={};for(const[r,o]of Object.entries(e))KZ.has(r)||(i[r]=o);return e.jwks!==void 0&&(i.jwks=e.jwks),e.response_types!==void 0&&(i.response_types=e.response_types),{clientFields:t,extraMetadata:i}}function vo(e,t){const n=e[t];return n&&n.length>0?n:void 0}function e0(e,t){const n=e.client_metadata??{},i=n.contacts,r=i&&i.length>0?i.split(","):void 0,a=(e.registration_metadata??{}).response_types,c=Array.isArray(a)&&a.every(d=>typeof d=="string")?a:void 0;return{client_id:e.client_id,client_name:e.name,client_id_issued_at:Math.floor(new Date(e.created_at).getTime()/1e3),client_secret_expires_at:0,registration_client_uri:t.registration_client_uri,client_secret:t.include_client_secret&&t.client_secret?t.client_secret:void 0,registration_access_token:t.registration_access_token,redirect_uris:e.callbacks&&e.callbacks.length>0?e.callbacks:void 0,grant_types:e.grant_types&&e.grant_types.length>0?e.grant_types:void 0,response_types:c,token_endpoint_auth_method:e.token_endpoint_auth_method,logo_uri:e.logo_uri,client_uri:vo(n,"client_uri"),tos_uri:vo(n,"tos_uri"),policy_uri:vo(n,"policy_uri"),jwks_uri:vo(n,"jwks_uri"),software_id:vo(n,"software_id"),software_version:vo(n,"software_version"),scope:vo(n,"scope"),contacts:r}}function WZ(e){if(!e)return;const t=e.iat_constraints;return qp(t)?t:void 0}function x3(e){if(e)for(const t of e)try{const n=new URL(t);if(!n.protocol||!n.host)throw new V(400,{error:"invalid_redirect_uri",error_description:`Invalid redirect_uri: ${t}`})}catch{throw new V(400,{error:"invalid_redirect_uri",error_description:`Invalid redirect_uri: ${t}`})}}function C3(e,t){if(!(!e||!t||t.length===0)){for(const n of e)if(!t.includes(n))throw new V(400,{error:"invalid_client_metadata",error_description:`grant_type "${n}" is not allowed for this tenant`})}}async function JZ(e,t,n){if(!t){if(n)throw new V(400,{error:"invalid_client_metadata",error_description:"scope requires audience"});return null}const{resource_servers:i}=await e.env.data.resourceServers.list(e.var.tenant_id),r=i.find(a=>a.identifier===t);if(!r)throw new V(400,{error:"invalid_client_metadata",error_description:`Unknown audience: ${t}`});const o=n?n.split(/\s+/).filter(Boolean):[];if(o.length>0){const a=new Set((r.scopes??[]).map(l=>l.value)),c=o.filter(l=>!a.has(l));if(c.length>0)throw new V(400,{error:"invalid_scope",error_description:`Scope(s) not defined on the resource server: ${c.join(", ")}`})}return{audience:t,scopes:o}}const YZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["oidc-register"],method:"post",path:"/",request:{body:{content:{"application/json":{schema:Zm}}}},responses:{201:{content:{"application/json":{schema:Xm}},description:"Client registered"}}}),async e=>{const t=await Du(e);Bu(t);const n=await hH(e,t),i=e.req.valid("json"),r=S3(n?.constraints,i);if(!r.ok)throw new V(400,{error:"invalid_client_metadata",error_description:`Field "${r.violation?.field}" conflicts with Initial Access Token constraint`});const o=Zm.safeParse(r.filled);if(!o.success)throw new V(400,{error:"invalid_client_metadata",error_description:"Merged request (with IAT constraints applied) is not valid RFC 7591 metadata"});const a=o.data;if(a.grant_types?.some(y=>y==="authorization_code"||y==="implicit")&&(!a.redirect_uris||a.redirect_uris.length===0))throw new V(400,{error:"invalid_redirect_uri",error_description:"redirect_uris is required for authorization_code and implicit grant types"});x3(a.redirect_uris),C3(a.grant_types,t.flags?.dcr_allowed_grant_types);const c=await JZ(e,a.audience,a.scope),{clientFields:l,extraMetadata:d}=E3(a),u=gH(),p=mH(),f=await $6(),h={...d};delete h.iat_constraints,n?.constraints&&(h.iat_constraints=n.constraints);const g={client_id:u,name:l.name??`Client ${u.slice(0,8)}`,client_secret:p,callbacks:l.callbacks??[],grant_types:l.grant_types??["authorization_code"],token_endpoint_auth_method:l.token_endpoint_auth_method??"client_secret_basic",logo_uri:l.logo_uri,client_metadata:l.client_metadata,owner_user_id:n?.sub,registration_type:n?"iat_dcr":"open_dcr",registration_metadata:h};let m;if(await e.env.data.transaction(async y=>{const b=Xa(y);if(n&&!await b.markUsed(e.var.tenant_id,n.id,new Date().toISOString()))throw new V(401,{error:"invalid_token",error_description:"Initial access token already used"});m=await y.clients.create(e.var.tenant_id,g),c&&await y.clientGrants.create(e.var.tenant_id,{client_id:u,audience:c.audience,scope:c.scopes}),await b.create(e.var.tenant_id,{id:f.id,token_hash:f.token_hash,type:"rat",client_id:u,single_use:!1})}),!m)throw new V(500,{error:"server_error",error_description:"Failed to create client"});const _=Rm(e,u),w=e0(m,{client_secret:p,registration_access_token:f.token,registration_client_uri:_,include_client_secret:!0});return await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Dynamic Client Registration",targetType:"client",targetId:u}),e.json(w,{status:201})}).openapi(s.createRoute({tags:["oidc-register"],method:"get",path:"/{client_id}",request:{params:s.z.object({client_id:s.z.string()})},responses:{200:{content:{"application/json":{schema:Xm}},description:"Client configuration"}}}),async e=>{const t=await Du(e);Bu(t);const{client_id:n}=e.req.valid("param");await Dm(e,n);const i=await e.env.data.clients.get(e.var.tenant_id,n);if(!i||Bm(i))throw new V(401,{error:"invalid_token",error_description:"Client not found"});const r=e0(i,{registration_client_uri:Rm(e,n),include_client_secret:!1});return e.json(r)}).openapi(s.createRoute({tags:["oidc-register"],method:"put",path:"/{client_id}",request:{params:s.z.object({client_id:s.z.string()}),body:{content:{"application/json":{schema:Zm}}}},responses:{200:{content:{"application/json":{schema:Xm}},description:"Updated client configuration"}}}),async e=>{const t=await Du(e);Bu(t);const{client_id:n}=e.req.valid("param");await Dm(e,n);const i=await e.env.data.clients.get(e.var.tenant_id,n);if(!i||Bm(i))throw new V(401,{error:"invalid_token",error_description:"Client not found"});const r=e.req.valid("json");if(r.client_id!==void 0&&r.client_id!==n)throw new V(400,{error:"invalid_client_metadata",error_description:"client_id in body does not match URL"});const o=WZ(i.registration_metadata);if(o){const h=S3(o,r);if(!h.ok)throw new V(400,{error:"invalid_client_metadata",error_description:`Field "${h.violation?.field}" was bound at registration time and cannot be changed`})}x3(r.redirect_uris),C3(r.grant_types,t.flags?.dcr_allowed_grant_types);const{clientFields:a,extraMetadata:c}=E3(r),l={...c};o&&(l.iat_constraints=o);const d={name:a.name??`Client ${n.slice(0,8)}`,callbacks:a.callbacks??[],grant_types:a.grant_types??["authorization_code"],token_endpoint_auth_method:a.token_endpoint_auth_method??"client_secret_basic",logo_uri:a.logo_uri,client_metadata:a.client_metadata??{},registration_metadata:l};if(!await e.env.data.clients.update(e.var.tenant_id,n,d))throw new V(500,{error:"server_error",error_description:"Failed to update client"});const p=await e.env.data.clients.get(e.var.tenant_id,n);if(!p)throw new V(500,{error:"server_error",error_description:"Failed to read back updated client"});await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"RFC 7592 Client Update",targetType:"client",targetId:n});const f=e0(p,{registration_client_uri:Rm(e,n),include_client_secret:!1});return e.json(f)}).openapi(s.createRoute({tags:["oidc-register"],method:"delete",path:"/{client_id}",request:{params:s.z.object({client_id:s.z.string()})},responses:{204:{description:"Client deleted"}}}),async e=>{const t=await Du(e);Bu(t);const{client_id:n}=e.req.valid("param");await Dm(e,n);const i=await e.env.data.clients.get(e.var.tenant_id,n);if(!i||Bm(i))throw new V(401,{error:"invalid_token",error_description:"Client not found"});const r={...i.client_metadata??{},status:"deleted"},o=await e.env.data.clientGrants.list(e.var.tenant_id,{q:`client_id:"${n}"`});return await e.env.data.transaction(async a=>{await a.clients.update(e.var.tenant_id,n,{client_metadata:r});for(const c of o.client_grants)c.id&&await a.clientGrants.remove(e.var.tenant_id,c.id);await Xa(a).revokeByClient(e.var.tenant_id,n,new Date().toISOString())}),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"RFC 7592 Client Delete",targetType:"client",targetId:n}),e.body(null,204)}),QZ=new Set(["localhost","127.0.0.1","[::1]"]);function T3(e,t=[]){let n;try{n=new URL(e)}catch{return{ok:!1,reason:"not a valid URL"}}if(n.protocol!=="http:"&&n.protocol!=="https:")return{ok:!1,reason:"scheme must be http or https"};const i=n.hostname.replace(/\.$/,"");if(!i)return{ok:!1,reason:"missing host"};if(i==="0.0.0.0"||i==="[::]")return{ok:!1,reason:"unspecified address is not a valid origin"};const r=n.port?`:${n.port}`:"",o=`${n.protocol}//${i}${r}`;return n.protocol==="https:"?{ok:!0,origin:o,isLoopback:!1,isAllowlisted:!1,isHttp:!1}:QZ.has(i)?{ok:!0,origin:o,isLoopback:!0,isAllowlisted:!1,isHttp:!0}:t.map(c=>c.toLowerCase()).includes(o)?{ok:!0,origin:o,isLoopback:!1,isAllowlisted:!0,isHttp:!0}:{ok:!1,reason:"http origin requires loopback or tenant allowlist"}}const ZZ=1800,XZ=s.z.object({integration_type:s.z.string().min(1).optional().openapi({description:"Optional caller-defined integration label. Surfaced on the consent screen and stored on the resulting client's IAT constraints. No validation beyond non-empty string."}),domain:s.z.string().min(1).openapi({description:"The domain that will host the integration (origin must match return_to)"}),return_to:s.z.string().url().openapi({description:"Where the browser is redirected after consent (success or cancel)"}),state:s.z.string().min(1).openapi({description:"Caller-supplied CSRF token round-tripped on the redirect"}),scope:s.z.string().optional().openapi({description:"Optional space-separated scope list pre-bound to the IAT"}),audience:s.z.string().optional().openapi({description:"Optional API identifier the registered client should be granted access to. When set, the resulting client receives a `client_grants` row binding (client_id, audience, scope[]) so it can mint access tokens for that API via client_credentials."})}),eX=new s.OpenAPIHono().openapi(s.createRoute({tags:["connect"],method:"get",path:"/",request:{query:XZ},responses:{302:{description:"Redirect to /u2/connect/start with a fresh login_session id",headers:s.z.object({Location:s.z.string()})},400:{description:"Invalid request",content:{"application/json":{schema:s.z.object({})}}},404:{description:"DCR / consent flow not enabled for this tenant",content:{"application/json":{schema:s.z.object({})}}}}}),async e=>{const t=e.var.tenant_id,n=await e.env.data.tenants.get(t);if(!n)throw new V(404,{error:"invalid_request",error_description:"Tenant not found"});if(!n.flags?.enable_dynamic_client_registration)throw new V(404,{error:"invalid_request",error_description:"Dynamic Client Registration is not enabled"});const{integration_type:i,domain:r,return_to:o,state:a,scope:c,audience:l}=e.req.valid("query");if(l){const{resource_servers:_}=await e.env.data.resourceServers.list(t),w=_.find(y=>y.identifier===l);if(!w)throw new V(400,{error:"invalid_request",error_description:`Unknown audience: ${l}`});if(c){const y=new Set((w.scopes??[]).map(v=>v.value)),A=c.split(/\s+/).filter(Boolean).filter(v=>!y.has(v));if(A.length>0)throw new V(400,{error:"invalid_scope",error_description:`Scope(s) not defined on the resource server: ${A.join(", ")}`})}}else if(c)throw new V(400,{error:"invalid_request",error_description:"scope requires audience"});const d=n.flags?.allow_http_return_to??[],u=/^https?:\/\//i.test(r)?r:`https://${r}`,p=T3(u,d);if(!p.ok)throw new V(400,{error:"invalid_request",error_description:`domain: ${p.reason}`});const f=T3(o,d);if(!f.ok)throw new V(400,{error:"invalid_request",error_description:`return_to: ${f.reason}`});if(f.origin!==p.origin)throw new V(400,{error:"invalid_request",error_description:"return_to origin must match domain"});let h=n.default_client_id?await e.env.data.clients.get(t,n.default_client_id):null;if(!h){const{clients:_}=await e.env.data.clients.list(t);h=_[0]??null}if(!h)throw new V(400,{error:"invalid_request",error_description:"No clients configured for this tenant"});const g=new Date(Date.now()+ZZ*1e3).toISOString(),m=await e.env.data.loginSessions.create(t,{expires_at:g,authParams:{client_id:h.client_id,state:a},csrf_token:Le(),ip:e.var.ip,useragent:e.var.useragent,state_data:JSON.stringify({connect:{integration_type:i,domain:r,return_to:o,scope:c,audience:l,caller_state:a,is_local_dev:f.isLoopback||f.isAllowlisted}})});return e.redirect(`/u2/connect/start?state=${encodeURIComponent(m.id)}`,302)});function tX(e){const t=new s.OpenAPIHono;t.use(xc(e)),t.use(du({getOutbox:()=>e.dataAdapter.outbox,getDestinations:r=>[new xs(e.dataAdapter.logs),new Ic(e.dataAdapter.hooks,k6({tenants:r.env.data.tenants,keys:r.env.data.keys,issuer:Bn(r.env,r.var.custom_domain)}),{webhookInvoker:r.env.webhookInvoker}),new zc(e.dataAdapter.users)]})),t.use(async(r,o)=>{const a=au(r,e.dataAdapter),c=e.dataAdapter.cache||$c({defaultTtlSeconds:0,maxEntries:100,cleanupIntervalMs:0}),l=e.dataAdapter.cache?300:0,d=lu(a,{defaultTtl:l,cacheEntities:["tenants","connections","clientConnections","customDomains","clients","branding","themes","promptSettings","forms","resourceServers","roles","organizations","userRoles","userPermissions","hooks","keys"],cache:c});return r.env.data=cu(r,d),o()});const n=F6({origin:r=>r||"",allowHeaders:["Tenant-Id","Content-Type","Auth0-Client","Upgrade-Insecure-Requests"],allowMethods:["POST"],maxAge:600});t.use("/oauth/token",n),t.use("/oauth/revoke",n),t.use(Tc).use(Cc).use(Ag(t));const i=t.route("/v2/logout",cV).route("/oidc/logout",uV).route("/userinfo",gV).route("/.well-known",mV).route("/oauth/token",uW).route("/oauth/revoke",pW).route("/dbconnections",gZ).route("/passwordless",mZ).route("/co/authenticate",AZ).route("/authorize",HZ).route("/account",VZ).route("/oidc/register",YZ).route("/connect/start",eX).route("/callback",oV).route("/login/callback",sV);return i.doc("/spec",{openapi:"3.0.0",info:{version:"1.0.0",title:"Oauth API"},security:[{oauth2:["openid","email","profile"]}]}),Sv(i),i}async function Ge(e,t,n=!1){const{env:i}=e,r=await i.data.loginSessions.get(e.var.tenant_id||"",t);if(!r)throw new z(400,{message:"Login session not found"});e.set("loginSession",r);const o=await nt(i,r.authParams.client_id);e.set("client_id",o.client_id),on(e,o.tenant.id);const a=o.tenant;if(r.session_id&&!n){if(!r.authParams.redirect_uri)throw new z(400,{message:"Login session closed and no redirect URI available"});const f=new URL(r.authParams.redirect_uri);throw f.searchParams.set("error","access_denied"),f.searchParams.set("error_description","Login session closed"),r.authParams.state&&f.searchParams.set("state",r.authParams.state),new Bt(f.toString(),302)}const[c,l]=await Promise.all([i.data.themes.get(a.id,"default"),i.data.branding.get(a.id)]),d=c??Kl,u=l?{...l,favicon_url:e.var.custom_domain?l.favicon_url:void 0}:null,p=r.authParams?.ui_locales?.split(" ")?.map(f=>f.split("-")[0])?.find(f=>{if(Array.isArray(U.options.supportedLngs))return U.options.supportedLngs.includes(f)});return await U.changeLanguage(p||"en"),{theme:d,branding:u,client:o,tenant:a,loginSession:r}}async function ys(e,t,n){const{theme:i,branding:r,client:o,tenant:a,loginSession:c}=await Ge(e,t,!0),l=xr(o.tenant.id,e.req.header("cookie")),d=l?await e.env.data.sessions.get(o.tenant.id,l):null;if(n?.continuationScope&&Qf(c,n.continuationScope)){if(!c.user_id)throw new Bt(`/u/login/identifier?state=${encodeURIComponent(t)}`);const h=await e.env.data.users.get(o.tenant.id,c.user_id);if(!h)throw new Bt(`/u/login/identifier?state=${encodeURIComponent(t)}`);const g=c.session_id?await e.env.data.sessions.get(o.tenant.id,c.session_id):null;return{theme:i,branding:r,client:o,user:h,tenant:a,loginSession:c,session:g,isContinuation:!0}}if(!d||d.revoked_at||!c.session_id)throw new Bt(`/u/login/identifier?state=${encodeURIComponent(t)}`);const p=await e.env.data.sessions.get(o.tenant.id,c.session_id),f=await e.env.data.users.get(o.tenant.id,d.user_id);if(!f||p?.user_id!==d.user_id)throw new Bt(`/u/login/identifier?state=${encodeURIComponent(t)}`);return{theme:i,branding:r,client:o,user:f,tenant:a,loginSession:c,session:p,isContinuation:!1}}const t0={[Z.USERNAME_PASSWORD]:"password",[Z.EMAIL]:"email",[Z.SMS]:"sms"};async function B8(e,t,n,i,r){if(i==="username"||r==="password")return"password";if(r==="code")return i==="sms"?"sms":"email";const a=(i==="email"?await uo({userAdapter:e.env.data.users,tenant_id:t.tenant.id,email:n}):i==="sms"?await fr({userAdapter:e.env.data.users,tenant_id:t.tenant.id,username:n,provider:"sms"}):await hr({env:e.env,tenant_id:t.tenant.id,username:n}))?.app_metadata?.strategy;if(a&&t0[a])return t0[a];const c=t.connections.map(d=>t0[d.strategy]).filter(d=>d!==void 0);return c.length===1&&c[0]?c[0]:(await e.env.data.promptSettings.get(t.tenant.id)).password_first&&c.includes("password")?"password":i==="sms"?"sms":"email"}const m1=({theme:e,branding:t})=>{const n=e?.widget?.logo_url||t?.logo_url;return n?S("div",{className:"inline-flex h-9 items-center",children:S("img",{src:n,className:"h-full w-auto",alt:"Logo"})}):S(Pa,{})},L8=e=>S("div",{className:"mt-8",children:e.client?.client_metadata?.termsAndConditionsUrl&&S("div",{className:"text-xs text-gray-300",children:[U.t("agree_to")," ",S("a",{href:e.client.client_metadata.termsAndConditionsUrl,className:"text-primary hover:underline",target:"_blank",rel:"noreferrer",children:U.t("terms")})]})});var n0={exports:{}};var $3;function nX(){return $3||($3=1,(function(e){(function(){var t={}.hasOwnProperty;function n(){for(var o="",a=0;a<arguments.length;a++){var c=arguments[a];c&&(o=r(o,i(c)))}return o}function i(o){if(typeof o=="string"||typeof o=="number")return o;if(typeof o!="object")return"";if(Array.isArray(o))return n.apply(null,o);if(o.toString!==Object.prototype.toString&&!o.toString.toString().includes("[native code]"))return o.toString();var a="";for(var c in o)t.call(o,c)&&o[c]&&(a=r(a,c));return a}function r(o,a){return a?o?o+" "+a:o+a:o}e.exports?(n.default=n,e.exports=n):window.classNames=n})()})(n0)),n0.exports}var iX=nX();const ct=$b(iX),rX=e=>e==="small"?"text-base":e==="medium"?"text-2xl":e==="large"?"text-3xl":"",wt=({name:e,size:t,className:n=""})=>{const i=rX(t);return S("span",{className:ct(`uicon-${e}`,n,i)})};function M8(e){const t=e.replace("#",""),n=parseInt(t,16);return[n>>16&255,n>>8&255,n&255]}function oX(e,t,n){return`#${(e<<16|t<<8|n).toString(16).padStart(6,"0")}`}const sX=(e,t)=>{const[n,i,r]=M8(e);return oX(Math.min(255,Math.round(n+(255-n)*t)),Math.min(255,Math.round(i+(255-i)*t)),Math.min(255,Math.round(r+(255-r)*t)))};function I3(e){const[t,n,i]=M8(e).map(r=>{const o=r/255;return o<=.04045?o/12.92:Math.pow((o+.055)/1.055,2.4)});return .2126*t+.7152*n+.0722*i}function z3(e,t){const n=I3(e),i=I3(t),r=Math.max(n,i),o=Math.min(n,i);return(r+.05)/(o+.05)}function P3(e,t="light"){const n=z3(e,"#ffffff"),i=z3(e,"#000000"),r=1.35;return t==="light"?i>n*r?"#000000":"#ffffff":i*r>n?"#000000":"#ffffff"}const aX=(e,t)=>{const n=e?.colors?.primary_button||t?.colors?.primary||"#000000",i=e?.colors?.base_hover_color||sX(n,.2),r=e?.colors?.primary_button_label,o=r||P3(n,"light"),a=r||P3(n,"dark"),c=o!==a?`
370
+ `," ",n],r=new Set(i);for(;this.p<this.N&&!r.has(this.peek());)yield this.match(n)?this.readOutputToken(t):this.readHTMLToken(i)}match(t){for(let n=0;n<t.length;n++)if(t[n]!==this.input[this.p+n])return!1;return!0}rmatch(t){for(let n=0;n<t.length;n++)if(t[t.length-1-n]!==this.input[this.p-1-n])return!1;return!0}peekType(t=0){return this.p+t>=this.N?0:tt[this.input.charCodeAt(this.p+t)]}peek(t=0){return this.p+t>=this.N?"":this.input[this.p+t]}skipBlank(){for(;this.peekType()&tc;)++this.p}};class qJ{constructor(t,n){this.handlers={},this.stopRequested=!1,this.tokens=t,this.parseToken=n}on(t,n){return this.handlers[t]=n,this}trigger(t,n){const i=this.handlers[t];return i?(i.call(this,n),!0):!1}start(){this.trigger("start");let t;for(;!this.stopRequested&&(t=this.tokens.shift());){if(this.trigger("token",t)||$s(t)&&this.trigger(`tag:${t.name}`,t))continue;const n=this.parseToken(t,this.tokens);this.trigger("template",n)}return this.stopRequested||this.trigger("end"),this}stop(){return this.stopRequested=!0,this}}class a1{constructor(t){this.token=t}}class pt extends a1{constructor(t,n,i){super(t),this.name=t.name,this.liquid=i,this.tokenizer=t.tokenizer}}class Pc{constructor(t,n){this.hash={};const i=t instanceof Di?t:new Di(t,{});for(const r of i.readHashes(n))this.hash[r.name.content]=r.value}*render(t){const n={};for(const i of Object.keys(this.hash))n[i]=this.hash[i]===void 0?!0:yield Et(this.hash[i],t);return n}}function HJ(e){return class extends pt{constructor(t,n,i){super(t,n,i),Tt(e.parse)&&e.parse.call(this,t,n)}*render(t,n){const i=yield new Pc(this.token.args,t.opts.keyValueSeparator).render(t);return yield e.render.call(this,t,n,i)}}}function _8(e){return Ut(e)}class w8{constructor(t,n,i){this.token=t,this.name=t.name,this.handler=Tt(n)?n:Tt(n?.handler)?n.handler:s8,this.raw=!Tt(n)&&!!n?.raw,this.args=t.args,this.liquid=i}*render(t,n){const i=[];for(const r of this.args)_8(r)?i.push([r[0],yield Et(r[1],n)]):i.push(yield Et(r,n));return yield this.handler.apply({context:n,token:this.token,liquid:this.liquid},[t,...i])}}class Cn{constructor(t,n){this.filters=[];const i=typeof t=="string"?new Di(t,n.options.operators).readFilteredValue():t;this.initial=i.initial,this.filters=i.filters.map(r=>new w8(r,this.getFilter(n,r.name),n))}*value(t,n){n=n||t.opts.lenientIf&&this.filters.length>0&&this.filters[0].name==="default";let i=yield this.initial.evaluate(t,n);for(const r of this.filters)i=yield r.render(i,t);return i}getFilter(t,n){const i=t.filters[n];return Jt(i||!t.options.strictFilters,()=>`undefined filter: ${n}`),i}}class VJ extends a1{constructor(t,n){var i;super(t);const r=new Di(t.input,n.options.operators,t.file,t.contentRange);this.value=new Cn(r.readFilteredValue(),n);const o=this.value.filters,a=n.options.outputEscape;if(!(!((i=o[o.length-1])===null||i===void 0)&&i.raw)&&a){const c=new g8(toString.call(a),[],"",0,0);o.push(new w8(c,a,n))}}*render(t,n){const i=yield this.value.value(t,!1);n.write(i)}*arguments(){yield this.value}}class KJ extends a1{constructor(t){super(t),this.str=t.getContent()}*render(t,n){n.write(this.str)}}class ms{constructor(t,n){this.segments=t,this.location=n}toString(){return lh(this.segments,!0)}toArray(){function*t(...n){for(const i of n)i instanceof ms?yield Array.from(t(...i.segments)):yield i}return Array.from(t(...this.segments))}}class Jm{constructor(){this.map=new Map}get(t){const n=lh([t.segments[0]]);return this.map.has(n)||this.map.set(n,[]),this.map.get(n)}has(t){return this.map.has(lh([t.segments[0]]))}push(t){this.get(t).push(t)}asObject(){return Object.fromEntries(this.map)}}const b8={partials:!0};function*v8(e,t,n){const i=new Jm,r=new Jm,o=new Jm,a=new a3(new Set),c=new Set;function l(u,p){i.push(u);const f=p.alias(u);if(f!==void 0){const h=f.segments[0];Pe(h)&&!a.has(h)&&r.push(f)}else{const h=u.segments[0];Pe(h)&&!p.has(h)&&r.push(u)}for(const h of u.segments)h instanceof ms&&l(h,p)}function*d(u,p){if(u.arguments)for(const f of u.arguments())for(const h of c3(f))l(h,p);if(u.localScope)for(const f of u.localScope()){p.add(f.content),p.deleteAlias(f.content);const[h,g]=f.getPosition();o.push(new ms([f.content],{row:h,col:g,file:f.file}))}if(u.children)if(u.partialScope){const f=u.partialScope();if(f===void 0){for(const m of yield u.children(t,n))yield d(m,p);return}if(c.has(f.name))return;const h=new Set,g=f.isolated?new a3(h):p.push(h);for(const m of f.scope)if(Pe(m))h.add(m);else{const[_,w]=m;h.add(_);const y=Array.from(c3(w));y.length&&g.setAlias(_,y[0].segments)}for(const m of yield u.children(t,n))yield d(m,g),c.add(f.name);g.pop()}else{u.blockScope&&p.push(new Set(u.blockScope()));for(const f of yield u.children(t,n))yield d(f,p);u.blockScope&&p.pop()}}for(const u of e)yield d(u,a);return{variables:i.asObject(),globals:r.asObject(),locals:o.asObject()}}function Ir(e,t={}){const n=Object.assign(Object.assign({},b8),t);return sr(v8(e,n.partials,!1))}function zr(e,t={}){const n=Object.assign(Object.assign({},b8),t);return ar(v8(e,n.partials,!0))}class a3{constructor(t){this.stack=[{names:t,aliases:new Map}]}has(t){for(const n of this.stack)if(n.names.has(t))return!0;return!1}push(t){return this.stack.push({names:t,aliases:new Map}),this}pop(){var t;return(t=this.stack.pop())===null||t===void 0?void 0:t.names}add(t){this.stack[0].names.add(t)}alias(t){const n=t.segments[0];if(!Pe(n))return;const i=this.getAlias(n);if(i!==void 0)return new ms([...i,...t.segments.slice(1)],t.location)}setAlias(t,n){this.stack[this.stack.length-1].aliases.set(t,n)}deleteAlias(t){this.stack[this.stack.length-1].aliases.delete(t)}getAlias(t){for(const n of this.stack){if(n.aliases.has(t))return n.aliases.get(t);if(n.names.has(t))return}}}function*c3(e){Sn(e)?yield*Ca(e):e instanceof Cn&&(yield*GJ(e))}function*GJ(e){for(const t of e.initial.postfix)Sn(t)&&(yield*Ca(t));for(const t of e.filters)for(const n of t.args)_8(n)&&n[1]?yield*Ca(n[1]):Sn(n)&&(yield*Ca(n))}function*Ca(e){k8(e)?(yield*Ca(e.lhs),yield*Ca(e.rhs)):dh(e)&&(yield Sw(e))}function Sw(e){const t=[];let n=e.file;const i=e.props[0];n=n||i.file,Ew(i)||d3(i)||u3(i)?t.push(i.content):dh(i)&&t.push(...Sw(i).segments);for(const a of e.props.slice(1))n=n||a.file,Ew(a)||d3(a)||u3(a)?t.push(a.content):dh(a)&&t.push(Sw(a));const[r,o]=e.getPosition();return new ms(t,{row:r,col:o,file:n})}const l3=/^[\u0080-\uFFFFa-zA-Z_][\u0080-\uFFFFa-zA-Z0-9_-]*$/;function lh(e,t=!1){const n=[],i=e[0];Pe(i)&&(!t||i.match(l3)?n.push(`${i}`):n.push(`['${i}']`));for(const r of e.slice(1))r instanceof ms?n.push(`[${lh(r.segments)}]`):Pe(r)?r.match(l3)?n.push(`.${r}`):n.push(`['${r}']`):n.push(`[${r}]`);return n.join("")}var ic;(function(e){e.Partials="partials",e.Layouts="layouts",e.Root="root"})(ic||(ic={}));class WJ{constructor(t){var n,i,r,o;if(this.options=t,t.relativeReference){const c=t.fs.sep;Jt(c,"`fs.sep` is required for relative reference");const l=["."+c,".."+c,"./","../"];this.shouldLoadRelative=d=>l.some(u=>d.startsWith(u))}else this.shouldLoadRelative=c=>!1;const a=t.fs;this.contains=bw(((n=a.contains)===null||n===void 0?void 0:n.bind(a))||(()=>at(this,void 0,void 0,function*(){return!0})),((i=a.containsSync)===null||i===void 0?void 0:i.bind(a))||(()=>!0)),this.exists=bw(((r=a.exists)===null||r===void 0?void 0:r.bind(a))||(()=>at(this,void 0,void 0,function*(){return!1})),(o=a.existsSync)===null||o===void 0?void 0:o.bind(a))}*lookup(t,n,i,r){const o=this.options[n];for(const a of this.candidates(t,o,r)){let c=!1;for(const l of o)if(yield this.contains(!!i,l,a)){c=!0;break}if(c&&(yield this.exists(!!i,a)))return a}throw this.lookupError(t,o)}*candidates(t,n,i){const{fs:r,extname:o}=this.options;this.shouldLoadRelative(t)&&i&&(yield r.resolve(this.dirname(i),t,o));for(const a of n)yield r.resolve(a,t,o);if(r.fallback!==void 0){const a=r.fallback(t);a!==void 0&&(yield a)}}dirname(t){const n=this.options.fs;return Jt(n.dirname,"`fs.dirname` is required for relative reference"),n.dirname(t)}lookupError(t,n){const i=new Error("ENOENT");return i.message=`ENOENT: Failed to lookup "${t}" in "${n}"`,i.code="ENOENT",i}}let bo=class{constructor(t){var n,i;this.liquid=t,this.cache=this.liquid.options.cache,this.fs=this.liquid.options.fs,this.parseFile=this.cache?this._parseFileCached:this._parseFile,this.loader=new WJ(this.liquid.options),this.parseLimit=new Aw("parse length",t.options.parseLimit),this.readFile=bw(((n=this.fs.readFile)===null||n===void 0?void 0:n.bind(this.fs))||(()=>at(this,void 0,void 0,function*(){throw new Error("readFile not implemented")})),(i=this.fs.readFileSync)===null||i===void 0?void 0:i.bind(this.fs))}parse(t,n){t=String(t),this.parseLimit.use(t.length);const r=new Di(t,this.liquid.options.operators,n).readTopLevelTokens(this.liquid.options);return this.parseTokens(r)}parseTokens(t){let n;const i=[],r=[];for(;n=t.shift();)try{i.push(this.parseToken(n,t))}catch(o){if(this.liquid.options.catchAllErrors)r.push(o);else throw o}if(r.length)throw new a8(r);return i}parseToken(t,n){try{if($s(t)){const i=this.liquid.tags[t.name];return Jt(i,`tag "${t.name}" not found`),new i(t,n,this.liquid,this)}return YJ(t)?new VJ(t,this.liquid):new KJ(t)}catch(i){throw Ts.is(i)?i:new kW(i,t)}}parseStream(t){return new qJ(t,(n,i)=>this.parseToken(n,i))}*_parseFileCached(t,n,i=ic.Root,r){const o=this.cache,a=this.loader.shouldLoadRelative(t)?r+","+t:i+":"+t,c=yield o.read(a);if(c)return c;const l=this._parseFile(t,n,i,r),d=n?yield l:sr(l);o.write(a,d);try{return yield d}catch(u){throw o.remove(a),u}}*_parseFile(t,n,i=ic.Root,r){const o=yield this.loader.lookup(t,i,n,r);return this.parse(yield this.readFile(!!n,o),o)}};var it;(function(e){e[e.Number=1]="Number",e[e.Literal=2]="Literal",e[e.Tag=4]="Tag",e[e.Output=8]="Output",e[e.HTML=16]="HTML",e[e.Filter=32]="Filter",e[e.Hash=64]="Hash",e[e.PropertyAccess=128]="PropertyAccess",e[e.Word=256]="Word",e[e.Range=512]="Range",e[e.Quoted=1024]="Quoted",e[e.Operator=2048]="Operator",e[e.FilteredValue=4096]="FilteredValue",e[e.Delimited=12]="Delimited"})(it||(it={}));function JJ(e){return!!(vi(e)&it.Delimited)}function A8(e){return vi(e)===it.Operator}function c1(e){return vi(e)===it.HTML}function YJ(e){return vi(e)===it.Output}function $s(e){return vi(e)===it.Tag}function Ew(e){return vi(e)===it.Quoted}function d3(e){return vi(e)===it.Number}function dh(e){return vi(e)===it.PropertyAccess}function u3(e){return vi(e)===it.Word}function k8(e){return vi(e)===it.Range}function Sn(e){return(vi(e)&1667)>0}function vi(e){return e?e.kind:-1}class Ro{constructor(t={},n=ya,i={},{memoryLimit:r,renderLimit:o}={}){var a,c,l,d,u;this.scopes=[{}],this.registers={},this.breakCalled=!1,this.continueCalled=!1,this.sync=!!i.sync,this.opts=n,this.globals=(a=i.globals)!==null&&a!==void 0?a:n.globals,this.environments=jg(t)?t:Object(t),this.strictVariables=(c=i.strictVariables)!==null&&c!==void 0?c:this.opts.strictVariables,this.ownPropertyOnly=(l=i.ownPropertyOnly)!==null&&l!==void 0?l:n.ownPropertyOnly,this.memoryLimit=r??new Aw("memory alloc",(d=i.memoryLimit)!==null&&d!==void 0?d:n.memoryLimit),this.renderLimit=o??new Aw("template render",kw().now()+((u=i.renderLimit)!==null&&u!==void 0?u:n.renderLimit))}getRegister(t,n=void 0){return this.registers[t]=this.registers[t]||n}setRegister(t,n){return this.registers[t]=n}saveRegister(...t){return t.map(n=>[n,this.getRegister(n)])}restoreRegister(t){return t.forEach(([n,i])=>this.setRegister(n,i))}getAll(){return[this.globals,this.environments,...this.scopes].reduce((t,n)=>ch(t,n),{})}get(t){return this.getSync(t)}getSync(t){return ar(this._get(t))}*_get(t){const n=this.findScope(t[0]);return yield this._getFromScope(n,t)}getFromScope(t,n){return ar(this._getFromScope(t,n))}*_getFromScope(t,n,i=this.strictVariables){Pe(n)&&(n=n.split("."));for(let r=0;r<n.length;r++)if(t=yield this.readProperty(t,n[r]),i&&gW(t))throw new xW(n.slice(0,r+1).join("."));return t}push(t){return this.scopes.push(t)}pop(){return this.scopes.pop()}bottom(){return this.scopes[0]}spawn(t={}){return new Ro(t,this.opts,{sync:this.sync,globals:this.globals,strictVariables:this.strictVariables,ownPropertyOnly:this.ownPropertyOnly},{renderLimit:this.renderLimit,memoryLimit:this.memoryLimit})}findScope(t){for(let n=this.scopes.length-1;n>=0;n--){const i=this.scopes[n];if(t in i)return i}return t in this.environments?this.environments:this.globals}readProperty(t,n){if(t=t8(t),n=Be(n),_t(t))return t;if(Ut(t)&&n<0)return t[t.length+ +n];const i=QJ(t,n,this.ownPropertyOnly);return i===void 0&&t instanceof Cs?t.liquidMethodMissing(n,this):Tt(i)?i.call(t):n==="size"?eY(t):n==="first"?ZJ(t):n==="last"?XJ(t):i}}function QJ(e,t,n){if(!(n&&!i1.call(e,t)&&!(e instanceof Cs)))return e[t]}function ZJ(e){return Ut(e)?e[0]:e.first}function XJ(e){return Ut(e)?e[e.length-1]:e.last}function eY(e){if(i1.call(e,"size")||e.size!==void 0)return e.size;if(Ut(e)||Pe(e))return e.length;if(typeof e=="object")return Object.keys(e).length}var es;(function(e){e[e.OUTPUT=0]="OUTPUT",e[e.STORE=1]="STORE"})(es||(es={}));const tY=Hi(Math.abs),nY=Hi(Math.max),iY=Hi(Math.min),rY=Hi(Math.ceil),oY=Hi((e,t,n=!1)=>n?Math.floor(e/t):e/t),sY=Hi(Math.floor),aY=Hi((e,t)=>e-t),cY=Hi((e,t)=>e+t),lY=Hi((e,t)=>e%t),dY=Hi((e,t)=>e*t);function uY(e,t=0){e=ww(e),t=ww(t);const n=Math.pow(10,t),i=e*n;return Math.sign(e)*Math.round(Math.abs(i))/n}var pY=Object.freeze({__proto__:null,abs:tY,at_least:nY,at_most:iY,ceil:rY,divided_by:oY,floor:sY,minus:aY,plus:cY,modulo:lY,times:dY,round:uY});const fY=e=>decodeURIComponent(de(e)).replace(/\+/g," "),hY=e=>encodeURIComponent(de(e)).replace(/%20/g,"+"),gY=e=>encodeURIComponent(de(e)).replace(/%20/g,"+").replace(/[!'()*]/g,t=>"%"+t.charCodeAt(0).toString(16).toUpperCase()),mY=e=>encodeURI(de(e)).replace(/%5B/g,"[").replace(/%5D/g,"]"),p3=/[^\p{M}\p{L}\p{Nd}]+/ug,yY={raw:/\s+/g,default:p3,pretty:/[^\p{M}\p{L}\p{Nd}._~!$&'()+,;=@]+/ug,ascii:/[^A-Za-z0-9]+/g,latin:p3,none:null};function _Y(e,t="default",n=!1){e=de(e);const i=yY[t];return i&&(t==="latin"&&(e=wY(e)),e=e.replace(i,"-").replace(/^-|-$/g,"")),n?e:e.toLowerCase()}function wY(e){return e.replace(/[àáâãäå]/g,"a").replace(/[æ]/g,"ae").replace(/[ç]/g,"c").replace(/[èéêë]/g,"e").replace(/[ìíîï]/g,"i").replace(/[ð]/g,"d").replace(/[ñ]/g,"n").replace(/[òóôõöø]/g,"o").replace(/[ùúûü]/g,"u").replace(/[ýÿ]/g,"y").replace(/[ß]/g,"ss").replace(/[œ]/g,"oe").replace(/[þ]/g,"th").replace(/[ẞ]/g,"SS").replace(/[Œ]/g,"OE").replace(/[Þ]/g,"TH")}var bY=Object.freeze({__proto__:null,url_decode:fY,url_encode:hY,cgi_escape:gY,uri_escape:mY,slugify:_Y});const vY=Og(function(e,t){const n=Wt(e),i=_t(t)?" ":de(t),r=n.length*(1+i.length);return this.context.memoryLimit.use(r),n.join(i)}),AY=Og(e=>n8(e)?i8(e):""),kY=Og(e=>n8(e)?e[0]:""),SY=Og(function(e){const t=Wt(e);return this.context.memoryLimit.use(t.length),[...t].reverse()});function*S8(e,t,n){const i=[],r=Wt(e);this.context.memoryLimit.use(r.length);for(const o of r)i.push([o,t?yield this.context._getFromScope(o,de(t).split("."),!1):o]);return i.sort((o,a)=>n(o[1],a[1])).map(o=>o[0])}function*EY(e,t){return yield*S8.call(this,e,t,bW)}function*xY(e,t){return yield*S8.call(this,e,t,vW)}const CY=e=>e&&e.length||0;function*TY(e,t){const n=[],i=Wt(e);this.context.memoryLimit.use(i.length);for(const r of i)n.push(yield this.context._getFromScope(r,de(t),!1));return n}function*$Y(e,t){let n=0;const i=Wt(e);for(const r of i){const o=Number(t?yield this.context._getFromScope(r,de(t),!1):r);n+=Number.isNaN(o)?0:o}return n}function IY(e){const t=Wt(e);return this.context.memoryLimit.use(t.length),t.filter(n=>!_t(Be(n)))}function E8(e,t=[]){const n=Wt(e),i=Wt(t);return this.context.memoryLimit.use(n.length+i.length),n.concat(i)}function zY(e,t){return E8.call(this,e,[t])}function PY(e,t){const n=Wt(e);this.context.memoryLimit.use(n.length);const i=[...n];return i.unshift(t),i}function NY(e){const t=[...Wt(e)];return t.pop(),t}function jY(e){const t=Wt(e);this.context.memoryLimit.use(t.length);const n=[...t];return n.shift(),n}function OY(e,t,n=1){return e=Be(e),_t(e)?[]:(Ut(e)||(e=de(e)),t=t<0?e.length+t:t,this.context.memoryLimit.use(n),e.slice(t,t+n))}function x8(e){return this.context.opts.jekyllWhere?t=>nc.is(e)?ur(t,e):Ut(t)?mJ(t,e):ur(t,e):e===void 0?t=>Ko(t,this.context):t=>ur(t,e)}function*C8(e,t,n,i){const r=[];t=Wt(t),this.context.memoryLimit.use(t.length);const o=new Di(de(n)).readScopeValue();for(const c of t)r.push(yield Et(o,this.context.spawn(c)));const a=x8.call(this,i);return t.filter((c,l)=>a(r[l])===e)}function*T8(e,t,n,i){const r=[],o=new Cn(de(i),this.liquid),a=Wt(t);this.context.memoryLimit.use(a.length);for(const c of a){this.context.push({[n]:c});const l=yield o.value(this.context);this.context.pop(),l===e&&r.push(c)}return r}function*FY(e,t,n){return yield*C8.call(this,!0,e,t,n)}function*RY(e,t,n){return yield*C8.call(this,!1,e,t,n)}function*DY(e,t,n){return yield*T8.call(this,!0,e,t,n)}function*BY(e,t,n){return yield*T8.call(this,!1,e,t,n)}function*LY(e,t){const n=new Map;e=pu(e);const i=new Di(de(t)).readScopeValue();this.context.memoryLimit.use(e.length);for(const r of e){const o=yield Et(i,this.context.spawn(r));n.has(o)||n.set(o,[]),n.get(o).push(r)}return[...n.entries()].map(([r,o])=>({name:r,items:o}))}function*MY(e,t,n){const i=new Map,r=new Cn(de(n),this.liquid);e=pu(e),this.context.memoryLimit.use(e.length);for(const o of e){this.context.push({[t]:o});const a=yield r.value(this.context);this.context.pop(),i.has(a)||i.set(a,[]),i.get(a).push(o)}return[...i.entries()].map(([o,a])=>({name:o,items:a}))}function*l1(e,t,n){const i=new Di(de(t)).readScopeValue(),r=Wt(e),o=x8.call(this,n);for(let a=0;a<r.length;a++){const c=yield Et(i,this.context.spawn(r[a]));if(o(c))return[a,r[a]]}}function*d1(e,t,n){const i=new Cn(de(n),this.liquid),r=Wt(e);for(let o=0;o<r.length;o++){this.context.push({[t]:r[o]});const a=yield i.value(this.context);if(this.context.pop(),a)return[o,r[o]]}}function*UY(e,t,n){return!!(yield*l1.call(this,e,t,n))}function*qY(e,t,n){return!!(yield*d1.call(this,e,t,n))}function*HY(e,t,n){const i=yield*l1.call(this,e,t,n);return i?i[0]:void 0}function*VY(e,t,n){const i=yield*d1.call(this,e,t,n);return i?i[0]:void 0}function*KY(e,t,n){const i=yield*l1.call(this,e,t,n);return i?i[1]:void 0}function*GY(e,t,n){const i=yield*d1.call(this,e,t,n);return i?i[1]:void 0}function WY(e){return e=Wt(e),this.context.memoryLimit.use(e.length),[...new Set(e)]}function JY(e,t=1){if(e=Be(e),_t(e))return[];Ut(e)||(e=de(e)),this.context.memoryLimit.use(t);const n=[...e].sort(()=>Math.random()-.5);return t===1?n[0]:n.slice(0,t)}var YY=Object.freeze({__proto__:null,join:vY,last:AY,first:kY,reverse:SY,sort:EY,sort_natural:xY,size:CY,map:TY,sum:$Y,compact:IY,concat:E8,push:zY,unshift:PY,pop:NY,shift:jY,slice:OY,where:FY,reject:RY,where_exp:DY,reject_exp:BY,group_by:LY,group_by_exp:MY,has:UY,has_exp:qY,find_index:HY,find_index_exp:VY,find:KY,find_exp:GY,uniq:WY,sample:JY});function u1(e,t,n){var i,r;const o=((i=e?.length)!==null&&i!==void 0?i:0)+((r=n?.length)!==null&&r!==void 0?r:0);this.context.memoryLimit.use(o);const a=I8(e,this.context.opts,n);return a?(t=Be(t),t=_t(t)?this.context.opts.dateFormat:de(t),this.context.memoryLimit.use(t.length),gp(a,t,this.context.memoryLimit)):e}function QY(e){return u1.call(this,e,"%Y-%m-%dT%H:%M:%S%:z")}function ZY(e){return u1.call(this,e,"%a, %d %b %Y %H:%M:%S %z")}function XY(e,t,n){return $8.call(this,e,"%b",t,n)}function eQ(e,t,n){return $8.call(this,e,"%B",t,n)}function $8(e,t,n,i){const r=I8(e,this.context.opts);if(!r)return e;const o=this.context.memoryLimit;if(n==="ordinal"){const a=r.getDate();return i==="US"?gp(r,`${t} ${a}%q, %Y`,o):gp(r,`${a}%q ${t} %Y`,o)}return gp(r,`%d ${t} %Y`,o)}function I8(e,t,n){let i;const r=n??t.timezoneOffset,o=t.locale;if(e=Be(e),!_t(e))return e==="now"||e==="today"?i=new ri(Date.now(),o,r):Ng(e)?i=new ri(e*1e3,o,r):Pe(e)?/^\d+$/.test(e)?i=new ri(+e*1e3,o,r):t.preserveTimezones&&n===void 0?i=ri.createDateFixedToTimezone(e,o):i=new ri(e,o,r):i=new ri(e,o,r),i.valid()?i:void 0}var tQ=Object.freeze({__proto__:null,date:u1,date_to_xmlschema:QY,date_to_rfc822:ZY,date_to_string:XY,date_to_long_string:eQ});const Ym=/[\u4E00-\u9FFF\uF900-\uFAFF\u3400-\u4DBF\u3040-\u309F\u30A0-\u30FF\uAC00-\uD7AF]/gu,f3=/[^\u4E00-\u9FFF\uF900-\uFAFF\u3400-\u4DBF\u3040-\u309F\u30A0-\u30FF\uAC00-\uD7AF\s]+/gu;function nQ(e,t){Jt(arguments.length===2,"append expect 2 arguments");const n=de(e),i=de(t);return this.context.memoryLimit.use(n.length+i.length),n+i}function iQ(e,t){Jt(arguments.length===2,"prepend expect 2 arguments");const n=de(e),i=de(t);return this.context.memoryLimit.use(n.length+i.length),i+n}function rQ(e,t){const n=de(e);if(this.context.memoryLimit.use(n.length),t){t=de(t),this.context.memoryLimit.use(t.length);for(let i=0,r=new Set(t);i<n.length;i++)if(!r.has(n[i]))return n.slice(i);return""}return n.trimStart()}function oQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),t.toLowerCase()}function sQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),de(t).toUpperCase()}function aQ(e,t){const n=de(e);return t=de(t),this.context.memoryLimit.use(n.length+t.length),n.split(t).join("")}function cQ(e,t){const n=de(e);return t=de(t),this.context.memoryLimit.use(n.length+t.length),n.replace(t,"")}function lQ(e,t){const n=de(e),i=de(t);this.context.memoryLimit.use(n.length+i.length);const r=n.lastIndexOf(i);return r===-1?n:n.substring(0,r)+n.substring(r+i.length)}function dQ(e,t){if(e=de(e),this.context.memoryLimit.use(e.length),t){t=de(t),this.context.memoryLimit.use(t.length);for(let n=e.length-1,i=new Set(t);n>=0;n--)if(!i.has(e[n]))return e.slice(0,n+1);return""}return e.trimEnd()}function uQ(e,t){const n=de(e);this.context.memoryLimit.use(n.length);const i=n.split(de(t));for(;i.length&&i[i.length-1]==="";)i.pop();return i}function pQ(e,t){const n=de(e);if(this.context.memoryLimit.use(n.length),t){const i=new Set(de(t));this.context.memoryLimit.use(i.size);let r=0,o=n.length-1;for(;i.has(n[r]);)r++;for(;o>=r&&i.has(n[o]);)o--;return n.slice(r,o+1)}return n.trim()}function fQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),t.replace(/\r?\n/gm,"")}function hQ(e){return e=de(e),this.context.memoryLimit.use(e.length),e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()}function gQ(e,t,n){const i=de(e);t=de(t),n=de(n);const r=i.split(t),o=i.length+(r.length-1)*(n.length-t.length);return this.context.memoryLimit.use(o),r.join(n)}function mQ(e,t,n){const i=de(e);return t=de(t),n=de(n),this.context.memoryLimit.use(i.length+t.length+n.length),i.replace(t,()=>n)}function yQ(e,t,n){const i=de(e),r=de(t),o=de(n);this.context.memoryLimit.use(i.length+r.length+o.length);const a=i.lastIndexOf(r);return a===-1?i:i.substring(0,a)+o+i.substring(a+r.length)}function _Q(e,t=50,n="..."){const i=de(e);return n=de(n),this.context.memoryLimit.use(i.length+n.length),i.length<=t?e:i.substring(0,t-n.length)+n}function wQ(e,t=15,n="..."){const i=de(e);n=de(n),this.context.memoryLimit.use(i.length+n.length);const r=i.split(/\s+/);t<=0&&(t=1);let o=r.slice(0,t).join(" ");return r.length>=t&&(o+=n),o}function bQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),t.replace(/\s+/g," ")}function vQ(e,t){const n=de(e);if(this.context.memoryLimit.use(n.length),e=n.trim(),!e)return 0;switch(t){case"cjk":return(e.match(Ym)||[]).length+(e.match(f3)||[]).length;case"auto":return Ym.test(e)?e.match(Ym).length+(e.match(f3)||[]).length:e.split(/\s+/).length;default:return e.split(/\s+/).length}}function AQ(e,t="and"){switch(t=de(t),this.context.memoryLimit.use(e.length+t.length),e.length){case 0:return"";case 1:return e[0];case 2:return`${e[0]} ${t} ${e[1]}`;default:return`${e.slice(0,-1).join(", ")}, ${t} ${e[e.length-1]}`}}var kQ=Object.freeze({__proto__:null,append:nQ,prepend:iQ,lstrip:rQ,downcase:oQ,upcase:sQ,remove:aQ,remove_first:cQ,remove_last:lQ,rstrip:dQ,split:uQ,strip:pQ,strip_newlines:fQ,capitalize:hQ,replace:gQ,replace_first:mQ,replace_last:yQ,truncate:_Q,truncatewords:wQ,normalize_whitespace:bQ,number_of_words:vQ,array_to_sentence_string:AQ});function SQ(e){return btoa(String.fromCharCode(...new TextEncoder().encode(e)))}function EQ(e){return new TextDecoder().decode(Uint8Array.from(atob(e),t=>t.charCodeAt(0)))}function xQ(e){if(typeof Buffer<"u"&&Buffer.isBuffer(e))return this.context.memoryLimit.use(e.byteLength),e.toString("base64");const t=de(e);return this.context.memoryLimit.use(t.length),SQ(t)}function CQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),EQ(t)}var TQ=Object.freeze({__proto__:null,base64_encode:xQ,base64_decode:CQ});function z8(e){const t=new Uint8Array(e);let n="";for(let i=0;i<t.length;i++)n+=t[i].toString(16).padStart(2,"0");return n}function $Q(e){return at(this,void 0,void 0,function*(){const t=new TextEncoder().encode(e),n=yield crypto.subtle.digest("SHA-256",t);return z8(n)})}function IQ(e,t){return at(this,void 0,void 0,function*(){const n=new TextEncoder,i=yield crypto.subtle.importKey("raw",n.encode(t),{name:"HMAC",hash:"SHA-256"},!1,["sign"]),r=yield crypto.subtle.sign("HMAC",i,n.encode(e));return z8(r)})}function zQ(e){const t=de(e);return this.context.memoryLimit.use(t.length),$Q(t)}function PQ(e,t){const n=de(e),i=de(t);return this.context.memoryLimit.use(n.length+i.length),IQ(n,i)}var NQ=Object.freeze({__proto__:null,sha256:zQ,hmac_sha256:PQ});const jQ=Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},FJ),pY),bY),YY),tQ),kQ),TQ),NQ),y8);class OQ extends pt{constructor(t,n,i){super(t,n,i),this.identifier=this.tokenizer.readIdentifier(),this.key=this.identifier.content,this.tokenizer.assert(this.key,"expected variable name"),this.tokenizer.skipBlank(),this.tokenizer.assert(this.tokenizer.peek()==="=",'expected "="'),this.tokenizer.advance(),this.value=new Cn(this.tokenizer.readFilteredValue(),this.liquid)}*render(t){t.bottom()[this.key]=yield this.value.value(t,this.liquid.options.lenientIf)}*arguments(){yield this.value}*localScope(){yield this.identifier}}const h3=["offset","limit","reversed"];class FQ extends pt{constructor(t,n,i,r){super(t,n,i);const o=this.tokenizer.readIdentifier(),a=this.tokenizer.readIdentifier(),c=this.tokenizer.readValue();if(!o.size()||a.content!=="in"||!c)throw new Error(`illegal tag: ${t.getText()}`);this.variable=o.content,this.collection=c,this.hash=new Pc(this.tokenizer,i.options.keyValueSeparator),this.templates=[],this.elseTemplates=[];let l;const d=r.parseStream(n).on("start",()=>l=this.templates).on("tag:else",u=>{ah(u.args),l=this.elseTemplates}).on("tag:endfor",u=>{ah(u.args),d.stop()}).on("template",u=>l.push(u)).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)});d.start()}*render(t,n){const i=this.liquid.renderer;let r=pu(yield Et(this.collection,t));if(!r.length){yield i.renderTemplates(this.elseTemplates,t,n);return}const o="continue-"+this.variable+"-"+this.collection.getText();t.push({continue:t.getRegister(o,{})});const a=yield this.hash.render(t);t.pop(),r=(this.liquid.options.orderedFilterParameters?Object.keys(a).filter(d=>h3.includes(d)):h3.filter(d=>a[d]!==void 0)).reduce((d,u)=>u==="offset"?DQ(d,a.offset):u==="limit"?BQ(d,a.limit):RQ(d),r),t.setRegister(o,(a.offset||0)+r.length);const l={forloop:new o1(r.length,this.collection.getText(),this.variable)};t.push(l);for(const d of r){if(l[this.variable]=d,t.continueCalled=t.breakCalled=!1,yield i.renderTemplates(this.templates,t,n),t.breakCalled)break;l.forloop.next()}t.continueCalled=t.breakCalled=!1,t.pop()}*children(){const t=this.templates.slice();return this.elseTemplates&&t.push(...this.elseTemplates),t}*arguments(){yield this.collection;for(const t of Object.values(this.hash.hash))Sn(t)&&(yield t)}blockScope(){return[this.variable,"forloop"]}}function RQ(e){return[...e].reverse()}function DQ(e,t){return e.slice(t)}function BQ(e,t){return e.slice(0,t)}class LQ extends pt{constructor(t,n,i,r){for(super(t,n,i),this.templates=[],this.identifier=this.readVariable(),this.variable=this.identifier.content;n.length;){const o=n.shift();if($s(o)&&o.name==="endcapture")return;this.templates.push(r.parseToken(o,n))}throw new Error(`tag ${t.getText()} not closed`)}readVariable(){let t=this.tokenizer.readIdentifier();if(t.content||(t=this.tokenizer.readQuoted(),t))return t;throw this.tokenizer.error("invalid capture name")}*render(t){const i=yield this.liquid.renderer.renderTemplates(this.templates,t);t.bottom()[this.variable]=i}*children(){return this.templates}*localScope(){yield this.identifier}}class MQ extends pt{constructor(t,n,i,r){super(t,n,i),this.branches=[],this.elseTemplates=[],this.value=new Cn(this.tokenizer.readFilteredValue(),this.liquid),this.elseTemplates=[];let o=[],a=0;const c=r.parseStream(n).on("tag:when",l=>{if(a>0)return;o=[];const d=[];for(;!l.tokenizer.end();)d.push(l.tokenizer.readValueOrThrow()),l.tokenizer.skipBlank(),l.tokenizer.peek()===","?l.tokenizer.readTo(","):l.tokenizer.readTo("or");this.branches.push({values:d,templates:o})}).on("tag:else",()=>{a++,o=this.elseTemplates}).on("tag:endcase",()=>c.stop()).on("template",l=>{(o!==this.elseTemplates||a===1)&&o.push(l)}).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)});c.start()}*render(t,n){const i=this.liquid.renderer,r=Be(yield this.value.value(t,t.opts.lenientIf));let o=!1;for(const a of this.branches)for(const c of a.values){const l=yield Et(c,t,t.opts.lenientIf);if(ur(r,l)){yield i.renderTemplates(a.templates,t,n),o=!0;break}}o||(yield i.renderTemplates(this.elseTemplates,t,n))}*arguments(){yield this.value,yield*this.branches.flatMap(t=>t.values)}*children(){const t=this.branches.flatMap(n=>n.templates);return this.elseTemplates&&t.push(...this.elseTemplates),t}}class UQ extends pt{constructor(t,n,i){for(super(t,n,i);n.length;){const r=n.shift();if($s(r)&&r.name==="endcomment")return}throw new Error(`tag ${t.getText()} not closed`)}render(){}}class qQ extends pt{constructor(t,n,i,r){super(t,n,i);const o=this.tokenizer;for(this.file=p1(o,this.liquid,r),this.currentFile=t.file;!o.end();){o.skipBlank();const a=o.p,c=o.readIdentifier();if((c.content==="with"||c.content==="for")&&(o.skipBlank(),o.peek()!==":")){const l=o.readValue();if(l){const d=o.p,u=o.readIdentifier();let p;u.content==="as"?p=o.readIdentifier():o.p=d,this[c.content]={value:l,alias:p&&p.content},o.skipBlank(),o.peek()===","&&o.advance();continue}}o.p=a;break}this.hash=new Pc(o,i.options.keyValueSeparator)}*render(t,n){const{liquid:i,hash:r}=this,o=yield f1(this.file,t,i);Jt(o,()=>`illegal file path "${o}"`);const a=t.spawn(),c=a.bottom();if(ch(c,yield r.render(t)),this.with){const{value:l,alias:d}=this.with;c[d||o]=yield Et(l,t)}if(this.for){const{value:l,alias:d}=this.for,u=pu(yield Et(l,t));c.forloop=new o1(u.length,l.getText(),d);for(const p of u){c[d]=p;const f=yield i._parsePartialFile(o,a.sync,this.currentFile);yield i.renderer.renderTemplates(f,a,n),c.forloop.next()}}else{const l=yield i._parsePartialFile(o,a.sync,this.currentFile);yield i.renderer.renderTemplates(l,a,n)}}*children(t,n){return t&&Pe(this.file)?yield this.liquid._parsePartialFile(this.file,n,this.currentFile):[]}partialScope(){if(Pe(this.file)){const t=Object.keys(this.hash.hash);if(this.with){const{value:n,alias:i}=this.with;Pe(i)?t.push([i,n]):Pe(this.file)&&t.push([this.file,n])}if(this.for){const{value:n,alias:i}=this.for;Pe(i)?t.push([i,n]):Pe(this.file)&&t.push([this.file,n])}return{name:this.file,isolated:!0,scope:t}}}*arguments(){for(const t of Object.values(this.hash.hash))Sn(t)&&(yield t);if(this.with){const{value:t}=this.with;Sn(t)&&(yield t)}if(this.for){const{value:t}=this.for;Sn(t)&&(yield t)}}}function p1(e,t,n){if(t.options.dynamicPartials){const o=e.readValue();if(e.assert(o,"illegal file path"),o.getText()==="none")return;if(Ew(o)){const a=n.parse(uJ(o));return g3(a)}return o}const i=[...e.readFileNameTemplate(t.options)],r=g3(n.parseTokens(i));return r==="none"?void 0:r}function g3(e){return e.length===1&&c1(e[0].token)?e[0].token.getContent():e}function*f1(e,t,n){return typeof e=="string"?e:Array.isArray(e)?n.renderer.renderTemplates(e,t):yield Et(e,t)}class HQ extends pt{constructor(t,n,i,r){super(t,n,i);const{tokenizer:o}=t;this.file=p1(o,this.liquid,r),this.currentFile=t.file;const a=o.p;o.readIdentifier().content==="with"?(o.skipBlank(),o.peek()!==":"?this.withVar=o.readValue():o.p=a):o.p=a,this.hash=new Pc(o,i.options.jekyllInclude||i.options.keyValueSeparator)}*render(t,n){const{liquid:i,hash:r,withVar:o}=this,{renderer:a}=i,c=yield f1(this.file,t,i);Jt(c,()=>`illegal file path "${c}"`);const l=t.saveRegister("blocks","blockMode");t.setRegister("blocks",{}),t.setRegister("blockMode",es.OUTPUT);const d=yield r.render(t);o&&(d[c]=yield Et(o,t));const u=yield i._parsePartialFile(c,t.sync,this.currentFile);t.push(t.opts.jekyllInclude?{include:d}:d),yield a.renderTemplates(u,t,n),t.pop(),t.restoreRegister(l)}*children(t,n){return t&&Pe(this.file)?yield this.liquid._parsePartialFile(this.file,n,this.currentFile):[]}partialScope(){if(Pe(this.file)){let t;return this.liquid.options.jekyllInclude?t=["include"]:(t=Object.keys(this.hash.hash),this.withVar&&t.push([this.file,this.withVar])),{name:this.file,isolated:!1,scope:t}}}*arguments(){yield*Object.values(this.hash.hash).filter(Sn),Sn(this.file)&&(yield this.file),Sn(this.withVar)&&(yield this.withVar)}}class VQ extends pt{constructor(t,n,i){super(t,n,i),this.identifier=this.tokenizer.readIdentifier(),this.variable=this.identifier.content}render(t,n){const i=t.environments;Ng(i[this.variable])||(i[this.variable]=0),n.write(de(--i[this.variable]))}*localScope(){yield this.identifier}}class KQ extends pt{constructor(t,n,i){super(t,n,i),this.candidates=[];const r=this.tokenizer.readValue();for(this.tokenizer.skipBlank(),r&&(this.tokenizer.peek()===":"?(this.group=r,this.tokenizer.advance()):this.candidates.push(r));!this.tokenizer.end();){const o=this.tokenizer.readValue();o&&this.candidates.push(o),this.tokenizer.readTo(",")}this.tokenizer.assert(this.candidates.length,()=>`empty candidates: "${t.getText()}"`)}*render(t,n){const r=`cycle:${yield Et(this.group,t)}:`+this.candidates.join(","),o=t.getRegister("cycle",{});let a=o[r];a===void 0&&(a=o[r]=0);const c=this.candidates[a];return a=(a+1)%this.candidates.length,o[r]=a,yield Et(c,t)}*arguments(){yield*this.candidates,this.group&&(yield this.group)}}class GQ extends pt{constructor(t,n,i,r){super(t,n,i),this.branches=[];let o=[];r.parseStream(n).on("start",()=>this.branches.push({value:new Cn(t.tokenizer.readFilteredValue(),this.liquid),templates:o=[]})).on("tag:elsif",a=>{Jt(!this.elseTemplates,"unexpected elsif after else"),this.branches.push({value:new Cn(a.tokenizer.readFilteredValue(),this.liquid),templates:o=[]})}).on("tag:else",a=>{ah(a.args),Jt(!this.elseTemplates,"duplicated else"),o=this.elseTemplates=[]}).on("tag:endif",function(a){ah(a.args),this.stop()}).on("template",a=>o.push(a)).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)}).start()}*render(t,n){const i=this.liquid.renderer;for(const{value:r,templates:o}of this.branches){const a=yield r.value(t,t.opts.lenientIf);if(Ko(a,t)){yield i.renderTemplates(o,t,n);return}}yield i.renderTemplates(this.elseTemplates||[],t,n)}*children(){const t=this.branches.flatMap(n=>n.templates);return this.elseTemplates&&t.push(...this.elseTemplates),t}arguments(){return this.branches.map(t=>t.value)}}class WQ extends pt{constructor(t,n,i){super(t,n,i),this.identifier=this.tokenizer.readIdentifier(),this.variable=this.identifier.content}render(t,n){const i=t.environments;Ng(i[this.variable])||(i[this.variable]=0);const r=i[this.variable];i[this.variable]++,n.write(de(r))}*localScope(){yield this.identifier}}class JQ extends pt{constructor(t,n,i,r){super(t,n,i),this.file=p1(this.tokenizer,this.liquid,r),this.currentFile=t.file,this.args=new Pc(this.tokenizer,i.options.keyValueSeparator),this.templates=r.parseTokens(n)}*render(t,n){const{liquid:i,args:r,file:o}=this,{renderer:a}=i;if(o===void 0){t.setRegister("blockMode",es.OUTPUT),yield a.renderTemplates(this.templates,t,n);return}const c=yield f1(this.file,t,i);Jt(c,()=>`illegal file path "${c}"`);const l=yield i._parseLayoutFile(c,t.sync,this.currentFile);t.setRegister("blockMode",es.STORE);const d=yield a.renderTemplates(this.templates,t),u=t.getRegister("blocks",{});u[""]===void 0&&(u[""]=(p,f)=>f.write(d)),t.setRegister("blockMode",es.OUTPUT),t.push(yield r.render(t)),yield a.renderTemplates(l,t,n),t.pop()}*children(t){const n=this.templates.slice();return t&&Pe(this.file)&&n.push(...yield this.liquid._parsePartialFile(this.file,!0,this.currentFile)),n}*arguments(){for(const t of Object.values(this.args.hash))Sn(t)&&(yield t);Sn(this.file)&&(yield this.file)}partialScope(){if(Pe(this.file))return{name:this.file,isolated:!1,scope:Object.keys(this.args.hash)}}}class YQ extends pt{constructor(t,n,i,r){super(t,n,i),this.templates=[];const o=/\w+/.exec(t.args);for(this.block=o?o[0]:"";n.length;){const a=n.shift();if($s(a)&&a.name==="endblock")return;const c=r.parseToken(a,n);this.templates.push(c)}throw new Error(`tag ${t.getText()} not closed`)}*render(t,n){const i=this.getBlockRender(t);t.getRegister("blockMode")===es.STORE?t.getRegister("blocks",{})[this.block]=i:yield i(new GS,n)}getBlockRender(t){const n=this,{liquid:i,templates:r}=this,o=t.getRegister("blocks",{})[this.block],a=function*(c,l){const d=t.getRegister("blockStack",[]);if(d.includes(n))throw new Error("block tag cannot be nested");d.push(n),t.push({block:c}),yield i.renderer.renderTemplates(r,t,l),t.pop(),d.pop()};return o?(c,l)=>o(new GS(d=>a(c,d)),l):a}*children(){return this.templates}blockScope(){return["block"]}}class QQ extends pt{constructor(t,n,i){for(super(t,n,i),this.tokens=[];n.length;){const r=n.shift();if($s(r)&&r.name==="endraw")return;this.tokens.push(r)}throw new Error(`tag ${t.getText()} not closed`)}render(){return this.tokens.map(t=>t.getText()).join("")}}class ZQ extends o1{constructor(t,n,i,r){super(t,i,r),this.length=t,this.cols=n}row(){return Math.floor(this.i/this.cols)+1}col0(){return this.i%this.cols}col(){return this.col0()+1}col_first(){return this.col0()===0}col_last(){return this.col()===this.cols}}class XQ extends pt{constructor(t,n,i,r){super(t,n,i);const o=this.tokenizer.readIdentifier();this.tokenizer.skipBlank();const a=this.tokenizer.readIdentifier(),c=this.tokenizer.readValue();if(a.content!=="in"||!c)throw new Error(`illegal tag: ${t.getText()}`);this.variable=o.content,this.collection=c,this.args=new Pc(this.tokenizer,i.options.keyValueSeparator),this.templates=[];let l;const d=r.parseStream(n).on("start",()=>l=this.templates).on("tag:endtablerow",()=>d.stop()).on("template",u=>l.push(u)).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)});d.start()}*render(t,n){let i=pu(yield Et(this.collection,t));const r=yield this.args.render(t),o=r.offset||0,a=r.limit===void 0?i.length:r.limit;i=i.slice(o,o+a);const c=r.cols||i.length,l=this.liquid.renderer,d=new ZQ(i.length,c,this.collection.getText(),this.variable),u={tablerowloop:d};t.push(u);for(let p=0;p<i.length;p++,d.next())u[this.variable]=i[p],d.col0()===0&&(d.row()!==1&&n.write("</tr>"),n.write(`<tr class="row${d.row()}">`)),n.write(`<td class="col${d.col()}">`),yield l.renderTemplates(this.templates,t,n),n.write("</td>");i.length&&n.write("</tr>"),t.pop()}*children(){return this.templates}*arguments(){yield this.collection;for(const t of Object.values(this.args.hash))Sn(t)&&(yield t)}blockScope(){return[this.variable,"tablerowloop"]}}class eZ extends pt{constructor(t,n,i,r){super(t,n,i),this.branches=[],this.elseTemplates=[];let o=[],a=0;r.parseStream(n).on("start",()=>this.branches.push({value:new Cn(t.tokenizer.readFilteredValue(),this.liquid),test:Fg,templates:o=[]})).on("tag:elsif",c=>{if(a>0){o=[];return}this.branches.push({value:new Cn(c.tokenizer.readFilteredValue(),this.liquid),test:Ko,templates:o=[]})}).on("tag:else",()=>{a++,o=this.elseTemplates}).on("tag:endunless",function(){this.stop()}).on("template",c=>{(o!==this.elseTemplates||a===1)&&o.push(c)}).on("end",()=>{throw new Error(`tag ${t.getText()} not closed`)}).start()}*render(t,n){const i=this.liquid.renderer;for(const{value:r,test:o,templates:a}of this.branches){const c=yield r.value(t,t.opts.lenientIf);if(o(c,t)){yield i.renderTemplates(a,t,n);return}}yield i.renderTemplates(this.elseTemplates,t,n)}*children(){const t=this.branches.flatMap(n=>n.templates);return this.elseTemplates&&t.push(...this.elseTemplates),t}arguments(){return this.branches.map(t=>t.value)}}class tZ extends pt{render(t,n){t.breakCalled=!0}}class nZ extends pt{render(t,n){t.continueCalled=!0}}class iZ extends pt{constructor(t,n,i){super(t,n,i),this.tokenizer.skipBlank(),this.tokenizer.end()||(this.value=new Cn(this.tokenizer.readFilteredValue(),this.liquid))}*render(t,n){if(!this.value)return;const i=yield this.value.value(t,!1);n.write(i)}*arguments(){this.value&&(yield this.value)}}class rZ extends pt{constructor(t,n,i,r){super(t,n,i);const o=this.tokenizer.readLiquidTagTokens(this.liquid.options);this.templates=r.parseTokens(o)}*render(t,n){yield this.liquid.renderer.renderTemplates(this.templates,t,n)}*children(){return this.templates}}class oZ extends pt{constructor(t,n,i){if(super(t,n,i),t.args.search(/\n\s*[^#\s]/g)!==-1)throw new Error("every line of an inline comment must start with a '#' character")}render(){}}const sZ={assign:OQ,for:FQ,capture:LQ,case:MQ,comment:UQ,include:HQ,render:qQ,decrement:VQ,increment:WQ,cycle:KQ,if:GQ,layout:JQ,block:YQ,raw:QQ,tablerow:XQ,unless:eZ,break:tZ,continue:nZ,echo:iZ,liquid:rZ,"#":oZ};class h1{constructor(t={}){this.renderer=new cJ,this.filters=Object.create(null),this.tags=Object.create(null),this.options=DJ(t),this.parser=new bo(this),HS(sZ,(n,i)=>this.registerTag(i,n)),HS(jQ,(n,i)=>this.registerFilter(i,n))}parse(t,n){return new bo(this).parse(t,n)}_render(t,n,i){const r=n instanceof Ro?n:new Ro(n,this.options,i);return this.renderer.renderTemplates(t,r)}render(t,n,i){return at(this,void 0,void 0,function*(){return sr(this._render(t,n,Object.assign(Object.assign({},i),{sync:!1})))})}renderSync(t,n,i){return ar(this._render(t,n,Object.assign(Object.assign({},i),{sync:!0})))}renderToNodeStream(t,n,i={}){const r=new Ro(n,this.options,i);return this.renderer.renderTemplatesToNodeStream(t,r)}_parseAndRender(t,n,i){const r=this.parse(t);return this._render(r,n,i)}parseAndRender(t,n,i){return at(this,void 0,void 0,function*(){return sr(this._parseAndRender(t,n,Object.assign(Object.assign({},i),{sync:!1})))})}parseAndRenderSync(t,n,i){return ar(this._parseAndRender(t,n,Object.assign(Object.assign({},i),{sync:!0})))}_parsePartialFile(t,n,i){return new bo(this).parseFile(t,n,ic.Partials,i)}_parseLayoutFile(t,n,i){return new bo(this).parseFile(t,n,ic.Layouts,i)}_parseFile(t,n,i,r){return new bo(this).parseFile(t,n,i,r)}parseFile(t,n){return at(this,void 0,void 0,function*(){return sr(new bo(this).parseFile(t,!1,n))})}parseFileSync(t,n){return ar(new bo(this).parseFile(t,!0,n))}*_renderFile(t,n,i){const r=yield this._parseFile(t,i.sync,i.lookupType);return yield this._render(r,n,i)}renderFile(t,n,i){return at(this,void 0,void 0,function*(){return sr(this._renderFile(t,n,Object.assign(Object.assign({},i),{sync:!1})))})}renderFileSync(t,n,i){return ar(this._renderFile(t,n,Object.assign(Object.assign({},i),{sync:!0})))}renderFileToNodeStream(t,n,i){return at(this,void 0,void 0,function*(){const r=yield this.parseFile(t);return this.renderToNodeStream(r,n,i)})}_evalValue(t,n){const i=new Cn(t,this),r=n instanceof Ro?n:new Ro(n,this.options);return i.value(r)}evalValue(t,n){return at(this,void 0,void 0,function*(){return sr(this._evalValue(t,n))})}evalValueSync(t,n){return ar(this._evalValue(t,n))}registerFilter(t,n){this.filters[t]=n}registerTag(t,n){this.tags[t]=Tt(n)?n:HJ(n)}plugin(t){return t.call(this,h1)}express(){const t=this;let n=!0;return function(i,r,o){if(n){n=!1;const a=mp(this.root);t.options.root.unshift(...a),t.options.layouts.unshift(...a),t.options.partials.unshift(...a)}t.renderFile(i,r).then(a=>o(null,a),o)}}analyze(t,n={}){return at(this,void 0,void 0,function*(){return Ir(t,n)})}analyzeSync(t,n={}){return zr(t,n)}parseAndAnalyze(t,n,i={}){return at(this,void 0,void 0,function*(){return Ir(this.parse(t,n),i)})}parseAndAnalyzeSync(t,n,i={}){return zr(this.parse(t,n),i)}variables(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Object.keys(i.variables)})}variablesSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Object.keys(i.variables)}fullVariables(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Array.from(new Set(Object.values(i.variables).flatMap(r=>r.map(o=>String(o)))))})}fullVariablesSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Array.from(new Set(Object.values(i.variables).flatMap(r=>r.map(o=>String(o)))))}variableSegments(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Array.from(Lu(Object.values(i.variables).flatMap(r=>r.map(o=>o.toArray()))))})}variableSegmentsSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Array.from(Lu(Object.values(i.variables).flatMap(r=>r.map(o=>o.toArray()))))}globalVariables(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Object.keys(i.globals)})}globalVariablesSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Object.keys(i.globals)}globalFullVariables(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Array.from(new Set(Object.values(i.globals).flatMap(r=>r.map(o=>String(o)))))})}globalFullVariablesSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Array.from(new Set(Object.values(i.globals).flatMap(r=>r.map(o=>String(o)))))}globalVariableSegments(t,n={}){return at(this,void 0,void 0,function*(){const i=yield Ir(Pe(t)?this.parse(t):t,n);return Array.from(Lu(Object.values(i.globals).flatMap(r=>r.map(o=>o.toArray()))))})}globalVariableSegmentsSync(t,n={}){const i=zr(Pe(t)?this.parse(t):t,n);return Array.from(Lu(Object.values(i.globals).flatMap(r=>r.map(o=>o.toArray()))))}}const aZ={reset_email:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ password_reset_title }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ password_reset_title }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ reset_password_email_click_to_reset }}</p><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="text-align:center;margin-bottom:1rem;margin-top:1rem"><tbody><tr><td><a href="{{ url }}" style="line-height:100%;text-decoration:none;display:inline-block;max-width:100%;mso-padding-alt:0px;background-color:{{ branding.primary_color }};color:#ffffff;border-radius:4px;font-size:14px;font-weight:600;padding:12px 24px;padding-top:12px;padding-right:24px;padding-bottom:12px;padding-left:24px" target="_blank"><span><!--[if mso]><i style="mso-font-width:400%;mso-text-raise:18" hidden>&#8202;&#8202;&#8202;</i><![endif]--></span><span style="max-width:100%;display:inline-block;line-height:120%;mso-padding-alt:0px;mso-text-raise:9px">{{ reset_password_email_reset }}</span><span><!--[if mso]><i style="mso-font-width:400%" hidden>&#8202;&#8202;&#8202;&#8203;</i><![endif]--></span></a></td></tr></tbody></table></td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>',reset_email_by_code:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ password_reset_title }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ password_reset_title }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ reset_password_email_click_to_reset }}</p><p style="font-size:1.875rem;line-height:1.2;font-weight:700;text-align:center;margin-bottom:1rem;margin-top:1rem;letter-spacing:0.25em">{{ code }}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);text-align:center;margin-top:16px;margin-bottom:16px">{{ code_valid_30_minutes }}</p></td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>',verify_email:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ welcome_to_your_account }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ welcome_to_your_account }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ link_email_click_to_login }}</p><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="text-align:center;margin-bottom:1rem;margin-top:1rem"><tbody><tr><td><a href="{{ url }}" style="line-height:100%;text-decoration:none;display:inline-block;max-width:100%;mso-padding-alt:0px;background-color:{{ branding.primary_color }};color:#ffffff;border-radius:4px;font-size:14px;font-weight:600;padding:12px 24px;padding-top:12px;padding-right:24px;padding-bottom:12px;padding-left:24px" target="_blank"><span><!--[if mso]><i style="mso-font-width:400%;mso-text-raise:18" hidden>&#8202;&#8202;&#8202;</i><![endif]--></span><span style="max-width:100%;display:inline-block;line-height:120%;mso-padding-alt:0px;mso-text-raise:9px">{{ link_email_login }}</span><span><!--[if mso]><i style="mso-font-width:400%" hidden>&#8202;&#8202;&#8202;&#8203;</i><![endif]--></span></a></td></tr></tbody></table>{% if code %}<p style="font-size:14px;line-height:24px;text-align:center;color:rgb(113,113,123);margin-top:1rem;margin-bottom:16px">{{ link_email_or_enter_code }}</p><p style="font-size:1.875rem;line-height:1.2;font-weight:700;text-align:center;margin-bottom:0.5rem;margin-top:0.5rem;letter-spacing:0.25em">{{ code }}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);text-align:center;margin-top:16px;margin-bottom:16px">{{ code_valid_30_minutes }}</p>{% endif %}</td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>',verify_email_by_code:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ welcome_to_your_account }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ welcome_to_your_account }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ link_email_click_to_login }}</p><p style="font-size:1.875rem;line-height:1.2;font-weight:700;text-align:center;margin-bottom:1rem;margin-top:1rem;letter-spacing:0.25em">{{ code }}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);text-align:center;margin-top:16px;margin-bottom:16px">{{ code_valid_30_minutes }}</p></td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>',welcome_email:'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html dir="ltr" lang="en"><head><link rel="preload" as="image" href="{{ branding.logo }}"/><meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/><meta name="x-apple-disable-message-reformatting"/></head><body style="background-color:rgb(244,244,245)"><!--$--><!--html--><!--head--><div style="display:none;overflow:hidden;line-height:1px;opacity:0;max-height:0;max-width:0" data-skip-in-text="true">{{ welcome_to_your_account }}<div> ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF ‌​‍‎‏\uFEFF</div></div><!--body--><table border="0" width="100%" cellPadding="0" cellSpacing="0" role="presentation" align="center"><tbody><tr><td style="background-color:rgb(244,244,245);font-family:ui-sans-serif,system-ui,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;,&quot;Segoe UI Symbol&quot;,&quot;Noto Color Emoji&quot;"><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="max-width:560px;background-color:rgb(255,255,255);margin-bottom:2rem;margin-top:2rem;margin-right:auto;margin-left:auto;border-radius:0.375rem;overflow:hidden"><tbody><tr style="width:100%"><td><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-top:1.5rem;padding-bottom:0.5rem;text-align:center"><tbody><tr><td>{% if branding.logo %}<img alt="{{ tenant.friendly_name }}" src="{{ branding.logo }}" style="display:block;outline:none;border:none;text-decoration:none;margin-right:auto;margin-left:auto" width="120"/>{% endif %}</td></tr></tbody></table><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1.5rem;color:rgb(39,39,42)"><tbody><tr><td><h1 style="font-size:1.25rem;line-height:1.4;font-weight:600;margin-bottom:0.5rem">{{ welcome_to_your_account }}</h1><p style="font-size:14px;line-height:24px;margin-top:16px;margin-bottom:16px">{{ welcome_body }}</p>{% if url %}<table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="text-align:center;margin-bottom:1rem;margin-top:1rem"><tbody><tr><td><a href="{{ url }}" style="line-height:100%;text-decoration:none;display:inline-block;max-width:100%;mso-padding-alt:0px;background-color:{{ branding.primary_color }};color:#ffffff;border-radius:4px;font-size:14px;font-weight:600;padding:12px 24px;padding-top:12px;padding-right:24px;padding-bottom:12px;padding-left:24px" target="_blank"><span><!--[if mso]><i style="mso-font-width:400%;mso-text-raise:18" hidden>&#8202;&#8202;&#8202;</i><![endif]--></span><span style="max-width:100%;display:inline-block;line-height:120%;mso-padding-alt:0px;mso-text-raise:9px">{{ welcome_cta }}</span><span><!--[if mso]><i style="mso-font-width:400%" hidden>&#8202;&#8202;&#8202;&#8203;</i><![endif]--></span></a></td></tr></tbody></table>{% endif %}</td></tr></tbody></table><hr style="width:100%;border:none;border-top:1px solid #eaeaea;border-color:rgb(228,228,231);margin:0rem"/><table align="center" width="100%" border="0" cellPadding="0" cellSpacing="0" role="presentation" style="padding-right:1.5rem;padding-left:1.5rem;padding-bottom:1rem;padding-top:1rem;text-align:center"><tbody><tr><td><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin:0rem;margin-top:0rem;margin-bottom:0rem;margin-left:0rem;margin-right:0rem">{{ support_info }}<!-- --> <!-- -->{% if tenant.support_url %}<a href="{{ tenant.support_url }}" style="color:rgb(113,113,123);text-decoration-line:underline" target="_blank">{{ contact_us }}</a>{% endif %}</p><p style="font-size:0.75rem;line-height:1.3333333333333333;color:rgb(113,113,123);margin-top:0.5rem;margin-bottom:0rem">{{ copyright }}</p></td></tr></tbody></table></td></tr></tbody></table></td></tr></tbody></table><!--/$--></body></html>'},cZ={reset_email:"{{ password_reset_title }}",reset_email_by_code:"{{ password_reset_title }}",verify_email:"{{ welcome_to_your_account }}",verify_email_by_code:"{{ code_email_subject }}",welcome_email:"{{ welcome_to_your_account }}"};function lZ(e){const t=aZ[e],n=cZ[e];return!t||!n?null:{subject:n,body:t}}const m3=new h1({cache:!0,strictVariables:!1,strictFilters:!1});async function dZ(e,t,n,i){const r=await e.env.data.emailTemplates.get(e.var.tenant_id,t);if(r&&r.enabled===!1)return{kind:"disabled"};const o=r?{subject:r.subject,body:r.body}:lZ(t);if(!o)return{kind:"none"};const[a,c]=await Promise.all([m3.parseAndRender(o.subject,n),m3.parseAndRender(o.body,n)]);return{kind:"rendered",email:{subject:a,html:c,from:r?.from||i}}}const P8=s.z.object({api_key:s.z.string().min(1),domain:s.z.string().min(4),region:s.z.enum(["eu"]).nullish()});class N8{options;constructor(t={}){this.options=t}async send(t){const n=this.options.fetchImpl??globalThis.fetch,i=P8.parse(t.emailProvider.credentials),o=`https://${i.region==="eu"?"api.eu.mailgun.net":"api.mailgun.net"}/v3/${encodeURIComponent(i.domain)}/messages`,a=new URLSearchParams;a.append("from",t.from),a.append("to",t.to),a.append("subject",t.subject),a.append("template",t.template),a.append("h:X-Mailgun-Variables",JSON.stringify(t.data)),t.html&&a.append("html",t.html),t.text&&a.append("text",t.text);const c=btoa(`api:${i.api_key}`),l=await n(o,{method:"POST",headers:{Authorization:`Basic ${c}`,"Content-Type":"application/x-www-form-urlencoded"},body:a.toString()});if(!l.ok){const d=await l.text().catch(()=>"");throw new Error(`Mailgun send failed: ${l.status} ${l.statusText} ${d.slice(0,500)}`)}}}const uZ={mailgun:()=>new N8};async function pZ(e,t){const n=await e.env.data.emailProviders.get(e.var.tenant_id);if(!n)throw new z(500,{message:"Email provider not found"});const i=uZ[n.name],r=i?i():e.env.data.emailService;if(!r)throw new z(500,{message:"Email service not configured"});try{await r.send({emailProvider:n,...t,from:t.from||n.default_from_address||`login@${e.env.ISSUER}`})}catch(o){const a=o instanceof Error?o.message:String(o);throw console.error(`[sendEmail] tenant=${e.var.tenant_id} provider=${n.name} template=${t.template} to=${t.to}: ${a}`,o),await B(e,e.var.tenant_id,{type:R.FAILED_SENDING_NOTIFICATION,description:`email send failed via ${n.name}: ${a}`.slice(0,500),details:{provider:n.name,template:t.template,to:t.to,error:a},waitForCompletion:!0}),o}}async function j8(e,t){if(!e.var.client_id)throw new z(500,{message:"Client not found"});const n=await nt(e.env,e.var.client_id),i=n.connections.find(o=>o.strategy===Z.SMS);if(!i)throw new z(500,{message:"SMS provider not found"});const r=e.env.data.smsService;if(!r)throw new z(500,{message:"SMS service not configured"});try{await r.send({options:i.options,to:t.to,from:t.from,text:t.text,template:"auth-code",data:{code:t.code,tenantName:n.tenant.friendly_name,tenantId:n.tenant.id}})}catch(o){const a=o instanceof Error?o.message:String(o);throw console.error(`[sendSms] tenant=${e.var.tenant_id} connection=${i.name} to=${t.to}: ${a}`,o),await B(e,e.var.tenant_id,{type:R.FAILED_SENDING_NOTIFICATION,description:`sms send failed via ${i.name}: ${a}`.slice(0,500),details:{connection:i.name,to:t.to,error:a},waitForCompletion:!0}),o}}async function O8(e,t){const n=await e.env.data.tenants.get(e.var.tenant_id);if(!n)throw new z(500,{message:"Tenant not found"});const i=await e.env.data.branding.get(e.var.tenant_id),r=i?.logo_url||"",o=i?.colors?.primary||"#7d68f4",a={vendorName:n.friendly_name,lng:t||"en"};return{tenant:n,logo:r,buttonColor:o,options:a}}async function Nc(e,t){const i=(await e.env.data.emailProviders.get(e.var.tenant_id))?.default_from_address||`login@${e.env.ISSUER}`,r={...t.data,tenant:{id:t.tenant.id,friendly_name:t.tenant.friendly_name,support_url:t.tenant.support_url||""},branding:{logo:t.branding.logo,primary_color:t.branding.primary_color},url:t.url,code:t.code},o=await dZ(e,t.templateName,r,i);if(o.kind==="disabled")return!1;const a=o.kind==="rendered"?o.email.subject:t.fallbackSubject,c=o.kind==="rendered"?o.email.html:t.fallbackHtml,l=o.kind==="rendered"?o.email.from:i;return await pZ(e,{to:t.to,subject:a,html:c,template:t.legacyTemplate,data:t.data,from:l}),!0}async function F8(e,t,n,i,r){const{tenant:o,logo:a,buttonColor:c,options:l}=await O8(e,r),d=`${Fn(e.env)}reset-password?state=${i}&code=${n}`,u={vendorName:o.friendly_name,logo:a,passwordResetUrl:d,supportUrl:o.support_url||"https://support.sesamy.com",buttonColor:c,password_reset_title:oe("password_reset_title",l),passwordResetTitle:oe("password_reset_title",l),reset_password_email_click_to_reset:oe("reset_password_email_click_to_reset",l),resetPasswordEmailClickToReset:oe("reset_password_email_click_to_reset",l),reset_password_email_reset:oe("reset_password_email_reset",l),resetPasswordEmailReset:oe("reset_password_email_reset",l),support_info:oe("support_info",l),supportInfo:oe("support_info",l),contact_us:oe("contact_us",l),contactUs:oe("contact_us",l),copyright:oe("copyright",l),tenantName:o.friendly_name,tenantId:o.id};await Nc(e,{to:t,templateName:"reset_email",legacyTemplate:"auth-password-reset",fallbackSubject:oe("reset_password_title",l),fallbackHtml:`Click here to reset your password: ${d}`,tenant:o,branding:{logo:a,primary_color:c},url:d,data:u}),B(e,o.id,{type:R.SUCCESS_CHANGE_PASSWORD_REQUEST,description:t})}async function fZ(e,t,n,i){const{tenant:r,logo:o,buttonColor:a,options:c}=await O8(e,i),l={code:n,vendorName:r.friendly_name,logo:o,supportUrl:r.support_url||"https://support.sesamy.com",buttonColor:a,welcomeToYourAccount:oe("password_reset_title",c),password_reset_title:oe("password_reset_title",c),linkEmailClickToLogin:oe("reset_password_email_click_to_reset",c),reset_password_email_click_to_reset:oe("reset_password_email_click_to_reset",c),linkEmailLogin:oe("reset_password_email_reset",c),reset_password_email_reset:oe("reset_password_email_reset",c),linkEmailOrEnterCode:oe("link_email_or_enter_code",{...c,code:n}),codeValid30Mins:oe("code_valid_30_minutes",c),code_valid_30_minutes:oe("code_valid_30_minutes",c),support_info:oe("support_info",c),supportInfo:oe("support_info",c),contact_us:oe("contact_us",c),contactUs:oe("contact_us",c),copyright:oe("copyright",c)};await Nc(e,{to:t,templateName:"reset_email_by_code",legacyTemplate:"auth-code",fallbackSubject:oe("reset_password_title",c),fallbackHtml:`Your password reset code is: ${n}`,tenant:r,branding:{logo:o,primary_color:a},code:n,data:l}),B(e,r.id,{type:R.SUCCESS_CHANGE_PASSWORD_REQUEST,description:t})}async function fu(e,{to:t,code:n,language:i}){const r=await e.env.data.tenants.get(e.var.tenant_id);if(!r)throw new z(500,{message:"Tenant not found"});const{connectionType:o}=go(t),a=await e.env.data.branding.get(e.var.tenant_id),c=a?.logo_url||"",l=a?.colors?.primary||"#7d68f4",d=new URL(Fn(e.env)),u={vendorName:r.friendly_name,vendorId:r.id,loginDomain:d.hostname,code:n,lng:i||"en"};if(o==="email"){const p={code:n,vendorName:r.friendly_name,logo:c,supportUrl:r.support_url||"",buttonColor:l,welcomeToYourAccount:oe("welcome_to_your_account",u),welcome_to_your_account:oe("welcome_to_your_account",u),linkEmailClickToLogin:oe("link_email_click_to_login",u),link_email_click_to_login:oe("link_email_click_to_login",u),linkEmailLogin:oe("link_email_login",u),link_email_login:oe("link_email_login",u),linkEmailOrEnterCode:oe("link_email_or_enter_code",u),link_email_or_enter_code:oe("link_email_or_enter_code",u),codeValid30Mins:oe("code_valid_30_minutes",u),code_valid_30_minutes:oe("code_valid_30_minutes",u),code_email_subject:oe("code_email_subject",u),supportInfo:oe("support_info",u),support_info:oe("support_info",u),contactUs:oe("contact_us",u),contact_us:oe("contact_us",u),copyright:oe("copyright",u)};await Nc(e,{to:t,templateName:"verify_email_by_code",legacyTemplate:"auth-code",fallbackSubject:oe("code_email_subject",u),fallbackHtml:`Click here to validate your email: ${Fn(e.env)}validate-email`,tenant:r,branding:{logo:c,primary_color:l},code:n,data:p})}else o==="sms"&&await j8(e,{to:t,text:oe("sms_code_text",u),code:n,from:r.friendly_name});B(e,r.id,{type:R.CODE_LINK_SENT,description:t})}async function hu(e,{to:t,code:n,authParams:i,language:r}){const o=await e.env.data.tenants.get(e.var.tenant_id);if(!o)throw new z(500,{message:"Tenant not found"});if(!i.redirect_uri)throw new z(400,{message:"redirect_uri is required"});const{connectionType:a}=go(t),c=await e.env.data.branding.get(e.var.tenant_id),l=c?.logo_url||"",d=c?.colors?.primary||"",u=new URL(ni(e.env));u.pathname="passwordless/verify_redirect",u.searchParams.set("verification_code",n),u.searchParams.set("connection",a),u.searchParams.set("client_id",i.client_id),u.searchParams.set("redirect_uri",i.redirect_uri),u.searchParams.set("email",t),i.response_type&&u.searchParams.set("response_type",i.response_type),i.scope&&u.searchParams.set("scope",i.scope),i.state&&u.searchParams.set("state",i.state),i.nonce&&u.searchParams.set("nonce",i.nonce),i.code_challenge&&u.searchParams.set("code_challenge",i.code_challenge),i.code_challenge_method&&u.searchParams.set("code_challenge_method",i.code_challenge_method),i.audience&&u.searchParams.set("audience",i.audience);const p={vendorName:o.friendly_name,code:n,lng:r||"en"};if(a==="email"){const f={code:n,vendorName:o.friendly_name,logo:l,supportUrl:o.support_url||"",magicLink:u.toString(),buttonColor:d,welcomeToYourAccount:oe("welcome_to_your_account",p),welcome_to_your_account:oe("welcome_to_your_account",p),linkEmailClickToLogin:oe("link_email_click_to_login",p),link_email_click_to_login:oe("link_email_click_to_login",p),linkEmailLogin:oe("link_email_login",p),link_email_login:oe("link_email_login",p),linkEmailOrEnterCode:oe("link_email_or_enter_code",p),link_email_or_enter_code:oe("link_email_or_enter_code",p),codeValid30Mins:oe("code_valid_30_minutes",p),code_valid_30_minutes:oe("code_valid_30_minutes",p),code_email_subject:oe("code_email_subject",p),supportInfo:oe("support_info",p),support_info:oe("support_info",p),contactUs:oe("contact_us",p),contact_us:oe("contact_us",p),copyright:oe("copyright",p)};await Nc(e,{to:t,templateName:"verify_email",legacyTemplate:"auth-link",fallbackSubject:oe("code_email_subject",p),fallbackHtml:`Click here to validate your email: ${u.toString()}`,tenant:o,branding:{logo:l,primary_color:d},url:u.toString(),code:n,data:f})}else if(a==="sms")await j8(e,{to:t,text:`${oe("link_sms_login",p)}: ${u.toString()}`,code:n,from:o.friendly_name});else throw new z(400,{message:"Only email and SMS connections are supported for magic links"});B(e,o.id,{type:R.CODE_LINK_SENT,description:t})}async function Dg(e,t,n){const i=await e.env.data.tenants.get(e.var.tenant_id);if(!i)throw new z(500,{message:"Tenant not found"});if(!t.email)throw new z(400,{message:"User has no email"});const r=await e.env.data.branding.get(e.var.tenant_id),o=r?.logo_url||"",a=r?.colors?.primary||"#7d68f4",c={vendorName:i.friendly_name,lng:n||"en"},l=`${Fn(e.env)}validate-email`,d={vendorName:i.friendly_name,logo:o,emailValidationUrl:l,supportUrl:i.support_url||"https://support.sesamy.com",buttonColor:a,welcomeToYourAccount:oe("welcome_to_your_account",c),welcome_to_your_account:oe("welcome_to_your_account",c),verifyEmailVerify:oe("verify_email_verify",c),verify_email_verify:oe("verify_email_verify",c),link_email_click_to_login:oe("verify_email_verify",c),link_email_login:oe("verify_email_verify",c),supportInfo:oe("support_info",c),support_info:oe("support_info",c),contactUs:oe("contact_us",c),contact_us:oe("contact_us",c),copyright:oe("copyright",c)};await Nc(e,{to:t.email,templateName:"verify_email",legacyTemplate:"auth-verify-email",fallbackSubject:oe("welcome_to_your_account",c),fallbackHtml:`Click here to validate your email: ${l}`,tenant:i,branding:{logo:o,primary_color:a},url:l,data:d})}async function hZ(e,t,n,i,r){const o=await e.env.data.tenants.get(e.var.tenant_id);if(!o)throw new z(500,{message:"Tenant not found"});const a=await e.env.data.branding.get(e.var.tenant_id),c=a?.logo_url||"",l=a?.colors?.primary||"#7d68f4",d={vendorName:o.friendly_name,lng:"en"},u=`${Fn(e.env)}signup?state=${i}&code=${n}`,p={vendorName:o.friendly_name,logo:c,signupUrl:u,setPassword:oe("set_password",d),registerPasswordAccount:oe("register_password_account",d),clickToSignUpDescription:oe("click_to_sign_up_description",d),supportUrl:o.support_url||"https://support.sesamy.com",buttonColor:l,welcomeToYourAccount:oe("welcome_to_your_account",d),welcome_to_your_account:oe("welcome_to_your_account",d),verifyEmailVerify:oe("verify_email_verify",d),verify_email_verify:oe("verify_email_verify",d),link_email_click_to_login:oe("click_to_sign_up_description",d),link_email_login:oe("set_password",d),supportInfo:oe("support_info",d),support_info:oe("support_info",d),contactUs:oe("contact_us",d),contact_us:oe("contact_us",d),copyright:oe("copyright",d)};await Nc(e,{to:t,templateName:"verify_email",legacyTemplate:"auth-pre-signup-verification",fallbackSubject:oe("register_password_account",d),fallbackHtml:`Click here to register: ${u}`,tenant:o,branding:{logo:c,primary_color:l},url:u,data:p})}const gZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["dbconnections"],method:"post",path:"/signup",request:{body:{content:{"application/json":{schema:s.z.object({client_id:s.z.string(),connection:s.z.literal(Z.USERNAME_PASSWORD),email:s.z.string().transform(e=>e.toLowerCase()),password:s.z.string()})}}}},responses:{200:{content:{"application/json":{schema:s.z.object({_id:s.z.string(),email:s.z.string().optional(),email_verified:s.z.boolean(),app_metadata:s.z.object({}),user_metadata:s.z.object({})})}},description:"Created user"}}}),async e=>{const{email:t,password:n,client_id:i}=e.req.valid("json"),r=await nt(e.env,i);e.set("client_id",r.client_id),on(e,r.tenant.id);const a=r.connections.find(h=>h.strategy===Z.USERNAME_PASSWORD)?.name||Z.USERNAME_PASSWORD,c=await Fd(e.env.data,r.tenant.id,a);try{await Od(c,{tenantId:r.tenant.id,userId:"",newPassword:n,data:e.env.data})}catch(h){throw new z(400,{message:h?.message||"Password does not meet the requirements"})}if(await hr({env:e.env,tenant_id:r.tenant.id,username:t}))throw new z(400,{message:"Invalid sign up"});const{hash:d,algorithm:u}=await Na(n),p=await fc(e.env,r.tenant.id),f=await e.env.data.users.create(r.tenant.id,{user_id:`${p}|${lo()}`,email:t,email_verified:!1,provider:p,connection:Z.USERNAME_PASSWORD,is_social:!1,password:{hash:d,algorithm:u}});e.set("user_id",f.user_id),e.set("username",f.email),e.set("connection",f.connection);try{await Dg(e,f)}catch(h){console.error("Failed to send verification email:",h)}return B(e,r.tenant.id,{type:R.SUCCESS_SIGNUP,description:"Successful signup"}),e.json({_id:f.user_id,email:f.email,email_verified:!1,app_metadata:{},user_metadata:{}})}).openapi(s.createRoute({tags:["dbconnections"],method:"post",path:"/change_password",request:{body:{content:{"application/json":{schema:s.z.object({client_id:s.z.string(),connection:s.z.literal(Z.USERNAME_PASSWORD),email:s.z.string().transform(e=>e.toLowerCase())})}}}},responses:{200:{description:"Redirect to the client's redirect uri"}}}),async e=>{const{email:t,client_id:n}=e.req.valid("json"),i=await nt(e.env,n);if(e.set("client_id",i.client_id),on(e,i.tenant.id),!await po({env:e.env,tenant_id:i.tenant.id,username:t}))return e.html("If an account with that email exists, we've sent instructions to reset your password.");const o={client_id:n,username:t,audience:i.tenant.default_audience},a=await e.env.data.loginSessions.create(i.tenant.id,{expires_at:new Date(Date.now()+no*1e3).toISOString(),authParams:o,csrf_token:Le(),ip:e.get("ip"),useragent:e.get("useragent"),auth0Client:Ri(e.get("auth0_client"))});return await F8(e,t,a.id,a.authParams.state),e.html("If an account with that email exists, we've sent instructions to reset your password.")});function Tn(){const e=new Uint8Array(6);crypto.getRandomValues(e);let t="";for(let n=0;n<6;n+=1)t+=(e[n]%10).toString();return t}const mZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["passwordless"],method:"post",path:"/start",request:{body:{content:{"application/json":{schema:s.z.union([s.z.object({connection:s.z.literal("email"),client_id:s.z.string(),email:s.z.string().transform(e=>e.toLowerCase()),send:s.z.enum(["link","code"]),authParams:Hl.omit({client_id:!0})}),s.z.object({client_id:s.z.string(),connection:s.z.literal("sms"),phone_number:s.z.string(),send:s.z.enum(["link","code"]),authParams:Hl.omit({client_id:!0})})])}}}},responses:{200:{description:"Status"}}}),async e=>{const t=e.req.valid("json"),{env:n}=e,{client_id:i,send:r,authParams:o,connection:a}=t,c=await nt(e.env,i);e.set("client_id",c.client_id),on(e,c.tenant.id);const l=a==="email"?t.email:t.phone_number,d=e.get("ip"),u=e.get("useragent"),p=e.get("auth0_client"),f=Ri(p),h=o.audience??c.tenant.default_audience,g=await n.data.loginSessions.create(c.tenant.id,{authParams:{...o,client_id:i,username:l,audience:h},expires_at:new Date(Date.now()+ka).toISOString(),csrf_token:Le(),ip:d,useragent:u,auth0Client:f}),m=await n.data.codes.create(c.tenant.id,{code_id:Tn(),code_type:"otp",login_id:g.id,expires_at:new Date(Date.now()+ka).toISOString(),redirect_uri:o.redirect_uri}),_=o?.ui_locales?.split(" ")?.map(w=>w.split("-")[0])[0];return r==="link"?await hu(e,{to:l,code:m.code_id,authParams:{...o,client_id:i,audience:h},language:_}):await fu(e,{to:l,code:m.code_id,language:_}),e.html("OK")}).openapi(s.createRoute({tags:["passwordless"],method:"get",path:"/verify_redirect",request:{query:s.z.object({scope:s.z.string(),response_type:s.z.nativeEnum(xn),redirect_uri:s.z.string(),state:s.z.string(),nonce:s.z.string().optional(),verification_code:s.z.string(),connection:s.z.string(),client_id:s.z.string(),email:s.z.string().transform(e=>e.toLowerCase()),audience:s.z.string().optional()})},responses:{302:{description:"Successful verification, redirecting to continue flow.",headers:s.z.object({Location:s.z.string().url()}).openapi({})},400:{description:"Bad Request (e.g., invalid client, invalid code, missing parameters).",content:{"application/json":{schema:s.z.object({error:s.z.string(),error_description:s.z.string().optional()})}}},500:{description:"Internal Server Error.",content:{"application/json":{schema:s.z.object({error:s.z.string(),error_description:s.z.string().optional()})}}}}}),async e=>{const{env:t}=e,{client_id:n,email:i,verification_code:r,redirect_uri:o,state:a,scope:c,audience:l,response_type:d,nonce:u}=e.req.valid("query"),p=await nt(t,n);e.set("client_id",p.client_id),on(e,p.tenant.id),e.set("connection","email");const f={client_id:n,redirect_uri:o,state:a,nonce:u,scope:c,audience:l,response_type:d};let h="Something went wrong. Please try again later.";try{const b=await uu(e,{client_id:n,username:i,otp:r,authParams:f,enforceIpCheck:!0});if(b instanceof Response)return b;if(b&&typeof b=="object"&&"access_token"in b)return e.json(b)}catch(b){const A=b;"message"in A&&typeof A.message=="string"&&(h=A.message)}const g=e.get("ip"),m=e.get("useragent"),_=e.get("auth0_client"),w=Ri(_),y=await t.data.loginSessions.create(p.tenant.id,{authParams:{...f,username:i,audience:f.audience??p.tenant.default_audience},expires_at:new Date(Date.now()+ka).toISOString(),csrf_token:Le(),ip:g,useragent:m,auth0Client:w});return e.redirect(`${Fn(e.env,e.var.custom_domain)}invalid-session?state=${y.id}&error=${encodeURIComponent(h)}`,302)});class Io extends z{_code;constructor(t,n){super(t,n),this._code=n?.code}get code(){return this._code}}async function yZ(e,t){const i=[];for(let r=0;;r++){const{connections:o}=await e.env.data.connections.list(t,{page:r,per_page:100,include_totals:!1});if(i.push(...o),o.length<100)break}return i}async function y3(e,t,n){return(await yZ(e,t)).find(r=>r.name===n)??null}function Mu(e){return typeof e=="string"?e:void 0}function _Z(e){const t=e.options&&typeof e.options=="object"?e.options.configuration:void 0;if(!t||typeof t!="object")return null;const n=t,i=Mu(n.token_endpoint),r=Mu(n.userinfo_endpoint),o=Mu(n.client_id),a=Mu(n.client_secret);return!i||!r||!o||!a?null:{tokenEndpoint:i,userinfoEndpoint:r,clientId:o,clientSecret:a}}async function _3(e){const{ctx:t,client:n,username:i,password:r,dbConnection:o,existingUser:a}=e;if(o.options?.import_mode!==!0)return null;const c=_Z(o);if(!c)return null;let l;try{l=await kV({tokenEndpoint:c.tokenEndpoint,clientId:c.clientId,clientSecret:c.clientSecret,realm:o.name,username:i,password:r})}catch(g){if(g instanceof kn)return console.warn(`Auth0 upstream ROPG failed for tenant=${n.tenant.id} realm=${o.name}: ${g.code} ${g.description??""}`),null;throw g}const d=t.env.data;let u=a;if(!u){let g;try{g=await L6(c.userinfoEndpoint,l.access_token)}catch(b){if(b instanceof kn)return console.warn(`Auth0 upstream userinfo failed for tenant=${n.tenant.id}: ${b.code} ${b.description??""}`),null;throw b}const m=i.includes("@"),_=typeof g.email=="string"?g.email:void 0,w=await fc(t.env,n.tenant.id),y=`${w}|${lo()}`;u=await d.users.create(n.tenant.id,{user_id:y,email:_??(m?i:void 0),username:m?void 0:i,name:typeof g.name=="string"?g.name:i,given_name:typeof g.given_name=="string"?g.given_name:void 0,family_name:typeof g.family_name=="string"?g.family_name:void 0,nickname:typeof g.nickname=="string"?g.nickname:void 0,picture:typeof g.picture=="string"?g.picture:void 0,email_verified:g.email_verified===!0,provider:w,connection:o.name,is_social:!1,last_ip:t.var.ip??"",last_login:new Date().toISOString(),profileData:JSON.stringify(g)})}const{hash:p,algorithm:f}=await Na(r),h=await d.passwords.get(n.tenant.id,u.user_id);return h&&await d.passwords.update(n.tenant.id,{id:h.id,user_id:u.user_id,password:h.password,algorithm:h.algorithm,is_current:!1}),await d.passwords.create(n.tenant.id,{user_id:u.user_id,password:p,algorithm:f,is_current:!0}),u}async function wZ(e,t,n){const i=n.app_metadata||{},r=i.failed_logins||[],o=Date.now(),a=[...r.filter(c=>o-c<1e3*60*5),o];i.failed_logins=a,await e.users.update(t,n.user_id,{app_metadata:i})}function bZ(e){return typeof e=="object"&&e!==null&&"allowed"in e&&typeof e.allowed=="boolean"}function vZ(e){const n=(e.app_metadata||{}).failed_logins||[],i=Date.now();return n.filter(r=>i-r<1e3*60*5)}async function R8(e,t,n,i,r=Z.USERNAME_PASSWORD){const{data:o}=e.env,{username:a}=n;if(e.set("username",a),!a)throw new V(400,{message:"Username is required"});const c=t.tenant.attack_protection?.suspicious_ip_throttling,l=e.var.ip,d=l?c?.allowlist?.includes(l):!1;if(o.rateLimit&&c?.enabled&&l&&!d){let _={allowed:!0};try{const w=await o.rateLimit.consume("pre-login",`${t.tenant.id}:${l}`);bZ(w)&&(_=w)}catch(w){console.error("Pre-login rate limit consume failed:",w)}if(!_.allowed)throw B(e,t.tenant.id,{type:R.FAILED_LOGIN,description:"Rate limit exceeded for pre-login"}),new Io(429,{message:"Too many requests",code:"TOO_MANY_REQUESTS"})}let u=await po({env:e.env,tenant_id:t.tenant.id,username:a});if(!u){const _=await y3(e,t.tenant.id,r);if(_?.options?.import_mode===!0){const w=await _3({ctx:e,client:t,username:a,password:n.password,dbConnection:_,existingUser:null});w&&(u=w)}if(!u)throw B(e,t.tenant.id,{type:R.FAILED_LOGIN_INCORRECT_PASSWORD,description:"Invalid user"}),new Io(403,{message:"User not found",code:"USER_NOT_FOUND"})}const p=u.linked_to?await o.users.get(t.tenant.id,u.linked_to):u;if(!p)throw new Io(403,{message:"User not found",code:"USER_NOT_FOUND"});if(e.set("connection",u.connection),e.set("user_id",p.user_id),vZ(p).length>=3)throw B(e,t.tenant.id,{type:R.FAILED_LOGIN,description:"Too many failed login attempts"}),new Io(403,{message:"Too many failed login attempts",code:"TOO_MANY_FAILED_LOGINS"});const h=await o.passwords.get(t.tenant.id,u.user_id);let g=h&&await dc.compare(n.password,h.password);if(!g){const _=await y3(e,t.tenant.id,u.connection);_?.options?.import_mode===!0&&await _3({ctx:e,client:t,username:a,password:n.password,dbConnection:_,existingUser:p})&&(g=!0)}if(!g)throw B(e,t.tenant.id,{type:R.FAILED_LOGIN_INCORRECT_PASSWORD,description:"Invalid password"}),wZ(o,t.tenant.id,p),new Io(403,{message:"Invalid password",code:"INVALID_PASSWORD"});if(!u.email_verified&&t.client_metadata?.email_validation==="enforced"){const _=i?.authParams?.ui_locales?.split(" ")?.map(w=>w.split("-")[0])[0];throw await Dg(e,u,_),B(e,t.tenant.id,{type:R.FAILED_LOGIN,description:"Email not verified"}),i&&await xq(e,t.tenant.id,i,"Email not verified"),new Io(403,{message:"Email not verified",code:"EMAIL_NOT_VERIFIED"})}const m=p.app_metadata||{};return m.failed_logins&&m.failed_logins.length>0&&(m.failed_logins=[],o.users.update(t.tenant.id,p.user_id,{app_metadata:m})),{client:t,authParams:n,user:p,loginSession:i}}async function gu(e,t,n,i,r,o=Z.USERNAME_PASSWORD){const a=await R8(e,t,n,i,o);return ot(e,{...a,ticketAuth:r,authConnection:e.get("connection")||Z.USERNAME_PASSWORD,authStrategy:{strategy:Z.USERNAME_PASSWORD,strategy_type:Gt.DATABASE}})}async function g1(e,t,n,i,r){await TI(e,{client:t,username:n,connection:Z.USERNAME_PASSWORD,ip:e.var.ip});let o=Tn(),a=await e.env.data.codes.get(t.tenant.id,o,"password_reset");for(;a;)o=Tn(),a=await e.env.data.codes.get(t.tenant.id,o,"password_reset");let c=i;if(!await e.env.data.loginSessions.get(t.tenant.id,i)){const u=e.get("ip"),p=e.get("useragent"),f=e.get("auth0_client"),h=Ri(f);c=(await e.env.data.loginSessions.create(t.tenant.id,{expires_at:new Date(Date.now()+D5).toISOString(),authParams:{client_id:t.client_id,username:n},csrf_token:Le(),ip:u,useragent:p,auth0Client:h})).id}const d=await e.env.data.codes.create(t.tenant.id,{code_id:o,code_type:"password_reset",login_id:c,expires_at:new Date(Date.now()+hM).toISOString()});r==="code"?await fZ(e,n,d.code_id):await F8(e,n,d.code_id,c)}const AZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["oauth"],method:"post",path:"/",request:{body:{content:{"application/json":{schema:s.z.union([s.z.object({credential_type:s.z.literal("http://auth0.com/oauth/grant-type/passwordless/otp"),otp:s.z.string(),client_id:s.z.string(),username:s.z.string().transform(e=>e.toLowerCase()),realm:s.z.enum([Z.EMAIL]),scope:s.z.string().optional()}),s.z.object({credential_type:s.z.literal("http://auth0.com/oauth/grant-type/password-realm"),client_id:s.z.string(),username:s.z.string().transform(e=>e.toLowerCase()),password:s.z.string(),realm:s.z.enum([Z.USERNAME_PASSWORD]),scope:s.z.string().optional()})])}}}},responses:{200:{description:"List of tenants"}}}),async e=>{const t=e.req.valid("json"),{client_id:n,username:i}=t;e.set("username",i);const r=await nt(e.env,n);e.set("client_id",n),on(e,r.tenant.id);const o=i.toLocaleLowerCase(),a=e.get("ip"),c=e.get("useragent"),l=e.get("auth0_client");let d;if("otp"in t)d=await uu(e,{client_id:n,username:o,otp:t.otp});else if("password"in t){const u=await e.env.data.loginSessions.create(r.tenant.id,{expires_at:new Date(Date.now()+no*1e3).toISOString(),authParams:{client_id:n,username:o,audience:r.tenant.default_audience},csrf_token:Le(),ip:a,useragent:c,auth0Client:Ri(l)});d=await gu(e,r,{username:o,password:t.password,client_id:n},u,!0,t.realm)}else throw new z(400,{message:"Code or password required"});return d});function D8(e,t){if(!e||t.length===0)return!1;const n=Qm(e)?.host??null;if(!n)return!1;for(const i of t){let r;if(i.startsWith("http://")||i.startsWith("https://")?r=Qm(i)?.host??null:r=Qm("https://"+i)?.host??null,n===r)return!0}return!1}function Qm(e){try{return new URL(e)}catch{return null}}function kZ(e,t){if(!e||t===void 0)return!1;const n=new Date(e.authenticated_at).getTime(),i=t*1e3;return Date.now()-n>i}async function SZ({ctx:e,session:t,client:n,authParams:i,connection:r,login_hint:o,screen_hint:a}){const c=new URL(e.req.url);e.var.custom_domain&&(c.hostname=e.var.custom_domain);const{ip:l,auth0_client:d,useragent:u}=e.var,p=Ri(d);kZ(t,i.max_age)&&(t=void 0);const f=i.prompt?.split(" ")??[];(f.includes("login")||f.includes("select_account"))&&(t=void 0);const h=await e.env.data.loginSessions.create(n.tenant.id,{expires_at:new Date(Date.now()+no*1e3).toISOString(),authParams:i,csrf_token:Le(),authorization_url:c.toString(),ip:l,useragent:u,auth0Client:p}),g=n.client_metadata?.universal_login_version==="2"?"/u2":"/u";if(t&&o&&a!=="login"){const m=await e.env.data.users.get(n.tenant.id,t.user_id);if(m?.email===o)return ot(e,{client:n,loginSession:h,authParams:i,user:m,existingSessionIdToLink:t.id})}if(r===Z.EMAIL&&o){const m=Tn();return await e.env.data.codes.create(n.tenant.id,{code_id:m,code_type:"otp",login_id:h.id,expires_at:new Date(Date.now()+no*1e3).toISOString(),redirect_uri:i.redirect_uri}),await hu(e,{code:m,to:o,authParams:i}),e.redirect(`${g}/login/email-otp-challenge?state=${h.id}`)}if(t&&a!=="login"){const m=await e.env.data.users.get(n.tenant.id,t.user_id);if(m)return ot(e,{client:n,loginSession:h,authParams:i,user:m,existingSessionIdToLink:t.id})}if(g==="/u2"){const m=await e.env.data.promptSettings.get(n.tenant.id),_=Wo.parse(m||{}),w=n.connections.some(y=>y.strategy===Z.USERNAME_PASSWORD);if(_.identifier_first===!1&&w)return e.redirect(`${g}/login?state=${h.id}`)}return e.redirect(`${g}/login/identifier?state=${h.id}`)}async function EZ(e,t,n){if(n===Z.USERNAME_PASSWORD)return fc(e.env,t);if(n===Z.EMAIL)return Z.EMAIL;throw new V(403,{message:"Invalid realm"})}async function xZ(e,t,n,i,r){const{env:o}=e;e.set("connection",r);const a=await o.data.codes.get(t,n,"ticket");if(!a||a.used_at)throw new V(403,{message:"Ticket not found"});const c=await o.data.loginSessions.get(t,a.login_id);if(!c||!c.authParams.username)throw new V(403,{message:"Session not found"});const l=await nt(o,c.authParams.client_id,t);e.set("client_id",c.authParams.client_id),await o.data.codes.used(t,n);const d=await EZ(e,t,r),p=l.connections.find(g=>g.name===r)?.strategy||(Xp(d)?Z.USERNAME_PASSWORD:Z.EMAIL),f=p===Z.USERNAME_PASSWORD?Gt.DATABASE:Gt.PASSWORDLESS;let h=r===Z.USERNAME_PASSWORD?await TI(e,{client:l,username:c.authParams.username,connection:r,ip:e.var.ip}):await jd(e,{username:c.authParams.username,provider:d,client:l,connection:r,isSocial:!1,ip:e.var.ip});return e.set("username",h.email||h.phone_number),e.set("user_id",h.user_id),ot(e,{authParams:{scope:c.authParams?.scope,...i},loginSession:c,user:h,client:l,authConnection:r,authStrategy:{strategy:p,strategy_type:f}})}function w3(e,t){return t===mt.QUERY?!1:t===mt.FRAGMENT?!0:e!==xn.CODE}async function CZ({ctx:e,client:t,session:n,redirect_uri:i,state:r,nonce:o,code_challenge_method:a,code_challenge:c,audience:l,scope:d,response_type:u,response_mode:p,organization:f,max_age:h}){const{env:g}=e,m=new URL(i),_=`${m.protocol}//${m.host}`,w=p===mt.WEB_MESSAGE;async function y(ne="Login required"){const ie=new Headers;if(n&&(B(e,t.tenant.id,{type:R.FAILED_SILENT_AUTH,description:ne}),$v(t.tenant.id,e.var.host).forEach(De=>{ie.append("set-cookie",De)})),w)return tw(e,_,JSON.stringify({error:"login_required",error_description:ne,state:r}),ie);const xe={error:"login_required",error_description:ne};if(r&&(xe.state=r),p===mt.FORM_POST)return Mf(i,xe,ie);const ft=new URL(i);if(w3(u,p))ft.hash=new URLSearchParams(xe).toString();else for(const[Os,De]of Object.entries(xe))ft.searchParams.set(Os,De);const zt={Location:ft.toString()},js=ie.get("set-cookie");return js&&(zt["set-cookie"]=js),new Response(null,{status:302,headers:zt})}const b=!n||n?.expires_at&&new Date(n.expires_at)<new Date||n?.idle_expires_at&&new Date(n.idle_expires_at)<new Date,A=n&&h!==void 0&&Date.now()-new Date(n.authenticated_at).getTime()>h*1e3;if(b||A)return y();const v=await g.data.users.get(t.tenant.id,n.user_id);if(!v)return console.error("User not found",n.user_id),y("User not found");const k=v.linked_to?await g.data.users.get(t.tenant.id,v.linked_to):v;if(!k)return console.error("Linked primary user not found",v.linked_to),y("User not found");e.set("user_id",k.user_id),e.set("username",k.email),e.set("connection",k.connection);let x;if(f&&(x=await g.data.organizations.get(t.tenant.id,f),!x))return y("Organization not found");const I=l;let $=d||"",N=[],T;if(I)try{const ne=await fd(e,{tenantId:t.tenant.id,clientId:t.client_id,audience:I,requestedScopes:d?.split(" ")||[],organizationId:x?.id,userId:k.user_id});$=ne.scopes.join(" "),N=ne.permissions,T=t.app_type==="spa"&&ne.token_lifetime_for_web?ne.token_lifetime_for_web:ne.token_lifetime}catch(ne){if(ne?.statusCode===403||ne?.status===403){const ie=ne?.body?.error_description||ne?.message||"Access denied";return y(ie)}throw ne}else if(x&&!(await g.data.userOrganizations.list(t.tenant.id,{q:`user_id:${k.user_id}`,per_page:1e3})).userOrganizations.some(xe=>xe.organization_id===x.id))return y("User is not a member of the specified organization");let P;n.login_session_id&&(P=(await g.data.loginSessions.get(t.tenant.id,n.login_session_id))?.auth_connection);const O=P||k.connection,j=await g.data.loginSessions.create(t.tenant.id,{csrf_token:Le(),authParams:{client_id:t.client_id,audience:l,scope:d,state:r,nonce:o,response_type:u,redirect_uri:i,organization:f,max_age:h},expires_at:new Date(Date.now()+300*1e3).toISOString(),session_id:n.id,...O?{auth_connection:O}:{},ip:e.var.ip,useragent:e.var.useragent}),F=h!==void 0?Math.floor(new Date(n.authenticated_at).getTime()/1e3):void 0,L={client:t,authParams:{client_id:t.client_id,audience:l,code_challenge_method:a,code_challenge:c,scope:$,state:r,nonce:o,response_type:u,redirect_uri:i,max_age:h},user:k,session_id:n.id,auth_time:F,permissions:N,organization:x,token_lifetime:T},M=u.split(" "),H=M.includes("code"),W=M.includes("id_token"),te=M.includes("token"),Q=H&&(W||te);let ee;if(u===xn.CODE)ee=await Gf(e,{user:k,client:t,authParams:L.authParams,login_id:j.id});else if(Q){const ne=await Gf(e,{user:k,client:t,authParams:L.authParams,login_id:j.id});ee={...await Qa(e,{...L,code:ne.code}),code:ne.code,state:ne.state}}else ee=await Qa(e,L);const K=t.tenant.idle_session_lifetime?new Date(Date.now()+t.tenant.idle_session_lifetime*60*60*1e3).toISOString():void 0;await g.data.sessions.update(t.tenant.id,n.id,{used_at:new Date().toISOString(),last_interaction_at:new Date().toISOString(),login_session_id:j.id,device:{...n.device,last_ip:e.var.ip||"",last_user_agent:e.var.useragent||""},idle_expires_at:K}),K&&await g.data.loginSessions.update(t.tenant.id,j.id,{expires_at:K}),B(e,t.tenant.id,{type:R.SUCCESS_SILENT_AUTH,description:"Successful silent authentication"});const ke=new Headers;if(Iv(t.tenant.id,n.id,e.var.host).forEach(ne=>{ke.append("set-cookie",ne)}),w)return tw(e,_,JSON.stringify({...ee,state:r}),ke);const se={},Ee=ee.code,We=ee.access_token,Je=ee.id_token;if(H&&typeof Ee=="string"&&(se.code=Ee),typeof We=="string"&&(te&&(se.access_token=We,typeof ee.token_type=="string"&&(se.token_type=ee.token_type),typeof ee.expires_in=="number"&&(se.expires_in=String(ee.expires_in))),W&&typeof Je=="string"&&(se.id_token=Je)),r&&(se.state=r),(te||W)&&d&&(se.scope=d),p===mt.FORM_POST)return Mf(i,se,ke);const Ze=new URL(i);if(w3(u,p))Ze.hash=new URLSearchParams(se).toString();else for(const[ne,ie]of Object.entries(se))Ze.searchParams.set(ne,ie);const Ue={Location:Ze.toString()},J=ke.get("set-cookie");return J&&(Ue["set-cookie"]=J),new Response(null,{status:302,headers:Ue})}const TZ=1024;function $Z(e,t){const n=e.split(":")[0]?.split(".")??[],i=t.split(":")[0]?.split(".")??[];if(n.length<2||i.length<2)return!1;const r=n.slice(-2).join("."),o=i.slice(-2).join(".");return r===o}async function IZ(e,t,n){return await e.env.data.customDomains.getByDomain(t)?!0:$Z(t,n)}async function zZ(e,t){const n=await e.env.data.loginSessions.get(e.var.tenant_id||"",t);if(!n)throw new V(403,{message:"State not found"});const i=n.authorization_url;if(i&&i.length<=TZ){let c=null;try{c=new URL(i)}catch{c=null}const l=e.var.host||"";if(c&&c.host&&c.host!==l&&await IZ(e,c.host,l)){const u=new URL("/authorize/resume",c.origin);return u.searchParams.set("state",t),new Response(null,{status:302,headers:{location:u.toString()}})}}const r=await nt(e.env,n.authParams.client_id);on(e,r.tenant.id),e.set("client_id",r.client_id);const o=n.state||ve.PENDING;if(o===ve.PENDING)throw new V(400,{error:"invalid_request",error_description:"Login session is not yet authenticated"});if(o===ve.COMPLETED)throw new V(409,{error:"invalid_request",error_description:"Login session has already been completed"});if(o===ve.FAILED)throw new V(400,{error:"access_denied",error_description:`Login session failed: ${n.failure_reason||"unknown reason"}`});if(o===ve.EXPIRED)throw new V(400,{error:"invalid_request",error_description:"Login session has expired"});if(!n.user_id)throw new V(500,{message:"Authenticated login session has no user_id"});const a=await e.env.data.users.get(r.tenant.id,n.user_id);if(!a)throw new V(500,{message:"Authenticated user not found"});return e.set("user_id",a.user_id),n.auth_connection&&e.set("connection",n.auth_connection),ot(e,{authParams:n.authParams,client:r,user:a,loginSession:n,authStrategy:n.auth_strategy,authConnection:n.auth_connection})}const PZ=new Set(["RS256","RS384","RS512","ES256","ES384","ES512"]),NZ=new Set(["HS256","HS384","HS512"]),jZ={HS256:"SHA-256",HS384:"SHA-384",HS512:"SHA-512"},OZ={name:"RSASSA-PKCS1-v1_5"},FZ={ES256:"SHA-256",ES384:"SHA-384",ES512:"SHA-512"};class jt extends Error{constructor(t,n){super(n),this.code=t,this.name="RequestObjectVerificationError"}code}function b3(e){const t=new TextDecoder().decode(Lt.decode(e,{strict:!1})),n=JSON.parse(t);if(typeof n!="object"||n===null)throw new jt("invalid_request_object","JOSE segment is not an object");return n}async function RZ(e,t,n){const i=e.split(".");if(i.length!==3)throw new jt("invalid_request_object","request object is not a 3-part JWS");const[r,o,a]=i;let c,l;try{c=b3(r),l=b3(o)}catch(p){throw p instanceof jt?p:new jt("invalid_request_object","failed to decode JOSE segments")}if(!c.alg)throw new jt("invalid_request_object","missing alg");if(c.alg==="none")throw new jt("unsupported_alg","unsigned request objects (alg=none) are not accepted");const d=new Uint8Array(new TextEncoder().encode(`${r}.${o}`)),u=new Uint8Array(Lt.decode(a,{strict:!1}));if(NZ.has(c.alg)){if(!t.client_secret)throw new jt("missing_keys","client has no client_secret for HMAC verification");const p=await crypto.subtle.importKey("raw",new Uint8Array(new TextEncoder().encode(t.client_secret)),{name:"HMAC",hash:jZ[c.alg]},!1,["verify"]);if(!await crypto.subtle.verify("HMAC",p,u,d))throw new jt("signature_invalid","HMAC signature did not verify")}else if(PZ.has(c.alg)){const p=c.alg,f=await e8(t,{fetch:n.fetch});if(f.length===0)throw new jt("missing_keys","client has no jwks/jwks_uri registered");const h=c.kid?f.filter(_=>_.kid===c.kid):f.filter(_=>v3(_,p));if(h.length===0)throw new jt("missing_keys",c.kid?`no JWK found with kid=${c.kid}`:`no JWK found for alg=${p}`);let g=!1,m=!1;for(const _ of h){if(!v3(_,p))continue;let w;try{const b=Ev(_,p);w=await crypto.subtle.importKey("jwk",_,b,!1,["verify"])}catch{continue}const y=_.kty==="EC"?{name:"ECDSA",hash:FZ[p]}:OZ;try{if(m=!0,await crypto.subtle.verify(y,w,u,d)){g=!0;break}}catch{continue}}if(!g)throw new jt(m?"signature_invalid":"missing_keys",m?`asymmetric signature did not verify (kid=${c.kid??"(none)"}, alg=${p})`:`no JWK compatible with alg=${p} (kid=${c.kid??"(none)"})`)}else throw new jt("unsupported_alg",`alg ${c.alg} is not supported`);return DZ(l,t,n),l}function v3(e,t){return!(e.alg&&e.alg!==t||t.startsWith("ES")&&e.kty!=="EC"||t.startsWith("RS")&&e.kty!=="RSA")}function DZ(e,t,n){const i=n.leewaySeconds??30,r=Math.floor((n.now?n.now():Date.now())/1e3);if(typeof e.exp!="number")throw new jt("claim_invalid","request object missing exp");if(e.exp+i<r)throw new jt("claim_invalid","request object is expired");if(typeof e.nbf=="number"&&e.nbf-i>r)throw new jt("claim_invalid","request object not yet valid");if(e.iss!==void 0&&e.iss!==t.client_id)throw new jt("claim_invalid",`iss mismatch: expected client_id ${t.client_id}, got ${String(e.iss)}`);if(e.aud!==void 0&&n.issuer){const o=e.aud;if(!(o===n.issuer||Array.isArray(o)&&o.some(c=>c===n.issuer)))throw new jt("claim_invalid",`aud claim does not match issuer ${n.issuer}`)}}const BZ=[Z.EMAIL,Z.SMS,Z.USERNAME_PASSWORD],A3=["code","id_token","token"];function LZ(e){const t=e.split(/\s+/).filter(Boolean);return t.length<=1?e:[...t].sort((n,i)=>A3.indexOf(n)-A3.indexOf(i)).join(" ")}const k3=s.z.object({client_id:s.z.string().optional(),vendor_id:s.z.string().optional(),redirect_uri:s.z.string().optional(),scope:s.z.string().optional(),state:s.z.string().optional(),prompt:s.z.string().optional(),response_mode:s.z.nativeEnum(mt).optional(),response_type:s.z.preprocess(e=>typeof e=="string"?LZ(e):e,s.z.nativeEnum(xn).optional()),audience:s.z.string().optional(),connection:s.z.string().optional(),nonce:s.z.string().optional(),max_age:s.z.string().optional(),acr_values:s.z.string().optional(),login_ticket:s.z.string().optional(),code_challenge_method:s.z.nativeEnum(bh).optional(),code_challenge:s.z.string().optional(),realm:s.z.string().optional(),auth0Client:s.z.string().optional(),organization:s.z.string().optional(),login_hint:s.z.string().optional(),screen_hint:s.z.string().optional(),ui_locales:s.z.string().optional(),claims:s.z.union([s.z.string(),s.z.record(s.z.any())]).optional()});function MZ(e){if(e==null)return;let t;if(typeof e=="string"){if(!e)return;try{t=JSON.parse(e)}catch{throw new z(400,{message:"invalid claims parameter: not valid JSON"})}}else t=e;const n=Zw.safeParse(t);if(!n.success)throw new z(400,{message:"invalid claims parameter: must be an object with optional `userinfo` and `id_token` members"});const i={};return n.data.userinfo&&Object.keys(n.data.userinfo).length>0&&(i.userinfo=n.data.userinfo),n.data.id_token&&Object.keys(n.data.id_token).length>0&&(i.id_token=n.data.id_token),i.userinfo||i.id_token?i:void 0}const UZ=new Set(["application/oauth-authz-req+jwt","application/jwt"]);async function qZ(e,t){const{status:n,body:i,contentType:r}=await X6(e,t);if(n!==200)throw new z(400,{message:`request_uri returned status ${n}`});const o=(r??"").split(";")[0]?.trim().toLowerCase()??"";if(!UZ.has(o))throw new z(400,{message:`request_uri returned unsupported content-type: ${o||"(missing)"}`});const a=i.trim();if(!a||a.split(".").length!==3)throw new z(400,{message:"request_uri did not return a JWT"});return a}const HZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["oauth"],method:"get",path:"/",request:{query:k3.extend({client_id:s.z.string(),screen_hint:s.z.string().openapi({example:"signup",description:'Optional hint for the screen to show, like "signup" or "login".'}).optional(),request:s.z.string().openapi({description:"JWT containing authorization request parameters (OpenID Connect Core Section 6.1). MUST be signed; alg=none is rejected."}).optional(),request_uri:s.z.string().url().openapi({description:"URL referencing a Request Object JWT (OpenID Connect Core Section 6.2). The URL is fetched with SSRF protection."}).optional()}).passthrough()},responses:{200:{description:"Successful authorization response. This can be an HTML page (e.g., for silent authentication iframe or universal login page) or a JSON object containing tokens (e.g., for response_mode=web_message).",content:{"text/html":{schema:s.z.string().openapi({example:"<html>...</html>"})},"application/json":{schema:db}}},302:{description:"Redirect to the client's redirect URI, an authentication page, or an external identity provider.",headers:s.z.object({Location:s.z.string().url()})},400:{description:"Bad Request. Invalid parameters or other client-side errors.",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}},403:{description:"Forbidden. The request is not allowed (e.g., invalid origin).",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}}}}),async e=>{const{env:t}=e,n=e.req.valid("query");if(n.request&&n.request_uri)throw new z(400,{message:"request and request_uri are mutually exclusive"});const i={allowPrivateHosts:t.ALLOW_PRIVATE_OUTBOUND_FETCH===!0,allowedSchemes:t.ALLOW_PRIVATE_OUTBOUND_FETCH?["http:","https:"]:["https:"]};let r=n.request;if(n.request_uri)try{r=await qZ(n.request_uri,i)}catch(Q){throw Q instanceof Fo?new z(400,{message:`request_uri rejected: ${Q.message}`}):Q}let o={},a;if(r){if(!n.client_id)throw new z(400,{message:"client_id is required to verify a request object"});a=await nt(t,n.client_id);try{const Q=await RZ(r,a,{issuer:Bn(t,e.var.custom_domain),fetch:i}),ee=k3.safeParse(Q);if(!ee.success)throw new z(400,{message:`invalid request object: ${ee.error.issues.map(K=>`${K.path.join(".")}: ${K.message}`).join("; ")}`});o=ee.data}catch(Q){throw Q instanceof jt?new z(400,{message:`invalid request object (${Q.code}): ${Q.message}`}):Q}}for(const Q of Object.keys(o)){const ee=o[Q],K=n[Q];if(ee!==void 0&&K!==void 0&&ee!==K)throw new z(400,{message:`request object and query parameter "${Q}" disagree`})}let{redirect_uri:c,scope:l,audience:d,nonce:u,response_type:p,response_mode:f,code_challenge:h,code_challenge_method:g,prompt:m,max_age:_,acr_values:w,login_hint:y,ui_locales:b,organization:A,claims:v}={...n,...o};const{client_id:k,vendor_id:x,state:I,connection:$,login_ticket:N,realm:T,screen_hint:P}={...n,...o};e.set("log","authorize");let O=MZ(v);const j=a&&a.client_id===k?a:await nt(t,k);if(e.set("client_id",j.client_id),on(e,j.tenant.id),I){const Q=await t.data.loginSessions.get(j.tenant.id,I);if(Q&&Q.state!==ve.COMPLETED&&Q.state!==ve.FAILED&&Q.state!==ve.EXPIRED){const ee=Q.authParams;c=c??ee.redirect_uri,l=l??ee.scope,d=d??ee.audience,u=u??ee.nonce,p=p??ee.response_type,f=f??ee.response_mode,h=h??ee.code_challenge,g=g??ee.code_challenge_method,m=m??ee.prompt,_=_??ee.max_age?.toString(),w=w??ee.acr_values,y=y??ee.username,b=b??ee.ui_locales,A=A??ee.organization,!O&&ee.claims&&(O=ee.claims)}}let F=c;typeof c=="string"&&(F=c.split("#")[0]);const L=e.req.header("origin");if(L&&!D8(L,j.web_origins||[]))throw new z(403,{message:`Origin ${L} not allowed`});if(!p){const Q=!!F&&nh(F,j.callbacks||[],{allowPathWildcards:!0,allowSubDomainWildcards:!0});if(F&&Q){const ee={error:"invalid_request",error_description:"Missing required parameter: response_type"};if(I&&(ee.state=I),f===mt.FORM_POST)return Mf(F,ee,new Headers);const K=new URL(F);for(const[ke,ge]of Object.entries(ee))K.searchParams.set(ke,ge);return e.redirect(K.toString())}throw new z(400,{message:"Missing required parameter: response_type"})}const M={redirect_uri:F,scope:l,state:I,client_id:k,vendor_id:x,audience:d??j.tenant.default_audience,nonce:u,prompt:m,response_type:p,response_mode:f,code_challenge:h,code_challenge_method:g,username:y,ui_locales:b,organization:A,max_age:_?parseInt(_,10):void 0,acr_values:w,claims:O};if(M.redirect_uri){const Q=j.callbacks||[];if(e.var.host&&(Q.push(`${Bn(e.env,e.var.custom_domain)}/*`),Q.push(`${Fn(e.env,e.var.custom_domain)}/*`)),!nh(M.redirect_uri,Q,{allowPathWildcards:!0,allowSubDomainWildcards:!0}))throw new z(400,{message:`Invalid redirect URI - ${M.redirect_uri}`})}let H;const W=mM(j.tenant.id,e.req.header("cookie"));for(const Q of W){const ee=await t.data.sessions.get(j.tenant.id,Q);if(ee&&!ee.revoked_at){H=ee;break}}if(j.sso_disabled&&(H=void 0),m=="none"){if(!F||!I||!p)throw new z(400,{message:"Missing required parameters for silent auth: redirect_uri, state, and response_type"});return CZ({ctx:e,session:H||void 0,redirect_uri:F,state:I,response_type:p,response_mode:f,client:j,nonce:u,code_challenge_method:g,code_challenge:h,audience:M.audience,scope:l,organization:A,max_age:_?parseInt(_,10):void 0})}if(j.connections.length===1&&j.connections[0]&&!BZ.includes(j.connections[0].strategy||""))return th(e,j,j.connections[0].name,M);if($&&$!==Z.EMAIL)return th(e,j,$,M);if(N){const Q=await xZ(e,j.tenant.id,N,M,T);return Q instanceof Response?Q:e.json(Q)}const te=await SZ({ctx:e,client:j,authParams:M,session:H||void 0,connection:$,login_hint:y,screen_hint:P});return te instanceof Response?te:e.json(te)}).openapi(s.createRoute({tags:["oauth"],method:"get",path:"/resume",request:{query:s.z.object({state:s.z.string()})},responses:{302:{description:"Redirect to the client's redirect_uri (with cookie set), to a MFA/continuation UL screen, or to the original authorization host when the browser is on the wrong custom domain.",headers:s.z.object({Location:s.z.string().url()})},400:{description:"Login session is in PENDING, FAILED, or EXPIRED state.",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}},403:{description:"Login session not found.",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}},409:{description:"Login session has already been completed (replay).",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}}}}),async e=>{const{state:t}=e.req.valid("query");return zZ(e,t)}),VZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["oauth"],method:"get",path:"/",request:{query:s.z.object({client_id:s.z.string(),redirect_url:s.z.string().optional(),login_hint:s.z.string().toLowerCase().optional(),screen_hint:s.z.enum(["account","change-email","change-phone","change-password"]).optional().default("account")})},responses:{302:{description:"Redirect to the account page with login session state or login page",headers:s.z.object({Location:s.z.string().url()})},400:{description:"Bad Request. Invalid parameters or other client-side errors.",content:{"application/json":{schema:s.z.object({message:s.z.string()})}}}}}),async e=>{const{env:t}=e,{client_id:n,redirect_url:i,login_hint:r,screen_hint:o}=e.req.valid("query");e.set("log","account");const a=await nt(t,n);e.set("client_id",a.client_id),on(e,a.tenant.id);const c={redirect_uri:i||e.req.url,client_id:n,username:r},l=e.req.header("origin");if(l&&!D8(l,a.web_origins||[]))throw new z(403,{message:`Origin ${l} not allowed`});if(c.redirect_uri){const y=a.callbacks||[];if(e.var.host&&(y.push(`${Bn(e.env,e.var.custom_domain)}/*`),y.push(`${Fn(e.env,e.var.custom_domain)}/*`)),!nh(c.redirect_uri,y,{allowPathWildcards:!0,allowSubDomainWildcards:!0}))throw new z(400,{message:`Invalid redirect URI - ${c.redirect_uri}`})}const d=xr(a.tenant.id,e.req.header("cookie")),u=d?await t.data.sessions.get(a.tenant.id,d):void 0;let p=u&&!u.revoked_at?u:void 0;a.sso_disabled&&(p=void 0);const f=new URL(e.req.url);e.var.custom_domain&&(f.hostname=e.var.custom_domain);const{ip:h,auth0_client:g,useragent:m}=e.var,_=Ri(g),w=await t.data.loginSessions.create(a.tenant.id,{expires_at:new Date(Date.now()+no*1e3).toISOString(),authParams:c,csrf_token:Le(),authorization_url:f.toString(),ip:h,useragent:m,auth0Client:_});if(p){if(r&&(await t.data.users.get(a.tenant.id,p.user_id))?.email!==r)return e.redirect(`${Fn(e.env,e.var.custom_domain)}login/identifier?state=${encodeURIComponent(w.id)}`);if(await t.data.loginSessions.update(a.tenant.id,w.id,{session_id:p.id}),o==="change-email"){const b=new URL("/u2/account/profile",e.req.url);return b.searchParams.set("state",w.id),e.redirect(b.toString())}const y=new URL("/u2/account",e.req.url);return y.searchParams.set("state",w.id),e.redirect(y.toString())}return e.redirect(`${Fn(e.env,e.var.custom_domain)}login/identifier?state=${encodeURIComponent(w.id)}`)});function xw(e,t){if(e===t)return!0;if(e==null||t==null||typeof e!=typeof t)return!1;if(Array.isArray(e)&&Array.isArray(t)){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(!xw(e[n],t[n]))return!1;return!0}if(qp(e)&&qp(t)){const n=Object.keys(e),i=Object.keys(t);if(n.length!==i.length)return!1;for(const r of n)if(!xw(e[r],t[r]))return!1;return!0}return!1}function S3(e,t){const n={...t};if(!e)return{ok:!0,filled:n};for(const[i,r]of Object.entries(e)){const o=t[i];if(o===void 0){n[i]=r;continue}if(!xw(o,r))return{ok:!1,violation:{field:i,expected:r,got:o},filled:n}}return{ok:!0,filled:n}}const Zm=s.z.object({redirect_uris:s.z.array(s.z.string()).optional(),client_name:s.z.string().min(1).optional(),client_uri:s.z.string().url().optional(),logo_uri:s.z.string().url().optional(),tos_uri:s.z.string().url().optional(),policy_uri:s.z.string().url().optional(),contacts:s.z.array(s.z.string()).optional(),scope:s.z.string().optional(),grant_types:s.z.array(s.z.string()).optional(),response_types:s.z.array(s.z.string()).optional(),token_endpoint_auth_method:s.z.enum(["none","client_secret_basic","client_secret_post","client_secret_jwt","private_key_jwt"]).optional(),jwks_uri:s.z.string().url().optional(),jwks:s.z.record(s.z.unknown()).optional(),software_id:s.z.string().optional(),software_version:s.z.string().optional(),client_id:s.z.string().optional(),client_secret:s.z.string().optional(),audience:s.z.string().optional()}),Xm=s.z.object({client_id:s.z.string(),client_secret:s.z.string().optional(),client_id_issued_at:s.z.number().optional(),client_secret_expires_at:s.z.number().optional(),registration_access_token:s.z.string().optional(),registration_client_uri:s.z.string(),client_name:s.z.string().optional(),redirect_uris:s.z.array(s.z.string()).optional(),grant_types:s.z.array(s.z.string()).optional(),response_types:s.z.array(s.z.string()).optional(),token_endpoint_auth_method:s.z.string().optional(),logo_uri:s.z.string().optional(),client_uri:s.z.string().optional(),tos_uri:s.z.string().optional(),policy_uri:s.z.string().optional(),contacts:s.z.array(s.z.string()).optional(),scope:s.z.string().optional(),jwks_uri:s.z.string().optional(),software_id:s.z.string().optional(),software_version:s.z.string().optional()}),KZ=new Set(["redirect_uris","client_name","client_uri","logo_uri","tos_uri","policy_uri","contacts","scope","grant_types","response_types","token_endpoint_auth_method","jwks_uri","jwks","software_id","software_version","client_id","client_secret","domain","integration_type","audience"]);function GZ(e){const t=[];for(const n of["client_uri","tos_uri","policy_uri","jwks_uri","software_id","software_version"]){const i=e[n];typeof i=="string"&&i.length>0&&t.push([n,i])}return e.contacts&&Array.isArray(e.contacts)&&e.contacts.length>0&&t.push(["contacts",e.contacts.join(",")]),e.scope&&typeof e.scope=="string"&&t.push(["scope",e.scope]),t.length>0?Object.fromEntries(t):void 0}function E3(e){const t={};e.client_name!==void 0&&(t.name=e.client_name),e.redirect_uris!==void 0&&(t.callbacks=e.redirect_uris),e.grant_types!==void 0&&(t.grant_types=e.grant_types),e.token_endpoint_auth_method!==void 0&&(t.token_endpoint_auth_method=e.token_endpoint_auth_method),e.logo_uri!==void 0&&(t.logo_uri=e.logo_uri);const n=GZ(e);n&&(t.client_metadata=n);const i={};for(const[r,o]of Object.entries(e))KZ.has(r)||(i[r]=o);return e.jwks!==void 0&&(i.jwks=e.jwks),e.response_types!==void 0&&(i.response_types=e.response_types),{clientFields:t,extraMetadata:i}}function vo(e,t){const n=e[t];return n&&n.length>0?n:void 0}function e0(e,t){const n=e.client_metadata??{},i=n.contacts,r=i&&i.length>0?i.split(","):void 0,a=(e.registration_metadata??{}).response_types,c=Array.isArray(a)&&a.every(d=>typeof d=="string")?a:void 0;return{client_id:e.client_id,client_name:e.name,client_id_issued_at:Math.floor(new Date(e.created_at).getTime()/1e3),client_secret_expires_at:0,registration_client_uri:t.registration_client_uri,client_secret:t.include_client_secret&&t.client_secret?t.client_secret:void 0,registration_access_token:t.registration_access_token,redirect_uris:e.callbacks&&e.callbacks.length>0?e.callbacks:void 0,grant_types:e.grant_types&&e.grant_types.length>0?e.grant_types:void 0,response_types:c,token_endpoint_auth_method:e.token_endpoint_auth_method,logo_uri:e.logo_uri,client_uri:vo(n,"client_uri"),tos_uri:vo(n,"tos_uri"),policy_uri:vo(n,"policy_uri"),jwks_uri:vo(n,"jwks_uri"),software_id:vo(n,"software_id"),software_version:vo(n,"software_version"),scope:vo(n,"scope"),contacts:r}}function WZ(e){if(!e)return;const t=e.iat_constraints;return qp(t)?t:void 0}function x3(e){if(e)for(const t of e)try{const n=new URL(t);if(!n.protocol||!n.host)throw new V(400,{error:"invalid_redirect_uri",error_description:`Invalid redirect_uri: ${t}`})}catch{throw new V(400,{error:"invalid_redirect_uri",error_description:`Invalid redirect_uri: ${t}`})}}function C3(e,t){if(!(!e||!t||t.length===0)){for(const n of e)if(!t.includes(n))throw new V(400,{error:"invalid_client_metadata",error_description:`grant_type "${n}" is not allowed for this tenant`})}}async function JZ(e,t,n){if(!t){if(n)throw new V(400,{error:"invalid_client_metadata",error_description:"scope requires audience"});return null}const{resource_servers:i}=await e.env.data.resourceServers.list(e.var.tenant_id),r=i.find(a=>a.identifier===t);if(!r)throw new V(400,{error:"invalid_client_metadata",error_description:`Unknown audience: ${t}`});const o=n?n.split(/\s+/).filter(Boolean):[];if(o.length>0){const a=new Set((r.scopes??[]).map(l=>l.value)),c=o.filter(l=>!a.has(l));if(c.length>0)throw new V(400,{error:"invalid_scope",error_description:`Scope(s) not defined on the resource server: ${c.join(", ")}`})}return{audience:t,scopes:o}}const YZ=new s.OpenAPIHono().openapi(s.createRoute({tags:["oidc-register"],method:"post",path:"/",request:{body:{content:{"application/json":{schema:Zm}}}},responses:{201:{content:{"application/json":{schema:Xm}},description:"Client registered"}}}),async e=>{const t=await Du(e);Bu(t);const n=await hH(e,t),i=e.req.valid("json"),r=S3(n?.constraints,i);if(!r.ok)throw new V(400,{error:"invalid_client_metadata",error_description:`Field "${r.violation?.field}" conflicts with Initial Access Token constraint`});const o=Zm.safeParse(r.filled);if(!o.success)throw new V(400,{error:"invalid_client_metadata",error_description:"Merged request (with IAT constraints applied) is not valid RFC 7591 metadata"});const a=o.data;if(a.grant_types?.some(y=>y==="authorization_code"||y==="implicit")&&(!a.redirect_uris||a.redirect_uris.length===0))throw new V(400,{error:"invalid_redirect_uri",error_description:"redirect_uris is required for authorization_code and implicit grant types"});x3(a.redirect_uris),C3(a.grant_types,t.flags?.dcr_allowed_grant_types);const c=await JZ(e,a.audience,a.scope),{clientFields:l,extraMetadata:d}=E3(a),u=gH(),p=mH(),f=await $6(),h={...d};delete h.iat_constraints,n?.constraints&&(h.iat_constraints=n.constraints);const g={client_id:u,name:l.name??`Client ${u.slice(0,8)}`,client_secret:p,callbacks:l.callbacks??[],grant_types:l.grant_types??["authorization_code"],token_endpoint_auth_method:l.token_endpoint_auth_method??"client_secret_basic",logo_uri:l.logo_uri,client_metadata:l.client_metadata,owner_user_id:n?.sub,registration_type:n?"iat_dcr":"open_dcr",registration_metadata:h};let m;if(await e.env.data.transaction(async y=>{const b=Xa(y);if(n&&!await b.markUsed(e.var.tenant_id,n.id,new Date().toISOString()))throw new V(401,{error:"invalid_token",error_description:"Initial access token already used"});m=await y.clients.create(e.var.tenant_id,g),c&&await y.clientGrants.create(e.var.tenant_id,{client_id:u,audience:c.audience,scope:c.scopes}),await b.create(e.var.tenant_id,{id:f.id,token_hash:f.token_hash,type:"rat",client_id:u,single_use:!1})}),!m)throw new V(500,{error:"server_error",error_description:"Failed to create client"});const _=Rm(e,u),w=e0(m,{client_secret:p,registration_access_token:f.token,registration_client_uri:_,include_client_secret:!0});return await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"Dynamic Client Registration",targetType:"client",targetId:u}),e.json(w,{status:201})}).openapi(s.createRoute({tags:["oidc-register"],method:"get",path:"/{client_id}",request:{params:s.z.object({client_id:s.z.string()})},responses:{200:{content:{"application/json":{schema:Xm}},description:"Client configuration"}}}),async e=>{const t=await Du(e);Bu(t);const{client_id:n}=e.req.valid("param");await Dm(e,n);const i=await e.env.data.clients.get(e.var.tenant_id,n);if(!i||Bm(i))throw new V(401,{error:"invalid_token",error_description:"Client not found"});const r=e0(i,{registration_client_uri:Rm(e,n),include_client_secret:!1});return e.json(r)}).openapi(s.createRoute({tags:["oidc-register"],method:"put",path:"/{client_id}",request:{params:s.z.object({client_id:s.z.string()}),body:{content:{"application/json":{schema:Zm}}}},responses:{200:{content:{"application/json":{schema:Xm}},description:"Updated client configuration"}}}),async e=>{const t=await Du(e);Bu(t);const{client_id:n}=e.req.valid("param");await Dm(e,n);const i=await e.env.data.clients.get(e.var.tenant_id,n);if(!i||Bm(i))throw new V(401,{error:"invalid_token",error_description:"Client not found"});const r=e.req.valid("json");if(r.client_id!==void 0&&r.client_id!==n)throw new V(400,{error:"invalid_client_metadata",error_description:"client_id in body does not match URL"});const o=WZ(i.registration_metadata);if(o){const h=S3(o,r);if(!h.ok)throw new V(400,{error:"invalid_client_metadata",error_description:`Field "${h.violation?.field}" was bound at registration time and cannot be changed`})}x3(r.redirect_uris),C3(r.grant_types,t.flags?.dcr_allowed_grant_types);const{clientFields:a,extraMetadata:c}=E3(r),l={...c};o&&(l.iat_constraints=o);const d={name:a.name??`Client ${n.slice(0,8)}`,callbacks:a.callbacks??[],grant_types:a.grant_types??["authorization_code"],token_endpoint_auth_method:a.token_endpoint_auth_method??"client_secret_basic",logo_uri:a.logo_uri,client_metadata:a.client_metadata??{},registration_metadata:l};if(!await e.env.data.clients.update(e.var.tenant_id,n,d))throw new V(500,{error:"server_error",error_description:"Failed to update client"});const p=await e.env.data.clients.get(e.var.tenant_id,n);if(!p)throw new V(500,{error:"server_error",error_description:"Failed to read back updated client"});await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"RFC 7592 Client Update",targetType:"client",targetId:n});const f=e0(p,{registration_client_uri:Rm(e,n),include_client_secret:!1});return e.json(f)}).openapi(s.createRoute({tags:["oidc-register"],method:"delete",path:"/{client_id}",request:{params:s.z.object({client_id:s.z.string()})},responses:{204:{description:"Client deleted"}}}),async e=>{const t=await Du(e);Bu(t);const{client_id:n}=e.req.valid("param");await Dm(e,n);const i=await e.env.data.clients.get(e.var.tenant_id,n);if(!i||Bm(i))throw new V(401,{error:"invalid_token",error_description:"Client not found"});const r={...i.client_metadata??{},status:"deleted"},o=await e.env.data.clientGrants.list(e.var.tenant_id,{q:`client_id:"${n}"`});return await e.env.data.transaction(async a=>{await a.clients.update(e.var.tenant_id,n,{client_metadata:r});for(const c of o.client_grants)c.id&&await a.clientGrants.remove(e.var.tenant_id,c.id);await Xa(a).revokeByClient(e.var.tenant_id,n,new Date().toISOString())}),await B(e,e.var.tenant_id,{type:R.SUCCESS_API_OPERATION,description:"RFC 7592 Client Delete",targetType:"client",targetId:n}),e.body(null,204)}),QZ=new Set(["localhost","127.0.0.1","[::1]"]);function T3(e,t=[]){let n;try{n=new URL(e)}catch{return{ok:!1,reason:"not a valid URL"}}if(n.protocol!=="http:"&&n.protocol!=="https:")return{ok:!1,reason:"scheme must be http or https"};const i=n.hostname.replace(/\.$/,"");if(!i)return{ok:!1,reason:"missing host"};if(i==="0.0.0.0"||i==="[::]")return{ok:!1,reason:"unspecified address is not a valid origin"};const r=n.port?`:${n.port}`:"",o=`${n.protocol}//${i}${r}`;return n.protocol==="https:"?{ok:!0,origin:o,isLoopback:!1,isAllowlisted:!1,isHttp:!1}:QZ.has(i)?{ok:!0,origin:o,isLoopback:!0,isAllowlisted:!1,isHttp:!0}:t.map(c=>c.toLowerCase()).includes(o)?{ok:!0,origin:o,isLoopback:!1,isAllowlisted:!0,isHttp:!0}:{ok:!1,reason:"http origin requires loopback or tenant allowlist"}}const ZZ=1800,XZ=s.z.object({integration_type:s.z.string().min(1).optional().openapi({description:"Optional caller-defined integration label. Surfaced on the consent screen and stored on the resulting client's IAT constraints. No validation beyond non-empty string."}),domain:s.z.string().min(1).openapi({description:"The domain that will host the integration (origin must match return_to)"}),return_to:s.z.string().url().openapi({description:"Where the browser is redirected after consent (success or cancel)"}),state:s.z.string().min(1).openapi({description:"Caller-supplied CSRF token round-tripped on the redirect"}),scope:s.z.string().optional().openapi({description:"Optional space-separated scope list pre-bound to the IAT"}),audience:s.z.string().optional().openapi({description:"Optional API identifier the registered client should be granted access to. When set, the resulting client receives a `client_grants` row binding (client_id, audience, scope[]) so it can mint access tokens for that API via client_credentials."})}),eX=new s.OpenAPIHono().openapi(s.createRoute({tags:["connect"],method:"get",path:"/",request:{query:XZ},responses:{302:{description:"Redirect to /u2/connect/start with a fresh login_session id",headers:s.z.object({Location:s.z.string()})},400:{description:"Invalid request",content:{"application/json":{schema:s.z.object({})}}},404:{description:"DCR / consent flow not enabled for this tenant",content:{"application/json":{schema:s.z.object({})}}}}}),async e=>{const t=e.var.tenant_id,n=await e.env.data.tenants.get(t);if(!n)throw new V(404,{error:"invalid_request",error_description:"Tenant not found"});if(!n.flags?.enable_dynamic_client_registration)throw new V(404,{error:"invalid_request",error_description:"Dynamic Client Registration is not enabled"});const{integration_type:i,domain:r,return_to:o,state:a,scope:c,audience:l}=e.req.valid("query");if(l){const{resource_servers:_}=await e.env.data.resourceServers.list(t),w=_.find(y=>y.identifier===l);if(!w)throw new V(400,{error:"invalid_request",error_description:`Unknown audience: ${l}`});if(c){const y=new Set((w.scopes??[]).map(v=>v.value)),A=c.split(/\s+/).filter(Boolean).filter(v=>!y.has(v));if(A.length>0)throw new V(400,{error:"invalid_scope",error_description:`Scope(s) not defined on the resource server: ${A.join(", ")}`})}}else if(c)throw new V(400,{error:"invalid_request",error_description:"scope requires audience"});const d=n.flags?.allow_http_return_to??[],u=/^https?:\/\//i.test(r)?r:`https://${r}`,p=T3(u,d);if(!p.ok)throw new V(400,{error:"invalid_request",error_description:`domain: ${p.reason}`});const f=T3(o,d);if(!f.ok)throw new V(400,{error:"invalid_request",error_description:`return_to: ${f.reason}`});if(f.origin!==p.origin)throw new V(400,{error:"invalid_request",error_description:"return_to origin must match domain"});let h=n.default_client_id?await e.env.data.clients.get(t,n.default_client_id):null;if(!h){const{clients:_}=await e.env.data.clients.list(t);h=_[0]??null}if(!h)throw new V(400,{error:"invalid_request",error_description:"No clients configured for this tenant"});const g=new Date(Date.now()+ZZ*1e3).toISOString(),m=await e.env.data.loginSessions.create(t,{expires_at:g,authParams:{client_id:h.client_id,state:a},csrf_token:Le(),ip:e.var.ip,useragent:e.var.useragent,state_data:JSON.stringify({connect:{integration_type:i,domain:r,return_to:o,scope:c,audience:l,caller_state:a,is_local_dev:f.isLoopback||f.isAllowlisted}})});return e.redirect(`/u2/connect/start?state=${encodeURIComponent(m.id)}`,302)});function tX(e){const t=new s.OpenAPIHono;t.use(xc(e)),t.use(du({getOutbox:()=>e.dataAdapter.outbox,getDestinations:r=>[new xs(e.dataAdapter.logs),new Ic(e.dataAdapter.hooks,k6({tenants:r.env.data.tenants,keys:r.env.data.keys,issuer:Bn(r.env,r.var.custom_domain)}),{webhookInvoker:r.env.webhookInvoker}),new zc(e.dataAdapter.users)]})),t.use(async(r,o)=>{const a=au(r,e.dataAdapter),c=e.dataAdapter.cache||$c({defaultTtlSeconds:0,maxEntries:100,cleanupIntervalMs:0}),l=e.dataAdapter.cache?300:0,d=lu(a,{defaultTtl:l,cacheEntities:["tenants","connections","clientConnections","customDomains","clients","branding","themes","promptSettings","forms","resourceServers","roles","organizations","userRoles","userPermissions","hooks","keys"],cache:c});return r.env.data=cu(r,d),o()});const n=F6({origin:r=>r||"",allowHeaders:["Tenant-Id","Content-Type","Auth0-Client","Upgrade-Insecure-Requests"],allowMethods:["POST"],maxAge:600});t.use("/oauth/token",n),t.use("/oauth/revoke",n),t.use(Tc).use(Cc).use(Ag(t));const i=t.route("/v2/logout",cV).route("/oidc/logout",uV).route("/userinfo",gV).route("/.well-known",mV).route("/oauth/token",uW).route("/oauth/revoke",pW).route("/dbconnections",gZ).route("/passwordless",mZ).route("/co/authenticate",AZ).route("/authorize",HZ).route("/account",VZ).route("/oidc/register",YZ).route("/connect/start",eX).route("/callback",oV).route("/login/callback",sV);return i.doc("/spec",{openapi:"3.0.0",info:{version:"1.0.0",title:"Oauth API"},security:[{oauth2:["openid","email","profile"]}]}),Sv(i),i}async function Ge(e,t,n=!1){const{env:i}=e,r=await i.data.loginSessions.get(e.var.tenant_id||"",t);if(!r)throw new z(400,{message:"Login session not found"});e.set("loginSession",r);const o=await nt(i,r.authParams.client_id);e.set("client_id",o.client_id),on(e,o.tenant.id);const a=o.tenant;if(r.session_id&&!n){if(!r.authParams.redirect_uri)throw new z(400,{message:"Login session closed and no redirect URI available"});const f=new URL(r.authParams.redirect_uri);throw f.searchParams.set("error","access_denied"),f.searchParams.set("error_description","Login session closed"),r.authParams.state&&f.searchParams.set("state",r.authParams.state),new Bt(f.toString(),302)}const[c,l]=await Promise.all([i.data.themes.get(a.id,"default"),i.data.branding.get(a.id)]),d=c??Kl,u=l?{...l,favicon_url:e.var.custom_domain?l.favicon_url:void 0}:null,p=r.authParams?.ui_locales?.split(" ")?.map(f=>f.split("-")[0])?.find(f=>{if(Array.isArray(U.options.supportedLngs))return U.options.supportedLngs.includes(f)});return await U.changeLanguage(p||"en"),{theme:d,branding:u,client:o,tenant:a,loginSession:r}}async function ys(e,t,n){const{theme:i,branding:r,client:o,tenant:a,loginSession:c}=await Ge(e,t,!0),l=xr(o.tenant.id,e.req.header("cookie")),d=l?await e.env.data.sessions.get(o.tenant.id,l):null;if(n?.continuationScope&&Qf(c,n.continuationScope)){if(!c.user_id)throw new Bt(`/u/login/identifier?state=${encodeURIComponent(t)}`);const h=await e.env.data.users.get(o.tenant.id,c.user_id);if(!h)throw new Bt(`/u/login/identifier?state=${encodeURIComponent(t)}`);const g=c.session_id?await e.env.data.sessions.get(o.tenant.id,c.session_id):null;return{theme:i,branding:r,client:o,user:h,tenant:a,loginSession:c,session:g,isContinuation:!0}}if(!d||d.revoked_at||!c.session_id)throw new Bt(`/u/login/identifier?state=${encodeURIComponent(t)}`);const p=await e.env.data.sessions.get(o.tenant.id,c.session_id),f=await e.env.data.users.get(o.tenant.id,d.user_id);if(!f||p?.user_id!==d.user_id)throw new Bt(`/u/login/identifier?state=${encodeURIComponent(t)}`);return{theme:i,branding:r,client:o,user:f,tenant:a,loginSession:c,session:p,isContinuation:!1}}const t0={[Z.USERNAME_PASSWORD]:"password",[Z.EMAIL]:"email",[Z.SMS]:"sms"};async function B8(e,t,n,i,r){if(i==="username"||r==="password")return"password";if(r==="code")return i==="sms"?"sms":"email";const a=(i==="email"?await uo({userAdapter:e.env.data.users,tenant_id:t.tenant.id,email:n}):i==="sms"?await fr({userAdapter:e.env.data.users,tenant_id:t.tenant.id,username:n,provider:"sms"}):await hr({env:e.env,tenant_id:t.tenant.id,username:n}))?.app_metadata?.strategy;if(a&&t0[a])return t0[a];const c=t.connections.map(d=>t0[d.strategy]).filter(d=>d!==void 0);return c.length===1&&c[0]?c[0]:(await e.env.data.promptSettings.get(t.tenant.id)).password_first&&c.includes("password")?"password":i==="sms"?"sms":"email"}const m1=({theme:e,branding:t})=>{const n=e?.widget?.logo_url||t?.logo_url;return n?S("div",{className:"inline-flex h-9 items-center",children:S("img",{src:n,className:"h-full w-auto",alt:"Logo"})}):S(Pa,{})},L8=e=>S("div",{className:"mt-8",children:e.client?.client_metadata?.termsAndConditionsUrl&&S("div",{className:"text-xs text-gray-300",children:[U.t("agree_to")," ",S("a",{href:e.client.client_metadata.termsAndConditionsUrl,className:"text-primary hover:underline",target:"_blank",rel:"noreferrer",children:U.t("terms")})]})});var n0={exports:{}};var $3;function nX(){return $3||($3=1,(function(e){(function(){var t={}.hasOwnProperty;function n(){for(var o="",a=0;a<arguments.length;a++){var c=arguments[a];c&&(o=r(o,i(c)))}return o}function i(o){if(typeof o=="string"||typeof o=="number")return o;if(typeof o!="object")return"";if(Array.isArray(o))return n.apply(null,o);if(o.toString!==Object.prototype.toString&&!o.toString.toString().includes("[native code]"))return o.toString();var a="";for(var c in o)t.call(o,c)&&o[c]&&(a=r(a,c));return a}function r(o,a){return a?o?o+" "+a:o+a:o}e.exports?(n.default=n,e.exports=n):window.classNames=n})()})(n0)),n0.exports}var iX=nX();const ct=$b(iX),rX=e=>e==="small"?"text-base":e==="medium"?"text-2xl":e==="large"?"text-3xl":"",wt=({name:e,size:t,className:n=""})=>{const i=rX(t);return S("span",{className:ct(`uicon-${e}`,n,i)})};function M8(e){const t=e.replace("#",""),n=parseInt(t,16);return[n>>16&255,n>>8&255,n&255]}function oX(e,t,n){return`#${(e<<16|t<<8|n).toString(16).padStart(6,"0")}`}const sX=(e,t)=>{const[n,i,r]=M8(e);return oX(Math.min(255,Math.round(n+(255-n)*t)),Math.min(255,Math.round(i+(255-i)*t)),Math.min(255,Math.round(r+(255-r)*t)))};function I3(e){const[t,n,i]=M8(e).map(r=>{const o=r/255;return o<=.04045?o/12.92:Math.pow((o+.055)/1.055,2.4)});return .2126*t+.7152*n+.0722*i}function z3(e,t){const n=I3(e),i=I3(t),r=Math.max(n,i),o=Math.min(n,i);return(r+.05)/(o+.05)}function P3(e,t="light"){const n=z3(e,"#ffffff"),i=z3(e,"#000000"),r=1.35;return t==="light"?i>n*r?"#000000":"#ffffff":i*r>n?"#000000":"#ffffff"}const aX=(e,t)=>{const n=e?.colors?.primary_button||t?.colors?.primary||"#000000",i=e?.colors?.base_hover_color||sX(n,.2),r=e?.colors?.primary_button_label,o=r||P3(n,"light"),a=r||P3(n,"dark"),c=o!==a?`
371
371
  @media (prefers-color-scheme: dark) {
372
372
  body { --text-on-primary: ${a}; }
373
373
  }`:"";return`