@authhero/kysely-adapter 11.8.3 → 11.8.4

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.
@@ -1,4 +1,4 @@
1
- Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:`Module`}});var e=Object.defineProperty,t=(t,n)=>{let r={};for(var i in t)e(r,i,{get:t[i],enumerable:!0});return n||e(r,Symbol.toStringTag,{value:`Module`}),r};let n=require("nanoid"),r=require("@authhero/adapter-interfaces");require("@hono/zod-openapi");let i=require("kysely");var a=17,o={organization:`org_`,connection:`con_`,action:`act_`,action_version:`ver_`,hook:`h_`,hook_code:`hc_`,rule:`rul_`,resource_server:`api_`,guardian_factor:`gfa_`,invite:`inv_`};function s(e){let t=(0,n.customAlphabet)(`0123456789abcdefghijklmnopqrstuvwxyz`,a)();return`${o[e]}${t}`}function c(){return s(`organization`)}function l(){return s(`connection`)}function u(){return s(`action`)}function d(){return s(`action_version`)}function f(){return s(`hook`)}function p(){return s(`resource_server`)}function m(){return s(`hook_code`)}function h(){return s(`invite`)}function g(e){return async(t,n)=>{let r=Date.now(),i=u();return await e.insertInto(`actions`).values({id:i,tenant_id:t,name:n.name,code:n.code,runtime:n.runtime||null,status:`built`,secrets:n.secrets?JSON.stringify(n.secrets):null,dependencies:n.dependencies?JSON.stringify(n.dependencies):null,supported_triggers:n.supported_triggers?JSON.stringify(n.supported_triggers):null,is_system:+!!n.is_system,inherit:+!!n.inherit,created_at_ts:r,updated_at_ts:r}).execute(),{id:i,tenant_id:t,name:n.name,code:n.code,runtime:n.runtime,status:`built`,secrets:n.secrets?.map(e=>({name:e.name})),dependencies:n.dependencies,supported_triggers:n.supported_triggers,is_system:n.is_system??!1,inherit:n.inherit??!1,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function _(e){if(e!=null){if(typeof e==`number`)return new Date(e).toISOString();if(typeof e==`string`){if(e===``)return;let t=parseFloat(e);return!isNaN(t)&&/^\d+(\.\d+)?$/.test(e)?new Date(t).toISOString():e}}}function v(e,t=new Date(0).toISOString()){return _(e)??t}function y(e){if(!e||e===``)return null;let t=new Date(e);return isNaN(t.getTime())?null:t.getTime()}function b(){return new Date().toISOString()}function x(e,t,n=[]){let r={};for(let n of t){let t=n.replace(/_ts$/,``);r[t]=v(e[n])}for(let t of n){let n=t.replace(/_ts$/,``);r[n]=_(e[t])}return r}function S(e){if(e)try{return JSON.parse(e)}catch{return}}function ee(e){return async(t,n)=>{let r=await e.selectFrom(`actions`).where(`actions.tenant_id`,`=`,t).where(`actions.id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{created_at_ts:i,updated_at_ts:a,deployed_at_ts:o,secrets:s,dependencies:c,supported_triggers:l,is_system:u,inherit:d,tenant_id:f,...p}=r,m=x({created_at_ts:i,updated_at_ts:a},[`created_at_ts`,`updated_at_ts`]);return{...p,tenant_id:t,...m,runtime:p.runtime??void 0,status:p.status||`built`,deployed_at:o?new Date(Number(o)).toISOString():void 0,secrets:S(s),dependencies:S(c),supported_triggers:S(l),is_system:!!u,inherit:!!d}}}function te(e,t){let n=new Set(t),r=e=>{let t=[],r=``,i=!1;for(let n=0;n<e.length;n++){let a=e[n];a===`"`?(i=!i,r+=a):a===` `&&!i?(r.trim()&&t.push(r.trim()),r=``):r+=a}return r.trim()&&t.push(r.trim()),t.filter(e=>{let t=e.replace(/^([^:]+)=/,`$1:`),r=t.startsWith(`-`)?t.slice(1):t;if(r.startsWith(`_exists_:`))return n.has(r.slice(9));let i=r.indexOf(`:`);return i>0?n.has(r.slice(0,i)):!0}).join(` `)},i=e.split(/ OR /i);return i.length>1?i.map(r).filter(e=>e.length>0).join(` OR `):r(e)}function C(e,t,n,r,i=[]){let a=new Set(i),o=n.split(/ OR /i);if(o.length>1)return t.where(e=>{let t=o.map(t=>{let n=t.trim().match(/^([^:]+):(.+)$/);if(n){let[,t,r]=n;if(!t||!r)return null;let i=t.trim(),o=r.replace(/^"(.*)"$/,`$1`).trim();return a.has(i)?e(i,`like`,`%${o}%`):e(i,`=`,o)}return null}).filter(Boolean);return e.or(t)});let s=[],c=``,l=!1;for(let e=0;e<n.length;e++){let t=n[e];t===`"`?(l=!l,c+=t):t===` `&&!l?c.trim()&&(s.push(c.trim()),c=``):c+=t}return c.trim()&&s.push(c.trim()),s.filter(e=>e!==`AND`).map(e=>e.replace(/^([^:]+)=/g,`$1:`)).map(e=>{let t=e.startsWith(`-`),n=null,r=``,i=!1,a;if(e.startsWith(`-_exists_:`))n=e.substring(10),i=!0,t=!0;else if(e.startsWith(`_exists_:`))n=e.substring(9),i=!0,t=!1;else if(e.includes(`:`)){let o=t?e.substring(1):e,s=o.indexOf(`:`);n=o.substring(0,s),r=o.substring(s+1),i=!1,r.startsWith(`>=`)?(a=`>=`,r=r.substring(2)):r.startsWith(`>`)?(a=`>`,r=r.substring(1)):r.startsWith(`<=`)?(a=`<=`,r=r.substring(2)):r.startsWith(`<`)?(a=`<`,r=r.substring(1)):a=`=`,r.startsWith(`"`)&&r.endsWith(`"`)&&r.length>1&&(r=r.slice(1,-1))}else n=null,r=e,i=!1;return{key:n,value:r,isNegation:t,isExistsQuery:i,operator:a}}).forEach(({key:n,value:i,isNegation:o,isExistsQuery:s,operator:c})=>{if(n)if(s)t=o?t.where(n,`is`,null):t.where(n,`is not`,null);else if(a.has(n)&&c===`=`)t=t.where(n,o?`not like`:`like`,`%${i}%`);else if(o)switch(c){case`>`:t=t.where(n,`<=`,i);break;case`>=`:t=t.where(n,`<`,i);break;case`<`:t=t.where(n,`>=`,i);break;case`<=`:t=t.where(n,`>`,i);break;default:t=t.where(n,`!=`,i)}else t=t.where(n,c,i);else if(i){let{ref:n}=e.dynamic;t=t.where(e=>e.or(r.map(t=>t===`user_id`?e(n(t),`=`,i):e(n(t),`like`,`%${i}%`))))}}),t}function w(e){return typeof e==`string`?parseInt(e,10):typeof e==`bigint`?Number(e):e}function T(e){if(e)try{return JSON.parse(e)}catch{return}}function ne(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,q:o}=n,s=e.selectFrom(`actions`).where(`actions.tenant_id`,`=`,t);o&&(s=C(e,s,o,[`name`]));let c=(await s.offset(r*i).limit(i).selectAll().execute()).map(e=>{let{created_at_ts:n,updated_at_ts:r,deployed_at_ts:i,secrets:a,dependencies:o,supported_triggers:s,is_system:c,inherit:l,tenant_id:u,...d}=e,f=x({created_at_ts:n,updated_at_ts:r},[`created_at_ts`,`updated_at_ts`]);return{...d,tenant_id:t,...f,runtime:d.runtime??void 0,status:d.status||`built`,deployed_at:i?new Date(Number(i)).toISOString():void 0,secrets:T(a),dependencies:T(o),supported_triggers:T(s),is_system:!!c,inherit:!!l}});if(!a)return{actions:c,start:0,limit:0,length:0};let{count:l}=await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{actions:c,start:r*i,limit:i,length:w(l)}}}function re(e){if(!e)return[];try{let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}function ie(e){return async(t,n,r)=>{let i={updated_at_ts:Date.now()};if(r.name!==void 0&&(i.name=r.name),r.code!==void 0&&(i.code=r.code),r.runtime!==void 0&&(i.runtime=r.runtime),r.secrets!==void 0){let a=await e.selectFrom(`actions`).where(`actions.id`,`=`,n).where(`actions.tenant_id`,`=`,t).select(`secrets`).executeTakeFirst(),o=new Map(re(a?.secrets).map(e=>[e.name,e])),s=r.secrets.map(e=>e.value===void 0?{name:e.name,value:o.get(e.name)?.value}:e);i.secrets=JSON.stringify(s)}if(r.dependencies!==void 0&&(i.dependencies=JSON.stringify(r.dependencies)),r.supported_triggers!==void 0&&(i.supported_triggers=JSON.stringify(r.supported_triggers)),r.status!==void 0&&(i.status=r.status),r.deployed_at!==void 0){let e=new Date(r.deployed_at).getTime();Number.isFinite(e)&&(i.deployed_at_ts=e)}return r.is_system!==void 0&&(i.is_system=+!!r.is_system),r.inherit!==void 0&&(i.inherit=+!!r.inherit),(await e.updateTable(`actions`).set(i).where(`actions.id`,`=`,n).where(`actions.tenant_id`,`=`,t).executeTakeFirst()).numUpdatedRows>0}}function ae(e){return async(t,n)=>(await e.deleteFrom(`actions`).where(`actions.id`,`=`,n).where(`actions.tenant_id`,`=`,t).executeTakeFirst()).numDeletedRows>0}function oe(e){return{create:g(e),get:ee(e),list:ne(e),update:ie(e),remove:ae(e)}}function se(e){return async(t,n)=>{let r=Date.now();return await e.insertInto(`action_executions`).values({id:n.id,tenant_id:t,trigger_id:n.trigger_id,status:n.status,results:JSON.stringify(n.results),logs:n.logs?JSON.stringify(n.logs):null,created_at_ts:r,updated_at_ts:r}).execute(),{id:n.id,tenant_id:t,trigger_id:n.trigger_id,status:n.status,results:n.results,logs:n.logs,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function ce(e){if(e)try{return JSON.parse(e)}catch{return}}function le(e){return async(t,n)=>{let r=await e.selectFrom(`action_executions`).where(`action_executions.tenant_id`,`=`,t).where(`action_executions.id`,`=`,n).selectAll().executeTakeFirst();return r?{id:r.id,tenant_id:r.tenant_id,trigger_id:r.trigger_id,status:r.status,results:ce(r.results)??[],logs:ce(r.logs),created_at:new Date(Number(r.created_at_ts)).toISOString(),updated_at:new Date(Number(r.updated_at_ts)).toISOString()}:null}}function ue(e){return{create:se(e),get:le(e)}}function de(e){if(e)try{return JSON.parse(e)}catch{return}}function fe(e){let{created_at_ts:t,updated_at_ts:n,secrets:r,dependencies:i,supported_triggers:a,deployed:o,runtime:s,...c}=e;return{...c,runtime:s??void 0,deployed:!!o,secrets:de(r),dependencies:de(i),supported_triggers:de(a),created_at:new Date(Number(t)).toISOString(),updated_at:new Date(Number(n)).toISOString()}}function pe(e){return{async create(t,n){let r=Date.now(),i=d(),a=n.deployed!==!1,o=await e.transaction().execute(async e=>{let o=((await e.selectFrom(`action_versions`).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n.action_id).select(`number`).orderBy(`number`,`desc`).limit(1).executeTakeFirst())?.number??0)+1;return a&&await e.updateTable(`action_versions`).set({deployed:0,updated_at_ts:r}).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n.action_id).execute(),await e.insertInto(`action_versions`).values({id:i,tenant_id:t,action_id:n.action_id,number:o,code:n.code,runtime:n.runtime||null,secrets:n.secrets?JSON.stringify(n.secrets):null,dependencies:n.dependencies?JSON.stringify(n.dependencies):null,supported_triggers:n.supported_triggers?JSON.stringify(n.supported_triggers):null,deployed:+!!a,created_at_ts:r,updated_at_ts:r}).execute(),o});return{id:i,tenant_id:t,action_id:n.action_id,number:o,code:n.code,runtime:n.runtime,secrets:n.secrets,dependencies:n.dependencies,supported_triggers:n.supported_triggers,deployed:a,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}},async get(t,n,r){let i=await e.selectFrom(`action_versions`).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n).where(`id`,`=`,r).selectAll().executeTakeFirst();return i?fe(i):null},async list(t,n,r={}){let{page:i=0,per_page:a=50,include_totals:o=!1}=r,s=e.selectFrom(`action_versions`).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n),c=(await s.orderBy(`number`,`desc`).offset(i*a).limit(a).selectAll().execute()).map(fe);if(!o)return{versions:c,start:0,limit:0,length:0};let{count:l}=await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{versions:c,start:i*a,limit:a,length:w(l)}},async removeForAction(t,n){let r=await e.deleteFrom(`action_versions`).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows??0)}}}var E=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})}};function me(e){return async(t,r)=>{let{identities:i,phone_verified:a,password:o,...s}=r,c=new Date().toISOString(),l={...s,login_count:s.login_count??0,created_at:s.created_at??c,updated_at:s.updated_at??c,tenant_id:t,email_verified:+!!r.email_verified,phone_verified:a===void 0?null:+!!a,is_social:+!!r.is_social,app_metadata:JSON.stringify(r.app_metadata),user_metadata:JSON.stringify(r.user_metadata),address:r.address?JSON.stringify(r.address):null};try{let r=async e=>{if(await e.insertInto(`users`).values(l).execute(),o&&l.user_id){let r={id:(0,n.nanoid)(),user_id:l.user_id,password:o.hash,algorithm:o.algorithm,is_current:1,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),tenant_id:t};await e.insertInto(`passwords`).values(r).execute()}};e.isTransaction?await r(e):await e.transaction().execute(r)}catch(e){throw e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`||e.message.includes(`AlreadyExists`)?new E(409,{message:`User already exists`}):new E(500,{message:`${e.code}, ${e.message}`})}return{...l,email:l.email||``,email_verified:l.email_verified===1,phone_verified:l.phone_verified===null?void 0:l.phone_verified===1,is_social:l.is_social===1,address:r.address}}}function D(e){if(typeof e!=`object`||!e)return e;if(Array.isArray(e))return e.map(e=>typeof e==`object`&&e?D(e):e);let t={...e};for(let e in t){let n=t[e];n===null?delete t[e]:typeof n==`object`&&n&&(Array.isArray(n)?t[e]=n.map(e=>typeof e==`object`&&e?D(e):e):t[e]=D(n))}return t}var he=[`email`,`email_verified`,`phone_number`,`phone_verified`,`username`];function O(e,t=!1){let n={connection:e.connection,provider:e.provider,user_id:(0,r.parseUserId)(e.user_id).id,isSocial:!!e.is_social};for(let t of he)e[t]!==void 0&&e[t]!==null&&(n[t]=t.endsWith(`_verified`)?!!e[t]:e[t]);if(!t){let t={};try{t=JSON.parse(e.profileData||`{}`)}catch(e){console.error(`Error parsing profileData`,e)}n.profileData={email:e.email,email_verified:!!e.email_verified,...t}}return n}function ge(e){return async(t,n)=>{let[r,i]=await Promise.all([e.selectFrom(`users`).where(`users.tenant_id`,`=`,t).where(`users.user_id`,`=`,n).selectAll().executeTakeFirst(),e.selectFrom(`users`).where(`users.tenant_id`,`=`,t).where(`users.linked_to`,`=`,n).selectAll().orderBy(`created_at`,`asc`).execute()]);if(!r)return null;let{tenant_id:a,...o}=r;return D({...o,email:r.email||``,email_verified:r.email_verified===1,phone_verified:r.phone_verified===null?void 0:r.phone_verified===1,is_social:r.is_social===1,app_metadata:JSON.parse(r.app_metadata),user_metadata:JSON.parse(r.user_metadata),address:r.address?JSON.parse(r.address):void 0,identities:[O(r,!0),...i.map(e=>O(e))]})}}var _e=[`user_id`,`email`,`email_verified`,`username`,`phone_number`,`phone_verified`,`name`,`given_name`,`family_name`,`nickname`,`picture`,`locale`,`linked_to`,`provider`,`connection`,`is_social`,`last_ip`,`last_login`,`login_count`,`created_at`,`updated_at`],ve=[`email`,`name`,`phone_number`,`user_id`];function ye(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`users`).where(`users.tenant_id`,`=`,t);if(s){let t=te(s,_e);t&&(c=C(e,c,t,ve))}if(o&&o.sort_by){let{ref:t}=e.dynamic;c=c.orderBy(t(o.sort_by),o.sort_order)}let l=await c.offset(r*i).limit(i).selectAll().execute(),u=l.map(e=>e.user_id),d=u.length?await e.selectFrom(`users`).selectAll().where(`users.tenant_id`,`=`,t).where(`users.linked_to`,`in`,u).orderBy(`created_at`,`asc`).execute():[],f=l.map(e=>{let t=d.filter(t=>t.linked_to===e.user_id);return D({...e,email_verified:e.email_verified===1,phone_verified:e.phone_verified===null?void 0:e.phone_verified===1,is_social:e.is_social===1,app_metadata:JSON.parse(e.app_metadata),user_metadata:JSON.parse(e.user_metadata),address:e.address?JSON.parse(e.address):void 0,identities:[O(e,!0),...t.map(e=>O(e))]})});if(!a)return{users:f,start:0,limit:0,length:0};let{count:p}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{users:f,start:r*i,limit:i,length:w(p)}}}function be(e){return async(t,n)=>(await e.deleteFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.user_id`,`in`,e=>e.selectFrom(`users`).select(`users.user_id`).where(`users.tenant_id`,`=`,t).where(e=>e.or([e(`users.user_id`,`=`,n),e(`users.linked_to`,`=`,n)]))).execute(),await e.deleteFrom(`users`).where(`users.tenant_id`,`=`,t).where(`users.linked_to`,`=`,n).execute(),(await e.deleteFrom(`users`).where(`users.tenant_id`,`=`,t).where(`users.user_id`,`=`,n).execute()).length===1)}function k(e,t=``,n={}){for(let r in e)if(Object.prototype.hasOwnProperty.call(e,r)){let i=t?`${t}_${r}`:r,a=e[r];typeof a==`object`&&a&&!Array.isArray(a)?k(a,i,n):typeof a==`boolean`?n[i]=+!!a:n[i]=a}return n}function xe(e,t){let n={};for(let[r,i]of Object.entries(e)){let e=t.find(e=>r.startsWith(`${e}_`));if(!e)n[r]=i;else{let t=r.slice(e.length+1);n[e]={...n[e],[t]:i}}}return n}function Se(e){return async(t,n,r)=>{let i=k({...r,updated_at:new Date().toISOString(),app_metadata:r.app_metadata?JSON.stringify(r.app_metadata):void 0,user_metadata:r.user_metadata?JSON.stringify(r.user_metadata):void 0,address:r.address?JSON.stringify(r.address):void 0,phone_verified:r.phone_verified===void 0?void 0:+!!r.phone_verified});return(await e.updateTable(`users`).set(i).where(`users.tenant_id`,`=`,t).where(`users.user_id`,`=`,n).execute()).length===1}}function Ce(e){return async(t,n,r,i)=>(await e.updateTable(`users`).set({linked_to:null}).where(`users.tenant_id`,`=`,t).where(`users.user_id`,`=`,`${r}|${i}`).where(`users.linked_to`,`=`,`${n}`).execute()).length===1}function we(e){let t=me(e);return{create:t,rawCreate:t,remove:be(e),get:ge(e),list:ye(e),update:Se(e),unlink:Ce(e)}}function Te(e){return async(t,i)=>{let a=new Date().toISOString(),o=r.flowSchema.parse({id:`af_${(0,n.nanoid)()}`,...i,actions:i.actions||[],created_at:a,updated_at:a});return await e.insertInto(`flows`).values({...o,tenant_id:t,actions:JSON.stringify(o.actions)}).execute(),o}}function A(e,t){if(!e)return t;try{return JSON.parse(e)}catch{return t}}function Ee(e){if(e)try{let t=JSON.parse(e);return t&&typeof t==`object`&&!Array.isArray(t)?t:void 0}catch{return}}function De(e,t,n={...e}){for(let r in t)r in e&&(n[r]=A(e[r],t[r]));return n}function Oe(e){return async(t,n)=>{let i=await e.selectFrom(`flows`).selectAll().where(`flows.id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();if(!i)return null;let a={...i,actions:A(i.actions,[])};return r.flowSchema.parse(D(a))}}function ke(e){return async(t,n={})=>{let{page:i=0,per_page:a=50,include_totals:o=!1,q:s}=n,c=e.selectFrom(`flows`).where(`tenant_id`,`=`,t);s&&(c=C(e,c,s,[]));let l=(await c.offset(i*a).limit(a).selectAll().execute()).map(e=>{let t={...e,actions:A(e.actions,[])};return r.flowSchema.parse(D(t))});if(!o)return{flows:l,start:0,limit:0,length:0};let{count:u}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{flows:l,start:i*a,limit:a,length:w(u)}}}function Ae(e){return async(t,n,i)=>{let a={...i,updated_at:new Date().toISOString()};i.actions!==void 0&&(a.actions=JSON.stringify(i.actions));let{numUpdatedRows:o}=await e.updateTable(`flows`).set(a).where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();if(o===0n)return null;let s=await e.selectFrom(`flows`).selectAll().where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();return s?r.flowSchema.parse({...s,actions:s.actions?JSON.parse(s.actions):[]}):null}}function je(e){return async(t,n)=>((await e.deleteFrom(`flows`).where(`id`,`=`,n).where(`tenant_id`,`=`,t).execute())[0]?.numDeletedRows??0n)>0n}function Me(e){return{create:Te(e),get:Oe(e),list:ke(e),update:Ae(e),remove:je(e)}}function j(e,t,n={...e}){for(let r of t)e[r]!==void 0&&(n[r]=JSON.stringify(e[r]));return n}function Ne(e,t,n=e){for(let r of t)e[r]!==void 0&&(n[r]=+!!e[r])}function Pe(e){let t={};for(let n in e)e[n]!==void 0&&e[n]!==null&&(t[n]=e[n]);return t}function Fe(e){let t={...e};return e.session_cookie&&typeof e.session_cookie==`string`&&(t.session_cookie=JSON.parse(e.session_cookie)),e.enabled_locales&&typeof e.enabled_locales==`string`&&(t.enabled_locales=JSON.parse(e.enabled_locales)),e.error_page&&typeof e.error_page==`string`&&(t.error_page=JSON.parse(e.error_page)),e.flags&&typeof e.flags==`string`&&(t.flags=JSON.parse(e.flags)),e.sandbox_versions_available&&typeof e.sandbox_versions_available==`string`&&(t.sandbox_versions_available=JSON.parse(e.sandbox_versions_available)),e.change_password&&typeof e.change_password==`string`&&(t.change_password=JSON.parse(e.change_password)),e.guardian_mfa_page&&typeof e.guardian_mfa_page==`string`&&(t.guardian_mfa_page=JSON.parse(e.guardian_mfa_page)),e.sessions&&typeof e.sessions==`string`&&(t.sessions=JSON.parse(e.sessions)),e.oidc_logout&&typeof e.oidc_logout==`string`&&(t.oidc_logout=JSON.parse(e.oidc_logout)),e.device_flow&&typeof e.device_flow==`string`&&(t.device_flow=JSON.parse(e.device_flow)),e.default_token_quota&&typeof e.default_token_quota==`string`&&(t.default_token_quota=JSON.parse(e.default_token_quota)),e.allowed_logout_urls&&typeof e.allowed_logout_urls==`string`&&(t.allowed_logout_urls=JSON.parse(e.allowed_logout_urls)),e.acr_values_supported&&typeof e.acr_values_supported==`string`&&(t.acr_values_supported=JSON.parse(e.acr_values_supported)),e.mtls&&typeof e.mtls==`string`&&(t.mtls=JSON.parse(e.mtls)),e.mfa&&typeof e.mfa==`string`&&(t.mfa=JSON.parse(e.mfa)),e.attack_protection&&typeof e.attack_protection==`string`&&(t.attack_protection=JSON.parse(e.attack_protection)),e.allow_organization_name_in_authentication_api!==void 0&&(t.allow_organization_name_in_authentication_api=e.allow_organization_name_in_authentication_api===1),e.customize_mfa_in_postlogin_action!==void 0&&(t.customize_mfa_in_postlogin_action=e.customize_mfa_in_postlogin_action===1),e.pushed_authorization_requests_supported!==void 0&&(t.pushed_authorization_requests_supported=e.pushed_authorization_requests_supported===1),e.authorization_response_iss_parameter_supported!==void 0&&(t.authorization_response_iss_parameter_supported=e.authorization_response_iss_parameter_supported===1),D(t)}function Ie(e){let t={...e};return j(e,[`session_cookie`,`enabled_locales`,`error_page`,`flags`,`sandbox_versions_available`,`change_password`,`guardian_mfa_page`,`sessions`,`oidc_logout`,`device_flow`,`default_token_quota`,`allowed_logout_urls`,`acr_values_supported`,`mtls`,`mfa`,`attack_protection`],t),e.allow_organization_name_in_authentication_api!==void 0&&(t.allow_organization_name_in_authentication_api=+!!e.allow_organization_name_in_authentication_api),e.customize_mfa_in_postlogin_action!==void 0&&(t.customize_mfa_in_postlogin_action=+!!e.customize_mfa_in_postlogin_action),e.pushed_authorization_requests_supported!==void 0&&(t.pushed_authorization_requests_supported=+!!e.pushed_authorization_requests_supported),e.authorization_response_iss_parameter_supported!==void 0&&(t.authorization_response_iss_parameter_supported=+!!e.authorization_response_iss_parameter_supported),Pe(t)}function Le(e){return async t=>{let r={id:t.id||(0,n.nanoid)(),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...t},i=Ie(r);try{await e.insertInto(`tenants`).values(i).execute()}catch(e){throw e?.message?.includes(`UNIQUE constraint failed`)||e?.message?.includes(`duplicate key`)||e?.code===`SQLITE_CONSTRAINT`||e?.code===`ER_DUP_ENTRY`||e?.code===`23505`?new E(409,{message:`Tenant with ID '${r.id}' already exists`}):e}return r}}function Re(e){return async t=>{let n=await e.selectFrom(`tenants`).where(`tenants.id`,`=`,t).selectAll().executeTakeFirst();return n?Fe(n):null}}function ze(e){return async t=>{let n=e.selectFrom(`tenants`),{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=t||{};if(o&&o.sort_by){let{ref:t}=e.dynamic;n=n.orderBy(t(o.sort_by),o.sort_order)}s&&(n=C(e,n,s,[`friendly_name`]));let c=(await n.offset(r*i).limit(i).selectAll().execute()).map(Fe);if(!a)return{tenants:c};let{count:l}=await n.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow(),u=w(l);return{tenants:c,start:r*i,limit:i,length:u}}}function Be(e){return async(t,n)=>{let r={...Ie(n),id:t,updated_at:new Date().toISOString()};await e.updateTable(`tenants`).set(r).where(`id`,`=`,t).execute()}}function Ve(e){return async t=>(await e.deleteFrom(`tenants`).where(`tenants.id`,`=`,t).execute()).length===1}function He(e){return{create:Le(e),get:Re(e),list:ze(e),update:Be(e),remove:Ve(e)}}function Ue(e){return e?JSON.stringify(e):void 0}var We=256;function Ge(e){return async(t,r)=>{let i=r.user_agent?.slice(0,We),a=r.log_id||(0,n.nanoid)(),{location_info:o,...s}=r;return await e.insertInto(`logs`).values({...s,log_id:a,tenant_id:t,user_agent:i,description:r.description?.substring(0,256),isMobile:+!!r.isMobile,scope:r.scope,auth0_client:Ue(r.auth0_client),details:Ue(r.details)?.substring(0,8192),country_code:o?.country_code,city_name:o?.city_name,latitude:o?.latitude,longitude:o?.longitude,time_zone:o?.time_zone,continent_code:o?.continent_code}).execute(),{...r,log_id:a,user_agent:i}}}function Ke(e){if(!e)return``;try{return JSON.parse(e)}catch{return e}}function qe(e){return{...e,client_id:e.client_id,client_name:``,auth0_client:Ke(e.auth0_client),details:Ke(e.details),isMobile:!!e.isMobile,scope:e.scope||void 0,log_id:e.log_id,location_info:e.country_code?{country_code:e.country_code,city_name:e.city_name||``,latitude:e.latitude||``,longitude:e.longitude||``,time_zone:e.time_zone||``,continent_code:e.continent_code||``}:void 0}}function Je(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s,from_date:c,to_date:l}=n,u=e.selectFrom(`logs`).where(`logs.tenant_id`,`=`,t);s&&(u=C(e,u,s,[`user_id`,`ip`],[`description`])),typeof c==`number`&&Number.isFinite(c)&&(u=u.where(`logs.date`,`>=`,new Date(Math.floor(c)*1e3).toISOString())),typeof l==`number`&&Number.isFinite(l)&&(u=u.where(`logs.date`,`<=`,new Date(Math.floor(l)*1e3+999).toISOString()));let d=u;if(o&&o.sort_by){let{ref:t}=e.dynamic;d=d.orderBy(t(o.sort_by),o.sort_order)}d=d.offset(r*i).limit(i);let f=(await d.selectAll().execute()).map(qe);if(!a)return{logs:f,start:0,limit:0,length:0};let{count:p}=await u.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{logs:f,start:r*i,limit:i,length:w(p)}}}function Ye(e){return async(t,n)=>{let r=await e.selectFrom(`logs`).where(`logs.tenant_id`,`=`,t).where(`logs.log_id`,`=`,n).selectAll().executeTakeFirst();return r?qe(r):null}}function Xe(e){return{create:Ge(e),list:Je(e),get:Ye(e)}}function Ze(e){return async(t,n)=>{let r=await e.selectFrom(`sessions`).where(`sessions.tenant_id`,`=`,t).where(`sessions.id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,device:a,clients:o,created_at_ts:s,updated_at_ts:c,expires_at_ts:l,idle_expires_at_ts:u,authenticated_at_ts:d,last_interaction_at_ts:f,used_at_ts:p,revoked_at_ts:m,...h}=r,g=x({created_at_ts:s,updated_at_ts:c,expires_at_ts:l,idle_expires_at_ts:u,authenticated_at_ts:d,last_interaction_at_ts:f,used_at_ts:p,revoked_at_ts:m},[`created_at_ts`,`updated_at_ts`,`authenticated_at_ts`,`last_interaction_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`used_at_ts`,`revoked_at_ts`]);return{...h,...g,device:JSON.parse(a),clients:JSON.parse(o)}}}function Qe(e){return async(t,n)=>{let r=Date.now(),i=b(),a={...n,created_at:i,updated_at:i,authenticated_at:i,last_interaction_at:i},{expires_at:o,idle_expires_at:s,used_at:c,revoked_at:l,device:u,clients:d,...f}=n;return await e.insertInto(`sessions`).values({...f,tenant_id:t,created_at_ts:r,updated_at_ts:r,authenticated_at_ts:r,last_interaction_at_ts:r,expires_at_ts:y(o),idle_expires_at_ts:y(s),used_at_ts:y(c),revoked_at_ts:y(l),device:JSON.stringify(u),clients:JSON.stringify(d)}).execute(),a}}function $e(e){return async(t,n)=>!!(await e.deleteFrom(`sessions`).where(`tenant_id`,`=`,t).where(`sessions.id`,`=`,n).execute()).length}function et(e){return async(t,n,r)=>{let i={updated_at_ts:Date.now(),device:r.device?JSON.stringify(r.device):void 0,clients:r.clients?JSON.stringify(r.clients):void 0};return r.expires_at!==void 0&&(i.expires_at_ts=y(r.expires_at)),r.idle_expires_at!==void 0&&(i.idle_expires_at_ts=y(r.idle_expires_at)),r.authenticated_at!==void 0&&(i.authenticated_at_ts=y(r.authenticated_at)),r.last_interaction_at!==void 0&&(i.last_interaction_at_ts=y(r.last_interaction_at)),r.used_at!==void 0&&(i.used_at_ts=y(r.used_at)),r.revoked_at!==void 0&&(i.revoked_at_ts=y(r.revoked_at)),r.user_id!==void 0&&(i.user_id=r.user_id),r.login_session_id!==void 0&&(i.login_session_id=r.login_session_id),!!(await e.updateTable(`sessions`).set(i).where(`tenant_id`,`=`,t).where(`sessions.id`,`=`,n).execute()).length}}function tt(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`sessions`).where(`sessions.tenant_id`,`=`,t);s&&(c=C(e,c,s,[`user_id`,`session_id`]));let l=c;if(o&&o.sort_by){let{ref:t}=e.dynamic;l=l.orderBy(t(o.sort_by),o.sort_order)}l=l.offset(r*i).limit(i);let u=(await l.selectAll().execute()).map(e=>{let{tenant_id:t,device:n,clients:r,created_at_ts:i,updated_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,authenticated_at_ts:c,last_interaction_at_ts:l,used_at_ts:u,revoked_at_ts:d,...f}=e,p=x({created_at_ts:i,updated_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,authenticated_at_ts:c,last_interaction_at_ts:l,used_at_ts:u,revoked_at_ts:d},[`created_at_ts`,`updated_at_ts`,`authenticated_at_ts`,`last_interaction_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`used_at_ts`,`revoked_at_ts`]);return{...f,...p,device:JSON.parse(n),clients:JSON.parse(r)}});if(!a)return{sessions:u,start:0,limit:0,length:0};let{count:d}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow(),f=w(d);return{sessions:u,start:r*i,limit:i,length:f}}}function nt(e){return{create:Qe(e),get:Ze(e),list:tt(e),remove:$e(e),update:et(e)}}function rt(e){return async(t,n)=>{let r=await e.selectFrom(`passwords`).where(`passwords.tenant_id`,`=`,t).where(`passwords.user_id`,`=`,n).where(`passwords.is_current`,`=`,1).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,...a}=r;return{...a,is_current:!!a.is_current}}}function it(e){return async(t,r)=>{let i=r.id||(0,n.nanoid)(),a=r.is_current??!0,o={id:i,...r,is_current:a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return a&&await e.updateTable(`passwords`).set({is_current:0}).where(`user_id`,`=`,r.user_id).where(`tenant_id`,`=`,t).where(`is_current`,`=`,1).execute(),await e.insertInto(`passwords`).values({...o,is_current:+!!o.is_current,tenant_id:t}).execute(),o}}function at(e){return async(t,n)=>{let r=e.updateTable(`passwords`).set({password:n.password,algorithm:n.algorithm,is_current:+!!n.is_current,updated_at:new Date().toISOString()}).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n.user_id);return r=n.id?r.where(`id`,`=`,n.id):r.where(`is_current`,`=`,1),(await r.execute()).length===1}}function ot(e){return async(t,n,r)=>{let i=e.selectFrom(`passwords`).where(`passwords.tenant_id`,`=`,t).where(`passwords.user_id`,`=`,n).orderBy(`created_at`,`desc`);return r&&(i=i.limit(r)),(await i.selectAll().execute()).map(({tenant_id:e,...t})=>({...t,is_current:!!t.is_current}))}}function st(e){return{create:it(e),update:at(e),get:rt(e),list:ot(e)}}function ct(e){return async(t,n={})=>{let{page:i=0,per_page:a=50,include_totals:o=!1,q:s}=n,c=e.selectFrom(`codes`).where(`codes.tenant_id`,`=`,t);s&&(c=C(e,c,s,[`code`,`login_id`]));let l=(await c.offset(i*a).limit(a).selectAll().execute()).map(e=>{let{tenant_id:t,...n}=e;return r.codeSchema.parse(D(n))});if(!o)return{codes:l,start:0,limit:0,length:0};let{count:u}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{codes:l,start:i*a,limit:a,length:w(u)}}}function lt(e){return async(t,n)=>{let r={...n,created_at:new Date().toISOString()};return await e.insertInto(`codes`).values({...r,tenant_id:t}).execute(),r}}function ut(e){return async(t,n)=>(await e.deleteFrom(`codes`).where(`codes.tenant_id`,`=`,t).where(`codes.code_id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function dt(e){return async(t,n,r)=>{let i=e.selectFrom(`codes`).where(`codes.code_id`,`=`,n).where(`codes.code_type`,`=`,r);t.length&&(i=i.where(`codes.tenant_id`,`=`,t));let a=await i.selectAll().executeTakeFirst();return a?D(a):null}}function ft(e){return async(t,n)=>(await e.updateTable(`codes`).set({used_at:new Date().toISOString()}).where(`codes.tenant_id`,`=`,t).where(`codes.code_id`,`=`,n).executeTakeFirst()).numUpdatedRows>0}function pt(e){return async(t,n)=>(await e.updateTable(`codes`).set({used_at:new Date().toISOString()}).where(`codes.tenant_id`,`=`,t).where(`codes.code_id`,`=`,n).where(`codes.used_at`,`is`,null).executeTakeFirst()).numUpdatedRows>0}function mt(e){return{create:lt(e),list:ct(e),remove:ut(e),used:ft(e),consume:pt(e),get:dt(e)}}function ht(e){return async(t,n)=>{let{is_system:r,...i}=n;delete i.enabled_clients;let a={id:i.id||l(),...i,is_system:r?!0:void 0,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return await e.insertInto(`connections`).values({...a,is_system:+!!r,options:JSON.stringify(a.options||{}),tenant_id:t}).execute(),a}}function gt(e){let{is_system:t,...n}=e;return D({...n,is_system:t?!0:void 0,options:typeof e.options==`string`?JSON.parse(e.options):{}})}function _t(e){return e.map(gt)}function vt(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,q:o}=n,s=e.selectFrom(`connections`).where(`connections.tenant_id`,`=`,t);o&&(s=C(e,s,o,[`user_id`,`ip`]));let c=_t(await s.offset(r*i).limit(i).selectAll().execute());if(!a)return{connections:c,start:0,limit:0,length:0};let{count:l}=await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{connections:c,start:r*i,limit:i,length:w(l)}}}function yt(e){return async(t,n)=>(await e.deleteFrom(`connections`).where(`connections.tenant_id`,`=`,t).where(`connections.id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function bt(e){return async(t,n)=>{let r=await e.selectFrom(`connections`).where(`connections.tenant_id`,`=`,t).where(`connections.id`,`=`,n).selectAll().executeTakeFirst();return r?gt(r):null}}function xt(e){return async(t,n,r)=>{let{is_system:i,...a}=r;delete a.enabled_clients;let o={...a,is_system:i===void 0?void 0:+!!i,updated_at:new Date().toISOString()};return await e.updateTable(`connections`).set({...o,options:o.options?JSON.stringify(o.options):void 0}).where(`connections.id`,`=`,n).where(`connections.tenant_id`,`=`,t).execute(),!0}}function St(e){return{create:ht(e),get:bt(e),list:vt(e),remove:yt(e),update:xt(e)}}function Ct(e){return async(t,r)=>{let i=r.client_id??(0,n.nanoid)(),a={created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...r,client_id:i,global:r.global??!1,is_first_party:r.is_first_party??!0,oidc_conformant:r.oidc_conformant??!0,auth0_conformant:r.auth0_conformant??!0,sso:r.sso??!1,sso_disabled:r.sso_disabled??!1,cross_origin_authentication:r.cross_origin_authentication??!1,custom_login_page_on:r.custom_login_page_on??!1,require_pushed_authorization_requests:r.require_pushed_authorization_requests??!1,require_proof_of_possession:r.require_proof_of_possession??!1,hide_sign_up_disabled_error:r.hide_sign_up_disabled_error??!1},o={...a,tenant_id:t};return Ne(a,[`global`,`is_first_party`,`oidc_conformant`,`auth0_conformant`,`sso`,`sso_disabled`,`cross_origin_authentication`,`custom_login_page_on`,`require_pushed_authorization_requests`,`require_proof_of_possession`,`hide_sign_up_disabled_error`],o),Object.assign(o,{callbacks:JSON.stringify(r.callbacks||[]),allowed_origins:JSON.stringify(r.allowed_origins||[]),web_origins:JSON.stringify(r.web_origins||[]),client_aliases:JSON.stringify(r.client_aliases||[]),allowed_clients:JSON.stringify(r.allowed_clients||[]),connections:JSON.stringify(r.connections||[]),allowed_logout_urls:JSON.stringify(r.allowed_logout_urls||[]),session_transfer:JSON.stringify(r.session_transfer||{}),oidc_logout:JSON.stringify(r.oidc_logout||{}),grant_types:JSON.stringify(r.grant_types||[]),jwt_configuration:JSON.stringify(r.jwt_configuration||{}),signing_keys:JSON.stringify(r.signing_keys||[]),encryption_key:JSON.stringify(r.encryption_key||{}),addons:JSON.stringify(r.addons||{}),client_metadata:JSON.stringify(r.client_metadata||{}),mobile:JSON.stringify(r.mobile||{}),native_social_login:JSON.stringify(r.native_social_login||{}),refresh_token:JSON.stringify(r.refresh_token||{}),default_organization:JSON.stringify(r.default_organization||{}),client_authentication_methods:JSON.stringify(r.client_authentication_methods||{}),signed_request_object:JSON.stringify(r.signed_request_object||{}),token_quota:JSON.stringify(r.token_quota||{}),owner_user_id:r.owner_user_id??null,registration_type:r.registration_type??null,registration_metadata:r.registration_metadata?JSON.stringify(r.registration_metadata):null}),await e.insertInto(`clients`).values(o).execute(),a}}function wt(e){return async(t,n)=>{let r=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,...a}=r;return D({...a,global:!!r.global,is_first_party:!!r.is_first_party,oidc_conformant:!!r.oidc_conformant,auth0_conformant:!!r.auth0_conformant,sso:!!r.sso,sso_disabled:!!r.sso_disabled,cross_origin_authentication:!!r.cross_origin_authentication,custom_login_page_on:!!r.custom_login_page_on,require_pushed_authorization_requests:!!r.require_pushed_authorization_requests,require_proof_of_possession:!!r.require_proof_of_possession,hide_sign_up_disabled_error:!!r.hide_sign_up_disabled_error,callbacks:JSON.parse(r.callbacks),allowed_origins:JSON.parse(r.allowed_origins),web_origins:JSON.parse(r.web_origins),client_aliases:JSON.parse(r.client_aliases),allowed_clients:JSON.parse(r.allowed_clients),connections:JSON.parse(r.connections||`[]`),allowed_logout_urls:JSON.parse(r.allowed_logout_urls),session_transfer:JSON.parse(r.session_transfer),oidc_logout:JSON.parse(r.oidc_logout),grant_types:JSON.parse(r.grant_types),jwt_configuration:JSON.parse(r.jwt_configuration),signing_keys:JSON.parse(r.signing_keys),encryption_key:JSON.parse(r.encryption_key),addons:JSON.parse(r.addons),client_metadata:JSON.parse(r.client_metadata),mobile:JSON.parse(r.mobile),native_social_login:JSON.parse(r.native_social_login),refresh_token:JSON.parse(r.refresh_token),default_organization:JSON.parse(r.default_organization),client_authentication_methods:JSON.parse(r.client_authentication_methods),signed_request_object:JSON.parse(r.signed_request_object),token_quota:JSON.parse(r.token_quota),registration_metadata:r.registration_metadata?JSON.parse(r.registration_metadata):void 0})}}function Tt(e){return async t=>{let n=await e.selectFrom(`clients`).where(`clients.client_id`,`=`,t).selectAll().executeTakeFirst();return n?D({...n,global:!!n.global,is_first_party:!!n.is_first_party,oidc_conformant:!!n.oidc_conformant,auth0_conformant:!!n.auth0_conformant,sso:!!n.sso,sso_disabled:!!n.sso_disabled,cross_origin_authentication:!!n.cross_origin_authentication,custom_login_page_on:!!n.custom_login_page_on,require_pushed_authorization_requests:!!n.require_pushed_authorization_requests,require_proof_of_possession:!!n.require_proof_of_possession,hide_sign_up_disabled_error:!!n.hide_sign_up_disabled_error,callbacks:JSON.parse(n.callbacks),allowed_origins:JSON.parse(n.allowed_origins),web_origins:JSON.parse(n.web_origins),client_aliases:JSON.parse(n.client_aliases),allowed_clients:JSON.parse(n.allowed_clients),connections:JSON.parse(n.connections||`[]`),allowed_logout_urls:JSON.parse(n.allowed_logout_urls),session_transfer:JSON.parse(n.session_transfer),oidc_logout:JSON.parse(n.oidc_logout),grant_types:JSON.parse(n.grant_types),jwt_configuration:JSON.parse(n.jwt_configuration),signing_keys:JSON.parse(n.signing_keys),encryption_key:JSON.parse(n.encryption_key),addons:JSON.parse(n.addons),client_metadata:JSON.parse(n.client_metadata),mobile:JSON.parse(n.mobile),native_social_login:JSON.parse(n.native_social_login),refresh_token:JSON.parse(n.refresh_token),default_organization:JSON.parse(n.default_organization),client_authentication_methods:JSON.parse(n.client_authentication_methods),signed_request_object:JSON.parse(n.signed_request_object),token_quota:JSON.parse(n.token_quota),registration_metadata:n.registration_metadata?JSON.parse(n.registration_metadata):void 0}):null}}function Et(e){return async(t,n)=>{let r=e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t),a=new Set([`owner_user_id`,`registration_type`]);if(n?.q){let e=n.q.trim().match(/^([a-zA-Z_][a-zA-Z0-9_]*):"?([^"]*)"?$/);if(e&&a.has(e[1])&&e[2]){let t=e[1];r=r.where(t,`=`,e[2])}else r=r.where(e=>e.or([e(`name`,`like`,`%${n.q}%`),e(`client_id`,`like`,`%${n.q}%`)]))}if(n?.sort){let e=n.sort.sort_order===`asc`?`asc`:`desc`,t=n.sort.sort_by;r=[`name`,`client_id`,`created_at`,`updated_at`].includes(t)?r.orderBy(t,e):r.orderBy(`created_at`,`desc`)}else r=r.orderBy(`created_at`,`desc`);if(n?.from!==void 0){let e=parseInt(n.from,10);isNaN(e)||(r=r.offset(e))}else if(n?.page!==void 0){let e=n?.per_page||n?.take||10,t=n.page*e;r=r.offset(t)}let o=n?.take||n?.per_page||10;r=r.limit(o);let s=await r.selectAll().execute(),c=s.length;if(n?.include_totals){let r=e.selectFrom(`clients`).select(i.sql`count(*)`.as(`count`)).where(`clients.tenant_id`,`=`,t);if(n?.q){let e=n.q.trim().match(/^([a-zA-Z_][a-zA-Z0-9_]*):"?([^"]*)"?$/);if(e&&a.has(e[1])&&e[2]){let t=e[1];r=r.where(t,`=`,e[2])}else r=r.where(e=>e.or([e(`name`,`like`,`%${n.q}%`),e(`client_id`,`like`,`%${n.q}%`)]))}let o=await r.executeTakeFirst();c=Number(o?.count||0)}let l=s.map(e=>D({...e,global:!!e.global,is_first_party:!!e.is_first_party,oidc_conformant:!!e.oidc_conformant,auth0_conformant:!!e.auth0_conformant,sso:!!e.sso,sso_disabled:!!e.sso_disabled,cross_origin_authentication:!!e.cross_origin_authentication,custom_login_page_on:!!e.custom_login_page_on,require_pushed_authorization_requests:!!e.require_pushed_authorization_requests,require_proof_of_possession:!!e.require_proof_of_possession,hide_sign_up_disabled_error:!!e.hide_sign_up_disabled_error,callbacks:JSON.parse(e.callbacks),allowed_origins:JSON.parse(e.allowed_origins),web_origins:JSON.parse(e.web_origins),client_aliases:JSON.parse(e.client_aliases),allowed_clients:JSON.parse(e.allowed_clients),connections:JSON.parse(e.connections||`[]`),allowed_logout_urls:JSON.parse(e.allowed_logout_urls),session_transfer:JSON.parse(e.session_transfer),oidc_logout:JSON.parse(e.oidc_logout),grant_types:JSON.parse(e.grant_types),jwt_configuration:JSON.parse(e.jwt_configuration),signing_keys:JSON.parse(e.signing_keys),encryption_key:JSON.parse(e.encryption_key),addons:JSON.parse(e.addons),client_metadata:JSON.parse(e.client_metadata),mobile:JSON.parse(e.mobile),native_social_login:JSON.parse(e.native_social_login),refresh_token:JSON.parse(e.refresh_token),default_organization:JSON.parse(e.default_organization),client_authentication_methods:JSON.parse(e.client_authentication_methods),signed_request_object:JSON.parse(e.signed_request_object),token_quota:JSON.parse(e.token_quota),registration_metadata:e.registration_metadata?JSON.parse(e.registration_metadata):void 0})),u=n?.take||n?.per_page||10,d=n?.from?parseInt(n.from,10):n?.page?n.page*u:0;return{clients:l,totals:{start:isNaN(d)?0:d,limit:u,length:l.length,total:c}}}}function Dt(e){return async(t,n)=>(await e.deleteFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function Ot(e){return async(t,n,r)=>{let i={...r,updated_at:new Date().toISOString()};return Ne(r,[`global`,`is_first_party`,`oidc_conformant`,`auth0_conformant`,`sso`,`sso_disabled`,`cross_origin_authentication`,`custom_login_page_on`,`require_pushed_authorization_requests`,`require_proof_of_possession`,`hide_sign_up_disabled_error`],i),j(r,[`callbacks`,`allowed_origins`,`web_origins`,`client_aliases`,`allowed_clients`,`connections`,`allowed_logout_urls`,`session_transfer`,`oidc_logout`,`grant_types`,`jwt_configuration`,`signing_keys`,`encryption_key`,`addons`,`client_metadata`,`mobile`,`native_social_login`,`refresh_token`,`default_organization`,`client_authentication_methods`,`signed_request_object`,`token_quota`,`registration_metadata`],i),(await e.updateTable(`clients`).set(i).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).executeTakeFirst()).numUpdatedRows>0}}function kt(e){return{create:Ct(e),get:wt(e),getByClientId:Tt(e),list:Et(e),remove:Dt(e),update:Ot(e)}}function At(e){return async(t,n)=>{let r=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).select(`connections`).executeTakeFirst();if(!r)return[];let i=JSON.parse(r.connections||`[]`);if(i.length===0)return[];let a=await e.selectFrom(`connections`).where(`connections.tenant_id`,`=`,t).where(`connections.id`,`in`,i).selectAll().execute(),o=new Map(a.map(e=>[e.id,gt(e)]));return i.map(e=>o.get(e)).filter(e=>e!==void 0)}}function jt(e){return async(t,n,r)=>(await e.updateTable(`clients`).set({connections:JSON.stringify(r),updated_at:new Date().toISOString()}).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).executeTakeFirst()).numUpdatedRows>0}function Mt(e){return async(t,n)=>{let r=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).select([`client_id`,`connections`]).execute(),i=[];for(let e of r)JSON.parse(e.connections||`[]`).includes(n)&&i.push(e.client_id);return i}}function Nt(e){return async(t,n,r)=>{let i=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,r).select(`connections`).executeTakeFirst();if(!i)return!1;let a=JSON.parse(i.connections||`[]`);return a.includes(n)?!0:(a.push(n),(await e.updateTable(`clients`).set({connections:JSON.stringify(a),updated_at:new Date().toISOString()}).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,r).executeTakeFirst()).numUpdatedRows>0)}}function Pt(e){return async(t,n,r)=>{let i=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,r).select(`connections`).executeTakeFirst();if(!i)return!1;let a=JSON.parse(i.connections||`[]`),o=a.filter(e=>e!==n);return o.length===a.length?!0:(await e.updateTable(`clients`).set({connections:JSON.stringify(o),updated_at:new Date().toISOString()}).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,r).executeTakeFirst()).numUpdatedRows>0}}function Ft(e){return{listByClient:At(e),updateByClient:jt(e),listByConnection:Mt(e),addClientToConnection:Nt(e),removeClientFromConnection:Pt(e)}}function It(e){return async(t,r)=>{let i=new Date().toISOString(),a=(0,n.nanoid)(),{scope:o,authorization_details_types:s,...c}=r,l={id:a,tenant_id:t,...c,scope:o?JSON.stringify(o):`[]`,authorization_details_types:s?JSON.stringify(s):`[]`,allow_any_organization:c.allow_any_organization===void 0?void 0:+!!c.allow_any_organization,is_system:c.is_system===void 0?void 0:+!!c.is_system,created_at:i,updated_at:i};return await e.insertInto(`client_grants`).values(l).execute(),D({id:a,tenant_id:t,...c,scope:o||[],authorization_details_types:s||[],allow_any_organization:c.allow_any_organization??!1,is_system:c.is_system??!1,created_at:i,updated_at:i})}}function Lt(e){return async(t,n)=>{let r=await e.selectFrom(`client_grants`).selectAll().where(`client_grants.tenant_id`,`=`,t).where(`client_grants.id`,`=`,n).executeTakeFirst();return r?D({id:r.id,client_id:r.client_id,audience:r.audience,scope:r.scope?JSON.parse(r.scope):[],organization_usage:r.organization_usage,allow_any_organization:r.allow_any_organization===void 0?!1:!!r.allow_any_organization,is_system:r.is_system===void 0?!1:!!r.is_system,subject_type:r.subject_type,authorization_details_types:r.authorization_details_types?JSON.parse(r.authorization_details_types):[],created_at:r.created_at,updated_at:r.updated_at}):null}}function Rt(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,q:o,sort:s}=n,c=e.selectFrom(`client_grants`).where(`client_grants.tenant_id`,`=`,t);if(o){let t=o.trim(),n=t.split(/\s+/),r=n.length===1?n[0]:void 0,i=r?r.match(/^(-)?([a-zA-Z_][a-zA-Z0-9_]*):"?([^"]*)"?$/):null,a=i?i[3]:``,s=/^(>=|>|<=|<)/.test(a||``);if(i&&!s&&a){let t=!!i[1],n=i[2],{ref:r}=e.dynamic,o=r(`client_grants.${n}`);if(n===`allow_any_organization`){let e=+(a===`true`);c=t?c.where(o,`!=`,e):c.where(o,`=`,e)}else c=t?c.where(o,`!=`,a):c.where(o,`=`,a)}else c=C(e,c,t,[])}let l=c;if(s){let{ref:t}=e.dynamic;l=l.orderBy(t(s.sort_by),s.sort_order)}else l=l.orderBy(`client_grants.created_at`,`desc`);l=l.limit(i).offset(r*i);let u=(await l.selectAll().execute()).map(e=>D({id:e.id,client_id:e.client_id,audience:e.audience,scope:e.scope?JSON.parse(e.scope):[],organization_usage:e.organization_usage,allow_any_organization:e.allow_any_organization===void 0?!1:!!e.allow_any_organization,is_system:e.is_system===void 0?!1:!!e.is_system,subject_type:e.subject_type,authorization_details_types:e.authorization_details_types?JSON.parse(e.authorization_details_types):[],created_at:e.created_at,updated_at:e.updated_at}));if(!a)return{client_grants:u,start:0,limit:0,length:0};let{count:d}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{client_grants:u,start:r*i,limit:i,length:w(d)}}}function zt(e){return async(t,n)=>((await e.deleteFrom(`client_grants`).where(`client_grants.tenant_id`,`=`,t).where(`client_grants.id`,`=`,n).executeTakeFirst()).numDeletedRows??0n)>0n}function Bt(e){return async(t,n,r)=>{let i=new Date().toISOString(),{scope:a,authorization_details_types:o,...s}=r,c={...s,updated_at:i};return a!==void 0&&(c.scope=JSON.stringify(a)),o!==void 0&&(c.authorization_details_types=JSON.stringify(o)),s.allow_any_organization!==void 0&&(c.allow_any_organization=+!!s.allow_any_organization),s.is_system!==void 0&&(c.is_system=+!!s.is_system),((await e.updateTable(`client_grants`).set(c).where(`client_grants.tenant_id`,`=`,t).where(`client_grants.id`,`=`,n).executeTakeFirst()).numUpdatedRows??0n)>0n}}function Vt(e){return{create:It(e),get:Lt(e),list:Rt(e),remove:zt(e),update:Bt(e)}}function Ht(e){return async(t,n)=>{let r=Date.now();return await e.insertInto(`client_registration_tokens`).values({id:n.id,tenant_id:t,token_hash:n.token_hash,type:n.type,client_id:n.client_id??null,sub:n.sub??null,constraints:n.constraints?JSON.stringify(n.constraints):null,single_use:+!!n.single_use,expires_at_ts:y(n.expires_at),created_at_ts:r,used_at_ts:null,revoked_at_ts:null}).execute(),{id:n.id,token_hash:n.token_hash,type:n.type,client_id:n.client_id,sub:n.sub,constraints:n.constraints,single_use:n.single_use,expires_at:n.expires_at,created_at:new Date(r).toISOString()}}}function Ut(e){let t=r.clientRegistrationTokenTypeSchema.safeParse(e);if(!t.success)throw Error(`Unknown client_registration_tokens.type: ${e}`);return t.data}function Wt(e){if(!e)return;let t;try{t=JSON.parse(e)}catch{return}return(0,r.isPlainObject)(t)?t:void 0}function Gt(e){return{id:e.id,token_hash:e.token_hash,type:Ut(e.type),client_id:e.client_id??void 0,sub:e.sub??void 0,constraints:Wt(e.constraints),single_use:!!e.single_use,expires_at:_(e.expires_at_ts),used_at:_(e.used_at_ts),revoked_at:_(e.revoked_at_ts),created_at:v(e.created_at_ts)}}function Kt(e){return async(t,n)=>{let r=await e.selectFrom(`client_registration_tokens`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).selectAll().executeTakeFirst();return r?Gt(r):null}}function qt(e){return async(t,n)=>{let r=await e.selectFrom(`client_registration_tokens`).where(`tenant_id`,`=`,t).where(`token_hash`,`=`,n).selectAll().executeTakeFirst();return r?Gt(r):null}}function Jt(e){return async(t,n)=>(await e.selectFrom(`client_registration_tokens`).where(`tenant_id`,`=`,t).where(`client_id`,`=`,n).orderBy(`created_at_ts`,`desc`).selectAll().execute()).map(Gt)}function Yt(e){return async(t,n,r)=>(await e.updateTable(`client_registration_tokens`).set({used_at_ts:y(r)}).where(`tenant_id`,`=`,t).where(`id`,`=`,n).where(`used_at_ts`,`is`,null).executeTakeFirst()).numUpdatedRows>0}function Xt(e){return async(t,n,r)=>(await e.updateTable(`client_registration_tokens`).set({revoked_at_ts:y(r)}).where(`tenant_id`,`=`,t).where(`id`,`=`,n).where(`revoked_at_ts`,`is`,null).executeTakeFirst()).numUpdatedRows>0}function Zt(e){return async(t,n,r)=>{let i=await e.updateTable(`client_registration_tokens`).set({revoked_at_ts:y(r)}).where(`tenant_id`,`=`,t).where(`client_id`,`=`,n).where(`revoked_at_ts`,`is`,null).executeTakeFirst();return Number(i.numUpdatedRows)}}function Qt(e){return async(t,n)=>(await e.deleteFrom(`client_registration_tokens`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function $t(e){return{create:Ht(e),get:Kt(e),getByHash:qt(e),listByClient:Jt(e),markUsed:Yt(e),revoke:Xt(e),revokeByClient:Zt(e),remove:Qt(e)}}function en(e){return async(t={})=>{let{page:n=0,per_page:r=100,include_totals:i=!1,sort:a,q:o}=t,s=e.selectFrom(`keys`).where(e=>e.or([e(`revoked_at`,`>`,new Date().toISOString()),e(`revoked_at`,`is`,null)]));o&&(s=C(e,s,o,[`kid`,`tenant_id`,`connection`,`fingerprint`,`thumbprint`,`type`]));let c=s.select(e=>e.fn.count(`kid`).as(`count`)),l=n*r;s=s.limit(r).offset(l),a&&(s=s.orderBy(a.sort_by,a.sort_order));let u=await s.selectAll().execute();return i?{signingKeys:u,start:l,limit:r,length:w((await c.executeTakeFirst())?.count??0)}:{signingKeys:u,start:0,limit:0,length:0}}}function tn(e){return async t=>{await e.insertInto(`keys`).values({...t,created_at:new Date().toDateString()}).execute()}}function nn(e){return async(t,n)=>!!(await e.updateTable(`keys`).set(n).where(`kid`,`=`,t).execute()).length}function rn(e){return{create:tn(e),list:en(e),update:nn(e)}}function an(e){return async(t,r)=>{let i={custom_domain_id:r.custom_domain_id||(0,n.nanoid)(),status:`pending`,primary:!1,...r};return await e.insertInto(`custom_domains`).values({...i,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),tenant_id:t,primary:+!!i.primary,domain_metadata:i.domain_metadata?JSON.stringify(i.domain_metadata):void 0}).execute(),i}}function on(e){return async t=>(await e.selectFrom(`custom_domains`).where(`custom_domains.tenant_id`,`=`,t).selectAll().execute()).map(e=>({...e,primary:e.primary===1,domain_metadata:A(e.domain_metadata,void 0)}))}function sn(e){return async(t,n)=>(await e.deleteFrom(`custom_domains`).where(`custom_domains.tenant_id`,`=`,t).where(`custom_domains.custom_domain_id`,`=`,n).execute()).length>0}function cn(e){return async(t,n)=>{let r=await e.selectFrom(`custom_domains`).where(`custom_domains.tenant_id`,`=`,t).where(`custom_domains.custom_domain_id`,`=`,n).selectAll().executeTakeFirst();return r?{...r,primary:r.primary===1,domain_metadata:A(r.domain_metadata,void 0),verification:A(r.verification,void 0)}:null}}function ln(e){return async(t,n,r)=>{let{verification:i,domain_metadata:a,primary:o,...s}=r,c={...s,updated_at:new Date().toISOString(),...o!==void 0&&{primary:+!!o},...a!==void 0&&{domain_metadata:JSON.stringify(a)},...i!==void 0&&{verification:JSON.stringify(i)}};return(await e.updateTable(`custom_domains`).set(c).where(`custom_domains.tenant_id`,`=`,t).where(`custom_domains.custom_domain_id`,`=`,n).execute()).length>0}}function un(e){return async t=>{let n=await e.selectFrom(`custom_domains`).where(`custom_domains.domain`,`=`,t).selectAll().executeTakeFirst();return n?{...n,primary:n.primary===1,domain_metadata:A(n.domain_metadata,void 0)}:null}}function dn(e){return{create:an(e),get:cn(e),getByDomain:un(e),list:on(e),remove:sn(e),update:ln(e)}}function fn(e){return async t=>{let[n]=await e.selectFrom(`branding`).where(`branding.tenant_id`,`=`,t).selectAll().execute();if(!n)return null;let{tenant_id:r,colors_primary:i,colors_page_background_type:a,colors_page_background_start:o,colors_page_background_end:s,colors_page_background_angle_dev:c,font_url:l,...u}=n;return D({...u,colors:{primary:i,page_background:{type:a,start:o,end:s,angle_deg:c}},font:l?{url:l}:void 0})}}function pn(e){return async(t,n)=>{let{colors:r,font:i,...a}=n,o=r?.page_background,s=o&&typeof o==`object`?o:void 0;try{await e.insertInto(`branding`).values({...a,colors_primary:r?.primary,colors_page_background_type:s?.type,colors_page_background_start:s?.start,colors_page_background_end:s?.end,colors_page_background_angle_dev:s?.angle_deg,font_url:n.font?.url,tenant_id:t}).execute()}catch{await e.updateTable(`branding`).set({...a,colors_primary:r?.primary,colors_page_background_type:s?.type,colors_page_background_start:s?.start,colors_page_background_end:s?.end,colors_page_background_angle_dev:s?.angle_deg,font_url:n.font?.url}).where(`tenant_id`,`=`,t).execute()}}}function mn(e){return{get:fn(e),set:pn(e)}}function hn(e){return async t=>{let n=await e.selectFrom(`universal_login_templates`).select([`body`]).where(`tenant_id`,`=`,t).executeTakeFirst();return n?{body:n.body}:null}}function gn(e){return async(t,n)=>{let r=Date.now();try{await e.insertInto(`universal_login_templates`).values({tenant_id:t,body:n.body,created_at_ts:r,updated_at_ts:r}).execute()}catch{await e.updateTable(`universal_login_templates`).set({body:n.body,updated_at_ts:r}).where(`tenant_id`,`=`,t).execute()}}}function _n(e){return async t=>{await e.deleteFrom(`universal_login_templates`).where(`tenant_id`,`=`,t).execute()}}function vn(e){return{get:hn(e),set:gn(e),delete:_n(e)}}function yn(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`hooks`).where(`hooks.tenant_id`,`=`,t);if(s&&(c=C(e,c,s,[`url`,`form_id`,`template_id`,`code_id`])),o?.sort_by){let{ref:t}=e.dynamic;c=c.orderBy(t(o.sort_by),o.sort_order)}else c=c.orderBy(`priority`,`desc`).orderBy(`created_at_ts`,`asc`);let l=(await c.offset(r*i).limit(i).selectAll().execute()).map(e=>{let{tenant_id:t,enabled:n,synchronous:r,created_at_ts:i,updated_at_ts:a,metadata:o,...s}=e,c=x({created_at_ts:i,updated_at_ts:a},[`created_at_ts`,`updated_at_ts`]);return D({...s,...c,enabled:!!n,synchronous:!!r,metadata:Ee(o)})});if(!a)return{hooks:l,start:0,limit:0,length:0};let{count:u}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{hooks:l,start:r*i,limit:i,length:w(u)}}}function bn(e){return async(t,n)=>{let r=await e.selectFrom(`hooks`).where(`hooks.tenant_id`,`=`,t).where(`hooks.hook_id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,created_at_ts:a,updated_at_ts:o,metadata:s,...c}=r,l=x({created_at_ts:a,updated_at_ts:o},[`created_at_ts`,`updated_at_ts`]);return D({...c,...l,enabled:!!c.enabled,synchronous:!!c.synchronous,metadata:Ee(s)})}}function xn(e){return async(t,n)=>(await e.deleteFrom(`hooks`).where(`hooks.tenant_id`,`=`,t).where(`hooks.hook_id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function Sn(e){return async(t,n)=>{let r=Date.now(),i=n.hook_id||f(),{hook_id:a,enabled:o,synchronous:s,metadata:c,...l}=n;return await e.insertInto(`hooks`).values({...l,hook_id:i,tenant_id:t,enabled:+!!o,synchronous:+!!s,metadata:c?JSON.stringify(c):null,created_at_ts:r,updated_at_ts:r}).execute(),{...l,hook_id:i,enabled:o??!1,synchronous:s??!1,...c?{metadata:c}:{},created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function Cn(e){return async(t,n,r)=>{let{hook_id:i,metadata:a,...o}=r,s={...o,updated_at_ts:Date.now(),enabled:r.enabled===void 0?void 0:+!!r.enabled,synchronous:r.synchronous===void 0?void 0:+!!r.synchronous,...a===void 0?{}:{metadata:a===null?null:JSON.stringify(a)}};return await e.updateTable(`hooks`).set(s).where(`hooks.hook_id`,`=`,n).where(`hooks.tenant_id`,`=`,t).execute(),!0}}function wn(e){return{create:Sn(e),get:bn(e),list:yn(e),update:Cn(e),remove:xn(e)}}function Tn(e){return async(t,n)=>{let r=Date.now(),i=m();return await e.insertInto(`hook_code`).values({id:i,tenant_id:t,code:n.code,secrets:n.secrets?JSON.stringify(n.secrets):null,created_at_ts:r,updated_at_ts:r}).execute(),{id:i,tenant_id:t,code:n.code,secrets:n.secrets,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function En(e){return async(t,n)=>{let r=await e.selectFrom(`hook_code`).where(`hook_code.tenant_id`,`=`,t).where(`hook_code.id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{created_at_ts:i,updated_at_ts:a,secrets:o,...s}=r,c=x({created_at_ts:i,updated_at_ts:a},[`created_at_ts`,`updated_at_ts`]);return{...s,...c,secrets:o?(()=>{try{return JSON.parse(o)}catch{console.warn(`Failed to parse secrets for hook_code ${n}`);return}})():void 0}}}function Dn(e){return async(t,n,r)=>{let i={updated_at_ts:Date.now()};return r.code!==void 0&&(i.code=r.code),r.secrets!==void 0&&(i.secrets=JSON.stringify(r.secrets)),(await e.updateTable(`hook_code`).set(i).where(`hook_code.id`,`=`,n).where(`hook_code.tenant_id`,`=`,t).executeTakeFirst()).numUpdatedRows>0}}function On(e){return async(t,n)=>(await e.deleteFrom(`hook_code`).where(`hook_code.tenant_id`,`=`,t).where(`hook_code.id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function kn(e){return{create:Tn(e),get:En(e),update:Dn(e),remove:On(e)}}function An(e){return async(t,r,i)=>{let a={themeId:i||(0,n.nanoid)(),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...r},o={...a,tenant_id:t};return await e.insertInto(`themes`).values(k(o)).execute(),a}}function jn(e){return async(t,n)=>(await e.deleteFrom(`themes`).where(`themes.tenant_id`,`=`,t).where(`themes.themeId`,`=`,n).executeTakeFirst()).numDeletedRows>0}function Mn(e){return async(t,n)=>{let r=await e.selectFrom(`themes`).where(`themes.tenant_id`,`=`,t).where(`themes.themeId`,`=`,n).selectAll().executeTakeFirst();return r?D(xe({...r,borders_show_widget_shadow:!!r.borders_show_widget_shadow,fonts_body_text_bold:!!r.fonts_body_text_bold,fonts_buttons_text_bold:!!r.fonts_buttons_text_bold,fonts_input_labels_bold:!!r.fonts_input_labels_bold,fonts_links_bold:!!r.fonts_links_bold,fonts_subtitle_bold:!!r.fonts_subtitle_bold,fonts_title_bold:!!r.fonts_title_bold},[`widget`,`colors`,`borders`,`fonts`,`page_background`])):null}}function Nn(e){return async(t,n,r)=>{let{themeId:i,...a}=r,o=k({...a,updated_at:new Date().toISOString()});return await e.updateTable(`themes`).set(o).where(`themes.themeId`,`=`,n).where(`themes.tenant_id`,`=`,t).execute(),!0}}function Pn(e){return{create:An(e),get:Mn(e),remove:jn(e),update:Nn(e)}}function Fn(e){return async(t,n)=>{let i=await e.selectFrom(`login_sessions`).where(`login_sessions.id`,`=`,n).selectAll().executeTakeFirst();if(!i)return null;let{created_at_ts:a,updated_at_ts:o,expires_at_ts:s,auth_params:c,...l}=i,u=x({created_at_ts:a,updated_at_ts:o,expires_at_ts:s},[`created_at_ts`,`updated_at_ts`,`expires_at_ts`]),d=xe(D({...l,...u,state:i.state||r.LoginSessionState.PENDING,state_data:i.state_data,failure_reason:i.failure_reason}),[`auth_strategy`]);return d.authParams=typeof c==`string`&&c.length>0?JSON.parse(c):{},r.loginSessionSchema.parse(d)}}var In=`0123456789ABCDEFGHJKMNPQRSTVWXYZ`,Ln=32,Rn=10,zn=16;function Bn(e){let t=``;for(let n=Rn;n>0;n--)t=In.charAt(e%Ln)+t,e=Math.floor(e/Ln);return t}function Vn(){let e=new Uint8Array(zn);crypto.getRandomValues(e);let t=``;for(let n=0;n<zn;n++)t+=In.charAt(e[n]%Ln);return t}function Hn(){return Bn(Date.now())+Vn()}function Un(e){return async(t,n)=>{let i=b(),a={id:Hn(),...n,authorization_url:n.authorization_url?.slice(0,1024),created_at:i,updated_at:i,state:n.state||r.LoginSessionState.PENDING,state_data:n.state_data,failure_reason:n.failure_reason},{authParams:o,...s}=a,c=Date.now(),l=k(s);return delete l.created_at,delete l.updated_at,delete l.expires_at,await e.insertInto(`login_sessions`).values({...l,tenant_id:t,auth_params:JSON.stringify(o),created_at_ts:c,updated_at_ts:c,expires_at_ts:n.expires_at?new Date(n.expires_at).getTime():c+1e3*60*60*24}).execute(),a}}function Wn(e){return async(t,n,r)=>{let{created_at:i,updated_at:a,expires_at:o,authParams:s,...c}=r,l={};if(s!==void 0){let r=(await e.selectFrom(`login_sessions`).where(`login_sessions.id`,`=`,n).where(`login_sessions.tenant_id`,`=`,t).select([`auth_params`]).executeTakeFirst())?.auth_params,i=typeof r==`string`&&r.length>0?JSON.parse(r):{};l={auth_params:JSON.stringify({...i,...s})}}let u=k(c);return delete u.created_at_ts,delete u.updated_at_ts,delete u.expires_at_ts,delete u.id,delete u.tenant_id,(await e.updateTable(`login_sessions`).set({...u,...l,updated_at_ts:Date.now(),...o===void 0?{}:{expires_at_ts:y(o)}}).where(`login_sessions.id`,`=`,n).where(`login_sessions.tenant_id`,`=`,t).execute()).length===1}}function Gn(e){return async(t,n)=>(await e.deleteFrom(`login_sessions`).where(`login_sessions.tenant_id`,`=`,t).where(`login_sessions.id`,`=`,n).execute()).length>0}function Kn(e){return{create:Un(e),get:Fn(e),update:Wn(e),remove:Gn(e)}}function qn(e){return async t=>{let[n]=await e.selectFrom(`prompt_settings`).where(`prompt_settings.tenant_id`,`=`,t).selectAll().execute();return D({identifier_first:!!n?.identifier_first,password_first:!!n?.password_first,webauthn_platform_first_factor:!!n?.webauthn_platform_first_factor,universal_login_experience:n?.universal_login_experience||`new`})}}function Jn(e){let t={};return typeof e.identifier_first==`boolean`&&(t.identifier_first=+!!e.identifier_first),typeof e.password_first==`boolean`&&(t.password_first=+!!e.password_first),typeof e.webauthn_platform_first_factor==`boolean`&&(t.webauthn_platform_first_factor=+!!e.webauthn_platform_first_factor),e.universal_login_experience&&(t.universal_login_experience=e.universal_login_experience),t}function Yn(e){return async(t,n)=>{let r=Jn(n);try{await e.insertInto(`prompt_settings`).values({tenant_id:t,identifier_first:r.identifier_first??1,password_first:r.password_first??0,webauthn_platform_first_factor:r.webauthn_platform_first_factor??0,universal_login_experience:r.universal_login_experience??`new`}).execute()}catch{if(Object.keys(r).length===0)return;await e.updateTable(`prompt_settings`).set(r).where(`tenant_id`,`=`,t).execute()}}}function Xn(e){return{get:qn(e),set:Yn(e)}}function Zn(e){return async t=>{let[n]=await e.selectFrom(`email_providers`).where(`email_providers.tenant_id`,`=`,t).selectAll().execute();if(!n)return null;let{tenant_id:r,credentials:i,settings:a,enabled:o,...s}=n;return D({...s,credentials:JSON.parse(i),settings:JSON.parse(a),enabled:!!o})}}function Qn(e){return async(t,n)=>{let{credentials:r,settings:i,enabled:a,...o}=n;await e.updateTable(`email_providers`).set({...o,credentials:r?JSON.stringify(r):void 0,settings:i?JSON.stringify(i):void 0,enabled:a===void 0?void 0:+!!a}).where(`tenant_id`,`=`,t).execute()}}function $n(e){return async(t,n)=>{let{credentials:r,settings:i,enabled:a,...o}=n;await e.insertInto(`email_providers`).values({...o,enabled:+!!a,credentials:JSON.stringify(r),settings:JSON.stringify(i),tenant_id:t,created_at:new Date().toISOString(),updated_at:new Date().toISOString()}).execute()}}function er(e){return async t=>{await e.deleteFrom(`email_providers`).where(`tenant_id`,`=`,t).execute()}}function tr(e){return{get:Zn(e),create:$n(e),update:Qn(e),remove:er(e)}}function nr(e){let t={template:e.template,body:e.body,from:e.from,subject:e.subject,syntax:e.syntax,includeEmailInRedirect:!!e.include_email_in_redirect,enabled:!!e.enabled};return e.result_url!==null&&e.result_url!==void 0&&(t.resultUrl=e.result_url),e.url_lifetime_in_seconds!==null&&e.url_lifetime_in_seconds!==void 0&&(t.urlLifetimeInSeconds=e.url_lifetime_in_seconds),t}function rr(e){return async(t,n)=>{let i=await e.selectFrom(`email_templates`).where(`tenant_id`,`=`,t).where(`template`,`=`,n).selectAll().executeTakeFirst();return i?r.emailTemplateSchema.parse(nr(i)):null}}function ir(e){return async t=>(await e.selectFrom(`email_templates`).where(`tenant_id`,`=`,t).orderBy(`template`,`asc`).selectAll().execute()).map(e=>r.emailTemplateSchema.parse(nr(e)))}function ar(e){return async(t,n)=>{let r=new Date().toISOString();return await e.insertInto(`email_templates`).values({tenant_id:t,template:n.template,body:n.body,from:n.from,subject:n.subject,syntax:n.syntax,result_url:n.resultUrl??null,url_lifetime_in_seconds:n.urlLifetimeInSeconds??null,include_email_in_redirect:+!!n.includeEmailInRedirect,enabled:+!!n.enabled,created_at:r,updated_at:r}).execute(),n}}function or(e){return async(t,n,r)=>{let i={};if(r.body!==void 0&&(i.body=r.body),r.from!==void 0&&(i.from=r.from),r.subject!==void 0&&(i.subject=r.subject),r.syntax!==void 0&&(i.syntax=r.syntax),r.resultUrl!==void 0&&(i.result_url=r.resultUrl),r.urlLifetimeInSeconds!==void 0&&(i.url_lifetime_in_seconds=r.urlLifetimeInSeconds),r.includeEmailInRedirect!==void 0&&(i.include_email_in_redirect=+!!r.includeEmailInRedirect),r.enabled!==void 0&&(i.enabled=+!!r.enabled),Object.keys(i).length===0)return await e.selectFrom(`email_templates`).where(`tenant_id`,`=`,t).where(`template`,`=`,n).select(`template`).executeTakeFirst()!==void 0;i.updated_at=new Date().toISOString();let a=await e.updateTable(`email_templates`).set(i).where(`tenant_id`,`=`,t).where(`template`,`=`,n).executeTakeFirst();return Number(a.numUpdatedRows??0)>0}}function sr(e){return async(t,n)=>{let r=await e.deleteFrom(`email_templates`).where(`tenant_id`,`=`,t).where(`template`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows??0)>0}}function cr(e){return{get:rr(e),list:ir(e),create:ar(e),update:or(e),remove:sr(e)}}function lr(e){return async(t,n)=>{let r=await e.selectFrom(`refresh_tokens`).where(`refresh_tokens.tenant_id`,`=`,t).where(`refresh_tokens.id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,created_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,last_exchanged_at_ts:c,revoked_at_ts:l,rotated_at_ts:u,...d}=r,f=x({created_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,last_exchanged_at_ts:c,revoked_at_ts:l,rotated_at_ts:u},[`created_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`last_exchanged_at_ts`,`revoked_at_ts`,`rotated_at_ts`]);return{...d,...f,rotating:!!r.rotating,device:r.device?JSON.parse(r.device):{},resource_servers:r.resource_servers?JSON.parse(r.resource_servers):[]}}}function ur(e){return async(t,n)=>{let r=await e.selectFrom(`refresh_tokens`).where(`refresh_tokens.tenant_id`,`=`,t).where(`refresh_tokens.token_lookup`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,created_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,last_exchanged_at_ts:c,revoked_at_ts:l,rotated_at_ts:u,...d}=r,f=x({created_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,last_exchanged_at_ts:c,revoked_at_ts:l,rotated_at_ts:u},[`created_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`last_exchanged_at_ts`,`revoked_at_ts`,`rotated_at_ts`]);return{...d,...f,rotating:!!r.rotating,device:r.device?JSON.parse(r.device):{},resource_servers:r.resource_servers?JSON.parse(r.resource_servers):[]}}}function dr(e){return async(t,n)=>{let r=b(),i={...n,created_at:r},{expires_at:a,idle_expires_at:o,last_exchanged_at:s,rotated_at:c,device:l,resource_servers:u,rotating:d,...f}=n,p=Date.now(),m=y(a),h=o?y(o):null,g=Math.max(m??0,h??0);return await e.transaction().execute(async e=>{await e.insertInto(`refresh_tokens`).values({...f,tenant_id:t,rotating:+!!d,device:JSON.stringify(l),resource_servers:JSON.stringify(u),created_at_ts:p,expires_at_ts:m,idle_expires_at_ts:h,last_exchanged_at_ts:s?y(s):null,rotated_at_ts:c?y(c):null}).execute(),g>0&&n.login_id&&await e.updateTable(`login_sessions`).set({expires_at_ts:g,updated_at_ts:p}).where(`tenant_id`,`=`,t).where(`id`,`=`,n.login_id).where(`expires_at_ts`,`<`,g).execute()}),{...n,...i}}}function fr(e){return async(t,n)=>!!(await e.deleteFrom(`refresh_tokens`).where(`tenant_id`,`=`,t).where(`refresh_tokens.id`,`=`,n).execute()).length}function pr(e){return async(t,n,r)=>{let i=y(r),a=await e.updateTable(`refresh_tokens`).set({revoked_at_ts:i}).where(`tenant_id`,`=`,t).where(`login_id`,`=`,n).where(`revoked_at_ts`,`is`,null).executeTakeFirst();return Number(a.numUpdatedRows??0)}}function mr(e){return async(t,n,r)=>{let i=y(r),a=await e.updateTable(`refresh_tokens`).set({revoked_at_ts:i}).where(`tenant_id`,`=`,t).where(`family_id`,`=`,n).where(`revoked_at_ts`,`is`,null).executeTakeFirst();return Number(a.numUpdatedRows??0)}}function hr(e){return async(t,n,r,i)=>{let{created_at:a,expires_at:o,idle_expires_at:s,last_exchanged_at:c,revoked_at:l,rotated_at:u,device:d,resource_servers:f,rotating:p,...m}=r,h={...m,device:d?JSON.stringify(d):void 0,resource_servers:f?JSON.stringify(f):void 0,rotating:p===void 0?void 0:+!!p,expires_at_ts:o===void 0?void 0:y(o),idle_expires_at_ts:s===void 0?void 0:y(s),last_exchanged_at_ts:c===void 0?void 0:y(c),revoked_at_ts:l===void 0?void 0:y(l),rotated_at_ts:u===void 0?void 0:y(u)},g=i?.loginSessionBump,_=g?y(g.expires_at):null,v=await e.updateTable(`refresh_tokens`).set(h).where(`tenant_id`,`=`,t).where(`refresh_tokens.id`,`=`,n).executeTakeFirst();return g?.login_id&&_&&_>0&&await e.updateTable(`login_sessions`).set({expires_at_ts:_,updated_at_ts:Date.now()}).where(`tenant_id`,`=`,t).where(`id`,`=`,g.login_id).where(`expires_at_ts`,`<`,_).execute().catch(()=>{}),(v?.numUpdatedRows??0n)>0n}}function gr(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`refresh_tokens`).where(`refresh_tokens.tenant_id`,`=`,t);s&&(c=C(e,c,s,[`token`,`login_id`]));let l=c;if(o&&o.sort_by){let{ref:t}=e.dynamic;l=l.orderBy(t(o.sort_by),o.sort_order)}l=l.offset(r*i).limit(i);let u=(await l.selectAll().execute()).map(e=>{let{tenant_id:t,created_at_ts:n,expires_at_ts:r,idle_expires_at_ts:i,last_exchanged_at_ts:a,revoked_at_ts:o,rotated_at_ts:s,...c}=e,l=x({created_at_ts:n,expires_at_ts:r,idle_expires_at_ts:i,last_exchanged_at_ts:a,revoked_at_ts:o,rotated_at_ts:s},[`created_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`last_exchanged_at_ts`,`revoked_at_ts`,`rotated_at_ts`]);return{...c,...l,rotating:!!e.rotating,device:e.device?JSON.parse(e.device):{},resource_servers:e.resource_servers?JSON.parse(e.resource_servers):[]}});if(!a)return{refresh_tokens:u,start:0,limit:0,length:0};let{count:d}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow(),f=w(d);return{refresh_tokens:u,start:r*i,limit:i,length:f}}}function _r(e){return{create:dr(e),get:lr(e),getByLookup:ur(e),list:gr(e),remove:fr(e),revokeByLoginSession:pr(e),revokeFamily:mr(e),update:hr(e)}}var vr=10080*60*1e3;function yr(e){return async t=>{let{tenant_id:n,user_id:r}=t||{},i=Date.now()-vr,a=1e3;try{let t=0;for(;;){let o=e.deleteFrom(`refresh_tokens`).where(e=>e.or([e(`expires_at_ts`,`<`,i),e(`idle_expires_at_ts`,`<`,i)]));n&&(o=o.where(`tenant_id`,`=`,n)),r&&(o=o.where(`user_id`,`=`,r));let s=await o.limit(a).execute(),c=Number(s[0]?.numDeletedRows??0);if(t+=c,c<a)break}let o=0;for(;;){let t=e.deleteFrom(`sessions`).where(e=>e.or([e(`expires_at_ts`,`<`,i),e(`idle_expires_at_ts`,`<`,i)]));n&&(t=t.where(`tenant_id`,`=`,n)),r&&(t=t.where(`user_id`,`=`,r));let s=await t.limit(a).execute(),c=Number(s[0]?.numDeletedRows??0);if(o+=c,c<a)break}let s=0;for(;;){let t=e.deleteFrom(`login_sessions`).where(`expires_at_ts`,`<`,i);n&&(t=t.where(`tenant_id`,`=`,n)),r&&(t=t.where(`user_id`,`=`,r));let o=await t.limit(a).execute(),c=Number(o[0]?.numDeletedRows??0);if(s+=c,c<a)break}(t>0||o>0||s>0)&&console.log(`Session cleanup: deleted ${t} refresh_tokens, ${o} sessions, ${s} login_sessions`)}catch(e){console.error(`Error during session cleanup:`,e)}}}function br(e){return async(t,i)=>{let a=r.formSchema.parse({id:(0,n.nanoid)(),...i,created_at:new Date().toISOString(),updated_at:new Date().toISOString()});return await e.insertInto(`forms`).values({...a,nodes:JSON.stringify(a.nodes||[]),start:JSON.stringify(a.start||{}),ending:JSON.stringify(a.ending||{}),tenant_id:t}).execute(),r.formSchema.parse(a)}}function xr(e){return async(t,n={})=>{let{page:i=0,per_page:a=50,include_totals:o=!1,q:s}=n,c=e.selectFrom(`forms`).where(`tenant_id`,`=`,t);s&&(c=C(e,c,s,[]));let l=(await c.offset(i*a).limit(a).selectAll().execute()).map(e=>{let t={...e};if(typeof t.nodes==`string`)try{t.nodes=JSON.parse(t.nodes)}catch{}if(typeof t.start==`string`)try{t.start=JSON.parse(t.start)}catch{}if(typeof t.ending==`string`)try{t.ending=JSON.parse(t.ending)}catch{}return r.formSchema.parse(D(t))});if(!o)return{forms:l,start:0,limit:0,length:0};let{count:u}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{forms:l,start:i*a,limit:a,length:w(u)}}}function Sr(e){return async(t,n)=>{let{numDeletedRows:r}=await e.deleteFrom(`forms`).where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();return r>0}}function Cr(e){return async(t,n)=>{let i=await e.selectFrom(`forms`).selectAll().where(`forms.id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();if(!i)return null;let a={...i};if(typeof a.nodes==`string`)try{a.nodes=JSON.parse(a.nodes)}catch{}if(typeof a.start==`string`)try{a.start=JSON.parse(a.start)}catch{}if(typeof a.ending==`string`)try{a.ending=JSON.parse(a.ending)}catch{}return r.formSchema.parse(D(a))}}function wr(e){return async(t,n,r)=>{let i={...r,updated_at:new Date().toISOString()};j(r,[`nodes`,`start`,`ending`],i);let{numUpdatedRows:a}=await e.updateTable(`forms`).set(i).where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();return a>0}}function Tr(e){return{create:br(e),get:Cr(e),list:xr(e),remove:Sr(e),update:wr(e)}}function Er(e){return async(t,n)=>{let i=new Date().toISOString(),a={id:p(),...n,created_at:i,updated_at:i},o=r.resourceServerSchema.parse(a),{verificationKey:s,scopes:c,options:l,skip_consent_for_verifiable_first_party_clients:u,allow_offline_access:d,is_system:f,metadata:m,...h}=o,g={...h,tenant_id:t,scopes:c?JSON.stringify(c):`[]`,options:l?JSON.stringify(l):`{}`,skip_consent_for_verifiable_first_party_clients:+!!u,allow_offline_access:+!!d,is_system:+!!f,metadata:m?JSON.stringify(m):void 0,verification_key:s,created_at:i,updated_at:i};return await e.insertInto(`resource_servers`).values(g).execute(),D(o)}}function Dr(e){return async(t,n)=>{let r=await e.selectFrom(`resource_servers`).selectAll().where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();if(!r)return null;let{verification_key:i,scopes:a,options:o,skip_consent_for_verifiable_first_party_clients:s,allow_offline_access:c,is_system:l,metadata:u,...d}=r,f=D({...d,scopes:a?JSON.parse(a):[],options:o?JSON.parse(o):{},skip_consent_for_verifiable_first_party_clients:!!s,allow_offline_access:!!c,is_system:l?!0:void 0,metadata:u?JSON.parse(u):void 0,verificationKey:i});return f.token_lifetime??=86400,f.token_lifetime_for_web??=7200,f}}function Or(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,q:o}=n,s=e.selectFrom(`resource_servers`).where(`resource_servers.tenant_id`,`=`,t);if(o){let t=o.trim(),n=t.split(/\s+/),r=n.length===1?n[0]:void 0,i=r?r.match(/^(-)?(name|identifier):(.*)$/):null,a=i?i[3]:``,c=/^(>=|>|<=|<)/.test(a||``);if(i&&!c){let e=!!i[1],t=i[2]===`name`?`resource_servers.name`:`resource_servers.identifier`;s=e?s.where(t,`not like`,`%${a}%`):s.where(t,`like`,`%${a}%`)}else s=C(e,s,t,[`resource_servers.name`,`resource_servers.identifier`])}let c=(await s.offset(r*i).limit(i).selectAll().execute()).map(e=>{let{verification_key:t,scopes:n,options:r,skip_consent_for_verifiable_first_party_clients:i,allow_offline_access:a,is_system:o,metadata:s,...c}=e,l=D({...c,scopes:n?JSON.parse(n):[],options:r?JSON.parse(r):{},skip_consent_for_verifiable_first_party_clients:!!i,allow_offline_access:!!a,is_system:o?!0:void 0,metadata:s?JSON.parse(s):void 0,verificationKey:t});return l.token_lifetime??=86400,l.token_lifetime_for_web??=7200,l});if(!a)return{resource_servers:c,start:0,limit:0,length:0};let{count:l}=await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{resource_servers:c,start:r*i,limit:i,length:w(l)}}}function kr(e){return async(t,n)=>{let r=await e.deleteFrom(`resource_servers`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows)>0}}function Ar(e){return async(t,n,r)=>{let{verificationKey:i,scopes:a,options:o,skip_consent_for_verifiable_first_party_clients:s,allow_offline_access:c,is_system:l,metadata:u,...d}=r,f={...d,updated_at:new Date().toISOString()};if(i!==void 0&&(f.verification_key=i),a!==void 0&&(f.scopes=JSON.stringify(a)),o!==void 0){let r=await e.selectFrom(`resource_servers`).select(`options`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst(),i={...r?.options?JSON.parse(r.options):{},...o};f.options=JSON.stringify(i)}u!==void 0&&(f.metadata=JSON.stringify(u)),s!==void 0&&(f.skip_consent_for_verifiable_first_party_clients=+!!s),c!==void 0&&(f.allow_offline_access=+!!c),l!==void 0&&(f.is_system=+!!l);let p=await e.updateTable(`resource_servers`).set(f).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return Number(p.numUpdatedRows)>0}}function jr(e){return{create:Er(e),get:Dr(e),list:Or(e),remove:kr(e),update:Ar(e)}}function Mr(e){return async(t,r)=>{let i=new Date().toISOString(),a=r.id||(0,n.nanoid)(),{is_system:o,id:s,metadata:c,...l}=r,u={id:a,...l,tenant_id:t,is_system:+!!o,metadata:c?JSON.stringify(c):void 0,created_at:i,updated_at:i};return await e.insertInto(`roles`).values(u).execute(),{id:a,...l,is_system:o?!0:void 0,metadata:c,created_at:i,updated_at:i}}}function Nr(e){return async(t,n)=>{let r=await e.selectFrom(`roles`).selectAll().where(`roles.tenant_id`,`=`,t).where(`roles.id`,`=`,n).executeTakeFirst();if(!r)return null;let{is_system:i,tenant_id:a,metadata:o,...s}=r;return{...s,is_system:i?!0:void 0,metadata:o?JSON.parse(o):void 0}}}function Pr(e){return async(t,n)=>{let r=e.selectFrom(`roles`).where(`roles.tenant_id`,`=`,t),{page:i=0,per_page:a=50,include_totals:o=!1}=n;n.q&&(r=C(e,r,n.q,[`name`]));let s=(await r.offset(i*a).limit(a).selectAll().execute()).map(e=>{let{is_system:t,tenant_id:n,metadata:r,...i}=e;return{...i,is_system:t?!0:void 0,metadata:r?JSON.parse(r):void 0}});if(!o)return{roles:s,start:i*a,limit:a,length:s.length};let{count:c}=await r.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{roles:s,start:i*a,limit:a,length:w(c)}}}function Fr(e){return async(t,n,r)=>{let{is_system:i,metadata:a,...o}=r,s={...o,is_system:i===void 0?void 0:+!!i,metadata:a===void 0?void 0:JSON.stringify(a),updated_at:new Date().toISOString()},c=await e.updateTable(`roles`).set(s).where(`roles.tenant_id`,`=`,t).where(`roles.id`,`=`,n).executeTakeFirst();return Number(c.numUpdatedRows)>0}}function Ir(e){return async(t,n)=>{let r=await e.deleteFrom(`roles`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows)>0}}function Lr(e){return{create:Mr(e),get:Nr(e),list:Pr(e),update:Fr(e),remove:Ir(e)}}function Rr(e){return async(t,n,r)=>{if(r.length===0)return!0;let i=new Date().toISOString();try{for(let a of r){if(a.role_id!==n)throw Error(`Permission role_id ${a.role_id} does not match expected role_id ${n}`);let r={tenant_id:t,role_id:a.role_id,resource_server_identifier:a.resource_server_identifier,permission_name:a.permission_name,created_at:i};try{await e.insertInto(`role_permissions`).values(r).execute()}catch(e){if(e.code===`SQLITE_CONSTRAINT_PRIMARYKEY`||e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`)continue;throw e}}return!0}catch(e){return console.error(`Error assigning role permissions:`,e),!1}}}function zr(e){return async(t,n,r)=>{if(r.length===0)return!0;try{return(await Promise.all(r.map(r=>e.deleteFrom(`role_permissions`).where(`tenant_id`,`=`,t).where(`role_id`,`=`,n).where(`resource_server_identifier`,`=`,r.resource_server_identifier).where(`permission_name`,`=`,r.permission_name).executeTakeFirst()))).some(e=>Number(e.numDeletedRows)>0)}catch(e){return console.error(`Error removing role permissions:`,e),!1}}}function Br(e){return async(t,n,r={})=>{let{page:i=0,per_page:a=50,include_totals:o=!1}=r,s=e.selectFrom(`role_permissions`).leftJoin(`resource_servers`,e=>e.onRef(`role_permissions.tenant_id`,`=`,`resource_servers.tenant_id`).onRef(`role_permissions.resource_server_identifier`,`=`,`resource_servers.id`)).select([`role_permissions.role_id`,`role_permissions.resource_server_identifier`,`role_permissions.permission_name`,`role_permissions.created_at`,`resource_servers.name as resource_server_name`]).where(`role_permissions.tenant_id`,`=`,t).where(`role_permissions.role_id`,`=`,n),c=(await s.offset(i*a).limit(a).execute()).map(e=>({role_id:e.role_id,resource_server_identifier:e.resource_server_identifier,resource_server_name:e.resource_server_name||e.resource_server_identifier,permission_name:e.permission_name,description:null,created_at:e.created_at}));return o&&await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow(),c}}function Vr(e){return{assign:Rr(e),remove:zr(e),list:Br(e)}}function Hr(e){return async(t,r)=>{let i=new Date().toISOString(),a=r.scope??[],o=r.audience??``,s=await e.selectFrom(`grants`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,r.user_id).where(`client_id`,`=`,r.clientID).where(`audience`,`=`,o).selectAll().executeTakeFirst();if(s){let n=s.scope?JSON.parse(s.scope):[],r=Array.from(new Set([...n,...a]));return await e.updateTable(`grants`).set({scope:JSON.stringify(r),updated_at:i}).where(`tenant_id`,`=`,t).where(`id`,`=`,s.id).execute(),{id:s.id,user_id:s.user_id,clientID:s.client_id,audience:s.audience||void 0,scope:r}}let c=(0,n.nanoid)();return await e.insertInto(`grants`).values({id:c,tenant_id:t,user_id:r.user_id,client_id:r.clientID,audience:o,scope:JSON.stringify(a),created_at:i,updated_at:i}).execute(),{id:c,user_id:r.user_id,clientID:r.clientID,audience:o||void 0,scope:a}}}function Ur(e){return async(t,n,r,i)=>{let a=await e.selectFrom(`grants`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n).where(`client_id`,`=`,r).where(`audience`,`=`,i??``).selectAll().executeTakeFirst();return a?{id:a.id,user_id:a.user_id,clientID:a.client_id,audience:a.audience||void 0,scope:a.scope?JSON.parse(a.scope):[]}:null}}function Wr(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`grants`).where(`grants.tenant_id`,`=`,t);s&&(c=C(e,c,s,[`user_id`,`client_id`,`audience`]));let l=c;if(o&&o.sort_by){let{ref:t}=e.dynamic;l=l.orderBy(t(o.sort_by),o.sort_order)}l=l.offset(r*i).limit(i);let u=(await l.selectAll().execute()).map(e=>({id:e.id,user_id:e.user_id,clientID:e.client_id,audience:e.audience||void 0,scope:e.scope?JSON.parse(e.scope):[]}));if(!a)return{grants:u,start:0,limit:0,length:0};let{count:d}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{grants:u,start:r*i,limit:i,length:w(d)}}}function Gr(e){return async(t,n)=>(await e.deleteFrom(`grants`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function Kr(e){return async(t,n)=>(await e.deleteFrom(`grants`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function qr(e){return{create:Hr(e),get:Ur(e),list:Wr(e),remove:Gr(e),removeByUser:Kr(e)}}function Jr(e){return async(t,n,r,i)=>{let a=new Date().toISOString();try{let o={tenant_id:t,user_id:n,resource_server_identifier:r.resource_server_identifier,permission_name:r.permission_name,organization_id:i||r.organization_id||``,created_at:a};return await e.insertInto(`user_permissions`).values(o).execute(),!0}catch(e){return e.code===`SQLITE_CONSTRAINT_PRIMARYKEY`||e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`SQLITE_CONSTRAINT`||e.code===`ER_DUP_ENTRY`||e.message&&e.message.includes(`UNIQUE constraint failed`)||e.message&&e.message.includes(`PRIMARY KEY constraint failed`)?!0:(console.error(`Error creating user permission:`,e),!1)}}}function Yr(e){return async(t,n,r,i)=>{try{let a=e.deleteFrom(`user_permissions`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n).where(`resource_server_identifier`,`=`,r.resource_server_identifier).where(`permission_name`,`=`,r.permission_name);return a=i===void 0?a.where(`organization_id`,`=`,``):a.where(`organization_id`,`=`,i),await a.execute(),!0}catch(e){return console.error(`Error removing user permission:`,e),!1}}}function Xr(e){return async(t,n,r,i)=>{let a=e.selectFrom(`user_permissions`).leftJoin(`resource_servers`,e=>e.onRef(`user_permissions.tenant_id`,`=`,`resource_servers.tenant_id`).onRef(`user_permissions.resource_server_identifier`,`=`,`resource_servers.id`)).select([`user_permissions.resource_server_identifier`,`user_permissions.permission_name`,`resource_servers.name as resource_server_name`,`user_permissions.user_id`,`user_permissions.created_at`,`user_permissions.organization_id`]).where(`user_permissions.tenant_id`,`=`,t).where(`user_permissions.user_id`,`=`,n);return i!==void 0&&(a=a.where(`user_permissions.organization_id`,`=`,i)),(await a.execute()).map(e=>({resource_server_identifier:e.resource_server_identifier,permission_name:e.permission_name,description:null,resource_server_name:e.resource_server_name||e.resource_server_identifier,user_id:e.user_id,created_at:e.created_at,organization_id:e.organization_id===``?void 0:e.organization_id}))}}function Zr(e){return{create:Jr(e),remove:Yr(e),list:Xr(e)}}function Qr(e){let t=Zr(e);return{create:(e,n,r,i)=>t.create(e,n,r,i),remove:(e,n,r,i)=>t.remove(e,n,r,i),list:(e,n,r,i)=>t.list(e,n,r,i)}}function $r(e){return async(t,n,r,i)=>{let a=e.selectFrom(`user_roles as ur`).innerJoin(`roles as r`,e=>e.onRef(`ur.role_id`,`=`,`r.id`).onRef(`ur.tenant_id`,`=`,`r.tenant_id`)).select([`r.id`,`r.name`,`r.description`,`r.created_at`,`r.updated_at`]).where(`ur.tenant_id`,`=`,t).where(`ur.user_id`,`=`,n);return i!==void 0&&(a=a.where(`ur.organization_id`,`=`,i)),await a.execute()}}function ei(e){return async(t,n,r,i)=>{let a=new Date().toISOString();try{return await e.insertInto(`user_roles`).values({tenant_id:t,user_id:n,role_id:r,organization_id:i||``,created_at:a}).execute(),!0}catch(e){return e.code===`SQLITE_CONSTRAINT_PRIMARYKEY`||e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`SQLITE_CONSTRAINT`||e.code===`ER_DUP_ENTRY`||e.message&&e.message.includes(`UNIQUE constraint failed`)||e.message&&e.message.includes(`PRIMARY KEY constraint failed`)?!0:(console.error(`Error creating user role:`,e),!1)}}}function ti(e){return async(t,n,r,i)=>{try{let a=e.deleteFrom(`user_roles`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n).where(`role_id`,`=`,r);return a=i===void 0?a.where(`organization_id`,`=`,``):a.where(`organization_id`,`=`,i),await a.execute(),!0}catch(e){return console.error(`Error removing user roles:`,e),!1}}}function ni(e){return{list:$r(e),create:ei(e),remove:ti(e)}}function ri(e){let t=ni(e);return{list:(e,n,r,i)=>t.list(e,n,r,i),create:(e,n,r,i)=>t.create(e,n,r,i),remove:(e,n,r,i)=>t.remove(e,n,r,i)}}function ii(e){return async(t,n)=>{let r={...n,id:n.id||c(),tenant_id:t,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),branding:JSON.stringify(n.branding||{}),metadata:JSON.stringify(n.metadata||{}),enabled_connections:JSON.stringify(n.enabled_connections||[]),token_quota:JSON.stringify(n.token_quota||{})};try{await e.insertInto(`organizations`).values(r).execute()}catch(e){throw e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`||e.message.includes(`AlreadyExists`)?new E(409,{message:`Organization already exists`}):e}return{...n,id:r.id,created_at:r.created_at,updated_at:r.updated_at}}}function ai(e){return async(t,n)=>{let r=await e.selectFrom(`organizations`).selectAll().where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return r||=await e.selectFrom(`organizations`).selectAll().where(`tenant_id`,`=`,t).where(`name`,`=`,n).executeTakeFirst(),r?D({...r,branding:r.branding?JSON.parse(r.branding):{},metadata:r.metadata?JSON.parse(r.metadata):{},enabled_connections:r.enabled_connections?JSON.parse(r.enabled_connections):[],token_quota:r.token_quota?JSON.parse(r.token_quota):{}}):null}}var M=[`name`,`display_name`];function oi(e){return async(t,n)=>{let r=e.selectFrom(`organizations`).where(`tenant_id`,`=`,t);if(n?.q){let t=te(n.q,M);t&&(r=C(e,r,t,M))}if(n?.sort){let e=n.sort.sort_order===`asc`?`asc`:`desc`,t=n.sort.sort_by;r=[`name`,`display_name`,`created_at`].includes(t)?r.orderBy(t,e):r.orderBy(`created_at`,`desc`)}else r=r.orderBy(`created_at`,`desc`);let a=n?.take??n?.per_page,o=typeof a==`number`&&Number.isFinite(a)?Math.floor(a):NaN,s=o>=1?o:10,c=0;if(n?.from!==void 0){let e=parseInt(n.from,10);Number.isNaN(e)||(c=Math.max(0,e))}else typeof n?.page==`number`&&Number.isFinite(n.page)&&(c=Math.max(0,Math.floor(n.page)*s));c>0&&(r=r.offset(c)),r=r.limit(s);let l=await r.selectAll().execute(),u=l.length;if(n?.include_totals){let r=e.selectFrom(`organizations`).where(`tenant_id`,`=`,t);if(n?.q){let t=te(n.q,M);t&&(r=C(e,r,t,M))}let a=await r.select(i.sql`count(*)`.as(`count`)).executeTakeFirst();u=Number(a?.count||0)}let d=l.map(e=>D({...e,branding:e.branding?JSON.parse(e.branding):{},metadata:e.metadata?JSON.parse(e.metadata):{},enabled_connections:e.enabled_connections?JSON.parse(e.enabled_connections):[],token_quota:e.token_quota?JSON.parse(e.token_quota):{}}));return{organizations:d,start:c,limit:s,length:d.length,total:u}}}function si(e){return async(t,n)=>(await e.deleteFrom(`organizations`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).execute()).length>0}function ci(e){return async(t,n,r)=>{let{branding:i,metadata:a,enabled_connections:o,token_quota:s,...c}=r,l={...c,updated_at:new Date().toISOString()};return j(r,[`branding`,`metadata`,`enabled_connections`,`token_quota`],l),(await e.updateTable(`organizations`).set(l).where(`tenant_id`,`=`,t).where(`id`,`=`,n).execute()).length>0}}function li(e){return{create:ii(e),get:ai(e),list:oi(e),remove:si(e),update:ci(e)}}function N(e,t){return{connection_id:e.connection_id,assign_membership_on_login:!!e.assign_membership_on_login,show_as_button:!!e.show_as_button,is_signup_enabled:!!e.is_signup_enabled,connection:t?{name:t.name,strategy:t.strategy}:void 0,created_at:e.created_at,updated_at:e.updated_at}}async function P(e,t,n){let r=await e.selectFrom(`connections`).select([`name`,`strategy`]).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();if(r)return{name:r.name,strategy:typeof r.strategy==`string`?r.strategy:void 0}}function ui(e){return{async create(t,n,r){let i=new Date().toISOString(),a={tenant_id:t,organization_id:n,connection_id:r.connection_id,assign_membership_on_login:+!!r.assign_membership_on_login,show_as_button:r.show_as_button===!1?0:1,is_signup_enabled:r.is_signup_enabled===!1?0:1,created_at:i,updated_at:i};return await e.insertInto(`organization_connections`).values(a).execute(),N(a,await P(e,t,r.connection_id))},async list(t,n){let r=await e.selectFrom(`organization_connections`).selectAll().where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).execute(),i=[];for(let n of r){let r=await P(e,t,n.connection_id);i.push(N(n,r))}return i},async get(t,n,r){let i=await e.selectFrom(`organization_connections`).selectAll().where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).where(`connection_id`,`=`,r).executeTakeFirst();return i?N(i,await P(e,t,r)):null},async update(t,n,r,i){let a={updated_at:new Date().toISOString()};i.assign_membership_on_login!==void 0&&(a.assign_membership_on_login=+!!i.assign_membership_on_login),i.show_as_button!==void 0&&(a.show_as_button=+!!i.show_as_button),i.is_signup_enabled!==void 0&&(a.is_signup_enabled=+!!i.is_signup_enabled);let o=await e.updateTable(`organization_connections`).set(a).where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).where(`connection_id`,`=`,r).executeTakeFirst();if(Number(o.numUpdatedRows??0)===0)return null;let s=await e.selectFrom(`organization_connections`).selectAll().where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).where(`connection_id`,`=`,r).executeTakeFirst();return s?N(s,await P(e,t,r)):null},async remove(t,n,r){let i=await e.deleteFrom(`organization_connections`).where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).where(`connection_id`,`=`,r).executeTakeFirst();return Number(i.numDeletedRows??0)>0}}}function di(e){return async(t,r)=>{let i={id:(0,n.nanoid)(),tenant_id:t,user_id:r.user_id,organization_id:r.organization_id,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};try{await e.insertInto(`user_organizations`).values(i).execute()}catch(e){throw e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`?new E(409,{message:`User is already a member of this organization`}):e}return{...i}}}function fi(e){return async(t,n)=>{let r=await e.selectFrom(`user_organizations`).selectAll().where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();return r?{id:r.id,user_id:r.user_id,organization_id:r.organization_id,created_at:r.created_at,updated_at:r.updated_at}:null}}function pi(e){return async(t,n)=>{let r=n?.page||0,i=n?.per_page||50,a=r*i,o=e.selectFrom(`user_organizations`).selectAll().where(`tenant_id`,`=`,t);if(n?.q){if(n.q.startsWith(`user_id:`)){let e=n.q.replace(`user_id:`,``);o=o.where(`user_id`,`=`,e)}else if(n.q.startsWith(`organization_id:`)){let e=n.q.replace(`organization_id:`,``);o=o.where(`organization_id`,`=`,e)}}o=o.orderBy(`created_at`,`desc`),i>0&&(o=o.limit(i).offset(a));let s=await o.execute(),c=e.selectFrom(`user_organizations`).select(e.fn.count(`id`).as(`count`)).where(`tenant_id`,`=`,t);if(n?.q){if(n.q.startsWith(`user_id:`)){let e=n.q.replace(`user_id:`,``);c=c.where(`user_id`,`=`,e)}else if(n.q.startsWith(`organization_id:`)){let e=n.q.replace(`organization_id:`,``);c=c.where(`organization_id`,`=`,e)}}let l=await c.executeTakeFirst();return{userOrganizations:s.map(e=>({id:e.id,user_id:e.user_id,organization_id:e.organization_id,created_at:e.created_at,updated_at:e.updated_at})),start:a,limit:i,length:Number(l?.count||0)}}}function mi(e){return async(t,n,r)=>{let i=r?.page||0,a=r?.per_page||50,o=i*a,s=e.selectFrom(`user_organizations`).innerJoin(`organizations`,e=>e.onRef(`organizations.id`,`=`,`user_organizations.organization_id`).on(`organizations.tenant_id`,`=`,t)).select([`organizations.id`,`organizations.name`,`organizations.display_name`,`organizations.branding`,`organizations.metadata`,`organizations.enabled_connections`,`organizations.token_quota`,`organizations.created_at`,`organizations.updated_at`,`user_organizations.created_at as joined_at`]).where(`user_organizations.tenant_id`,`=`,t).where(`user_organizations.user_id`,`=`,n);s=s.orderBy(`user_organizations.created_at`,`desc`),a>0&&(s=s.limit(a).offset(o));let c=await s.execute(),l=await e.selectFrom(`user_organizations`).innerJoin(`organizations`,e=>e.onRef(`organizations.id`,`=`,`user_organizations.organization_id`).on(`organizations.tenant_id`,`=`,t)).select(e.fn.count(`user_organizations.id`).as(`count`)).where(`user_organizations.tenant_id`,`=`,t).where(`user_organizations.user_id`,`=`,n).executeTakeFirst();return{organizations:c.map(e=>({id:e.id,name:e.name,display_name:e.display_name,branding:e.branding?JSON.parse(e.branding):void 0,metadata:e.metadata?JSON.parse(e.metadata):{},enabled_connections:e.enabled_connections?JSON.parse(e.enabled_connections):[],token_quota:e.token_quota?JSON.parse(e.token_quota):void 0,created_at:e.created_at,updated_at:e.updated_at,joined_at:e.joined_at})),start:o,limit:a,length:Number(l?.count||0)}}}function hi(e){return async(t,n)=>(await e.deleteFrom(`user_organizations`).where(`id`,`=`,n).where(`tenant_id`,`=`,t).execute()).length>0}function gi(e){return async(t,n,r)=>{let i={...r,updated_at:new Date().toISOString()};return(await e.updateTable(`user_organizations`).set(i).where(`id`,`=`,n).where(`tenant_id`,`=`,t).execute()).length>0}}function _i(e){return{create:di(e),get:fi(e),list:pi(e),listUserOrganizations:mi(e),remove:hi(e),update:gi(e)}}function vi(e){return async(t,n)=>{let r=n.id||h(),i=new Date().toISOString(),a=n.ttl_sec||604800,o=new Date(Date.now()+a*1e3).toISOString(),s=j({id:r,tenant_id:t,organization_id:n.organization_id,inviter:n.inviter||{},invitee:n.invitee||{},client_id:n.client_id,connection_id:n.connection_id||null,invitation_url:n.invitation_url,created_at:i,expires_at:o,app_metadata:n.app_metadata||{},user_metadata:n.user_metadata||{},roles:n.roles||[],ticket_id:null,ttl_sec:a,send_invitation_email:n.send_invitation_email??!0?1:0},[`inviter`,`invitee`,`app_metadata`,`user_metadata`,`roles`]);try{await e.insertInto(`invites`).values(s).execute()}catch(e){throw e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`||e.message.includes(`AlreadyExists`)?new E(409,{message:`Invite already exists`}):e}return{id:r,organization_id:s.organization_id,inviter:n.inviter,invitee:n.invitee,client_id:n.client_id,connection_id:n.connection_id,invitation_url:n.invitation_url,created_at:i,expires_at:o,app_metadata:n.app_metadata||{},user_metadata:n.user_metadata||{},roles:n.roles||[],ticket_id:s.ticket_id||void 0,ttl_sec:a,send_invitation_email:n.send_invitation_email??!0}}}function yi(e){return async(t,n)=>{let r=await e.selectFrom(`invites`).selectAll().where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return r?D({...De(r,{inviter:{},invitee:{},app_metadata:{},user_metadata:{},roles:[]}),send_invitation_email:r.send_invitation_email===1}):null}}function bi(e){return async(t,n)=>{let r=e.selectFrom(`invites`).selectAll().where(`tenant_id`,`=`,t).orderBy(`created_at`,`desc`);if(n?.per_page&&(r=r.limit(n.per_page)),n?.page){let e=(n.page-1)*(n.per_page||10);r=r.offset(e)}let i=(await r.execute()).map(e=>D({...De(e,{inviter:{},invitee:{},app_metadata:{},user_metadata:{},roles:[]}),send_invitation_email:e.send_invitation_email===1}));return{invites:i,start:n?.page?(n.page-1)*(n.per_page||10):0,limit:n?.per_page||i.length,length:i.length}}}function xi(e){return async(t,n)=>(await e.deleteFrom(`invites`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst()).numDeletedRows>0n}function Si(e){return async(t,n,r)=>{let i={};return r.inviter!==void 0&&(i.inviter=JSON.stringify(r.inviter)),r.invitee!==void 0&&(i.invitee=JSON.stringify(r.invitee)),r.client_id!==void 0&&(i.client_id=r.client_id),r.connection_id!==void 0&&(i.connection_id=r.connection_id),r.app_metadata!==void 0&&(i.app_metadata=JSON.stringify(r.app_metadata)),r.user_metadata!==void 0&&(i.user_metadata=JSON.stringify(r.user_metadata)),r.roles!==void 0&&(i.roles=JSON.stringify(r.roles)),r.ttl_sec!==void 0&&(i.ttl_sec=r.ttl_sec,i.expires_at=new Date(Date.now()+r.ttl_sec*1e3).toISOString()),r.send_invitation_email!==void 0&&(i.send_invitation_email=+!!r.send_invitation_email),Object.keys(i).length===0?!0:(await e.updateTable(`invites`).set(i).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst()).numUpdatedRows>0n}}function Ci(e){return{create:vi(e),get:yi(e),list:bi(e),remove:xi(e),update:Si(e)}}var wi=[`s`],Ti=[`pwd_leak`];function Ei(e){return/^\d{8}$/.test(e)?`${e.slice(0,4)}-${e.slice(4,6)}-${e.slice(6,8)}`:e}function Di(e){return e.toISOString().split(`T`)[0]}function Oi(e){return{async getDaily(t,n={}){let{from:r,to:a}=n,o=new Date,s=new Date(o);s.setDate(s.getDate()-30);let c=r?Ei(r):Di(s),l=a?Ei(a):Di(o),u=i.sql`DATE(logs.date)`;return(await e.selectFrom(`logs`).where(`tenant_id`,`=`,t).where(u,`>=`,c).where(u,`<=`,l).select(e=>[u.as(`date`),e.fn.sum(e.case().when(`type`,`in`,wi).then(1).else(0).end()).as(`logins`),e.fn.sum(e.case().when(`type`,`=`,`ss`).then(1).else(0).end()).as(`signups`),e.fn.sum(e.case().when(`type`,`in`,Ti).then(1).else(0).end()).as(`leaked_passwords`),e.fn.min(`date`).as(`first_event`),e.fn.max(`date`).as(`last_event`)]).groupBy(u).orderBy(`date`,`asc`).execute()).map(e=>({date:e.date,logins:Number(e.logins)||0,signups:Number(e.signups)||0,leaked_passwords:Number(e.leaked_passwords)||0,created_at:e.first_event||new Date().toISOString(),updated_at:e.last_event||new Date().toISOString()}))},async getActiveUsers(t){let n=new Date;return n.setDate(n.getDate()-30),(await e.selectFrom(`logs`).where(`tenant_id`,`=`,t).where(`date`,`>=`,n.toISOString()).where(`type`,`in`,wi).where(`user_id`,`is not`,null).select(e=>e.fn.count(`user_id`).distinct().as(`count`)).executeTakeFirstOrThrow()).count||0}}}var ki={"active-users":[`s`,`seacft`],logins:[`s`,`f`,`fp`],signups:[`ss`,`fs`],"refresh-tokens":[`seacft`,`fertft`],sessions:[`slo`]},Ai={"active-users":{alias:`active_users`,type:`UInt64`,agg:`uniq`},logins:{alias:`logins`,type:`UInt64`,agg:`count`},signups:{alias:`signups`,type:`UInt64`,agg:`count`},"refresh-tokens":{alias:`refresh_tokens`,type:`UInt64`,agg:`count`},sessions:{alias:`sessions`,type:`UInt64`,agg:`count`}};async function ji(e){try{return await i.sql`SELECT @@version_comment`.execute(e),`mysql`}catch{return`sqlite`}}function F(e,t){let n=new Intl.DateTimeFormat(`en-US`,{timeZone:e,year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,hour12:!1}),r={};for(let e of n.formatToParts(t))r[e.type]=e.value;let i=r.hour===`24`?`00`:r.hour,a=Date.UTC(Number(r.year),Number(r.month)-1,Number(r.day),Number(i),Number(r.minute),Number(r.second)),o=Math.round((a-t.getTime())/6e4),s=o>=0?`+`:`-`,c=Math.abs(o);return`${s}${String(Math.floor(c/60)).padStart(2,`0`)}:${String(c%60).padStart(2,`0`)}`}var Mi=[`January`,`February`,`March`,`April`,`May`,`June`,`July`,`August`,`September`,`October`,`November`,`December`];function Ni(e,t){let n=t.getUTCFullYear(),r=F(e,new Date(Date.UTC(n,0,1)));for(let t=1;t<12;t++){let i=F(e,new Date(Date.UTC(n,t,1)));if(i!==r)throw Error(`Timezone '${e}' is DST-varying (offset ${r} in January vs ${i} in ${Mi[t]}) and cannot be bucketed with a single fixed offset by the SQL analytics adapter. Use a fixed-offset zone (e.g. 'UTC' or '+02:00').`)}}function Pi(e){let t=e.startsWith(`-`)?-1:1,[n,r]=e.slice(1).split(`:`);return t*(Number(n)*60+Number(r))}function Fi(e,t){let n;if(t===`+00:00`)n=i.sql`${i.sql.ref(`logs.date`)}`;else{let e=Pi(t),r=`${e>=0?`+`:`-`}${Math.abs(e)} minutes`;n=i.sql`datetime(${i.sql.ref(`logs.date`)}, ${r})`}switch(e){case`hour`:return i.sql`substr(${n}, 1, 13)`;case`month`:return i.sql`substr(${n}, 1, 7)`;case`day`:return i.sql`substr(${n}, 1, 10)`;case`week`:return i.sql`date(substr(${n}, 1, 10), '-' || ((cast(strftime('%w', substr(${n}, 1, 10)) as integer) + 6) % 7) || ' days')`;default:throw Error(`Unsupported interval '${e}' for SQL analytics adapter`)}}function Ii(e,t){if(t===`+00:00`)switch(e){case`hour`:return i.sql`substring(${i.sql.ref(`logs.date`)}, 1, 13)`;case`day`:return i.sql`substring(${i.sql.ref(`logs.date`)}, 1, 10)`;case`month`:return i.sql`substring(${i.sql.ref(`logs.date`)}, 1, 7)`;case`week`:{let e=i.sql`str_to_date(substring(${i.sql.ref(`logs.date`)}, 1, 10), '%Y-%m-%d')`;return i.sql`date_format(date_sub(${e}, interval weekday(${e}) day), '%Y-%m-%d')`}default:throw Error(`Unsupported interval '${e}' for SQL analytics adapter`)}let n=Pi(t),r=i.sql`date_add(str_to_date(substring(${i.sql.ref(`logs.date`)}, 1, 19), '%Y-%m-%dT%H:%i:%s'), interval ${i.sql.lit(n)} minute)`;switch(e){case`hour`:return i.sql`date_format(${r}, '%Y-%m-%dT%H')`;case`day`:return i.sql`date_format(${r}, '%Y-%m-%d')`;case`month`:return i.sql`date_format(${r}, '%Y-%m')`;case`week`:return i.sql`date_format(date_sub(${r}, interval weekday(${r}) day), '%Y-%m-%d')`;default:throw Error(`Unsupported interval '${e}' for SQL analytics adapter`)}}function Li(e,t,n,r){Ni(t,n);let i=F(t,n);return r===`mysql`?Ii(e,i):Fi(e,i)}function Ri(e){switch(e){case`connection`:return`logs.connection`;case`client_id`:return`logs.client_id`;case`user_type`:return`logs.strategy_type`;case`event`:return`logs.type`;case`time`:throw Error(`time dimension is handled separately`)}}function zi(e){let t=null,n=()=>(t||=ji(e),t);return{async query(t,r,a){let o=Date.now(),s=ki[r],c=Ai[r],l=await n(),u=[],d=e.selectFrom(`logs`).where(`tenant_id`,`=`,t);d=d.where(`date`,`>=`,a.from).where(`date`,`<`,a.to),d=d.where(`type`,`in`,s),a.filters.connection?.length&&(d=d.where(`connection`,`in`,a.filters.connection)),a.filters.client_id?.length&&(d=d.where(`client_id`,`in`,a.filters.client_id)),a.filters.user_type?.length&&(d=d.where(`strategy_type`,`in`,a.filters.user_type)),a.filters.user_id?.length&&(d=d.where(`user_id`,`in`,a.filters.user_id));let f=[],p=[];for(let e of a.group_by)if(e===`time`){let e=Li(a.interval,a.tz,new Date(a.from),l);p.push({alias:`time`,expr:e}),f.push(e),u.push({name:`time`,type:a.interval===`hour`?`DateTime`:`Date`})}else{let t=Ri(e);p.push({alias:e,expr:i.sql`${i.sql.ref(t)}`}),f.push(i.sql`${i.sql.ref(t)}`),u.push({name:e,type:`String`})}let m=c.agg===`uniq`?i.sql`COUNT(DISTINCT ${i.sql.ref(`logs.user_id`)})`:i.sql`COUNT(*)`;p.push({alias:c.alias,expr:m}),u.push({name:c.alias,type:c.type});let h=d.select(p.map(({alias:e,expr:t})=>t.as(e)));if(f.length>0&&(h=h.groupBy(f)),a.order_by){let e=a.order_by.startsWith(`-`),t=e?a.order_by.slice(1):a.order_by;h=h.orderBy(t,e?`desc`:`asc`)}else h=a.group_by.length>0&&a.group_by[0]===`time`?h.orderBy(`time`,`asc`):h.orderBy(c.alias,`desc`);h=h.limit(a.limit).offset(a.offset);let g=(await h.execute()).map(e=>{let t={};for(let n of u){let r=e[n.name];t[n.name]=n.type===`UInt64`?Number(r)||0:r??``}return t});return{meta:u,data:g,rows:g.length,rows_before_limit_at_least:g.length,statistics:{elapsed:(Date.now()-o)/1e3}}}}}function Bi(e){return{async get(t,n,r){let i=await e.selectFrom(`custom_text`).selectAll().where(`tenant_id`,`=`,t).where(`prompt`,`=`,n).where(`language`,`=`,r).executeTakeFirst();if(!i)return null;try{return JSON.parse(i.custom_text)}catch{return null}},async set(t,n,r,i){let a=Date.now(),o=JSON.stringify(i);await e.selectFrom(`custom_text`).select(`tenant_id`).where(`tenant_id`,`=`,t).where(`prompt`,`=`,n).where(`language`,`=`,r).executeTakeFirst()?await e.updateTable(`custom_text`).set({custom_text:o,updated_at_ts:a}).where(`tenant_id`,`=`,t).where(`prompt`,`=`,n).where(`language`,`=`,r).execute():await e.insertInto(`custom_text`).values({tenant_id:t,prompt:n,language:r,custom_text:o,created_at_ts:a,updated_at_ts:a}).execute()},async delete(t,n,r){await e.deleteFrom(`custom_text`).where(`tenant_id`,`=`,t).where(`prompt`,`=`,n).where(`language`,`=`,r).execute()},async list(t){return(await e.selectFrom(`custom_text`).select([`prompt`,`language`]).where(`tenant_id`,`=`,t).execute()).map(e=>({prompt:e.prompt,language:e.language}))}}}function Vi(e){return async(t,n)=>{let r=Date.now(),i=Hn();return await e.insertInto(`authentication_methods`).values({id:i,tenant_id:t,user_id:n.user_id,type:n.type,phone_number:n.phone_number,totp_secret:n.totp_secret,credential_id:n.credential_id,public_key:n.public_key,sign_count:n.sign_count,credential_backed_up:n.credential_backed_up==null?void 0:+!!n.credential_backed_up,transports:n.transports?JSON.stringify(n.transports):void 0,friendly_name:n.friendly_name,confirmed:+!!n.confirmed,created_at_ts:r,updated_at_ts:r}).execute(),{id:i,user_id:n.user_id,type:n.type,phone_number:n.phone_number,totp_secret:n.totp_secret,credential_id:n.credential_id,public_key:n.public_key,sign_count:n.sign_count,credential_backed_up:n.credential_backed_up,transports:n.transports,friendly_name:n.friendly_name,confirmed:n.confirmed??!1,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function Hi(e){return async(t,n)=>{let r=await e.selectFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.id`,`=`,n).selectAll().executeTakeFirst();return r?{id:r.id,user_id:r.user_id,type:r.type,phone_number:r.phone_number??void 0,totp_secret:r.totp_secret??void 0,credential_id:r.credential_id??void 0,public_key:r.public_key??void 0,sign_count:r.sign_count??void 0,credential_backed_up:r.credential_backed_up==null?void 0:r.credential_backed_up===1,transports:r.transports?JSON.parse(r.transports):void 0,friendly_name:r.friendly_name??void 0,confirmed:r.confirmed===1,created_at:v(r.created_at_ts),updated_at:v(r.updated_at_ts)}:null}}function Ui(e){return async(t,n)=>{let r=await e.selectFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.credential_id`,`=`,n).selectAll().executeTakeFirst();return r?{id:r.id,user_id:r.user_id,type:r.type,phone_number:r.phone_number??void 0,totp_secret:r.totp_secret??void 0,credential_id:r.credential_id??void 0,public_key:r.public_key??void 0,sign_count:r.sign_count??void 0,credential_backed_up:r.credential_backed_up==null?void 0:r.credential_backed_up===1,transports:r.transports?JSON.parse(r.transports):void 0,friendly_name:r.friendly_name??void 0,confirmed:r.confirmed===1,created_at:v(r.created_at_ts),updated_at:v(r.updated_at_ts)}:null}}function Wi(e){return async(t,n)=>(await e.selectFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.user_id`,`=`,n).selectAll().execute()).map(e=>({id:e.id,user_id:e.user_id,type:e.type,phone_number:e.phone_number??void 0,totp_secret:e.totp_secret??void 0,credential_id:e.credential_id??void 0,public_key:e.public_key??void 0,sign_count:e.sign_count??void 0,credential_backed_up:e.credential_backed_up==null?void 0:e.credential_backed_up===1,transports:e.transports?JSON.parse(e.transports):void 0,friendly_name:e.friendly_name??void 0,confirmed:e.confirmed===1,created_at:v(e.created_at_ts),updated_at:v(e.updated_at_ts)}))}function Gi(e){return async(t,n,r)=>{let i={updated_at_ts:Date.now()};r.phone_number!==void 0&&(i.phone_number=r.phone_number),r.totp_secret!==void 0&&(i.totp_secret=r.totp_secret),r.credential_id!==void 0&&(i.credential_id=r.credential_id),r.public_key!==void 0&&(i.public_key=r.public_key),r.sign_count!==void 0&&(i.sign_count=r.sign_count),r.credential_backed_up!==void 0&&(i.credential_backed_up=+!!r.credential_backed_up),r.transports!==void 0&&(i.transports=JSON.stringify(r.transports)),r.friendly_name!==void 0&&(i.friendly_name=r.friendly_name),r.confirmed!==void 0&&(i.confirmed=+!!r.confirmed),await e.updateTable(`authentication_methods`).set(i).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.id`,`=`,n).execute();let a=await Hi(e)(t,n);if(!a)throw Error(`Authentication method ${n} not found`);return a}}function Ki(e){return async(t,n)=>(await e.deleteFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function qi(e){return{create:Vi(e),get:Hi(e),getByCredentialId:Ui(e),list:Wi(e),update:Gi(e),remove:Ki(e)}}function Ji(e){return async(t,r)=>{let i=(0,n.nanoid)();return await e.insertInto(`outbox_events`).values({id:i,tenant_id:t,event_type:r.event_type,log_type:r.log_type,aggregate_type:r.target.type,aggregate_id:r.target.id,payload:JSON.stringify({...r,id:i}),created_at:new Date().toISOString(),processed_at:null,retry_count:0,next_retry_at:null,error:null}).execute(),i}}function Yi(e){return async t=>t.length===0?[]:(await e.selectFrom(`outbox_events`).selectAll().where(`id`,`in`,t).execute()).map(e=>({...JSON.parse(e.payload),id:e.id,created_at:e.created_at,processed_at:e.processed_at,retry_count:e.retry_count,next_retry_at:e.next_retry_at,error:e.error}))}function Xi(e){return async t=>{let n=new Date().toISOString();return(await e.selectFrom(`outbox_events`).selectAll().where(`processed_at`,`is`,null).where(e=>e.or([e(`next_retry_at`,`is`,null),e(`next_retry_at`,`<=`,n)])).where(e=>e.or([e(`claimed_by`,`is`,null),e(`claim_expires_at`,`<=`,n)])).orderBy(`created_at`,`asc`).orderBy(`id`,`asc`).limit(t).execute()).map(e=>({...JSON.parse(e.payload),id:e.id,created_at:e.created_at,processed_at:e.processed_at,retry_count:e.retry_count,next_retry_at:e.next_retry_at,error:e.error}))}}function Zi(e){return async(t,n,r)=>{if(t.length===0)return[];let i=new Date().toISOString(),a=new Date(Date.now()+r).toISOString();return await e.updateTable(`outbox_events`).set({claimed_by:n,claim_expires_at:a}).where(`id`,`in`,t).where(`processed_at`,`is`,null).where(e=>e.or([e(`claimed_by`,`is`,null),e(`claim_expires_at`,`<=`,i)])).execute(),(await e.selectFrom(`outbox_events`).select(`id`).where(`id`,`in`,t).where(`claimed_by`,`=`,n).where(`claim_expires_at`,`=`,a).execute()).map(e=>e.id)}}function Qi(e){return async t=>{if(t.length===0)return;let n=new Date().toISOString();await e.updateTable(`outbox_events`).set({processed_at:n}).where(`id`,`in`,t).execute()}}function $i(e){return async(t,n,r)=>{await e.updateTable(`outbox_events`).set({error:n,next_retry_at:r,retry_count:i.sql`retry_count + 1`,claimed_by:null,claim_expires_at:null}).where(`id`,`=`,t).execute()}}function ea(e){return async(t,n)=>{let r=new Date().toISOString();await e.updateTable(`outbox_events`).set({processed_at:r,dead_lettered_at:r,final_error:n}).where(`id`,`=`,t).execute()}}function ta(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1}=n,o=(await e.selectFrom(`outbox_events`).selectAll().where(`tenant_id`,`=`,t).where(`dead_lettered_at`,`is not`,null).orderBy(`dead_lettered_at`,`desc`).orderBy(`id`,`asc`).offset(r*i).limit(i).execute()).flatMap(e=>{let t;try{t=JSON.parse(e.payload)}catch(t){return console.error(`Failed to parse outbox payload for event ${e.id}`,t),[]}return[{...t,id:e.id,created_at:e.created_at,processed_at:e.processed_at,retry_count:e.retry_count,next_retry_at:e.next_retry_at,error:e.error,dead_lettered_at:e.dead_lettered_at,final_error:e.final_error}]}),s=o.length;if(a){let[n]=await e.selectFrom(`outbox_events`).select(e=>e.fn.countAll().as(`total`)).where(`tenant_id`,`=`,t).where(`dead_lettered_at`,`is not`,null).execute();s=Number(n?.total??o.length)}return{events:o,start:r*i,limit:i,length:s}}}function na(e){return async(t,n)=>{let r=await e.updateTable(`outbox_events`).set({processed_at:null,dead_lettered_at:null,final_error:null,retry_count:0,next_retry_at:null,error:null}).where(`id`,`=`,t).where(`tenant_id`,`=`,n).where(`dead_lettered_at`,`is not`,null).executeTakeFirst();return Number(r.numUpdatedRows)>0}}function ra(e){return async t=>{let n=await e.deleteFrom(`outbox_events`).where(`processed_at`,`is not`,null).where(`processed_at`,`<`,t).executeTakeFirst();return Number(n.numDeletedRows)}}function ia(e){return{create:Ji(e),getByIds:Yi(e),getUnprocessed:Xi(e),claimEvents:Zi(e),markProcessed:Qi(e),markRetry:$i(e),deadLetter:ea(e),listFailed:ta(e),replay:na(e),cleanup:ra(e)}}function I(e){return{id:e.id,name:e.name,type:e.type,status:e.status,sink:JSON.parse(e.sink),filters:e.filters?JSON.parse(e.filters):void 0,isPriority:e.is_priority==null?void 0:e.is_priority===1,created_at:e.created_at,updated_at:e.updated_at}}function aa(e){return{async create(t,r){let i=new Date().toISOString(),a={id:`lst_${(0,n.nanoid)()}`,tenant_id:t,name:r.name,type:r.type,status:r.status??`active`,sink:JSON.stringify(r.sink),filters:r.filters?JSON.stringify(r.filters):null,is_priority:r.isPriority===void 0?null:+!!r.isPriority,created_at:i,updated_at:i};return await e.insertInto(`log_streams`).values(a).execute(),I(a)},async get(t,n){let r=await e.selectFrom(`log_streams`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).selectAll().executeTakeFirst();return r?I(r):null},async list(t){return(await e.selectFrom(`log_streams`).where(`tenant_id`,`=`,t).selectAll().execute()).map(I)},async update(t,n,r){let i={updated_at:new Date().toISOString()};return r.name!==void 0&&(i.name=r.name),r.type!==void 0&&(i.type=r.type),r.status!==void 0&&(i.status=r.status),r.sink!==void 0&&(i.sink=JSON.stringify(r.sink)),r.filters!==void 0&&(i.filters=r.filters?JSON.stringify(r.filters):null),r.isPriority!==void 0&&(i.is_priority=+!!r.isPriority),((await e.updateTable(`log_streams`).set(i).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst())?.numUpdatedRows??0n)>0n},async remove(t,n){return((await e.deleteFrom(`log_streams`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst())?.numDeletedRows??0n)>0n}}}function L(e){return{id:e.id,name:e.name,provider:r.migrationProviderTypeSchema.parse(e.provider),connection:e.connection,enabled:e.enabled===1,credentials:JSON.parse(e.credentials),created_at:e.created_at,updated_at:e.updated_at}}function oa(e){return{async create(t,r){let i=new Date().toISOString(),a=r.id??`mig_${(0,n.nanoid)()}`,o=r.enabled??!0,s={id:a,tenant_id:t,name:r.name,provider:r.provider,connection:r.connection,enabled:+!!o,credentials:JSON.stringify(r.credentials),created_at:i,updated_at:i};return await e.insertInto(`migration_sources`).values(s).execute(),L(s)},async get(t,n){let r=await e.selectFrom(`migration_sources`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).selectAll().executeTakeFirst();return r?L(r):null},async list(t){return(await e.selectFrom(`migration_sources`).where(`tenant_id`,`=`,t).selectAll().execute()).map(L)},async update(t,n,r){let i={updated_at:new Date().toISOString()};return r.name!==void 0&&(i.name=r.name),r.provider!==void 0&&(i.provider=r.provider),r.connection!==void 0&&(i.connection=r.connection),r.enabled!==void 0&&(i.enabled=+!!r.enabled),r.credentials!==void 0&&(i.credentials=JSON.stringify(r.credentials)),((await e.updateTable(`migration_sources`).set(i).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst())?.numUpdatedRows??0n)>0n},async remove(t,n){return((await e.deleteFrom(`migration_sources`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst())?.numDeletedRows??0n)>0n}}}function R(e){return{id:e.id,tenant_id:e.tenant_id,custom_domain_id:e.custom_domain_id,priority:e.priority,match:sa(e.match),handlers:ca(e.handlers),created_at:e.created_at,updated_at:e.updated_at}}function sa(e){if(!e)return{path:`/*`};try{let t=JSON.parse(e),n=r.matchSchema.safeParse(t);if(n.success)return n.data}catch{}return{path:`/*`}}function ca(e){if(!e)return[];try{let t=JSON.parse(e);if(!Array.isArray(t))return[];let n=[];for(let e of t){let t=r.handlerConfigSchema.safeParse(e);t.success&&n.push(t.data)}return n}catch{return[]}}function z(e){return{async create(t,r){let i=new Date().toISOString(),a={id:r.id||(0,n.nanoid)(),tenant_id:t,custom_domain_id:r.custom_domain_id,priority:r.priority,match:r.match,handlers:r.handlers,created_at:i,updated_at:i};return await e.insertInto(`proxy_routes`).values({id:a.id,tenant_id:a.tenant_id,custom_domain_id:a.custom_domain_id,priority:a.priority,match:JSON.stringify(a.match),handlers:JSON.stringify(a.handlers),created_at:a.created_at,updated_at:a.updated_at}).execute(),a},async get(t,n){let r=await e.selectFrom(`proxy_routes`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).selectAll().executeTakeFirst();return r?R(r):null},async list(t,n={}){let r=n.page??0,i=n.per_page??50,a=e.selectFrom(`proxy_routes`).where(`tenant_id`,`=`,t);n.custom_domain_id&&(a=a.where(`custom_domain_id`,`=`,n.custom_domain_id));let o=await a.selectAll().orderBy(`priority`,`asc`).orderBy(`created_at`,`asc`).offset(r*i).limit(i).execute();return{proxy_routes:o.map(R),start:r*i,limit:i,length:o.length}},async update(t,n,r){let i={updated_at:new Date().toISOString()};r.priority!==void 0&&(i.priority=r.priority),r.match!==void 0&&(i.match=JSON.stringify(r.match)),r.handlers!==void 0&&(i.handlers=JSON.stringify(r.handlers));let a=await e.updateTable(`proxy_routes`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).set(i).executeTakeFirst();return Number(a.numUpdatedRows)>0},async remove(t,n){let r=await e.deleteFrom(`proxy_routes`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows)>0}}}async function la(e,t){let n=t.indexOf(`:`),r=n===-1?t:t.slice(0,n),i=(r.endsWith(`.`)?r.slice(0,-1):r).toLowerCase(),a=await e.selectFrom(`custom_domains`).where(`domain`,`=`,i).select([`custom_domain_id`,`tenant_id`,`domain`]).executeTakeFirst();if(!a)return null;let o=await e.selectFrom(`proxy_routes`).where(`tenant_id`,`=`,a.tenant_id).where(`custom_domain_id`,`=`,a.custom_domain_id).selectAll().orderBy(`priority`,`asc`).orderBy(`created_at`,`asc`).execute();return{tenant_id:a.tenant_id,custom_domain_id:a.custom_domain_id,domain:a.domain,routes:o.map(R)}}function ua(e){return{proxyRoutes:z(e),resolveHost:t=>la(e,t)}}function da(e){return typeof e==`string`}function fa(e){return typeof e==`object`&&!!e}function pa(e){return e[e.length-1]}function B(e){return Object.freeze(e)}var ma=class{transformQuery(e){return e.node}async transformResult(e){return e.result}},ha=B({is(e){return e.kind===`AliasNode`},create(e,t){return B({kind:`AliasNode`,node:e,alias:t})}}),V=B({is(e){return e.kind===`IdentifierNode`},create(e){return B({kind:`IdentifierNode`,name:e})}}),ga=B({is(e){return e.kind===`AndNode`},create(e,t){return B({kind:`AndNode`,left:e,right:t})}}),_a=B({is(e){return e.kind===`OrNode`},create(e,t){return B({kind:`OrNode`,left:e,right:t})}}),H=B({is(e){return e.kind===`OnNode`},create(e){return B({kind:`OnNode`,on:e})},cloneWithOperation(e,t,n){return B({...e,on:t===`And`?ga.create(e.on,n):_a.create(e.on,n)})}}),va=B({is(e){return e.kind===`JoinNode`},create(e,t){return B({kind:`JoinNode`,joinType:e,table:t,on:void 0})},createWithOn(e,t,n){return B({kind:`JoinNode`,joinType:e,table:t,on:H.create(n)})},cloneWithOn(e,t){return B({...e,on:e.on?H.cloneWithOperation(e.on,`And`,t):H.create(t)})}}),ya=B({is(e){return e.kind===`ListNode`},create(e){return B({kind:`ListNode`,items:B(e)})}}),ba=class{nodeStack=[];#e=B({AliasNode:this.transformAlias.bind(this),ColumnNode:this.transformColumn.bind(this),IdentifierNode:this.transformIdentifier.bind(this),SchemableIdentifierNode:this.transformSchemableIdentifier.bind(this),RawNode:this.transformRaw.bind(this),ReferenceNode:this.transformReference.bind(this),SelectQueryNode:this.transformSelectQuery.bind(this),SelectionNode:this.transformSelection.bind(this),TableNode:this.transformTable.bind(this),FromNode:this.transformFrom.bind(this),SelectAllNode:this.transformSelectAll.bind(this),AndNode:this.transformAnd.bind(this),OrNode:this.transformOr.bind(this),ValueNode:this.transformValue.bind(this),ValueListNode:this.transformValueList.bind(this),PrimitiveValueListNode:this.transformPrimitiveValueList.bind(this),ParensNode:this.transformParens.bind(this),JoinNode:this.transformJoin.bind(this),OperatorNode:this.transformOperator.bind(this),WhereNode:this.transformWhere.bind(this),InsertQueryNode:this.transformInsertQuery.bind(this),DeleteQueryNode:this.transformDeleteQuery.bind(this),ReturningNode:this.transformReturning.bind(this),CreateTableNode:this.transformCreateTable.bind(this),AddColumnNode:this.transformAddColumn.bind(this),ColumnDefinitionNode:this.transformColumnDefinition.bind(this),DropTableNode:this.transformDropTable.bind(this),DataTypeNode:this.transformDataType.bind(this),OrderByNode:this.transformOrderBy.bind(this),OrderByItemNode:this.transformOrderByItem.bind(this),GroupByNode:this.transformGroupBy.bind(this),GroupByItemNode:this.transformGroupByItem.bind(this),UpdateQueryNode:this.transformUpdateQuery.bind(this),ColumnUpdateNode:this.transformColumnUpdate.bind(this),LimitNode:this.transformLimit.bind(this),OffsetNode:this.transformOffset.bind(this),OnConflictNode:this.transformOnConflict.bind(this),OnDuplicateKeyNode:this.transformOnDuplicateKey.bind(this),CreateIndexNode:this.transformCreateIndex.bind(this),DropIndexNode:this.transformDropIndex.bind(this),ListNode:this.transformList.bind(this),PrimaryKeyConstraintNode:this.transformPrimaryKeyConstraint.bind(this),UniqueConstraintNode:this.transformUniqueConstraint.bind(this),ReferencesNode:this.transformReferences.bind(this),CheckConstraintNode:this.transformCheckConstraint.bind(this),WithNode:this.transformWith.bind(this),CommonTableExpressionNode:this.transformCommonTableExpression.bind(this),CommonTableExpressionNameNode:this.transformCommonTableExpressionName.bind(this),HavingNode:this.transformHaving.bind(this),CreateSchemaNode:this.transformCreateSchema.bind(this),DropSchemaNode:this.transformDropSchema.bind(this),AlterTableNode:this.transformAlterTable.bind(this),DropColumnNode:this.transformDropColumn.bind(this),RenameColumnNode:this.transformRenameColumn.bind(this),AlterColumnNode:this.transformAlterColumn.bind(this),ModifyColumnNode:this.transformModifyColumn.bind(this),AddConstraintNode:this.transformAddConstraint.bind(this),DropConstraintNode:this.transformDropConstraint.bind(this),RenameConstraintNode:this.transformRenameConstraint.bind(this),ForeignKeyConstraintNode:this.transformForeignKeyConstraint.bind(this),CreateViewNode:this.transformCreateView.bind(this),RefreshMaterializedViewNode:this.transformRefreshMaterializedView.bind(this),DropViewNode:this.transformDropView.bind(this),GeneratedNode:this.transformGenerated.bind(this),DefaultValueNode:this.transformDefaultValue.bind(this),OnNode:this.transformOn.bind(this),ValuesNode:this.transformValues.bind(this),SelectModifierNode:this.transformSelectModifier.bind(this),CreateTypeNode:this.transformCreateType.bind(this),DropTypeNode:this.transformDropType.bind(this),ExplainNode:this.transformExplain.bind(this),DefaultInsertValueNode:this.transformDefaultInsertValue.bind(this),AggregateFunctionNode:this.transformAggregateFunction.bind(this),OverNode:this.transformOver.bind(this),PartitionByNode:this.transformPartitionBy.bind(this),PartitionByItemNode:this.transformPartitionByItem.bind(this),SetOperationNode:this.transformSetOperation.bind(this),BinaryOperationNode:this.transformBinaryOperation.bind(this),UnaryOperationNode:this.transformUnaryOperation.bind(this),UsingNode:this.transformUsing.bind(this),FunctionNode:this.transformFunction.bind(this),CaseNode:this.transformCase.bind(this),WhenNode:this.transformWhen.bind(this),JSONReferenceNode:this.transformJSONReference.bind(this),JSONPathNode:this.transformJSONPath.bind(this),JSONPathLegNode:this.transformJSONPathLeg.bind(this),JSONOperatorChainNode:this.transformJSONOperatorChain.bind(this),TupleNode:this.transformTuple.bind(this),MergeQueryNode:this.transformMergeQuery.bind(this),MatchedNode:this.transformMatched.bind(this),AddIndexNode:this.transformAddIndex.bind(this),CastNode:this.transformCast.bind(this),FetchNode:this.transformFetch.bind(this),TopNode:this.transformTop.bind(this),OutputNode:this.transformOutput.bind(this),OrActionNode:this.transformOrAction.bind(this),CollateNode:this.transformCollate.bind(this),AlterTypeNode:this.transformAlterType.bind(this),AddValueNode:this.transformAddValue.bind(this),RenameValueNode:this.transformRenameValue.bind(this)});transformNode(e,t){if(!e)return e;this.nodeStack.push(e);let n=this.transformNodeImpl(e,t);return this.nodeStack.pop(),B(n)}transformNodeImpl(e,t){return this.#e[e.kind](e,t)}transformNodeList(e,t){return e&&B(e.map(e=>this.transformNode(e,t)))}transformSelectQuery(e,t){return{kind:`SelectQueryNode`,from:this.transformNode(e.from,t),selections:this.transformNodeList(e.selections,t),distinctOn:this.transformNodeList(e.distinctOn,t),joins:this.transformNodeList(e.joins,t),groupBy:this.transformNode(e.groupBy,t),orderBy:this.transformNode(e.orderBy,t),where:this.transformNode(e.where,t),frontModifiers:this.transformNodeList(e.frontModifiers,t),endModifiers:this.transformNodeList(e.endModifiers,t),limit:this.transformNode(e.limit,t),offset:this.transformNode(e.offset,t),with:this.transformNode(e.with,t),having:this.transformNode(e.having,t),explain:this.transformNode(e.explain,t),setOperations:this.transformNodeList(e.setOperations,t),fetch:this.transformNode(e.fetch,t),top:this.transformNode(e.top,t)}}transformSelection(e,t){return{kind:`SelectionNode`,selection:this.transformNode(e.selection,t)}}transformColumn(e,t){return{kind:`ColumnNode`,column:this.transformNode(e.column,t)}}transformAlias(e,t){return{kind:`AliasNode`,node:this.transformNode(e.node,t),alias:this.transformNode(e.alias,t)}}transformTable(e,t){return{kind:`TableNode`,table:this.transformNode(e.table,t)}}transformFrom(e,t){return{kind:`FromNode`,froms:this.transformNodeList(e.froms,t)}}transformReference(e,t){return{kind:`ReferenceNode`,column:this.transformNode(e.column,t),table:this.transformNode(e.table,t)}}transformAnd(e,t){return{kind:`AndNode`,left:this.transformNode(e.left,t),right:this.transformNode(e.right,t)}}transformOr(e,t){return{kind:`OrNode`,left:this.transformNode(e.left,t),right:this.transformNode(e.right,t)}}transformValueList(e,t){return{kind:`ValueListNode`,values:this.transformNodeList(e.values,t)}}transformParens(e,t){return{kind:`ParensNode`,node:this.transformNode(e.node,t)}}transformJoin(e,t){return{kind:`JoinNode`,joinType:e.joinType,table:this.transformNode(e.table,t),on:this.transformNode(e.on,t)}}transformRaw(e,t){return{kind:`RawNode`,sqlFragments:B([...e.sqlFragments]),parameters:this.transformNodeList(e.parameters,t)}}transformWhere(e,t){return{kind:`WhereNode`,where:this.transformNode(e.where,t)}}transformInsertQuery(e,t){return{kind:`InsertQueryNode`,into:this.transformNode(e.into,t),columns:this.transformNodeList(e.columns,t),values:this.transformNode(e.values,t),returning:this.transformNode(e.returning,t),onConflict:this.transformNode(e.onConflict,t),onDuplicateKey:this.transformNode(e.onDuplicateKey,t),endModifiers:this.transformNodeList(e.endModifiers,t),with:this.transformNode(e.with,t),orAction:this.transformNode(e.orAction,t),replace:e.replace,explain:this.transformNode(e.explain,t),defaultValues:e.defaultValues,top:this.transformNode(e.top,t),output:this.transformNode(e.output,t)}}transformValues(e,t){return{kind:`ValuesNode`,values:this.transformNodeList(e.values,t)}}transformDeleteQuery(e,t){return{kind:`DeleteQueryNode`,from:this.transformNode(e.from,t),using:this.transformNode(e.using,t),joins:this.transformNodeList(e.joins,t),where:this.transformNode(e.where,t),returning:this.transformNode(e.returning,t),endModifiers:this.transformNodeList(e.endModifiers,t),with:this.transformNode(e.with,t),orderBy:this.transformNode(e.orderBy,t),limit:this.transformNode(e.limit,t),explain:this.transformNode(e.explain,t),top:this.transformNode(e.top,t),output:this.transformNode(e.output,t)}}transformReturning(e,t){return{kind:`ReturningNode`,selections:this.transformNodeList(e.selections,t)}}transformCreateTable(e,t){return{kind:`CreateTableNode`,table:this.transformNode(e.table,t),columns:this.transformNodeList(e.columns,t),constraints:this.transformNodeList(e.constraints,t),indexes:this.transformNodeList(e.indexes,t),temporary:e.temporary,ifNotExists:e.ifNotExists,onCommit:e.onCommit,frontModifiers:this.transformNodeList(e.frontModifiers,t),endModifiers:this.transformNodeList(e.endModifiers,t),selectQuery:this.transformNode(e.selectQuery,t)}}transformColumnDefinition(e,t){return{kind:`ColumnDefinitionNode`,column:this.transformNode(e.column,t),dataType:this.transformNode(e.dataType,t),references:this.transformNode(e.references,t),primaryKey:e.primaryKey,autoIncrement:e.autoIncrement,unique:e.unique,notNull:e.notNull,unsigned:e.unsigned,defaultTo:this.transformNode(e.defaultTo,t),check:this.transformNode(e.check,t),generated:this.transformNode(e.generated,t),frontModifiers:this.transformNodeList(e.frontModifiers,t),endModifiers:this.transformNodeList(e.endModifiers,t),nullsNotDistinct:e.nullsNotDistinct,identity:e.identity,ifNotExists:e.ifNotExists}}transformAddColumn(e,t){return{kind:`AddColumnNode`,column:this.transformNode(e.column,t)}}transformDropTable(e,t){return{kind:`DropTableNode`,table:this.transformNode(e.table,t),ifExists:e.ifExists,cascade:e.cascade,temporary:e.temporary}}transformOrderBy(e,t){return{kind:`OrderByNode`,items:this.transformNodeList(e.items,t)}}transformOrderByItem(e,t){return{kind:`OrderByItemNode`,orderBy:this.transformNode(e.orderBy,t),direction:this.transformNode(e.direction,t),collation:this.transformNode(e.collation,t),nulls:e.nulls}}transformGroupBy(e,t){return{kind:`GroupByNode`,items:this.transformNodeList(e.items,t)}}transformGroupByItem(e,t){return{kind:`GroupByItemNode`,groupBy:this.transformNode(e.groupBy,t)}}transformUpdateQuery(e,t){return{kind:`UpdateQueryNode`,table:this.transformNode(e.table,t),from:this.transformNode(e.from,t),joins:this.transformNodeList(e.joins,t),where:this.transformNode(e.where,t),updates:this.transformNodeList(e.updates,t),returning:this.transformNode(e.returning,t),endModifiers:this.transformNodeList(e.endModifiers,t),with:this.transformNode(e.with,t),explain:this.transformNode(e.explain,t),limit:this.transformNode(e.limit,t),top:this.transformNode(e.top,t),output:this.transformNode(e.output,t),orderBy:this.transformNode(e.orderBy,t)}}transformColumnUpdate(e,t){return{kind:`ColumnUpdateNode`,column:this.transformNode(e.column,t),value:this.transformNode(e.value,t)}}transformLimit(e,t){return{kind:`LimitNode`,limit:this.transformNode(e.limit,t)}}transformOffset(e,t){return{kind:`OffsetNode`,offset:this.transformNode(e.offset,t)}}transformOnConflict(e,t){return{kind:`OnConflictNode`,columns:this.transformNodeList(e.columns,t),constraint:this.transformNode(e.constraint,t),indexExpression:this.transformNode(e.indexExpression,t),indexWhere:this.transformNode(e.indexWhere,t),updates:this.transformNodeList(e.updates,t),updateWhere:this.transformNode(e.updateWhere,t),doNothing:e.doNothing}}transformOnDuplicateKey(e,t){return{kind:`OnDuplicateKeyNode`,updates:this.transformNodeList(e.updates,t)}}transformCreateIndex(e,t){return{kind:`CreateIndexNode`,name:this.transformNode(e.name,t),table:this.transformNode(e.table,t),columns:this.transformNodeList(e.columns,t),unique:e.unique,using:this.transformNode(e.using,t),ifNotExists:e.ifNotExists,where:this.transformNode(e.where,t),nullsNotDistinct:e.nullsNotDistinct}}transformList(e,t){return{kind:`ListNode`,items:this.transformNodeList(e.items,t)}}transformDropIndex(e,t){return{kind:`DropIndexNode`,name:this.transformNode(e.name,t),table:this.transformNode(e.table,t),ifExists:e.ifExists,cascade:e.cascade}}transformPrimaryKeyConstraint(e,t){return{kind:`PrimaryKeyConstraintNode`,columns:this.transformNodeList(e.columns,t),name:this.transformNode(e.name,t),deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformUniqueConstraint(e,t){return{kind:`UniqueConstraintNode`,columns:this.transformNodeList(e.columns,t),name:this.transformNode(e.name,t),nullsNotDistinct:e.nullsNotDistinct,deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformForeignKeyConstraint(e,t){return{kind:`ForeignKeyConstraintNode`,columns:this.transformNodeList(e.columns,t),references:this.transformNode(e.references,t),name:this.transformNode(e.name,t),onDelete:e.onDelete,onUpdate:e.onUpdate,deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformSetOperation(e,t){return{kind:`SetOperationNode`,operator:e.operator,expression:this.transformNode(e.expression,t),all:e.all}}transformReferences(e,t){return{kind:`ReferencesNode`,table:this.transformNode(e.table,t),columns:this.transformNodeList(e.columns,t),onDelete:e.onDelete,onUpdate:e.onUpdate}}transformCheckConstraint(e,t){return{kind:`CheckConstraintNode`,expression:this.transformNode(e.expression,t),name:this.transformNode(e.name,t)}}transformWith(e,t){return{kind:`WithNode`,expressions:this.transformNodeList(e.expressions,t),recursive:e.recursive}}transformCommonTableExpression(e,t){return{kind:`CommonTableExpressionNode`,name:this.transformNode(e.name,t),materialized:e.materialized,expression:this.transformNode(e.expression,t)}}transformCommonTableExpressionName(e,t){return{kind:`CommonTableExpressionNameNode`,table:this.transformNode(e.table,t),columns:this.transformNodeList(e.columns,t)}}transformHaving(e,t){return{kind:`HavingNode`,having:this.transformNode(e.having,t)}}transformCreateSchema(e,t){return{kind:`CreateSchemaNode`,schema:this.transformNode(e.schema,t),ifNotExists:e.ifNotExists}}transformDropSchema(e,t){return{kind:`DropSchemaNode`,schema:this.transformNode(e.schema,t),ifExists:e.ifExists,cascade:e.cascade}}transformAlterTable(e,t){return{kind:`AlterTableNode`,table:this.transformNode(e.table,t),renameTo:this.transformNode(e.renameTo,t),setSchema:this.transformNode(e.setSchema,t),columnAlterations:this.transformNodeList(e.columnAlterations,t),addConstraint:this.transformNode(e.addConstraint,t),dropConstraint:this.transformNode(e.dropConstraint,t),renameConstraint:this.transformNode(e.renameConstraint,t),addIndex:this.transformNode(e.addIndex,t),dropIndex:this.transformNode(e.dropIndex,t)}}transformDropColumn(e,t){return{kind:`DropColumnNode`,column:this.transformNode(e.column,t),ifExists:e.ifExists}}transformRenameColumn(e,t){return{kind:`RenameColumnNode`,column:this.transformNode(e.column,t),renameTo:this.transformNode(e.renameTo,t)}}transformAlterColumn(e,t){return{kind:`AlterColumnNode`,column:this.transformNode(e.column,t),dataType:this.transformNode(e.dataType,t),dataTypeExpression:this.transformNode(e.dataTypeExpression,t),setDefault:this.transformNode(e.setDefault,t),dropDefault:e.dropDefault,setNotNull:e.setNotNull,dropNotNull:e.dropNotNull}}transformModifyColumn(e,t){return{kind:`ModifyColumnNode`,column:this.transformNode(e.column,t)}}transformAddConstraint(e,t){return{kind:`AddConstraintNode`,constraint:this.transformNode(e.constraint,t)}}transformDropConstraint(e,t){return{kind:`DropConstraintNode`,constraintName:this.transformNode(e.constraintName,t),ifExists:e.ifExists,modifier:e.modifier}}transformRenameConstraint(e,t){return{kind:`RenameConstraintNode`,oldName:this.transformNode(e.oldName,t),newName:this.transformNode(e.newName,t)}}transformCreateView(e,t){return{kind:`CreateViewNode`,name:this.transformNode(e.name,t),temporary:e.temporary,orReplace:e.orReplace,ifNotExists:e.ifNotExists,materialized:e.materialized,columns:this.transformNodeList(e.columns,t),as:this.transformNode(e.as,t)}}transformRefreshMaterializedView(e,t){return{kind:`RefreshMaterializedViewNode`,name:this.transformNode(e.name,t),concurrently:e.concurrently,withNoData:e.withNoData}}transformDropView(e,t){return{kind:`DropViewNode`,name:this.transformNode(e.name,t),ifExists:e.ifExists,materialized:e.materialized,cascade:e.cascade}}transformGenerated(e,t){return{kind:`GeneratedNode`,byDefault:e.byDefault,always:e.always,identity:e.identity,stored:e.stored,expression:this.transformNode(e.expression,t)}}transformDefaultValue(e,t){return{kind:`DefaultValueNode`,defaultValue:this.transformNode(e.defaultValue,t)}}transformOn(e,t){return{kind:`OnNode`,on:this.transformNode(e.on,t)}}transformSelectModifier(e,t){return{kind:`SelectModifierNode`,modifier:e.modifier,rawModifier:this.transformNode(e.rawModifier,t),of:this.transformNodeList(e.of,t)}}transformCreateType(e,t){return{kind:`CreateTypeNode`,name:this.transformNode(e.name,t),enum:this.transformNode(e.enum,t)}}transformDropType(e,t){return{kind:`DropTypeNode`,name:this.transformNode(e.name,t),additionalNames:this.transformNodeList(e.additionalNames,t),cascade:e.cascade,ifExists:e.ifExists}}transformExplain(e,t){return{kind:`ExplainNode`,format:e.format,options:this.transformNode(e.options,t)}}transformSchemableIdentifier(e,t){return{kind:`SchemableIdentifierNode`,schema:this.transformNode(e.schema,t),identifier:this.transformNode(e.identifier,t)}}transformAggregateFunction(e,t){return{kind:`AggregateFunctionNode`,func:e.func,aggregated:this.transformNodeList(e.aggregated,t),distinct:e.distinct,orderBy:this.transformNode(e.orderBy,t),withinGroup:this.transformNode(e.withinGroup,t),filter:this.transformNode(e.filter,t),over:this.transformNode(e.over,t)}}transformOver(e,t){return{kind:`OverNode`,orderBy:this.transformNode(e.orderBy,t),partitionBy:this.transformNode(e.partitionBy,t)}}transformPartitionBy(e,t){return{kind:`PartitionByNode`,items:this.transformNodeList(e.items,t)}}transformPartitionByItem(e,t){return{kind:`PartitionByItemNode`,partitionBy:this.transformNode(e.partitionBy,t)}}transformBinaryOperation(e,t){return{kind:`BinaryOperationNode`,leftOperand:this.transformNode(e.leftOperand,t),operator:this.transformNode(e.operator,t),rightOperand:this.transformNode(e.rightOperand,t)}}transformUnaryOperation(e,t){return{kind:`UnaryOperationNode`,operator:this.transformNode(e.operator,t),operand:this.transformNode(e.operand,t)}}transformUsing(e,t){return{kind:`UsingNode`,tables:this.transformNodeList(e.tables,t)}}transformFunction(e,t){return{kind:`FunctionNode`,func:e.func,arguments:this.transformNodeList(e.arguments,t)}}transformCase(e,t){return{kind:`CaseNode`,value:this.transformNode(e.value,t),when:this.transformNodeList(e.when,t),else:this.transformNode(e.else,t),isStatement:e.isStatement}}transformWhen(e,t){return{kind:`WhenNode`,condition:this.transformNode(e.condition,t),result:this.transformNode(e.result,t)}}transformJSONReference(e,t){return{kind:`JSONReferenceNode`,reference:this.transformNode(e.reference,t),traversal:this.transformNode(e.traversal,t)}}transformJSONPath(e,t){return{kind:`JSONPathNode`,inOperator:this.transformNode(e.inOperator,t),pathLegs:this.transformNodeList(e.pathLegs,t)}}transformJSONPathLeg(e,t){return{kind:`JSONPathLegNode`,type:e.type,value:e.value}}transformJSONOperatorChain(e,t){return{kind:`JSONOperatorChainNode`,operator:this.transformNode(e.operator,t),values:this.transformNodeList(e.values,t)}}transformTuple(e,t){return{kind:`TupleNode`,values:this.transformNodeList(e.values,t)}}transformMergeQuery(e,t){return{kind:`MergeQueryNode`,into:this.transformNode(e.into,t),using:this.transformNode(e.using,t),whens:this.transformNodeList(e.whens,t),with:this.transformNode(e.with,t),top:this.transformNode(e.top,t),endModifiers:this.transformNodeList(e.endModifiers,t),output:this.transformNode(e.output,t),returning:this.transformNode(e.returning,t)}}transformMatched(e,t){return{kind:`MatchedNode`,not:e.not,bySource:e.bySource}}transformAddIndex(e,t){return{kind:`AddIndexNode`,name:this.transformNode(e.name,t),columns:this.transformNodeList(e.columns,t),unique:e.unique,using:this.transformNode(e.using,t),ifNotExists:e.ifNotExists}}transformCast(e,t){return{kind:`CastNode`,expression:this.transformNode(e.expression,t),dataType:this.transformNode(e.dataType,t)}}transformFetch(e,t){return{kind:`FetchNode`,rowCount:this.transformNode(e.rowCount,t),modifier:e.modifier}}transformTop(e,t){return{kind:`TopNode`,expression:e.expression,modifiers:e.modifiers}}transformOutput(e,t){return{kind:`OutputNode`,selections:this.transformNodeList(e.selections,t)}}transformAlterType(e,t){return{kind:`AlterTypeNode`,name:this.transformNode(e.name,t),addValue:this.transformNode(e.addValue,t),renameTo:this.transformNode(e.renameTo,t),renameValue:this.transformNode(e.renameValue,t),setSchema:this.transformNode(e.setSchema,t)}}transformAddValue(e,t){return{kind:`AddValueNode`,value:this.transformNode(e.value,t),ifNotExists:e.ifNotExists,isBefore:e.isBefore,neighborValue:this.transformNode(e.neighborValue,t)}}transformRenameValue(e,t){return{kind:`RenameValueNode`,oldValue:this.transformNode(e.oldValue,t),newValue:this.transformNode(e.newValue,t)}}transformDataType(e,t){return e}transformSelectAll(e,t){return e}transformIdentifier(e,t){return e}transformValue(e,t){return e}transformPrimitiveValueList(e,t){return e}transformOperator(e,t){return e}transformDefaultInsertValue(e,t){return e}transformOrAction(e,t){return e}transformCollate(e,t){return e}};function xa(e){return fa(e)&&da(e.kind)}var Sa={AlterTableNode:!0,AlterTypeNode:!0,CreateIndexNode:!0,CreateSchemaNode:!0,CreateTableNode:!0,CreateTypeNode:!0,CreateViewNode:!0,DeleteQueryNode:!0,DropIndexNode:!0,DropSchemaNode:!0,DropTableNode:!0,DropTypeNode:!0,RefreshMaterializedViewNode:!0,DropViewNode:!0,InsertQueryNode:!0,RawNode:!0,SelectQueryNode:!0,UpdateQueryNode:!0,MergeQueryNode:!0};function Ca(e){return xa(e)&&Sa[e.kind]===!0}var U=B({is(e){return e.kind===`SchemableIdentifierNode`},create(e){return B({kind:`SchemableIdentifierNode`,identifier:V.create(e)})},createWithSchema(e,t){return B({kind:`SchemableIdentifierNode`,schema:V.create(e),identifier:V.create(t)})}}),W=B({is(e){return e.kind===`TableNode`},create(e){return B({kind:`TableNode`,table:U.create(e)})},createWithSchema(e,t){return B({kind:`TableNode`,table:U.createWithSchema(e,t)})}}),wa=B({is(e){return e.kind===`UsingNode`},create(e){return B({kind:`UsingNode`,tables:B(e)})},cloneWithTables(e,t){return B({...e,tables:B([...e.tables,...t])})}}),Ta=B({json_agg:!0,to_json:!0}),Ea=class extends ba{#e;#t=new Set;#n=new Set;constructor(e){super(),this.#e=e}transformNodeImpl(e,t){if(!Ca(e))return super.transformNodeImpl(e,t);let n=this.#a(e);for(let e of n)this.#n.add(e);let r=this.#i(e);for(let e of r)this.#t.add(e);let i=super.transformNodeImpl(e,t);for(let e of r)this.#t.delete(e);for(let e of n)this.#n.delete(e);return i}transformSchemableIdentifier(e,t){let n=super.transformSchemableIdentifier(e,t);return n.schema||!this.#t.has(e.identifier.name)?n:{...n,schema:V.create(this.#e)}}transformReferences(e,t){let n=super.transformReferences(e,t);return n.table.table.schema?n:{...n,table:W.createWithSchema(this.#e,n.table.table.identifier.name)}}transformAggregateFunction(e,t){return{...super.transformAggregateFunction({...e,aggregated:[]},t),aggregated:this.#r(e,t,`aggregated`)}}transformFunction(e,t){return{...super.transformFunction({...e,arguments:[]},t),arguments:this.#r(e,t,`arguments`)}}transformSelectModifier(e,t){return{...super.transformSelectModifier({...e,of:void 0},t),of:e.of?.map(e=>W.is(e)&&!e.table.schema?{...e,table:this.transformIdentifier(e.table.identifier,t)}:this.transformNode(e,t))}}#r(e,t,n){return Ta[e.func]?e[n].map(e=>!W.is(e)||e.table.schema?this.transformNode(e,t):{...e,table:this.transformIdentifier(e.table.identifier,t)}):this.transformNodeList(e[n],t)}#i(e){let t=new Set;if(`name`in e&&e.name&&U.is(e.name)&&this.#s(e.name,t),`from`in e&&e.from)for(let n of e.from.froms)this.#o(n,t);if(`into`in e&&e.into&&this.#o(e.into,t),`table`in e&&e.table&&this.#o(e.table,t),`joins`in e&&e.joins)for(let n of e.joins)this.#o(n.table,t);return`using`in e&&e.using&&(va.is(e.using)?this.#o(e.using.table,t):this.#o(e.using,t)),t}#a(e){let t=new Set;return`with`in e&&e.with&&this.#c(e.with,t),t}#o(e,t){if(W.is(e))return this.#s(e.table,t);if(ha.is(e)&&W.is(e.node))return this.#s(e.node.table,t);if(ya.is(e)){for(let n of e.items)this.#o(n,t);return}if(wa.is(e)){for(let n of e.tables)this.#o(n,t);return}}#s(e,t){let n=e.identifier.name;!this.#t.has(n)&&!this.#n.has(n)&&t.add(n)}#c(e,t){for(let n of e.expressions){let e=n.name.table.table.identifier.name;this.#n.has(e)||t.add(e)}}},Da=class{#e;constructor(e){this.#e=new Ea(e)}transformQuery(e){return this.#e.transformNode(e.node,e.queryId)}async transformResult(e){return e.result}},G=`migration_lock`;B({__noMigrations__:!0});var Oa=class{#e;constructor(e){this.#e=B(e)}async getMigrations(){let e=await this.#f(this.#r)?await this.#e.db.withPlugin(this.#o).selectFrom(this.#r).select([`name`,`timestamp`]).$narrowType().execute():[];return(await this.#_()).map(({name:t,...n})=>{let r=e.find(e=>e.name===t);return{name:t,migration:n,executedAt:r?new Date(r.timestamp):void 0}})}async migrateToLatest(e){return this.#t(()=>({direction:`Up`,step:1/0}),e)}async migrateTo(e,t){return this.#t(({migrations:t,executedMigrations:n,pendingMigrations:r})=>{if(fa(e)&&e.__noMigrations__===!0)return{direction:`Down`,step:1/0};if(!t.find(t=>t.name===e))throw Error(`migration "${e}" doesn't exist`);let i=n.indexOf(e),a=r.findIndex(t=>t.name===e);if(i!==-1)return{direction:`Down`,step:n.length-i-1};if(a!==-1)return{direction:`Up`,step:a+1};throw Error(`migration "${e}" isn't executed or pending`)},t)}async migrateUp(e){return this.#t(()=>({direction:`Up`,step:1}),e)}async migrateDown(e){return this.#t(()=>({direction:`Down`,step:1}),e)}async#t(e,t){try{return await this.#s(),await this.#c(),await this.#l(),await this.#u(),await this.#m(e,t)}catch(e){return e instanceof K?e.resultSet:{error:e}}}get#n(){return this.#e.migrationTableSchema}get#r(){return this.#e.migrationTableName??`kysely_migration`}get#i(){return this.#e.migrationLockTableName??`kysely_migration_lock`}get#a(){return this.#e.allowUnorderedMigrations??!1}get#o(){return this.#n?new Da(this.#n):new ma}async#s(){if(this.#n&&!await this.#d())try{await this.#C(this.#e.db.schema.createSchema(this.#n))}catch(e){if(!await this.#d())throw e}}async#c(){if(!await this.#f(this.#r))try{await this.#C(this.#e.db.schema.withPlugin(this.#o).createTable(this.#r).addColumn(`name`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`timestamp`,`varchar(255)`,e=>e.notNull()))}catch(e){if(!await this.#f(this.#r))throw e}}async#l(){if(!await this.#f(this.#i))try{await this.#C(this.#e.db.schema.withPlugin(this.#o).createTable(this.#i).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`is_locked`,`integer`,e=>e.notNull().defaultTo(0)))}catch(e){if(!await this.#f(this.#i))throw e}}async#u(){if(!await this.#p())try{await this.#e.db.withPlugin(this.#o).insertInto(this.#i).values({id:G,is_locked:0}).execute()}catch(e){if(!await this.#p())throw e}}async#d(){return(await this.#e.db.introspection.getSchemas()).some(e=>e.name===this.#n)}async#f(e){let t=this.#n;return(await this.#e.db.introspection.getTables({withInternalKyselyTables:!0})).some(n=>n.name===e&&(!t||n.schema===t))}async#p(){return!!await this.#e.db.withPlugin(this.#o).selectFrom(this.#i).where(`id`,`=`,G).select(`id`).executeTakeFirst()}async#m(e,t){let n=this.#e.db.getExecutor().adapter,r=B({lockTable:this.#e.migrationLockTableName??`kysely_migration_lock`,lockRowId:G,lockTableSchema:this.#e.migrationTableSchema}),i=async t=>{try{await n.acquireMigrationLock(t,r);let i=await this.#h(t);if(i.migrations.length===0)return{results:[]};let{direction:a,step:o}=e(i);return o<=0?{results:[]}:a===`Down`?await this.#x(t,i,o):a===`Up`?await this.#S(t,i,o):{results:[]}}finally{await n.releaseMigrationLock(t,r)}},a=t?.disableTransactions??this.#e.disableTransactions;if(this.#e.db.isTransaction){if(!n.supportsTransactionalDdl)throw Error(`Transactional DDL is not supported in this dialect. Passing a transaction to this migrator would result in failure or unexpected behavior.`);if(a)throw Error("`disableTransactions` is true but the migrator was given a transaction. Passing a transaction to this migrator would result in failure or unexpected behavior.");return i(this.#e.db)}return n.supportsTransactionalDdl&&!a?this.#e.db.transaction().execute(i):this.#e.db.connection().execute(i)}async#h(e){let t=await this.#_(),n=await this.#v(e);this.#y(t,n),this.#a||this.#b(t,n);let r=this.#g(t,n);return B({migrations:t,executedMigrations:n,lastMigration:pa(n),pendingMigrations:r})}#g(e,t){return e.filter(e=>!t.includes(e.name))}async#_(){let e=await this.#e.provider.getMigrations();return Object.keys(e).sort().map(t=>({...e[t],name:t}))}async#v(e){let t=await e.withPlugin(this.#o).selectFrom(this.#r).select([`name`,`timestamp`]).$narrowType().execute(),n=this.#e.nameComparator||((e,t)=>e.localeCompare(t));return t.sort((e,t)=>e.timestamp===t.timestamp?n(e.name,t.name):new Date(e.timestamp).getTime()-new Date(t.timestamp).getTime()).map(e=>e.name)}#y(e,t){for(let n of t)if(!e.some(e=>e.name===n))throw Error(`corrupted migrations: previously executed migration ${n} is missing`)}#b(e,t){for(let n=0;n<t.length;++n)if(e[n].name!==t[n])throw Error(`corrupted migrations: expected previously executed migration ${t[n]} to be at index ${n} but ${e[n].name} was found in its place. New migrations must always have a name that comes alphabetically after the last executed migration.`)}async#x(e,t,n){let r=t.executedMigrations.toReversed().slice(0,n).map(e=>t.migrations.find(t=>t.name===e)),i=r.map(e=>({migrationName:e.name,direction:`Down`,status:`NotExecuted`}));for(let t=0;t<i.length;++t){let n=r[t];try{n.down&&(await n.down(e),await e.withPlugin(this.#o).deleteFrom(this.#r).where(`name`,`=`,n.name).execute(),i[t]={migrationName:n.name,direction:`Down`,status:`Success`})}catch(e){throw i[t]={migrationName:n.name,direction:`Down`,status:`Error`},new K({error:e,results:i})}}return{results:i}}async#S(e,t,n){let r=t.pendingMigrations.slice(0,n).map(e=>({migrationName:e.name,direction:`Up`,status:`NotExecuted`}));for(let n=0;n<r.length;n++){let i=t.pendingMigrations[n];try{await i.up(e),await e.withPlugin(this.#o).insertInto(this.#r).values({name:i.name,timestamp:new Date().toISOString()}).execute(),r[n]={migrationName:i.name,direction:`Up`,status:`Success`}}catch(e){throw r[n]={migrationName:i.name,direction:`Up`,status:`Error`},new K({error:e,results:r})}}return{results:r}}async#C(e){this.#e.db.getExecutor().adapter.supportsCreateIfNotExists&&(e=e.ifNotExists()),await e.execute()}},K=class extends Error{#e;constructor(e){super(),this.#e=e}get resultSet(){return this.#e}},ka=class{migrations;constructor(e){this.migrations=e}async getMigrations(){return this.migrations}},Aa=t({down:()=>Ma,up:()=>ja});async function ja(e){await e.schema.createTable(`tenants`).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`name`,`varchar(255)`).addColumn(`audience`,`varchar(255)`).addColumn(`sender_email`,`varchar(255)`).addColumn(`sender_name`,`varchar(255)`).addColumn(`language`,`varchar(255)`).addColumn(`logo`,`varchar(255)`).addColumn(`primary_color`,`varchar(255)`).addColumn(`secondary_color`,`varchar(255)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`users`).addColumn(`user_id`,`varchar(255)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`email`,`varchar(255)`).addColumn(`given_name`,`varchar(255)`).addColumn(`family_name`,`varchar(255)`).addColumn(`nickname`,`varchar(255)`).addColumn(`name`,`varchar(255)`).addColumn(`picture`,`varchar(2083)`).addColumn(`tags`,`varchar(255)`).addColumn(`phone_number`,`varchar(17)`).addColumn(`phone_verified`,`boolean`).addColumn(`username`,`varchar(128)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).addPrimaryKeyConstraint(`users_tenants`,[`user_id`,`tenant_id`]).addColumn(`linked_to`,`varchar(255)`).addForeignKeyConstraint(`linked_to_constraint`,[`linked_to`,`tenant_id`],`users`,[`user_id`,`tenant_id`]).addColumn(`last_ip`,`varchar(255)`).addColumn(`login_count`,`integer`,e=>e.notNull()).addColumn(`last_login`,`varchar(255)`).addColumn(`provider`,`varchar(255)`,e=>e.notNull()).addColumn(`connection`,`varchar(255)`).addColumn(`email_verified`,`boolean`,e=>e.notNull()).addColumn(`is_social`,`boolean`,e=>e.notNull()).addColumn(`app_metadata`,`varchar(4096)`,e=>e.defaultTo(`{}`).notNull()).addColumn(`user_metadata`,`varchar(4096)`,e=>e.defaultTo(`{}`).notNull()).addUniqueConstraint(`unique_email_provider`,[`email`,`provider`,`tenant_id`]).addUniqueConstraint(`unique_phone_provider`,[`phone_number`,`provider`,`tenant_id`]).execute(),await e.schema.createTable(`members`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`sub`,`varchar(255)`).addColumn(`email`,`varchar(255)`).addColumn(`name`,`varchar(255)`).addColumn(`status`,`varchar(255)`).addColumn(`role`,`varchar(255)`).addColumn(`picture`,`varchar(2083)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`applications`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`client_secret`,`varchar(255)`).addColumn(`allowed_logout_urls`,`varchar(255)`).addColumn(`authentication_settings`,`varchar(255)`).addColumn(`addons`,`varchar(4096)`,e=>e.notNull().defaultTo(`{}`)).addColumn(`callbacks`,`varchar(1024)`,e=>e.notNull().defaultTo(`[]`)).addColumn(`allowed_origins`,`varchar(1024)`,e=>e.notNull().defaultTo(`[]`)).addColumn(`web_origins`,`varchar(1024)`,e=>e.notNull().defaultTo(`[]`)).addColumn(`allowed_clients`,`varchar(1024)`,e=>e.defaultTo(`[]`).notNull()).addColumn(`options_kid`,`varchar(32)`).addColumn(`options_team_id`,`varchar(32)`).addColumn(`options_client_id`,`varchar(128)`).addColumn(`options_client_secret`,`varchar(255)`).addColumn(`options_scope`,`varchar(255)`).addColumn(`options_realms`,`varchar(255)`).addColumn(`options_app_secret`,`varchar(1024)`).addColumn(`email_validation`,`varchar(255)`).addColumn(`disable_sign_ups`,`boolean`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`connections`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`response_type`,`varchar(255)`).addColumn(`response_mode`,`varchar(255)`).addColumn(`strategy`,`varchar(64)`).addColumn(`options`,`varchar(2048)`,e=>e.defaultTo(`{}`).notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`migrations`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`provider`,`varchar(255)`).addColumn(`client_id`,`varchar(255)`).addColumn(`origin`,`varchar(255)`).addColumn(`domain`,`varchar(255)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`domains`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`domain`,`varchar(255)`,e=>e.notNull()).addColumn(`email_service`,`varchar(255)`).addColumn(`email_api_key`,`varchar(255)`).addColumn(`dkim_private_key`,`varchar(2048)`).addColumn(`dkim_public_key`,`varchar(2048)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute()}async function Ma(e){await e.schema.dropTable(`domains`).execute(),await e.schema.dropTable(`members`).execute(),await e.schema.dropTable(`users`).execute(),await e.schema.dropTable(`connections`).execute(),await e.schema.dropTable(`applications`).execute(),await e.schema.dropTable(`migrations`).execute(),await e.schema.dropTable(`tenants`).execute()}var Na=t({down:()=>Fa,up:()=>Pa});async function Pa(e){await e.schema.alterTable(`tenants`).addColumn(`support_url`,`varchar(255)`).execute()}async function Fa(e){await e.schema.alterTable(`tenants`).dropColumn(`support_url`).execute()}var Ia=t({down:()=>Ra,up:()=>La});async function La(e){}async function Ra(e){}var za=t({down:()=>Va,up:()=>Ba});async function Ba(e){await e.schema.createTable(`logs`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`category`,`varchar(255)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(64)`).addColumn(`user_id`,`varchar(64)`).addForeignKeyConstraint(`tenant_id_constraint`,[`tenant_id`],`tenants`,[`id`],e=>e.onDelete(`cascade`)).addColumn(`ip`,`varchar(255)`).addColumn(`type`,`varchar(8)`,e=>e.notNull()).addColumn(`date`,`varchar(25)`,e=>e.notNull()).addColumn(`client_id`,`varchar(255)`).addColumn(`client_name`,`varchar(255)`).addColumn(`user_agent`,`varchar(255)`).addColumn(`description`,`varchar(255)`).addColumn(`details`,`varchar(2048)`).execute()}async function Va(e){await e.schema.dropTable(`logs`).execute()}var Ha=t({down:()=>Wa,up:()=>Ua});async function Ua(e){}async function Wa(e){}var Ga=t({down:()=>qa,up:()=>Ka});async function Ka(e){await e.schema.createTable(`sessions`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`authenticated_at`,`varchar(35)`).addColumn(`last_interaction_at`,`varchar(35)`).addColumn(`used_at`,`varchar(35)`).addColumn(`revoked_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`clients`,`varchar(1024)`,e=>e.notNull()).execute(),await e.schema.createTable(`tickets`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`email`,`varchar(255)`,e=>e.notNull()).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(1024)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute(),await e.schema.createTable(`otps`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`code`,`varchar(255)`,e=>e.notNull()).addColumn(`email`,`varchar(255)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`send`,`varchar(255)`).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(1024)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute(),await e.schema.createIndex(`otps_email_index`).on(`otps`).column(`email`).execute(),await e.schema.createIndex(`otps_expires_at_index`).on(`otps`).column(`expires_at`).execute()}async function qa(e){await e.schema.dropTable(`sessions`).execute(),await e.schema.dropTable(`tickets`).execute(),await e.schema.dropTable(`otps`).execute()}var Ja=t({down:()=>Xa,up:()=>Ya});async function Ya(e){await e.schema.createTable(`passwords`).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addPrimaryKeyConstraint(`passwords_pkey`,[`user_id`,`tenant_id`]).addForeignKeyConstraint(`user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(255)`).addColumn(`updated_at`,`varchar(255)`).execute(),await e.schema.createTable(`codes`).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`user_id`,`varchar(255)`).addColumn(`tenant_id`,`varchar(255)`).addForeignKeyConstraint(`user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute(),await e.schema.createIndex(`codes_expires_at_index`).on(`codes`).column(`expires_at`).execute()}async function Xa(e){await e.schema.dropTable(`passwords`).execute(),await e.schema.dropTable(`codes`).execute()}var Za=t({down:()=>$a,up:()=>Qa});async function Qa(e){}async function $a(e){}var eo=t({down:()=>no,up:()=>to});async function to(e){await e.schema.alterTable(`passwords`).addColumn(`password`,`varchar(255)`,e=>e.notNull()).execute()}async function no(e){await e.schema.alterTable(`passwords`).dropColumn(`password`).execute()}var ro=t({down:()=>ao,up:()=>io});async function io(e){}async function ao(e){}var oo=t({down:()=>co,up:()=>so});async function so(e){}async function co(e){}var lo=t({down:()=>fo,up:()=>uo});async function uo(e){}async function fo(e){}var po=t({down:()=>ho,up:()=>mo});async function mo(e){await e.schema.createIndex(`users_email_index`).on(`users`).column(`email`).execute()}async function ho(e){await e.schema.dropIndex(`users_email_index`).execute()}var go=t({down:()=>vo,up:()=>_o});async function _o(e){await e.schema.alterTable(`users`).addColumn(`profileData`,`varchar(2048)`).execute()}async function vo(e){await e.schema.alterTable(`users`).dropColumn(`profileData`).execute()}var yo=t({down:()=>xo,up:()=>bo});async function bo(e){await e.schema.createIndex(`users_linked_to_index`).on(`users`).column(`linked_to`).execute()}async function xo(e){await e.schema.dropIndex(`users_linked_to_index`)}var So=t({down:()=>wo,up:()=>Co});async function Co(e){await e.schema.alterTable(`users`).addColumn(`locale`,`varchar(255)`).execute()}async function wo(e){await e.schema.alterTable(`users`).dropColumn(`locale`).execute()}var To=t({down:()=>Do,up:()=>Eo});async function Eo(e){await e.schema.createTable(`keys`).addColumn(`kid`,`varchar(255)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`)).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`revoked_at`,`varchar(255)`).addColumn(`cert`,`varchar(4096)`).addColumn(`pkcs7`,`varchar(4096)`).addColumn(`fingerprint`,`varchar(256)`).addColumn(`thumbprint`,`varchar(256)`).addColumn(`current_since`,`varchar(256)`).addColumn(`current_until`,`varchar(256)`).addColumn(`type`,`varchar(50)`,e=>e.notNull().defaultTo(`jwt_signing`)).addColumn(`connection`,`varchar(255)`,e=>e.references(`connections.id`).onDelete(`cascade`)).execute()}async function Do(e){await e.schema.dropTable(`keys`).execute()}var Oo=t({down:()=>Ao,up:()=>ko});async function ko(e){}async function Ao(e){}var jo=t({down:()=>No,up:()=>Mo});async function Mo(e){}async function No(e){}var Po=t({down:()=>Io,up:()=>Fo});async function Fo(e){await e.schema.alterTable(`otps`).addColumn(`audience`,`varchar(255)`).execute()}async function Io(e){await e.schema.alterTable(`otps`).dropColumn(`audience`).execute()}var Lo=t({down:()=>zo,up:()=>Ro});async function Ro(e){}async function zo(e){}var Bo=t({down:()=>Ho,up:()=>Vo});async function Vo(e){await e.schema.alterTable(`logs`).dropColumn(`category`).execute()}async function Ho(e){await e.schema.alterTable(`logs`).addColumn(`category`,`varchar(255)`,e=>e.notNull()).execute()}var Uo=t({down:()=>Go,up:()=>Wo});async function Wo(e){await e.schema.alterTable(`users`).dropColumn(`tags`).execute()}async function Go(e){await e.schema.alterTable(`users`).addColumn(`tags`,`varchar(255)`).execute()}var Ko=t({down:()=>Jo,up:()=>qo});async function qo(e){await e.schema.createIndex(`logs_user_id`).on(`logs`).column(`user_id`).execute(),await e.schema.createIndex(`logs_tenant_id`).on(`logs`).column(`tenant_id`).execute(),await e.schema.createIndex(`logs_date`).on(`logs`).column(`date`).execute()}async function Jo(e){await e.schema.dropIndex(`logs_user_id`),await e.schema.dropIndex(`logs_tenant_id`),await e.schema.dropIndex(`logs_date`)}var Yo=t({down:()=>Zo,up:()=>Xo});async function Xo(e){await e.schema.alterTable(`logs`).dropColumn(`details`).execute(),await e.schema.alterTable(`logs`).addColumn(`details`,`varchar(8192)`).execute()}async function Zo(e){await e.schema.alterTable(`logs`).dropColumn(`details`).execute(),await e.schema.alterTable(`logs`).addColumn(`details`,`varchar(2048)`).execute()}var Qo=t({down:()=>es,up:()=>$o});async function $o(e){await e.schema.alterTable(`logs`).addColumn(`user_name`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`auth0_client`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`isMobile`,`boolean`).execute(),await e.schema.alterTable(`logs`).addColumn(`connection`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`connection_id`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`audience`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`scope`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`strategy`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`strategy_type`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`hostname`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`session_connection`,`varchar(255)`).execute()}async function es(e){await e.schema.alterTable(`logs`).dropColumn(`user_name`).execute(),await e.schema.alterTable(`logs`).dropColumn(`auth0_client`).execute(),await e.schema.alterTable(`logs`).dropColumn(`isMobile`).execute(),await e.schema.alterTable(`logs`).dropColumn(`connection`).execute(),await e.schema.alterTable(`logs`).dropColumn(`connection_id`).execute(),await e.schema.alterTable(`logs`).dropColumn(`audience`).execute(),await e.schema.alterTable(`logs`).dropColumn(`scope`).execute(),await e.schema.alterTable(`logs`).dropColumn(`strategy`).execute(),await e.schema.alterTable(`logs`).dropColumn(`strategy_type`).execute(),await e.schema.alterTable(`logs`).dropColumn(`hostname`).execute(),await e.schema.alterTable(`logs`).dropColumn(`session_connection`).execute()}var ts=t({down:()=>rs,up:()=>ns});async function ns(e){await e.schema.createIndex(`users_name_index`).on(`users`).column(`name`).execute()}async function rs(e){await e.schema.dropIndex(`users_name_index`).execute()}var is=t({down:()=>os,up:()=>as});async function as(e){}async function os(e){await e.schema.alterTable(`users`).dropConstraint(`unique_email_provider`).execute()}var ss=t({down:()=>ls,up:()=>cs});async function cs(e){await e.schema.alterTable(`otps`).dropColumn(`state`).execute(),await e.schema.alterTable(`otps`).addColumn(`state`,`varchar(8192)`).execute()}async function ls(e){await e.schema.alterTable(`otps`).dropColumn(`state`).execute(),await e.schema.alterTable(`otps`).addColumn(`state`,`varchar(1024)`).execute()}var us=t({down:()=>fs,up:()=>ds});async function ds(e){await e.schema.alterTable(`tickets`).dropColumn(`state`).execute(),await e.schema.alterTable(`tickets`).addColumn(`state`,`varchar(8192)`).execute()}async function fs(e){await e.schema.alterTable(`tickets`).dropColumn(`state`).execute(),await e.schema.alterTable(`tickets`).addColumn(`state`,`varchar(1024)`).execute()}var ps=t({down:()=>hs,up:()=>ms});async function ms(e){await e.schema.createTable(`branding`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull().primaryKey()).addColumn(`logo_url`,`varchar(512)`).addColumn(`favicon_url`,`varchar(512)`).addColumn(`font_url`,`varchar(512)`).addColumn(`colors_primary`,`varchar(8)`).addColumn(`colors_page_background_type`,`varchar(32)`).addColumn(`colors_page_background_start`,`varchar(8)`).addColumn(`colors_page_background_end`,`varchar(8)`).addColumn(`colors_page_background_angle_dev`,`integer`).execute()}async function hs(e){await e.schema.dropTable(`branding`).execute()}var gs=t({down:()=>vs,up:()=>_s});async function _s(e){}async function vs(e){}var ys=t({down:()=>xs,up:()=>bs});async function bs(e){}async function xs(e){}var Ss=t({down:()=>ws,up:()=>Cs});async function Cs(e){}async function ws(e){}var Ts=t({down:()=>Ds,up:()=>Es});async function Es(e){}async function Ds(e){}var Os=t({down:()=>As,up:()=>ks});async function ks(e){await e.schema.createTable(`authentication_codes`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`code`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`,e=>e.notNull()).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(8192)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}async function As(e){await e.schema.dropTable(`authentication_codes`).execute()}var js=t({down:()=>Ns,up:()=>Ms});async function Ms(e){}async function Ns(e){}var Ps=t({down:()=>Is,up:()=>Fs});async function Fs(e){await e.schema.alterTable(`otps`).addColumn(`ip`,`varchar(64)`).execute()}async function Is(e){await e.schema.alterTable(`otps`).dropColumn(`ip`).execute()}var Ls=t({down:()=>zs,up:()=>Rs});async function Rs(e){await e.schema.alterTable(`logs`).dropColumn(`user_agent`).execute(),await e.schema.alterTable(`logs`).addColumn(`user_agent`,`varchar(1024)`).execute()}async function zs(e){await e.schema.alterTable(`logs`).dropColumn(`user_agent`).execute(),await e.schema.alterTable(`logs`).addColumn(`user_agent`,`varchar(255)`).execute()}var Bs=t({down:()=>Hs,up:()=>Vs});async function Vs(e){}async function Hs(e){}var Us=t({down:()=>Gs,up:()=>Ws});async function Ws(e){await e.schema.createTable(`hooks`).addColumn(`hook_id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`url`,`varchar(512)`,e=>e.notNull()).addColumn(`trigger_id`,`varchar(255)`,e=>e.notNull()).addColumn(`enabled`,`boolean`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).addColumn(`synchronous`,`boolean`,e=>e.defaultTo(!1).notNull()).addColumn(`priority`,`integer`).execute()}async function Gs(e){await e.schema.dropTable(`hooks`).execute()}var Ks=t({down:()=>Js,up:()=>qs});async function qs(e){}async function Js(e){}var Ys=t({down:()=>Zs,up:()=>Xs});async function Xs(e){}async function Zs(e){}var Qs=t({down:()=>ec,up:()=>$s});async function $s(e){await e.schema.createTable(`logins`).addColumn(`login_id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`authParams_client_id`,`varchar(255)`,e=>e.notNull()).addColumn(`authParams_vendor_id`,`varchar(255)`).addColumn(`authParams_username`,`varchar(255)`).addColumn(`authParams_response_type`,`varchar(255)`).addColumn(`authParams_response_mode`,`varchar(255)`).addColumn(`authParams_audience`,`varchar(255)`).addColumn(`authParams_scope`,`varchar(511)`).addColumn(`authParams_state`,`varchar(511)`).addColumn(`authParams_code_challenge_method`,`varchar(256)`).addColumn(`authParams_code_challenge`,`varchar(256)`).addColumn(`authParams_redirect_uri`,`varchar(256)`).addColumn(`authParams_organization`,`varchar(256)`).addColumn(`authorization_url`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`ip`,`varchar(255)`).addColumn(`useragent`,`varchar(512)`).execute(),await e.schema.alterTable(`passwords`).addColumn(`algorithm`,`varchar(16)`).execute(),await e.schema.dropTable(`codes`).execute(),await e.schema.createTable(`codes`).addColumn(`code_id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`login_id`,`varchar(255)`).addForeignKeyConstraint(`codes_user_id_tenant_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`code_type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}async function ec(e){await e.schema.dropTable(`logins`).execute(),await e.schema.alterTable(`passwords`).dropColumn(`algorithm`).execute(),await e.schema.dropTable(`codes`).execute(),await e.schema.createTable(`codes`).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`code`,`varchar(255)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`tenant_id`,`varchar(255)`).addForeignKeyConstraint(`codes_user_id_tenant_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}var tc=t({down:()=>rc,up:()=>nc});async function nc(e){}async function rc(e){}var ic=t({down:()=>oc,up:()=>ac});async function ac(e){await e.schema.alterTable(`logins`).addColumn(`auth0Client`,`varchar(256)`).execute()}async function oc(e){await e.schema.alterTable(`logins`).dropColumn(`auth0Client`).execute()}var sc=t({down:()=>lc,up:()=>cc});async function cc(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_state`).execute(),await e.schema.alterTable(`logins`).addColumn(`authParams_state`,`varchar(8192)`).execute()}async function lc(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_state`).execute(),await e.schema.alterTable(`logins`).addColumn(`authParams_state`,`varchar(511)`).execute()}var uc=t({down:()=>fc,up:()=>dc});async function dc(e){}async function fc(e){}var pc=t({down:()=>hc,up:()=>mc});async function mc(e){}async function hc(e){}var gc=t({down:()=>vc,up:()=>_c});async function _c(e){await e.schema.alterTable(`logins`).addColumn(`authParams_nonce`,`varchar(255)`).execute()}async function vc(e){await e.schema.alterTable(`logins`).dropColumn(`nonce`).execute()}var yc=t({down:()=>xc,up:()=>bc});async function bc(e){}async function xc(e){}var Sc=t({down:()=>wc,up:()=>Cc});async function Cc(e){}async function wc(e){}var Tc=t({down:()=>Dc,up:()=>Ec});async function Ec(e){await e.schema.dropTable(`codes`).execute(),await e.schema.createTable(`codes`).addColumn(`code_id`,`varchar(255)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`login_id`,`varchar(255)`).addColumn(`connection_id`,`varchar(255)`).addForeignKeyConstraint(`codes_user_id_tenant_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`code_type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).addPrimaryKeyConstraint(`PK_codes_code_id_code_type`,[`code_id`,`code_type`]).execute()}async function Dc(e){await e.schema.dropTable(`codes`).execute(),await e.schema.createTable(`codes`).addColumn(`code_id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`connection_id`,`varchar(255)`).addColumn(`login_id`,`varchar(255)`).addForeignKeyConstraint(`codes_user_id_tenant_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`code_type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}var Oc=t({down:()=>Ac,up:()=>kc});async function kc(e){await e.schema.dropTable(`otps`).execute(),await e.schema.dropTable(`authentication_codes`).execute()}async function Ac(e){await e.schema.alterTable(`keys`).addColumn(`private_key`,`varchar(2048)`).addColumn(`public_key`,`varchar(2048)`).execute(),await e.schema.createTable(`otps`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`code`,`varchar(255)`,e=>e.notNull()).addColumn(`email`,`varchar(255)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`send`,`varchar(255)`).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(1024)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute(),await e.schema.createTable(`authentication_codes`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`code`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`,e=>e.notNull()).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(8192)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}var jc=t({down:()=>Nc,up:()=>Mc});async function Mc(e){await e.schema.createIndex(`IDX_logs_tenant_date_type_user`).on(`logs`).columns([`tenant_id`,`date`,`type`,`user_id`]).execute()}async function Nc(e){await e.schema.dropIndex(`IDX_logs_tenant_date_type_user`).on(`logs`).execute()}var Pc=t({down:()=>Ic,up:()=>Fc});async function Fc(e){}async function Ic(e){}var Lc=t({down:()=>zc,up:()=>Rc});async function Rc(e){await e.schema.createTable(`prompt_settings`).addColumn(`tenant_id`,`varchar(64)`,e=>e.primaryKey()).addColumn(`universal_login_experience`,`varchar(16)`,e=>e.defaultTo(`new`).notNull()).addColumn(`identifier_first`,`boolean`,e=>e.defaultTo(!0).notNull()).addColumn(`password_first`,`boolean`,e=>e.defaultTo(!1).notNull()).addColumn(`webauthn_platform_first_factor`,`boolean`,e=>e.defaultTo(!1).notNull()).execute()}async function zc(e){await e.schema.dropTable(`prompt_settings`).execute()}var Bc=t({down:()=>Hc,up:()=>Vc});async function Vc(e){}async function Hc(e){}var Uc=t({down:()=>Gc,up:()=>Wc});async function Wc(e){}async function Gc(e){}var Kc=t({down:()=>Jc,up:()=>qc});async function qc(e){}async function Jc(e){}var Yc=t({down:()=>Zc,up:()=>Xc});async function Xc(e){await e.schema.alterTable(`logins`).addColumn(`authParams_ui_locales`,`varchar(32)`).execute()}async function Zc(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_ui_locales`).execute()}var Qc=t({down:()=>el,up:()=>$c});async function $c(e){await e.schema.alterTable(`logins`).addColumn(`authParams_prompt`,`varchar(16)`).execute()}async function el(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_prompt`).execute()}var tl=t({down:()=>rl,up:()=>nl});async function nl(e){}async function rl(e){}var il=t({down:()=>ol,up:()=>al});async function al(e){await e.schema.alterTable(`logins`).addColumn(`authParams_act_as`,`varchar(255)`).execute()}async function ol(e){await e.schema.alterTable(`logins`).dropColumn(`authParam_act_as`).execute()}var sl=t({down:()=>ll,up:()=>cl});async function cl(e){await e.schema.alterTable(`codes`).addColumn(`code_verifier`,`varchar(128)`).execute()}async function ll(e){await e.schema.alterTable(`codes`).dropColumn(`code_verifier`).execute()}var ul=t({down:()=>fl,up:()=>dl});async function dl(e){await e.schema.createTable(`email_providers`).addColumn(`tenant_id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`enabled`,`boolean`,e=>e.notNull()).addColumn(`default_from_address`,`varchar(255)`).addColumn(`credentials`,`varchar(2048)`,e=>e.notNull().defaultTo(`{}`)).addColumn(`settings`,`varchar(2048)`,e=>e.notNull().defaultTo(`{}`)).addColumn(`created_at`,`varchar(29)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(29)`,e=>e.notNull()).execute()}async function fl(e){await e.schema.dropTable(`email_providers`).execute()}var pl=t({down:()=>hl,up:()=>ml});async function ml(e){await e.schema.dropTable(`tickets`).execute()}async function hl(e){await e.schema.createTable(`tickets`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`email`,`varchar(255)`,e=>e.notNull()).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(1024)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}var gl=t({down:()=>vl,up:()=>_l});async function _l(e){}async function vl(e){await e.schema.alterTable(`logins`).dropColumn(`ip`).dropColumn(`useragent`).execute()}var yl=t({down:()=>xl,up:()=>bl});async function bl(e){await e.schema.createTable(`refresh_tokens`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(21)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`session_id`,`varchar(21)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`last_exchanged_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`resource_servers`,`varchar(2048)`,e=>e.notNull()).addColumn(`rotating`,`boolean`,e=>e.notNull()).execute()}async function xl(e){await e.schema.dropTable(`refresh_tokens`).execute()}var Sl=t({down:()=>wl,up:()=>Cl});async function Cl(e){}async function wl(e){}var Tl=t({down:()=>Dl,up:()=>El});async function El(e){await e.schema.dropTable(`sessions`).execute(),await e.schema.dropTable(`refresh_tokens`).execute()}async function Dl(e){await e.schema.createTable(`sessions`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`sessions_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`authenticated_at`,`varchar(35)`).addColumn(`last_interaction_at`,`varchar(35)`).addColumn(`used_at`,`varchar(35)`).addColumn(`revoked_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`clients`,`varchar(1024)`,e=>e.notNull()).execute(),await e.schema.createTable(`refresh_tokens`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(21)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`session_id`,`varchar(21)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`refresh_tokens_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`last_exchanged_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`resource_servers`,`varchar(2048)`,e=>e.notNull()).addColumn(`rotating`,`boolean`,e=>e.notNull()).execute()}var Ol=t({down:()=>Al,up:()=>kl});async function kl(e){await e.schema.createTable(`sessions_2`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`sessions_2_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`authenticated_at`,`varchar(35)`).addColumn(`last_interaction_at`,`varchar(35)`).addColumn(`used_at`,`varchar(35)`).addColumn(`revoked_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`clients`,`varchar(1024)`,e=>e.notNull()).execute(),await e.schema.createTable(`refresh_tokens_2`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(21)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`session_id`,`varchar(21)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`refresh_tokens_2_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`last_exchanged_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`resource_servers`,`varchar(2048)`,e=>e.notNull()).addColumn(`rotating`,`boolean`,e=>e.notNull()).execute()}async function Al(e){await e.schema.dropTable(`sessions_2`).execute(),await e.schema.dropTable(`refresh_tokens_2`).execute()}var jl=t({down:()=>Nl,up:()=>Ml});async function Ml(e){await e.schema.createTable(`custom_domains`).addColumn(`custom_domain_id`,`varchar(21)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`domain`,`varchar(255)`,e=>e.notNull()).addColumn(`primary`,`boolean`,e=>e.notNull()).addColumn(`status`,`varchar(50)`,e=>e.notNull()).addColumn(`type`,`varchar(50)`,e=>e.notNull()).addColumn(`origin_domain_name`,`varchar(255)`).addColumn(`verification`,`varchar(2048)`).addColumn(`custom_client_ip_header`,`varchar(50)`).addColumn(`tls_policy`,`varchar(50)`).addColumn(`domain_metadata`,`varchar(2048)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).execute(),await e.schema.dropTable(`domains`).execute()}async function Nl(e){await e.schema.dropTable(`custom_domains`).execute(),await e.schema.createTable(`domains`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`domain`,`varchar(255)`,e=>e.notNull()).addColumn(`email_service`,`varchar(255)`).addColumn(`email_api_key`,`varchar(255)`).addColumn(`dkim_private_key`,`varchar(2048)`).addColumn(`dkim_public_key`,`varchar(2048)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute()}var Pl=t({down:()=>Il,up:()=>Fl});async function Fl(e){}async function Il(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_organization`).dropColumn(`authorization_url`).execute()}var Ll=t({down:()=>zl,up:()=>Rl});async function Rl(e){await e.schema.alterTable(`logins`).dropColumn(`authorization_url`).execute(),await e.schema.alterTable(`logins`).addColumn(`authorization_url`,`varchar(2048)`).execute()}async function zl(e){await e.schema.alterTable(`logins`).dropColumn(`authorization_url`).execute(),await e.schema.alterTable(`logins`).addColumn(`authorization_url`,`varchar(1024)`).execute()}var Bl=t({down:()=>Hl,up:()=>Vl});async function Vl(e){}async function Hl(e){}var Ul=t({down:()=>Gl,up:()=>Wl});async function Wl(e){await e.schema.createTable(`sessions`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`sessions_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`authenticated_at`,`varchar(35)`).addColumn(`last_interaction_at`,`varchar(35)`).addColumn(`used_at`,`varchar(35)`).addColumn(`revoked_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`clients`,`varchar(1024)`,e=>e.notNull()).execute(),await e.schema.createTable(`login_sessions`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`session_id`,`varchar(21)`,e=>e.references(`sessions.id`).onDelete(`cascade`)).addColumn(`csrf_token`,`varchar(21)`,e=>e.notNull()).addColumn(`authParams_client_id`,`varchar(255)`,e=>e.notNull()).addColumn(`authParams_vendor_id`,`varchar(255)`).addColumn(`authParams_username`,`varchar(255)`).addColumn(`authParams_response_type`,`varchar(255)`).addColumn(`authParams_response_mode`,`varchar(255)`).addColumn(`authParams_audience`,`varchar(255)`).addColumn(`authParams_scope`,`varchar(511)`).addColumn(`authParams_state`,`varchar(2048)`).addColumn(`authParams_nonce`,`varchar(255)`).addColumn(`authParams_code_challenge_method`,`varchar(255)`).addColumn(`authParams_code_challenge`,`varchar(255)`).addColumn(`authParams_redirect_uri`,`varchar(255)`).addColumn(`authParams_organization`,`varchar(255)`).addColumn(`authParams_prompt`,`varchar(32)`).addColumn(`authParams_act_as`,`varchar(256)`).addColumn(`authParams_ui_locales`,`varchar(32)`).addColumn(`authorization_url`,`varchar(1024)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`,e=>e.notNull()).addColumn(`ip`,`varchar(39)`).addColumn(`useragent`,`varchar(1024)`).addColumn(`auth0Client`,`varchar(255)`).execute(),await e.schema.createTable(`refresh_tokens`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(21)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`session_id`,`varchar(21)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`refresh_tokens_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`last_exchanged_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`resource_servers`,`varchar(2048)`,e=>e.notNull()).addColumn(`rotating`,`boolean`,e=>e.notNull()).execute()}async function Gl(e){await e.schema.dropTable(`sessions`).execute(),await e.schema.dropTable(`login_sessions`).execute(),await e.schema.dropTable(`refresh_tokens`).execute()}var Kl=t({down:()=>Jl,up:()=>ql});async function ql(e){await e.schema.dropTable(`logins`).execute(),await e.schema.dropTable(`sessions_2`).execute(),await e.schema.dropTable(`refresh_tokens_2`).execute()}async function Jl(e){}var Yl=t({down:()=>Zl,up:()=>Xl});async function Xl(e){await e.schema.dropTable(`custom_domains`).execute(),await e.schema.createTable(`custom_domains`).addColumn(`custom_domain_id`,`varchar(256)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`domain`,`varchar(255)`,e=>e.notNull()).addColumn(`primary`,`boolean`,e=>e.notNull()).addColumn(`status`,`varchar(50)`,e=>e.notNull()).addColumn(`type`,`varchar(50)`,e=>e.notNull()).addColumn(`origin_domain_name`,`varchar(255)`).addColumn(`verification`,`varchar(2048)`).addColumn(`custom_client_ip_header`,`varchar(50)`).addColumn(`tls_policy`,`varchar(50)`).addColumn(`domain_metadata`,`varchar(2048)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).execute()}async function Zl(e){}var Ql=t({down:()=>eu,up:()=>$l});async function $l(e){}async function eu(e){await e.schema.alterTable(`users`).dropColumn(`phone_number`).dropColumn(`phone_verified`).dropColumn(`username`).execute()}var tu=t({down:()=>ru,up:()=>nu});async function nu(e){await e.schema.createTable(`forms`).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(255)`,e=>e.notNull()).addColumn(`messages`,`varchar(255)`).addColumn(`languages`,`varchar(255)`).addColumn(`translations`,`varchar(4096)`).addColumn(`nodes`,`varchar(4096)`).addColumn(`start`,`varchar(255)`).addColumn(`ending`,`varchar(255)`).addColumn(`style`,`varchar(1042)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createIndex(`forms_tenant_id_idx`).on(`forms`).column(`tenant_id`).execute()}async function ru(e){await e.schema.dropTable(`forms`).execute()}var iu=t({down:()=>ou,up:()=>au});async function au(e){await e.schema.alterTable(`hooks`).addColumn(`form_id`,`text`).execute(),await e.schema.alterTable(`hooks`).addColumn(`url_tmp`,`varchar(512)`).execute(),await e.updateTable(`hooks`).set(e=>({url_tmp:e.ref(`url`)})).execute(),await e.schema.alterTable(`hooks`).dropColumn(`url`).execute(),await e.schema.alterTable(`hooks`).renameColumn(`url_tmp`,`url`).execute()}async function ou(e){await e.schema.dropTable(`hooks`).ifExists().execute(),await e.schema.createTable(`hooks`).addColumn(`hook_id`,`text`,e=>e.primaryKey()).addColumn(`tenant_id`,`text`,e=>e.notNull()).addColumn(`trigger_id`,`text`,e=>e.notNull()).addColumn(`enabled`,`integer`,e=>e.notNull().defaultTo(0)).addColumn(`url`,`varchar(512)`,e=>e.notNull()).addColumn(`synchronous`,`integer`,e=>e.notNull().defaultTo(0)).addColumn(`priority`,`integer`).addColumn(`created_at`,`text`,e=>e.notNull()).addColumn(`updated_at`,`text`,e=>e.notNull()).execute()}var su=t({down:()=>lu,up:()=>cu});async function cu(e){await e.schema.alterTable(`login_sessions`).addColumn(`login_completed`,`boolean`,e=>e.notNull().defaultTo(0)).execute()}async function lu(e){await e.schema.alterTable(`login_sessions`).dropColumn(`login_completed`).execute()}var uu=t({down:()=>fu,up:()=>du});async function du(e){await e.schema.alterTable(`sessions`).addColumn(`login_session_id`,`varchar(21)`,e=>e.references(`login_sessions.id`).onDelete(`set null`)).execute()}async function fu(e){await e.schema.alterTable(`sessions`).dropColumn(`login_session_id`).execute()}var pu=t({down:()=>hu,up:()=>mu});async function mu(e){await e.schema.createIndex(`IDX_sessions_login_session_id`).on(`sessions`).column(`login_session_id`).execute()}async function hu(e){await e.schema.dropIndex(`IDX_sessions_login_session_id`).on(`sessions`).execute()}var gu=t({down:()=>vu,up:()=>_u});async function _u(e){await e.schema.alterTable(`codes`).addColumn(`code_challenge`,`varchar(128)`).execute(),await e.schema.alterTable(`codes`).addColumn(`code_challenge_method`,`varchar(5)`).execute()}async function vu(e){await e.schema.alterTable(`codes`).dropColumn(`code_challenge`).execute(),await e.schema.alterTable(`codes`).dropColumn(`code_challenge_method`).execute()}var yu=t({down:()=>xu,up:()=>bu});async function bu(e){await e.schema.alterTable(`codes`).addColumn(`redirect_uri`,`varchar(1024)`).execute()}async function xu(e){await e.schema.alterTable(`codes`).dropColumn(`redirect_uri`).execute()}var Su=t({down:()=>wu,up:()=>Cu});async function Cu(e){await e.schema.alterTable(`codes`).addColumn(`nonce`,`varchar(1024)`).execute(),await e.schema.alterTable(`codes`).addColumn(`state`,`varchar(2048)`).execute()}async function wu(e){await e.schema.alterTable(`codes`).dropColumn(`nonce`).execute(),await e.schema.alterTable(`codes`).dropColumn(`state`).execute()}var Tu=t({down:()=>Du,up:()=>Eu});async function Eu(e){await e.schema.createTable(`themes`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`themeId`,`varchar(255)`,e=>e.notNull()).addColumn(`displayName`,`varchar(255)`,e=>e.notNull()).addColumn(`colors_primary_button_label`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_primary_button`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_secondary_button_border`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_secondary_button_label`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_base_focus_color`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_base_hover_color`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_body_text`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_captcha_widget_theme`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_error`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_header`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_icons`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_input_background`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_input_border`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_input_filled_text`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_input_labels_placeholders`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_links_focused_components`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_success`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_widget_background`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_widget_border`,`varchar(24)`,e=>e.notNull()).addColumn(`borders_button_border_radius`,`integer`,e=>e.notNull()).addColumn(`borders_button_border_weight`,`integer`,e=>e.notNull()).addColumn(`borders_buttons_style`,`varchar(24)`,e=>e.notNull()).addColumn(`borders_input_border_radius`,`integer`,e=>e.notNull()).addColumn(`borders_input_border_weight`,`integer`,e=>e.notNull()).addColumn(`borders_inputs_style`,`varchar(24)`,e=>e.notNull()).addColumn(`borders_show_widget_shadow`,`boolean`,e=>e.notNull()).addColumn(`borders_widget_border_weight`,`integer`,e=>e.notNull()).addColumn(`borders_widget_corner_radius`,`integer`,e=>e.notNull()).addColumn(`fonts_body_text_bold`,`integer`,e=>e.notNull()).addColumn(`fonts_body_text_size`,`integer`,e=>e.notNull()).addColumn(`fonts_buttons_text_bold`,`integer`,e=>e.notNull()).addColumn(`fonts_buttons_text_size`,`integer`,e=>e.notNull()).addColumn(`fonts_font_url`,`varchar(255)`,e=>e.notNull()).addColumn(`fonts_input_labels_bold`,`integer`,e=>e.notNull()).addColumn(`fonts_input_labels_size`,`integer`,e=>e.notNull()).addColumn(`fonts_links_bold`,`boolean`,e=>e.notNull()).addColumn(`fonts_links_size`,`integer`,e=>e.notNull()).addColumn(`fonts_links_style`,`varchar(24)`,e=>e.notNull()).addColumn(`fonts_reference_text_size`,`integer`,e=>e.notNull()).addColumn(`fonts_subtitle_bold`,`boolean`,e=>e.notNull()).addColumn(`fonts_subtitle_size`,`integer`,e=>e.notNull()).addColumn(`fonts_title_bold`,`boolean`,e=>e.notNull()).addColumn(`fonts_title_size`,`integer`,e=>e.notNull()).addColumn(`page_background_background_color`,`varchar(24)`,e=>e.notNull()).addColumn(`page_background_background_image_url`,`varchar(255)`,e=>e.notNull()).addColumn(`page_background_page_layout`,`varchar(24)`,e=>e.notNull()).addColumn(`widget_header_text_alignment`,`varchar(24)`,e=>e.notNull()).addColumn(`widget_logo_height`,`integer`,e=>e.notNull()).addColumn(`widget_logo_position`,`varchar(24)`,e=>e.notNull()).addColumn(`widget_logo_url`,`varchar(255)`,e=>e.notNull()).addColumn(`widget_social_buttons_layout`,`varchar(24)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`themes_pkey`,[`tenant_id`,`themeId`]).execute(),await e.schema.createIndex(`themes_tenant_id_idx`).on(`themes`).column(`tenant_id`).execute()}async function Du(e){await e.schema.dropTable(`themes`).execute()}var Ou=t({down:()=>Au,up:()=>ku});async function ku(e){await e.schema.createTable(`resource_servers`).addColumn(`id`,`varchar(21)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`identifier`,`varchar(191)`,e=>e.notNull()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`scopes`,`varchar(4096)`).addColumn(`signing_alg`,`varchar(64)`).addColumn(`signing_secret`,`varchar(2048)`).addColumn(`token_lifetime`,`integer`).addColumn(`token_lifetime_for_web`,`integer`).addColumn(`skip_consent_for_verifiable_first_party_clients`,`integer`).addColumn(`allow_offline_access`,`integer`).addColumn(`verification_key`,`varchar(4096)`).addColumn(`options`,`varchar(4096)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`resource_servers_pk`,[`tenant_id`,`id`]).execute(),await e.schema.createIndex(`resource_servers_tenant_identifier_uq`).on(`resource_servers`).columns([`tenant_id`,`identifier`]).unique().execute(),await e.schema.createTable(`roles`).addColumn(`id`,`varchar(21)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`name`,`varchar(50)`,e=>e.notNull()).addColumn(`description`,`varchar(255)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`roles_pk`,[`tenant_id`,`id`]).execute(),await e.schema.createIndex(`roles_tenant_name_uq`).on(`roles`).columns([`tenant_id`,`name`]).unique().execute()}async function Au(e){await e.schema.dropTable(`roles`).execute(),await e.schema.dropTable(`resource_servers`).execute()}var ju=t({down:()=>Nu,up:()=>Mu});async function Mu(e){await e.schema.createTable(`role_permissions`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`role_id`,`varchar(21)`,e=>e.notNull()).addColumn(`resource_server_identifier`,`varchar(191)`,e=>e.notNull()).addColumn(`permission_name`,`varchar(191)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`role_permissions_pk`,[`tenant_id`,`role_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createIndex(`role_permissions_role_fk`).on(`role_permissions`).columns([`tenant_id`,`role_id`]).execute(),await e.schema.createIndex(`role_permissions_permission_fk`).on(`role_permissions`).columns([`tenant_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createTable(`user_permissions`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`resource_server_identifier`,`varchar(191)`,e=>e.notNull()).addColumn(`permission_name`,`varchar(191)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_permissions_pk`,[`tenant_id`,`user_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createIndex(`user_permissions_user_fk`).on(`user_permissions`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_permissions_permission_fk`).on(`user_permissions`).columns([`tenant_id`,`resource_server_identifier`,`permission_name`]).execute()}async function Nu(e){await e.schema.dropTable(`user_permissions`).execute(),await e.schema.dropTable(`role_permissions`).execute()}var Pu=t({down:()=>Iu,up:()=>Fu});async function Fu(e){await e.schema.createTable(`user_roles`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`role_id`,`varchar(21)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_roles_pk`,[`tenant_id`,`user_id`,`role_id`]).execute(),await e.schema.createIndex(`user_roles_user_fk`).on(`user_roles`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_roles_role_fk`).on(`user_roles`).columns([`tenant_id`,`role_id`]).execute()}async function Iu(e){await e.schema.dropTable(`user_roles`).execute()}var Lu=t({down:()=>zu,up:()=>Ru});async function Ru(e){}async function zu(e){await e.schema.alterTable(`keys`).dropColumn(`connection`).execute(),await e.schema.alterTable(`keys`).modifyColumn(`cert`,`varchar(2048)`).execute(),await e.schema.alterTable(`keys`).modifyColumn(`pkcs7`,`varchar(2048)`).execute(),await e.schema.alterTable(`keys`).dropColumn(`type`).execute()}var Bu=t({down:()=>Hu,up:()=>Vu});async function Vu(e){await e.schema.createTable(`organizations`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`name`,`varchar(256)`,e=>e.notNull()).addColumn(`display_name`,`varchar(256)`).addColumn(`branding`,`text`).addColumn(`metadata`,`text`).addColumn(`enabled_connections`,`text`).addColumn(`token_quota`,`text`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).execute(),await e.schema.createIndex(`idx_organizations_tenant_id`).on(`organizations`).column(`tenant_id`).execute(),await e.schema.createIndex(`idx_organizations_tenant_name_unique`).on(`organizations`).columns([`tenant_id`,`name`]).unique().execute()}async function Hu(e){await e.schema.dropTable(`organizations`).execute()}var Uu=t({down:()=>Gu,up:()=>Wu});async function Wu(e){await e.schema.createTable(`user_organizations`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`organization_id`,`varchar(21)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addUniqueConstraint(`user_organizations_unique`,[`tenant_id`,`user_id`,`organization_id`]).execute(),await e.schema.createIndex(`idx_user_organizations_tenant_id`).on(`user_organizations`).column(`tenant_id`).execute(),await e.schema.createIndex(`idx_user_organizations_user_id`).on(`user_organizations`).column(`user_id`).execute(),await e.schema.createIndex(`idx_user_organizations_organization_id`).on(`user_organizations`).column(`organization_id`).execute()}async function Gu(e){await e.schema.dropTable(`user_organizations`).execute()}var Ku=t({down:()=>Ju,up:()=>qu});async function qu(e){await e.schema.dropTable(`user_permissions`).execute(),await e.schema.dropTable(`user_roles`).execute(),await e.schema.createTable(`user_permissions`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`resource_server_identifier`,`varchar(21)`,e=>e.notNull()).addColumn(`permission_name`,`varchar(191)`,e=>e.notNull()).addColumn(`organization_id`,`varchar(21)`,e=>e.notNull().defaultTo(``)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_permissions_pk`,[`tenant_id`,`user_id`,`resource_server_identifier`,`permission_name`,`organization_id`]).execute(),await e.schema.createIndex(`user_permissions_user_fk`).on(`user_permissions`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_permissions_permission_fk`).on(`user_permissions`).columns([`tenant_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createIndex(`user_permissions_organization_fk`).on(`user_permissions`).column(`organization_id`).execute(),await e.schema.createTable(`user_roles`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`role_id`,`varchar(21)`,e=>e.notNull()).addColumn(`organization_id`,`varchar(191)`,e=>e.notNull().defaultTo(``)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_roles_pk`,[`tenant_id`,`user_id`,`role_id`,`organization_id`]).execute(),await e.schema.createIndex(`user_roles_user_fk`).on(`user_roles`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_roles_role_fk`).on(`user_roles`).columns([`tenant_id`,`role_id`]).execute(),await e.schema.createIndex(`user_roles_organization_fk`).on(`user_roles`).column(`organization_id`).execute()}async function Ju(e){await e.schema.dropTable(`user_permissions`).execute(),await e.schema.dropTable(`user_roles`).execute(),await e.schema.createTable(`user_permissions`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`resource_server_identifier`,`varchar(191)`,e=>e.notNull()).addColumn(`permission_name`,`varchar(191)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_permissions_pk`,[`tenant_id`,`user_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createIndex(`user_permissions_user_fk`).on(`user_permissions`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_permissions_permission_fk`).on(`user_permissions`).columns([`tenant_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createTable(`user_roles`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`role_id`,`varchar(21)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_roles_pk`,[`tenant_id`,`user_id`,`role_id`]).execute(),await e.schema.createIndex(`user_roles_user_fk`).on(`user_roles`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_roles_role_fk`).on(`user_roles`).columns([`tenant_id`,`role_id`]).execute()}var Yu=t({down:()=>Zu,up:()=>Xu});async function Xu(e){await e.schema.createTable(`clients`).addColumn(`client_id`,`varchar(191)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(191)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`description`,`varchar(140)`).addColumn(`global`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`client_secret`,`varchar(255)`).addColumn(`app_type`,`varchar(64)`,e=>e.defaultTo(`regular_web`)).addColumn(`logo_uri`,`varchar(2083)`).addColumn(`is_first_party`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`oidc_conformant`,`integer`,e=>e.defaultTo(1).notNull()).addColumn(`callbacks`,`text`,e=>e.notNull()).addColumn(`allowed_origins`,`text`,e=>e.notNull()).addColumn(`web_origins`,`text`,e=>e.notNull()).addColumn(`client_aliases`,`text`,e=>e.notNull()).addColumn(`allowed_clients`,`text`,e=>e.notNull()).addColumn(`allowed_logout_urls`,`text`,e=>e.notNull()).addColumn(`session_transfer`,`text`,e=>e.notNull()).addColumn(`oidc_logout`,`text`,e=>e.notNull()).addColumn(`grant_types`,`text`,e=>e.notNull()).addColumn(`jwt_configuration`,`text`,e=>e.notNull()).addColumn(`signing_keys`,`text`,e=>e.notNull()).addColumn(`encryption_key`,`text`,e=>e.notNull()).addColumn(`sso`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`sso_disabled`,`integer`,e=>e.defaultTo(1).notNull()).addColumn(`cross_origin_authentication`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`cross_origin_loc`,`varchar(2083)`).addColumn(`custom_login_page_on`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`custom_login_page`,`text`).addColumn(`custom_login_page_preview`,`text`).addColumn(`form_template`,`text`).addColumn(`addons`,`text`,e=>e.notNull()).addColumn(`token_endpoint_auth_method`,`varchar(64)`,e=>e.defaultTo(`client_secret_basic`)).addColumn(`client_metadata`,`text`,e=>e.notNull()).addColumn(`mobile`,`text`,e=>e.notNull()).addColumn(`initiate_login_uri`,`varchar(2083)`).addColumn(`native_social_login`,`text`,e=>e.notNull()).addColumn(`refresh_token`,`text`,e=>e.notNull()).addColumn(`default_organization`,`text`,e=>e.notNull()).addColumn(`organization_usage`,`varchar(32)`,e=>e.defaultTo(`deny`)).addColumn(`organization_require_behavior`,`varchar(32)`,e=>e.defaultTo(`no_prompt`)).addColumn(`client_authentication_methods`,`text`,e=>e.notNull()).addColumn(`require_pushed_authorization_requests`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`require_proof_of_possession`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`signed_request_object`,`text`,e=>e.notNull()).addColumn(`compliance_level`,`varchar(64)`).addColumn(`par_request_expiry`,`integer`).addColumn(`token_quota`,`text`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`clients_tenant_id_client_id`,[`tenant_id`,`client_id`]).execute()}async function Zu(e){await e.schema.dropTable(`clients`).execute()}var Qu=!1;function $u(e){Qu=e}function q(...e){Qu&&console.log(...e)}function J(...e){console.warn(...e)}var ed=t({down:()=>ad,up:()=>nd});async function td(e){try{return await i.sql`SELECT VERSION()`.execute(e),`mysql`}catch{return`sqlite`}}async function nd(e){await td(e)===`mysql`?await rd(e):await id(e)}async function rd(e){await e.transaction().execute(async e=>{let t=await i.sql`
1
+ Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:`Module`}});var e=Object.defineProperty,t=(t,n)=>{let r={};for(var i in t)e(r,i,{get:t[i],enumerable:!0});return n||e(r,Symbol.toStringTag,{value:`Module`}),r};let n=require("nanoid"),r=require("@authhero/adapter-interfaces");require("@hono/zod-openapi");let i=require("kysely");var a=17,o={organization:`org_`,connection:`con_`,action:`act_`,action_version:`ver_`,hook:`h_`,hook_code:`hc_`,rule:`rul_`,resource_server:`api_`,guardian_factor:`gfa_`,invite:`inv_`};function s(e){let t=(0,n.customAlphabet)(`0123456789abcdefghijklmnopqrstuvwxyz`,a)();return`${o[e]}${t}`}function c(){return s(`organization`)}function l(){return s(`connection`)}function u(){return s(`action`)}function d(){return s(`action_version`)}function f(){return s(`hook`)}function p(){return s(`resource_server`)}function m(){return s(`hook_code`)}function h(){return s(`invite`)}function g(e){return async(t,n)=>{let r=Date.now(),i=u();return await e.insertInto(`actions`).values({id:i,tenant_id:t,name:n.name,code:n.code,runtime:n.runtime||null,status:`built`,secrets:n.secrets?JSON.stringify(n.secrets):null,dependencies:n.dependencies?JSON.stringify(n.dependencies):null,supported_triggers:n.supported_triggers?JSON.stringify(n.supported_triggers):null,is_system:+!!n.is_system,inherit:+!!n.inherit,created_at_ts:r,updated_at_ts:r}).execute(),{id:i,tenant_id:t,name:n.name,code:n.code,runtime:n.runtime,status:`built`,secrets:n.secrets?.map(e=>({name:e.name})),dependencies:n.dependencies,supported_triggers:n.supported_triggers,is_system:n.is_system??!1,inherit:n.inherit??!1,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function _(e){if(e!=null){if(typeof e==`number`)return new Date(e).toISOString();if(typeof e==`string`){if(e===``)return;let t=parseFloat(e);return!isNaN(t)&&/^\d+(\.\d+)?$/.test(e)?new Date(t).toISOString():e}}}function v(e,t=new Date(0).toISOString()){return _(e)??t}function y(e){if(!e||e===``)return null;let t=new Date(e);return isNaN(t.getTime())?null:t.getTime()}function b(){return new Date().toISOString()}function x(e,t,n=[]){let r={};for(let n of t){let t=n.replace(/_ts$/,``);r[t]=v(e[n])}for(let t of n){let n=t.replace(/_ts$/,``);r[n]=_(e[t])}return r}function S(e){if(e)try{return JSON.parse(e)}catch{return}}function ee(e){return async(t,n)=>{let r=await e.selectFrom(`actions`).where(`actions.tenant_id`,`=`,t).where(`actions.id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{created_at_ts:i,updated_at_ts:a,deployed_at_ts:o,secrets:s,dependencies:c,supported_triggers:l,is_system:u,inherit:d,tenant_id:f,...p}=r,m=x({created_at_ts:i,updated_at_ts:a},[`created_at_ts`,`updated_at_ts`]);return{...p,tenant_id:t,...m,runtime:p.runtime??void 0,status:p.status||`built`,deployed_at:o?new Date(Number(o)).toISOString():void 0,secrets:S(s),dependencies:S(c),supported_triggers:S(l),is_system:!!u,inherit:!!d}}}function te(e,t){let n=new Set(t),r=e=>{let t=[],r=``,i=!1;for(let n=0;n<e.length;n++){let a=e[n];a===`"`?(i=!i,r+=a):a===` `&&!i?(r.trim()&&t.push(r.trim()),r=``):r+=a}return r.trim()&&t.push(r.trim()),t.filter(e=>{let t=e.replace(/^([^:]+)=/,`$1:`),r=t.startsWith(`-`)?t.slice(1):t;if(r.startsWith(`_exists_:`))return n.has(r.slice(9));let i=r.indexOf(`:`);return i>0?n.has(r.slice(0,i)):!0}).join(` `)},i=e.split(/ OR /i);return i.length>1?i.map(r).filter(e=>e.length>0).join(` OR `):r(e)}function C(e,t,n,r,i=[]){let a=new Set(i),o=n.split(/ OR /i);if(o.length>1)return t.where(e=>{let t=o.map(t=>{let n=t.trim().match(/^([^:]+):(.+)$/);if(n){let[,t,r]=n;if(!t||!r)return null;let i=t.trim(),o=r.replace(/^"(.*)"$/,`$1`).trim();return a.has(i)?e(i,`like`,`%${o}%`):e(i,`=`,o)}return null}).filter(Boolean);return e.or(t)});let s=[],c=``,l=!1;for(let e=0;e<n.length;e++){let t=n[e];t===`"`?(l=!l,c+=t):t===` `&&!l?c.trim()&&(s.push(c.trim()),c=``):c+=t}return c.trim()&&s.push(c.trim()),s.filter(e=>e!==`AND`).map(e=>e.replace(/^([^:]+)=/g,`$1:`)).map(e=>{let t=e.startsWith(`-`),n=null,r=``,i=!1,a;if(e.startsWith(`-_exists_:`))n=e.substring(10),i=!0,t=!0;else if(e.startsWith(`_exists_:`))n=e.substring(9),i=!0,t=!1;else if(e.includes(`:`)){let o=t?e.substring(1):e,s=o.indexOf(`:`);n=o.substring(0,s),r=o.substring(s+1),i=!1,r.startsWith(`>=`)?(a=`>=`,r=r.substring(2)):r.startsWith(`>`)?(a=`>`,r=r.substring(1)):r.startsWith(`<=`)?(a=`<=`,r=r.substring(2)):r.startsWith(`<`)?(a=`<`,r=r.substring(1)):a=`=`,r.startsWith(`"`)&&r.endsWith(`"`)&&r.length>1&&(r=r.slice(1,-1))}else n=null,r=e,i=!1;return{key:n,value:r,isNegation:t,isExistsQuery:i,operator:a}}).forEach(({key:n,value:i,isNegation:o,isExistsQuery:s,operator:c})=>{if(n)if(s)t=o?t.where(n,`is`,null):t.where(n,`is not`,null);else if(a.has(n)&&c===`=`)t=t.where(n,o?`not like`:`like`,`%${i}%`);else if(o)switch(c){case`>`:t=t.where(n,`<=`,i);break;case`>=`:t=t.where(n,`<`,i);break;case`<`:t=t.where(n,`>=`,i);break;case`<=`:t=t.where(n,`>`,i);break;default:t=t.where(n,`!=`,i)}else t=t.where(n,c,i);else if(i){let{ref:n}=e.dynamic;t=t.where(e=>e.or(r.map(t=>t===`user_id`?e(n(t),`=`,i):e(n(t),`like`,`%${i}%`))))}}),t}function w(e){return typeof e==`string`?parseInt(e,10):typeof e==`bigint`?Number(e):e}function T(e){if(e)try{return JSON.parse(e)}catch{return}}function ne(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,q:o}=n,s=e.selectFrom(`actions`).where(`actions.tenant_id`,`=`,t);o&&(s=C(e,s,o,[`name`]));let c=(await s.offset(r*i).limit(i).selectAll().execute()).map(e=>{let{created_at_ts:n,updated_at_ts:r,deployed_at_ts:i,secrets:a,dependencies:o,supported_triggers:s,is_system:c,inherit:l,tenant_id:u,...d}=e,f=x({created_at_ts:n,updated_at_ts:r},[`created_at_ts`,`updated_at_ts`]);return{...d,tenant_id:t,...f,runtime:d.runtime??void 0,status:d.status||`built`,deployed_at:i?new Date(Number(i)).toISOString():void 0,secrets:T(a),dependencies:T(o),supported_triggers:T(s),is_system:!!c,inherit:!!l}});if(!a)return{actions:c,start:0,limit:0,length:0};let{count:l}=await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{actions:c,start:r*i,limit:i,length:w(l)}}}function re(e){if(!e)return[];try{let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}function ie(e){return async(t,n,r)=>{let i={updated_at_ts:Date.now()};if(r.name!==void 0&&(i.name=r.name),r.code!==void 0&&(i.code=r.code),r.runtime!==void 0&&(i.runtime=r.runtime),r.secrets!==void 0){let a=await e.selectFrom(`actions`).where(`actions.id`,`=`,n).where(`actions.tenant_id`,`=`,t).select(`secrets`).executeTakeFirst(),o=new Map(re(a?.secrets).map(e=>[e.name,e])),s=r.secrets.map(e=>e.value===void 0?{name:e.name,value:o.get(e.name)?.value}:e);i.secrets=JSON.stringify(s)}if(r.dependencies!==void 0&&(i.dependencies=JSON.stringify(r.dependencies)),r.supported_triggers!==void 0&&(i.supported_triggers=JSON.stringify(r.supported_triggers)),r.status!==void 0&&(i.status=r.status),r.deployed_at!==void 0){let e=new Date(r.deployed_at).getTime();Number.isFinite(e)&&(i.deployed_at_ts=e)}return r.is_system!==void 0&&(i.is_system=+!!r.is_system),r.inherit!==void 0&&(i.inherit=+!!r.inherit),(await e.updateTable(`actions`).set(i).where(`actions.id`,`=`,n).where(`actions.tenant_id`,`=`,t).executeTakeFirst()).numUpdatedRows>0}}function ae(e){return async(t,n)=>(await e.deleteFrom(`actions`).where(`actions.id`,`=`,n).where(`actions.tenant_id`,`=`,t).executeTakeFirst()).numDeletedRows>0}function oe(e){return{create:g(e),get:ee(e),list:ne(e),update:ie(e),remove:ae(e)}}function se(e){return async(t,n)=>{let r=Date.now();return await e.insertInto(`action_executions`).values({id:n.id,tenant_id:t,trigger_id:n.trigger_id,status:n.status,results:JSON.stringify(n.results),logs:n.logs?JSON.stringify(n.logs):null,created_at_ts:r,updated_at_ts:r}).execute(),{id:n.id,tenant_id:t,trigger_id:n.trigger_id,status:n.status,results:n.results,logs:n.logs,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function ce(e){if(e)try{return JSON.parse(e)}catch{return}}function le(e){return async(t,n)=>{let r=await e.selectFrom(`action_executions`).where(`action_executions.tenant_id`,`=`,t).where(`action_executions.id`,`=`,n).selectAll().executeTakeFirst();return r?{id:r.id,tenant_id:r.tenant_id,trigger_id:r.trigger_id,status:r.status,results:ce(r.results)??[],logs:ce(r.logs),created_at:new Date(Number(r.created_at_ts)).toISOString(),updated_at:new Date(Number(r.updated_at_ts)).toISOString()}:null}}function ue(e){return{create:se(e),get:le(e)}}function de(e){if(e)try{return JSON.parse(e)}catch{return}}function fe(e){let{created_at_ts:t,updated_at_ts:n,secrets:r,dependencies:i,supported_triggers:a,deployed:o,runtime:s,...c}=e;return{...c,runtime:s??void 0,deployed:!!o,secrets:de(r),dependencies:de(i),supported_triggers:de(a),created_at:new Date(Number(t)).toISOString(),updated_at:new Date(Number(n)).toISOString()}}function pe(e){return{async create(t,n){let r=Date.now(),i=d(),a=n.deployed!==!1,o=await e.transaction().execute(async e=>{let o=((await e.selectFrom(`action_versions`).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n.action_id).select(`number`).orderBy(`number`,`desc`).limit(1).executeTakeFirst())?.number??0)+1;return a&&await e.updateTable(`action_versions`).set({deployed:0,updated_at_ts:r}).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n.action_id).execute(),await e.insertInto(`action_versions`).values({id:i,tenant_id:t,action_id:n.action_id,number:o,code:n.code,runtime:n.runtime||null,secrets:n.secrets?JSON.stringify(n.secrets):null,dependencies:n.dependencies?JSON.stringify(n.dependencies):null,supported_triggers:n.supported_triggers?JSON.stringify(n.supported_triggers):null,deployed:+!!a,created_at_ts:r,updated_at_ts:r}).execute(),o});return{id:i,tenant_id:t,action_id:n.action_id,number:o,code:n.code,runtime:n.runtime,secrets:n.secrets,dependencies:n.dependencies,supported_triggers:n.supported_triggers,deployed:a,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}},async get(t,n,r){let i=await e.selectFrom(`action_versions`).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n).where(`id`,`=`,r).selectAll().executeTakeFirst();return i?fe(i):null},async list(t,n,r={}){let{page:i=0,per_page:a=50,include_totals:o=!1}=r,s=e.selectFrom(`action_versions`).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n),c=(await s.orderBy(`number`,`desc`).offset(i*a).limit(a).selectAll().execute()).map(fe);if(!o)return{versions:c,start:0,limit:0,length:0};let{count:l}=await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{versions:c,start:i*a,limit:a,length:w(l)}},async removeForAction(t,n){let r=await e.deleteFrom(`action_versions`).where(`tenant_id`,`=`,t).where(`action_id`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows??0)}}}var E=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})}};function me(e){return async(t,r)=>{let{identities:i,phone_verified:a,password:o,...s}=r,c=new Date().toISOString(),l={...s,login_count:s.login_count??0,created_at:s.created_at??c,updated_at:s.updated_at??c,tenant_id:t,email_verified:+!!r.email_verified,phone_verified:a===void 0?null:+!!a,is_social:+!!r.is_social,app_metadata:JSON.stringify(r.app_metadata),user_metadata:JSON.stringify(r.user_metadata),address:r.address?JSON.stringify(r.address):null};try{let r=async e=>{if(await e.insertInto(`users`).values(l).execute(),o&&l.user_id){let r={id:(0,n.nanoid)(),user_id:l.user_id,password:o.hash,algorithm:o.algorithm,is_current:1,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),tenant_id:t};await e.insertInto(`passwords`).values(r).execute()}};e.isTransaction?await r(e):await e.transaction().execute(r)}catch(e){throw e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`||e.message.includes(`AlreadyExists`)?new E(409,{message:`User already exists`}):new E(500,{message:`${e.code}, ${e.message}`})}return{...l,email:l.email||``,email_verified:l.email_verified===1,phone_verified:l.phone_verified===null?void 0:l.phone_verified===1,is_social:l.is_social===1,address:r.address}}}function D(e){if(typeof e!=`object`||!e)return e;if(Array.isArray(e))return e.map(e=>typeof e==`object`&&e?D(e):e);let t={...e};for(let e in t){let n=t[e];n===null?delete t[e]:typeof n==`object`&&n&&(Array.isArray(n)?t[e]=n.map(e=>typeof e==`object`&&e?D(e):e):t[e]=D(n))}return t}var he=[`email`,`email_verified`,`phone_number`,`phone_verified`,`username`];function O(e,t=!1){let n={connection:e.connection,provider:e.provider,user_id:(0,r.parseUserId)(e.user_id).id,isSocial:!!e.is_social};for(let t of he)e[t]!==void 0&&e[t]!==null&&(n[t]=t.endsWith(`_verified`)?!!e[t]:e[t]);if(!t){let t={};try{t=JSON.parse(e.profileData||`{}`)}catch(e){console.error(`Error parsing profileData`,e)}n.profileData={email:e.email,email_verified:!!e.email_verified,...t}}return n}function ge(e){return async(t,n)=>{let[r,i]=await Promise.all([e.selectFrom(`users`).where(`users.tenant_id`,`=`,t).where(`users.user_id`,`=`,n).selectAll().executeTakeFirst(),e.selectFrom(`users`).where(`users.tenant_id`,`=`,t).where(`users.linked_to`,`=`,n).selectAll().orderBy(`created_at`,`asc`).execute()]);if(!r)return null;let{tenant_id:a,...o}=r;return D({...o,email:r.email||``,email_verified:r.email_verified===1,phone_verified:r.phone_verified===null?void 0:r.phone_verified===1,is_social:r.is_social===1,app_metadata:JSON.parse(r.app_metadata),user_metadata:JSON.parse(r.user_metadata),address:r.address?JSON.parse(r.address):void 0,identities:[O(r,!0),...i.map(e=>O(e))]})}}var _e=[`user_id`,`email`,`email_verified`,`username`,`phone_number`,`phone_verified`,`name`,`given_name`,`family_name`,`nickname`,`picture`,`locale`,`linked_to`,`provider`,`connection`,`is_social`,`last_ip`,`last_login`,`login_count`,`created_at`,`updated_at`],ve=[`email`,`name`,`phone_number`,`user_id`];function ye(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`users`).where(`users.tenant_id`,`=`,t);if(s){let t=te(s,_e);t&&(c=C(e,c,t,ve))}if(o&&o.sort_by){let{ref:t}=e.dynamic;c=c.orderBy(t(o.sort_by),o.sort_order)}let l=await c.offset(r*i).limit(i).selectAll().execute(),u=l.map(e=>e.user_id),d=u.length?await e.selectFrom(`users`).selectAll().where(`users.tenant_id`,`=`,t).where(`users.linked_to`,`in`,u).orderBy(`created_at`,`asc`).execute():[],f=l.map(e=>{let t=d.filter(t=>t.linked_to===e.user_id);return D({...e,email_verified:e.email_verified===1,phone_verified:e.phone_verified===null?void 0:e.phone_verified===1,is_social:e.is_social===1,app_metadata:JSON.parse(e.app_metadata),user_metadata:JSON.parse(e.user_metadata),address:e.address?JSON.parse(e.address):void 0,identities:[O(e,!0),...t.map(e=>O(e))]})});if(!a)return{users:f,start:0,limit:0,length:0};let{count:p}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{users:f,start:r*i,limit:i,length:w(p)}}}function be(e){return async(t,n)=>(await e.deleteFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.user_id`,`in`,e=>e.selectFrom(`users`).select(`users.user_id`).where(`users.tenant_id`,`=`,t).where(e=>e.or([e(`users.user_id`,`=`,n),e(`users.linked_to`,`=`,n)]))).execute(),await e.deleteFrom(`users`).where(`users.tenant_id`,`=`,t).where(`users.linked_to`,`=`,n).execute(),(await e.deleteFrom(`users`).where(`users.tenant_id`,`=`,t).where(`users.user_id`,`=`,n).execute()).length===1)}function k(e,t=``,n={}){for(let r in e)if(Object.prototype.hasOwnProperty.call(e,r)){let i=t?`${t}_${r}`:r,a=e[r];typeof a==`object`&&a&&!Array.isArray(a)?k(a,i,n):typeof a==`boolean`?n[i]=+!!a:n[i]=a}return n}function xe(e,t){let n={};for(let[r,i]of Object.entries(e)){let e=t.find(e=>r.startsWith(`${e}_`));if(!e)n[r]=i;else{let t=r.slice(e.length+1);n[e]={...n[e],[t]:i}}}return n}function Se(e){return async(t,n,r)=>{let i=k({...r,updated_at:new Date().toISOString(),app_metadata:r.app_metadata?JSON.stringify(r.app_metadata):void 0,user_metadata:r.user_metadata?JSON.stringify(r.user_metadata):void 0,address:r.address?JSON.stringify(r.address):void 0,phone_verified:r.phone_verified===void 0?void 0:+!!r.phone_verified});return(await e.updateTable(`users`).set(i).where(`users.tenant_id`,`=`,t).where(`users.user_id`,`=`,n).execute()).length===1}}function Ce(e){return async(t,n,r,i)=>(await e.updateTable(`users`).set({linked_to:null}).where(`users.tenant_id`,`=`,t).where(`users.user_id`,`=`,`${r}|${i}`).where(`users.linked_to`,`=`,`${n}`).execute()).length===1}function we(e){let t=me(e);return{create:t,rawCreate:t,remove:be(e),get:ge(e),list:ye(e),update:Se(e),unlink:Ce(e)}}function Te(e){return async(t,i)=>{let a=new Date().toISOString(),o=r.flowSchema.parse({id:`af_${(0,n.nanoid)()}`,...i,actions:i.actions||[],created_at:a,updated_at:a});return await e.insertInto(`flows`).values({...o,tenant_id:t,actions:JSON.stringify(o.actions)}).execute(),o}}function A(e,t){if(!e)return t;try{return JSON.parse(e)}catch{return t}}function Ee(e){if(e)try{let t=JSON.parse(e);return t&&typeof t==`object`&&!Array.isArray(t)?t:void 0}catch{return}}function De(e,t,n={...e}){for(let r in t)r in e&&(n[r]=A(e[r],t[r]));return n}function Oe(e){return async(t,n)=>{let i=await e.selectFrom(`flows`).selectAll().where(`flows.id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();if(!i)return null;let a={...i,actions:A(i.actions,[])};return r.flowSchema.parse(D(a))}}function ke(e){return async(t,n={})=>{let{page:i=0,per_page:a=50,include_totals:o=!1,q:s}=n,c=e.selectFrom(`flows`).where(`tenant_id`,`=`,t);s&&(c=C(e,c,s,[]));let l=(await c.offset(i*a).limit(a).selectAll().execute()).map(e=>{let t={...e,actions:A(e.actions,[])};return r.flowSchema.parse(D(t))});if(!o)return{flows:l,start:0,limit:0,length:0};let{count:u}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{flows:l,start:i*a,limit:a,length:w(u)}}}function Ae(e){return async(t,n,i)=>{let a={...i,updated_at:new Date().toISOString()};i.actions!==void 0&&(a.actions=JSON.stringify(i.actions));let{numUpdatedRows:o}=await e.updateTable(`flows`).set(a).where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();if(o===0n)return null;let s=await e.selectFrom(`flows`).selectAll().where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();return s?r.flowSchema.parse({...s,actions:s.actions?JSON.parse(s.actions):[]}):null}}function je(e){return async(t,n)=>((await e.deleteFrom(`flows`).where(`id`,`=`,n).where(`tenant_id`,`=`,t).execute())[0]?.numDeletedRows??0n)>0n}function Me(e){return{create:Te(e),get:Oe(e),list:ke(e),update:Ae(e),remove:je(e)}}function j(e,t,n={...e}){for(let r of t)e[r]!==void 0&&(n[r]=JSON.stringify(e[r]));return n}function Ne(e,t,n=e){for(let r of t)e[r]!==void 0&&(n[r]=+!!e[r])}function Pe(e){let t={};for(let n in e)e[n]!==void 0&&e[n]!==null&&(t[n]=e[n]);return t}function Fe(e){let t={...e};return e.session_cookie&&typeof e.session_cookie==`string`&&(t.session_cookie=JSON.parse(e.session_cookie)),e.enabled_locales&&typeof e.enabled_locales==`string`&&(t.enabled_locales=JSON.parse(e.enabled_locales)),e.error_page&&typeof e.error_page==`string`&&(t.error_page=JSON.parse(e.error_page)),e.flags&&typeof e.flags==`string`&&(t.flags=JSON.parse(e.flags)),e.sandbox_versions_available&&typeof e.sandbox_versions_available==`string`&&(t.sandbox_versions_available=JSON.parse(e.sandbox_versions_available)),e.change_password&&typeof e.change_password==`string`&&(t.change_password=JSON.parse(e.change_password)),e.guardian_mfa_page&&typeof e.guardian_mfa_page==`string`&&(t.guardian_mfa_page=JSON.parse(e.guardian_mfa_page)),e.sessions&&typeof e.sessions==`string`&&(t.sessions=JSON.parse(e.sessions)),e.oidc_logout&&typeof e.oidc_logout==`string`&&(t.oidc_logout=JSON.parse(e.oidc_logout)),e.device_flow&&typeof e.device_flow==`string`&&(t.device_flow=JSON.parse(e.device_flow)),e.default_token_quota&&typeof e.default_token_quota==`string`&&(t.default_token_quota=JSON.parse(e.default_token_quota)),e.allowed_logout_urls&&typeof e.allowed_logout_urls==`string`&&(t.allowed_logout_urls=JSON.parse(e.allowed_logout_urls)),e.acr_values_supported&&typeof e.acr_values_supported==`string`&&(t.acr_values_supported=JSON.parse(e.acr_values_supported)),e.mtls&&typeof e.mtls==`string`&&(t.mtls=JSON.parse(e.mtls)),e.mfa&&typeof e.mfa==`string`&&(t.mfa=JSON.parse(e.mfa)),e.attack_protection&&typeof e.attack_protection==`string`&&(t.attack_protection=JSON.parse(e.attack_protection)),e.allow_organization_name_in_authentication_api!==void 0&&(t.allow_organization_name_in_authentication_api=e.allow_organization_name_in_authentication_api===1),e.customize_mfa_in_postlogin_action!==void 0&&(t.customize_mfa_in_postlogin_action=e.customize_mfa_in_postlogin_action===1),e.pushed_authorization_requests_supported!==void 0&&(t.pushed_authorization_requests_supported=e.pushed_authorization_requests_supported===1),e.authorization_response_iss_parameter_supported!==void 0&&(t.authorization_response_iss_parameter_supported=e.authorization_response_iss_parameter_supported===1),D(t)}function Ie(e){let t={...e};return j(e,[`session_cookie`,`enabled_locales`,`error_page`,`flags`,`sandbox_versions_available`,`change_password`,`guardian_mfa_page`,`sessions`,`oidc_logout`,`device_flow`,`default_token_quota`,`allowed_logout_urls`,`acr_values_supported`,`mtls`,`mfa`,`attack_protection`],t),e.allow_organization_name_in_authentication_api!==void 0&&(t.allow_organization_name_in_authentication_api=+!!e.allow_organization_name_in_authentication_api),e.customize_mfa_in_postlogin_action!==void 0&&(t.customize_mfa_in_postlogin_action=+!!e.customize_mfa_in_postlogin_action),e.pushed_authorization_requests_supported!==void 0&&(t.pushed_authorization_requests_supported=+!!e.pushed_authorization_requests_supported),e.authorization_response_iss_parameter_supported!==void 0&&(t.authorization_response_iss_parameter_supported=+!!e.authorization_response_iss_parameter_supported),Pe(t)}function Le(e){return async t=>{let r={id:t.id||(0,n.nanoid)(),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...t},i=Ie(r);try{await e.insertInto(`tenants`).values(i).execute()}catch(e){throw e?.message?.includes(`UNIQUE constraint failed`)||e?.message?.includes(`duplicate key`)||e?.code===`SQLITE_CONSTRAINT`||e?.code===`ER_DUP_ENTRY`||e?.code===`23505`?new E(409,{message:`Tenant with ID '${r.id}' already exists`}):e}return r}}function Re(e){return async t=>{let n=await e.selectFrom(`tenants`).where(`tenants.id`,`=`,t).selectAll().executeTakeFirst();return n?Fe(n):null}}function ze(e){return async t=>{let n=e.selectFrom(`tenants`),{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=t||{};if(o&&o.sort_by){let{ref:t}=e.dynamic;n=n.orderBy(t(o.sort_by),o.sort_order)}s&&(n=C(e,n,s,[`friendly_name`]));let c=(await n.offset(r*i).limit(i).selectAll().execute()).map(Fe);if(!a)return{tenants:c};let{count:l}=await n.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow(),u=w(l);return{tenants:c,start:r*i,limit:i,length:u}}}function Be(e){return async(t,n)=>{let r={...Ie(n),id:t,updated_at:new Date().toISOString()};await e.updateTable(`tenants`).set(r).where(`id`,`=`,t).execute()}}function Ve(e){return async t=>(await e.deleteFrom(`tenants`).where(`tenants.id`,`=`,t).execute()).length===1}function He(e){return{create:Le(e),get:Re(e),list:ze(e),update:Be(e),remove:Ve(e)}}function Ue(e){return e?JSON.stringify(e):void 0}var We=256;function Ge(e){return async(t,r)=>{let i=r.user_agent?.slice(0,We),a=r.log_id||(0,n.nanoid)(),{location_info:o,...s}=r;return await e.insertInto(`logs`).values({...s,log_id:a,tenant_id:t,user_agent:i,description:r.description?.substring(0,256),isMobile:+!!r.isMobile,scope:r.scope,auth0_client:Ue(r.auth0_client),details:Ue(r.details)?.substring(0,8192),country_code:o?.country_code,city_name:o?.city_name,latitude:o?.latitude,longitude:o?.longitude,time_zone:o?.time_zone,continent_code:o?.continent_code}).execute(),{...r,log_id:a,user_agent:i}}}function Ke(e){if(!e)return``;try{return JSON.parse(e)}catch{return e}}function qe(e){return{...e,client_id:e.client_id,client_name:``,auth0_client:Ke(e.auth0_client),details:Ke(e.details),isMobile:!!e.isMobile,scope:e.scope||void 0,log_id:e.log_id,location_info:e.country_code?{country_code:e.country_code,city_name:e.city_name||``,latitude:e.latitude||``,longitude:e.longitude||``,time_zone:e.time_zone||``,continent_code:e.continent_code||``}:void 0}}function Je(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s,from_date:c,to_date:l}=n,u=e.selectFrom(`logs`).where(`logs.tenant_id`,`=`,t);s&&(u=C(e,u,s,[`user_id`,`ip`],[`description`])),typeof c==`number`&&Number.isFinite(c)&&(u=u.where(`logs.date`,`>=`,new Date(Math.floor(c)*1e3).toISOString())),typeof l==`number`&&Number.isFinite(l)&&(u=u.where(`logs.date`,`<=`,new Date(Math.floor(l)*1e3+999).toISOString()));let d=u;if(o&&o.sort_by){let{ref:t}=e.dynamic;d=d.orderBy(t(o.sort_by),o.sort_order)}d=d.offset(r*i).limit(i);let f=(await d.selectAll().execute()).map(qe);if(!a)return{logs:f,start:0,limit:0,length:0};let{count:p}=await u.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{logs:f,start:r*i,limit:i,length:w(p)}}}function Ye(e){return async(t,n)=>{let r=await e.selectFrom(`logs`).where(`logs.tenant_id`,`=`,t).where(`logs.log_id`,`=`,n).selectAll().executeTakeFirst();return r?qe(r):null}}function Xe(e){return{create:Ge(e),list:Je(e),get:Ye(e)}}function Ze(e){return async(t,n)=>{let r=await e.selectFrom(`sessions`).where(`sessions.tenant_id`,`=`,t).where(`sessions.id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,device:a,clients:o,created_at_ts:s,updated_at_ts:c,expires_at_ts:l,idle_expires_at_ts:u,authenticated_at_ts:d,last_interaction_at_ts:f,used_at_ts:p,revoked_at_ts:m,...h}=r,g=x({created_at_ts:s,updated_at_ts:c,expires_at_ts:l,idle_expires_at_ts:u,authenticated_at_ts:d,last_interaction_at_ts:f,used_at_ts:p,revoked_at_ts:m},[`created_at_ts`,`updated_at_ts`,`authenticated_at_ts`,`last_interaction_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`used_at_ts`,`revoked_at_ts`]);return{...h,...g,device:JSON.parse(a),clients:JSON.parse(o)}}}function Qe(e){return async(t,n)=>{let r=Date.now(),i=b(),a={...n,created_at:i,updated_at:i,authenticated_at:i,last_interaction_at:i},{expires_at:o,idle_expires_at:s,used_at:c,revoked_at:l,device:u,clients:d,...f}=n;return await e.insertInto(`sessions`).values({...f,tenant_id:t,created_at_ts:r,updated_at_ts:r,authenticated_at_ts:r,last_interaction_at_ts:r,expires_at_ts:y(o),idle_expires_at_ts:y(s),used_at_ts:y(c),revoked_at_ts:y(l),device:JSON.stringify(u),clients:JSON.stringify(d)}).execute(),a}}function $e(e){return async(t,n)=>!!(await e.deleteFrom(`sessions`).where(`tenant_id`,`=`,t).where(`sessions.id`,`=`,n).execute()).length}function et(e){return async(t,n,r)=>{let i={updated_at_ts:Date.now(),device:r.device?JSON.stringify(r.device):void 0,clients:r.clients?JSON.stringify(r.clients):void 0};return r.expires_at!==void 0&&(i.expires_at_ts=y(r.expires_at)),r.idle_expires_at!==void 0&&(i.idle_expires_at_ts=y(r.idle_expires_at)),r.authenticated_at!==void 0&&(i.authenticated_at_ts=y(r.authenticated_at)),r.last_interaction_at!==void 0&&(i.last_interaction_at_ts=y(r.last_interaction_at)),r.used_at!==void 0&&(i.used_at_ts=y(r.used_at)),r.revoked_at!==void 0&&(i.revoked_at_ts=y(r.revoked_at)),r.user_id!==void 0&&(i.user_id=r.user_id),r.login_session_id!==void 0&&(i.login_session_id=r.login_session_id),!!(await e.updateTable(`sessions`).set(i).where(`tenant_id`,`=`,t).where(`sessions.id`,`=`,n).execute()).length}}function tt(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`sessions`).where(`sessions.tenant_id`,`=`,t);s&&(c=C(e,c,s,[`user_id`,`session_id`]));let l=c;if(o&&o.sort_by){let{ref:t}=e.dynamic;l=l.orderBy(t(o.sort_by),o.sort_order)}l=l.offset(r*i).limit(i);let u=(await l.selectAll().execute()).map(e=>{let{tenant_id:t,device:n,clients:r,created_at_ts:i,updated_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,authenticated_at_ts:c,last_interaction_at_ts:l,used_at_ts:u,revoked_at_ts:d,...f}=e,p=x({created_at_ts:i,updated_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,authenticated_at_ts:c,last_interaction_at_ts:l,used_at_ts:u,revoked_at_ts:d},[`created_at_ts`,`updated_at_ts`,`authenticated_at_ts`,`last_interaction_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`used_at_ts`,`revoked_at_ts`]);return{...f,...p,device:JSON.parse(n),clients:JSON.parse(r)}});if(!a)return{sessions:u,start:0,limit:0,length:0};let{count:d}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow(),f=w(d);return{sessions:u,start:r*i,limit:i,length:f}}}function nt(e){return{create:Qe(e),get:Ze(e),list:tt(e),remove:$e(e),update:et(e)}}function rt(e){return async(t,n)=>{let r=await e.selectFrom(`passwords`).where(`passwords.tenant_id`,`=`,t).where(`passwords.user_id`,`=`,n).where(`passwords.is_current`,`=`,1).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,...a}=r;return{...a,is_current:!!a.is_current}}}function it(e){return async(t,r)=>{let i=r.id||(0,n.nanoid)(),a=r.is_current??!0,o={id:i,...r,is_current:a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return a&&await e.updateTable(`passwords`).set({is_current:0}).where(`user_id`,`=`,r.user_id).where(`tenant_id`,`=`,t).where(`is_current`,`=`,1).execute(),await e.insertInto(`passwords`).values({...o,is_current:+!!o.is_current,tenant_id:t}).execute(),o}}function at(e){return async(t,n)=>{let r=e.updateTable(`passwords`).set({password:n.password,algorithm:n.algorithm,is_current:+!!n.is_current,updated_at:new Date().toISOString()}).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n.user_id);return r=n.id?r.where(`id`,`=`,n.id):r.where(`is_current`,`=`,1),(await r.execute()).length===1}}function ot(e){return async(t,n,r)=>{let i=e.selectFrom(`passwords`).where(`passwords.tenant_id`,`=`,t).where(`passwords.user_id`,`=`,n).orderBy(`created_at`,`desc`);return r&&(i=i.limit(r)),(await i.selectAll().execute()).map(({tenant_id:e,...t})=>({...t,is_current:!!t.is_current}))}}function st(e){return{create:it(e),update:at(e),get:rt(e),list:ot(e)}}function ct(e){return async(t,n={})=>{let{page:i=0,per_page:a=50,include_totals:o=!1,q:s}=n,c=e.selectFrom(`codes`).where(`codes.tenant_id`,`=`,t);s&&(c=C(e,c,s,[`code`,`login_id`]));let l=(await c.offset(i*a).limit(a).selectAll().execute()).map(e=>{let{tenant_id:t,...n}=e;return r.codeSchema.parse(D(n))});if(!o)return{codes:l,start:0,limit:0,length:0};let{count:u}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{codes:l,start:i*a,limit:a,length:w(u)}}}function lt(e){return async(t,n)=>{let r={...n,created_at:new Date().toISOString()};return await e.insertInto(`codes`).values({...r,tenant_id:t}).execute(),r}}function ut(e){return async(t,n)=>(await e.deleteFrom(`codes`).where(`codes.tenant_id`,`=`,t).where(`codes.code_id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function dt(e){return async(t,n,r)=>{let i=e.selectFrom(`codes`).where(`codes.code_id`,`=`,n).where(`codes.code_type`,`=`,r);t.length&&(i=i.where(`codes.tenant_id`,`=`,t));let a=await i.selectAll().executeTakeFirst();return a?D(a):null}}function ft(e){return async(t,n)=>(await e.updateTable(`codes`).set({used_at:new Date().toISOString()}).where(`codes.tenant_id`,`=`,t).where(`codes.code_id`,`=`,n).executeTakeFirst()).numUpdatedRows>0}function pt(e){return async(t,n)=>(await e.updateTable(`codes`).set({used_at:new Date().toISOString()}).where(`codes.tenant_id`,`=`,t).where(`codes.code_id`,`=`,n).where(`codes.used_at`,`is`,null).executeTakeFirst()).numUpdatedRows>0}function mt(e){return{create:lt(e),list:ct(e),remove:ut(e),used:ft(e),consume:pt(e),get:dt(e)}}function ht(e){return async(t,n)=>{let{is_system:r,...i}=n;delete i.enabled_clients;let a={id:i.id||l(),...i,is_system:r?!0:void 0,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return await e.insertInto(`connections`).values({...a,is_system:+!!r,options:JSON.stringify(a.options||{}),tenant_id:t}).execute(),a}}function gt(e){let{is_system:t,...n}=e;return D({...n,is_system:t?!0:void 0,options:typeof e.options==`string`?JSON.parse(e.options):{}})}function _t(e){return e.map(gt)}function vt(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,q:o}=n,s=e.selectFrom(`connections`).where(`connections.tenant_id`,`=`,t);o&&(s=C(e,s,o,[`user_id`,`ip`]));let c=_t(await s.offset(r*i).limit(i).selectAll().execute());if(!a)return{connections:c,start:0,limit:0,length:0};let{count:l}=await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{connections:c,start:r*i,limit:i,length:w(l)}}}function yt(e){return async(t,n)=>(await e.deleteFrom(`connections`).where(`connections.tenant_id`,`=`,t).where(`connections.id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function bt(e){return async(t,n)=>{let r=await e.selectFrom(`connections`).where(`connections.tenant_id`,`=`,t).where(`connections.id`,`=`,n).selectAll().executeTakeFirst();return r?gt(r):null}}function xt(e){return async(t,n,r)=>{let{is_system:i,...a}=r;delete a.enabled_clients;let o={...a,is_system:i===void 0?void 0:+!!i,updated_at:new Date().toISOString()};return await e.updateTable(`connections`).set({...o,options:o.options?JSON.stringify(o.options):void 0}).where(`connections.id`,`=`,n).where(`connections.tenant_id`,`=`,t).execute(),!0}}function St(e){return{create:ht(e),get:bt(e),list:vt(e),remove:yt(e),update:xt(e)}}function Ct(e){return async(t,r)=>{let i=r.client_id??(0,n.nanoid)(),a={created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...r,client_id:i,global:r.global??!1,is_first_party:r.is_first_party??!0,oidc_conformant:r.oidc_conformant??!0,auth0_conformant:r.auth0_conformant??!0,sso:r.sso??!1,sso_disabled:r.sso_disabled??!1,cross_origin_authentication:r.cross_origin_authentication??!1,custom_login_page_on:r.custom_login_page_on??!1,require_pushed_authorization_requests:r.require_pushed_authorization_requests??!1,require_proof_of_possession:r.require_proof_of_possession??!1,hide_sign_up_disabled_error:r.hide_sign_up_disabled_error??!1},o={...a,tenant_id:t};return Ne(a,[`global`,`is_first_party`,`oidc_conformant`,`auth0_conformant`,`sso`,`sso_disabled`,`cross_origin_authentication`,`custom_login_page_on`,`require_pushed_authorization_requests`,`require_proof_of_possession`,`hide_sign_up_disabled_error`],o),Object.assign(o,{callbacks:JSON.stringify(r.callbacks||[]),allowed_origins:JSON.stringify(r.allowed_origins||[]),web_origins:JSON.stringify(r.web_origins||[]),client_aliases:JSON.stringify(r.client_aliases||[]),allowed_clients:JSON.stringify(r.allowed_clients||[]),connections:JSON.stringify(r.connections||[]),allowed_logout_urls:JSON.stringify(r.allowed_logout_urls||[]),session_transfer:JSON.stringify(r.session_transfer||{}),oidc_logout:JSON.stringify(r.oidc_logout||{}),grant_types:JSON.stringify(r.grant_types||[]),jwt_configuration:JSON.stringify(r.jwt_configuration||{}),signing_keys:JSON.stringify(r.signing_keys||[]),encryption_key:JSON.stringify(r.encryption_key||{}),addons:JSON.stringify(r.addons||{}),client_metadata:JSON.stringify(r.client_metadata||{}),mobile:JSON.stringify(r.mobile||{}),native_social_login:JSON.stringify(r.native_social_login||{}),refresh_token:JSON.stringify(r.refresh_token||{}),default_organization:JSON.stringify(r.default_organization||{}),client_authentication_methods:JSON.stringify(r.client_authentication_methods||{}),signed_request_object:JSON.stringify(r.signed_request_object||{}),token_quota:JSON.stringify(r.token_quota||{}),owner_user_id:r.owner_user_id??null,registration_type:r.registration_type??null,registration_metadata:r.registration_metadata?JSON.stringify(r.registration_metadata):null}),await e.insertInto(`clients`).values(o).execute(),a}}function wt(e){return async(t,n)=>{let r=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,...a}=r;return D({...a,global:!!r.global,is_first_party:!!r.is_first_party,oidc_conformant:!!r.oidc_conformant,auth0_conformant:!!r.auth0_conformant,sso:!!r.sso,sso_disabled:!!r.sso_disabled,cross_origin_authentication:!!r.cross_origin_authentication,custom_login_page_on:!!r.custom_login_page_on,require_pushed_authorization_requests:!!r.require_pushed_authorization_requests,require_proof_of_possession:!!r.require_proof_of_possession,hide_sign_up_disabled_error:!!r.hide_sign_up_disabled_error,callbacks:JSON.parse(r.callbacks),allowed_origins:JSON.parse(r.allowed_origins),web_origins:JSON.parse(r.web_origins),client_aliases:JSON.parse(r.client_aliases),allowed_clients:JSON.parse(r.allowed_clients),connections:JSON.parse(r.connections||`[]`),allowed_logout_urls:JSON.parse(r.allowed_logout_urls),session_transfer:JSON.parse(r.session_transfer),oidc_logout:JSON.parse(r.oidc_logout),grant_types:JSON.parse(r.grant_types),jwt_configuration:JSON.parse(r.jwt_configuration),signing_keys:JSON.parse(r.signing_keys),encryption_key:JSON.parse(r.encryption_key),addons:JSON.parse(r.addons),client_metadata:JSON.parse(r.client_metadata),mobile:JSON.parse(r.mobile),native_social_login:JSON.parse(r.native_social_login),refresh_token:JSON.parse(r.refresh_token),default_organization:JSON.parse(r.default_organization),client_authentication_methods:JSON.parse(r.client_authentication_methods),signed_request_object:JSON.parse(r.signed_request_object),token_quota:JSON.parse(r.token_quota),registration_metadata:r.registration_metadata?JSON.parse(r.registration_metadata):void 0})}}function Tt(e){return async t=>{let n=await e.selectFrom(`clients`).where(`clients.client_id`,`=`,t).selectAll().executeTakeFirst();return n?D({...n,global:!!n.global,is_first_party:!!n.is_first_party,oidc_conformant:!!n.oidc_conformant,auth0_conformant:!!n.auth0_conformant,sso:!!n.sso,sso_disabled:!!n.sso_disabled,cross_origin_authentication:!!n.cross_origin_authentication,custom_login_page_on:!!n.custom_login_page_on,require_pushed_authorization_requests:!!n.require_pushed_authorization_requests,require_proof_of_possession:!!n.require_proof_of_possession,hide_sign_up_disabled_error:!!n.hide_sign_up_disabled_error,callbacks:JSON.parse(n.callbacks),allowed_origins:JSON.parse(n.allowed_origins),web_origins:JSON.parse(n.web_origins),client_aliases:JSON.parse(n.client_aliases),allowed_clients:JSON.parse(n.allowed_clients),connections:JSON.parse(n.connections||`[]`),allowed_logout_urls:JSON.parse(n.allowed_logout_urls),session_transfer:JSON.parse(n.session_transfer),oidc_logout:JSON.parse(n.oidc_logout),grant_types:JSON.parse(n.grant_types),jwt_configuration:JSON.parse(n.jwt_configuration),signing_keys:JSON.parse(n.signing_keys),encryption_key:JSON.parse(n.encryption_key),addons:JSON.parse(n.addons),client_metadata:JSON.parse(n.client_metadata),mobile:JSON.parse(n.mobile),native_social_login:JSON.parse(n.native_social_login),refresh_token:JSON.parse(n.refresh_token),default_organization:JSON.parse(n.default_organization),client_authentication_methods:JSON.parse(n.client_authentication_methods),signed_request_object:JSON.parse(n.signed_request_object),token_quota:JSON.parse(n.token_quota),registration_metadata:n.registration_metadata?JSON.parse(n.registration_metadata):void 0}):null}}function Et(e){return async(t,n)=>{let r=e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t),a=new Set([`owner_user_id`,`registration_type`]);if(n?.q){let e=n.q.trim().match(/^([a-zA-Z_][a-zA-Z0-9_]*):"?([^"]*)"?$/);if(e&&a.has(e[1])&&e[2]){let t=e[1];r=r.where(t,`=`,e[2])}else r=r.where(e=>e.or([e(`name`,`like`,`%${n.q}%`),e(`client_id`,`like`,`%${n.q}%`)]))}if(n?.sort){let e=n.sort.sort_order===`asc`?`asc`:`desc`,t=n.sort.sort_by;r=[`name`,`client_id`,`created_at`,`updated_at`].includes(t)?r.orderBy(t,e):r.orderBy(`created_at`,`desc`)}else r=r.orderBy(`created_at`,`desc`);if(n?.from!==void 0){let e=parseInt(n.from,10);isNaN(e)||(r=r.offset(e))}else if(n?.page!==void 0){let e=n?.per_page||n?.take||10,t=n.page*e;r=r.offset(t)}let o=n?.take||n?.per_page||10;r=r.limit(o);let s=await r.selectAll().execute(),c=s.length;if(n?.include_totals){let r=e.selectFrom(`clients`).select(i.sql`count(*)`.as(`count`)).where(`clients.tenant_id`,`=`,t);if(n?.q){let e=n.q.trim().match(/^([a-zA-Z_][a-zA-Z0-9_]*):"?([^"]*)"?$/);if(e&&a.has(e[1])&&e[2]){let t=e[1];r=r.where(t,`=`,e[2])}else r=r.where(e=>e.or([e(`name`,`like`,`%${n.q}%`),e(`client_id`,`like`,`%${n.q}%`)]))}let o=await r.executeTakeFirst();c=Number(o?.count||0)}let l=s.map(e=>D({...e,global:!!e.global,is_first_party:!!e.is_first_party,oidc_conformant:!!e.oidc_conformant,auth0_conformant:!!e.auth0_conformant,sso:!!e.sso,sso_disabled:!!e.sso_disabled,cross_origin_authentication:!!e.cross_origin_authentication,custom_login_page_on:!!e.custom_login_page_on,require_pushed_authorization_requests:!!e.require_pushed_authorization_requests,require_proof_of_possession:!!e.require_proof_of_possession,hide_sign_up_disabled_error:!!e.hide_sign_up_disabled_error,callbacks:JSON.parse(e.callbacks),allowed_origins:JSON.parse(e.allowed_origins),web_origins:JSON.parse(e.web_origins),client_aliases:JSON.parse(e.client_aliases),allowed_clients:JSON.parse(e.allowed_clients),connections:JSON.parse(e.connections||`[]`),allowed_logout_urls:JSON.parse(e.allowed_logout_urls),session_transfer:JSON.parse(e.session_transfer),oidc_logout:JSON.parse(e.oidc_logout),grant_types:JSON.parse(e.grant_types),jwt_configuration:JSON.parse(e.jwt_configuration),signing_keys:JSON.parse(e.signing_keys),encryption_key:JSON.parse(e.encryption_key),addons:JSON.parse(e.addons),client_metadata:JSON.parse(e.client_metadata),mobile:JSON.parse(e.mobile),native_social_login:JSON.parse(e.native_social_login),refresh_token:JSON.parse(e.refresh_token),default_organization:JSON.parse(e.default_organization),client_authentication_methods:JSON.parse(e.client_authentication_methods),signed_request_object:JSON.parse(e.signed_request_object),token_quota:JSON.parse(e.token_quota),registration_metadata:e.registration_metadata?JSON.parse(e.registration_metadata):void 0})),u=n?.take||n?.per_page||10,d=n?.from?parseInt(n.from,10):n?.page?n.page*u:0;return{clients:l,totals:{start:isNaN(d)?0:d,limit:u,length:l.length,total:c}}}}function Dt(e){return async(t,n)=>(await e.deleteFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function Ot(e){return async(t,n,r)=>{let i={...r,updated_at:new Date().toISOString()};return Ne(r,[`global`,`is_first_party`,`oidc_conformant`,`auth0_conformant`,`sso`,`sso_disabled`,`cross_origin_authentication`,`custom_login_page_on`,`require_pushed_authorization_requests`,`require_proof_of_possession`,`hide_sign_up_disabled_error`],i),j(r,[`callbacks`,`allowed_origins`,`web_origins`,`client_aliases`,`allowed_clients`,`connections`,`allowed_logout_urls`,`session_transfer`,`oidc_logout`,`grant_types`,`jwt_configuration`,`signing_keys`,`encryption_key`,`addons`,`client_metadata`,`mobile`,`native_social_login`,`refresh_token`,`default_organization`,`client_authentication_methods`,`signed_request_object`,`token_quota`,`registration_metadata`],i),(await e.updateTable(`clients`).set(i).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).executeTakeFirst()).numUpdatedRows>0}}function kt(e){return{create:Ct(e),get:wt(e),getByClientId:Tt(e),list:Et(e),remove:Dt(e),update:Ot(e)}}function At(e){return async(t,n)=>{let r=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).select(`connections`).executeTakeFirst();if(!r)return[];let i=JSON.parse(r.connections||`[]`);if(i.length===0)return[];let a=await e.selectFrom(`connections`).where(`connections.tenant_id`,`=`,t).where(`connections.id`,`in`,i).selectAll().execute(),o=new Map(a.map(e=>[e.id,gt(e)]));return i.map(e=>o.get(e)).filter(e=>e!==void 0)}}function jt(e){return async(t,n,r)=>(await e.updateTable(`clients`).set({connections:JSON.stringify(r),updated_at:new Date().toISOString()}).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,n).executeTakeFirst()).numUpdatedRows>0}function Mt(e){return async(t,n)=>{let r=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).select([`client_id`,`connections`]).execute(),i=[];for(let e of r)JSON.parse(e.connections||`[]`).includes(n)&&i.push(e.client_id);return i}}function Nt(e){return async(t,n,r)=>{let i=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,r).select(`connections`).executeTakeFirst();if(!i)return!1;let a=JSON.parse(i.connections||`[]`);return a.includes(n)?!0:(a.push(n),(await e.updateTable(`clients`).set({connections:JSON.stringify(a),updated_at:new Date().toISOString()}).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,r).executeTakeFirst()).numUpdatedRows>0)}}function Pt(e){return async(t,n,r)=>{let i=await e.selectFrom(`clients`).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,r).select(`connections`).executeTakeFirst();if(!i)return!1;let a=JSON.parse(i.connections||`[]`),o=a.filter(e=>e!==n);return o.length===a.length?!0:(await e.updateTable(`clients`).set({connections:JSON.stringify(o),updated_at:new Date().toISOString()}).where(`clients.tenant_id`,`=`,t).where(`clients.client_id`,`=`,r).executeTakeFirst()).numUpdatedRows>0}}function Ft(e){return{listByClient:At(e),updateByClient:jt(e),listByConnection:Mt(e),addClientToConnection:Nt(e),removeClientFromConnection:Pt(e)}}function It(e){return async(t,r)=>{let i=new Date().toISOString(),a=(0,n.nanoid)(),{scope:o,authorization_details_types:s,...c}=r,l={id:a,tenant_id:t,...c,scope:o?JSON.stringify(o):`[]`,authorization_details_types:s?JSON.stringify(s):`[]`,allow_any_organization:c.allow_any_organization===void 0?void 0:+!!c.allow_any_organization,is_system:c.is_system===void 0?void 0:+!!c.is_system,created_at:i,updated_at:i};return await e.insertInto(`client_grants`).values(l).execute(),D({id:a,tenant_id:t,...c,scope:o||[],authorization_details_types:s||[],allow_any_organization:c.allow_any_organization??!1,is_system:c.is_system??!1,created_at:i,updated_at:i})}}function Lt(e){return async(t,n)=>{let r=await e.selectFrom(`client_grants`).selectAll().where(`client_grants.tenant_id`,`=`,t).where(`client_grants.id`,`=`,n).executeTakeFirst();return r?D({id:r.id,client_id:r.client_id,audience:r.audience,scope:r.scope?JSON.parse(r.scope):[],organization_usage:r.organization_usage,allow_any_organization:r.allow_any_organization===void 0?!1:!!r.allow_any_organization,is_system:r.is_system===void 0?!1:!!r.is_system,subject_type:r.subject_type,authorization_details_types:r.authorization_details_types?JSON.parse(r.authorization_details_types):[],created_at:r.created_at,updated_at:r.updated_at}):null}}function Rt(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,q:o,sort:s}=n,c=e.selectFrom(`client_grants`).where(`client_grants.tenant_id`,`=`,t);if(o){let t=o.trim(),n=t.split(/\s+/),r=n.length===1?n[0]:void 0,i=r?r.match(/^(-)?([a-zA-Z_][a-zA-Z0-9_]*):"?([^"]*)"?$/):null,a=i?i[3]:``,s=/^(>=|>|<=|<)/.test(a||``);if(i&&!s&&a){let t=!!i[1],n=i[2],{ref:r}=e.dynamic,o=r(`client_grants.${n}`);if(n===`allow_any_organization`){let e=+(a===`true`);c=t?c.where(o,`!=`,e):c.where(o,`=`,e)}else c=t?c.where(o,`!=`,a):c.where(o,`=`,a)}else c=C(e,c,t,[])}let l=c;if(s){let{ref:t}=e.dynamic;l=l.orderBy(t(s.sort_by),s.sort_order)}else l=l.orderBy(`client_grants.created_at`,`desc`);l=l.limit(i).offset(r*i);let u=(await l.selectAll().execute()).map(e=>D({id:e.id,client_id:e.client_id,audience:e.audience,scope:e.scope?JSON.parse(e.scope):[],organization_usage:e.organization_usage,allow_any_organization:e.allow_any_organization===void 0?!1:!!e.allow_any_organization,is_system:e.is_system===void 0?!1:!!e.is_system,subject_type:e.subject_type,authorization_details_types:e.authorization_details_types?JSON.parse(e.authorization_details_types):[],created_at:e.created_at,updated_at:e.updated_at}));if(!a)return{client_grants:u,start:0,limit:0,length:0};let{count:d}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{client_grants:u,start:r*i,limit:i,length:w(d)}}}function zt(e){return async(t,n)=>((await e.deleteFrom(`client_grants`).where(`client_grants.tenant_id`,`=`,t).where(`client_grants.id`,`=`,n).executeTakeFirst()).numDeletedRows??0n)>0n}function Bt(e){return async(t,n,r)=>{let i=new Date().toISOString(),{scope:a,authorization_details_types:o,...s}=r,c={...s,updated_at:i};return a!==void 0&&(c.scope=JSON.stringify(a)),o!==void 0&&(c.authorization_details_types=JSON.stringify(o)),s.allow_any_organization!==void 0&&(c.allow_any_organization=+!!s.allow_any_organization),s.is_system!==void 0&&(c.is_system=+!!s.is_system),((await e.updateTable(`client_grants`).set(c).where(`client_grants.tenant_id`,`=`,t).where(`client_grants.id`,`=`,n).executeTakeFirst()).numUpdatedRows??0n)>0n}}function Vt(e){return{create:It(e),get:Lt(e),list:Rt(e),remove:zt(e),update:Bt(e)}}function Ht(e){return async(t,n)=>{let r=Date.now();return await e.insertInto(`client_registration_tokens`).values({id:n.id,tenant_id:t,token_hash:n.token_hash,type:n.type,client_id:n.client_id??null,sub:n.sub??null,constraints:n.constraints?JSON.stringify(n.constraints):null,single_use:+!!n.single_use,expires_at_ts:y(n.expires_at),created_at_ts:r,used_at_ts:null,revoked_at_ts:null}).execute(),{id:n.id,token_hash:n.token_hash,type:n.type,client_id:n.client_id,sub:n.sub,constraints:n.constraints,single_use:n.single_use,expires_at:n.expires_at,created_at:new Date(r).toISOString()}}}function Ut(e){let t=r.clientRegistrationTokenTypeSchema.safeParse(e);if(!t.success)throw Error(`Unknown client_registration_tokens.type: ${e}`);return t.data}function Wt(e){if(!e)return;let t;try{t=JSON.parse(e)}catch{return}return(0,r.isPlainObject)(t)?t:void 0}function Gt(e){return{id:e.id,token_hash:e.token_hash,type:Ut(e.type),client_id:e.client_id??void 0,sub:e.sub??void 0,constraints:Wt(e.constraints),single_use:!!e.single_use,expires_at:_(e.expires_at_ts),used_at:_(e.used_at_ts),revoked_at:_(e.revoked_at_ts),created_at:v(e.created_at_ts)}}function Kt(e){return async(t,n)=>{let r=await e.selectFrom(`client_registration_tokens`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).selectAll().executeTakeFirst();return r?Gt(r):null}}function qt(e){return async(t,n)=>{let r=await e.selectFrom(`client_registration_tokens`).where(`tenant_id`,`=`,t).where(`token_hash`,`=`,n).selectAll().executeTakeFirst();return r?Gt(r):null}}function Jt(e){return async(t,n)=>(await e.selectFrom(`client_registration_tokens`).where(`tenant_id`,`=`,t).where(`client_id`,`=`,n).orderBy(`created_at_ts`,`desc`).selectAll().execute()).map(Gt)}function Yt(e){return async(t,n,r)=>(await e.updateTable(`client_registration_tokens`).set({used_at_ts:y(r)}).where(`tenant_id`,`=`,t).where(`id`,`=`,n).where(`used_at_ts`,`is`,null).executeTakeFirst()).numUpdatedRows>0}function Xt(e){return async(t,n,r)=>(await e.updateTable(`client_registration_tokens`).set({revoked_at_ts:y(r)}).where(`tenant_id`,`=`,t).where(`id`,`=`,n).where(`revoked_at_ts`,`is`,null).executeTakeFirst()).numUpdatedRows>0}function Zt(e){return async(t,n,r)=>{let i=await e.updateTable(`client_registration_tokens`).set({revoked_at_ts:y(r)}).where(`tenant_id`,`=`,t).where(`client_id`,`=`,n).where(`revoked_at_ts`,`is`,null).executeTakeFirst();return Number(i.numUpdatedRows)}}function Qt(e){return async(t,n)=>(await e.deleteFrom(`client_registration_tokens`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function $t(e){return{create:Ht(e),get:Kt(e),getByHash:qt(e),listByClient:Jt(e),markUsed:Yt(e),revoke:Xt(e),revokeByClient:Zt(e),remove:Qt(e)}}function en(e){return async(t={})=>{let{page:n=0,per_page:r=100,include_totals:i=!1,sort:a,q:o}=t,s=e.selectFrom(`keys`).where(e=>e.or([e(`revoked_at`,`>`,new Date().toISOString()),e(`revoked_at`,`is`,null)]));o&&(s=C(e,s,o,[`kid`,`tenant_id`,`connection`,`fingerprint`,`thumbprint`,`type`]));let c=s.select(e=>e.fn.count(`kid`).as(`count`)),l=n*r;s=s.limit(r).offset(l),a&&(s=s.orderBy(a.sort_by,a.sort_order));let u=await s.selectAll().execute();return i?{signingKeys:u,start:l,limit:r,length:w((await c.executeTakeFirst())?.count??0)}:{signingKeys:u,start:0,limit:0,length:0}}}function tn(e){return async t=>{await e.insertInto(`keys`).values({...t,created_at:new Date().toDateString()}).execute()}}function nn(e){return async(t,n)=>!!(await e.updateTable(`keys`).set(n).where(`kid`,`=`,t).execute()).length}function rn(e){return{create:tn(e),list:en(e),update:nn(e)}}function an(e){return async(t,r)=>{let i={custom_domain_id:r.custom_domain_id||(0,n.nanoid)(),status:`pending`,primary:!1,...r};return await e.insertInto(`custom_domains`).values({...i,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),tenant_id:t,primary:+!!i.primary,domain_metadata:i.domain_metadata?JSON.stringify(i.domain_metadata):void 0}).execute(),i}}function on(e){return async t=>(await e.selectFrom(`custom_domains`).where(`custom_domains.tenant_id`,`=`,t).selectAll().execute()).map(e=>({...e,primary:e.primary===1,domain_metadata:A(e.domain_metadata,void 0),verification:A(e.verification,void 0)}))}function sn(e){return async(t,n)=>(await e.deleteFrom(`custom_domains`).where(`custom_domains.tenant_id`,`=`,t).where(`custom_domains.custom_domain_id`,`=`,n).execute()).length>0}function cn(e){return async(t,n)=>{let r=await e.selectFrom(`custom_domains`).where(`custom_domains.tenant_id`,`=`,t).where(`custom_domains.custom_domain_id`,`=`,n).selectAll().executeTakeFirst();return r?{...r,primary:r.primary===1,domain_metadata:A(r.domain_metadata,void 0),verification:A(r.verification,void 0)}:null}}function ln(e){return async(t,n,r)=>{let{verification:i,domain_metadata:a,primary:o,...s}=r,c={...s,updated_at:new Date().toISOString(),...o!==void 0&&{primary:+!!o},...a!==void 0&&{domain_metadata:JSON.stringify(a)},...i!==void 0&&{verification:JSON.stringify(i)}};return(await e.updateTable(`custom_domains`).set(c).where(`custom_domains.tenant_id`,`=`,t).where(`custom_domains.custom_domain_id`,`=`,n).execute()).length>0}}function un(e){return async t=>{let n=await e.selectFrom(`custom_domains`).where(`custom_domains.domain`,`=`,t).selectAll().executeTakeFirst();return n?{...n,primary:n.primary===1,domain_metadata:A(n.domain_metadata,void 0)}:null}}function dn(e){return{create:an(e),get:cn(e),getByDomain:un(e),list:on(e),remove:sn(e),update:ln(e)}}function fn(e){return async t=>{let[n]=await e.selectFrom(`branding`).where(`branding.tenant_id`,`=`,t).selectAll().execute();if(!n)return null;let{tenant_id:r,colors_primary:i,colors_page_background_type:a,colors_page_background_start:o,colors_page_background_end:s,colors_page_background_angle_dev:c,font_url:l,...u}=n;return D({...u,colors:{primary:i,page_background:{type:a,start:o,end:s,angle_deg:c}},font:l?{url:l}:void 0})}}function pn(e){return async(t,n)=>{let{colors:r,font:i,...a}=n,o=r?.page_background,s=o&&typeof o==`object`?o:void 0;try{await e.insertInto(`branding`).values({...a,colors_primary:r?.primary,colors_page_background_type:s?.type,colors_page_background_start:s?.start,colors_page_background_end:s?.end,colors_page_background_angle_dev:s?.angle_deg,font_url:n.font?.url,tenant_id:t}).execute()}catch{await e.updateTable(`branding`).set({...a,colors_primary:r?.primary,colors_page_background_type:s?.type,colors_page_background_start:s?.start,colors_page_background_end:s?.end,colors_page_background_angle_dev:s?.angle_deg,font_url:n.font?.url}).where(`tenant_id`,`=`,t).execute()}}}function mn(e){return{get:fn(e),set:pn(e)}}function hn(e){return async t=>{let n=await e.selectFrom(`universal_login_templates`).select([`body`]).where(`tenant_id`,`=`,t).executeTakeFirst();return n?{body:n.body}:null}}function gn(e){return async(t,n)=>{let r=Date.now();try{await e.insertInto(`universal_login_templates`).values({tenant_id:t,body:n.body,created_at_ts:r,updated_at_ts:r}).execute()}catch{await e.updateTable(`universal_login_templates`).set({body:n.body,updated_at_ts:r}).where(`tenant_id`,`=`,t).execute()}}}function _n(e){return async t=>{await e.deleteFrom(`universal_login_templates`).where(`tenant_id`,`=`,t).execute()}}function vn(e){return{get:hn(e),set:gn(e),delete:_n(e)}}function yn(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`hooks`).where(`hooks.tenant_id`,`=`,t);if(s&&(c=C(e,c,s,[`url`,`form_id`,`template_id`,`code_id`])),o?.sort_by){let{ref:t}=e.dynamic;c=c.orderBy(t(o.sort_by),o.sort_order)}else c=c.orderBy(`priority`,`desc`).orderBy(`created_at_ts`,`asc`);let l=(await c.offset(r*i).limit(i).selectAll().execute()).map(e=>{let{tenant_id:t,enabled:n,synchronous:r,created_at_ts:i,updated_at_ts:a,metadata:o,...s}=e,c=x({created_at_ts:i,updated_at_ts:a},[`created_at_ts`,`updated_at_ts`]);return D({...s,...c,enabled:!!n,synchronous:!!r,metadata:Ee(o)})});if(!a)return{hooks:l,start:0,limit:0,length:0};let{count:u}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{hooks:l,start:r*i,limit:i,length:w(u)}}}function bn(e){return async(t,n)=>{let r=await e.selectFrom(`hooks`).where(`hooks.tenant_id`,`=`,t).where(`hooks.hook_id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,created_at_ts:a,updated_at_ts:o,metadata:s,...c}=r,l=x({created_at_ts:a,updated_at_ts:o},[`created_at_ts`,`updated_at_ts`]);return D({...c,...l,enabled:!!c.enabled,synchronous:!!c.synchronous,metadata:Ee(s)})}}function xn(e){return async(t,n)=>(await e.deleteFrom(`hooks`).where(`hooks.tenant_id`,`=`,t).where(`hooks.hook_id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function Sn(e){return async(t,n)=>{let r=Date.now(),i=n.hook_id||f(),{hook_id:a,enabled:o,synchronous:s,metadata:c,...l}=n;return await e.insertInto(`hooks`).values({...l,hook_id:i,tenant_id:t,enabled:+!!o,synchronous:+!!s,metadata:c?JSON.stringify(c):null,created_at_ts:r,updated_at_ts:r}).execute(),{...l,hook_id:i,enabled:o??!1,synchronous:s??!1,...c?{metadata:c}:{},created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function Cn(e){return async(t,n,r)=>{let{hook_id:i,metadata:a,...o}=r,s={...o,updated_at_ts:Date.now(),enabled:r.enabled===void 0?void 0:+!!r.enabled,synchronous:r.synchronous===void 0?void 0:+!!r.synchronous,...a===void 0?{}:{metadata:a===null?null:JSON.stringify(a)}};return await e.updateTable(`hooks`).set(s).where(`hooks.hook_id`,`=`,n).where(`hooks.tenant_id`,`=`,t).execute(),!0}}function wn(e){return{create:Sn(e),get:bn(e),list:yn(e),update:Cn(e),remove:xn(e)}}function Tn(e){return async(t,n)=>{let r=Date.now(),i=m();return await e.insertInto(`hook_code`).values({id:i,tenant_id:t,code:n.code,secrets:n.secrets?JSON.stringify(n.secrets):null,created_at_ts:r,updated_at_ts:r}).execute(),{id:i,tenant_id:t,code:n.code,secrets:n.secrets,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function En(e){return async(t,n)=>{let r=await e.selectFrom(`hook_code`).where(`hook_code.tenant_id`,`=`,t).where(`hook_code.id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{created_at_ts:i,updated_at_ts:a,secrets:o,...s}=r,c=x({created_at_ts:i,updated_at_ts:a},[`created_at_ts`,`updated_at_ts`]);return{...s,...c,secrets:o?(()=>{try{return JSON.parse(o)}catch{console.warn(`Failed to parse secrets for hook_code ${n}`);return}})():void 0}}}function Dn(e){return async(t,n,r)=>{let i={updated_at_ts:Date.now()};return r.code!==void 0&&(i.code=r.code),r.secrets!==void 0&&(i.secrets=JSON.stringify(r.secrets)),(await e.updateTable(`hook_code`).set(i).where(`hook_code.id`,`=`,n).where(`hook_code.tenant_id`,`=`,t).executeTakeFirst()).numUpdatedRows>0}}function On(e){return async(t,n)=>(await e.deleteFrom(`hook_code`).where(`hook_code.tenant_id`,`=`,t).where(`hook_code.id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function kn(e){return{create:Tn(e),get:En(e),update:Dn(e),remove:On(e)}}function An(e){return async(t,r,i)=>{let a={themeId:i||(0,n.nanoid)(),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...r},o={...a,tenant_id:t};return await e.insertInto(`themes`).values(k(o)).execute(),a}}function jn(e){return async(t,n)=>(await e.deleteFrom(`themes`).where(`themes.tenant_id`,`=`,t).where(`themes.themeId`,`=`,n).executeTakeFirst()).numDeletedRows>0}function Mn(e){return async(t,n)=>{let r=await e.selectFrom(`themes`).where(`themes.tenant_id`,`=`,t).where(`themes.themeId`,`=`,n).selectAll().executeTakeFirst();return r?D(xe({...r,borders_show_widget_shadow:!!r.borders_show_widget_shadow,fonts_body_text_bold:!!r.fonts_body_text_bold,fonts_buttons_text_bold:!!r.fonts_buttons_text_bold,fonts_input_labels_bold:!!r.fonts_input_labels_bold,fonts_links_bold:!!r.fonts_links_bold,fonts_subtitle_bold:!!r.fonts_subtitle_bold,fonts_title_bold:!!r.fonts_title_bold},[`widget`,`colors`,`borders`,`fonts`,`page_background`])):null}}function Nn(e){return async(t,n,r)=>{let{themeId:i,...a}=r,o=k({...a,updated_at:new Date().toISOString()});return await e.updateTable(`themes`).set(o).where(`themes.themeId`,`=`,n).where(`themes.tenant_id`,`=`,t).execute(),!0}}function Pn(e){return{create:An(e),get:Mn(e),remove:jn(e),update:Nn(e)}}function Fn(e){return async(t,n)=>{let i=await e.selectFrom(`login_sessions`).where(`login_sessions.id`,`=`,n).selectAll().executeTakeFirst();if(!i)return null;let{created_at_ts:a,updated_at_ts:o,expires_at_ts:s,auth_params:c,...l}=i,u=x({created_at_ts:a,updated_at_ts:o,expires_at_ts:s},[`created_at_ts`,`updated_at_ts`,`expires_at_ts`]),d=xe(D({...l,...u,state:i.state||r.LoginSessionState.PENDING,state_data:i.state_data,failure_reason:i.failure_reason}),[`auth_strategy`]);return d.authParams=typeof c==`string`&&c.length>0?JSON.parse(c):{},r.loginSessionSchema.parse(d)}}var In=`0123456789ABCDEFGHJKMNPQRSTVWXYZ`,Ln=32,Rn=10,zn=16;function Bn(e){let t=``;for(let n=Rn;n>0;n--)t=In.charAt(e%Ln)+t,e=Math.floor(e/Ln);return t}function Vn(){let e=new Uint8Array(zn);crypto.getRandomValues(e);let t=``;for(let n=0;n<zn;n++)t+=In.charAt(e[n]%Ln);return t}function Hn(){return Bn(Date.now())+Vn()}function Un(e){return async(t,n)=>{let i=b(),a={id:Hn(),...n,authorization_url:n.authorization_url?.slice(0,1024),created_at:i,updated_at:i,state:n.state||r.LoginSessionState.PENDING,state_data:n.state_data,failure_reason:n.failure_reason},{authParams:o,...s}=a,c=Date.now(),l=k(s);return delete l.created_at,delete l.updated_at,delete l.expires_at,await e.insertInto(`login_sessions`).values({...l,tenant_id:t,auth_params:JSON.stringify(o),created_at_ts:c,updated_at_ts:c,expires_at_ts:n.expires_at?new Date(n.expires_at).getTime():c+1e3*60*60*24}).execute(),a}}function Wn(e){return async(t,n,r)=>{let{created_at:i,updated_at:a,expires_at:o,authParams:s,...c}=r,l={};if(s!==void 0){let r=(await e.selectFrom(`login_sessions`).where(`login_sessions.id`,`=`,n).where(`login_sessions.tenant_id`,`=`,t).select([`auth_params`]).executeTakeFirst())?.auth_params,i=typeof r==`string`&&r.length>0?JSON.parse(r):{};l={auth_params:JSON.stringify({...i,...s})}}let u=k(c);return delete u.created_at_ts,delete u.updated_at_ts,delete u.expires_at_ts,delete u.id,delete u.tenant_id,(await e.updateTable(`login_sessions`).set({...u,...l,updated_at_ts:Date.now(),...o===void 0?{}:{expires_at_ts:y(o)}}).where(`login_sessions.id`,`=`,n).where(`login_sessions.tenant_id`,`=`,t).execute()).length===1}}function Gn(e){return async(t,n)=>(await e.deleteFrom(`login_sessions`).where(`login_sessions.tenant_id`,`=`,t).where(`login_sessions.id`,`=`,n).execute()).length>0}function Kn(e){return{create:Un(e),get:Fn(e),update:Wn(e),remove:Gn(e)}}function qn(e){return async t=>{let[n]=await e.selectFrom(`prompt_settings`).where(`prompt_settings.tenant_id`,`=`,t).selectAll().execute();return D({identifier_first:!!n?.identifier_first,password_first:!!n?.password_first,webauthn_platform_first_factor:!!n?.webauthn_platform_first_factor,universal_login_experience:n?.universal_login_experience||`new`})}}function Jn(e){let t={};return typeof e.identifier_first==`boolean`&&(t.identifier_first=+!!e.identifier_first),typeof e.password_first==`boolean`&&(t.password_first=+!!e.password_first),typeof e.webauthn_platform_first_factor==`boolean`&&(t.webauthn_platform_first_factor=+!!e.webauthn_platform_first_factor),e.universal_login_experience&&(t.universal_login_experience=e.universal_login_experience),t}function Yn(e){return async(t,n)=>{let r=Jn(n);try{await e.insertInto(`prompt_settings`).values({tenant_id:t,identifier_first:r.identifier_first??1,password_first:r.password_first??0,webauthn_platform_first_factor:r.webauthn_platform_first_factor??0,universal_login_experience:r.universal_login_experience??`new`}).execute()}catch{if(Object.keys(r).length===0)return;await e.updateTable(`prompt_settings`).set(r).where(`tenant_id`,`=`,t).execute()}}}function Xn(e){return{get:qn(e),set:Yn(e)}}function Zn(e){return async t=>{let[n]=await e.selectFrom(`email_providers`).where(`email_providers.tenant_id`,`=`,t).selectAll().execute();if(!n)return null;let{tenant_id:r,credentials:i,settings:a,enabled:o,...s}=n;return D({...s,credentials:JSON.parse(i),settings:JSON.parse(a),enabled:!!o})}}function Qn(e){return async(t,n)=>{let{credentials:r,settings:i,enabled:a,...o}=n;await e.updateTable(`email_providers`).set({...o,credentials:r?JSON.stringify(r):void 0,settings:i?JSON.stringify(i):void 0,enabled:a===void 0?void 0:+!!a}).where(`tenant_id`,`=`,t).execute()}}function $n(e){return async(t,n)=>{let{credentials:r,settings:i,enabled:a,...o}=n;await e.insertInto(`email_providers`).values({...o,enabled:+!!a,credentials:JSON.stringify(r),settings:JSON.stringify(i),tenant_id:t,created_at:new Date().toISOString(),updated_at:new Date().toISOString()}).execute()}}function er(e){return async t=>{await e.deleteFrom(`email_providers`).where(`tenant_id`,`=`,t).execute()}}function tr(e){return{get:Zn(e),create:$n(e),update:Qn(e),remove:er(e)}}function nr(e){let t={template:e.template,body:e.body,from:e.from,subject:e.subject,syntax:e.syntax,includeEmailInRedirect:!!e.include_email_in_redirect,enabled:!!e.enabled};return e.result_url!==null&&e.result_url!==void 0&&(t.resultUrl=e.result_url),e.url_lifetime_in_seconds!==null&&e.url_lifetime_in_seconds!==void 0&&(t.urlLifetimeInSeconds=e.url_lifetime_in_seconds),t}function rr(e){return async(t,n)=>{let i=await e.selectFrom(`email_templates`).where(`tenant_id`,`=`,t).where(`template`,`=`,n).selectAll().executeTakeFirst();return i?r.emailTemplateSchema.parse(nr(i)):null}}function ir(e){return async t=>(await e.selectFrom(`email_templates`).where(`tenant_id`,`=`,t).orderBy(`template`,`asc`).selectAll().execute()).map(e=>r.emailTemplateSchema.parse(nr(e)))}function ar(e){return async(t,n)=>{let r=new Date().toISOString();return await e.insertInto(`email_templates`).values({tenant_id:t,template:n.template,body:n.body,from:n.from,subject:n.subject,syntax:n.syntax,result_url:n.resultUrl??null,url_lifetime_in_seconds:n.urlLifetimeInSeconds??null,include_email_in_redirect:+!!n.includeEmailInRedirect,enabled:+!!n.enabled,created_at:r,updated_at:r}).execute(),n}}function or(e){return async(t,n,r)=>{let i={};if(r.body!==void 0&&(i.body=r.body),r.from!==void 0&&(i.from=r.from),r.subject!==void 0&&(i.subject=r.subject),r.syntax!==void 0&&(i.syntax=r.syntax),r.resultUrl!==void 0&&(i.result_url=r.resultUrl),r.urlLifetimeInSeconds!==void 0&&(i.url_lifetime_in_seconds=r.urlLifetimeInSeconds),r.includeEmailInRedirect!==void 0&&(i.include_email_in_redirect=+!!r.includeEmailInRedirect),r.enabled!==void 0&&(i.enabled=+!!r.enabled),Object.keys(i).length===0)return await e.selectFrom(`email_templates`).where(`tenant_id`,`=`,t).where(`template`,`=`,n).select(`template`).executeTakeFirst()!==void 0;i.updated_at=new Date().toISOString();let a=await e.updateTable(`email_templates`).set(i).where(`tenant_id`,`=`,t).where(`template`,`=`,n).executeTakeFirst();return Number(a.numUpdatedRows??0)>0}}function sr(e){return async(t,n)=>{let r=await e.deleteFrom(`email_templates`).where(`tenant_id`,`=`,t).where(`template`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows??0)>0}}function cr(e){return{get:rr(e),list:ir(e),create:ar(e),update:or(e),remove:sr(e)}}function lr(e){return async(t,n)=>{let r=await e.selectFrom(`refresh_tokens`).where(`refresh_tokens.tenant_id`,`=`,t).where(`refresh_tokens.id`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,created_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,last_exchanged_at_ts:c,revoked_at_ts:l,rotated_at_ts:u,...d}=r,f=x({created_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,last_exchanged_at_ts:c,revoked_at_ts:l,rotated_at_ts:u},[`created_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`last_exchanged_at_ts`,`revoked_at_ts`,`rotated_at_ts`]);return{...d,...f,rotating:!!r.rotating,device:r.device?JSON.parse(r.device):{},resource_servers:r.resource_servers?JSON.parse(r.resource_servers):[]}}}function ur(e){return async(t,n)=>{let r=await e.selectFrom(`refresh_tokens`).where(`refresh_tokens.tenant_id`,`=`,t).where(`refresh_tokens.token_lookup`,`=`,n).selectAll().executeTakeFirst();if(!r)return null;let{tenant_id:i,created_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,last_exchanged_at_ts:c,revoked_at_ts:l,rotated_at_ts:u,...d}=r,f=x({created_at_ts:a,expires_at_ts:o,idle_expires_at_ts:s,last_exchanged_at_ts:c,revoked_at_ts:l,rotated_at_ts:u},[`created_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`last_exchanged_at_ts`,`revoked_at_ts`,`rotated_at_ts`]);return{...d,...f,rotating:!!r.rotating,device:r.device?JSON.parse(r.device):{},resource_servers:r.resource_servers?JSON.parse(r.resource_servers):[]}}}function dr(e){return async(t,n)=>{let r=b(),i={...n,created_at:r},{expires_at:a,idle_expires_at:o,last_exchanged_at:s,rotated_at:c,device:l,resource_servers:u,rotating:d,...f}=n,p=Date.now(),m=y(a),h=o?y(o):null,g=Math.max(m??0,h??0);return await e.transaction().execute(async e=>{await e.insertInto(`refresh_tokens`).values({...f,tenant_id:t,rotating:+!!d,device:JSON.stringify(l),resource_servers:JSON.stringify(u),created_at_ts:p,expires_at_ts:m,idle_expires_at_ts:h,last_exchanged_at_ts:s?y(s):null,rotated_at_ts:c?y(c):null}).execute(),g>0&&n.login_id&&await e.updateTable(`login_sessions`).set({expires_at_ts:g,updated_at_ts:p}).where(`tenant_id`,`=`,t).where(`id`,`=`,n.login_id).where(`expires_at_ts`,`<`,g).execute()}),{...n,...i}}}function fr(e){return async(t,n)=>!!(await e.deleteFrom(`refresh_tokens`).where(`tenant_id`,`=`,t).where(`refresh_tokens.id`,`=`,n).execute()).length}function pr(e){return async(t,n,r)=>{let i=y(r),a=await e.updateTable(`refresh_tokens`).set({revoked_at_ts:i}).where(`tenant_id`,`=`,t).where(`login_id`,`=`,n).where(`revoked_at_ts`,`is`,null).executeTakeFirst();return Number(a.numUpdatedRows??0)}}function mr(e){return async(t,n,r)=>{let i=y(r),a=await e.updateTable(`refresh_tokens`).set({revoked_at_ts:i}).where(`tenant_id`,`=`,t).where(`family_id`,`=`,n).where(`revoked_at_ts`,`is`,null).executeTakeFirst();return Number(a.numUpdatedRows??0)}}function hr(e){return async(t,n,r,i)=>{let{created_at:a,expires_at:o,idle_expires_at:s,last_exchanged_at:c,revoked_at:l,rotated_at:u,device:d,resource_servers:f,rotating:p,...m}=r,h={...m,device:d?JSON.stringify(d):void 0,resource_servers:f?JSON.stringify(f):void 0,rotating:p===void 0?void 0:+!!p,expires_at_ts:o===void 0?void 0:y(o),idle_expires_at_ts:s===void 0?void 0:y(s),last_exchanged_at_ts:c===void 0?void 0:y(c),revoked_at_ts:l===void 0?void 0:y(l),rotated_at_ts:u===void 0?void 0:y(u)},g=i?.loginSessionBump,_=g?y(g.expires_at):null,v=await e.updateTable(`refresh_tokens`).set(h).where(`tenant_id`,`=`,t).where(`refresh_tokens.id`,`=`,n).executeTakeFirst();return g?.login_id&&_&&_>0&&await e.updateTable(`login_sessions`).set({expires_at_ts:_,updated_at_ts:Date.now()}).where(`tenant_id`,`=`,t).where(`id`,`=`,g.login_id).where(`expires_at_ts`,`<`,_).execute().catch(()=>{}),(v?.numUpdatedRows??0n)>0n}}function gr(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`refresh_tokens`).where(`refresh_tokens.tenant_id`,`=`,t);s&&(c=C(e,c,s,[`token`,`login_id`]));let l=c;if(o&&o.sort_by){let{ref:t}=e.dynamic;l=l.orderBy(t(o.sort_by),o.sort_order)}l=l.offset(r*i).limit(i);let u=(await l.selectAll().execute()).map(e=>{let{tenant_id:t,created_at_ts:n,expires_at_ts:r,idle_expires_at_ts:i,last_exchanged_at_ts:a,revoked_at_ts:o,rotated_at_ts:s,...c}=e,l=x({created_at_ts:n,expires_at_ts:r,idle_expires_at_ts:i,last_exchanged_at_ts:a,revoked_at_ts:o,rotated_at_ts:s},[`created_at_ts`],[`expires_at_ts`,`idle_expires_at_ts`,`last_exchanged_at_ts`,`revoked_at_ts`,`rotated_at_ts`]);return{...c,...l,rotating:!!e.rotating,device:e.device?JSON.parse(e.device):{},resource_servers:e.resource_servers?JSON.parse(e.resource_servers):[]}});if(!a)return{refresh_tokens:u,start:0,limit:0,length:0};let{count:d}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow(),f=w(d);return{refresh_tokens:u,start:r*i,limit:i,length:f}}}function _r(e){return{create:dr(e),get:lr(e),getByLookup:ur(e),list:gr(e),remove:fr(e),revokeByLoginSession:pr(e),revokeFamily:mr(e),update:hr(e)}}var vr=10080*60*1e3;function yr(e){return async t=>{let{tenant_id:n,user_id:r}=t||{},i=Date.now()-vr,a=1e3;try{let t=0;for(;;){let o=e.deleteFrom(`refresh_tokens`).where(e=>e.or([e(`expires_at_ts`,`<`,i),e(`idle_expires_at_ts`,`<`,i)]));n&&(o=o.where(`tenant_id`,`=`,n)),r&&(o=o.where(`user_id`,`=`,r));let s=await o.limit(a).execute(),c=Number(s[0]?.numDeletedRows??0);if(t+=c,c<a)break}let o=0;for(;;){let t=e.deleteFrom(`sessions`).where(e=>e.or([e(`expires_at_ts`,`<`,i),e(`idle_expires_at_ts`,`<`,i)]));n&&(t=t.where(`tenant_id`,`=`,n)),r&&(t=t.where(`user_id`,`=`,r));let s=await t.limit(a).execute(),c=Number(s[0]?.numDeletedRows??0);if(o+=c,c<a)break}let s=0;for(;;){let t=e.deleteFrom(`login_sessions`).where(`expires_at_ts`,`<`,i);n&&(t=t.where(`tenant_id`,`=`,n)),r&&(t=t.where(`user_id`,`=`,r));let o=await t.limit(a).execute(),c=Number(o[0]?.numDeletedRows??0);if(s+=c,c<a)break}(t>0||o>0||s>0)&&console.log(`Session cleanup: deleted ${t} refresh_tokens, ${o} sessions, ${s} login_sessions`)}catch(e){console.error(`Error during session cleanup:`,e)}}}function br(e){return async(t,i)=>{let a=r.formSchema.parse({id:(0,n.nanoid)(),...i,created_at:new Date().toISOString(),updated_at:new Date().toISOString()});return await e.insertInto(`forms`).values({...a,nodes:JSON.stringify(a.nodes||[]),start:JSON.stringify(a.start||{}),ending:JSON.stringify(a.ending||{}),tenant_id:t}).execute(),r.formSchema.parse(a)}}function xr(e){return async(t,n={})=>{let{page:i=0,per_page:a=50,include_totals:o=!1,q:s}=n,c=e.selectFrom(`forms`).where(`tenant_id`,`=`,t);s&&(c=C(e,c,s,[]));let l=(await c.offset(i*a).limit(a).selectAll().execute()).map(e=>{let t={...e};if(typeof t.nodes==`string`)try{t.nodes=JSON.parse(t.nodes)}catch{}if(typeof t.start==`string`)try{t.start=JSON.parse(t.start)}catch{}if(typeof t.ending==`string`)try{t.ending=JSON.parse(t.ending)}catch{}return r.formSchema.parse(D(t))});if(!o)return{forms:l,start:0,limit:0,length:0};let{count:u}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{forms:l,start:i*a,limit:a,length:w(u)}}}function Sr(e){return async(t,n)=>{let{numDeletedRows:r}=await e.deleteFrom(`forms`).where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();return r>0}}function Cr(e){return async(t,n)=>{let i=await e.selectFrom(`forms`).selectAll().where(`forms.id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();if(!i)return null;let a={...i};if(typeof a.nodes==`string`)try{a.nodes=JSON.parse(a.nodes)}catch{}if(typeof a.start==`string`)try{a.start=JSON.parse(a.start)}catch{}if(typeof a.ending==`string`)try{a.ending=JSON.parse(a.ending)}catch{}return r.formSchema.parse(D(a))}}function wr(e){return async(t,n,r)=>{let i={...r,updated_at:new Date().toISOString()};j(r,[`nodes`,`start`,`ending`],i);let{numUpdatedRows:a}=await e.updateTable(`forms`).set(i).where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();return a>0}}function Tr(e){return{create:br(e),get:Cr(e),list:xr(e),remove:Sr(e),update:wr(e)}}function Er(e){return async(t,n)=>{let i=new Date().toISOString(),a={id:p(),...n,created_at:i,updated_at:i},o=r.resourceServerSchema.parse(a),{verificationKey:s,scopes:c,options:l,skip_consent_for_verifiable_first_party_clients:u,allow_offline_access:d,is_system:f,metadata:m,...h}=o,g={...h,tenant_id:t,scopes:c?JSON.stringify(c):`[]`,options:l?JSON.stringify(l):`{}`,skip_consent_for_verifiable_first_party_clients:+!!u,allow_offline_access:+!!d,is_system:+!!f,metadata:m?JSON.stringify(m):void 0,verification_key:s,created_at:i,updated_at:i};return await e.insertInto(`resource_servers`).values(g).execute(),D(o)}}function Dr(e){return async(t,n)=>{let r=await e.selectFrom(`resource_servers`).selectAll().where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();if(!r)return null;let{verification_key:i,scopes:a,options:o,skip_consent_for_verifiable_first_party_clients:s,allow_offline_access:c,is_system:l,metadata:u,...d}=r,f=D({...d,scopes:a?JSON.parse(a):[],options:o?JSON.parse(o):{},skip_consent_for_verifiable_first_party_clients:!!s,allow_offline_access:!!c,is_system:l?!0:void 0,metadata:u?JSON.parse(u):void 0,verificationKey:i});return f.token_lifetime??=86400,f.token_lifetime_for_web??=7200,f}}function Or(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,q:o}=n,s=e.selectFrom(`resource_servers`).where(`resource_servers.tenant_id`,`=`,t);if(o){let t=o.trim(),n=t.split(/\s+/),r=n.length===1?n[0]:void 0,i=r?r.match(/^(-)?(name|identifier):(.*)$/):null,a=i?i[3]:``,c=/^(>=|>|<=|<)/.test(a||``);if(i&&!c){let e=!!i[1],t=i[2]===`name`?`resource_servers.name`:`resource_servers.identifier`;s=e?s.where(t,`not like`,`%${a}%`):s.where(t,`like`,`%${a}%`)}else s=C(e,s,t,[`resource_servers.name`,`resource_servers.identifier`])}let c=(await s.offset(r*i).limit(i).selectAll().execute()).map(e=>{let{verification_key:t,scopes:n,options:r,skip_consent_for_verifiable_first_party_clients:i,allow_offline_access:a,is_system:o,metadata:s,...c}=e,l=D({...c,scopes:n?JSON.parse(n):[],options:r?JSON.parse(r):{},skip_consent_for_verifiable_first_party_clients:!!i,allow_offline_access:!!a,is_system:o?!0:void 0,metadata:s?JSON.parse(s):void 0,verificationKey:t});return l.token_lifetime??=86400,l.token_lifetime_for_web??=7200,l});if(!a)return{resource_servers:c,start:0,limit:0,length:0};let{count:l}=await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{resource_servers:c,start:r*i,limit:i,length:w(l)}}}function kr(e){return async(t,n)=>{let r=await e.deleteFrom(`resource_servers`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows)>0}}function Ar(e){return async(t,n,r)=>{let{verificationKey:i,scopes:a,options:o,skip_consent_for_verifiable_first_party_clients:s,allow_offline_access:c,is_system:l,metadata:u,...d}=r,f={...d,updated_at:new Date().toISOString()};if(i!==void 0&&(f.verification_key=i),a!==void 0&&(f.scopes=JSON.stringify(a)),o!==void 0){let r=await e.selectFrom(`resource_servers`).select(`options`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst(),i={...r?.options?JSON.parse(r.options):{},...o};f.options=JSON.stringify(i)}u!==void 0&&(f.metadata=JSON.stringify(u)),s!==void 0&&(f.skip_consent_for_verifiable_first_party_clients=+!!s),c!==void 0&&(f.allow_offline_access=+!!c),l!==void 0&&(f.is_system=+!!l);let p=await e.updateTable(`resource_servers`).set(f).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return Number(p.numUpdatedRows)>0}}function jr(e){return{create:Er(e),get:Dr(e),list:Or(e),remove:kr(e),update:Ar(e)}}function Mr(e){return async(t,r)=>{let i=new Date().toISOString(),a=r.id||(0,n.nanoid)(),{is_system:o,id:s,metadata:c,...l}=r,u={id:a,...l,tenant_id:t,is_system:+!!o,metadata:c?JSON.stringify(c):void 0,created_at:i,updated_at:i};return await e.insertInto(`roles`).values(u).execute(),{id:a,...l,is_system:o?!0:void 0,metadata:c,created_at:i,updated_at:i}}}function Nr(e){return async(t,n)=>{let r=await e.selectFrom(`roles`).selectAll().where(`roles.tenant_id`,`=`,t).where(`roles.id`,`=`,n).executeTakeFirst();if(!r)return null;let{is_system:i,tenant_id:a,metadata:o,...s}=r;return{...s,is_system:i?!0:void 0,metadata:o?JSON.parse(o):void 0}}}function Pr(e){return async(t,n)=>{let r=e.selectFrom(`roles`).where(`roles.tenant_id`,`=`,t),{page:i=0,per_page:a=50,include_totals:o=!1}=n;n.q&&(r=C(e,r,n.q,[`name`]));let s=(await r.offset(i*a).limit(a).selectAll().execute()).map(e=>{let{is_system:t,tenant_id:n,metadata:r,...i}=e;return{...i,is_system:t?!0:void 0,metadata:r?JSON.parse(r):void 0}});if(!o)return{roles:s,start:i*a,limit:a,length:s.length};let{count:c}=await r.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{roles:s,start:i*a,limit:a,length:w(c)}}}function Fr(e){return async(t,n,r)=>{let{is_system:i,metadata:a,...o}=r,s={...o,is_system:i===void 0?void 0:+!!i,metadata:a===void 0?void 0:JSON.stringify(a),updated_at:new Date().toISOString()},c=await e.updateTable(`roles`).set(s).where(`roles.tenant_id`,`=`,t).where(`roles.id`,`=`,n).executeTakeFirst();return Number(c.numUpdatedRows)>0}}function Ir(e){return async(t,n)=>{let r=await e.deleteFrom(`roles`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows)>0}}function Lr(e){return{create:Mr(e),get:Nr(e),list:Pr(e),update:Fr(e),remove:Ir(e)}}function Rr(e){return async(t,n,r)=>{if(r.length===0)return!0;let i=new Date().toISOString();try{for(let a of r){if(a.role_id!==n)throw Error(`Permission role_id ${a.role_id} does not match expected role_id ${n}`);let r={tenant_id:t,role_id:a.role_id,resource_server_identifier:a.resource_server_identifier,permission_name:a.permission_name,created_at:i};try{await e.insertInto(`role_permissions`).values(r).execute()}catch(e){if(e.code===`SQLITE_CONSTRAINT_PRIMARYKEY`||e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`)continue;throw e}}return!0}catch(e){return console.error(`Error assigning role permissions:`,e),!1}}}function zr(e){return async(t,n,r)=>{if(r.length===0)return!0;try{return(await Promise.all(r.map(r=>e.deleteFrom(`role_permissions`).where(`tenant_id`,`=`,t).where(`role_id`,`=`,n).where(`resource_server_identifier`,`=`,r.resource_server_identifier).where(`permission_name`,`=`,r.permission_name).executeTakeFirst()))).some(e=>Number(e.numDeletedRows)>0)}catch(e){return console.error(`Error removing role permissions:`,e),!1}}}function Br(e){return async(t,n,r={})=>{let{page:i=0,per_page:a=50,include_totals:o=!1}=r,s=e.selectFrom(`role_permissions`).leftJoin(`resource_servers`,e=>e.onRef(`role_permissions.tenant_id`,`=`,`resource_servers.tenant_id`).onRef(`role_permissions.resource_server_identifier`,`=`,`resource_servers.id`)).select([`role_permissions.role_id`,`role_permissions.resource_server_identifier`,`role_permissions.permission_name`,`role_permissions.created_at`,`resource_servers.name as resource_server_name`]).where(`role_permissions.tenant_id`,`=`,t).where(`role_permissions.role_id`,`=`,n),c=(await s.offset(i*a).limit(a).execute()).map(e=>({role_id:e.role_id,resource_server_identifier:e.resource_server_identifier,resource_server_name:e.resource_server_name||e.resource_server_identifier,permission_name:e.permission_name,description:null,created_at:e.created_at}));return o&&await s.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow(),c}}function Vr(e){return{assign:Rr(e),remove:zr(e),list:Br(e)}}function Hr(e){return async(t,r)=>{let i=new Date().toISOString(),a=r.scope??[],o=r.audience??``,s=await e.selectFrom(`grants`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,r.user_id).where(`client_id`,`=`,r.clientID).where(`audience`,`=`,o).selectAll().executeTakeFirst();if(s){let n=s.scope?JSON.parse(s.scope):[],r=Array.from(new Set([...n,...a]));return await e.updateTable(`grants`).set({scope:JSON.stringify(r),updated_at:i}).where(`tenant_id`,`=`,t).where(`id`,`=`,s.id).execute(),{id:s.id,user_id:s.user_id,clientID:s.client_id,audience:s.audience||void 0,scope:r}}let c=(0,n.nanoid)();return await e.insertInto(`grants`).values({id:c,tenant_id:t,user_id:r.user_id,client_id:r.clientID,audience:o,scope:JSON.stringify(a),created_at:i,updated_at:i}).execute(),{id:c,user_id:r.user_id,clientID:r.clientID,audience:o||void 0,scope:a}}}function Ur(e){return async(t,n,r,i)=>{let a=await e.selectFrom(`grants`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n).where(`client_id`,`=`,r).where(`audience`,`=`,i??``).selectAll().executeTakeFirst();return a?{id:a.id,user_id:a.user_id,clientID:a.client_id,audience:a.audience||void 0,scope:a.scope?JSON.parse(a.scope):[]}:null}}function Wr(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1,sort:o,q:s}=n,c=e.selectFrom(`grants`).where(`grants.tenant_id`,`=`,t);s&&(c=C(e,c,s,[`user_id`,`client_id`,`audience`]));let l=c;if(o&&o.sort_by){let{ref:t}=e.dynamic;l=l.orderBy(t(o.sort_by),o.sort_order)}l=l.offset(r*i).limit(i);let u=(await l.selectAll().execute()).map(e=>({id:e.id,user_id:e.user_id,clientID:e.client_id,audience:e.audience||void 0,scope:e.scope?JSON.parse(e.scope):[]}));if(!a)return{grants:u,start:0,limit:0,length:0};let{count:d}=await c.select(e=>e.fn.countAll().as(`count`)).executeTakeFirstOrThrow();return{grants:u,start:r*i,limit:i,length:w(d)}}}function Gr(e){return async(t,n)=>(await e.deleteFrom(`grants`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function Kr(e){return async(t,n)=>(await e.deleteFrom(`grants`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function qr(e){return{create:Hr(e),get:Ur(e),list:Wr(e),remove:Gr(e),removeByUser:Kr(e)}}function Jr(e){return async(t,n,r,i)=>{let a=new Date().toISOString();try{let o={tenant_id:t,user_id:n,resource_server_identifier:r.resource_server_identifier,permission_name:r.permission_name,organization_id:i||r.organization_id||``,created_at:a};return await e.insertInto(`user_permissions`).values(o).execute(),!0}catch(e){return e.code===`SQLITE_CONSTRAINT_PRIMARYKEY`||e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`SQLITE_CONSTRAINT`||e.code===`ER_DUP_ENTRY`||e.message&&e.message.includes(`UNIQUE constraint failed`)||e.message&&e.message.includes(`PRIMARY KEY constraint failed`)?!0:(console.error(`Error creating user permission:`,e),!1)}}}function Yr(e){return async(t,n,r,i)=>{try{let a=e.deleteFrom(`user_permissions`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n).where(`resource_server_identifier`,`=`,r.resource_server_identifier).where(`permission_name`,`=`,r.permission_name);return a=i===void 0?a.where(`organization_id`,`=`,``):a.where(`organization_id`,`=`,i),await a.execute(),!0}catch(e){return console.error(`Error removing user permission:`,e),!1}}}function Xr(e){return async(t,n,r,i)=>{let a=e.selectFrom(`user_permissions`).leftJoin(`resource_servers`,e=>e.onRef(`user_permissions.tenant_id`,`=`,`resource_servers.tenant_id`).onRef(`user_permissions.resource_server_identifier`,`=`,`resource_servers.id`)).select([`user_permissions.resource_server_identifier`,`user_permissions.permission_name`,`resource_servers.name as resource_server_name`,`user_permissions.user_id`,`user_permissions.created_at`,`user_permissions.organization_id`]).where(`user_permissions.tenant_id`,`=`,t).where(`user_permissions.user_id`,`=`,n);return i!==void 0&&(a=a.where(`user_permissions.organization_id`,`=`,i)),(await a.execute()).map(e=>({resource_server_identifier:e.resource_server_identifier,permission_name:e.permission_name,description:null,resource_server_name:e.resource_server_name||e.resource_server_identifier,user_id:e.user_id,created_at:e.created_at,organization_id:e.organization_id===``?void 0:e.organization_id}))}}function Zr(e){return{create:Jr(e),remove:Yr(e),list:Xr(e)}}function Qr(e){let t=Zr(e);return{create:(e,n,r,i)=>t.create(e,n,r,i),remove:(e,n,r,i)=>t.remove(e,n,r,i),list:(e,n,r,i)=>t.list(e,n,r,i)}}function $r(e){return async(t,n,r,i)=>{let a=e.selectFrom(`user_roles as ur`).innerJoin(`roles as r`,e=>e.onRef(`ur.role_id`,`=`,`r.id`).onRef(`ur.tenant_id`,`=`,`r.tenant_id`)).select([`r.id`,`r.name`,`r.description`,`r.created_at`,`r.updated_at`]).where(`ur.tenant_id`,`=`,t).where(`ur.user_id`,`=`,n);return i!==void 0&&(a=a.where(`ur.organization_id`,`=`,i)),await a.execute()}}function ei(e){return async(t,n,r,i)=>{let a=new Date().toISOString();try{return await e.insertInto(`user_roles`).values({tenant_id:t,user_id:n,role_id:r,organization_id:i||``,created_at:a}).execute(),!0}catch(e){return e.code===`SQLITE_CONSTRAINT_PRIMARYKEY`||e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`SQLITE_CONSTRAINT`||e.code===`ER_DUP_ENTRY`||e.message&&e.message.includes(`UNIQUE constraint failed`)||e.message&&e.message.includes(`PRIMARY KEY constraint failed`)?!0:(console.error(`Error creating user role:`,e),!1)}}}function ti(e){return async(t,n,r,i)=>{try{let a=e.deleteFrom(`user_roles`).where(`tenant_id`,`=`,t).where(`user_id`,`=`,n).where(`role_id`,`=`,r);return a=i===void 0?a.where(`organization_id`,`=`,``):a.where(`organization_id`,`=`,i),await a.execute(),!0}catch(e){return console.error(`Error removing user roles:`,e),!1}}}function ni(e){return{list:$r(e),create:ei(e),remove:ti(e)}}function ri(e){let t=ni(e);return{list:(e,n,r,i)=>t.list(e,n,r,i),create:(e,n,r,i)=>t.create(e,n,r,i),remove:(e,n,r,i)=>t.remove(e,n,r,i)}}function ii(e){return async(t,n)=>{let r={...n,id:n.id||c(),tenant_id:t,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),branding:JSON.stringify(n.branding||{}),metadata:JSON.stringify(n.metadata||{}),enabled_connections:JSON.stringify(n.enabled_connections||[]),token_quota:JSON.stringify(n.token_quota||{})};try{await e.insertInto(`organizations`).values(r).execute()}catch(e){throw e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`||e.message.includes(`AlreadyExists`)?new E(409,{message:`Organization already exists`}):e}return{...n,id:r.id,created_at:r.created_at,updated_at:r.updated_at}}}function ai(e){return async(t,n)=>{let r=await e.selectFrom(`organizations`).selectAll().where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return r||=await e.selectFrom(`organizations`).selectAll().where(`tenant_id`,`=`,t).where(`name`,`=`,n).executeTakeFirst(),r?D({...r,branding:r.branding?JSON.parse(r.branding):{},metadata:r.metadata?JSON.parse(r.metadata):{},enabled_connections:r.enabled_connections?JSON.parse(r.enabled_connections):[],token_quota:r.token_quota?JSON.parse(r.token_quota):{}}):null}}var M=[`name`,`display_name`];function oi(e){return async(t,n)=>{let r=e.selectFrom(`organizations`).where(`tenant_id`,`=`,t);if(n?.q){let t=te(n.q,M);t&&(r=C(e,r,t,M))}if(n?.sort){let e=n.sort.sort_order===`asc`?`asc`:`desc`,t=n.sort.sort_by;r=[`name`,`display_name`,`created_at`].includes(t)?r.orderBy(t,e):r.orderBy(`created_at`,`desc`)}else r=r.orderBy(`created_at`,`desc`);let a=n?.take??n?.per_page,o=typeof a==`number`&&Number.isFinite(a)?Math.floor(a):NaN,s=o>=1?o:10,c=0;if(n?.from!==void 0){let e=parseInt(n.from,10);Number.isNaN(e)||(c=Math.max(0,e))}else typeof n?.page==`number`&&Number.isFinite(n.page)&&(c=Math.max(0,Math.floor(n.page)*s));c>0&&(r=r.offset(c)),r=r.limit(s);let l=await r.selectAll().execute(),u=l.length;if(n?.include_totals){let r=e.selectFrom(`organizations`).where(`tenant_id`,`=`,t);if(n?.q){let t=te(n.q,M);t&&(r=C(e,r,t,M))}let a=await r.select(i.sql`count(*)`.as(`count`)).executeTakeFirst();u=Number(a?.count||0)}let d=l.map(e=>D({...e,branding:e.branding?JSON.parse(e.branding):{},metadata:e.metadata?JSON.parse(e.metadata):{},enabled_connections:e.enabled_connections?JSON.parse(e.enabled_connections):[],token_quota:e.token_quota?JSON.parse(e.token_quota):{}}));return{organizations:d,start:c,limit:s,length:d.length,total:u}}}function si(e){return async(t,n)=>(await e.deleteFrom(`organizations`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).execute()).length>0}function ci(e){return async(t,n,r)=>{let{branding:i,metadata:a,enabled_connections:o,token_quota:s,...c}=r,l={...c,updated_at:new Date().toISOString()};return j(r,[`branding`,`metadata`,`enabled_connections`,`token_quota`],l),(await e.updateTable(`organizations`).set(l).where(`tenant_id`,`=`,t).where(`id`,`=`,n).execute()).length>0}}function li(e){return{create:ii(e),get:ai(e),list:oi(e),remove:si(e),update:ci(e)}}function N(e,t){return{connection_id:e.connection_id,assign_membership_on_login:!!e.assign_membership_on_login,show_as_button:!!e.show_as_button,is_signup_enabled:!!e.is_signup_enabled,connection:t?{name:t.name,strategy:t.strategy}:void 0,created_at:e.created_at,updated_at:e.updated_at}}async function P(e,t,n){let r=await e.selectFrom(`connections`).select([`name`,`strategy`]).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();if(r)return{name:r.name,strategy:typeof r.strategy==`string`?r.strategy:void 0}}function ui(e){return{async create(t,n,r){let i=new Date().toISOString(),a={tenant_id:t,organization_id:n,connection_id:r.connection_id,assign_membership_on_login:+!!r.assign_membership_on_login,show_as_button:r.show_as_button===!1?0:1,is_signup_enabled:r.is_signup_enabled===!1?0:1,created_at:i,updated_at:i};return await e.insertInto(`organization_connections`).values(a).execute(),N(a,await P(e,t,r.connection_id))},async list(t,n){let r=await e.selectFrom(`organization_connections`).selectAll().where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).execute(),i=[];for(let n of r){let r=await P(e,t,n.connection_id);i.push(N(n,r))}return i},async get(t,n,r){let i=await e.selectFrom(`organization_connections`).selectAll().where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).where(`connection_id`,`=`,r).executeTakeFirst();return i?N(i,await P(e,t,r)):null},async update(t,n,r,i){let a={updated_at:new Date().toISOString()};i.assign_membership_on_login!==void 0&&(a.assign_membership_on_login=+!!i.assign_membership_on_login),i.show_as_button!==void 0&&(a.show_as_button=+!!i.show_as_button),i.is_signup_enabled!==void 0&&(a.is_signup_enabled=+!!i.is_signup_enabled);let o=await e.updateTable(`organization_connections`).set(a).where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).where(`connection_id`,`=`,r).executeTakeFirst();if(Number(o.numUpdatedRows??0)===0)return null;let s=await e.selectFrom(`organization_connections`).selectAll().where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).where(`connection_id`,`=`,r).executeTakeFirst();return s?N(s,await P(e,t,r)):null},async remove(t,n,r){let i=await e.deleteFrom(`organization_connections`).where(`tenant_id`,`=`,t).where(`organization_id`,`=`,n).where(`connection_id`,`=`,r).executeTakeFirst();return Number(i.numDeletedRows??0)>0}}}function di(e){return async(t,r)=>{let i={id:(0,n.nanoid)(),tenant_id:t,user_id:r.user_id,organization_id:r.organization_id,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};try{await e.insertInto(`user_organizations`).values(i).execute()}catch(e){throw e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`?new E(409,{message:`User is already a member of this organization`}):e}return{...i}}}function fi(e){return async(t,n)=>{let r=await e.selectFrom(`user_organizations`).selectAll().where(`id`,`=`,n).where(`tenant_id`,`=`,t).executeTakeFirst();return r?{id:r.id,user_id:r.user_id,organization_id:r.organization_id,created_at:r.created_at,updated_at:r.updated_at}:null}}function pi(e){return async(t,n)=>{let r=n?.page||0,i=n?.per_page||50,a=r*i,o=e.selectFrom(`user_organizations`).selectAll().where(`tenant_id`,`=`,t);if(n?.q){if(n.q.startsWith(`user_id:`)){let e=n.q.replace(`user_id:`,``);o=o.where(`user_id`,`=`,e)}else if(n.q.startsWith(`organization_id:`)){let e=n.q.replace(`organization_id:`,``);o=o.where(`organization_id`,`=`,e)}}o=o.orderBy(`created_at`,`desc`),i>0&&(o=o.limit(i).offset(a));let s=await o.execute(),c=e.selectFrom(`user_organizations`).select(e.fn.count(`id`).as(`count`)).where(`tenant_id`,`=`,t);if(n?.q){if(n.q.startsWith(`user_id:`)){let e=n.q.replace(`user_id:`,``);c=c.where(`user_id`,`=`,e)}else if(n.q.startsWith(`organization_id:`)){let e=n.q.replace(`organization_id:`,``);c=c.where(`organization_id`,`=`,e)}}let l=await c.executeTakeFirst();return{userOrganizations:s.map(e=>({id:e.id,user_id:e.user_id,organization_id:e.organization_id,created_at:e.created_at,updated_at:e.updated_at})),start:a,limit:i,length:Number(l?.count||0)}}}function mi(e){return async(t,n,r)=>{let i=r?.page||0,a=r?.per_page||50,o=i*a,s=e.selectFrom(`user_organizations`).innerJoin(`organizations`,e=>e.onRef(`organizations.id`,`=`,`user_organizations.organization_id`).on(`organizations.tenant_id`,`=`,t)).select([`organizations.id`,`organizations.name`,`organizations.display_name`,`organizations.branding`,`organizations.metadata`,`organizations.enabled_connections`,`organizations.token_quota`,`organizations.created_at`,`organizations.updated_at`,`user_organizations.created_at as joined_at`]).where(`user_organizations.tenant_id`,`=`,t).where(`user_organizations.user_id`,`=`,n);s=s.orderBy(`user_organizations.created_at`,`desc`),a>0&&(s=s.limit(a).offset(o));let c=await s.execute(),l=await e.selectFrom(`user_organizations`).innerJoin(`organizations`,e=>e.onRef(`organizations.id`,`=`,`user_organizations.organization_id`).on(`organizations.tenant_id`,`=`,t)).select(e.fn.count(`user_organizations.id`).as(`count`)).where(`user_organizations.tenant_id`,`=`,t).where(`user_organizations.user_id`,`=`,n).executeTakeFirst();return{organizations:c.map(e=>({id:e.id,name:e.name,display_name:e.display_name,branding:e.branding?JSON.parse(e.branding):void 0,metadata:e.metadata?JSON.parse(e.metadata):{},enabled_connections:e.enabled_connections?JSON.parse(e.enabled_connections):[],token_quota:e.token_quota?JSON.parse(e.token_quota):void 0,created_at:e.created_at,updated_at:e.updated_at,joined_at:e.joined_at})),start:o,limit:a,length:Number(l?.count||0)}}}function hi(e){return async(t,n)=>(await e.deleteFrom(`user_organizations`).where(`id`,`=`,n).where(`tenant_id`,`=`,t).execute()).length>0}function gi(e){return async(t,n,r)=>{let i={...r,updated_at:new Date().toISOString()};return(await e.updateTable(`user_organizations`).set(i).where(`id`,`=`,n).where(`tenant_id`,`=`,t).execute()).length>0}}function _i(e){return{create:di(e),get:fi(e),list:pi(e),listUserOrganizations:mi(e),remove:hi(e),update:gi(e)}}function vi(e){return async(t,n)=>{let r=n.id||h(),i=new Date().toISOString(),a=n.ttl_sec||604800,o=new Date(Date.now()+a*1e3).toISOString(),s=j({id:r,tenant_id:t,organization_id:n.organization_id,inviter:n.inviter||{},invitee:n.invitee||{},client_id:n.client_id,connection_id:n.connection_id||null,invitation_url:n.invitation_url,created_at:i,expires_at:o,app_metadata:n.app_metadata||{},user_metadata:n.user_metadata||{},roles:n.roles||[],ticket_id:null,ttl_sec:a,send_invitation_email:n.send_invitation_email??!0?1:0},[`inviter`,`invitee`,`app_metadata`,`user_metadata`,`roles`]);try{await e.insertInto(`invites`).values(s).execute()}catch(e){throw e.code===`SQLITE_CONSTRAINT_UNIQUE`||e.code===`ER_DUP_ENTRY`||e.message.includes(`AlreadyExists`)?new E(409,{message:`Invite already exists`}):e}return{id:r,organization_id:s.organization_id,inviter:n.inviter,invitee:n.invitee,client_id:n.client_id,connection_id:n.connection_id,invitation_url:n.invitation_url,created_at:i,expires_at:o,app_metadata:n.app_metadata||{},user_metadata:n.user_metadata||{},roles:n.roles||[],ticket_id:s.ticket_id||void 0,ttl_sec:a,send_invitation_email:n.send_invitation_email??!0}}}function yi(e){return async(t,n)=>{let r=await e.selectFrom(`invites`).selectAll().where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return r?D({...De(r,{inviter:{},invitee:{},app_metadata:{},user_metadata:{},roles:[]}),send_invitation_email:r.send_invitation_email===1}):null}}function bi(e){return async(t,n)=>{let r=e.selectFrom(`invites`).selectAll().where(`tenant_id`,`=`,t).orderBy(`created_at`,`desc`);if(n?.per_page&&(r=r.limit(n.per_page)),n?.page){let e=(n.page-1)*(n.per_page||10);r=r.offset(e)}let i=(await r.execute()).map(e=>D({...De(e,{inviter:{},invitee:{},app_metadata:{},user_metadata:{},roles:[]}),send_invitation_email:e.send_invitation_email===1}));return{invites:i,start:n?.page?(n.page-1)*(n.per_page||10):0,limit:n?.per_page||i.length,length:i.length}}}function xi(e){return async(t,n)=>(await e.deleteFrom(`invites`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst()).numDeletedRows>0n}function Si(e){return async(t,n,r)=>{let i={};return r.inviter!==void 0&&(i.inviter=JSON.stringify(r.inviter)),r.invitee!==void 0&&(i.invitee=JSON.stringify(r.invitee)),r.client_id!==void 0&&(i.client_id=r.client_id),r.connection_id!==void 0&&(i.connection_id=r.connection_id),r.app_metadata!==void 0&&(i.app_metadata=JSON.stringify(r.app_metadata)),r.user_metadata!==void 0&&(i.user_metadata=JSON.stringify(r.user_metadata)),r.roles!==void 0&&(i.roles=JSON.stringify(r.roles)),r.ttl_sec!==void 0&&(i.ttl_sec=r.ttl_sec,i.expires_at=new Date(Date.now()+r.ttl_sec*1e3).toISOString()),r.send_invitation_email!==void 0&&(i.send_invitation_email=+!!r.send_invitation_email),Object.keys(i).length===0?!0:(await e.updateTable(`invites`).set(i).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst()).numUpdatedRows>0n}}function Ci(e){return{create:vi(e),get:yi(e),list:bi(e),remove:xi(e),update:Si(e)}}var wi=[`s`],Ti=[`pwd_leak`];function Ei(e){return/^\d{8}$/.test(e)?`${e.slice(0,4)}-${e.slice(4,6)}-${e.slice(6,8)}`:e}function Di(e){return e.toISOString().split(`T`)[0]}function Oi(e){return{async getDaily(t,n={}){let{from:r,to:a}=n,o=new Date,s=new Date(o);s.setDate(s.getDate()-30);let c=r?Ei(r):Di(s),l=a?Ei(a):Di(o),u=i.sql`DATE(logs.date)`;return(await e.selectFrom(`logs`).where(`tenant_id`,`=`,t).where(u,`>=`,c).where(u,`<=`,l).select(e=>[u.as(`date`),e.fn.sum(e.case().when(`type`,`in`,wi).then(1).else(0).end()).as(`logins`),e.fn.sum(e.case().when(`type`,`=`,`ss`).then(1).else(0).end()).as(`signups`),e.fn.sum(e.case().when(`type`,`in`,Ti).then(1).else(0).end()).as(`leaked_passwords`),e.fn.min(`date`).as(`first_event`),e.fn.max(`date`).as(`last_event`)]).groupBy(u).orderBy(`date`,`asc`).execute()).map(e=>({date:e.date,logins:Number(e.logins)||0,signups:Number(e.signups)||0,leaked_passwords:Number(e.leaked_passwords)||0,created_at:e.first_event||new Date().toISOString(),updated_at:e.last_event||new Date().toISOString()}))},async getActiveUsers(t){let n=new Date;return n.setDate(n.getDate()-30),(await e.selectFrom(`logs`).where(`tenant_id`,`=`,t).where(`date`,`>=`,n.toISOString()).where(`type`,`in`,wi).where(`user_id`,`is not`,null).select(e=>e.fn.count(`user_id`).distinct().as(`count`)).executeTakeFirstOrThrow()).count||0}}}var ki={"active-users":[`s`,`seacft`],logins:[`s`,`f`,`fp`],signups:[`ss`,`fs`],"refresh-tokens":[`seacft`,`fertft`],sessions:[`slo`]},Ai={"active-users":{alias:`active_users`,type:`UInt64`,agg:`uniq`},logins:{alias:`logins`,type:`UInt64`,agg:`count`},signups:{alias:`signups`,type:`UInt64`,agg:`count`},"refresh-tokens":{alias:`refresh_tokens`,type:`UInt64`,agg:`count`},sessions:{alias:`sessions`,type:`UInt64`,agg:`count`}};async function ji(e){try{return await i.sql`SELECT @@version_comment`.execute(e),`mysql`}catch{return`sqlite`}}function F(e,t){let n=new Intl.DateTimeFormat(`en-US`,{timeZone:e,year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,hour12:!1}),r={};for(let e of n.formatToParts(t))r[e.type]=e.value;let i=r.hour===`24`?`00`:r.hour,a=Date.UTC(Number(r.year),Number(r.month)-1,Number(r.day),Number(i),Number(r.minute),Number(r.second)),o=Math.round((a-t.getTime())/6e4),s=o>=0?`+`:`-`,c=Math.abs(o);return`${s}${String(Math.floor(c/60)).padStart(2,`0`)}:${String(c%60).padStart(2,`0`)}`}var Mi=[`January`,`February`,`March`,`April`,`May`,`June`,`July`,`August`,`September`,`October`,`November`,`December`];function Ni(e,t){let n=t.getUTCFullYear(),r=F(e,new Date(Date.UTC(n,0,1)));for(let t=1;t<12;t++){let i=F(e,new Date(Date.UTC(n,t,1)));if(i!==r)throw Error(`Timezone '${e}' is DST-varying (offset ${r} in January vs ${i} in ${Mi[t]}) and cannot be bucketed with a single fixed offset by the SQL analytics adapter. Use a fixed-offset zone (e.g. 'UTC' or '+02:00').`)}}function Pi(e){let t=e.startsWith(`-`)?-1:1,[n,r]=e.slice(1).split(`:`);return t*(Number(n)*60+Number(r))}function Fi(e,t){let n;if(t===`+00:00`)n=i.sql`${i.sql.ref(`logs.date`)}`;else{let e=Pi(t),r=`${e>=0?`+`:`-`}${Math.abs(e)} minutes`;n=i.sql`datetime(${i.sql.ref(`logs.date`)}, ${r})`}switch(e){case`hour`:return i.sql`substr(${n}, 1, 13)`;case`month`:return i.sql`substr(${n}, 1, 7)`;case`day`:return i.sql`substr(${n}, 1, 10)`;case`week`:return i.sql`date(substr(${n}, 1, 10), '-' || ((cast(strftime('%w', substr(${n}, 1, 10)) as integer) + 6) % 7) || ' days')`;default:throw Error(`Unsupported interval '${e}' for SQL analytics adapter`)}}function Ii(e,t){if(t===`+00:00`)switch(e){case`hour`:return i.sql`substring(${i.sql.ref(`logs.date`)}, 1, 13)`;case`day`:return i.sql`substring(${i.sql.ref(`logs.date`)}, 1, 10)`;case`month`:return i.sql`substring(${i.sql.ref(`logs.date`)}, 1, 7)`;case`week`:{let e=i.sql`str_to_date(substring(${i.sql.ref(`logs.date`)}, 1, 10), '%Y-%m-%d')`;return i.sql`date_format(date_sub(${e}, interval weekday(${e}) day), '%Y-%m-%d')`}default:throw Error(`Unsupported interval '${e}' for SQL analytics adapter`)}let n=Pi(t),r=i.sql`date_add(str_to_date(substring(${i.sql.ref(`logs.date`)}, 1, 19), '%Y-%m-%dT%H:%i:%s'), interval ${i.sql.lit(n)} minute)`;switch(e){case`hour`:return i.sql`date_format(${r}, '%Y-%m-%dT%H')`;case`day`:return i.sql`date_format(${r}, '%Y-%m-%d')`;case`month`:return i.sql`date_format(${r}, '%Y-%m')`;case`week`:return i.sql`date_format(date_sub(${r}, interval weekday(${r}) day), '%Y-%m-%d')`;default:throw Error(`Unsupported interval '${e}' for SQL analytics adapter`)}}function Li(e,t,n,r){Ni(t,n);let i=F(t,n);return r===`mysql`?Ii(e,i):Fi(e,i)}function Ri(e){switch(e){case`connection`:return`logs.connection`;case`client_id`:return`logs.client_id`;case`user_type`:return`logs.strategy_type`;case`event`:return`logs.type`;case`time`:throw Error(`time dimension is handled separately`)}}function zi(e){let t=null,n=()=>(t||=ji(e),t);return{async query(t,r,a){let o=Date.now(),s=ki[r],c=Ai[r],l=await n(),u=[],d=e.selectFrom(`logs`).where(`tenant_id`,`=`,t);d=d.where(`date`,`>=`,a.from).where(`date`,`<`,a.to),d=d.where(`type`,`in`,s),a.filters.connection?.length&&(d=d.where(`connection`,`in`,a.filters.connection)),a.filters.client_id?.length&&(d=d.where(`client_id`,`in`,a.filters.client_id)),a.filters.user_type?.length&&(d=d.where(`strategy_type`,`in`,a.filters.user_type)),a.filters.user_id?.length&&(d=d.where(`user_id`,`in`,a.filters.user_id));let f=[],p=[];for(let e of a.group_by)if(e===`time`){let e=Li(a.interval,a.tz,new Date(a.from),l);p.push({alias:`time`,expr:e}),f.push(e),u.push({name:`time`,type:a.interval===`hour`?`DateTime`:`Date`})}else{let t=Ri(e);p.push({alias:e,expr:i.sql`${i.sql.ref(t)}`}),f.push(i.sql`${i.sql.ref(t)}`),u.push({name:e,type:`String`})}let m=c.agg===`uniq`?i.sql`COUNT(DISTINCT ${i.sql.ref(`logs.user_id`)})`:i.sql`COUNT(*)`;p.push({alias:c.alias,expr:m}),u.push({name:c.alias,type:c.type});let h=d.select(p.map(({alias:e,expr:t})=>t.as(e)));if(f.length>0&&(h=h.groupBy(f)),a.order_by){let e=a.order_by.startsWith(`-`),t=e?a.order_by.slice(1):a.order_by;h=h.orderBy(t,e?`desc`:`asc`)}else h=a.group_by.length>0&&a.group_by[0]===`time`?h.orderBy(`time`,`asc`):h.orderBy(c.alias,`desc`);h=h.limit(a.limit).offset(a.offset);let g=(await h.execute()).map(e=>{let t={};for(let n of u){let r=e[n.name];t[n.name]=n.type===`UInt64`?Number(r)||0:r??``}return t});return{meta:u,data:g,rows:g.length,rows_before_limit_at_least:g.length,statistics:{elapsed:(Date.now()-o)/1e3}}}}}function Bi(e){return{async get(t,n,r){let i=await e.selectFrom(`custom_text`).selectAll().where(`tenant_id`,`=`,t).where(`prompt`,`=`,n).where(`language`,`=`,r).executeTakeFirst();if(!i)return null;try{return JSON.parse(i.custom_text)}catch{return null}},async set(t,n,r,i){let a=Date.now(),o=JSON.stringify(i);await e.selectFrom(`custom_text`).select(`tenant_id`).where(`tenant_id`,`=`,t).where(`prompt`,`=`,n).where(`language`,`=`,r).executeTakeFirst()?await e.updateTable(`custom_text`).set({custom_text:o,updated_at_ts:a}).where(`tenant_id`,`=`,t).where(`prompt`,`=`,n).where(`language`,`=`,r).execute():await e.insertInto(`custom_text`).values({tenant_id:t,prompt:n,language:r,custom_text:o,created_at_ts:a,updated_at_ts:a}).execute()},async delete(t,n,r){await e.deleteFrom(`custom_text`).where(`tenant_id`,`=`,t).where(`prompt`,`=`,n).where(`language`,`=`,r).execute()},async list(t){return(await e.selectFrom(`custom_text`).select([`prompt`,`language`]).where(`tenant_id`,`=`,t).execute()).map(e=>({prompt:e.prompt,language:e.language}))}}}function Vi(e){return async(t,n)=>{let r=Date.now(),i=Hn();return await e.insertInto(`authentication_methods`).values({id:i,tenant_id:t,user_id:n.user_id,type:n.type,phone_number:n.phone_number,totp_secret:n.totp_secret,credential_id:n.credential_id,public_key:n.public_key,sign_count:n.sign_count,credential_backed_up:n.credential_backed_up==null?void 0:+!!n.credential_backed_up,transports:n.transports?JSON.stringify(n.transports):void 0,friendly_name:n.friendly_name,confirmed:+!!n.confirmed,created_at_ts:r,updated_at_ts:r}).execute(),{id:i,user_id:n.user_id,type:n.type,phone_number:n.phone_number,totp_secret:n.totp_secret,credential_id:n.credential_id,public_key:n.public_key,sign_count:n.sign_count,credential_backed_up:n.credential_backed_up,transports:n.transports,friendly_name:n.friendly_name,confirmed:n.confirmed??!1,created_at:new Date(r).toISOString(),updated_at:new Date(r).toISOString()}}}function Hi(e){return async(t,n)=>{let r=await e.selectFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.id`,`=`,n).selectAll().executeTakeFirst();return r?{id:r.id,user_id:r.user_id,type:r.type,phone_number:r.phone_number??void 0,totp_secret:r.totp_secret??void 0,credential_id:r.credential_id??void 0,public_key:r.public_key??void 0,sign_count:r.sign_count??void 0,credential_backed_up:r.credential_backed_up==null?void 0:r.credential_backed_up===1,transports:r.transports?JSON.parse(r.transports):void 0,friendly_name:r.friendly_name??void 0,confirmed:r.confirmed===1,created_at:v(r.created_at_ts),updated_at:v(r.updated_at_ts)}:null}}function Ui(e){return async(t,n)=>{let r=await e.selectFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.credential_id`,`=`,n).selectAll().executeTakeFirst();return r?{id:r.id,user_id:r.user_id,type:r.type,phone_number:r.phone_number??void 0,totp_secret:r.totp_secret??void 0,credential_id:r.credential_id??void 0,public_key:r.public_key??void 0,sign_count:r.sign_count??void 0,credential_backed_up:r.credential_backed_up==null?void 0:r.credential_backed_up===1,transports:r.transports?JSON.parse(r.transports):void 0,friendly_name:r.friendly_name??void 0,confirmed:r.confirmed===1,created_at:v(r.created_at_ts),updated_at:v(r.updated_at_ts)}:null}}function Wi(e){return async(t,n)=>(await e.selectFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.user_id`,`=`,n).selectAll().execute()).map(e=>({id:e.id,user_id:e.user_id,type:e.type,phone_number:e.phone_number??void 0,totp_secret:e.totp_secret??void 0,credential_id:e.credential_id??void 0,public_key:e.public_key??void 0,sign_count:e.sign_count??void 0,credential_backed_up:e.credential_backed_up==null?void 0:e.credential_backed_up===1,transports:e.transports?JSON.parse(e.transports):void 0,friendly_name:e.friendly_name??void 0,confirmed:e.confirmed===1,created_at:v(e.created_at_ts),updated_at:v(e.updated_at_ts)}))}function Gi(e){return async(t,n,r)=>{let i={updated_at_ts:Date.now()};r.phone_number!==void 0&&(i.phone_number=r.phone_number),r.totp_secret!==void 0&&(i.totp_secret=r.totp_secret),r.credential_id!==void 0&&(i.credential_id=r.credential_id),r.public_key!==void 0&&(i.public_key=r.public_key),r.sign_count!==void 0&&(i.sign_count=r.sign_count),r.credential_backed_up!==void 0&&(i.credential_backed_up=+!!r.credential_backed_up),r.transports!==void 0&&(i.transports=JSON.stringify(r.transports)),r.friendly_name!==void 0&&(i.friendly_name=r.friendly_name),r.confirmed!==void 0&&(i.confirmed=+!!r.confirmed),await e.updateTable(`authentication_methods`).set(i).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.id`,`=`,n).execute();let a=await Hi(e)(t,n);if(!a)throw Error(`Authentication method ${n} not found`);return a}}function Ki(e){return async(t,n)=>(await e.deleteFrom(`authentication_methods`).where(`authentication_methods.tenant_id`,`=`,t).where(`authentication_methods.id`,`=`,n).executeTakeFirst()).numDeletedRows>0}function qi(e){return{create:Vi(e),get:Hi(e),getByCredentialId:Ui(e),list:Wi(e),update:Gi(e),remove:Ki(e)}}function Ji(e){return async(t,r)=>{let i=(0,n.nanoid)();return await e.insertInto(`outbox_events`).values({id:i,tenant_id:t,event_type:r.event_type,log_type:r.log_type,aggregate_type:r.target.type,aggregate_id:r.target.id,payload:JSON.stringify({...r,id:i}),created_at:new Date().toISOString(),processed_at:null,retry_count:0,next_retry_at:null,error:null}).execute(),i}}function Yi(e){return async t=>t.length===0?[]:(await e.selectFrom(`outbox_events`).selectAll().where(`id`,`in`,t).execute()).map(e=>({...JSON.parse(e.payload),id:e.id,created_at:e.created_at,processed_at:e.processed_at,retry_count:e.retry_count,next_retry_at:e.next_retry_at,error:e.error}))}function Xi(e){return async t=>{let n=new Date().toISOString();return(await e.selectFrom(`outbox_events`).selectAll().where(`processed_at`,`is`,null).where(e=>e.or([e(`next_retry_at`,`is`,null),e(`next_retry_at`,`<=`,n)])).where(e=>e.or([e(`claimed_by`,`is`,null),e(`claim_expires_at`,`<=`,n)])).orderBy(`created_at`,`asc`).orderBy(`id`,`asc`).limit(t).execute()).map(e=>({...JSON.parse(e.payload),id:e.id,created_at:e.created_at,processed_at:e.processed_at,retry_count:e.retry_count,next_retry_at:e.next_retry_at,error:e.error}))}}function Zi(e){return async(t,n,r)=>{if(t.length===0)return[];let i=new Date().toISOString(),a=new Date(Date.now()+r).toISOString();return await e.updateTable(`outbox_events`).set({claimed_by:n,claim_expires_at:a}).where(`id`,`in`,t).where(`processed_at`,`is`,null).where(e=>e.or([e(`claimed_by`,`is`,null),e(`claim_expires_at`,`<=`,i)])).execute(),(await e.selectFrom(`outbox_events`).select(`id`).where(`id`,`in`,t).where(`claimed_by`,`=`,n).where(`claim_expires_at`,`=`,a).execute()).map(e=>e.id)}}function Qi(e){return async t=>{if(t.length===0)return;let n=new Date().toISOString();await e.updateTable(`outbox_events`).set({processed_at:n}).where(`id`,`in`,t).execute()}}function $i(e){return async(t,n,r)=>{await e.updateTable(`outbox_events`).set({error:n,next_retry_at:r,retry_count:i.sql`retry_count + 1`,claimed_by:null,claim_expires_at:null}).where(`id`,`=`,t).execute()}}function ea(e){return async(t,n)=>{let r=new Date().toISOString();await e.updateTable(`outbox_events`).set({processed_at:r,dead_lettered_at:r,final_error:n}).where(`id`,`=`,t).execute()}}function ta(e){return async(t,n={})=>{let{page:r=0,per_page:i=50,include_totals:a=!1}=n,o=(await e.selectFrom(`outbox_events`).selectAll().where(`tenant_id`,`=`,t).where(`dead_lettered_at`,`is not`,null).orderBy(`dead_lettered_at`,`desc`).orderBy(`id`,`asc`).offset(r*i).limit(i).execute()).flatMap(e=>{let t;try{t=JSON.parse(e.payload)}catch(t){return console.error(`Failed to parse outbox payload for event ${e.id}`,t),[]}return[{...t,id:e.id,created_at:e.created_at,processed_at:e.processed_at,retry_count:e.retry_count,next_retry_at:e.next_retry_at,error:e.error,dead_lettered_at:e.dead_lettered_at,final_error:e.final_error}]}),s=o.length;if(a){let[n]=await e.selectFrom(`outbox_events`).select(e=>e.fn.countAll().as(`total`)).where(`tenant_id`,`=`,t).where(`dead_lettered_at`,`is not`,null).execute();s=Number(n?.total??o.length)}return{events:o,start:r*i,limit:i,length:s}}}function na(e){return async(t,n)=>{let r=await e.updateTable(`outbox_events`).set({processed_at:null,dead_lettered_at:null,final_error:null,retry_count:0,next_retry_at:null,error:null}).where(`id`,`=`,t).where(`tenant_id`,`=`,n).where(`dead_lettered_at`,`is not`,null).executeTakeFirst();return Number(r.numUpdatedRows)>0}}function ra(e){return async t=>{let n=await e.deleteFrom(`outbox_events`).where(`processed_at`,`is not`,null).where(`processed_at`,`<`,t).executeTakeFirst();return Number(n.numDeletedRows)}}function ia(e){return{create:Ji(e),getByIds:Yi(e),getUnprocessed:Xi(e),claimEvents:Zi(e),markProcessed:Qi(e),markRetry:$i(e),deadLetter:ea(e),listFailed:ta(e),replay:na(e),cleanup:ra(e)}}function I(e){return{id:e.id,name:e.name,type:e.type,status:e.status,sink:JSON.parse(e.sink),filters:e.filters?JSON.parse(e.filters):void 0,isPriority:e.is_priority==null?void 0:e.is_priority===1,created_at:e.created_at,updated_at:e.updated_at}}function aa(e){return{async create(t,r){let i=new Date().toISOString(),a={id:`lst_${(0,n.nanoid)()}`,tenant_id:t,name:r.name,type:r.type,status:r.status??`active`,sink:JSON.stringify(r.sink),filters:r.filters?JSON.stringify(r.filters):null,is_priority:r.isPriority===void 0?null:+!!r.isPriority,created_at:i,updated_at:i};return await e.insertInto(`log_streams`).values(a).execute(),I(a)},async get(t,n){let r=await e.selectFrom(`log_streams`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).selectAll().executeTakeFirst();return r?I(r):null},async list(t){return(await e.selectFrom(`log_streams`).where(`tenant_id`,`=`,t).selectAll().execute()).map(I)},async update(t,n,r){let i={updated_at:new Date().toISOString()};return r.name!==void 0&&(i.name=r.name),r.type!==void 0&&(i.type=r.type),r.status!==void 0&&(i.status=r.status),r.sink!==void 0&&(i.sink=JSON.stringify(r.sink)),r.filters!==void 0&&(i.filters=r.filters?JSON.stringify(r.filters):null),r.isPriority!==void 0&&(i.is_priority=+!!r.isPriority),((await e.updateTable(`log_streams`).set(i).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst())?.numUpdatedRows??0n)>0n},async remove(t,n){return((await e.deleteFrom(`log_streams`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst())?.numDeletedRows??0n)>0n}}}function L(e){return{id:e.id,name:e.name,provider:r.migrationProviderTypeSchema.parse(e.provider),connection:e.connection,enabled:e.enabled===1,credentials:JSON.parse(e.credentials),created_at:e.created_at,updated_at:e.updated_at}}function oa(e){return{async create(t,r){let i=new Date().toISOString(),a=r.id??`mig_${(0,n.nanoid)()}`,o=r.enabled??!0,s={id:a,tenant_id:t,name:r.name,provider:r.provider,connection:r.connection,enabled:+!!o,credentials:JSON.stringify(r.credentials),created_at:i,updated_at:i};return await e.insertInto(`migration_sources`).values(s).execute(),L(s)},async get(t,n){let r=await e.selectFrom(`migration_sources`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).selectAll().executeTakeFirst();return r?L(r):null},async list(t){return(await e.selectFrom(`migration_sources`).where(`tenant_id`,`=`,t).selectAll().execute()).map(L)},async update(t,n,r){let i={updated_at:new Date().toISOString()};return r.name!==void 0&&(i.name=r.name),r.provider!==void 0&&(i.provider=r.provider),r.connection!==void 0&&(i.connection=r.connection),r.enabled!==void 0&&(i.enabled=+!!r.enabled),r.credentials!==void 0&&(i.credentials=JSON.stringify(r.credentials)),((await e.updateTable(`migration_sources`).set(i).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst())?.numUpdatedRows??0n)>0n},async remove(t,n){return((await e.deleteFrom(`migration_sources`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst())?.numDeletedRows??0n)>0n}}}function R(e){return{id:e.id,tenant_id:e.tenant_id,custom_domain_id:e.custom_domain_id,priority:e.priority,match:sa(e.match),handlers:ca(e.handlers),created_at:e.created_at,updated_at:e.updated_at}}function sa(e){if(!e)return{path:`/*`};try{let t=JSON.parse(e),n=r.matchSchema.safeParse(t);if(n.success)return n.data}catch{}return{path:`/*`}}function ca(e){if(!e)return[];try{let t=JSON.parse(e);if(!Array.isArray(t))return[];let n=[];for(let e of t){let t=r.handlerConfigSchema.safeParse(e);t.success&&n.push(t.data)}return n}catch{return[]}}function z(e){return{async create(t,r){let i=new Date().toISOString(),a={id:r.id||(0,n.nanoid)(),tenant_id:t,custom_domain_id:r.custom_domain_id,priority:r.priority,match:r.match,handlers:r.handlers,created_at:i,updated_at:i};return await e.insertInto(`proxy_routes`).values({id:a.id,tenant_id:a.tenant_id,custom_domain_id:a.custom_domain_id,priority:a.priority,match:JSON.stringify(a.match),handlers:JSON.stringify(a.handlers),created_at:a.created_at,updated_at:a.updated_at}).execute(),a},async get(t,n){let r=await e.selectFrom(`proxy_routes`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).selectAll().executeTakeFirst();return r?R(r):null},async list(t,n={}){let r=n.page??0,i=n.per_page??50,a=e.selectFrom(`proxy_routes`).where(`tenant_id`,`=`,t);n.custom_domain_id&&(a=a.where(`custom_domain_id`,`=`,n.custom_domain_id));let o=await a.selectAll().orderBy(`priority`,`asc`).orderBy(`created_at`,`asc`).offset(r*i).limit(i).execute();return{proxy_routes:o.map(R),start:r*i,limit:i,length:o.length}},async update(t,n,r){let i={updated_at:new Date().toISOString()};r.priority!==void 0&&(i.priority=r.priority),r.match!==void 0&&(i.match=JSON.stringify(r.match)),r.handlers!==void 0&&(i.handlers=JSON.stringify(r.handlers));let a=await e.updateTable(`proxy_routes`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).set(i).executeTakeFirst();return Number(a.numUpdatedRows)>0},async remove(t,n){let r=await e.deleteFrom(`proxy_routes`).where(`tenant_id`,`=`,t).where(`id`,`=`,n).executeTakeFirst();return Number(r.numDeletedRows)>0}}}async function la(e,t){let n=t.indexOf(`:`),r=n===-1?t:t.slice(0,n),i=(r.endsWith(`.`)?r.slice(0,-1):r).toLowerCase(),a=await e.selectFrom(`custom_domains`).where(`domain`,`=`,i).select([`custom_domain_id`,`tenant_id`,`domain`]).executeTakeFirst();if(!a)return null;let o=await e.selectFrom(`proxy_routes`).where(`tenant_id`,`=`,a.tenant_id).where(`custom_domain_id`,`=`,a.custom_domain_id).selectAll().orderBy(`priority`,`asc`).orderBy(`created_at`,`asc`).execute();return{tenant_id:a.tenant_id,custom_domain_id:a.custom_domain_id,domain:a.domain,routes:o.map(R)}}function ua(e){return{proxyRoutes:z(e),resolveHost:t=>la(e,t)}}function da(e){return typeof e==`string`}function fa(e){return typeof e==`object`&&!!e}function pa(e){return e[e.length-1]}function B(e){return Object.freeze(e)}var ma=class{transformQuery(e){return e.node}async transformResult(e){return e.result}},ha=B({is(e){return e.kind===`AliasNode`},create(e,t){return B({kind:`AliasNode`,node:e,alias:t})}}),V=B({is(e){return e.kind===`IdentifierNode`},create(e){return B({kind:`IdentifierNode`,name:e})}}),ga=B({is(e){return e.kind===`AndNode`},create(e,t){return B({kind:`AndNode`,left:e,right:t})}}),_a=B({is(e){return e.kind===`OrNode`},create(e,t){return B({kind:`OrNode`,left:e,right:t})}}),H=B({is(e){return e.kind===`OnNode`},create(e){return B({kind:`OnNode`,on:e})},cloneWithOperation(e,t,n){return B({...e,on:t===`And`?ga.create(e.on,n):_a.create(e.on,n)})}}),va=B({is(e){return e.kind===`JoinNode`},create(e,t){return B({kind:`JoinNode`,joinType:e,table:t,on:void 0})},createWithOn(e,t,n){return B({kind:`JoinNode`,joinType:e,table:t,on:H.create(n)})},cloneWithOn(e,t){return B({...e,on:e.on?H.cloneWithOperation(e.on,`And`,t):H.create(t)})}}),ya=B({is(e){return e.kind===`ListNode`},create(e){return B({kind:`ListNode`,items:B(e)})}}),ba=class{nodeStack=[];#e=B({AliasNode:this.transformAlias.bind(this),ColumnNode:this.transformColumn.bind(this),IdentifierNode:this.transformIdentifier.bind(this),SchemableIdentifierNode:this.transformSchemableIdentifier.bind(this),RawNode:this.transformRaw.bind(this),ReferenceNode:this.transformReference.bind(this),SelectQueryNode:this.transformSelectQuery.bind(this),SelectionNode:this.transformSelection.bind(this),TableNode:this.transformTable.bind(this),FromNode:this.transformFrom.bind(this),SelectAllNode:this.transformSelectAll.bind(this),AndNode:this.transformAnd.bind(this),OrNode:this.transformOr.bind(this),ValueNode:this.transformValue.bind(this),ValueListNode:this.transformValueList.bind(this),PrimitiveValueListNode:this.transformPrimitiveValueList.bind(this),ParensNode:this.transformParens.bind(this),JoinNode:this.transformJoin.bind(this),OperatorNode:this.transformOperator.bind(this),WhereNode:this.transformWhere.bind(this),InsertQueryNode:this.transformInsertQuery.bind(this),DeleteQueryNode:this.transformDeleteQuery.bind(this),ReturningNode:this.transformReturning.bind(this),CreateTableNode:this.transformCreateTable.bind(this),AddColumnNode:this.transformAddColumn.bind(this),ColumnDefinitionNode:this.transformColumnDefinition.bind(this),DropTableNode:this.transformDropTable.bind(this),DataTypeNode:this.transformDataType.bind(this),OrderByNode:this.transformOrderBy.bind(this),OrderByItemNode:this.transformOrderByItem.bind(this),GroupByNode:this.transformGroupBy.bind(this),GroupByItemNode:this.transformGroupByItem.bind(this),UpdateQueryNode:this.transformUpdateQuery.bind(this),ColumnUpdateNode:this.transformColumnUpdate.bind(this),LimitNode:this.transformLimit.bind(this),OffsetNode:this.transformOffset.bind(this),OnConflictNode:this.transformOnConflict.bind(this),OnDuplicateKeyNode:this.transformOnDuplicateKey.bind(this),CreateIndexNode:this.transformCreateIndex.bind(this),DropIndexNode:this.transformDropIndex.bind(this),ListNode:this.transformList.bind(this),PrimaryKeyConstraintNode:this.transformPrimaryKeyConstraint.bind(this),UniqueConstraintNode:this.transformUniqueConstraint.bind(this),ReferencesNode:this.transformReferences.bind(this),CheckConstraintNode:this.transformCheckConstraint.bind(this),WithNode:this.transformWith.bind(this),CommonTableExpressionNode:this.transformCommonTableExpression.bind(this),CommonTableExpressionNameNode:this.transformCommonTableExpressionName.bind(this),HavingNode:this.transformHaving.bind(this),CreateSchemaNode:this.transformCreateSchema.bind(this),DropSchemaNode:this.transformDropSchema.bind(this),AlterTableNode:this.transformAlterTable.bind(this),DropColumnNode:this.transformDropColumn.bind(this),RenameColumnNode:this.transformRenameColumn.bind(this),AlterColumnNode:this.transformAlterColumn.bind(this),ModifyColumnNode:this.transformModifyColumn.bind(this),AddConstraintNode:this.transformAddConstraint.bind(this),DropConstraintNode:this.transformDropConstraint.bind(this),RenameConstraintNode:this.transformRenameConstraint.bind(this),ForeignKeyConstraintNode:this.transformForeignKeyConstraint.bind(this),CreateViewNode:this.transformCreateView.bind(this),RefreshMaterializedViewNode:this.transformRefreshMaterializedView.bind(this),DropViewNode:this.transformDropView.bind(this),GeneratedNode:this.transformGenerated.bind(this),DefaultValueNode:this.transformDefaultValue.bind(this),OnNode:this.transformOn.bind(this),ValuesNode:this.transformValues.bind(this),SelectModifierNode:this.transformSelectModifier.bind(this),CreateTypeNode:this.transformCreateType.bind(this),DropTypeNode:this.transformDropType.bind(this),ExplainNode:this.transformExplain.bind(this),DefaultInsertValueNode:this.transformDefaultInsertValue.bind(this),AggregateFunctionNode:this.transformAggregateFunction.bind(this),OverNode:this.transformOver.bind(this),PartitionByNode:this.transformPartitionBy.bind(this),PartitionByItemNode:this.transformPartitionByItem.bind(this),SetOperationNode:this.transformSetOperation.bind(this),BinaryOperationNode:this.transformBinaryOperation.bind(this),UnaryOperationNode:this.transformUnaryOperation.bind(this),UsingNode:this.transformUsing.bind(this),FunctionNode:this.transformFunction.bind(this),CaseNode:this.transformCase.bind(this),WhenNode:this.transformWhen.bind(this),JSONReferenceNode:this.transformJSONReference.bind(this),JSONPathNode:this.transformJSONPath.bind(this),JSONPathLegNode:this.transformJSONPathLeg.bind(this),JSONOperatorChainNode:this.transformJSONOperatorChain.bind(this),TupleNode:this.transformTuple.bind(this),MergeQueryNode:this.transformMergeQuery.bind(this),MatchedNode:this.transformMatched.bind(this),AddIndexNode:this.transformAddIndex.bind(this),CastNode:this.transformCast.bind(this),FetchNode:this.transformFetch.bind(this),TopNode:this.transformTop.bind(this),OutputNode:this.transformOutput.bind(this),OrActionNode:this.transformOrAction.bind(this),CollateNode:this.transformCollate.bind(this),AlterTypeNode:this.transformAlterType.bind(this),AddValueNode:this.transformAddValue.bind(this),RenameValueNode:this.transformRenameValue.bind(this)});transformNode(e,t){if(!e)return e;this.nodeStack.push(e);let n=this.transformNodeImpl(e,t);return this.nodeStack.pop(),B(n)}transformNodeImpl(e,t){return this.#e[e.kind](e,t)}transformNodeList(e,t){return e&&B(e.map(e=>this.transformNode(e,t)))}transformSelectQuery(e,t){return{kind:`SelectQueryNode`,from:this.transformNode(e.from,t),selections:this.transformNodeList(e.selections,t),distinctOn:this.transformNodeList(e.distinctOn,t),joins:this.transformNodeList(e.joins,t),groupBy:this.transformNode(e.groupBy,t),orderBy:this.transformNode(e.orderBy,t),where:this.transformNode(e.where,t),frontModifiers:this.transformNodeList(e.frontModifiers,t),endModifiers:this.transformNodeList(e.endModifiers,t),limit:this.transformNode(e.limit,t),offset:this.transformNode(e.offset,t),with:this.transformNode(e.with,t),having:this.transformNode(e.having,t),explain:this.transformNode(e.explain,t),setOperations:this.transformNodeList(e.setOperations,t),fetch:this.transformNode(e.fetch,t),top:this.transformNode(e.top,t)}}transformSelection(e,t){return{kind:`SelectionNode`,selection:this.transformNode(e.selection,t)}}transformColumn(e,t){return{kind:`ColumnNode`,column:this.transformNode(e.column,t)}}transformAlias(e,t){return{kind:`AliasNode`,node:this.transformNode(e.node,t),alias:this.transformNode(e.alias,t)}}transformTable(e,t){return{kind:`TableNode`,table:this.transformNode(e.table,t)}}transformFrom(e,t){return{kind:`FromNode`,froms:this.transformNodeList(e.froms,t)}}transformReference(e,t){return{kind:`ReferenceNode`,column:this.transformNode(e.column,t),table:this.transformNode(e.table,t)}}transformAnd(e,t){return{kind:`AndNode`,left:this.transformNode(e.left,t),right:this.transformNode(e.right,t)}}transformOr(e,t){return{kind:`OrNode`,left:this.transformNode(e.left,t),right:this.transformNode(e.right,t)}}transformValueList(e,t){return{kind:`ValueListNode`,values:this.transformNodeList(e.values,t)}}transformParens(e,t){return{kind:`ParensNode`,node:this.transformNode(e.node,t)}}transformJoin(e,t){return{kind:`JoinNode`,joinType:e.joinType,table:this.transformNode(e.table,t),on:this.transformNode(e.on,t)}}transformRaw(e,t){return{kind:`RawNode`,sqlFragments:B([...e.sqlFragments]),parameters:this.transformNodeList(e.parameters,t)}}transformWhere(e,t){return{kind:`WhereNode`,where:this.transformNode(e.where,t)}}transformInsertQuery(e,t){return{kind:`InsertQueryNode`,into:this.transformNode(e.into,t),columns:this.transformNodeList(e.columns,t),values:this.transformNode(e.values,t),returning:this.transformNode(e.returning,t),onConflict:this.transformNode(e.onConflict,t),onDuplicateKey:this.transformNode(e.onDuplicateKey,t),endModifiers:this.transformNodeList(e.endModifiers,t),with:this.transformNode(e.with,t),orAction:this.transformNode(e.orAction,t),replace:e.replace,explain:this.transformNode(e.explain,t),defaultValues:e.defaultValues,top:this.transformNode(e.top,t),output:this.transformNode(e.output,t)}}transformValues(e,t){return{kind:`ValuesNode`,values:this.transformNodeList(e.values,t)}}transformDeleteQuery(e,t){return{kind:`DeleteQueryNode`,from:this.transformNode(e.from,t),using:this.transformNode(e.using,t),joins:this.transformNodeList(e.joins,t),where:this.transformNode(e.where,t),returning:this.transformNode(e.returning,t),endModifiers:this.transformNodeList(e.endModifiers,t),with:this.transformNode(e.with,t),orderBy:this.transformNode(e.orderBy,t),limit:this.transformNode(e.limit,t),explain:this.transformNode(e.explain,t),top:this.transformNode(e.top,t),output:this.transformNode(e.output,t)}}transformReturning(e,t){return{kind:`ReturningNode`,selections:this.transformNodeList(e.selections,t)}}transformCreateTable(e,t){return{kind:`CreateTableNode`,table:this.transformNode(e.table,t),columns:this.transformNodeList(e.columns,t),constraints:this.transformNodeList(e.constraints,t),indexes:this.transformNodeList(e.indexes,t),temporary:e.temporary,ifNotExists:e.ifNotExists,onCommit:e.onCommit,frontModifiers:this.transformNodeList(e.frontModifiers,t),endModifiers:this.transformNodeList(e.endModifiers,t),selectQuery:this.transformNode(e.selectQuery,t)}}transformColumnDefinition(e,t){return{kind:`ColumnDefinitionNode`,column:this.transformNode(e.column,t),dataType:this.transformNode(e.dataType,t),references:this.transformNode(e.references,t),primaryKey:e.primaryKey,autoIncrement:e.autoIncrement,unique:e.unique,notNull:e.notNull,unsigned:e.unsigned,defaultTo:this.transformNode(e.defaultTo,t),check:this.transformNode(e.check,t),generated:this.transformNode(e.generated,t),frontModifiers:this.transformNodeList(e.frontModifiers,t),endModifiers:this.transformNodeList(e.endModifiers,t),nullsNotDistinct:e.nullsNotDistinct,identity:e.identity,ifNotExists:e.ifNotExists}}transformAddColumn(e,t){return{kind:`AddColumnNode`,column:this.transformNode(e.column,t)}}transformDropTable(e,t){return{kind:`DropTableNode`,table:this.transformNode(e.table,t),ifExists:e.ifExists,cascade:e.cascade,temporary:e.temporary}}transformOrderBy(e,t){return{kind:`OrderByNode`,items:this.transformNodeList(e.items,t)}}transformOrderByItem(e,t){return{kind:`OrderByItemNode`,orderBy:this.transformNode(e.orderBy,t),direction:this.transformNode(e.direction,t),collation:this.transformNode(e.collation,t),nulls:e.nulls}}transformGroupBy(e,t){return{kind:`GroupByNode`,items:this.transformNodeList(e.items,t)}}transformGroupByItem(e,t){return{kind:`GroupByItemNode`,groupBy:this.transformNode(e.groupBy,t)}}transformUpdateQuery(e,t){return{kind:`UpdateQueryNode`,table:this.transformNode(e.table,t),from:this.transformNode(e.from,t),joins:this.transformNodeList(e.joins,t),where:this.transformNode(e.where,t),updates:this.transformNodeList(e.updates,t),returning:this.transformNode(e.returning,t),endModifiers:this.transformNodeList(e.endModifiers,t),with:this.transformNode(e.with,t),explain:this.transformNode(e.explain,t),limit:this.transformNode(e.limit,t),top:this.transformNode(e.top,t),output:this.transformNode(e.output,t),orderBy:this.transformNode(e.orderBy,t)}}transformColumnUpdate(e,t){return{kind:`ColumnUpdateNode`,column:this.transformNode(e.column,t),value:this.transformNode(e.value,t)}}transformLimit(e,t){return{kind:`LimitNode`,limit:this.transformNode(e.limit,t)}}transformOffset(e,t){return{kind:`OffsetNode`,offset:this.transformNode(e.offset,t)}}transformOnConflict(e,t){return{kind:`OnConflictNode`,columns:this.transformNodeList(e.columns,t),constraint:this.transformNode(e.constraint,t),indexExpression:this.transformNode(e.indexExpression,t),indexWhere:this.transformNode(e.indexWhere,t),updates:this.transformNodeList(e.updates,t),updateWhere:this.transformNode(e.updateWhere,t),doNothing:e.doNothing}}transformOnDuplicateKey(e,t){return{kind:`OnDuplicateKeyNode`,updates:this.transformNodeList(e.updates,t)}}transformCreateIndex(e,t){return{kind:`CreateIndexNode`,name:this.transformNode(e.name,t),table:this.transformNode(e.table,t),columns:this.transformNodeList(e.columns,t),unique:e.unique,using:this.transformNode(e.using,t),ifNotExists:e.ifNotExists,where:this.transformNode(e.where,t),nullsNotDistinct:e.nullsNotDistinct}}transformList(e,t){return{kind:`ListNode`,items:this.transformNodeList(e.items,t)}}transformDropIndex(e,t){return{kind:`DropIndexNode`,name:this.transformNode(e.name,t),table:this.transformNode(e.table,t),ifExists:e.ifExists,cascade:e.cascade}}transformPrimaryKeyConstraint(e,t){return{kind:`PrimaryKeyConstraintNode`,columns:this.transformNodeList(e.columns,t),name:this.transformNode(e.name,t),deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformUniqueConstraint(e,t){return{kind:`UniqueConstraintNode`,columns:this.transformNodeList(e.columns,t),name:this.transformNode(e.name,t),nullsNotDistinct:e.nullsNotDistinct,deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformForeignKeyConstraint(e,t){return{kind:`ForeignKeyConstraintNode`,columns:this.transformNodeList(e.columns,t),references:this.transformNode(e.references,t),name:this.transformNode(e.name,t),onDelete:e.onDelete,onUpdate:e.onUpdate,deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformSetOperation(e,t){return{kind:`SetOperationNode`,operator:e.operator,expression:this.transformNode(e.expression,t),all:e.all}}transformReferences(e,t){return{kind:`ReferencesNode`,table:this.transformNode(e.table,t),columns:this.transformNodeList(e.columns,t),onDelete:e.onDelete,onUpdate:e.onUpdate}}transformCheckConstraint(e,t){return{kind:`CheckConstraintNode`,expression:this.transformNode(e.expression,t),name:this.transformNode(e.name,t)}}transformWith(e,t){return{kind:`WithNode`,expressions:this.transformNodeList(e.expressions,t),recursive:e.recursive}}transformCommonTableExpression(e,t){return{kind:`CommonTableExpressionNode`,name:this.transformNode(e.name,t),materialized:e.materialized,expression:this.transformNode(e.expression,t)}}transformCommonTableExpressionName(e,t){return{kind:`CommonTableExpressionNameNode`,table:this.transformNode(e.table,t),columns:this.transformNodeList(e.columns,t)}}transformHaving(e,t){return{kind:`HavingNode`,having:this.transformNode(e.having,t)}}transformCreateSchema(e,t){return{kind:`CreateSchemaNode`,schema:this.transformNode(e.schema,t),ifNotExists:e.ifNotExists}}transformDropSchema(e,t){return{kind:`DropSchemaNode`,schema:this.transformNode(e.schema,t),ifExists:e.ifExists,cascade:e.cascade}}transformAlterTable(e,t){return{kind:`AlterTableNode`,table:this.transformNode(e.table,t),renameTo:this.transformNode(e.renameTo,t),setSchema:this.transformNode(e.setSchema,t),columnAlterations:this.transformNodeList(e.columnAlterations,t),addConstraint:this.transformNode(e.addConstraint,t),dropConstraint:this.transformNode(e.dropConstraint,t),renameConstraint:this.transformNode(e.renameConstraint,t),addIndex:this.transformNode(e.addIndex,t),dropIndex:this.transformNode(e.dropIndex,t)}}transformDropColumn(e,t){return{kind:`DropColumnNode`,column:this.transformNode(e.column,t),ifExists:e.ifExists}}transformRenameColumn(e,t){return{kind:`RenameColumnNode`,column:this.transformNode(e.column,t),renameTo:this.transformNode(e.renameTo,t)}}transformAlterColumn(e,t){return{kind:`AlterColumnNode`,column:this.transformNode(e.column,t),dataType:this.transformNode(e.dataType,t),dataTypeExpression:this.transformNode(e.dataTypeExpression,t),setDefault:this.transformNode(e.setDefault,t),dropDefault:e.dropDefault,setNotNull:e.setNotNull,dropNotNull:e.dropNotNull}}transformModifyColumn(e,t){return{kind:`ModifyColumnNode`,column:this.transformNode(e.column,t)}}transformAddConstraint(e,t){return{kind:`AddConstraintNode`,constraint:this.transformNode(e.constraint,t)}}transformDropConstraint(e,t){return{kind:`DropConstraintNode`,constraintName:this.transformNode(e.constraintName,t),ifExists:e.ifExists,modifier:e.modifier}}transformRenameConstraint(e,t){return{kind:`RenameConstraintNode`,oldName:this.transformNode(e.oldName,t),newName:this.transformNode(e.newName,t)}}transformCreateView(e,t){return{kind:`CreateViewNode`,name:this.transformNode(e.name,t),temporary:e.temporary,orReplace:e.orReplace,ifNotExists:e.ifNotExists,materialized:e.materialized,columns:this.transformNodeList(e.columns,t),as:this.transformNode(e.as,t)}}transformRefreshMaterializedView(e,t){return{kind:`RefreshMaterializedViewNode`,name:this.transformNode(e.name,t),concurrently:e.concurrently,withNoData:e.withNoData}}transformDropView(e,t){return{kind:`DropViewNode`,name:this.transformNode(e.name,t),ifExists:e.ifExists,materialized:e.materialized,cascade:e.cascade}}transformGenerated(e,t){return{kind:`GeneratedNode`,byDefault:e.byDefault,always:e.always,identity:e.identity,stored:e.stored,expression:this.transformNode(e.expression,t)}}transformDefaultValue(e,t){return{kind:`DefaultValueNode`,defaultValue:this.transformNode(e.defaultValue,t)}}transformOn(e,t){return{kind:`OnNode`,on:this.transformNode(e.on,t)}}transformSelectModifier(e,t){return{kind:`SelectModifierNode`,modifier:e.modifier,rawModifier:this.transformNode(e.rawModifier,t),of:this.transformNodeList(e.of,t)}}transformCreateType(e,t){return{kind:`CreateTypeNode`,name:this.transformNode(e.name,t),enum:this.transformNode(e.enum,t)}}transformDropType(e,t){return{kind:`DropTypeNode`,name:this.transformNode(e.name,t),additionalNames:this.transformNodeList(e.additionalNames,t),cascade:e.cascade,ifExists:e.ifExists}}transformExplain(e,t){return{kind:`ExplainNode`,format:e.format,options:this.transformNode(e.options,t)}}transformSchemableIdentifier(e,t){return{kind:`SchemableIdentifierNode`,schema:this.transformNode(e.schema,t),identifier:this.transformNode(e.identifier,t)}}transformAggregateFunction(e,t){return{kind:`AggregateFunctionNode`,func:e.func,aggregated:this.transformNodeList(e.aggregated,t),distinct:e.distinct,orderBy:this.transformNode(e.orderBy,t),withinGroup:this.transformNode(e.withinGroup,t),filter:this.transformNode(e.filter,t),over:this.transformNode(e.over,t)}}transformOver(e,t){return{kind:`OverNode`,orderBy:this.transformNode(e.orderBy,t),partitionBy:this.transformNode(e.partitionBy,t)}}transformPartitionBy(e,t){return{kind:`PartitionByNode`,items:this.transformNodeList(e.items,t)}}transformPartitionByItem(e,t){return{kind:`PartitionByItemNode`,partitionBy:this.transformNode(e.partitionBy,t)}}transformBinaryOperation(e,t){return{kind:`BinaryOperationNode`,leftOperand:this.transformNode(e.leftOperand,t),operator:this.transformNode(e.operator,t),rightOperand:this.transformNode(e.rightOperand,t)}}transformUnaryOperation(e,t){return{kind:`UnaryOperationNode`,operator:this.transformNode(e.operator,t),operand:this.transformNode(e.operand,t)}}transformUsing(e,t){return{kind:`UsingNode`,tables:this.transformNodeList(e.tables,t)}}transformFunction(e,t){return{kind:`FunctionNode`,func:e.func,arguments:this.transformNodeList(e.arguments,t)}}transformCase(e,t){return{kind:`CaseNode`,value:this.transformNode(e.value,t),when:this.transformNodeList(e.when,t),else:this.transformNode(e.else,t),isStatement:e.isStatement}}transformWhen(e,t){return{kind:`WhenNode`,condition:this.transformNode(e.condition,t),result:this.transformNode(e.result,t)}}transformJSONReference(e,t){return{kind:`JSONReferenceNode`,reference:this.transformNode(e.reference,t),traversal:this.transformNode(e.traversal,t)}}transformJSONPath(e,t){return{kind:`JSONPathNode`,inOperator:this.transformNode(e.inOperator,t),pathLegs:this.transformNodeList(e.pathLegs,t)}}transformJSONPathLeg(e,t){return{kind:`JSONPathLegNode`,type:e.type,value:e.value}}transformJSONOperatorChain(e,t){return{kind:`JSONOperatorChainNode`,operator:this.transformNode(e.operator,t),values:this.transformNodeList(e.values,t)}}transformTuple(e,t){return{kind:`TupleNode`,values:this.transformNodeList(e.values,t)}}transformMergeQuery(e,t){return{kind:`MergeQueryNode`,into:this.transformNode(e.into,t),using:this.transformNode(e.using,t),whens:this.transformNodeList(e.whens,t),with:this.transformNode(e.with,t),top:this.transformNode(e.top,t),endModifiers:this.transformNodeList(e.endModifiers,t),output:this.transformNode(e.output,t),returning:this.transformNode(e.returning,t)}}transformMatched(e,t){return{kind:`MatchedNode`,not:e.not,bySource:e.bySource}}transformAddIndex(e,t){return{kind:`AddIndexNode`,name:this.transformNode(e.name,t),columns:this.transformNodeList(e.columns,t),unique:e.unique,using:this.transformNode(e.using,t),ifNotExists:e.ifNotExists}}transformCast(e,t){return{kind:`CastNode`,expression:this.transformNode(e.expression,t),dataType:this.transformNode(e.dataType,t)}}transformFetch(e,t){return{kind:`FetchNode`,rowCount:this.transformNode(e.rowCount,t),modifier:e.modifier}}transformTop(e,t){return{kind:`TopNode`,expression:e.expression,modifiers:e.modifiers}}transformOutput(e,t){return{kind:`OutputNode`,selections:this.transformNodeList(e.selections,t)}}transformAlterType(e,t){return{kind:`AlterTypeNode`,name:this.transformNode(e.name,t),addValue:this.transformNode(e.addValue,t),renameTo:this.transformNode(e.renameTo,t),renameValue:this.transformNode(e.renameValue,t),setSchema:this.transformNode(e.setSchema,t)}}transformAddValue(e,t){return{kind:`AddValueNode`,value:this.transformNode(e.value,t),ifNotExists:e.ifNotExists,isBefore:e.isBefore,neighborValue:this.transformNode(e.neighborValue,t)}}transformRenameValue(e,t){return{kind:`RenameValueNode`,oldValue:this.transformNode(e.oldValue,t),newValue:this.transformNode(e.newValue,t)}}transformDataType(e,t){return e}transformSelectAll(e,t){return e}transformIdentifier(e,t){return e}transformValue(e,t){return e}transformPrimitiveValueList(e,t){return e}transformOperator(e,t){return e}transformDefaultInsertValue(e,t){return e}transformOrAction(e,t){return e}transformCollate(e,t){return e}};function xa(e){return fa(e)&&da(e.kind)}var Sa={AlterTableNode:!0,AlterTypeNode:!0,CreateIndexNode:!0,CreateSchemaNode:!0,CreateTableNode:!0,CreateTypeNode:!0,CreateViewNode:!0,DeleteQueryNode:!0,DropIndexNode:!0,DropSchemaNode:!0,DropTableNode:!0,DropTypeNode:!0,RefreshMaterializedViewNode:!0,DropViewNode:!0,InsertQueryNode:!0,RawNode:!0,SelectQueryNode:!0,UpdateQueryNode:!0,MergeQueryNode:!0};function Ca(e){return xa(e)&&Sa[e.kind]===!0}var U=B({is(e){return e.kind===`SchemableIdentifierNode`},create(e){return B({kind:`SchemableIdentifierNode`,identifier:V.create(e)})},createWithSchema(e,t){return B({kind:`SchemableIdentifierNode`,schema:V.create(e),identifier:V.create(t)})}}),W=B({is(e){return e.kind===`TableNode`},create(e){return B({kind:`TableNode`,table:U.create(e)})},createWithSchema(e,t){return B({kind:`TableNode`,table:U.createWithSchema(e,t)})}}),wa=B({is(e){return e.kind===`UsingNode`},create(e){return B({kind:`UsingNode`,tables:B(e)})},cloneWithTables(e,t){return B({...e,tables:B([...e.tables,...t])})}}),Ta=B({json_agg:!0,to_json:!0}),Ea=class extends ba{#e;#t=new Set;#n=new Set;constructor(e){super(),this.#e=e}transformNodeImpl(e,t){if(!Ca(e))return super.transformNodeImpl(e,t);let n=this.#a(e);for(let e of n)this.#n.add(e);let r=this.#i(e);for(let e of r)this.#t.add(e);let i=super.transformNodeImpl(e,t);for(let e of r)this.#t.delete(e);for(let e of n)this.#n.delete(e);return i}transformSchemableIdentifier(e,t){let n=super.transformSchemableIdentifier(e,t);return n.schema||!this.#t.has(e.identifier.name)?n:{...n,schema:V.create(this.#e)}}transformReferences(e,t){let n=super.transformReferences(e,t);return n.table.table.schema?n:{...n,table:W.createWithSchema(this.#e,n.table.table.identifier.name)}}transformAggregateFunction(e,t){return{...super.transformAggregateFunction({...e,aggregated:[]},t),aggregated:this.#r(e,t,`aggregated`)}}transformFunction(e,t){return{...super.transformFunction({...e,arguments:[]},t),arguments:this.#r(e,t,`arguments`)}}transformSelectModifier(e,t){return{...super.transformSelectModifier({...e,of:void 0},t),of:e.of?.map(e=>W.is(e)&&!e.table.schema?{...e,table:this.transformIdentifier(e.table.identifier,t)}:this.transformNode(e,t))}}#r(e,t,n){return Ta[e.func]?e[n].map(e=>!W.is(e)||e.table.schema?this.transformNode(e,t):{...e,table:this.transformIdentifier(e.table.identifier,t)}):this.transformNodeList(e[n],t)}#i(e){let t=new Set;if(`name`in e&&e.name&&U.is(e.name)&&this.#s(e.name,t),`from`in e&&e.from)for(let n of e.from.froms)this.#o(n,t);if(`into`in e&&e.into&&this.#o(e.into,t),`table`in e&&e.table&&this.#o(e.table,t),`joins`in e&&e.joins)for(let n of e.joins)this.#o(n.table,t);return`using`in e&&e.using&&(va.is(e.using)?this.#o(e.using.table,t):this.#o(e.using,t)),t}#a(e){let t=new Set;return`with`in e&&e.with&&this.#c(e.with,t),t}#o(e,t){if(W.is(e))return this.#s(e.table,t);if(ha.is(e)&&W.is(e.node))return this.#s(e.node.table,t);if(ya.is(e)){for(let n of e.items)this.#o(n,t);return}if(wa.is(e)){for(let n of e.tables)this.#o(n,t);return}}#s(e,t){let n=e.identifier.name;!this.#t.has(n)&&!this.#n.has(n)&&t.add(n)}#c(e,t){for(let n of e.expressions){let e=n.name.table.table.identifier.name;this.#n.has(e)||t.add(e)}}},Da=class{#e;constructor(e){this.#e=new Ea(e)}transformQuery(e){return this.#e.transformNode(e.node,e.queryId)}async transformResult(e){return e.result}},G=`migration_lock`;B({__noMigrations__:!0});var Oa=class{#e;constructor(e){this.#e=B(e)}async getMigrations(){let e=await this.#f(this.#r)?await this.#e.db.withPlugin(this.#o).selectFrom(this.#r).select([`name`,`timestamp`]).$narrowType().execute():[];return(await this.#_()).map(({name:t,...n})=>{let r=e.find(e=>e.name===t);return{name:t,migration:n,executedAt:r?new Date(r.timestamp):void 0}})}async migrateToLatest(e){return this.#t(()=>({direction:`Up`,step:1/0}),e)}async migrateTo(e,t){return this.#t(({migrations:t,executedMigrations:n,pendingMigrations:r})=>{if(fa(e)&&e.__noMigrations__===!0)return{direction:`Down`,step:1/0};if(!t.find(t=>t.name===e))throw Error(`migration "${e}" doesn't exist`);let i=n.indexOf(e),a=r.findIndex(t=>t.name===e);if(i!==-1)return{direction:`Down`,step:n.length-i-1};if(a!==-1)return{direction:`Up`,step:a+1};throw Error(`migration "${e}" isn't executed or pending`)},t)}async migrateUp(e){return this.#t(()=>({direction:`Up`,step:1}),e)}async migrateDown(e){return this.#t(()=>({direction:`Down`,step:1}),e)}async#t(e,t){try{return await this.#s(),await this.#c(),await this.#l(),await this.#u(),await this.#m(e,t)}catch(e){return e instanceof K?e.resultSet:{error:e}}}get#n(){return this.#e.migrationTableSchema}get#r(){return this.#e.migrationTableName??`kysely_migration`}get#i(){return this.#e.migrationLockTableName??`kysely_migration_lock`}get#a(){return this.#e.allowUnorderedMigrations??!1}get#o(){return this.#n?new Da(this.#n):new ma}async#s(){if(this.#n&&!await this.#d())try{await this.#C(this.#e.db.schema.createSchema(this.#n))}catch(e){if(!await this.#d())throw e}}async#c(){if(!await this.#f(this.#r))try{await this.#C(this.#e.db.schema.withPlugin(this.#o).createTable(this.#r).addColumn(`name`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`timestamp`,`varchar(255)`,e=>e.notNull()))}catch(e){if(!await this.#f(this.#r))throw e}}async#l(){if(!await this.#f(this.#i))try{await this.#C(this.#e.db.schema.withPlugin(this.#o).createTable(this.#i).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`is_locked`,`integer`,e=>e.notNull().defaultTo(0)))}catch(e){if(!await this.#f(this.#i))throw e}}async#u(){if(!await this.#p())try{await this.#e.db.withPlugin(this.#o).insertInto(this.#i).values({id:G,is_locked:0}).execute()}catch(e){if(!await this.#p())throw e}}async#d(){return(await this.#e.db.introspection.getSchemas()).some(e=>e.name===this.#n)}async#f(e){let t=this.#n;return(await this.#e.db.introspection.getTables({withInternalKyselyTables:!0})).some(n=>n.name===e&&(!t||n.schema===t))}async#p(){return!!await this.#e.db.withPlugin(this.#o).selectFrom(this.#i).where(`id`,`=`,G).select(`id`).executeTakeFirst()}async#m(e,t){let n=this.#e.db.getExecutor().adapter,r=B({lockTable:this.#e.migrationLockTableName??`kysely_migration_lock`,lockRowId:G,lockTableSchema:this.#e.migrationTableSchema}),i=async t=>{try{await n.acquireMigrationLock(t,r);let i=await this.#h(t);if(i.migrations.length===0)return{results:[]};let{direction:a,step:o}=e(i);return o<=0?{results:[]}:a===`Down`?await this.#x(t,i,o):a===`Up`?await this.#S(t,i,o):{results:[]}}finally{await n.releaseMigrationLock(t,r)}},a=t?.disableTransactions??this.#e.disableTransactions;if(this.#e.db.isTransaction){if(!n.supportsTransactionalDdl)throw Error(`Transactional DDL is not supported in this dialect. Passing a transaction to this migrator would result in failure or unexpected behavior.`);if(a)throw Error("`disableTransactions` is true but the migrator was given a transaction. Passing a transaction to this migrator would result in failure or unexpected behavior.");return i(this.#e.db)}return n.supportsTransactionalDdl&&!a?this.#e.db.transaction().execute(i):this.#e.db.connection().execute(i)}async#h(e){let t=await this.#_(),n=await this.#v(e);this.#y(t,n),this.#a||this.#b(t,n);let r=this.#g(t,n);return B({migrations:t,executedMigrations:n,lastMigration:pa(n),pendingMigrations:r})}#g(e,t){return e.filter(e=>!t.includes(e.name))}async#_(){let e=await this.#e.provider.getMigrations();return Object.keys(e).sort().map(t=>({...e[t],name:t}))}async#v(e){let t=await e.withPlugin(this.#o).selectFrom(this.#r).select([`name`,`timestamp`]).$narrowType().execute(),n=this.#e.nameComparator||((e,t)=>e.localeCompare(t));return t.sort((e,t)=>e.timestamp===t.timestamp?n(e.name,t.name):new Date(e.timestamp).getTime()-new Date(t.timestamp).getTime()).map(e=>e.name)}#y(e,t){for(let n of t)if(!e.some(e=>e.name===n))throw Error(`corrupted migrations: previously executed migration ${n} is missing`)}#b(e,t){for(let n=0;n<t.length;++n)if(e[n].name!==t[n])throw Error(`corrupted migrations: expected previously executed migration ${t[n]} to be at index ${n} but ${e[n].name} was found in its place. New migrations must always have a name that comes alphabetically after the last executed migration.`)}async#x(e,t,n){let r=t.executedMigrations.toReversed().slice(0,n).map(e=>t.migrations.find(t=>t.name===e)),i=r.map(e=>({migrationName:e.name,direction:`Down`,status:`NotExecuted`}));for(let t=0;t<i.length;++t){let n=r[t];try{n.down&&(await n.down(e),await e.withPlugin(this.#o).deleteFrom(this.#r).where(`name`,`=`,n.name).execute(),i[t]={migrationName:n.name,direction:`Down`,status:`Success`})}catch(e){throw i[t]={migrationName:n.name,direction:`Down`,status:`Error`},new K({error:e,results:i})}}return{results:i}}async#S(e,t,n){let r=t.pendingMigrations.slice(0,n).map(e=>({migrationName:e.name,direction:`Up`,status:`NotExecuted`}));for(let n=0;n<r.length;n++){let i=t.pendingMigrations[n];try{await i.up(e),await e.withPlugin(this.#o).insertInto(this.#r).values({name:i.name,timestamp:new Date().toISOString()}).execute(),r[n]={migrationName:i.name,direction:`Up`,status:`Success`}}catch(e){throw r[n]={migrationName:i.name,direction:`Up`,status:`Error`},new K({error:e,results:r})}}return{results:r}}async#C(e){this.#e.db.getExecutor().adapter.supportsCreateIfNotExists&&(e=e.ifNotExists()),await e.execute()}},K=class extends Error{#e;constructor(e){super(),this.#e=e}get resultSet(){return this.#e}},ka=class{migrations;constructor(e){this.migrations=e}async getMigrations(){return this.migrations}},Aa=t({down:()=>Ma,up:()=>ja});async function ja(e){await e.schema.createTable(`tenants`).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`name`,`varchar(255)`).addColumn(`audience`,`varchar(255)`).addColumn(`sender_email`,`varchar(255)`).addColumn(`sender_name`,`varchar(255)`).addColumn(`language`,`varchar(255)`).addColumn(`logo`,`varchar(255)`).addColumn(`primary_color`,`varchar(255)`).addColumn(`secondary_color`,`varchar(255)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`users`).addColumn(`user_id`,`varchar(255)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`email`,`varchar(255)`).addColumn(`given_name`,`varchar(255)`).addColumn(`family_name`,`varchar(255)`).addColumn(`nickname`,`varchar(255)`).addColumn(`name`,`varchar(255)`).addColumn(`picture`,`varchar(2083)`).addColumn(`tags`,`varchar(255)`).addColumn(`phone_number`,`varchar(17)`).addColumn(`phone_verified`,`boolean`).addColumn(`username`,`varchar(128)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).addPrimaryKeyConstraint(`users_tenants`,[`user_id`,`tenant_id`]).addColumn(`linked_to`,`varchar(255)`).addForeignKeyConstraint(`linked_to_constraint`,[`linked_to`,`tenant_id`],`users`,[`user_id`,`tenant_id`]).addColumn(`last_ip`,`varchar(255)`).addColumn(`login_count`,`integer`,e=>e.notNull()).addColumn(`last_login`,`varchar(255)`).addColumn(`provider`,`varchar(255)`,e=>e.notNull()).addColumn(`connection`,`varchar(255)`).addColumn(`email_verified`,`boolean`,e=>e.notNull()).addColumn(`is_social`,`boolean`,e=>e.notNull()).addColumn(`app_metadata`,`varchar(4096)`,e=>e.defaultTo(`{}`).notNull()).addColumn(`user_metadata`,`varchar(4096)`,e=>e.defaultTo(`{}`).notNull()).addUniqueConstraint(`unique_email_provider`,[`email`,`provider`,`tenant_id`]).addUniqueConstraint(`unique_phone_provider`,[`phone_number`,`provider`,`tenant_id`]).execute(),await e.schema.createTable(`members`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`sub`,`varchar(255)`).addColumn(`email`,`varchar(255)`).addColumn(`name`,`varchar(255)`).addColumn(`status`,`varchar(255)`).addColumn(`role`,`varchar(255)`).addColumn(`picture`,`varchar(2083)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`applications`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`client_secret`,`varchar(255)`).addColumn(`allowed_logout_urls`,`varchar(255)`).addColumn(`authentication_settings`,`varchar(255)`).addColumn(`addons`,`varchar(4096)`,e=>e.notNull().defaultTo(`{}`)).addColumn(`callbacks`,`varchar(1024)`,e=>e.notNull().defaultTo(`[]`)).addColumn(`allowed_origins`,`varchar(1024)`,e=>e.notNull().defaultTo(`[]`)).addColumn(`web_origins`,`varchar(1024)`,e=>e.notNull().defaultTo(`[]`)).addColumn(`allowed_clients`,`varchar(1024)`,e=>e.defaultTo(`[]`).notNull()).addColumn(`options_kid`,`varchar(32)`).addColumn(`options_team_id`,`varchar(32)`).addColumn(`options_client_id`,`varchar(128)`).addColumn(`options_client_secret`,`varchar(255)`).addColumn(`options_scope`,`varchar(255)`).addColumn(`options_realms`,`varchar(255)`).addColumn(`options_app_secret`,`varchar(1024)`).addColumn(`email_validation`,`varchar(255)`).addColumn(`disable_sign_ups`,`boolean`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`connections`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`response_type`,`varchar(255)`).addColumn(`response_mode`,`varchar(255)`).addColumn(`strategy`,`varchar(64)`).addColumn(`options`,`varchar(2048)`,e=>e.defaultTo(`{}`).notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`migrations`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`provider`,`varchar(255)`).addColumn(`client_id`,`varchar(255)`).addColumn(`origin`,`varchar(255)`).addColumn(`domain`,`varchar(255)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createTable(`domains`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`domain`,`varchar(255)`,e=>e.notNull()).addColumn(`email_service`,`varchar(255)`).addColumn(`email_api_key`,`varchar(255)`).addColumn(`dkim_private_key`,`varchar(2048)`).addColumn(`dkim_public_key`,`varchar(2048)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute()}async function Ma(e){await e.schema.dropTable(`domains`).execute(),await e.schema.dropTable(`members`).execute(),await e.schema.dropTable(`users`).execute(),await e.schema.dropTable(`connections`).execute(),await e.schema.dropTable(`applications`).execute(),await e.schema.dropTable(`migrations`).execute(),await e.schema.dropTable(`tenants`).execute()}var Na=t({down:()=>Fa,up:()=>Pa});async function Pa(e){await e.schema.alterTable(`tenants`).addColumn(`support_url`,`varchar(255)`).execute()}async function Fa(e){await e.schema.alterTable(`tenants`).dropColumn(`support_url`).execute()}var Ia=t({down:()=>Ra,up:()=>La});async function La(e){}async function Ra(e){}var za=t({down:()=>Va,up:()=>Ba});async function Ba(e){await e.schema.createTable(`logs`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`category`,`varchar(255)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(64)`).addColumn(`user_id`,`varchar(64)`).addForeignKeyConstraint(`tenant_id_constraint`,[`tenant_id`],`tenants`,[`id`],e=>e.onDelete(`cascade`)).addColumn(`ip`,`varchar(255)`).addColumn(`type`,`varchar(8)`,e=>e.notNull()).addColumn(`date`,`varchar(25)`,e=>e.notNull()).addColumn(`client_id`,`varchar(255)`).addColumn(`client_name`,`varchar(255)`).addColumn(`user_agent`,`varchar(255)`).addColumn(`description`,`varchar(255)`).addColumn(`details`,`varchar(2048)`).execute()}async function Va(e){await e.schema.dropTable(`logs`).execute()}var Ha=t({down:()=>Wa,up:()=>Ua});async function Ua(e){}async function Wa(e){}var Ga=t({down:()=>qa,up:()=>Ka});async function Ka(e){await e.schema.createTable(`sessions`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`authenticated_at`,`varchar(35)`).addColumn(`last_interaction_at`,`varchar(35)`).addColumn(`used_at`,`varchar(35)`).addColumn(`revoked_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`clients`,`varchar(1024)`,e=>e.notNull()).execute(),await e.schema.createTable(`tickets`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`email`,`varchar(255)`,e=>e.notNull()).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(1024)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute(),await e.schema.createTable(`otps`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`code`,`varchar(255)`,e=>e.notNull()).addColumn(`email`,`varchar(255)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`send`,`varchar(255)`).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(1024)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute(),await e.schema.createIndex(`otps_email_index`).on(`otps`).column(`email`).execute(),await e.schema.createIndex(`otps_expires_at_index`).on(`otps`).column(`expires_at`).execute()}async function qa(e){await e.schema.dropTable(`sessions`).execute(),await e.schema.dropTable(`tickets`).execute(),await e.schema.dropTable(`otps`).execute()}var Ja=t({down:()=>Xa,up:()=>Ya});async function Ya(e){await e.schema.createTable(`passwords`).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addPrimaryKeyConstraint(`passwords_pkey`,[`user_id`,`tenant_id`]).addForeignKeyConstraint(`user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(255)`).addColumn(`updated_at`,`varchar(255)`).execute(),await e.schema.createTable(`codes`).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`user_id`,`varchar(255)`).addColumn(`tenant_id`,`varchar(255)`).addForeignKeyConstraint(`user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute(),await e.schema.createIndex(`codes_expires_at_index`).on(`codes`).column(`expires_at`).execute()}async function Xa(e){await e.schema.dropTable(`passwords`).execute(),await e.schema.dropTable(`codes`).execute()}var Za=t({down:()=>$a,up:()=>Qa});async function Qa(e){}async function $a(e){}var eo=t({down:()=>no,up:()=>to});async function to(e){await e.schema.alterTable(`passwords`).addColumn(`password`,`varchar(255)`,e=>e.notNull()).execute()}async function no(e){await e.schema.alterTable(`passwords`).dropColumn(`password`).execute()}var ro=t({down:()=>ao,up:()=>io});async function io(e){}async function ao(e){}var oo=t({down:()=>co,up:()=>so});async function so(e){}async function co(e){}var lo=t({down:()=>fo,up:()=>uo});async function uo(e){}async function fo(e){}var po=t({down:()=>ho,up:()=>mo});async function mo(e){await e.schema.createIndex(`users_email_index`).on(`users`).column(`email`).execute()}async function ho(e){await e.schema.dropIndex(`users_email_index`).execute()}var go=t({down:()=>vo,up:()=>_o});async function _o(e){await e.schema.alterTable(`users`).addColumn(`profileData`,`varchar(2048)`).execute()}async function vo(e){await e.schema.alterTable(`users`).dropColumn(`profileData`).execute()}var yo=t({down:()=>xo,up:()=>bo});async function bo(e){await e.schema.createIndex(`users_linked_to_index`).on(`users`).column(`linked_to`).execute()}async function xo(e){await e.schema.dropIndex(`users_linked_to_index`)}var So=t({down:()=>wo,up:()=>Co});async function Co(e){await e.schema.alterTable(`users`).addColumn(`locale`,`varchar(255)`).execute()}async function wo(e){await e.schema.alterTable(`users`).dropColumn(`locale`).execute()}var To=t({down:()=>Do,up:()=>Eo});async function Eo(e){await e.schema.createTable(`keys`).addColumn(`kid`,`varchar(255)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`)).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`revoked_at`,`varchar(255)`).addColumn(`cert`,`varchar(4096)`).addColumn(`pkcs7`,`varchar(4096)`).addColumn(`fingerprint`,`varchar(256)`).addColumn(`thumbprint`,`varchar(256)`).addColumn(`current_since`,`varchar(256)`).addColumn(`current_until`,`varchar(256)`).addColumn(`type`,`varchar(50)`,e=>e.notNull().defaultTo(`jwt_signing`)).addColumn(`connection`,`varchar(255)`,e=>e.references(`connections.id`).onDelete(`cascade`)).execute()}async function Do(e){await e.schema.dropTable(`keys`).execute()}var Oo=t({down:()=>Ao,up:()=>ko});async function ko(e){}async function Ao(e){}var jo=t({down:()=>No,up:()=>Mo});async function Mo(e){}async function No(e){}var Po=t({down:()=>Io,up:()=>Fo});async function Fo(e){await e.schema.alterTable(`otps`).addColumn(`audience`,`varchar(255)`).execute()}async function Io(e){await e.schema.alterTable(`otps`).dropColumn(`audience`).execute()}var Lo=t({down:()=>zo,up:()=>Ro});async function Ro(e){}async function zo(e){}var Bo=t({down:()=>Ho,up:()=>Vo});async function Vo(e){await e.schema.alterTable(`logs`).dropColumn(`category`).execute()}async function Ho(e){await e.schema.alterTable(`logs`).addColumn(`category`,`varchar(255)`,e=>e.notNull()).execute()}var Uo=t({down:()=>Go,up:()=>Wo});async function Wo(e){await e.schema.alterTable(`users`).dropColumn(`tags`).execute()}async function Go(e){await e.schema.alterTable(`users`).addColumn(`tags`,`varchar(255)`).execute()}var Ko=t({down:()=>Jo,up:()=>qo});async function qo(e){await e.schema.createIndex(`logs_user_id`).on(`logs`).column(`user_id`).execute(),await e.schema.createIndex(`logs_tenant_id`).on(`logs`).column(`tenant_id`).execute(),await e.schema.createIndex(`logs_date`).on(`logs`).column(`date`).execute()}async function Jo(e){await e.schema.dropIndex(`logs_user_id`),await e.schema.dropIndex(`logs_tenant_id`),await e.schema.dropIndex(`logs_date`)}var Yo=t({down:()=>Zo,up:()=>Xo});async function Xo(e){await e.schema.alterTable(`logs`).dropColumn(`details`).execute(),await e.schema.alterTable(`logs`).addColumn(`details`,`varchar(8192)`).execute()}async function Zo(e){await e.schema.alterTable(`logs`).dropColumn(`details`).execute(),await e.schema.alterTable(`logs`).addColumn(`details`,`varchar(2048)`).execute()}var Qo=t({down:()=>es,up:()=>$o});async function $o(e){await e.schema.alterTable(`logs`).addColumn(`user_name`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`auth0_client`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`isMobile`,`boolean`).execute(),await e.schema.alterTable(`logs`).addColumn(`connection`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`connection_id`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`audience`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`scope`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`strategy`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`strategy_type`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`hostname`,`varchar(255)`).execute(),await e.schema.alterTable(`logs`).addColumn(`session_connection`,`varchar(255)`).execute()}async function es(e){await e.schema.alterTable(`logs`).dropColumn(`user_name`).execute(),await e.schema.alterTable(`logs`).dropColumn(`auth0_client`).execute(),await e.schema.alterTable(`logs`).dropColumn(`isMobile`).execute(),await e.schema.alterTable(`logs`).dropColumn(`connection`).execute(),await e.schema.alterTable(`logs`).dropColumn(`connection_id`).execute(),await e.schema.alterTable(`logs`).dropColumn(`audience`).execute(),await e.schema.alterTable(`logs`).dropColumn(`scope`).execute(),await e.schema.alterTable(`logs`).dropColumn(`strategy`).execute(),await e.schema.alterTable(`logs`).dropColumn(`strategy_type`).execute(),await e.schema.alterTable(`logs`).dropColumn(`hostname`).execute(),await e.schema.alterTable(`logs`).dropColumn(`session_connection`).execute()}var ts=t({down:()=>rs,up:()=>ns});async function ns(e){await e.schema.createIndex(`users_name_index`).on(`users`).column(`name`).execute()}async function rs(e){await e.schema.dropIndex(`users_name_index`).execute()}var is=t({down:()=>os,up:()=>as});async function as(e){}async function os(e){await e.schema.alterTable(`users`).dropConstraint(`unique_email_provider`).execute()}var ss=t({down:()=>ls,up:()=>cs});async function cs(e){await e.schema.alterTable(`otps`).dropColumn(`state`).execute(),await e.schema.alterTable(`otps`).addColumn(`state`,`varchar(8192)`).execute()}async function ls(e){await e.schema.alterTable(`otps`).dropColumn(`state`).execute(),await e.schema.alterTable(`otps`).addColumn(`state`,`varchar(1024)`).execute()}var us=t({down:()=>fs,up:()=>ds});async function ds(e){await e.schema.alterTable(`tickets`).dropColumn(`state`).execute(),await e.schema.alterTable(`tickets`).addColumn(`state`,`varchar(8192)`).execute()}async function fs(e){await e.schema.alterTable(`tickets`).dropColumn(`state`).execute(),await e.schema.alterTable(`tickets`).addColumn(`state`,`varchar(1024)`).execute()}var ps=t({down:()=>hs,up:()=>ms});async function ms(e){await e.schema.createTable(`branding`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull().primaryKey()).addColumn(`logo_url`,`varchar(512)`).addColumn(`favicon_url`,`varchar(512)`).addColumn(`font_url`,`varchar(512)`).addColumn(`colors_primary`,`varchar(8)`).addColumn(`colors_page_background_type`,`varchar(32)`).addColumn(`colors_page_background_start`,`varchar(8)`).addColumn(`colors_page_background_end`,`varchar(8)`).addColumn(`colors_page_background_angle_dev`,`integer`).execute()}async function hs(e){await e.schema.dropTable(`branding`).execute()}var gs=t({down:()=>vs,up:()=>_s});async function _s(e){}async function vs(e){}var ys=t({down:()=>xs,up:()=>bs});async function bs(e){}async function xs(e){}var Ss=t({down:()=>ws,up:()=>Cs});async function Cs(e){}async function ws(e){}var Ts=t({down:()=>Ds,up:()=>Es});async function Es(e){}async function Ds(e){}var Os=t({down:()=>As,up:()=>ks});async function ks(e){await e.schema.createTable(`authentication_codes`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`code`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`,e=>e.notNull()).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(8192)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}async function As(e){await e.schema.dropTable(`authentication_codes`).execute()}var js=t({down:()=>Ns,up:()=>Ms});async function Ms(e){}async function Ns(e){}var Ps=t({down:()=>Is,up:()=>Fs});async function Fs(e){await e.schema.alterTable(`otps`).addColumn(`ip`,`varchar(64)`).execute()}async function Is(e){await e.schema.alterTable(`otps`).dropColumn(`ip`).execute()}var Ls=t({down:()=>zs,up:()=>Rs});async function Rs(e){await e.schema.alterTable(`logs`).dropColumn(`user_agent`).execute(),await e.schema.alterTable(`logs`).addColumn(`user_agent`,`varchar(1024)`).execute()}async function zs(e){await e.schema.alterTable(`logs`).dropColumn(`user_agent`).execute(),await e.schema.alterTable(`logs`).addColumn(`user_agent`,`varchar(255)`).execute()}var Bs=t({down:()=>Hs,up:()=>Vs});async function Vs(e){}async function Hs(e){}var Us=t({down:()=>Gs,up:()=>Ws});async function Ws(e){await e.schema.createTable(`hooks`).addColumn(`hook_id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`url`,`varchar(512)`,e=>e.notNull()).addColumn(`trigger_id`,`varchar(255)`,e=>e.notNull()).addColumn(`enabled`,`boolean`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).addColumn(`synchronous`,`boolean`,e=>e.defaultTo(!1).notNull()).addColumn(`priority`,`integer`).execute()}async function Gs(e){await e.schema.dropTable(`hooks`).execute()}var Ks=t({down:()=>Js,up:()=>qs});async function qs(e){}async function Js(e){}var Ys=t({down:()=>Zs,up:()=>Xs});async function Xs(e){}async function Zs(e){}var Qs=t({down:()=>ec,up:()=>$s});async function $s(e){await e.schema.createTable(`logins`).addColumn(`login_id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`authParams_client_id`,`varchar(255)`,e=>e.notNull()).addColumn(`authParams_vendor_id`,`varchar(255)`).addColumn(`authParams_username`,`varchar(255)`).addColumn(`authParams_response_type`,`varchar(255)`).addColumn(`authParams_response_mode`,`varchar(255)`).addColumn(`authParams_audience`,`varchar(255)`).addColumn(`authParams_scope`,`varchar(511)`).addColumn(`authParams_state`,`varchar(511)`).addColumn(`authParams_code_challenge_method`,`varchar(256)`).addColumn(`authParams_code_challenge`,`varchar(256)`).addColumn(`authParams_redirect_uri`,`varchar(256)`).addColumn(`authParams_organization`,`varchar(256)`).addColumn(`authorization_url`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`ip`,`varchar(255)`).addColumn(`useragent`,`varchar(512)`).execute(),await e.schema.alterTable(`passwords`).addColumn(`algorithm`,`varchar(16)`).execute(),await e.schema.dropTable(`codes`).execute(),await e.schema.createTable(`codes`).addColumn(`code_id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`login_id`,`varchar(255)`).addForeignKeyConstraint(`codes_user_id_tenant_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`code_type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}async function ec(e){await e.schema.dropTable(`logins`).execute(),await e.schema.alterTable(`passwords`).dropColumn(`algorithm`).execute(),await e.schema.dropTable(`codes`).execute(),await e.schema.createTable(`codes`).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`code`,`varchar(255)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`tenant_id`,`varchar(255)`).addForeignKeyConstraint(`codes_user_id_tenant_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}var tc=t({down:()=>rc,up:()=>nc});async function nc(e){}async function rc(e){}var ic=t({down:()=>oc,up:()=>ac});async function ac(e){await e.schema.alterTable(`logins`).addColumn(`auth0Client`,`varchar(256)`).execute()}async function oc(e){await e.schema.alterTable(`logins`).dropColumn(`auth0Client`).execute()}var sc=t({down:()=>lc,up:()=>cc});async function cc(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_state`).execute(),await e.schema.alterTable(`logins`).addColumn(`authParams_state`,`varchar(8192)`).execute()}async function lc(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_state`).execute(),await e.schema.alterTable(`logins`).addColumn(`authParams_state`,`varchar(511)`).execute()}var uc=t({down:()=>fc,up:()=>dc});async function dc(e){}async function fc(e){}var pc=t({down:()=>hc,up:()=>mc});async function mc(e){}async function hc(e){}var gc=t({down:()=>vc,up:()=>_c});async function _c(e){await e.schema.alterTable(`logins`).addColumn(`authParams_nonce`,`varchar(255)`).execute()}async function vc(e){await e.schema.alterTable(`logins`).dropColumn(`nonce`).execute()}var yc=t({down:()=>xc,up:()=>bc});async function bc(e){}async function xc(e){}var Sc=t({down:()=>wc,up:()=>Cc});async function Cc(e){}async function wc(e){}var Tc=t({down:()=>Dc,up:()=>Ec});async function Ec(e){await e.schema.dropTable(`codes`).execute(),await e.schema.createTable(`codes`).addColumn(`code_id`,`varchar(255)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`login_id`,`varchar(255)`).addColumn(`connection_id`,`varchar(255)`).addForeignKeyConstraint(`codes_user_id_tenant_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`code_type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).addPrimaryKeyConstraint(`PK_codes_code_id_code_type`,[`code_id`,`code_type`]).execute()}async function Dc(e){await e.schema.dropTable(`codes`).execute(),await e.schema.createTable(`codes`).addColumn(`code_id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`connection_id`,`varchar(255)`).addColumn(`login_id`,`varchar(255)`).addForeignKeyConstraint(`codes_user_id_tenant_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`code_type`,`varchar(255)`,e=>e.notNull()).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}var Oc=t({down:()=>Ac,up:()=>kc});async function kc(e){await e.schema.dropTable(`otps`).execute(),await e.schema.dropTable(`authentication_codes`).execute()}async function Ac(e){await e.schema.alterTable(`keys`).addColumn(`private_key`,`varchar(2048)`).addColumn(`public_key`,`varchar(2048)`).execute(),await e.schema.createTable(`otps`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`code`,`varchar(255)`,e=>e.notNull()).addColumn(`email`,`varchar(255)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addColumn(`send`,`varchar(255)`).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(1024)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute(),await e.schema.createTable(`authentication_codes`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`code`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`user_id`,`varchar(255)`,e=>e.notNull()).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(8192)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}var jc=t({down:()=>Nc,up:()=>Mc});async function Mc(e){await e.schema.createIndex(`IDX_logs_tenant_date_type_user`).on(`logs`).columns([`tenant_id`,`date`,`type`,`user_id`]).execute()}async function Nc(e){await e.schema.dropIndex(`IDX_logs_tenant_date_type_user`).on(`logs`).execute()}var Pc=t({down:()=>Ic,up:()=>Fc});async function Fc(e){}async function Ic(e){}var Lc=t({down:()=>zc,up:()=>Rc});async function Rc(e){await e.schema.createTable(`prompt_settings`).addColumn(`tenant_id`,`varchar(64)`,e=>e.primaryKey()).addColumn(`universal_login_experience`,`varchar(16)`,e=>e.defaultTo(`new`).notNull()).addColumn(`identifier_first`,`boolean`,e=>e.defaultTo(!0).notNull()).addColumn(`password_first`,`boolean`,e=>e.defaultTo(!1).notNull()).addColumn(`webauthn_platform_first_factor`,`boolean`,e=>e.defaultTo(!1).notNull()).execute()}async function zc(e){await e.schema.dropTable(`prompt_settings`).execute()}var Bc=t({down:()=>Hc,up:()=>Vc});async function Vc(e){}async function Hc(e){}var Uc=t({down:()=>Gc,up:()=>Wc});async function Wc(e){}async function Gc(e){}var Kc=t({down:()=>Jc,up:()=>qc});async function qc(e){}async function Jc(e){}var Yc=t({down:()=>Zc,up:()=>Xc});async function Xc(e){await e.schema.alterTable(`logins`).addColumn(`authParams_ui_locales`,`varchar(32)`).execute()}async function Zc(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_ui_locales`).execute()}var Qc=t({down:()=>el,up:()=>$c});async function $c(e){await e.schema.alterTable(`logins`).addColumn(`authParams_prompt`,`varchar(16)`).execute()}async function el(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_prompt`).execute()}var tl=t({down:()=>rl,up:()=>nl});async function nl(e){}async function rl(e){}var il=t({down:()=>ol,up:()=>al});async function al(e){await e.schema.alterTable(`logins`).addColumn(`authParams_act_as`,`varchar(255)`).execute()}async function ol(e){await e.schema.alterTable(`logins`).dropColumn(`authParam_act_as`).execute()}var sl=t({down:()=>ll,up:()=>cl});async function cl(e){await e.schema.alterTable(`codes`).addColumn(`code_verifier`,`varchar(128)`).execute()}async function ll(e){await e.schema.alterTable(`codes`).dropColumn(`code_verifier`).execute()}var ul=t({down:()=>fl,up:()=>dl});async function dl(e){await e.schema.createTable(`email_providers`).addColumn(`tenant_id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`enabled`,`boolean`,e=>e.notNull()).addColumn(`default_from_address`,`varchar(255)`).addColumn(`credentials`,`varchar(2048)`,e=>e.notNull().defaultTo(`{}`)).addColumn(`settings`,`varchar(2048)`,e=>e.notNull().defaultTo(`{}`)).addColumn(`created_at`,`varchar(29)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(29)`,e=>e.notNull()).execute()}async function fl(e){await e.schema.dropTable(`email_providers`).execute()}var pl=t({down:()=>hl,up:()=>ml});async function ml(e){await e.schema.dropTable(`tickets`).execute()}async function hl(e){await e.schema.createTable(`tickets`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(255)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`email`,`varchar(255)`,e=>e.notNull()).addColumn(`nonce`,`varchar(255)`).addColumn(`state`,`varchar(1024)`).addColumn(`scope`,`varchar(1024)`).addColumn(`response_type`,`varchar(256)`).addColumn(`response_mode`,`varchar(256)`).addColumn(`redirect_uri`,`varchar(1024)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(255)`,e=>e.notNull()).addColumn(`used_at`,`varchar(255)`).execute()}var gl=t({down:()=>vl,up:()=>_l});async function _l(e){}async function vl(e){await e.schema.alterTable(`logins`).dropColumn(`ip`).dropColumn(`useragent`).execute()}var yl=t({down:()=>xl,up:()=>bl});async function bl(e){await e.schema.createTable(`refresh_tokens`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(21)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`session_id`,`varchar(21)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`last_exchanged_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`resource_servers`,`varchar(2048)`,e=>e.notNull()).addColumn(`rotating`,`boolean`,e=>e.notNull()).execute()}async function xl(e){await e.schema.dropTable(`refresh_tokens`).execute()}var Sl=t({down:()=>wl,up:()=>Cl});async function Cl(e){}async function wl(e){}var Tl=t({down:()=>Dl,up:()=>El});async function El(e){await e.schema.dropTable(`sessions`).execute(),await e.schema.dropTable(`refresh_tokens`).execute()}async function Dl(e){await e.schema.createTable(`sessions`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`sessions_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`authenticated_at`,`varchar(35)`).addColumn(`last_interaction_at`,`varchar(35)`).addColumn(`used_at`,`varchar(35)`).addColumn(`revoked_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`clients`,`varchar(1024)`,e=>e.notNull()).execute(),await e.schema.createTable(`refresh_tokens`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(21)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`session_id`,`varchar(21)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`refresh_tokens_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`last_exchanged_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`resource_servers`,`varchar(2048)`,e=>e.notNull()).addColumn(`rotating`,`boolean`,e=>e.notNull()).execute()}var Ol=t({down:()=>Al,up:()=>kl});async function kl(e){await e.schema.createTable(`sessions_2`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`sessions_2_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`authenticated_at`,`varchar(35)`).addColumn(`last_interaction_at`,`varchar(35)`).addColumn(`used_at`,`varchar(35)`).addColumn(`revoked_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`clients`,`varchar(1024)`,e=>e.notNull()).execute(),await e.schema.createTable(`refresh_tokens_2`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(21)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`session_id`,`varchar(21)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`refresh_tokens_2_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`last_exchanged_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`resource_servers`,`varchar(2048)`,e=>e.notNull()).addColumn(`rotating`,`boolean`,e=>e.notNull()).execute()}async function Al(e){await e.schema.dropTable(`sessions_2`).execute(),await e.schema.dropTable(`refresh_tokens_2`).execute()}var jl=t({down:()=>Nl,up:()=>Ml});async function Ml(e){await e.schema.createTable(`custom_domains`).addColumn(`custom_domain_id`,`varchar(21)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`domain`,`varchar(255)`,e=>e.notNull()).addColumn(`primary`,`boolean`,e=>e.notNull()).addColumn(`status`,`varchar(50)`,e=>e.notNull()).addColumn(`type`,`varchar(50)`,e=>e.notNull()).addColumn(`origin_domain_name`,`varchar(255)`).addColumn(`verification`,`varchar(2048)`).addColumn(`custom_client_ip_header`,`varchar(50)`).addColumn(`tls_policy`,`varchar(50)`).addColumn(`domain_metadata`,`varchar(2048)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).execute(),await e.schema.dropTable(`domains`).execute()}async function Nl(e){await e.schema.dropTable(`custom_domains`).execute(),await e.schema.createTable(`domains`).addColumn(`id`,`varchar(255)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`domain`,`varchar(255)`,e=>e.notNull()).addColumn(`email_service`,`varchar(255)`).addColumn(`email_api_key`,`varchar(255)`).addColumn(`dkim_private_key`,`varchar(2048)`).addColumn(`dkim_public_key`,`varchar(2048)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute()}var Pl=t({down:()=>Il,up:()=>Fl});async function Fl(e){}async function Il(e){await e.schema.alterTable(`logins`).dropColumn(`authParams_organization`).dropColumn(`authorization_url`).execute()}var Ll=t({down:()=>zl,up:()=>Rl});async function Rl(e){await e.schema.alterTable(`logins`).dropColumn(`authorization_url`).execute(),await e.schema.alterTable(`logins`).addColumn(`authorization_url`,`varchar(2048)`).execute()}async function zl(e){await e.schema.alterTable(`logins`).dropColumn(`authorization_url`).execute(),await e.schema.alterTable(`logins`).addColumn(`authorization_url`,`varchar(1024)`).execute()}var Bl=t({down:()=>Hl,up:()=>Vl});async function Vl(e){}async function Hl(e){}var Ul=t({down:()=>Gl,up:()=>Wl});async function Wl(e){await e.schema.createTable(`sessions`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`sessions_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`authenticated_at`,`varchar(35)`).addColumn(`last_interaction_at`,`varchar(35)`).addColumn(`used_at`,`varchar(35)`).addColumn(`revoked_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`clients`,`varchar(1024)`,e=>e.notNull()).execute(),await e.schema.createTable(`login_sessions`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`session_id`,`varchar(21)`,e=>e.references(`sessions.id`).onDelete(`cascade`)).addColumn(`csrf_token`,`varchar(21)`,e=>e.notNull()).addColumn(`authParams_client_id`,`varchar(255)`,e=>e.notNull()).addColumn(`authParams_vendor_id`,`varchar(255)`).addColumn(`authParams_username`,`varchar(255)`).addColumn(`authParams_response_type`,`varchar(255)`).addColumn(`authParams_response_mode`,`varchar(255)`).addColumn(`authParams_audience`,`varchar(255)`).addColumn(`authParams_scope`,`varchar(511)`).addColumn(`authParams_state`,`varchar(2048)`).addColumn(`authParams_nonce`,`varchar(255)`).addColumn(`authParams_code_challenge_method`,`varchar(255)`).addColumn(`authParams_code_challenge`,`varchar(255)`).addColumn(`authParams_redirect_uri`,`varchar(255)`).addColumn(`authParams_organization`,`varchar(255)`).addColumn(`authParams_prompt`,`varchar(32)`).addColumn(`authParams_act_as`,`varchar(256)`).addColumn(`authParams_ui_locales`,`varchar(32)`).addColumn(`authorization_url`,`varchar(1024)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`,e=>e.notNull()).addColumn(`ip`,`varchar(39)`).addColumn(`useragent`,`varchar(1024)`).addColumn(`auth0Client`,`varchar(255)`).execute(),await e.schema.createTable(`refresh_tokens`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`client_id`,`varchar(21)`,e=>e.references(`applications.id`).onDelete(`cascade`).notNull()).addColumn(`tenant_id`,`varchar(255)`).addColumn(`session_id`,`varchar(21)`,e=>e.notNull()).addColumn(`user_id`,`varchar(255)`).addForeignKeyConstraint(`refresh_tokens_user_id_constraint`,[`user_id`,`tenant_id`],`users`,[`user_id`,`tenant_id`],e=>e.onDelete(`cascade`)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`expires_at`,`varchar(35)`).addColumn(`idle_expires_at`,`varchar(35)`).addColumn(`last_exchanged_at`,`varchar(35)`).addColumn(`device`,`varchar(2048)`,e=>e.notNull()).addColumn(`resource_servers`,`varchar(2048)`,e=>e.notNull()).addColumn(`rotating`,`boolean`,e=>e.notNull()).execute()}async function Gl(e){await e.schema.dropTable(`sessions`).execute(),await e.schema.dropTable(`login_sessions`).execute(),await e.schema.dropTable(`refresh_tokens`).execute()}var Kl=t({down:()=>Jl,up:()=>ql});async function ql(e){await e.schema.dropTable(`logins`).execute(),await e.schema.dropTable(`sessions_2`).execute(),await e.schema.dropTable(`refresh_tokens_2`).execute()}async function Jl(e){}var Yl=t({down:()=>Zl,up:()=>Xl});async function Xl(e){await e.schema.dropTable(`custom_domains`).execute(),await e.schema.createTable(`custom_domains`).addColumn(`custom_domain_id`,`varchar(256)`,e=>e.notNull().primaryKey()).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`domain`,`varchar(255)`,e=>e.notNull()).addColumn(`primary`,`boolean`,e=>e.notNull()).addColumn(`status`,`varchar(50)`,e=>e.notNull()).addColumn(`type`,`varchar(50)`,e=>e.notNull()).addColumn(`origin_domain_name`,`varchar(255)`).addColumn(`verification`,`varchar(2048)`).addColumn(`custom_client_ip_header`,`varchar(50)`).addColumn(`tls_policy`,`varchar(50)`).addColumn(`domain_metadata`,`varchar(2048)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).execute()}async function Zl(e){}var Ql=t({down:()=>eu,up:()=>$l});async function $l(e){}async function eu(e){await e.schema.alterTable(`users`).dropColumn(`phone_number`).dropColumn(`phone_verified`).dropColumn(`username`).execute()}var tu=t({down:()=>ru,up:()=>nu});async function nu(e){await e.schema.createTable(`forms`).addColumn(`id`,`varchar(255)`,e=>e.primaryKey()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(255)`,e=>e.notNull()).addColumn(`messages`,`varchar(255)`).addColumn(`languages`,`varchar(255)`).addColumn(`translations`,`varchar(4096)`).addColumn(`nodes`,`varchar(4096)`).addColumn(`start`,`varchar(255)`).addColumn(`ending`,`varchar(255)`).addColumn(`style`,`varchar(1042)`).addColumn(`created_at`,`varchar(255)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(255)`,e=>e.notNull()).execute(),await e.schema.createIndex(`forms_tenant_id_idx`).on(`forms`).column(`tenant_id`).execute()}async function ru(e){await e.schema.dropTable(`forms`).execute()}var iu=t({down:()=>ou,up:()=>au});async function au(e){await e.schema.alterTable(`hooks`).addColumn(`form_id`,`text`).execute(),await e.schema.alterTable(`hooks`).addColumn(`url_tmp`,`varchar(512)`).execute(),await e.updateTable(`hooks`).set(e=>({url_tmp:e.ref(`url`)})).execute(),await e.schema.alterTable(`hooks`).dropColumn(`url`).execute(),await e.schema.alterTable(`hooks`).renameColumn(`url_tmp`,`url`).execute()}async function ou(e){await e.schema.dropTable(`hooks`).ifExists().execute(),await e.schema.createTable(`hooks`).addColumn(`hook_id`,`text`,e=>e.primaryKey()).addColumn(`tenant_id`,`text`,e=>e.notNull()).addColumn(`trigger_id`,`text`,e=>e.notNull()).addColumn(`enabled`,`integer`,e=>e.notNull().defaultTo(0)).addColumn(`url`,`varchar(512)`,e=>e.notNull()).addColumn(`synchronous`,`integer`,e=>e.notNull().defaultTo(0)).addColumn(`priority`,`integer`).addColumn(`created_at`,`text`,e=>e.notNull()).addColumn(`updated_at`,`text`,e=>e.notNull()).execute()}var su=t({down:()=>lu,up:()=>cu});async function cu(e){await e.schema.alterTable(`login_sessions`).addColumn(`login_completed`,`boolean`,e=>e.notNull().defaultTo(0)).execute()}async function lu(e){await e.schema.alterTable(`login_sessions`).dropColumn(`login_completed`).execute()}var uu=t({down:()=>fu,up:()=>du});async function du(e){await e.schema.alterTable(`sessions`).addColumn(`login_session_id`,`varchar(21)`,e=>e.references(`login_sessions.id`).onDelete(`set null`)).execute()}async function fu(e){await e.schema.alterTable(`sessions`).dropColumn(`login_session_id`).execute()}var pu=t({down:()=>hu,up:()=>mu});async function mu(e){await e.schema.createIndex(`IDX_sessions_login_session_id`).on(`sessions`).column(`login_session_id`).execute()}async function hu(e){await e.schema.dropIndex(`IDX_sessions_login_session_id`).on(`sessions`).execute()}var gu=t({down:()=>vu,up:()=>_u});async function _u(e){await e.schema.alterTable(`codes`).addColumn(`code_challenge`,`varchar(128)`).execute(),await e.schema.alterTable(`codes`).addColumn(`code_challenge_method`,`varchar(5)`).execute()}async function vu(e){await e.schema.alterTable(`codes`).dropColumn(`code_challenge`).execute(),await e.schema.alterTable(`codes`).dropColumn(`code_challenge_method`).execute()}var yu=t({down:()=>xu,up:()=>bu});async function bu(e){await e.schema.alterTable(`codes`).addColumn(`redirect_uri`,`varchar(1024)`).execute()}async function xu(e){await e.schema.alterTable(`codes`).dropColumn(`redirect_uri`).execute()}var Su=t({down:()=>wu,up:()=>Cu});async function Cu(e){await e.schema.alterTable(`codes`).addColumn(`nonce`,`varchar(1024)`).execute(),await e.schema.alterTable(`codes`).addColumn(`state`,`varchar(2048)`).execute()}async function wu(e){await e.schema.alterTable(`codes`).dropColumn(`nonce`).execute(),await e.schema.alterTable(`codes`).dropColumn(`state`).execute()}var Tu=t({down:()=>Du,up:()=>Eu});async function Eu(e){await e.schema.createTable(`themes`).addColumn(`tenant_id`,`varchar(255)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`themeId`,`varchar(255)`,e=>e.notNull()).addColumn(`displayName`,`varchar(255)`,e=>e.notNull()).addColumn(`colors_primary_button_label`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_primary_button`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_secondary_button_border`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_secondary_button_label`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_base_focus_color`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_base_hover_color`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_body_text`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_captcha_widget_theme`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_error`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_header`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_icons`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_input_background`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_input_border`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_input_filled_text`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_input_labels_placeholders`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_links_focused_components`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_success`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_widget_background`,`varchar(24)`,e=>e.notNull()).addColumn(`colors_widget_border`,`varchar(24)`,e=>e.notNull()).addColumn(`borders_button_border_radius`,`integer`,e=>e.notNull()).addColumn(`borders_button_border_weight`,`integer`,e=>e.notNull()).addColumn(`borders_buttons_style`,`varchar(24)`,e=>e.notNull()).addColumn(`borders_input_border_radius`,`integer`,e=>e.notNull()).addColumn(`borders_input_border_weight`,`integer`,e=>e.notNull()).addColumn(`borders_inputs_style`,`varchar(24)`,e=>e.notNull()).addColumn(`borders_show_widget_shadow`,`boolean`,e=>e.notNull()).addColumn(`borders_widget_border_weight`,`integer`,e=>e.notNull()).addColumn(`borders_widget_corner_radius`,`integer`,e=>e.notNull()).addColumn(`fonts_body_text_bold`,`integer`,e=>e.notNull()).addColumn(`fonts_body_text_size`,`integer`,e=>e.notNull()).addColumn(`fonts_buttons_text_bold`,`integer`,e=>e.notNull()).addColumn(`fonts_buttons_text_size`,`integer`,e=>e.notNull()).addColumn(`fonts_font_url`,`varchar(255)`,e=>e.notNull()).addColumn(`fonts_input_labels_bold`,`integer`,e=>e.notNull()).addColumn(`fonts_input_labels_size`,`integer`,e=>e.notNull()).addColumn(`fonts_links_bold`,`boolean`,e=>e.notNull()).addColumn(`fonts_links_size`,`integer`,e=>e.notNull()).addColumn(`fonts_links_style`,`varchar(24)`,e=>e.notNull()).addColumn(`fonts_reference_text_size`,`integer`,e=>e.notNull()).addColumn(`fonts_subtitle_bold`,`boolean`,e=>e.notNull()).addColumn(`fonts_subtitle_size`,`integer`,e=>e.notNull()).addColumn(`fonts_title_bold`,`boolean`,e=>e.notNull()).addColumn(`fonts_title_size`,`integer`,e=>e.notNull()).addColumn(`page_background_background_color`,`varchar(24)`,e=>e.notNull()).addColumn(`page_background_background_image_url`,`varchar(255)`,e=>e.notNull()).addColumn(`page_background_page_layout`,`varchar(24)`,e=>e.notNull()).addColumn(`widget_header_text_alignment`,`varchar(24)`,e=>e.notNull()).addColumn(`widget_logo_height`,`integer`,e=>e.notNull()).addColumn(`widget_logo_position`,`varchar(24)`,e=>e.notNull()).addColumn(`widget_logo_url`,`varchar(255)`,e=>e.notNull()).addColumn(`widget_social_buttons_layout`,`varchar(24)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`themes_pkey`,[`tenant_id`,`themeId`]).execute(),await e.schema.createIndex(`themes_tenant_id_idx`).on(`themes`).column(`tenant_id`).execute()}async function Du(e){await e.schema.dropTable(`themes`).execute()}var Ou=t({down:()=>Au,up:()=>ku});async function ku(e){await e.schema.createTable(`resource_servers`).addColumn(`id`,`varchar(21)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`identifier`,`varchar(191)`,e=>e.notNull()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`scopes`,`varchar(4096)`).addColumn(`signing_alg`,`varchar(64)`).addColumn(`signing_secret`,`varchar(2048)`).addColumn(`token_lifetime`,`integer`).addColumn(`token_lifetime_for_web`,`integer`).addColumn(`skip_consent_for_verifiable_first_party_clients`,`integer`).addColumn(`allow_offline_access`,`integer`).addColumn(`verification_key`,`varchar(4096)`).addColumn(`options`,`varchar(4096)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`resource_servers_pk`,[`tenant_id`,`id`]).execute(),await e.schema.createIndex(`resource_servers_tenant_identifier_uq`).on(`resource_servers`).columns([`tenant_id`,`identifier`]).unique().execute(),await e.schema.createTable(`roles`).addColumn(`id`,`varchar(21)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`name`,`varchar(50)`,e=>e.notNull()).addColumn(`description`,`varchar(255)`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`roles_pk`,[`tenant_id`,`id`]).execute(),await e.schema.createIndex(`roles_tenant_name_uq`).on(`roles`).columns([`tenant_id`,`name`]).unique().execute()}async function Au(e){await e.schema.dropTable(`roles`).execute(),await e.schema.dropTable(`resource_servers`).execute()}var ju=t({down:()=>Nu,up:()=>Mu});async function Mu(e){await e.schema.createTable(`role_permissions`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`role_id`,`varchar(21)`,e=>e.notNull()).addColumn(`resource_server_identifier`,`varchar(191)`,e=>e.notNull()).addColumn(`permission_name`,`varchar(191)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`role_permissions_pk`,[`tenant_id`,`role_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createIndex(`role_permissions_role_fk`).on(`role_permissions`).columns([`tenant_id`,`role_id`]).execute(),await e.schema.createIndex(`role_permissions_permission_fk`).on(`role_permissions`).columns([`tenant_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createTable(`user_permissions`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`resource_server_identifier`,`varchar(191)`,e=>e.notNull()).addColumn(`permission_name`,`varchar(191)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_permissions_pk`,[`tenant_id`,`user_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createIndex(`user_permissions_user_fk`).on(`user_permissions`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_permissions_permission_fk`).on(`user_permissions`).columns([`tenant_id`,`resource_server_identifier`,`permission_name`]).execute()}async function Nu(e){await e.schema.dropTable(`user_permissions`).execute(),await e.schema.dropTable(`role_permissions`).execute()}var Pu=t({down:()=>Iu,up:()=>Fu});async function Fu(e){await e.schema.createTable(`user_roles`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`role_id`,`varchar(21)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_roles_pk`,[`tenant_id`,`user_id`,`role_id`]).execute(),await e.schema.createIndex(`user_roles_user_fk`).on(`user_roles`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_roles_role_fk`).on(`user_roles`).columns([`tenant_id`,`role_id`]).execute()}async function Iu(e){await e.schema.dropTable(`user_roles`).execute()}var Lu=t({down:()=>zu,up:()=>Ru});async function Ru(e){}async function zu(e){await e.schema.alterTable(`keys`).dropColumn(`connection`).execute(),await e.schema.alterTable(`keys`).modifyColumn(`cert`,`varchar(2048)`).execute(),await e.schema.alterTable(`keys`).modifyColumn(`pkcs7`,`varchar(2048)`).execute(),await e.schema.alterTable(`keys`).dropColumn(`type`).execute()}var Bu=t({down:()=>Hu,up:()=>Vu});async function Vu(e){await e.schema.createTable(`organizations`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`name`,`varchar(256)`,e=>e.notNull()).addColumn(`display_name`,`varchar(256)`).addColumn(`branding`,`text`).addColumn(`metadata`,`text`).addColumn(`enabled_connections`,`text`).addColumn(`token_quota`,`text`).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).execute(),await e.schema.createIndex(`idx_organizations_tenant_id`).on(`organizations`).column(`tenant_id`).execute(),await e.schema.createIndex(`idx_organizations_tenant_name_unique`).on(`organizations`).columns([`tenant_id`,`name`]).unique().execute()}async function Hu(e){await e.schema.dropTable(`organizations`).execute()}var Uu=t({down:()=>Gu,up:()=>Wu});async function Wu(e){await e.schema.createTable(`user_organizations`).addColumn(`id`,`varchar(21)`,e=>e.primaryKey()).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`organization_id`,`varchar(21)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addUniqueConstraint(`user_organizations_unique`,[`tenant_id`,`user_id`,`organization_id`]).execute(),await e.schema.createIndex(`idx_user_organizations_tenant_id`).on(`user_organizations`).column(`tenant_id`).execute(),await e.schema.createIndex(`idx_user_organizations_user_id`).on(`user_organizations`).column(`user_id`).execute(),await e.schema.createIndex(`idx_user_organizations_organization_id`).on(`user_organizations`).column(`organization_id`).execute()}async function Gu(e){await e.schema.dropTable(`user_organizations`).execute()}var Ku=t({down:()=>Ju,up:()=>qu});async function qu(e){await e.schema.dropTable(`user_permissions`).execute(),await e.schema.dropTable(`user_roles`).execute(),await e.schema.createTable(`user_permissions`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`resource_server_identifier`,`varchar(21)`,e=>e.notNull()).addColumn(`permission_name`,`varchar(191)`,e=>e.notNull()).addColumn(`organization_id`,`varchar(21)`,e=>e.notNull().defaultTo(``)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_permissions_pk`,[`tenant_id`,`user_id`,`resource_server_identifier`,`permission_name`,`organization_id`]).execute(),await e.schema.createIndex(`user_permissions_user_fk`).on(`user_permissions`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_permissions_permission_fk`).on(`user_permissions`).columns([`tenant_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createIndex(`user_permissions_organization_fk`).on(`user_permissions`).column(`organization_id`).execute(),await e.schema.createTable(`user_roles`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`role_id`,`varchar(21)`,e=>e.notNull()).addColumn(`organization_id`,`varchar(191)`,e=>e.notNull().defaultTo(``)).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_roles_pk`,[`tenant_id`,`user_id`,`role_id`,`organization_id`]).execute(),await e.schema.createIndex(`user_roles_user_fk`).on(`user_roles`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_roles_role_fk`).on(`user_roles`).columns([`tenant_id`,`role_id`]).execute(),await e.schema.createIndex(`user_roles_organization_fk`).on(`user_roles`).column(`organization_id`).execute()}async function Ju(e){await e.schema.dropTable(`user_permissions`).execute(),await e.schema.dropTable(`user_roles`).execute(),await e.schema.createTable(`user_permissions`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`resource_server_identifier`,`varchar(191)`,e=>e.notNull()).addColumn(`permission_name`,`varchar(191)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_permissions_pk`,[`tenant_id`,`user_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createIndex(`user_permissions_user_fk`).on(`user_permissions`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_permissions_permission_fk`).on(`user_permissions`).columns([`tenant_id`,`resource_server_identifier`,`permission_name`]).execute(),await e.schema.createTable(`user_roles`).addColumn(`tenant_id`,`varchar(191)`,e=>e.notNull()).addColumn(`user_id`,`varchar(191)`,e=>e.notNull()).addColumn(`role_id`,`varchar(21)`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`user_roles_pk`,[`tenant_id`,`user_id`,`role_id`]).execute(),await e.schema.createIndex(`user_roles_user_fk`).on(`user_roles`).columns([`tenant_id`,`user_id`]).execute(),await e.schema.createIndex(`user_roles_role_fk`).on(`user_roles`).columns([`tenant_id`,`role_id`]).execute()}var Yu=t({down:()=>Zu,up:()=>Xu});async function Xu(e){await e.schema.createTable(`clients`).addColumn(`client_id`,`varchar(191)`,e=>e.notNull()).addColumn(`tenant_id`,`varchar(191)`,e=>e.references(`tenants.id`).onDelete(`cascade`).notNull()).addColumn(`name`,`varchar(255)`,e=>e.notNull()).addColumn(`description`,`varchar(140)`).addColumn(`global`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`client_secret`,`varchar(255)`).addColumn(`app_type`,`varchar(64)`,e=>e.defaultTo(`regular_web`)).addColumn(`logo_uri`,`varchar(2083)`).addColumn(`is_first_party`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`oidc_conformant`,`integer`,e=>e.defaultTo(1).notNull()).addColumn(`callbacks`,`text`,e=>e.notNull()).addColumn(`allowed_origins`,`text`,e=>e.notNull()).addColumn(`web_origins`,`text`,e=>e.notNull()).addColumn(`client_aliases`,`text`,e=>e.notNull()).addColumn(`allowed_clients`,`text`,e=>e.notNull()).addColumn(`allowed_logout_urls`,`text`,e=>e.notNull()).addColumn(`session_transfer`,`text`,e=>e.notNull()).addColumn(`oidc_logout`,`text`,e=>e.notNull()).addColumn(`grant_types`,`text`,e=>e.notNull()).addColumn(`jwt_configuration`,`text`,e=>e.notNull()).addColumn(`signing_keys`,`text`,e=>e.notNull()).addColumn(`encryption_key`,`text`,e=>e.notNull()).addColumn(`sso`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`sso_disabled`,`integer`,e=>e.defaultTo(1).notNull()).addColumn(`cross_origin_authentication`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`cross_origin_loc`,`varchar(2083)`).addColumn(`custom_login_page_on`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`custom_login_page`,`text`).addColumn(`custom_login_page_preview`,`text`).addColumn(`form_template`,`text`).addColumn(`addons`,`text`,e=>e.notNull()).addColumn(`token_endpoint_auth_method`,`varchar(64)`,e=>e.defaultTo(`client_secret_basic`)).addColumn(`client_metadata`,`text`,e=>e.notNull()).addColumn(`mobile`,`text`,e=>e.notNull()).addColumn(`initiate_login_uri`,`varchar(2083)`).addColumn(`native_social_login`,`text`,e=>e.notNull()).addColumn(`refresh_token`,`text`,e=>e.notNull()).addColumn(`default_organization`,`text`,e=>e.notNull()).addColumn(`organization_usage`,`varchar(32)`,e=>e.defaultTo(`deny`)).addColumn(`organization_require_behavior`,`varchar(32)`,e=>e.defaultTo(`no_prompt`)).addColumn(`client_authentication_methods`,`text`,e=>e.notNull()).addColumn(`require_pushed_authorization_requests`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`require_proof_of_possession`,`integer`,e=>e.defaultTo(0).notNull()).addColumn(`signed_request_object`,`text`,e=>e.notNull()).addColumn(`compliance_level`,`varchar(64)`).addColumn(`par_request_expiry`,`integer`).addColumn(`token_quota`,`text`,e=>e.notNull()).addColumn(`created_at`,`varchar(35)`,e=>e.notNull()).addColumn(`updated_at`,`varchar(35)`,e=>e.notNull()).addPrimaryKeyConstraint(`clients_tenant_id_client_id`,[`tenant_id`,`client_id`]).execute()}async function Zu(e){await e.schema.dropTable(`clients`).execute()}var Qu=!1;function $u(e){Qu=e}function q(...e){Qu&&console.log(...e)}function J(...e){console.warn(...e)}var ed=t({down:()=>ad,up:()=>nd});async function td(e){try{return await i.sql`SELECT VERSION()`.execute(e),`mysql`}catch{return`sqlite`}}async function nd(e){await td(e)===`mysql`?await rd(e):await id(e)}async function rd(e){await e.transaction().execute(async e=>{let t=await i.sql`
2
2
  SELECT
3
3
  rc.CONSTRAINT_NAME,
4
4
  rc.TABLE_NAME