@prisma/studio-core 0.19.1 → 0.19.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.
@@ -6,5 +6,5 @@ function require(mod) {
6
6
  if (mod === 'react-dom') return ___react_dom___;
7
7
  throw new Error(`Unknown module ${mod}`);
8
8
  }
9
- import{a as m}from"./chunk-UQDXNCLC.js";import{c as $,d as B}from"./chunk-DTFJIWXL.js";import{a as w,b as q,d as C,e as z,h as D,i as L,j as Q,k as N,l as F}from"./chunk-PI3N7ZW6.js";import{a as G}from"./chunk-N6ZIYSZ5.js";import{A as I,C as O,D as Y,p as U,q as p,t as H,u as j,x as v,y as P,z as k}from"./chunk-TB3YFW43.js";var J={bool:{group:"boolean"},boolean:{group:"boolean"},bytea:{group:"string"},char:{group:"string"},citext:{group:"string"},date:{format:"YYYY-MM-DD",group:"datetime"},interval:{group:"string"},name:{group:"string"},varchar:{group:"string"},text:{group:"string"},time:{format:"HH:mm:ss.SSS",group:"time"},timestamp:{format:"YYYY-MM-DD HH:mm:ss.SSS",group:"datetime"},timestamptz:{format:"YYYY-MM-DD HH:mm:ss.SSSZZ",group:"datetime"},"timestamp without time zone":{format:"YYYY-MM-DD HH:mm:ss.SSS",group:"datetime"},"timestamp with time zone":{format:"YYYY-MM-DD HH:mm:ss.SSSZZ",group:"datetime"},timetz:{format:"HH:mm:ss.SSSZZ",group:"time"},"time without time zone":{format:"HH:mm:ss.SSS",group:"time"},"time with time zone":{format:"HH:mm:ss.SSSZZ",group:"time"},uuid:{format:"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",group:"raw"},int2:{group:"numeric"},int4:{group:"numeric"},int8:{group:"numeric"},smallint:{group:"numeric"},integer:{group:"numeric"},bigint:{group:"numeric"},decimal:{group:"numeric"},numeric:{group:"numeric"},real:{group:"numeric"},float4:{group:"numeric"},float8:{group:"numeric"},"double precision":{group:"numeric"},json:{group:"json"},jsonb:{group:"json"}};function T(r){return v({...r,Adapter:j,QueryCompiler:H})}function K(r){let e=N(r),n=e.normalizedSearchTerm;if(n.length<2)return e;let o=new Set(e.predicates.flatMap(l=>l.kind==="text-like"?[l.column]:[])),i=64-o.size;if(i<=0)return e;let u=`%${ie(n)}%`,a=[];for(let l of Object.values(r.table.columns))if(!o.has(l.name)&&(a.push({column:l.name,kind:"text-like",pattern:u}),a.length>=i))break;return a.length===0?e:{...e,predicates:[...e.predicates,...a]}}function ie(r){return r.replaceAll("%","\\%").replaceAll("_","\\_")}function Z(r,e){let{rows:n,table:{columns:o,name:i,schema:u}}=r,a=T(e);return k(a.withSchema(u).insertInto(i).values(O({columns:o,context:"insert",supportsDefaultKeyword:!0,values:n})).returning(Object.keys(o)).returning(M().as("__ps_inserted_at__")))}function W(r,e){let{filter:n={after:"and",filters:[],kind:"FilterGroup"},fullTableSearchTerm:o,pageIndex:i,pageSize:u,sortOrder:a,table:{columns:l,name:t,schema:s}}=r,_=T(e),g=Y(n.filters,l),y=K({searchTerm:o,table:r.table}),b=y.predicates.length>0?c=>c.and([g(c),F(y,{dialect:"postgres"})(c)]):g,h="__ps_agg__",A="__ps_count__",x="__ps_search_guardrails__";if(L(o))return k(_.with(x,c=>c.selectNoFrom(d=>[d.fn("set_config",[p.lit("statement_timeout"),p.lit(`${5e3}ms`),p.lit(!0)]).as("__ps_statement_timeout__"),d.fn("set_config",[p.lit("lock_timeout"),p.lit(`${100}ms`),p.lit(!0)]).as("__ps_lock_timeout__")])).with(h,c=>c.withSchema(s).selectFrom(t).innerJoin(p.table(x).as(x),d=>d.onTrue()).where(b).select(d=>d.cast(d.fn.coalesce(d.fn.countAll(),p.lit(0)),"text").as(A))).withSchema(s).selectFrom(t).innerJoin(x,c=>c.onTrue()).innerJoin(h,c=>c.onTrue()).where(b).select(`${h}.${A}`).select(Object.keys(l)).$call(c=>a.reduce((d,f)=>{let S=l[f.column];return S?.datatype.group==="numeric"&&!S.datatype.isArray?d.orderBy(p`cast(${p.ref(f.column)} as numeric)`,f.direction):d.orderBy(f.column,f.direction)},c)).limit(u).offset(p.lit(BigInt(i)*BigInt(u))));let E=_.withSchema(s).selectFrom(t).where(b).select(c=>c.cast(c.fn.coalesce(c.fn.countAll(),p.lit(0)),"text").as(A));return k(_.with(h,()=>E).withSchema(s).selectFrom(t).innerJoin(h,c=>c.onTrue()).where(b).select(`${h}.${A}`).select(Object.keys(l)).$call(c=>a.reduce((d,f)=>{let S=l[f.column];return S?.datatype.group==="numeric"&&!S.datatype.isArray?d.orderBy(p`cast(${p.ref(f.column)} as numeric)`,f.direction):d.orderBy(f.column,f.direction)},c)).limit(u).offset(p.lit(BigInt(i)*BigInt(u))))}function De(){return[{created_at:new Date("2025-01-26T21:56:12.345Z"),deleted_at:null,id:1,name:"John Doe",__ps_count__:"2",role:"admin",name_role:"Jonn Doe - admin"},{created_at:new Date("2025-01-26T20:56:12.345Z"),deleted_at:null,id:2,name:"Jane Doe",__ps_count__:"2",role:"poweruser",name_role:"Jane Doe - poweruser"}]}function V(r,e){let{changes:n,row:o,table:{columns:i,name:u,schema:a}}=r,l=T(e);return k(l.withSchema(a).updateTable(u).set(O({columns:i,context:"update",supportsDefaultKeyword:!0,values:n})).$call(I([o],i)).returning(Object.keys(i)).returning(M().as("__ps_updated_at__")))}function X(r,e){let{rows:n,table:{columns:o,name:i,schema:u}}=r,a=T(e);return k(a.withSchema(u).deleteFrom(i).$call(I(n,o)).returning(Object.keys(o)).returning(M().as("__ps_deleted_at__")))}function M(){let r=U();return r.cast(r.fn("floor",[r(r.fn("extract",[p`epoch from now()`]),"*",1e3)]),"text")}function ee(r){return p`(select coalesce(json_agg(agg), '[]') from ${r} as agg)`}var ue="r",ce="v",pe=[ue,ce];function te(r){return k(T(r).selectFrom("pg_catalog.pg_class as cls").innerJoin("pg_catalog.pg_namespace as ns","cls.relnamespace","ns.oid").$call(me).where("cls.relkind","in",pe).select(e=>["ns.nspname as schema","cls.relname as name",ee(e.selectFrom("pg_catalog.pg_attribute as att").innerJoin("pg_catalog.pg_type as typ","typ.oid","att.atttypid").innerJoin("pg_catalog.pg_namespace as tns","tns.oid","typ.typnamespace").leftJoin("pg_catalog.pg_constraint as pk_con",n=>n.on("pk_con.contype","=","p").onRef("pk_con.conrelid","=","cls.oid").on(o=>o("att.attnum","=",o.fn.any("pk_con.conkey")))).leftJoin("pg_catalog.pg_constraint as fk_con",n=>n.on("fk_con.contype","=","f").onRef("fk_con.conrelid","=","cls.oid").on(o=>o("att.attnum","=",o.fn.any("fk_con.conkey")))).leftJoin("pg_catalog.pg_class as fk_cls","fk_cls.oid","fk_con.confrelid").leftJoin("pg_catalog.pg_namespace as fk_ns","fk_ns.oid","fk_cls.relnamespace").leftJoin("pg_catalog.pg_attribute as fk_att",n=>n.onRef("fk_att.attrelid","=","fk_cls.oid").on(o=>o("fk_att.attnum","=",o.fn.any("fk_con.confkey")))).leftJoin("pg_catalog.pg_attrdef as def",n=>n.onRef("def.adrelid","=","att.attrelid").onRef("def.adnum","=","att.attnum")).whereRef("att.attrelid","=","cls.oid").where("att.attnum",">=",0).where("att.attisdropped","!=",!0).select(["att.attname as name","fk_att.attname as fk_column","fk_cls.relname as fk_table","fk_ns.nspname as fk_schema","tns.nspname as datatype_schema","typ.typname as datatype"]).select(n=>[n("att.attidentity","!=","").or(n("def.adbin","is not",null).and(n.fn("pg_get_expr",["def.adbin","def.adrelid"]),"like","nextval(%")).$castTo().as("autoinc"),n("att.attgenerated","!=","").$castTo().as("computed"),n.fn("pg_get_expr",["def.adbin","def.adrelid"]).as("default"),n("att.attnotnull","!=",!0).$castTo().as("nullable"),n.fn.coalesce(n.selectFrom("pg_catalog.pg_enum as enm").whereRef("enm.enumtypid","=","typ.oid").select(o=>o.fn.jsonAgg(o.ref("enm.enumlabel")).as("o")),p`'[]'`).as("options"),n.fn("array_position",["pk_con.conkey","att.attnum"]).as("pk")])).as("columns")]))}function re(){return[{schema:"zoo",name:"animals",columns:[{autoinc:!0,computed:!1,datatype:"int4",datatype_schema:"pg_catalog",default:"nextval('zoo.animals_id_seq'::regclass)",fk_column:null,fk_schema:null,fk_table:null,name:"id",nullable:!1,options:[],pk:1},{autoinc:!1,computed:!1,datatype:"text",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"name",nullable:!0,options:[],pk:null}]},{schema:"public",name:"users",columns:[{autoinc:!0,computed:!1,datatype:"int4",datatype_schema:"pg_catalog",default:"nextval('users_id_seq'::regclass)",fk_column:null,fk_schema:null,fk_table:null,name:"id",nullable:!1,options:[],pk:1},{autoinc:!1,computed:!1,datatype:"timestamp",datatype_schema:"pg_catalog",default:"CURRENT_TIMESTAMP",fk_column:null,fk_schema:null,fk_table:null,name:"created_at",nullable:!0,options:[],pk:null},{autoinc:!1,computed:!1,datatype:"timestamp",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"deleted_at",nullable:!0,options:[],pk:null},{autoinc:!1,computed:!1,datatype:"varchar",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"role",nullable:!0,options:[],pk:null},{autoinc:!1,computed:!1,datatype:"varchar",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"name",nullable:!0,options:[],pk:null},{autoinc:!1,computed:!0,datatype:"text",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"name_role",nullable:!1,options:[],pk:null}]},{schema:"public",name:"composite_pk",columns:[{autoinc:!1,computed:!1,datatype:"uuid",datatype_schema:"pg_catalog",default:"gen_random_uuid()",fk_column:null,fk_schema:null,fk_table:null,name:"id",nullable:!1,options:[],pk:1},{autoinc:!1,computed:!1,datatype:"text",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"name",nullable:!0,options:[],pk:2},{autoinc:!1,computed:!1,datatype:"timestamp",datatype_schema:"pg_catalog",default:"now()",fk_column:null,fk_schema:null,fk_table:null,name:"created_at",nullable:!0,options:[],pk:null}]}]}function ae(){let r=T();return k(r.selectNoFrom(r.fn("current_setting",[p.lit("timezone")]).as("timezone")))}function ne(){return[{timezone:"UTC"}]}function me(r){return r.where("ns.nspname","!~","^pg_").where("ns.nspname","!=","information_schema")}function $e(r){let{executor:e,...n}=r,o=D(),i=typeof e.lintSql=="function";async function u(a){try{let l=te(n),t=ae(),[[s,_],[g,y]]=await Promise.all([e.execute(l,a),e.execute(t,a)]);if(s)return m({error:s,query:l});if(g)return m({error:g,query:t});let b=y[0]?.timezone;return b?[null,se({query:l,tables:_,timezone:b})]:m({error:new Error("Timezone not found"),query:t})}catch(l){return m({error:l})}}return{defaultSchema:"public",capabilities:{fullTableSearch:!0,sqlDialect:"postgresql",sqlEditorAutocomplete:!0,sqlEditorLint:!0},async introspect(a){return await u(a)},async query(a,l){try{let t=W(a,n),[s,_]=await Q({executor:e,options:l,query:t,searchTerm:a.fullTableSearchTerm,state:o});return s?m({error:s,query:t}):[null,{filteredRowCount:_[0]?.__ps_count__||"0",rows:_,query:t}]}catch(t){return m({error:t})}},async raw(a,l){return await fe(e,a,l)},async sqlSchema(a,l){let[t,s]=await u(l);return t?[t]:[null,G({defaultSchema:"public",dialect:"postgresql",introspection:s})]},async sqlLint(a,l){if(i&&typeof e.lintSql=="function")try{let[t,s]=await e.lintSql(a,l);if(!t)return[null,s];if(!oe(t))return m({error:t});le(t)&&(i=!1)}catch(t){if(!oe(t))return m({error:t});le(t)&&(i=!1)}return await de(e,a,l)},async insert(a,l){try{let t=Z(a,n),[s,_]=await e.execute(t,l);return s?m({error:s,query:t}):[null,{rows:_,query:t}]}catch(t){return m({error:t})}},async update(a,l){try{let t=V(a,n),[s,_]=await e.execute(t,l);if(s)return m({error:s,query:t});let[g]=_;return g?[null,{row:g,query:t}]:m({error:new Error("Update failed"),query:t})}catch(t){return m({error:t})}},async delete(a,l){try{let t=X(a,n),[s]=await e.execute(t,l);return s?m({error:s,query:t}):[null,{...a,query:t}]}catch(t){return m({error:t})}}}}function oe(r){if(!(r instanceof Error))return!1;let e=r.message.toLowerCase();return e.includes("invalid procedure")||e.includes("unexpected server error")||e.includes("internal server error")||e.includes("bad gateway")||e.includes("service unavailable")||e.includes("not supported")||e.includes("method not allowed")}function le(r){if(!(r instanceof Error))return!1;let e=r.message.toLowerCase();return e.includes("invalid procedure")||e.includes("unexpected server error")||e.includes("internal server error")||e.includes("not supported")||e.includes("method not allowed")}async function de(r,e,n){let o=$(e.sql);if(!o.ok)return[null,{diagnostics:[o.diagnostic],schemaVersion:e.schemaVersion}];let i=[];for(let u of o.statements)try{let a=P(`EXPLAIN (FORMAT JSON) ${u.statement}`),[l]=await r.execute(a,n);if(!l)continue;i.push(...B({error:l,positionOffset:u.from,sql:u.statement}))}catch(a){i.push(...B({error:a,positionOffset:u.from,sql:u.statement}))}return[null,{diagnostics:i,schemaVersion:e.schemaVersion}]}async function fe(r,e,n){try{let o=P(e.sql),[i,u]=await r.execute(o,n);return i?m({error:i,query:o}):[null,{query:o,rowCount:u.length,rows:u}]}catch(o){return m({error:o})}}function se(r){let{query:e,tables:n,timezone:o}=r;return n.reduce((i,u)=>{let{schemas:a}=i,{columns:l,name:t,schema:s}=u,_=l.reduce((g,y)=>{let{autoinc:b,computed:h,datatype:A,datatype_schema:x,default:R,name:E,options:c,nullable:d}=y,f=A.startsWith("_"),S=f?A.slice(1):A;return{...g,[E]:{datatype:{...J[S]||{group:c.length>0?"enum":"raw"},isArray:f,isNative:x==="pg_catalog",name:f?`${S}[]`:S,options:c,schema:x},defaultValue:R,fkColumn:y.fk_column,fkSchema:y.fk_schema,fkTable:y.fk_table,isAutoincrement:b,isComputed:h,isRequired:!d&&!b&&!h&&R==null,name:E,nullable:d,pkPosition:y.pk,schema:s,table:t}}},{});return a[s]===void 0&&(a[s]={name:s,tables:{}}),a[s].tables[t]={columns:_,name:t,schema:s},i},{filterOperators:_e,query:e,schemas:{public:{name:"public",tables:{}}},timezone:o})}var _e=["=","!=",">",">=","<","<=","is","is not","like","not like","ilike","not ilike"];function Je(){let r=re(),[{timezone:e}]=ne();return se({tables:r,timezone:e,query:{parameters:[],sql:"<mocked>"}})}export{K as a,Z as b,W as c,De as d,V as e,X as f,te as g,re as h,ae as i,ne as j,$e as k,Je as l};
10
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/postgres-core/datatype.ts", "../data/postgres-core/builder.ts", "../data/postgres-core/full-table-search.ts", "../data/postgres-core/dml.ts", "../node_modules/.pnpm/kysely@0.28.10/node_modules/kysely/dist/esm/helpers/postgres.js", "../data/postgres-core/introspection.ts", "../data/postgres-core/adapter.ts"],
  "sourcesContent": ["import type { DataType } from \"../adapter\";\n\nexport const POSTGRESQL_DATA_TYPES_TO_METADATA: Record<\n  string,\n  Pick<DataType, \"format\" | \"group\">\n> = {\n  bool: {\n    group: \"boolean\",\n  },\n  boolean: {\n    group: \"boolean\",\n  },\n  bytea: {\n    group: \"string\",\n  },\n  char: {\n    group: \"string\",\n  },\n  citext: {\n    group: \"string\",\n  },\n  /**\n   * @example '2025-04-14'\n   */\n  date: {\n    format: \"YYYY-MM-DD\",\n    group: \"datetime\",\n  },\n  /**\n   * @example '1 day 2 hours'\n   */\n  interval: {\n    group: \"string\",\n  },\n  name: {\n    group: \"string\",\n  },\n  varchar: {\n    group: \"string\",\n  },\n  text: {\n    group: \"string\",\n  },\n  /**\n   * short form of `time without time zone`.\n   *\n   * @example '14:30:00'\n   */\n  time: {\n    format: \"HH:mm:ss.SSS\",\n    group: \"time\",\n  },\n  /**\n   * short form of `timestamp without time zone`.\n   *\n   * @example '2025-04-14 14:30:00'\n   */\n  timestamp: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\n    group: \"datetime\",\n  },\n  /**\n   * short form of `timestamp with time zone`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  timestamptz: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSSZZ\",\n    group: \"datetime\",\n  },\n  /**\n   * long form of `timestamp`.\n   *\n   * @example '2025-04-14 14:30:00'\n   */\n  \"timestamp without time zone\": {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\n    group: \"datetime\",\n  },\n  /**\n   * long form of `timestamptz`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  \"timestamp with time zone\": {\n    format: \"YYYY-MM-DD HH:mm:ss.SSSZZ\",\n    group: \"datetime\",\n  },\n  /**\n   * short form of `time with time zone`.\n   *\n   * @example '14:30:00+00'\n   */\n  timetz: {\n    format: \"HH:mm:ss.SSSZZ\",\n    group: \"time\",\n  },\n  /**\n   * long form of `time`.\n   *\n   * @example '14:30:00'\n   */\n  \"time without time zone\": {\n    format: \"HH:mm:ss.SSS\",\n    group: \"time\",\n  },\n  /**\n   * long form of `timetz`.\n   *\n   * @example '14:30:00+00'\n   */\n  \"time with time zone\": {\n    format: \"HH:mm:ss.SSSZZ\",\n    group: \"time\",\n  },\n  uuid: {\n    format: \"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\",\n    group: \"raw\",\n  },\n  int2: {\n    group: \"numeric\",\n  },\n  int4: {\n    group: \"numeric\",\n  },\n  int8: {\n    group: \"numeric\",\n  },\n  smallint: {\n    group: \"numeric\",\n  },\n  integer: {\n    group: \"numeric\",\n  },\n  bigint: {\n    group: \"numeric\",\n  },\n  decimal: {\n    group: \"numeric\",\n  },\n  numeric: {\n    group: \"numeric\",\n  },\n  real: {\n    group: \"numeric\",\n  },\n  float4: {\n    group: \"numeric\",\n  },\n  float8: {\n    group: \"numeric\",\n  },\n  \"double precision\": {\n    group: \"numeric\",\n  },\n  json: {\n    group: \"json\",\n  },\n  jsonb: {\n    group: \"json\",\n  },\n};\n", "import { type Kysely, PostgresAdapter, PostgresQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getPostgreSQLBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder({\n    ...requirements,\n    Adapter: PostgresAdapter,\n    QueryCompiler: PostgresQueryCompiler,\n  });\n}\n", "import type { Table } from \"../adapter\";\nimport {\n  buildFullTableSearchPlan as buildBaseFullTableSearchPlan,\n  createFullTableSearchExecutionState,\n  executeQueryWithFullTableSearchGuardrails,\n  FULL_TABLE_SEARCH_MAX_TEXT_COLUMNS,\n  FULL_TABLE_SEARCH_MIN_QUERY_LENGTH,\n  FULL_TABLE_SEARCH_MYSQL_LOCK_WAIT_TIMEOUT_SECONDS,\n  FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS,\n  FULL_TABLE_SEARCH_TIMEOUT_MESSAGE,\n  FULL_TABLE_SEARCH_TIMEOUT_MS,\n  type FullTableSearchPlan,\n  type FullTableSearchPredicate,\n  FullTableSearchTimeoutError,\n  getFullTableSearchExpression,\n  isFullTableSearchRequest,\n} from \"../full-table-search\";\n\nexport {\n  createFullTableSearchExecutionState,\n  executeQueryWithFullTableSearchGuardrails,\n  FULL_TABLE_SEARCH_MAX_TEXT_COLUMNS,\n  FULL_TABLE_SEARCH_MIN_QUERY_LENGTH,\n  FULL_TABLE_SEARCH_MYSQL_LOCK_WAIT_TIMEOUT_SECONDS,\n  FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS,\n  FULL_TABLE_SEARCH_TIMEOUT_MESSAGE,\n  FULL_TABLE_SEARCH_TIMEOUT_MS,\n  FullTableSearchTimeoutError,\n  getFullTableSearchExpression,\n  isFullTableSearchRequest,\n};\nexport type {\n  FullTableSearchDialect,\n  FullTableSearchExecutionState,\n  FullTableSearchPredicate,\n} from \"../full-table-search\";\n\nexport function buildFullTableSearchPlan(args: {\n  searchTerm: string | undefined;\n  table: Table;\n}): FullTableSearchPlan {\n  const basePlan = buildBaseFullTableSearchPlan(args);\n  const normalizedSearchTerm = basePlan.normalizedSearchTerm;\n\n  if (normalizedSearchTerm.length < FULL_TABLE_SEARCH_MIN_QUERY_LENGTH) {\n    return basePlan;\n  }\n\n  const existingTextColumns = new Set(\n    basePlan.predicates.flatMap((predicate) =>\n      predicate.kind === \"text-like\" ? [predicate.column] : [],\n    ),\n  );\n  const remainingTextSlots =\n    FULL_TABLE_SEARCH_MAX_TEXT_COLUMNS - existingTextColumns.size;\n\n  if (remainingTextSlots <= 0) {\n    return basePlan;\n  }\n\n  const pattern = `%${escapeLikePattern(normalizedSearchTerm)}%`;\n  const supplementalPredicates: FullTableSearchPredicate[] = [];\n\n  for (const column of Object.values(args.table.columns)) {\n    if (existingTextColumns.has(column.name)) {\n      continue;\n    }\n\n    supplementalPredicates.push({\n      column: column.name,\n      kind: \"text-like\",\n      pattern,\n    });\n\n    if (supplementalPredicates.length >= remainingTextSlots) {\n      break;\n    }\n  }\n\n  if (supplementalPredicates.length === 0) {\n    return basePlan;\n  }\n\n  return {\n    ...basePlan,\n    predicates: [...basePlan.predicates, ...supplementalPredicates],\n  };\n}\n\nfunction escapeLikePattern(value: string): string {\n  return value.replaceAll(\"%\", \"\\\\%\").replaceAll(\"_\", \"\\\\_\");\n}\n", "import {\n  expressionBuilder,\n  type InferResult,\n  type SimpleReferenceExpression,\n  sql,\n} from \"kysely\";\n\nimport type {\n  AdapterDeleteDetails,\n  AdapterInsertDetails,\n  AdapterQueryDetails,\n  AdapterUpdateDetails,\n} from \"../adapter\";\nimport {\n  applyInferredRowFilters,\n  applyTransformations,\n  type BuilderRequirements,\n  compile,\n  getSelectFilterExpression,\n} from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getPostgreSQLBuilder } from \"./builder\";\nimport {\n  buildFullTableSearchPlan,\n  FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS,\n  FULL_TABLE_SEARCH_TIMEOUT_MS,\n  getFullTableSearchExpression,\n  isFullTableSearchRequest,\n} from \"./full-table-search\";\nimport type { mockTablesQuery } from \"./introspection\";\n\n/**\n * Inserts one or more rows into a table and returns the inserted rows along with their `ctid`.\n */\nexport function getInsertQuery(\n  details: AdapterInsertDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder =\n    getPostgreSQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .insertInto(tableName)\n      .values(\n        applyTransformations({\n          columns,\n          context: \"insert\",\n          supportsDefaultKeyword: true,\n          values: rows,\n        }),\n      )\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_inserted_at__\")),\n  );\n}\n\n/**\n * Returns a query that selects all columns from a table, along with an unbound row count as `__ps_count__`.\n */\nexport function getSelectQuery(\n  details: AdapterQueryDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    filter = { after: \"and\", filters: [], kind: \"FilterGroup\" },\n    fullTableSearchTerm,\n    pageIndex,\n    pageSize,\n    sortOrder,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder =\n    getPostgreSQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  const appliedFilterExpression = getSelectFilterExpression(\n    filter.filters,\n    columns,\n  );\n  const fullTableSearchPlan = buildFullTableSearchPlan({\n    searchTerm: fullTableSearchTerm,\n    table: details.table,\n  });\n  const combinedWhereExpression =\n    fullTableSearchPlan.predicates.length > 0\n      ? (eb: Parameters<ReturnType<typeof getSelectFilterExpression>>[0]) =>\n          eb.and([\n            appliedFilterExpression(eb),\n            getFullTableSearchExpression(fullTableSearchPlan, {\n              dialect: \"postgres\",\n            })(eb),\n          ])\n      : appliedFilterExpression;\n\n  const AGG_NAME = \"__ps_agg__\";\n  const COUNT_REF = \"__ps_count__\";\n  const SEARCH_GUARDRAILS_NAME = \"__ps_search_guardrails__\";\n  const shouldApplySearchGuardrails =\n    isFullTableSearchRequest(fullTableSearchTerm);\n  if (shouldApplySearchGuardrails) {\n    return compile(\n      builder\n        .with(SEARCH_GUARDRAILS_NAME, (qb) =>\n          qb.selectNoFrom((eb) => [\n            eb\n              .fn<string>(\"set_config\", [\n                sql.lit(\"statement_timeout\"),\n                sql.lit(`${FULL_TABLE_SEARCH_TIMEOUT_MS}ms`),\n                sql.lit(true),\n              ])\n              .as(\"__ps_statement_timeout__\"),\n            eb\n              .fn<string>(\"set_config\", [\n                sql.lit(\"lock_timeout\"),\n                sql.lit(`${FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS}ms`),\n                sql.lit(true),\n              ])\n              .as(\"__ps_lock_timeout__\"),\n          ]),\n        )\n        .with(AGG_NAME, (qb) =>\n          qb\n            .withSchema(schema)\n            .selectFrom(tableName)\n            .innerJoin(\n              sql.table(SEARCH_GUARDRAILS_NAME).as(SEARCH_GUARDRAILS_NAME),\n              (jb) => jb.onTrue(),\n            )\n            .where(combinedWhereExpression)\n            .select((eb) =>\n              eb\n                .cast<BigIntString>(\n                  eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)),\n                  \"text\",\n                )\n                .as(COUNT_REF),\n            ),\n        )\n        .withSchema(schema)\n        .selectFrom(tableName)\n        .innerJoin(SEARCH_GUARDRAILS_NAME, (jb) => jb.onTrue())\n        .innerJoin(AGG_NAME, (jb) => jb.onTrue())\n        // TODO: cursor pagination?\n        .where(combinedWhereExpression)\n        .select(\n          `${AGG_NAME}.${COUNT_REF}` satisfies SimpleReferenceExpression<\n            { [AGG_NAME]: { [COUNT_REF]: BigIntString } },\n            typeof AGG_NAME\n          >,\n        )\n        .select(Object.keys(columns))\n        .$call((qb) => {\n          return sortOrder.reduce((currentQuery, item) => {\n            const column = columns[item.column];\n\n            if (\n              column?.datatype.group === \"numeric\" &&\n              !column.datatype.isArray\n            ) {\n              return currentQuery.orderBy(\n                sql`cast(${sql.ref(item.column)} as numeric)`,\n                item.direction,\n              );\n            }\n\n            return currentQuery.orderBy(item.column, item.direction);\n          }, qb);\n        })\n        .limit(pageSize)\n        // we're injecting the offset value here to avoid serialization complexity (`bigint` is a no-go for `JSON.stringify`).\n        .offset(sql.lit(BigInt(pageIndex) * BigInt(pageSize))),\n    );\n  }\n\n  const countQuery = builder\n    .withSchema(schema)\n    .selectFrom(tableName)\n    .where(combinedWhereExpression)\n    .select((eb) =>\n      eb\n        .cast<BigIntString>(\n          eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)),\n          \"text\",\n        )\n        .as(COUNT_REF),\n    );\n\n  return compile(\n    builder\n      .with(AGG_NAME, () => countQuery)\n      .withSchema(schema)\n      .selectFrom(tableName)\n      .innerJoin(AGG_NAME, (jb) => jb.onTrue())\n      // TODO: cursor pagination?\n      .where(combinedWhereExpression)\n      .select(\n        `${AGG_NAME}.${COUNT_REF}` satisfies SimpleReferenceExpression<\n          { [AGG_NAME]: InferResult<typeof countQuery>[number] },\n          typeof AGG_NAME\n        >,\n      )\n      .select(Object.keys(columns))\n      .$call((qb) => {\n        return sortOrder.reduce((currentQuery, item) => {\n          const column = columns[item.column];\n\n          if (\n            column?.datatype.group === \"numeric\" &&\n            !column.datatype.isArray\n          ) {\n            return currentQuery.orderBy(\n              sql`cast(${sql.ref(item.column)} as numeric)`,\n              item.direction,\n            );\n          }\n\n          return currentQuery.orderBy(item.column, item.direction);\n        }, qb);\n      })\n      .limit(pageSize)\n      // we're injecting the offset value here to avoid serialization complexity (`bigint` is a no-go for `JSON.stringify`).\n      .offset(sql.lit(BigInt(pageIndex) * BigInt(pageSize))),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockSelectQuery() {\n  return [\n    {\n      created_at: new Date(\"2025-01-26T21:56:12.345Z\"),\n      deleted_at: null,\n      id: 1,\n      name: \"John Doe\",\n      __ps_count__: \"2\",\n      role: \"admin\",\n      name_role: \"Jonn Doe - admin\",\n    },\n    {\n      created_at: new Date(\"2025-01-26T20:56:12.345Z\"),\n      deleted_at: null,\n      id: 2,\n      name: \"Jane Doe\",\n      __ps_count__: \"2\",\n      role: \"poweruser\",\n      name_role: \"Jane Doe - poweruser\",\n    },\n  ] as const satisfies {\n    // best effort no need to go overboard\n    [K in\n      | ReturnType<typeof mockTablesQuery>[1][\"columns\"][number][\"name\"]\n      | \"__ps_count__\"]: unknown;\n  }[];\n}\n\n/**\n * Returns a query that updates a given row in a table with given changes.\n */\nexport function getUpdateQuery(\n  details: AdapterUpdateDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    changes,\n    row,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder =\n    getPostgreSQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .updateTable(tableName)\n      .set(\n        applyTransformations({\n          columns,\n          context: \"update\",\n          supportsDefaultKeyword: true,\n          values: changes,\n        }),\n      )\n      .$call(applyInferredRowFilters([row], columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_updated_at__\")),\n  );\n}\n\n/**\n * Returns a query that deletes a given set of rows.\n */\nexport function getDeleteQuery(\n  details: AdapterDeleteDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder =\n    getPostgreSQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .deleteFrom(tableName)\n      .$call(applyInferredRowFilters(rows, columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_deleted_at__\")),\n  );\n}\n\nfunction getCurrentTimestampMillis() {\n  const eb = expressionBuilder();\n\n  return eb.cast<BigIntString>(\n    eb.fn(\"floor\", [eb(eb.fn(\"extract\", [sql`epoch from now()`]), \"*\", 1_000)]),\n    \"text\",\n  );\n}\n", "/// <reference types=\"./postgres.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\n/**\n * A postgres helper for aggregating a subquery (or other expression) into a JSONB array.\n *\n * ### Examples\n *\n * <!-- siteExample(\"select\", \"Nested array\", 110) -->\n *\n * While kysely is not an ORM and it doesn't have the concept of relations, we do provide\n * helpers for fetching nested objects and arrays in a single query. In this example we\n * use the `jsonArrayFrom` helper to fetch person's pets along with the person's id.\n *\n * Please keep in mind that the helpers under the `kysely/helpers` folder, including\n * `jsonArrayFrom`, are not guaranteed to work with third party dialects. In order for\n * them to work, the dialect must automatically parse the `json` data type into\n * JavaScript JSON values like objects and arrays. Some dialects might simply return\n * the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`\n * to parse the results.\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonArrayFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .orderBy('pet.name')\n *     ).as('pets')\n *   ])\n *   .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", (\n *   select coalesce(json_agg(agg), '[]') from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     order by \"pet\".\"name\"\n *   ) as agg\n * ) as \"pets\"\n * from \"person\"\n * ```\n */\nexport function jsonArrayFrom(expr) {\n    return sql `(select coalesce(json_agg(agg), '[]') from ${expr} as agg)`;\n}\n/**\n * A postgres helper for turning a subquery (or other expression) into a JSON object.\n *\n * The subquery must only return one row.\n *\n * ### Examples\n *\n * <!-- siteExample(\"select\", \"Nested object\", 120) -->\n *\n * While kysely is not an ORM and it doesn't have the concept of relations, we do provide\n * helpers for fetching nested objects and arrays in a single query. In this example we\n * use the `jsonObjectFrom` helper to fetch person's favorite pet along with the person's id.\n *\n * Please keep in mind that the helpers under the `kysely/helpers` folder, including\n * `jsonObjectFrom`, are not guaranteed to work with third-party dialects. In order for\n * them to work, the dialect must automatically parse the `json` data type into\n * JavaScript JSON values like objects and arrays. Some dialects might simply return\n * the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`\n * to parse the results.\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonObjectFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .where('pet.is_favorite', '=', true)\n *     ).as('favorite_pet')\n *   ])\n *   .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", (\n *   select to_json(obj) from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     and \"pet\".\"is_favorite\" = $1\n *   ) as obj\n * ) as \"favorite_pet\"\n * from \"person\"\n * ```\n */\nexport function jsonObjectFrom(expr) {\n    return sql `(select to_json(obj) from ${expr} as obj)`;\n}\n/**\n * The PostgreSQL `json_build_object` function.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `PostgresDialect`.\n * While the produced SQL is compatible with all PostgreSQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n * import { jsonBuildObject } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonBuildObject({\n *       first: eb.ref('first_name'),\n *       last: eb.ref('last_name'),\n *       full: sql<string>`first_name ||\u00A0' ' || last_name`\n *     }).as('name')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.name.first\n * result[0]?.name.last\n * result[0]?.name.full\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", json_build_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', first_name || ' ' || last_name\n * ) as \"name\"\n * from \"person\"\n * ```\n */\nexport function jsonBuildObject(obj) {\n    return sql `json_build_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;\n}\n/**\n * The PostgreSQL `merge_action` function.\n *\n * This function can be used in a `returning` clause to get the action that was\n * performed in a `mergeInto` query. The function returns one of the following\n * strings: `'INSERT'`, `'UPDATE'`, or `'DELETE'`.\n *\n * ### Examples\n *\n * ```ts\n * import { mergeAction } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .mergeInto('person as p')\n *   .using('person_backup as pb', 'p.id', 'pb.id')\n *   .whenMatched()\n *   .thenUpdateSet(({ ref }) => ({\n *     first_name: ref('pb.first_name'),\n *     updated_at: ref('pb.updated_at').$castTo<string | null>(),\n *   }))\n *   .whenNotMatched()\n *   .thenInsertValues(({ ref}) => ({\n *     id: ref('pb.id'),\n *     first_name: ref('pb.first_name'),\n *     created_at: ref('pb.updated_at'),\n *     updated_at: ref('pb.updated_at').$castTo<string | null>(),\n *   }))\n *   .returning([mergeAction().as('action'), 'p.id', 'p.updated_at'])\n *   .execute()\n *\n * result[0].action\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\" as \"p\"\n * using \"person_backup\" as \"pb\" on \"p\".\"id\" = \"pb\".\"id\"\n * when matched then update set\n *   \"first_name\" = \"pb\".\"first_name\",\n *   \"updated_at\" = \"pb\".\"updated_at\"::text\n * when not matched then insert values (\"id\", \"first_name\", \"created_at\", \"updated_at\")\n * values (\"pb\".\"id\", \"pb\".\"first_name\", \"pb\".\"updated_at\", \"pb\".\"updated_at\")\n * returning merge_action() as \"action\", \"p\".\"id\", \"p\".\"updated_at\"\n * ```\n */\nexport function mergeAction() {\n    return sql `merge_action()`;\n}\n", "import { type SelectQueryBuilder, sql } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/postgres\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getPostgreSQLBuilder } from \"./builder\";\n\nconst REGULAR_TABLE_KIND = \"r\";\nconst VIEW_TABLE_KIND = \"v\";\nconst TABLE_KINDS = [REGULAR_TABLE_KIND, VIEW_TABLE_KIND] as const;\ntype TableKind = (typeof TABLE_KINDS)[number];\n\ninterface Database {\n  /** column defaults */\n  \"pg_catalog.pg_attrdef\": {\n    /** default expression as a node tree, use pg_get_expr(adbin, adrelid) */\n    adbin: string;\n    /** column number */\n    adnum: number;\n    /** table identifier */\n    adrelid: number;\n  };\n  /** columns */\n  \"pg_catalog.pg_attribute\": {\n    /**\n     * generation flag for computed columns:\n     * '' (empty) for regular columns,\n     * 's' for STORED generated columns (Postgres GENERATED ALWAYS AS).\n     */\n    attgenerated: \"\" | \"s\";\n    /**\n     * identity column flag:\n     * '' (empty) for regular columns,\n     * 'a' for ALWAYS (GENERATED ALWAYS AS IDENTITY),\n     * 'd' for BY DEFAULT (GENERATED BY DEFAULT AS IDENTITY).\n     */\n    attidentity: \"\" | \"a\" | \"d\";\n    /** was the column dropped. dropped columns might not be 100% removed immediately. */\n    attisdropped: boolean;\n    /** column name */\n    attname: string;\n    /** NOT NULL constraint: true if the column has a NOT NULL constraint */\n    attnotnull: boolean;\n    /** column order number in its table */\n    attnum: number;\n    /** table/view identifier */\n    attrelid: string;\n    /** column datatype identifier */\n    atttypid: string;\n  };\n  /** resources, e.g. tables, sequences, etc. */\n  \"pg_catalog.pg_class\": {\n    /** resource id */\n    oid: number;\n    /** resource kind: regular table, view */\n    relkind: TableKind;\n    /** resource name */\n    relname: string;\n    /** schema id */\n    relnamespace: number;\n  };\n  /** constraints */\n  \"pg_catalog.pg_constraint\": {\n    /** if a foreign key, the referenced columns */\n    confkey: number[];\n    /** if a foreign key, the referenced table */\n    confrelid: number;\n    /**\n     * an ordered array of columns included in the constraint.\n     *\n     * the columns are represented by their ordinal number (`attnum`) in their relation (table).\n     *\n     * @example `'{1,3}'` - a constraint with 2 columns, the 1st & 3rd in their table.\n     */\n    conkey: number[];\n    /** relation (table) id which this constraint was created for */\n    conrelid: number;\n    /**\n     * constraint type.\n     *\n     * `'p'` - primary key constraint.\n     * `'f'` - foreign key constraint.\n     */\n    contype: \"p\" | \"f\" | (string & {});\n  };\n  /** enum types' values */\n  \"pg_catalog.pg_enum\": {\n    /** enum value */\n    enumlabel: string;\n    /** enum's type id */\n    enumtypid: number;\n  };\n  /** schemas */\n  \"pg_catalog.pg_namespace\": {\n    /** schema name */\n    nspname: string;\n    /** schema id */\n    oid: number;\n  };\n  /** datatypes */\n  \"pg_catalog.pg_type\": {\n    /** type id */\n    oid: number;\n    /** type name */\n    typname: string;\n    /** type's schema (aka namespace) id */\n    typnamespace: number;\n  };\n}\n\n/**\n * Returns a query that returns metadata for all user-defined tables and views in the database.\n */\nexport function getTablesQuery(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  return compile(\n    getPostgreSQLBuilder<Database>(requirements)\n      .selectFrom(\"pg_catalog.pg_class as cls\")\n      .innerJoin(\"pg_catalog.pg_namespace as ns\", \"cls.relnamespace\", \"ns.oid\")\n      .$call(excludeSystemTables)\n      // regular tables or views\n      .where(\"cls.relkind\", \"in\", TABLE_KINDS)\n      .select((eb) => [\n        \"ns.nspname as schema\",\n        \"cls.relname as name\",\n        jsonArrayFrom(\n          eb\n            .selectFrom(\"pg_catalog.pg_attribute as att\")\n            .innerJoin(\"pg_catalog.pg_type as typ\", \"typ.oid\", \"att.atttypid\")\n            .innerJoin(\n              \"pg_catalog.pg_namespace as tns\",\n              \"tns.oid\",\n              \"typ.typnamespace\",\n            )\n            .leftJoin(\"pg_catalog.pg_constraint as pk_con\", (jb) =>\n              jb\n                .on(\"pk_con.contype\", \"=\", \"p\")\n                .onRef(\"pk_con.conrelid\", \"=\", \"cls.oid\")\n                .on((eb) => eb(\"att.attnum\", \"=\", eb.fn.any(\"pk_con.conkey\"))),\n            )\n            .leftJoin(\"pg_catalog.pg_constraint as fk_con\", (jb) =>\n              jb\n                .on(\"fk_con.contype\", \"=\", \"f\")\n                .onRef(\"fk_con.conrelid\", \"=\", \"cls.oid\")\n                .on((eb) => eb(\"att.attnum\", \"=\", eb.fn.any(\"fk_con.conkey\"))),\n            )\n            .leftJoin(\n              \"pg_catalog.pg_class as fk_cls\",\n              \"fk_cls.oid\",\n              \"fk_con.confrelid\",\n            )\n            .leftJoin(\n              \"pg_catalog.pg_namespace as fk_ns\",\n              \"fk_ns.oid\",\n              \"fk_cls.relnamespace\",\n            )\n            .leftJoin(\"pg_catalog.pg_attribute as fk_att\", (jb) =>\n              jb\n                .onRef(\"fk_att.attrelid\", \"=\", \"fk_cls.oid\")\n                // Use a callback for the .on() condition to ensure correct context for types\n                .on((on_eb) =>\n                  on_eb(\"fk_att.attnum\", \"=\", on_eb.fn.any(\"fk_con.confkey\")),\n                ),\n            )\n            .leftJoin(\"pg_catalog.pg_attrdef as def\", (jb) =>\n              jb\n                .onRef(\"def.adrelid\", \"=\", \"att.attrelid\")\n                .onRef(\"def.adnum\", \"=\", \"att.attnum\"),\n            )\n            .whereRef(\"att.attrelid\", \"=\", \"cls.oid\")\n            // exclude system columns\n            .where(\"att.attnum\", \">=\", 0)\n            .where(\"att.attisdropped\", \"!=\", true)\n            .select([\n              \"att.attname as name\",\n              \"fk_att.attname as fk_column\",\n              \"fk_cls.relname as fk_table\",\n              \"fk_ns.nspname as fk_schema\",\n              \"tns.nspname as datatype_schema\",\n              \"typ.typname as datatype\",\n            ])\n            .select((eb) => [\n              eb(\"att.attidentity\", \"!=\", \"\")\n                .or(\n                  eb(\"def.adbin\", \"is not\", null).and(\n                    eb.fn(\"pg_get_expr\", [\"def.adbin\", \"def.adrelid\"]),\n                    \"like\",\n                    \"nextval(%\",\n                  ),\n                )\n                .$castTo<boolean>()\n                .as(\"autoinc\"),\n              eb(\"att.attgenerated\", \"!=\", \"\")\n                .$castTo<boolean>()\n                .as(\"computed\"),\n              eb\n                .fn<string | null>(\"pg_get_expr\", [\"def.adbin\", \"def.adrelid\"])\n                .as(\"default\"),\n              eb(\"att.attnotnull\", \"!=\", true)\n                .$castTo<boolean>()\n                .as(\"nullable\"),\n              eb.fn\n                .coalesce(\n                  eb\n                    .selectFrom(\"pg_catalog.pg_enum as enm\")\n                    .whereRef(\"enm.enumtypid\", \"=\", \"typ.oid\")\n                    .select((eb) =>\n                      eb.fn.jsonAgg(eb.ref(\"enm.enumlabel\")).as(\"o\"),\n                    ),\n                  sql<string[]>`'[]'`,\n                )\n                .as(\"options\"),\n              eb\n                .fn<\n                  number | null\n                >(\"array_position\", [\"pk_con.conkey\", \"att.attnum\"])\n                .as(\"pk\"),\n            ]),\n        ).as(\"columns\"),\n      ]),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTablesQuery() {\n  return [\n    {\n      schema: \"zoo\",\n      name: \"animals\",\n      columns: [\n        {\n          autoinc: true,\n          computed: false,\n          datatype: \"int4\",\n          datatype_schema: \"pg_catalog\",\n          default: \"nextval('zoo.animals_id_seq'::regclass)\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: false,\n          options: [],\n          pk: 1,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n      ],\n    },\n    {\n      schema: \"public\",\n      name: \"users\",\n      columns: [\n        {\n          autoinc: true,\n          computed: false,\n          datatype: \"int4\",\n          datatype_schema: \"pg_catalog\",\n          default: \"nextval('users_id_seq'::regclass)\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: false,\n          options: [],\n          pk: 1,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          default: \"CURRENT_TIMESTAMP\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"deleted_at\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"varchar\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"role\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"varchar\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n        {\n          autoinc: false,\n          computed: true,\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"name_role\",\n          nullable: false,\n          options: [],\n          pk: null,\n        },\n      ],\n    },\n    {\n      schema: \"public\",\n      name: \"composite_pk\",\n      columns: [\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"uuid\",\n          datatype_schema: \"pg_catalog\",\n          default: \"gen_random_uuid()\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: false,\n          options: [],\n          pk: 1,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: true,\n          options: [],\n          pk: 2,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          default: \"now()\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n      ],\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n\n/**\n * Returns a query that returns the current timezone setting of the PostgreSQL database.\n */\nexport function getTimezoneQuery() {\n  const builder = getPostgreSQLBuilder();\n\n  return compile(\n    builder.selectNoFrom(\n      builder\n        .fn<string>(\"current_setting\", [sql.lit(\"timezone\")])\n        .as(\"timezone\"),\n    ),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTimezoneQuery() {\n  return [{ timezone: \"UTC\" }] as const satisfies QueryResult<\n    typeof getTimezoneQuery\n  >;\n}\n\n/**\n * We don't want PostgreSQL internals in introspection results. To be used in `$call`.\n */\nfunction excludeSystemTables<\n  T extends SelectQueryBuilder<\n    Database & {\n      ns: Database[\"pg_catalog.pg_namespace\"];\n      cls: Database[\"pg_catalog.pg_class\"];\n    },\n    \"ns\" | \"cls\",\n    object\n  >,\n>(qb: T): T {\n  return qb\n    .where(`ns.nspname`, `!~`, `^pg_`)\n    .where(`ns.nspname`, `!=`, `information_schema`) as never;\n}\n", "import {\n  type Adapter,\n  type AdapterDeleteResult,\n  type AdapterError,\n  type AdapterInsertResult,\n  type AdapterIntrospectResult,\n  type AdapterQueryResult,\n  type AdapterRawDetails,\n  type AdapterRawResult,\n  type AdapterRequirements,\n  type AdapterSqlLintDetails,\n  type AdapterSqlLintResult,\n  type AdapterSqlSchemaResult,\n  type AdapterUpdateResult,\n  type Column,\n  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport {\n  createFullTableSearchExecutionState,\n  executeQueryWithFullTableSearchGuardrails,\n} from \"../full-table-search\";\nimport { asQuery, type Query, QueryResult } from \"../query\";\nimport { createSqlEditorSchemaFromIntrospection } from \"../sql-editor-schema\";\nimport type { Either } from \"../type-utils\";\nimport { POSTGRESQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport {\n  getDeleteQuery,\n  getInsertQuery,\n  getSelectQuery,\n  getUpdateQuery,\n} from \"./dml\";\nimport {\n  getTablesQuery,\n  getTimezoneQuery,\n  mockTablesQuery,\n  mockTimezoneQuery,\n} from \"./introspection\";\nimport {\n  createLintDiagnosticsFromPostgresError,\n  validateSqlForLint,\n} from \"./sql-lint\";\n\nexport type PostgresAdapterRequirements = AdapterRequirements;\n\nexport function createPostgresAdapter(\n  requirements: PostgresAdapterRequirements,\n): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n  const fullTableSearchState = createFullTableSearchExecutionState();\n  let canUseExecutorLintTransport = typeof executor.lintSql === \"function\";\n\n  async function introspectDatabase(\n    options: Parameters<Adapter[\"introspect\"]>[0],\n  ): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n    try {\n      const tablesQuery = getTablesQuery(otherRequirements);\n      const timezoneQuery = getTimezoneQuery();\n\n      const [[tablesError, tables], [timezoneError, timezones]] =\n        await Promise.all([\n          executor.execute(tablesQuery, options),\n          executor.execute(timezoneQuery, options),\n        ]);\n\n      if (tablesError) {\n        return createAdapterError({ error: tablesError, query: tablesQuery });\n      }\n\n      if (timezoneError) {\n        return createAdapterError({\n          error: timezoneError,\n          query: timezoneQuery,\n        });\n      }\n\n      const timezone = timezones[0]?.timezone;\n\n      if (!timezone) {\n        return createAdapterError({\n          error: new Error(\"Timezone not found\"),\n          query: timezoneQuery,\n        });\n      }\n\n      return [\n        null,\n        createIntrospection({ query: tablesQuery, tables, timezone }),\n      ];\n    } catch (error: unknown) {\n      return createAdapterError({ error: error as Error });\n    }\n  }\n\n  return {\n    defaultSchema: \"public\",\n    capabilities: {\n      fullTableSearch: true,\n      sqlDialect: \"postgresql\",\n      sqlEditorAutocomplete: true,\n      sqlEditorLint: true,\n    },\n\n    async introspect(\n      options,\n    ): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      return await introspectDatabase(options);\n    },\n\n    async query(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n        const [error, results] =\n          await executeQueryWithFullTableSearchGuardrails({\n            executor,\n            options,\n            query,\n            searchTerm: details.fullTableSearchTerm,\n            state: fullTableSearchState,\n          });\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [\n          null,\n          {\n            filteredRowCount: results[0]?.__ps_count__ || \"0\",\n            rows: results,\n            query,\n          },\n        ];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async raw(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterRawResult>> {\n      return await executeRawQuery(executor, details, options);\n    },\n\n    async sqlSchema(\n      _details,\n      options,\n    ): Promise<Either<AdapterError, AdapterSqlSchemaResult>> {\n      const [error, introspection] = await introspectDatabase(options);\n\n      if (error) {\n        return [error];\n      }\n\n      return [\n        null,\n        createSqlEditorSchemaFromIntrospection({\n          defaultSchema: \"public\",\n          dialect: \"postgresql\",\n          introspection,\n        }),\n      ];\n    },\n\n    async sqlLint(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterSqlLintResult>> {\n      if (canUseExecutorLintTransport && typeof executor.lintSql === \"function\") {\n        try {\n          const [error, result] = await executor.lintSql(details, options);\n\n          if (!error) {\n            return [null, result];\n          }\n\n          if (!shouldFallbackToExplainLint(error)) {\n            return createAdapterError({ error });\n          }\n\n          if (shouldDisableLintTransport(error)) {\n            canUseExecutorLintTransport = false;\n          }\n        } catch (error: unknown) {\n          if (!shouldFallbackToExplainLint(error)) {\n            return createAdapterError({ error: error as Error });\n          }\n\n          if (shouldDisableLintTransport(error)) {\n            canUseExecutorLintTransport = false;\n          }\n        }\n      }\n\n      return await lintWithExplainFallback(executor, details, options);\n    },\n\n    async insert(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterInsertResult>> {\n      try {\n        const query = getInsertQuery(details, otherRequirements);\n\n        const [error, rows] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { rows, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async update(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      try {\n        const query = getUpdateQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        const [row] = results;\n\n        if (!row) {\n          return createAdapterError({\n            error: new Error(\"Update failed\"),\n            query,\n          });\n        }\n\n        return [null, { row, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async delete(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n\n        const [error] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { ...details, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n  };\n}\n\nfunction shouldFallbackToExplainLint(error: unknown): boolean {\n  if (!(error instanceof Error)) {\n    return false;\n  }\n\n  const message = error.message.toLowerCase();\n\n  return (\n    message.includes(\"invalid procedure\") ||\n    message.includes(\"unexpected server error\") ||\n    message.includes(\"internal server error\") ||\n    message.includes(\"bad gateway\") ||\n    message.includes(\"service unavailable\") ||\n    message.includes(\"not supported\") ||\n    message.includes(\"method not allowed\")\n  );\n}\n\nfunction shouldDisableLintTransport(error: unknown): boolean {\n  if (!(error instanceof Error)) {\n    return false;\n  }\n\n  const message = error.message.toLowerCase();\n\n  return (\n    message.includes(\"invalid procedure\") ||\n    message.includes(\"unexpected server error\") ||\n    message.includes(\"internal server error\") ||\n    message.includes(\"not supported\") ||\n    message.includes(\"method not allowed\")\n  );\n}\n\nasync function lintWithExplainFallback(\n  executor: AdapterRequirements[\"executor\"],\n  details: AdapterSqlLintDetails,\n  options: Parameters<NonNullable<Adapter[\"sqlLint\"]>>[1],\n): Promise<Either<AdapterError, AdapterSqlLintResult>> {\n  const validation = validateSqlForLint(details.sql);\n\n  if (!validation.ok) {\n    return [\n      null,\n      {\n        diagnostics: [validation.diagnostic],\n        schemaVersion: details.schemaVersion,\n      },\n    ];\n  }\n\n  const diagnostics: AdapterSqlLintResult[\"diagnostics\"] = [];\n\n  for (const statement of validation.statements) {\n    try {\n      const explainQuery = asQuery<Record<string, unknown>>(\n        `EXPLAIN (FORMAT JSON) ${statement.statement}`,\n      );\n      const [error] = await executor.execute(explainQuery, options);\n\n      if (!error) {\n        continue;\n      }\n\n      diagnostics.push(\n        ...createLintDiagnosticsFromPostgresError({\n          error,\n          positionOffset: statement.from,\n          sql: statement.statement,\n        }),\n      );\n    } catch (error: unknown) {\n      diagnostics.push(\n        ...createLintDiagnosticsFromPostgresError({\n          error,\n          positionOffset: statement.from,\n          sql: statement.statement,\n        }),\n      );\n    }\n  }\n\n  return [\n    null,\n    {\n      diagnostics,\n      schemaVersion: details.schemaVersion,\n    },\n  ];\n}\n\nasync function executeRawQuery(\n  executor: AdapterRequirements[\"executor\"],\n  details: AdapterRawDetails,\n  options: Parameters<Adapter[\"raw\"]>[1],\n): Promise<Either<AdapterError, AdapterRawResult>> {\n  try {\n    const query = asQuery<Record<string, unknown>>(details.sql);\n    const [error, rows] = await executor.execute(query, options);\n\n    if (error) {\n      return createAdapterError({ error, query });\n    }\n\n    return [\n      null,\n      {\n        query,\n        rowCount: rows.length,\n        rows: rows,\n      },\n    ];\n  } catch (error: unknown) {\n    return createAdapterError({ error: error as Error });\n  }\n}\n\nfunction createIntrospection(args: {\n  query: Query;\n  tables: QueryResult<typeof getTablesQuery>;\n  timezone: string;\n}): AdapterIntrospectResult {\n  const { query, tables, timezone } = args;\n\n  return tables.reduce(\n    (result, table) => {\n      const { schemas } = result;\n      const { columns, name: tableName, schema } = table;\n\n      const columnsRecord = columns.reduce(\n        (columns, column) => {\n          const {\n            autoinc,\n            computed,\n            datatype,\n            datatype_schema,\n            default: defaultValue,\n            name: columnName,\n            options,\n            nullable,\n          } = column;\n\n          const isArray = datatype.startsWith(\"_\");\n          const strippedDataType = isArray ? datatype.slice(1) : datatype;\n\n          return {\n            ...columns,\n            [columnName]: {\n              datatype: {\n                ...(POSTGRESQL_DATA_TYPES_TO_METADATA[strippedDataType] || {\n                  group: options.length > 0 ? \"enum\" : \"raw\",\n                }),\n                isArray,\n                isNative: datatype_schema === \"pg_catalog\",\n                name: isArray ? `${strippedDataType}[]` : strippedDataType,\n                options,\n                schema: datatype_schema,\n              },\n              defaultValue,\n              fkColumn: column.fk_column,\n              fkSchema: column.fk_schema,\n              fkTable: column.fk_table,\n              isAutoincrement: autoinc,\n              isComputed: computed,\n              isRequired:\n                !nullable && !autoinc && !computed && defaultValue == null,\n              name: columnName,\n              nullable,\n              pkPosition: column.pk,\n              schema,\n              table: tableName,\n            } as const satisfies Column,\n          };\n        },\n        {} as Table[\"columns\"],\n      );\n\n      if (schemas[schema] === undefined) {\n        schemas[schema] = { name: schema, tables: {} };\n      }\n\n      schemas[schema].tables[tableName] = {\n        columns: columnsRecord,\n        name: tableName,\n        schema,\n      };\n\n      return result;\n    },\n    {\n      filterOperators,\n      query,\n      schemas: { public: { name: \"public\", tables: {} } },\n      timezone,\n    } satisfies AdapterIntrospectResult as AdapterIntrospectResult,\n  );\n}\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n  \"ilike\",\n  \"not ilike\",\n] satisfies FilterOperator[];\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const tables = mockTablesQuery();\n  const [{ timezone }] = mockTimezoneQuery();\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n\n  return createIntrospection({ tables, timezone, query }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      [K in (typeof tables)[number][\"schema\"]]: {\n        name: K;\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: typeof timezone;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n"],
  "mappings": "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S,EACfJ,EACG,GAEC,iBAAkB,CAAC,gBAAiB,YAAY,CAAC,EAClD,GAAG,IAAI,CACZ,CAAC,CACL,EAAE,GAAG,SAAS,CAChB,CAAC,CACL,CACF,CAKO,SAASK,IAAkB,CAChC,MAAO,CACL,CACE,OAAQ,MACR,KAAM,UACN,QAAS,CACP,CACE,QAAS,GACT,SAAU,GACV,SAAU,OACV,gBAAiB,aACjB,QAAS,0CACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,KACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,CACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,OACV,gBAAiB,aACjB,QAAS,KACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,OACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,CACF,CACF,EACA,CACE,OAAQ,SACR,KAAM,QACN,QAAS,CACP,CACE,QAAS,GACT,SAAU,GACV,SAAU,OACV,gBAAiB,aACjB,QAAS,oCACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,KACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,CACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,YACV,gBAAiB,aACjB,QAAS,oBACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,aACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,YACV,gBAAiB,aACjB,QAAS,KACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,aACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,UACV,gBAAiB,aACjB,QAAS,KACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,OACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,UACV,gBAAiB,aACjB,QAAS,KACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,OACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,EACA,CACE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",
  "names": ["POSTGRESQL_DATA_TYPES_TO_METADATA", "getPostgreSQLBuilder", "requirements", "getBuilder", "PostgresAdapter", "PostgresQueryCompiler", "buildFullTableSearchPlan", "args", "basePlan", "normalizedSearchTerm", "existingTextColumns", "predicate", "remainingTextSlots", "pattern", "escapeLikePattern", "supplementalPredicates", "column", "value", "getInsertQuery", "details", "requirements", "rows", "columns", "tableName", "schema", "builder", "getPostgreSQLBuilder", "compile", "applyTransformations", "getCurrentTimestampMillis", "getSelectQuery", "filter", "fullTableSearchTerm", "pageIndex", "pageSize", "sortOrder", "appliedFilterExpression", "getSelectFilterExpression", "fullTableSearchPlan", "buildFullTableSearchPlan", "combinedWhereExpression", "eb", "getFullTableSearchExpression", "AGG_NAME", "COUNT_REF", "SEARCH_GUARDRAILS_NAME", "isFullTableSearchRequest", "qb", "sql", "jb", "currentQuery", "item", "column", "countQuery", "mockSelectQuery", "getUpdateQuery", "changes", "row", "applyInferredRowFilters", "getDeleteQuery", "expressionBuilder", "jsonArrayFrom", "expr", "sql", "REGULAR_TABLE_KIND", "VIEW_TABLE_KIND", "TABLE_KINDS", "getTablesQuery", "requirements", "compile", "getPostgreSQLBuilder", "excludeSystemTables", "eb", "jsonArrayFrom", "jb", "on_eb", "sql", "mockTablesQuery", "getTimezoneQuery", "builder", "mockTimezoneQuery", "qb", "createPostgresAdapter", "requirements", "executor", "otherRequirements", "fullTableSearchState", "createFullTableSearchExecutionState", "canUseExecutorLintTransport", "introspectDatabase", "options", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "createAdapterError", "timezone", "createIntrospection", "error", "details", "query", "getSelectQuery", "results", "executeQueryWithFullTableSearchGuardrails", "executeRawQuery", "_details", "introspection", "createSqlEditorSchemaFromIntrospection", "result", "shouldFallbackToExplainLint", "shouldDisableLintTransport", "lintWithExplainFallback", "getInsertQuery", "rows", "getUpdateQuery", "row", "getDeleteQuery", "message", "validation", "validateSqlForLint", "diagnostics", "statement", "explainQuery", "asQuery", "createLintDiagnosticsFromPostgresError", "args", "table", "schemas", "columns", "tableName", "schema", "columnsRecord", "column", "autoinc", "computed", "datatype", "datatype_schema", "defaultValue", "columnName", "nullable", "isArray", "strippedDataType", "POSTGRESQL_DATA_TYPES_TO_METADATA", "filterOperators", "mockIntrospect", "mockTablesQuery", "mockTimezoneQuery"]
}

9
+ import{a as m}from"./chunk-UQDXNCLC.js";import{a as w,b as q,d as C,e as z,h as D,i as L,j as Q,k as U,l as F}from"./chunk-PI3N7ZW6.js";import{a as G}from"./chunk-N6ZIYSZ5.js";import{c as $,d as O}from"./chunk-DTFJIWXL.js";import{A as I,C as B,D as Y,p as N,q as p,t as H,u as j,x as v,y as P,z as k}from"./chunk-TB3YFW43.js";var J={bool:{group:"boolean"},boolean:{group:"boolean"},bytea:{group:"string"},char:{group:"string"},citext:{group:"string"},date:{format:"YYYY-MM-DD",group:"datetime"},interval:{group:"string"},name:{group:"string"},varchar:{group:"string"},text:{group:"string"},time:{format:"HH:mm:ss.SSS",group:"time"},timestamp:{format:"YYYY-MM-DD HH:mm:ss.SSS",group:"datetime"},timestamptz:{format:"YYYY-MM-DD HH:mm:ss.SSSZZ",group:"datetime"},"timestamp without time zone":{format:"YYYY-MM-DD HH:mm:ss.SSS",group:"datetime"},"timestamp with time zone":{format:"YYYY-MM-DD HH:mm:ss.SSSZZ",group:"datetime"},timetz:{format:"HH:mm:ss.SSSZZ",group:"time"},"time without time zone":{format:"HH:mm:ss.SSS",group:"time"},"time with time zone":{format:"HH:mm:ss.SSSZZ",group:"time"},uuid:{format:"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",group:"raw"},int2:{group:"numeric"},int4:{group:"numeric"},int8:{group:"numeric"},smallint:{group:"numeric"},integer:{group:"numeric"},bigint:{group:"numeric"},decimal:{group:"numeric"},numeric:{group:"numeric"},real:{group:"numeric"},float4:{group:"numeric"},float8:{group:"numeric"},"double precision":{group:"numeric"},json:{group:"json"},jsonb:{group:"json"}};function T(r){return v({...r,Adapter:j,QueryCompiler:H})}function K(r){let e=U(r),n=e.normalizedSearchTerm;if(n.length<2)return e;let o=new Set(e.predicates.flatMap(l=>l.kind==="text-like"?[l.column]:[])),i=64-o.size;if(i<=0)return e;let u=`%${ie(n)}%`,a=[];for(let l of Object.values(r.table.columns))if(!o.has(l.name)&&(a.push({column:l.name,kind:"text-like",pattern:u}),a.length>=i))break;return a.length===0?e:{...e,predicates:[...e.predicates,...a]}}function ie(r){return r.replaceAll("%","\\%").replaceAll("_","\\_")}function Z(r,e){let{rows:n,table:{columns:o,name:i,schema:u}}=r,a=T(e);return k(a.withSchema(u).insertInto(i).values(B({columns:o,context:"insert",supportsDefaultKeyword:!0,values:n})).returning(Object.keys(o)).returning(M().as("__ps_inserted_at__")))}function W(r,e){let{filter:n={after:"and",filters:[],kind:"FilterGroup"},fullTableSearchTerm:o,pageIndex:i,pageSize:u,sortOrder:a,table:{columns:l,name:t,schema:s}}=r,_=T(e),g=Y(n.filters,l),y=K({searchTerm:o,table:r.table}),b=y.predicates.length>0?c=>c.and([g(c),F(y,{dialect:"postgres"})(c)]):g,h="__ps_agg__",A="__ps_count__",x="__ps_search_guardrails__";if(L(o))return k(_.with(x,c=>c.selectNoFrom(d=>[d.fn("set_config",[p.lit("statement_timeout"),p.lit(`${5e3}ms`),p.lit(!0)]).as("__ps_statement_timeout__"),d.fn("set_config",[p.lit("lock_timeout"),p.lit(`${100}ms`),p.lit(!0)]).as("__ps_lock_timeout__")])).with(h,c=>c.withSchema(s).selectFrom(t).innerJoin(p.table(x).as(x),d=>d.onTrue()).where(b).select(d=>d.cast(d.fn.coalesce(d.fn.countAll(),p.lit(0)),"text").as(A))).withSchema(s).selectFrom(t).innerJoin(x,c=>c.onTrue()).innerJoin(h,c=>c.onTrue()).where(b).select(`${h}.${A}`).select(Object.keys(l)).$call(c=>a.reduce((d,f)=>{let S=l[f.column];return S?.datatype.group==="numeric"&&!S.datatype.isArray?d.orderBy(p`cast(${p.ref(f.column)} as numeric)`,f.direction):d.orderBy(f.column,f.direction)},c)).limit(u).offset(p.lit(BigInt(i)*BigInt(u))));let E=_.withSchema(s).selectFrom(t).where(b).select(c=>c.cast(c.fn.coalesce(c.fn.countAll(),p.lit(0)),"text").as(A));return k(_.with(h,()=>E).withSchema(s).selectFrom(t).innerJoin(h,c=>c.onTrue()).where(b).select(`${h}.${A}`).select(Object.keys(l)).$call(c=>a.reduce((d,f)=>{let S=l[f.column];return S?.datatype.group==="numeric"&&!S.datatype.isArray?d.orderBy(p`cast(${p.ref(f.column)} as numeric)`,f.direction):d.orderBy(f.column,f.direction)},c)).limit(u).offset(p.lit(BigInt(i)*BigInt(u))))}function De(){return[{created_at:new Date("2025-01-26T21:56:12.345Z"),deleted_at:null,id:1,name:"John Doe",__ps_count__:"2",role:"admin",name_role:"Jonn Doe - admin"},{created_at:new Date("2025-01-26T20:56:12.345Z"),deleted_at:null,id:2,name:"Jane Doe",__ps_count__:"2",role:"poweruser",name_role:"Jane Doe - poweruser"}]}function V(r,e){let{changes:n,row:o,table:{columns:i,name:u,schema:a}}=r,l=T(e);return k(l.withSchema(a).updateTable(u).set(B({columns:i,context:"update",supportsDefaultKeyword:!0,values:n})).$call(I([o],i)).returning(Object.keys(i)).returning(M().as("__ps_updated_at__")))}function X(r,e){let{rows:n,table:{columns:o,name:i,schema:u}}=r,a=T(e);return k(a.withSchema(u).deleteFrom(i).$call(I(n,o)).returning(Object.keys(o)).returning(M().as("__ps_deleted_at__")))}function M(){let r=N();return r.cast(r.fn("floor",[r(r.fn("extract",[p`epoch from now()`]),"*",1e3)]),"text")}function ee(r){return p`(select coalesce(json_agg(agg), '[]') from ${r} as agg)`}var ue="r",ce="v",pe=[ue,ce];function te(r){return k(T(r).selectFrom("pg_catalog.pg_class as cls").innerJoin("pg_catalog.pg_namespace as ns","cls.relnamespace","ns.oid").$call(me).where("cls.relkind","in",pe).select(e=>["ns.nspname as schema","cls.relname as name",ee(e.selectFrom("pg_catalog.pg_attribute as att").innerJoin("pg_catalog.pg_type as typ","typ.oid","att.atttypid").innerJoin("pg_catalog.pg_namespace as tns","tns.oid","typ.typnamespace").leftJoin("pg_catalog.pg_constraint as pk_con",n=>n.on("pk_con.contype","=","p").onRef("pk_con.conrelid","=","cls.oid").on(o=>o("att.attnum","=",o.fn.any("pk_con.conkey")))).leftJoin("pg_catalog.pg_constraint as fk_con",n=>n.on("fk_con.contype","=","f").onRef("fk_con.conrelid","=","cls.oid").on(o=>o("att.attnum","=",o.fn.any("fk_con.conkey")))).leftJoin("pg_catalog.pg_class as fk_cls","fk_cls.oid","fk_con.confrelid").leftJoin("pg_catalog.pg_namespace as fk_ns","fk_ns.oid","fk_cls.relnamespace").leftJoin("pg_catalog.pg_attribute as fk_att",n=>n.onRef("fk_att.attrelid","=","fk_cls.oid").on(o=>o("fk_att.attnum","=",o.fn.any("fk_con.confkey")))).leftJoin("pg_catalog.pg_attrdef as def",n=>n.onRef("def.adrelid","=","att.attrelid").onRef("def.adnum","=","att.attnum")).whereRef("att.attrelid","=","cls.oid").where("att.attnum",">=",0).where("att.attisdropped","!=",!0).select(["att.attname as name","fk_att.attname as fk_column","fk_cls.relname as fk_table","fk_ns.nspname as fk_schema","tns.nspname as datatype_schema","typ.typname as datatype"]).select(n=>[n("att.attidentity","!=","").or(n("def.adbin","is not",null).and(n.fn("pg_get_expr",["def.adbin","def.adrelid"]),"like","nextval(%")).$castTo().as("autoinc"),n("att.attgenerated","!=","").$castTo().as("computed"),n.fn("pg_get_expr",["def.adbin","def.adrelid"]).as("default"),n("att.attnotnull","!=",!0).$castTo().as("nullable"),n.fn.coalesce(n.selectFrom("pg_catalog.pg_enum as enm").whereRef("enm.enumtypid","=","typ.oid").select(o=>o.fn.jsonAgg(o.ref("enm.enumlabel")).as("o")),p`'[]'`).as("options"),n.fn("array_position",["pk_con.conkey","att.attnum"]).as("pk")])).as("columns")]))}function re(){return[{schema:"zoo",name:"animals",columns:[{autoinc:!0,computed:!1,datatype:"int4",datatype_schema:"pg_catalog",default:"nextval('zoo.animals_id_seq'::regclass)",fk_column:null,fk_schema:null,fk_table:null,name:"id",nullable:!1,options:[],pk:1},{autoinc:!1,computed:!1,datatype:"text",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"name",nullable:!0,options:[],pk:null}]},{schema:"public",name:"users",columns:[{autoinc:!0,computed:!1,datatype:"int4",datatype_schema:"pg_catalog",default:"nextval('users_id_seq'::regclass)",fk_column:null,fk_schema:null,fk_table:null,name:"id",nullable:!1,options:[],pk:1},{autoinc:!1,computed:!1,datatype:"timestamp",datatype_schema:"pg_catalog",default:"CURRENT_TIMESTAMP",fk_column:null,fk_schema:null,fk_table:null,name:"created_at",nullable:!0,options:[],pk:null},{autoinc:!1,computed:!1,datatype:"timestamp",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"deleted_at",nullable:!0,options:[],pk:null},{autoinc:!1,computed:!1,datatype:"varchar",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"role",nullable:!0,options:[],pk:null},{autoinc:!1,computed:!1,datatype:"varchar",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"name",nullable:!0,options:[],pk:null},{autoinc:!1,computed:!0,datatype:"text",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"name_role",nullable:!1,options:[],pk:null}]},{schema:"public",name:"composite_pk",columns:[{autoinc:!1,computed:!1,datatype:"uuid",datatype_schema:"pg_catalog",default:"gen_random_uuid()",fk_column:null,fk_schema:null,fk_table:null,name:"id",nullable:!1,options:[],pk:1},{autoinc:!1,computed:!1,datatype:"text",datatype_schema:"pg_catalog",default:null,fk_column:null,fk_schema:null,fk_table:null,name:"name",nullable:!0,options:[],pk:2},{autoinc:!1,computed:!1,datatype:"timestamp",datatype_schema:"pg_catalog",default:"now()",fk_column:null,fk_schema:null,fk_table:null,name:"created_at",nullable:!0,options:[],pk:null}]}]}function ae(){let r=T();return k(r.selectNoFrom(r.fn("current_setting",[p.lit("timezone")]).as("timezone")))}function ne(){return[{timezone:"UTC"}]}function me(r){return r.where("ns.nspname","!~","^pg_").where("ns.nspname","!=","information_schema")}function $e(r){let{executor:e,...n}=r,o=D(),i=typeof e.lintSql=="function";async function u(a){try{let l=te(n),t=ae(),[[s,_],[g,y]]=await Promise.all([e.execute(l,a),e.execute(t,a)]);if(s)return m({error:s,query:l});if(g)return m({error:g,query:t});let b=y[0]?.timezone;return b?[null,se({query:l,tables:_,timezone:b})]:m({error:new Error("Timezone not found"),query:t})}catch(l){return m({error:l})}}return{defaultSchema:"public",capabilities:{fullTableSearch:!0,sqlDialect:"postgresql",sqlEditorAutocomplete:!0,sqlEditorLint:!0},async introspect(a){return await u(a)},async query(a,l){try{let t=W(a,n),[s,_]=await Q({executor:e,options:l,query:t,searchTerm:a.fullTableSearchTerm,state:o});return s?m({error:s,query:t}):[null,{filteredRowCount:_[0]?.__ps_count__||"0",rows:_,query:t}]}catch(t){return m({error:t})}},async raw(a,l){return await fe(e,a,l)},async sqlSchema(a,l){let[t,s]=await u(l);return t?[t]:[null,G({defaultSchema:"public",dialect:"postgresql",introspection:s})]},async sqlLint(a,l){if(i&&typeof e.lintSql=="function")try{let[t,s]=await e.lintSql(a,l);if(!t)return[null,s];if(!oe(t))return m({error:t});le(t)&&(i=!1)}catch(t){if(!oe(t))return m({error:t});le(t)&&(i=!1)}return await de(e,a,l)},async insert(a,l){try{let t=Z(a,n),[s,_]=await e.execute(t,l);return s?m({error:s,query:t}):[null,{rows:_,query:t}]}catch(t){return m({error:t})}},async update(a,l){try{let t=V(a,n),[s,_]=await e.execute(t,l);if(s)return m({error:s,query:t});let[g]=_;return g?[null,{row:g,query:t}]:m({error:new Error("Update failed"),query:t})}catch(t){return m({error:t})}},async delete(a,l){try{let t=X(a,n),[s]=await e.execute(t,l);return s?m({error:s,query:t}):[null,{...a,query:t}]}catch(t){return m({error:t})}}}}function oe(r){if(!(r instanceof Error))return!1;let e=r.message.toLowerCase();return e.includes("invalid procedure")||e.includes("unexpected server error")||e.includes("internal server error")||e.includes("bad gateway")||e.includes("service unavailable")||e.includes("not supported")||e.includes("method not allowed")}function le(r){if(!(r instanceof Error))return!1;let e=r.message.toLowerCase();return e.includes("invalid procedure")||e.includes("unexpected server error")||e.includes("internal server error")||e.includes("not supported")||e.includes("method not allowed")}async function de(r,e,n){let o=$(e.sql);if(!o.ok)return[null,{diagnostics:[o.diagnostic],schemaVersion:e.schemaVersion}];let i=[];for(let u of o.statements)try{let a=P(`EXPLAIN ${u.statement}`),[l]=await r.execute(a,n);if(!l)continue;i.push(...O({error:l,positionOffset:u.from,sql:u.statement}))}catch(a){i.push(...O({error:a,positionOffset:u.from,sql:u.statement}))}return[null,{diagnostics:i,schemaVersion:e.schemaVersion}]}async function fe(r,e,n){try{let o=P(e.sql),[i,u]=await r.execute(o,n);return i?m({error:i,query:o}):[null,{query:o,rowCount:u.length,rows:u}]}catch(o){return m({error:o})}}function se(r){let{query:e,tables:n,timezone:o}=r;return n.reduce((i,u)=>{let{schemas:a}=i,{columns:l,name:t,schema:s}=u,_=l.reduce((g,y)=>{let{autoinc:b,computed:h,datatype:A,datatype_schema:x,default:R,name:E,options:c,nullable:d}=y,f=A.startsWith("_"),S=f?A.slice(1):A;return{...g,[E]:{datatype:{...J[S]||{group:c.length>0?"enum":"raw"},isArray:f,isNative:x==="pg_catalog",name:f?`${S}[]`:S,options:c,schema:x},defaultValue:R,fkColumn:y.fk_column,fkSchema:y.fk_schema,fkTable:y.fk_table,isAutoincrement:b,isComputed:h,isRequired:!d&&!b&&!h&&R==null,name:E,nullable:d,pkPosition:y.pk,schema:s,table:t}}},{});return a[s]===void 0&&(a[s]={name:s,tables:{}}),a[s].tables[t]={columns:_,name:t,schema:s},i},{filterOperators:_e,query:e,schemas:{public:{name:"public",tables:{}}},timezone:o})}var _e=["=","!=",">",">=","<","<=","is","is not","like","not like","ilike","not ilike"];function Je(){let r=re(),[{timezone:e}]=ne();return se({tables:r,timezone:e,query:{parameters:[],sql:"<mocked>"}})}export{K as a,Z as b,W as c,De as d,V as e,X as f,te as g,re as h,ae as i,ne as j,$e as k,Je as l};
10
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/postgres-core/datatype.ts", "../data/postgres-core/builder.ts", "../data/postgres-core/full-table-search.ts", "../data/postgres-core/dml.ts", "../node_modules/.pnpm/kysely@0.28.10/node_modules/kysely/dist/esm/helpers/postgres.js", "../data/postgres-core/introspection.ts", "../data/postgres-core/adapter.ts"],
  "sourcesContent": ["import type { DataType } from \"../adapter\";\n\nexport const POSTGRESQL_DATA_TYPES_TO_METADATA: Record<\n  string,\n  Pick<DataType, \"format\" | \"group\">\n> = {\n  bool: {\n    group: \"boolean\",\n  },\n  boolean: {\n    group: \"boolean\",\n  },\n  bytea: {\n    group: \"string\",\n  },\n  char: {\n    group: \"string\",\n  },\n  citext: {\n    group: \"string\",\n  },\n  /**\n   * @example '2025-04-14'\n   */\n  date: {\n    format: \"YYYY-MM-DD\",\n    group: \"datetime\",\n  },\n  /**\n   * @example '1 day 2 hours'\n   */\n  interval: {\n    group: \"string\",\n  },\n  name: {\n    group: \"string\",\n  },\n  varchar: {\n    group: \"string\",\n  },\n  text: {\n    group: \"string\",\n  },\n  /**\n   * short form of `time without time zone`.\n   *\n   * @example '14:30:00'\n   */\n  time: {\n    format: \"HH:mm:ss.SSS\",\n    group: \"time\",\n  },\n  /**\n   * short form of `timestamp without time zone`.\n   *\n   * @example '2025-04-14 14:30:00'\n   */\n  timestamp: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\n    group: \"datetime\",\n  },\n  /**\n   * short form of `timestamp with time zone`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  timestamptz: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSSZZ\",\n    group: \"datetime\",\n  },\n  /**\n   * long form of `timestamp`.\n   *\n   * @example '2025-04-14 14:30:00'\n   */\n  \"timestamp without time zone\": {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\n    group: \"datetime\",\n  },\n  /**\n   * long form of `timestamptz`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  \"timestamp with time zone\": {\n    format: \"YYYY-MM-DD HH:mm:ss.SSSZZ\",\n    group: \"datetime\",\n  },\n  /**\n   * short form of `time with time zone`.\n   *\n   * @example '14:30:00+00'\n   */\n  timetz: {\n    format: \"HH:mm:ss.SSSZZ\",\n    group: \"time\",\n  },\n  /**\n   * long form of `time`.\n   *\n   * @example '14:30:00'\n   */\n  \"time without time zone\": {\n    format: \"HH:mm:ss.SSS\",\n    group: \"time\",\n  },\n  /**\n   * long form of `timetz`.\n   *\n   * @example '14:30:00+00'\n   */\n  \"time with time zone\": {\n    format: \"HH:mm:ss.SSSZZ\",\n    group: \"time\",\n  },\n  uuid: {\n    format: \"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\",\n    group: \"raw\",\n  },\n  int2: {\n    group: \"numeric\",\n  },\n  int4: {\n    group: \"numeric\",\n  },\n  int8: {\n    group: \"numeric\",\n  },\n  smallint: {\n    group: \"numeric\",\n  },\n  integer: {\n    group: \"numeric\",\n  },\n  bigint: {\n    group: \"numeric\",\n  },\n  decimal: {\n    group: \"numeric\",\n  },\n  numeric: {\n    group: \"numeric\",\n  },\n  real: {\n    group: \"numeric\",\n  },\n  float4: {\n    group: \"numeric\",\n  },\n  float8: {\n    group: \"numeric\",\n  },\n  \"double precision\": {\n    group: \"numeric\",\n  },\n  json: {\n    group: \"json\",\n  },\n  jsonb: {\n    group: \"json\",\n  },\n};\n", "import { type Kysely, PostgresAdapter, PostgresQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getPostgreSQLBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder({\n    ...requirements,\n    Adapter: PostgresAdapter,\n    QueryCompiler: PostgresQueryCompiler,\n  });\n}\n", "import type { Table } from \"../adapter\";\nimport {\n  buildFullTableSearchPlan as buildBaseFullTableSearchPlan,\n  createFullTableSearchExecutionState,\n  executeQueryWithFullTableSearchGuardrails,\n  FULL_TABLE_SEARCH_MAX_TEXT_COLUMNS,\n  FULL_TABLE_SEARCH_MIN_QUERY_LENGTH,\n  FULL_TABLE_SEARCH_MYSQL_LOCK_WAIT_TIMEOUT_SECONDS,\n  FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS,\n  FULL_TABLE_SEARCH_TIMEOUT_MESSAGE,\n  FULL_TABLE_SEARCH_TIMEOUT_MS,\n  type FullTableSearchPlan,\n  type FullTableSearchPredicate,\n  FullTableSearchTimeoutError,\n  getFullTableSearchExpression,\n  isFullTableSearchRequest,\n} from \"../full-table-search\";\n\nexport {\n  createFullTableSearchExecutionState,\n  executeQueryWithFullTableSearchGuardrails,\n  FULL_TABLE_SEARCH_MAX_TEXT_COLUMNS,\n  FULL_TABLE_SEARCH_MIN_QUERY_LENGTH,\n  FULL_TABLE_SEARCH_MYSQL_LOCK_WAIT_TIMEOUT_SECONDS,\n  FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS,\n  FULL_TABLE_SEARCH_TIMEOUT_MESSAGE,\n  FULL_TABLE_SEARCH_TIMEOUT_MS,\n  FullTableSearchTimeoutError,\n  getFullTableSearchExpression,\n  isFullTableSearchRequest,\n};\nexport type {\n  FullTableSearchDialect,\n  FullTableSearchExecutionState,\n  FullTableSearchPredicate,\n} from \"../full-table-search\";\n\nexport function buildFullTableSearchPlan(args: {\n  searchTerm: string | undefined;\n  table: Table;\n}): FullTableSearchPlan {\n  const basePlan = buildBaseFullTableSearchPlan(args);\n  const normalizedSearchTerm = basePlan.normalizedSearchTerm;\n\n  if (normalizedSearchTerm.length < FULL_TABLE_SEARCH_MIN_QUERY_LENGTH) {\n    return basePlan;\n  }\n\n  const existingTextColumns = new Set(\n    basePlan.predicates.flatMap((predicate) =>\n      predicate.kind === \"text-like\" ? [predicate.column] : [],\n    ),\n  );\n  const remainingTextSlots =\n    FULL_TABLE_SEARCH_MAX_TEXT_COLUMNS - existingTextColumns.size;\n\n  if (remainingTextSlots <= 0) {\n    return basePlan;\n  }\n\n  const pattern = `%${escapeLikePattern(normalizedSearchTerm)}%`;\n  const supplementalPredicates: FullTableSearchPredicate[] = [];\n\n  for (const column of Object.values(args.table.columns)) {\n    if (existingTextColumns.has(column.name)) {\n      continue;\n    }\n\n    supplementalPredicates.push({\n      column: column.name,\n      kind: \"text-like\",\n      pattern,\n    });\n\n    if (supplementalPredicates.length >= remainingTextSlots) {\n      break;\n    }\n  }\n\n  if (supplementalPredicates.length === 0) {\n    return basePlan;\n  }\n\n  return {\n    ...basePlan,\n    predicates: [...basePlan.predicates, ...supplementalPredicates],\n  };\n}\n\nfunction escapeLikePattern(value: string): string {\n  return value.replaceAll(\"%\", \"\\\\%\").replaceAll(\"_\", \"\\\\_\");\n}\n", "import {\n  expressionBuilder,\n  type InferResult,\n  type SimpleReferenceExpression,\n  sql,\n} from \"kysely\";\n\nimport type {\n  AdapterDeleteDetails,\n  AdapterInsertDetails,\n  AdapterQueryDetails,\n  AdapterUpdateDetails,\n} from \"../adapter\";\nimport {\n  applyInferredRowFilters,\n  applyTransformations,\n  type BuilderRequirements,\n  compile,\n  getSelectFilterExpression,\n} from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getPostgreSQLBuilder } from \"./builder\";\nimport {\n  buildFullTableSearchPlan,\n  FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS,\n  FULL_TABLE_SEARCH_TIMEOUT_MS,\n  getFullTableSearchExpression,\n  isFullTableSearchRequest,\n} from \"./full-table-search\";\nimport type { mockTablesQuery } from \"./introspection\";\n\n/**\n * Inserts one or more rows into a table and returns the inserted rows along with their `ctid`.\n */\nexport function getInsertQuery(\n  details: AdapterInsertDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder =\n    getPostgreSQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .insertInto(tableName)\n      .values(\n        applyTransformations({\n          columns,\n          context: \"insert\",\n          supportsDefaultKeyword: true,\n          values: rows,\n        }),\n      )\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_inserted_at__\")),\n  );\n}\n\n/**\n * Returns a query that selects all columns from a table, along with an unbound row count as `__ps_count__`.\n */\nexport function getSelectQuery(\n  details: AdapterQueryDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    filter = { after: \"and\", filters: [], kind: \"FilterGroup\" },\n    fullTableSearchTerm,\n    pageIndex,\n    pageSize,\n    sortOrder,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder =\n    getPostgreSQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  const appliedFilterExpression = getSelectFilterExpression(\n    filter.filters,\n    columns,\n  );\n  const fullTableSearchPlan = buildFullTableSearchPlan({\n    searchTerm: fullTableSearchTerm,\n    table: details.table,\n  });\n  const combinedWhereExpression =\n    fullTableSearchPlan.predicates.length > 0\n      ? (eb: Parameters<ReturnType<typeof getSelectFilterExpression>>[0]) =>\n          eb.and([\n            appliedFilterExpression(eb),\n            getFullTableSearchExpression(fullTableSearchPlan, {\n              dialect: \"postgres\",\n            })(eb),\n          ])\n      : appliedFilterExpression;\n\n  const AGG_NAME = \"__ps_agg__\";\n  const COUNT_REF = \"__ps_count__\";\n  const SEARCH_GUARDRAILS_NAME = \"__ps_search_guardrails__\";\n  const shouldApplySearchGuardrails =\n    isFullTableSearchRequest(fullTableSearchTerm);\n  if (shouldApplySearchGuardrails) {\n    return compile(\n      builder\n        .with(SEARCH_GUARDRAILS_NAME, (qb) =>\n          qb.selectNoFrom((eb) => [\n            eb\n              .fn<string>(\"set_config\", [\n                sql.lit(\"statement_timeout\"),\n                sql.lit(`${FULL_TABLE_SEARCH_TIMEOUT_MS}ms`),\n                sql.lit(true),\n              ])\n              .as(\"__ps_statement_timeout__\"),\n            eb\n              .fn<string>(\"set_config\", [\n                sql.lit(\"lock_timeout\"),\n                sql.lit(`${FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS}ms`),\n                sql.lit(true),\n              ])\n              .as(\"__ps_lock_timeout__\"),\n          ]),\n        )\n        .with(AGG_NAME, (qb) =>\n          qb\n            .withSchema(schema)\n            .selectFrom(tableName)\n            .innerJoin(\n              sql.table(SEARCH_GUARDRAILS_NAME).as(SEARCH_GUARDRAILS_NAME),\n              (jb) => jb.onTrue(),\n            )\n            .where(combinedWhereExpression)\n            .select((eb) =>\n              eb\n                .cast<BigIntString>(\n                  eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)),\n                  \"text\",\n                )\n                .as(COUNT_REF),\n            ),\n        )\n        .withSchema(schema)\n        .selectFrom(tableName)\n        .innerJoin(SEARCH_GUARDRAILS_NAME, (jb) => jb.onTrue())\n        .innerJoin(AGG_NAME, (jb) => jb.onTrue())\n        // TODO: cursor pagination?\n        .where(combinedWhereExpression)\n        .select(\n          `${AGG_NAME}.${COUNT_REF}` satisfies SimpleReferenceExpression<\n            { [AGG_NAME]: { [COUNT_REF]: BigIntString } },\n            typeof AGG_NAME\n          >,\n        )\n        .select(Object.keys(columns))\n        .$call((qb) => {\n          return sortOrder.reduce((currentQuery, item) => {\n            const column = columns[item.column];\n\n            if (\n              column?.datatype.group === \"numeric\" &&\n              !column.datatype.isArray\n            ) {\n              return currentQuery.orderBy(\n                sql`cast(${sql.ref(item.column)} as numeric)`,\n                item.direction,\n              );\n            }\n\n            return currentQuery.orderBy(item.column, item.direction);\n          }, qb);\n        })\n        .limit(pageSize)\n        // we're injecting the offset value here to avoid serialization complexity (`bigint` is a no-go for `JSON.stringify`).\n        .offset(sql.lit(BigInt(pageIndex) * BigInt(pageSize))),\n    );\n  }\n\n  const countQuery = builder\n    .withSchema(schema)\n    .selectFrom(tableName)\n    .where(combinedWhereExpression)\n    .select((eb) =>\n      eb\n        .cast<BigIntString>(\n          eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)),\n          \"text\",\n        )\n        .as(COUNT_REF),\n    );\n\n  return compile(\n    builder\n      .with(AGG_NAME, () => countQuery)\n      .withSchema(schema)\n      .selectFrom(tableName)\n      .innerJoin(AGG_NAME, (jb) => jb.onTrue())\n      // TODO: cursor pagination?\n      .where(combinedWhereExpression)\n      .select(\n        `${AGG_NAME}.${COUNT_REF}` satisfies SimpleReferenceExpression<\n          { [AGG_NAME]: InferResult<typeof countQuery>[number] },\n          typeof AGG_NAME\n        >,\n      )\n      .select(Object.keys(columns))\n      .$call((qb) => {\n        return sortOrder.reduce((currentQuery, item) => {\n          const column = columns[item.column];\n\n          if (\n            column?.datatype.group === \"numeric\" &&\n            !column.datatype.isArray\n          ) {\n            return currentQuery.orderBy(\n              sql`cast(${sql.ref(item.column)} as numeric)`,\n              item.direction,\n            );\n          }\n\n          return currentQuery.orderBy(item.column, item.direction);\n        }, qb);\n      })\n      .limit(pageSize)\n      // we're injecting the offset value here to avoid serialization complexity (`bigint` is a no-go for `JSON.stringify`).\n      .offset(sql.lit(BigInt(pageIndex) * BigInt(pageSize))),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockSelectQuery() {\n  return [\n    {\n      created_at: new Date(\"2025-01-26T21:56:12.345Z\"),\n      deleted_at: null,\n      id: 1,\n      name: \"John Doe\",\n      __ps_count__: \"2\",\n      role: \"admin\",\n      name_role: \"Jonn Doe - admin\",\n    },\n    {\n      created_at: new Date(\"2025-01-26T20:56:12.345Z\"),\n      deleted_at: null,\n      id: 2,\n      name: \"Jane Doe\",\n      __ps_count__: \"2\",\n      role: \"poweruser\",\n      name_role: \"Jane Doe - poweruser\",\n    },\n  ] as const satisfies {\n    // best effort no need to go overboard\n    [K in\n      | ReturnType<typeof mockTablesQuery>[1][\"columns\"][number][\"name\"]\n      | \"__ps_count__\"]: unknown;\n  }[];\n}\n\n/**\n * Returns a query that updates a given row in a table with given changes.\n */\nexport function getUpdateQuery(\n  details: AdapterUpdateDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    changes,\n    row,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder =\n    getPostgreSQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .updateTable(tableName)\n      .set(\n        applyTransformations({\n          columns,\n          context: \"update\",\n          supportsDefaultKeyword: true,\n          values: changes,\n        }),\n      )\n      .$call(applyInferredRowFilters([row], columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_updated_at__\")),\n  );\n}\n\n/**\n * Returns a query that deletes a given set of rows.\n */\nexport function getDeleteQuery(\n  details: AdapterDeleteDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder =\n    getPostgreSQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .deleteFrom(tableName)\n      .$call(applyInferredRowFilters(rows, columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_deleted_at__\")),\n  );\n}\n\nfunction getCurrentTimestampMillis() {\n  const eb = expressionBuilder();\n\n  return eb.cast<BigIntString>(\n    eb.fn(\"floor\", [eb(eb.fn(\"extract\", [sql`epoch from now()`]), \"*\", 1_000)]),\n    \"text\",\n  );\n}\n", "/// <reference types=\"./postgres.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\n/**\n * A postgres helper for aggregating a subquery (or other expression) into a JSONB array.\n *\n * ### Examples\n *\n * <!-- siteExample(\"select\", \"Nested array\", 110) -->\n *\n * While kysely is not an ORM and it doesn't have the concept of relations, we do provide\n * helpers for fetching nested objects and arrays in a single query. In this example we\n * use the `jsonArrayFrom` helper to fetch person's pets along with the person's id.\n *\n * Please keep in mind that the helpers under the `kysely/helpers` folder, including\n * `jsonArrayFrom`, are not guaranteed to work with third party dialects. In order for\n * them to work, the dialect must automatically parse the `json` data type into\n * JavaScript JSON values like objects and arrays. Some dialects might simply return\n * the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`\n * to parse the results.\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonArrayFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .orderBy('pet.name')\n *     ).as('pets')\n *   ])\n *   .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", (\n *   select coalesce(json_agg(agg), '[]') from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     order by \"pet\".\"name\"\n *   ) as agg\n * ) as \"pets\"\n * from \"person\"\n * ```\n */\nexport function jsonArrayFrom(expr) {\n    return sql `(select coalesce(json_agg(agg), '[]') from ${expr} as agg)`;\n}\n/**\n * A postgres helper for turning a subquery (or other expression) into a JSON object.\n *\n * The subquery must only return one row.\n *\n * ### Examples\n *\n * <!-- siteExample(\"select\", \"Nested object\", 120) -->\n *\n * While kysely is not an ORM and it doesn't have the concept of relations, we do provide\n * helpers for fetching nested objects and arrays in a single query. In this example we\n * use the `jsonObjectFrom` helper to fetch person's favorite pet along with the person's id.\n *\n * Please keep in mind that the helpers under the `kysely/helpers` folder, including\n * `jsonObjectFrom`, are not guaranteed to work with third-party dialects. In order for\n * them to work, the dialect must automatically parse the `json` data type into\n * JavaScript JSON values like objects and arrays. Some dialects might simply return\n * the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`\n * to parse the results.\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonObjectFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .where('pet.is_favorite', '=', true)\n *     ).as('favorite_pet')\n *   ])\n *   .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", (\n *   select to_json(obj) from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     and \"pet\".\"is_favorite\" = $1\n *   ) as obj\n * ) as \"favorite_pet\"\n * from \"person\"\n * ```\n */\nexport function jsonObjectFrom(expr) {\n    return sql `(select to_json(obj) from ${expr} as obj)`;\n}\n/**\n * The PostgreSQL `json_build_object` function.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `PostgresDialect`.\n * While the produced SQL is compatible with all PostgreSQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n * import { jsonBuildObject } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonBuildObject({\n *       first: eb.ref('first_name'),\n *       last: eb.ref('last_name'),\n *       full: sql<string>`first_name ||\u00A0' ' || last_name`\n *     }).as('name')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.name.first\n * result[0]?.name.last\n * result[0]?.name.full\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", json_build_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', first_name || ' ' || last_name\n * ) as \"name\"\n * from \"person\"\n * ```\n */\nexport function jsonBuildObject(obj) {\n    return sql `json_build_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;\n}\n/**\n * The PostgreSQL `merge_action` function.\n *\n * This function can be used in a `returning` clause to get the action that was\n * performed in a `mergeInto` query. The function returns one of the following\n * strings: `'INSERT'`, `'UPDATE'`, or `'DELETE'`.\n *\n * ### Examples\n *\n * ```ts\n * import { mergeAction } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .mergeInto('person as p')\n *   .using('person_backup as pb', 'p.id', 'pb.id')\n *   .whenMatched()\n *   .thenUpdateSet(({ ref }) => ({\n *     first_name: ref('pb.first_name'),\n *     updated_at: ref('pb.updated_at').$castTo<string | null>(),\n *   }))\n *   .whenNotMatched()\n *   .thenInsertValues(({ ref}) => ({\n *     id: ref('pb.id'),\n *     first_name: ref('pb.first_name'),\n *     created_at: ref('pb.updated_at'),\n *     updated_at: ref('pb.updated_at').$castTo<string | null>(),\n *   }))\n *   .returning([mergeAction().as('action'), 'p.id', 'p.updated_at'])\n *   .execute()\n *\n * result[0].action\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\" as \"p\"\n * using \"person_backup\" as \"pb\" on \"p\".\"id\" = \"pb\".\"id\"\n * when matched then update set\n *   \"first_name\" = \"pb\".\"first_name\",\n *   \"updated_at\" = \"pb\".\"updated_at\"::text\n * when not matched then insert values (\"id\", \"first_name\", \"created_at\", \"updated_at\")\n * values (\"pb\".\"id\", \"pb\".\"first_name\", \"pb\".\"updated_at\", \"pb\".\"updated_at\")\n * returning merge_action() as \"action\", \"p\".\"id\", \"p\".\"updated_at\"\n * ```\n */\nexport function mergeAction() {\n    return sql `merge_action()`;\n}\n", "import { type SelectQueryBuilder, sql } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/postgres\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getPostgreSQLBuilder } from \"./builder\";\n\nconst REGULAR_TABLE_KIND = \"r\";\nconst VIEW_TABLE_KIND = \"v\";\nconst TABLE_KINDS = [REGULAR_TABLE_KIND, VIEW_TABLE_KIND] as const;\ntype TableKind = (typeof TABLE_KINDS)[number];\n\ninterface Database {\n  /** column defaults */\n  \"pg_catalog.pg_attrdef\": {\n    /** default expression as a node tree, use pg_get_expr(adbin, adrelid) */\n    adbin: string;\n    /** column number */\n    adnum: number;\n    /** table identifier */\n    adrelid: number;\n  };\n  /** columns */\n  \"pg_catalog.pg_attribute\": {\n    /**\n     * generation flag for computed columns:\n     * '' (empty) for regular columns,\n     * 's' for STORED generated columns (Postgres GENERATED ALWAYS AS).\n     */\n    attgenerated: \"\" | \"s\";\n    /**\n     * identity column flag:\n     * '' (empty) for regular columns,\n     * 'a' for ALWAYS (GENERATED ALWAYS AS IDENTITY),\n     * 'd' for BY DEFAULT (GENERATED BY DEFAULT AS IDENTITY).\n     */\n    attidentity: \"\" | \"a\" | \"d\";\n    /** was the column dropped. dropped columns might not be 100% removed immediately. */\n    attisdropped: boolean;\n    /** column name */\n    attname: string;\n    /** NOT NULL constraint: true if the column has a NOT NULL constraint */\n    attnotnull: boolean;\n    /** column order number in its table */\n    attnum: number;\n    /** table/view identifier */\n    attrelid: string;\n    /** column datatype identifier */\n    atttypid: string;\n  };\n  /** resources, e.g. tables, sequences, etc. */\n  \"pg_catalog.pg_class\": {\n    /** resource id */\n    oid: number;\n    /** resource kind: regular table, view */\n    relkind: TableKind;\n    /** resource name */\n    relname: string;\n    /** schema id */\n    relnamespace: number;\n  };\n  /** constraints */\n  \"pg_catalog.pg_constraint\": {\n    /** if a foreign key, the referenced columns */\n    confkey: number[];\n    /** if a foreign key, the referenced table */\n    confrelid: number;\n    /**\n     * an ordered array of columns included in the constraint.\n     *\n     * the columns are represented by their ordinal number (`attnum`) in their relation (table).\n     *\n     * @example `'{1,3}'` - a constraint with 2 columns, the 1st & 3rd in their table.\n     */\n    conkey: number[];\n    /** relation (table) id which this constraint was created for */\n    conrelid: number;\n    /**\n     * constraint type.\n     *\n     * `'p'` - primary key constraint.\n     * `'f'` - foreign key constraint.\n     */\n    contype: \"p\" | \"f\" | (string & {});\n  };\n  /** enum types' values */\n  \"pg_catalog.pg_enum\": {\n    /** enum value */\n    enumlabel: string;\n    /** enum's type id */\n    enumtypid: number;\n  };\n  /** schemas */\n  \"pg_catalog.pg_namespace\": {\n    /** schema name */\n    nspname: string;\n    /** schema id */\n    oid: number;\n  };\n  /** datatypes */\n  \"pg_catalog.pg_type\": {\n    /** type id */\n    oid: number;\n    /** type name */\n    typname: string;\n    /** type's schema (aka namespace) id */\n    typnamespace: number;\n  };\n}\n\n/**\n * Returns a query that returns metadata for all user-defined tables and views in the database.\n */\nexport function getTablesQuery(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  return compile(\n    getPostgreSQLBuilder<Database>(requirements)\n      .selectFrom(\"pg_catalog.pg_class as cls\")\n      .innerJoin(\"pg_catalog.pg_namespace as ns\", \"cls.relnamespace\", \"ns.oid\")\n      .$call(excludeSystemTables)\n      // regular tables or views\n      .where(\"cls.relkind\", \"in\", TABLE_KINDS)\n      .select((eb) => [\n        \"ns.nspname as schema\",\n        \"cls.relname as name\",\n        jsonArrayFrom(\n          eb\n            .selectFrom(\"pg_catalog.pg_attribute as att\")\n            .innerJoin(\"pg_catalog.pg_type as typ\", \"typ.oid\", \"att.atttypid\")\n            .innerJoin(\n              \"pg_catalog.pg_namespace as tns\",\n              \"tns.oid\",\n              \"typ.typnamespace\",\n            )\n            .leftJoin(\"pg_catalog.pg_constraint as pk_con\", (jb) =>\n              jb\n                .on(\"pk_con.contype\", \"=\", \"p\")\n                .onRef(\"pk_con.conrelid\", \"=\", \"cls.oid\")\n                .on((eb) => eb(\"att.attnum\", \"=\", eb.fn.any(\"pk_con.conkey\"))),\n            )\n            .leftJoin(\"pg_catalog.pg_constraint as fk_con\", (jb) =>\n              jb\n                .on(\"fk_con.contype\", \"=\", \"f\")\n                .onRef(\"fk_con.conrelid\", \"=\", \"cls.oid\")\n                .on((eb) => eb(\"att.attnum\", \"=\", eb.fn.any(\"fk_con.conkey\"))),\n            )\n            .leftJoin(\n              \"pg_catalog.pg_class as fk_cls\",\n              \"fk_cls.oid\",\n              \"fk_con.confrelid\",\n            )\n            .leftJoin(\n              \"pg_catalog.pg_namespace as fk_ns\",\n              \"fk_ns.oid\",\n              \"fk_cls.relnamespace\",\n            )\n            .leftJoin(\"pg_catalog.pg_attribute as fk_att\", (jb) =>\n              jb\n                .onRef(\"fk_att.attrelid\", \"=\", \"fk_cls.oid\")\n                // Use a callback for the .on() condition to ensure correct context for types\n                .on((on_eb) =>\n                  on_eb(\"fk_att.attnum\", \"=\", on_eb.fn.any(\"fk_con.confkey\")),\n                ),\n            )\n            .leftJoin(\"pg_catalog.pg_attrdef as def\", (jb) =>\n              jb\n                .onRef(\"def.adrelid\", \"=\", \"att.attrelid\")\n                .onRef(\"def.adnum\", \"=\", \"att.attnum\"),\n            )\n            .whereRef(\"att.attrelid\", \"=\", \"cls.oid\")\n            // exclude system columns\n            .where(\"att.attnum\", \">=\", 0)\n            .where(\"att.attisdropped\", \"!=\", true)\n            .select([\n              \"att.attname as name\",\n              \"fk_att.attname as fk_column\",\n              \"fk_cls.relname as fk_table\",\n              \"fk_ns.nspname as fk_schema\",\n              \"tns.nspname as datatype_schema\",\n              \"typ.typname as datatype\",\n            ])\n            .select((eb) => [\n              eb(\"att.attidentity\", \"!=\", \"\")\n                .or(\n                  eb(\"def.adbin\", \"is not\", null).and(\n                    eb.fn(\"pg_get_expr\", [\"def.adbin\", \"def.adrelid\"]),\n                    \"like\",\n                    \"nextval(%\",\n                  ),\n                )\n                .$castTo<boolean>()\n                .as(\"autoinc\"),\n              eb(\"att.attgenerated\", \"!=\", \"\")\n                .$castTo<boolean>()\n                .as(\"computed\"),\n              eb\n                .fn<string | null>(\"pg_get_expr\", [\"def.adbin\", \"def.adrelid\"])\n                .as(\"default\"),\n              eb(\"att.attnotnull\", \"!=\", true)\n                .$castTo<boolean>()\n                .as(\"nullable\"),\n              eb.fn\n                .coalesce(\n                  eb\n                    .selectFrom(\"pg_catalog.pg_enum as enm\")\n                    .whereRef(\"enm.enumtypid\", \"=\", \"typ.oid\")\n                    .select((eb) =>\n                      eb.fn.jsonAgg(eb.ref(\"enm.enumlabel\")).as(\"o\"),\n                    ),\n                  sql<string[]>`'[]'`,\n                )\n                .as(\"options\"),\n              eb\n                .fn<\n                  number | null\n                >(\"array_position\", [\"pk_con.conkey\", \"att.attnum\"])\n                .as(\"pk\"),\n            ]),\n        ).as(\"columns\"),\n      ]),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTablesQuery() {\n  return [\n    {\n      schema: \"zoo\",\n      name: \"animals\",\n      columns: [\n        {\n          autoinc: true,\n          computed: false,\n          datatype: \"int4\",\n          datatype_schema: \"pg_catalog\",\n          default: \"nextval('zoo.animals_id_seq'::regclass)\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: false,\n          options: [],\n          pk: 1,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n      ],\n    },\n    {\n      schema: \"public\",\n      name: \"users\",\n      columns: [\n        {\n          autoinc: true,\n          computed: false,\n          datatype: \"int4\",\n          datatype_schema: \"pg_catalog\",\n          default: \"nextval('users_id_seq'::regclass)\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: false,\n          options: [],\n          pk: 1,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          default: \"CURRENT_TIMESTAMP\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"deleted_at\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"varchar\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"role\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"varchar\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n        {\n          autoinc: false,\n          computed: true,\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"name_role\",\n          nullable: false,\n          options: [],\n          pk: null,\n        },\n      ],\n    },\n    {\n      schema: \"public\",\n      name: \"composite_pk\",\n      columns: [\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"uuid\",\n          datatype_schema: \"pg_catalog\",\n          default: \"gen_random_uuid()\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: false,\n          options: [],\n          pk: 1,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          default: null,\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: true,\n          options: [],\n          pk: 2,\n        },\n        {\n          autoinc: false,\n          computed: false,\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          default: \"now()\",\n          fk_column: null,\n          fk_schema: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: true,\n          options: [],\n          pk: null,\n        },\n      ],\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n\n/**\n * Returns a query that returns the current timezone setting of the PostgreSQL database.\n */\nexport function getTimezoneQuery() {\n  const builder = getPostgreSQLBuilder();\n\n  return compile(\n    builder.selectNoFrom(\n      builder\n        .fn<string>(\"current_setting\", [sql.lit(\"timezone\")])\n        .as(\"timezone\"),\n    ),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTimezoneQuery() {\n  return [{ timezone: \"UTC\" }] as const satisfies QueryResult<\n    typeof getTimezoneQuery\n  >;\n}\n\n/**\n * We don't want PostgreSQL internals in introspection results. To be used in `$call`.\n */\nfunction excludeSystemTables<\n  T extends SelectQueryBuilder<\n    Database & {\n      ns: Database[\"pg_catalog.pg_namespace\"];\n      cls: Database[\"pg_catalog.pg_class\"];\n    },\n    \"ns\" | \"cls\",\n    object\n  >,\n>(qb: T): T {\n  return qb\n    .where(`ns.nspname`, `!~`, `^pg_`)\n    .where(`ns.nspname`, `!=`, `information_schema`) as never;\n}\n", "import {\n  type Adapter,\n  type AdapterDeleteResult,\n  type AdapterError,\n  type AdapterInsertResult,\n  type AdapterIntrospectResult,\n  type AdapterQueryResult,\n  type AdapterRawDetails,\n  type AdapterRawResult,\n  type AdapterRequirements,\n  type AdapterSqlLintDetails,\n  type AdapterSqlLintResult,\n  type AdapterSqlSchemaResult,\n  type AdapterUpdateResult,\n  type Column,\n  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport {\n  createFullTableSearchExecutionState,\n  executeQueryWithFullTableSearchGuardrails,\n} from \"../full-table-search\";\nimport { asQuery, type Query, QueryResult } from \"../query\";\nimport { createSqlEditorSchemaFromIntrospection } from \"../sql-editor-schema\";\nimport type { Either } from \"../type-utils\";\nimport { POSTGRESQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport {\n  getDeleteQuery,\n  getInsertQuery,\n  getSelectQuery,\n  getUpdateQuery,\n} from \"./dml\";\nimport {\n  getTablesQuery,\n  getTimezoneQuery,\n  mockTablesQuery,\n  mockTimezoneQuery,\n} from \"./introspection\";\nimport {\n  createLintDiagnosticsFromPostgresError,\n  validateSqlForLint,\n} from \"./sql-lint\";\n\nexport type PostgresAdapterRequirements = AdapterRequirements;\n\nexport function createPostgresAdapter(\n  requirements: PostgresAdapterRequirements,\n): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n  const fullTableSearchState = createFullTableSearchExecutionState();\n  let canUseExecutorLintTransport = typeof executor.lintSql === \"function\";\n\n  async function introspectDatabase(\n    options: Parameters<Adapter[\"introspect\"]>[0],\n  ): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n    try {\n      const tablesQuery = getTablesQuery(otherRequirements);\n      const timezoneQuery = getTimezoneQuery();\n\n      const [[tablesError, tables], [timezoneError, timezones]] =\n        await Promise.all([\n          executor.execute(tablesQuery, options),\n          executor.execute(timezoneQuery, options),\n        ]);\n\n      if (tablesError) {\n        return createAdapterError({ error: tablesError, query: tablesQuery });\n      }\n\n      if (timezoneError) {\n        return createAdapterError({\n          error: timezoneError,\n          query: timezoneQuery,\n        });\n      }\n\n      const timezone = timezones[0]?.timezone;\n\n      if (!timezone) {\n        return createAdapterError({\n          error: new Error(\"Timezone not found\"),\n          query: timezoneQuery,\n        });\n      }\n\n      return [\n        null,\n        createIntrospection({ query: tablesQuery, tables, timezone }),\n      ];\n    } catch (error: unknown) {\n      return createAdapterError({ error: error as Error });\n    }\n  }\n\n  return {\n    defaultSchema: \"public\",\n    capabilities: {\n      fullTableSearch: true,\n      sqlDialect: \"postgresql\",\n      sqlEditorAutocomplete: true,\n      sqlEditorLint: true,\n    },\n\n    async introspect(\n      options,\n    ): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      return await introspectDatabase(options);\n    },\n\n    async query(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n        const [error, results] =\n          await executeQueryWithFullTableSearchGuardrails({\n            executor,\n            options,\n            query,\n            searchTerm: details.fullTableSearchTerm,\n            state: fullTableSearchState,\n          });\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [\n          null,\n          {\n            filteredRowCount: results[0]?.__ps_count__ || \"0\",\n            rows: results,\n            query,\n          },\n        ];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async raw(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterRawResult>> {\n      return await executeRawQuery(executor, details, options);\n    },\n\n    async sqlSchema(\n      _details,\n      options,\n    ): Promise<Either<AdapterError, AdapterSqlSchemaResult>> {\n      const [error, introspection] = await introspectDatabase(options);\n\n      if (error) {\n        return [error];\n      }\n\n      return [\n        null,\n        createSqlEditorSchemaFromIntrospection({\n          defaultSchema: \"public\",\n          dialect: \"postgresql\",\n          introspection,\n        }),\n      ];\n    },\n\n    async sqlLint(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterSqlLintResult>> {\n      if (canUseExecutorLintTransport && typeof executor.lintSql === \"function\") {\n        try {\n          const [error, result] = await executor.lintSql(details, options);\n\n          if (!error) {\n            return [null, result];\n          }\n\n          if (!shouldFallbackToExplainLint(error)) {\n            return createAdapterError({ error });\n          }\n\n          if (shouldDisableLintTransport(error)) {\n            canUseExecutorLintTransport = false;\n          }\n        } catch (error: unknown) {\n          if (!shouldFallbackToExplainLint(error)) {\n            return createAdapterError({ error: error as Error });\n          }\n\n          if (shouldDisableLintTransport(error)) {\n            canUseExecutorLintTransport = false;\n          }\n        }\n      }\n\n      return await lintWithExplainFallback(executor, details, options);\n    },\n\n    async insert(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterInsertResult>> {\n      try {\n        const query = getInsertQuery(details, otherRequirements);\n\n        const [error, rows] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { rows, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async update(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      try {\n        const query = getUpdateQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        const [row] = results;\n\n        if (!row) {\n          return createAdapterError({\n            error: new Error(\"Update failed\"),\n            query,\n          });\n        }\n\n        return [null, { row, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async delete(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n\n        const [error] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { ...details, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n  };\n}\n\nfunction shouldFallbackToExplainLint(error: unknown): boolean {\n  if (!(error instanceof Error)) {\n    return false;\n  }\n\n  const message = error.message.toLowerCase();\n\n  return (\n    message.includes(\"invalid procedure\") ||\n    message.includes(\"unexpected server error\") ||\n    message.includes(\"internal server error\") ||\n    message.includes(\"bad gateway\") ||\n    message.includes(\"service unavailable\") ||\n    message.includes(\"not supported\") ||\n    message.includes(\"method not allowed\")\n  );\n}\n\nfunction shouldDisableLintTransport(error: unknown): boolean {\n  if (!(error instanceof Error)) {\n    return false;\n  }\n\n  const message = error.message.toLowerCase();\n\n  return (\n    message.includes(\"invalid procedure\") ||\n    message.includes(\"unexpected server error\") ||\n    message.includes(\"internal server error\") ||\n    message.includes(\"not supported\") ||\n    message.includes(\"method not allowed\")\n  );\n}\n\nasync function lintWithExplainFallback(\n  executor: AdapterRequirements[\"executor\"],\n  details: AdapterSqlLintDetails,\n  options: Parameters<NonNullable<Adapter[\"sqlLint\"]>>[1],\n): Promise<Either<AdapterError, AdapterSqlLintResult>> {\n  const validation = validateSqlForLint(details.sql);\n\n  if (!validation.ok) {\n    return [\n      null,\n      {\n        diagnostics: [validation.diagnostic],\n        schemaVersion: details.schemaVersion,\n      },\n    ];\n  }\n\n  const diagnostics: AdapterSqlLintResult[\"diagnostics\"] = [];\n\n  for (const statement of validation.statements) {\n    try {\n      const explainQuery = asQuery<Record<string, unknown>>(\n        `EXPLAIN ${statement.statement}`,\n      );\n      const [error] = await executor.execute(explainQuery, options);\n\n      if (!error) {\n        continue;\n      }\n\n      diagnostics.push(\n        ...createLintDiagnosticsFromPostgresError({\n          error,\n          positionOffset: statement.from,\n          sql: statement.statement,\n        }),\n      );\n    } catch (error: unknown) {\n      diagnostics.push(\n        ...createLintDiagnosticsFromPostgresError({\n          error,\n          positionOffset: statement.from,\n          sql: statement.statement,\n        }),\n      );\n    }\n  }\n\n  return [\n    null,\n    {\n      diagnostics,\n      schemaVersion: details.schemaVersion,\n    },\n  ];\n}\n\nasync function executeRawQuery(\n  executor: AdapterRequirements[\"executor\"],\n  details: AdapterRawDetails,\n  options: Parameters<Adapter[\"raw\"]>[1],\n): Promise<Either<AdapterError, AdapterRawResult>> {\n  try {\n    const query = asQuery<Record<string, unknown>>(details.sql);\n    const [error, rows] = await executor.execute(query, options);\n\n    if (error) {\n      return createAdapterError({ error, query });\n    }\n\n    return [\n      null,\n      {\n        query,\n        rowCount: rows.length,\n        rows: rows,\n      },\n    ];\n  } catch (error: unknown) {\n    return createAdapterError({ error: error as Error });\n  }\n}\n\nfunction createIntrospection(args: {\n  query: Query;\n  tables: QueryResult<typeof getTablesQuery>;\n  timezone: string;\n}): AdapterIntrospectResult {\n  const { query, tables, timezone } = args;\n\n  return tables.reduce(\n    (result, table) => {\n      const { schemas } = result;\n      const { columns, name: tableName, schema } = table;\n\n      const columnsRecord = columns.reduce(\n        (columns, column) => {\n          const {\n            autoinc,\n            computed,\n            datatype,\n            datatype_schema,\n            default: defaultValue,\n            name: columnName,\n            options,\n            nullable,\n          } = column;\n\n          const isArray = datatype.startsWith(\"_\");\n          const strippedDataType = isArray ? datatype.slice(1) : datatype;\n\n          return {\n            ...columns,\n            [columnName]: {\n              datatype: {\n                ...(POSTGRESQL_DATA_TYPES_TO_METADATA[strippedDataType] || {\n                  group: options.length > 0 ? \"enum\" : \"raw\",\n                }),\n                isArray,\n                isNative: datatype_schema === \"pg_catalog\",\n                name: isArray ? `${strippedDataType}[]` : strippedDataType,\n                options,\n                schema: datatype_schema,\n              },\n              defaultValue,\n              fkColumn: column.fk_column,\n              fkSchema: column.fk_schema,\n              fkTable: column.fk_table,\n              isAutoincrement: autoinc,\n              isComputed: computed,\n              isRequired:\n                !nullable && !autoinc && !computed && defaultValue == null,\n              name: columnName,\n              nullable,\n              pkPosition: column.pk,\n              schema,\n              table: tableName,\n            } as const satisfies Column,\n          };\n        },\n        {} as Table[\"columns\"],\n      );\n\n      if (schemas[schema] === undefined) {\n        schemas[schema] = { name: schema, tables: {} };\n      }\n\n      schemas[schema].tables[tableName] = {\n        columns: columnsRecord,\n        name: tableName,\n        schema,\n      };\n\n      return result;\n    },\n    {\n      filterOperators,\n      query,\n      schemas: { public: { name: \"public\", tables: {} } },\n      timezone,\n    } satisfies AdapterIntrospectResult as AdapterIntrospectResult,\n  );\n}\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n  \"ilike\",\n  \"not ilike\",\n] satisfies FilterOperator[];\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const tables = mockTablesQuery();\n  const [{ timezone }] = mockTimezoneQuery();\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n\n  return createIntrospection({ tables, timezone, query }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      [K in (typeof tables)[number][\"schema\"]]: {\n        name: K;\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: typeof timezone;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n"],
  "mappings": "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S,EACfJ,EACG,GAEC,iBAAkB,CAAC,gBAAiB,YAAY,CAAC,EAClD,GAAG,IAAI,CACZ,CAAC,CACL,EAAE,GAAG,SAAS,CAChB,CAAC,CACL,CACF,CAKO,SAASK,IAAkB,CAChC,MAAO,CACL,CACE,OAAQ,MACR,KAAM,UACN,QAAS,CACP,CACE,QAAS,GACT,SAAU,GACV,SAAU,OACV,gBAAiB,aACjB,QAAS,0CACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,KACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,CACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,OACV,gBAAiB,aACjB,QAAS,KACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,OACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,CACF,CACF,EACA,CACE,OAAQ,SACR,KAAM,QACN,QAAS,CACP,CACE,QAAS,GACT,SAAU,GACV,SAAU,OACV,gBAAiB,aACjB,QAAS,oCACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,KACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,CACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,YACV,gBAAiB,aACjB,QAAS,oBACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,aACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,YACV,gBAAiB,aACjB,QAAS,KACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,aACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,UACV,gBAAiB,aACjB,QAAS,KACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,OACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,EACA,CACE,QAAS,GACT,SAAU,GACV,SAAU,UACV,gBAAiB,aACjB,QAAS,KACT,UAAW,KACX,UAAW,KACX,SAAU,KACV,KAAM,OACN,SAAU,GACV,QAAS,CAAC,EACV,GAAI,IACN,EACA,CACE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",
  "names": ["POSTGRESQL_DATA_TYPES_TO_METADATA", "getPostgreSQLBuilder", "requirements", "getBuilder", "PostgresAdapter", "PostgresQueryCompiler", "buildFullTableSearchPlan", "args", "basePlan", "normalizedSearchTerm", "existingTextColumns", "predicate", "remainingTextSlots", "pattern", "escapeLikePattern", "supplementalPredicates", "column", "value", "getInsertQuery", "details", "requirements", "rows", "columns", "tableName", "schema", "builder", "getPostgreSQLBuilder", "compile", "applyTransformations", "getCurrentTimestampMillis", "getSelectQuery", "filter", "fullTableSearchTerm", "pageIndex", "pageSize", "sortOrder", "appliedFilterExpression", "getSelectFilterExpression", "fullTableSearchPlan", "buildFullTableSearchPlan", "combinedWhereExpression", "eb", "getFullTableSearchExpression", "AGG_NAME", "COUNT_REF", "SEARCH_GUARDRAILS_NAME", "isFullTableSearchRequest", "qb", "sql", "jb", "currentQuery", "item", "column", "countQuery", "mockSelectQuery", "getUpdateQuery", "changes", "row", "applyInferredRowFilters", "getDeleteQuery", "expressionBuilder", "jsonArrayFrom", "expr", "sql", "REGULAR_TABLE_KIND", "VIEW_TABLE_KIND", "TABLE_KINDS", "getTablesQuery", "requirements", "compile", "getPostgreSQLBuilder", "excludeSystemTables", "eb", "jsonArrayFrom", "jb", "on_eb", "sql", "mockTablesQuery", "getTimezoneQuery", "builder", "mockTimezoneQuery", "qb", "createPostgresAdapter", "requirements", "executor", "otherRequirements", "fullTableSearchState", "createFullTableSearchExecutionState", "canUseExecutorLintTransport", "introspectDatabase", "options", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "createAdapterError", "timezone", "createIntrospection", "error", "details", "query", "getSelectQuery", "results", "executeQueryWithFullTableSearchGuardrails", "executeRawQuery", "_details", "introspection", "createSqlEditorSchemaFromIntrospection", "result", "shouldFallbackToExplainLint", "shouldDisableLintTransport", "lintWithExplainFallback", "getInsertQuery", "rows", "getUpdateQuery", "row", "getDeleteQuery", "message", "validation", "validateSqlForLint", "diagnostics", "statement", "explainQuery", "asQuery", "createLintDiagnosticsFromPostgresError", "args", "table", "schemas", "columns", "tableName", "schema", "columnsRecord", "column", "autoinc", "computed", "datatype", "datatype_schema", "defaultValue", "columnName", "nullable", "isArray", "strippedDataType", "POSTGRESQL_DATA_TYPES_TO_METADATA", "filterOperators", "mockIntrospect", "mockTablesQuery", "mockTimezoneQuery"]
}
