@authhero/kysely-adapter 10.40.0 → 10.42.0

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 +1 @@
1
- "use strict";var Ee=Object.defineProperty;var de=t=>{throw TypeError(t)};var Le=(t,e,a)=>e in t?Ee(t,e,{enumerable:!0,configurable:!0,writable:!0,value:a}):t[e]=a;var K=(t,e,a)=>Le(t,typeof e!="symbol"?e+"":e,a),X=(t,e,a)=>e.has(t)||de("Cannot "+a);var m=(t,e,a)=>(X(t,e,"read from private field"),a?a.call(t):e.get(t)),k=(t,e,a)=>e.has(t)?de("Cannot add the same private member more than once"):e instanceof WeakSet?e.add(t):e.set(t,a),U=(t,e,a,r)=>(X(t,e,"write to private field"),r?r.call(t,a):e.set(t,a),a),p=(t,e,a)=>(X(t,e,"access private method"),a);Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const x=require("@authhero/adapter-interfaces");require("@hono/zod-openapi");var Q=class extends Error{constructor(e=500,a){super(a==null?void 0:a.message,{cause:a==null?void 0:a.cause});K(this,"res");K(this,"status");this.res=a==null?void 0:a.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 Re(t){return async(e,a)=>{const{identities:r,...n}=a,o={...n,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),login_count:0,tenant_id:e,email_verified:a.email_verified?1:0,is_social:a.is_social?1:0,app_metadata:JSON.stringify(a.app_metadata),user_metadata:JSON.stringify(a.user_metadata)};try{await t.insertInto("users").values(o).execute()}catch(s){throw s.code==="SQLITE_CONSTRAINT_UNIQUE"||s.message.includes("AlreadyExists")?new Q(409,{message:"User already exists"}):new Q(500,{message:`${s.code}, ${s.message}`})}return{...o,email:o.email||"",email_verified:o.email_verified===1,is_social:o.is_social===1}}}function y(t){if(t==null||typeof t!="object")return t;if(Array.isArray(t))return t.map(a=>a!==null&&typeof a=="object"?y(a):a);const e={...t};for(const a in e){const r=e[a];r===null?delete e[a]:r!==null&&typeof r=="object"&&(Array.isArray(r)?e[a]=r.map(n=>n!==null&&typeof n=="object"?y(n):n):e[a]=y(r))}return e}function fe(t){let e={};try{e=JSON.parse(t.profileData||"{}")}catch(a){console.error("Error parsing profileData",a)}return{connection:t.connection,provider:t.provider,user_id:x.parseUserId(t.user_id).id,isSocial:!!t.is_social,profileData:{email:t.email,email_verified:!!t.email_verified,...e}}}function Ke(t){return async(e,a)=>{const[r,n]=await Promise.all([t.selectFrom("users").where("users.tenant_id","=",e).where("users.user_id","=",a).selectAll().executeTakeFirst(),t.selectFrom("users").where("users.tenant_id","=",e).where("users.linked_to","=",a).selectAll().execute()]);if(!r)return null;const{tenant_id:o,...s}=r,i={...s,email:r.email||"",email_verified:r.email_verified===1,is_social:r.is_social===1,app_metadata:JSON.parse(r.app_metadata),user_metadata:JSON.parse(r.user_metadata),identities:[{connection:r.connection,provider:r.provider,user_id:x.parseUserId(r.user_id).id,isSocial:!!r.is_social},...n.map(fe)]};return y(i)}}function O(t,e,a,r){return a.split(/\s+/).map(o=>o.replace(/^([^:]+)=/g,"$1:")).map(o=>{let s=o.startsWith("-"),i=null,c="",u=!1,_;if(o.startsWith("-_exists_:"))i=o.substring(10),u=!0,s=!0;else if(o.startsWith("_exists_:"))i=o.substring(9),u=!0,s=!1;else if(o.includes(":")){const d=s?o.substring(1):o,h=d.indexOf(":");i=d.substring(0,h),c=d.substring(h+1),u=!1,c.startsWith(">=")?(_=">=",c=c.substring(2)):c.startsWith(">")?(_=">",c=c.substring(1)):c.startsWith("<=")?(_="<=",c=c.substring(2)):c.startsWith("<")?(_="<",c=c.substring(1)):_="="}else i=null,c=o,u=!1;return{key:i,value:c,isNegation:s,isExistsQuery:u,operator:_}}).forEach(({key:o,value:s,isNegation:i,isExistsQuery:c,operator:u})=>{if(o)if(c)i?e=e.where(o,"is",null):e=e.where(o,"is not",null);else if(i)switch(u){case">":e=e.where(o,"<=",s);break;case">=":e=e.where(o,"<",s);break;case"<":e=e.where(o,">=",s);break;case"<=":e=e.where(o,">",s);break;default:e=e.where(o,"!=",s)}else e=e.where(o,u,s);else if(s){const{ref:_}=t.dynamic;e=e.where(d=>d.or(r.map(h=>d(_(h),"like",`%${s}%`))))}}),e}function T(t){return typeof t=="string"?parseInt(t,10):typeof t=="bigint"?Number(t):t}function Ue(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=a;let c=t.selectFrom("users").where("users.tenant_id","=",e);if(i&&(c=O(t,c,i,["email","name"])),s&&s.sort_by){const{ref:w}=t.dynamic;c=c.orderBy(w(s.sort_by),s.sort_order)}const _=await c.offset(r*n).limit(n).selectAll().execute(),d=_.map(w=>w.user_id),h=d.length?await t.selectFrom("users").selectAll().where("users.tenant_id","=",e).where("users.linked_to","in",d).execute():[],f=_.map(w=>{const b=h.filter(P=>P.linked_to===w.user_id);return y({...w,email_verified:w.email_verified===1,is_social:w.is_social===1,app_metadata:JSON.parse(w.app_metadata),user_metadata:JSON.parse(w.user_metadata),identities:[{connection:w.connection,provider:w.provider,user_id:x.parseUserId(w.user_id).id,isSocial:!!w.is_social},...b.map(fe)]})});if(!o)return{users:f,start:0,limit:0,length:0};const{count:g}=await c.select(w=>w.fn.countAll().as("count")).executeTakeFirstOrThrow();return{users:f,start:r*n,limit:n,length:T(g)}}}function qe(t){return async(e,a)=>(await t.deleteFrom("users").where("users.tenant_id","=",e).where("users.linked_to","=",a).execute(),(await t.deleteFrom("users").where("users.tenant_id","=",e).where("users.user_id","=",a).execute()).length===1)}function R(t,e="",a={}){for(let r in t)if(Object.prototype.hasOwnProperty.call(t,r)){const n=e?`${e}_${r}`:r,o=t[r];typeof o=="object"&&o!==null&&!Array.isArray(o)?R(o,n,a):typeof o=="boolean"?a[n]=o?1:0:a[n]=o}return a}function pe(t,e){const a={};for(const[r,n]of Object.entries(t)){const o=e.find(s=>r.startsWith(`${s}_`));if(!o)a[r]=n;else{const s=r.slice(o.length+1);a[o]={...a[o],[s]:n}}}return a}function Be(t){return async(e,a,r)=>{const n=R({...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});return(await t.updateTable("users").set(n).where("users.tenant_id","=",e).where("users.user_id","=",a).execute()).length===1}}function Qe(t){return async(e,a,r,n)=>{const o={linked_to:null};return(await t.updateTable("users").set(o).where("users.tenant_id","=",e).where("users.user_id","=",`${r}|${n}`).where("users.linked_to","=",`${a}`).execute()).length===1}}function We(t){return{create:Re(t),remove:qe(t),get:Ke(t),list:Ue(t),update:Be(t),unlink:Qe(t)}}const Ve="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";let S=(t=21)=>{let e="",a=crypto.getRandomValues(new Uint8Array(t));for(;t--;)e+=Ve[a[t]&63];return e};function Ge(t){return async e=>{const a={id:e.id||S(),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...e};return await t.insertInto("tenants").values(a).execute(),a}}function Ye(t){return async e=>{const a=await t.selectFrom("tenants").where("tenants.id","=",e).selectAll().executeTakeFirst();return a?y(a):null}}function He(t){return async e=>{let a=t.selectFrom("tenants");const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=e;if(s&&s.sort_by){const{ref:f}=t.dynamic;a=a.orderBy(f(s.sort_by),s.sort_order)}i&&(a=a.where(f=>f.or([f("name","like",`%${i}%`)])));const _=(await a.offset(r*n).limit(n).selectAll().execute()).map(y);if(!o)return{tenants:_};const{count:d}=await a.select(f=>f.fn.countAll().as("count")).executeTakeFirstOrThrow(),h=T(d);return{tenants:_,start:r*n,limit:n,length:h}}}function Xe(t){return async(e,a)=>{const r={...a,id:e,updated_at:new Date().toISOString()};await t.updateTable("tenants").set(r).where("id","=",e).execute()}}function Ze(t){return async e=>(await t.deleteFrom("tenants").where("tenants.id","=",e).execute()).length===1}function et(t){return{create:Ge(t),get:Ye(t),list:He(t),update:Xe(t),remove:Ze(t)}}function ue(t){return t?JSON.stringify(t):void 0}const tt=1024;function at(t){return async(e,a)=>{var n,o,s;const r={id:S(),...a,user_agent:a.user_agent.slice(0,tt)};return await t.insertInto("logs").values({...r,description:(n=r.description)==null?void 0:n.substring(0,256),isMobile:a.isMobile?1:0,tenant_id:e,scope:(o=a.scope)==null?void 0:o.join(","),auth0_client:ue(a.auth0_client),details:(s=ue(a.details))==null?void 0:s.substring(0,8192)}).execute(),r}}function me(t){if(!t)return"";try{return JSON.parse(t)}catch{return t}}function ge(t){return{...t,client_id:t.client_id,client_name:"",auth0_client:me(t.auth0_client),details:me(t.details),isMobile:!!t.isMobile,scope:t.scope?t.scope.split(","):void 0,log_id:t.id,_id:t.id}}function rt(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=a;let c=t.selectFrom("logs").where("logs.tenant_id","=",e);i&&(c=O(t,c,i,["user_id","ip"]));let u=c;if(s&&s.sort_by){const{ref:f}=t.dynamic;u=u.orderBy(f(s.sort_by),s.sort_order)}u=u.offset(r*n).limit(n);const d=(await u.selectAll().execute()).map(ge);if(!o)return{logs:d,start:0,limit:0,length:0};const{count:h}=await c.select(f=>f.fn.countAll().as("count")).executeTakeFirstOrThrow();return{logs:d,start:r*n,limit:n,length:T(h)}}}function nt(t){return async(e,a)=>{const r=await t.selectFrom("logs").where("logs.tenant_id","=",e).where("logs.id","=",a).selectAll().executeTakeFirst();return r?ge(r):null}}function ot(t){return{create:at(t),list:rt(t),get:nt(t)}}function st(t){return async(e,a)=>{const r=await t.selectFrom("sessions").where("sessions.tenant_id","=",e).where("sessions.id","=",a).selectAll().executeTakeFirst();if(!r)return null;const{tenant_id:n,device:o,clients:s,...i}=r;return{...i,device:JSON.parse(o),clients:JSON.parse(s)}}}function it(t){return async(e,a)=>{const r={...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),authenticated_at:new Date().toISOString(),last_interaction_at:new Date().toISOString()};return await t.insertInto("sessions").values({...r,tenant_id:e,device:JSON.stringify(a.device),clients:JSON.stringify(a.clients)}).execute(),r}}function lt(t){return async(e,a)=>!!(await t.deleteFrom("sessions").where("tenant_id","=",e).where("sessions.id","=",a).execute()).length}function ct(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString(),device:r.device?JSON.stringify(r.device):void 0,clients:r.clients?JSON.stringify(r.clients):void 0};return!!(await t.updateTable("sessions").set(n).where("tenant_id","=",e).where("sessions.id","=",a).execute()).length}}function dt(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=a;let c=t.selectFrom("sessions").where("sessions.tenant_id","=",e);i&&(c=O(t,c,i,["user_id","session_id"]));let u=c;if(s&&s.sort_by){const{ref:g}=t.dynamic;u=u.orderBy(g(s.sort_by),s.sort_order)}u=u.offset(r*n).limit(n);const d=(await u.selectAll().execute()).map(g=>({...g,device:JSON.parse(g.device),clients:JSON.parse(g.clients)}));if(!o)return{sessions:d,start:0,limit:0,length:0};const{count:h}=await c.select(g=>g.fn.countAll().as("count")).executeTakeFirstOrThrow(),f=T(h);return{sessions:d,start:r*n,limit:n,length:f}}}function ut(t){return{create:it(t),get:st(t),list:dt(t),remove:lt(t),update:ct(t)}}function mt(t){return async(e,a)=>{const r=await t.selectFrom("passwords").where("passwords.tenant_id","=",e).where("passwords.user_id","=",a).selectAll().executeTakeFirst();if(!r)return null;const{tenant_id:n,...o}=r;return o}}function _t(t){return async(e,a)=>{const r={...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return await t.insertInto("passwords").values({...r,tenant_id:e}).execute(),r}}function ht(t){return async(e,a)=>(await t.updateTable("passwords").set({password:a.password,updated_at:new Date().toISOString()}).where("tenant_id","=",e).where("user_id","=",a.user_id).execute()).length===1}function ft(t){return{create:_t(t),update:ht(t),get:mt(t)}}function pt(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("codes").where("codes.tenant_id","=",e);s&&(i=O(t,i,s,["code","login_id"]));const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>{const{tenant_id:f,...g}=h;return x.codeSchema.parse(y(g))});if(!o)return{codes:_,start:0,limit:0,length:0};const{count:d}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{codes:_,start:r*n,limit:n,length:T(d)}}}function gt(t){return async(e,a)=>{const r={...a,created_at:new Date().toISOString()};return await t.insertInto("codes").values({...r,tenant_id:e}).execute(),r}}function wt(t){return async(e,a)=>(await t.deleteFrom("codes").where("codes.tenant_id","=",e).where("codes.code_id","=",a).executeTakeFirst()).numDeletedRows>0}function yt(t){return async(e,a,r)=>{let n=t.selectFrom("codes").where("codes.code_id","=",a).where("codes.code_type","=",r);e.length&&(n=n.where("codes.tenant_id","=",e));const o=await n.selectAll().executeTakeFirst();return o?y(o):null}}function vt(t){return async(e,a)=>(await t.updateTable("codes").set({used_at:new Date().toISOString()}).where("codes.tenant_id","=",e).where("codes.code_id","=",a).executeTakeFirst()).numUpdatedRows>0}function Nt(t){return{create:gt(t),list:pt(t),remove:wt(t),used:vt(t),get:yt(t)}}function Ct(t){return async(e,a)=>{const r={created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...a,disable_sign_ups:a.disable_sign_ups??!1},n=JSON.stringify(a.allowed_origins),o=JSON.stringify(a.callbacks),s=JSON.stringify(a.web_origins),i=JSON.stringify(a.allowed_logout_urls),c=JSON.stringify(a.allowed_clients);return await t.insertInto("applications").values({...r,tenant_id:e,disable_sign_ups:a.disable_sign_ups?1:0,addons:a.addons?JSON.stringify(a.addons):"{}",callbacks:o,allowed_origins:n,web_origins:s,allowed_logout_urls:i,allowed_clients:c}).execute(),r}}function bt(t){return async e=>({applications:(await t.selectFrom("applications").where("applications.tenant_id","=",e).selectAll().execute()).map(o=>({...o,disable_sign_ups:!!o.disable_sign_ups,addons:o.addons?JSON.parse(o.addons):{},callbacks:o.callbacks?JSON.parse(o.callbacks):[],allowed_origins:o.allowed_origins?JSON.parse(o.allowed_origins):[],web_origins:o.web_origins?JSON.parse(o.web_origins):[],allowed_logout_urls:o.allowed_logout_urls?JSON.parse(o.allowed_logout_urls):[],allowed_clients:o.allowed_logout_urls?JSON.parse(o.allowed_logout_urls):[]}))})}function xt(t){return async(e,a)=>{const r=await t.selectFrom("applications").where("applications.tenant_id","=",e).where("applications.id","=",a).selectAll().executeTakeFirst();return r?y({...r,disable_sign_ups:!!r.disable_sign_ups,addons:JSON.parse(r.addons),callbacks:JSON.parse(r.callbacks),allowed_origins:JSON.parse(r.allowed_origins),web_origins:JSON.parse(r.web_origins),allowed_logout_urls:JSON.parse(r.allowed_logout_urls)}):null}}function Tt(t){return async(e,a)=>(await t.deleteFrom("applications").where("applications.tenant_id","=",e).where("applications.id","=",a).executeTakeFirst()).numDeletedRows>0}function St(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString(),allowed_origins:r.allowed_origins?JSON.stringify(r.allowed_origins):void 0,callbacks:r.callbacks?JSON.stringify(r.callbacks):void 0,web_origins:r.web_origins?JSON.stringify(r.web_origins):void 0,allowed_logout_urls:r.allowed_logout_urls?JSON.stringify(r.allowed_logout_urls):void 0,allowed_clients:r.allowed_clients?JSON.stringify(r.allowed_clients):void 0,addons:r.addons?JSON.stringify(r.addons):"{}",disable_sign_ups:r.disable_sign_ups?1:0};return await t.updateTable("applications").set(n).where("applications.id","=",a).where("applications.tenant_id","=",e).execute(),!0}}function Ot(t){return{create:Ct(t),list:bt(t),get:xt(t),remove:Tt(t),update:St(t)}}function kt(t){return async(e,a)=>{const r={id:S(),...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return await t.insertInto("connections").values({...r,options:JSON.stringify(r.options||{}),tenant_id:e}).execute(),r}}function $t(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("connections").where("connections.tenant_id","=",e);s&&(i=O(t,i,s,["user_id","ip"]));const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>y({...h,options:JSON.parse(h.options)}));if(!o)return{connections:_,start:0,limit:0,length:0};const{count:d}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{connections:_,start:r*n,limit:n,length:T(d)}}}function It(t){return async(e,a)=>(await t.deleteFrom("connections").where("connections.tenant_id","=",e).where("connections.id","=",a).executeTakeFirst()).numDeletedRows>0}function Dt(t){return async(e,a)=>{const r=await t.selectFrom("connections").where("connections.tenant_id","=",e).where("connections.id","=",a).selectAll().executeTakeFirst();return r?y({...r,options:JSON.parse(r.options)}):null}}function Pt(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString()};return await t.updateTable("connections").set({...n,options:n.options?JSON.stringify(n.options):void 0}).where("connections.id","=",a).where("connections.tenant_id","=",e).execute(),!0}}function zt(t){return{create:kt(t),get:Dt(t),list:$t(t),remove:It(t),update:Pt(t)}}function jt(t){return{get:async e=>{const a=await t.selectFrom("applications").selectAll().where("id","=",e).executeTakeFirst();if(!a)return null;const r=await t.selectFrom("tenants").selectAll().where("id","=",a.tenant_id).executeTakeFirst();if(!r)throw new Q(404,{message:"Tenant not found"});const n=await t.selectFrom("connections").where("tenant_id","=",a.tenant_id).selectAll().execute();return{...a,connections:n.map(s=>x.connectionSchema.parse(y({...s,options:s.options?JSON.parse(s.options):{}}))),addons:a.addons?JSON.parse(a.addons):{},callbacks:a.callbacks?JSON.parse(a.callbacks):[],allowed_origins:a.allowed_origins?JSON.parse(a.allowed_origins):[],web_origins:a.web_origins?JSON.parse(a.web_origins):[],allowed_logout_urls:a.allowed_logout_urls?JSON.parse(a.allowed_logout_urls):[],allowed_clients:a.allowed_clients?JSON.parse(a.allowed_clients):[],tenant:y(r),disable_sign_ups:!!a.disable_sign_ups}}}}function Ft(t){return async(e={})=>{const{page:a=0,per_page:r=100,include_totals:n=!1,sort:o,q:s}=e;let i=t.selectFrom("keys").where(f=>f.or([f("revoked_at",">",new Date().toISOString()),f("revoked_at","is",null)]));s&&(i=O(t,i,s,["kid","connection","fingerprint","thumbprint","type"]));let c=i.select(f=>f.fn.count("kid").as("count"));const u=a*r;i=i.limit(r).offset(u),o&&(i=i.orderBy(o.sort_by,o.sort_order));const _=await i.selectAll().execute();if(!n)return{signingKeys:_,start:0,limit:0,length:0};const d=await c.executeTakeFirst(),h=T((d==null?void 0:d.count)??0);return{signingKeys:_,start:u,limit:r,length:h}}}function At(t){return async e=>{await t.insertInto("keys").values({...e,created_at:new Date().toDateString()}).execute()}}function Mt(t){return async(e,a)=>!!(await t.updateTable("keys").set(a).where("kid","=",e).execute()).length}function Jt(t){return{create:At(t),list:Ft(t),update:Mt(t)}}function Et(t){return async(e,a)=>{const r={custom_domain_id:S(),status:"pending",primary:!1,...a};return await t.insertInto("custom_domains").values({...r,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),tenant_id:e,primary:r.primary?1:0}).execute(),r}}function Lt(t){return async e=>(await t.selectFrom("custom_domains").where("custom_domains.tenant_id","=",e).selectAll().execute()).map(r=>({...r,primary:r.primary===1}))}function Rt(t){return async(e,a)=>(await t.deleteFrom("custom_domains").where("custom_domains.tenant_id","=",e).where("custom_domains.custom_domain_id","=",a).execute()).length>0}function Kt(t){return async(e,a)=>{const r=await t.selectFrom("custom_domains").where("custom_domains.tenant_id","=",e).where("custom_domains.custom_domain_id","=",a).selectAll().executeTakeFirst();return r?{...r,primary:r.primary===1}:null}}function Ut(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString(),primary:r.primary?1:0};return(await t.updateTable("custom_domains").set(n).where("custom_domains.tenant_id","=",e).where("custom_domains.custom_domain_id","=",a).execute()).length>0}}function qt(t){return async e=>{const a=await t.selectFrom("custom_domains").where("custom_domains.domain","=",e).selectAll().executeTakeFirst();return a?{...a,primary:a.primary===1}:null}}function Bt(t){return{create:Et(t),get:Kt(t),getByDomain:qt(t),list:Lt(t),remove:Rt(t),update:Ut(t)}}function Qt(t){return async e=>{const[a]=await t.selectFrom("branding").where("branding.tenant_id","=",e).selectAll().execute();if(!a)return null;const{tenant_id:r,colors_primary:n,colors_page_background_type:o,colors_page_background_start:s,colors_page_background_end:i,colors_page_background_angle_dev:c,font_url:u,..._}=a;return y({..._,colors:{primary:n,page_background:{type:o,start:s,end:i,angle_deg:c}},font:u?{url:u}:void 0})}}function Wt(t){return async(e,a)=>{var s,i,c,u,_,d,h,f,g,w,b,P,A,z,G,ie,le,ce;const{colors:r,font:n,...o}=a;try{await t.insertInto("branding").values({...o,colors_primary:r==null?void 0:r.primary,colors_page_background_type:(i=(s=a.colors)==null?void 0:s.page_background)==null?void 0:i.type,colors_page_background_start:(u=(c=a.colors)==null?void 0:c.page_background)==null?void 0:u.start,colors_page_background_end:(d=(_=a.colors)==null?void 0:_.page_background)==null?void 0:d.end,colors_page_background_angle_dev:(f=(h=a.colors)==null?void 0:h.page_background)==null?void 0:f.angle_deg,font_url:(g=a.font)==null?void 0:g.url,tenant_id:e}).execute()}catch{await t.updateTable("branding").set({...o,colors_primary:r==null?void 0:r.primary,colors_page_background_type:(b=(w=a.colors)==null?void 0:w.page_background)==null?void 0:b.type,colors_page_background_start:(A=(P=a.colors)==null?void 0:P.page_background)==null?void 0:A.start,colors_page_background_end:(G=(z=a.colors)==null?void 0:z.page_background)==null?void 0:G.end,colors_page_background_angle_dev:(le=(ie=a.colors)==null?void 0:ie.page_background)==null?void 0:le.angle_deg,font_url:(ce=a.font)==null?void 0:ce.url}).where("tenant_id","=",e).execute()}}}function Vt(t){return{get:Qt(t),set:Wt(t)}}function Gt(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("hooks").where("hooks.tenant_id","=",e);s&&(i=O(t,i,s,["url","form_id"]));const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>{const{tenant_id:f,enabled:g,synchronous:w,...b}=h;return y({...b,enabled:!!g,synchronous:!!w})});if(!o)return{hooks:_,start:0,limit:0,length:0};const{count:d}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{hooks:_,start:r*n,limit:n,length:T(d)}}}function Yt(t){return async(e,a)=>{const r=await t.selectFrom("hooks").where("hooks.tenant_id","=",e).where("hooks.hook_id","=",a).selectAll().executeTakeFirst();return r?y({...r,enabled:!!r.enabled,synchronous:!!r.synchronous}):null}}function Ht(t){return async(e,a)=>(await t.deleteFrom("hooks").where("hooks.tenant_id","=",e).where("hooks.hook_id","=",a).executeTakeFirst()).numDeletedRows>0}function Xt(t){return async(e,a)=>{const r={hook_id:S(),...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return await t.insertInto("hooks").values({...r,tenant_id:e,enabled:a.enabled?1:0,synchronous:a.synchronous?1:0}).execute(),r}}function Zt(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString(),enabled:r.enabled!==void 0?r.enabled?1:0:void 0,synchronous:r.enabled!==void 0?r.synchronous?1:0:void 0};return await t.updateTable("hooks").set(n).where("hooks.hook_id","=",a).where("hooks.tenant_id","=",e).execute(),!0}}function ea(t){return{create:Xt(t),get:Yt(t),list:Gt(t),update:Zt(t),remove:Ht(t)}}function ta(t){return async(e,a)=>{const r={themeId:S(),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...a},n={...r,tenant_id:e};return await t.insertInto("themes").values(R(n)).execute(),r}}function aa(t){return async(e,a)=>(await t.deleteFrom("themes").where("themes.tenant_id","=",e).where("themes.themeId","=",a).executeTakeFirst()).numDeletedRows>0}function ra(t){return async(e,a)=>{const r=await t.selectFrom("themes").where("themes.tenant_id","=",e).where("themes.themeId","=",a).selectAll().executeTakeFirst();if(!r)return null;const n={...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};return y(pe(n,["widget","colors","borders","fonts","page_background"]))}}function na(t){return async(e,a,r)=>{const n=R({...r,updated_at:new Date().toISOString()});return await t.updateTable("themes").set(n).where("themes.themeId","=",a).where("themes.tenant_id","=",e).execute(),!0}}function oa(t){return{create:ta(t),get:ra(t),remove:aa(t),update:na(t)}}function sa(t){return async(e,a)=>{const r=await t.selectFrom("login_sessions").where("login_sessions.id","=",a).selectAll().executeTakeFirst();return r?x.loginSessionSchema.parse(pe(y({...r,login_completed:!!r.login_completed}),["authParams"])):null}}function ia(t){return async(e,a)=>{var n;const r={id:S(),...a,authorization_url:(n=a.authorization_url)==null?void 0:n.slice(0,1024),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),login_completed:!!a.login_completed};return await t.insertInto("login_sessions").values({...R(r),tenant_id:e}).execute(),r}}function la(t){return async(e,a,r)=>(await t.updateTable("login_sessions").set(R({...r})).where("login_sessions.id","=",a).where("login_sessions.tenant_id","=",e).execute()).length===1}function ca(t){return async(e,a)=>(await t.deleteFrom("login_sessions").where("login_sessions.tenant_id","=",e).where("login_sessions.id","=",a).execute()).length>0}function da(t){return{create:ia(t),get:sa(t),update:la(t),remove:ca(t)}}function ua(t){return async e=>{const[a]=await t.selectFrom("prompt_settings").where("prompt_settings.tenant_id","=",e).selectAll().execute();return y({identifier_first:!!(a!=null&&a.identifier_first),password_first:!!(a!=null&&a.password_first),webauthn_platform_first_factor:!!(a!=null&&a.webauthn_platform_first_factor),universal_login_experience:(a==null?void 0:a.universal_login_experience)||"new"})}}function _e(t){return y({...t,webauthn_platform_first_factor:t.webauthn_platform_first_factor?!!t.webauthn_platform_first_factor:void 0,identifier_first:t.identifier_first?!!t.identifier_first:void 0,password_first:t.password_first?!!t.password_first:void 0,universal_login_experience:t.universal_login_experience})}function ma(t){return async(e,a)=>{try{const r=x.promptSettingSchema.parse(a);await t.insertInto("prompt_settings").values({..._e(r),tenant_id:e}).execute()}catch{await t.updateTable("prompt_settings").set(_e(a)).where("tenant_id","=",e).execute()}}}function _a(t){return{get:ua(t),set:ma(t)}}function ha(t){return async e=>{const[a]=await t.selectFrom("email_providers").where("email_providers.tenant_id","=",e).selectAll().execute();if(!a)return null;const{tenant_id:r,credentials:n,settings:o,enabled:s,...i}=a;return y({...i,credentials:JSON.parse(n),settings:JSON.parse(o),enabled:!!s})}}function fa(t){return async(e,a)=>{const{credentials:r,settings:n,enabled:o,...s}=a;await t.updateTable("email_providers").set({...s,credentials:r?JSON.stringify(r):void 0,settings:n?JSON.stringify(n):void 0,enabled:o!==void 0?o?1:0:void 0}).where("tenant_id","=",e).execute()}}function pa(t){return async(e,a)=>{const{credentials:r,settings:n,enabled:o,...s}=a;await t.insertInto("email_providers").values({...s,enabled:o?1:0,credentials:JSON.stringify(r),settings:JSON.stringify(n),tenant_id:e,created_at:new Date().toISOString(),updated_at:new Date().toISOString()}).execute()}}function ga(t){return{get:ha(t),create:pa(t),update:fa(t)}}function wa(t){return async(e,a)=>{const r=await t.selectFrom("refresh_tokens").where("refresh_tokens.tenant_id","=",e).where("refresh_tokens.id","=",a).selectAll().executeTakeFirst();return r?{...r,rotating:!!r.rotating,device:r.device?JSON.parse(r.device):{},resource_servers:r.resource_servers?JSON.parse(r.resource_servers):[]}:null}}function ya(t){return async(e,a)=>{const r={...a,created_at:new Date().toISOString()};return await t.insertInto("refresh_tokens").values({...r,tenant_id:e,rotating:a.rotating?1:0,device:JSON.stringify(a.device),resource_servers:JSON.stringify(a.resource_servers)}).execute(),{...a,...r}}}function va(t){return async(e,a)=>!!(await t.deleteFrom("refresh_tokens").where("tenant_id","=",e).where("refresh_tokens.id","=",a).execute()).length}function Na(t){return async(e,a,r)=>{const n={...r,device:r.device?JSON.stringify(r.device):void 0,resource_servers:r.resource_servers?JSON.stringify(r.resource_servers):void 0,rotating:r.rotating?1:0};return!!(await t.updateTable("refresh_tokens").set(n).where("tenant_id","=",e).where("refresh_tokens.id","=",a).execute()).length}}function Ca(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=a;let c=t.selectFrom("refresh_tokens").where("refresh_tokens.tenant_id","=",e);i&&(c=O(t,c,i,["token","session_id"]));let u=c;if(s&&s.sort_by){const{ref:g}=t.dynamic;u=u.orderBy(g(s.sort_by),s.sort_order)}u=u.offset(r*n).limit(n);const d=(await u.selectAll().execute()).map(g=>({...g,rotating:!!g.rotating,device:g.device?JSON.parse(g.device):{},resource_servers:g.resource_servers?JSON.parse(g.resource_servers):[]}));if(!o)return{refresh_tokens:d,start:0,limit:0,length:0};const{count:h}=await c.select(g=>g.fn.countAll().as("count")).executeTakeFirstOrThrow(),f=T(h);return{refresh_tokens:d,start:r*n,limit:n,length:f}}}function ba(t){return{create:ya(t),get:wa(t),list:Ca(t),remove:va(t),update:Na(t)}}function xa(t){return async()=>{const e=new Date(Date.now()-864e5).toISOString(),a=new Date(Date.now()-1e3*60*60*24*7).toISOString(),r=new Date(Date.now()-1e3*60*60*24*30*3).toISOString();console.log("delete codes"),await t.deleteFrom("codes").where("created_at","<",e).limit(1e5).execute(),console.log("delete sessions"),await t.deleteFrom("login_sessions").where("created_at","<",a).where("session_id","is",null).limit(1e5).execute(),console.log("delete logs"),await t.deleteFrom("logs").where("date","<",r).limit(1e5).execute(),console.log("delete refresh tokens"),await t.deleteFrom("refresh_tokens").where(o=>o.or([o("expires_at","<",a),o("idle_expires_at","<",a)])).limit(1e4).execute(),console.log("delete sessions");const n=await t.selectFrom("sessions").select("id").where(o=>o.or([o("expires_at","<",a),o("idle_expires_at","<",a)])).where("id","not in",t.selectFrom("refresh_tokens").select("session_id")).limit(1e5).execute();n.length>0&&await t.deleteFrom("sessions").where("id","in",n.map(o=>o.id)).execute(),console.log("cleanup complete")}}function Ta(t){return async(e,a)=>{const r=x.formSchema.parse({id:S(),...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()});return await t.insertInto("forms").values({...r,nodes:JSON.stringify(r.nodes||[]),start:JSON.stringify(r.start||{}),ending:JSON.stringify(r.ending||{}),tenant_id:e}).execute(),x.formSchema.parse(r)}}function Sa(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("forms").where("tenant_id","=",e);s&&(i=O(t,i,s,[]));const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>{const f={...h};if(typeof f.nodes=="string")try{f.nodes=JSON.parse(f.nodes)}catch{}if(typeof f.start=="string")try{f.start=JSON.parse(f.start)}catch{}if(typeof f.ending=="string")try{f.ending=JSON.parse(f.ending)}catch{}return x.formSchema.parse(y(f))});if(!o)return{forms:_,start:0,limit:0,length:0};const{count:d}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{forms:_,start:r*n,limit:n,length:T(d)}}}function Oa(t){return async(e,a)=>{const{numDeletedRows:r}=await t.deleteFrom("forms").where("id","=",a).where("tenant_id","=",e).executeTakeFirst();return r>0}}function ka(t){return async(e,a)=>{const r=await t.selectFrom("forms").selectAll().where("forms.id","=",a).where("tenant_id","=",e).executeTakeFirst();if(!r)return null;const n={...r};if(typeof n.nodes=="string")try{n.nodes=JSON.parse(n.nodes)}catch{}if(typeof n.start=="string")try{n.start=JSON.parse(n.start)}catch{}if(typeof n.ending=="string")try{n.ending=JSON.parse(n.ending)}catch{}return x.formSchema.parse(y(n))}}function $a(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString()};r.nodes&&(n.nodes=JSON.stringify(r.nodes)),r.start&&(n.start=JSON.stringify(r.start)),r.ending&&(n.ending=JSON.stringify(r.ending));const{numUpdatedRows:o}=await t.updateTable("forms").set(n).where("id","=",a).where("tenant_id","=",e).executeTakeFirst();return o>0}}function Ia(t){return{create:Ta(t),get:ka(t),list:Sa(t),remove:Oa(t),update:$a(t)}}function Da(t){return async(e,a)=>{const r=new Date().toISOString(),n={id:S(),...a,created_at:r,updated_at:r},o=x.resourceServerSchema.parse(n),{verificationKey:s,scopes:i,options:c,skip_consent_for_verifiable_first_party_clients:u,allow_offline_access:_,...d}=o,h={...d,tenant_id:e,scopes:i?JSON.stringify(i):"[]",options:c?JSON.stringify(c):"{}",skip_consent_for_verifiable_first_party_clients:u?1:0,allow_offline_access:_?1:0,verification_key:s,created_at:r,updated_at:r};return await t.insertInto("resource_servers").values(h).execute(),y(o)}}function Pa(t){return async(e,a)=>{const r=await t.selectFrom("resource_servers").selectAll().where("tenant_id","=",e).where("id","=",a).executeTakeFirst();if(!r)return null;const n=r,{verification_key:o,scopes:s,options:i,skip_consent_for_verifiable_first_party_clients:c,allow_offline_access:u,..._}=n,d={..._,scopes:s?JSON.parse(s):[],options:i?JSON.parse(i):{},skip_consent_for_verifiable_first_party_clients:!!c,allow_offline_access:!!u,verificationKey:o};return y(d)}}function za(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("resource_servers").where("resource_servers.tenant_id","=",e);if(s){const h=s.trim(),f=h.split(/\s+/),g=f.length===1?f[0]:void 0,w=g?g.match(/^(-)?(name|identifier):(.*)$/):null,b=w?w[3]:"",P=/^(>=|>|<=|<)/.test(b||"");if(w&&!P){const A=!!w[1],z=w[2]==="name"?"resource_servers.name":"resource_servers.identifier";i=A?i.where(z,"not like",`%${b}%`):i.where(z,"like",`%${b}%`)}else i=O(t,i,h,["resource_servers.name","resource_servers.identifier"])}const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>{const f=h,{verification_key:g,scopes:w,options:b,skip_consent_for_verifiable_first_party_clients:P,allow_offline_access:A,...z}=f,G={...z,scopes:w?JSON.parse(w):[],options:b?JSON.parse(b):{},skip_consent_for_verifiable_first_party_clients:!!P,allow_offline_access:!!A,verificationKey:g};return y(G)});if(!o)return{resource_servers:_,start:0,limit:0,length:0};const{count:d}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{resource_servers:_,start:r*n,limit:n,length:T(d)}}}function ja(t){return async(e,a)=>{const r=await t.deleteFrom("resource_servers").where("tenant_id","=",e).where("id","=",a).executeTakeFirst();return Number(r.numDeletedRows)>0}}function Fa(t){return async(e,a,r)=>{const{verificationKey:n,scopes:o,options:s,skip_consent_for_verifiable_first_party_clients:i,allow_offline_access:c,...u}=r,_={...u,updated_at:new Date().toISOString()};n!==void 0&&(_.verification_key=n),o!==void 0&&(_.scopes=JSON.stringify(o)),s!==void 0&&(_.options=JSON.stringify(s)),i!==void 0&&(_.skip_consent_for_verifiable_first_party_clients=i?1:0),c!==void 0&&(_.allow_offline_access=c?1:0);const d=await t.updateTable("resource_servers").set(_).where("tenant_id","=",e).where("id","=",a).executeTakeFirst();return Number(d.numUpdatedRows)>0}}function Aa(t){return{create:Da(t),get:Pa(t),list:za(t),remove:ja(t),update:Fa(t)}}function Ma(t){return async(e,a)=>{const r=new Date().toISOString(),n=S(),o={id:n,...a,tenant_id:e,created_at:r,updated_at:r};return await t.insertInto("roles").values(o).execute(),{id:n,...a,created_at:r,updated_at:r}}}function Ja(t){return async(e,a)=>{const r=await t.selectFrom("roles").selectAll().where("roles.tenant_id","=",e).where("roles.id","=",a).executeTakeFirst();return r?{...r}:null}}function Ea(t){return async(e,a)=>{let r=t.selectFrom("roles").where("roles.tenant_id","=",e);const{page:n=0,per_page:o=50,include_totals:s=!1}=a;a.q&&(r=O(t,r,a.q,["name"]));const c=await r.offset(n*o).limit(o).selectAll().execute();if(!s)return{roles:c,start:n*o,limit:o,length:c.length};const{count:u}=await r.select(_=>_.fn.countAll().as("count")).executeTakeFirstOrThrow();return{roles:c,start:n*o,limit:o,length:T(u)}}}function La(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString()},o=await t.updateTable("roles").set(n).where("roles.tenant_id","=",e).where("roles.id","=",a).executeTakeFirst();return Number(o.numUpdatedRows)>0}}function Ra(t){return async(e,a)=>{const r=await t.deleteFrom("roles").where("tenant_id","=",e).where("id","=",a).executeTakeFirst();return Number(r.numDeletedRows)>0}}function Ka(t){return{create:Ma(t),get:Ja(t),list:Ea(t),update:La(t),remove:Ra(t)}}function Ua(t){return async(e,a,r)=>{if(r.length===0)return!0;const n=new Date().toISOString();try{for(const o of r){if(o.role_id!==a)throw new Error(`Permission role_id ${o.role_id} does not match expected role_id ${a}`);const s={tenant_id:e,role_id:o.role_id,resource_server_identifier:o.resource_server_identifier,permission_name:o.permission_name,created_at:n};try{await t.insertInto("role_permissions").values(s).execute()}catch(i){if(i.code==="SQLITE_CONSTRAINT_PRIMARYKEY"||i.code==="SQLITE_CONSTRAINT_UNIQUE")continue;throw i}}return!0}catch(o){return console.error("Error assigning role permissions:",o),!1}}}function qa(t){return async(e,a,r)=>{if(r.length===0)return!0;try{return(await Promise.all(r.map(o=>t.deleteFrom("role_permissions").where("tenant_id","=",e).where("role_id","=",a).where("resource_server_identifier","=",o.resource_server_identifier).where("permission_name","=",o.permission_name).executeTakeFirst()))).some(o=>Number(o.numDeletedRows)>0)}catch(n){return console.error("Error removing role permissions:",n),!1}}}function Ba(t){return async(e,a,r={})=>{const{page:n=0,per_page:o=50,include_totals:s=!1}=r;let i=t.selectFrom("role_permissions").leftJoin("resource_servers",d=>d.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","=",e).where("role_permissions.role_id","=",a);const _=(await i.offset(n*o).limit(o).execute()).map(d=>({role_id:d.role_id,resource_server_identifier:d.resource_server_identifier,resource_server_name:d.resource_server_name||d.resource_server_identifier,permission_name:d.permission_name,description:null,created_at:d.created_at}));return s&&await i.select(d=>d.fn.countAll().as("count")).executeTakeFirstOrThrow(),_}}function Qa(t){return{assign:Ua(t),remove:qa(t),list:Ba(t)}}function Wa(t){return async(e,a,r,n)=>{const o=new Date().toISOString();try{const s={tenant_id:e,user_id:a,resource_server_identifier:r.resource_server_identifier,permission_name:r.permission_name,organization_id:n||r.organization_id||"",created_at:o};return await t.insertInto("user_permissions").values(s).execute(),!0}catch(s){return s.code==="SQLITE_CONSTRAINT_PRIMARYKEY"||s.code==="SQLITE_CONSTRAINT_UNIQUE"||s.code==="SQLITE_CONSTRAINT"||s.message&&s.message.includes("UNIQUE constraint failed")||s.message&&s.message.includes("PRIMARY KEY constraint failed")?!0:(console.error("Error creating user permission:",s),!1)}}}function Va(t){return async(e,a,r,n)=>{try{let o=t.deleteFrom("user_permissions").where("tenant_id","=",e).where("user_id","=",a).where("resource_server_identifier","=",r.resource_server_identifier).where("permission_name","=",r.permission_name);return n!==void 0?o=o.where("organization_id","=",n):o=o.where("organization_id","=",""),await o.execute(),!0}catch(o){return console.error("Error removing user permission:",o),!1}}}function Ga(t){return async(e,a,r,n)=>{let o=t.selectFrom("user_permissions").leftJoin("resource_servers",i=>i.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","=",e).where("user_permissions.user_id","=",a);return n!==void 0&&(o=o.where("user_permissions.organization_id","=",n)),(await o.execute()).map(i=>({resource_server_identifier:i.resource_server_identifier,permission_name:i.permission_name,description:null,resource_server_name:i.resource_server_name||i.resource_server_identifier,user_id:i.user_id,created_at:i.created_at,organization_id:i.organization_id===""?void 0:i.organization_id}))}}function Ya(t){return{create:Wa(t),remove:Va(t),list:Ga(t)}}function Ha(t){const e=Ya(t);return{create:(a,r,n,o)=>e.create(a,r,n,o),remove:(a,r,n,o)=>e.remove(a,r,n,o),list:(a,r,n,o)=>e.list(a,r,n,o)}}function Xa(t){return async(e,a,r,n)=>{let o=t.selectFrom("user_roles as ur").innerJoin("roles as r",i=>i.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","=",e).where("ur.user_id","=",a);return n!==void 0&&(o=o.where("ur.organization_id","=",n)),await o.execute()}}function Za(t){return async(e,a,r,n)=>{const o=new Date().toISOString();try{return await t.insertInto("user_roles").values({tenant_id:e,user_id:a,role_id:r,organization_id:n||"",created_at:o}).execute(),!0}catch(s){return s.code==="SQLITE_CONSTRAINT_PRIMARYKEY"||s.code==="SQLITE_CONSTRAINT_UNIQUE"||s.code==="SQLITE_CONSTRAINT"||s.message&&s.message.includes("UNIQUE constraint failed")||s.message&&s.message.includes("PRIMARY KEY constraint failed")?!0:(console.error("Error creating user role:",s),!1)}}}function er(t){return async(e,a,r,n)=>{try{let o=t.deleteFrom("user_roles").where("tenant_id","=",e).where("user_id","=",a).where("role_id","=",r);return n!==void 0?o=o.where("organization_id","=",n):o=o.where("organization_id","=",""),await o.execute(),!0}catch(o){return console.error("Error removing user roles:",o),!1}}}function tr(t){return{list:Xa(t),create:Za(t),remove:er(t)}}function ar(t){const e=tr(t);return{list:(a,r,n,o)=>e.list(a,r,n,o),create:(a,r,n,o)=>e.create(a,r,n,o),remove:(a,r,n,o)=>e.remove(a,r,n,o)}}function rr(t){return async(e,a)=>{const r={...a,id:a.id||S(),tenant_id:e,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),branding:JSON.stringify(a.branding||{}),metadata:JSON.stringify(a.metadata||{}),enabled_connections:JSON.stringify(a.enabled_connections||[]),token_quota:JSON.stringify(a.token_quota||{})};try{await t.insertInto("organizations").values(r).execute()}catch(n){throw n.code==="SQLITE_CONSTRAINT_UNIQUE"||n.message.includes("AlreadyExists")?new Q(409,{message:"Organization already exists"}):n}return{...a,id:r.id,created_at:r.created_at,updated_at:r.updated_at}}}function nr(t){return async(e,a)=>{const r=await t.selectFrom("organizations").selectAll().where("tenant_id","=",e).where("id","=",a).executeTakeFirst();return r?y({...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}}function or(t){return async(e,a)=>{let r=t.selectFrom("organizations").selectAll().where("tenant_id","=",e).orderBy("created_at","desc");if(a!=null&&a.per_page&&(r=r.limit(a.per_page)),a!=null&&a.page){const s=(a.page-1)*(a.per_page||10);r=r.offset(s)}const o=(await r.execute()).map(s=>y({...s,branding:s.branding?JSON.parse(s.branding):{},metadata:s.metadata?JSON.parse(s.metadata):{},enabled_connections:s.enabled_connections?JSON.parse(s.enabled_connections):[],token_quota:s.token_quota?JSON.parse(s.token_quota):{}}));return{organizations:o,start:a!=null&&a.page?(a.page-1)*(a.per_page||10):0,limit:(a==null?void 0:a.per_page)||o.length,length:o.length}}}function sr(t){return async(e,a)=>(await t.deleteFrom("organizations").where("tenant_id","=",e).where("id","=",a).execute()).length>0}function ir(t){return async(e,a,r)=>{const{branding:n,metadata:o,enabled_connections:s,token_quota:i,...c}=r,u={...c,updated_at:new Date().toISOString()};return n!==void 0&&(u.branding=JSON.stringify(n)),o!==void 0&&(u.metadata=JSON.stringify(o)),s!==void 0&&(u.enabled_connections=JSON.stringify(s)),i!==void 0&&(u.token_quota=JSON.stringify(i)),(await t.updateTable("organizations").set(u).where("tenant_id","=",e).where("id","=",a).execute()).length>0}}function lr(t){return{create:rr(t),get:nr(t),list:or(t),remove:sr(t),update:ir(t)}}function cr(t){return async(e,a)=>{const r={id:S(),tenant_id:e,user_id:a.user_id,organization_id:a.organization_id,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};try{await t.insertInto("user_organizations").values(r).execute()}catch(n){throw n.code==="SQLITE_CONSTRAINT_UNIQUE"||n.code==="ER_DUP_ENTRY"?new Q(409,{message:"User is already a member of this organization"}):n}return{...r}}}function dr(t){return async(e,a)=>{const r=await t.selectFrom("user_organizations").selectAll().where("id","=",a).where("tenant_id","=",e).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 ur(t){return async(e,a)=>{const r=(a==null?void 0:a.page)||0,n=(a==null?void 0:a.per_page)||50,o=r*n;let s=t.selectFrom("user_organizations").selectAll().where("tenant_id","=",e);if(a!=null&&a.q){if(a.q.startsWith("user_id:")){const d=a.q.replace("user_id:","");s=s.where("user_id","=",d)}else if(a.q.startsWith("organization_id:")){const d=a.q.replace("organization_id:","");s=s.where("organization_id","=",d)}}s=s.orderBy("created_at","desc"),n>0&&(s=s.limit(n).offset(o));const i=await s.execute();let c=t.selectFrom("user_organizations").select(t.fn.count("id").as("count")).where("tenant_id","=",e);if(a!=null&&a.q){if(a.q.startsWith("user_id:")){const d=a.q.replace("user_id:","");c=c.where("user_id","=",d)}else if(a.q.startsWith("organization_id:")){const d=a.q.replace("organization_id:","");c=c.where("organization_id","=",d)}}const u=await c.executeTakeFirst();return{userOrganizations:i.map(d=>({id:d.id,user_id:d.user_id,organization_id:d.organization_id,created_at:d.created_at,updated_at:d.updated_at})),start:o,limit:n,length:Number((u==null?void 0:u.count)||0)}}}function mr(t){return async(e,a,r)=>{const n=(r==null?void 0:r.page)||0,o=(r==null?void 0:r.per_page)||50,s=n*o;let i=t.selectFrom("user_organizations").innerJoin("organizations","organizations.id","user_organizations.organization_id").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","=",e).where("user_organizations.user_id","=",a);i=i.orderBy("user_organizations.created_at","desc"),o>0&&(i=i.limit(o).offset(s));const c=await i.execute(),u=await t.selectFrom("user_organizations").innerJoin("organizations","organizations.id","user_organizations.organization_id").select(t.fn.count("user_organizations.id").as("count")).where("user_organizations.tenant_id","=",e).where("user_organizations.user_id","=",a).executeTakeFirst();return{organizations:c.map(d=>({id:d.id,name:d.name,display_name:d.display_name,branding:d.branding?JSON.parse(d.branding):void 0,metadata:d.metadata?JSON.parse(d.metadata):{},enabled_connections:d.enabled_connections?JSON.parse(d.enabled_connections):[],token_quota:d.token_quota?JSON.parse(d.token_quota):void 0,created_at:d.created_at,updated_at:d.updated_at,joined_at:d.joined_at})),start:s,limit:o,length:Number((u==null?void 0:u.count)||0)}}}function _r(t){return async(e,a)=>(await t.deleteFrom("user_organizations").where("id","=",a).where("tenant_id","=",e).execute()).length>0}function hr(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString()};return(await t.updateTable("user_organizations").set(n).where("id","=",a).where("tenant_id","=",e).execute()).length>0}}function fr(t){return{create:cr(t),get:dr(t),list:ur(t),listUserOrganizations:mr(t),remove:_r(t),update:hr(t)}}function pr(t){return t[t.length-1]}function C(t){return Object.freeze(t)}const Y=C({is(t){return t.kind==="IdentifierNode"},create(t){return C({kind:"IdentifierNode",name:t})}}),ae=C({is(t){return t.kind==="SchemableIdentifierNode"},create(t){return C({kind:"SchemableIdentifierNode",identifier:Y.create(t)})},createWithSchema(t,e){return C({kind:"SchemableIdentifierNode",schema:Y.create(t),identifier:Y.create(e)})}}),gr=C({is(t){return t.kind==="AliasNode"},create(t,e){return C({kind:"AliasNode",node:t,alias:e})}}),Z=C({is(t){return t.kind==="TableNode"},create(t){return C({kind:"TableNode",table:ae.create(t)})},createWithSchema(t,e){return C({kind:"TableNode",table:ae.createWithSchema(t,e)})}});var H;class wr{constructor(){K(this,"nodeStack",[]);k(this,H,C({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),ForeignKeyConstraintNode:this.transformForeignKeyConstraint.bind(this),CreateViewNode:this.transformCreateView.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)}))}transformNode(e){if(!e)return e;this.nodeStack.push(e);const a=this.transformNodeImpl(e);return this.nodeStack.pop(),C(a)}transformNodeImpl(e){return m(this,H)[e.kind](e)}transformNodeList(e){return e&&C(e.map(a=>this.transformNode(a)))}transformSelectQuery(e){return{kind:"SelectQueryNode",from:this.transformNode(e.from),selections:this.transformNodeList(e.selections),distinctOn:this.transformNodeList(e.distinctOn),joins:this.transformNodeList(e.joins),groupBy:this.transformNode(e.groupBy),orderBy:this.transformNode(e.orderBy),where:this.transformNode(e.where),frontModifiers:this.transformNodeList(e.frontModifiers),endModifiers:this.transformNodeList(e.endModifiers),limit:this.transformNode(e.limit),offset:this.transformNode(e.offset),with:this.transformNode(e.with),having:this.transformNode(e.having),explain:this.transformNode(e.explain),setOperations:this.transformNodeList(e.setOperations),fetch:this.transformNode(e.fetch),top:this.transformNode(e.top)}}transformSelection(e){return{kind:"SelectionNode",selection:this.transformNode(e.selection)}}transformColumn(e){return{kind:"ColumnNode",column:this.transformNode(e.column)}}transformAlias(e){return{kind:"AliasNode",node:this.transformNode(e.node),alias:this.transformNode(e.alias)}}transformTable(e){return{kind:"TableNode",table:this.transformNode(e.table)}}transformFrom(e){return{kind:"FromNode",froms:this.transformNodeList(e.froms)}}transformReference(e){return{kind:"ReferenceNode",column:this.transformNode(e.column),table:this.transformNode(e.table)}}transformAnd(e){return{kind:"AndNode",left:this.transformNode(e.left),right:this.transformNode(e.right)}}transformOr(e){return{kind:"OrNode",left:this.transformNode(e.left),right:this.transformNode(e.right)}}transformValueList(e){return{kind:"ValueListNode",values:this.transformNodeList(e.values)}}transformParens(e){return{kind:"ParensNode",node:this.transformNode(e.node)}}transformJoin(e){return{kind:"JoinNode",joinType:e.joinType,table:this.transformNode(e.table),on:this.transformNode(e.on)}}transformRaw(e){return{kind:"RawNode",sqlFragments:C([...e.sqlFragments]),parameters:this.transformNodeList(e.parameters)}}transformWhere(e){return{kind:"WhereNode",where:this.transformNode(e.where)}}transformInsertQuery(e){return{kind:"InsertQueryNode",into:this.transformNode(e.into),columns:this.transformNodeList(e.columns),values:this.transformNode(e.values),returning:this.transformNode(e.returning),onConflict:this.transformNode(e.onConflict),onDuplicateKey:this.transformNode(e.onDuplicateKey),with:this.transformNode(e.with),ignore:e.ignore,replace:e.replace,explain:this.transformNode(e.explain),defaultValues:e.defaultValues,top:this.transformNode(e.top),output:this.transformNode(e.output)}}transformValues(e){return{kind:"ValuesNode",values:this.transformNodeList(e.values)}}transformDeleteQuery(e){return{kind:"DeleteQueryNode",from:this.transformNode(e.from),using:this.transformNode(e.using),joins:this.transformNodeList(e.joins),where:this.transformNode(e.where),returning:this.transformNode(e.returning),with:this.transformNode(e.with),orderBy:this.transformNode(e.orderBy),limit:this.transformNode(e.limit),explain:this.transformNode(e.explain),top:this.transformNode(e.top),output:this.transformNode(e.output)}}transformReturning(e){return{kind:"ReturningNode",selections:this.transformNodeList(e.selections)}}transformCreateTable(e){return{kind:"CreateTableNode",table:this.transformNode(e.table),columns:this.transformNodeList(e.columns),constraints:this.transformNodeList(e.constraints),temporary:e.temporary,ifNotExists:e.ifNotExists,onCommit:e.onCommit,frontModifiers:this.transformNodeList(e.frontModifiers),endModifiers:this.transformNodeList(e.endModifiers),selectQuery:this.transformNode(e.selectQuery)}}transformColumnDefinition(e){return{kind:"ColumnDefinitionNode",column:this.transformNode(e.column),dataType:this.transformNode(e.dataType),references:this.transformNode(e.references),primaryKey:e.primaryKey,autoIncrement:e.autoIncrement,unique:e.unique,notNull:e.notNull,unsigned:e.unsigned,defaultTo:this.transformNode(e.defaultTo),check:this.transformNode(e.check),generated:this.transformNode(e.generated),frontModifiers:this.transformNodeList(e.frontModifiers),endModifiers:this.transformNodeList(e.endModifiers),nullsNotDistinct:e.nullsNotDistinct,identity:e.identity,ifNotExists:e.ifNotExists}}transformAddColumn(e){return{kind:"AddColumnNode",column:this.transformNode(e.column)}}transformDropTable(e){return{kind:"DropTableNode",table:this.transformNode(e.table),ifExists:e.ifExists,cascade:e.cascade}}transformOrderBy(e){return{kind:"OrderByNode",items:this.transformNodeList(e.items)}}transformOrderByItem(e){return{kind:"OrderByItemNode",orderBy:this.transformNode(e.orderBy),direction:this.transformNode(e.direction)}}transformGroupBy(e){return{kind:"GroupByNode",items:this.transformNodeList(e.items)}}transformGroupByItem(e){return{kind:"GroupByItemNode",groupBy:this.transformNode(e.groupBy)}}transformUpdateQuery(e){return{kind:"UpdateQueryNode",table:this.transformNode(e.table),from:this.transformNode(e.from),joins:this.transformNodeList(e.joins),where:this.transformNode(e.where),updates:this.transformNodeList(e.updates),returning:this.transformNode(e.returning),with:this.transformNode(e.with),explain:this.transformNode(e.explain),limit:this.transformNode(e.limit),top:this.transformNode(e.top),output:this.transformNode(e.output)}}transformColumnUpdate(e){return{kind:"ColumnUpdateNode",column:this.transformNode(e.column),value:this.transformNode(e.value)}}transformLimit(e){return{kind:"LimitNode",limit:this.transformNode(e.limit)}}transformOffset(e){return{kind:"OffsetNode",offset:this.transformNode(e.offset)}}transformOnConflict(e){return{kind:"OnConflictNode",columns:this.transformNodeList(e.columns),constraint:this.transformNode(e.constraint),indexExpression:this.transformNode(e.indexExpression),indexWhere:this.transformNode(e.indexWhere),updates:this.transformNodeList(e.updates),updateWhere:this.transformNode(e.updateWhere),doNothing:e.doNothing}}transformOnDuplicateKey(e){return{kind:"OnDuplicateKeyNode",updates:this.transformNodeList(e.updates)}}transformCreateIndex(e){return{kind:"CreateIndexNode",name:this.transformNode(e.name),table:this.transformNode(e.table),columns:this.transformNodeList(e.columns),unique:e.unique,using:this.transformNode(e.using),ifNotExists:e.ifNotExists,where:this.transformNode(e.where),nullsNotDistinct:e.nullsNotDistinct}}transformList(e){return{kind:"ListNode",items:this.transformNodeList(e.items)}}transformDropIndex(e){return{kind:"DropIndexNode",name:this.transformNode(e.name),table:this.transformNode(e.table),ifExists:e.ifExists,cascade:e.cascade}}transformPrimaryKeyConstraint(e){return{kind:"PrimaryKeyConstraintNode",columns:this.transformNodeList(e.columns),name:this.transformNode(e.name)}}transformUniqueConstraint(e){return{kind:"UniqueConstraintNode",columns:this.transformNodeList(e.columns),name:this.transformNode(e.name),nullsNotDistinct:e.nullsNotDistinct}}transformForeignKeyConstraint(e){return{kind:"ForeignKeyConstraintNode",columns:this.transformNodeList(e.columns),references:this.transformNode(e.references),name:this.transformNode(e.name),onDelete:e.onDelete,onUpdate:e.onUpdate}}transformSetOperation(e){return{kind:"SetOperationNode",operator:e.operator,expression:this.transformNode(e.expression),all:e.all}}transformReferences(e){return{kind:"ReferencesNode",table:this.transformNode(e.table),columns:this.transformNodeList(e.columns),onDelete:e.onDelete,onUpdate:e.onUpdate}}transformCheckConstraint(e){return{kind:"CheckConstraintNode",expression:this.transformNode(e.expression),name:this.transformNode(e.name)}}transformWith(e){return{kind:"WithNode",expressions:this.transformNodeList(e.expressions),recursive:e.recursive}}transformCommonTableExpression(e){return{kind:"CommonTableExpressionNode",name:this.transformNode(e.name),materialized:e.materialized,expression:this.transformNode(e.expression)}}transformCommonTableExpressionName(e){return{kind:"CommonTableExpressionNameNode",table:this.transformNode(e.table),columns:this.transformNodeList(e.columns)}}transformHaving(e){return{kind:"HavingNode",having:this.transformNode(e.having)}}transformCreateSchema(e){return{kind:"CreateSchemaNode",schema:this.transformNode(e.schema),ifNotExists:e.ifNotExists}}transformDropSchema(e){return{kind:"DropSchemaNode",schema:this.transformNode(e.schema),ifExists:e.ifExists,cascade:e.cascade}}transformAlterTable(e){return{kind:"AlterTableNode",table:this.transformNode(e.table),renameTo:this.transformNode(e.renameTo),setSchema:this.transformNode(e.setSchema),columnAlterations:this.transformNodeList(e.columnAlterations),addConstraint:this.transformNode(e.addConstraint),dropConstraint:this.transformNode(e.dropConstraint),addIndex:this.transformNode(e.addIndex),dropIndex:this.transformNode(e.dropIndex)}}transformDropColumn(e){return{kind:"DropColumnNode",column:this.transformNode(e.column)}}transformRenameColumn(e){return{kind:"RenameColumnNode",column:this.transformNode(e.column),renameTo:this.transformNode(e.renameTo)}}transformAlterColumn(e){return{kind:"AlterColumnNode",column:this.transformNode(e.column),dataType:this.transformNode(e.dataType),dataTypeExpression:this.transformNode(e.dataTypeExpression),setDefault:this.transformNode(e.setDefault),dropDefault:e.dropDefault,setNotNull:e.setNotNull,dropNotNull:e.dropNotNull}}transformModifyColumn(e){return{kind:"ModifyColumnNode",column:this.transformNode(e.column)}}transformAddConstraint(e){return{kind:"AddConstraintNode",constraint:this.transformNode(e.constraint)}}transformDropConstraint(e){return{kind:"DropConstraintNode",constraintName:this.transformNode(e.constraintName),ifExists:e.ifExists,modifier:e.modifier}}transformCreateView(e){return{kind:"CreateViewNode",name:this.transformNode(e.name),temporary:e.temporary,orReplace:e.orReplace,ifNotExists:e.ifNotExists,materialized:e.materialized,columns:this.transformNodeList(e.columns),as:this.transformNode(e.as)}}transformDropView(e){return{kind:"DropViewNode",name:this.transformNode(e.name),ifExists:e.ifExists,materialized:e.materialized,cascade:e.cascade}}transformGenerated(e){return{kind:"GeneratedNode",byDefault:e.byDefault,always:e.always,identity:e.identity,stored:e.stored,expression:this.transformNode(e.expression)}}transformDefaultValue(e){return{kind:"DefaultValueNode",defaultValue:this.transformNode(e.defaultValue)}}transformOn(e){return{kind:"OnNode",on:this.transformNode(e.on)}}transformSelectModifier(e){return{kind:"SelectModifierNode",modifier:e.modifier,rawModifier:this.transformNode(e.rawModifier),of:this.transformNodeList(e.of)}}transformCreateType(e){return{kind:"CreateTypeNode",name:this.transformNode(e.name),enum:this.transformNode(e.enum)}}transformDropType(e){return{kind:"DropTypeNode",name:this.transformNode(e.name),ifExists:e.ifExists}}transformExplain(e){return{kind:"ExplainNode",format:e.format,options:this.transformNode(e.options)}}transformSchemableIdentifier(e){return{kind:"SchemableIdentifierNode",schema:this.transformNode(e.schema),identifier:this.transformNode(e.identifier)}}transformAggregateFunction(e){return{kind:"AggregateFunctionNode",aggregated:this.transformNodeList(e.aggregated),distinct:e.distinct,filter:this.transformNode(e.filter),func:e.func,over:this.transformNode(e.over)}}transformOver(e){return{kind:"OverNode",orderBy:this.transformNode(e.orderBy),partitionBy:this.transformNode(e.partitionBy)}}transformPartitionBy(e){return{kind:"PartitionByNode",items:this.transformNodeList(e.items)}}transformPartitionByItem(e){return{kind:"PartitionByItemNode",partitionBy:this.transformNode(e.partitionBy)}}transformBinaryOperation(e){return{kind:"BinaryOperationNode",leftOperand:this.transformNode(e.leftOperand),operator:this.transformNode(e.operator),rightOperand:this.transformNode(e.rightOperand)}}transformUnaryOperation(e){return{kind:"UnaryOperationNode",operator:this.transformNode(e.operator),operand:this.transformNode(e.operand)}}transformUsing(e){return{kind:"UsingNode",tables:this.transformNodeList(e.tables)}}transformFunction(e){return{kind:"FunctionNode",func:e.func,arguments:this.transformNodeList(e.arguments)}}transformCase(e){return{kind:"CaseNode",value:this.transformNode(e.value),when:this.transformNodeList(e.when),else:this.transformNode(e.else),isStatement:e.isStatement}}transformWhen(e){return{kind:"WhenNode",condition:this.transformNode(e.condition),result:this.transformNode(e.result)}}transformJSONReference(e){return{kind:"JSONReferenceNode",reference:this.transformNode(e.reference),traversal:this.transformNode(e.traversal)}}transformJSONPath(e){return{kind:"JSONPathNode",inOperator:this.transformNode(e.inOperator),pathLegs:this.transformNodeList(e.pathLegs)}}transformJSONPathLeg(e){return{kind:"JSONPathLegNode",type:e.type,value:e.value}}transformJSONOperatorChain(e){return{kind:"JSONOperatorChainNode",operator:this.transformNode(e.operator),values:this.transformNodeList(e.values)}}transformTuple(e){return{kind:"TupleNode",values:this.transformNodeList(e.values)}}transformMergeQuery(e){return{kind:"MergeQueryNode",into:this.transformNode(e.into),using:this.transformNode(e.using),whens:this.transformNodeList(e.whens),with:this.transformNode(e.with),top:this.transformNode(e.top),output:this.transformNode(e.output)}}transformMatched(e){return{kind:"MatchedNode",not:e.not,bySource:e.bySource}}transformAddIndex(e){return{kind:"AddIndexNode",name:this.transformNode(e.name),columns:this.transformNodeList(e.columns),unique:e.unique,using:this.transformNode(e.using),ifNotExists:e.ifNotExists}}transformCast(e){return{kind:"CastNode",expression:this.transformNode(e.expression),dataType:this.transformNode(e.dataType)}}transformFetch(e){return{kind:"FetchNode",rowCount:this.transformNode(e.rowCount),modifier:e.modifier}}transformTop(e){return{kind:"TopNode",expression:e.expression,modifiers:e.modifiers}}transformOutput(e){return{kind:"OutputNode",selections:this.transformNodeList(e.selections)}}transformDataType(e){return e}transformSelectAll(e){return e}transformIdentifier(e){return e}transformValue(e){return e}transformPrimitiveValueList(e){return e}transformOperator(e){return e}transformDefaultInsertValue(e){return e}}H=new WeakMap;const yr=C({AlterTableNode:!0,CreateIndexNode:!0,CreateSchemaNode:!0,CreateTableNode:!0,CreateTypeNode:!0,CreateViewNode:!0,DeleteQueryNode:!0,DropIndexNode:!0,DropSchemaNode:!0,DropTableNode:!0,DropTypeNode:!0,DropViewNode:!0,InsertQueryNode:!0,RawNode:!0,SelectQueryNode:!0,UpdateQueryNode:!0,MergeQueryNode:!0});var L,j,F,N,we,ye,ve,M,re,Ne;class vr extends wr{constructor(a){super();k(this,N);k(this,L);k(this,j,new Set);k(this,F,new Set);U(this,L,a)}transformNodeImpl(a){if(!p(this,N,we).call(this,a))return super.transformNodeImpl(a);const r=p(this,N,ve).call(this,a);for(const s of r)m(this,F).add(s);const n=p(this,N,ye).call(this,a);for(const s of n)m(this,j).add(s);const o=super.transformNodeImpl(a);for(const s of n)m(this,j).delete(s);for(const s of r)m(this,F).delete(s);return o}transformSchemableIdentifier(a){const r=super.transformSchemableIdentifier(a);return r.schema||!m(this,j).has(a.identifier.name)?r:{...r,schema:Y.create(m(this,L))}}transformReferences(a){const r=super.transformReferences(a);return r.table.table.schema?r:{...r,table:Z.createWithSchema(m(this,L),r.table.table.identifier.name)}}}L=new WeakMap,j=new WeakMap,F=new WeakMap,N=new WeakSet,we=function(a){return a.kind in yr},ye=function(a){const r=new Set;if("name"in a&&a.name&&ae.is(a.name)&&p(this,N,re).call(this,a.name,r),"from"in a&&a.from)for(const n of a.from.froms)p(this,N,M).call(this,n,r);if("into"in a&&a.into&&p(this,N,M).call(this,a.into,r),"table"in a&&a.table&&p(this,N,M).call(this,a.table,r),"joins"in a&&a.joins)for(const n of a.joins)p(this,N,M).call(this,n.table,r);return"using"in a&&a.using&&p(this,N,M).call(this,a.using,r),r},ve=function(a){const r=new Set;return"with"in a&&a.with&&p(this,N,Ne).call(this,a.with,r),r},M=function(a,r){const n=Z.is(a)?a:gr.is(a)&&Z.is(a.node)?a.node:null;n&&p(this,N,re).call(this,n.table,r)},re=function(a,r){const n=a.identifier.name;!m(this,j).has(n)&&!m(this,F).has(n)&&r.add(n)},Ne=function(a,r){for(const n of a.expressions){const o=n.name.table.table.identifier.name;m(this,F).has(o)||r.add(o)}};var W;class Nr{constructor(e){k(this,W);U(this,W,new vr(e))}transformQuery(e){return m(this,W).transformNode(e.node)}async transformResult(e){return e.result}}W=new WeakMap;class Cr{transformQuery(e){return e.node}async transformResult(e){return e.result}}const br="kysely_migration",he="kysely_migration_lock",xr=!1,ee="migration_lock",Tr=C({__noMigrations__:!0});var v,l,q,$,I,J,be,D,xe,Te,Se,Oe,ke,ne,E,oe,$e,Ie,De,se,Pe,ze,je,Fe,Ae,B;class Ce{constructor(e){k(this,l);k(this,v);U(this,v,C(e))}async getMigrations(){const e=await p(this,l,E).call(this,m(this,l,I))?await m(this,v).db.withPlugin(m(this,l,D)).selectFrom(m(this,l,I)).select(["name","timestamp"]).execute():[];return(await p(this,l,se).call(this)).map(({name:r,...n})=>{const o=e.find(s=>s.name===r);return{name:r,migration:n,executedAt:o?new Date(o.timestamp):void 0}})}async migrateToLatest(){return p(this,l,q).call(this,()=>({direction:"Up",step:1/0}))}async migrateTo(e){return p(this,l,q).call(this,({migrations:a,executedMigrations:r,pendingMigrations:n})=>{if(e===Tr)return{direction:"Down",step:1/0};if(!a.find(i=>i.name===e))throw new Error(`migration "${e}" doesn't exist`);const o=r.indexOf(e),s=n.findIndex(i=>i.name===e);if(o!==-1)return{direction:"Down",step:r.length-o-1};if(s!==-1)return{direction:"Up",step:s+1};throw new Error(`migration "${e}" isn't executed or pending`)})}async migrateUp(){return p(this,l,q).call(this,()=>({direction:"Up",step:1}))}async migrateDown(){return p(this,l,q).call(this,()=>({direction:"Down",step:1}))}}v=new WeakMap,l=new WeakSet,q=async function(e){try{return await p(this,l,xe).call(this),await p(this,l,$e).call(this,e)}catch(a){return a instanceof te?a.resultSet:{error:a}}},$=function(){return m(this,v).migrationTableSchema},I=function(){return m(this,v).migrationTableName??br},J=function(){return m(this,v).migrationLockTableName??he},be=function(){return m(this,v).allowUnorderedMigrations??xr},D=function(){return m(this,l,$)?new Nr(m(this,l,$)):new Cr},xe=async function(){await p(this,l,Te).call(this),await p(this,l,Se).call(this),await p(this,l,Oe).call(this),await p(this,l,ke).call(this)},Te=async function(){if(m(this,l,$)&&!await p(this,l,ne).call(this))try{await p(this,l,B).call(this,m(this,v).db.schema.createSchema(m(this,l,$)))}catch(e){if(!await p(this,l,ne).call(this))throw e}},Se=async function(){if(!await p(this,l,E).call(this,m(this,l,I)))try{m(this,l,$)&&await p(this,l,B).call(this,m(this,v).db.schema.createSchema(m(this,l,$))),await p(this,l,B).call(this,m(this,v).db.schema.withPlugin(m(this,l,D)).createTable(m(this,l,I)).addColumn("name","varchar(255)",e=>e.notNull().primaryKey()).addColumn("timestamp","varchar(255)",e=>e.notNull()))}catch(e){if(!await p(this,l,E).call(this,m(this,l,I)))throw e}},Oe=async function(){if(!await p(this,l,E).call(this,m(this,l,J)))try{await p(this,l,B).call(this,m(this,v).db.schema.withPlugin(m(this,l,D)).createTable(m(this,l,J)).addColumn("id","varchar(255)",e=>e.notNull().primaryKey()).addColumn("is_locked","integer",e=>e.notNull().defaultTo(0)))}catch(e){if(!await p(this,l,E).call(this,m(this,l,J)))throw e}},ke=async function(){if(!await p(this,l,oe).call(this))try{await m(this,v).db.withPlugin(m(this,l,D)).insertInto(m(this,l,J)).values({id:ee,is_locked:0}).execute()}catch(e){if(!await p(this,l,oe).call(this))throw e}},ne=async function(){return(await m(this,v).db.introspection.getSchemas()).some(a=>a.name===m(this,l,$))},E=async function(e){const a=m(this,l,$);return(await m(this,v).db.introspection.getTables({withInternalKyselyTables:!0})).some(n=>n.name===e&&(!a||n.schema===a))},oe=async function(){return!!await m(this,v).db.withPlugin(m(this,l,D)).selectFrom(m(this,l,J)).where("id","=",ee).select("id").executeTakeFirst()},$e=async function(e){const a=m(this,v).db.getExecutor().adapter,r=C({lockTable:m(this,v).migrationLockTableName??he,lockRowId:ee,lockTableSchema:m(this,v).migrationTableSchema}),n=async o=>{try{await a.acquireMigrationLock(o,r);const s=await p(this,l,Ie).call(this,o);if(s.migrations.length===0)return{results:[]};const{direction:i,step:c}=e(s);return c<=0?{results:[]}:i==="Down"?await p(this,l,Fe).call(this,o,s,c):i==="Up"?await p(this,l,Ae).call(this,o,s,c):{results:[]}}finally{await a.releaseMigrationLock(o,r)}};return a.supportsTransactionalDdl?m(this,v).db.transaction().execute(n):m(this,v).db.connection().execute(n)},Ie=async function(e){const a=await p(this,l,se).call(this),r=await p(this,l,Pe).call(this,e);p(this,l,ze).call(this,a,r),m(this,l,be)||p(this,l,je).call(this,a,r);const n=p(this,l,De).call(this,a,r);return C({migrations:a,executedMigrations:r,lastMigration:pr(r),pendingMigrations:n})},De=function(e,a){return e.filter(r=>!a.includes(r.name))},se=async function(){const e=await m(this,v).provider.getMigrations();return Object.keys(e).sort().map(a=>({...e[a],name:a}))},Pe=async function(e){return(await e.withPlugin(m(this,l,D)).selectFrom(m(this,l,I)).select("name").orderBy(["timestamp","name"]).execute()).map(r=>r.name)},ze=function(e,a){for(const r of a)if(!e.some(n=>n.name===r))throw new Error(`corrupted migrations: previously executed migration ${r} is missing`)},je=function(e,a){for(let r=0;r<a.length;++r)if(e[r].name!==a[r])throw new Error(`corrupted migrations: expected previously executed migration ${a[r]} to be at index ${r} but ${e[r].name} was found in its place. New migrations must always have a name that comes alphabetically after the last executed migration.`)},Fe=async function(e,a,r){const n=a.executedMigrations.slice().reverse().slice(0,r).map(s=>a.migrations.find(i=>i.name===s)),o=n.map(s=>({migrationName:s.name,direction:"Down",status:"NotExecuted"}));for(let s=0;s<o.length;++s){const i=n[s];try{i.down&&(await i.down(e),await e.withPlugin(m(this,l,D)).deleteFrom(m(this,l,I)).where("name","=",i.name).execute(),o[s]={migrationName:i.name,direction:"Down",status:"Success"})}catch(c){throw o[s]={migrationName:i.name,direction:"Down",status:"Error"},new te({error:c,results:o})}}return{results:o}},Ae=async function(e,a,r){const o=a.pendingMigrations.slice(0,r).map(s=>({migrationName:s.name,direction:"Up",status:"NotExecuted"}));for(let s=0;s<o.length;s++){const i=a.pendingMigrations[s];try{await i.up(e),await e.withPlugin(m(this,l,D)).insertInto(m(this,l,I)).values({name:i.name,timestamp:new Date().toISOString()}).execute(),o[s]={migrationName:i.name,direction:"Up",status:"Success"}}catch(c){throw o[s]={migrationName:i.name,direction:"Up",status:"Error"},new te({error:c,results:o})}}return{results:o}},B=async function(e){m(this,v).db.getExecutor().adapter.supportsCreateIfNotExists&&(e=e.ifNotExists()),await e.execute()};var V;class te extends Error{constructor(a){super();k(this,V);U(this,V,a)}get resultSet(){return m(this,V)}}V=new WeakMap;class Me{constructor(e){K(this,"migrations");this.migrations=e}async getMigrations(){return this.migrations}}async function Sr(t){await t.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 t.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 t.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 t.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 t.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 t.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 t.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 Or(t){await t.schema.dropTable("domains").execute(),await t.schema.dropTable("members").execute(),await t.schema.dropTable("users").execute(),await t.schema.dropTable("connections").execute(),await t.schema.dropTable("applications").execute(),await t.schema.dropTable("migrations").execute(),await t.schema.dropTable("tenants").execute()}const kr=Object.freeze(Object.defineProperty({__proto__:null,down:Or,up:Sr},Symbol.toStringTag,{value:"Module"}));async function $r(t){await t.schema.alterTable("tenants").addColumn("support_url","varchar(255)").execute()}async function Ir(t){await t.schema.alterTable("tenants").dropColumn("support_url").execute()}const Dr=Object.freeze(Object.defineProperty({__proto__:null,down:Ir,up:$r},Symbol.toStringTag,{value:"Module"}));async function Pr(t){}async function zr(t){}const jr=Object.freeze(Object.defineProperty({__proto__:null,down:zr,up:Pr},Symbol.toStringTag,{value:"Module"}));async function Fr(t){await t.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 Ar(t){await t.schema.dropTable("logs").execute()}const Mr=Object.freeze(Object.defineProperty({__proto__:null,down:Ar,up:Fr},Symbol.toStringTag,{value:"Module"}));async function Jr(t){}async function Er(t){}const Lr=Object.freeze(Object.defineProperty({__proto__:null,down:Er,up:Jr},Symbol.toStringTag,{value:"Module"}));async function Rr(t){await t.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 t.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 t.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 t.schema.createIndex("otps_email_index").on("otps").column("email").execute(),await t.schema.createIndex("otps_expires_at_index").on("otps").column("expires_at").execute()}async function Kr(t){await t.schema.dropTable("sessions").execute(),await t.schema.dropTable("tickets").execute(),await t.schema.dropTable("otps").execute()}const Ur=Object.freeze(Object.defineProperty({__proto__:null,down:Kr,up:Rr},Symbol.toStringTag,{value:"Module"}));async function qr(t){await t.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 t.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 t.schema.createIndex("codes_expires_at_index").on("codes").column("expires_at").execute()}async function Br(t){await t.schema.dropTable("passwords").execute(),await t.schema.dropTable("codes").execute()}const Qr=Object.freeze(Object.defineProperty({__proto__:null,down:Br,up:qr},Symbol.toStringTag,{value:"Module"}));async function Wr(t){}async function Vr(t){}const Gr=Object.freeze(Object.defineProperty({__proto__:null,down:Vr,up:Wr},Symbol.toStringTag,{value:"Module"}));async function Yr(t){await t.schema.alterTable("passwords").addColumn("password","varchar(255)",e=>e.notNull()).execute()}async function Hr(t){await t.schema.alterTable("passwords").dropColumn("password").execute()}const Xr=Object.freeze(Object.defineProperty({__proto__:null,down:Hr,up:Yr},Symbol.toStringTag,{value:"Module"}));async function Zr(t){}async function en(t){}const tn=Object.freeze(Object.defineProperty({__proto__:null,down:en,up:Zr},Symbol.toStringTag,{value:"Module"}));async function an(t){}async function rn(t){}const nn=Object.freeze(Object.defineProperty({__proto__:null,down:rn,up:an},Symbol.toStringTag,{value:"Module"}));async function on(t){}async function sn(t){}const ln=Object.freeze(Object.defineProperty({__proto__:null,down:sn,up:on},Symbol.toStringTag,{value:"Module"}));async function cn(t){await t.schema.createIndex("users_email_index").on("users").column("email").execute()}async function dn(t){await t.schema.dropIndex("users_email_index").execute()}const un=Object.freeze(Object.defineProperty({__proto__:null,down:dn,up:cn},Symbol.toStringTag,{value:"Module"}));async function mn(t){await t.schema.alterTable("users").addColumn("profileData","varchar(2048)").execute()}async function _n(t){await t.schema.alterTable("users").dropColumn("profileData").execute()}const hn=Object.freeze(Object.defineProperty({__proto__:null,down:_n,up:mn},Symbol.toStringTag,{value:"Module"}));async function fn(t){await t.schema.createIndex("users_linked_to_index").on("users").column("linked_to").execute()}async function pn(t){await t.schema.dropIndex("users_linked_to_index")}const gn=Object.freeze(Object.defineProperty({__proto__:null,down:pn,up:fn},Symbol.toStringTag,{value:"Module"}));async function wn(t){await t.schema.alterTable("users").addColumn("locale","varchar(255)").execute()}async function yn(t){await t.schema.alterTable("users").dropColumn("locale").execute()}const vn=Object.freeze(Object.defineProperty({__proto__:null,down:yn,up:wn},Symbol.toStringTag,{value:"Module"}));async function Nn(t){await t.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 Cn(t){await t.schema.dropTable("keys").execute()}const bn=Object.freeze(Object.defineProperty({__proto__:null,down:Cn,up:Nn},Symbol.toStringTag,{value:"Module"}));async function xn(t){}async function Tn(t){}const Sn=Object.freeze(Object.defineProperty({__proto__:null,down:Tn,up:xn},Symbol.toStringTag,{value:"Module"}));async function On(t){}async function kn(t){}const $n=Object.freeze(Object.defineProperty({__proto__:null,down:kn,up:On},Symbol.toStringTag,{value:"Module"}));async function In(t){await t.schema.alterTable("otps").addColumn("audience","varchar(255)").execute()}async function Dn(t){await t.schema.alterTable("otps").dropColumn("audience").execute()}const Pn=Object.freeze(Object.defineProperty({__proto__:null,down:Dn,up:In},Symbol.toStringTag,{value:"Module"}));async function zn(t){}async function jn(t){}const Fn=Object.freeze(Object.defineProperty({__proto__:null,down:jn,up:zn},Symbol.toStringTag,{value:"Module"}));async function An(t){await t.schema.alterTable("logs").dropColumn("category").execute()}async function Mn(t){await t.schema.alterTable("logs").addColumn("category","varchar(255)",e=>e.notNull()).execute()}const Jn=Object.freeze(Object.defineProperty({__proto__:null,down:Mn,up:An},Symbol.toStringTag,{value:"Module"}));async function En(t){await t.schema.alterTable("users").dropColumn("tags").execute()}async function Ln(t){await t.schema.alterTable("users").addColumn("tags","varchar(255)").execute()}const Rn=Object.freeze(Object.defineProperty({__proto__:null,down:Ln,up:En},Symbol.toStringTag,{value:"Module"}));async function Kn(t){await t.schema.createIndex("logs_user_id").on("logs").column("user_id").execute(),await t.schema.createIndex("logs_tenant_id").on("logs").column("tenant_id").execute(),await t.schema.createIndex("logs_date").on("logs").column("date").execute()}async function Un(t){await t.schema.dropIndex("logs_user_id"),await t.schema.dropIndex("logs_tenant_id"),await t.schema.dropIndex("logs_date")}const qn=Object.freeze(Object.defineProperty({__proto__:null,down:Un,up:Kn},Symbol.toStringTag,{value:"Module"}));async function Bn(t){await t.schema.alterTable("logs").dropColumn("details").execute(),await t.schema.alterTable("logs").addColumn("details","varchar(8192)").execute()}async function Qn(t){await t.schema.alterTable("logs").dropColumn("details").execute(),await t.schema.alterTable("logs").addColumn("details","varchar(2048)").execute()}const Wn=Object.freeze(Object.defineProperty({__proto__:null,down:Qn,up:Bn},Symbol.toStringTag,{value:"Module"}));async function Vn(t){await t.schema.alterTable("logs").addColumn("user_name","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("auth0_client","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("isMobile","boolean").execute(),await t.schema.alterTable("logs").addColumn("connection","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("connection_id","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("audience","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("scope","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("strategy","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("strategy_type","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("hostname","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("session_connection","varchar(255)").execute()}async function Gn(t){await t.schema.alterTable("logs").dropColumn("user_name").execute(),await t.schema.alterTable("logs").dropColumn("auth0_client").execute(),await t.schema.alterTable("logs").dropColumn("isMobile").execute(),await t.schema.alterTable("logs").dropColumn("connection").execute(),await t.schema.alterTable("logs").dropColumn("connection_id").execute(),await t.schema.alterTable("logs").dropColumn("audience").execute(),await t.schema.alterTable("logs").dropColumn("scope").execute(),await t.schema.alterTable("logs").dropColumn("strategy").execute(),await t.schema.alterTable("logs").dropColumn("strategy_type").execute(),await t.schema.alterTable("logs").dropColumn("hostname").execute(),await t.schema.alterTable("logs").dropColumn("session_connection").execute()}const Yn=Object.freeze(Object.defineProperty({__proto__:null,down:Gn,up:Vn},Symbol.toStringTag,{value:"Module"}));async function Hn(t){await t.schema.createIndex("users_name_index").on("users").column("name").execute()}async function Xn(t){await t.schema.dropIndex("users_name_index").execute()}const Zn=Object.freeze(Object.defineProperty({__proto__:null,down:Xn,up:Hn},Symbol.toStringTag,{value:"Module"}));async function eo(t){}async function to(t){await t.schema.alterTable("users").dropConstraint("unique_email_provider").execute()}const ao=Object.freeze(Object.defineProperty({__proto__:null,down:to,up:eo},Symbol.toStringTag,{value:"Module"}));async function ro(t){await t.schema.alterTable("otps").dropColumn("state").execute(),await t.schema.alterTable("otps").addColumn("state","varchar(8192)").execute()}async function no(t){await t.schema.alterTable("otps").dropColumn("state").execute(),await t.schema.alterTable("otps").addColumn("state","varchar(1024)").execute()}const oo=Object.freeze(Object.defineProperty({__proto__:null,down:no,up:ro},Symbol.toStringTag,{value:"Module"}));async function so(t){await t.schema.alterTable("tickets").dropColumn("state").execute(),await t.schema.alterTable("tickets").addColumn("state","varchar(8192)").execute()}async function io(t){await t.schema.alterTable("tickets").dropColumn("state").execute(),await t.schema.alterTable("tickets").addColumn("state","varchar(1024)").execute()}const lo=Object.freeze(Object.defineProperty({__proto__:null,down:io,up:so},Symbol.toStringTag,{value:"Module"}));async function co(t){await t.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 uo(t){await t.schema.dropTable("branding").execute()}const mo=Object.freeze(Object.defineProperty({__proto__:null,down:uo,up:co},Symbol.toStringTag,{value:"Module"}));async function _o(t){}async function ho(t){}const fo=Object.freeze(Object.defineProperty({__proto__:null,down:ho,up:_o},Symbol.toStringTag,{value:"Module"}));async function po(t){}async function go(t){}const wo=Object.freeze(Object.defineProperty({__proto__:null,down:go,up:po},Symbol.toStringTag,{value:"Module"}));async function yo(t){}async function vo(t){}const No=Object.freeze(Object.defineProperty({__proto__:null,down:vo,up:yo},Symbol.toStringTag,{value:"Module"}));async function Co(t){}async function bo(t){}const xo=Object.freeze(Object.defineProperty({__proto__:null,down:bo,up:Co},Symbol.toStringTag,{value:"Module"}));async function To(t){await t.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 So(t){await t.schema.dropTable("authentication_codes").execute()}const Oo=Object.freeze(Object.defineProperty({__proto__:null,down:So,up:To},Symbol.toStringTag,{value:"Module"}));async function ko(t){}async function $o(t){}const Io=Object.freeze(Object.defineProperty({__proto__:null,down:$o,up:ko},Symbol.toStringTag,{value:"Module"}));async function Do(t){await t.schema.alterTable("otps").addColumn("ip","varchar(64)").execute()}async function Po(t){await t.schema.alterTable("otps").dropColumn("ip").execute()}const zo=Object.freeze(Object.defineProperty({__proto__:null,down:Po,up:Do},Symbol.toStringTag,{value:"Module"}));async function jo(t){await t.schema.alterTable("logs").dropColumn("user_agent").execute(),await t.schema.alterTable("logs").addColumn("user_agent","varchar(1024)").execute()}async function Fo(t){await t.schema.alterTable("logs").dropColumn("user_agent").execute(),await t.schema.alterTable("logs").addColumn("user_agent","varchar(255)").execute()}const Ao=Object.freeze(Object.defineProperty({__proto__:null,down:Fo,up:jo},Symbol.toStringTag,{value:"Module"}));async function Mo(t){}async function Jo(t){}const Eo=Object.freeze(Object.defineProperty({__proto__:null,down:Jo,up:Mo},Symbol.toStringTag,{value:"Module"}));async function Lo(t){await t.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 Ro(t){await t.schema.dropTable("hooks").execute()}const Ko=Object.freeze(Object.defineProperty({__proto__:null,down:Ro,up:Lo},Symbol.toStringTag,{value:"Module"}));async function Uo(t){}async function qo(t){}const Bo=Object.freeze(Object.defineProperty({__proto__:null,down:qo,up:Uo},Symbol.toStringTag,{value:"Module"}));async function Qo(t){}async function Wo(t){}const Vo=Object.freeze(Object.defineProperty({__proto__:null,down:Wo,up:Qo},Symbol.toStringTag,{value:"Module"}));async function Go(t){await t.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 t.schema.alterTable("passwords").addColumn("algorithm","varchar(16)").execute(),await t.schema.dropTable("codes").execute(),await t.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 Yo(t){await t.schema.dropTable("logins").execute(),await t.schema.alterTable("passwords").dropColumn("algorithm").execute(),await t.schema.dropTable("codes").execute(),await t.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()}const Ho=Object.freeze(Object.defineProperty({__proto__:null,down:Yo,up:Go},Symbol.toStringTag,{value:"Module"}));async function Xo(t){}async function Zo(t){}const es=Object.freeze(Object.defineProperty({__proto__:null,down:Zo,up:Xo},Symbol.toStringTag,{value:"Module"}));async function ts(t){await t.schema.alterTable("logins").addColumn("auth0Client","varchar(256)").execute()}async function as(t){await t.schema.alterTable("logins").dropColumn("auth0Client").execute()}const rs=Object.freeze(Object.defineProperty({__proto__:null,down:as,up:ts},Symbol.toStringTag,{value:"Module"}));async function ns(t){await t.schema.alterTable("logins").dropColumn("authParams_state").execute(),await t.schema.alterTable("logins").addColumn("authParams_state","varchar(8192)").execute()}async function os(t){await t.schema.alterTable("logins").dropColumn("authParams_state").execute(),await t.schema.alterTable("logins").addColumn("authParams_state","varchar(511)").execute()}const ss=Object.freeze(Object.defineProperty({__proto__:null,down:os,up:ns},Symbol.toStringTag,{value:"Module"}));async function is(t){}async function ls(t){}const cs=Object.freeze(Object.defineProperty({__proto__:null,down:ls,up:is},Symbol.toStringTag,{value:"Module"}));async function ds(t){}async function us(t){}const ms=Object.freeze(Object.defineProperty({__proto__:null,down:us,up:ds},Symbol.toStringTag,{value:"Module"}));async function _s(t){await t.schema.alterTable("logins").addColumn("authParams_nonce","varchar(255)").execute()}async function hs(t){await t.schema.alterTable("logins").dropColumn("nonce").execute()}const fs=Object.freeze(Object.defineProperty({__proto__:null,down:hs,up:_s},Symbol.toStringTag,{value:"Module"}));async function ps(t){}async function gs(t){}const ws=Object.freeze(Object.defineProperty({__proto__:null,down:gs,up:ps},Symbol.toStringTag,{value:"Module"}));async function ys(t){}async function vs(t){}const Ns=Object.freeze(Object.defineProperty({__proto__:null,down:vs,up:ys},Symbol.toStringTag,{value:"Module"}));async function Cs(t){await t.schema.dropTable("codes").execute(),await t.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 bs(t){await t.schema.dropTable("codes").execute(),await t.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()}const xs=Object.freeze(Object.defineProperty({__proto__:null,down:bs,up:Cs},Symbol.toStringTag,{value:"Module"}));async function Ts(t){await t.schema.dropTable("otps").execute(),await t.schema.dropTable("authentication_codes").execute()}async function Ss(t){await t.schema.alterTable("keys").addColumn("private_key","varchar(2048)").addColumn("public_key","varchar(2048)").execute(),await t.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 t.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()}const Os=Object.freeze(Object.defineProperty({__proto__:null,down:Ss,up:Ts},Symbol.toStringTag,{value:"Module"}));async function ks(t){await t.schema.createIndex("IDX_logs_tenant_date_type_user").on("logs").columns(["tenant_id","date","type","user_id"]).execute()}async function $s(t){await t.schema.dropIndex("IDX_logs_tenant_date_type_user").on("logs").execute()}const Is=Object.freeze(Object.defineProperty({__proto__:null,down:$s,up:ks},Symbol.toStringTag,{value:"Module"}));async function Ds(t){}async function Ps(t){}const zs=Object.freeze(Object.defineProperty({__proto__:null,down:Ps,up:Ds},Symbol.toStringTag,{value:"Module"}));async function js(t){await t.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 Fs(t){await t.schema.dropTable("prompt_settings").execute()}const As=Object.freeze(Object.defineProperty({__proto__:null,down:Fs,up:js},Symbol.toStringTag,{value:"Module"}));async function Ms(t){}async function Js(t){}const Es=Object.freeze(Object.defineProperty({__proto__:null,down:Js,up:Ms},Symbol.toStringTag,{value:"Module"}));async function Ls(t){}async function Rs(t){}const Ks=Object.freeze(Object.defineProperty({__proto__:null,down:Rs,up:Ls},Symbol.toStringTag,{value:"Module"}));async function Us(t){}async function qs(t){}const Bs=Object.freeze(Object.defineProperty({__proto__:null,down:qs,up:Us},Symbol.toStringTag,{value:"Module"}));async function Qs(t){await t.schema.alterTable("logins").addColumn("authParams_ui_locales","varchar(32)").execute()}async function Ws(t){await t.schema.alterTable("logins").dropColumn("authParams_ui_locales").execute()}const Vs=Object.freeze(Object.defineProperty({__proto__:null,down:Ws,up:Qs},Symbol.toStringTag,{value:"Module"}));async function Gs(t){await t.schema.alterTable("logins").addColumn("authParams_prompt","varchar(16)").execute()}async function Ys(t){await t.schema.alterTable("logins").dropColumn("authParams_prompt").execute()}const Hs=Object.freeze(Object.defineProperty({__proto__:null,down:Ys,up:Gs},Symbol.toStringTag,{value:"Module"}));async function Xs(t){}async function Zs(t){}const ei=Object.freeze(Object.defineProperty({__proto__:null,down:Zs,up:Xs},Symbol.toStringTag,{value:"Module"}));async function ti(t){await t.schema.alterTable("logins").addColumn("authParams_act_as","varchar(255)").execute()}async function ai(t){await t.schema.alterTable("logins").dropColumn("authParam_act_as").execute()}const ri=Object.freeze(Object.defineProperty({__proto__:null,down:ai,up:ti},Symbol.toStringTag,{value:"Module"}));async function ni(t){await t.schema.alterTable("codes").addColumn("code_verifier","varchar(128)").execute()}async function oi(t){await t.schema.alterTable("codes").dropColumn("code_verifier").execute()}const si=Object.freeze(Object.defineProperty({__proto__:null,down:oi,up:ni},Symbol.toStringTag,{value:"Module"}));async function ii(t){await t.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 li(t){await t.schema.dropTable("email_providers").execute()}const ci=Object.freeze(Object.defineProperty({__proto__:null,down:li,up:ii},Symbol.toStringTag,{value:"Module"}));async function di(t){await t.schema.dropTable("tickets").execute()}async function ui(t){await t.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()}const mi=Object.freeze(Object.defineProperty({__proto__:null,down:ui,up:di},Symbol.toStringTag,{value:"Module"}));async function _i(t){}async function hi(t){await t.schema.alterTable("logins").dropColumn("ip").dropColumn("useragent").execute()}const fi=Object.freeze(Object.defineProperty({__proto__:null,down:hi,up:_i},Symbol.toStringTag,{value:"Module"}));async function pi(t){await t.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 gi(t){await t.schema.dropTable("refresh_tokens").execute()}const wi=Object.freeze(Object.defineProperty({__proto__:null,down:gi,up:pi},Symbol.toStringTag,{value:"Module"}));async function yi(t){}async function vi(t){}const Ni=Object.freeze(Object.defineProperty({__proto__:null,down:vi,up:yi},Symbol.toStringTag,{value:"Module"}));async function Ci(t){await t.schema.dropTable("sessions").execute(),await t.schema.dropTable("refresh_tokens").execute()}async function bi(t){await t.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 t.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()}const xi=Object.freeze(Object.defineProperty({__proto__:null,down:bi,up:Ci},Symbol.toStringTag,{value:"Module"}));async function Ti(t){await t.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 t.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 Si(t){await t.schema.dropTable("sessions_2").execute(),await t.schema.dropTable("refresh_tokens_2").execute()}const Oi=Object.freeze(Object.defineProperty({__proto__:null,down:Si,up:Ti},Symbol.toStringTag,{value:"Module"}));async function ki(t){await t.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 t.schema.dropTable("domains").execute()}async function $i(t){await t.schema.dropTable("custom_domains").execute(),await t.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()}const Ii=Object.freeze(Object.defineProperty({__proto__:null,down:$i,up:ki},Symbol.toStringTag,{value:"Module"}));async function Di(t){}async function Pi(t){await t.schema.alterTable("logins").dropColumn("authParams_organization").dropColumn("authorization_url").execute()}const zi=Object.freeze(Object.defineProperty({__proto__:null,down:Pi,up:Di},Symbol.toStringTag,{value:"Module"}));async function ji(t){await t.schema.alterTable("logins").dropColumn("authorization_url").execute(),await t.schema.alterTable("logins").addColumn("authorization_url","varchar(2048)").execute()}async function Fi(t){await t.schema.alterTable("logins").dropColumn("authorization_url").execute(),await t.schema.alterTable("logins").addColumn("authorization_url","varchar(1024)").execute()}const Ai=Object.freeze(Object.defineProperty({__proto__:null,down:Fi,up:ji},Symbol.toStringTag,{value:"Module"}));async function Mi(t){}async function Ji(t){}const Ei=Object.freeze(Object.defineProperty({__proto__:null,down:Ji,up:Mi},Symbol.toStringTag,{value:"Module"}));async function Li(t){await t.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 t.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 t.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 Ri(t){await t.schema.dropTable("sessions").execute(),await t.schema.dropTable("login_sessions").execute(),await t.schema.dropTable("refresh_tokens").execute()}const Ki=Object.freeze(Object.defineProperty({__proto__:null,down:Ri,up:Li},Symbol.toStringTag,{value:"Module"}));async function Ui(t){await t.schema.dropTable("logins").execute(),await t.schema.dropTable("sessions_2").execute(),await t.schema.dropTable("refresh_tokens_2").execute()}async function qi(t){}const Bi=Object.freeze(Object.defineProperty({__proto__:null,down:qi,up:Ui},Symbol.toStringTag,{value:"Module"}));async function Qi(t){await t.schema.dropTable("custom_domains").execute(),await t.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 Wi(t){}const Vi=Object.freeze(Object.defineProperty({__proto__:null,down:Wi,up:Qi},Symbol.toStringTag,{value:"Module"}));async function Gi(t){}async function Yi(t){await t.schema.alterTable("users").dropColumn("phone_number").dropColumn("phone_verified").dropColumn("username").execute()}const Hi=Object.freeze(Object.defineProperty({__proto__:null,down:Yi,up:Gi},Symbol.toStringTag,{value:"Module"}));async function Xi(t){await t.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 t.schema.createIndex("forms_tenant_id_idx").on("forms").column("tenant_id").execute()}async function Zi(t){await t.schema.dropTable("forms").execute()}const el=Object.freeze(Object.defineProperty({__proto__:null,down:Zi,up:Xi},Symbol.toStringTag,{value:"Module"}));async function tl(t){await t.schema.alterTable("hooks").addColumn("form_id","text").execute(),await t.schema.alterTable("hooks").addColumn("url_tmp","varchar(512)").execute(),await t.updateTable("hooks").set(e=>({url_tmp:e.ref("url")})).execute(),await t.schema.alterTable("hooks").dropColumn("url").execute(),await t.schema.alterTable("hooks").renameColumn("url_tmp","url").execute()}async function al(t){await t.schema.dropTable("hooks").ifExists().execute(),await t.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()}const rl=Object.freeze(Object.defineProperty({__proto__:null,down:al,up:tl},Symbol.toStringTag,{value:"Module"}));async function nl(t){await t.schema.alterTable("login_sessions").addColumn("login_completed","boolean",e=>e.notNull().defaultTo(0)).execute()}async function ol(t){await t.schema.alterTable("login_sessions").dropColumn("login_completed").execute()}const sl=Object.freeze(Object.defineProperty({__proto__:null,down:ol,up:nl},Symbol.toStringTag,{value:"Module"}));async function il(t){await t.schema.alterTable("sessions").addColumn("login_session_id","varchar(21)",e=>e.references("login_sessions.id").onDelete("set null")).execute()}async function ll(t){await t.schema.alterTable("sessions").dropColumn("login_session_id").execute()}const cl=Object.freeze(Object.defineProperty({__proto__:null,down:ll,up:il},Symbol.toStringTag,{value:"Module"}));async function dl(t){await t.schema.createIndex("IDX_sessions_login_session_id").on("sessions").column("login_session_id").execute()}async function ul(t){await t.schema.dropIndex("IDX_sessions_login_session_id").on("sessions").execute()}const ml=Object.freeze(Object.defineProperty({__proto__:null,down:ul,up:dl},Symbol.toStringTag,{value:"Module"}));async function _l(t){await t.schema.alterTable("codes").addColumn("code_challenge","varchar(128)").execute(),await t.schema.alterTable("codes").addColumn("code_challenge_method","varchar(5)").execute()}async function hl(t){await t.schema.alterTable("codes").dropColumn("code_challenge").execute(),await t.schema.alterTable("codes").dropColumn("code_challenge_method").execute()}const fl=Object.freeze(Object.defineProperty({__proto__:null,down:hl,up:_l},Symbol.toStringTag,{value:"Module"}));async function pl(t){await t.schema.alterTable("codes").addColumn("redirect_uri","varchar(1024)").execute()}async function gl(t){await t.schema.alterTable("codes").dropColumn("redirect_uri").execute()}const wl=Object.freeze(Object.defineProperty({__proto__:null,down:gl,up:pl},Symbol.toStringTag,{value:"Module"}));async function yl(t){await t.schema.alterTable("codes").addColumn("nonce","varchar(1024)").execute(),await t.schema.alterTable("codes").addColumn("state","varchar(2048)").execute()}async function vl(t){await t.schema.alterTable("codes").dropColumn("nonce").execute(),await t.schema.alterTable("codes").dropColumn("state").execute()}const Nl=Object.freeze(Object.defineProperty({__proto__:null,down:vl,up:yl},Symbol.toStringTag,{value:"Module"}));async function Cl(t){await t.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 t.schema.createIndex("themes_tenant_id_idx").on("themes").column("tenant_id").execute()}async function bl(t){await t.schema.dropTable("themes").execute()}const xl=Object.freeze(Object.defineProperty({__proto__:null,down:bl,up:Cl},Symbol.toStringTag,{value:"Module"}));async function Tl(t){await t.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 t.schema.createIndex("resource_servers_tenant_identifier_uq").on("resource_servers").columns(["tenant_id","identifier"]).unique().execute(),await t.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 t.schema.createIndex("roles_tenant_name_uq").on("roles").columns(["tenant_id","name"]).unique().execute()}async function Sl(t){await t.schema.dropTable("roles").execute(),await t.schema.dropTable("resource_servers").execute()}const Ol=Object.freeze(Object.defineProperty({__proto__:null,down:Sl,up:Tl},Symbol.toStringTag,{value:"Module"}));async function kl(t){await t.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 t.schema.createIndex("role_permissions_role_fk").on("role_permissions").columns(["tenant_id","role_id"]).execute(),await t.schema.createIndex("role_permissions_permission_fk").on("role_permissions").columns(["tenant_id","resource_server_identifier","permission_name"]).execute(),await t.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 t.schema.createIndex("user_permissions_user_fk").on("user_permissions").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_permissions_permission_fk").on("user_permissions").columns(["tenant_id","resource_server_identifier","permission_name"]).execute()}async function $l(t){await t.schema.dropTable("user_permissions").execute(),await t.schema.dropTable("role_permissions").execute()}const Il=Object.freeze(Object.defineProperty({__proto__:null,down:$l,up:kl},Symbol.toStringTag,{value:"Module"}));async function Dl(t){await t.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 t.schema.createIndex("user_roles_user_fk").on("user_roles").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_roles_role_fk").on("user_roles").columns(["tenant_id","role_id"]).execute()}async function Pl(t){await t.schema.dropTable("user_roles").execute()}const zl=Object.freeze(Object.defineProperty({__proto__:null,down:Pl,up:Dl},Symbol.toStringTag,{value:"Module"}));async function jl(t){}async function Fl(t){await t.schema.alterTable("keys").dropColumn("connection").execute(),await t.schema.alterTable("keys").modifyColumn("cert","varchar(2048)").execute(),await t.schema.alterTable("keys").modifyColumn("pkcs7","varchar(2048)").execute(),await t.schema.alterTable("keys").dropColumn("type").execute()}const Al=Object.freeze(Object.defineProperty({__proto__:null,down:Fl,up:jl},Symbol.toStringTag,{value:"Module"}));async function Ml(t){await t.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 t.schema.createIndex("idx_organizations_tenant_id").on("organizations").column("tenant_id").execute(),await t.schema.createIndex("idx_organizations_tenant_name_unique").on("organizations").columns(["tenant_id","name"]).unique().execute()}async function Jl(t){await t.schema.dropTable("organizations").execute()}const El=Object.freeze(Object.defineProperty({__proto__:null,down:Jl,up:Ml},Symbol.toStringTag,{value:"Module"}));async function Ll(t){await t.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 t.schema.createIndex("idx_user_organizations_tenant_id").on("user_organizations").column("tenant_id").execute(),await t.schema.createIndex("idx_user_organizations_user_id").on("user_organizations").column("user_id").execute(),await t.schema.createIndex("idx_user_organizations_organization_id").on("user_organizations").column("organization_id").execute()}async function Rl(t){await t.schema.dropTable("user_organizations").execute()}const Kl=Object.freeze(Object.defineProperty({__proto__:null,down:Rl,up:Ll},Symbol.toStringTag,{value:"Module"}));async function Ul(t){await t.schema.dropTable("user_permissions").execute(),await t.schema.dropTable("user_roles").execute(),await t.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 t.schema.createIndex("user_permissions_user_fk").on("user_permissions").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_permissions_permission_fk").on("user_permissions").columns(["tenant_id","resource_server_identifier","permission_name"]).execute(),await t.schema.createIndex("user_permissions_organization_fk").on("user_permissions").column("organization_id").execute(),await t.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 t.schema.createIndex("user_roles_user_fk").on("user_roles").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_roles_role_fk").on("user_roles").columns(["tenant_id","role_id"]).execute(),await t.schema.createIndex("user_roles_organization_fk").on("user_roles").column("organization_id").execute()}async function ql(t){await t.schema.dropTable("user_permissions").execute(),await t.schema.dropTable("user_roles").execute(),await t.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 t.schema.createIndex("user_permissions_user_fk").on("user_permissions").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_permissions_permission_fk").on("user_permissions").columns(["tenant_id","resource_server_identifier","permission_name"]).execute(),await t.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 t.schema.createIndex("user_roles_user_fk").on("user_roles").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_roles_role_fk").on("user_roles").columns(["tenant_id","role_id"]).execute()}const Bl=Object.freeze(Object.defineProperty({__proto__:null,down:ql,up:Ul},Symbol.toStringTag,{value:"Module"})),Je={m1_init:kr,m2_magicLink:Dr,m3_updateAt:jr,m4_logTable:Mr,m5_userProfile:Lr,m6_sessions:Ur,m7_passwords:Qr,m8_logsTableNewFields:Gr,m9_passwordTableNewField:Xr,n01_codesTable:tn,n11_universalLoginSession:nn,n12_userFields:ln,n13_userEmailIndex:un,n14_profileDataField:hn,n15_userEmailIndex:gn,n16_userLocale:vn,n17_signingKeys:bn,n18_logsFields:Sn,n19_connectionsUserinfo:$n,n20_missingFields:Pn,n21_sessionDeletedAt:Fn,n22_dropLogsFields:Jn,n23_dropUsersFields:Rn,n24_logsIndexes:qn,n25_logDescMaxLength:Wn,n26_logsTableExtraFields:Yn,n27_usersTableNameIndex:Zn,n28_usersEmailConstrain:ao,n29_increaseOtpStateLength:oo,n30_increaseTicketStateLength:lo,n31_branding:mo,n32_indexesAndNotNull:fo,n33_vendorIdInUniversalLoginSession:wo,n34_auth0ClientInUniversalLoginSession:No,n35_increaseUniversalSessionStateLength:xo,n36_authenticationCodes:Oo,n37_disableSignUps:Io,n38_otpIpAddress:zo,n39_increaseUserAgentLength:Ao,n40_userId:Eo,n41_hooks:Ko,n42_userIdIndexes:Bo,n43_userIdIndexes:Vo,n44_codes:Ho,n45_hookProperties:es,n46_loginAuth0Client:rs,n47_loginAuth0Client:ss,n48_saml:cs,n49_removeFields:ms,n50_authParamsNonce:fs,n51_connectionid:ws,n52_cert:Ns,n53_codes_primary_key:xs,n54_cleanup_tables:Os,n55_logs_index:Is,n56_application_fields:zs,n57_prompt_settings:As,n58_connection_client_id:Es,n59_connection_options:Ks,n60_users_metadata:Bs,n61_userLocales:Vs,n62_prompt:Hs,n63_connection_cleanup:ei,n64_act_as:ri,n65_code_verifier:si,n66_email_providers:ci,n67_drop_tickets:mi,n68_login_useragents:fi,n70_refresh_tokens:wi,n71_session_new_fields:Ni,n72_session_primary_key:xi,n73_drop_sessions:Oi,n74_custom_domains:Ii,n75_organizations:zi,n76_authorization_url_length:Ai,n77_drop_sessions:Ei,n78_login_sessions:Ki,n79_drop_sessions_2:Bi,n80_recreate_custom_domains:Vi,n81_phone:Hi,n82_forms:el,n83_addFormsIdToHooks:rl,n84_login_completed:sl,n85_add_login_session_id_to_sessions:cl,n86_index_sessions_login_session_id:ml,n87_code_challenge:fl,n88_add_redirect_uri_to_codes:wl,n89_add_nonce_and_state_to_codes:Nl,n90_themes:xl,n91_resource_servers_rules_permissions:Ol,n92_role_permissions:Il,n93_add_permissions_to_roles:zl,n94_keys_connection_and_extend_columns:Al,n95_create_organizations_table:El,n96_create_user_organizations_table:Kl,n97_add_organization_to_user_permissions_and_roles:Bl};async function Ql(t,e=!1){e&&console.log("migrating...");const a=new Me(Je),r=new Ce({db:t,provider:a}),{error:n,results:o}=await r.migrateToLatest();if(o==null||o.forEach(s=>{s.status==="Success"?e&&console.log(`migration "${s.migrationName}" was executed successfully`):s.status==="Error"&&console.error(`failed to execute migration "${s.migrationName}"`)}),n)throw console.error("failed to migrate"),console.error(n),n}async function Wl(t){console.log("migrating...");const e=new Me(Je),a=new Ce({db:t,provider:e}),{error:r,results:n}=await a.migrateDown();if(n==null||n.forEach(o=>{o.status==="Success"?console.log(`migration "${o.migrationName}" was reverted successfully`):o.status==="Error"&&console.error(`failed to execute migration "${o.migrationName}"`)}),r)throw console.error("failed to migrate"),console.error(r),r}function Vl(t){return{applications:Ot(t),branding:Vt(t),cleanup:xa(t),clients:jt(t),codes:Nt(t),connections:zt(t),emailProviders:ga(t),customDomains:Bt(t),forms:Ia(t),hooks:ea(t),keys:Jt(t),loginSessions:da(t),logs:ot(t),passwords:ft(t),promptSettings:_a(t),refreshTokens:ba(t),resourceServers:Aa(t),rolePermissions:Qa(t),userPermissions:Ha(t),userRoles:ar(t),roles:Ka(t),sessions:ut(t),tenants:et(t),themes:oa(t),users:We(t),organizations:lr(t),userOrganizations:fr(t)}}exports.default=Vl;exports.migrateDown=Wl;exports.migrateToLatest=Ql;
1
+ "use strict";var Je=Object.defineProperty;var ce=t=>{throw TypeError(t)};var Le=(t,e,a)=>e in t?Je(t,e,{enumerable:!0,configurable:!0,writable:!0,value:a}):t[e]=a;var K=(t,e,a)=>Le(t,typeof e!="symbol"?e+"":e,a),X=(t,e,a)=>e.has(t)||ce("Cannot "+a);var m=(t,e,a)=>(X(t,e,"read from private field"),a?a.call(t):e.get(t)),k=(t,e,a)=>e.has(t)?ce("Cannot add the same private member more than once"):e instanceof WeakSet?e.add(t):e.set(t,a),U=(t,e,a,r)=>(X(t,e,"write to private field"),r?r.call(t,a):e.set(t,a),a),p=(t,e,a)=>(X(t,e,"access private method"),a);Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const x=require("@authhero/adapter-interfaces");require("@hono/zod-openapi");var Q=class extends Error{constructor(e=500,a){super(a==null?void 0:a.message,{cause:a==null?void 0:a.cause});K(this,"res");K(this,"status");this.res=a==null?void 0:a.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 Re(t){return async(e,a)=>{const{identities:r,...n}=a,o={...n,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),login_count:0,tenant_id:e,email_verified:a.email_verified?1:0,is_social:a.is_social?1:0,app_metadata:JSON.stringify(a.app_metadata),user_metadata:JSON.stringify(a.user_metadata)};try{await t.insertInto("users").values(o).execute()}catch(s){throw s.code==="SQLITE_CONSTRAINT_UNIQUE"||s.message.includes("AlreadyExists")?new Q(409,{message:"User already exists"}):new Q(500,{message:`${s.code}, ${s.message}`})}return{...o,email:o.email||"",email_verified:o.email_verified===1,is_social:o.is_social===1}}}function y(t){if(t==null||typeof t!="object")return t;if(Array.isArray(t))return t.map(a=>a!==null&&typeof a=="object"?y(a):a);const e={...t};for(const a in e){const r=e[a];r===null?delete e[a]:r!==null&&typeof r=="object"&&(Array.isArray(r)?e[a]=r.map(n=>n!==null&&typeof n=="object"?y(n):n):e[a]=y(r))}return e}function fe(t){let e={};try{e=JSON.parse(t.profileData||"{}")}catch(a){console.error("Error parsing profileData",a)}return{connection:t.connection,provider:t.provider,user_id:x.parseUserId(t.user_id).id,isSocial:!!t.is_social,profileData:{email:t.email,email_verified:!!t.email_verified,...e}}}function Ke(t){return async(e,a)=>{const[r,n]=await Promise.all([t.selectFrom("users").where("users.tenant_id","=",e).where("users.user_id","=",a).selectAll().executeTakeFirst(),t.selectFrom("users").where("users.tenant_id","=",e).where("users.linked_to","=",a).selectAll().execute()]);if(!r)return null;const{tenant_id:o,...s}=r,i={...s,email:r.email||"",email_verified:r.email_verified===1,is_social:r.is_social===1,app_metadata:JSON.parse(r.app_metadata),user_metadata:JSON.parse(r.user_metadata),identities:[{connection:r.connection,provider:r.provider,user_id:x.parseUserId(r.user_id).id,isSocial:!!r.is_social},...n.map(fe)]};return y(i)}}function O(t,e,a,r){return a.split(/\s+/).map(o=>o.replace(/^([^:]+)=/g,"$1:")).map(o=>{let s=o.startsWith("-"),i=null,d="",u=!1,_;if(o.startsWith("-_exists_:"))i=o.substring(10),u=!0,s=!0;else if(o.startsWith("_exists_:"))i=o.substring(9),u=!0,s=!1;else if(o.includes(":")){const c=s?o.substring(1):o,h=c.indexOf(":");i=c.substring(0,h),d=c.substring(h+1),u=!1,d.startsWith(">=")?(_=">=",d=d.substring(2)):d.startsWith(">")?(_=">",d=d.substring(1)):d.startsWith("<=")?(_="<=",d=d.substring(2)):d.startsWith("<")?(_="<",d=d.substring(1)):_="="}else i=null,d=o,u=!1;return{key:i,value:d,isNegation:s,isExistsQuery:u,operator:_}}).forEach(({key:o,value:s,isNegation:i,isExistsQuery:d,operator:u})=>{if(o)if(d)i?e=e.where(o,"is",null):e=e.where(o,"is not",null);else if(i)switch(u){case">":e=e.where(o,"<=",s);break;case">=":e=e.where(o,"<",s);break;case"<":e=e.where(o,">=",s);break;case"<=":e=e.where(o,">",s);break;default:e=e.where(o,"!=",s)}else e=e.where(o,u,s);else if(s){const{ref:_}=t.dynamic;e=e.where(c=>c.or(r.map(h=>c(_(h),"like",`%${s}%`))))}}),e}function T(t){return typeof t=="string"?parseInt(t,10):typeof t=="bigint"?Number(t):t}function Ue(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=a;let d=t.selectFrom("users").where("users.tenant_id","=",e);if(i&&(d=O(t,d,i,["email","name"])),s&&s.sort_by){const{ref:w}=t.dynamic;d=d.orderBy(w(s.sort_by),s.sort_order)}const _=await d.offset(r*n).limit(n).selectAll().execute(),c=_.map(w=>w.user_id),h=c.length?await t.selectFrom("users").selectAll().where("users.tenant_id","=",e).where("users.linked_to","in",c).execute():[],f=_.map(w=>{const b=h.filter(z=>z.linked_to===w.user_id);return y({...w,email_verified:w.email_verified===1,is_social:w.is_social===1,app_metadata:JSON.parse(w.app_metadata),user_metadata:JSON.parse(w.user_metadata),identities:[{connection:w.connection,provider:w.provider,user_id:x.parseUserId(w.user_id).id,isSocial:!!w.is_social},...b.map(fe)]})});if(!o)return{users:f,start:0,limit:0,length:0};const{count:g}=await d.select(w=>w.fn.countAll().as("count")).executeTakeFirstOrThrow();return{users:f,start:r*n,limit:n,length:T(g)}}}function qe(t){return async(e,a)=>(await t.deleteFrom("users").where("users.tenant_id","=",e).where("users.linked_to","=",a).execute(),(await t.deleteFrom("users").where("users.tenant_id","=",e).where("users.user_id","=",a).execute()).length===1)}function R(t,e="",a={}){for(let r in t)if(Object.prototype.hasOwnProperty.call(t,r)){const n=e?`${e}_${r}`:r,o=t[r];typeof o=="object"&&o!==null&&!Array.isArray(o)?R(o,n,a):typeof o=="boolean"?a[n]=o?1:0:a[n]=o}return a}function pe(t,e){const a={};for(const[r,n]of Object.entries(t)){const o=e.find(s=>r.startsWith(`${s}_`));if(!o)a[r]=n;else{const s=r.slice(o.length+1);a[o]={...a[o],[s]:n}}}return a}function Be(t){return async(e,a,r)=>{const n=R({...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});return(await t.updateTable("users").set(n).where("users.tenant_id","=",e).where("users.user_id","=",a).execute()).length===1}}function Qe(t){return async(e,a,r,n)=>{const o={linked_to:null};return(await t.updateTable("users").set(o).where("users.tenant_id","=",e).where("users.user_id","=",`${r}|${n}`).where("users.linked_to","=",`${a}`).execute()).length===1}}function We(t){return{create:Re(t),remove:qe(t),get:Ke(t),list:Ue(t),update:Be(t),unlink:Qe(t)}}const Ve="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";let S=(t=21)=>{let e="",a=crypto.getRandomValues(new Uint8Array(t));for(;t--;)e+=Ve[a[t]&63];return e};function Ge(t){return async e=>{const a={id:e.id||S(),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...e};return await t.insertInto("tenants").values(a).execute(),a}}function Ye(t){return async e=>{const a=await t.selectFrom("tenants").where("tenants.id","=",e).selectAll().executeTakeFirst();return a?y(a):null}}function He(t){return async e=>{let a=t.selectFrom("tenants");const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=e;if(s&&s.sort_by){const{ref:f}=t.dynamic;a=a.orderBy(f(s.sort_by),s.sort_order)}i&&(a=a.where(f=>f.or([f("name","like",`%${i}%`)])));const _=(await a.offset(r*n).limit(n).selectAll().execute()).map(y);if(!o)return{tenants:_};const{count:c}=await a.select(f=>f.fn.countAll().as("count")).executeTakeFirstOrThrow(),h=T(c);return{tenants:_,start:r*n,limit:n,length:h}}}function Xe(t){return async(e,a)=>{const r={...a,id:e,updated_at:new Date().toISOString()};await t.updateTable("tenants").set(r).where("id","=",e).execute()}}function Ze(t){return async e=>(await t.deleteFrom("tenants").where("tenants.id","=",e).execute()).length===1}function et(t){return{create:Ge(t),get:Ye(t),list:He(t),update:Xe(t),remove:Ze(t)}}function ue(t){return t?JSON.stringify(t):void 0}const tt=1024;function at(t){return async(e,a)=>{var n,o,s;const r={id:S(),...a,user_agent:a.user_agent.slice(0,tt)};return await t.insertInto("logs").values({...r,description:(n=r.description)==null?void 0:n.substring(0,256),isMobile:a.isMobile?1:0,tenant_id:e,scope:(o=a.scope)==null?void 0:o.join(","),auth0_client:ue(a.auth0_client),details:(s=ue(a.details))==null?void 0:s.substring(0,8192)}).execute(),r}}function me(t){if(!t)return"";try{return JSON.parse(t)}catch{return t}}function ge(t){return{...t,client_id:t.client_id,client_name:"",auth0_client:me(t.auth0_client),details:me(t.details),isMobile:!!t.isMobile,scope:t.scope?t.scope.split(","):void 0,log_id:t.id,_id:t.id}}function rt(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=a;let d=t.selectFrom("logs").where("logs.tenant_id","=",e);i&&(d=O(t,d,i,["user_id","ip"]));let u=d;if(s&&s.sort_by){const{ref:f}=t.dynamic;u=u.orderBy(f(s.sort_by),s.sort_order)}u=u.offset(r*n).limit(n);const c=(await u.selectAll().execute()).map(ge);if(!o)return{logs:c,start:0,limit:0,length:0};const{count:h}=await d.select(f=>f.fn.countAll().as("count")).executeTakeFirstOrThrow();return{logs:c,start:r*n,limit:n,length:T(h)}}}function nt(t){return async(e,a)=>{const r=await t.selectFrom("logs").where("logs.tenant_id","=",e).where("logs.id","=",a).selectAll().executeTakeFirst();return r?ge(r):null}}function ot(t){return{create:at(t),list:rt(t),get:nt(t)}}function st(t){return async(e,a)=>{const r=await t.selectFrom("sessions").where("sessions.tenant_id","=",e).where("sessions.id","=",a).selectAll().executeTakeFirst();if(!r)return null;const{tenant_id:n,device:o,clients:s,...i}=r;return{...i,device:JSON.parse(o),clients:JSON.parse(s)}}}function it(t){return async(e,a)=>{const r={...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),authenticated_at:new Date().toISOString(),last_interaction_at:new Date().toISOString()};return await t.insertInto("sessions").values({...r,tenant_id:e,device:JSON.stringify(a.device),clients:JSON.stringify(a.clients)}).execute(),r}}function lt(t){return async(e,a)=>!!(await t.deleteFrom("sessions").where("tenant_id","=",e).where("sessions.id","=",a).execute()).length}function dt(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString(),device:r.device?JSON.stringify(r.device):void 0,clients:r.clients?JSON.stringify(r.clients):void 0};return!!(await t.updateTable("sessions").set(n).where("tenant_id","=",e).where("sessions.id","=",a).execute()).length}}function ct(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=a;let d=t.selectFrom("sessions").where("sessions.tenant_id","=",e);i&&(d=O(t,d,i,["user_id","session_id"]));let u=d;if(s&&s.sort_by){const{ref:g}=t.dynamic;u=u.orderBy(g(s.sort_by),s.sort_order)}u=u.offset(r*n).limit(n);const c=(await u.selectAll().execute()).map(g=>({...g,device:JSON.parse(g.device),clients:JSON.parse(g.clients)}));if(!o)return{sessions:c,start:0,limit:0,length:0};const{count:h}=await d.select(g=>g.fn.countAll().as("count")).executeTakeFirstOrThrow(),f=T(h);return{sessions:c,start:r*n,limit:n,length:f}}}function ut(t){return{create:it(t),get:st(t),list:ct(t),remove:lt(t),update:dt(t)}}function mt(t){return async(e,a)=>{const r=await t.selectFrom("passwords").where("passwords.tenant_id","=",e).where("passwords.user_id","=",a).selectAll().executeTakeFirst();if(!r)return null;const{tenant_id:n,...o}=r;return o}}function _t(t){return async(e,a)=>{const r={...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return await t.insertInto("passwords").values({...r,tenant_id:e}).execute(),r}}function ht(t){return async(e,a)=>(await t.updateTable("passwords").set({password:a.password,updated_at:new Date().toISOString()}).where("tenant_id","=",e).where("user_id","=",a.user_id).execute()).length===1}function ft(t){return{create:_t(t),update:ht(t),get:mt(t)}}function pt(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("codes").where("codes.tenant_id","=",e);s&&(i=O(t,i,s,["code","login_id"]));const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>{const{tenant_id:f,...g}=h;return x.codeSchema.parse(y(g))});if(!o)return{codes:_,start:0,limit:0,length:0};const{count:c}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{codes:_,start:r*n,limit:n,length:T(c)}}}function gt(t){return async(e,a)=>{const r={...a,created_at:new Date().toISOString()};return await t.insertInto("codes").values({...r,tenant_id:e}).execute(),r}}function wt(t){return async(e,a)=>(await t.deleteFrom("codes").where("codes.tenant_id","=",e).where("codes.code_id","=",a).executeTakeFirst()).numDeletedRows>0}function yt(t){return async(e,a,r)=>{let n=t.selectFrom("codes").where("codes.code_id","=",a).where("codes.code_type","=",r);e.length&&(n=n.where("codes.tenant_id","=",e));const o=await n.selectAll().executeTakeFirst();return o?y(o):null}}function vt(t){return async(e,a)=>(await t.updateTable("codes").set({used_at:new Date().toISOString()}).where("codes.tenant_id","=",e).where("codes.code_id","=",a).executeTakeFirst()).numUpdatedRows>0}function Nt(t){return{create:gt(t),list:pt(t),remove:wt(t),used:vt(t),get:yt(t)}}function Ct(t){return async(e,a)=>{const r={created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...a,disable_sign_ups:a.disable_sign_ups??!1},n=JSON.stringify(a.allowed_origins),o=JSON.stringify(a.callbacks),s=JSON.stringify(a.web_origins),i=JSON.stringify(a.allowed_logout_urls),d=JSON.stringify(a.allowed_clients);return await t.insertInto("applications").values({...r,tenant_id:e,disable_sign_ups:a.disable_sign_ups?1:0,addons:a.addons?JSON.stringify(a.addons):"{}",callbacks:o,allowed_origins:n,web_origins:s,allowed_logout_urls:i,allowed_clients:d}).execute(),r}}function bt(t){return async e=>({applications:(await t.selectFrom("applications").where("applications.tenant_id","=",e).selectAll().execute()).map(o=>({...o,disable_sign_ups:!!o.disable_sign_ups,addons:o.addons?JSON.parse(o.addons):{},callbacks:o.callbacks?JSON.parse(o.callbacks):[],allowed_origins:o.allowed_origins?JSON.parse(o.allowed_origins):[],web_origins:o.web_origins?JSON.parse(o.web_origins):[],allowed_logout_urls:o.allowed_logout_urls?JSON.parse(o.allowed_logout_urls):[],allowed_clients:o.allowed_logout_urls?JSON.parse(o.allowed_logout_urls):[]}))})}function xt(t){return async(e,a)=>{const r=await t.selectFrom("applications").where("applications.tenant_id","=",e).where("applications.id","=",a).selectAll().executeTakeFirst();return r?y({...r,disable_sign_ups:!!r.disable_sign_ups,addons:JSON.parse(r.addons),callbacks:JSON.parse(r.callbacks),allowed_origins:JSON.parse(r.allowed_origins),web_origins:JSON.parse(r.web_origins),allowed_logout_urls:JSON.parse(r.allowed_logout_urls)}):null}}function Tt(t){return async(e,a)=>(await t.deleteFrom("applications").where("applications.tenant_id","=",e).where("applications.id","=",a).executeTakeFirst()).numDeletedRows>0}function St(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString(),allowed_origins:r.allowed_origins?JSON.stringify(r.allowed_origins):void 0,callbacks:r.callbacks?JSON.stringify(r.callbacks):void 0,web_origins:r.web_origins?JSON.stringify(r.web_origins):void 0,allowed_logout_urls:r.allowed_logout_urls?JSON.stringify(r.allowed_logout_urls):void 0,allowed_clients:r.allowed_clients?JSON.stringify(r.allowed_clients):void 0,addons:r.addons?JSON.stringify(r.addons):"{}",disable_sign_ups:r.disable_sign_ups?1:0};return await t.updateTable("applications").set(n).where("applications.id","=",a).where("applications.tenant_id","=",e).execute(),!0}}function Ot(t){return{create:Ct(t),list:bt(t),get:xt(t),remove:Tt(t),update:St(t)}}function kt(t){return async(e,a)=>{const r={id:S(),...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return await t.insertInto("connections").values({...r,options:JSON.stringify(r.options||{}),tenant_id:e}).execute(),r}}function $t(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("connections").where("connections.tenant_id","=",e);s&&(i=O(t,i,s,["user_id","ip"]));const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>y({...h,options:JSON.parse(h.options)}));if(!o)return{connections:_,start:0,limit:0,length:0};const{count:c}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{connections:_,start:r*n,limit:n,length:T(c)}}}function It(t){return async(e,a)=>(await t.deleteFrom("connections").where("connections.tenant_id","=",e).where("connections.id","=",a).executeTakeFirst()).numDeletedRows>0}function Dt(t){return async(e,a)=>{const r=await t.selectFrom("connections").where("connections.tenant_id","=",e).where("connections.id","=",a).selectAll().executeTakeFirst();return r?y({...r,options:JSON.parse(r.options)}):null}}function zt(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString()};return await t.updateTable("connections").set({...n,options:n.options?JSON.stringify(n.options):void 0}).where("connections.id","=",a).where("connections.tenant_id","=",e).execute(),!0}}function Pt(t){return{create:kt(t),get:Dt(t),list:$t(t),remove:It(t),update:zt(t)}}function jt(t){return{get:async e=>{const a=await t.selectFrom("applications").selectAll().where("id","=",e).executeTakeFirst();if(!a)return null;const r=await t.selectFrom("tenants").selectAll().where("id","=",a.tenant_id).executeTakeFirst();if(!r)throw new Q(404,{message:"Tenant not found"});const n=await t.selectFrom("connections").where("tenant_id","=",a.tenant_id).selectAll().execute();return{...a,connections:n.map(s=>x.connectionSchema.parse(y({...s,options:s.options?JSON.parse(s.options):{}}))),addons:a.addons?JSON.parse(a.addons):{},callbacks:a.callbacks?JSON.parse(a.callbacks):[],allowed_origins:a.allowed_origins?JSON.parse(a.allowed_origins):[],web_origins:a.web_origins?JSON.parse(a.web_origins):[],allowed_logout_urls:a.allowed_logout_urls?JSON.parse(a.allowed_logout_urls):[],allowed_clients:a.allowed_clients?JSON.parse(a.allowed_clients):[],tenant:y(r),disable_sign_ups:!!a.disable_sign_ups}}}}function Ft(t){return async(e={})=>{const{page:a=0,per_page:r=100,include_totals:n=!1,sort:o,q:s}=e;let i=t.selectFrom("keys").where(f=>f.or([f("revoked_at",">",new Date().toISOString()),f("revoked_at","is",null)]));s&&(i=O(t,i,s,["kid","connection","fingerprint","thumbprint","type"]));let d=i.select(f=>f.fn.count("kid").as("count"));const u=a*r;i=i.limit(r).offset(u),o&&(i=i.orderBy(o.sort_by,o.sort_order));const _=await i.selectAll().execute();if(!n)return{signingKeys:_,start:0,limit:0,length:0};const c=await d.executeTakeFirst(),h=T((c==null?void 0:c.count)??0);return{signingKeys:_,start:u,limit:r,length:h}}}function At(t){return async e=>{await t.insertInto("keys").values({...e,created_at:new Date().toDateString()}).execute()}}function Mt(t){return async(e,a)=>!!(await t.updateTable("keys").set(a).where("kid","=",e).execute()).length}function Et(t){return{create:At(t),list:Ft(t),update:Mt(t)}}function Jt(t){return async(e,a)=>{const r={custom_domain_id:S(),status:"pending",primary:!1,...a};return await t.insertInto("custom_domains").values({...r,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),tenant_id:e,primary:r.primary?1:0}).execute(),r}}function Lt(t){return async e=>(await t.selectFrom("custom_domains").where("custom_domains.tenant_id","=",e).selectAll().execute()).map(r=>({...r,primary:r.primary===1}))}function Rt(t){return async(e,a)=>(await t.deleteFrom("custom_domains").where("custom_domains.tenant_id","=",e).where("custom_domains.custom_domain_id","=",a).execute()).length>0}function Kt(t){return async(e,a)=>{const r=await t.selectFrom("custom_domains").where("custom_domains.tenant_id","=",e).where("custom_domains.custom_domain_id","=",a).selectAll().executeTakeFirst();return r?{...r,primary:r.primary===1}:null}}function Ut(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString(),primary:r.primary?1:0};return(await t.updateTable("custom_domains").set(n).where("custom_domains.tenant_id","=",e).where("custom_domains.custom_domain_id","=",a).execute()).length>0}}function qt(t){return async e=>{const a=await t.selectFrom("custom_domains").where("custom_domains.domain","=",e).selectAll().executeTakeFirst();return a?{...a,primary:a.primary===1}:null}}function Bt(t){return{create:Jt(t),get:Kt(t),getByDomain:qt(t),list:Lt(t),remove:Rt(t),update:Ut(t)}}function Qt(t){return async e=>{const[a]=await t.selectFrom("branding").where("branding.tenant_id","=",e).selectAll().execute();if(!a)return null;const{tenant_id:r,colors_primary:n,colors_page_background_type:o,colors_page_background_start:s,colors_page_background_end:i,colors_page_background_angle_dev:d,font_url:u,..._}=a;return y({..._,colors:{primary:n,page_background:{type:o,start:s,end:i,angle_deg:d}},font:u?{url:u}:void 0})}}function Wt(t){return async(e,a)=>{var s,i,d,u,_,c,h,f,g,w,b,z,A,P,G,ie,le,de;const{colors:r,font:n,...o}=a;try{await t.insertInto("branding").values({...o,colors_primary:r==null?void 0:r.primary,colors_page_background_type:(i=(s=a.colors)==null?void 0:s.page_background)==null?void 0:i.type,colors_page_background_start:(u=(d=a.colors)==null?void 0:d.page_background)==null?void 0:u.start,colors_page_background_end:(c=(_=a.colors)==null?void 0:_.page_background)==null?void 0:c.end,colors_page_background_angle_dev:(f=(h=a.colors)==null?void 0:h.page_background)==null?void 0:f.angle_deg,font_url:(g=a.font)==null?void 0:g.url,tenant_id:e}).execute()}catch{await t.updateTable("branding").set({...o,colors_primary:r==null?void 0:r.primary,colors_page_background_type:(b=(w=a.colors)==null?void 0:w.page_background)==null?void 0:b.type,colors_page_background_start:(A=(z=a.colors)==null?void 0:z.page_background)==null?void 0:A.start,colors_page_background_end:(G=(P=a.colors)==null?void 0:P.page_background)==null?void 0:G.end,colors_page_background_angle_dev:(le=(ie=a.colors)==null?void 0:ie.page_background)==null?void 0:le.angle_deg,font_url:(de=a.font)==null?void 0:de.url}).where("tenant_id","=",e).execute()}}}function Vt(t){return{get:Qt(t),set:Wt(t)}}function Gt(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("hooks").where("hooks.tenant_id","=",e);s&&(i=O(t,i,s,["url","form_id"]));const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>{const{tenant_id:f,enabled:g,synchronous:w,...b}=h;return y({...b,enabled:!!g,synchronous:!!w})});if(!o)return{hooks:_,start:0,limit:0,length:0};const{count:c}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{hooks:_,start:r*n,limit:n,length:T(c)}}}function Yt(t){return async(e,a)=>{const r=await t.selectFrom("hooks").where("hooks.tenant_id","=",e).where("hooks.hook_id","=",a).selectAll().executeTakeFirst();return r?y({...r,enabled:!!r.enabled,synchronous:!!r.synchronous}):null}}function Ht(t){return async(e,a)=>(await t.deleteFrom("hooks").where("hooks.tenant_id","=",e).where("hooks.hook_id","=",a).executeTakeFirst()).numDeletedRows>0}function Xt(t){return async(e,a)=>{const r={hook_id:S(),...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};return await t.insertInto("hooks").values({...r,tenant_id:e,enabled:a.enabled?1:0,synchronous:a.synchronous?1:0}).execute(),r}}function Zt(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString(),enabled:r.enabled!==void 0?r.enabled?1:0:void 0,synchronous:r.enabled!==void 0?r.synchronous?1:0:void 0};return await t.updateTable("hooks").set(n).where("hooks.hook_id","=",a).where("hooks.tenant_id","=",e).execute(),!0}}function ea(t){return{create:Xt(t),get:Yt(t),list:Gt(t),update:Zt(t),remove:Ht(t)}}function ta(t){return async(e,a)=>{const r={themeId:S(),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),...a},n={...r,tenant_id:e};return await t.insertInto("themes").values(R(n)).execute(),r}}function aa(t){return async(e,a)=>(await t.deleteFrom("themes").where("themes.tenant_id","=",e).where("themes.themeId","=",a).executeTakeFirst()).numDeletedRows>0}function ra(t){return async(e,a)=>{const r=await t.selectFrom("themes").where("themes.tenant_id","=",e).where("themes.themeId","=",a).selectAll().executeTakeFirst();if(!r)return null;const n={...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};return y(pe(n,["widget","colors","borders","fonts","page_background"]))}}function na(t){return async(e,a,r)=>{const n=R({...r,updated_at:new Date().toISOString()});return await t.updateTable("themes").set(n).where("themes.themeId","=",a).where("themes.tenant_id","=",e).execute(),!0}}function oa(t){return{create:ta(t),get:ra(t),remove:aa(t),update:na(t)}}function sa(t){return async(e,a)=>{const r=await t.selectFrom("login_sessions").where("login_sessions.id","=",a).selectAll().executeTakeFirst();return r?x.loginSessionSchema.parse(pe(y({...r,login_completed:!!r.login_completed}),["authParams"])):null}}function ia(t){return async(e,a)=>{var n;const r={id:S(),...a,authorization_url:(n=a.authorization_url)==null?void 0:n.slice(0,1024),created_at:new Date().toISOString(),updated_at:new Date().toISOString(),login_completed:!!a.login_completed};return await t.insertInto("login_sessions").values({...R(r),tenant_id:e}).execute(),r}}function la(t){return async(e,a,r)=>(await t.updateTable("login_sessions").set(R({...r})).where("login_sessions.id","=",a).where("login_sessions.tenant_id","=",e).execute()).length===1}function da(t){return async(e,a)=>(await t.deleteFrom("login_sessions").where("login_sessions.tenant_id","=",e).where("login_sessions.id","=",a).execute()).length>0}function ca(t){return{create:ia(t),get:sa(t),update:la(t),remove:da(t)}}function ua(t){return async e=>{const[a]=await t.selectFrom("prompt_settings").where("prompt_settings.tenant_id","=",e).selectAll().execute();return y({identifier_first:!!(a!=null&&a.identifier_first),password_first:!!(a!=null&&a.password_first),webauthn_platform_first_factor:!!(a!=null&&a.webauthn_platform_first_factor),universal_login_experience:(a==null?void 0:a.universal_login_experience)||"new"})}}function _e(t){return y({...t,webauthn_platform_first_factor:t.webauthn_platform_first_factor?!!t.webauthn_platform_first_factor:void 0,identifier_first:t.identifier_first?!!t.identifier_first:void 0,password_first:t.password_first?!!t.password_first:void 0,universal_login_experience:t.universal_login_experience})}function ma(t){return async(e,a)=>{try{const r=x.promptSettingSchema.parse(a);await t.insertInto("prompt_settings").values({..._e(r),tenant_id:e}).execute()}catch{await t.updateTable("prompt_settings").set(_e(a)).where("tenant_id","=",e).execute()}}}function _a(t){return{get:ua(t),set:ma(t)}}function ha(t){return async e=>{const[a]=await t.selectFrom("email_providers").where("email_providers.tenant_id","=",e).selectAll().execute();if(!a)return null;const{tenant_id:r,credentials:n,settings:o,enabled:s,...i}=a;return y({...i,credentials:JSON.parse(n),settings:JSON.parse(o),enabled:!!s})}}function fa(t){return async(e,a)=>{const{credentials:r,settings:n,enabled:o,...s}=a;await t.updateTable("email_providers").set({...s,credentials:r?JSON.stringify(r):void 0,settings:n?JSON.stringify(n):void 0,enabled:o!==void 0?o?1:0:void 0}).where("tenant_id","=",e).execute()}}function pa(t){return async(e,a)=>{const{credentials:r,settings:n,enabled:o,...s}=a;await t.insertInto("email_providers").values({...s,enabled:o?1:0,credentials:JSON.stringify(r),settings:JSON.stringify(n),tenant_id:e,created_at:new Date().toISOString(),updated_at:new Date().toISOString()}).execute()}}function ga(t){return{get:ha(t),create:pa(t),update:fa(t)}}function wa(t){return async(e,a)=>{const r=await t.selectFrom("refresh_tokens").where("refresh_tokens.tenant_id","=",e).where("refresh_tokens.id","=",a).selectAll().executeTakeFirst();return r?{...r,rotating:!!r.rotating,device:r.device?JSON.parse(r.device):{},resource_servers:r.resource_servers?JSON.parse(r.resource_servers):[]}:null}}function ya(t){return async(e,a)=>{const r={...a,created_at:new Date().toISOString()};return await t.insertInto("refresh_tokens").values({...r,tenant_id:e,rotating:a.rotating?1:0,device:JSON.stringify(a.device),resource_servers:JSON.stringify(a.resource_servers)}).execute(),{...a,...r}}}function va(t){return async(e,a)=>!!(await t.deleteFrom("refresh_tokens").where("tenant_id","=",e).where("refresh_tokens.id","=",a).execute()).length}function Na(t){return async(e,a,r)=>{const n={...r,device:r.device?JSON.stringify(r.device):void 0,resource_servers:r.resource_servers?JSON.stringify(r.resource_servers):void 0,rotating:r.rotating?1:0};return!!(await t.updateTable("refresh_tokens").set(n).where("tenant_id","=",e).where("refresh_tokens.id","=",a).execute()).length}}function Ca(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,sort:s,q:i}=a;let d=t.selectFrom("refresh_tokens").where("refresh_tokens.tenant_id","=",e);i&&(d=O(t,d,i,["token","session_id"]));let u=d;if(s&&s.sort_by){const{ref:g}=t.dynamic;u=u.orderBy(g(s.sort_by),s.sort_order)}u=u.offset(r*n).limit(n);const c=(await u.selectAll().execute()).map(g=>({...g,rotating:!!g.rotating,device:g.device?JSON.parse(g.device):{},resource_servers:g.resource_servers?JSON.parse(g.resource_servers):[]}));if(!o)return{refresh_tokens:c,start:0,limit:0,length:0};const{count:h}=await d.select(g=>g.fn.countAll().as("count")).executeTakeFirstOrThrow(),f=T(h);return{refresh_tokens:c,start:r*n,limit:n,length:f}}}function ba(t){return{create:ya(t),get:wa(t),list:Ca(t),remove:va(t),update:Na(t)}}function xa(t){return async()=>{const e=new Date(Date.now()-864e5).toISOString(),a=new Date(Date.now()-1e3*60*60*24*7).toISOString(),r=new Date(Date.now()-1e3*60*60*24*30*3).toISOString();console.log("delete codes"),await t.deleteFrom("codes").where("created_at","<",e).limit(1e5).execute(),console.log("delete sessions"),await t.deleteFrom("login_sessions").where("created_at","<",a).where("session_id","is",null).limit(1e5).execute(),console.log("delete logs"),await t.deleteFrom("logs").where("date","<",r).limit(1e5).execute(),console.log("delete refresh tokens"),await t.deleteFrom("refresh_tokens").where(o=>o.or([o("expires_at","<",a),o("idle_expires_at","<",a)])).limit(1e4).execute(),console.log("delete sessions");const n=await t.selectFrom("sessions").select("id").where(o=>o.or([o("expires_at","<",a),o("idle_expires_at","<",a)])).where("id","not in",t.selectFrom("refresh_tokens").select("session_id")).limit(1e5).execute();n.length>0&&await t.deleteFrom("sessions").where("id","in",n.map(o=>o.id)).execute(),console.log("cleanup complete")}}function Ta(t){return async(e,a)=>{const r=x.formSchema.parse({id:S(),...a,created_at:new Date().toISOString(),updated_at:new Date().toISOString()});return await t.insertInto("forms").values({...r,nodes:JSON.stringify(r.nodes||[]),start:JSON.stringify(r.start||{}),ending:JSON.stringify(r.ending||{}),tenant_id:e}).execute(),x.formSchema.parse(r)}}function Sa(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("forms").where("tenant_id","=",e);s&&(i=O(t,i,s,[]));const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>{const f={...h};if(typeof f.nodes=="string")try{f.nodes=JSON.parse(f.nodes)}catch{}if(typeof f.start=="string")try{f.start=JSON.parse(f.start)}catch{}if(typeof f.ending=="string")try{f.ending=JSON.parse(f.ending)}catch{}return x.formSchema.parse(y(f))});if(!o)return{forms:_,start:0,limit:0,length:0};const{count:c}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{forms:_,start:r*n,limit:n,length:T(c)}}}function Oa(t){return async(e,a)=>{const{numDeletedRows:r}=await t.deleteFrom("forms").where("id","=",a).where("tenant_id","=",e).executeTakeFirst();return r>0}}function ka(t){return async(e,a)=>{const r=await t.selectFrom("forms").selectAll().where("forms.id","=",a).where("tenant_id","=",e).executeTakeFirst();if(!r)return null;const n={...r};if(typeof n.nodes=="string")try{n.nodes=JSON.parse(n.nodes)}catch{}if(typeof n.start=="string")try{n.start=JSON.parse(n.start)}catch{}if(typeof n.ending=="string")try{n.ending=JSON.parse(n.ending)}catch{}return x.formSchema.parse(y(n))}}function $a(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString()};r.nodes&&(n.nodes=JSON.stringify(r.nodes)),r.start&&(n.start=JSON.stringify(r.start)),r.ending&&(n.ending=JSON.stringify(r.ending));const{numUpdatedRows:o}=await t.updateTable("forms").set(n).where("id","=",a).where("tenant_id","=",e).executeTakeFirst();return o>0}}function Ia(t){return{create:Ta(t),get:ka(t),list:Sa(t),remove:Oa(t),update:$a(t)}}function Da(t){return async(e,a)=>{const r=new Date().toISOString(),n={id:S(),...a,created_at:r,updated_at:r},o=x.resourceServerSchema.parse(n),{verificationKey:s,scopes:i,options:d,skip_consent_for_verifiable_first_party_clients:u,allow_offline_access:_,...c}=o,h={...c,tenant_id:e,scopes:i?JSON.stringify(i):"[]",options:d?JSON.stringify(d):"{}",skip_consent_for_verifiable_first_party_clients:u?1:0,allow_offline_access:_?1:0,verification_key:s,created_at:r,updated_at:r};return await t.insertInto("resource_servers").values(h).execute(),y(o)}}function za(t){return async(e,a)=>{const r=await t.selectFrom("resource_servers").selectAll().where("tenant_id","=",e).where("id","=",a).executeTakeFirst();if(!r)return null;const n=r,{verification_key:o,scopes:s,options:i,skip_consent_for_verifiable_first_party_clients:d,allow_offline_access:u,..._}=n,c={..._,scopes:s?JSON.parse(s):[],options:i?JSON.parse(i):{},skip_consent_for_verifiable_first_party_clients:!!d,allow_offline_access:!!u,verificationKey:o};return y(c)}}function Pa(t){return async(e,a={})=>{const{page:r=0,per_page:n=50,include_totals:o=!1,q:s}=a;let i=t.selectFrom("resource_servers").where("resource_servers.tenant_id","=",e);if(s){const h=s.trim(),f=h.split(/\s+/),g=f.length===1?f[0]:void 0,w=g?g.match(/^(-)?(name|identifier):(.*)$/):null,b=w?w[3]:"",z=/^(>=|>|<=|<)/.test(b||"");if(w&&!z){const A=!!w[1],P=w[2]==="name"?"resource_servers.name":"resource_servers.identifier";i=A?i.where(P,"not like",`%${b}%`):i.where(P,"like",`%${b}%`)}else i=O(t,i,h,["resource_servers.name","resource_servers.identifier"])}const _=(await i.offset(r*n).limit(n).selectAll().execute()).map(h=>{const f=h,{verification_key:g,scopes:w,options:b,skip_consent_for_verifiable_first_party_clients:z,allow_offline_access:A,...P}=f,G={...P,scopes:w?JSON.parse(w):[],options:b?JSON.parse(b):{},skip_consent_for_verifiable_first_party_clients:!!z,allow_offline_access:!!A,verificationKey:g};return y(G)});if(!o)return{resource_servers:_,start:0,limit:0,length:0};const{count:c}=await i.select(h=>h.fn.countAll().as("count")).executeTakeFirstOrThrow();return{resource_servers:_,start:r*n,limit:n,length:T(c)}}}function ja(t){return async(e,a)=>{const r=await t.deleteFrom("resource_servers").where("tenant_id","=",e).where("id","=",a).executeTakeFirst();return Number(r.numDeletedRows)>0}}function Fa(t){return async(e,a,r)=>{const{verificationKey:n,scopes:o,options:s,skip_consent_for_verifiable_first_party_clients:i,allow_offline_access:d,...u}=r,_={...u,updated_at:new Date().toISOString()};n!==void 0&&(_.verification_key=n),o!==void 0&&(_.scopes=JSON.stringify(o)),s!==void 0&&(_.options=JSON.stringify(s)),i!==void 0&&(_.skip_consent_for_verifiable_first_party_clients=i?1:0),d!==void 0&&(_.allow_offline_access=d?1:0);const c=await t.updateTable("resource_servers").set(_).where("tenant_id","=",e).where("id","=",a).executeTakeFirst();return Number(c.numUpdatedRows)>0}}function Aa(t){return{create:Da(t),get:za(t),list:Pa(t),remove:ja(t),update:Fa(t)}}function Ma(t){return async(e,a)=>{const r=new Date().toISOString(),n=S(),o={id:n,...a,tenant_id:e,created_at:r,updated_at:r};return await t.insertInto("roles").values(o).execute(),{id:n,...a,created_at:r,updated_at:r}}}function Ea(t){return async(e,a)=>{const r=await t.selectFrom("roles").selectAll().where("roles.tenant_id","=",e).where("roles.id","=",a).executeTakeFirst();return r?{...r}:null}}function Ja(t){return async(e,a)=>{let r=t.selectFrom("roles").where("roles.tenant_id","=",e);const{page:n=0,per_page:o=50,include_totals:s=!1}=a;a.q&&(r=O(t,r,a.q,["name"]));const d=await r.offset(n*o).limit(o).selectAll().execute();if(!s)return{roles:d,start:n*o,limit:o,length:d.length};const{count:u}=await r.select(_=>_.fn.countAll().as("count")).executeTakeFirstOrThrow();return{roles:d,start:n*o,limit:o,length:T(u)}}}function La(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString()},o=await t.updateTable("roles").set(n).where("roles.tenant_id","=",e).where("roles.id","=",a).executeTakeFirst();return Number(o.numUpdatedRows)>0}}function Ra(t){return async(e,a)=>{const r=await t.deleteFrom("roles").where("tenant_id","=",e).where("id","=",a).executeTakeFirst();return Number(r.numDeletedRows)>0}}function Ka(t){return{create:Ma(t),get:Ea(t),list:Ja(t),update:La(t),remove:Ra(t)}}function Ua(t){return async(e,a,r)=>{if(r.length===0)return!0;const n=new Date().toISOString();try{for(const o of r){if(o.role_id!==a)throw new Error(`Permission role_id ${o.role_id} does not match expected role_id ${a}`);const s={tenant_id:e,role_id:o.role_id,resource_server_identifier:o.resource_server_identifier,permission_name:o.permission_name,created_at:n};try{await t.insertInto("role_permissions").values(s).execute()}catch(i){if(i.code==="SQLITE_CONSTRAINT_PRIMARYKEY"||i.code==="SQLITE_CONSTRAINT_UNIQUE")continue;throw i}}return!0}catch(o){return console.error("Error assigning role permissions:",o),!1}}}function qa(t){return async(e,a,r)=>{if(r.length===0)return!0;try{return(await Promise.all(r.map(o=>t.deleteFrom("role_permissions").where("tenant_id","=",e).where("role_id","=",a).where("resource_server_identifier","=",o.resource_server_identifier).where("permission_name","=",o.permission_name).executeTakeFirst()))).some(o=>Number(o.numDeletedRows)>0)}catch(n){return console.error("Error removing role permissions:",n),!1}}}function Ba(t){return async(e,a,r={})=>{const{page:n=0,per_page:o=50,include_totals:s=!1}=r;let i=t.selectFrom("role_permissions").leftJoin("resource_servers",c=>c.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","=",e).where("role_permissions.role_id","=",a);const _=(await i.offset(n*o).limit(o).execute()).map(c=>({role_id:c.role_id,resource_server_identifier:c.resource_server_identifier,resource_server_name:c.resource_server_name||c.resource_server_identifier,permission_name:c.permission_name,description:null,created_at:c.created_at}));return s&&await i.select(c=>c.fn.countAll().as("count")).executeTakeFirstOrThrow(),_}}function Qa(t){return{assign:Ua(t),remove:qa(t),list:Ba(t)}}function Wa(t){return async(e,a,r,n)=>{const o=new Date().toISOString();try{const s={tenant_id:e,user_id:a,resource_server_identifier:r.resource_server_identifier,permission_name:r.permission_name,organization_id:n||r.organization_id||"",created_at:o};return await t.insertInto("user_permissions").values(s).execute(),!0}catch(s){return s.code==="SQLITE_CONSTRAINT_PRIMARYKEY"||s.code==="SQLITE_CONSTRAINT_UNIQUE"||s.code==="SQLITE_CONSTRAINT"||s.message&&s.message.includes("UNIQUE constraint failed")||s.message&&s.message.includes("PRIMARY KEY constraint failed")?!0:(console.error("Error creating user permission:",s),!1)}}}function Va(t){return async(e,a,r,n)=>{try{let o=t.deleteFrom("user_permissions").where("tenant_id","=",e).where("user_id","=",a).where("resource_server_identifier","=",r.resource_server_identifier).where("permission_name","=",r.permission_name);return n!==void 0?o=o.where("organization_id","=",n):o=o.where("organization_id","=",""),await o.execute(),!0}catch(o){return console.error("Error removing user permission:",o),!1}}}function Ga(t){return async(e,a,r,n)=>{let o=t.selectFrom("user_permissions").leftJoin("resource_servers",i=>i.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","=",e).where("user_permissions.user_id","=",a);return n!==void 0&&(o=o.where("user_permissions.organization_id","=",n)),(await o.execute()).map(i=>({resource_server_identifier:i.resource_server_identifier,permission_name:i.permission_name,description:null,resource_server_name:i.resource_server_name||i.resource_server_identifier,user_id:i.user_id,created_at:i.created_at,organization_id:i.organization_id===""?void 0:i.organization_id}))}}function Ya(t){return{create:Wa(t),remove:Va(t),list:Ga(t)}}function Ha(t){const e=Ya(t);return{create:(a,r,n,o)=>e.create(a,r,n,o),remove:(a,r,n,o)=>e.remove(a,r,n,o),list:(a,r,n,o)=>e.list(a,r,n,o)}}function Xa(t){return async(e,a,r,n)=>{let o=t.selectFrom("user_roles as ur").innerJoin("roles as r",i=>i.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","=",e).where("ur.user_id","=",a);return n!==void 0&&(o=o.where("ur.organization_id","=",n)),await o.execute()}}function Za(t){return async(e,a,r,n)=>{const o=new Date().toISOString();try{return await t.insertInto("user_roles").values({tenant_id:e,user_id:a,role_id:r,organization_id:n||"",created_at:o}).execute(),!0}catch(s){return s.code==="SQLITE_CONSTRAINT_PRIMARYKEY"||s.code==="SQLITE_CONSTRAINT_UNIQUE"||s.code==="SQLITE_CONSTRAINT"||s.message&&s.message.includes("UNIQUE constraint failed")||s.message&&s.message.includes("PRIMARY KEY constraint failed")?!0:(console.error("Error creating user role:",s),!1)}}}function er(t){return async(e,a,r,n)=>{try{let o=t.deleteFrom("user_roles").where("tenant_id","=",e).where("user_id","=",a).where("role_id","=",r);return n!==void 0?o=o.where("organization_id","=",n):o=o.where("organization_id","=",""),await o.execute(),!0}catch(o){return console.error("Error removing user roles:",o),!1}}}function tr(t){return{list:Xa(t),create:Za(t),remove:er(t)}}function ar(t){const e=tr(t);return{list:(a,r,n,o)=>e.list(a,r,n,o),create:(a,r,n,o)=>e.create(a,r,n,o),remove:(a,r,n,o)=>e.remove(a,r,n,o)}}function rr(t){return async(e,a)=>{const r={...a,id:a.id||S(),tenant_id:e,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),branding:JSON.stringify(a.branding||{}),metadata:JSON.stringify(a.metadata||{}),enabled_connections:JSON.stringify(a.enabled_connections||[]),token_quota:JSON.stringify(a.token_quota||{})};try{await t.insertInto("organizations").values(r).execute()}catch(n){throw n.code==="SQLITE_CONSTRAINT_UNIQUE"||n.message.includes("AlreadyExists")?new Q(409,{message:"Organization already exists"}):n}return{...a,id:r.id,created_at:r.created_at,updated_at:r.updated_at}}}function nr(t){return async(e,a)=>{const r=await t.selectFrom("organizations").selectAll().where("tenant_id","=",e).where("id","=",a).executeTakeFirst();return r?y({...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}}function or(t){return async(e,a)=>{let r=t.selectFrom("organizations").selectAll().where("tenant_id","=",e).orderBy("created_at","desc");if(a!=null&&a.per_page&&(r=r.limit(a.per_page)),a!=null&&a.page){const s=(a.page-1)*(a.per_page||10);r=r.offset(s)}const o=(await r.execute()).map(s=>y({...s,branding:s.branding?JSON.parse(s.branding):{},metadata:s.metadata?JSON.parse(s.metadata):{},enabled_connections:s.enabled_connections?JSON.parse(s.enabled_connections):[],token_quota:s.token_quota?JSON.parse(s.token_quota):{}}));return{organizations:o,start:a!=null&&a.page?(a.page-1)*(a.per_page||10):0,limit:(a==null?void 0:a.per_page)||o.length,length:o.length}}}function sr(t){return async(e,a)=>(await t.deleteFrom("organizations").where("tenant_id","=",e).where("id","=",a).execute()).length>0}function ir(t){return async(e,a,r)=>{const{branding:n,metadata:o,enabled_connections:s,token_quota:i,...d}=r,u={...d,updated_at:new Date().toISOString()};return n!==void 0&&(u.branding=JSON.stringify(n)),o!==void 0&&(u.metadata=JSON.stringify(o)),s!==void 0&&(u.enabled_connections=JSON.stringify(s)),i!==void 0&&(u.token_quota=JSON.stringify(i)),(await t.updateTable("organizations").set(u).where("tenant_id","=",e).where("id","=",a).execute()).length>0}}function lr(t){return{create:rr(t),get:nr(t),list:or(t),remove:sr(t),update:ir(t)}}function dr(t){return async(e,a)=>{const r={id:S(),tenant_id:e,user_id:a.user_id,organization_id:a.organization_id,created_at:new Date().toISOString(),updated_at:new Date().toISOString()};try{await t.insertInto("user_organizations").values(r).execute()}catch(n){throw n.code==="SQLITE_CONSTRAINT_UNIQUE"||n.code==="ER_DUP_ENTRY"?new Q(409,{message:"User is already a member of this organization"}):n}return{...r}}}function cr(t){return async(e,a)=>{const r=await t.selectFrom("user_organizations").selectAll().where("id","=",a).where("tenant_id","=",e).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 ur(t){return async(e,a)=>{const r=(a==null?void 0:a.page)||0,n=(a==null?void 0:a.per_page)||50,o=r*n;let s=t.selectFrom("user_organizations").selectAll().where("tenant_id","=",e);if(a!=null&&a.q){if(a.q.startsWith("user_id:")){const c=a.q.replace("user_id:","");s=s.where("user_id","=",c)}else if(a.q.startsWith("organization_id:")){const c=a.q.replace("organization_id:","");s=s.where("organization_id","=",c)}}s=s.orderBy("created_at","desc"),n>0&&(s=s.limit(n).offset(o));const i=await s.execute();let d=t.selectFrom("user_organizations").select(t.fn.count("id").as("count")).where("tenant_id","=",e);if(a!=null&&a.q){if(a.q.startsWith("user_id:")){const c=a.q.replace("user_id:","");d=d.where("user_id","=",c)}else if(a.q.startsWith("organization_id:")){const c=a.q.replace("organization_id:","");d=d.where("organization_id","=",c)}}const u=await d.executeTakeFirst();return{userOrganizations:i.map(c=>({id:c.id,user_id:c.user_id,organization_id:c.organization_id,created_at:c.created_at,updated_at:c.updated_at})),start:o,limit:n,length:Number((u==null?void 0:u.count)||0)}}}function mr(t){return async(e,a,r)=>{const n=(r==null?void 0:r.page)||0,o=(r==null?void 0:r.per_page)||50,s=n*o;let i=t.selectFrom("user_organizations").innerJoin("organizations","organizations.id","user_organizations.organization_id").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","=",e).where("user_organizations.user_id","=",a);i=i.orderBy("user_organizations.created_at","desc"),o>0&&(i=i.limit(o).offset(s));const d=await i.execute(),u=await t.selectFrom("user_organizations").innerJoin("organizations","organizations.id","user_organizations.organization_id").select(t.fn.count("user_organizations.id").as("count")).where("user_organizations.tenant_id","=",e).where("user_organizations.user_id","=",a).executeTakeFirst();return{organizations:d.map(c=>({id:c.id,name:c.name,display_name:c.display_name,branding:c.branding?JSON.parse(c.branding):void 0,metadata:c.metadata?JSON.parse(c.metadata):{},enabled_connections:c.enabled_connections?JSON.parse(c.enabled_connections):[],token_quota:c.token_quota?JSON.parse(c.token_quota):void 0,created_at:c.created_at,updated_at:c.updated_at,joined_at:c.joined_at})),start:s,limit:o,length:Number((u==null?void 0:u.count)||0)}}}function _r(t){return async(e,a)=>(await t.deleteFrom("user_organizations").where("id","=",a).where("tenant_id","=",e).execute()).length>0}function hr(t){return async(e,a,r)=>{const n={...r,updated_at:new Date().toISOString()};return(await t.updateTable("user_organizations").set(n).where("id","=",a).where("tenant_id","=",e).execute()).length>0}}function fr(t){return{create:dr(t),get:cr(t),list:ur(t),listUserOrganizations:mr(t),remove:_r(t),update:hr(t)}}function pr(t){return t[t.length-1]}function C(t){return Object.freeze(t)}const Y=C({is(t){return t.kind==="IdentifierNode"},create(t){return C({kind:"IdentifierNode",name:t})}}),ae=C({is(t){return t.kind==="SchemableIdentifierNode"},create(t){return C({kind:"SchemableIdentifierNode",identifier:Y.create(t)})},createWithSchema(t,e){return C({kind:"SchemableIdentifierNode",schema:Y.create(t),identifier:Y.create(e)})}}),gr=C({is(t){return t.kind==="AliasNode"},create(t,e){return C({kind:"AliasNode",node:t,alias:e})}}),Z=C({is(t){return t.kind==="TableNode"},create(t){return C({kind:"TableNode",table:ae.create(t)})},createWithSchema(t,e){return C({kind:"TableNode",table:ae.createWithSchema(t,e)})}});var H;class wr{constructor(){K(this,"nodeStack",[]);k(this,H,C({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),ForeignKeyConstraintNode:this.transformForeignKeyConstraint.bind(this),CreateViewNode:this.transformCreateView.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)}))}transformNode(e){if(!e)return e;this.nodeStack.push(e);const a=this.transformNodeImpl(e);return this.nodeStack.pop(),C(a)}transformNodeImpl(e){return m(this,H)[e.kind](e)}transformNodeList(e){return e&&C(e.map(a=>this.transformNode(a)))}transformSelectQuery(e){return{kind:"SelectQueryNode",from:this.transformNode(e.from),selections:this.transformNodeList(e.selections),distinctOn:this.transformNodeList(e.distinctOn),joins:this.transformNodeList(e.joins),groupBy:this.transformNode(e.groupBy),orderBy:this.transformNode(e.orderBy),where:this.transformNode(e.where),frontModifiers:this.transformNodeList(e.frontModifiers),endModifiers:this.transformNodeList(e.endModifiers),limit:this.transformNode(e.limit),offset:this.transformNode(e.offset),with:this.transformNode(e.with),having:this.transformNode(e.having),explain:this.transformNode(e.explain),setOperations:this.transformNodeList(e.setOperations),fetch:this.transformNode(e.fetch),top:this.transformNode(e.top)}}transformSelection(e){return{kind:"SelectionNode",selection:this.transformNode(e.selection)}}transformColumn(e){return{kind:"ColumnNode",column:this.transformNode(e.column)}}transformAlias(e){return{kind:"AliasNode",node:this.transformNode(e.node),alias:this.transformNode(e.alias)}}transformTable(e){return{kind:"TableNode",table:this.transformNode(e.table)}}transformFrom(e){return{kind:"FromNode",froms:this.transformNodeList(e.froms)}}transformReference(e){return{kind:"ReferenceNode",column:this.transformNode(e.column),table:this.transformNode(e.table)}}transformAnd(e){return{kind:"AndNode",left:this.transformNode(e.left),right:this.transformNode(e.right)}}transformOr(e){return{kind:"OrNode",left:this.transformNode(e.left),right:this.transformNode(e.right)}}transformValueList(e){return{kind:"ValueListNode",values:this.transformNodeList(e.values)}}transformParens(e){return{kind:"ParensNode",node:this.transformNode(e.node)}}transformJoin(e){return{kind:"JoinNode",joinType:e.joinType,table:this.transformNode(e.table),on:this.transformNode(e.on)}}transformRaw(e){return{kind:"RawNode",sqlFragments:C([...e.sqlFragments]),parameters:this.transformNodeList(e.parameters)}}transformWhere(e){return{kind:"WhereNode",where:this.transformNode(e.where)}}transformInsertQuery(e){return{kind:"InsertQueryNode",into:this.transformNode(e.into),columns:this.transformNodeList(e.columns),values:this.transformNode(e.values),returning:this.transformNode(e.returning),onConflict:this.transformNode(e.onConflict),onDuplicateKey:this.transformNode(e.onDuplicateKey),with:this.transformNode(e.with),ignore:e.ignore,replace:e.replace,explain:this.transformNode(e.explain),defaultValues:e.defaultValues,top:this.transformNode(e.top),output:this.transformNode(e.output)}}transformValues(e){return{kind:"ValuesNode",values:this.transformNodeList(e.values)}}transformDeleteQuery(e){return{kind:"DeleteQueryNode",from:this.transformNode(e.from),using:this.transformNode(e.using),joins:this.transformNodeList(e.joins),where:this.transformNode(e.where),returning:this.transformNode(e.returning),with:this.transformNode(e.with),orderBy:this.transformNode(e.orderBy),limit:this.transformNode(e.limit),explain:this.transformNode(e.explain),top:this.transformNode(e.top),output:this.transformNode(e.output)}}transformReturning(e){return{kind:"ReturningNode",selections:this.transformNodeList(e.selections)}}transformCreateTable(e){return{kind:"CreateTableNode",table:this.transformNode(e.table),columns:this.transformNodeList(e.columns),constraints:this.transformNodeList(e.constraints),temporary:e.temporary,ifNotExists:e.ifNotExists,onCommit:e.onCommit,frontModifiers:this.transformNodeList(e.frontModifiers),endModifiers:this.transformNodeList(e.endModifiers),selectQuery:this.transformNode(e.selectQuery)}}transformColumnDefinition(e){return{kind:"ColumnDefinitionNode",column:this.transformNode(e.column),dataType:this.transformNode(e.dataType),references:this.transformNode(e.references),primaryKey:e.primaryKey,autoIncrement:e.autoIncrement,unique:e.unique,notNull:e.notNull,unsigned:e.unsigned,defaultTo:this.transformNode(e.defaultTo),check:this.transformNode(e.check),generated:this.transformNode(e.generated),frontModifiers:this.transformNodeList(e.frontModifiers),endModifiers:this.transformNodeList(e.endModifiers),nullsNotDistinct:e.nullsNotDistinct,identity:e.identity,ifNotExists:e.ifNotExists}}transformAddColumn(e){return{kind:"AddColumnNode",column:this.transformNode(e.column)}}transformDropTable(e){return{kind:"DropTableNode",table:this.transformNode(e.table),ifExists:e.ifExists,cascade:e.cascade}}transformOrderBy(e){return{kind:"OrderByNode",items:this.transformNodeList(e.items)}}transformOrderByItem(e){return{kind:"OrderByItemNode",orderBy:this.transformNode(e.orderBy),direction:this.transformNode(e.direction)}}transformGroupBy(e){return{kind:"GroupByNode",items:this.transformNodeList(e.items)}}transformGroupByItem(e){return{kind:"GroupByItemNode",groupBy:this.transformNode(e.groupBy)}}transformUpdateQuery(e){return{kind:"UpdateQueryNode",table:this.transformNode(e.table),from:this.transformNode(e.from),joins:this.transformNodeList(e.joins),where:this.transformNode(e.where),updates:this.transformNodeList(e.updates),returning:this.transformNode(e.returning),with:this.transformNode(e.with),explain:this.transformNode(e.explain),limit:this.transformNode(e.limit),top:this.transformNode(e.top),output:this.transformNode(e.output)}}transformColumnUpdate(e){return{kind:"ColumnUpdateNode",column:this.transformNode(e.column),value:this.transformNode(e.value)}}transformLimit(e){return{kind:"LimitNode",limit:this.transformNode(e.limit)}}transformOffset(e){return{kind:"OffsetNode",offset:this.transformNode(e.offset)}}transformOnConflict(e){return{kind:"OnConflictNode",columns:this.transformNodeList(e.columns),constraint:this.transformNode(e.constraint),indexExpression:this.transformNode(e.indexExpression),indexWhere:this.transformNode(e.indexWhere),updates:this.transformNodeList(e.updates),updateWhere:this.transformNode(e.updateWhere),doNothing:e.doNothing}}transformOnDuplicateKey(e){return{kind:"OnDuplicateKeyNode",updates:this.transformNodeList(e.updates)}}transformCreateIndex(e){return{kind:"CreateIndexNode",name:this.transformNode(e.name),table:this.transformNode(e.table),columns:this.transformNodeList(e.columns),unique:e.unique,using:this.transformNode(e.using),ifNotExists:e.ifNotExists,where:this.transformNode(e.where),nullsNotDistinct:e.nullsNotDistinct}}transformList(e){return{kind:"ListNode",items:this.transformNodeList(e.items)}}transformDropIndex(e){return{kind:"DropIndexNode",name:this.transformNode(e.name),table:this.transformNode(e.table),ifExists:e.ifExists,cascade:e.cascade}}transformPrimaryKeyConstraint(e){return{kind:"PrimaryKeyConstraintNode",columns:this.transformNodeList(e.columns),name:this.transformNode(e.name)}}transformUniqueConstraint(e){return{kind:"UniqueConstraintNode",columns:this.transformNodeList(e.columns),name:this.transformNode(e.name),nullsNotDistinct:e.nullsNotDistinct}}transformForeignKeyConstraint(e){return{kind:"ForeignKeyConstraintNode",columns:this.transformNodeList(e.columns),references:this.transformNode(e.references),name:this.transformNode(e.name),onDelete:e.onDelete,onUpdate:e.onUpdate}}transformSetOperation(e){return{kind:"SetOperationNode",operator:e.operator,expression:this.transformNode(e.expression),all:e.all}}transformReferences(e){return{kind:"ReferencesNode",table:this.transformNode(e.table),columns:this.transformNodeList(e.columns),onDelete:e.onDelete,onUpdate:e.onUpdate}}transformCheckConstraint(e){return{kind:"CheckConstraintNode",expression:this.transformNode(e.expression),name:this.transformNode(e.name)}}transformWith(e){return{kind:"WithNode",expressions:this.transformNodeList(e.expressions),recursive:e.recursive}}transformCommonTableExpression(e){return{kind:"CommonTableExpressionNode",name:this.transformNode(e.name),materialized:e.materialized,expression:this.transformNode(e.expression)}}transformCommonTableExpressionName(e){return{kind:"CommonTableExpressionNameNode",table:this.transformNode(e.table),columns:this.transformNodeList(e.columns)}}transformHaving(e){return{kind:"HavingNode",having:this.transformNode(e.having)}}transformCreateSchema(e){return{kind:"CreateSchemaNode",schema:this.transformNode(e.schema),ifNotExists:e.ifNotExists}}transformDropSchema(e){return{kind:"DropSchemaNode",schema:this.transformNode(e.schema),ifExists:e.ifExists,cascade:e.cascade}}transformAlterTable(e){return{kind:"AlterTableNode",table:this.transformNode(e.table),renameTo:this.transformNode(e.renameTo),setSchema:this.transformNode(e.setSchema),columnAlterations:this.transformNodeList(e.columnAlterations),addConstraint:this.transformNode(e.addConstraint),dropConstraint:this.transformNode(e.dropConstraint),addIndex:this.transformNode(e.addIndex),dropIndex:this.transformNode(e.dropIndex)}}transformDropColumn(e){return{kind:"DropColumnNode",column:this.transformNode(e.column)}}transformRenameColumn(e){return{kind:"RenameColumnNode",column:this.transformNode(e.column),renameTo:this.transformNode(e.renameTo)}}transformAlterColumn(e){return{kind:"AlterColumnNode",column:this.transformNode(e.column),dataType:this.transformNode(e.dataType),dataTypeExpression:this.transformNode(e.dataTypeExpression),setDefault:this.transformNode(e.setDefault),dropDefault:e.dropDefault,setNotNull:e.setNotNull,dropNotNull:e.dropNotNull}}transformModifyColumn(e){return{kind:"ModifyColumnNode",column:this.transformNode(e.column)}}transformAddConstraint(e){return{kind:"AddConstraintNode",constraint:this.transformNode(e.constraint)}}transformDropConstraint(e){return{kind:"DropConstraintNode",constraintName:this.transformNode(e.constraintName),ifExists:e.ifExists,modifier:e.modifier}}transformCreateView(e){return{kind:"CreateViewNode",name:this.transformNode(e.name),temporary:e.temporary,orReplace:e.orReplace,ifNotExists:e.ifNotExists,materialized:e.materialized,columns:this.transformNodeList(e.columns),as:this.transformNode(e.as)}}transformDropView(e){return{kind:"DropViewNode",name:this.transformNode(e.name),ifExists:e.ifExists,materialized:e.materialized,cascade:e.cascade}}transformGenerated(e){return{kind:"GeneratedNode",byDefault:e.byDefault,always:e.always,identity:e.identity,stored:e.stored,expression:this.transformNode(e.expression)}}transformDefaultValue(e){return{kind:"DefaultValueNode",defaultValue:this.transformNode(e.defaultValue)}}transformOn(e){return{kind:"OnNode",on:this.transformNode(e.on)}}transformSelectModifier(e){return{kind:"SelectModifierNode",modifier:e.modifier,rawModifier:this.transformNode(e.rawModifier),of:this.transformNodeList(e.of)}}transformCreateType(e){return{kind:"CreateTypeNode",name:this.transformNode(e.name),enum:this.transformNode(e.enum)}}transformDropType(e){return{kind:"DropTypeNode",name:this.transformNode(e.name),ifExists:e.ifExists}}transformExplain(e){return{kind:"ExplainNode",format:e.format,options:this.transformNode(e.options)}}transformSchemableIdentifier(e){return{kind:"SchemableIdentifierNode",schema:this.transformNode(e.schema),identifier:this.transformNode(e.identifier)}}transformAggregateFunction(e){return{kind:"AggregateFunctionNode",aggregated:this.transformNodeList(e.aggregated),distinct:e.distinct,filter:this.transformNode(e.filter),func:e.func,over:this.transformNode(e.over)}}transformOver(e){return{kind:"OverNode",orderBy:this.transformNode(e.orderBy),partitionBy:this.transformNode(e.partitionBy)}}transformPartitionBy(e){return{kind:"PartitionByNode",items:this.transformNodeList(e.items)}}transformPartitionByItem(e){return{kind:"PartitionByItemNode",partitionBy:this.transformNode(e.partitionBy)}}transformBinaryOperation(e){return{kind:"BinaryOperationNode",leftOperand:this.transformNode(e.leftOperand),operator:this.transformNode(e.operator),rightOperand:this.transformNode(e.rightOperand)}}transformUnaryOperation(e){return{kind:"UnaryOperationNode",operator:this.transformNode(e.operator),operand:this.transformNode(e.operand)}}transformUsing(e){return{kind:"UsingNode",tables:this.transformNodeList(e.tables)}}transformFunction(e){return{kind:"FunctionNode",func:e.func,arguments:this.transformNodeList(e.arguments)}}transformCase(e){return{kind:"CaseNode",value:this.transformNode(e.value),when:this.transformNodeList(e.when),else:this.transformNode(e.else),isStatement:e.isStatement}}transformWhen(e){return{kind:"WhenNode",condition:this.transformNode(e.condition),result:this.transformNode(e.result)}}transformJSONReference(e){return{kind:"JSONReferenceNode",reference:this.transformNode(e.reference),traversal:this.transformNode(e.traversal)}}transformJSONPath(e){return{kind:"JSONPathNode",inOperator:this.transformNode(e.inOperator),pathLegs:this.transformNodeList(e.pathLegs)}}transformJSONPathLeg(e){return{kind:"JSONPathLegNode",type:e.type,value:e.value}}transformJSONOperatorChain(e){return{kind:"JSONOperatorChainNode",operator:this.transformNode(e.operator),values:this.transformNodeList(e.values)}}transformTuple(e){return{kind:"TupleNode",values:this.transformNodeList(e.values)}}transformMergeQuery(e){return{kind:"MergeQueryNode",into:this.transformNode(e.into),using:this.transformNode(e.using),whens:this.transformNodeList(e.whens),with:this.transformNode(e.with),top:this.transformNode(e.top),output:this.transformNode(e.output)}}transformMatched(e){return{kind:"MatchedNode",not:e.not,bySource:e.bySource}}transformAddIndex(e){return{kind:"AddIndexNode",name:this.transformNode(e.name),columns:this.transformNodeList(e.columns),unique:e.unique,using:this.transformNode(e.using),ifNotExists:e.ifNotExists}}transformCast(e){return{kind:"CastNode",expression:this.transformNode(e.expression),dataType:this.transformNode(e.dataType)}}transformFetch(e){return{kind:"FetchNode",rowCount:this.transformNode(e.rowCount),modifier:e.modifier}}transformTop(e){return{kind:"TopNode",expression:e.expression,modifiers:e.modifiers}}transformOutput(e){return{kind:"OutputNode",selections:this.transformNodeList(e.selections)}}transformDataType(e){return e}transformSelectAll(e){return e}transformIdentifier(e){return e}transformValue(e){return e}transformPrimitiveValueList(e){return e}transformOperator(e){return e}transformDefaultInsertValue(e){return e}}H=new WeakMap;const yr=C({AlterTableNode:!0,CreateIndexNode:!0,CreateSchemaNode:!0,CreateTableNode:!0,CreateTypeNode:!0,CreateViewNode:!0,DeleteQueryNode:!0,DropIndexNode:!0,DropSchemaNode:!0,DropTableNode:!0,DropTypeNode:!0,DropViewNode:!0,InsertQueryNode:!0,RawNode:!0,SelectQueryNode:!0,UpdateQueryNode:!0,MergeQueryNode:!0});var L,j,F,N,we,ye,ve,M,re,Ne;class vr extends wr{constructor(a){super();k(this,N);k(this,L);k(this,j,new Set);k(this,F,new Set);U(this,L,a)}transformNodeImpl(a){if(!p(this,N,we).call(this,a))return super.transformNodeImpl(a);const r=p(this,N,ve).call(this,a);for(const s of r)m(this,F).add(s);const n=p(this,N,ye).call(this,a);for(const s of n)m(this,j).add(s);const o=super.transformNodeImpl(a);for(const s of n)m(this,j).delete(s);for(const s of r)m(this,F).delete(s);return o}transformSchemableIdentifier(a){const r=super.transformSchemableIdentifier(a);return r.schema||!m(this,j).has(a.identifier.name)?r:{...r,schema:Y.create(m(this,L))}}transformReferences(a){const r=super.transformReferences(a);return r.table.table.schema?r:{...r,table:Z.createWithSchema(m(this,L),r.table.table.identifier.name)}}}L=new WeakMap,j=new WeakMap,F=new WeakMap,N=new WeakSet,we=function(a){return a.kind in yr},ye=function(a){const r=new Set;if("name"in a&&a.name&&ae.is(a.name)&&p(this,N,re).call(this,a.name,r),"from"in a&&a.from)for(const n of a.from.froms)p(this,N,M).call(this,n,r);if("into"in a&&a.into&&p(this,N,M).call(this,a.into,r),"table"in a&&a.table&&p(this,N,M).call(this,a.table,r),"joins"in a&&a.joins)for(const n of a.joins)p(this,N,M).call(this,n.table,r);return"using"in a&&a.using&&p(this,N,M).call(this,a.using,r),r},ve=function(a){const r=new Set;return"with"in a&&a.with&&p(this,N,Ne).call(this,a.with,r),r},M=function(a,r){const n=Z.is(a)?a:gr.is(a)&&Z.is(a.node)?a.node:null;n&&p(this,N,re).call(this,n.table,r)},re=function(a,r){const n=a.identifier.name;!m(this,j).has(n)&&!m(this,F).has(n)&&r.add(n)},Ne=function(a,r){for(const n of a.expressions){const o=n.name.table.table.identifier.name;m(this,F).has(o)||r.add(o)}};var W;class Nr{constructor(e){k(this,W);U(this,W,new vr(e))}transformQuery(e){return m(this,W).transformNode(e.node)}async transformResult(e){return e.result}}W=new WeakMap;class Cr{transformQuery(e){return e.node}async transformResult(e){return e.result}}const br="kysely_migration",he="kysely_migration_lock",xr=!1,ee="migration_lock",Tr=C({__noMigrations__:!0});var v,l,q,$,I,E,be,D,xe,Te,Se,Oe,ke,ne,J,oe,$e,Ie,De,se,ze,Pe,je,Fe,Ae,B;class Ce{constructor(e){k(this,l);k(this,v);U(this,v,C(e))}async getMigrations(){const e=await p(this,l,J).call(this,m(this,l,I))?await m(this,v).db.withPlugin(m(this,l,D)).selectFrom(m(this,l,I)).select(["name","timestamp"]).execute():[];return(await p(this,l,se).call(this)).map(({name:r,...n})=>{const o=e.find(s=>s.name===r);return{name:r,migration:n,executedAt:o?new Date(o.timestamp):void 0}})}async migrateToLatest(){return p(this,l,q).call(this,()=>({direction:"Up",step:1/0}))}async migrateTo(e){return p(this,l,q).call(this,({migrations:a,executedMigrations:r,pendingMigrations:n})=>{if(e===Tr)return{direction:"Down",step:1/0};if(!a.find(i=>i.name===e))throw new Error(`migration "${e}" doesn't exist`);const o=r.indexOf(e),s=n.findIndex(i=>i.name===e);if(o!==-1)return{direction:"Down",step:r.length-o-1};if(s!==-1)return{direction:"Up",step:s+1};throw new Error(`migration "${e}" isn't executed or pending`)})}async migrateUp(){return p(this,l,q).call(this,()=>({direction:"Up",step:1}))}async migrateDown(){return p(this,l,q).call(this,()=>({direction:"Down",step:1}))}}v=new WeakMap,l=new WeakSet,q=async function(e){try{return await p(this,l,xe).call(this),await p(this,l,$e).call(this,e)}catch(a){return a instanceof te?a.resultSet:{error:a}}},$=function(){return m(this,v).migrationTableSchema},I=function(){return m(this,v).migrationTableName??br},E=function(){return m(this,v).migrationLockTableName??he},be=function(){return m(this,v).allowUnorderedMigrations??xr},D=function(){return m(this,l,$)?new Nr(m(this,l,$)):new Cr},xe=async function(){await p(this,l,Te).call(this),await p(this,l,Se).call(this),await p(this,l,Oe).call(this),await p(this,l,ke).call(this)},Te=async function(){if(m(this,l,$)&&!await p(this,l,ne).call(this))try{await p(this,l,B).call(this,m(this,v).db.schema.createSchema(m(this,l,$)))}catch(e){if(!await p(this,l,ne).call(this))throw e}},Se=async function(){if(!await p(this,l,J).call(this,m(this,l,I)))try{m(this,l,$)&&await p(this,l,B).call(this,m(this,v).db.schema.createSchema(m(this,l,$))),await p(this,l,B).call(this,m(this,v).db.schema.withPlugin(m(this,l,D)).createTable(m(this,l,I)).addColumn("name","varchar(255)",e=>e.notNull().primaryKey()).addColumn("timestamp","varchar(255)",e=>e.notNull()))}catch(e){if(!await p(this,l,J).call(this,m(this,l,I)))throw e}},Oe=async function(){if(!await p(this,l,J).call(this,m(this,l,E)))try{await p(this,l,B).call(this,m(this,v).db.schema.withPlugin(m(this,l,D)).createTable(m(this,l,E)).addColumn("id","varchar(255)",e=>e.notNull().primaryKey()).addColumn("is_locked","integer",e=>e.notNull().defaultTo(0)))}catch(e){if(!await p(this,l,J).call(this,m(this,l,E)))throw e}},ke=async function(){if(!await p(this,l,oe).call(this))try{await m(this,v).db.withPlugin(m(this,l,D)).insertInto(m(this,l,E)).values({id:ee,is_locked:0}).execute()}catch(e){if(!await p(this,l,oe).call(this))throw e}},ne=async function(){return(await m(this,v).db.introspection.getSchemas()).some(a=>a.name===m(this,l,$))},J=async function(e){const a=m(this,l,$);return(await m(this,v).db.introspection.getTables({withInternalKyselyTables:!0})).some(n=>n.name===e&&(!a||n.schema===a))},oe=async function(){return!!await m(this,v).db.withPlugin(m(this,l,D)).selectFrom(m(this,l,E)).where("id","=",ee).select("id").executeTakeFirst()},$e=async function(e){const a=m(this,v).db.getExecutor().adapter,r=C({lockTable:m(this,v).migrationLockTableName??he,lockRowId:ee,lockTableSchema:m(this,v).migrationTableSchema}),n=async o=>{try{await a.acquireMigrationLock(o,r);const s=await p(this,l,Ie).call(this,o);if(s.migrations.length===0)return{results:[]};const{direction:i,step:d}=e(s);return d<=0?{results:[]}:i==="Down"?await p(this,l,Fe).call(this,o,s,d):i==="Up"?await p(this,l,Ae).call(this,o,s,d):{results:[]}}finally{await a.releaseMigrationLock(o,r)}};return a.supportsTransactionalDdl?m(this,v).db.transaction().execute(n):m(this,v).db.connection().execute(n)},Ie=async function(e){const a=await p(this,l,se).call(this),r=await p(this,l,ze).call(this,e);p(this,l,Pe).call(this,a,r),m(this,l,be)||p(this,l,je).call(this,a,r);const n=p(this,l,De).call(this,a,r);return C({migrations:a,executedMigrations:r,lastMigration:pr(r),pendingMigrations:n})},De=function(e,a){return e.filter(r=>!a.includes(r.name))},se=async function(){const e=await m(this,v).provider.getMigrations();return Object.keys(e).sort().map(a=>({...e[a],name:a}))},ze=async function(e){return(await e.withPlugin(m(this,l,D)).selectFrom(m(this,l,I)).select("name").orderBy(["timestamp","name"]).execute()).map(r=>r.name)},Pe=function(e,a){for(const r of a)if(!e.some(n=>n.name===r))throw new Error(`corrupted migrations: previously executed migration ${r} is missing`)},je=function(e,a){for(let r=0;r<a.length;++r)if(e[r].name!==a[r])throw new Error(`corrupted migrations: expected previously executed migration ${a[r]} to be at index ${r} but ${e[r].name} was found in its place. New migrations must always have a name that comes alphabetically after the last executed migration.`)},Fe=async function(e,a,r){const n=a.executedMigrations.slice().reverse().slice(0,r).map(s=>a.migrations.find(i=>i.name===s)),o=n.map(s=>({migrationName:s.name,direction:"Down",status:"NotExecuted"}));for(let s=0;s<o.length;++s){const i=n[s];try{i.down&&(await i.down(e),await e.withPlugin(m(this,l,D)).deleteFrom(m(this,l,I)).where("name","=",i.name).execute(),o[s]={migrationName:i.name,direction:"Down",status:"Success"})}catch(d){throw o[s]={migrationName:i.name,direction:"Down",status:"Error"},new te({error:d,results:o})}}return{results:o}},Ae=async function(e,a,r){const o=a.pendingMigrations.slice(0,r).map(s=>({migrationName:s.name,direction:"Up",status:"NotExecuted"}));for(let s=0;s<o.length;s++){const i=a.pendingMigrations[s];try{await i.up(e),await e.withPlugin(m(this,l,D)).insertInto(m(this,l,I)).values({name:i.name,timestamp:new Date().toISOString()}).execute(),o[s]={migrationName:i.name,direction:"Up",status:"Success"}}catch(d){throw o[s]={migrationName:i.name,direction:"Up",status:"Error"},new te({error:d,results:o})}}return{results:o}},B=async function(e){m(this,v).db.getExecutor().adapter.supportsCreateIfNotExists&&(e=e.ifNotExists()),await e.execute()};var V;class te extends Error{constructor(a){super();k(this,V);U(this,V,a)}get resultSet(){return m(this,V)}}V=new WeakMap;class Me{constructor(e){K(this,"migrations");this.migrations=e}async getMigrations(){return this.migrations}}async function Sr(t){await t.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 t.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 t.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 t.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 t.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 t.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 t.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 Or(t){await t.schema.dropTable("domains").execute(),await t.schema.dropTable("members").execute(),await t.schema.dropTable("users").execute(),await t.schema.dropTable("connections").execute(),await t.schema.dropTable("applications").execute(),await t.schema.dropTable("migrations").execute(),await t.schema.dropTable("tenants").execute()}const kr=Object.freeze(Object.defineProperty({__proto__:null,down:Or,up:Sr},Symbol.toStringTag,{value:"Module"}));async function $r(t){await t.schema.alterTable("tenants").addColumn("support_url","varchar(255)").execute()}async function Ir(t){await t.schema.alterTable("tenants").dropColumn("support_url").execute()}const Dr=Object.freeze(Object.defineProperty({__proto__:null,down:Ir,up:$r},Symbol.toStringTag,{value:"Module"}));async function zr(t){}async function Pr(t){}const jr=Object.freeze(Object.defineProperty({__proto__:null,down:Pr,up:zr},Symbol.toStringTag,{value:"Module"}));async function Fr(t){await t.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 Ar(t){await t.schema.dropTable("logs").execute()}const Mr=Object.freeze(Object.defineProperty({__proto__:null,down:Ar,up:Fr},Symbol.toStringTag,{value:"Module"}));async function Er(t){}async function Jr(t){}const Lr=Object.freeze(Object.defineProperty({__proto__:null,down:Jr,up:Er},Symbol.toStringTag,{value:"Module"}));async function Rr(t){await t.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 t.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 t.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 t.schema.createIndex("otps_email_index").on("otps").column("email").execute(),await t.schema.createIndex("otps_expires_at_index").on("otps").column("expires_at").execute()}async function Kr(t){await t.schema.dropTable("sessions").execute(),await t.schema.dropTable("tickets").execute(),await t.schema.dropTable("otps").execute()}const Ur=Object.freeze(Object.defineProperty({__proto__:null,down:Kr,up:Rr},Symbol.toStringTag,{value:"Module"}));async function qr(t){await t.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 t.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 t.schema.createIndex("codes_expires_at_index").on("codes").column("expires_at").execute()}async function Br(t){await t.schema.dropTable("passwords").execute(),await t.schema.dropTable("codes").execute()}const Qr=Object.freeze(Object.defineProperty({__proto__:null,down:Br,up:qr},Symbol.toStringTag,{value:"Module"}));async function Wr(t){}async function Vr(t){}const Gr=Object.freeze(Object.defineProperty({__proto__:null,down:Vr,up:Wr},Symbol.toStringTag,{value:"Module"}));async function Yr(t){await t.schema.alterTable("passwords").addColumn("password","varchar(255)",e=>e.notNull()).execute()}async function Hr(t){await t.schema.alterTable("passwords").dropColumn("password").execute()}const Xr=Object.freeze(Object.defineProperty({__proto__:null,down:Hr,up:Yr},Symbol.toStringTag,{value:"Module"}));async function Zr(t){}async function en(t){}const tn=Object.freeze(Object.defineProperty({__proto__:null,down:en,up:Zr},Symbol.toStringTag,{value:"Module"}));async function an(t){}async function rn(t){}const nn=Object.freeze(Object.defineProperty({__proto__:null,down:rn,up:an},Symbol.toStringTag,{value:"Module"}));async function on(t){}async function sn(t){}const ln=Object.freeze(Object.defineProperty({__proto__:null,down:sn,up:on},Symbol.toStringTag,{value:"Module"}));async function dn(t){await t.schema.createIndex("users_email_index").on("users").column("email").execute()}async function cn(t){await t.schema.dropIndex("users_email_index").execute()}const un=Object.freeze(Object.defineProperty({__proto__:null,down:cn,up:dn},Symbol.toStringTag,{value:"Module"}));async function mn(t){await t.schema.alterTable("users").addColumn("profileData","varchar(2048)").execute()}async function _n(t){await t.schema.alterTable("users").dropColumn("profileData").execute()}const hn=Object.freeze(Object.defineProperty({__proto__:null,down:_n,up:mn},Symbol.toStringTag,{value:"Module"}));async function fn(t){await t.schema.createIndex("users_linked_to_index").on("users").column("linked_to").execute()}async function pn(t){await t.schema.dropIndex("users_linked_to_index")}const gn=Object.freeze(Object.defineProperty({__proto__:null,down:pn,up:fn},Symbol.toStringTag,{value:"Module"}));async function wn(t){await t.schema.alterTable("users").addColumn("locale","varchar(255)").execute()}async function yn(t){await t.schema.alterTable("users").dropColumn("locale").execute()}const vn=Object.freeze(Object.defineProperty({__proto__:null,down:yn,up:wn},Symbol.toStringTag,{value:"Module"}));async function Nn(t){await t.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 Cn(t){await t.schema.dropTable("keys").execute()}const bn=Object.freeze(Object.defineProperty({__proto__:null,down:Cn,up:Nn},Symbol.toStringTag,{value:"Module"}));async function xn(t){}async function Tn(t){}const Sn=Object.freeze(Object.defineProperty({__proto__:null,down:Tn,up:xn},Symbol.toStringTag,{value:"Module"}));async function On(t){}async function kn(t){}const $n=Object.freeze(Object.defineProperty({__proto__:null,down:kn,up:On},Symbol.toStringTag,{value:"Module"}));async function In(t){await t.schema.alterTable("otps").addColumn("audience","varchar(255)").execute()}async function Dn(t){await t.schema.alterTable("otps").dropColumn("audience").execute()}const zn=Object.freeze(Object.defineProperty({__proto__:null,down:Dn,up:In},Symbol.toStringTag,{value:"Module"}));async function Pn(t){}async function jn(t){}const Fn=Object.freeze(Object.defineProperty({__proto__:null,down:jn,up:Pn},Symbol.toStringTag,{value:"Module"}));async function An(t){await t.schema.alterTable("logs").dropColumn("category").execute()}async function Mn(t){await t.schema.alterTable("logs").addColumn("category","varchar(255)",e=>e.notNull()).execute()}const En=Object.freeze(Object.defineProperty({__proto__:null,down:Mn,up:An},Symbol.toStringTag,{value:"Module"}));async function Jn(t){await t.schema.alterTable("users").dropColumn("tags").execute()}async function Ln(t){await t.schema.alterTable("users").addColumn("tags","varchar(255)").execute()}const Rn=Object.freeze(Object.defineProperty({__proto__:null,down:Ln,up:Jn},Symbol.toStringTag,{value:"Module"}));async function Kn(t){await t.schema.createIndex("logs_user_id").on("logs").column("user_id").execute(),await t.schema.createIndex("logs_tenant_id").on("logs").column("tenant_id").execute(),await t.schema.createIndex("logs_date").on("logs").column("date").execute()}async function Un(t){await t.schema.dropIndex("logs_user_id"),await t.schema.dropIndex("logs_tenant_id"),await t.schema.dropIndex("logs_date")}const qn=Object.freeze(Object.defineProperty({__proto__:null,down:Un,up:Kn},Symbol.toStringTag,{value:"Module"}));async function Bn(t){await t.schema.alterTable("logs").dropColumn("details").execute(),await t.schema.alterTable("logs").addColumn("details","varchar(8192)").execute()}async function Qn(t){await t.schema.alterTable("logs").dropColumn("details").execute(),await t.schema.alterTable("logs").addColumn("details","varchar(2048)").execute()}const Wn=Object.freeze(Object.defineProperty({__proto__:null,down:Qn,up:Bn},Symbol.toStringTag,{value:"Module"}));async function Vn(t){await t.schema.alterTable("logs").addColumn("user_name","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("auth0_client","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("isMobile","boolean").execute(),await t.schema.alterTable("logs").addColumn("connection","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("connection_id","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("audience","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("scope","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("strategy","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("strategy_type","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("hostname","varchar(255)").execute(),await t.schema.alterTable("logs").addColumn("session_connection","varchar(255)").execute()}async function Gn(t){await t.schema.alterTable("logs").dropColumn("user_name").execute(),await t.schema.alterTable("logs").dropColumn("auth0_client").execute(),await t.schema.alterTable("logs").dropColumn("isMobile").execute(),await t.schema.alterTable("logs").dropColumn("connection").execute(),await t.schema.alterTable("logs").dropColumn("connection_id").execute(),await t.schema.alterTable("logs").dropColumn("audience").execute(),await t.schema.alterTable("logs").dropColumn("scope").execute(),await t.schema.alterTable("logs").dropColumn("strategy").execute(),await t.schema.alterTable("logs").dropColumn("strategy_type").execute(),await t.schema.alterTable("logs").dropColumn("hostname").execute(),await t.schema.alterTable("logs").dropColumn("session_connection").execute()}const Yn=Object.freeze(Object.defineProperty({__proto__:null,down:Gn,up:Vn},Symbol.toStringTag,{value:"Module"}));async function Hn(t){await t.schema.createIndex("users_name_index").on("users").column("name").execute()}async function Xn(t){await t.schema.dropIndex("users_name_index").execute()}const Zn=Object.freeze(Object.defineProperty({__proto__:null,down:Xn,up:Hn},Symbol.toStringTag,{value:"Module"}));async function eo(t){}async function to(t){await t.schema.alterTable("users").dropConstraint("unique_email_provider").execute()}const ao=Object.freeze(Object.defineProperty({__proto__:null,down:to,up:eo},Symbol.toStringTag,{value:"Module"}));async function ro(t){await t.schema.alterTable("otps").dropColumn("state").execute(),await t.schema.alterTable("otps").addColumn("state","varchar(8192)").execute()}async function no(t){await t.schema.alterTable("otps").dropColumn("state").execute(),await t.schema.alterTable("otps").addColumn("state","varchar(1024)").execute()}const oo=Object.freeze(Object.defineProperty({__proto__:null,down:no,up:ro},Symbol.toStringTag,{value:"Module"}));async function so(t){await t.schema.alterTable("tickets").dropColumn("state").execute(),await t.schema.alterTable("tickets").addColumn("state","varchar(8192)").execute()}async function io(t){await t.schema.alterTable("tickets").dropColumn("state").execute(),await t.schema.alterTable("tickets").addColumn("state","varchar(1024)").execute()}const lo=Object.freeze(Object.defineProperty({__proto__:null,down:io,up:so},Symbol.toStringTag,{value:"Module"}));async function co(t){await t.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 uo(t){await t.schema.dropTable("branding").execute()}const mo=Object.freeze(Object.defineProperty({__proto__:null,down:uo,up:co},Symbol.toStringTag,{value:"Module"}));async function _o(t){}async function ho(t){}const fo=Object.freeze(Object.defineProperty({__proto__:null,down:ho,up:_o},Symbol.toStringTag,{value:"Module"}));async function po(t){}async function go(t){}const wo=Object.freeze(Object.defineProperty({__proto__:null,down:go,up:po},Symbol.toStringTag,{value:"Module"}));async function yo(t){}async function vo(t){}const No=Object.freeze(Object.defineProperty({__proto__:null,down:vo,up:yo},Symbol.toStringTag,{value:"Module"}));async function Co(t){}async function bo(t){}const xo=Object.freeze(Object.defineProperty({__proto__:null,down:bo,up:Co},Symbol.toStringTag,{value:"Module"}));async function To(t){await t.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 So(t){await t.schema.dropTable("authentication_codes").execute()}const Oo=Object.freeze(Object.defineProperty({__proto__:null,down:So,up:To},Symbol.toStringTag,{value:"Module"}));async function ko(t){}async function $o(t){}const Io=Object.freeze(Object.defineProperty({__proto__:null,down:$o,up:ko},Symbol.toStringTag,{value:"Module"}));async function Do(t){await t.schema.alterTable("otps").addColumn("ip","varchar(64)").execute()}async function zo(t){await t.schema.alterTable("otps").dropColumn("ip").execute()}const Po=Object.freeze(Object.defineProperty({__proto__:null,down:zo,up:Do},Symbol.toStringTag,{value:"Module"}));async function jo(t){await t.schema.alterTable("logs").dropColumn("user_agent").execute(),await t.schema.alterTable("logs").addColumn("user_agent","varchar(1024)").execute()}async function Fo(t){await t.schema.alterTable("logs").dropColumn("user_agent").execute(),await t.schema.alterTable("logs").addColumn("user_agent","varchar(255)").execute()}const Ao=Object.freeze(Object.defineProperty({__proto__:null,down:Fo,up:jo},Symbol.toStringTag,{value:"Module"}));async function Mo(t){}async function Eo(t){}const Jo=Object.freeze(Object.defineProperty({__proto__:null,down:Eo,up:Mo},Symbol.toStringTag,{value:"Module"}));async function Lo(t){await t.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 Ro(t){await t.schema.dropTable("hooks").execute()}const Ko=Object.freeze(Object.defineProperty({__proto__:null,down:Ro,up:Lo},Symbol.toStringTag,{value:"Module"}));async function Uo(t){}async function qo(t){}const Bo=Object.freeze(Object.defineProperty({__proto__:null,down:qo,up:Uo},Symbol.toStringTag,{value:"Module"}));async function Qo(t){}async function Wo(t){}const Vo=Object.freeze(Object.defineProperty({__proto__:null,down:Wo,up:Qo},Symbol.toStringTag,{value:"Module"}));async function Go(t){await t.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 t.schema.alterTable("passwords").addColumn("algorithm","varchar(16)").execute(),await t.schema.dropTable("codes").execute(),await t.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 Yo(t){await t.schema.dropTable("logins").execute(),await t.schema.alterTable("passwords").dropColumn("algorithm").execute(),await t.schema.dropTable("codes").execute(),await t.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()}const Ho=Object.freeze(Object.defineProperty({__proto__:null,down:Yo,up:Go},Symbol.toStringTag,{value:"Module"}));async function Xo(t){}async function Zo(t){}const es=Object.freeze(Object.defineProperty({__proto__:null,down:Zo,up:Xo},Symbol.toStringTag,{value:"Module"}));async function ts(t){await t.schema.alterTable("logins").addColumn("auth0Client","varchar(256)").execute()}async function as(t){await t.schema.alterTable("logins").dropColumn("auth0Client").execute()}const rs=Object.freeze(Object.defineProperty({__proto__:null,down:as,up:ts},Symbol.toStringTag,{value:"Module"}));async function ns(t){await t.schema.alterTable("logins").dropColumn("authParams_state").execute(),await t.schema.alterTable("logins").addColumn("authParams_state","varchar(8192)").execute()}async function os(t){await t.schema.alterTable("logins").dropColumn("authParams_state").execute(),await t.schema.alterTable("logins").addColumn("authParams_state","varchar(511)").execute()}const ss=Object.freeze(Object.defineProperty({__proto__:null,down:os,up:ns},Symbol.toStringTag,{value:"Module"}));async function is(t){}async function ls(t){}const ds=Object.freeze(Object.defineProperty({__proto__:null,down:ls,up:is},Symbol.toStringTag,{value:"Module"}));async function cs(t){}async function us(t){}const ms=Object.freeze(Object.defineProperty({__proto__:null,down:us,up:cs},Symbol.toStringTag,{value:"Module"}));async function _s(t){await t.schema.alterTable("logins").addColumn("authParams_nonce","varchar(255)").execute()}async function hs(t){await t.schema.alterTable("logins").dropColumn("nonce").execute()}const fs=Object.freeze(Object.defineProperty({__proto__:null,down:hs,up:_s},Symbol.toStringTag,{value:"Module"}));async function ps(t){}async function gs(t){}const ws=Object.freeze(Object.defineProperty({__proto__:null,down:gs,up:ps},Symbol.toStringTag,{value:"Module"}));async function ys(t){}async function vs(t){}const Ns=Object.freeze(Object.defineProperty({__proto__:null,down:vs,up:ys},Symbol.toStringTag,{value:"Module"}));async function Cs(t){await t.schema.dropTable("codes").execute(),await t.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 bs(t){await t.schema.dropTable("codes").execute(),await t.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()}const xs=Object.freeze(Object.defineProperty({__proto__:null,down:bs,up:Cs},Symbol.toStringTag,{value:"Module"}));async function Ts(t){await t.schema.dropTable("otps").execute(),await t.schema.dropTable("authentication_codes").execute()}async function Ss(t){await t.schema.alterTable("keys").addColumn("private_key","varchar(2048)").addColumn("public_key","varchar(2048)").execute(),await t.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 t.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()}const Os=Object.freeze(Object.defineProperty({__proto__:null,down:Ss,up:Ts},Symbol.toStringTag,{value:"Module"}));async function ks(t){await t.schema.createIndex("IDX_logs_tenant_date_type_user").on("logs").columns(["tenant_id","date","type","user_id"]).execute()}async function $s(t){await t.schema.dropIndex("IDX_logs_tenant_date_type_user").on("logs").execute()}const Is=Object.freeze(Object.defineProperty({__proto__:null,down:$s,up:ks},Symbol.toStringTag,{value:"Module"}));async function Ds(t){}async function zs(t){}const Ps=Object.freeze(Object.defineProperty({__proto__:null,down:zs,up:Ds},Symbol.toStringTag,{value:"Module"}));async function js(t){await t.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 Fs(t){await t.schema.dropTable("prompt_settings").execute()}const As=Object.freeze(Object.defineProperty({__proto__:null,down:Fs,up:js},Symbol.toStringTag,{value:"Module"}));async function Ms(t){}async function Es(t){}const Js=Object.freeze(Object.defineProperty({__proto__:null,down:Es,up:Ms},Symbol.toStringTag,{value:"Module"}));async function Ls(t){}async function Rs(t){}const Ks=Object.freeze(Object.defineProperty({__proto__:null,down:Rs,up:Ls},Symbol.toStringTag,{value:"Module"}));async function Us(t){}async function qs(t){}const Bs=Object.freeze(Object.defineProperty({__proto__:null,down:qs,up:Us},Symbol.toStringTag,{value:"Module"}));async function Qs(t){await t.schema.alterTable("logins").addColumn("authParams_ui_locales","varchar(32)").execute()}async function Ws(t){await t.schema.alterTable("logins").dropColumn("authParams_ui_locales").execute()}const Vs=Object.freeze(Object.defineProperty({__proto__:null,down:Ws,up:Qs},Symbol.toStringTag,{value:"Module"}));async function Gs(t){await t.schema.alterTable("logins").addColumn("authParams_prompt","varchar(16)").execute()}async function Ys(t){await t.schema.alterTable("logins").dropColumn("authParams_prompt").execute()}const Hs=Object.freeze(Object.defineProperty({__proto__:null,down:Ys,up:Gs},Symbol.toStringTag,{value:"Module"}));async function Xs(t){}async function Zs(t){}const ei=Object.freeze(Object.defineProperty({__proto__:null,down:Zs,up:Xs},Symbol.toStringTag,{value:"Module"}));async function ti(t){await t.schema.alterTable("logins").addColumn("authParams_act_as","varchar(255)").execute()}async function ai(t){await t.schema.alterTable("logins").dropColumn("authParam_act_as").execute()}const ri=Object.freeze(Object.defineProperty({__proto__:null,down:ai,up:ti},Symbol.toStringTag,{value:"Module"}));async function ni(t){await t.schema.alterTable("codes").addColumn("code_verifier","varchar(128)").execute()}async function oi(t){await t.schema.alterTable("codes").dropColumn("code_verifier").execute()}const si=Object.freeze(Object.defineProperty({__proto__:null,down:oi,up:ni},Symbol.toStringTag,{value:"Module"}));async function ii(t){await t.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 li(t){await t.schema.dropTable("email_providers").execute()}const di=Object.freeze(Object.defineProperty({__proto__:null,down:li,up:ii},Symbol.toStringTag,{value:"Module"}));async function ci(t){await t.schema.dropTable("tickets").execute()}async function ui(t){await t.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()}const mi=Object.freeze(Object.defineProperty({__proto__:null,down:ui,up:ci},Symbol.toStringTag,{value:"Module"}));async function _i(t){}async function hi(t){await t.schema.alterTable("logins").dropColumn("ip").dropColumn("useragent").execute()}const fi=Object.freeze(Object.defineProperty({__proto__:null,down:hi,up:_i},Symbol.toStringTag,{value:"Module"}));async function pi(t){await t.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 gi(t){await t.schema.dropTable("refresh_tokens").execute()}const wi=Object.freeze(Object.defineProperty({__proto__:null,down:gi,up:pi},Symbol.toStringTag,{value:"Module"}));async function yi(t){}async function vi(t){}const Ni=Object.freeze(Object.defineProperty({__proto__:null,down:vi,up:yi},Symbol.toStringTag,{value:"Module"}));async function Ci(t){await t.schema.dropTable("sessions").execute(),await t.schema.dropTable("refresh_tokens").execute()}async function bi(t){await t.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 t.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()}const xi=Object.freeze(Object.defineProperty({__proto__:null,down:bi,up:Ci},Symbol.toStringTag,{value:"Module"}));async function Ti(t){await t.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 t.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 Si(t){await t.schema.dropTable("sessions_2").execute(),await t.schema.dropTable("refresh_tokens_2").execute()}const Oi=Object.freeze(Object.defineProperty({__proto__:null,down:Si,up:Ti},Symbol.toStringTag,{value:"Module"}));async function ki(t){await t.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 t.schema.dropTable("domains").execute()}async function $i(t){await t.schema.dropTable("custom_domains").execute(),await t.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()}const Ii=Object.freeze(Object.defineProperty({__proto__:null,down:$i,up:ki},Symbol.toStringTag,{value:"Module"}));async function Di(t){}async function zi(t){await t.schema.alterTable("logins").dropColumn("authParams_organization").dropColumn("authorization_url").execute()}const Pi=Object.freeze(Object.defineProperty({__proto__:null,down:zi,up:Di},Symbol.toStringTag,{value:"Module"}));async function ji(t){await t.schema.alterTable("logins").dropColumn("authorization_url").execute(),await t.schema.alterTable("logins").addColumn("authorization_url","varchar(2048)").execute()}async function Fi(t){await t.schema.alterTable("logins").dropColumn("authorization_url").execute(),await t.schema.alterTable("logins").addColumn("authorization_url","varchar(1024)").execute()}const Ai=Object.freeze(Object.defineProperty({__proto__:null,down:Fi,up:ji},Symbol.toStringTag,{value:"Module"}));async function Mi(t){}async function Ei(t){}const Ji=Object.freeze(Object.defineProperty({__proto__:null,down:Ei,up:Mi},Symbol.toStringTag,{value:"Module"}));async function Li(t){await t.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 t.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 t.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 Ri(t){await t.schema.dropTable("sessions").execute(),await t.schema.dropTable("login_sessions").execute(),await t.schema.dropTable("refresh_tokens").execute()}const Ki=Object.freeze(Object.defineProperty({__proto__:null,down:Ri,up:Li},Symbol.toStringTag,{value:"Module"}));async function Ui(t){await t.schema.dropTable("logins").execute(),await t.schema.dropTable("sessions_2").execute(),await t.schema.dropTable("refresh_tokens_2").execute()}async function qi(t){}const Bi=Object.freeze(Object.defineProperty({__proto__:null,down:qi,up:Ui},Symbol.toStringTag,{value:"Module"}));async function Qi(t){await t.schema.dropTable("custom_domains").execute(),await t.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 Wi(t){}const Vi=Object.freeze(Object.defineProperty({__proto__:null,down:Wi,up:Qi},Symbol.toStringTag,{value:"Module"}));async function Gi(t){}async function Yi(t){await t.schema.alterTable("users").dropColumn("phone_number").dropColumn("phone_verified").dropColumn("username").execute()}const Hi=Object.freeze(Object.defineProperty({__proto__:null,down:Yi,up:Gi},Symbol.toStringTag,{value:"Module"}));async function Xi(t){await t.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 t.schema.createIndex("forms_tenant_id_idx").on("forms").column("tenant_id").execute()}async function Zi(t){await t.schema.dropTable("forms").execute()}const el=Object.freeze(Object.defineProperty({__proto__:null,down:Zi,up:Xi},Symbol.toStringTag,{value:"Module"}));async function tl(t){await t.schema.alterTable("hooks").addColumn("form_id","text").execute(),await t.schema.alterTable("hooks").addColumn("url_tmp","varchar(512)").execute(),await t.updateTable("hooks").set(e=>({url_tmp:e.ref("url")})).execute(),await t.schema.alterTable("hooks").dropColumn("url").execute(),await t.schema.alterTable("hooks").renameColumn("url_tmp","url").execute()}async function al(t){await t.schema.dropTable("hooks").ifExists().execute(),await t.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()}const rl=Object.freeze(Object.defineProperty({__proto__:null,down:al,up:tl},Symbol.toStringTag,{value:"Module"}));async function nl(t){await t.schema.alterTable("login_sessions").addColumn("login_completed","boolean",e=>e.notNull().defaultTo(0)).execute()}async function ol(t){await t.schema.alterTable("login_sessions").dropColumn("login_completed").execute()}const sl=Object.freeze(Object.defineProperty({__proto__:null,down:ol,up:nl},Symbol.toStringTag,{value:"Module"}));async function il(t){await t.schema.alterTable("sessions").addColumn("login_session_id","varchar(21)",e=>e.references("login_sessions.id").onDelete("set null")).execute()}async function ll(t){await t.schema.alterTable("sessions").dropColumn("login_session_id").execute()}const dl=Object.freeze(Object.defineProperty({__proto__:null,down:ll,up:il},Symbol.toStringTag,{value:"Module"}));async function cl(t){await t.schema.createIndex("IDX_sessions_login_session_id").on("sessions").column("login_session_id").execute()}async function ul(t){await t.schema.dropIndex("IDX_sessions_login_session_id").on("sessions").execute()}const ml=Object.freeze(Object.defineProperty({__proto__:null,down:ul,up:cl},Symbol.toStringTag,{value:"Module"}));async function _l(t){await t.schema.alterTable("codes").addColumn("code_challenge","varchar(128)").execute(),await t.schema.alterTable("codes").addColumn("code_challenge_method","varchar(5)").execute()}async function hl(t){await t.schema.alterTable("codes").dropColumn("code_challenge").execute(),await t.schema.alterTable("codes").dropColumn("code_challenge_method").execute()}const fl=Object.freeze(Object.defineProperty({__proto__:null,down:hl,up:_l},Symbol.toStringTag,{value:"Module"}));async function pl(t){await t.schema.alterTable("codes").addColumn("redirect_uri","varchar(1024)").execute()}async function gl(t){await t.schema.alterTable("codes").dropColumn("redirect_uri").execute()}const wl=Object.freeze(Object.defineProperty({__proto__:null,down:gl,up:pl},Symbol.toStringTag,{value:"Module"}));async function yl(t){await t.schema.alterTable("codes").addColumn("nonce","varchar(1024)").execute(),await t.schema.alterTable("codes").addColumn("state","varchar(2048)").execute()}async function vl(t){await t.schema.alterTable("codes").dropColumn("nonce").execute(),await t.schema.alterTable("codes").dropColumn("state").execute()}const Nl=Object.freeze(Object.defineProperty({__proto__:null,down:vl,up:yl},Symbol.toStringTag,{value:"Module"}));async function Cl(t){await t.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 t.schema.createIndex("themes_tenant_id_idx").on("themes").column("tenant_id").execute()}async function bl(t){await t.schema.dropTable("themes").execute()}const xl=Object.freeze(Object.defineProperty({__proto__:null,down:bl,up:Cl},Symbol.toStringTag,{value:"Module"}));async function Tl(t){await t.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 t.schema.createIndex("resource_servers_tenant_identifier_uq").on("resource_servers").columns(["tenant_id","identifier"]).unique().execute(),await t.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 t.schema.createIndex("roles_tenant_name_uq").on("roles").columns(["tenant_id","name"]).unique().execute()}async function Sl(t){await t.schema.dropTable("roles").execute(),await t.schema.dropTable("resource_servers").execute()}const Ol=Object.freeze(Object.defineProperty({__proto__:null,down:Sl,up:Tl},Symbol.toStringTag,{value:"Module"}));async function kl(t){await t.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 t.schema.createIndex("role_permissions_role_fk").on("role_permissions").columns(["tenant_id","role_id"]).execute(),await t.schema.createIndex("role_permissions_permission_fk").on("role_permissions").columns(["tenant_id","resource_server_identifier","permission_name"]).execute(),await t.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 t.schema.createIndex("user_permissions_user_fk").on("user_permissions").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_permissions_permission_fk").on("user_permissions").columns(["tenant_id","resource_server_identifier","permission_name"]).execute()}async function $l(t){await t.schema.dropTable("user_permissions").execute(),await t.schema.dropTable("role_permissions").execute()}const Il=Object.freeze(Object.defineProperty({__proto__:null,down:$l,up:kl},Symbol.toStringTag,{value:"Module"}));async function Dl(t){await t.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 t.schema.createIndex("user_roles_user_fk").on("user_roles").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_roles_role_fk").on("user_roles").columns(["tenant_id","role_id"]).execute()}async function zl(t){await t.schema.dropTable("user_roles").execute()}const Pl=Object.freeze(Object.defineProperty({__proto__:null,down:zl,up:Dl},Symbol.toStringTag,{value:"Module"}));async function jl(t){}async function Fl(t){await t.schema.alterTable("keys").dropColumn("connection").execute(),await t.schema.alterTable("keys").modifyColumn("cert","varchar(2048)").execute(),await t.schema.alterTable("keys").modifyColumn("pkcs7","varchar(2048)").execute(),await t.schema.alterTable("keys").dropColumn("type").execute()}const Al=Object.freeze(Object.defineProperty({__proto__:null,down:Fl,up:jl},Symbol.toStringTag,{value:"Module"}));async function Ml(t){await t.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 t.schema.createIndex("idx_organizations_tenant_id").on("organizations").column("tenant_id").execute(),await t.schema.createIndex("idx_organizations_tenant_name_unique").on("organizations").columns(["tenant_id","name"]).unique().execute()}async function El(t){await t.schema.dropTable("organizations").execute()}const Jl=Object.freeze(Object.defineProperty({__proto__:null,down:El,up:Ml},Symbol.toStringTag,{value:"Module"}));async function Ll(t){await t.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 t.schema.createIndex("idx_user_organizations_tenant_id").on("user_organizations").column("tenant_id").execute(),await t.schema.createIndex("idx_user_organizations_user_id").on("user_organizations").column("user_id").execute(),await t.schema.createIndex("idx_user_organizations_organization_id").on("user_organizations").column("organization_id").execute()}async function Rl(t){await t.schema.dropTable("user_organizations").execute()}const Kl=Object.freeze(Object.defineProperty({__proto__:null,down:Rl,up:Ll},Symbol.toStringTag,{value:"Module"}));async function Ul(t){await t.schema.dropTable("user_permissions").execute(),await t.schema.dropTable("user_roles").execute(),await t.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 t.schema.createIndex("user_permissions_user_fk").on("user_permissions").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_permissions_permission_fk").on("user_permissions").columns(["tenant_id","resource_server_identifier","permission_name"]).execute(),await t.schema.createIndex("user_permissions_organization_fk").on("user_permissions").column("organization_id").execute(),await t.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 t.schema.createIndex("user_roles_user_fk").on("user_roles").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_roles_role_fk").on("user_roles").columns(["tenant_id","role_id"]).execute(),await t.schema.createIndex("user_roles_organization_fk").on("user_roles").column("organization_id").execute()}async function ql(t){await t.schema.dropTable("user_permissions").execute(),await t.schema.dropTable("user_roles").execute(),await t.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 t.schema.createIndex("user_permissions_user_fk").on("user_permissions").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_permissions_permission_fk").on("user_permissions").columns(["tenant_id","resource_server_identifier","permission_name"]).execute(),await t.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 t.schema.createIndex("user_roles_user_fk").on("user_roles").columns(["tenant_id","user_id"]).execute(),await t.schema.createIndex("user_roles_role_fk").on("user_roles").columns(["tenant_id","role_id"]).execute()}const Bl=Object.freeze(Object.defineProperty({__proto__:null,down:ql,up:Ul},Symbol.toStringTag,{value:"Module"}));async function Ql(t){await t.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.defaultTo("[]").notNull()).addColumn("allowed_origins","text",e=>e.defaultTo("[]").notNull()).addColumn("web_origins","text",e=>e.defaultTo("[]").notNull()).addColumn("client_aliases","text",e=>e.defaultTo("[]").notNull()).addColumn("allowed_clients","text",e=>e.defaultTo("[]").notNull()).addColumn("allowed_logout_urls","text",e=>e.defaultTo("[]").notNull()).addColumn("session_transfer","text",e=>e.defaultTo("{}").notNull()).addColumn("oidc_logout","text",e=>e.defaultTo("{}").notNull()).addColumn("grant_types","text",e=>e.defaultTo("[]").notNull()).addColumn("jwt_configuration","text",e=>e.defaultTo("{}").notNull()).addColumn("signing_keys","text",e=>e.defaultTo("[]").notNull()).addColumn("encryption_key","text",e=>e.defaultTo("{}").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.defaultTo("{}").notNull()).addColumn("token_endpoint_auth_method","varchar(64)",e=>e.defaultTo("client_secret_basic")).addColumn("client_metadata","text",e=>e.defaultTo("{}").notNull()).addColumn("mobile","text",e=>e.defaultTo("{}").notNull()).addColumn("initiate_login_uri","varchar(2083)").addColumn("native_social_login","text",e=>e.defaultTo("{}").notNull()).addColumn("refresh_token","text",e=>e.defaultTo("{}").notNull()).addColumn("default_organization","text",e=>e.defaultTo("{}").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.defaultTo("{}").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.defaultTo("{}").notNull()).addColumn("compliance_level","varchar(64)").addColumn("par_request_expiry","integer").addColumn("token_quota","text",e=>e.defaultTo("{}").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 Wl(t){await t.schema.dropTable("clients").execute()}const Vl=Object.freeze(Object.defineProperty({__proto__:null,down:Wl,up:Ql},Symbol.toStringTag,{value:"Module"})),Ee={m1_init:kr,m2_magicLink:Dr,m3_updateAt:jr,m4_logTable:Mr,m5_userProfile:Lr,m6_sessions:Ur,m7_passwords:Qr,m8_logsTableNewFields:Gr,m9_passwordTableNewField:Xr,n01_codesTable:tn,n11_universalLoginSession:nn,n12_userFields:ln,n13_userEmailIndex:un,n14_profileDataField:hn,n15_userEmailIndex:gn,n16_userLocale:vn,n17_signingKeys:bn,n18_logsFields:Sn,n19_connectionsUserinfo:$n,n20_missingFields:zn,n21_sessionDeletedAt:Fn,n22_dropLogsFields:En,n23_dropUsersFields:Rn,n24_logsIndexes:qn,n25_logDescMaxLength:Wn,n26_logsTableExtraFields:Yn,n27_usersTableNameIndex:Zn,n28_usersEmailConstrain:ao,n29_increaseOtpStateLength:oo,n30_increaseTicketStateLength:lo,n31_branding:mo,n32_indexesAndNotNull:fo,n33_vendorIdInUniversalLoginSession:wo,n34_auth0ClientInUniversalLoginSession:No,n35_increaseUniversalSessionStateLength:xo,n36_authenticationCodes:Oo,n37_disableSignUps:Io,n38_otpIpAddress:Po,n39_increaseUserAgentLength:Ao,n40_userId:Jo,n41_hooks:Ko,n42_userIdIndexes:Bo,n43_userIdIndexes:Vo,n44_codes:Ho,n45_hookProperties:es,n46_loginAuth0Client:rs,n47_loginAuth0Client:ss,n48_saml:ds,n49_removeFields:ms,n50_authParamsNonce:fs,n51_connectionid:ws,n52_cert:Ns,n53_codes_primary_key:xs,n54_cleanup_tables:Os,n55_logs_index:Is,n56_application_fields:Ps,n57_prompt_settings:As,n58_connection_client_id:Js,n59_connection_options:Ks,n60_users_metadata:Bs,n61_userLocales:Vs,n62_prompt:Hs,n63_connection_cleanup:ei,n64_act_as:ri,n65_code_verifier:si,n66_email_providers:di,n67_drop_tickets:mi,n68_login_useragents:fi,n70_refresh_tokens:wi,n71_session_new_fields:Ni,n72_session_primary_key:xi,n73_drop_sessions:Oi,n74_custom_domains:Ii,n75_organizations:Pi,n76_authorization_url_length:Ai,n77_drop_sessions:Ji,n78_login_sessions:Ki,n79_drop_sessions_2:Bi,n80_recreate_custom_domains:Vi,n81_phone:Hi,n82_forms:el,n83_addFormsIdToHooks:rl,n84_login_completed:sl,n85_add_login_session_id_to_sessions:dl,n86_index_sessions_login_session_id:ml,n87_code_challenge:fl,n88_add_redirect_uri_to_codes:wl,n89_add_nonce_and_state_to_codes:Nl,n90_themes:xl,n91_resource_servers_rules_permissions:Ol,n92_role_permissions:Il,n93_add_permissions_to_roles:Pl,n94_keys_connection_and_extend_columns:Al,n95_create_organizations_table:Jl,n96_create_user_organizations_table:Kl,n97_add_organization_to_user_permissions_and_roles:Bl,n98_clients:Vl};async function Gl(t,e=!1){e&&console.log("migrating...");const a=new Me(Ee),r=new Ce({db:t,provider:a}),{error:n,results:o}=await r.migrateToLatest();if(o==null||o.forEach(s=>{s.status==="Success"?e&&console.log(`migration "${s.migrationName}" was executed successfully`):s.status==="Error"&&console.error(`failed to execute migration "${s.migrationName}"`)}),n)throw console.error("failed to migrate"),console.error(n),n}async function Yl(t){console.log("migrating...");const e=new Me(Ee),a=new Ce({db:t,provider:e}),{error:r,results:n}=await a.migrateDown();if(n==null||n.forEach(o=>{o.status==="Success"?console.log(`migration "${o.migrationName}" was reverted successfully`):o.status==="Error"&&console.error(`failed to execute migration "${o.migrationName}"`)}),r)throw console.error("failed to migrate"),console.error(r),r}function Hl(t){return{applications:Ot(t),branding:Vt(t),cleanup:xa(t),clients:{create:async()=>{throw new Error("Not implemented")},get:async()=>{throw new Error("Not implemented")},list:async()=>{throw new Error("Not implemented")},remove:async()=>{throw new Error("Not implemented")},update:async()=>{throw new Error("Not implemented")}},legacyClients:jt(t),codes:Nt(t),connections:Pt(t),emailProviders:ga(t),customDomains:Bt(t),forms:Ia(t),hooks:ea(t),keys:Et(t),loginSessions:ca(t),logs:ot(t),passwords:ft(t),promptSettings:_a(t),refreshTokens:ba(t),resourceServers:Aa(t),rolePermissions:Qa(t),userPermissions:Ha(t),userRoles:ar(t),roles:Ka(t),sessions:ut(t),tenants:et(t),themes:oa(t),users:We(t),organizations:lr(t),userOrganizations:fr(t)}}exports.default=Hl;exports.migrateDown=Yl;exports.migrateToLatest=Gl;