@supabase/lite 0.2.0 → 0.2.1-next.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -7
- package/STATUS.md +844 -0
- package/UPGRADE.md +221 -0
- package/dist/{Connection-rAPmec1m.d.ts → Connection-CSVCuMv-.d.ts} +1 -152
- package/dist/cli/index.js +144 -178
- package/dist/cli/lib.js +44 -76
- package/dist/db/browser/index.d.ts +3 -532
- package/dist/db/browser/index.js +3 -238
- package/dist/db/bun/index.d.ts +3 -532
- package/dist/db/bun/index.js +3 -238
- package/dist/db/fallback.d.ts +4 -180
- package/dist/db/fallback.js +2 -236
- package/dist/db/node/index.d.ts +3 -532
- package/dist/db/node/index.js +3 -238
- package/dist/db/workerd/index.d.ts +6 -535
- package/dist/db/workerd/index.js +2 -237
- package/dist/index.d.ts +329 -7
- package/dist/index.js +255 -88
- package/dist/vite/index.js +2 -6
- package/package.json +6 -9
package/dist/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {jsonStringify}from'@supabase/lite';import {Kysely,PostgresQueryCompiler,PostgresIntrospector,DummyDriver,PostgresAdapter,SqliteQueryCompiler,SqliteIntrospector,SqliteAdapter,sql}from'kysely';import {jsonObjectFrom as jsonObjectFrom$1,jsonArrayFrom as jsonArrayFrom$1}from'kysely/helpers/postgres';import {jsonObjectFrom,jsonArrayFrom}from'kysely/helpers/sqlite';import
|
|
1
|
+
import {Deparser,QuoteUtils}from'pgsql-deparser';import {DeparserContext}from'pgsql-deparser/visitors/base.js';import {SqlFormatter}from'pgsql-deparser/utils/sql-formatter.js';import {jsonStringify,Connection,RelationNotFoundError,invariant,DataLossError,PlanStepType}from'@supabase/lite';import {Kysely,PostgresQueryCompiler,PostgresIntrospector,DummyDriver,PostgresAdapter,SqliteQueryCompiler,SqliteIntrospector,SqliteAdapter,sql,OperationNodeTransformer,SchemableIdentifierNode,JoinNode,TableNode,AliasNode,ListNode,UsingNode}from'kysely';import {jsonObjectFrom as jsonObjectFrom$1,jsonArrayFrom as jsonArrayFrom$1}from'kysely/helpers/postgres';import {jsonObjectFrom,jsonArrayFrom}from'kysely/helpers/sqlite';import Np from'bcryptjs';import {v7}from'uuid';import {createClient}from'@supabase/supabase-js';try {
|
|
2
2
|
/**
|
|
3
3
|
* Adding this to avoid warnings from node:sqlite being experimental
|
|
4
4
|
*/
|
|
@@ -9,83 +9,89 @@ import {jsonStringify}from'@supabase/lite';import {Kysely,PostgresQueryCompiler,
|
|
|
9
9
|
};
|
|
10
10
|
} catch {}
|
|
11
11
|
|
|
12
|
-
var Lh=Object.create;var xa=Object.defineProperty;var kh=Object.getOwnPropertyDescriptor;var $h=Object.getOwnPropertyNames;var Ph=Object.getPrototypeOf,Dh=Object.prototype.hasOwnProperty;var jh=(s,e)=>()=>(s&&(e=s(s=0)),e);var Mn=(s,e)=>()=>(e||s((e={exports:{}}).exports,e),e.exports),Fn=(s,e)=>{for(var r in e)xa(s,r,{get:e[r],enumerable:true});},xh=(s,e,r,t)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of $h(e))!Dh.call(s,n)&&n!==r&&xa(s,n,{get:()=>e[n],enumerable:!(t=kh(e,n))||t.enumerable});return s};var qn=(s,e,r)=>(r=s!=null?Lh(Ph(s)):{},xh(xa(r,"default",{value:s,enumerable:true}),s));var Tp=Mn((i_,Fo)=>{var Ii=process||{},Sp=Ii.argv||[],Ni=Ii.env||{},mE=!(Ni.NO_COLOR||Sp.includes("--no-color"))&&(!!Ni.FORCE_COLOR||Sp.includes("--color")||Ii.platform==="win32"||(Ii.stdout||{}).isTTY&&Ni.TERM!=="dumb"||!!Ni.CI),hE=(s,e,r=s)=>t=>{let n=""+t,i=n.indexOf(e,s.length);return ~i?s+dE(n,e,r,i)+e:s+n+e},dE=(s,e,r,t)=>{let n="",i=0;do n+=s.substring(i,t)+r,i=t+e.length,t=s.indexOf(e,i);while(~t);return n+s.substring(i)},bp=(s=mE)=>{let e=s?hE:()=>String;return {isColorSupported:s,reset:e("\x1B[0m","\x1B[0m"),bold:e("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:e("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:e("\x1B[3m","\x1B[23m"),underline:e("\x1B[4m","\x1B[24m"),inverse:e("\x1B[7m","\x1B[27m"),hidden:e("\x1B[8m","\x1B[28m"),strikethrough:e("\x1B[9m","\x1B[29m"),black:e("\x1B[30m","\x1B[39m"),red:e("\x1B[31m","\x1B[39m"),green:e("\x1B[32m","\x1B[39m"),yellow:e("\x1B[33m","\x1B[39m"),blue:e("\x1B[34m","\x1B[39m"),magenta:e("\x1B[35m","\x1B[39m"),cyan:e("\x1B[36m","\x1B[39m"),white:e("\x1B[37m","\x1B[39m"),gray:e("\x1B[90m","\x1B[39m"),bgBlack:e("\x1B[40m","\x1B[49m"),bgRed:e("\x1B[41m","\x1B[49m"),bgGreen:e("\x1B[42m","\x1B[49m"),bgYellow:e("\x1B[43m","\x1B[49m"),bgBlue:e("\x1B[44m","\x1B[49m"),bgMagenta:e("\x1B[45m","\x1B[49m"),bgCyan:e("\x1B[46m","\x1B[49m"),bgWhite:e("\x1B[47m","\x1B[49m"),blackBright:e("\x1B[90m","\x1B[39m"),redBright:e("\x1B[91m","\x1B[39m"),greenBright:e("\x1B[92m","\x1B[39m"),yellowBright:e("\x1B[93m","\x1B[39m"),blueBright:e("\x1B[94m","\x1B[39m"),magentaBright:e("\x1B[95m","\x1B[39m"),cyanBright:e("\x1B[96m","\x1B[39m"),whiteBright:e("\x1B[97m","\x1B[39m"),bgBlackBright:e("\x1B[100m","\x1B[49m"),bgRedBright:e("\x1B[101m","\x1B[49m"),bgGreenBright:e("\x1B[102m","\x1B[49m"),bgYellowBright:e("\x1B[103m","\x1B[49m"),bgBlueBright:e("\x1B[104m","\x1B[49m"),bgMagentaBright:e("\x1B[105m","\x1B[49m"),bgCyanBright:e("\x1B[106m","\x1B[49m"),bgWhiteBright:e("\x1B[107m","\x1B[49m")}};Fo.exports=bp();Fo.exports.createColors=bp;});var Rf={};Fn(Rf,{AwsClient:()=>yl,AwsV4Signer:()=>Qi});async function Hs(s,e){let r=await crypto.subtle.importKey("raw",typeof s=="string"?gl.encode(s):s,{name:"HMAC",hash:{name:"SHA-256"}},false,["sign"]);return crypto.subtle.sign("HMAC",r,gl.encode(e))}async function wf(s){return crypto.subtle.digest("SHA-256",typeof s=="string"?gl.encode(s):s)}function dl(s){let e=new Uint8Array(s),r="";for(let t=0;t<e.length;t++){let n=e[t];r+=Cf[n>>>4&15],r+=Cf[n&15];}return r}function Af(s){return s.replace(/[!'()*]/g,e=>"%"+e.charCodeAt(0).toString(16).toUpperCase())}function sS(s,e){let{hostname:r,pathname:t}=s;if(r.endsWith(".on.aws")){let o=r.match(/^[^.]{1,63}\.lambda-url\.([^.]{1,63})\.on\.aws$/);return o!=null?["lambda",o[1]||""]:["",""]}if(r.endsWith(".r2.cloudflarestorage.com"))return ["s3","auto"];if(r.endsWith(".backblazeb2.com")){let o=r.match(/^(?:[^.]{1,63}\.)?s3\.([^.]{1,63})\.backblazeb2\.com$/);return o!=null?["s3",o[1]||""]:["",""]}let n=r.replace("dualstack.","").match(/([^.]{1,63})\.(?:([^.]{0,63})\.)?amazonaws\.com(?:\.cn)?$/),i=n&&n[1]||"",a=n&&n[2];if(a==="us-gov")a="us-gov-west-1";else if(a==="s3"||a==="s3-accelerate")a="us-east-1",i="s3";else if(i==="iot")r.startsWith("iot.")?i="execute-api":r.startsWith("data.jobs.iot.")?i="iot-jobs-data":i=t==="/mqtt"?"iotdevicegateway":"iotdata";else if(i==="autoscaling"){let o=(e.get("X-Amz-Target")||"").split(".")[0];o==="AnyScaleFrontendService"?i="application-autoscaling":o==="AnyScaleScalingPlannerFrontendService"&&(i="autoscaling-plans");}else a==null&&i.startsWith("s3-")?(a=i.slice(3).replace(/^fips-|^external-1/,""),i="s3"):i.endsWith("-fips")?i=i.slice(0,-5):a&&/-\d$/.test(i)&&!/-\d$/.test(a)&&([i,a]=[a,i]);return [tS[i]||i,a||""]}var gl,tS,rS,yl,Qi,Cf,_f=jh(()=>{gl=new TextEncoder,tS={appstream2:"appstream",cloudhsmv2:"cloudhsm",email:"ses",marketplace:"aws-marketplace",mobile:"AWSMobileHubService",pinpoint:"mobiletargeting",queue:"sqs","git-codecommit":"codecommit","mturk-requester-sandbox":"mturk-requester","personalize-runtime":"personalize"},rS=new Set(["authorization","content-type","content-length","user-agent","presigned-expires","expect","x-amzn-trace-id","range","connection"]),yl=class{constructor({accessKeyId:e,secretAccessKey:r,sessionToken:t,service:n,region:i,cache:a,retries:o,initRetryMs:l}){if(e==null)throw new TypeError("accessKeyId is a required option");if(r==null)throw new TypeError("secretAccessKey is a required option");this.accessKeyId=e,this.secretAccessKey=r,this.sessionToken=t,this.service=n,this.region=i,this.cache=a||new Map,this.retries=o??10,this.initRetryMs=l||50;}async sign(e,r){if(e instanceof Request){let{method:i,url:a,headers:o,body:l}=e;r=Object.assign({method:i,url:a,headers:o},r),r.body==null&&o.has("Content-Type")&&(r.body=l!=null&&o.has("X-Amz-Content-Sha256")?l:await e.clone().arrayBuffer()),e=a;}let t=new Qi(Object.assign({url:e.toString()},r,this,r&&r.aws)),n=Object.assign({},r,await t.sign());delete n.aws;try{return new Request(n.url.toString(),n)}catch(i){if(i instanceof TypeError)return new Request(n.url.toString(),Object.assign({duplex:"half"},n));throw i}}async fetch(e,r){for(let t=0;t<=this.retries;t++){let n=fetch(await this.sign(e,r));if(t===this.retries)return n;let i=await n;if(i.status<500&&i.status!==429)return i;await new Promise(a=>setTimeout(a,Math.random()*this.initRetryMs*Math.pow(2,t)));}throw new Error("An unknown error occurred, ensure retries is not negative")}},Qi=class{constructor({method:e,url:r,headers:t,body:n,accessKeyId:i,secretAccessKey:a,sessionToken:o,service:l,region:u,cache:p,datetime:c,signQuery:f,appendSessionToken:m,allHeaders:d,singleEncode:g}){if(r==null)throw new TypeError("url is a required option");if(i==null)throw new TypeError("accessKeyId is a required option");if(a==null)throw new TypeError("secretAccessKey is a required option");this.method=e||(n?"POST":"GET"),this.url=new URL(r),this.headers=new Headers(t||{}),this.body=n,this.accessKeyId=i,this.secretAccessKey=a,this.sessionToken=o;let b,y;(!l||!u)&&([b,y]=sS(this.url,this.headers)),this.service=l||b||"",this.region=u||y||"us-east-1",this.cache=p||new Map,this.datetime=c||new Date().toISOString().replace(/[:-]|\.\d{3}/g,""),this.signQuery=f,this.appendSessionToken=m||this.service==="iotdevicegateway",this.headers.delete("Host"),this.service==="s3"&&!this.signQuery&&!this.headers.has("X-Amz-Content-Sha256")&&this.headers.set("X-Amz-Content-Sha256","UNSIGNED-PAYLOAD");let T=this.signQuery?this.url.searchParams:this.headers;if(T.set("X-Amz-Date",this.datetime),this.sessionToken&&!this.appendSessionToken&&T.set("X-Amz-Security-Token",this.sessionToken),this.signableHeaders=["host",...this.headers.keys()].filter(w=>d||!rS.has(w)).sort(),this.signedHeaders=this.signableHeaders.join(";"),this.canonicalHeaders=this.signableHeaders.map(w=>w+":"+(w==="host"?this.url.host:(this.headers.get(w)||"").replace(/\s+/g," "))).join(`
|
|
13
|
-
`)
|
|
12
|
+
var Nh=Object.create;var Zo=Object.defineProperty;var Ih=Object.getOwnPropertyDescriptor;var Dh=Object.getOwnPropertyNames;var jh=Object.getPrototypeOf,Lh=Object.prototype.hasOwnProperty;var $=(t,e)=>()=>(t&&(e=t(t=0)),e);var iu=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),xr=(t,e)=>{for(var n in e)Zo(t,n,{get:e[n],enumerable:true});},Uh=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Dh(e))!Lh.call(t,s)&&s!==n&&Zo(t,s,{get:()=>e[s],enumerable:!(r=Ih(e,s))||r.enumerable});return t};var ou=(t,e,n)=>(n=t!=null?Nh(jh(t)):{},Uh(Zo(n,"default",{value:t,enumerable:true}),t));function Mh(t,e,n=void 0){let r=typeof e=="string"?uu(e):na(e);return ni(t,r,n)}function ni(t,e,n=void 0){let r=typeof e=="string"?e.split(/[.\[\]\"]+/).filter(s=>s):e;if(r.length===0)return t;try{let[s,...i]=r;return !s||!(s in t)?n:ni(t[s],i,n)}catch{if(typeof n<"u")return n;throw new Error(`Invalid path: ${r.join(".")}`)}}function qh(t){return t===null}function fe(t){return !Array.isArray(t)&&typeof t=="object"&&t!==null}function Wh(t){return Object.prototype.toString.call(t)==="[object Object]"}function ot(t){return typeof t=="string"}function wt(t){return typeof t=="number"}function Jh(t){return typeof t=="number"&&Number.isInteger(t)}function ia(t){return typeof t=="boolean"}function Kt(t){return Array.isArray(t)}function Kh(t){return typeof t!="boolean"}function Hh(t){return t!==void 0&&Kh(t)&&"type"in t}function ve(t){return t!==void 0&&fe(t)&&xe in t}function zh(t){return ve(t)&&typeof t.toJSON()=="boolean"}function Gh(t,e,n){if(!t)throw new Bh(e,n)}function fu(t){return ot(t)?t.normalize("NFC"):t}function vr(t,e){let n=typeof t;if(n!==typeof e)return false;if(Array.isArray(t)){if(!Array.isArray(e))return false;let r=t.length;if(r!==e.length)return false;for(let s=0;s<r;s++)if(!vr(t[s],e[s]))return false;return true}if(n==="object"){if(!t||!e)return t===e;let r=Object.keys(t),s=Object.keys(e);if(r.length!==s.length)return false;for(let i of r)if(!vr(t[i],e[i]))return false;return true}return t===e}function Vh(t,e){return e.reduce((n,r)=>(r in t&&(n[r]=t[r]),n),{})}function du(t){try{return structuredClone(t)}catch{return t}}function Qh(t,e,n={}){let r=e;try{r=structuredClone(e);}catch{r=JSON.parse(JSON.stringify(e));}let s={resolver:n.resolver||new oa(t),depth:n.depth||0,dropUnknown:n.dropUnknown??false};return s.resolver.hasRef(t,r)?s.resolver.resolve(t.$ref).coerce(r,{...s,depth:s.depth+1}):r}function ri(t,e,n={}){return t.map(r=>r.validate(e,ti(n)).valid?r:void 0).filter(Boolean)}function Ag(t,e,n={}){let r={keywordPath:n.keywordPath||[],instancePath:n.instancePath||[],coerce:n.coerce||false,errors:n.errors||[],shortCircuit:n.shortCircuit||false,ignoreUnsupported:n.ignoreUnsupported||false,resolver:n.resolver||t.getResolver?.()||new oa(t),depth:n.depth?n.depth+1:0,skipClone:n.skipClone||false},s;if(n?.coerce&&t.coerce){let i=t.coerce(e,{resolver:r.resolver,depth:r.depth});s=r.skipClone?i:structuredClone(i);}else s=r.skipClone?e:structuredClone(e);if(n.ignoreUnsupported!==true){let i=["$defs"];for(let o of i)if(t[o])throw new Error(`${o} not implemented`)}if(r.resolver.hasRef(t,s)){let i=r.resolver.resolve(t.$ref).validate(s,{...r,errors:[]});i.valid||r.errors.push(...i.errors);}else {let i={keywordPath:r.keywordPath,instancePath:r.instancePath,coerce:r.coerce,errors:[],shortCircuit:r.shortCircuit,ignoreUnsupported:r.ignoreUnsupported,resolver:r.resolver,depth:r.depth};for(let o in t)if(o==="type"&&t.type!==void 0){if(s!==void 0){let a=ea[o];if(a){i.errors=[];let l=a(t,s,i);if(!l.valid){if(n.shortCircuit)return l;r.errors.push(...l.errors);}}}}else if(o in ea&&t[o]!==void 0){if(s===void 0)continue;let a=ea[o];if(a){i.errors=[];let l=a(t,s,i);if(!l.valid){if(n.shortCircuit)return l;r.errors.push(...l.errors);}}}}return {valid:r.errors.length===0,errors:r.errors}}function si(t,e,n){return new class extends St{type=t}(e,n)}function ra(t){return new Og(t)}function lu(t,e){return Array.isArray(t)?t.map(e):t!==void 0?[e(t)]:[]}function cu(t,e,n=r=>r){return Object.fromEntries(Object.entries(t).map(([r,s])=>[r,n(e(s,r),r)]))}function Jt(t){if(ia(t))return ra(t);let e=structuredClone(t);if(!fe(e))throw new Fh("non-object schemas cannot be converted to a schema",e);"properties"in e&&e.properties&&(e.properties=cu(e.properties,(i,o)=>{try{return Jt(i)}catch(a){throw new Error(`Couldn't schemaize property "${o}": ${String(a)}`)}},(i,o)=>"required"in e&&Array.isArray(e.required)&&e.required.includes(o)?i:i.optional()));let n=["patternProperties","dependentSchemas","$defs"];for(let i of n)i in e&&e[i]&&(e[i]=cu(e[i],Jt));let r=["additionalProperties","items","prefixItems","propertyNames","contains","not","if","then","else"];for(let i of r)i in e&&typeof e[i]<"u"&&(Kt(e[i])?e[i]=lu(e[i],Jt):e[i]=Jt(e[i]));let s=["anyOf","oneOf","allOf"];for(let i of s)if(i in e){let{[i]:o}=e;e[i]=lu(o,Jt);}if(Hh(e))switch(e.type){case "string":return cn(e);case "number":return hu(e);case "integer":return gu(e);case "boolean":return Rr(e);case "object":{let{properties:i,...o}=e;return ii(i,o)}case "array":{let{items:i,...o}=e;return yu(i,o)}}return pu(e)}function Bg(){return {type(t){let e=t.map(n=>Array.isArray(n)?new Set(n):new Set([n])).reduce((n,r)=>n?new Set([...n].filter(s=>r.has(s))):new Set(r));if(!e.size)throw new Error('Incompatible "type" in allOf');return e.size===1?[...e][0]:[...e]},enum(t){let e=t.map(n=>new Set(n)).reduce((n,r)=>new Set([...n].filter(s=>r.has(s))));if(!e.size)throw new Error('Incompatible "enum" in allOf');return [...e]},required(t){return [...new Set(t.flat())]},properties(t,e,n){return t.reduce((r,s)=>n(r,s),{})},patternProperties(t,e,n){return t.reduce((r,s)=>n(r,s),{})},$defs(t,e,n){return t.reduce((r,s)=>n(r,s),{})},definitions(t,e,n){return t.reduce((r,s)=>n(r,s),{})},...Object.fromEntries(Mg.map(t=>[t,e=>Math.min(...e)])),...Object.fromEntries(Fg.map(t=>[t,e=>Math.max(...e)]))}}function qg(t){let e={...Bg(),...t.resolvers};function n(r,s){if(Array.isArray(r)&&Array.isArray(s))return [...new Set([...r,...s])];if(sa(r)&&sa(s)){let i={...r};for(let[o,a]of Object.entries(s))if(o in i){let l=e[o];i[o]=l?l([i[o],a],o,n):ta(a);}else i[o]=ta(a);return i}return ta(s)}return n}function Jg(t,e={}){let n=e.deep!==false,r=qg(e);function s(i){if(Array.isArray(i))return i.map(s);if(!sa(i))return i;if(Array.isArray(i.allOf)){let a=i.allOf.map(s);if(a.some(p=>p===false))return false;let l=a.filter(p=>p!==true);if(!l.length)return true;let c=l.reduce((p,y)=>r(p,y),{}),f=Wg(c);if(f!==null)return f;let u={...i};delete u.allOf;let d=r(c,n?s(u):u);return n?s(d):d}let o={};for(let[a,l]of Object.entries(i))o[a]=s(l);return o}return s(t)}var na,uu,Q,T,Mn,ti,ln,Fh,Bh,xe,oa,Xh,Yh,Zh,eg,tg,ng,rg,sg,ig,og,ag,lg,cg,ug,fg,dg,pg,mg,hg,gg,yg,bg,wg,Sg,Eg,_g,xg,vg,Cg,Rg,Tg,au,kg,ea,St,Cr,Og,pu,$g,Pg,ii,Fn,Ng,Ig,Dg,aa,cn,mu,hu,gu,jg,yu,Rr,ei,bu,Lg,Ug,sa,ta,Mg,Fg,Wg,Kg,wu,Hg,zg,Gg,g,ee=$(()=>{na=(t=[],e="")=>"/"+[e,...t.map(n=>String(n).replace(/\./g,"/"))].filter(Boolean).join("/"),uu=t=>t.split("/").slice(1);Q=(t={},e,n,r)=>({valid:false,errors:[...t.errors??[],{keywordLocation:na([...t.keywordPath??[],e]),instanceLocation:na(t.instancePath),error:typeof n=="string"?n:`Invalid value for ${e}`,data:r}]}),T=()=>({valid:true,errors:[]}),Mn=(t,e,n)=>{let r=Array.isArray(e)?e:[e],s=n?Array.isArray(n)?n:[n]:[];return {...t,keywordPath:[...t.keywordPath??[],...r],instancePath:s?[...t.instancePath??[],...s]:t.instancePath}},ti=(t={})=>({...t,errors:[]}),ln=class extends Error{constructor(t){super(`Expected ${t}`);}},Fh=class extends Error{constructor(t,e){super(`${t??"Invalid raw schema"}: ${JSON.stringify(e)}`),this.schema=e;}},Bh=class extends Error{constructor(t,e){super(`${t}, got: 'type "${typeof e}": ${JSON.stringify(e)}'`),this.value=e;}},xe=Symbol.for("jsonv-ts:schema");oa=class{constructor(t){this.root=t,this.cache=new Map;}cache;hasRef(t,e){return e!==void 0&&"$ref"in t&&ot(t.$ref)}resolve(t){let e=this.cache.get(t);if(!e){if(e=Mh(this.root,t),!ve(e))throw new Error(`ref not found: ${t}`);if("$ref"in e&&e.$ref===t)throw new Error(`ref loop: ${t}`);this.cache.set(t,e);}return e}};Xh=({type:t},e,n={})=>{if(t===void 0||e===void 0)return T();let r,s={string:ot,number:wt,integer:Jh,object:fe,array:Kt,boolean:ia,null:qh};if(Array.isArray(t)){for(let i of t){if(!(i in s))throw new ln(`Unknown type: ${i}`);if(s[i](e))return T()}r=`Expected one of: ${t.join(", ")}`;}else {if(!(t in s))throw new ln(`Unknown type: ${t}`);s[t](e)||(r=`Expected ${t}`);}return r?Q(n,"type",r,e):T()},Yh=({const:t},e,n={})=>vr(t,e)?T():Q(n,"const",`Expected const: ${t}`,e),Zh=({enum:t=[]},e,n={})=>t.some(r=>vr(r,e))?T():Q(n,"enum",`Expected enum: ${JSON.stringify(t)}`,e);eg=({anyOf:t=[]},e,n={})=>ri(t,e,n).length>0?T():Q(n,"anyOf","Expected at least one to match",e),tg=({oneOf:t=[]},e,n={})=>ri(t,e).length===1?T():Q(n,"oneOf","Expected exactly one to match",e),ng=({allOf:t=[]},e,n={})=>ri(t,e,n).length===t.length?T():Q(n,"allOf","Expected all to match",e),rg=({not:t},e,n={})=>e===void 0?T():ve(t)&&t.validate(e,n).valid?Q(n,"not","Expected not to match",e):T(),sg=({if:t,then:e,else:n},r,s={})=>{if(t&&(e||n)){if(t.validate(r,ti(s)).valid)return e?e.validate(r,ti(s)):T();if(n)return n.validate(r,ti(s))}return T()},ig=({pattern:t=""},e,n={})=>{if(!ot(e))return T();if(t instanceof RegExp){if(t.test(e))return T()}else if(new RegExp(t,"u").test(e))return T();return Q(n,"pattern",`Expected string matching pattern ${t}`,e)},og=({minLength:t=0},e,n={})=>ot(e)?[...fu(e)].length>=t?T():Q(n,"minLength",`Expected string with minimum length of ${t}`,e):T(),ag=({maxLength:t=0},e,n={})=>ot(e)?[...fu(e)].length<=t?T():Q(n,"maxLength",`Expected string with maximum length of ${t}`,e):T(),lg=({multipleOf:t=0},e,n={})=>{if(!wt(e))return T();if(!(Number.isFinite(e)&&Number.isFinite(t))||t<=0)throw new ln("number");let r=e/t,s=Number.EPSILON*Math.max(1,Math.abs(r));return Math.abs(r-Math.round(r))<=s?T():Q(n,"multipleOf",`Expected number being a multiple of ${t}`,e)},cg=({maximum:t=0},e,n={})=>!wt(e)||e<=t?T():Q(n,"maximum",`Expected number less than or equal to ${t}`,e),ug=({exclusiveMaximum:t=0},e,n={})=>!wt(e)||e<t?T():Q(n,"exclusiveMaximum",`Expected number less than ${t}`,e),fg=({minimum:t=0},e,n={})=>!wt(e)||e>=t?T():Q(n,"minimum",`Expected number greater than or equal to ${t}`,e),dg=({exclusiveMinimum:t=0},e,n={})=>!wt(e)||e>t?T():Q(n,"exclusiveMinimum",`Expected number greater than ${t}`,e),pg=({properties:t={}},e,n={})=>{if(!fe(e))return T();for(let[r,s]of Object.entries(e)){let i=t[r];if(!ve(i))continue;let o=i.validate(s,Mn(n,["properties",r],r));if(!o.valid)return o}return T()},mg=({properties:t={},additionalProperties:e,patternProperties:n},r,s={})=>{if(!fe(r))return T();if(!ve(e))throw new ln("additionalProperties must be a boolean or a managed schema");let i=Object.keys(t),o=fe(n)?Object.keys(r).filter(l=>Object.keys(n).some(c=>new RegExp(c).test(l))):[],a=Object.keys(r).filter(l=>!i.includes(l)&&!o.includes(l));if(a.length>0){if(zh(e)){if(e.toJSON()===true)return T();let l=a.reduce((c,f)=>(c[f]=r[f],c),{});return Q(s,"additionalProperties","Additional properties are not allowed",l)}else if(ve(e))for(let l of a){let c=e.validate(r[l],Mn(s,["additionalProperties"],l));if(!c.valid)return c}}return T()},hg=({dependentRequired:t},e,n={})=>{if(!fe(e))return T();let r=Object.keys(e).filter(s=>typeof e[s]!="function");if(fe(t)){for(let[s,i]of Object.entries(t))if(r.includes(s)){for(let o of i)if(!r.includes(o))return Q(n,"dependentRequired",`Expected dependent required property ${o}`,e)}}return T()},gg=({required:t=[]},e,n={})=>{if(!fe(e))return T();let r=Object.keys(e).filter(s=>typeof e[s]!="function");return t.every(s=>r.includes(s))?T():Q(n,"required",`Expected object with required properties ${t.join(", ")}`,e)},yg=({dependentSchemas:t},e,n={})=>{if(!fe(e))return T();let r=Object.keys(e).filter(s=>typeof e[s]!="function");if(fe(t)){for(let[s,i]of Object.entries(t))if(r.includes(s)){let o=i.validate(e,n);if(!o.valid)return o}}return T()},bg=({minProperties:t=0},e,n={})=>fe(e)?Object.keys(e).length>=t?T():Q(n,"minProperties",`Expected object with at least ${t} properties`,e):T(),wg=({maxProperties:t=0},e,n={})=>!fe(e)||Object.keys(e).length<=t?T():Q(n,"maxProperties",`Expected object with at most ${t} properties`,e),Sg=({patternProperties:t={}},e,n={})=>{if(!fe(e))return T();if(!fe(t))throw new ln("patternProperties must be an object");for(let[r,s]of Object.entries(e))for(let[i,o]of Object.entries(t))if(new RegExp(i,"u").test(r)){let a=o.validate(s,Mn(n,["patternProperties"],r));if(!a.valid)return a}return T()},Eg=({propertyNames:t},e,n={})=>{if(!fe(e)||t===void 0)return T();if(!ve(t))throw new ln("propertyNames must be a managed schema");for(let r of Object.keys(e)){let s=t.validate(r,Mn(n,["propertyNames"],r));if(!s.valid)return s}return T()},_g=({items:t,prefixItems:e=[]},n,r={})=>{if(!Kt(n)||t===void 0)return T();if(!ve(t))throw new ln("items must be a managed schema");for(let[s,i]of n.slice(e.length).entries()){let o=t.validate(i,Mn(r,["items"],String(s)));if(!o.valid)return o}return T()},xg=({minItems:t=0},e,n={})=>!Kt(e)||e.length>=t?T():Q(n,"minItems",`Expected array with at least ${t} items`,e),vg=({maxItems:t=0},e,n={})=>!Kt(e)||e.length<=t?T():Q(n,"maxItems",`Expected array with at most ${t} items`,e),Cg=({uniqueItems:t=false},e,n={})=>{if(!Kt(e)||!t)return T();for(let r=0;r<e.length;r++){let s=e[r];for(let i=0;i<e.length;i++){if(r===i)continue;let o=e[i];if(vr(s,o))return Q(n,"uniqueItems",`Duplicated items at index ${r} and ${i}`,e)}}return T()},Rg=({contains:t,minContains:e,maxContains:n},r,s={})=>{if(!ve(t))throw new Error("contains must be a managed schema");if(!Kt(r))return T();let i=r.filter(o=>t.validate(o).valid).length;return i<(e??1)?Q(s,e?"minContains":"contains",`Expected array to contain at least ${e??1}, but found ${i}`,r):n!==void 0&&i>n?Q(s,"maxContains",`Expected array to contain at most ${n}, but found ${i}`,r):T()},Tg=({prefixItems:t=[]},e,n={})=>{if(!Kt(e))return T();for(let r=0;r<e.length;r++){let s=t[r]?.validate(e[r],Mn(n,String(r),String(r)));if(s&&s?.valid!==true)return s}return T()},au={email:t=>{if(t.length>318)return false;if(/^[a-z0-9!#$%&'*+/=?^_`{|}~-]{1,20}(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]{1,21}){0,2}@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,60}[a-z0-9])?){0,3}$/i.test(t))return true;if(!t.includes("@")||/(^\.|^"|\.@|\.\.)/.test(t))return false;let[e,n,...r]=t.split("@");return !e||!n||r.length!==0||e.length>64||n.length>253||!/^[a-z0-9.-]+$/i.test(n)||!/^[a-z0-9.!#$%&'*+/=?^_`{|}~-]+$/i.test(e)?false:n.split(".").every(s=>/^[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?$/i.test(s))},hostname:t=>t.length>(t.endsWith(".")?254:253)?false:/^[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*\.?$/i.test(t),date:t=>{if(t.length!==10)return false;if(t[5]==="0"&&t[6]==="2"){if(/^\d\d\d\d-02-(?:[012][1-8]|[12]0|[01]9)$/.test(t))return true;let e=t.match(/^(\d\d\d\d)-02-29$/);if(!e)return false;let n=Number(e[1]);return n%16===0||n%4===0&&n%25!==0}return t.endsWith("31")?/^\d\d\d\d-(?:0[13578]|1[02])-31$/.test(t):/^\d\d\d\d-(?:0[13-9]|1[012])-(?:[012][1-9]|[123]0)$/.test(t)},time:t=>{if(t.length>27||!/^(?:2[0-3]|[0-1]\d):[0-5]\d:(?:[0-5]\d|60)(?:\.\d+)?(?:z|[+-](?:2[0-3]|[0-1]\d)(?::?[0-5]\d)?)?$/i.test(t))return false;if(!/:60/.test(t))return true;let e=t.match(/([0-9.]+|[^0-9.])/g);if(!e)return false;let n=Number(e[0])*60+Number(e[2]);return e[5]==="+"?n+=1440-Number(e[6]||0)*60-Number(e[8]||0):e[5]==="-"&&(n+=Number(e[6]||0)*60+Number(e[8]||0)),n%1440===1439},"date-time":t=>{if(t.length>38)return false;let e=/^\d\d\d\d-(?:0[1-9]|1[0-2])-(?:[0-2]\d|3[01])[t\s](?:2[0-3]|[0-1]\d):[0-5]\d:(?:[0-5]\d|60)(?:\.\d+)?(?:z|[+-](?:2[0-3]|[0-1]\d)(?::?[0-5]\d)?)$/i,n=t[5]==="0"&&t[6]==="2";if(n&&t[8]==="3"||!e.test(t))return false;if(t[17]==="6"){let r=t.slice(11).match(/([0-9.]+|[^0-9.])/g);if(!r)return false;let s=Number(r[0])*60+Number(r[2]);if(r[5]==="+"?s+=1440-Number(r[6]||0)*60-Number(r[8]||0):r[5]==="-"&&(s+=Number(r[6]||0)*60+Number(r[8]||0)),s%1440!==1439)return false}if(n){if(/^\d\d\d\d-02-(?:[012][1-8]|[12]0|[01]9)/.test(t))return true;let r=t.match(/^(\d\d\d\d)-02-29/);if(!r)return false;let s=Number(r[1]??0);return s%16===0||s%4===0&&s%25!==0}return t[8]==="3"&&t[9]==="1"?/^\d\d\d\d-(?:0[13578]|1[02])-31/.test(t):/^\d\d\d\d-(?:0[13-9]|1[012])-(?:[012][1-9]|[123]0)/.test(t)},ipv4:t=>t.length<=15&&/^(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)$/.test(t),ipv6:t=>{if(t.length>45||t.length<2)return false;let e=0,n=0,r=0,s=false,i=false,o=0,a=true;for(let c=0;c<t.length;c++){let f=t.charCodeAt(c);if(c===1&&o===58&&f!==58)return false;if(f>=48&&f<=57){if(++r>4)return false}else if(f===46){if(e>6||n>=3||r===0||i)return false;n++,r=0;}else if(f===58){if(n>0||e>=7)return false;if(o===58){if(s)return false;s=true;}else c===0&&(a=false);e++,r=0,i=false;}else if(f>=97&&f<=102||f>=65&&f<=70){if(n>0||++r>4)return false;i=true;}else return false;o=f;}if(e<2||n>0&&(n!==3||r===0))return false;if(s&&t.length===2)return true;if(n>0&&!/(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}$/.test(t))return false;let l=n>0?6:7;return s?(a||r>0)&&e<l:e===l&&a&&r>0},uri:t=>/^[a-z][a-z0-9+\-.]*:(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|v[0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/?(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?)(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i.test(t),"uri-reference":t=>/^(?:[a-z][a-z0-9+\-.]*:)?(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|v[0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/?(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?)?(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i.test(t),"uri-template":t=>/^(?:[^\x00-\x20"'<>%\\^`{|}]|%[0-9a-f]{2}|\{[+#./;?&=,!@|]?(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?(?:,(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?)*\})*$/i.test(t),"json-pointer":t=>/^(?:|\/(?:[^~]|~0|~1)*)$/.test(t),"relative-json-pointer":t=>/^(?:0|[1-9][0-9]*)(?:|#|\/(?:[^~]|~0|~1)*)$/.test(t),uuid:t=>/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(t),duration:t=>t.length>1&&t.length<80&&(/^P\d+([.,]\d+)?W$/.test(t)||/^P[\dYMDTHS]*(\d[.,]\d+)?[YMDHS]$/.test(t)&&/^P([.,\d]+Y)?([.,\d]+M)?([.,\d]+D)?(T([.,\d]+H)?([.,\d]+M)?([.,\d]+S)?)?$/.test(t)),regex:t=>{if(/[^\\]\\Z/.test(t))return false;try{return new RegExp(t,"u"),!0}catch{return false}},binary:()=>true,password:()=>true},kg=({format:t},e,n={})=>!ot(e)||!t?T():au[t]?au[t](e)?T():Q(n,"format",`Expected format: ${t}`,e):T(),ea={type:Xh,const:Yh,enum:Zh,allOf:ng,anyOf:eg,oneOf:tg,not:rg,minLength:og,maxLength:ag,pattern:ig,format:kg,minimum:fg,exclusiveMinimum:dg,maximum:cg,exclusiveMaximum:ug,multipleOf:lg,required:gg,dependentRequired:hg,dependentSchemas:yg,minProperties:bg,maxProperties:wg,propertyNames:Eg,properties:pg,patternProperties:Sg,additionalProperties:mg,minItems:xg,maxItems:vg,uniqueItems:Cg,contains:Rg,prefixItems:Tg,items:_g,if:sg};St=class{"~standard";[xe];_resolver;type;$id;$ref;$schema;title;description;readOnly;writeOnly;$comment;examples;constructor(t,e){let{type:n,validate:r,coerce:s,template:i,...o}=t||{};Object.assign(this,{type:n},o),this[xe]={raw:t,optional:false,overrides:e},this["~standard"]={version:1,vendor:"jsonv-ts",validate:a=>{let l=this.validate(a);return l.valid?{value:a}:{issues:l.errors.map(c=>({message:c.error,path:uu(c.instanceLocation)}))}}};}template(t,e){let n=this,r=t;if(n.const!==void 0?r=n.const:r===void 0&&(n.default!==void 0&&(r=n.default),e?.withExtendedOptional&&n.enum!==void 0&&(r=n.enum[0])),e?.withOptional!==true&&r===void 0&&this.isOptional())return r;if(this[xe].raw?.template){let i=this[xe].raw.template(r,e);i!==void 0&&(r=i);}let s=this[xe].overrides?.template?.(r,e);return s!==void 0&&(r=s),r}validate(t,e){let n={keywordPath:e?.keywordPath||[],instancePath:e?.instancePath||[],coerce:e?.coerce||false,errors:e?.errors||[],shortCircuit:e?.shortCircuit||false,ignoreUnsupported:e?.ignoreUnsupported||false,resolver:e?.resolver||this.getResolver(),depth:e?.depth?e.depth+1:0,skipClone:e?.skipClone??true},r=this[xe].raw?.validate;if(r!==void 0){let s=r(t,n);if(!s.valid)return s}return Ag(this,t,n)}coerce(t,e){let n={...e,resolver:e?.resolver||this.getResolver(),depth:e?.depth?e.depth+1:0,dropUnknown:e?.dropUnknown??false},r=this[xe].raw?.coerce;if(r!==void 0)return r(t,n);let s=this[xe].overrides?.coerce?.(t,n)??t;return Qh(this,s,n)}optional(){return this[xe].optional=true,this}isOptional(){return this[xe].optional}getResolver(){return this._resolver||(this._resolver=new oa(this)),this._resolver}children(t){return []}*walk({instancePath:t=[],keywordPath:e=[],data:n,maxDepth:r=Number.POSITIVE_INFINITY,...s}={}){let i=t.length===0&&n?du(n):n;if(s.includeSelf!==false&&(yield new Cr(this,{instancePath:t,keywordPath:e,data:i,...s})),!(t.length>=r))for(let o of this.children(s)){let a=[...t,...o.instancePath];yield*o.schema.walk({...s,data:i,maxDepth:r,instancePath:a,keywordPath:[...e,...o.keywordPath]});}}*[Symbol.iterator](t){for(let e of this.walk(t))yield e;}toJSON(){let{toJSON:t,"~standard":e,_resolver:n,...r}=this;return JSON.parse(JSON.stringify(r))}},Cr=class{constructor(t,e={}){this.schema=t,this.instancePath=e.instancePath||[],this.keywordPath=e.keywordPath||[],this.depth=this.instancePath.length;try{if(e.data!==void 0){let n=ni(e.data,this.instancePath);t.validate(n).valid&&(this.data=n);}}catch{}}instancePath;keywordPath;data;depth;appendInstancePath(t){return this.instancePath=[...this.instancePath,...t],this}appendKeywordPath(t){return this.keywordPath=[...this.keywordPath,...t],this}setData(t){return this.data=t,this}};Og=class extends St{constructor(t){super(),this.bool=t;}toJSON(){return this.bool}validate(t,e){return this.bool?T():Q(e,"","Always fails",t)}};pu=t=>si(t?.type,t),$g=(t,e)=>si(void 0,{...e,const:t}),Pg=class extends St{type="object";properties;required;constructor(t,e){let n=[];for(let[s,i]of Object.entries(t||{}))Gh(ve(i),"properties must be managed schemas",i),i[xe].optional||n.push(s);let r=e?.additionalProperties===false?ra(false):e?.additionalProperties;n=n.length>0?n:void 0,super({...e,additionalProperties:r,properties:t,required:n},{template:(s,i)=>{let o=structuredClone(fe(s)?s:{}),a={...o};if(this.properties)for(let[l,c]of Object.entries(this.properties)){let f=ni(o,l);if(c.isOptional()&&i?.withOptional!==true&&f===void 0&&s===void 0)continue;let u=c.template(f,i);u!==void 0&&(a[l]=u);}if(!(Object.keys(a).length===0&&!i?.withExtendedOptional))return a},coerce:(s,i)=>{let o=Object.keys(this.properties),a=du(s),l=o.length>0&&Object.values(this.properties).every(f=>!f[xe].optional);if(Wh(a)&&(i?.dropUnknown===true||l)&&(a=Vh(a,o)),typeof a=="string"&&a.match(/^\{/)&&(a=JSON.parse(a)),typeof a!="object"||a===null)return;if(this.properties)for(let[f,u]of Object.entries(this.properties)){let d=a[f];d!==void 0&&(a[f]=u.coerce(d,i));}let c=this.additionalProperties;if(i?.dropUnknown!==true&&(!c||c.validate(null).valid)){let f=fe(s)?s:{},u=Object.keys(f).filter(d=>!o.includes(d));for(let d of u)a[d]=c?c.coerce(f[d],i):f[d];}return a}}),this.properties=t,this.required=n;}strict(){return this.additionalProperties=ra(false),this[xe].raw.additionalProperties=false,this}partial(){for(let[,t]of Object.entries(this.properties))t[xe].optional=true;return this.required=void 0,this}children(t){let e=[];for(let[n,r]of Object.entries(this.properties)){let s=new Cr(r,t);s.appendInstancePath([n]),s.appendKeywordPath(["properties",n]),e.push(s);}return e}},ii=(t,e)=>new Pg(t,e),Fn=(t,e)=>ii(t,e).strict(),Ng=(t,e)=>ii(t,e).partial(),Ig=class extends St{type="object";additionalProperties;constructor(t,e){super({...e,additionalProperties:t},{template:(n,r)=>r?.withExtendedOptional&&(n===void 0||!fe(n))?{}:n}),this.additionalProperties=t;}children(t){let e=[],n=new Cr(this.additionalProperties,t);return n.appendKeywordPath(["additionalProperties"]),e.push(n),e}},Dg=(t,e)=>new Ig(t,e),aa=class extends St{type="string";constructor(t){super(t,{template:(e,n)=>n?.withExtendedOptional&&(e===void 0||!ot(e))?"":e,coerce:e=>wt(e)?String(e):e});}toJSON(){let{pattern:t,"~standard":e,_resolver:n,...r}=this;return JSON.parse(JSON.stringify({...r,pattern:t instanceof RegExp?t.source:t}))}},cn=t=>new aa(t),mu=(t,e,n)=>si(t,n,{template:(r,s)=>s?.withExtendedOptional&&(r===void 0||!wt(r))?n?.minimum??0:r,coerce:r=>{if(ot(r)){let s=e.parseFn(r);if(!Number.isNaN(s))return s}return r}}),hu=t=>mu("number",{parseFn:Number},t),gu=t=>mu("integer",{parseFn:Number.parseInt},t),jg=class extends St{constructor(t,e={}){super({...e,items:t},{template:n=>n===void 0||!Array.isArray(n)?[]:n,coerce:(n,r)=>{try{let s=typeof n=="string"?JSON.parse(n):n;if(!Array.isArray(s))return;if(ve(this.items))for(let[i,o]of s.entries())s[i]=this.items.coerce(o,r);return s}catch{}return n}}),this.items=t,this.items=t;}type="array";children(t){let e=[];if(this.items){let n=new Cr(this.items,t);n.appendKeywordPath(["items"]),e.push(n);}return e}},yu=(t,e)=>new jg(t,e),Rr=t=>si("boolean",t,{template:(e,n)=>n?.withExtendedOptional&&(e===void 0||!ia(e))?false:e,coerce:e=>{if(ot(e)&&["true","false","1","0"].includes(e))return e==="true"||e==="1";if(wt(e)){if(e===1)return true;if(e===0)return false}return e}}),ei=Symbol.for("unionType"),bu=class extends St{[ei];constructor(t,e,n){super({...n,[e]:t},{coerce:(r,s)=>{let i=n?.coerce;if(i!==void 0)return i.bind(this)(r,s);let o=ri(t,r,{ignoreUnsupported:true,resolver:s?.resolver,coerce:true});return o.length>0?o[0].coerce(r,s):r}}),this[ei]=e;}get schemas(){return this[this[ei]]}children(t){let e=[];for(let[n,r]of this.schemas.entries()){let s=new Cr(r,t);s.appendKeywordPath([this[ei],n]),e.push(s);}return e}},Lg=(t,e)=>new bu(t,"anyOf",e),Ug=(t,e)=>new bu(t,"oneOf",e);sa=t=>typeof t=="object"&&t!==null&&!Array.isArray(t),ta=t=>typeof globalThis.structuredClone=="function"?globalThis.structuredClone(t):JSON.parse(JSON.stringify(t)),Mg=["maximum","exclusiveMaximum","maxLength","maxItems","maxProperties"],Fg=["minimum","exclusiveMinimum","minLength","minItems","minProperties"];Wg=t=>t===true||t===false?t:null;Kg=(t,e)=>{let n=JSON.parse(JSON.stringify({...e,allOf:t}));return Jt(Jg(n))},wu=class extends St{$ref;constructor(t,e){if(!e&&!ve(t))throw new Error("Ref not set");if(ve(t)&&!t.$id)throw new Error("Ref must have an $id");let n=e??t?.$id;super({$ref:n},{coerce:(r,s)=>{let i=s?.resolver?.resolve(this.$ref);if(!ve(i))throw new Error(`Ref not found: ${this.$ref}`);return i.coerce(r,s)}}),this.$ref=n;}},Hg=(t,e)=>new wu(t,e),zg=t=>new wu(void 0,t),Gg=t=>t(new St({$ref:"#",coerce:(e,n)=>{let r=n?.resolver?.resolve("#");if(!ve(r))throw new Error("Ref not found: #");return r.coerce(e,n)}})),g={boolean:Rr,any:pu,literal:$g,object:ii,strictObject:Fn,partialObject:Ng,record:Dg,string:cn,number:hu,integer:gu,array:yu,anyOf:Lg,oneOf:Ug,allOf:Kg,ref:Hg,refId:zg,recursive:Gg};});var sd=iu((xT,nl)=>{var Bi=process||{},nd=Bi.argv||[],Fi=Bi.env||{},mw=!(Fi.NO_COLOR||nd.includes("--no-color"))&&(!!Fi.FORCE_COLOR||nd.includes("--color")||Bi.platform==="win32"||(Bi.stdout||{}).isTTY&&Fi.TERM!=="dumb"||!!Fi.CI),hw=(t,e,n=t)=>r=>{let s=""+r,i=s.indexOf(e,t.length);return ~i?t+gw(s,e,n,i)+e:t+s+e},gw=(t,e,n,r)=>{let s="",i=0;do s+=t.substring(i,r)+n,i=r+e.length,r=t.indexOf(e,i);while(~r);return s+t.substring(i)},rd=(t=mw)=>{let e=t?hw:()=>String;return {isColorSupported:t,reset:e("\x1B[0m","\x1B[0m"),bold:e("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:e("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:e("\x1B[3m","\x1B[23m"),underline:e("\x1B[4m","\x1B[24m"),inverse:e("\x1B[7m","\x1B[27m"),hidden:e("\x1B[8m","\x1B[28m"),strikethrough:e("\x1B[9m","\x1B[29m"),black:e("\x1B[30m","\x1B[39m"),red:e("\x1B[31m","\x1B[39m"),green:e("\x1B[32m","\x1B[39m"),yellow:e("\x1B[33m","\x1B[39m"),blue:e("\x1B[34m","\x1B[39m"),magenta:e("\x1B[35m","\x1B[39m"),cyan:e("\x1B[36m","\x1B[39m"),white:e("\x1B[37m","\x1B[39m"),gray:e("\x1B[90m","\x1B[39m"),bgBlack:e("\x1B[40m","\x1B[49m"),bgRed:e("\x1B[41m","\x1B[49m"),bgGreen:e("\x1B[42m","\x1B[49m"),bgYellow:e("\x1B[43m","\x1B[49m"),bgBlue:e("\x1B[44m","\x1B[49m"),bgMagenta:e("\x1B[45m","\x1B[49m"),bgCyan:e("\x1B[46m","\x1B[49m"),bgWhite:e("\x1B[47m","\x1B[49m"),blackBright:e("\x1B[90m","\x1B[39m"),redBright:e("\x1B[91m","\x1B[39m"),greenBright:e("\x1B[92m","\x1B[39m"),yellowBright:e("\x1B[93m","\x1B[39m"),blueBright:e("\x1B[94m","\x1B[39m"),magentaBright:e("\x1B[95m","\x1B[39m"),cyanBright:e("\x1B[96m","\x1B[39m"),whiteBright:e("\x1B[97m","\x1B[39m"),bgBlackBright:e("\x1B[100m","\x1B[49m"),bgRedBright:e("\x1B[101m","\x1B[49m"),bgGreenBright:e("\x1B[102m","\x1B[49m"),bgYellowBright:e("\x1B[103m","\x1B[49m"),bgBlueBright:e("\x1B[104m","\x1B[49m"),bgMagentaBright:e("\x1B[105m","\x1B[49m"),bgCyanBright:e("\x1B[106m","\x1B[49m"),bgWhiteBright:e("\x1B[107m","\x1B[49m")}};nl.exports=rd();nl.exports.createColors=rd;});function vT(t){return ["string","number","boolean"].includes(typeof t)}function CT(t){return [true,false,0,1].includes(t)}function RT(t){return typeof t=="string"}var id=$(()=>{});function kT(...t){return e=>t.reduce((n,r)=>r(n),e)}function AT(...t){return e=>e.map(n=>t.reduce((r,s)=>s(r),n))}var od=$(()=>{});function ad(t){return Object.prototype.toString.call(t)==="[object Object]"}function ld(t){return t!==null&&typeof t=="object"}function $T(t,e){let n={};for(let r in t)t[r]!==e[r]&&(n[r]=e[r]);return n}function Yt(t,e,n=void 0){let r=typeof e=="string"?e.split(/[.[\]"]+/).filter(s=>s):e;if(r.length===0)return t;try{let[s,...i]=r;return !s||!(s in t)?n:Yt(t[s],i,n)}catch{if(typeof n<"u")return n;throw new Error(`Invalid path: ${r.join(".")}`)}}function yw(t,e,n){let r=e;if(typeof r=="string"){let o=a=>a[0]==='"'&&a.at(-1)==='"';r=r.split(/[.[\]]+/).filter(a=>a).map(a=>Number.isNaN(Number(a))?a:Number(a)).map(a=>typeof a=="string"&&o(a)?a.slice(1,-1):a);}if(r.length===0)throw new Error("The path must have at least one entry in it");let[s,...i]=r;return i.length===0?(t[s]=n,t):(s in t||(t[s]=typeof i[0]=="number"?[]:{}),yw(t[s],i,n),t)}function PT(t,e){return e.reduce((n,r)=>(r in t&&(n[r]=t[r]),n),{})}function NT(t,e){let n=new Set(e),r={};for(let[s,i]of Object.entries(t))n.has(s)||(r[s]=i);return r}function sl(t,...e){for(let n of e)for(let[r,s]of Object.entries(n))s!==void 0&&(!ad(s)&&!Array.isArray(s)||Array.isArray(s)&&!Array.isArray(t[r])?t[r]=s:ld(t[r])?sl(t[r],s):t[r]=s);return t}function bw(t,e,n){for(let[r,s]of Object.entries(e)){let i=n(t[r],s,r,t,e);if(i!==void 0){t[r]=i;continue}s!==void 0&&(!ad(s)&&!Array.isArray(s)||Array.isArray(s)&&!Array.isArray(t[r])?t[r]=s:ld(t[r])?bw(t[r],s,n):t[r]=s);}return t}function rl(t,e){let n=s=>{if(s!==Object(s))return "primitive";if(Array.isArray(s))return "array";if(s instanceof Map)return "map";if(s!=null&&[null,Object.prototype].includes(Object.getPrototypeOf(s)))return "plainObject";if(s instanceof Function)return "function";throw new Error(`deeply comparing an instance of type ${t.constructor?.name} is not supported.`)},r=n(t);if(r!==n(e))return false;if(r==="primitive")return t===e||Number.isNaN(t)&&Number.isNaN(e);if(r==="array")return t.length===e.length&&t.every((s,i)=>rl(s,e[i]));if(r==="map")return t.size===e.size&&[...t].every(([s,i])=>e.has(s)&&rl(i,e.get(s)));if(r==="plainObject"){let s=new Map(Object.entries(t)),i=new Map(Object.entries(e));return s.size===i.size&&[...s].every(([o,a])=>i.has(o)&&rl(a,i.get(o)))}else {if(r==="function")return t.toString()===e.toString();throw new Error("Unreachable")}}function IT(...t){let[e,n,r]=t;return JSON.stringify(e,(s,i)=>typeof i=="bigint"?Number.parseInt(i.toString(),10):i instanceof Map?Object.fromEntries(i.entries()):i instanceof Set?Array.from(i):n&&typeof n=="function"?n(s,i):i,r)}var Gr=$(()=>{});function jT(t){let e=t instanceof Request?new URL(t.url).searchParams:t;return Object.fromEntries(e.entries())}function LT(t,e){let n=t instanceof Request?new URL(t.url).searchParams:t,r={};for(let[s,i]of n.entries())e(s,i)&&(r[s]=i);return r}var cd=$(()=>{});function MT(){try{return !ww()&&global?.process?.release?.name==="node"}catch{return false}}function ww(){try{return typeof Bun<"u"}catch{return false}}function ud(t,e){if(!t)throw new Error(e)}function FT(t,e){try{return t(),!1}catch(n){if(e){if(n instanceof e)return true;throw n}return true}}async function BT(t,e){try{return await t,!1}catch(n){if(e){if(n instanceof e)return true;throw n}return true}}function qT(t,e){try{return t()}catch{return e}}async function WT(t,e){let n=performance.now();await t();let r=performance.now();e(r-n);}var JT,fd=$(()=>{JT={Map:t=>t instanceof Map?t:new Map(typeof t=="object"&&t!==null?Object.entries(t):[]),Set:t=>t instanceof Set?t:new Set(Array.isArray(t)?t:[]),Array:t=>Array.isArray(t)?t:["string","number","boolean"].includes(typeof t)?[t]:[]};});function Vr(t,e={}){return t.split(`
|
|
13
|
+
`).map(n=>n.trim()).filter(n=>n.length>0).filter(n=>!n.startsWith(e.comments??"--")).join(`
|
|
14
|
+
`)}function HT(t,e=true){return (e?Vr(t):t).split(";").filter(Boolean)}function zT(t){let e=[],n="",r=0,s=t.length,i=o=>{Sw(o).length>0&&e.push(o.trim());};for(;r<s;){let o=t[r],a=t[r+1];if(o==="-"&&a==="-"){for(;r<s&&t[r]!==`
|
|
15
|
+
`;)n+=t[r],r++;continue}if(o==="/"&&a==="*"){for(n+="/*",r+=2;r<s&&!(t[r]==="*"&&t[r+1]==="/");)n+=t[r],r++;r<s&&(n+="*/",r+=2);continue}if(o==="'"){for(n+=o,r++;r<s;){if(t[r]==="'"&&t[r+1]==="'"){n+="''",r+=2;continue}if(n+=t[r],t[r]==="'"){r++;break}r++;}continue}if(o==='"'){for(n+=o,r++;r<s;){if(t[r]==='"'&&t[r+1]==='"'){n+='""',r+=2;continue}if(n+=t[r],t[r]==='"'){r++;break}r++;}continue}if(o==="$"){let l=t.indexOf("$",r+1);if(l!==-1){let c=t.slice(r,l+1);if(/^\$[A-Za-z_][A-Za-z0-9_]*\$$|^\$\$$/.test(c)){n+=c,r=l+1;let u=t.indexOf(c,r);u===-1?(n+=t.slice(r),r=s):(n+=t.slice(r,u+c.length),r=u+c.length);continue}}}if(o===";"){i(n),n="",r++;continue}n+=o,r++;}return i(n),e}function Sw(t){let e="",n=0,r=t.length;for(;n<r;){let s=t[n],i=t[n+1];if(s==="-"&&i==="-"){for(;n<r&&t[n]!==`
|
|
16
|
+
`;)n++;continue}if(s==="/"&&i==="*"){for(n+=2;n<r&&!(t[n]==="*"&&t[n+1]==="/");)n++;n+=2;continue}e+=s,n++;}return e.trim()}function il(t){return (t??"").trim().toLowerCase()}function ol(t){return (t??"").replace(/\s+/g," ").replace(/"/g,"").trim().toLowerCase()}function al(t){if(t==null)return null;let e=t.trim();for(;e.startsWith("(")&&e.endsWith(")");)e=e.slice(1,-1).trim();return (e.startsWith("'")&&e.endsWith("'")||e.startsWith('"')&&e.endsWith('"'))&&(e=e.slice(1,-1)),e}var Qr=$(()=>{});function QT(t=10,e={}){let o="abcdefghijklmnopqrstuvwxyz"+(e.uppercase?"ABCDEFGHIJKLMNOPQRSTUVWXYZ":"")+(e.numbers?"0123456789":"")+(e.special?"!@#$%^&*()_+{}:\"<>?|[];',./`~":""),a="";for(let l=0;l<t;l++)a+=o[Math.floor(Math.random()*o.length)];return a}function XT(t,e){if(typeof t!="string"){if(e?.panic)throw new Error("Email must be a string");return false}if(!g.string({format:"email"}).validate(t).valid){if(e?.panic)throw new Error("Invalid email");return false}if(e?.domains?.length&&!e.domains.includes(t.split("@")[1])){if(e?.panic)throw new Error("Email domain not allowed");return false}return true}function YT(t,{panic:e=true,length:n=8,numbers:r=0,special:s=0}={}){try{if(typeof t!="string"){if(e)throw new Error("Password must be a string");return !1}if(t.length<n){if(e)throw new Error(`Password must be at least ${n} characters long`);return !1}if((t.match(/[0-9]/g)?.length??0)<r){if(e)throw new Error(`Password must contain at least ${r} numbers`);return !1}if((t.match(/[!@#$%^&*()_+\-=[\]{};':"\\|,.<>/?]/g)?.length??0)<s){if(e)throw new Error(`Password must contain at least ${s} special characters`);return !1}return !0}catch(i){if(e)throw i;return false}}function ZT(t){return !t||t.length===0?t:t.charAt(0).toUpperCase()+t.slice(1)}function ek(t,e=" "){return !t||t.length===0?t:t.split(e).map(n=>n.charAt(0).toUpperCase()+n.slice(1)).join(e)}function tk(t){return !t||t.length===0?t:t.split("_").map(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()).join(" ")}function Ew(t){return String(t).normalize("NFKD").replace(/[\u0300-\u036f]/g,"")}function nk(t){return Ew(t).trim().toLowerCase().replace(/[^a-z0-9 -]/g,"").replace(/\s+/g,"-").replace(/-+/g,"-")}function rk(t,e=50,n="..."){return t.length<=e?t:t.substring(0,e)+n}function P(t,e='"'){return `${e}${t}${e}`}function qi(t,e,n){if(e instanceof RegExp)return e.test(t);if(typeof e=="string")switch(!n&&e.startsWith("/")&&(n="regex"),n){case "regex":return new RegExp(e).test(t);case "sql":return new RegExp(e.replace("%",".*").replace("_",".")).test(t);case "wildcard":return new RegExp(e.replace("*",".*")).test(t);default:return t.includes(e)}return false}function sk(t,e,n=/\{\{([\w-]+)\}\}/g){return t.replace(n,(r,s)=>s in e?e[s]:r)}function pd(t,e,n=.33){if(e.length===0)return null;let r=dd(t),s=[];for(let l of e){let c=_w(r,dd(l));c>.1&&s.push([l,c]);}s.sort((l,c)=>c[1]-l[1]);let i=s.slice(0,50),o=null,a=n;for(let[l]of i){let c=Math.max(t.length,l.length),f=c===0?1:1-xw(t.toLowerCase(),l.toLowerCase())/c;f>a&&(a=f,o=l);}return o}function dd(t,e=2){let n=new Map,r=`-${t.toLowerCase()}-`;for(let s=0;s<=r.length-e;s++){let i=r.slice(s,s+e);n.set(i,(n.get(i)||0)+1);}return n}function _w(t,e){let n=0,r=0,s=0;for(let[i,o]of t){r+=o*o;let a=e.get(i);a!==void 0&&(n+=o*a);}for(let[,i]of e)s+=i*i;return r===0||s===0?0:n/(Math.sqrt(r)*Math.sqrt(s))}function xw(t,e){let n=t.length,r=e.length,s=Array.from({length:r+1},(i,o)=>o);for(let i=1;i<=n;i++){let o=s[0];s[0]=i;for(let a=1;a<=r;a++){let l=s[a];s[a]=t[i-1]===e[a-1]?o:1+Math.min(o,s[a],s[a-1]),o=l;}}return s[r]}var Xr=$(()=>{ee();});function ok(t){return typeof t=="number"?t:Number.parseInt(String(t),10)}var md=$(()=>{});function lk(){return crypto.randomUUID()}var hd=$(()=>{});var Yr=$(()=>{id();od();Gr();cd();fd();Qr();Xr();md();hd();});var Sn,Wi=$(()=>{Sn=class extends Error{constructor(n,r,s,i){super(`check constraint "${s}" violated for ${n}.${r}`);this.table=n;this.column=r;this.constraint=s;this.value=i;this.name="CheckConstraintError";}};});var mp={};xr(mp,{AwsClient:()=>Nl,AwsV4Signer:()=>lo});async function as(t,e){let n=await crypto.subtle.importKey("raw",typeof t=="string"?Pl.encode(t):t,{name:"HMAC",hash:{name:"SHA-256"}},false,["sign"]);return crypto.subtle.sign("HMAC",n,Pl.encode(e))}async function fp(t){return crypto.subtle.digest("SHA-256",typeof t=="string"?Pl.encode(t):t)}function $l(t){let e=new Uint8Array(t),n="";for(let r=0;r<e.length;r++){let s=e[r];n+=dp[s>>>4&15],n+=dp[s&15];}return n}function pp(t){return t.replace(/[!'()*]/g,e=>"%"+e.charCodeAt(0).toString(16).toUpperCase())}function rS(t,e){let{hostname:n,pathname:r}=t;if(n.endsWith(".on.aws")){let a=n.match(/^[^.]{1,63}\.lambda-url\.([^.]{1,63})\.on\.aws$/);return a!=null?["lambda",a[1]||""]:["",""]}if(n.endsWith(".r2.cloudflarestorage.com"))return ["s3","auto"];if(n.endsWith(".backblazeb2.com")){let a=n.match(/^(?:[^.]{1,63}\.)?s3\.([^.]{1,63})\.backblazeb2\.com$/);return a!=null?["s3",a[1]||""]:["",""]}let s=n.replace("dualstack.","").match(/([^.]{1,63})\.(?:([^.]{0,63})\.)?amazonaws\.com(?:\.cn)?$/),i=s&&s[1]||"",o=s&&s[2];if(o==="us-gov")o="us-gov-west-1";else if(o==="s3"||o==="s3-accelerate")o="us-east-1",i="s3";else if(i==="iot")n.startsWith("iot.")?i="execute-api":n.startsWith("data.jobs.iot.")?i="iot-jobs-data":i=r==="/mqtt"?"iotdevicegateway":"iotdata";else if(i==="autoscaling"){let a=(e.get("X-Amz-Target")||"").split(".")[0];a==="AnyScaleFrontendService"?i="application-autoscaling":a==="AnyScaleScalingPlannerFrontendService"&&(i="autoscaling-plans");}else o==null&&i.startsWith("s3-")?(o=i.slice(3).replace(/^fips-|^external-1/,""),i="s3"):i.endsWith("-fips")?i=i.slice(0,-5):o&&/-\d$/.test(i)&&!/-\d$/.test(o)&&([i,o]=[o,i]);return [tS[i]||i,o||""]}var Pl,tS,nS,Nl,lo,dp,hp=$(()=>{Pl=new TextEncoder,tS={appstream2:"appstream",cloudhsmv2:"cloudhsm",email:"ses",marketplace:"aws-marketplace",mobile:"AWSMobileHubService",pinpoint:"mobiletargeting",queue:"sqs","git-codecommit":"codecommit","mturk-requester-sandbox":"mturk-requester","personalize-runtime":"personalize"},nS=new Set(["authorization","content-type","content-length","user-agent","presigned-expires","expect","x-amzn-trace-id","range","connection"]),Nl=class{constructor({accessKeyId:e,secretAccessKey:n,sessionToken:r,service:s,region:i,cache:o,retries:a,initRetryMs:l}){if(e==null)throw new TypeError("accessKeyId is a required option");if(n==null)throw new TypeError("secretAccessKey is a required option");this.accessKeyId=e,this.secretAccessKey=n,this.sessionToken=r,this.service=s,this.region=i,this.cache=o||new Map,this.retries=a??10,this.initRetryMs=l||50;}async sign(e,n){if(e instanceof Request){let{method:i,url:o,headers:a,body:l}=e;n=Object.assign({method:i,url:o,headers:a},n),n.body==null&&a.has("Content-Type")&&(n.body=l!=null&&a.has("X-Amz-Content-Sha256")?l:await e.clone().arrayBuffer()),e=o;}let r=new lo(Object.assign({url:e.toString()},n,this,n&&n.aws)),s=Object.assign({},n,await r.sign());delete s.aws;try{return new Request(s.url.toString(),s)}catch(i){if(i instanceof TypeError)return new Request(s.url.toString(),Object.assign({duplex:"half"},s));throw i}}async fetch(e,n){for(let r=0;r<=this.retries;r++){let s=fetch(await this.sign(e,n));if(r===this.retries)return s;let i=await s;if(i.status<500&&i.status!==429)return i;await new Promise(o=>setTimeout(o,Math.random()*this.initRetryMs*Math.pow(2,r)));}throw new Error("An unknown error occurred, ensure retries is not negative")}},lo=class{constructor({method:e,url:n,headers:r,body:s,accessKeyId:i,secretAccessKey:o,sessionToken:a,service:l,region:c,cache:f,datetime:u,signQuery:d,appendSessionToken:p,allHeaders:y,singleEncode:h}){if(n==null)throw new TypeError("url is a required option");if(i==null)throw new TypeError("accessKeyId is a required option");if(o==null)throw new TypeError("secretAccessKey is a required option");this.method=e||(s?"POST":"GET"),this.url=new URL(n),this.headers=new Headers(r||{}),this.body=s,this.accessKeyId=i,this.secretAccessKey=o,this.sessionToken=a;let b,m;(!l||!c)&&([b,m]=rS(this.url,this.headers)),this.service=l||b||"",this.region=c||m||"us-east-1",this.cache=f||new Map,this.datetime=u||new Date().toISOString().replace(/[:-]|\.\d{3}/g,""),this.signQuery=d,this.appendSessionToken=p||this.service==="iotdevicegateway",this.headers.delete("Host"),this.service==="s3"&&!this.signQuery&&!this.headers.has("X-Amz-Content-Sha256")&&this.headers.set("X-Amz-Content-Sha256","UNSIGNED-PAYLOAD");let w=this.signQuery?this.url.searchParams:this.headers;if(w.set("X-Amz-Date",this.datetime),this.sessionToken&&!this.appendSessionToken&&w.set("X-Amz-Security-Token",this.sessionToken),this.signableHeaders=["host",...this.headers.keys()].filter(S=>y||!nS.has(S)).sort(),this.signedHeaders=this.signableHeaders.join(";"),this.canonicalHeaders=this.signableHeaders.map(S=>S+":"+(S==="host"?this.url.host:(this.headers.get(S)||"").replace(/\s+/g," "))).join(`
|
|
17
|
+
`),this.credentialString=[this.datetime.slice(0,8),this.region,this.service,"aws4_request"].join("/"),this.signQuery&&(this.service==="s3"&&!w.has("X-Amz-Expires")&&w.set("X-Amz-Expires","86400"),w.set("X-Amz-Algorithm","AWS4-HMAC-SHA256"),w.set("X-Amz-Credential",this.accessKeyId+"/"+this.credentialString),w.set("X-Amz-SignedHeaders",this.signedHeaders)),this.service==="s3")try{this.encodedPath=decodeURIComponent(this.url.pathname.replace(/\+/g," "));}catch{this.encodedPath=this.url.pathname;}else this.encodedPath=this.url.pathname.replace(/\/+/g,"/");h||(this.encodedPath=encodeURIComponent(this.encodedPath).replace(/%2F/g,"/")),this.encodedPath=pp(this.encodedPath);let _=new Set;this.encodedSearch=[...this.url.searchParams].filter(([S])=>{if(!S)return false;if(this.service==="s3"){if(_.has(S))return false;_.add(S);}return true}).map(S=>S.map(E=>pp(encodeURIComponent(E)))).sort(([S,E],[C,x])=>S<C?-1:S>C?1:E<x?-1:E>x?1:0).map(S=>S.join("=")).join("&");}async sign(){return this.signQuery?(this.url.searchParams.set("X-Amz-Signature",await this.signature()),this.sessionToken&&this.appendSessionToken&&this.url.searchParams.set("X-Amz-Security-Token",this.sessionToken)):this.headers.set("Authorization",await this.authHeader()),{method:this.method,url:this.url,headers:this.headers,body:this.body}}async authHeader(){return ["AWS4-HMAC-SHA256 Credential="+this.accessKeyId+"/"+this.credentialString,"SignedHeaders="+this.signedHeaders,"Signature="+await this.signature()].join(", ")}async signature(){let e=this.datetime.slice(0,8),n=[this.secretAccessKey,e,this.region,this.service].join(),r=this.cache.get(n);if(!r){let s=await as("AWS4"+this.secretAccessKey,e),i=await as(s,this.region),o=await as(i,this.service);r=await as(o,"aws4_request"),this.cache.set(n,r);}return $l(await as(r,await this.stringToSign()))}async stringToSign(){return ["AWS4-HMAC-SHA256",this.datetime,this.credentialString,$l(await fp(await this.canonicalString()))].join(`
|
|
14
18
|
`)}async canonicalString(){return [this.method.toUpperCase(),this.encodedPath,this.encodedSearch,this.canonicalHeaders+`
|
|
15
19
|
`,this.signedHeaders,await this.hexBodyHash()].join(`
|
|
16
|
-
`)}async hexBodyHash(){let e=this.headers.get("X-Amz-Content-Sha256")||(this.service==="s3"&&this.signQuery?"UNSIGNED-PAYLOAD":null);if(e==null){if(this.body&&typeof this.body!="string"&&!("byteLength"in this.body))throw new Error("body must be a string, ArrayBuffer or ArrayBufferView, unless you include the X-Amz-Content-Sha256 header");e
|
|
17
|
-
|
|
18
|
-
`," ",r),this.select=a,this.from=o,this.group=l,this.sort=u,this.insertColumns=p,this.update=c,this.bool=f,this.isColumnConstraint=m,this.isDomainConstraint=d,this.alterColumnOptions=g,this.alterTableOptions=b,this.isEnumValue=y,this.objtype=T,this.subtype=C,Object.assign(this,w);}spawn(e,r={}){return new s({indentLevel:this.indentLevel,prettyMode:this.prettyMode,isStringLiteral:this.isStringLiteral,parentNodeTypes:[...this.parentNodeTypes,e],formatter:this.formatter,select:this.select,from:this.from,group:this.group,sort:this.sort,insertColumns:this.insertColumns,update:this.update,bool:this.bool,isColumnConstraint:this.isColumnConstraint,isDomainConstraint:this.isDomainConstraint,alterColumnOptions:this.alterColumnOptions,alterTableOptions:this.alterTableOptions,isEnumValue:this.isEnumValue,objtype:this.objtype,subtype:this.subtype,...r})}indent(e,r){if(!this.prettyMode)return e;let t=r!==void 0?r:this.indentLevel+1;return this.formatter.indent(e,t)}newline(){return this.formatter.newline()}parens(e){return this.formatter.parens(e)}format(e,r){return this.formatter.format(e,r)}isPretty(){return this.formatter.isPretty()}};as.DeparserContext=bu;var Tu=class{getNodeType(e){return Object.keys(e)[0]}getNodeData(e){let r=this.getNodeType(e);return e[r]}formatList(e,r=", ",t="",n){return !e||e.length===0?"":e.map(i=>`${t}${n(i)}`).join(r)}formatParts(e,r=" "){return e.filter(t=>t!=null&&t!=="").join(r)}formatParens(e){return `(${e})`}formatIndent(e,r=1){return e}};as.BaseVisitor=Tu;});var Ma=(s=[],e="")=>"/"+[e,...s.map(r=>String(r).replace(/\./g,"/"))].filter(Boolean).join("/"),Ou=s=>s.split("/").slice(1);function Uh(s,e,r=void 0){let t=typeof e=="string"?Ou(e):Ma(e);return Hn(s,t,r)}function Hn(s,e,r=void 0){let t=typeof e=="string"?e.split(/[.\[\]\"]+/).filter(n=>n):e;if(t.length===0)return s;try{let[n,...i]=t;return !n||!(n in s)?r:Hn(s[n],i,r)}catch{if(typeof r<"u")return r;throw new Error(`Invalid path: ${t.join(".")}`)}}var X=(s={},e,r,t)=>({valid:false,errors:[...s.errors??[],{keywordLocation:Ma([...s.keywordPath??[],e]),instanceLocation:Ma(s.instancePath),error:typeof r=="string"?r:`Invalid value for ${e}`,data:t}]}),N=()=>({valid:true,errors:[]}),Ir=(s,e,r)=>{let t=Array.isArray(e)?e:[e],n=r?Array.isArray(r)?r:[r]:[];return {...s,keywordPath:[...s.keywordPath??[],...t],instancePath:n?[...s.instancePath??[],...n]:s.instancePath}},Wn=(s={})=>({...s,errors:[]}),rr=class extends Error{constructor(s){super(`Expected ${s}`);}},Bh=class extends Error{constructor(s,e){super(`${s??"Invalid raw schema"}: ${JSON.stringify(e)}`),this.schema=e;}},Mh=class extends Error{constructor(s,e){super(`${s}, got: 'type "${typeof e}": ${JSON.stringify(e)}'`),this.value=e;}},Ce=Symbol.for("jsonv-ts:schema");function Fh(s){return s===null}function pe(s){return !Array.isArray(s)&&typeof s=="object"&&s!==null}function qh(s){return Object.prototype.toString.call(s)==="[object Object]"}function it(s){return typeof s=="string"}function Et(s){return typeof s=="number"}function Jh(s){return typeof s=="number"&&Number.isInteger(s)}function Ja(s){return typeof s=="boolean"}function qt(s){return Array.isArray(s)}function Wh(s){return typeof s!="boolean"}function Hh(s){return s!==void 0&&Wh(s)&&"type"in s}function Ae(s){return s!==void 0&&pe(s)&&Ce in s}function Gh(s){return Ae(s)&&typeof s.toJSON()=="boolean"}function Vh(s,e,r){if(!s)throw new Mh(e,r)}function Nu(s){return it(s)?s.normalize("NFC"):s}function fs(s,e){let r=typeof s;if(r!==typeof e)return false;if(Array.isArray(s)){if(!Array.isArray(e))return false;let t=s.length;if(t!==e.length)return false;for(let n=0;n<t;n++)if(!fs(s[n],e[n]))return false;return true}if(r==="object"){if(!s||!e)return s===e;let t=Object.keys(s),n=Object.keys(e);if(t.length!==n.length)return false;for(let i of t)if(!fs(s[i],e[i]))return false;return true}return s===e}function Kh(s,e){return e.reduce((r,t)=>(t in s&&(r[t]=s[t]),r),{})}function Iu(s){try{return structuredClone(s)}catch{return s}}var Wa=class{constructor(s){this.root=s,this.cache=new Map;}cache;hasRef(s,e){return e!==void 0&&"$ref"in s&&it(s.$ref)}resolve(s){let e=this.cache.get(s);if(!e){if(e=Uh(this.root,s),!Ae(e))throw new Error(`ref not found: ${s}`);if("$ref"in e&&e.$ref===s)throw new Error(`ref loop: ${s}`);this.cache.set(s,e);}return e}};function Yh(s,e,r={}){let t=e;try{t=structuredClone(e);}catch{t=JSON.parse(JSON.stringify(e));}let n={resolver:r.resolver||new Wa(s),depth:r.depth||0,dropUnknown:r.dropUnknown??false};return n.resolver.hasRef(s,t)?n.resolver.resolve(s.$ref).coerce(t,{...n,depth:n.depth+1}):t}var zh=({type:s},e,r={})=>{if(s===void 0||e===void 0)return N();let t,n={string:it,number:Et,integer:Jh,object:pe,array:qt,boolean:Ja,null:Fh};if(Array.isArray(s)){for(let i of s){if(!(i in n))throw new rr(`Unknown type: ${i}`);if(n[i](e))return N()}t=`Expected one of: ${s.join(", ")}`;}else {if(!(s in n))throw new rr(`Unknown type: ${s}`);n[s](e)||(t=`Expected ${s}`);}return t?X(r,"type",t,e):N()},Xh=({const:s},e,r={})=>fs(s,e)?N():X(r,"const",`Expected const: ${s}`,e),Qh=({enum:s=[]},e,r={})=>s.some(t=>fs(t,e))?N():X(r,"enum",`Expected enum: ${JSON.stringify(s)}`,e);function Gn(s,e,r={}){return s.map(t=>t.validate(e,Wn(r)).valid?t:void 0).filter(Boolean)}var Zh=({anyOf:s=[]},e,r={})=>Gn(s,e,r).length>0?N():X(r,"anyOf","Expected at least one to match",e),ed=({oneOf:s=[]},e,r={})=>Gn(s,e).length===1?N():X(r,"oneOf","Expected exactly one to match",e),td=({allOf:s=[]},e,r={})=>Gn(s,e,r).length===s.length?N():X(r,"allOf","Expected all to match",e),rd=({not:s},e,r={})=>e===void 0?N():Ae(s)&&s.validate(e,r).valid?X(r,"not","Expected not to match",e):N(),sd=({if:s,then:e,else:r},t,n={})=>{if(s&&(e||r)){if(s.validate(t,Wn(n)).valid)return e?e.validate(t,Wn(n)):N();if(r)return r.validate(t,Wn(n))}return N()},nd=({pattern:s=""},e,r={})=>{if(!it(e))return N();if(s instanceof RegExp){if(s.test(e))return N()}else if(new RegExp(s,"u").test(e))return N();return X(r,"pattern",`Expected string matching pattern ${s}`,e)},id=({minLength:s=0},e,r={})=>it(e)?[...Nu(e)].length>=s?N():X(r,"minLength",`Expected string with minimum length of ${s}`,e):N(),ad=({maxLength:s=0},e,r={})=>it(e)?[...Nu(e)].length<=s?N():X(r,"maxLength",`Expected string with maximum length of ${s}`,e):N(),od=({multipleOf:s=0},e,r={})=>{if(!Et(e))return N();if(!(Number.isFinite(e)&&Number.isFinite(s))||s<=0)throw new rr("number");let t=e/s,n=Number.EPSILON*Math.max(1,Math.abs(t));return Math.abs(t-Math.round(t))<=n?N():X(r,"multipleOf",`Expected number being a multiple of ${s}`,e)},ld=({maximum:s=0},e,r={})=>!Et(e)||e<=s?N():X(r,"maximum",`Expected number less than or equal to ${s}`,e),ud=({exclusiveMaximum:s=0},e,r={})=>!Et(e)||e<s?N():X(r,"exclusiveMaximum",`Expected number less than ${s}`,e),cd=({minimum:s=0},e,r={})=>!Et(e)||e>=s?N():X(r,"minimum",`Expected number greater than or equal to ${s}`,e),pd=({exclusiveMinimum:s=0},e,r={})=>!Et(e)||e>s?N():X(r,"exclusiveMinimum",`Expected number greater than ${s}`,e),fd=({properties:s={}},e,r={})=>{if(!pe(e))return N();for(let[t,n]of Object.entries(e)){let i=s[t];if(!Ae(i))continue;let a=i.validate(n,Ir(r,["properties",t],t));if(!a.valid)return a}return N()},md=({properties:s={},additionalProperties:e,patternProperties:r},t,n={})=>{if(!pe(t))return N();if(!Ae(e))throw new rr("additionalProperties must be a boolean or a managed schema");let i=Object.keys(s),a=pe(r)?Object.keys(t).filter(l=>Object.keys(r).some(u=>new RegExp(u).test(l))):[],o=Object.keys(t).filter(l=>!i.includes(l)&&!a.includes(l));if(o.length>0){if(Gh(e)){if(e.toJSON()===true)return N();let l=o.reduce((u,p)=>(u[p]=t[p],u),{});return X(n,"additionalProperties","Additional properties are not allowed",l)}else if(Ae(e))for(let l of o){let u=e.validate(t[l],Ir(n,["additionalProperties"],l));if(!u.valid)return u}}return N()},hd=({dependentRequired:s},e,r={})=>{if(!pe(e))return N();let t=Object.keys(e).filter(n=>typeof e[n]!="function");if(pe(s)){for(let[n,i]of Object.entries(s))if(t.includes(n)){for(let a of i)if(!t.includes(a))return X(r,"dependentRequired",`Expected dependent required property ${a}`,e)}}return N()},dd=({required:s=[]},e,r={})=>{if(!pe(e))return N();let t=Object.keys(e).filter(n=>typeof e[n]!="function");return s.every(n=>t.includes(n))?N():X(r,"required",`Expected object with required properties ${s.join(", ")}`,e)},gd=({dependentSchemas:s},e,r={})=>{if(!pe(e))return N();let t=Object.keys(e).filter(n=>typeof e[n]!="function");if(pe(s)){for(let[n,i]of Object.entries(s))if(t.includes(n)){let a=i.validate(e,r);if(!a.valid)return a}}return N()},yd=({minProperties:s=0},e,r={})=>pe(e)?Object.keys(e).length>=s?N():X(r,"minProperties",`Expected object with at least ${s} properties`,e):N(),Ed=({maxProperties:s=0},e,r={})=>!pe(e)||Object.keys(e).length<=s?N():X(r,"maxProperties",`Expected object with at most ${s} properties`,e),Sd=({patternProperties:s={}},e,r={})=>{if(!pe(e))return N();if(!pe(s))throw new rr("patternProperties must be an object");for(let[t,n]of Object.entries(e))for(let[i,a]of Object.entries(s))if(new RegExp(i,"u").test(t)){let o=a.validate(n,Ir(r,["patternProperties"],t));if(!o.valid)return o}return N()},bd=({propertyNames:s},e,r={})=>{if(!pe(e)||s===void 0)return N();if(!Ae(s))throw new rr("propertyNames must be a managed schema");for(let t of Object.keys(e)){let n=s.validate(t,Ir(r,["propertyNames"],t));if(!n.valid)return n}return N()},Td=({items:s,prefixItems:e=[]},r,t={})=>{if(!qt(r)||s===void 0)return N();if(!Ae(s))throw new rr("items must be a managed schema");for(let[n,i]of r.slice(e.length).entries()){let a=s.validate(i,Ir(t,["items"],String(n)));if(!a.valid)return a}return N()},wd=({minItems:s=0},e,r={})=>!qt(e)||e.length>=s?N():X(r,"minItems",`Expected array with at least ${s} items`,e),Cd=({maxItems:s=0},e,r={})=>!qt(e)||e.length<=s?N():X(r,"maxItems",`Expected array with at most ${s} items`,e),Ad=({uniqueItems:s=false},e,r={})=>{if(!qt(e)||!s)return N();for(let t=0;t<e.length;t++){let n=e[t];for(let i=0;i<e.length;i++){if(t===i)continue;let a=e[i];if(fs(n,a))return X(r,"uniqueItems",`Duplicated items at index ${t} and ${i}`,e)}}return N()},Rd=({contains:s,minContains:e,maxContains:r},t,n={})=>{if(!Ae(s))throw new Error("contains must be a managed schema");if(!qt(t))return N();let i=t.filter(a=>s.validate(a).valid).length;return i<(e??1)?X(n,e?"minContains":"contains",`Expected array to contain at least ${e??1}, but found ${i}`,t):r!==void 0&&i>r?X(n,"maxContains",`Expected array to contain at most ${r}, but found ${i}`,t):N()},_d=({prefixItems:s=[]},e,r={})=>{if(!qt(e))return N();for(let t=0;t<e.length;t++){let n=s[t]?.validate(e[t],Ir(r,String(t),String(t)));if(n&&n?.valid!==true)return n}return N()},Ru={email:s=>{if(s.length>318)return false;if(/^[a-z0-9!#$%&'*+/=?^_`{|}~-]{1,20}(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]{1,21}){0,2}@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,60}[a-z0-9])?){0,3}$/i.test(s))return true;if(!s.includes("@")||/(^\.|^"|\.@|\.\.)/.test(s))return false;let[e,r,...t]=s.split("@");return !e||!r||t.length!==0||e.length>64||r.length>253||!/^[a-z0-9.-]+$/i.test(r)||!/^[a-z0-9.!#$%&'*+/=?^_`{|}~-]+$/i.test(e)?false:r.split(".").every(n=>/^[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?$/i.test(n))},hostname:s=>s.length>(s.endsWith(".")?254:253)?false:/^[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*\.?$/i.test(s),date:s=>{if(s.length!==10)return false;if(s[5]==="0"&&s[6]==="2"){if(/^\d\d\d\d-02-(?:[012][1-8]|[12]0|[01]9)$/.test(s))return true;let e=s.match(/^(\d\d\d\d)-02-29$/);if(!e)return false;let r=Number(e[1]);return r%16===0||r%4===0&&r%25!==0}return s.endsWith("31")?/^\d\d\d\d-(?:0[13578]|1[02])-31$/.test(s):/^\d\d\d\d-(?:0[13-9]|1[012])-(?:[012][1-9]|[123]0)$/.test(s)},time:s=>{if(s.length>27||!/^(?:2[0-3]|[0-1]\d):[0-5]\d:(?:[0-5]\d|60)(?:\.\d+)?(?:z|[+-](?:2[0-3]|[0-1]\d)(?::?[0-5]\d)?)?$/i.test(s))return false;if(!/:60/.test(s))return true;let e=s.match(/([0-9.]+|[^0-9.])/g);if(!e)return false;let r=Number(e[0])*60+Number(e[2]);return e[5]==="+"?r+=1440-Number(e[6]||0)*60-Number(e[8]||0):e[5]==="-"&&(r+=Number(e[6]||0)*60+Number(e[8]||0)),r%1440===1439},"date-time":s=>{if(s.length>38)return false;let e=/^\d\d\d\d-(?:0[1-9]|1[0-2])-(?:[0-2]\d|3[01])[t\s](?:2[0-3]|[0-1]\d):[0-5]\d:(?:[0-5]\d|60)(?:\.\d+)?(?:z|[+-](?:2[0-3]|[0-1]\d)(?::?[0-5]\d)?)$/i,r=s[5]==="0"&&s[6]==="2";if(r&&s[8]==="3"||!e.test(s))return false;if(s[17]==="6"){let t=s.slice(11).match(/([0-9.]+|[^0-9.])/g);if(!t)return false;let n=Number(t[0])*60+Number(t[2]);if(t[5]==="+"?n+=1440-Number(t[6]||0)*60-Number(t[8]||0):t[5]==="-"&&(n+=Number(t[6]||0)*60+Number(t[8]||0)),n%1440!==1439)return false}if(r){if(/^\d\d\d\d-02-(?:[012][1-8]|[12]0|[01]9)/.test(s))return true;let t=s.match(/^(\d\d\d\d)-02-29/);if(!t)return false;let n=Number(t[1]??0);return n%16===0||n%4===0&&n%25!==0}return s[8]==="3"&&s[9]==="1"?/^\d\d\d\d-(?:0[13578]|1[02])-31/.test(s):/^\d\d\d\d-(?:0[13-9]|1[012])-(?:[012][1-9]|[123]0)/.test(s)},ipv4:s=>s.length<=15&&/^(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)$/.test(s),ipv6:s=>{if(s.length>45||s.length<2)return false;let e=0,r=0,t=0,n=false,i=false,a=0,o=true;for(let u=0;u<s.length;u++){let p=s.charCodeAt(u);if(u===1&&a===58&&p!==58)return false;if(p>=48&&p<=57){if(++t>4)return false}else if(p===46){if(e>6||r>=3||t===0||i)return false;r++,t=0;}else if(p===58){if(r>0||e>=7)return false;if(a===58){if(n)return false;n=true;}else u===0&&(o=false);e++,t=0,i=false;}else if(p>=97&&p<=102||p>=65&&p<=70){if(r>0||++t>4)return false;i=true;}else return false;a=p;}if(e<2||r>0&&(r!==3||t===0))return false;if(n&&s.length===2)return true;if(r>0&&!/(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}$/.test(s))return false;let l=r>0?6:7;return n?(o||t>0)&&e<l:e===l&&o&&t>0},uri:s=>/^[a-z][a-z0-9+\-.]*:(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|v[0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/?(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?)(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i.test(s),"uri-reference":s=>/^(?:[a-z][a-z0-9+\-.]*:)?(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|v[0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/?(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?)?(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i.test(s),"uri-template":s=>/^(?:[^\x00-\x20"'<>%\\^`{|}]|%[0-9a-f]{2}|\{[+#./;?&=,!@|]?(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?(?:,(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?)*\})*$/i.test(s),"json-pointer":s=>/^(?:|\/(?:[^~]|~0|~1)*)$/.test(s),"relative-json-pointer":s=>/^(?:0|[1-9][0-9]*)(?:|#|\/(?:[^~]|~0|~1)*)$/.test(s),uuid:s=>/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(s),duration:s=>s.length>1&&s.length<80&&(/^P\d+([.,]\d+)?W$/.test(s)||/^P[\dYMDTHS]*(\d[.,]\d+)?[YMDHS]$/.test(s)&&/^P([.,\d]+Y)?([.,\d]+M)?([.,\d]+D)?(T([.,\d]+H)?([.,\d]+M)?([.,\d]+S)?)?$/.test(s)),regex:s=>{if(/[^\\]\\Z/.test(s))return false;try{return new RegExp(s,"u"),!0}catch{return false}},binary:()=>true,password:()=>true},vd=({format:s},e,r={})=>!it(e)||!s?N():Ru[s]?Ru[s](e)?N():X(r,"format",`Expected format: ${s}`,e):N();var Ua={type:zh,const:Xh,enum:Qh,allOf:td,anyOf:Zh,oneOf:ed,not:rd,minLength:id,maxLength:ad,pattern:nd,format:vd,minimum:cd,exclusiveMinimum:pd,maximum:ld,exclusiveMaximum:ud,multipleOf:od,required:dd,dependentRequired:hd,dependentSchemas:gd,minProperties:yd,maxProperties:Ed,propertyNames:bd,properties:fd,patternProperties:Sd,additionalProperties:md,minItems:wd,maxItems:Cd,uniqueItems:Ad,contains:Rd,prefixItems:_d,items:Td,if:sd};function Od(s,e,r={}){let t={keywordPath:r.keywordPath||[],instancePath:r.instancePath||[],coerce:r.coerce||false,errors:r.errors||[],shortCircuit:r.shortCircuit||false,ignoreUnsupported:r.ignoreUnsupported||false,resolver:r.resolver||s.getResolver?.()||new Wa(s),depth:r.depth?r.depth+1:0,skipClone:r.skipClone||false},n;if(r?.coerce&&s.coerce){let i=s.coerce(e,{resolver:t.resolver,depth:t.depth});n=t.skipClone?i:structuredClone(i);}else n=t.skipClone?e:structuredClone(e);if(r.ignoreUnsupported!==true){let i=["$defs"];for(let a of i)if(s[a])throw new Error(`${a} not implemented`)}if(t.resolver.hasRef(s,n)){let i=t.resolver.resolve(s.$ref).validate(n,{...t,errors:[]});i.valid||t.errors.push(...i.errors);}else {let i={keywordPath:t.keywordPath,instancePath:t.instancePath,coerce:t.coerce,errors:[],shortCircuit:t.shortCircuit,ignoreUnsupported:t.ignoreUnsupported,resolver:t.resolver,depth:t.depth};for(let a in s)if(a==="type"&&s.type!==void 0){if(n!==void 0){let o=Ua[a];if(o){i.errors=[];let l=o(s,n,i);if(!l.valid){if(r.shortCircuit)return l;t.errors.push(...l.errors);}}}}else if(a in Ua&&s[a]!==void 0){if(n===void 0)continue;let o=Ua[a];if(o){i.errors=[];let l=o(s,n,i);if(!l.valid){if(r.shortCircuit)return l;t.errors.push(...l.errors);}}}}return {valid:t.errors.length===0,errors:t.errors}}var St=class{"~standard";[Ce];_resolver;type;$id;$ref;$schema;title;description;readOnly;writeOnly;$comment;examples;constructor(s,e){let{type:r,validate:t,coerce:n,template:i,...a}=s||{};Object.assign(this,{type:r},a),this[Ce]={raw:s,optional:false,overrides:e},this["~standard"]={version:1,vendor:"jsonv-ts",validate:o=>{let l=this.validate(o);return l.valid?{value:o}:{issues:l.errors.map(u=>({message:u.error,path:Ou(u.instanceLocation)}))}}};}template(s,e){let r=this,t=s;if(r.const!==void 0?t=r.const:t===void 0&&(r.default!==void 0&&(t=r.default),e?.withExtendedOptional&&r.enum!==void 0&&(t=r.enum[0])),e?.withOptional!==true&&t===void 0&&this.isOptional())return t;if(this[Ce].raw?.template){let i=this[Ce].raw.template(t,e);i!==void 0&&(t=i);}let n=this[Ce].overrides?.template?.(t,e);return n!==void 0&&(t=n),t}validate(s,e){let r={keywordPath:e?.keywordPath||[],instancePath:e?.instancePath||[],coerce:e?.coerce||false,errors:e?.errors||[],shortCircuit:e?.shortCircuit||false,ignoreUnsupported:e?.ignoreUnsupported||false,resolver:e?.resolver||this.getResolver(),depth:e?.depth?e.depth+1:0,skipClone:e?.skipClone??true},t=this[Ce].raw?.validate;if(t!==void 0){let n=t(s,r);if(!n.valid)return n}return Od(this,s,r)}coerce(s,e){let r={...e,resolver:e?.resolver||this.getResolver(),depth:e?.depth?e.depth+1:0,dropUnknown:e?.dropUnknown??false},t=this[Ce].raw?.coerce;if(t!==void 0)return t(s,r);let n=this[Ce].overrides?.coerce?.(s,r)??s;return Yh(this,n,r)}optional(){return this[Ce].optional=true,this}isOptional(){return this[Ce].optional}getResolver(){return this._resolver||(this._resolver=new Wa(this)),this._resolver}children(s){return []}*walk({instancePath:s=[],keywordPath:e=[],data:r,maxDepth:t=Number.POSITIVE_INFINITY,...n}={}){let i=s.length===0&&r?Iu(r):r;if(n.includeSelf!==false&&(yield new ms(this,{instancePath:s,keywordPath:e,data:i,...n})),!(s.length>=t))for(let a of this.children(n)){let o=[...s,...a.instancePath];yield*a.schema.walk({...n,data:i,maxDepth:t,instancePath:o,keywordPath:[...e,...a.keywordPath]});}}*[Symbol.iterator](s){for(let e of this.walk(s))yield e;}toJSON(){let{toJSON:s,"~standard":e,_resolver:r,...t}=this;return JSON.parse(JSON.stringify(t))}},ms=class{constructor(s,e={}){this.schema=s,this.instancePath=e.instancePath||[],this.keywordPath=e.keywordPath||[],this.depth=this.instancePath.length;try{if(e.data!==void 0){let r=Hn(e.data,this.instancePath);s.validate(r).valid&&(this.data=r);}}catch{}}instancePath;keywordPath;data;depth;appendInstancePath(s){return this.instancePath=[...this.instancePath,...s],this}appendKeywordPath(s){return this.keywordPath=[...this.keywordPath,...s],this}setData(s){return this.data=s,this}};function Vn(s,e,r){return new class extends St{type=s}(e,r)}var Nd=class extends St{constructor(s){super(),this.bool=s;}toJSON(){return this.bool}validate(s,e){return this.bool?N():X(e,"","Always fails",s)}};function Fa(s){return new Nd(s)}var Lu=s=>Vn(s?.type,s),Id=(s,e)=>Vn(void 0,{...e,const:s}),Ld=class extends St{type="object";properties;required;constructor(s,e){let r=[];for(let[n,i]of Object.entries(s||{}))Vh(Ae(i),"properties must be managed schemas",i),i[Ce].optional||r.push(n);let t=e?.additionalProperties===false?Fa(false):e?.additionalProperties;r=r.length>0?r:void 0,super({...e,additionalProperties:t,properties:s,required:r},{template:(n,i)=>{let a=structuredClone(pe(n)?n:{}),o={...a};if(this.properties)for(let[l,u]of Object.entries(this.properties)){let p=Hn(a,l);if(u.isOptional()&&i?.withOptional!==true&&p===void 0&&n===void 0)continue;let c=u.template(p,i);c!==void 0&&(o[l]=c);}if(!(Object.keys(o).length===0&&!i?.withExtendedOptional))return o},coerce:(n,i)=>{let a=Object.keys(this.properties),o=Iu(n),l=a.length>0&&Object.values(this.properties).every(p=>!p[Ce].optional);if(qh(o)&&(i?.dropUnknown===true||l)&&(o=Kh(o,a)),typeof o=="string"&&o.match(/^\{/)&&(o=JSON.parse(o)),typeof o!="object"||o===null)return;if(this.properties)for(let[p,c]of Object.entries(this.properties)){let f=o[p];f!==void 0&&(o[p]=c.coerce(f,i));}let u=this.additionalProperties;if(i?.dropUnknown!==true&&(!u||u.validate(null).valid)){let p=pe(n)?n:{},c=Object.keys(p).filter(f=>!a.includes(f));for(let f of c)o[f]=u?u.coerce(p[f],i):p[f];}return o}}),this.properties=s,this.required=r;}strict(){return this.additionalProperties=Fa(false),this[Ce].raw.additionalProperties=false,this}partial(){for(let[,s]of Object.entries(this.properties))s[Ce].optional=true;return this.required=void 0,this}children(s){let e=[];for(let[r,t]of Object.entries(this.properties)){let n=new ms(t,s);n.appendInstancePath([r]),n.appendKeywordPath(["properties",r]),e.push(n);}return e}},Kn=(s,e)=>new Ld(s,e),Lr=(s,e)=>Kn(s,e).strict(),kd=(s,e)=>Kn(s,e).partial(),$d=class extends St{type="object";additionalProperties;constructor(s,e){super({...e,additionalProperties:s},{template:(r,t)=>t?.withExtendedOptional&&(r===void 0||!pe(r))?{}:r}),this.additionalProperties=s;}children(s){let e=[],r=new ms(this.additionalProperties,s);return r.appendKeywordPath(["additionalProperties"]),e.push(r),e}},Pd=(s,e)=>new $d(s,e),Ha=class extends St{type="string";constructor(s){super(s,{template:(e,r)=>r?.withExtendedOptional&&(e===void 0||!it(e))?"":e,coerce:e=>Et(e)?String(e):e});}toJSON(){let{pattern:s,"~standard":e,_resolver:r,...t}=this;return JSON.parse(JSON.stringify({...t,pattern:s instanceof RegExp?s.source:s}))}},sr=s=>new Ha(s),ku=(s,e,r)=>Vn(s,r,{template:(t,n)=>n?.withExtendedOptional&&(t===void 0||!Et(t))?r?.minimum??0:t,coerce:t=>{if(it(t)){let n=e.parseFn(t);if(!Number.isNaN(n))return n}return t}}),$u=s=>ku("number",{parseFn:Number},s),Pu=s=>ku("integer",{parseFn:Number.parseInt},s),Dd=class extends St{constructor(s,e={}){super({...e,items:s},{template:r=>r===void 0||!Array.isArray(r)?[]:r,coerce:(r,t)=>{try{let n=typeof r=="string"?JSON.parse(r):r;if(!Array.isArray(n))return;if(Ae(this.items))for(let[i,a]of n.entries())n[i]=this.items.coerce(a,t);return n}catch{}return r}}),this.items=s,this.items=s;}type="array";children(s){let e=[];if(this.items){let r=new ms(this.items,s);r.appendKeywordPath(["items"]),e.push(r);}return e}},Du=(s,e)=>new Dd(s,e),hs=s=>Vn("boolean",s,{template:(e,r)=>r?.withExtendedOptional&&(e===void 0||!Ja(e))?false:e,coerce:e=>{if(it(e)&&["true","false","1","0"].includes(e))return e==="true"||e==="1";if(Et(e)){if(e===1)return true;if(e===0)return false}return e}}),Jn=Symbol.for("unionType"),ju=class extends St{[Jn];constructor(s,e,r){super({...r,[e]:s},{coerce:(t,n)=>{let i=r?.coerce;if(i!==void 0)return i.bind(this)(t,n);let a=Gn(s,t,{ignoreUnsupported:true,resolver:n?.resolver,coerce:true});return a.length>0?a[0].coerce(t,n):t}}),this[Jn]=e;}get schemas(){return this[this[Jn]]}children(s){let e=[];for(let[r,t]of this.schemas.entries()){let n=new ms(t,s);n.appendKeywordPath([this[Jn],r]),e.push(n);}return e}},jd=(s,e)=>new ju(s,"anyOf",e),xd=(s,e)=>new ju(s,"oneOf",e);function _u(s,e){return Array.isArray(s)?s.map(e):s!==void 0?[e(s)]:[]}function vu(s,e,r=t=>t){return Object.fromEntries(Object.entries(s).map(([t,n])=>[t,r(e(n,t),t)]))}function Ft(s){if(Ja(s))return Fa(s);let e=structuredClone(s);if(!pe(e))throw new Bh("non-object schemas cannot be converted to a schema",e);"properties"in e&&e.properties&&(e.properties=vu(e.properties,(i,a)=>{try{return Ft(i)}catch(o){throw new Error(`Couldn't schemaize property "${a}": ${String(o)}`)}},(i,a)=>"required"in e&&Array.isArray(e.required)&&e.required.includes(a)?i:i.optional()));let r=["patternProperties","dependentSchemas","$defs"];for(let i of r)i in e&&e[i]&&(e[i]=vu(e[i],Ft));let t=["additionalProperties","items","prefixItems","propertyNames","contains","not","if","then","else"];for(let i of t)i in e&&typeof e[i]<"u"&&(qt(e[i])?e[i]=_u(e[i],Ft):e[i]=Ft(e[i]));let n=["anyOf","oneOf","allOf"];for(let i of n)if(i in e){let{[i]:a}=e;e[i]=_u(a,Ft);}if(Hh(e))switch(e.type){case "string":return sr(e);case "number":return $u(e);case "integer":return Pu(e);case "boolean":return hs(e);case "object":{let{properties:i,...a}=e;return Kn(i,a)}case "array":{let{items:i,...a}=e;return Du(i,a)}}return Lu(e)}var qa=s=>typeof s=="object"&&s!==null&&!Array.isArray(s),Ba=s=>typeof globalThis.structuredClone=="function"?globalThis.structuredClone(s):JSON.parse(JSON.stringify(s)),Ud=["maximum","exclusiveMaximum","maxLength","maxItems","maxProperties"],Bd=["minimum","exclusiveMinimum","minLength","minItems","minProperties"];function Md(){return {type(s){let e=s.map(r=>Array.isArray(r)?new Set(r):new Set([r])).reduce((r,t)=>r?new Set([...r].filter(n=>t.has(n))):new Set(t));if(!e.size)throw new Error('Incompatible "type" in allOf');return e.size===1?[...e][0]:[...e]},enum(s){let e=s.map(r=>new Set(r)).reduce((r,t)=>new Set([...r].filter(n=>t.has(n))));if(!e.size)throw new Error('Incompatible "enum" in allOf');return [...e]},required(s){return [...new Set(s.flat())]},properties(s,e,r){return s.reduce((t,n)=>r(t,n),{})},patternProperties(s,e,r){return s.reduce((t,n)=>r(t,n),{})},$defs(s,e,r){return s.reduce((t,n)=>r(t,n),{})},definitions(s,e,r){return s.reduce((t,n)=>r(t,n),{})},...Object.fromEntries(Ud.map(s=>[s,e=>Math.min(...e)])),...Object.fromEntries(Bd.map(s=>[s,e=>Math.max(...e)]))}}function Fd(s){let e={...Md(),...s.resolvers};function r(t,n){if(Array.isArray(t)&&Array.isArray(n))return [...new Set([...t,...n])];if(qa(t)&&qa(n)){let i={...t};for(let[a,o]of Object.entries(n))if(a in i){let l=e[a];i[a]=l?l([i[a],o],a,r):Ba(o);}else i[a]=Ba(o);return i}return Ba(n)}return r}var qd=s=>s===true||s===false?s:null;function Jd(s,e={}){let r=e.deep!==false,t=Fd(e);function n(i){if(Array.isArray(i))return i.map(n);if(!qa(i))return i;if(Array.isArray(i.allOf)){let o=i.allOf.map(n);if(o.some(m=>m===false))return false;let l=o.filter(m=>m!==true);if(!l.length)return true;let u=l.reduce((m,d)=>t(m,d),{}),p=qd(u);if(p!==null)return p;let c={...i};delete c.allOf;let f=t(u,r?n(c):c);return r?n(f):f}let a={};for(let[o,l]of Object.entries(i))a[o]=n(l);return a}return n(s)}var Wd=(s,e)=>{let r=JSON.parse(JSON.stringify({...e,allOf:s}));return Ft(Jd(r))},xu=class extends St{$ref;constructor(s,e){if(!e&&!Ae(s))throw new Error("Ref not set");if(Ae(s)&&!s.$id)throw new Error("Ref must have an $id");let r=e??s?.$id;super({$ref:r},{coerce:(t,n)=>{let i=n?.resolver?.resolve(this.$ref);if(!Ae(i))throw new Error(`Ref not found: ${this.$ref}`);return i.coerce(t,n)}}),this.$ref=r;}},Hd=(s,e)=>new xu(s,e),Gd=s=>new xu(void 0,s),Vd=s=>s(new St({$ref:"#",coerce:(e,r)=>{let t=r?.resolver?.resolve("#");if(!Ae(t))throw new Error("Ref not found: #");return t.coerce(e,r)}}));var E={boolean:hs,any:Lu,literal:Id,object:Kn,strictObject:Lr,partialObject:kd,record:Pd,string:sr,number:$u,integer:Pu,array:Du,anyOf:jd,oneOf:xd,allOf:Wd,ref:Hd,refId:Gd,recursive:Vd};function Uu(s,e){var r=Object.keys(s);if(Object.getOwnPropertySymbols){var t=Object.getOwnPropertySymbols(s);e&&(t=t.filter(function(n){return Object.getOwnPropertyDescriptor(s,n).enumerable})),r.push.apply(r,t);}return r}function Bu(s){for(var e=1;e<arguments.length;e++){var r=arguments[e]!=null?arguments[e]:{};e%2?Uu(Object(r),true).forEach(function(t){Kd(s,t,r[t]);}):Object.getOwnPropertyDescriptors?Object.defineProperties(s,Object.getOwnPropertyDescriptors(r)):Uu(Object(r)).forEach(function(t){Object.defineProperty(s,t,Object.getOwnPropertyDescriptor(r,t));});}return s}function Kd(s,e,r){return e=Yd(e),e in s?Object.defineProperty(s,e,{value:r,enumerable:true,configurable:true,writable:true}):s[e]=r,s}function Yd(s){var e=zd(s,"string");return typeof e=="symbol"?e:String(e)}function zd(s,e){if(typeof s!="object"||s===null)return s;var r=s[Symbol.toPrimitive];if(r!==void 0){var t=r.call(s,e);if(typeof t!="object")return t;throw new TypeError("@@toPrimitive must return a primitive value.")}return (e==="string"?String:Number)(s)}var Xd=Mu({}),xe=Xd;function Mu(s){return e.withOptions=r=>Mu(Bu(Bu({},s),r)),e;function e(r,...t){let n=typeof r=="string"?[r]:r.raw,{alignValues:i=false,escapeSpecialCharacters:a=Array.isArray(r),trimWhitespace:o=true}=s,l="";for(let c=0;c<n.length;c++){let f=n[c];if(a&&(f=f.replace(/\\\n[ \t]*/g,"").replace(/\\`/g,"`").replace(/\\\$/g,"$").replace(/\\\{/g,"{")),l+=f,c<t.length){let m=i?Qd(t[c],l):t[c];l+=m;}}let u=l.split(`
|
|
19
|
-
`),
|
|
20
|
-
|
|
21
|
-
`).replace(/\\t/g," ").replace(/\\r/g,"\r").replace(/\\v/g,"\v").replace(/\\b/g,"\b").replace(/\\f/g,"\f").replace(/\\0/g,"\0").replace(/\\x([\da-fA-F]{2})/g,(c,f)=>String.fromCharCode(parseInt(f,16))).replace(/\\u\{([\da-fA-F]{1,6})\}/g,(c,f)=>String.fromCodePoint(parseInt(f,16))).replace(/\\u([\da-fA-F]{4})/g,(c,f)=>String.fromCharCode(parseInt(f,16)))),typeof Bun<"u"&&(l=l.replace(/\\u(?:\{([\da-fA-F]{1,6})\}|([\da-fA-F]{4}))/g,(c,f,m)=>{var d;let g=(d=f??m)!==null&&d!==void 0?d:"";return String.fromCodePoint(parseInt(g,16))})),l}}function Qd(s,e){if(typeof s!="string"||!s.includes(`
|
|
22
|
-
`))return s;let
|
|
23
|
-
`)
|
|
24
|
-
${n}`)}return s}var Fu=[{name:"Self-hosted Logflare Configuration",link:"https://supabase.com/docs/reference/self-hosting-analytics/list-endpoints#getting-started"}],zn=["analytics"],qu=E.strictObject({enabled:E.boolean({default:false,description:"Enable the local Logflare service.",tags:zn,links:Fu}),port:E.number({default:54327,description:"Port to the local Logflare service.",tags:zn}),vector_port:E.number({default:54328,description:"Port to the local syslog ingest service.",tags:zn}),backend:E.string({enum:["postgres","bigquery"],default:"postgres",description:xe`
|
|
20
|
+
`)}async hexBodyHash(){let e=this.headers.get("X-Amz-Content-Sha256")||(this.service==="s3"&&this.signQuery?"UNSIGNED-PAYLOAD":null);if(e==null){if(this.body&&typeof this.body!="string"&&!("byteLength"in this.body))throw new Error("body must be a string, ArrayBuffer or ArrayBufferView, unless you include the X-Amz-Content-Sha256 header");e=$l(await fp(this.body||""));}return e}};dp=["0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"];});var Fm=iu((oI,CE)=>{CE.exports={"dev/vite/main.tsx":{file:"assets/main-BsWx0q9l.js",name:"main",src:"dev/vite/main.tsx",isEntry:true,css:["assets/main-DexXgo9R.css"]}};});var Nc,Gm,Vm,$o=$(()=>{Nc=(p=>(p.DISABLE_FOREIGN_KEYS="disable_foreign_keys",p.ENABLE_FOREIGN_KEYS="enable_foreign_keys",p.BEGIN_TRANSACTION="begin_transaction",p.COMMIT_TRANSACTION="commit_transaction",p.CREATE_TABLE="create_table",p.ADD_COLUMN="add_column",p.DROP_COLUMN="drop_column",p.ADD_INDEX="add_index",p.DROP_INDEX="drop_index",p.DROP_TABLE="drop_table",p.RENAME_TABLE="rename_table",p.COPY_DATA="copy_data",p.CREATE_TRIGGER="create_trigger",p))(Nc||{}),Gm=class extends Error{constructor(n){super(`Migration would cause data loss:
|
|
21
|
+
${n.map(r=>` - ${r.table}: ${r.reason}`).join(`
|
|
22
|
+
`)}`);this.warnings=n;this.name="DataLossError";}},Vm=class extends Error{constructor(n,r,s){super(`Migration failed at step ${n}: ${s.message}
|
|
23
|
+
SQL: ${r}`);this.stepIndex=n;this.sql=r;this.cause=s;this.name="MigrationError";}};});var on,No=$(()=>{on=class t{constructor(e){this.data=e;}appliesTo(e){return this.data.command==="ALL"||this.data.command===e}appliesToRole(e){return this.data.roles.length===0||this.data.roles.includes(e)}toJSON(){return this.data}static fromJSON(e){return new t(e)}};});var pr,Dc=$(()=>{Qr();pr=class{makeIndexKey(e){return `${e.table}:${e.name}:${e.unique}:${e.columns.join(",")}`}makeForeignKeyKey(e){return `${e.table}:${e.column}:${e.ref_table}:${e.ref_column}`}diff(e,n){let r=[],s=[],i=[],o=[],a=new Set(e.tables.map(h=>h.name)),l=new Set(n.tables.map(h=>h.name));for(let h of n.tables)a.has(h.name)||r.push({type:"added",name:h.name,sql:h.sql});for(let h of e.tables)l.has(h.name)||r.push({type:"removed",name:h.name});for(let h of e.tables){let b=n.tables.find(_=>_.name===h.name);if(!b)continue;let m=ol(h.sql),w=ol(b.sql);m!==w&&r.push({type:"modified",name:h.name,sql:b.sql});}let c=e.tables.filter(h=>l.has(h.name));for(let h of c){let b=e.columns.filter(S=>S.table===h.name),m=n.columns.filter(S=>S.table===h.name),w=new Map(b.map(S=>[S.name,S])),_=new Map(m.map(S=>[S.name,S]));for(let[S,E]of _)w.has(S)||s.push({type:"added",table:h.name,name:S,column:E});for(let[S]of w)_.has(S)||s.push({type:"removed",table:h.name,name:S});for(let[S,E]of w){let C=_.get(S);if(!C)continue;let x={};il(E.type)!==il(C.type)&&(x.type={from:E.type,to:C.type}),E.nullable!==C.nullable&&(x.nullable={from:E.nullable,to:C.nullable}),al(E.default_value)!==al(C.default_value)&&(x.default_value={from:E.default_value,to:C.default_value}),Object.keys(x).length>0&&s.push({type:"modified",table:h.name,name:S,changes:x});}}let f=new Map(e.indexes.map(h=>[this.makeIndexKey(h),h])),u=new Map(n.indexes.map(h=>[this.makeIndexKey(h),h]));for(let[h,b]of u)f.has(h)||i.push({type:"added",...b});for(let[h,b]of f)u.has(h)||i.push({type:"removed",...b});let d=new Map(e.foreign_keys.map(h=>[this.makeForeignKeyKey(h),h])),p=new Map(n.foreign_keys.map(h=>[this.makeForeignKeyKey(h),h]));for(let[h,b]of p)d.has(h)||o.push({type:"added",...b});for(let[h,b]of d)p.has(h)||o.push({type:"removed",...b});let y=r.length>0||s.length>0||i.length>0||o.length>0;return {tables:r,columns:s,indexes:i,foreign_keys:o,has_changes:y}}};});var WE,mr,jc=$(()=>{$o();Xr();WE=["CURRENT_TIMESTAMP","CURRENT_TIME","CURRENT_DATE"],mr=class{plan(e,n,r,s){if(!e.has_changes)return {steps:[],warnings:[],unsafe:false};let i=[],o=[];i.push({sql:"PRAGMA foreign_keys=OFF;",description:"Disable foreign key checks",type:"disable_foreign_keys"}),i.push({sql:"BEGIN;",description:"Begin transaction",type:"begin_transaction"});for(let u of e.tables.filter(d=>d.type==="added")){i.push({sql:`${u.sql};`,description:`CREATE TABLE ${P(u.name)}`,type:"create_table"});let d=r.indexes.filter(p=>p.table===u.name);for(let p of d){let y=p.unique?"UNIQUE ":"",h=p.columns.map(b=>P(b)).join(", ");i.push({sql:`CREATE ${y}INDEX ${P(p.name)} ON ${P(u.name)} (${h});`,description:`Create index ${P(p.name)} on ${P(u.name)}`,type:"add_index"});}}let a=new Set(n.tables.map(u=>u.name)),l=new Set(r.tables.map(u=>u.name)),c=new Set(e.tables.filter(u=>u.type==="modified").map(u=>u.name)),f=[...a].filter(u=>l.has(u));for(let u of f){if(!(c.has(u)||e.columns.some(h=>h.table===u)||e.indexes.some(h=>h.table===u)||e.foreign_keys.some(h=>h.table===u)))continue;let{canAlter:p,addedCols:y}=this.canSimpleAlter(u,e,r);if(p){for(let m of y)i.push({sql:`ALTER TABLE ${P(u)} ADD COLUMN ${this.columnDef(m)};`,description:`Add column ${P(m.name)} to ${P(u)}`,type:"add_column"});let h=e.indexes.filter(m=>m.table===u&&m.type==="added"),b=e.indexes.filter(m=>m.table===u&&m.type==="removed");for(let m of b)i.push({sql:`DROP INDEX IF EXISTS ${P(m.name)};`,description:`Drop index ${P(m.name)}`,type:"drop_index"});for(let m of h){let w=m.unique?"UNIQUE ":"",_=m.columns.map(S=>P(S)).join(", ");i.push({sql:`CREATE ${w}INDEX ${P(m.name)} ON ${P(u)} (${_});`,description:`Create index ${P(m.name)} on ${P(u)}`,type:"add_index"});}}else {let h=this.rebuildTable(u,n,r,e);i.push(...h.steps),o.push(...h.warnings);}}for(let u of e.tables.filter(d=>d.type==="removed"))i.push({sql:`DROP TABLE ${P(u.name)};`,description:`Drop table ${P(u.name)}`,type:"drop_table"}),o.push({table:u.name,reason:"table will be dropped"});return i.push({sql:"COMMIT;",description:"Commit transaction",type:"commit_transaction"}),i.push({sql:"PRAGMA foreign_keys=ON;",description:"Re-enable foreign key checks",type:"enable_foreign_keys"}),{steps:i,warnings:o,unsafe:o.length>0}}rebuildTable(e,n,r,s){let i=[],o=[],a=r.tables.find(m=>m.name===e);if(!a)return {steps:i,warnings:o};let l=`_${e}_migrate_new`,c=a.sql.replace(new RegExp(`(CREATE\\s+TABLE\\s+)(?:"${e}"|${e})`,"i"),`$1${P(l)}`);i.push({sql:`${c};`,description:`Create temporary table ${P(l)}`,type:"create_table"});let f=n.columns.filter(m=>m.table===e).map(m=>m.name),u=r.columns.filter(m=>m.table===e).map(m=>m.name),d=f.filter(m=>u.includes(m));if(d.length>0){let m=d.map(w=>P(w)).join(", ");i.push({sql:`INSERT INTO ${P(l)} (${m})
|
|
24
|
+
SELECT ${m}
|
|
25
|
+
FROM ${P(e)};`,description:`Copy data from ${P(e)} to ${P(l)}`,type:"copy_data"});}i.push({sql:`DROP TABLE ${P(e)};`,description:`Drop old table ${P(e)}`,type:"drop_table"}),i.push({sql:`ALTER TABLE ${P(l)} RENAME TO ${P(e)};`,description:`Rename ${P(l)} to ${P(e)}`,type:"rename_table"});let p=r.indexes.filter(m=>m.table===e);for(let m of p){let w=m.unique?"UNIQUE ":"",_=m.columns.map(S=>P(S)).join(", ");i.push({sql:`CREATE ${w}INDEX ${P(m.name)} ON ${P(e)} (${_});`,description:`Recreate index ${P(m.name)} on ${P(e)}`,type:"add_index"});}let y=r.triggers?.filter(m=>m.table===e)??[];for(let m of y)i.push({sql:`${m.sql};`,description:`Recreate trigger ${P(m.name)} on ${P(e)}`,type:"create_trigger"});let h=s.columns.filter(m=>m.table===e&&m.type==="removed");for(let m of h)o.push({table:e,reason:`column "${m.name}" will be dropped`});let b=s.columns.filter(m=>m.table===e&&m.type==="modified");for(let m of b)m.changes?.type&&o.push({table:e,reason:`column "${m.name}" type changes from ${m.changes.type.from} to ${m.changes.type.to}`}),m.changes?.nullable&&!m.changes.nullable.to&&o.push({table:e,reason:`column "${m.name}" becomes NOT NULL`});return {steps:i,warnings:o}}canSimpleAlter(e,n,r){let s=n.columns.filter(u=>u.table===e),i=s.filter(u=>u.type==="added"),o=s.filter(u=>u.type==="removed"),a=s.filter(u=>u.type==="modified"),l=n.foreign_keys.some(u=>u.table===e);if(o.length>0||a.length>0||l)return {canAlter:false,addedCols:i};let c=r.tables.find(u=>u.name===e);return c&&/\bCHECK\s*\(/i.test(c.sql)?{canAlter:false,addedCols:i}:{canAlter:i.every(u=>{let d=u.column;return this.hasNonConstantDefault(d.default_value)?false:d.nullable||d.default_value!=null})&&i.length>0,addedCols:i}}hasNonConstantDefault(e){if(e==null)return false;let n=e.trim().toUpperCase();return WE.includes(n)}columnDef(e){let n=e.column,r=`${P(n.name)} ${n.type||"TEXT"}`;return n.nullable||(r+=" NOT NULL"),n.default_value!=null&&(r+=` DEFAULT ${n.default_value}`),r}};});async function hr(t){let{parse:e}=await import('pgsql-parser');return e(t)}var oh=$(()=>{});function Is(t){if("String"in t)return t.String.sval}function Pn(t){return t.map(Is).filter(e=>e!=null)}function Nn(t){return t==null?[]:t.List!==void 0?t.List.items||[]:Array.isArray(t)?t:[t]}function Uo(t){return QuoteUtils.quoteIdentifier(t)}function gr(t){return Object.keys(t)[0]}function ah(t){if("A_Const"in t){if(t.A_Const.ival)return t.A_Const.ival.ival;if(t.A_Const.fval)return t.A_Const.fval.fval;if(t.A_Const.sval)return t.A_Const.sval.sval;if(t.A_Const.boolval)return t.A_Const.boolval.boolval;if(t.A_Const.isnull)return null}}var In=$(()=>{});function ch(t){let e=t.toLowerCase().trim();if(e.startsWith("_")||e.endsWith("[]"))return "TEXT";let n=ZE[e];if(!n)throw new Dn(`Unsupported PostgreSQL type: "${t}"`);return n}function Mo(t){let e=t.toLowerCase();return ["serial","serial4","bigserial","serial8","smallserial","serial2"].includes(e)}function Fo(t){let e=t.toLowerCase();return ["varchar","character varying","char","character","bpchar"].includes(e)}function Bo(t){let e=t.toLowerCase();return ["numeric","decimal"].includes(e)}var Dn,N,ZE,lh,e_,qo,yr=$(()=>{In();Dn=class extends Error{},N=class extends Dn{constructor(n,r){super(r??`Unsupported node type: ${gr(n)}`);this.node=n;}},ZE={int2:"INTEGER",smallint:"INTEGER",int4:"INTEGER",integer:"INTEGER",int:"INTEGER",int8:"INTEGER",bigint:"INTEGER",serial:"INTEGER",serial4:"INTEGER",bigserial:"INTEGER",serial8:"INTEGER",smallserial:"INTEGER",serial2:"INTEGER",float4:"REAL",real:"REAL",float8:"REAL","double precision":"REAL",numeric:"REAL",decimal:"REAL",text:"TEXT",varchar:"TEXT","character varying":"TEXT",char:"TEXT",character:"TEXT",bpchar:"TEXT",name:"TEXT",bytea:"BLOB",bool:"INTEGER",boolean:"INTEGER",date:"TEXT",time:"TEXT","time without time zone":"TEXT",timetz:"TEXT","time with time zone":"TEXT",timestamp:"TEXT","timestamp without time zone":"TEXT",timestamptz:"TEXT","timestamp with time zone":"TEXT",interval:"TEXT",json:"TEXT",jsonb:"TEXT",uuid:"TEXT",inet:"TEXT"},lh=["<",">","<=",">=","=","<>","!=","+","-","*","/","%","&","|","<<",">>","||","BETWEEN","NOT BETWEEN","IN","NOT IN","LIKE","NOT LIKE","IS NULL","IS NOT NULL","IS TRUE","IS NOT TRUE","IS FALSE","IS NOT FALSE","IS UNKNOWN","IS NOT UNKNOWN","AND","OR","NOT","->>"];e_={CreateEnumStmt:{react:"ignore"},CreateDomainStmt:{react:"warn"},CreateSeqStmt:{react:"error"},AlterSeqStmt:{react:"error"},CreateSchemaStmt:{react:"warn"},CreatePolicyStmt:{react:"ignore"},PartitionElem:{react:"error"},PartitionCmd:{react:"error"},VariableSetStmt:{react:"ignore"},CompositeTypeStmt:{react:"error"},AlterEnumStmt:{react:"error"},AlterObjectSchemaStmt:{react:"error"},AlterOwnerStmt:{react:"error"},AlterTypeStmt:{react:"error"},AlterFunctionStmt:{react:"error"},AlterDefaultPrivilegesStmt:{react:"error"},GrantStmt:{react:"error"},GrantRoleStmt:{react:"error"},CopyStmt:{react:"error"},CreateCastStmt:{react:"error"},AlterOpFamilyStmt:{react:"error"},AlterOperatorStmt:{react:"error"},TruncateStmt:{react:"error"},A_Indirection:{react:"error"},XmlExpr:{react:"error"},XmlSerialize:{react:"error"},RangeTableSample:{react:"error"},GroupingSet:{react:"error"}},qo=new Map(Object.entries(e_));});var Wo,uh=$(()=>{yr();In();Wo=class{constructor(e){this.ast=e;this.result=[...this.walk(this.ast,[],{trackPaths:["returningList"]})];}result=[];*walk(e=this.ast,n=[],r={}){if(!e||typeof e!="object")return;let{trackPaths:s=[]}=r;if(Array.isArray(e)){for(let o=0;o<e.length;o++)yield*this.walk(e[o],n,r);return}let i=Object.keys(e);if(i.length===1&&i[0][0]>="A"&&i[0][0]<="Z"){let o=i[0];yield {node:e,path:n},yield*this.walk(e[o],[...n,o],r);}else for(let[o,a]of Object.entries(e))if(a&&typeof a=="object"){let l=s.includes(o)?[...n,o]:n;yield*this.walk(a,l,r);}}containsUnsupportedNode(){for(let{node:e}of this.result){let n=gr(e),r=qo.get(n);if(r&&r.react==="error")return true}}hasFuncCall(){for(let{node:e}of this.result)if("FuncCall"in e)return true;return false}getFuncCalls(){return Array.from(this.result).map(({node:e})=>e).filter(e=>"FuncCall"in e).map(e=>e.FuncCall)}getFuncCallNames(){return this.getFuncCalls().flatMap(e=>e.funcname?.map(n=>n.String?.sval||n.String?.str))}hasSqlValueFunction(){for(let{node:e}of this.result)if("SQLValueFunction"in e)return true;return false}getSqlValueFunctions(){return Array.from(this.result).map(({node:e})=>e).filter(e=>"SQLValueFunction"in e).map(e=>e.SQLValueFunction)}getSqlValueFunctionNames(){return this.getSqlValueFunctions().map(e=>e.op)}hasUnsafeStar(){let e=this.result.filter(({node:n})=>"A_Star"in n);if(e.length===0)return false;for(let{path:n}of e)if(!n.includes("SelectStmt")&&!n.includes("returningList"))return true;return false}getRelationDefinitions(){return this.result.filter(({node:n})=>"CreateStmt"in n).map(({node:n})=>n.CreateStmt).map(n=>({relation:{relname:n.relation?.relname??"",inh:n.relation?.inh,relpersistence:n.relation?.relpersistence},columns:n.tableElts?.map(r=>{let s=r.ColumnDef?.typeName?.names?.map(o=>"String"in o?o.String.sval:""),i=s?.some(o=>o.toLowerCase().includes("pg_catalog"));return {name:r.ColumnDef?.colname??"",is_local:r.ColumnDef?.is_local,pg_catalog:i,type:s?.filter(o=>!o.toLowerCase().includes("pg_catalog"))[0]??"",types:s,constraints:r.ColumnDef?.constraints}})}))}getRelationColumnTypes(){return {has_non_pg_catalog_types:this.getRelationDefinitions().some(e=>e.columns?.some(n=>!n.pg_catalog)),types:Array.from(new Set(this.getRelationDefinitions().flatMap(e=>e.columns?.map(n=>n.type))))}}};});var t_,n_,r_,s_,br,Jo,fh=$(()=>{yr();t_=["DECLARE","IF","ELSIF","ELSE","LOOP","WHILE","FOR","FOREACH","EXCEPTION","RAISE","PERFORM","EXECUTE","SELECT"],n_=/^NEW\.(\w+)\s*(?::=|=)\s*(.+)$/is,r_=/^RETURN\s+(NEW|OLD)$/i,s_=/^(INSERT|UPDATE|DELETE)\b/i,br=class extends Dn{constructor(n,r,s){super(s??`Unsupported PL/pgSQL: ${n}`);this.hint=n;this.body=r;}},Jo=class{parse(e){let n=this.extractBlock(e),r=this.splitStatements(n),s=[],i=null;for(let o of r){let a=o.trim();if(!a)continue;this.rejectUnsupported(a);let l=a.match(r_);if(l){i=l[1].toUpperCase(),s.push({type:"return",value:i});continue}let c=a.match(n_);if(c){s.push({type:"assignment",column:c[1],expression:c[2].trim()});continue}if(s_.test(a)){s.push({type:"dml",sql:a});continue}throw new br(`"${a.substring(0,80)}" is not translatable to SQLite`,n)}if(!i)throw new Dn("Trigger function body must end with RETURN NEW or RETURN OLD");return {statements:s,returnValue:i}}extractBlock(e){let n=e.trim(),r=n.toUpperCase();if(/^\s*DECLARE\b/i.test(n))throw new br('"DECLARE" is not translatable to SQLite',e);let s=r.indexOf("BEGIN"),i=r.lastIndexOf("END");if(s===-1||i===-1||i<=s)throw new br("Expected BEGIN ... END block in trigger function body",e);return n.slice(s+5,i).trim()}splitStatements(e){let n=[],r="",s=0,i=false,o="";for(let l=0;l<e.length;l++){let c=e[l];if(i){r+=c,c===o&&(l+1<e.length&&e[l+1]===o?r+=e[++l]:i=false);continue}if(c==="'"||c==='"'){i=true,o=c,r+=c;continue}if(c==="("){s++,r+=c;continue}if(c===")"){s--,r+=c;continue}if(c===";"&&s===0){n.push(r.trim()),r="";continue}r+=c;}let a=r.trim();return a&&n.push(a),n}rejectUnsupported(e){let n=e.match(/^(\w+)/)?.[1]?.toUpperCase();if(n&&t_.includes(n))throw new br(`"${n}" is not translatable to SQLite`,e)}};});var be,Ft=$(()=>{Wi();be=class{context;constructor(e){this.context=e;}get isShimBacked(){return false}checkConstraint(){return null}serialize(e){return e}deserialize(e){return e}validateStorage(e){return {status:"pass",message:null}}validationFail(e,n){return {status:"fail",message:e,action:n}}validationPass(){return {status:"pass",message:null}}isNullish(e){return e==null}toColumnDDL(e){let{includeNullable:n=true}=e??{},r=[],s=this.context.column;r.push(this.quoteIfNeeded(s)),r.push(this.sqliteType),this.context.isPrimaryKey&&r.push("PRIMARY KEY"),this.context.isSerial&&this.context.isPrimaryKey&&r.push("AUTOINCREMENT"),n&&!this.context.nullable&&!this.context.isPrimaryKey&&r.push("NOT NULL"),this.context.isUnique&&!this.context.isPrimaryKey&&r.push("UNIQUE"),this.context.defaultValue!==null&&r.push(`DEFAULT ${this.context.defaultValue}`);let i=this.checkConstraint();return i&&r.push(`CHECK (${i})`),r.join(" ")}checkError(e,n){return new Sn(this.context.table,this.context.column,e,n)}quoteIfNeeded(e){return /^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)?e:`"${e}"`}};});var jn,Ko=$(()=>{Ft();jn=class extends be{get sqliteType(){return "INTEGER"}};});var Ds,Lc=$(()=>{Ko();Ds=class extends jn{constructor(e){super({...e,isSerial:true});}};});function i_(t,e){let{precision:n,scale:r}=e,s=10**r,i=10**(n-r);return Math.abs(Math.round(t*s)-t*s)<1e-4&&Math.abs(t)<i}var js,Uc=$(()=>{Ft();js=class extends be{numericPrecision;constructor(e,n){super(e),this.numericPrecision=n;}get isShimBacked(){return this.numericPrecision!==void 0}get sqliteType(){return "REAL"}checkConstraint(){if(this.numericPrecision){let{precision:e,scale:n}=this.numericPrecision,r=this.context.column,s=10**n,i=10**(e-n);return `ABS(ROUND(${r} * ${s}) - ${r} * ${s}) < 0.0001 AND ABS(${r}) < ${i}`}return null}validateStorage(e){if(this.isNullish(e))return this.validationPass();if(typeof e!="number"||!Number.isFinite(e))return this.validationFail("Expected finite number.","Patch rows with finite numbers.");if(this.numericPrecision){let{precision:n,scale:r}=this.numericPrecision;if(!i_(e,this.numericPrecision))return this.validationFail(`Does not fit numeric(${n}, ${r}).`,"Patch rows within numeric precision.")}return this.validationPass()}};});var ie,tt=$(()=>{Ft();ie=class extends be{lengthConstraint;constructor(e,n){super(e),this.lengthConstraint=n;}get isShimBacked(){return this.lengthConstraint!==void 0}get sqliteType(){return "TEXT"}checkConstraint(){return this.lengthConstraint!==void 0?`length(${this.context.column}) <= ${this.lengthConstraint}`:null}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"?this.validationFail("Expected text.","Patch rows with text values."):this.lengthConstraint!==void 0&&Array.from(e).length>this.lengthConstraint?this.validationFail(`Exceeds length ${this.lengthConstraint}.`,"Patch rows with shorter text."):this.validationPass()}};});var Ls,Mc=$(()=>{Ft();Ls=class extends be{get sqliteType(){return "BLOB"}};});var Us,Fc=$(()=>{Ft();Us=class extends be{get isShimBacked(){return true}get sqliteType(){return "INTEGER"}checkConstraint(){return `${this.context.column} IN (0, 1)`}serialize(e){if(this.isNullish(e))return e;if(e===true||e===1)return 1;if(e===false||e===0)return 0;throw this.checkError("boolean_range",e)}deserialize(e){return this.isNullish(e)?e:e===1?true:e===0?false:e}validateStorage(e){return this.isNullish(e)?this.validationPass():e===1||e===0?this.validationPass():this.validationFail("Expected 0 or 1.","Patch rows with boolean values.")}};});function dh(t){try{return {ok:!0,value:JSON.parse(t)}}catch{return {ok:false}}}var Ms,Bc=$(()=>{Ft();Ms=class extends be{get isShimBacked(){return true}get sqliteType(){return "TEXT"}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR json_valid(${e})`}serialize(e){if(this.isNullish(e))return e;try{return JSON.stringify(e)}catch{throw this.checkError("json_valid",e)}}deserialize(e){if(this.isNullish(e))return e;if(typeof e=="string"){let n=dh(e);return n.ok?n.value:e}return e}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"?this.validationFail("Expected JSON text.","Patch rows with JSON values."):dh(e).ok?this.validationPass():this.validationFail("Invalid JSON text.","Patch rows with valid JSON.")}};});function o_(t){if(!/^\d{4}-\d{2}-\d{2}$/.test(t))return false;let e=new Date(`${t}T00:00:00.000Z`);return !Number.isNaN(e.getTime())&&e.toISOString().slice(0,10)===t}var Fs,qc=$(()=>{tt();Fs=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR date(${e}) IS NOT NULL`}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!o_(e)?this.validationFail("Invalid date.","Patch rows with YYYY-MM-DD dates."):this.validationPass()}};});function a_(t){let e=t.match(/^(\d{2}):(\d{2})(?::(\d{2})(?:\.\d{1,6})?)?([+-](\d{2}):?(\d{2}))?$/);if(!e)return false;let n=Number(e[1]),r=Number(e[2]),s=e[3]===void 0?0:Number(e[3]),i=e[5]===void 0?null:Number(e[5]),o=e[6]===void 0?null:Number(e[6]),a=i===null||o!==null&&i<=15&&o<=59;return n<=24&&r<=59&&s<=59&&(n!==24||r===0&&s===0)&&a}var Bs,Wc=$(()=>{tt();Bs=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR time(${e}) IS NOT NULL`}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!a_(e)?this.validationFail("Invalid time.","Patch rows with HH:MM[:SS] times."):this.validationPass()}};});function l_(t){let e=t.match(/^(\d{4})-(\d{2})-(\d{2})[ T](\d{2}):(\d{2})(?::(\d{2})(?:\.\d{1,6})?)?(?:Z|([+-](\d{2}):?(\d{2})))?$/);if(!e)return false;let n=Number(e[1]),r=Number(e[2]),s=Number(e[3]),i=Number(e[4]),o=Number(e[5]),a=e[6]===void 0?0:Number(e[6]),l=e[8]===void 0?null:Number(e[8]),c=e[9]===void 0?null:Number(e[9]),f=new Date(Date.UTC(n,r-1,s)),u=f.getUTCFullYear()===n&&f.getUTCMonth()===r-1&&f.getUTCDate()===s,d=i<=24&&o<=59&&a<=59&&(i!==24||o===0&&a===0),p=l===null||c!==null&&l<=15&&c<=59;return u&&d&&p}var qs,Jc=$(()=>{tt();qs=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR datetime(${e}) IS NOT NULL`}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!l_(e)?this.validationFail("Invalid timestamp.","Patch rows with ISO timestamps."):this.validationPass()}};});var Ws,Kc=$(()=>{tt();Ws=class extends ie{get isShimBacked(){return true}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||e.trim().length===0?this.validationFail("Expected interval text.","Patch rows with interval strings."):/^-?\d+(?:\.\d+)?$/.test(e.trim())?this.validationFail("Ambiguous numeric interval.","Patch rows with explicit interval strings."):this.validationPass()}};});var Js,Hc=$(()=>{tt();Js=class extends ie{enumValues;constructor(e,n){super(e),this.enumValues=n;}get isShimBacked(){return true}checkConstraint(){let e=this.context.column,n=this.enumValues.map(r=>`'${r.replace(/'/g,"''")}'`).join(", ");return `${e} IN (${n})`}serialize(e){if(this.isNullish(e))return e;if(typeof e!="string"||!this.enumValues.includes(e))throw this.checkError("enum_membership",e);return e}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!this.enumValues.includes(e)?this.validationFail("Invalid enum value.","Patch rows with declared enum values."):this.validationPass()}};});function ph(t){try{return {ok:!0,value:JSON.parse(t)}}catch{return {ok:false}}}var wr,zc=$(()=>{Ft();wr=class extends be{elementField;constructor(e,n){super(e),this.elementField=n;}get sqliteType(){return "TEXT"}get isShimBacked(){return true}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR (json_valid(${e}) AND json_type(${e}) = 'array')`}serialize(e){if(this.isNullish(e))return e;if(!Array.isArray(e))throw this.checkError("array_type",e);return this.elementField?JSON.stringify(e.map(n=>this.elementField.serialize(n))):JSON.stringify(e)}deserialize(e){if(this.isNullish(e))return e;if(typeof e=="string"){let n=ph(e);if(n.ok&&Array.isArray(n.value))return this.elementField?n.value.map(r=>this.elementField.deserialize(r)):n.value}return e}validateStorage(e){if(this.isNullish(e))return this.validationPass();if(typeof e!="string")return this.validationFail("Expected JSON array text.","Patch rows with array values.");let n=ph(e);if(!n.ok)return this.validationFail("Invalid JSON array text.","Patch rows with array values.");if(!Array.isArray(n.value))return this.validationFail("Expected JSON array.","Patch rows with array values.");if(this.elementField)for(let r of n.value){let s=this.elementField.validateStorage(r);if(s.status==="fail")return this.validationFail(`Invalid ${this.elementField.context.pgTypeName} array element.`,s.action??"Patch rows with valid array elements.")}return this.validationPass()}};});function mh(t){return u_.test(t.toLowerCase())}var c_,u_,Ks,Gc=$(()=>{tt();c_="????????-????-????-????-????????????",u_=/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/;Ks=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.quoteIfNeeded(this.context.column);return `${e} IS NULL OR ${e} GLOB '${c_}'`}serialize(e){if(this.isNullish(e))return e;if(typeof e!="string")throw this.checkError("uuid_format",e);let n=e.toLowerCase();if(!mh(n))throw this.checkError("uuid_format",e);return n}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!mh(e)?this.validationFail("Invalid UUID.","Patch rows with valid UUIDs."):this.validationPass()}};});function f_(t){let e=t.split("/");if(e.length>2)return null;let n=e[0];if(!n)return null;if(e.length===1)return {address:n,prefix:null};let r=e[1];return !r||!/^\d+$/.test(r)?null:{address:n,prefix:Number(r)}}function d_(t){let e=t.split(".");return e.length!==4?false:e.every(n=>{if(!/^\d+$/.test(n))return false;let r=Number(n);return r>=0&&r<=255})}function p_(t){if(!t.includes(":"))return false;try{return new URL(`http://[${t}]/`),!0}catch{return false}}function hh(t){let e=f_(t);return e?d_(e.address)?e.prefix===null||e.prefix>=0&&e.prefix<=32:p_(e.address)?e.prefix===null||e.prefix>=0&&e.prefix<=128:false:false}var Hs,Vc=$(()=>{tt();Hs=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.quoteIfNeeded(this.context.column);return `${e} IS NULL OR (length(${e}) BETWEEN 3 AND 49 AND (instr(${e}, '.') > 0 OR instr(${e}, ':') > 0))`}serialize(e){if(this.isNullish(e))return e;if(typeof e!="string")throw this.checkError("inet_format",e);let n=e.trim();if(!hh(n))throw this.checkError("inet_format",e);return n}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!hh(e.trim())?this.validationFail("Invalid inet address.","Patch rows with valid inet strings."):this.validationPass()}};});var zs,Qc=$(()=>{tt();zs=class extends ie{serialize(e){throw new Error(`Unsupported type "${this.context.pgTypeName}" for ${this.context.table}.${this.context.column}`)}deserialize(e){throw new Error(`Unsupported type "${this.context.pgTypeName}" for ${this.context.table}.${this.context.column}`)}toColumnDDL(){throw new Error(`Unsupported type "${this.context.pgTypeName}" for ${this.context.table}.${this.context.column}`)}};});function Ln(t,e){if(e?.isArray){let r=Ln(t,{...e,isArray:false});return new wr(t,r)}if(e?.enumValues)return new Js(t,e.enumValues);let n=t.pgTypeName.toLowerCase().trim();if(n.startsWith("_")||n.endsWith("[]")){let r=n.startsWith("_")?n.slice(1):n.slice(0,-2),s={...t,pgTypeName:r},i=Ln(s);return new wr(t,i)}return h_.has(n)?new Ds(t):m_.has(n)?new jn(t):w_.has(n)?new Us(t):S_.has(n)?new Ms(t):v_.has(n)?new Fs(t):C_.has(n)?new Bs(t):R_.has(n)?new qs(t):T_.has(n)?new Ws(t):b_.has(n)?new Ls(t):g_.has(n)?new js(t,e?.numericPrecision):E_.has(n)?new Ks(t):__.has(n)?new ie(t,63):x_.has(n)?new Hs(t):y_.has(n)?new ie(t,e?.lengthConstraint):new zs(t)}var m_,h_,g_,y_,b_,w_,S_,E_,__,x_,v_,C_,R_,T_,Xc=$(()=>{Ko();Lc();Uc();tt();Mc();Fc();Bc();qc();Wc();Jc();Kc();Hc();zc();Gc();Vc();Qc();m_=new Set(["int2","smallint","int4","integer","int","int8","bigint"]),h_=new Set(["serial","serial4","bigserial","serial8","smallserial","serial2"]),g_=new Set(["float4","real","float8","double precision","numeric","decimal"]),y_=new Set(["text","varchar","character varying","char","character","bpchar"]),b_=new Set(["bytea"]),w_=new Set(["bool","boolean"]),S_=new Set(["json","jsonb"]),E_=new Set(["uuid"]),__=new Set(["name"]),x_=new Set(["inet"]),v_=new Set(["date"]),C_=new Set(["time","timetz","time without time zone","time with time zone"]),R_=new Set(["timestamp","timestamptz","timestamp without time zone","timestamp with time zone"]),T_=new Set(["interval"]);});function Yc(t,e="auto"){let n=t.toLowerCase(),r=Ho[n];if(!r)return null;switch(e){case "translate":{if(!r.sqlite)throw new Error(`No SQLite translation for function "${t}"`);return {sqliteExpr:r.sqlite(),jsFn:null}}case "synthetic":{if(!r.js)throw new Error(`No JS implementation for function "${t}"`);return {sqliteExpr:null,jsFn:r.js}}case "auto":return r.js?{sqliteExpr:null,jsFn:r.js}:r.sqlite?{sqliteExpr:r.sqlite(),jsFn:null}:null}}var gh,Ho,Zc=$(()=>{gh="lower(hex(randomblob(4))) || '-' || lower(hex(randomblob(2))) || '-4' || substr(lower(hex(randomblob(2))),2) || '-' || substr('89ab',abs(random()) % 4 + 1, 1) || substr(lower(hex(randomblob(2))),2) || '-' || lower(hex(randomblob(6)))",Ho={gen_random_uuid:{sqlite:()=>gh,js:()=>crypto.randomUUID()},uuid_generate_v4:{sqlite:()=>gh,js:()=>crypto.randomUUID()},now:{sqlite:()=>"datetime('now')",js:()=>new Date().toISOString()},current_timestamp:{sqlite:()=>"datetime('now')",js:()=>new Date().toISOString()},current_date:{sqlite:()=>"date('now')",js:()=>new Date().toISOString().split("T")[0]},current_time:{sqlite:()=>"time('now')",js:()=>new Date().toISOString().split("T")[1].replace("Z","")},random:{sqlite:()=>"random()",js:()=>Math.random()},length:{sqlite:()=>"length",js:null},lower:{sqlite:()=>"lower",js:null},upper:{sqlite:()=>"upper",js:null},substr:{sqlite:()=>"substr",js:null},substring:{sqlite:()=>"substr",js:null},trim:{sqlite:()=>"trim",js:null},ltrim:{sqlite:()=>"ltrim",js:null},rtrim:{sqlite:()=>"rtrim",js:null},replace:{sqlite:()=>"replace",js:null},coalesce:{sqlite:()=>"coalesce",js:null},nullif:{sqlite:()=>"nullif",js:null},count:{sqlite:()=>"count",js:null},sum:{sqlite:()=>"sum",js:null},avg:{sqlite:()=>"avg",js:null},min:{sqlite:()=>"min",js:null},max:{sqlite:()=>"max",js:null},localtime:{sqlite:()=>"time('now', 'localtime')",js:null},localtimestamp:{sqlite:()=>"datetime('now', 'localtime')",js:null}};});var zo,yh=$(()=>{yr();In();In();uh();Yr();fh();$o();Dc();jc();Xr();Xc();Zc();zo=class extends Deparser{enums;schemaHandling;warnings=[];helper;config;triggerFunctions=new Map;plpgsqlParser=new Jo;introspection;functionResolution;constructor(e,{enums:n,schemaHandling:r,introspection:s,...i}={}){super(e,i),this.schemaHandling=r??"default",this.enums=n??new Map,this.helper=new Wo(e),this.config=i,this.introspection=s,this.functionResolution=i?.functionResolution??"translate";}visit(e,n){let r=gr(e),s=qo.get(r);if(s){if(s.react==="error")throw new N({[r]:e},`Unsupported node type: ${r}`);return s.react==="warn"&&this.warnings.push({type:r,node:e}),""}return super.visit(e,n)}deparse(e,n){if(e==null)return null;if(!n){let r=new SqlFormatter;n=new DeparserContext({formatter:r});}return typeof e=="number"||e instanceof Number?e.toString():this.visit(e,n)}RawStmt(e,n){if(!e.stmt||e.stmt.CommentStmt)return "";let r=this.deparse(e.stmt,n);return !r||r.length===0?"":e.stmt_len?r+";":r}RangeVar(e,n){this.ensureRelation(e);let r=this.effectiveSchema(e.schemaname),s=e.relname,i=this.quoteBareIfNeeded(s);r&&(this.schemaHandling==="prefix"?i=`${r}__${s}`:i=`"${r}.${s}"`);let o=e.alias?" "+this.Alias(e.alias,n):"";return i+o}getRelationName(e){this.ensureRelation(e);let n=this.effectiveSchema(e.schemaname),r=e.relname;return n?this.schemaHandling==="prefix"?`${n}__${r}`:`${n}.${r}`:r}quoteBareIfNeeded(e){return /^[A-Za-z_][A-Za-z0-9_]*$/.test(e)?e:`"${e.replace(/"/g,'""')}"`}effectiveSchema(e){if(e){if(this.config.forceDefaultSchema||this.schemaHandling!=="default")return e;if(e!=="public")return e}}ensureRelation(e){let n=this.config.forceDefaultSchema;n&&(!e||typeof e!="object"||n.length===0||e.schemaname||(e.schemaname=n));}CreateStmt(e,n){if(e.inhRelations&&e.inhRelations.length>0)throw new N({CreateStmt:e},"Inheritance is not supported in SQLite");if(e.ofTypename!==void 0)throw new N({CreateStmt:e},"Typed tables (CREATE TABLE ... OF type_name) are not supported. Define columns directly in the CREATE TABLE statement instead.");if(e.options&&e.options.length>0&&(e.options=void 0),!e.tableElts||e.tableElts.length===0)throw new N({CreateStmt:e},"Empty tables are not supported in SQLite. Define at least one column.");return e.accessMethod&&(e.accessMethod=void 0),super.CreateStmt(e,n)+" STRICT"}TableLikeClause(e,n){throw new N({TableLikeClause:e},"CREATE TABLE ... (LIKE ...) is not supported in SQLite. Define the table columns explicitly instead.")}DefElem(e,n){if(["oids","fillfactor",/^autovacuum_/i,"toast_tuple_target","parallel_workers","user_catalog_table"].some(i=>qi(e.defname??"",i)))return "";let s=super.DefElem(e,n);throw new N({DefElem:e},`DefElem "${e.defname}" (${s}) not supported`)}TypeName(e,n){if(!e.names)return "";let r=e.names.map(i=>i.String?i.String.sval||i.String.str:"").filter(Boolean);if(r.length===0)return "";let s=r.length===2&&r[0]==="pg_catalog"?r[1]:r.join(".");return e.arrayBounds&&e.arrayBounds.length>0||this.enums.has(s.toLowerCase())?"TEXT":ch(s)}ColumnDef(e,n){let r=[],s=e.colname;s&&r.push(this.quoteIfNeeded(s));let i=false,o=false,a=null,l=null,c=null,f=false;if(e.typeName){let u=e.typeName.names?.map(y=>y.String?.sval||y.String?.str).filter(Boolean);c=u&&(u.length===2&&u[0]==="pg_catalog"?u[1]:u[0]),i=!!(c&&Mo(c)),f=!!(e.typeName.arrayBounds&&e.typeName.arrayBounds.length>0);let d=Array.isArray(e.typeName.typmods)?e.typeName.typmods:[],p=y=>d[y]?.A_Const?.ival?.ival??d[y]?.A_Const?.val?.ival?.ival;if(c&&Fo(c)&&d.length>0){let y=p(0);typeof y=="number"&&y>0&&(a={maxLen:y});}if(c&&Bo(c)&&d.length>=2){let y=p(0),h=p(1);typeof y=="number"&&typeof h=="number"&&y>0&&h>=0&&(l={precision:y,scale:h});}if(e.constraints){let y=Array.isArray(e.constraints)?e.constraints:[];o=y.some(h=>h.Constraint?.contype==="CONSTR_PRIMARY"),y.some(h=>h.Constraint?.contype==="CONSTR_IDENTITY")&&(i=true);}r.push(this.TypeName(e.typeName,n));}if(e.constraints){let u=Array.isArray(e.constraints)?e.constraints:[],d=u.map(y=>this.visit(y,n));r.push(...d.filter(Boolean));let p=u.some(y=>y.Constraint?.contype==="CONSTR_CHECK");i&&o&&!p&&r.push("AUTOINCREMENT");}if(s&&c){let u={isArray:f};a&&(u.lengthConstraint=a.maxLen),l&&(u.numericPrecision=l);let d=this.enums.get(c.toLowerCase());d&&(u.enumValues=d);let h=Ln({schema:"public",table:"",column:s,pgTypeName:c,nullable:true,defaultValue:null,defaultFn:null,isPrimaryKey:o,isUnique:false,isSerial:i},u).checkConstraint();h&&r.push(`CHECK (${h})`);}return r.join(" ")}Constraint(e,n){let r=e.contype;if(r==="CONSTR_IDENTITY"||r==="CONSTR_ATTR_DEFERRABLE"||r==="CONSTR_ATTR_NOT_DEFERRABLE"||r==="CONSTR_ATTR_DEFERRED"||r==="CONSTR_ATTR_IMMEDIATE")return "";if(r==="CONSTR_NULL")return "NULL";if(r==="CONSTR_NOTNULL")return "NOT NULL";if(r==="CONSTR_DEFAULT"&&e.raw_expr){let s=this.visit(e.raw_expr,n);return s.includes("(")&&!s.startsWith("(")?`DEFAULT (${s})`:`DEFAULT ${s}`}if(r==="CONSTR_CHECK"&&e.raw_expr){let s=[];e.conname&&s.push("CONSTRAINT",Uo(e.conname)),s.push("CHECK");let i=this.visit(e.raw_expr,n);return s.push(`(${i})`),s.join(" ")}if(r==="CONSTR_PRIMARY")return e.keys&&e.keys.length>0?`PRIMARY KEY (${Nn(e.keys).map(i=>this.visit(i,n)).join(", ")})`:"PRIMARY KEY";if(r==="CONSTR_UNIQUE")return e.keys&&e.keys.length>0?`UNIQUE (${Nn(e.keys).map(i=>this.visit(i,n)).join(", ")})`:"UNIQUE";if(r==="CONSTR_FOREIGN")return super.Constraint(e,n).replace(/FOREIGN\s+KEY\s+REFERENCES/gi,"REFERENCES");if(r==="CONSTR_GENERATED"&&e.raw_expr)return `GENERATED ALWAYS AS (${this.visit(e.raw_expr,n)}) STORED`;if(r==="CONSTR_EXCLUSION")throw new N({Constraint:e},"EXCLUSION constraints are not supported in SQLite");return ""}FuncCall(e,n){let s=(e.funcname||[]).map(c=>c.String?.sval||c.String?.str).filter(Boolean);if(s.length===0)throw new Error("Function call has no name");let i=s[s.length-1].toLowerCase();if(i==="extract"&&e.args&&e.args.length>=2){let c=e.args[0];if((c?.A_Const?.sval?.sval||c?.String?.sval)==="epoch")return `strftime('%s', ${this.visit(e.args[1],n)})`}let a=(e.args??[]).map(c=>this.visit(c,n));if(e.agg_star)return `${i}(*)`;if(e.agg_distinct)return `${i}(DISTINCT ${a.join(", ")})`;let l=Yc(i,this.functionResolution);if(l){if(l.sqliteExpr!==null){let c=l.sqliteExpr;return c.includes("(")?c:`${c}(${a.join(", ")})`}if(l.jsFn!==null){let c=Ho[i];if(c?.sqlite){let f=c.sqlite();return f.includes("(")?f:`${f}(${a.join(", ")})`}}}throw new N({FuncCall:e},`Function call "${i}" not supported`)}SQLValueFunction(e,n){switch(e.op){case "SVFOP_CURRENT_TIMESTAMP":return "datetime('now')";case "SVFOP_CURRENT_DATE":return "date('now')";case "SVFOP_CURRENT_TIME":return "time('now')";default:throw new N({SQLValueFunction:e},`SQLValueFunction "${e.op}" not supported`)}}ResTarget(e,n){if(e.indirection&&e.indirection.length>0)throw new N({ResTarget:e},"Indirections are not supported in SQLite");let r=[];return n.update&&e.name?(r.push(this.quoteIfNeeded(e.name)),r.push("="),e.val&&r.push(this.deparse(e.val,n))):n.insertColumns&&e.name?r.push(this.quoteIfNeeded(e.name)):(e.val&&r.push(this.deparse(e.val,n)),e.name&&r.push(this.Alias({aliasname:e.name},n))),r.join(" ")}A_Expr(e,n){if(["AEXPR_OP_ALL","AEXPR_OP_ANY"].includes(e.kind))throw new N({A_Expr:e},"ALL/ANY/SOME comparison operators are not supported. Use NOT EXISTS or IN instead");if(e.name&&e.name.length>0){if(e.name.length>1)throw new N({A_Expr:e},"Schema-qualified OPERATOR() syntax is not supported in SQLite");let r=e.name[0]?.String?.sval||e.name[0]?.String?.str;if(r){if(!e.lexpr||!e.rexpr)throw new N({A_Expr:e},"A_Expr missing left or right expression");if(!lh.includes(r.toUpperCase()))throw new N({A_Expr:e},`Operator "${r}" is not supported in SQLite`);if(r==="~~"||r==="~~*"){let s=this.visit(e.lexpr,n),i=this.visit(e.rexpr,n);return `${s} LIKE ${i}`}if(r==="!~~"||r==="!~~*"){let s=this.visit(e.lexpr,n),i=this.visit(e.rexpr,n);return `${s} NOT LIKE ${i}`}if(r==="~"||r==="~*"){let s=this.visit(e.lexpr,n),i=this.visit(e.rexpr,n);return `${s} GLOB ${i}`}}}return super.A_Expr(e,n)}IndexStmt(e,n){let r=["CREATE"];e.unique&&r.push("UNIQUE"),r.push("INDEX"),e.if_not_exists&&r.push("IF NOT EXISTS"),e.idxname&&r.push(Uo(e.idxname)),r.push("ON"),e.relation&&r.push(this.RangeVar(e.relation,n));let s=(e.indexParams??[]).map(i=>"IndexElem"in i?this.IndexElem(i.IndexElem,n):this.visit(i,n)).filter(Boolean);return r.push(`(${s.join(", ")})`),r.join(" ")}IndexElem(e,n){let r=[];return e.name?r.push(Uo(e.name)):e.expr&&r.push(`(${this.visit(e.expr,n)})`),e.ordering==="SORTBY_ASC"&&r.push("ASC"),e.ordering==="SORTBY_DESC"&&r.push("DESC"),e.nulls_ordering==="SORTBY_NULLS_FIRST"&&r.push("NULLS FIRST"),e.nulls_ordering==="SORTBY_NULLS_LAST"&&r.push("NULLS LAST"),r.join(" ")}TypeCast(e,n){if(!e.arg||!e.typeName)return super.TypeCast(e,n);if([...this.helper.walk(e)].filter(({node:o})=>"A_Star"in o).length>0)throw new N({TypeCast:e},"A.* in type casts are not supported in SQLite");if(e.typeName.arrayBounds&&e.typeName.arrayBounds.length>0){if("A_Const"in e.arg&&e.arg.A_Const.sval){let o=e.arg.A_Const.sval.sval;if(o.startsWith("{")&&o.endsWith("}")){let a=e.typeName.names?.map(u=>u.String?.sval).filter(Boolean)??[],l=a.length===2&&a[0]==="pg_catalog"?a[1]:a[0],f=["text","varchar","character varying","char","bpchar","name","uuid"].includes(l?.toLowerCase());try{let u=this.parsePgArrayLiteral(o,f);return `'${JSON.stringify(u).replace(/'/g,"''")}'`}catch{}}}return this.visit(e.arg,n)}let s=this.visit(e.arg,n),i=this.TypeName(e.typeName,n);return `CAST(${s} AS ${i})`}A_ArrayExpr(e,n){let r=Nn(e.elements),s=this.tryExtractStaticArray(r);return s!==void 0?`'${JSON.stringify(s).replace(/'/g,"''")}'`:`json_array(${r.map(o=>this.visit(o,n)).join(", ")})`}tryExtractStaticArray(e){let n=[];for(let r of e)if("A_ArrayExpr"in r){let s=Nn(r.A_ArrayExpr.elements),i=this.tryExtractStaticArray(s);if(i===void 0)return;n.push(i);}else if("A_Const"in r){let s=r.A_Const;if(s.isnull)n.push(null);else if(s.ival)n.push(s.ival.ival);else if(s.fval)n.push(parseFloat(s.fval.fval));else if(s.sval)n.push(s.sval.sval);else if("boolval"in s)n.push(s.boolval.boolval===true);else return}else return;return n}parsePgArrayLiteral(e,n){if(!e.startsWith("{")||!e.endsWith("}"))throw new Error("Not a PG array literal");let r=e.slice(1,-1);if(r.length===0)return [];let s=[],i=0;for(;i<r.length;)if(r[i]==="{"){let o=0,a=i;for(;a<r.length;){if(r[a]==="{")o++;else if(r[a]==="}"&&(o--,o===0))break;a++;}s.push(this.parsePgArrayLiteral(r.slice(i,a+1),n)),i=a+1,r[i]===","&&i++;}else if(r[i]==='"'){let o=i+1,a="";for(;o<r.length&&r[o]!=='"';)r[o]==="\\"&&o++,a+=r[o],o++;s.push(a),i=o+1,r[i]===","&&i++;}else {let o=i;for(;o<r.length&&r[o]!==","&&r[o]!=="}";)o++;if(o===i)throw new Error("Malformed PG array literal");let a=r.slice(i,o);if(a==="NULL")s.push(null);else if(n)s.push(a);else {let l=Number(a);s.push(isNaN(l)?a:l);}i=o,r[i]===","&&i++;}return s}BetweenExpr(e,n){return super.A_Expr(e,n)}AlterTableStmt(e,n){let r=e.cmds??[],s=["AT_EnableRowSecurity","AT_ForceRowSecurity"],i=r.filter(f=>"AlterTableCmd"in f&&!s.includes(f.AlterTableCmd.subtype));if(i.length===0)return "";if(!["OBJECT_TABLE","OBJECT_INDEX","OBJECT_VIEW"].includes(e.objtype))throw new N({AlterTableStmt:e},`AlterTableStmt with objtype ${e.objtype} is not supported`);let o=["AT_AddColumn","AT_DropColumn"],a=["AT_AlterColumnType","AT_SetNotNull","AT_DropNotNull","AT_ColumnDefault","AT_AddConstraint","AT_DropConstraint"],l=[],c=[];for(let f of i){let u=f.AlterTableCmd.subtype;if(o.includes(u)){let d={...e,cmds:[f]};l.push(super.AlterTableStmt(d,n));}else if(a.includes(u))c.push(f.AlterTableCmd);else throw new N({AlterTableStmt:e},`AlterTableCmd with subtype ${u} is not supported in SQLite`)}if(c.length>0){let f=this.getRelationName(e.relation);l.push(this.generateRebuildSql(f,c));}return l.join(`;
|
|
26
|
+
`)}AlterTableCmd(e,n){if(!["AT_AddColumn","AT_DropColumn"].includes(e.subtype))throw new N({AlterTableCmd:e},`AlterTableCmd with subtype ${e.subtype} is not supported`);return e.subtype==="AT_DropColumn"&&e.behavior?super.AlterTableCmd({...e,behavior:void 0},n):super.AlterTableCmd(e,n)}DefineStmt(e,n){if(e.kind==="OBJECT_AGGREGATE")throw new Error("AGGREGATE definitions are not supported in SQLite");return super.DefineStmt(e,n)}InsertStmt(e,n){if("selectStmt"in e){let s=(e.selectStmt?.SelectStmt?.valuesLists??[]).map(i=>i.List?.items?.map(o=>"SetToDefault"in o));if(s.length===1&&s[0]?.every(i=>i===true))return super.InsertStmt({...e,selectStmt:void 0,cols:void 0},n);if(s.some(i=>i.some(o=>o===true)))throw new N({InsertStmt:e},"Insert with partial DEFAULT values is not supported")}return super.InsertStmt(e,n)}SelectStmt(e,n){if(this.helper.hasUnsafeStar())throw new N({SelectStmt:e},"Row-wise comparison using .* is not supported in SQLite. Expand to explicit per-column comparisons instead.");if(e.intoClause)throw new N({SelectStmt:e},"SELECT ... INTO clause is not supported in SQLite");if(e.distinctClause){let s=Nn(e.distinctClause);if(s.length>0&&Object.keys(s[0]).length>0)throw new N({SelectStmt:e},"DISTINCT ON clause is not supported in SQLite. Use window functions instead.")}if(e.limitOffset&&!e.limitCount)throw new N({SelectStmt:e},"OFFSET without LIMIT is not supported in SQLite");let r=super.SelectStmt(e,n);if(/^SELECT\s+FROM/.test(r))throw new N({SelectStmt:e},"SELECT without a target list is not supported in SQLite");return r}JoinExpr(e,n){return e.alias&&this.Alias(e.alias,n),super.JoinExpr(e,n)}A_Const(e,n){if(e.bsval!==void 0)throw new N({A_Const:e},"Bit string literals are not supported in SQLite");let r=super.A_Const(e,n);return typeof r=="string"&&r.startsWith("E'")?r.substring(2,r.length-1):r}SortBy(e,n){if(e.sortby_dir==="SORTBY_USING"){let r=Nn(e.useOp),s=r[0]?.String?.sval;if(r.length>1||!["<",">"].includes(s??""))throw new N({SortBy:e},"Only `USING <` or `USING >` are supported.");e.sortby_dir=s==="<"?"SORTBY_DESC":"SORTBY_ASC",e.useOp=void 0;}return super.SortBy(e,n)}RangeSubselect(e,n){if(e.lateral)throw new N({RangeSubselect:e},"LATERAL subqueries are not supported in SQLite");return super.RangeSubselect(e,n)}SubLink(e,n){if(["ANY_SUBLINK","ALL_SUBLINK"].includes(e.subLinkType))throw new N({SubLink:e},"ANY/ALL/SOME subqueries are not supported. Use NOT EXISTS or IN instead");if(e.subLinkType==="ARRAY_SUBLINK")throw new N({SubLink:e},"ARRAY subqueries are not supported in SQLite");return super.SubLink(e,n)}LockingClause(e,n){return ""}UpdateStmt(e,n){if(n.parentNodeTypes.includes("SelectStmt"))throw new N({UpdateStmt:e},"UPDATE ... FROM (SELECT ...) is not supported in SQLite");return super.UpdateStmt(e,n)}Alias(e,n){if(e.colnames&&e.colnames.length>0)throw new N({Alias:e},"Aliasing with column names is not supported in SQLite");return `AS "${e.aliasname}"`}CreateFunctionStmt(e,n){let r=e.options??[],s=e.returnType?.names?.map(c=>c.String?.sval).filter(Boolean).join("."),i=r.find(c=>c.DefElem?.defname==="language")?.DefElem?.arg?.String?.sval;if(s!=="trigger"||i!=="plpgsql")throw new N({CreateFunctionStmt:e},"Only trigger functions with LANGUAGE plpgsql are supported");let o=e.funcname?.map(c=>c.String?.sval).filter(Boolean).pop();if(!o)throw new Error("Function has no name");let a=r.find(c=>c.DefElem?.defname==="as")?.DefElem?.arg?.List?.items?.[0]?.String?.sval;if(!a)throw new Error("Function has no body");let l=this.plpgsqlParser.parse(a);return this.triggerFunctions.set(o,l),""}CreateTrigStmt(e,n){let r=e.trigname,s=this.RangeVar(e.relation,n),i=e.funcname?.map(u=>u.String?.sval).filter(Boolean).pop();if(!i)throw new Error(`Trigger "${r}" has no function reference`);let o=this.triggerFunctions.get(i);if(!o)throw new N({CreateTrigStmt:e},`Trigger "${r}" references unknown function "${i}"`);let a=e.timing===2?"BEFORE":e.timing===64?"INSTEAD OF":"AFTER",l=[];if(e.events&4&&l.push("INSERT"),e.events&8&&l.push("DELETE"),e.events&16)if(e.columns?.length){let u=e.columns.map(d=>d.String?.sval).filter(Boolean);l.push(`UPDATE OF ${u.join(", ")}`);}else l.push("UPDATE");let c=l.join(" OR "),f=this.buildTriggerBody(o,s,n);return [`CREATE TRIGGER ${r}`,`${a} ${c} ON ${s}`,"FOR EACH ROW","BEGIN",...f.map(u=>` ${u};`),"END"].join(`
|
|
27
|
+
`)}buildTriggerBody(e,n,r){let s=[],i=[];for(let o of e.statements)if(o.type!=="return"){if(o.type==="assignment"){i.push(o);continue}i.length>0&&(s.push(this.buildAssignmentUpdate(i,n,r)),i.length=0),o.type==="dml"&&s.push(this.translateDml(o.sql,r));}return i.length>0&&s.push(this.buildAssignmentUpdate(i,n,r)),s}buildAssignmentUpdate(e,n,r){let s=e.map(i=>{let o=this.translateExpression(i.expression,r);return `${i.column} = ${o}`});return `UPDATE ${n} SET ${s.join(", ")} WHERE rowid = NEW.rowid`}translateExpression(e,n){try{let r=`SELECT ${e}`,s=e.trim().toLowerCase();return s==="now()"||s==="current_timestamp"?"datetime('now')":e}catch{return e}}translateDml(e,n){return e.replace(/\bnow\(\)/gi,"datetime('now')").replace(/\bcurrent_timestamp\b/gi,"datetime('now')").replace(/\bgen_random_uuid\(\)/gi,this.uuidExpression()).replace(/\buuid_generate_v4\(\)/gi,this.uuidExpression())}uuidExpression(){return "lower(hex(randomblob(4))) || '-' || lower(hex(randomblob(2))) || '-4' || substr(lower(hex(randomblob(2))),2) || '-' || substr('89ab',abs(random()) % 4 + 1, 1) || substr(lower(hex(randomblob(2))),2) || '-' || lower(hex(randomblob(6)))"}NullTest(e,n){if(e.arg?.ColumnRef?.fields?.length>1)throw new N({NullTest:e},"row-level NULL tests are not supported in SQLite");return super.NullTest(e,n)}RenameStmt(e,n){if(!e.renameType)throw new Error("RenameStmt requires renameType");let r=["OBJECT_TABLE","OBJECT_VIEW","OBJECT_COLUMN"];if(e.renameType==="OBJECT_COLUMN"&&(e.relationType==="OBJECT_FOREIGN_TABLE"||e.relationType==="OBJECT_VIEW"))throw new N({RenameStmt:e},`RenameStmt with relationType ${e.relationType} is not supported`);if(!r.includes(e.renameType))throw new N({RenameStmt:e},`RenameStmt with renameType ${e.renameType} is not supported in SQLite`);return super.RenameStmt(e,n)}DropStmt(e,n){let r=e.removeType;if(["OBJECT_TABLE","OBJECT_VIEW","OBJECT_INDEX","OBJECT_TRIGGER"].includes(r))return super.DropStmt(e,n);if(["OBJECT_POLICY"].includes(r))return "";throw new N({DropStmt:e},`DROP with removeType ${r} is not supported in SQLite`)}generateRebuildSql(e,n){if(!this.introspection)throw new Error(`ALTER TABLE on "${e}" requires 12-step rebuild but no introspection was provided. Pass introspection in DeparseOptions to enable column type changes, NOT NULL, defaults, and constraint modifications.`);let r=this.buildDesiredSchema(this.introspection,e,n),s=new pr,i=new mr,o=s.diff(this.introspection,r);return o.has_changes?i.plan(o,this.introspection,r).steps.filter(l=>!["disable_foreign_keys","begin_transaction","commit_transaction","enable_foreign_keys"].includes(l.type)).map(l=>l.sql).join(`
|
|
28
|
+
`):""}buildDesiredSchema(e,n,r){let s={...e,tables:e.tables.map(i=>({...i})),columns:e.columns.map(i=>({...i})),indexes:e.indexes.map(i=>({...i})),foreign_keys:e.foreign_keys.map(i=>({...i})),primary_keys:e.primary_keys.map(i=>({...i})),views:e.views.map(i=>({...i})),triggers:(e.triggers??[]).map(i=>({...i})),check_constraints:e.check_constraints.map(i=>({...i})),unique_constraints:(e.unique_constraints??[]).map(i=>({...i})),comments:(e.comments??[]).map(i=>({...i})),custom_types:e.custom_types.map(i=>({...i}))};for(let i of r){let o=s.columns.findIndex(a=>a.table===n&&a.name===i.name);switch(i.subtype){case "AT_AlterColumnType":{if(o===-1)break;let a=this.extractTypeName(i);a&&(s.columns[o]={...s.columns[o],type:a.toLowerCase()});break}case "AT_SetNotNull":{if(o===-1)break;s.columns[o]={...s.columns[o],nullable:false};break}case "AT_DropNotNull":{if(o===-1)break;s.columns[o]={...s.columns[o],nullable:true};break}case "AT_ColumnDefault":{if(o===-1)break;if(i.def){let a=this.extractDefaultValue(i);s.columns[o]={...s.columns[o],default_value:a};}else s.columns[o]={...s.columns[o],default_value:null};break}case "AT_AddConstraint":case "AT_DropConstraint":{let a=s.tables.findIndex(l=>l.name===n);a!==-1&&(s.tables[a]={...s.tables[a],sql:s.tables[a].sql+" /* modified */"});break}}}return this.rebuildTableSql(s,n),s}rebuildTableSql(e,n){let r=e.tables.findIndex(u=>u.name===n);if(r===-1)return;let s=e.columns.filter(u=>u.table===n),i=e.foreign_keys.filter(u=>u.table===n),o=e.check_constraints.filter(u=>u.table===n),a=s.map(u=>{let d=`${P(u.name)} ${u.type||"TEXT"}`;return u.is_primary_key&&(d+=" PRIMARY KEY"),u.nullable||(d+=" NOT NULL"),u.default_value!=null&&(d+=` DEFAULT ${u.default_value}`),d}),l=i.map(u=>`FOREIGN KEY (${P(u.column)}) REFERENCES ${P(u.ref_table)}(${P(u.ref_column)}) ON UPDATE ${u.on_update} ON DELETE ${u.on_delete}`),c=o.map(u=>`CHECK (${u.expression})`),f=[...a,...l,...c];e.tables[r]={...e.tables[r],sql:`CREATE TABLE ${P(n)} (${f.join(", ")}) STRICT`};}extractTypeName(e){let n=e.def?.ColumnDef;return n?.typeName?.TypeName?(n.typeName.TypeName.names??[]).map(s=>s.String?.sval).filter(Boolean).pop()??null:null}extractDefaultValue(e){return e.def?"Integer"in e.def?String(e.def.Integer.ival):"Float"in e.def?e.def.Float.fval:"String"in e.def?`'${e.def.String.sval}'`:null:null}};});var Qe,Un,eu=$(()=>{In();yr();Qe=class extends N{constructor(e,n){super(e,`Unsupported expression: ${n}`);}},Un=class{deparse(e){if("A_Const"in e){let s=e.A_Const;if(s.boolval!==void 0)return s.boolval.boolval?{}:{$always:false}}let n=Object.keys(e)[0],r=this[n];if(!r)throw new Qe({[n]:e},`Unsupported expression: ${n}`);return r.call(this,e[n])}deparseValue(e){if("A_Const"in e)return this.A_Const(e.A_Const);if("ColumnRef"in e)return this.ColumnRef(e.ColumnRef);if("FuncCall"in e)return this.FuncCall(e.FuncCall);if("SubLink"in e)return this.SubLink(e.SubLink);if("TypeCast"in e)return this.TypeCast(e.TypeCast);if("A_Expr"in e){let r=this.isJwtAccessor(e.A_Expr);return r||this.A_Expr(e.A_Expr)}if("BoolExpr"in e)return this.BoolExpr(e.BoolExpr);let n=Object.keys(e)[0];throw new Qe({[n]:e},`deparseValue: ${n}`)}A_Expr(e){if(e.kind==="AEXPR_OP"){let n=e.name?.[0],r=n?Is(n):void 0;if(!r)throw new Qe({A_Expr:e},"A_Expr missing operator");let s=this.isJwtAccessor(e);if(s)return {[s]:{}};let i=e.lexpr?this.deparseValue(e.lexpr):void 0,o=e.rexpr?this.deparseValue(e.rexpr):void 0,a=this.mapOperator(r);if(!a)throw new Qe({A_Expr:e},`Unsupported operator: ${r}`);let l=e.rexpr!=null&&"ColumnRef"in e.rexpr;if(typeof i=="string"&&i.startsWith("{{")&&l)return {[o]:{[a]:i}};let c=l&&typeof o=="string"?{$ref:o}:o;return {[i]:{[a]:c}}}if(e.kind==="AEXPR_LIKE"||e.kind==="AEXPR_ILIKE"){let n=e.lexpr?this.deparseValue(e.lexpr):void 0,r=e.rexpr?this.deparseValue(e.rexpr):void 0,i=(e.name?.[0]?Is(e.name[0]):"~~")==="!~~"?"$notLike":"$like";return {[n]:{[i]:r}}}if(e.kind==="AEXPR_IN"){let n=e.lexpr?this.deparseValue(e.lexpr):void 0,r=e.rexpr&&"List"in e.rexpr&&e.rexpr.List.items?e.rexpr.List.items.map(s=>this.deparseValue(s)):[];return {[n]:{$in:r}}}throw new Qe({A_Expr:e},`A_Expr kind: ${e.kind}`)}BoolExpr(e){let n=e.args??[];switch(e.boolop){case "AND_EXPR":return {$and:n.map(r=>this.deparse(r))};case "OR_EXPR":return {$or:n.map(r=>this.deparse(r))};case "NOT_EXPR":return {$not:this.deparse(n[0])};default:throw new Qe({BoolExpr:e},`BoolExpr op: ${e.boolop}`)}}NullTest(e){let n=e.arg?this.deparseValue(e.arg):void 0;return e.nulltesttype==="IS_NULL"?{[n]:{$is:null}}:{[n]:{$isNot:null}}}SubLink(e){if(e.subLinkType==="ANY_SUBLINK"){let n=e.testexpr?this.deparseValue(e.testexpr):void 0,r=e.subselect?this.SelectStmt(e.subselect.SelectStmt):void 0;return {[n]:{$in:r}}}if(e.subLinkType==="EXISTS_SUBLINK")return {$exists:e.subselect?this.SelectStmt(e.subselect.SelectStmt):void 0};if(e.subLinkType==="EXPR_SUBLINK"){let n=e.subselect?e.subselect.SelectStmt:void 0;if(n?.fromClause?.length)return this.SelectStmt(n);if(n?.targetList?.[0]){let r=n.targetList[0],s="ResTarget"in r?r.ResTarget:void 0;if(s?.val){let i=this.deparseValue(s.val);return i}}}throw new Qe({SubLink:e},`SubLink type: ${e.subLinkType}`)}SelectStmt(e){let{from:n,schema:r,join:s}=this.deparseFromClause(e.fromClause??[]),i=[];for(let d of e.targetList??[]){let p="ResTarget"in d?d.ResTarget:void 0;if(p?.val){let y=this.deparseValue(p.val);Array.isArray(y)?i.push(...y.map(String)):y!=null&&y!==""&&i.push(String(y));}}let o=e.whereClause?this.deparse(e.whereClause):void 0,a=this.deparseSortClause(e.sortClause),l=this.deparseLimit(e.limitCount),c=this.deparseLimit(e.limitOffset),f=this.deparseGroupClause(e.groupClause),u={type:"query",from:n,select:i};return r&&(u.schema=r),Object.keys(s).length>0&&(u.join=s),o&&(u.where=o),a.length>0&&(u.order=a),l!==void 0&&(u.limit=l),c!==void 0&&(u.offset=c),f.length>0&&(u.group=f),u}FuncCall(e){let n=this.isAuthFunc(e.funcname??[]);if(n)return n;throw new Qe({FuncCall:e},`FuncCall: ${Pn(e.funcname??[]).join(".")}`)}ColumnRef(e){let n=Pn(e.fields??[]);return n.length===1?n[0]:n.join(".")}A_Const(e){if(e.boolval!==void 0)return e.boolval.boolval;if(e.ival!==void 0)return e.ival.ival??0;if(e.fval!==void 0)return parseFloat(e.fval.fval??"0");if(e.sval!==void 0)return e.sval.sval??"";if(e.isnull)return null;throw new Qe({A_Const:e},"A_Const: unknown variant")}TypeCast(e){if(!e.arg)throw new Qe({TypeCast:e},"TypeCast: missing arg");return this.deparseValue(e.arg)}BooleanTest(e){let n=e.arg?this.deparseValue(e.arg):void 0;return e.booltesttype==="IS_TRUE"?{[n]:{$eq:true}}:{[n]:{$eq:false}}}deparseFromClause(e){let n={};if(e.length===0)return {from:"",join:n};let r=e[0];if("RangeVar"in r){let s=r.RangeVar;return {from:s.relname??"",schema:s.schemaname,join:n}}if("JoinExpr"in r){let{from:s,schema:i}=this.walkJoinExpr(r.JoinExpr,n);return {from:s,schema:i,join:n}}return {from:"",join:n}}walkJoinExpr(e,n){let r={from:""};if(e.larg)if("RangeVar"in e.larg){let s=e.larg.RangeVar;r={from:s.relname??"",schema:s.schemaname};}else "JoinExpr"in e.larg&&(r=this.walkJoinExpr(e.larg.JoinExpr,n));if(e.rarg&&"RangeVar"in e.rarg){let s=e.rarg.RangeVar,i=s.relname??"",o=s.alias?.aliasname??i,a=e.jointype==="JOIN_LEFT"?"left":"inner",l={from:i,type:a};e.quals&&(l.on=this.deparse(e.quals));let c=o;if(c in n){let f=2;for(;`${c}_${f}`in n;)f++;c=`${c}_${f}`;}n[c]=l;}return r}deparseSortClause(e){if(!e)return [];let n=[];for(let r of e){if(!("SortBy"in r))continue;let s=r.SortBy;if(!s.node)continue;let i=String(this.deparseValue(s.node)),o=s.sortby_dir==="SORTBY_DESC"?"desc":"asc",a={column:i,direction:o};s.sortby_nulls==="SORTBY_NULLS_FIRST"?a.nullsFirst=true:s.sortby_nulls==="SORTBY_NULLS_LAST"&&(a.nullsFirst=false),n.push(a);}return n}deparseLimit(e){if(!e)return;let n=this.deparseValue(e);return typeof n=="number"?n:Number(n)}deparseGroupClause(e){return e?e.map(n=>String(this.deparseValue(n))):[]}isAuthFunc(e){let n=Pn(e);if(n.length===2&&n[0]==="auth"){if(n[1]==="uid")return "{{auth.uid}}";if(n[1]==="jwt")return "{{auth.jwt}}";if(n[1]==="role")return "{{auth.role}}";throw new Error(`Unsupported auth function: "${n.slice(1).join(".")}"`)}return null}isJwtAccessor(e){if(e.kind!=="AEXPR_OP")return null;let n=e.name?.[0]?Is(e.name[0]):void 0;if(n!=="->"&&n!=="->>")return null;let r=e.rexpr&&"A_Const"in e.rexpr?e.rexpr.A_Const.sval?.sval:void 0;if(r===void 0)return null;if(e.lexpr&&"FuncCall"in e.lexpr)return this.isAuthFunc(e.lexpr.FuncCall.funcname??[])==="{{auth.jwt}}"?`{{auth.jwt.${r}}}`:null;if(e.lexpr&&"A_Expr"in e.lexpr){let s=this.isJwtAccessor(e.lexpr.A_Expr);if(s)return `${s.slice(0,-2)}.${r}}}`}return null}mapOperator(e){switch(e){case "=":return "$eq";case "<>":case "!=":return "$neq";case ">":return "$gt";case ">=":return "$gte";case "<":return "$lt";case "<=":return "$lte";case "~~":return "$like";case "!~~":return "$notLike";default:return}}};});var Gs,bh=$(()=>{Gs=class{table;schema;fields;constructor(e,n="public",r=new Map){this.table=e,this.schema=n,this.fields=r;}get(e){return this.fields.get(e)}has(e){return this.fields.has(e)}set(e,n){this.fields.set(e,n);}columns(){return Array.from(this.fields.keys())}all(){return Array.from(this.fields.values())}serializeRow(e){let n={};for(let[r,s]of Object.entries(e)){let i=this.fields.get(r);n[r]=i?i.serialize(s):s;}return n}deserializeRow(e){let n={};for(let[r,s]of Object.entries(e)){let i=this.fields.get(r);n[r]=i?i.deserialize(s):s;}return n}applyDefaults(e){let n={...e};for(let[r,s]of this.fields)!(r in n)&&s.context.defaultFn&&(n[r]=s.context.defaultFn());return n}};});var wh=$(()=>{Ft();Wi();Ko();Lc();Uc();tt();Mc();Fc();Bc();qc();Wc();Jc();Kc();Hc();zc();Gc();Vc();Qc();Xc();Zc();bh();});function Eh(t){let e=new Map;for(let n of t.stmts??[]){if(!n.stmt||!("CreateEnumStmt"in n.stmt))continue;let r=n.stmt.CreateEnumStmt,s=Pn(r.typeName??[]).join(".");if(!s||!r.vals)continue;let i=Pn(r.vals);e.set(s.toLowerCase(),i);}return e}function _h(t){let e=new Map;for(let n of t.stmts??[]){if(!n.stmt||!("VariableSetStmt"in n.stmt))continue;let r=n.stmt.VariableSetStmt,s=r.name,i=ah(r.args?.[0]??{});e.set(s,{value:i,local:r.is_local});}return e}function xh(t){let e=new Un,n=new Set,r=[];for(let s of t.stmts??[])if(s.stmt){if("CreatePolicyStmt"in s.stmt){let i=s.stmt.CreatePolicyStmt,o=i.table?.relname??"",a=i.table?.schemaname,l={select:"SELECT",insert:"INSERT",update:"UPDATE",delete:"DELETE"},c=i.cmd_name?l[i.cmd_name]??"ALL":"ALL",f=i.permissive===true,u=[],d=false;for(let b of i.roles??[])if("RoleSpec"in b){let m=b.RoleSpec;m.roletype==="ROLESPEC_PUBLIC"?m.location===-1&&(d=true):m.roletype==="ROLESPEC_CSTRING"&&m.rolename&&u.push(m.rolename);}if(d){let b=a?`${a}.${o}`:o,m=i.policy_name??"",w=`${b}::${m}`;Sh.has(w)||(Sh.add(w),console.warn(`[supalite] policy "${m}" on "${b}" has no TO clause \u2014 applies to all roles (PUBLIC). For clarity, prefer an explicit \`TO <role>\` clause (e.g. \`TO authenticated\`).`));}let p=i.qual?e.deparse(i.qual):void 0,y=i.with_check?e.deparse(i.with_check):void 0,h=new on({name:i.policy_name??"",table:o,schema:a,command:c,permissive:f,roles:u,using:p,withCheck:y});r.push(h);}if("AlterTableStmt"in s.stmt){let i=s.stmt.AlterTableStmt;if((i.cmds??[]).some(l=>"AlterTableCmd"in l&&(l.AlterTableCmd.subtype==="AT_EnableRowSecurity"||l.AlterTableCmd.subtype==="AT_ForceRowSecurity"))){let l=i.relation?.relname??"";n.add(l);}}}return {policies:r,tables:n}}function vh(t,e){let n=new Map;for(let r of t.stmts??[]){if(!r.stmt||!("CreateStmt"in r.stmt))continue;let s=r.stmt.CreateStmt,i=s.relation?.relname??"",o=s.relation?.schemaname??"public";if(!i)continue;let a=new Gs(i,o);for(let l of s.tableElts??[]){if(!("ColumnDef"in l))continue;let c=l.ColumnDef,f=c.colname;if(!f)continue;let u=c.typeName?.names?.map(I=>I.String?.sval||I.String?.str).filter(Boolean),d=u&&(u.length===2&&u[0]==="pg_catalog"?u[1]:u[0]);if(!d)continue;let p=!!c.typeName?.arrayBounds?.length,y=Array.isArray(c.typeName?.typmods)?c.typeName.typmods:[],h=I=>y[I]?.A_Const?.ival?.ival??y[I]?.A_Const?.val?.ival?.ival,b={isArray:p};if(Fo(d)&&y.length>0){let I=h(0);typeof I=="number"&&I>0&&(b.lengthConstraint=I);}if(Bo(d)&&y.length>=2){let I=h(0),ue=h(1);typeof I=="number"&&typeof ue=="number"&&I>0&&ue>=0&&(b.numericPrecision={precision:I,scale:ue});}let m=e.get(d.toLowerCase());m&&(b.enumValues=m);let w=Array.isArray(c.constraints)?c.constraints:[],_=w.some(I=>I.Constraint?.contype==="CONSTR_PRIMARY"),S=Mo(d)||w.some(I=>I.Constraint?.contype==="CONSTR_IDENTITY"),E=w.some(I=>I.Constraint?.contype==="CONSTR_NOTNULL"),C=w.find(I=>I.Constraint?.contype==="CONSTR_UNIQUE"),x=w.find(I=>I.Constraint?.contype==="CONSTR_GENERATED"),R=w.find(I=>I.Constraint?.contype==="CONSTR_FOREIGN"),v=w.find(I=>I.Constraint?.contype==="CONSTR_CHECK"),k;if(R){let I=R.Constraint,ue=I.pktable?.relname,Xe=I.pktable?.schemaname,Qs=I.pk_attrs?.[0]?.String?.sval;ue&&Qs&&(k={refSchema:Xe,refTable:ue,refColumn:Qs,constraintName:I.conname||void 0});}let z={schema:o,table:i,column:f,pgTypeName:d,nullable:!E&&!_,defaultValue:null,defaultFn:null,isPrimaryKey:_,isUnique:!!C,isSerial:S,isGenerated:!!x,fkRef:k,hasCheck:!!v,checkConstraintName:v?.Constraint?.conname||void 0,uniqueConstraintName:C?.Constraint?.conname||void 0};a.set(f,Ln(z,b));}n.set(`${o}.${i}`,a);}return n}function Ch(t){let e=[];for(let n of t.stmts??[]){if(!n.stmt||!("CreateStmt"in n.stmt))continue;let r=n.stmt.CreateStmt,s=r.relation?.relname??"",i=r.relation?.schemaname??"public";if(s)for(let o of r.tableElts??[]){if("ColumnDef"in o)continue;let a=o;if(!a.Constraint)continue;let l=a.Constraint,c=l.contype;if(c==="CONSTR_UNIQUE"){let f=(l.keys??[]).map(u=>u.String?.sval??u.String?.str).filter(Boolean);if(f.length===0)continue;e.push({schema:i,table:s,kind:"unique",name:l.conname||void 0,columns:f});}else if(c==="CONSTR_CHECK")e.push({schema:i,table:s,kind:"check",name:l.conname||void 0,columns:[]});else if(c==="CONSTR_FOREIGN"){let f=(l.fk_attrs??[]).map(p=>p.String?.sval??p.String?.str).filter(Boolean),u=(l.pk_attrs??[]).map(p=>p.String?.sval??p.String?.str).filter(Boolean),d=l.pktable?.relname;if(!d)continue;e.push({schema:i,table:s,kind:"foreign_key",name:l.conname||void 0,columns:f,refSchema:l.pktable?.schemaname,refTable:d,refColumns:u});}}}return e}function Rh(t){let e=[];for(let n of t.stmts??[]){if(!n.stmt||!("CommentStmt"in n.stmt))continue;let r=n.stmt.CommentStmt,s=r.comment??"";if(!s)continue;let i=r.objtype,o=(r.object?.List?.items??r.object?.items??[]).map(a=>a.String?.sval??a.String?.str).filter(Boolean);if(o.length!==0){if(i==="OBJECT_TABLE"||i==="OBJECT_VIEW"){let[a,l]=o.length>=2?o:["public",o[0]];e.push({schema:a,table:l,text:s});}else if(i==="OBJECT_COLUMN"){let a="public",l,c;o.length>=3?[a,l,c]=o:[l,c]=o,e.push({schema:a,table:l,column:c,text:s});}}}return e}var Sh,Th=$(()=>{eu();In();No();wh();yr();Sh=new Set;});var Oh={};xr(Oh,{Policy:()=>on,deparseDdl:()=>tu,deparseExpression:()=>N_,deparsePostgresDdl:()=>P_,deparseSelect:()=>I_,parse:()=>hr,parseExpression:()=>Ah,translatePostgresDdl:()=>kh});async function kh(t,e={}){let n=await hr(t);return tu(n,e).ddl}async function P_(t,e={}){let n=await hr(t);return {ast:n,...tu(n,e)}}function tu(t,e={}){let n=Eh(t),r=vh(t,n),s=_h(t),i=Ch(t),o=Rh(t),a=new zo(t,{...e,enums:n}),{policies:l,tables:c}=xh(t);if(e.strict)for(let f of l){if(!r.get(`${f.data.schema??"public"}.${f.data.table}`))throw new Error(`Policy "${f.data.name}" references unknown table "${f.data.table}"`);if(!c.has(f.data.table))throw new Error(`RLS is not enabled on table "${f.data.table}"`)}return {ddl:a.deparseQuery(),enums:n,rls:{tables:c,policies:l},schema:r,vars:s,tableConstraints:i,comments:o}}async function Ah(t){let n=(await hr(`SELECT 1 WHERE ${t}`)).stmts?.[0]?.stmt;if(!n||!("SelectStmt"in n))throw new Error("expected SelectStmt");let r=n.SelectStmt.whereClause;if(!r)throw new Error("no whereClause");return r}async function N_(t){let e=await Ah(t);return new Un().deparse(e)}async function I_(t){let n=(await hr(t)).stmts?.[0]?.stmt;if(!n||!("SelectStmt"in n))throw new Error("expected SelectStmt");return new Un().deparse(n)}var nu=$(()=>{oh();yh();eu();Th();No();});ee();function Su(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(s){return Object.getOwnPropertyDescriptor(t,s).enumerable})),n.push.apply(n,r);}return n}function Eu(t){for(var e=1;e<arguments.length;e++){var n=arguments[e]!=null?arguments[e]:{};e%2?Su(Object(n),true).forEach(function(r){Vg(t,r,n[r]);}):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(n)):Su(Object(n)).forEach(function(r){Object.defineProperty(t,r,Object.getOwnPropertyDescriptor(n,r));});}return t}function Vg(t,e,n){return e=Qg(e),e in t?Object.defineProperty(t,e,{value:n,enumerable:true,configurable:true,writable:true}):t[e]=n,t}function Qg(t){var e=Xg(t,"string");return typeof e=="symbol"?e:String(e)}function Xg(t,e){if(typeof t!="object"||t===null)return t;var n=t[Symbol.toPrimitive];if(n!==void 0){var r=n.call(t,e);if(typeof r!="object")return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return (e==="string"?String:Number)(t)}var Yg=_u({}),Le=Yg;function _u(t){return e.withOptions=n=>_u(Eu(Eu({},t),n)),e;function e(n,...r){let s=typeof n=="string"?[n]:n.raw,{alignValues:i=false,escapeSpecialCharacters:o=Array.isArray(n),trimWhitespace:a=true}=t,l="";for(let u=0;u<s.length;u++){let d=s[u];if(o&&(d=d.replace(/\\\n[ \t]*/g,"").replace(/\\`/g,"`").replace(/\\\$/g,"$").replace(/\\\{/g,"{")),l+=d,u<r.length){let p=i?Zg(r[u],l):r[u];l+=p;}}let c=l.split(`
|
|
29
|
+
`),f=null;for(let u of c){let d=u.match(/^(\s+)\S+/);if(d){let p=d[1].length;f?f=Math.min(f,p):f=p;}}if(f!==null){let u=f;l=c.map(d=>d[0]===" "||d[0]===" "?d.slice(u):d).join(`
|
|
30
|
+
`);}return a&&(l=l.trim()),o&&(l=l.replace(/\\n/g,`
|
|
31
|
+
`).replace(/\\t/g," ").replace(/\\r/g,"\r").replace(/\\v/g,"\v").replace(/\\b/g,"\b").replace(/\\f/g,"\f").replace(/\\0/g,"\0").replace(/\\x([\da-fA-F]{2})/g,(u,d)=>String.fromCharCode(parseInt(d,16))).replace(/\\u\{([\da-fA-F]{1,6})\}/g,(u,d)=>String.fromCodePoint(parseInt(d,16))).replace(/\\u([\da-fA-F]{4})/g,(u,d)=>String.fromCharCode(parseInt(d,16)))),typeof Bun<"u"&&(l=l.replace(/\\u(?:\{([\da-fA-F]{1,6})\}|([\da-fA-F]{4}))/g,(u,d,p)=>{var y;let h=(y=d??p)!==null&&y!==void 0?y:"";return String.fromCodePoint(parseInt(h,16))})),l}}function Zg(t,e){if(typeof t!="string"||!t.includes(`
|
|
32
|
+
`))return t;let r=e.slice(e.lastIndexOf(`
|
|
33
|
+
`)+1).match(/^(\s+)/);if(r){let s=r[1];return t.replace(/\n/g,`
|
|
34
|
+
${s}`)}return t}ee();var xu=[{name:"Self-hosted Logflare Configuration",link:"https://supabase.com/docs/reference/self-hosting-analytics/list-endpoints#getting-started"}],ai=["analytics"],vu=g.strictObject({enabled:g.boolean({default:false,description:"Enable the local Logflare service.",tags:ai,links:xu}),port:g.number({default:54327,description:"Port to the local Logflare service.",tags:ai}),vector_port:g.number({default:54328,description:"Port to the local syslog ingest service.",tags:ai}),backend:g.string({enum:["postgres","bigquery"],default:"postgres",description:Le`
|
|
25
35
|
Configure one of the supported backends:
|
|
26
36
|
|
|
27
37
|
- \`postgres\`
|
|
28
|
-
- \`bigquery\``,tags:
|
|
29
|
-
Client secret for the ${
|
|
38
|
+
- \`bigquery\``,tags:ai,links:xu})}).partial();ee();var ey=Symbol.for("lite-only"),Ht=t=>(Object.defineProperty(t,ey,{value:true,enumerable:false,writable:false,configurable:false}),t);var at=[{name:"PostgREST configuration",link:"https://postgrest.org/en/stable/configuration.html"}],Ke=["api"],Cu=g.strictObject({enabled:g.boolean({default:true,description:"Enable the local PostgREST service.",tags:Ke,links:at}),port:g.number({default:54321,description:"Port to use for the API URL.",tags:Ke,links:at}),schemas:g.array(g.string({description:"Schemas to expose in your API. Tables, views and functions in this schema will get API endpoints. `public` and `storage` are always included.",tags:Ke,links:at}),{default:["public","storage","graphql_public"]}),extra_search_path:g.array(g.string({description:"Extra schemas to add to the search_path of every request. public is always included.",tags:Ke,links:at}),{default:["public","extensions"]}),max_rows:g.number({default:1e3,description:"The maximum number of rows returned from a view, table, or stored procedure. Limits payload size for accidental or malicious requests.",tags:Ke,links:at}),pg_safe_update:g.boolean({default:false,description:"Require a WHERE clause on UPDATE and DELETE requests. Equivalent to pg_safe_update extension.",tags:Ke,links:at}),plan_enabled:Ht(g.boolean({default:false,description:"Enable the EXPLAIN plan feature via `Accept: application/vnd.pgrst.plan`. Disabled by default to match PostgREST's `db-plan-enabled` setting.",tags:Ke,links:at})),aggregates_enabled:Ht(g.boolean({default:false,description:"Enable aggregate functions (count(), sum(), avg(), min(), max()) in select. Disabled by default to match PostgREST's `db-aggregates-enabled` setting.",tags:Ke,links:at})),limited_mutations_enabled:Ht(g.boolean({default:false,description:"Honor `?limit`, `?offset`, and `?order` on UPDATE/DELETE via subquery. Disabled by default to match PostgREST's silent-ignore behavior.",tags:Ke,links:at})),anonymous_enabled:Ht(g.boolean({default:true,description:"Allow requests without an Authorization header. When false, unauthenticated requests receive 401 PGRST302 'Anonymous access is disabled'. Mirrors PostgREST's `db-anon-role`.",tags:Ke,links:at})),tls:g.strictObject({enabled:g.boolean({default:false,description:"Enable TLS for the local PostgREST service.",tags:Ke})}).partial(),external_url:g.string({default:"http://127.0.0.1:54321",description:"External URL for accessing the API server.",tags:Ke})}).partial();ee();ee();var un=["auth"],fn={auth:{name:"Auth Server configuration",link:"https://supabase.com/docs/reference/auth"}},Tr=(t,e)=>g.strictObject({subject:g.string({default:e,description:`The subject of the ${t} email.`}),content_path:g.string({description:`The path to the content of the ${t} email.`})}).partial(),Ru=g.strictObject({enable_signup:g.boolean({default:true,description:"Allow/disallow new user signups via email to your project.",tags:un,links:[fn.auth]}),double_confirm_changes:g.boolean({default:true,description:"If enabled, a user will be required to confirm any email change on both the old, and new email addresses. If disabled, only the new email is required to confirm.",tags:un,links:[fn.auth]}),enable_confirmations:g.boolean({default:false,description:"If enabled, users need to confirm their email address before signing in.",tags:un,links:[fn.auth]}),secure_password_change:g.boolean({default:false,description:"If enabled, users will need to reauthenticate or have logged in recently to change their password.",tags:un,links:[fn.auth]}),max_frequency:g.string({default:"1s",description:"Controls the minimum amount of time that must pass before sending another signup confirmation or password reset email.",tags:un,links:[fn.auth]}),smtp:g.strictObject({host:g.string({default:"inbucket",description:"Hostname or IP address of the SMTP server."}),port:g.number({default:2500,description:"Port number of the SMTP server."}),user:g.string({description:"Username for authenticating with the SMTP server."}),pass:g.string({description:"Password for authenticating with the SMTP server."}),admin_email:g.string({default:"admin@email.com",description:"Email used as the sender for emails sent from the application."}),sender_name:g.string({description:"Display name used as the sender for emails sent from the application."})}).partial(),template:g.strictObject({invite:Tr("invite","You have been invited"),confirmation:Tr("confirmation","Confirm Your Signup"),recovery:Tr("recovery","Reset Your Password"),magic_link:Tr("magic link","Your Magic Link"),email_change:Tr("email change","Confirm Email Change")}).partial(),otp_length:g.number({default:6,description:"Number of characters used in the email OTP.",tags:un,links:[fn.auth]}),otp_expiry:g.number({default:3600,description:"Number of seconds before the email OTP expires (defaults to 1 hour).",tags:un,links:[fn.auth]})}).partial();ee();var li=["auth"],la=(t,e)=>({name:t,link:`https://supabase.com/docs/guides/auth/auth-hooks/${e}`}),kr=(t,e)=>g.strictObject({enabled:g.boolean({default:false,description:`Enable/disable the ${t.toLowerCase()}.`,tags:li,links:[la(t,e)]}),uri:g.string({description:"The URI of the postgres function or HTTP endpoint to call.",tags:li,links:[la(t,e)]}),secrets:g.array(g.string({description:"A secret to pass to the function or endpoint.",tags:li}),{description:"The secrets to pass to the postgres function or HTTP endpoint.",tags:li,links:[la(t,e)]})}).partial(),Tu=g.strictObject({mfa_verification_attempt:kr("MFA Verification Hook","mfa-verification-hook"),password_verification_attempt:kr("Password Verification Hook","password-verification-hook"),custom_access_token:kr("Custom Access Token Hook","custom-access-token-hook"),send_sms:kr("Send SMS Hook","send-sms-hook"),send_email:kr("Send Email Hook","send-email-hook")}).partial();ee();var zt=["auth"],Gt={mfa:{name:"Multi-Factor Authentication",link:"https://supabase.com/docs/guides/auth/auth-mfa"},totp:{name:"Multi-Factor Authentication (TOTP)",link:"https://supabase.com/docs/guides/auth/auth-mfa/totp"},phone:{name:"Multi-Factor Authentication (Phone)",link:"https://supabase.com/docs/guides/auth/auth-mfa/phone"}},ku=g.strictObject({totp:g.strictObject({enroll_enabled:g.boolean({default:true,description:"Allow/disallow TOTP enrollment for users.",tags:zt,links:[Gt.totp]}),verify_enabled:g.boolean({default:true,description:"Allow/disallow TOTP verification for users.",tags:zt,links:[Gt.totp]})}).partial(),phone:g.strictObject({enroll_enabled:g.boolean({default:false,description:"Allow/disallow phone enrollment for users.",tags:zt,links:[Gt.phone]}),verify_enabled:g.boolean({default:false,description:"Allow/disallow phone verification for users.",tags:zt,links:[Gt.phone]}),otp_length:g.number({default:6,description:"The length of the OTP code.",tags:zt,links:[Gt.phone]}),template:g.string({default:"Your code is {{ .Code }}",description:"The template to use for the phone message.",tags:zt,links:[Gt.phone]}),max_frequency:g.string({default:"60s",description:"The maximum frequency of the phone messages.",tags:zt,links:[Gt.phone]})}).partial(),max_enrolled_factors:g.number({default:10,description:"The maximum number of MFA factors a user can enroll in.",tags:zt,links:[Gt.mfa]})}).partial();ee();ee();var ca=class extends aa{},Et=t=>new ca(t);var Bn=["auth"],de=t=>{let e=[{name:`Login with ${t.name}`,link:`https://supabase.com/docs/guides/auth/social-login/auth-${t.id}`}];return g.strictObject({enabled:g.boolean({default:false,description:`Use the ${t.name} OAuth provider.`,tags:Bn,links:e}),client_id:g.string({description:`Client ID for the ${t.name} OAuth provider.`,tags:Bn,links:e}),secret:Et({default:`env(SUPABASE_AUTH_EXTERNAL_${t.id.toUpperCase()}_SECRET)`,description:Le`
|
|
39
|
+
Client secret for the ${t.name} OAuth provider.
|
|
30
40
|
|
|
31
41
|
DO NOT commit your OAuth provider secret to git. Use environment variable substitution instead.
|
|
32
|
-
`,tags:kr,links:e}),url:E.string({description:"The base URL used for constructing the URLs to request authorization and access tokens.",...s.url,tags:kr,links:e}),redirect_uri:E.string({description:`The URI the ${s.name} OAuth2 provider will redirect to with the code and state values.`,tags:kr,links:e}),skip_nonce_check:E.boolean({default:false,description:"If true, the nonce check will be skipped.",tags:kr,links:e})}).partial()},Vu=E.strictObject({apple:fe({id:"apple",name:"Apple"}),azure:fe({id:"azure",name:"Azure"}),bitbucket:fe({id:"bitbucket",name:"Bitbucket"}),discord:fe({id:"discord",name:"Discord"}),facebook:fe({id:"facebook",name:"Facebook"}),github:fe({id:"github",name:"GitHub"}),gitlab:fe({id:"gitlab",name:"Gitlab",url:{default:"https://gitlab.com"}}),google:fe({id:"google",name:"Google"}),kakao:fe({id:"kakao",name:"Kakao"}),keycloak:fe({id:"keycloak",name:"Keycloak",url:{examples:["https://keycloak.example.com/realms/myrealm"]}}),linkedin:fe({id:"linkedin",name:"LinkedIn"}),notion:fe({id:"notion",name:"Notion"}),twitch:fe({id:"twitch",name:"Twitch"}),twitter:fe({id:"twitter",name:"Twitter"}),slack:fe({id:"slack",name:"Slack"}),spotify:fe({id:"spotify",name:"Spotify"}),workos:fe({id:"workos",name:"WorkOS"}),zoom:fe({id:"zoom",name:"Zoom"})}).partial();var Ka=["auth"],Ya=[{name:"User sessions",link:"https://supabase.com/docs/guides/auth/sessions"}],Ku=E.strictObject({timebox:E.string({description:"The timebox for the user session.",tags:Ka,links:Ya}),inactivity_timeout:E.string({description:"The inactivity timeout for the user session.",tags:Ka,links:Ya}),single_per_user:E.boolean({default:false,description:"Limit each user to one active refreshable session.",tags:Ka,links:Ya})}).partial();var te=["auth"],ne={auth:{name:"Auth Server configuration",link:"https://supabase.com/docs/reference/auth"},phoneLogin:s=>({name:`Enabling Phone Login (${s})`,link:`https://supabase.com/docs/guides/auth/phone-login?showSmsProvider=${s}#enabling-phone-login`})},Yu=E.strictObject({enable_signup:E.boolean({default:true,description:"Allow/disallow new user signups via SMS to your project.",tags:te,links:[ne.auth]}),enable_confirmations:E.boolean({default:false,description:"If enabled, users need to confirm their phone number before signing in.",tags:te,links:[ne.auth]}),template:E.string({default:"Your code is {{ .Code }}",description:"The template to use for the SMS message.",tags:te,links:[ne.auth]}),max_frequency:E.string({default:"60s",description:"Controls the minimum amount of time that must pass before sending another sms otp.",tags:te}),twilio:E.strictObject({enabled:E.boolean({default:false,description:"Enable/disable Twilio provider for phone login.",tags:te,links:[ne.phoneLogin("Twilio")]}),account_sid:E.string({description:"The account SID for the Twilio API.",tags:te,links:[ne.phoneLogin("Twilio")]}),message_service_sid:E.string({description:"The message service SID for the Twilio API.",tags:te,links:[ne.phoneLogin("Twilio")]}),auth_token:E.string({description:"The auth token for the Twilio API.",tags:te,links:[ne.phoneLogin("Twilio")]})}).partial(),twilio_verify:E.strictObject({enabled:E.boolean({default:false,description:"Enable/disable Twilio Verify provider for phone verification.",tags:te,links:[ne.phoneLogin("Twilio")]}),account_sid:E.string({description:"The account SID for the Twilio API.",tags:te,links:[ne.phoneLogin("Twilio")]}),message_service_sid:E.string({description:"The message service SID for the Twilio API.",tags:te,links:[ne.phoneLogin("Twilio")]}),auth_token:E.string({description:"The auth token for the Twilio API.",tags:te,links:[ne.phoneLogin("Twilio")]})}).partial(),messagebird:E.strictObject({enabled:E.boolean({default:false,description:"Enable/disable MessageBird provider for phone login.",tags:te,links:[ne.phoneLogin("MessageBird")]}),originator:E.string({description:"The originator of the SMS message.",tags:te,links:[ne.phoneLogin("MessageBird")]}),api_key:E.string({description:"The API key for the MessageBird API.",tags:te,links:[ne.phoneLogin("MessageBird")]})}).partial(),textlocal:E.strictObject({enabled:E.boolean({default:false,description:"Enable/disable Textlocal provider for phone login.",tags:te,links:[ne.phoneLogin("Textlocal%2520(Community%2520Supported)")]}),sender:E.string({description:"The sender of the SMS message.",tags:te,links:[ne.phoneLogin("Textlocal%2520(Community%2520Supported)")]}),api_key:E.string({description:"The API key for the Textlocal API.",tags:te,links:[ne.phoneLogin("Textlocal%2520(Community%2520Supported)")]})}).partial(),vonage:E.strictObject({enabled:E.boolean({default:false,description:"Enable/disable Vonage provider for phone login.",tags:te,links:[ne.phoneLogin("Vonage")]}),from:E.string({description:"The sender of the SMS message.",tags:te,links:[ne.phoneLogin("Vonage")]}),api_key:E.string({description:"The API key for the Vonage API.",tags:te,links:[ne.phoneLogin("Vonage")]}),api_secret:E.string({description:"The API secret for the Vonage API.",tags:te,links:[ne.phoneLogin("Vonage")]})}).partial(),test_otp:E.record(E.string(),{description:"Use pre-defined map of phone number to OTP for testing.",tags:te,links:[ne.auth]})}).partial();var Ue=["auth"],Ge={auth:{name:"Auth Server configuration",link:"https://supabase.com/docs/reference/auth"}},zu=["letters_digits","lower_upper_letters_digits","lower_upper_letters_digits_symbols"],Xu=E.strictObject({enabled:E.boolean({default:true,description:"Enable the local GoTrue service.",tags:Ue,links:[Ge.auth]}),jwt_secret:E.string({default:"unsafe-secret-change-me",description:"The secret used to sign JWT tokens.",tags:Ue,links:[Ge.auth]}),site_url:E.string({default:"http://localhost:3000",description:"The base URL of your website. Used as an allow-list for redirects and for constructing URLs used in emails.",tags:Ue,links:[Ge.auth]}),additional_redirect_urls:E.array(E.string({description:"A URL that auth providers are permitted to redirect to.",tags:Ue}),{default:["https://localhost:3000"],description:"A list of _exact_ URLs that auth providers are permitted to redirect to post authentication.",tags:Ue,links:[Ge.auth]}),jwt_expiry:E.number({default:3600,description:"How long tokens are valid for, in seconds. Defaults to 3600 (1 hour), maximum 604,800 seconds (one week).",tags:Ue,links:[Ge.auth]}),enable_refresh_token_rotation:E.boolean({default:true,description:"If disabled, the refresh token will never expire.",tags:Ue,links:[Ge.auth]}),refresh_token_reuse_interval:E.number({default:10,description:"Allows refresh tokens to be reused after expiry, up to the specified interval in seconds. Requires enable_refresh_token_rotation = true.",tags:Ue,links:[Ge.auth]}),enable_manual_linking:E.boolean({default:false,description:"Allow/disallow testing manual linking of accounts.",tags:Ue,links:[Ge.auth]}),enable_signup:E.boolean({default:true,description:"Allow/disallow new user signups to your project.",tags:Ue,links:[Ge.auth]}),enable_anonymous_sign_ins:E.boolean({default:false,description:"Allow/disallow anonymous sign-ins to your project.",tags:Ue,links:[Ge.auth]}),minimum_password_length:E.number({default:6,description:"Passwords shorter than this value will be rejected as weak. Minimum 6, recommended 8 or more.",tags:Ue,links:[Ge.auth]}),password_requirements:E.string({description:`Passwords that do not meet the following requirements will be rejected as weak. Supported values are: ${zu.join(", ")}`,enum:["",...zu],tags:Ue,links:[Ge.auth]}),hook:Hu,mfa:Gu,sessions:Ku,email:Wu,sms:Yu,external:Vu}).partial();var ar={postgres:{name:"PostgreSQL configuration",link:"https://postgrest.org/en/stable/configuration.html"},pgbouncer:s=>({name:"PgBouncer Configuration",link:`https://www.pgbouncer.org/config.html${s?`#${s}`:""}`})},Re=["database"],Qu=E.object({driver:Jt(E.string({enum:["sqlite","sqlite-postgres","pglite","postgres"],default:"sqlite",description:"The database driver to use.",tags:Re})),url:Jt(E.string({description:"Path to the database file/directory (Supalite only).",tags:Re})),port:E.number({default:54322,description:"Port to use for the local database URL.",tags:Re,links:[ar.postgres]}),shadow_port:E.number({default:54320,description:"Port to use for the local shadow database.",tags:Re}),major_version:E.number({default:15,description:"The database major version to use. This has to be the same as your remote database's. Run `SHOW server_version;` on the remote database to check.",tags:Re,links:[ar.postgres]}),pooler:E.object({enabled:E.boolean({default:false,description:"Enable the local PgBouncer service.",tags:Re,links:[ar.pgbouncer()]}),port:E.number({default:54329,description:"Port to use for the local connection pooler.",tags:Re,links:[ar.pgbouncer("listen_port")]}),pool_mode:E.string({enum:["transaction","session"],default:"transaction",description:"Specifies when a server connection can be reused by other clients. Configure one of the supported pooler modes: `transaction`, `session`.",tags:Re,links:[ar.pgbouncer("pool_mode")]}),default_pool_size:E.number({default:20,description:"How many server connections to allow per user/database pair.",tags:Re,links:[ar.pgbouncer("default_pool_size")]}),max_client_conn:E.number({default:100,description:"Maximum number of client connections allowed.",tags:Re,links:[ar.pgbouncer("max_client_conn")]})}).partial(),seed:E.strictObject({enabled:E.boolean({default:true,description:"Enable seeding the database with SQL files.",tags:Re}),sql_paths:E.array(E.string({description:"Path to a SQL file to seed the database with.",tags:Re}),{default:["./seed.sql"],description:"Paths to SQL files to seed the database with. Supports glob patterns relative to supabase directory.",examples:[["./seeds/*.sql","../project-src/seeds/*-load-testing.sql"]],tags:Re})}).partial(),migrations:E.strictObject({enabled:E.boolean({default:true,description:"Enable migrations.",tags:Re}),schema_paths:E.array(E.string({description:"Path to a SQL file to seed the database with.",tags:Re}),{default:["./schemas/schema.sql"]})}).partial()}).partial();var za=["edge-functions"],Zu=E.strictObject({enabled:E.boolean({default:true,description:"Enable the local Edge Runtime service.",tags:za}),policy:E.string({enum:["oneshot","per_worker"],default:"oneshot",description:"Configure the supported request policy. Use `oneshot` for hot reload, or `per_worker` for load testing.",tags:za}),inspector_port:E.number({default:8083,description:"Port to run the Edge Functions inspector on.",tags:za})}).partial();var ys=["experimental"],ec=E.strictObject({orioledb_version:E.string({description:"Postgres storage engine to use OrioleDB (S3)",tags:ys}),s3_host:bt({description:"S3 bucket URL.",examples:["<bucket_name>.s3-<region>.amazonaws.com"],default:"env(S3_HOST)",tags:ys}),s3_region:bt({description:"S3 bucket region.",examples:["us-east-1"],default:"env(S3_REGION)",tags:ys}),s3_access_key:bt({description:"S3 access key.",default:"env(S3_ACCESS_KEY)",tags:ys}),s3_secret_key:bt({description:"S3 secret key.",default:"env(S3_SECRET_KEY)",tags:ys})}).partial();var Qn=["functions"],Zn=[{name:"`supabase functions` CLI subcommands",link:"https://supabase.com/docs/reference/cli/supabase-functions"}],eg=Lr({enabled:hs({default:true,description:xe`
|
|
42
|
+
`,tags:Bn,links:e}),url:g.string({description:"The base URL used for constructing the URLs to request authorization and access tokens.",...t.url,tags:Bn,links:e}),redirect_uri:g.string({description:`The URI the ${t.name} OAuth2 provider will redirect to with the code and state values.`,tags:Bn,links:e}),skip_nonce_check:g.boolean({default:false,description:"If true, the nonce check will be skipped.",tags:Bn,links:e})}).partial()},Au=g.strictObject({apple:de({id:"apple",name:"Apple"}),azure:de({id:"azure",name:"Azure"}),bitbucket:de({id:"bitbucket",name:"Bitbucket"}),discord:de({id:"discord",name:"Discord"}),facebook:de({id:"facebook",name:"Facebook"}),github:de({id:"github",name:"GitHub"}),gitlab:de({id:"gitlab",name:"Gitlab",url:{default:"https://gitlab.com"}}),google:de({id:"google",name:"Google"}),kakao:de({id:"kakao",name:"Kakao"}),keycloak:de({id:"keycloak",name:"Keycloak",url:{examples:["https://keycloak.example.com/realms/myrealm"]}}),linkedin:de({id:"linkedin",name:"LinkedIn"}),notion:de({id:"notion",name:"Notion"}),twitch:de({id:"twitch",name:"Twitch"}),twitter:de({id:"twitter",name:"Twitter"}),slack:de({id:"slack",name:"Slack"}),spotify:de({id:"spotify",name:"Spotify"}),workos:de({id:"workos",name:"WorkOS"}),zoom:de({id:"zoom",name:"Zoom"})}).partial();ee();var ua=["auth"],fa=[{name:"User sessions",link:"https://supabase.com/docs/guides/auth/sessions"}],Ou=g.strictObject({timebox:g.string({description:"The timebox for the user session.",tags:ua,links:fa}),inactivity_timeout:g.string({description:"The inactivity timeout for the user session.",tags:ua,links:fa}),single_per_user:g.boolean({default:false,description:"Limit each user to one active refreshable session.",tags:ua,links:fa})}).partial();ee();var te=["auth"],se={auth:{name:"Auth Server configuration",link:"https://supabase.com/docs/reference/auth"},phoneLogin:t=>({name:`Enabling Phone Login (${t})`,link:`https://supabase.com/docs/guides/auth/phone-login?showSmsProvider=${t}#enabling-phone-login`})},$u=g.strictObject({enable_signup:g.boolean({default:true,description:"Allow/disallow new user signups via SMS to your project.",tags:te,links:[se.auth]}),enable_confirmations:g.boolean({default:false,description:"If enabled, users need to confirm their phone number before signing in.",tags:te,links:[se.auth]}),template:g.string({default:"Your code is {{ .Code }}",description:"The template to use for the SMS message.",tags:te,links:[se.auth]}),max_frequency:g.string({default:"60s",description:"Controls the minimum amount of time that must pass before sending another sms otp.",tags:te}),twilio:g.strictObject({enabled:g.boolean({default:false,description:"Enable/disable Twilio provider for phone login.",tags:te,links:[se.phoneLogin("Twilio")]}),account_sid:g.string({description:"The account SID for the Twilio API.",tags:te,links:[se.phoneLogin("Twilio")]}),message_service_sid:g.string({description:"The message service SID for the Twilio API.",tags:te,links:[se.phoneLogin("Twilio")]}),auth_token:g.string({description:"The auth token for the Twilio API.",tags:te,links:[se.phoneLogin("Twilio")]})}).partial(),twilio_verify:g.strictObject({enabled:g.boolean({default:false,description:"Enable/disable Twilio Verify provider for phone verification.",tags:te,links:[se.phoneLogin("Twilio")]}),account_sid:g.string({description:"The account SID for the Twilio API.",tags:te,links:[se.phoneLogin("Twilio")]}),message_service_sid:g.string({description:"The message service SID for the Twilio API.",tags:te,links:[se.phoneLogin("Twilio")]}),auth_token:g.string({description:"The auth token for the Twilio API.",tags:te,links:[se.phoneLogin("Twilio")]})}).partial(),messagebird:g.strictObject({enabled:g.boolean({default:false,description:"Enable/disable MessageBird provider for phone login.",tags:te,links:[se.phoneLogin("MessageBird")]}),originator:g.string({description:"The originator of the SMS message.",tags:te,links:[se.phoneLogin("MessageBird")]}),api_key:g.string({description:"The API key for the MessageBird API.",tags:te,links:[se.phoneLogin("MessageBird")]})}).partial(),textlocal:g.strictObject({enabled:g.boolean({default:false,description:"Enable/disable Textlocal provider for phone login.",tags:te,links:[se.phoneLogin("Textlocal%2520(Community%2520Supported)")]}),sender:g.string({description:"The sender of the SMS message.",tags:te,links:[se.phoneLogin("Textlocal%2520(Community%2520Supported)")]}),api_key:g.string({description:"The API key for the Textlocal API.",tags:te,links:[se.phoneLogin("Textlocal%2520(Community%2520Supported)")]})}).partial(),vonage:g.strictObject({enabled:g.boolean({default:false,description:"Enable/disable Vonage provider for phone login.",tags:te,links:[se.phoneLogin("Vonage")]}),from:g.string({description:"The sender of the SMS message.",tags:te,links:[se.phoneLogin("Vonage")]}),api_key:g.string({description:"The API key for the Vonage API.",tags:te,links:[se.phoneLogin("Vonage")]}),api_secret:g.string({description:"The API secret for the Vonage API.",tags:te,links:[se.phoneLogin("Vonage")]})}).partial(),test_otp:g.record(g.string(),{description:"Use pre-defined map of phone number to OTP for testing.",tags:te,links:[se.auth]})}).partial();var Ue=["auth"],He={auth:{name:"Auth Server configuration",link:"https://supabase.com/docs/reference/auth"}},Pu=["letters_digits","lower_upper_letters_digits","lower_upper_letters_digits_symbols"],Nu=g.strictObject({enabled:g.boolean({default:true,description:"Enable the local GoTrue service.",tags:Ue,links:[He.auth]}),jwt_secret:g.string({default:"unsafe-secret-change-me",description:"The secret used to sign JWT tokens.",tags:Ue,links:[He.auth]}),site_url:g.string({default:"http://localhost:3000",description:"The base URL of your website. Used as an allow-list for redirects and for constructing URLs used in emails.",tags:Ue,links:[He.auth]}),additional_redirect_urls:g.array(g.string({description:"A URL that auth providers are permitted to redirect to.",tags:Ue}),{default:["https://localhost:3000"],description:"A list of _exact_ URLs that auth providers are permitted to redirect to post authentication.",tags:Ue,links:[He.auth]}),jwt_expiry:g.number({default:3600,description:"How long tokens are valid for, in seconds. Defaults to 3600 (1 hour), maximum 604,800 seconds (one week).",tags:Ue,links:[He.auth]}),enable_refresh_token_rotation:g.boolean({default:true,description:"If disabled, the refresh token will never expire.",tags:Ue,links:[He.auth]}),refresh_token_reuse_interval:g.number({default:10,description:"Allows refresh tokens to be reused after expiry, up to the specified interval in seconds. Requires enable_refresh_token_rotation = true.",tags:Ue,links:[He.auth]}),enable_manual_linking:g.boolean({default:false,description:"Allow/disallow testing manual linking of accounts.",tags:Ue,links:[He.auth]}),enable_signup:g.boolean({default:true,description:"Allow/disallow new user signups to your project.",tags:Ue,links:[He.auth]}),enable_anonymous_sign_ins:g.boolean({default:false,description:"Allow/disallow anonymous sign-ins to your project.",tags:Ue,links:[He.auth]}),minimum_password_length:g.number({default:6,description:"Passwords shorter than this value will be rejected as weak. Minimum 6, recommended 8 or more.",tags:Ue,links:[He.auth]}),password_requirements:g.string({description:`Passwords that do not meet the following requirements will be rejected as weak. Supported values are: ${Pu.join(", ")}`,enum:["",...Pu],tags:Ue,links:[He.auth]}),hook:Tu,mfa:ku,sessions:Ou,email:Ru,sms:$u,external:Au}).partial();ee();var dn={postgres:{name:"PostgreSQL configuration",link:"https://postgrest.org/en/stable/configuration.html"},pgbouncer:t=>({name:"PgBouncer Configuration",link:`https://www.pgbouncer.org/config.html${t?`#${t}`:""}`})},Ce=["database"],Iu=g.object({driver:Ht(g.string({enum:["sqlite","sqlite-postgres","pglite","postgres"],default:"sqlite",description:"The database driver to use.",tags:Ce})),url:Ht(g.string({description:"Path to the database file/directory (Supalite only).",tags:Ce})),port:g.number({default:54322,description:"Port to use for the local database URL.",tags:Ce,links:[dn.postgres]}),shadow_port:g.number({default:54320,description:"Port to use for the local shadow database.",tags:Ce}),major_version:g.number({default:15,description:"The database major version to use. This has to be the same as your remote database's. Run `SHOW server_version;` on the remote database to check.",tags:Ce,links:[dn.postgres]}),pooler:g.object({enabled:g.boolean({default:false,description:"Enable the local PgBouncer service.",tags:Ce,links:[dn.pgbouncer()]}),port:g.number({default:54329,description:"Port to use for the local connection pooler.",tags:Ce,links:[dn.pgbouncer("listen_port")]}),pool_mode:g.string({enum:["transaction","session"],default:"transaction",description:"Specifies when a server connection can be reused by other clients. Configure one of the supported pooler modes: `transaction`, `session`.",tags:Ce,links:[dn.pgbouncer("pool_mode")]}),default_pool_size:g.number({default:20,description:"How many server connections to allow per user/database pair.",tags:Ce,links:[dn.pgbouncer("default_pool_size")]}),max_client_conn:g.number({default:100,description:"Maximum number of client connections allowed.",tags:Ce,links:[dn.pgbouncer("max_client_conn")]})}).partial(),seed:g.strictObject({enabled:g.boolean({default:true,description:"Enable seeding the database with SQL files.",tags:Ce}),sql_paths:g.array(g.string({description:"Path to a SQL file to seed the database with.",tags:Ce}),{default:["./seed.sql"],description:"Paths to SQL files to seed the database with. Supports glob patterns relative to supabase directory.",examples:[["./seeds/*.sql","../project-src/seeds/*-load-testing.sql"]],tags:Ce})}).partial(),migrations:g.strictObject({enabled:g.boolean({default:true,description:"Enable migrations.",tags:Ce}),schema_paths:g.array(g.string({description:"Path to a SQL file to seed the database with.",tags:Ce}),{default:["./schemas/schema.sql"]})}).partial()}).partial();ee();var da=["edge-functions"],Du=g.strictObject({enabled:g.boolean({default:true,description:"Enable the local Edge Runtime service.",tags:da}),policy:g.string({enum:["oneshot","per_worker"],default:"oneshot",description:"Configure the supported request policy. Use `oneshot` for hot reload, or `per_worker` for load testing.",tags:da}),inspector_port:g.number({default:8083,description:"Port to run the Edge Functions inspector on.",tags:da})}).partial();ee();var Ar=["experimental"],ju=g.strictObject({orioledb_version:g.string({description:"Postgres storage engine to use OrioleDB (S3)",tags:Ar}),s3_host:Et({description:"S3 bucket URL.",examples:["<bucket_name>.s3-<region>.amazonaws.com"],default:"env(S3_HOST)",tags:Ar}),s3_region:Et({description:"S3 bucket region.",examples:["us-east-1"],default:"env(S3_REGION)",tags:Ar}),s3_access_key:Et({description:"S3 access key.",default:"env(S3_ACCESS_KEY)",tags:Ar}),s3_secret_key:Et({description:"S3 secret key.",default:"env(S3_SECRET_KEY)",tags:Ar})}).partial();ee();var ci=["functions"],ui=[{name:"`supabase functions` CLI subcommands",link:"https://supabase.com/docs/reference/cli/supabase-functions"}],ty=Fn({enabled:Rr({default:true,description:Le`
|
|
33
43
|
Controls whether a function is deployed or served. When set to false,
|
|
34
44
|
the function will be skipped during deployment and won't be served locally.
|
|
35
45
|
This is useful for disabling demo functions or temporarily disabling a function
|
|
36
46
|
without removing its code.
|
|
37
|
-
`,tags:
|
|
47
|
+
`,tags:ci,links:ui}),verify_jwt:Rr({default:true,description:Le`
|
|
38
48
|
By default, when you deploy your Edge Functions or serve them locally, it
|
|
39
49
|
will reject requests without a valid JWT in the Authorization header.
|
|
40
50
|
Setting this configuration changes the default behavior.
|
|
41
|
-
`,tags:
|
|
51
|
+
`,tags:ci,links:ui}),import_map:cn({description:Le`
|
|
42
52
|
Specify the Deno import map file to use for the Function.
|
|
43
53
|
|
|
44
54
|
Note that the \`--import-map\` flag overrides this configuration.
|
|
45
|
-
`,tags:
|
|
55
|
+
`,tags:ci,links:ui}),entrypoint:cn({description:Le`
|
|
46
56
|
Specify the entrypoint path to the Function (defaults to "functions/slug/index.ts").
|
|
47
57
|
|
|
48
58
|
Both \`.js\` and \`.ts\` file extensions are supported.
|
|
49
|
-
`,tags:
|
|
59
|
+
`,tags:ci,links:ui})}).partial(),Lu=Fn({},{patternProperties:{"^[a-zA-Z0-9_-]+$":ty}});ee();var fi=[{name:"Inbucket documentation",link:"https://www.inbucket.org"}],di=["local"],Uu=g.strictObject({enabled:g.boolean({default:true,description:"Enable the local InBucket service.",tags:di,links:fi}),port:g.number({default:54324,description:Le`
|
|
50
60
|
Port to use for the email testing server web interface.
|
|
51
61
|
|
|
52
62
|
Emails sent with the local dev setup are not actually sent - rather, they are monitored, and you can view the emails that would have been sent from the web interface.
|
|
53
|
-
`,tags:
|
|
63
|
+
`,tags:di,links:fi}),smtp_port:g.number({default:54325,description:Le`
|
|
54
64
|
Port to use for the email testing server SMTP port.
|
|
55
65
|
|
|
56
66
|
Emails sent with the local dev setup are not actually sent - rather, they are monitored, and you can view the emails that would have been sent from the web interface.
|
|
57
67
|
|
|
58
68
|
If set, you can access the SMTP server from this port.
|
|
59
|
-
`,tags:
|
|
69
|
+
`,tags:di,links:fi}),pop3_port:g.number({default:54326,description:Le`
|
|
60
70
|
Port to use for the email testing server POP3 port.
|
|
61
71
|
|
|
62
72
|
Emails sent with the local dev setup are not actually sent - rather, they are monitored, and you can view the emails that would have been sent from the web interface.
|
|
63
73
|
|
|
64
74
|
If set, you can access the POP3 server from this port.
|
|
65
|
-
`,tags:ti,links:ei})}).partial();var tg=[{name:"Supabase Realtime",link:"https://supabase.com/docs/guides/realtime"}],Xa=["realtime"],sc=E.strictObject({enabled:E.boolean({default:true,description:"Enable the local Realtime service.",tags:Xa,links:tg}),ip_version:E.string({enum:["IPv4","IPv6"],default:"IPv4",description:"Bind realtime via either IPv4 or IPv6.",tags:Xa,links:[{name:"Supabase Realtime Configuration",link:"https://supabase.com/docs/guides/realtime/self-hosting"}]}),max_header_length:E.number({default:4096,description:"Maximum length of the HTTP header.",tags:Xa})}).partial();var ri=[{name:"Storage server configuration",link:"https://supabase.com/docs/guides/self-hosting/storage/config"}],Gt=["storage"],rg=E.strictObject({public:E.boolean({default:false,description:"Enable public access to the bucket."}),file_size_limit:E.string({default:"50MiB",description:"The maximum file size allowed for the bucket.",examples:["5MB","500KB"],tags:Gt,links:ri}),allowed_mime_types:E.array(E.string({description:"A MIME type allowed for the bucket.",tags:Gt}),{examples:[["image/png","image/jpeg"]],description:"The list of allowed MIME types for the bucket.",tags:Gt}),objects_path:E.string({description:"The path to the objects in the bucket.",tags:Gt})}).partial(),nc=E.strictObject({enabled:E.boolean({default:true,description:"Enable the local Storage service.",tags:Gt,links:ri}),file_size_limit:E.string({default:"50MiB",description:"The maximum file size allowed.",examples:["5MB","500KB"],tags:Gt,links:ri}),image_transformation:E.strictObject({enabled:E.boolean({default:true,description:"Enable image transformation.",tags:Gt,links:ri})}).partial(),buckets:E.record(rg,{description:"Storage buckets configuration.",tags:Gt})}).partial();var Qa={studio:{name:"Supabase Studio",link:"https://supabase.com/docs/guides/studio"},config:{name:"Supabase Studio Configuration",link:"https://supabase.com/docs/guides/self-hosting/studio"}},si=["studio"],ic=E.strictObject({enabled:E.boolean({default:true,description:"Enable the local Supabase Studio dashboard.",tags:si,links:[Qa.studio]}),port:E.number({default:54323,description:"Port to use for Supabase Studio.",tags:si}),api_url:E.string({default:"http://localhost",description:"External URL of the API server that frontend connects to.",tags:si,links:[Qa.config]}),openai_api_key:bt({default:"env(OPENAI_API_KEY)",description:"OpenAI API key to use for Supabase AI in the Supabase Studio.",tags:si,links:[Qa.config]})}).partial();var ni=Lr({project_id:sr({description:"A string used to distinguish different Supabase projects on the same host. Defaults to the working directory name when running `supabase init`.",tags:["general"]}),analytics:qu,api:Ju,auth:Xu,db:Qu,edge_runtime:Zu,functions:tc,inbucket:rc,realtime:sc,storage:nc,studio:ic,experimental:ec}).partial();var Za=(s,e,r)=>(t,n)=>{let i=-1;return a(0);async function a(o){if(o<=i)throw new Error("next() called multiple times");i=o;let l,u=false,p;if(s[o]?(p=s[o][0][0],t.req.routeIndex=o):p=o===s.length&&n||void 0,p)try{l=await p(t,()=>a(o+1));}catch(c){if(c instanceof Error&&e)t.error=c,l=await e(c,t),u=true;else throw c}else t.finalized===false&&r&&(l=await r(t));return l&&(t.finalized===false||u)&&(t.res=l),t}};var ii=class extends Error{res;status;constructor(s=500,e){super(e?.message,{cause:e?.cause}),this.res=e?.res,this.status=s;}getResponse(){return this.res?new Response(this.res.body,{status:this.status,headers:this.res.headers}):new Response(this.message,{status:this.status})}};var ac=Symbol();var oc=async(s,e=Object.create(null))=>{let{all:r=false,dot:t=false}=e,i=(s instanceof ai?s.raw.headers:s.headers).get("Content-Type");return i?.startsWith("multipart/form-data")||i?.startsWith("application/x-www-form-urlencoded")?sg(s,{all:r,dot:t}):{}};async function sg(s,e){let r=await s.formData();return r?ng(r,e):{}}function ng(s,e){let r=Object.create(null);return s.forEach((t,n)=>{e.all||n.endsWith("[]")?ig(r,n,t):r[n]=t;}),e.dot&&Object.entries(r).forEach(([t,n])=>{t.includes(".")&&(ag(r,t,n),delete r[t]);}),r}var ig=(s,e,r)=>{s[e]!==void 0?Array.isArray(s[e])?s[e].push(r):s[e]=[s[e],r]:e.endsWith("[]")?s[e]=[r]:s[e]=r;},ag=(s,e,r)=>{let t=s,n=e.split(".");n.forEach((i,a)=>{a===n.length-1?t[i]=r:((!t[i]||typeof t[i]!="object"||Array.isArray(t[i])||t[i]instanceof File)&&(t[i]=Object.create(null)),t=t[i]);});};var to=s=>{let e=s.split("/");return e[0]===""&&e.shift(),e},lc=s=>{let{groups:e,path:r}=og(s),t=to(r);return lg(t,e)},og=s=>{let e=[];return s=s.replace(/\{[^}]+\}/g,(r,t)=>{let n=`@${t}`;return e.push([n,r]),n}),{groups:e,path:s}},lg=(s,e)=>{for(let r=e.length-1;r>=0;r--){let[t]=e[r];for(let n=s.length-1;n>=0;n--)if(s[n].includes(t)){s[n]=s[n].replace(t,e[r][1]);break}}return s},oi={},uc=(s,e)=>{if(s==="*")return "*";let r=s.match(/^\:([^\{\}]+)(?:\{(.+)\})?$/);if(r){let t=`${s}#${e}`;return oi[t]||(r[2]?oi[t]=e&&e[0]!==":"&&e[0]!=="*"?[t,r[1],new RegExp(`^${r[2]}(?=/${e})`)]:[s,r[1],new RegExp(`^${r[2]}$`)]:oi[t]=[s,r[1],true]),oi[t]}return null},$r=(s,e)=>{try{return e(s)}catch{return s.replace(/(?:%[0-9A-Fa-f]{2})+/g,r=>{try{return e(r)}catch{return r}})}},ug=s=>$r(s,decodeURI),ro=s=>{let e=s.url,r=e.indexOf("/",e.indexOf(":")+4),t=r;for(;t<e.length;t++){let n=e.charCodeAt(t);if(n===37){let i=e.indexOf("?",t),a=e.indexOf("#",t),o=i===-1?a===-1?void 0:a:a===-1?i:Math.min(i,a),l=e.slice(r,o);return ug(l.includes("%25")?l.replace(/%25/g,"%2525"):l)}else if(n===63||n===35)break}return e.slice(r,t)};var cc=s=>{let e=ro(s);return e.length>1&&e.at(-1)==="/"?e.slice(0,-1):e},or=(s,e,...r)=>(r.length&&(e=or(e,...r)),`${s?.[0]==="/"?"":"/"}${s}${e==="/"?"":`${s?.at(-1)==="/"?"":"/"}${e?.[0]==="/"?e.slice(1):e}`}`),li=s=>{if(s.charCodeAt(s.length-1)!==63||!s.includes(":"))return null;let e=s.split("/"),r=[],t="";return e.forEach(n=>{if(n!==""&&!/\:/.test(n))t+="/"+n;else if(/\:/.test(n))if(/\?/.test(n)){r.length===0&&t===""?r.push("/"):r.push(t);let i=n.replace("?","");t+="/"+i,r.push(t);}else t+="/"+n;}),r.filter((n,i,a)=>a.indexOf(n)===i)},eo=s=>/[%+]/.test(s)?(s.indexOf("+")!==-1&&(s=s.replace(/\+/g," ")),s.indexOf("%")!==-1?$r(s,Es):s):s,pc=(s,e,r)=>{let t;if(!r&&e&&!/[%+]/.test(e)){let a=s.indexOf("?",8);if(a===-1)return;for(s.startsWith(e,a+1)||(a=s.indexOf(`&${e}`,a+1));a!==-1;){let o=s.charCodeAt(a+e.length+1);if(o===61){let l=a+e.length+2,u=s.indexOf("&",l);return eo(s.slice(l,u===-1?void 0:u))}else if(o==38||isNaN(o))return "";a=s.indexOf(`&${e}`,a+1);}if(t=/[%+]/.test(s),!t)return}let n={};t??=/[%+]/.test(s);let i=s.indexOf("?",8);for(;i!==-1;){let a=s.indexOf("&",i+1),o=s.indexOf("=",i);o>a&&a!==-1&&(o=-1);let l=s.slice(i+1,o===-1?a===-1?void 0:a:o);if(t&&(l=eo(l)),i=a,l==="")continue;let u;o===-1?u="":(u=s.slice(o+1,a===-1?void 0:a),t&&(u=eo(u))),r?(n[l]&&Array.isArray(n[l])||(n[l]=[]),n[l].push(u)):n[l]??=u;}return e?n[e]:n},fc=pc,mc=(s,e)=>pc(s,e,true),Es=decodeURIComponent;var hc=s=>$r(s,Es),ai=class{raw;#e;#t;routeIndex=0;path;bodyCache={};constructor(s,e="/",r=[[]]){this.raw=s,this.path=e,this.#t=r,this.#e={};}param(s){return s?this.#r(s):this.#i()}#r(s){let e=this.#t[0][this.routeIndex][1][s],r=this.#n(e);return r&&/\%/.test(r)?hc(r):r}#i(){let s={},e=Object.keys(this.#t[0][this.routeIndex][1]);for(let r of e){let t=this.#n(this.#t[0][this.routeIndex][1][r]);t!==void 0&&(s[r]=/\%/.test(t)?hc(t):t);}return s}#n(s){return this.#t[1]?this.#t[1][s]:s}query(s){return fc(this.url,s)}queries(s){return mc(this.url,s)}header(s){if(s)return this.raw.headers.get(s)??void 0;let e={};return this.raw.headers.forEach((r,t)=>{e[t]=r;}),e}async parseBody(s){return this.bodyCache.parsedBody??=await oc(this,s)}#s=s=>{let{bodyCache:e,raw:r}=this,t=e[s];if(t)return t;let n=Object.keys(e)[0];return n?e[n].then(i=>(n==="json"&&(i=JSON.stringify(i)),new Response(i)[s]())):e[s]=r[s]()};json(){return this.#s("text").then(s=>JSON.parse(s))}text(){return this.#s("text")}arrayBuffer(){return this.#s("arrayBuffer")}blob(){return this.#s("blob")}formData(){return this.#s("formData")}addValidatedData(s,e){this.#e[s]=e;}valid(s){return this.#e[s]}get url(){return this.raw.url}get method(){return this.raw.method}get[ac](){return this.#t}get matchedRoutes(){return this.#t[0].map(([[,s]])=>s)}get routePath(){return this.#t[0].map(([[,s]])=>s)[this.routeIndex].path}};var Qe={Stringify:1},G=(s,e)=>{let r=new String(s);return r.isEscaped=true,r.callbacks=e,r},cg=/[&<>'"]/,ui=async(s,e)=>{let r="";e||=[];let t=await Promise.all(s);for(let n=t.length-1;r+=t[n],n--,!(n<0);n--){let i=t[n];typeof i=="object"&&e.push(...i.callbacks||[]);let a=i.isEscaped;if(i=await(typeof i=="object"?i.toString():i),typeof i=="object"&&e.push(...i.callbacks||[]),i.isEscaped??a)r+=i;else {let o=[r];Tt(i,o),r=o[0];}}return G(r,e)},Tt=(s,e)=>{let r=s.search(cg);if(r===-1){e[0]+=s;return}let t,n,i=0;for(n=r;n<s.length;n++){switch(s.charCodeAt(n)){case 34:t=""";break;case 39:t="'";break;case 38:t="&";break;case 60:t="<";break;case 62:t=">";break;default:continue}e[0]+=s.substring(i,n)+t,i=n+1;}e[0]+=s.substring(i,n);},so=s=>{let e=s.callbacks;if(!e?.length)return s;let r=[s],t={};return e.forEach(n=>n({phase:Qe.Stringify,buffer:r,context:t})),r[0]},lr=async(s,e,r,t,n)=>{typeof s=="object"&&!(s instanceof String)&&(s instanceof Promise||(s=s.toString()),s instanceof Promise&&(s=await s));let i=s.callbacks;if(!i?.length)return Promise.resolve(s);n?n[0]+=s:n=[s];let a=Promise.all(i.map(o=>o({phase:e,buffer:n,context:t}))).then(o=>Promise.all(o.filter(Boolean).map(l=>lr(l,e,false,t,n))).then(()=>n[0]));return r?G(await a,i):a};var pg="text/plain; charset=UTF-8",no=(s,e)=>({"Content-Type":s,...e}),Ss=(s,e)=>new Response(s,e),dc=class{#e;#t;env={};#r;finalized=false;error;#i;#n;#s;#c;#l;#u;#o;#p;#f;constructor(s,e){this.#e=s,e&&(this.#n=e.executionCtx,this.env=e.env,this.#u=e.notFoundHandler,this.#f=e.path,this.#p=e.matchResult);}get req(){return this.#t??=new ai(this.#e,this.#f,this.#p),this.#t}get event(){if(this.#n&&"respondWith"in this.#n)return this.#n;throw Error("This context has no FetchEvent")}get executionCtx(){if(this.#n)return this.#n;throw Error("This context has no ExecutionContext")}get res(){return this.#s||=Ss(null,{headers:this.#o??=new Headers})}set res(s){if(this.#s&&s){s=Ss(s.body,s);for(let[e,r]of this.#s.headers.entries())if(e!=="content-type")if(e==="set-cookie"){let t=this.#s.headers.getSetCookie();s.headers.delete("set-cookie");for(let n of t)s.headers.append("set-cookie",n);}else s.headers.set(e,r);}this.#s=s,this.finalized=true;}render=(...s)=>(this.#l??=e=>this.html(e),this.#l(...s));setLayout=s=>this.#c=s;getLayout=()=>this.#c;setRenderer=s=>{this.#l=s;};header=(s,e,r)=>{this.finalized&&(this.#s=Ss(this.#s.body,this.#s));let t=this.#s?this.#s.headers:this.#o??=new Headers;e===void 0?t.delete(s):r?.append?t.append(s,e):t.set(s,e);};status=s=>{this.#i=s;};set=(s,e)=>{this.#r??=new Map,this.#r.set(s,e);};get=s=>this.#r?this.#r.get(s):void 0;get var(){return this.#r?Object.fromEntries(this.#r):{}}#a(s,e,r){let t=this.#s?new Headers(this.#s.headers):this.#o??new Headers;if(typeof e=="object"&&"headers"in e){let i=e.headers instanceof Headers?e.headers:new Headers(e.headers);for(let[a,o]of i)a.toLowerCase()==="set-cookie"?t.append(a,o):t.set(a,o);}if(r)for(let[i,a]of Object.entries(r))if(typeof a=="string")t.set(i,a);else {t.delete(i);for(let o of a)t.append(i,o);}let n=typeof e=="number"?e:e?.status??this.#i;return Ss(s,{status:n,headers:t})}newResponse=(...s)=>this.#a(...s);body=(s,e,r)=>this.#a(s,e,r);text=(s,e,r)=>!this.#o&&!this.#i&&!e&&!r&&!this.finalized?new Response(s):this.#a(s,e,no(pg,r));json=(s,e,r)=>this.#a(JSON.stringify(s),e,no("application/json",r));html=(s,e,r)=>{let t=n=>this.#a(n,e,no("text/html; charset=UTF-8",r));return typeof s=="object"?lr(s,Qe.Stringify,false,{}).then(t):t(s)};redirect=(s,e)=>{let r=String(s);return this.header("Location",/[^\x00-\xFF]/.test(r)?encodeURI(r):r),this.newResponse(null,e??302)};notFound=()=>(this.#u??=()=>Ss(),this.#u(this))};var Z="ALL",gc="all",yc=["get","post","put","delete","options","patch"],ci="Can not add a route since the matcher is already built.",pi=class extends Error{};var Ec="__COMPOSED_HANDLER";var fg=s=>s.text("404 Not Found",404),Sc=(s,e)=>{if("getResponse"in s){let r=s.getResponse();return e.newResponse(r.body,r)}return console.error(s),e.text("Internal Server Error",500)},bc=class Tc{get;post;put;delete;options;patch;all;on;use;router;getPath;_basePath="/";#e="/";routes=[];constructor(e={}){[...yc,gc].forEach(i=>{this[i]=(a,...o)=>(typeof a=="string"?this.#e=a:this.#i(i,this.#e,a),o.forEach(l=>{this.#i(i,this.#e,l);}),this);}),this.on=(i,a,...o)=>{for(let l of [a].flat()){this.#e=l;for(let u of [i].flat())o.map(p=>{this.#i(u.toUpperCase(),this.#e,p);});}return this},this.use=(i,...a)=>(typeof i=="string"?this.#e=i:(this.#e="*",a.unshift(i)),a.forEach(o=>{this.#i(Z,this.#e,o);}),this);let{strict:t,...n}=e;Object.assign(this,n),this.getPath=t??true?e.getPath??ro:cc;}#t(){let e=new Tc({router:this.router,getPath:this.getPath});return e.errorHandler=this.errorHandler,e.#r=this.#r,e.routes=this.routes,e}#r=fg;errorHandler=Sc;route(e,r){let t=this.basePath(e);return r.routes.map(n=>{let i;r.errorHandler===Sc?i=n.handler:(i=async(a,o)=>(await Za([],r.errorHandler)(a,()=>n.handler(a,o))).res,i[Ec]=n.handler),t.#i(n.method,n.path,i);}),this}basePath(e){let r=this.#t();return r._basePath=or(this._basePath,e),r}onError=e=>(this.errorHandler=e,this);notFound=e=>(this.#r=e,this);mount(e,r,t){let n,i;t&&(typeof t=="function"?i=t:(i=t.optionHandler,t.replaceRequest===false?n=l=>l:n=t.replaceRequest));let a=i?l=>{let u=i(l);return Array.isArray(u)?u:[u]}:l=>{let u;try{u=l.executionCtx;}catch{}return [l.env,u]};n||=(()=>{let l=or(this._basePath,e),u=l==="/"?0:l.length;return p=>{let c=new URL(p.url);return c.pathname=c.pathname.slice(u)||"/",new Request(c,p)}})();let o=async(l,u)=>{let p=await r(n(l.req.raw),...a(l));if(p)return p;await u();};return this.#i(Z,or(e,"*"),o),this}#i(e,r,t){e=e.toUpperCase(),r=or(this._basePath,r);let n={basePath:this._basePath,path:r,method:e,handler:t};this.router.add(e,r,[t,n]),this.routes.push(n);}#n(e,r){if(e instanceof Error)return this.errorHandler(e,r);throw e}#s(e,r,t,n){if(n==="HEAD")return (async()=>new Response(null,await this.#s(e,r,t,"GET")))();let i=this.getPath(e,{env:t}),a=this.router.match(n,i),o=new dc(e,{path:i,matchResult:a,env:t,executionCtx:r,notFoundHandler:this.#r});if(a[0].length===1){let u;try{u=a[0][0][0][0](o,async()=>{o.res=await this.#r(o);});}catch(p){return this.#n(p,o)}return u instanceof Promise?u.then(p=>p||(o.finalized?o.res:this.#r(o))).catch(p=>this.#n(p,o)):u??this.#r(o)}let l=Za(a[0],this.errorHandler,this.#r);return (async()=>{try{let u=await l(o);if(!u.finalized)throw new Error("Context is not finalized. Did you forget to return a Response object or `await next()`?");return u.res}catch(u){return this.#n(u,o)}})()}fetch=(e,...r)=>this.#s(e,r[1],r[0],e.method);request=(e,r,t,n)=>e instanceof Request?this.fetch(r?new Request(e,r):e,t,n):(e=e.toString(),this.fetch(new Request(/^https?:\/\//.test(e)?e:`http://localhost${or("/",e)}`,r),t,n));fire=()=>{addEventListener("fetch",e=>{e.respondWith(this.#s(e.request,e,void 0,e.request.method));});}};var fi=[];function io(s,e){let r=this.buildAllMatchers(),t=((n,i)=>{let a=r[n]||r[Z],o=a[2][i];if(o)return o;let l=i.match(a[0]);if(!l)return [[],fi];let u=l.indexOf("",1);return [a[1][u],l]});return this.match=t,t(s,e)}var mi="[^/]+",bs=".*",Ts="(?:|/.*)",ur=Symbol(),mg=new Set(".\\+*[^]$()");function hg(s,e){return s.length===1?e.length===1?s<e?-1:1:-1:e.length===1||s===bs||s===Ts?1:e===bs||e===Ts?-1:s===mi?1:e===mi?-1:s.length===e.length?s<e?-1:1:e.length-s.length}var wc=class ao{#e;#t;#r=Object.create(null);insert(e,r,t,n,i){if(e.length===0){if(this.#e!==void 0)throw ur;if(i)return;this.#e=r;return}let[a,...o]=e,l=a==="*"?o.length===0?["","",bs]:["","",mi]:a==="/*"?["","",Ts]:a.match(/^\:([^\{\}]+)(?:\{(.+)\})?$/),u;if(l){let p=l[1],c=l[2]||mi;if(p&&l[2]&&(c===".*"||(c=c.replace(/^\((?!\?:)(?=[^)]+\)$)/,"(?:"),/\((?!\?:)/.test(c))))throw ur;if(u=this.#r[c],!u){if(Object.keys(this.#r).some(f=>f!==bs&&f!==Ts))throw ur;if(i)return;u=this.#r[c]=new ao,p!==""&&(u.#t=n.varIndex++);}!i&&p!==""&&t.push([p,u.#t]);}else if(u=this.#r[a],!u){if(Object.keys(this.#r).some(p=>p.length>1&&p!==bs&&p!==Ts))throw ur;if(i)return;u=this.#r[a]=new ao;}u.insert(o,r,t,n,i);}buildRegExpStr(){let r=Object.keys(this.#r).sort(hg).map(t=>{let n=this.#r[t];return (typeof n.#t=="number"?`(${t})@${n.#t}`:mg.has(t)?`\\${t}`:t)+n.buildRegExpStr()});return typeof this.#e=="number"&&r.unshift(`#${this.#e}`),r.length===0?"":r.length===1?r[0]:"(?:"+r.join("|")+")"}};var Cc=class{#e={varIndex:0};#t=new wc;insert(s,e,r){let t=[],n=[];for(let a=0;;){let o=false;if(s=s.replace(/\{[^}]+\}/g,l=>{let u=`@\\${a}`;return n[a]=[u,l],a++,o=true,u}),!o)break}let i=s.match(/(?::[^\/]+)|(?:\/\*$)|./g)||[];for(let a=n.length-1;a>=0;a--){let[o]=n[a];for(let l=i.length-1;l>=0;l--)if(i[l].indexOf(o)!==-1){i[l]=i[l].replace(o,n[a][1]);break}}return this.#t.insert(i,e,t,this.#e,r),t}buildRegExp(){let s=this.#t.buildRegExpStr();if(s==="")return [/^$/,[],[]];let e=0,r=[],t=[];return s=s.replace(/#(\d+)|@(\d+)|\.\*\$/g,(n,i,a)=>i!==void 0?(r[++e]=Number(i),"$()"):(a!==void 0&&(t[Number(a)]=++e),"")),[new RegExp(`^${s}`),r,t]}};var dg=[/^$/,[],Object.create(null)],Ac=Object.create(null);function Rc(s){return Ac[s]??=new RegExp(s==="*"?"":`^${s.replace(/\/\*$|([.\\+*[^\]$()])/g,(e,r)=>r?`\\${r}`:"(?:|/.*)")}$`)}function gg(){Ac=Object.create(null);}function yg(s){let e=new Cc,r=[];if(s.length===0)return dg;let t=s.map(u=>[!/\*|\/:/.test(u[0]),...u]).sort(([u,p],[c,f])=>u?1:c?-1:p.length-f.length),n=Object.create(null);for(let u=0,p=-1,c=t.length;u<c;u++){let[f,m,d]=t[u];f?n[m]=[d.map(([b])=>[b,Object.create(null)]),fi]:p++;let g;try{g=e.insert(m,p,f);}catch(b){throw b===ur?new pi(m):b}f||(r[p]=d.map(([b,y])=>{let T=Object.create(null);for(y-=1;y>=0;y--){let[C,w]=g[y];T[C]=w;}return [b,T]}));}let[i,a,o]=e.buildRegExp();for(let u=0,p=r.length;u<p;u++)for(let c=0,f=r[u].length;c<f;c++){let m=r[u][c]?.[1];if(!m)continue;let d=Object.keys(m);for(let g=0,b=d.length;g<b;g++)m[d[g]]=o[m[d[g]]];}let l=[];for(let u in a)l[u]=r[a[u]];return [i,l,n]}function Pr(s,e){if(s){for(let r of Object.keys(s).sort((t,n)=>n.length-t.length))if(Rc(r).test(e))return [...s[r]]}}var hi=class{name="RegExpRouter";#e;#t;constructor(){this.#e={[Z]:Object.create(null)},this.#t={[Z]:Object.create(null)};}add(s,e,r){let t=this.#e,n=this.#t;if(!t||!n)throw new Error(ci);t[s]||[t,n].forEach(o=>{o[s]=Object.create(null),Object.keys(o[Z]).forEach(l=>{o[s][l]=[...o[Z][l]];});}),e==="/*"&&(e="*");let i=(e.match(/\/:/g)||[]).length;if(/\*$/.test(e)){let o=Rc(e);s===Z?Object.keys(t).forEach(l=>{t[l][e]||=Pr(t[l],e)||Pr(t[Z],e)||[];}):t[s][e]||=Pr(t[s],e)||Pr(t[Z],e)||[],Object.keys(t).forEach(l=>{(s===Z||s===l)&&Object.keys(t[l]).forEach(u=>{o.test(u)&&t[l][u].push([r,i]);});}),Object.keys(n).forEach(l=>{(s===Z||s===l)&&Object.keys(n[l]).forEach(u=>o.test(u)&&n[l][u].push([r,i]));});return}let a=li(e)||[e];for(let o=0,l=a.length;o<l;o++){let u=a[o];Object.keys(n).forEach(p=>{(s===Z||s===p)&&(n[p][u]||=[...Pr(t[p],u)||Pr(t[Z],u)||[]],n[p][u].push([r,i-l+o+1]));});}}match=io;buildAllMatchers(){let s=Object.create(null);return Object.keys(this.#t).concat(Object.keys(this.#e)).forEach(e=>{s[e]||=this.#r(e);}),this.#e=this.#t=void 0,gg(),s}#r(s){let e=[],r=s===Z;return [this.#e,this.#t].forEach(t=>{let n=t[s]?Object.keys(t[s]).map(i=>[i,t[s][i]]):[];n.length!==0?(r||=true,e.push(...n)):s!==Z&&e.push(...Object.keys(t[Z]).map(i=>[i,t[Z][i]]));}),r?yg(e):null}};var oo=class{name="SmartRouter";#e=[];#t=[];constructor(s){this.#e=s.routers;}add(s,e,r){if(!this.#t)throw new Error(ci);this.#t.push([s,e,r]);}match(s,e){if(!this.#t)throw new Error("Fatal error");let r=this.#e,t=this.#t,n=r.length,i=0,a;for(;i<n;i++){let o=r[i];try{for(let l=0,u=t.length;l<u;l++)o.add(...t[l]);a=o.match(s,e);}catch(l){if(l instanceof pi)continue;throw l}this.match=o.match.bind(o),this.#e=[o],this.#t=void 0;break}if(i===n)throw new Error("Fatal error");return this.name=`SmartRouter + ${this.activeRouter.name}`,a}get activeRouter(){if(this.#t||this.#e.length!==1)throw new Error("No active router has been determined yet.");return this.#e[0]}};var ws=Object.create(null),Eg=s=>{for(let e in s)return true;return false},_c=class vc{#e;#t;#r;#i=0;#n=ws;constructor(e,r,t){if(this.#t=t||Object.create(null),this.#e=[],e&&r){let n=Object.create(null);n[e]={handler:r,possibleKeys:[],score:0},this.#e=[n];}this.#r=[];}insert(e,r,t){this.#i=++this.#i;let n=this,i=lc(r),a=[];for(let o=0,l=i.length;o<l;o++){let u=i[o],p=i[o+1],c=uc(u,p),f=Array.isArray(c)?c[0]:u;if(f in n.#t){n=n.#t[f],c&&a.push(c[1]);continue}n.#t[f]=new vc,c&&(n.#r.push(c),a.push(c[1])),n=n.#t[f];}return n.#e.push({[e]:{handler:t,possibleKeys:a.filter((o,l,u)=>u.indexOf(o)===l),score:this.#i}}),n}#s(e,r,t,n,i){for(let a=0,o=r.#e.length;a<o;a++){let l=r.#e[a],u=l[t]||l[Z],p={};if(u!==void 0&&(u.params=Object.create(null),e.push(u),n!==ws||i&&i!==ws))for(let c=0,f=u.possibleKeys.length;c<f;c++){let m=u.possibleKeys[c],d=p[u.score];u.params[m]=i?.[m]&&!d?i[m]:n[m]??i?.[m],p[u.score]=true;}}}search(e,r){let t=[];this.#n=ws;let i=[this],a=to(r),o=[],l=a.length,u=null;for(let p=0;p<l;p++){let c=a[p],f=p===l-1,m=[];for(let g=0,b=i.length;g<b;g++){let y=i[g],T=y.#t[c];T&&(T.#n=y.#n,f?(T.#t["*"]&&this.#s(t,T.#t["*"],e,y.#n),this.#s(t,T,e,y.#n)):m.push(T));for(let C=0,w=y.#r.length;C<w;C++){let A=y.#r[C],v=y.#n===ws?{}:{...y.#n};if(A==="*"){let K=y.#t["*"];K&&(this.#s(t,K,e,y.#n),K.#n=v,m.push(K));continue}let[R,O,_]=A;if(!c&&!(_ instanceof RegExp))continue;let I=y.#t[R];if(_ instanceof RegExp){if(u===null){u=new Array(l);let ce=r[0]==="/"?1:0;for(let Xe=0;Xe<l;Xe++)u[Xe]=ce,ce+=a[Xe].length+1;}let K=r.substring(u[p]),D=_.exec(K);if(D){if(v[O]=D[0],this.#s(t,I,e,y.#n,v),Eg(I.#t)){I.#n=v;let ce=D[0].match(/\//)?.length??0;(o[ce]||=[]).push(I);}continue}}(_===true||_.test(c))&&(v[O]=c,f?(this.#s(t,I,e,v,y.#n),I.#t["*"]&&this.#s(t,I.#t["*"],e,v,y.#n)):(I.#n=v,m.push(I)));}}let d=o.shift();i=d?m.concat(d):m;}return t.length>1&&t.sort((p,c)=>p.score-c.score),[t.map(({handler:p,params:c})=>[p,c])]}};var lo=class{name="TrieRouter";#e;constructor(){this.#e=new _c;}add(s,e,r){let t=li(e);if(t){for(let n=0,i=t.length;n<i;n++)this.#e.insert(s,t[n],r);return}this.#e.insert(s,e,r);}match(s,e){return this.#e.search(s,e)}};var be=class extends bc{constructor(s={}){super(s),this.router=s.router??new oo({routers:[new hi,new lo]});}};var bg=s=>JSON.parse(jsonStringify(s)),Oc=new be().get("/ping",s=>s.json({message:"pong"})).get("/config",s=>s.json(s.var.app.config)).get("/info",s=>s.json(bg({connection:s.var.app.connection.config,config:s.var.app.config}))).get("/introspect",async s=>{let e=await s.var.app.connection.introspect();return s.json(e)});var Ne=class extends Error{code;details;hint;httpStatus;constructor(e){super(e.message),this.name="EmbedError",this.code=e.code,this.details=e.details,this.hint=e.hint,this.httpStatus=e.httpStatus;}},Be=class extends Error{constructor(r,t=r){super(r);this.details=t;this.name="SelectParseError";}},Vt=class extends Error{constructor(r,t=r){super(r);this.details=t;this.name="QueryParamParseError";}},Dr=class extends Error{constructor(r="Invalid path specified in request URL",t=null){super(r);this.details=t;this.name="RouteValidationError";}},me=class extends Error{constructor(r,t,n){super(r);this.details=t;this.position=n;this.name="OrderParseError";}};var Tg="/rest/v1";function uo(s,e=Tg){let r=new URL(s.url),t=decodeURIComponent(r.pathname);t.startsWith(e)&&(t=t.slice(e.length)),t=t.replace(/^\/+|\/+$/g,"");let n=t.split("/");if(n[0]==="rpc"&&n[1])return {function:n[1],isRpc:true};if(n.length>1)throw new Dr;return {from:n[0]||void 0,isRpc:false}}function co(s){let e=s.method.toUpperCase(),r;e==="GET"||e==="HEAD"?r=s.headers.get("Accept-Profile")??void 0:r=s.headers.get("Content-Profile")??void 0;let t=[],n=[],i=s.headers.get("Prefer");i&&n.push(i);for(let o of n){let l=o.split(",").map(u=>u.trim()).filter(Boolean);for(let u of l){let p=u.indexOf("=");if(p===-1)continue;let c=u.slice(0,p).trim(),f=u.slice(p+1).trim();c==="max-affected"?t.push({key:"max-affected",value:Number(f)}):t.push({key:c,value:f});}}let a=s.headers.get("Accept")??"application/json";return {schema:r,preferTokens:t,accept:a}}var Nc=new Set(["count","sum","avg","min","max"]);function F(s){return s.input[s.pos]??""}function U(s,e=1){s.pos+=e;}function _e(s){return s.pos>=s.input.length}function Ie(s,e){return s.input.startsWith(e,s.pos)}function fo(s){return /^[a-zA-Z0-9_]$/.test(s)}function q(s){for(;!_e(s)&&/\s/.test(F(s));)U(s);}function ho(s){let r=new URL(s.url).searchParams.get("select");if(r==null)return {select:[],join:{},embeddedAliases:new Set};if(r==="")return {select:[],join:{},embeddedAliases:new Set};if(r.trim()==="")throw new Be("failed to parse select parameter");let t={},n=new Set,i={input:r,pos:0},a=kc(i,t,n);if(q(i),!_e(i))throw new Error(`Unexpected input at position ${i.pos}: "${i.input.slice(i.pos)}"`);return {select:a,join:t,embeddedAliases:n}}function kc(s,e,r){let t=[];if(q(s),_e(s)||F(s)===")"||F(s)===","&&(U(s),q(s),_e(s)||F(s)===")"))return t;for(t.push(Ic(s,e,r));!_e(s)&&(q(s),F(s)===",");)U(s),q(s),t.push(Ic(s,e,r));return t}function Ic(s,e,r){if(q(s),F(s)==="*")return U(s),"*";if(Ie(s,"..."))return U(s,3),q(s),wg(s,e,r);let t=ot(s,{allowSpaces:true,allowDollar:true});return q(s),Ie(s,"::")?mo(t,void 0,s,e,r):F(s)===":"?(U(s),q(s),Cg(t,s,e,r)):mo(t,void 0,s,e,r)}function wg(s,e,r){let t=ot(s);q(s);let{hint:n,innerJoin:i}=$c(s);if(q(s),F(s)!=="(")throw new Error(`Expected "(" for spread embed at position ${s.pos}`);let{subSelect:a,subJoin:o}=Pc(s),l=t,u={};i&&(u.type="inner"),n&&(u.hint=n),e[l]=u,r.add(l);let p={spread:true,select:a};return Object.keys(o).length>0&&(p.join=o),{[l]:p}}function Cg(s,e,r,t){let n=ot(e,{allowSpaces:true,allowDollar:true});return q(e),mo(n,s,e,r,t)}function mo(s,e,r,t,n){return q(r),s==="count"&&(_e(r)||F(r)===","||F(r)===")"||F(r)==="("||Ie(r,"::"))?Rg(e,r):F(r)==="!"||F(r)==="("?Ag(s,e,r,t,n):_g(s,e,r)}function Ag(s,e,r,t,n){let{hint:i,innerJoin:a}=$c(r);if(q(r),F(r)!=="(")throw new Be("failed to parse select parameter");let{subSelect:o,subJoin:l}=Pc(r),u=e??s,p={};e&&(p.from=s),a&&(p.type="inner"),i&&(p.hint=i),t[u]=p,n.add(u),e&&s!==u&&n.add(s);let c={select:o};return Object.keys(l).length>0&&(c.join=l),{[u]:c}}function $c(s){if(q(s),F(s)!=="!")return {};U(s);let e=ot(s);if(e==="inner")return {innerJoin:true};if(e==="left")return {};let r=e;if(q(s),F(s)==="!"){U(s);let t=ot(s);if(t==="inner")return {hint:r,innerJoin:true};if(t==="left")return {hint:r};throw new Error(`Expected "inner" or "left" after hint, got "${t}" at position ${s.pos}`)}return {hint:r}}function Pc(s,e,r){if(F(s)!=="(")throw new Error(`Expected "(" at position ${s.pos}`);U(s),q(s);let t={},n=new Set;if(F(s)===")")return U(s),{subSelect:[],subJoin:t};let i=kc(s,t,n);if(q(s),F(s)!==")")throw new Error(`Expected ")" at position ${s.pos}`);return U(s),{subSelect:i,subJoin:t}}function Rg(s,e){q(e);let r=true;if(F(e)==="("){r=false,U(e);let a=e.pos;for(;!_e(e)&&F(e)!==")";)U(e);if(_e(e))throw new Be("expected closing paren for count()");let o=e.input.slice(a,e.pos).trim();if(U(e),o!=="")throw new Be("expected null arg for count()")}q(e);let t;Ie(e,"::")&&(U(e,2),t=Cs(e));let n=s??"count",i={aggregate:"count"};return r&&(i.bareCount=true),t&&(i.cast=t),{[n]:i}}function _g(s,e,r){q(r);let t,n,i=false,a;if(Ie(r,"->")){let{path:p,lastProp:c,lastIsText:f,invalidTextTraversalKey:m}=vg(r);t=p,n=c||void 0,i=f,a=m;}q(r);let o,l;if(Ie(r,"::")){U(r,2);let p=Cs(r);if(q(r),F(r)==="."&&!_e(r)){let c=r.input[r.pos+1]??"";if(fo(c)){let f=r.pos;U(r);let m=ot(r);if(Nc.has(m)&&Ie(r,"()"))return o=p,U(r,2),q(r),Ie(r,"::")&&(U(r,2),l=Cs(r),po(r)),Lc(s,e,t,n,i,a,o,m,l);r.pos=f;}}l=p,po(r);}let u;if(F(r)==="."&&!_e(r)){let p=r.input[r.pos+1]??"";if(fo(p)){let c=r.pos;U(r);let f=ot(r);Nc.has(f)&&Ie(r,"()")?(u=f,U(r,2),q(r),Ie(r,"::")&&(U(r,2),l=Cs(r),po(r))):r.pos=c;}}return Lc(s,e,t,n,i,a,o,u,l)}function po(s){for(q(s);Ie(s,"::");)U(s,2),Cs(s),q(s);}function Cs(s){q(s);let e=[ot(s)];for(;!_e(s);){let r=s.pos;if(q(s),s.pos===r)break;let t=F(s);if(!(t==='"'||/^[a-zA-Z0-9_]$/.test(t))){s.pos=r;break}e.push(ot(s));}return e.join(" ")}function Lc(s,e,r,t,n,i,a,o,l){let u=e??(o||void 0)??t;if(!u&&!a&&!l&&!o&&!r)return s;let p=u??s,c={};return s!==p&&(c.column=s),o&&!c.column&&s===p&&(c.column=s),r&&(c.column||(c.column=s),c.path=r,n&&(c.pathText=true),i&&(c.invalidJsonTextTraversalKey=i)),a&&(c.preCast=a),o&&(c.aggregate=o),l&&(c.cast=l),{[p]:c}}function vg(s){let e=[],r="",t=false,n;for(;Ie(s,"->");){let a=t;U(s,2);let o=false;F(s)===">"&&(U(s),o=true);let l=Og(s);e.push(l),a&&n===void 0&&(n=l),/^-?\d+$/.test(l)||(r=l),t=o;}return {path:"$."+e.join("."),lastProp:r,lastIsText:t,invalidTextTraversalKey:n}}function Og(s){return Ng(s)}function Ng(s){q(s);let e=s.pos;if(F(s)==='"')return ot(s);let r="";for(;!_e(s)&&!(Ie(s,"->")||Ie(s,"::"));){let t=F(s);if(t===","||t==="."||t===":"||/\s/.test(t))break;r+=t,U(s);}if(r==="")throw new Be(`"failed to parse select parameter (${s.input})" (line 1, column ${e+1})`);if(r.includes("--")||r.endsWith("-"))throw new Be("failed to parse select parameter");if(/^-\d+\D/.test(r))throw new Be("failed to parse select parameter");return r}function ot(s,e={}){if(q(s),F(s)==='"'){U(s);let t="";for(;!_e(s)&&F(s)!=='"';)t+=F(s),U(s);if(_e(s))throw new Error(`Missing closing quote at position ${s.pos}`);return U(s),t}let r="";for(;!_e(s);){let t=F(s);if(fo(t))r+=t,U(s);else if(e.allowDollar&&t==="$")r+=t,U(s);else if(e.allowSpaces&&t===" ")r+=t,U(s);else if(t==="-"&&r.length>0){if((s.input[s.pos+1]??"")===">")break;r+=t,U(s);}else break}if(e.allowSpaces&&(r=r.trimEnd()),r==="")throw new Error(`Expected identifier at position ${s.pos}`);if(r.includes("--")||r.endsWith("-"))throw new Be("failed to parse select parameter");return r}async function go(s){let e=s.method.toUpperCase();if(e==="GET"||e==="HEAD")return {};let r=await s.text(),t=s.headers.get("Content-Type")??"";if(!r&&t.includes("text/csv"))throw new jr('parse error (not enough input) at ""');if(!r)return {};if(t.includes("application/json"))try{let n=JSON.parse(r);return Array.isArray(n)?{values:n}:{values:n}}catch{throw new Error(`Invalid JSON body: ${r.slice(0,100)}`)}if(t.includes("text/csv"))return {values:Ig(r)};if(t.includes("application/x-www-form-urlencoded")){let n=new URLSearchParams(r),i={};for(let[a,o]of n)i[a]=o;return {values:i}}return {raw:r}}function Ig(s){let e=s.replace(/\r\n/g,`
|
|
75
|
+
`,tags:di,links:fi})}).partial();ee();var ny=[{name:"Supabase Realtime",link:"https://supabase.com/docs/guides/realtime"}],pa=["realtime"],Mu=g.strictObject({enabled:g.boolean({default:true,description:"Enable the local Realtime service.",tags:pa,links:ny}),ip_version:g.string({enum:["IPv4","IPv6"],default:"IPv4",description:"Bind realtime via either IPv4 or IPv6.",tags:pa,links:[{name:"Supabase Realtime Configuration",link:"https://supabase.com/docs/guides/realtime/self-hosting"}]}),max_header_length:g.number({default:4096,description:"Maximum length of the HTTP header.",tags:pa})}).partial();ee();var pi=[{name:"Storage server configuration",link:"https://supabase.com/docs/guides/self-hosting/storage/config"}],Vt=["storage"],ry=g.strictObject({public:g.boolean({default:false,description:"Enable public access to the bucket."}),file_size_limit:g.string({default:"50MiB",description:"The maximum file size allowed for the bucket.",examples:["5MB","500KB"],tags:Vt,links:pi}),allowed_mime_types:g.array(g.string({description:"A MIME type allowed for the bucket.",tags:Vt}),{examples:[["image/png","image/jpeg"]],description:"The list of allowed MIME types for the bucket.",tags:Vt}),objects_path:g.string({description:"The path to the objects in the bucket.",tags:Vt})}).partial(),Fu=g.strictObject({enabled:g.boolean({default:true,description:"Enable the local Storage service.",tags:Vt,links:pi}),file_size_limit:g.string({default:"50MiB",description:"The maximum file size allowed.",examples:["5MB","500KB"],tags:Vt,links:pi}),image_transformation:g.strictObject({enabled:g.boolean({default:true,description:"Enable image transformation.",tags:Vt,links:pi})}).partial(),buckets:g.record(ry,{description:"Storage buckets configuration.",tags:Vt})}).partial();ee();var ma={studio:{name:"Supabase Studio",link:"https://supabase.com/docs/guides/studio"},config:{name:"Supabase Studio Configuration",link:"https://supabase.com/docs/guides/self-hosting/studio"}},mi=["studio"],Bu=g.strictObject({enabled:g.boolean({default:true,description:"Enable the local Supabase Studio dashboard.",tags:mi,links:[ma.studio]}),port:g.number({default:54323,description:"Port to use for Supabase Studio.",tags:mi}),api_url:g.string({default:"http://localhost",description:"External URL of the API server that frontend connects to.",tags:mi,links:[ma.config]}),openai_api_key:Et({default:"env(OPENAI_API_KEY)",description:"OpenAI API key to use for Supabase AI in the Supabase Studio.",tags:mi,links:[ma.config]})}).partial();var hi=Fn({project_id:cn({description:"A string used to distinguish different Supabase projects on the same host. Defaults to the working directory name when running `supabase init`.",tags:["general"]}),analytics:vu,api:Cu,auth:Nu,db:Iu,edge_runtime:Du,functions:Lu,inbucket:Uu,realtime:Mu,storage:Fu,studio:Bu,experimental:ju}).partial();var ha=(t,e,n)=>(r,s)=>{let i=-1;return o(0);async function o(a){if(a<=i)throw new Error("next() called multiple times");i=a;let l,c=false,f;if(t[a]?(f=t[a][0][0],r.req.routeIndex=a):f=a===t.length&&s||void 0,f)try{l=await f(r,()=>o(a+1));}catch(u){if(u instanceof Error&&e)r.error=u,l=await e(u,r),c=true;else throw u}else r.finalized===false&&n&&(l=await n(r));return l&&(r.finalized===false||c)&&(r.res=l),r}};var gi=class extends Error{res;status;constructor(t=500,e){super(e?.message,{cause:e?.cause}),this.res=e?.res,this.status=t;}getResponse(){return this.res?new Response(this.res.body,{status:this.status,headers:this.res.headers}):new Response(this.message,{status:this.status})}};var qu=Symbol();var Wu=async(t,e=Object.create(null))=>{let{all:n=false,dot:r=false}=e,i=(t instanceof yi?t.raw.headers:t.headers).get("Content-Type");return i?.startsWith("multipart/form-data")||i?.startsWith("application/x-www-form-urlencoded")?sy(t,{all:n,dot:r}):{}};async function sy(t,e){let n=await t.formData();return n?iy(n,e):{}}function iy(t,e){let n=Object.create(null);return t.forEach((r,s)=>{e.all||s.endsWith("[]")?oy(n,s,r):n[s]=r;}),e.dot&&Object.entries(n).forEach(([r,s])=>{r.includes(".")&&(ay(n,r,s),delete n[r]);}),n}var oy=(t,e,n)=>{t[e]!==void 0?Array.isArray(t[e])?t[e].push(n):t[e]=[t[e],n]:e.endsWith("[]")?t[e]=[n]:t[e]=n;},ay=(t,e,n)=>{let r=t,s=e.split(".");s.forEach((i,o)=>{o===s.length-1?r[i]=n:((!r[i]||typeof r[i]!="object"||Array.isArray(r[i])||r[i]instanceof File)&&(r[i]=Object.create(null)),r=r[i]);});};var ya=t=>{let e=t.split("/");return e[0]===""&&e.shift(),e},Ju=t=>{let{groups:e,path:n}=ly(t),r=ya(n);return cy(r,e)},ly=t=>{let e=[];return t=t.replace(/\{[^}]+\}/g,(n,r)=>{let s=`@${r}`;return e.push([s,n]),s}),{groups:e,path:t}},cy=(t,e)=>{for(let n=e.length-1;n>=0;n--){let[r]=e[n];for(let s=t.length-1;s>=0;s--)if(t[s].includes(r)){t[s]=t[s].replace(r,e[n][1]);break}}return t},bi={},Ku=(t,e)=>{if(t==="*")return "*";let n=t.match(/^\:([^\{\}]+)(?:\{(.+)\})?$/);if(n){let r=`${t}#${e}`;return bi[r]||(n[2]?bi[r]=e&&e[0]!==":"&&e[0]!=="*"?[r,n[1],new RegExp(`^${n[2]}(?=/${e})`)]:[t,n[1],new RegExp(`^${n[2]}$`)]:bi[r]=[t,n[1],true]),bi[r]}return null},qn=(t,e)=>{try{return e(t)}catch{return t.replace(/(?:%[0-9A-Fa-f]{2})+/g,n=>{try{return e(n)}catch{return n}})}},uy=t=>qn(t,decodeURI),ba=t=>{let e=t.url,n=e.indexOf("/",e.indexOf(":")+4),r=n;for(;r<e.length;r++){let s=e.charCodeAt(r);if(s===37){let i=e.indexOf("?",r),o=e.indexOf("#",r),a=i===-1?o===-1?void 0:o:o===-1?i:Math.min(i,o),l=e.slice(n,a);return uy(l.includes("%25")?l.replace(/%25/g,"%2525"):l)}else if(s===63||s===35)break}return e.slice(n,r)};var Hu=t=>{let e=ba(t);return e.length>1&&e.at(-1)==="/"?e.slice(0,-1):e},pn=(t,e,...n)=>(n.length&&(e=pn(e,...n)),`${t?.[0]==="/"?"":"/"}${t}${e==="/"?"":`${t?.at(-1)==="/"?"":"/"}${e?.[0]==="/"?e.slice(1):e}`}`),wi=t=>{if(t.charCodeAt(t.length-1)!==63||!t.includes(":"))return null;let e=t.split("/"),n=[],r="";return e.forEach(s=>{if(s!==""&&!/\:/.test(s))r+="/"+s;else if(/\:/.test(s))if(/\?/.test(s)){n.length===0&&r===""?n.push("/"):n.push(r);let i=s.replace("?","");r+="/"+i,n.push(r);}else r+="/"+s;}),n.filter((s,i,o)=>o.indexOf(s)===i)},ga=t=>/[%+]/.test(t)?(t.indexOf("+")!==-1&&(t=t.replace(/\+/g," ")),t.indexOf("%")!==-1?qn(t,Or):t):t,zu=(t,e,n)=>{let r;if(!n&&e&&!/[%+]/.test(e)){let o=t.indexOf("?",8);if(o===-1)return;for(t.startsWith(e,o+1)||(o=t.indexOf(`&${e}`,o+1));o!==-1;){let a=t.charCodeAt(o+e.length+1);if(a===61){let l=o+e.length+2,c=t.indexOf("&",l);return ga(t.slice(l,c===-1?void 0:c))}else if(a==38||isNaN(a))return "";o=t.indexOf(`&${e}`,o+1);}if(r=/[%+]/.test(t),!r)return}let s={};r??=/[%+]/.test(t);let i=t.indexOf("?",8);for(;i!==-1;){let o=t.indexOf("&",i+1),a=t.indexOf("=",i);a>o&&o!==-1&&(a=-1);let l=t.slice(i+1,a===-1?o===-1?void 0:o:a);if(r&&(l=ga(l)),i=o,l==="")continue;let c;a===-1?c="":(c=t.slice(a+1,o===-1?void 0:o),r&&(c=ga(c))),n?(s[l]&&Array.isArray(s[l])||(s[l]=[]),s[l].push(c)):s[l]??=c;}return e?s[e]:s},Gu=zu,Vu=(t,e)=>zu(t,e,true),Or=decodeURIComponent;var Qu=t=>qn(t,Or),yi=class{raw;#e;#t;routeIndex=0;path;bodyCache={};constructor(t,e="/",n=[[]]){this.raw=t,this.path=e,this.#t=n,this.#e={};}param(t){return t?this.#n(t):this.#i()}#n(t){let e=this.#t[0][this.routeIndex][1][t],n=this.#r(e);return n&&/\%/.test(n)?Qu(n):n}#i(){let t={},e=Object.keys(this.#t[0][this.routeIndex][1]);for(let n of e){let r=this.#r(this.#t[0][this.routeIndex][1][n]);r!==void 0&&(t[n]=/\%/.test(r)?Qu(r):r);}return t}#r(t){return this.#t[1]?this.#t[1][t]:t}query(t){return Gu(this.url,t)}queries(t){return Vu(this.url,t)}header(t){if(t)return this.raw.headers.get(t)??void 0;let e={};return this.raw.headers.forEach((n,r)=>{e[r]=n;}),e}async parseBody(t){return this.bodyCache.parsedBody??=await Wu(this,t)}#s=t=>{let{bodyCache:e,raw:n}=this,r=e[t];if(r)return r;let s=Object.keys(e)[0];return s?e[s].then(i=>(s==="json"&&(i=JSON.stringify(i)),new Response(i)[t]())):e[t]=n[t]()};json(){return this.#s("text").then(t=>JSON.parse(t))}text(){return this.#s("text")}arrayBuffer(){return this.#s("arrayBuffer")}blob(){return this.#s("blob")}formData(){return this.#s("formData")}addValidatedData(t,e){this.#e[t]=e;}valid(t){return this.#e[t]}get url(){return this.raw.url}get method(){return this.raw.method}get[qu](){return this.#t}get matchedRoutes(){return this.#t[0].map(([[,t]])=>t)}get routePath(){return this.#t[0].map(([[,t]])=>t)[this.routeIndex].path}};var Ye={Stringify:1},K=(t,e)=>{let n=new String(t);return n.isEscaped=true,n.callbacks=e,n},fy=/[&<>'"]/,Si=async(t,e)=>{let n="";e||=[];let r=await Promise.all(t);for(let s=r.length-1;n+=r[s],s--,!(s<0);s--){let i=r[s];typeof i=="object"&&e.push(...i.callbacks||[]);let o=i.isEscaped;if(i=await(typeof i=="object"?i.toString():i),typeof i=="object"&&e.push(...i.callbacks||[]),i.isEscaped??o)n+=i;else {let a=[n];_t(i,a),n=a[0];}}return K(n,e)},_t=(t,e)=>{let n=t.search(fy);if(n===-1){e[0]+=t;return}let r,s,i=0;for(s=n;s<t.length;s++){switch(t.charCodeAt(s)){case 34:r=""";break;case 39:r="'";break;case 38:r="&";break;case 60:r="<";break;case 62:r=">";break;default:continue}e[0]+=t.substring(i,s)+r,i=s+1;}e[0]+=t.substring(i,s);},wa=t=>{let e=t.callbacks;if(!e?.length)return t;let n=[t],r={};return e.forEach(s=>s({phase:Ye.Stringify,buffer:n,context:r})),n[0]},mn=async(t,e,n,r,s)=>{typeof t=="object"&&!(t instanceof String)&&(t instanceof Promise||(t=t.toString()),t instanceof Promise&&(t=await t));let i=t.callbacks;if(!i?.length)return Promise.resolve(t);s?s[0]+=t:s=[t];let o=Promise.all(i.map(a=>a({phase:e,buffer:s,context:r}))).then(a=>Promise.all(a.filter(Boolean).map(l=>mn(l,e,false,r,s))).then(()=>s[0]));return n?K(await o,i):o};var dy="text/plain; charset=UTF-8",Sa=(t,e)=>({"Content-Type":t,...e}),$r=(t,e)=>new Response(t,e),Xu=class{#e;#t;env={};#n;finalized=false;error;#i;#r;#s;#u;#l;#c;#a;#f;#d;constructor(t,e){this.#e=t,e&&(this.#r=e.executionCtx,this.env=e.env,this.#c=e.notFoundHandler,this.#d=e.path,this.#f=e.matchResult);}get req(){return this.#t??=new yi(this.#e,this.#d,this.#f),this.#t}get event(){if(this.#r&&"respondWith"in this.#r)return this.#r;throw Error("This context has no FetchEvent")}get executionCtx(){if(this.#r)return this.#r;throw Error("This context has no ExecutionContext")}get res(){return this.#s||=$r(null,{headers:this.#a??=new Headers})}set res(t){if(this.#s&&t){t=$r(t.body,t);for(let[e,n]of this.#s.headers.entries())if(e!=="content-type")if(e==="set-cookie"){let r=this.#s.headers.getSetCookie();t.headers.delete("set-cookie");for(let s of r)t.headers.append("set-cookie",s);}else t.headers.set(e,n);}this.#s=t,this.finalized=true;}render=(...t)=>(this.#l??=e=>this.html(e),this.#l(...t));setLayout=t=>this.#u=t;getLayout=()=>this.#u;setRenderer=t=>{this.#l=t;};header=(t,e,n)=>{this.finalized&&(this.#s=$r(this.#s.body,this.#s));let r=this.#s?this.#s.headers:this.#a??=new Headers;e===void 0?r.delete(t):n?.append?r.append(t,e):r.set(t,e);};status=t=>{this.#i=t;};set=(t,e)=>{this.#n??=new Map,this.#n.set(t,e);};get=t=>this.#n?this.#n.get(t):void 0;get var(){return this.#n?Object.fromEntries(this.#n):{}}#o(t,e,n){let r=this.#s?new Headers(this.#s.headers):this.#a??new Headers;if(typeof e=="object"&&"headers"in e){let i=e.headers instanceof Headers?e.headers:new Headers(e.headers);for(let[o,a]of i)o.toLowerCase()==="set-cookie"?r.append(o,a):r.set(o,a);}if(n)for(let[i,o]of Object.entries(n))if(typeof o=="string")r.set(i,o);else {r.delete(i);for(let a of o)r.append(i,a);}let s=typeof e=="number"?e:e?.status??this.#i;return $r(t,{status:s,headers:r})}newResponse=(...t)=>this.#o(...t);body=(t,e,n)=>this.#o(t,e,n);text=(t,e,n)=>!this.#a&&!this.#i&&!e&&!n&&!this.finalized?new Response(t):this.#o(t,e,Sa(dy,n));json=(t,e,n)=>this.#o(JSON.stringify(t),e,Sa("application/json",n));html=(t,e,n)=>{let r=s=>this.#o(s,e,Sa("text/html; charset=UTF-8",n));return typeof t=="object"?mn(t,Ye.Stringify,false,{}).then(r):r(t)};redirect=(t,e)=>{let n=String(t);return this.header("Location",/[^\x00-\xFF]/.test(n)?encodeURI(n):n),this.newResponse(null,e??302)};notFound=()=>(this.#c??=()=>$r(),this.#c(this))};var Y="ALL",Yu="all",Zu=["get","post","put","delete","options","patch"],Ei="Can not add a route since the matcher is already built.",_i=class extends Error{};var ef="__COMPOSED_HANDLER";var py=t=>t.text("404 Not Found",404),tf=(t,e)=>{if("getResponse"in t){let n=t.getResponse();return e.newResponse(n.body,n)}return console.error(t),e.text("Internal Server Error",500)},nf=class rf{get;post;put;delete;options;patch;all;on;use;router;getPath;_basePath="/";#e="/";routes=[];constructor(e={}){[...Zu,Yu].forEach(i=>{this[i]=(o,...a)=>(typeof o=="string"?this.#e=o:this.#i(i,this.#e,o),a.forEach(l=>{this.#i(i,this.#e,l);}),this);}),this.on=(i,o,...a)=>{for(let l of [o].flat()){this.#e=l;for(let c of [i].flat())a.map(f=>{this.#i(c.toUpperCase(),this.#e,f);});}return this},this.use=(i,...o)=>(typeof i=="string"?this.#e=i:(this.#e="*",o.unshift(i)),o.forEach(a=>{this.#i(Y,this.#e,a);}),this);let{strict:r,...s}=e;Object.assign(this,s),this.getPath=r??true?e.getPath??ba:Hu;}#t(){let e=new rf({router:this.router,getPath:this.getPath});return e.errorHandler=this.errorHandler,e.#n=this.#n,e.routes=this.routes,e}#n=py;errorHandler=tf;route(e,n){let r=this.basePath(e);return n.routes.map(s=>{let i;n.errorHandler===tf?i=s.handler:(i=async(o,a)=>(await ha([],n.errorHandler)(o,()=>s.handler(o,a))).res,i[ef]=s.handler),r.#i(s.method,s.path,i);}),this}basePath(e){let n=this.#t();return n._basePath=pn(this._basePath,e),n}onError=e=>(this.errorHandler=e,this);notFound=e=>(this.#n=e,this);mount(e,n,r){let s,i;r&&(typeof r=="function"?i=r:(i=r.optionHandler,r.replaceRequest===false?s=l=>l:s=r.replaceRequest));let o=i?l=>{let c=i(l);return Array.isArray(c)?c:[c]}:l=>{let c;try{c=l.executionCtx;}catch{}return [l.env,c]};s||=(()=>{let l=pn(this._basePath,e),c=l==="/"?0:l.length;return f=>{let u=new URL(f.url);return u.pathname=u.pathname.slice(c)||"/",new Request(u,f)}})();let a=async(l,c)=>{let f=await n(s(l.req.raw),...o(l));if(f)return f;await c();};return this.#i(Y,pn(e,"*"),a),this}#i(e,n,r){e=e.toUpperCase(),n=pn(this._basePath,n);let s={basePath:this._basePath,path:n,method:e,handler:r};this.router.add(e,n,[r,s]),this.routes.push(s);}#r(e,n){if(e instanceof Error)return this.errorHandler(e,n);throw e}#s(e,n,r,s){if(s==="HEAD")return (async()=>new Response(null,await this.#s(e,n,r,"GET")))();let i=this.getPath(e,{env:r}),o=this.router.match(s,i),a=new Xu(e,{path:i,matchResult:o,env:r,executionCtx:n,notFoundHandler:this.#n});if(o[0].length===1){let c;try{c=o[0][0][0][0](a,async()=>{a.res=await this.#n(a);});}catch(f){return this.#r(f,a)}return c instanceof Promise?c.then(f=>f||(a.finalized?a.res:this.#n(a))).catch(f=>this.#r(f,a)):c??this.#n(a)}let l=ha(o[0],this.errorHandler,this.#n);return (async()=>{try{let c=await l(a);if(!c.finalized)throw new Error("Context is not finalized. Did you forget to return a Response object or `await next()`?");return c.res}catch(c){return this.#r(c,a)}})()}fetch=(e,...n)=>this.#s(e,n[1],n[0],e.method);request=(e,n,r,s)=>e instanceof Request?this.fetch(n?new Request(e,n):e,r,s):(e=e.toString(),this.fetch(new Request(/^https?:\/\//.test(e)?e:`http://localhost${pn("/",e)}`,n),r,s));fire=()=>{addEventListener("fetch",e=>{e.respondWith(this.#s(e.request,e,void 0,e.request.method));});}};var xi=[];function Ea(t,e){let n=this.buildAllMatchers(),r=((s,i)=>{let o=n[s]||n[Y],a=o[2][i];if(a)return a;let l=i.match(o[0]);if(!l)return [[],xi];let c=l.indexOf("",1);return [o[1][c],l]});return this.match=r,r(t,e)}var vi="[^/]+",Pr=".*",Nr="(?:|/.*)",hn=Symbol(),my=new Set(".\\+*[^]$()");function hy(t,e){return t.length===1?e.length===1?t<e?-1:1:-1:e.length===1||t===Pr||t===Nr?1:e===Pr||e===Nr?-1:t===vi?1:e===vi?-1:t.length===e.length?t<e?-1:1:e.length-t.length}var sf=class _a{#e;#t;#n=Object.create(null);insert(e,n,r,s,i){if(e.length===0){if(this.#e!==void 0)throw hn;if(i)return;this.#e=n;return}let[o,...a]=e,l=o==="*"?a.length===0?["","",Pr]:["","",vi]:o==="/*"?["","",Nr]:o.match(/^\:([^\{\}]+)(?:\{(.+)\})?$/),c;if(l){let f=l[1],u=l[2]||vi;if(f&&l[2]&&(u===".*"||(u=u.replace(/^\((?!\?:)(?=[^)]+\)$)/,"(?:"),/\((?!\?:)/.test(u))))throw hn;if(c=this.#n[u],!c){if(Object.keys(this.#n).some(d=>d!==Pr&&d!==Nr))throw hn;if(i)return;c=this.#n[u]=new _a,f!==""&&(c.#t=s.varIndex++);}!i&&f!==""&&r.push([f,c.#t]);}else if(c=this.#n[o],!c){if(Object.keys(this.#n).some(f=>f.length>1&&f!==Pr&&f!==Nr))throw hn;if(i)return;c=this.#n[o]=new _a;}c.insert(a,n,r,s,i);}buildRegExpStr(){let n=Object.keys(this.#n).sort(hy).map(r=>{let s=this.#n[r];return (typeof s.#t=="number"?`(${r})@${s.#t}`:my.has(r)?`\\${r}`:r)+s.buildRegExpStr()});return typeof this.#e=="number"&&n.unshift(`#${this.#e}`),n.length===0?"":n.length===1?n[0]:"(?:"+n.join("|")+")"}};var of=class{#e={varIndex:0};#t=new sf;insert(t,e,n){let r=[],s=[];for(let o=0;;){let a=false;if(t=t.replace(/\{[^}]+\}/g,l=>{let c=`@\\${o}`;return s[o]=[c,l],o++,a=true,c}),!a)break}let i=t.match(/(?::[^\/]+)|(?:\/\*$)|./g)||[];for(let o=s.length-1;o>=0;o--){let[a]=s[o];for(let l=i.length-1;l>=0;l--)if(i[l].indexOf(a)!==-1){i[l]=i[l].replace(a,s[o][1]);break}}return this.#t.insert(i,e,r,this.#e,n),r}buildRegExp(){let t=this.#t.buildRegExpStr();if(t==="")return [/^$/,[],[]];let e=0,n=[],r=[];return t=t.replace(/#(\d+)|@(\d+)|\.\*\$/g,(s,i,o)=>i!==void 0?(n[++e]=Number(i),"$()"):(o!==void 0&&(r[Number(o)]=++e),"")),[new RegExp(`^${t}`),n,r]}};var gy=[/^$/,[],Object.create(null)],af=Object.create(null);function lf(t){return af[t]??=new RegExp(t==="*"?"":`^${t.replace(/\/\*$|([.\\+*[^\]$()])/g,(e,n)=>n?`\\${n}`:"(?:|/.*)")}$`)}function yy(){af=Object.create(null);}function by(t){let e=new of,n=[];if(t.length===0)return gy;let r=t.map(c=>[!/\*|\/:/.test(c[0]),...c]).sort(([c,f],[u,d])=>c?1:u?-1:f.length-d.length),s=Object.create(null);for(let c=0,f=-1,u=r.length;c<u;c++){let[d,p,y]=r[c];d?s[p]=[y.map(([b])=>[b,Object.create(null)]),xi]:f++;let h;try{h=e.insert(p,f,d);}catch(b){throw b===hn?new _i(p):b}d||(n[f]=y.map(([b,m])=>{let w=Object.create(null);for(m-=1;m>=0;m--){let[_,S]=h[m];w[_]=S;}return [b,w]}));}let[i,o,a]=e.buildRegExp();for(let c=0,f=n.length;c<f;c++)for(let u=0,d=n[c].length;u<d;u++){let p=n[c][u]?.[1];if(!p)continue;let y=Object.keys(p);for(let h=0,b=y.length;h<b;h++)p[y[h]]=a[p[y[h]]];}let l=[];for(let c in o)l[c]=n[o[c]];return [i,l,s]}function Wn(t,e){if(t){for(let n of Object.keys(t).sort((r,s)=>s.length-r.length))if(lf(n).test(e))return [...t[n]]}}var Ci=class{name="RegExpRouter";#e;#t;constructor(){this.#e={[Y]:Object.create(null)},this.#t={[Y]:Object.create(null)};}add(t,e,n){let r=this.#e,s=this.#t;if(!r||!s)throw new Error(Ei);r[t]||[r,s].forEach(a=>{a[t]=Object.create(null),Object.keys(a[Y]).forEach(l=>{a[t][l]=[...a[Y][l]];});}),e==="/*"&&(e="*");let i=(e.match(/\/:/g)||[]).length;if(/\*$/.test(e)){let a=lf(e);t===Y?Object.keys(r).forEach(l=>{r[l][e]||=Wn(r[l],e)||Wn(r[Y],e)||[];}):r[t][e]||=Wn(r[t],e)||Wn(r[Y],e)||[],Object.keys(r).forEach(l=>{(t===Y||t===l)&&Object.keys(r[l]).forEach(c=>{a.test(c)&&r[l][c].push([n,i]);});}),Object.keys(s).forEach(l=>{(t===Y||t===l)&&Object.keys(s[l]).forEach(c=>a.test(c)&&s[l][c].push([n,i]));});return}let o=wi(e)||[e];for(let a=0,l=o.length;a<l;a++){let c=o[a];Object.keys(s).forEach(f=>{(t===Y||t===f)&&(s[f][c]||=[...Wn(r[f],c)||Wn(r[Y],c)||[]],s[f][c].push([n,i-l+a+1]));});}}match=Ea;buildAllMatchers(){let t=Object.create(null);return Object.keys(this.#t).concat(Object.keys(this.#e)).forEach(e=>{t[e]||=this.#n(e);}),this.#e=this.#t=void 0,yy(),t}#n(t){let e=[],n=t===Y;return [this.#e,this.#t].forEach(r=>{let s=r[t]?Object.keys(r[t]).map(i=>[i,r[t][i]]):[];s.length!==0?(n||=true,e.push(...s)):t!==Y&&e.push(...Object.keys(r[Y]).map(i=>[i,r[Y][i]]));}),n?by(e):null}};var xa=class{name="SmartRouter";#e=[];#t=[];constructor(t){this.#e=t.routers;}add(t,e,n){if(!this.#t)throw new Error(Ei);this.#t.push([t,e,n]);}match(t,e){if(!this.#t)throw new Error("Fatal error");let n=this.#e,r=this.#t,s=n.length,i=0,o;for(;i<s;i++){let a=n[i];try{for(let l=0,c=r.length;l<c;l++)a.add(...r[l]);o=a.match(t,e);}catch(l){if(l instanceof _i)continue;throw l}this.match=a.match.bind(a),this.#e=[a],this.#t=void 0;break}if(i===s)throw new Error("Fatal error");return this.name=`SmartRouter + ${this.activeRouter.name}`,o}get activeRouter(){if(this.#t||this.#e.length!==1)throw new Error("No active router has been determined yet.");return this.#e[0]}};var Ir=Object.create(null),wy=t=>{for(let e in t)return true;return false},cf=class uf{#e;#t;#n;#i=0;#r=Ir;constructor(e,n,r){if(this.#t=r||Object.create(null),this.#e=[],e&&n){let s=Object.create(null);s[e]={handler:n,possibleKeys:[],score:0},this.#e=[s];}this.#n=[];}insert(e,n,r){this.#i=++this.#i;let s=this,i=Ju(n),o=[];for(let a=0,l=i.length;a<l;a++){let c=i[a],f=i[a+1],u=Ku(c,f),d=Array.isArray(u)?u[0]:c;if(d in s.#t){s=s.#t[d],u&&o.push(u[1]);continue}s.#t[d]=new uf,u&&(s.#n.push(u),o.push(u[1])),s=s.#t[d];}return s.#e.push({[e]:{handler:r,possibleKeys:o.filter((a,l,c)=>c.indexOf(a)===l),score:this.#i}}),s}#s(e,n,r,s,i){for(let o=0,a=n.#e.length;o<a;o++){let l=n.#e[o],c=l[r]||l[Y],f={};if(c!==void 0&&(c.params=Object.create(null),e.push(c),s!==Ir||i&&i!==Ir))for(let u=0,d=c.possibleKeys.length;u<d;u++){let p=c.possibleKeys[u],y=f[c.score];c.params[p]=i?.[p]&&!y?i[p]:s[p]??i?.[p],f[c.score]=true;}}}search(e,n){let r=[];this.#r=Ir;let i=[this],o=ya(n),a=[],l=o.length,c=null;for(let f=0;f<l;f++){let u=o[f],d=f===l-1,p=[];for(let h=0,b=i.length;h<b;h++){let m=i[h],w=m.#t[u];w&&(w.#r=m.#r,d?(w.#t["*"]&&this.#s(r,w.#t["*"],e,m.#r),this.#s(r,w,e,m.#r)):p.push(w));for(let _=0,S=m.#n.length;_<S;_++){let E=m.#n[_],C=m.#r===Ir?{}:{...m.#r};if(E==="*"){let z=m.#t["*"];z&&(this.#s(r,z,e,m.#r),z.#r=C,p.push(z));continue}let[x,R,v]=E;if(!u&&!(v instanceof RegExp))continue;let k=m.#t[x];if(v instanceof RegExp){if(c===null){c=new Array(l);let ue=n[0]==="/"?1:0;for(let Xe=0;Xe<l;Xe++)c[Xe]=ue,ue+=o[Xe].length+1;}let z=n.substring(c[f]),I=v.exec(z);if(I){if(C[R]=I[0],this.#s(r,k,e,m.#r,C),wy(k.#t)){k.#r=C;let ue=I[0].match(/\//)?.length??0;(a[ue]||=[]).push(k);}continue}}(v===true||v.test(u))&&(C[R]=u,d?(this.#s(r,k,e,C,m.#r),k.#t["*"]&&this.#s(r,k.#t["*"],e,C,m.#r)):(k.#r=C,p.push(k)));}}let y=a.shift();i=y?p.concat(y):p;}return r.length>1&&r.sort((f,u)=>f.score-u.score),[r.map(({handler:f,params:u})=>[f,u])]}};var va=class{name="TrieRouter";#e;constructor(){this.#e=new cf;}add(t,e,n){let r=wi(e);if(r){for(let s=0,i=r.length;s<i;s++)this.#e.insert(t,r[s],n);return}this.#e.insert(t,e,n);}match(t,e){return this.#e.search(t,e)}};var Se=class extends nf{constructor(t={}){super(t),this.router=t.router??new xa({routers:[new Ci,new va]});}};var Ey=t=>JSON.parse(jsonStringify(t)),ff=new Se().get("/ping",t=>t.json({message:"pong"})).get("/config",t=>t.json(t.var.app.config)).get("/info",t=>t.json(Ey({connection:t.var.app.connection.config,config:t.var.app.config}))).get("/introspect",async t=>{let e=await t.var.app.connection.introspect();return t.json(e)});var Ae=class extends Error{code;details;hint;httpStatus;constructor(e){super(e.message),this.name="EmbedError",this.code=e.code,this.details=e.details,this.hint=e.hint,this.httpStatus=e.httpStatus;}},Me=class extends Error{constructor(n,r=n){super(n);this.details=r;this.name="SelectParseError";}},Qt=class extends Error{constructor(n,r=n){super(n);this.details=r;this.name="QueryParamParseError";}},Jn=class extends Error{constructor(n="Invalid path specified in request URL",r=null){super(n);this.details=r;this.name="RouteValidationError";}},pe=class extends Error{constructor(n,r,s){super(n);this.details=r;this.position=s;this.name="OrderParseError";}};var _y="/rest/v1";function Ca(t,e=_y){let n=new URL(t.url),r=decodeURIComponent(n.pathname);r.startsWith(e)&&(r=r.slice(e.length)),r=r.replace(/^\/+|\/+$/g,"");let s=r.split("/");if(s[0]==="rpc"&&s[1])return {function:s[1],isRpc:true};if(s.length>1)throw new Jn;return {from:s[0]||void 0,isRpc:false}}function Ra(t){let e=t.method.toUpperCase(),n;e==="GET"||e==="HEAD"?n=t.headers.get("Accept-Profile")??void 0:n=t.headers.get("Content-Profile")??void 0;let r=[],s=[],i=t.headers.get("Prefer");i&&s.push(i);for(let a of s){let l=a.split(",").map(c=>c.trim()).filter(Boolean);for(let c of l){let f=c.indexOf("=");if(f===-1)continue;let u=c.slice(0,f).trim(),d=c.slice(f+1).trim();u==="max-affected"?r.push({key:"max-affected",value:Number(d)}):r.push({key:u,value:d});}}let o=t.headers.get("Accept")??"application/json";return {schema:n,preferTokens:r,accept:o}}var df=new Set(["count","sum","avg","min","max"]);function F(t){return t.input[t.pos]??""}function L(t,e=1){t.pos+=e;}function Re(t){return t.pos>=t.input.length}function Oe(t,e){return t.input.startsWith(e,t.pos)}function ka(t){return /^[a-zA-Z0-9_]$/.test(t)}function B(t){for(;!Re(t)&&/\s/.test(F(t));)L(t);}function Oa(t){let n=new URL(t.url).searchParams.get("select");if(n==null)return {select:[],join:{},embeddedAliases:new Set};if(n==="")return {select:[],join:{},embeddedAliases:new Set};if(n.trim()==="")throw new Me("failed to parse select parameter");let r={},s=new Set,i={input:n,pos:0},o=hf(i,r,s);if(B(i),!Re(i))throw new Error(`Unexpected input at position ${i.pos}: "${i.input.slice(i.pos)}"`);return {select:o,join:r,embeddedAliases:s}}function hf(t,e,n){let r=[];if(B(t),Re(t)||F(t)===")"||F(t)===","&&(L(t),B(t),Re(t)||F(t)===")"))return r;for(r.push(pf(t,e,n));!Re(t)&&(B(t),F(t)===",");)L(t),B(t),r.push(pf(t,e,n));return r}function pf(t,e,n){if(B(t),F(t)==="*")return L(t),"*";if(Oe(t,"..."))return L(t,3),B(t),xy(t,e,n);let r=lt(t,{allowSpaces:true,allowDollar:true});return B(t),Oe(t,"::")?Aa(r,void 0,t,e,n):F(t)===":"?(L(t),B(t),vy(r,t,e,n)):Aa(r,void 0,t,e,n)}function xy(t,e,n){let r=lt(t);B(t);let{hint:s,innerJoin:i}=gf(t);if(B(t),F(t)!=="(")throw new Error(`Expected "(" for spread embed at position ${t.pos}`);let{subSelect:o,subJoin:a}=yf(t),l=r,c={};i&&(c.type="inner"),s&&(c.hint=s),e[l]=c,n.add(l);let f={spread:true,select:o};return Object.keys(a).length>0&&(f.join=a),{[l]:f}}function vy(t,e,n,r){let s=lt(e,{allowSpaces:true,allowDollar:true});return B(e),Aa(s,t,e,n,r)}function Aa(t,e,n,r,s){return B(n),t==="count"&&(Re(n)||F(n)===","||F(n)===")"||F(n)==="("||Oe(n,"::"))?Ry(e,n):F(n)==="!"||F(n)==="("?Cy(t,e,n,r,s):Ty(t,e,n)}function Cy(t,e,n,r,s){let{hint:i,innerJoin:o}=gf(n);if(B(n),F(n)!=="(")throw new Me("failed to parse select parameter");let{subSelect:a,subJoin:l}=yf(n),c=e??t,f={};e&&(f.from=t),o&&(f.type="inner"),i&&(f.hint=i),r[c]=f,s.add(c),e&&t!==c&&s.add(t);let u={select:a};return Object.keys(l).length>0&&(u.join=l),{[c]:u}}function gf(t){if(B(t),F(t)!=="!")return {};L(t);let e=lt(t);if(e==="inner")return {innerJoin:true};if(e==="left")return {};let n=e;if(B(t),F(t)==="!"){L(t);let r=lt(t);if(r==="inner")return {hint:n,innerJoin:true};if(r==="left")return {hint:n};throw new Error(`Expected "inner" or "left" after hint, got "${r}" at position ${t.pos}`)}return {hint:n}}function yf(t,e,n){if(F(t)!=="(")throw new Error(`Expected "(" at position ${t.pos}`);L(t),B(t);let r={},s=new Set;if(F(t)===")")return L(t),{subSelect:[],subJoin:r};let i=hf(t,r,s);if(B(t),F(t)!==")")throw new Error(`Expected ")" at position ${t.pos}`);return L(t),{subSelect:i,subJoin:r}}function Ry(t,e){B(e);let n=true;if(F(e)==="("){n=false,L(e);let o=e.pos;for(;!Re(e)&&F(e)!==")";)L(e);if(Re(e))throw new Me("expected closing paren for count()");let a=e.input.slice(o,e.pos).trim();if(L(e),a!=="")throw new Me("expected null arg for count()")}B(e);let r;Oe(e,"::")&&(L(e,2),r=Dr(e));let s=t??"count",i={aggregate:"count"};return n&&(i.bareCount=true),r&&(i.cast=r),{[s]:i}}function Ty(t,e,n){B(n);let r,s,i=false,o;if(Oe(n,"->")){let{path:f,lastProp:u,lastIsText:d,invalidTextTraversalKey:p}=ky(n);r=f,s=u||void 0,i=d,o=p;}B(n);let a,l;if(Oe(n,"::")){L(n,2);let f=Dr(n);if(B(n),F(n)==="."&&!Re(n)){let u=n.input[n.pos+1]??"";if(ka(u)){let d=n.pos;L(n);let p=lt(n);if(df.has(p)&&Oe(n,"()"))return a=f,L(n,2),B(n),Oe(n,"::")&&(L(n,2),l=Dr(n),Ta(n)),mf(t,e,r,s,i,o,a,p,l);n.pos=d;}}l=f,Ta(n);}let c;if(F(n)==="."&&!Re(n)){let f=n.input[n.pos+1]??"";if(ka(f)){let u=n.pos;L(n);let d=lt(n);df.has(d)&&Oe(n,"()")?(c=d,L(n,2),B(n),Oe(n,"::")&&(L(n,2),l=Dr(n),Ta(n))):n.pos=u;}}return mf(t,e,r,s,i,o,a,c,l)}function Ta(t){for(B(t);Oe(t,"::");)L(t,2),Dr(t),B(t);}function Dr(t){B(t);let e=[lt(t)];for(;!Re(t);){let n=t.pos;if(B(t),t.pos===n)break;let r=F(t);if(!(r==='"'||/^[a-zA-Z0-9_]$/.test(r))){t.pos=n;break}e.push(lt(t));}return e.join(" ")}function mf(t,e,n,r,s,i,o,a,l){let c=e??(a||void 0)??r;if(!c&&!o&&!l&&!a&&!n)return t;let f=c??t,u={};return t!==f&&(u.column=t),a&&!u.column&&t===f&&(u.column=t),n&&(u.column||(u.column=t),u.path=n,s&&(u.pathText=true),i&&(u.invalidJsonTextTraversalKey=i)),o&&(u.preCast=o),a&&(u.aggregate=a),l&&(u.cast=l),{[f]:u}}function ky(t){let e=[],n="",r=false,s;for(;Oe(t,"->");){let o=r;L(t,2);let a=false;F(t)===">"&&(L(t),a=true);let l=Ay(t);e.push(l),o&&s===void 0&&(s=l),/^-?\d+$/.test(l)||(n=l),r=a;}return {path:"$."+e.join("."),lastProp:n,lastIsText:r,invalidTextTraversalKey:s}}function Ay(t){return Oy(t)}function Oy(t){B(t);let e=t.pos;if(F(t)==='"')return lt(t);let n="";for(;!Re(t)&&!(Oe(t,"->")||Oe(t,"::"));){let r=F(t);if(r===","||r==="."||r===":"||/\s/.test(r))break;n+=r,L(t);}if(n==="")throw new Me(`"failed to parse select parameter (${t.input})" (line 1, column ${e+1})`);if(n.includes("--")||n.endsWith("-"))throw new Me("failed to parse select parameter");if(/^-\d+\D/.test(n))throw new Me("failed to parse select parameter");return n}function lt(t,e={}){if(B(t),F(t)==='"'){L(t);let r="";for(;!Re(t)&&F(t)!=='"';)r+=F(t),L(t);if(Re(t))throw new Error(`Missing closing quote at position ${t.pos}`);return L(t),r}let n="";for(;!Re(t);){let r=F(t);if(ka(r))n+=r,L(t);else if(e.allowDollar&&r==="$")n+=r,L(t);else if(e.allowSpaces&&r===" ")n+=r,L(t);else if(r==="-"&&n.length>0){if((t.input[t.pos+1]??"")===">")break;n+=r,L(t);}else break}if(e.allowSpaces&&(n=n.trimEnd()),n==="")throw new Error(`Expected identifier at position ${t.pos}`);if(n.includes("--")||n.endsWith("-"))throw new Me("failed to parse select parameter");return n}async function $a(t){let e=t.method.toUpperCase();if(e==="GET"||e==="HEAD")return {};let n=await t.text(),r=t.headers.get("Content-Type")??"";if(!n&&r.includes("text/csv"))throw new Kn('parse error (not enough input) at ""');if(!n)return {};if(r.includes("application/json"))try{let s=JSON.parse(n);return Array.isArray(s)?{values:s}:{values:s}}catch{throw new Error(`Invalid JSON body: ${n.slice(0,100)}`)}if(r.includes("text/csv"))return {values:$y(n)};if(r.includes("application/x-www-form-urlencoded")){let s=new URLSearchParams(n),i={};for(let[o,a]of s)i[o]=a;return {values:i}}return {raw:n}}function $y(t){let e=t.replace(/\r\n/g,`
|
|
66
76
|
`).replace(/\r/g,`
|
|
67
|
-
`),
|
|
68
|
-
`);){let{row:
|
|
69
|
-
`)return
|
|
70
|
-
`;)i+=s[t],t++;r.push(i),t<n&&s[t]===","&&t++;}}return {row:r,nextPos:t}}var jr=class extends Error{constructor(e){super(e),this.name="CsvParseError";}};function yo(s){let e=new URL(s.url),r=new Map;for(let[t,n]of e.searchParams.entries()){let i=r.get(t)??[];i.push(n),r.set(t,i);}return r}function Eo(s,e,r){let t=e.toUpperCase();if(s.isRpc)return "rpc";switch(t){case "GET":case "HEAD":return "query";case "POST":return r.preferTokens.find(i=>i.key==="resolution"&&(i.value==="merge-duplicates"||i.value==="ignore-duplicates"))?"upsert":"insert";case "PATCH":return "update";case "PUT":return "put";case "DELETE":return "delete";default:return "query"}}var jc=new Set(["eq","neq","gt","gte","lt","lte","like","ilike","match","imatch","is","isdistinct","in","cs","cd","ov","sl","sr","nxl","nxr","adj","fts","plfts","phfts","wfts","not"]),Dc={eq:"$eq",neq:"$neq",gt:"$gt",gte:"$gte",lt:"$lt",lte:"$lte",like:"$like",ilike:"$ilike",match:"$regex",imatch:"$iregex",is:"$is",isdistinct:"$isDistinct",in:"$in",cs:"$contains",cd:"$containedBy",ov:"$overlaps",sl:"$rangeLt",sr:"$rangeGt",nxl:"$rangeGte",nxr:"$rangeLte",adj:"$rangeAdjacent"},$g={any:"Any",all:"All"},Pg=new Set(["eq","gt","gte","lt","lte","like","ilike","match","imatch"]),Dg={fts:void 0,plfts:"plain",phfts:"phrase",wfts:"websearch"};function So(s){let e=s.match(/^(\w+)\((any|all)\)$/);if(e){let[,n,i]=e;if(!Pg.has(n))return null;let a=Dc[n];return a?{astOp:a+$g[i]}:null}let r=s.match(/^(p[lh]fts|wfts|fts)(?:\(([^)]+)\))?$/);if(r){let[,n,i]=r;return i!==void 0&&!/^[A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)?$/.test(i)?null:{astOp:"$textSearch",ftsType:Dg[n],ftsConfig:i}}let t=Dc[s];return t?{astOp:t}:null}function As(s){let e=s.indexOf(".");if(e===-1)return false;let t=s.substring(0,e).replace(/\((any|all)\)$/,"");return jc.has(t)}var cr=new Set(["select","order","limit","offset","on_conflict","columns"]);function Rs(s){if(s.startsWith("(")&&s.endsWith(")")&&(s=s.slice(1,-1)),s.trim()==="")return [];let e=[],r=0;for(;r<s.length;){if(s[r]==='"'){r++;let t="";for(;r<s.length&&s[r]!=='"';)s[r]==="\\"&&r+1<s.length&&r++,t+=s[r],r++;r<s.length&&r++,e.push(t);}else {let t="";for(;r<s.length&&s[r]!==",";)t+=s[r],r++;e.push(wt(t,{preserveWhitespace:true}));}r<s.length&&s[r]===","&&(r++,r===s.length&&e.push(""));}return e}function _s(s){if(s.startsWith("{")&&s.endsWith("}")&&(s=s.slice(1,-1)),s==="")return [];let e=[],r=0;for(;r<s.length;){if(s[r]==='"'){r++;let t="";for(;r<s.length&&s[r]!=='"';)s[r]==="\\"&&r+1<s.length&&r++,t+=s[r],r++;r<s.length&&r++,e.push(t);}else {let t="";for(;r<s.length&&s[r]!==",";)t+=s[r],r++;e.push(wt(t));}r<s.length&&s[r]===","&&r++;}return e}var di=Symbol.for("postgrest:not_null"),pr=Symbol.for("postgrest:unknown");function wt(s,e){let r=e?.preserveWhitespace===true,t=s.trim();if(t.startsWith('"')&&t.endsWith('"')&&t.length>=2)return t.slice(1,-1);let n=t.toLowerCase();if(n==="null")return null;if(n==="not_null")return di;if(n==="true")return true;if(n==="false")return false;if(n==="unknown")return null;if(t!==""&&!Number.isNaN(Number(t))&&Number.isFinite(Number(t)))return Number(t);if(t.startsWith("{")&&t.endsWith("}"))try{let i=JSON.parse(t);if(typeof i=="object"&&!Array.isArray(i))return i}catch{}return r?t===""?"":s:t}function wo(s,e){let r={},t={};for(let[n,i]of s){if(cr.has(n))continue;let o=n.startsWith('"')?-1:n.indexOf(".");if(o>0&&!n.slice(0,o).includes("->")){let l=n.slice(0,o),u=n.slice(o+1);if(e.has(l)){if(u==="order"||u==="limit"||u==="offset")continue;if(u.includes(".")){let p=u.lastIndexOf("."),c=u.slice(p+1);if(c==="order"||c==="limit"||c==="offset")continue}t[l]||(t[l]={}),xg(u,i,t[l]);continue}if(n!=="not.or"&&n!=="not.and")throw jg(l)}To(n,i,r);}return {where:r,embeddedWheres:t}}function jg(s){return new Ne({httpStatus:400,code:"PGRST108",message:`'${s}' is not an embedded resource in this request`,details:null,hint:`Verify that '${s}' is included in the 'select' query parameter.`})}function To(s,e,r){if(s==="or"||s==="and"){let n=e.map(a=>xc(a)),i=n.length===1?n[0]:n.flat();r[`$${s}`]=i;return}if(s==="not.or"||s==="not.and"){let n=s.slice(4),i=e.map(o=>xc(o)),a=i.length===1?i[0]:i.flat();r.$not={[`$${n}`]:a};return}let t=Bc(Fg(s),{stopAtSpace:false});Mc(t);for(let n of e){let i=Uc(n);r[t]?Object.assign(r[t],i):r[t]=i;}}function xg(s,e,r){let t=Ug(s);if(!t){To(s,e,r);return}let n={};To(t.filterKey,e,n);for(let[i,a]of Object.entries(n))r[`${t.path}.${i}`]=a;}function Ug(s){for(let e of ["not.or","not.and","or","and"]){let r=`.${e}`;if(s.endsWith(r)){let t=s.slice(0,-r.length);if((e==="or"||e==="and")&&t==="not")continue;if(t)return {path:t,filterKey:e}}}}function Uc(s){let e=s,r=false;e.startsWith("not.")&&(r=true,e=e.slice(4));let t=e.indexOf("."),n,i;t===-1?(n=e,i=""):(n=e.slice(0,t),i=e.slice(t+1));let a=So(n);if(!a)throw new Error(`"failed to parse filter (${s})" (line 1, column 1)`);let{astOp:o,ftsType:l,ftsConfig:u}=a;if(r&&o==="$in")return {$notIn:bo(o,i)};if(r&&o==="$is")return {$isNot:bo(o,i)};let p=o==="$textSearch"?Mg(i,l,u):bo(o,i);return r?{$not:{[o]:p}}:{[o]:p}}function bo(s,e){if(s==="$in"||s==="$notIn"){if(!e.startsWith("(")||!e.endsWith(")")){let r=s==="$in"?"in":"not.in";throw new Error(`"failed to parse filter (${r}.${e})" (line 1, column ${r.length+e.length+2})`)}return Rs(e)}if(s.endsWith("Any")||s.endsWith("All")){if(e.startsWith("{"))return _s(e);if(!Bg(s))throw Object.assign(new Error(`malformed array literal: "${e}"`),{code:"22P02",detail:'Array value must start with "{" or dimension information.'});return Rs(e)}if(s==="$contains"||s==="$containedBy"||s==="$overlaps"){if(e.startsWith("{")){try{let r=JSON.parse(e);if(typeof r=="object"&&!Array.isArray(r))return r}catch{}return _s(e)}return e.startsWith("[")||e.startsWith("(")?e:wt(e)}if(s.startsWith("$range"))return e;if(s==="$is"){let r=e.toLowerCase().trim();if(!["null","true","false","unknown","not_null"].includes(r))throw new Error(`"failed to parse filter (is.${e})" (line 1, column ${2+e.length})`);return r==="unknown"?pr:wt(e)}if(s==="$like"||s==="$ilike"||s==="$likeAny"||s==="$ilikeAny"||s==="$likeAll"||s==="$ilikeAll"){let r=e.replace(/\*/g,"%");return s.endsWith("Any")||s.endsWith("All")?r.startsWith("{")?_s(r):Rs(r):r}return s==="$isDistinct"?e:wt(e)}function Bg(s){return s==="$likeAny"||s==="$ilikeAny"||s==="$likeAll"||s==="$ilikeAll"}function Mg(s,e,r){let t={query:s};return e&&(t.type=e),r&&(t.config=r),t}function xc(s){if(!s.startsWith("(")||!s.endsWith(")"))throw new Error(`"failed to parse logic tree (${s})" (line 1, column ${s.length+3})`);let e=s.slice(1,-1);for(;e.endsWith(")");){let r=0;for(let t of e)t==="("?r++:t===")"&&r--;if(r<0)e=e.slice(0,e.length+r);else break}if(e.trim()==="")throw new Error(`"failed to parse logic tree (${s})" (line 1, column ${s.length+2})`);try{return vs(e).map(t=>Os(t))}catch{throw new Error(`"failed to parse logic tree (${s})" (line 1, column ${s.length+2})`)}}function vs(s){let e=[],r=0,t=0,n=false,i="";for(let a of s)if(a==='"'&&!n?n=true:a==='"'&&n&&(n=false),n||(a==="("?r++:a===")"?r--:a==="{"?t++:a==="}"&&t--),a===","&&r===0&&t===0&&!n){if(i.trim()==="")throw new Error("empty logical expression");e.push(i.trim()),i="";}else i+=a;if(i.trim())e.push(i.trim());else if(s.trim().endsWith(","))throw new Error("empty logical expression");return e}function Os(s){let e=s.trim(),r=e.match(/^and\s*\((.*)\)$/s);if(r)return {$and:vs(r[1]).map(f=>Os(f))};let t=e.match(/^or\s*\((.*)\)$/s);if(t)return {$or:vs(t[1]).map(f=>Os(f))};let n=e.match(/^not\.and\s*\((.*)\)$/s);if(n)return {$not:{$and:vs(n[1]).map(f=>Os(f))}};let i=e.match(/^not\.or\s*\((.*)\)$/s);if(i)return {$not:{$or:vs(i[1]).map(f=>Os(f))}};if(/^(?:and|or|not)=/.test(e))throw new Error(`Invalid filter expression: "${s}"`);if(e.startsWith("not.")||e.startsWith("not("))throw new Error(`Invalid filter expression: "${s}"`);let a=s,o=false;a.startsWith("not.")&&(o=true,a=a.slice(4));let l=a.indexOf(".");if(l===-1)throw new Error(`Invalid filter expression: "${s}"`);let u=Bc(a.slice(0,l),{stopAtSpace:true});Mc(u);let p=a.slice(l+1),c=Uc(o?`not.${p}`:p);return {[u]:c}}function Bc(s,e){let t=(e.stopAtSpace?/[!@/\\~[\]()\t ]/:/[!@/\\~[\]()\t]/).exec(s);return t?s.slice(0,t.index):s}function Fg(s){return s.length>=2&&s.startsWith('"')&&s.endsWith('"')?s.slice(1,-1).replace(/""/g,'"'):s}function Mc(s){if(s===""||s==="*"||s.includes("--")||s.endsWith("-"))throw new Error(`Invalid filter expression: "${s}"`);if(/->>?-\d+\D/.test(s))throw new Error(`Invalid filter expression: "${s}"`)}function qg(s){let e=s.match(/^([a-zA-Z_][a-zA-Z0-9_]*)\(([^)]+)\)$/);return e?{embed:e[1],column:e[2]}:null}function Fc(s){if(s===void 0)return;let e=s.trim();if(!/^[+-]?\d+$/.test(e))return;let r=Number(e);return Number.isFinite(r)?r:void 0}function Co(s,e){let r=Fc(s),t=Fc(e);return t!==void 0&&t<0&&(r!==void 0&&r>=0&&(r=Math.max(0,r+t)),t=void 0),{limit:r,offset:t}}function Ro(s,e){let r={embeddedTransforms:{}},t,n,i={},a={},o={},l={};for(let[f,m]of s){let d=m[0],g=f.indexOf(".");if(g>0){let b=f.slice(0,g),y=f.slice(g+1);if(e.has(b)){if(y==="order"||y==="limit"||y==="offset"){r.embeddedTransforms[b]||(r.embeddedTransforms[b]={}),y==="order"?r.embeddedTransforms[b].order=Ao(d):y==="limit"?i[b]=d:y==="offset"&&(a[b]=d);continue}if(y.includes(".")){let T=y.lastIndexOf("."),C=y.slice(T+1);if(C==="order"||C==="limit"||C==="offset"){r.embeddedTransforms[b]||(r.embeddedTransforms[b]={});let w=r.embeddedTransforms[b],A=y.slice(0,T);w._nested||(w._nested={});let v=w._nested;v[A]||(v[A]={});let R=v[A];C==="order"?R.order=Ao(d):C==="limit"?(o[b]||(o[b]={}),o[b][A]=d):C==="offset"&&(l[b]||(l[b]={}),l[b][A]=d);continue}}}}f==="order"?r.order=Ao(d):f==="limit"?t=d:f==="offset"&&(n=d);}if(r.order){for(let f of r.order)if(f.embed&&!e.has(f.embed))throw new Ne({httpStatus:400,code:"PGRST108",message:`'${f.embed}' is not an embedded resource in this request`,details:null,hint:`Verify that '${f.embed}' is included in the 'select' query parameter.`})}let u=Co(t,n);u.limit!==void 0&&(r.limit=u.limit),u.offset!==void 0&&(r.offset=u.offset);let p=new Set([...Object.keys(i),...Object.keys(a)]);for(let f of p){let m=Co(i[f],a[f]);r.embeddedTransforms[f]||(r.embeddedTransforms[f]={}),m.limit!==void 0&&(r.embeddedTransforms[f].limit=m.limit),m.offset!==void 0&&(r.embeddedTransforms[f].offset=m.offset);}let c=new Set([...Object.keys(o),...Object.keys(l)]);for(let f of c){let m=new Set([...Object.keys(o[f]??{}),...Object.keys(l[f]??{})]);for(let d of m){let g=Co(o[f]?.[d],l[f]?.[d]),b=r.embeddedTransforms[f]?._nested?.[d];b&&(g.limit!==void 0&&(b.limit=g.limit),g.offset!==void 0&&(b.offset=g.offset));}}return r}function Ao(s){return Jg(s).map(({entry:e,start:r})=>Wg(e.trim(),s,r+e.length-e.trimStart().length))}function Jg(s){let e=[],r=0,t=0;for(let n=0;n<s.length;n++){let i=s[n];i==="("?r++:i===")"?r=Math.max(0,r-1):i===","&&r===0&&(e.push({entry:s.slice(t,n),start:t}),t=n+1);}return e.push({entry:s.slice(t),start:t}),e}function Wg(s,e,r){let t=s.split("."),n={column:t[0]},i=t[0];if(!i)throw new me(`failed to parse order (${e})`,'unexpected end of input expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input',1);let a=i.indexOf("::");if(a!==-1)throw new me(`failed to parse order (${e})`,`unexpected ':' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,r+a+1);let o=i.indexOf("--");if(o!==-1)throw new me(`failed to parse order (${e})`,`unexpected '-' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,r+o+2);let l=i.search(/[@#%]/);if(l!==-1)throw new me(`failed to parse order (${e})`,`unexpected '${i[l]}' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,r+l+1);if(i.endsWith("-"))throw new me(`failed to parse order (${e})`,`unexpected '-' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,r+i.length);let u=i.indexOf(":");if(u!==-1)throw new me(`failed to parse order (${e})`,`unexpected ':' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,r+u+1);let p=qg(i);if(p){if(p.column.includes(","))throw new me(`failed to parse order (${e})`,`unexpected ',' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,r+i.indexOf(",",p.embed.length)+1);n.column=p.column,n.embed=p.embed;}let c=r+i.length+1,f=false,m=false;for(let d=1;d<t.length;d++){let g=t[d];if(g==="asc"||g==="desc"){if(f)throw new me(`failed to parse order (${e})`,`unexpected '${g[0]}' expecting "," or end of input`,c+1);if(m)throw new me(`failed to parse order (${e})`,`unexpected '${g[0]}' expecting "," or end of input`,c+1);n.direction=g,f=true,c+=g.length+1;}else if(g==="nullsfirst"||g==="nullslast"){if(m)throw new me(`failed to parse order (${e})`,`unexpected '${g[0]}' expecting "," or end of input`,c+1);n.nullsFirst=g==="nullsfirst",m=true,c+=g.length+1;}else {let b=["asc","desc","nullsfirst","nullslast"],y=null;for(let T of b)if(g.startsWith(T)&&g.length>T.length){y=T;break}if(y){let T=g[y.length],C=c+y.length;throw new me(`failed to parse order (${e})`,`unexpected '${T}' expecting "," or end of input`,C+1)}throw new me(`failed to parse order (${e})`,`unexpected '${g[0]}' expecting "," or end of input`,c+1)}}return n}function _o(s,e,r){let t={};for(let i of s.preferTokens)switch(i.key){case "count":t.count=i.value;break;case "missing":t.missing=i.value;break;case "handling":t.handling=i.value;break;case "tx":t.tx=i.value,i.value==="rollback"&&(t.rollback=true);break;case "max-affected":t.maxAffected=i.value;break;case "timezone":t.timezone=i.value;break;case "return":t.return=i.value;break}r.toUpperCase()==="HEAD"&&(t.head=true),s.accept.includes("application/vnd.pgrst.object")&&(t.cardinality="one"),s.accept.includes("application/vnd.pgrst.plan")&&(t.explain=Vg(s.accept));let n=e.get("columns");if(n){let i=n[0];t.columns=Hg("columns",i);}return t}function Hg(s,e){let r=e.split(",").map(t=>Gg(t));if(r.length===0||r.some(t=>t===""||t==="*"||t.includes("--")||t.endsWith("-")))throw new Vt(`"failed to parse ${s} parameter (${e})" (line 1, column 1)`,"unexpected input");return r}function Gg(s){let e=s.trim();return e.startsWith('"')&&e.endsWith('"')?e.slice(1,-1):e.replace(/@.*$/,"")}function Vg(s){let e={},r=s.match(/options=([^;]+)/);if(r){let t=r[1].split("|").map(n=>n.trim());e.analyze=t.includes("analyze"),e.verbose=t.includes("verbose"),e.settings=t.includes("settings"),e.buffers=t.includes("buffers"),e.wal=t.includes("wal");}return e}function vo(s,e,r,t){if(!s.isRpc)return {};if(e.toUpperCase()==="POST"){let o={httpMethod:"POST"};return t.values?(Array.isArray(t.values)?(o.args=t.values,o.paramsType="positional"):(o.args=t.values,o.paramsType="named"),o.inputType="json"):t.raw!==void 0&&(o.args={_raw:t.raw},o.inputType="text"),o}let i={};for(let[o,l]of r){if(cr.has(o))continue;let u=l[0];As(u)||(i[o]=wt(u));}let a={httpMethod:"GET",paramsType:"named",inputType:"json"};return Object.keys(i).length>0&&(a.args=i),a}function Oo(s,e){let r=s.get("on_conflict"),t=r===void 0?void 0:Kg(r[0]),i=e.preferTokens.find(a=>a.key==="resolution")?.value==="ignore-duplicates";return {onConflict:t?.length?t:void 0,ignoreDuplicates:i}}function Kg(s){let e=s.split(",").map(r=>r.trim());if(e.length===0||e.some(r=>r===""||r.includes("--")||r.endsWith("-")))throw new Vt(`"failed to parse on_conflict parameter (${s})" (line 1, column 1)`,"unexpected input");return e}async function gi(s,e){let r=e?.basePath,t=e?.parseRoute??(K=>uo(K,r)),n=e?.parseHeaders??co,i=e?.parseSelect??ho,a=e?.parseBody??go,o=e?.parseQueryParams??yo,l=e?.resolveType??Eo,u=e?.resolveFilters??wo,p=e?.resolveTransforms??Ro,c=e?.resolveMeta??_o,f=e?.resolveRpcParams??vo,m=e?.resolveUpsertParams??Oo,[d,g,b,y,T]=await Promise.all([t(s),n(s),i(s),a(s),o(s)]),C=s.method,w=l(d,C,g),A=T;if(d.isRpc&&C.toUpperCase()==="GET"){A=new Map;for(let[K,D]of T){if(cr.has(K)){A.set(K,D);continue}let ce=D.filter(Xe=>As(Xe));ce.length>0&&A.set(K,ce);}}let v=u(A,b.embeddedAliases),R=p(T,b.embeddedAliases),O=c(g,T,C),_=f(d,C,T,y),I=w==="upsert"||w==="put"?m(T,g):void 0;return Yg(w,d,g,b,y,v,R,O,_,I)}function Yg(s,e,r,t,n,i,a,o,l,u){let p={type:s};return e.isRpc?p.function=e.function:p.from=e.from,r.schema&&(p.schema=r.schema),Object.keys(t.join).length>0&&(p.join=t.join),t.select.length>0&&(p.select=qc(t.select,i.embeddedWheres,a.embeddedTransforms,t.join)),Object.keys(i.where).length>0&&(p.where=i.where),(s==="insert"||s==="update"||s==="upsert"||s==="put")&&n.values!==void 0&&(p.values=n.values),s==="rpc"&&(l.args!==void 0&&(p.args=l.args),l.httpMethod&&(p.httpMethod=l.httpMethod),l.paramsType&&(p.paramsType=l.paramsType),l.inputType&&(p.inputType=l.inputType)),(s==="upsert"||s==="put")&&u&&(u.onConflict&&(p.onConflict=u.onConflict),p.ignoreDuplicates=u.ignoreDuplicates),o.return==="representation"&&(s==="insert"||s==="update"||s==="delete"||s==="upsert"||s==="put")&&(!p.select||p.select.length===0)&&(p.select=["*"]),a.order&&(p.order=a.order),a.limit!==void 0&&(p.limit=a.limit),a.offset!==void 0&&(p.offset=a.offset),Object.keys(o).length>0&&(p.$meta=o),p}function qc(s,e,r,t){return s.map(n=>{if(typeof n=="string")return n;let i=Object.keys(n)[0],a=n[i];if(!a.select)return n;let o={...a},l=t?.[i]?.from,u=e[i]||l&&e[l],p=r[i]||l&&r[l];if(u){let c={},f={};for(let[m,d]of Object.entries(u)){let g=m.indexOf(".");if(g>0){let b=m.slice(0,g),y=m.slice(g+1);if(o.join?.[b]||o.select?.some(w=>typeof w=="object"&&b in w&&"select"in(w[b]??{}))){f[b]||(f[b]={}),f[b][y]=d;continue}}c[m]=d;}Object.keys(c).length>0&&(o.where=c);for(let[m,d]of Object.entries(f))e[m]={...e[m],...d};}if(p){let c=p;if(c.order&&(o.order=c.order),c.limit!==void 0&&(o.limit=c.limit),c.offset!==void 0&&(o.offset=c.offset),c._nested)for(let[f,m]of Object.entries(c._nested))r[f]=m;}return o.select&&(o.select=qc(o.select,e,r,o.join)),{[i]:o}})}function yi(s){return s!=null&&typeof s=="object"&&"$ref"in s}var zg=/^[a-zA-Z_][a-zA-Z0-9_.]*$/,Xg=/[;'"\\/*\-#]/,Qg=/['\\;(]/,Ct=class extends Error{constructor(r,t){super(`Unsafe ${t}: "${r}"`);this.value=r;this.context=t;this.name="SanitizeError";}};function At(s,e){if(!zg.test(s))throw new Ct(s,e)}function No(s,e){if(Xg.test(s))throw new Ct(s,e);let r=0;for(let t of s)if(t==="("?r++:t===")"&&r--,r<0)throw new Ct(s,e);if(r!==0)throw new Ct(s,e)}function xr(s,e){if(Qg.test(s))throw new Ct(s,e)}function fr(s){let e=s.indexOf("->");if(e===-1)return {col:s,parts:[]};let r=s.slice(0,e),t=s.slice(e),n=[];for(;t.length>0;){let i;if(t.startsWith("->>"))i="->>",t=t.slice(3);else if(t.startsWith("->"))i="->",t=t.slice(2);else break;let a=t.indexOf("->"),o=a===-1?t:t.slice(0,a);n.push({op:i,key:o}),t=a===-1?"":t.slice(a);}return {col:r,parts:n}}function Ns(s,e){return s.map(r=>{let t=/^-?\d+$/.test(r.key);return t||xr(r.key,e),t?`${r.op}${r.key}`:`${r.op}'${r.key}'`}).join("")}function L(s){return typeof s=="string"?sql.ref(s):s}function Zg(s){return `"${s.replace(/"/g,'""')}"`}function Jc(s){return sql.raw(Zg(s))}function Wc(s,e,r=e.currentTable,t=e.currentSchema){if(!r||!e.introspection?.columns)return;let n=e.introspection.columns.filter(i=>i.table===r&&i.name===s);if(n.length!==0)return n.find(i=>!t||i.schema===t)??n.find(i=>["","public"].includes(i.schema??""))??n[0]}function Ei(s,e,r=e.currentTable,t=e.currentSchema){return Wc(s,e,r,t)!==void 0}function ae(s,e,r=e.currentTable){return Ei(s,e,r)?Jc(s):sql.ref(s)}function Kt(s,e,r,t=r.currentTable){let n=Ei(e,r,t)?Jc(e):sql.ref(e);return sql`${sql.ref(s)}.${n}`}function ey(s){return (s?.pg_type??s?.type??"").toLowerCase()}function Hc(s,e,r=e.currentTable){if(e.dialect!=="postgres")return false;let t=ey(Wc(s,e,r));return t.endsWith("[]")||t.startsWith("_")||t==="array"}function Gc(s){let e=[];for(let r of s){if(!/^\d+$/.test(r))return;e.push(`[${Number(r)+1}]`);}return e.join("")}function Vc(s,e,r,t=r.currentTable,n=false){let i=e.replace(/^\$\./,"").split(".").filter(Boolean);if(i.length===0)return ae(s,r,t);if(Hc(s,r,t)){let l=Gc(i);if(l)return sql`${ae(s,r,t)}${sql.raw(l)}`}let a=i.map((l,u)=>({op:u===i.length-1&&n?"->>":"->",key:l})),o=Ns(a,"JSON path key");return sql`${ae(s,r,t)}${sql.raw(o)}`}function Is(s,e,r=e.currentTable,t){let{col:n,parts:i}=fr(s),a=t?Kt(t,n,e,r):ae(n,e,r);if(i.length===0)return a;if(Hc(n,e,r)){let u=Gc(i.map(p=>p.key));if(u)return sql`${a}${sql.raw(u)}`}let o=e.dialect==="sqlite"?i.map((u,p)=>p===i.length-1?{...u,op:"->>"}:u):i,l=Ns(o,"JSON path key");return sql`${a}${sql.raw(l)}`}var Si={$eq:(s,e,r)=>sql`${L(e)} = ${r}`,$neq:(s,e,r)=>sql`${L(e)} != ${r}`,$gt:(s,e,r)=>sql`${L(e)} > ${r}`,$gte:(s,e,r)=>sql`${L(e)} >= ${r}`,$lt:(s,e,r)=>sql`${L(e)} < ${r}`,$lte:(s,e,r)=>sql`${L(e)} <= ${r}`,$like:(s,e,r)=>sql`${L(e)} like ${r}`,$is:(s,e,r)=>{let t=L(e);return r===di?sql`${t} IS NOT NULL`:r===pr?sql`${t} IS UNKNOWN`:r===null?sql`${t} IS NULL`:r===true?sql`${t} IS TRUE`:r===false?sql`${t} IS FALSE`:sql`${t} IS NULL`},$isNot:(s,e,r)=>{let t=L(e);return r===di?sql`${t} IS NULL`:r===pr?sql`${t} IS NOT UNKNOWN`:r===null?sql`${t} IS NOT NULL`:r===true?sql`${t} IS NOT TRUE`:r===false?sql`${t} IS NOT FALSE`:sql`${t} IS NOT NULL`},$in:(s,e,r)=>{if(Array.isArray(r)&&r.length===0)return sql`false`;let t=L(e);return Array.isArray(r)?sql`${t} in (${sql.join(r.map(n=>sql`${n}`))})`:sql`${t} in ${r}`},$notIn:(s,e,r)=>{if(Array.isArray(r)&&r.length===0)return sql`true`;let t=L(e);return Array.isArray(r)?sql`${t} not in (${sql.join(r.map(n=>sql`${n}`))})`:sql`${t} not in ${r}`},$isDistinct:(s,e,r)=>sql`${L(e)} is distinct from ${r}`},bi={$eq:"=",$neq:"!=",$gt:">",$gte:">=",$lt:"<",$lte:"<="};function Io(s){return s!=null&&typeof s=="object"&&s.type==="query"}function Ti(s,e){let r=e.db;return s.schema&&(r=r.withSchema(s.schema)),Lo(s,e,r)}function ty(s){return s.includes("->")}function zc(s,e){let{col:r,parts:t}=fr(s);return t.length===0?ae(s,e):Is(s,e)}function ke(s,e,r){let t=[];for(let[n,i]of Object.entries(e)){if(n==="$always"){i===false&&t.push(sql`0 = 1`);continue}if(n==="$or"){let a=i;t.push(s.or(a.map(o=>ke(s,o,r))));}else if(n==="$and"){let a=i;t.push(s.and(a.map(o=>ke(s,o,r))));}else if(n==="$not")t.push(s.not(ke(s,i,r)));else if(n==="$exists"){let a=i;t.push(s.exists(Ti(a,r)));}else {let a=i,o=ty(n);for(let[l,u]of Object.entries(a)){if(yi(u)){let p=bi[l];if(!p)throw new Error(`Unsupported ref operator: ${l}`);t.push(sql`${o?zc(n,r):ae(n,r)} ${sql.raw(p)} ${ae(u.$ref,r)}`);continue}if(l==="$not"){let p=u;for(let[c,f]of Object.entries(p))if(o)t.push(s.not(Yc(n,c,f,r)));else {let m=Kc(n,c,f,r);if(m){t.push(s.not(m));continue}let d=r.operators[c];if(!d)throw new Error(`Unsupported operator: ${c}`);t.push(s.not(d(s,ae(n,r),f)));}}else if(Io(u)){let p=Ti(u,r),c=r.operators[l];if(!c)throw new Error(`Unsupported operator: ${l}`);t.push(c(s,ae(n,r),p));}else if(o)t.push(Yc(n,l,u,r));else {let p=Kc(n,l,u,r);if(p){t.push(p);continue}let c=ry(n,l,u,r);if(c){t.push(c);continue}let f=r.operators[l];if(!f)throw new Error(`Unsupported operator: ${l}`);t.push(f(s,ae(n,r),u));}}}}return t.length===1?t[0]:s.and(t)}function Kc(s,e,r,t){if(e!=="$is"&&e!=="$isNot"||r!==pr)return null;let n=Xc(s,t);if(!n)return null;let i=Qc(n.pg_type??n.type);if(i==="boolean")return t.dialect!=="sqlite"?null:e==="$is"?sql`${ae(s,t)} IS NULL`:sql`${ae(s,t)} IS NOT NULL`;throw Object.assign(new Error(`argument of IS UNKNOWN must be type boolean, not type ${i}`),{code:"42804",detail:null})}function Xc(s,e){if(!e.introspection?.columns||!e.currentTable)return null;let r=s.includes("->")?fr(s).col:s,t=e.introspection.columns.filter(i=>i.table===e.currentTable&&i.name===r);if(t.length===0)return null;let n=e.currentSchema;return t.find(i=>!n||i.schema===n)??t.find(i=>["","public"].includes(i.schema??""))??t[0]}function Qc(s){switch(s.toLowerCase()){case "bool":return "boolean";case "int8":case "bigserial":case "serial8":return "bigint";case "int4":case "serial":case "serial4":return "integer";case "int2":return "smallint";default:return s.toLowerCase()}}function ry(s,e,r,t){if(t.dialect!=="postgres"||e!=="$eq"&&e!=="$neq"||typeof r!="string"||!/^\s*[[{]/.test(r))return null;let n=Xc(s,t),i=Qc(n?.pg_type??n?.type??"");if(i!=="json"&&i!=="jsonb")return null;let a=ae(s,t),o=sql`cast(${sql.raw(sy(r))} as ${sql.raw(i)})`;return e==="$eq"?sql`${a} = ${o}`:sql`${a} != ${o}`}function sy(s){return `'${s.replace(/'/g,"''")}'`}function Yc(s,e,r,t){let n=t?zc(s,t):L(s),a={$eq:"=",$neq:"!=",$gt:">",$gte:">=",$lt:"<",$lte:"<=",$like:"like",$ilike:"ilike"}[e];if(a)return sql`${n} ${sql.raw(a)} ${r}`;if(e==="$is")return r===null?sql`${n} IS NULL`:r===true?sql`${n} IS TRUE`:r===false?sql`${n} IS FALSE`:sql`${n} IS NULL`;if(e==="$isNot")return r===null?sql`${n} IS NOT NULL`:r===true?sql`${n} IS NOT TRUE`:r===false?sql`${n} IS NOT FALSE`:sql`${n} IS NOT NULL`;if(e==="$in"){if(t&&Io(r))return sql`${n} in ${Ti(r,t)}`;let o=r;return o.length===0?sql`false`:sql`${n} in (${sql.join(o.map(l=>sql`${l}`))})`}if(e==="$notIn"){if(t&&Io(r))return sql`${n} not in ${Ti(r,t)}`;let o=r;return o.length===0?sql`true`:sql`${n} not in (${sql.join(o.map(l=>sql`${l}`))})`}return sql`${n} = ${r}`}function ue(s){return "select"in s||"spread"in s||"join"in s}function Ri(s,e,r,t,n,i=false){if(!e||e.length===0)return s.selectAll();for(let a of e)if(typeof a=="string")if(a==="*")s=i&&n?s.selectAll(n):s.selectAll();else if(/^-?\d+(?:\.\d+)?$/.test(a))s=s.select(sql.lit(Number(a)).as("_lit"));else if(my(a,r,n)){let o=i&&n?Kt(n,a,r,n):ae(a,r,n);s=s.select(sql`json(${o})`.as(a));}else s=i&&n&&!a.includes(".")?s.select(Kt(n,a,r,n).as(a)):!/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(a)&&Ei(a,r,n)?s.select(ae(a,r,n).as(a)):s.select(a);else for(let[o,l]of Object.entries(a))ue(l)?s=_y(s,o,l,r,t,n):s=oy(s,o,l,r,n,i);return s}function ks(s,e){if(!e||e.length===0)return s;for(let r of e)if(typeof r=="string")s=r==="*"?s.returningAll():s.returning(r);else for(let[t,n]of Object.entries(r)){if(ue(n))continue;let i=n.column||t;s=s.returning(i);}return s}function mr(s,e,r,t,n,i=false){let a;if(r.aggregate==="count"&&!r.column&&!r.path)a=s.fn.countAll();else {let o=r.column||e;if(r.invalidJsonTextTraversalKey&&t.dialect==="postgres")throw Object.assign(new Error(`operator does not exist: text -> ${ny(r.invalidJsonTextTraversalKey)}`),{code:"42883",detail:null,hint:"No operator matches the given name and argument types. You might need to add explicit type casts."});a=r.path?Vc(o,r.path,t,n,r.pathText===true):n&&i?Kt(n,o,t,n):ae(o,t,n),r.preCast&&(No(r.preCast,"pre-cast type"),a=sql`cast(${a} as ${sql.raw(r.preCast)})`),r.aggregate&&(a=sql`${sql.raw(r.aggregate)}(${a})`);}return r.cast&&(No(r.cast,"cast type"),a=t.dialect==="sqlite"&&(iy(r.cast)||ay(r.cast))?sql`json(${a})`:sql`cast(${a} as ${sql.raw(r.cast)})`),a}function ny(s){return /^-?\d+$/.test(s)?"integer":"unknown"}function iy(s){let e=s.trim().toLowerCase();return e==="json"||e==="jsonb"}function ay(s){let e=s.trim().toLowerCase();return e.startsWith("_")||e.endsWith("[]")}function oy(s,e,r,t,n,i=false){return s.select(a=>mr(a,e,r,t,n,i).as(e))}function ly(s){if(!s)return false;for(let e of s)if(typeof e!="string"){for(let r of Object.values(e))if(!ue(r)&&r.aggregate)return true}return false}function uy(s){if(!s)return false;for(let e of s)if(typeof e!="string"){for(let r of Object.values(e))if(ue(r)&&r.spread&&$o(r.select))return true}return false}function cy(s){if(!s)return false;for(let e of s)if(typeof e!="string"){for(let r of Object.values(e))if(ue(r)&&r.spread)return true}return false}function py(s){return ly(s)||uy(s)}function $o(s){if(!s)return false;for(let e of s)if(typeof e!="string")for(let r of Object.values(e)){if(ue(r)){if($o(r.select))return true;continue}if(r.aggregate)return true}return false}function Po(s){if(!s)return false;for(let e of s)if(typeof e!="string")for(let r of Object.values(e)){if(ue(r)){if(r.spread)continue;if(Po(r.select))return true;continue}let t=r;if(t.aggregate&&!t.bareCount)return true}return false}function Do(s,e,r,t,n){if(!py(e))return s;let i=[];for(let a of e){if(typeof a=="string"){if(a==="*")continue;i.push(ae(a,r,t));continue}for(let[o,l]of Object.entries(a)){if(ue(l))continue;let u=l;u.aggregate||i.push(p=>mr(p,o,u,r,t));}}return fy(i,e,r,t,n),i.length===0?s:s.groupBy(i)}function fy(s,e,r,t,n){if(!(!e||!t||!r.introspection?.foreign_keys)){for(let i of e)if(typeof i!="string")for(let[a,o]of Object.entries(i)){if(!ue(o)||!o.spread)continue;let l=o,u=n?.[a],p=u?.from||a;p=_t(p,t,r.introspection);let c=ve(r.introspection,t,p,u?.hint),f=c?.type==="m2o"||c?.type==="o2m"&<(c,p,r.introspection);if(!c||!f)continue;let m=_i(l.select,p,r.introspection)??l.select??[],d=`_spread_${a}`;for(let g of m){if(typeof g=="string"){g!=="*"&&s.push(`${d}.${g}`);continue}let[b,y]=Object.entries(g)[0];ue(y)||y.aggregate||s.push(T=>mr(T,b,y,r,d,true));}}}}function ep(s,e,r,t,n){if(!s||!e||!t||!n.introspection?.foreign_keys)return s;let i=new Set;for(let a of e)if(typeof a!="string")for(let[o,l]of Object.entries(a)){if(!ue(l)||!l.spread)continue;let u=r?.[o],p=u?.from||o;p=_t(p,t,n.introspection);let c=ve(n.introspection,t,p,u?.hint),f=c?.type==="m2o"||c?.type==="o2m"&<(c,p,n.introspection);c&&f&&i.add(o);}return i.size===0?s:s.map(a=>a.embed&&i.has(a.embed)?{...a,embed:`_spread_${a.embed}`}:a)}function tp(s,e,r,t){if(!s||!r||!t.introspection?.foreign_keys)return false;for(let n of s)if(typeof n!="string")for(let[i,a]of Object.entries(n)){if(!ue(a)||!a.spread)continue;let o=e?.[i],l=o?.from||i;l=_t(l,r,t.introspection);let u=ve(t.introspection,r,l,o?.hint),p=u?.type==="m2o"||u?.type==="o2m"&<(u,l,t.introspection);if(u&&p)return true}return false}function wi(s){let e=new Map;for(let r of s){let t=r.foreign_key_name,n=e.get(t);n?n.push(r):e.set(t,[r]);}return [...e.values()]}function jo(s,e,r,t){s=s.innerJoin(e.junctionTable,n=>{let i=n;for(let a=0;a<e.junctionToTargetCols.length;a++)i=i.onRef(`${e.junctionTable}.${e.junctionToTargetCols[a]}`,"=",`${r}.${e.targetCols[a]}`);return i});for(let n=0;n<e.junctionToParentCols.length;n++)s=s.whereRef(`${e.junctionTable}.${e.junctionToParentCols[n]}`,"=",`${t}.${e.parentCols[n]}`);return s}function xo(s,e,r,t,n=r){let i=n===r?r:`${r} as ${n}`;if(e.type==="m2o"){let[,l]=e.leftCol.split("."),[,u]=e.rightCol.split(".");return s.leftJoin(i,p=>p.onRef(`${n}.${u}`,"=",`${t}.${l}`))}let[,a]=e.leftCol.split("."),[,o]=e.rightCol.split(".");return s.leftJoin(i,l=>l.onRef(`${n}.${a}`,"=",`${t}.${o}`))}function $s(s,e,r,t,n){let i=new Set;if(!e||!t.introspection?.foreign_keys)return {sub:s,joined:i};for(let a of e){if(!a.embed||i.has(a.embed))continue;At(a.embed,"order embed alias");let o=n?.[a.embed],l=Bo(a.embed,o,r,t.introspection);l!==a.embed&&At(l,"order embed target");let u=ve(t.introspection,r,l,o?.hint),p=u?.type==="m2o"||u?.type==="o2m"&<(u,l,t.introspection);!u||!p||(s=xo(s,u,l,r,a.embed),i.add(a.embed),i.add(l));}return {sub:s,joined:i}}function rp(s){return s&&s.map(e=>e.embed&&e.nullsFirst===void 0?{...e,nullsFirst:e.direction==="desc"}:e)}function ko(s,e){let r={};for(let[t,n]of Object.entries(s))t==="$or"||t==="$and"?r[t]=n.map(i=>ko(i,e)):t==="$not"?r[t]=ko(n,e):t.startsWith("$")||t.includes(".")?r[t]=n:r[`${e}.${t}`]=n;return r}function Ci(s,e,r){let t=r.includes(".")?r.split(".").pop():r,n=s.introspection?.columns?.find(a=>a.table===e&&a.name===t),i=(n?.pg_type||n?.type||"").toLowerCase();return i==="json"||i==="jsonb"}function my(s,e,r){return e.dialect==="sqlite"&&r!==void 0&&/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(s)&&Ci(e,r,s)}function hy(s,e){if(!s)return false;let r=e.includes(".")?e.split(".").pop():e;return s.some(t=>t.column.includes("->")?t.column.slice(0,t.column.indexOf("->"))===r:false)}function Ls(s,e,r,t){return Ci(s,e,r)||hy(t,r)}function dy(s,e,r){if(!s)return null;let t=[];for(let n of s){if(typeof n=="string"){if(n==="*")return null;let l=n.includes(".")?n.split(".").pop():n;t.push({alias:l,asJson:Ci(r,e,l)});continue}let[i,a]=Object.entries(n)[0];if(!i||!a)continue;if(ue(a))return null;let o=Ci(r,e,a.column||i);t.push({alias:i,asJson:o});}return t}function gy(s,e,r,t){let n=dy(e,r,t);if(!n||n.length===0)return t.jsonObjectFrom(s);let i=n.flatMap(a=>[sql.lit(a.alias),a.asJson?sql`json(${sql.ref(`obj.${a.alias}`)})`:sql.ref(`obj.${a.alias}`)]);return sql`(select json_object(${sql.join(i)}) from ${s} as obj)`}function yy(s){return s==="m2o"?"many-to-one":s==="o2m"?"one-to-many":"many-to-many"}function Ey(s,e,r){return s.fk?s.type==="m2m"?`${s.fk.foreign_key_name} using ${s.junctionTable}(${s.fk.column}) and ${e}(${s.fk.ref_column})`:`${s.fk.foreign_key_name} using ${s.fk.table}(${s.fk.column}) and ${s.fk.ref_table}(${s.fk.ref_column})`:""}function Sy(s,e){if(!s||!e)return null;let r=[];for(let n of s.tables??[])r.push(n.name);for(let n of s.views??[])r.push(n.name);let t=r.find(n=>n.length===e.length+1&&n.startsWith(e));return t?`Perhaps you meant '${t}' instead of '${e}'.`:null}function Uo(s,e,r,t){let n=s?.foreign_keys?.find(a=>a.table===e||a.ref_table===e)?.schema||"test",i=t?` using the hint '${t}'`:"";throw new Ne({httpStatus:400,code:"PGRST200",message:`Could not find a relationship between '${e}' and '${r}' in the schema cache`,details:`Searched for a foreign key relationship between '${e}' and '${r}'${i} in the schema '${n}', but no matches were found.`,hint:Sy(s,r)})}function ve(s,e,r,t){if(!s||!s.foreign_keys)return null;let n=s.foreign_keys.filter(m=>m.is_visible!==false);if(t){let m=n.find(A=>A.foreign_key_name===t);if(m){if(m.table===e&&m.ref_table===r)return {leftCol:`${e}.${m.column}`,rightCol:`${r}.${m.ref_column}`,type:"m2o"};if(m.table===r&&m.ref_table===e)return {leftCol:`${r}.${m.column}`,rightCol:`${e}.${m.ref_column}`,type:"o2m"}}let d=n.find(A=>A.table===e&&A.column===t&&A.ref_table===r);if(d)return {leftCol:`${e}.${d.column}`,rightCol:`${r}.${d.ref_column}`,type:"m2o"};let g=n.find(A=>A.table===r&&A.column===t&&A.ref_table===e);if(g)return {leftCol:`${r}.${g.column}`,rightCol:`${e}.${g.ref_column}`,type:"o2m"};let b=n.filter(A=>A.table===t),y=wi(b.filter(A=>A.ref_table===e)),T=wi(b.filter(A=>A.ref_table===r));if(y.length>0&&T.length>0){let A=y[0],v=T[0];return {type:"m2m",junctionTable:t,junctionToParentCols:A.map(R=>R.column),parentCols:A.map(R=>R.ref_column),junctionToTargetCols:v.map(R=>R.column),targetCols:v.map(R=>R.ref_column)}}let C=n.find(A=>A.table===r&&A.ref_column===t&&A.ref_table===e);if(C)return {leftCol:`${r}.${C.column}`,rightCol:`${e}.${C.ref_column}`,type:"o2m"};let w=n.find(A=>A.table===e&&A.ref_column===t&&A.ref_table===r);if(w)return {leftCol:`${e}.${w.column}`,rightCol:`${r}.${w.ref_column}`,type:"m2o"};Uo(s,e,r,t);}if(e===r){let m=n.find(d=>d.table===r&&d.ref_table===e);if(m)return {leftCol:`${r}.${m.column}`,rightCol:`${e}.${m.ref_column}`,type:"o2m"}}let i=n.filter(m=>m.table===e&&m.ref_table===r),a=[...new Map(i.map(m=>[m.foreign_key_name,m])).values()],o=n.filter(m=>m.table===r&&m.ref_table===e),l=[...new Map(o.map(m=>[m.foreign_key_name,m])).values()],u=[],p=wi(n.filter(m=>m.ref_table===e));for(let m of p){let d=m[0].table;if(d===e||d===r)continue;let g=n.filter(b=>b.table===d&&b.ref_table===r);if(g.length!==0)for(let b of wi(g))u.push({type:"m2m",junctionTable:d,junctionToParentCols:m.map(y=>y.column),parentCols:m.map(y=>y.ref_column),junctionToTargetCols:b.map(y=>y.column),targetCols:b.map(y=>y.ref_column),fk:m[0]});}if(a.length+l.length+u.length===0)return null;if(a.length>1||l.length>1){let m=[...a.map(y=>({leftCol:`${e}.${y.column}`,rightCol:`${r}.${y.ref_column}`,type:"m2o",fk:y})),...l.map(y=>({leftCol:`${r}.${y.column}`,rightCol:`${e}.${y.ref_column}`,type:"o2m",fk:y})),...u],d=m.map(y=>({cardinality:yy(y.type),embedding:`${e} with ${r}`,relationship:Ey(y,e)})),b=m.map(y=>y.fk?.foreign_key_name).filter(Boolean).map(y=>`'${r}!${y}'`).join(", ");throw new Ne({httpStatus:300,code:"PGRST201",message:`Could not embed because more than one relationship was found for '${e}' and '${r}'`,details:d,hint:b?`Try changing '${r}' to one of the following: ${b}. Find the desired relationship in the 'details' key.`:null})}if(a.length===1){let m=a[0];return {leftCol:`${e}.${m.column}`,rightCol:`${r}.${m.ref_column}`,type:"m2o"}}if(l.length===1){let m=l[0];return {leftCol:`${r}.${m.column}`,rightCol:`${e}.${m.ref_column}`,type:"o2m"}}return u.length===1?u[0]:null}function sp(s,e,r,t){if(!(!s||!r||!t.introspection?.foreign_keys))for(let n of s){if(!n.embed)continue;let i=e?.[n.embed],a=Bo(n.embed,i,r,t.introspection),o=ve(t.introspection,r,a,i?.hint);if(!o)continue;if(!(o.type==="m2o"||o.type==="o2m"&<(o,a,t.introspection)))throw new Ne({httpStatus:400,code:"PGRST118",message:`A related order on '${n.embed}' is not possible`,details:`'${r}' and '${n.embed}' do not form a many-to-one or one-to-one relationship`,hint:null})}}function _t(s,e,r){if(!r?.foreign_keys||r.tables?.some(l=>l.name===s)||r.views?.some(l=>l.name===s))return s;let n=r.foreign_keys,i=n.find(l=>l.table===e&&l.column===s);if(i)return i.ref_table;let a=n.find(l=>l.foreign_key_name===s&&(l.table===e||l.ref_table===e));if(a)return a.table===e?a.ref_table:a.table;let o=n.find(l=>l.ref_table===e&&l.ref_column===s);return o?o.table:s}function Zc(s,e,r,t,n,i){let a=n?.[e],o=a?.from||e;i&&(o=_t(o,i,t.introspection));let l=i?ve(t.introspection,i,o,a?.hint):null;return s.where(u=>{let p=u.selectFrom(o).select(sql`1`.as("_"));return a?.on?p=p.where(c=>ke(c,a.on,t)):l&&l.type==="m2m"?p=jo(p,l,o,i):l?p=p.whereRef(l.leftCol,"=",l.rightCol):i&&(p=p.whereRef(`${o}.${i}_id`,"=",`${i}.id`)),r.where&&Object.keys(r.where).length>0&&(p=p.where(c=>ke(c,r.where,t))),u.exists(p)})}function lt(s,e,r){if(!r||s.type!=="o2m")return false;let t=s.leftCol.split(".")[1];return r.indexes?.some(a=>a.table===e&&a.unique&&a.columns.length===1&&a.columns[0]===t)||r.unique_constraints?.some(a=>a.table===e&&a.columns.length===1&&a.columns[0]===t)?true:r.primary_keys?.some(a=>a.table===e&&a.columns.length===1&&a.columns[0]===t)??false}function by(s,e){return s&&s.map(r=>typeof r!="string"||r==="*"||r.includes(".")||/^-?\d+(?:\.\d+)?$/.test(r)?r:`${e}.${r}`)}function Ps(s){if(typeof s=="string")return {colAlias:s,colName:s};let e=Object.keys(s)[0],r=s[e];return {colAlias:e,colName:r?.column||e}}function Ty(s,e,r,t,n,i){if(!r.select||!i)return s;let a=n?.[e],o=a?.from||e;o=_t(o,i,t.introspection);let l=ve(t.introspection,i,o,a?.hint),u=_i(r.select,o,t.introspection)??r.select;if(!t.introspection?.foreign_keys)return Ry(s,u,o,i,l);if(!l)throw new Ne({httpStatus:400,code:"PGRST120",message:"Could not embed because the relationship is not a one-to-one or many-to-one",details:null,hint:null});if(!(l.type==="m2o"||l.type==="o2m"&<(l,o,t.introspection))){if($o(r.select))throw new Ne({httpStatus:400,code:"PGRST127",message:"Feature not implemented",details:"Aggregates are not implemented for one-to-many or many-to-many spreads.",hint:null});return Cy(s,u,r,l,o,i,t)}let c=`_spread_${e}`,[f,m]=l.leftCol.split("."),[,d]=l.rightCol.split("."),g=f===o?m:d,b=f===i?m:d,y="__spread_join_key",T=[],C=new Set;for(let w of u){if(typeof w=="string"&&w==="*")continue;let A;if(typeof w!="string"){let O=Object.values(w)[0];if(ue(O))continue;A=O;}let{colAlias:v,colName:R}=Ps(w);T.push({src:R,out:v,def:A}),C.add(R);}s=s.leftJoin(w=>{let A=w.selectFrom(o);A=A.select(`${o}.${g} as ${y}`);for(let v of C)A=A.select(`${o}.${v} as ${v}`);return A.as(c)},w=>w.onRef(`${c}.${y}`,"=",`${i}.${b}`));for(let{out:w,def:A}of T)A?s=s.select(v=>mr(v,w,A,t,c,true).as(w)):s=s.select(`${c}.${w}`);return s}function wy(s,e,r,t){for(let n of s){if(typeof n=="string")continue;let i=Object.values(n)[0];if(!ue(i))continue;let{colAlias:a}=Ps(n),o=e.join?.[a],l=_t(o?.from||a,r,t.introspection),u=ve(t.introspection,r,l,o?.hint);if(!u||u.type!=="o2m"||!lt(u,l,t.introspection))continue;let p=t.introspection?.primary_keys?.find(c=>c.table===l);if(p?.columns?.length)return {nestedTargetTable:l,fkRel:u,pkColumns:p.columns}}return null}function Cy(s,e,r,t,n,i,a){let o=r.order?null:wy(e,r,n,a);for(let l of e){if(typeof l=="string"&&l==="*")continue;let u=typeof l=="string"?null:Object.values(l)[0],p=u!==null&&ue(u),c=p&&u.spread,{colAlias:f,colName:m}=Ps(l);if(c){s=Ay(s,f,u,r,t,n,i,a);continue}s=s.select(d=>{let g=d.selectFrom(n);if(g=Ai(g,t,n,i),r.where&&Object.keys(r.where).length>0&&(g=g.where(b=>ke(b,r.where,a))),r.order&&(g=$s(g,r.order,n,a,r.join).sub,g=Rt(g,rp(r.order),void 0,a,n)),r.limit!==void 0&&(g=g.limit(r.limit)),r.offset!==void 0&&(g=g.offset(r.offset)),o&&(g=xo(g,o.fkRel,o.nestedTargetTable,n),g=Rt(g,o.pkColumns.map(b=>({column:b,embed:o.nestedTargetTable})),void 0,a)),p){let b=r.join?.[f];return g=g.select(y=>np(y,f,u,a,b,n).as("value")),a.jsonScalarArrayFrom(g,"value",true).as(f)}else return u!==null?(g=g.select(b=>mr(b,m,u,a,n).as("value")),a.jsonScalarArrayFrom(g,"value",Ls(a,n,m,r.order)).as(f)):(g=g.select(`${n}.${m} as value`),a.jsonScalarArrayFrom(g,"value",Ls(a,n,m,r.order)).as(f))});}return s}function Ay(s,e,r,t,n,i,a,o){let l=t.join?.[e],u=_t(l?.from||e,i,o.introspection),p=ve(o.introspection,i,u,l?.hint),c=_i(r.select,u,o.introspection)??r.select??[],f=p?.type==="m2o"||p?.type==="o2m"&<(p,u,o.introspection);for(let m of c){if(typeof m=="string"&&m==="*")continue;let d=typeof m=="string"?null:Object.values(m)[0],{colAlias:g,colName:b}=Ps(m);s=s.select(y=>{let T=y.selectFrom(i);T=Ai(T,n,i,a),t.where&&Object.keys(t.where).length>0&&(T=T.where(w=>ke(w,t.where,o)));let C=$s(T,t.order,i,o,t.join);if(T=C.sub,t.order&&(T=Rt(T,rp(t.order),void 0,o,i)),t.limit!==void 0&&(T=T.limit(t.limit)),t.offset!==void 0&&(T=T.offset(t.offset)),!p)return T=T.where(sql`1 = 0`).select(sql`null`.as("value")),o.jsonScalarArrayFrom(T).as(g);if(f){if(C.joined.has(u)||(T=xo(T,p,u,i)),!t.order&&p.type==="o2m"){let w=o.introspection?.primary_keys?.find(A=>A.table===u);w?.columns?.length&&(T=Rt(T,w.columns.map(A=>({column:A,embed:u})),void 0,o));}if(d!==null&&!ue(d)){let w={...d,column:`${u}.${b}`};T=T.select(A=>mr(A,g,w,o).as("value"));}else T=T.select(`${u}.${b} as value`);return o.jsonScalarArrayFrom(T,"value",Ls(o,u,b,t.order)).as(g)}else return T=T.select(w=>{let A=w.selectFrom(u);return A=Ai(A,p,u,i),d!==null&&!ue(d)?(A=A.select(v=>mr(v,b,d,o,u).as("value")),o.jsonScalarArrayFrom(A,"value",Ls(o,u,b,t.order)).as("value")):(A=A.select(`${u}.${b} as value`),o.jsonScalarArrayFrom(A,"value",Ls(o,u,b,t.order)).as("value"))}),o.jsonScalarArrayFrom(T,"value",true).as(g)});}return s}function Ai(s,e,r,t){return e.type==="m2m"?jo(s,e,r,t):s.whereRef(e.leftCol,"=",e.rightCol)}function Ry(s,e,r,t,n){for(let i of e){if(typeof i=="string"&&i==="*")continue;let{colAlias:a,colName:o}=Ps(i);s=s.select(l=>{let u=l.selectFrom(r).select(`${r}.${o}`);return n&&n.type!=="m2m"?u=u.whereRef(n.leftCol,"=",n.rightCol):u=u.whereRef(`${r}.${t}_id`,"=",`${t}.id`),u=u.limit(1),u.as(a)});}return s}function _i(s,e,r){if(!s||!r?.columns||!s.some(i=>i==="*"))return s;let t=r.columns.filter(i=>i.table===e).sort((i,a)=>i.ordinal_position-a.ordinal_position).map(i=>i.name);if(t.length===0)return s;let n=[];for(let i of s)if(i==="*")for(let a of t)n.push(a);else n.push(i);return n}function Bo(s,e,r,t){let n=e?.from||s;if(!t?.foreign_keys||t.tables?.some(p=>p.name===n)||t.views?.some(p=>p.name===n))return n;let a=t.foreign_keys,o=a.find(p=>p.table===r&&p.column===n);if(o)return o.ref_table;let l=a.find(p=>p.foreign_key_name===n&&(p.table===r||p.ref_table===r));if(l)return l.table===r?l.ref_table:l.table;let u=a.find(p=>p.ref_table===r&&p.ref_column===n);return u?u.table:n}function _y(s,e,r,t,n,i){let a=n?.[e];if(!r.select||r.select.length===0){if(a?.type==="inner"&&i)return Zc(s,e,r,t,n,i);if(i&&!a?.on&&t.introspection?.foreign_keys){let o=Bo(e,a,i,t.introspection);ve(t.introspection,i,o,a?.hint)||Uo(t.introspection,i,o,a?.hint);}return s}return a?.type==="inner"&&i&&(s=Zc(s,e,r,t,n,i)),r.spread&&i?Ty(s,e,r,t,n,i):s.select(o=>np(o,e,r,t,a,i).as(e))}function np(s,e,r,t,n,i){let a=n?.from||e;if(i&&t.introspection?.foreign_keys){let C=t.introspection.foreign_keys.find(w=>w.table===i&&w.column===a);if(C)a=C.ref_table;else {let w=t.introspection.foreign_keys.find(A=>A.foreign_key_name===a&&(A.table===i||A.ref_table===i));if(w)a=w.table===i?w.ref_table:w.table;else {let A=t.introspection.foreign_keys.find(v=>v.ref_table===i&&v.ref_column===a);A&&(a=A.table);}}}let o=i===a,l=o?`${a}_self`:a,u=o?`${a} as ${l}`:a,p=s.selectFrom(u),c=i&&!n?.on?ve(t.introspection,i,a,n?.hint):null,f=c?.type==="m2m",m=_i(r.select,a,t.introspection),d=f?by(m,l):m;if(p=Ri(p,d,t,r.join,l,cy(d)),r.where&&Object.keys(r.where).length>0){let C=vi(p,r.where,r.select,r.join,a,t);p=C.qb,Object.keys(C.remainingWhere).length>0&&(p=p.where(w=>ke(w,C.remainingWhere,t)));}let g="o2m";if(n?.on)p=p.where(C=>ke(C,n.on,t));else if(i){let C=ve(t.introspection,i,a,n?.hint);if(C&&C.type==="m2m")g="m2m",p=jo(p,C,l,i);else if(C){let w=o?C.leftCol.replace(`${a}.`,`${l}.`):C.leftCol;p=p.whereRef(w,"=",C.rightCol),g=C.type;}else t.introspection?.foreign_keys?Uo(t.introspection,i,a,n?.hint):p=p.whereRef(`${l}.${i}_id`,"=",`${i}.id`);}p=Do(p,d,t,a),r.order?.some(C=>C.embed)&&(p=$s(p,r.order,a,t,r.join).sub),p=Rt(p,r.order,void 0,t,a),g==="m2m"&&!r.order&&c?.type==="m2m"&&t.dialect==="sqlite"&&(p=p.orderBy(`${c.junctionTable}.${t.rowIdColumn}`,"asc")),r.limit!==void 0&&(p=p.limit(r.limit)),r.offset!==void 0&&(p=p.offset(r.offset));let b=false;if(g==="o2m"&&i&&t.introspection){let C=ve(t.introspection,i,a,n?.hint);C&&C.type==="o2m"&&(b=lt(C,a,t.introspection));}let y=r.spread||g==="m2o"||b;return y&&t.dialect==="sqlite"?gy(p,d,a,t):(y?t.jsonObjectFrom:t.jsonArrayFrom)(p)}function ip(s,e,r,t){if(!s||!t.introspection?.foreign_keys)return false;for(let n of s){if(typeof n=="string")continue;let[i,a]=Object.entries(n)[0];if(!ue(a)||!a.spread)continue;let l=e?.[i],u=_t(l?.from||i,r,t.introspection),p=ve(t.introspection,r,u,l?.hint);if(!p)continue;if(!(p.type==="m2o"||p.type==="o2m"&<(p,u,t.introspection)))return true}return false}function vi(s,e,r,t,n,i){if(!r||!e||!i.introspection?.foreign_keys)return {qb:s,remainingWhere:e};if(Object.keys(e).length===0||!lp(e,r))return {qb:s,remainingWhere:e};let a=e;return s=s.where(o=>{let l=ap(o,e,r,t,n,i);return a=l.remainingWhere,l.expression??sql`1 = 1`}),Object.keys(a).length===Object.keys(e).length?{qb:s,remainingWhere:e}:{qb:s,remainingWhere:a}}function ap(s,e,r,t,n,i){let a=[],o={};for(let[u,p]of Object.entries(e)){if((u==="$or"||u==="$and")&&Array.isArray(p)){let f=p.map(m=>ap(s,m,r,t,n,i));if(f.length>0&&f.every(m=>m.fullyHandled&&m.expression)){a.push(u==="$or"?s.or(f.map(m=>m.expression)):s.and(f.map(m=>m.expression)));continue}o[u]=p;continue}let c=vy(s,u,p,r,t,n,i);c?a.push(c):o[u]=p;}let l=a.length===0?null:a.length===1?a[0]:s.and(a);return {expression:l,remainingWhere:o,fullyHandled:l!==null&&Object.keys(o).length===0}}function vy(s,e,r,t,n,i,a){let o=r;if(!o||typeof o!="object")return null;let l="$is"in o&&o.$is===null,u="$isNot"in o&&o.$isNot===null;if(!l&&!u)return null;let p=op(t,e);if(!p)return null;let c=n?.[e],f=_t(c?.from||e,i,a.introspection),m=ve(a.introspection,i,f,c?.hint);if(!m)return null;let d=s.selectFrom(f).select(sql`1`.as("_"));if(c?.on?d=d.where(b=>ke(b,c.on,a)):d=Ai(d,m,f,i),p.where&&Object.keys(p.where).length>0){let b=vi(d,p.where,p.select,p.join,f,a);if(d=b.qb,Object.keys(b.remainingWhere).length>0){let y=ko(b.remainingWhere,f);d=d.where(T=>ke(T,y,a));}}let g=s.exists(d);return u?g:s.not(g)}function op(s,e){for(let r of s){if(typeof r=="string")continue;let t=r[e];if(t&&ue(t))return t}return null}function lp(s,e){for(let[r,t]of Object.entries(s)){if((r==="$or"||r==="$and")&&Array.isArray(t)){if(t.some(o=>lp(o,e)))return true;continue}let n=t;if(!n||typeof n!="object")continue;let i="$is"in n&&n.$is===null,a="$isNot"in n&&n.$isNot===null;if((i||a)&&op(e,r))return true}return false}function Oy(s,e,r){return s.schema?.get(`${e??"public"}.${r}`)}function Mo(s,e,r,t,n={}){if(!s)return s;let i=Oy(e,r,t),a=o=>{let l=Ny(o,i,e,r,t),u=n.applyDefaults&&i?i.applyDefaults(l):l;return i?i.serializeRow(u):Iy(u,e,r,t)};return Array.isArray(s)?s.map(o=>a(o)):a(s)}function Ny(s,e,r,t,n){let i={};for(let[a,o]of Object.entries(s)){let l=e?.get(a)?.context.pgTypeName??pp(r,t,n,a)??void 0;i[a]=Ly(o,l);}return i}function Iy(s,e,r,t){if(e.dialect!=="sqlite")return s;let n={};for(let[i,a]of Object.entries(s)){let o=pp(e,r,t,i);n[i]=Py(o)?Dy(a):a;}return n}function pp(s,e,r,t){let i=(s.introspection?.columns??[]).filter(o=>o.table===r&&o.name===t);if(i.length===0)return;let a=i.find(o=>o.schema===(e??"public"))??i.find(o=>o.schema==="public")??i[0];return a.pg_type??a.type}function Ly(s,e){if(s==null||typeof s!="string")return s;let r=fp(e);return r==="boolean"?ky(s):r==="integer"?up(s,true):r==="number"?up(s,false):r==="json"?mp(s):r==="array"?$y(s):s}function fp(s){if(!s)return;let e=s.toLowerCase().trim();if(e.startsWith("_")||e.endsWith("[]"))return "array";if(e==="bool"||e==="boolean")return "boolean";if(["int2","smallint","int4","integer","int","int8","bigint"].includes(e))return "integer";if(["float4","real","float8","double precision","numeric","decimal"].includes(e))return "number";if(e==="json"||e==="jsonb")return "json"}function ky(s){let e=s.trim().toLowerCase();return ["true","t","1","yes","y","on"].includes(e)?true:["false","f","0","no","n","off"].includes(e)?false:s}function up(s,e){let r=s.trim();if(r==="")return s;let t=Number(r);return !Number.isFinite(t)||e&&!Number.isInteger(t)?s:t}function mp(s){let e=s.trim();if(e==="")return s;try{return JSON.parse(e)}catch{return s}}function $y(s){let e=mp(s);return Array.isArray(e)?e:s}function Py(s){let e=fp(s);return e==="json"||e==="array"}function Dy(s){return s==null||typeof s=="string"?s:JSON.stringify(s)}function hp(s,e){let r=e.db;switch(s.schema&&(r=r.withSchema(s.schema)),s.type){case "query":return Lo(s,e,r);case "insert":return xy(s,e,r);case "update":return Uy(s,e,r);case "delete":return By(s,e,r);case "upsert":case "put":return My(s,e,r);case "rpc":return Fy(s,e,r);default:throw s&&"type"in s?(console.error(s),new Error(`Unsupported AST type: ${s.type}`)):new Error("Invalid AST")}}function Rt(s,e,r,t,n){if(!e)return s;for(let i of e){let a=i.embed?(At(i.embed,"order embed alias"),i.column.includes("->")?t?Is(i.column,t,n,i.embed):cp(i.column,i.embed):(At(i.column,"order embed column"),t?Kt(i.embed,i.column,t,n):sql`${sql.ref(i.embed)}.${sql.ref(i.column)}`)):i.column.includes("->")?t?Is(i.column,t,n,r):cp(i.column,void 0,r):r?t?Kt(r,i.column,t,n):sql`${sql.ref(r)}.${sql.ref(i.column)}`:t?ae(i.column,t,n):i.column,o=i.nullsFirst!==void 0?i.nullsFirst:t?.dialect==="sqlite"?i.direction==="desc":void 0;o!==void 0?s=s.orderBy(a,l=>{let u=i.direction==="desc"?l.desc():l.asc();return o?u.nullsFirst():u.nullsLast()}):s=s.orderBy(a,i.direction||"asc");}return s}function cp(s,e,r){let{col:t,parts:n}=fr(s);if(n.length===0)return sql.ref(s);e&&At(t,"order embed column");let i=Ns(n,"ORDER BY JSON path key");return e?sql`${sql.ref(e)}.${sql.ref(t)}${sql.raw(i)}`:r?sql`${sql.ref(r)}.${sql.ref(t)}${sql.raw(i)}`:sql`${sql.ref(t)}${sql.raw(i)}`}function Ds(s,e,r,t,n){return !e||Object.keys(e).length===0?s:s.where(i=>ke(i,e,{...r,currentTable:t,currentSchema:n}))}function Lo(s,e,r){let t=r.selectFrom(s.from);t=jy(t,s.join,s.select);let n=s.order?.some(p=>p.embed)===true;t=Ri(t,s.select,e,s.join,s.from,n||tp(s.select,s.join,s.from,e));let i=s.where??{},{qb:a,remainingWhere:o}=s.from?vi(t,i,s.select,s.join,s.from,e):{qb:t,remainingWhere:i};t=a,t=Ds(t,o,e,s.from,s.schema),t=Do(t,s.select,e,s.from,s.join),sp(s.order,s.join,s.from,e),s.from&&n&&(t=$s(t,s.order,s.from,e,s.join).sub);let l=s.from&&ip(s.select,s.join,s.from,e)?s.from:void 0,u=ep(s.order,s.select,s.join,s.from,e);return t=Rt(t,u,l,e,s.from),s.limit!==void 0&&(t=t.limit(s.limit)),s.offset!==void 0&&(t=t.offset(s.offset)),t}function jy(s,e,r){if(!e)return s;let t=new Set;if(r){for(let n of r)if(typeof n!="string")for(let i of Object.keys(n))t.add(i);}for(let[n,i]of Object.entries(e)){if(!i.on||t.has(n))continue;let a=i.from||n,o=i.type==="left"?"leftJoin":"innerJoin";s=s[o](`${a} as ${n}`,l=>dp(l,i.on));}return s}function dp(s,e){for(let[r,t]of Object.entries(e))if(r==="$and")for(let n of t)s=dp(s,n);else {let n=t;for(let[i,a]of Object.entries(n)){let o=bi[i];if(!o)throw new Error(`Unsupported join operator: ${i}`);yi(a)?s=s.onRef(r,o,a.$ref):s=s.on(r,o,a);}}return s}function xy(s,e,r){let t=r.insertInto(s.from);if(s.values){let n=Mo(s.values,e,s.schema,s.from,{applyDefaults:true});t=t.values(n);}return t=ks(t,s.select),t}function Uy(s,e,r){let t=r.updateTable(s.from);if(s.values){let n=Mo(s.values,e,s.schema,s.from);t=t.set(n);}return s.limit!==void 0||s.offset!==void 0?t=gp(t,s,e,r):t=Ds(t,s.where??{},e,s.from,s.schema),t=ks(t,s.select),t}function By(s,e,r){let t=r.deleteFrom(s.from);return s.limit!==void 0||s.offset!==void 0?t=gp(t,s,e,r):t=Ds(t,s.where??{},e,s.from,s.schema),t=ks(t,s.select),t}function gp(s,e,r,t){let i=r.introspection?.primary_keys.find(l=>l.table===e.from)?.columns??[],a=t.selectFrom(e.from),o=r.rowIdColumn;if(i.length>0)for(let l of i)a=a.select(l);else a=a.select(sql.ref(o).as("__rowid"));if(a=Ds(a,e.where??{},r,e.from,e.schema),a=Rt(a,e.order,void 0,r,e.from),e.limit!==void 0&&(a=a.limit(e.limit)),e.offset!==void 0&&(a=a.offset(e.offset)),i.length===1)return s.where(i[0],"in",a);if(i.length>1){let l="__ltd_target",u=t.selectFrom(a.as(l)).select(sql`1`.as("_"));for(let p of i)u=u.whereRef(`${l}.${p}`,"=",`${e.from}.${p}`);return s.where(p=>p.exists(u))}else return s.where(sql.ref(o),"in",a)}function My(s,e,r){let t=s.values,n=Mo(t,e,s.schema,s.from,{applyDefaults:true}),i=r.insertInto(s.from).values(n);return s.onConflict&&(i=i.onConflict(a=>{let o=s.onConflict.length===1?a.column(s.onConflict[0]):a.columns(s.onConflict);if(s.ignoreDuplicates)return o.doNothing();let l=Array.isArray(n)?n[0]:n,u=Object.keys(l).filter(p=>!s.onConflict.includes(p));return u.length===0?o.doUpdateSet({[s.onConflict[0]]:sql.ref(`excluded.${s.onConflict[0]}`)}):o.doUpdateSet(p=>{let c={};for(let f of u)c[f]=p.ref(`excluded.${f}`);return c})})),i=ks(i,s.select),i}function Fy(s,e,r){let t=s.function;At(t,"RPC function name");let n;if(s.args&&!Array.isArray(s.args)&&Object.keys(s.args).length>0){let o=Object.entries(s.args).map(([l,u])=>(At(l,"RPC param key"),sql`${sql.raw(l)} := ${u}`));n=sql`${sql.raw(t)}(${sql.join(o)})`;}else if(Array.isArray(s.args)&&s.args.length>0){let a=s.args.map(o=>sql`${o}`);n=sql`${sql.raw(t)}(${sql.join(a)})`;}else n=sql`${sql.raw(t)}()`;let i=r.selectFrom(n.as(t));return i=Ri(i,s.select,e),i=Ds(i,s.where??{},e,s.from,s.schema),i=Rt(i,s.order,void 0,e,s.from),s.limit!==void 0&&(i=i.limit(s.limit)),s.offset!==void 0&&(i=i.offset(s.offset)),i}var Yy=new Kysely({dialect:{createAdapter:()=>new PostgresAdapter,createDriver:()=>new DummyDriver,createIntrospector:s=>new PostgresIntrospector(s),createQueryCompiler:()=>new PostgresQueryCompiler}}),zy={$ilike:(s,e,r)=>sql`${L(e)} ilike ${r}`,$regex:(s,e,r)=>sql`${L(e)} ~ ${r}`,$iregex:(s,e,r)=>sql`${L(e)} ~* ${r}`,$contains:(s,e,r)=>sql`${L(e)} @> ${r}`,$containedBy:(s,e,r)=>sql`${L(e)} <@ ${r}`,$overlaps:(s,e,r)=>sql`${L(e)} && ${r}`,$rangeLt:(s,e,r)=>sql`${L(e)} << ${r}`,$rangeGt:(s,e,r)=>sql`${L(e)} >> ${r}`,$rangeGte:(s,e,r)=>sql`${L(e)} &> ${r}`,$rangeLte:(s,e,r)=>sql`${L(e)} &< ${r}`,$rangeAdjacent:(s,e,r)=>sql`${L(e)} -|- ${r}`,$textSearch:(s,e,r)=>{let t=r,n=t.config||"english",i="to_tsquery";return t.type==="plain"?i="plainto_tsquery":t.type==="phrase"?i="phraseto_tsquery":t.type==="websearch"&&(i="websearch_to_tsquery"),sql`${L(e)} @@ ${sql.raw(i)}(${sql.literal(n)}, ${t.query})`},$eqAny:(s,e,r)=>sql`${L(e)} = any(${r})`,$neqAny:(s,e,r)=>sql`${L(e)} != any(${r})`,$gtAny:(s,e,r)=>sql`${L(e)} > any(${r})`,$gteAny:(s,e,r)=>sql`${L(e)} >= any(${r})`,$ltAny:(s,e,r)=>sql`${L(e)} < any(${r})`,$lteAny:(s,e,r)=>sql`${L(e)} <= any(${r})`,$likeAny:(s,e,r)=>sql`${L(e)} like any(${r})`,$ilikeAny:(s,e,r)=>sql`${L(e)} ilike any(${r})`,$eqAll:(s,e,r)=>sql`${L(e)} = all(${r})`,$neqAll:(s,e,r)=>sql`${L(e)} != all(${r})`,$gtAll:(s,e,r)=>sql`${L(e)} > all(${r})`,$gteAll:(s,e,r)=>sql`${L(e)} >= all(${r})`,$ltAll:(s,e,r)=>sql`${L(e)} < all(${r})`,$lteAll:(s,e,r)=>sql`${L(e)} <= all(${r})`,$likeAll:(s,e,r)=>sql`${L(e)} like all(${r})`,$ilikeAll:(s,e,r)=>sql`${L(e)} ilike all(${r})`,$regexAny:(s,e,r)=>sql`${L(e)} ~ any(${r})`,$iregexAny:(s,e,r)=>sql`${L(e)} ~* any(${r})`,$regexAll:(s,e,r)=>sql`${L(e)} ~ all(${r})`,$iregexAll:(s,e,r)=>sql`${L(e)} ~* all(${r})`};function Xy(s,e){let r=e.replace(/^\$\./,"").split(".");if(r.length===0)return sql.ref(s);let t=r.map((n,i)=>{let a=i===r.length-1?"->>":"->",o=/^-?\d+$/.test(n);return o||xr(n,"JSON path key"),o?`${a}${n}`:`${a}'${n}'`}).join("");return sql`${sql.ref(s)}${sql.raw(t)}`}function Qy(s,e="value",r=false){let t=sql.ref(e);return sql`(select coalesce(json_agg(${t}), '[]'::json) from ${s} as _agg)`}var yp={db:Yy,operators:{...Si,...zy},jsonArrayFrom:jsonArrayFrom$1,jsonObjectFrom:jsonObjectFrom$1,jsonScalarArrayFrom:Qy,jsonPath:Xy,rowIdColumn:"ctid"};var aE=new Kysely({dialect:{createAdapter:()=>new SqliteAdapter,createDriver:()=>new DummyDriver,createIntrospector:s=>new SqliteIntrospector(s),createQueryCompiler:()=>new SqliteQueryCompiler}});function oE(s,e){let r=e.replace(/^\$\./,"").split(".");if(r.length===0)return sql.ref(s);let t=r.map((n,i)=>{let a=i===r.length-1?"->>":"->",o=/^-?\d+$/.test(n);return o||xr(n,"JSON path key"),o?`${a}${n}`:`${a}'${n}'`}).join("");return sql`${sql.ref(s)}${sql.raw(t)}`}function lE(s,e){let r=L(s);if(e.length===0)return sql`${r} is not null`;let t=sql.join(e.map(n=>sql`${n}`));return sql`${r} is not null and (select count(distinct value) from json_each(${r}) where value in (${t})) = ${sql.lit(e.length)}`}function uE(s,e){let r=L(s),t=Object.keys(e);if(t.length===0)return sql`${r} is not null`;let n=t.map(i=>(xr(i,"JSON object key"),sql`json_extract(${r}, ${sql.raw(`'$.${i}'`)}) = ${e[i]}`));return sql`${r} is not null and ${sql.join(n,sql` and `)}`}function Oi(s,e,r,t){if(!Array.isArray(e))throw new Error(`$${r}${t} on sqlite requires an array value`);if(e.length===0)return t==="any"?sql`false`:sql`true`;let n=L(s),i=r==="ilike"?sql`lower(${n})`:n,a=e.map(o=>r==="ilike"?sql`${i} like lower(${o})`:sql`${i} like ${o}`);return sql`(${sql.join(a,t==="any"?sql` or `:sql` and `)})`}var cE={$ilike:(s,e,r)=>sql`lower(${L(e)}) like lower(${r})`,$likeAny:(s,e,r)=>Oi(e,r,"like","any"),$ilikeAny:(s,e,r)=>Oi(e,r,"ilike","any"),$likeAll:(s,e,r)=>Oi(e,r,"like","all"),$ilikeAll:(s,e,r)=>Oi(e,r,"ilike","all"),$contains:(s,e,r)=>{if(Array.isArray(r))return lE(e,r);if(r!==null&&typeof r=="object")return uE(e,r);throw new Error("$contains on sqlite requires an array or object value")},$containedBy:(s,e,r)=>{if(!Array.isArray(r))throw new Error("$containedBy on sqlite requires an array value");let t=L(e);if(r.length===0)return sql`${t} is not null and not exists (select 1 from json_each(${t}))`;let n=sql.join(r.map(i=>sql`${i}`));return sql`${t} is not null and not exists (select 1 from json_each(${t}) where value not in (${n}))`},$overlaps:(s,e,r)=>{if(!Array.isArray(r))throw new Error("$overlaps on sqlite requires an array value");let t=L(e);if(r.length===0)return sql`1 = 0`;let n=sql.join(r.map(i=>sql`${i}`));return sql`${t} is not null and exists (select 1 from json_each(${t}) where value in (${n}))`}};function pE(s,e="value",r=false){let t=sql.ref(e),n=r?sql`json_group_array(json(${t}))`:sql`json_group_array(${t})`;return sql`(select coalesce(${n}, json('[]')) from ${s} as _agg)`}var Ep={db:aE,operators:{...Si,...cE},jsonArrayFrom:jsonArrayFrom,jsonObjectFrom:jsonObjectFrom,jsonScalarArrayFrom:pE,jsonPath:oE,rowIdColumn:"rowid"};function fE(s){switch(s){case "postgres":return yp;case "sqlite":return Ep;default:throw new Error(`Unsupported dialect: ${s}`)}}function he(s,e="postgres",r){let t=fE(e),n=r&&"introspection"in r?r:{db:r,introspection:void 0};return hp(s,{...t,dialect:e,db:n.db??t.db,introspection:n.introspection,schema:n.schema})}var Ve=qn(Tp());function a_(s){return ["string","number","boolean"].includes(typeof s)}function o_(s){return [true,false,0,1].includes(s)}function l_(s){return typeof s=="string"}function c_(...s){return e=>s.reduce((r,t)=>t(r),e)}function p_(...s){return e=>e.map(r=>s.reduce((t,n)=>n(t),r))}function wp(s){return Object.prototype.toString.call(s)==="[object Object]"}function Cp(s){return s!==null&&typeof s=="object"}function m_(s,e){let r={};for(let t in s)s[t]!==e[t]&&(r[t]=e[t]);return r}function Li(s,e,r=void 0){let t=typeof e=="string"?e.split(/[.[\]"]+/).filter(n=>n):e;if(t.length===0)return s;try{let[n,...i]=t;return !n||!(n in s)?r:Li(s[n],i,r)}catch{if(typeof r<"u")return r;throw new Error(`Invalid path: ${t.join(".")}`)}}function gE(s,e,r){let t=e;if(typeof t=="string"){let a=o=>o[0]==='"'&&o.at(-1)==='"';t=t.split(/[.[\]]+/).filter(o=>o).map(o=>Number.isNaN(Number(o))?o:Number(o)).map(o=>typeof o=="string"&&a(o)?o.slice(1,-1):o);}if(t.length===0)throw new Error("The path must have at least one entry in it");let[n,...i]=t;return i.length===0?(s[n]=r,s):(n in s||(s[n]=typeof i[0]=="number"?[]:{}),gE(s[n],i,r),s)}function h_(s,e){return e.reduce((r,t)=>(t in s&&(r[t]=s[t]),r),{})}function d_(s,e){let r=new Set(e),t={};for(let[n,i]of Object.entries(s))r.has(n)||(t[n]=i);return t}function yE(s,...e){for(let r of e)for(let[t,n]of Object.entries(r))n!==void 0&&(!wp(n)&&!Array.isArray(n)||Array.isArray(n)&&!Array.isArray(s[t])?s[t]=n:Cp(s[t])?yE(s[t],n):s[t]=n);return s}function EE(s,e,r){for(let[t,n]of Object.entries(e)){let i=r(s[t],n,t,s,e);if(i!==void 0){s[t]=i;continue}n!==void 0&&(!wp(n)&&!Array.isArray(n)||Array.isArray(n)&&!Array.isArray(s[t])?s[t]=n:Cp(s[t])?EE(s[t],n,r):s[t]=n);}return s}function qo(s,e){let r=n=>{if(n!==Object(n))return "primitive";if(Array.isArray(n))return "array";if(n instanceof Map)return "map";if(n!=null&&[null,Object.prototype].includes(Object.getPrototypeOf(n)))return "plainObject";if(n instanceof Function)return "function";throw new Error(`deeply comparing an instance of type ${s.constructor?.name} is not supported.`)},t=r(s);if(t!==r(e))return false;if(t==="primitive")return s===e||Number.isNaN(s)&&Number.isNaN(e);if(t==="array")return s.length===e.length&&s.every((n,i)=>qo(n,e[i]));if(t==="map")return s.size===e.size&&[...s].every(([n,i])=>e.has(n)&&qo(i,e.get(n)));if(t==="plainObject"){let n=new Map(Object.entries(s)),i=new Map(Object.entries(e));return n.size===i.size&&[...n].every(([a,o])=>i.has(a)&&qo(o,i.get(a)))}else {if(t==="function")return s.toString()===e.toString();throw new Error("Unreachable")}}function g_(...s){let[e,r,t]=s;return JSON.stringify(e,(n,i)=>typeof i=="bigint"?Number.parseInt(i.toString(),10):i instanceof Map?Object.fromEntries(i.entries()):i instanceof Set?Array.from(i):r&&typeof r=="function"?r(n,i):i,t)}function E_(s){let e=s instanceof Request?new URL(s.url).searchParams:s;return Object.fromEntries(e.entries())}function S_(s,e){let r=s instanceof Request?new URL(s.url).searchParams:s,t={};for(let[n,i]of r.entries())e(n,i)&&(t[n]=i);return t}function T_(){try{return !SE()&&global?.process?.release?.name==="node"}catch{return false}}function SE(){try{return typeof Bun<"u"}catch{return false}}function w_(s,e){if(!s)throw new Error(e)}function C_(s,e){try{return s(),!1}catch(r){if(e){if(r instanceof e)return true;throw r}return true}}async function A_(s,e){try{return await s,!1}catch(r){if(e){if(r instanceof e)return true;throw r}return true}}function R_(s,e){try{return s()}catch{return e}}async function __(s,e){let r=performance.now();await s();let t=performance.now();e(t-r);}var v_={Map:s=>s instanceof Map?s:new Map(typeof s=="object"&&s!==null?Object.entries(s):[]),Set:s=>s instanceof Set?s:new Set(Array.isArray(s)?s:[]),Array:s=>Array.isArray(s)?s:["string","number","boolean"].includes(typeof s)?[s]:[]};function js(s,e={}){return s.split(`
|
|
71
|
-
`).map(r=>r.trim()).filter(r=>r.length>0).filter(r=>!r.startsWith(e.comments??"--")).join(`
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
`;)r++;continue}if(n==="/"&&i==="*"){for(r+=2;r<t&&!(s[r]==="*"&&s[r+1]==="/");)r++;r+=2;continue}e+=n,r++;}return e.trim()}function Jo(s){return (s??"").trim().toLowerCase()}function Wo(s){return (s??"").replace(/\s+/g," ").replace(/"/g,"").trim().toLowerCase()}function Ho(s){if(s==null)return null;let e=s.trim();for(;e.startsWith("(")&&e.endsWith(")");)e=e.slice(1,-1).trim();return (e.startsWith("'")&&e.endsWith("'")||e.startsWith('"')&&e.endsWith('"'))&&(e=e.slice(1,-1)),e}function $_(s=10,e={}){let a="abcdefghijklmnopqrstuvwxyz"+(e.uppercase?"ABCDEFGHIJKLMNOPQRSTUVWXYZ":"")+(e.numbers?"0123456789":"")+(e.special?"!@#$%^&*()_+{}:\"<>?|[];',./`~":""),o="";for(let l=0;l<s;l++)o+=a[Math.floor(Math.random()*a.length)];return o}function P_(s,e){if(typeof s!="string"){if(e?.panic)throw new Error("Email must be a string");return false}if(!E.string({format:"email"}).validate(s).valid){if(e?.panic)throw new Error("Invalid email");return false}if(e?.domains?.length&&!e.domains.includes(s.split("@")[1])){if(e?.panic)throw new Error("Email domain not allowed");return false}return true}function D_(s,{panic:e=true,length:r=8,numbers:t=0,special:n=0}={}){try{if(typeof s!="string"){if(e)throw new Error("Password must be a string");return !1}if(s.length<r){if(e)throw new Error(`Password must be at least ${r} characters long`);return !1}if((s.match(/[0-9]/g)?.length??0)<t){if(e)throw new Error(`Password must contain at least ${t} numbers`);return !1}if((s.match(/[!@#$%^&*()_+\-=[\]{};':"\\|,.<>/?]/g)?.length??0)<n){if(e)throw new Error(`Password must contain at least ${n} special characters`);return !1}return !0}catch(i){if(e)throw i;return false}}function j_(s){return !s||s.length===0?s:s.charAt(0).toUpperCase()+s.slice(1)}function x_(s,e=" "){return !s||s.length===0?s:s.split(e).map(r=>r.charAt(0).toUpperCase()+r.slice(1)).join(e)}function U_(s){return !s||s.length===0?s:s.split("_").map(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()).join(" ")}function TE(s){return String(s).normalize("NFKD").replace(/[\u0300-\u036f]/g,"")}function B_(s){return TE(s).trim().toLowerCase().replace(/[^a-z0-9 -]/g,"").replace(/\s+/g,"-").replace(/-+/g,"-")}function M_(s,e=50,r="..."){return s.length<=e?s:s.substring(0,e)+r}function $(s,e='"'){return `${e}${s}${e}`}function ki(s,e,r){if(e instanceof RegExp)return e.test(s);if(typeof e=="string")switch(!r&&e.startsWith("/")&&(r="regex"),r){case "regex":return new RegExp(e).test(s);case "sql":return new RegExp(e.replace("%",".*").replace("_",".")).test(s);case "wildcard":return new RegExp(e.replace("*",".*")).test(s);default:return s.includes(e)}return false}function F_(s,e,r=/\{\{([\w-]+)\}\}/g){return s.replace(r,(t,n)=>n in e?e[n]:t)}function Rp(s,e,r=.33){if(e.length===0)return null;let t=Ap(s),n=[];for(let l of e){let u=wE(t,Ap(l));u>.1&&n.push([l,u]);}n.sort((l,u)=>u[1]-l[1]);let i=n.slice(0,50),a=null,o=r;for(let[l]of i){let u=Math.max(s.length,l.length),p=u===0?1:1-CE(s.toLowerCase(),l.toLowerCase())/u;p>o&&(o=p,a=l);}return a}function Ap(s,e=2){let r=new Map,t=`-${s.toLowerCase()}-`;for(let n=0;n<=t.length-e;n++){let i=t.slice(n,n+e);r.set(i,(r.get(i)||0)+1);}return r}function wE(s,e){let r=0,t=0,n=0;for(let[i,a]of s){t+=a*a;let o=e.get(i);o!==void 0&&(r+=a*o);}for(let[,i]of e)n+=i*i;return t===0||n===0?0:r/(Math.sqrt(t)*Math.sqrt(n))}function CE(s,e){let r=s.length,t=e.length,n=Array.from({length:t+1},(i,a)=>a);for(let i=1;i<=r;i++){let a=n[0];n[0]=i;for(let o=1;o<=t;o++){let l=n[o];n[o]=s[i-1]===e[o-1]?a:1+Math.min(a,n[o],n[o-1]),a=l;}}return n[t]}function J_(s){return typeof s=="number"?s:Number.parseInt(String(s),10)}function H_(){return crypto.randomUUID()}var xs=class extends Error{constructor(r,t){super(`Could not find the table '${[r,t].filter(Boolean).join(".")}' in the schema cache`);this.schema=r;this.relation=t;}},Go=class{constructor(e){this.config=e;}kysely;introspection;async translateDdl(e){return e}async clearSchemaCache(){this.introspection=void 0,await this.deleteCachedIntrospection();}async readCachedIntrospection(e){if(typeof this.introspection=="object"&&e?.useCache===true)return this.introspection;if(e?.useCache!==true||!this.config.schemaCache)return;let r=await this.config.schemaCache.get(this.schemaCacheKey());if(r)try{return this.introspection=JSON.parse(r),this.introspection}catch{await this.deleteCachedIntrospection();return}}async writeCachedIntrospection(e,r){this.introspection=e,r?.useDriver===true&&await this.config.schemaCache?.set(this.schemaCacheKey(),JSON.stringify(e));}async deleteCachedIntrospection(){await this.config.schemaCache?.delete(this.schemaCacheKey());}schemaCacheKey(){return ["@supabase/lite","schema-cache",this.dialect,this.config.introspection?.name??"",this.config.url??""].join(":")}async exec(e,...r){try{return sql(e,...r??[]).execute(this.kysely)}catch(t){throw console.error(t),new Error(`Failed to execute query: ${e}`)}}async ping(){try{let e=await this.exec("SELECT 1");return e&&Array.isArray(e.rows)&&e.rows.length===1}catch{return false}}async transaction(e,r){throw new Error("This Connection does not support transactions")}createMigrator(e){throw new Error("This Connection does not support migrations")}async onPostgrestAST(e,r){return e}deserializeRow(e){return e}normalizeDbError(e){return e}async withContext(e,r,t){return r(this.kysely)}};var $i=class extends Error{constructor(r){super(`new row violates row-level security policy for table "${r.data.table}"`);this.policy=r;this.name="PolicyViolation";}};var hr=class extends Error{constructor(r,t,n,i){super(`check constraint "${n}" violated for ${r}.${t}`);this.table=r;this.column=t;this.constraint=n;this.value=i;this.name="CheckConstraintError";}};function k(s,e,r,t,n){let i=JSON.stringify({code:e,details:t,hint:n,message:r}),a=new TextEncoder().encode(i);return new Response(a,{status:s,headers:{"Content-Type":"application/json; charset=utf-8","Content-Length":String(a.byteLength)}})}function Ze(s){return k(s.status,s.code,s.message,s.details??null,s.hint??null)}var dr=new TextEncoder,vt=new TextDecoder;function Pi(...s){let e=s.reduce((n,{length:i})=>n+i,0),r=new Uint8Array(e),t=0;for(let n of s)r.set(n,t),t+=n.length;return r}function Yt(s){let e=new Uint8Array(s.length);for(let r=0;r<s.length;r++){let t=s.charCodeAt(r);if(t>127)throw new TypeError("non-ASCII string encountered in encode()");e[r]=t;}return e}function _p(s){if(Uint8Array.prototype.toBase64)return s.toBase64();let e=32768,r=[];for(let t=0;t<s.length;t+=e)r.push(String.fromCharCode.apply(null,s.subarray(t,t+e)));return btoa(r.join(""))}function vp(s){if(Uint8Array.fromBase64)return Uint8Array.fromBase64(s);let e=atob(s),r=new Uint8Array(e.length);for(let t=0;t<e.length;t++)r[t]=e.charCodeAt(t);return r}function Ur(s){if(Uint8Array.fromBase64)return Uint8Array.fromBase64(typeof s=="string"?s:vt.decode(s),{alphabet:"base64url"});let e=s;e instanceof Uint8Array&&(e=vt.decode(e)),e=e.replace(/-/g,"+").replace(/_/g,"/");try{return vp(e)}catch{throw new TypeError("The input to be decoded is not correctly encoded.")}}function Di(s){let e=s;return typeof e=="string"&&(e=dr.encode(e)),Uint8Array.prototype.toBase64?e.toBase64({alphabet:"base64url",omitPadding:true}):_p(e).replace(/=/g,"").replace(/\+/g,"-").replace(/\//g,"_")}var Nt={};Fn(Nt,{JOSEAlgNotAllowed:()=>Us,JOSEError:()=>de,JOSENotSupported:()=>Me,JWEDecryptionFailed:()=>Vo,JWEInvalid:()=>Ko,JWKInvalid:()=>Yo,JWKSInvalid:()=>zo,JWKSMultipleMatchingKeys:()=>Qo,JWKSNoMatchingKey:()=>Xo,JWKSTimeout:()=>Zo,JWSInvalid:()=>Y,JWSSignatureVerificationFailed:()=>Bs,JWTClaimValidationFailed:()=>$e,JWTExpired:()=>Br,JWTInvalid:()=>Ot});var de=class extends Error{static code="ERR_JOSE_GENERIC";code="ERR_JOSE_GENERIC";constructor(e,r){super(e,r),this.name=this.constructor.name,Error.captureStackTrace?.(this,this.constructor);}},$e=class extends de{static code="ERR_JWT_CLAIM_VALIDATION_FAILED";code="ERR_JWT_CLAIM_VALIDATION_FAILED";claim;reason;payload;constructor(e,r,t="unspecified",n="unspecified"){super(e,{cause:{claim:t,reason:n,payload:r}}),this.claim=t,this.reason=n,this.payload=r;}},Br=class extends de{static code="ERR_JWT_EXPIRED";code="ERR_JWT_EXPIRED";claim;reason;payload;constructor(e,r,t="unspecified",n="unspecified"){super(e,{cause:{claim:t,reason:n,payload:r}}),this.claim=t,this.reason=n,this.payload=r;}},Us=class extends de{static code="ERR_JOSE_ALG_NOT_ALLOWED";code="ERR_JOSE_ALG_NOT_ALLOWED"},Me=class extends de{static code="ERR_JOSE_NOT_SUPPORTED";code="ERR_JOSE_NOT_SUPPORTED"},Vo=class extends de{static code="ERR_JWE_DECRYPTION_FAILED";code="ERR_JWE_DECRYPTION_FAILED";constructor(e="decryption operation failed",r){super(e,r);}},Ko=class extends de{static code="ERR_JWE_INVALID";code="ERR_JWE_INVALID"},Y=class extends de{static code="ERR_JWS_INVALID";code="ERR_JWS_INVALID"},Ot=class extends de{static code="ERR_JWT_INVALID";code="ERR_JWT_INVALID"},Yo=class extends de{static code="ERR_JWK_INVALID";code="ERR_JWK_INVALID"},zo=class extends de{static code="ERR_JWKS_INVALID";code="ERR_JWKS_INVALID"},Xo=class extends de{static code="ERR_JWKS_NO_MATCHING_KEY";code="ERR_JWKS_NO_MATCHING_KEY";constructor(e="no applicable key found in the JSON Web Key Set",r){super(e,r);}},Qo=class extends de{[Symbol.asyncIterator];static code="ERR_JWKS_MULTIPLE_MATCHING_KEYS";code="ERR_JWKS_MULTIPLE_MATCHING_KEYS";constructor(e="multiple matching keys found in the JSON Web Key Set",r){super(e,r);}},Zo=class extends de{static code="ERR_JWKS_TIMEOUT";code="ERR_JWKS_TIMEOUT";constructor(e="request timed out",r){super(e,r);}},Bs=class extends de{static code="ERR_JWS_SIGNATURE_VERIFICATION_FAILED";code="ERR_JWS_SIGNATURE_VERIFICATION_FAILED";constructor(e="signature verification failed",r){super(e,r);}};var ut=(s,e="algorithm.name")=>new TypeError(`CryptoKey does not support this operation, its ${e} must be ${s}`),Mr=(s,e)=>s.name===e;function el(s){return parseInt(s.name.slice(4),10)}function RE(s){switch(s){case "ES256":return "P-256";case "ES384":return "P-384";case "ES512":return "P-521";default:throw new Error("unreachable")}}function _E(s,e){if(e&&!s.usages.includes(e))throw new TypeError(`CryptoKey does not support this operation, its usages must include ${e}.`)}function Op(s,e,r){switch(e){case "HS256":case "HS384":case "HS512":{if(!Mr(s.algorithm,"HMAC"))throw ut("HMAC");let t=parseInt(e.slice(2),10);if(el(s.algorithm.hash)!==t)throw ut(`SHA-${t}`,"algorithm.hash");break}case "RS256":case "RS384":case "RS512":{if(!Mr(s.algorithm,"RSASSA-PKCS1-v1_5"))throw ut("RSASSA-PKCS1-v1_5");let t=parseInt(e.slice(2),10);if(el(s.algorithm.hash)!==t)throw ut(`SHA-${t}`,"algorithm.hash");break}case "PS256":case "PS384":case "PS512":{if(!Mr(s.algorithm,"RSA-PSS"))throw ut("RSA-PSS");let t=parseInt(e.slice(2),10);if(el(s.algorithm.hash)!==t)throw ut(`SHA-${t}`,"algorithm.hash");break}case "Ed25519":case "EdDSA":{if(!Mr(s.algorithm,"Ed25519"))throw ut("Ed25519");break}case "ML-DSA-44":case "ML-DSA-65":case "ML-DSA-87":{if(!Mr(s.algorithm,e))throw ut(e);break}case "ES256":case "ES384":case "ES512":{if(!Mr(s.algorithm,"ECDSA"))throw ut("ECDSA");let t=RE(e);if(s.algorithm.namedCurve!==t)throw ut(t,"algorithm.namedCurve");break}default:throw new TypeError("CryptoKey does not support this operation")}_E(s,r);}function Np(s,e,...r){if(r=r.filter(Boolean),r.length>2){let t=r.pop();s+=`one of type ${r.join(", ")}, or ${t}.`;}else r.length===2?s+=`one of type ${r[0]} or ${r[1]}.`:s+=`of type ${r[0]}.`;return e==null?s+=` Received ${e}`:typeof e=="function"&&e.name?s+=` Received function ${e.name}`:typeof e=="object"&&e!=null&&e.constructor?.name&&(s+=` Received an instance of ${e.constructor.name}`),s}var Ip=(s,...e)=>Np("Key must be ",s,...e),tl=(s,e,...r)=>Np(`Key for the ${s} algorithm must be `,e,...r);var rl=s=>{if(s?.[Symbol.toStringTag]==="CryptoKey")return true;try{return s instanceof CryptoKey}catch{return false}},sl=s=>s?.[Symbol.toStringTag]==="KeyObject",nl=s=>rl(s)||sl(s);function ji(...s){let e=s.filter(Boolean);if(e.length===0||e.length===1)return true;let r;for(let t of e){let n=Object.keys(t);if(!r||r.size===0){r=new Set(n);continue}for(let i of n){if(r.has(i))return false;r.add(i);}}return true}var vE=s=>typeof s=="object"&&s!==null;function zt(s){if(!vE(s)||Object.prototype.toString.call(s)!=="[object Object]")return false;if(Object.getPrototypeOf(s)===null)return true;let e=s;for(;Object.getPrototypeOf(e)!==null;)e=Object.getPrototypeOf(e);return Object.getPrototypeOf(s)===e}function xi(s,e){if(s.startsWith("RS")||s.startsWith("PS")){let{modulusLength:r}=e.algorithm;if(typeof r!="number"||r<2048)throw new TypeError(`${s} requires key modulusLength to be 2048 bits or larger`)}}function OE(s){let e,r;switch(s.kty){case "AKP":{switch(s.alg){case "ML-DSA-44":case "ML-DSA-65":case "ML-DSA-87":e={name:s.alg},r=s.priv?["sign"]:["verify"];break;default:throw new Me('Invalid or unsupported JWK "alg" (Algorithm) Parameter value')}break}case "RSA":{switch(s.alg){case "PS256":case "PS384":case "PS512":e={name:"RSA-PSS",hash:`SHA-${s.alg.slice(-3)}`},r=s.d?["sign"]:["verify"];break;case "RS256":case "RS384":case "RS512":e={name:"RSASSA-PKCS1-v1_5",hash:`SHA-${s.alg.slice(-3)}`},r=s.d?["sign"]:["verify"];break;case "RSA-OAEP":case "RSA-OAEP-256":case "RSA-OAEP-384":case "RSA-OAEP-512":e={name:"RSA-OAEP",hash:`SHA-${parseInt(s.alg.slice(-3),10)||1}`},r=s.d?["decrypt","unwrapKey"]:["encrypt","wrapKey"];break;default:throw new Me('Invalid or unsupported JWK "alg" (Algorithm) Parameter value')}break}case "EC":{switch(s.alg){case "ES256":e={name:"ECDSA",namedCurve:"P-256"},r=s.d?["sign"]:["verify"];break;case "ES384":e={name:"ECDSA",namedCurve:"P-384"},r=s.d?["sign"]:["verify"];break;case "ES512":e={name:"ECDSA",namedCurve:"P-521"},r=s.d?["sign"]:["verify"];break;case "ECDH-ES":case "ECDH-ES+A128KW":case "ECDH-ES+A192KW":case "ECDH-ES+A256KW":e={name:"ECDH",namedCurve:s.crv},r=s.d?["deriveBits"]:[];break;default:throw new Me('Invalid or unsupported JWK "alg" (Algorithm) Parameter value')}break}case "OKP":{switch(s.alg){case "Ed25519":case "EdDSA":e={name:"Ed25519"},r=s.d?["sign"]:["verify"];break;case "ECDH-ES":case "ECDH-ES+A128KW":case "ECDH-ES+A192KW":case "ECDH-ES+A256KW":e={name:s.crv},r=s.d?["deriveBits"]:[];break;default:throw new Me('Invalid or unsupported JWK "alg" (Algorithm) Parameter value')}break}default:throw new Me('Invalid or unsupported JWK "kty" (Key Type) Parameter value')}return {algorithm:e,keyUsages:r}}async function Lp(s){if(!s.alg)throw new TypeError('"alg" argument is required when "jwk.alg" is not present');let{algorithm:e,keyUsages:r}=OE(s),t={...s};return t.kty!=="AKP"&&delete t.alg,delete t.use,crypto.subtle.importKey("jwk",t,e,s.ext??!(s.d||s.priv),s.key_ops??r)}function Ui(s,e,r,t,n){if(n.crit!==void 0&&t?.crit===void 0)throw new s('"crit" (Critical) Header Parameter MUST be integrity protected');if(!t||t.crit===void 0)return new Set;if(!Array.isArray(t.crit)||t.crit.length===0||t.crit.some(a=>typeof a!="string"||a.length===0))throw new s('"crit" (Critical) Header Parameter MUST be an array of non-empty strings when present');let i;r!==void 0?i=new Map([...Object.entries(r),...e.entries()]):i=e;for(let a of t.crit){if(!i.has(a))throw new Me(`Extension Header Parameter "${a}" is not recognized`);if(n[a]===void 0)throw new s(`Extension Header Parameter "${a}" is missing`);if(i.get(a)&&t[a]===void 0)throw new s(`Extension Header Parameter "${a}" MUST be integrity protected`)}return new Set(t.crit)}function kp(s,e){if(e!==void 0&&(!Array.isArray(e)||e.some(r=>typeof r!="string")))throw new TypeError(`"${s}" option must be an array of strings`);if(e)return new Set(e)}var Ms=s=>zt(s)&&typeof s.kty=="string",$p=s=>s.kty!=="oct"&&(s.kty==="AKP"&&typeof s.priv=="string"||typeof s.d=="string"),Pp=s=>s.kty!=="oct"&&s.d===void 0&&s.priv===void 0,Dp=s=>s.kty==="oct"&&typeof s.k=="string";var Fr,jp=async(s,e,r,t=false)=>{Fr||=new WeakMap;let n=Fr.get(s);if(n?.[r])return n[r];let i=await Lp({...e,alg:r});return t&&Object.freeze(s),n?n[r]=i:Fr.set(s,{[r]:i}),i},IE=(s,e)=>{Fr||=new WeakMap;let r=Fr.get(s);if(r?.[e])return r[e];let t=s.type==="public",n=!!t,i;if(s.asymmetricKeyType==="x25519"){switch(e){case "ECDH-ES":case "ECDH-ES+A128KW":case "ECDH-ES+A192KW":case "ECDH-ES+A256KW":break;default:throw new TypeError("given KeyObject instance cannot be used for this algorithm")}i=s.toCryptoKey(s.asymmetricKeyType,n,t?[]:["deriveBits"]);}if(s.asymmetricKeyType==="ed25519"){if(e!=="EdDSA"&&e!=="Ed25519")throw new TypeError("given KeyObject instance cannot be used for this algorithm");i=s.toCryptoKey(s.asymmetricKeyType,n,[t?"verify":"sign"]);}switch(s.asymmetricKeyType){case "ml-dsa-44":case "ml-dsa-65":case "ml-dsa-87":{if(e!==s.asymmetricKeyType.toUpperCase())throw new TypeError("given KeyObject instance cannot be used for this algorithm");i=s.toCryptoKey(s.asymmetricKeyType,n,[t?"verify":"sign"]);}}if(s.asymmetricKeyType==="rsa"){let a;switch(e){case "RSA-OAEP":a="SHA-1";break;case "RS256":case "PS256":case "RSA-OAEP-256":a="SHA-256";break;case "RS384":case "PS384":case "RSA-OAEP-384":a="SHA-384";break;case "RS512":case "PS512":case "RSA-OAEP-512":a="SHA-512";break;default:throw new TypeError("given KeyObject instance cannot be used for this algorithm")}if(e.startsWith("RSA-OAEP"))return s.toCryptoKey({name:"RSA-OAEP",hash:a},n,t?["encrypt"]:["decrypt"]);i=s.toCryptoKey({name:e.startsWith("PS")?"RSA-PSS":"RSASSA-PKCS1-v1_5",hash:a},n,[t?"verify":"sign"]);}if(s.asymmetricKeyType==="ec"){let o=new Map([["prime256v1","P-256"],["secp384r1","P-384"],["secp521r1","P-521"]]).get(s.asymmetricKeyDetails?.namedCurve);if(!o)throw new TypeError("given KeyObject instance cannot be used for this algorithm");e==="ES256"&&o==="P-256"&&(i=s.toCryptoKey({name:"ECDSA",namedCurve:o},n,[t?"verify":"sign"])),e==="ES384"&&o==="P-384"&&(i=s.toCryptoKey({name:"ECDSA",namedCurve:o},n,[t?"verify":"sign"])),e==="ES512"&&o==="P-521"&&(i=s.toCryptoKey({name:"ECDSA",namedCurve:o},n,[t?"verify":"sign"])),e.startsWith("ECDH-ES")&&(i=s.toCryptoKey({name:"ECDH",namedCurve:o},n,t?[]:["deriveBits"]));}if(!i)throw new TypeError("given KeyObject instance cannot be used for this algorithm");return r?r[e]=i:Fr.set(s,{[e]:i}),i};async function Bi(s,e){if(s instanceof Uint8Array||rl(s))return s;if(sl(s)){if(s.type==="secret")return s.export();if("toCryptoKey"in s&&typeof s.toCryptoKey=="function")try{return IE(s,e)}catch(t){if(t instanceof TypeError)throw t}let r=s.export({format:"jwk"});return jp(s,r,e)}if(Ms(s))return s.k?Ur(s.k):jp(s,s,e,true);throw new Error("unreachable")}var qr=s=>s?.[Symbol.toStringTag],il=(s,e,r)=>{if(e.use!==void 0){let t;switch(r){case "sign":case "verify":t="sig";break;case "encrypt":case "decrypt":t="enc";break}if(e.use!==t)throw new TypeError(`Invalid key for this operation, its "use" must be "${t}" when present`)}if(e.alg!==void 0&&e.alg!==s)throw new TypeError(`Invalid key for this operation, its "alg" must be "${s}" when present`);if(Array.isArray(e.key_ops)){let t;switch(true){case(r==="sign"||r==="verify"):case s==="dir":case s.includes("CBC-HS"):t=r;break;case s.startsWith("PBES2"):t="deriveBits";break;case /^A\d{3}(?:GCM)?(?:KW)?$/.test(s):!s.includes("GCM")&&s.endsWith("KW")?t=r==="encrypt"?"wrapKey":"unwrapKey":t=r;break;case(r==="encrypt"&&s.startsWith("RSA")):t="wrapKey";break;case r==="decrypt":t=s.startsWith("RSA")?"unwrapKey":"deriveBits";break}if(t&&e.key_ops?.includes?.(t)===false)throw new TypeError(`Invalid key for this operation, its "key_ops" must include "${t}" when present`)}return true},LE=(s,e,r)=>{if(!(e instanceof Uint8Array)){if(Ms(e)){if(Dp(e)&&il(s,e,r))return;throw new TypeError('JSON Web Key for symmetric algorithms must have JWK "kty" (Key Type) equal to "oct" and the JWK "k" (Key Value) present')}if(!nl(e))throw new TypeError(tl(s,e,"CryptoKey","KeyObject","JSON Web Key","Uint8Array"));if(e.type!=="secret")throw new TypeError(`${qr(e)} instances for symmetric algorithms must be of type "secret"`)}},kE=(s,e,r)=>{if(Ms(e))switch(r){case "decrypt":case "sign":if($p(e)&&il(s,e,r))return;throw new TypeError("JSON Web Key for this operation must be a private JWK");case "encrypt":case "verify":if(Pp(e)&&il(s,e,r))return;throw new TypeError("JSON Web Key for this operation must be a public JWK")}if(!nl(e))throw new TypeError(tl(s,e,"CryptoKey","KeyObject","JSON Web Key"));if(e.type==="secret")throw new TypeError(`${qr(e)} instances for asymmetric algorithms must not be of type "secret"`);if(e.type==="public")switch(r){case "sign":throw new TypeError(`${qr(e)} instances for asymmetric algorithm signing must be of type "private"`);case "decrypt":throw new TypeError(`${qr(e)} instances for asymmetric algorithm decryption must be of type "private"`)}if(e.type==="private")switch(r){case "verify":throw new TypeError(`${qr(e)} instances for asymmetric algorithm verifying must be of type "public"`);case "encrypt":throw new TypeError(`${qr(e)} instances for asymmetric algorithm encryption must be of type "public"`)}};function Mi(s,e,r){switch(s.substring(0,2)){case "A1":case "A2":case "di":case "HS":case "PB":LE(s,e,r);break;default:kE(s,e,r);}}function Fi(s,e){let r=`SHA-${s.slice(-3)}`;switch(s){case "HS256":case "HS384":case "HS512":return {hash:r,name:"HMAC"};case "PS256":case "PS384":case "PS512":return {hash:r,name:"RSA-PSS",saltLength:parseInt(s.slice(-3),10)>>3};case "RS256":case "RS384":case "RS512":return {hash:r,name:"RSASSA-PKCS1-v1_5"};case "ES256":case "ES384":case "ES512":return {hash:r,name:"ECDSA",namedCurve:e.namedCurve};case "Ed25519":case "EdDSA":return {name:"Ed25519"};case "ML-DSA-44":case "ML-DSA-65":case "ML-DSA-87":return {name:s};default:throw new Me(`alg ${s} is not supported either by JOSE or your javascript runtime`)}}async function qi(s,e,r){if(e instanceof Uint8Array){if(!s.startsWith("HS"))throw new TypeError(Ip(e,"CryptoKey","KeyObject","JSON Web Key"));return crypto.subtle.importKey("raw",e,{hash:`SHA-${s.slice(-3)}`,name:"HMAC"},false,[r])}return Op(e,s,r),e}async function xp(s,e,r,t){let n=await qi(s,e,"verify");xi(s,n);let i=Fi(s,n.algorithm);try{return await crypto.subtle.verify(i,n,r,t)}catch{return false}}async function Up(s,e,r){if(!zt(s))throw new Y("Flattened JWS must be an object");if(s.protected===void 0&&s.header===void 0)throw new Y('Flattened JWS must have either of the "protected" or "header" members');if(s.protected!==void 0&&typeof s.protected!="string")throw new Y("JWS Protected Header incorrect type");if(s.payload===void 0)throw new Y("JWS Payload missing");if(typeof s.signature!="string")throw new Y("JWS Signature missing or incorrect type");if(s.header!==void 0&&!zt(s.header))throw new Y("JWS Unprotected Header incorrect type");let t={};if(s.protected)try{let b=Ur(s.protected);t=JSON.parse(vt.decode(b));}catch{throw new Y("JWS Protected Header is invalid")}if(!ji(t,s.header))throw new Y("JWS Protected and JWS Unprotected Header Parameter names must be disjoint");let n={...t,...s.header},i=Ui(Y,new Map([["b64",true]]),r?.crit,t,n),a=true;if(i.has("b64")&&(a=t.b64,typeof a!="boolean"))throw new Y('The "b64" (base64url-encode payload) Header Parameter must be a boolean');let{alg:o}=n;if(typeof o!="string"||!o)throw new Y('JWS "alg" (Algorithm) Header Parameter missing or invalid');let l=r&&kp("algorithms",r.algorithms);if(l&&!l.has(o))throw new Us('"alg" (Algorithm) Header Parameter value not allowed');if(a){if(typeof s.payload!="string")throw new Y("JWS Payload must be a string")}else if(typeof s.payload!="string"&&!(s.payload instanceof Uint8Array))throw new Y("JWS Payload must be a string or an Uint8Array instance");let u=false;typeof e=="function"&&(e=await e(t,s),u=true),Mi(o,e,"verify");let p=Pi(s.protected!==void 0?Yt(s.protected):new Uint8Array,Yt("."),typeof s.payload=="string"?a?Yt(s.payload):dr.encode(s.payload):s.payload),c;try{c=Ur(s.signature);}catch{throw new Y("Failed to base64url decode the signature")}let f=await Bi(e,o);if(!await xp(o,f,c,p))throw new Bs;let d;if(a)try{d=Ur(s.payload);}catch{throw new Y("Failed to base64url decode the payload")}else typeof s.payload=="string"?d=dr.encode(s.payload):d=s.payload;let g={payload:d};return s.protected!==void 0&&(g.protectedHeader=t),s.header!==void 0&&(g.unprotectedHeader=s.header),u?{...g,key:f}:g}async function Bp(s,e,r){if(s instanceof Uint8Array&&(s=vt.decode(s)),typeof s!="string")throw new Y("Compact JWS must be a string or Uint8Array");let{0:t,1:n,2:i,length:a}=s.split(".");if(a!==3)throw new Y("Invalid Compact JWS");let o=await Up({payload:n,protected:t,signature:i},e,r),l={payload:o.payload,protectedHeader:o.protectedHeader};return typeof e=="function"?{...l,key:o.key}:l}var Xt=s=>Math.floor(s.getTime()/1e3),Fp=60,qp=Fp*60,al=qp*24,$E=al*7,PE=al*365.25,DE=/^(\+|\-)? ?(\d+|\d+\.\d+) ?(seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)(?: (ago|from now))?$/i;function Fs(s){let e=DE.exec(s);if(!e||e[4]&&e[1])throw new TypeError("Invalid time period format");let r=parseFloat(e[2]),t=e[3].toLowerCase(),n;switch(t){case "sec":case "secs":case "second":case "seconds":case "s":n=Math.round(r);break;case "minute":case "minutes":case "min":case "mins":case "m":n=Math.round(r*Fp);break;case "hour":case "hours":case "hr":case "hrs":case "h":n=Math.round(r*qp);break;case "day":case "days":case "d":n=Math.round(r*al);break;case "week":case "weeks":case "w":n=Math.round(r*$E);break;default:n=Math.round(r*PE);break}return e[1]==="-"||e[4]==="ago"?-n:n}function gr(s,e){if(!Number.isFinite(e))throw new TypeError(`Invalid ${s} input`);return e}var Mp=s=>s.includes("/")?s.toLowerCase():`application/${s.toLowerCase()}`,jE=(s,e)=>typeof s=="string"?e.includes(s):Array.isArray(s)?e.some(Set.prototype.has.bind(new Set(s))):false;function Jp(s,e,r={}){let t;try{t=JSON.parse(vt.decode(e));}catch{}if(!zt(t))throw new Ot("JWT Claims Set must be a top-level JSON object");let{typ:n}=r;if(n&&(typeof s.typ!="string"||Mp(s.typ)!==Mp(n)))throw new $e('unexpected "typ" JWT header value',t,"typ","check_failed");let{requiredClaims:i=[],issuer:a,subject:o,audience:l,maxTokenAge:u}=r,p=[...i];u!==void 0&&p.push("iat"),l!==void 0&&p.push("aud"),o!==void 0&&p.push("sub"),a!==void 0&&p.push("iss");for(let d of new Set(p.reverse()))if(!(d in t))throw new $e(`missing required "${d}" claim`,t,d,"missing");if(a&&!(Array.isArray(a)?a:[a]).includes(t.iss))throw new $e('unexpected "iss" claim value',t,"iss","check_failed");if(o&&t.sub!==o)throw new $e('unexpected "sub" claim value',t,"sub","check_failed");if(l&&!jE(t.aud,typeof l=="string"?[l]:l))throw new $e('unexpected "aud" claim value',t,"aud","check_failed");let c;switch(typeof r.clockTolerance){case "string":c=Fs(r.clockTolerance);break;case "number":c=r.clockTolerance;break;case "undefined":c=0;break;default:throw new TypeError("Invalid clockTolerance option type")}let{currentDate:f}=r,m=Xt(f||new Date);if((t.iat!==void 0||u)&&typeof t.iat!="number")throw new $e('"iat" claim must be a number',t,"iat","invalid");if(t.nbf!==void 0){if(typeof t.nbf!="number")throw new $e('"nbf" claim must be a number',t,"nbf","invalid");if(t.nbf>m+c)throw new $e('"nbf" claim timestamp check failed',t,"nbf","check_failed")}if(t.exp!==void 0){if(typeof t.exp!="number")throw new $e('"exp" claim must be a number',t,"exp","invalid");if(t.exp<=m-c)throw new Br('"exp" claim timestamp check failed',t,"exp","check_failed")}if(u){let d=m-t.iat,g=typeof u=="number"?u:Fs(u);if(d-c>g)throw new Br('"iat" claim timestamp check failed (too far in the past)',t,"iat","check_failed");if(d<0-c)throw new $e('"iat" claim timestamp check failed (it should be in the past)',t,"iat","check_failed")}return t}var Ji=class{#e;constructor(e){if(!zt(e))throw new TypeError("JWT Claims Set MUST be an object");this.#e=structuredClone(e);}data(){return dr.encode(JSON.stringify(this.#e))}get iss(){return this.#e.iss}set iss(e){this.#e.iss=e;}get sub(){return this.#e.sub}set sub(e){this.#e.sub=e;}get aud(){return this.#e.aud}set aud(e){this.#e.aud=e;}set jti(e){this.#e.jti=e;}set nbf(e){typeof e=="number"?this.#e.nbf=gr("setNotBefore",e):e instanceof Date?this.#e.nbf=gr("setNotBefore",Xt(e)):this.#e.nbf=Xt(new Date)+Fs(e);}set exp(e){typeof e=="number"?this.#e.exp=gr("setExpirationTime",e):e instanceof Date?this.#e.exp=gr("setExpirationTime",Xt(e)):this.#e.exp=Xt(new Date)+Fs(e);}set iat(e){e===void 0?this.#e.iat=Xt(new Date):e instanceof Date?this.#e.iat=gr("setIssuedAt",Xt(e)):typeof e=="string"?this.#e.iat=gr("setIssuedAt",Xt(new Date)+Fs(e)):this.#e.iat=gr("setIssuedAt",e);}};async function yr(s,e,r){let t=await Bp(s,e,r);if(t.protectedHeader.crit?.includes("b64")&&t.protectedHeader.b64===false)throw new Ot("JWTs MUST NOT use unencoded payload");let i={payload:Jp(t.protectedHeader,t.payload,r),protectedHeader:t.protectedHeader};return typeof e=="function"?{...i,key:t.key}:i}async function Wp(s,e,r){let t=await qi(s,e,"sign");xi(s,t);let n=await crypto.subtle.sign(Fi(s,t.algorithm),t,r);return new Uint8Array(n)}var Wi=class{#e;#t;#r;constructor(e){if(!(e instanceof Uint8Array))throw new TypeError("payload must be an instance of Uint8Array");this.#e=e;}setProtectedHeader(e){if(this.#t)throw new TypeError("setProtectedHeader can only be called once");return this.#t=e,this}setUnprotectedHeader(e){if(this.#r)throw new TypeError("setUnprotectedHeader can only be called once");return this.#r=e,this}async sign(e,r){if(!this.#t&&!this.#r)throw new Y("either setProtectedHeader or setUnprotectedHeader must be called before #sign()");if(!ji(this.#t,this.#r))throw new Y("JWS Protected and JWS Unprotected Header Parameter names must be disjoint");let t={...this.#t,...this.#r},n=Ui(Y,new Map([["b64",true]]),r?.crit,this.#t,t),i=true;if(n.has("b64")&&(i=this.#t.b64,typeof i!="boolean"))throw new Y('The "b64" (base64url-encode payload) Header Parameter must be a boolean');let{alg:a}=t;if(typeof a!="string"||!a)throw new Y('JWS "alg" (Algorithm) Header Parameter missing or invalid');Mi(a,e,"sign");let o,l;i?(o=Di(this.#e),l=Yt(o)):(l=this.#e,o="");let u,p;this.#t?(u=Di(JSON.stringify(this.#t)),p=Yt(u)):(u="",p=new Uint8Array);let c=Pi(p,Yt("."),l),f=await Bi(e,a),m=await Wp(a,f,c),d={signature:Di(m),payload:o};return this.#r&&(d.header=this.#r),this.#t&&(d.protected=u),d}};var Hi=class{#e;constructor(e){this.#e=new Wi(e);}setProtectedHeader(e){return this.#e.setProtectedHeader(e),this}async sign(e,r){let t=await this.#e.sign(e,r);if(t.payload===void 0)throw new TypeError("use the flattened module for creating JWS with b64: false");return `${t.protected}.${t.payload}.${t.signature}`}};var Er=class{#e;#t;constructor(e={}){this.#t=new Ji(e);}setIssuer(e){return this.#t.iss=e,this}setSubject(e){return this.#t.sub=e,this}setAudience(e){return this.#t.aud=e,this}setJti(e){return this.#t.jti=e,this}setNotBefore(e){return this.#t.nbf=e,this}setExpirationTime(e){return this.#t.exp=e,this}setIssuedAt(e){return this.#t.iat=e,this}setProtectedHeader(e){return this.#e=e,this}async sign(e,r){let t=new Hi(this.#t.data());if(t.setProtectedHeader(this.#e),Array.isArray(this.#e?.crit)&&this.#e.crit.includes("b64")&&this.#e.b64===false)throw new Ot("JWTs MUST NOT use unencoded payload");return t.sign(e,r)}};async function Hp(s,e){if(!s||!s.startsWith("Bearer "))return e.anonymousEnabled?{kind:"ok",payload:null}:{kind:"error",response:Ze({status:401,code:"PGRST302",message:"Anonymous access is disabled"})};let r=s.slice(7).trim(),t=r.split(".");if(t.length!==3||t.some(n=>n.length===0))return e.anonymousEnabled?{kind:"ok",payload:null}:{kind:"error",response:Ze({status:401,code:"PGRST301",message:`Expected 3 parts in JWT; got ${Math.max(1,t.filter(n=>n.length>0).length)}`})};if(!e.jwtSecret)return {kind:"error",response:Ze({status:500,code:"PGRST300",message:"Server lacks JWT secret"})};try{let n=new TextEncoder().encode(e.jwtSecret),{payload:i}=await yr(r,n,{algorithms:["HS256"]});return typeof i.iat=="number"&&i.iat>Math.floor(Date.now()/1e3)?{kind:"error",response:Ze({status:401,code:"PGRST303",message:"JWT issued at future"})}:{kind:"ok",payload:i}}catch(n){return n instanceof Nt.JWTExpired?{kind:"error",response:Ze({status:401,code:"PGRST303",message:"JWT expired"})}:{kind:"error",response:Ze({status:401,code:"PGRST301",message:"No suitable key or wrong key type",details:"None of the keys was able to decode the JWT"})}}}function Gi(s,e,r,t){return !r||!e?.from?s:s.map(n=>ol(n,e.select,e.from,e.schema,e.join,r,t))}function ol(s,e,r,t,n,i,a){let o=i.get(`${t??a}.${r}`),l=UE(e,n),u={};for(let[p,c]of Object.entries(s)){let f=l.get(p);if(f&&"embed"in f){let g=f.embed;u[p]=xE(c,g,t,i,a);continue}let m=f?.sourceColumn??p,d=o?.get(m);u[p]=d?d.deserialize(c):c;}return u}function xE(s,e,r,t,n){return Array.isArray(s)?s.map(i=>i&&typeof i=="object"?ol(i,e.select,e.table,r,e.join,t,n):i):s&&typeof s=="object"?ol(s,e.select,e.table,r,e.join,t,n):s}function UE(s,e){let r=new Map;if(!s)return r;for(let t of s){if(typeof t=="string"){if(t==="*")continue;r.set(t,{sourceColumn:t});continue}if(!(!t||typeof t!="object"))for(let[n,i]of Object.entries(t))if(BE(i)){let a=e?.[n]?.from??n;r.set(n,{embed:{table:a,select:i.select,join:i.join}});}else {let a=i;if(a.cast||a.path||a.aggregate)continue;r.set(n,{sourceColumn:a.column??n});}}return r}function BE(s){return s!=null&&typeof s=="object"&&("select"in s||"where"in s||"order"in s||"limit"in s||"offset"in s||"spread"in s||"join"in s)}var qs=Symbol.for("lite-internal-request");function It(s){return JSON.stringify(s,(e,r)=>typeof r=="bigint"?Number.parseInt(r.toString(),10):r)}var Gp=/application\/vnd\.pgrst\.plan(?:\+(json|text))?/i;function Vp(s){let e=s.match(Gp);if(!e)return null;let r=e[1]?.toLowerCase()==="json"?"json":"text",t=s.match(/;\s*options=([^;]+)/i),n=t?`; options=${t[1].trim()}`:"";return {format:r,optionsSegment:n}}function Kp(s){return Gp.test(s)}function Yp(s){return /;\s*nulls\s*=\s*stripped/i.test(s)}function Sr(s){if(Array.isArray(s))return s.map(e=>Sr(e));if(s!==null&&typeof s=="object"){let e={};for(let[r,t]of Object.entries(s))t!==null&&(e[r]=Sr(t));return e}return s}function pl(s,e){if(!e||e.length===0)return s;let r=(t,n)=>{for(let i of e){if(i.embed)continue;let a=t[i.column],o=n[i.column],l=a==null,u=o==null;if(l&&u)continue;if(l)return i.nullsFirst?-1:1;if(u)return i.nullsFirst?1:-1;let p;if(typeof a=="number"&&typeof o=="number"?p=a-o:p=String(a).localeCompare(String(o)),p!==0)return i.direction==="desc"?-p:p}return 0};return [...s].sort(r)}function zp(s,e){return !e||e.length===0?s:s.map(r=>fl(r,e))}function Xp(s,e){if(!e||e.length===0)return s;let r=ME(e);return r.size===0?s:s.map(t=>{if(!Ws(t))return t;let n={...t};for(let i of r){let a=n[i];a!==null&&typeof a=="object"&&(n[i]=JSON.stringify(a));}return n})}function Qp(s,e){return !e||e.length===0?s:s.map(r=>ll(r,e))}function Zp(s,e){return !e||e.length===0?s:s.map(r=>ul(r,e))}function ef(s,e){return !e||e.length===0?s:s.map(r=>cl(r,e))}function ME(s){let e=new Set;for(let r of s){if(typeof r=="string")continue;let[t,n]=Object.entries(r)[0]??[];if(!t||!n)continue;let i=n;i.path&&i.pathText&&!tf(i.cast)&&e.add(t);}return e}function tf(s){let e=s?.trim().toLowerCase();return e==="json"||e==="jsonb"}function fl(s,e){if(Array.isArray(s))return s.map(t=>fl(t,e));if(!Ws(s))return s;let r={...s};for(let t of e){if(typeof t=="string")continue;let[n,i]=Object.entries(t)[0]??[];!n||!i||!Vi(i)||n in r&&(r[n]=qE(r[n],i.select));}return r}function ll(s,e){if(Array.isArray(s))return s.map(t=>ll(t,e));if(!Ws(s))return s;let r={...s};for(let t of e){if(typeof t=="string")continue;let[n,i]=Object.entries(t)[0]??[];if(!n||!i)continue;if(Vi(i)){n in r&&i.select&&(r[n]=ll(r[n],i.select));continue}let a=i;a.aggregate==="avg"&&a.cast!=="text"&&n in r&&(r[n]=FE(r[n]));}return r}function ul(s,e){if(Array.isArray(s))return s.map(t=>ul(t,e));if(!Ws(s))return s;let r={...s};for(let t of e){if(typeof t=="string")continue;let[n,i]=Object.entries(t)[0]??[];if(!n||!i)continue;if(Vi(i)){n in r&&i.select&&(r[n]=ul(r[n],i.select));continue}tf(i.cast)&&n in r&&(r[n]=rf(r[n]));}return r}function cl(s,e){if(Array.isArray(s))return s.map(t=>cl(t,e));if(!Ws(s))return s;let r={...s};for(let t of e){if(typeof t=="string")continue;let[n,i]=Object.entries(t)[0]??[];if(!n||!i)continue;if(Vi(i)){n in r&&i.select&&(r[n]=cl(r[n],i.select));continue}let a=i;a.path&&!a.pathText&&n in r&&(r[n]=rf(r[n]));}return r}function FE(s){if(typeof s!="string")return s;let e=s.trim();if(!/^[+-]?(?:\d+\.?\d*|\.\d+)(?:e[+-]?\d+)?$/i.test(e))return s;let r=Number(e);return !Number.isFinite(r)||e.replace(/^[+-]/,"").replace(/e[+-]?\d+$/i,"").replace(".","").replace(/^0+/,"").replace(/0+$/,"").length>15?s:r}function qE(s,e){let r=JE(s);return !e||e.length===0?r:fl(r,e)}function JE(s){if(typeof s!="string")return s;let e=s[0];if(e!=="["&&e!=="{")return s;try{return JSON.parse(s)}catch{return s}}function rf(s){if(typeof s!="string")return s;try{return JSON.parse(s)}catch{return s}}function Ws(s){return s!==null&&typeof s=="object"&&!Array.isArray(s)}function Vi(s){return s!==null&&typeof s=="object"&&("select"in s||"spread"in s||"join"in s)}var WE=new Set(["*/*","application/*","application/json","application/vnd.pgrst.object","application/vnd.pgrst.object+json","application/vnd.pgrst.array","application/vnd.pgrst.array+json","application/octet-stream","text/csv"]);function sf(s){let e=Vp(s);return e?`application/vnd.pgrst.plan+${e.format}; for="application/json"${e.optionsSegment}`:s}function nf(s,e){let r=s.split(",").map(t=>t.split(";")[0].trim().toLowerCase()).filter(Boolean);if(r.length===0)return true;for(let t of r)if(WE.has(t)||e&&t.startsWith("application/vnd.pgrst.plan"))return true;return false}function af(s,e){let r=Vp(s)??{format:"text",optionsSegment:""},t=`application/vnd.pgrst.plan+${r.format}; for="application/json"${r.optionsSegment}; charset=utf-8`,n=r.format==="json"?It({sql:e.sql,parameters:[...e.parameters]}):e.sql;return new Response(n,{status:200,headers:{"Content-Type":t}})}function br(s,e,r){let t=s+e-1,n=r!==void 0?`${r}`:"*";return `${s}-${t}/${n}`}async function Js(s,e,r,t){let n=e.join&&Object.values(e.join).some(p=>p.type==="inner"),i=HE(e);if(n||i){let p={...e,type:"query",order:void 0,limit:void 0,offset:void 0},c=he(p,r,{db:s,introspection:t}),{sql:f,parameters:m}=c.compile(),d=`SELECT count(*) as __count FROM (${f}) AS __inner_count`,b=(await s.executeQuery({sql:d,parameters:m,query:{kind:"RawNode"}})).rows?.[0];return Number(b?.__count??0)}let a={...e,type:"query",select:[{__count:{aggregate:"count"}}],order:void 0,limit:void 0,offset:void 0,join:void 0},l=await he(a,r,{db:s,introspection:t}).execute(),u=Array.isArray(l)?l[0]:l;return Number(u?.__count??0)}async function of(s,e,r,t){if(e.$meta?.count!=="planned"&&e.$meta?.count!=="estimated"||r!=="postgres")return Js(s,e,r,t);let n={...e,type:"query",order:void 0,limit:void 0,offset:void 0},a=he(n,r,{db:s,introspection:t}).compile(),u=(await s.executeQuery({sql:`EXPLAIN (FORMAT JSON) ${a.sql}`,parameters:a.parameters,query:{kind:"RawNode"}})).rows?.[0]?.["QUERY PLAN"],p=Array.isArray(u)&&u[0]&&typeof u[0]=="object"?u[0].Plan:void 0,c=p&&typeof p=="object"?Number(p["Plan Rows"]):Number.NaN;return Number.isFinite(c)?c:Js(s,e,r,t)}function HE(s){if(s.type!=="query"||!s.where||!s.select)return false;let e=GE(s.select);return e.size===0?false:lf(s.where,e)}function lf(s,e){for(let[r,t]of Object.entries(s)){if((r==="$or"||r==="$and")&&Array.isArray(t)){if(t.some(i=>i&&typeof i=="object"&&lf(i,e)))return true;continue}if(!e.has(r)||!t||typeof t!="object")continue;let n=t;if(n.$is===null||n.$isNot===null)return true}return false}function GE(s){let e=new Set;for(let r of s){if(typeof r=="string")continue;let[t,n]=Object.entries(r)[0]??[];t&&n&&typeof n=="object"&&"select"in n&&e.add(t);}return e}var VE=/[",\n\r ]/;function uf(s){if(s==null)return "";let e;return typeof s=="string"?e=s:typeof s=="number"||typeof s=="boolean"?e=String(s):typeof s=="bigint"?e=s.toString():e=JSON.stringify(s),VE.test(e)?`"${e.replace(/"/g,'""')}"`:e}function Ki(s,e){let r=s.length>0?Object.keys(s[0]):[];if(r.length===0)return "";let t=[r.map(n=>uf(n)).join(",")];for(let n of s)t.push(r.map(i=>uf(n[i])).join(","));return t.join(`
|
|
75
|
-
`)}function cf(s){return s.split(",").map(r=>r.split(";")[0].trim().toLowerCase()).includes("text/csv")}function mf(s,e){if(s.type!=="upsert"&&s.type!=="put")return {ast:s};if(s.type==="put"){if(s.limit!==void 0||s.offset!==void 0)return k(400,"PGRST114","limit/offset querystring parameters are not allowed for PUT",null,null);let t=pf(s,e),n=KE(s.where,t);if(!n)return k(405,"PGRST105","Filters must include all and only primary key columns with 'eq' operators",null,null);if(Array.isArray(s.values)&&s.values.length===0)return {ast:s,emptyPayload:true};if(!hl(s.values))return k(400,"PGRST102","Empty or invalid json",null,null);for(let i of t)if(!zE(s.values[i],n[i]))return k(400,"PGRST115","Payload values do not match URL in primary key column(s)",null,null);return s.onConflict=t,s.ignoreDuplicates=false,{ast:s,preflight:{mode:"put",conflictColumns:t}}}let r=s.onConflict?.length?s.onConflict:pf(s,e);return r.length===0?(s.onConflict=void 0,{ast:s}):(s.onConflict=r,{ast:s,appliedResolution:s.ignoreDuplicates?"ignore-duplicates":"merge-duplicates",preflight:s.ignoreDuplicates?void 0:{mode:"merge-duplicates",conflictColumns:r}})}function hf(s,e){let r=s.$meta,t={"Content-Type":"application/json; charset=utf-8"},n=ml(r,e.appliedResolution),i=r?.count==="exact"||r?.count==="planned"||r?.count==="estimated"?"*/0":"*/*";return r?.return==="representation"?(t["Content-Range"]=i,t["Content-Length"]="2",n&&(t["Preference-Applied"]=n),new Response("[]",{status:Lt(s,"representation",e.appliedResolution,false),headers:t})):(t["Content-Range"]=i,n&&(t["Preference-Applied"]=n),new Response(null,{status:Lt(s,"no-return",e.appliedResolution,false),headers:t}))}function pf(s,e){if(!s.from)return [];let r=s.schema??"public",t=e.primary_keys.find(n=>n.table===s.from&&n.schema===r);return t?t.columns:e.primary_keys.find(n=>n.table===s.from)?.columns??[]}function KE(s,e){if(!s||e.length===0)return null;let r=Object.keys(s);if(r.length!==e.length)return null;let t={};for(let n of r){if(n.startsWith("$")||!e.includes(n))return null;let i=YE(s[n]);if(!i.ok)return null;t[n]=i.value;}return t}function YE(s){if(!hl(s))return {ok:false};let e=Object.keys(s);return e.length!==1||e[0]!=="$eq"?{ok:false}:{ok:true,value:s.$eq}}function zE(s,e){return Object.is(s,e)?true:s!==null&&e!==null&&s!==void 0&&e!==void 0&&typeof s!="object"&&typeof e!="object"?String(s)===String(e):It(s)===It(e)}function ml(s,e){let r=[];return e&&r.push(`resolution=${e}`),s?.missing&&r.push(`missing=${s.missing}`),s?.return&&r.push(`return=${s.return}`),s?.count&&s.count!=="none"&&r.push(`count=${s.count}`),s?.tx&&r.push(`tx=${s.tx}`),r.length>0?r.join(", "):void 0}function Lt(s,e,r,t){switch(s.type){case "insert":return 201;case "upsert":return !r||r==="ignore-duplicates"?201:t===false?200:201;case "put":return e==="representation"?t?201:200:204;case "update":case "delete":return e==="representation"?200:204;default:return 200}}async function df(s,e,r,t,n){if(e.type==="insert")return true;if(!n.preflight||!e.from)return;if(n.preflight.mode==="put")return !await ff(s,e.from,e.schema,e.where??{},r,t);let i=Array.isArray(e.values)?e.values:e.values?[e.values]:[];for(let a of i){if(!hl(a))continue;let o=XE(n.preflight.conflictColumns,a);if(!o||!await ff(s,e.from,e.schema,o,r,t))return true}return false}function XE(s,e){let r={};for(let t of s){if(!(t in e))return;r[t]={$eq:e[t]};}return r}async function ff(s,e,r,t,n,i){return await Js(s,{type:"query",from:e,schema:r,where:t},n,i)>0}function hl(s){return s!==null&&typeof s=="object"&&!Array.isArray(s)}function yf(s){return s?.count==="exact"||s?.count==="planned"||s?.count==="estimated"}function gf(s,e,r){return yf(e)?`*/${r??0}`:s.type==="update"&&r!==0?br(0,r??1,void 0):"*/*"}function QE(s,e,r,t){return e&&(s.type==="insert"||s.type==="upsert"||s.type==="delete")?t!==void 0?`*/${t}`:"*/*":br(r,1,t)}function Ef(s){return "select"in s||"spread"in s||"join"in s}function Sf(s,e){if(s){for(let r of s)if(typeof r!="string")for(let t of Object.values(r))Ef(t)&&((t.limit===void 0||t.limit>e)&&(t.limit=e),Sf(t.select,e));}}function ZE(s){if(!s)return false;for(let e of s)if(typeof e!="string")for(let[r,t]of Object.entries(e)){if(Ef(t))return true;let n=t;if(n.path||n.cast||n.preCast||n.aggregate||(n.column??r)!==r)return true}return false}var eS={swagger:"2.0",info:{description:"",title:"standard public schema",version:"14.1"},basePath:"/",schemes:["https"],consumes:["application/json","application/vnd.pgrst.object+json;nulls=stripped","application/vnd.pgrst.object+json","text/csv"],produces:["application/json","application/vnd.pgrst.object+json;nulls=stripped","application/vnd.pgrst.object+json","text/csv"]},bf=s=>new be().all("/:relation",async e=>{let{app:r}=e.var,t=r.connection;if(!r.config.api?.enabled)return e.notFound();let n=e.req.param("relation"),i=await t.introspect({useCache:true});if(t.config.introspection?.exclude_tables?.some(f=>ki(n,f,"sql")))return e.notFound();if(!(qs in e.req.raw)){let f=await Hp(e.req.header("Authorization"),{jwtSecret:r.config.auth?.jwt_secret,anonymousEnabled:r.config.api?.anonymous_enabled!==false});if(f.kind==="error")return f.response;f.payload&&(e.set("userId",f.payload.sub),e.set("sessionId",f.payload.session_id),e.set("jwt",f.payload));}let{dialect:o}=t,l=t.config.translation?.deparse?.schema,u=e.var.jwt,p={auth:{uid:e.var.userId??null,role:u?.role||"anon",jwt:u??null}},c;try{if(c=await gi(e.req.raw,{basePath:"/rest/v1"}),c.schema){let R=new Set;for(let O of i.tables)O.schema&&R.add(O.schema);for(let O of i.views)O.schema&&R.add(O.schema);if(R.size>0&&R.add("public"),R.size>0&&!R.has(c.schema)){let O=[...R].sort().join(", ");return k(406,"PGRST106",`Invalid schema: ${c.schema}`,null,`Only the following schemas are exposed: ${O}`)}}if(c=await t.onPostgrestAST(c,p),s?.debug&&console.log(Ve.default.dim("[POSTGREST:AST]"),c),r.config.api?.aggregates_enabled!==!0&&Po(c.select))return k(400,"PGRST123","Use of aggregate functions is not allowed",null,null);let f=e.req.header("Accept")??"application/json",m=r.config.api?.plan_enabled===!0;if(!nf(f,m))return k(406,"PGRST107",`None of these media types are available: ${sf(f)}`,null,null);let d=Yp(f),g=cf(f),b=e.req.header("Prefer");if(b){let R=b.split(",").map(_=>_.trim()).filter(Boolean);if(R.find(_=>_.startsWith("handling="))==="handling=strict"){let _=R.filter(I=>!I.includes("="));if(_.length>0)return k(400,"PGRST122","Invalid preferences given with handling=strict",`Invalid preferences: ${_.join(", ")}`,null)}}if(t.dialect==="sqlite"&&c.from){let R=c.schema??"",O=i.tables.some(I=>I.name===c.from&&(I.schema??"")===R),_=i.views.some(I=>I.name===c.from&&(I.schema??"")===R);if(!O&&!_)throw new xs(c.schema,c.from)}let y=c.$meta,T=c.type==="update"||c.type==="delete"||c.type==="insert"||c.type==="upsert"||c.type==="put",C={ast:c};if(T&&y?.return!=="representation"&&(c.select=void 0),(c.type==="put"||c.type==="upsert")&&(c.limit!==void 0||c.offset!==void 0))return k(400,"PGRST114","limit/offset querystring parameters are not allowed for PUT",null,null);if((c.type==="update"||c.type==="delete"||c.type==="insert")&&r.config.api?.limited_mutations_enabled!==!0&&(c.limit=void 0,c.offset=void 0),r.config.api?.pg_safe_update&&T){let R=c.where&&Object.keys(c.where).length>0;if(c.type==="update"&&!R)return k(400,"21000","UPDATE requires a WHERE clause",null,null);if(c.type==="delete"&&!R)return k(400,"21000","DELETE requires a WHERE clause",null,null)}if(T&&(c.type==="insert"||c.type==="update"||c.type==="upsert"||c.type==="put")){if((c.type==="update"||c.type==="insert"||c.type==="upsert"||c.type==="put")&&(c.values===void 0||c.values===null))return k(400,"PGRST102","Empty or invalid json",null,null);if(c.type==="update"&&c.values&&typeof c.values=="object"&&!Array.isArray(c.values)&&Object.keys(c.values).length===0){let R=y?.return==="representation"?200:204,O={"Content-Type":"application/json; charset=utf-8","Content-Range":"*/*"};if(y?.return==="representation"){let _=new TextEncoder().encode("[]");return O["Content-Length"]=String(_.byteLength),O["Preference-Applied"]="return=representation",new Response(_,{status:R,headers:O})}return new Response(null,{status:R,headers:O})}if(c.type==="put"&&Array.isArray(c.values)&&(c.values.length===0?C.emptyPayload=!0:c.values=c.values[0]),Array.isArray(c.values)){if(y?.cardinality==="one"&&(c.type==="insert"||c.type==="upsert")&&c.values.length>1)return k(406,"PGRST116","Cannot coerce the result to a single JSON object",`The result contains ${c.values.length} rows`,null);if(c.values.length>0&&c.values.some(R=>typeof R!="object"||R===null||Array.isArray(R)))return y?.columns?k(400,"22023","argument of jsonb_to_recordset must be an array of objects",null,null):k(400,"PGRST102","All object keys must match",null,null);if(!y?.columns&&c.values.length>1){let R=Object.keys(c.values[0]).sort().join(",");for(let O=1;O<c.values.length;O++)if(Object.keys(c.values[O]).sort().join(",")!==R)return k(400,"PGRST102","All object keys must match",null,null)}}if(y?.columns&&c.from){let R=i.columns.filter(_=>_.table===c.from).map(_=>_.name);for(let _ of y.columns){if(_==="")return k(400,"PGRST100",'"failed to parse columns parameter ()" (line 1, column 1)',"unexpected end of input",null);if(!R.includes(_))return k(400,"PGRST204",`Could not find the '${_}' column of '${c.from}' in the schema cache`,null,null)}let O=new Set(y.columns);if(c.values)if(Array.isArray(c.values))c.values=c.values.map(_=>{let I={};for(let K of O)K in _&&(I[K]=_[K]);return I});else {let _={};for(let I of O)I in c.values&&(_[I]=c.values[I]);c.values=_;}}if(!y?.columns&&c.values&&c.from&&(c.type==="insert"||c.type==="update"||c.type==="upsert"||c.type==="put")){let R=i.columns.filter(O=>O.table===c.from).map(O=>O.name);if(R.length>0){let O=Array.isArray(c.values)?c.values.length>0?Object.keys(c.values[0]):[]:Object.keys(c.values);for(let _ of O)if(!R.includes(_))return k(400,"PGRST204",`Could not find the '${_}' column of '${c.from}' in the schema cache`,null,null)}}if(c.values&&c.from&&(c.type==="insert"||c.type==="update"||c.type==="upsert"||c.type==="put")){let R=c.schema??"public",O=new Set(i.columns.filter(_=>_.table===c.from&&(_.schema||"public")===R&&_.is_generated===!0).map(_=>_.name));if(O.size>0){let _=Array.isArray(c.values)?c.values:[c.values];for(let I of _)if(!(!I||typeof I!="object")){for(let K of Object.keys(I))if(O.has(K))return k(400,"428C9",`cannot insert a non-DEFAULT value into column "${K}"`,`Column "${K}" is a generated column.`,null)}}}}let w=mf(c,i);if(w instanceof Response)return w;if(C=w,c=C.ast,T&&((c.type==="insert"||c.type==="upsert")&&Array.isArray(c.values)&&c.values.length===0||C.emptyPayload))return y?.cardinality==="one"?k(406,"PGRST116","Cannot coerce the result to a single JSON object","The result contains 0 rows",null):hf(c,C);let A=e.req.method.toUpperCase(),v=e.req.header("Range");if(v&&(A==="GET"||A==="HEAD")){let R=v.match(/^(\d+)-(\d*)$/);if(R){let O=parseInt(R[1],10);if(R[2]!==""){let _=parseInt(R[2],10);if(O>_)return k(416,"PGRST103","Requested range not satisfiable","The lower boundary must be lower than or equal to the upper boundary in the Range header.",null);c.offset=O,c.limit=_-O+1;}else c.offset=O;}}if(c.limit!==void 0&&c.limit<0||c.limit===0&&c.offset!==void 0&&c.offset>0)return k(416,"PGRST103","Requested range not satisfiable","Limit should be greater than or equal to zero.",null);if(c.offset!==void 0&&c.offset<0&&(c.offset=0),!T){let R=r.config.api?.max_rows;R!==void 0&&R>0&&((c.limit===void 0||c.limit>R)&&(c.limit=R),Sf(c.select,R));}return await t.withContext(p,async R=>{let O=e.req.header("Accept")??"application/json";if(m&&Kp(O)){let W=he(c,o,{db:R,introspection:i,schema:l}).compile();return s?.debug&&console.info(Ve.default.dim(`[POSTGREST:PLAN] ${W.sql}
|
|
76
|
-
- ${JSON.stringify([...
|
|
77
|
-
- ${JSON.stringify([...
|
|
78
|
-
- ${JSON.stringify([...
|
|
79
|
-
- ${JSON.stringify([...
|
|
80
|
-
- ${JSON.stringify([...
|
|
81
|
-
- ${JSON.stringify([...
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
- ${JSON.stringify([...nt])}`));}Q=await ps.execute();}}Q=Q.map(qe=>t.deserializeRow(qe)),Q=Gi(Q,c,l,"public"),c.order&&c.order.length>0&&(Q=pl(Q,c.order));let tt=Lt(c,"representation",C.appliedResolution,_),ee=Q.length,Oe=["return=representation"];y?.count&&Oe.push(`count=${y.count}`),y?.tx&&Oe.push(`tx=${y.tx}`);let Bt=c.type==="delete"||c.type==="insert"||c.type==="upsert"?"*/*":ee>0?br(0,ee,void 0):"*/*",De=d?Sr(Q):Q,je=g?Ki(De):It(De),gt=new TextEncoder().encode(je),Mt={"Content-Type":g?"text/csv; charset=utf-8":d?"application/vnd.pgrst.array+json;nulls=stripped; charset=utf-8":"application/json; charset=utf-8","Content-Range":Bt,"Content-Length":String(gt.byteLength)};if(Oe.length>0&&(Mt["Preference-Applied"]=Oe.join(", ")),(c.type==="insert"||c.type==="upsert")&&W.length>0&&Q.length>0){let qe=Q[0],we=W.map(rt=>`${rt}=eq.${qe[rt]}`).join("&");Mt.Location=`/${c.from}?${we}`;}return new Response(gt,{status:tt,headers:Mt})}let ce=he(c,o,{db:R,introspection:i,schema:l}),{sql:Xe,parameters:jn}=ce.compile();s?.debug&&console.info(Ve.default.dim(`[POSTGREST:SQL] ${Xe}
|
|
85
|
-
- ${JSON.stringify([...jn])}`));let dt=await ce.execute(),se,Cu=!1,us=0;if(T&&Array.isArray(dt)&&dt.length>0&&dt[0]&&typeof dt[0]=="object"&&("numUpdatedRows"in dt[0]||"numInsertedOrUpdatedRows"in dt[0]||"numDeletedRows"in dt[0])){Cu=!0;let oe=dt[0];us=Number(oe.numUpdatedRows??oe.numInsertedOrUpdatedRows??oe.numDeletedRows??0),se=[];}else se=dt;let $a=Array.isArray(se);$a&&(se=se.map(oe=>t.deserializeRow(oe)),se=Gi(se,c,l,"public"),se=zp(se,c.select),se=Qp(se,c.select),se=Zp(se,c.select),se=ef(se,c.select),t.dialect==="sqlite"&&(se=Xp(se,c.select))),T&&$a&&c.order&&c.order.length>0&&(se=pl(se,c.order));let Pa=$a?se:[],Ut=Pa.length,tr=c.offset??0;if(T&&Cu){if(y?.cardinality==="one"){if(us===0)return k(406,"PGRST116","Cannot coerce the result to a single JSON object","The result contains 0 rows",null);if(us>1)return k(406,"PGRST116","Cannot coerce the result to a single JSON object",`The result contains ${us} rows`,null)}let oe=Lt(c,"no-return",C.appliedResolution,_),W={"Content-Type":"application/json; charset=utf-8","Content-Range":gf(c,y,us)};return I&&(W["Preference-Applied"]=I),new Response(null,{status:oe,headers:W})}let Se;if(yf(y)&&(T?Se=Ut:Se=await of(R,c,o,i)),y?.cardinality==="one"){if(Ut===0)return k(406,"PGRST116","Cannot coerce the result to a single JSON object","The result contains 0 rows",null);if(Ut>1)return k(406,"PGRST116","Cannot coerce the result to a single JSON object",`The result contains ${Ut} rows`,null);let oe=200;T&&(oe=Lt(c,"representation",C.appliedResolution,_));let W=d?Sr(Pa[0]):Pa[0],Q=It(W),tt=new TextEncoder().encode(Q),ee={"Content-Type":d?"application/vnd.pgrst.object+json;nulls=stripped; charset=utf-8":"application/vnd.pgrst.object+json; charset=utf-8","Content-Range":QE(c,T,tr,Se),"Content-Length":String(tt.byteLength)};return I&&(ee["Preference-Applied"]=I),y?.head?new Response(null,{status:oe,headers:ee}):new Response(tt,{status:oe,headers:ee})}if(Se!==void 0&&tr>0&&Ut===0&&tr>=Se){let oe=JSON.stringify({code:"PGRST103",details:`An offset of ${tr} was requested, but there are only ${Se} rows.`,hint:null,message:"Requested range not satisfiable"}),W=new TextEncoder().encode(oe),Q={"Content-Type":"application/json; charset=utf-8","Content-Range":`*/${Se}`,"Content-Length":String(W.byteLength)};return I&&(Q["Preference-Applied"]=I),new Response(W,{status:416,headers:Q})}let cs;T&&(c.type==="insert"||c.type==="upsert"||c.type==="delete")?cs=Se!==void 0?`*/${Se}`:"*/*":T&&y?.return!=="representation"?cs=Se!==void 0?`*/${Se}`:"*/*":Ut>0?cs=br(tr,Ut,Se):cs=Se!==void 0?`*/${Se}`:"*/*";let xn=200;T?xn=Lt(c,"representation",C.appliedResolution,_):Se!==void 0&&(tr+Ut<Se||tr>0)&&(xn=206);let Un=d?Sr(se):se,Ih=g?Ki(Array.isArray(Un)?Un:[Un]):It(Un),Au=new TextEncoder().encode(Ih),Da={"Content-Type":g?"text/csv; charset=utf-8":d?"application/vnd.pgrst.array+json;nulls=stripped; charset=utf-8":"application/json; charset=utf-8","Content-Range":cs,"Content-Length":String(Au.byteLength)};return I&&(Da["Preference-Applied"]=I),y?.head?new Response(null,{status:xn,headers:Da}):new Response(Au,{status:xn,headers:Da})},{forceRollback:s?.forceRollback===!0})}catch(f){if(f instanceof me){let d=`"${f.message}" (line 1, column ${f.position})`;return k(400,"PGRST100",d,f.details,null)}if(f instanceof Be)return k(400,"PGRST100",f.message,f.details,null);if(f instanceof Vt)return k(400,"PGRST100",f.message,f.details,null);if(f instanceof Dr)return k(404,"PGRST125",f.message,f.details,null);if(f instanceof Ne)return k(f.httpStatus,f.code,f.message,f.details,f.hint);if(f instanceof jr)return k(400,"PGRST102",f.message,null,null);if(f instanceof Error&&f.message.startsWith("Invalid JSON body"))return k(400,"PGRST102","Empty or invalid json",null,null);if(f instanceof Ct)return k(400,"PGRST100",f.message,f.message,null);if(f instanceof hr)return k(400,"23514",f.message,`check constraint "${f.constraint}" violated`,null);if(f instanceof $i){let g=Li(p,"auth.role","anon")==="anon"?401:403;return Ze({status:g,code:"PGRST301",message:f.message})}let m=t.normalizeDbError(f);if(console.error(m),m instanceof xs){let d=[...i.tables.map(y=>y.name),...i.views.map(y=>y.name)],g=Rp(m.relation,d),b=m.schema||"public";return Ze({status:404,code:"PGRST205",message:m.message,hint:g?`Perhaps you meant the table '${b}.${g}'`:null})}if(m?.code==="42501"){let g=Li(p,"auth.role","anon")==="anon"?401:403;return Ze({status:g,code:"PGRST301",message:m.message})}if(m?.code==="42P01")return k(404,"PGRST205","Could not find the relation in the schema cache",m.message,null);if(m?.code==="23505"||m?.code==="23503")return k(409,m.code,m.message,m.detail??null,null);if(typeof m?.code=="string"){let d=m.code.slice(0,2);if(m.code==="42883")return k(404,m.code,m.message,m.detail??null,m.hint??null);if(d==="42"||d==="22"||d==="21"||m.code==="23502"){let g=m.message,b=c?.from;return m.code==="42703"&&b&&(g=g.replace(/^column "([^"]+)" does not exist$/,(y,T)=>`column ${b}.${T} does not exist`)),k(400,m.code,g,m.detail??null,m.hint??null)}if(d==="55")return k(500,m.code,m.message,m.detail??null,m.hint??null)}return m?.message?.includes("Unknown operator")?k(400,"PGRST100",m.message,null,null):m instanceof Error&&(m.message.includes("Expected identifier")||m.message.includes("Invalid filter")||m.message.includes("Unexpected input")||m.message.includes("Unsupported operator")||m.message.includes("failed to parse filter")||m.message.includes("failed to parse logic tree")||/^Expected .* at position \d+$/.test(m.message)||m.message.startsWith('Expected "(" for spread embed'))?k(400,"PGRST100",m.message,m.message,null):k(500,"SUP",String(m),null,null)}}).use(async(e,r)=>{if(e.req.method==="GET"&&e.req.path.endsWith("/"))return e.json(eS);await r();}).all("*",e=>k(404,"PGRST125","Invalid path specified in request URL",null,null));var Jr=class{maxSizeBytes;now;entries=new Map;sizeBytes=0;constructor(e={}){this.maxSizeBytes=e.maxSizeBytes??1024*1024,this.now=e.now??Date.now;}async get(e){let r=this.entries.get(e);if(r){if(this.isExpired(r)){this.deleteEntry(e,r);return}return this.entries.delete(e),this.entries.set(e,r),r.value}}async set(e,r,t){let n=this.entries.get(e);n&&this.deleteEntry(e,n);let i={value:r,size:Tf(e)+Tf(r),expiresAt:t?.ttl&&t.ttl>0?this.now()+t.ttl*1e3:void 0};this.entries.set(e,i),this.sizeBytes+=i.size,this.evictToSize();}async delete(e){let r=this.entries.get(e);r&&this.deleteEntry(e,r);}isExpired(e){return typeof e.expiresAt=="number"&&e.expiresAt<=this.now()}evictToSize(){for(;this.sizeBytes>this.maxSizeBytes;){let e=this.entries.keys().next().value;if(typeof e!="string")break;let r=this.entries.get(e);if(!r)break;this.deleteEntry(e,r);}}deleteEntry(e,r){this.entries.delete(e),this.sizeBytes-=r.size;}};function Tf(s){return new TextEncoder().encode(s).byteLength}var Yi=class{constructor(e){this.options=e;}async get(e){return await this.options.namespace.get(e)??void 0}async set(e,r,t){await this.options.namespace.put(e,r,{...t?.ttl&&t.ttl>0?{expirationTtl:t.ttl}:{}});}async delete(e){await this.options.namespace.delete(e);}};var zi=class{constructor(e){this.options=e;}async get(e){return await this.options.client.get(e)??void 0}async set(e,r,t){if(t?.ttl&&t.ttl>0){await this.options.client.set(e,r,"EX",t.ttl);return}await this.options.client.set(e,r);}async delete(e){if(this.options.client.del){await this.options.client.del(e);return}if(this.options.client.delete){await this.options.client.delete(e);return}throw new Error("RedisCacheDriver client must provide del() or delete()")}};var Xi=class{constructor(e){this.options=e;this.endpoint=e.endpoint??"https://api.resend.com/emails",this.fetchFn=e.fetch??fetch;}endpoint;fetchFn;async send(e){let r=await this.fetchFn(this.endpoint,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${this.options.apiKey}`},body:JSON.stringify({from:this.options.from,to:e.to,subject:e.subject,...e.text?{text:e.text}:{},...e.html?{html:e.html}:{}})});if(!r.ok)throw new Error(`Resend email failed (${r.status}): ${await r.text()}`)}};var Zi=class{constructor(e){this.options=e;this.endpoint=`https://email.${e.region}.amazonaws.com/v2/email/outbound-emails`,this.client=e.client;}endpoint;client;async send(e){let r=await this.getClient(),t={FromEmailAddress:this.options.from,Destination:{ToAddresses:[e.to]},Content:{Simple:{Subject:{Data:e.subject,Charset:"UTF-8"},Body:{...e.text?{Text:{Data:e.text,Charset:"UTF-8"}}:{},...e.html?{Html:{Data:e.html,Charset:"UTF-8"}}:{}}}}},n=await r.fetch(this.endpoint,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify(t)});if(!n.ok)throw new Error(`AWS SES email failed (${n.status}): ${await n.text()}`)}async getClient(){if(this.client)return this.client;let{AwsClient:e}=await Promise.resolve().then(()=>(_f(),Rf));return this.client=new e({accessKeyId:this.options.accessKeyId,secretAccessKey:this.options.secretAccessKey,service:"ses",region:this.options.region}),this.client}};var ea=class{constructor(e){this.options=e;this.sendmailPath=e.sendmailPath??"/usr/sbin/sendmail";}sendmailPath;async send(e){let{spawn:r}=await import('node:child_process').catch(()=>{throw new Error("SendmailEmailDriver requires a Node-compatible runtime")}),t=El(this.options.from,e);await new Promise((n,i)=>{let a=r(this.sendmailPath,["-t","-i"],{stdio:["pipe","ignore","pipe"]}),o=[];a.on("error",l=>{i(new Error(`SendmailEmailDriver failed to start ${this.sendmailPath}: ${l.message}`));}),a.stderr?.on("data",l=>o.push(Buffer.from(l))),a.on("close",l=>{if(l===0){n();return}i(new Error(`SendmailEmailDriver exited with code ${l}: ${Buffer.concat(o).toString("utf8")}`));}),a.stdin.end(t);});}};function El(s,e){let r=e.html?"text/html; charset=UTF-8":"text/plain; charset=UTF-8";return [`From: ${s}`,`To: ${e.to}`,`Subject: ${e.subject}`,"MIME-Version: 1.0",`Content-Type: ${r}`,"",e.html??e.text??""].join(`
|
|
86
|
-
`)}var Gs=class{messages=new Map;maxKeepCount;order=[];constructor(e={}){this.maxKeepCount=e.maxKeepCount??100;}async send(e){if(this.maxKeepCount<=0)return;let r=e.to.toLowerCase(),t={...e,sentAt:new Date().toISOString()},n=this.messages.get(r)??[];n.push(t),this.messages.set(r,n),this.order.push({key:r,message:t}),this.trim();}clear(){this.messages.clear(),this.order.length=0;}trim(){for(;this.order.length>this.maxKeepCount;){let e=this.order.shift();if(!e)return;let r=this.messages.get(e.key);if(!r)continue;let t=r.indexOf(e.message);t>=0&&r.splice(t,1),r.length===0&&this.messages.delete(e.key);}}},Wr=class extends Gs{silent;logger;constructor(e={}){super({maxKeepCount:0}),this.silent=e.silent??false,this.logger=e.logger??console;}async send(e){await super.send(e),this.silent||this.logger.info(["[@supabase/lite] Email driver noop send",`To: ${e.to}`,`Subject: ${e.subject}`,e.text?`Text: ${e.text}`:void 0,e.html?`HTML: ${e.html}`:void 0].filter(Boolean).join(`
|
|
87
|
-
`));}};var Vs=class{silent;logger;constructor(e={}){this.silent=e.silent??false,this.logger=e.logger??console;}async send(e){this.silent||this.logger.info(["[@supabase/lite] SMS driver noop send",`To: ${e.to}`,`Body: ${e.body}`].join(`
|
|
88
|
-
`));}};function vf(s={}){return {email:s.email??new Wr,sms:s.sms??new Vs,cache:s.cache??new Jr}}var Sl=new Map,Ks=class{constructor(e){this.driver=e;}async sendConfirmation(e,r,t,n){await this.send(nS(e,r,t,n));}async sendRecovery(e,r,t,n){await this.send(iS(e,r,t,n));}async sendMagicLink(e,r,t,n){await this.send(aS(e,r,t,n));}async sendEmailChange(e,r,t,n){await this.send(oS(e,r,t,n));}async sendReauthentication(e,r,t){await this.send(lS(e,r,t));}async send(e){await this.driver.send({to:e.to,subject:e.subject,text:e.body.text,html:e.body.html});}};function nS(s,e,r,t){return {to:s,subject:"Confirm Your Signup",body:{text:`Your confirmation code is: ${r}`,html:`<p>Your confirmation code is: <strong>${r}</strong></p><p><a href="http://localhost:3000/verify?token_hash=${e}&type=signup">Confirm</a></p>`},otp:r,tokenHash:e,meta:{...t,emailActionType:t?.emailActionType??"signup"}}}function iS(s,e,r,t){return {to:s,subject:"Reset Your Password",body:{text:`Your recovery code is: ${r}`,html:`<p>Your recovery code is: <strong>${r}</strong></p><p><a href="http://localhost:3000/verify?token_hash=${e}&type=recovery">Reset</a></p>`},otp:r,tokenHash:e,meta:{...t,emailActionType:t?.emailActionType??"recovery"}}}function aS(s,e,r,t){return {to:s,subject:"Your Magic Link",body:{text:`Your login code is: ${r}`,html:`<p>Your login code is: <strong>${r}</strong></p><p><a href="http://localhost:3000/verify?token_hash=${e}&type=magiclink">Login</a></p>`},otp:r,tokenHash:e,meta:{...t,emailActionType:t?.emailActionType??"magiclink"}}}function oS(s,e,r,t){return {to:s,subject:"Confirm Email Change",body:{text:`Your email change code is: ${r}`,html:`<p>Your email change code is: <strong>${r}</strong></p><p><a href="http://localhost:3000/verify?token_hash=${e}&type=email_change">Confirm</a></p>`},otp:r,tokenHash:e,meta:{...t,emailActionType:t?.emailActionType??"email_change"}}}function lS(s,e,r){return {to:s,subject:"Reauthentication",body:{text:`Your reauthentication code is: ${e}`,html:`<p>Your reauthentication code is: <strong>${e}</strong></p>`},otp:e,tokenHash:r?.tokenHash,meta:{...r,emailActionType:r?.emailActionType??"reauthentication"}}}var M=class extends Error{constructor(r,t,n,i,a){super(n);this.status=r;this.code=t;this.details=i;this.headers=a;this.name="AuthError";}toJSON(){return {code:this.status,error_code:this.code,msg:this.message,...this.details}}},ct=()=>new M(400,"invalid_credentials","Invalid login credentials"),Of=()=>new M(400,"email_not_confirmed","Email not confirmed"),Nf=(s,e=[],r=["length"])=>{let t=[];return r.includes("length")&&t.push(`Password should be at least ${s} characters.`),r.includes("characters")&&t.push(`Password should contain at least one character of each: ${e.join(", ")}.`),new M(422,"weak_password",t.join(" "),{weak_password:{reasons:r}})},If=(s="Access token is required")=>new M(401,"no_authorization",s),Hr=()=>new M(401,"no_authorization","This endpoint requires a valid Bearer token"),Ys=s=>new M(403,"bad_jwt",s),bl=()=>Ys("invalid JWT: unable to parse or verify signature, token is malformed: token contains an invalid number of segments"),Tl=s=>Ys(`invalid JWT: unable to parse or verify signature, token is malformed: could not JSON decode header: ${s}`),Lf=()=>Ys("invalid JWT: unable to parse or verify signature, token signature is invalid: signature is invalid"),kf=()=>Ys("invalid JWT: unable to parse or verify signature, token has invalid claims: token is expired"),wl=()=>Ys("invalid claim: missing sub claim"),Cl=()=>new M(400,"bad_jwt","invalid claim: sub claim must be a UUID");var $f=()=>new M(403,"user_not_found","User from sub claim in JWT does not exist"),Pf=()=>new M(403,"session_not_found","Session from session_id claim in JWT does not exist"),Df=()=>new M(422,"user_already_exists","User already registered"),jf=()=>new M(422,"email_exists","A user with this email address has already been registered"),Al=()=>new M(422,"signup_disabled","Signups not allowed for this instance"),xf=()=>new M(400,"email_provider_disabled","Email signups are disabled"),Uf=()=>new M(422,"otp_disabled","Signups not allowed for otp"),Bf=()=>new M(422,"same_password","New password should be different from the old password."),Gr=()=>new M(403,"otp_expired","Email link is invalid or has expired"),re=(s,e=422)=>new M(e,"validation_failed",s);var zs=s=>new M(400,"bad_json",s),Rl=()=>new M(400,"validation_failed","Refresh token is not valid"),Vr=()=>new M(400,"refresh_token_not_found","Invalid Refresh Token: Refresh Token Not Found"),ta=(s,e)=>new M(400,"refresh_token_already_used","Invalid Refresh Token: Already Used",void 0,{...s?{"Sb-Auth-Session-Id":s}:{},...e?{"Sb-Auth-User-Id":e}:{}}),Mf=()=>new M(401,"session_not_found","Invalid Refresh Token: Already Used"),_l=(s,e,r)=>new M(400,"session_expired",s==="inactivity"?"Invalid Refresh Token: Session Expired (Inactivity)":"Invalid Refresh Token: Session Expired",void 0,{...e?{"Sb-Auth-Session-Id":e}:{},...r?{"Sb-Auth-User-Id":r}:{}}),Ff=()=>new M(422,"anonymous_provider_disabled","Anonymous sign-ins are disabled"),qf=()=>new M(400,"invalid_credentials","unsupported_grant_type"),ra=()=>new M(429,"over_email_send_rate_limit","For security purposes, you can only request this after 59 seconds.");async function Ol(s,e,r){let t=new TextEncoder().encode(e),n=Math.floor(Date.now()/1e3);return new Er({...s,iat:n}).setProtectedHeader({alg:"HS256",typ:"JWT"}).setIssuedAt(n).setExpirationTime(n+r).sign(t)}async function Jf(s,e){let r=s.split(".");if(r.length!==3||r.some(i=>i===""))throw bl();let t=uS(r[0]);if(t)throw t;let n=new TextEncoder().encode(e);try{let{payload:i}=await yr(s,n,{algorithms:["HS256"]});return i}catch(i){throw i instanceof Nt.JWTExpired?kf():i instanceof Nt.JWSSignatureVerificationFailed?Lf():i instanceof Nt.JWSInvalid||i instanceof Nt.JWTInvalid?bl():i}}function uS(s){let e=cS(s);if(!e)return Tl("unexpected end of JSON input");let r=pS(e);try{return JSON.parse(new TextDecoder("utf-8").decode(e)),null}catch{return Tl(Nl(r))}}function cS(s){try{let e=s.replace(/-/g,"+").replace(/_/g,"/").padEnd(s.length+(4-s.length%4)%4,"="),r=atob(e),t=new Uint8Array(r.length);for(let n=0;n<r.length;n++)t[n]=r.charCodeAt(n);return t}catch{return null}}function pS(s){let e="";for(let r of s)e+=String.fromCharCode(r);return e}var fS={n:"null",t:"true",f:"false"};function Nl(s){let e=0;for(;e<s.length;){let i=s.charCodeAt(e);if(i===32||i===9||i===10||i===13)e++;else break}let r=s.slice(e);if(!r)return "unexpected end of JSON input";let t=r[0],n=fS[t];if(n){for(let i=1;i<n.length;i++){if(i>=r.length)return "unexpected end of JSON input";if(r[i]!==n[i])return `invalid character ${vl(r[i])} in literal ${n} (expecting '${n[i]}')`}return `invalid character ${vl(r[n.length]??" ")} after top-level value`}return t==="{"||t==="["||t==='"'||t==="-"||t>="0"&&t<="9"?"":`invalid character ${vl(t)} looking for beginning of value`}function vl(s){let e=s.codePointAt(0)??0;return e>=32&&e<127?`'${s}'`:`'\\u${e.toString(16).padStart(4,"0")}'`}async function Xs(s){return Wf.hash(s,10)}async function Il(s,e){return Wf.compare(s,e)}function Hf(s,e=6,r=[]){let t=[];return s.length<e&&t.push("length"),r.length>0&&r.some(n=>!mS(s,n))&&t.push("characters"),t}function mS(s,e){for(let r of s)if(e.includes(r))return true;return false}function kt(s=6){let e=crypto.getRandomValues(new Uint8Array(s)),r="";for(let t=0;t<s;t++)r+=(e[t]%10).toString();return r}function et(){let s=crypto.getRandomValues(new Uint8Array(32));return Array.from(s).map(e=>e.toString(16).padStart(2,"0")).join("")}function Ll(){return v7()}function Ke(){return v7()}function sa(s){if(!s.jwt_secret)throw new Error('[auth] is enabled but `auth.jwt_secret` is empty. Add `jwt_secret = "<secret>"` under [auth] in your config.toml.')}var Qs=class{constructor(e,r,t){this.repo=e;this.config=r;this.mailer=t;sa(r),this.jwtExpiry=r.jwt_expiry??3600,this.minPasswordLength=r.minimum_password_length??6,this.passwordRequiredCharacters=r.password_required_characters??dS(r.password_requirements),this.sessionTimeboxSeconds=Vf(r.sessions?.timebox),this.sessionInactivitySeconds=Vf(r.sessions?.inactivity_timeout);}jwtExpiry;minPasswordLength;passwordRequiredCharacters;sessionTimeboxSeconds;sessionInactivitySeconds;async signUp(e,r,t){if(this.config.enable_signup===false)throw Al();if(!e)throw Ff();if(this.config.email?.enable_signup===false)throw xf();if(r==null||r===void 0||r==="")throw re("Signup requires a valid password",400);if(!Kr(e))throw re("Unable to validate email address: invalid format",400);if(r.length>72)throw re("Password cannot be longer than 72 characters",400);this.assertPasswordStrong(r);let i=!(this.config.email?.enable_confirmations??this.config.enable_confirmations??false);e=e.toLowerCase();let a=await this.repo.findUserByEmail(e);if(a)throw i?(await this.createAuditLog(a.id,e,"user_repeated_signup","user"),Df()):ra();let o=Ke(),l=await Xs(r),u=new Date().toISOString(),p=null,c=null,f=null;i||(p=kt(),c=et(),f=u);let m={...t??{},email:e,email_verified:i,phone_verified:false,sub:o},d={...t??{},email:e,email_verified:false,phone_verified:false,sub:o},g=await this.repo.createUser({id:o,email:e,encrypted_password:l,confirmed_at:i?u:null,raw_user_meta_data:m,raw_app_meta_data:{provider:"email",providers:["email"]},confirmation_token:c,confirmation_sent_at:f});await this.repo.createIdentity({id:Ke(),provider:"email",provider_id:o,user_id:o,identity_data:d}),!i&&p&&c&&await this.mailer.sendConfirmation(e,c,p,{userId:o,redirectTo:this.config.site_url});let b=await this.repo.findIdentitiesByUserId(o),y=this.repo.parseUserJson(g),T=this.mapUserToResponse(y,b,"signup");if(i){let C=await this.createSessionForUser(y,b);return await this.createAuditLog(o,e,"user_signedup","team"),{user:T,session:C}}return await this.createAuditLog(o,e,"user_confirmation_requested","user"),{user:T}}async signInWithPassword(e,r){if(!e)throw re("missing email or phone",400);if(!r)throw ct();let t=await this.repo.findUserByEmail(e.toLowerCase());if(!t||!t.encrypted_password)throw ct();let n=this.repo.parseUserJson(t);if(!n.confirmed_at)throw Of();if(!await Il(r,n.encrypted_password))throw ct();let a=await this.repo.findIdentitiesByUserId(t.id);return this.createSessionForUser(n,a,"user")}async refreshSession(e){if(!e)throw Rl();let r=await this.repo.findRefreshToken(e);if(!r)throw gS(e)?Vr():Rl();if(Kf(r))return this.refreshWithRevokedToken(r);let t=await this.repo.findUserById(r.user_id);if(!t)throw Vr();let n=null;if(r.session_id){if(n=await this.repo.findSessionById(r.session_id),!n)throw Vr();this.assertSessionRefreshable(n);}let i=Yf(n?.updated_at,n?.refreshed_at,t.updated_at);await this.repo.revokeRefreshToken(r.id);let a=Ll(),o=r.session_id??Ke();return r.session_id?await this.repo.updateSessionRefreshedAt(r.session_id,i):await this.repo.createSession({id:o,user_id:t.id}),await this.repo.createRefreshToken({token:a,user_id:t.id,session_id:o,parent:r.token}),await this.createAuditLog(t.id,t.email??"","token_refreshed","token",false),await this.createAuditLog(t.id,t.email??"","token_revoked","token",false),this.createRefreshResponse(t,o,a,i)}async refreshWithRevokedToken(e){if(this.config.sessions?.single_per_user)throw Mf();if(!e.session_id)throw ta(e.session_id,e.user_id);let r=await this.repo.findRefreshTokensBySession(e.session_id),t=yS(r,e.token),n=t.filter(u=>!Kf(u));if((this.config.enable_refresh_token_rotation??false)&&t.length>1)throw await this.repo.revokeRefreshTokensByIds(n.map(u=>u.id)),ta(e.session_id,e.user_id);let i=n.at(-1);if(!i)throw ta(e.session_id,e.user_id);let a=await this.repo.findUserById(e.user_id);if(!a)throw Vr();let o=await this.repo.findSessionById(e.session_id);if(!o)throw Vr();this.assertSessionRefreshable(o);let l=Yf(o.updated_at,o.refreshed_at,a.updated_at);return await this.repo.updateSessionRefreshedAt(e.session_id,l),await this.createAuditLog(a.id,a.email??"","token_refreshed","token",false),this.createRefreshResponse(a,e.session_id,i.token,l)}async createRefreshResponse(e,r,t,n){let i=await this.repo.updateUser(e.id,{last_sign_in_at:n}),a=this.repo.parseUserJson(i??e),o=await this.repo.findIdentitiesByUserId(e.id),l=await Ol({sub:e.id,aud:e.aud||"authenticated",role:e.role||"authenticated",email:e.email??void 0,session_id:r},this.config.jwt_secret,this.jwtExpiry),u=Math.floor(Date.now()/1e3);return zf({access_token:l,refresh_token:t,token_type:"bearer",expires_in:this.jwtExpiry,expires_at:u+this.jwtExpiry,user:this.mapUserToResponse(a,o,"user")},r,e.id)}assertSessionRefreshable(e){let r=Date.now();if(this.sessionTimeboxSeconds!==void 0&&r-Date.parse(e.created_at)>this.sessionTimeboxSeconds*1e3)throw _l(void 0,e.id,e.user_id);let t=e.refreshed_at??e.created_at;if(this.sessionInactivitySeconds!==void 0&&r-Date.parse(t)>this.sessionInactivitySeconds*1e3)throw _l("inactivity",e.id,e.user_id)}async getUser(e){let r=await this.repo.findUserById(e);if(!r)throw ct();let t=this.repo.parseUserJson(r),n=await this.repo.findIdentitiesByUserId(e);return this.mapUserToResponse(t,n,"user")}async updateUser(e,r){let t=await this.repo.findUserById(e);if(!t)throw ct();let n=this.repo.parseUserJson(t),i={},a=false,o=false,l=r.data!==void 0||r.password!==void 0||r.email!==void 0;if(r.data!==void 0){let c=typeof n.raw_user_meta_data=="object"?n.raw_user_meta_data:{};i.raw_user_meta_data=hS(c,r.data??{}),a=true;}if(r.password!==void 0){if(this.assertPasswordStrong(r.password),n.encrypted_password&&await Il(r.password,n.encrypted_password))throw Bf();i.encrypted_password=await Xs(r.password),i.recovery_token=null,i.recovery_sent_at=null,a=true,o=true;}if(r.email!==void 0)if(r.email==="")a=true;else {let c=r.email.toLowerCase();if(!Kr(c))throw re("Unable to validate email address: invalid format",400);if(a=true,c!==n.email?.toLowerCase()){let f=await this.repo.findUserByEmail(c);if(f&&f.id!==e)throw jf();let m=new Date().toISOString(),d=kt(),g=et(),b=kt(),y=et(),T=this.config.email?.double_confirm_changes??true;i.email_change=c,i.email_change_token_current=T?g:null,i.email_change_token_new=y,i.email_change_sent_at=m,T?await this.mailer.sendEmailChange(c,g,d,{userId:e,tokenNew:b,tokenHashNew:y,redirectTo:this.config.site_url}):await this.mailer.sendEmailChange(c,y,b,{userId:e,redirectTo:this.config.site_url});}}l||(a=true);let u=n;if(Object.keys(i).length>0){let c=await this.repo.updateUser(e,i);if(!c)throw ct();u=this.repo.parseUserJson(c);}o&&await this.createAuditLog(e,n.email??"","user_updated_password","user",false),a&&await this.createAuditLog(e,n.email??"","user_modified","user",false);let p=await this.repo.findIdentitiesByUserId(e);return this.mapUserToResponse(u,p,"user")}async signOut(e,r,t){let n=r??"local";if(!["global","local","others"].includes(n))throw re(`Unsupported logout scope "${n}"`,400);let i=await this.repo.findUserById(t);if(!i)throw ct();let a=this.repo.parseUserJson(i);n==="global"?(await this.repo.deleteRefreshTokensForUser(t),await this.repo.deleteUserSessions(t)):n==="others"&&e?(await this.repo.deleteRefreshTokensForUser(t,e),await this.repo.deleteUserSessions(t,e)):e&&(await this.repo.deleteRefreshTokensForSession(e),await this.repo.deleteSession(e)),await this.createAuditLog(t,a.email??"","logout","account",false);}async signInWithOtp(e,r){if(!e)throw re("One of email or phone must be set",400);if(e=e.toLowerCase(),!Kr(e))throw re("Unable to validate email address: invalid format",400);let t=await this.repo.findUserByEmail(e),n=!t;if(!t&&r?.shouldCreateUser!==false){let l=Ke(),u=await Xs(et()),p=new Date().toISOString();t=await this.repo.createUser({id:l,email:e,encrypted_password:u,confirmed_at:p,raw_app_meta_data:{provider:"email",providers:["email"]},raw_user_meta_data:{email:e,email_verified:true,phone_verified:false,sub:l}}),await this.repo.createIdentity({id:Ke(),provider:"email",provider_id:l,user_id:l,identity_data:{email:e,email_verified:false,phone_verified:false,sub:l}});}if(!t)throw Uf();let i=kt(),a=et(),o=new Date().toISOString();if(await this.repo.updateUser(t.id,{recovery_token:a,recovery_sent_at:o}),await this.createAuditLog(t.id,e,"user_recovery_requested","user",false),await this.mailer.sendMagicLink(e,a,i,{userId:t.id,redirectTo:this.config.site_url}),n){let l=await this.repo.findUserById(t.id);if(!l)throw ct();let u=this.repo.parseUserJson(l),p=await this.repo.findIdentitiesByUserId(t.id);await this.createSessionForUser(u,p),await this.createAuditLog(t.id,e,"user_signedup","team");}}async requestMagicLink(e,r){if(!e)throw re("Password recovery requires an email",422);if(e=e.toLowerCase(),!Kr(e))throw re("Unable to validate email address: invalid format",400);let t=await this.repo.findUserByEmail(e),n=!t;if(!t){if(this.config.enable_signup===false)throw Al();let l=Ke(),u=await Xs(et()),p=new Date().toISOString();t=await this.repo.createUser({id:l,email:e,encrypted_password:u,confirmed_at:p,raw_app_meta_data:{provider:"email",providers:["email"]},raw_user_meta_data:{email:e,email_verified:true,phone_verified:false,sub:l}}),await this.repo.createIdentity({id:Ke(),provider:l,provider_id:l,user_id:l,identity_data:{email:e,email_verified:false,phone_verified:false,sub:l}});}let i=kt(),a=et(),o=new Date().toISOString();if(await this.repo.updateUser(t.id,{recovery_token:a,recovery_sent_at:o}),await this.createAuditLog(t.id,e,"user_recovery_requested","user",false),await this.mailer.sendMagicLink(e,a,i,{userId:t.id,redirectTo:this.config.site_url}),n){let l=await this.repo.findUserById(t.id);if(!l)throw ct();let u=this.repo.parseUserJson(l),p=await this.repo.findIdentitiesByUserId(t.id);await this.createSessionForUser(u,p),await this.createAuditLog(t.id,e,"user_signedup","team");}}async verifyOtp(e){let r=null,t=null;if(e.token_hash){let u=await this.findUserByTokenAndType(e.token_hash,e.type);r=u?.user??null,t=u?.tokenColumn??null;}else if(e.email&&e.token)if(r=await this.repo.findUserByEmail(e.email.toLowerCase()),r){for(let u of this.getTokenColumnsForType(e.type)){let p=r[u];if(p===e.token||this.otpMatchesStoredTokenHash(e.email,e.token,p)){t=u;break}}if(!t)throw Gr()}else throw Gr();else throw Gr();if(!r)throw Gr();let n=this.repo.parseUserJson(r),i=new Date().toISOString(),a={};if(n.confirmed_at||(a.confirmed_at=i),e.type==="email_change"&&n.email_change){a.email=n.email_change,a.email_change=null,a.email_change_token_current=null,a.email_change_token_new=null;let u=await this.repo.findIdentitiesByUserId(r.id);for(let p of u){let c=typeof p.identity_data=="string"?JSON.parse(p.identity_data):{...p.identity_data??{}};await this.repo.updateIdentity(p.id,{identity_data:{...c,email:n.email_change,email_verified:true}});}await this.createAuditLog(r.id,n.email??"","user_modified","user",false);}else if(e.type==="signup"){let u=typeof n.raw_user_meta_data=="object"?n.raw_user_meta_data:{};a.raw_user_meta_data={...u,email_verified:true};let p=await this.repo.findIdentitiesByUserId(r.id);for(let c of p){let f=typeof c.identity_data=="string"?JSON.parse(c.identity_data):{...c.identity_data??{}};await this.repo.updateIdentity(c.id,{identity_data:{...f,email_verified:true}});}t&&(a[t]=null);}else t&&(a[t]=null);a.last_sign_in_at=i,await this.repo.updateUser(r.id,a);let o=await this.repo.findUserById(r.id);if(!o)throw Gr();let l=await this.repo.findIdentitiesByUserId(r.id);return e.type==="signup"&&await this.createAuditLog(r.id,o.email??"","user_signedup","team"),this.createSessionForUser(this.repo.parseUserJson(o),l,"verify",{createLoginAudit:["magiclink","recovery"].includes(e.type),includeLoginProviderTrait:!["magiclink","recovery"].includes(e.type),authenticationMethod:["email_change","magiclink","recovery","signup"].includes(e.type)?"otp":"password"})}async recover(e){if(!e)throw re("Password recovery requires an email",400);if(e=e.toLowerCase(),!Kr(e))throw re("Unable to validate email address: invalid format",400);let r=await this.repo.findUserByEmail(e);if(!r)return;let t=kt(),n=et(),i=new Date().toISOString();await this.repo.updateUser(r.id,{recovery_token:n,recovery_sent_at:i}),await this.createAuditLog(r.id,e,"user_recovery_requested","user",false),await this.mailer.sendRecovery(e,n,t,{userId:r.id,redirectTo:this.config.site_url});}async resend(e,r){if(!["signup","email_change","sms","phone_change"].includes(e))throw re("Missing one of these types: signup, email_change, sms, phone_change",400);if((e==="signup"||e==="email_change")&&!r)throw re("Type provided requires an email address",400);if(!r)return;if(r=r.toLowerCase(),!Kr(r))throw re("Unable to validate email address: invalid format",400);let t=await this.repo.findUserByEmail(r);if(!t)return;let n=kt(),i=et(),a=new Date().toISOString();if(e==="signup"){if(t.confirmed_at||!t.confirmation_sent_at)return;throw ra()}else if(e==="email_change"){if(!t.email_change)return;if(t.email_change_sent_at)throw ra();await this.repo.updateUser(t.id,{email_change_token_new:i,email_change_sent_at:a}),await this.mailer.sendEmailChange(t.email_change,i,n,{userId:t.id,redirectTo:this.config.site_url});}}async reauthenticate(e){let r=await this.repo.findUserById(e);if(!r)throw If();let t=kt(),n=et(),i=new Date().toISOString();await this.repo.updateUser(r.id,{reauthentication_token:n,reauthentication_sent_at:i}),await this.mailer.sendReauthentication(r.email,t,{userId:r.id,tokenHash:n,redirectTo:this.config.site_url}),await this.createAuditLog(r.id,r.email??"","user_reauthenticate_requested","",false);}async createSessionForUser(e,r,t="session",n={}){let i=new Date().toISOString(),a=await this.repo.updateUser(e.id,{last_sign_in_at:i}),o=a?this.repo.parseUserJson(a):e;this.config.sessions?.single_per_user&&await this.repo.revokeUserRefreshTokens(e.id);let l=Ke();await this.repo.createSession({id:l,user_id:e.id});let u=Ll();await this.repo.createRefreshToken({token:u,user_id:e.id,session_id:l}),(n.createLoginAudit??true)&&await this.createAuditLog(e.id,e.email??"","login","account",n.includeLoginProviderTrait??true);let p=await Ol({sub:e.id,aud:e.aud||"authenticated",role:e.role||"authenticated",email:e.email??void 0,session_id:l},this.config.jwt_secret,this.jwtExpiry),c=Math.floor(Date.now()/1e3);return zf({access_token:p,refresh_token:u,token_type:"bearer",expires_in:this.jwtExpiry,expires_at:c+this.jwtExpiry,user:this.mapUserToResponse(o,r,t)},l,e.id)}assertPasswordStrong(e){let r=Hf(e,this.minPasswordLength,this.passwordRequiredCharacters);if(r.length>0)throw Nf(this.minPasswordLength,this.passwordRequiredCharacters,r)}mapUserToResponse(e,r,t){let n=typeof e.raw_app_meta_data=="string"?JSON.parse(e.raw_app_meta_data):e.raw_app_meta_data??{},i=typeof e.raw_user_meta_data=="string"?JSON.parse(e.raw_user_meta_data):e.raw_user_meta_data??{},a={id:e.id,aud:e.aud||"authenticated",role:e.role||"authenticated",email:e.email??"",phone:e.phone??"",app_metadata:n,user_metadata:i,identities:r.map(o=>this.mapIdentityToResponse(o,t,e)),created_at:e.created_at,updated_at:e.updated_at,is_anonymous:false};return e.confirmed_at&&(a.email_confirmed_at=e.confirmed_at,(t==="user"||t==="verify")&&(a.confirmed_at=e.confirmed_at)),e.last_sign_in_at&&(a.last_sign_in_at=e.last_sign_in_at),e.confirmation_sent_at&&(a.confirmation_sent_at=e.confirmation_sent_at),e.email_change&&(a.new_email=e.email_change),e.email_change_sent_at&&(a.email_change_sent_at=e.email_change_sent_at),t==="verify"&&e.recovery_sent_at&&(a.recovery_sent_at=e.recovery_sent_at),a}mapIdentityToResponse(e,r,t){let n=typeof e.identity_data=="string"?JSON.parse(e.identity_data):e.identity_data??{},i=r==="session"&&t.confirmed_at?{...n,email_verified:true}:n,a=e.email??(typeof i.email=="string"?i.email:t.email??void 0);return {identity_id:e.id,id:e.provider_id,user_id:e.user_id,identity_data:i,provider:"email",last_sign_in_at:e.last_sign_in_at??e.created_at,created_at:e.created_at,updated_at:e.updated_at,...a?{email:a}:{}}}async findUserByTokenAndType(e,r){if(r==="email_change"){let t=await this.repo.findUserByToken("email_change_token_current",e);if(t)return {user:t,tokenColumn:"email_change_token_current"};let n=await this.repo.findUserByToken("email_change_token_new",e);return n?{user:n,tokenColumn:"email_change_token_new"}:null}for(let t of this.getTokenColumnsForType(r)){let n=await this.repo.findUserByToken(t,e);if(n)return {user:n,tokenColumn:t}}return null}otpMatchesStoredTokenHash(e,r,t){return !r||typeof t!="string"?false:(Sl.get(e.toLowerCase())??[]).some(i=>i.otp===r&&i.tokenHash===t)}getTokenColumnsForType(e){switch(e){case "signup":return ["confirmation_token"];case "magiclink":return ["recovery_token","confirmation_token"];case "recovery":return ["recovery_token"];case "email_change":return ["email_change_token_new"];case "reauthentication":return ["reauthentication_token"];default:return []}}async createAuditLog(e,r,t,n,i=true){let a={action:t,actor_id:e,actor_username:r,actor_via_sso:false,log_type:n};i&&(a.traits={provider:"email"}),await this.repo.createAuditLogEntry({id:Ke(),payload:a});}};function hS(s,e){let r={...s};for(let[t,n]of Object.entries(e))n===null?delete r[t]:r[t]=n;return r}function dS(s){switch(s){case "letters_digits":return ["abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ","0123456789"];case "lower_upper_letters_digits":return ["abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ","0123456789"];case "lower_upper_letters_digits_symbols":return ["abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ","0123456789","!@#$%^&*"];default:return []}}function Vf(s){if(!s)return;let e=s.match(/^(\d+)(ms|s|m|h)?$/);if(!e)return;let r=Number(e[1]);switch(e[2]??"s"){case "ms":return r/1e3;case "m":return r*60;case "h":return r*3600;default:return r}}function Kr(s){return /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(s)}function gS(s){return /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(s)}function Kf(s){return s.revoked===true||s.revoked===1}function yS(s,e){let r=[],t=[e];for(;t.length>0;){let n=t.shift();for(let i of s)i.parent!==n||r.some(a=>a.id===i.id)||(r.push(i),t.push(i.token));}return r}function Yf(...s){let e=Math.max(0,...s.map(t=>t?Date.parse(t):0)),r=Date.now();return new Date(Math.max(r,e+1)).toISOString()}function zf(s,e,r){return Object.defineProperties(s,{session_id:{value:e,enumerable:false},user_id:{value:r,enumerable:false}}),s}function kl(s){if(s==null)return {};if(typeof s=="string")try{return JSON.parse(s)}catch{return {}}return s}function Tr(s){return typeof s=="string"?s:JSON.stringify(s??{})}var Zs=class{constructor(e,r){this.db=e;this.dialect=r;this.schema="auth";}schema;bool(e){return this.dialect==="sqlite"?e?1:0:e}table(e){return this.db.withSchema(this.schema).selectFrom(e)}insertInto(e){return this.db.withSchema(this.schema).insertInto(e)}update(e){return this.db.withSchema(this.schema).updateTable(e)}deleteFrom(e){return this.db.withSchema(this.schema).deleteFrom(e)}async findUserByEmail(e){return await this.table("users").selectAll().where("email","=",e.toLowerCase()).executeTakeFirst()??null}async findUserById(e){return await this.table("users").selectAll().where("id","=",e).executeTakeFirst()??null}async findUserByToken(e,r){return await this.table("users").selectAll().where(e,"=",r).executeTakeFirst()??null}async createUser(e){let r=new Date().toISOString(),t={id:e.id,aud:e.aud??"authenticated",role:e.role??"authenticated",email:e.email.toLowerCase(),encrypted_password:e.encrypted_password??null,phone:e.phone??null,email_confirmed_at:e.email_confirmed_at??e.confirmed_at??null,confirmation_token:e.confirmation_token??null,confirmation_sent_at:e.confirmation_sent_at??null,recovery_token:e.recovery_token??null,recovery_sent_at:e.recovery_sent_at??null,email_change:e.email_change??null,email_change_token_new:e.email_change_token_new??null,email_change_token_current:e.email_change_token_current??null,email_change_sent_at:e.email_change_sent_at??null,email_change_confirm_status:e.email_change_confirm_status??0,reauthentication_token:e.reauthentication_token??null,reauthentication_sent_at:e.reauthentication_sent_at??null,raw_app_meta_data:Tr(e.raw_app_meta_data??{provider:"email",providers:["email"]}),raw_user_meta_data:Tr(e.raw_user_meta_data??{}),is_sso_user:this.bool(e.is_sso_user??false),is_anonymous:this.bool(e.is_anonymous??false),last_sign_in_at:e.last_sign_in_at??null,created_at:r,updated_at:r};return await this.insertInto("users").values(t).execute(),await this.findUserById(e.id)}async updateUser(e,r){let t={...r,updated_at:new Date().toISOString()};return t.confirmed_at!=null&&t.email_confirmed_at==null&&(t.email_confirmed_at=t.confirmed_at),delete t.confirmed_at,t.raw_app_meta_data!=null&&(t.raw_app_meta_data=Tr(t.raw_app_meta_data)),t.raw_user_meta_data!=null&&(t.raw_user_meta_data=Tr(t.raw_user_meta_data)),t.is_sso_user!=null&&(t.is_sso_user=this.bool(!!t.is_sso_user)),t.is_anonymous!=null&&(t.is_anonymous=this.bool(!!t.is_anonymous)),await this.update("users").set(t).where("id","=",e).execute(),this.findUserById(e)}async createSession(e){let r=new Date().toISOString(),t={id:e.id,user_id:e.user_id,aal:e.aal??"aal1",not_after:null,refreshed_at:null,user_agent:null,ip:null,tag:null,refresh_token_hmac_key:null,refresh_token_counter:null,scopes:null,factor_id:null,created_at:r,updated_at:r};return await this.insertInto("sessions").values(t).execute(),t}async findSessionById(e){return await this.table("sessions").selectAll().where("id","=",e).executeTakeFirst()??null}async updateSessionRefreshedAt(e,r){return await this.update("sessions").set({refreshed_at:r,updated_at:r}).where("id","=",e).execute(),this.findSessionById(e)}async deleteSession(e){await this.deleteFrom("sessions").where("id","=",e).execute();}async deleteUserSessions(e,r){let t=this.deleteFrom("sessions").where("user_id","=",e);r&&(t=t.where("id","!=",r)),await t.execute();}async deleteRefreshTokensForSession(e){await this.deleteFrom("refresh_tokens").where("session_id","=",e).execute();}async deleteRefreshTokensForUser(e,r){let t=this.deleteFrom("refresh_tokens").where("user_id","=",e);r&&(t=t.where("session_id","!=",r)),await t.execute();}async createRefreshToken(e){let r=new Date().toISOString(),t={id:Ke(),token:e.token,user_id:e.user_id,session_id:e.session_id,revoked:this.bool(false),parent:e.parent??null,created_at:r,updated_at:r};return await this.insertInto("refresh_tokens").values(t).execute(),t}async findRefreshToken(e){return await this.table("refresh_tokens").selectAll().where("token","=",e).executeTakeFirst()??null}async findRefreshTokensBySession(e){return await this.table("refresh_tokens").selectAll().where("session_id","=",e).execute()}async revokeRefreshToken(e){await this.update("refresh_tokens").set({revoked:this.bool(true),updated_at:new Date().toISOString()}).where("id","=",e).execute();}async revokeSessionRefreshTokens(e){await this.update("refresh_tokens").set({revoked:this.bool(true),updated_at:new Date().toISOString()}).where("session_id","=",e).execute();}async revokeRefreshTokensByIds(e){e.length!==0&&await this.update("refresh_tokens").set({revoked:this.bool(true),updated_at:new Date().toISOString()}).where("id","in",e).execute();}async revokeUserRefreshTokens(e){await this.update("refresh_tokens").set({revoked:this.bool(true),updated_at:new Date().toISOString()}).where("user_id","=",e).execute();}async createIdentity(e){let r=new Date().toISOString(),t={id:e.id,provider:e.provider,provider_id:e.provider_id,user_id:e.user_id,identity_data:Tr(e.identity_data),last_sign_in_at:e.last_sign_in_at??r,created_at:r,updated_at:r};return await this.insertInto("identities").values(t).execute(),{...t,identity_data:e.identity_data}}async findIdentitiesByUserId(e){return (await this.table("identities").selectAll().where("user_id","=",e).execute()).map(t=>({...t,identity_data:kl(t.identity_data)}))}async updateIdentity(e,r){let t={...r,updated_at:new Date().toISOString()};t.identity_data!=null&&(t.identity_data=Tr(t.identity_data)),delete t.email,await this.update("identities").set(t).where("id","=",e).execute();}async createAuditLogEntry(e){let r={id:e.id,payload:Tr(e.payload??{}),ip_address:e.ip_address??"",created_at:new Date().toISOString()};await this.insertInto("audit_log_entries").values(r).execute();}parseUserJson(e){return {...e,raw_app_meta_data:kl(e.raw_app_meta_data),raw_user_meta_data:kl(e.raw_user_meta_data),confirmed_at:e.confirmed_at??e.email_confirmed_at??null}}};function Xf(){return {version:ES(),name:"GoTrue",description:"GoTrue is a user registration and authentication API"}}function Qf(s){return {external:{anonymous_users:s.enable_anonymous_sign_ins??false,apple:false,azure:false,bitbucket:false,discord:false,facebook:false,snapchat:false,figma:false,fly:false,github:false,gitlab:false,google:false,keycloak:false,kakao:false,linkedin:false,linkedin_oidc:false,notion:false,spotify:false,slack:false,slack_oidc:false,workos:false,twitch:false,twitter:false,email:s.email?.enable_signup??true,phone:false,zoom:false},disable_signup:!(s.enable_signup??true),mailer_autoconfirm:!(s.email?.enable_confirmations??false),phone_autoconfirm:false,sms_provider:"",saml_enabled:false}}function Zf(){return {keys:[]}}function em(){return {issuer:"",jwks_uri:"/.well-known/jwks.json"}}function ES(){return [$l(JSON.stringify({alg:"HS256",typ:"JWT"})),$l(JSON.stringify({name:"GoTrue",implementation:"@supabase/lite"})),$l("metadata")].join(".")}function $l(s){if(typeof Buffer<"u")return Buffer.from(s,"utf-8").toString("base64url");let e=new TextEncoder().encode(s),r="";for(let t of e)r+=String.fromCharCode(t);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}var Pl=s=>s;var SS="00000000-0000-0000-0000-000000000000",bS=/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i,Dl=({onError:s}={})=>Pl(async(e,r)=>{if(!e.var.userId||!e.var.sessionId){let t=await rm(e);if(t&&s)return s(t,e)}await r();}),en=()=>Pl(async(s,e)=>{if(!s.var.userId){let r=await rm(s);if(r)return tm(s,r);if(!s.var.userId)return tm(s,Hr())}await e();});async function rm(s){let e=s.req.header("Authorization");if(!e)return Hr();if(!e.startsWith("Bearer "))return Hr();let r=e.slice(7);if(!r||/^\s/.test(r))return Hr();let t=s.get("app").config.auth?.jwt_secret;if(!t)return null;let n;try{n=await Jf(r,t);}catch(u){return u instanceof M?u:Hr()}let i=TS(n);if(i)return i;let a=n.sub;if(n.role!=="service_role"&&!await s.var.authService.repo.findUserById(a))return $f();let l=n.session_id;if(l){if(!await s.var.authService.repo.findSessionById(l))return Pf();s.set("sessionId",l);}return s.set("userId",a),s.set("jwt",n),null}function TS(s){let e=s.sub,r=s.role;return e==null||e===""?wl():typeof e!="string"?Cl():bS.test(e)?e===SS&&r==="service_role"?wl():null:Cl()}function tm(s,e){return s.header("X-Sb-Error-Code",e.code),s.json(e.toJSON(),e.status)}var jl=new be().onError((s,e)=>{if(s instanceof M){e.header("X-Sb-Error-Code",s.code);for(let[r,t]of Object.entries(s.headers??{}))e.header(r,t);return e.json(s.toJSON(),s.status)}return console.error("Auth error:",s),e.json({error:"server_error",error_description:"Internal server error"},500)}).options("*",s=>{let e=s.req.header("Access-Control-Request-Method");return e&&s.header("Access-Control-Allow-Methods",e),s.header("Access-Control-Allow-Credentials","true"),s.header("Access-Control-Allow-Origin","*"),s.body(null,204)}).post("/signup",async s=>{let e=await $t(s,{requireBody:true}),{authService:r}=s.var,t=await r.signUp(e.email,e.password,e.data);return t.session?(na(s,t.session),s.json(t.session,200)):s.json(t.user,200)}).all("/signup",wr("POST")).post("/token",async s=>{let e=s.req.query("grant_type"),r=await $t(s,{requireBody:true}),{authService:t}=s.var;if(e==="password"){let n=await t.signInWithPassword(r.email,r.password);return na(s,n),s.json({...n,weak_password:null},200)}if(e==="refresh_token"){let n=await t.refreshSession(r.refresh_token);return na(s,n),s.json(n,200)}throw qf()}).all("/token",wr("POST")).post("/otp",async s=>{let e=await $t(s),{authService:r}=s.var;return await r.signInWithOtp(e.email,{shouldCreateUser:e.create_user??e.options?.shouldCreateUser}),s.json({},200)}).post("/magiclink",async s=>{let e=await $t(s),{authService:r}=s.var;return await r.requestMagicLink(e.email,e.gotrue_meta_security),s.json({},200)}).all("/magiclink",wr("POST")).post("/verify",async s=>{let e=await $t(s),{authService:r}=s.var;CS(e);let t=await r.verifyOtp({email:e.email,token:e.token,token_hash:e.token_hash,type:e.type});return na(s,t),s.json(t,200)}).get("/verify",s=>{let e=s.req.query("type");throw e?sm.has(e)?re("Verify requires a token or a token hash",400):re("Invalid email verification type",400):re("Verify requires a verification type",400)}).post("/recover",async s=>{let e=await $t(s),{authService:r}=s.var;return await r.recover(e.email),s.json({},200)}).post("/resend",async s=>{let e=await $t(s),{authService:r}=s.var;return await r.resend(e.type,e.email),s.json({},200)}).get("/health",s=>s.json(Xf(),200)).all("/health",wr("GET")).get("/settings",s=>s.json(Qf(s.var.app.config.auth??{}),200)).all("/settings",wr("GET")).get("/.well-known/jwks.json",s=>(s.header("Cache-Control","public, max-age=600"),s.json(Zf(),200))).get("/.well-known/openid-configuration",s=>(s.header("Cache-Control","public, max-age=600"),s.json(em(),200))).all("/nonexistent",wS).use(en()).post("/logout",async s=>{let e=await $t(s),{authService:r}=s.var;return await r.signOut(s.get("sessionId"),s.req.query("scope")??e.scope,s.get("userId")),s.body(null,204)}).get("/user",async s=>{let{authService:e}=s.var,r=await e.getUser(s.get("userId"));return s.json(r,200)}).put("/user",async s=>{let e=await $t(s),{authService:r}=s.var,t=await r.updateUser(s.get("userId"),{data:e.data,password:e.password,email:e.email});return s.json(t,200)}).all("/user",wr("GET, PUT")).get("/reauthenticate",async s=>{let{authService:e}=s.var;return await e.reauthenticate(s.get("userId")),s.json({},200)}).all("/reauthenticate",wr("GET"));function wr(s){return e=>(e.header("Allow",s),e.body(null,405))}function wS(s){return s.header("Content-Type","text/plain; charset=utf-8"),s.header("X-Content-Type-Options","nosniff"),s.body("404 page not found",404)}var sm=new Set(["signup","magiclink","recovery","email_change","reauthentication"]);function CS(s){let e=typeof s.type=="string"?s.type:"";if(!e)throw re("Verify requires a verification type",400);if(!sm.has(e))throw re("Invalid email verification type",400);let r=typeof s.token_hash=="string"?s.token_hash:"",t=typeof s.token=="string"?s.token:"",n=typeof s.email=="string"?s.email:"";if(e==="signup"&&!r&&!(n&&t))throw re("Verify requires either a token or a token hash",400)}async function $t(s,e={}){if(!s.req.raw.body){if(e.requireBody)throw zs("Could not parse request body as JSON: unexpected end of JSON input");return {}}let r=await s.req.text();if(r===""){if(e.requireBody)throw zs("Could not parse request body as JSON: unexpected end of JSON input");return {}}try{return JSON.parse(r)}catch{if(s.req.header("Content-Type")?.toLowerCase().split(";")[0]?.trim()==="application/x-www-form-urlencoded")throw zs("Could not parse request body as JSON: unexpected end of JSON input");let n=Nl(r)||"invalid character ' ' looking for beginning of value";throw zs(`Could not parse request body as JSON: ${n}`)}}function na(s,e){e.session_id&&s.header("Sb-Auth-Session-Id",e.session_id),e.user_id&&s.header("Sb-Auth-User-Id",e.user_id),e.refresh_token&&s.header("Sb-Auth-Refresh-Token-Prefix",String(e.refresh_token).slice(0,8));}function nm(s){let e=s.connection.dialect,r=new Zs(s.connection.kysely,e);return new Qs(r,s.config.auth,s._mailer??new Ks(s.drivers.email))}function im(s){if(s==null)return {};if(typeof s=="string")try{return JSON.parse(s)}catch{return {}}return s}function am(s){if(s==null)return [];if(Array.isArray(s))return s;if(typeof s=="string")try{return JSON.parse(s)}catch{return []}return []}function Qt(s){return typeof s=="string"?s:JSON.stringify(s??{})}var tn=class{constructor(e,r){this.db=e;this.dialect=r;this.schema="storage";}schema;table(e){return this.db.withSchema(this.schema).selectFrom(e)}insertInto(e){return this.db.withSchema(this.schema).insertInto(e)}update(e){return this.db.withSchema(this.schema).updateTable(e)}deleteFrom(e){return this.db.withSchema(this.schema).deleteFrom(e)}async createBucket(e){let r=new Date().toISOString(),t={id:e.id,name:e.name,owner:e.owner??null,owner_id:e.owner_id??null,public:e.public??false,file_size_limit:e.file_size_limit??null,allowed_mime_types:this.dialect==="postgres"?e.allowed_mime_types??null:Qt(e.allowed_mime_types??[]),created_at:r,updated_at:r};return await this.insertInto("buckets").values(t).execute(),await this.findBucketById(e.id)}async findBucketById(e){let r=await this.table("buckets").selectAll().where("id","=",e).executeTakeFirst();return r?this.parseBucketRow(r):null}async findBucketByName(e){let r=await this.table("buckets").selectAll().where("name","=",e).executeTakeFirst();return r?this.parseBucketRow(r):null}async listBuckets(){return (await this.table("buckets").selectAll().execute()).map(r=>this.parseBucketRow(r))}async updateBucket(e,r){let t={updated_at:new Date().toISOString()};return r.public!==void 0&&(t.public=r.public),r.file_size_limit!==void 0&&(t.file_size_limit=r.file_size_limit),r.allowed_mime_types!==void 0&&(t.allowed_mime_types=this.dialect==="postgres"?r.allowed_mime_types??null:Qt(r.allowed_mime_types)),await this.update("buckets").set(t).where("id","=",e).execute(),this.findBucketById(e)}async deleteBucket(e){await this.deleteFrom("buckets").where("id","=",e).execute();}async isBucketEmpty(e){let r=await this.table("objects").select(this.db.fn.count("id").as("count")).where("bucket_id","=",e).executeTakeFirst();return Number(r?.count??0)===0}async createObject(e){let r=new Date().toISOString(),t={id:e.id,bucket_id:e.bucket_id,name:e.name,owner:e.owner??null,owner_id:e.owner_id??null,metadata:Qt(e.metadata??{}),user_metadata:Qt(e.user_metadata??{}),version:e.version??null,created_at:r,updated_at:r,last_accessed_at:r};return this.dialect!=="postgres"&&(t.path_tokens=Qt(e.name.split("/"))),await this.insertInto("objects").values(t).execute(),await this.findObjectById(e.id)}async findObjectById(e){let r=await this.table("objects").selectAll().where("id","=",e).executeTakeFirst();return r?this.parseObjectRow(r):null}async findObjectByPath(e,r){let t=await this.table("objects").selectAll().where("bucket_id","=",e).where("name","=",r).executeTakeFirst();return t?this.parseObjectRow(t):null}async listObjects(e,r,t){let n=this.table("objects").selectAll().where("bucket_id","=",e);return r&&(n=n.where("name","like",`${r}%`)),t?.search&&(n=n.where("name","like",`%${t.search}%`)),t?.sortBy?n=n.orderBy(t.sortBy.column,t.sortBy.order):n=n.orderBy("name","asc"),t?.limit&&(n=n.limit(t.limit)),t?.offset&&(n=n.offset(t.offset)),(await n.execute()).map(a=>this.parseObjectRow(a))}async updateObject(e,r){let t={updated_at:new Date().toISOString()};return r.name!==void 0&&(t.name=r.name,this.dialect!=="postgres"&&(t.path_tokens=Qt(r.name.split("/")))),r.metadata!==void 0&&(t.metadata=Qt(r.metadata)),r.user_metadata!==void 0&&(t.user_metadata=Qt(r.user_metadata)),r.version!==void 0&&(t.version=r.version),r.owner!==void 0&&(t.owner=r.owner),r.owner_id!==void 0&&(t.owner_id=r.owner_id),await this.update("objects").set(t).where("id","=",e).execute(),this.findObjectById(e)}async deleteObject(e){await this.deleteFrom("objects").where("id","=",e).execute();}async deleteObjectsByBucket(e){let t=(await this.table("objects").select("name").where("bucket_id","=",e).execute()).map(n=>n.name);return t.length>0&&await this.deleteFrom("objects").where("bucket_id","=",e).execute(),t}async objectExists(e,r){return !!await this.table("objects").select("id").where("bucket_id","=",e).where("name","=",r).executeTakeFirst()}async touchObject(e){await this.update("objects").set({last_accessed_at:new Date().toISOString()}).where("id","=",e).execute();}parseBucketRow(e){return {...e,owner:e.owner??"",owner_id:e.owner_id??"",public:!!e.public,allowed_mime_types:e.allowed_mime_types==null?null:am(e.allowed_mime_types)}}parseObjectRow(e){return {...e,metadata:im(e.metadata),user_metadata:im(e.user_metadata),path_tokens:am(e.path_tokens)}}};var V=class s extends Error{constructor(r,t,n){super(n);this.status=r;this.code=t;}name="StorageError";static bucketNotFound(r){return new s(404,"Bucket not found",`Bucket not found: ${r}`)}static bucketAlreadyExists(r){return new s(409,"Duplicate","The resource already exists")}static bucketNotEmpty(r){return new s(409,"ResourceNotEmpty","The bucket you tried to delete is not empty")}static objectNotFound(r){return new s(404,"Object not found",`Object not found: ${r}`)}static invalidMimeType(r,t){return new s(415,"invalid_mime_type",`mime type ${r} is not supported. Supported: ${t.join(", ")}`)}static fileTooLarge(r){return new s(413,"Payload too large",`The object exceeded the maximum allowed size of ${r} bytes`)}static invalidKey(r){return new s(400,"Invalid key",`Invalid object key: ${r}`)}static storageNotConfigured(){return new s(500,"Storage not configured","Storage is enabled but no storage adapter has been set. Set app._storageAdapter before making storage requests.")}toJSON(){return {statusCode:String(this.status),error:this.code,message:this.message}}};var rn=class{constructor(e,r,t,n={},i){this.repo=e;this.adapter=r;this.config=t;this.options=n;this.transformationAdapter=i;}initialized=false;async init(){if(!this.initialized&&(this.initialized=true,this.options.autoCreateBuckets!==false&&this.config.buckets))for(let[e,r]of Object.entries(this.config.buckets))await this.repo.findBucketById(e)||await this.repo.createBucket({id:e,name:e,public:r.public??false,file_size_limit:r.file_size_limit?RS(r.file_size_limit):null,allowed_mime_types:r.allowed_mime_types});}async createBucket(e){if(await this.repo.findBucketById(e.id))throw V.bucketAlreadyExists(e.id);return this.repo.createBucket(e)}async getBucket(e){let r=await this.repo.findBucketById(e);if(!r)throw V.bucketNotFound(e);return r}async listBuckets(){return this.repo.listBuckets()}async updateBucket(e,r){if(!await this.repo.findBucketById(e))throw V.bucketNotFound(e);return await this.repo.updateBucket(e,r)}async deleteBucket(e){if(!await this.repo.findBucketById(e))throw V.bucketNotFound(e);if(!await this.repo.isBucketEmpty(e))throw V.bucketNotEmpty(e);await this.repo.deleteBucket(e);}async emptyBucket(e){if(!await this.repo.findBucketById(e))throw V.bucketNotFound(e);let t=await this.repo.deleteObjectsByBucket(e);t.length>0&&await this.adapter.deleteObjects(e,t);}async upload(e,r,t,n){xl(r);let i=await this.repo.findBucketById(e);if(!i)throw V.bucketNotFound(e);let a=n?.contentType??"application/octet-stream",o=n?.cacheControl??"no-cache";if(i.allowed_mime_types&&i.allowed_mime_types.length>0&&!i.allowed_mime_types.includes(a))throw V.invalidMimeType(a,i.allowed_mime_types);let l=i.file_size_limit??this.config.fileSizeLimit??null;if(l&&n?.contentLength&&n.contentLength>l)throw V.fileTooLarge(l);let u=await this.repo.findObjectByPath(e,r);if(u&&!n?.upsert)throw V.bucketAlreadyExists(r);return await this.adapter.uploadObject(e,r,void 0,t,a,o),u&&n?.upsert?await this.repo.updateObject(u.id,{metadata:n?.metadata??u.metadata,version:crypto.randomUUID()}):this.repo.createObject({id:crypto.randomUUID(),bucket_id:e,name:r,owner:n?.owner??null,owner_id:n?.owner??null,metadata:n?.metadata??{},version:crypto.randomUUID()})}async download(e,r,t){let n=await this.repo.findObjectByPath(e,r);if(!n)throw V.objectNotFound(r);if(await this.repo.touchObject(n.id),t?.transform&&this.transformationAdapter&&!this.transformationAdapter.requiresBuffer&&this.transformationAdapter.transformFromUrl){let a=await this.adapter.privateAssetUrl(e,r,n.version??void 0),o=await this.transformationAdapter.transformFromUrl(a,t.transform);return {body:o.body,metadata:{cacheControl:"public, max-age=3600",contentLength:o.contentLength??0,size:o.contentLength??0,mimetype:o.contentType,eTag:""}}}let i=await this.adapter.getObject(e,r,n.version??void 0);if(!i.body)throw V.objectNotFound(r);if(t?.transform&&this.transformationAdapter?.requiresBuffer){let a=await AS(i.body),o=await this.transformationAdapter.transform(a,t.transform);return {body:o.body,metadata:{...i.metadata,mimetype:o.contentType,size:o.contentLength??0,contentLength:o.contentLength??0}}}return {body:i.body,metadata:i.metadata}}async update(e,r,t,n){return this.upload(e,r,t,{...n,upsert:n?.upsert??true})}async remove(e,r){if(!await this.repo.findBucketById(e))throw V.bucketNotFound(e);let n=[];for(let i of r){let a=await this.repo.findObjectByPath(e,i);a&&(await this.adapter.deleteObject(e,i,a.version??void 0),await this.repo.deleteObject(a.id),n.push(a));}return n}async list(e,r,t){if(!await this.repo.findBucketById(e))throw V.bucketNotFound(e);return this.repo.listObjects(e,r,t)}async move(e,r,t){xl(t);let n=await this.repo.findObjectByPath(e,r);if(!n)throw V.objectNotFound(r);await this.adapter.copyObject(e,r,n.version??void 0,t,void 0),await this.adapter.deleteObject(e,r,n.version??void 0),await this.repo.updateObject(n.id,{name:t,version:crypto.randomUUID()});}async copy(e,r,t){xl(t);let n=await this.repo.findObjectByPath(e,r);if(!n)throw V.objectNotFound(r);return await this.adapter.copyObject(e,r,n.version??void 0,t,void 0),await this.repo.createObject({id:crypto.randomUUID(),bucket_id:e,name:t,owner:n.owner,owner_id:n.owner_id,metadata:n.metadata,version:crypto.randomUUID()}),{key:t}}async info(e,r){let t=await this.repo.findObjectByPath(e,r);if(!t)throw V.objectNotFound(r);let n=await this.adapter.headObject(e,r,t.version??void 0);return {...t,httpMetadata:n}}async exists(e,r){return this.repo.objectExists(e,r)}async createSignedUrl(e,r,t){if(!await this.repo.findObjectByPath(e,r))throw V.objectNotFound(r);let i=await this.signStorageToken({sub:r,bucket:e,intent:"download"},t);return {signedUrl:`/storage/v1/object/sign/${e}/${r}?token=${i}`}}async createSignedUrls(e,r,t){let n=[];for(let i of r)try{let{signedUrl:a}=await this.createSignedUrl(e,i,t);n.push({path:i,signedUrl:a,error:null});}catch(a){n.push({path:i,signedUrl:"",error:a.message});}return n}async createSignedUploadUrl(e,r){if(!await this.repo.findBucketById(e))throw V.bucketNotFound(e);let n=await this.signStorageToken({sub:r,bucket:e,intent:"upload"},7200);return {signedUrl:`/storage/v1/object/upload/sign/${e}/${r}?token=${n}`,token:n,path:r}}async verifySignedUrl(e){let r=new TextEncoder().encode(this.config.jwtSecret),{payload:t}=await yr(e,r,{algorithms:["HS256"]});return {bucket:t.bucket,path:t.sub,intent:t.intent}}async signStorageToken(e,r){let t=new TextEncoder().encode(this.config.jwtSecret),n=Math.floor(Date.now()/1e3);return new Er({...e,iat:n}).setProtectedHeader({alg:"HS256",typ:"JWT"}).setIssuedAt(n).setExpirationTime(n+r).sign(t)}};async function AS(s){if(s instanceof Uint8Array||Buffer.isBuffer(s))return s;if(s instanceof Blob)return new Uint8Array(await s.arrayBuffer());let e=[],r=s.getReader();for(;;){let{done:t,value:n}=await r.read();if(t)break;e.push(n);}return Buffer.concat(e)}function xl(s){if(!s||s.includes("..")||s.startsWith("/"))throw V.invalidKey(s)}function RS(s){let e=s.match(/^(\d+(?:\.\d+)?)\s*(B|KB|KiB|MB|MiB|GB|GiB)$/i);if(!e)return 0;let r=Number.parseFloat(e[1]),t=e[2].toUpperCase();return Math.floor(r*({B:1,KB:1e3,KIB:1024,MB:1e6,MIB:1048576,GB:1e9,GIB:1073741824}[t]??1))}var _S=/^[\w!#$%&'*.^`|~+-]+$/,vS=/^[ !#-:<-[\]-~]*$/,Ul=(s,e)=>{let r=s.trim().split(";"),t={};for(let n of r){n=n.trim();let i=n.indexOf("=");if(i===-1)continue;let a=n.substring(0,i).trim();if(!_S.test(a))continue;let o=n.substring(i+1).trim();if(o.startsWith('"')&&o.endsWith('"')&&(o=o.slice(1,-1)),vS.test(o)&&(t[a]=o.indexOf("%")!==-1?$r(o,Es):o,e));}return t};var om=(s,e,r)=>{let t=s.req.raw.headers.get("Cookie");return t?Ul(t):{}};var lm=(s,e)=>new Response(s,{headers:{"Content-Type":e}}).formData();var OS=/^application\/([a-z-\.]+\+)?json(;\s*[a-zA-Z0-9\-]+\=([^;]+))*$/,NS=/^multipart\/form-data(;\s?boundary=[a-zA-Z0-9'"()+_,\-./:=?]+)?$/,IS=/^application\/x-www-form-urlencoded(;\s*[a-zA-Z0-9\-]+\=([^;]+))*$/,Bl=(s,e)=>async(r,t)=>{let n={},i=r.req.header("Content-Type");switch(s){case "json":if(!i||!OS.test(i))break;try{n=await r.req.json();}catch{let o="Malformed JSON in request body";throw new ii(400,{message:o})}break;case "form":{if(!i||!(NS.test(i)||IS.test(i)))break;let o;if(r.req.bodyCache.formData)o=await r.req.bodyCache.formData;else try{let u=await r.req.arrayBuffer();o=await lm(u,i),r.req.bodyCache.formData=o;}catch(u){let p="Malformed FormData request.";throw p+=u instanceof Error?` ${u.message}`:` ${String(u)}`,new ii(400,{message:p})}let l={};o.forEach((u,p)=>{p.endsWith("[]")?(l[p]??=[]).push(u):Array.isArray(l[p])?l[p].push(u):p in l?l[p]=[l[p],u]:l[p]=u;}),n=l;break}case "query":n=Object.fromEntries(Object.entries(r.req.queries()).map(([o,l])=>l.length===1?[o,l[0]]:[o,l]));break;case "param":n=r.req.param();break;case "header":n=r.req.header();break;case "cookie":n=om(r);break}let a=await e(n,r);return a instanceof Response?a:(r.req.addValidatedData(s,a),await t())};var LS=Symbol.for("jsonv"),kS=(s,e)=>Object.assign(s,{[LS]:e}),Pt=(s,e,r,t)=>{let n=Bl(s,async(i,a)=>{let o=e.coerce(i,{dropUnknown:r?.dropUnknown}),l=e.validate(o);if(!l.valid)return a.json({...l,schema:e},400);return o});return kS(n,{type:"parameters",skip:r?.skipOpenAPI,value:{target:s,schema:e}})};var $S=E.object({id:E.string(),name:E.string(),public:E.boolean({default:false}).optional(),file_size_limit:E.number().optional(),allowed_mime_types:E.array(E.string()).optional()}),PS=E.object({public:E.boolean().optional(),file_size_limit:E.number().optional(),allowed_mime_types:E.array(E.string()).optional()}),DS=E.object({prefix:E.string().optional(),limit:E.number().optional(),offset:E.number().optional(),sortBy:E.object({column:E.string(),order:E.string()}).optional(),search:E.string().optional()}),um=E.object({bucketId:E.string(),sourceKey:E.string(),destinationKey:E.string()}),jS=E.object({expiresIn:E.number()}),xS=E.object({expiresIn:E.number(),paths:E.array(E.string())}),US=E.object({prefixes:E.array(E.string())}),BS=new be().get("/object/public/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/public/${e}/`),{storageService:t}=s.var;if(!(await t.getBucket(e)).public)return s.json({error:"Bucket is not public"},400);let i=Ml(s.req.query()),a=await t.download(e,r,{transform:i??void 0});return new Response(a.body,{headers:Fl(a.metadata)})}).get("/object/sign/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/sign/${e}/`),t=s.req.query("token"),{storageService:n}=s.var;if(!t)return s.json({error:"Missing token"},400);let i=await n.verifySignedUrl(t);if(i.bucket!==e||i.path!==r)return s.json({error:"Invalid token"},403);let a=Ml(s.req.query()),o=await n.download(e,r,{transform:a??void 0});return new Response(o.body,{headers:Fl(o.metadata)})}).put("/object/upload/sign/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/upload/sign/${e}/`),t=s.req.query("token"),{storageService:n}=s.var;if(!t)return s.json({error:"Missing token"},400);let i=await n.verifySignedUrl(t);if(i.bucket!==e||i.path!==r||i.intent!=="upload")return s.json({error:"Invalid token"},403);let a=s.req.header("content-type")??"application/octet-stream",o=s.req.header("content-length")?Number.parseInt(s.req.header("content-length"),10):void 0,l=s.req.raw.body??new Uint8Array(await s.req.arrayBuffer()),u=await n.upload(e,r,l,{contentType:a,contentLength:o,upsert:true});return s.json({Key:u.name},200)}),MS=new be().use(en()).post("/bucket",Pt("json",$S),async s=>{let e=s.req.valid("json"),{storageService:r}=s.var,t=await r.createBucket({id:e.id,name:e.name??e.id,public:e.public,file_size_limit:e.file_size_limit,allowed_mime_types:e.allowed_mime_types});return s.json({name:t.name},200)}).get("/bucket",async s=>{let{storageService:e}=s.var,r=await e.listBuckets();return s.json(r,200)}).get("/bucket/:id",async s=>{let{storageService:e}=s.var,r=await e.getBucket(s.req.param("id"));return s.json(r,200)}).put("/bucket/:id",Pt("json",PS),async s=>{let{storageService:e}=s.var;return await e.updateBucket(s.req.param("id"),s.req.valid("json")),s.json({message:"Successfully updated"},200)}).delete("/bucket/:id",async s=>{let{storageService:e}=s.var;return await e.deleteBucket(s.req.param("id")),s.json({message:"Successfully deleted"},200)}).post("/bucket/:id/empty",async s=>{let{storageService:e}=s.var;return await e.emptyBucket(s.req.param("id")),s.json({message:"Empty bucket has been queued. Completion may take up to an hour."},200)}).post("/object/list/:bucketId",Pt("json",DS),async s=>{let e=s.req.param("bucketId"),r=s.req.valid("json"),{storageService:t}=s.var,n=await t.list(e,r.prefix,{limit:r.limit,offset:r.offset,sortBy:r.sortBy,search:r.search});return s.json(n,200)}).post("/object/move",Pt("json",um),async s=>{let e=s.req.valid("json"),{storageService:r}=s.var;return await r.move(e.bucketId,e.sourceKey,e.destinationKey),s.json({message:"Successfully moved"},200)}).post("/object/copy",Pt("json",um),async s=>{let e=s.req.valid("json"),{storageService:r}=s.var,t=await r.copy(e.bucketId,e.sourceKey,e.destinationKey);return s.json({key:t.key},200)}).get("/object/info/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/info/${e}/`),{storageService:t}=s.var,n=await t.info(e,r);return s.json(n,200)}).post("/object/sign/:bucketId/*",Pt("json",jS),async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/sign/${e}/`),{expiresIn:t}=s.req.valid("json"),{storageService:n}=s.var,i=await n.createSignedUrl(e,r,t);return s.json(i,200)}).post("/object/sign/:bucketId",Pt("json",xS),async s=>{let e=s.req.param("bucketId"),{expiresIn:r,paths:t}=s.req.valid("json"),{storageService:n}=s.var,i=await n.createSignedUrls(e,t,r);return s.json(i,200)}).post("/object/upload/sign/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/upload/sign/${e}/`),{storageService:t}=s.var,n=await t.createSignedUploadUrl(e,r);return s.json(n,200)}).delete("/object/:bucketId",Pt("json",US),async s=>{let e=s.req.param("bucketId"),{prefixes:r}=s.req.valid("json"),{storageService:t}=s.var,n=await t.remove(e,r);return s.json(n,200)}).post("/object/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/${e}/`),{storageService:t}=s.var,n=s.req.header("content-type")??"application/octet-stream",i=s.req.header("cache-control")??"no-cache",a=s.req.header("x-upsert")==="true",o,l,u;if(n.startsWith("multipart/form-data")){let f=(await s.req.formData()).get("file");if(!f)throw new V(400,"InvalidRequest","Missing file in multipart upload");let m=new Uint8Array(await f.arrayBuffer());o=m,l=f.type||"application/octet-stream",u=m.length;}else o=s.req.raw.body??new Uint8Array(await s.req.arrayBuffer()),l=n,u=s.req.header("content-length")?Number.parseInt(s.req.header("content-length"),10):void 0;let p=await t.upload(e,r,o,{contentType:l,cacheControl:i,contentLength:u,upsert:a,owner:s.get("userId")??null});return s.json({Key:`${e}/${p.name}`,Id:p.id},200)}).put("/object/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/${e}/`),{storageService:t}=s.var,n=s.req.header("content-type")??"application/octet-stream",i=s.req.header("cache-control")??"no-cache",a=s.req.header("content-length")?Number.parseInt(s.req.header("content-length"),10):void 0,o=s.req.raw.body??new Uint8Array(await s.req.arrayBuffer()),l=await t.update(e,r,o,{contentType:n,cacheControl:i,contentLength:a,owner:s.get("userId")??null});return s.json({Key:`${e}/${l.name}`,Id:l.id},200)}).get("/object/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/${e}/`),{storageService:t}=s.var,n=Ml(s.req.query()),i=await t.download(e,r,{transform:n??void 0});return new Response(i.body,{headers:Fl(i.metadata)})}).on("HEAD","/object/:bucketId/*",async s=>{let e=s.req.param("bucketId"),r=pt(s.req.path,`/object/${e}/`),{storageService:t}=s.var;return await t.exists(e,r)?s.body(null,200):s.body(null,404)}),ql=new be().onError((s,e)=>s instanceof V?e.json(s.toJSON(),400):(console.error("Storage error:",s),e.json({error:"server_error",message:"Internal server error"},500))).route("/",BS).route("/",MS);function pt(s,e){let r=s.replace(/^\/storage\/v1/,""),t=r.indexOf(e);return t===-1?r.split("/").slice(3).join("/"):r.slice(t+e.length)}function Ml(s){let{width:e,height:r,resize:t,format:n,quality:i}=s;return !e&&!r&&!t&&!n&&!i?null:{width:e?Number.parseInt(e,10):void 0,height:r?Number.parseInt(r,10):void 0,resize:t,format:n,quality:i?Number.parseInt(i,10):void 0}}function Fl(s){let e={"Content-Type":s.mimetype,"Cache-Control":s.cacheControl,ETag:s.eTag};return s.contentLength&&(e["Content-Length"]=String(s.contentLength)),s.lastModified&&(e["Last-Modified"]=s.lastModified.toUTCString()),s.contentRange&&(e["Content-Range"]=s.contentRange),e}var Jl=`-- supabase/storage core schema (Postgres)
|
|
77
|
+
`),n=Py(e);if(n.length===0)throw new Kn("parse error (not enough input)");let r=n[0];if(n.length===1)return [];let s=[];for(let i=1;i<n.length;i++){let o=n[i],a={};for(let l=0;l<r.length;l++){let c=l<o.length?o[l]:"";a[r[l]]=c===""?null:c;}s.push(a);}return s}function Py(t){let e=[],n=0,r=t.length;for(;n<r&&!(n===r-1&&t[n]===`
|
|
78
|
+
`);){let{row:s,nextPos:i}=Ny(t,n);e.push(s),n=i;}return e}function Ny(t,e){let n=[],r=e,s=t.length;for(;r<=s;){if(r===s||t[r]===`
|
|
79
|
+
`)return n.length,{row:n,nextPos:r+1};if(t[r]==='"'){let i="";for(r++;r<s;)if(t[r]==='"')if(r+1<s&&t[r+1]==='"')i+='"',r+=2;else {r++;break}else i+=t[r],r++;n.push(i),r<s&&t[r]===","&&r++;}else {let i="";for(;r<s&&t[r]!==","&&t[r]!==`
|
|
80
|
+
`;)i+=t[r],r++;n.push(i),r<s&&t[r]===","&&r++;}}return {row:n,nextPos:r}}var Kn=class extends Error{constructor(e){super(e),this.name="CsvParseError";}};function Pa(t){let e=new URL(t.url),n=new Map;for(let[r,s]of e.searchParams.entries()){let i=n.get(r)??[];i.push(s),n.set(r,i);}return n}function Na(t,e,n){let r=e.toUpperCase();if(t.isRpc)return "rpc";switch(r){case "GET":case "HEAD":return "query";case "POST":return n.preferTokens.find(i=>i.key==="resolution"&&(i.value==="merge-duplicates"||i.value==="ignore-duplicates"))?"upsert":"insert";case "PATCH":return "update";case "PUT":return "put";case "DELETE":return "delete";default:return "query"}}var wf=new Set(["eq","neq","gt","gte","lt","lte","like","ilike","match","imatch","is","isdistinct","in","cs","cd","ov","sl","sr","nxl","nxr","adj","fts","plfts","phfts","wfts","not"]),bf={eq:"$eq",neq:"$neq",gt:"$gt",gte:"$gte",lt:"$lt",lte:"$lte",like:"$like",ilike:"$ilike",match:"$regex",imatch:"$iregex",is:"$is",isdistinct:"$isDistinct",in:"$in",cs:"$contains",cd:"$containedBy",ov:"$overlaps",sl:"$rangeLt",sr:"$rangeGt",nxl:"$rangeGte",nxr:"$rangeLte",adj:"$rangeAdjacent"},Iy={any:"Any",all:"All"},Dy=new Set(["eq","gt","gte","lt","lte","like","ilike","match","imatch"]),jy={fts:void 0,plfts:"plain",phfts:"phrase",wfts:"websearch"};function Ia(t){let e=t.match(/^(\w+)\((any|all)\)$/);if(e){let[,s,i]=e;if(!Dy.has(s))return null;let o=bf[s];return o?{astOp:o+Iy[i]}:null}let n=t.match(/^(p[lh]fts|wfts|fts)(?:\(([^)]+)\))?$/);if(n){let[,s,i]=n;return i!==void 0&&!/^[A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)?$/.test(i)?null:{astOp:"$textSearch",ftsType:jy[s],ftsConfig:i}}let r=bf[t];return r?{astOp:r}:null}function jr(t){let e=t.indexOf(".");if(e===-1)return false;let r=t.substring(0,e).replace(/\((any|all)\)$/,"");return wf.has(r)}var gn=new Set(["select","order","limit","offset","on_conflict","columns"]);function Lr(t){if(t.startsWith("(")&&t.endsWith(")")&&(t=t.slice(1,-1)),t.trim()==="")return [];let e=[],n=0;for(;n<t.length;){if(t[n]==='"'){n++;let r="";for(;n<t.length&&t[n]!=='"';)t[n]==="\\"&&n+1<t.length&&n++,r+=t[n],n++;n<t.length&&n++,e.push(r);}else {let r="";for(;n<t.length&&t[n]!==",";)r+=t[n],n++;e.push(xt(r,{preserveWhitespace:true}));}n<t.length&&t[n]===","&&(n++,n===t.length&&e.push(""));}return e}function Ur(t){if(t.startsWith("{")&&t.endsWith("}")&&(t=t.slice(1,-1)),t==="")return [];let e=[],n=0;for(;n<t.length;){if(t[n]==='"'){n++;let r="";for(;n<t.length&&t[n]!=='"';)t[n]==="\\"&&n+1<t.length&&n++,r+=t[n],n++;n<t.length&&n++,e.push(r);}else {let r="";for(;n<t.length&&t[n]!==",";)r+=t[n],n++;e.push(xt(r));}n<t.length&&t[n]===","&&n++;}return e}var Ri=Symbol.for("postgrest:not_null"),yn=Symbol.for("postgrest:unknown");function xt(t,e){let n=e?.preserveWhitespace===true,r=t.trim();if(r.startsWith('"')&&r.endsWith('"')&&r.length>=2)return r.slice(1,-1);let s=r.toLowerCase();if(s==="null")return null;if(s==="not_null")return Ri;if(s==="true")return true;if(s==="false")return false;if(s==="unknown")return null;if(r!==""&&!Number.isNaN(Number(r))&&Number.isFinite(Number(r)))return Number(r);if(r.startsWith("{")&&r.endsWith("}"))try{let i=JSON.parse(r);if(typeof i=="object"&&!Array.isArray(i))return i}catch{}return n?r===""?"":t:r}function La(t,e){let n={},r={};for(let[s,i]of t){if(gn.has(s))continue;let a=s.startsWith('"')?-1:s.indexOf(".");if(a>0&&!s.slice(0,a).includes("->")){let l=s.slice(0,a),c=s.slice(a+1);if(e.has(l)){if(c==="order"||c==="limit"||c==="offset")continue;if(c.includes(".")){let f=c.lastIndexOf("."),u=c.slice(f+1);if(u==="order"||u==="limit"||u==="offset")continue}r[l]||(r[l]={}),Uy(c,i,r[l]);continue}if(s!=="not.or"&&s!=="not.and")throw Ly(l)}ja(s,i,n);}return {where:n,embeddedWheres:r}}function Ly(t){return new Ae({httpStatus:400,code:"PGRST108",message:`'${t}' is not an embedded resource in this request`,details:null,hint:`Verify that '${t}' is included in the 'select' query parameter.`})}function ja(t,e,n){if(t==="or"||t==="and"){let s=e.map(o=>Sf(o)),i=s.length===1?s[0]:s.flat();n[`$${t}`]=i;return}if(t==="not.or"||t==="not.and"){let s=t.slice(4),i=e.map(a=>Sf(a)),o=i.length===1?i[0]:i.flat();n.$not={[`$${s}`]:o};return}let r=_f(qy(t),{stopAtSpace:false});xf(r);for(let s of e){let i=Ef(s);n[r]?Object.assign(n[r],i):n[r]=i;}}function Uy(t,e,n){let r=My(t);if(!r){ja(t,e,n);return}let s={};ja(r.filterKey,e,s);for(let[i,o]of Object.entries(s))n[`${r.path}.${i}`]=o;}function My(t){for(let e of ["not.or","not.and","or","and"]){let n=`.${e}`;if(t.endsWith(n)){let r=t.slice(0,-n.length);if((e==="or"||e==="and")&&r==="not")continue;if(r)return {path:r,filterKey:e}}}}function Ef(t){let e=t,n=false;e.startsWith("not.")&&(n=true,e=e.slice(4));let r=e.indexOf("."),s,i;r===-1?(s=e,i=""):(s=e.slice(0,r),i=e.slice(r+1));let o=Ia(s);if(!o)throw new Error(`"failed to parse filter (${t})" (line 1, column 1)`);let{astOp:a,ftsType:l,ftsConfig:c}=o;if(n&&a==="$in")return {$notIn:Da(a,i)};if(n&&a==="$is")return {$isNot:Da(a,i)};let f=a==="$textSearch"?By(i,l,c):Da(a,i);return n?{$not:{[a]:f}}:{[a]:f}}function Da(t,e){if(t==="$in"||t==="$notIn"){if(!e.startsWith("(")||!e.endsWith(")")){let n=t==="$in"?"in":"not.in";throw new Error(`"failed to parse filter (${n}.${e})" (line 1, column ${n.length+e.length+2})`)}return Lr(e)}if(t.endsWith("Any")||t.endsWith("All")){if(e.startsWith("{"))return Ur(e);if(!Fy(t))throw Object.assign(new Error(`malformed array literal: "${e}"`),{code:"22P02",detail:'Array value must start with "{" or dimension information.'});return Lr(e)}if(t==="$contains"||t==="$containedBy"||t==="$overlaps"){if(e.startsWith("{")){try{let n=JSON.parse(e);if(typeof n=="object"&&!Array.isArray(n))return n}catch{}return Ur(e)}return e.startsWith("[")||e.startsWith("(")?e:xt(e)}if(t.startsWith("$range"))return e;if(t==="$is"){let n=e.toLowerCase().trim();if(!["null","true","false","unknown","not_null"].includes(n))throw new Error(`"failed to parse filter (is.${e})" (line 1, column ${2+e.length})`);return n==="unknown"?yn:xt(e)}if(t==="$like"||t==="$ilike"||t==="$likeAny"||t==="$ilikeAny"||t==="$likeAll"||t==="$ilikeAll"){let n=e.replace(/\*/g,"%");return t.endsWith("Any")||t.endsWith("All")?n.startsWith("{")?Ur(n):Lr(n):n}return t==="$isDistinct"?e:xt(e)}function Fy(t){return t==="$likeAny"||t==="$ilikeAny"||t==="$likeAll"||t==="$ilikeAll"}function By(t,e,n){let r={query:t};return e&&(r.type=e),n&&(r.config=n),r}function Sf(t){if(!t.startsWith("(")||!t.endsWith(")"))throw new Error(`"failed to parse logic tree (${t})" (line 1, column ${t.length+3})`);let e=t.slice(1,-1);for(;e.endsWith(")");){let n=0;for(let r of e)r==="("?n++:r===")"&&n--;if(n<0)e=e.slice(0,e.length+n);else break}if(e.trim()==="")throw new Error(`"failed to parse logic tree (${t})" (line 1, column ${t.length+2})`);try{return Mr(e).map(r=>Fr(r))}catch{throw new Error(`"failed to parse logic tree (${t})" (line 1, column ${t.length+2})`)}}function Mr(t){let e=[],n=0,r=0,s=false,i="";for(let o of t)if(o==='"'&&!s?s=true:o==='"'&&s&&(s=false),s||(o==="("?n++:o===")"?n--:o==="{"?r++:o==="}"&&r--),o===","&&n===0&&r===0&&!s){if(i.trim()==="")throw new Error("empty logical expression");e.push(i.trim()),i="";}else i+=o;if(i.trim())e.push(i.trim());else if(t.trim().endsWith(","))throw new Error("empty logical expression");return e}function Fr(t){let e=t.trim(),n=e.match(/^and\s*\((.*)\)$/s);if(n)return {$and:Mr(n[1]).map(d=>Fr(d))};let r=e.match(/^or\s*\((.*)\)$/s);if(r)return {$or:Mr(r[1]).map(d=>Fr(d))};let s=e.match(/^not\.and\s*\((.*)\)$/s);if(s)return {$not:{$and:Mr(s[1]).map(d=>Fr(d))}};let i=e.match(/^not\.or\s*\((.*)\)$/s);if(i)return {$not:{$or:Mr(i[1]).map(d=>Fr(d))}};if(/^(?:and|or|not)=/.test(e))throw new Error(`Invalid filter expression: "${t}"`);if(e.startsWith("not.")||e.startsWith("not("))throw new Error(`Invalid filter expression: "${t}"`);let o=t,a=false;o.startsWith("not.")&&(a=true,o=o.slice(4));let l=o.indexOf(".");if(l===-1)throw new Error(`Invalid filter expression: "${t}"`);let c=_f(o.slice(0,l),{stopAtSpace:true});xf(c);let f=o.slice(l+1),u=Ef(a?`not.${f}`:f);return {[c]:u}}function _f(t,e){let r=(e.stopAtSpace?/[!@/\\~[\]()\t ]/:/[!@/\\~[\]()\t]/).exec(t);return r?t.slice(0,r.index):t}function qy(t){return t.length>=2&&t.startsWith('"')&&t.endsWith('"')?t.slice(1,-1).replace(/""/g,'"'):t}function xf(t){if(t===""||t==="*"||t.includes("--")||t.endsWith("-"))throw new Error(`Invalid filter expression: "${t}"`);if(/->>?-\d+\D/.test(t))throw new Error(`Invalid filter expression: "${t}"`)}function Wy(t){let e=t.match(/^([a-zA-Z_][a-zA-Z0-9_]*)\(([^)]+)\)$/);return e?{embed:e[1],column:e[2]}:null}function vf(t){if(t===void 0)return;let e=t.trim();if(!/^[+-]?\d+$/.test(e))return;let n=Number(e);return Number.isFinite(n)?n:void 0}function Ua(t,e){let n=vf(t),r=vf(e);return r!==void 0&&r<0&&(n!==void 0&&n>=0&&(n=Math.max(0,n+r)),r=void 0),{limit:n,offset:r}}function Fa(t,e){let n={embeddedTransforms:{}},r,s,i={},o={},a={},l={};for(let[d,p]of t){let y=p[0],h=d.indexOf(".");if(h>0){let b=d.slice(0,h),m=d.slice(h+1);if(e.has(b)){if(m==="order"||m==="limit"||m==="offset"){n.embeddedTransforms[b]||(n.embeddedTransforms[b]={}),m==="order"?n.embeddedTransforms[b].order=Ma(y):m==="limit"?i[b]=y:m==="offset"&&(o[b]=y);continue}if(m.includes(".")){let w=m.lastIndexOf("."),_=m.slice(w+1);if(_==="order"||_==="limit"||_==="offset"){n.embeddedTransforms[b]||(n.embeddedTransforms[b]={});let S=n.embeddedTransforms[b],E=m.slice(0,w);S._nested||(S._nested={});let C=S._nested;C[E]||(C[E]={});let x=C[E];_==="order"?x.order=Ma(y):_==="limit"?(a[b]||(a[b]={}),a[b][E]=y):_==="offset"&&(l[b]||(l[b]={}),l[b][E]=y);continue}}}}d==="order"?n.order=Ma(y):d==="limit"?r=y:d==="offset"&&(s=y);}if(n.order){for(let d of n.order)if(d.embed&&!e.has(d.embed))throw new Ae({httpStatus:400,code:"PGRST108",message:`'${d.embed}' is not an embedded resource in this request`,details:null,hint:`Verify that '${d.embed}' is included in the 'select' query parameter.`})}let c=Ua(r,s);c.limit!==void 0&&(n.limit=c.limit),c.offset!==void 0&&(n.offset=c.offset);let f=new Set([...Object.keys(i),...Object.keys(o)]);for(let d of f){let p=Ua(i[d],o[d]);n.embeddedTransforms[d]||(n.embeddedTransforms[d]={}),p.limit!==void 0&&(n.embeddedTransforms[d].limit=p.limit),p.offset!==void 0&&(n.embeddedTransforms[d].offset=p.offset);}let u=new Set([...Object.keys(a),...Object.keys(l)]);for(let d of u){let p=new Set([...Object.keys(a[d]??{}),...Object.keys(l[d]??{})]);for(let y of p){let h=Ua(a[d]?.[y],l[d]?.[y]),b=n.embeddedTransforms[d]?._nested?.[y];b&&(h.limit!==void 0&&(b.limit=h.limit),h.offset!==void 0&&(b.offset=h.offset));}}return n}function Ma(t){return Jy(t).map(({entry:e,start:n})=>Ky(e.trim(),t,n+e.length-e.trimStart().length))}function Jy(t){let e=[],n=0,r=0;for(let s=0;s<t.length;s++){let i=t[s];i==="("?n++:i===")"?n=Math.max(0,n-1):i===","&&n===0&&(e.push({entry:t.slice(r,s),start:r}),r=s+1);}return e.push({entry:t.slice(r),start:r}),e}function Ky(t,e,n){let r=t.split("."),s={column:r[0]},i=r[0];if(!i)throw new pe(`failed to parse order (${e})`,'unexpected end of input expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input',1);let o=i.indexOf("::");if(o!==-1)throw new pe(`failed to parse order (${e})`,`unexpected ':' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,n+o+1);let a=i.indexOf("--");if(a!==-1)throw new pe(`failed to parse order (${e})`,`unexpected '-' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,n+a+2);let l=i.search(/[@#%]/);if(l!==-1)throw new pe(`failed to parse order (${e})`,`unexpected '${i[l]}' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,n+l+1);if(i.endsWith("-"))throw new pe(`failed to parse order (${e})`,`unexpected '-' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,n+i.length);let c=i.indexOf(":");if(c!==-1)throw new pe(`failed to parse order (${e})`,`unexpected ':' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,n+c+1);let f=Wy(i);if(f){if(f.column.includes(","))throw new pe(`failed to parse order (${e})`,`unexpected ',' expecting letter, digit, "-", "->>", "->", delimiter (.), "," or end of input`,n+i.indexOf(",",f.embed.length)+1);s.column=f.column,s.embed=f.embed;}let u=n+i.length+1,d=false,p=false;for(let y=1;y<r.length;y++){let h=r[y];if(h==="asc"||h==="desc"){if(d)throw new pe(`failed to parse order (${e})`,`unexpected '${h[0]}' expecting "," or end of input`,u+1);if(p)throw new pe(`failed to parse order (${e})`,`unexpected '${h[0]}' expecting "," or end of input`,u+1);s.direction=h,d=true,u+=h.length+1;}else if(h==="nullsfirst"||h==="nullslast"){if(p)throw new pe(`failed to parse order (${e})`,`unexpected '${h[0]}' expecting "," or end of input`,u+1);s.nullsFirst=h==="nullsfirst",p=true,u+=h.length+1;}else {let b=["asc","desc","nullsfirst","nullslast"],m=null;for(let w of b)if(h.startsWith(w)&&h.length>w.length){m=w;break}if(m){let w=h[m.length],_=u+m.length;throw new pe(`failed to parse order (${e})`,`unexpected '${w}' expecting "," or end of input`,_+1)}throw new pe(`failed to parse order (${e})`,`unexpected '${h[0]}' expecting "," or end of input`,u+1)}}return s}function Ba(t,e,n){let r={};for(let i of t.preferTokens)switch(i.key){case "count":r.count=i.value;break;case "missing":r.missing=i.value;break;case "handling":r.handling=i.value;break;case "tx":r.tx=i.value,i.value==="rollback"&&(r.rollback=true);break;case "max-affected":r.maxAffected=i.value;break;case "timezone":r.timezone=i.value;break;case "return":r.return=i.value;break}n.toUpperCase()==="HEAD"&&(r.head=true),t.accept.includes("application/vnd.pgrst.object")&&(r.cardinality="one"),t.accept.includes("application/vnd.pgrst.plan")&&(r.explain=Gy(t.accept));let s=e.get("columns");if(s){let i=s[0];r.columns=Hy("columns",i);}return r}function Hy(t,e){let n=e.split(",").map(r=>zy(r));if(n.length===0||n.some(r=>r===""||r==="*"||r.includes("--")||r.endsWith("-")))throw new Qt(`"failed to parse ${t} parameter (${e})" (line 1, column 1)`,"unexpected input");return n}function zy(t){let e=t.trim();return e.startsWith('"')&&e.endsWith('"')?e.slice(1,-1):e.replace(/@.*$/,"")}function Gy(t){let e={},n=t.match(/options=([^;]+)/);if(n){let r=n[1].split("|").map(s=>s.trim());e.analyze=r.includes("analyze"),e.verbose=r.includes("verbose"),e.settings=r.includes("settings"),e.buffers=r.includes("buffers"),e.wal=r.includes("wal");}return e}function qa(t,e,n,r){if(!t.isRpc)return {};if(e.toUpperCase()==="POST"){let a={httpMethod:"POST"};return r.values?(Array.isArray(r.values)?(a.args=r.values,a.paramsType="positional"):(a.args=r.values,a.paramsType="named"),a.inputType="json"):r.raw!==void 0&&(a.args={_raw:r.raw},a.inputType="text"),a}let i={};for(let[a,l]of n){if(gn.has(a))continue;let c=l[0];jr(c)||(i[a]=xt(c));}let o={httpMethod:"GET",paramsType:"named",inputType:"json"};return Object.keys(i).length>0&&(o.args=i),o}function Wa(t,e){let n=t.get("on_conflict"),r=n===void 0?void 0:Vy(n[0]),i=e.preferTokens.find(o=>o.key==="resolution")?.value==="ignore-duplicates";return {onConflict:r?.length?r:void 0,ignoreDuplicates:i}}function Vy(t){let e=t.split(",").map(n=>n.trim());if(e.length===0||e.some(n=>n===""||n.includes("--")||n.endsWith("-")))throw new Qt(`"failed to parse on_conflict parameter (${t})" (line 1, column 1)`,"unexpected input");return e}async function Ti(t,e){let n=e?.basePath,r=e?.parseRoute??(z=>Ca(z,n)),s=e?.parseHeaders??Ra,i=e?.parseSelect??Oa,o=e?.parseBody??$a,a=e?.parseQueryParams??Pa,l=e?.resolveType??Na,c=e?.resolveFilters??La,f=e?.resolveTransforms??Fa,u=e?.resolveMeta??Ba,d=e?.resolveRpcParams??qa,p=e?.resolveUpsertParams??Wa,[y,h,b,m,w]=await Promise.all([r(t),s(t),i(t),o(t),a(t)]),_=t.method,S=l(y,_,h),E=w;if(y.isRpc&&_.toUpperCase()==="GET"){E=new Map;for(let[z,I]of w){if(gn.has(z)){E.set(z,I);continue}let ue=I.filter(Xe=>jr(Xe));ue.length>0&&E.set(z,ue);}}let C=c(E,b.embeddedAliases),x=f(w,b.embeddedAliases),R=u(h,w,_),v=d(y,_,w,m),k=S==="upsert"||S==="put"?p(w,h):void 0;return Qy(S,y,h,b,m,C,x,R,v,k)}function Qy(t,e,n,r,s,i,o,a,l,c){let f={type:t};return e.isRpc?f.function=e.function:f.from=e.from,n.schema&&(f.schema=n.schema),Object.keys(r.join).length>0&&(f.join=r.join),r.select.length>0&&(f.select=Cf(r.select,i.embeddedWheres,o.embeddedTransforms,r.join)),Object.keys(i.where).length>0&&(f.where=i.where),(t==="insert"||t==="update"||t==="upsert"||t==="put")&&s.values!==void 0&&(f.values=s.values),t==="rpc"&&(l.args!==void 0&&(f.args=l.args),l.httpMethod&&(f.httpMethod=l.httpMethod),l.paramsType&&(f.paramsType=l.paramsType),l.inputType&&(f.inputType=l.inputType)),(t==="upsert"||t==="put")&&c&&(c.onConflict&&(f.onConflict=c.onConflict),f.ignoreDuplicates=c.ignoreDuplicates),a.return==="representation"&&(t==="insert"||t==="update"||t==="delete"||t==="upsert"||t==="put")&&(!f.select||f.select.length===0)&&(f.select=["*"]),o.order&&(f.order=o.order),o.limit!==void 0&&(f.limit=o.limit),o.offset!==void 0&&(f.offset=o.offset),Object.keys(a).length>0&&(f.$meta=a),f}function Cf(t,e,n,r){return t.map(s=>{if(typeof s=="string")return s;let i=Object.keys(s)[0],o=s[i];if(!o.select)return s;let a={...o},l=r?.[i]?.from,c=e[i]||l&&e[l],f=n[i]||l&&n[l];if(c){let u={},d={};for(let[p,y]of Object.entries(c)){let h=p.indexOf(".");if(h>0){let b=p.slice(0,h),m=p.slice(h+1);if(a.join?.[b]||a.select?.some(S=>typeof S=="object"&&b in S&&"select"in(S[b]??{}))){d[b]||(d[b]={}),d[b][m]=y;continue}}u[p]=y;}Object.keys(u).length>0&&(a.where=u);for(let[p,y]of Object.entries(d))e[p]={...e[p],...y};}if(f){let u=f;if(u.order&&(a.order=u.order),u.limit!==void 0&&(a.limit=u.limit),u.offset!==void 0&&(a.offset=u.offset),u._nested)for(let[d,p]of Object.entries(u._nested))n[d]=p;}return a.select&&(a.select=Cf(a.select,e,n,a.join)),{[i]:a}})}function ki(t){return t!=null&&typeof t=="object"&&"$ref"in t}var Xy=/^[a-zA-Z_][a-zA-Z0-9_.]*$/,Yy=/[;'"\\/*\-#]/,Zy=/['\\;(]/,vt=class extends Error{constructor(n,r){super(`Unsafe ${r}: "${n}"`);this.value=n;this.context=r;this.name="SanitizeError";}};function Ct(t,e){if(!Xy.test(t))throw new vt(t,e)}function Ja(t,e){if(Yy.test(t))throw new vt(t,e);let n=0;for(let r of t)if(r==="("?n++:r===")"&&n--,n<0)throw new vt(t,e);if(n!==0)throw new vt(t,e)}function Hn(t,e){if(Zy.test(t))throw new vt(t,e)}function bn(t){let e=t.indexOf("->");if(e===-1)return {col:t,parts:[]};let n=t.slice(0,e),r=t.slice(e),s=[];for(;r.length>0;){let i;if(r.startsWith("->>"))i="->>",r=r.slice(3);else if(r.startsWith("->"))i="->",r=r.slice(2);else break;let o=r.indexOf("->"),a=o===-1?r:r.slice(0,o);s.push({op:i,key:a}),r=o===-1?"":r.slice(o);}return {col:n,parts:s}}function Br(t,e){return t.map(n=>{let r=/^-?\d+$/.test(n.key);return r||Hn(n.key,e),r?`${n.op}${n.key}`:`${n.op}'${n.key}'`}).join("")}function A(t){return typeof t=="string"?sql.ref(t):t}function eb(t){return `"${t.replace(/"/g,'""')}"`}function Rf(t){return sql.raw(eb(t))}function Tf(t,e,n=e.currentTable,r=e.currentSchema){if(!n||!e.introspection?.columns)return;let s=e.introspection.columns.filter(i=>i.table===n&&i.name===t);if(s.length!==0)return s.find(i=>!r||i.schema===r)??s.find(i=>["","public"].includes(i.schema??""))??s[0]}function Ai(t,e,n=e.currentTable,r=e.currentSchema){return Tf(t,e,n,r)!==void 0}function oe(t,e,n=e.currentTable){return Ai(t,e,n)?Rf(t):sql.ref(t)}function Xt(t,e,n,r=n.currentTable){let s=Ai(e,n,r)?Rf(e):sql.ref(e);return sql`${sql.ref(t)}.${s}`}function tb(t){return (t?.pg_type??t?.type??"").toLowerCase()}function kf(t,e,n=e.currentTable){if(e.dialect!=="postgres")return false;let r=tb(Tf(t,e,n));return r.endsWith("[]")||r.startsWith("_")||r==="array"}function Af(t){let e=[];for(let n of t){if(!/^\d+$/.test(n))return;e.push(`[${Number(n)+1}]`);}return e.join("")}function Of(t,e,n,r=n.currentTable,s=false){let i=e.replace(/^\$\./,"").split(".").filter(Boolean);if(i.length===0)return oe(t,n,r);if(kf(t,n,r)){let l=Af(i);if(l)return sql`${oe(t,n,r)}${sql.raw(l)}`}let o=i.map((l,c)=>({op:c===i.length-1&&s?"->>":"->",key:l})),a=Br(o,"JSON path key");return sql`${oe(t,n,r)}${sql.raw(a)}`}function qr(t,e,n=e.currentTable,r){let{col:s,parts:i}=bn(t),o=r?Xt(r,s,e,n):oe(s,e,n);if(i.length===0)return o;if(kf(s,e,n)){let c=Af(i.map(f=>f.key));if(c)return sql`${o}${sql.raw(c)}`}let a=e.dialect==="sqlite"?i.map((c,f)=>f===i.length-1?{...c,op:"->>"}:c):i,l=Br(a,"JSON path key");return sql`${o}${sql.raw(l)}`}var Oi={$eq:(t,e,n)=>sql`${A(e)} = ${n}`,$neq:(t,e,n)=>sql`${A(e)} != ${n}`,$gt:(t,e,n)=>sql`${A(e)} > ${n}`,$gte:(t,e,n)=>sql`${A(e)} >= ${n}`,$lt:(t,e,n)=>sql`${A(e)} < ${n}`,$lte:(t,e,n)=>sql`${A(e)} <= ${n}`,$like:(t,e,n)=>sql`${A(e)} like ${n}`,$is:(t,e,n)=>{let r=A(e);return n===Ri?sql`${r} IS NOT NULL`:n===yn?sql`${r} IS UNKNOWN`:n===null?sql`${r} IS NULL`:n===true?sql`${r} IS TRUE`:n===false?sql`${r} IS FALSE`:sql`${r} IS NULL`},$isNot:(t,e,n)=>{let r=A(e);return n===Ri?sql`${r} IS NULL`:n===yn?sql`${r} IS NOT UNKNOWN`:n===null?sql`${r} IS NOT NULL`:n===true?sql`${r} IS NOT TRUE`:n===false?sql`${r} IS NOT FALSE`:sql`${r} IS NOT NULL`},$in:(t,e,n)=>{if(Array.isArray(n)&&n.length===0)return sql`false`;let r=A(e);return Array.isArray(n)?sql`${r} in (${sql.join(n.map(s=>sql`${s}`))})`:sql`${r} in ${n}`},$notIn:(t,e,n)=>{if(Array.isArray(n)&&n.length===0)return sql`true`;let r=A(e);return Array.isArray(n)?sql`${r} not in (${sql.join(n.map(s=>sql`${s}`))})`:sql`${r} not in ${n}`},$isDistinct:(t,e,n)=>sql`${A(e)} is distinct from ${n}`},$i={$eq:"=",$neq:"!=",$gt:">",$gte:">=",$lt:"<",$lte:"<="};function Ka(t){return t!=null&&typeof t=="object"&&t.type==="query"}function Pi(t,e){let n=e.db;return t.schema&&(n=n.withSchema(t.schema)),Ha(t,e,n)}function nb(t){return t.includes("->")}function Nf(t,e){let{col:n,parts:r}=bn(t);return r.length===0?oe(t,e):qr(t,e)}function Pe(t,e,n){let r=[];for(let[s,i]of Object.entries(e)){if(s==="$always"){i===false&&r.push(sql`0 = 1`);continue}if(s==="$or"){let o=i;r.push(t.or(o.map(a=>Pe(t,a,n))));}else if(s==="$and"){let o=i;r.push(t.and(o.map(a=>Pe(t,a,n))));}else if(s==="$not")r.push(t.not(Pe(t,i,n)));else if(s==="$exists"){let o=i;r.push(t.exists(Pi(o,n)));}else {let o=i,a=nb(s);for(let[l,c]of Object.entries(o)){if(ki(c)){let f=$i[l];if(!f)throw new Error(`Unsupported ref operator: ${l}`);r.push(sql`${a?Nf(s,n):oe(s,n)} ${sql.raw(f)} ${oe(c.$ref,n)}`);continue}if(l==="$not"){let f=c;for(let[u,d]of Object.entries(f))if(a)r.push(t.not(Pf(s,u,d,n)));else {let p=$f(s,u,d,n);if(p){r.push(t.not(p));continue}let y=n.operators[u];if(!y)throw new Error(`Unsupported operator: ${u}`);r.push(t.not(y(t,oe(s,n),d)));}}else if(Ka(c)){let f=Pi(c,n),u=n.operators[l];if(!u)throw new Error(`Unsupported operator: ${l}`);r.push(u(t,oe(s,n),f));}else if(a)r.push(Pf(s,l,c,n));else {let f=$f(s,l,c,n);if(f){r.push(f);continue}let u=rb(s,l,c,n);if(u){r.push(u);continue}let d=n.operators[l];if(!d)throw new Error(`Unsupported operator: ${l}`);r.push(d(t,oe(s,n),c));}}}}return r.length===1?r[0]:t.and(r)}function $f(t,e,n,r){if(e!=="$is"&&e!=="$isNot"||n!==yn)return null;let s=If(t,r);if(!s)return null;let i=Df(s.pg_type??s.type);if(i==="boolean")return r.dialect!=="sqlite"?null:e==="$is"?sql`${oe(t,r)} IS NULL`:sql`${oe(t,r)} IS NOT NULL`;throw Object.assign(new Error(`argument of IS UNKNOWN must be type boolean, not type ${i}`),{code:"42804",detail:null})}function If(t,e){if(!e.introspection?.columns||!e.currentTable)return null;let n=t.includes("->")?bn(t).col:t,r=e.introspection.columns.filter(i=>i.table===e.currentTable&&i.name===n);if(r.length===0)return null;let s=e.currentSchema;return r.find(i=>!s||i.schema===s)??r.find(i=>["","public"].includes(i.schema??""))??r[0]}function Df(t){switch(t.toLowerCase()){case "bool":return "boolean";case "int8":case "bigserial":case "serial8":return "bigint";case "int4":case "serial":case "serial4":return "integer";case "int2":return "smallint";default:return t.toLowerCase()}}function rb(t,e,n,r){if(r.dialect!=="postgres"||e!=="$eq"&&e!=="$neq"||typeof n!="string"||!/^\s*[[{]/.test(n))return null;let s=If(t,r),i=Df(s?.pg_type??s?.type??"");if(i!=="json"&&i!=="jsonb")return null;let o=oe(t,r),a=sql`cast(${sql.raw(sb(n))} as ${sql.raw(i)})`;return e==="$eq"?sql`${o} = ${a}`:sql`${o} != ${a}`}function sb(t){return `'${t.replace(/'/g,"''")}'`}function Pf(t,e,n,r){let s=r?Nf(t,r):A(t),o={$eq:"=",$neq:"!=",$gt:">",$gte:">=",$lt:"<",$lte:"<=",$like:"like",$ilike:"ilike"}[e];if(o)return sql`${s} ${sql.raw(o)} ${n}`;if(e==="$is")return n===null?sql`${s} IS NULL`:n===true?sql`${s} IS TRUE`:n===false?sql`${s} IS FALSE`:sql`${s} IS NULL`;if(e==="$isNot")return n===null?sql`${s} IS NOT NULL`:n===true?sql`${s} IS NOT TRUE`:n===false?sql`${s} IS NOT FALSE`:sql`${s} IS NOT NULL`;if(e==="$in"){if(r&&Ka(n))return sql`${s} in ${Pi(n,r)}`;let a=n;return a.length===0?sql`false`:sql`${s} in (${sql.join(a.map(l=>sql`${l}`))})`}if(e==="$notIn"){if(r&&Ka(n))return sql`${s} not in ${Pi(n,r)}`;let a=n;return a.length===0?sql`true`:sql`${s} not in (${sql.join(a.map(l=>sql`${l}`))})`}return sql`${s} = ${n}`}function ce(t){return "select"in t||"spread"in t||"join"in t}function ji(t,e,n,r,s,i=false){if(!e||e.length===0)return t.selectAll();for(let o of e)if(typeof o=="string")if(o==="*")t=i&&s?t.selectAll(s):t.selectAll();else if(/^-?\d+(?:\.\d+)?$/.test(o))t=t.select(sql.lit(Number(o)).as("_lit"));else if(mb(o,n,s)){let a=i&&s?Xt(s,o,n,s):oe(o,n,s);t=t.select(sql`json(${a})`.as(o));}else t=i&&s&&!o.includes(".")?t.select(Xt(s,o,n,s).as(o)):!/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(o)&&Ai(o,n,s)?t.select(oe(o,n,s).as(o)):t.select(o);else for(let[a,l]of Object.entries(o))ce(l)?t=Tb(t,a,l,n,r,s):t=lb(t,a,l,n,s,i);return t}function Jr(t,e){if(!e||e.length===0)return t;for(let n of e)if(typeof n=="string")t=n==="*"?t.returningAll():t.returning(n);else for(let[r,s]of Object.entries(n)){if(ce(s))continue;let i=s.column||r;t=t.returning(i);}return t}function wn(t,e,n,r,s,i=false){let o;if(n.aggregate==="count"&&!n.column&&!n.path)o=t.fn.countAll();else {let a=n.column||e;if(n.invalidJsonTextTraversalKey&&r.dialect==="postgres")throw Object.assign(new Error(`operator does not exist: text -> ${ib(n.invalidJsonTextTraversalKey)}`),{code:"42883",detail:null,hint:"No operator matches the given name and argument types. You might need to add explicit type casts."});o=n.path?Of(a,n.path,r,s,n.pathText===true):s&&i?Xt(s,a,r,s):oe(a,r,s),n.preCast&&(Ja(n.preCast,"pre-cast type"),o=sql`cast(${o} as ${sql.raw(n.preCast)})`),n.aggregate&&(o=sql`${sql.raw(n.aggregate)}(${o})`);}return n.cast&&(Ja(n.cast,"cast type"),o=r.dialect==="sqlite"&&(ob(n.cast)||ab(n.cast))?sql`json(${o})`:sql`cast(${o} as ${sql.raw(n.cast)})`),o}function ib(t){return /^-?\d+$/.test(t)?"integer":"unknown"}function ob(t){let e=t.trim().toLowerCase();return e==="json"||e==="jsonb"}function ab(t){let e=t.trim().toLowerCase();return e.startsWith("_")||e.endsWith("[]")}function lb(t,e,n,r,s,i=false){return t.select(o=>wn(o,e,n,r,s,i).as(e))}function cb(t){if(!t)return false;for(let e of t)if(typeof e!="string"){for(let n of Object.values(e))if(!ce(n)&&n.aggregate)return true}return false}function ub(t){if(!t)return false;for(let e of t)if(typeof e!="string"){for(let n of Object.values(e))if(ce(n)&&n.spread&&Ga(n.select))return true}return false}function fb(t){if(!t)return false;for(let e of t)if(typeof e!="string"){for(let n of Object.values(e))if(ce(n)&&n.spread)return true}return false}function db(t){return cb(t)||ub(t)}function Ga(t){if(!t)return false;for(let e of t)if(typeof e!="string")for(let n of Object.values(e)){if(ce(n)){if(Ga(n.select))return true;continue}if(n.aggregate)return true}return false}function Va(t){if(!t)return false;for(let e of t)if(typeof e!="string")for(let n of Object.values(e)){if(ce(n)){if(n.spread)continue;if(Va(n.select))return true;continue}let r=n;if(r.aggregate&&!r.bareCount)return true}return false}function Qa(t,e,n,r,s){if(!db(e))return t;let i=[];for(let o of e){if(typeof o=="string"){if(o==="*")continue;i.push(oe(o,n,r));continue}for(let[a,l]of Object.entries(o)){if(ce(l))continue;let c=l;c.aggregate||i.push(f=>wn(f,a,c,n,r));}}return pb(i,e,n,r,s),i.length===0?t:t.groupBy(i)}function pb(t,e,n,r,s){if(!(!e||!r||!n.introspection?.foreign_keys)){for(let i of e)if(typeof i!="string")for(let[o,a]of Object.entries(i)){if(!ce(a)||!a.spread)continue;let l=a,c=s?.[o],f=c?.from||o;f=Tt(f,r,n.introspection);let u=Te(n.introspection,r,f,c?.hint),d=u?.type==="m2o"||u?.type==="o2m"&&ct(u,f,n.introspection);if(!u||!d)continue;let p=Li(l.select,f,n.introspection)??l.select??[],y=`_spread_${o}`;for(let h of p){if(typeof h=="string"){h!=="*"&&t.push(`${y}.${h}`);continue}let[b,m]=Object.entries(h)[0];ce(m)||m.aggregate||t.push(w=>wn(w,b,m,n,y,true));}}}}function Lf(t,e,n,r,s){if(!t||!e||!r||!s.introspection?.foreign_keys)return t;let i=new Set;for(let o of e)if(typeof o!="string")for(let[a,l]of Object.entries(o)){if(!ce(l)||!l.spread)continue;let c=n?.[a],f=c?.from||a;f=Tt(f,r,s.introspection);let u=Te(s.introspection,r,f,c?.hint),d=u?.type==="m2o"||u?.type==="o2m"&&ct(u,f,s.introspection);u&&d&&i.add(a);}return i.size===0?t:t.map(o=>o.embed&&i.has(o.embed)?{...o,embed:`_spread_${o.embed}`}:o)}function Uf(t,e,n,r){if(!t||!n||!r.introspection?.foreign_keys)return false;for(let s of t)if(typeof s!="string")for(let[i,o]of Object.entries(s)){if(!ce(o)||!o.spread)continue;let a=e?.[i],l=a?.from||i;l=Tt(l,n,r.introspection);let c=Te(r.introspection,n,l,a?.hint),f=c?.type==="m2o"||c?.type==="o2m"&&ct(c,l,r.introspection);if(c&&f)return true}return false}function Ni(t){let e=new Map;for(let n of t){let r=n.foreign_key_name,s=e.get(r);s?s.push(n):e.set(r,[n]);}return [...e.values()]}function Xa(t,e,n,r){t=t.innerJoin(e.junctionTable,s=>{let i=s;for(let o=0;o<e.junctionToTargetCols.length;o++)i=i.onRef(`${e.junctionTable}.${e.junctionToTargetCols[o]}`,"=",`${n}.${e.targetCols[o]}`);return i});for(let s=0;s<e.junctionToParentCols.length;s++)t=t.whereRef(`${e.junctionTable}.${e.junctionToParentCols[s]}`,"=",`${r}.${e.parentCols[s]}`);return t}function Ya(t,e,n,r,s=n){let i=s===n?n:`${n} as ${s}`;if(e.type==="m2o"){let[,l]=e.leftCol.split("."),[,c]=e.rightCol.split(".");return t.leftJoin(i,f=>f.onRef(`${s}.${c}`,"=",`${r}.${l}`))}let[,o]=e.leftCol.split("."),[,a]=e.rightCol.split(".");return t.leftJoin(i,l=>l.onRef(`${s}.${o}`,"=",`${r}.${a}`))}function Kr(t,e,n,r,s){let i=new Set;if(!e||!r.introspection?.foreign_keys)return {sub:t,joined:i};for(let o of e){if(!o.embed||i.has(o.embed))continue;Ct(o.embed,"order embed alias");let a=s?.[o.embed],l=el(o.embed,a,n,r.introspection);l!==o.embed&&Ct(l,"order embed target");let c=Te(r.introspection,n,l,a?.hint),f=c?.type==="m2o"||c?.type==="o2m"&&ct(c,l,r.introspection);!c||!f||(t=Ya(t,c,l,n,o.embed),i.add(o.embed),i.add(l));}return {sub:t,joined:i}}function Mf(t){return t&&t.map(e=>e.embed&&e.nullsFirst===void 0?{...e,nullsFirst:e.direction==="desc"}:e)}function za(t,e){let n={};for(let[r,s]of Object.entries(t))r==="$or"||r==="$and"?n[r]=s.map(i=>za(i,e)):r==="$not"?n[r]=za(s,e):r.startsWith("$")||r.includes(".")?n[r]=s:n[`${e}.${r}`]=s;return n}function Ii(t,e,n){let r=n.includes(".")?n.split(".").pop():n,s=t.introspection?.columns?.find(o=>o.table===e&&o.name===r),i=(s?.pg_type||s?.type||"").toLowerCase();return i==="json"||i==="jsonb"}function mb(t,e,n){return e.dialect==="sqlite"&&n!==void 0&&/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(t)&&Ii(e,n,t)}function hb(t,e){if(!t)return false;let n=e.includes(".")?e.split(".").pop():e;return t.some(r=>r.column.includes("->")?r.column.slice(0,r.column.indexOf("->"))===n:false)}function Wr(t,e,n,r){return Ii(t,e,n)||hb(r,n)}function gb(t,e,n){if(!t)return null;let r=[];for(let s of t){if(typeof s=="string"){if(s==="*")return null;let l=s.includes(".")?s.split(".").pop():s;r.push({alias:l,asJson:Ii(n,e,l)});continue}let[i,o]=Object.entries(s)[0];if(!i||!o)continue;if(ce(o))return null;let a=Ii(n,e,o.column||i);r.push({alias:i,asJson:a});}return r}function yb(t,e,n,r){let s=gb(e,n,r);if(!s||s.length===0)return r.jsonObjectFrom(t);let i=s.flatMap(o=>[sql.lit(o.alias),o.asJson?sql`json(${sql.ref(`obj.${o.alias}`)})`:sql.ref(`obj.${o.alias}`)]);return sql`(select json_object(${sql.join(i)}) from ${t} as obj)`}function bb(t){return t==="m2o"?"many-to-one":t==="o2m"?"one-to-many":"many-to-many"}function wb(t,e,n){return t.fk?t.type==="m2m"?`${t.fk.foreign_key_name} using ${t.junctionTable}(${t.fk.column}) and ${e}(${t.fk.ref_column})`:`${t.fk.foreign_key_name} using ${t.fk.table}(${t.fk.column}) and ${t.fk.ref_table}(${t.fk.ref_column})`:""}function Sb(t,e){if(!t||!e)return null;let n=[];for(let s of t.tables??[])n.push(s.name);for(let s of t.views??[])n.push(s.name);let r=n.find(s=>s.length===e.length+1&&s.startsWith(e));return r?`Perhaps you meant '${r}' instead of '${e}'.`:null}function Za(t,e,n,r){let s=t?.foreign_keys?.find(o=>o.table===e||o.ref_table===e)?.schema||"test",i=r?` using the hint '${r}'`:"";throw new Ae({httpStatus:400,code:"PGRST200",message:`Could not find a relationship between '${e}' and '${n}' in the schema cache`,details:`Searched for a foreign key relationship between '${e}' and '${n}'${i} in the schema '${s}', but no matches were found.`,hint:Sb(t,n)})}function Te(t,e,n,r){if(!t||!t.foreign_keys)return null;let s=t.foreign_keys.filter(p=>p.is_visible!==false);if(r){let p=s.find(E=>E.foreign_key_name===r);if(p){if(p.table===e&&p.ref_table===n)return {leftCol:`${e}.${p.column}`,rightCol:`${n}.${p.ref_column}`,type:"m2o"};if(p.table===n&&p.ref_table===e)return {leftCol:`${n}.${p.column}`,rightCol:`${e}.${p.ref_column}`,type:"o2m"}}let y=s.find(E=>E.table===e&&E.column===r&&E.ref_table===n);if(y)return {leftCol:`${e}.${y.column}`,rightCol:`${n}.${y.ref_column}`,type:"m2o"};let h=s.find(E=>E.table===n&&E.column===r&&E.ref_table===e);if(h)return {leftCol:`${n}.${h.column}`,rightCol:`${e}.${h.ref_column}`,type:"o2m"};let b=s.filter(E=>E.table===r),m=Ni(b.filter(E=>E.ref_table===e)),w=Ni(b.filter(E=>E.ref_table===n));if(m.length>0&&w.length>0){let E=m[0],C=w[0];return {type:"m2m",junctionTable:r,junctionToParentCols:E.map(x=>x.column),parentCols:E.map(x=>x.ref_column),junctionToTargetCols:C.map(x=>x.column),targetCols:C.map(x=>x.ref_column)}}let _=s.find(E=>E.table===n&&E.ref_column===r&&E.ref_table===e);if(_)return {leftCol:`${n}.${_.column}`,rightCol:`${e}.${_.ref_column}`,type:"o2m"};let S=s.find(E=>E.table===e&&E.ref_column===r&&E.ref_table===n);if(S)return {leftCol:`${e}.${S.column}`,rightCol:`${n}.${S.ref_column}`,type:"m2o"};Za(t,e,n,r);}if(e===n){let p=s.find(y=>y.table===n&&y.ref_table===e);if(p)return {leftCol:`${n}.${p.column}`,rightCol:`${e}.${p.ref_column}`,type:"o2m"}}let i=s.filter(p=>p.table===e&&p.ref_table===n),o=[...new Map(i.map(p=>[p.foreign_key_name,p])).values()],a=s.filter(p=>p.table===n&&p.ref_table===e),l=[...new Map(a.map(p=>[p.foreign_key_name,p])).values()],c=[],f=Ni(s.filter(p=>p.ref_table===e));for(let p of f){let y=p[0].table;if(y===e||y===n)continue;let h=s.filter(b=>b.table===y&&b.ref_table===n);if(h.length!==0)for(let b of Ni(h))c.push({type:"m2m",junctionTable:y,junctionToParentCols:p.map(m=>m.column),parentCols:p.map(m=>m.ref_column),junctionToTargetCols:b.map(m=>m.column),targetCols:b.map(m=>m.ref_column),fk:p[0]});}if(o.length+l.length+c.length===0)return null;if(o.length>1||l.length>1){let p=[...o.map(m=>({leftCol:`${e}.${m.column}`,rightCol:`${n}.${m.ref_column}`,type:"m2o",fk:m})),...l.map(m=>({leftCol:`${n}.${m.column}`,rightCol:`${e}.${m.ref_column}`,type:"o2m",fk:m})),...c],y=p.map(m=>({cardinality:bb(m.type),embedding:`${e} with ${n}`,relationship:wb(m,e)})),b=p.map(m=>m.fk?.foreign_key_name).filter(Boolean).map(m=>`'${n}!${m}'`).join(", ");throw new Ae({httpStatus:300,code:"PGRST201",message:`Could not embed because more than one relationship was found for '${e}' and '${n}'`,details:y,hint:b?`Try changing '${n}' to one of the following: ${b}. Find the desired relationship in the 'details' key.`:null})}if(o.length===1){let p=o[0];return {leftCol:`${e}.${p.column}`,rightCol:`${n}.${p.ref_column}`,type:"m2o"}}if(l.length===1){let p=l[0];return {leftCol:`${n}.${p.column}`,rightCol:`${e}.${p.ref_column}`,type:"o2m"}}return c.length===1?c[0]:null}function Ff(t,e,n,r){if(!(!t||!n||!r.introspection?.foreign_keys))for(let s of t){if(!s.embed)continue;let i=e?.[s.embed],o=el(s.embed,i,n,r.introspection),a=Te(r.introspection,n,o,i?.hint);if(!a)continue;if(!(a.type==="m2o"||a.type==="o2m"&&ct(a,o,r.introspection)))throw new Ae({httpStatus:400,code:"PGRST118",message:`A related order on '${s.embed}' is not possible`,details:`'${n}' and '${s.embed}' do not form a many-to-one or one-to-one relationship`,hint:null})}}function Tt(t,e,n){if(!n?.foreign_keys||n.tables?.some(l=>l.name===t)||n.views?.some(l=>l.name===t))return t;let s=n.foreign_keys,i=s.find(l=>l.table===e&&l.column===t);if(i)return i.ref_table;let o=s.find(l=>l.foreign_key_name===t&&(l.table===e||l.ref_table===e));if(o)return o.table===e?o.ref_table:o.table;let a=s.find(l=>l.ref_table===e&&l.ref_column===t);return a?a.table:t}function jf(t,e,n,r,s,i){let o=s?.[e],a=o?.from||e;i&&(a=Tt(a,i,r.introspection));let l=i?Te(r.introspection,i,a,o?.hint):null;return t.where(c=>{let f=c.selectFrom(a).select(sql`1`.as("_"));return o?.on?f=f.where(u=>Pe(u,o.on,r)):l&&l.type==="m2m"?f=Xa(f,l,a,i):l?f=f.whereRef(l.leftCol,"=",l.rightCol):i&&(f=f.whereRef(`${a}.${i}_id`,"=",`${i}.id`)),n.where&&Object.keys(n.where).length>0&&(f=f.where(u=>Pe(u,n.where,r))),c.exists(f)})}function ct(t,e,n){if(!n||t.type!=="o2m")return false;let r=t.leftCol.split(".")[1];return n.indexes?.some(o=>o.table===e&&o.unique&&o.columns.length===1&&o.columns[0]===r)||n.unique_constraints?.some(o=>o.table===e&&o.columns.length===1&&o.columns[0]===r)?true:n.primary_keys?.some(o=>o.table===e&&o.columns.length===1&&o.columns[0]===r)??false}function Eb(t,e){return t&&t.map(n=>typeof n!="string"||n==="*"||n.includes(".")||/^-?\d+(?:\.\d+)?$/.test(n)?n:`${e}.${n}`)}function Hr(t){if(typeof t=="string")return {colAlias:t,colName:t};let e=Object.keys(t)[0],n=t[e];return {colAlias:e,colName:n?.column||e}}function _b(t,e,n,r,s,i){if(!n.select||!i)return t;let o=s?.[e],a=o?.from||e;a=Tt(a,i,r.introspection);let l=Te(r.introspection,i,a,o?.hint),c=Li(n.select,a,r.introspection)??n.select;if(!r.introspection?.foreign_keys)return Rb(t,c,a,i,l);if(!l)throw new Ae({httpStatus:400,code:"PGRST120",message:"Could not embed because the relationship is not a one-to-one or many-to-one",details:null,hint:null});if(!(l.type==="m2o"||l.type==="o2m"&&ct(l,a,r.introspection))){if(Ga(n.select))throw new Ae({httpStatus:400,code:"PGRST127",message:"Feature not implemented",details:"Aggregates are not implemented for one-to-many or many-to-many spreads.",hint:null});return vb(t,c,n,l,a,i,r)}let u=`_spread_${e}`,[d,p]=l.leftCol.split("."),[,y]=l.rightCol.split("."),h=d===a?p:y,b=d===i?p:y,m="__spread_join_key",w=[],_=new Set;for(let S of c){if(typeof S=="string"&&S==="*")continue;let E;if(typeof S!="string"){let R=Object.values(S)[0];if(ce(R))continue;E=R;}let{colAlias:C,colName:x}=Hr(S);w.push({src:x,out:C,def:E}),_.add(x);}t=t.leftJoin(S=>{let E=S.selectFrom(a);E=E.select(`${a}.${h} as ${m}`);for(let C of _)E=E.select(`${a}.${C} as ${C}`);return E.as(u)},S=>S.onRef(`${u}.${m}`,"=",`${i}.${b}`));for(let{out:S,def:E}of w)E?t=t.select(C=>wn(C,S,E,r,u,true).as(S)):t=t.select(`${u}.${S}`);return t}function xb(t,e,n,r){for(let s of t){if(typeof s=="string")continue;let i=Object.values(s)[0];if(!ce(i))continue;let{colAlias:o}=Hr(s),a=e.join?.[o],l=Tt(a?.from||o,n,r.introspection),c=Te(r.introspection,n,l,a?.hint);if(!c||c.type!=="o2m"||!ct(c,l,r.introspection))continue;let f=r.introspection?.primary_keys?.find(u=>u.table===l);if(f?.columns?.length)return {nestedTargetTable:l,fkRel:c,pkColumns:f.columns}}return null}function vb(t,e,n,r,s,i,o){let a=n.order?null:xb(e,n,s,o);for(let l of e){if(typeof l=="string"&&l==="*")continue;let c=typeof l=="string"?null:Object.values(l)[0],f=c!==null&&ce(c),u=f&&c.spread,{colAlias:d,colName:p}=Hr(l);if(u){t=Cb(t,d,c,n,r,s,i,o);continue}t=t.select(y=>{let h=y.selectFrom(s);if(h=Di(h,r,s,i),n.where&&Object.keys(n.where).length>0&&(h=h.where(b=>Pe(b,n.where,o))),n.order&&(h=Kr(h,n.order,s,o,n.join).sub,h=Rt(h,Mf(n.order),void 0,o,s)),n.limit!==void 0&&(h=h.limit(n.limit)),n.offset!==void 0&&(h=h.offset(n.offset)),a&&(h=Ya(h,a.fkRel,a.nestedTargetTable,s),h=Rt(h,a.pkColumns.map(b=>({column:b,embed:a.nestedTargetTable})),void 0,o)),f){let b=n.join?.[d];return h=h.select(m=>Bf(m,d,c,o,b,s).as("value")),o.jsonScalarArrayFrom(h,"value",true).as(d)}else return c!==null?(h=h.select(b=>wn(b,p,c,o,s).as("value")),o.jsonScalarArrayFrom(h,"value",Wr(o,s,p,n.order)).as(d)):(h=h.select(`${s}.${p} as value`),o.jsonScalarArrayFrom(h,"value",Wr(o,s,p,n.order)).as(d))});}return t}function Cb(t,e,n,r,s,i,o,a){let l=r.join?.[e],c=Tt(l?.from||e,i,a.introspection),f=Te(a.introspection,i,c,l?.hint),u=Li(n.select,c,a.introspection)??n.select??[],d=f?.type==="m2o"||f?.type==="o2m"&&ct(f,c,a.introspection);for(let p of u){if(typeof p=="string"&&p==="*")continue;let y=typeof p=="string"?null:Object.values(p)[0],{colAlias:h,colName:b}=Hr(p);t=t.select(m=>{let w=m.selectFrom(i);w=Di(w,s,i,o),r.where&&Object.keys(r.where).length>0&&(w=w.where(S=>Pe(S,r.where,a)));let _=Kr(w,r.order,i,a,r.join);if(w=_.sub,r.order&&(w=Rt(w,Mf(r.order),void 0,a,i)),r.limit!==void 0&&(w=w.limit(r.limit)),r.offset!==void 0&&(w=w.offset(r.offset)),!f)return w=w.where(sql`1 = 0`).select(sql`null`.as("value")),a.jsonScalarArrayFrom(w).as(h);if(d){if(_.joined.has(c)||(w=Ya(w,f,c,i)),!r.order&&f.type==="o2m"){let S=a.introspection?.primary_keys?.find(E=>E.table===c);S?.columns?.length&&(w=Rt(w,S.columns.map(E=>({column:E,embed:c})),void 0,a));}if(y!==null&&!ce(y)){let S={...y,column:`${c}.${b}`};w=w.select(E=>wn(E,h,S,a).as("value"));}else w=w.select(`${c}.${b} as value`);return a.jsonScalarArrayFrom(w,"value",Wr(a,c,b,r.order)).as(h)}else return w=w.select(S=>{let E=S.selectFrom(c);return E=Di(E,f,c,i),y!==null&&!ce(y)?(E=E.select(C=>wn(C,b,y,a,c).as("value")),a.jsonScalarArrayFrom(E,"value",Wr(a,c,b,r.order)).as("value")):(E=E.select(`${c}.${b} as value`),a.jsonScalarArrayFrom(E,"value",Wr(a,c,b,r.order)).as("value"))}),a.jsonScalarArrayFrom(w,"value",true).as(h)});}return t}function Di(t,e,n,r){return e.type==="m2m"?Xa(t,e,n,r):t.whereRef(e.leftCol,"=",e.rightCol)}function Rb(t,e,n,r,s){for(let i of e){if(typeof i=="string"&&i==="*")continue;let{colAlias:o,colName:a}=Hr(i);t=t.select(l=>{let c=l.selectFrom(n).select(`${n}.${a}`);return s&&s.type!=="m2m"?c=c.whereRef(s.leftCol,"=",s.rightCol):c=c.whereRef(`${n}.${r}_id`,"=",`${r}.id`),c=c.limit(1),c.as(o)});}return t}function Li(t,e,n){if(!t||!n?.columns||!t.some(i=>i==="*"))return t;let r=n.columns.filter(i=>i.table===e).sort((i,o)=>i.ordinal_position-o.ordinal_position).map(i=>i.name);if(r.length===0)return t;let s=[];for(let i of t)if(i==="*")for(let o of r)s.push(o);else s.push(i);return s}function el(t,e,n,r){let s=e?.from||t;if(!r?.foreign_keys||r.tables?.some(f=>f.name===s)||r.views?.some(f=>f.name===s))return s;let o=r.foreign_keys,a=o.find(f=>f.table===n&&f.column===s);if(a)return a.ref_table;let l=o.find(f=>f.foreign_key_name===s&&(f.table===n||f.ref_table===n));if(l)return l.table===n?l.ref_table:l.table;let c=o.find(f=>f.ref_table===n&&f.ref_column===s);return c?c.table:s}function Tb(t,e,n,r,s,i){let o=s?.[e];if(!n.select||n.select.length===0){if(o?.type==="inner"&&i)return jf(t,e,n,r,s,i);if(i&&!o?.on&&r.introspection?.foreign_keys){let a=el(e,o,i,r.introspection);Te(r.introspection,i,a,o?.hint)||Za(r.introspection,i,a,o?.hint);}return t}return o?.type==="inner"&&i&&(t=jf(t,e,n,r,s,i)),n.spread&&i?_b(t,e,n,r,s,i):t.select(a=>Bf(a,e,n,r,o,i).as(e))}function Bf(t,e,n,r,s,i){let o=s?.from||e;if(i&&r.introspection?.foreign_keys){let _=r.introspection.foreign_keys.find(S=>S.table===i&&S.column===o);if(_)o=_.ref_table;else {let S=r.introspection.foreign_keys.find(E=>E.foreign_key_name===o&&(E.table===i||E.ref_table===i));if(S)o=S.table===i?S.ref_table:S.table;else {let E=r.introspection.foreign_keys.find(C=>C.ref_table===i&&C.ref_column===o);E&&(o=E.table);}}}let a=i===o,l=a?`${o}_self`:o,c=a?`${o} as ${l}`:o,f=t.selectFrom(c),u=i&&!s?.on?Te(r.introspection,i,o,s?.hint):null,d=u?.type==="m2m",p=Li(n.select,o,r.introspection),y=d?Eb(p,l):p;if(f=ji(f,y,r,n.join,l,fb(y)),n.where&&Object.keys(n.where).length>0){let _=Ui(f,n.where,n.select,n.join,o,r);f=_.qb,Object.keys(_.remainingWhere).length>0&&(f=f.where(S=>Pe(S,_.remainingWhere,r)));}let h="o2m";if(s?.on)f=f.where(_=>Pe(_,s.on,r));else if(i){let _=Te(r.introspection,i,o,s?.hint);if(_&&_.type==="m2m")h="m2m",f=Xa(f,_,l,i);else if(_){let S=a?_.leftCol.replace(`${o}.`,`${l}.`):_.leftCol;f=f.whereRef(S,"=",_.rightCol),h=_.type;}else r.introspection?.foreign_keys?Za(r.introspection,i,o,s?.hint):f=f.whereRef(`${l}.${i}_id`,"=",`${i}.id`);}f=Qa(f,y,r,o),n.order?.some(_=>_.embed)&&(f=Kr(f,n.order,o,r,n.join).sub),f=Rt(f,n.order,void 0,r,o),h==="m2m"&&!n.order&&u?.type==="m2m"&&r.dialect==="sqlite"&&(f=f.orderBy(`${u.junctionTable}.${r.rowIdColumn}`,"asc")),n.limit!==void 0&&(f=f.limit(n.limit)),n.offset!==void 0&&(f=f.offset(n.offset));let b=false;if(h==="o2m"&&i&&r.introspection){let _=Te(r.introspection,i,o,s?.hint);_&&_.type==="o2m"&&(b=ct(_,o,r.introspection));}let m=n.spread||h==="m2o"||b;return m&&r.dialect==="sqlite"?yb(f,y,o,r):(m?r.jsonObjectFrom:r.jsonArrayFrom)(f)}function qf(t,e,n,r){if(!t||!r.introspection?.foreign_keys)return false;for(let s of t){if(typeof s=="string")continue;let[i,o]=Object.entries(s)[0];if(!ce(o)||!o.spread)continue;let l=e?.[i],c=Tt(l?.from||i,n,r.introspection),f=Te(r.introspection,n,c,l?.hint);if(!f)continue;if(!(f.type==="m2o"||f.type==="o2m"&&ct(f,c,r.introspection)))return true}return false}function Ui(t,e,n,r,s,i){if(!n||!e||!i.introspection?.foreign_keys)return {qb:t,remainingWhere:e};if(Object.keys(e).length===0||!Kf(e,n))return {qb:t,remainingWhere:e};let o=e;return t=t.where(a=>{let l=Wf(a,e,n,r,s,i);return o=l.remainingWhere,l.expression??sql`1 = 1`}),Object.keys(o).length===Object.keys(e).length?{qb:t,remainingWhere:e}:{qb:t,remainingWhere:o}}function Wf(t,e,n,r,s,i){let o=[],a={};for(let[c,f]of Object.entries(e)){if((c==="$or"||c==="$and")&&Array.isArray(f)){let d=f.map(p=>Wf(t,p,n,r,s,i));if(d.length>0&&d.every(p=>p.fullyHandled&&p.expression)){o.push(c==="$or"?t.or(d.map(p=>p.expression)):t.and(d.map(p=>p.expression)));continue}a[c]=f;continue}let u=kb(t,c,f,n,r,s,i);u?o.push(u):a[c]=f;}let l=o.length===0?null:o.length===1?o[0]:t.and(o);return {expression:l,remainingWhere:a,fullyHandled:l!==null&&Object.keys(a).length===0}}function kb(t,e,n,r,s,i,o){let a=n;if(!a||typeof a!="object")return null;let l="$is"in a&&a.$is===null,c="$isNot"in a&&a.$isNot===null;if(!l&&!c)return null;let f=Jf(r,e);if(!f)return null;let u=s?.[e],d=Tt(u?.from||e,i,o.introspection),p=Te(o.introspection,i,d,u?.hint);if(!p)return null;let y=t.selectFrom(d).select(sql`1`.as("_"));if(u?.on?y=y.where(b=>Pe(b,u.on,o)):y=Di(y,p,d,i),f.where&&Object.keys(f.where).length>0){let b=Ui(y,f.where,f.select,f.join,d,o);if(y=b.qb,Object.keys(b.remainingWhere).length>0){let m=za(b.remainingWhere,d);y=y.where(w=>Pe(w,m,o));}}let h=t.exists(y);return c?h:t.not(h)}function Jf(t,e){for(let n of t){if(typeof n=="string")continue;let r=n[e];if(r&&ce(r))return r}return null}function Kf(t,e){for(let[n,r]of Object.entries(t)){if((n==="$or"||n==="$and")&&Array.isArray(r)){if(r.some(a=>Kf(a,e)))return true;continue}let s=r;if(!s||typeof s!="object")continue;let i="$is"in s&&s.$is===null,o="$isNot"in s&&s.$isNot===null;if((i||o)&&Jf(e,n))return true}return false}function Ab(t,e,n){return t.schema?.get(`${e??"public"}.${n}`)}function tl(t,e,n,r,s={}){if(!t)return t;let i=Ab(e,n,r),o=a=>{let l=Ob(a,i,e,n,r),c=s.applyDefaults&&i?i.applyDefaults(l):l;return i?i.serializeRow(c):$b(c,e,n,r)};return Array.isArray(t)?t.map(a=>o(a)):o(t)}function Ob(t,e,n,r,s){let i={};for(let[o,a]of Object.entries(t)){let l=e?.get(o)?.context.pgTypeName??Gf(n,r,s,o)??void 0;i[o]=Pb(a,l);}return i}function $b(t,e,n,r){if(e.dialect!=="sqlite")return t;let s={};for(let[i,o]of Object.entries(t)){let a=Gf(e,n,r,i);s[i]=Db(a)?jb(o):o;}return s}function Gf(t,e,n,r){let i=(t.introspection?.columns??[]).filter(a=>a.table===n&&a.name===r);if(i.length===0)return;let o=i.find(a=>a.schema===(e??"public"))??i.find(a=>a.schema==="public")??i[0];return o.pg_type??o.type}function Pb(t,e){if(t==null||typeof t!="string")return t;let n=Vf(e);return n==="boolean"?Nb(t):n==="integer"?Hf(t,true):n==="number"?Hf(t,false):n==="json"?Qf(t):n==="array"?Ib(t):t}function Vf(t){if(!t)return;let e=t.toLowerCase().trim();if(e.startsWith("_")||e.endsWith("[]"))return "array";if(e==="bool"||e==="boolean")return "boolean";if(["int2","smallint","int4","integer","int","int8","bigint"].includes(e))return "integer";if(["float4","real","float8","double precision","numeric","decimal"].includes(e))return "number";if(e==="json"||e==="jsonb")return "json"}function Nb(t){let e=t.trim().toLowerCase();return ["true","t","1","yes","y","on"].includes(e)?true:["false","f","0","no","n","off"].includes(e)?false:t}function Hf(t,e){let n=t.trim();if(n==="")return t;let r=Number(n);return !Number.isFinite(r)||e&&!Number.isInteger(r)?t:r}function Qf(t){let e=t.trim();if(e==="")return t;try{return JSON.parse(e)}catch{return t}}function Ib(t){let e=Qf(t);return Array.isArray(e)?e:t}function Db(t){let e=Vf(t);return e==="json"||e==="array"}function jb(t){return t==null||typeof t=="string"?t:JSON.stringify(t)}function Xf(t,e){let n=e.db;switch(t.schema&&(n=n.withSchema(t.schema)),t.type){case "query":return Ha(t,e,n);case "insert":return Ub(t,e,n);case "update":return Mb(t,e,n);case "delete":return Fb(t,e,n);case "upsert":case "put":return Bb(t,e,n);case "rpc":return qb(t,e,n);default:throw t&&"type"in t?(console.error(t),new Error(`Unsupported AST type: ${t.type}`)):new Error("Invalid AST")}}function Rt(t,e,n,r,s){if(!e)return t;for(let i of e){let o=i.embed?(Ct(i.embed,"order embed alias"),i.column.includes("->")?r?qr(i.column,r,s,i.embed):zf(i.column,i.embed):(Ct(i.column,"order embed column"),r?Xt(i.embed,i.column,r,s):sql`${sql.ref(i.embed)}.${sql.ref(i.column)}`)):i.column.includes("->")?r?qr(i.column,r,s,n):zf(i.column,void 0,n):n?r?Xt(n,i.column,r,s):sql`${sql.ref(n)}.${sql.ref(i.column)}`:r?oe(i.column,r,s):i.column,a=i.nullsFirst!==void 0?i.nullsFirst:r?.dialect==="sqlite"?i.direction==="desc":void 0;a!==void 0?t=t.orderBy(o,l=>{let c=i.direction==="desc"?l.desc():l.asc();return a?c.nullsFirst():c.nullsLast()}):t=t.orderBy(o,i.direction||"asc");}return t}function zf(t,e,n){let{col:r,parts:s}=bn(t);if(s.length===0)return sql.ref(t);e&&Ct(r,"order embed column");let i=Br(s,"ORDER BY JSON path key");return e?sql`${sql.ref(e)}.${sql.ref(r)}${sql.raw(i)}`:n?sql`${sql.ref(n)}.${sql.ref(r)}${sql.raw(i)}`:sql`${sql.ref(r)}${sql.raw(i)}`}function zr(t,e,n,r,s){return !e||Object.keys(e).length===0?t:t.where(i=>Pe(i,e,{...n,currentTable:r,currentSchema:s}))}function Ha(t,e,n){let r=n.selectFrom(t.from);r=Lb(r,t.join,t.select);let s=t.order?.some(f=>f.embed)===true;r=ji(r,t.select,e,t.join,t.from,s||Uf(t.select,t.join,t.from,e));let i=t.where??{},{qb:o,remainingWhere:a}=t.from?Ui(r,i,t.select,t.join,t.from,e):{qb:r,remainingWhere:i};r=o,r=zr(r,a,e,t.from,t.schema),r=Qa(r,t.select,e,t.from,t.join),Ff(t.order,t.join,t.from,e),t.from&&s&&(r=Kr(r,t.order,t.from,e,t.join).sub);let l=t.from&&qf(t.select,t.join,t.from,e)?t.from:void 0,c=Lf(t.order,t.select,t.join,t.from,e);return r=Rt(r,c,l,e,t.from),t.limit!==void 0&&(r=r.limit(t.limit)),t.offset!==void 0&&(r=r.offset(t.offset)),r}function Lb(t,e,n){if(!e)return t;let r=new Set;if(n){for(let s of n)if(typeof s!="string")for(let i of Object.keys(s))r.add(i);}for(let[s,i]of Object.entries(e)){if(!i.on||r.has(s))continue;let o=i.from||s,a=i.type==="left"?"leftJoin":"innerJoin";t=t[a](`${o} as ${s}`,l=>Yf(l,i.on));}return t}function Yf(t,e){for(let[n,r]of Object.entries(e))if(n==="$and")for(let s of r)t=Yf(t,s);else {let s=r;for(let[i,o]of Object.entries(s)){let a=$i[i];if(!a)throw new Error(`Unsupported join operator: ${i}`);ki(o)?t=t.onRef(n,a,o.$ref):t=t.on(n,a,o);}}return t}function Ub(t,e,n){let r=n.insertInto(t.from);if(t.values){let s=tl(t.values,e,t.schema,t.from,{applyDefaults:true});r=r.values(s);}return r=Jr(r,t.select),r}function Mb(t,e,n){let r=n.updateTable(t.from);if(t.values){let s=tl(t.values,e,t.schema,t.from);r=r.set(s);}return t.limit!==void 0||t.offset!==void 0?r=Zf(r,t,e,n):r=zr(r,t.where??{},e,t.from,t.schema),r=Jr(r,t.select),r}function Fb(t,e,n){let r=n.deleteFrom(t.from);return t.limit!==void 0||t.offset!==void 0?r=Zf(r,t,e,n):r=zr(r,t.where??{},e,t.from,t.schema),r=Jr(r,t.select),r}function Zf(t,e,n,r){let i=n.introspection?.primary_keys.find(l=>l.table===e.from)?.columns??[],o=r.selectFrom(e.from),a=n.rowIdColumn;if(i.length>0)for(let l of i)o=o.select(l);else o=o.select(sql.ref(a).as("__rowid"));if(o=zr(o,e.where??{},n,e.from,e.schema),o=Rt(o,e.order,void 0,n,e.from),e.limit!==void 0&&(o=o.limit(e.limit)),e.offset!==void 0&&(o=o.offset(e.offset)),i.length===1)return t.where(i[0],"in",o);if(i.length>1){let l="__ltd_target",c=r.selectFrom(o.as(l)).select(sql`1`.as("_"));for(let f of i)c=c.whereRef(`${l}.${f}`,"=",`${e.from}.${f}`);return t.where(f=>f.exists(c))}else return t.where(sql.ref(a),"in",o)}function Bb(t,e,n){let r=t.values,s=tl(r,e,t.schema,t.from,{applyDefaults:true}),i=n.insertInto(t.from).values(s);return t.onConflict&&(i=i.onConflict(o=>{let a=t.onConflict.length===1?o.column(t.onConflict[0]):o.columns(t.onConflict);if(t.ignoreDuplicates)return a.doNothing();let l=Array.isArray(s)?s[0]:s,c=Object.keys(l).filter(f=>!t.onConflict.includes(f));return c.length===0?a.doUpdateSet({[t.onConflict[0]]:sql.ref(`excluded.${t.onConflict[0]}`)}):a.doUpdateSet(f=>{let u={};for(let d of c)u[d]=f.ref(`excluded.${d}`);return u})})),i=Jr(i,t.select),i}function qb(t,e,n){let r=t.function;Ct(r,"RPC function name");let s;if(t.args&&!Array.isArray(t.args)&&Object.keys(t.args).length>0){let a=Object.entries(t.args).map(([l,c])=>(Ct(l,"RPC param key"),sql`${sql.raw(l)} := ${c}`));s=sql`${sql.raw(r)}(${sql.join(a)})`;}else if(Array.isArray(t.args)&&t.args.length>0){let o=t.args.map(a=>sql`${a}`);s=sql`${sql.raw(r)}(${sql.join(o)})`;}else s=sql`${sql.raw(r)}()`;let i=n.selectFrom(s.as(r));return i=ji(i,t.select,e),i=zr(i,t.where??{},e,t.from,t.schema),i=Rt(i,t.order,void 0,e,t.from),t.limit!==void 0&&(i=i.limit(t.limit)),t.offset!==void 0&&(i=i.offset(t.offset)),i}var Qb=new Kysely({dialect:{createAdapter:()=>new PostgresAdapter,createDriver:()=>new DummyDriver,createIntrospector:t=>new PostgresIntrospector(t),createQueryCompiler:()=>new PostgresQueryCompiler}}),Xb={$ilike:(t,e,n)=>sql`${A(e)} ilike ${n}`,$regex:(t,e,n)=>sql`${A(e)} ~ ${n}`,$iregex:(t,e,n)=>sql`${A(e)} ~* ${n}`,$contains:(t,e,n)=>sql`${A(e)} @> ${n}`,$containedBy:(t,e,n)=>sql`${A(e)} <@ ${n}`,$overlaps:(t,e,n)=>sql`${A(e)} && ${n}`,$rangeLt:(t,e,n)=>sql`${A(e)} << ${n}`,$rangeGt:(t,e,n)=>sql`${A(e)} >> ${n}`,$rangeGte:(t,e,n)=>sql`${A(e)} &> ${n}`,$rangeLte:(t,e,n)=>sql`${A(e)} &< ${n}`,$rangeAdjacent:(t,e,n)=>sql`${A(e)} -|- ${n}`,$textSearch:(t,e,n)=>{let r=n,s=r.config||"english",i="to_tsquery";return r.type==="plain"?i="plainto_tsquery":r.type==="phrase"?i="phraseto_tsquery":r.type==="websearch"&&(i="websearch_to_tsquery"),sql`${A(e)} @@ ${sql.raw(i)}(${sql.literal(s)}, ${r.query})`},$eqAny:(t,e,n)=>sql`${A(e)} = any(${n})`,$neqAny:(t,e,n)=>sql`${A(e)} != any(${n})`,$gtAny:(t,e,n)=>sql`${A(e)} > any(${n})`,$gteAny:(t,e,n)=>sql`${A(e)} >= any(${n})`,$ltAny:(t,e,n)=>sql`${A(e)} < any(${n})`,$lteAny:(t,e,n)=>sql`${A(e)} <= any(${n})`,$likeAny:(t,e,n)=>sql`${A(e)} like any(${n})`,$ilikeAny:(t,e,n)=>sql`${A(e)} ilike any(${n})`,$eqAll:(t,e,n)=>sql`${A(e)} = all(${n})`,$neqAll:(t,e,n)=>sql`${A(e)} != all(${n})`,$gtAll:(t,e,n)=>sql`${A(e)} > all(${n})`,$gteAll:(t,e,n)=>sql`${A(e)} >= all(${n})`,$ltAll:(t,e,n)=>sql`${A(e)} < all(${n})`,$lteAll:(t,e,n)=>sql`${A(e)} <= all(${n})`,$likeAll:(t,e,n)=>sql`${A(e)} like all(${n})`,$ilikeAll:(t,e,n)=>sql`${A(e)} ilike all(${n})`,$regexAny:(t,e,n)=>sql`${A(e)} ~ any(${n})`,$iregexAny:(t,e,n)=>sql`${A(e)} ~* any(${n})`,$regexAll:(t,e,n)=>sql`${A(e)} ~ all(${n})`,$iregexAll:(t,e,n)=>sql`${A(e)} ~* all(${n})`};function Yb(t,e){let n=e.replace(/^\$\./,"").split(".");if(n.length===0)return sql.ref(t);let r=n.map((s,i)=>{let o=i===n.length-1?"->>":"->",a=/^-?\d+$/.test(s);return a||Hn(s,"JSON path key"),a?`${o}${s}`:`${o}'${s}'`}).join("");return sql`${sql.ref(t)}${sql.raw(r)}`}function Zb(t,e="value",n=false){let r=sql.ref(e);return sql`(select coalesce(json_agg(${r}), '[]'::json) from ${t} as _agg)`}var ed={db:Qb,operators:{...Oi,...Xb},jsonArrayFrom:jsonArrayFrom$1,jsonObjectFrom:jsonObjectFrom$1,jsonScalarArrayFrom:Zb,jsonPath:Yb,rowIdColumn:"ctid"};var aw=new Kysely({dialect:{createAdapter:()=>new SqliteAdapter,createDriver:()=>new DummyDriver,createIntrospector:t=>new SqliteIntrospector(t),createQueryCompiler:()=>new SqliteQueryCompiler}});function lw(t,e){let n=e.replace(/^\$\./,"").split(".");if(n.length===0)return sql.ref(t);let r=n.map((s,i)=>{let o=i===n.length-1?"->>":"->",a=/^-?\d+$/.test(s);return a||Hn(s,"JSON path key"),a?`${o}${s}`:`${o}'${s}'`}).join("");return sql`${sql.ref(t)}${sql.raw(r)}`}function cw(t,e){let n=A(t);if(e.length===0)return sql`${n} is not null`;let r=sql.join(e.map(s=>sql`${s}`));return sql`${n} is not null and (select count(distinct value) from json_each(${n}) where value in (${r})) = ${sql.lit(e.length)}`}function uw(t,e){let n=A(t),r=Object.keys(e);if(r.length===0)return sql`${n} is not null`;let s=r.map(i=>(Hn(i,"JSON object key"),sql`json_extract(${n}, ${sql.raw(`'$.${i}'`)}) = ${e[i]}`));return sql`${n} is not null and ${sql.join(s,sql` and `)}`}function Mi(t,e,n,r){if(!Array.isArray(e))throw new Error(`$${n}${r} on sqlite requires an array value`);if(e.length===0)return r==="any"?sql`false`:sql`true`;let s=A(t),i=n==="ilike"?sql`lower(${s})`:s,o=e.map(a=>n==="ilike"?sql`${i} like lower(${a})`:sql`${i} like ${a}`);return sql`(${sql.join(o,r==="any"?sql` or `:sql` and `)})`}var fw={$ilike:(t,e,n)=>sql`lower(${A(e)}) like lower(${n})`,$likeAny:(t,e,n)=>Mi(e,n,"like","any"),$ilikeAny:(t,e,n)=>Mi(e,n,"ilike","any"),$likeAll:(t,e,n)=>Mi(e,n,"like","all"),$ilikeAll:(t,e,n)=>Mi(e,n,"ilike","all"),$contains:(t,e,n)=>{if(Array.isArray(n))return cw(e,n);if(n!==null&&typeof n=="object")return uw(e,n);throw new Error("$contains on sqlite requires an array or object value")},$containedBy:(t,e,n)=>{if(!Array.isArray(n))throw new Error("$containedBy on sqlite requires an array value");let r=A(e);if(n.length===0)return sql`${r} is not null and not exists (select 1 from json_each(${r}))`;let s=sql.join(n.map(i=>sql`${i}`));return sql`${r} is not null and not exists (select 1 from json_each(${r}) where value not in (${s}))`},$overlaps:(t,e,n)=>{if(!Array.isArray(n))throw new Error("$overlaps on sqlite requires an array value");let r=A(e);if(n.length===0)return sql`1 = 0`;let s=sql.join(n.map(i=>sql`${i}`));return sql`${r} is not null and exists (select 1 from json_each(${r}) where value in (${s}))`}};function dw(t,e="value",n=false){let r=sql.ref(e),s=n?sql`json_group_array(json(${r}))`:sql`json_group_array(${r})`;return sql`(select coalesce(${s}, json('[]')) from ${t} as _agg)`}var td={db:aw,operators:{...Oi,...fw},jsonArrayFrom:jsonArrayFrom,jsonObjectFrom:jsonObjectFrom,jsonScalarArrayFrom:dw,jsonPath:lw,rowIdColumn:"rowid"};function pw(t){switch(t){case "postgres":return ed;case "sqlite":return td;default:throw new Error(`Unsupported dialect: ${t}`)}}function me(t,e="postgres",n){let r=pw(e),s=n&&"introspection"in n?n:{db:n,introspection:void 0};return Xf(t,{...r,dialect:e,db:s.db??r.db,introspection:s.introspection,schema:s.schema})}var ze=ou(sd());Yr();Gr();var Zr=class extends Error{constructor(n,r){super(`Could not find the table '${[n,r].filter(Boolean).join(".")}' in the schema cache`);this.schema=n;this.relation=r;}},ll=class{constructor(e){this.config=e;}kysely;introspection;async translateDdl(e){return e}async clearSchemaCache(){this.introspection=void 0,await this.deleteCachedIntrospection();}async readCachedIntrospection(e){if(typeof this.introspection=="object"&&e?.useCache===true)return this.introspection;if(e?.useCache!==true||!this.config.schemaCache)return;let n=await this.config.schemaCache.get(this.schemaCacheKey());if(n)try{return this.introspection=JSON.parse(n),this.introspection}catch{await this.deleteCachedIntrospection();return}}async writeCachedIntrospection(e,n){this.introspection=e,n?.useDriver===true&&await this.config.schemaCache?.set(this.schemaCacheKey(),JSON.stringify(e));}async deleteCachedIntrospection(){await this.config.schemaCache?.delete(this.schemaCacheKey());}schemaCacheKey(){return ["@supabase/lite","schema-cache",this.dialect,this.config.introspection?.name??"",this.config.url??""].join(":")}async exec(e,...n){try{return sql(e,...n??[]).execute(this.kysely)}catch(r){throw console.error(r),new Error(`Failed to execute query: ${e}`)}}async ping(){try{let e=await this.exec("SELECT 1");return e&&Array.isArray(e.rows)&&e.rows.length===1}catch{return false}}async transaction(e,n){throw new Error("This Connection does not support transactions")}createMigrator(e){throw new Error("This Connection does not support migrations")}async onPostgrestAST(e,n){return e}deserializeRow(e){return e}normalizeDbError(e){return e}async withContext(e,n,r){return n(this.kysely)}};Xr();var zn=class extends Error{constructor(n){super(`new row violates row-level security policy for table "${n.data.table}"`);this.policy=n;this.name="PolicyViolation";}};Wi();function O(t,e,n,r,s){let i=JSON.stringify({code:e,details:r,hint:s,message:n}),o=new TextEncoder().encode(i);return new Response(o,{status:t,headers:{"Content-Type":"application/json; charset=utf-8","Content-Length":String(o.byteLength)}})}function Ze(t){return O(t.status,t.code,t.message,t.details??null,t.hint??null)}var En=new TextEncoder,kt=new TextDecoder;function Ji(...t){let e=t.reduce((s,{length:i})=>s+i,0),n=new Uint8Array(e),r=0;for(let s of t)n.set(s,r),r+=s.length;return n}function Zt(t){let e=new Uint8Array(t.length);for(let n=0;n<t.length;n++){let r=t.charCodeAt(n);if(r>127)throw new TypeError("non-ASCII string encountered in encode()");e[n]=r;}return e}function gd(t){if(Uint8Array.prototype.toBase64)return t.toBase64();let e=32768,n=[];for(let r=0;r<t.length;r+=e)n.push(String.fromCharCode.apply(null,t.subarray(r,r+e)));return btoa(n.join(""))}function yd(t){if(Uint8Array.fromBase64)return Uint8Array.fromBase64(t);let e=atob(t),n=new Uint8Array(e.length);for(let r=0;r<e.length;r++)n[r]=e.charCodeAt(r);return n}function Gn(t){if(Uint8Array.fromBase64)return Uint8Array.fromBase64(typeof t=="string"?t:kt.decode(t),{alphabet:"base64url"});let e=t;e instanceof Uint8Array&&(e=kt.decode(e)),e=e.replace(/-/g,"+").replace(/_/g,"/");try{return yd(e)}catch{throw new TypeError("The input to be decoded is not correctly encoded.")}}function Ki(t){let e=t;return typeof e=="string"&&(e=En.encode(e)),Uint8Array.prototype.toBase64?e.toBase64({alphabet:"base64url",omitPadding:true}):gd(e).replace(/=/g,"").replace(/\+/g,"-").replace(/\//g,"_")}var Ot={};xr(Ot,{JOSEAlgNotAllowed:()=>es,JOSEError:()=>he,JOSENotSupported:()=>Fe,JWEDecryptionFailed:()=>cl,JWEInvalid:()=>ul,JWKInvalid:()=>fl,JWKSInvalid:()=>dl,JWKSMultipleMatchingKeys:()=>ml,JWKSNoMatchingKey:()=>pl,JWKSTimeout:()=>hl,JWSInvalid:()=>G,JWSSignatureVerificationFailed:()=>ts,JWTClaimValidationFailed:()=>Ne,JWTExpired:()=>Vn,JWTInvalid:()=>At});var he=class extends Error{static code="ERR_JOSE_GENERIC";code="ERR_JOSE_GENERIC";constructor(e,n){super(e,n),this.name=this.constructor.name,Error.captureStackTrace?.(this,this.constructor);}},Ne=class extends he{static code="ERR_JWT_CLAIM_VALIDATION_FAILED";code="ERR_JWT_CLAIM_VALIDATION_FAILED";claim;reason;payload;constructor(e,n,r="unspecified",s="unspecified"){super(e,{cause:{claim:r,reason:s,payload:n}}),this.claim=r,this.reason=s,this.payload=n;}},Vn=class extends he{static code="ERR_JWT_EXPIRED";code="ERR_JWT_EXPIRED";claim;reason;payload;constructor(e,n,r="unspecified",s="unspecified"){super(e,{cause:{claim:r,reason:s,payload:n}}),this.claim=r,this.reason=s,this.payload=n;}},es=class extends he{static code="ERR_JOSE_ALG_NOT_ALLOWED";code="ERR_JOSE_ALG_NOT_ALLOWED"},Fe=class extends he{static code="ERR_JOSE_NOT_SUPPORTED";code="ERR_JOSE_NOT_SUPPORTED"},cl=class extends he{static code="ERR_JWE_DECRYPTION_FAILED";code="ERR_JWE_DECRYPTION_FAILED";constructor(e="decryption operation failed",n){super(e,n);}},ul=class extends he{static code="ERR_JWE_INVALID";code="ERR_JWE_INVALID"},G=class extends he{static code="ERR_JWS_INVALID";code="ERR_JWS_INVALID"},At=class extends he{static code="ERR_JWT_INVALID";code="ERR_JWT_INVALID"},fl=class extends he{static code="ERR_JWK_INVALID";code="ERR_JWK_INVALID"},dl=class extends he{static code="ERR_JWKS_INVALID";code="ERR_JWKS_INVALID"},pl=class extends he{static code="ERR_JWKS_NO_MATCHING_KEY";code="ERR_JWKS_NO_MATCHING_KEY";constructor(e="no applicable key found in the JSON Web Key Set",n){super(e,n);}},ml=class extends he{[Symbol.asyncIterator];static code="ERR_JWKS_MULTIPLE_MATCHING_KEYS";code="ERR_JWKS_MULTIPLE_MATCHING_KEYS";constructor(e="multiple matching keys found in the JSON Web Key Set",n){super(e,n);}},hl=class extends he{static code="ERR_JWKS_TIMEOUT";code="ERR_JWKS_TIMEOUT";constructor(e="request timed out",n){super(e,n);}},ts=class extends he{static code="ERR_JWS_SIGNATURE_VERIFICATION_FAILED";code="ERR_JWS_SIGNATURE_VERIFICATION_FAILED";constructor(e="signature verification failed",n){super(e,n);}};var ut=(t,e="algorithm.name")=>new TypeError(`CryptoKey does not support this operation, its ${e} must be ${t}`),Qn=(t,e)=>t.name===e;function gl(t){return parseInt(t.name.slice(4),10)}function Cw(t){switch(t){case "ES256":return "P-256";case "ES384":return "P-384";case "ES512":return "P-521";default:throw new Error("unreachable")}}function Rw(t,e){if(e&&!t.usages.includes(e))throw new TypeError(`CryptoKey does not support this operation, its usages must include ${e}.`)}function bd(t,e,n){switch(e){case "HS256":case "HS384":case "HS512":{if(!Qn(t.algorithm,"HMAC"))throw ut("HMAC");let r=parseInt(e.slice(2),10);if(gl(t.algorithm.hash)!==r)throw ut(`SHA-${r}`,"algorithm.hash");break}case "RS256":case "RS384":case "RS512":{if(!Qn(t.algorithm,"RSASSA-PKCS1-v1_5"))throw ut("RSASSA-PKCS1-v1_5");let r=parseInt(e.slice(2),10);if(gl(t.algorithm.hash)!==r)throw ut(`SHA-${r}`,"algorithm.hash");break}case "PS256":case "PS384":case "PS512":{if(!Qn(t.algorithm,"RSA-PSS"))throw ut("RSA-PSS");let r=parseInt(e.slice(2),10);if(gl(t.algorithm.hash)!==r)throw ut(`SHA-${r}`,"algorithm.hash");break}case "Ed25519":case "EdDSA":{if(!Qn(t.algorithm,"Ed25519"))throw ut("Ed25519");break}case "ML-DSA-44":case "ML-DSA-65":case "ML-DSA-87":{if(!Qn(t.algorithm,e))throw ut(e);break}case "ES256":case "ES384":case "ES512":{if(!Qn(t.algorithm,"ECDSA"))throw ut("ECDSA");let r=Cw(e);if(t.algorithm.namedCurve!==r)throw ut(r,"algorithm.namedCurve");break}default:throw new TypeError("CryptoKey does not support this operation")}Rw(t,n);}function wd(t,e,...n){if(n=n.filter(Boolean),n.length>2){let r=n.pop();t+=`one of type ${n.join(", ")}, or ${r}.`;}else n.length===2?t+=`one of type ${n[0]} or ${n[1]}.`:t+=`of type ${n[0]}.`;return e==null?t+=` Received ${e}`:typeof e=="function"&&e.name?t+=` Received function ${e.name}`:typeof e=="object"&&e!=null&&e.constructor?.name&&(t+=` Received an instance of ${e.constructor.name}`),t}var Sd=(t,...e)=>wd("Key must be ",t,...e),yl=(t,e,...n)=>wd(`Key for the ${t} algorithm must be `,e,...n);var bl=t=>{if(t?.[Symbol.toStringTag]==="CryptoKey")return true;try{return t instanceof CryptoKey}catch{return false}},wl=t=>t?.[Symbol.toStringTag]==="KeyObject",Sl=t=>bl(t)||wl(t);function Hi(...t){let e=t.filter(Boolean);if(e.length===0||e.length===1)return true;let n;for(let r of e){let s=Object.keys(r);if(!n||n.size===0){n=new Set(s);continue}for(let i of s){if(n.has(i))return false;n.add(i);}}return true}var Tw=t=>typeof t=="object"&&t!==null;function en(t){if(!Tw(t)||Object.prototype.toString.call(t)!=="[object Object]")return false;if(Object.getPrototypeOf(t)===null)return true;let e=t;for(;Object.getPrototypeOf(e)!==null;)e=Object.getPrototypeOf(e);return Object.getPrototypeOf(t)===e}function zi(t,e){if(t.startsWith("RS")||t.startsWith("PS")){let{modulusLength:n}=e.algorithm;if(typeof n!="number"||n<2048)throw new TypeError(`${t} requires key modulusLength to be 2048 bits or larger`)}}function kw(t){let e,n;switch(t.kty){case "AKP":{switch(t.alg){case "ML-DSA-44":case "ML-DSA-65":case "ML-DSA-87":e={name:t.alg},n=t.priv?["sign"]:["verify"];break;default:throw new Fe('Invalid or unsupported JWK "alg" (Algorithm) Parameter value')}break}case "RSA":{switch(t.alg){case "PS256":case "PS384":case "PS512":e={name:"RSA-PSS",hash:`SHA-${t.alg.slice(-3)}`},n=t.d?["sign"]:["verify"];break;case "RS256":case "RS384":case "RS512":e={name:"RSASSA-PKCS1-v1_5",hash:`SHA-${t.alg.slice(-3)}`},n=t.d?["sign"]:["verify"];break;case "RSA-OAEP":case "RSA-OAEP-256":case "RSA-OAEP-384":case "RSA-OAEP-512":e={name:"RSA-OAEP",hash:`SHA-${parseInt(t.alg.slice(-3),10)||1}`},n=t.d?["decrypt","unwrapKey"]:["encrypt","wrapKey"];break;default:throw new Fe('Invalid or unsupported JWK "alg" (Algorithm) Parameter value')}break}case "EC":{switch(t.alg){case "ES256":e={name:"ECDSA",namedCurve:"P-256"},n=t.d?["sign"]:["verify"];break;case "ES384":e={name:"ECDSA",namedCurve:"P-384"},n=t.d?["sign"]:["verify"];break;case "ES512":e={name:"ECDSA",namedCurve:"P-521"},n=t.d?["sign"]:["verify"];break;case "ECDH-ES":case "ECDH-ES+A128KW":case "ECDH-ES+A192KW":case "ECDH-ES+A256KW":e={name:"ECDH",namedCurve:t.crv},n=t.d?["deriveBits"]:[];break;default:throw new Fe('Invalid or unsupported JWK "alg" (Algorithm) Parameter value')}break}case "OKP":{switch(t.alg){case "Ed25519":case "EdDSA":e={name:"Ed25519"},n=t.d?["sign"]:["verify"];break;case "ECDH-ES":case "ECDH-ES+A128KW":case "ECDH-ES+A192KW":case "ECDH-ES+A256KW":e={name:t.crv},n=t.d?["deriveBits"]:[];break;default:throw new Fe('Invalid or unsupported JWK "alg" (Algorithm) Parameter value')}break}default:throw new Fe('Invalid or unsupported JWK "kty" (Key Type) Parameter value')}return {algorithm:e,keyUsages:n}}async function Ed(t){if(!t.alg)throw new TypeError('"alg" argument is required when "jwk.alg" is not present');let{algorithm:e,keyUsages:n}=kw(t),r={...t};return r.kty!=="AKP"&&delete r.alg,delete r.use,crypto.subtle.importKey("jwk",r,e,t.ext??!(t.d||t.priv),t.key_ops??n)}function Gi(t,e,n,r,s){if(s.crit!==void 0&&r?.crit===void 0)throw new t('"crit" (Critical) Header Parameter MUST be integrity protected');if(!r||r.crit===void 0)return new Set;if(!Array.isArray(r.crit)||r.crit.length===0||r.crit.some(o=>typeof o!="string"||o.length===0))throw new t('"crit" (Critical) Header Parameter MUST be an array of non-empty strings when present');let i;n!==void 0?i=new Map([...Object.entries(n),...e.entries()]):i=e;for(let o of r.crit){if(!i.has(o))throw new Fe(`Extension Header Parameter "${o}" is not recognized`);if(s[o]===void 0)throw new t(`Extension Header Parameter "${o}" is missing`);if(i.get(o)&&r[o]===void 0)throw new t(`Extension Header Parameter "${o}" MUST be integrity protected`)}return new Set(r.crit)}function _d(t,e){if(e!==void 0&&(!Array.isArray(e)||e.some(n=>typeof n!="string")))throw new TypeError(`"${t}" option must be an array of strings`);if(e)return new Set(e)}var ns=t=>en(t)&&typeof t.kty=="string",xd=t=>t.kty!=="oct"&&(t.kty==="AKP"&&typeof t.priv=="string"||typeof t.d=="string"),vd=t=>t.kty!=="oct"&&t.d===void 0&&t.priv===void 0,Cd=t=>t.kty==="oct"&&typeof t.k=="string";var Xn,Rd=async(t,e,n,r=false)=>{Xn||=new WeakMap;let s=Xn.get(t);if(s?.[n])return s[n];let i=await Ed({...e,alg:n});return r&&Object.freeze(t),s?s[n]=i:Xn.set(t,{[n]:i}),i},Ow=(t,e)=>{Xn||=new WeakMap;let n=Xn.get(t);if(n?.[e])return n[e];let r=t.type==="public",s=!!r,i;if(t.asymmetricKeyType==="x25519"){switch(e){case "ECDH-ES":case "ECDH-ES+A128KW":case "ECDH-ES+A192KW":case "ECDH-ES+A256KW":break;default:throw new TypeError("given KeyObject instance cannot be used for this algorithm")}i=t.toCryptoKey(t.asymmetricKeyType,s,r?[]:["deriveBits"]);}if(t.asymmetricKeyType==="ed25519"){if(e!=="EdDSA"&&e!=="Ed25519")throw new TypeError("given KeyObject instance cannot be used for this algorithm");i=t.toCryptoKey(t.asymmetricKeyType,s,[r?"verify":"sign"]);}switch(t.asymmetricKeyType){case "ml-dsa-44":case "ml-dsa-65":case "ml-dsa-87":{if(e!==t.asymmetricKeyType.toUpperCase())throw new TypeError("given KeyObject instance cannot be used for this algorithm");i=t.toCryptoKey(t.asymmetricKeyType,s,[r?"verify":"sign"]);}}if(t.asymmetricKeyType==="rsa"){let o;switch(e){case "RSA-OAEP":o="SHA-1";break;case "RS256":case "PS256":case "RSA-OAEP-256":o="SHA-256";break;case "RS384":case "PS384":case "RSA-OAEP-384":o="SHA-384";break;case "RS512":case "PS512":case "RSA-OAEP-512":o="SHA-512";break;default:throw new TypeError("given KeyObject instance cannot be used for this algorithm")}if(e.startsWith("RSA-OAEP"))return t.toCryptoKey({name:"RSA-OAEP",hash:o},s,r?["encrypt"]:["decrypt"]);i=t.toCryptoKey({name:e.startsWith("PS")?"RSA-PSS":"RSASSA-PKCS1-v1_5",hash:o},s,[r?"verify":"sign"]);}if(t.asymmetricKeyType==="ec"){let a=new Map([["prime256v1","P-256"],["secp384r1","P-384"],["secp521r1","P-521"]]).get(t.asymmetricKeyDetails?.namedCurve);if(!a)throw new TypeError("given KeyObject instance cannot be used for this algorithm");e==="ES256"&&a==="P-256"&&(i=t.toCryptoKey({name:"ECDSA",namedCurve:a},s,[r?"verify":"sign"])),e==="ES384"&&a==="P-384"&&(i=t.toCryptoKey({name:"ECDSA",namedCurve:a},s,[r?"verify":"sign"])),e==="ES512"&&a==="P-521"&&(i=t.toCryptoKey({name:"ECDSA",namedCurve:a},s,[r?"verify":"sign"])),e.startsWith("ECDH-ES")&&(i=t.toCryptoKey({name:"ECDH",namedCurve:a},s,r?[]:["deriveBits"]));}if(!i)throw new TypeError("given KeyObject instance cannot be used for this algorithm");return n?n[e]=i:Xn.set(t,{[e]:i}),i};async function Vi(t,e){if(t instanceof Uint8Array||bl(t))return t;if(wl(t)){if(t.type==="secret")return t.export();if("toCryptoKey"in t&&typeof t.toCryptoKey=="function")try{return Ow(t,e)}catch(r){if(r instanceof TypeError)throw r}let n=t.export({format:"jwk"});return Rd(t,n,e)}if(ns(t))return t.k?Gn(t.k):Rd(t,t,e,true);throw new Error("unreachable")}var Yn=t=>t?.[Symbol.toStringTag],El=(t,e,n)=>{if(e.use!==void 0){let r;switch(n){case "sign":case "verify":r="sig";break;case "encrypt":case "decrypt":r="enc";break}if(e.use!==r)throw new TypeError(`Invalid key for this operation, its "use" must be "${r}" when present`)}if(e.alg!==void 0&&e.alg!==t)throw new TypeError(`Invalid key for this operation, its "alg" must be "${t}" when present`);if(Array.isArray(e.key_ops)){let r;switch(true){case(n==="sign"||n==="verify"):case t==="dir":case t.includes("CBC-HS"):r=n;break;case t.startsWith("PBES2"):r="deriveBits";break;case /^A\d{3}(?:GCM)?(?:KW)?$/.test(t):!t.includes("GCM")&&t.endsWith("KW")?r=n==="encrypt"?"wrapKey":"unwrapKey":r=n;break;case(n==="encrypt"&&t.startsWith("RSA")):r="wrapKey";break;case n==="decrypt":r=t.startsWith("RSA")?"unwrapKey":"deriveBits";break}if(r&&e.key_ops?.includes?.(r)===false)throw new TypeError(`Invalid key for this operation, its "key_ops" must include "${r}" when present`)}return true},$w=(t,e,n)=>{if(!(e instanceof Uint8Array)){if(ns(e)){if(Cd(e)&&El(t,e,n))return;throw new TypeError('JSON Web Key for symmetric algorithms must have JWK "kty" (Key Type) equal to "oct" and the JWK "k" (Key Value) present')}if(!Sl(e))throw new TypeError(yl(t,e,"CryptoKey","KeyObject","JSON Web Key","Uint8Array"));if(e.type!=="secret")throw new TypeError(`${Yn(e)} instances for symmetric algorithms must be of type "secret"`)}},Pw=(t,e,n)=>{if(ns(e))switch(n){case "decrypt":case "sign":if(xd(e)&&El(t,e,n))return;throw new TypeError("JSON Web Key for this operation must be a private JWK");case "encrypt":case "verify":if(vd(e)&&El(t,e,n))return;throw new TypeError("JSON Web Key for this operation must be a public JWK")}if(!Sl(e))throw new TypeError(yl(t,e,"CryptoKey","KeyObject","JSON Web Key"));if(e.type==="secret")throw new TypeError(`${Yn(e)} instances for asymmetric algorithms must not be of type "secret"`);if(e.type==="public")switch(n){case "sign":throw new TypeError(`${Yn(e)} instances for asymmetric algorithm signing must be of type "private"`);case "decrypt":throw new TypeError(`${Yn(e)} instances for asymmetric algorithm decryption must be of type "private"`)}if(e.type==="private")switch(n){case "verify":throw new TypeError(`${Yn(e)} instances for asymmetric algorithm verifying must be of type "public"`);case "encrypt":throw new TypeError(`${Yn(e)} instances for asymmetric algorithm encryption must be of type "public"`)}};function Qi(t,e,n){switch(t.substring(0,2)){case "A1":case "A2":case "di":case "HS":case "PB":$w(t,e,n);break;default:Pw(t,e,n);}}function Xi(t,e){let n=`SHA-${t.slice(-3)}`;switch(t){case "HS256":case "HS384":case "HS512":return {hash:n,name:"HMAC"};case "PS256":case "PS384":case "PS512":return {hash:n,name:"RSA-PSS",saltLength:parseInt(t.slice(-3),10)>>3};case "RS256":case "RS384":case "RS512":return {hash:n,name:"RSASSA-PKCS1-v1_5"};case "ES256":case "ES384":case "ES512":return {hash:n,name:"ECDSA",namedCurve:e.namedCurve};case "Ed25519":case "EdDSA":return {name:"Ed25519"};case "ML-DSA-44":case "ML-DSA-65":case "ML-DSA-87":return {name:t};default:throw new Fe(`alg ${t} is not supported either by JOSE or your javascript runtime`)}}async function Yi(t,e,n){if(e instanceof Uint8Array){if(!t.startsWith("HS"))throw new TypeError(Sd(e,"CryptoKey","KeyObject","JSON Web Key"));return crypto.subtle.importKey("raw",e,{hash:`SHA-${t.slice(-3)}`,name:"HMAC"},false,[n])}return bd(e,t,n),e}async function Td(t,e,n,r){let s=await Yi(t,e,"verify");zi(t,s);let i=Xi(t,s.algorithm);try{return await crypto.subtle.verify(i,s,n,r)}catch{return false}}async function kd(t,e,n){if(!en(t))throw new G("Flattened JWS must be an object");if(t.protected===void 0&&t.header===void 0)throw new G('Flattened JWS must have either of the "protected" or "header" members');if(t.protected!==void 0&&typeof t.protected!="string")throw new G("JWS Protected Header incorrect type");if(t.payload===void 0)throw new G("JWS Payload missing");if(typeof t.signature!="string")throw new G("JWS Signature missing or incorrect type");if(t.header!==void 0&&!en(t.header))throw new G("JWS Unprotected Header incorrect type");let r={};if(t.protected)try{let b=Gn(t.protected);r=JSON.parse(kt.decode(b));}catch{throw new G("JWS Protected Header is invalid")}if(!Hi(r,t.header))throw new G("JWS Protected and JWS Unprotected Header Parameter names must be disjoint");let s={...r,...t.header},i=Gi(G,new Map([["b64",true]]),n?.crit,r,s),o=true;if(i.has("b64")&&(o=r.b64,typeof o!="boolean"))throw new G('The "b64" (base64url-encode payload) Header Parameter must be a boolean');let{alg:a}=s;if(typeof a!="string"||!a)throw new G('JWS "alg" (Algorithm) Header Parameter missing or invalid');let l=n&&_d("algorithms",n.algorithms);if(l&&!l.has(a))throw new es('"alg" (Algorithm) Header Parameter value not allowed');if(o){if(typeof t.payload!="string")throw new G("JWS Payload must be a string")}else if(typeof t.payload!="string"&&!(t.payload instanceof Uint8Array))throw new G("JWS Payload must be a string or an Uint8Array instance");let c=false;typeof e=="function"&&(e=await e(r,t),c=true),Qi(a,e,"verify");let f=Ji(t.protected!==void 0?Zt(t.protected):new Uint8Array,Zt("."),typeof t.payload=="string"?o?Zt(t.payload):En.encode(t.payload):t.payload),u;try{u=Gn(t.signature);}catch{throw new G("Failed to base64url decode the signature")}let d=await Vi(e,a);if(!await Td(a,d,u,f))throw new ts;let y;if(o)try{y=Gn(t.payload);}catch{throw new G("Failed to base64url decode the payload")}else typeof t.payload=="string"?y=En.encode(t.payload):y=t.payload;let h={payload:y};return t.protected!==void 0&&(h.protectedHeader=r),t.header!==void 0&&(h.unprotectedHeader=t.header),c?{...h,key:d}:h}async function Ad(t,e,n){if(t instanceof Uint8Array&&(t=kt.decode(t)),typeof t!="string")throw new G("Compact JWS must be a string or Uint8Array");let{0:r,1:s,2:i,length:o}=t.split(".");if(o!==3)throw new G("Invalid Compact JWS");let a=await kd({payload:s,protected:r,signature:i},e,n),l={payload:a.payload,protectedHeader:a.protectedHeader};return typeof e=="function"?{...l,key:a.key}:l}var tn=t=>Math.floor(t.getTime()/1e3),$d=60,Pd=$d*60,_l=Pd*24,Nw=_l*7,Iw=_l*365.25,Dw=/^(\+|\-)? ?(\d+|\d+\.\d+) ?(seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)(?: (ago|from now))?$/i;function rs(t){let e=Dw.exec(t);if(!e||e[4]&&e[1])throw new TypeError("Invalid time period format");let n=parseFloat(e[2]),r=e[3].toLowerCase(),s;switch(r){case "sec":case "secs":case "second":case "seconds":case "s":s=Math.round(n);break;case "minute":case "minutes":case "min":case "mins":case "m":s=Math.round(n*$d);break;case "hour":case "hours":case "hr":case "hrs":case "h":s=Math.round(n*Pd);break;case "day":case "days":case "d":s=Math.round(n*_l);break;case "week":case "weeks":case "w":s=Math.round(n*Nw);break;default:s=Math.round(n*Iw);break}return e[1]==="-"||e[4]==="ago"?-s:s}function _n(t,e){if(!Number.isFinite(e))throw new TypeError(`Invalid ${t} input`);return e}var Od=t=>t.includes("/")?t.toLowerCase():`application/${t.toLowerCase()}`,jw=(t,e)=>typeof t=="string"?e.includes(t):Array.isArray(t)?e.some(Set.prototype.has.bind(new Set(t))):false;function Nd(t,e,n={}){let r;try{r=JSON.parse(kt.decode(e));}catch{}if(!en(r))throw new At("JWT Claims Set must be a top-level JSON object");let{typ:s}=n;if(s&&(typeof t.typ!="string"||Od(t.typ)!==Od(s)))throw new Ne('unexpected "typ" JWT header value',r,"typ","check_failed");let{requiredClaims:i=[],issuer:o,subject:a,audience:l,maxTokenAge:c}=n,f=[...i];c!==void 0&&f.push("iat"),l!==void 0&&f.push("aud"),a!==void 0&&f.push("sub"),o!==void 0&&f.push("iss");for(let y of new Set(f.reverse()))if(!(y in r))throw new Ne(`missing required "${y}" claim`,r,y,"missing");if(o&&!(Array.isArray(o)?o:[o]).includes(r.iss))throw new Ne('unexpected "iss" claim value',r,"iss","check_failed");if(a&&r.sub!==a)throw new Ne('unexpected "sub" claim value',r,"sub","check_failed");if(l&&!jw(r.aud,typeof l=="string"?[l]:l))throw new Ne('unexpected "aud" claim value',r,"aud","check_failed");let u;switch(typeof n.clockTolerance){case "string":u=rs(n.clockTolerance);break;case "number":u=n.clockTolerance;break;case "undefined":u=0;break;default:throw new TypeError("Invalid clockTolerance option type")}let{currentDate:d}=n,p=tn(d||new Date);if((r.iat!==void 0||c)&&typeof r.iat!="number")throw new Ne('"iat" claim must be a number',r,"iat","invalid");if(r.nbf!==void 0){if(typeof r.nbf!="number")throw new Ne('"nbf" claim must be a number',r,"nbf","invalid");if(r.nbf>p+u)throw new Ne('"nbf" claim timestamp check failed',r,"nbf","check_failed")}if(r.exp!==void 0){if(typeof r.exp!="number")throw new Ne('"exp" claim must be a number',r,"exp","invalid");if(r.exp<=p-u)throw new Vn('"exp" claim timestamp check failed',r,"exp","check_failed")}if(c){let y=p-r.iat,h=typeof c=="number"?c:rs(c);if(y-u>h)throw new Vn('"iat" claim timestamp check failed (too far in the past)',r,"iat","check_failed");if(y<0-u)throw new Ne('"iat" claim timestamp check failed (it should be in the past)',r,"iat","check_failed")}return r}var Zi=class{#e;constructor(e){if(!en(e))throw new TypeError("JWT Claims Set MUST be an object");this.#e=structuredClone(e);}data(){return En.encode(JSON.stringify(this.#e))}get iss(){return this.#e.iss}set iss(e){this.#e.iss=e;}get sub(){return this.#e.sub}set sub(e){this.#e.sub=e;}get aud(){return this.#e.aud}set aud(e){this.#e.aud=e;}set jti(e){this.#e.jti=e;}set nbf(e){typeof e=="number"?this.#e.nbf=_n("setNotBefore",e):e instanceof Date?this.#e.nbf=_n("setNotBefore",tn(e)):this.#e.nbf=tn(new Date)+rs(e);}set exp(e){typeof e=="number"?this.#e.exp=_n("setExpirationTime",e):e instanceof Date?this.#e.exp=_n("setExpirationTime",tn(e)):this.#e.exp=tn(new Date)+rs(e);}set iat(e){e===void 0?this.#e.iat=tn(new Date):e instanceof Date?this.#e.iat=_n("setIssuedAt",tn(e)):typeof e=="string"?this.#e.iat=_n("setIssuedAt",tn(new Date)+rs(e)):this.#e.iat=_n("setIssuedAt",e);}};async function xn(t,e,n){let r=await Ad(t,e,n);if(r.protectedHeader.crit?.includes("b64")&&r.protectedHeader.b64===false)throw new At("JWTs MUST NOT use unencoded payload");let i={payload:Nd(r.protectedHeader,r.payload,n),protectedHeader:r.protectedHeader};return typeof e=="function"?{...i,key:r.key}:i}async function Id(t,e,n){let r=await Yi(t,e,"sign");zi(t,r);let s=await crypto.subtle.sign(Xi(t,r.algorithm),r,n);return new Uint8Array(s)}var eo=class{#e;#t;#n;constructor(e){if(!(e instanceof Uint8Array))throw new TypeError("payload must be an instance of Uint8Array");this.#e=e;}setProtectedHeader(e){if(this.#t)throw new TypeError("setProtectedHeader can only be called once");return this.#t=e,this}setUnprotectedHeader(e){if(this.#n)throw new TypeError("setUnprotectedHeader can only be called once");return this.#n=e,this}async sign(e,n){if(!this.#t&&!this.#n)throw new G("either setProtectedHeader or setUnprotectedHeader must be called before #sign()");if(!Hi(this.#t,this.#n))throw new G("JWS Protected and JWS Unprotected Header Parameter names must be disjoint");let r={...this.#t,...this.#n},s=Gi(G,new Map([["b64",true]]),n?.crit,this.#t,r),i=true;if(s.has("b64")&&(i=this.#t.b64,typeof i!="boolean"))throw new G('The "b64" (base64url-encode payload) Header Parameter must be a boolean');let{alg:o}=r;if(typeof o!="string"||!o)throw new G('JWS "alg" (Algorithm) Header Parameter missing or invalid');Qi(o,e,"sign");let a,l;i?(a=Ki(this.#e),l=Zt(a)):(l=this.#e,a="");let c,f;this.#t?(c=Ki(JSON.stringify(this.#t)),f=Zt(c)):(c="",f=new Uint8Array);let u=Ji(f,Zt("."),l),d=await Vi(e,o),p=await Id(o,d,u),y={signature:Ki(p),payload:a};return this.#n&&(y.header=this.#n),this.#t&&(y.protected=c),y}};var to=class{#e;constructor(e){this.#e=new eo(e);}setProtectedHeader(e){return this.#e.setProtectedHeader(e),this}async sign(e,n){let r=await this.#e.sign(e,n);if(r.payload===void 0)throw new TypeError("use the flattened module for creating JWS with b64: false");return `${r.protected}.${r.payload}.${r.signature}`}};var vn=class{#e;#t;constructor(e={}){this.#t=new Zi(e);}setIssuer(e){return this.#t.iss=e,this}setSubject(e){return this.#t.sub=e,this}setAudience(e){return this.#t.aud=e,this}setJti(e){return this.#t.jti=e,this}setNotBefore(e){return this.#t.nbf=e,this}setExpirationTime(e){return this.#t.exp=e,this}setIssuedAt(e){return this.#t.iat=e,this}setProtectedHeader(e){return this.#e=e,this}async sign(e,n){let r=new to(this.#t.data());if(r.setProtectedHeader(this.#e),Array.isArray(this.#e?.crit)&&this.#e.crit.includes("b64")&&this.#e.b64===false)throw new At("JWTs MUST NOT use unencoded payload");return r.sign(e,n)}};async function Dd(t,e){if(!t||!t.startsWith("Bearer "))return e.anonymousEnabled?{kind:"ok",payload:null}:{kind:"error",response:Ze({status:401,code:"PGRST302",message:"Anonymous access is disabled"})};let n=t.slice(7).trim(),r=n.split(".");if(r.length!==3||r.some(s=>s.length===0))return e.anonymousEnabled?{kind:"ok",payload:null}:{kind:"error",response:Ze({status:401,code:"PGRST301",message:`Expected 3 parts in JWT; got ${Math.max(1,r.filter(s=>s.length>0).length)}`})};if(!e.jwtSecret)return {kind:"error",response:Ze({status:500,code:"PGRST300",message:"Server lacks JWT secret"})};try{let s=new TextEncoder().encode(e.jwtSecret),{payload:i}=await xn(n,s,{algorithms:["HS256"]});return typeof i.iat=="number"&&i.iat>Math.floor(Date.now()/1e3)?{kind:"error",response:Ze({status:401,code:"PGRST303",message:"JWT issued at future"})}:{kind:"ok",payload:i}}catch(s){return s instanceof Ot.JWTExpired?{kind:"error",response:Ze({status:401,code:"PGRST303",message:"JWT expired"})}:{kind:"error",response:Ze({status:401,code:"PGRST301",message:"No suitable key or wrong key type",details:"None of the keys was able to decode the JWT"})}}}function no(t,e,n,r){return !n||!e?.from?t:t.map(s=>xl(s,e.select,e.from,e.schema,e.join,n,r))}function xl(t,e,n,r,s,i,o){let a=i.get(`${r??o}.${n}`),l=Uw(e,s),c={};for(let[f,u]of Object.entries(t)){let d=l.get(f);if(d&&"embed"in d){let h=d.embed;c[f]=Lw(u,h,r,i,o);continue}let p=d?.sourceColumn??f,y=a?.get(p);c[f]=y?y.deserialize(u):u;}return c}function Lw(t,e,n,r,s){return Array.isArray(t)?t.map(i=>i&&typeof i=="object"?xl(i,e.select,e.table,n,e.join,r,s):i):t&&typeof t=="object"?xl(t,e.select,e.table,n,e.join,r,s):t}function Uw(t,e){let n=new Map;if(!t)return n;for(let r of t){if(typeof r=="string"){if(r==="*")continue;n.set(r,{sourceColumn:r});continue}if(!(!r||typeof r!="object"))for(let[s,i]of Object.entries(r))if(Mw(i)){let o=e?.[s]?.from??s;n.set(s,{embed:{table:o,select:i.select,join:i.join}});}else {let o=i;if(o.cast||o.path||o.aggregate)continue;n.set(s,{sourceColumn:o.column??s});}}return n}function Mw(t){return t!=null&&typeof t=="object"&&("select"in t||"where"in t||"order"in t||"limit"in t||"offset"in t||"spread"in t||"join"in t)}var ss=Symbol.for("lite-internal-request");function $t(t){return JSON.stringify(t,(e,n)=>typeof n=="bigint"?Number.parseInt(n.toString(),10):n)}var jd=/application\/vnd\.pgrst\.plan(?:\+(json|text))?/i;function Ld(t){let e=t.match(jd);if(!e)return null;let n=e[1]?.toLowerCase()==="json"?"json":"text",r=t.match(/;\s*options=([^;]+)/i),s=r?`; options=${r[1].trim()}`:"";return {format:n,optionsSegment:s}}function Ud(t){return jd.test(t)}function Md(t){return /;\s*nulls\s*=\s*stripped/i.test(t)}function Cn(t){if(Array.isArray(t))return t.map(e=>Cn(e));if(t!==null&&typeof t=="object"){let e={};for(let[n,r]of Object.entries(t))r!==null&&(e[n]=Cn(r));return e}return t}function Tl(t,e){if(!e||e.length===0)return t;let n=(r,s)=>{for(let i of e){if(i.embed)continue;let o=r[i.column],a=s[i.column],l=o==null,c=a==null;if(l&&c)continue;if(l)return i.nullsFirst?-1:1;if(c)return i.nullsFirst?1:-1;let f;if(typeof o=="number"&&typeof a=="number"?f=o-a:f=String(o).localeCompare(String(a)),f!==0)return i.direction==="desc"?-f:f}return 0};return [...t].sort(n)}function Fd(t,e){return !e||e.length===0?t:t.map(n=>kl(n,e))}function Bd(t,e){if(!e||e.length===0)return t;let n=Fw(e);return n.size===0?t:t.map(r=>{if(!os(r))return r;let s={...r};for(let i of n){let o=s[i];o!==null&&typeof o=="object"&&(s[i]=JSON.stringify(o));}return s})}function qd(t,e){return !e||e.length===0?t:t.map(n=>vl(n,e))}function Wd(t,e){return !e||e.length===0?t:t.map(n=>Cl(n,e))}function Jd(t,e){return !e||e.length===0?t:t.map(n=>Rl(n,e))}function Fw(t){let e=new Set;for(let n of t){if(typeof n=="string")continue;let[r,s]=Object.entries(n)[0]??[];if(!r||!s)continue;let i=s;i.path&&i.pathText&&!Kd(i.cast)&&e.add(r);}return e}function Kd(t){let e=t?.trim().toLowerCase();return e==="json"||e==="jsonb"}function kl(t,e){if(Array.isArray(t))return t.map(r=>kl(r,e));if(!os(t))return t;let n={...t};for(let r of e){if(typeof r=="string")continue;let[s,i]=Object.entries(r)[0]??[];!s||!i||!ro(i)||s in n&&(n[s]=qw(n[s],i.select));}return n}function vl(t,e){if(Array.isArray(t))return t.map(r=>vl(r,e));if(!os(t))return t;let n={...t};for(let r of e){if(typeof r=="string")continue;let[s,i]=Object.entries(r)[0]??[];if(!s||!i)continue;if(ro(i)){s in n&&i.select&&(n[s]=vl(n[s],i.select));continue}let o=i;o.aggregate==="avg"&&o.cast!=="text"&&s in n&&(n[s]=Bw(n[s]));}return n}function Cl(t,e){if(Array.isArray(t))return t.map(r=>Cl(r,e));if(!os(t))return t;let n={...t};for(let r of e){if(typeof r=="string")continue;let[s,i]=Object.entries(r)[0]??[];if(!s||!i)continue;if(ro(i)){s in n&&i.select&&(n[s]=Cl(n[s],i.select));continue}Kd(i.cast)&&s in n&&(n[s]=Hd(n[s]));}return n}function Rl(t,e){if(Array.isArray(t))return t.map(r=>Rl(r,e));if(!os(t))return t;let n={...t};for(let r of e){if(typeof r=="string")continue;let[s,i]=Object.entries(r)[0]??[];if(!s||!i)continue;if(ro(i)){s in n&&i.select&&(n[s]=Rl(n[s],i.select));continue}let o=i;o.path&&!o.pathText&&s in n&&(n[s]=Hd(n[s]));}return n}function Bw(t){if(typeof t!="string")return t;let e=t.trim();if(!/^[+-]?(?:\d+\.?\d*|\.\d+)(?:e[+-]?\d+)?$/i.test(e))return t;let n=Number(e);return !Number.isFinite(n)||e.replace(/^[+-]/,"").replace(/e[+-]?\d+$/i,"").replace(".","").replace(/^0+/,"").replace(/0+$/,"").length>15?t:n}function qw(t,e){let n=Ww(t);return !e||e.length===0?n:kl(n,e)}function Ww(t){if(typeof t!="string")return t;let e=t[0];if(e!=="["&&e!=="{")return t;try{return JSON.parse(t)}catch{return t}}function Hd(t){if(typeof t!="string")return t;try{return JSON.parse(t)}catch{return t}}function os(t){return t!==null&&typeof t=="object"&&!Array.isArray(t)}function ro(t){return t!==null&&typeof t=="object"&&("select"in t||"spread"in t||"join"in t)}var Jw=new Set(["*/*","application/*","application/json","application/vnd.pgrst.object","application/vnd.pgrst.object+json","application/vnd.pgrst.array","application/vnd.pgrst.array+json","application/octet-stream","text/csv"]);function zd(t){let e=Ld(t);return e?`application/vnd.pgrst.plan+${e.format}; for="application/json"${e.optionsSegment}`:t}function Gd(t,e){let n=t.split(",").map(r=>r.split(";")[0].trim().toLowerCase()).filter(Boolean);if(n.length===0)return true;for(let r of n)if(Jw.has(r)||e&&r.startsWith("application/vnd.pgrst.plan"))return true;return false}function Vd(t,e){let n=Ld(t)??{format:"text",optionsSegment:""},r=`application/vnd.pgrst.plan+${n.format}; for="application/json"${n.optionsSegment}; charset=utf-8`,s=n.format==="json"?$t({sql:e.sql,parameters:[...e.parameters]}):e.sql;return new Response(s,{status:200,headers:{"Content-Type":r}})}function Rn(t,e,n){let r=t+e-1,s=n!==void 0?`${n}`:"*";return `${t}-${r}/${s}`}async function is(t,e,n,r){let s=e.join&&Object.values(e.join).some(f=>f.type==="inner"),i=Kw(e);if(s||i){let f={...e,type:"query",order:void 0,limit:void 0,offset:void 0},u=me(f,n,{db:t,introspection:r}),{sql:d,parameters:p}=u.compile(),y=`SELECT count(*) as __count FROM (${d}) AS __inner_count`,b=(await t.executeQuery({sql:y,parameters:p,query:{kind:"RawNode"}})).rows?.[0];return Number(b?.__count??0)}let o={...e,type:"query",select:[{__count:{aggregate:"count"}}],order:void 0,limit:void 0,offset:void 0,join:void 0},l=await me(o,n,{db:t,introspection:r}).execute(),c=Array.isArray(l)?l[0]:l;return Number(c?.__count??0)}async function Qd(t,e,n,r){if(e.$meta?.count!=="planned"&&e.$meta?.count!=="estimated"||n!=="postgres")return is(t,e,n,r);let s={...e,type:"query",order:void 0,limit:void 0,offset:void 0},o=me(s,n,{db:t,introspection:r}).compile(),c=(await t.executeQuery({sql:`EXPLAIN (FORMAT JSON) ${o.sql}`,parameters:o.parameters,query:{kind:"RawNode"}})).rows?.[0]?.["QUERY PLAN"],f=Array.isArray(c)&&c[0]&&typeof c[0]=="object"?c[0].Plan:void 0,u=f&&typeof f=="object"?Number(f["Plan Rows"]):Number.NaN;return Number.isFinite(u)?u:is(t,e,n,r)}function Kw(t){if(t.type!=="query"||!t.where||!t.select)return false;let e=Hw(t.select);return e.size===0?false:Xd(t.where,e)}function Xd(t,e){for(let[n,r]of Object.entries(t)){if((n==="$or"||n==="$and")&&Array.isArray(r)){if(r.some(i=>i&&typeof i=="object"&&Xd(i,e)))return true;continue}if(!e.has(n)||!r||typeof r!="object")continue;let s=r;if(s.$is===null||s.$isNot===null)return true}return false}function Hw(t){let e=new Set;for(let n of t){if(typeof n=="string")continue;let[r,s]=Object.entries(n)[0]??[];r&&s&&typeof s=="object"&&"select"in s&&e.add(r);}return e}var zw=/[",\n\r ]/;function Yd(t){if(t==null)return "";let e;return typeof t=="string"?e=t:typeof t=="number"||typeof t=="boolean"?e=String(t):typeof t=="bigint"?e=t.toString():e=JSON.stringify(t),zw.test(e)?`"${e.replace(/"/g,'""')}"`:e}function so(t,e){let n=t.length>0?Object.keys(t[0]):[];if(n.length===0)return "";let r=[n.map(s=>Yd(s)).join(",")];for(let s of t)r.push(n.map(i=>Yd(s[i])).join(","));return r.join(`
|
|
81
|
+
`)}function Zd(t){return t.split(",").map(n=>n.split(";")[0].trim().toLowerCase()).includes("text/csv")}function np(t,e){if(t.type!=="upsert"&&t.type!=="put")return {ast:t};if(t.type==="put"){if(t.limit!==void 0||t.offset!==void 0)return O(400,"PGRST114","limit/offset querystring parameters are not allowed for PUT",null,null);let r=ep(t,e),s=Gw(t.where,r);if(!s)return O(405,"PGRST105","Filters must include all and only primary key columns with 'eq' operators",null,null);if(Array.isArray(t.values)&&t.values.length===0)return {ast:t,emptyPayload:true};if(!Ol(t.values))return O(400,"PGRST102","Empty or invalid json",null,null);for(let i of r)if(!Qw(t.values[i],s[i]))return O(400,"PGRST115","Payload values do not match URL in primary key column(s)",null,null);return t.onConflict=r,t.ignoreDuplicates=false,{ast:t,preflight:{mode:"put",conflictColumns:r}}}let n=t.onConflict?.length?t.onConflict:ep(t,e);return n.length===0?(t.onConflict=void 0,{ast:t}):(t.onConflict=n,{ast:t,appliedResolution:t.ignoreDuplicates?"ignore-duplicates":"merge-duplicates",preflight:t.ignoreDuplicates?void 0:{mode:"merge-duplicates",conflictColumns:n}})}function rp(t,e){let n=t.$meta,r={"Content-Type":"application/json; charset=utf-8"},s=Al(n,e.appliedResolution),i=n?.count==="exact"||n?.count==="planned"||n?.count==="estimated"?"*/0":"*/*";return n?.return==="representation"?(r["Content-Range"]=i,r["Content-Length"]="2",s&&(r["Preference-Applied"]=s),new Response("[]",{status:Pt(t,"representation",e.appliedResolution,false),headers:r})):(r["Content-Range"]=i,s&&(r["Preference-Applied"]=s),new Response(null,{status:Pt(t,"no-return",e.appliedResolution,false),headers:r}))}function ep(t,e){if(!t.from)return [];let n=t.schema??"public",r=e.primary_keys.find(s=>s.table===t.from&&s.schema===n);return r?r.columns:e.primary_keys.find(s=>s.table===t.from)?.columns??[]}function Gw(t,e){if(!t||e.length===0)return null;let n=Object.keys(t);if(n.length!==e.length)return null;let r={};for(let s of n){if(s.startsWith("$")||!e.includes(s))return null;let i=Vw(t[s]);if(!i.ok)return null;r[s]=i.value;}return r}function Vw(t){if(!Ol(t))return {ok:false};let e=Object.keys(t);return e.length!==1||e[0]!=="$eq"?{ok:false}:{ok:true,value:t.$eq}}function Qw(t,e){return Object.is(t,e)?true:t!==null&&e!==null&&t!==void 0&&e!==void 0&&typeof t!="object"&&typeof e!="object"?String(t)===String(e):$t(t)===$t(e)}function Al(t,e){let n=[];return e&&n.push(`resolution=${e}`),t?.missing&&n.push(`missing=${t.missing}`),t?.return&&n.push(`return=${t.return}`),t?.count&&t.count!=="none"&&n.push(`count=${t.count}`),t?.tx&&n.push(`tx=${t.tx}`),n.length>0?n.join(", "):void 0}function Pt(t,e,n,r){switch(t.type){case "insert":return 201;case "upsert":return !n||n==="ignore-duplicates"?201:r===false?200:201;case "put":return e==="representation"?r?201:200:204;case "update":case "delete":return e==="representation"?200:204;default:return 200}}async function sp(t,e,n,r,s){if(e.type==="insert")return true;if(!s.preflight||!e.from)return;if(s.preflight.mode==="put")return !await tp(t,e.from,e.schema,e.where??{},n,r);let i=Array.isArray(e.values)?e.values:e.values?[e.values]:[];for(let o of i){if(!Ol(o))continue;let a=Xw(s.preflight.conflictColumns,o);if(!a||!await tp(t,e.from,e.schema,a,n,r))return true}return false}function Xw(t,e){let n={};for(let r of t){if(!(r in e))return;n[r]={$eq:e[r]};}return n}async function tp(t,e,n,r,s,i){return await is(t,{type:"query",from:e,schema:n,where:r},s,i)>0}function Ol(t){return t!==null&&typeof t=="object"&&!Array.isArray(t)}function op(t){return t?.count==="exact"||t?.count==="planned"||t?.count==="estimated"}function ip(t,e,n){return op(e)?`*/${n??0}`:t.type==="update"&&n!==0?Rn(0,n??1,void 0):"*/*"}function Yw(t,e,n,r){return e&&(t.type==="insert"||t.type==="upsert"||t.type==="delete")?r!==void 0?`*/${r}`:"*/*":Rn(n,1,r)}function ap(t){return "select"in t||"spread"in t||"join"in t}function lp(t,e){if(t){for(let n of t)if(typeof n!="string")for(let r of Object.values(n))ap(r)&&((r.limit===void 0||r.limit>e)&&(r.limit=e),lp(r.select,e));}}function Zw(t){if(!t)return false;for(let e of t)if(typeof e!="string")for(let[n,r]of Object.entries(e)){if(ap(r))return true;let s=r;if(s.path||s.cast||s.preCast||s.aggregate||(s.column??n)!==n)return true}return false}var eS={swagger:"2.0",info:{description:"",title:"standard public schema",version:"14.1"},basePath:"/",schemes:["https"],consumes:["application/json","application/vnd.pgrst.object+json;nulls=stripped","application/vnd.pgrst.object+json","text/csv"],produces:["application/json","application/vnd.pgrst.object+json;nulls=stripped","application/vnd.pgrst.object+json","text/csv"]},cp=t=>new Se().all("/:relation",async e=>{let{app:n}=e.var,r=n.connection;if(!n.config.api?.enabled)return e.notFound();let s=e.req.param("relation"),i=await r.introspect({useCache:true});if(r.config.introspection?.exclude_tables?.some(d=>qi(s,d,"sql")))return e.notFound();if(!(ss in e.req.raw)){let d=await Dd(e.req.header("Authorization"),{jwtSecret:n.config.auth?.jwt_secret,anonymousEnabled:n.config.api?.anonymous_enabled!==false});if(d.kind==="error")return d.response;d.payload&&(e.set("userId",d.payload.sub),e.set("sessionId",d.payload.session_id),e.set("jwt",d.payload));}let{dialect:a}=r,l=r.config.translation?.deparse?.schema,c=e.var.jwt,f={auth:{uid:e.var.userId??null,role:c?.role||"anon",jwt:c??null}},u;try{if(u=await Ti(e.req.raw,{basePath:"/rest/v1"}),u.schema){let x=new Set;for(let R of i.tables)R.schema&&x.add(R.schema);for(let R of i.views)R.schema&&x.add(R.schema);if(x.size>0&&x.add("public"),x.size>0&&!x.has(u.schema)){let R=[...x].sort().join(", ");return O(406,"PGRST106",`Invalid schema: ${u.schema}`,null,`Only the following schemas are exposed: ${R}`)}}if(u=await r.onPostgrestAST(u,f),t?.debug&&console.log(ze.default.dim("[POSTGREST:AST]"),u),n.config.api?.aggregates_enabled!==!0&&Va(u.select))return O(400,"PGRST123","Use of aggregate functions is not allowed",null,null);let d=e.req.header("Accept")??"application/json",p=n.config.api?.plan_enabled===!0;if(!Gd(d,p))return O(406,"PGRST107",`None of these media types are available: ${zd(d)}`,null,null);let y=Md(d),h=Zd(d),b=e.req.header("Prefer");if(b){let x=b.split(",").map(v=>v.trim()).filter(Boolean);if(x.find(v=>v.startsWith("handling="))==="handling=strict"){let v=x.filter(k=>!k.includes("="));if(v.length>0)return O(400,"PGRST122","Invalid preferences given with handling=strict",`Invalid preferences: ${v.join(", ")}`,null)}}if(r.dialect==="sqlite"&&u.from){let x=u.schema??"",R=i.tables.some(k=>k.name===u.from&&(k.schema??"")===x),v=i.views.some(k=>k.name===u.from&&(k.schema??"")===x);if(!R&&!v)throw new Zr(u.schema,u.from)}let m=u.$meta,w=u.type==="update"||u.type==="delete"||u.type==="insert"||u.type==="upsert"||u.type==="put",_={ast:u};if(w&&m?.return!=="representation"&&(u.select=void 0),(u.type==="put"||u.type==="upsert")&&(u.limit!==void 0||u.offset!==void 0))return O(400,"PGRST114","limit/offset querystring parameters are not allowed for PUT",null,null);if((u.type==="update"||u.type==="delete"||u.type==="insert")&&n.config.api?.limited_mutations_enabled!==!0&&(u.limit=void 0,u.offset=void 0),n.config.api?.pg_safe_update&&w){let x=u.where&&Object.keys(u.where).length>0;if(u.type==="update"&&!x)return O(400,"21000","UPDATE requires a WHERE clause",null,null);if(u.type==="delete"&&!x)return O(400,"21000","DELETE requires a WHERE clause",null,null)}if(w&&(u.type==="insert"||u.type==="update"||u.type==="upsert"||u.type==="put")){if((u.type==="update"||u.type==="insert"||u.type==="upsert"||u.type==="put")&&(u.values===void 0||u.values===null))return O(400,"PGRST102","Empty or invalid json",null,null);if(u.type==="update"&&u.values&&typeof u.values=="object"&&!Array.isArray(u.values)&&Object.keys(u.values).length===0){let x=m?.return==="representation"?200:204,R={"Content-Type":"application/json; charset=utf-8","Content-Range":"*/*"};if(m?.return==="representation"){let v=new TextEncoder().encode("[]");return R["Content-Length"]=String(v.byteLength),R["Preference-Applied"]="return=representation",new Response(v,{status:x,headers:R})}return new Response(null,{status:x,headers:R})}if(u.type==="put"&&Array.isArray(u.values)&&(u.values.length===0?_.emptyPayload=!0:u.values=u.values[0]),Array.isArray(u.values)){if(m?.cardinality==="one"&&(u.type==="insert"||u.type==="upsert")&&u.values.length>1)return O(406,"PGRST116","Cannot coerce the result to a single JSON object",`The result contains ${u.values.length} rows`,null);if(u.values.length>0&&u.values.some(x=>typeof x!="object"||x===null||Array.isArray(x)))return m?.columns?O(400,"22023","argument of jsonb_to_recordset must be an array of objects",null,null):O(400,"PGRST102","All object keys must match",null,null);if(!m?.columns&&u.values.length>1){let x=Object.keys(u.values[0]).sort().join(",");for(let R=1;R<u.values.length;R++)if(Object.keys(u.values[R]).sort().join(",")!==x)return O(400,"PGRST102","All object keys must match",null,null)}}if(m?.columns&&u.from){let x=i.columns.filter(v=>v.table===u.from).map(v=>v.name);for(let v of m.columns){if(v==="")return O(400,"PGRST100",'"failed to parse columns parameter ()" (line 1, column 1)',"unexpected end of input",null);if(!x.includes(v))return O(400,"PGRST204",`Could not find the '${v}' column of '${u.from}' in the schema cache`,null,null)}let R=new Set(m.columns);if(u.values)if(Array.isArray(u.values))u.values=u.values.map(v=>{let k={};for(let z of R)z in v&&(k[z]=v[z]);return k});else {let v={};for(let k of R)k in u.values&&(v[k]=u.values[k]);u.values=v;}}if(!m?.columns&&u.values&&u.from&&(u.type==="insert"||u.type==="update"||u.type==="upsert"||u.type==="put")){let x=i.columns.filter(R=>R.table===u.from).map(R=>R.name);if(x.length>0){let R=Array.isArray(u.values)?u.values.length>0?Object.keys(u.values[0]):[]:Object.keys(u.values);for(let v of R)if(!x.includes(v))return O(400,"PGRST204",`Could not find the '${v}' column of '${u.from}' in the schema cache`,null,null)}}if(u.values&&u.from&&(u.type==="insert"||u.type==="update"||u.type==="upsert"||u.type==="put")){let x=u.schema??"public",R=new Set(i.columns.filter(v=>v.table===u.from&&(v.schema||"public")===x&&v.is_generated===!0).map(v=>v.name));if(R.size>0){let v=Array.isArray(u.values)?u.values:[u.values];for(let k of v)if(!(!k||typeof k!="object")){for(let z of Object.keys(k))if(R.has(z))return O(400,"428C9",`cannot insert a non-DEFAULT value into column "${z}"`,`Column "${z}" is a generated column.`,null)}}}}let S=np(u,i);if(S instanceof Response)return S;if(_=S,u=_.ast,w&&((u.type==="insert"||u.type==="upsert")&&Array.isArray(u.values)&&u.values.length===0||_.emptyPayload))return m?.cardinality==="one"?O(406,"PGRST116","Cannot coerce the result to a single JSON object","The result contains 0 rows",null):rp(u,_);let E=e.req.method.toUpperCase(),C=e.req.header("Range");if(C&&(E==="GET"||E==="HEAD")){let x=C.match(/^(\d+)-(\d*)$/);if(x){let R=parseInt(x[1],10);if(x[2]!==""){let v=parseInt(x[2],10);if(R>v)return O(416,"PGRST103","Requested range not satisfiable","The lower boundary must be lower than or equal to the upper boundary in the Range header.",null);u.offset=R,u.limit=v-R+1;}else u.offset=R;}}if(u.limit!==void 0&&u.limit<0||u.limit===0&&u.offset!==void 0&&u.offset>0)return O(416,"PGRST103","Requested range not satisfiable","Limit should be greater than or equal to zero.",null);if(u.offset!==void 0&&u.offset<0&&(u.offset=0),!w){let x=n.config.api?.max_rows;x!==void 0&&x>0&&((u.limit===void 0||u.limit>x)&&(u.limit=x),lp(u.select,x));}return await r.withContext(f,async x=>{let R=e.req.header("Accept")??"application/json";if(p&&Ud(R)){let W=me(u,a,{db:x,introspection:i,schema:l}).compile();return t?.debug&&console.info(ze.default.dim(`[POSTGREST:PLAN] ${W.sql}
|
|
82
|
+
- ${JSON.stringify([...W.parameters])}`)),Vd(R,W)}let v=w?await sp(x,u,a,i,_):void 0,k=Al(m,_.appliedResolution);if(w&&m?.return==="minimal"){let ae={...u,select:void 0},W=me(ae,a,{db:x,introspection:i,schema:l}),{sql:X,parameters:nt}=W.compile();t?.debug&&console.info(ze.default.dim(`[POSTGREST:SQL] ${X}
|
|
83
|
+
- ${JSON.stringify([...nt])}`));let Z=await W.execute(),ke=Array.isArray(Z)&&Z.length>0&&Z[0]&&typeof Z[0]=="object"&&("numUpdatedRows"in Z[0]||"numInsertedOrUpdatedRows"in Z[0]||"numDeletedRows"in Z[0])?Z[0]:void 0,qt=ke===void 0?void 0:Number(ke.numUpdatedRows??ke.numInsertedOrUpdatedRows??ke.numDeletedRows??0),De=Pt(u,"no-return",_.appliedResolution,v),je={"Content-Range":ip(u,m,qt)};return k&&(je["Preference-Applied"]=k),new Response(null,{status:De,headers:je})}if(w&&m?.return==="headers-only"){let W=i.primary_keys.find(De=>De.table===u.from)?.columns??[],X={...u,select:W.length>0?W:void 0},nt=me(X,a,{db:x,introspection:i,schema:l});if(t?.debug){let{sql:De,parameters:je}=nt.compile();console.info(ze.default.dim(`[POSTGREST:SQL] ${De}
|
|
84
|
+
- ${JSON.stringify([...je])}`));}let Z=await nt.execute(),ke=Pt(u,"no-return",_.appliedResolution,v),qt={"Content-Range":"*/*"};if(k&&(qt["Preference-Applied"]=k),W.length>0&&Array.isArray(Z)&&Z.length>0){let De=Z[0],je=W.map(yt=>`${yt}=eq.${De[yt]}`).join("&");qt.Location=`/${u.from}?${je}`;}return new Response(null,{status:ke,headers:qt})}if(w&&(u.type==="update"||u.type==="delete")&&(u.limit!==void 0||u.offset!==void 0)){let ae={...u,select:void 0},W=me(ae,a,{db:x,introspection:i,schema:l});if(t?.debug){let{sql:yt,parameters:Wt}=W.compile();console.info(ze.default.dim(`[POSTGREST:SQL:LTD] ${yt}
|
|
85
|
+
- ${JSON.stringify([...Wt])}`));}if(await W.execute(),m?.return==="representation"){let yt={...u,type:"query",values:void 0,limit:void 0,offset:void 0},Wt=me(yt,a,{db:x,introspection:i,schema:l});if(t?.debug){let{sql:it,parameters:Zs}=Wt.compile();console.info(ze.default.dim(`[POSTGREST:SQL:LTD-SEL] ${it}
|
|
86
|
+
- ${JSON.stringify([...Zs])}`));}let qe=await Wt.execute(),_e=Array.isArray(qe)?qe:[];_e=_e.map(it=>r.deserializeRow(it)),_e=no(_e,u,l,"public");let rt=_e.length,We=[];m.return==="representation"&&We.push("return=representation"),m.count&&We.push(`count=${m.count}`),m.tx&&We.push(`tx=${m.tx}`);let Je=u.type==="delete"?"*/*":rt>0?Rn(0,rt,void 0):"*/*",st=y?Cn(_e):_e,Yo=h?so(st):$t(st),_r=new TextEncoder().encode(Yo),bt={"Content-Type":h?"text/csv; charset=utf-8":y?"application/vnd.pgrst.array+json;nulls=stripped; charset=utf-8":"application/json; charset=utf-8","Content-Range":Je,"Content-Length":String(_r.byteLength)};return We.length>0&&(bt["Preference-Applied"]=We.join(", ")),new Response(_r,{status:200,headers:bt})}let X={...u,type:"query",select:[{__count:{aggregate:"count"}}],values:void 0,order:void 0,limit:void 0,offset:void 0},Z=await me(X,a,{db:x,introspection:i,schema:l}).execute(),ke=Number((Array.isArray(Z)?Z[0]:Z)?.__count??0),De={"Content-Range":ke>0?Rn(0,ke,void 0):"*/*"},je=[];return m?.count&&je.push(`count=${m.count}`),m?.tx&&je.push(`tx=${m.tx}`),je.length>0&&(De["Preference-Applied"]=je.join(", ")),new Response(null,{status:204,headers:De})}if(w&&m?.return==="representation"&&Zw(u.select)){let W=i.primary_keys.find(qe=>qe.table===u.from)?.columns??[],X=[];if(u.type==="delete"){let qe={...u,type:"query",values:void 0},_e=me(qe,a,{db:x,introspection:i,schema:l});if(t?.debug){let{sql:Je,parameters:st}=_e.compile();console.info(ze.default.dim(`[POSTGREST:SQL:EMB-PRE] ${Je}
|
|
87
|
+
- ${JSON.stringify([...st])}`));}X=await _e.execute();let rt={...u,select:void 0},We=me(rt,a,{db:x,introspection:i,schema:l});if(t?.debug){let{sql:Je,parameters:st}=We.compile();console.info(ze.default.dim(`[POSTGREST:SQL:EMB-DEL] ${Je}
|
|
88
|
+
- ${JSON.stringify([...st])}`));}await We.execute();}else {if(W.length===0)return O(500,"PGRSTXXX","Cannot return embedded data on a table without a primary key",null,null);let qe={...u,select:W},_e=me(qe,a,{db:x,introspection:i,schema:l});if(t?.debug){let{sql:Je,parameters:st}=_e.compile();console.info(ze.default.dim(`[POSTGREST:SQL:EMB-MUT] ${Je}
|
|
89
|
+
- ${JSON.stringify([...st])}`));}let rt=await _e.execute(),We=Array.isArray(rt)?rt:[];if(We.length>0){let Je;if(W.length===1){let bt=W[0];Je={[bt]:{$in:We.map(it=>it[bt])}};}else Je={$or:We.map(bt=>{let it={};for(let Zs of W)it[Zs]={$eq:bt[Zs]};return it})};let st=u.where?{$and:[u.where,Je]}:Je,Yo={...u,type:"query",values:void 0,where:st},_r=me(Yo,a,{db:x,introspection:i,schema:l});if(t?.debug){let{sql:bt,parameters:it}=_r.compile();console.info(ze.default.dim(`[POSTGREST:SQL:EMB-SEL] ${bt}
|
|
90
|
+
- ${JSON.stringify([...it])}`));}X=await _r.execute();}}X=X.map(qe=>r.deserializeRow(qe)),X=no(X,u,l,"public"),u.order&&u.order.length>0&&(X=Tl(X,u.order));let nt=Pt(u,"representation",_.appliedResolution,v),Z=X.length,ke=["return=representation"];m?.count&&ke.push(`count=${m.count}`),m?.tx&&ke.push(`tx=${m.tx}`);let qt=u.type==="delete"||u.type==="insert"||u.type==="upsert"?"*/*":Z>0?Rn(0,Z,void 0):"*/*",De=y?Cn(X):X,je=h?so(De):$t(De),yt=new TextEncoder().encode(je),Wt={"Content-Type":h?"text/csv; charset=utf-8":y?"application/vnd.pgrst.array+json;nulls=stripped; charset=utf-8":"application/json; charset=utf-8","Content-Range":qt,"Content-Length":String(yt.byteLength)};if(ke.length>0&&(Wt["Preference-Applied"]=ke.join(", ")),(u.type==="insert"||u.type==="upsert")&&W.length>0&&X.length>0){let qe=X[0],_e=W.map(rt=>`${rt}=eq.${qe[rt]}`).join("&");Wt.Location=`/${u.from}?${_e}`;}return new Response(yt,{status:nt,headers:Wt})}let ue=me(u,a,{db:x,introspection:i,schema:l}),{sql:Xe,parameters:Qs}=ue.compile();t?.debug&&console.info(ze.default.dim(`[POSTGREST:SQL] ${Xe}
|
|
91
|
+
- ${JSON.stringify([...Qs])}`));let gt=await ue.execute(),re,ru=!1,Sr=0;if(w&&Array.isArray(gt)&>.length>0&>[0]&&typeof gt[0]=="object"&&("numUpdatedRows"in gt[0]||"numInsertedOrUpdatedRows"in gt[0]||"numDeletedRows"in gt[0])){ru=!0;let ae=gt[0];Sr=Number(ae.numUpdatedRows??ae.numInsertedOrUpdatedRows??ae.numDeletedRows??0),re=[];}else re=gt;let Vo=Array.isArray(re);Vo&&(re=re.map(ae=>r.deserializeRow(ae)),re=no(re,u,l,"public"),re=Fd(re,u.select),re=qd(re,u.select),re=Wd(re,u.select),re=Jd(re,u.select),r.dialect==="sqlite"&&(re=Bd(re,u.select))),w&&Vo&&u.order&&u.order.length>0&&(re=Tl(re,u.order));let Qo=Vo?re:[],Bt=Qo.length,an=u.offset??0;if(w&&ru){if(m?.cardinality==="one"){if(Sr===0)return O(406,"PGRST116","Cannot coerce the result to a single JSON object","The result contains 0 rows",null);if(Sr>1)return O(406,"PGRST116","Cannot coerce the result to a single JSON object",`The result contains ${Sr} rows`,null)}let ae=Pt(u,"no-return",_.appliedResolution,v),W={"Content-Type":"application/json; charset=utf-8","Content-Range":ip(u,m,Sr)};return k&&(W["Preference-Applied"]=k),new Response(null,{status:ae,headers:W})}let we;if(op(m)&&(w?we=Bt:we=await Qd(x,u,a,i)),m?.cardinality==="one"){if(Bt===0)return O(406,"PGRST116","Cannot coerce the result to a single JSON object","The result contains 0 rows",null);if(Bt>1)return O(406,"PGRST116","Cannot coerce the result to a single JSON object",`The result contains ${Bt} rows`,null);let ae=200;w&&(ae=Pt(u,"representation",_.appliedResolution,v));let W=y?Cn(Qo[0]):Qo[0],X=$t(W),nt=new TextEncoder().encode(X),Z={"Content-Type":y?"application/vnd.pgrst.object+json;nulls=stripped; charset=utf-8":"application/vnd.pgrst.object+json; charset=utf-8","Content-Range":Yw(u,w,an,we),"Content-Length":String(nt.byteLength)};return k&&(Z["Preference-Applied"]=k),m?.head?new Response(null,{status:ae,headers:Z}):new Response(nt,{status:ae,headers:Z})}if(we!==void 0&&an>0&&Bt===0&&an>=we){let ae=JSON.stringify({code:"PGRST103",details:`An offset of ${an} was requested, but there are only ${we} rows.`,hint:null,message:"Requested range not satisfiable"}),W=new TextEncoder().encode(ae),X={"Content-Type":"application/json; charset=utf-8","Content-Range":`*/${we}`,"Content-Length":String(W.byteLength)};return k&&(X["Preference-Applied"]=k),new Response(W,{status:416,headers:X})}let Er;w&&(u.type==="insert"||u.type==="upsert"||u.type==="delete")?Er=we!==void 0?`*/${we}`:"*/*":w&&m?.return!=="representation"?Er=we!==void 0?`*/${we}`:"*/*":Bt>0?Er=Rn(an,Bt,we):Er=we!==void 0?`*/${we}`:"*/*";let Xs=200;w?Xs=Pt(u,"representation",_.appliedResolution,v):we!==void 0&&(an+Bt<we||an>0)&&(Xs=206);let Ys=y?Cn(re):re,Ph=h?so(Array.isArray(Ys)?Ys:[Ys]):$t(Ys),su=new TextEncoder().encode(Ph),Xo={"Content-Type":h?"text/csv; charset=utf-8":y?"application/vnd.pgrst.array+json;nulls=stripped; charset=utf-8":"application/json; charset=utf-8","Content-Range":Er,"Content-Length":String(su.byteLength)};return k&&(Xo["Preference-Applied"]=k),m?.head?new Response(null,{status:Xs,headers:Xo}):new Response(su,{status:Xs,headers:Xo})},{forceRollback:t?.forceRollback===!0})}catch(d){if(d instanceof pe){let y=`"${d.message}" (line 1, column ${d.position})`;return O(400,"PGRST100",y,d.details,null)}if(d instanceof Me)return O(400,"PGRST100",d.message,d.details,null);if(d instanceof Qt)return O(400,"PGRST100",d.message,d.details,null);if(d instanceof Jn)return O(404,"PGRST125",d.message,d.details,null);if(d instanceof Ae)return O(d.httpStatus,d.code,d.message,d.details,d.hint);if(d instanceof Kn)return O(400,"PGRST102",d.message,null,null);if(d instanceof Error&&d.message.startsWith("Invalid JSON body"))return O(400,"PGRST102","Empty or invalid json",null,null);if(d instanceof vt)return O(400,"PGRST100",d.message,d.message,null);if(d instanceof Sn)return O(400,"23514",d.message,`check constraint "${d.constraint}" violated`,null);if(d instanceof zn){let h=Yt(f,"auth.role","anon")==="anon"?401:403;return Ze({status:h,code:"PGRST301",message:d.message})}let p=r.normalizeDbError(d);if(console.error(p),p instanceof Zr){let y=[...i.tables.map(m=>m.name),...i.views.map(m=>m.name)],h=pd(p.relation,y),b=p.schema||"public";return Ze({status:404,code:"PGRST205",message:p.message,hint:h?`Perhaps you meant the table '${b}.${h}'`:null})}if(p?.code==="42501"){let h=Yt(f,"auth.role","anon")==="anon"?401:403;return Ze({status:h,code:"PGRST301",message:p.message})}if(p?.code==="42P01")return O(404,"PGRST205","Could not find the relation in the schema cache",p.message,null);if(p?.code==="23505"||p?.code==="23503")return O(409,p.code,p.message,p.detail??null,null);if(typeof p?.code=="string"){let y=p.code.slice(0,2);if(p.code==="42883")return O(404,p.code,p.message,p.detail??null,p.hint??null);if(y==="42"||y==="22"||y==="21"||p.code==="23502"){let h=p.message,b=u?.from;return p.code==="42703"&&b&&(h=h.replace(/^column "([^"]+)" does not exist$/,(m,w)=>`column ${b}.${w} does not exist`)),O(400,p.code,h,p.detail??null,p.hint??null)}if(y==="55")return O(500,p.code,p.message,p.detail??null,p.hint??null)}return p?.message?.includes("Unknown operator")?O(400,"PGRST100",p.message,null,null):p instanceof Error&&(p.message.includes("Expected identifier")||p.message.includes("Invalid filter")||p.message.includes("Unexpected input")||p.message.includes("Unsupported operator")||p.message.includes("failed to parse filter")||p.message.includes("failed to parse logic tree")||/^Expected .* at position \d+$/.test(p.message)||p.message.startsWith('Expected "(" for spread embed'))?O(400,"PGRST100",p.message,p.message,null):O(500,"SUP",String(p),null,null)}}).use(async(e,n)=>{if(e.req.method==="GET"&&e.req.path.endsWith("/"))return e.json(eS);await n();}).all("*",e=>O(404,"PGRST125","Invalid path specified in request URL",null,null));var Zn=class{maxSizeBytes;now;entries=new Map;sizeBytes=0;constructor(e={}){this.maxSizeBytes=e.maxSizeBytes??1024*1024,this.now=e.now??Date.now;}async get(e){let n=this.entries.get(e);if(n){if(this.isExpired(n)){this.deleteEntry(e,n);return}return this.entries.delete(e),this.entries.set(e,n),n.value}}async set(e,n,r){let s=this.entries.get(e);s&&this.deleteEntry(e,s);let i={value:n,size:up(e)+up(n),expiresAt:r?.ttl&&r.ttl>0?this.now()+r.ttl*1e3:void 0};this.entries.set(e,i),this.sizeBytes+=i.size,this.evictToSize();}async delete(e){let n=this.entries.get(e);n&&this.deleteEntry(e,n);}isExpired(e){return typeof e.expiresAt=="number"&&e.expiresAt<=this.now()}evictToSize(){for(;this.sizeBytes>this.maxSizeBytes;){let e=this.entries.keys().next().value;if(typeof e!="string")break;let n=this.entries.get(e);if(!n)break;this.deleteEntry(e,n);}}deleteEntry(e,n){this.entries.delete(e),this.sizeBytes-=n.size;}};function up(t){return new TextEncoder().encode(t).byteLength}var io=class{constructor(e){this.options=e;}async get(e){return await this.options.namespace.get(e)??void 0}async set(e,n,r){await this.options.namespace.put(e,n,{...r?.ttl&&r.ttl>0?{expirationTtl:r.ttl}:{}});}async delete(e){await this.options.namespace.delete(e);}};var oo=class{constructor(e){this.options=e;}async get(e){return await this.options.client.get(e)??void 0}async set(e,n,r){if(r?.ttl&&r.ttl>0){await this.options.client.set(e,n,"EX",r.ttl);return}await this.options.client.set(e,n);}async delete(e){if(this.options.client.del){await this.options.client.del(e);return}if(this.options.client.delete){await this.options.client.delete(e);return}throw new Error("RedisCacheDriver client must provide del() or delete()")}};var ao=class{constructor(e){this.options=e;this.endpoint=e.endpoint??"https://api.resend.com/emails",this.fetchFn=e.fetch??fetch;}endpoint;fetchFn;async send(e){let n=await this.fetchFn(this.endpoint,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${this.options.apiKey}`},body:JSON.stringify({from:this.options.from,to:e.to,subject:e.subject,...e.text?{text:e.text}:{},...e.html?{html:e.html}:{}})});if(!n.ok)throw new Error(`Resend email failed (${n.status}): ${await n.text()}`)}};var co=class{constructor(e){this.options=e;this.endpoint=`https://email.${e.region}.amazonaws.com/v2/email/outbound-emails`,this.client=e.client;}endpoint;client;async send(e){let n=await this.getClient(),r={FromEmailAddress:this.options.from,Destination:{ToAddresses:[e.to]},Content:{Simple:{Subject:{Data:e.subject,Charset:"UTF-8"},Body:{...e.text?{Text:{Data:e.text,Charset:"UTF-8"}}:{},...e.html?{Html:{Data:e.html,Charset:"UTF-8"}}:{}}}}},s=await n.fetch(this.endpoint,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify(r)});if(!s.ok)throw new Error(`AWS SES email failed (${s.status}): ${await s.text()}`)}async getClient(){if(this.client)return this.client;let{AwsClient:e}=await Promise.resolve().then(()=>(hp(),mp));return this.client=new e({accessKeyId:this.options.accessKeyId,secretAccessKey:this.options.secretAccessKey,service:"ses",region:this.options.region}),this.client}};var uo=class{constructor(e){this.options=e;this.sendmailPath=e.sendmailPath??"/usr/sbin/sendmail";}sendmailPath;async send(e){let{spawn:n}=await import('node:child_process').catch(()=>{throw new Error("SendmailEmailDriver requires a Node-compatible runtime")}),r=Il(this.options.from,e);await new Promise((s,i)=>{let o=n(this.sendmailPath,["-t","-i"],{stdio:["pipe","ignore","pipe"]}),a=[];o.on("error",l=>{i(new Error(`SendmailEmailDriver failed to start ${this.sendmailPath}: ${l.message}`));}),o.stderr?.on("data",l=>a.push(Buffer.from(l))),o.on("close",l=>{if(l===0){s();return}i(new Error(`SendmailEmailDriver exited with code ${l}: ${Buffer.concat(a).toString("utf8")}`));}),o.stdin.end(r);});}};function Il(t,e){let n=e.html?"text/html; charset=UTF-8":"text/plain; charset=UTF-8";return [`From: ${t}`,`To: ${e.to}`,`Subject: ${e.subject}`,"MIME-Version: 1.0",`Content-Type: ${n}`,"",e.html??e.text??""].join(`
|
|
92
|
+
`)}var ls=class{messages=new Map;maxKeepCount;order=[];constructor(e={}){this.maxKeepCount=e.maxKeepCount??100;}async send(e){if(this.maxKeepCount<=0)return;let n=e.to.toLowerCase(),r={...e,sentAt:new Date().toISOString()},s=this.messages.get(n)??[];s.push(r),this.messages.set(n,s),this.order.push({key:n,message:r}),this.trim();}clear(){this.messages.clear(),this.order.length=0;}trim(){for(;this.order.length>this.maxKeepCount;){let e=this.order.shift();if(!e)return;let n=this.messages.get(e.key);if(!n)continue;let r=n.indexOf(e.message);r>=0&&n.splice(r,1),n.length===0&&this.messages.delete(e.key);}}},er=class extends ls{silent;logger;constructor(e={}){super({maxKeepCount:0}),this.silent=e.silent??false,this.logger=e.logger??console;}async send(e){await super.send(e),this.silent||this.logger.info(["[@supabase/lite] Email driver noop send",`To: ${e.to}`,`Subject: ${e.subject}`,e.text?`Text: ${e.text}`:void 0,e.html?`HTML: ${e.html}`:void 0].filter(Boolean).join(`
|
|
93
|
+
`));}};var cs=class{silent;logger;constructor(e={}){this.silent=e.silent??false,this.logger=e.logger??console;}async send(e){this.silent||this.logger.info(["[@supabase/lite] SMS driver noop send",`To: ${e.to}`,`Body: ${e.body}`].join(`
|
|
94
|
+
`));}};function gp(t={}){return {email:t.email??new er,sms:t.sms??new cs,cache:t.cache??new Zn}}var Dl=new Map,us=class{constructor(e){this.driver=e;}async sendConfirmation(e,n,r,s){await this.send(sS(e,n,r,s));}async sendRecovery(e,n,r,s){await this.send(iS(e,n,r,s));}async sendMagicLink(e,n,r,s){await this.send(oS(e,n,r,s));}async sendEmailChange(e,n,r,s){await this.send(aS(e,n,r,s));}async sendReauthentication(e,n,r){await this.send(lS(e,n,r));}async send(e){await this.driver.send({to:e.to,subject:e.subject,text:e.body.text,html:e.body.html});}};function sS(t,e,n,r){return {to:t,subject:"Confirm Your Signup",body:{text:`Your confirmation code is: ${n}`,html:`<p>Your confirmation code is: <strong>${n}</strong></p><p><a href="http://localhost:3000/verify?token_hash=${e}&type=signup">Confirm</a></p>`},otp:n,tokenHash:e,meta:{...r,emailActionType:r?.emailActionType??"signup"}}}function iS(t,e,n,r){return {to:t,subject:"Reset Your Password",body:{text:`Your recovery code is: ${n}`,html:`<p>Your recovery code is: <strong>${n}</strong></p><p><a href="http://localhost:3000/verify?token_hash=${e}&type=recovery">Reset</a></p>`},otp:n,tokenHash:e,meta:{...r,emailActionType:r?.emailActionType??"recovery"}}}function oS(t,e,n,r){return {to:t,subject:"Your Magic Link",body:{text:`Your login code is: ${n}`,html:`<p>Your login code is: <strong>${n}</strong></p><p><a href="http://localhost:3000/verify?token_hash=${e}&type=magiclink">Login</a></p>`},otp:n,tokenHash:e,meta:{...r,emailActionType:r?.emailActionType??"magiclink"}}}function aS(t,e,n,r){return {to:t,subject:"Confirm Email Change",body:{text:`Your email change code is: ${n}`,html:`<p>Your email change code is: <strong>${n}</strong></p><p><a href="http://localhost:3000/verify?token_hash=${e}&type=email_change">Confirm</a></p>`},otp:n,tokenHash:e,meta:{...r,emailActionType:r?.emailActionType??"email_change"}}}function lS(t,e,n){return {to:t,subject:"Reauthentication",body:{text:`Your reauthentication code is: ${e}`,html:`<p>Your reauthentication code is: <strong>${e}</strong></p>`},otp:e,tokenHash:n?.tokenHash,meta:{...n,emailActionType:n?.emailActionType??"reauthentication"}}}var M=class extends Error{constructor(n,r,s,i,o){super(s);this.status=n;this.code=r;this.details=i;this.headers=o;this.name="AuthError";}toJSON(){return {code:this.status,error_code:this.code,msg:this.message,...this.details}}},ft=()=>new M(400,"invalid_credentials","Invalid login credentials"),yp=()=>new M(400,"email_not_confirmed","Email not confirmed"),bp=(t,e=[],n=["length"])=>{let r=[];return n.includes("length")&&r.push(`Password should be at least ${t} characters.`),n.includes("characters")&&r.push(`Password should contain at least one character of each: ${e.join(", ")}.`),new M(422,"weak_password",r.join(" "),{weak_password:{reasons:n}})},wp=(t="Access token is required")=>new M(401,"no_authorization",t),tr=()=>new M(401,"no_authorization","This endpoint requires a valid Bearer token"),fs=t=>new M(403,"bad_jwt",t),jl=()=>fs("invalid JWT: unable to parse or verify signature, token is malformed: token contains an invalid number of segments"),Ll=t=>fs(`invalid JWT: unable to parse or verify signature, token is malformed: could not JSON decode header: ${t}`),Sp=()=>fs("invalid JWT: unable to parse or verify signature, token signature is invalid: signature is invalid"),Ep=()=>fs("invalid JWT: unable to parse or verify signature, token has invalid claims: token is expired"),Ul=()=>fs("invalid claim: missing sub claim"),Ml=()=>new M(400,"bad_jwt","invalid claim: sub claim must be a UUID");var _p=()=>new M(403,"user_not_found","User from sub claim in JWT does not exist"),xp=()=>new M(403,"session_not_found","Session from session_id claim in JWT does not exist"),vp=()=>new M(422,"user_already_exists","User already registered"),Cp=()=>new M(422,"email_exists","A user with this email address has already been registered"),Fl=()=>new M(422,"signup_disabled","Signups not allowed for this instance"),Rp=()=>new M(400,"email_provider_disabled","Email signups are disabled"),Tp=()=>new M(422,"otp_disabled","Signups not allowed for otp"),kp=()=>new M(422,"same_password","New password should be different from the old password."),nr=()=>new M(403,"otp_expired","Email link is invalid or has expired"),ne=(t,e=422)=>new M(e,"validation_failed",t);var ds=t=>new M(400,"bad_json",t),Bl=()=>new M(400,"validation_failed","Refresh token is not valid"),rr=()=>new M(400,"refresh_token_not_found","Invalid Refresh Token: Refresh Token Not Found"),fo=(t,e)=>new M(400,"refresh_token_already_used","Invalid Refresh Token: Already Used",void 0,{...t?{"Sb-Auth-Session-Id":t}:{},...e?{"Sb-Auth-User-Id":e}:{}}),Ap=()=>new M(401,"session_not_found","Invalid Refresh Token: Already Used"),ql=(t,e,n)=>new M(400,"session_expired",t==="inactivity"?"Invalid Refresh Token: Session Expired (Inactivity)":"Invalid Refresh Token: Session Expired",void 0,{...e?{"Sb-Auth-Session-Id":e}:{},...n?{"Sb-Auth-User-Id":n}:{}}),Op=()=>new M(422,"anonymous_provider_disabled","Anonymous sign-ins are disabled"),$p=()=>new M(400,"invalid_credentials","unsupported_grant_type"),po=()=>new M(429,"over_email_send_rate_limit","For security purposes, you can only request this after 59 seconds.");async function Jl(t,e,n){let r=new TextEncoder().encode(e),s=Math.floor(Date.now()/1e3);return new vn({...t,iat:s}).setProtectedHeader({alg:"HS256",typ:"JWT"}).setIssuedAt(s).setExpirationTime(s+n).sign(r)}async function Pp(t,e){let n=t.split(".");if(n.length!==3||n.some(i=>i===""))throw jl();let r=cS(n[0]);if(r)throw r;let s=new TextEncoder().encode(e);try{let{payload:i}=await xn(t,s,{algorithms:["HS256"]});return i}catch(i){throw i instanceof Ot.JWTExpired?Ep():i instanceof Ot.JWSSignatureVerificationFailed?Sp():i instanceof Ot.JWSInvalid||i instanceof Ot.JWTInvalid?jl():i}}function cS(t){let e=uS(t);if(!e)return Ll("unexpected end of JSON input");let n=fS(e);try{return JSON.parse(new TextDecoder("utf-8").decode(e)),null}catch{return Ll(Kl(n))}}function uS(t){try{let e=t.replace(/-/g,"+").replace(/_/g,"/").padEnd(t.length+(4-t.length%4)%4,"="),n=atob(e),r=new Uint8Array(n.length);for(let s=0;s<n.length;s++)r[s]=n.charCodeAt(s);return r}catch{return null}}function fS(t){let e="";for(let n of t)e+=String.fromCharCode(n);return e}var dS={n:"null",t:"true",f:"false"};function Kl(t){let e=0;for(;e<t.length;){let i=t.charCodeAt(e);if(i===32||i===9||i===10||i===13)e++;else break}let n=t.slice(e);if(!n)return "unexpected end of JSON input";let r=n[0],s=dS[r];if(s){for(let i=1;i<s.length;i++){if(i>=n.length)return "unexpected end of JSON input";if(n[i]!==s[i])return `invalid character ${Wl(n[i])} in literal ${s} (expecting '${s[i]}')`}return `invalid character ${Wl(n[s.length]??" ")} after top-level value`}return r==="{"||r==="["||r==='"'||r==="-"||r>="0"&&r<="9"?"":`invalid character ${Wl(r)} looking for beginning of value`}function Wl(t){let e=t.codePointAt(0)??0;return e>=32&&e<127?`'${t}'`:`'\\u${e.toString(16).padStart(4,"0")}'`}async function ps(t){return Np.hash(t,10)}async function Hl(t,e){return Np.compare(t,e)}function Ip(t,e=6,n=[]){let r=[];return t.length<e&&r.push("length"),n.length>0&&n.some(s=>!pS(t,s))&&r.push("characters"),r}function pS(t,e){for(let n of t)if(e.includes(n))return true;return false}function Nt(t=6){let e=crypto.getRandomValues(new Uint8Array(t)),n="";for(let r=0;r<t;r++)n+=(e[r]%10).toString();return n}function et(){let t=crypto.getRandomValues(new Uint8Array(32));return Array.from(t).map(e=>e.toString(16).padStart(2,"0")).join("")}function zl(){return v7()}function Ge(){return v7()}function mo(t){if(!t.jwt_secret)throw new Error('[auth] is enabled but `auth.jwt_secret` is empty. Add `jwt_secret = "<secret>"` under [auth] in your config.toml.')}var ms=class{constructor(e,n,r){this.repo=e;this.config=n;this.mailer=r;mo(n),this.jwtExpiry=n.jwt_expiry??3600,this.minPasswordLength=n.minimum_password_length??6,this.passwordRequiredCharacters=n.password_required_characters??hS(n.password_requirements),this.sessionTimeboxSeconds=jp(n.sessions?.timebox),this.sessionInactivitySeconds=jp(n.sessions?.inactivity_timeout);}jwtExpiry;minPasswordLength;passwordRequiredCharacters;sessionTimeboxSeconds;sessionInactivitySeconds;async signUp(e,n,r){if(this.config.enable_signup===false)throw Fl();if(!e)throw Op();if(this.config.email?.enable_signup===false)throw Rp();if(n==null||n===void 0||n==="")throw ne("Signup requires a valid password",400);if(!sr(e))throw ne("Unable to validate email address: invalid format",400);if(n.length>72)throw ne("Password cannot be longer than 72 characters",400);this.assertPasswordStrong(n);let i=!(this.config.email?.enable_confirmations??this.config.enable_confirmations??false);e=e.toLowerCase();let o=await this.repo.findUserByEmail(e);if(o)throw i?(await this.createAuditLog(o.id,e,"user_repeated_signup","user"),vp()):po();let a=Ge(),l=await ps(n),c=new Date().toISOString(),f=null,u=null,d=null;i||(f=Nt(),u=et(),d=c);let p={...r??{},email:e,email_verified:i,phone_verified:false,sub:a},y={...r??{},email:e,email_verified:false,phone_verified:false,sub:a},h=await this.repo.createUser({id:a,email:e,encrypted_password:l,confirmed_at:i?c:null,raw_user_meta_data:p,raw_app_meta_data:{provider:"email",providers:["email"]},confirmation_token:u,confirmation_sent_at:d});await this.repo.createIdentity({id:Ge(),provider:"email",provider_id:a,user_id:a,identity_data:y}),!i&&f&&u&&await this.mailer.sendConfirmation(e,u,f,{userId:a,redirectTo:this.config.site_url});let b=await this.repo.findIdentitiesByUserId(a),m=this.repo.parseUserJson(h),w=this.mapUserToResponse(m,b,"signup");if(i){let _=await this.createSessionForUser(m,b);return await this.createAuditLog(a,e,"user_signedup","team"),{user:w,session:_}}return await this.createAuditLog(a,e,"user_confirmation_requested","user"),{user:w}}async signInWithPassword(e,n){if(!e)throw ne("missing email or phone",400);if(!n)throw ft();let r=await this.repo.findUserByEmail(e.toLowerCase());if(!r||!r.encrypted_password)throw ft();let s=this.repo.parseUserJson(r);if(!s.confirmed_at)throw yp();if(!await Hl(n,s.encrypted_password))throw ft();let o=await this.repo.findIdentitiesByUserId(r.id);return this.createSessionForUser(s,o,"user")}async refreshSession(e){if(!e)throw Bl();let n=await this.repo.findRefreshToken(e);if(!n)throw gS(e)?rr():Bl();if(Lp(n))return this.refreshWithRevokedToken(n);let r=await this.repo.findUserById(n.user_id);if(!r)throw rr();let s=null;if(n.session_id){if(s=await this.repo.findSessionById(n.session_id),!s)throw rr();this.assertSessionRefreshable(s);}let i=Up(s?.updated_at,s?.refreshed_at,r.updated_at);await this.repo.revokeRefreshToken(n.id);let o=zl(),a=n.session_id??Ge();return n.session_id?await this.repo.updateSessionRefreshedAt(n.session_id,i):await this.repo.createSession({id:a,user_id:r.id}),await this.repo.createRefreshToken({token:o,user_id:r.id,session_id:a,parent:n.token}),await this.createAuditLog(r.id,r.email??"","token_refreshed","token",false),await this.createAuditLog(r.id,r.email??"","token_revoked","token",false),this.createRefreshResponse(r,a,o,i)}async refreshWithRevokedToken(e){if(this.config.sessions?.single_per_user)throw Ap();if(!e.session_id)throw fo(e.session_id,e.user_id);let n=await this.repo.findRefreshTokensBySession(e.session_id),r=yS(n,e.token),s=r.filter(c=>!Lp(c));if((this.config.enable_refresh_token_rotation??false)&&r.length>1)throw await this.repo.revokeRefreshTokensByIds(s.map(c=>c.id)),fo(e.session_id,e.user_id);let i=s.at(-1);if(!i)throw fo(e.session_id,e.user_id);let o=await this.repo.findUserById(e.user_id);if(!o)throw rr();let a=await this.repo.findSessionById(e.session_id);if(!a)throw rr();this.assertSessionRefreshable(a);let l=Up(a.updated_at,a.refreshed_at,o.updated_at);return await this.repo.updateSessionRefreshedAt(e.session_id,l),await this.createAuditLog(o.id,o.email??"","token_refreshed","token",false),this.createRefreshResponse(o,e.session_id,i.token,l)}async createRefreshResponse(e,n,r,s){let i=await this.repo.updateUser(e.id,{last_sign_in_at:s}),o=this.repo.parseUserJson(i??e),a=await this.repo.findIdentitiesByUserId(e.id),l=await Jl({sub:e.id,aud:e.aud||"authenticated",role:e.role||"authenticated",email:e.email??void 0,session_id:n},this.config.jwt_secret,this.jwtExpiry),c=Math.floor(Date.now()/1e3);return Mp({access_token:l,refresh_token:r,token_type:"bearer",expires_in:this.jwtExpiry,expires_at:c+this.jwtExpiry,user:this.mapUserToResponse(o,a,"user")},n,e.id)}assertSessionRefreshable(e){let n=Date.now();if(this.sessionTimeboxSeconds!==void 0&&n-Date.parse(e.created_at)>this.sessionTimeboxSeconds*1e3)throw ql(void 0,e.id,e.user_id);let r=e.refreshed_at??e.created_at;if(this.sessionInactivitySeconds!==void 0&&n-Date.parse(r)>this.sessionInactivitySeconds*1e3)throw ql("inactivity",e.id,e.user_id)}async getUser(e){let n=await this.repo.findUserById(e);if(!n)throw ft();let r=this.repo.parseUserJson(n),s=await this.repo.findIdentitiesByUserId(e);return this.mapUserToResponse(r,s,"user")}async updateUser(e,n){let r=await this.repo.findUserById(e);if(!r)throw ft();let s=this.repo.parseUserJson(r),i={},o=false,a=false,l=n.data!==void 0||n.password!==void 0||n.email!==void 0;if(n.data!==void 0){let u=typeof s.raw_user_meta_data=="object"?s.raw_user_meta_data:{};i.raw_user_meta_data=mS(u,n.data??{}),o=true;}if(n.password!==void 0){if(this.assertPasswordStrong(n.password),s.encrypted_password&&await Hl(n.password,s.encrypted_password))throw kp();i.encrypted_password=await ps(n.password),i.recovery_token=null,i.recovery_sent_at=null,o=true,a=true;}if(n.email!==void 0)if(n.email==="")o=true;else {let u=n.email.toLowerCase();if(!sr(u))throw ne("Unable to validate email address: invalid format",400);if(o=true,u!==s.email?.toLowerCase()){let d=await this.repo.findUserByEmail(u);if(d&&d.id!==e)throw Cp();let p=new Date().toISOString(),y=Nt(),h=et(),b=Nt(),m=et(),w=this.config.email?.double_confirm_changes??true;i.email_change=u,i.email_change_token_current=w?h:null,i.email_change_token_new=m,i.email_change_sent_at=p,w?await this.mailer.sendEmailChange(u,h,y,{userId:e,tokenNew:b,tokenHashNew:m,redirectTo:this.config.site_url}):await this.mailer.sendEmailChange(u,m,b,{userId:e,redirectTo:this.config.site_url});}}l||(o=true);let c=s;if(Object.keys(i).length>0){let u=await this.repo.updateUser(e,i);if(!u)throw ft();c=this.repo.parseUserJson(u);}a&&await this.createAuditLog(e,s.email??"","user_updated_password","user",false),o&&await this.createAuditLog(e,s.email??"","user_modified","user",false);let f=await this.repo.findIdentitiesByUserId(e);return this.mapUserToResponse(c,f,"user")}async signOut(e,n,r){let s=n??"local";if(!["global","local","others"].includes(s))throw ne(`Unsupported logout scope "${s}"`,400);let i=await this.repo.findUserById(r);if(!i)throw ft();let o=this.repo.parseUserJson(i);s==="global"?(await this.repo.deleteRefreshTokensForUser(r),await this.repo.deleteUserSessions(r)):s==="others"&&e?(await this.repo.deleteRefreshTokensForUser(r,e),await this.repo.deleteUserSessions(r,e)):e&&(await this.repo.deleteRefreshTokensForSession(e),await this.repo.deleteSession(e)),await this.createAuditLog(r,o.email??"","logout","account",false);}async signInWithOtp(e,n){if(!e)throw ne("One of email or phone must be set",400);if(e=e.toLowerCase(),!sr(e))throw ne("Unable to validate email address: invalid format",400);let r=await this.repo.findUserByEmail(e),s=!r;if(!r&&n?.shouldCreateUser!==false){let l=Ge(),c=await ps(et()),f=new Date().toISOString();r=await this.repo.createUser({id:l,email:e,encrypted_password:c,confirmed_at:f,raw_app_meta_data:{provider:"email",providers:["email"]},raw_user_meta_data:{email:e,email_verified:true,phone_verified:false,sub:l}}),await this.repo.createIdentity({id:Ge(),provider:"email",provider_id:l,user_id:l,identity_data:{email:e,email_verified:false,phone_verified:false,sub:l}});}if(!r)throw Tp();let i=Nt(),o=et(),a=new Date().toISOString();if(await this.repo.updateUser(r.id,{recovery_token:o,recovery_sent_at:a}),await this.createAuditLog(r.id,e,"user_recovery_requested","user",false),await this.mailer.sendMagicLink(e,o,i,{userId:r.id,redirectTo:this.config.site_url}),s){let l=await this.repo.findUserById(r.id);if(!l)throw ft();let c=this.repo.parseUserJson(l),f=await this.repo.findIdentitiesByUserId(r.id);await this.createSessionForUser(c,f),await this.createAuditLog(r.id,e,"user_signedup","team");}}async requestMagicLink(e,n){if(!e)throw ne("Password recovery requires an email",422);if(e=e.toLowerCase(),!sr(e))throw ne("Unable to validate email address: invalid format",400);let r=await this.repo.findUserByEmail(e),s=!r;if(!r){if(this.config.enable_signup===false)throw Fl();let l=Ge(),c=await ps(et()),f=new Date().toISOString();r=await this.repo.createUser({id:l,email:e,encrypted_password:c,confirmed_at:f,raw_app_meta_data:{provider:"email",providers:["email"]},raw_user_meta_data:{email:e,email_verified:true,phone_verified:false,sub:l}}),await this.repo.createIdentity({id:Ge(),provider:l,provider_id:l,user_id:l,identity_data:{email:e,email_verified:false,phone_verified:false,sub:l}});}let i=Nt(),o=et(),a=new Date().toISOString();if(await this.repo.updateUser(r.id,{recovery_token:o,recovery_sent_at:a}),await this.createAuditLog(r.id,e,"user_recovery_requested","user",false),await this.mailer.sendMagicLink(e,o,i,{userId:r.id,redirectTo:this.config.site_url}),s){let l=await this.repo.findUserById(r.id);if(!l)throw ft();let c=this.repo.parseUserJson(l),f=await this.repo.findIdentitiesByUserId(r.id);await this.createSessionForUser(c,f),await this.createAuditLog(r.id,e,"user_signedup","team");}}async verifyOtp(e){let n=null,r=null;if(e.token_hash){let c=await this.findUserByTokenAndType(e.token_hash,e.type);n=c?.user??null,r=c?.tokenColumn??null;}else if(e.email&&e.token)if(n=await this.repo.findUserByEmail(e.email.toLowerCase()),n){for(let c of this.getTokenColumnsForType(e.type)){let f=n[c];if(f===e.token||this.otpMatchesStoredTokenHash(e.email,e.token,f)){r=c;break}}if(!r)throw nr()}else throw nr();else throw nr();if(!n)throw nr();let s=this.repo.parseUserJson(n),i=new Date().toISOString(),o={};if(s.confirmed_at||(o.confirmed_at=i),e.type==="email_change"&&s.email_change){o.email=s.email_change,o.email_change=null,o.email_change_token_current=null,o.email_change_token_new=null;let c=await this.repo.findIdentitiesByUserId(n.id);for(let f of c){let u=typeof f.identity_data=="string"?JSON.parse(f.identity_data):{...f.identity_data??{}};await this.repo.updateIdentity(f.id,{identity_data:{...u,email:s.email_change,email_verified:true}});}await this.createAuditLog(n.id,s.email??"","user_modified","user",false);}else if(e.type==="signup"){let c=typeof s.raw_user_meta_data=="object"?s.raw_user_meta_data:{};o.raw_user_meta_data={...c,email_verified:true};let f=await this.repo.findIdentitiesByUserId(n.id);for(let u of f){let d=typeof u.identity_data=="string"?JSON.parse(u.identity_data):{...u.identity_data??{}};await this.repo.updateIdentity(u.id,{identity_data:{...d,email_verified:true}});}r&&(o[r]=null);}else r&&(o[r]=null);o.last_sign_in_at=i,await this.repo.updateUser(n.id,o);let a=await this.repo.findUserById(n.id);if(!a)throw nr();let l=await this.repo.findIdentitiesByUserId(n.id);return e.type==="signup"&&await this.createAuditLog(n.id,a.email??"","user_signedup","team"),this.createSessionForUser(this.repo.parseUserJson(a),l,"verify",{createLoginAudit:["magiclink","recovery"].includes(e.type),includeLoginProviderTrait:!["magiclink","recovery"].includes(e.type),authenticationMethod:["email_change","magiclink","recovery","signup"].includes(e.type)?"otp":"password"})}async recover(e){if(!e)throw ne("Password recovery requires an email",400);if(e=e.toLowerCase(),!sr(e))throw ne("Unable to validate email address: invalid format",400);let n=await this.repo.findUserByEmail(e);if(!n)return;let r=Nt(),s=et(),i=new Date().toISOString();await this.repo.updateUser(n.id,{recovery_token:s,recovery_sent_at:i}),await this.createAuditLog(n.id,e,"user_recovery_requested","user",false),await this.mailer.sendRecovery(e,s,r,{userId:n.id,redirectTo:this.config.site_url});}async resend(e,n){if(!["signup","email_change","sms","phone_change"].includes(e))throw ne("Missing one of these types: signup, email_change, sms, phone_change",400);if((e==="signup"||e==="email_change")&&!n)throw ne("Type provided requires an email address",400);if(!n)return;if(n=n.toLowerCase(),!sr(n))throw ne("Unable to validate email address: invalid format",400);let r=await this.repo.findUserByEmail(n);if(!r)return;let s=Nt(),i=et(),o=new Date().toISOString();if(e==="signup"){if(r.confirmed_at||!r.confirmation_sent_at)return;throw po()}else if(e==="email_change"){if(!r.email_change)return;if(r.email_change_sent_at)throw po();await this.repo.updateUser(r.id,{email_change_token_new:i,email_change_sent_at:o}),await this.mailer.sendEmailChange(r.email_change,i,s,{userId:r.id,redirectTo:this.config.site_url});}}async reauthenticate(e){let n=await this.repo.findUserById(e);if(!n)throw wp();let r=Nt(),s=et(),i=new Date().toISOString();await this.repo.updateUser(n.id,{reauthentication_token:s,reauthentication_sent_at:i}),await this.mailer.sendReauthentication(n.email,r,{userId:n.id,tokenHash:s,redirectTo:this.config.site_url}),await this.createAuditLog(n.id,n.email??"","user_reauthenticate_requested","",false);}async createSessionForUser(e,n,r="session",s={}){let i=new Date().toISOString(),o=await this.repo.updateUser(e.id,{last_sign_in_at:i}),a=o?this.repo.parseUserJson(o):e;this.config.sessions?.single_per_user&&await this.repo.revokeUserRefreshTokens(e.id);let l=Ge();await this.repo.createSession({id:l,user_id:e.id});let c=zl();await this.repo.createRefreshToken({token:c,user_id:e.id,session_id:l}),(s.createLoginAudit??true)&&await this.createAuditLog(e.id,e.email??"","login","account",s.includeLoginProviderTrait??true);let f=await Jl({sub:e.id,aud:e.aud||"authenticated",role:e.role||"authenticated",email:e.email??void 0,session_id:l},this.config.jwt_secret,this.jwtExpiry),u=Math.floor(Date.now()/1e3);return Mp({access_token:f,refresh_token:c,token_type:"bearer",expires_in:this.jwtExpiry,expires_at:u+this.jwtExpiry,user:this.mapUserToResponse(a,n,r)},l,e.id)}assertPasswordStrong(e){let n=Ip(e,this.minPasswordLength,this.passwordRequiredCharacters);if(n.length>0)throw bp(this.minPasswordLength,this.passwordRequiredCharacters,n)}mapUserToResponse(e,n,r){let s=typeof e.raw_app_meta_data=="string"?JSON.parse(e.raw_app_meta_data):e.raw_app_meta_data??{},i=typeof e.raw_user_meta_data=="string"?JSON.parse(e.raw_user_meta_data):e.raw_user_meta_data??{},o={id:e.id,aud:e.aud||"authenticated",role:e.role||"authenticated",email:e.email??"",phone:e.phone??"",app_metadata:s,user_metadata:i,identities:n.map(a=>this.mapIdentityToResponse(a,r,e)),created_at:e.created_at,updated_at:e.updated_at,is_anonymous:false};return e.confirmed_at&&(o.email_confirmed_at=e.confirmed_at,(r==="user"||r==="verify")&&(o.confirmed_at=e.confirmed_at)),e.last_sign_in_at&&(o.last_sign_in_at=e.last_sign_in_at),e.confirmation_sent_at&&(o.confirmation_sent_at=e.confirmation_sent_at),e.email_change&&(o.new_email=e.email_change),e.email_change_sent_at&&(o.email_change_sent_at=e.email_change_sent_at),r==="verify"&&e.recovery_sent_at&&(o.recovery_sent_at=e.recovery_sent_at),o}mapIdentityToResponse(e,n,r){let s=typeof e.identity_data=="string"?JSON.parse(e.identity_data):e.identity_data??{},i=n==="session"&&r.confirmed_at?{...s,email_verified:true}:s,o=e.email??(typeof i.email=="string"?i.email:r.email??void 0);return {identity_id:e.id,id:e.provider_id,user_id:e.user_id,identity_data:i,provider:"email",last_sign_in_at:e.last_sign_in_at??e.created_at,created_at:e.created_at,updated_at:e.updated_at,...o?{email:o}:{}}}async findUserByTokenAndType(e,n){if(n==="email_change"){let r=await this.repo.findUserByToken("email_change_token_current",e);if(r)return {user:r,tokenColumn:"email_change_token_current"};let s=await this.repo.findUserByToken("email_change_token_new",e);return s?{user:s,tokenColumn:"email_change_token_new"}:null}for(let r of this.getTokenColumnsForType(n)){let s=await this.repo.findUserByToken(r,e);if(s)return {user:s,tokenColumn:r}}return null}otpMatchesStoredTokenHash(e,n,r){return !n||typeof r!="string"?false:(Dl.get(e.toLowerCase())??[]).some(i=>i.otp===n&&i.tokenHash===r)}getTokenColumnsForType(e){switch(e){case "signup":return ["confirmation_token"];case "magiclink":return ["recovery_token","confirmation_token"];case "recovery":return ["recovery_token"];case "email_change":return ["email_change_token_new"];case "reauthentication":return ["reauthentication_token"];default:return []}}async createAuditLog(e,n,r,s,i=true){let o={action:r,actor_id:e,actor_username:n,actor_via_sso:false,log_type:s};i&&(o.traits={provider:"email"}),await this.repo.createAuditLogEntry({id:Ge(),payload:o});}};function mS(t,e){let n={...t};for(let[r,s]of Object.entries(e))s===null?delete n[r]:n[r]=s;return n}function hS(t){switch(t){case "letters_digits":return ["abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ","0123456789"];case "lower_upper_letters_digits":return ["abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ","0123456789"];case "lower_upper_letters_digits_symbols":return ["abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ","0123456789","!@#$%^&*"];default:return []}}function jp(t){if(!t)return;let e=t.match(/^(\d+)(ms|s|m|h)?$/);if(!e)return;let n=Number(e[1]);switch(e[2]??"s"){case "ms":return n/1e3;case "m":return n*60;case "h":return n*3600;default:return n}}function sr(t){return /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(t)}function gS(t){return /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(t)}function Lp(t){return t.revoked===true||t.revoked===1}function yS(t,e){let n=[],r=[e];for(;r.length>0;){let s=r.shift();for(let i of t)i.parent!==s||n.some(o=>o.id===i.id)||(n.push(i),r.push(i.token));}return n}function Up(...t){let e=Math.max(0,...t.map(r=>r?Date.parse(r):0)),n=Date.now();return new Date(Math.max(n,e+1)).toISOString()}function Mp(t,e,n){return Object.defineProperties(t,{session_id:{value:e,enumerable:false},user_id:{value:n,enumerable:false}}),t}function Gl(t){if(t==null)return {};if(typeof t=="string")try{return JSON.parse(t)}catch{return {}}return t}function Tn(t){return typeof t=="string"?t:JSON.stringify(t??{})}var hs=class{constructor(e,n){this.db=e;this.dialect=n;this.schema="auth";}schema;bool(e){return this.dialect==="sqlite"?e?1:0:e}table(e){return this.db.withSchema(this.schema).selectFrom(e)}insertInto(e){return this.db.withSchema(this.schema).insertInto(e)}update(e){return this.db.withSchema(this.schema).updateTable(e)}deleteFrom(e){return this.db.withSchema(this.schema).deleteFrom(e)}async findUserByEmail(e){return await this.table("users").selectAll().where("email","=",e.toLowerCase()).executeTakeFirst()??null}async findUserById(e){return await this.table("users").selectAll().where("id","=",e).executeTakeFirst()??null}async findUserByToken(e,n){return await this.table("users").selectAll().where(e,"=",n).executeTakeFirst()??null}async createUser(e){let n=new Date().toISOString(),r={id:e.id,aud:e.aud??"authenticated",role:e.role??"authenticated",email:e.email.toLowerCase(),encrypted_password:e.encrypted_password??null,phone:e.phone??null,email_confirmed_at:e.email_confirmed_at??e.confirmed_at??null,confirmation_token:e.confirmation_token??null,confirmation_sent_at:e.confirmation_sent_at??null,recovery_token:e.recovery_token??null,recovery_sent_at:e.recovery_sent_at??null,email_change:e.email_change??null,email_change_token_new:e.email_change_token_new??null,email_change_token_current:e.email_change_token_current??null,email_change_sent_at:e.email_change_sent_at??null,email_change_confirm_status:e.email_change_confirm_status??0,reauthentication_token:e.reauthentication_token??null,reauthentication_sent_at:e.reauthentication_sent_at??null,raw_app_meta_data:Tn(e.raw_app_meta_data??{provider:"email",providers:["email"]}),raw_user_meta_data:Tn(e.raw_user_meta_data??{}),is_sso_user:this.bool(e.is_sso_user??false),is_anonymous:this.bool(e.is_anonymous??false),last_sign_in_at:e.last_sign_in_at??null,created_at:n,updated_at:n};return await this.insertInto("users").values(r).execute(),await this.findUserById(e.id)}async updateUser(e,n){let r={...n,updated_at:new Date().toISOString()};return r.confirmed_at!=null&&r.email_confirmed_at==null&&(r.email_confirmed_at=r.confirmed_at),delete r.confirmed_at,r.raw_app_meta_data!=null&&(r.raw_app_meta_data=Tn(r.raw_app_meta_data)),r.raw_user_meta_data!=null&&(r.raw_user_meta_data=Tn(r.raw_user_meta_data)),r.is_sso_user!=null&&(r.is_sso_user=this.bool(!!r.is_sso_user)),r.is_anonymous!=null&&(r.is_anonymous=this.bool(!!r.is_anonymous)),await this.update("users").set(r).where("id","=",e).execute(),this.findUserById(e)}async createSession(e){let n=new Date().toISOString(),r={id:e.id,user_id:e.user_id,aal:e.aal??"aal1",not_after:null,refreshed_at:null,user_agent:null,ip:null,tag:null,refresh_token_hmac_key:null,refresh_token_counter:null,scopes:null,factor_id:null,created_at:n,updated_at:n};return await this.insertInto("sessions").values(r).execute(),r}async findSessionById(e){return await this.table("sessions").selectAll().where("id","=",e).executeTakeFirst()??null}async updateSessionRefreshedAt(e,n){return await this.update("sessions").set({refreshed_at:n,updated_at:n}).where("id","=",e).execute(),this.findSessionById(e)}async deleteSession(e){await this.deleteFrom("sessions").where("id","=",e).execute();}async deleteUserSessions(e,n){let r=this.deleteFrom("sessions").where("user_id","=",e);n&&(r=r.where("id","!=",n)),await r.execute();}async deleteRefreshTokensForSession(e){await this.deleteFrom("refresh_tokens").where("session_id","=",e).execute();}async deleteRefreshTokensForUser(e,n){let r=this.deleteFrom("refresh_tokens").where("user_id","=",e);n&&(r=r.where("session_id","!=",n)),await r.execute();}async createRefreshToken(e){let n=new Date().toISOString(),r={id:Ge(),token:e.token,user_id:e.user_id,session_id:e.session_id,revoked:this.bool(false),parent:e.parent??null,created_at:n,updated_at:n};return await this.insertInto("refresh_tokens").values(r).execute(),r}async findRefreshToken(e){return await this.table("refresh_tokens").selectAll().where("token","=",e).executeTakeFirst()??null}async findRefreshTokensBySession(e){return await this.table("refresh_tokens").selectAll().where("session_id","=",e).execute()}async revokeRefreshToken(e){await this.update("refresh_tokens").set({revoked:this.bool(true),updated_at:new Date().toISOString()}).where("id","=",e).execute();}async revokeSessionRefreshTokens(e){await this.update("refresh_tokens").set({revoked:this.bool(true),updated_at:new Date().toISOString()}).where("session_id","=",e).execute();}async revokeRefreshTokensByIds(e){e.length!==0&&await this.update("refresh_tokens").set({revoked:this.bool(true),updated_at:new Date().toISOString()}).where("id","in",e).execute();}async revokeUserRefreshTokens(e){await this.update("refresh_tokens").set({revoked:this.bool(true),updated_at:new Date().toISOString()}).where("user_id","=",e).execute();}async createIdentity(e){let n=new Date().toISOString(),r={id:e.id,provider:e.provider,provider_id:e.provider_id,user_id:e.user_id,identity_data:Tn(e.identity_data),last_sign_in_at:e.last_sign_in_at??n,created_at:n,updated_at:n};return await this.insertInto("identities").values(r).execute(),{...r,identity_data:e.identity_data}}async findIdentitiesByUserId(e){return (await this.table("identities").selectAll().where("user_id","=",e).execute()).map(r=>({...r,identity_data:Gl(r.identity_data)}))}async updateIdentity(e,n){let r={...n,updated_at:new Date().toISOString()};r.identity_data!=null&&(r.identity_data=Tn(r.identity_data)),delete r.email,await this.update("identities").set(r).where("id","=",e).execute();}async createAuditLogEntry(e){let n={id:e.id,payload:Tn(e.payload??{}),ip_address:e.ip_address??"",created_at:new Date().toISOString()};await this.insertInto("audit_log_entries").values(n).execute();}parseUserJson(e){return {...e,raw_app_meta_data:Gl(e.raw_app_meta_data),raw_user_meta_data:Gl(e.raw_user_meta_data),confirmed_at:e.confirmed_at??e.email_confirmed_at??null}}};function Fp(){return {version:bS(),name:"GoTrue",description:"GoTrue is a user registration and authentication API"}}function Bp(t){return {external:{anonymous_users:t.enable_anonymous_sign_ins??false,apple:false,azure:false,bitbucket:false,discord:false,facebook:false,snapchat:false,figma:false,fly:false,github:false,gitlab:false,google:false,keycloak:false,kakao:false,linkedin:false,linkedin_oidc:false,notion:false,spotify:false,slack:false,slack_oidc:false,workos:false,twitch:false,twitter:false,email:t.email?.enable_signup??true,phone:false,zoom:false},disable_signup:!(t.enable_signup??true),mailer_autoconfirm:!(t.email?.enable_confirmations??false),phone_autoconfirm:false,sms_provider:"",saml_enabled:false}}function qp(){return {keys:[]}}function Wp(){return {issuer:"",jwks_uri:"/.well-known/jwks.json"}}function bS(){return [Vl(JSON.stringify({alg:"HS256",typ:"JWT"})),Vl(JSON.stringify({name:"GoTrue",implementation:"@supabase/lite"})),Vl("metadata")].join(".")}function Vl(t){if(typeof Buffer<"u")return Buffer.from(t,"utf-8").toString("base64url");let e=new TextEncoder().encode(t),n="";for(let r of e)n+=String.fromCharCode(r);return btoa(n).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}var Ql=t=>t;var wS="00000000-0000-0000-0000-000000000000",SS=/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i,Xl=({onError:t}={})=>Ql(async(e,n)=>{if(!e.var.userId||!e.var.sessionId){let r=await Kp(e);if(r&&t)return t(r,e)}await n();}),gs=()=>Ql(async(t,e)=>{if(!t.var.userId){let n=await Kp(t);if(n)return Jp(t,n);if(!t.var.userId)return Jp(t,tr())}await e();});async function Kp(t){let e=t.req.header("Authorization");if(!e)return tr();if(!e.startsWith("Bearer "))return tr();let n=e.slice(7);if(!n||/^\s/.test(n))return tr();let r=t.get("app").config.auth?.jwt_secret;if(!r)return null;let s;try{s=await Pp(n,r);}catch(c){return c instanceof M?c:tr()}let i=ES(s);if(i)return i;let o=s.sub;if(s.role!=="service_role"&&!await t.var.authService.repo.findUserById(o))return _p();let l=s.session_id;if(l){if(!await t.var.authService.repo.findSessionById(l))return xp();t.set("sessionId",l);}return t.set("userId",o),t.set("jwt",s),null}function ES(t){let e=t.sub,n=t.role;return e==null||e===""?Ul():typeof e!="string"?Ml():SS.test(e)?e===wS&&n==="service_role"?Ul():null:Ml()}function Jp(t,e){return t.header("X-Sb-Error-Code",e.code),t.json(e.toJSON(),e.status)}var Yl=new Se().onError((t,e)=>{if(t instanceof M){e.header("X-Sb-Error-Code",t.code);for(let[n,r]of Object.entries(t.headers??{}))e.header(n,r);return e.json(t.toJSON(),t.status)}return console.error("Auth error:",t),e.json({error:"server_error",error_description:"Internal server error"},500)}).options("*",t=>{let e=t.req.header("Access-Control-Request-Method");return e&&t.header("Access-Control-Allow-Methods",e),t.header("Access-Control-Allow-Credentials","true"),t.header("Access-Control-Allow-Origin","*"),t.body(null,204)}).post("/signup",async t=>{let e=await It(t,{requireBody:true}),{authService:n}=t.var,r=await n.signUp(e.email,e.password,e.data);return r.session?(ho(t,r.session),t.json(r.session,200)):t.json(r.user,200)}).all("/signup",kn("POST")).post("/token",async t=>{let e=t.req.query("grant_type"),n=await It(t,{requireBody:true}),{authService:r}=t.var;if(e==="password"){let s=await r.signInWithPassword(n.email,n.password);return ho(t,s),t.json({...s,weak_password:null},200)}if(e==="refresh_token"){let s=await r.refreshSession(n.refresh_token);return ho(t,s),t.json(s,200)}throw $p()}).all("/token",kn("POST")).post("/otp",async t=>{let e=await It(t),{authService:n}=t.var;return await n.signInWithOtp(e.email,{shouldCreateUser:e.create_user??e.options?.shouldCreateUser}),t.json({},200)}).post("/magiclink",async t=>{let e=await It(t),{authService:n}=t.var;return await n.requestMagicLink(e.email,e.gotrue_meta_security),t.json({},200)}).all("/magiclink",kn("POST")).post("/verify",async t=>{let e=await It(t),{authService:n}=t.var;xS(e);let r=await n.verifyOtp({email:e.email,token:e.token,token_hash:e.token_hash,type:e.type});return ho(t,r),t.json(r,200)}).get("/verify",t=>{let e=t.req.query("type");throw e?Hp.has(e)?ne("Verify requires a token or a token hash",400):ne("Invalid email verification type",400):ne("Verify requires a verification type",400)}).post("/recover",async t=>{let e=await It(t),{authService:n}=t.var;return await n.recover(e.email),t.json({},200)}).post("/resend",async t=>{let e=await It(t),{authService:n}=t.var;return await n.resend(e.type,e.email),t.json({},200)}).get("/health",t=>t.json(Fp(),200)).all("/health",kn("GET")).get("/settings",t=>t.json(Bp(t.var.app.config.auth??{}),200)).all("/settings",kn("GET")).get("/.well-known/jwks.json",t=>(t.header("Cache-Control","public, max-age=600"),t.json(qp(),200))).get("/.well-known/openid-configuration",t=>(t.header("Cache-Control","public, max-age=600"),t.json(Wp(),200))).all("/nonexistent",_S).use(gs()).post("/logout",async t=>{let e=await It(t),{authService:n}=t.var;return await n.signOut(t.get("sessionId"),t.req.query("scope")??e.scope,t.get("userId")),t.body(null,204)}).get("/user",async t=>{let{authService:e}=t.var,n=await e.getUser(t.get("userId"));return t.json(n,200)}).put("/user",async t=>{let e=await It(t),{authService:n}=t.var,r=await n.updateUser(t.get("userId"),{data:e.data,password:e.password,email:e.email});return t.json(r,200)}).all("/user",kn("GET, PUT")).get("/reauthenticate",async t=>{let{authService:e}=t.var;return await e.reauthenticate(t.get("userId")),t.json({},200)}).all("/reauthenticate",kn("GET"));function kn(t){return e=>(e.header("Allow",t),e.body(null,405))}function _S(t){return t.header("Content-Type","text/plain; charset=utf-8"),t.header("X-Content-Type-Options","nosniff"),t.body("404 page not found",404)}var Hp=new Set(["signup","magiclink","recovery","email_change","reauthentication"]);function xS(t){let e=typeof t.type=="string"?t.type:"";if(!e)throw ne("Verify requires a verification type",400);if(!Hp.has(e))throw ne("Invalid email verification type",400);let n=typeof t.token_hash=="string"?t.token_hash:"",r=typeof t.token=="string"?t.token:"",s=typeof t.email=="string"?t.email:"";if(e==="signup"&&!n&&!(s&&r))throw ne("Verify requires either a token or a token hash",400)}async function It(t,e={}){if(!t.req.raw.body){if(e.requireBody)throw ds("Could not parse request body as JSON: unexpected end of JSON input");return {}}let n=await t.req.text();if(n===""){if(e.requireBody)throw ds("Could not parse request body as JSON: unexpected end of JSON input");return {}}try{return JSON.parse(n)}catch{if(t.req.header("Content-Type")?.toLowerCase().split(";")[0]?.trim()==="application/x-www-form-urlencoded")throw ds("Could not parse request body as JSON: unexpected end of JSON input");let s=Kl(n)||"invalid character ' ' looking for beginning of value";throw ds(`Could not parse request body as JSON: ${s}`)}}function ho(t,e){e.session_id&&t.header("Sb-Auth-Session-Id",e.session_id),e.user_id&&t.header("Sb-Auth-User-Id",e.user_id),e.refresh_token&&t.header("Sb-Auth-Refresh-Token-Prefix",String(e.refresh_token).slice(0,8));}function zp(t){let e=t.connection.dialect,n=new hs(t.connection.kysely,e);return new ms(n,t.config.auth,t._mailer??new us(t.drivers.email))}function Gp(t){if(t==null)return {};if(typeof t=="string")try{return JSON.parse(t)}catch{return {}}return t}function Vp(t){if(t==null)return [];if(Array.isArray(t))return t;if(typeof t=="string")try{return JSON.parse(t)}catch{return []}return []}function nn(t){return typeof t=="string"?t:JSON.stringify(t??{})}var ys=class{constructor(e,n){this.db=e;this.dialect=n;this.schema="storage";}schema;table(e){return this.db.withSchema(this.schema).selectFrom(e)}insertInto(e){return this.db.withSchema(this.schema).insertInto(e)}update(e){return this.db.withSchema(this.schema).updateTable(e)}deleteFrom(e){return this.db.withSchema(this.schema).deleteFrom(e)}async createBucket(e){let n=new Date().toISOString(),r={id:e.id,name:e.name,owner:e.owner??null,owner_id:e.owner_id??null,public:e.public??false,file_size_limit:e.file_size_limit??null,allowed_mime_types:this.dialect==="postgres"?e.allowed_mime_types??null:nn(e.allowed_mime_types??[]),created_at:n,updated_at:n};return await this.insertInto("buckets").values(r).execute(),await this.findBucketById(e.id)}async findBucketById(e){let n=await this.table("buckets").selectAll().where("id","=",e).executeTakeFirst();return n?this.parseBucketRow(n):null}async findBucketByName(e){let n=await this.table("buckets").selectAll().where("name","=",e).executeTakeFirst();return n?this.parseBucketRow(n):null}async listBuckets(){return (await this.table("buckets").selectAll().execute()).map(n=>this.parseBucketRow(n))}async updateBucket(e,n){let r={updated_at:new Date().toISOString()};return n.public!==void 0&&(r.public=n.public),n.file_size_limit!==void 0&&(r.file_size_limit=n.file_size_limit),n.allowed_mime_types!==void 0&&(r.allowed_mime_types=this.dialect==="postgres"?n.allowed_mime_types??null:nn(n.allowed_mime_types)),await this.update("buckets").set(r).where("id","=",e).execute(),this.findBucketById(e)}async deleteBucket(e){await this.deleteFrom("buckets").where("id","=",e).execute();}async isBucketEmpty(e){let n=await this.table("objects").select(this.db.fn.count("id").as("count")).where("bucket_id","=",e).executeTakeFirst();return Number(n?.count??0)===0}async createObject(e){let n=new Date().toISOString(),r={id:e.id,bucket_id:e.bucket_id,name:e.name,owner:e.owner??null,owner_id:e.owner_id??null,metadata:nn(e.metadata??{}),user_metadata:nn(e.user_metadata??{}),version:e.version??null,created_at:n,updated_at:n,last_accessed_at:n};return this.dialect!=="postgres"&&(r.path_tokens=nn(e.name.split("/"))),await this.insertInto("objects").values(r).execute(),await this.findObjectById(e.id)}async findObjectById(e){let n=await this.table("objects").selectAll().where("id","=",e).executeTakeFirst();return n?this.parseObjectRow(n):null}async findObjectByPath(e,n){let r=await this.table("objects").selectAll().where("bucket_id","=",e).where("name","=",n).executeTakeFirst();return r?this.parseObjectRow(r):null}async listObjects(e,n,r){let s=this.table("objects").selectAll().where("bucket_id","=",e);return n&&(s=s.where("name","like",`${n}%`)),r?.search&&(s=s.where("name","like",`%${r.search}%`)),r?.sortBy?s=s.orderBy(r.sortBy.column,r.sortBy.order):s=s.orderBy("name","asc"),r?.limit&&(s=s.limit(r.limit)),r?.offset&&(s=s.offset(r.offset)),(await s.execute()).map(o=>this.parseObjectRow(o))}async updateObject(e,n){let r={updated_at:new Date().toISOString()};return n.name!==void 0&&(r.name=n.name,this.dialect!=="postgres"&&(r.path_tokens=nn(n.name.split("/")))),n.metadata!==void 0&&(r.metadata=nn(n.metadata)),n.user_metadata!==void 0&&(r.user_metadata=nn(n.user_metadata)),n.version!==void 0&&(r.version=n.version),n.owner!==void 0&&(r.owner=n.owner),n.owner_id!==void 0&&(r.owner_id=n.owner_id),await this.update("objects").set(r).where("id","=",e).execute(),this.findObjectById(e)}async deleteObject(e){await this.deleteFrom("objects").where("id","=",e).execute();}async deleteObjectsByBucket(e){let r=(await this.table("objects").select("name").where("bucket_id","=",e).execute()).map(s=>s.name);return r.length>0&&await this.deleteFrom("objects").where("bucket_id","=",e).execute(),r}async objectExists(e,n){return !!await this.table("objects").select("id").where("bucket_id","=",e).where("name","=",n).executeTakeFirst()}async touchObject(e){await this.update("objects").set({last_accessed_at:new Date().toISOString()}).where("id","=",e).execute();}parseBucketRow(e){return {...e,owner:e.owner??"",owner_id:e.owner_id??"",public:!!e.public,allowed_mime_types:e.allowed_mime_types==null?null:Vp(e.allowed_mime_types)}}parseObjectRow(e){return {...e,metadata:Gp(e.metadata),user_metadata:Gp(e.user_metadata),path_tokens:Vp(e.path_tokens)}}};var H=class t extends Error{constructor(n,r,s){super(s);this.status=n;this.code=r;}name="StorageError";static bucketNotFound(n){return new t(404,"Bucket not found",`Bucket not found: ${n}`)}static bucketAlreadyExists(n){return new t(409,"Duplicate","The resource already exists")}static bucketNotEmpty(n){return new t(409,"ResourceNotEmpty","The bucket you tried to delete is not empty")}static objectNotFound(n){return new t(404,"Object not found",`Object not found: ${n}`)}static invalidMimeType(n,r){return new t(415,"invalid_mime_type",`mime type ${n} is not supported. Supported: ${r.join(", ")}`)}static fileTooLarge(n){return new t(413,"Payload too large",`The object exceeded the maximum allowed size of ${n} bytes`)}static invalidKey(n){return new t(400,"Invalid key",`Invalid object key: ${n}`)}static storageNotConfigured(){return new t(500,"Storage not configured","Storage is enabled but no storage adapter has been set. Set app._storageAdapter before making storage requests.")}toJSON(){return {statusCode:String(this.status),error:this.code,message:this.message}}};var bs=class{constructor(e,n,r,s={},i){this.repo=e;this.adapter=n;this.config=r;this.options=s;this.transformationAdapter=i;}initialized=false;async init(){if(!this.initialized&&(this.initialized=true,this.options.autoCreateBuckets!==false&&this.config.buckets))for(let[e,n]of Object.entries(this.config.buckets))await this.repo.findBucketById(e)||await this.repo.createBucket({id:e,name:e,public:n.public??false,file_size_limit:n.file_size_limit?CS(n.file_size_limit):null,allowed_mime_types:n.allowed_mime_types});}async createBucket(e){if(await this.repo.findBucketById(e.id))throw H.bucketAlreadyExists(e.id);return this.repo.createBucket(e)}async getBucket(e){let n=await this.repo.findBucketById(e);if(!n)throw H.bucketNotFound(e);return n}async listBuckets(){return this.repo.listBuckets()}async updateBucket(e,n){if(!await this.repo.findBucketById(e))throw H.bucketNotFound(e);return await this.repo.updateBucket(e,n)}async deleteBucket(e){if(!await this.repo.findBucketById(e))throw H.bucketNotFound(e);if(!await this.repo.isBucketEmpty(e))throw H.bucketNotEmpty(e);await this.repo.deleteBucket(e);}async emptyBucket(e){if(!await this.repo.findBucketById(e))throw H.bucketNotFound(e);let r=await this.repo.deleteObjectsByBucket(e);r.length>0&&await this.adapter.deleteObjects(e,r);}async upload(e,n,r,s){Zl(n);let i=await this.repo.findBucketById(e);if(!i)throw H.bucketNotFound(e);let o=s?.contentType??"application/octet-stream",a=s?.cacheControl??"no-cache";if(i.allowed_mime_types&&i.allowed_mime_types.length>0&&!i.allowed_mime_types.includes(o))throw H.invalidMimeType(o,i.allowed_mime_types);let l=i.file_size_limit??this.config.fileSizeLimit??null;if(l&&s?.contentLength&&s.contentLength>l)throw H.fileTooLarge(l);let c=await this.repo.findObjectByPath(e,n);if(c&&!s?.upsert)throw H.bucketAlreadyExists(n);return await this.adapter.uploadObject(e,n,void 0,r,o,a),c&&s?.upsert?await this.repo.updateObject(c.id,{metadata:s?.metadata??c.metadata,version:crypto.randomUUID()}):this.repo.createObject({id:crypto.randomUUID(),bucket_id:e,name:n,owner:s?.owner??null,owner_id:s?.owner??null,metadata:s?.metadata??{},version:crypto.randomUUID()})}async download(e,n,r){let s=await this.repo.findObjectByPath(e,n);if(!s)throw H.objectNotFound(n);if(await this.repo.touchObject(s.id),r?.transform&&this.transformationAdapter&&!this.transformationAdapter.requiresBuffer&&this.transformationAdapter.transformFromUrl){let o=await this.adapter.privateAssetUrl(e,n,s.version??void 0),a=await this.transformationAdapter.transformFromUrl(o,r.transform);return {body:a.body,metadata:{cacheControl:"public, max-age=3600",contentLength:a.contentLength??0,size:a.contentLength??0,mimetype:a.contentType,eTag:""}}}let i=await this.adapter.getObject(e,n,s.version??void 0);if(!i.body)throw H.objectNotFound(n);if(r?.transform&&this.transformationAdapter?.requiresBuffer){let o=await vS(i.body),a=await this.transformationAdapter.transform(o,r.transform);return {body:a.body,metadata:{...i.metadata,mimetype:a.contentType,size:a.contentLength??0,contentLength:a.contentLength??0}}}return {body:i.body,metadata:i.metadata}}async update(e,n,r,s){return this.upload(e,n,r,{...s,upsert:s?.upsert??true})}async remove(e,n){if(!await this.repo.findBucketById(e))throw H.bucketNotFound(e);let s=[];for(let i of n){let o=await this.repo.findObjectByPath(e,i);o&&(await this.adapter.deleteObject(e,i,o.version??void 0),await this.repo.deleteObject(o.id),s.push(o));}return s}async list(e,n,r){if(!await this.repo.findBucketById(e))throw H.bucketNotFound(e);return this.repo.listObjects(e,n,r)}async move(e,n,r){Zl(r);let s=await this.repo.findObjectByPath(e,n);if(!s)throw H.objectNotFound(n);await this.adapter.copyObject(e,n,s.version??void 0,r,void 0),await this.adapter.deleteObject(e,n,s.version??void 0),await this.repo.updateObject(s.id,{name:r,version:crypto.randomUUID()});}async copy(e,n,r){Zl(r);let s=await this.repo.findObjectByPath(e,n);if(!s)throw H.objectNotFound(n);return await this.adapter.copyObject(e,n,s.version??void 0,r,void 0),await this.repo.createObject({id:crypto.randomUUID(),bucket_id:e,name:r,owner:s.owner,owner_id:s.owner_id,metadata:s.metadata,version:crypto.randomUUID()}),{key:r}}async info(e,n){let r=await this.repo.findObjectByPath(e,n);if(!r)throw H.objectNotFound(n);let s=await this.adapter.headObject(e,n,r.version??void 0);return {...r,httpMetadata:s}}async exists(e,n){return this.repo.objectExists(e,n)}async createSignedUrl(e,n,r){if(!await this.repo.findObjectByPath(e,n))throw H.objectNotFound(n);let i=await this.signStorageToken({sub:n,bucket:e,intent:"download"},r);return {signedUrl:`/storage/v1/object/sign/${e}/${n}?token=${i}`}}async createSignedUrls(e,n,r){let s=[];for(let i of n)try{let{signedUrl:o}=await this.createSignedUrl(e,i,r);s.push({path:i,signedUrl:o,error:null});}catch(o){s.push({path:i,signedUrl:"",error:o.message});}return s}async createSignedUploadUrl(e,n){if(!await this.repo.findBucketById(e))throw H.bucketNotFound(e);let s=await this.signStorageToken({sub:n,bucket:e,intent:"upload"},7200);return {signedUrl:`/storage/v1/object/upload/sign/${e}/${n}?token=${s}`,token:s,path:n}}async verifySignedUrl(e){let n=new TextEncoder().encode(this.config.jwtSecret),{payload:r}=await xn(e,n,{algorithms:["HS256"]});return {bucket:r.bucket,path:r.sub,intent:r.intent}}async signStorageToken(e,n){let r=new TextEncoder().encode(this.config.jwtSecret),s=Math.floor(Date.now()/1e3);return new vn({...e,iat:s}).setProtectedHeader({alg:"HS256",typ:"JWT"}).setIssuedAt(s).setExpirationTime(s+n).sign(r)}};async function vS(t){if(t instanceof Uint8Array||Buffer.isBuffer(t))return t;if(t instanceof Blob)return new Uint8Array(await t.arrayBuffer());let e=[],n=t.getReader();for(;;){let{done:r,value:s}=await n.read();if(r)break;e.push(s);}return Buffer.concat(e)}function Zl(t){if(!t||t.includes("..")||t.startsWith("/"))throw H.invalidKey(t)}function CS(t){let e=t.match(/^(\d+(?:\.\d+)?)\s*(B|KB|KiB|MB|MiB|GB|GiB)$/i);if(!e)return 0;let n=Number.parseFloat(e[1]),r=e[2].toUpperCase();return Math.floor(n*({B:1,KB:1e3,KIB:1024,MB:1e6,MIB:1048576,GB:1e9,GIB:1073741824}[r]??1))}var RS=/^[\w!#$%&'*.^`|~+-]+$/,TS=/^[ !#-:<-[\]-~]*$/,ec=(t,e)=>{let n=t.trim().split(";"),r={};for(let s of n){s=s.trim();let i=s.indexOf("=");if(i===-1)continue;let o=s.substring(0,i).trim();if(!RS.test(o))continue;let a=s.substring(i+1).trim();if(a.startsWith('"')&&a.endsWith('"')&&(a=a.slice(1,-1)),TS.test(a)&&(r[o]=a.indexOf("%")!==-1?qn(a,Or):a,e));}return r};var Qp=(t,e,n)=>{let r=t.req.raw.headers.get("Cookie");return r?ec(r):{}};var Xp=(t,e)=>new Response(t,{headers:{"Content-Type":e}}).formData();var kS=/^application\/([a-z-\.]+\+)?json(;\s*[a-zA-Z0-9\-]+\=([^;]+))*$/,AS=/^multipart\/form-data(;\s?boundary=[a-zA-Z0-9'"()+_,\-./:=?]+)?$/,OS=/^application\/x-www-form-urlencoded(;\s*[a-zA-Z0-9\-]+\=([^;]+))*$/,tc=(t,e)=>async(n,r)=>{let s={},i=n.req.header("Content-Type");switch(t){case "json":if(!i||!kS.test(i))break;try{s=await n.req.json();}catch{let a="Malformed JSON in request body";throw new gi(400,{message:a})}break;case "form":{if(!i||!(AS.test(i)||OS.test(i)))break;let a;if(n.req.bodyCache.formData)a=await n.req.bodyCache.formData;else try{let c=await n.req.arrayBuffer();a=await Xp(c,i),n.req.bodyCache.formData=a;}catch(c){let f="Malformed FormData request.";throw f+=c instanceof Error?` ${c.message}`:` ${String(c)}`,new gi(400,{message:f})}let l={};a.forEach((c,f)=>{f.endsWith("[]")?(l[f]??=[]).push(c):Array.isArray(l[f])?l[f].push(c):f in l?l[f]=[l[f],c]:l[f]=c;}),s=l;break}case "query":s=Object.fromEntries(Object.entries(n.req.queries()).map(([a,l])=>l.length===1?[a,l[0]]:[a,l]));break;case "param":s=n.req.param();break;case "header":s=n.req.header();break;case "cookie":s=Qp(n);break}let o=await e(s,n);return o instanceof Response?o:(n.req.addValidatedData(t,o),await r())};var $S=Symbol.for("jsonv"),PS=(t,e)=>Object.assign(t,{[$S]:e}),Dt=(t,e,n,r)=>{let s=tc(t,async(i,o)=>{let a=e.coerce(i,{dropUnknown:n?.dropUnknown}),l=e.validate(a);if(!l.valid)return o.json({...l,schema:e},400);return a});return PS(s,{type:"parameters",skip:n?.skipOpenAPI,value:{target:t,schema:e}})};ee();var NS=g.object({id:g.string(),name:g.string(),public:g.boolean({default:false}).optional(),file_size_limit:g.number().optional(),allowed_mime_types:g.array(g.string()).optional()}),IS=g.object({public:g.boolean().optional(),file_size_limit:g.number().optional(),allowed_mime_types:g.array(g.string()).optional()}),DS=g.object({prefix:g.string().optional(),limit:g.number().optional(),offset:g.number().optional(),sortBy:g.object({column:g.string(),order:g.string()}).optional(),search:g.string().optional()}),Yp=g.object({bucketId:g.string(),sourceKey:g.string(),destinationKey:g.string()}),jS=g.object({expiresIn:g.number()}),LS=g.object({expiresIn:g.number(),paths:g.array(g.string())}),US=g.object({prefixes:g.array(g.string())}),MS=new Se().get("/object/public/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/public/${e}/`),{storageService:r}=t.var;if(!(await r.getBucket(e)).public)return t.json({error:"Bucket is not public"},400);let i=nc(t.req.query()),o=await r.download(e,n,{transform:i??void 0});return new Response(o.body,{headers:rc(o.metadata)})}).get("/object/sign/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/sign/${e}/`),r=t.req.query("token"),{storageService:s}=t.var;if(!r)return t.json({error:"Missing token"},400);let i=await s.verifySignedUrl(r);if(i.bucket!==e||i.path!==n)return t.json({error:"Invalid token"},403);let o=nc(t.req.query()),a=await s.download(e,n,{transform:o??void 0});return new Response(a.body,{headers:rc(a.metadata)})}).put("/object/upload/sign/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/upload/sign/${e}/`),r=t.req.query("token"),{storageService:s}=t.var;if(!r)return t.json({error:"Missing token"},400);let i=await s.verifySignedUrl(r);if(i.bucket!==e||i.path!==n||i.intent!=="upload")return t.json({error:"Invalid token"},403);let o=t.req.header("content-type")??"application/octet-stream",a=t.req.header("content-length")?Number.parseInt(t.req.header("content-length"),10):void 0,l=t.req.raw.body??new Uint8Array(await t.req.arrayBuffer()),c=await s.upload(e,n,l,{contentType:o,contentLength:a,upsert:true});return t.json({Key:c.name},200)}),FS=new Se().use(gs()).post("/bucket",Dt("json",NS),async t=>{let e=t.req.valid("json"),{storageService:n}=t.var,r=await n.createBucket({id:e.id,name:e.name??e.id,public:e.public,file_size_limit:e.file_size_limit,allowed_mime_types:e.allowed_mime_types});return t.json({name:r.name},200)}).get("/bucket",async t=>{let{storageService:e}=t.var,n=await e.listBuckets();return t.json(n,200)}).get("/bucket/:id",async t=>{let{storageService:e}=t.var,n=await e.getBucket(t.req.param("id"));return t.json(n,200)}).put("/bucket/:id",Dt("json",IS),async t=>{let{storageService:e}=t.var;return await e.updateBucket(t.req.param("id"),t.req.valid("json")),t.json({message:"Successfully updated"},200)}).delete("/bucket/:id",async t=>{let{storageService:e}=t.var;return await e.deleteBucket(t.req.param("id")),t.json({message:"Successfully deleted"},200)}).post("/bucket/:id/empty",async t=>{let{storageService:e}=t.var;return await e.emptyBucket(t.req.param("id")),t.json({message:"Empty bucket has been queued. Completion may take up to an hour."},200)}).post("/object/list/:bucketId",Dt("json",DS),async t=>{let e=t.req.param("bucketId"),n=t.req.valid("json"),{storageService:r}=t.var,s=await r.list(e,n.prefix,{limit:n.limit,offset:n.offset,sortBy:n.sortBy,search:n.search});return t.json(s,200)}).post("/object/move",Dt("json",Yp),async t=>{let e=t.req.valid("json"),{storageService:n}=t.var;return await n.move(e.bucketId,e.sourceKey,e.destinationKey),t.json({message:"Successfully moved"},200)}).post("/object/copy",Dt("json",Yp),async t=>{let e=t.req.valid("json"),{storageService:n}=t.var,r=await n.copy(e.bucketId,e.sourceKey,e.destinationKey);return t.json({key:r.key},200)}).get("/object/info/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/info/${e}/`),{storageService:r}=t.var,s=await r.info(e,n);return t.json(s,200)}).post("/object/sign/:bucketId/*",Dt("json",jS),async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/sign/${e}/`),{expiresIn:r}=t.req.valid("json"),{storageService:s}=t.var,i=await s.createSignedUrl(e,n,r);return t.json(i,200)}).post("/object/sign/:bucketId",Dt("json",LS),async t=>{let e=t.req.param("bucketId"),{expiresIn:n,paths:r}=t.req.valid("json"),{storageService:s}=t.var,i=await s.createSignedUrls(e,r,n);return t.json(i,200)}).post("/object/upload/sign/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/upload/sign/${e}/`),{storageService:r}=t.var,s=await r.createSignedUploadUrl(e,n);return t.json(s,200)}).delete("/object/:bucketId",Dt("json",US),async t=>{let e=t.req.param("bucketId"),{prefixes:n}=t.req.valid("json"),{storageService:r}=t.var,s=await r.remove(e,n);return t.json(s,200)}).post("/object/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/${e}/`),{storageService:r}=t.var,s=t.req.header("content-type")??"application/octet-stream",i=t.req.header("cache-control")??"no-cache",o=t.req.header("x-upsert")==="true",a,l,c;if(s.startsWith("multipart/form-data")){let d=(await t.req.formData()).get("file");if(!d)throw new H(400,"InvalidRequest","Missing file in multipart upload");let p=new Uint8Array(await d.arrayBuffer());a=p,l=d.type||"application/octet-stream",c=p.length;}else a=t.req.raw.body??new Uint8Array(await t.req.arrayBuffer()),l=s,c=t.req.header("content-length")?Number.parseInt(t.req.header("content-length"),10):void 0;let f=await r.upload(e,n,a,{contentType:l,cacheControl:i,contentLength:c,upsert:o,owner:t.get("userId")??null});return t.json({Key:`${e}/${f.name}`,Id:f.id},200)}).put("/object/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/${e}/`),{storageService:r}=t.var,s=t.req.header("content-type")??"application/octet-stream",i=t.req.header("cache-control")??"no-cache",o=t.req.header("content-length")?Number.parseInt(t.req.header("content-length"),10):void 0,a=t.req.raw.body??new Uint8Array(await t.req.arrayBuffer()),l=await r.update(e,n,a,{contentType:s,cacheControl:i,contentLength:o,owner:t.get("userId")??null});return t.json({Key:`${e}/${l.name}`,Id:l.id},200)}).get("/object/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/${e}/`),{storageService:r}=t.var,s=nc(t.req.query()),i=await r.download(e,n,{transform:s??void 0});return new Response(i.body,{headers:rc(i.metadata)})}).on("HEAD","/object/:bucketId/*",async t=>{let e=t.req.param("bucketId"),n=dt(t.req.path,`/object/${e}/`),{storageService:r}=t.var;return await r.exists(e,n)?t.body(null,200):t.body(null,404)}),sc=new Se().onError((t,e)=>t instanceof H?e.json(t.toJSON(),400):(console.error("Storage error:",t),e.json({error:"server_error",message:"Internal server error"},500))).route("/",MS).route("/",FS);function dt(t,e){let n=t.replace(/^\/storage\/v1/,""),r=n.indexOf(e);return r===-1?n.split("/").slice(3).join("/"):n.slice(r+e.length)}function nc(t){let{width:e,height:n,resize:r,format:s,quality:i}=t;return !e&&!n&&!r&&!s&&!i?null:{width:e?Number.parseInt(e,10):void 0,height:n?Number.parseInt(n,10):void 0,resize:r,format:s,quality:i?Number.parseInt(i,10):void 0}}function rc(t){let e={"Content-Type":t.mimetype,"Cache-Control":t.cacheControl,ETag:t.eTag};return t.contentLength&&(e["Content-Length"]=String(t.contentLength)),t.lastModified&&(e["Last-Modified"]=t.lastModified.toUTCString()),t.contentRange&&(e["Content-Range"]=t.contentRange),e}Qr();var ic=`-- supabase/storage core schema (Postgres)
|
|
89
95
|
-- Source: supabase/storage migrations (consolidated)
|
|
90
96
|
|
|
91
97
|
CREATE SCHEMA IF NOT EXISTS storage;
|
|
@@ -120,11 +126,11 @@ CREATE TABLE IF NOT EXISTS storage.objects (
|
|
|
120
126
|
);
|
|
121
127
|
|
|
122
128
|
CREATE INDEX IF NOT EXISTS storage_objects_name_pattern_search ON storage.objects (name text_pattern_ops);
|
|
123
|
-
`;function Wl(s=true){return s?js(Jl):Jl}var ia=class{driver=null;requiresBuffer=false;async transform(e,r){return {body:e,contentType:"application/octet-stream",contentLength:e.byteLength}}};function cm(s){if(!s._storageAdapter)throw V.storageNotConfigured();let e=s.connection.dialect,r=new tn(s.connection.kysely,e),t=s.config.auth?.jwt_secret??"secret",n=s._transformationAdapter??new ia;return new rn(r,s._storageAdapter,{jwtSecret:t,fileSizeLimit:s.config.storage?.file_size_limit?qS(s.config.storage.file_size_limit):void 0,buckets:s.config.storage?.buckets},{autoCreateBuckets:true},n)}function qS(s){let e=s.match(/^(\d+(?:\.\d+)?)\s*(B|KB|KiB|MB|MiB|GB|GiB)$/i);if(!e)return 0;let r=Number.parseFloat(e[1]),t=e[2].toUpperCase();return Math.floor(r*({B:1,KB:1e3,KIB:1024,MB:1e6,MIB:1048576,GB:1e9,GIB:1073741824}[t]??1))}var Ye=Symbol("RENDERER"),Zt=Symbol("ERROR_HANDLER"),z=Symbol("STASH"),aa=Symbol("INTERNAL"),Hl=Symbol("MEMO"),Yr=Symbol("PERMALINK");var Gl=s=>(s[aa]=true,s);var Vl=s=>({value:e,children:r})=>{if(!r)return;let t={children:[{tag:Gl(()=>{s.push(e);}),props:{}}]};Array.isArray(r)?t.children.push(...r.flat()):t.children.push(r),t.children.push({tag:Gl(()=>{s.pop();}),props:{}});let n={tag:"",props:t,type:""};return n[Zt]=i=>{throw s.pop(),i},n},oa=s=>{let e=[s],r=Vl(e);return r.values=e,r.Provider=r,Dt.push(r),r};var Dt=[],sn=s=>{let e=[s],r=(t=>{e.push(t.value);let n;try{n=t.children?(Array.isArray(t.children)?new Kl("",{},t.children):t.children).toString():"";}catch(i){throw e.pop(),i}return n instanceof Promise?n.finally(()=>e.pop()).then(i=>G(i,i.callbacks)):(e.pop(),G(n))});return r.values=e,r.Provider=r,r[Ye]=Vl(e),Dt.push(r),r},Te=s=>s.values.at(-1);var zr={title:[],script:["src"],style:["data-href"],link:["href"],meta:["name","httpEquiv","charset","itemProp"]},nn={},Xr="data-precedence";var ln={};Fn(ln,{button:()=>zS,form:()=>KS,input:()=>YS,link:()=>GS,meta:()=>VS,script:()=>WS,style:()=>HS,title:()=>JS});var Cr=s=>Array.isArray(s)?s:[s];var pm=new WeakMap,fm=(s,e,r,t)=>({buffer:n,context:i})=>{if(!n)return;let a=pm.get(i)||{};pm.set(i,a);let o=a[s]||=[],l=false,u=zr[s];if(u.length>0){e:for(let[,p]of o)for(let c of u)if((p?.[c]??null)===r?.[c]){l=true;break e}}if(l?n[0]=n[0].replaceAll(e,""):u.length>0?o.push([e,r,t]):o.unshift([e,r,t]),n[0].indexOf("</head>")!==-1){let p;if(t===void 0)p=o.map(([c])=>c);else {let c=[];p=o.map(([f,,m])=>{let d=c.indexOf(m);return d===-1&&(c.push(m),d=c.length-1),[f,d]}).sort((f,m)=>f[1]-m[1]).map(([f])=>f);}p.forEach(c=>{n[0]=n[0].replaceAll(c,"");}),n[0]=n[0].replace(/(?=<\/head>)/,p.join(""));}},an=(s,e,r)=>G(new Fe(s,r,Cr(e??[])).toString()),on=(s,e,r,t)=>{if("itemProp"in r)return an(s,e,r);let{precedence:n,blocking:i,...a}=r;n=t?n??"":void 0,t&&(a[Xr]=n);let o=new Fe(s,a,Cr(e||[])).toString();return o instanceof Promise?o.then(l=>G(o,[...l.callbacks||[],fm(s,l,a,n)])):G(o,[fm(s,o,a,n)])},JS=({children:s,...e})=>{let r=la();if(r){let t=Te(r);if(t==="svg"||t==="head")return new Fe("title",e,Cr(s??[]))}return on("title",s,e,false)},WS=({children:s,...e})=>{let r=la();return ["src","async"].some(t=>!e[t])||r&&Te(r)==="head"?an("script",s,e):on("script",s,e,false)},HS=({children:s,...e})=>["href","precedence"].every(r=>r in e)?(e["data-href"]=e.href,delete e.href,on("style",s,e,true)):an("style",s,e),GS=({children:s,...e})=>["onLoad","onError"].some(r=>r in e)||e.rel==="stylesheet"&&(!("precedence"in e)||"disabled"in e)?an("link",s,e):on("link",s,e,"precedence"in e),VS=({children:s,...e})=>{let r=la();return r&&Te(r)==="head"?an("meta",s,e):on("meta",s,e,false)},mm=(s,{children:e,...r})=>new Fe(s,r,Cr(e??[])),KS=s=>(typeof s.action=="function"&&(s.action=Yr in s.action?s.action[Yr]:void 0),mm("form",s)),hm=(s,e)=>(typeof e.formAction=="function"&&(e.formAction=Yr in e.formAction?e.formAction[Yr]:void 0),mm(s,e)),YS=s=>hm("input",s),zS=s=>hm("button",s);var XS=new Map([["className","class"],["htmlFor","for"],["crossOrigin","crossorigin"],["httpEquiv","http-equiv"],["itemProp","itemprop"],["fetchPriority","fetchpriority"],["noModule","nomodule"],["formAction","formaction"]]),Qr=s=>XS.get(s)||s,un=(s,e)=>{for(let[r,t]of Object.entries(s)){let n=r[0]==="-"||!/[A-Z]/.test(r)?r:r.replace(/[A-Z]/g,i=>`-${i.toLowerCase()}`);e(n,t==null?null:typeof t=="number"?n.match(/^(?:a|border-im|column(?:-c|s)|flex(?:$|-[^b])|grid-(?:ar|[^a])|font-w|li|or|sca|st|ta|wido|z)|ty$/)?`${t}`:`${t}px`:t);}};var cn=void 0,la=()=>cn,QS=s=>/[A-Z]/.test(s)&&s.match(/^(?:al|basel|clip(?:Path|Rule)$|co|do|fill|fl|fo|gl|let|lig|i|marker[EMS]|o|pai|pointe|sh|st[or]|text[^L]|tr|u|ve|w)/)?s.replace(/([A-Z])/g,"-$1").toLowerCase():s,ZS=["area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr"],eb=["allowfullscreen","async","autofocus","autoplay","checked","controls","default","defer","disabled","download","formnovalidate","hidden","inert","ismap","itemscope","loop","multiple","muted","nomodule","novalidate","open","playsinline","readonly","required","reversed","selected"],zl=(s,e)=>{for(let r=0,t=s.length;r<t;r++){let n=s[r];if(typeof n=="string")Tt(n,e);else {if(typeof n=="boolean"||n===null||n===void 0)continue;n instanceof Fe?n.toStringToBuffer(e):typeof n=="number"||n.isEscaped?e[0]+=n:n instanceof Promise?e.unshift("",n):zl(n,e);}}},Fe=class{tag;props;key;children;isEscaped=true;localContexts;constructor(s,e,r){this.tag=s,this.props=e,this.children=r;}get type(){return this.tag}get ref(){return this.props.ref||null}toString(){let s=[""];this.localContexts?.forEach(([e,r])=>{e.values.push(r);});try{this.toStringToBuffer(s);}finally{this.localContexts?.forEach(([e])=>{e.values.pop();});}return s.length===1?"callbacks"in s?so(G(s[0],s.callbacks)).toString():s[0]:ui(s,s.callbacks)}toStringToBuffer(s){let e=this.tag,r=this.props,{children:t}=this;s[0]+=`<${e}`;let n=cn&&Te(cn)==="svg"?i=>QS(Qr(i)):i=>Qr(i);for(let[i,a]of Object.entries(r))if(i=n(i),i!=="children"){if(i==="style"&&typeof a=="object"){let o="";un(a,(l,u)=>{u!=null&&(o+=`${o?";":""}${l}:${u}`);}),s[0]+=' style="',Tt(o,s),s[0]+='"';}else if(typeof a=="string")s[0]+=` ${i}="`,Tt(a,s),s[0]+='"';else if(a!=null)if(typeof a=="number"||a.isEscaped)s[0]+=` ${i}="${a}"`;else if(typeof a=="boolean"&&eb.includes(i))a&&(s[0]+=` ${i}=""`);else if(i==="dangerouslySetInnerHTML"){if(t.length>0)throw new Error("Can only set one of `children` or `props.dangerouslySetInnerHTML`.");t=[G(a.__html)];}else if(a instanceof Promise)s[0]+=` ${i}="`,s.unshift('"',a);else if(typeof a=="function"){if(!i.startsWith("on")&&i!=="ref")throw new Error(`Invalid prop '${i}' of type 'function' supplied to '${e}'.`)}else s[0]+=` ${i}="`,Tt(a.toString(),s),s[0]+='"';}if(ZS.includes(e)&&t.length===0){s[0]+="/>";return}s[0]+=">",zl(t,s),s[0]+=`</${e}>`;}},Yl=class extends Fe{toStringToBuffer(s){let{children:e}=this,r={...this.props};e.length&&(r.children=e.length===1?e[0]:e);let t=this.tag.call(null,r);if(!(typeof t=="boolean"||t==null))if(t instanceof Promise)if(Dt.length===0)s.unshift("",t);else {let n=Dt.map(i=>[i,i.values.at(-1)]);s.unshift("",t.then(i=>(i instanceof Fe&&(i.localContexts=n),i)));}else t instanceof Fe?t.toStringToBuffer(s):typeof t=="number"||t.isEscaped?(s[0]+=t,t.callbacks&&(s.callbacks||=[],s.callbacks.push(...t.callbacks))):Tt(t,s);}},Kl=class extends Fe{toStringToBuffer(s){zl(this.children,s);}},dm=false,pn=(s,e,r)=>{if(!dm){for(let t in nn)ln[t][Ye]=nn[t];dm=true;}return typeof s=="function"?new Yl(s,e,r):ln[s]?new Yl(ln[s],e,r):s==="svg"||s==="head"?(cn||=sn(""),new Fe(s,e,[new Yl(cn,{value:s},r)])):new Fe(s,e,r)};var ft=({children:s})=>new Kl("",{children:s},Array.isArray(s)?s:s?[s]:[]);var fa={};Fn(fa,{button:()=>qm,clearCache:()=>fb,composeRef:()=>pa,form:()=>Bm,input:()=>Fm,link:()=>jm,meta:()=>xm,script:()=>Pm,style:()=>Dm,title:()=>$m});var mn="_hp",tb={Change:"Input",DoubleClick:"DblClick"},rb={svg:"2000/svg",math:"1998/Math/MathML"},mt=[],Zl=new WeakMap,Zr=void 0,wm=()=>Zr,jt=s=>"t"in s,Ql={onClick:["click",false]},gm=s=>{if(!s.startsWith("on"))return;if(Ql[s])return Ql[s];let e=s.match(/^on([A-Z][a-zA-Z]+?(?:PointerCapture)?)(Capture)?$/);if(e){let[,r,t]=e;return Ql[s]=[(tb[r]||r).toLowerCase(),!!t]}},ym=(s,e)=>Zr&&s instanceof SVGElement&&/[A-Z]/.test(e)&&(e in s.style||e.match(/^(?:o|pai|str|u|ve)/))?e.replace(/([A-Z])/g,"-$1").toLowerCase():e,sb=(s,e,r)=>{e||={};for(let t in e){let n=e[t];if(t!=="children"&&(!r||r[t]!==n)){t=Qr(t);let i=gm(t);if(i){if(r?.[t]!==n&&(r&&s.removeEventListener(i[0],r[t],i[1]),n!=null)){if(typeof n!="function")throw new Error(`Event handler for "${t}" is not a function`);s.addEventListener(i[0],n,i[1]);}}else if(t==="dangerouslySetInnerHTML"&&n)s.innerHTML=n.__html;else if(t==="ref"){let a;typeof n=="function"?a=n(s)||(()=>n(null)):n&&"current"in n&&(n.current=s,a=()=>n.current=null),Zl.set(s,a);}else if(t==="style"){let a=s.style;typeof n=="string"?a.cssText=n:(a.cssText="",n!=null&&un(n,a.setProperty.bind(a)));}else {if(t==="value"){let o=s.nodeName;if(o==="INPUT"||o==="TEXTAREA"||o==="SELECT"){if(s.value=n==null||n===false?null:n,o==="TEXTAREA"){s.textContent=n;continue}else if(o==="SELECT"){s.selectedIndex===-1&&(s.selectedIndex=0);continue}}}else (t==="checked"&&s.nodeName==="INPUT"||t==="selected"&&s.nodeName==="OPTION")&&(s[t]=n);let a=ym(s,t);n==null||n===false?s.removeAttribute(a):n===true?s.setAttribute(a,""):typeof n=="string"||typeof n=="number"?s.setAttribute(a,n):s.setAttribute(a,n.toString());}}}if(r)for(let t in r){let n=r[t];if(t!=="children"&&!(t in e)){t=Qr(t);let i=gm(t);i?s.removeEventListener(i[0],n,i[1]):t==="ref"?Zl.get(s)?.():s.removeAttribute(ym(s,t));}}},nb=(s,e)=>{e[z][0]=0,mt.push([s,e]);let r=e.tag[Ye]||e.tag,t=r.defaultProps?{...r.defaultProps,...e.props}:e.props;try{return [r.call(null,t)]}finally{mt.pop();}},Cm=(s,e,r,t,n)=>{s.vR?.length&&(t.push(...s.vR),delete s.vR),typeof s.tag=="function"&&s[z][1][tu]?.forEach(i=>n.push(i)),s.vC.forEach(i=>{if(jt(i))r.push(i);else if(typeof i.tag=="function"||i.tag===""){i.c=e;let a=r.length;if(Cm(i,e,r,t,n),i.s){for(let o=a;o<r.length;o++)r[o].s=true;i.s=false;}}else r.push(i),i.vR?.length&&(t.push(...i.vR),delete i.vR);});},ib=s=>{for(;s&&(s.tag===mn||!s.e);)s=s.tag===mn||!s.vC?.[0]?s.nN:s.vC[0];return s?.e},Am=s=>{jt(s)||(s[z]?.[1][tu]?.forEach(e=>e[2]?.()),Zl.get(s.e)?.(),s.p===2&&s.vC?.forEach(e=>e.p=2),s.vC?.forEach(Am)),s.p||(s.e?.remove(),delete s.e),typeof s.tag=="function"&&(fn.delete(s),ua.delete(s),delete s[z][3],s.a=true);},Rm=(s,e,r)=>{s.c=e,_m(s,e,r);},Em=(s,e)=>{if(e){for(let r=0,t=s.length;r<t;r++)if(s[r]===e)return r}},Sm=Symbol(),_m=(s,e,r)=>{let t=[],n=[],i=[];Cm(s,e,t,n,i),n.forEach(Am);let a=r?void 0:e.childNodes,o,l=null;if(r)o=-1;else if(!a.length)o=0;else {let u=Em(a,ib(s.nN));u!==void 0?(l=a[u],o=u):o=Em(a,t.find(p=>p.tag!==mn&&p.e)?.e)??-1,o===-1&&(r=true);}for(let u=0,p=t.length;u<p;u++,o++){let c=t[u],f;if(c.s&&c.e)f=c.e,c.s=false;else {let m=r||!c.e;jt(c)?(c.e&&c.d&&(c.e.textContent=c.t),c.d=false,f=c.e||=document.createTextNode(c.t)):(f=c.e||=c.n?document.createElementNS(c.n,c.tag):document.createElement(c.tag),sb(f,c.props,c.pP),_m(c,f,m));}c.tag===mn?o--:r?f.parentNode||e.appendChild(f):a[o]!==f&&a[o-1]!==f&&(a[o+1]===f?e.appendChild(a[o]):e.insertBefore(f,l||a[o]||null));}if(s.pP&&(s.pP=void 0),i.length){let u=[],p=[];i.forEach(([,c,,f,m])=>{c&&u.push(c),f&&p.push(f),m?.();}),u.forEach(c=>c()),p.length&&requestAnimationFrame(()=>{p.forEach(c=>c());});}},ab=(s,e)=>!!(s&&s.length===e.length&&s.every((r,t)=>r[1]===e[t][1])),ua=new WeakMap,eu=(s,e,r)=>{let t=!r&&e.pC;r&&(e.pC||=e.vC);let n;try{r||=typeof e.tag=="function"?nb(s,e):Cr(e.props.children),r[0]?.tag===""&&r[0][Zt]&&(n=r[0][Zt],s[5].push([s,n,e]));let i=t?[...e.pC]:e.vC?[...e.vC]:void 0,a=[],o;for(let l=0;l<r.length;l++){if(Array.isArray(r[l])){r.splice(l,1,...r[l].flat(1/0)),l--;continue}let u=ob(r[l]);if(u){typeof u.tag=="function"&&!u.tag[aa]&&(Dt.length>0&&(u[z][2]=Dt.map(c=>[c,c.values.at(-1)])),s[5]?.length&&(u[z][3]=s[5].at(-1)));let p;if(i&&i.length){let c=i.findIndex(jt(u)?f=>jt(f):u.key!==void 0?f=>f.key===u.key&&f.tag===u.tag:f=>f.tag===u.tag);c!==-1&&(p=i[c],i.splice(c,1));}if(p)if(jt(u))p.t!==u.t&&(p.t=u.t,p.d=!0),u=p;else {let c=p.pP=p.props;if(p.props=u.props,p.f||=u.f||e.f,typeof u.tag=="function"){let f=p[z][2];p[z][2]=u[z][2]||[],p[z][3]=u[z][3],!p.f&&((p.o||p)===u.o||p.tag[Hl]?.(c,p.props))&&ab(f,p[z][2])&&(p.s=!0);}u=p;}else if(!jt(u)&&Zr){let c=Te(Zr);c&&(u.n=c);}if(!jt(u)&&!u.s&&(eu(s,u),delete u.f),a.push(u),o&&!o.s&&!u.s)for(let c=o;c&&!jt(c);c=c.vC?.at(-1))c.nN=u;o=u;}}e.vR=t?[...e.vC,...i||[]]:i||[],e.vC=a,t&&delete e.pC;}catch(i){if(e.f=true,i===Sm){if(n)return;throw i}let[a,o,l]=e[z]?.[3]||[];if(o){let u=()=>hn([0,false,s[2]],l),p=ua.get(l)||[];p.push(u),ua.set(l,p);let c=o(i,()=>{let f=ua.get(l);if(f){let m=f.indexOf(u);if(m!==-1)return f.splice(m,1),u()}});if(c){if(s[0]===1)s[1]=true;else if(eu(s,l,[c]),(o.length===1||s!==a)&&l.c){Rm(l,l.c,false);return}throw Sm}}throw i}finally{n&&s[5].pop();}},ob=s=>{if(!(s==null||typeof s=="boolean")){if(typeof s=="string"||typeof s=="number")return {t:s.toString(),d:true};if("vR"in s&&(s={tag:s.tag,props:s.props,key:s.key,f:s.f,type:s.tag,ref:s.props.ref,o:s.o||s}),typeof s.tag=="function")s[z]=[0,[]];else {let e=rb[s.tag];e&&(Zr||=oa(""),s.props.children=[{tag:Zr,props:{value:s.n=`http://www.w3.org/${e}`,children:s.props.children}}]);}return s}};var bm=(s,e)=>{e[z][2]?.forEach(([r,t])=>{r.values.push(t);});try{eu(s,e,void 0);}catch{return}if(e.a){delete e.a;return}e[z][2]?.forEach(([r])=>{r.values.pop();}),(s[0]!==1||!s[1])&&Rm(e,e.c,false);},fn=new WeakMap,Tm=[],hn=async(s,e)=>{s[5]||=[];let r=fn.get(e);r&&r[0](void 0);let t,n=new Promise(i=>t=i);if(fn.set(e,[t,()=>{s[2]?s[2](s,e,i=>{bm(i,e);}).then(()=>t(e)):(bm(s,e),t(e));}]),Tm.length)Tm.at(-1).add(e);else {await Promise.resolve();let i=fn.get(e);i&&(fn.delete(e),i[1]());}return n};var vm=(s,e,r)=>({tag:mn,props:{children:s},key:r,e,p:1});var lb=0,tu=1,ub=2,cb=3;var ru=new WeakMap,Nm=(s,e)=>!s||!e||s.length!==e.length||e.some((r,t)=>r!==s[t]);var pb=void 0;var Om=[];var ca=s=>{let e=()=>typeof s=="function"?s():s,r=mt.at(-1);if(!r)return [e(),()=>{}];let[,t]=r,n=t[z][1][lb]||=[],i=t[z][0]++;return n[i]||=[e(),a=>{let o=pb,l=n[i];if(typeof a=="function"&&(a=a(l[0])),!Object.is(a,l[0]))if(l[0]=a,Om.length){let[u,p]=Om.at(-1);Promise.all([u===3?t:hn([u,false,o],t),p]).then(([c])=>{if(!c||!(u===2||u===3))return;let f=c.vC;requestAnimationFrame(()=>{setTimeout(()=>{f===c.vC&&hn([u===3?1:0,false,o],c);});});});}else hn([0,false,o],t);}]};var es=(s,e)=>{let r=mt.at(-1);if(!r)return s;let[,t]=r,n=t[z][1][ub]||=[],i=t[z][0]++,a=n[i];return Nm(a?.[1],e)?n[i]=[s,e]:s=n[i][0],s};var su=s=>{let e=ru.get(s);if(e){if(e.length===2)throw e[1];return e[0]}throw s.then(r=>ru.set(s,[r]),r=>ru.set(s,[void 0,r])),s},nu=(s,e)=>{let r=mt.at(-1);if(!r)return s();let[,t]=r,n=t[z][1][cb]||=[],i=t[z][0]++,a=n[i];return Nm(a?.[1],e)&&(n[i]=[s(),e]),n[i][0]};var Lm=oa({pending:false,data:null,method:null,action:null}),Im=new Set,km=s=>{Im.add(s),s.finally(()=>Im.delete(s));};var fb=()=>{iu=Object.create(null),au=Object.create(null);},pa=(s,e)=>nu(()=>r=>{let t;s&&(typeof s=="function"?t=s(r)||(()=>{s(null);}):s&&"current"in s&&(s.current=r,t=()=>{s.current=null;}));let n=e(r);return ()=>{n?.(),t?.();}},[s]),iu=Object.create(null),au=Object.create(null),dn=(s,e,r,t,n)=>{if(e?.itemProp)return {tag:s,props:e,type:s,ref:e.ref};let i=document.head,{onLoad:a,onError:o,precedence:l,blocking:u,...p}=e,c=null,f=false,m=zr[s],d;if(m.length>0){let T=i.querySelectorAll(s);e:for(let C of T)for(let w of zr[s])if(C.getAttribute(w)===e[w]){c=C;break e}if(!c){let C=m.reduce((w,A)=>e[A]===void 0?w:`${w}-${A}-${e[A]}`,s);f=!au[C],c=au[C]||=(()=>{let w=document.createElement(s);for(let A of m)e[A]!==void 0&&w.setAttribute(A,e[A]),e.rel&&w.setAttribute("rel",e.rel);return w})();}}else d=i.querySelectorAll(s);l=t?l??"":void 0,t&&(p[Xr]=l);let g=es(T=>{if(m.length>0){let C=false;for(let w of i.querySelectorAll(s)){if(C&&w.getAttribute(Xr)!==l){i.insertBefore(T,w);return}w.getAttribute(Xr)===l&&(C=true);}i.appendChild(T);}else if(d){let C=false;for(let w of d)if(w===T){C=true;break}C||i.insertBefore(T,i.contains(d[0])?d[0]:i.querySelector(s)),d=void 0;}},[l]),b=pa(e.ref,T=>{let C=m[0];if(r===2&&(T.innerHTML=""),(f||d)&&g(T),!o&&!a)return;let w=iu[T.getAttribute(C)]||=new Promise((A,v)=>{T.addEventListener("load",A),T.addEventListener("error",v);});a&&(w=w.then(a)),o&&(w=w.catch(o)),w.catch(()=>{});});if(n&&u==="render"){let T=zr[s][0];if(e[T]){let C=e[T],w=iu[C]||=new Promise((A,v)=>{g(c),c.addEventListener("load",A),c.addEventListener("error",v);});su(w);}}let y={tag:s,type:s,props:{...p,ref:b},ref:b};return y.p=r,c&&(y.e=c),vm(y,i)},$m=s=>{let e=wm();return (e&&Te(e))?.endsWith("svg")?{tag:"title",props:s,type:"title",ref:s.ref}:dn("title",s,void 0,false,false)},Pm=s=>!s||["src","async"].some(e=>!s[e])?{tag:"script",props:s,type:"script",ref:s.ref}:dn("script",s,1,false,true),Dm=s=>!s||!["href","precedence"].every(e=>e in s)?{tag:"style",props:s,type:"style",ref:s.ref}:(s["data-href"]=s.href,delete s.href,dn("style",s,2,true,true)),jm=s=>!s||["onLoad","onError"].some(e=>e in s)||s.rel==="stylesheet"&&(!("precedence"in s)||"disabled"in s)?{tag:"link",props:s,type:"link",ref:s.ref}:dn("link",s,1,"precedence"in s,true),xm=s=>dn("meta",s,void 0,false,false),Um=Symbol(),Bm=s=>{let{action:e,...r}=s;typeof e!="function"&&(r.action=e);let[t,n]=ca([null,false]),i=es(async u=>{let p=u.isTrusted?e:u.detail[Um];if(typeof p!="function")return;u.preventDefault();let c=new FormData(u.target);n([c,true]);let f=p(c);f instanceof Promise&&(km(f),await f),n([null,true]);},[]),a=pa(s.ref,u=>(u.addEventListener("submit",i),()=>{u.removeEventListener("submit",i);})),[o,l]=t;return t[1]=false,{tag:Lm,props:{value:{pending:o!==null,data:o,method:o?"post":null,action:o?e:null},children:{tag:"form",props:{...r,ref:a},type:"form",ref:a}},f:l}},Mm=(s,{formAction:e,...r})=>{if(typeof e=="function"){let t=es(n=>{n.preventDefault(),n.currentTarget.form.dispatchEvent(new CustomEvent("submit",{detail:{[Um]:e}}));},[]);r.ref=pa(r.ref,n=>(n.addEventListener("click",t),()=>{n.removeEventListener("click",t);}));}return {tag:s,props:r,type:s,ref:r.ref}},Fm=s=>Mm("input",s),qm=s=>Mm("button",s);Object.assign(nn,{title:$m,script:Pm,style:Dm,link:jm,meta:xm,form:Bm,input:Fm,button:qm});sn(null);new TextEncoder;var Ar=":-hono-global",gb=new RegExp(`^${Ar}{(.*)}$`),da="hono-css",xt=Symbol(),ge=Symbol(),Pe=Symbol(),ht=Symbol(),ga=Symbol(),Vm=Symbol();var Km=s=>{let e=0,r=11;for(;e<s.length;)r=101*r+s.charCodeAt(e++)>>>0;return "css-"+r},yb=['"(?:(?:\\\\[\\s\\S]|[^"\\\\])*)"',"'(?:(?:\\\\[\\s\\S]|[^'\\\\])*)'"].join("|"),Eb=new RegExp(["("+yb+")","(?:"+["^\\s+","\\/\\*.*?\\*\\/\\s*","\\/\\/.*\\n\\s*","\\s+$"].join("|")+")","\\s*;\\s*(}|$)\\s*","\\s*([{};:,])\\s*","(\\s)\\s+"].join("|"),"g"),Sb=s=>s.replace(Eb,(e,r,t,n,i)=>r||t||n||i||""),Ym=(s,e)=>{let r=[],t=[],n=s[0].match(/^\s*\/\*(.*?)\*\//)?.[1]||"",i="";for(let a=0,o=s.length;a<o;a++){i+=s[a];let l=e[a];if(!(typeof l=="boolean"||l===null||l===void 0)){Array.isArray(l)||(l=[l]);for(let u=0,p=l.length;u<p;u++){let c=l[u];if(!(typeof c=="boolean"||c===null||c===void 0))if(typeof c=="string")/([\\"'\/])/.test(c)?i+=c.replace(/([\\"']|(?<=<)\/)/g,"\\$1"):i+=c;else if(typeof c=="number")i+=c;else if(c[Vm])i+=c[Vm];else if(c[ge].startsWith("@keyframes "))r.push(c),i+=` ${c[ge].substring(11)} `;else {if(s[a+1]?.match(/^\s*{/))r.push(c),c=`.${c[ge]}`;else {r.push(...c[ht]),t.push(...c[ga]),c=c[Pe];let f=c.length;if(f>0){let m=c[f-1];m!==";"&&m!=="}"&&(c+=";");}}i+=`${c||""}`;}}}}return [n,Sb(i),r,t]},ts=(s,e)=>{let[r,t,n,i]=Ym(s,e),a=gb.exec(t);a&&(t=a[1]);let o=(a?Ar:"")+Km(r+t),l=(a?n.map(u=>u[ge]):[o,...i]).join(" ");return {[xt]:o,[ge]:l,[Pe]:t,[ht]:n,[ga]:i}},ya=s=>{for(let e=0,r=s.length;e<r;e++){let t=s[e];typeof t=="string"&&(s[e]={[xt]:"",[ge]:"",[Pe]:"",[ht]:[],[ga]:[t]});}return s},Ea=(s,...e)=>{let[r,t]=Ym(s,e);return {[xt]:"",[ge]:`@keyframes ${Km(r+t)}`,[Pe]:t,[ht]:[],[ga]:[]}},bb=0,Sa=((s,e)=>{s||(s=[`/* h-v-t ${bb++} */`]);let r=Array.isArray(s)?ts(s,e):s,t=r[ge],n=ts(["view-transition-name:",""],[t]);return r[ge]=Ar+r[ge],r[Pe]=r[Pe].replace(/(?<=::view-transition(?:[a-z-]*)\()(?=\))/g,t),n[ge]=n[xt]=t,n[ht]=[...r[ht],r],n});var wb=s=>{let e=[],r=0,t=0;for(let n=0,i=s.length;n<i;n++){let a=s[n];if(a==="'"||a==='"'){let o=a;for(n++;n<i;n++){if(s[n]==="\\"){n++;continue}if(s[n]===o)break}continue}if(a==="{"){t++;continue}if(a==="}"){t--,t===0&&(e.push(s.slice(r,n+1)),r=n+1);continue}}return e},uu=({id:s})=>{let e,r=()=>(e||(e=document.querySelector(`style#${s}`)?.sheet,e&&(e.addedStyles=new Set)),e?[e,e.addedStyles]:[]),t=(a,o)=>{let[l,u]=r();if(!l||!u){Promise.resolve().then(()=>{if(!r()[0])throw new Error("style sheet not found");t(a,o);});return}u.has(a)||(u.add(a),(a.startsWith(Ar)?wb(o):[`${a[0]==="@"?"":"."}${a}{${o}}`]).forEach(p=>{l.insertRule(p,l.cssRules.length);}));};return [{toString(){let a=this[xt];return t(a,this[Pe]),this[ht].forEach(({[ge]:o,[Pe]:l})=>{t(o,l);}),this[ge]}},({children:a,nonce:o})=>({tag:"style",props:{id:s,nonce:o,children:a&&(Array.isArray(a)?a:[a]).map(l=>l[Pe])}})]};var Ab=({id:s})=>{let[e,r]=uu({id:s}),t=new WeakMap,n=new WeakMap,i=new RegExp(`(<style id="${s}"(?: nonce="[^"]*")?>.*?)(</style>)`),a=f=>{let m=({buffer:y,context:T})=>{let[C,w]=t.get(T),A=Object.keys(C);if(!A.length)return;let v="";if(A.forEach(_=>{w[_]=true,v+=_.startsWith(Ar)?C[_]:`${_[0]==="@"?"":"."}${_}{${C[_]}}`;}),t.set(T,[{},w]),y&&i.test(y[0])){y[0]=y[0].replace(i,(_,I,K)=>`${I}${v}${K}`);return}let R=n.get(T),O=`<script${R?` nonce="${R}"`:""}>document.querySelector('#${s}').textContent+=${JSON.stringify(v)}</script>`;if(y){y[0]=`${O}${y[0]}`;return}return Promise.resolve(O)},d=({context:y})=>{t.has(y)||t.set(y,[{},{}]);let[T,C]=t.get(y),w=true;if(C[f[xt]]||(w=false,T[f[xt]]=f[Pe]),f[ht].forEach(({[ge]:A,[Pe]:v})=>{C[A]||(w=false,T[A]=v);}),!w)return Promise.resolve(G("",[m]))},g=new String(f[ge]);Object.assign(g,f),g.isEscaped=true,g.callbacks=[d];let b=Promise.resolve(g);return Object.assign(b,f),b.toString=e.toString,b},o=(f,...m)=>a(ts(f,m)),l=(...f)=>(f=ya(f),o(Array(f.length).fill(""),...f)),u=Ea,p=((f,...m)=>a(Sa(f,m))),c=({children:f,nonce:m}={})=>G(`<style id="${s}"${m?` nonce="${m}"`:""}>${f?f[Pe]:""}</style>`,[({context:d})=>{n.set(d,m);}]);return c[Ye]=r,{css:o,cx:l,keyframes:u,viewTransition:p,Style:c}},yn=Ab({id:da}),zm=yn.Style;function ye(s,e,r){let t;if(!e||!("children"in e))t=pn(s,e,[]);else {let n=e.children;t=Array.isArray(n)?pn(s,e,n):pn(s,e,[n]);}return t.key=r,t}var cu=new be().get("/*",async s=>{let e={js:"main.js",css:["styles.css"]},r="/static/",t=await Promise.resolve().then(()=>qn(Xm())).then(n=>n.default);try{let n=Object.values(t).find(i=>i.isEntry);if(!n)throw new Error("No entry found in manifest");e.js=n?.file,e.css=n?.css??[];}catch(n){console.warn("Couldn't find assets in manifest",n);}return s.html(ye(ft,{children:ye("html",{lang:"en","data-theme":"dark",style:"color-scheme: dark",class:"dark",children:[ye("head",{children:[ye("meta",{charset:"UTF-8"}),ye("meta",{name:"viewport",content:"width=device-width, initial-scale=1, maximum-scale=1"}),ye("link",{rel:"icon",href:r+"favicon.ico",type:"image/x-icon"}),ye("title",{children:"Supalite"}),ye(ft,{children:[ye("script",{type:"module",src:r+e?.js}),e?.css.map((n,i)=>ye("link",{rel:"stylesheet",href:r+n},i))]}),ye(zm,{})]}),ye("body",{children:ye("div",{id:"root"})})]})}))});async function _b(s){return cu.fetch(s)}var vb={storage:"EXPERIMENTAL_STORAGE",cloud:"EXPERIMENTAL_CLOUD"},Qm=["storage","cloud"],fu=Object.fromEntries(Qm.map(s=>[s,Ob(s)]));function Ob(s){let e=typeof process<"u"&&process.env||void 0;return e?e.NODE_ENV==="test"?true:e[vb[s]]==="1":false}function rs(s){return fu[s]}function Nb(s,e){fu[s]=e;}function Zm(){return Qm.filter(s=>fu[s])}function Ib(){let s=Zm();if(s.length===0)return null;let e=s.includes("storage")?" Cloud sync (lite cloud deploy) is disabled.":"";return `EXPERIMENTAL FEATURES ENABLED: ${s.join(", ")} - not supported, do not use in production.${e}`}var pu=false;function eh(s=e=>console.warn(e)){if(pu)return;if(typeof process<"u"&&process.env?.NODE_ENV==="test"){pu=true;return}let e=Ib();e&&s(e),pu=true;}function th(s,e={}){let r=e.middlewares??[async(t,n)=>{await n();}];return new be().use(async(t,n)=>{t.set("app",s),s.config.auth?.enabled&&t.set("authService",nm(s)),s.config.storage?.enabled&&s._storageAdapter&&rs("storage")&&t.set("storageService",cm(s)),await n();}).use(...r).use(Dl()).route("/auth/v1",jl).route("/rest/v1",bf({forceRollback:e.forceRollback})).use("/storage/v1/*",async(t,n)=>{if(!rs("storage"))return t.notFound();await n();}).route("/storage/v1",ql).route("/_system",Oc).use(async(t,n)=>{if(!e.disableStudio&&s.config.studio?.enabled)return cu.fetch(t.req.raw);if(!e.disableFallback)return t.notFound();await n();})}var Lb=s=>{let e=s.toJSON();return Ft(e)},mu=class extends Error{constructor(r,t,n=[]){super(`Invalid schema given for ${JSON.stringify(t,null,2)}
|
|
129
|
+
`;function oc(t=true){return t?Vr(ic):ic}var go=class{driver=null;requiresBuffer=false;async transform(e,n){return {body:e,contentType:"application/octet-stream",contentLength:e.byteLength}}};function Zp(t){if(!t._storageAdapter)throw H.storageNotConfigured();let e=t.connection.dialect,n=new ys(t.connection.kysely,e),r=t.config.auth?.jwt_secret??"secret",s=t._transformationAdapter??new go;return new bs(n,t._storageAdapter,{jwtSecret:r,fileSizeLimit:t.config.storage?.file_size_limit?qS(t.config.storage.file_size_limit):void 0,buckets:t.config.storage?.buckets},{autoCreateBuckets:true},s)}function qS(t){let e=t.match(/^(\d+(?:\.\d+)?)\s*(B|KB|KiB|MB|MiB|GB|GiB)$/i);if(!e)return 0;let n=Number.parseFloat(e[1]),r=e[2].toUpperCase();return Math.floor(n*({B:1,KB:1e3,KIB:1024,MB:1e6,MIB:1048576,GB:1e9,GIB:1073741824}[r]??1))}var Ve=Symbol("RENDERER"),rn=Symbol("ERROR_HANDLER"),V=Symbol("STASH"),yo=Symbol("INTERNAL"),ac=Symbol("MEMO"),ir=Symbol("PERMALINK");var lc=t=>(t[yo]=true,t);var cc=t=>({value:e,children:n})=>{if(!n)return;let r={children:[{tag:lc(()=>{t.push(e);}),props:{}}]};Array.isArray(n)?r.children.push(...n.flat()):r.children.push(n),r.children.push({tag:lc(()=>{t.pop();}),props:{}});let s={tag:"",props:r,type:""};return s[rn]=i=>{throw t.pop(),i},s},bo=t=>{let e=[t],n=cc(e);return n.values=e,n.Provider=n,jt.push(n),n};var jt=[],ws=t=>{let e=[t],n=(r=>{e.push(r.value);let s;try{s=r.children?(Array.isArray(r.children)?new uc("",{},r.children):r.children).toString():"";}catch(i){throw e.pop(),i}return s instanceof Promise?s.finally(()=>e.pop()).then(i=>K(i,i.callbacks)):(e.pop(),K(s))});return n.values=e,n.Provider=n,n[Ve]=cc(e),jt.push(n),n},Ee=t=>t.values.at(-1);var or={title:[],script:["src"],style:["data-href"],link:["href"],meta:["name","httpEquiv","charset","itemProp"]},Ss={},ar="data-precedence";var xs={};xr(xs,{button:()=>QS,form:()=>GS,input:()=>VS,link:()=>HS,meta:()=>zS,script:()=>JS,style:()=>KS,title:()=>WS});var An=t=>Array.isArray(t)?t:[t];var em=new WeakMap,tm=(t,e,n,r)=>({buffer:s,context:i})=>{if(!s)return;let o=em.get(i)||{};em.set(i,o);let a=o[t]||=[],l=false,c=or[t];if(c.length>0){e:for(let[,f]of a)for(let u of c)if((f?.[u]??null)===n?.[u]){l=true;break e}}if(l?s[0]=s[0].replaceAll(e,""):c.length>0?a.push([e,n,r]):a.unshift([e,n,r]),s[0].indexOf("</head>")!==-1){let f;if(r===void 0)f=a.map(([u])=>u);else {let u=[];f=a.map(([d,,p])=>{let y=u.indexOf(p);return y===-1&&(u.push(p),y=u.length-1),[d,y]}).sort((d,p)=>d[1]-p[1]).map(([d])=>d);}f.forEach(u=>{s[0]=s[0].replaceAll(u,"");}),s[0]=s[0].replace(/(?=<\/head>)/,f.join(""));}},Es=(t,e,n)=>K(new Be(t,n,An(e??[])).toString()),_s=(t,e,n,r)=>{if("itemProp"in n)return Es(t,e,n);let{precedence:s,blocking:i,...o}=n;s=r?s??"":void 0,r&&(o[ar]=s);let a=new Be(t,o,An(e||[])).toString();return a instanceof Promise?a.then(l=>K(a,[...l.callbacks||[],tm(t,l,o,s)])):K(a,[tm(t,a,o,s)])},WS=({children:t,...e})=>{let n=wo();if(n){let r=Ee(n);if(r==="svg"||r==="head")return new Be("title",e,An(t??[]))}return _s("title",t,e,false)},JS=({children:t,...e})=>{let n=wo();return ["src","async"].some(r=>!e[r])||n&&Ee(n)==="head"?Es("script",t,e):_s("script",t,e,false)},KS=({children:t,...e})=>["href","precedence"].every(n=>n in e)?(e["data-href"]=e.href,delete e.href,_s("style",t,e,true)):Es("style",t,e),HS=({children:t,...e})=>["onLoad","onError"].some(n=>n in e)||e.rel==="stylesheet"&&(!("precedence"in e)||"disabled"in e)?Es("link",t,e):_s("link",t,e,"precedence"in e),zS=({children:t,...e})=>{let n=wo();return n&&Ee(n)==="head"?Es("meta",t,e):_s("meta",t,e,false)},nm=(t,{children:e,...n})=>new Be(t,n,An(e??[])),GS=t=>(typeof t.action=="function"&&(t.action=ir in t.action?t.action[ir]:void 0),nm("form",t)),rm=(t,e)=>(typeof e.formAction=="function"&&(e.formAction=ir in e.formAction?e.formAction[ir]:void 0),nm(t,e)),VS=t=>rm("input",t),QS=t=>rm("button",t);var XS=new Map([["className","class"],["htmlFor","for"],["crossOrigin","crossorigin"],["httpEquiv","http-equiv"],["itemProp","itemprop"],["fetchPriority","fetchpriority"],["noModule","nomodule"],["formAction","formaction"]]),lr=t=>XS.get(t)||t,vs=(t,e)=>{for(let[n,r]of Object.entries(t)){let s=n[0]==="-"||!/[A-Z]/.test(n)?n:n.replace(/[A-Z]/g,i=>`-${i.toLowerCase()}`);e(s,r==null?null:typeof r=="number"?s.match(/^(?:a|border-im|column(?:-c|s)|flex(?:$|-[^b])|grid-(?:ar|[^a])|font-w|li|or|sca|st|ta|wido|z)|ty$/)?`${r}`:`${r}px`:r);}};var Cs=void 0,wo=()=>Cs,YS=t=>/[A-Z]/.test(t)&&t.match(/^(?:al|basel|clip(?:Path|Rule)$|co|do|fill|fl|fo|gl|let|lig|i|marker[EMS]|o|pai|pointe|sh|st[or]|text[^L]|tr|u|ve|w)/)?t.replace(/([A-Z])/g,"-$1").toLowerCase():t,ZS=["area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr"],eE=["allowfullscreen","async","autofocus","autoplay","checked","controls","default","defer","disabled","download","formnovalidate","hidden","inert","ismap","itemscope","loop","multiple","muted","nomodule","novalidate","open","playsinline","readonly","required","reversed","selected"],dc=(t,e)=>{for(let n=0,r=t.length;n<r;n++){let s=t[n];if(typeof s=="string")_t(s,e);else {if(typeof s=="boolean"||s===null||s===void 0)continue;s instanceof Be?s.toStringToBuffer(e):typeof s=="number"||s.isEscaped?e[0]+=s:s instanceof Promise?e.unshift("",s):dc(s,e);}}},Be=class{tag;props;key;children;isEscaped=true;localContexts;constructor(t,e,n){this.tag=t,this.props=e,this.children=n;}get type(){return this.tag}get ref(){return this.props.ref||null}toString(){let t=[""];this.localContexts?.forEach(([e,n])=>{e.values.push(n);});try{this.toStringToBuffer(t);}finally{this.localContexts?.forEach(([e])=>{e.values.pop();});}return t.length===1?"callbacks"in t?wa(K(t[0],t.callbacks)).toString():t[0]:Si(t,t.callbacks)}toStringToBuffer(t){let e=this.tag,n=this.props,{children:r}=this;t[0]+=`<${e}`;let s=Cs&&Ee(Cs)==="svg"?i=>YS(lr(i)):i=>lr(i);for(let[i,o]of Object.entries(n))if(i=s(i),i!=="children"){if(i==="style"&&typeof o=="object"){let a="";vs(o,(l,c)=>{c!=null&&(a+=`${a?";":""}${l}:${c}`);}),t[0]+=' style="',_t(a,t),t[0]+='"';}else if(typeof o=="string")t[0]+=` ${i}="`,_t(o,t),t[0]+='"';else if(o!=null)if(typeof o=="number"||o.isEscaped)t[0]+=` ${i}="${o}"`;else if(typeof o=="boolean"&&eE.includes(i))o&&(t[0]+=` ${i}=""`);else if(i==="dangerouslySetInnerHTML"){if(r.length>0)throw new Error("Can only set one of `children` or `props.dangerouslySetInnerHTML`.");r=[K(o.__html)];}else if(o instanceof Promise)t[0]+=` ${i}="`,t.unshift('"',o);else if(typeof o=="function"){if(!i.startsWith("on")&&i!=="ref")throw new Error(`Invalid prop '${i}' of type 'function' supplied to '${e}'.`)}else t[0]+=` ${i}="`,_t(o.toString(),t),t[0]+='"';}if(ZS.includes(e)&&r.length===0){t[0]+="/>";return}t[0]+=">",dc(r,t),t[0]+=`</${e}>`;}},fc=class extends Be{toStringToBuffer(t){let{children:e}=this,n={...this.props};e.length&&(n.children=e.length===1?e[0]:e);let r=this.tag.call(null,n);if(!(typeof r=="boolean"||r==null))if(r instanceof Promise)if(jt.length===0)t.unshift("",r);else {let s=jt.map(i=>[i,i.values.at(-1)]);t.unshift("",r.then(i=>(i instanceof Be&&(i.localContexts=s),i)));}else r instanceof Be?r.toStringToBuffer(t):typeof r=="number"||r.isEscaped?(t[0]+=r,r.callbacks&&(t.callbacks||=[],t.callbacks.push(...r.callbacks))):_t(r,t);}},uc=class extends Be{toStringToBuffer(t){dc(this.children,t);}},sm=false,Rs=(t,e,n)=>{if(!sm){for(let r in Ss)xs[r][Ve]=Ss[r];sm=true;}return typeof t=="function"?new fc(t,e,n):xs[t]?new fc(xs[t],e,n):t==="svg"||t==="head"?(Cs||=ws(""),new Be(t,e,[new fc(Cs,{value:t},n)])):new Be(t,e,n)};var pt=({children:t})=>new uc("",{children:t},Array.isArray(t)?t:t?[t]:[]);var xo={};xr(xo,{button:()=>$m,clearCache:()=>dE,composeRef:()=>_o,form:()=>km,input:()=>Om,link:()=>Cm,meta:()=>Rm,script:()=>xm,style:()=>vm,title:()=>_m});var ks="_hp",tE={Change:"Input",DoubleClick:"DblClick"},nE={svg:"2000/svg",math:"1998/Math/MathML"},mt=[],hc=new WeakMap,cr=void 0,fm=()=>cr,Lt=t=>"t"in t,mc={onClick:["click",false]},im=t=>{if(!t.startsWith("on"))return;if(mc[t])return mc[t];let e=t.match(/^on([A-Z][a-zA-Z]+?(?:PointerCapture)?)(Capture)?$/);if(e){let[,n,r]=e;return mc[t]=[(tE[n]||n).toLowerCase(),!!r]}},om=(t,e)=>cr&&t instanceof SVGElement&&/[A-Z]/.test(e)&&(e in t.style||e.match(/^(?:o|pai|str|u|ve)/))?e.replace(/([A-Z])/g,"-$1").toLowerCase():e,rE=(t,e,n)=>{e||={};for(let r in e){let s=e[r];if(r!=="children"&&(!n||n[r]!==s)){r=lr(r);let i=im(r);if(i){if(n?.[r]!==s&&(n&&t.removeEventListener(i[0],n[r],i[1]),s!=null)){if(typeof s!="function")throw new Error(`Event handler for "${r}" is not a function`);t.addEventListener(i[0],s,i[1]);}}else if(r==="dangerouslySetInnerHTML"&&s)t.innerHTML=s.__html;else if(r==="ref"){let o;typeof s=="function"?o=s(t)||(()=>s(null)):s&&"current"in s&&(s.current=t,o=()=>s.current=null),hc.set(t,o);}else if(r==="style"){let o=t.style;typeof s=="string"?o.cssText=s:(o.cssText="",s!=null&&vs(s,o.setProperty.bind(o)));}else {if(r==="value"){let a=t.nodeName;if(a==="INPUT"||a==="TEXTAREA"||a==="SELECT"){if(t.value=s==null||s===false?null:s,a==="TEXTAREA"){t.textContent=s;continue}else if(a==="SELECT"){t.selectedIndex===-1&&(t.selectedIndex=0);continue}}}else (r==="checked"&&t.nodeName==="INPUT"||r==="selected"&&t.nodeName==="OPTION")&&(t[r]=s);let o=om(t,r);s==null||s===false?t.removeAttribute(o):s===true?t.setAttribute(o,""):typeof s=="string"||typeof s=="number"?t.setAttribute(o,s):t.setAttribute(o,s.toString());}}}if(n)for(let r in n){let s=n[r];if(r!=="children"&&!(r in e)){r=lr(r);let i=im(r);i?t.removeEventListener(i[0],s,i[1]):r==="ref"?hc.get(t)?.():t.removeAttribute(om(t,r));}}},sE=(t,e)=>{e[V][0]=0,mt.push([t,e]);let n=e.tag[Ve]||e.tag,r=n.defaultProps?{...n.defaultProps,...e.props}:e.props;try{return [n.call(null,r)]}finally{mt.pop();}},dm=(t,e,n,r,s)=>{t.vR?.length&&(r.push(...t.vR),delete t.vR),typeof t.tag=="function"&&t[V][1][yc]?.forEach(i=>s.push(i)),t.vC.forEach(i=>{if(Lt(i))n.push(i);else if(typeof i.tag=="function"||i.tag===""){i.c=e;let o=n.length;if(dm(i,e,n,r,s),i.s){for(let a=o;a<n.length;a++)n[a].s=true;i.s=false;}}else n.push(i),i.vR?.length&&(r.push(...i.vR),delete i.vR);});},iE=t=>{for(;t&&(t.tag===ks||!t.e);)t=t.tag===ks||!t.vC?.[0]?t.nN:t.vC[0];return t?.e},pm=t=>{Lt(t)||(t[V]?.[1][yc]?.forEach(e=>e[2]?.()),hc.get(t.e)?.(),t.p===2&&t.vC?.forEach(e=>e.p=2),t.vC?.forEach(pm)),t.p||(t.e?.remove(),delete t.e),typeof t.tag=="function"&&(Ts.delete(t),So.delete(t),delete t[V][3],t.a=true);},mm=(t,e,n)=>{t.c=e,hm(t,e,n);},am=(t,e)=>{if(e){for(let n=0,r=t.length;n<r;n++)if(t[n]===e)return n}},lm=Symbol(),hm=(t,e,n)=>{let r=[],s=[],i=[];dm(t,e,r,s,i),s.forEach(pm);let o=n?void 0:e.childNodes,a,l=null;if(n)a=-1;else if(!o.length)a=0;else {let c=am(o,iE(t.nN));c!==void 0?(l=o[c],a=c):a=am(o,r.find(f=>f.tag!==ks&&f.e)?.e)??-1,a===-1&&(n=true);}for(let c=0,f=r.length;c<f;c++,a++){let u=r[c],d;if(u.s&&u.e)d=u.e,u.s=false;else {let p=n||!u.e;Lt(u)?(u.e&&u.d&&(u.e.textContent=u.t),u.d=false,d=u.e||=document.createTextNode(u.t)):(d=u.e||=u.n?document.createElementNS(u.n,u.tag):document.createElement(u.tag),rE(d,u.props,u.pP),hm(u,d,p));}u.tag===ks?a--:n?d.parentNode||e.appendChild(d):o[a]!==d&&o[a-1]!==d&&(o[a+1]===d?e.appendChild(o[a]):e.insertBefore(d,l||o[a]||null));}if(t.pP&&(t.pP=void 0),i.length){let c=[],f=[];i.forEach(([,u,,d,p])=>{u&&c.push(u),d&&f.push(d),p?.();}),c.forEach(u=>u()),f.length&&requestAnimationFrame(()=>{f.forEach(u=>u());});}},oE=(t,e)=>!!(t&&t.length===e.length&&t.every((n,r)=>n[1]===e[r][1])),So=new WeakMap,gc=(t,e,n)=>{let r=!n&&e.pC;n&&(e.pC||=e.vC);let s;try{n||=typeof e.tag=="function"?sE(t,e):An(e.props.children),n[0]?.tag===""&&n[0][rn]&&(s=n[0][rn],t[5].push([t,s,e]));let i=r?[...e.pC]:e.vC?[...e.vC]:void 0,o=[],a;for(let l=0;l<n.length;l++){if(Array.isArray(n[l])){n.splice(l,1,...n[l].flat(1/0)),l--;continue}let c=aE(n[l]);if(c){typeof c.tag=="function"&&!c.tag[yo]&&(jt.length>0&&(c[V][2]=jt.map(u=>[u,u.values.at(-1)])),t[5]?.length&&(c[V][3]=t[5].at(-1)));let f;if(i&&i.length){let u=i.findIndex(Lt(c)?d=>Lt(d):c.key!==void 0?d=>d.key===c.key&&d.tag===c.tag:d=>d.tag===c.tag);u!==-1&&(f=i[u],i.splice(u,1));}if(f)if(Lt(c))f.t!==c.t&&(f.t=c.t,f.d=!0),c=f;else {let u=f.pP=f.props;if(f.props=c.props,f.f||=c.f||e.f,typeof c.tag=="function"){let d=f[V][2];f[V][2]=c[V][2]||[],f[V][3]=c[V][3],!f.f&&((f.o||f)===c.o||f.tag[ac]?.(u,f.props))&&oE(d,f[V][2])&&(f.s=!0);}c=f;}else if(!Lt(c)&&cr){let u=Ee(cr);u&&(c.n=u);}if(!Lt(c)&&!c.s&&(gc(t,c),delete c.f),o.push(c),a&&!a.s&&!c.s)for(let u=a;u&&!Lt(u);u=u.vC?.at(-1))u.nN=c;a=c;}}e.vR=r?[...e.vC,...i||[]]:i||[],e.vC=o,r&&delete e.pC;}catch(i){if(e.f=true,i===lm){if(s)return;throw i}let[o,a,l]=e[V]?.[3]||[];if(a){let c=()=>As([0,false,t[2]],l),f=So.get(l)||[];f.push(c),So.set(l,f);let u=a(i,()=>{let d=So.get(l);if(d){let p=d.indexOf(c);if(p!==-1)return d.splice(p,1),c()}});if(u){if(t[0]===1)t[1]=true;else if(gc(t,l,[u]),(a.length===1||t!==o)&&l.c){mm(l,l.c,false);return}throw lm}}throw i}finally{s&&t[5].pop();}},aE=t=>{if(!(t==null||typeof t=="boolean")){if(typeof t=="string"||typeof t=="number")return {t:t.toString(),d:true};if("vR"in t&&(t={tag:t.tag,props:t.props,key:t.key,f:t.f,type:t.tag,ref:t.props.ref,o:t.o||t}),typeof t.tag=="function")t[V]=[0,[]];else {let e=nE[t.tag];e&&(cr||=bo(""),t.props.children=[{tag:cr,props:{value:t.n=`http://www.w3.org/${e}`,children:t.props.children}}]);}return t}};var cm=(t,e)=>{e[V][2]?.forEach(([n,r])=>{n.values.push(r);});try{gc(t,e,void 0);}catch{return}if(e.a){delete e.a;return}e[V][2]?.forEach(([n])=>{n.values.pop();}),(t[0]!==1||!t[1])&&mm(e,e.c,false);},Ts=new WeakMap,um=[],As=async(t,e)=>{t[5]||=[];let n=Ts.get(e);n&&n[0](void 0);let r,s=new Promise(i=>r=i);if(Ts.set(e,[r,()=>{t[2]?t[2](t,e,i=>{cm(i,e);}).then(()=>r(e)):(cm(t,e),r(e));}]),um.length)um.at(-1).add(e);else {await Promise.resolve();let i=Ts.get(e);i&&(Ts.delete(e),i[1]());}return s};var gm=(t,e,n)=>({tag:ks,props:{children:t},key:n,e,p:1});var lE=0,yc=1,cE=2,uE=3;var bc=new WeakMap,bm=(t,e)=>!t||!e||t.length!==e.length||e.some((n,r)=>n!==t[r]);var fE=void 0;var ym=[];var Eo=t=>{let e=()=>typeof t=="function"?t():t,n=mt.at(-1);if(!n)return [e(),()=>{}];let[,r]=n,s=r[V][1][lE]||=[],i=r[V][0]++;return s[i]||=[e(),o=>{let a=fE,l=s[i];if(typeof o=="function"&&(o=o(l[0])),!Object.is(o,l[0]))if(l[0]=o,ym.length){let[c,f]=ym.at(-1);Promise.all([c===3?r:As([c,false,a],r),f]).then(([u])=>{if(!u||!(c===2||c===3))return;let d=u.vC;requestAnimationFrame(()=>{setTimeout(()=>{d===u.vC&&As([c===3?1:0,false,a],u);});});});}else As([0,false,a],r);}]};var ur=(t,e)=>{let n=mt.at(-1);if(!n)return t;let[,r]=n,s=r[V][1][cE]||=[],i=r[V][0]++,o=s[i];return bm(o?.[1],e)?s[i]=[t,e]:t=s[i][0],t};var wc=t=>{let e=bc.get(t);if(e){if(e.length===2)throw e[1];return e[0]}throw t.then(n=>bc.set(t,[n]),n=>bc.set(t,[void 0,n])),t},Sc=(t,e)=>{let n=mt.at(-1);if(!n)return t();let[,r]=n,s=r[V][1][uE]||=[],i=r[V][0]++,o=s[i];return bm(o?.[1],e)&&(s[i]=[t(),e]),s[i][0]};var Sm=bo({pending:false,data:null,method:null,action:null}),wm=new Set,Em=t=>{wm.add(t),t.finally(()=>wm.delete(t));};var dE=()=>{Ec=Object.create(null),_c=Object.create(null);},_o=(t,e)=>Sc(()=>n=>{let r;t&&(typeof t=="function"?r=t(n)||(()=>{t(null);}):t&&"current"in t&&(t.current=n,r=()=>{t.current=null;}));let s=e(n);return ()=>{s?.(),r?.();}},[t]),Ec=Object.create(null),_c=Object.create(null),Os=(t,e,n,r,s)=>{if(e?.itemProp)return {tag:t,props:e,type:t,ref:e.ref};let i=document.head,{onLoad:o,onError:a,precedence:l,blocking:c,...f}=e,u=null,d=false,p=or[t],y;if(p.length>0){let w=i.querySelectorAll(t);e:for(let _ of w)for(let S of or[t])if(_.getAttribute(S)===e[S]){u=_;break e}if(!u){let _=p.reduce((S,E)=>e[E]===void 0?S:`${S}-${E}-${e[E]}`,t);d=!_c[_],u=_c[_]||=(()=>{let S=document.createElement(t);for(let E of p)e[E]!==void 0&&S.setAttribute(E,e[E]),e.rel&&S.setAttribute("rel",e.rel);return S})();}}else y=i.querySelectorAll(t);l=r?l??"":void 0,r&&(f[ar]=l);let h=ur(w=>{if(p.length>0){let _=false;for(let S of i.querySelectorAll(t)){if(_&&S.getAttribute(ar)!==l){i.insertBefore(w,S);return}S.getAttribute(ar)===l&&(_=true);}i.appendChild(w);}else if(y){let _=false;for(let S of y)if(S===w){_=true;break}_||i.insertBefore(w,i.contains(y[0])?y[0]:i.querySelector(t)),y=void 0;}},[l]),b=_o(e.ref,w=>{let _=p[0];if(n===2&&(w.innerHTML=""),(d||y)&&h(w),!a&&!o)return;let S=Ec[w.getAttribute(_)]||=new Promise((E,C)=>{w.addEventListener("load",E),w.addEventListener("error",C);});o&&(S=S.then(o)),a&&(S=S.catch(a)),S.catch(()=>{});});if(s&&c==="render"){let w=or[t][0];if(e[w]){let _=e[w],S=Ec[_]||=new Promise((E,C)=>{h(u),u.addEventListener("load",E),u.addEventListener("error",C);});wc(S);}}let m={tag:t,type:t,props:{...f,ref:b},ref:b};return m.p=n,u&&(m.e=u),gm(m,i)},_m=t=>{let e=fm();return (e&&Ee(e))?.endsWith("svg")?{tag:"title",props:t,type:"title",ref:t.ref}:Os("title",t,void 0,false,false)},xm=t=>!t||["src","async"].some(e=>!t[e])?{tag:"script",props:t,type:"script",ref:t.ref}:Os("script",t,1,false,true),vm=t=>!t||!["href","precedence"].every(e=>e in t)?{tag:"style",props:t,type:"style",ref:t.ref}:(t["data-href"]=t.href,delete t.href,Os("style",t,2,true,true)),Cm=t=>!t||["onLoad","onError"].some(e=>e in t)||t.rel==="stylesheet"&&(!("precedence"in t)||"disabled"in t)?{tag:"link",props:t,type:"link",ref:t.ref}:Os("link",t,1,"precedence"in t,true),Rm=t=>Os("meta",t,void 0,false,false),Tm=Symbol(),km=t=>{let{action:e,...n}=t;typeof e!="function"&&(n.action=e);let[r,s]=Eo([null,false]),i=ur(async c=>{let f=c.isTrusted?e:c.detail[Tm];if(typeof f!="function")return;c.preventDefault();let u=new FormData(c.target);s([u,true]);let d=f(u);d instanceof Promise&&(Em(d),await d),s([null,true]);},[]),o=_o(t.ref,c=>(c.addEventListener("submit",i),()=>{c.removeEventListener("submit",i);})),[a,l]=r;return r[1]=false,{tag:Sm,props:{value:{pending:a!==null,data:a,method:a?"post":null,action:a?e:null},children:{tag:"form",props:{...n,ref:o},type:"form",ref:o}},f:l}},Am=(t,{formAction:e,...n})=>{if(typeof e=="function"){let r=ur(s=>{s.preventDefault(),s.currentTarget.form.dispatchEvent(new CustomEvent("submit",{detail:{[Tm]:e}}));},[]);n.ref=_o(n.ref,s=>(s.addEventListener("click",r),()=>{s.removeEventListener("click",r);}));}return {tag:t,props:n,type:t,ref:n.ref}},Om=t=>Am("input",t),$m=t=>Am("button",t);Object.assign(Ss,{title:_m,script:xm,style:vm,link:Cm,meta:Rm,form:km,input:Om,button:$m});ws(null);new TextEncoder;var On=":-hono-global",gE=new RegExp(`^${On}{(.*)}$`),Ro="hono-css",Ut=Symbol(),ge=Symbol(),Ie=Symbol(),ht=Symbol(),To=Symbol(),jm=Symbol();var Lm=t=>{let e=0,n=11;for(;e<t.length;)n=101*n+t.charCodeAt(e++)>>>0;return "css-"+n},yE=['"(?:(?:\\\\[\\s\\S]|[^"\\\\])*)"',"'(?:(?:\\\\[\\s\\S]|[^'\\\\])*)'"].join("|"),bE=new RegExp(["("+yE+")","(?:"+["^\\s+","\\/\\*.*?\\*\\/\\s*","\\/\\/.*\\n\\s*","\\s+$"].join("|")+")","\\s*;\\s*(}|$)\\s*","\\s*([{};:,])\\s*","(\\s)\\s+"].join("|"),"g"),wE=t=>t.replace(bE,(e,n,r,s,i)=>n||r||s||i||""),Um=(t,e)=>{let n=[],r=[],s=t[0].match(/^\s*\/\*(.*?)\*\//)?.[1]||"",i="";for(let o=0,a=t.length;o<a;o++){i+=t[o];let l=e[o];if(!(typeof l=="boolean"||l===null||l===void 0)){Array.isArray(l)||(l=[l]);for(let c=0,f=l.length;c<f;c++){let u=l[c];if(!(typeof u=="boolean"||u===null||u===void 0))if(typeof u=="string")/([\\"'\/])/.test(u)?i+=u.replace(/([\\"']|(?<=<)\/)/g,"\\$1"):i+=u;else if(typeof u=="number")i+=u;else if(u[jm])i+=u[jm];else if(u[ge].startsWith("@keyframes "))n.push(u),i+=` ${u[ge].substring(11)} `;else {if(t[o+1]?.match(/^\s*{/))n.push(u),u=`.${u[ge]}`;else {n.push(...u[ht]),r.push(...u[To]),u=u[Ie];let d=u.length;if(d>0){let p=u[d-1];p!==";"&&p!=="}"&&(u+=";");}}i+=`${u||""}`;}}}}return [s,wE(i),n,r]},fr=(t,e)=>{let[n,r,s,i]=Um(t,e),o=gE.exec(r);o&&(r=o[1]);let a=(o?On:"")+Lm(n+r),l=(o?s.map(c=>c[ge]):[a,...i]).join(" ");return {[Ut]:a,[ge]:l,[Ie]:r,[ht]:s,[To]:i}},ko=t=>{for(let e=0,n=t.length;e<n;e++){let r=t[e];typeof r=="string"&&(t[e]={[Ut]:"",[ge]:"",[Ie]:"",[ht]:[],[To]:[r]});}return t},Ao=(t,...e)=>{let[n,r]=Um(t,e);return {[Ut]:"",[ge]:`@keyframes ${Lm(n+r)}`,[Ie]:r,[ht]:[],[To]:[]}},SE=0,Oo=((t,e)=>{t||(t=[`/* h-v-t ${SE++} */`]);let n=Array.isArray(t)?fr(t,e):t,r=n[ge],s=fr(["view-transition-name:",""],[r]);return n[ge]=On+n[ge],n[Ie]=n[Ie].replace(/(?<=::view-transition(?:[a-z-]*)\()(?=\))/g,r),s[ge]=s[Ut]=r,s[ht]=[...n[ht],n],s});var _E=t=>{let e=[],n=0,r=0;for(let s=0,i=t.length;s<i;s++){let o=t[s];if(o==="'"||o==='"'){let a=o;for(s++;s<i;s++){if(t[s]==="\\"){s++;continue}if(t[s]===a)break}continue}if(o==="{"){r++;continue}if(o==="}"){r--,r===0&&(e.push(t.slice(n,s+1)),n=s+1);continue}}return e},Cc=({id:t})=>{let e,n=()=>(e||(e=document.querySelector(`style#${t}`)?.sheet,e&&(e.addedStyles=new Set)),e?[e,e.addedStyles]:[]),r=(o,a)=>{let[l,c]=n();if(!l||!c){Promise.resolve().then(()=>{if(!n()[0])throw new Error("style sheet not found");r(o,a);});return}c.has(o)||(c.add(o),(o.startsWith(On)?_E(a):[`${o[0]==="@"?"":"."}${o}{${a}}`]).forEach(f=>{l.insertRule(f,l.cssRules.length);}));};return [{toString(){let o=this[Ut];return r(o,this[Ie]),this[ht].forEach(({[ge]:a,[Ie]:l})=>{r(a,l);}),this[ge]}},({children:o,nonce:a})=>({tag:"style",props:{id:t,nonce:a,children:o&&(Array.isArray(o)?o:[o]).map(l=>l[Ie])}})]};var vE=({id:t})=>{let[e,n]=Cc({id:t}),r=new WeakMap,s=new WeakMap,i=new RegExp(`(<style id="${t}"(?: nonce="[^"]*")?>.*?)(</style>)`),o=d=>{let p=({buffer:m,context:w})=>{let[_,S]=r.get(w),E=Object.keys(_);if(!E.length)return;let C="";if(E.forEach(v=>{S[v]=true,C+=v.startsWith(On)?_[v]:`${v[0]==="@"?"":"."}${v}{${_[v]}}`;}),r.set(w,[{},S]),m&&i.test(m[0])){m[0]=m[0].replace(i,(v,k,z)=>`${k}${C}${z}`);return}let x=s.get(w),R=`<script${x?` nonce="${x}"`:""}>document.querySelector('#${t}').textContent+=${JSON.stringify(C)}</script>`;if(m){m[0]=`${R}${m[0]}`;return}return Promise.resolve(R)},y=({context:m})=>{r.has(m)||r.set(m,[{},{}]);let[w,_]=r.get(m),S=true;if(_[d[Ut]]||(S=false,w[d[Ut]]=d[Ie]),d[ht].forEach(({[ge]:E,[Ie]:C})=>{_[E]||(S=false,w[E]=C);}),!S)return Promise.resolve(K("",[p]))},h=new String(d[ge]);Object.assign(h,d),h.isEscaped=true,h.callbacks=[y];let b=Promise.resolve(h);return Object.assign(b,d),b.toString=e.toString,b},a=(d,...p)=>o(fr(d,p)),l=(...d)=>(d=ko(d),a(Array(d.length).fill(""),...d)),c=Ao,f=((d,...p)=>o(Oo(d,p))),u=({children:d,nonce:p}={})=>K(`<style id="${t}"${p?` nonce="${p}"`:""}>${d?d[Ie]:""}</style>`,[({context:y})=>{s.set(y,p);}]);return u[Ve]=n,{css:a,cx:l,keyframes:c,viewTransition:f,Style:u}},Ps=vE({id:Ro}),Mm=Ps.Style;function ye(t,e,n){let r;if(!e||!("children"in e))r=Rs(t,e,[]);else {let s=e.children;r=Array.isArray(s)?Rs(t,e,s):Rs(t,e,[s]);}return r.key=n,r}var Rc=new Se().get("/*",async t=>{let e={js:"main.js",css:["styles.css"]},n="/static/",r=await Promise.resolve().then(()=>ou(Fm())).then(s=>s.default);try{let s=Object.values(r).find(i=>i.isEntry);if(!s)throw new Error("No entry found in manifest");e.js=s?.file,e.css=s?.css??[];}catch(s){console.warn("Couldn't find assets in manifest",s);}return t.html(ye(pt,{children:ye("html",{lang:"en","data-theme":"dark",style:"color-scheme: dark",class:"dark",children:[ye("head",{children:[ye("meta",{charset:"UTF-8"}),ye("meta",{name:"viewport",content:"width=device-width, initial-scale=1, maximum-scale=1"}),ye("link",{rel:"icon",href:n+"favicon.ico",type:"image/x-icon"}),ye("title",{children:"Supalite"}),ye(pt,{children:[ye("script",{type:"module",src:n+e?.js}),e?.css.map((s,i)=>ye("link",{rel:"stylesheet",href:n+s},i))]}),ye(Mm,{})]}),ye("body",{children:ye("div",{id:"root"})})]})}))});async function RE(t){return Rc.fetch(t)}var TE={storage:"EXPERIMENTAL_STORAGE",cloud:"EXPERIMENTAL_CLOUD"},Bm=["storage","cloud"],kc=Object.fromEntries(Bm.map(t=>[t,kE(t)]));function kE(t){let e=typeof process<"u"&&process.env||void 0;return e?e.NODE_ENV==="test"?true:e[TE[t]]==="1":false}function dr(t){return kc[t]}function AE(t,e){kc[t]=e;}function qm(){return Bm.filter(t=>kc[t])}function OE(){let t=qm();if(t.length===0)return null;let e=t.includes("storage")?" Cloud sync (lite cloud deploy) is disabled.":"";return `EXPERIMENTAL FEATURES ENABLED: ${t.join(", ")} - not supported, do not use in production.${e}`}var Tc=false;function Wm(t=e=>console.warn(e)){if(Tc)return;if(typeof process<"u"&&process.env?.NODE_ENV==="test"){Tc=true;return}let e=OE();e&&t(e),Tc=true;}function Jm(t,e={}){let n=e.middlewares??[async(r,s)=>{await s();}];return new Se().use(async(r,s)=>{r.set("app",t),t.config.auth?.enabled&&r.set("authService",zp(t)),t.config.storage?.enabled&&t._storageAdapter&&dr("storage")&&r.set("storageService",Zp(t)),await s();}).use(...n).use(Xl()).route("/auth/v1",Yl).route("/rest/v1",cp({forceRollback:e.forceRollback})).use("/storage/v1/*",async(r,s)=>{if(!dr("storage"))return r.notFound();await s();}).route("/storage/v1",sc).route("/_system",ff).use(async(r,s)=>{if(!e.disableStudio&&t.config.studio?.enabled)return Rc.fetch(r.req.raw);if(!e.disableFallback)return r.notFound();await s();})}ee();var $E=t=>{let e=t.toJSON();return Jt(e)},Ac=class extends Error{constructor(n,r,s=[]){super(`Invalid schema given for ${JSON.stringify(r,null,2)}
|
|
124
130
|
|
|
125
|
-
Error: ${JSON.stringify(
|
|
131
|
+
Error: ${JSON.stringify(s[0],null,2)}
|
|
126
132
|
|
|
127
|
-
Schema: ${JSON.stringify(
|
|
133
|
+
Schema: ${JSON.stringify(n.toJSON(),null,2)}`);this.schema=n;this.value=r;this.errors=s;}name="InvalidSchemaError";first(){return this.errors[0]}firstToString(){let n=this.first();return `${n.error} at ${n.instanceLocation}`}};function Km(t,e,n){let r=n?.clone?$E(t):t,s=n?.coerce!==false?r.coerce(e,{dropUnknown:n?.coerceDropUnknown??false}):e;n?.withDefaults!==false&&(s=r.template(s,{withOptional:true,withExtendedOptional:n?.withExtendedDefaults??false}));let i=t.validate(s,{shortCircuit:true,ignoreUnsupported:true});if(!i.valid)if(n?.onError)n.onError(i.errors);else throw new Ac(r,e,i.errors);return s}Qr();var Oc=`-- supabase/auth core schema (Postgres)
|
|
128
134
|
-- Scope: Core Authentication + User Management
|
|
129
135
|
-- Source: GoTrue migrations + runtime analysis
|
|
130
136
|
|
|
@@ -301,50 +307,211 @@ CREATE TABLE IF NOT EXISTS auth.audit_log_entries (
|
|
|
301
307
|
created_at timestamptz DEFAULT now(),
|
|
302
308
|
ip_address varchar(64) DEFAULT ''
|
|
303
309
|
);
|
|
304
|
-
`;function
|
|
305
|
-
|
|
306
|
-
`),this._rls){let
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
`," ",r),this.select=a,this.from=o,this.group=l,this.sort=u,this.insertColumns=p,this.update=c,this.bool=f,this.isColumnConstraint=m,this.isDomainConstraint=d,this.alterColumnOptions=g,this.alterTableOptions=b,this.isEnumValue=y,this.objtype=T,this.subtype=C,Object.assign(this,w);}spawn(e,r={}){return new s({indentLevel:this.indentLevel,prettyMode:this.prettyMode,isStringLiteral:this.isStringLiteral,parentNodeTypes:[...this.parentNodeTypes,e],formatter:this.formatter,select:this.select,from:this.from,group:this.group,sort:this.sort,insertColumns:this.insertColumns,update:this.update,bool:this.bool,isColumnConstraint:this.isColumnConstraint,isDomainConstraint:this.isDomainConstraint,alterColumnOptions:this.alterColumnOptions,alterTableOptions:this.alterTableOptions,isEnumValue:this.isEnumValue,objtype:this.objtype,subtype:this.subtype,...r})}indent(e,r){if(!this.prettyMode)return e;let t=r!==void 0?r:this.indentLevel+1;return this.formatter.indent(e,t)}newline(){return this.formatter.newline()}parens(e){return this.formatter.parens(e)}format(e,r){return this.formatter.format(e,r)}isPretty(){return this.formatter.isPretty()}};var En={UNRESERVED_KEYWORD:["abort","absent","absolute","access","action","add","admin","after","aggregate","also","alter","always","asensitive","assertion","assignment","at","atomic","attach","attribute","backward","before","begin","breadth","by","cache","call","called","cascade","cascaded","catalog","chain","characteristics","checkpoint","class","close","cluster","columns","comment","comments","commit","committed","compression","conditional","configuration","conflict","connection","constraints","content","continue","conversion","copy","cost","csv","cube","current","cursor","cycle","data","database","day","deallocate","declare","defaults","deferred","definer","delete","delimiter","delimiters","depends","depth","detach","dictionary","disable","discard","document","domain","double","drop","each","empty","enable","encoding","encrypted","enforced","enum","error","escape","event","exclude","excluding","exclusive","execute","explain","expression","extension","external","family","filter","finalize","first","following","force","format","forward","function","functions","generated","global","granted","groups","handler","header","hold","hour","identity","if","ignore","immediate","immutable","implicit","import","include","including","increment","indent","index","indexes","inherit","inherits","inline","input","insensitive","insert","instead","invoker","isolation","keep","key","keys","label","language","large","last","leakproof","level","listen","load","local","location","lock","locked","logged","lsn","mapping","match","matched","materialized","maxvalue","merge","method","minute","minvalue","mode","month","move","name","names","nested","new","next","nfc","nfd","nfkc","nfkd","no","normalized","nothing","notify","nowait","nulls","object","objects","of","off","oids","old","omit","operator","option","options","ordinality","others","over","overriding","owned","owner","parallel","parameter","parser","partial","partition","partitions","passing","password","path","period","plan","plans","policy","preceding","prepare","prepared","preserve","prior","privileges","procedural","procedure","procedures","program","publication","quote","quotes","range","read","reassign","recursive","ref","referencing","refresh","reindex","relative","release","rename","repeatable","replace","replica","reset","respect","restart","restrict","return","returns","revoke","role","rollback","rollup","routine","routines","rows","rule","savepoint","scalar","schema","schemas","scroll","search","second","security","sequence","sequences","serializable","server","session","set","sets","share","show","simple","skip","snapshot","source","split","sql","stable","standalone","start","statement","statistics","stdin","stdout","storage","stored","strict","string","strip","subscription","support","sysid","system","tables","tablespace","target","temp","template","temporary","text","ties","transaction","transform","trigger","truncate","trusted","type","types","uescape","unbounded","uncommitted","unconditional","unencrypted","unknown","unlisten","unlogged","until","update","vacuum","valid","validate","validator","value","varying","version","view","views","virtual","volatile","wait","whitespace","within","without","work","wrapper","write","xml","year","yes","zone"],RESERVED_KEYWORD:["all","analyse","analyze","and","any","array","as","asc","asymmetric","both","case","cast","check","collate","column","constraint","create","current_catalog","current_date","current_role","current_time","current_timestamp","current_user","default","deferrable","desc","distinct","do","else","end","except","false","fetch","for","foreign","from","grant","group","having","in","initially","intersect","into","lateral","leading","limit","localtime","localtimestamp","not","null","offset","on","only","or","order","placing","primary","references","returning","select","session_user","some","symmetric","system_user","table","then","to","trailing","true","union","unique","user","using","variadic","when","where","window","with"],TYPE_FUNC_NAME_KEYWORD:["authorization","binary","collation","concurrently","cross","current_schema","freeze","full","ilike","inner","is","isnull","join","left","like","natural","notnull","outer","overlaps","right","similar","tablesample","verbose"],COL_NAME_KEYWORD:["between","bigint","bit","boolean","char","character","coalesce","dec","decimal","exists","extract","float","greatest","grouping","inout","int","integer","interval","json","json_array","json_arrayagg","json_exists","json_object","json_objectagg","json_query","json_scalar","json_serialize","json_table","json_value","least","merge_action","national","nchar","none","normalize","nullif","numeric","out","overlay","position","precision","real","row","setof","smallint","substring","time","timestamp","treat","trim","values","varchar","xmlattributes","xmlconcat","xmlelement","xmlexists","xmlforest","xmlnamespaces","xmlparse","xmlpi","xmlroot","xmlserialize","xmltable"]},lh=new Set(En.RESERVED_KEYWORD??[]),uh=new Set(En.UNRESERVED_KEYWORD??[]),ch=new Set(En.COL_NAME_KEYWORD??[]),ph=new Set(En.TYPE_FUNC_NAME_KEYWORD??[]);function ba(s){let e=s.toLowerCase();return lh.has(e)?"RESERVED_KEYWORD":ph.has(e)?"TYPE_FUNC_NAME_KEYWORD":ch.has(e)?"COL_NAME_KEYWORD":uh.has(e)?"UNRESERVED_KEYWORD":"NO_KEYWORD"}var S=class s{static escape(e){return `'${e.replace(/'/g,"''")}'`}static escapeEString(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"''")}static formatEString(e){return s.needsEscapePrefix(e)?`E'${s.escapeEString(e)}'`:s.escape(e)}static needsEscapePrefix(e){return !/^\\x[0-9a-fA-F]+$/i.test(e)&&e.includes("\\")}static quoteIdentifier(e){if(!e)return e;let r=true,t=e[0];t>="a"&&t<="z"||t==="_"||(r=false);for(let i=0;i<e.length;i++){let a=e[i];a>="a"&&a<="z"||a>="0"&&a<="9"||a==="_"||(r=false);}if(r){let i=ba(e);i!=="NO_KEYWORD"&&i!=="UNRESERVED_KEYWORD"&&(r=false);}if(r)return e;let n='"';for(let i=0;i<e.length;i++){let a=e[i];a==='"'&&(n+='"'),n+=a;}return n+='"',n}static quoteIdentifierAfterDot(e){if(!e)return e;let r=true,t=e[0];t>="a"&&t<="z"||t==="_"||(r=false);for(let i=0;i<e.length;i++){let a=e[i];a>="a"&&a<="z"||a>="0"&&a<="9"||a==="_"||(r=false);}if(r)return e;let n='"';for(let i=0;i<e.length;i++){let a=e[i];a==='"'&&(n+='"'),n+=a;}return n+='"',n}static quoteDottedName(e){return !e||e.length===0?"":e.length===1?s.quoteIdentifier(e[0]):e.map((r,t)=>t===0?s.quoteIdentifier(r):s.quoteIdentifierAfterDot(r)).join(".")}static quoteQualifiedIdentifier(e,r){return e?`${s.quoteIdentifier(e)}.${s.quoteIdentifierAfterDot(r)}`:s.quoteIdentifier(r)}static quoteIdentifierTypeName(e){if(!e)return e;let r=true,t=e[0];t>="a"&&t<="z"||t==="_"||(r=false);for(let i=0;i<e.length;i++){let a=e[i];a>="a"&&a<="z"||a>="0"&&a<="9"||a==="_"||(r=false);}if(r&&ba(e)==="RESERVED_KEYWORD"&&(r=false),r)return e;let n='"';for(let i=0;i<e.length;i++){let a=e[i];a==='"'&&(n+='"'),n+=a;}return n+='"',n}static quoteTypeDottedName(e){return !e||e.length===0?"":e.map(r=>s.quoteIdentifierTypeName(r)).join(".")}};var h=class{static unwrapList(e){return e==null?[]:e.List!==void 0?e.List.items||[]:Array.isArray(e)?e:[e]}static formatList(e,r=", ",t="",n){return !e||e.length===0?"":e.map(i=>`${t}${n(i)}`).join(r)}};var Db=["int2","int4","int8","float4","float8","numeric","varchar","char","bpchar","text","bool","date","time","timetz","timestamp","timestamptz","interval","bytea","uuid","json","jsonb","xml","money","bit","varbit","inet","cidr","macaddr","macaddr8"],jb=[["numeric",["decimal","dec"]],["int4",["int","integer"]],["float8",["float"]],["bpchar",["character"]],["varchar",["character varying"]]];function xb(s){return s&&typeof s=="object"&&!Array.isArray(s)&&!("ParseResult"in s)&&!("RawStmt"in s)&&("stmts"in s||"version"in s)}var ns=class s{tree;options;constructor(e,r={}){this.options={functionDelimiter:"$$",functionDelimiterFallback:"$EOFCODE$",...r},xb(e)?this.tree=[{ParseResult:e}]:Array.isArray(e)?this.tree=e:this.tree=[e];}static deparse(e,r={}){return new s(e,r).deparseQuery()}deparseQuery(){let e=new er(this.options.newline,this.options.tab,this.options.pretty),r=new ss({formatter:e,prettyMode:this.options.pretty});return this.tree.map(t=>this.deparse(t,r)||"").filter(t=>t!=="").join(r.newline()+r.newline())}getFunctionDelimiter(e){let r=this.options.functionDelimiter||"$$";return e.includes(r)?this.options.functionDelimiterFallback||"$EOFCODE$":r}getObjectTypeKeyword(e){switch(e){case "OBJECT_TABLE":return "TABLE";case "OBJECT_VIEW":return "VIEW";case "OBJECT_INDEX":return "INDEX";case "OBJECT_SEQUENCE":return "SEQUENCE";case "OBJECT_FUNCTION":return "FUNCTION";case "OBJECT_PROCEDURE":return "PROCEDURE";case "OBJECT_SCHEMA":return "SCHEMA";case "OBJECT_DATABASE":return "DATABASE";case "OBJECT_DOMAIN":return "DOMAIN";case "OBJECT_AGGREGATE":return "AGGREGATE";case "OBJECT_CONVERSION":return "CONVERSION";case "OBJECT_LANGUAGE":return "LANGUAGE";case "OBJECT_OPERATOR":return "OPERATOR";case "OBJECT_OPFAMILY":return "OPERATOR FAMILY";case "OBJECT_OPCLASS":return "OPERATOR CLASS";case "OBJECT_TSDICTIONARY":return "TEXT SEARCH DICTIONARY";case "OBJECT_TSCONFIGURATION":return "TEXT SEARCH CONFIGURATION";case "OBJECT_EVENT_TRIGGER":return "EVENT TRIGGER";case "OBJECT_FDW":return "FOREIGN DATA WRAPPER";case "OBJECT_FOREIGN_SERVER":return "SERVER";case "OBJECT_TYPE":return "TYPE";case "OBJECT_COLLATION":return "COLLATION";case "OBJECT_PUBLICATION":return "PUBLICATION";case "OBJECT_ACCESS_METHOD":return "ACCESS METHOD";case "OBJECT_AMOP":return "OPERATOR CLASS";case "OBJECT_AMPROC":return "OPERATOR CLASS";case "OBJECT_ATTRIBUTE":return "ATTRIBUTE";case "OBJECT_CAST":return "CAST";case "OBJECT_COLUMN":return "COLUMN";case "OBJECT_DEFAULT":return "DEFAULT";case "OBJECT_DEFACL":return "DEFAULT PRIVILEGES";case "OBJECT_DOMCONSTRAINT":return "DOMAIN";case "OBJECT_EXTENSION":return "EXTENSION";case "OBJECT_FOREIGN_TABLE":return "FOREIGN TABLE";case "OBJECT_LARGEOBJECT":return "LARGE OBJECT";case "OBJECT_MATVIEW":return "MATERIALIZED VIEW";case "OBJECT_PARAMETER_ACL":return "PARAMETER";case "OBJECT_POLICY":return "POLICY";case "OBJECT_PUBLICATION_NAMESPACE":return "PUBLICATION";case "OBJECT_PUBLICATION_REL":return "PUBLICATION";case "OBJECT_ROLE":return "ROLE";case "OBJECT_ROUTINE":return "ROUTINE";case "OBJECT_RULE":return "RULE";case "OBJECT_STATISTIC_EXT":return "STATISTICS";case "OBJECT_SUBSCRIPTION":return "SUBSCRIPTION";case "OBJECT_TABCONSTRAINT":return "CONSTRAINT";case "OBJECT_TABLESPACE":return "TABLESPACE";case "OBJECT_TRANSFORM":return "TRANSFORM";case "OBJECT_TRIGGER":return "TRIGGER";case "OBJECT_TSPARSER":return "TEXT SEARCH PARSER";case "OBJECT_TSTEMPLATE":return "TEXT SEARCH TEMPLATE";case "OBJECT_USER_MAPPING":return "USER MAPPING";default:throw new Error(`Unsupported objectType: ${e}`)}}deparse(e,r){if(e==null)return null;if(!r){let t=new er(this.options.newline,this.options.tab,this.options.pretty);r=new ss({formatter:t,prettyMode:this.options.pretty});}if(typeof e=="number"||e instanceof Number)return e.toString();try{return this.visit(e,r)}catch(t){let n=Object.keys(e)[0];throw new Error(`Error deparsing ${n}: ${t.message}`)}}visit(e,r){if(!r){let a=new er(this.options.newline,this.options.tab,this.options.pretty);r=new ss({formatter:a,prettyMode:this.options.pretty});}let t=this.getNodeType(e);if(!t)return "";let n=this.getNodeData(e),i=t;if(typeof this[i]=="function")return this[i](n,r);throw new Error(`Deparser does not handle node type: ${t}`)}getNodeType(e){return Object.keys(e)[0]}getNodeData(e){let r=Object.keys(e);return r.length===1&&typeof e[r[0]]=="object"?e[r[0]]:e}ParseResult(e,r){return !e.stmts||e.stmts.length===0?"":e.stmts.filter(t=>t!=null).map(t=>this.RawStmt(t,r)).filter(t=>t!=="").join(r.newline()+r.newline())}RawStmt(e,r){if(!e.stmt)return "";let t=this.deparse(e.stmt,r);return e.stmt_len?t+";":t}SelectStmt(e,r){let t=[];if(e.withClause&&t.push(this.WithClause(e.withClause,r)),!e.op||e.op==="SETOP_NONE")e.valuesLists==null&&(!r.isPretty()||!e.targetList)&&t.push("SELECT");else {let i=this.SelectStmt(e.larg,r),a=this.SelectStmt(e.rarg,r),o=e.larg&&(e.larg.op&&e.larg.op!=="SETOP_NONE"||e.larg.sortClause||e.larg.limitCount||e.larg.limitOffset||e.larg.withClause),l=e.rarg&&(e.rarg.op&&e.rarg.op!=="SETOP_NONE"||e.rarg.sortClause||e.rarg.limitCount||e.rarg.limitOffset||e.rarg.withClause);switch(o?t.push(r.parens(i)):t.push(i),e.op){case "SETOP_UNION":t.push("UNION");break;case "SETOP_INTERSECT":t.push("INTERSECT");break;case "SETOP_EXCEPT":t.push("EXCEPT");break;default:throw new Error(`Bad SelectStmt op: ${e.op}`)}e.all&&t.push("ALL"),l?t.push(r.parens(a)):t.push(a);}let n="";if(e.distinctClause){let i=h.unwrapList(e.distinctClause);if(i.length>0&&Object.keys(i[0]).length>0){let a=i.map(o=>this.visit(o,r.spawn("SelectStmt",{select:true}))).join(", ");n=" DISTINCT ON "+r.parens(a);}else n=" DISTINCT";if(!r.isPretty())if(i.length>0&&Object.keys(i[0]).length>0){t.push("DISTINCT ON");let a=i.map(o=>this.visit(o,r.spawn("SelectStmt",{select:true}))).join(", ");t.push(r.parens(a));}else t.push("DISTINCT");}if(e.targetList){let i=h.unwrapList(e.targetList);if(r.isPretty())if(i.length===1){let a=i[0],o=this.visit(a,r.spawn("SelectStmt",{select:true}));this.isComplexSelectTarget(a)?(t.push("SELECT"+n),this.containsMultilineStringLiteral(o)?t.push(o):t.push(r.indent(o))):t.push("SELECT"+n+" "+o);}else {let o=i.map(l=>{let u=this.visit(l,r.spawn("SelectStmt",{select:true}));return this.containsMultilineStringLiteral(u)?u:r.indent(u)}).join(","+r.newline());t.push("SELECT"+n),t.push(o);}else {let a=i.map(o=>this.visit(o,r.spawn("SelectStmt",{select:true}))).join(", ");t.push(a);}}if(e.intoClause&&(t.push("INTO"),t.push(this.IntoClause(e.intoClause,r))),e.fromClause){let a=h.unwrapList(e.fromClause).map(o=>this.deparse(o,r.spawn("SelectStmt",{from:true}))).join(", ");t.push("FROM "+a.trim());}if(e.whereClause)if(r.isPretty()){t.push("WHERE");let o=this.visit(e.whereClause,r).split(r.newline()).map((l,u)=>u===0?r.indent(l):l);t.push(o.join(r.newline()));}else t.push("WHERE"),t.push(this.visit(e.whereClause,r));if(e.valuesLists)if(r.isPretty()){t.push("VALUES");let a=h.unwrapList(e.valuesLists).map(o=>{let l=h.unwrapList(o).map(u=>this.visit(u,r));return r.parens(l.join(", "))}).map(o=>this.containsMultilineStringLiteral(o)?o:r.indent(o));t.push(a.join(`,
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
`));}else t.push(o.join(", "));}}e.onConflictClause.whereClause&&(t.push("WHERE"),t.push(this.visit(e.onConflictClause.whereClause,r)));}else e.onConflictClause.action==="ONCONFLICT_NOTHING"&&t.push("DO NOTHING");}if(e.returningList){t.push("RETURNING");let i=h.unwrapList(e.returningList).map(a=>this.visit(a,r));t.push(i.join(", "));}return t.join(" ")}UpdateStmt(e,r){let t=[];e.withClause&&t.push(this.WithClause(e.withClause,r)),t.push("UPDATE"),e.relation&&t.push(this.RangeVar(e.relation,r)),t.push("SET");let n=h.unwrapList(e.targetList);if(n&&n.length){n[0];let a=new Set,o=[];for(let l=0;l<n.length;l++){if(a.has(l))continue;let u=n[l],p=u.ResTarget?.val?.MultiAssignRef;if(p){let c=[];for(let d=l;d<n.length;d++){let g=n[d],b=g.ResTarget?.val?.MultiAssignRef;b&&JSON.stringify(b.source)===JSON.stringify(p.source)&&(c.push(g),a.add(d));}let f=c.map(d=>d.ResTarget.name),m=`${r.parens(f.join(", "))} = ${this.visit(p.source,r)}`;o.push(m);}else o.push(this.visit(u,r.spawn("UpdateStmt",{update:true}))),a.add(l);}t.push(o.join(","));}if(e.fromClause){t.push("FROM");let a=h.unwrapList(e.fromClause).map(o=>this.visit(o,r));t.push(a.join(", "));}return e.whereClause&&(t.push("WHERE"),t.push(this.visit(e.whereClause,r))),e.returningList&&(t.push("RETURNING"),t.push(this.deparseReturningList(e.returningList,r))),t.join(" ")}DeleteStmt(e,r){try{let t=[];if(e.withClause)try{t.push(this.WithClause(e.withClause,r));}catch(n){throw console.warn(`Error processing withClause in DeleteStmt: ${n instanceof Error?n.message:String(n)}`),new Error(`Error deparsing DeleteStmt: ${n instanceof Error?n.message:String(n)}`)}if(t.push("DELETE"),t.push("FROM"),!e.relation)throw new Error("DeleteStmt requires a relation");if(t.push(this.RangeVar(e.relation,r)),e.usingClause){t.push("USING");let i=h.unwrapList(e.usingClause).filter(a=>a!=null&&this.getNodeType(a)!=="undefined").map(a=>{try{return this.visit(a,r)}catch(o){return console.warn(`Error processing usingClause item in DeleteStmt: ${o instanceof Error?o.message:String(o)}`),""}}).filter(a=>a&&a.trim());i.length>0&&t.push(i.join(", "));}if(e.whereClause){t.push("WHERE");try{t.push(this.visit(e.whereClause,r));}catch(n){throw console.warn(`Error processing whereClause in DeleteStmt: ${n instanceof Error?n.message:String(n)}`),new Error(`Error deparsing DeleteStmt: ${n instanceof Error?n.message:String(n)}`)}}if(e.returningList){t.push("RETURNING");try{t.push(this.deparseReturningList(e.returningList,r));}catch(n){throw console.warn(`Error processing returningList in DeleteStmt: ${n instanceof Error?n.message:String(n)}`),new Error(`Error deparsing DeleteStmt: ${n instanceof Error?n.message:String(n)}`)}}return t.join(" ")}catch(t){throw new Error(`Error deparsing DeleteStmt: ${t instanceof Error?t.message:String(t)}`)}}WithClause(e,r){let t=["WITH"];if(e.recursive&&t.push("RECURSIVE"),e.ctes&&e.ctes.length>0){let n=h.unwrapList(e.ctes);if(r.isPretty()){let i=n.map((a,o)=>{let l=this.visit(a,r),u=o===0?r.newline():","+r.newline();return this.containsMultilineStringLiteral(l)?u+l:u+r.indent(l)});t.push(i.join(""));}else {let i=n.map(a=>this.visit(a,r));t.push(i.join(", "));}}return t.join(" ")}ResTarget(e,r){let t=[];if(r.update&&e.name){if(t.push(S.quoteIdentifier(e.name)),e.indirection&&e.indirection.length>0){let n=h.unwrapList(e.indirection).map(i=>i.String?`.${S.quoteIdentifierAfterDot(i.String.sval||i.String.str)}`:this.visit(i,r));t.push(n.join(""));}t.push("="),e.val&&t.push(this.deparse(e.val,r));}else if(r.insertColumns&&e.name){if(t.push(S.quoteIdentifier(e.name)),e.indirection&&e.indirection.length>0){let n=h.unwrapList(e.indirection).map(i=>i.String?`.${S.quoteIdentifierAfterDot(i.String.sval||i.String.str)}`:this.visit(i,r));t.push(n.join(""));}}else e.val&&t.push(this.deparse(e.val,r)),e.name&&(t.push("AS"),t.push(S.quoteIdentifier(e.name)));return t.join(" ")}deparseReturningList(e,r){return h.unwrapList(e).filter(t=>t!=null&&this.getNodeType(t)!=="undefined").map(t=>{try{if(this.getNodeType(t)==="ResTarget"){let n=this.getNodeData(t),i=n.val?this.visit(n.val,r):"",a=n.name?` AS ${S.quoteIdentifier(n.name)}`:"";return i+a}else return this.visit(t,r)}catch(n){return console.warn(`Error processing returning item: ${n instanceof Error?n.message:String(n)}`),""}}).filter(t=>t&&t.trim()).join(", ")}BoolExpr(e,r){let t=e.boolop,n=h.unwrapList(e.args),i="%s";r.bool&&(i="(%s)");let a=r.spawn("BoolExpr",{bool:true});switch(t){case "AND_EXPR":if(r.isPretty()&&n.length>1){let o=n.map(l=>this.visit(l,a)).join(r.newline()+r.indent("AND "));return i.replace("%s",()=>o)}else {let o=n.map(l=>this.visit(l,a)).join(" AND ");return i.replace("%s",()=>o)}case "OR_EXPR":if(r.isPretty()&&n.length>1){let o=n.map(l=>this.visit(l,a)).join(r.newline()+r.indent("OR "));return i.replace("%s",()=>o)}else {let o=n.map(l=>this.visit(l,a)).join(" OR ");return i.replace("%s",()=>o)}case "NOT_EXPR":return `NOT (${this.visit(n[0],r)})`;default:throw new Error(`Unhandled BoolExpr boolop: ${t}`)}}FuncCall(e,r){let t=h.unwrapList(e.funcname),n=h.unwrapList(e.args),i=t.map(p=>p.String?.sval||p.String?.str||"").filter(p=>p),a=S.quoteDottedName(i);if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.xmlexists"&&n.length>=2){let p=this.visit(n[0],r),c=this.visit(n[1],r);return `xmlexists (${p} PASSING ${c})`}if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.extract"&&n.length>=2){let p=this.visit(n[0],r),c=this.visit(n[1],r);return p.startsWith("'")&&p.endsWith("'")&&(p=p.slice(1,-1).toUpperCase()),`EXTRACT(${p} FROM ${c})`}if(e.funcformat==="COERCE_SQL_SYNTAX"&&(a==="pg_catalog.rtrim"||a==="pg_catalog.ltrim"||a==="pg_catalog.btrim")&&n.length>=1){let p=this.visit(n[0],r),c="";if(n.length>=2&&(c=` ${this.visit(n[1],r)}`),a==="pg_catalog.rtrim")return `TRIM(TRAILING${c} FROM ${p})`;if(a==="pg_catalog.ltrim")return `TRIM(LEADING${c} FROM ${p})`;if(a==="pg_catalog.btrim")return `TRIM(BOTH${c} FROM ${p})`}if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.pg_collation_for")return `COLLATION FOR (${n.map(c=>this.visit(c,r)).join(", ")})`;if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.substring"){let p=this.visit(n[0],r);if(n.length===3){let c=this.visit(n[1],r),f=this.visit(n[2],r);return `SUBSTRING(${p} FROM ${c} FOR ${f})`}else if(n.length===2){let c=this.visit(n[1],r);return `SUBSTRING(${p} FROM ${c})`}}if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.position"&&n.length===2){let p=this.visit(n[0],r);return `POSITION(${this.visit(n[1],r)} IN ${p})`}if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.overlay"){if(n.length===4){let p=this.visit(n[0],r),c=this.visit(n[1],r),f=this.visit(n[2],r),m=this.visit(n[3],r);return `OVERLAY(${p} PLACING ${c} FROM ${f} FOR ${m})`}else if(n.length===3){let p=this.visit(n[0],r),c=this.visit(n[1],r),f=this.visit(n[2],r);return `OVERLAY(${p} PLACING ${c} FROM ${f})`}}if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.is_normalized"){let p=this.visit(n[0],r);if(n.length===2){let f=this.visit(n[1],r).replace(/'/g,"");return `${p} IS ${f} NORMALIZED`}else return `${p} IS NORMALIZED`}if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.normalize"){let p=this.visit(n[0],r);if(n.length===2){let f=this.visit(n[1],r).replace(/'/g,"");return `normalize(${p}, ${f})`}else return `normalize(${p})`}if(e.funcformat==="COERCE_SQL_SYNTAX"&&a==="pg_catalog.system_user"&&n.length===0)return "SYSTEM_USER";if(a==="pg_catalog.overlaps"&&n.length===4){let p=this.visit(n[0],r),c=this.visit(n[1],r),f=this.visit(n[2],r),m=this.visit(n[3],r);return `(${p}, ${c}) OVERLAPS (${f}, ${m})`}if(a==="pg_catalog.timezone"&&n.length===2){let p=this.visit(n[1],r),c=this.visit(n[0],r);if(n[1]&&"A_Expr"in n[1]&&n[1].A_Expr?.kind==="AEXPR_OP"){let f=this.deparseOperatorName(h.unwrapList(n[1].A_Expr.name),r);(f==="+"||f==="-"||f==="*"||f==="/")&&(p=r.parens(p));}return `${p} AT TIME ZONE ${c}`}let o=[];if(e.agg_star)e.agg_distinct?o.push("DISTINCT *"):o.push("*");else {let p=n.map(c=>this.visit(c,r));if(e.func_variadic&&p.length>0){let c=p.length-1;p[c]=`VARIADIC ${p[c]}`;}e.agg_distinct&&p.length>0?o.push("DISTINCT "+p.join(", ")):o.push(...p);}let l="";if(e.agg_order&&e.agg_order.length>0){let c=h.unwrapList(e.agg_order).map(f=>this.visit(f,r));e.agg_within_group?l=` WITHIN GROUP (ORDER BY ${c.join(", ")})`:l=` ORDER BY ${c.join(", ")}`;}let u;if(e.agg_within_group&&l?u=`${a}(${o.join(", ")})${l}`:u=`${a}(${o.join(", ")}${l})`,e.agg_filter&&(u+=` FILTER (WHERE ${this.visit(e.agg_filter,r)})`),e.over)if(e.over.name)u+=` OVER ${e.over.name}`;else {let p=[];if(e.over.partitionClause){let m=h.unwrapList(e.over.partitionClause).map(d=>this.visit(d,r));p.push(`PARTITION BY ${m.join(", ")}`);}if(e.over.orderClause){let m=h.unwrapList(e.over.orderClause).map(d=>this.visit(d,r));p.push(`ORDER BY ${m.join(", ")}`);}let c=this.formatWindowFrame(e.over,r.spawn("FuncCall"));if(c&&p.push(c),p.length>0)if(r.isPretty()&&p.length>1){let f=p.map(m=>r.indent(m));u+=` OVER (${r.newline()}${f.join(r.newline())}${r.newline()})`;}else u+=` OVER (${p.join(" ")})`;else u+=" OVER ()";}return u}FuncExpr(e,r){let t=`func_${e.funcid}`,n=e.args?h.unwrapList(e.args).map(i=>this.visit(i,r)).join(", "):"";return `${t}(${n})`}A_Const(e,r){let t=e;if(t.ival!==void 0)return typeof t.ival=="object"&&t.ival!==null?t.ival.ival!==void 0?t.ival.ival.toString():Object.keys(t.ival).length===0?"0":t.ival.toString():t.ival===null?"NULL":t.ival.toString();if(t.fval!==void 0)return typeof t.fval=="object"&&t.fval!==null?t.fval.fval!==void 0?t.fval.fval.toString():Object.keys(t.fval).length===0?"0.0":t.fval.toString():t.fval===null?"NULL":t.fval.toString();if(t.sval!==void 0)return typeof t.sval=="object"&&t.sval!==null?t.sval.sval!==void 0?S.formatEString(t.sval.sval):t.sval.String&&t.sval.String.sval!==void 0?S.formatEString(t.sval.String.sval):Object.keys(t.sval).length===0?"''":S.formatEString(t.sval.toString()):t.sval===null?"NULL":S.formatEString(t.sval);if(t.boolval!==void 0)return typeof t.boolval=="object"&&t.boolval!==null?t.boolval.boolval!==void 0?t.boolval.boolval?"true":"false":Object.keys(t.boolval).length===0?"false":t.boolval?"true":"false":t.boolval===null?"NULL":t.boolval?"true":"false";if(t.bsval!==void 0)if(typeof t.bsval=="object"&&t.bsval!==null)if(t.bsval.bsval!==void 0){let n=t.bsval.bsval;return n.startsWith("x")&&/^x[0-9A-Fa-f]+$/.test(n)?`x'${n.substring(1)}'`:n.startsWith("b")?`b'${n.substring(1)}'`:`b'${n}'`}else return Object.keys(t.bsval).length===0?"''":t.bsval.toString();else {if(t.bsval===null)return "NULL";{let n=t.bsval;return n.startsWith("x")&&/^x[0-9A-Fa-f]+$/.test(n)?`x'${n.substring(1)}'`:n.startsWith("b")?`b'${n.substring(1)}'`:`b'${n}'`}}if(t.val){if(t.val.Integer?.ival!==void 0)return t.val.Integer.ival.toString();if(t.val.Float?.fval!==void 0)return t.val.Float.fval.toString();if(t.val.String?.sval!==void 0)return S.escape(t.val.String.sval);if(t.val.Boolean?.boolval!==void 0)return t.val.Boolean.boolval?"true":"false";if(t.val.BitString?.bsval!==void 0)return t.val.BitString.bsval}return t.isnull===true?"NULL":typeof t=="object"&&t!==null?t.Boolean!==void 0?t.Boolean?"true":"false":t.Integer!==void 0?typeof t.Integer=="object"&&t.Integer.ival!==void 0?t.Integer.ival.toString():t.Integer.toString():t.Float!==void 0?typeof t.Float=="object"&&t.Float.fval!==void 0?t.Float.fval.toString():t.Float.toString():t.String!==void 0?typeof t.String=="object"&&t.String.sval!==void 0?S.escape(t.String.sval):S.escape(t.String):(Object.keys(t).length===0||console.warn("A_Const: Unhandled object structure:",JSON.stringify(t,null,2)),"NULL"):"NULL"}ColumnRef(e,r){return h.unwrapList(e.fields).map(n=>n.String?S.quoteIdentifier(n.String.sval||n.String.str):n.A_Star?"*":this.visit(n,r)).join(".")}TypeName(e,r){if(!e.names)return "";let t=[];e.setof&&t.push("SETOF");let n=e.names.map(u=>u.String?u.String.sval||u.String.str:"").filter(Boolean);if(n.length===0)return "";let i=null;e.typmods?n.some(p=>(typeof p=="string"?p:p.String?.sval||p.String?.str)==="interval")?i=this.formatIntervalTypeMods(e.typmods,r):i=this.formatTypeMods(e.typmods,r):e.typemod&&e.typemod!==-1&&(i=this.formatSingleTypeMod(e.typemod,n[0]));let a=(u,p)=>p!=null?u==="interval"?p.startsWith("(")?`${u}${p}`:`${u} ${p}`:`${u}(${p})`:u,o=u=>u.map(p=>p.Integer&&p.Integer.ival!==void 0&&p.Integer.ival!==-1?`[${p.Integer.ival}]`:"[]").join("");if(n.length===1){let u=n[0];if(u==="char")return r.parentNodeTypes.includes("TypeCast")&&i==="1"?t.push('"char"'):t.push(a('"char"',i)),t.join(" ");let p=a(S.quoteIdentifierTypeName(u),i);return e.arrayBounds&&e.arrayBounds.length>0&&(p+=o(e.arrayBounds)),t.push(p),t.join(" ")}if(n.length===2){let[u,p]=n;if(u==="pg_catalog"&&p==="char")return t.push(a("pg_catalog.char",i)),t.join(" ");if(u==="pg_catalog"){let c=`${u}.${p}`;p==="bpchar"&&i?c="char":p==="varchar"?c="varchar":p==="numeric"?c="numeric":p==="int4"?c="int":p==="float8"?c="double precision":p==="float4"?c="real":p==="int8"?c="bigint":p==="int2"?c="smallint":p==="bool"?c="boolean":p==="interval"?(r.parentNodeTypes.includes("TypeCast"),c="interval"):p==="timestamptz"?i?(c=`timestamp(${i}) with time zone`,i=null):c="timestamp with time zone":p==="timetz"?i?(c=`time(${i}) with time zone`,i=null):c="time with time zone":p==="timestamp"?i?(c=`timestamp(${i})`,i=null):c="timestamp":p==="time"&&(i?(c=`time(${i})`,i=null):c="time");let f=a(c,i);return e.arrayBounds&&e.arrayBounds.length>0&&(f+=o(e.arrayBounds)),t.push(f),t.join(" ")}}let l=a(S.quoteTypeDottedName(n),i);return e.arrayBounds&&e.arrayBounds.length>0&&(l+=o(e.arrayBounds)),t.push(l),t.join(" ")}Alias(e,r){let t=e.aliasname,n=[];if(e.colnames){let a=h.unwrapList(e.colnames).map(o=>{let l=this.deparse(o,r);return l.startsWith('"')&&l.endsWith('"')?l:this.quoteIfNeeded(l)});n.push("AS",this.quoteIfNeeded(t)+r.parens(a.join(", ")));}else n.push("AS",this.quoteIfNeeded(t));return n.join(" ")}RangeVar(e,r){let t=[];e&&(!("inh"in e)||e.inh===void 0)&&!r.parentNodeTypes.includes("CompositeTypeStmt")&&!r.parentNodeTypes.includes("AlterTypeStmt")&&r.objtype!=="OBJECT_TYPE"&&!r.parentNodeTypes.includes("CreateForeignTableStmt")&&t.push("ONLY");let n="";if(e.catalogname?(n=S.quoteIdentifier(e.catalogname),e.schemaname&&(n+="."+S.quoteIdentifierAfterDot(e.schemaname)),n+="."+S.quoteIdentifierAfterDot(e.relname)):e.schemaname?n=S.quoteQualifiedIdentifier(e.schemaname,e.relname):n=S.quoteIdentifier(e.relname),t.push(n),e.alias){let a=this.Alias(e.alias,r);t.push(a);}return t.join(" ")}formatIntervalTypeMods(e,r){if(!e||e.length===0)return null;let t=h.unwrapList(e),n={4:"year",2:"month",8:"day",1024:"hour",2048:"minute",4096:"second",6:"year to month",1032:"day to hour",3080:"day to minute",7176:"day to second",3072:"hour to minute",7168:"hour to second",6144:"minute to second"};if(t.length===1){let a=t[0];if(a&&typeof a=="object"){let o=a.A_Const;if(o&&o.ival!==void 0){let l=typeof o.ival=="object"?o.ival.ival:o.ival;if(l!==void 0)return n[l]?n[l]:`(${l})`}}}if(t.length===2){let a=t[0],o=t[1];if(a&&typeof a=="object"){let l=a.A_Const;if(l&&l.ival!==void 0){let u=typeof l.ival=="object"?l.ival.ival:l.ival;if(o&&typeof o=="object"){let p=o.A_Const;if(p&&p.ival!==void 0){let c=typeof p.ival=="object"?p.ival.ival!==void 0?p.ival.ival:0:p.ival;if(u===32767&&c>=0)return `(${c})`;if(n[u]&&c>=0)return `${n[u]}(${c})`}}}}}let i=t.map(a=>{if(a&&typeof a=="object"){let l=a.A_Const;if(l&&l.ival!==void 0){let u=typeof l.ival=="object"?l.ival.ival:l.ival;if(u!==void 0)return n[u]||u.toString()}}return this.visit(a,r)||""}).filter(Boolean);return i.length>0?i.join(" "):null}formatTypeMods(e,r){if(!e||e.length===0)return null;let n=h.unwrapList(e).filter(i=>{if(i&&typeof i=="object"){let a=i.A_Const;if(a&&a.ival&&(typeof a.ival=="object"?a.ival.ival:a.ival)===32767)return false}return true});return n.length===0?null:n.map(i=>this.deparse(i,r)).join(", ")}formatSingleTypeMod(e,r){switch(r){case "varchar":case "bpchar":case "char":if(e>4)return (e-64).toString();break;case "numeric":case "decimal":if(e>4){let t=e-4,n=t>>16&65535,i=t&65535;return i>0?`${n},${i}`:n.toString()}break;case "time":case "timetz":case "timestamp":case "timestamptz":case "interval":if(e>=0)return e.toString();break}return null}getPgCatalogTypeName(e,r){switch(e){case "bpchar":return r!=null?"char":"bpchar";case "varchar":return "varchar";case "numeric":return "numeric";case "bool":return "boolean";case "int2":return "smallint";case "int4":return "int";case "int8":return "bigint";case "real":return "float4";case "time":return "time";case "timestamp":return "timestamp";case "interval":return "interval";case "bit":return "bit";default:return e}}isPgCatalogType(e){let r=e.replace(/^pg_catalog\./,"");if(Db.includes(r))return true;for(let[t,n]of jb)if(n.includes(r))return true;return false}A_ArrayExpr(e,r){return `ARRAY[${h.unwrapList(e.elements).map(i=>this.visit(i,r)).join(", ")}]`}A_Indices(e,r){let t=[];return e.is_slice?(e.lidx&&t.push(this.visit(e.lidx,r)),t.push(":"),e.uidx&&t.push(this.visit(e.uidx,r))):e.uidx&&t.push(this.visit(e.uidx,r)),`[${t.join("")}]`}A_Indirection(e,r){let t=this.visit(e.arg,r),n=this.getNodeType(e.arg);(n==="TypeCast"||n==="SubLink"||n==="A_Expr"||n==="FuncCall"||n==="A_Indirection"||n==="ColumnRef"||n==="RowExpr")&&(t=`(${t})`);let i=[t],a=h.unwrapList(e.indirection);for(let o of a)if(o.String||o.A_Star){let l=o.A_Star?"*":S.quoteIdentifier(o.String.sval||o.String.str);i.push(`.${l}`);}else i.push(this.visit(o,r));return i.join("")}A_Star(e,r){return "*"}CaseExpr(e,r){let t=["CASE"];e.arg&&t.push(this.visit(e.arg,r));let n=h.unwrapList(e.args);if(r.isPretty()&&n.length>0){for(let i of n){let a=this.visit(i,r);this.containsMultilineStringLiteral(a)?t.push(r.newline()+a):t.push(r.newline()+r.indent(a));}if(e.defresult){let i=this.visit(e.defresult,r);this.containsMultilineStringLiteral(i)?t.push(r.newline()+"ELSE "+i):t.push(r.newline()+r.indent("ELSE "+i));}return t.push(r.newline()+"END"),t.join(" ")}else {for(let i of n)t.push(this.visit(i,r));return e.defresult&&(t.push("ELSE"),t.push(this.visit(e.defresult,r))),t.push("END"),t.join(" ")}}CoalesceExpr(e,r){return `COALESCE(${h.unwrapList(e.args).map(i=>this.visit(i,r)).join(", ")})`}TypeCast(e,r){let t=this.visit(e.arg,r),n=this.TypeName(e.typeName,r);if(n==="bpchar"||n==="pg_catalog.bpchar"){let i=e.typeName?.names;if(i&&i.length===2&&i[0]?.String?.sval==="pg_catalog"&&i[1]?.String?.sval==="bpchar")return `CAST(${t} AS ${n})`}if(this.isPgCatalogType(n)){let i=this.getNodeType(e.arg),a=i==="A_Const"||i==="ColumnRef",o=i==="FuncCall";if((a||o)&&!(a&&(t.includes("(")||t.startsWith("-")))){let u=n.replace("pg_catalog.","");return o?`${r.parens(t)}::${u}`:`${t}::${u}`}}return `CAST(${t} AS ${n})`}CollateClause(e,r){let t=[];if(e.arg){let n=this.visit(e.arg,r),i=this.getNodeType(e.arg);(i==="A_Expr"||i==="FuncCall"||i==="SubLink")&&(n=`(${n})`),t.push(n);}if(t.push("COLLATE"),e.collname){let n=h.unwrapList(e.collname);t.push(n.map(i=>this.visit(i,r)).join("."));}return t.join(" ")}BooleanTest(e,r){let t=[],n=r.spawn("BooleanTest",{bool:true});switch(t.push(this.visit(e.arg,n)),e.booltesttype){case "IS_TRUE":t.push("IS TRUE");break;case "IS_NOT_TRUE":t.push("IS NOT TRUE");break;case "IS_FALSE":t.push("IS FALSE");break;case "IS_NOT_FALSE":t.push("IS NOT FALSE");break;case "IS_UNKNOWN":t.push("IS UNKNOWN");break;case "IS_NOT_UNKNOWN":t.push("IS NOT UNKNOWN");break}return t.join(" ")}NullTest(e,r){let t=[];switch(t.push(this.visit(e.arg,r)),e.nulltesttype){case "IS_NULL":t.push("IS NULL");break;case "IS_NOT_NULL":t.push("IS NOT NULL");break}return t.join(" ")}quoteIfNeeded(e){return S.quoteIdentifier(e)}preserveOperatorDefElemCase(e){return {leftarg:"Leftarg",rightarg:"Rightarg",procedure:"Procedure",function:"Function",commutator:"Commutator",negator:"Negator",restrict:"Restrict",join:"Join",hashes:"Hashes",merges:"Merges"}[e.toLowerCase()]||e}String(e,r){if(r.isStringLiteral||r.isEnumValue)return S.formatEString(e.sval||"");let t=e.sval||"";return r.parentNodeTypes.includes("DefElem")||r.parentNodeTypes.includes("CreateOpClassItem")||r.parentNodeTypes.includes("ObjectWithArgs")&&/^[+\-*/<>=~!@#%^&|`?]+$/.test(t)?t:S.quoteIdentifier(t)}Integer(e,r){return e.ival?.toString()||"0"}Float(e,r){return e.fval||"0.0"}Boolean(e,r){return e.boolval?"true":"false"}BitString(e,r){return e.bsval.startsWith("x")?`x'${e.bsval.substring(1)}'`:e.bsval.startsWith("b")?`b'${e.bsval.substring(1)}'`:`b'${e.bsval}'`}Null(e,r){return "NULL"}List(e,r){return !e.items||e.items.length===0?"":e.items.map(t=>this.visit(t,r)).join(", ")}CreateStmt(e,r){let t=["CREATE"];if(e.relation&&e.relation.relpersistence==="t"?t.push("TEMPORARY"):e.relation&&e.relation.relpersistence==="u"&&t.push("UNLOGGED"),e.if_not_exists?t.push("TABLE IF NOT EXISTS"):t.push("TABLE"),t.push(this.RangeVar(e.relation,r)),e.ofTypename){if(t.push("OF"),t.push(this.TypeName(e.ofTypename,r)),e.tableElts){let i=h.unwrapList(e.tableElts).map(a=>this.deparse(a,r));t.push(r.parens(i.join(", ")));}}else if(e.tableElts){let i=h.unwrapList(e.tableElts).map(a=>this.deparse(a,r.spawn("CreateStmt")));if(r.isPretty()){let a=i.map(o=>{let l=o.trim();return l.startsWith(`
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
`)&&(n+=" "),n+=t[i];return n}return t.join(" ")}SubLink(e,r){let t=r.parens(this.visit(e.subselect,r));switch(e.subLinkType){case "ANY_SUBLINK":if(e.testexpr&&e.operName){let n=this.visit(e.testexpr,r),i=this.deparseOperatorName(e.operName,r);return `${n} ${i} ANY ${t}`}else if(e.testexpr)return `${this.visit(e.testexpr,r)} IN ${t}`;return t;case "ALL_SUBLINK":if(e.testexpr&&e.operName){let n=this.visit(e.testexpr,r),i=this.deparseOperatorName(e.operName,r);return `${n} ${i} ALL ${t}`}return t;case "EXISTS_SUBLINK":return `EXISTS ${t}`;case "ARRAY_SUBLINK":return `ARRAY${t}`;default:return t}}CaseWhen(e,r){let t=["WHEN"];return e.expr&&t.push(this.visit(e.expr,r)),t.push("THEN"),e.result&&t.push(this.visit(e.result,r)),t.join(" ")}WindowDef(e,r){let t=[];e.name&&t.push(e.name);let n=[];if(e.partitionClause){let a=h.unwrapList(e.partitionClause).map(o=>this.visit(o,r));n.push(`PARTITION BY ${a.join(", ")}`);}if(e.orderClause){let a=h.unwrapList(e.orderClause).map(o=>this.visit(o,r));n.push(`ORDER BY ${a.join(", ")}`);}if(e.frameOptions&&e.frameOptions!==1058){let i=this.formatWindowFrame(e,r.spawn("WindowDef"));i&&n.push(i);}return n.length>0?(e.name&&t.push("AS"),t.push(`(${n.join(" ")})`)):e.name?(t.push("AS"),t.push("()")):t.length===0&&t.push("()"),t.join(" ")}formatWindowFrame(e,r){if(!e.frameOptions)return null;let t=e.frameOptions,i=t&-229377,a=[];if(t&1&&(t&2?a.push("RANGE"):t&4?a.push("ROWS"):t&8&&a.push("GROUPS")),a.length===0)return null;let o=[];if(i===789)o.push("CURRENT ROW"),o.push("AND UNBOUNDED FOLLOWING");else if(i===1077)o.push("UNBOUNDED PRECEDING"),o.push("AND CURRENT ROW");else if(i===18453)e.startOffset&&e.endOffset&&(o.push(`${this.visit(e.startOffset,r)} PRECEDING`),o.push(`AND ${this.visit(e.endOffset,r)} FOLLOWING`));else if(i===1557)o.push("CURRENT ROW"),o.push("AND CURRENT ROW");else if(i===16917)o.push("CURRENT ROW"),e.endOffset&&o.push(`AND ${this.visit(e.endOffset,r)} FOLLOWING`);else {if(i===1058)return null;e.startOffset?t&1024?o.push(`${this.visit(e.startOffset,r)} PRECEDING`):t&2048?o.push(`${this.visit(e.startOffset,r)} FOLLOWING`):o.push(`${this.visit(e.startOffset,r)} PRECEDING`):t&16?o.push("UNBOUNDED PRECEDING"):t&32&&o.push("CURRENT ROW"),e.endOffset?o.length>0&&(t&4096?o.push(`AND ${this.visit(e.endOffset,r)} PRECEDING`):t&8192?o.push(`AND ${this.visit(e.endOffset,r)} FOLLOWING`):o.push(`AND ${this.visit(e.endOffset,r)} FOLLOWING`)):t&128?o.length>0&&o.push("AND UNBOUNDED FOLLOWING"):(o.length>0&&o.push("AND CURRENT ROW"));}return o.length>0&&(a.push("BETWEEN"),a.push(o.join(" "))),t&32768?a.push("EXCLUDE CURRENT ROW"):t&65536?a.push("EXCLUDE GROUP"):t&131072&&a.push("EXCLUDE TIES"),a.join(" ")}SortBy(e,r){let t=[];if(e.node&&t.push(this.visit(e.node,r)),e.sortby_dir==="SORTBY_USING"&&e.useOp){t.push("USING");let n=h.unwrapList(e.useOp);t.push(n.map(i=>i.String&&i.String.sval?i.String.sval:this.visit(i,r)).join("."));}else e.sortby_dir==="SORTBY_ASC"?t.push("ASC"):e.sortby_dir==="SORTBY_DESC"&&t.push("DESC");return e.sortby_nulls==="SORTBY_NULLS_FIRST"?t.push("NULLS FIRST"):e.sortby_nulls==="SORTBY_NULLS_LAST"&&t.push("NULLS LAST"),t.join(" ")}GroupingSet(e,r){switch(e.kind){case "GROUPING_SET_EMPTY":return "()";case "GROUPING_SET_SIMPLE":return "";case "GROUPING_SET_ROLLUP":return `ROLLUP (${h.unwrapList(e.content).map(u=>this.visit(u,r)).join(", ")})`;case "GROUPING_SET_CUBE":return `CUBE (${h.unwrapList(e.content).map(u=>this.visit(u,r)).join(", ")})`;case "GROUPING_SET_SETS":return `GROUPING SETS (${h.unwrapList(e.content).map(u=>this.visit(u,r)).join(", ")})`;default:return ""}}CommonTableExpr(e,r){let t=[];if(e.ctename&&t.push(e.ctename),e.aliascolnames){let i=h.unwrapList(e.aliascolnames).map(a=>this.visit(a,r));t[t.length-1]+=r.parens(i.join(", "));}return t.push("AS"),e.ctematerialized==="CTEMaterializeNever"?t.push("NOT MATERIALIZED"):e.ctematerialized==="CTEMaterializeAlways"&&t.push("MATERIALIZED"),e.ctequery&&t.push(r.parens(this.visit(e.ctequery,r))),t.join(" ")}ParamRef(e,r){return `$${e.number}`}LockingClause(e,r){let t=[];switch(e.strength){case "LCS_FORUPDATE":t.push("FOR UPDATE");break;case "LCS_FORSHARE":t.push("FOR SHARE");break;case "LCS_FORKEYSHARE":t.push("FOR KEY SHARE");break;case "LCS_FORNOKEYUPDATE":t.push("FOR NO KEY UPDATE");break;default:throw new Error(`Unsupported locking strength: ${e.strength}`)}if(e.lockedRels&&e.lockedRels.length>0){t.push("OF");let n=h.unwrapList(e.lockedRels).map(i=>this.visit(i,r)).join(", ");t.push(n);}return e.waitPolicy==="LockWaitSkip"?t.push("SKIP LOCKED"):e.waitPolicy==="LockWaitError"&&t.push("NOWAIT"),t.join(" ")}MinMaxExpr(e,r){let n=h.unwrapList(e.args).map(i=>this.visit(i,r));return e.op==="IS_GREATEST"?`GREATEST(${n.join(", ")})`:`LEAST(${n.join(", ")})`}RowExpr(e,r){let n=h.unwrapList(e.args).map(i=>this.visit(i,r));return e.row_format==="COERCE_IMPLICIT_CAST"?`(${n.join(", ")})`:`ROW(${n.join(", ")})`}OpExpr(e,r){let t=h.unwrapList(e.args);if(t.length===2){let n=this.visit(t[0],r),i=this.visit(t[1],r),a=this.getOperatorName(e.opno);return `${n} ${a} ${i}`}else if(t.length===1){let n=this.visit(t[0],r);return `${this.getOperatorName(e.opno)} ${n}`}throw new Error(`Unsupported OpExpr with ${t.length} arguments`)}DistinctExpr(e,r){let t=h.unwrapList(e.args);if(t.length===2){let n=r.spawn("DistinctExpr",{isStringLiteral:true}),i=this.visit(t[0],n),a=this.visit(t[1],n);return `${i} IS DISTINCT FROM ${a}`}throw new Error(`DistinctExpr requires exactly 2 arguments, got ${t.length}`)}NullIfExpr(e,r){let t=h.unwrapList(e.args);if(t.length===2){let n=r.spawn("NullIfExpr",{isStringLiteral:true}),i=this.visit(t[0],n),a=this.visit(t[1],n);return `NULLIF(${i}, ${a})`}throw new Error(`NullIfExpr requires exactly 2 arguments, got ${t.length}`)}ScalarArrayOpExpr(e,r){let t=h.unwrapList(e.args);if(t.length===2){let n=this.visit(t[0],r),i=this.visit(t[1],r),a=e.useOr?"ANY":"ALL",o=this.getOperatorName(e.opno);return `${n} ${o} ${a}(${i})`}throw new Error(`ScalarArrayOpExpr requires exactly 2 arguments, got ${t.length}`)}Aggref(e,r){let t=this.getAggFunctionName(e.aggfnoid),n=t+"(",i=e.aggdistinct&&e.aggdistinct.length>0;if(e.args&&e.args.length>0){let o=h.unwrapList(e.args).map(l=>this.visit(l,r));i?n+="DISTINCT "+o.join(", "):n+=o.join(", ");}else t.toUpperCase()==="COUNT"&&(i?n+="DISTINCT *":n+="*");if(n+=")",e.aggorder&&e.aggorder.length>0){n+=" ORDER BY ";let o=h.unwrapList(e.aggorder).map(l=>this.visit(l,r));n+=o.join(", ");}return n}WindowFunc(e,r){let n=this.getWindowFunctionName(e.winfnoid)+"(";if(e.args&&e.args.length>0){let a=h.unwrapList(e.args).map(o=>this.visit(o,r));n+=a.join(", ");}return n+=") OVER (",e.winref&&typeof e.winref=="object"?n+=this.visit(e.winref,r):e.winref&&(n+="ORDER BY created_at ASC"),n+=")",n}FieldSelect(e,r){let t=[];return e.arg&&t.push(this.visit(e.arg,r)),e.fieldnum!==void 0&&t.push(`.field_${e.fieldnum}`),t.join("")}RelabelType(e,r){if(e.arg){let t=r.spawn("RelabelType",{isStringLiteral:true});return this.visit(e.arg,t)}return ""}CoerceViaIO(e,r){return e.arg?this.visit(e.arg,r):""}ArrayCoerceExpr(e,r){return e.arg?this.visit(e.arg,r):""}ConvertRowtypeExpr(e,r){if(e.arg){let t=r.spawn("ConvertRowtypeExpr",{isStringLiteral:true});return this.visit(e.arg,t)}return ""}NamedArgExpr(e,r){let t=[];return e.name&&(t.push(e.name),t.push("=>")),e.arg&&t.push(this.visit(e.arg,r)),t.join(" ")}ViewStmt(e,r){let t=[];if(t.push("CREATE"),e.replace&&t.push("OR REPLACE"),e.view&&e.view.relpersistence==="t"&&t.push("TEMPORARY"),t.push("VIEW"),e.view&&t.push(this.RangeVar(e.view,r)),e.aliases&&e.aliases.length>0){let n=h.unwrapList(e.aliases).map(i=>this.visit(i,r));t.push(r.parens(n.join(", ")));}if(e.options&&e.options.length>0){let n=r.spawn("ViewStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(`WITH (${i.join(", ")})`);}if(t.push("AS"),e.query&&t.push(this.visit(e.query,r)),e.withCheckOption)switch(e.withCheckOption){case "CASCADED_CHECK_OPTION":t.push("WITH CASCADED CHECK OPTION");break;case "LOCAL_CHECK_OPTION":t.push("WITH LOCAL CHECK OPTION");break}return t.join(" ")}IndexStmt(e,r){let t=[];if(t.push("CREATE"),e.unique&&t.push("UNIQUE"),t.push("INDEX"),e.concurrent&&t.push("CONCURRENTLY"),e.if_not_exists&&t.push("IF NOT EXISTS"),e.idxname&&t.push(S.quoteIdentifier(e.idxname)),t.push("ON"),e.relation&&t.push(this.RangeVar(e.relation,r)),e.accessMethod&&e.accessMethod!=="btree"&&(t.push("USING"),t.push(e.accessMethod)),e.indexParams&&e.indexParams.length>0){let n=h.unwrapList(e.indexParams).map(i=>this.visit(i,r));t.push(r.parens(n.join(", ")));}if(e.indexIncludingParams&&e.indexIncludingParams.length>0){let n=h.unwrapList(e.indexIncludingParams).map(i=>this.visit(i,r));t.push("INCLUDE"),t.push(r.parens(n.join(", ")));}if(e.whereClause&&(t.push("WHERE"),t.push(this.visit(e.whereClause,r))),e.options&&e.options.length>0){let n=r.spawn("IndexStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push("WITH"),t.push(r.parens(i.join(", ")));}return e.nulls_not_distinct&&t.push("NULLS NOT DISTINCT"),e.tableSpace&&(t.push("TABLESPACE"),t.push(S.quoteIdentifier(e.tableSpace))),t.join(" ")}IndexElem(e,r){let t=[];if(e.name?t.push(S.quoteIdentifier(e.name)):e.expr&&t.push(r.parens(this.visit(e.expr,r))),e.collation&&e.collation.length>0){let n=h.unwrapList(e.collation).map(i=>this.visit(i,r));t.push("COLLATE"),t.push(n.join("."));}if(e.opclass&&e.opclass.length>0){let i=h.unwrapList(e.opclass).map(a=>this.visit(a,r)).join(".");if(e.opclassopts&&e.opclassopts.length>0){let a=h.unwrapList(e.opclassopts).map(o=>{if(o.DefElem&&o.DefElem.arg&&this.getNodeType(o.DefElem.arg)==="String"){let l=this.getNodeData(o.DefElem.arg);return `${o.DefElem.defname}='${l.sval}'`}return this.visit(o,r.spawn("IndexElem"))});i+=`(${a.join(", ")})`;}t.push(i);}if(e.ordering)switch(e.ordering){case "SORTBY_ASC":t.push("ASC");break;case "SORTBY_DESC":t.push("DESC");break}if(e.nulls_ordering)switch(e.nulls_ordering){case "SORTBY_NULLS_FIRST":t.push("NULLS FIRST");break;case "SORTBY_NULLS_LAST":t.push("NULLS LAST");break}return t.join(" ")}PartitionElem(e,r){let t=[];if(e.name?t.push(S.quoteIdentifier(e.name)):e.expr&&t.push(r.parens(this.visit(e.expr,r))),e.collation&&e.collation.length>0){let n=h.unwrapList(e.collation).map(i=>this.visit(i,r));t.push("COLLATE"),t.push(n.join("."));}if(e.opclass&&e.opclass.length>0){let n=h.unwrapList(e.opclass).map(i=>this.visit(i,r));t.push(n.join("."));}return t.join(" ")}PartitionCmd(e,r){let t=[];if(e.concurrent&&t.push("CONCURRENTLY"),e.name&&t.push(this.visit(e.name,r)),e.bound)if(e.bound.strategy==="l"&&e.bound.listdatums){t.push("FOR VALUES IN");let n=h.unwrapList(e.bound.listdatums).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}else if(e.bound.strategy==="r"&&(e.bound.lowerdatums||e.bound.upperdatums)){if(t.push("FOR VALUES FROM"),e.bound.lowerdatums){let n=h.unwrapList(e.bound.lowerdatums).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}if(e.bound.upperdatums){t.push("TO");let n=h.unwrapList(e.bound.upperdatums).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}}else e.bound.strategy==="h"&&e.bound.modulus!==void 0&&e.bound.remainder!==void 0?(t.push("FOR VALUES WITH"),t.push(`(modulus ${e.bound.modulus}, remainder ${e.bound.remainder})`)):e.bound.is_default&&t.push("DEFAULT");return t.join(" ")}getAggFunctionName(e){return {2100:"avg",2101:"count",2102:"max",2103:"min",2104:"sum",2105:"stddev",2106:"variance",2107:"array_agg",2108:"string_agg"}[e||0]||"unknown_agg"}getWindowFunctionName(e){return {3100:"row_number",3101:"rank",3102:"dense_rank",3103:"percent_rank",3104:"cume_dist",3105:"ntile",3106:"lag",3107:"lead",3108:"first_value",3109:"last_value"}[e||0]||"unknown_window_func"}getOperatorName(e){return {96:"=",518:"<>",97:"<",521:">",523:"<=",525:">=",551:"+",552:"-",553:"*",554:"/",555:"%",484:"-",1752:"~~",1753:"!~~",1754:"~~*",1755:"!~~*",15:"=",58:"<",59:"<=",61:">",62:">="}[e||0]||"="}JoinExpr(e,r){let t=[];e.larg&&t.push(this.visit(e.larg,r));let n="";switch(e.isNatural&&(n="NATURAL "),e.jointype){case "JOIN_INNER":e.isNatural?n+="JOIN":!e.quals&&(!e.usingClause||e.usingClause.length===0)?n+="CROSS JOIN":n+="JOIN";break;case "JOIN_LEFT":n+="LEFT JOIN";break;case "JOIN_FULL":n+="FULL JOIN";break;case "JOIN_RIGHT":n+="RIGHT JOIN";break;default:n+="JOIN";}if(e.rarg){let a=this.visit(e.rarg,r);e.rarg&&"JoinExpr"in e.rarg&&!e.rarg.JoinExpr.alias&&(a=`(${a})`),r.isPretty()?t.push(r.newline()+n+" "+a):t.push(n+" "+a);}else r.isPretty()?t.push(r.newline()+n):t.push(n);if(e.usingClause&&e.usingClause.length>0){let o=h.unwrapList(e.usingClause).map(l=>this.visit(l,r));r.isPretty()?t.push(` USING (${o.join(", ")})`):t.push(`USING (${o.join(", ")})`);}else if(e.quals){let a=this.visit(e.quals,r);r.isPretty()?a.includes("AND")||a.includes("OR")||a.length>50?this.containsMultilineStringLiteral(a)?t.push(` ON ${a}`):t.push(` ON${r.newline()}${r.indent(a)}`):t.push(` ON ${a}`):t.push(`ON ${a}`);}let i;if(r.isPretty()?i=t.join(""):i=t.join(" "),e.join_using_alias&&e.join_using_alias.aliasname){let a=e.join_using_alias.aliasname;if(e.join_using_alias.colnames&&e.join_using_alias.colnames.length>0){let l=h.unwrapList(e.join_using_alias.colnames).map(u=>this.visit(u,r)).join(", ");a+=`(${l})`;}i+=` AS ${a}`;}if(e.alias&&e.alias.aliasname){let a=e.alias.aliasname;if(e.alias.colnames&&e.alias.colnames.length>0){let l=h.unwrapList(e.alias.colnames).map(u=>this.visit(u,r)).join(", ");a+=`(${l})`;}i=`(${i}) ${a}`;}return i}FromExpr(e,r){let i=h.unwrapList(e.fromlist).map(a=>this.visit(a,r)).join(", ");return e.quals&&(i+=` WHERE ${this.visit(e.quals,r)}`),i}TransactionStmt(e,r){let t=[];switch(e.kind){case "TRANS_STMT_BEGIN":t.push("BEGIN");break;case "TRANS_STMT_START":t.push("START TRANSACTION");break;case "TRANS_STMT_COMMIT":t.push("COMMIT");break;case "TRANS_STMT_ROLLBACK":t.push("ROLLBACK");break;case "TRANS_STMT_SAVEPOINT":t.push("SAVEPOINT"),e.savepoint_name&&t.push(S.quoteIdentifier(e.savepoint_name));break;case "TRANS_STMT_RELEASE":t.push("RELEASE SAVEPOINT"),e.savepoint_name&&t.push(S.quoteIdentifier(e.savepoint_name));break;case "TRANS_STMT_ROLLBACK_TO":t.push("ROLLBACK TO"),e.savepoint_name&&t.push(S.quoteIdentifier(e.savepoint_name));break;case "TRANS_STMT_PREPARE":t.push("PREPARE TRANSACTION"),e.gid&&t.push(`'${e.gid}'`);break;case "TRANS_STMT_COMMIT_PREPARED":t.push("COMMIT PREPARED"),e.gid&&t.push(`'${e.gid}'`);break;case "TRANS_STMT_ROLLBACK_PREPARED":t.push("ROLLBACK PREPARED"),e.gid&&t.push(`'${e.gid}'`);break;default:throw new Error(`Unsupported TransactionStmt kind: ${e.kind}`)}if(e.options&&e.options.length>0){let n=h.unwrapList(e.options).map(i=>{if(i.DefElem){let a=i.DefElem;if(a.defname==="transaction_read_only"){let o=false;if(a.arg){let l=this.getNodeData(a.arg);if(l.ival!==void 0)o=(typeof l.ival=="object"?l.ival.ival:l.ival)===1;else if(l.sval!==void 0){let p=(typeof l.sval=="object"?l.sval.sval:l.sval).replace(/'/g,"");o=p.toLowerCase()==="on"||p.toLowerCase()==="true";}}return o?"READ ONLY":"READ WRITE"}else if(a.defname==="transaction_isolation"){if(a.arg&&a.arg.A_Const&&a.arg.A_Const.sval)return `ISOLATION LEVEL ${a.arg.A_Const.sval.sval.toUpperCase()}`}else if(a.defname==="transaction_deferrable"){let o=false;if(a.arg){let l=this.getNodeData(a.arg);if(l.ival!==void 0)o=(typeof l.ival=="object"?l.ival.ival:l.ival)===1;else if(l.sval!==void 0){let p=(typeof l.sval=="object"?l.sval.sval:l.sval).replace(/'/g,"");o=p.toLowerCase()==="on"||p.toLowerCase()==="true";}}return o?"DEFERRABLE":"NOT DEFERRABLE"}}return this.visit(i,r)}).filter(Boolean);n.length>0&&t.push(n.join(", "));}return t.join(" ")}VariableSetStmt(e,r){switch(e.kind){case "VAR_SET_VALUE":let t=e.is_local?"LOCAL ":"",n=e.args?h.unwrapList(e.args).map(u=>{let p=this.getNodeData(u);if(p.sval!==void 0){let c=typeof p.sval=="object"?p.sval.sval:p.sval;return c===""||c.includes(" ")||c.includes("-")||/[A-Z]/.test(c)||/^\d/.test(c)||c.includes(".")||c.includes("$")||c.toLowerCase()==="all"||/^[+-]\d/.test(c)?`'${c}'`:c}return this.visit(u,r)}).join(", "):"",i=S.quoteIdentifier(e.name);return !e.args||e.args.length===0?`SET ${t}${i}`:`SET ${t}${i} TO ${n}`;case "VAR_SET_DEFAULT":return `SET ${S.quoteIdentifier(e.name)} TO DEFAULT`;case "VAR_SET_CURRENT":return `SET ${S.quoteIdentifier(e.name)} FROM CURRENT`;case "VAR_SET_MULTI":if(e.name==="TRANSACTION"||e.name==="SESSION CHARACTERISTICS"){let u=[];if(e.args){let p=h.unwrapList(e.args);for(let c of p)if(c.DefElem){let f=c.DefElem;if(f.defname==="transaction_isolation"){let m=f.arg?this.visit(f.arg,r):"";u.push(`ISOLATION LEVEL ${m.replace(/'/g,"").toUpperCase()}`);}else if(f.defname==="transaction_read_only"){let m=false;if(f.arg){let d=this.getNodeData(f.arg);if(d.ival!==void 0)m=(typeof d.ival=="object"?d.ival.ival:d.ival)===1;else if(d.sval!==void 0){let b=(typeof d.sval=="object"?d.sval.sval:d.sval).replace(/'/g,"");m=b.toLowerCase()==="on"||b.toLowerCase()==="true";}}u.push(m?"READ ONLY":"READ WRITE");}else if(f.defname==="transaction_deferrable"){let m=false;if(f.arg){let d=this.getNodeData(f.arg);if(d.ival!==void 0)m=(typeof d.ival=="object"?d.ival.ival:d.ival)===1;else if(d.sval!==void 0){let b=(typeof d.sval=="object"?d.sval.sval:d.sval).replace(/'/g,"");m=b.toLowerCase()==="on"||b.toLowerCase()==="true";}}u.push(m?"DEFERRABLE":"NOT DEFERRABLE");}}}return e.name==="SESSION CHARACTERISTICS"?`SET SESSION CHARACTERISTICS AS TRANSACTION ${u.join(", ")}`:`SET TRANSACTION ${u.join(", ")}`}else return `SET ${e.args?h.unwrapList(e.args).map(p=>p.VariableSetStmt?this.VariableSetStmt(p.VariableSetStmt,r):this.visit(p,r)).join(", "):""}`;case "VAR_RESET":return `RESET ${S.quoteIdentifier(e.name)}`;case "VAR_RESET_ALL":return "RESET ALL";default:throw new Error(`Unsupported VariableSetStmt kind: ${e.kind}`)}}VariableShowStmt(e,r){return e.name==="ALL"?"SHOW ALL":`SHOW ${e.name}`}CreateSchemaStmt(e,r){let t=["CREATE SCHEMA"];if(e.if_not_exists&&t.push("IF NOT EXISTS"),e.schemaname&&t.push(S.quoteIdentifier(e.schemaname)),e.authrole&&(t.push("AUTHORIZATION"),t.push(this.RoleSpec(e.authrole,r))),e.schemaElts&&e.schemaElts.length>0){let n=h.unwrapList(e.schemaElts).map(i=>this.visit(i,r)).join(" ");t.push(n);}return t.join(" ")}RoleSpec(e,r){if(e.rolename)return this.quoteIfNeeded(e.rolename);switch(e.roletype){case "ROLESPEC_PUBLIC":return "PUBLIC";case "ROLESPEC_CURRENT_USER":return "CURRENT_USER";case "ROLESPEC_SESSION_USER":return "SESSION_USER";case "ROLESPEC_CURRENT_ROLE":return "CURRENT_ROLE";default:return "PUBLIC"}}roletype(e,r){return e.rolename?e.rolename:""}DropStmt(e,r){let t=["DROP"];if(e.removeType)switch(e.removeType){case "OBJECT_TABLE":t.push("TABLE");break;case "OBJECT_VIEW":t.push("VIEW");break;case "OBJECT_INDEX":t.push("INDEX");break;case "OBJECT_SEQUENCE":t.push("SEQUENCE");break;case "OBJECT_SCHEMA":t.push("SCHEMA");break;case "OBJECT_FUNCTION":t.push("FUNCTION");break;case "OBJECT_PROCEDURE":t.push("PROCEDURE");break;case "OBJECT_DATABASE":t.push("DATABASE");break;case "OBJECT_EXTENSION":t.push("EXTENSION");break;case "OBJECT_TYPE":t.push("TYPE");break;case "OBJECT_DOMAIN":t.push("DOMAIN");break;case "OBJECT_TRIGGER":t.push("TRIGGER");break;case "OBJECT_RULE":t.push("RULE");break;case "OBJECT_POLICY":t.push("POLICY");break;case "OBJECT_ROLE":t.push("ROLE");break;case "OBJECT_TABLESPACE":t.push("TABLESPACE");break;case "OBJECT_FOREIGN_SERVER":t.push("SERVER");break;case "OBJECT_FDW":t.push("FOREIGN DATA WRAPPER");break;case "OBJECT_PUBLICATION":t.push("PUBLICATION");break;case "OBJECT_SUBSCRIPTION":t.push("SUBSCRIPTION");break;case "OBJECT_CAST":t.push("CAST");break;case "OBJECT_TRANSFORM":t.push("TRANSFORM");break;case "OBJECT_ACCESS_METHOD":t.push("ACCESS METHOD");break;case "OBJECT_OPERATOR":t.push("OPERATOR");break;case "OBJECT_FOREIGN_TABLE":t.push("FOREIGN TABLE");break;case "OBJECT_MATVIEW":t.push("MATERIALIZED VIEW");break;case "OBJECT_OPCLASS":t.push("OPERATOR CLASS");break;case "OBJECT_OPFAMILY":t.push("OPERATOR FAMILY");break;case "OBJECT_COLLATION":t.push("COLLATION");break;case "OBJECT_CONVERSION":t.push("CONVERSION");break;case "OBJECT_LANGUAGE":t.push("LANGUAGE");break;case "OBJECT_LARGEOBJECT":t.push("LARGE OBJECT");break;case "OBJECT_AGGREGATE":t.push("AGGREGATE");break;case "OBJECT_STATISTIC_EXT":t.push("STATISTICS");break;case "OBJECT_EVENT_TRIGGER":t.push("EVENT TRIGGER");break;case "OBJECT_AMOP":t.push("OPERATOR CLASS");break;case "OBJECT_AMPROC":t.push("OPERATOR CLASS");break;case "OBJECT_ATTRIBUTE":t.push("ATTRIBUTE");break;case "OBJECT_DEFAULT":t.push("DEFAULT");break;case "OBJECT_DEFACL":t.push("DEFAULT PRIVILEGES");break;case "OBJECT_PARAMETER_ACL":t.push("PARAMETER");break;case "OBJECT_PUBLICATION_NAMESPACE":t.push("PUBLICATION");break;case "OBJECT_PUBLICATION_REL":t.push("PUBLICATION");break;case "OBJECT_ROUTINE":t.push("ROUTINE");break;case "OBJECT_TABCONSTRAINT":t.push("CONSTRAINT");break;case "OBJECT_TSCONFIGURATION":t.push("TEXT SEARCH CONFIGURATION");break;case "OBJECT_TSDICTIONARY":t.push("TEXT SEARCH DICTIONARY");break;case "OBJECT_TSPARSER":t.push("TEXT SEARCH PARSER");break;case "OBJECT_TSTEMPLATE":t.push("TEXT SEARCH TEMPLATE");break;case "OBJECT_USER_MAPPING":t.push("USER MAPPING");break;default:throw new Error(`Unsupported DROP object type: ${e.removeType}`)}if(e.concurrent&&t.push("CONCURRENTLY"),e.missing_ok&&t.push("IF EXISTS"),e.objects&&e.objects.length>0)if(e.removeType==="OBJECT_POLICY"){let n=e.objects[0];if(n&&n.List&&n.List.items){let i=n.List.items.map(a=>a.String&&a.String.sval?a.String.sval:this.visit(a,r));if(i.length===3){let[a,o,l]=i;t.push(`${l} ON ${a}.${o}`);}else if(i.length===2){let[a,o]=i;t.push(`${o} ON ${a}`);}else t.push(i.join(", "));}}else if(e.removeType==="OBJECT_CAST"){let n=e.objects.map(i=>{if(i&&i.List&&i.List.items){let o=i.List.items.map(l=>this.visit(l,r)).filter(l=>l&&l.trim());if(o.length===2){let[l,u]=o;return `(${l} AS ${u})`}return o.join(".")}return this.visit(i,r)}).filter(i=>i&&i.trim()).join(", ");n&&t.push(n);}else if(e.removeType==="OBJECT_TRIGGER"||e.removeType==="OBJECT_RULE"){let n=e.objects.map(i=>{if(i&&i.List&&i.List.items){let o=i.List.items.map(l=>l.String&&l.String.sval?S.quoteIdentifier(l.String.sval):this.visit(l,r)).filter(l=>l&&l.trim());if(o.length===2){let[l,u]=o;return `${u} ON ${l}`}else if(o.length===3){let[l,u,p]=o;return `${p} ON ${l}.${u}`}return o.join(".")}return this.visit(i,r)}).filter(i=>i&&i.trim()).join(", ");n&&t.push(n);}else if(e.removeType==="OBJECT_OPFAMILY"||e.removeType==="OBJECT_OPCLASS"){let n=e.objects.map(i=>{if(i&&i.List&&i.List.items){let o=i.List.items.map(l=>l.String&&l.String.sval?l.String.sval:this.visit(l,r)).filter(l=>l&&l.trim());if(o.length===2){let l=o[0],u=o[1];return `${S.quoteIdentifier(u)} USING ${l}`}else if(o.length===3){let l=o[0],u=o[1],p=o[2];return `${S.quoteQualifiedIdentifier(u,p)} USING ${l}`}return o.join(".")}return this.visit(i,r)}).filter(i=>i&&i.trim()).join(", ");n&&t.push(n);}else if(e.removeType==="OBJECT_TRANSFORM"){let n=e.objects.map(i=>{if(i&&i.List&&i.List.items){let o=i.List.items.map(l=>l.String&&l.String.sval?l.String.sval:this.visit(l,r)).filter(l=>l&&l.trim());if(o.length===2){let[l,u]=o;return `FOR ${l} LANGUAGE ${u}`}return o.join(".")}return this.visit(i,r)}).filter(i=>i&&i.trim()).join(", ");n&&t.push(n);}else {let n=e.objects.map(i=>{if(Array.isArray(i))return i.map(u=>this.visit(u,r)).filter(u=>u&&u.trim()).join(".");if(i&&i.List&&i.List.items)return i.List.items.map(u=>u.String&&u.String.sval?S.quoteIdentifier(u.String.sval):this.visit(u,r)).filter(u=>u&&u.trim()).join(".");let a=r.spawn("DropStmt",{objtype:e.removeType});return this.visit(i,a)}).filter(i=>i&&i.trim()).join(", ");n&&t.push(n);}return e.behavior==="DROP_CASCADE"&&t.push("CASCADE"),t.join(" ")}TruncateStmt(e,r){let t=["TRUNCATE"];if(e.relations&&e.relations.length>0){let n=e.relations.map(i=>this.visit(i,r)).join(", ");t.push(n);}return e.restart_seqs&&t.push("RESTART IDENTITY"),e.behavior==="DROP_CASCADE"&&t.push("CASCADE"),t.join(" ")}ReturnStmt(e,r){let t=["RETURN"];if(e.returnval){let n=this.visit(e.returnval,r);t.push(n);}return t.join(" ")}PLAssignStmt(e,r){let t=[];if(e.name){let n=S.quoteIdentifier(e.name);if(e.indirection&&e.indirection.length>0){let i=e.indirection.map(a=>this.visit(a,r)).join("");n+=i;}t.push(n);}if(t.push(":="),e.val){let n=e.val;if(n.targetList){t.push("SELECT");let i=this.targetList(n.targetList,r);t.push(i);}else {let i=this.visit(e.val,r);t.push(i);}}return t.join(" ")}CopyStmt(e,r){let t=["COPY"];if(e.relation){let n=this.RangeVar(e.relation,r);t.push(n);}else if(e.query){let n=this.visit(e.query,r);t.push(`(${n})`);}if(e.attlist&&e.attlist.length>0){let n=h.unwrapList(e.attlist).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}if(e.is_from?t.push("FROM"):t.push("TO"),e.is_program&&t.push("PROGRAM"),e.filename?t.push(`'${e.filename}'`):t.push("STDIN"),e.options&&e.options.length>0){t.push("WITH");let n=h.unwrapList(e.options).map(i=>this.visit(i,r.spawn("CopyStmt"))).join(", ");t.push(`(${n})`);}if(e.whereClause){t.push("WHERE");let n=this.visit(e.whereClause,r);t.push(n);}return t.join(" ")}AlterTableStmt(e,r){let t=["ALTER"];if(e.objtype)switch(e.objtype){case "OBJECT_TABLE":t.push("TABLE");break;case "OBJECT_INDEX":t.push("INDEX");break;case "OBJECT_SEQUENCE":t.push("SEQUENCE");break;case "OBJECT_VIEW":t.push("VIEW");break;case "OBJECT_MATVIEW":t.push("MATERIALIZED VIEW");break;case "OBJECT_FOREIGN_TABLE":t.push("FOREIGN TABLE");break;case "OBJECT_TYPE":t.push("TYPE");break;default:t.push("TABLE");}else t.push("TABLE");e.missing_ok&&t.push("IF EXISTS");let n=r.spawn("AlterTableStmt",{objtype:e.objtype});if(e.relation){let i=this.RangeVar(e.relation,n);t.push(i);}if(e.cmds&&e.cmds.length>0){let i=h.unwrapList(e.cmds);if(r.isPretty()){let a=i.map(o=>{let l=this.visit(o,n);return r.newline()+r.indent(l)}).join(",");t.push(a);}else {let a=i.map(o=>this.visit(o,n)).join(", ");t.push(a);}}return t.join(" ")}AlterTableCmd(e,r){let t=[];if(e.subtype)switch(e.subtype){case "AT_AddColumn":if(r.objtype==="OBJECT_TYPE"?t.push("ADD ATTRIBUTE"):t.push("ADD COLUMN"),e.missing_ok&&t.push("IF NOT EXISTS"),e.def){let n=this.getNodeData(e.def);if(r.isPretty()){let i=[],a=[];if(n.colname&&i.push(S.quoteIdentifier(n.colname)),n.typeName&&i.push(this.TypeName(n.typeName,r)),n.is_not_null&&a.push("NOT NULL"),n.collClause&&a.push(this.CollateClause(n.collClause,r)),n.constraints&&h.unwrapList(n.constraints).forEach(u=>{let p=r.spawn("ColumnDef",{isColumnConstraint:true}),c=this.visit(u,p);if(c.includes("REFERENCES")&&c.includes("ON DELETE")){let f=c.match(/^(.*REFERENCES[^)]*\([^)]*\))\s*(ON\s+DELETE\s+CASCADE.*)$/);f?(a.push(f[1]),a.push(f[2])):a.push(c);}else if(c==="UNIQUE"&&n.raw_default){let f="DEFAULT "+this.visit(n.raw_default,r);a.push("UNIQUE "+f);}else a.push(c);}),n.raw_default&&!n.constraints?.some(l=>this.visit(l,r.spawn("ColumnDef",{isColumnConstraint:true}))==="UNIQUE")){let l="DEFAULT "+this.visit(n.raw_default,r);a.push(l);}if(n.fdwoptions&&n.fdwoptions.length>0){a.push("OPTIONS");let l=r.spawn("ColumnDef"),u=h.unwrapList(n.fdwoptions).map(p=>this.visit(p,l));a.push(`(${u.join(", ")})`);}let o=i.join(" ");if(a.length>0){let l=a.map(u=>r.indent(u)).join(r.newline());o+=r.newline()+l;}t.push(o);}else {let i=[];if(n.colname&&i.push(S.quoteIdentifier(n.colname)),n.typeName&&i.push(this.TypeName(n.typeName,r)),n.collClause&&i.push(this.CollateClause(n.collClause,r)),n.fdwoptions&&n.fdwoptions.length>0){i.push("OPTIONS");let a=r.spawn("ColumnDef"),o=h.unwrapList(n.fdwoptions).map(l=>this.visit(l,a));i.push(`(${o.join(", ")})`);}if(n.constraints){let o=h.unwrapList(n.constraints).map(l=>{let u=r.spawn("ColumnDef",{isColumnConstraint:true});return this.visit(l,u)});i.push(...o);}n.raw_default&&(i.push("DEFAULT"),i.push(this.visit(n.raw_default,r))),n.is_not_null&&i.push("NOT NULL"),t.push(i.join(" "));}}e.behavior==="DROP_CASCADE"&&t.push("CASCADE");break;case "AT_DropColumn":e.missing_ok?r.objtype==="OBJECT_TYPE"?t.push("DROP ATTRIBUTE IF EXISTS"):t.push("DROP COLUMN IF EXISTS"):r.objtype==="OBJECT_TYPE"?t.push("DROP ATTRIBUTE"):t.push("DROP COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),e.behavior==="DROP_CASCADE"?t.push("CASCADE"):e.behavior==="DROP_RESTRICT"&&t.push("RESTRICT");break;case "AT_AlterColumnType":if(r.objtype==="OBJECT_TYPE"?t.push("ALTER ATTRIBUTE"):t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("TYPE"),e.def){let n=this.getNodeData(e.def);if(n&&n.typeName)t.push(this.TypeName(n.typeName,r)),n.raw_default&&(t.push("USING"),t.push(this.visit(n.raw_default,r)));else {let i=this.visit(e.def,r);t.push(i);}}e.behavior==="DROP_CASCADE"&&t.push("CASCADE");break;case "AT_SetTableSpace":t.push("SET TABLESPACE"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_AddConstraint":if(t.push("ADD"),e.def){let n=this.visit(e.def,r);t.push(n);}break;case "AT_DropConstraint":e.missing_ok?t.push("DROP CONSTRAINT IF EXISTS"):t.push("DROP CONSTRAINT"),e.name&&t.push(S.quoteIdentifier(e.name)),e.behavior==="DROP_CASCADE"?t.push("CASCADE"):e.behavior==="DROP_RESTRICT"&&t.push("RESTRICT");break;case "AT_SetRelOptions":if(t.push("SET"),e.def){let n=r.spawn("AlterTableCmd",{subtype:"AT_SetRelOptions"}),i=h.unwrapList(e.def).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}else t.push("()");break;case "AT_ResetRelOptions":if(t.push("RESET"),e.def){let n=r.spawn("AlterTableCmd",{subtype:"AT_ResetRelOptions"}),i=h.unwrapList(e.def).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}else t.push("()");break;case "AT_ColumnDefault":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),e.def?(t.push("SET DEFAULT"),t.push(this.visit(e.def,r))):t.push("DROP DEFAULT");break;case "AT_SetStorage":if(t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("SET STORAGE"),e.def){let n=this.visit(e.def,r);t.push(n);}break;case "AT_ClusterOn":t.push("CLUSTER ON"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_DropCluster":t.push("SET WITHOUT CLUSTER");break;case "AT_ChangeOwner":t.push("OWNER TO"),e.newowner&&t.push(this.RoleSpec(e.newowner,r));break;case "AT_AddInherit":t.push("INHERIT"),e.def&&t.push(this.visit(e.def,r));break;case "AT_DropInherit":t.push("NO INHERIT"),e.def&&t.push(this.visit(e.def,r));break;case "AT_SetNotNull":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("SET NOT NULL");break;case "AT_DropNotNull":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("DROP NOT NULL");break;case "AT_SetStatistics":t.push("ALTER COLUMN"),e.name?t.push(S.quoteIdentifier(e.name)):e.num!==void 0&&e.num!==null&&t.push(e.num.toString()),t.push("SET STATISTICS"),e.def&&t.push(this.visit(e.def,r));break;case "AT_SetOptions":if(t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("SET"),e.def){let n=r.spawn("AlterTableCmd",{subtype:"AT_SetOptions"}),i=h.unwrapList(e.def).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}else t.push("()");break;case "AT_ResetOptions":if(t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("RESET"),e.def){let n=r.spawn("AlterTableCmd",{subtype:"AT_ResetOptions"}),i=h.unwrapList(e.def).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}else t.push("()");break;case "AT_SetCompression":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("SET COMPRESSION"),e.def&&t.push(this.visit(e.def,r));break;case "AT_ValidateConstraint":t.push("VALIDATE CONSTRAINT"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_EnableTrig":t.push("ENABLE TRIGGER"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_EnableAlwaysTrig":t.push("ENABLE ALWAYS TRIGGER"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_EnableReplicaTrig":t.push("ENABLE REPLICA TRIGGER"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_DisableTrig":t.push("DISABLE TRIGGER"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_EnableTrigAll":t.push("ENABLE TRIGGER ALL");break;case "AT_DisableTrigAll":t.push("DISABLE TRIGGER ALL");break;case "AT_EnableTrigUser":t.push("ENABLE TRIGGER USER");break;case "AT_DisableTrigUser":t.push("DISABLE TRIGGER USER");break;case "AT_EnableRule":t.push("ENABLE RULE"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_EnableAlwaysRule":t.push("ENABLE ALWAYS RULE"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_EnableReplicaRule":t.push("ENABLE REPLICA RULE"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_DisableRule":t.push("DISABLE RULE"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "AT_SetAccessMethod":t.push("SET ACCESS METHOD"),e.name?t.push(S.quoteIdentifier(e.name)):t.push("DEFAULT");break;case "AT_EnableRowSecurity":t.push("ENABLE ROW LEVEL SECURITY");break;case "AT_DisableRowSecurity":t.push("DISABLE ROW LEVEL SECURITY");break;case "AT_ForceRowSecurity":t.push("FORCE ROW LEVEL SECURITY");break;case "AT_NoForceRowSecurity":t.push("NO FORCE ROW LEVEL SECURITY");break;case "AT_AttachPartition":t.push("ATTACH PARTITION"),e.def&&t.push(this.visit(e.def,r));break;case "AT_DetachPartition":t.push("DETACH PARTITION"),e.def&&t.push(this.visit(e.def,r));break;case "AT_DetachPartitionFinalize":t.push("DETACH PARTITION"),e.def&&t.push(this.visit(e.def,r)),t.push("FINALIZE");break;case "AT_SetLogged":t.push("SET LOGGED");break;case "AT_SetUnLogged":t.push("SET UNLOGGED");break;case "AT_AddColumnToView":if(t.push("ADD COLUMN"),e.def){let n=this.visit(e.def,r);t.push(n);}break;case "AT_CookedColumnDefault":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),e.def?(t.push("SET DEFAULT"),t.push(this.visit(e.def,r))):t.push("DROP DEFAULT");break;case "AT_SetExpression":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("SET EXPRESSION"),e.def&&t.push(this.visit(e.def,r));break;case "AT_DropExpression":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("DROP EXPRESSION");break;case "AT_CheckNotNull":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("SET NOT NULL");break;case "AT_AddIndex":t.push("ADD"),e.def&&t.push(this.visit(e.def,r));break;case "AT_ReAddIndex":t.push("ADD"),e.def&&t.push(this.visit(e.def,r));break;case "AT_ReAddConstraint":t.push("ADD"),e.def&&t.push(this.visit(e.def,r));break;case "AT_ReAddDomainConstraint":t.push("ADD"),e.def&&t.push(this.visit(e.def,r));break;case "AT_AlterConstraint":if(t.push("ALTER CONSTRAINT"),e.def&&this.getNodeType(e.def)==="Constraint"){let n=this.getNodeData(e.def);n.conname&&(t.push(S.quoteIdentifier(n.conname)),n.deferrable!==void 0&&t.push(n.deferrable?"DEFERRABLE":"NOT DEFERRABLE"),n.initdeferred!==void 0&&t.push(n.initdeferred?"INITIALLY DEFERRED":"INITIALLY IMMEDIATE"));}else e.name&&(t.push(S.quoteIdentifier(e.name)),e.def&&t.push(this.visit(e.def,r)));break;case "AT_AddIndexConstraint":t.push("ADD"),e.def&&t.push(this.visit(e.def,r));break;case "AT_ReAddComment":t.push("COMMENT"),e.def&&t.push(this.visit(e.def,r));break;case "AT_AlterColumnGenericOptions":if(t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("OPTIONS"),e.def){let n=r.spawn("AlterTableCmd",{alterColumnOptions:true}),i=h.unwrapList(e.def).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}break;case "AT_DropOids":t.push("SET WITHOUT OIDS");break;case "AT_ReplaceRelOptions":if(t.push("REPLACE"),e.def&&Array.isArray(e.def)){let n=h.unwrapList(e.def).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}else t.push("()");break;case "AT_AddOf":t.push("OF"),e.def&&t.push(this.visit(e.def,r));break;case "AT_DropOf":t.push("NOT OF");break;case "AT_ReplicaIdentity":t.push("REPLICA IDENTITY"),e.def&&t.push(this.visit(e.def,r));break;case "AT_GenericOptions":if(t.push("OPTIONS"),e.def){let n=r.spawn("AlterTableCmd",{alterTableOptions:true}),i=h.unwrapList(e.def).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}break;case "AT_AddIdentity":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("ADD"),e.def&&t.push(this.visit(e.def,r));break;case "AT_SetIdentity":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("SET"),e.def&&t.push(this.visit(e.def,r));break;case "AT_DropIdentity":t.push("ALTER COLUMN"),e.name&&t.push(S.quoteIdentifier(e.name)),t.push("DROP IDENTITY"),e.behavior==="DROP_CASCADE"?t.push("CASCADE"):e.behavior==="DROP_RESTRICT"&&t.push("RESTRICT");break;case "AT_ReAddStatistics":t.push("ADD"),e.def&&t.push(this.visit(e.def,r));break;default:throw new Error(`Unsupported AlterTableCmd subtype: ${e.subtype}`)}return t.join(" ")}CreateFunctionStmt(e,r){let t=["CREATE"];if(e.replace&&t.push("OR REPLACE"),e.is_procedure?t.push("PROCEDURE"):t.push("FUNCTION"),e.funcname&&e.funcname.length>0){let i=e.funcname.map(o=>o.String?.sval||o.String?.str||"").filter(o=>o),a=S.quoteDottedName(i);if(e.parameters&&e.parameters.length>0){let o=e.parameters.filter(l=>this.getNodeData(l).mode!=="FUNC_PARAM_TABLE").map(l=>this.visit(l,r));if(o.length>0)if(r.isPretty()){let l=o.map(u=>r.indent(u)).join(","+r.newline());t.push(a+"("+r.newline()+l+r.newline()+")");}else t.push(a+"("+o.join(", ")+")");else t.push(a+"()");}else t.push(a+"()");}if(e.parameters&&e.parameters.some(i=>this.getNodeData(i).mode==="FUNC_PARAM_TABLE")){let i=e.parameters.filter(a=>this.getNodeData(a).mode==="FUNC_PARAM_TABLE").map(a=>this.visit(a,r));if(r.isPretty()){let a=i.map(o=>r.indent(o)).join(","+r.newline());t.push("RETURNS TABLE ("+r.newline()+a+r.newline()+")");}else t.push("RETURNS TABLE ("),t.push(i.join(", ")),t.push(")");}else e.returnType&&(t.push("RETURNS"),t.push(this.TypeName(e.returnType,r)));if(e.options&&e.options.length>0){let i=r.spawn("CreateFunctionStmt"),a=e.options.map(o=>this.visit(o,i));t.push(...a);}if(e.sql_body){let i=this.getNodeType(e.sql_body);if(i==="ReturnStmt")t.push(this.visit(e.sql_body,r));else {if(t.push("BEGIN ATOMIC"),i==="List"){let a=h.unwrapList(e.sql_body);if(!(a.length===0||a.length===1&&Object.keys(a[0]).length===0)){let o=a;a.length===1&&a[0].List&&(o=h.unwrapList(a[0]));let l=o.filter(u=>u&&Object.keys(u).length>0).map(u=>{let p=this.visit(u,r);return p.endsWith(";")?p:p+";"});l.length>0&&t.push(l.join(" "));}}else {let a=this.visit(e.sql_body,r);a&&!a.endsWith(";")?t.push(a+";"):t.push(a);}t.push("END");}}return t.join(" ")}FunctionParameter(e,r){let t=[];if(e.mode)switch(e.mode){case "FUNC_PARAM_IN":t.push("IN");break;case "FUNC_PARAM_OUT":t.push("OUT");break;case "FUNC_PARAM_INOUT":t.push("INOUT");break;case "FUNC_PARAM_VARIADIC":t.push("VARIADIC");break}return e.name&&t.push(S.quoteIdentifier(e.name)),e.argType&&t.push(this.TypeName(e.argType,r)),e.defexpr&&(t.push("DEFAULT"),t.push(this.visit(e.defexpr,r))),t.join(" ")}CreateEnumStmt(e,r){let t=["CREATE","TYPE"];if(e.typeName){let n=h.unwrapList(e.typeName).map(i=>this.visit(i,r)).join(".");t.push(n);}if(t.push("AS","ENUM"),e.vals&&e.vals.length>0){let n=r.spawn("CreateEnumStmt",{isEnumValue:true}),i=h.unwrapList(e.vals).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}else t.push("()");return t.join(" ")}CreateDomainStmt(e,r){let t=["CREATE","DOMAIN"];if(e.domainname){let n=h.unwrapList(e.domainname).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.typeName&&(t.push("AS"),t.push(this.TypeName(e.typeName,r))),e.collClause&&t.push(this.CollateClause(e.collClause,r)),e.constraints){let n=h.unwrapList(e.constraints).map(i=>this.visit(i,r)).join(" ");n&&t.push(n);}return t.join(" ")}CreateRoleStmt(e,r){let t=["CREATE"];if(e.stmt_type==="ROLESTMT_ROLE"?t.push("ROLE"):e.stmt_type==="ROLESTMT_USER"?t.push("USER"):e.stmt_type==="ROLESTMT_GROUP"?t.push("GROUP"):t.push("ROLE"),e.role){let n=S.quoteIdentifier(e.role);t.push(n);}if(e.options){let n=h.unwrapList(e.options).map(i=>this.visit(i,r.spawn("CreateRoleStmt"))).join(" ");n&&(t.push("WITH"),t.push(n));}return t.join(" ")}DefElem(e,r){if(!e.defname)return "";if(r.parentNodeTypes.includes("DefineStmt")&&["commutator","negator"].includes(e.defname.toLowerCase())&&e.arg&&this.getNodeType(e.arg)==="List"){let t=this.getNodeData(e.arg),n=h.unwrapList(t.items);if(n.length===1&&n[0].String)return `${this.preserveOperatorDefElemCase(e.defname)} = ${n[0].String.sval}`}if(r.parentNodeTypes.includes("IndexElem")){if(e.arg&&this.getNodeType(e.arg)==="String"){let t=this.getNodeData(e.arg);return `${e.defname}='${t.sval}'`}return `${e.defname}=${this.visit(e.arg,r.spawn("DefElem"))}`}if(r.parentNodeTypes.includes("DefineStmt")&&["hashes","merges"].includes(e.defname.toLowerCase())&&!e.arg)return e.defname!==e.defname.toLowerCase()&&e.defname!==e.defname.toUpperCase()?S.quoteIdentifier(e.defname):e.defname.charAt(0).toUpperCase()+e.defname.slice(1).toLowerCase();if(r.parentNodeTypes.includes("AlterFdwStmt")||r.parentNodeTypes.includes("CreateFdwStmt")||r.parentNodeTypes.includes("CreateForeignServerStmt")||r.parentNodeTypes.includes("AlterForeignServerStmt")||r.parentNodeTypes.includes("CreateUserMappingStmt")||r.parentNodeTypes.includes("AlterUserMappingStmt")||r.parentNodeTypes.includes("ColumnDef")||r.parentNodeTypes.includes("CreateForeignTableStmt")||r.parentNodeTypes.includes("ImportForeignSchemaStmt")||r.alterColumnOptions||r.alterTableOptions){if(["handler","validator"].includes(e.defname)){if(!e.arg)return `NO ${e.defname.toUpperCase()}`;let t=r.spawn("DefElem"),n=this.visit(e.arg,t);return `${e.defname.toUpperCase()} ${n}`}if(e.arg){let t=r.spawn("DefElem"),n=this.visit(e.arg,t);if(r.parentNodeTypes.includes("CreateFdwStmt")||r.parentNodeTypes.includes("AlterFdwStmt")){let o=typeof n=="string"&&!n.startsWith("'")?`'${n}'`:n,l=S.quoteIdentifier(e.defname);return e.defaction==="DEFELEM_ADD"?`ADD ${l} ${o}`:e.defaction==="DEFELEM_DROP"?`DROP ${l}`:e.defaction==="DEFELEM_SET"?`SET ${l} ${o}`:`${l} ${o}`}let i=typeof n=="string"&&!n.startsWith("'")?`'${n}'`:n;return e.defaction==="DEFELEM_ADD"?`ADD ${e.defname} ${i}`:e.defaction==="DEFELEM_DROP"?`DROP ${e.defname}`:e.defaction==="DEFELEM_SET"?`SET ${e.defname} ${i}`:`${S.quoteIdentifier(e.defname)} ${i}`}else if(e.defaction==="DEFELEM_DROP")return `DROP ${e.defname}`}if((r.parentNodeTypes.includes("CreateSeqStmt")||r.parentNodeTypes.includes("AlterSeqStmt"))&&(e.defname==="minvalue"||e.defname==="maxvalue")&&!e.arg)return `NO ${e.defname.toUpperCase()}`;if((r.parentNodeTypes.includes("CreateRoleStmt")||r.parentNodeTypes.includes("AlterRoleStmt"))&&e.defname==="password"){if(!e.arg)return "PASSWORD NULL";let t=r.spawn("DefElem"),n=this.visit(e.arg,t);return `PASSWORD ${typeof n=="string"&&!n.startsWith("'")?`'${n}'`:n}`}if(e.arg){let t=r.spawn("DefElem"),n=this.visit(e.arg,t);if(r.parentNodeTypes.includes("AlterOperatorStmt")){if(e.arg&&this.getNodeType(e.arg)==="TypeName"){let a=this.getNodeData(e.arg);if(a.names){let o=h.unwrapList(a.names);if(o.length===1&&o[0].String)return `${e.defname} = ${o[0].String.sval}`}}if(e.arg&&this.getNodeType(e.arg)==="List"){let a=this.getNodeData(e.arg),o=h.unwrapList(a.items);if(o.length===1&&o[0].String)return `${e.defname} = ${o[0].String.sval}`}}if(r.parentNodeTypes.includes("CreatedbStmt")||r.parentNodeTypes.includes("DropdbStmt")){let a=typeof n=="string"?S.escape(n):n;return `${e.defname} = ${a}`}if(r.parentNodeTypes.includes("CreateForeignServerStmt")||r.parentNodeTypes.includes("AlterForeignServerStmt")){let a=typeof n=="string"?S.escape(n):n;return `${S.quoteIdentifier(e.defname)} ${a}`}if(r.parentNodeTypes.includes("CreateRoleStmt")||r.parentNodeTypes.includes("AlterRoleStmt")){if(e.defname==="rolemembers"&&e.arg&&this.getNodeType(e.arg)==="List"){let a=this.getNodeData(e.arg),l=h.unwrapList(a.items).map(u=>this.visit(u,r));return r.parentNodeTypes.includes("CreateRoleStmt")?`ROLE ${l.join(", ")}`:`ADD USER ${l.join(", ")}`}if(e.defname==="addroleto"&&e.arg&&this.getNodeType(e.arg)==="List"){let a=this.getNodeData(e.arg);return `IN ROLE ${h.unwrapList(a.items).map(u=>this.visit(u,r)).join(", ")}`}if(e.defname==="validUntil")return `VALID UNTIL ${typeof n=="string"&&!n.startsWith("'")?`'${n}'`:n}`;if(e.defname==="adminmembers")return `ADMIN ${n}`;if(e.defname==="connectionlimit")return `CONNECTION LIMIT ${n}`;if(e.defname==="sysid")return `SYSID ${n}`;if(String(n)==="true")return e.defname==="isreplication"?"REPLICATION":e.defname==="canlogin"?"LOGIN":e.defname.toUpperCase();if(String(n)==="false")return e.defname==="canlogin"?"NOLOGIN":e.defname==="isreplication"?"NOREPLICATION":`NO${e.defname.toUpperCase()}`}if(r.parentNodeTypes.includes("CreateSeqStmt")||r.parentNodeTypes.includes("AlterSeqStmt")){if(e.defname==="owned_by")if(e.arg&&this.getNodeType(e.arg)==="List"){let a=this.getNodeData(e.arg);return `OWNED BY ${h.unwrapList(a.items).map(u=>{let p=this.getNodeData(u);if(this.getNodeType(u)==="String"){let c=p.sval;return S.quoteIdentifier(c)}return this.visit(u,r)}).join(".")}`}else return `OWNED BY ${n}`;if(e.defname==="cycle"){let a=String(n).toLowerCase();if(a==="true"||a==="1")return "CYCLE";if(a==="false"||a==="0")return "NO CYCLE"}return (e.defname==="minvalue"||e.defname==="maxvalue")&&!e.arg?`NO ${e.defname.toUpperCase()}`:`${e.defname.toUpperCase()} ${n}`}if(r.parentNodeTypes.includes("CreateTableSpaceStmt")||r.parentNodeTypes.includes("AlterTableSpaceOptionsStmt"))return `${e.defname.toUpperCase()} ${n}`;if(r.parentNodeTypes.includes("ExplainStmt"))return n?`${e.defname.toUpperCase()} ${n.toUpperCase()}`:e.defname.toUpperCase();if(r.parentNodeTypes.includes("DoStmt")){if(e.defname==="as"){let a=r.spawn("DefElem"),o=e.arg?this.visit(e.arg,a):"";if(Array.isArray(o)){let u=o.join(""),p=this.getFunctionDelimiter(u);return `${p}${u}${p}`}else {let l=this.getFunctionDelimiter(o);return `${l}${o}${l}`}}return ""}if(r.parentNodeTypes.includes("CreateFunctionStmt")||r.parentNodeTypes.includes("AlterFunctionStmt")){if(e.defname==="as")if(e.arg&&e.arg.List){let l=(e.arg.List.items||[]).map(u=>u.String?u.String.sval:this.visit(u,r));if(l.length===1){let u=l[0],p=this.getFunctionDelimiter(u);return `AS ${p}${u}${p}`}else return `AS ${l.map(u=>{let p=this.getFunctionDelimiter(u);return `${p}${u}${p}`}).join(", ")}`}else if(Array.isArray(n)){let a=n;if(a.length===1){let o=a[0],l=this.getFunctionDelimiter(o);return `AS ${l}${o}${l}`}else return `AS ${a.map(o=>{let l=this.getFunctionDelimiter(o);return `${l}${o}${l}`}).join(", ")}`}else {let a=this.getFunctionDelimiter(n);return `AS ${a}${n}${a}`}return e.defname==="language"?`LANGUAGE ${n}`:e.defname==="volatility"?n.toUpperCase():e.defname==="strict"?n==="true"?"STRICT":"CALLED ON NULL INPUT":e.defname==="security"?n==="true"?"SECURITY DEFINER":"SECURITY INVOKER":e.defname==="leakproof"?n==="true"?"LEAKPROOF":"NOT LEAKPROOF":e.defname==="cost"?`COST ${n}`:e.defname==="rows"?`ROWS ${n}`:e.defname==="window"?n==="true"?"WINDOW":"":e.defname==="set"?this.visit(e.arg,r):`${e.defname.toUpperCase()} ${n}`}if(r.parentNodeTypes.includes("CreateExtensionStmt")||r.parentNodeTypes.includes("AlterExtensionStmt")||r.parentNodeTypes.includes("CreateFdwStmt")||r.parentNodeTypes.includes("AlterFdwStmt")){if(r.parentNodeTypes.includes("AlterExtensionStmt")){if(e.defname==="new_version")return `UPDATE TO ${typeof n=="string"&&!n.startsWith("'")?`'${n}'`:n}`;if(e.defname==="schema")return `SET SCHEMA ${n}`}if(r.parentNodeTypes.includes("CreateFdwStmt")){if(["handler","validator"].includes(e.defname))return `${e.defname.toUpperCase()} ${n}`;let a=typeof n=="string"?S.escape(n):n;return `${e.defname} ${a}`}return e.defname==="cascade"?n==="true"?"CASCADE":"":`${e.defname.toUpperCase()} ${n}`}if(r.parentNodeTypes.includes("IndexStmt"))return `${e.defname}=${n}`;if(r.parentNodeTypes.includes("IndexElem")){if(e.arg&&this.getNodeType(e.arg)==="String"){let a=this.getNodeData(e.arg);return `${e.defname}='${a.sval}'`}return `${e.defname}=${n}`}if(r.parentNodeTypes.includes("CreateStmt")){if(e.arg&&this.getNodeType(e.arg)==="Integer"){let a=this.getNodeData(e.arg);return `${e.defname}=${a.ival}`}return `${e.defname}=${n}`}if(r.parentNodeTypes.includes("CreateEventTrigStmt")){if(e.arg&&this.getNodeType(e.arg)==="List"){let a=this.getNodeData(e.arg),l=h.unwrapList(a.items).map(u=>this.getNodeType(u)==="String"?`'${this.getNodeData(u).sval||""}'`:this.visit(u,r));return `${e.defname} IN (${l.join(", ")})`}return `${e.defname} = ${n}`}if((r.parentNodeTypes.includes("AlterTableCmd")||r.parentNodeTypes.includes("AlterTableStmt"))&&!r.parentNodeTypes.includes("ColumnDef")){let a=e.defnamespace?`${e.defnamespace}.${e.defname}`:e.defname;return e.arg&&this.getNodeType(e.arg)==="TypeName"?`${a} = ${n}`:`${a} = ${n}`}if(r.parentNodeTypes.includes("ViewStmt")){if(typeof n=="string"&&/^\d+$/.test(n))return `${e.defname}=${n}`;let a=typeof n=="string"?S.escape(n):n;return `${e.defname} = ${a}`}if(r.parentNodeTypes.includes("CopyStmt"))return e.defname==="format"&&e.arg&&this.getNodeType(e.arg)==="String"?`FORMAT ${this.getNodeData(e.arg).sval.toUpperCase()}`:e.arg?`${e.defname.toUpperCase()} ${n}`:e.defname.toUpperCase();if(r.parentNodeTypes.includes("DefineStmt")){let a=this.preserveOperatorDefElemCase(e.defname);if(["commutator","negator"].includes(e.defname.toLowerCase())){if(e.arg){if(e.arg&&this.getNodeType(e.arg)==="List"){let u=this.getNodeData(e.arg),p=h.unwrapList(u.items);if(p.length===1&&p[0].String)return `${a} = ${p[0].String.sval}`}let l=n.replace(/^"(.*)"$/,"$1");return `${a} = ${l}`}return a}if(["hashes","merges"].includes(e.defname.toLowerCase()))return e.defname!==e.defname.toLowerCase()&&e.defname!==e.defname.toUpperCase()?S.quoteIdentifier(e.defname):a.toUpperCase();let o=S.quoteIdentifier(e.defname);if(o!==e.defname){if(e.arg){if(this.getNodeType(e.arg)==="String"){let l=this.getNodeData(e.arg);return l.sval==="true"||l.sval==="false"?`${o} = ${l.sval}`:`${o} = '${l.sval}'`}return `${o} = ${n}`}return o}if(a!==e.defname)return e.arg?`${a} = ${n}`:a;if(e.arg&&this.getNodeType(e.arg)==="String"){let l=this.getNodeData(e.arg);return l.sval==="true"||l.sval==="false"?`${e.defname} = ${l.sval}`:`${e.defname} = '${l.sval}'`}if(e.arg&&this.getNodeType(e.arg)==="Boolean"){let l=this.getNodeData(e.arg);return `${e.defname} = ${l.boolval?"true":"false"}`}if(e.arg&&this.getNodeType(e.arg)==="Integer"){let l=this.getNodeData(e.arg);return `${e.defname} = ${l.ival}`}if(e.arg&&this.getNodeType(e.arg)==="TypeName"){let l=this.getNodeData(e.arg);if(l.names){let u=h.unwrapList(l.names);if(u.length===1&&u[0].String)return `${e.defname} = ${u[0].String.sval}`}return `${e.defname} = ${n}`}}let i=typeof n=="string"?S.escape(n):n;return `${e.defname} = ${i}`}return r.parentNodeTypes.includes("DefineStmt")&&!e.arg&&e.defname!==e.defname.toLowerCase()&&e.defname!==e.defname.toUpperCase()?S.quoteIdentifier(e.defname):e.defname.toUpperCase()}CreateTableSpaceStmt(e,r){let t=["CREATE","TABLESPACE"];if(e.tablespacename&&t.push(e.tablespacename),e.owner&&(t.push("OWNER"),t.push(this.RoleSpec(e.owner,r))),e.location&&(t.push("LOCATION"),t.push(`'${e.location}'`)),e.options&&e.options.length>0){t.push("WITH");let n=r.spawn("CreateTableSpaceStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}return t.join(" ")}DropTableSpaceStmt(e,r){let t=["DROP","TABLESPACE"];return e.missing_ok&&t.push("IF","EXISTS"),e.tablespacename&&t.push(e.tablespacename),t.join(" ")}AlterTableSpaceOptionsStmt(e,r){let t=["ALTER","TABLESPACE"];if(e.tablespacename&&t.push(e.tablespacename),e.isReset?t.push("RESET"):t.push("SET"),e.options&&e.options.length>0){let n=r.spawn("AlterTableSpaceOptionsStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}return t.join(" ")}CreateExtensionStmt(e,r){let t=["CREATE","EXTENSION"];if(e.if_not_exists&&t.push("IF","NOT","EXISTS"),e.extname&&t.push(this.quoteIfNeeded(e.extname)),e.options&&e.options.length>0){let n=r.spawn("CreateExtensionStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n)).join(" ");t.push(i);}return t.join(" ")}AlterExtensionStmt(e,r){let t=["ALTER","EXTENSION"];if(e.extname&&t.push(this.quoteIfNeeded(e.extname)),e.options&&e.options.length>0){let n=r.spawn("AlterExtensionStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n)).join(" ");t.push(i);}return t.join(" ")}AlterExtensionContentsStmt(e,r){let t=["ALTER","EXTENSION"];if(e.extname&&t.push(this.quoteIfNeeded(e.extname)),e.action===1?t.push("ADD"):e.action===-1&&t.push("DROP"),e.objtype)try{t.push(this.getObjectTypeKeyword(e.objtype));}catch{t.push(e.objtype.toString());}return e.object&&t.push(this.visit(e.object,r)),t.join(" ")}CreateFdwStmt(e,r){let t=["CREATE","FOREIGN","DATA","WRAPPER"];if(e.fdwname&&t.push(e.fdwname),e.func_options&&e.func_options.length>0){let n=r.spawn("CreateFdwStmt"),i=h.unwrapList(e.func_options).map(a=>this.visit(a,n)).join(" ");t.push(i);}if(e.options&&e.options.length>0){t.push("OPTIONS");let n=r.spawn("CreateFdwStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n)).join(", ");t.push(`(${i})`);}return t.join(" ")}SetOperationStmt(e,r){let t=[];if(e.larg&&t.push(this.visit(e.larg,r)),e.op)switch(e.op){case "SETOP_UNION":t.push(e.all?"UNION ALL":"UNION");break;case "SETOP_INTERSECT":t.push(e.all?"INTERSECT ALL":"INTERSECT");break;case "SETOP_EXCEPT":t.push(e.all?"EXCEPT ALL":"EXCEPT");break;default:throw new Error(`Unsupported SetOperation: ${e.op}`)}return e.rarg&&t.push(this.visit(e.rarg,r)),t.join(" ")}ReplicaIdentityStmt(e,r){let t=[];if(e.identity_type)switch(e.identity_type){case "d":case "REPLICA_IDENTITY_DEFAULT":t.push("DEFAULT");break;case "f":case "REPLICA_IDENTITY_FULL":t.push("FULL");break;case "n":case "REPLICA_IDENTITY_NOTHING":t.push("NOTHING");break;case "i":case "REPLICA_IDENTITY_INDEX":t.push("USING","INDEX"),e.name&&t.push(S.quoteIdentifier(e.name));break;default:throw new Error(`Unsupported replica identity type: ${e.identity_type}`)}return t.join(" ")}AlterCollationStmt(e,r){let t=["ALTER","COLLATION"];if(e.collname&&e.collname.length>0){let n=h.unwrapList(e.collname).map(i=>this.visit(i,r)).join(".");t.push(n);}return t.push("REFRESH","VERSION"),t.join(" ")}AlterDomainStmt(e,r){let t=["ALTER","DOMAIN"];if(e.typeName&&e.typeName.length>0){let n=h.unwrapList(e.typeName).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.subtype)switch(e.subtype){case "AT_SetNotNull":t.push("SET","NOT","NULL");break;case "AT_DropNotNull":t.push("DROP","NOT","NULL");break;case "AT_SetDefault":t.push("SET","DEFAULT"),e.def&&t.push(this.visit(e.def,r));break;case "AT_DropDefault":t.push("DROP","DEFAULT");break;case "AT_AddConstraint":if(t.push("ADD"),e.def){let n=r.spawn("CreateDomainStmt",{isDomainConstraint:true});t.push(this.visit(e.def,n));}break;case "AT_DropConstraint":t.push("DROP","CONSTRAINT"),e.missing_ok&&t.push("IF","EXISTS"),e.name&&t.push(S.quoteIdentifier(e.name)),e.behavior==="DROP_CASCADE"&&t.push("CASCADE");break;case "AT_ValidateConstraint":t.push("VALIDATE","CONSTRAINT"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "C":if(t.push("ADD"),e.def){let n=r.spawn("CreateDomainStmt",{isDomainConstraint:true});t.push(this.visit(e.def,n));}break;case "X":t.push("DROP","CONSTRAINT"),e.missing_ok&&t.push("IF","EXISTS"),e.name&&t.push(S.quoteIdentifier(e.name)),e.behavior==="DROP_CASCADE"&&t.push("CASCADE");break;case "V":t.push("VALIDATE","CONSTRAINT"),e.name&&t.push(S.quoteIdentifier(e.name));break;case "O":t.push("SET","NOT","NULL");break;case "N":t.push("DROP","NOT","NULL");break;case "T":e.def?(t.push("SET","DEFAULT"),t.push(this.visit(e.def,r))):t.push("DROP","DEFAULT");break;default:throw new Error(`Unsupported AlterDomainStmt subtype: ${e.subtype}`)}return t.join(" ")}PrepareStmt(e,r){let t=["PREPARE"];if(e.name&&t.push(e.name),e.argtypes&&e.argtypes.length>0){let n=h.unwrapList(e.argtypes).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}return t.push("AS"),e.query&&t.push(this.visit(e.query,r)),t.join(" ")}ExecuteStmt(e,r){let t=["EXECUTE"];if(e.name&&t.push(e.name),e.params&&e.params.length>0){let n=h.unwrapList(e.params).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}return t.join(" ")}DeallocateStmt(e,r){let t=["DEALLOCATE"];return e.isall?t.push("ALL"):e.name&&t.push(e.name),t.join(" ")}NotifyStmt(e,r){let t=["NOTIFY"];return e.conditionname&&t.push(e.conditionname),e.payload!==null&&e.payload!==void 0&&(t.push(","),t.push(`'${e.payload}'`)),t.join(" ")}ListenStmt(e,r){let t=["LISTEN"];return e.conditionname&&t.push(e.conditionname),t.join(" ")}UnlistenStmt(e,r){let t=["UNLISTEN"];return e.conditionname?t.push(e.conditionname):t.push("*"),t.join(" ")}CheckPointStmt(e,r){return "CHECKPOINT"}LoadStmt(e,r){if(!e.filename)throw new Error("LoadStmt requires filename");return `LOAD '${e.filename}'`}DiscardStmt(e,r){switch(e.target){case "DISCARD_ALL":return "DISCARD ALL";case "DISCARD_PLANS":return "DISCARD PLANS";case "DISCARD_SEQUENCES":return "DISCARD SEQUENCES";case "DISCARD_TEMP":return "DISCARD TEMP";default:throw new Error(`Unsupported DiscardStmt target: ${e.target}`)}}CommentStmt(e,r){let t=["COMMENT ON"];if(e.objtype)switch(e.objtype){case "OBJECT_TABLE":t.push("TABLE");break;case "OBJECT_COLUMN":t.push("COLUMN");break;case "OBJECT_INDEX":t.push("INDEX");break;case "OBJECT_FUNCTION":t.push("FUNCTION");break;case "OBJECT_VIEW":t.push("VIEW");break;case "OBJECT_SCHEMA":t.push("SCHEMA");break;case "OBJECT_DATABASE":t.push("DATABASE");break;case "OBJECT_MATVIEW":t.push("MATERIALIZED VIEW");break;case "OBJECT_TABCONSTRAINT":t.push("CONSTRAINT");break;case "OBJECT_TRIGGER":t.push("TRIGGER");break;case "OBJECT_FDW":t.push("FOREIGN DATA WRAPPER");break;case "OBJECT_EVENT_TRIGGER":t.push("EVENT TRIGGER");break;case "OBJECT_FOREIGN_SERVER":t.push("SERVER");break;case "OBJECT_FOREIGN_TABLE":t.push("FOREIGN TABLE");break;case "OBJECT_STATISTIC_EXT":t.push("STATISTICS");break;case "OBJECT_LARGEOBJECT":t.push("LARGE OBJECT");break;case "OBJECT_OPERATOR":t.push("OPERATOR");break;case "OBJECT_OPCLASS":t.push("OPERATOR CLASS");break;case "OBJECT_OPFAMILY":t.push("OPERATOR FAMILY");break;case "OBJECT_POLICY":t.push("POLICY");break;case "OBJECT_TSPARSER":t.push("TEXT SEARCH PARSER");break;case "OBJECT_TSDICTIONARY":t.push("TEXT SEARCH DICTIONARY");break;case "OBJECT_TSTEMPLATE":t.push("TEXT SEARCH TEMPLATE");break;case "OBJECT_TSCONFIGURATION":t.push("TEXT SEARCH CONFIGURATION");break;case "OBJECT_TRANSFORM":t.push("TRANSFORM");break;default:t.push(e.objtype.replace("OBJECT_",""));}if(e.object)if(e.object&&typeof e.object=="object"&&"List"in e.object){let n=e.object.List;if(n.items&&n.items.length>0){let i=h.unwrapList(n.items).map(a=>this.visit(a,r));if(e.objtype==="OBJECT_TABCONSTRAINT")if(i.length===3){let[a,o,l]=i;t.push(l),t.push("ON"),t.push(`${a}.${o}`);}else if(i.length===2){let[a,o]=i;t.push(o),t.push("ON"),t.push(a);}else t.push(i.join("."));else if(e.objtype==="OBJECT_TRIGGER")if(i.length===2){let[a,o]=i;t.push(o),t.push("ON"),t.push(a);}else t.push(i.join("."));else if(e.objtype==="OBJECT_RULE")if(i.length===2){let[a,o]=i;t.push(o),t.push("ON"),t.push(a);}else t.push(i.join("."));else if(e.objtype==="OBJECT_OPERATOR")if(e.object&&e.object.ObjectWithArgs){let a=e.object.ObjectWithArgs,o=a.objname&&a.objname[0]&&a.objname[0].String?a.objname[0].String.sval:"unknown";o.startsWith('"')&&o.endsWith('"')&&(o=o.slice(1,-1));let l=[];a.objargs&&a.objargs.forEach(u=>{if(!u||Object.keys(u).length===0)l.push("NONE");else if(u.TypeName){let p=this.visit(u,r);l.push(p);}else l.push("unknown");}),t.push(`${o} (${l.join(", ")})`);}else t.push(i.join("."));else if(e.objtype==="OBJECT_OPCLASS"||e.objtype==="OBJECT_OPFAMILY")if(i.length>=2){let a=i[i.length-1],o=i[i.length-2];t.push(`${a} USING ${o}`);}else t.push(i.join(" USING "));else if(e.objtype==="OBJECT_POLICY")if(i.length===2){let[a,o]=i;t.push(o),t.push("ON"),t.push(a);}else t.push(i.join("."));else if(e.objtype==="OBJECT_TRANSFORM")if(i.length===2){let[a,o]=i;t.push("FOR"),t.push(a),t.push("LANGUAGE"),t.push(o);}else t.push(i.join("."));else t.push(i.join("."));}}else if(e.objtype==="OBJECT_OPERATOR"&&e.object&&e.object.ObjectWithArgs){let n=e.object.ObjectWithArgs,i=n.objname&&n.objname[0]&&n.objname[0].String?n.objname[0].String.sval:"unknown";i.startsWith('"')&&i.endsWith('"')&&(i=i.slice(1,-1));let a=[];n.objargs&&n.objargs.forEach(o=>{if(!o||Object.keys(o).length===0)a.push("NONE");else if(o.TypeName){let l=this.visit(o,r);a.push(l);}else a.push("unknown");}),t.push(`${i}(${a.join(", ")})`);}else {let n=r.spawn("CommentStmt",{objtype:e.objtype});t.push(this.visit(e.object,n));}return t.push("IS"),e.comment===null||e.comment===void 0?t.push("NULL"):e.comment&&t.push(S.formatEString(e.comment)),t.join(" ")}LockStmt(e,r){let t=["LOCK","TABLE"];if(e.relations&&e.relations.length>0){let n=h.unwrapList(e.relations).map(i=>this.visit(i,r)).join(", ");t.push(n);}if(e.mode!==void 0){let n=["","ACCESS SHARE","ROW SHARE","ROW EXCLUSIVE","SHARE UPDATE EXCLUSIVE","SHARE","SHARE ROW EXCLUSIVE","EXCLUSIVE","ACCESS EXCLUSIVE"];e.mode>=1&&e.mode<n.length&&t.push("IN",n[e.mode],"MODE");}return e.nowait&&t.push("NOWAIT"),t.join(" ")}CreatePolicyStmt(e,r){let t=[],n=["CREATE","POLICY"];if(e.policy_name&&n.push(S.quoteIdentifier(e.policy_name)),t.push(n.join(" ")),e.table&&(r.isPretty()?t.push(r.newline()+r.indent(`ON ${this.RangeVar(e.table,r)}`)):(t.push("ON"),t.push(this.RangeVar(e.table,r)))),e.permissive===void 0?r.isPretty()?t.push(r.newline()+r.indent("AS RESTRICTIVE")):t.push("AS","RESTRICTIVE"):e.permissive===true&&(r.isPretty()?t.push(r.newline()+r.indent("AS PERMISSIVE")):t.push("AS","PERMISSIVE")),e.cmd_name&&(r.isPretty()?t.push(r.newline()+r.indent(`FOR ${e.cmd_name.toUpperCase()}`)):t.push("FOR",e.cmd_name.toUpperCase())),e.roles&&e.roles.length>0){let i=h.unwrapList(e.roles).map(a=>this.visit(a,r));r.isPretty()?t.push(r.newline()+r.indent(`TO ${i.join(", ")}`)):(t.push("TO"),t.push(i.join(", ")));}if(e.qual)if(r.isPretty()){let i=this.visit(e.qual,r);t.push(r.newline()+r.indent("USING (")),t.push(r.newline()+r.indent(r.indent(i))),t.push(r.newline()+r.indent(")"));}else t.push("USING"),t.push(`(${this.visit(e.qual,r)})`);if(e.with_check)if(r.isPretty()){let i=this.visit(e.with_check,r);t.push(r.newline()+r.indent("WITH CHECK (")),t.push(r.newline()+r.indent(r.indent(i))),t.push(r.newline()+r.indent(")"));}else t.push("WITH CHECK"),t.push(`(${this.visit(e.with_check,r)})`);return r.isPretty()?t.join(""):t.join(" ")}AlterPolicyStmt(e,r){let t=["ALTER","POLICY"];if(e.policy_name&&t.push(S.quoteIdentifier(e.policy_name)),e.table&&(t.push("ON"),t.push(this.RangeVar(e.table,r))),e.roles&&e.roles.length>0){t.push("TO");let n=h.unwrapList(e.roles).map(i=>this.visit(i,r));t.push(n.join(", "));}return e.qual&&(t.push("USING"),t.push(`(${this.visit(e.qual,r)})`)),e.with_check&&(t.push("WITH CHECK"),t.push(`(${this.visit(e.with_check,r)})`)),t.join(" ")}CreateUserMappingStmt(e,r){let t=["CREATE"];if(e.if_not_exists&&t.push("IF","NOT","EXISTS"),t.push("USER","MAPPING"),t.push("FOR"),e.user?t.push(this.RoleSpec(e.user,r)):t.push("CURRENT_USER"),t.push("SERVER"),e.servername&&t.push(S.quoteIdentifier(e.servername)),e.options&&e.options.length>0){t.push("OPTIONS");let n=r.spawn("CreateUserMappingStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(`(${i.join(", ")})`);}return t.join(" ")}CreateStatsStmt(e,r){let t=["CREATE"];if(e.if_not_exists&&t.push("IF","NOT","EXISTS"),t.push("STATISTICS"),e.defnames&&e.defnames.length>0){let n=h.unwrapList(e.defnames).map(i=>this.visit(i,r));t.push(n.join("."));}if(e.stat_types&&e.stat_types.length>0){let n=h.unwrapList(e.stat_types).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}if(t.push("ON"),e.exprs&&e.exprs.length>0){let n=h.unwrapList(e.exprs).map(i=>this.visit(i,r));t.push(n.join(", "));}if(e.relations&&e.relations.length>0){t.push("FROM");let n=h.unwrapList(e.relations).map(i=>this.visit(i,r));t.push(n.join(", "));}return t.join(" ")}StatsElem(e,r){return e.name?this.quoteIfNeeded(e.name):e.expr?`(${this.visit(e.expr,r)})`:""}CreatePublicationStmt(e,r){let t=["CREATE","PUBLICATION"];if(e.pubname&&t.push(S.quoteIdentifier(e.pubname)),e.pubobjects&&e.pubobjects.length>0){t.push("FOR","TABLE");let n=h.unwrapList(e.pubobjects).map(i=>this.visit(i,r));t.push(n.join(", "));}else e.for_all_tables&&t.push("FOR","ALL","TABLES");if(e.options&&e.options.length>0){t.push("WITH");let n=h.unwrapList(e.options).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}return t.join(" ")}CreateSubscriptionStmt(e,r){let t=["CREATE","SUBSCRIPTION"];if(e.subname&&t.push(S.quoteIdentifier(e.subname)),t.push("CONNECTION"),e.conninfo&&t.push(`'${e.conninfo}'`),t.push("PUBLICATION"),e.publication&&e.publication.length>0){let n=h.unwrapList(e.publication).map(i=>this.visit(i,r));t.push(n.join(", "));}if(e.options&&e.options.length>0){t.push("WITH");let n=h.unwrapList(e.options).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}return t.join(" ")}AlterPublicationStmt(e,r){let t=["ALTER","PUBLICATION"];if(e.pubname&&t.push(S.quoteIdentifier(e.pubname)),e.action)switch(e.action){case "AP_AddObjects":t.push("ADD");break;case "AP_DropObjects":t.push("DROP");break;case "AP_SetObjects":t.push("SET");break;default:throw new Error(`Unsupported AlterPublicationStmt action: ${e.action}`)}if(e.for_all_tables)t.push("FOR ALL TABLES");else if(e.pubobjects&&e.pubobjects.length>0){t.push("FOR TABLE");let n=h.unwrapList(e.pubobjects).map(i=>this.visit(i,r));t.push(n.join(", "));}if(e.options&&e.options.length>0){t.push("WITH");let n=h.unwrapList(e.options).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}return t.join(" ")}AlterSubscriptionStmt(e,r){let t=["ALTER","SUBSCRIPTION"];if(e.subname&&t.push(S.quoteIdentifier(e.subname)),e.kind)switch(e.kind){case "ALTER_SUBSCRIPTION_OPTIONS":t.push("SET");break;case "ALTER_SUBSCRIPTION_CONNECTION":t.push("CONNECTION"),e.conninfo&&t.push(`'${e.conninfo}'`);break;case "ALTER_SUBSCRIPTION_SET_PUBLICATION":if(t.push("SET PUBLICATION"),e.publication&&e.publication.length>0){let n=h.unwrapList(e.publication).map(i=>this.visit(i,r));t.push(n.join(", "));}break;case "ALTER_SUBSCRIPTION_REFRESH":t.push("REFRESH PUBLICATION");break;case "ALTER_SUBSCRIPTION_ENABLED":t.push("ENABLE");break;case "ALTER_SUBSCRIPTION_SKIP":t.push("SKIP");break;default:throw new Error(`Unsupported AlterSubscriptionStmt kind: ${e.kind}`)}if(e.options&&e.options.length>0){t.push("WITH");let n=h.unwrapList(e.options).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}return t.join(" ")}DropSubscriptionStmt(e,r){let t=["DROP","SUBSCRIPTION"];if(e.missing_ok&&t.push("IF EXISTS"),e.subname&&t.push(S.quoteIdentifier(e.subname)),e.behavior)switch(e.behavior){case "DROP_CASCADE":t.push("CASCADE");break;case "DROP_RESTRICT":t.push("RESTRICT");break}return t.join(" ")}DoStmt(e,r){let t=["DO"];if(e.args&&e.args.length>0){let n=r.spawn("DoStmt"),i=h.unwrapList(e.args),a=[];for(let o of i)if(this.getNodeType(o)==="DefElem"){let u=this.getNodeData(o);if(u.defname==="language"){let p=this.visit(u.arg,n);a.push(`LANGUAGE ${p}`);}else if(u.defname==="as")if(this.getNodeType(u.arg)==="String"){let c=this.getNodeData(u.arg),f=this.getFunctionDelimiter(c.sval);a.push(`${f}${c.sval}${f}`);}else a.push(this.visit(u.arg,n));}t.push(...a);}return t.join(" ")}generateUniqueDollarTag(e){let r=/\$[a-zA-Z0-9_]*\$/g,t=e.match(r)||[];if(t.length===0)return "$$";let n=new Set(t);if(n.has("$$")){let i=1,a=`$do${i}$`;for(;n.has(a);)i++,a=`$do${i}$`;return a}return "$$"}InlineCodeBlock(e,r){if(e.source_text){let n=this.getFunctionDelimiter(e.source_text);return `${n}${e.source_text}${n}`}let t=this.options.functionDelimiter||"$$";return `${t}${t}`}CallContext(e,r){return e.atomic!==void 0?e.atomic?"ATOMIC":"NOT ATOMIC":""}ConstraintsSetStmt(e,r){let t=["SET","CONSTRAINTS"];if(e.constraints&&e.constraints.length>0){let n=h.unwrapList(e.constraints).map(i=>this.visit(i,r));t.push(n.join(", "));}else t.push("ALL");return t.push(e.deferred?"DEFERRED":"IMMEDIATE"),t.join(" ")}AlterSystemStmt(e,r){let t=["ALTER","SYSTEM"];if(e.setstmt){let i=this.VariableSetStmt(e.setstmt,r).replace(/^SET\s+/,"");t.push("SET",i);}return t.join(" ")}VacuumRelation(e,r){let t=[];if(e.relation&&t.push(this.RangeVar(e.relation,r)),e.va_cols&&e.va_cols.length>0){t.push("(");let n=h.unwrapList(e.va_cols).map(i=>this.visit(i,r));t.push(n.join(", ")),t.push(")");}return t.join(" ")}DropOwnedStmt(e,r){let t=["DROP","OWNED","BY"];if(e.roles&&e.roles.length>0){let n=h.unwrapList(e.roles).map(i=>this.visit(i,r));t.push(n.join(", "));}if(e.behavior)switch(e.behavior){case "DROP_CASCADE":t.push("CASCADE");break;case "DROP_RESTRICT":t.push("RESTRICT");break}return t.join(" ")}ReassignOwnedStmt(e,r){let t=["REASSIGN","OWNED","BY"];if(e.roles&&e.roles.length>0){let n=h.unwrapList(e.roles).map(i=>this.visit(i,r));t.push(n.join(", "));}return t.push("TO"),e.newrole&&t.push(this.RoleSpec(e.newrole,r)),t.join(" ")}AlterTSDictionaryStmt(e,r){let t=["ALTER","TEXT","SEARCH","DICTIONARY"];if(e.dictname&&e.dictname.length>0){let n=h.unwrapList(e.dictname).map(i=>this.visit(i,r));t.push(n.join("."));}if(e.options&&e.options.length>0){t.push("(");let n=h.unwrapList(e.options).map(i=>this.visit(i,r));t.push(n.join(", ")),t.push(")");}return t.join(" ")}AlterTSConfigurationStmt(e,r){let t=["ALTER","TEXT","SEARCH","CONFIGURATION"];if(e.cfgname&&e.cfgname.length>0){let n=h.unwrapList(e.cfgname).map(i=>this.visit(i,r));t.push(n.join("."));}if(e.kind)switch(e.kind){case "ALTER_TSCONFIG_ADD_MAPPING":if(t.push("ADD","MAPPING","FOR"),e.tokentype&&e.tokentype.length>0){let n=h.unwrapList(e.tokentype).map(i=>this.visit(i,r));t.push(n.join(", "));}if(e.dicts&&e.dicts.length>0){t.push("WITH");let n=h.unwrapList(e.dicts).map(i=>i.List&&i.List.items?h.unwrapList(i.List.items).map(a=>this.visit(a,r)).join("."):this.visit(i,r));t.push(n.join(", "));}break;case "ALTER_TSCONFIG_ALTER_MAPPING_FOR_TOKEN":if(t.push("ALTER","MAPPING","FOR"),e.tokentype&&e.tokentype.length>0){let n=h.unwrapList(e.tokentype).map(i=>this.visit(i,r));t.push(n.join(", "));}if(e.dicts&&e.dicts.length>0){t.push("WITH");let n=h.unwrapList(e.dicts).map(i=>i.List&&i.List.items?h.unwrapList(i.List.items).map(a=>this.visit(a,r)).join("."):this.visit(i,r));t.push(n.join(", "));}break;case "ALTER_TSCONFIG_REPLACE_DICT":if(t.push("ALTER","MAPPING","REPLACE"),e.dicts&&e.dicts.length>=2){let n=h.unwrapList(e.dicts).map(i=>i.List&&i.List.items?h.unwrapList(i.List.items).map(a=>this.visit(a,r)).join("."):this.visit(i,r));t.push(n[0],"WITH",n.slice(1).join(", "));}break;case "ALTER_TSCONFIG_REPLACE_DICT_FOR_TOKEN":if(t.push("ALTER","MAPPING","FOR"),e.tokentype&&e.tokentype.length>0){let n=h.unwrapList(e.tokentype).map(i=>this.visit(i,r));t.push(n.join(", "));}if(e.dicts&&e.dicts.length>=2){t.push("REPLACE");let n=h.unwrapList(e.dicts).map(i=>i.List&&i.List.items?h.unwrapList(i.List.items).map(a=>this.visit(a,r)).join("."):this.visit(i,r));t.push(n[0],"WITH",n.slice(1).join(", "));}break;case "ALTER_TSCONFIG_DROP_MAPPING":if(t.push("DROP","MAPPING","FOR"),e.tokentype&&e.tokentype.length>0){let n=h.unwrapList(e.tokentype).map(i=>this.visit(i,r));t.push(n.join(", "));}break;default:throw new Error(`Unsupported AlterTSConfigurationStmt kind: ${e.kind}`)}return t.join(" ")}ClosePortalStmt(e,r){let t=["CLOSE"];return e.portalname?t.push(S.quoteIdentifier(e.portalname)):t.push("ALL"),t.join(" ")}FetchStmt(e,r){let t=[e.ismove?"MOVE":"FETCH"],n=e.howMany===9223372036854776e3;if(e.direction)switch(e.direction){case "FETCH_FORWARD":n?t.push("FORWARD","ALL"):e.howMany!==void 0&&e.howMany!==null?t.push("FORWARD",e.howMany.toString()):t.push("FORWARD");break;case "FETCH_BACKWARD":n?t.push("BACKWARD","ALL"):e.howMany!==void 0&&e.howMany!==null?t.push("BACKWARD",e.howMany.toString()):t.push("BACKWARD");break;case "FETCH_ABSOLUTE":e.howMany!==void 0&&e.howMany!==null&&t.push("ABSOLUTE",e.howMany.toString());break;case "FETCH_RELATIVE":e.howMany!==void 0&&e.howMany!==null?t.push("RELATIVE",e.howMany.toString()):t.push("RELATIVE","0");break;default:throw new Error(`Unsupported FetchStmt direction: ${e.direction}`)}else n&&t.push("ALL");return e.portalname&&t.push(S.quoteIdentifier(e.portalname)),t.join(" ")}AlterStatsStmt(e,r){let t=["ALTER","STATISTICS"];if(e.defnames&&e.defnames.length>0){let n=h.unwrapList(e.defnames).map(i=>this.visit(i,r));t.push(n.join("."));}return t.push("SET","STATISTICS"),e.stxstattarget&&t.push(this.visit(e.stxstattarget,r)),t.join(" ")}ObjectWithArgs(e,r){let t="";if(e.objname&&e.objname.length>0){let n=r.spawn("ObjectWithArgs");t=h.unwrapList(e.objname).map(a=>this.visit(a,n)).join(".");}if(e.objfuncargs&&e.objfuncargs.length>0){let n=h.unwrapList(e.objfuncargs).map(i=>this.visit(i,r));t+=`(${n.join(", ")})`;}else if(e.objargs&&e.objargs.length>0){let n=h.unwrapList(e.objargs).map(i=>!i||Object.keys(i).length===0?"NONE":this.visit(i,r));t+=`(${n.join(", ")})`;}else e.args_unspecified||((r.parentNodeTypes.includes("CommentStmt")||r.parentNodeTypes.includes("DropStmt"))&&r.objtype==="OBJECT_AGGREGATE"?t+="(*)":r.parentNodeTypes.includes("CreateOpClassItem")||(t+="()"));return t}AlterOperatorStmt(e,r){let t=["ALTER","OPERATOR"];if(e.opername&&t.push(this.ObjectWithArgs(e.opername,r)),t.push("SET"),e.options&&e.options.length>0){let n=r.spawn("AlterOperatorStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(`(${i.join(", ")})`);}return t.join(" ")}AlterFdwStmt(e,r){let t=["ALTER","FOREIGN","DATA","WRAPPER"];if(e.fdwname&&t.push(S.quoteIdentifier(e.fdwname)),e.func_options&&e.func_options.length>0){let n=r.spawn("AlterFdwStmt"),i=h.unwrapList(e.func_options).map(a=>this.visit(a,n));t.push(i.join(" "));}if(e.options&&e.options.length>0){t.push("OPTIONS");let n=r.spawn("AlterFdwStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(`(${i.join(", ")})`);}return t.join(" ")}CreateForeignServerStmt(e,r){let t=["CREATE","SERVER"];if(e.if_not_exists&&t.push("IF","NOT","EXISTS"),e.servername&&t.push(S.quoteIdentifier(e.servername)),e.servertype&&t.push("TYPE",S.escape(e.servertype)),e.version&&t.push("VERSION",S.escape(e.version)),e.fdwname&&t.push("FOREIGN","DATA","WRAPPER",S.quoteIdentifier(e.fdwname)),e.options&&e.options.length>0){t.push("OPTIONS"),t.push("(");let n=r.spawn("CreateForeignServerStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(i.join(", ")),t.push(")");}return t.join(" ")}AlterForeignServerStmt(e,r){let t=["ALTER","SERVER"];if(e.servername&&t.push(S.quoteIdentifier(e.servername)),e.version&&t.push("VERSION",S.escape(e.version)),e.options&&e.options.length>0){t.push("OPTIONS"),t.push("(");let n=r.spawn("AlterForeignServerStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(i.join(", ")),t.push(")");}return t.join(" ")}AlterUserMappingStmt(e,r){let t=["ALTER","USER","MAPPING","FOR"];if(e.user?t.push(this.RoleSpec(e.user,r)):t.push("CURRENT_USER"),t.push("SERVER"),e.servername&&t.push(S.quoteIdentifier(e.servername)),e.options&&e.options.length>0){t.push("OPTIONS");let n=r.spawn("AlterUserMappingStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(`(${i.join(", ")})`);}return t.join(" ")}DropUserMappingStmt(e,r){let t=["DROP","USER","MAPPING"];return e.missing_ok&&t.push("IF","EXISTS"),t.push("FOR"),e.user?t.push(this.RoleSpec(e.user,r)):t.push("CURRENT_USER"),t.push("SERVER"),e.servername&&t.push(S.quoteIdentifier(e.servername)),t.join(" ")}ImportForeignSchemaStmt(e,r){let t=["IMPORT","FOREIGN","SCHEMA"];if(e.remote_schema&&t.push(S.quoteIdentifier(e.remote_schema)),e.list_type)switch(e.list_type){case "FDW_IMPORT_SCHEMA_ALL":break;case "FDW_IMPORT_SCHEMA_LIMIT_TO":if(t.push("LIMIT","TO"),e.table_list&&e.table_list.length>0){let n=h.unwrapList(e.table_list).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}break;case "FDW_IMPORT_SCHEMA_EXCEPT":if(t.push("EXCEPT"),e.table_list&&e.table_list.length>0){let n=h.unwrapList(e.table_list).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}break;default:throw new Error(`Unsupported ImportForeignSchemaStmt list_type: ${e.list_type}`)}if(t.push("FROM","SERVER"),e.server_name&&t.push(S.quoteIdentifier(e.server_name)),t.push("INTO"),e.local_schema&&t.push(S.quoteIdentifier(e.local_schema)),e.options&&e.options.length>0){let n=r.spawn("ImportForeignSchemaStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(`OPTIONS (${i.join(", ")})`);}return t.join(" ")}ClusterStmt(e,r){let t=["CLUSTER"];if(e.relation&&(t.push(this.RangeVar(e.relation,r)),e.indexname&&t.push("USING",S.quoteIdentifier(e.indexname))),e.params&&e.params.length>0){let n=h.unwrapList(e.params).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}return t.join(" ")}VacuumStmt(e,r){let t=[e.is_vacuumcmd?"VACUUM":"ANALYZE"];if(e.options&&e.options.length>0){let n=h.unwrapList(e.options).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}if(e.rels&&e.rels.length>0){let n=h.unwrapList(e.rels).map(i=>this.visit(i,r));t.push(n.join(", "));}return t.join(" ")}ExplainStmt(e,r){let t=["EXPLAIN"];if(e.options&&e.options.length>0){let n=r.spawn("ExplainStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(`(${i.join(", ")})`);}return e.query&&t.push(this.visit(e.query,r)),t.join(" ")}ReindexStmt(e,r){let t=["REINDEX"];if(e.params&&e.params.length>0){let n=h.unwrapList(e.params).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}if(e.kind)switch(e.kind){case "REINDEX_OBJECT_INDEX":t.push("INDEX");break;case "REINDEX_OBJECT_TABLE":t.push("TABLE");break;case "REINDEX_OBJECT_SCHEMA":t.push("SCHEMA");break;case "REINDEX_OBJECT_SYSTEM":t.push("SYSTEM");break;case "REINDEX_OBJECT_DATABASE":t.push("DATABASE");break;default:throw new Error(`Unsupported ReindexStmt kind: ${e.kind}`)}return e.relation&&t.push(this.RangeVar(e.relation,r)),e.name&&t.push(S.quoteIdentifier(e.name)),t.join(" ")}CallStmt(e,r){let t=["CALL"];if(e.funccall){let n=e.funccall;if(n.funcname&&n.funcname.length>0){let a=n.funcname.map(l=>l.String?l.String.sval:this.visit(l,r)).join("."),o="";n.args&&n.args.length>0?o=`(${n.args.map(u=>this.visit(u,r)).join(", ")})`:o="()",t.push(`${a}${o}`);}}else if(e.funcexpr)t.push(this.FuncExpr(e.funcexpr,r));else throw new Error("CallStmt requires either funccall or funcexpr");return t.join(" ")}CreatedbStmt(e,r){let t=["CREATE DATABASE"];if(!e.dbname)throw new Error("CreatedbStmt requires dbname");if(t.push(S.quoteIdentifier(e.dbname)),e.options&&e.options.length>0){let n=h.unwrapList(e.options).map(i=>this.visit(i,r)).join(" ");t.push("WITH",n);}return t.join(" ")}DropdbStmt(e,r){let t=["DROP DATABASE"];if(e.missing_ok&&t.push("IF EXISTS"),!e.dbname)throw new Error("DropdbStmt requires dbname");if(t.push(S.quoteIdentifier(e.dbname)),e.options&&e.options.length>0){let n=h.unwrapList(e.options).map(i=>this.visit(i,r)).join(" ");t.push("WITH",n);}return t.join(" ")}RenameStmt(e,r){let t=["ALTER"];if(!e.renameType)throw new Error("RenameStmt requires renameType");switch(e.renameType){case "OBJECT_TABLE":t.push("TABLE");break;case "OBJECT_VIEW":t.push("VIEW");break;case "OBJECT_INDEX":t.push("INDEX");break;case "OBJECT_SEQUENCE":t.push("SEQUENCE");break;case "OBJECT_FUNCTION":t.push("FUNCTION");break;case "OBJECT_PROCEDURE":t.push("PROCEDURE");break;case "OBJECT_SCHEMA":t.push("SCHEMA");break;case "OBJECT_DATABASE":t.push("DATABASE");break;case "OBJECT_COLUMN":e.relationType==="OBJECT_FOREIGN_TABLE"?t.push("FOREIGN TABLE"):e.relationType==="OBJECT_VIEW"?t.push("VIEW"):t.push("TABLE");break;case "OBJECT_DOMAIN":t.push("DOMAIN");break;case "OBJECT_TYPE":t.push("TYPE");break;case "OBJECT_DOMCONSTRAINT":t.push("DOMAIN");break;case "OBJECT_TABCONSTRAINT":t.push("TABLE");break;case "OBJECT_AGGREGATE":t.push("AGGREGATE");break;case "OBJECT_COLLATION":t.push("COLLATION");break;case "OBJECT_CONVERSION":t.push("CONVERSION");break;case "OBJECT_EXTENSION":t.push("EXTENSION");break;case "OBJECT_FOREIGN_SERVER":t.push("SERVER");break;case "OBJECT_FOREIGN_TABLE":t.push("FOREIGN TABLE");break;case "OBJECT_LANGUAGE":t.push("LANGUAGE");break;case "OBJECT_MATVIEW":t.push("MATERIALIZED VIEW");break;case "OBJECT_OPCLASS":t.push("OPERATOR CLASS");break;case "OBJECT_OPERATOR":t.push("OPERATOR");break;case "OBJECT_OPFAMILY":t.push("OPERATOR FAMILY");break;case "OBJECT_POLICY":t.push("POLICY"),e.subname&&t.push(S.quoteIdentifier(e.subname));break;case "OBJECT_PUBLICATION":t.push("PUBLICATION");break;case "OBJECT_ROLE":t.push("ROLE");break;case "OBJECT_RULE":t.push("RULE");break;case "OBJECT_SUBSCRIPTION":t.push("SUBSCRIPTION");break;case "OBJECT_TABLESPACE":t.push("TABLESPACE");break;case "OBJECT_TRIGGER":t.push("TRIGGER");break;case "OBJECT_TSCONFIGURATION":t.push("TEXT SEARCH CONFIGURATION");break;case "OBJECT_TSDICTIONARY":t.push("TEXT SEARCH DICTIONARY");break;case "OBJECT_TSPARSER":t.push("TEXT SEARCH PARSER");break;case "OBJECT_TSTEMPLATE":t.push("TEXT SEARCH TEMPLATE");break;case "OBJECT_FDW":t.push("FOREIGN DATA WRAPPER");break;case "OBJECT_EVENT_TRIGGER":t.push("EVENT TRIGGER");break;case "OBJECT_ATTRIBUTE":e.relationType==="OBJECT_TYPE"?t.push("TYPE"):t.push("TABLE");break;case "OBJECT_ROUTINE":t.push("ROUTINE");break;default:throw new Error(`Unsupported RenameStmt renameType: ${e.renameType}`)}if(e.missing_ok&&t.push("IF EXISTS"),e.renameType==="OBJECT_RULE"&&e.subname&&e.relation)t.push(S.quoteIdentifier(e.subname)),t.push("ON"),t.push(this.RangeVar(e.relation,r));else if(e.relation){let n=r.spawn("RenameStmt",{objtype:e.relationType});e.renameType==="OBJECT_POLICY"&&t.push("ON"),t.push(this.RangeVar(e.relation,n));}else if(e.object)if((e.renameType==="OBJECT_OPFAMILY"||e.renameType==="OBJECT_OPCLASS")&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(`${S.quoteIdentifier(a)} USING ${i}`);}else t.push(this.visit(e.object,r));}else if(e.renameType==="OBJECT_SCHEMA"&&e.object.List){let n=h.unwrapList(e.object);n.length>0&&n[0].String?t.push(this.quoteIfNeeded(n[0].String.sval)):t.push(this.visit(e.object,r));}else t.push(this.visit(e.object,r));if(e.renameType==="OBJECT_COLUMN"&&e.subname?t.push("RENAME COLUMN",S.quoteIdentifier(e.subname),"TO"):e.renameType==="OBJECT_DOMCONSTRAINT"&&e.subname?t.push("RENAME CONSTRAINT",S.quoteIdentifier(e.subname),"TO"):e.renameType==="OBJECT_TABCONSTRAINT"&&e.subname?t.push("RENAME CONSTRAINT",S.quoteIdentifier(e.subname),"TO"):e.renameType==="OBJECT_ATTRIBUTE"&&e.subname?t.push("RENAME ATTRIBUTE",S.quoteIdentifier(e.subname),"TO"):e.renameType==="OBJECT_ROLE"&&e.subname?t.push(S.quoteIdentifier(e.subname),"RENAME TO"):e.renameType==="OBJECT_SCHEMA"&&e.subname?t.push(this.quoteIfNeeded(e.subname),"RENAME TO"):(e.renameType,t.push("RENAME TO")),!e.newname)throw new Error("RenameStmt requires newname");return t.push(S.quoteIdentifier(e.newname)),e.behavior==="DROP_CASCADE"&&t.push("CASCADE"),t.join(" ")}AlterOwnerStmt(e,r){let t=["ALTER"];if(!e.objectType)throw new Error("AlterOwnerStmt requires objectType");if(t.push(this.getObjectTypeKeyword(e.objectType)),e.relation)t.push(this.RangeVar(e.relation,r));else if(e.object)if((e.objectType==="OBJECT_OPFAMILY"||e.objectType==="OBJECT_OPCLASS")&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(`${S.quoteIdentifier(a)} USING ${i}`);}else t.push(this.visit(e.object,r));}else t.push(this.visit(e.object,r));if(t.push("OWNER TO"),!e.newowner)throw new Error("AlterOwnerStmt requires newowner");return t.push(this.RoleSpec(e.newowner,r)),t.join(" ")}GrantStmt(e,r){let t=[];if(e.is_grant?t.push("GRANT"):(t.push("REVOKE"),e.grant_option&&t.push("GRANT OPTION FOR")),e.privileges&&e.privileges.length>0){let n=r.spawn("GrantStmt"),i=h.unwrapList(e.privileges).map(a=>this.visit(a,n)).join(", ");t.push(i);}else t.push("ALL");if(t.push("ON"),e.objtype&&e.targtype==="ACL_TARGET_DEFAULTS")switch(e.objtype){case "OBJECT_TABLE":t.push("TABLES");break;case "OBJECT_SEQUENCE":t.push("SEQUENCES");break;case "OBJECT_FUNCTION":t.push("FUNCTIONS");break;case "OBJECT_PROCEDURE":t.push("PROCEDURES");break;case "OBJECT_ROUTINE":t.push("ROUTINES");break;case "OBJECT_TYPE":t.push("TYPES");break;case "OBJECT_SCHEMA":t.push("SCHEMAS");break;}switch(e.targtype){case "ACL_TARGET_OBJECT":if(e.objtype==="OBJECT_SCHEMA"?t.push("SCHEMA"):e.objtype==="OBJECT_LANGUAGE"?t.push("LANGUAGE"):e.objtype==="OBJECT_FUNCTION"?t.push("FUNCTION"):e.objtype==="OBJECT_PROCEDURE"?t.push("PROCEDURE"):e.objtype==="OBJECT_TYPE"?t.push("TYPE"):e.objtype==="OBJECT_DOMAIN"?t.push("DOMAIN"):e.objtype==="OBJECT_LARGEOBJECT"?t.push("LARGE OBJECT"):e.objtype==="OBJECT_FDW"?t.push("FOREIGN","DATA","WRAPPER"):e.objtype==="OBJECT_FOREIGN_SERVER"?t.push("FOREIGN","SERVER"):e.objtype==="OBJECT_DATABASE"&&t.push("DATABASE"),e.objects&&e.objects.length>0){let n=h.unwrapList(e.objects).map(i=>this.visit(i,r)).join(", ");t.push(n);}break;case "ACL_TARGET_ALL_IN_SCHEMA":switch(e.objtype){case "OBJECT_TABLE":t.push("ALL TABLES IN SCHEMA");break;case "OBJECT_SEQUENCE":t.push("ALL SEQUENCES IN SCHEMA");break;case "OBJECT_FUNCTION":t.push("ALL FUNCTIONS IN SCHEMA");break;case "OBJECT_PROCEDURE":t.push("ALL PROCEDURES IN SCHEMA");break;case "OBJECT_ROUTINE":t.push("ALL ROUTINES IN SCHEMA");break;case "OBJECT_TYPE":t.push("ALL TYPES IN SCHEMA");break;default:t.push("ALL TABLES IN SCHEMA");break}if(e.objects&&e.objects.length>0){let n=h.unwrapList(e.objects).map(i=>this.visit(i,r)).join(", ");t.push(n);}break;default:if(e.objects&&e.objects.length>0){let n=h.unwrapList(e.objects).map(i=>this.visit(i,r)).join(", ");t.push(n);}}if(e.is_grant?t.push("TO"):t.push("FROM"),e.grantees&&e.grantees.length>0){let n=h.unwrapList(e.grantees).map(i=>this.visit(i,r)).join(", ");t.push(n);}return e.grant_option&&e.is_grant&&t.push("WITH GRANT OPTION"),e.is_grant||(e.behavior==="DROP_CASCADE"?t.push("CASCADE"):e.behavior==="DROP_RESTRICT"&&t.push("RESTRICT")),t.join(" ")}GrantRoleStmt(e,r){let t=[],n=false,i=false,a=false,o,l,u;if(e.opt&&e.opt.length>0){let p=h.unwrapList(e.opt),c=p.find(d=>d.DefElem&&d.DefElem.defname==="inherit"),f=p.find(d=>d.String&&d.String.sval==="admin"||d.DefElem&&d.DefElem.defname==="admin"),m=p.find(d=>d.DefElem&&d.DefElem.defname==="set");c&&c.DefElem&&(n=true,o=c.DefElem.arg?.Boolean?.boolval),f&&(i=true,f.DefElem&&f.DefElem.arg&&(l=f.DefElem.arg.Boolean?.boolval)),m&&m.DefElem&&(a=true,u=m.DefElem.arg?.Boolean?.boolval);}if(e.is_grant?t.push("GRANT"):(t.push("REVOKE"),n?t.push("INHERIT OPTION FOR"):i&&t.push("ADMIN OPTION FOR")),e.granted_roles&&e.granted_roles.length>0){let p=h.unwrapList(e.granted_roles).map(c=>this.visit(c,r)).join(", ");t.push(p);}if(e.is_grant?t.push("TO"):t.push("FROM"),e.grantee_roles&&e.grantee_roles.length>0){let p=h.unwrapList(e.grantee_roles).map(c=>this.visit(c,r)).join(", ");t.push(p);}if(e.is_grant){let p=[];i&&(l===true?p.push("ADMIN OPTION"):l===false?p.push("ADMIN FALSE"):p.push("ADMIN OPTION")),n&&(o===true?p.push("INHERIT OPTION"):o===false&&p.push("INHERIT FALSE")),a&&(u===true?p.push("SET TRUE"):u===false&&p.push("SET FALSE")),p.length>0&&t.push("WITH",p.join(", "));}return t.join(" ")}SecLabelStmt(e,r){let t=["SECURITY LABEL"];if(e.provider&&t.push("FOR",S.quoteIdentifier(e.provider)),t.push("ON"),e.objtype)switch(e.objtype){case "OBJECT_TABLE":t.push("TABLE");break;case "OBJECT_COLUMN":t.push("COLUMN");break;case "OBJECT_FUNCTION":t.push("FUNCTION");break;case "OBJECT_SCHEMA":t.push("SCHEMA");break;case "OBJECT_DATABASE":t.push("DATABASE");break;case "OBJECT_ROLE":t.push("ROLE");break;default:t.push(e.objtype.replace("OBJECT_",""));}return e.object&&t.push(this.visit(e.object,r)),t.push("IS"),e.label?t.push(`'${e.label}'`):t.push("NULL"),t.join(" ")}AlterDefaultPrivilegesStmt(e,r){let t=["ALTER DEFAULT PRIVILEGES"];if(e.options&&e.options.length>0){let n=h.unwrapList(e.options);for(let i of n){let a=this.getNodeData(i);if(a.defname==="schemas"){if(t.push("IN SCHEMA"),a.arg){let o=h.unwrapList(a.arg).map(l=>this.visit(l,r)).join(", ");t.push(o);}}else if(a.defname==="roles"&&(t.push("FOR ROLE"),a.arg)){let o=h.unwrapList(a.arg).map(l=>this.visit(l,r)).join(", ");t.push(o);}}}if(e.action){let n=this.GrantStmt(e.action,r);if(r.isPretty())return t.join(" ")+r.newline()+r.indent(n);t.push(n);}return t.join(" ")}CreateConversionStmt(e,r){let t=["CREATE"];if(e.def&&t.push("DEFAULT"),t.push("CONVERSION"),e.conversion_name&&e.conversion_name.length>0){let n=h.unwrapList(e.conversion_name).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.for_encoding_name&&t.push("FOR",`'${e.for_encoding_name}'`),e.to_encoding_name&&t.push("TO",`'${e.to_encoding_name}'`),e.func_name&&e.func_name.length>0){t.push("FROM");let n=h.unwrapList(e.func_name).map(i=>this.visit(i,r)).join(".");t.push(n);}return t.join(" ")}CreateCastStmt(e,r){let t=["CREATE CAST"];if(t.push("("),e.sourcetype&&t.push(this.TypeName(e.sourcetype,r)),t.push("AS"),e.targettype&&t.push(this.TypeName(e.targettype,r)),t.push(")"),e.func?(t.push("WITH FUNCTION"),t.push(this.ObjectWithArgs(e.func,r))):e.inout?t.push("WITH INOUT"):t.push("WITHOUT FUNCTION"),e.context)switch(e.context){case "COERCION_IMPLICIT":t.push("AS IMPLICIT");break;case "COERCION_ASSIGNMENT":t.push("AS ASSIGNMENT");break;case "COERCION_EXPLICIT":break;default:throw new Error(`Unsupported CreateCastStmt context: ${e.context}`)}else e.context==="COERCION_ASSIGNMENT"&&t.push("AS ASSIGNMENT");return t.join(" ")}CreatePLangStmt(e,r){let t=["CREATE"];if(e.replace&&t.push("OR REPLACE"),e.pltrusted&&t.push("TRUSTED"),t.push("LANGUAGE"),e.plname&&t.push(S.quoteIdentifier(e.plname)),e.plhandler&&e.plhandler.length>0){t.push("HANDLER");let n=h.unwrapList(e.plhandler).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.plinline&&e.plinline.length>0){t.push("INLINE");let n=h.unwrapList(e.plinline).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.plvalidator&&e.plvalidator.length>0){t.push("VALIDATOR");let n=h.unwrapList(e.plvalidator).map(i=>this.visit(i,r)).join(".");t.push(n);}return t.join(" ")}CreateTransformStmt(e,r){let t=["CREATE"];e.replace&&t.push("OR REPLACE"),t.push("TRANSFORM FOR"),e.type_name&&t.push(this.TypeName(e.type_name,r)),t.push("LANGUAGE"),e.lang&&t.push(S.quoteIdentifier(e.lang)),t.push("(");let n=[];if(e.fromsql){let i=this.ObjectWithArgs(e.fromsql,r);n.push(`FROM SQL WITH FUNCTION ${i}`);}if(e.tosql){let i=this.ObjectWithArgs(e.tosql,r);n.push(`TO SQL WITH FUNCTION ${i}`);}return t.push(n.join(", ")),t.push(")"),t.join(" ")}CreateTrigStmt(e,r){let t=["CREATE"];if(e.replace&&t.push("OR REPLACE"),e.isconstraint&&t.push("CONSTRAINT"),t.push("TRIGGER"),e.trigname&&t.push(S.quoteIdentifier(e.trigname)),r.isPretty()){let n=[],i=[];e.timing&2?i.push("BEFORE"):e.timing&64?i.push("INSTEAD OF"):i.push("AFTER");let a=[];if(e.events&4&&a.push("INSERT"),e.events&8&&a.push("DELETE"),e.events&16){let l="UPDATE";if(e.columns&&e.columns.length>0){let u=h.unwrapList(e.columns).map(p=>this.visit(p,r)).join(", ");l+=" OF "+u;}a.push(l);}if(e.events&32&&a.push("TRUNCATE"),n.push(r.indent(i.join(" ")+" "+a.join(" OR "))),e.relation&&n.push(r.indent("ON "+this.RangeVar(e.relation,r))),e.transitionRels&&e.transitionRels.length>0){let l=h.unwrapList(e.transitionRels).map(u=>this.visit(u,r)).join(" ");n.push(r.indent("REFERENCING "+l));}if(e.deferrable&&n.push(r.indent("DEFERRABLE")),e.initdeferred&&n.push(r.indent("INITIALLY DEFERRED")),e.row?n.push(r.indent("FOR EACH ROW")):n.push(r.indent("FOR EACH STATEMENT")),e.whenClause){let l="WHEN ("+this.visit(e.whenClause,r)+")";n.push(r.indent(l));}let o="EXECUTE";if(e.funcname&&e.funcname.length>0){let l=h.unwrapList(e.funcname).map(u=>this.visit(u,r)).join(".");o+=" PROCEDURE "+l;}if(e.args&&e.args.length>0){let l=r.spawn("CreateTrigStmt",{isStringLiteral:true}),u=h.unwrapList(e.args).map(p=>this.visit(p,l)).join(", ");o+="("+u+")";}else o+="()";return n.push(r.indent(o)),t.join(" ")+r.newline()+n.join(r.newline())}else {let n=[];e.timing&2?n.push("BEFORE"):e.timing&64?n.push("INSTEAD OF"):n.push("AFTER"),t.push(n.join(" "));let i=[];if(e.events&4&&i.push("INSERT"),e.events&8&&i.push("DELETE"),e.events&16&&i.push("UPDATE"),e.events&32&&i.push("TRUNCATE"),t.push(i.join(" OR ")),e.columns&&e.columns.length>0){t.push("OF");let a=h.unwrapList(e.columns).map(o=>this.visit(o,r)).join(", ");t.push(a);}if(t.push("ON"),e.relation&&t.push(this.RangeVar(e.relation,r)),e.constrrel&&(t.push("FROM"),t.push(this.RangeVar(e.constrrel,r))),e.deferrable&&t.push("DEFERRABLE"),e.initdeferred&&t.push("INITIALLY DEFERRED"),e.transitionRels&&e.transitionRels.length>0){t.push("REFERENCING");let a=h.unwrapList(e.transitionRels).map(o=>this.visit(o,r)).join(" ");t.push(a);}if(e.row?t.push("FOR EACH ROW"):t.push("FOR EACH STATEMENT"),e.whenClause&&(t.push("WHEN"),t.push("("),t.push(this.visit(e.whenClause,r)),t.push(")")),t.push("EXECUTE"),e.funcname&&e.funcname.length>0){let a=h.unwrapList(e.funcname).map(o=>this.visit(o,r)).join(".");t.push("FUNCTION",a);}if(e.args&&e.args.length>0){t.push("(");let a=r.spawn("CreateTrigStmt",{isStringLiteral:true}),o=h.unwrapList(e.args).map(l=>this.visit(l,a)).join(", ");t.push(o),t.push(")");}else t.push("()");return t.join(" ")}}TriggerTransition(e,r){let t=[];return e.isNew?t.push("NEW TABLE AS"):t.push("OLD TABLE AS"),e.name&&t.push(S.quoteIdentifier(e.name)),t.join(" ")}CreateEventTrigStmt(e,r){let t=["CREATE EVENT TRIGGER"];if(e.trigname&&t.push(S.quoteIdentifier(e.trigname)),t.push("ON"),e.eventname&&t.push(e.eventname),e.whenclause&&e.whenclause.length>0){t.push("WHEN");let n=r.spawn("CreateEventTrigStmt"),i=h.unwrapList(e.whenclause).map(a=>this.visit(a,n)).join(" AND ");t.push(i);}if(t.push("EXECUTE"),e.funcname&&e.funcname.length>0){let n=h.unwrapList(e.funcname).map(i=>this.visit(i,r)).join(".");t.push("PROCEDURE",n+"()");}return t.join(" ")}AlterEventTrigStmt(e,r){let t=["ALTER EVENT TRIGGER"];if(e.trigname&&t.push(S.quoteIdentifier(e.trigname)),e.tgenabled)switch(e.tgenabled){case "O":t.push("ENABLE");break;case "D":t.push("DISABLE");break;case "R":t.push("ENABLE REPLICA");break;case "A":t.push("ENABLE ALWAYS");break;default:throw new Error(`Unsupported trigger enable state: ${e.tgenabled}`)}return t.join(" ")}CreateOpClassStmt(e,r){let t=["CREATE OPERATOR CLASS"];if(e.opclassname&&e.opclassname.length>0){let n=h.unwrapList(e.opclassname).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.isDefault&&t.push("DEFAULT"),t.push("FOR TYPE"),e.datatype&&t.push(this.TypeName(e.datatype,r)),t.push("USING"),e.amname&&t.push(e.amname),e.opfamilyname&&e.opfamilyname.length>0){t.push("FAMILY");let n=h.unwrapList(e.opfamilyname).map(i=>this.visit(i,r)).join(".");t.push(n);}if(t.push("AS"),e.items&&e.items.length>0){let n=h.unwrapList(e.items).map(i=>this.visit(i,r)).join(", ");t.push(n);}return t.join(" ")}CreateOpFamilyStmt(e,r){let t=["CREATE OPERATOR FAMILY"];if(e.opfamilyname&&e.opfamilyname.length>0){let n=h.unwrapList(e.opfamilyname).map(i=>this.visit(i,r)).join(".");t.push(n);}return t.push("USING"),e.amname&&t.push(e.amname),t.join(" ")}AlterOpFamilyStmt(e,r){let t=["ALTER OPERATOR FAMILY"];if(e.opfamilyname&&e.opfamilyname.length>0){let n=h.unwrapList(e.opfamilyname).map(i=>this.visit(i,r)).join(".");t.push(n);}if(t.push("USING"),e.amname&&t.push(e.amname),e.isDrop?t.push("DROP"):t.push("ADD"),e.items&&e.items.length>0){let n=h.unwrapList(e.items).map(i=>this.visit(i,r)).join(", ");t.push(n);}return t.join(" ")}MergeStmt(e,r){let t=[];if(e.withClause&&t.push(this.WithClause(e.withClause,r)),t.push("MERGE INTO"),e.relation&&t.push(this.RangeVar(e.relation,r)),e.sourceRelation&&(t.push("USING"),t.push(this.visit(e.sourceRelation,r))),e.joinCondition&&(t.push("ON"),t.push(this.visit(e.joinCondition,r))),e.mergeWhenClauses&&e.mergeWhenClauses.length>0){let n=h.unwrapList(e.mergeWhenClauses).map(i=>this.visit(i,r)).join(" ");t.push(n);}return t.join(" ")}AlterTableMoveAllStmt(e,r){let t=["ALTER"];return e.objtype==="OBJECT_TABLE"?t.push("TABLE"):e.objtype==="OBJECT_INDEX"?t.push("INDEX"):t.push("TABLE"),t.push("ALL","IN","TABLESPACE"),e.orig_tablespacename&&t.push(S.quoteIdentifier(e.orig_tablespacename)),t.push("SET","TABLESPACE"),e.new_tablespacename&&t.push(S.quoteIdentifier(e.new_tablespacename)),e.nowait&&t.push("NOWAIT"),t.join(" ")}CreateSeqStmt(e,r){let t=["CREATE"];if(e.sequence&&e.sequence.relpersistence==="t"&&t.push("TEMPORARY"),t.push("SEQUENCE"),e.if_not_exists&&t.push("IF NOT EXISTS"),e.sequence){let n=[],i=e.sequence;i.schemaname&&n.push(S.quoteIdentifier(i.schemaname)),i.relname&&n.push(S.quoteIdentifier(i.relname)),t.push(n.join("."));}if(e.options&&e.options.length>0){let n=r.spawn("CreateSeqStmt"),i=h.unwrapList(e.options).filter(a=>a!=null&&this.getNodeType(a)!=="undefined").map(a=>{try{return this.visit(a,n)}catch(o){return console.warn(`Error processing option in CreateSeqStmt: ${o instanceof Error?o.message:String(o)}`),""}}).filter(a=>a!=="").join(" ");i&&t.push(i);}return t.join(" ")}AlterSeqStmt(e,r){let t=["ALTER","SEQUENCE"];if(e.missing_ok&&t.push("IF EXISTS"),e.sequence){let n=[],i=e.sequence;i.schemaname&&n.push(S.quoteIdentifier(i.schemaname)),i.relname&&n.push(S.quoteIdentifier(i.relname)),t.push(n.join("."));}if(e.options&&e.options.length>0){let n=r.spawn("AlterSeqStmt"),i=h.unwrapList(e.options).filter(a=>a&&a!==void 0).map(a=>{try{return !a||this.getNodeType(a)==="undefined"?"":this.visit(a,n)}catch(o){return console.warn(`Error processing option in AlterSeqStmt: ${o instanceof Error?o.message:String(o)}`),""}}).filter(a=>a&&a.trim().length>0).join(" ");i&&t.push(i);}return e.for_identity&&t.push("FOR IDENTITY"),t.join(" ")}CompositeTypeStmt(e,r){let t=["CREATE","TYPE"];if(e.typevar){let n=r.spawn("CompositeTypeStmt");t.push(this.RangeVar(e.typevar,n));}if(t.push("AS"),e.coldeflist&&e.coldeflist.length>0){let n=h.unwrapList(e.coldeflist).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}else t.push("()");return t.join(" ")}CreateRangeStmt(e,r){let t=["CREATE","TYPE"];if(e.typeName&&e.typeName.length>0){let n=h.unwrapList(e.typeName).map(i=>this.visit(i,r)).join(".");t.push(n);}if(t.push("AS","RANGE"),e.params&&e.params.length>0){let n=h.unwrapList(e.params).map(i=>{let a=this.getNodeData(i);if(a.defname&&a.arg){let o=this.visit(a.arg,r);return `${a.defname} = ${o}`}return this.visit(i,r)});t.push(`(${n.join(", ")})`);}return t.join(" ")}AlterEnumStmt(e,r){let t=["ALTER","TYPE"];if(e.typeName&&e.typeName.length>0){let n=h.unwrapList(e.typeName).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.oldVal&&e.newVal){let n=e.oldVal.replace(/'/g,"''"),i=e.newVal.replace(/'/g,"''");t.push("RENAME","VALUE",`'${n}'`,"TO",`'${i}'`);}else if(e.newVal){t.push("ADD","VALUE"),e.skipIfNewValExists&&t.push("IF NOT EXISTS");let n=e.newVal.replace(/'/g,"''");if(t.push(`'${n}'`),e.newValNeighbor){let i=e.newValNeighbor.replace(/'/g,"''");e.newValIsAfter?t.push("AFTER",`'${i}'`):t.push("BEFORE",`'${i}'`);}}return t.join(" ")}AlterTypeStmt(e,r){let t=["ALTER","TYPE"];if(e.typeName&&e.typeName.length>0){let n=h.unwrapList(e.typeName).map(i=>this.visit(i,r)).join(".");t.push(n);}if(t.push("SET"),e.options&&e.options.length>0){let n=h.unwrapList(e.options).map(i=>{let a=this.getNodeData(i);if(a.defname&&a.arg){let o=this.visit(a.arg,r);return `${a.defname} = ${o}`}return this.visit(i,r)});t.push(`(${n.join(", ")})`);}return t.join(" ")}AlterRoleStmt(e,r){let t=e.options&&h.unwrapList(e.options).some(i=>i.DefElem&&i.DefElem.defname==="rolemembers"),n=["ALTER",t?"GROUP":"ROLE"];if(e.role&&n.push(this.RoleSpec(e.role,r)),e.options){let i=r.spawn("AlterRoleStmt");if(t){let a=h.unwrapList(e.options).find(o=>o.DefElem&&o.DefElem.defname==="rolemembers");if(a&&a.DefElem){let o=e.action===1?"ADD":"DROP";if(n.push(o,"USER"),a.DefElem.arg&&a.DefElem.arg.List){let l=h.unwrapList(a.DefElem.arg.List.items).map(u=>this.visit(u,i)).join(", ");n.push(l);}}}else {let a=h.unwrapList(e.options).map(o=>this.visit(o,i)).join(" ");a&&n.push(a);}}return n.join(" ")}DropRoleStmt(e,r){let t=["DROP","ROLE"];if(e.missing_ok&&t.push("IF EXISTS"),e.roles){let n=h.unwrapList(e.roles).map(i=>this.visit(i,r)).join(", ");t.push(n);}return t.join(" ")}targetList(e,r){return !e||!Array.isArray(e)?"":e.map(t=>this.visit(t,r)).join(", ")}CreateAggregateStmt(e,r){let t=["CREATE"];if(e.replace&&t.push("OR REPLACE"),t.push("AGGREGATE"),e.defnames&&e.defnames.length>0){let i=h.unwrapList(e.defnames).map(a=>this.visit(a,r)).join(".");t.push(i);}if(t.push("("),e.args&&e.args.length>0){let i=h.unwrapList(e.args).map(a=>this.visit(a,r)).join(", ");t.push(i);}else t.push("*");t.push(")"),t.push("(");let n=[];if(e.definition&&e.definition.length>0){let i=h.unwrapList(e.definition).map(a=>{let o=this.getNodeData(a);return o.defname==="sfunc"||o.defname==="sfunc1"?`SFUNC = ${this.visit(o.arg,r)}`:o.defname==="stype"||o.defname==="stype1"?`STYPE = ${this.visit(o.arg,r)}`:o.defname==="basetype"?`BASETYPE = ${this.visit(o.arg,r)}`:o.defname==="finalfunc"?`FINALFUNC = ${this.visit(o.arg,r)}`:o.defname==="initcond"||o.defname==="initcond1"?`INITCOND = ${this.visit(o.arg,r)}`:o.defname==="combinefunc"?`COMBINEFUNC = ${this.visit(o.arg,r)}`:o.defname==="serialfunc"?`SERIALFUNC = ${this.visit(o.arg,r)}`:o.defname==="deserialfunc"?`DESERIALFUNC = ${this.visit(o.arg,r)}`:o.defname==="parallel"?`PARALLEL = ${this.visit(o.arg,r)}`:this.visit(a,r)});n.push(...i);}return t.push(n.join(", ")),t.push(")"),t.join(" ")}CreateTableAsStmt(e,r){let t=["CREATE"];if(e.objtype==="OBJECT_MATVIEW"?t.push("MATERIALIZED VIEW"):e.into&&e.into.rel&&e.into.rel.relpersistence==="t"?t.push("TEMPORARY TABLE"):t.push("TABLE"),e.if_not_exists&&t.push("IF NOT EXISTS"),e.into&&e.into.rel&&t.push(this.RangeVar(e.into.rel,r)),e.into&&e.into.colNames&&e.into.colNames.length>0){t.push("(");let n=h.unwrapList(e.into.colNames).map(i=>this.visit(i,r)).join(", ");t.push(n),t.push(")");}if(e.into&&e.into.accessMethod&&(t.push("USING"),t.push(e.into.accessMethod)),e.into&&e.into.onCommit&&e.into.onCommit!=="ONCOMMIT_NOOP")switch(t.push("ON COMMIT"),e.into.onCommit){case "ONCOMMIT_PRESERVE_ROWS":t.push("PRESERVE ROWS");break;case "ONCOMMIT_DELETE_ROWS":t.push("DELETE ROWS");break;case "ONCOMMIT_DROP":t.push("DROP");break}if(t.push("AS"),e.query&&t.push(this.visit(e.query,r)),e.into&&e.into.options&&e.into.options.length>0){t.push("WITH");let n=h.unwrapList(e.into.options).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}return e.into&&e.into.skipData&&t.push("WITH NO DATA"),t.join(" ")}RefreshMatViewStmt(e,r){let t=["REFRESH","MATERIALIZED","VIEW"];return e.concurrent&&t.push("CONCURRENTLY"),e.relation&&t.push(this.visit(e.relation,r)),e.skipData&&t.push("WITH NO DATA"),t.join(" ")}AccessPriv(e,r){let t=[];if(e.priv_name?t.push(e.priv_name.toUpperCase()):t.push("ALL"),e.cols&&e.cols.length>0){t.push("(");let n=r.spawn("AccessPriv"),i=h.unwrapList(e.cols).map(a=>this.visit(a,n));t.push(i.join(", ")),t.push(")");}return t.join(" ")}aliasname(e,r){return typeof e=="string"?S.quoteIdentifier(e):this.visit(e,r)}DefineStmt(e,r){let t=[];if(!e.kind)throw new Error("DefineStmt requires kind property");switch(e.kind){case "OBJECT_OPERATOR":if(t.push("CREATE OPERATOR"),e.defnames&&e.defnames.length>0){let n=h.unwrapList(e.defnames).map((i,a)=>{if(a===e.defnames.length-1){let o=this.getNodeData(i);if(o&&o.sval)return o.sval}return this.visit(i,r)});t.push(n.join("."));}if(e.definition&&e.definition.length>0){t.push("(");let n=h.unwrapList(e.definition).map(i=>{if(i.DefElem){let a=i.DefElem,o=a.defname,l=a.arg;if(o&&l){let u=S.quoteIdentifier(o),p=u!==o?u:this.preserveOperatorDefElemCase(o);if((o.toLowerCase()==="commutator"||o.toLowerCase()==="negator")&&l.List){let c=h.unwrapList(l.List.items);if(c.length===1&&c[0].String)return `${p} = ${c[0].String.sval}`}return o.toLowerCase()==="commutator"||o.toLowerCase()==="negator"?`${p} = ${this.visit(l,r)}`:`${p} = ${this.visit(l,r)}`}else if(o&&!l)return o==="Hashes"||o==="Merges"?S.quoteIdentifier(o):this.preserveOperatorDefElemCase(o).toUpperCase()}return this.visit(i,r)});t.push(n.join(", ")),t.push(")");}break;case "OBJECT_TYPE":if(t.push("CREATE TYPE"),e.defnames&&e.defnames.length>0&&t.push(h.unwrapList(e.defnames).map(n=>this.visit(n,r)).join(".")),e.definition&&e.definition.length>0){let n=r.spawn("DefineStmt"),i=h.unwrapList(e.definition).map(a=>this.visit(a,n));t.push(`(${i.join(", ")})`);}break;case "OBJECT_AGGREGATE":if(t.push("CREATE"),e.replace&&t.push("OR REPLACE"),t.push("AGGREGATE"),e.defnames&&e.defnames.length>0){let n=h.unwrapList(e.defnames).map(i=>this.visit(i,r));t.push(n.join("."));}if(e.args&&e.args.length>0){let n=h.unwrapList(e.args),i=n.some(l=>l.Integer&&l.Integer.ival===1),a=n.length>=2&&n[0].List&&n[0].List.items&&n[0].List.items.length===1&&n[0].List.items[0].FunctionParameter&&n[0].List.items[0].FunctionParameter.mode==="FUNC_PARAM_DEFAULT"&&n[1].Integer&&Object.keys(n[1].Integer).length===0,o=n.filter(l=>!(l.Integer&&(l.Integer.ival===-1||l.Integer.ival===1)||l.Integer&&Object.keys(l.Integer).length===0&&a));if(o.length>0)if(a){let l=o[0];if(l.List&&l.List.items&&l.List.items[0].FunctionParameter){let u=l.List.items[0].FunctionParameter,p;if(u.argType&&u.argType.names){let c=u.argType.names;c.length>=2&&c[0].String&&c[0].String.sval==="pg_catalog"?p=c[1].String.sval:c.length>=1&&c[0].String?p=c[0].String.sval:p="unknown";}else p=this.visit({TypeName:u.argType},r);t.push(`(ORDER BY ${p})`);}else {let u=this.visit(l,r);t.push(`(ORDER BY ${u})`);}}else if(i&&o.length===1&&o[0].List){let l=o[0].List;if(l.items&&l.items.length>=2){let u=h.unwrapList(l.items),p=this.visit(u[0],r),c=u.slice(1).map(f=>this.visit(f,r));t.push(`(${p} ORDER BY ${c.join(", ")})`);}else if(l.items&&l.items.length===1){let u=l.items[0];if(u.FunctionParameter&&u.FunctionParameter.mode==="FUNC_PARAM_VARIADIC"){let p=this.visit(u,r);t.push(`(${p} ORDER BY ${p})`);}else {let p=this.visit(u,r);t.push(`(${p})`);}}else {let u=o.map(p=>Object.keys(p).length===0?"*":this.visit(p,r));t.push(`(${u.join(", ")})`);}}else {let l=o.map(u=>Object.keys(u).length===0?"*":this.visit(u,r));t.push(`(${l.join(", ")})`);}}if(e.definition&&e.definition.length>0){let n=h.unwrapList(e.definition).map(i=>{if(i.DefElem){let a=i.DefElem,o=a.defname,l=a.arg;if(o&&l){let u=S.quoteIdentifier(o),p=u!==o?u:o;return l.String?`${p} = '${l.String.sval}'`:`${p} = ${this.visit(l,r)}`}}return this.visit(i,r)});t.push(`(${n.join(", ")})`);}break;case "OBJECT_TSDICTIONARY":if(t.push("CREATE TEXT SEARCH DICTIONARY"),e.defnames&&e.defnames.length>0&&t.push(h.unwrapList(e.defnames).map(n=>this.visit(n,r)).join(".")),e.definition&&e.definition.length>0){t.push("(");let n=h.unwrapList(e.definition).map(i=>{if(i.DefElem){let a=i.DefElem,o=a.defname,l=a.arg;if(o&&l)return `${o} = ${this.visit(l,r)}`}return this.visit(i,r)});t.push(n.join(", ")),t.push(")");}break;case "OBJECT_TSCONFIGURATION":if(t.push("CREATE TEXT SEARCH CONFIGURATION"),e.defnames&&e.defnames.length>0&&t.push(h.unwrapList(e.defnames).map(n=>this.visit(n,r)).join(".")),e.definition&&e.definition.length>0){t.push("(");let n=h.unwrapList(e.definition).map(i=>{if(i.DefElem){let a=i.DefElem,o=a.defname,l=a.arg;if(o&&l)return `${o} = ${this.visit(l,r)}`}return this.visit(i,r)});t.push(n.join(", ")),t.push(")");}break;case "OBJECT_TSPARSER":if(t.push("CREATE TEXT SEARCH PARSER"),e.defnames&&e.defnames.length>0){let n=h.unwrapList(e.defnames).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.definition&&e.definition.length>0){t.push("(");let n=h.unwrapList(e.definition).map(i=>{if(i.DefElem){let a=i.DefElem,o=a.defname,l=a.arg;if(o&&l)return `${o} = ${this.visit(l,r)}`}return this.visit(i,r)});t.push(n.join(", ")),t.push(")");}break;case "OBJECT_TSTEMPLATE":if(t.push("CREATE TEXT SEARCH TEMPLATE"),e.defnames&&e.defnames.length>0){let n=h.unwrapList(e.defnames).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.definition&&e.definition.length>0){t.push("(");let n=h.unwrapList(e.definition).map(i=>{if(i.DefElem){let a=i.DefElem,o=a.defname,l=a.arg;if(o&&l)return `${o} = ${this.visit(l,r)}`}return this.visit(i,r)});t.push(n.join(", ")),t.push(")");}break;case "OBJECT_COLLATION":if(t.push("CREATE COLLATION"),e.defnames&&e.defnames.length>0&&t.push(h.unwrapList(e.defnames).map(n=>this.visit(n,r)).join(".")),e.definition&&e.definition.length>0){let n=h.unwrapList(e.definition).map(a=>{if(a.DefElem){let o=a.DefElem,l=o.defname,u=o.arg;if(l&&u){if(l==="from")return `FROM ${this.visit(u,r)}`;let p;return u.String?p=`'${u.String.sval}'`:p=this.visit(u,r),`${l} = ${p}`}}return this.visit(a,r)});n.some(a=>a.startsWith("FROM "))?t.push(n.join(" ")):t.push(`(${n.join(", ")})`);}break;default:throw new Error(`Unsupported DefineStmt kind: ${e.kind}`)}return t.join(" ")}AlterDatabaseStmt(e,r){let t=["ALTER","DATABASE"];if(e.dbname&&t.push(S.quoteIdentifier(e.dbname)),e.options&&e.options.length>0){let n=h.unwrapList(e.options).map(i=>this.visit(i,r));t.push(n.join(" "));}return t.join(" ")}AlterDatabaseRefreshCollStmt(e,r){let t=["ALTER","DATABASE"];return e.dbname&&t.push(S.quoteIdentifier(e.dbname)),t.push("REFRESH","COLLATION","VERSION"),t.join(" ")}AlterDatabaseSetStmt(e,r){let t=["ALTER","DATABASE"];if(e.dbname&&t.push(S.quoteIdentifier(e.dbname)),e.setstmt){let n=this.VariableSetStmt(e.setstmt,r);t.push(n);}return t.join(" ")}DeclareCursorStmt(e,r){let t=["DECLARE"];e.portalname&&t.push(S.quoteIdentifier(e.portalname));let n=[];return e.options&&(e.options&2?n.push("SCROLL"):e.options&4&&n.push("NO SCROLL"),e.options&1&&n.push("BINARY"),e.options&8&&n.push("INSENSITIVE")),n.length>0&&t.push(...n),t.push("CURSOR"),e.options&&e.options&32&&t.push("WITH HOLD"),t.push("FOR"),e.query&&t.push(this.visit(e.query,r)),t.join(" ")}PublicationObjSpec(e,r){let t=[];return e.pubobjtype==="PUBLICATIONOBJ_TABLE"?(t.push("TABLE"),e.pubtable&&t.push(this.PublicationTable(e.pubtable,r))):e.pubobjtype==="PUBLICATIONOBJ_TABLES_IN_SCHEMA"?(t.push("TABLES IN SCHEMA"),e.name&&t.push(S.quoteIdentifier(e.name))):e.pubobjtype==="PUBLICATIONOBJ_TABLES_IN_CUR_SCHEMA"&&t.push("TABLES IN SCHEMA CURRENT_SCHEMA"),t.join(" ")}PublicationTable(e,r){let t=[];if(e.relation&&t.push(this.RangeVar(e.relation,r)),e.columns&&e.columns.length>0){let n=h.unwrapList(e.columns).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}return e.whereClause&&(t.push("WHERE"),t.push(this.visit(e.whereClause,r))),t.join(" ")}CreateAmStmt(e,r){let t=["CREATE","ACCESS","METHOD"];switch(e.amname&&t.push(S.quoteIdentifier(e.amname)),t.push("TYPE"),e.amtype){case "i":t.push("INDEX");break;case "t":t.push("TABLE");break;default:t.push(e.amtype||"");break}if(e.handler_name&&e.handler_name.length>0){t.push("HANDLER");let n=h.unwrapList(e.handler_name).map(i=>this.visit(i,r)).join(".");t.push(n);}return t.join(" ")}IntoClause(e,r){let t=[];if(e.rel&&t.push(this.RangeVar(e.rel,r)),e.colNames&&e.colNames.length>0){let n=h.unwrapList(e.colNames).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}if(e.accessMethod&&t.push("USING",e.accessMethod),e.options&&e.options.length>0){t.push("WITH");let n=h.unwrapList(e.options).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}if(e.onCommit&&e.onCommit!=="ONCOMMIT_NOOP")switch(t.push("ON COMMIT"),e.onCommit){case "ONCOMMIT_PRESERVE_ROWS":t.push("PRESERVE ROWS");break;case "ONCOMMIT_DELETE_ROWS":t.push("DELETE ROWS");break;case "ONCOMMIT_DROP":t.push("DROP");break}return e.tableSpaceName&&t.push("TABLESPACE",S.quoteIdentifier(e.tableSpaceName)),t.join(" ")}OnConflictExpr(e,r){let t=["ON CONFLICT"];if(e.arbiterElems&&e.arbiterElems.length>0){let n=h.unwrapList(e.arbiterElems).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}if(e.arbiterWhere&&(t.push("WHERE"),t.push(this.visit(e.arbiterWhere,r))),e.action==="ONCONFLICT_NOTHING")t.push("DO NOTHING");else if(e.action==="ONCONFLICT_UPDATE"){if(t.push("DO UPDATE SET"),e.onConflictSet&&e.onConflictSet.length>0){let n=h.unwrapList(e.onConflictSet).map(i=>this.visit(i,r)).join(", ");t.push(n);}e.onConflictWhere&&(t.push("WHERE"),t.push(this.visit(e.onConflictWhere,r)));}return t.join(" ")}ScanToken(e,r){return ""}CreateOpClassItem(e,r){let t=[];if(e.itemtype===1){t.push("OPERATOR");let n=e.number!==void 0?e.number:0;if(t.push(n.toString()),e.name){let i=r.spawn("CreateOpClassItem");t.push(this.ObjectWithArgs(e.name,i));}}else if(e.itemtype===2){t.push("FUNCTION");let n=e.number!==void 0?e.number:0;if(t.push(n.toString()),e.name){let i=r.spawn("CreateOpClassItem");t.push(this.ObjectWithArgs(e.name,i));}}else e.itemtype===3&&(t.push("STORAGE"),e.storedtype&&t.push(this.TypeName(e.storedtype,r)));if(e.order_family&&e.order_family.length>0){t.push("FOR ORDER BY");let n=h.unwrapList(e.order_family).map(i=>this.visit(i,r)).join(".");t.push(n);}if(e.class_args&&e.class_args.length>0){let n=h.unwrapList(e.class_args).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}return t.join(" ")}Var(e,r){return e.varno&&e.varattno?`$${e.varno}.${e.varattno}`:"$var"}TableFunc(e,r){let t=[];if(e.functype==="TFT_XMLTABLE"){if(t.push("XMLTABLE"),e.ns_names&&e.ns_names.length>0){t.push("XMLNAMESPACES");let n=h.unwrapList(e.ns_names).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}if(e.rowexpr&&t.push(`(${this.visit(e.rowexpr,r)})`),e.docexpr&&(t.push("PASSING"),t.push(this.visit(e.docexpr,r))),e.colexprs&&e.colexprs.length>0){t.push("COLUMNS");let n=h.unwrapList(e.colexprs).map(i=>this.visit(i,r)).join(", ");t.push(n);}}else if(e.functype==="TFT_JSON_TABLE"&&(t.push("JSON_TABLE"),e.docexpr&&t.push(`(${this.visit(e.docexpr,r)})`),e.rowexpr&&(t.push(","),t.push(`'${this.visit(e.rowexpr,r)}'`)),e.colexprs&&e.colexprs.length>0)){t.push("COLUMNS");let n=h.unwrapList(e.colexprs).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}return t.join(" ")}RangeTableFunc(e,r){let t=[];if(e.lateral&&t.push("LATERAL"),e.docexpr&&t.push(this.visit(e.docexpr,r)),e.rowexpr&&(t.push("PASSING"),t.push(this.visit(e.rowexpr,r))),e.columns&&e.columns.length>0){t.push("COLUMNS");let n=h.unwrapList(e.columns).map(i=>this.visit(i,r)).join(", ");t.push(`(${n})`);}return e.alias&&t.push(this.Alias(e.alias,r)),t.join(" ")}RangeTableFuncCol(e,r){let t=[];return e.colname&&t.push(S.quoteIdentifier(e.colname)),e.for_ordinality?t.push("FOR ORDINALITY"):e.typeName&&t.push(this.TypeName(e.typeName,r)),e.colexpr&&(t.push("PATH"),t.push(`'${this.visit(e.colexpr,r)}'`)),e.coldefexpr&&(t.push("DEFAULT"),t.push(this.visit(e.coldefexpr,r))),t.join(" ")}JsonArrayQueryConstructor(e,r){let t=["JSON_ARRAYAGG"];return e.query&&t.push(`(${this.visit(e.query,r)})`),e.format&&t.push("FORMAT JSON"),e.output&&t.push("RETURNING TEXT"),e.absent_on_null?t.push("ABSENT ON NULL"):t.push("NULL ON NULL"),t.join(" ")}RangeFunction(e,r){let t=[];if(e.lateral&&t.push("LATERAL"),e.is_rowsfrom){if(t.push("ROWS FROM"),e.functions&&e.functions.length>0){let n=h.unwrapList(e.functions).filter(i=>i!=null).map(i=>{try{if(this.getNodeType(i)==="List"){let o=this.getNodeData(i);if(o&&o.items&&Array.isArray(o.items)){let l=o.items;if(l.length>=2){let u=this.visit(l[0],r),p=this.getNodeData(l[1]);if(p&&p.items&&Array.isArray(p.items)){let c=p.items.map(f=>this.visit(f,r)).filter(f=>f&&f.trim());if(c.length>0)return `${u} AS (${c.join(", ")})`}return u}else if(l.length===1)return this.visit(l[0],r)}}return this.visit(i,r)}catch(a){return console.warn(`Error processing function in RangeFunction: ${a instanceof Error?a.message:String(a)}`),""}}).filter(i=>i&&i.trim());n.length>0&&t.push(`(${n.join(", ")})`);}}else if(e.functions&&e.functions.length>0){let n=h.unwrapList(e.functions).filter(i=>i!=null).map(i=>{try{if(this.getNodeType(i)==="List"){let o=this.getNodeData(i);if(o&&o.items&&Array.isArray(o.items)){let l=o.items;if(l.length>=1)return this.visit(l[0],r)}}return this.visit(i,r)}catch(a){return console.warn(`Error processing function in RangeFunction: ${a instanceof Error?a.message:String(a)}`),""}}).filter(i=>i&&i.trim());n.length>0&&t.push(n.join(", "));}if(e.ordinality&&t.push("WITH ORDINALITY"),e.alias)if(e.coldeflist&&e.coldeflist.length>0){let n=e.alias.aliasname,i=h.unwrapList(e.coldeflist).map(a=>this.visit(a,r)).filter(a=>a&&a.trim());t.push(`${n} (${i.join(", ")})`);}else t.push(this.Alias(e.alias,r));else if(e.coldeflist&&e.coldeflist.length>0){let n=h.unwrapList(e.coldeflist).map(i=>this.visit(i,r)).filter(i=>i&&i.trim());t.push(`AS (${n.join(", ")})`);}return t.join(" ")}XmlExpr(e,r){if(e.op==="IS_XMLPI")if(e.name&&e.args&&e.args.length>0){let n=h.unwrapList(e.args).map(i=>this.visit(i,r));return `xmlpi(name ${S.quoteIdentifier(e.name)}, ${n.join(", ")})`}else return e.name?`xmlpi(name ${S.quoteIdentifier(e.name)})`:"XMLPI()";let t=[];switch(e.op){case "IS_XMLCONCAT":t.push("XMLCONCAT");break;case "IS_XMLELEMENT":t.push("XMLELEMENT");let n=[];if(e.name&&n.push(`NAME ${S.quoteIdentifier(e.name)}`),e.named_args&&e.named_args.length>0){let a=h.unwrapList(e.named_args).map(o=>this.visit(o,r));n.push(`XMLATTRIBUTES(${a.join(", ")})`);}if(e.args&&e.args.length>0){let a=h.unwrapList(e.args).map(o=>this.visit(o,r));n.push(...a);}n.length>0&&t.push(`(${n.join(", ")})`);break;case "IS_XMLFOREST":t.push("XMLFOREST");break;case "IS_XMLPARSE":t.push("XMLPARSE");let i=[];if(e.xmloption&&(e.xmloption==="XMLOPTION_DOCUMENT"?i.push("DOCUMENT"):e.xmloption==="XMLOPTION_CONTENT"&&i.push("CONTENT")),e.args&&e.args.length>0){let a=h.unwrapList(e.args).map(o=>this.visit(o,r));a.length>0&&i.push(a[0]);}i.length>0&&t.push(`(${i.join(" ")})`);break;case "IS_XMLROOT":if(t.push("XMLROOT"),e.args&&e.args.length>0){let a=h.unwrapList(e.args),o=[];if(a[0]&&o.push(this.visit(a[0],r)),a[1]){let l=a[1];l.A_Const&&l.A_Const.isnull?o.push("version NO VALUE"):o.push(`version ${this.visit(l,r)}`);}if(a[2]){let l=a[2];l.A_Const&&l.A_Const.ival!==void 0?l.A_Const.ival.ival===1?o.push("STANDALONE NO"):l.A_Const.ival.ival===2?o.push("STANDALONE NO VALUE"):l.A_Const.ival.ival===3||(Object.keys(l.A_Const.ival).length===0?o.push("STANDALONE YES"):o.push(`STANDALONE ${this.visit(l,r)}`)):o.push(`STANDALONE ${this.visit(l,r)}`);}o.length>0&&t.push(`(${o.join(", ")})`);}break;case "IS_XMLSERIALIZE":t.push("XMLSERIALIZE");break;case "IS_DOCUMENT":if(e.args&&e.args.length>0){let a=h.unwrapList(e.args).map(o=>this.visit(o,r));t.push(`${a[0]} IS DOCUMENT`);}else t.push("IS DOCUMENT");break;default:throw new Error(`Unsupported XmlExpr op: ${e.op}`)}if(e.op!=="IS_XMLELEMENT"&&e.op!=="IS_XMLPARSE"&&e.op!=="IS_XMLROOT"&&e.op!=="IS_DOCUMENT"){if(e.name){let n=S.quoteIdentifier(e.name);t.push(`NAME ${n}`);}if(e.args&&e.args.length>0){let n=h.unwrapList(e.args).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}}if(e.named_args&&e.named_args.length>0&&e.op!=="IS_XMLELEMENT"){let n=h.unwrapList(e.named_args).map(i=>this.visit(i,r));e.op==="IS_XMLFOREST"?t.push(`(${n.join(", ")})`):t.push(`XMLATTRIBUTES(${n.join(", ")})`);}return t.join(" ")}schemaname(e,r){if(typeof e=="string")return S.quoteIdentifier(e);if(e&&e.String&&e.String.sval)return S.quoteIdentifier(e.String.sval);if(e&&typeof e=="object"){if(e.sval!==void 0)return S.quoteIdentifier(e.sval);if(e.List&&Array.isArray(e.List.items)){let t=e.List.items;if(t.length>0&&t[0].String&&t[0].String.sval)return S.quoteIdentifier(t[0].String.sval)}return e.val!==void 0?S.quoteIdentifier(e.val):""}return ""}RangeTableSample(e,r){let t=[];if(e.relation&&t.push(this.visit(e.relation,r)),t.push("TABLESAMPLE"),e.method&&e.method.length>0){let n=e.method.map(i=>this.visit(i,r));t.push(n.join("."));}if(e.args&&e.args.length>0){let n=e.args.map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}return e.repeatable&&(t.push("REPEATABLE"),t.push(`(${this.visit(e.repeatable,r)})`)),t.join(" ")}XmlSerialize(e,r){let t=["XMLSERIALIZE"];return t.push("("),e.typeName&&(e.xmloption==="XMLOPTION_DOCUMENT"?t.push("DOCUMENT"):t.push("CONTENT"),t.push(this.visit(e.expr,r)),t.push("AS"),t.push(this.TypeName(e.typeName,r))),t.push(")"),t.join(" ")}ctes(e,r){if(!e||!Array.isArray(e))return "";let t=["WITH"];e.length>0&&e[0]&&e[0].CommonTableExpr&&e[0].CommonTableExpr.recursive&&t.push("RECURSIVE");let n=e.map(i=>this.visit(i,r));return t.push(n.join(", ")),t.join(" ")}RuleStmt(e,r){let t=["CREATE"];if(e.replace&&t.push("OR REPLACE"),t.push("RULE"),e.rulename&&t.push(S.quoteIdentifier(e.rulename)),t.push("AS ON"),e.event)switch(e.event){case "CMD_SELECT":t.push("SELECT");break;case "CMD_INSERT":t.push("INSERT");break;case "CMD_UPDATE":t.push("UPDATE");break;case "CMD_DELETE":t.push("DELETE");break;default:t.push(e.event.toString());}if(t.push("TO"),e.relation&&t.push(this.RangeVar(e.relation,r)),e.whereClause&&(t.push("WHERE"),t.push(this.visit(e.whereClause,r))),t.push("DO"),e.instead&&t.push("INSTEAD"),e.actions&&e.actions.length>0)if(e.actions.length===1)t.push(this.visit(e.actions[0],r));else {t.push("(");let n=h.unwrapList(e.actions).map(i=>this.visit(i,r));t.push(n.join("; ")),t.push(")");}else t.push("NOTHING");return t.join(" ")}RangeSubselect(e,r){let t=[];return e.lateral&&t.push("LATERAL"),e.subquery&&(t.push("("),t.push(this.visit(e.subquery,r)),t.push(")")),e.alias&&t.push(this.Alias(e.alias,r)),t.join(" ")}relname(e,r){return typeof e=="string"?S.quoteIdentifier(e):e&&e.String&&e.String.sval?S.quoteIdentifier(e.String.sval):e&&typeof e=="object"&&e.relname?S.quoteIdentifier(e.relname):this.visit(e,r)}rel(e,r){return typeof e=="string"?S.quoteIdentifier(e):e&&e.String&&e.String.sval?S.quoteIdentifier(e.String.sval):e&&e.RangeVar?this.RangeVar(e.RangeVar,r):e&&typeof e=="object"&&e.relname?S.quoteIdentifier(e.relname):this.visit(e,r)}objname(e,r){return typeof e=="string"?S.quoteIdentifier(e):e&&e.String&&e.String.sval?S.quoteIdentifier(e.String.sval):Array.isArray(e)?e.map(n=>n&&n.String&&n.String.sval?S.quoteIdentifier(n.String.sval):this.visit(n,r)).join("."):this.visit(e,r)}SQLValueFunction(e,r){switch(e.op){case "SVFOP_CURRENT_DATE":return "CURRENT_DATE";case "SVFOP_CURRENT_TIME":return "CURRENT_TIME";case "SVFOP_CURRENT_TIME_N":return `CURRENT_TIME(${e.typmod||0})`;case "SVFOP_CURRENT_TIMESTAMP":return "CURRENT_TIMESTAMP";case "SVFOP_CURRENT_TIMESTAMP_N":return `CURRENT_TIMESTAMP(${e.typmod||0})`;case "SVFOP_LOCALTIME":return "LOCALTIME";case "SVFOP_LOCALTIME_N":return `LOCALTIME(${e.typmod||0})`;case "SVFOP_LOCALTIMESTAMP":return "LOCALTIMESTAMP";case "SVFOP_LOCALTIMESTAMP_N":return `LOCALTIMESTAMP(${e.typmod||0})`;case "SVFOP_CURRENT_ROLE":return "CURRENT_ROLE";case "SVFOP_CURRENT_USER":return "CURRENT_USER";case "SVFOP_USER":return "USER";case "SVFOP_SESSION_USER":return "SESSION_USER";case "SVFOP_CURRENT_CATALOG":return "CURRENT_CATALOG";case "SVFOP_CURRENT_SCHEMA":return "CURRENT_SCHEMA";default:throw new Error(`Unsupported SQLValueFunction op: ${e.op}`)}}GroupingFunc(e,r){let t=["GROUPING"];if(e.args&&e.args.length>0){let n=h.unwrapList(e.args).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}else t.push("()");return t.join("")}MultiAssignRef(e,r){let t=[];return e.source&&t.push(this.visit(e.source,r)),e.colno>0&&t.push(`[${e.colno}]`),t.join("")}SetToDefault(e,r){return "DEFAULT"}CurrentOfExpr(e,r){let t=["CURRENT OF"];return e.cursor_name&&t.push(S.quoteIdentifier(e.cursor_name)),e.cursor_param>0&&t.push(`$${e.cursor_param}`),t.join(" ")}TableLikeClause(e,r){let t=["LIKE"];if(e.relation&&t.push(this.visit(e.relation,r)),e.options&&typeof e.options=="number")if(e.options===2147483647||e.options===2147483647)t.push("INCLUDING ALL");else {let n=[];e.options&1&&n.push("INCLUDING COMMENTS"),e.options&4&&n.push("INCLUDING CONSTRAINTS"),e.options&8&&n.push("INCLUDING DEFAULTS"),e.options&16&&n.push("INCLUDING GENERATED"),e.options&32&&n.push("INCLUDING IDENTITY"),e.options&64&&n.push("INCLUDING INDEXES"),e.options&128&&n.push("INCLUDING STATISTICS"),e.options&256&&n.push("INCLUDING STORAGE"),n.length>0&&t.push(n.join(" "));}return t.join(" ")}AlterFunctionStmt(e,r){let t=["ALTER"];if(e.objtype==="OBJECT_PROCEDURE"?t.push("PROCEDURE"):t.push("FUNCTION"),e.func&&t.push(this.ObjectWithArgs(e.func,r)),e.actions&&e.actions.length>0){let n=r.spawn("AlterFunctionStmt"),i=h.unwrapList(e.actions).map(a=>this.visit(a,n));t.push(i.join(" "));}return t.join(" ")}AlterObjectSchemaStmt(e,r){let t=["ALTER"];try{t.push(this.getObjectTypeKeyword(e.objectType));}catch{t.push(e.objectType.toString());}if(e.missing_ok&&t.push("IF EXISTS"),e.relation&&(e.objectType==="OBJECT_TABLE"||e.objectType==="OBJECT_FOREIGN_TABLE"||e.objectType==="OBJECT_MATVIEW"))t.push(this.RangeVar(e.relation,r));else if(e.object)if(e.objectType==="OBJECT_DOMAIN"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(S.quoteQualifiedIdentifier(i,a));}else t.push(this.visit(e.object,r));}else if(e.objectType==="OBJECT_TYPE"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(S.quoteQualifiedIdentifier(i,a));}else t.push(this.visit(e.object,r));}else if(e.objectType==="OBJECT_CONVERSION"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(S.quoteQualifiedIdentifier(i,a));}else t.push(this.visit(e.object,r));}else if(e.objectType==="OBJECT_TSPARSER"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(S.quoteQualifiedIdentifier(i,a));}else t.push(this.visit(e.object,r));}else if(e.objectType==="OBJECT_TSCONFIGURATION"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(S.quoteQualifiedIdentifier(i,a));}else t.push(this.visit(e.object,r));}else if(e.objectType==="OBJECT_TSTEMPLATE"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(S.quoteQualifiedIdentifier(i,a));}else t.push(this.visit(e.object,r));}else if(e.objectType==="OBJECT_TSDICTIONARY"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(S.quoteQualifiedIdentifier(i,a));}else t.push(this.visit(e.object,r));}else if(e.objectType==="OBJECT_OPCLASS"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(`${S.quoteIdentifier(a)} USING ${i}`);}else if(n.length===3){let i=n[0].String?.sval||"",a=n[1].String?.sval||"",o=n[2].String?.sval||"";t.push(`${S.quoteQualifiedIdentifier(a,o)} USING ${i}`);}else t.push(this.visit(e.object,r));}else if(e.objectType==="OBJECT_OPFAMILY"&&e.object.List){let n=h.unwrapList(e.object);if(n.length===2){let i=n[0].String?.sval||"",a=n[1].String?.sval||"";t.push(`${S.quoteIdentifier(a)} USING ${i}`);}else if(n.length===3){let i=n[0].String?.sval||"",a=n[1].String?.sval||"",o=n[2].String?.sval||"";t.push(`${S.quoteQualifiedIdentifier(a,o)} USING ${i}`);}else t.push(this.visit(e.object,r));}else t.push(this.visit(e.object,r));return t.push("SET SCHEMA"),e.newschema&&t.push(S.quoteIdentifier(e.newschema)),t.join(" ")}AlterRoleSetStmt(e,r){let t=["ALTER","ROLE"];if(e.role?t.push(this.RoleSpec(e.role,r)):t.push("ALL"),e.database&&(t.push("IN DATABASE"),t.push(this.quoteIfNeeded(e.database))),e.setstmt){if(e.setstmt.kind==="VAR_RESET")t.push("RESET"),e.setstmt.name&&t.push(e.setstmt.name);else if(t.push("SET"),e.setstmt.name&&t.push(e.setstmt.name),e.setstmt.args&&e.setstmt.args.length>0){t.push("TO");let n=h.unwrapList(e.setstmt.args).map(i=>this.visit(i,r)).join(", ");t.push(n);}}return t.join(" ")}CreateForeignTableStmt(e,r){let t=["CREATE FOREIGN TABLE"];if(e.base&&e.base.relation){let n=r.spawn("CreateForeignTableStmt");t.push(this.RangeVar(e.base.relation,n));}if(e.base&&e.base.tableElts){let n=h.unwrapList(e.base.tableElts).map(i=>this.visit(i,r));t.push(`(${n.join(", ")})`);}else e.base?.partbound||t.push("()");if(e.base&&e.base.inhRelations&&e.base.inhRelations.length>0)if(e.base.partbound){let n=h.unwrapList(e.base.inhRelations).map(i=>this.visit(i,r));t.push(`PARTITION OF ${n.join(", ")}`),e.base.partbound.is_default&&t.push("DEFAULT");}else {let n=h.unwrapList(e.base.inhRelations).map(i=>this.visit(i,r));t.push(`INHERITS (${n.join(", ")})`);}if(e.servername&&(t.push("SERVER"),t.push(S.quoteIdentifier(e.servername))),e.options&&e.options.length>0){let n=r.spawn("CreateForeignTableStmt"),i=h.unwrapList(e.options).map(a=>this.visit(a,n));t.push(`OPTIONS (${i.join(", ")})`);}return t.join(" ")}containsMultilineStringLiteral(e){return /'[^']*\n[^']*'/g.test(e)}};function Sn(s){if("String"in s)return s.String.sval}function Rr(s){return s.map(Sn).filter(e=>e!=null)}function _r(s){return s==null?[]:s.List!==void 0?s.List.items||[]:Array.isArray(s)?s:[s]}function Ta(s){return S.quoteIdentifier(s)}function is(s){return Object.keys(s)[0]}function fh(s){if("A_Const"in s){if(s.A_Const.ival)return s.A_Const.ival.ival;if(s.A_Const.fval)return s.A_Const.fval.fval;if(s.A_Const.sval)return s.A_Const.sval.sval;if(s.A_Const.boolval)return s.A_Const.boolval.boolval;if(s.A_Const.isnull)return null}}var vr=class extends Error{},P=class extends vr{constructor(r,t){super(t??`Unsupported node type: ${is(r)}`);this.node=r;}},Bb={int2:"INTEGER",smallint:"INTEGER",int4:"INTEGER",integer:"INTEGER",int:"INTEGER",int8:"INTEGER",bigint:"INTEGER",serial:"INTEGER",serial4:"INTEGER",bigserial:"INTEGER",serial8:"INTEGER",smallserial:"INTEGER",serial2:"INTEGER",float4:"REAL",real:"REAL",float8:"REAL","double precision":"REAL",numeric:"REAL",decimal:"REAL",text:"TEXT",varchar:"TEXT","character varying":"TEXT",char:"TEXT",character:"TEXT",bpchar:"TEXT",name:"TEXT",bytea:"BLOB",bool:"INTEGER",boolean:"INTEGER",date:"TEXT",time:"TEXT","time without time zone":"TEXT",timetz:"TEXT","time with time zone":"TEXT",timestamp:"TEXT","timestamp without time zone":"TEXT",timestamptz:"TEXT","timestamp with time zone":"TEXT",interval:"TEXT",json:"TEXT",jsonb:"TEXT",uuid:"TEXT",inet:"TEXT"},mh=["<",">","<=",">=","=","<>","!=","+","-","*","/","%","&","|","<<",">>","||","BETWEEN","NOT BETWEEN","IN","NOT IN","LIKE","NOT LIKE","IS NULL","IS NOT NULL","IS TRUE","IS NOT TRUE","IS FALSE","IS NOT FALSE","IS UNKNOWN","IS NOT UNKNOWN","AND","OR","NOT","->>"];function hh(s){let e=s.toLowerCase().trim();if(e.startsWith("_")||e.endsWith("[]"))return "TEXT";let r=Bb[e];if(!r)throw new vr(`Unsupported PostgreSQL type: "${s}"`);return r}function wa(s){let e=s.toLowerCase();return ["serial","serial4","bigserial","serial8","smallserial","serial2"].includes(e)}function Ca(s){let e=s.toLowerCase();return ["varchar","character varying","char","character","bpchar"].includes(e)}function Aa(s){let e=s.toLowerCase();return ["numeric","decimal"].includes(e)}var Mb={CreateEnumStmt:{react:"ignore"},CreateDomainStmt:{react:"warn"},CreateSeqStmt:{react:"error"},AlterSeqStmt:{react:"error"},CreateSchemaStmt:{react:"warn"},CreatePolicyStmt:{react:"ignore"},PartitionElem:{react:"error"},PartitionCmd:{react:"error"},VariableSetStmt:{react:"ignore"},CompositeTypeStmt:{react:"error"},AlterEnumStmt:{react:"error"},AlterObjectSchemaStmt:{react:"error"},AlterOwnerStmt:{react:"error"},AlterTypeStmt:{react:"error"},AlterFunctionStmt:{react:"error"},AlterDefaultPrivilegesStmt:{react:"error"},GrantStmt:{react:"error"},GrantRoleStmt:{react:"error"},CopyStmt:{react:"error"},CreateCastStmt:{react:"error"},AlterOpFamilyStmt:{react:"error"},AlterOperatorStmt:{react:"error"},TruncateStmt:{react:"error"},A_Indirection:{react:"error"},XmlExpr:{react:"error"},XmlSerialize:{react:"error"},RangeTableSample:{react:"error"},GroupingSet:{react:"error"}},Ra=new Map(Object.entries(Mb));var Th=qn(dh());var wh=qn(Su());var va=class{constructor(e){this.ast=e;this.result=[...this.walk(this.ast,[],{trackPaths:["returningList"]})];}result=[];*walk(e=this.ast,r=[],t={}){if(!e||typeof e!="object")return;let{trackPaths:n=[]}=t;if(Array.isArray(e)){for(let a=0;a<e.length;a++)yield*this.walk(e[a],r,t);return}let i=Object.keys(e);if(i.length===1&&i[0][0]>="A"&&i[0][0]<="Z"){let a=i[0];yield {node:e,path:r},yield*this.walk(e[a],[...r,a],t);}else for(let[a,o]of Object.entries(e))if(o&&typeof o=="object"){let l=n.includes(a)?[...r,a]:r;yield*this.walk(o,l,t);}}containsUnsupportedNode(){for(let{node:e}of this.result){let r=is(e),t=Ra.get(r);if(t&&t.react==="error")return true}}hasFuncCall(){for(let{node:e}of this.result)if("FuncCall"in e)return true;return false}getFuncCalls(){return Array.from(this.result).map(({node:e})=>e).filter(e=>"FuncCall"in e).map(e=>e.FuncCall)}getFuncCallNames(){return this.getFuncCalls().flatMap(e=>e.funcname?.map(r=>r.String?.sval||r.String?.str))}hasSqlValueFunction(){for(let{node:e}of this.result)if("SQLValueFunction"in e)return true;return false}getSqlValueFunctions(){return Array.from(this.result).map(({node:e})=>e).filter(e=>"SQLValueFunction"in e).map(e=>e.SQLValueFunction)}getSqlValueFunctionNames(){return this.getSqlValueFunctions().map(e=>e.op)}hasUnsafeStar(){let e=this.result.filter(({node:r})=>"A_Star"in r);if(e.length===0)return false;for(let{path:r}of e)if(!r.includes("SelectStmt")&&!r.includes("returningList"))return true;return false}getRelationDefinitions(){return this.result.filter(({node:r})=>"CreateStmt"in r).map(({node:r})=>r.CreateStmt).map(r=>({relation:{relname:r.relation?.relname??"",inh:r.relation?.inh,relpersistence:r.relation?.relpersistence},columns:r.tableElts?.map(t=>{let n=t.ColumnDef?.typeName?.names?.map(a=>"String"in a?a.String.sval:""),i=n?.some(a=>a.toLowerCase().includes("pg_catalog"));return {name:t.ColumnDef?.colname??"",is_local:t.ColumnDef?.is_local,pg_catalog:i,type:n?.filter(a=>!a.toLowerCase().includes("pg_catalog"))[0]??"",types:n,constraints:t.ColumnDef?.constraints}})}))}getRelationColumnTypes(){return {has_non_pg_catalog_types:this.getRelationDefinitions().some(e=>e.columns?.some(r=>!r.pg_catalog)),types:Array.from(new Set(this.getRelationDefinitions().flatMap(e=>e.columns?.map(r=>r.type))))}}};var qb=["DECLARE","IF","ELSIF","ELSE","LOOP","WHILE","FOR","FOREACH","EXCEPTION","RAISE","PERFORM","EXECUTE","SELECT"],Jb=/^NEW\.(\w+)\s*(?::=|=)\s*(.+)$/is,Wb=/^RETURN\s+(NEW|OLD)$/i,Hb=/^(INSERT|UPDATE|DELETE)\b/i,os=class extends vr{constructor(r,t,n){super(n??`Unsupported PL/pgSQL: ${r}`);this.hint=r;this.body=t;}},Oa=class{parse(e){let r=this.extractBlock(e),t=this.splitStatements(r),n=[],i=null;for(let a of t){let o=a.trim();if(!o)continue;this.rejectUnsupported(o);let l=o.match(Wb);if(l){i=l[1].toUpperCase(),n.push({type:"return",value:i});continue}let u=o.match(Jb);if(u){n.push({type:"assignment",column:u[1],expression:u[2].trim()});continue}if(Hb.test(o)){n.push({type:"dml",sql:o});continue}throw new os(`"${o.substring(0,80)}" is not translatable to SQLite`,r)}if(!i)throw new vr("Trigger function body must end with RETURN NEW or RETURN OLD");return {statements:n,returnValue:i}}extractBlock(e){let r=e.trim(),t=r.toUpperCase();if(/^\s*DECLARE\b/i.test(r))throw new os('"DECLARE" is not translatable to SQLite',e);let n=t.indexOf("BEGIN"),i=t.lastIndexOf("END");if(n===-1||i===-1||i<=n)throw new os("Expected BEGIN ... END block in trigger function body",e);return r.slice(n+5,i).trim()}splitStatements(e){let r=[],t="",n=0,i=false,a="";for(let l=0;l<e.length;l++){let u=e[l];if(i){t+=u,u===a&&(l+1<e.length&&e[l+1]===a?t+=e[++l]:i=false);continue}if(u==="'"||u==='"'){i=true,a=u,t+=u;continue}if(u==="("){n++,t+=u;continue}if(u===")"){n--,t+=u;continue}if(u===";"&&n===0){r.push(t.trim()),t="";continue}t+=u;}let o=t.trim();return o&&r.push(o),r}rejectUnsupported(e){let r=e.match(/^(\w+)/)?.[1]?.toUpperCase();if(r&&qb.includes(r))throw new os(`"${r}" is not translatable to SQLite`,e)}};var Na=class{makeIndexKey(e){return `${e.table}:${e.name}:${e.unique}:${e.columns.join(",")}`}makeForeignKeyKey(e){return `${e.table}:${e.column}:${e.ref_table}:${e.ref_column}`}diff(e,r){let t=[],n=[],i=[],a=[],o=new Set(e.tables.map(g=>g.name)),l=new Set(r.tables.map(g=>g.name));for(let g of r.tables)o.has(g.name)||t.push({type:"added",name:g.name,sql:g.sql});for(let g of e.tables)l.has(g.name)||t.push({type:"removed",name:g.name});for(let g of e.tables){let b=r.tables.find(C=>C.name===g.name);if(!b)continue;let y=Wo(g.sql),T=Wo(b.sql);y!==T&&t.push({type:"modified",name:g.name,sql:b.sql});}let u=e.tables.filter(g=>l.has(g.name));for(let g of u){let b=e.columns.filter(w=>w.table===g.name),y=r.columns.filter(w=>w.table===g.name),T=new Map(b.map(w=>[w.name,w])),C=new Map(y.map(w=>[w.name,w]));for(let[w,A]of C)T.has(w)||n.push({type:"added",table:g.name,name:w,column:A});for(let[w]of T)C.has(w)||n.push({type:"removed",table:g.name,name:w});for(let[w,A]of T){let v=C.get(w);if(!v)continue;let R={};Jo(A.type)!==Jo(v.type)&&(R.type={from:A.type,to:v.type}),A.nullable!==v.nullable&&(R.nullable={from:A.nullable,to:v.nullable}),Ho(A.default_value)!==Ho(v.default_value)&&(R.default_value={from:A.default_value,to:v.default_value}),Object.keys(R).length>0&&n.push({type:"modified",table:g.name,name:w,changes:R});}}let p=new Map(e.indexes.map(g=>[this.makeIndexKey(g),g])),c=new Map(r.indexes.map(g=>[this.makeIndexKey(g),g]));for(let[g,b]of c)p.has(g)||i.push({type:"added",...b});for(let[g,b]of p)c.has(g)||i.push({type:"removed",...b});let f=new Map(e.foreign_keys.map(g=>[this.makeForeignKeyKey(g),g])),m=new Map(r.foreign_keys.map(g=>[this.makeForeignKeyKey(g),g]));for(let[g,b]of m)f.has(g)||a.push({type:"added",...b});for(let[g,b]of f)m.has(g)||a.push({type:"removed",...b});let d=t.length>0||n.length>0||i.length>0||a.length>0;return {tables:t,columns:n,indexes:i,foreign_keys:a,has_changes:d}}};var Gb=["CURRENT_TIMESTAMP","CURRENT_TIME","CURRENT_DATE"],Ia=class{plan(e,r,t,n){if(!e.has_changes)return {steps:[],warnings:[],unsafe:false};let i=[],a=[];i.push({sql:"PRAGMA foreign_keys=OFF;",description:"Disable foreign key checks",type:"disable_foreign_keys"}),i.push({sql:"BEGIN;",description:"Begin transaction",type:"begin_transaction"});for(let c of e.tables.filter(f=>f.type==="added")){i.push({sql:`${c.sql};`,description:`CREATE TABLE ${$(c.name)}`,type:"create_table"});let f=t.indexes.filter(m=>m.table===c.name);for(let m of f){let d=m.unique?"UNIQUE ":"",g=m.columns.map(b=>$(b)).join(", ");i.push({sql:`CREATE ${d}INDEX ${$(m.name)} ON ${$(c.name)} (${g});`,description:`Create index ${$(m.name)} on ${$(c.name)}`,type:"add_index"});}}let o=new Set(r.tables.map(c=>c.name)),l=new Set(t.tables.map(c=>c.name)),u=new Set(e.tables.filter(c=>c.type==="modified").map(c=>c.name)),p=[...o].filter(c=>l.has(c));for(let c of p){if(!(u.has(c)||e.columns.some(g=>g.table===c)||e.indexes.some(g=>g.table===c)||e.foreign_keys.some(g=>g.table===c)))continue;let{canAlter:m,addedCols:d}=this.canSimpleAlter(c,e,t);if(m){for(let y of d)i.push({sql:`ALTER TABLE ${$(c)} ADD COLUMN ${this.columnDef(y)};`,description:`Add column ${$(y.name)} to ${$(c)}`,type:"add_column"});let g=e.indexes.filter(y=>y.table===c&&y.type==="added"),b=e.indexes.filter(y=>y.table===c&&y.type==="removed");for(let y of b)i.push({sql:`DROP INDEX IF EXISTS ${$(y.name)};`,description:`Drop index ${$(y.name)}`,type:"drop_index"});for(let y of g){let T=y.unique?"UNIQUE ":"",C=y.columns.map(w=>$(w)).join(", ");i.push({sql:`CREATE ${T}INDEX ${$(y.name)} ON ${$(c)} (${C});`,description:`Create index ${$(y.name)} on ${$(c)}`,type:"add_index"});}}else {let g=this.rebuildTable(c,r,t,e);i.push(...g.steps),a.push(...g.warnings);}}for(let c of e.tables.filter(f=>f.type==="removed"))i.push({sql:`DROP TABLE ${$(c.name)};`,description:`Drop table ${$(c.name)}`,type:"drop_table"}),a.push({table:c.name,reason:"table will be dropped"});return i.push({sql:"COMMIT;",description:"Commit transaction",type:"commit_transaction"}),i.push({sql:"PRAGMA foreign_keys=ON;",description:"Re-enable foreign key checks",type:"enable_foreign_keys"}),{steps:i,warnings:a,unsafe:a.length>0}}rebuildTable(e,r,t,n){let i=[],a=[],o=t.tables.find(y=>y.name===e);if(!o)return {steps:i,warnings:a};let l=`_${e}_migrate_new`,u=o.sql.replace(new RegExp(`(CREATE\\s+TABLE\\s+)(?:"${e}"|${e})`,"i"),`$1${$(l)}`);i.push({sql:`${u};`,description:`Create temporary table ${$(l)}`,type:"create_table"});let p=r.columns.filter(y=>y.table===e).map(y=>y.name),c=t.columns.filter(y=>y.table===e).map(y=>y.name),f=p.filter(y=>c.includes(y));if(f.length>0){let y=f.map(T=>$(T)).join(", ");i.push({sql:`INSERT INTO ${$(l)} (${y})
|
|
339
|
-
|
|
340
|
-
FROM ${$(e)};`,description:`Copy data from ${$(e)} to ${$(l)}`,type:"copy_data"});}i.push({sql:`DROP TABLE ${$(e)};`,description:`Drop old table ${$(e)}`,type:"drop_table"}),i.push({sql:`ALTER TABLE ${$(l)} RENAME TO ${$(e)};`,description:`Rename ${$(l)} to ${$(e)}`,type:"rename_table"});let m=t.indexes.filter(y=>y.table===e);for(let y of m){let T=y.unique?"UNIQUE ":"",C=y.columns.map(w=>$(w)).join(", ");i.push({sql:`CREATE ${T}INDEX ${$(y.name)} ON ${$(e)} (${C});`,description:`Recreate index ${$(y.name)} on ${$(e)}`,type:"add_index"});}let d=t.triggers?.filter(y=>y.table===e)??[];for(let y of d)i.push({sql:`${y.sql};`,description:`Recreate trigger ${$(y.name)} on ${$(e)}`,type:"create_trigger"});let g=n.columns.filter(y=>y.table===e&&y.type==="removed");for(let y of g)a.push({table:e,reason:`column "${y.name}" will be dropped`});let b=n.columns.filter(y=>y.table===e&&y.type==="modified");for(let y of b)y.changes?.type&&a.push({table:e,reason:`column "${y.name}" type changes from ${y.changes.type.from} to ${y.changes.type.to}`}),y.changes?.nullable&&!y.changes.nullable.to&&a.push({table:e,reason:`column "${y.name}" becomes NOT NULL`});return {steps:i,warnings:a}}canSimpleAlter(e,r,t){let n=r.columns.filter(c=>c.table===e),i=n.filter(c=>c.type==="added"),a=n.filter(c=>c.type==="removed"),o=n.filter(c=>c.type==="modified"),l=r.foreign_keys.some(c=>c.table===e);if(a.length>0||o.length>0||l)return {canAlter:false,addedCols:i};let u=t.tables.find(c=>c.name===e);return u&&/\bCHECK\s*\(/i.test(u.sql)?{canAlter:false,addedCols:i}:{canAlter:i.every(c=>{let f=c.column;return this.hasNonConstantDefault(f.default_value)?false:f.nullable||f.default_value!=null})&&i.length>0,addedCols:i}}hasNonConstantDefault(e){if(e==null)return false;let r=e.trim().toUpperCase();return Gb.includes(r)}columnDef(e){let r=e.column,t=`${$(r.name)} ${r.type||"TEXT"}`;return r.nullable||(t+=" NOT NULL"),r.default_value!=null&&(t+=` DEFAULT ${r.default_value}`),t}};var Ee=class{context;constructor(e){this.context=e;}get isShimBacked(){return false}checkConstraint(){return null}serialize(e){return e}deserialize(e){return e}validateStorage(e){return {status:"pass",message:null}}validationFail(e,r){return {status:"fail",message:e,action:r}}validationPass(){return {status:"pass",message:null}}isNullish(e){return e==null}toColumnDDL(e){let{includeNullable:r=true}=e??{},t=[],n=this.context.column;t.push(this.quoteIfNeeded(n)),t.push(this.sqliteType),this.context.isPrimaryKey&&t.push("PRIMARY KEY"),this.context.isSerial&&this.context.isPrimaryKey&&t.push("AUTOINCREMENT"),r&&!this.context.nullable&&!this.context.isPrimaryKey&&t.push("NOT NULL"),this.context.isUnique&&!this.context.isPrimaryKey&&t.push("UNIQUE"),this.context.defaultValue!==null&&t.push(`DEFAULT ${this.context.defaultValue}`);let i=this.checkConstraint();return i&&t.push(`CHECK (${i})`),t.join(" ")}checkError(e,r){return new hr(this.context.table,this.context.column,e,r)}quoteIfNeeded(e){return /^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)?e:`"${e}"`}};var Or=class extends Ee{get sqliteType(){return "INTEGER"}};var bn=class extends Or{constructor(e){super({...e,isSerial:true});}};function Vb(s,e){let{precision:r,scale:t}=e,n=10**t,i=10**(r-t);return Math.abs(Math.round(s*n)-s*n)<1e-4&&Math.abs(s)<i}var Tn=class extends Ee{numericPrecision;constructor(e,r){super(e),this.numericPrecision=r;}get isShimBacked(){return this.numericPrecision!==void 0}get sqliteType(){return "REAL"}checkConstraint(){if(this.numericPrecision){let{precision:e,scale:r}=this.numericPrecision,t=this.context.column,n=10**r,i=10**(e-r);return `ABS(ROUND(${t} * ${n}) - ${t} * ${n}) < 0.0001 AND ABS(${t}) < ${i}`}return null}validateStorage(e){if(this.isNullish(e))return this.validationPass();if(typeof e!="number"||!Number.isFinite(e))return this.validationFail("Expected finite number.","Patch rows with finite numbers.");if(this.numericPrecision){let{precision:r,scale:t}=this.numericPrecision;if(!Vb(e,this.numericPrecision))return this.validationFail(`Does not fit numeric(${r}, ${t}).`,"Patch rows within numeric precision.")}return this.validationPass()}};var ie=class extends Ee{lengthConstraint;constructor(e,r){super(e),this.lengthConstraint=r;}get isShimBacked(){return this.lengthConstraint!==void 0}get sqliteType(){return "TEXT"}checkConstraint(){return this.lengthConstraint!==void 0?`length(${this.context.column}) <= ${this.lengthConstraint}`:null}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"?this.validationFail("Expected text.","Patch rows with text values."):this.lengthConstraint!==void 0&&Array.from(e).length>this.lengthConstraint?this.validationFail(`Exceeds length ${this.lengthConstraint}.`,"Patch rows with shorter text."):this.validationPass()}};var wn=class extends Ee{get sqliteType(){return "BLOB"}};var Cn=class extends Ee{get isShimBacked(){return true}get sqliteType(){return "INTEGER"}checkConstraint(){return `${this.context.column} IN (0, 1)`}serialize(e){if(this.isNullish(e))return e;if(e===true||e===1)return 1;if(e===false||e===0)return 0;throw this.checkError("boolean_range",e)}deserialize(e){return this.isNullish(e)?e:e===1?true:e===0?false:e}validateStorage(e){return this.isNullish(e)?this.validationPass():e===1||e===0?this.validationPass():this.validationFail("Expected 0 or 1.","Patch rows with boolean values.")}};function gh(s){try{return {ok:!0,value:JSON.parse(s)}}catch{return {ok:false}}}var An=class extends Ee{get isShimBacked(){return true}get sqliteType(){return "TEXT"}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR json_valid(${e})`}serialize(e){if(this.isNullish(e))return e;try{return JSON.stringify(e)}catch{throw this.checkError("json_valid",e)}}deserialize(e){if(this.isNullish(e))return e;if(typeof e=="string"){let r=gh(e);return r.ok?r.value:e}return e}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"?this.validationFail("Expected JSON text.","Patch rows with JSON values."):gh(e).ok?this.validationPass():this.validationFail("Invalid JSON text.","Patch rows with valid JSON.")}};function Kb(s){if(!/^\d{4}-\d{2}-\d{2}$/.test(s))return false;let e=new Date(`${s}T00:00:00.000Z`);return !Number.isNaN(e.getTime())&&e.toISOString().slice(0,10)===s}var Rn=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR date(${e}) IS NOT NULL`}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!Kb(e)?this.validationFail("Invalid date.","Patch rows with YYYY-MM-DD dates."):this.validationPass()}};function Yb(s){let e=s.match(/^(\d{2}):(\d{2})(?::(\d{2})(?:\.\d{1,6})?)?([+-](\d{2}):?(\d{2}))?$/);if(!e)return false;let r=Number(e[1]),t=Number(e[2]),n=e[3]===void 0?0:Number(e[3]),i=e[5]===void 0?null:Number(e[5]),a=e[6]===void 0?null:Number(e[6]),o=i===null||a!==null&&i<=15&&a<=59;return r<=24&&t<=59&&n<=59&&(r!==24||t===0&&n===0)&&o}var _n=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR time(${e}) IS NOT NULL`}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!Yb(e)?this.validationFail("Invalid time.","Patch rows with HH:MM[:SS] times."):this.validationPass()}};function zb(s){let e=s.match(/^(\d{4})-(\d{2})-(\d{2})[ T](\d{2}):(\d{2})(?::(\d{2})(?:\.\d{1,6})?)?(?:Z|([+-](\d{2}):?(\d{2})))?$/);if(!e)return false;let r=Number(e[1]),t=Number(e[2]),n=Number(e[3]),i=Number(e[4]),a=Number(e[5]),o=e[6]===void 0?0:Number(e[6]),l=e[8]===void 0?null:Number(e[8]),u=e[9]===void 0?null:Number(e[9]),p=new Date(Date.UTC(r,t-1,n)),c=p.getUTCFullYear()===r&&p.getUTCMonth()===t-1&&p.getUTCDate()===n,f=i<=24&&a<=59&&o<=59&&(i!==24||a===0&&o===0),m=l===null||u!==null&&l<=15&&u<=59;return c&&f&&m}var vn=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR datetime(${e}) IS NOT NULL`}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!zb(e)?this.validationFail("Invalid timestamp.","Patch rows with ISO timestamps."):this.validationPass()}};var On=class extends ie{get isShimBacked(){return true}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||e.trim().length===0?this.validationFail("Expected interval text.","Patch rows with interval strings."):/^-?\d+(?:\.\d+)?$/.test(e.trim())?this.validationFail("Ambiguous numeric interval.","Patch rows with explicit interval strings."):this.validationPass()}};var Nn=class extends ie{enumValues;constructor(e,r){super(e),this.enumValues=r;}get isShimBacked(){return true}checkConstraint(){let e=this.context.column,r=this.enumValues.map(t=>`'${t.replace(/'/g,"''")}'`).join(", ");return `${e} IN (${r})`}serialize(e){if(this.isNullish(e))return e;if(typeof e!="string"||!this.enumValues.includes(e))throw this.checkError("enum_membership",e);return e}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!this.enumValues.includes(e)?this.validationFail("Invalid enum value.","Patch rows with declared enum values."):this.validationPass()}};function yh(s){try{return {ok:!0,value:JSON.parse(s)}}catch{return {ok:false}}}var ls=class extends Ee{elementField;constructor(e,r){super(e),this.elementField=r;}get sqliteType(){return "TEXT"}get isShimBacked(){return true}checkConstraint(){let e=this.context.column;return `${e} IS NULL OR (json_valid(${e}) AND json_type(${e}) = 'array')`}serialize(e){if(this.isNullish(e))return e;if(!Array.isArray(e))throw this.checkError("array_type",e);return this.elementField?JSON.stringify(e.map(r=>this.elementField.serialize(r))):JSON.stringify(e)}deserialize(e){if(this.isNullish(e))return e;if(typeof e=="string"){let r=yh(e);if(r.ok&&Array.isArray(r.value))return this.elementField?r.value.map(t=>this.elementField.deserialize(t)):r.value}return e}validateStorage(e){if(this.isNullish(e))return this.validationPass();if(typeof e!="string")return this.validationFail("Expected JSON array text.","Patch rows with array values.");let r=yh(e);if(!r.ok)return this.validationFail("Invalid JSON array text.","Patch rows with array values.");if(!Array.isArray(r.value))return this.validationFail("Expected JSON array.","Patch rows with array values.");if(this.elementField)for(let t of r.value){let n=this.elementField.validateStorage(t);if(n.status==="fail")return this.validationFail(`Invalid ${this.elementField.context.pgTypeName} array element.`,n.action??"Patch rows with valid array elements.")}return this.validationPass()}};var Xb="????????-????-????-????-????????????",Qb=/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/;function Eh(s){return Qb.test(s.toLowerCase())}var In=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.quoteIfNeeded(this.context.column);return `${e} IS NULL OR ${e} GLOB '${Xb}'`}serialize(e){if(this.isNullish(e))return e;if(typeof e!="string")throw this.checkError("uuid_format",e);let r=e.toLowerCase();if(!Eh(r))throw this.checkError("uuid_format",e);return r}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!Eh(e)?this.validationFail("Invalid UUID.","Patch rows with valid UUIDs."):this.validationPass()}};function Zb(s){let e=s.split("/");if(e.length>2)return null;let r=e[0];if(!r)return null;if(e.length===1)return {address:r,prefix:null};let t=e[1];return !t||!/^\d+$/.test(t)?null:{address:r,prefix:Number(t)}}function eT(s){let e=s.split(".");return e.length!==4?false:e.every(r=>{if(!/^\d+$/.test(r))return false;let t=Number(r);return t>=0&&t<=255})}function tT(s){if(!s.includes(":"))return false;try{return new URL(`http://[${s}]/`),!0}catch{return false}}function Sh(s){let e=Zb(s);return e?eT(e.address)?e.prefix===null||e.prefix>=0&&e.prefix<=32:tT(e.address)?e.prefix===null||e.prefix>=0&&e.prefix<=128:false:false}var Ln=class extends ie{get isShimBacked(){return true}checkConstraint(){let e=this.quoteIfNeeded(this.context.column);return `${e} IS NULL OR (length(${e}) BETWEEN 3 AND 49 AND (instr(${e}, '.') > 0 OR instr(${e}, ':') > 0))`}serialize(e){if(this.isNullish(e))return e;if(typeof e!="string")throw this.checkError("inet_format",e);let r=e.trim();if(!Sh(r))throw this.checkError("inet_format",e);return r}validateStorage(e){return this.isNullish(e)?this.validationPass():typeof e!="string"||!Sh(e.trim())?this.validationFail("Invalid inet address.","Patch rows with valid inet strings."):this.validationPass()}};var kn=class extends ie{serialize(e){throw new Error(`Unsupported type "${this.context.pgTypeName}" for ${this.context.table}.${this.context.column}`)}deserialize(e){throw new Error(`Unsupported type "${this.context.pgTypeName}" for ${this.context.table}.${this.context.column}`)}toColumnDDL(){throw new Error(`Unsupported type "${this.context.pgTypeName}" for ${this.context.table}.${this.context.column}`)}};var rT=new Set(["int2","smallint","int4","integer","int","int8","bigint"]),sT=new Set(["serial","serial4","bigserial","serial8","smallserial","serial2"]),nT=new Set(["float4","real","float8","double precision","numeric","decimal"]),iT=new Set(["text","varchar","character varying","char","character","bpchar"]),aT=new Set(["bytea"]),oT=new Set(["bool","boolean"]),lT=new Set(["json","jsonb"]),uT=new Set(["uuid"]),cT=new Set(["name"]),pT=new Set(["inet"]),fT=new Set(["date"]),mT=new Set(["time","timetz","time without time zone","time with time zone"]),hT=new Set(["timestamp","timestamptz","timestamp without time zone","timestamp with time zone"]),dT=new Set(["interval"]);function Nr(s,e){if(e?.isArray){let t=Nr(s,{...e,isArray:false});return new ls(s,t)}if(e?.enumValues)return new Nn(s,e.enumValues);let r=s.pgTypeName.toLowerCase().trim();if(r.startsWith("_")||r.endsWith("[]")){let t=r.startsWith("_")?r.slice(1):r.slice(0,-2),n={...s,pgTypeName:t},i=Nr(n);return new ls(s,i)}return sT.has(r)?new bn(s):rT.has(r)?new Or(s):oT.has(r)?new Cn(s):lT.has(r)?new An(s):fT.has(r)?new Rn(s):mT.has(r)?new _n(s):hT.has(r)?new vn(s):dT.has(r)?new On(s):aT.has(r)?new wn(s):nT.has(r)?new Tn(s,e?.numericPrecision):uT.has(r)?new In(s):cT.has(r)?new ie(s,63):pT.has(r)?new Ln(s):iT.has(r)?new ie(s,e?.lengthConstraint):new kn(s)}var bh="lower(hex(randomblob(4))) || '-' || lower(hex(randomblob(2))) || '-4' || substr(lower(hex(randomblob(2))),2) || '-' || substr('89ab',abs(random()) % 4 + 1, 1) || substr(lower(hex(randomblob(2))),2) || '-' || lower(hex(randomblob(6)))",La={gen_random_uuid:{sqlite:()=>bh,js:()=>crypto.randomUUID()},uuid_generate_v4:{sqlite:()=>bh,js:()=>crypto.randomUUID()},now:{sqlite:()=>"datetime('now')",js:()=>new Date().toISOString()},current_timestamp:{sqlite:()=>"datetime('now')",js:()=>new Date().toISOString()},current_date:{sqlite:()=>"date('now')",js:()=>new Date().toISOString().split("T")[0]},current_time:{sqlite:()=>"time('now')",js:()=>new Date().toISOString().split("T")[1].replace("Z","")},random:{sqlite:()=>"random()",js:()=>Math.random()},length:{sqlite:()=>"length",js:null},lower:{sqlite:()=>"lower",js:null},upper:{sqlite:()=>"upper",js:null},substr:{sqlite:()=>"substr",js:null},substring:{sqlite:()=>"substr",js:null},trim:{sqlite:()=>"trim",js:null},ltrim:{sqlite:()=>"ltrim",js:null},rtrim:{sqlite:()=>"rtrim",js:null},replace:{sqlite:()=>"replace",js:null},coalesce:{sqlite:()=>"coalesce",js:null},nullif:{sqlite:()=>"nullif",js:null},count:{sqlite:()=>"count",js:null},sum:{sqlite:()=>"sum",js:null},avg:{sqlite:()=>"avg",js:null},min:{sqlite:()=>"min",js:null},max:{sqlite:()=>"max",js:null},localtime:{sqlite:()=>"time('now', 'localtime')",js:null},localtimestamp:{sqlite:()=>"datetime('now', 'localtime')",js:null}};function wu(s,e="auto"){let r=s.toLowerCase(),t=La[r];if(!t)return null;switch(e){case "translate":{if(!t.sqlite)throw new Error(`No SQLite translation for function "${s}"`);return {sqliteExpr:t.sqlite(),jsFn:null}}case "synthetic":{if(!t.js)throw new Error(`No JS implementation for function "${s}"`);return {sqliteExpr:null,jsFn:t.js}}case "auto":return t.js?{sqliteExpr:null,jsFn:t.js}:t.sqlite?{sqliteExpr:t.sqlite(),jsFn:null}:null}}var ka=class extends ns{enums;schemaHandling;warnings=[];helper;config;triggerFunctions=new Map;plpgsqlParser=new Oa;introspection;functionResolution;constructor(e,{enums:r,schemaHandling:t,introspection:n,...i}={}){super(e,i),this.schemaHandling=t??"default",this.enums=r??new Map,this.helper=new va(e),this.config=i,this.introspection=n,this.functionResolution=i?.functionResolution??"translate";}visit(e,r){let t=is(e),n=Ra.get(t);if(n){if(n.react==="error")throw new P({[t]:e},`Unsupported node type: ${t}`);return n.react==="warn"&&this.warnings.push({type:t,node:e}),""}return super.visit(e,r)}deparse(e,r){if(e==null)return null;if(!r){let t=new wh.SqlFormatter;r=new Th.DeparserContext({formatter:t});}return typeof e=="number"||e instanceof Number?e.toString():this.visit(e,r)}RawStmt(e,r){if(!e.stmt||e.stmt.CommentStmt)return "";let t=this.deparse(e.stmt,r);return !t||t.length===0?"":e.stmt_len?t+";":t}RangeVar(e,r){this.ensureRelation(e);let t=this.effectiveSchema(e.schemaname),n=e.relname,i=this.quoteBareIfNeeded(n);t&&(this.schemaHandling==="prefix"?i=`${t}__${n}`:i=`"${t}.${n}"`);let a=e.alias?" "+this.Alias(e.alias,r):"";return i+a}getRelationName(e){this.ensureRelation(e);let r=this.effectiveSchema(e.schemaname),t=e.relname;return r?this.schemaHandling==="prefix"?`${r}__${t}`:`${r}.${t}`:t}quoteBareIfNeeded(e){return /^[A-Za-z_][A-Za-z0-9_]*$/.test(e)?e:`"${e.replace(/"/g,'""')}"`}effectiveSchema(e){if(e){if(this.config.forceDefaultSchema||this.schemaHandling!=="default")return e;if(e!=="public")return e}}ensureRelation(e){let r=this.config.forceDefaultSchema;r&&(!e||typeof e!="object"||r.length===0||e.schemaname||(e.schemaname=r));}CreateStmt(e,r){if(e.inhRelations&&e.inhRelations.length>0)throw new P({CreateStmt:e},"Inheritance is not supported in SQLite");if(e.ofTypename!==void 0)throw new P({CreateStmt:e},"Typed tables (CREATE TABLE ... OF type_name) are not supported. Define columns directly in the CREATE TABLE statement instead.");if(e.options&&e.options.length>0&&(e.options=void 0),!e.tableElts||e.tableElts.length===0)throw new P({CreateStmt:e},"Empty tables are not supported in SQLite. Define at least one column.");return e.accessMethod&&(e.accessMethod=void 0),super.CreateStmt(e,r)+" STRICT"}TableLikeClause(e,r){throw new P({TableLikeClause:e},"CREATE TABLE ... (LIKE ...) is not supported in SQLite. Define the table columns explicitly instead.")}DefElem(e,r){if(["oids","fillfactor",/^autovacuum_/i,"toast_tuple_target","parallel_workers","user_catalog_table"].some(i=>ki(e.defname??"",i)))return "";let n=super.DefElem(e,r);throw new P({DefElem:e},`DefElem "${e.defname}" (${n}) not supported`)}TypeName(e,r){if(!e.names)return "";let t=e.names.map(i=>i.String?i.String.sval||i.String.str:"").filter(Boolean);if(t.length===0)return "";let n=t.length===2&&t[0]==="pg_catalog"?t[1]:t.join(".");return e.arrayBounds&&e.arrayBounds.length>0||this.enums.has(n.toLowerCase())?"TEXT":hh(n)}ColumnDef(e,r){let t=[],n=e.colname;n&&t.push(this.quoteIfNeeded(n));let i=false,a=false,o=null,l=null,u=null,p=false;if(e.typeName){let c=e.typeName.names?.map(d=>d.String?.sval||d.String?.str).filter(Boolean);u=c&&(c.length===2&&c[0]==="pg_catalog"?c[1]:c[0]),i=!!(u&&wa(u)),p=!!(e.typeName.arrayBounds&&e.typeName.arrayBounds.length>0);let f=Array.isArray(e.typeName.typmods)?e.typeName.typmods:[],m=d=>f[d]?.A_Const?.ival?.ival??f[d]?.A_Const?.val?.ival?.ival;if(u&&Ca(u)&&f.length>0){let d=m(0);typeof d=="number"&&d>0&&(o={maxLen:d});}if(u&&Aa(u)&&f.length>=2){let d=m(0),g=m(1);typeof d=="number"&&typeof g=="number"&&d>0&&g>=0&&(l={precision:d,scale:g});}if(e.constraints){let d=Array.isArray(e.constraints)?e.constraints:[];a=d.some(g=>g.Constraint?.contype==="CONSTR_PRIMARY"),d.some(g=>g.Constraint?.contype==="CONSTR_IDENTITY")&&(i=true);}t.push(this.TypeName(e.typeName,r));}if(e.constraints){let c=Array.isArray(e.constraints)?e.constraints:[],f=c.map(d=>this.visit(d,r));t.push(...f.filter(Boolean));let m=c.some(d=>d.Constraint?.contype==="CONSTR_CHECK");i&&a&&!m&&t.push("AUTOINCREMENT");}if(n&&u){let c={isArray:p};o&&(c.lengthConstraint=o.maxLen),l&&(c.numericPrecision=l);let f=this.enums.get(u.toLowerCase());f&&(c.enumValues=f);let g=Nr({schema:"public",table:"",column:n,pgTypeName:u,nullable:true,defaultValue:null,defaultFn:null,isPrimaryKey:a,isUnique:false,isSerial:i},c).checkConstraint();g&&t.push(`CHECK (${g})`);}return t.join(" ")}Constraint(e,r){let t=e.contype;if(t==="CONSTR_IDENTITY"||t==="CONSTR_ATTR_DEFERRABLE"||t==="CONSTR_ATTR_NOT_DEFERRABLE"||t==="CONSTR_ATTR_DEFERRED"||t==="CONSTR_ATTR_IMMEDIATE")return "";if(t==="CONSTR_NULL")return "NULL";if(t==="CONSTR_NOTNULL")return "NOT NULL";if(t==="CONSTR_DEFAULT"&&e.raw_expr){let n=this.visit(e.raw_expr,r);return n.includes("(")&&!n.startsWith("(")?`DEFAULT (${n})`:`DEFAULT ${n}`}if(t==="CONSTR_CHECK"&&e.raw_expr){let n=[];e.conname&&n.push("CONSTRAINT",Ta(e.conname)),n.push("CHECK");let i=this.visit(e.raw_expr,r);return n.push(`(${i})`),n.join(" ")}if(t==="CONSTR_PRIMARY")return e.keys&&e.keys.length>0?`PRIMARY KEY (${_r(e.keys).map(i=>this.visit(i,r)).join(", ")})`:"PRIMARY KEY";if(t==="CONSTR_UNIQUE")return e.keys&&e.keys.length>0?`UNIQUE (${_r(e.keys).map(i=>this.visit(i,r)).join(", ")})`:"UNIQUE";if(t==="CONSTR_FOREIGN")return super.Constraint(e,r).replace(/FOREIGN\s+KEY\s+REFERENCES/gi,"REFERENCES");if(t==="CONSTR_GENERATED"&&e.raw_expr)return `GENERATED ALWAYS AS (${this.visit(e.raw_expr,r)}) STORED`;if(t==="CONSTR_EXCLUSION")throw new P({Constraint:e},"EXCLUSION constraints are not supported in SQLite");return ""}FuncCall(e,r){let n=(e.funcname||[]).map(u=>u.String?.sval||u.String?.str).filter(Boolean);if(n.length===0)throw new Error("Function call has no name");let i=n[n.length-1].toLowerCase();if(i==="extract"&&e.args&&e.args.length>=2){let u=e.args[0];if((u?.A_Const?.sval?.sval||u?.String?.sval)==="epoch")return `strftime('%s', ${this.visit(e.args[1],r)})`}let o=(e.args??[]).map(u=>this.visit(u,r));if(e.agg_star)return `${i}(*)`;if(e.agg_distinct)return `${i}(DISTINCT ${o.join(", ")})`;let l=wu(i,this.functionResolution);if(l){if(l.sqliteExpr!==null){let u=l.sqliteExpr;return u.includes("(")?u:`${u}(${o.join(", ")})`}if(l.jsFn!==null){let u=La[i];if(u?.sqlite){let p=u.sqlite();return p.includes("(")?p:`${p}(${o.join(", ")})`}}}throw new P({FuncCall:e},`Function call "${i}" not supported`)}SQLValueFunction(e,r){switch(e.op){case "SVFOP_CURRENT_TIMESTAMP":return "datetime('now')";case "SVFOP_CURRENT_DATE":return "date('now')";case "SVFOP_CURRENT_TIME":return "time('now')";default:throw new P({SQLValueFunction:e},`SQLValueFunction "${e.op}" not supported`)}}ResTarget(e,r){if(e.indirection&&e.indirection.length>0)throw new P({ResTarget:e},"Indirections are not supported in SQLite");let t=[];return r.update&&e.name?(t.push(this.quoteIfNeeded(e.name)),t.push("="),e.val&&t.push(this.deparse(e.val,r))):r.insertColumns&&e.name?t.push(this.quoteIfNeeded(e.name)):(e.val&&t.push(this.deparse(e.val,r)),e.name&&t.push(this.Alias({aliasname:e.name},r))),t.join(" ")}A_Expr(e,r){if(["AEXPR_OP_ALL","AEXPR_OP_ANY"].includes(e.kind))throw new P({A_Expr:e},"ALL/ANY/SOME comparison operators are not supported. Use NOT EXISTS or IN instead");if(e.name&&e.name.length>0){if(e.name.length>1)throw new P({A_Expr:e},"Schema-qualified OPERATOR() syntax is not supported in SQLite");let t=e.name[0]?.String?.sval||e.name[0]?.String?.str;if(t){if(!e.lexpr||!e.rexpr)throw new P({A_Expr:e},"A_Expr missing left or right expression");if(!mh.includes(t.toUpperCase()))throw new P({A_Expr:e},`Operator "${t}" is not supported in SQLite`);if(t==="~~"||t==="~~*"){let n=this.visit(e.lexpr,r),i=this.visit(e.rexpr,r);return `${n} LIKE ${i}`}if(t==="!~~"||t==="!~~*"){let n=this.visit(e.lexpr,r),i=this.visit(e.rexpr,r);return `${n} NOT LIKE ${i}`}if(t==="~"||t==="~*"){let n=this.visit(e.lexpr,r),i=this.visit(e.rexpr,r);return `${n} GLOB ${i}`}}}return super.A_Expr(e,r)}IndexStmt(e,r){let t=["CREATE"];e.unique&&t.push("UNIQUE"),t.push("INDEX"),e.if_not_exists&&t.push("IF NOT EXISTS"),e.idxname&&t.push(Ta(e.idxname)),t.push("ON"),e.relation&&t.push(this.RangeVar(e.relation,r));let n=(e.indexParams??[]).map(i=>"IndexElem"in i?this.IndexElem(i.IndexElem,r):this.visit(i,r)).filter(Boolean);return t.push(`(${n.join(", ")})`),t.join(" ")}IndexElem(e,r){let t=[];return e.name?t.push(Ta(e.name)):e.expr&&t.push(`(${this.visit(e.expr,r)})`),e.ordering==="SORTBY_ASC"&&t.push("ASC"),e.ordering==="SORTBY_DESC"&&t.push("DESC"),e.nulls_ordering==="SORTBY_NULLS_FIRST"&&t.push("NULLS FIRST"),e.nulls_ordering==="SORTBY_NULLS_LAST"&&t.push("NULLS LAST"),t.join(" ")}TypeCast(e,r){if(!e.arg||!e.typeName)return super.TypeCast(e,r);if([...this.helper.walk(e)].filter(({node:a})=>"A_Star"in a).length>0)throw new P({TypeCast:e},"A.* in type casts are not supported in SQLite");if(e.typeName.arrayBounds&&e.typeName.arrayBounds.length>0){if("A_Const"in e.arg&&e.arg.A_Const.sval){let a=e.arg.A_Const.sval.sval;if(a.startsWith("{")&&a.endsWith("}")){let o=e.typeName.names?.map(c=>c.String?.sval).filter(Boolean)??[],l=o.length===2&&o[0]==="pg_catalog"?o[1]:o[0],p=["text","varchar","character varying","char","bpchar","name","uuid"].includes(l?.toLowerCase());try{let c=this.parsePgArrayLiteral(a,p);return `'${JSON.stringify(c).replace(/'/g,"''")}'`}catch{}}}return this.visit(e.arg,r)}let n=this.visit(e.arg,r),i=this.TypeName(e.typeName,r);return `CAST(${n} AS ${i})`}A_ArrayExpr(e,r){let t=_r(e.elements),n=this.tryExtractStaticArray(t);return n!==void 0?`'${JSON.stringify(n).replace(/'/g,"''")}'`:`json_array(${t.map(a=>this.visit(a,r)).join(", ")})`}tryExtractStaticArray(e){let r=[];for(let t of e)if("A_ArrayExpr"in t){let n=_r(t.A_ArrayExpr.elements),i=this.tryExtractStaticArray(n);if(i===void 0)return;r.push(i);}else if("A_Const"in t){let n=t.A_Const;if(n.isnull)r.push(null);else if(n.ival)r.push(n.ival.ival);else if(n.fval)r.push(parseFloat(n.fval.fval));else if(n.sval)r.push(n.sval.sval);else if("boolval"in n)r.push(n.boolval.boolval===true);else return}else return;return r}parsePgArrayLiteral(e,r){if(!e.startsWith("{")||!e.endsWith("}"))throw new Error("Not a PG array literal");let t=e.slice(1,-1);if(t.length===0)return [];let n=[],i=0;for(;i<t.length;)if(t[i]==="{"){let a=0,o=i;for(;o<t.length;){if(t[o]==="{")a++;else if(t[o]==="}"&&(a--,a===0))break;o++;}n.push(this.parsePgArrayLiteral(t.slice(i,o+1),r)),i=o+1,t[i]===","&&i++;}else if(t[i]==='"'){let a=i+1,o="";for(;a<t.length&&t[a]!=='"';)t[a]==="\\"&&a++,o+=t[a],a++;n.push(o),i=a+1,t[i]===","&&i++;}else {let a=i;for(;a<t.length&&t[a]!==","&&t[a]!=="}";)a++;if(a===i)throw new Error("Malformed PG array literal");let o=t.slice(i,a);if(o==="NULL")n.push(null);else if(r)n.push(o);else {let l=Number(o);n.push(isNaN(l)?o:l);}i=a,t[i]===","&&i++;}return n}BetweenExpr(e,r){return super.A_Expr(e,r)}AlterTableStmt(e,r){let t=e.cmds??[],n=["AT_EnableRowSecurity","AT_ForceRowSecurity"],i=t.filter(p=>"AlterTableCmd"in p&&!n.includes(p.AlterTableCmd.subtype));if(i.length===0)return "";if(!["OBJECT_TABLE","OBJECT_INDEX","OBJECT_VIEW"].includes(e.objtype))throw new P({AlterTableStmt:e},`AlterTableStmt with objtype ${e.objtype} is not supported`);let a=["AT_AddColumn","AT_DropColumn"],o=["AT_AlterColumnType","AT_SetNotNull","AT_DropNotNull","AT_ColumnDefault","AT_AddConstraint","AT_DropConstraint"],l=[],u=[];for(let p of i){let c=p.AlterTableCmd.subtype;if(a.includes(c)){let f={...e,cmds:[p]};l.push(super.AlterTableStmt(f,r));}else if(o.includes(c))u.push(p.AlterTableCmd);else throw new P({AlterTableStmt:e},`AlterTableCmd with subtype ${c} is not supported in SQLite`)}if(u.length>0){let p=this.getRelationName(e.relation);l.push(this.generateRebuildSql(p,u));}return l.join(`;
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
`):""}buildDesiredSchema(e,r,t){let n={...e,tables:e.tables.map(i=>({...i})),columns:e.columns.map(i=>({...i})),indexes:e.indexes.map(i=>({...i})),foreign_keys:e.foreign_keys.map(i=>({...i})),primary_keys:e.primary_keys.map(i=>({...i})),views:e.views.map(i=>({...i})),triggers:(e.triggers??[]).map(i=>({...i})),check_constraints:e.check_constraints.map(i=>({...i})),unique_constraints:(e.unique_constraints??[]).map(i=>({...i})),comments:(e.comments??[]).map(i=>({...i})),custom_types:e.custom_types.map(i=>({...i}))};for(let i of t){let a=n.columns.findIndex(o=>o.table===r&&o.name===i.name);switch(i.subtype){case "AT_AlterColumnType":{if(a===-1)break;let o=this.extractTypeName(i);o&&(n.columns[a]={...n.columns[a],type:o.toLowerCase()});break}case "AT_SetNotNull":{if(a===-1)break;n.columns[a]={...n.columns[a],nullable:false};break}case "AT_DropNotNull":{if(a===-1)break;n.columns[a]={...n.columns[a],nullable:true};break}case "AT_ColumnDefault":{if(a===-1)break;if(i.def){let o=this.extractDefaultValue(i);n.columns[a]={...n.columns[a],default_value:o};}else n.columns[a]={...n.columns[a],default_value:null};break}case "AT_AddConstraint":case "AT_DropConstraint":{let o=n.tables.findIndex(l=>l.name===r);o!==-1&&(n.tables[o]={...n.tables[o],sql:n.tables[o].sql+" /* modified */"});break}}}return this.rebuildTableSql(n,r),n}rebuildTableSql(e,r){let t=e.tables.findIndex(c=>c.name===r);if(t===-1)return;let n=e.columns.filter(c=>c.table===r),i=e.foreign_keys.filter(c=>c.table===r),a=e.check_constraints.filter(c=>c.table===r),o=n.map(c=>{let f=`${$(c.name)} ${c.type||"TEXT"}`;return c.is_primary_key&&(f+=" PRIMARY KEY"),c.nullable||(f+=" NOT NULL"),c.default_value!=null&&(f+=` DEFAULT ${c.default_value}`),f}),l=i.map(c=>`FOREIGN KEY (${$(c.column)}) REFERENCES ${$(c.ref_table)}(${$(c.ref_column)}) ON UPDATE ${c.on_update} ON DELETE ${c.on_delete}`),u=a.map(c=>`CHECK (${c.expression})`),p=[...o,...l,...u];e.tables[t]={...e.tables[t],sql:`CREATE TABLE ${$(r)} (${p.join(", ")}) STRICT`};}extractTypeName(e){let r=e.def?.ColumnDef;return r?.typeName?.TypeName?(r.typeName.TypeName.names??[]).map(n=>n.String?.sval).filter(Boolean).pop()??null:null}extractDefaultValue(e){return e.def?"Integer"in e.def?String(e.def.Integer.ival):"Float"in e.def?e.def.Float.fval:"String"in e.def?`'${e.def.String.sval}'`:null:null}};var ze=class extends P{constructor(e,r){super(e,`Unsupported expression: ${r}`);}},$n=class{deparse(e){if("A_Const"in e){let n=e.A_Const;if(n.boolval!==void 0)return n.boolval.boolval?{}:{$always:false}}let r=Object.keys(e)[0],t=this[r];if(!t)throw new ze({[r]:e},`Unsupported expression: ${r}`);return t.call(this,e[r])}deparseValue(e){if("A_Const"in e)return this.A_Const(e.A_Const);if("ColumnRef"in e)return this.ColumnRef(e.ColumnRef);if("FuncCall"in e)return this.FuncCall(e.FuncCall);if("SubLink"in e)return this.SubLink(e.SubLink);if("TypeCast"in e)return this.TypeCast(e.TypeCast);if("A_Expr"in e){let t=this.isJwtAccessor(e.A_Expr);return t||this.A_Expr(e.A_Expr)}if("BoolExpr"in e)return this.BoolExpr(e.BoolExpr);let r=Object.keys(e)[0];throw new ze({[r]:e},`deparseValue: ${r}`)}A_Expr(e){if(e.kind==="AEXPR_OP"){let r=e.name?.[0],t=r?Sn(r):void 0;if(!t)throw new ze({A_Expr:e},"A_Expr missing operator");let n=this.isJwtAccessor(e);if(n)return {[n]:{}};let i=e.lexpr?this.deparseValue(e.lexpr):void 0,a=e.rexpr?this.deparseValue(e.rexpr):void 0,o=this.mapOperator(t);if(!o)throw new ze({A_Expr:e},`Unsupported operator: ${t}`);let l=e.rexpr!=null&&"ColumnRef"in e.rexpr;if(typeof i=="string"&&i.startsWith("{{")&&l)return {[a]:{[o]:i}};let u=l&&typeof a=="string"?{$ref:a}:a;return {[i]:{[o]:u}}}if(e.kind==="AEXPR_LIKE"||e.kind==="AEXPR_ILIKE"){let r=e.lexpr?this.deparseValue(e.lexpr):void 0,t=e.rexpr?this.deparseValue(e.rexpr):void 0,i=(e.name?.[0]?Sn(e.name[0]):"~~")==="!~~"?"$notLike":"$like";return {[r]:{[i]:t}}}if(e.kind==="AEXPR_IN"){let r=e.lexpr?this.deparseValue(e.lexpr):void 0,t=e.rexpr&&"List"in e.rexpr&&e.rexpr.List.items?e.rexpr.List.items.map(n=>this.deparseValue(n)):[];return {[r]:{$in:t}}}throw new ze({A_Expr:e},`A_Expr kind: ${e.kind}`)}BoolExpr(e){let r=e.args??[];switch(e.boolop){case "AND_EXPR":return {$and:r.map(t=>this.deparse(t))};case "OR_EXPR":return {$or:r.map(t=>this.deparse(t))};case "NOT_EXPR":return {$not:this.deparse(r[0])};default:throw new ze({BoolExpr:e},`BoolExpr op: ${e.boolop}`)}}NullTest(e){let r=e.arg?this.deparseValue(e.arg):void 0;return e.nulltesttype==="IS_NULL"?{[r]:{$is:null}}:{[r]:{$isNot:null}}}SubLink(e){if(e.subLinkType==="ANY_SUBLINK"){let r=e.testexpr?this.deparseValue(e.testexpr):void 0,t=e.subselect?this.SelectStmt(e.subselect.SelectStmt):void 0;return {[r]:{$in:t}}}if(e.subLinkType==="EXISTS_SUBLINK")return {$exists:e.subselect?this.SelectStmt(e.subselect.SelectStmt):void 0};if(e.subLinkType==="EXPR_SUBLINK"){let r=e.subselect?e.subselect.SelectStmt:void 0;if(r?.fromClause?.length)return this.SelectStmt(r);if(r?.targetList?.[0]){let t=r.targetList[0],n="ResTarget"in t?t.ResTarget:void 0;if(n?.val){let i=this.deparseValue(n.val);return i}}}throw new ze({SubLink:e},`SubLink type: ${e.subLinkType}`)}SelectStmt(e){let{from:r,schema:t,join:n}=this.deparseFromClause(e.fromClause??[]),i=[];for(let f of e.targetList??[]){let m="ResTarget"in f?f.ResTarget:void 0;if(m?.val){let d=this.deparseValue(m.val);Array.isArray(d)?i.push(...d.map(String)):d!=null&&d!==""&&i.push(String(d));}}let a=e.whereClause?this.deparse(e.whereClause):void 0,o=this.deparseSortClause(e.sortClause),l=this.deparseLimit(e.limitCount),u=this.deparseLimit(e.limitOffset),p=this.deparseGroupClause(e.groupClause),c={type:"query",from:r,select:i};return t&&(c.schema=t),Object.keys(n).length>0&&(c.join=n),a&&(c.where=a),o.length>0&&(c.order=o),l!==void 0&&(c.limit=l),u!==void 0&&(c.offset=u),p.length>0&&(c.group=p),c}FuncCall(e){let r=this.isAuthFunc(e.funcname??[]);if(r)return r;throw new ze({FuncCall:e},`FuncCall: ${Rr(e.funcname??[]).join(".")}`)}ColumnRef(e){let r=Rr(e.fields??[]);return r.length===1?r[0]:r.join(".")}A_Const(e){if(e.boolval!==void 0)return e.boolval.boolval;if(e.ival!==void 0)return e.ival.ival??0;if(e.fval!==void 0)return parseFloat(e.fval.fval??"0");if(e.sval!==void 0)return e.sval.sval??"";if(e.isnull)return null;throw new ze({A_Const:e},"A_Const: unknown variant")}TypeCast(e){if(!e.arg)throw new ze({TypeCast:e},"TypeCast: missing arg");return this.deparseValue(e.arg)}BooleanTest(e){let r=e.arg?this.deparseValue(e.arg):void 0;return e.booltesttype==="IS_TRUE"?{[r]:{$eq:true}}:{[r]:{$eq:false}}}deparseFromClause(e){let r={};if(e.length===0)return {from:"",join:r};let t=e[0];if("RangeVar"in t){let n=t.RangeVar;return {from:n.relname??"",schema:n.schemaname,join:r}}if("JoinExpr"in t){let{from:n,schema:i}=this.walkJoinExpr(t.JoinExpr,r);return {from:n,schema:i,join:r}}return {from:"",join:r}}walkJoinExpr(e,r){let t={from:""};if(e.larg)if("RangeVar"in e.larg){let n=e.larg.RangeVar;t={from:n.relname??"",schema:n.schemaname};}else "JoinExpr"in e.larg&&(t=this.walkJoinExpr(e.larg.JoinExpr,r));if(e.rarg&&"RangeVar"in e.rarg){let n=e.rarg.RangeVar,i=n.relname??"",a=n.alias?.aliasname??i,o=e.jointype==="JOIN_LEFT"?"left":"inner",l={from:i,type:o};e.quals&&(l.on=this.deparse(e.quals));let u=a;if(u in r){let p=2;for(;`${u}_${p}`in r;)p++;u=`${u}_${p}`;}r[u]=l;}return t}deparseSortClause(e){if(!e)return [];let r=[];for(let t of e){if(!("SortBy"in t))continue;let n=t.SortBy;if(!n.node)continue;let i=String(this.deparseValue(n.node)),a=n.sortby_dir==="SORTBY_DESC"?"desc":"asc",o={column:i,direction:a};n.sortby_nulls==="SORTBY_NULLS_FIRST"?o.nullsFirst=true:n.sortby_nulls==="SORTBY_NULLS_LAST"&&(o.nullsFirst=false),r.push(o);}return r}deparseLimit(e){if(!e)return;let r=this.deparseValue(e);return typeof r=="number"?r:Number(r)}deparseGroupClause(e){return e?e.map(r=>String(this.deparseValue(r))):[]}isAuthFunc(e){let r=Rr(e);if(r.length===2&&r[0]==="auth"){if(r[1]==="uid")return "{{auth.uid}}";if(r[1]==="jwt")return "{{auth.jwt}}";if(r[1]==="role")return "{{auth.role}}";throw new Error(`Unsupported auth function: "${r.slice(1).join(".")}"`)}return null}isJwtAccessor(e){if(e.kind!=="AEXPR_OP")return null;let r=e.name?.[0]?Sn(e.name[0]):void 0;if(r!=="->"&&r!=="->>")return null;let t=e.rexpr&&"A_Const"in e.rexpr?e.rexpr.A_Const.sval?.sval:void 0;if(t===void 0)return null;if(e.lexpr&&"FuncCall"in e.lexpr)return this.isAuthFunc(e.lexpr.FuncCall.funcname??[])==="{{auth.jwt}}"?`{{auth.jwt.${t}}}`:null;if(e.lexpr&&"A_Expr"in e.lexpr){let n=this.isJwtAccessor(e.lexpr.A_Expr);if(n)return `${n.slice(0,-2)}.${t}}}`}return null}mapOperator(e){switch(e){case "=":return "$eq";case "<>":case "!=":return "$neq";case ">":return "$gt";case ">=":return "$gte";case "<":return "$lt";case "<=":return "$lte";case "~~":return "$like";case "!~~":return "$notLike";default:return}}};var Pn=class s{constructor(e){this.data=e;}appliesTo(e){return this.data.command==="ALL"||this.data.command===e}appliesToRole(e){return this.data.roles.length===0||this.data.roles.includes(e)}toJSON(){return this.data}static fromJSON(e){return new s(e)}};var Dn=class{table;schema;fields;constructor(e,r="public",t=new Map){this.table=e,this.schema=r,this.fields=t;}get(e){return this.fields.get(e)}has(e){return this.fields.has(e)}set(e,r){this.fields.set(e,r);}columns(){return Array.from(this.fields.keys())}all(){return Array.from(this.fields.values())}serializeRow(e){let r={};for(let[t,n]of Object.entries(e)){let i=this.fields.get(t);r[t]=i?i.serialize(n):n;}return r}deserializeRow(e){let r={};for(let[t,n]of Object.entries(e)){let i=this.fields.get(t);r[t]=i?i.deserialize(n):n;}return r}applyDefaults(e){let r={...e};for(let[t,n]of this.fields)!(t in r)&&n.context.defaultFn&&(r[t]=n.context.defaultFn());return r}};var Ch=new Set;function Ah(s){let e=new Map;for(let r of s.stmts??[]){if(!r.stmt||!("CreateEnumStmt"in r.stmt))continue;let t=r.stmt.CreateEnumStmt,n=Rr(t.typeName??[]).join(".");if(!n||!t.vals)continue;let i=Rr(t.vals);e.set(n.toLowerCase(),i);}return e}function Rh(s){let e=new Map;for(let r of s.stmts??[]){if(!r.stmt||!("VariableSetStmt"in r.stmt))continue;let t=r.stmt.VariableSetStmt,n=t.name,i=fh(t.args?.[0]??{});e.set(n,{value:i,local:t.is_local});}return e}function _h(s){let e=new $n,r=new Set,t=[];for(let n of s.stmts??[])if(n.stmt){if("CreatePolicyStmt"in n.stmt){let i=n.stmt.CreatePolicyStmt,a=i.table?.relname??"",o=i.table?.schemaname,l={select:"SELECT",insert:"INSERT",update:"UPDATE",delete:"DELETE"},u=i.cmd_name?l[i.cmd_name]??"ALL":"ALL",p=i.permissive===true,c=[],f=false;for(let b of i.roles??[])if("RoleSpec"in b){let y=b.RoleSpec;y.roletype==="ROLESPEC_PUBLIC"?y.location===-1&&(f=true):y.roletype==="ROLESPEC_CSTRING"&&y.rolename&&c.push(y.rolename);}if(f){let b=o?`${o}.${a}`:a,y=i.policy_name??"",T=`${b}::${y}`;Ch.has(T)||(Ch.add(T),console.warn(`[supalite] policy "${y}" on "${b}" has no TO clause \u2014 applies to all roles (PUBLIC). For clarity, prefer an explicit \`TO <role>\` clause (e.g. \`TO authenticated\`).`));}let m=i.qual?e.deparse(i.qual):void 0,d=i.with_check?e.deparse(i.with_check):void 0,g=new Pn({name:i.policy_name??"",table:a,schema:o,command:u,permissive:p,roles:c,using:m,withCheck:d});t.push(g);}if("AlterTableStmt"in n.stmt){let i=n.stmt.AlterTableStmt;if((i.cmds??[]).some(l=>"AlterTableCmd"in l&&(l.AlterTableCmd.subtype==="AT_EnableRowSecurity"||l.AlterTableCmd.subtype==="AT_ForceRowSecurity"))){let l=i.relation?.relname??"";r.add(l);}}}return {policies:t,tables:r}}function vh(s,e){let r=new Map;for(let t of s.stmts??[]){if(!t.stmt||!("CreateStmt"in t.stmt))continue;let n=t.stmt.CreateStmt,i=n.relation?.relname??"",a=n.relation?.schemaname??"public";if(!i)continue;let o=new Dn(i,a);for(let l of n.tableElts??[]){if(!("ColumnDef"in l))continue;let u=l.ColumnDef,p=u.colname;if(!p)continue;let c=u.typeName?.names?.map(D=>D.String?.sval||D.String?.str).filter(Boolean),f=c&&(c.length===2&&c[0]==="pg_catalog"?c[1]:c[0]);if(!f)continue;let m=!!u.typeName?.arrayBounds?.length,d=Array.isArray(u.typeName?.typmods)?u.typeName.typmods:[],g=D=>d[D]?.A_Const?.ival?.ival??d[D]?.A_Const?.val?.ival?.ival,b={isArray:m};if(Ca(f)&&d.length>0){let D=g(0);typeof D=="number"&&D>0&&(b.lengthConstraint=D);}if(Aa(f)&&d.length>=2){let D=g(0),ce=g(1);typeof D=="number"&&typeof ce=="number"&&D>0&&ce>=0&&(b.numericPrecision={precision:D,scale:ce});}let y=e.get(f.toLowerCase());y&&(b.enumValues=y);let T=Array.isArray(u.constraints)?u.constraints:[],C=T.some(D=>D.Constraint?.contype==="CONSTR_PRIMARY"),w=wa(f)||T.some(D=>D.Constraint?.contype==="CONSTR_IDENTITY"),A=T.some(D=>D.Constraint?.contype==="CONSTR_NOTNULL"),v=T.find(D=>D.Constraint?.contype==="CONSTR_UNIQUE"),R=T.find(D=>D.Constraint?.contype==="CONSTR_GENERATED"),O=T.find(D=>D.Constraint?.contype==="CONSTR_FOREIGN"),_=T.find(D=>D.Constraint?.contype==="CONSTR_CHECK"),I;if(O){let D=O.Constraint,ce=D.pktable?.relname,Xe=D.pktable?.schemaname,jn=D.pk_attrs?.[0]?.String?.sval;ce&&jn&&(I={refSchema:Xe,refTable:ce,refColumn:jn,constraintName:D.conname||void 0});}let K={schema:a,table:i,column:p,pgTypeName:f,nullable:!A&&!C,defaultValue:null,defaultFn:null,isPrimaryKey:C,isUnique:!!v,isSerial:w,isGenerated:!!R,fkRef:I,hasCheck:!!_,checkConstraintName:_?.Constraint?.conname||void 0,uniqueConstraintName:v?.Constraint?.conname||void 0};o.set(p,Nr(K,b));}r.set(`${a}.${i}`,o);}return r}function Oh(s){let e=[];for(let r of s.stmts??[]){if(!r.stmt||!("CreateStmt"in r.stmt))continue;let t=r.stmt.CreateStmt,n=t.relation?.relname??"",i=t.relation?.schemaname??"public";if(n)for(let a of t.tableElts??[]){if("ColumnDef"in a)continue;let o=a;if(!o.Constraint)continue;let l=o.Constraint,u=l.contype;if(u==="CONSTR_UNIQUE"){let p=(l.keys??[]).map(c=>c.String?.sval??c.String?.str).filter(Boolean);if(p.length===0)continue;e.push({schema:i,table:n,kind:"unique",name:l.conname||void 0,columns:p});}else if(u==="CONSTR_CHECK")e.push({schema:i,table:n,kind:"check",name:l.conname||void 0,columns:[]});else if(u==="CONSTR_FOREIGN"){let p=(l.fk_attrs??[]).map(m=>m.String?.sval??m.String?.str).filter(Boolean),c=(l.pk_attrs??[]).map(m=>m.String?.sval??m.String?.str).filter(Boolean),f=l.pktable?.relname;if(!f)continue;e.push({schema:i,table:n,kind:"foreign_key",name:l.conname||void 0,columns:p,refSchema:l.pktable?.schemaname,refTable:f,refColumns:c});}}}return e}function Nh(s){let e=[];for(let r of s.stmts??[]){if(!r.stmt||!("CommentStmt"in r.stmt))continue;let t=r.stmt.CommentStmt,n=t.comment??"";if(!n)continue;let i=t.objtype,a=(t.object?.List?.items??t.object?.items??[]).map(o=>o.String?.sval??o.String?.str).filter(Boolean);if(a.length!==0){if(i==="OBJECT_TABLE"||i==="OBJECT_VIEW"){let[o,l]=a.length>=2?a:["public",a[0]];e.push({schema:o,table:l,text:n});}else if(i==="OBJECT_COLUMN"){let o="public",l,u;a.length>=3?[o,l,u]=a:[l,u]=a,e.push({schema:o,table:l,column:u,text:n});}}}return e}async function yT(s,e={}){let r=await oh(s);return ET(r,e).ddl}function ET(s,e={}){let r=Ah(s),t=vh(s,r),n=Rh(s),i=Oh(s),a=Nh(s),o=new ka(s,{...e,enums:r}),{policies:l,tables:u}=_h(s);if(e.strict)for(let p of l){if(!t.get(`${p.data.schema??"public"}.${p.data.table}`))throw new Error(`Policy "${p.data.name}" references unknown table "${p.data.table}"`);if(!u.has(p.data.table))throw new Error(`RLS is not enabled on table "${p.data.table}"`)}return {ddl:o.deparseQuery(),enums:r,rls:{tables:u,policies:l},schema:t,vars:n,tableConstraints:i,comments:a}}try{let{emitWarning:s}=process;process.emitWarning=(e,...r)=>{if(!e.includes("SQLite is an experimental feature"))return s(e,...r)};}catch{}/*! Bundled license information:
|
|
310
|
+
`;function $c(t=true){return t?Vr(Oc):Oc}var Pc=class{_connection;_rls;config;server;drivers;#e=false;_mailer;_storageAdapter;_transformationAdapter;constructor({connection:e,options:n={},rls:r,...s}){this._connection=e,this._rls=r,this.drivers=gp(n.drivers),this.config=Km(hi,s,{withDefaults:n.defaults??true}),this.server=Jm(this,n.server);}get connection(){if(this._connection instanceof Promise)throw new Error("Connection is not available yet");return this._connection}async init(){if(this.#e)return this;Wm(),this.config.auth?.enabled&&mo(this.config.auth),await this._connection;let e=this.connection;if(e.config.schemaCache??=this.drivers.cache,e.config.baseSchema=[e.config.baseSchema??"",this.config.auth?.enabled&&$c(),this.config.storage?.enabled&&this._storageAdapter&&dr("storage")&&oc()].filter(Boolean).join(`
|
|
311
|
+
|
|
312
|
+
`),this._rls){let n=e;if(typeof n.updateDeparseInfo=="function"){let r=n.config.translation?.deparse;n.updateDeparseInfo({enums:r?.enums??new Map,schema:r?.schema??new Map,vars:r?.vars??new Map,...r,rls:{tables:new Set(this._rls.tables),policies:this._rls.policies}});}}return this.#e=true,this}isValidConfig(e){if(typeof e=="object"&&e!==null&&("connection"in e||"options"in e)){let{connection:n,options:r,...s}=e;return hi.validate(s).valid}return hi.validate(e).valid}getClient(e){return createClient("http://localhost","<nokey>",{...e,global:{...e?.global,fetch:async(n,r)=>{let s=new Request(n,r);return Object.assign(s,{[ss]:true}),await this.fetch(s)}}})}isLocalRequest(e){return ss in e}fetch=async e=>(await this.init(),this.server.fetch(e));getInfoJson(){return JSON.parse(jsonStringify({connection:this.connection?.config??{},config:this.config}))}};var Hm=class extends Error{name="UnableToCreateRuntimeConnection";constructor(e){super(`Unable to create runtime connection: ${e}`);}},zm=class extends Error{constructor(n,r,s){super(`Failed to translate Postgres to SQLite DDL: ${String(s)}`);this.pgSql=n;this.sqliteDdl=r;this.cause=s;}name="InvalidPostgresToSQLiteTranslation"};$o();Yr();var DE=(t={})=>{let e=(n="m")=>[...t.exclude_tables??[],"sqlite_%"].map(r=>r.includes("%")?`${n}.name NOT LIKE '${r}'`:`${n}.name != '${r}'`).join(" AND ");return `WITH table_info AS (SELECT
|
|
313
|
+
json_group_array(
|
|
314
|
+
json_object(
|
|
315
|
+
'name', m.name,
|
|
316
|
+
'sql', m.sql,
|
|
317
|
+
'schema', '',
|
|
318
|
+
'type', m.type,
|
|
319
|
+
'rows', -1,
|
|
320
|
+
'engine', '',
|
|
321
|
+
'collation', ''
|
|
322
|
+
)
|
|
323
|
+
) AS data
|
|
324
|
+
FROM sqlite_master m
|
|
325
|
+
WHERE m.type IN ('table', 'view') AND ${e()}),
|
|
326
|
+
column_info AS (SELECT
|
|
327
|
+
json_group_array(
|
|
328
|
+
json_object(
|
|
329
|
+
'table', m.name,
|
|
330
|
+
'name', p.name,
|
|
331
|
+
'type', CASE
|
|
332
|
+
WHEN INSTR(LOWER(p.type), '(') > 0
|
|
333
|
+
THEN SUBSTR(LOWER(p.type), 1,
|
|
334
|
+
INSTR(LOWER(p.type), '(') - 1)
|
|
335
|
+
ELSE LOWER(p.type)
|
|
336
|
+
END,
|
|
337
|
+
'nullable', CASE
|
|
338
|
+
WHEN p."notnull" = 0 THEN json('true')
|
|
339
|
+
ELSE json('false') END,
|
|
340
|
+
'default_value', p.dflt_value,
|
|
341
|
+
'is_primary_key',
|
|
342
|
+
CASE WHEN p.pk > 0 THEN json('true') ELSE json('false') END,
|
|
343
|
+
'schema', '',
|
|
344
|
+
'ordinal_position', p.cid,
|
|
345
|
+
'collation', '',
|
|
346
|
+
'character_maximum_length',
|
|
347
|
+
CASE
|
|
348
|
+
WHEN LOWER(p.type) LIKE 'char%' OR
|
|
349
|
+
LOWER(p.type) LIKE 'varchar%' THEN
|
|
350
|
+
CASE
|
|
351
|
+
WHEN INSTR(p.type, '(') > 0 THEN
|
|
352
|
+
REPLACE(SUBSTR(p.type, INSTR(p.type, '(') + 1,
|
|
353
|
+
LENGTH(p.type) -
|
|
354
|
+
INSTR(p.type, '(') - 1), ')', '')
|
|
355
|
+
ELSE null
|
|
356
|
+
END
|
|
357
|
+
ELSE null
|
|
358
|
+
END,
|
|
359
|
+
'precision',
|
|
360
|
+
CASE
|
|
361
|
+
WHEN LOWER(p.type) LIKE 'decimal%' OR
|
|
362
|
+
LOWER(p.type) LIKE 'numeric%' THEN
|
|
363
|
+
CASE
|
|
364
|
+
WHEN INSTR(p.type, '(') > 0 THEN
|
|
365
|
+
json_object(
|
|
366
|
+
'precision',
|
|
367
|
+
CAST(SUBSTR(p.type, INSTR(p.type, '(') + 1,
|
|
368
|
+
INSTR(p.type, ',') -
|
|
369
|
+
INSTR(p.type, '(') -
|
|
370
|
+
1) AS INTEGER),
|
|
371
|
+
'scale',
|
|
372
|
+
CAST(SUBSTR(p.type, INSTR(p.type, ',') + 1,
|
|
373
|
+
INSTR(p.type, ')') -
|
|
374
|
+
INSTR(p.type, ',') -
|
|
375
|
+
1) AS INTEGER)
|
|
376
|
+
)
|
|
377
|
+
ELSE null
|
|
378
|
+
END
|
|
379
|
+
ELSE null
|
|
380
|
+
END,
|
|
381
|
+
'is_identity',
|
|
382
|
+
CASE
|
|
383
|
+
WHEN p.pk = 1 AND LOWER(p.type) LIKE '%int%'
|
|
384
|
+
THEN json('true')
|
|
385
|
+
WHEN LOWER((SELECT sql FROM sqlite_master WHERE
|
|
386
|
+
name = m.name)) LIKE
|
|
387
|
+
'%' || p.name || '%autoincrement%' THEN json('true')
|
|
388
|
+
ELSE json('false')
|
|
389
|
+
END,
|
|
390
|
+
'is_generated',
|
|
391
|
+
CASE WHEN p.hidden IN (2, 3)
|
|
392
|
+
THEN json('true') ELSE json('false') END
|
|
393
|
+
)
|
|
394
|
+
) AS data
|
|
395
|
+
FROM sqlite_master m
|
|
396
|
+
JOIN pragma_table_xinfo(m.name) p
|
|
397
|
+
ON m.type IN ('table', 'view') AND ${e()}
|
|
398
|
+
WHERE p.hidden != 1),
|
|
399
|
+
index_info AS (SELECT
|
|
400
|
+
json_group_array(
|
|
401
|
+
json_object(
|
|
402
|
+
'table', idx_data.tbl,
|
|
403
|
+
'name', idx_data.idx_name,
|
|
404
|
+
'unique', CASE
|
|
405
|
+
WHEN idx_data.is_unique = 1 THEN json('true')
|
|
406
|
+
ELSE json('false') END,
|
|
407
|
+
'columns', json(idx_data.cols),
|
|
408
|
+
'schema', ''
|
|
409
|
+
)
|
|
410
|
+
) AS data
|
|
411
|
+
FROM (SELECT
|
|
412
|
+
m.name AS tbl,
|
|
413
|
+
idx.name AS idx_name,
|
|
414
|
+
idx."unique" AS is_unique,
|
|
415
|
+
json_group_array(ic.name ORDER BY ic.seqno) AS cols
|
|
416
|
+
FROM sqlite_master m
|
|
417
|
+
JOIN pragma_index_list(m.name) idx
|
|
418
|
+
ON m.type = 'table' AND ${e()}
|
|
419
|
+
JOIN pragma_index_info(idx.name) ic
|
|
420
|
+
-- only include explicit CREATE INDEX objects; skip autoindexes from PK/UNIQUE constraints
|
|
421
|
+
WHERE idx.origin = 'c' AND idx.name NOT LIKE 'sqlite_autoindex_%'
|
|
422
|
+
GROUP BY m.name, idx.name, idx."unique") idx_data),
|
|
423
|
+
fk_info AS (SELECT
|
|
424
|
+
json_group_array(
|
|
425
|
+
json_object(
|
|
426
|
+
'table', m.name,
|
|
427
|
+
'column', fk."from",
|
|
428
|
+
'ref_table', fk."table",
|
|
429
|
+
'ref_column', fk."to",
|
|
430
|
+
'on_update', fk.on_update,
|
|
431
|
+
'on_delete', fk.on_delete,
|
|
432
|
+
'schema', '',
|
|
433
|
+
'is_visible', true,
|
|
434
|
+
'foreign_key_name',
|
|
435
|
+
'fk_' || m.name || '_' || fk.id || '_' || fk."table",
|
|
436
|
+
'fk_def',
|
|
437
|
+
'FOREIGN KEY (' || fk."from" || ') REFERENCES ' || fk."table" ||
|
|
438
|
+
'(' || fk."to" || ')' ||
|
|
439
|
+
' ON UPDATE ' || fk.on_update || ' ON DELETE ' || fk.on_delete
|
|
440
|
+
)
|
|
441
|
+
) AS data
|
|
442
|
+
FROM sqlite_master m
|
|
443
|
+
JOIN pragma_foreign_key_list(m.name) fk
|
|
444
|
+
ON m.type = 'table' AND ${e()}),
|
|
445
|
+
pk_info AS (SELECT
|
|
446
|
+
json_group_array(
|
|
447
|
+
json_object(
|
|
448
|
+
'table', pk.tbl,
|
|
449
|
+
'columns', json(pk.cols),
|
|
450
|
+
'schema', '',
|
|
451
|
+
'field_count', pk.field_count
|
|
452
|
+
)
|
|
453
|
+
) AS data
|
|
454
|
+
FROM (SELECT
|
|
455
|
+
m.name AS tbl,
|
|
456
|
+
json_group_array(p.name ORDER BY p.pk) AS cols,
|
|
457
|
+
COUNT(p.name) AS field_count
|
|
458
|
+
FROM sqlite_master m
|
|
459
|
+
JOIN pragma_table_info(m.name) p
|
|
460
|
+
ON m.type = 'table' AND ${e()} AND p.pk > 0
|
|
461
|
+
GROUP BY m.name) pk),
|
|
462
|
+
view_info AS (SELECT
|
|
463
|
+
json_group_array(
|
|
464
|
+
json_object('name', m.name, 'sql', m.sql, 'schema', '')
|
|
465
|
+
) AS data
|
|
466
|
+
FROM sqlite_master m
|
|
467
|
+
WHERE m.type = 'view' AND ${e()}),
|
|
468
|
+
trigger_info AS (SELECT
|
|
469
|
+
json_group_array(
|
|
470
|
+
json_object(
|
|
471
|
+
'table', m.tbl_name,
|
|
472
|
+
'name', m.name,
|
|
473
|
+
'sql', m.sql,
|
|
474
|
+
'schema', ''
|
|
475
|
+
)
|
|
476
|
+
) AS data
|
|
477
|
+
FROM sqlite_master m
|
|
478
|
+
WHERE m.type = 'trigger' AND ${e("m")}),
|
|
479
|
+
unique_info AS (SELECT
|
|
480
|
+
json_group_array(
|
|
481
|
+
json_object(
|
|
482
|
+
'table', uc.tbl,
|
|
483
|
+
'name', uc.idx_name,
|
|
484
|
+
'columns', json(uc.cols),
|
|
485
|
+
'schema', ''
|
|
486
|
+
)
|
|
487
|
+
) AS data
|
|
488
|
+
FROM (SELECT
|
|
489
|
+
m.name AS tbl,
|
|
490
|
+
idx.name AS idx_name,
|
|
491
|
+
json_group_array(ic.name ORDER BY ic.seqno) AS cols
|
|
492
|
+
FROM sqlite_master m
|
|
493
|
+
JOIN pragma_index_list(m.name) idx
|
|
494
|
+
ON m.type = 'table' AND ${e()}
|
|
495
|
+
JOIN pragma_index_info(idx.name) ic
|
|
496
|
+
WHERE idx.origin = 'u'
|
|
497
|
+
GROUP BY m.name, idx.name) uc)
|
|
498
|
+
SELECT
|
|
499
|
+
(SELECT data FROM table_info) AS tables,
|
|
500
|
+
(SELECT data FROM column_info) AS columns,
|
|
501
|
+
(SELECT data FROM index_info) AS indexes,
|
|
502
|
+
(SELECT data FROM fk_info) AS foreign_keys,
|
|
503
|
+
(SELECT data FROM pk_info) AS primary_keys,
|
|
504
|
+
(SELECT data FROM view_info) AS views,
|
|
505
|
+
(SELECT data FROM trigger_info) AS triggers,
|
|
506
|
+
(SELECT data FROM unique_info) AS unique_constraints,
|
|
507
|
+
${t.name?`'${t.name}'`:"'sqlite'"} AS database_name,
|
|
508
|
+
${t.version?`'${t.version}'`:"sqlite_version()"} AS version;`};function sn(t){if(!t)return [];try{return Array.isArray(t)?t:JSON.parse(t)}catch{return []}}async function Qm(t,e={}){let r=(await t.exec(DE(e)))?.rows?.[0]||{};return {tables:sn(r.tables),columns:sn(r.columns),indexes:sn(r.indexes),foreign_keys:sn(r.foreign_keys),primary_keys:sn(r.primary_keys),views:sn(r.views),triggers:sn(r.triggers),check_constraints:[],unique_constraints:sn(r.unique_constraints),comments:[],custom_types:[],database_name:r.database_name??"sqlite",version:r.version??""}}var qE=new Set(["AlterTableNode","CreateIndexNode","CreateSchemaNode","CreateTableNode","CreateTypeNode","CreateViewNode","RefreshMaterializedViewNode","DeleteQueryNode","DropIndexNode","DropSchemaNode","DropTableNode","DropTypeNode","DropViewNode","InsertQueryNode","RawNode","SelectQueryNode","UpdateQueryNode","MergeQueryNode"]),Ic=class extends OperationNodeTransformer{constructor(n){super();this.config=n;}#e=new Set;#t=new Set;transformNodeImpl(n,r){if(!qE.has(n.kind))return super.transformNodeImpl(n,r);let s=this.#s(n);for(let o of s)this.#t.add(o);let i=this.#n(n);for(let o of i)this.#e.add(o);try{return super.transformNodeImpl(n,r)}finally{for(let o of i)this.#e.delete(o);for(let o of s)this.#t.delete(o);}}transformSchemableIdentifier(n,r){let s=n.identifier.name,i=n.schema?.name,o=!i&&this.config.appendDefaultSchema&&this.config.defaultSchema&&!this.#t.has(s)&&this.#e.has(s),a=i??(o?this.config.defaultSchema:void 0);if(!a)return {kind:"SchemableIdentifierNode",schema:void 0,identifier:{kind:"IdentifierNode",name:s}};let l=this.config.approach==="snake_case"?"__":".";return {kind:"SchemableIdentifierNode",schema:void 0,identifier:{kind:"IdentifierNode",name:`${a}${l}${s}`}}}#n(n){let r=new Set;if(n?.name&&SchemableIdentifierNode.is(n.name)&&this.#r(n.name,r),n?.from?.froms)for(let s of n.from.froms)this.#i(s,r);if(n?.into&&this.#i(n.into,r),n?.table&&this.#i(n.table,r),n?.joins)for(let s of n.joins)this.#i(s.table,r);return n?.using&&(JoinNode.is(n.using)?this.#i(n.using.table,r):this.#i(n.using,r)),r}#i(n,r){if(TableNode.is(n)){this.#r(n.table,r);return}if(AliasNode.is(n)&&TableNode.is(n.node)){this.#r(n.node.table,r);return}if(ListNode.is(n)){for(let s of n.items)this.#i(s,r);return}if(UsingNode.is(n))for(let s of n.tables)this.#i(s,r);}#r(n,r){let s=n.identifier.name;this.#t.has(s)||r.add(s);}#s(n){let r=new Set;if(n?.with?.expressions)for(let s of n.with.expressions){let i=s?.name?.table?.table?.identifier?.name;i&&r.add(i);}return r}},Po=class{#e;constructor(e){this.#e=new Ic(e);}transformQuery(e){return this.#e.transformNode(e.node)}async transformResult(e){return e.result}};No();Dc();jc();function Ns(t){return t==="migrations"||t==="supabase_migrations.schema_migrations"||t==="supabase_migrations.seed_files"}function Ym(t){return {...t,tables:t.tables.filter(e=>!Ns(e.name)),columns:t.columns.filter(e=>!Ns(e.table)),indexes:t.indexes.filter(e=>!Ns(e.table)),foreign_keys:t.foreign_keys.filter(e=>!Ns(e.table)),primary_keys:t.primary_keys.filter(e=>!Ns(e.table))}}var Io=class{constructor(e,n,r={}){this.conn=e;this.desiredSchema=n;this.options=r;this.differ=new pr,this.planner=new mr;}differ;planner;translationResult;async getDesiredSchema(){let e=await this.conn.translateDdl(this.desiredSchema);return this.translationResult=e,await this.options.onTranslation?.(e),e.ddl}async diff(){let e=await this.conn.introspect({postprocess:false}),n=await this.getDesiredSchema();if(!n||n.trim().length===0)return {current:e,desired:e,diff:{tables:[],columns:[],indexes:[],foreign_keys:[],has_changes:false},plan:{steps:[],warnings:[],unsafe:false}};let{createConnection:r}=await import('@supabase/lite/sqlite'),s=await r({url:":memory:"});try{await s.exec(n);let i=await s.introspect({postprocess:!1}),o=Ym(e),a=Ym(i),l=this.differ.diff(o,a),c=this.planner.plan(l,o,a);return {current:e,desired:i,diff:l,plan:c}}finally{await s.close();}}safeSortPlanSteps(e){return invariant(Array.isArray(e),"steps must be an array"),e.sort((n,r)=>{let s=i=>i===PlanStepType.DROP_COLUMN?1:i===PlanStepType.DROP_TABLE?2:i===PlanStepType.RENAME_TABLE?3:0;return s(n.type)-s(r.type)})}async migratePlan(e,n){if(e.steps.length===0)return;if(e.unsafe&&!n?.force)throw new DataLossError(e.warnings??[]);let r=this.safeSortPlanSteps(e.steps).filter(s=>![PlanStepType.DISABLE_FOREIGN_KEYS,PlanStepType.BEGIN_TRANSACTION,PlanStepType.COMMIT_TRANSACTION,PlanStepType.ENABLE_FOREIGN_KEYS].includes(s.type));await this.conn.transaction(r.map(s=>s.sql),{intent:"migration"});}async migrate(e){let n=await this.diff();return await this.migratePlan(n.plan,e),n}};Gr();var eh=/^\{\{(.+)\}\}$/;function th(t){return typeof t=="string"&&eh.test(t)}function HE(t){return eh.exec(t)[1]}var Zm=Symbol("unresolved");function nh(t,e){let n=HE(t),r=Yt(e,n,Zm);if(r===Zm)throw new Error(`Unresolved variable: {{${n}}}`);return r}function Mt(t,e){let n={};for(let[r,s]of Object.entries(t)){if(r==="$or"||r==="$and"){n[r]=s.map(i=>Mt(i,e));continue}if(r==="$not"){n[r]=Mt(s,e);continue}if(r==="$always"){n[r]=s;continue}if(r==="$exists"){let i=s;n[r]={...i,where:i?.where?Mt(i.where,e):i?.where};continue}if(th(r)){let i=nh(r,e),a=GE(i,s);n.$always=a;continue}if(s!=null&&typeof s=="object"&&!Array.isArray(s)){n[r]=rh(s,e);continue}n[r]=s;}return n}function rh(t,e){let n={};for(let[r,s]of Object.entries(t))r==="$not"&&s!=null&&typeof s=="object"?n[r]=rh(s,e):zE(s)?n[r]={...s,where:s?.where?Mt(s?.where,e):void 0}:th(s)?n[r]=nh(s,e):n[r]=s;return n}function zE(t){return t!=null&&typeof t=="object"&&t.type==="query"}function GE(t,e){for(let[n,r]of Object.entries(e))switch(n){case "$eq":if(t!==r)return false;break;case "$neq":if(t===r)return false;break;case "$in":if(!Array.isArray(r)||!r.includes(t))return false;break;case "$notIn":if(Array.isArray(r)&&r.includes(t))return false;break;default:throw new Error(`Cannot statically evaluate operator ${n} on placeholder key`)}return true}Gr();var jo=class{constructor(e,n,r){this.tables=e;this.policies=n;this.defaultSchema=r;}enforce(e,n){let r=e.from;if(!r||!this.isRlsEnabled(r,e.schema))return e;let s=VE(e.type);if(!s)return e;let i=Yt(n,"auth.role")??"anon",{permissive:o,restrictive:a}=this.resolvePolicies(r,e.schema,s,i);switch(s){case "SELECT":case "DELETE":{let l=this.combineUsing(o,a,n);return {...e,where:sh(e.where,l)}}case "UPDATE":{let l=this.combineUsing(o,a,n),c={...e,where:sh(e.where,l)};if(l.$always===false)return c;let f=this.combineWithCheck(o,a,n,s);if(e.values&&Object.keys(f).length>0){let u=new Set(Object.keys(e.values));this.validateWithCheck(f,e.values,o,a,u);}return c}case "INSERT":{let l=this.combineWithCheck(o,a,n,s);if(e.values){let c=Array.isArray(e.values)?e.values:[e.values];for(let f of c)this.validateWithCheck(l,f,o,a);}return e}default:return e}}isRlsEnabled(e,n){return this.tables.has(e)}resolvePolicies(e,n,r,s){let i=this.policies.filter(o=>o.data.table===e&&this.schemasMatch(o.data.schema,n)&&o.appliesTo(r)&&o.appliesToRole(s));return {permissive:i.filter(o=>o.data.permissive),restrictive:i.filter(o=>!o.data.permissive)}}schemasMatch(e,n){let r=e||this.defaultSchema,s=n||this.defaultSchema;return r===s}combineUsing(e,n,r){if(e.length===0)return {$always:false};let s=e.map(o=>o.data.using).filter(o=>o!=null&&Object.keys(o).length>0).map(o=>Mt(o,r)),i;s.length===0?i={}:s.length===1?i=s[0]:i={$or:s};for(let o of n)if(o.data.using&&Object.keys(o.data.using).length>0){let a=Mt(o.data.using,r);i=Object.keys(i).length===0?a:{$and:[i,a]};}return i}combineWithCheck(e,n,r,s){if(e.length===0)return {$always:false};let i=e.map(a=>a.data.withCheck??(s==="UPDATE"?a.data.using:void 0)).filter(a=>a!=null&&Object.keys(a).length>0).map(a=>Mt(a,r)),o;i.length===0?o={}:i.length===1?o=i[0]:o={$or:i};for(let a of n){let l=a.data.withCheck??(s==="UPDATE"?a.data.using:void 0);if(l&&Object.keys(l).length>0){let c=Mt(l,r);o=Object.keys(o).length===0?c:{$and:[o,c]};}}return o}validateWithCheck(e,n,r,s,i){if(Object.keys(e).length===0)return;if(!Do(e,n,i)){let a=r[0]??s[0];throw a?new zn(a):new Error("RLS policy violation")}}};function VE(t){switch(t){case "query":return "SELECT";case "insert":case "upsert":case "put":return "INSERT";case "update":return "UPDATE";case "delete":return "DELETE";default:return}}function sh(t,e){return !t||Object.keys(t).length===0?e:Object.keys(e).length===0?t:{$and:[t,e]}}function Do(t,e,n){for(let[r,s]of Object.entries(t)){if(r==="$always"){if(s===false)return false;continue}if(r==="$and"){if(!s.every(l=>Do(l,e,n)))return false;continue}if(r==="$or"){if(!s.some(l=>Do(l,e,n)))return false;continue}if(r==="$not"){if(Do(s,e,n))return false;continue}if(n&&!n.has(r))continue;let i=s,o=e[r];for(let[a,l]of Object.entries(i))if(!QE(o,a,l))return false}return true}function QE(t,e,n){switch(e){case "$eq":return t===n;case "$neq":return t!==n;case "$gt":return t>n;case "$gte":return t>=n;case "$lt":return t<n;case "$lte":return t<=n;case "$in":return Array.isArray(n)&&n.includes(t);case "$notIn":return !Array.isArray(n)||!n.includes(t);case "$is":return t===n;case "$isNot":return t!==n;default:throw new Error(`Cannot evaluate operator "${e}" client-side for WITH CHECK`)}}var Lo=class{transformQuery(e){return e.node}transformResult(e){return e.result.rows?Promise.resolve({...e.result,rows:e.result.rows.map(n=>{let r={};for(let s in n){let i=n[s];if(typeof i=="string"&&(i[0]==="{"||i[0]==="["))try{r[s]=JSON.parse(i);}catch{r[s]=i;}else r[s]=i;}return r})}):Promise.resolve(e.result)}};function ih(t){let e={};for(let n in t){let r=t[n];if(typeof r=="string"&&(r[0]==="["||r[0]==="{"))try{e[n]=JSON.parse(r);}catch{e[n]=r;}else e[n]=r;}return e}var Vs=class t extends Connection{dialect="sqlite";deserializeRow(e){return this.config.ddlDialect==="postgres"?ih(e):e}constructor(e={}){super({...e,translation:{...e.translation,schemas:{appendDefaultSchema:false,approach:"quote",defaultSchema:"public",...e.translation?.schemas},deparse:t.parseDeparseInfo(e.translation?.deparse)},introspection:{name:"sqlite",...e.introspection,exclude_tables:Array.from(new Set([...e.introspection?.exclude_tables??[],"sqlite_%","supabase_migrations.%","migrations"]))}});}static parseDeparseInfo(e){try{if(typeof e!="object"||e===null)return {};let n=e?.rls?.tables instanceof Set?e.rls.tables:new Set(e.rls?.tables??[]),r=e?.rls?.policies.map(i=>new on(JSON.parse(JSON.stringify(i)))),s=e?.vars instanceof Map?e.vars:new Map(Object.entries(e.vars??{}));return {rls:{tables:n,policies:r},vars:s}}catch(n){return console.log("error parsing deparse info",n),{}}}updateDeparseInfo(e){this.config.translation={...this.config.translation,deparse:e};}withSqlitePlugins(e=[]){let n=[];return this.config.ddlDialect==="sqlite"&&n.push(new Lo),n.push(new Po(sl({appendDefaultSchema:false,approach:"quote",defaultSchema:"public"},{...this.config.translation?.schemas}))),[...n,...e]}async translateDdl(e){if(e.trim().length===0)return {ddl:e};if(this.config.ddlDialect==="sqlite")return {ddl:e};let n=this.config.translation?.schemas?.defaultSchema&&this.config.translation?.schemas?.appendDefaultSchema?this.config.translation?.schemas?.defaultSchema:false,r=await this.introspect({postprocess:false}).catch(()=>{}),{deparsePostgresDdl:s}=await Promise.resolve().then(()=>(nu(),Oh));return await s(e,{forceDefaultSchema:n,introspection:r,schemaHandling:this.config.translation?.schemas?.approach==="snake_case"?"prefix":"default"})}async introspect(e){ud(typeof e=="object"||e===void 0,"options must be an object");let n=e?.useCache??false;if(e?.postprocess!==false){let i=await this.readCachedIntrospection({useCache:n});if(i)return i}let r=await Qm(this,this.config.introspection),s=this.config.translation?.schemas?.approach==="snake_case"?"__":".";if(this.config.ddlDialect==="postgres"&&e?.postprocess!==false){let i=this.config.translation?.schemas?.defaultSchema??this.config.translation?.schemas?.appendDefaultSchema?"public":void 0,o=(l="table")=>c=>{let f=c[l],u=c.schema??i;return !u&&i&&f.includes(s)&&([u,f]=f.split(s)),{...c,[l]:f,schema:u??i}},a=l=>{let c=o()(l),f=c.ref_table,u=c.ref_schema??i;return f?.includes(s)&&([u,f]=f.split(s)),{...c,ref_table:f,ref_schema:u??i}};r={...r,tables:r.tables.map(o("name")),columns:r.columns.map(o()),indexes:r.indexes.map(o()),primary_keys:r.primary_keys.map(o()),foreign_keys:r.foreign_keys.map(a),views:r.views.map(o("name")),check_constraints:r.check_constraints.map(o("table"))};}return this.config.ddlDialect==="postgres"&&e?.postprocess!==false&&(r=this.mergeDeparseMetadata(r)),r=this.markForeignKeyVisibility(r),r={...r,ddl_dialect:this.config.ddlDialect??"postgres",schema_separator:s},e?.postprocess!==false&&await this.writeCachedIntrospection(r,{useDriver:n}),r}async transaction(e,n){n?.intent==="migration"&&await this.exec("PRAGMA foreign_keys=OFF;"),await this.exec("BEGIN");try{for(let r of e)try{await this.exec(r);}catch(s){throw console.error(`Failed to execute statement: ${r}`),s}await this.exec("COMMIT");}catch(r){throw await this.exec("ROLLBACK"),r}finally{n?.intent==="migration"&&(await this.exec("PRAGMA foreign_keys=ON;"),await this.clearSchemaCache());}}async close(){}mergeDeparseMetadata(e){let n=this.config.translation?.deparse;if(!n?.schema)return e;let r=e.columns.map(l=>({...l})),s=e.foreign_keys.map(l=>({...l})),i=[...e.unique_constraints??[]],o=[...e.check_constraints??[]];for(let[,l]of n.schema)for(let c of l.all()){let f=c.context,u=r.find(d=>d.table===f.table&&d.name===f.column);if(u&&(u.pg_type=f.pgTypeName,f.isGenerated!==void 0&&(u.is_generated=f.isGenerated)),f.fkRef?.constraintName){let d=s.find(p=>p.table===f.table&&p.column===f.column&&p.ref_table===f.fkRef.refTable&&p.ref_column===f.fkRef.refColumn);d&&(d.foreign_key_name=f.fkRef.constraintName);}f.uniqueConstraintName&&i.push({schema:f.schema,table:f.table,name:f.uniqueConstraintName,columns:[f.column]}),f.hasCheck&&o.push({schema:f.schema,table:f.table,expression:"",name:f.checkConstraintName,column:f.column});}for(let l of n.tableConstraints??[])if(l.kind==="unique")i.push({schema:l.schema,table:l.table,name:l.name??"",columns:l.columns});else if(l.kind==="check")o.push({schema:l.schema,table:l.table,expression:"",name:l.name});else if(l.kind==="foreign_key"&&l.name){let c=l.refTable;for(let f=0;f<l.columns.length;f++){let u=s.find(d=>d.table===l.table&&d.column===l.columns[f]&&d.ref_table===c&&d.ref_column===(l.refColumns?.[f]??""));u&&(u.foreign_key_name=l.name);}}let a=[...e.comments??[],...n.comments??[]];return {...e,columns:r,foreign_keys:s,unique_constraints:i,check_constraints:o,comments:a}}markForeignKeyVisibility(e){let n=new Set(e.views.map(s=>s.name)),r=s=>s.startsWith("private_")?n.has(s.slice(8)):true;return {...e,foreign_keys:e.foreign_keys.map(s=>({...s,is_visible:r(s.table)&&r(s.ref_table)}))}}createMigrator(e){let n=[this.config.baseSchema,e].filter(Boolean).join(`
|
|
509
|
+
|
|
510
|
+
`);return new Io(this,n,{onTranslation:async r=>{if(this.config.translation){let s={enums:r.enums,rls:r.rls,schema:r.schema,vars:r.vars,tableConstraints:r.tableConstraints??[],comments:r.comments??[]};this.config.translation.deparse=s;}}})}get maxBoundParameters(){return this.config.maxBoundParameters??100}assertParamLimit(e){let n=e?.length??0,r=this.maxBoundParameters;if(!(n<=r))throw Object.assign(new Error(`Query exceeds max bound parameters (${n} > ${r}). SQLite drivers vary in how many parameters they accept per statement; @supabase/lite enforces a conservative limit of ${r} for portability. Split the query (e.g. chunk large .in() filters or batch INSERTs) on the caller.`),{code:"54000"})}prepareBindParams(e){return this.assertParamLimit(e),this.normalizeBindParams(e)}normalizeBindParams(e){if(!e||e.length===0)return [];let n=[];for(let r=0;r<e.length;r++){let s=e[r];if(s===void 0)continue;if(s===null){n.push(s);continue}let i=typeof s;if(i==="boolean"){n.push(s?1:0);continue}if(i==="number"||i==="bigint"||i==="string"){n.push(s);continue}if(s instanceof Uint8Array||s instanceof ArrayBuffer||s instanceof Date){n.push(s);continue}throw new Error(`Cannot bind value at parameter ${r+1}: unsupported type ${Array.isArray(s)?"array":i}`)}return n}normalizeDbError(e){let n=e,r=n?.cause?.code??n?.code,s=n?.cause?.message??n?.message??String(e);if(r==="SQLITE_CONSTRAINT_NOTNULL")return Object.assign(new Error(s),{code:"23502",detail:s});if(r==="SQLITE_CONSTRAINT_UNIQUE"||r==="SQLITE_CONSTRAINT_PRIMARYKEY")return Object.assign(new Error(s),{code:"23505",detail:s});if(r==="SQLITE_CONSTRAINT_FOREIGNKEY")return Object.assign(new Error(s),{code:"23503",detail:s});if(typeof s=="string"){if(/too many SQL variables/i.test(s)){let a=this.maxBoundParameters;return Object.assign(new Error(`Query exceeds SQLite bound-parameter limit. @supabase/lite enforces a conservative limit of ${a} for portability across drivers. Split the query (e.g. chunk large .in() filters or batch INSERTs) on the caller.`),{code:"54000",detail:s})}let i=s.match(/no such table:\s*([A-Za-z0-9_.]+)/i);if(i){let a=i[1],l=a.lastIndexOf("."),c=l>=0?a.slice(0,l):void 0,f=l>=0?a.slice(l+1):a;return new RelationNotFoundError(c,f)}let o=s.match(/no such column:\s*([A-Za-z0-9_.]+)/i);if(o)return Object.assign(new Error(`column ${o[1]} does not exist`),{code:"42703",detail:s})}return e}async onPostgrestAST(e,n){if(this.config.ddlDialect==="sqlite")return e.schema=void 0,this.applyRls(e,n);let r=this.config.translation?.schemas?.appendDefaultSchema,s=this.config.translation?.schemas?.defaultSchema;if(e.schema&&e.schema===s&&!r?e.schema=void 0:!e.schema&&s&&r&&(e.schema=s),!e.from)return e;let i=await this.introspect({useCache:true}),o=e.schema??(r&&s?s:""),a=e.from;if(!(i.tables.some(c=>c.name===a&&(c.schema??"")===o)||i.views.some(c=>c.name===a&&(c.schema??"")===o))){if(!(i.tables.some(f=>f.name===a&&["","public",s].includes(f.schema??""))||i.views.some(f=>f.name===a&&["","public",s].includes(f.schema??""))))throw new RelationNotFoundError(o,a);e.schema=void 0;}return this.applyRls(e,n)}applyRls(e,n){let r=this.config.translation?.deparse?.rls;if(!r||!n)return e;let s=this.config.translation?.schemas?.defaultSchema||void 0;return new jo(r.tables,r.policies,s).enforce(e,n)}};var Go=class extends Vs{constructor(n){super({...n,introspection:{...n.introspection,version:"3.47.0"}});this.config=n;}dialect="sqlite";driver=null;kysely=null;fetch(n,r){let s=n instanceof URL?new URL(n.toString(),this.config.host):new URL(n,this.config.host);return fetch(s,{...r,headers:{"Content-Type":"application/json",Accept:"application/json",Authorization:`Bearer ${this.config.token}`,...r?.headers}})}async introspect(n){let r=new URLSearchParams({useCache:n?.useCache?"1":"0",postprocess:n?.postprocess?"1":"0"}),s=await this.fetch(`/v1/projects/${this.config.projectRef}/db/introspect?${r}`),i=await s.text();if(!s.ok)throw console.error(i),new Error(`Failed to get project introspect: ${s.status} ${s.statusText}`);try{let o=JSON.parse(i);if(!o)throw new Error("Failed to get project introspect");return o}catch(o){throw console.error(o),console.log(i),new Error(`Failed to parse introspect response: "${i}"`)}}async transaction(n,r){let s=await this.fetch(`/v1/projects/${this.config.projectRef}/db/transaction?intent=${r?.intent??"migration"}`,{method:"POST",body:JSON.stringify({statements:n})});if(!s.ok)throw new Error(`Failed to execute transaction: ${s.status} ${s.statusText}`)}async exec(n,...r){let s=await this.fetch(`/v1/projects/${this.config.projectRef}/db/exec`,{method:"POST",body:JSON.stringify({statement:n,parameters:r})}),i=await s.text();if(!s.ok)throw console.error(i),new Error(`Failed to execute statement: ${s.status} ${s.statusText}`);try{return JSON.parse(i)}catch(o){throw console.error(o),new Error(`Failed to parse exec response: "${i}"`)}}async close(){}};function j_(t){return new Go(t)}nu();Yr();try{let{emitWarning:t}=process;process.emitWarning=(e,...n)=>{if(!e.includes("SQLite is an experimental feature"))return t(e,...n)};}catch{}/*! Bundled license information:
|
|
344
511
|
|
|
345
512
|
aws4fetch/dist/aws4fetch.esm.mjs:
|
|
346
513
|
(**
|
|
347
514
|
* @license MIT <https://opensource.org/licenses/MIT>
|
|
348
515
|
* @copyright Michael Hart 2024
|
|
349
516
|
*)
|
|
350
|
-
*/export{
|
|
517
|
+
*/export{Pc as App,co as AwsSesEmailDriver,Go as CloudConnection,io as CloudflareKvCacheDriver,ll as Connection,Gm as DataLossError,ls as InMemoryEmailDriver,Zn as InMemoryLruCacheDriver,zm as InvalidPostgresToSQLiteTranslation,Vm as MigrationError,er as NoopEmailDriver,cs as NoopSmsDriver,Nc as PlanStepType,oo as RedisCacheDriver,Zr as RelationNotFoundError,ao as ResendEmailDriver,uo as SendmailEmailDriver,Vs as SqliteConnection,Hm as UnableToCreateRuntimeConnection,YT as checkPasswordStrength,Vr as cleanSql,j_ as cloud,gp as createAppDrivers,JT as ensureVar,LT as filterSearchParams,Il as formatSendmailMessage,pd as fuzzyMatch,$c as getAuthSchemaSql,Yt as getPath,HT as getStatementsArray,ud as invariant,CT as isBooleanLike,ww as isBun,XT as isEmail,rl as isEqual,dr as isExperimentalEnabled,MT as isNode,ld as isObject,ad as isPlainObject,vT as isPrimitive,RT as isString,IT as jsonStringify,qm as listEnabledExperimentals,WT as measureTime,sl as mergeObject,bw as mergeObjectWith,al as normalizeDefault,ol as normalizeSql,Ew as normalizeString,il as normalizeType,$T as objectDiff,NT as omit,jT as params,ok as parseBigInt,qi as patternMatch,PT as pick,kT as pipe,AT as pipeEach,P as quote,QT as randomString,sk as replacePlaceholders,gs as requireAuth,Xl as resolveAuth,AE as setExperimental,yw as setPath,nk as slugify,tk as snakeToPascalWithSpaces,zT as splitSqlStatements,RE as studioRouteHandler,FT as threw,BT as threwAsync,kh as translatePostgresDdl,rk as truncate,qT as trySync,ZT as ucFirst,ek as ucFirstAll,lk as uuid};
|