@prisma/studio-core 0.12.0 → 0.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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{e as r}from"./chunk-GDQBQ7MK.js";r();function i(t){let{error:n,query:a}=t,e=n;return e.query=a,[e]}export{i as a};
9
+ import{e as r}from"./chunk-GGFIWHFO.js";r();function i(t){let{error:n,query:a}=t,e=n;return e.query=a,[e]}export{i as a};
10
10
  //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/adapter.ts"],
  "sourcesContent": ["import type { Executor } from \"./executor\";\nimport type { Query } from \"./query\";\nimport type { BigIntString, Either, NumericString } from \"./type-utils\";\n\nexport interface AdapterRequirements {\n  executor: Executor;\n  noParameters?: boolean;\n}\n\nexport interface Adapter {\n  /**\n   * The schema studio will choose by default.\n   *\n   * e.g. `public` for PostgreSQL\n   */\n  readonly defaultSchema?: string;\n\n  /**\n   * Introspects the database and returns structured information about the schemas, tables, etc.\n   *\n   * @param options - Options for the introspection request.\n   */\n  introspect(options: AdapterIntrospectOptions): Promise<Either<AdapterError, AdapterIntrospectResult>>;\n\n  /**\n   * Executes a structured query against the database.\n   */\n  query(details: AdapterQueryDetails, options: AdapterQueryOptions): Promise<Either<AdapterError, AdapterQueryResult>>;\n\n  /**\n   * Inserts a single row into the database.\n   */\n  insert(\n    details: AdapterInsertDetails,\n    options: AdapterInsertOptions,\n  ): Promise<Either<AdapterError, AdapterInsertResult>>;\n\n  /**\n   * Updates a given row in the database with given changes.\n   */\n  update(\n    details: AdapterUpdateDetails,\n    options: AdapterUpdateOptions,\n  ): Promise<Either<AdapterError, AdapterUpdateResult>>;\n\n  /**\n   * Deletes given rows from the database.\n   */\n  delete(\n    details: AdapterDeleteDetails,\n    options: AdapterDeleteOptions,\n  ): Promise<Either<AdapterError, AdapterDeleteResult>>;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterIntrospectOptions extends AdapterBaseOptions {}\n\nexport interface AdapterQueryOptions extends AdapterBaseOptions {\n  abortSignal: AbortSignal;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterInsertOptions extends AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterUpdateOptions extends AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterDeleteOptions extends AdapterBaseOptions {}\n\ntype SchemaName = string;\n\nexport interface AdapterIntrospectResult {\n  schemas: Record<SchemaName, Schema>;\n  timezone: string;\n  filterOperators: FilterOperator[];\n  query: Query;\n}\n\ntype TableName = string;\n\nexport interface Schema {\n  name: string;\n  tables: Record<TableName, Table>;\n}\n\ntype ColumnName = string;\n\nexport interface Table {\n  columns: Record<ColumnName, Column>;\n  name: TableName;\n  schema: SchemaName;\n}\n\nexport interface Column {\n  datatype: DataType;\n  defaultValue:\n    | \"CURRENT_DATE\"\n    | \"CURRENT_TIME\"\n    | \"CURRENT_TIMESTAMP\"\n    | \"datetime('now')\" // sqlite\n    | \"gen_random_uuid()\" // postgres uuid\n    | \"json_array()\" // mysql empty json array\n    | `nextval(${string})` // postgres serial/autoinc\n    | `now()`\n    | \"uuid_to_bin(uuid())\" // mysql binary uuid\n    | \"uuid()\" // mysql uuid\n    | (string & {})\n    | null;\n  fkColumn: ColumnName | null;\n  fkSchema: SchemaName | null;\n  fkTable: TableName | null;\n  isAutoincrement: boolean;\n  isComputed: boolean;\n  isRequired: boolean;\n  name: ColumnName;\n  nullable: boolean;\n  pkPosition: number | null;\n  schema: SchemaName;\n  table: TableName;\n}\n\nexport interface DataType {\n  /**\n   * The database-specific affinity/type.\n   *\n   * e.g. in SQLite, datatypes can be anything. They are reduced to affinity via string matching rules.\n   *\n   * {@link https://sqlite.org/datatype3.html#determination_of_column_affinity}\n   */\n  affinity?: string;\n\n  /**\n   * The database-specific format for the datatype.\n   */\n  format?: string;\n\n  /**\n   * A simplification/normalization for UI usage.\n   *\n   * e.g. varchar and char are strings.\n   */\n  group: DataTypeGroup;\n\n  /**\n   * Is this a native array type?\n   */\n  isArray: boolean;\n\n  /**\n   * Is a native database datatype or a user-defined datatype?\n   *\n   * e.g. PostgreSQL enums are user-defined datatypes, but `int4` is a native datatype.\n   */\n  isNative: boolean;\n\n  /**\n   * Will be displayed as-is.\n   */\n  name: string;\n\n  /**\n   * Enum values for enum types.\n   */\n  options: string[];\n\n  /**\n   * The schema the datatype belongs to.\n   */\n  schema: string;\n}\n\nexport type DataTypeGroup = \"string\" | \"datetime\" | \"boolean\" | \"enum\" | \"time\" | \"raw\" | \"numeric\" | \"json\";\n\nexport interface AdapterQueryDetails {\n  /**\n   * Zero-based index of the page to fetch.\n   */\n  pageIndex: number;\n\n  /**\n   * Maximum number of rows to fetch from the database.\n   */\n  pageSize: number;\n\n  /**\n   * Sort order for the query.\n   */\n  sortOrder: SortOrderItem[];\n\n  /**\n   * The table to select from.\n   */\n  table: Table;\n\n  /**\n   * The filter to be applied.\n   */\n  filter?: FilterGroup;\n}\n\nexport type FilterOperator =\n  | \"=\"\n  | \"!=\"\n  | \">\"\n  | \">=\"\n  | \"<\"\n  | \"<=\"\n  | \"is\"\n  | \"is not\"\n  | \"like\"\n  | \"not like\"\n  | \"ilike\"\n  | \"not ilike\";\n\nexport interface ColumnFilter {\n  kind: \"ColumnFilter\";\n  column: string;\n  operator: FilterOperator;\n  value: unknown;\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface FilterGroup {\n  kind: \"FilterGroup\";\n  filters: (ColumnFilter | FilterGroup)[];\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface SortOrderItem {\n  /**\n   * The column to sort by.\n   */\n  column: ColumnName;\n\n  /**\n   * The direction to sort the column by.\n   */\n  direction: SortDirection;\n}\n\nexport type SortDirection = \"asc\" | \"desc\";\n\nexport class AdapterError extends Error {\n  query?: Query<unknown>;\n}\n\nexport interface AdapterQueryResult {\n  /**\n   * The total number of rows the query would return if not limited.\n   *\n   * If the database does not support counting rows, this should be set to `Infinity`.\n   */\n  filteredRowCount: number | bigint | NumericString | BigIntString;\n\n  /**\n   * The rows returned by the query.\n   */\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterInsertDetails {\n  /**\n   * The table to insert into.\n   */\n  table: Table;\n\n  /**\n   * The values to insert into the table.\n   * - The keys should match the column names in the table.\n   * - The values should be the values to insert into the table.\n   */\n  rows: Record<string, unknown>[];\n}\n\nexport interface AdapterInsertResult {\n  /**\n   * The freshly inserted row data.\n   */\n  rows: Record<string, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query<unknown>;\n}\n\nexport interface AdapterUpdateDetails {\n  /**\n   * Changes to apply to the row.\n   */\n  changes: Record<ColumnName, unknown>;\n\n  /**\n   * The row to update.\n   */\n  row: Record<ColumnName, unknown>;\n\n  /**\n   * The table to update in.\n   */\n  table: Table;\n}\n\nexport interface AdapterUpdateResult {\n  /**\n   * The updated row data.\n   */\n  row: Record<ColumnName, unknown> & {\n    /**\n     * When the changes were applied in database time.\n     */\n    __ps_updated_at__: string | number | Date;\n  };\n\n  // TODO: turn this into a list.\n  /**\n   * The executed query string.\n   */\n  query: Query<unknown>;\n}\n\nexport interface AdapterDeleteDetails {\n  /**\n   * The rows to delete.\n   */\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The table to delete from.\n   */\n  table: Table;\n}\n\nexport interface AdapterDeleteResult {\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query<unknown>;\n}\n\nexport function createAdapterError(args: { error: Error; query?: Query<unknown> }) {\n  const { error, query } = args;\n\n  const adapterError = error as AdapterError;\n\n  adapterError.query = query;\n\n  return [adapterError] as [AdapterError];\n}\n"],
  "mappings": ";;;;;;;;wCAAAA,IAiWO,SAASC,EAAmBC,EAAgD,CACjF,GAAM,CAAE,MAAAC,EAAO,MAAAC,CAAM,EAAIF,EAEnBG,EAAeF,EAErB,OAAAE,EAAa,MAAQD,EAEd,CAACC,CAAY,CACtB",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "createAdapterError", "args", "error", "query", "adapterError"]
}

@@ -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{i as l,j as u,k as f,l as m,m as t,n as p,o as i}from"./chunk-V6UBAFT2.js";import{e as a}from"./chunk-GDQBQ7MK.js";a();function I(o,r){let n=[];for(let{selection:e}of o.selections??[])if(t.is(e)&&m.is(e.column))n.push(s(e.column.column.name),c(r,e.column.column.name));else if(m.is(e))n.push(s(e.column.name),c(r,e.column.name));else if(u.is(e)&&l.is(e.alias))n.push(s(e.alias.name),c(r,e.alias.name));else throw new Error("can't extract column names from the select query node");return n}function s(o){return new i(p.createImmediate(o))}function c(o,r){return new i(t.create(m.create(r),f.create(o)))}export{I as a};
9
+ import{i as l,j as u,k as f,l as m,m as t,n as p,o as i}from"./chunk-UHDZB3FI.js";import{e as a}from"./chunk-GGFIWHFO.js";a();function I(o,r){let n=[];for(let{selection:e}of o.selections??[])if(t.is(e)&&m.is(e.column))n.push(s(e.column.column.name),c(r,e.column.column.name));else if(m.is(e))n.push(s(e.column.name),c(r,e.column.name));else if(u.is(e)&&l.is(e.alias))n.push(s(e.alias.name),c(r,e.alias.name));else throw new Error("can't extract column names from the select query node");return n}function s(o){return new i(p.createImmediate(o))}function c(o,r){return new i(t.create(m.create(r),f.create(o)))}export{I as a};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vbm9kZV9tb2R1bGVzLy5wbnBtL2t5c2VseUAwLjI4Ljgvbm9kZV9tb2R1bGVzL2t5c2VseS9kaXN0L2VzbS91dGlsL2pzb24tb2JqZWN0LWFyZ3MuanMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8vLyA8cmVmZXJlbmNlIHR5cGVzPVwiLi9qc29uLW9iamVjdC1hcmdzLmQudHNcIiAvPlxuaW1wb3J0IHsgRXhwcmVzc2lvbldyYXBwZXIgfSBmcm9tICcuLi9leHByZXNzaW9uL2V4cHJlc3Npb24td3JhcHBlci5qcyc7XG5pbXBvcnQgeyBBbGlhc05vZGUgfSBmcm9tICcuLi9vcGVyYXRpb24tbm9kZS9hbGlhcy1ub2RlLmpzJztcbmltcG9ydCB7IENvbHVtbk5vZGUgfSBmcm9tICcuLi9vcGVyYXRpb24tbm9kZS9jb2x1bW4tbm9kZS5qcyc7XG5pbXBvcnQgeyBJZGVudGlmaWVyTm9kZSB9IGZyb20gJy4uL29wZXJhdGlvbi1ub2RlL2lkZW50aWZpZXItbm9kZS5qcyc7XG5pbXBvcnQgeyBSZWZlcmVuY2VOb2RlIH0gZnJvbSAnLi4vb3BlcmF0aW9uLW5vZGUvcmVmZXJlbmNlLW5vZGUuanMnO1xuaW1wb3J0IHsgVGFibGVOb2RlIH0gZnJvbSAnLi4vb3BlcmF0aW9uLW5vZGUvdGFibGUtbm9kZS5qcyc7XG5pbXBvcnQgeyBWYWx1ZU5vZGUgfSBmcm9tICcuLi9vcGVyYXRpb24tbm9kZS92YWx1ZS1ub2RlLmpzJztcbmV4cG9ydCBmdW5jdGlvbiBnZXRKc29uT2JqZWN0QXJncyhub2RlLCB0YWJsZSkge1xuICAgIGNvbnN0IGFyZ3MgPSBbXTtcbiAgICBmb3IgKGNvbnN0IHsgc2VsZWN0aW9uOiBzIH0gb2Ygbm9kZS5zZWxlY3Rpb25zID8/IFtdKSB7XG4gICAgICAgIGlmIChSZWZlcmVuY2VOb2RlLmlzKHMpICYmIENvbHVtbk5vZGUuaXMocy5jb2x1bW4pKSB7XG4gICAgICAgICAgICBhcmdzLnB1c2goY29sTmFtZShzLmNvbHVtbi5jb2x1bW4ubmFtZSksIGNvbFJlZih0YWJsZSwgcy5jb2x1bW4uY29sdW1uLm5hbWUpKTtcbiAgICAgICAgfVxuICAgICAgICBlbHNlIGlmIChDb2x1bW5Ob2RlLmlzKHMpKSB7XG4gICAgICAgICAgICBhcmdzLnB1c2goY29sTmFtZShzLmNvbHVtbi5uYW1lKSwgY29sUmVmKHRhYmxlLCBzLmNvbHVtbi5uYW1lKSk7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSBpZiAoQWxpYXNOb2RlLmlzKHMpICYmIElkZW50aWZpZXJOb2RlLmlzKHMuYWxpYXMpKSB7XG4gICAgICAgICAgICBhcmdzLnB1c2goY29sTmFtZShzLmFsaWFzLm5hbWUpLCBjb2xSZWYodGFibGUsIHMuYWxpYXMubmFtZSkpO1xuICAgICAgICB9XG4gICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBjYW4ndCBleHRyYWN0IGNvbHVtbiBuYW1lcyBmcm9tIHRoZSBzZWxlY3QgcXVlcnkgbm9kZWApO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBhcmdzO1xufVxuZnVuY3Rpb24gY29sTmFtZShjb2wpIHtcbiAgICByZXR1cm4gbmV3IEV4cHJlc3Npb25XcmFwcGVyKFZhbHVlTm9kZS5jcmVhdGVJbW1lZGlhdGUoY29sKSk7XG59XG5mdW5jdGlvbiBjb2xSZWYodGFibGUsIGNvbCkge1xuICAgIHJldHVybiBuZXcgRXhwcmVzc2lvbldyYXBwZXIoUmVmZXJlbmNlTm9kZS5jcmVhdGUoQ29sdW1uTm9kZS5jcmVhdGUoY29sKSwgVGFibGVOb2RlLmNyZWF0ZSh0YWJsZSkpKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7OzBIQUFBQSxJQVFPLFNBQVNDLEVBQWtCQyxFQUFNQyxFQUFPLENBQzNDLElBQU1DLEVBQU8sQ0FBQyxFQUNkLE9BQVcsQ0FBRSxVQUFXQyxDQUFFLElBQUtILEVBQUssWUFBYyxDQUFDLEVBQy9DLEdBQUlJLEVBQWMsR0FBR0QsQ0FBQyxHQUFLRSxFQUFXLEdBQUdGLEVBQUUsTUFBTSxFQUM3Q0QsRUFBSyxLQUFLSSxFQUFRSCxFQUFFLE9BQU8sT0FBTyxJQUFJLEVBQUdJLEVBQU9OLEVBQU9FLEVBQUUsT0FBTyxPQUFPLElBQUksQ0FBQyxVQUV2RUUsRUFBVyxHQUFHRixDQUFDLEVBQ3BCRCxFQUFLLEtBQUtJLEVBQVFILEVBQUUsT0FBTyxJQUFJLEVBQUdJLEVBQU9OLEVBQU9FLEVBQUUsT0FBTyxJQUFJLENBQUMsVUFFekRLLEVBQVUsR0FBR0wsQ0FBQyxHQUFLTSxFQUFlLEdBQUdOLEVBQUUsS0FBSyxFQUNqREQsRUFBSyxLQUFLSSxFQUFRSCxFQUFFLE1BQU0sSUFBSSxFQUFHSSxFQUFPTixFQUFPRSxFQUFFLE1BQU0sSUFBSSxDQUFDLE1BRzVELE9BQU0sSUFBSSxNQUFNLHVEQUF1RCxFQUcvRSxPQUFPRCxDQUNYLENBQ0EsU0FBU0ksRUFBUUksRUFBSyxDQUNsQixPQUFPLElBQUlDLEVBQWtCQyxFQUFVLGdCQUFnQkYsQ0FBRyxDQUFDLENBQy9ELENBQ0EsU0FBU0gsRUFBT04sRUFBT1MsRUFBSyxDQUN4QixPQUFPLElBQUlDLEVBQWtCUCxFQUFjLE9BQU9DLEVBQVcsT0FBT0ssQ0FBRyxFQUFHRyxFQUFVLE9BQU9aLENBQUssQ0FBQyxDQUFDLENBQ3RHIiwKICAibmFtZXMiOiBbImluaXRfZGVmaW5lX0FDQ0VMRVJBVEVfU0NIRU1BX0JZX1BST1ZJREVSIiwgImdldEpzb25PYmplY3RBcmdzIiwgIm5vZGUiLCAidGFibGUiLCAiYXJncyIsICJzIiwgIlJlZmVyZW5jZU5vZGUiLCAiQ29sdW1uTm9kZSIsICJjb2xOYW1lIiwgImNvbFJlZiIsICJBbGlhc05vZGUiLCAiSWRlbnRpZmllck5vZGUiLCAiY29sIiwgIkV4cHJlc3Npb25XcmFwcGVyIiwgIlZhbHVlTm9kZSIsICJUYWJsZU5vZGUiXQp9Cg==
@@ -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{e as r}from"./chunk-GDQBQ7MK.js";r();var e=class extends Error{constructor(){super("This operation was aborted"),this.name="AbortError"}};function u(){return[new e]}export{e as a,u as b};
9
+ import{e as r}from"./chunk-GGFIWHFO.js";r();var e=class extends Error{constructor(){super("This operation was aborted"),this.name="AbortError"}};function u(){return[new e]}export{e as a,u as b};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vZGF0YS9leGVjdXRvci50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHR5cGUgeyBRdWVyeSwgUXVlcnlSZXN1bHQgfSBmcm9tIFwiLi9xdWVyeVwiO1xuaW1wb3J0IHR5cGUgeyBFaXRoZXIgfSBmcm9tIFwiLi90eXBlLXV0aWxzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRXhlY3V0b3Ige1xuICBleGVjdXRlPFQ+KHF1ZXJ5OiBRdWVyeTxUPiwgb3B0aW9ucz86IEV4ZWN1dGVPcHRpb25zKTogUHJvbWlzZTxFaXRoZXI8RXJyb3IsIFF1ZXJ5UmVzdWx0PFF1ZXJ5PFQ+Pj4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNlcXVlbmNlRXhlY3V0b3IgZXh0ZW5kcyBFeGVjdXRvciB7XG4gIGV4ZWN1dGVTZXF1ZW5jZTxULCBTPihcbiAgICBzZXF1ZW5jZTogcmVhZG9ubHkgW1F1ZXJ5PFQ+LCBRdWVyeTxTPl0sXG4gICAgb3B0aW9ucz86IEV4ZWN1dGVPcHRpb25zLFxuICApOiBQcm9taXNlPFtbRXJyb3JdXSB8IFtbbnVsbCwgUXVlcnlSZXN1bHQ8UXVlcnk8VD4+XSwgRWl0aGVyPEVycm9yLCBRdWVyeVJlc3VsdDxRdWVyeTxTPj4+XT47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRXhlY3V0ZU9wdGlvbnMge1xuICBhYm9ydFNpZ25hbD86IEFib3J0U2lnbmFsO1xufVxuXG5leHBvcnQgY2xhc3MgQWJvcnRFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoXCJUaGlzIG9wZXJhdGlvbiB3YXMgYWJvcnRlZFwiKTtcbiAgICB0aGlzLm5hbWUgPSBcIkFib3J0RXJyb3JcIjtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QWJvcnRSZXN1bHQoKTogW0Fib3J0RXJyb3JdIHtcbiAgcmV0dXJuIFtuZXcgQWJvcnRFcnJvcigpXTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7O3dDQUFBQSxJQWtCTyxJQUFNQyxFQUFOLGNBQXlCLEtBQU0sQ0FDcEMsYUFBYyxDQUNaLE1BQU0sNEJBQTRCLEVBQ2xDLEtBQUssS0FBTyxZQUNkLENBQ0YsRUFFTyxTQUFTQyxHQUErQixDQUM3QyxNQUFPLENBQUMsSUFBSUQsQ0FBWSxDQUMxQiIsCiAgIm5hbWVzIjogWyJpbml0X2RlZmluZV9BQ0NFTEVSQVRFX1NDSEVNQV9CWV9QUk9WSURFUiIsICJBYm9ydEVycm9yIiwgImdldEFib3J0UmVzdWx0Il0KfQo=
@@ -0,0 +1,10 @@
1
+ import * as ___react___ from 'react';
2
+ import * as ___react_dom___ from 'react-dom';
3
+
4
+ function require(mod) {
5
+ if (mod === 'react') return ___react___;
6
+ if (mod === 'react-dom') return ___react_dom___;
7
+ throw new Error(`Unknown module ${mod}`);
8
+ }
9
+ import{e as p,f as d}from"./chunk-GGFIWHFO.js";p();function m(e,t=w){let{columns:r,rows:n,types:i}=e,s=[],c=A(r);for(let o=0,y=n.length;o<y;o++){let l=n[o],a={...c};for(let u=0,f=l.length;u<f;u++){let R=r[u];a[R]=t(l[u],i[u],R)}s.push(a)}return s}function w(e,t,r){return e}function A(e){let t={};for(let r=0,n=e.length;r<n;r++)t[e[r]]=null;return t}p();var x=["mysql","postgres","postgresql"],g="accelerate.prisma-data.net",h=d;function _(e){let{provider:t}=e;if(t!=="postgresql"&&!x.includes(t))throw new Error(`Invalid provider: ${t}`);let r=P(e);return{execute:b(e,r)}}function P(e){let{host:t,engineHash:r,clientVersion:n,provider:i,apiKey:s}=e,o=`${t===g?"https":"http"}://${t||g}/${n}/${E(i).hash}`,y=e.fetch||fetch,l={Authorization:`Bearer ${s}`,"Prisma-Engine-Hash":r};return a=>y(`${o}/${a.path}`,{body:a.body,headers:l,method:a.method,signal:a.signal})}async function q(e,t,r){let n=await r({body:E(e.provider).encoded,method:"PUT",path:"schema",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to upload schema to query engine: ${n.statusText}`)}}function E(e){return e==="postgresql"?h.postgres:h[e]}async function S(e,t,r){let n=await r({body:JSON.stringify(e),method:"POST",path:"graphql",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to execute query: ${n.statusText}`)}return await n.json()}function b(e,t){let{resultDeserializerFn:r=m}=e,n=null;return async(i,s)=>{try{await(n||=q(e,s,t));let{data:c,errors:o}=await S({action:"queryRaw",query:{arguments:{parameters:i.parameters,query:i.sql},selection:{}}},s,t);return o?[new AggregateError(o,"Errors occurred while executing the query")]:[null,r(c.queryRaw)]}catch(c){return[c]}}}export{m as a,_ as b};
10
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/accelerate/deserializer.ts", "../data/accelerate/http-client.ts"],
  "sourcesContent": ["// ----------------------------------------------------------------------------\n// STOLEN AND ALTERED FROM https://github.com/prisma/prisma/blob/07932ae18132381bb84db889a9dcad0e6c9e6a68/packages/client/src/runtime/utils/deserializeRawResults.ts\n// ----------------------------------------------------------------------------\n\nexport function deserializeRawResult(\n  response: RawResponse,\n  valueDeserializerFn: (\n    value: unknown,\n    type: QueryIntrospectionBuiltinType,\n    column: string,\n  ) => unknown = deserializeValue,\n): DeserializedResponse {\n  const { columns, rows, types } = response;\n\n  const deserializedResponse: DeserializedResponse = [];\n\n  // Performance optimization. See https://github.com/brianc/node-postgres/issues/3042\n  const prebuiltEmptyObject = createPrebuiltEmptyResultObject(columns);\n\n  for (let i = 0, len = rows.length; i < len; i++) {\n    const row = rows[i]!;\n\n    const mappedRow = { ...prebuiltEmptyObject } as Record<string, unknown>;\n\n    for (let j = 0, len = row.length; j < len; j++) {\n      const column = columns[j]!;\n\n      mappedRow[column] = valueDeserializerFn(row[j], types[j]!, column);\n    }\n\n    deserializedResponse.push(mappedRow);\n  }\n\n  return deserializedResponse;\n}\n\nfunction deserializeValue(value: unknown, _type: QueryIntrospectionBuiltinType, _column: string): unknown {\n  return value;\n}\n\nexport type DeserializedResponse = Array<Record<string, unknown>>;\n\nfunction createPrebuiltEmptyResultObject(columns: string[]): Record<string, null> {\n  const row: Record<string, null> = {};\n\n  for (let i = 0, len = columns.length; i < len; i++) {\n    row[columns[i]!] = null;\n  }\n\n  return row;\n}\n\nexport interface RawResponse {\n  columns: string[];\n  types: QueryIntrospectionBuiltinType[];\n  rows: unknown[][];\n}\n\nexport type QueryIntrospectionBuiltinType =\n  | \"int\"\n  | \"bigint\"\n  | \"float\"\n  | \"double\"\n  | \"string\"\n  | \"enum\"\n  | \"bytes\"\n  | \"bool\"\n  | \"char\"\n  | \"decimal\"\n  | \"json\"\n  | \"xml\"\n  | \"uuid\"\n  | \"datetime\"\n  | \"date\"\n  | \"time\"\n  | \"int-array\"\n  | \"bigint-array\"\n  | \"float-array\"\n  | \"double-array\"\n  | \"string-array\"\n  | \"char-array\"\n  | \"bytes-array\"\n  | \"bool-array\"\n  | \"decimal-array\"\n  | \"json-array\"\n  | \"xml-array\"\n  | \"uuid-array\"\n  | \"datetime-array\"\n  | \"date-array\"\n  | \"time-array\"\n  | \"null\"\n  | \"unknown\";\n", "import type { JsonBatchQuery, JsonQuery } from \"@prisma/client/runtime/library\";\n\nimport type { ExecuteOptions, Executor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { deserializeRawResult, type RawResponse } from \"./deserializer\";\n\nexport const SUPPORTED_ACCELERATE_PROVIDERS = [\"mysql\", \"postgres\", \"postgresql\"] as const;\nexport type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];\n\n/** value injected at build time */\ndeclare const ACCELERATE_SCHEMA_BY_PROVIDER: Record<SupportedAccelerateProvider, { encoded: string; hash: string }>;\n\nexport type JsonRequest = JsonQuery | JsonBatchQuery;\n\nexport interface QueryRawResult {\n  data: {\n    queryRaw: RawResponse;\n  };\n  errors?: unknown[];\n}\n\nconst ACCELERATE_HOST = \"accelerate.prisma-data.net\";\nexport const SCHEMA_BY_PROVIDER = ACCELERATE_SCHEMA_BY_PROVIDER;\n\nexport interface AccelerateHttpClientParams {\n  /**\n   * Accelerate API key.\n   */\n  apiKey: string;\n\n  /**\n   * Optional fetch implementation.\n   */\n  fetch?: typeof globalThis.fetch;\n\n  /**\n   * Optional host.\n   *\n   * Defaults to `accelerate.prisma-data.net`.\n   */\n  host?: string;\n\n  /**\n   * Database provider.\n   */\n  provider: SupportedAccelerateProvider | \"postgresql\";\n\n  /**\n   * Prisma Engine Hash (eg. 173f8d54f8d52e692c7e27e72a88314ec7aeff60)\n   */\n  engineHash: string;\n\n  /**\n   * Prisma Client Version (eg. 6.5.0).\n   */\n  clientVersion: string;\n\n  /**\n   * Function used to deserialize the results of queries.\n   *\n   * By default, the results are passed to `deserializeRawResult`.\n   */\n  resultDeserializerFn?: (this: void, response: RawResponse) => unknown[];\n}\n\nexport interface AccelerateHttpClient extends Executor {\n  execute<T>(this: void, query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;\n}\n\nexport function createAccelerateHttpClient(props: AccelerateHttpClientParams): AccelerateHttpClient {\n  const { provider } = props;\n\n  if (provider !== \"postgresql\" && !SUPPORTED_ACCELERATE_PROVIDERS.includes(provider)) {\n    throw new Error(`Invalid provider: ${provider}`);\n  }\n\n  const sendAccelerateRequest = getSendAccelerateRequestFn(props);\n\n  return {\n    execute: getSendQueryRequestFn(props, sendAccelerateRequest),\n  };\n}\n\nfunction getSendAccelerateRequestFn(\n  props: AccelerateHttpClientParams,\n): (request: RequestInit & { path: string; signal?: AbortSignal }) => Promise<Response> {\n  const { host, engineHash, clientVersion, provider, apiKey } = props;\n  const protocol = host === ACCELERATE_HOST ? \"https\" : \"http\";\n  const baseUrl = `${protocol}://${host || ACCELERATE_HOST}/${clientVersion}/${getSchemaByProvider(provider).hash}`;\n\n  const fetchFn = props.fetch || fetch;\n  const headers = {\n    Authorization: `Bearer ${apiKey}`,\n    \"Prisma-Engine-Hash\": engineHash,\n  } as const;\n\n  return (request) =>\n    fetchFn(`${baseUrl}/${request.path}`, {\n      body: request.body,\n      headers,\n      method: request.method,\n      signal: request.signal,\n    });\n}\n\nasync function sendSchemaRequest(\n  props: AccelerateHttpClientParams,\n  options: ExecuteOptions | undefined,\n  sendRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<void> {\n  const response = await sendRequest({\n    body: getSchemaByProvider(props.provider).encoded,\n    method: \"PUT\",\n    path: \"schema\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to upload schema to query engine: ${response.statusText}`);\n  }\n}\n\nfunction getSchemaByProvider(\n  provider: SupportedAccelerateProvider | \"postgresql\",\n): (typeof SCHEMA_BY_PROVIDER)[keyof typeof SCHEMA_BY_PROVIDER] {\n  if (provider === \"postgresql\") {\n    return SCHEMA_BY_PROVIDER[\"postgres\"];\n  }\n\n  return SCHEMA_BY_PROVIDER[provider];\n}\n\nasync function sendPrismaOrmRequest<R>(\n  request: JsonRequest,\n  options: ExecuteOptions | undefined,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<R> {\n  const response = await sendAccelerateRequest({\n    body: JSON.stringify(request),\n    method: \"POST\",\n    path: \"graphql\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to execute query: ${response.statusText}`);\n  }\n\n  return (await response.json()) as R;\n}\n\nfunction getSendQueryRequestFn(\n  props: AccelerateHttpClientParams,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Executor[\"execute\"] {\n  const { resultDeserializerFn = deserializeRawResult } = props;\n  let schemaRequest: Promise<void> | null = null;\n\n  return async (query, options) => {\n    try {\n      await (schemaRequest ||= sendSchemaRequest(props, options, sendAccelerateRequest));\n\n      const { data, errors } = await sendPrismaOrmRequest<QueryRawResult>(\n        {\n          action: \"queryRaw\",\n          query: {\n            arguments: {\n              parameters: query.parameters as never[],\n              query: query.sql,\n            },\n            selection: {},\n          },\n        },\n        options,\n        sendAccelerateRequest,\n      );\n\n      if (errors) {\n        return [new AggregateError(errors, \"Errors occurred while executing the query\")];\n      }\n\n      return [null, resultDeserializerFn(data.queryRaw) as QueryResult<typeof query>];\n    } catch (error: unknown) {\n      return [error as Error];\n    }\n  };\n}\n"],
  "mappings": "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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "deserializeRawResult", "response", "valueDeserializerFn", "deserializeValue", "columns", "rows", "types", "deserializedResponse", "prebuiltEmptyObject", "createPrebuiltEmptyResultObject", "i", "len", "row", "mappedRow", "j", "column", "value", "_type", "_column", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "SUPPORTED_ACCELERATE_PROVIDERS", "ACCELERATE_HOST", "SCHEMA_BY_PROVIDER", "define_ACCELERATE_SCHEMA_BY_PROVIDER_default", "createAccelerateHttpClient", "props", "provider", "sendAccelerateRequest", "getSendAccelerateRequestFn", "getSendQueryRequestFn", "host", "engineHash", "clientVersion", "apiKey", "baseUrl", "getSchemaByProvider", "fetchFn", "headers", "request", "sendSchemaRequest", "options", "sendRequest", "response", "sendPrismaOrmRequest", "resultDeserializerFn", "deserializeRawResult", "schemaRequest", "query", "data", "errors", "error"]
}

@@ -1,2 +1,2 @@
1
- "use strict";var R=Object.defineProperty;var A=Object.getOwnPropertyDescriptor;var x=Object.getOwnPropertyNames;var P=Object.prototype.hasOwnProperty;var S=(e,t)=>{for(var r in t)R(e,r,{get:t[r],enumerable:!0})},q=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of x(t))!P.call(e,o)&&o!==r&&R(e,o,{get:()=>t[o],enumerable:!(n=A(t,o))||n.enumerable});return e};var C=e=>q(R({},"__esModule",{value:!0}),e);var k={};S(k,{createAccelerateHttpClient:()=>E,deserializeRawResult:()=>y});module.exports=C(k);var p={postgres:{encoded:"ZGF0YXNvdXJjZSBkYiB7CiAgICBwcm92aWRlciA9ICJwb3N0Z3JlcyIKICAgIHVybCAgICAgID0gZW52KCJEQVRBQkFTRV9VUkwiKQp9CiAgICAKZ2VuZXJhdG9yIGNsaWVudCB7CiAgICBwcm92aWRlciA9ICJwcmlzbWEtY2xpZW50LWpzIgp9",hash:"54195896aeafa3318ca33f5a8bb44c6b4d89c368cb15288f3bd5ace35a3f9227"},postgresql:{encoded:"ZGF0YXNvdXJjZSBkYiB7CiAgICBwcm92aWRlciA9ICJwb3N0Z3Jlc3FsIgogICAgdXJsICAgICAgPSBlbnYoIkRBVEFCQVNFX1VSTCIpCn0KICAgIApnZW5lcmF0b3IgY2xpZW50IHsKICAgIHByb3ZpZGVyID0gInByaXNtYS1jbGllbnQtanMiCn0=",hash:"d2898eb0d71a62767c6497d5c37718cf28c13e6144b1c97f6849ff0f76e958fb"}};function y(e,t=b){let{columns:r,rows:n,types:o}=e,a=[],c=H(r);for(let s=0,d=n.length;s<d;s++){let l=n[s],i={...c};for(let u=0,w=l.length;u<w;u++){let m=r[u];i[m]=t(l[u],o[u],m)}a.push(i)}return a}function b(e,t,r){return e}function H(e){let t={};for(let r=0,n=e.length;r<n;r++)t[e[r]]=null;return t}var O=["postgres","postgresql"],g="accelerate.prisma-data.net",h=p;function E(e){let{provider:t}=e;if(t!=="postgresql"&&!O.includes(t))throw new Error(`Invalid provider: ${t}`);let r=_(e);return{execute:D(e,r)}}function _(e){let{host:t,engineHash:r,clientVersion:n,provider:o,apiKey:a}=e,s=`${t===g?"https":"http"}://${t||g}/${n}/${f(o).hash}`,d=e.fetch||fetch,l={Authorization:`Bearer ${a}`,"Prisma-Engine-Hash":r};return i=>d(`${s}/${i.path}`,{body:i.body,headers:l,method:i.method,signal:i.signal})}async function Q(e,t,r){let n=await r({body:f(e.provider).encoded,method:"PUT",path:"schema",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to upload schema to query engine: ${n.statusText}`)}}function f(e){return e==="postgresql"?h.postgres:h[e]}async function v(e,t,r){let n=await r({body:JSON.stringify(e),method:"POST",path:"graphql",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to execute query: ${n.statusText}`)}return await n.json()}function D(e,t){let{resultDeserializerFn:r=y}=e,n=null;return async(o,a)=>{try{await(n||=Q(e,a,t));let{data:c,errors:s}=await v({action:"queryRaw",query:{arguments:{parameters:o.parameters,query:o.sql},selection:{}}},a,t);return s?[new AggregateError(s,"Errors occurred while executing the query")]:[null,r(c.queryRaw)]}catch(c){return[c]}}}
2
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/accelerate/index.ts", "<define:ACCELERATE_SCHEMA_BY_PROVIDER>", "../../../data/accelerate/deserializer.ts", "../../../data/accelerate/http-client.ts"],
  "sourcesContent": ["export {\n  type DeserializedResponse,\n  deserializeRawResult,\n  type QueryIntrospectionBuiltinType,\n  type RawResponse,\n} from \"./deserializer\";\nexport {\n  type AccelerateHttpClient,\n  type AccelerateHttpClientParams,\n  createAccelerateHttpClient,\n  type SupportedAccelerateProvider,\n} from \"./http-client\";\n", "", "// ----------------------------------------------------------------------------\n// STOLEN AND ALTERED FROM https://github.com/prisma/prisma/blob/07932ae18132381bb84db889a9dcad0e6c9e6a68/packages/client/src/runtime/utils/deserializeRawResults.ts\n// ----------------------------------------------------------------------------\n\nexport function deserializeRawResult(\n  response: RawResponse,\n  valueDeserializerFn: (\n    value: unknown,\n    type: QueryIntrospectionBuiltinType,\n    column: string,\n  ) => unknown = deserializeValue,\n): DeserializedResponse {\n  const { columns, rows, types } = response;\n\n  const deserializedResponse: DeserializedResponse = [];\n\n  // Performance optimization. See https://github.com/brianc/node-postgres/issues/3042\n  const prebuiltEmptyObject = createPrebuiltEmptyResultObject(columns);\n\n  for (let i = 0, len = rows.length; i < len; i++) {\n    const row = rows[i]!;\n\n    const mappedRow = { ...prebuiltEmptyObject } as Record<string, unknown>;\n\n    for (let j = 0, len = row.length; j < len; j++) {\n      const column = columns[j]!;\n\n      mappedRow[column] = valueDeserializerFn(row[j], types[j]!, column);\n    }\n\n    deserializedResponse.push(mappedRow);\n  }\n\n  return deserializedResponse;\n}\n\nfunction deserializeValue(value: unknown, _type: QueryIntrospectionBuiltinType, _column: string): unknown {\n  return value;\n}\n\nexport type DeserializedResponse = Array<Record<string, unknown>>;\n\nfunction createPrebuiltEmptyResultObject(columns: string[]): Record<string, null> {\n  const row: Record<string, null> = {};\n\n  for (let i = 0, len = columns.length; i < len; i++) {\n    row[columns[i]!] = null;\n  }\n\n  return row;\n}\n\nexport interface RawResponse {\n  columns: string[];\n  types: QueryIntrospectionBuiltinType[];\n  rows: unknown[][];\n}\n\nexport type QueryIntrospectionBuiltinType =\n  | \"int\"\n  | \"bigint\"\n  | \"float\"\n  | \"double\"\n  | \"string\"\n  | \"enum\"\n  | \"bytes\"\n  | \"bool\"\n  | \"char\"\n  | \"decimal\"\n  | \"json\"\n  | \"xml\"\n  | \"uuid\"\n  | \"datetime\"\n  | \"date\"\n  | \"time\"\n  | \"int-array\"\n  | \"bigint-array\"\n  | \"float-array\"\n  | \"double-array\"\n  | \"string-array\"\n  | \"char-array\"\n  | \"bytes-array\"\n  | \"bool-array\"\n  | \"decimal-array\"\n  | \"json-array\"\n  | \"xml-array\"\n  | \"uuid-array\"\n  | \"datetime-array\"\n  | \"date-array\"\n  | \"time-array\"\n  | \"null\"\n  | \"unknown\";\n", "import type { JsonBatchQuery, JsonQuery } from \"@prisma/client/runtime/library\";\n\nimport type { ExecuteOptions, Executor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { deserializeRawResult, type RawResponse } from \"./deserializer\";\n\nexport const SUPPORTED_ACCELERATE_PROVIDERS = [\n  // \"mysql\",\n  \"postgres\",\n  \"postgresql\",\n] as const;\nexport type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];\n\n/** value injected at build time */\ndeclare const ACCELERATE_SCHEMA_BY_PROVIDER: Record<SupportedAccelerateProvider, { encoded: string; hash: string }>;\n\nexport type JsonRequest = JsonQuery | JsonBatchQuery;\n\nexport interface QueryRawResult {\n  data: {\n    queryRaw: RawResponse;\n  };\n  errors?: unknown[];\n}\n\nconst ACCELERATE_HOST = \"accelerate.prisma-data.net\";\nexport const SCHEMA_BY_PROVIDER = ACCELERATE_SCHEMA_BY_PROVIDER;\n\nexport interface AccelerateHttpClientParams {\n  /**\n   * Accelerate API key.\n   */\n  apiKey: string;\n\n  /**\n   * Optional fetch implementation.\n   */\n  fetch?: typeof globalThis.fetch;\n\n  /**\n   * Optional host.\n   *\n   * Defaults to `accelerate.prisma-data.net`.\n   */\n  host?: string;\n\n  /**\n   * Database provider.\n   */\n  provider: SupportedAccelerateProvider | \"postgresql\";\n\n  /**\n   * Prisma Engine Hash (eg. 173f8d54f8d52e692c7e27e72a88314ec7aeff60)\n   */\n  engineHash: string;\n\n  /**\n   * Prisma Client Version (eg. 6.5.0).\n   */\n  clientVersion: string;\n\n  /**\n   * Function used to deserialize the results of queries.\n   *\n   * By default, the results are passed to `deserializeRawResult`.\n   */\n  resultDeserializerFn?: (this: void, response: RawResponse) => unknown[];\n}\n\nexport interface AccelerateHttpClient extends Executor {\n  execute<T>(this: void, query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;\n}\n\nexport function createAccelerateHttpClient(props: AccelerateHttpClientParams): AccelerateHttpClient {\n  const { provider } = props;\n\n  if (provider !== \"postgresql\" && !SUPPORTED_ACCELERATE_PROVIDERS.includes(provider)) {\n    throw new Error(`Invalid provider: ${provider}`);\n  }\n\n  const sendAccelerateRequest = getSendAccelerateRequestFn(props);\n\n  return {\n    execute: getSendQueryRequestFn(props, sendAccelerateRequest),\n  };\n}\n\nfunction getSendAccelerateRequestFn(\n  props: AccelerateHttpClientParams,\n): (request: RequestInit & { path: string; signal?: AbortSignal }) => Promise<Response> {\n  const { host, engineHash, clientVersion, provider, apiKey } = props;\n  const protocol = host === ACCELERATE_HOST ? \"https\" : \"http\";\n  const baseUrl = `${protocol}://${host || ACCELERATE_HOST}/${clientVersion}/${getSchemaByProvider(provider).hash}`;\n\n  const fetchFn = props.fetch || fetch;\n  const headers = {\n    Authorization: `Bearer ${apiKey}`,\n    \"Prisma-Engine-Hash\": engineHash,\n  } as const;\n\n  return (request) =>\n    fetchFn(`${baseUrl}/${request.path}`, {\n      body: request.body,\n      headers,\n      method: request.method,\n      signal: request.signal,\n    });\n}\n\nasync function sendSchemaRequest(\n  props: AccelerateHttpClientParams,\n  options: ExecuteOptions | undefined,\n  sendRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<void> {\n  const response = await sendRequest({\n    body: getSchemaByProvider(props.provider).encoded,\n    method: \"PUT\",\n    path: \"schema\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to upload schema to query engine: ${response.statusText}`);\n  }\n}\n\nfunction getSchemaByProvider(\n  provider: SupportedAccelerateProvider | \"postgresql\",\n): (typeof SCHEMA_BY_PROVIDER)[keyof typeof SCHEMA_BY_PROVIDER] {\n  if (provider === \"postgresql\") {\n    return SCHEMA_BY_PROVIDER[\"postgres\"];\n  }\n\n  return SCHEMA_BY_PROVIDER[provider];\n}\n\nasync function sendPrismaOrmRequest<R>(\n  request: JsonRequest,\n  options: ExecuteOptions | undefined,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<R> {\n  const response = await sendAccelerateRequest({\n    body: JSON.stringify(request),\n    method: \"POST\",\n    path: \"graphql\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to execute query: ${response.statusText}`);\n  }\n\n  return (await response.json()) as R;\n}\n\nfunction getSendQueryRequestFn(\n  props: AccelerateHttpClientParams,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Executor[\"execute\"] {\n  const { resultDeserializerFn = deserializeRawResult } = props;\n  let schemaRequest: Promise<void> | null = null;\n\n  return async (query, options) => {\n    try {\n      await (schemaRequest ||= sendSchemaRequest(props, options, sendAccelerateRequest));\n\n      const { data, errors } = await sendPrismaOrmRequest<QueryRawResult>(\n        {\n          action: \"queryRaw\",\n          query: {\n            arguments: {\n              parameters: query.parameters as never[],\n              query: query.sql,\n            },\n            selection: {},\n          },\n        },\n        options,\n        sendAccelerateRequest,\n      );\n\n      if (errors) {\n        return [new AggregateError(errors, \"Errors occurred while executing the query\")];\n      }\n\n      return [null, resultDeserializerFn(data.queryRaw) as QueryResult<typeof query>];\n    } catch (error: unknown) {\n      return [error as Error];\n    }\n  };\n}\n"],
  "mappings": "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",
  "names": ["accelerate_exports", "__export", "createAccelerateHttpClient", "deserializeRawResult", "__toCommonJS", "define_ACCELERATE_SCHEMA_BY_PROVIDER_default", "deserializeRawResult", "response", "valueDeserializerFn", "deserializeValue", "columns", "rows", "types", "deserializedResponse", "prebuiltEmptyObject", "createPrebuiltEmptyResultObject", "i", "len", "row", "mappedRow", "j", "column", "value", "_type", "_column", "SUPPORTED_ACCELERATE_PROVIDERS", "ACCELERATE_HOST", "SCHEMA_BY_PROVIDER", "define_ACCELERATE_SCHEMA_BY_PROVIDER_default", "createAccelerateHttpClient", "props", "provider", "sendAccelerateRequest", "getSendAccelerateRequestFn", "getSendQueryRequestFn", "host", "engineHash", "clientVersion", "apiKey", "baseUrl", "getSchemaByProvider", "fetchFn", "headers", "request", "sendSchemaRequest", "options", "sendRequest", "response", "sendPrismaOrmRequest", "resultDeserializerFn", "deserializeRawResult", "schemaRequest", "query", "data", "errors", "error"]
}

1
+ "use strict";var R=Object.defineProperty;var A=Object.getOwnPropertyDescriptor;var x=Object.getOwnPropertyNames;var P=Object.prototype.hasOwnProperty;var q=(e,t)=>{for(var r in t)R(e,r,{get:t[r],enumerable:!0})},S=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of x(t))!P.call(e,o)&&o!==r&&R(e,o,{get:()=>t[o],enumerable:!(n=A(t,o))||n.enumerable});return e};var C=e=>S(R({},"__esModule",{value:!0}),e);var k={};q(k,{createAccelerateHttpClient:()=>E,deserializeRawResult:()=>y});module.exports=C(k);var p={mysql:{encoded:"ZGF0YXNvdXJjZSBkYiB7CiAgICBwcm92aWRlciA9ICJteXNxbCIKICAgIHVybCAgICAgID0gZW52KCJEQVRBQkFTRV9VUkwiKQp9CiAgICAKZ2VuZXJhdG9yIGNsaWVudCB7CiAgICBwcm92aWRlciA9ICJwcmlzbWEtY2xpZW50LWpzIgp9",hash:"8157ef0f68a62b93385f659d0df3eb630f54b49387d67be1e69cc376bc2e0901"},postgres:{encoded:"ZGF0YXNvdXJjZSBkYiB7CiAgICBwcm92aWRlciA9ICJwb3N0Z3JlcyIKICAgIHVybCAgICAgID0gZW52KCJEQVRBQkFTRV9VUkwiKQp9CiAgICAKZ2VuZXJhdG9yIGNsaWVudCB7CiAgICBwcm92aWRlciA9ICJwcmlzbWEtY2xpZW50LWpzIgp9",hash:"54195896aeafa3318ca33f5a8bb44c6b4d89c368cb15288f3bd5ace35a3f9227"},postgresql:{encoded:"ZGF0YXNvdXJjZSBkYiB7CiAgICBwcm92aWRlciA9ICJwb3N0Z3Jlc3FsIgogICAgdXJsICAgICAgPSBlbnYoIkRBVEFCQVNFX1VSTCIpCn0KICAgIApnZW5lcmF0b3IgY2xpZW50IHsKICAgIHByb3ZpZGVyID0gInByaXNtYS1jbGllbnQtanMiCn0=",hash:"d2898eb0d71a62767c6497d5c37718cf28c13e6144b1c97f6849ff0f76e958fb"}};function y(e,t=b){let{columns:r,rows:n,types:o}=e,a=[],c=H(r);for(let s=0,d=n.length;s<d;s++){let l=n[s],i={...c};for(let u=0,w=l.length;u<w;u++){let m=r[u];i[m]=t(l[u],o[u],m)}a.push(i)}return a}function b(e,t,r){return e}function H(e){let t={};for(let r=0,n=e.length;r<n;r++)t[e[r]]=null;return t}var O=["mysql","postgres","postgresql"],g="accelerate.prisma-data.net",h=p;function E(e){let{provider:t}=e;if(t!=="postgresql"&&!O.includes(t))throw new Error(`Invalid provider: ${t}`);let r=_(e);return{execute:D(e,r)}}function _(e){let{host:t,engineHash:r,clientVersion:n,provider:o,apiKey:a}=e,s=`${t===g?"https":"http"}://${t||g}/${n}/${f(o).hash}`,d=e.fetch||fetch,l={Authorization:`Bearer ${a}`,"Prisma-Engine-Hash":r};return i=>d(`${s}/${i.path}`,{body:i.body,headers:l,method:i.method,signal:i.signal})}async function Q(e,t,r){let n=await r({body:f(e.provider).encoded,method:"PUT",path:"schema",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to upload schema to query engine: ${n.statusText}`)}}function f(e){return e==="postgresql"?h.postgres:h[e]}async function v(e,t,r){let n=await r({body:JSON.stringify(e),method:"POST",path:"graphql",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to execute query: ${n.statusText}`)}return await n.json()}function D(e,t){let{resultDeserializerFn:r=y}=e,n=null;return async(o,a)=>{try{await(n||=Q(e,a,t));let{data:c,errors:s}=await v({action:"queryRaw",query:{arguments:{parameters:o.parameters,query:o.sql},selection:{}}},a,t);return s?[new AggregateError(s,"Errors occurred while executing the query")]:[null,r(c.queryRaw)]}catch(c){return[c]}}}
2
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/accelerate/index.ts", "<define:ACCELERATE_SCHEMA_BY_PROVIDER>", "../../../data/accelerate/deserializer.ts", "../../../data/accelerate/http-client.ts"],
  "sourcesContent": ["export {\n  type DeserializedResponse,\n  deserializeRawResult,\n  type QueryIntrospectionBuiltinType,\n  type RawResponse,\n} from \"./deserializer\";\nexport {\n  type AccelerateHttpClient,\n  type AccelerateHttpClientParams,\n  createAccelerateHttpClient,\n  type SupportedAccelerateProvider,\n} from \"./http-client\";\n", "", "// ----------------------------------------------------------------------------\n// STOLEN AND ALTERED FROM https://github.com/prisma/prisma/blob/07932ae18132381bb84db889a9dcad0e6c9e6a68/packages/client/src/runtime/utils/deserializeRawResults.ts\n// ----------------------------------------------------------------------------\n\nexport function deserializeRawResult(\n  response: RawResponse,\n  valueDeserializerFn: (\n    value: unknown,\n    type: QueryIntrospectionBuiltinType,\n    column: string,\n  ) => unknown = deserializeValue,\n): DeserializedResponse {\n  const { columns, rows, types } = response;\n\n  const deserializedResponse: DeserializedResponse = [];\n\n  // Performance optimization. See https://github.com/brianc/node-postgres/issues/3042\n  const prebuiltEmptyObject = createPrebuiltEmptyResultObject(columns);\n\n  for (let i = 0, len = rows.length; i < len; i++) {\n    const row = rows[i]!;\n\n    const mappedRow = { ...prebuiltEmptyObject } as Record<string, unknown>;\n\n    for (let j = 0, len = row.length; j < len; j++) {\n      const column = columns[j]!;\n\n      mappedRow[column] = valueDeserializerFn(row[j], types[j]!, column);\n    }\n\n    deserializedResponse.push(mappedRow);\n  }\n\n  return deserializedResponse;\n}\n\nfunction deserializeValue(value: unknown, _type: QueryIntrospectionBuiltinType, _column: string): unknown {\n  return value;\n}\n\nexport type DeserializedResponse = Array<Record<string, unknown>>;\n\nfunction createPrebuiltEmptyResultObject(columns: string[]): Record<string, null> {\n  const row: Record<string, null> = {};\n\n  for (let i = 0, len = columns.length; i < len; i++) {\n    row[columns[i]!] = null;\n  }\n\n  return row;\n}\n\nexport interface RawResponse {\n  columns: string[];\n  types: QueryIntrospectionBuiltinType[];\n  rows: unknown[][];\n}\n\nexport type QueryIntrospectionBuiltinType =\n  | \"int\"\n  | \"bigint\"\n  | \"float\"\n  | \"double\"\n  | \"string\"\n  | \"enum\"\n  | \"bytes\"\n  | \"bool\"\n  | \"char\"\n  | \"decimal\"\n  | \"json\"\n  | \"xml\"\n  | \"uuid\"\n  | \"datetime\"\n  | \"date\"\n  | \"time\"\n  | \"int-array\"\n  | \"bigint-array\"\n  | \"float-array\"\n  | \"double-array\"\n  | \"string-array\"\n  | \"char-array\"\n  | \"bytes-array\"\n  | \"bool-array\"\n  | \"decimal-array\"\n  | \"json-array\"\n  | \"xml-array\"\n  | \"uuid-array\"\n  | \"datetime-array\"\n  | \"date-array\"\n  | \"time-array\"\n  | \"null\"\n  | \"unknown\";\n", "import type { JsonBatchQuery, JsonQuery } from \"@prisma/client/runtime/library\";\n\nimport type { ExecuteOptions, Executor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { deserializeRawResult, type RawResponse } from \"./deserializer\";\n\nexport const SUPPORTED_ACCELERATE_PROVIDERS = [\"mysql\", \"postgres\", \"postgresql\"] as const;\nexport type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];\n\n/** value injected at build time */\ndeclare const ACCELERATE_SCHEMA_BY_PROVIDER: Record<SupportedAccelerateProvider, { encoded: string; hash: string }>;\n\nexport type JsonRequest = JsonQuery | JsonBatchQuery;\n\nexport interface QueryRawResult {\n  data: {\n    queryRaw: RawResponse;\n  };\n  errors?: unknown[];\n}\n\nconst ACCELERATE_HOST = \"accelerate.prisma-data.net\";\nexport const SCHEMA_BY_PROVIDER = ACCELERATE_SCHEMA_BY_PROVIDER;\n\nexport interface AccelerateHttpClientParams {\n  /**\n   * Accelerate API key.\n   */\n  apiKey: string;\n\n  /**\n   * Optional fetch implementation.\n   */\n  fetch?: typeof globalThis.fetch;\n\n  /**\n   * Optional host.\n   *\n   * Defaults to `accelerate.prisma-data.net`.\n   */\n  host?: string;\n\n  /**\n   * Database provider.\n   */\n  provider: SupportedAccelerateProvider | \"postgresql\";\n\n  /**\n   * Prisma Engine Hash (eg. 173f8d54f8d52e692c7e27e72a88314ec7aeff60)\n   */\n  engineHash: string;\n\n  /**\n   * Prisma Client Version (eg. 6.5.0).\n   */\n  clientVersion: string;\n\n  /**\n   * Function used to deserialize the results of queries.\n   *\n   * By default, the results are passed to `deserializeRawResult`.\n   */\n  resultDeserializerFn?: (this: void, response: RawResponse) => unknown[];\n}\n\nexport interface AccelerateHttpClient extends Executor {\n  execute<T>(this: void, query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;\n}\n\nexport function createAccelerateHttpClient(props: AccelerateHttpClientParams): AccelerateHttpClient {\n  const { provider } = props;\n\n  if (provider !== \"postgresql\" && !SUPPORTED_ACCELERATE_PROVIDERS.includes(provider)) {\n    throw new Error(`Invalid provider: ${provider}`);\n  }\n\n  const sendAccelerateRequest = getSendAccelerateRequestFn(props);\n\n  return {\n    execute: getSendQueryRequestFn(props, sendAccelerateRequest),\n  };\n}\n\nfunction getSendAccelerateRequestFn(\n  props: AccelerateHttpClientParams,\n): (request: RequestInit & { path: string; signal?: AbortSignal }) => Promise<Response> {\n  const { host, engineHash, clientVersion, provider, apiKey } = props;\n  const protocol = host === ACCELERATE_HOST ? \"https\" : \"http\";\n  const baseUrl = `${protocol}://${host || ACCELERATE_HOST}/${clientVersion}/${getSchemaByProvider(provider).hash}`;\n\n  const fetchFn = props.fetch || fetch;\n  const headers = {\n    Authorization: `Bearer ${apiKey}`,\n    \"Prisma-Engine-Hash\": engineHash,\n  } as const;\n\n  return (request) =>\n    fetchFn(`${baseUrl}/${request.path}`, {\n      body: request.body,\n      headers,\n      method: request.method,\n      signal: request.signal,\n    });\n}\n\nasync function sendSchemaRequest(\n  props: AccelerateHttpClientParams,\n  options: ExecuteOptions | undefined,\n  sendRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<void> {\n  const response = await sendRequest({\n    body: getSchemaByProvider(props.provider).encoded,\n    method: \"PUT\",\n    path: \"schema\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to upload schema to query engine: ${response.statusText}`);\n  }\n}\n\nfunction getSchemaByProvider(\n  provider: SupportedAccelerateProvider | \"postgresql\",\n): (typeof SCHEMA_BY_PROVIDER)[keyof typeof SCHEMA_BY_PROVIDER] {\n  if (provider === \"postgresql\") {\n    return SCHEMA_BY_PROVIDER[\"postgres\"];\n  }\n\n  return SCHEMA_BY_PROVIDER[provider];\n}\n\nasync function sendPrismaOrmRequest<R>(\n  request: JsonRequest,\n  options: ExecuteOptions | undefined,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<R> {\n  const response = await sendAccelerateRequest({\n    body: JSON.stringify(request),\n    method: \"POST\",\n    path: \"graphql\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to execute query: ${response.statusText}`);\n  }\n\n  return (await response.json()) as R;\n}\n\nfunction getSendQueryRequestFn(\n  props: AccelerateHttpClientParams,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Executor[\"execute\"] {\n  const { resultDeserializerFn = deserializeRawResult } = props;\n  let schemaRequest: Promise<void> | null = null;\n\n  return async (query, options) => {\n    try {\n      await (schemaRequest ||= sendSchemaRequest(props, options, sendAccelerateRequest));\n\n      const { data, errors } = await sendPrismaOrmRequest<QueryRawResult>(\n        {\n          action: \"queryRaw\",\n          query: {\n            arguments: {\n              parameters: query.parameters as never[],\n              query: query.sql,\n            },\n            selection: {},\n          },\n        },\n        options,\n        sendAccelerateRequest,\n      );\n\n      if (errors) {\n        return [new AggregateError(errors, \"Errors occurred while executing the query\")];\n      }\n\n      return [null, resultDeserializerFn(data.queryRaw) as QueryResult<typeof query>];\n    } catch (error: unknown) {\n      return [error as Error];\n    }\n  };\n}\n"],
  "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,gCAAAE,EAAA,yBAAAC,IAAA,eAAAC,EAAAJ,GCAA,IAAAK,EAAA,CAAC,MAAQ,CAAC,QAAU,uLAAuL,KAAO,kEAAkE,EAAE,SAAW,CAAC,QAAU,2LAA2L,KAAO,kEAAkE,EAAE,WAAa,CAAC,QAAU,+LAA+L,KAAO,kEAAkE,CAAC,ECI50B,SAASC,EACdC,EACAC,EAIeC,EACO,CACtB,GAAM,CAAE,QAAAC,EAAS,KAAAC,EAAM,MAAAC,CAAM,EAAIL,EAE3BM,EAA6C,CAAC,EAG9CC,EAAsBC,EAAgCL,CAAO,EAEnE,QAASM,EAAI,EAAGC,EAAMN,EAAK,OAAQK,EAAIC,EAAKD,IAAK,CAC/C,IAAME,EAAMP,EAAKK,CAAC,EAEZG,EAAY,CAAE,GAAGL,CAAoB,EAE3C,QAASM,EAAI,EAAGH,EAAMC,EAAI,OAAQE,EAAIH,EAAKG,IAAK,CAC9C,IAAMC,EAASX,EAAQU,CAAC,EAExBD,EAAUE,CAAM,EAAIb,EAAoBU,EAAIE,CAAC,EAAGR,EAAMQ,CAAC,EAAIC,CAAM,CACnE,CAEAR,EAAqB,KAAKM,CAAS,CACrC,CAEA,OAAON,CACT,CAEA,SAASJ,EAAiBa,EAAgBC,EAAsCC,EAA0B,CACxG,OAAOF,CACT,CAIA,SAASP,EAAgCL,EAAyC,CAChF,IAAMQ,EAA4B,CAAC,EAEnC,QAASF,EAAI,EAAGC,EAAMP,EAAQ,OAAQM,EAAIC,EAAKD,IAC7CE,EAAIR,EAAQM,CAAC,CAAE,EAAI,KAGrB,OAAOE,CACT,CC3CO,IAAMO,EAAiC,CAAC,QAAS,WAAY,YAAY,EAe1EC,EAAkB,6BACXC,EAAqBC,EA+C3B,SAASC,EAA2BC,EAAyD,CAClG,GAAM,CAAE,SAAAC,CAAS,EAAID,EAErB,GAAIC,IAAa,cAAgB,CAACN,EAA+B,SAASM,CAAQ,EAChF,MAAM,IAAI,MAAM,qBAAqBA,CAAQ,EAAE,EAGjD,IAAMC,EAAwBC,EAA2BH,CAAK,EAE9D,MAAO,CACL,QAASI,EAAsBJ,EAAOE,CAAqB,CAC7D,CACF,CAEA,SAASC,EACPH,EACsF,CACtF,GAAM,CAAE,KAAAK,EAAM,WAAAC,EAAY,cAAAC,EAAe,SAAAN,EAAU,OAAAO,CAAO,EAAIR,EAExDS,EAAU,GADCJ,IAAST,EAAkB,QAAU,MAC3B,MAAMS,GAAQT,CAAe,IAAIW,CAAa,IAAIG,EAAoBT,CAAQ,EAAE,IAAI,GAEzGU,EAAUX,EAAM,OAAS,MACzBY,EAAU,CACd,cAAe,UAAUJ,CAAM,GAC/B,qBAAsBF,CACxB,EAEA,OAAQO,GACNF,EAAQ,GAAGF,CAAO,IAAII,EAAQ,IAAI,GAAI,CACpC,KAAMA,EAAQ,KACd,QAAAD,EACA,OAAQC,EAAQ,OAChB,OAAQA,EAAQ,MAClB,CAAC,CACL,CAEA,eAAeC,EACbd,EACAe,EACAC,EACe,CACf,IAAMC,EAAW,MAAMD,EAAY,CACjC,KAAMN,EAAoBV,EAAM,QAAQ,EAAE,QAC1C,OAAQ,MACR,KAAM,SACN,OAAQe,GAAS,WACnB,CAAC,EAED,GAAI,CAACE,EAAS,GAAI,CAChB,GAAI,CACF,QAAQ,MAAM,MAAMA,EAAS,KAAK,CAAC,CACrC,MAAQ,CAER,CACA,MAAM,IAAI,MAAM,4CAA4CA,EAAS,UAAU,EAAE,CACnF,CACF,CAEA,SAASP,EACPT,EAC8D,CAC9D,OAAIA,IAAa,aACRJ,EAAmB,SAGrBA,EAAmBI,CAAQ,CACpC,CAEA,eAAeiB,EACbL,EACAE,EACAb,EACY,CACZ,IAAMe,EAAW,MAAMf,EAAsB,CAC3C,KAAM,KAAK,UAAUW,CAAO,EAC5B,OAAQ,OACR,KAAM,UACN,OAAQE,GAAS,WACnB,CAAC,EAED,GAAI,CAACE,EAAS,GAAI,CAChB,GAAI,CACF,QAAQ,MAAM,MAAMA,EAAS,KAAK,CAAC,CACrC,MAAQ,CAER,CACA,MAAM,IAAI,MAAM,4BAA4BA,EAAS,UAAU,EAAE,CACnE,CAEA,OAAQ,MAAMA,EAAS,KAAK,CAC9B,CAEA,SAASb,EACPJ,EACAE,EACqB,CACrB,GAAM,CAAE,qBAAAiB,EAAuBC,CAAqB,EAAIpB,EACpDqB,EAAsC,KAE1C,MAAO,OAAOC,EAAOP,IAAY,CAC/B,GAAI,CACF,MAAOM,IAAkBP,EAAkBd,EAAOe,EAASb,CAAqB,GAEhF,GAAM,CAAE,KAAAqB,EAAM,OAAAC,CAAO,EAAI,MAAMN,EAC7B,CACE,OAAQ,WACR,MAAO,CACL,UAAW,CACT,WAAYI,EAAM,WAClB,MAAOA,EAAM,GACf,EACA,UAAW,CAAC,CACd,CACF,EACAP,EACAb,CACF,EAEA,OAAIsB,EACK,CAAC,IAAI,eAAeA,EAAQ,2CAA2C,CAAC,EAG1E,CAAC,KAAML,EAAqBI,EAAK,QAAQ,CAA8B,CAChF,OAASE,EAAgB,CACvB,MAAO,CAACA,CAAc,CACxB,CACF,CACF",
  "names": ["accelerate_exports", "__export", "createAccelerateHttpClient", "deserializeRawResult", "__toCommonJS", "define_ACCELERATE_SCHEMA_BY_PROVIDER_default", "deserializeRawResult", "response", "valueDeserializerFn", "deserializeValue", "columns", "rows", "types", "deserializedResponse", "prebuiltEmptyObject", "createPrebuiltEmptyResultObject", "i", "len", "row", "mappedRow", "j", "column", "value", "_type", "_column", "SUPPORTED_ACCELERATE_PROVIDERS", "ACCELERATE_HOST", "SCHEMA_BY_PROVIDER", "define_ACCELERATE_SCHEMA_BY_PROVIDER_default", "createAccelerateHttpClient", "props", "provider", "sendAccelerateRequest", "getSendAccelerateRequestFn", "getSendQueryRequestFn", "host", "engineHash", "clientVersion", "apiKey", "baseUrl", "getSchemaByProvider", "fetchFn", "headers", "request", "sendSchemaRequest", "options", "sendRequest", "response", "sendPrismaOrmRequest", "resultDeserializerFn", "deserializeRawResult", "schemaRequest", "query", "data", "errors", "error"]
}

@@ -10,7 +10,7 @@ interface RawResponse {
10
10
  }
11
11
  type QueryIntrospectionBuiltinType = "int" | "bigint" | "float" | "double" | "string" | "enum" | "bytes" | "bool" | "char" | "decimal" | "json" | "xml" | "uuid" | "datetime" | "date" | "time" | "int-array" | "bigint-array" | "float-array" | "double-array" | "string-array" | "char-array" | "bytes-array" | "bool-array" | "decimal-array" | "json-array" | "xml-array" | "uuid-array" | "datetime-array" | "date-array" | "time-array" | "null" | "unknown";
12
12
 
13
- declare const SUPPORTED_ACCELERATE_PROVIDERS: readonly ["postgres", "postgresql"];
13
+ declare const SUPPORTED_ACCELERATE_PROVIDERS: readonly ["mysql", "postgres", "postgresql"];
14
14
  type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];
15
15
  interface AccelerateHttpClientParams {
16
16
  /**
@@ -10,7 +10,7 @@ interface RawResponse {
10
10
  }
11
11
  type QueryIntrospectionBuiltinType = "int" | "bigint" | "float" | "double" | "string" | "enum" | "bytes" | "bool" | "char" | "decimal" | "json" | "xml" | "uuid" | "datetime" | "date" | "time" | "int-array" | "bigint-array" | "float-array" | "double-array" | "string-array" | "char-array" | "bytes-array" | "bool-array" | "decimal-array" | "json-array" | "xml-array" | "uuid-array" | "datetime-array" | "date-array" | "time-array" | "null" | "unknown";
12
12
 
13
- declare const SUPPORTED_ACCELERATE_PROVIDERS: readonly ["postgres", "postgresql"];
13
+ declare const SUPPORTED_ACCELERATE_PROVIDERS: readonly ["mysql", "postgres", "postgresql"];
14
14
  type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];
15
15
  interface AccelerateHttpClientParams {
16
16
  /**
@@ -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 t,b as p}from"../../chunk-TOYVCWT3.js";import{e}from"../../chunk-GDQBQ7MK.js";e();export{p as createAccelerateHttpClient,t as deserializeRawResult};
9
+ import{a as t,b as p}from"../../chunk-ZDKFUEBN.js";import{e}from"../../chunk-GGFIWHFO.js";e();export{p as createAccelerateHttpClient,t as deserializeRawResult};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9hY2NlbGVyYXRlL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJleHBvcnQge1xuICB0eXBlIERlc2VyaWFsaXplZFJlc3BvbnNlLFxuICBkZXNlcmlhbGl6ZVJhd1Jlc3VsdCxcbiAgdHlwZSBRdWVyeUludHJvc3BlY3Rpb25CdWlsdGluVHlwZSxcbiAgdHlwZSBSYXdSZXNwb25zZSxcbn0gZnJvbSBcIi4vZGVzZXJpYWxpemVyXCI7XG5leHBvcnQge1xuICB0eXBlIEFjY2VsZXJhdGVIdHRwQ2xpZW50LFxuICB0eXBlIEFjY2VsZXJhdGVIdHRwQ2xpZW50UGFyYW1zLFxuICBjcmVhdGVBY2NlbGVyYXRlSHR0cENsaWVudCxcbiAgdHlwZSBTdXBwb3J0ZWRBY2NlbGVyYXRlUHJvdmlkZXIsXG59IGZyb20gXCIuL2h0dHAtY2xpZW50XCI7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7OzswRkFBQUEiLAogICJuYW1lcyI6IFsiaW5pdF9kZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVIiXQp9Cg==
@@ -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{e as l}from"../../chunk-GDQBQ7MK.js";l();l();function F(e){let{customHeaders:t,customPayload:n,resultDeserializerFn:o,url:c}=e,s=e.fetch||fetch;return{async execute(y,p){try{let r=await s(c,{body:JSON.stringify({customPayload:n,procedure:"query",query:y}),headers:{Accept:"application/json","Content-Type":"application/json",...t},method:"POST",signal:p?.abortSignal});if(!r.ok){let a;try{a=await r.text()}catch{a="unknown error"}return[new Error(a)]}let[u,i]=await r.json();return u?[d(u)]:[null,o?.(i)||i]}catch(r){return[r]}},async executeSequence(y,p){try{let r=await s(c,{body:JSON.stringify({customPayload:n,procedure:"sequence",sequence:y}),headers:{Accept:"application/json","Content-Type":"application/json",...t},method:"POST",signal:p?.abortSignal});if(!r.ok){let f;try{f=await r.text()}catch{f="unknown error"}return[[new Error(f)]]}let[[u,i],a]=await r.json();if(u)return[[d(u)]];let S=o?.(i)||i,[g,m]=a||[];return g?[[null,S],[d(g)]]:[[null,S],[null,o?.(m)||m]]}catch(r){return[[r]]}}}}function w(e){if(e instanceof AggregateError){let{name:t,message:n}=e,o=e.errors.map(w);return{name:t,message:n,errors:o}}if(e instanceof Error){let{name:t,message:n}=e;return{name:t,message:n}}return{name:"UnknownError",message:JSON.stringify(e)}}function d(e){let{name:t,message:n}=e;if(e.errors!==void 0){let c=e.errors.map(d),s=new AggregateError(c,n);return s.name=e.name,s}let o=new Error(e.message);return e.name=t,o}export{F as createStudioBFFClient,d as deserializeError,w as serializeError};
9
+ import{e as l}from"../../chunk-GGFIWHFO.js";l();l();function F(e){let{customHeaders:t,customPayload:n,resultDeserializerFn:o,url:c}=e,s=e.fetch||fetch;return{async execute(y,p){try{let r=await s(c,{body:JSON.stringify({customPayload:n,procedure:"query",query:y}),headers:{Accept:"application/json","Content-Type":"application/json",...t},method:"POST",signal:p?.abortSignal});if(!r.ok){let a;try{a=await r.text()}catch{a="unknown error"}return[new Error(a)]}let[u,i]=await r.json();return u?[d(u)]:[null,o?.(i)||i]}catch(r){return[r]}},async executeSequence(y,p){try{let r=await s(c,{body:JSON.stringify({customPayload:n,procedure:"sequence",sequence:y}),headers:{Accept:"application/json","Content-Type":"application/json",...t},method:"POST",signal:p?.abortSignal});if(!r.ok){let f;try{f=await r.text()}catch{f="unknown error"}return[[new Error(f)]]}let[[u,i],a]=await r.json();if(u)return[[d(u)]];let S=o?.(i)||i,[g,m]=a||[];return g?[[null,S],[d(g)]]:[[null,S],[null,o?.(m)||m]]}catch(r){return[[r]]}}}}function w(e){if(e instanceof AggregateError){let{name:t,message:n}=e,o=e.errors.map(w);return{name:t,message:n,errors:o}}if(e instanceof Error){let{name:t,message:n}=e;return{name:t,message:n}}return{name:"UnknownError",message:JSON.stringify(e)}}function d(e){let{name:t,message:n}=e;if(e.errors!==void 0){let c=e.errors.map(d),s=new AggregateError(c,n);return s.name=e.name,s}let o=new Error(e.message);return e.name=t,o}export{F as createStudioBFFClient,d as deserializeError,w as serializeError};
10
10
  //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/bff/index.ts", "../../../data/bff/bff-client.ts"],
  "sourcesContent": ["export * from \"./bff-client\";\n", "import type { ExecuteOptions, SequenceExecutor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\n\nexport interface StudioBFFClientProps {\n  /**\n   * Allows passing custom headers to the BFF.\n   *\n   * e.g. authorization token.\n   */\n  customHeaders?: Record<string, string>;\n\n  /**\n   * Allows passing custom payload to the BFF via `body.customPayload`.\n   *\n   * e.g. tenant id.\n   */\n  customPayload?: Record<string, unknown>;\n\n  /**\n   * Allows overriding the fetch function implementation.\n   *\n   * e.g. for testing, or older Node.js versions.\n   */\n  fetch?: typeof globalThis.fetch;\n\n  /**\n   * Function used to deserialize the results of queries.\n   *\n   * By default, the results are returned as is without any additional processing.\n   */\n  resultDeserializerFn?(this: void, results: unknown): unknown[];\n\n  /**\n   * BFF endpoint URL.\n   *\n   * e.g. `https://api.example.com/studio`\n   */\n  url: string | URL;\n}\n\nexport interface StudioBFFClient extends SequenceExecutor {\n  /**\n   * Requests BFF to query the database.\n   *\n   * The query is sent as `body.query`.\n   */\n  execute<T>(this: void, query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;\n\n  /**\n   * Requests BFF to execute a sequence of queries.\n   *\n   * The sequence is sent as `body.sequence`.\n   */\n  executeSequence<T, S>(\n    this: void,\n    sequence: readonly [Query<T>, Query<S>],\n    options?: ExecuteOptions,\n  ): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;\n}\n\nexport type StudioBFFRequest = StudioBFFQueryRequest | StudioBFFSequenceRequest;\n\nexport interface StudioBFFQueryRequest {\n  customPayload?: Record<string, unknown>;\n  procedure: \"query\";\n  query: Query<unknown>;\n}\n\nexport interface StudioBFFSequenceRequest {\n  customPayload?: Record<string, unknown>;\n  procedure: \"sequence\";\n  sequence: readonly [Query<unknown>, Query<unknown>];\n}\n\n/**\n * Creates a Studio BFF client. BFF stands for \"Backend For Frontend\" btw.\n */\nexport function createStudioBFFClient(props: StudioBFFClientProps): StudioBFFClient {\n  const { customHeaders, customPayload, resultDeserializerFn, url } = props;\n  const fetchFn = props.fetch || fetch;\n\n  return {\n    async execute(query, options) {\n      try {\n        const response = await fetchFn(url, {\n          body: JSON.stringify({ customPayload, procedure: \"query\", query } satisfies StudioBFFQueryRequest),\n          headers: {\n            Accept: \"application/json\",\n            \"Content-Type\": \"application/json\",\n            ...customHeaders,\n          },\n          method: \"POST\",\n          signal: options?.abortSignal,\n        });\n\n        if (!response.ok) {\n          let errorText: string;\n\n          try {\n            errorText = await response.text();\n          } catch {\n            errorText = \"unknown error\";\n          }\n\n          return [new Error(errorText)];\n        }\n\n        const [error, results] = (await response.json()) as [SerializedError, unknown];\n\n        if (error) {\n          return [deserializeError(error)];\n        }\n\n        return [null, (resultDeserializerFn?.(results) || results) as never];\n      } catch (error: unknown) {\n        return [error as Error];\n      }\n    },\n\n    async executeSequence(sequence, options) {\n      try {\n        const response = await fetchFn(url, {\n          body: JSON.stringify({ customPayload, procedure: \"sequence\", sequence } satisfies StudioBFFSequenceRequest),\n          headers: {\n            Accept: \"application/json\",\n            \"Content-Type\": \"application/json\",\n            ...customHeaders,\n          },\n          method: \"POST\",\n          signal: options?.abortSignal,\n        });\n\n        if (!response.ok) {\n          let errorText: string;\n\n          try {\n            errorText = await response.text();\n          } catch {\n            errorText = \"unknown error\";\n          }\n\n          return [[new Error(errorText)]];\n        }\n\n        const [[firstError, firstResult], maybeSecondResult] = (await response.json()) as [\n          [SerializedError, unknown],\n          ...[SerializedError, unknown][],\n        ];\n\n        if (firstError) {\n          return [[deserializeError(firstError)]];\n        }\n\n        const firstDeserializedResult = (resultDeserializerFn?.(firstResult) || firstResult) as never;\n\n        const [secondError, secondResult] = maybeSecondResult || [];\n\n        if (secondError) {\n          return [[null, firstDeserializedResult], [deserializeError(secondError)]];\n        }\n\n        return [\n          [null, firstDeserializedResult],\n          [null, (resultDeserializerFn?.(secondResult) || secondResult) as never],\n        ];\n      } catch (error: unknown) {\n        return [[error as Error]];\n      }\n    },\n  };\n}\n\nexport interface SerializedError {\n  message: string;\n  name: string;\n  errors?: SerializedError[];\n}\n\nexport function serializeError(error: unknown): SerializedError {\n  if (error instanceof AggregateError) {\n    const { name, message } = error;\n    const errors = error.errors.map(serializeError);\n    return { name, message, errors };\n  }\n\n  if (error instanceof Error) {\n    const { name, message } = error;\n    return { name, message };\n  }\n\n  return { name: `UnknownError`, message: JSON.stringify(error) };\n}\n\nexport function deserializeError(error: SerializedError): Error {\n  const { name, message } = error;\n\n  if (error.errors !== undefined) {\n    const errors = error.errors.map(deserializeError);\n    const aggregateError = new AggregateError(errors, message);\n    aggregateError.name = error.name;\n    return aggregateError;\n  }\n\n  const regularError = new Error(error.message);\n  error.name = name;\n  return regularError;\n}\n"],
  "mappings": "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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "createStudioBFFClient", "props", "customHeaders", "customPayload", "resultDeserializerFn", "url", "fetchFn", "query", "options", "response", "errorText", "error", "results", "deserializeError", "sequence", "firstError", "firstResult", "maybeSecondResult", "firstDeserializedResult", "secondError", "secondResult", "serializeError", "name", "message", "errors", "aggregateError", "regularError"]
}

@@ -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 r,b as t,c as p,d as o,e as y,f,g as x,h as m}from"../chunk-V6UBAFT2.js";import{e}from"../chunk-GDQBQ7MK.js";e();export{f as DEFAULT_ARRAY_DISPLAY,m as DEFAULT_ARRAY_VALUE,y as DEFAULT_BOOLEAN,x as DEFAULT_JSON,o as DEFAULT_NUMERIC,p as DEFAULT_STRING,r as applyInferredRowFilters,t as getDate0};
9
+ import{A as r,b as t,c as p,d as o,e as y,f,g as x,h as m}from"../chunk-UHDZB3FI.js";import{e}from"../chunk-GGFIWHFO.js";e();export{f as DEFAULT_ARRAY_DISPLAY,m as DEFAULT_ARRAY_VALUE,y as DEFAULT_BOOLEAN,x as DEFAULT_JSON,o as DEFAULT_NUMERIC,p as DEFAULT_STRING,r as applyInferredRowFilters,t as getDate0};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vZGF0YS9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiZXhwb3J0IHR5cGUgKiBmcm9tIFwiLi9hZGFwdGVyXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kZWZhdWx0c1wiO1xuZXhwb3J0IHR5cGUgKiBmcm9tIFwiLi9leGVjdXRvclwiO1xuZXhwb3J0IHsgYXBwbHlJbmZlcnJlZFJvd0ZpbHRlcnMsIHR5cGUgUXVlcnksIHR5cGUgUXVlcnlSZXN1bHQgfSBmcm9tIFwiLi9xdWVyeVwiO1xuZXhwb3J0IHR5cGUgKiBmcm9tIFwiLi90eXBlLXV0aWxzXCI7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozt5SEFBQUEiLAogICJuYW1lcyI6IFsiaW5pdF9kZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVIiXQp9Cg==
@@ -6,6 +6,6 @@ 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 $}from"../../chunk-CUMTLWHY.js";import{a as se}from"../../chunk-ZUEQ555M.js";import{a as i}from"../../chunk-I4OGOLAT.js";import{A as O,B as F,C as q,D as z,q as _,v as j,w as P,x as Y,z as T}from"../../chunk-V6UBAFT2.js";import{e as E}from"../../chunk-GDQBQ7MK.js";E();E();E();var H={bigint:{group:"numeric"},binary:{group:"string"},bit:{group:"raw"},blob:{group:"string"},char:{group:"string"},"char binary":{group:"string"},date:{format:"YYYY-MM-DD",group:"datetime"},datetime:{format:"YYYY-MM-DD HH:mm:ss.SSS",group:"datetime"},dec:{group:"numeric"},decimal:{group:"numeric"},double:{group:"numeric"},"double precision":{group:"numeric"},enum:{group:"enum"},fixed:{group:"numeric"},float:{group:"numeric"},geometry:{group:"raw"},geometrycollection:{group:"raw"},int:{group:"numeric"},integer:{group:"numeric"},json:{group:"json"},linestring:{group:"raw"},long:{group:"string"},"long varchar":{group:"string"},longblob:{group:"string"},longtext:{group:"string"},longvarbinary:{group:"string"},longvarchar:{group:"string"},mediumblob:{group:"string"},mediumint:{group:"numeric"},mediumtext:{group:"string"},multilinestring:{group:"raw"},multipoint:{group:"raw"},multipolygon:{group:"raw"},numeric:{group:"numeric"},point:{group:"raw"},polygon:{group:"raw"},real:{group:"numeric"},set:{group:"raw"},smallint:{group:"numeric"},text:{group:"string"},time:{format:"HH:mm:ss.SSS",group:"time"},timestamp:{format:"YYYY-MM-DD HH:mm:ss.SSS",group:"datetime"},tinyblob:{group:"string"},tinyint:{group:"numeric"},tinytext:{group:"string"},varbinary:{group:"string"},varchar:{group:"string"},"varchar binary":{group:"string"},vector:{group:"raw"},year:{format:"YYYY",group:"numeric"}};E();E();function R(o){return Y({...o,Adapter:P,QueryCompiler:j})}function v(o,t){let{rows:r,table:{columns:u,name:n}}=o,e=R(t);return T(e.deleteFrom(n).$call(O(r,u)).$castTo())}function L(o,t){let{rows:r,table:{columns:u,name:n}}=o,e=R(t);return T(e.insertInto(n).values(q({columns:u,context:"insert",supportsDefaultKeyword:!0,values:r})).$castTo())}function C(o,t){let{criteria:r,table:{columns:u,name:n}}=o,e=R(t);return T(e.selectFrom(n).$call(O(r,u)).select(Object.keys(u)).select(J().as("__ps_inserted_at__")))}function G(o,t){let{changes:r,row:u,table:{columns:n,name:e}}=o,s=R(t);return T(s.selectFrom(e).$call(O([{...u,...r}],n)).select(Object.keys(n)).select(J().as("__ps_updated_at__")))}function K(o,t){let{filter:r={after:"and",filters:[],kind:"FilterGroup"},pageIndex:u,pageSize:n,sortOrder:e,table:{columns:s,name:m}}=o,y=R(t),c=z(r.filters,s),A="__ps_agg__",g="__ps_count__",f=y.selectFrom(m).where(c).select(l=>l.cast(l.fn.coalesce(l.fn.countAll(),_.lit(0)),"char").as(g));return T(y.with(A,()=>f).selectFrom(m).innerJoin(A,l=>l.onTrue()).where(c).select(`${A}.${g}`).select(Object.keys(s)).$call(l=>e.reduce((b,a)=>b.orderBy(a.column,a.direction),l)).limit(n).offset(_.lit(BigInt(u)*BigInt(n))))}function Ee(){return[]}function V(o,t){let{changes:r,row:u,table:{columns:n,name:e,schema:s}}=o,m=R(t);return T(m.withSchema(s).updateTable(e).set(q({columns:n,context:"update",supportsDefaultKeyword:!0,values:r})).$call(O([u],n)).$castTo())}function J(){return _`cast(unix_timestamp(now(3)) * 1000 as unsigned)`}E();E();function W(o){return _`(select cast(coalesce(json_arrayagg(json_object(${_.join(oe(o.toOperationNode(),"agg"))})), '[]') as json) from ${o} as agg)`}function oe(o,t){try{return $(o,t)}catch{throw new Error("MySQL 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 X(o){return T(R(o).selectFrom("information_schema.tables as t").where("t.TABLE_SCHEMA","=",_`database()`).where("t.TABLE_TYPE","in",["BASE TABLE","VIEW"]).select(["t.TABLE_SCHEMA as schema","t.TABLE_NAME as name","t.TABLE_TYPE as type"]).$narrowType().select(t=>W(t.selectFrom("information_schema.columns as c").leftJoin("information_schema.KEY_COLUMN_USAGE as kcu",r=>r.onRef("kcu.TABLE_SCHEMA","=","c.TABLE_SCHEMA").onRef("kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("kcu.POSITION_IN_UNIQUE_CONSTRAINT","is not",null)).leftJoin("information_schema.KEY_COLUMN_USAGE as pk_kcu",r=>r.onRef("pk_kcu.TABLE_SCHEMA","=","c.TABLE_SCHEMA").onRef("pk_kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("pk_kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("pk_kcu.CONSTRAINT_NAME","=","PRIMARY")).whereRef("c.TABLE_SCHEMA","=","t.TABLE_SCHEMA").whereRef("c.TABLE_NAME","=","t.TABLE_NAME").select(["c.COLUMN_DEFAULT as default","c.COLUMN_NAME as name","c.COLUMN_TYPE as datatype","c.ORDINAL_POSITION as position","kcu.REFERENCED_TABLE_NAME as fk_table","kcu.REFERENCED_COLUMN_NAME as fk_column","pk_kcu.ORDINAL_POSITION as pk"]).select(r=>[r("c.EXTRA","=","auto_increment").as("autoincrement"),r("c.EXTRA","in",["on update CURRENT_TIMESTAMP","STORED GENERATED","VIRTUAL GENERATED"]).as("computed"),r("c.IS_NULLABLE","=","YES").as("nullable")])).as("columns")).orderBy("t.TABLE_SCHEMA").orderBy("t.TABLE_NAME").orderBy("t.TABLE_TYPE"))}function Z(){return[{columns:[{autoincrement:1,computed:0,datatype:"int",default:null,fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"binary(16)",default:"uuid_to_bin(uuid())",fk_column:null,fk_table:null,name:"uuid",nullable:1,pk:null,position:2},{autoincrement:0,computed:0,datatype:"varchar(255)",default:null,fk_column:null,fk_table:null,name:"name",nullable:1,pk:null,position:3},{autoincrement:0,computed:1,datatype:"text",default:null,fk_column:null,fk_table:null,name:"id_name",nullable:1,pk:null,position:4}],name:"animals",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:0,computed:0,datatype:"char(36)",default:"uuid()",fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"text",default:null,fk_column:null,fk_table:null,name:"name",nullable:0,pk:2,position:2},{autoincrement:0,computed:0,datatype:"timestamp",default:"CURRENT_TIMESTAMP",fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:null,position:3}],name:"composite_pk",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:1,computed:0,datatype:"int",default:null,fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"timestamp",default:null,fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:null,position:2},{autoincrement:0,computed:0,datatype:"enum('admin','maintainer','member')",default:null,fk_column:null,fk_table:null,name:"role",nullable:0,pk:null,position:3},{autoincrement:0,computed:0,datatype:"int",default:null,fk_column:"id",fk_table:"animals",name:"animal_id",nullable:1,pk:null,position:4}],name:"users",schema:"studio",type:"BASE TABLE"}]}function ee(o){let t=R(o),r=_`@@session.time_zone`;return T(t.selectNoFrom(t.case().when(r,"=","SYSTEM").then(_`@@system_time_zone`).else(r).end().as("timezone")).$narrowType())}function re(){return[{timezone:"UTC"}]}function Ce(o){let{executor:t,...r}=o;return{async delete(u,n){try{let e=v(u,r),[s]=await t.execute(e,n);return s?i({error:s,query:e}):[null,{...u,query:e}]}catch(e){return i({error:e})}},async insert(u,n){try{let{rows:e,table:s}=u,{columns:m}=s,y=Object.values(m).find(a=>a.isAutoincrement),c=e.map(a=>F(a,m)),A=c.some(a=>{let p=Object.values(a);return p.length===0||p.some(d=>d==null)});if(!y&&A)return i({error:new Error("Cannot proceed with the insertion, some rows cannot be refetched after insertion."),query:L(u,r)});if(!A){let a=L(u,r),p=C({criteria:c,table:s},r),d=[a,p],[[h],N]=await t.executeSequence(d,n),k=Q(d);if(h)return i({error:h,query:k});let[M,S]=N;return M?i({error:new Error("Failed to refetch inserted rows - please refresh.",{cause:M}),query:k}):[null,{rows:S,query:k}]}let g=await Promise.all(e.map(async a=>{let p=L({rows:[a],table:s},r),[d,h]=await t.execute(p,n);if(d)return i({error:d,query:p});let{name:N}=y,k=a[N]||h[0]?.insertId;if(!k)return i({error:new Error("Could not determine value for autoincrement column to refetch inserted row."),query:p});let M=C({criteria:[{[N]:k}],table:{...s,columns:Object.values(m).reduce((x,D)=>{let{name:U}=D;return x[U]={...D,pkPosition:U===N?1:null},x},{})}},r),[S,ne]=await t.execute(M,n),B=Q([p,M]);if(S)return console.error("Error refetching inserted row:",S),i({error:new Error("Failed to refetch inserted row - please refresh.",{cause:S}),query:B});let[I]=ne;return I?[null,{row:I,query:B}]:i({error:new Error("Refetch query returned no results for inserted row."),query:B})})),f=[],l=null,b=[];for(let a=0;a<g.length;a++){let[p,d]=g[a];p?(b.push([a,p]),p.query&&(l=l?Q([l,p.query]):p.query)):(f.push(d.row),d.query&&(l=l?Q([l,d.query]):d.query))}return b.length>0?i({error:new AggregateError(b.map(([,a])=>a),`Row${b.length>1?"s":""} ${b.map(([a])=>a).join(", ")} could not be inserted or refetched.`),query:l}):[null,{rows:f,query:l}]}catch(e){return i({error:e})}},async introspect(u){try{let n=X(o),e=ee(o),[[s,m],[y,c]]=await Promise.all([t.execute(n,u),t.execute(e,u)]);if(s)return i({error:s,query:n});if(y)return i({error:y,query:e});let A=c[0]?.timezone;return A?[null,te({query:n,tables:m,timezone:A})]:i({error:new Error("Timezone not found"),query:e})}catch(n){return i({error:n})}},async query(u,n){try{let e=K(u,r),[s,m]=await t.execute(e,n);return s?i({error:s,query:e}):[null,{filteredRowCount:m[0]?.__ps_count__||"0",rows:m,query:e}]}catch(e){return i({error:e})}},async update(u,n){try{let e=V(u,r),s=G(u,r),[[m],y]=await t.executeSequence([e,s],n);if(m)return i({error:m,query:e});let[c,A]=y;if(c)return i({error:c,query:e});let[g]=A;return g?[null,{row:g,query:e}]:i({error:new Error("Updated row not found"),query:e})}catch(e){return i({error:e})}}}}function te(o){let{query:t,tables:r,timezone:u}=o;return r.reduce((n,e)=>{let{schemas:s}=n,{columns:m,name:y,schema:c}=e,A=m.sort((g,f)=>g.position-f.position).reduce((g,f)=>{let{datatype:l,default:b,name:a}=f,p=l.indexOf("("),d=(p>-1?l.substring(0,p):l).trim().toLowerCase(),h=!!f.autoincrement,N=!!f.computed,k=!!f.nullable;return{...g,[a]:{datatype:{...H[d]||{group:"raw"},isArray:!1,isNative:!0,name:d,options:d==="enum"?l.slice(6,-2).split("','"):[],schema:c},defaultValue:b,fkColumn:f.fk_column,fkSchema:c,fkTable:f.fk_table,isAutoincrement:h,isComputed:N,isRequired:!k&&!h&&!N&&b==null,name:a,nullable:k,pkPosition:f.pk,schema:c,table:y}}},{});return s[c]===void 0&&(s[c]={name:c,tables:{}}),s[c].tables[y]={columns:A,name:y,schema:c},n},{filterOperators:ue,query:t,schemas:{},timezone:u})}var ue=["=","!=",">",">=","<","<=","is","is not","like","not like"];function Ie(){let o=Z(),[{timezone:t}]=re();return te({tables:o,timezone:t,query:{parameters:[],sql:"<mocked>"}})}function Q(o){let[t,r]=o;return{parameters:t.parameters.concat(r.parameters),sql:`${t.sql};
9
+ import{a as $}from"../../chunk-WEUE32ZL.js";import{a as se}from"../../chunk-6MJRFEB4.js";import{a as i}from"../../chunk-V6YDTHJJ.js";import{A as O,B as F,C as q,D as z,q as _,v as j,w as P,x as Y,z as T}from"../../chunk-UHDZB3FI.js";import{e as E}from"../../chunk-GGFIWHFO.js";E();E();E();var H={bigint:{group:"numeric"},binary:{group:"string"},bit:{group:"raw"},blob:{group:"string"},char:{group:"string"},"char binary":{group:"string"},date:{format:"YYYY-MM-DD",group:"datetime"},datetime:{format:"YYYY-MM-DD HH:mm:ss.SSS",group:"datetime"},dec:{group:"numeric"},decimal:{group:"numeric"},double:{group:"numeric"},"double precision":{group:"numeric"},enum:{group:"enum"},fixed:{group:"numeric"},float:{group:"numeric"},geometry:{group:"raw"},geometrycollection:{group:"raw"},int:{group:"numeric"},integer:{group:"numeric"},json:{group:"json"},linestring:{group:"raw"},long:{group:"string"},"long varchar":{group:"string"},longblob:{group:"string"},longtext:{group:"string"},longvarbinary:{group:"string"},longvarchar:{group:"string"},mediumblob:{group:"string"},mediumint:{group:"numeric"},mediumtext:{group:"string"},multilinestring:{group:"raw"},multipoint:{group:"raw"},multipolygon:{group:"raw"},numeric:{group:"numeric"},point:{group:"raw"},polygon:{group:"raw"},real:{group:"numeric"},set:{group:"raw"},smallint:{group:"numeric"},text:{group:"string"},time:{format:"HH:mm:ss.SSS",group:"time"},timestamp:{format:"YYYY-MM-DD HH:mm:ss.SSS",group:"datetime"},tinyblob:{group:"string"},tinyint:{group:"numeric"},tinytext:{group:"string"},varbinary:{group:"string"},varchar:{group:"string"},"varchar binary":{group:"string"},vector:{group:"raw"},year:{format:"YYYY",group:"numeric"}};E();E();function R(o){return Y({...o,Adapter:P,QueryCompiler:j})}function v(o,t){let{rows:r,table:{columns:u,name:n}}=o,e=R(t);return T(e.deleteFrom(n).$call(O(r,u)).$castTo())}function L(o,t){let{rows:r,table:{columns:u,name:n}}=o,e=R(t);return T(e.insertInto(n).values(q({columns:u,context:"insert",supportsDefaultKeyword:!0,values:r})).$castTo())}function C(o,t){let{criteria:r,table:{columns:u,name:n}}=o,e=R(t);return T(e.selectFrom(n).$call(O(r,u)).select(Object.keys(u)).select(J().as("__ps_inserted_at__")))}function G(o,t){let{changes:r,row:u,table:{columns:n,name:e}}=o,s=R(t);return T(s.selectFrom(e).$call(O([{...u,...r}],n)).select(Object.keys(n)).select(J().as("__ps_updated_at__")))}function K(o,t){let{filter:r={after:"and",filters:[],kind:"FilterGroup"},pageIndex:u,pageSize:n,sortOrder:e,table:{columns:s,name:m}}=o,y=R(t),c=z(r.filters,s),A="__ps_agg__",g="__ps_count__",f=y.selectFrom(m).where(c).select(l=>l.cast(l.fn.coalesce(l.fn.countAll(),_.lit(0)),"char").as(g));return T(y.with(A,()=>f).selectFrom(m).innerJoin(A,l=>l.onTrue()).where(c).select(`${A}.${g}`).select(Object.keys(s)).$call(l=>e.reduce((b,a)=>b.orderBy(a.column,a.direction),l)).limit(n).offset(_.lit(BigInt(u)*BigInt(n))))}function Ee(){return[]}function V(o,t){let{changes:r,row:u,table:{columns:n,name:e,schema:s}}=o,m=R(t);return T(m.withSchema(s).updateTable(e).set(q({columns:n,context:"update",supportsDefaultKeyword:!0,values:r})).$call(O([u],n)).$castTo())}function J(){return _`cast(unix_timestamp(now(3)) * 1000 as unsigned)`}E();E();function W(o){return _`(select cast(coalesce(json_arrayagg(json_object(${_.join(oe(o.toOperationNode(),"agg"))})), '[]') as json) from ${o} as agg)`}function oe(o,t){try{return $(o,t)}catch{throw new Error("MySQL 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 X(o){return T(R(o).selectFrom("information_schema.tables as t").where("t.TABLE_SCHEMA","=",_`database()`).where("t.TABLE_TYPE","in",["BASE TABLE","VIEW"]).select(["t.TABLE_SCHEMA as schema","t.TABLE_NAME as name","t.TABLE_TYPE as type"]).$narrowType().select(t=>W(t.selectFrom("information_schema.columns as c").leftJoin("information_schema.KEY_COLUMN_USAGE as kcu",r=>r.onRef("kcu.TABLE_SCHEMA","=","c.TABLE_SCHEMA").onRef("kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("kcu.POSITION_IN_UNIQUE_CONSTRAINT","is not",null)).leftJoin("information_schema.KEY_COLUMN_USAGE as pk_kcu",r=>r.onRef("pk_kcu.TABLE_SCHEMA","=","c.TABLE_SCHEMA").onRef("pk_kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("pk_kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("pk_kcu.CONSTRAINT_NAME","=","PRIMARY")).whereRef("c.TABLE_SCHEMA","=","t.TABLE_SCHEMA").whereRef("c.TABLE_NAME","=","t.TABLE_NAME").select(["c.COLUMN_DEFAULT as default","c.COLUMN_NAME as name","c.COLUMN_TYPE as datatype","c.ORDINAL_POSITION as position","kcu.REFERENCED_TABLE_NAME as fk_table","kcu.REFERENCED_COLUMN_NAME as fk_column","pk_kcu.ORDINAL_POSITION as pk"]).select(r=>[r("c.EXTRA","=","auto_increment").as("autoincrement"),r("c.EXTRA","in",["on update CURRENT_TIMESTAMP","STORED GENERATED","VIRTUAL GENERATED"]).as("computed"),r("c.IS_NULLABLE","=","YES").as("nullable")])).as("columns")).orderBy("t.TABLE_SCHEMA").orderBy("t.TABLE_NAME").orderBy("t.TABLE_TYPE"))}function Z(){return[{columns:[{autoincrement:1,computed:0,datatype:"int",default:null,fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"binary(16)",default:"uuid_to_bin(uuid())",fk_column:null,fk_table:null,name:"uuid",nullable:1,pk:null,position:2},{autoincrement:0,computed:0,datatype:"varchar(255)",default:null,fk_column:null,fk_table:null,name:"name",nullable:1,pk:null,position:3},{autoincrement:0,computed:1,datatype:"text",default:null,fk_column:null,fk_table:null,name:"id_name",nullable:1,pk:null,position:4}],name:"animals",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:0,computed:0,datatype:"char(36)",default:"uuid()",fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"text",default:null,fk_column:null,fk_table:null,name:"name",nullable:0,pk:2,position:2},{autoincrement:0,computed:0,datatype:"timestamp",default:"CURRENT_TIMESTAMP",fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:null,position:3}],name:"composite_pk",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:1,computed:0,datatype:"int",default:null,fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"timestamp",default:null,fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:null,position:2},{autoincrement:0,computed:0,datatype:"enum('admin','maintainer','member')",default:null,fk_column:null,fk_table:null,name:"role",nullable:0,pk:null,position:3},{autoincrement:0,computed:0,datatype:"int",default:null,fk_column:"id",fk_table:"animals",name:"animal_id",nullable:1,pk:null,position:4}],name:"users",schema:"studio",type:"BASE TABLE"}]}function ee(o){let t=R(o),r=_`@@session.time_zone`;return T(t.selectNoFrom(t.case().when(r,"=","SYSTEM").then(_`@@system_time_zone`).else(r).end().as("timezone")).$narrowType())}function re(){return[{timezone:"UTC"}]}function Ce(o){let{executor:t,...r}=o;return{async delete(u,n){try{let e=v(u,r),[s]=await t.execute(e,n);return s?i({error:s,query:e}):[null,{...u,query:e}]}catch(e){return i({error:e})}},async insert(u,n){try{let{rows:e,table:s}=u,{columns:m}=s,y=Object.values(m).find(a=>a.isAutoincrement),c=e.map(a=>F(a,m)),A=c.some(a=>{let p=Object.values(a);return p.length===0||p.some(d=>d==null)});if(!y&&A)return i({error:new Error("Cannot proceed with the insertion, some rows cannot be refetched after insertion."),query:L(u,r)});if(!A){let a=L(u,r),p=C({criteria:c,table:s},r),d=[a,p],[[h],N]=await t.executeSequence(d,n),k=Q(d);if(h)return i({error:h,query:k});let[M,S]=N;return M?i({error:new Error("Failed to refetch inserted rows - please refresh.",{cause:M}),query:k}):[null,{rows:S,query:k}]}let g=await Promise.all(e.map(async a=>{let p=L({rows:[a],table:s},r),[d,h]=await t.execute(p,n);if(d)return i({error:d,query:p});let{name:N}=y,k=a[N]||h[0]?.insertId;if(!k)return i({error:new Error("Could not determine value for autoincrement column to refetch inserted row."),query:p});let M=C({criteria:[{[N]:k}],table:{...s,columns:Object.values(m).reduce((x,D)=>{let{name:U}=D;return x[U]={...D,pkPosition:U===N?1:null},x},{})}},r),[S,ne]=await t.execute(M,n),B=Q([p,M]);if(S)return console.error("Error refetching inserted row:",S),i({error:new Error("Failed to refetch inserted row - please refresh.",{cause:S}),query:B});let[I]=ne;return I?[null,{row:I,query:B}]:i({error:new Error("Refetch query returned no results for inserted row."),query:B})})),f=[],l=null,b=[];for(let a=0;a<g.length;a++){let[p,d]=g[a];p?(b.push([a,p]),p.query&&(l=l?Q([l,p.query]):p.query)):(f.push(d.row),d.query&&(l=l?Q([l,d.query]):d.query))}return b.length>0?i({error:new AggregateError(b.map(([,a])=>a),`Row${b.length>1?"s":""} ${b.map(([a])=>a).join(", ")} could not be inserted or refetched.`),query:l}):[null,{rows:f,query:l}]}catch(e){return i({error:e})}},async introspect(u){try{let n=X(o),e=ee(o),[[s,m],[y,c]]=await Promise.all([t.execute(n,u),t.execute(e,u)]);if(s)return i({error:s,query:n});if(y)return i({error:y,query:e});let A=c[0]?.timezone;return A?[null,te({query:n,tables:m,timezone:A})]:i({error:new Error("Timezone not found"),query:e})}catch(n){return i({error:n})}},async query(u,n){try{let e=K(u,r),[s,m]=await t.execute(e,n);return s?i({error:s,query:e}):[null,{filteredRowCount:m[0]?.__ps_count__||"0",rows:m,query:e}]}catch(e){return i({error:e})}},async update(u,n){try{let e=V(u,r),s=G(u,r),[[m],y]=await t.executeSequence([e,s],n);if(m)return i({error:m,query:e});let[c,A]=y;if(c)return i({error:c,query:e});let[g]=A;return g?[null,{row:g,query:e}]:i({error:new Error("Updated row not found"),query:e})}catch(e){return i({error:e})}}}}function te(o){let{query:t,tables:r,timezone:u}=o;return r.reduce((n,e)=>{let{schemas:s}=n,{columns:m,name:y,schema:c}=e,A=m.sort((g,f)=>g.position-f.position).reduce((g,f)=>{let{datatype:l,default:b,name:a}=f,p=l.indexOf("("),d=(p>-1?l.substring(0,p):l).trim().toLowerCase(),h=!!f.autoincrement,N=!!f.computed,k=!!f.nullable;return{...g,[a]:{datatype:{...H[d]||{group:"raw"},isArray:!1,isNative:!0,name:d,options:d==="enum"?l.slice(6,-2).split("','"):[],schema:c},defaultValue:b,fkColumn:f.fk_column,fkSchema:c,fkTable:f.fk_table,isAutoincrement:h,isComputed:N,isRequired:!k&&!h&&!N&&b==null,name:a,nullable:k,pkPosition:f.pk,schema:c,table:y}}},{});return s[c]===void 0&&(s[c]={name:c,tables:{}}),s[c].tables[y]={columns:A,name:y,schema:c},n},{filterOperators:ue,query:t,schemas:{},timezone:u})}var ue=["=","!=",">",">=","<","<=","is","is not","like","not like"];function Ie(){let o=Z(),[{timezone:t}]=re();return te({tables:o,timezone:t,query:{parameters:[],sql:"<mocked>"}})}function Q(o){let[t,r]=o;return{parameters:t.parameters.concat(r.parameters),sql:`${t.sql};
10
10
  ${r.sql}`}}export{Ce as createMySQLAdapter,se as getCancelQuery,v as getDeleteQuery,L as getInsertQuery,C as getInsertRefetchQuery,K as getSelectQuery,X as getTablesQuery,ee as getTimezoneQuery,V as getUpdateQuery,G as getUpdateRefetchQuery,Ie as mockIntrospect,Ee as mockSelectQuery,Z as mockTablesQuery,re as mockTimezoneQuery};
11
11
  //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/mysql-core/index.ts", "../../../data/mysql-core/adapter.ts", "../../../data/mysql-core/datatype.ts", "../../../data/mysql-core/dml.ts", "../../../data/mysql-core/builder.ts", "../../../data/mysql-core/introspection.ts", "../../../../../node_modules/.pnpm/kysely@0.28.8/node_modules/kysely/dist/esm/helpers/mysql.js"],
  "sourcesContent": ["export * from \"./adapter\";\nexport * from \"./dml\";\nexport * from \"./introspection\";\nexport * from \"./utility\";\n", "import {\n  type Adapter,\n  type AdapterDeleteResult,\n  type AdapterError,\n  type AdapterInsertResult,\n  type AdapterIntrospectResult,\n  type AdapterQueryResult,\n  type AdapterRequirements,\n  type AdapterUpdateResult,\n  type Column,\n  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport type { SequenceExecutor } from \"../executor\";\nimport { inferFilterObject, type Query, type QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { MYSQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport {\n  getDeleteQuery,\n  getInsertQuery,\n  getInsertRefetchQuery,\n  getSelectQuery,\n  getUpdateQuery,\n  getUpdateRefetchQuery,\n} from \"./dml\";\nimport { getTablesQuery, getTimezoneQuery, mockTablesQuery, mockTimezoneQuery } from \"./introspection\";\n\nexport type MySQLAdapterRequirements = Omit<AdapterRequirements, \"executor\"> & {\n  executor: SequenceExecutor;\n};\n\nexport function createMySQLAdapter(requirements: MySQLAdapterRequirements): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n\n  return {\n    async delete(details, options): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n\n        const [error] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { ...details, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async insert(details, options): Promise<Either<AdapterError, AdapterInsertResult>> {\n      try {\n        const { rows, table } = details;\n        const { columns } = table;\n\n        const autoincrementColumn: Column | undefined = Object.values(columns).find((column) => column.isAutoincrement);\n\n        const filterObjects = rows.map((row) => inferFilterObject(row, columns));\n\n        const hasPartialFilterObjects = filterObjects.some((filterObject) => {\n          const filterValues = Object.values(filterObject);\n\n          return filterValues.length === 0 || filterValues.some((value) => value == null);\n        });\n\n        // TODO: handle classic partial filter object cases (e.g. uuid) here or before requesting from adapter.\n        if (!autoincrementColumn && hasPartialFilterObjects) {\n          return createAdapterError({\n            error: new Error(\"Cannot proceed with the insertion, some rows cannot be refetched after insertion.\"),\n            query: getInsertQuery(details, otherRequirements),\n          });\n        }\n\n        if (!hasPartialFilterObjects) {\n          const insertQuery = getInsertQuery(details, otherRequirements);\n          const refetchQuery = getInsertRefetchQuery({ criteria: filterObjects, table }, otherRequirements);\n          const sequence = [insertQuery, refetchQuery] as const;\n\n          const [[insertError], maybeRefetchResult] = await executor.executeSequence(sequence, options);\n\n          const query = joinSequence(sequence);\n\n          if (insertError) {\n            return createAdapterError({ error: insertError, query });\n          }\n\n          const [refetchError, refetchResults] = maybeRefetchResult!;\n\n          if (refetchError) {\n            return createAdapterError({\n              error: new Error(\"Failed to refetch inserted rows - please refresh.\", { cause: refetchError }),\n              query,\n            });\n          }\n\n          return [null, { rows: refetchResults, query }];\n        }\n\n        // has autoincrement column - insert rows one by one and refetch, taking advantage of `insertId` if inserted row has no value for this column.\n        const results = await Promise.all(\n          rows.map(async (row) => {\n            const insertQuery = getInsertQuery({ rows: [row], table }, otherRequirements);\n\n            const [error, result] = await executor.execute(insertQuery, options);\n\n            if (error) {\n              return createAdapterError({ error, query: insertQuery });\n            }\n\n            const { name: autoincrementColumnName } = autoincrementColumn!;\n\n            const value = row[autoincrementColumnName] || result[0]?.insertId;\n\n            if (!value) {\n              return createAdapterError({\n                error: new Error(\"Could not determine value for autoincrement column to refetch inserted row.\"),\n                query: insertQuery,\n              });\n            }\n\n            const refetchQuery = getInsertRefetchQuery(\n              {\n                criteria: [{ [autoincrementColumnName]: value }],\n                table: {\n                  ...table,\n                  // FIXME: dirty hack to mark autoincrement column as THE primary key for refetching.\n                  columns: Object.values(columns).reduce(\n                    (acc, column) => {\n                      const { name: columnName } = column;\n\n                      acc[columnName] = {\n                        ...column,\n                        pkPosition: columnName === autoincrementColumnName ? 1 : null,\n                      };\n\n                      return acc;\n                    },\n                    {} as Table[\"columns\"],\n                  ),\n                },\n              },\n              otherRequirements,\n            );\n\n            const [refetchError, refetchResults] = await executor.execute(refetchQuery, options);\n\n            const query = joinSequence([insertQuery, refetchQuery]);\n\n            if (refetchError) {\n              console.error(\"Error refetching inserted row:\", refetchError);\n\n              return createAdapterError({\n                error: new Error(\"Failed to refetch inserted row - please refresh.\", { cause: refetchError }),\n                query,\n              });\n            }\n\n            const [refetchedRow] = refetchResults;\n\n            if (!refetchedRow) {\n              return createAdapterError({\n                error: new Error(\"Refetch query returned no results for inserted row.\"),\n                query,\n              });\n            }\n\n            return [null, { row: refetchedRow, query }] as const;\n          }),\n        );\n\n        const insertedRows: Record<string, unknown>[] = [];\n        let query: Query<unknown> | null = null;\n        const errors: [number, AdapterError][] = [];\n\n        for (let i = 0; i < results.length; i++) {\n          const [error, result] = results[i]!;\n\n          if (error) {\n            errors.push([i, error]);\n\n            if (error.query) {\n              query = !query ? error.query : joinSequence([query, error.query]);\n            }\n          } else {\n            insertedRows.push(result.row);\n\n            if (result.query) {\n              query = !query ? result.query : joinSequence([query, result.query]);\n            }\n          }\n        }\n\n        if (errors.length > 0) {\n          return createAdapterError({\n            error: new AggregateError(\n              errors.map(([, error]) => error),\n              `Row${errors.length > 1 ? \"s\" : \"\"} ${errors.map(([index]) => index).join(\", \")} could not be inserted or refetched.`,\n            ),\n            query: query!,\n          });\n        }\n\n        return [null, { rows: insertedRows, query: query! }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async introspect(options): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      try {\n        const tablesQuery = getTablesQuery(requirements);\n        const timezoneQuery = getTimezoneQuery(requirements);\n\n        const [[tablesError, tables], [timezoneError, timezones]] = await Promise.all([\n          executor.execute(tablesQuery, options),\n          executor.execute(timezoneQuery, options),\n        ]);\n\n        if (tablesError) {\n          return createAdapterError({ error: tablesError, query: tablesQuery });\n        }\n\n        if (timezoneError) {\n          return createAdapterError({ error: timezoneError, query: timezoneQuery });\n        }\n\n        const timezone = timezones[0]?.timezone;\n\n        if (!timezone) {\n          return createAdapterError({ error: new Error(\"Timezone not found\"), query: timezoneQuery });\n        }\n\n        return [null, createIntrospection({ query: tablesQuery, tables, timezone })];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async query(details, options): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { filteredRowCount: results[0]?.__ps_count__ || \"0\", rows: results, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async update(details, options): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      try {\n        const updateQuery = getUpdateQuery(details, otherRequirements);\n        const refetchQuery = getUpdateRefetchQuery(details, otherRequirements);\n\n        const [[updateError], refetchResult] = await executor.executeSequence([updateQuery, refetchQuery], options);\n\n        if (updateError) {\n          return createAdapterError({ error: updateError, query: updateQuery });\n        }\n\n        const [refetchError, results] = refetchResult!;\n\n        if (refetchError) {\n          return createAdapterError({ error: refetchError, query: updateQuery });\n        }\n\n        const [row] = results;\n\n        if (!row) {\n          return createAdapterError({ error: new Error(\"Updated row not found\"), query: updateQuery });\n        }\n\n        return [null, { row, query: updateQuery }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n  };\n}\n\nfunction createIntrospection(args: {\n  query: Query;\n  tables: QueryResult<typeof getTablesQuery>;\n  timezone: string;\n}): AdapterIntrospectResult {\n  const { query, tables, timezone } = args;\n\n  return tables.reduce(\n    (result, table) => {\n      const { schemas } = result;\n      const { columns, name: tableName, schema } = table;\n\n      const columnsRecord = columns\n        .sort((a, b) => a.position - b.position)\n        .reduce(\n          (columns, column) => {\n            const { datatype, default: defaultValue, name: columnName } = column;\n\n            const indexOfParenthesis = datatype.indexOf(\"(\");\n            const strippedDataType = (indexOfParenthesis > -1 ? datatype.substring(0, indexOfParenthesis) : datatype)\n              .trim()\n              .toLowerCase();\n\n            const isAutoincrement = Boolean(column.autoincrement);\n            const isComputed = Boolean(column.computed);\n            const nullable = Boolean(column.nullable);\n\n            return {\n              ...columns,\n              [columnName]: {\n                datatype: {\n                  ...(MYSQL_DATA_TYPES_TO_METADATA[strippedDataType] || { group: \"raw\" }),\n                  isArray: false,\n                  isNative: true,\n                  name: strippedDataType,\n                  options:\n                    strippedDataType === \"enum\" ? datatype.slice(`enum('`.length, -`')`.length).split(`','`) : [],\n                  schema,\n                },\n                defaultValue,\n                fkColumn: column.fk_column,\n                fkSchema: schema,\n                fkTable: column.fk_table,\n                isAutoincrement,\n                isComputed,\n                isRequired: !nullable && !isAutoincrement && !isComputed && defaultValue == null,\n                name: columnName,\n                nullable,\n                pkPosition: column.pk,\n                schema,\n                table: tableName,\n              } as const satisfies Column,\n            };\n          },\n          {} as Table[\"columns\"],\n        );\n\n      if (schemas[schema] === undefined) {\n        schemas[schema] = { name: schema, tables: {} };\n      }\n\n      schemas[schema].tables[tableName] = { columns: columnsRecord, name: tableName, schema };\n\n      return result;\n    },\n    { filterOperators, query, schemas: {}, timezone } satisfies AdapterIntrospectResult as AdapterIntrospectResult,\n  );\n}\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n] satisfies FilterOperator[];\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const tables = mockTablesQuery();\n  const [{ timezone }] = mockTimezoneQuery();\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n\n  return createIntrospection({ tables, timezone, query }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      [K in (typeof tables)[number][\"schema\"]]: {\n        name: K;\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: typeof timezone;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n\nfunction joinSequence(sequence: readonly [Query<unknown>, Query<unknown>]): Query<unknown> {\n  const [query0, query1] = sequence;\n\n  return {\n    parameters: query0.parameters.concat(query1.parameters),\n    sql: `${query0.sql};\\n${query1.sql}`,\n  };\n}\n", "import type { DataType } from \"../adapter\";\n\nexport const MYSQL_DATA_TYPES_TO_METADATA: Record<string, Pick<DataType, \"format\" | \"group\">> = {\n  bigint: {\n    group: \"numeric\",\n  },\n  binary: {\n    group: \"string\",\n  },\n  bit: {\n    group: \"raw\",\n  },\n  blob: {\n    group: \"string\",\n  },\n  char: {\n    group: \"string\",\n  },\n  \"char binary\": {\n    group: \"string\",\n  },\n  date: {\n    format: \"YYYY-MM-DD\",\n    group: \"datetime\",\n  },\n  datetime: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\n    group: \"datetime\",\n  },\n  dec: {\n    group: \"numeric\",\n  },\n  decimal: {\n    group: \"numeric\",\n  },\n  double: {\n    group: \"numeric\",\n  },\n  \"double precision\": {\n    group: \"numeric\",\n  },\n  enum: {\n    group: \"enum\",\n  },\n  fixed: {\n    group: \"numeric\",\n  },\n  float: {\n    group: \"numeric\",\n  },\n  geometry: {\n    group: \"raw\",\n  },\n  geometrycollection: {\n    group: \"raw\",\n  },\n  int: {\n    group: \"numeric\",\n  },\n  integer: {\n    group: \"numeric\",\n  },\n  json: {\n    group: \"json\",\n  },\n  linestring: {\n    group: \"raw\",\n  },\n  long: {\n    group: \"string\",\n  },\n  \"long varchar\": {\n    group: \"string\",\n  },\n  longblob: {\n    group: \"string\",\n  },\n  longtext: {\n    group: \"string\",\n  },\n  longvarbinary: {\n    group: \"string\",\n  },\n  longvarchar: {\n    group: \"string\",\n  },\n  mediumblob: {\n    group: \"string\",\n  },\n  mediumint: {\n    group: \"numeric\",\n  },\n  mediumtext: {\n    group: \"string\",\n  },\n  multilinestring: {\n    group: \"raw\",\n  },\n  multipoint: {\n    group: \"raw\",\n  },\n  multipolygon: {\n    group: \"raw\",\n  },\n  numeric: {\n    group: \"numeric\",\n  },\n  point: {\n    group: \"raw\",\n  },\n  polygon: {\n    group: \"raw\",\n  },\n  real: {\n    group: \"numeric\",\n  },\n  /**\n   * https://dev.mysql.com/doc/refman/9.5/en/set.html\n   */\n  set: {\n    group: \"raw\",\n  },\n  smallint: {\n    group: \"numeric\",\n  },\n  text: {\n    group: \"string\",\n  },\n  time: {\n    format: \"HH:mm:ss.SSS\",\n    group: \"time\",\n  },\n  timestamp: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\n    group: \"datetime\",\n  },\n  tinyblob: {\n    group: \"string\",\n  },\n  tinyint: {\n    group: \"numeric\",\n  },\n  tinytext: {\n    group: \"string\",\n  },\n  varbinary: {\n    group: \"string\",\n  },\n  varchar: {\n    group: \"string\",\n  },\n  \"varchar binary\": {\n    group: \"string\",\n  },\n  /**\n   * https://dev.mysql.com/doc/refman/9.5/en/vector.html\n   */\n  vector: {\n    group: \"raw\",\n  },\n  year: {\n    format: \"YYYY\",\n    group: \"numeric\",\n  },\n};\n", "import { type InferResult, type SimpleReferenceExpression, sql } from \"kysely\";\nimport type { OkPacketParams } from \"mysql2\";\n\nimport type { AdapterDeleteDetails, AdapterQueryDetails, AdapterUpdateDetails, Table } from \"../adapter\";\nimport {\n  applyInferredRowFilters,\n  applyTransformations,\n  type BuilderRequirements,\n  compile,\n  getSelectFilterExpression,\n} from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getMySQLBuilder } from \"./builder\";\nimport { mockTablesQuery } from \"./introspection\";\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 = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(builder.deleteFrom(tableName).$call(applyInferredRowFilters(rows, columns)).$castTo<OkPacketParams>());\n}\n\nexport function getInsertQuery(\n  details: { rows: Record<string, unknown>[]; table: Table },\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .insertInto(tableName)\n      .values(applyTransformations({ columns, context: \"insert\", supportsDefaultKeyword: true, values: rows }))\n      .$castTo<OkPacketParams>(),\n  );\n}\n\nexport function getInsertRefetchQuery(\n  details: { criteria: Record<string, unknown>[]; table: Table },\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    criteria,\n    table: { columns, name: tableName },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .selectFrom(tableName)\n      .$call(applyInferredRowFilters(criteria, columns))\n      .select(Object.keys(columns))\n      .select(getCurrentTimestampMillis().as(\"__ps_inserted_at__\")),\n  );\n}\n\nexport function getUpdateRefetchQuery(\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 = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .selectFrom(tableName)\n      .$call(applyInferredRowFilters([{ ...row, ...changes }], columns))\n      .select(Object.keys(columns))\n      .select(getCurrentTimestampMillis().as(\"__ps_updated_at__\")),\n  );\n}\n\nexport function getSelectQuery(\n  details: AdapterQueryDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    filter = { after: \"and\", filters: [], kind: \"FilterGroup\" },\n    pageIndex,\n    pageSize,\n    sortOrder,\n    table: { columns, name: tableName },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  const filterExpression = getSelectFilterExpression(filter.filters, columns);\n\n  const AGG_NAME = \"__ps_agg__\";\n  const COUNT_REF = \"__ps_count__\";\n\n  const countQuery = builder\n    .selectFrom(tableName)\n    .where(filterExpression)\n    .select((eb) => eb.cast<BigIntString>(eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)), \"char\").as(COUNT_REF));\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(filterExpression)\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) => sortOrder.reduce((qb, item) => qb.orderBy(item.column, item.direction), qb))\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  // TODO: ...\n  return [] as const satisfies {\n    // best effort no need to go overboard\n    [K in ReturnType<typeof mockTablesQuery>[1][\"columns\"][number][\"name\"] | \"__ps_count__\"]: unknown;\n  }[];\n}\n\nexport function getUpdateQuery(\n  details: AdapterUpdateDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    changes,\n    row,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .updateTable(tableName)\n      .set(applyTransformations({ columns, context: \"update\", supportsDefaultKeyword: true, values: changes }))\n      .$call(applyInferredRowFilters([row], columns))\n      .$castTo<OkPacketParams>(),\n  );\n}\n\nfunction getCurrentTimestampMillis() {\n  return sql<number | string>`cast(unix_timestamp(now(3)) * 1000 as unsigned)`;\n}\n", "import { type Kysely, MysqlAdapter, MysqlQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getMySQLBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder({ ...requirements, Adapter: MysqlAdapter, QueryCompiler: MysqlQueryCompiler });\n}\n", "import { sql } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/mysql\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getMySQLBuilder } from \"./builder\";\n\ninterface Database {\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-key-column-usage-table.html */\n  \"information_schema.KEY_COLUMN_USAGE\": {\n    COLUMN_NAME: string;\n    CONSTRAINT_NAME: string;\n    ORDINAL_POSITION: number;\n    /** null - when unique or primary key constraint. 1-n - when foreign key constraint */\n    POSITION_IN_UNIQUE_CONSTRAINT: number | null;\n    REFERENCED_COLUMN_NAME: string;\n    REFERENCED_TABLE_NAME: string;\n    TABLE_NAME: string;\n    TABLE_SCHEMA: string;\n  };\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-columns-table.html */\n  \"information_schema.columns\": {\n    /** The default value for the column. This is NULL if the column has an explicit default of NULL, or if the column definition includes no DEFAULT clause. */\n    COLUMN_DEFAULT: string | null;\n    COLUMN_NAME: string;\n    /** Contains the type name and possibly other information such as the precision or length. */\n    COLUMN_TYPE: string;\n    /** Extra information about the column. Possible values are */\n    EXTRA:\n      | \"\"\n      | \"auto_increment\"\n      | \"on update CURRENT_TIMESTAMP\"\n      | \"STORED GENERATED\"\n      | \"VIRTUAL GENERATED\"\n      | \"DEFAULT GENERATED\";\n    IS_NULLABLE: \"YES\" | \"NO\";\n    /** The position of the column within the table. ORDINAL_POSITION is necessary because you might want to say ORDER BY ORDINAL_POSITION. Unlike SHOW COLUMNS, SELECT from the COLUMNS table does not have automatic ordering. */\n    ORDINAL_POSITION: number;\n    TABLE_NAME: string;\n    TABLE_SCHEMA: string;\n  };\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-tables-table.html */\n  \"information_schema.tables\": {\n    TABLE_NAME: string;\n    /** The name of the schema (database) to which the table belongs. */\n    TABLE_SCHEMA: string;\n    /** BASE TABLE for a table, VIEW for a view, or SYSTEM VIEW for an INFORMATION_SCHEMA table. */\n    TABLE_TYPE: \"BASE TABLE\" | \"VIEW\" | \"SYSTEM VIEW\";\n  };\n}\n\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  return compile(\n    getMySQLBuilder<Database>(requirements)\n      .selectFrom(\"information_schema.tables as t\")\n      .where(\"t.TABLE_SCHEMA\", \"=\", sql<string>`database()`)\n      .where(\"t.TABLE_TYPE\", \"in\", [\"BASE TABLE\", \"VIEW\"])\n      .select([\"t.TABLE_SCHEMA as schema\", \"t.TABLE_NAME as name\", \"t.TABLE_TYPE as type\"])\n      .$narrowType<{ type: \"BASE TABLE\" | \"VIEW\" }>()\n      .select((eb) =>\n        // `json_arrayagg` ignores `order by` inside the subquery, so we need to order after aggregation.\n        jsonArrayFrom(\n          eb\n            .selectFrom(\"information_schema.columns as c\")\n            .leftJoin(\"information_schema.KEY_COLUMN_USAGE as kcu\", (jb) =>\n              jb\n                .onRef(\"kcu.TABLE_SCHEMA\", \"=\", \"c.TABLE_SCHEMA\")\n                .onRef(\"kcu.TABLE_NAME\", \"=\", \"c.TABLE_NAME\")\n                .onRef(\"kcu.COLUMN_NAME\", \"=\", \"c.COLUMN_NAME\")\n                // only get foreign key constraints\n                .on(\"kcu.POSITION_IN_UNIQUE_CONSTRAINT\", \"is not\", null),\n            )\n            .leftJoin(\"information_schema.KEY_COLUMN_USAGE as pk_kcu\", (jb) =>\n              jb\n                .onRef(\"pk_kcu.TABLE_SCHEMA\", \"=\", \"c.TABLE_SCHEMA\")\n                .onRef(\"pk_kcu.TABLE_NAME\", \"=\", \"c.TABLE_NAME\")\n                .onRef(\"pk_kcu.COLUMN_NAME\", \"=\", \"c.COLUMN_NAME\")\n                // only get primary key constraint - guaranteed to be \"PRIMARY\" even if a name was given during creation\n                .on(\"pk_kcu.CONSTRAINT_NAME\", \"=\", \"PRIMARY\"),\n            )\n            .whereRef(\"c.TABLE_SCHEMA\", \"=\", \"t.TABLE_SCHEMA\")\n            .whereRef(\"c.TABLE_NAME\", \"=\", \"t.TABLE_NAME\")\n            .select([\n              \"c.COLUMN_DEFAULT as default\",\n              \"c.COLUMN_NAME as name\",\n              \"c.COLUMN_TYPE as datatype\",\n              \"c.ORDINAL_POSITION as position\",\n              \"kcu.REFERENCED_TABLE_NAME as fk_table\",\n              \"kcu.REFERENCED_COLUMN_NAME as fk_column\",\n              \"pk_kcu.ORDINAL_POSITION as pk\",\n            ])\n            .select((eb) => [\n              eb(\"c.EXTRA\", \"=\", \"auto_increment\").as(\"autoincrement\"),\n              eb(\"c.EXTRA\", \"in\", [\"on update CURRENT_TIMESTAMP\", \"STORED GENERATED\", \"VIRTUAL GENERATED\"]).as(\n                \"computed\",\n              ),\n              eb(\"c.IS_NULLABLE\", \"=\", \"YES\").as(\"nullable\"),\n            ]),\n        ).as(\"columns\"),\n      )\n      .orderBy(\"t.TABLE_SCHEMA\")\n      .orderBy(\"t.TABLE_NAME\")\n      .orderBy(\"t.TABLE_TYPE\"),\n  );\n}\n\nexport function mockTablesQuery() {\n  return [\n    {\n      columns: [\n        {\n          autoincrement: 1,\n          computed: 0,\n          datatype: \"int\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: 0,\n          pk: 1,\n          position: 1,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"binary(16)\",\n          default: \"uuid_to_bin(uuid())\",\n          fk_column: null,\n          fk_table: null,\n          name: \"uuid\",\n          nullable: 1,\n          pk: null,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"varchar(255)\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 1,\n          pk: null,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 1,\n          datatype: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"id_name\",\n          nullable: 1,\n          pk: null,\n          position: 4,\n        },\n      ],\n      name: \"animals\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n    {\n      columns: [\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"char(36)\",\n          default: \"uuid()\",\n          fk_column: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: 0,\n          pk: 1,\n          position: 1,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 0,\n          pk: 2,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"timestamp\",\n          default: \"CURRENT_TIMESTAMP\",\n          fk_column: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: 1,\n          pk: null,\n          position: 3,\n        },\n      ],\n      name: \"composite_pk\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n    {\n      columns: [\n        {\n          autoincrement: 1,\n          computed: 0,\n          datatype: \"int\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: 0,\n          pk: 1,\n          position: 1,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"timestamp\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: 1,\n          pk: null,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"enum('admin','maintainer','member')\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"role\",\n          nullable: 0,\n          pk: null,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"int\",\n          default: null,\n          fk_column: \"id\",\n          fk_table: \"animals\",\n          name: \"animal_id\",\n          nullable: 1,\n          pk: null,\n          position: 4,\n        },\n      ],\n      name: \"users\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n\nexport function getTimezoneQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  const builder = getMySQLBuilder(requirements);\n\n  const sessionTz = sql<\"SYSTEM\" | (string & {})>`@@session.time_zone`;\n\n  return compile(\n    builder\n      .selectNoFrom(\n        builder\n          .case()\n          .when(sessionTz, \"=\", \"SYSTEM\")\n          .then(sql<string>`@@system_time_zone`)\n          .else(sessionTz)\n          .end()\n          .as(\"timezone\"),\n      )\n      .$narrowType<{ timezone: string }>(),\n  );\n}\n\nexport function mockTimezoneQuery() {\n  return [{ timezone: \"UTC\" }] as const satisfies QueryResult<typeof getTimezoneQuery>;\n}\n", "/// <reference types=\"./mysql.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\nimport { getJsonObjectArgs } from '../util/json-object-args.js';\n/**\n * A MySQL helper for aggregating a subquery into a JSON array.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into arrays. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/mysql'\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 (MySQL):\n *\n * ```sql\n * select `id`, (\n *   select cast(coalesce(json_arrayagg(json_object(\n *     'pet_id', `agg`.`pet_id`,\n *     'name', `agg`.`name`\n *   )), '[]') as json) 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 cast(coalesce(json_arrayagg(json_object(${sql.join(getMysqlJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') as json) from ${expr} as agg)`;\n}\n/**\n * A MySQL helper for turning a subquery into a JSON object.\n *\n * The subquery must only return one row.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/mysql'\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 (MySQL):\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(getMysqlJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;\n}\n/**\n * The MySQL `json_object` function.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * 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: eb.fn('concat', ['first_name', eb.val(' '), '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 (MySQL):\n *\n * ```sql\n * select \"id\", json_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', concat(`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 getMysqlJsonObjectArgs(node, table) {\n    try {\n        return getJsonObjectArgs(node, table);\n    }\n    catch {\n        throw new Error('MySQL 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"],
  "mappings": ";;;;;;;;qRAAAA,ICAAC,ICAAC,IAEO,IAAMC,EAAmF,CAC9F,OAAQ,CACN,MAAO,SACT,EACA,OAAQ,CACN,MAAO,QACT,EACA,IAAK,CACH,MAAO,KACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,cAAe,CACb,MAAO,QACT,EACA,KAAM,CACJ,OAAQ,aACR,MAAO,UACT,EACA,SAAU,CACR,OAAQ,0BACR,MAAO,UACT,EACA,IAAK,CACH,MAAO,SACT,EACA,QAAS,CACP,MAAO,SACT,EACA,OAAQ,CACN,MAAO,SACT,EACA,mBAAoB,CAClB,MAAO,SACT,EACA,KAAM,CACJ,MAAO,MACT,EACA,MAAO,CACL,MAAO,SACT,EACA,MAAO,CACL,MAAO,SACT,EACA,SAAU,CACR,MAAO,KACT,EACA,mBAAoB,CAClB,MAAO,KACT,EACA,IAAK,CACH,MAAO,SACT,EACA,QAAS,CACP,MAAO,SACT,EACA,KAAM,CACJ,MAAO,MACT,EACA,WAAY,CACV,MAAO,KACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,eAAgB,CACd,MAAO,QACT,EACA,SAAU,CACR,MAAO,QACT,EACA,SAAU,CACR,MAAO,QACT,EACA,cAAe,CACb,MAAO,QACT,EACA,YAAa,CACX,MAAO,QACT,EACA,WAAY,CACV,MAAO,QACT,EACA,UAAW,CACT,MAAO,SACT,EACA,WAAY,CACV,MAAO,QACT,EACA,gBAAiB,CACf,MAAO,KACT,EACA,WAAY,CACV,MAAO,KACT,EACA,aAAc,CACZ,MAAO,KACT,EACA,QAAS,CACP,MAAO,SACT,EACA,MAAO,CACL,MAAO,KACT,EACA,QAAS,CACP,MAAO,KACT,EACA,KAAM,CACJ,MAAO,SACT,EAIA,IAAK,CACH,MAAO,KACT,EACA,SAAU,CACR,MAAO,SACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,KAAM,CACJ,OAAQ,eACR,MAAO,MACT,EACA,UAAW,CACT,OAAQ,0BACR,MAAO,UACT,EACA,SAAU,CACR,MAAO,QACT,EACA,QAAS,CACP,MAAO,SACT,EACA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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "MYSQL_DATA_TYPES_TO_METADATA", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "getMySQLBuilder", "requirements", "getBuilder", "MysqlAdapter", "MysqlQueryCompiler", "getDeleteQuery", "details", "requirements", "rows", "columns", "tableName", "builder", "getMySQLBuilder", "compile", "applyInferredRowFilters", "getInsertQuery", "applyTransformations", "getInsertRefetchQuery", "criteria", "getCurrentTimestampMillis", "getUpdateRefetchQuery", "changes", "row", "getSelectQuery", "filter", "pageIndex", "pageSize", "sortOrder", "filterExpression", "getSelectFilterExpression", "AGG_NAME", "COUNT_REF", "countQuery", "eb", "sql", "jb", "qb", "item", "mockSelectQuery", "getUpdateQuery", "schema", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "jsonArrayFrom", "expr", "sql", "getMysqlJsonObjectArgs", "getMysqlJsonObjectArgs", "node", "table", "getJsonObjectArgs", "getTablesQuery", "requirements", "compile", "getMySQLBuilder", "sql", "eb", "jsonArrayFrom", "jb", "mockTablesQuery", "getTimezoneQuery", "builder", "sessionTz", "mockTimezoneQuery", "createMySQLAdapter", "requirements", "executor", "otherRequirements", "details", "options", "query", "getDeleteQuery", "error", "createAdapterError", "rows", "table", "columns", "autoincrementColumn", "column", "filterObjects", "row", "inferFilterObject", "hasPartialFilterObjects", "filterObject", "filterValues", "value", "getInsertQuery", "insertQuery", "refetchQuery", "getInsertRefetchQuery", "sequence", "insertError", "maybeRefetchResult", "joinSequence", "refetchError", "refetchResults", "results", "result", "autoincrementColumnName", "acc", "columnName", "refetchedRow", "insertedRows", "errors", "i", "index", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "timezone", "createIntrospection", "getSelectQuery", "updateQuery", "getUpdateQuery", "getUpdateRefetchQuery", "updateError", "refetchResult", "args", "schemas", "tableName", "schema", "columnsRecord", "a", "b", "datatype", "defaultValue", "indexOfParenthesis", "strippedDataType", "isAutoincrement", "isComputed", "nullable", "MYSQL_DATA_TYPES_TO_METADATA", "filterOperators", "mockIntrospect", "mockTablesQuery", "mockTimezoneQuery", "query0", "query1"]
}

@@ -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 q}from"../../chunk-ZUEQ555M.js";import{b as u}from"../../chunk-SXTJF4PD.js";import{e as d}from"../../chunk-GDQBQ7MK.js";d();function h(n){return{async execute(o,i){let{abortSignal:r}=i||{};if(!r)try{let[e]=await n.query(o.sql,o.parameters);return[null,l(e)]}catch(e){return[e]}if(r.aborted)return u();let a,t;try{let e,s=new Promise(w=>e=w);r.addEventListener("abort",a=()=>e());let c=n.getConnection(),f=await Promise.race([c,s]);if(!f)return c.catch(()=>{}),u();if(t=f,r.aborted)return t.release(),u();let m=(t||n).query(o.sql,o.parameters),y=await Promise.race([m,s]);if(!y)return Promise.allSettled([v(n,y),m]).finally(()=>t?.release()),u();t.release();let[P]=y;return[null,l(P)]}catch(e){return t?.release(),[e]}finally{a&&r?.removeEventListener("abort",a)}},async executeSequence(o,i){let r;try{r=await n.getConnection();let[a,t]=o,[e]=await r.query(a.sql,a.parameters).catch(c=>[c]);if(e instanceof Error)return[[e]];let[s]=await r.query(t.sql,t.parameters).catch(c=>[c]);return s instanceof Error?[[null,l(e)],[s]]:[[null,l(e)],[null,l(s)]]}catch(a){return[[a]]}finally{r?.release()}}}}function l(n){return Array.isArray(n)?n:[n]}async function v(n,o){let i=q(o);try{await n.query(i.sql,i.parameters)}catch(r){console.error("Failed to cancel query:",r)}}export{h as createMySQL2Executor};
9
+ import{a as q}from"../../chunk-6MJRFEB4.js";import{b as u}from"../../chunk-YHRFAAQN.js";import{e as d}from"../../chunk-GGFIWHFO.js";d();function h(n){return{async execute(o,i){let{abortSignal:r}=i||{};if(!r)try{let[e]=await n.query(o.sql,o.parameters);return[null,l(e)]}catch(e){return[e]}if(r.aborted)return u();let a,t;try{let e,s=new Promise(w=>e=w);r.addEventListener("abort",a=()=>e());let c=n.getConnection(),f=await Promise.race([c,s]);if(!f)return c.catch(()=>{}),u();if(t=f,r.aborted)return t.release(),u();let m=(t||n).query(o.sql,o.parameters),y=await Promise.race([m,s]);if(!y)return Promise.allSettled([v(n,y),m]).finally(()=>t?.release()),u();t.release();let[P]=y;return[null,l(P)]}catch(e){return t?.release(),[e]}finally{a&&r?.removeEventListener("abort",a)}},async executeSequence(o,i){let r;try{r=await n.getConnection();let[a,t]=o,[e]=await r.query(a.sql,a.parameters).catch(c=>[c]);if(e instanceof Error)return[[e]];let[s]=await r.query(t.sql,t.parameters).catch(c=>[c]);return s instanceof Error?[[null,l(e)],[s]]:[[null,l(e)],[null,l(s)]]}catch(a){return[[a]]}finally{r?.release()}}}}function l(n){return Array.isArray(n)?n:[n]}async function v(n,o){let i=q(o);try{await n.query(i.sql,i.parameters)}catch(r){console.error("Failed to cancel query:",r)}}export{h as createMySQL2Executor};
10
10
  //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/mysql2/index.ts"],
  "sourcesContent": ["import type { Pool, PoolConnection } from \"mysql2/promise\";\n\nimport { getAbortResult, type SequenceExecutor } from \"../executor\";\nimport { getCancelQuery } from \"../mysql-core/utility\";\n\nexport function createMySQL2Executor(pool: Pool): SequenceExecutor {\n  return {\n    async execute(query, options) {\n      const { abortSignal } = options || {};\n\n      if (!abortSignal) {\n        try {\n          const [result] = await pool.query(query.sql, query.parameters);\n\n          return [null, asArray(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: PoolConnection | 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 = pool.getConnection();\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 queryPromise = (connection || pool).query(query.sql, query.parameters);\n\n        const queryResult = await Promise.race([queryPromise, abortionPromise]);\n\n        if (!queryResult) {\n          // not important enough to await.\n          void Promise.allSettled([cancelQuery(pool, queryResult), queryPromise]).finally(() => connection?.release());\n\n          return getAbortResult();\n        }\n\n        connection.release();\n\n        const [result] = queryResult;\n\n        return [null, asArray(result)] 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    // TODO: abort signal handling\n    // TODO: transaction?\n    async executeSequence(sequence, _options) {\n      let connection: PoolConnection | undefined;\n\n      try {\n        connection = await pool.getConnection();\n\n        const [query0, query1] = sequence;\n\n        const [result0] = await connection.query(query0.sql, query0.parameters).catch((error) => [error as Error]);\n\n        if (result0 instanceof Error) {\n          return [[result0]];\n        }\n\n        const [result1] = await connection.query(query1.sql, query1.parameters).catch((error) => [error as Error]);\n\n        if (result1 instanceof Error) {\n          return [[null, asArray(result0)], [result1]] as never;\n        }\n\n        return [\n          [null, asArray(result0)],\n          [null, asArray(result1)],\n        ] as never;\n      } catch (error: unknown) {\n        return [[error as Error]];\n      } finally {\n        connection?.release();\n      }\n    },\n  };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction asArray<T>(value: T): T extends any[] ? T : T[] {\n  return (Array.isArray(value) ? value : [value]) as never;\n}\n\nasync function cancelQuery(pool: Pool, threadId: unknown): Promise<void> {\n  const query = getCancelQuery(threadId);\n\n  try {\n    await pool.query(query.sql, query.parameters);\n  } catch (error: unknown) {\n    console.error(\"Failed to cancel query:\", error);\n  }\n}\n"],
  "mappings": ";;;;;;;;oIAAAA,IAKO,SAASC,EAAqBC,EAA8B,CACjE,MAAO,CACL,MAAM,QAAQC,EAAOC,EAAS,CAC5B,GAAM,CAAE,YAAAC,CAAY,EAAID,GAAW,CAAC,EAEpC,GAAI,CAACC,EACH,GAAI,CACF,GAAM,CAACC,CAAM,EAAI,MAAMJ,EAAK,MAAMC,EAAM,IAAKA,EAAM,UAAU,EAE7D,MAAO,CAAC,KAAMI,EAAQD,CAAM,CAAC,CAC/B,OAASE,EAAgB,CACvB,MAAO,CAACA,CAAc,CACxB,CAGF,GAAIH,EAAY,QACd,OAAOI,EAAe,EAGxB,IAAIC,EACAC,EAEJ,GAAI,CACF,IAAIC,EACEC,EAAkB,IAAI,QAAeC,GAAaF,EAAUE,CAAQ,EAE1ET,EAAY,iBAAiB,QAAUK,EAAgB,IAAME,EAAQ,CAAE,EAEvE,IAAMG,EAAoBb,EAAK,cAAc,EAEvCc,EAAmB,MAAM,QAAQ,KAAK,CAACD,EAAmBF,CAAe,CAAC,EAEhF,GAAI,CAACG,EACH,OAAKD,EAAkB,MAAM,IAAM,CAAC,CAAC,EAE9BN,EAAe,EAKxB,GAFAE,EAAaK,EAETX,EAAY,QACd,OAAAM,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMQ,GAAgBN,GAAcT,GAAM,MAAMC,EAAM,IAAKA,EAAM,UAAU,EAErEe,EAAc,MAAM,QAAQ,KAAK,CAACD,EAAcJ,CAAe,CAAC,EAEtE,GAAI,CAACK,EAEH,OAAK,QAAQ,WAAW,CAACC,EAAYjB,EAAMgB,CAAW,EAAGD,CAAY,CAAC,EAAE,QAAQ,IAAMN,GAAY,QAAQ,CAAC,EAEpGF,EAAe,EAGxBE,EAAW,QAAQ,EAEnB,GAAM,CAACL,CAAM,EAAIY,EAEjB,MAAO,CAAC,KAAMX,EAAQD,CAAM,CAAC,CAC/B,OAASE,EAAgB,CACvB,OAAAG,GAAY,QAAQ,EAEb,CAACH,CAAc,CACxB,QAAE,CACIE,GACFL,GAAa,oBAAoB,QAASK,CAAa,CAE3D,CACF,EAIA,MAAM,gBAAgBU,EAAUC,EAAU,CACxC,IAAIV,EAEJ,GAAI,CACFA,EAAa,MAAMT,EAAK,cAAc,EAEtC,GAAM,CAACoB,EAAQC,CAAM,EAAIH,EAEnB,CAACI,CAAO,EAAI,MAAMb,EAAW,MAAMW,EAAO,IAAKA,EAAO,UAAU,EAAE,MAAOd,GAAU,CAACA,CAAc,CAAC,EAEzG,GAAIgB,aAAmB,MACrB,MAAO,CAAC,CAACA,CAAO,CAAC,EAGnB,GAAM,CAACC,CAAO,EAAI,MAAMd,EAAW,MAAMY,EAAO,IAAKA,EAAO,UAAU,EAAE,MAAOf,GAAU,CAACA,CAAc,CAAC,EAEzG,OAAIiB,aAAmB,MACd,CAAC,CAAC,KAAMlB,EAAQiB,CAAO,CAAC,EAAG,CAACC,CAAO,CAAC,EAGtC,CACL,CAAC,KAAMlB,EAAQiB,CAAO,CAAC,EACvB,CAAC,KAAMjB,EAAQkB,CAAO,CAAC,CACzB,CACF,OAASjB,EAAgB,CACvB,MAAO,CAAC,CAACA,CAAc,CAAC,CAC1B,QAAE,CACAG,GAAY,QAAQ,CACtB,CACF,CACF,CACF,CAGA,SAASJ,EAAWmB,EAAqC,CACvD,OAAQ,MAAM,QAAQA,CAAK,EAAIA,EAAQ,CAACA,CAAK,CAC/C,CAEA,eAAeP,EAAYjB,EAAYyB,EAAkC,CACvE,IAAMxB,EAAQyB,EAAeD,CAAQ,EAErC,GAAI,CACF,MAAMzB,EAAK,MAAMC,EAAM,IAAKA,EAAM,UAAU,CAC9C,OAASK,EAAgB,CACvB,QAAQ,MAAM,0BAA2BA,CAAK,CAChD,CACF",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "createMySQL2Executor", "pool", "query", "options", "abortSignal", "result", "asArray", "error", "getAbortResult", "abortListener", "connection", "aborted", "abortionPromise", "resolve", "connectionPromise", "connectionResult", "queryPromise", "queryResult", "cancelQuery", "sequence", "_options", "query0", "query1", "result0", "result1", "value", "threadId", "getCancelQuery"]
}

@@ -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{e as a}from"../../chunk-GDQBQ7MK.js";a();function v(c){return{execute:u=>{let{parameters:i,sql:l,transformations:r}=u,f=c.prepare(l);try{let e=f.all(...i);if(!r||Object.keys(r).length===0)return Promise.resolve([null,e]);for(let n of e)for(let t in r){let s=r[t],o=n[t];if(s==="json-parse"){if(typeof o=="string")try{n[t]=JSON.parse(o)}catch(p){console.error(`Failed to JSON.parse column "${t}" with value: ${o}`,p)}continue}}return Promise.resolve([null,e])}catch(e){return Promise.resolve([e])}}}}export{v as createNodeSQLiteExecutor};
9
+ import{e as a}from"../../chunk-GGFIWHFO.js";a();function v(c){return{execute:u=>{let{parameters:i,sql:l,transformations:r}=u,f=c.prepare(l);try{let e=f.all(...i);if(!r||Object.keys(r).length===0)return Promise.resolve([null,e]);for(let n of e)for(let t in r){let s=r[t],o=n[t];if(s==="json-parse"){if(typeof o=="string")try{n[t]=JSON.parse(o)}catch(p){console.error(`Failed to JSON.parse column "${t}" with value: ${o}`,p)}continue}}return Promise.resolve([null,e])}catch(e){return Promise.resolve([e])}}}}export{v as createNodeSQLiteExecutor};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9ub2RlLXNxbGl0ZS9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHR5cGUgeyBEYXRhYmFzZVN5bmMsIFNRTElucHV0VmFsdWUgfSBmcm9tIFwibm9kZTpzcWxpdGVcIjtcblxuaW1wb3J0IHR5cGUgeyBFeGVjdXRvciB9IGZyb20gXCIuLi9leGVjdXRvclwiO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlTm9kZVNRTGl0ZUV4ZWN1dG9yKGRhdGFiYXNlOiBEYXRhYmFzZVN5bmMpOiBFeGVjdXRvciB7XG4gIHJldHVybiB7XG4gICAgZXhlY3V0ZTogKHF1ZXJ5KSA9PiB7XG4gICAgICBjb25zdCB7IHBhcmFtZXRlcnMsIHNxbCwgdHJhbnNmb3JtYXRpb25zIH0gPSBxdWVyeTtcblxuICAgICAgY29uc3Qgc3RhdGVtZW50ID0gZGF0YWJhc2UucHJlcGFyZShzcWwpO1xuXG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByb3dzID0gc3RhdGVtZW50LmFsbCguLi4ocGFyYW1ldGVycyBhcyBTUUxJbnB1dFZhbHVlW10pKTtcblxuICAgICAgICBpZiAoIXRyYW5zZm9ybWF0aW9ucyB8fCBPYmplY3Qua2V5cyh0cmFuc2Zvcm1hdGlvbnMpLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoW251bGwsIHJvd3NdKSBhcyBuZXZlcjtcbiAgICAgICAgfVxuXG4gICAgICAgIGZvciAoY29uc3Qgcm93IG9mIHJvd3MpIHtcbiAgICAgICAgICBmb3IgKGNvbnN0IGNvbHVtbiBpbiB0cmFuc2Zvcm1hdGlvbnMpIHtcbiAgICAgICAgICAgIGNvbnN0IHRyYW5zZm9ybWF0aW9uID0gdHJhbnNmb3JtYXRpb25zW2NvbHVtbl07XG4gICAgICAgICAgICBjb25zdCB2YWx1ZSA9IHJvd1tjb2x1bW5dO1xuXG4gICAgICAgICAgICBpZiAodHJhbnNmb3JtYXRpb24gPT09IFwianNvbi1wYXJzZVwiKSB7XG4gICAgICAgICAgICAgIGlmICh0eXBlb2YgdmFsdWUgPT09IFwic3RyaW5nXCIpIHtcbiAgICAgICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgICAgcm93W2NvbHVtbl0gPSBKU09OLnBhcnNlKHZhbHVlKSBhcyBuZXZlcjtcbiAgICAgICAgICAgICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICAgICAgICAgICAgY29uc29sZS5lcnJvcihgRmFpbGVkIHRvIEpTT04ucGFyc2UgY29sdW1uIFwiJHtjb2x1bW59XCIgd2l0aCB2YWx1ZTogJHt2YWx1ZX1gLCBlcnJvcik7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHRyYW5zZm9ybWF0aW9uIHNhdGlzZmllcyB1bmRlZmluZWQ7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShbbnVsbCwgcm93c10pIGFzIG5ldmVyO1xuICAgICAgfSBjYXRjaCAoZXJyb3I6IHVua25vd24pIHtcbiAgICAgICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShbZXJyb3IgYXMgRXJyb3JdKTtcbiAgICAgIH1cbiAgICB9LFxuICB9O1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7NENBQUFBLElBSU8sU0FBU0MsRUFBeUJDLEVBQWtDLENBQ3pFLE1BQU8sQ0FDTCxRQUFVQyxHQUFVLENBQ2xCLEdBQU0sQ0FBRSxXQUFBQyxFQUFZLElBQUFDLEVBQUssZ0JBQUFDLENBQWdCLEVBQUlILEVBRXZDSSxFQUFZTCxFQUFTLFFBQVFHLENBQUcsRUFFdEMsR0FBSSxDQUNGLElBQU1HLEVBQU9ELEVBQVUsSUFBSSxHQUFJSCxDQUE4QixFQUU3RCxHQUFJLENBQUNFLEdBQW1CLE9BQU8sS0FBS0EsQ0FBZSxFQUFFLFNBQVcsRUFDOUQsT0FBTyxRQUFRLFFBQVEsQ0FBQyxLQUFNRSxDQUFJLENBQUMsRUFHckMsUUFBV0MsS0FBT0QsRUFDaEIsUUFBV0UsS0FBVUosRUFBaUIsQ0FDcEMsSUFBTUssRUFBaUJMLEVBQWdCSSxDQUFNLEVBQ3ZDRSxFQUFRSCxFQUFJQyxDQUFNLEVBRXhCLEdBQUlDLElBQW1CLGFBQWMsQ0FDbkMsR0FBSSxPQUFPQyxHQUFVLFNBQ25CLEdBQUksQ0FDRkgsRUFBSUMsQ0FBTSxFQUFJLEtBQUssTUFBTUUsQ0FBSyxDQUNoQyxPQUFTQyxFQUFPLENBQ2QsUUFBUSxNQUFNLGdDQUFnQ0gsQ0FBTSxpQkFBaUJFLENBQUssR0FBSUMsQ0FBSyxDQUNyRixDQUdGLFFBQ0YsQ0FHRixDQUdGLE9BQU8sUUFBUSxRQUFRLENBQUMsS0FBTUwsQ0FBSSxDQUFDLENBQ3JDLE9BQVNLLEVBQWdCLENBQ3ZCLE9BQU8sUUFBUSxRQUFRLENBQUNBLENBQWMsQ0FBQyxDQUN6QyxDQUNGLENBQ0YsQ0FDRiIsCiAgIm5hbWVzIjogWyJpbml0X2RlZmluZV9BQ0NFTEVSQVRFX1NDSEVNQV9CWV9QUk9WSURFUiIsICJjcmVhdGVOb2RlU1FMaXRlRXhlY3V0b3IiLCAiZGF0YWJhc2UiLCAicXVlcnkiLCAicGFyYW1ldGVycyIsICJzcWwiLCAidHJhbnNmb3JtYXRpb25zIiwgInN0YXRlbWVudCIsICJyb3dzIiwgInJvdyIsICJjb2x1bW4iLCAidHJhbnNmb3JtYXRpb24iLCAidmFsdWUiLCAiZXJyb3IiXQp9Cg==