@prisma/studio-core-licensed 0.0.0-dev.202511180328 → 0.0.0-dev.202511180420
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-OTK4ZF2W.js → chunk-24UZSKGU.js} +1 -1
- package/dist/chunk-NQGSK3IM.js +10 -0
- package/dist/chunk-RYYSZZYL.js +10 -0
- package/dist/data/accelerate/index.d.cts +1 -1
- package/dist/data/accelerate/index.d.ts +1 -1
- package/dist/data/bff/index.d.cts +1 -1
- package/dist/data/bff/index.d.ts +1 -1
- package/dist/data/index.d.cts +1 -1
- package/dist/data/index.d.ts +1 -1
- package/dist/data/mysql-core/index.cjs +2 -2
- package/dist/data/mysql-core/index.d.cts +9 -3
- package/dist/data/mysql-core/index.d.ts +9 -3
- package/dist/data/mysql-core/index.js +2 -2
- package/dist/data/mysql2/index.cjs +2 -2
- package/dist/data/mysql2/index.d.cts +1 -1
- package/dist/data/mysql2/index.d.ts +1 -1
- package/dist/data/mysql2/index.js +1 -1
- package/dist/data/node-sqlite/index.d.cts +1 -1
- package/dist/data/node-sqlite/index.d.ts +1 -1
- package/dist/data/pglite/index.cjs +1 -1
- package/dist/data/pglite/index.d.cts +1 -1
- package/dist/data/pglite/index.d.ts +1 -1
- package/dist/data/pglite/index.js +1 -1
- package/dist/data/postgres-core/index.cjs +1 -1
- package/dist/data/postgres-core/index.d.cts +1 -1
- package/dist/data/postgres-core/index.d.ts +1 -1
- package/dist/data/postgres-core/index.js +1 -1
- package/dist/data/postgresjs/index.cjs +2 -2
- package/dist/data/postgresjs/index.d.cts +1 -1
- package/dist/data/postgresjs/index.d.ts +1 -1
- package/dist/data/postgresjs/index.js +1 -1
- package/dist/data/ppg/index.d.cts +1 -1
- package/dist/data/ppg/index.d.ts +1 -1
- package/dist/data/sqlite-core/index.cjs +1 -1
- package/dist/data/sqlite-core/index.d.cts +1 -1
- package/dist/data/sqlite-core/index.d.ts +1 -1
- package/dist/data/sqlite-core/index.js +1 -1
- package/dist/{index-2horhMcs.d.ts → index-CV9DQF9a.d.cts} +5 -2
- package/dist/{index-2horhMcs.d.cts → index-CV9DQF9a.d.ts} +5 -2
- package/dist/metafile-cjs.json +1 -1
- package/dist/metafile-esm.json +1 -1
- package/dist/ui/index.cjs +1 -1
- package/dist/ui/index.d.cts +1 -1
- package/dist/ui/index.d.ts +1 -1
- package/dist/ui/index.js +1 -1
- package/package.json +1 -1
- package/dist/chunk-AHIV4VYN.js +0 -10
- package/dist/chunk-CM36Z3XQ.js +0 -10
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, g as AdapterInsertDetails, B as BuilderRequirements, e as AdapterQueryDetails, h as AdapterUpdateDetails, f as AdapterDeleteDetails } from '../../index-
|
|
1
|
+
import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, g as AdapterInsertDetails, B as BuilderRequirements, e as AdapterQueryDetails, h as AdapterUpdateDetails, f as AdapterDeleteDetails } from '../../index-CV9DQF9a.cjs';
|
|
2
2
|
import 'kysely';
|
|
3
3
|
|
|
4
4
|
type PostgresAdapterRequirements = AdapterRequirements;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, g as AdapterInsertDetails, B as BuilderRequirements, e as AdapterQueryDetails, h as AdapterUpdateDetails, f as AdapterDeleteDetails } from '../../index-
|
|
1
|
+
import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, g as AdapterInsertDetails, B as BuilderRequirements, e as AdapterQueryDetails, h as AdapterUpdateDetails, f as AdapterDeleteDetails } from '../../index-CV9DQF9a.js';
|
|
2
2
|
import 'kysely';
|
|
3
3
|
|
|
4
4
|
type PostgresAdapterRequirements = AdapterRequirements;
|
|
@@ -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,b,c,d,e,f,g,h,i,j,k}from"../../chunk-
|
|
9
|
+
import{a,b,c,d,e,f,g,h,i,j,k}from"../../chunk-RYYSZZYL.js";import{a as l,b as m}from"../../chunk-M7E5UEO3.js";import"../../chunk-24UZSKGU.js";import"../../chunk-A6CVKSUD.js";import"../../chunk-GDQBQ7MK.js";export{j as createPostgresAdapter,m as getCancelQuery,e as getDeleteQuery,a as getInsertQuery,l as getPIDQuery,b as getSelectQuery,f as getTablesQuery,h as getTimezoneQuery,d as getUpdateQuery,k as mockIntrospect,c as mockSelectQuery,g as mockTablesQuery,i as mockTimezoneQuery};
|
|
10
10
|
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var l=Object.defineProperty;var
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/postgresjs/index.ts", "../../../data/executor.ts", "../../../data/query.ts", "../../../data/postgres-core/utility.ts"],
  "sourcesContent": ["import type { ReservedSql, Sql } from \"postgres\";\n\nimport { type Executor, getAbortResult } from \"../executor\";\nimport { getCancelQuery, getPIDQuery } from \"../postgres-core/utility\";\nimport type { QueryResult } from \"../query\";\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(query.sql, query.parameters as never);\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>((resolve) => (aborted = resolve));\n\n        abortSignal.addEventListener(\"abort\", (abortListener = () => aborted()));\n\n        const connectionPromise = postgresjs.reserve();\n\n        const connectionResult = await Promise.race([connectionPromise, abortionPromise]);\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(query.sql, query.parameters as never);\n\n        const queryResult = await Promise.race([queryPromise, abortionPromise]);\n\n        if (!queryResult) {\n          void Promise.allSettled([cancelQuery(postgresjs, pidResult!), queryPromise]).finally(() =>\n            connection?.release(),\n          );\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}\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>>(query.sql, query.parameters as never);\n\n    return result?.pid;\n  } catch (error) {\n    console.error(\"Failed to get connection PID:\", error);\n\n    return undefined;\n  }\n}\n", "import type { Query, QueryResult } from \"./query\";\nimport type { Either } from \"./type-utils\";\n\nexport interface Executor {\n  execute<T>(query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;\n}\n\nexport interface ExecuteOptions {\n  abortSignal?: AbortSignal;\n}\n\nexport class AbortError extends Error {\n  constructor() {\n    super(\"This operation was aborted\");\n    this.name = \"AbortError\";\n  }\n}\n\nexport function getAbortResult(): [AbortError] {\n  return [new AbortError()];\n}\n", "import {\n  type Compilable,\n  type DialectAdapter,\n  DummyDriver,\n  type Expression,\n  type ExpressionBuilder,\n  expressionBuilder,\n  type ExpressionWrapper,\n  type InsertObject,\n  Kysely,\n  type KyselyPlugin,\n  OperationNodeTransformer,\n  type PluginTransformQueryArgs,\n  type PluginTransformResultArgs,\n  type PrimitiveValueListNode,\n  type QueryCompiler,\n  type QueryResult as KyselyQueryResult,\n  type RootOperationNode,\n  sql,\n  type SqlBool,\n  type UnknownRow,\n  type UpdateObject,\n  ValueListNode,\n  ValueNode,\n  type WhereInterface,\n} from \"kysely\";\n\nimport type { Column, ColumnFilter, FilterGroup, Table } from \"./adapter\";\n\nexport interface BuilderRequirements {\n  Adapter: { new (): DialectAdapter };\n  noParameters?: boolean;\n  QueryCompiler: { new (): QueryCompiler };\n}\n\nexport function getBuilder<DB>(requirements: BuilderRequirements): Kysely<DB> {\n  return new Kysely({\n    dialect: {\n      createAdapter: () => new requirements.Adapter(),\n      createDriver: () => new DummyDriver(),\n      // @ts-expect-error - we don't need built-in introspection in this case\n      createIntrospector: () => null,\n      createQueryCompiler: () => new requirements.QueryCompiler(),\n    },\n    plugins: [...(requirements.noParameters ? [new ImmediateValuePlugin()] : [])],\n  });\n}\n\n/**\n * A plugin that transforms all values to immediate values. This means their injected into the SQL string instead of populating the parameters array.\n * In some situations, a database driver might not support parameters, and this plugin can be used to work around that.\n */\nclass ImmediateValuePlugin implements KyselyPlugin {\n  readonly #transformer = new ImmediateValueTransformer();\n\n  transformQuery(args: PluginTransformQueryArgs): RootOperationNode {\n    return this.#transformer.transformNode(args.node);\n  }\n\n  transformResult(args: PluginTransformResultArgs): Promise<KyselyQueryResult<UnknownRow>> {\n    return Promise.resolve(args.result);\n  }\n}\n\nclass ImmediateValueTransformer extends OperationNodeTransformer {\n  protected override transformPrimitiveValueList(node: PrimitiveValueListNode): PrimitiveValueListNode {\n    return ValueListNode.create(node.values.map(ValueNode.createImmediate)) as never;\n  }\n\n  override transformValue(node: ValueNode): ValueNode {\n    return { ...super.transformValue(node), immediate: true };\n  }\n}\n\ndeclare const queryType: unique symbol;\nexport interface Query<T = Record<string, unknown>> {\n  [queryType]?: T;\n  parameters: readonly unknown[];\n  sql: string;\n  transformations?: Partial<Record<keyof T, \"json-parse\">>;\n}\n\nexport function asQuery<T>(query: string | Query<unknown>): Query<T> {\n  if (typeof query === \"string\") {\n    return { parameters: [], sql: query } as never;\n  }\n\n  return query as never;\n}\n\nexport type QueryResult<T> =\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  T extends Query<infer R> ? R[] : T extends (...args: any[]) => Query<infer R> ? R[] : never;\n\nexport interface CompileOptions<T> {\n  /**\n   * A mapping of column names to transformations that should be applied to the result.\n   * Currently supported transformation is \"json-parse\", which parses a JSON string into an object.\n   */\n  transformations?: Partial<Record<keyof T, \"json-parse\">>;\n}\n\nexport function compile<T = Record<string, unknown>>(\n  compileable: Compilable<T>,\n  options?: CompileOptions<T>,\n): Query<T> {\n  const compiledQuery = compileable.compile();\n\n  return {\n    parameters: compiledQuery.parameters,\n    sql: compiledQuery.sql,\n    transformations: options?.transformations,\n  };\n}\n\n/**\n * Applies a filter to the given rows based on the primary key columns of the table.\n *\n * @example db.selectFrom(\"users\").$call(applyInferredRowFilters(rows, columns)).selectAll()\n */\nexport function applyInferredRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]) {\n  const rowFilters = inferRowFilters(rows, columns);\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return <QB extends WhereInterface<any, any>>(qb: QB): QB =>\n    qb.where((eb) => {\n      return eb.or(\n        rowFilters.map((rowFilter) => {\n          return eb.and(\n            rowFilter.map(([columnName, value]) =>\n              eb(columnName, value === null ? \"is\" : Array.isArray(value) ? \"in\" : \"=\", value),\n            ),\n          );\n        }),\n      );\n    }) as never;\n}\n\n/**\n * Part of a filter that predicts a match.\n * ie. ... WHERE $ColumName = $Value ...\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype RowFilterPredicate = [ColumnName: string | Expression<any>, Value: unknown];\n\n/**\n * A row filter is comprised of one or more predicates.\n */\ntype RowFilter = RowFilterPredicate[];\n\n/**\n * Row filters is simply a set of multiple {@link RowFilter}.\n */\ntype RowFilters = RowFilter[];\n\n/**\n * Infers the filter that is necessary to uniquely identify a given row\n * individually.\n */\nexport function inferFilterObject(row: Record<string, unknown>, columns: Table[\"columns\"]): Record<string, unknown> {\n  const filter: Record<string, unknown> = {};\n\n  for (const column of Object.values(columns)) {\n    const { isInPrimaryKey, name: columnName } = column;\n\n    if (!isInPrimaryKey) {\n      continue;\n    }\n\n    filter[columnName] = row[columnName] ?? null;\n  }\n\n  return filter;\n}\n\n/**\n * Infers the filter that is necessary to uniquely identify multiple rows\n * individually.\n *\n * Elegantly infers the best possible statement to filter with.\n * TODO: introspect primary key ordinal numbers so the tuple is in the correct order.\n * TODO: if we ever support MSSQL, we'll need to drop to dumb (... and ...) or (... and ...) like in the old way just for MSSQL.\n *\n * For single column primary key:\n *\n * 1. if only 1 row: col = value\n * 2. if multiple rows: col IN (value1, value2, ...)\n *\n * For composite primary key:\n *\n * 1. if only 1 row: (col1, col2, ...) = (value1, value2, ...)\n * 2. if multiple rows: (col1, col2, ...) IN ((value1a, value2a, ...), (value1b, value2b, ...), ...)\n */\nexport function inferRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]): RowFilters {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const refs: ExpressionWrapper<any, any, any>[] = [];\n  const values: unknown[] = [];\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const eb = expressionBuilder<any, any>();\n\n  for (const row of rows) {\n    const valuesForRow: unknown[] = [];\n\n    for (const column of Object.values(columns)) {\n      const { isInPrimaryKey, name: columnName } = column;\n\n      if (!isInPrimaryKey) {\n        continue;\n      }\n\n      if (row === rows.at(0)) {\n        refs.push(eb.ref(columnName));\n      }\n\n      valuesForRow.push(transformValue(row[columnName] ?? null, column));\n    }\n\n    values.push(refs.length === 1 ? valuesForRow.at(0)! : tupleFrom(valuesForRow));\n  }\n\n  const lhs = refs.length === 1 ? refs.at(0)! : tupleFrom(refs);\n  const rhs = values.length === 1 ? values.at(0)! : values;\n\n  return [[[lhs, rhs]]];\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction tupleFrom(items: unknown[]): Expression<any> {\n  return sql`(${sql.join(items, sql`, `)})`;\n}\n\nexport function applyTransformations<C extends \"insert\" | \"update\">(\n  _context: C,\n  values: C extends \"update\" ? Record<string, unknown> : Record<string, unknown> | Record<string, unknown>[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): C extends \"update\" ? () => UpdateObject<any, any> : () => InsertObject<any, any> | InsertObject<any, any>[] {\n  return () =>\n    Array.isArray(values) ? values.map((row) => transformValues(row, columns)) : transformValues(values, columns);\n}\n\nfunction transformValues(\n  values: Record<string, unknown>,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): InsertObject<any, any> | UpdateObject<any, any> {\n  if (Object.keys(values).length === 0) {\n    return { [Object.keys(columns).at(0)!]: sql`default` };\n  }\n\n  return Object.entries(values).reduce(\n    (obj, [key, value]) => ({ ...obj, [key]: transformValue(value, columns[key]!) }),\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    {} as InsertObject<any, any> | UpdateObject<any, any>,\n  );\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function transformValue(value: unknown, column: Column): ExpressionWrapper<any, any, any> {\n  const { datatype } = column;\n\n  const eb = expressionBuilder();\n\n  if (value === null) {\n    return eb.lit(null);\n  }\n\n  if (!datatype.isNative) {\n    return eb.cast(eb.val(value), sql.id(datatype.schema, datatype.name));\n  }\n\n  return eb.val(value);\n}\n\nexport function getSelectFilterExpression(\n  filters: (ColumnFilter | FilterGroup)[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (filters.length === 0) return (eb) => eb.lit(true); // no filters, always true\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const orGroupsOfAndBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[][] = [];\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  let currentAndGroupBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[] = [];\n\n  for (let i = 0; i < filters.length; i++) {\n    currentAndGroupBuilders.push(buildBaseExpressionBuilder(filters[i]!, columns));\n\n    // &n AND group ends if it's the last filter, or the item is followed by an 'or'\n    if (i === filters.length - 1 || filters[i]!.after === \"or\") {\n      orGroupsOfAndBuilders.push(currentAndGroupBuilders);\n      currentAndGroupBuilders = []; // start a new group\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return (eb: ExpressionBuilder<any, any>) => {\n    const andExpressions = orGroupsOfAndBuilders.map((group) => {\n      return eb.and(group.map((builder) => builder(eb)));\n    });\n\n    return eb.or(andExpressions);\n  };\n}\n\n// Helper to build an expression builder for a single filter or a group\nfunction buildBaseExpressionBuilder(\n  spec: ColumnFilter | FilterGroup,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (spec.kind === \"ColumnFilter\") {\n    return (eb) => {\n      const { column, operator, value } = spec;\n\n      const columnMeta = columns[column]!;\n\n      return eb(\n        columnMeta.datatype.group === \"raw\" ? eb.cast(column, \"text\") : column,\n        operator,\n        transformValue(value, columnMeta),\n      );\n    };\n  }\n\n  return getSelectFilterExpression(spec.filters, columns);\n}\n", "import { asQuery, type Query } from \"../query\";\n\nexport function getPIDQuery(): Query<{ pid: unknown }> {\n  return asQuery(\"select pg_backend_pid() as pid\");\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport function getCancelQuery(pid: {}): Query<unknown> {\n  return {\n    parameters: [pid],\n    sql: \"select pg_cancel_backend($1);\",\n  };\n}\n"],
  "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,8BAAAE,IAAA,eAAAC,EAAAH,GCWO,IAAMI,EAAN,cAAyB,KAAM,CACpC,aAAc,CACZ,MAAM,4BAA4B,EAClC,KAAK,KAAO,YACd,CACF,EAEO,SAASC,GAA+B,CAC7C,MAAO,CAAC,IAAID,CAAY,CAC1B,CC8DO,SAASE,EAAWC,EAA0C,CACnE,OAAI,OAAOA,GAAU,SACZ,CAAE,WAAY,CAAC,EAAG,IAAKA,CAAM,EAG/BA,CACT,CCtFO,SAASC,GAAuC,CACrD,OAAOC,EAAQ,gCAAgC,CACjD,CAGO,SAASC,EAAeC,EAAyB,CACtD,MAAO,CACL,WAAY,CAACA,CAAG,EAChB,IAAK,+BACP,CACF,CHNO,SAASC,EAAyBC,EAA2B,CAClE,MAAO,CACL,QAAS,MAAOC,EAAOC,IAAY,CACjC,GAAM,CAAE,YAAAC,CAAY,EAAID,GAAW,CAAC,EAEpC,GAAI,CAACC,EACH,GAAI,CAGF,MAAO,CAAC,KAFO,MAAMH,EAAW,OAAOC,EAAM,IAAKA,EAAM,UAAmB,CAE9C,CAC/B,OAASG,EAAgB,CACvB,MAAO,CAACA,CAAc,CACxB,CAGF,GAAID,EAAY,QACd,OAAOE,EAAe,EAGxB,IAAIC,EACAC,EAEJ,GAAI,CACF,IAAIC,EACEC,EAAkB,IAAI,QAAeC,GAAaF,EAAUE,CAAQ,EAE1EP,EAAY,iBAAiB,QAAUG,EAAgB,IAAME,EAAQ,CAAE,EAEvE,IAAMG,EAAoBX,EAAW,QAAQ,EAEvCY,EAAmB,MAAM,QAAQ,KAAK,CAACD,EAAmBF,CAAe,CAAC,EAEhF,GAAI,CAACG,EACH,OAAKD,EAAkB,MAAM,IAAM,CAAC,CAAC,EAE9BN,EAAe,EAKxB,GAFAE,EAAaK,EAETT,EAAY,QACd,OAAAI,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMQ,EAAaC,EAAiBP,CAAU,EAExCQ,EAAY,MAAM,QAAQ,KAAK,CAACF,EAAYJ,CAAe,CAAC,EAElE,GAAIM,IAAc,OAChB,OAAKF,EAAW,MAAM,IAAM,CAAC,CAAC,EAAE,QAAQ,IAAMN,GAAY,QAAQ,CAAC,EAE5DF,EAAe,EAGxB,GAAIF,EAAY,QACd,OAAAI,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMW,EAAeT,EAAW,OAAON,EAAM,IAAKA,EAAM,UAAmB,EAErEgB,EAAc,MAAM,QAAQ,KAAK,CAACD,EAAcP,CAAe,CAAC,EAEtE,OAAKQ,GAQLV,EAAW,QAAQ,EAEZ,CAAC,KAAMU,CAAoB,IAT3B,QAAQ,WAAW,CAACC,EAAYlB,EAAYe,CAAU,EAAGC,CAAY,CAAC,EAAE,QAAQ,IACnFT,GAAY,QAAQ,CACtB,EAEOF,EAAe,EAM1B,OAASD,EAAgB,CACvB,OAAAG,GAAY,QAAQ,EAEb,CAACH,CAAc,CACxB,QAAE,CACIE,GACFH,GAAa,oBAAoB,QAASG,CAAa,CAE3D,CACF,CACF,CACF,CAGA,eAAeY,EAAYlB,EAAiBmB,EAAwB,CAClE,IAAMlB,EAAQmB,EAAeD,CAAG,EAEhC,GAAI,CACF,MAAMnB,EAAW,OAAOC,EAAM,IAAKA,EAAM,UAAmB,CAC9D,OAASG,EAAO,CACd,QAAQ,MAAM,0BAA2BA,CAAK,CAChD,CACF,CAEA,eAAeU,EAAiBP,EAA2C,CACzE,IAAMN,EAAQoB,EAAY,EAE1B,GAAI,CACF,GAAM,CAACC,CAAM,EAAI,MAAMf,EAAW,OAAkCN,EAAM,IAAKA,EAAM,UAAmB,EAExG,OAAOqB,GAAQ,GACjB,OAASlB,EAAO,CACd,QAAQ,MAAM,gCAAiCA,CAAK,EAEpD,MACF,CACF",
  "names": ["postgresjs_exports", "__export", "createPostgresJSExecutor", "__toCommonJS", "AbortError", "getAbortResult", "asQuery", "query", "getPIDQuery", "asQuery", "getCancelQuery", "pid", "createPostgresJSExecutor", "postgresjs", "query", "options", "abortSignal", "error", "getAbortResult", "abortListener", "connection", "aborted", "abortionPromise", "resolve", "connectionPromise", "connectionResult", "pidPromise", "getConnectionPID", "pidResult", "queryPromise", "queryResult", "cancelQuery", "pid", "getCancelQuery", "getPIDQuery", "result"]
}

|
|
1
|
+
"use strict";var l=Object.defineProperty;var E=Object.getOwnPropertyDescriptor;var P=Object.getOwnPropertyNames;var v=Object.prototype.hasOwnProperty;var T=(e,r)=>{for(var n in r)l(e,n,{get:r[n],enumerable:!0})},k=(e,r,n,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of P(r))!v.call(e,o)&&o!==n&&l(e,o,{get:()=>r[o],enumerable:!(t=E(r,o))||t.enumerable});return e};var q=e=>k(l({},"__esModule",{value:!0}),e);var C={};T(C,{createPostgresJSExecutor:()=>h});module.exports=q(C);var c=class extends Error{constructor(){super("This operation was aborted"),this.name="AbortError"}};function i(){return[new c]}function R(e){return typeof e=="string"?{parameters:[],sql:e}:e}function g(){return R("select pg_backend_pid() as pid")}function b(e){return{parameters:[e],sql:"select pg_cancel_backend($1);"}}function h(e){return{execute:async(r,n)=>{let{abortSignal:t}=n||{};if(!t)try{return[null,await e.unsafe(r.sql,r.parameters)]}catch(a){return[a]}if(t.aborted)return i();let o,s;try{let a,u=new Promise(Q=>a=Q);t.addEventListener("abort",o=()=>a());let y=e.reserve(),d=await Promise.race([y,u]);if(!d)return y.catch(()=>{}),i();if(s=d,t.aborted)return s.release(),i();let m=O(s),f=await Promise.race([m,u]);if(f===void 0)return m.catch(()=>{}).finally(()=>s?.release()),i();if(t.aborted)return s.release(),i();let x=s.unsafe(r.sql,r.parameters),w=await Promise.race([x,u]);return w?(s.release(),[null,w]):(Promise.allSettled([B(e,f),x]).finally(()=>s?.release()),i())}catch(a){return s?.release(),[a]}finally{o&&t?.removeEventListener("abort",o)}}}}async function B(e,r){let n=b(r);try{await e.unsafe(n.sql,n.parameters)}catch(t){console.error("Failed to cancel query:",t)}}async function O(e){let r=g();try{let[n]=await e.unsafe(r.sql,r.parameters);return n?.pid}catch(n){console.error("Failed to get connection PID:",n);return}}
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/postgresjs/index.ts", "../../../data/executor.ts", "../../../data/query.ts", "../../../data/postgres-core/utility.ts"],
  "sourcesContent": ["import type { ReservedSql, Sql } from \"postgres\";\n\nimport { type Executor, getAbortResult } from \"../executor\";\nimport { getCancelQuery, getPIDQuery } from \"../postgres-core/utility\";\nimport type { QueryResult } from \"../query\";\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(query.sql, query.parameters as never);\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>((resolve) => (aborted = resolve));\n\n        abortSignal.addEventListener(\"abort\", (abortListener = () => aborted()));\n\n        const connectionPromise = postgresjs.reserve();\n\n        const connectionResult = await Promise.race([connectionPromise, abortionPromise]);\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(query.sql, query.parameters as never);\n\n        const queryResult = await Promise.race([queryPromise, abortionPromise]);\n\n        if (!queryResult) {\n          void Promise.allSettled([cancelQuery(postgresjs, pidResult!), queryPromise]).finally(() =>\n            connection?.release(),\n          );\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}\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>>(query.sql, query.parameters as never);\n\n    return result?.pid;\n  } catch (error) {\n    console.error(\"Failed to get connection PID:\", error);\n\n    return undefined;\n  }\n}\n", "import type { Query, QueryResult } from \"./query\";\nimport type { Either } from \"./type-utils\";\n\nexport interface Executor {\n  execute<T>(query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;\n}\n\nexport interface SequenceExecutor extends Executor {\n  executeSequence<T, S>(\n    query: [Query<T>, Query<S>],\n    options?: ExecuteOptions,\n  ): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;\n}\n\nexport interface ExecuteOptions {\n  abortSignal?: AbortSignal;\n}\n\nexport class AbortError extends Error {\n  constructor() {\n    super(\"This operation was aborted\");\n    this.name = \"AbortError\";\n  }\n}\n\nexport function getAbortResult(): [AbortError] {\n  return [new AbortError()];\n}\n", "import {\n  type Compilable,\n  type DialectAdapter,\n  DummyDriver,\n  type Expression,\n  type ExpressionBuilder,\n  expressionBuilder,\n  type ExpressionWrapper,\n  type InsertObject,\n  Kysely,\n  type KyselyPlugin,\n  OperationNodeTransformer,\n  type PluginTransformQueryArgs,\n  type PluginTransformResultArgs,\n  type PrimitiveValueListNode,\n  type QueryCompiler,\n  type QueryResult as KyselyQueryResult,\n  type RootOperationNode,\n  sql,\n  type SqlBool,\n  type UnknownRow,\n  type UpdateObject,\n  ValueListNode,\n  ValueNode,\n  type WhereInterface,\n} from \"kysely\";\n\nimport type { Column, ColumnFilter, FilterGroup, Table } from \"./adapter\";\n\nexport interface BuilderRequirements {\n  Adapter: { new (): DialectAdapter };\n  noParameters?: boolean;\n  QueryCompiler: { new (): QueryCompiler };\n}\n\nexport function getBuilder<DB>(requirements: BuilderRequirements): Kysely<DB> {\n  return new Kysely({\n    dialect: {\n      createAdapter: () => new requirements.Adapter(),\n      createDriver: () => new DummyDriver(),\n      // @ts-expect-error - we don't need built-in introspection in this case\n      createIntrospector: () => null,\n      createQueryCompiler: () => new requirements.QueryCompiler(),\n    },\n    plugins: [...(requirements.noParameters ? [new ImmediateValuePlugin()] : [])],\n  });\n}\n\n/**\n * A plugin that transforms all values to immediate values. This means their injected into the SQL string instead of populating the parameters array.\n * In some situations, a database driver might not support parameters, and this plugin can be used to work around that.\n */\nclass ImmediateValuePlugin implements KyselyPlugin {\n  readonly #transformer = new ImmediateValueTransformer();\n\n  transformQuery(args: PluginTransformQueryArgs): RootOperationNode {\n    return this.#transformer.transformNode(args.node);\n  }\n\n  transformResult(args: PluginTransformResultArgs): Promise<KyselyQueryResult<UnknownRow>> {\n    return Promise.resolve(args.result);\n  }\n}\n\nclass ImmediateValueTransformer extends OperationNodeTransformer {\n  protected override transformPrimitiveValueList(node: PrimitiveValueListNode): PrimitiveValueListNode {\n    return ValueListNode.create(node.values.map(ValueNode.createImmediate)) as never;\n  }\n\n  override transformValue(node: ValueNode): ValueNode {\n    return { ...super.transformValue(node), immediate: true };\n  }\n}\n\ndeclare const queryType: unique symbol;\nexport interface Query<T = Record<string, unknown>> {\n  [queryType]?: T;\n  parameters: readonly unknown[];\n  sql: string;\n  transformations?: Partial<Record<keyof T, \"json-parse\">>;\n}\n\nexport function asQuery<T>(query: string | Query<unknown>): Query<T> {\n  if (typeof query === \"string\") {\n    return { parameters: [], sql: query } as never;\n  }\n\n  return query as never;\n}\n\nexport type QueryResult<T> =\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  T extends Query<infer R> ? R[] : T extends (...args: any[]) => Query<infer R> ? R[] : never;\n\nexport interface CompileOptions<T> {\n  /**\n   * A mapping of column names to transformations that should be applied to the result.\n   * Currently supported transformation is \"json-parse\", which parses a JSON string into an object.\n   */\n  transformations?: Partial<Record<keyof T, \"json-parse\">>;\n}\n\nexport function compile<T = Record<string, unknown>>(\n  compileable: Compilable<T>,\n  options?: CompileOptions<T>,\n): Query<T> {\n  const compiledQuery = compileable.compile();\n\n  return {\n    parameters: compiledQuery.parameters,\n    sql: compiledQuery.sql,\n    transformations: options?.transformations,\n  };\n}\n\n/**\n * Applies a filter to the given rows based on the primary key columns of the table.\n *\n * @example db.selectFrom(\"users\").$call(applyInferredRowFilters(rows, columns)).selectAll()\n */\nexport function applyInferredRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]) {\n  const rowFilters = inferRowFilters(rows, columns);\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return <QB extends WhereInterface<any, any>>(qb: QB): QB =>\n    qb.where((eb) => {\n      return eb.or(\n        rowFilters.map((rowFilter) => {\n          return eb.and(\n            rowFilter.map(([columnName, value]) =>\n              eb(columnName, value === null ? \"is\" : Array.isArray(value) ? \"in\" : \"=\", value),\n            ),\n          );\n        }),\n      );\n    }) as never;\n}\n\n/**\n * Part of a filter that predicts a match.\n * ie. ... WHERE $ColumName = $Value ...\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype RowFilterPredicate = [ColumnName: string | Expression<any>, Value: unknown];\n\n/**\n * A row filter is comprised of one or more predicates.\n */\ntype RowFilter = RowFilterPredicate[];\n\n/**\n * Row filters is simply a set of multiple {@link RowFilter}.\n */\ntype RowFilters = RowFilter[];\n\n/**\n * Infers the filter that is necessary to uniquely identify a given row\n * individually.\n */\nexport function inferFilterObject(row: Record<string, unknown>, columns: Table[\"columns\"]): Record<string, unknown> {\n  const filter: Record<string, unknown> = {};\n\n  for (const column of Object.values(columns)) {\n    const { isInPrimaryKey, name: columnName } = column;\n\n    if (!isInPrimaryKey) {\n      continue;\n    }\n\n    filter[columnName] = row[columnName] ?? null;\n  }\n\n  return filter;\n}\n\n/**\n * Infers the filter that is necessary to uniquely identify multiple rows\n * individually.\n *\n * Elegantly infers the best possible statement to filter with.\n * TODO: introspect primary key ordinal numbers so the tuple is in the correct order.\n * TODO: if we ever support MSSQL, we'll need to drop to dumb (... and ...) or (... and ...) like in the old way just for MSSQL.\n *\n * For single column primary key:\n *\n * 1. if only 1 row: col = value\n * 2. if multiple rows: col IN (value1, value2, ...)\n *\n * For composite primary key:\n *\n * 1. if only 1 row: (col1, col2, ...) = (value1, value2, ...)\n * 2. if multiple rows: (col1, col2, ...) IN ((value1a, value2a, ...), (value1b, value2b, ...), ...)\n */\nexport function inferRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]): RowFilters {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const refs: ExpressionWrapper<any, any, any>[] = [];\n  const values: unknown[] = [];\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const eb = expressionBuilder<any, any>();\n\n  for (const row of rows) {\n    const valuesForRow: unknown[] = [];\n\n    for (const column of Object.values(columns)) {\n      const { isInPrimaryKey, name: columnName } = column;\n\n      if (!isInPrimaryKey) {\n        continue;\n      }\n\n      if (row === rows.at(0)) {\n        refs.push(eb.ref(columnName));\n      }\n\n      valuesForRow.push(transformValue(row[columnName] ?? null, column));\n    }\n\n    values.push(refs.length === 1 ? valuesForRow.at(0)! : tupleFrom(valuesForRow));\n  }\n\n  const lhs = refs.length === 1 ? refs.at(0)! : tupleFrom(refs);\n  const rhs = values.length === 1 ? values.at(0)! : values;\n\n  return [[[lhs, rhs]]];\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction tupleFrom(items: unknown[]): Expression<any> {\n  return sql`(${sql.join(items, sql`, `)})`;\n}\n\nexport function applyTransformations<C extends \"insert\" | \"update\">(\n  _context: C,\n  values: C extends \"update\" ? Record<string, unknown> : Record<string, unknown> | Record<string, unknown>[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): C extends \"update\" ? () => UpdateObject<any, any> : () => InsertObject<any, any> | InsertObject<any, any>[] {\n  return () =>\n    Array.isArray(values) ? values.map((row) => transformValues(row, columns)) : transformValues(values, columns);\n}\n\nfunction transformValues(\n  values: Record<string, unknown>,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): InsertObject<any, any> | UpdateObject<any, any> {\n  if (Object.keys(values).length === 0) {\n    return { [Object.keys(columns).at(0)!]: sql`default` };\n  }\n\n  return Object.entries(values).reduce(\n    (obj, [key, value]) => ({ ...obj, [key]: transformValue(value, columns[key]!) }),\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    {} as InsertObject<any, any> | UpdateObject<any, any>,\n  );\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function transformValue(value: unknown, column: Column): ExpressionWrapper<any, any, any> {\n  const { datatype } = column;\n\n  const eb = expressionBuilder();\n\n  if (value === null) {\n    return eb.lit(null);\n  }\n\n  if (!datatype.isNative) {\n    return eb.cast(eb.val(value), sql.id(datatype.schema, datatype.name));\n  }\n\n  return eb.val(value);\n}\n\nexport function getSelectFilterExpression(\n  filters: (ColumnFilter | FilterGroup)[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (filters.length === 0) return (eb) => eb.lit(true); // no filters, always true\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const orGroupsOfAndBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[][] = [];\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  let currentAndGroupBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[] = [];\n\n  for (let i = 0; i < filters.length; i++) {\n    currentAndGroupBuilders.push(buildBaseExpressionBuilder(filters[i]!, columns));\n\n    // &n AND group ends if it's the last filter, or the item is followed by an 'or'\n    if (i === filters.length - 1 || filters[i]!.after === \"or\") {\n      orGroupsOfAndBuilders.push(currentAndGroupBuilders);\n      currentAndGroupBuilders = []; // start a new group\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return (eb: ExpressionBuilder<any, any>) => {\n    const andExpressions = orGroupsOfAndBuilders.map((group) => {\n      return eb.and(group.map((builder) => builder(eb)));\n    });\n\n    return eb.or(andExpressions);\n  };\n}\n\n// Helper to build an expression builder for a single filter or a group\nfunction buildBaseExpressionBuilder(\n  spec: ColumnFilter | FilterGroup,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (spec.kind === \"ColumnFilter\") {\n    return (eb) => {\n      const { column, operator, value } = spec;\n\n      const columnMeta = columns[column]!;\n\n      return eb(\n        columnMeta.datatype.group === \"raw\" ? eb.cast(column, \"text\") : column,\n        operator,\n        transformValue(value, columnMeta),\n      );\n    };\n  }\n\n  return getSelectFilterExpression(spec.filters, columns);\n}\n", "import { asQuery, type Query } from \"../query\";\n\nexport function getPIDQuery(): Query<{ pid: unknown }> {\n  return asQuery(\"select pg_backend_pid() as pid\");\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport function getCancelQuery(pid: {}): Query<unknown> {\n  return {\n    parameters: [pid],\n    sql: \"select pg_cancel_backend($1);\",\n  };\n}\n"],
  "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,8BAAAE,IAAA,eAAAC,EAAAH,GCkBO,IAAMI,EAAN,cAAyB,KAAM,CACpC,aAAc,CACZ,MAAM,4BAA4B,EAClC,KAAK,KAAO,YACd,CACF,EAEO,SAASC,GAA+B,CAC7C,MAAO,CAAC,IAAID,CAAY,CAC1B,CCuDO,SAASE,EAAWC,EAA0C,CACnE,OAAI,OAAOA,GAAU,SACZ,CAAE,WAAY,CAAC,EAAG,IAAKA,CAAM,EAG/BA,CACT,CCtFO,SAASC,GAAuC,CACrD,OAAOC,EAAQ,gCAAgC,CACjD,CAGO,SAASC,EAAeC,EAAyB,CACtD,MAAO,CACL,WAAY,CAACA,CAAG,EAChB,IAAK,+BACP,CACF,CHNO,SAASC,EAAyBC,EAA2B,CAClE,MAAO,CACL,QAAS,MAAOC,EAAOC,IAAY,CACjC,GAAM,CAAE,YAAAC,CAAY,EAAID,GAAW,CAAC,EAEpC,GAAI,CAACC,EACH,GAAI,CAGF,MAAO,CAAC,KAFO,MAAMH,EAAW,OAAOC,EAAM,IAAKA,EAAM,UAAmB,CAE9C,CAC/B,OAASG,EAAgB,CACvB,MAAO,CAACA,CAAc,CACxB,CAGF,GAAID,EAAY,QACd,OAAOE,EAAe,EAGxB,IAAIC,EACAC,EAEJ,GAAI,CACF,IAAIC,EACEC,EAAkB,IAAI,QAAeC,GAAaF,EAAUE,CAAQ,EAE1EP,EAAY,iBAAiB,QAAUG,EAAgB,IAAME,EAAQ,CAAE,EAEvE,IAAMG,EAAoBX,EAAW,QAAQ,EAEvCY,EAAmB,MAAM,QAAQ,KAAK,CAACD,EAAmBF,CAAe,CAAC,EAEhF,GAAI,CAACG,EACH,OAAKD,EAAkB,MAAM,IAAM,CAAC,CAAC,EAE9BN,EAAe,EAKxB,GAFAE,EAAaK,EAETT,EAAY,QACd,OAAAI,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMQ,EAAaC,EAAiBP,CAAU,EAExCQ,EAAY,MAAM,QAAQ,KAAK,CAACF,EAAYJ,CAAe,CAAC,EAElE,GAAIM,IAAc,OAChB,OAAKF,EAAW,MAAM,IAAM,CAAC,CAAC,EAAE,QAAQ,IAAMN,GAAY,QAAQ,CAAC,EAE5DF,EAAe,EAGxB,GAAIF,EAAY,QACd,OAAAI,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMW,EAAeT,EAAW,OAAON,EAAM,IAAKA,EAAM,UAAmB,EAErEgB,EAAc,MAAM,QAAQ,KAAK,CAACD,EAAcP,CAAe,CAAC,EAEtE,OAAKQ,GAQLV,EAAW,QAAQ,EAEZ,CAAC,KAAMU,CAAoB,IAT3B,QAAQ,WAAW,CAACC,EAAYlB,EAAYe,CAAU,EAAGC,CAAY,CAAC,EAAE,QAAQ,IACnFT,GAAY,QAAQ,CACtB,EAEOF,EAAe,EAM1B,OAASD,EAAgB,CACvB,OAAAG,GAAY,QAAQ,EAEb,CAACH,CAAc,CACxB,QAAE,CACIE,GACFH,GAAa,oBAAoB,QAASG,CAAa,CAE3D,CACF,CACF,CACF,CAGA,eAAeY,EAAYlB,EAAiBmB,EAAwB,CAClE,IAAMlB,EAAQmB,EAAeD,CAAG,EAEhC,GAAI,CACF,MAAMnB,EAAW,OAAOC,EAAM,IAAKA,EAAM,UAAmB,CAC9D,OAASG,EAAO,CACd,QAAQ,MAAM,0BAA2BA,CAAK,CAChD,CACF,CAEA,eAAeU,EAAiBP,EAA2C,CACzE,IAAMN,EAAQoB,EAAY,EAE1B,GAAI,CACF,GAAM,CAACC,CAAM,EAAI,MAAMf,EAAW,OAAkCN,EAAM,IAAKA,EAAM,UAAmB,EAExG,OAAOqB,GAAQ,GACjB,OAASlB,EAAO,CACd,QAAQ,MAAM,gCAAiCA,CAAK,EAEpD,MACF,CACF",
  "names": ["postgresjs_exports", "__export", "createPostgresJSExecutor", "__toCommonJS", "AbortError", "getAbortResult", "asQuery", "query", "getPIDQuery", "asQuery", "getCancelQuery", "pid", "createPostgresJSExecutor", "postgresjs", "query", "options", "abortSignal", "error", "getAbortResult", "abortListener", "connection", "aborted", "abortionPromise", "resolve", "connectionPromise", "connectionResult", "pidPromise", "getConnectionPID", "pidResult", "queryPromise", "queryResult", "cancelQuery", "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{b as s}from"../../chunk-
|
|
9
|
+
import{b as s}from"../../chunk-NQGSK3IM.js";import{a as p,b as P}from"../../chunk-M7E5UEO3.js";import"../../chunk-A6CVKSUD.js";import{e as v}from"../../chunk-GDQBQ7MK.js";v();function g(o){return{execute:async(e,t)=>{let{abortSignal:n}=t||{};if(!n)try{return[null,await o.unsafe(e.sql,e.parameters)]}catch(a){return[a]}if(n.aborted)return s();let i,r;try{let a,c=new Promise(q=>a=q);n.addEventListener("abort",i=()=>a());let u=o.reserve(),l=await Promise.race([u,c]);if(!l)return u.catch(()=>{}),s();if(r=l,n.aborted)return r.release(),s();let d=w(r),f=await Promise.race([d,c]);if(f===void 0)return d.catch(()=>{}).finally(()=>r?.release()),s();if(n.aborted)return r.release(),s();let m=r.unsafe(e.sql,e.parameters),y=await Promise.race([m,c]);return y?(r.release(),[null,y]):(Promise.allSettled([b(o,f),m]).finally(()=>r?.release()),s())}catch(a){return r?.release(),[a]}finally{i&&n?.removeEventListener("abort",i)}}}}async function b(o,e){let t=P(e);try{await o.unsafe(t.sql,t.parameters)}catch(n){console.error("Failed to cancel query:",n)}}async function w(o){let e=p();try{let[t]=await o.unsafe(e.sql,e.parameters);return t?.pid}catch(t){console.error("Failed to get connection PID:",t);return}}export{g as createPostgresJSExecutor};
|
|
10
10
|
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9wb3N0Z3Jlc2pzL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgdHlwZSB7IFJlc2VydmVkU3FsLCBTcWwgfSBmcm9tIFwicG9zdGdyZXNcIjtcblxuaW1wb3J0IHsgdHlwZSBFeGVjdXRvciwgZ2V0QWJvcnRSZXN1bHQgfSBmcm9tIFwiLi4vZXhlY3V0b3JcIjtcbmltcG9ydCB7IGdldENhbmNlbFF1ZXJ5LCBnZXRQSURRdWVyeSB9IGZyb20gXCIuLi9wb3N0Z3Jlcy1jb3JlL3V0aWxpdHlcIjtcbmltcG9ydCB0eXBlIHsgUXVlcnlSZXN1bHQgfSBmcm9tIFwiLi4vcXVlcnlcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVBvc3RncmVzSlNFeGVjdXRvcihwb3N0Z3Jlc2pzOiBTcWwpOiBFeGVjdXRvciB7XG4gIHJldHVybiB7XG4gICAgZXhlY3V0ZTogYXN5bmMgKHF1ZXJ5LCBvcHRpb25zKSA9PiB7XG4gICAgICBjb25zdCB7IGFib3J0U2lnbmFsIH0gPSBvcHRpb25zIHx8IHt9O1xuXG4gICAgICBpZiAoIWFib3J0U2lnbmFsKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgcG9zdGdyZXNqcy51bnNhZmUocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzIGFzIG5ldmVyKTtcblxuICAgICAgICAgIHJldHVybiBbbnVsbCwgcmVzdWx0IGFzIG5ldmVyXTtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3I6IHVua25vd24pIHtcbiAgICAgICAgICByZXR1cm4gW2Vycm9yIGFzIEVycm9yXTtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoYWJvcnRTaWduYWwuYWJvcnRlZCkge1xuICAgICAgICByZXR1cm4gZ2V0QWJvcnRSZXN1bHQoKTtcbiAgICAgIH1cblxuICAgICAgbGV0IGFib3J0TGlzdGVuZXI6ICgoKSA9PiB2b2lkKSB8IHVuZGVmaW5lZDtcbiAgICAgIGxldCBjb25uZWN0aW9uOiBSZXNlcnZlZFNxbCB8IHVuZGVmaW5lZDtcblxuICAgICAgdHJ5IHtcbiAgICAgICAgbGV0IGFib3J0ZWQ6ICgpID0+IHZvaWQ7XG4gICAgICAgIGNvbnN0IGFib3J0aW9uUHJvbWlzZSA9IG5ldyBQcm9taXNlPHZvaWQ+KChyZXNvbHZlKSA9PiAoYWJvcnRlZCA9IHJlc29sdmUpKTtcblxuICAgICAgICBhYm9ydFNpZ25hbC5hZGRFdmVudExpc3RlbmVyKFwiYWJvcnRcIiwgKGFib3J0TGlzdGVuZXIgPSAoKSA9PiBhYm9ydGVkKCkpKTtcblxuICAgICAgICBjb25zdCBjb25uZWN0aW9uUHJvbWlzZSA9IHBvc3RncmVzanMucmVzZXJ2ZSgpO1xuXG4gICAgICAgIGNvbnN0IGNvbm5lY3Rpb25SZXN1bHQgPSBhd2FpdCBQcm9taXNlLnJhY2UoW2Nvbm5lY3Rpb25Qcm9taXNlLCBhYm9ydGlvblByb21pc2VdKTtcblxuICAgICAgICBpZiAoIWNvbm5lY3Rpb25SZXN1bHQpIHtcbiAgICAgICAgICB2b2lkIGNvbm5lY3Rpb25Qcm9taXNlLmNhdGNoKCgpID0+IHt9KTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29ubmVjdGlvbiA9IGNvbm5lY3Rpb25SZXN1bHQ7XG5cbiAgICAgICAgaWYgKGFib3J0U2lnbmFsLmFib3J0ZWQpIHtcbiAgICAgICAgICBjb25uZWN0aW9uLnJlbGVhc2UoKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcGlkUHJvbWlzZSA9IGdldENvbm5lY3Rpb25QSUQoY29ubmVjdGlvbik7XG5cbiAgICAgICAgY29uc3QgcGlkUmVzdWx0ID0gYXdhaXQgUHJvbWlzZS5yYWNlKFtwaWRQcm9taXNlLCBhYm9ydGlvblByb21pc2VdKTtcblxuICAgICAgICBpZiAocGlkUmVzdWx0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICB2b2lkIHBpZFByb21pc2UuY2F0Y2goKCkgPT4ge30pLmZpbmFsbHkoKCkgPT4gY29ubmVjdGlvbj8ucmVsZWFzZSgpKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGFib3J0U2lnbmFsLmFib3J0ZWQpIHtcbiAgICAgICAgICBjb25uZWN0aW9uLnJlbGVhc2UoKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcXVlcnlQcm9taXNlID0gY29ubmVjdGlvbi51bnNhZmUocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzIGFzIG5ldmVyKTtcblxuICAgICAgICBjb25zdCBxdWVyeVJlc3VsdCA9IGF3YWl0IFByb21pc2UucmFjZShbcXVlcnlQcm9taXNlLCBhYm9ydGlvblByb21pc2VdKTtcblxuICAgICAgICBpZiAoIXF1ZXJ5UmVzdWx0KSB7XG4gICAgICAgICAgdm9pZCBQcm9taXNlLmFsbFNldHRsZWQoW2NhbmNlbFF1ZXJ5KHBvc3RncmVzanMsIHBpZFJlc3VsdCEpLCBxdWVyeVByb21pc2VdKS5maW5hbGx5KCgpID0+XG4gICAgICAgICAgICBjb25uZWN0aW9uPy5yZWxlYXNlKCksXG4gICAgICAgICAgKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29ubmVjdGlvbi5yZWxlYXNlKCk7XG5cbiAgICAgICAgcmV0dXJuIFtudWxsLCBxdWVyeVJlc3VsdCBhcyBuZXZlcl07XG4gICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICBjb25uZWN0aW9uPy5yZWxlYXNlKCk7XG5cbiAgICAgICAgcmV0dXJuIFtlcnJvciBhcyBFcnJvcl07XG4gICAgICB9IGZpbmFsbHkge1xuICAgICAgICBpZiAoYWJvcnRMaXN0ZW5lcikge1xuICAgICAgICAgIGFib3J0U2lnbmFsPy5yZW1vdmVFdmVudExpc3RlbmVyKFwiYWJvcnRcIiwgYWJvcnRMaXN0ZW5lcik7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICB9O1xufVxuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWVtcHR5LW9iamVjdC10eXBlXG5hc3luYyBmdW5jdGlvbiBjYW5jZWxRdWVyeShwb3N0Z3Jlc2pzOiBTcWwsIHBpZDoge30pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgcXVlcnkgPSBnZXRDYW5jZWxRdWVyeShwaWQpO1xuXG4gIHRyeSB7XG4gICAgYXdhaXQgcG9zdGdyZXNqcy51bnNhZmUocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzIGFzIG5ldmVyKTtcbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICBjb25zb2xlLmVycm9yKFwiRmFpbGVkIHRvIGNhbmNlbCBxdWVyeTpcIiwgZXJyb3IpO1xuICB9XG59XG5cbmFzeW5jIGZ1bmN0aW9uIGdldENvbm5lY3Rpb25QSUQoY29ubmVjdGlvbjogUmVzZXJ2ZWRTcWwpOiBQcm9taXNlPHVua25vd24+IHtcbiAgY29uc3QgcXVlcnkgPSBnZXRQSURRdWVyeSgpO1xuXG4gIHRyeSB7XG4gICAgY29uc3QgW3Jlc3VsdF0gPSBhd2FpdCBjb25uZWN0aW9uLnVuc2FmZTxRdWVyeVJlc3VsdDx0eXBlb2YgcXVlcnk+PihxdWVyeS5zcWwsIHF1ZXJ5LnBhcmFtZXRlcnMgYXMgbmV2ZXIpO1xuXG4gICAgcmV0dXJuIHJlc3VsdD8ucGlkO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGNvbnNvbGUuZXJyb3IoXCJGYWlsZWQgdG8gZ2V0IGNvbm5lY3Rpb24gUElEOlwiLCBlcnJvcik7XG5cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7OzsyS0FBQUEsSUFNTyxTQUFTQyxFQUF5QkMsRUFBMkIsQ0FDbEUsTUFBTyxDQUNMLFFBQVMsTUFBT0MsRUFBT0MsSUFBWSxDQUNqQyxHQUFNLENBQUUsWUFBQUMsQ0FBWSxFQUFJRCxHQUFXLENBQUMsRUFFcEMsR0FBSSxDQUFDQyxFQUNILEdBQUksQ0FHRixNQUFPLENBQUMsS0FGTyxNQUFNSCxFQUFXLE9BQU9DLEVBQU0sSUFBS0EsRUFBTSxVQUFtQixDQUU5QyxDQUMvQixPQUFTRyxFQUFnQixDQUN2QixNQUFPLENBQUNBLENBQWMsQ0FDeEIsQ0FHRixHQUFJRCxFQUFZLFFBQ2QsT0FBT0UsRUFBZSxFQUd4QixJQUFJQyxFQUNBQyxFQUVKLEdBQUksQ0FDRixJQUFJQyxFQUNFQyxFQUFrQixJQUFJLFFBQWVDLEdBQWFGLEVBQVVFLENBQVEsRUFFMUVQLEVBQVksaUJBQWlCLFFBQVVHLEVBQWdCLElBQU1FLEVBQVEsQ0FBRSxFQUV2RSxJQUFNRyxFQUFvQlgsRUFBVyxRQUFRLEVBRXZDWSxFQUFtQixNQUFNLFFBQVEsS0FBSyxDQUFDRCxFQUFtQkYsQ0FBZSxDQUFDLEVBRWhGLEdBQUksQ0FBQ0csRUFDSCxPQUFLRCxFQUFrQixNQUFNLElBQU0sQ0FBQyxDQUFDLEVBRTlCTixFQUFlLEVBS3hCLEdBRkFFLEVBQWFLLEVBRVRULEVBQVksUUFDZCxPQUFBSSxFQUFXLFFBQVEsRUFFWkYsRUFBZSxFQUd4QixJQUFNUSxFQUFhQyxFQUFpQlAsQ0FBVSxFQUV4Q1EsRUFBWSxNQUFNLFFBQVEsS0FBSyxDQUFDRixFQUFZSixDQUFlLENBQUMsRUFFbEUsR0FBSU0sSUFBYyxPQUNoQixPQUFLRixFQUFXLE1BQU0sSUFBTSxDQUFDLENBQUMsRUFBRSxRQUFRLElBQU1OLEdBQVksUUFBUSxDQUFDLEVBRTVERixFQUFlLEVBR3hCLEdBQUlGLEVBQVksUUFDZCxPQUFBSSxFQUFXLFFBQVEsRUFFWkYsRUFBZSxFQUd4QixJQUFNVyxFQUFlVCxFQUFXLE9BQU9OLEVBQU0sSUFBS0EsRUFBTSxVQUFtQixFQUVyRWdCLEVBQWMsTUFBTSxRQUFRLEtBQUssQ0FBQ0QsRUFBY1AsQ0FBZSxDQUFDLEVBRXRFLE9BQUtRLEdBUUxWLEVBQVcsUUFBUSxFQUVaLENBQUMsS0FBTVUsQ0FBb0IsSUFUM0IsUUFBUSxXQUFXLENBQUNDLEVBQVlsQixFQUFZZSxDQUFVLEVBQUdDLENBQVksQ0FBQyxFQUFFLFFBQVEsSUFDbkZULEdBQVksUUFBUSxDQUN0QixFQUVPRixFQUFlLEVBTTFCLE9BQVNELEVBQWdCLENBQ3ZCLE9BQUFHLEdBQVksUUFBUSxFQUViLENBQUNILENBQWMsQ0FDeEIsUUFBRSxDQUNJRSxHQUNGSCxHQUFhLG9CQUFvQixRQUFTRyxDQUFhLENBRTNELENBQ0YsQ0FDRixDQUNGLENBR0EsZUFBZVksRUFBWWxCLEVBQWlCbUIsRUFBd0IsQ0FDbEUsSUFBTWxCLEVBQVFtQixFQUFlRCxDQUFHLEVBRWhDLEdBQUksQ0FDRixNQUFNbkIsRUFBVyxPQUFPQyxFQUFNLElBQUtBLEVBQU0sVUFBbUIsQ0FDOUQsT0FBU0csRUFBTyxDQUNkLFFBQVEsTUFBTSwwQkFBMkJBLENBQUssQ0FDaEQsQ0FDRixDQUVBLGVBQWVVLEVBQWlCUCxFQUEyQyxDQUN6RSxJQUFNTixFQUFRb0IsRUFBWSxFQUUxQixHQUFJLENBQ0YsR0FBTSxDQUFDQyxDQUFNLEVBQUksTUFBTWYsRUFBVyxPQUFrQ04sRUFBTSxJQUFLQSxFQUFNLFVBQW1CLEVBRXhHLE9BQU9xQixHQUFRLEdBQ2pCLE9BQVNsQixFQUFPLENBQ2QsUUFBUSxNQUFNLGdDQUFpQ0EsQ0FBSyxFQUVwRCxNQUNGLENBQ0YiLAogICJuYW1lcyI6IFsiaW5pdF9kZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVIiLCAiY3JlYXRlUG9zdGdyZXNKU0V4ZWN1dG9yIiwgInBvc3RncmVzanMiLCAicXVlcnkiLCAib3B0aW9ucyIsICJhYm9ydFNpZ25hbCIsICJlcnJvciIsICJnZXRBYm9ydFJlc3VsdCIsICJhYm9ydExpc3RlbmVyIiwgImNvbm5lY3Rpb24iLCAiYWJvcnRlZCIsICJhYm9ydGlvblByb21pc2UiLCAicmVzb2x2ZSIsICJjb25uZWN0aW9uUHJvbWlzZSIsICJjb25uZWN0aW9uUmVzdWx0IiwgInBpZFByb21pc2UiLCAiZ2V0Q29ubmVjdGlvblBJRCIsICJwaWRSZXN1bHQiLCAicXVlcnlQcm9taXNlIiwgInF1ZXJ5UmVzdWx0IiwgImNhbmNlbFF1ZXJ5IiwgInBpZCIsICJnZXRDYW5jZWxRdWVyeSIsICJnZXRQSURRdWVyeSIsICJyZXN1bHQiXQp9Cg==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { RawResponse, AccelerateHttpClient } from '../accelerate/index.cjs';
|
|
2
2
|
export { DeserializedResponse, QueryIntrospectionBuiltinType, deserializeRawResult } from '../accelerate/index.cjs';
|
|
3
|
-
import '../../index-
|
|
3
|
+
import '../../index-CV9DQF9a.cjs';
|
|
4
4
|
import 'kysely';
|
|
5
5
|
|
|
6
6
|
interface PrismaPostgresHttpClientParams {
|
package/dist/data/ppg/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { RawResponse, AccelerateHttpClient } from '../accelerate/index.js';
|
|
2
2
|
export { DeserializedResponse, QueryIntrospectionBuiltinType, deserializeRawResult } from '../accelerate/index.js';
|
|
3
|
-
import '../../index-
|
|
3
|
+
import '../../index-CV9DQF9a.js';
|
|
4
4
|
import 'kysely';
|
|
5
5
|
|
|
6
6
|
interface PrismaPostgresHttpClientParams {
|