@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 p,b as q,c as r,d as s,e as t,f as u,g as v,h as w,i as x,j as y,k as z,l as A}from"../../chunk-GFC3LDB7.js";import{a as B,b as C}from"../../chunk-6EVUFNZS.js";import"../../chunk-UQDXNCLC.js";import{a as l,b as m,c as n,d as o}from"../../chunk-DTFJIWXL.js";import{a,b,c,d,e,f,g,h,i,j,l as k}from"../../chunk-PI3N7ZW6.js";import"../../chunk-N6ZIYSZ5.js";import"../../chunk-TB3YFW43.js";import"../../chunk-6QJ7HVIC.js";export{e as FULL_TABLE_SEARCH_MAX_TEXT_COLUMNS,d as FULL_TABLE_SEARCH_MIN_QUERY_LENGTH,c as FULL_TABLE_SEARCH_MYSQL_LOCK_WAIT_TIMEOUT_SECONDS,b as FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS,f as FULL_TABLE_SEARCH_TIMEOUT_MESSAGE,a as FULL_TABLE_SEARCH_TIMEOUT_MS,g as FullTableSearchTimeoutError,m as SQL_LINT_ALLOWED_STATEMENT_KEYWORDS,l as SQL_LINT_MAX_LENGTH,p as buildFullTableSearchPlan,h as createFullTableSearchExecutionState,o as createLintDiagnosticsFromPostgresError,z as createPostgresAdapter,j as executeQueryWithFullTableSearchGuardrails,C as getCancelQuery,u as getDeleteQuery,k as getFullTableSearchExpression,q as getInsertQuery,B as getPIDQuery,r as getSelectQuery,v as getTablesQuery,x as getTimezoneQuery,t as getUpdateQuery,i as isFullTableSearchRequest,A as mockIntrospect,s as mockSelectQuery,w as mockTablesQuery,y as mockTimezoneQuery,n as validateSqlForLint};
9
+ import{a as p,b as q,c as r,d as s,e as t,f as u,g as v,h as w,i as x,j as y,k as z,l as A}from"../../chunk-5TS6UALC.js";import"../../chunk-UQDXNCLC.js";import{a,b,c,d,e,f,g,h,i,j,l as k}from"../../chunk-PI3N7ZW6.js";import"../../chunk-N6ZIYSZ5.js";import{a as B,b as C}from"../../chunk-6EVUFNZS.js";import{a as l,b as m,c as n,d as o}from"../../chunk-DTFJIWXL.js";import"../../chunk-TB3YFW43.js";import"../../chunk-6QJ7HVIC.js";export{e as FULL_TABLE_SEARCH_MAX_TEXT_COLUMNS,d as FULL_TABLE_SEARCH_MIN_QUERY_LENGTH,c as FULL_TABLE_SEARCH_MYSQL_LOCK_WAIT_TIMEOUT_SECONDS,b as FULL_TABLE_SEARCH_POSTGRES_LOCK_TIMEOUT_MS,f as FULL_TABLE_SEARCH_TIMEOUT_MESSAGE,a as FULL_TABLE_SEARCH_TIMEOUT_MS,g as FullTableSearchTimeoutError,m as SQL_LINT_ALLOWED_STATEMENT_KEYWORDS,l as SQL_LINT_MAX_LENGTH,p as buildFullTableSearchPlan,h as createFullTableSearchExecutionState,o as createLintDiagnosticsFromPostgresError,z as createPostgresAdapter,j as executeQueryWithFullTableSearchGuardrails,C as getCancelQuery,u as getDeleteQuery,k as getFullTableSearchExpression,q as getInsertQuery,B as getPIDQuery,r as getSelectQuery,v as getTablesQuery,x as getTimezoneQuery,t as getUpdateQuery,i as isFullTableSearchRequest,A as mockIntrospect,s as mockSelectQuery,w as mockTablesQuery,y as mockTimezoneQuery,n as validateSqlForLint};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
@@ -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 b,b as p}from"../../chunk-6EVUFNZS.js";import{c as q,d}from"../../chunk-DTFJIWXL.js";import"../../chunk-TB3YFW43.js";import{a as y,b as c}from"../../chunk-KHDR47QR.js";import"../../chunk-6QJ7HVIC.js";var h="1000ms",E="100ms",S="1000ms";function N(i){return{execute:async(t,a)=>{let{abortSignal:o}=a||{};if(!o)try{return[null,await i.unsafe(t.sql,t.parameters)]}catch(s){return[s]}if(o.aborted)return c();let l,n;try{let s,u=new Promise(P=>s=P);o.addEventListener("abort",l=()=>s());let f=i.reserve(),m=await Promise.race([f,u]);if(!m)return f.catch(()=>{}),c();if(n=m,o.aborted)return n.release(),c();let e=L(n),r=await Promise.race([e,u]);if(r===void 0)return e.catch(()=>{}).finally(()=>n?.release()),c();if(o.aborted)return n.release(),c();let v=n.unsafe(t.sql,t.parameters),w=await Promise.race([v,u]);return w?(n.release(),[null,w]):(Promise.allSettled([_(i,r),v]).finally(()=>n?.release()),c())}catch(s){return n?.release(),[s]}finally{l&&o?.removeEventListener("abort",l)}},async lintSql(t,a){let o=q(t.sql);if(!o.ok)return[null,{diagnostics:[o.diagnostic],schemaVersion:t.schemaVersion}];let l=async e=>{await i.begin(async r=>{await r.unsafe(`set local statement_timeout = '${h}'`),await r.unsafe(`set local lock_timeout = '${E}'`),await r.unsafe(`set local idle_in_transaction_session_timeout = '${S}'`),await r.unsafe(`EXPLAIN (FORMAT JSON) ${e}`)})},{abortSignal:n}=a||{},s=[];if(!n){for(let e of o.statements)try{await l(e.statement)}catch(r){s.push(...d({error:r,positionOffset:e.from,sql:e.statement}))}return[null,{diagnostics:s,schemaVersion:t.schemaVersion}]}if(n.aborted)return c();let u=()=>{},f=new Promise((e,r)=>{u=r}),m=()=>u(new y);n.addEventListener("abort",m);try{for(let e of o.statements)try{await Promise.race([l(e.statement),f])}catch(r){if(r instanceof y)return[r];s.push(...d({error:r,positionOffset:e.from,sql:e.statement}))}return[null,{diagnostics:s,schemaVersion:t.schemaVersion}]}catch(e){return e instanceof y?[e]:[null,{diagnostics:d({error:e,sql:t.sql}),schemaVersion:t.schemaVersion}]}finally{n.removeEventListener("abort",m)}}}}async function _(i,t){let a=p(t);try{await i.unsafe(a.sql,a.parameters)}catch(o){console.error("Failed to cancel query:",o)}}async function L(i){let t=b();try{let[a]=await i.unsafe(t.sql,t.parameters);return a?.pid}catch(a){console.error("Failed to get connection PID:",a);return}}export{N as createPostgresJSExecutor};
9
+ import{a as y,b as c}from"../../chunk-KHDR47QR.js";import{a as b,b as p}from"../../chunk-6EVUFNZS.js";import{c as q,d}from"../../chunk-DTFJIWXL.js";import"../../chunk-TB3YFW43.js";import"../../chunk-6QJ7HVIC.js";var h="1000ms",E="100ms",S="1000ms";function N(i){return{execute:async(t,a)=>{let{abortSignal:o}=a||{};if(!o)try{return[null,await i.unsafe(t.sql,t.parameters)]}catch(s){return[s]}if(o.aborted)return c();let l,n;try{let s,u=new Promise(P=>s=P);o.addEventListener("abort",l=()=>s());let f=i.reserve(),m=await Promise.race([f,u]);if(!m)return f.catch(()=>{}),c();if(n=m,o.aborted)return n.release(),c();let e=L(n),r=await Promise.race([e,u]);if(r===void 0)return e.catch(()=>{}).finally(()=>n?.release()),c();if(o.aborted)return n.release(),c();let v=n.unsafe(t.sql,t.parameters),w=await Promise.race([v,u]);return w?(n.release(),[null,w]):(Promise.allSettled([_(i,r),v]).finally(()=>n?.release()),c())}catch(s){return n?.release(),[s]}finally{l&&o?.removeEventListener("abort",l)}},async lintSql(t,a){let o=q(t.sql);if(!o.ok)return[null,{diagnostics:[o.diagnostic],schemaVersion:t.schemaVersion}];let l=async e=>{await i.begin(async r=>{await r.unsafe(`set local statement_timeout = '${h}'`),await r.unsafe(`set local lock_timeout = '${E}'`),await r.unsafe(`set local idle_in_transaction_session_timeout = '${S}'`),await r.unsafe(`EXPLAIN (FORMAT JSON) ${e}`)})},{abortSignal:n}=a||{},s=[];if(!n){for(let e of o.statements)try{await l(e.statement)}catch(r){s.push(...d({error:r,positionOffset:e.from,sql:e.statement}))}return[null,{diagnostics:s,schemaVersion:t.schemaVersion}]}if(n.aborted)return c();let u=()=>{},f=new Promise((e,r)=>{u=r}),m=()=>u(new y);n.addEventListener("abort",m);try{for(let e of o.statements)try{await Promise.race([l(e.statement),f])}catch(r){if(r instanceof y)return[r];s.push(...d({error:r,positionOffset:e.from,sql:e.statement}))}return[null,{diagnostics:s,schemaVersion:t.schemaVersion}]}catch(e){return e instanceof y?[e]:[null,{diagnostics:d({error:e,sql:t.sql}),schemaVersion:t.schemaVersion}]}finally{n.removeEventListener("abort",m)}}}}async function _(i,t){let a=p(t);try{await i.unsafe(a.sql,a.parameters)}catch(o){console.error("Failed to cancel query:",o)}}async function L(i){let t=b();try{let[a]=await i.unsafe(t.sql,t.parameters);return a?.pid}catch(a){console.error("Failed to get connection PID:",a);return}}export{N as createPostgresJSExecutor};
10
10
  //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/postgresjs/index.ts"],
  "sourcesContent": ["import type { ReservedSql, Sql } from \"postgres\";\n\nimport { AbortError, type Executor, getAbortResult } from \"../executor\";\nimport {\n  createLintDiagnosticsFromPostgresError,\n  validateSqlForLint,\n} from \"../postgres-core/sql-lint\";\nimport { getCancelQuery, getPIDQuery } from \"../postgres-core/utility\";\nimport type { QueryResult } from \"../query\";\n\nconst SQL_LINT_STATEMENT_TIMEOUT = \"1000ms\";\nconst SQL_LINT_LOCK_TIMEOUT = \"100ms\";\nconst SQL_LINT_IDLE_IN_TRANSACTION_TIMEOUT = \"1000ms\";\n\nexport function createPostgresJSExecutor(postgresjs: Sql): Executor {\n  return {\n    execute: async (query, options) => {\n      const { abortSignal } = options || {};\n\n      if (!abortSignal) {\n        try {\n          const result = await postgresjs.unsafe(\n            query.sql,\n            query.parameters as never,\n          );\n\n          return [null, result as never];\n        } catch (error: unknown) {\n          return [error as Error];\n        }\n      }\n\n      if (abortSignal.aborted) {\n        return getAbortResult();\n      }\n\n      let abortListener: (() => void) | undefined;\n      let connection: ReservedSql | undefined;\n\n      try {\n        let aborted: () => void;\n        const abortionPromise = new Promise<void>(\n          (resolve) => (aborted = resolve),\n        );\n\n        abortSignal.addEventListener(\n          \"abort\",\n          (abortListener = () => aborted()),\n        );\n\n        const connectionPromise = postgresjs.reserve();\n\n        const connectionResult = await Promise.race([\n          connectionPromise,\n          abortionPromise,\n        ]);\n\n        if (!connectionResult) {\n          void connectionPromise.catch(() => {});\n\n          return getAbortResult();\n        }\n\n        connection = connectionResult;\n\n        if (abortSignal.aborted) {\n          connection.release();\n\n          return getAbortResult();\n        }\n\n        const pidPromise = getConnectionPID(connection);\n\n        const pidResult = await Promise.race([pidPromise, abortionPromise]);\n\n        if (pidResult === undefined) {\n          void pidPromise.catch(() => {}).finally(() => connection?.release());\n\n          return getAbortResult();\n        }\n\n        if (abortSignal.aborted) {\n          connection.release();\n\n          return getAbortResult();\n        }\n\n        const queryPromise = connection.unsafe(\n          query.sql,\n          query.parameters as never,\n        );\n\n        const queryResult = await Promise.race([queryPromise, abortionPromise]);\n\n        if (!queryResult) {\n          void Promise.allSettled([\n            cancelQuery(postgresjs, pidResult!),\n            queryPromise,\n          ]).finally(() => connection?.release());\n\n          return getAbortResult();\n        }\n\n        connection.release();\n\n        return [null, queryResult as never];\n      } catch (error: unknown) {\n        connection?.release();\n\n        return [error as Error];\n      } finally {\n        if (abortListener) {\n          abortSignal?.removeEventListener(\"abort\", abortListener);\n        }\n      }\n    },\n\n    async lintSql(details, options) {\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 executeLint = async (statementSql: string) => {\n        await postgresjs.begin(async (tx) => {\n          await tx.unsafe(\n            `set local statement_timeout = '${SQL_LINT_STATEMENT_TIMEOUT}'`,\n          );\n          await tx.unsafe(\n            `set local lock_timeout = '${SQL_LINT_LOCK_TIMEOUT}'`,\n          );\n          await tx.unsafe(\n            `set local idle_in_transaction_session_timeout = '${SQL_LINT_IDLE_IN_TRANSACTION_TIMEOUT}'`,\n          );\n          await tx.unsafe(`EXPLAIN (FORMAT JSON) ${statementSql}`);\n        });\n      };\n\n      const { abortSignal } = options || {};\n      const diagnostics: NonNullable<\n        Awaited<ReturnType<NonNullable<Executor[\"lintSql\"]>>>[1]\n      >[\"diagnostics\"] = [];\n\n      if (!abortSignal) {\n        for (const statement of validation.statements) {\n          try {\n            await executeLint(statement.statement);\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 [null, { diagnostics, schemaVersion: details.schemaVersion }];\n      }\n\n      if (abortSignal.aborted) {\n        return getAbortResult();\n      }\n\n      let rejectAbort: (reason?: unknown) => void = () => undefined;\n      const abortionPromise = new Promise<never>((_, reject) => {\n        rejectAbort = reject;\n      });\n      const onAbort = () => rejectAbort(new AbortError());\n      abortSignal.addEventListener(\"abort\", onAbort);\n\n      try {\n        for (const statement of validation.statements) {\n          try {\n            await Promise.race([\n              executeLint(statement.statement),\n              abortionPromise,\n            ]);\n          } catch (error: unknown) {\n            if (error instanceof AbortError) {\n              return [error];\n            }\n\n            diagnostics.push(\n              ...createLintDiagnosticsFromPostgresError({\n                error,\n                positionOffset: statement.from,\n                sql: statement.statement,\n              }),\n            );\n          }\n        }\n\n        return [null, { diagnostics, schemaVersion: details.schemaVersion }];\n      } catch (error: unknown) {\n        if (error instanceof AbortError) {\n          return [error];\n        }\n\n        return [\n          null,\n          {\n            diagnostics: createLintDiagnosticsFromPostgresError({\n              error,\n              sql: details.sql,\n            }),\n            schemaVersion: details.schemaVersion,\n          },\n        ];\n      } finally {\n        abortSignal.removeEventListener(\"abort\", onAbort);\n      }\n    },\n  };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nasync function cancelQuery(postgresjs: Sql, pid: {}): Promise<void> {\n  const query = getCancelQuery(pid);\n\n  try {\n    await postgresjs.unsafe(query.sql, query.parameters as never);\n  } catch (error) {\n    console.error(\"Failed to cancel query:\", error);\n  }\n}\n\nasync function getConnectionPID(connection: ReservedSql): Promise<unknown> {\n  const query = getPIDQuery();\n\n  try {\n    const [result] = await connection.unsafe<QueryResult<typeof query>>(\n      query.sql,\n      query.parameters as never,\n    );\n\n    return result?.pid;\n  } catch (error) {\n    console.error(\"Failed to get connection PID:\", error);\n\n    return undefined;\n  }\n}\n"],
  "mappings": "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",
  "names": ["SQL_LINT_STATEMENT_TIMEOUT", "SQL_LINT_LOCK_TIMEOUT", "SQL_LINT_IDLE_IN_TRANSACTION_TIMEOUT", "createPostgresJSExecutor", "postgresjs", "query", "options", "abortSignal", "error", "getAbortResult", "abortListener", "connection", "aborted", "abortionPromise", "resolve", "connectionPromise", "connectionResult", "pidPromise", "getConnectionPID", "pidResult", "queryPromise", "queryResult", "cancelQuery", "details", "validation", "validateSqlForLint", "executeLint", "statementSql", "tx", "diagnostics", "statement", "createLintDiagnosticsFromPostgresError", "rejectAbort", "_", "reject", "onAbort", "AbortError", "pid", "getCancelQuery", "getPIDQuery", "result"]
}

@@ -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 v}from"../../chunk-FJ7M2BJG.js";import{a as c}from"../../chunk-UQDXNCLC.js";import{c as G}from"../../chunk-DTFJIWXL.js";import{h as D,j as B,k as F,l as N}from"../../chunk-PI3N7ZW6.js";import{a as U}from"../../chunk-N6ZIYSZ5.js";import{A as q,C as S,D as M,p as k,q as y,r as C,s as P,x as j,y as w,z as g}from"../../chunk-TB3YFW43.js";import"../../chunk-6QJ7HVIC.js";var $={BLOB:{group:"raw"},INTEGER:{group:"numeric"},NULL:{group:"raw"},NUMERIC:{group:"numeric"},REAL:{group:"numeric"},TEXT:{group:"string"}};function K(t){if(!t)return"BLOB";let e=t.toUpperCase();return e.includes("INT")?"INTEGER":e.includes("TEXT")||e.includes("CHAR")||e.includes("CLOB")?"TEXT":e.includes("BLOB")?"BLOB":e.includes("REAL")||e.includes("FLOA")||e.includes("DOUB")?"REAL":"NUMERIC"}function b(t){return j({...t,Adapter:P,QueryCompiler:C})}function X(t,e){let{filter:o={after:"and",filters:[],kind:"FilterGroup"},fullTableSearchTerm:s,pageIndex:l,pageSize:i,sortOrder:n,table:{columns:a,name:r}}=t,u=b(e),m=M(o.filters,a),d=F({searchTerm:s,table:t.table}),T=d.predicates.length>0?p=>p.and([m(p),N(d,{dialect:"sqlite"})(p)]):m,f="__ps_agg__",A="__ps_count__",R=u.selectFrom(r).where(T).select(p=>p.cast(p.fn.coalesce(p.fn.countAll(),y.lit(0)),"text").as(A));return g(u.with(f,()=>R).selectFrom(r).innerJoin(f,p=>p.onTrue()).where(T).select(`${f}.${A}`).select(Object.keys(a)).$call(p=>n.reduce((_,E)=>_.orderBy(E.column,E.direction),p)).limit(i).offset(y.lit(BigInt(l)*BigInt(i))))}function Ee(){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 J(t,e){let{rows:o,table:{columns:s,name:l}}=t,i=b(e);return g(i.deleteFrom(l).$call(q(o,s)).returning(Object.keys(s)).returning(I().as("__ps_deleted_at__")))}function W(t,e){let{table:{columns:o,name:s},rows:l}=t,i=b(e);return g(i.insertInto(s).values(S({columns:o,context:"insert",supportsDefaultKeyword:!1,values:l})).returning(Object.keys(o)).returning(I().as("__ps_inserted_at__")))}function Y(t,e){let{changes:o,row:s,table:{columns:l,name:i}}=t,n=b(e);return g(n.updateTable(i).set(S({columns:l,context:"update",supportsDefaultKeyword:!1,values:o})).$call(q([s],l)).returning(Object.keys(l)).returning(I().as("__ps_updated_at__")))}function I(){let t=k();return t.cast(t.cast(y`(julianday('now') - 2440587.5) * 86400000.0`,"integer"),"text")}function V(t){return y`(select coalesce(json_group_array(json_object(${y.join(ae(t.toOperationNode(),"agg"))})), '[]') from ${t} as agg)`}function ae(t,e){try{return v(t,e)}catch{throw new Error("SQLite jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.")}}function z(t){return g(b(t).selectFrom(k().fn("pragma_table_list",[]).as("tl")).leftJoin("sqlite_schema as ss",e=>e.onRef("ss.type","=","tl.type").onRef("ss.name","=","tl.name")).where("tl.type","in",["table","view"]).where("tl.schema","=","main").where("tl.name","not like","sqlite_%").select(["tl.name","ss.sql"]).$narrowType().select(e=>[V(e.selectFrom(e.fn("pragma_table_xinfo",["tl.name"]).as("txi")).leftJoin(e.fn("pragma_foreign_key_list",["tl.name"]).as("fkl"),"fkl.from","txi.name").where("txi.hidden","!=",1).select(["txi.dflt_value as default","txi.name","txi.pk","txi.type as datatype","fkl.table as fk_table","fkl.to as fk_column"]).select(o=>[o("txi.hidden","in",[2,3]).as("computed"),o("txi.notnull","=",0).as("nullable")])).as("columns")]),{transformations:{columns:"json-parse"}})}function H(){return[{name:"animals",sql:"CREATE TABLE animals (id INTEGER PRIMARY KEY, name TEXT);",columns:[{name:"id",datatype:"INTEGER",default:null,pk:1,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name",datatype:"TEXT",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]},{name:"users",sql:"CREATE TABLE users (id UUID PRIMARY KEY, created_at TIMESTAMP, deleted_at TIMESTAMP, role varchar, name varchar, name_role text);",columns:[{name:"id",datatype:"INTEGER",default:null,pk:1,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"created_at",datatype:"TIMESTAMP",default:"1970-01-01 00:00:00.000",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"deleted_at",datatype:"TIMESTAMP",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"role",datatype:"varchar",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name",datatype:"varchar",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name_role",datatype:"text",default:null,pk:0,computed:1,nullable:0,fk_table:null,fk_column:null}]},{name:"composite_pk",sql:"CREATE TABLE composite_pk (id UUID, name TEXT, created_at timestamp, PRIMARY KEY (id, name));",columns:[{name:"id",datatype:"text",default:null,pk:1,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name",datatype:"TEXT",default:null,pk:2,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"created_at",datatype:"timestamp",default:"1970-01-01 00:00:00.000",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]}]}function Z(t){let{error:e,sql:o}=t,s=Math.max(0,t.positionOffset??0),l=se(o.length);if(!(e instanceof Error))return[{from:l.from+s,message:"SQL lint failed.",severity:"error",source:"sqlite",to:l.to+s}];let i=oe(e),n=ie(o,e.message)??l;return[{code:i,from:n.from+s,message:le(e.message),severity:"error",source:"sqlite",to:n.to+s}]}async function ee(t,e,o){let s=G(e.sql);if(!s.ok)return[null,{diagnostics:[s.diagnostic],schemaVersion:e.schemaVersion}];let l=[];for(let i of s.statements)try{let n=w(`EXPLAIN ${i.statement}`),[a]=await t.execute(n,o);if(!a)continue;l.push(...Z({error:a,positionOffset:i.from,sql:i.statement}))}catch(n){l.push(...Z({error:n,positionOffset:i.from,sql:i.statement}))}return[null,{diagnostics:l,schemaVersion:e.schemaVersion}]}function oe(t){let e=t;return typeof e.code=="string"?e.code:void 0}function le(t){return t.toLowerCase().includes("interrupted")?"Lint query timed out. Simplify the statement and try again.":t}function se(t){return t<=0?{from:0,to:0}:{from:0,to:1}}function ie(t,e){let o=/near\s+["'`]([^"'`]+)["'`]/i.exec(e);if(o?.[1])return L(t,o[1]);let s=/no such table:\s*([^\s]+)/i.exec(e);if(s?.[1])return L(t,s[1]);let l=/no such column:\s*([^\s]+)/i.exec(e);return l?.[1]?L(t,l[1]):null}function L(t,e){let o=e.trim().replace(/^['"`]|['"`]$/g,"");if(o.length===0)return null;let s=t.toLowerCase(),l=o.toLowerCase(),i=s.indexOf(l);if(i>=0)return{from:i,to:Math.min(t.length,i+o.length)};let n=l.split(".").at(-1);if(!n)return null;let a=s.indexOf(n);return a<0?null:{from:a,to:Math.min(t.length,a+n.length)}}var h="main",ue=["=","!=",">",">=","<","<=","is","is not","like","not like"];function Ue(t){let{executor:e,...o}=t,s=D(),l=typeof e.lintSql=="function";async function i(n){try{let a=z(t),[r,u]=await e.execute(a,n);return r?c({error:r,query:a}):[null,re({query:a,tables:u})]}catch(a){return c({error:a})}}return{defaultSchema:h,capabilities:{fullTableSearch:!0,sqlDialect:"sqlite",sqlEditorAutocomplete:!0,sqlEditorLint:!0},async delete(n,a){try{let r=J(n,o),[u]=await e.execute(r,a);return u?c({error:u,query:r}):[null,{...n,query:r}]}catch(r){return c({error:r})}},async insert(n,a){try{let r=W(n,o),[u,m]=await e.execute(r,a);return u?c({error:u,query:r}):[null,{rows:m,query:r}]}catch(r){return c({error:r})}},async introspect(n){return await i(n)},async sqlSchema(n,a){let[r,u]=await i(a);return r?[r]:[null,U({defaultSchema:h,dialect:"sqlite",introspection:u})]},async sqlLint(n,a){if(l&&typeof e.lintSql=="function")try{let[r,u]=await e.lintSql(n,a);if(!r)return[null,u];if(!te(r))return c({error:r});l=!1}catch(r){if(!te(r))return c({error:r});l=!1}return await ee(e,n,a)},async query(n,a){try{let r=X(n,o),[u,m]=await B({executor:e,options:a,query:r,searchTerm:n.fullTableSearchTerm,state:s});return u?c({error:u,query:r}):[null,{filteredRowCount:m[0]?.__ps_count__||"0",rows:m,query:r}]}catch(r){return c({error:r})}},async raw(n,a){try{let r=w(n.sql),[u,m]=await e.execute(r,a);return u?c({error:u,query:r}):[null,{query:r,rowCount:m.length,rows:m}]}catch(r){return c({error:r})}},async update(n,a){try{let r=Y(n,o),[u,m]=await e.execute(r,a);if(u)return c({error:u,query:r});let[d]=m;return d?[null,{row:d,query:r}]:c({error:new Error("Update failed"),query:r})}catch(r){return c({error:r})}}}}function te(t){if(!(t instanceof Error))return!1;let e=t.message.toLowerCase();return e.includes("invalid procedure")||e.includes("not supported")||e.includes("method not allowed")}var ce=/WITHOUT\s+ROWID/i;function re(t){let{tables:e,query:o}=t;return{filterOperators:ue,query:o,schemas:e.reduce((s,l)=>{let{columns:i,name:n,sql:a}=l,r=0,u=i.reduce((m,d,T)=>{let{datatype:f,default:A,fk_column:R,name:p,pk:_}=d;r=Math.max(r,_);let E=K(f),x=f.toUpperCase()==="INTEGER"&&_===1&&r===1&&!i.slice(T+1).some(function(ne){return ne.pk>1})&&!ce.test(a),Q=!!d.computed,O=!!d.nullable&&!x;return m[p]={datatype:{...$[E],affinity:E,isArray:!1,isNative:!0,name:f,options:[],schema:h},defaultValue:A,fkColumn:R,fkSchema:R?h:null,fkTable:d.fk_table,isAutoincrement:x,isComputed:Q,isRequired:!O&&!x&&!Q&&A==null,name:p,nullable:O,pkPosition:_>0?_:null,schema:h,table:n},m},{});return s.main.tables[n]={columns:u,name:n,schema:"main"},s},{main:{tables:{},name:"main"}}),timezone:"UTC"}}function ve(){let t={parameters:[],sql:"<mocked>"},e=H();return re({query:t,tables:e})}export{Z as createLintDiagnosticsFromSQLiteError,Ue as createSQLiteAdapter,J as getDeleteQuery,W as getInsertQuery,X as getSelectQuery,z as getTablesQuery,Y as getUpdateQuery,ee as lintSQLiteWithExplainFallback,ve as mockIntrospect,Ee as mockSelectQuery,H as mockTablesQuery};
9
+ import{a as v}from"../../chunk-FJ7M2BJG.js";import{a as c}from"../../chunk-UQDXNCLC.js";import{h as D,j as B,k as F,l as N}from"../../chunk-PI3N7ZW6.js";import{a as U}from"../../chunk-N6ZIYSZ5.js";import{c as G}from"../../chunk-DTFJIWXL.js";import{A as q,C as S,D as M,p as k,q as y,r as C,s as P,x as j,y as w,z as g}from"../../chunk-TB3YFW43.js";import"../../chunk-6QJ7HVIC.js";var $={BLOB:{group:"raw"},INTEGER:{group:"numeric"},NULL:{group:"raw"},NUMERIC:{group:"numeric"},REAL:{group:"numeric"},TEXT:{group:"string"}};function K(t){if(!t)return"BLOB";let e=t.toUpperCase();return e.includes("INT")?"INTEGER":e.includes("TEXT")||e.includes("CHAR")||e.includes("CLOB")?"TEXT":e.includes("BLOB")?"BLOB":e.includes("REAL")||e.includes("FLOA")||e.includes("DOUB")?"REAL":"NUMERIC"}function b(t){return j({...t,Adapter:P,QueryCompiler:C})}function X(t,e){let{filter:o={after:"and",filters:[],kind:"FilterGroup"},fullTableSearchTerm:s,pageIndex:l,pageSize:i,sortOrder:n,table:{columns:a,name:r}}=t,u=b(e),m=M(o.filters,a),d=F({searchTerm:s,table:t.table}),T=d.predicates.length>0?p=>p.and([m(p),N(d,{dialect:"sqlite"})(p)]):m,f="__ps_agg__",A="__ps_count__",R=u.selectFrom(r).where(T).select(p=>p.cast(p.fn.coalesce(p.fn.countAll(),y.lit(0)),"text").as(A));return g(u.with(f,()=>R).selectFrom(r).innerJoin(f,p=>p.onTrue()).where(T).select(`${f}.${A}`).select(Object.keys(a)).$call(p=>n.reduce((_,E)=>_.orderBy(E.column,E.direction),p)).limit(i).offset(y.lit(BigInt(l)*BigInt(i))))}function Ee(){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 J(t,e){let{rows:o,table:{columns:s,name:l}}=t,i=b(e);return g(i.deleteFrom(l).$call(q(o,s)).returning(Object.keys(s)).returning(I().as("__ps_deleted_at__")))}function W(t,e){let{table:{columns:o,name:s},rows:l}=t,i=b(e);return g(i.insertInto(s).values(S({columns:o,context:"insert",supportsDefaultKeyword:!1,values:l})).returning(Object.keys(o)).returning(I().as("__ps_inserted_at__")))}function Y(t,e){let{changes:o,row:s,table:{columns:l,name:i}}=t,n=b(e);return g(n.updateTable(i).set(S({columns:l,context:"update",supportsDefaultKeyword:!1,values:o})).$call(q([s],l)).returning(Object.keys(l)).returning(I().as("__ps_updated_at__")))}function I(){let t=k();return t.cast(t.cast(y`(julianday('now') - 2440587.5) * 86400000.0`,"integer"),"text")}function V(t){return y`(select coalesce(json_group_array(json_object(${y.join(ae(t.toOperationNode(),"agg"))})), '[]') from ${t} as agg)`}function ae(t,e){try{return v(t,e)}catch{throw new Error("SQLite jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.")}}function z(t){return g(b(t).selectFrom(k().fn("pragma_table_list",[]).as("tl")).leftJoin("sqlite_schema as ss",e=>e.onRef("ss.type","=","tl.type").onRef("ss.name","=","tl.name")).where("tl.type","in",["table","view"]).where("tl.schema","=","main").where("tl.name","not like","sqlite_%").select(["tl.name","ss.sql"]).$narrowType().select(e=>[V(e.selectFrom(e.fn("pragma_table_xinfo",["tl.name"]).as("txi")).leftJoin(e.fn("pragma_foreign_key_list",["tl.name"]).as("fkl"),"fkl.from","txi.name").where("txi.hidden","!=",1).select(["txi.dflt_value as default","txi.name","txi.pk","txi.type as datatype","fkl.table as fk_table","fkl.to as fk_column"]).select(o=>[o("txi.hidden","in",[2,3]).as("computed"),o("txi.notnull","=",0).as("nullable")])).as("columns")]),{transformations:{columns:"json-parse"}})}function H(){return[{name:"animals",sql:"CREATE TABLE animals (id INTEGER PRIMARY KEY, name TEXT);",columns:[{name:"id",datatype:"INTEGER",default:null,pk:1,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name",datatype:"TEXT",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]},{name:"users",sql:"CREATE TABLE users (id UUID PRIMARY KEY, created_at TIMESTAMP, deleted_at TIMESTAMP, role varchar, name varchar, name_role text);",columns:[{name:"id",datatype:"INTEGER",default:null,pk:1,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"created_at",datatype:"TIMESTAMP",default:"1970-01-01 00:00:00.000",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"deleted_at",datatype:"TIMESTAMP",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"role",datatype:"varchar",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name",datatype:"varchar",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name_role",datatype:"text",default:null,pk:0,computed:1,nullable:0,fk_table:null,fk_column:null}]},{name:"composite_pk",sql:"CREATE TABLE composite_pk (id UUID, name TEXT, created_at timestamp, PRIMARY KEY (id, name));",columns:[{name:"id",datatype:"text",default:null,pk:1,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name",datatype:"TEXT",default:null,pk:2,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"created_at",datatype:"timestamp",default:"1970-01-01 00:00:00.000",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]}]}function Z(t){let{error:e,sql:o}=t,s=Math.max(0,t.positionOffset??0),l=se(o.length);if(!(e instanceof Error))return[{from:l.from+s,message:"SQL lint failed.",severity:"error",source:"sqlite",to:l.to+s}];let i=oe(e),n=ie(o,e.message)??l;return[{code:i,from:n.from+s,message:le(e.message),severity:"error",source:"sqlite",to:n.to+s}]}async function ee(t,e,o){let s=G(e.sql);if(!s.ok)return[null,{diagnostics:[s.diagnostic],schemaVersion:e.schemaVersion}];let l=[];for(let i of s.statements)try{let n=w(`EXPLAIN ${i.statement}`),[a]=await t.execute(n,o);if(!a)continue;l.push(...Z({error:a,positionOffset:i.from,sql:i.statement}))}catch(n){l.push(...Z({error:n,positionOffset:i.from,sql:i.statement}))}return[null,{diagnostics:l,schemaVersion:e.schemaVersion}]}function oe(t){let e=t;return typeof e.code=="string"?e.code:void 0}function le(t){return t.toLowerCase().includes("interrupted")?"Lint query timed out. Simplify the statement and try again.":t}function se(t){return t<=0?{from:0,to:0}:{from:0,to:1}}function ie(t,e){let o=/near\s+["'`]([^"'`]+)["'`]/i.exec(e);if(o?.[1])return L(t,o[1]);let s=/no such table:\s*([^\s]+)/i.exec(e);if(s?.[1])return L(t,s[1]);let l=/no such column:\s*([^\s]+)/i.exec(e);return l?.[1]?L(t,l[1]):null}function L(t,e){let o=e.trim().replace(/^['"`]|['"`]$/g,"");if(o.length===0)return null;let s=t.toLowerCase(),l=o.toLowerCase(),i=s.indexOf(l);if(i>=0)return{from:i,to:Math.min(t.length,i+o.length)};let n=l.split(".").at(-1);if(!n)return null;let a=s.indexOf(n);return a<0?null:{from:a,to:Math.min(t.length,a+n.length)}}var h="main",ue=["=","!=",">",">=","<","<=","is","is not","like","not like"];function Ue(t){let{executor:e,...o}=t,s=D(),l=typeof e.lintSql=="function";async function i(n){try{let a=z(t),[r,u]=await e.execute(a,n);return r?c({error:r,query:a}):[null,re({query:a,tables:u})]}catch(a){return c({error:a})}}return{defaultSchema:h,capabilities:{fullTableSearch:!0,sqlDialect:"sqlite",sqlEditorAutocomplete:!0,sqlEditorLint:!0},async delete(n,a){try{let r=J(n,o),[u]=await e.execute(r,a);return u?c({error:u,query:r}):[null,{...n,query:r}]}catch(r){return c({error:r})}},async insert(n,a){try{let r=W(n,o),[u,m]=await e.execute(r,a);return u?c({error:u,query:r}):[null,{rows:m,query:r}]}catch(r){return c({error:r})}},async introspect(n){return await i(n)},async sqlSchema(n,a){let[r,u]=await i(a);return r?[r]:[null,U({defaultSchema:h,dialect:"sqlite",introspection:u})]},async sqlLint(n,a){if(l&&typeof e.lintSql=="function")try{let[r,u]=await e.lintSql(n,a);if(!r)return[null,u];if(!te(r))return c({error:r});l=!1}catch(r){if(!te(r))return c({error:r});l=!1}return await ee(e,n,a)},async query(n,a){try{let r=X(n,o),[u,m]=await B({executor:e,options:a,query:r,searchTerm:n.fullTableSearchTerm,state:s});return u?c({error:u,query:r}):[null,{filteredRowCount:m[0]?.__ps_count__||"0",rows:m,query:r}]}catch(r){return c({error:r})}},async raw(n,a){try{let r=w(n.sql),[u,m]=await e.execute(r,a);return u?c({error:u,query:r}):[null,{query:r,rowCount:m.length,rows:m}]}catch(r){return c({error:r})}},async update(n,a){try{let r=Y(n,o),[u,m]=await e.execute(r,a);if(u)return c({error:u,query:r});let[d]=m;return d?[null,{row:d,query:r}]:c({error:new Error("Update failed"),query:r})}catch(r){return c({error:r})}}}}function te(t){if(!(t instanceof Error))return!1;let e=t.message.toLowerCase();return e.includes("invalid procedure")||e.includes("not supported")||e.includes("method not allowed")}var ce=/WITHOUT\s+ROWID/i;function re(t){let{tables:e,query:o}=t;return{filterOperators:ue,query:o,schemas:e.reduce((s,l)=>{let{columns:i,name:n,sql:a}=l,r=0,u=i.reduce((m,d,T)=>{let{datatype:f,default:A,fk_column:R,name:p,pk:_}=d;r=Math.max(r,_);let E=K(f),x=f.toUpperCase()==="INTEGER"&&_===1&&r===1&&!i.slice(T+1).some(function(ne){return ne.pk>1})&&!ce.test(a),Q=!!d.computed,O=!!d.nullable&&!x;return m[p]={datatype:{...$[E],affinity:E,isArray:!1,isNative:!0,name:f,options:[],schema:h},defaultValue:A,fkColumn:R,fkSchema:R?h:null,fkTable:d.fk_table,isAutoincrement:x,isComputed:Q,isRequired:!O&&!x&&!Q&&A==null,name:p,nullable:O,pkPosition:_>0?_:null,schema:h,table:n},m},{});return s.main.tables[n]={columns:u,name:n,schema:"main"},s},{main:{tables:{},name:"main"}}),timezone:"UTC"}}function ve(){let t={parameters:[],sql:"<mocked>"},e=H();return re({query:t,tables:e})}export{Z as createLintDiagnosticsFromSQLiteError,Ue as createSQLiteAdapter,J as getDeleteQuery,W as getInsertQuery,X as getSelectQuery,z as getTablesQuery,Y as getUpdateQuery,ee as lintSQLiteWithExplainFallback,ve as mockIntrospect,Ee as mockSelectQuery,H as mockTablesQuery};
10
10
  //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/sqlite-core/datatype.ts", "../../../data/sqlite-core/builder.ts", "../../../data/sqlite-core/dml.ts", "../../../node_modules/.pnpm/kysely@0.28.10/node_modules/kysely/dist/esm/helpers/sqlite.js", "../../../data/sqlite-core/introspection.ts", "../../../data/sqlite-core/sql-lint.ts", "../../../data/sqlite-core/adapter.ts"],
  "sourcesContent": ["import type { DataType } from \"../adapter\";\n\nexport type SQLiteAffinity =\n  | \"BLOB\"\n  | \"INTEGER\"\n  | \"NULL\"\n  | \"NUMERIC\"\n  | \"REAL\"\n  | \"TEXT\";\n\nexport const SQLITE_AFFINITY_TO_METADATA: Record<\n  SQLiteAffinity,\n  Pick<DataType, \"format\" | \"group\">\n> = {\n  BLOB: {\n    group: \"raw\",\n  },\n  INTEGER: {\n    group: \"numeric\",\n  },\n  NULL: {\n    group: \"raw\",\n  },\n  NUMERIC: {\n    group: \"numeric\",\n  },\n  REAL: {\n    group: \"numeric\",\n  },\n  TEXT: {\n    group: \"string\",\n  },\n};\n\n/**\n * https://sqlite.org/datatype3.html#determination_of_column_affinity\n *\n * DO NOT CHANGE THE ORDER OF THE CHECKS IN THIS FUNCTION!\n */\nexport function determineColumnAffinity(\n  declaredDataType: string | null,\n): SQLiteAffinity {\n  if (!declaredDataType) {\n    return \"BLOB\";\n  }\n\n  const upperType = declaredDataType.toUpperCase();\n\n  if (upperType.includes(\"INT\")) {\n    return \"INTEGER\";\n  }\n\n  if (\n    upperType.includes(\"TEXT\") ||\n    upperType.includes(\"CHAR\") ||\n    upperType.includes(\"CLOB\")\n  ) {\n    return \"TEXT\";\n  }\n\n  if (upperType.includes(\"BLOB\")) {\n    return \"BLOB\";\n  }\n\n  if (\n    upperType.includes(\"REAL\") ||\n    upperType.includes(\"FLOA\") ||\n    upperType.includes(\"DOUB\")\n  ) {\n    return \"REAL\";\n  }\n\n  return \"NUMERIC\";\n}\n", "import { type Kysely, SqliteAdapter, SqliteQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getSQLiteBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder<Database>({\n    ...requirements,\n    Adapter: SqliteAdapter,\n    QueryCompiler: SqliteQueryCompiler,\n  });\n}\n", "import { expressionBuilder, type InferResult, sql } from \"kysely\";\nimport { SimpleReferenceExpression } from \"kysely\";\n\nimport type {\n  AdapterDeleteDetails,\n  AdapterInsertDetails,\n  AdapterQueryDetails,\n  AdapterUpdateDetails,\n} from \"../adapter\";\nimport {\n  buildFullTableSearchPlan,\n  getFullTableSearchExpression,\n} from \"../full-table-search\";\nimport {\n  applyInferredRowFilters,\n  applyTransformations,\n  type BuilderRequirements,\n  compile,\n  getSelectFilterExpression,\n} from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getSQLiteBuilder } from \"./builder\";\nimport { mockTablesQuery } from \"./introspection\";\n\n/**\n * Returns a query that selects all columns from a table 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 },\n  } = details;\n\n  const builder =\n    getSQLiteBuilder<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: \"sqlite\",\n            })(eb),\n          ])\n      : appliedFilterExpression;\n\n  const AGG_NAME = \"__ps_agg__\";\n  const COUNT_REF = \"__ps_count__\";\n\n  const countQuery = builder\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      .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        sortOrder.reduce(\n          (qb, item) => qb.orderBy(item.column, item.direction),\n          qb,\n        ),\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 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 },\n  } = details;\n\n  const builder =\n    getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .deleteFrom(tableName)\n      .$call(applyInferredRowFilters(rows, columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_deleted_at__\")),\n  );\n}\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    table: { columns, name: tableName },\n    rows,\n  } = details;\n\n  const builder =\n    getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .insertInto(tableName)\n      .values(\n        applyTransformations({\n          columns,\n          context: \"insert\",\n          supportsDefaultKeyword: false,\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 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 },\n  } = details;\n\n  const builder =\n    getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .updateTable(tableName)\n      .set(\n        applyTransformations({\n          columns,\n          context: \"update\",\n          supportsDefaultKeyword: false,\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\nfunction getCurrentTimestampMillis() {\n  const eb = expressionBuilder();\n\n  return eb.cast<BigIntString>(\n    eb.cast(sql`(julianday('now') - 2440587.5) * 86400000.0`, \"integer\"),\n    \"text\",\n  );\n}\n", "/// <reference types=\"./sqlite.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\nimport { getJsonObjectArgs } from '../util/json-object-args.js';\n/**\n * A SQLite helper for aggregating a subquery into a JSON array.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/sqlite'\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 * result[0]?.id\n * result[0]?.pets[0].pet_id\n * result[0]?.pets[0].name\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * select \"id\", (\n *   select coalesce(json_group_array(json_object(\n *     'pet_id', \"agg\".\"pet_id\",\n *     'name', \"agg\".\"name\"\n *   )), '[]') 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_group_array(json_object(${sql.join(getSqliteJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') from ${expr} as agg)`;\n}\n/**\n * A SQLite helper for turning a subquery into a JSON object.\n *\n * The subquery must only return one row.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/sqlite'\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 * result[0]?.id\n * result[0]?.favorite_pet?.pet_id\n * result[0]?.favorite_pet?.name\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * select \"id\", (\n *   select json_object(\n *     'pet_id', \"obj\".\"pet_id\",\n *     'name', \"obj\".\"name\"\n *   ) 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\" = ?\n *   ) as obj\n * ) as \"favorite_pet\"\n * from \"person\";\n * ```\n */\nexport function jsonObjectFrom(expr) {\n    return sql `(select json_object(${sql.join(getSqliteJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;\n}\n/**\n * The SQLite `json_object` function.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n * import { jsonBuildObject } from 'kysely/helpers/sqlite'\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 (SQLite):\n *\n * ```sql\n * select \"id\", json_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_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;\n}\nfunction getSqliteJsonObjectArgs(node, table) {\n    try {\n        return getJsonObjectArgs(node, table);\n    }\n    catch {\n        throw new Error('SQLite jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.');\n    }\n}\n", "/**\n * SQLite introspection queries to be used by the SQLite adapter's introspect method.\n * @module sqlite-core/introspection\n *\n * References:\n * https://sqlite.org/pragma.html\n * https://sqlite.org/schematab.html\n */\n\nimport { expressionBuilder, type NotNull } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/sqlite\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getSQLiteBuilder } from \"./builder\";\n\ninterface Database {\n  /** the main system table */\n  sqlite_schema: {\n    /** object name */\n    name: string;\n    /** page number in root index when object is a table. */\n    rootpage: number;\n    /** sql statement that can recreate the object. null when internal index object. */\n    sql: string | null;\n    /** related table/view name when object is an index/trigger. */\n    tbl_name: string;\n    /** object type */\n    type: \"index\" | \"table\" | \"trigger\" | \"view\";\n  };\n}\n\n/**\n * The shape of each row returned by `pragma_table_list(tableName?)`.\n */\ninterface PragmaTableList {\n  /** object name */\n  name: string;\n  /** schema name */\n  schema: \"main\" | \"temp\";\n  /** object type */\n  type: \"shadow\" | \"table\" | \"view\" | \"virtual\";\n}\n\n/**\n * The shape of each row returned by `pragma_table_xinfo(tableName)`.\n */\ninterface PragmaTableXInfo {\n  /** \"rank within current result set\" */\n  cid: number;\n  /** default value */\n  dflt_value: string | null;\n  /** 0 - normal, 1 - hidden, 2-3 - dynamic/stored generated */\n  hidden: 0 | 1 | 2 | 3;\n  /** column name */\n  name: string;\n  /** whether the column can be null */\n  notnull: 0 | 1;\n  /** 0 if not part of the primary key, otherwise the 1-based ordinal number of the column in the primary key */\n  pk: number;\n  /** data type */\n  type: string;\n}\n\n/**\n * The shape of each row returned by `pragma_foreign_key_list(tableName)`.\n */\ninterface PragmaForeignKeyList {\n  /** column name */\n  from: string;\n  /** ordinal number of column within the foreign key */\n  seq: number;\n  /** foreign table name */\n  table: string;\n  /** column name in the foreign table */\n  to: string;\n}\n\nexport function getTablesQuery(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  return compile(\n    getSQLiteBuilder<Database>(requirements)\n      .selectFrom(\n        expressionBuilder()\n          .fn<PragmaTableList>(\"pragma_table_list\", [])\n          .as(\"tl\"),\n      )\n      .leftJoin(\"sqlite_schema as ss\", (jb) =>\n        jb.onRef(\"ss.type\", \"=\", \"tl.type\").onRef(\"ss.name\", \"=\", \"tl.name\"),\n      )\n      .where(\"tl.type\", \"in\", [\"table\", \"view\"])\n      // exclude temporary tables/views\n      .where(\"tl.schema\", \"=\", \"main\")\n      // exclude system tables/views\n      .where(\"tl.name\", \"not like\", \"sqlite_%\")\n      .select([\"tl.name\", \"ss.sql\"])\n      // since we're excluding system tables, `ss.sql` should never be null here.\n      .$narrowType<{ sql: NotNull }>()\n      .select((eb) => [\n        jsonArrayFrom(\n          eb\n            .selectFrom(\n              eb\n                .fn<PragmaTableXInfo>(\"pragma_table_xinfo\", [\"tl.name\"])\n                .as(\"txi\"),\n            )\n            .leftJoin(\n              eb\n                .fn<PragmaForeignKeyList>(\"pragma_foreign_key_list\", [\n                  \"tl.name\",\n                ])\n                .as(\"fkl\"),\n              \"fkl.from\",\n              \"txi.name\",\n            )\n            // exclude hidden columns\n            .where(\"txi.hidden\", \"!=\", 1)\n            .select([\n              \"txi.dflt_value as default\",\n              \"txi.name\",\n              \"txi.pk\",\n              \"txi.type as datatype\",\n              \"fkl.table as fk_table\",\n              \"fkl.to as fk_column\",\n            ])\n            .select((eb) => [\n              eb(\"txi.hidden\", \"in\", [2, 3]).as(\"computed\"),\n              eb(\"txi.notnull\", \"=\", 0).as(\"nullable\"),\n            ]),\n        ).as(\"columns\"),\n      ]),\n    { transformations: { columns: \"json-parse\" } },\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTablesQuery() {\n  return [\n    {\n      name: \"animals\",\n      sql: \"CREATE TABLE animals (id INTEGER PRIMARY KEY, name TEXT);\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"INTEGER\",\n          default: null,\n          pk: 1,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"TEXT\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n    {\n      name: \"users\",\n      sql: \"CREATE TABLE users (id UUID PRIMARY KEY, created_at TIMESTAMP, deleted_at TIMESTAMP, role varchar, name varchar, name_role text);\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"INTEGER\",\n          default: null,\n          pk: 1,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"TIMESTAMP\",\n          default: \"1970-01-01 00:00:00.000\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"deleted_at\",\n          datatype: \"TIMESTAMP\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"role\",\n          datatype: \"varchar\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"varchar\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name_role\",\n          datatype: \"text\",\n          default: null,\n          pk: 0,\n          computed: 1,\n          nullable: 0,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n    {\n      name: \"composite_pk\",\n      sql: \"CREATE TABLE composite_pk (id UUID, name TEXT, created_at timestamp, PRIMARY KEY (id, name));\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"text\",\n          default: null,\n          pk: 1,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"TEXT\",\n          default: null,\n          pk: 2,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"timestamp\",\n          default: \"1970-01-01 00:00:00.000\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n", "import type {\n  Adapter,\n  AdapterError,\n  AdapterSqlLintDetails,\n  AdapterSqlLintDiagnostic,\n  AdapterSqlLintResult,\n} from \"../adapter\";\nimport type { Executor } from \"../executor\";\nimport { validateSqlForLint } from \"../postgres-core/sql-lint\";\nimport { asQuery } from \"../query\";\nimport type { Either } from \"../type-utils\";\n\nexport function createLintDiagnosticsFromSQLiteError(args: {\n  error: unknown;\n  positionOffset?: number;\n  sql: string;\n}): AdapterSqlLintDiagnostic[] {\n  const { error, sql } = args;\n  const positionOffset = Math.max(0, args.positionOffset ?? 0);\n  const fallbackRange = getFallbackRange(sql.length);\n\n  if (!(error instanceof Error)) {\n    return [\n      {\n        from: fallbackRange.from + positionOffset,\n        message: \"SQL lint failed.\",\n        severity: \"error\",\n        source: \"sqlite\",\n        to: fallbackRange.to + positionOffset,\n      },\n    ];\n  }\n\n  const code = getSQLiteErrorCode(error);\n  const inferredRange =\n    inferRangeFromMessage(sql, error.message) ?? fallbackRange;\n\n  return [\n    {\n      code,\n      from: inferredRange.from + positionOffset,\n      message: toSQLiteLintMessage(error.message),\n      severity: \"error\",\n      source: \"sqlite\",\n      to: inferredRange.to + positionOffset,\n    },\n  ];\n}\n\nexport async function lintSQLiteWithExplainFallback(\n  executor: 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        ...createLintDiagnosticsFromSQLiteError({\n          error,\n          positionOffset: statement.from,\n          sql: statement.statement,\n        }),\n      );\n    } catch (error: unknown) {\n      diagnostics.push(\n        ...createLintDiagnosticsFromSQLiteError({\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\nfunction getSQLiteErrorCode(error: Error): string | undefined {\n  const withCode = error as Error & { code?: unknown };\n  return typeof withCode.code === \"string\" ? withCode.code : undefined;\n}\n\nfunction toSQLiteLintMessage(message: string): string {\n  if (message.toLowerCase().includes(\"interrupted\")) {\n    return \"Lint query timed out. Simplify the statement and try again.\";\n  }\n\n  return message;\n}\n\nfunction getFallbackRange(sqlLength: number): { from: number; to: number } {\n  if (sqlLength <= 0) {\n    return { from: 0, to: 0 };\n  }\n\n  return { from: 0, to: 1 };\n}\n\nfunction inferRangeFromMessage(\n  sql: string,\n  message: string,\n): { from: number; to: number } | null {\n  const nearMatch = /near\\s+[\"'`]([^\"'`]+)[\"'`]/i.exec(message);\n  if (nearMatch?.[1]) {\n    return findTokenRange(sql, nearMatch[1]);\n  }\n\n  const missingTableMatch = /no such table:\\s*([^\\s]+)/i.exec(message);\n  if (missingTableMatch?.[1]) {\n    return findTokenRange(sql, missingTableMatch[1]);\n  }\n\n  const missingColumnMatch = /no such column:\\s*([^\\s]+)/i.exec(message);\n  if (missingColumnMatch?.[1]) {\n    return findTokenRange(sql, missingColumnMatch[1]);\n  }\n\n  return null;\n}\n\nfunction findTokenRange(\n  sql: string,\n  rawToken: string,\n): { from: number; to: number } | null {\n  const token = rawToken.trim().replace(/^['\"`]|['\"`]$/g, \"\");\n\n  if (token.length === 0) {\n    return null;\n  }\n\n  const lowerSql = sql.toLowerCase();\n  const lowerToken = token.toLowerCase();\n  const directIndex = lowerSql.indexOf(lowerToken);\n\n  if (directIndex >= 0) {\n    return {\n      from: directIndex,\n      to: Math.min(sql.length, directIndex + token.length),\n    };\n  }\n\n  const splitToken = lowerToken.split(\".\").at(-1);\n\n  if (!splitToken) {\n    return null;\n  }\n\n  const splitIndex = lowerSql.indexOf(splitToken);\n\n  if (splitIndex < 0) {\n    return null;\n  }\n\n  return {\n    from: splitIndex,\n    to: Math.min(sql.length, splitIndex + splitToken.length),\n  };\n}\n", "import {\n  type Adapter,\n  type AdapterDeleteResult,\n  type AdapterError,\n  type AdapterInsertResult,\n  type AdapterIntrospectResult,\n  type AdapterQueryResult,\n  type AdapterRawResult,\n  type AdapterRequirements,\n  type AdapterSqlLintResult,\n  type AdapterSqlSchemaResult,\n  type AdapterUpdateResult,\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, type QueryResult } from \"../query\";\nimport { createSqlEditorSchemaFromIntrospection } from \"../sql-editor-schema\";\nimport type { Either } from \"../type-utils\";\nimport {\n  determineColumnAffinity,\n  SQLITE_AFFINITY_TO_METADATA,\n} from \"./datatype\";\nimport {\n  getDeleteQuery,\n  getInsertQuery,\n  getSelectQuery,\n  getUpdateQuery,\n} from \"./dml\";\nimport { getTablesQuery, mockTablesQuery } from \"./introspection\";\nimport { lintSQLiteWithExplainFallback } from \"./sql-lint\";\n\nexport type SQLIteAdapterRequirements = AdapterRequirements;\n\nconst schema = \"main\";\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n] satisfies FilterOperator[];\n\nexport function createSQLiteAdapter(\n  requirements: SQLIteAdapterRequirements,\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(requirements);\n\n      const [tablesError, tables] = await executor.execute(\n        tablesQuery,\n        options,\n      );\n\n      if (tablesError) {\n        return createAdapterError({ error: tablesError, query: tablesQuery });\n      }\n\n      return [null, createIntrospection({ query: tablesQuery, tables })];\n    } catch (error: unknown) {\n      return createAdapterError({ error: error as Error });\n    }\n  }\n\n  return {\n    defaultSchema: schema,\n    capabilities: {\n      fullTableSearch: true,\n      sqlDialect: \"sqlite\",\n      sqlEditorAutocomplete: true,\n      sqlEditorLint: true,\n    },\n\n    async delete(\n      details,\n      options,\n    ): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n\n        // TODO: use results too.\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    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 introspect(\n      options,\n    ): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      return await introspectDatabase(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: schema,\n          dialect: \"sqlite\",\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          canUseExecutorLintTransport = false;\n        } catch (error: unknown) {\n          if (!shouldFallbackToExplainLint(error)) {\n            return createAdapterError({ error: error as Error });\n          }\n\n          canUseExecutorLintTransport = false;\n        }\n      }\n\n      return await lintSQLiteWithExplainFallback(executor, details, 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        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async raw(\n      details,\n      options,\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\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          // TODO: custom error?\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}\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(\"not supported\") ||\n    message.includes(\"method not allowed\")\n  );\n}\n\nconst WITHOUT_ROWID_REGEX = /WITHOUT\\s+ROWID/i;\n\nfunction createIntrospection(args: {\n  tables: QueryResult<typeof getTablesQuery>;\n  query: Query;\n}): AdapterIntrospectResult {\n  const { tables, query: tablesQuery } = args;\n\n  return {\n    filterOperators,\n    query: tablesQuery,\n    schemas: tables.reduce(\n      (schemas, table) => {\n        const { columns, name: tableName, sql } = table;\n\n        let maxPKSeen = 0;\n\n        const columnsRecord = columns.reduce(\n          (columnsRecord, column, index) => {\n            const {\n              datatype,\n              default: defaultValue,\n              fk_column,\n              name: columnName,\n              pk,\n            } = column;\n\n            maxPKSeen = Math.max(maxPKSeen, pk);\n\n            const affinity = determineColumnAffinity(datatype);\n\n            /**\n             * `INTEGER PRIMARY KEY` columns act as `rowid` alias. `rowid` columns\n             * are auto-generated unique numbers that exist in every SQLite table\n             * unless a table is created using `WITHOUT ROWID` option.\n             */\n            const isRowId =\n              datatype.toUpperCase() === \"INTEGER\" &&\n              pk === 1 &&\n              // no other primary key columns before this column.\n              maxPKSeen === 1 &&\n              !columns\n                .slice(index + 1)\n                .some(function isAlsoInPrimaryKey(column) {\n                  return column.pk > 1;\n                }) &&\n              !WITHOUT_ROWID_REGEX.test(sql);\n\n            const isComputed = Boolean(column.computed);\n            // `rowid` columns are implicitly not nullable.\n            const nullable = Boolean(column.nullable) && !isRowId;\n\n            columnsRecord[columnName] = {\n              datatype: {\n                ...SQLITE_AFFINITY_TO_METADATA[affinity],\n                affinity,\n                isArray: false,\n                isNative: true,\n                name: datatype,\n                // TODO: use `table.sql` to determine enum options from `check` constraints.\n                options: [],\n                schema,\n              },\n              defaultValue,\n              fkColumn: fk_column,\n              fkSchema: fk_column ? schema : null,\n              fkTable: column.fk_table,\n              // since `rowid` is auto generated unique number, and `AUTO INCREMENT`\n              // can only be applied to such columns, we consider them autoincrement\n              // and we don't need to check for the existence of the modifier in\n              // the `CREATE TABLE` statement.\n              isAutoincrement: isRowId,\n              isComputed,\n              isRequired:\n                !nullable && !isRowId && !isComputed && defaultValue == null,\n              name: columnName,\n              nullable,\n              pkPosition: pk > 0 ? pk : null,\n              schema,\n              table: tableName,\n            };\n\n            return columnsRecord;\n          },\n          {} as Table[\"columns\"],\n        );\n\n        schemas.main!.tables[tableName] = {\n          columns: columnsRecord,\n          name: tableName,\n          schema: \"main\",\n        };\n\n        return schemas;\n      },\n      {\n        main: { tables: {}, name: \"main\" },\n      } satisfies AdapterIntrospectResult[\"schemas\"] as AdapterIntrospectResult[\"schemas\"],\n    ),\n    timezone: \"UTC\",\n  };\n}\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n  const tables = mockTablesQuery();\n\n  return createIntrospection({ query, tables }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      main: {\n        name: \"main\";\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: string;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n"],
  "mappings": "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",
  "names": ["SQLITE_AFFINITY_TO_METADATA", "determineColumnAffinity", "declaredDataType", "upperType", "getSQLiteBuilder", "requirements", "getBuilder", "SqliteAdapter", "SqliteQueryCompiler", "getSelectQuery", "details", "requirements", "filter", "fullTableSearchTerm", "pageIndex", "pageSize", "sortOrder", "columns", "tableName", "builder", "getSQLiteBuilder", "appliedFilterExpression", "getSelectFilterExpression", "fullTableSearchPlan", "buildFullTableSearchPlan", "combinedWhereExpression", "eb", "getFullTableSearchExpression", "AGG_NAME", "COUNT_REF", "countQuery", "sql", "compile", "jb", "qb", "item", "mockSelectQuery", "getDeleteQuery", "rows", "applyInferredRowFilters", "getCurrentTimestampMillis", "getInsertQuery", "applyTransformations", "getUpdateQuery", "changes", "row", "expressionBuilder", "jsonArrayFrom", "expr", "sql", "getSqliteJsonObjectArgs", "getSqliteJsonObjectArgs", "node", "table", "getJsonObjectArgs", "getTablesQuery", "requirements", "compile", "getSQLiteBuilder", "expressionBuilder", "jb", "eb", "jsonArrayFrom", "mockTablesQuery", "createLintDiagnosticsFromSQLiteError", "args", "error", "sql", "positionOffset", "fallbackRange", "getFallbackRange", "code", "getSQLiteErrorCode", "inferredRange", "inferRangeFromMessage", "toSQLiteLintMessage", "lintSQLiteWithExplainFallback", "executor", "details", "options", "validation", "validateSqlForLint", "diagnostics", "statement", "explainQuery", "asQuery", "withCode", "message", "sqlLength", "nearMatch", "findTokenRange", "missingTableMatch", "missingColumnMatch", "rawToken", "token", "lowerSql", "lowerToken", "directIndex", "splitToken", "splitIndex", "schema", "filterOperators", "createSQLiteAdapter", "requirements", "executor", "otherRequirements", "fullTableSearchState", "createFullTableSearchExecutionState", "canUseExecutorLintTransport", "introspectDatabase", "options", "tablesQuery", "getTablesQuery", "tablesError", "tables", "createAdapterError", "createIntrospection", "error", "details", "query", "getDeleteQuery", "getInsertQuery", "rows", "_details", "introspection", "createSqlEditorSchemaFromIntrospection", "result", "shouldFallbackToExplainLint", "lintSQLiteWithExplainFallback", "getSelectQuery", "results", "executeQueryWithFullTableSearchGuardrails", "asQuery", "getUpdateQuery", "row", "message", "WITHOUT_ROWID_REGEX", "args", "schemas", "table", "columns", "tableName", "sql", "maxPKSeen", "columnsRecord", "column", "index", "datatype", "defaultValue", "fk_column", "columnName", "pk", "affinity", "determineColumnAffinity", "isRowId", "isComputed", "nullable", "SQLITE_AFFINITY_TO_METADATA", "mockIntrospect", "mockTablesQuery"]
}
