@prisma/studio-core 0.7.0 → 0.8.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.
Files changed (60) hide show
  1. package/dist/chunk-32BUC7NR.js +10 -0
  2. package/dist/chunk-3KCOUVOV.js +10 -0
  3. package/dist/chunk-A6CVKSUD.js +10 -0
  4. package/dist/chunk-M7E5UEO3.js +10 -0
  5. package/dist/chunk-O6ZAHVDF.js +10 -0
  6. package/dist/chunk-SXTJF4PD.js +10 -0
  7. package/dist/chunk-ZUEQ555M.js +10 -0
  8. package/dist/data/accelerate/index.d.cts +1 -1
  9. package/dist/data/accelerate/index.d.ts +1 -1
  10. package/dist/data/bff/index.cjs +2 -2
  11. package/dist/data/bff/index.d.cts +15 -3
  12. package/dist/data/bff/index.d.ts +15 -3
  13. package/dist/data/bff/index.js +2 -2
  14. package/dist/data/index.d.cts +1 -1
  15. package/dist/data/index.d.ts +1 -1
  16. package/dist/data/index.js +1 -1
  17. package/dist/data/mysql-core/index.cjs +3 -0
  18. package/dist/data/mysql-core/index.d.cts +176 -0
  19. package/dist/data/mysql-core/index.d.ts +176 -0
  20. package/dist/data/mysql-core/index.js +11 -0
  21. package/dist/data/mysql2/index.cjs +2 -0
  22. package/dist/data/mysql2/index.d.cts +7 -0
  23. package/dist/data/mysql2/index.d.ts +7 -0
  24. package/dist/data/mysql2/index.js +10 -0
  25. package/dist/data/node-sqlite/index.cjs +2 -2
  26. package/dist/data/node-sqlite/index.d.cts +2 -3
  27. package/dist/data/node-sqlite/index.d.ts +2 -3
  28. package/dist/data/node-sqlite/index.js +2 -2
  29. package/dist/data/pglite/index.cjs +2 -2
  30. package/dist/data/pglite/index.d.cts +1 -1
  31. package/dist/data/pglite/index.d.ts +1 -1
  32. package/dist/data/pglite/index.js +2 -2
  33. package/dist/data/postgres-core/index.cjs +2 -2
  34. package/dist/data/postgres-core/index.d.cts +37 -37
  35. package/dist/data/postgres-core/index.d.ts +37 -37
  36. package/dist/data/postgres-core/index.js +1 -1
  37. package/dist/data/postgresjs/index.cjs +2 -2
  38. package/dist/data/postgresjs/index.d.cts +3 -14
  39. package/dist/data/postgresjs/index.d.ts +3 -14
  40. package/dist/data/postgresjs/index.js +2 -2
  41. package/dist/data/ppg/index.d.cts +1 -1
  42. package/dist/data/ppg/index.d.ts +1 -1
  43. package/dist/data/sqlite-core/index.cjs +2 -2
  44. package/dist/data/sqlite-core/index.d.cts +25 -25
  45. package/dist/data/sqlite-core/index.d.ts +25 -25
  46. package/dist/data/sqlite-core/index.js +2 -2
  47. package/dist/{index-2horhMcs.d.cts → index-BhPjNuvP.d.cts} +10 -6
  48. package/dist/{index-2horhMcs.d.ts → index-BhPjNuvP.d.ts} +10 -6
  49. package/dist/metafile-cjs.json +1 -1
  50. package/dist/metafile-esm.json +1 -1
  51. package/dist/ui/index.cjs +1 -1
  52. package/dist/ui/index.d.cts +1 -1
  53. package/dist/ui/index.d.ts +1 -1
  54. package/dist/ui/index.js +2 -2
  55. package/package.json +22 -1
  56. package/dist/chunk-AHIV4VYN.js +0 -10
  57. package/dist/chunk-CTJRZ7VA.js +0 -10
  58. package/dist/chunk-NDYVVFWW.js +0 -10
  59. package/dist/chunk-OTK4ZF2W.js +0 -10
  60. package/dist/chunk-WHLVNWIR.js +0 -10
@@ -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{q as n}from"./chunk-A6CVKSUD.js";import{e}from"./chunk-GDQBQ7MK.js";e();function p(){return n("select pg_backend_pid() as pid")}function c(r){return{parameters:[r],sql:"select pg_cancel_backend($1);"}}export{p as a,c as b};
10
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vZGF0YS9wb3N0Z3Jlcy1jb3JlL3V0aWxpdHkudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7IGFzUXVlcnksIHR5cGUgUXVlcnkgfSBmcm9tIFwiLi4vcXVlcnlcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFBJRFF1ZXJ5KCk6IFF1ZXJ5PHsgcGlkOiB1bmtub3duIH0+IHtcbiAgcmV0dXJuIGFzUXVlcnkoXCJzZWxlY3QgcGdfYmFja2VuZF9waWQoKSBhcyBwaWRcIik7XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktb2JqZWN0LXR5cGVcbmV4cG9ydCBmdW5jdGlvbiBnZXRDYW5jZWxRdWVyeShwaWQ6IHt9KTogUXVlcnk8dW5rbm93bj4ge1xuICByZXR1cm4ge1xuICAgIHBhcmFtZXRlcnM6IFtwaWRdLFxuICAgIHNxbDogXCJzZWxlY3QgcGdfY2FuY2VsX2JhY2tlbmQoJDEpO1wiLFxuICB9O1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7MkVBQUFBLElBRU8sU0FBU0MsR0FBdUMsQ0FDckQsT0FBT0MsRUFBUSxnQ0FBZ0MsQ0FDakQsQ0FHTyxTQUFTQyxFQUFlQyxFQUF5QixDQUN0RCxNQUFPLENBQ0wsV0FBWSxDQUFDQSxDQUFHLEVBQ2hCLElBQUssK0JBQ1AsQ0FDRiIsCiAgIm5hbWVzIjogWyJpbml0X2RlZmluZV9BQ0NFTEVSQVRFX1NDSEVNQV9CWV9QUk9WSURFUiIsICJnZXRQSURRdWVyeSIsICJhc1F1ZXJ5IiwgImdldENhbmNlbFF1ZXJ5IiwgInBpZCJdCn0K
@@ -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 r}from"./chunk-GDQBQ7MK.js";r();function i(t){let{error:a,query:n}=t,e=a;return e.query=n,[e]}export{i as a};
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  fkColumn: ColumnName | null;\n  fkSchema: SchemaName | null;\n  fkTable: TableName | null;\n  isAutoincrement: boolean;\n  isComputed: boolean;\n  isInPrimaryKey: boolean;\n  name: ColumnName;\n  nullable: boolean;\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   * 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,IA8UO,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"]
}

@@ -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 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};
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}from"./chunk-GDQBQ7MK.js";e();function u(r){return{parameters:[r],sql:"kill ?"}}export{u as a};
10
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vZGF0YS9teXNxbC1jb3JlL3V0aWxpdHkudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB0eXBlIHsgUXVlcnkgfSBmcm9tIFwiLi4vcXVlcnlcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldENhbmNlbFF1ZXJ5KHRocmVhZElkOiB1bmtub3duKTogUXVlcnk8dW5rbm93bj4ge1xuICByZXR1cm4ge1xuICAgIHBhcmFtZXRlcnM6IFt0aHJlYWRJZF0sXG4gICAgc3FsOiBcImtpbGwgP1wiLFxuICB9O1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7bUNBQUFBLElBRU8sU0FBU0MsRUFBZUMsRUFBbUMsQ0FDaEUsTUFBTyxDQUNMLFdBQVksQ0FBQ0EsQ0FBUSxFQUNyQixJQUFLLFFBQ1AsQ0FDRiIsCiAgIm5hbWVzIjogWyJpbml0X2RlZmluZV9BQ0NFTEVSQVRFX1NDSEVNQV9CWV9QUk9WSURFUiIsICJnZXRDYW5jZWxRdWVyeSIsICJ0aHJlYWRJZCJdCn0K
@@ -1,4 +1,4 @@
1
- import { E as Executor, Q as Query, a as ExecuteOptions, b as Either, c as QueryResult } from '../../index-2horhMcs.cjs';
1
+ import { c as Executor, Q as Query, E as ExecuteOptions, a as Either, b as QueryResult } from '../../index-BhPjNuvP.cjs';
2
2
  import 'kysely';
3
3
 
4
4
  declare function deserializeRawResult(response: RawResponse, valueDeserializerFn?: (value: unknown, type: QueryIntrospectionBuiltinType, column: string) => unknown): DeserializedResponse;
@@ -1,4 +1,4 @@
1
- import { E as Executor, Q as Query, a as ExecuteOptions, b as Either, c as QueryResult } from '../../index-2horhMcs.js';
1
+ import { c as Executor, Q as Query, E as ExecuteOptions, a as Either, b as QueryResult } from '../../index-BhPjNuvP.js';
2
2
  import 'kysely';
3
3
 
4
4
  declare function deserializeRawResult(response: RawResponse, valueDeserializerFn?: (value: unknown, type: QueryIntrospectionBuiltinType, column: string) => unknown): DeserializedResponse;
@@ -1,2 +1,2 @@
1
- "use strict";var a=Object.defineProperty;var f=Object.getOwnPropertyDescriptor;var y=Object.getOwnPropertyNames;var E=Object.prototype.hasOwnProperty;var x=(e,r)=>{for(var t in r)a(e,t,{get:r[t],enumerable:!0})},F=(e,r,t,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of y(r))!E.call(e,n)&&n!==t&&a(e,n,{get:()=>r[n],enumerable:!(o=f(r,n))||o.enumerable});return e};var w=e=>F(a({},"__esModule",{value:!0}),e);var k={};x(k,{createStudioBFFClient:()=>h,deserializeError:()=>c,serializeError:()=>m});module.exports=w(k);function h(e){let{customHeaders:r,customPayload:t,resultDeserializerFn:o,url:n}=e,i=e.fetch||fetch;return{async execute(g,p){try{let s=await i(n,{body:JSON.stringify({customPayload:t,procedure:"query",query:g}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:p?.abortSignal});if(!s.ok){let u;try{u=await s.text()}catch{u="unknown error"}return[new Error(u)]}let[l,d]=await s.json();return l?[c(l)]:[null,o?.(d)||d]}catch(s){return[s]}}}}function m(e){if(e instanceof AggregateError){let{name:r,message:t}=e,o=e.errors.map(m);return{name:r,message:t,errors:o}}if(e instanceof Error){let{name:r,message:t}=e;return{name:r,message:t}}return{name:"UnknownError",message:JSON.stringify(e)}}function c(e){let{name:r,message:t}=e;if(e.errors!==void 0){let n=e.errors.map(c),i=new AggregateError(n,t);return i.name=e.name,i}let o=new Error(e.message);return e.name=r,o}
2
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9iZmYvaW5kZXgudHMiLCAiLi4vLi4vLi4vZGF0YS9iZmYvYmZmLWNsaWVudC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiZXhwb3J0ICogZnJvbSBcIi4vYmZmLWNsaWVudFwiO1xuIiwgImltcG9ydCB0eXBlIHsgRXhlY3V0ZU9wdGlvbnMsIEV4ZWN1dG9yIH0gZnJvbSBcIi4uL2V4ZWN1dG9yXCI7XG5pbXBvcnQgdHlwZSB7IFF1ZXJ5LCBRdWVyeVJlc3VsdCB9IGZyb20gXCIuLi9xdWVyeVwiO1xuaW1wb3J0IHR5cGUgeyBFaXRoZXIgfSBmcm9tIFwiLi4vdHlwZS11dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0dWRpb0JGRkNsaWVudFByb3BzIHtcbiAgLyoqXG4gICAqIEFsbG93cyBwYXNzaW5nIGN1c3RvbSBoZWFkZXJzIHRvIHRoZSBCRkYuXG4gICAqXG4gICAqIGUuZy4gYXV0aG9yaXphdGlvbiB0b2tlbi5cbiAgICovXG4gIGN1c3RvbUhlYWRlcnM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuXG4gIC8qKlxuICAgKiBBbGxvd3MgcGFzc2luZyBjdXN0b20gcGF5bG9hZCB0byB0aGUgQkZGIHZpYSBgYm9keS5jdXN0b21QYXlsb2FkYC5cbiAgICpcbiAgICogZS5nLiB0ZW5hbnQgaWQuXG4gICAqL1xuICBjdXN0b21QYXlsb2FkPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG5cbiAgLyoqXG4gICAqIEFsbG93cyBvdmVycmlkaW5nIHRoZSBmZXRjaCBmdW5jdGlvbiBpbXBsZW1lbnRhdGlvbi5cbiAgICpcbiAgICogZS5nLiBmb3IgdGVzdGluZywgb3Igb2xkZXIgTm9kZS5qcyB2ZXJzaW9ucy5cbiAgICovXG4gIGZldGNoPzogdHlwZW9mIGdsb2JhbFRoaXMuZmV0Y2g7XG5cbiAgLyoqXG4gICAqIEZ1bmN0aW9uIHVzZWQgdG8gZGVzZXJpYWxpemUgdGhlIHJlc3VsdHMgb2YgcXVlcmllcy5cbiAgICpcbiAgICogQnkgZGVmYXVsdCwgdGhlIHJlc3VsdHMgYXJlIHJldHVybmVkIGFzIGlzIHdpdGhvdXQgYW55IGFkZGl0aW9uYWwgcHJvY2Vzc2luZy5cbiAgICovXG4gIHJlc3VsdERlc2VyaWFsaXplckZuPyh0aGlzOiB2b2lkLCByZXN1bHRzOiB1bmtub3duKTogdW5rbm93bltdO1xuXG4gIC8qKlxuICAgKiBCRkYgZW5kcG9pbnQgVVJMLlxuICAgKlxuICAgKiBlLmcuIGBodHRwczovL2FwaS5leGFtcGxlLmNvbS9zdHVkaW9gXG4gICAqL1xuICB1cmw6IHN0cmluZyB8IFVSTDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdHVkaW9CRkZDbGllbnQgZXh0ZW5kcyBFeGVjdXRvciB7XG4gIC8qKlxuICAgKiBSZXF1ZXN0cyBCRkYgdG8gcXVlcnkgdGhlIGRhdGFiYXNlLlxuICAgKlxuICAgKiBUaGUgcXVlcnkgaXMgc2VudCBhcyBgYm9keS5xdWVyeWAuXG4gICAqL1xuICBleGVjdXRlPFQ+KHRoaXM6IHZvaWQsIHF1ZXJ5OiBRdWVyeTxUPiwgb3B0aW9ucz86IEV4ZWN1dGVPcHRpb25zKTogUHJvbWlzZTxFaXRoZXI8RXJyb3IsIFF1ZXJ5UmVzdWx0PFF1ZXJ5PFQ+Pj4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN0dWRpb0JGRlF1ZXJ5UmVxdWVzdCB7XG4gIGN1c3RvbVBheWxvYWQ/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgcHJvY2VkdXJlOiBcInF1ZXJ5XCI7XG4gIHF1ZXJ5OiBRdWVyeTx1bmtub3duPjtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgU3R1ZGlvIEJGRiBjbGllbnQuIEJGRiBzdGFuZHMgZm9yIFwiQmFja2VuZCBGb3IgRnJvbnRlbmRcIiBidHcuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTdHVkaW9CRkZDbGllbnQocHJvcHM6IFN0dWRpb0JGRkNsaWVudFByb3BzKTogU3R1ZGlvQkZGQ2xpZW50IHtcbiAgY29uc3QgeyBjdXN0b21IZWFkZXJzLCBjdXN0b21QYXlsb2FkLCByZXN1bHREZXNlcmlhbGl6ZXJGbiwgdXJsIH0gPSBwcm9wcztcbiAgY29uc3QgZmV0Y2hGbiA9IHByb3BzLmZldGNoIHx8IGZldGNoO1xuXG4gIHJldHVybiB7XG4gICAgYXN5bmMgZXhlY3V0ZShxdWVyeSwgb3B0aW9ucz8pIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2hGbih1cmwsIHtcbiAgICAgICAgICBib2R5OiBKU09OLnN0cmluZ2lmeSh7IGN1c3RvbVBheWxvYWQsIHByb2NlZHVyZTogXCJxdWVyeVwiLCBxdWVyeSB9IHNhdGlzZmllcyBTdHVkaW9CRkZRdWVyeVJlcXVlc3QpLFxuICAgICAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgICAgIEFjY2VwdDogXCJhcHBsaWNhdGlvbi9qc29uXCIsXG4gICAgICAgICAgICBcIkNvbnRlbnQtVHlwZVwiOiBcImFwcGxpY2F0aW9uL2pzb25cIixcbiAgICAgICAgICAgIC4uLmN1c3RvbUhlYWRlcnMsXG4gICAgICAgICAgfSxcbiAgICAgICAgICBtZXRob2Q6IFwiUE9TVFwiLFxuICAgICAgICAgIHNpZ25hbDogb3B0aW9ucz8uYWJvcnRTaWduYWwsXG4gICAgICAgIH0pO1xuXG4gICAgICAgIGlmICghcmVzcG9uc2Uub2spIHtcbiAgICAgICAgICBsZXQgZXJyb3JUZXh0OiBzdHJpbmc7XG5cbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgZXJyb3JUZXh0ID0gYXdhaXQgcmVzcG9uc2UudGV4dCgpO1xuICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgZXJyb3JUZXh0ID0gXCJ1bmtub3duIGVycm9yXCI7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgcmV0dXJuIFtuZXcgRXJyb3IoZXJyb3JUZXh0KV07XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBbZXJyb3IsIHJlc3VsdHNdID0gKGF3YWl0IHJlc3BvbnNlLmpzb24oKSkgYXMgW1NlcmlhbGl6ZWRFcnJvciwgdW5rbm93bl07XG5cbiAgICAgICAgaWYgKGVycm9yKSB7XG4gICAgICAgICAgcmV0dXJuIFtkZXNlcmlhbGl6ZUVycm9yKGVycm9yKV07XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gW251bGwsIChyZXN1bHREZXNlcmlhbGl6ZXJGbj8uKHJlc3VsdHMpIHx8IHJlc3VsdHMpIGFzIG5ldmVyXTtcbiAgICAgIH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG4gICAgICAgIC8vIFRPRE86IGhhbmRsZSBwcm9wZXJseVxuICAgICAgICByZXR1cm4gW2Vycm9yIGFzIEVycm9yXTtcbiAgICAgIH1cbiAgICB9LFxuICB9O1xufVxuXG5pbnRlcmZhY2UgU2VyaWFsaXplZEVycm9yIHtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGVycm9ycz86IFNlcmlhbGl6ZWRFcnJvcltdO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2VyaWFsaXplRXJyb3IoZXJyb3I6IHVua25vd24pOiBTZXJpYWxpemVkRXJyb3Ige1xuICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBBZ2dyZWdhdGVFcnJvcikge1xuICAgIGNvbnN0IHsgbmFtZSwgbWVzc2FnZSB9ID0gZXJyb3I7XG4gICAgY29uc3QgZXJyb3JzID0gZXJyb3IuZXJyb3JzLm1hcChzZXJpYWxpemVFcnJvcik7XG4gICAgcmV0dXJuIHsgbmFtZSwgbWVzc2FnZSwgZXJyb3JzIH07XG4gIH1cblxuICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgIGNvbnN0IHsgbmFtZSwgbWVzc2FnZSB9ID0gZXJyb3I7XG4gICAgcmV0dXJuIHsgbmFtZSwgbWVzc2FnZSB9O1xuICB9XG5cbiAgcmV0dXJuIHsgbmFtZTogYFVua25vd25FcnJvcmAsIG1lc3NhZ2U6IEpTT04uc3RyaW5naWZ5KGVycm9yKSB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGVzZXJpYWxpemVFcnJvcihlcnJvcjogU2VyaWFsaXplZEVycm9yKTogRXJyb3Ige1xuICBjb25zdCB7IG5hbWUsIG1lc3NhZ2UgfSA9IGVycm9yO1xuXG4gIGlmIChlcnJvci5lcnJvcnMgIT09IHVuZGVmaW5lZCkge1xuICAgIGNvbnN0IGVycm9ycyA9IGVycm9yLmVycm9ycy5tYXAoZGVzZXJpYWxpemVFcnJvcik7XG4gICAgY29uc3QgYWdncmVnYXRlRXJyb3IgPSBuZXcgQWdncmVnYXRlRXJyb3IoZXJyb3JzLCBtZXNzYWdlKTtcbiAgICBhZ2dyZWdhdGVFcnJvci5uYW1lID0gZXJyb3IubmFtZTtcbiAgICByZXR1cm4gYWdncmVnYXRlRXJyb3I7XG4gIH1cblxuICBjb25zdCByZWd1bGFyRXJyb3IgPSBuZXcgRXJyb3IoZXJyb3IubWVzc2FnZSk7XG4gIGVycm9yLm5hbWUgPSBuYW1lO1xuICByZXR1cm4gcmVndWxhckVycm9yO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogInlhQUFBLElBQUFBLEVBQUEsR0FBQUMsRUFBQUQsRUFBQSwyQkFBQUUsRUFBQSxxQkFBQUMsRUFBQSxtQkFBQUMsSUFBQSxlQUFBQyxFQUFBTCxHQzJETyxTQUFTTSxFQUFzQkMsRUFBOEMsQ0FDbEYsR0FBTSxDQUFFLGNBQUFDLEVBQWUsY0FBQUMsRUFBZSxxQkFBQUMsRUFBc0IsSUFBQUMsQ0FBSSxFQUFJSixFQUM5REssRUFBVUwsRUFBTSxPQUFTLE1BRS9CLE1BQU8sQ0FDTCxNQUFNLFFBQVFNLEVBQU9DLEVBQVUsQ0FDN0IsR0FBSSxDQUNGLElBQU1DLEVBQVcsTUFBTUgsRUFBUUQsRUFBSyxDQUNsQyxLQUFNLEtBQUssVUFBVSxDQUFFLGNBQUFGLEVBQWUsVUFBVyxRQUFTLE1BQUFJLENBQU0sQ0FBaUMsRUFDakcsUUFBUyxDQUNQLE9BQVEsbUJBQ1IsZUFBZ0IsbUJBQ2hCLEdBQUdMLENBQ0wsRUFDQSxPQUFRLE9BQ1IsT0FBUU0sR0FBUyxXQUNuQixDQUFDLEVBRUQsR0FBSSxDQUFDQyxFQUFTLEdBQUksQ0FDaEIsSUFBSUMsRUFFSixHQUFJLENBQ0ZBLEVBQVksTUFBTUQsRUFBUyxLQUFLLENBQ2xDLE1BQVEsQ0FDTkMsRUFBWSxlQUNkLENBRUEsTUFBTyxDQUFDLElBQUksTUFBTUEsQ0FBUyxDQUFDLENBQzlCLENBRUEsR0FBTSxDQUFDQyxFQUFPQyxDQUFPLEVBQUssTUFBTUgsRUFBUyxLQUFLLEVBRTlDLE9BQUlFLEVBQ0ssQ0FBQ0UsRUFBaUJGLENBQUssQ0FBQyxFQUcxQixDQUFDLEtBQU9QLElBQXVCUSxDQUFPLEdBQUtBLENBQWlCLENBQ3JFLE9BQVNELEVBQWdCLENBRXZCLE1BQU8sQ0FBQ0EsQ0FBYyxDQUN4QixDQUNGLENBQ0YsQ0FDRixDQVFPLFNBQVNHLEVBQWVILEVBQWlDLENBQzlELEdBQUlBLGFBQWlCLGVBQWdCLENBQ25DLEdBQU0sQ0FBRSxLQUFBSSxFQUFNLFFBQUFDLENBQVEsRUFBSUwsRUFDcEJNLEVBQVNOLEVBQU0sT0FBTyxJQUFJRyxDQUFjLEVBQzlDLE1BQU8sQ0FBRSxLQUFBQyxFQUFNLFFBQUFDLEVBQVMsT0FBQUMsQ0FBTyxDQUNqQyxDQUVBLEdBQUlOLGFBQWlCLE1BQU8sQ0FDMUIsR0FBTSxDQUFFLEtBQUFJLEVBQU0sUUFBQUMsQ0FBUSxFQUFJTCxFQUMxQixNQUFPLENBQUUsS0FBQUksRUFBTSxRQUFBQyxDQUFRLENBQ3pCLENBRUEsTUFBTyxDQUFFLEtBQU0sZUFBZ0IsUUFBUyxLQUFLLFVBQVVMLENBQUssQ0FBRSxDQUNoRSxDQUVPLFNBQVNFLEVBQWlCRixFQUErQixDQUM5RCxHQUFNLENBQUUsS0FBQUksRUFBTSxRQUFBQyxDQUFRLEVBQUlMLEVBRTFCLEdBQUlBLEVBQU0sU0FBVyxPQUFXLENBQzlCLElBQU1NLEVBQVNOLEVBQU0sT0FBTyxJQUFJRSxDQUFnQixFQUMxQ0ssRUFBaUIsSUFBSSxlQUFlRCxFQUFRRCxDQUFPLEVBQ3pELE9BQUFFLEVBQWUsS0FBT1AsRUFBTSxLQUNyQk8sQ0FDVCxDQUVBLElBQU1DLEVBQWUsSUFBSSxNQUFNUixFQUFNLE9BQU8sRUFDNUMsT0FBQUEsRUFBTSxLQUFPSSxFQUNOSSxDQUNUIiwKICAibmFtZXMiOiBbImJmZl9leHBvcnRzIiwgIl9fZXhwb3J0IiwgImNyZWF0ZVN0dWRpb0JGRkNsaWVudCIsICJkZXNlcmlhbGl6ZUVycm9yIiwgInNlcmlhbGl6ZUVycm9yIiwgIl9fdG9Db21tb25KUyIsICJjcmVhdGVTdHVkaW9CRkZDbGllbnQiLCAicHJvcHMiLCAiY3VzdG9tSGVhZGVycyIsICJjdXN0b21QYXlsb2FkIiwgInJlc3VsdERlc2VyaWFsaXplckZuIiwgInVybCIsICJmZXRjaEZuIiwgInF1ZXJ5IiwgIm9wdGlvbnMiLCAicmVzcG9uc2UiLCAiZXJyb3JUZXh0IiwgImVycm9yIiwgInJlc3VsdHMiLCAiZGVzZXJpYWxpemVFcnJvciIsICJzZXJpYWxpemVFcnJvciIsICJuYW1lIiwgIm1lc3NhZ2UiLCAiZXJyb3JzIiwgImFnZ3JlZ2F0ZUVycm9yIiwgInJlZ3VsYXJFcnJvciJdCn0K
1
+ "use strict";var f=Object.defineProperty;var w=Object.getOwnPropertyDescriptor;var F=Object.getOwnPropertyNames;var x=Object.prototype.hasOwnProperty;var q=(e,r)=>{for(var t in r)f(e,t,{get:r[t],enumerable:!0})},h=(e,r,t,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of F(r))!x.call(e,s)&&s!==t&&f(e,s,{get:()=>r[s],enumerable:!(o=w(r,s))||o.enumerable});return e};var R=e=>h(f({},"__esModule",{value:!0}),e);var T={};q(T,{createStudioBFFClient:()=>Q,deserializeError:()=>l,serializeError:()=>E});module.exports=R(T);function Q(e){let{customHeaders:r,customPayload:t,resultDeserializerFn:o,url:s}=e,u=e.fetch||fetch;return{async execute(d,y){try{let n=await u(s,{body:JSON.stringify({customPayload:t,procedure:"query",query:d}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:y?.abortSignal});if(!n.ok){let c;try{c=await n.text()}catch{c="unknown error"}return[new Error(c)]}let[i,a]=await n.json();return i?[l(i)]:[null,o?.(a)||a]}catch(n){return[n]}},async executeSequence(d,y){try{let n=await u(s,{body:JSON.stringify({customPayload:t,procedure:"sequence",sequence:d}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:y?.abortSignal});if(!n.ok){let p;try{p=await n.text()}catch{p="unknown error"}return[[new Error(p)]]}let[[i,a],c]=await n.json();if(i)return[[l(i)]];let S=o?.(a)||a,[g,m]=c||[];return g?[[null,S],[l(g)]]:[[null,S],[null,o?.(m)||m]]}catch(n){return[[n]]}}}}function E(e){if(e instanceof AggregateError){let{name:r,message:t}=e,o=e.errors.map(E);return{name:r,message:t,errors:o}}if(e instanceof Error){let{name:r,message:t}=e;return{name:r,message:t}}return{name:"UnknownError",message:JSON.stringify(e)}}function l(e){let{name:r,message:t}=e;if(e.errors!==void 0){let s=e.errors.map(l),u=new AggregateError(s,t);return u.name=e.name,u}let o=new Error(e.message);return e.name=r,o}
2
+ //# 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        // TODO: handle properly\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": ["bff_exports", "__export", "createStudioBFFClient", "deserializeError", "serializeError", "__toCommonJS", "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"]
}

@@ -1,4 +1,4 @@
1
- import { E as Executor, Q as Query, a as ExecuteOptions, b as Either, c as QueryResult } from '../../index-2horhMcs.cjs';
1
+ import { S as SequenceExecutor, Q as Query, E as ExecuteOptions, a as Either, b as QueryResult } from '../../index-BhPjNuvP.cjs';
2
2
  import 'kysely';
3
3
 
4
4
  interface StudioBFFClientProps {
@@ -33,19 +33,31 @@ interface StudioBFFClientProps {
33
33
  */
34
34
  url: string | URL;
35
35
  }
36
- interface StudioBFFClient extends Executor {
36
+ interface StudioBFFClient extends SequenceExecutor {
37
37
  /**
38
38
  * Requests BFF to query the database.
39
39
  *
40
40
  * The query is sent as `body.query`.
41
41
  */
42
42
  execute<T>(this: void, query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;
43
+ /**
44
+ * Requests BFF to execute a sequence of queries.
45
+ *
46
+ * The sequence is sent as `body.sequence`.
47
+ */
48
+ executeSequence<T, S>(this: void, sequence: readonly [Query<T>, Query<S>], options?: ExecuteOptions): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;
43
49
  }
50
+ type StudioBFFRequest = StudioBFFQueryRequest | StudioBFFSequenceRequest;
44
51
  interface StudioBFFQueryRequest {
45
52
  customPayload?: Record<string, unknown>;
46
53
  procedure: "query";
47
54
  query: Query<unknown>;
48
55
  }
56
+ interface StudioBFFSequenceRequest {
57
+ customPayload?: Record<string, unknown>;
58
+ procedure: "sequence";
59
+ sequence: readonly [Query<unknown>, Query<unknown>];
60
+ }
49
61
  /**
50
62
  * Creates a Studio BFF client. BFF stands for "Backend For Frontend" btw.
51
63
  */
@@ -58,4 +70,4 @@ interface SerializedError {
58
70
  declare function serializeError(error: unknown): SerializedError;
59
71
  declare function deserializeError(error: SerializedError): Error;
60
72
 
61
- export { type StudioBFFClient, type StudioBFFClientProps, type StudioBFFQueryRequest, createStudioBFFClient, deserializeError, serializeError };
73
+ export { type SerializedError, type StudioBFFClient, type StudioBFFClientProps, type StudioBFFQueryRequest, type StudioBFFRequest, type StudioBFFSequenceRequest, createStudioBFFClient, deserializeError, serializeError };
@@ -1,4 +1,4 @@
1
- import { E as Executor, Q as Query, a as ExecuteOptions, b as Either, c as QueryResult } from '../../index-2horhMcs.js';
1
+ import { S as SequenceExecutor, Q as Query, E as ExecuteOptions, a as Either, b as QueryResult } from '../../index-BhPjNuvP.js';
2
2
  import 'kysely';
3
3
 
4
4
  interface StudioBFFClientProps {
@@ -33,19 +33,31 @@ interface StudioBFFClientProps {
33
33
  */
34
34
  url: string | URL;
35
35
  }
36
- interface StudioBFFClient extends Executor {
36
+ interface StudioBFFClient extends SequenceExecutor {
37
37
  /**
38
38
  * Requests BFF to query the database.
39
39
  *
40
40
  * The query is sent as `body.query`.
41
41
  */
42
42
  execute<T>(this: void, query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;
43
+ /**
44
+ * Requests BFF to execute a sequence of queries.
45
+ *
46
+ * The sequence is sent as `body.sequence`.
47
+ */
48
+ executeSequence<T, S>(this: void, sequence: readonly [Query<T>, Query<S>], options?: ExecuteOptions): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;
43
49
  }
50
+ type StudioBFFRequest = StudioBFFQueryRequest | StudioBFFSequenceRequest;
44
51
  interface StudioBFFQueryRequest {
45
52
  customPayload?: Record<string, unknown>;
46
53
  procedure: "query";
47
54
  query: Query<unknown>;
48
55
  }
56
+ interface StudioBFFSequenceRequest {
57
+ customPayload?: Record<string, unknown>;
58
+ procedure: "sequence";
59
+ sequence: readonly [Query<unknown>, Query<unknown>];
60
+ }
49
61
  /**
50
62
  * Creates a Studio BFF client. BFF stands for "Backend For Frontend" btw.
51
63
  */
@@ -58,4 +70,4 @@ interface SerializedError {
58
70
  declare function serializeError(error: unknown): SerializedError;
59
71
  declare function deserializeError(error: SerializedError): Error;
60
72
 
61
- export { type StudioBFFClient, type StudioBFFClientProps, type StudioBFFQueryRequest, createStudioBFFClient, deserializeError, serializeError };
73
+ export { type SerializedError, type StudioBFFClient, type StudioBFFClientProps, type StudioBFFQueryRequest, type StudioBFFRequest, type StudioBFFSequenceRequest, createStudioBFFClient, deserializeError, serializeError };
@@ -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 i}from"../../chunk-GDQBQ7MK.js";i();i();function y(e){let{customHeaders:r,customPayload:t,resultDeserializerFn:n,url:u}=e,s=e.fetch||fetch;return{async execute(m,g){try{let o=await s(u,{body:JSON.stringify({customPayload:t,procedure:"query",query:m}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:g?.abortSignal});if(!o.ok){let a;try{a=await o.text()}catch{a="unknown error"}return[new Error(a)]}let[c,l]=await o.json();return c?[d(c)]:[null,n?.(l)||l]}catch(o){return[o]}}}}function f(e){if(e instanceof AggregateError){let{name:r,message:t}=e,n=e.errors.map(f);return{name:r,message:t,errors:n}}if(e instanceof Error){let{name:r,message:t}=e;return{name:r,message:t}}return{name:"UnknownError",message:JSON.stringify(e)}}function d(e){let{name:r,message:t}=e;if(e.errors!==void 0){let u=e.errors.map(d),s=new AggregateError(u,t);return s.name=e.name,s}let n=new Error(e.message);return e.name=r,n}export{y as createStudioBFFClient,d as deserializeError,f as serializeError};
10
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9iZmYvaW5kZXgudHMiLCAiLi4vLi4vLi4vZGF0YS9iZmYvYmZmLWNsaWVudC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiZXhwb3J0ICogZnJvbSBcIi4vYmZmLWNsaWVudFwiO1xuIiwgImltcG9ydCB0eXBlIHsgRXhlY3V0ZU9wdGlvbnMsIEV4ZWN1dG9yIH0gZnJvbSBcIi4uL2V4ZWN1dG9yXCI7XG5pbXBvcnQgdHlwZSB7IFF1ZXJ5LCBRdWVyeVJlc3VsdCB9IGZyb20gXCIuLi9xdWVyeVwiO1xuaW1wb3J0IHR5cGUgeyBFaXRoZXIgfSBmcm9tIFwiLi4vdHlwZS11dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0dWRpb0JGRkNsaWVudFByb3BzIHtcbiAgLyoqXG4gICAqIEFsbG93cyBwYXNzaW5nIGN1c3RvbSBoZWFkZXJzIHRvIHRoZSBCRkYuXG4gICAqXG4gICAqIGUuZy4gYXV0aG9yaXphdGlvbiB0b2tlbi5cbiAgICovXG4gIGN1c3RvbUhlYWRlcnM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuXG4gIC8qKlxuICAgKiBBbGxvd3MgcGFzc2luZyBjdXN0b20gcGF5bG9hZCB0byB0aGUgQkZGIHZpYSBgYm9keS5jdXN0b21QYXlsb2FkYC5cbiAgICpcbiAgICogZS5nLiB0ZW5hbnQgaWQuXG4gICAqL1xuICBjdXN0b21QYXlsb2FkPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG5cbiAgLyoqXG4gICAqIEFsbG93cyBvdmVycmlkaW5nIHRoZSBmZXRjaCBmdW5jdGlvbiBpbXBsZW1lbnRhdGlvbi5cbiAgICpcbiAgICogZS5nLiBmb3IgdGVzdGluZywgb3Igb2xkZXIgTm9kZS5qcyB2ZXJzaW9ucy5cbiAgICovXG4gIGZldGNoPzogdHlwZW9mIGdsb2JhbFRoaXMuZmV0Y2g7XG5cbiAgLyoqXG4gICAqIEZ1bmN0aW9uIHVzZWQgdG8gZGVzZXJpYWxpemUgdGhlIHJlc3VsdHMgb2YgcXVlcmllcy5cbiAgICpcbiAgICogQnkgZGVmYXVsdCwgdGhlIHJlc3VsdHMgYXJlIHJldHVybmVkIGFzIGlzIHdpdGhvdXQgYW55IGFkZGl0aW9uYWwgcHJvY2Vzc2luZy5cbiAgICovXG4gIHJlc3VsdERlc2VyaWFsaXplckZuPyh0aGlzOiB2b2lkLCByZXN1bHRzOiB1bmtub3duKTogdW5rbm93bltdO1xuXG4gIC8qKlxuICAgKiBCRkYgZW5kcG9pbnQgVVJMLlxuICAgKlxuICAgKiBlLmcuIGBodHRwczovL2FwaS5leGFtcGxlLmNvbS9zdHVkaW9gXG4gICAqL1xuICB1cmw6IHN0cmluZyB8IFVSTDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdHVkaW9CRkZDbGllbnQgZXh0ZW5kcyBFeGVjdXRvciB7XG4gIC8qKlxuICAgKiBSZXF1ZXN0cyBCRkYgdG8gcXVlcnkgdGhlIGRhdGFiYXNlLlxuICAgKlxuICAgKiBUaGUgcXVlcnkgaXMgc2VudCBhcyBgYm9keS5xdWVyeWAuXG4gICAqL1xuICBleGVjdXRlPFQ+KHRoaXM6IHZvaWQsIHF1ZXJ5OiBRdWVyeTxUPiwgb3B0aW9ucz86IEV4ZWN1dGVPcHRpb25zKTogUHJvbWlzZTxFaXRoZXI8RXJyb3IsIFF1ZXJ5UmVzdWx0PFF1ZXJ5PFQ+Pj4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN0dWRpb0JGRlF1ZXJ5UmVxdWVzdCB7XG4gIGN1c3RvbVBheWxvYWQ/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgcHJvY2VkdXJlOiBcInF1ZXJ5XCI7XG4gIHF1ZXJ5OiBRdWVyeTx1bmtub3duPjtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgU3R1ZGlvIEJGRiBjbGllbnQuIEJGRiBzdGFuZHMgZm9yIFwiQmFja2VuZCBGb3IgRnJvbnRlbmRcIiBidHcuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTdHVkaW9CRkZDbGllbnQocHJvcHM6IFN0dWRpb0JGRkNsaWVudFByb3BzKTogU3R1ZGlvQkZGQ2xpZW50IHtcbiAgY29uc3QgeyBjdXN0b21IZWFkZXJzLCBjdXN0b21QYXlsb2FkLCByZXN1bHREZXNlcmlhbGl6ZXJGbiwgdXJsIH0gPSBwcm9wcztcbiAgY29uc3QgZmV0Y2hGbiA9IHByb3BzLmZldGNoIHx8IGZldGNoO1xuXG4gIHJldHVybiB7XG4gICAgYXN5bmMgZXhlY3V0ZShxdWVyeSwgb3B0aW9ucz8pIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2hGbih1cmwsIHtcbiAgICAgICAgICBib2R5OiBKU09OLnN0cmluZ2lmeSh7IGN1c3RvbVBheWxvYWQsIHByb2NlZHVyZTogXCJxdWVyeVwiLCBxdWVyeSB9IHNhdGlzZmllcyBTdHVkaW9CRkZRdWVyeVJlcXVlc3QpLFxuICAgICAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgICAgIEFjY2VwdDogXCJhcHBsaWNhdGlvbi9qc29uXCIsXG4gICAgICAgICAgICBcIkNvbnRlbnQtVHlwZVwiOiBcImFwcGxpY2F0aW9uL2pzb25cIixcbiAgICAgICAgICAgIC4uLmN1c3RvbUhlYWRlcnMsXG4gICAgICAgICAgfSxcbiAgICAgICAgICBtZXRob2Q6IFwiUE9TVFwiLFxuICAgICAgICAgIHNpZ25hbDogb3B0aW9ucz8uYWJvcnRTaWduYWwsXG4gICAgICAgIH0pO1xuXG4gICAgICAgIGlmICghcmVzcG9uc2Uub2spIHtcbiAgICAgICAgICBsZXQgZXJyb3JUZXh0OiBzdHJpbmc7XG5cbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgZXJyb3JUZXh0ID0gYXdhaXQgcmVzcG9uc2UudGV4dCgpO1xuICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgZXJyb3JUZXh0ID0gXCJ1bmtub3duIGVycm9yXCI7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgcmV0dXJuIFtuZXcgRXJyb3IoZXJyb3JUZXh0KV07XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBbZXJyb3IsIHJlc3VsdHNdID0gKGF3YWl0IHJlc3BvbnNlLmpzb24oKSkgYXMgW1NlcmlhbGl6ZWRFcnJvciwgdW5rbm93bl07XG5cbiAgICAgICAgaWYgKGVycm9yKSB7XG4gICAgICAgICAgcmV0dXJuIFtkZXNlcmlhbGl6ZUVycm9yKGVycm9yKV07XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gW251bGwsIChyZXN1bHREZXNlcmlhbGl6ZXJGbj8uKHJlc3VsdHMpIHx8IHJlc3VsdHMpIGFzIG5ldmVyXTtcbiAgICAgIH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG4gICAgICAgIC8vIFRPRE86IGhhbmRsZSBwcm9wZXJseVxuICAgICAgICByZXR1cm4gW2Vycm9yIGFzIEVycm9yXTtcbiAgICAgIH1cbiAgICB9LFxuICB9O1xufVxuXG5pbnRlcmZhY2UgU2VyaWFsaXplZEVycm9yIHtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGVycm9ycz86IFNlcmlhbGl6ZWRFcnJvcltdO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2VyaWFsaXplRXJyb3IoZXJyb3I6IHVua25vd24pOiBTZXJpYWxpemVkRXJyb3Ige1xuICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBBZ2dyZWdhdGVFcnJvcikge1xuICAgIGNvbnN0IHsgbmFtZSwgbWVzc2FnZSB9ID0gZXJyb3I7XG4gICAgY29uc3QgZXJyb3JzID0gZXJyb3IuZXJyb3JzLm1hcChzZXJpYWxpemVFcnJvcik7XG4gICAgcmV0dXJuIHsgbmFtZSwgbWVzc2FnZSwgZXJyb3JzIH07XG4gIH1cblxuICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgIGNvbnN0IHsgbmFtZSwgbWVzc2FnZSB9ID0gZXJyb3I7XG4gICAgcmV0dXJuIHsgbmFtZSwgbWVzc2FnZSB9O1xuICB9XG5cbiAgcmV0dXJuIHsgbmFtZTogYFVua25vd25FcnJvcmAsIG1lc3NhZ2U6IEpTT04uc3RyaW5naWZ5KGVycm9yKSB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGVzZXJpYWxpemVFcnJvcihlcnJvcjogU2VyaWFsaXplZEVycm9yKTogRXJyb3Ige1xuICBjb25zdCB7IG5hbWUsIG1lc3NhZ2UgfSA9IGVycm9yO1xuXG4gIGlmIChlcnJvci5lcnJvcnMgIT09IHVuZGVmaW5lZCkge1xuICAgIGNvbnN0IGVycm9ycyA9IGVycm9yLmVycm9ycy5tYXAoZGVzZXJpYWxpemVFcnJvcik7XG4gICAgY29uc3QgYWdncmVnYXRlRXJyb3IgPSBuZXcgQWdncmVnYXRlRXJyb3IoZXJyb3JzLCBtZXNzYWdlKTtcbiAgICBhZ2dyZWdhdGVFcnJvci5uYW1lID0gZXJyb3IubmFtZTtcbiAgICByZXR1cm4gYWdncmVnYXRlRXJyb3I7XG4gIH1cblxuICBjb25zdCByZWd1bGFyRXJyb3IgPSBuZXcgRXJyb3IoZXJyb3IubWVzc2FnZSk7XG4gIGVycm9yLm5hbWUgPSBuYW1lO1xuICByZXR1cm4gcmVndWxhckVycm9yO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7NENBQUFBLElDQUFDLElBMkRPLFNBQVNDLEVBQXNCQyxFQUE4QyxDQUNsRixHQUFNLENBQUUsY0FBQUMsRUFBZSxjQUFBQyxFQUFlLHFCQUFBQyxFQUFzQixJQUFBQyxDQUFJLEVBQUlKLEVBQzlESyxFQUFVTCxFQUFNLE9BQVMsTUFFL0IsTUFBTyxDQUNMLE1BQU0sUUFBUU0sRUFBT0MsRUFBVSxDQUM3QixHQUFJLENBQ0YsSUFBTUMsRUFBVyxNQUFNSCxFQUFRRCxFQUFLLENBQ2xDLEtBQU0sS0FBSyxVQUFVLENBQUUsY0FBQUYsRUFBZSxVQUFXLFFBQVMsTUFBQUksQ0FBTSxDQUFpQyxFQUNqRyxRQUFTLENBQ1AsT0FBUSxtQkFDUixlQUFnQixtQkFDaEIsR0FBR0wsQ0FDTCxFQUNBLE9BQVEsT0FDUixPQUFRTSxHQUFTLFdBQ25CLENBQUMsRUFFRCxHQUFJLENBQUNDLEVBQVMsR0FBSSxDQUNoQixJQUFJQyxFQUVKLEdBQUksQ0FDRkEsRUFBWSxNQUFNRCxFQUFTLEtBQUssQ0FDbEMsTUFBUSxDQUNOQyxFQUFZLGVBQ2QsQ0FFQSxNQUFPLENBQUMsSUFBSSxNQUFNQSxDQUFTLENBQUMsQ0FDOUIsQ0FFQSxHQUFNLENBQUNDLEVBQU9DLENBQU8sRUFBSyxNQUFNSCxFQUFTLEtBQUssRUFFOUMsT0FBSUUsRUFDSyxDQUFDRSxFQUFpQkYsQ0FBSyxDQUFDLEVBRzFCLENBQUMsS0FBT1AsSUFBdUJRLENBQU8sR0FBS0EsQ0FBaUIsQ0FDckUsT0FBU0QsRUFBZ0IsQ0FFdkIsTUFBTyxDQUFDQSxDQUFjLENBQ3hCLENBQ0YsQ0FDRixDQUNGLENBUU8sU0FBU0csRUFBZUgsRUFBaUMsQ0FDOUQsR0FBSUEsYUFBaUIsZUFBZ0IsQ0FDbkMsR0FBTSxDQUFFLEtBQUFJLEVBQU0sUUFBQUMsQ0FBUSxFQUFJTCxFQUNwQk0sRUFBU04sRUFBTSxPQUFPLElBQUlHLENBQWMsRUFDOUMsTUFBTyxDQUFFLEtBQUFDLEVBQU0sUUFBQUMsRUFBUyxPQUFBQyxDQUFPLENBQ2pDLENBRUEsR0FBSU4sYUFBaUIsTUFBTyxDQUMxQixHQUFNLENBQUUsS0FBQUksRUFBTSxRQUFBQyxDQUFRLEVBQUlMLEVBQzFCLE1BQU8sQ0FBRSxLQUFBSSxFQUFNLFFBQUFDLENBQVEsQ0FDekIsQ0FFQSxNQUFPLENBQUUsS0FBTSxlQUFnQixRQUFTLEtBQUssVUFBVUwsQ0FBSyxDQUFFLENBQ2hFLENBRU8sU0FBU0UsRUFBaUJGLEVBQStCLENBQzlELEdBQU0sQ0FBRSxLQUFBSSxFQUFNLFFBQUFDLENBQVEsRUFBSUwsRUFFMUIsR0FBSUEsRUFBTSxTQUFXLE9BQVcsQ0FDOUIsSUFBTU0sRUFBU04sRUFBTSxPQUFPLElBQUlFLENBQWdCLEVBQzFDSyxFQUFpQixJQUFJLGVBQWVELEVBQVFELENBQU8sRUFDekQsT0FBQUUsRUFBZSxLQUFPUCxFQUFNLEtBQ3JCTyxDQUNULENBRUEsSUFBTUMsRUFBZSxJQUFJLE1BQU1SLEVBQU0sT0FBTyxFQUM1QyxPQUFBQSxFQUFNLEtBQU9JLEVBQ05JLENBQ1QiLAogICJuYW1lcyI6IFsiaW5pdF9kZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVIiLCAiaW5pdF9kZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVIiLCAiY3JlYXRlU3R1ZGlvQkZGQ2xpZW50IiwgInByb3BzIiwgImN1c3RvbUhlYWRlcnMiLCAiY3VzdG9tUGF5bG9hZCIsICJyZXN1bHREZXNlcmlhbGl6ZXJGbiIsICJ1cmwiLCAiZmV0Y2hGbiIsICJxdWVyeSIsICJvcHRpb25zIiwgInJlc3BvbnNlIiwgImVycm9yVGV4dCIsICJlcnJvciIsICJyZXN1bHRzIiwgImRlc2VyaWFsaXplRXJyb3IiLCAic2VyaWFsaXplRXJyb3IiLCAibmFtZSIsICJtZXNzYWdlIiwgImVycm9ycyIsICJhZ2dyZWdhdGVFcnJvciIsICJyZWd1bGFyRXJyb3IiXQp9Cg==
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};
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        // TODO: handle properly\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"]
}

@@ -1,2 +1,2 @@
1
- export { H as AbortError, A as Adapter, k as AdapterBaseOptions, f as AdapterDeleteDetails, p as AdapterDeleteOptions, z as AdapterDeleteResult, i as AdapterError, g as AdapterInsertDetails, n as AdapterInsertOptions, x as AdapterInsertResult, l as AdapterIntrospectOptions, q as AdapterIntrospectResult, e as AdapterQueryDetails, m as AdapterQueryOptions, w as AdapterQueryResult, d as AdapterRequirements, h as AdapterUpdateDetails, o as AdapterUpdateOptions, y as AdapterUpdateResult, J as BigIntString, C as Column, s as ColumnFilter, D as DataType, r as DataTypeGroup, b as Either, a as ExecuteOptions, E as Executor, t as FilterGroup, F as FilterOperator, N as NumericString, Q as Query, c as QueryResult, S as Schema, v as SortDirection, u as SortOrderItem, T as Table, j as applyInferredRowFilters, G as createAdapterError, I as getAbortResult } from '../index-2horhMcs.cjs';
1
+ export { I as AbortError, A as Adapter, k as AdapterBaseOptions, f as AdapterDeleteDetails, p as AdapterDeleteOptions, G as AdapterDeleteResult, i as AdapterError, g as AdapterInsertDetails, n as AdapterInsertOptions, y as AdapterInsertResult, l as AdapterIntrospectOptions, q as AdapterIntrospectResult, e as AdapterQueryDetails, m as AdapterQueryOptions, x as AdapterQueryResult, d as AdapterRequirements, h as AdapterUpdateDetails, o as AdapterUpdateOptions, z as AdapterUpdateResult, K as BigIntString, C as Column, t as ColumnFilter, D as DataType, s as DataTypeGroup, a as Either, E as ExecuteOptions, c as Executor, u as FilterGroup, F as FilterOperator, N as NumericString, Q as Query, b as QueryResult, r as Schema, S as SequenceExecutor, w as SortDirection, v as SortOrderItem, T as Table, j as applyInferredRowFilters, H as createAdapterError, J as getAbortResult } from '../index-BhPjNuvP.cjs';
2
2
  import 'kysely';
@@ -1,2 +1,2 @@
1
- export { H as AbortError, A as Adapter, k as AdapterBaseOptions, f as AdapterDeleteDetails, p as AdapterDeleteOptions, z as AdapterDeleteResult, i as AdapterError, g as AdapterInsertDetails, n as AdapterInsertOptions, x as AdapterInsertResult, l as AdapterIntrospectOptions, q as AdapterIntrospectResult, e as AdapterQueryDetails, m as AdapterQueryOptions, w as AdapterQueryResult, d as AdapterRequirements, h as AdapterUpdateDetails, o as AdapterUpdateOptions, y as AdapterUpdateResult, J as BigIntString, C as Column, s as ColumnFilter, D as DataType, r as DataTypeGroup, b as Either, a as ExecuteOptions, E as Executor, t as FilterGroup, F as FilterOperator, N as NumericString, Q as Query, c as QueryResult, S as Schema, v as SortDirection, u as SortOrderItem, T as Table, j as applyInferredRowFilters, G as createAdapterError, I as getAbortResult } from '../index-2horhMcs.js';
1
+ export { I as AbortError, A as Adapter, k as AdapterBaseOptions, f as AdapterDeleteDetails, p as AdapterDeleteOptions, G as AdapterDeleteResult, i as AdapterError, g as AdapterInsertDetails, n as AdapterInsertOptions, y as AdapterInsertResult, l as AdapterIntrospectOptions, q as AdapterIntrospectResult, e as AdapterQueryDetails, m as AdapterQueryOptions, x as AdapterQueryResult, d as AdapterRequirements, h as AdapterUpdateDetails, o as AdapterUpdateOptions, z as AdapterUpdateResult, K as BigIntString, C as Column, t as ColumnFilter, D as DataType, s as DataTypeGroup, a as Either, E as ExecuteOptions, c as Executor, u as FilterGroup, F as FilterOperator, N as NumericString, Q as Query, b as QueryResult, r as Schema, S as SequenceExecutor, w as SortDirection, v as SortOrderItem, T as Table, j as applyInferredRowFilters, H as createAdapterError, J as getAbortResult } from '../index-BhPjNuvP.js';
2
2
  import 'kysely';
@@ -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{q as r}from"../chunk-WHLVNWIR.js";import{e}from"../chunk-GDQBQ7MK.js";e();export{r as applyInferredRowFilters};
9
+ import{s as r}from"../chunk-A6CVKSUD.js";import{e}from"../chunk-GDQBQ7MK.js";e();export{r as applyInferredRowFilters};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vZGF0YS9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiZXhwb3J0IHR5cGUgKiBmcm9tIFwiLi9hZGFwdGVyXCI7XG5leHBvcnQgdHlwZSAqIGZyb20gXCIuL2V4ZWN1dG9yXCI7XG5leHBvcnQgeyBhcHBseUluZmVycmVkUm93RmlsdGVycywgdHlwZSBRdWVyeSwgdHlwZSBRdWVyeVJlc3VsdCB9IGZyb20gXCIuL3F1ZXJ5XCI7XG5leHBvcnQgdHlwZSAqIGZyb20gXCIuL3R5cGUtdXRpbHNcIjtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7OzZFQUFBQSIsCiAgIm5hbWVzIjogWyJpbml0X2RlZmluZV9BQ0NFTEVSQVRFX1NDSEVNQV9CWV9QUk9WSURFUiJdCn0K