45 lines
174 KiB
JavaScript
45 lines
174 KiB
JavaScript
"use strict";
|
|
/*
|
|
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
* This devtool is neither made for production nor for readable output files.
|
|
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
* or disable the default devtool with "devtool: false".
|
|
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
*/
|
|
exports.id = "vendor-chunks/iceberg-js";
|
|
exports.ids = ["vendor-chunks/iceberg-js"];
|
|
exports.modules = {
|
|
|
|
/***/ "(ssr)/./node_modules/iceberg-js/dist/index.mjs":
|
|
/*!************************************************!*\
|
|
!*** ./node_modules/iceberg-js/dist/index.mjs ***!
|
|
\************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ IcebergError: () => (/* binding */ IcebergError),\n/* harmony export */ IcebergRestCatalog: () => (/* binding */ IcebergRestCatalog),\n/* harmony export */ getCurrentSchema: () => (/* binding */ getCurrentSchema),\n/* harmony export */ isDecimalType: () => (/* binding */ isDecimalType),\n/* harmony export */ isFixedType: () => (/* binding */ isFixedType),\n/* harmony export */ parseDecimalType: () => (/* binding */ parseDecimalType),\n/* harmony export */ parseFixedType: () => (/* binding */ parseFixedType),\n/* harmony export */ typesEqual: () => (/* binding */ typesEqual)\n/* harmony export */ });\n// src/errors/IcebergError.ts\nvar IcebergError = class extends Error {\n constructor(message, opts){\n super(message);\n this.name = \"IcebergError\";\n this.status = opts.status;\n this.icebergType = opts.icebergType;\n this.icebergCode = opts.icebergCode;\n this.details = opts.details;\n this.isCommitStateUnknown = opts.icebergType === \"CommitStateUnknownException\" || [\n 500,\n 502,\n 504\n ].includes(opts.status) && opts.icebergType?.includes(\"CommitState\") === true;\n }\n /**\n * Returns true if the error is a 404 Not Found error.\n */ isNotFound() {\n return this.status === 404;\n }\n /**\n * Returns true if the error is a 409 Conflict error.\n */ isConflict() {\n return this.status === 409;\n }\n /**\n * Returns true if the error is a 419 Authentication Timeout error.\n */ isAuthenticationTimeout() {\n return this.status === 419;\n }\n};\n// src/utils/url.ts\nfunction buildUrl(baseUrl, path, query) {\n const url = new URL(path, baseUrl);\n if (query) {\n for (const [key, value] of Object.entries(query)){\n if (value !== void 0) {\n url.searchParams.set(key, value);\n }\n }\n }\n return url.toString();\n}\n// src/http/createFetchClient.ts\nasync function buildAuthHeaders(auth) {\n if (!auth || auth.type === \"none\") {\n return {};\n }\n if (auth.type === \"bearer\") {\n return {\n Authorization: `Bearer ${auth.token}`\n };\n }\n if (auth.type === \"header\") {\n return {\n [auth.name]: auth.value\n };\n }\n if (auth.type === \"custom\") {\n return await auth.getHeaders();\n }\n return {};\n}\nfunction createFetchClient(options) {\n const fetchFn = options.fetchImpl ?? globalThis.fetch;\n return {\n async request ({ method, path, query, body, headers }) {\n const url = buildUrl(options.baseUrl, path, query);\n const authHeaders = await buildAuthHeaders(options.auth);\n const res = await fetchFn(url, {\n method,\n headers: {\n ...body ? {\n \"Content-Type\": \"application/json\"\n } : {},\n ...authHeaders,\n ...headers\n },\n body: body ? JSON.stringify(body) : void 0\n });\n const text = await res.text();\n const isJson = (res.headers.get(\"content-type\") || \"\").includes(\"application/json\");\n const data = isJson && text ? JSON.parse(text) : text;\n if (!res.ok) {\n const errBody = isJson ? data : void 0;\n const errorDetail = errBody?.error;\n throw new IcebergError(errorDetail?.message ?? `Request failed with status ${res.status}`, {\n status: res.status,\n icebergType: errorDetail?.type,\n icebergCode: errorDetail?.code,\n details: errBody\n });\n }\n return {\n status: res.status,\n headers: res.headers,\n data\n };\n }\n };\n}\n// src/catalog/namespaces.ts\nfunction namespaceToPath(namespace) {\n return namespace.join(\"\\x1f\");\n}\nvar NamespaceOperations = class {\n constructor(client, prefix = \"\"){\n this.client = client;\n this.prefix = prefix;\n }\n async listNamespaces(parent) {\n const query = parent ? {\n parent: namespaceToPath(parent.namespace)\n } : void 0;\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces`,\n query\n });\n return response.data.namespaces.map((ns)=>({\n namespace: ns\n }));\n }\n async createNamespace(id, metadata) {\n const request = {\n namespace: id.namespace,\n properties: metadata?.properties\n };\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces`,\n body: request\n });\n return response.data;\n }\n async dropNamespace(id) {\n await this.client.request({\n method: \"DELETE\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n }\n async loadNamespaceMetadata(id) {\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n return {\n properties: response.data.properties\n };\n }\n async namespaceExists(id) {\n try {\n await this.client.request({\n method: \"HEAD\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n return true;\n } catch (error) {\n if (error instanceof IcebergError && error.status === 404) {\n return false;\n }\n throw error;\n }\n }\n async createNamespaceIfNotExists(id, metadata) {\n try {\n return await this.createNamespace(id, metadata);\n } catch (error) {\n if (error instanceof IcebergError && error.status === 409) {\n return;\n }\n throw error;\n }\n }\n};\n// src/catalog/tables.ts\nfunction namespaceToPath2(namespace) {\n return namespace.join(\"\\x1f\");\n}\nvar TableOperations = class {\n constructor(client, prefix = \"\", accessDelegation){\n this.client = client;\n this.prefix = prefix;\n this.accessDelegation = accessDelegation;\n }\n async listTables(namespace) {\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`\n });\n return response.data.identifiers;\n }\n async createTable(namespace, request) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`,\n body: request,\n headers\n });\n return response.data.metadata;\n }\n async updateTable(id, request) {\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n body: request\n });\n return {\n \"metadata-location\": response.data[\"metadata-location\"],\n metadata: response.data.metadata\n };\n }\n async dropTable(id, options) {\n await this.client.request({\n method: \"DELETE\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n query: {\n purgeRequested: String(options?.purge ?? false)\n }\n });\n }\n async loadTable(id) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n headers\n });\n return response.data.metadata;\n }\n async tableExists(id) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n try {\n await this.client.request({\n method: \"HEAD\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n headers\n });\n return true;\n } catch (error) {\n if (error instanceof IcebergError && error.status === 404) {\n return false;\n }\n throw error;\n }\n }\n async createTableIfNotExists(namespace, request) {\n try {\n return await this.createTable(namespace, request);\n } catch (error) {\n if (error instanceof IcebergError && error.status === 409) {\n return await this.loadTable({\n namespace: namespace.namespace,\n name: request.name\n });\n }\n throw error;\n }\n }\n};\n// src/catalog/IcebergRestCatalog.ts\nvar IcebergRestCatalog = class {\n /**\n * Creates a new Iceberg REST Catalog client.\n *\n * @param options - Configuration options for the catalog client\n */ constructor(options){\n let prefix = \"v1\";\n if (options.catalogName) {\n prefix += `/${options.catalogName}`;\n }\n const baseUrl = options.baseUrl.endsWith(\"/\") ? options.baseUrl : `${options.baseUrl}/`;\n this.client = createFetchClient({\n baseUrl,\n auth: options.auth,\n fetchImpl: options.fetch\n });\n this.accessDelegation = options.accessDelegation?.join(\",\");\n this.namespaceOps = new NamespaceOperations(this.client, prefix);\n this.tableOps = new TableOperations(this.client, prefix, this.accessDelegation);\n }\n /**\n * Lists all namespaces in the catalog.\n *\n * @param parent - Optional parent namespace to list children under\n * @returns Array of namespace identifiers\n *\n * @example\n * ```typescript\n * // List all top-level namespaces\n * const namespaces = await catalog.listNamespaces();\n *\n * // List namespaces under a parent\n * const children = await catalog.listNamespaces({ namespace: ['analytics'] });\n * ```\n */ async listNamespaces(parent) {\n return this.namespaceOps.listNamespaces(parent);\n }\n /**\n * Creates a new namespace in the catalog.\n *\n * @param id - Namespace identifier to create\n * @param metadata - Optional metadata properties for the namespace\n * @returns Response containing the created namespace and its properties\n *\n * @example\n * ```typescript\n * const response = await catalog.createNamespace(\n * { namespace: ['analytics'] },\n * { properties: { owner: 'data-team' } }\n * );\n * console.log(response.namespace); // ['analytics']\n * console.log(response.properties); // { owner: 'data-team', ... }\n * ```\n */ async createNamespace(id, metadata) {\n return this.namespaceOps.createNamespace(id, metadata);\n }\n /**\n * Drops a namespace from the catalog.\n *\n * The namespace must be empty (contain no tables) before it can be dropped.\n *\n * @param id - Namespace identifier to drop\n *\n * @example\n * ```typescript\n * await catalog.dropNamespace({ namespace: ['analytics'] });\n * ```\n */ async dropNamespace(id) {\n await this.namespaceOps.dropNamespace(id);\n }\n /**\n * Loads metadata for a namespace.\n *\n * @param id - Namespace identifier to load\n * @returns Namespace metadata including properties\n *\n * @example\n * ```typescript\n * const metadata = await catalog.loadNamespaceMetadata({ namespace: ['analytics'] });\n * console.log(metadata.properties);\n * ```\n */ async loadNamespaceMetadata(id) {\n return this.namespaceOps.loadNamespaceMetadata(id);\n }\n /**\n * Lists all tables in a namespace.\n *\n * @param namespace - Namespace identifier to list tables from\n * @returns Array of table identifiers\n *\n * @example\n * ```typescript\n * const tables = await catalog.listTables({ namespace: ['analytics'] });\n * console.log(tables); // [{ namespace: ['analytics'], name: 'events' }, ...]\n * ```\n */ async listTables(namespace) {\n return this.tableOps.listTables(namespace);\n }\n /**\n * Creates a new table in the catalog.\n *\n * @param namespace - Namespace to create the table in\n * @param request - Table creation request including name, schema, partition spec, etc.\n * @returns Table metadata for the created table\n *\n * @example\n * ```typescript\n * const metadata = await catalog.createTable(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n * ],\n * 'schema-id': 0\n * },\n * 'partition-spec': {\n * 'spec-id': 0,\n * fields: [\n * { source_id: 2, field_id: 1000, name: 'ts_day', transform: 'day' }\n * ]\n * }\n * }\n * );\n * ```\n */ async createTable(namespace, request) {\n return this.tableOps.createTable(namespace, request);\n }\n /**\n * Updates an existing table's metadata.\n *\n * Can update the schema, partition spec, or properties of a table.\n *\n * @param id - Table identifier to update\n * @param request - Update request with fields to modify\n * @returns Response containing the metadata location and updated table metadata\n *\n * @example\n * ```typescript\n * const response = await catalog.updateTable(\n * { namespace: ['analytics'], name: 'events' },\n * {\n * properties: { 'read.split.target-size': '134217728' }\n * }\n * );\n * console.log(response['metadata-location']); // s3://...\n * console.log(response.metadata); // TableMetadata object\n * ```\n */ async updateTable(id, request) {\n return this.tableOps.updateTable(id, request);\n }\n /**\n * Drops a table from the catalog.\n *\n * @param id - Table identifier to drop\n *\n * @example\n * ```typescript\n * await catalog.dropTable({ namespace: ['analytics'], name: 'events' });\n * ```\n */ async dropTable(id, options) {\n await this.tableOps.dropTable(id, options);\n }\n /**\n * Loads metadata for a table.\n *\n * @param id - Table identifier to load\n * @returns Table metadata including schema, partition spec, location, etc.\n *\n * @example\n * ```typescript\n * const metadata = await catalog.loadTable({ namespace: ['analytics'], name: 'events' });\n * console.log(metadata.schema);\n * console.log(metadata.location);\n * ```\n */ async loadTable(id) {\n return this.tableOps.loadTable(id);\n }\n /**\n * Checks if a namespace exists in the catalog.\n *\n * @param id - Namespace identifier to check\n * @returns True if the namespace exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = await catalog.namespaceExists({ namespace: ['analytics'] });\n * console.log(exists); // true or false\n * ```\n */ async namespaceExists(id) {\n return this.namespaceOps.namespaceExists(id);\n }\n /**\n * Checks if a table exists in the catalog.\n *\n * @param id - Table identifier to check\n * @returns True if the table exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = await catalog.tableExists({ namespace: ['analytics'], name: 'events' });\n * console.log(exists); // true or false\n * ```\n */ async tableExists(id) {\n return this.tableOps.tableExists(id);\n }\n /**\n * Creates a namespace if it does not exist.\n *\n * If the namespace already exists, returns void. If created, returns the response.\n *\n * @param id - Namespace identifier to create\n * @param metadata - Optional metadata properties for the namespace\n * @returns Response containing the created namespace and its properties, or void if it already exists\n *\n * @example\n * ```typescript\n * const response = await catalog.createNamespaceIfNotExists(\n * { namespace: ['analytics'] },\n * { properties: { owner: 'data-team' } }\n * );\n * if (response) {\n * console.log('Created:', response.namespace);\n * } else {\n * console.log('Already exists');\n * }\n * ```\n */ async createNamespaceIfNotExists(id, metadata) {\n return this.namespaceOps.createNamespaceIfNotExists(id, metadata);\n }\n /**\n * Creates a table if it does not exist.\n *\n * If the table already exists, returns its metadata instead.\n *\n * @param namespace - Namespace to create the table in\n * @param request - Table creation request including name, schema, partition spec, etc.\n * @returns Table metadata for the created or existing table\n *\n * @example\n * ```typescript\n * const metadata = await catalog.createTableIfNotExists(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n * ],\n * 'schema-id': 0\n * }\n * }\n * );\n * ```\n */ async createTableIfNotExists(namespace, request) {\n return this.tableOps.createTableIfNotExists(namespace, request);\n }\n};\n// src/catalog/types.ts\nvar DECIMAL_REGEX = /^decimal\\s*\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*\\)$/;\nvar FIXED_REGEX = /^fixed\\s*\\[\\s*(\\d+)\\s*\\]$/;\nfunction parseDecimalType(type) {\n const match = type.match(DECIMAL_REGEX);\n if (!match) return null;\n return {\n precision: parseInt(match[1], 10),\n scale: parseInt(match[2], 10)\n };\n}\nfunction parseFixedType(type) {\n const match = type.match(FIXED_REGEX);\n if (!match) return null;\n return {\n length: parseInt(match[1], 10)\n };\n}\nfunction isDecimalType(type) {\n return DECIMAL_REGEX.test(type);\n}\nfunction isFixedType(type) {\n return FIXED_REGEX.test(type);\n}\nfunction typesEqual(a, b) {\n const decimalA = parseDecimalType(a);\n const decimalB = parseDecimalType(b);\n if (decimalA && decimalB) {\n return decimalA.precision === decimalB.precision && decimalA.scale === decimalB.scale;\n }\n const fixedA = parseFixedType(a);\n const fixedB = parseFixedType(b);\n if (fixedA && fixedB) {\n return fixedA.length === fixedB.length;\n }\n return a === b;\n}\nfunction getCurrentSchema(metadata) {\n return metadata.schemas.find((s)=>s[\"schema-id\"] === metadata[\"current-schema-id\"]);\n}\n //# sourceMappingURL=index.mjs.map\n //# sourceMappingURL=index.mjs.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/iceberg-js/dist/index.mjs","mappings":";;;;;;;;;;;AAAA,6BAA6B;AAC7B,IAAIA,eAAe,cAAcC;IAC/BC,YAAYC,OAAO,EAAEC,IAAI,CAAE;QACzB,KAAK,CAACD;QACN,IAAI,CAACE,IAAI,GAAG;QACZ,IAAI,CAACC,MAAM,GAAGF,KAAKE,MAAM;QACzB,IAAI,CAACC,WAAW,GAAGH,KAAKG,WAAW;QACnC,IAAI,CAACC,WAAW,GAAGJ,KAAKI,WAAW;QACnC,IAAI,CAACC,OAAO,GAAGL,KAAKK,OAAO;QAC3B,IAAI,CAACC,oBAAoB,GAAGN,KAAKG,WAAW,KAAK,iCAAiC;YAAC;YAAK;YAAK;SAAI,CAACI,QAAQ,CAACP,KAAKE,MAAM,KAAKF,KAAKG,WAAW,EAAEI,SAAS,mBAAmB;IAC3K;IACA;;GAEC,GACDC,aAAa;QACX,OAAO,IAAI,CAACN,MAAM,KAAK;IACzB;IACA;;GAEC,GACDO,aAAa;QACX,OAAO,IAAI,CAACP,MAAM,KAAK;IACzB;IACA;;GAEC,GACDQ,0BAA0B;QACxB,OAAO,IAAI,CAACR,MAAM,KAAK;IACzB;AACF;AAEA,mBAAmB;AACnB,SAASS,SAASC,OAAO,EAAEC,IAAI,EAAEC,KAAK;IACpC,MAAMC,MAAM,IAAIC,IAAIH,MAAMD;IAC1B,IAAIE,OAAO;QACT,KAAK,MAAM,CAACG,KAAKC,MAAM,IAAIC,OAAOC,OAAO,CAACN,OAAQ;YAChD,IAAII,UAAU,KAAK,GAAG;gBACpBH,IAAIM,YAAY,CAACC,GAAG,CAACL,KAAKC;YAC5B;QACF;IACF;IACA,OAAOH,IAAIQ,QAAQ;AACrB;AAEA,gCAAgC;AAChC,eAAeC,iBAAiBC,IAAI;IAClC,IAAI,CAACA,QAAQA,KAAKC,IAAI,KAAK,QAAQ;QACjC,OAAO,CAAC;IACV;IACA,IAAID,KAAKC,IAAI,KAAK,UAAU;QAC1B,OAAO;YAAEC,eAAe,CAAC,OAAO,EAAEF,KAAKG,KAAK,CAAC,CAAC;QAAC;IACjD;IACA,IAAIH,KAAKC,IAAI,KAAK,UAAU;QAC1B,OAAO;YAAE,CAACD,KAAKxB,IAAI,CAAC,EAAEwB,KAAKP,KAAK;QAAC;IACnC;IACA,IAAIO,KAAKC,IAAI,KAAK,UAAU;QAC1B,OAAO,MAAMD,KAAKI,UAAU;IAC9B;IACA,OAAO,CAAC;AACV;AACA,SAASC,kBAAkBC,OAAO;IAChC,MAAMC,UAAUD,QAAQE,SAAS,IAAIC,WAAWC,KAAK;IACrD,OAAO;QACL,MAAMC,SAAQ,EACZC,MAAM,EACNxB,IAAI,EACJC,KAAK,EACLwB,IAAI,EACJC,OAAO,EACR;YACC,MAAMxB,MAAMJ,SAASoB,QAAQnB,OAAO,EAAEC,MAAMC;YAC5C,MAAM0B,cAAc,MAAMhB,iBAAiBO,QAAQN,IAAI;YACvD,MAAMgB,MAAM,MAAMT,QAAQjB,KAAK;gBAC7BsB;gBACAE,SAAS;oBACP,GAAGD,OAAO;wBAAE,gBAAgB;oBAAmB,IAAI,CAAC,CAAC;oBACrD,GAAGE,WAAW;oBACd,GAAGD,OAAO;gBACZ;gBACAD,MAAMA,OAAOI,KAAKC,SAAS,CAACL,QAAQ,KAAK;YAC3C;YACA,MAAMM,OAAO,MAAMH,IAAIG,IAAI;YAC3B,MAAMC,SAAS,CAACJ,IAAIF,OAAO,CAACO,GAAG,CAAC,mBAAmB,EAAC,EAAGvC,QAAQ,CAAC;YAChE,MAAMwC,OAAOF,UAAUD,OAAOF,KAAKM,KAAK,CAACJ,QAAQA;YACjD,IAAI,CAACH,IAAIQ,EAAE,EAAE;gBACX,MAAMC,UAAUL,SAASE,OAAO,KAAK;gBACrC,MAAMI,cAAcD,SAASE;gBAC7B,MAAM,IAAIxD,aACRuD,aAAapD,WAAW,CAAC,2BAA2B,EAAE0C,IAAIvC,MAAM,CAAC,CAAC,EAClE;oBACEA,QAAQuC,IAAIvC,MAAM;oBAClBC,aAAagD,aAAazB;oBAC1BtB,aAAa+C,aAAaE;oBAC1BhD,SAAS6C;gBACX;YAEJ;YACA,OAAO;gBAAEhD,QAAQuC,IAAIvC,MAAM;gBAAEqC,SAASE,IAAIF,OAAO;gBAAEQ;YAAK;QAC1D;IACF;AACF;AAEA,4BAA4B;AAC5B,SAASO,gBAAgBC,SAAS;IAChC,OAAOA,UAAUC,IAAI,CAAC;AACxB;AACA,IAAIC,sBAAsB;IACxB3D,YAAY4D,MAAM,EAAEC,SAAS,EAAE,CAAE;QAC/B,IAAI,CAACD,MAAM,GAAGA;QACd,IAAI,CAACC,MAAM,GAAGA;IAChB;IACA,MAAMC,eAAeC,MAAM,EAAE;QAC3B,MAAM/C,QAAQ+C,SAAS;YAAEA,QAAQP,gBAAgBO,OAAON,SAAS;QAAE,IAAI,KAAK;QAC5E,MAAMO,WAAW,MAAM,IAAI,CAACJ,MAAM,CAACtB,OAAO,CAAC;YACzCC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,WAAW,CAAC;YACjC7C;QACF;QACA,OAAOgD,SAASf,IAAI,CAACgB,UAAU,CAACC,GAAG,CAAC,CAACC,KAAQ;gBAAEV,WAAWU;YAAG;IAC/D;IACA,MAAMC,gBAAgBC,EAAE,EAAEC,QAAQ,EAAE;QAClC,MAAMhC,UAAU;YACdmB,WAAWY,GAAGZ,SAAS;YACvBc,YAAYD,UAAUC;QACxB;QACA,MAAMP,WAAW,MAAM,IAAI,CAACJ,MAAM,CAACtB,OAAO,CAAC;YACzCC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,WAAW,CAAC;YACjCrB,MAAMF;QACR;QACA,OAAO0B,SAASf,IAAI;IACtB;IACA,MAAMuB,cAAcH,EAAE,EAAE;QACtB,MAAM,IAAI,CAACT,MAAM,CAACtB,OAAO,CAAC;YACxBC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEL,gBAAgBa,GAAGZ,SAAS,EAAE,CAAC;QACpE;IACF;IACA,MAAMgB,sBAAsBJ,EAAE,EAAE;QAC9B,MAAML,WAAW,MAAM,IAAI,CAACJ,MAAM,CAACtB,OAAO,CAAC;YACzCC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEL,gBAAgBa,GAAGZ,SAAS,EAAE,CAAC;QACpE;QACA,OAAO;YACLc,YAAYP,SAASf,IAAI,CAACsB,UAAU;QACtC;IACF;IACA,MAAMG,gBAAgBL,EAAE,EAAE;QACxB,IAAI;YACF,MAAM,IAAI,CAACT,MAAM,CAACtB,OAAO,CAAC;gBACxBC,QAAQ;gBACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEL,gBAAgBa,GAAGZ,SAAS,EAAE,CAAC;YACpE;YACA,OAAO;QACT,EAAE,OAAOH,OAAO;YACd,IAAIA,iBAAiBxD,gBAAgBwD,MAAMlD,MAAM,KAAK,KAAK;gBACzD,OAAO;YACT;YACA,MAAMkD;QACR;IACF;IACA,MAAMqB,2BAA2BN,EAAE,EAAEC,QAAQ,EAAE;QAC7C,IAAI;YACF,OAAO,MAAM,IAAI,CAACF,eAAe,CAACC,IAAIC;QACxC,EAAE,OAAOhB,OAAO;YACd,IAAIA,iBAAiBxD,gBAAgBwD,MAAMlD,MAAM,KAAK,KAAK;gBACzD;YACF;YACA,MAAMkD;QACR;IACF;AACF;AAEA,wBAAwB;AACxB,SAASsB,iBAAiBnB,SAAS;IACjC,OAAOA,UAAUC,IAAI,CAAC;AACxB;AACA,IAAImB,kBAAkB;IACpB7E,YAAY4D,MAAM,EAAEC,SAAS,EAAE,EAAEiB,gBAAgB,CAAE;QACjD,IAAI,CAAClB,MAAM,GAAGA;QACd,IAAI,CAACC,MAAM,GAAGA;QACd,IAAI,CAACiB,gBAAgB,GAAGA;IAC1B;IACA,MAAMC,WAAWtB,SAAS,EAAE;QAC1B,MAAMO,WAAW,MAAM,IAAI,CAACJ,MAAM,CAACtB,OAAO,CAAC;YACzCC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEe,iBAAiBnB,UAAUA,SAAS,EAAE,OAAO,CAAC;QACnF;QACA,OAAOO,SAASf,IAAI,CAAC+B,WAAW;IAClC;IACA,MAAMC,YAAYxB,SAAS,EAAEnB,OAAO,EAAE;QACpC,MAAMG,UAAU,CAAC;QACjB,IAAI,IAAI,CAACqC,gBAAgB,EAAE;YACzBrC,OAAO,CAAC,8BAA8B,GAAG,IAAI,CAACqC,gBAAgB;QAChE;QACA,MAAMd,WAAW,MAAM,IAAI,CAACJ,MAAM,CAACtB,OAAO,CAAC;YACzCC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEe,iBAAiBnB,UAAUA,SAAS,EAAE,OAAO,CAAC;YACjFjB,MAAMF;YACNG;QACF;QACA,OAAOuB,SAASf,IAAI,CAACqB,QAAQ;IAC/B;IACA,MAAMY,YAAYb,EAAE,EAAE/B,OAAO,EAAE;QAC7B,MAAM0B,WAAW,MAAM,IAAI,CAACJ,MAAM,CAACtB,OAAO,CAAC;YACzCC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEe,iBAAiBP,GAAGZ,SAAS,EAAE,QAAQ,EAAEY,GAAGlE,IAAI,CAAC,CAAC;YACrFqC,MAAMF;QACR;QACA,OAAO;YACL,qBAAqB0B,SAASf,IAAI,CAAC,oBAAoB;YACvDqB,UAAUN,SAASf,IAAI,CAACqB,QAAQ;QAClC;IACF;IACA,MAAMa,UAAUd,EAAE,EAAEpC,OAAO,EAAE;QAC3B,MAAM,IAAI,CAAC2B,MAAM,CAACtB,OAAO,CAAC;YACxBC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEe,iBAAiBP,GAAGZ,SAAS,EAAE,QAAQ,EAAEY,GAAGlE,IAAI,CAAC,CAAC;YACrFa,OAAO;gBAAEoE,gBAAgBC,OAAOpD,SAASqD,SAAS;YAAO;QAC3D;IACF;IACA,MAAMC,UAAUlB,EAAE,EAAE;QAClB,MAAM5B,UAAU,CAAC;QACjB,IAAI,IAAI,CAACqC,gBAAgB,EAAE;YACzBrC,OAAO,CAAC,8BAA8B,GAAG,IAAI,CAACqC,gBAAgB;QAChE;QACA,MAAMd,WAAW,MAAM,IAAI,CAACJ,MAAM,CAACtB,OAAO,CAAC;YACzCC,QAAQ;YACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEe,iBAAiBP,GAAGZ,SAAS,EAAE,QAAQ,EAAEY,GAAGlE,IAAI,CAAC,CAAC;YACrFsC;QACF;QACA,OAAOuB,SAASf,IAAI,CAACqB,QAAQ;IAC/B;IACA,MAAMkB,YAAYnB,EAAE,EAAE;QACpB,MAAM5B,UAAU,CAAC;QACjB,IAAI,IAAI,CAACqC,gBAAgB,EAAE;YACzBrC,OAAO,CAAC,8BAA8B,GAAG,IAAI,CAACqC,gBAAgB;QAChE;QACA,IAAI;YACF,MAAM,IAAI,CAAClB,MAAM,CAACtB,OAAO,CAAC;gBACxBC,QAAQ;gBACRxB,MAAM,CAAC,EAAE,IAAI,CAAC8C,MAAM,CAAC,YAAY,EAAEe,iBAAiBP,GAAGZ,SAAS,EAAE,QAAQ,EAAEY,GAAGlE,IAAI,CAAC,CAAC;gBACrFsC;YACF;YACA,OAAO;QACT,EAAE,OAAOa,OAAO;YACd,IAAIA,iBAAiBxD,gBAAgBwD,MAAMlD,MAAM,KAAK,KAAK;gBACzD,OAAO;YACT;YACA,MAAMkD;QACR;IACF;IACA,MAAMmC,uBAAuBhC,SAAS,EAAEnB,OAAO,EAAE;QAC/C,IAAI;YACF,OAAO,MAAM,IAAI,CAAC2C,WAAW,CAACxB,WAAWnB;QAC3C,EAAE,OAAOgB,OAAO;YACd,IAAIA,iBAAiBxD,gBAAgBwD,MAAMlD,MAAM,KAAK,KAAK;gBACzD,OAAO,MAAM,IAAI,CAACmF,SAAS,CAAC;oBAAE9B,WAAWA,UAAUA,SAAS;oBAAEtD,MAAMmC,QAAQnC,IAAI;gBAAC;YACnF;YACA,MAAMmD;QACR;IACF;AACF;AAEA,oCAAoC;AACpC,IAAIoC,qBAAqB;IACvB;;;;GAIC,GACD1F,YAAYiC,OAAO,CAAE;QACnB,IAAI4B,SAAS;QACb,IAAI5B,QAAQ0D,WAAW,EAAE;YACvB9B,UAAU,CAAC,CAAC,EAAE5B,QAAQ0D,WAAW,CAAC,CAAC;QACrC;QACA,MAAM7E,UAAUmB,QAAQnB,OAAO,CAAC8E,QAAQ,CAAC,OAAO3D,QAAQnB,OAAO,GAAG,CAAC,EAAEmB,QAAQnB,OAAO,CAAC,CAAC,CAAC;QACvF,IAAI,CAAC8C,MAAM,GAAG5B,kBAAkB;YAC9BlB;YACAa,MAAMM,QAAQN,IAAI;YAClBQ,WAAWF,QAAQI,KAAK;QAC1B;QACA,IAAI,CAACyC,gBAAgB,GAAG7C,QAAQ6C,gBAAgB,EAAEpB,KAAK;QACvD,IAAI,CAACmC,YAAY,GAAG,IAAIlC,oBAAoB,IAAI,CAACC,MAAM,EAAEC;QACzD,IAAI,CAACiC,QAAQ,GAAG,IAAIjB,gBAAgB,IAAI,CAACjB,MAAM,EAAEC,QAAQ,IAAI,CAACiB,gBAAgB;IAChF;IACA;;;;;;;;;;;;;;GAcC,GACD,MAAMhB,eAAeC,MAAM,EAAE;QAC3B,OAAO,IAAI,CAAC8B,YAAY,CAAC/B,cAAc,CAACC;IAC1C;IACA;;;;;;;;;;;;;;;;GAgBC,GACD,MAAMK,gBAAgBC,EAAE,EAAEC,QAAQ,EAAE;QAClC,OAAO,IAAI,CAACuB,YAAY,CAACzB,eAAe,CAACC,IAAIC;IAC/C;IACA;;;;;;;;;;;GAWC,GACD,MAAME,cAAcH,EAAE,EAAE;QACtB,MAAM,IAAI,CAACwB,YAAY,CAACrB,aAAa,CAACH;IACxC;IACA;;;;;;;;;;;GAWC,GACD,MAAMI,sBAAsBJ,EAAE,EAAE;QAC9B,OAAO,IAAI,CAACwB,YAAY,CAACpB,qBAAqB,CAACJ;IACjD;IACA;;;;;;;;;;;GAWC,GACD,MAAMU,WAAWtB,SAAS,EAAE;QAC1B,OAAO,IAAI,CAACqC,QAAQ,CAACf,UAAU,CAACtB;IAClC;IACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BC,GACD,MAAMwB,YAAYxB,SAAS,EAAEnB,OAAO,EAAE;QACpC,OAAO,IAAI,CAACwD,QAAQ,CAACb,WAAW,CAACxB,WAAWnB;IAC9C;IACA;;;;;;;;;;;;;;;;;;;;GAoBC,GACD,MAAM4C,YAAYb,EAAE,EAAE/B,OAAO,EAAE;QAC7B,OAAO,IAAI,CAACwD,QAAQ,CAACZ,WAAW,CAACb,IAAI/B;IACvC;IACA;;;;;;;;;GASC,GACD,MAAM6C,UAAUd,EAAE,EAAEpC,OAAO,EAAE;QAC3B,MAAM,IAAI,CAAC6D,QAAQ,CAACX,SAAS,CAACd,IAAIpC;IACpC;IACA;;;;;;;;;;;;GAYC,GACD,MAAMsD,UAAUlB,EAAE,EAAE;QAClB,OAAO,IAAI,CAACyB,QAAQ,CAACP,SAAS,CAAClB;IACjC;IACA;;;;;;;;;;;GAWC,GACD,MAAMK,gBAAgBL,EAAE,EAAE;QACxB,OAAO,IAAI,CAACwB,YAAY,CAACnB,eAAe,CAACL;IAC3C;IACA;;;;;;;;;;;GAWC,GACD,MAAMmB,YAAYnB,EAAE,EAAE;QACpB,OAAO,IAAI,CAACyB,QAAQ,CAACN,WAAW,CAACnB;IACnC;IACA;;;;;;;;;;;;;;;;;;;;;GAqBC,GACD,MAAMM,2BAA2BN,EAAE,EAAEC,QAAQ,EAAE;QAC7C,OAAO,IAAI,CAACuB,YAAY,CAAClB,0BAA0B,CAACN,IAAIC;IAC1D;IACA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BC,GACD,MAAMmB,uBAAuBhC,SAAS,EAAEnB,OAAO,EAAE;QAC/C,OAAO,IAAI,CAACwD,QAAQ,CAACL,sBAAsB,CAAChC,WAAWnB;IACzD;AACF;AAEA,uBAAuB;AACvB,IAAIyD,gBAAgB;AACpB,IAAIC,cAAc;AAClB,SAASC,iBAAiBrE,IAAI;IAC5B,MAAMsE,QAAQtE,KAAKsE,KAAK,CAACH;IACzB,IAAI,CAACG,OAAO,OAAO;IACnB,OAAO;QACLC,WAAWC,SAASF,KAAK,CAAC,EAAE,EAAE;QAC9BG,OAAOD,SAASF,KAAK,CAAC,EAAE,EAAE;IAC5B;AACF;AACA,SAASI,eAAe1E,IAAI;IAC1B,MAAMsE,QAAQtE,KAAKsE,KAAK,CAACF;IACzB,IAAI,CAACE,OAAO,OAAO;IACnB,OAAO;QACLK,QAAQH,SAASF,KAAK,CAAC,EAAE,EAAE;IAC7B;AACF;AACA,SAASM,cAAc5E,IAAI;IACzB,OAAOmE,cAAcU,IAAI,CAAC7E;AAC5B;AACA,SAAS8E,YAAY9E,IAAI;IACvB,OAAOoE,YAAYS,IAAI,CAAC7E;AAC1B;AACA,SAAS+E,WAAWC,CAAC,EAAEC,CAAC;IACtB,MAAMC,WAAWb,iBAAiBW;IAClC,MAAMG,WAAWd,iBAAiBY;IAClC,IAAIC,YAAYC,UAAU;QACxB,OAAOD,SAASX,SAAS,KAAKY,SAASZ,SAAS,IAAIW,SAAST,KAAK,KAAKU,SAASV,KAAK;IACvF;IACA,MAAMW,SAASV,eAAeM;IAC9B,MAAMK,SAASX,eAAeO;IAC9B,IAAIG,UAAUC,QAAQ;QACpB,OAAOD,OAAOT,MAAM,KAAKU,OAAOV,MAAM;IACxC;IACA,OAAOK,MAAMC;AACf;AACA,SAASK,iBAAiB5C,QAAQ;IAChC,OAAOA,SAAS6C,OAAO,CAACC,IAAI,CAAC,CAACC,IAAMA,CAAC,CAAC,YAAY,KAAK/C,QAAQ,CAAC,oBAAoB;AACtF;AAEwI,CACxI,kCAAkC;CAClC,kCAAkC","sources":["webpack://whisky-vault/./node_modules/iceberg-js/dist/index.mjs?fcae"],"sourcesContent":["// src/errors/IcebergError.ts\nvar IcebergError = class extends Error {\n  constructor(message, opts) {\n    super(message);\n    this.name = \"IcebergError\";\n    this.status = opts.status;\n    this.icebergType = opts.icebergType;\n    this.icebergCode = opts.icebergCode;\n    this.details = opts.details;\n    this.isCommitStateUnknown = opts.icebergType === \"CommitStateUnknownException\" || [500, 502, 504].includes(opts.status) && opts.icebergType?.includes(\"CommitState\") === true;\n  }\n  /**\n   * Returns true if the error is a 404 Not Found error.\n   */\n  isNotFound() {\n    return this.status === 404;\n  }\n  /**\n   * Returns true if the error is a 409 Conflict error.\n   */\n  isConflict() {\n    return this.status === 409;\n  }\n  /**\n   * Returns true if the error is a 419 Authentication Timeout error.\n   */\n  isAuthenticationTimeout() {\n    return this.status === 419;\n  }\n};\n\n// src/utils/url.ts\nfunction buildUrl(baseUrl, path, query) {\n  const url = new URL(path, baseUrl);\n  if (query) {\n    for (const [key, value] of Object.entries(query)) {\n      if (value !== void 0) {\n        url.searchParams.set(key, value);\n      }\n    }\n  }\n  return url.toString();\n}\n\n// src/http/createFetchClient.ts\nasync function buildAuthHeaders(auth) {\n  if (!auth || auth.type === \"none\") {\n    return {};\n  }\n  if (auth.type === \"bearer\") {\n    return { Authorization: `Bearer ${auth.token}` };\n  }\n  if (auth.type === \"header\") {\n    return { [auth.name]: auth.value };\n  }\n  if (auth.type === \"custom\") {\n    return await auth.getHeaders();\n  }\n  return {};\n}\nfunction createFetchClient(options) {\n  const fetchFn = options.fetchImpl ?? globalThis.fetch;\n  return {\n    async request({\n      method,\n      path,\n      query,\n      body,\n      headers\n    }) {\n      const url = buildUrl(options.baseUrl, path, query);\n      const authHeaders = await buildAuthHeaders(options.auth);\n      const res = await fetchFn(url, {\n        method,\n        headers: {\n          ...body ? { \"Content-Type\": \"application/json\" } : {},\n          ...authHeaders,\n          ...headers\n        },\n        body: body ? JSON.stringify(body) : void 0\n      });\n      const text = await res.text();\n      const isJson = (res.headers.get(\"content-type\") || \"\").includes(\"application/json\");\n      const data = isJson && text ? JSON.parse(text) : text;\n      if (!res.ok) {\n        const errBody = isJson ? data : void 0;\n        const errorDetail = errBody?.error;\n        throw new IcebergError(\n          errorDetail?.message ?? `Request failed with status ${res.status}`,\n          {\n            status: res.status,\n            icebergType: errorDetail?.type,\n            icebergCode: errorDetail?.code,\n            details: errBody\n          }\n        );\n      }\n      return { status: res.status, headers: res.headers, data };\n    }\n  };\n}\n\n// src/catalog/namespaces.ts\nfunction namespaceToPath(namespace) {\n  return namespace.join(\"\u001f\");\n}\nvar NamespaceOperations = class {\n  constructor(client, prefix = \"\") {\n    this.client = client;\n    this.prefix = prefix;\n  }\n  async listNamespaces(parent) {\n    const query = parent ? { parent: namespaceToPath(parent.namespace) } : void 0;\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces`,\n      query\n    });\n    return response.data.namespaces.map((ns) => ({ namespace: ns }));\n  }\n  async createNamespace(id, metadata) {\n    const request = {\n      namespace: id.namespace,\n      properties: metadata?.properties\n    };\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces`,\n      body: request\n    });\n    return response.data;\n  }\n  async dropNamespace(id) {\n    await this.client.request({\n      method: \"DELETE\",\n      path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n    });\n  }\n  async loadNamespaceMetadata(id) {\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n    });\n    return {\n      properties: response.data.properties\n    };\n  }\n  async namespaceExists(id) {\n    try {\n      await this.client.request({\n        method: \"HEAD\",\n        path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n      });\n      return true;\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 404) {\n        return false;\n      }\n      throw error;\n    }\n  }\n  async createNamespaceIfNotExists(id, metadata) {\n    try {\n      return await this.createNamespace(id, metadata);\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 409) {\n        return;\n      }\n      throw error;\n    }\n  }\n};\n\n// src/catalog/tables.ts\nfunction namespaceToPath2(namespace) {\n  return namespace.join(\"\u001f\");\n}\nvar TableOperations = class {\n  constructor(client, prefix = \"\", accessDelegation) {\n    this.client = client;\n    this.prefix = prefix;\n    this.accessDelegation = accessDelegation;\n  }\n  async listTables(namespace) {\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`\n    });\n    return response.data.identifiers;\n  }\n  async createTable(namespace, request) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`,\n      body: request,\n      headers\n    });\n    return response.data.metadata;\n  }\n  async updateTable(id, request) {\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      body: request\n    });\n    return {\n      \"metadata-location\": response.data[\"metadata-location\"],\n      metadata: response.data.metadata\n    };\n  }\n  async dropTable(id, options) {\n    await this.client.request({\n      method: \"DELETE\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      query: { purgeRequested: String(options?.purge ?? false) }\n    });\n  }\n  async loadTable(id) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      headers\n    });\n    return response.data.metadata;\n  }\n  async tableExists(id) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    try {\n      await this.client.request({\n        method: \"HEAD\",\n        path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n        headers\n      });\n      return true;\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 404) {\n        return false;\n      }\n      throw error;\n    }\n  }\n  async createTableIfNotExists(namespace, request) {\n    try {\n      return await this.createTable(namespace, request);\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 409) {\n        return await this.loadTable({ namespace: namespace.namespace, name: request.name });\n      }\n      throw error;\n    }\n  }\n};\n\n// src/catalog/IcebergRestCatalog.ts\nvar IcebergRestCatalog = class {\n  /**\n   * Creates a new Iceberg REST Catalog client.\n   *\n   * @param options - Configuration options for the catalog client\n   */\n  constructor(options) {\n    let prefix = \"v1\";\n    if (options.catalogName) {\n      prefix += `/${options.catalogName}`;\n    }\n    const baseUrl = options.baseUrl.endsWith(\"/\") ? options.baseUrl : `${options.baseUrl}/`;\n    this.client = createFetchClient({\n      baseUrl,\n      auth: options.auth,\n      fetchImpl: options.fetch\n    });\n    this.accessDelegation = options.accessDelegation?.join(\",\");\n    this.namespaceOps = new NamespaceOperations(this.client, prefix);\n    this.tableOps = new TableOperations(this.client, prefix, this.accessDelegation);\n  }\n  /**\n   * Lists all namespaces in the catalog.\n   *\n   * @param parent - Optional parent namespace to list children under\n   * @returns Array of namespace identifiers\n   *\n   * @example\n   * ```typescript\n   * // List all top-level namespaces\n   * const namespaces = await catalog.listNamespaces();\n   *\n   * // List namespaces under a parent\n   * const children = await catalog.listNamespaces({ namespace: ['analytics'] });\n   * ```\n   */\n  async listNamespaces(parent) {\n    return this.namespaceOps.listNamespaces(parent);\n  }\n  /**\n   * Creates a new namespace in the catalog.\n   *\n   * @param id - Namespace identifier to create\n   * @param metadata - Optional metadata properties for the namespace\n   * @returns Response containing the created namespace and its properties\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.createNamespace(\n   *   { namespace: ['analytics'] },\n   *   { properties: { owner: 'data-team' } }\n   * );\n   * console.log(response.namespace); // ['analytics']\n   * console.log(response.properties); // { owner: 'data-team', ... }\n   * ```\n   */\n  async createNamespace(id, metadata) {\n    return this.namespaceOps.createNamespace(id, metadata);\n  }\n  /**\n   * Drops a namespace from the catalog.\n   *\n   * The namespace must be empty (contain no tables) before it can be dropped.\n   *\n   * @param id - Namespace identifier to drop\n   *\n   * @example\n   * ```typescript\n   * await catalog.dropNamespace({ namespace: ['analytics'] });\n   * ```\n   */\n  async dropNamespace(id) {\n    await this.namespaceOps.dropNamespace(id);\n  }\n  /**\n   * Loads metadata for a namespace.\n   *\n   * @param id - Namespace identifier to load\n   * @returns Namespace metadata including properties\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.loadNamespaceMetadata({ namespace: ['analytics'] });\n   * console.log(metadata.properties);\n   * ```\n   */\n  async loadNamespaceMetadata(id) {\n    return this.namespaceOps.loadNamespaceMetadata(id);\n  }\n  /**\n   * Lists all tables in a namespace.\n   *\n   * @param namespace - Namespace identifier to list tables from\n   * @returns Array of table identifiers\n   *\n   * @example\n   * ```typescript\n   * const tables = await catalog.listTables({ namespace: ['analytics'] });\n   * console.log(tables); // [{ namespace: ['analytics'], name: 'events' }, ...]\n   * ```\n   */\n  async listTables(namespace) {\n    return this.tableOps.listTables(namespace);\n  }\n  /**\n   * Creates a new table in the catalog.\n   *\n   * @param namespace - Namespace to create the table in\n   * @param request - Table creation request including name, schema, partition spec, etc.\n   * @returns Table metadata for the created table\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.createTable(\n   *   { namespace: ['analytics'] },\n   *   {\n   *     name: 'events',\n   *     schema: {\n   *       type: 'struct',\n   *       fields: [\n   *         { id: 1, name: 'id', type: 'long', required: true },\n   *         { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n   *       ],\n   *       'schema-id': 0\n   *     },\n   *     'partition-spec': {\n   *       'spec-id': 0,\n   *       fields: [\n   *         { source_id: 2, field_id: 1000, name: 'ts_day', transform: 'day' }\n   *       ]\n   *     }\n   *   }\n   * );\n   * ```\n   */\n  async createTable(namespace, request) {\n    return this.tableOps.createTable(namespace, request);\n  }\n  /**\n   * Updates an existing table's metadata.\n   *\n   * Can update the schema, partition spec, or properties of a table.\n   *\n   * @param id - Table identifier to update\n   * @param request - Update request with fields to modify\n   * @returns Response containing the metadata location and updated table metadata\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.updateTable(\n   *   { namespace: ['analytics'], name: 'events' },\n   *   {\n   *     properties: { 'read.split.target-size': '134217728' }\n   *   }\n   * );\n   * console.log(response['metadata-location']); // s3://...\n   * console.log(response.metadata); // TableMetadata object\n   * ```\n   */\n  async updateTable(id, request) {\n    return this.tableOps.updateTable(id, request);\n  }\n  /**\n   * Drops a table from the catalog.\n   *\n   * @param id - Table identifier to drop\n   *\n   * @example\n   * ```typescript\n   * await catalog.dropTable({ namespace: ['analytics'], name: 'events' });\n   * ```\n   */\n  async dropTable(id, options) {\n    await this.tableOps.dropTable(id, options);\n  }\n  /**\n   * Loads metadata for a table.\n   *\n   * @param id - Table identifier to load\n   * @returns Table metadata including schema, partition spec, location, etc.\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.loadTable({ namespace: ['analytics'], name: 'events' });\n   * console.log(metadata.schema);\n   * console.log(metadata.location);\n   * ```\n   */\n  async loadTable(id) {\n    return this.tableOps.loadTable(id);\n  }\n  /**\n   * Checks if a namespace exists in the catalog.\n   *\n   * @param id - Namespace identifier to check\n   * @returns True if the namespace exists, false otherwise\n   *\n   * @example\n   * ```typescript\n   * const exists = await catalog.namespaceExists({ namespace: ['analytics'] });\n   * console.log(exists); // true or false\n   * ```\n   */\n  async namespaceExists(id) {\n    return this.namespaceOps.namespaceExists(id);\n  }\n  /**\n   * Checks if a table exists in the catalog.\n   *\n   * @param id - Table identifier to check\n   * @returns True if the table exists, false otherwise\n   *\n   * @example\n   * ```typescript\n   * const exists = await catalog.tableExists({ namespace: ['analytics'], name: 'events' });\n   * console.log(exists); // true or false\n   * ```\n   */\n  async tableExists(id) {\n    return this.tableOps.tableExists(id);\n  }\n  /**\n   * Creates a namespace if it does not exist.\n   *\n   * If the namespace already exists, returns void. If created, returns the response.\n   *\n   * @param id - Namespace identifier to create\n   * @param metadata - Optional metadata properties for the namespace\n   * @returns Response containing the created namespace and its properties, or void if it already exists\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.createNamespaceIfNotExists(\n   *   { namespace: ['analytics'] },\n   *   { properties: { owner: 'data-team' } }\n   * );\n   * if (response) {\n   *   console.log('Created:', response.namespace);\n   * } else {\n   *   console.log('Already exists');\n   * }\n   * ```\n   */\n  async createNamespaceIfNotExists(id, metadata) {\n    return this.namespaceOps.createNamespaceIfNotExists(id, metadata);\n  }\n  /**\n   * Creates a table if it does not exist.\n   *\n   * If the table already exists, returns its metadata instead.\n   *\n   * @param namespace - Namespace to create the table in\n   * @param request - Table creation request including name, schema, partition spec, etc.\n   * @returns Table metadata for the created or existing table\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.createTableIfNotExists(\n   *   { namespace: ['analytics'] },\n   *   {\n   *     name: 'events',\n   *     schema: {\n   *       type: 'struct',\n   *       fields: [\n   *         { id: 1, name: 'id', type: 'long', required: true },\n   *         { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n   *       ],\n   *       'schema-id': 0\n   *     }\n   *   }\n   * );\n   * ```\n   */\n  async createTableIfNotExists(namespace, request) {\n    return this.tableOps.createTableIfNotExists(namespace, request);\n  }\n};\n\n// src/catalog/types.ts\nvar DECIMAL_REGEX = /^decimal\\s*\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*\\)$/;\nvar FIXED_REGEX = /^fixed\\s*\\[\\s*(\\d+)\\s*\\]$/;\nfunction parseDecimalType(type) {\n  const match = type.match(DECIMAL_REGEX);\n  if (!match) return null;\n  return {\n    precision: parseInt(match[1], 10),\n    scale: parseInt(match[2], 10)\n  };\n}\nfunction parseFixedType(type) {\n  const match = type.match(FIXED_REGEX);\n  if (!match) return null;\n  return {\n    length: parseInt(match[1], 10)\n  };\n}\nfunction isDecimalType(type) {\n  return DECIMAL_REGEX.test(type);\n}\nfunction isFixedType(type) {\n  return FIXED_REGEX.test(type);\n}\nfunction typesEqual(a, b) {\n  const decimalA = parseDecimalType(a);\n  const decimalB = parseDecimalType(b);\n  if (decimalA && decimalB) {\n    return decimalA.precision === decimalB.precision && decimalA.scale === decimalB.scale;\n  }\n  const fixedA = parseFixedType(a);\n  const fixedB = parseFixedType(b);\n  if (fixedA && fixedB) {\n    return fixedA.length === fixedB.length;\n  }\n  return a === b;\n}\nfunction getCurrentSchema(metadata) {\n  return metadata.schemas.find((s) => s[\"schema-id\"] === metadata[\"current-schema-id\"]);\n}\n\nexport { IcebergError, IcebergRestCatalog, getCurrentSchema, isDecimalType, isFixedType, parseDecimalType, parseFixedType, typesEqual };\n//# sourceMappingURL=index.mjs.map\n//# sourceMappingURL=index.mjs.map"],"names":["IcebergError","Error","constructor","message","opts","name","status","icebergType","icebergCode","details","isCommitStateUnknown","includes","isNotFound","isConflict","isAuthenticationTimeout","buildUrl","baseUrl","path","query","url","URL","key","value","Object","entries","searchParams","set","toString","buildAuthHeaders","auth","type","Authorization","token","getHeaders","createFetchClient","options","fetchFn","fetchImpl","globalThis","fetch","request","method","body","headers","authHeaders","res","JSON","stringify","text","isJson","get","data","parse","ok","errBody","errorDetail","error","code","namespaceToPath","namespace","join","NamespaceOperations","client","prefix","listNamespaces","parent","response","namespaces","map","ns","createNamespace","id","metadata","properties","dropNamespace","loadNamespaceMetadata","namespaceExists","createNamespaceIfNotExists","namespaceToPath2","TableOperations","accessDelegation","listTables","identifiers","createTable","updateTable","dropTable","purgeRequested","String","purge","loadTable","tableExists","createTableIfNotExists","IcebergRestCatalog","catalogName","endsWith","namespaceOps","tableOps","DECIMAL_REGEX","FIXED_REGEX","parseDecimalType","match","precision","parseInt","scale","parseFixedType","length","isDecimalType","test","isFixedType","typesEqual","a","b","decimalA","decimalB","fixedA","fixedB","getCurrentSchema","schemas","find","s"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/iceberg-js/dist/index.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/iceberg-js/dist/index.mjs":
|
|
/*!************************************************!*\
|
|
!*** ./node_modules/iceberg-js/dist/index.mjs ***!
|
|
\************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ IcebergError: () => (/* binding */ IcebergError),\n/* harmony export */ IcebergRestCatalog: () => (/* binding */ IcebergRestCatalog),\n/* harmony export */ getCurrentSchema: () => (/* binding */ getCurrentSchema),\n/* harmony export */ isDecimalType: () => (/* binding */ isDecimalType),\n/* harmony export */ isFixedType: () => (/* binding */ isFixedType),\n/* harmony export */ parseDecimalType: () => (/* binding */ parseDecimalType),\n/* harmony export */ parseFixedType: () => (/* binding */ parseFixedType),\n/* harmony export */ typesEqual: () => (/* binding */ typesEqual)\n/* harmony export */ });\n// src/errors/IcebergError.ts\nvar IcebergError = class extends Error {\n constructor(message, opts){\n super(message);\n this.name = \"IcebergError\";\n this.status = opts.status;\n this.icebergType = opts.icebergType;\n this.icebergCode = opts.icebergCode;\n this.details = opts.details;\n this.isCommitStateUnknown = opts.icebergType === \"CommitStateUnknownException\" || [\n 500,\n 502,\n 504\n ].includes(opts.status) && opts.icebergType?.includes(\"CommitState\") === true;\n }\n /**\n * Returns true if the error is a 404 Not Found error.\n */ isNotFound() {\n return this.status === 404;\n }\n /**\n * Returns true if the error is a 409 Conflict error.\n */ isConflict() {\n return this.status === 409;\n }\n /**\n * Returns true if the error is a 419 Authentication Timeout error.\n */ isAuthenticationTimeout() {\n return this.status === 419;\n }\n};\n// src/utils/url.ts\nfunction buildUrl(baseUrl, path, query) {\n const url = new URL(path, baseUrl);\n if (query) {\n for (const [key, value] of Object.entries(query)){\n if (value !== void 0) {\n url.searchParams.set(key, value);\n }\n }\n }\n return url.toString();\n}\n// src/http/createFetchClient.ts\nasync function buildAuthHeaders(auth) {\n if (!auth || auth.type === \"none\") {\n return {};\n }\n if (auth.type === \"bearer\") {\n return {\n Authorization: `Bearer ${auth.token}`\n };\n }\n if (auth.type === \"header\") {\n return {\n [auth.name]: auth.value\n };\n }\n if (auth.type === \"custom\") {\n return await auth.getHeaders();\n }\n return {};\n}\nfunction createFetchClient(options) {\n const fetchFn = options.fetchImpl ?? globalThis.fetch;\n return {\n async request ({ method, path, query, body, headers }) {\n const url = buildUrl(options.baseUrl, path, query);\n const authHeaders = await buildAuthHeaders(options.auth);\n const res = await fetchFn(url, {\n method,\n headers: {\n ...body ? {\n \"Content-Type\": \"application/json\"\n } : {},\n ...authHeaders,\n ...headers\n },\n body: body ? JSON.stringify(body) : void 0\n });\n const text = await res.text();\n const isJson = (res.headers.get(\"content-type\") || \"\").includes(\"application/json\");\n const data = isJson && text ? JSON.parse(text) : text;\n if (!res.ok) {\n const errBody = isJson ? data : void 0;\n const errorDetail = errBody?.error;\n throw new IcebergError(errorDetail?.message ?? `Request failed with status ${res.status}`, {\n status: res.status,\n icebergType: errorDetail?.type,\n icebergCode: errorDetail?.code,\n details: errBody\n });\n }\n return {\n status: res.status,\n headers: res.headers,\n data\n };\n }\n };\n}\n// src/catalog/namespaces.ts\nfunction namespaceToPath(namespace) {\n return namespace.join(\"\\x1f\");\n}\nvar NamespaceOperations = class {\n constructor(client, prefix = \"\"){\n this.client = client;\n this.prefix = prefix;\n }\n async listNamespaces(parent) {\n const query = parent ? {\n parent: namespaceToPath(parent.namespace)\n } : void 0;\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces`,\n query\n });\n return response.data.namespaces.map((ns)=>({\n namespace: ns\n }));\n }\n async createNamespace(id, metadata) {\n const request = {\n namespace: id.namespace,\n properties: metadata?.properties\n };\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces`,\n body: request\n });\n return response.data;\n }\n async dropNamespace(id) {\n await this.client.request({\n method: \"DELETE\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n }\n async loadNamespaceMetadata(id) {\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n return {\n properties: response.data.properties\n };\n }\n async namespaceExists(id) {\n try {\n await this.client.request({\n method: \"HEAD\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n return true;\n } catch (error) {\n if (error instanceof IcebergError && error.status === 404) {\n return false;\n }\n throw error;\n }\n }\n async createNamespaceIfNotExists(id, metadata) {\n try {\n return await this.createNamespace(id, metadata);\n } catch (error) {\n if (error instanceof IcebergError && error.status === 409) {\n return;\n }\n throw error;\n }\n }\n};\n// src/catalog/tables.ts\nfunction namespaceToPath2(namespace) {\n return namespace.join(\"\\x1f\");\n}\nvar TableOperations = class {\n constructor(client, prefix = \"\", accessDelegation){\n this.client = client;\n this.prefix = prefix;\n this.accessDelegation = accessDelegation;\n }\n async listTables(namespace) {\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`\n });\n return response.data.identifiers;\n }\n async createTable(namespace, request) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`,\n body: request,\n headers\n });\n return response.data.metadata;\n }\n async updateTable(id, request) {\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n body: request\n });\n return {\n \"metadata-location\": response.data[\"metadata-location\"],\n metadata: response.data.metadata\n };\n }\n async dropTable(id, options) {\n await this.client.request({\n method: \"DELETE\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n query: {\n purgeRequested: String(options?.purge ?? false)\n }\n });\n }\n async loadTable(id) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n headers\n });\n return response.data.metadata;\n }\n async tableExists(id) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n try {\n await this.client.request({\n method: \"HEAD\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n headers\n });\n return true;\n } catch (error) {\n if (error instanceof IcebergError && error.status === 404) {\n return false;\n }\n throw error;\n }\n }\n async createTableIfNotExists(namespace, request) {\n try {\n return await this.createTable(namespace, request);\n } catch (error) {\n if (error instanceof IcebergError && error.status === 409) {\n return await this.loadTable({\n namespace: namespace.namespace,\n name: request.name\n });\n }\n throw error;\n }\n }\n};\n// src/catalog/IcebergRestCatalog.ts\nvar IcebergRestCatalog = class {\n /**\n * Creates a new Iceberg REST Catalog client.\n *\n * @param options - Configuration options for the catalog client\n */ constructor(options){\n let prefix = \"v1\";\n if (options.catalogName) {\n prefix += `/${options.catalogName}`;\n }\n const baseUrl = options.baseUrl.endsWith(\"/\") ? options.baseUrl : `${options.baseUrl}/`;\n this.client = createFetchClient({\n baseUrl,\n auth: options.auth,\n fetchImpl: options.fetch\n });\n this.accessDelegation = options.accessDelegation?.join(\",\");\n this.namespaceOps = new NamespaceOperations(this.client, prefix);\n this.tableOps = new TableOperations(this.client, prefix, this.accessDelegation);\n }\n /**\n * Lists all namespaces in the catalog.\n *\n * @param parent - Optional parent namespace to list children under\n * @returns Array of namespace identifiers\n *\n * @example\n * ```typescript\n * // List all top-level namespaces\n * const namespaces = await catalog.listNamespaces();\n *\n * // List namespaces under a parent\n * const children = await catalog.listNamespaces({ namespace: ['analytics'] });\n * ```\n */ async listNamespaces(parent) {\n return this.namespaceOps.listNamespaces(parent);\n }\n /**\n * Creates a new namespace in the catalog.\n *\n * @param id - Namespace identifier to create\n * @param metadata - Optional metadata properties for the namespace\n * @returns Response containing the created namespace and its properties\n *\n * @example\n * ```typescript\n * const response = await catalog.createNamespace(\n * { namespace: ['analytics'] },\n * { properties: { owner: 'data-team' } }\n * );\n * console.log(response.namespace); // ['analytics']\n * console.log(response.properties); // { owner: 'data-team', ... }\n * ```\n */ async createNamespace(id, metadata) {\n return this.namespaceOps.createNamespace(id, metadata);\n }\n /**\n * Drops a namespace from the catalog.\n *\n * The namespace must be empty (contain no tables) before it can be dropped.\n *\n * @param id - Namespace identifier to drop\n *\n * @example\n * ```typescript\n * await catalog.dropNamespace({ namespace: ['analytics'] });\n * ```\n */ async dropNamespace(id) {\n await this.namespaceOps.dropNamespace(id);\n }\n /**\n * Loads metadata for a namespace.\n *\n * @param id - Namespace identifier to load\n * @returns Namespace metadata including properties\n *\n * @example\n * ```typescript\n * const metadata = await catalog.loadNamespaceMetadata({ namespace: ['analytics'] });\n * console.log(metadata.properties);\n * ```\n */ async loadNamespaceMetadata(id) {\n return this.namespaceOps.loadNamespaceMetadata(id);\n }\n /**\n * Lists all tables in a namespace.\n *\n * @param namespace - Namespace identifier to list tables from\n * @returns Array of table identifiers\n *\n * @example\n * ```typescript\n * const tables = await catalog.listTables({ namespace: ['analytics'] });\n * console.log(tables); // [{ namespace: ['analytics'], name: 'events' }, ...]\n * ```\n */ async listTables(namespace) {\n return this.tableOps.listTables(namespace);\n }\n /**\n * Creates a new table in the catalog.\n *\n * @param namespace - Namespace to create the table in\n * @param request - Table creation request including name, schema, partition spec, etc.\n * @returns Table metadata for the created table\n *\n * @example\n * ```typescript\n * const metadata = await catalog.createTable(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n * ],\n * 'schema-id': 0\n * },\n * 'partition-spec': {\n * 'spec-id': 0,\n * fields: [\n * { source_id: 2, field_id: 1000, name: 'ts_day', transform: 'day' }\n * ]\n * }\n * }\n * );\n * ```\n */ async createTable(namespace, request) {\n return this.tableOps.createTable(namespace, request);\n }\n /**\n * Updates an existing table's metadata.\n *\n * Can update the schema, partition spec, or properties of a table.\n *\n * @param id - Table identifier to update\n * @param request - Update request with fields to modify\n * @returns Response containing the metadata location and updated table metadata\n *\n * @example\n * ```typescript\n * const response = await catalog.updateTable(\n * { namespace: ['analytics'], name: 'events' },\n * {\n * properties: { 'read.split.target-size': '134217728' }\n * }\n * );\n * console.log(response['metadata-location']); // s3://...\n * console.log(response.metadata); // TableMetadata object\n * ```\n */ async updateTable(id, request) {\n return this.tableOps.updateTable(id, request);\n }\n /**\n * Drops a table from the catalog.\n *\n * @param id - Table identifier to drop\n *\n * @example\n * ```typescript\n * await catalog.dropTable({ namespace: ['analytics'], name: 'events' });\n * ```\n */ async dropTable(id, options) {\n await this.tableOps.dropTable(id, options);\n }\n /**\n * Loads metadata for a table.\n *\n * @param id - Table identifier to load\n * @returns Table metadata including schema, partition spec, location, etc.\n *\n * @example\n * ```typescript\n * const metadata = await catalog.loadTable({ namespace: ['analytics'], name: 'events' });\n * console.log(metadata.schema);\n * console.log(metadata.location);\n * ```\n */ async loadTable(id) {\n return this.tableOps.loadTable(id);\n }\n /**\n * Checks if a namespace exists in the catalog.\n *\n * @param id - Namespace identifier to check\n * @returns True if the namespace exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = await catalog.namespaceExists({ namespace: ['analytics'] });\n * console.log(exists); // true or false\n * ```\n */ async namespaceExists(id) {\n return this.namespaceOps.namespaceExists(id);\n }\n /**\n * Checks if a table exists in the catalog.\n *\n * @param id - Table identifier to check\n * @returns True if the table exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = await catalog.tableExists({ namespace: ['analytics'], name: 'events' });\n * console.log(exists); // true or false\n * ```\n */ async tableExists(id) {\n return this.tableOps.tableExists(id);\n }\n /**\n * Creates a namespace if it does not exist.\n *\n * If the namespace already exists, returns void. If created, returns the response.\n *\n * @param id - Namespace identifier to create\n * @param metadata - Optional metadata properties for the namespace\n * @returns Response containing the created namespace and its properties, or void if it already exists\n *\n * @example\n * ```typescript\n * const response = await catalog.createNamespaceIfNotExists(\n * { namespace: ['analytics'] },\n * { properties: { owner: 'data-team' } }\n * );\n * if (response) {\n * console.log('Created:', response.namespace);\n * } else {\n * console.log('Already exists');\n * }\n * ```\n */ async createNamespaceIfNotExists(id, metadata) {\n return this.namespaceOps.createNamespaceIfNotExists(id, metadata);\n }\n /**\n * Creates a table if it does not exist.\n *\n * If the table already exists, returns its metadata instead.\n *\n * @param namespace - Namespace to create the table in\n * @param request - Table creation request including name, schema, partition spec, etc.\n * @returns Table metadata for the created or existing table\n *\n * @example\n * ```typescript\n * const metadata = await catalog.createTableIfNotExists(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n * ],\n * 'schema-id': 0\n * }\n * }\n * );\n * ```\n */ async createTableIfNotExists(namespace, request) {\n return this.tableOps.createTableIfNotExists(namespace, request);\n }\n};\n// src/catalog/types.ts\nvar DECIMAL_REGEX = /^decimal\\s*\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*\\)$/;\nvar FIXED_REGEX = /^fixed\\s*\\[\\s*(\\d+)\\s*\\]$/;\nfunction parseDecimalType(type) {\n const match = type.match(DECIMAL_REGEX);\n if (!match) return null;\n return {\n precision: parseInt(match[1], 10),\n scale: parseInt(match[2], 10)\n };\n}\nfunction parseFixedType(type) {\n const match = type.match(FIXED_REGEX);\n if (!match) return null;\n return {\n length: parseInt(match[1], 10)\n };\n}\nfunction isDecimalType(type) {\n return DECIMAL_REGEX.test(type);\n}\nfunction isFixedType(type) {\n return FIXED_REGEX.test(type);\n}\nfunction typesEqual(a, b) {\n const decimalA = parseDecimalType(a);\n const decimalB = parseDecimalType(b);\n if (decimalA && decimalB) {\n return decimalA.precision === decimalB.precision && decimalA.scale === decimalB.scale;\n }\n const fixedA = parseFixedType(a);\n const fixedB = parseFixedType(b);\n if (fixedA && fixedB) {\n return fixedA.length === fixedB.length;\n }\n return a === b;\n}\nfunction getCurrentSchema(metadata) {\n return metadata.schemas.find((s)=>s[\"schema-id\"] === metadata[\"current-schema-id\"]);\n}\n //# sourceMappingURL=index.mjs.map\n //# sourceMappingURL=index.mjs.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/iceberg-js/dist/index.mjs","mappings":"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","sources":["webpack://whisky-vault/./node_modules/iceberg-js/dist/index.mjs?fcae"],"sourcesContent":["// src/errors/IcebergError.ts\nvar IcebergError = class extends Error {\n  constructor(message, opts) {\n    super(message);\n    this.name = \"IcebergError\";\n    this.status = opts.status;\n    this.icebergType = opts.icebergType;\n    this.icebergCode = opts.icebergCode;\n    this.details = opts.details;\n    this.isCommitStateUnknown = opts.icebergType === \"CommitStateUnknownException\" || [500, 502, 504].includes(opts.status) && opts.icebergType?.includes(\"CommitState\") === true;\n  }\n  /**\n   * Returns true if the error is a 404 Not Found error.\n   */\n  isNotFound() {\n    return this.status === 404;\n  }\n  /**\n   * Returns true if the error is a 409 Conflict error.\n   */\n  isConflict() {\n    return this.status === 409;\n  }\n  /**\n   * Returns true if the error is a 419 Authentication Timeout error.\n   */\n  isAuthenticationTimeout() {\n    return this.status === 419;\n  }\n};\n\n// src/utils/url.ts\nfunction buildUrl(baseUrl, path, query) {\n  const url = new URL(path, baseUrl);\n  if (query) {\n    for (const [key, value] of Object.entries(query)) {\n      if (value !== void 0) {\n        url.searchParams.set(key, value);\n      }\n    }\n  }\n  return url.toString();\n}\n\n// src/http/createFetchClient.ts\nasync function buildAuthHeaders(auth) {\n  if (!auth || auth.type === \"none\") {\n    return {};\n  }\n  if (auth.type === \"bearer\") {\n    return { Authorization: `Bearer ${auth.token}` };\n  }\n  if (auth.type === \"header\") {\n    return { [auth.name]: auth.value };\n  }\n  if (auth.type === \"custom\") {\n    return await auth.getHeaders();\n  }\n  return {};\n}\nfunction createFetchClient(options) {\n  const fetchFn = options.fetchImpl ?? globalThis.fetch;\n  return {\n    async request({\n      method,\n      path,\n      query,\n      body,\n      headers\n    }) {\n      const url = buildUrl(options.baseUrl, path, query);\n      const authHeaders = await buildAuthHeaders(options.auth);\n      const res = await fetchFn(url, {\n        method,\n        headers: {\n          ...body ? { \"Content-Type\": \"application/json\" } : {},\n          ...authHeaders,\n          ...headers\n        },\n        body: body ? JSON.stringify(body) : void 0\n      });\n      const text = await res.text();\n      const isJson = (res.headers.get(\"content-type\") || \"\").includes(\"application/json\");\n      const data = isJson && text ? JSON.parse(text) : text;\n      if (!res.ok) {\n        const errBody = isJson ? data : void 0;\n        const errorDetail = errBody?.error;\n        throw new IcebergError(\n          errorDetail?.message ?? `Request failed with status ${res.status}`,\n          {\n            status: res.status,\n            icebergType: errorDetail?.type,\n            icebergCode: errorDetail?.code,\n            details: errBody\n          }\n        );\n      }\n      return { status: res.status, headers: res.headers, data };\n    }\n  };\n}\n\n// src/catalog/namespaces.ts\nfunction namespaceToPath(namespace) {\n  return namespace.join(\"\u001f\");\n}\nvar NamespaceOperations = class {\n  constructor(client, prefix = \"\") {\n    this.client = client;\n    this.prefix = prefix;\n  }\n  async listNamespaces(parent) {\n    const query = parent ? { parent: namespaceToPath(parent.namespace) } : void 0;\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces`,\n      query\n    });\n    return response.data.namespaces.map((ns) => ({ namespace: ns }));\n  }\n  async createNamespace(id, metadata) {\n    const request = {\n      namespace: id.namespace,\n      properties: metadata?.properties\n    };\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces`,\n      body: request\n    });\n    return response.data;\n  }\n  async dropNamespace(id) {\n    await this.client.request({\n      method: \"DELETE\",\n      path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n    });\n  }\n  async loadNamespaceMetadata(id) {\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n    });\n    return {\n      properties: response.data.properties\n    };\n  }\n  async namespaceExists(id) {\n    try {\n      await this.client.request({\n        method: \"HEAD\",\n        path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n      });\n      return true;\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 404) {\n        return false;\n      }\n      throw error;\n    }\n  }\n  async createNamespaceIfNotExists(id, metadata) {\n    try {\n      return await this.createNamespace(id, metadata);\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 409) {\n        return;\n      }\n      throw error;\n    }\n  }\n};\n\n// src/catalog/tables.ts\nfunction namespaceToPath2(namespace) {\n  return namespace.join(\"\u001f\");\n}\nvar TableOperations = class {\n  constructor(client, prefix = \"\", accessDelegation) {\n    this.client = client;\n    this.prefix = prefix;\n    this.accessDelegation = accessDelegation;\n  }\n  async listTables(namespace) {\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`\n    });\n    return response.data.identifiers;\n  }\n  async createTable(namespace, request) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`,\n      body: request,\n      headers\n    });\n    return response.data.metadata;\n  }\n  async updateTable(id, request) {\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      body: request\n    });\n    return {\n      \"metadata-location\": response.data[\"metadata-location\"],\n      metadata: response.data.metadata\n    };\n  }\n  async dropTable(id, options) {\n    await this.client.request({\n      method: \"DELETE\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      query: { purgeRequested: String(options?.purge ?? false) }\n    });\n  }\n  async loadTable(id) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      headers\n    });\n    return response.data.metadata;\n  }\n  async tableExists(id) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    try {\n      await this.client.request({\n        method: \"HEAD\",\n        path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n        headers\n      });\n      return true;\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 404) {\n        return false;\n      }\n      throw error;\n    }\n  }\n  async createTableIfNotExists(namespace, request) {\n    try {\n      return await this.createTable(namespace, request);\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 409) {\n        return await this.loadTable({ namespace: namespace.namespace, name: request.name });\n      }\n      throw error;\n    }\n  }\n};\n\n// src/catalog/IcebergRestCatalog.ts\nvar IcebergRestCatalog = class {\n  /**\n   * Creates a new Iceberg REST Catalog client.\n   *\n   * @param options - Configuration options for the catalog client\n   */\n  constructor(options) {\n    let prefix = \"v1\";\n    if (options.catalogName) {\n      prefix += `/${options.catalogName}`;\n    }\n    const baseUrl = options.baseUrl.endsWith(\"/\") ? options.baseUrl : `${options.baseUrl}/`;\n    this.client = createFetchClient({\n      baseUrl,\n      auth: options.auth,\n      fetchImpl: options.fetch\n    });\n    this.accessDelegation = options.accessDelegation?.join(\",\");\n    this.namespaceOps = new NamespaceOperations(this.client, prefix);\n    this.tableOps = new TableOperations(this.client, prefix, this.accessDelegation);\n  }\n  /**\n   * Lists all namespaces in the catalog.\n   *\n   * @param parent - Optional parent namespace to list children under\n   * @returns Array of namespace identifiers\n   *\n   * @example\n   * ```typescript\n   * // List all top-level namespaces\n   * const namespaces = await catalog.listNamespaces();\n   *\n   * // List namespaces under a parent\n   * const children = await catalog.listNamespaces({ namespace: ['analytics'] });\n   * ```\n   */\n  async listNamespaces(parent) {\n    return this.namespaceOps.listNamespaces(parent);\n  }\n  /**\n   * Creates a new namespace in the catalog.\n   *\n   * @param id - Namespace identifier to create\n   * @param metadata - Optional metadata properties for the namespace\n   * @returns Response containing the created namespace and its properties\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.createNamespace(\n   *   { namespace: ['analytics'] },\n   *   { properties: { owner: 'data-team' } }\n   * );\n   * console.log(response.namespace); // ['analytics']\n   * console.log(response.properties); // { owner: 'data-team', ... }\n   * ```\n   */\n  async createNamespace(id, metadata) {\n    return this.namespaceOps.createNamespace(id, metadata);\n  }\n  /**\n   * Drops a namespace from the catalog.\n   *\n   * The namespace must be empty (contain no tables) before it can be dropped.\n   *\n   * @param id - Namespace identifier to drop\n   *\n   * @example\n   * ```typescript\n   * await catalog.dropNamespace({ namespace: ['analytics'] });\n   * ```\n   */\n  async dropNamespace(id) {\n    await this.namespaceOps.dropNamespace(id);\n  }\n  /**\n   * Loads metadata for a namespace.\n   *\n   * @param id - Namespace identifier to load\n   * @returns Namespace metadata including properties\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.loadNamespaceMetadata({ namespace: ['analytics'] });\n   * console.log(metadata.properties);\n   * ```\n   */\n  async loadNamespaceMetadata(id) {\n    return this.namespaceOps.loadNamespaceMetadata(id);\n  }\n  /**\n   * Lists all tables in a namespace.\n   *\n   * @param namespace - Namespace identifier to list tables from\n   * @returns Array of table identifiers\n   *\n   * @example\n   * ```typescript\n   * const tables = await catalog.listTables({ namespace: ['analytics'] });\n   * console.log(tables); // [{ namespace: ['analytics'], name: 'events' }, ...]\n   * ```\n   */\n  async listTables(namespace) {\n    return this.tableOps.listTables(namespace);\n  }\n  /**\n   * Creates a new table in the catalog.\n   *\n   * @param namespace - Namespace to create the table in\n   * @param request - Table creation request including name, schema, partition spec, etc.\n   * @returns Table metadata for the created table\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.createTable(\n   *   { namespace: ['analytics'] },\n   *   {\n   *     name: 'events',\n   *     schema: {\n   *       type: 'struct',\n   *       fields: [\n   *         { id: 1, name: 'id', type: 'long', required: true },\n   *         { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n   *       ],\n   *       'schema-id': 0\n   *     },\n   *     'partition-spec': {\n   *       'spec-id': 0,\n   *       fields: [\n   *         { source_id: 2, field_id: 1000, name: 'ts_day', transform: 'day' }\n   *       ]\n   *     }\n   *   }\n   * );\n   * ```\n   */\n  async createTable(namespace, request) {\n    return this.tableOps.createTable(namespace, request);\n  }\n  /**\n   * Updates an existing table's metadata.\n   *\n   * Can update the schema, partition spec, or properties of a table.\n   *\n   * @param id - Table identifier to update\n   * @param request - Update request with fields to modify\n   * @returns Response containing the metadata location and updated table metadata\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.updateTable(\n   *   { namespace: ['analytics'], name: 'events' },\n   *   {\n   *     properties: { 'read.split.target-size': '134217728' }\n   *   }\n   * );\n   * console.log(response['metadata-location']); // s3://...\n   * console.log(response.metadata); // TableMetadata object\n   * ```\n   */\n  async updateTable(id, request) {\n    return this.tableOps.updateTable(id, request);\n  }\n  /**\n   * Drops a table from the catalog.\n   *\n   * @param id - Table identifier to drop\n   *\n   * @example\n   * ```typescript\n   * await catalog.dropTable({ namespace: ['analytics'], name: 'events' });\n   * ```\n   */\n  async dropTable(id, options) {\n    await this.tableOps.dropTable(id, options);\n  }\n  /**\n   * Loads metadata for a table.\n   *\n   * @param id - Table identifier to load\n   * @returns Table metadata including schema, partition spec, location, etc.\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.loadTable({ namespace: ['analytics'], name: 'events' });\n   * console.log(metadata.schema);\n   * console.log(metadata.location);\n   * ```\n   */\n  async loadTable(id) {\n    return this.tableOps.loadTable(id);\n  }\n  /**\n   * Checks if a namespace exists in the catalog.\n   *\n   * @param id - Namespace identifier to check\n   * @returns True if the namespace exists, false otherwise\n   *\n   * @example\n   * ```typescript\n   * const exists = await catalog.namespaceExists({ namespace: ['analytics'] });\n   * console.log(exists); // true or false\n   * ```\n   */\n  async namespaceExists(id) {\n    return this.namespaceOps.namespaceExists(id);\n  }\n  /**\n   * Checks if a table exists in the catalog.\n   *\n   * @param id - Table identifier to check\n   * @returns True if the table exists, false otherwise\n   *\n   * @example\n   * ```typescript\n   * const exists = await catalog.tableExists({ namespace: ['analytics'], name: 'events' });\n   * console.log(exists); // true or false\n   * ```\n   */\n  async tableExists(id) {\n    return this.tableOps.tableExists(id);\n  }\n  /**\n   * Creates a namespace if it does not exist.\n   *\n   * If the namespace already exists, returns void. If created, returns the response.\n   *\n   * @param id - Namespace identifier to create\n   * @param metadata - Optional metadata properties for the namespace\n   * @returns Response containing the created namespace and its properties, or void if it already exists\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.createNamespaceIfNotExists(\n   *   { namespace: ['analytics'] },\n   *   { properties: { owner: 'data-team' } }\n   * );\n   * if (response) {\n   *   console.log('Created:', response.namespace);\n   * } else {\n   *   console.log('Already exists');\n   * }\n   * ```\n   */\n  async createNamespaceIfNotExists(id, metadata) {\n    return this.namespaceOps.createNamespaceIfNotExists(id, metadata);\n  }\n  /**\n   * Creates a table if it does not exist.\n   *\n   * If the table already exists, returns its metadata instead.\n   *\n   * @param namespace - Namespace to create the table in\n   * @param request - Table creation request including name, schema, partition spec, etc.\n   * @returns Table metadata for the created or existing table\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.createTableIfNotExists(\n   *   { namespace: ['analytics'] },\n   *   {\n   *     name: 'events',\n   *     schema: {\n   *       type: 'struct',\n   *       fields: [\n   *         { id: 1, name: 'id', type: 'long', required: true },\n   *         { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n   *       ],\n   *       'schema-id': 0\n   *     }\n   *   }\n   * );\n   * ```\n   */\n  async createTableIfNotExists(namespace, request) {\n    return this.tableOps.createTableIfNotExists(namespace, request);\n  }\n};\n\n// src/catalog/types.ts\nvar DECIMAL_REGEX = /^decimal\\s*\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*\\)$/;\nvar FIXED_REGEX = /^fixed\\s*\\[\\s*(\\d+)\\s*\\]$/;\nfunction parseDecimalType(type) {\n  const match = type.match(DECIMAL_REGEX);\n  if (!match) return null;\n  return {\n    precision: parseInt(match[1], 10),\n    scale: parseInt(match[2], 10)\n  };\n}\nfunction parseFixedType(type) {\n  const match = type.match(FIXED_REGEX);\n  if (!match) return null;\n  return {\n    length: parseInt(match[1], 10)\n  };\n}\nfunction isDecimalType(type) {\n  return DECIMAL_REGEX.test(type);\n}\nfunction isFixedType(type) {\n  return FIXED_REGEX.test(type);\n}\nfunction typesEqual(a, b) {\n  const decimalA = parseDecimalType(a);\n  const decimalB = parseDecimalType(b);\n  if (decimalA && decimalB) {\n    return decimalA.precision === decimalB.precision && decimalA.scale === decimalB.scale;\n  }\n  const fixedA = parseFixedType(a);\n  const fixedB = parseFixedType(b);\n  if (fixedA && fixedB) {\n    return fixedA.length === fixedB.length;\n  }\n  return a === b;\n}\nfunction getCurrentSchema(metadata) {\n  return metadata.schemas.find((s) => s[\"schema-id\"] === metadata[\"current-schema-id\"]);\n}\n\nexport { IcebergError, IcebergRestCatalog, getCurrentSchema, isDecimalType, isFixedType, parseDecimalType, parseFixedType, typesEqual };\n//# sourceMappingURL=index.mjs.map\n//# sourceMappingURL=index.mjs.map"],"names":["IcebergError","Error","constructor","message","opts","name","status","icebergType","icebergCode","details","isCommitStateUnknown","includes","isNotFound","isConflict","isAuthenticationTimeout","buildUrl","baseUrl","path","query","url","URL","key","value","Object","entries","searchParams","set","toString","buildAuthHeaders","auth","type","Authorization","token","getHeaders","createFetchClient","options","fetchFn","fetchImpl","globalThis","fetch","request","method","body","headers","authHeaders","res","JSON","stringify","text","isJson","get","data","parse","ok","errBody","errorDetail","error","code","namespaceToPath","namespace","join","NamespaceOperations","client","prefix","listNamespaces","parent","response","namespaces","map","ns","createNamespace","id","metadata","properties","dropNamespace","loadNamespaceMetadata","namespaceExists","createNamespaceIfNotExists","namespaceToPath2","TableOperations","accessDelegation","listTables","identifiers","createTable","updateTable","dropTable","purgeRequested","String","purge","loadTable","tableExists","createTableIfNotExists","IcebergRestCatalog","catalogName","endsWith","namespaceOps","tableOps","DECIMAL_REGEX","FIXED_REGEX","parseDecimalType","match","precision","parseInt","scale","parseFixedType","length","isDecimalType","test","isFixedType","typesEqual","a","b","decimalA","decimalB","fixedA","fixedB","getCurrentSchema","schemas","find","s"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/iceberg-js/dist/index.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/iceberg-js/dist/index.mjs":
|
|
/*!************************************************!*\
|
|
!*** ./node_modules/iceberg-js/dist/index.mjs ***!
|
|
\************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ IcebergError: () => (/* binding */ IcebergError),\n/* harmony export */ IcebergRestCatalog: () => (/* binding */ IcebergRestCatalog),\n/* harmony export */ getCurrentSchema: () => (/* binding */ getCurrentSchema),\n/* harmony export */ isDecimalType: () => (/* binding */ isDecimalType),\n/* harmony export */ isFixedType: () => (/* binding */ isFixedType),\n/* harmony export */ parseDecimalType: () => (/* binding */ parseDecimalType),\n/* harmony export */ parseFixedType: () => (/* binding */ parseFixedType),\n/* harmony export */ typesEqual: () => (/* binding */ typesEqual)\n/* harmony export */ });\n// src/errors/IcebergError.ts\nvar IcebergError = class extends Error {\n constructor(message, opts){\n super(message);\n this.name = \"IcebergError\";\n this.status = opts.status;\n this.icebergType = opts.icebergType;\n this.icebergCode = opts.icebergCode;\n this.details = opts.details;\n this.isCommitStateUnknown = opts.icebergType === \"CommitStateUnknownException\" || [\n 500,\n 502,\n 504\n ].includes(opts.status) && opts.icebergType?.includes(\"CommitState\") === true;\n }\n /**\n * Returns true if the error is a 404 Not Found error.\n */ isNotFound() {\n return this.status === 404;\n }\n /**\n * Returns true if the error is a 409 Conflict error.\n */ isConflict() {\n return this.status === 409;\n }\n /**\n * Returns true if the error is a 419 Authentication Timeout error.\n */ isAuthenticationTimeout() {\n return this.status === 419;\n }\n};\n// src/utils/url.ts\nfunction buildUrl(baseUrl, path, query) {\n const url = new URL(path, baseUrl);\n if (query) {\n for (const [key, value] of Object.entries(query)){\n if (value !== void 0) {\n url.searchParams.set(key, value);\n }\n }\n }\n return url.toString();\n}\n// src/http/createFetchClient.ts\nasync function buildAuthHeaders(auth) {\n if (!auth || auth.type === \"none\") {\n return {};\n }\n if (auth.type === \"bearer\") {\n return {\n Authorization: `Bearer ${auth.token}`\n };\n }\n if (auth.type === \"header\") {\n return {\n [auth.name]: auth.value\n };\n }\n if (auth.type === \"custom\") {\n return await auth.getHeaders();\n }\n return {};\n}\nfunction createFetchClient(options) {\n const fetchFn = options.fetchImpl ?? globalThis.fetch;\n return {\n async request ({ method, path, query, body, headers }) {\n const url = buildUrl(options.baseUrl, path, query);\n const authHeaders = await buildAuthHeaders(options.auth);\n const res = await fetchFn(url, {\n method,\n headers: {\n ...body ? {\n \"Content-Type\": \"application/json\"\n } : {},\n ...authHeaders,\n ...headers\n },\n body: body ? JSON.stringify(body) : void 0\n });\n const text = await res.text();\n const isJson = (res.headers.get(\"content-type\") || \"\").includes(\"application/json\");\n const data = isJson && text ? JSON.parse(text) : text;\n if (!res.ok) {\n const errBody = isJson ? data : void 0;\n const errorDetail = errBody?.error;\n throw new IcebergError(errorDetail?.message ?? `Request failed with status ${res.status}`, {\n status: res.status,\n icebergType: errorDetail?.type,\n icebergCode: errorDetail?.code,\n details: errBody\n });\n }\n return {\n status: res.status,\n headers: res.headers,\n data\n };\n }\n };\n}\n// src/catalog/namespaces.ts\nfunction namespaceToPath(namespace) {\n return namespace.join(\"\\x1f\");\n}\nvar NamespaceOperations = class {\n constructor(client, prefix = \"\"){\n this.client = client;\n this.prefix = prefix;\n }\n async listNamespaces(parent) {\n const query = parent ? {\n parent: namespaceToPath(parent.namespace)\n } : void 0;\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces`,\n query\n });\n return response.data.namespaces.map((ns)=>({\n namespace: ns\n }));\n }\n async createNamespace(id, metadata) {\n const request = {\n namespace: id.namespace,\n properties: metadata?.properties\n };\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces`,\n body: request\n });\n return response.data;\n }\n async dropNamespace(id) {\n await this.client.request({\n method: \"DELETE\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n }\n async loadNamespaceMetadata(id) {\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n return {\n properties: response.data.properties\n };\n }\n async namespaceExists(id) {\n try {\n await this.client.request({\n method: \"HEAD\",\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n });\n return true;\n } catch (error) {\n if (error instanceof IcebergError && error.status === 404) {\n return false;\n }\n throw error;\n }\n }\n async createNamespaceIfNotExists(id, metadata) {\n try {\n return await this.createNamespace(id, metadata);\n } catch (error) {\n if (error instanceof IcebergError && error.status === 409) {\n return;\n }\n throw error;\n }\n }\n};\n// src/catalog/tables.ts\nfunction namespaceToPath2(namespace) {\n return namespace.join(\"\\x1f\");\n}\nvar TableOperations = class {\n constructor(client, prefix = \"\", accessDelegation){\n this.client = client;\n this.prefix = prefix;\n this.accessDelegation = accessDelegation;\n }\n async listTables(namespace) {\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`\n });\n return response.data.identifiers;\n }\n async createTable(namespace, request) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`,\n body: request,\n headers\n });\n return response.data.metadata;\n }\n async updateTable(id, request) {\n const response = await this.client.request({\n method: \"POST\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n body: request\n });\n return {\n \"metadata-location\": response.data[\"metadata-location\"],\n metadata: response.data.metadata\n };\n }\n async dropTable(id, options) {\n await this.client.request({\n method: \"DELETE\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n query: {\n purgeRequested: String(options?.purge ?? false)\n }\n });\n }\n async loadTable(id) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n const response = await this.client.request({\n method: \"GET\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n headers\n });\n return response.data.metadata;\n }\n async tableExists(id) {\n const headers = {};\n if (this.accessDelegation) {\n headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n }\n try {\n await this.client.request({\n method: \"HEAD\",\n path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n headers\n });\n return true;\n } catch (error) {\n if (error instanceof IcebergError && error.status === 404) {\n return false;\n }\n throw error;\n }\n }\n async createTableIfNotExists(namespace, request) {\n try {\n return await this.createTable(namespace, request);\n } catch (error) {\n if (error instanceof IcebergError && error.status === 409) {\n return await this.loadTable({\n namespace: namespace.namespace,\n name: request.name\n });\n }\n throw error;\n }\n }\n};\n// src/catalog/IcebergRestCatalog.ts\nvar IcebergRestCatalog = class {\n /**\n * Creates a new Iceberg REST Catalog client.\n *\n * @param options - Configuration options for the catalog client\n */ constructor(options){\n let prefix = \"v1\";\n if (options.catalogName) {\n prefix += `/${options.catalogName}`;\n }\n const baseUrl = options.baseUrl.endsWith(\"/\") ? options.baseUrl : `${options.baseUrl}/`;\n this.client = createFetchClient({\n baseUrl,\n auth: options.auth,\n fetchImpl: options.fetch\n });\n this.accessDelegation = options.accessDelegation?.join(\",\");\n this.namespaceOps = new NamespaceOperations(this.client, prefix);\n this.tableOps = new TableOperations(this.client, prefix, this.accessDelegation);\n }\n /**\n * Lists all namespaces in the catalog.\n *\n * @param parent - Optional parent namespace to list children under\n * @returns Array of namespace identifiers\n *\n * @example\n * ```typescript\n * // List all top-level namespaces\n * const namespaces = await catalog.listNamespaces();\n *\n * // List namespaces under a parent\n * const children = await catalog.listNamespaces({ namespace: ['analytics'] });\n * ```\n */ async listNamespaces(parent) {\n return this.namespaceOps.listNamespaces(parent);\n }\n /**\n * Creates a new namespace in the catalog.\n *\n * @param id - Namespace identifier to create\n * @param metadata - Optional metadata properties for the namespace\n * @returns Response containing the created namespace and its properties\n *\n * @example\n * ```typescript\n * const response = await catalog.createNamespace(\n * { namespace: ['analytics'] },\n * { properties: { owner: 'data-team' } }\n * );\n * console.log(response.namespace); // ['analytics']\n * console.log(response.properties); // { owner: 'data-team', ... }\n * ```\n */ async createNamespace(id, metadata) {\n return this.namespaceOps.createNamespace(id, metadata);\n }\n /**\n * Drops a namespace from the catalog.\n *\n * The namespace must be empty (contain no tables) before it can be dropped.\n *\n * @param id - Namespace identifier to drop\n *\n * @example\n * ```typescript\n * await catalog.dropNamespace({ namespace: ['analytics'] });\n * ```\n */ async dropNamespace(id) {\n await this.namespaceOps.dropNamespace(id);\n }\n /**\n * Loads metadata for a namespace.\n *\n * @param id - Namespace identifier to load\n * @returns Namespace metadata including properties\n *\n * @example\n * ```typescript\n * const metadata = await catalog.loadNamespaceMetadata({ namespace: ['analytics'] });\n * console.log(metadata.properties);\n * ```\n */ async loadNamespaceMetadata(id) {\n return this.namespaceOps.loadNamespaceMetadata(id);\n }\n /**\n * Lists all tables in a namespace.\n *\n * @param namespace - Namespace identifier to list tables from\n * @returns Array of table identifiers\n *\n * @example\n * ```typescript\n * const tables = await catalog.listTables({ namespace: ['analytics'] });\n * console.log(tables); // [{ namespace: ['analytics'], name: 'events' }, ...]\n * ```\n */ async listTables(namespace) {\n return this.tableOps.listTables(namespace);\n }\n /**\n * Creates a new table in the catalog.\n *\n * @param namespace - Namespace to create the table in\n * @param request - Table creation request including name, schema, partition spec, etc.\n * @returns Table metadata for the created table\n *\n * @example\n * ```typescript\n * const metadata = await catalog.createTable(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n * ],\n * 'schema-id': 0\n * },\n * 'partition-spec': {\n * 'spec-id': 0,\n * fields: [\n * { source_id: 2, field_id: 1000, name: 'ts_day', transform: 'day' }\n * ]\n * }\n * }\n * );\n * ```\n */ async createTable(namespace, request) {\n return this.tableOps.createTable(namespace, request);\n }\n /**\n * Updates an existing table's metadata.\n *\n * Can update the schema, partition spec, or properties of a table.\n *\n * @param id - Table identifier to update\n * @param request - Update request with fields to modify\n * @returns Response containing the metadata location and updated table metadata\n *\n * @example\n * ```typescript\n * const response = await catalog.updateTable(\n * { namespace: ['analytics'], name: 'events' },\n * {\n * properties: { 'read.split.target-size': '134217728' }\n * }\n * );\n * console.log(response['metadata-location']); // s3://...\n * console.log(response.metadata); // TableMetadata object\n * ```\n */ async updateTable(id, request) {\n return this.tableOps.updateTable(id, request);\n }\n /**\n * Drops a table from the catalog.\n *\n * @param id - Table identifier to drop\n *\n * @example\n * ```typescript\n * await catalog.dropTable({ namespace: ['analytics'], name: 'events' });\n * ```\n */ async dropTable(id, options) {\n await this.tableOps.dropTable(id, options);\n }\n /**\n * Loads metadata for a table.\n *\n * @param id - Table identifier to load\n * @returns Table metadata including schema, partition spec, location, etc.\n *\n * @example\n * ```typescript\n * const metadata = await catalog.loadTable({ namespace: ['analytics'], name: 'events' });\n * console.log(metadata.schema);\n * console.log(metadata.location);\n * ```\n */ async loadTable(id) {\n return this.tableOps.loadTable(id);\n }\n /**\n * Checks if a namespace exists in the catalog.\n *\n * @param id - Namespace identifier to check\n * @returns True if the namespace exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = await catalog.namespaceExists({ namespace: ['analytics'] });\n * console.log(exists); // true or false\n * ```\n */ async namespaceExists(id) {\n return this.namespaceOps.namespaceExists(id);\n }\n /**\n * Checks if a table exists in the catalog.\n *\n * @param id - Table identifier to check\n * @returns True if the table exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = await catalog.tableExists({ namespace: ['analytics'], name: 'events' });\n * console.log(exists); // true or false\n * ```\n */ async tableExists(id) {\n return this.tableOps.tableExists(id);\n }\n /**\n * Creates a namespace if it does not exist.\n *\n * If the namespace already exists, returns void. If created, returns the response.\n *\n * @param id - Namespace identifier to create\n * @param metadata - Optional metadata properties for the namespace\n * @returns Response containing the created namespace and its properties, or void if it already exists\n *\n * @example\n * ```typescript\n * const response = await catalog.createNamespaceIfNotExists(\n * { namespace: ['analytics'] },\n * { properties: { owner: 'data-team' } }\n * );\n * if (response) {\n * console.log('Created:', response.namespace);\n * } else {\n * console.log('Already exists');\n * }\n * ```\n */ async createNamespaceIfNotExists(id, metadata) {\n return this.namespaceOps.createNamespaceIfNotExists(id, metadata);\n }\n /**\n * Creates a table if it does not exist.\n *\n * If the table already exists, returns its metadata instead.\n *\n * @param namespace - Namespace to create the table in\n * @param request - Table creation request including name, schema, partition spec, etc.\n * @returns Table metadata for the created or existing table\n *\n * @example\n * ```typescript\n * const metadata = await catalog.createTableIfNotExists(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n * ],\n * 'schema-id': 0\n * }\n * }\n * );\n * ```\n */ async createTableIfNotExists(namespace, request) {\n return this.tableOps.createTableIfNotExists(namespace, request);\n }\n};\n// src/catalog/types.ts\nvar DECIMAL_REGEX = /^decimal\\s*\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*\\)$/;\nvar FIXED_REGEX = /^fixed\\s*\\[\\s*(\\d+)\\s*\\]$/;\nfunction parseDecimalType(type) {\n const match = type.match(DECIMAL_REGEX);\n if (!match) return null;\n return {\n precision: parseInt(match[1], 10),\n scale: parseInt(match[2], 10)\n };\n}\nfunction parseFixedType(type) {\n const match = type.match(FIXED_REGEX);\n if (!match) return null;\n return {\n length: parseInt(match[1], 10)\n };\n}\nfunction isDecimalType(type) {\n return DECIMAL_REGEX.test(type);\n}\nfunction isFixedType(type) {\n return FIXED_REGEX.test(type);\n}\nfunction typesEqual(a, b) {\n const decimalA = parseDecimalType(a);\n const decimalB = parseDecimalType(b);\n if (decimalA && decimalB) {\n return decimalA.precision === decimalB.precision && decimalA.scale === decimalB.scale;\n }\n const fixedA = parseFixedType(a);\n const fixedB = parseFixedType(b);\n if (fixedA && fixedB) {\n return fixedA.length === fixedB.length;\n }\n return a === b;\n}\nfunction getCurrentSchema(metadata) {\n return metadata.schemas.find((s)=>s[\"schema-id\"] === metadata[\"current-schema-id\"]);\n}\n //# sourceMappingURL=index.mjs.map\n //# sourceMappingURL=index.mjs.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/iceberg-js/dist/index.mjs","mappings":"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","sources":["webpack://whisky-vault/./node_modules/iceberg-js/dist/index.mjs?fcae"],"sourcesContent":["// src/errors/IcebergError.ts\nvar IcebergError = class extends Error {\n  constructor(message, opts) {\n    super(message);\n    this.name = \"IcebergError\";\n    this.status = opts.status;\n    this.icebergType = opts.icebergType;\n    this.icebergCode = opts.icebergCode;\n    this.details = opts.details;\n    this.isCommitStateUnknown = opts.icebergType === \"CommitStateUnknownException\" || [500, 502, 504].includes(opts.status) && opts.icebergType?.includes(\"CommitState\") === true;\n  }\n  /**\n   * Returns true if the error is a 404 Not Found error.\n   */\n  isNotFound() {\n    return this.status === 404;\n  }\n  /**\n   * Returns true if the error is a 409 Conflict error.\n   */\n  isConflict() {\n    return this.status === 409;\n  }\n  /**\n   * Returns true if the error is a 419 Authentication Timeout error.\n   */\n  isAuthenticationTimeout() {\n    return this.status === 419;\n  }\n};\n\n// src/utils/url.ts\nfunction buildUrl(baseUrl, path, query) {\n  const url = new URL(path, baseUrl);\n  if (query) {\n    for (const [key, value] of Object.entries(query)) {\n      if (value !== void 0) {\n        url.searchParams.set(key, value);\n      }\n    }\n  }\n  return url.toString();\n}\n\n// src/http/createFetchClient.ts\nasync function buildAuthHeaders(auth) {\n  if (!auth || auth.type === \"none\") {\n    return {};\n  }\n  if (auth.type === \"bearer\") {\n    return { Authorization: `Bearer ${auth.token}` };\n  }\n  if (auth.type === \"header\") {\n    return { [auth.name]: auth.value };\n  }\n  if (auth.type === \"custom\") {\n    return await auth.getHeaders();\n  }\n  return {};\n}\nfunction createFetchClient(options) {\n  const fetchFn = options.fetchImpl ?? globalThis.fetch;\n  return {\n    async request({\n      method,\n      path,\n      query,\n      body,\n      headers\n    }) {\n      const url = buildUrl(options.baseUrl, path, query);\n      const authHeaders = await buildAuthHeaders(options.auth);\n      const res = await fetchFn(url, {\n        method,\n        headers: {\n          ...body ? { \"Content-Type\": \"application/json\" } : {},\n          ...authHeaders,\n          ...headers\n        },\n        body: body ? JSON.stringify(body) : void 0\n      });\n      const text = await res.text();\n      const isJson = (res.headers.get(\"content-type\") || \"\").includes(\"application/json\");\n      const data = isJson && text ? JSON.parse(text) : text;\n      if (!res.ok) {\n        const errBody = isJson ? data : void 0;\n        const errorDetail = errBody?.error;\n        throw new IcebergError(\n          errorDetail?.message ?? `Request failed with status ${res.status}`,\n          {\n            status: res.status,\n            icebergType: errorDetail?.type,\n            icebergCode: errorDetail?.code,\n            details: errBody\n          }\n        );\n      }\n      return { status: res.status, headers: res.headers, data };\n    }\n  };\n}\n\n// src/catalog/namespaces.ts\nfunction namespaceToPath(namespace) {\n  return namespace.join(\"\u001f\");\n}\nvar NamespaceOperations = class {\n  constructor(client, prefix = \"\") {\n    this.client = client;\n    this.prefix = prefix;\n  }\n  async listNamespaces(parent) {\n    const query = parent ? { parent: namespaceToPath(parent.namespace) } : void 0;\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces`,\n      query\n    });\n    return response.data.namespaces.map((ns) => ({ namespace: ns }));\n  }\n  async createNamespace(id, metadata) {\n    const request = {\n      namespace: id.namespace,\n      properties: metadata?.properties\n    };\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces`,\n      body: request\n    });\n    return response.data;\n  }\n  async dropNamespace(id) {\n    await this.client.request({\n      method: \"DELETE\",\n      path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n    });\n  }\n  async loadNamespaceMetadata(id) {\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n    });\n    return {\n      properties: response.data.properties\n    };\n  }\n  async namespaceExists(id) {\n    try {\n      await this.client.request({\n        method: \"HEAD\",\n        path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`\n      });\n      return true;\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 404) {\n        return false;\n      }\n      throw error;\n    }\n  }\n  async createNamespaceIfNotExists(id, metadata) {\n    try {\n      return await this.createNamespace(id, metadata);\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 409) {\n        return;\n      }\n      throw error;\n    }\n  }\n};\n\n// src/catalog/tables.ts\nfunction namespaceToPath2(namespace) {\n  return namespace.join(\"\u001f\");\n}\nvar TableOperations = class {\n  constructor(client, prefix = \"\", accessDelegation) {\n    this.client = client;\n    this.prefix = prefix;\n    this.accessDelegation = accessDelegation;\n  }\n  async listTables(namespace) {\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`\n    });\n    return response.data.identifiers;\n  }\n  async createTable(namespace, request) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(namespace.namespace)}/tables`,\n      body: request,\n      headers\n    });\n    return response.data.metadata;\n  }\n  async updateTable(id, request) {\n    const response = await this.client.request({\n      method: \"POST\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      body: request\n    });\n    return {\n      \"metadata-location\": response.data[\"metadata-location\"],\n      metadata: response.data.metadata\n    };\n  }\n  async dropTable(id, options) {\n    await this.client.request({\n      method: \"DELETE\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      query: { purgeRequested: String(options?.purge ?? false) }\n    });\n  }\n  async loadTable(id) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    const response = await this.client.request({\n      method: \"GET\",\n      path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n      headers\n    });\n    return response.data.metadata;\n  }\n  async tableExists(id) {\n    const headers = {};\n    if (this.accessDelegation) {\n      headers[\"X-Iceberg-Access-Delegation\"] = this.accessDelegation;\n    }\n    try {\n      await this.client.request({\n        method: \"HEAD\",\n        path: `${this.prefix}/namespaces/${namespaceToPath2(id.namespace)}/tables/${id.name}`,\n        headers\n      });\n      return true;\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 404) {\n        return false;\n      }\n      throw error;\n    }\n  }\n  async createTableIfNotExists(namespace, request) {\n    try {\n      return await this.createTable(namespace, request);\n    } catch (error) {\n      if (error instanceof IcebergError && error.status === 409) {\n        return await this.loadTable({ namespace: namespace.namespace, name: request.name });\n      }\n      throw error;\n    }\n  }\n};\n\n// src/catalog/IcebergRestCatalog.ts\nvar IcebergRestCatalog = class {\n  /**\n   * Creates a new Iceberg REST Catalog client.\n   *\n   * @param options - Configuration options for the catalog client\n   */\n  constructor(options) {\n    let prefix = \"v1\";\n    if (options.catalogName) {\n      prefix += `/${options.catalogName}`;\n    }\n    const baseUrl = options.baseUrl.endsWith(\"/\") ? options.baseUrl : `${options.baseUrl}/`;\n    this.client = createFetchClient({\n      baseUrl,\n      auth: options.auth,\n      fetchImpl: options.fetch\n    });\n    this.accessDelegation = options.accessDelegation?.join(\",\");\n    this.namespaceOps = new NamespaceOperations(this.client, prefix);\n    this.tableOps = new TableOperations(this.client, prefix, this.accessDelegation);\n  }\n  /**\n   * Lists all namespaces in the catalog.\n   *\n   * @param parent - Optional parent namespace to list children under\n   * @returns Array of namespace identifiers\n   *\n   * @example\n   * ```typescript\n   * // List all top-level namespaces\n   * const namespaces = await catalog.listNamespaces();\n   *\n   * // List namespaces under a parent\n   * const children = await catalog.listNamespaces({ namespace: ['analytics'] });\n   * ```\n   */\n  async listNamespaces(parent) {\n    return this.namespaceOps.listNamespaces(parent);\n  }\n  /**\n   * Creates a new namespace in the catalog.\n   *\n   * @param id - Namespace identifier to create\n   * @param metadata - Optional metadata properties for the namespace\n   * @returns Response containing the created namespace and its properties\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.createNamespace(\n   *   { namespace: ['analytics'] },\n   *   { properties: { owner: 'data-team' } }\n   * );\n   * console.log(response.namespace); // ['analytics']\n   * console.log(response.properties); // { owner: 'data-team', ... }\n   * ```\n   */\n  async createNamespace(id, metadata) {\n    return this.namespaceOps.createNamespace(id, metadata);\n  }\n  /**\n   * Drops a namespace from the catalog.\n   *\n   * The namespace must be empty (contain no tables) before it can be dropped.\n   *\n   * @param id - Namespace identifier to drop\n   *\n   * @example\n   * ```typescript\n   * await catalog.dropNamespace({ namespace: ['analytics'] });\n   * ```\n   */\n  async dropNamespace(id) {\n    await this.namespaceOps.dropNamespace(id);\n  }\n  /**\n   * Loads metadata for a namespace.\n   *\n   * @param id - Namespace identifier to load\n   * @returns Namespace metadata including properties\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.loadNamespaceMetadata({ namespace: ['analytics'] });\n   * console.log(metadata.properties);\n   * ```\n   */\n  async loadNamespaceMetadata(id) {\n    return this.namespaceOps.loadNamespaceMetadata(id);\n  }\n  /**\n   * Lists all tables in a namespace.\n   *\n   * @param namespace - Namespace identifier to list tables from\n   * @returns Array of table identifiers\n   *\n   * @example\n   * ```typescript\n   * const tables = await catalog.listTables({ namespace: ['analytics'] });\n   * console.log(tables); // [{ namespace: ['analytics'], name: 'events' }, ...]\n   * ```\n   */\n  async listTables(namespace) {\n    return this.tableOps.listTables(namespace);\n  }\n  /**\n   * Creates a new table in the catalog.\n   *\n   * @param namespace - Namespace to create the table in\n   * @param request - Table creation request including name, schema, partition spec, etc.\n   * @returns Table metadata for the created table\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.createTable(\n   *   { namespace: ['analytics'] },\n   *   {\n   *     name: 'events',\n   *     schema: {\n   *       type: 'struct',\n   *       fields: [\n   *         { id: 1, name: 'id', type: 'long', required: true },\n   *         { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n   *       ],\n   *       'schema-id': 0\n   *     },\n   *     'partition-spec': {\n   *       'spec-id': 0,\n   *       fields: [\n   *         { source_id: 2, field_id: 1000, name: 'ts_day', transform: 'day' }\n   *       ]\n   *     }\n   *   }\n   * );\n   * ```\n   */\n  async createTable(namespace, request) {\n    return this.tableOps.createTable(namespace, request);\n  }\n  /**\n   * Updates an existing table's metadata.\n   *\n   * Can update the schema, partition spec, or properties of a table.\n   *\n   * @param id - Table identifier to update\n   * @param request - Update request with fields to modify\n   * @returns Response containing the metadata location and updated table metadata\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.updateTable(\n   *   { namespace: ['analytics'], name: 'events' },\n   *   {\n   *     properties: { 'read.split.target-size': '134217728' }\n   *   }\n   * );\n   * console.log(response['metadata-location']); // s3://...\n   * console.log(response.metadata); // TableMetadata object\n   * ```\n   */\n  async updateTable(id, request) {\n    return this.tableOps.updateTable(id, request);\n  }\n  /**\n   * Drops a table from the catalog.\n   *\n   * @param id - Table identifier to drop\n   *\n   * @example\n   * ```typescript\n   * await catalog.dropTable({ namespace: ['analytics'], name: 'events' });\n   * ```\n   */\n  async dropTable(id, options) {\n    await this.tableOps.dropTable(id, options);\n  }\n  /**\n   * Loads metadata for a table.\n   *\n   * @param id - Table identifier to load\n   * @returns Table metadata including schema, partition spec, location, etc.\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.loadTable({ namespace: ['analytics'], name: 'events' });\n   * console.log(metadata.schema);\n   * console.log(metadata.location);\n   * ```\n   */\n  async loadTable(id) {\n    return this.tableOps.loadTable(id);\n  }\n  /**\n   * Checks if a namespace exists in the catalog.\n   *\n   * @param id - Namespace identifier to check\n   * @returns True if the namespace exists, false otherwise\n   *\n   * @example\n   * ```typescript\n   * const exists = await catalog.namespaceExists({ namespace: ['analytics'] });\n   * console.log(exists); // true or false\n   * ```\n   */\n  async namespaceExists(id) {\n    return this.namespaceOps.namespaceExists(id);\n  }\n  /**\n   * Checks if a table exists in the catalog.\n   *\n   * @param id - Table identifier to check\n   * @returns True if the table exists, false otherwise\n   *\n   * @example\n   * ```typescript\n   * const exists = await catalog.tableExists({ namespace: ['analytics'], name: 'events' });\n   * console.log(exists); // true or false\n   * ```\n   */\n  async tableExists(id) {\n    return this.tableOps.tableExists(id);\n  }\n  /**\n   * Creates a namespace if it does not exist.\n   *\n   * If the namespace already exists, returns void. If created, returns the response.\n   *\n   * @param id - Namespace identifier to create\n   * @param metadata - Optional metadata properties for the namespace\n   * @returns Response containing the created namespace and its properties, or void if it already exists\n   *\n   * @example\n   * ```typescript\n   * const response = await catalog.createNamespaceIfNotExists(\n   *   { namespace: ['analytics'] },\n   *   { properties: { owner: 'data-team' } }\n   * );\n   * if (response) {\n   *   console.log('Created:', response.namespace);\n   * } else {\n   *   console.log('Already exists');\n   * }\n   * ```\n   */\n  async createNamespaceIfNotExists(id, metadata) {\n    return this.namespaceOps.createNamespaceIfNotExists(id, metadata);\n  }\n  /**\n   * Creates a table if it does not exist.\n   *\n   * If the table already exists, returns its metadata instead.\n   *\n   * @param namespace - Namespace to create the table in\n   * @param request - Table creation request including name, schema, partition spec, etc.\n   * @returns Table metadata for the created or existing table\n   *\n   * @example\n   * ```typescript\n   * const metadata = await catalog.createTableIfNotExists(\n   *   { namespace: ['analytics'] },\n   *   {\n   *     name: 'events',\n   *     schema: {\n   *       type: 'struct',\n   *       fields: [\n   *         { id: 1, name: 'id', type: 'long', required: true },\n   *         { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n   *       ],\n   *       'schema-id': 0\n   *     }\n   *   }\n   * );\n   * ```\n   */\n  async createTableIfNotExists(namespace, request) {\n    return this.tableOps.createTableIfNotExists(namespace, request);\n  }\n};\n\n// src/catalog/types.ts\nvar DECIMAL_REGEX = /^decimal\\s*\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*\\)$/;\nvar FIXED_REGEX = /^fixed\\s*\\[\\s*(\\d+)\\s*\\]$/;\nfunction parseDecimalType(type) {\n  const match = type.match(DECIMAL_REGEX);\n  if (!match) return null;\n  return {\n    precision: parseInt(match[1], 10),\n    scale: parseInt(match[2], 10)\n  };\n}\nfunction parseFixedType(type) {\n  const match = type.match(FIXED_REGEX);\n  if (!match) return null;\n  return {\n    length: parseInt(match[1], 10)\n  };\n}\nfunction isDecimalType(type) {\n  return DECIMAL_REGEX.test(type);\n}\nfunction isFixedType(type) {\n  return FIXED_REGEX.test(type);\n}\nfunction typesEqual(a, b) {\n  const decimalA = parseDecimalType(a);\n  const decimalB = parseDecimalType(b);\n  if (decimalA && decimalB) {\n    return decimalA.precision === decimalB.precision && decimalA.scale === decimalB.scale;\n  }\n  const fixedA = parseFixedType(a);\n  const fixedB = parseFixedType(b);\n  if (fixedA && fixedB) {\n    return fixedA.length === fixedB.length;\n  }\n  return a === b;\n}\nfunction getCurrentSchema(metadata) {\n  return metadata.schemas.find((s) => s[\"schema-id\"] === metadata[\"current-schema-id\"]);\n}\n\nexport { IcebergError, IcebergRestCatalog, getCurrentSchema, isDecimalType, isFixedType, parseDecimalType, parseFixedType, typesEqual };\n//# sourceMappingURL=index.mjs.map\n//# sourceMappingURL=index.mjs.map"],"names":["IcebergError","Error","constructor","message","opts","name","status","icebergType","icebergCode","details","isCommitStateUnknown","includes","isNotFound","isConflict","isAuthenticationTimeout","buildUrl","baseUrl","path","query","url","URL","key","value","Object","entries","searchParams","set","toString","buildAuthHeaders","auth","type","Authorization","token","getHeaders","createFetchClient","options","fetchFn","fetchImpl","globalThis","fetch","request","method","body","headers","authHeaders","res","JSON","stringify","text","isJson","get","data","parse","ok","errBody","errorDetail","error","code","namespaceToPath","namespace","join","NamespaceOperations","client","prefix","listNamespaces","parent","response","namespaces","map","ns","createNamespace","id","metadata","properties","dropNamespace","loadNamespaceMetadata","namespaceExists","createNamespaceIfNotExists","namespaceToPath2","TableOperations","accessDelegation","listTables","identifiers","createTable","updateTable","dropTable","purgeRequested","String","purge","loadTable","tableExists","createTableIfNotExists","IcebergRestCatalog","catalogName","endsWith","namespaceOps","tableOps","DECIMAL_REGEX","FIXED_REGEX","parseDecimalType","match","precision","parseInt","scale","parseFixedType","length","isDecimalType","test","isFixedType","typesEqual","a","b","decimalA","decimalB","fixedA","fixedB","getCurrentSchema","schemas","find","s"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/iceberg-js/dist/index.mjs\n");
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |