@jiggai/kitchen 0.4.2 → 0.4.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (78) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/build-manifest.json +2 -2
  3. package/.next/prerender-manifest.json +3 -3
  4. package/.next/server/app/_global-error.html +2 -2
  5. package/.next/server/app/_global-error.rsc +1 -1
  6. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  7. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  8. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  9. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  10. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  11. package/.next/server/app/_not-found.html +1 -1
  12. package/.next/server/app/_not-found.rsc +2 -2
  13. package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  14. package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  15. package/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  16. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  17. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  18. package/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  19. package/.next/server/app/api/plugins/[pluginId]/[...path]/route.js +1 -1
  20. package/.next/server/app/api/plugins/[pluginId]/[...path]/route.js.nft.json +1 -1
  21. package/.next/server/app/api/plugins/[pluginId]/tabs/[tabId]/route.js +1 -1
  22. package/.next/server/app/api/plugins/[pluginId]/tabs/[tabId]/route.js.nft.json +1 -1
  23. package/.next/server/app/api/plugins/route.js +1 -1
  24. package/.next/server/app/api/plugins/route.js.nft.json +1 -1
  25. package/.next/server/app/api/plugins/test/route.js +1 -1
  26. package/.next/server/app/api/plugins/test/route.js.nft.json +1 -1
  27. package/.next/server/app/api/teams/[teamId]/tickets/assignees/route.js +2 -2
  28. package/.next/server/app/api/teams/plugins/route.js +1 -1
  29. package/.next/server/app/api/teams/plugins/route.js.nft.json +1 -1
  30. package/.next/server/app/channels.html +2 -2
  31. package/.next/server/app/channels.rsc +2 -2
  32. package/.next/server/app/channels.segments/_full.segment.rsc +2 -2
  33. package/.next/server/app/channels.segments/_head.segment.rsc +1 -1
  34. package/.next/server/app/channels.segments/_index.segment.rsc +1 -1
  35. package/.next/server/app/channels.segments/_tree.segment.rsc +1 -1
  36. package/.next/server/app/channels.segments/channels/__PAGE__.segment.rsc +1 -1
  37. package/.next/server/app/channels.segments/channels.segment.rsc +1 -1
  38. package/.next/server/app/goals/new.html +2 -2
  39. package/.next/server/app/goals/new.rsc +2 -2
  40. package/.next/server/app/goals/new.segments/_full.segment.rsc +2 -2
  41. package/.next/server/app/goals/new.segments/_head.segment.rsc +1 -1
  42. package/.next/server/app/goals/new.segments/_index.segment.rsc +1 -1
  43. package/.next/server/app/goals/new.segments/_tree.segment.rsc +1 -1
  44. package/.next/server/app/goals/new.segments/goals/new/__PAGE__.segment.rsc +1 -1
  45. package/.next/server/app/goals/new.segments/goals/new.segment.rsc +1 -1
  46. package/.next/server/app/goals/new.segments/goals.segment.rsc +1 -1
  47. package/.next/server/app/goals.html +1 -1
  48. package/.next/server/app/goals.rsc +2 -2
  49. package/.next/server/app/goals.segments/_full.segment.rsc +2 -2
  50. package/.next/server/app/goals.segments/_head.segment.rsc +1 -1
  51. package/.next/server/app/goals.segments/_index.segment.rsc +1 -1
  52. package/.next/server/app/goals.segments/_tree.segment.rsc +1 -1
  53. package/.next/server/app/goals.segments/goals/__PAGE__.segment.rsc +1 -1
  54. package/.next/server/app/goals.segments/goals.segment.rsc +1 -1
  55. package/.next/server/app/settings.html +1 -1
  56. package/.next/server/app/settings.rsc +2 -2
  57. package/.next/server/app/settings.segments/_full.segment.rsc +2 -2
  58. package/.next/server/app/settings.segments/_head.segment.rsc +1 -1
  59. package/.next/server/app/settings.segments/_index.segment.rsc +1 -1
  60. package/.next/server/app/settings.segments/_tree.segment.rsc +1 -1
  61. package/.next/server/app/settings.segments/settings/__PAGE__.segment.rsc +1 -1
  62. package/.next/server/app/settings.segments/settings.segment.rsc +1 -1
  63. package/.next/server/chunks/[root-of-the-server]__1e0ade2e._.js +22 -0
  64. package/.next/server/chunks/[root-of-the-server]__1e0ade2e._.js.map +1 -0
  65. package/.next/server/chunks/[root-of-the-server]__5aa1dc93._.js +1 -1
  66. package/.next/server/chunks/ssr/[root-of-the-server]__3b880807._.js +1 -1
  67. package/.next/server/chunks/ssr/[root-of-the-server]__3b880807._.js.map +1 -1
  68. package/.next/server/pages/404.html +1 -1
  69. package/.next/server/pages/500.html +2 -2
  70. package/.next/server/server-reference-manifest.js +1 -1
  71. package/.next/server/server-reference-manifest.json +1 -1
  72. package/openclaw.plugin.json +1 -1
  73. package/package.json +1 -1
  74. package/.next/server/chunks/[root-of-the-server]__497e7a9d._.js +0 -22
  75. package/.next/server/chunks/[root-of-the-server]__497e7a9d._.js.map +0 -1
  76. /package/.next/static/{YrhQe6JKLjXQk2SvUpwVM → Qrq3jqLaWMj-CoWdszvsX}/_buildManifest.js +0 -0
  77. /package/.next/static/{YrhQe6JKLjXQk2SvUpwVM → Qrq3jqLaWMj-CoWdszvsX}/_clientMiddlewareManifest.json +0 -0
  78. /package/.next/static/{YrhQe6JKLjXQk2SvUpwVM → Qrq3jqLaWMj-CoWdszvsX}/_ssgManifest.js +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../node_modules/drizzle-orm/table.utils.js","../../../node_modules/drizzle-orm/tracing-utils.js","../../../node_modules/drizzle-orm/pg-core/utils/array.js","../../../src/lib/kitchen-plugins.ts","../../../node_modules/drizzle-orm/version.js","../../../node_modules/drizzle-orm/view-common.js","../../../node_modules/drizzle-orm/pg-core/columns/postgis_extension/utils.js","../../../node_modules/drizzle-orm/entity.js","../../../node_modules/drizzle-orm/subquery.js","../../../node_modules/drizzle-orm/cache/core/cache.js","../../../node_modules/drizzle-orm/column-builder.js","../../../node_modules/drizzle-orm/logger.js","../../../node_modules/drizzle-orm/column.js","../../../node_modules/drizzle-orm/sql/expressions/select.js","../../../node_modules/drizzle-orm/errors.js","../../../node_modules/drizzle-orm/query-builders/query-builder.js","../../../node_modules/drizzle-orm/query-promise.js","../../../node_modules/drizzle-orm/sqlite-core/checks.js","../../../node_modules/drizzle-orm/sqlite-core/indexes.js","../../../node_modules/drizzle-orm/pg-core/columns/boolean.js","../../../node_modules/drizzle-orm/pg-core/columns/jsonb.js","../../../node_modules/drizzle-orm/pg-core/columns/macaddr.js","../../../node_modules/drizzle-orm/pg-core/columns/macaddr8.js","../../../node_modules/drizzle-orm/pg-core/columns/cidr.js","../../../node_modules/drizzle-orm/pg-core/columns/double-precision.js","../../../node_modules/drizzle-orm/pg-core/columns/enum.js","../../../node_modules/drizzle-orm/pg-core/columns/real.js","../../../node_modules/drizzle-orm/pg-core/columns/serial.js","../../../node_modules/drizzle-orm/pg-core/columns/smallserial.js","../../../node_modules/drizzle-orm/pg-core/columns/int.common.js","../../../node_modules/drizzle-orm/pg-core/primary-keys.js","../../../node_modules/drizzle-orm/table.js","../../../node_modules/drizzle-orm/casing.js","../../../node_modules/drizzle-orm/sqlite-core/foreign-keys.js","../../../node_modules/drizzle-orm/sqlite-core/unique-constraint.js","../../../node_modules/drizzle-orm/sqlite-core/columns/real.js","../../../node_modules/drizzle-orm/sqlite-core/view-base.js","../../../node_modules/drizzle-orm/tracing.js","../../../node_modules/drizzle-orm/pg-core/foreign-keys.js","../../../node_modules/drizzle-orm/pg-core/unique-constraint.js","../../../node_modules/drizzle-orm/pg-core/columns/inet.js","../../../node_modules/drizzle-orm/sqlite-core/primary-keys.js","../../../node_modules/drizzle-orm/sqlite-core/query-builders/count.js","../../../node_modules/drizzle-orm/sqlite-core/query-builders/raw.js","../../../node_modules/drizzle-orm/pg-core/columns/json.js","../../../node_modules/drizzle-orm/pg-core/columns/vector_extension/sparsevec.js","../../../node_modules/drizzle-orm/pg-core/columns/vector_extension/vector.js","../../../node_modules/drizzle-orm/pg-core/table.js","../../../node_modules/drizzle-orm/pg-core/columns/smallint.js","../../../node_modules/drizzle-orm/pg-core/columns/line.js","../../../node_modules/drizzle-orm/pg-core/columns/custom.js","../../../node_modules/drizzle-orm/pg-core/columns/date.common.js","../../../node_modules/drizzle-orm/pg-core/columns/text.js","../../../node_modules/drizzle-orm/pg-core/columns/uuid.js","../../../node_modules/drizzle-orm/pg-core/columns/bigserial.js","../../../node_modules/drizzle-orm/pg-core/columns/varchar.js","../../../node_modules/drizzle-orm/pg-core/columns/numeric.js","../../../node_modules/drizzle-orm/pg-core/columns/point.js","../../../node_modules/drizzle-orm/pg-core/columns/vector_extension/bit.js","../../../node_modules/drizzle-orm/sqlite-core/columns/blob.js","../../../node_modules/drizzle-orm/sqlite-core/columns/custom.js","../../../node_modules/drizzle-orm/sqlite-core/columns/numeric.js","../../../node_modules/drizzle-orm/pg-core/columns/char.js","../../../node_modules/drizzle-orm/sqlite-core/columns/text.js","../../../node_modules/drizzle-orm/sqlite-core/table.js","../../../node_modules/drizzle-orm/pg-core/columns/integer.js","../../../node_modules/drizzle-orm/pg-core/columns/interval.js","../../../node_modules/drizzle-orm/pg-core/columns/vector_extension/halfvec.js","../../../node_modules/drizzle-orm/pg-core/columns/date.js","../../../node_modules/drizzle-orm/pg-core/columns/time.js","../../../node_modules/drizzle-orm/pg-core/columns/bigint.js","../../../node_modules/drizzle-orm/sqlite-core/columns/integer.js","../../../node_modules/drizzle-orm/pg-core/columns/timestamp.js","../../../node_modules/drizzle-orm/pg-core/columns/postgis_extension/geometry.js","../../../node_modules/drizzle-orm/sqlite-core/query-builders/query-builder.js","../../../node_modules/drizzle-orm/alias.js","../../../node_modules/drizzle-orm/sqlite-core/query-builders/query.js","../../../node_modules/drizzle-orm/sqlite-core/columns/common.js","../../../node_modules/drizzle-orm/sqlite-core/session.js","../../../node_modules/drizzle-orm/selection-proxy.js","../../../node_modules/drizzle-orm/utils.js","../../../node_modules/drizzle-orm/sqlite-core/columns/all.js","../../../node_modules/drizzle-orm/pg-core/columns/common.js","../../../node_modules/drizzle-orm/sql/sql.js","../../../node_modules/drizzle-orm/sqlite-core/query-builders/delete.js","../../../node_modules/drizzle-orm/sqlite-core/query-builders/insert.js","../../../node_modules/drizzle-orm/better-sqlite3/session.js","../../../node_modules/drizzle-orm/better-sqlite3/driver.js","../../../node_modules/drizzle-orm/sqlite-core/utils.js","../../../node_modules/drizzle-orm/sql/expressions/conditions.js","../../../node_modules/drizzle-orm/sqlite-core/query-builders/update.js","../../../node_modules/drizzle-orm/sqlite-core/db.js","../../../node_modules/drizzle-orm/sqlite-core/query-builders/select.js","../../../node_modules/drizzle-orm/sqlite-core/dialect.js","../../../node_modules/drizzle-orm/relations.js","../../../node_modules/drizzle-orm/pg-core/columns/all.js"],"sourcesContent":["const TableName = Symbol.for(\"drizzle:Name\");\nexport {\n TableName\n};\n//# sourceMappingURL=table.utils.js.map","function iife(fn, ...args) {\n return fn(...args);\n}\nexport {\n iife\n};\n//# sourceMappingURL=tracing-utils.js.map","function parsePgArrayValue(arrayString, startFrom, inQuotes) {\n for (let i = startFrom; i < arrayString.length; i++) {\n const char = arrayString[i];\n if (char === \"\\\\\") {\n i++;\n continue;\n }\n if (char === '\"') {\n return [arrayString.slice(startFrom, i).replace(/\\\\/g, \"\"), i + 1];\n }\n if (inQuotes) {\n continue;\n }\n if (char === \",\" || char === \"}\") {\n return [arrayString.slice(startFrom, i).replace(/\\\\/g, \"\"), i];\n }\n }\n return [arrayString.slice(startFrom).replace(/\\\\/g, \"\"), arrayString.length];\n}\nfunction parsePgNestedArray(arrayString, startFrom = 0) {\n const result = [];\n let i = startFrom;\n let lastCharIsComma = false;\n while (i < arrayString.length) {\n const char = arrayString[i];\n if (char === \",\") {\n if (lastCharIsComma || i === startFrom) {\n result.push(\"\");\n }\n lastCharIsComma = true;\n i++;\n continue;\n }\n lastCharIsComma = false;\n if (char === \"\\\\\") {\n i += 2;\n continue;\n }\n if (char === '\"') {\n const [value2, startFrom2] = parsePgArrayValue(arrayString, i + 1, true);\n result.push(value2);\n i = startFrom2;\n continue;\n }\n if (char === \"}\") {\n return [result, i + 1];\n }\n if (char === \"{\") {\n const [value2, startFrom2] = parsePgNestedArray(arrayString, i + 1);\n result.push(value2);\n i = startFrom2;\n continue;\n }\n const [value, newStartFrom] = parsePgArrayValue(arrayString, i, false);\n result.push(value);\n i = newStartFrom;\n }\n return [result, i];\n}\nfunction parsePgArray(arrayString) {\n const [result] = parsePgNestedArray(arrayString, 1);\n return result;\n}\nfunction makePgArray(array) {\n return `{${array.map((item) => {\n if (Array.isArray(item)) {\n return makePgArray(item);\n }\n if (typeof item === \"string\") {\n return `\"${item.replace(/\\\\/g, \"\\\\\\\\\").replace(/\"/g, '\\\\\"')}\"`;\n }\n return `${item}`;\n }).join(\",\")}}`;\n}\nexport {\n makePgArray,\n parsePgArray,\n parsePgNestedArray\n};\n//# sourceMappingURL=array.js.map","import { readFileSync, existsSync, readdirSync } from 'fs';\nimport { join, resolve } from 'path';\nimport { homedir } from 'os';\nimport Database from 'better-sqlite3';\nimport { eq } from 'drizzle-orm';\nimport { drizzle } from 'drizzle-orm/better-sqlite3';\nimport { sqliteTable, text } from 'drizzle-orm/sqlite-core';\n\nexport interface KitchenPluginManifest {\n id: string;\n name: string;\n teamTypes: string[];\n tabs: {\n id: string;\n label: string;\n icon: string;\n bundle: string;\n }[];\n apiRoutes?: string;\n migrations?: string;\n}\n\nexport interface KitchenPluginContext {\n db: ReturnType<typeof drizzle>;\n teamDir: string;\n encrypt(data: unknown): string;\n decrypt(blob: string): unknown;\n registerCron(opts: { schedule: string; handler: string }): void;\n getConfig(key: string): string | null;\n setConfig(key: string, value: string): void;\n}\n\n// Plugin config table schema\nconst configTable = sqliteTable('config', {\n key: text('key').primaryKey(),\n value: text('value'),\n updatedAt: text('updated_at').default('CURRENT_TIMESTAMP'),\n});\n\n// Cache for discovered plugins\nlet cachedPlugins: Map<string, KitchenPluginManifest> | null = null;\n\n/**\n * The canonical location for Kitchen plugins installed via CLI.\n */\nexport function getPluginsDir(): string {\n return join(homedir(), '.openclaw', 'kitchen', 'plugins');\n}\n\n/**\n * Scan a node_modules directory for Kitchen plugin manifests.\n */\nfunction scanNodeModules(nodeModulesPath: string, plugins: Map<string, KitchenPluginManifest>): void {\n if (!existsSync(nodeModulesPath)) return;\n\n let entries: string[];\n try {\n entries = readdirSync(nodeModulesPath);\n } catch {\n return;\n }\n\n for (const entry of entries) {\n const entryPath = join(nodeModulesPath, entry);\n\n if (entry.startsWith('@')) {\n // Scoped package - check subdirectories\n try {\n const scopedEntries = readdirSync(entryPath);\n for (const scopedEntry of scopedEntries) {\n const packagePath = join(entryPath, scopedEntry);\n const manifest = loadPluginManifest(packagePath);\n if (manifest && !plugins.has(manifest.id)) {\n plugins.set(manifest.id, manifest);\n }\n }\n } catch {\n // Ignore errors reading scoped directories\n }\n } else {\n // Regular package\n const manifest = loadPluginManifest(entryPath);\n if (manifest && !plugins.has(manifest.id)) {\n plugins.set(manifest.id, manifest);\n }\n }\n }\n}\n\n/**\n * Discover all Kitchen plugins.\n *\n * Search order (first match wins per plugin id):\n * 1. ~/.openclaw/kitchen/plugins/node_modules/ (CLI-installed plugins)\n * 2. CWD/node_modules/ (dev / legacy fallback)\n */\nexport function discoverKitchenPlugins(): Map<string, KitchenPluginManifest> {\n if (cachedPlugins) return cachedPlugins;\n\n const plugins = new Map<string, KitchenPluginManifest>();\n\n // Primary: dedicated plugins directory\n const pluginsDir = getPluginsDir();\n scanNodeModules(join(pluginsDir, 'node_modules'), plugins);\n\n // Fallback: CWD node_modules (useful for dev mode)\n scanNodeModules(resolve('node_modules'), plugins);\n\n cachedPlugins = plugins;\n return plugins;\n}\n\n/**\n * Load plugin manifest from a package directory\n */\nfunction loadPluginManifest(packagePath: string): KitchenPluginManifest | null {\n try {\n const packageJsonPath = join(packagePath, 'package.json');\n if (!existsSync(packageJsonPath)) return null;\n\n const packageJson = JSON.parse(readFileSync(packageJsonPath, 'utf8'));\n const kitchenPlugin = packageJson.kitchenPlugin;\n\n if (!kitchenPlugin || typeof kitchenPlugin !== 'object') return null;\n\n // Validate required fields\n if (!kitchenPlugin.id || !kitchenPlugin.name || !Array.isArray(kitchenPlugin.teamTypes)) {\n console.warn(`Invalid Kitchen plugin manifest in ${packagePath}`);\n return null;\n }\n\n // Validate and resolve bundle paths\n const tabs = Array.isArray(kitchenPlugin.tabs) ? kitchenPlugin.tabs : [];\n for (const tab of tabs) {\n if (tab.bundle && !existsSync(join(packagePath, tab.bundle))) {\n console.warn(`Plugin ${kitchenPlugin.id}: bundle not found at ${tab.bundle}`);\n return null;\n }\n }\n\n return {\n id: String(kitchenPlugin.id),\n name: String(kitchenPlugin.name),\n teamTypes: kitchenPlugin.teamTypes as string[],\n tabs: tabs.map((tab: Record<string, unknown>) => ({\n id: String(tab.id || ''),\n label: String(tab.label || ''),\n icon: String(tab.icon || 'folder'),\n bundle: resolve(packagePath, String(tab.bundle || '')),\n })),\n apiRoutes: kitchenPlugin.apiRoutes ? resolve(packagePath, String(kitchenPlugin.apiRoutes)) : undefined,\n migrations: kitchenPlugin.migrations ? resolve(packagePath, String(kitchenPlugin.migrations)) : undefined,\n };\n } catch (error) {\n console.warn(`Failed to load plugin manifest from ${packagePath}:`, error);\n return null;\n }\n}\n\n/**\n * Create isolated SQLite database for a plugin\n */\nexport function createPluginDb(pluginId: string): ReturnType<typeof drizzle> {\n const dbDir = resolve(process.env.HOME || '.', '.openclaw', 'kitchen', 'plugins', pluginId);\n const dbPath = join(dbDir, `${pluginId}.db`);\n\n // Ensure directory exists\n try {\n try {\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const fs = require('fs');\n fs.mkdirSync(dbDir, { recursive: true });\n } catch {\n // Directory might already exist\n }\n } catch {\n // Directory might already exist\n }\n\n const sqlite = new Database(dbPath);\n const db = drizzle(sqlite, { schema: { config: configTable } });\n\n // Create config table if it doesn't exist\n sqlite.exec(`\n CREATE TABLE IF NOT EXISTS config (\n key TEXT PRIMARY KEY,\n value TEXT,\n updated_at TEXT DEFAULT CURRENT_TIMESTAMP\n )\n `);\n\n return db;\n}\n\n/**\n * Create plugin context for a given plugin\n */\nexport function createPluginContext(\n pluginId: string,\n teamDir: string,\n authToken: string\n): KitchenPluginContext {\n const db = createPluginDb(pluginId);\n\n // Simple AES-256-GCM encryption using auth token\n const encrypt = (data: unknown): string => {\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const crypto = require('crypto');\n const key = crypto.pbkdf2Sync(authToken, 'kitchen-plugin-salt', 100000, 32, 'sha256');\n const iv = crypto.randomBytes(16);\n const cipher = crypto.createCipher('aes-256-gcm', key);\n cipher.setAAD(iv);\n \n let encrypted = cipher.update(JSON.stringify(data), 'utf8', 'base64');\n encrypted += cipher.final('base64');\n const authTag = cipher.getAuthTag();\n \n return Buffer.concat([iv, authTag, Buffer.from(encrypted, 'base64')]).toString('base64');\n };\n\n const decrypt = (blob: string): unknown => {\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const crypto = require('crypto');\n const key = crypto.pbkdf2Sync(authToken, 'kitchen-plugin-salt', 100000, 32, 'sha256');\n const buffer = Buffer.from(blob, 'base64');\n \n const iv = buffer.subarray(0, 16);\n const authTag = buffer.subarray(16, 32);\n const encrypted = buffer.subarray(32).toString('base64');\n \n const decipher = crypto.createDecipher('aes-256-gcm', key);\n decipher.setAAD(iv);\n decipher.setAuthTag(authTag);\n \n let decrypted = decipher.update(encrypted, 'base64', 'utf8');\n decrypted += decipher.final('utf8');\n \n return JSON.parse(decrypted);\n };\n\n const registerCron = (opts: { schedule: string; handler: string }): void => {\n // Integration with OpenClaw cron system will be implemented in future versions\n console.log(`Plugin ${pluginId} registered cron:`, opts);\n };\n\n const getConfig = (key: string): string | null => {\n const result = db.select().from(configTable).where(eq(configTable.key, key)).get();\n return result?.value || null;\n };\n\n const setConfig = (key: string, value: string): void => {\n db.insert(configTable)\n .values({ key, value, updatedAt: new Date().toISOString() })\n .onConflictDoUpdate({ target: configTable.key, set: { value, updatedAt: new Date().toISOString() } });\n };\n\n return {\n db,\n teamDir,\n encrypt,\n decrypt,\n registerCron,\n getConfig,\n setConfig,\n };\n}\n\n/**\n * Filter plugins by team type\n */\nexport function getPluginsForTeamType(teamType: string): KitchenPluginManifest[] {\n const plugins = discoverKitchenPlugins();\n return Array.from(plugins.values()).filter(plugin =>\n plugin.teamTypes.includes(teamType)\n );\n}\n\n/**\n * Clear plugin cache (for testing)\n */\nexport function clearPluginCache(): void {\n cachedPlugins = null;\n}","// package.json\nvar version = \"0.45.2\";\n\n// src/version.ts\nvar compatibilityVersion = 10;\nexport {\n compatibilityVersion,\n version as npmVersion\n};\n","const ViewBaseConfig = Symbol.for(\"drizzle:ViewBaseConfig\");\nexport {\n ViewBaseConfig\n};\n//# sourceMappingURL=view-common.js.map","function hexToBytes(hex) {\n const bytes = [];\n for (let c = 0; c < hex.length; c += 2) {\n bytes.push(Number.parseInt(hex.slice(c, c + 2), 16));\n }\n return new Uint8Array(bytes);\n}\nfunction bytesToFloat64(bytes, offset) {\n const buffer = new ArrayBuffer(8);\n const view = new DataView(buffer);\n for (let i = 0; i < 8; i++) {\n view.setUint8(i, bytes[offset + i]);\n }\n return view.getFloat64(0, true);\n}\nfunction parseEWKB(hex) {\n const bytes = hexToBytes(hex);\n let offset = 0;\n const byteOrder = bytes[offset];\n offset += 1;\n const view = new DataView(bytes.buffer);\n const geomType = view.getUint32(offset, byteOrder === 1);\n offset += 4;\n let _srid;\n if (geomType & 536870912) {\n _srid = view.getUint32(offset, byteOrder === 1);\n offset += 4;\n }\n if ((geomType & 65535) === 1) {\n const x = bytesToFloat64(bytes, offset);\n offset += 8;\n const y = bytesToFloat64(bytes, offset);\n offset += 8;\n return [x, y];\n }\n throw new Error(\"Unsupported geometry type\");\n}\nexport {\n parseEWKB\n};\n//# sourceMappingURL=utils.js.map","const entityKind = Symbol.for(\"drizzle:entityKind\");\nconst hasOwnEntityKind = Symbol.for(\"drizzle:hasOwnEntityKind\");\nfunction is(value, type) {\n if (!value || typeof value !== \"object\") {\n return false;\n }\n if (value instanceof type) {\n return true;\n }\n if (!Object.prototype.hasOwnProperty.call(type, entityKind)) {\n throw new Error(\n `Class \"${type.name ?? \"<unknown>\"}\" doesn't look like a Drizzle entity. If this is incorrect and the class is provided by Drizzle, please report this as a bug.`\n );\n }\n let cls = Object.getPrototypeOf(value).constructor;\n if (cls) {\n while (cls) {\n if (entityKind in cls && cls[entityKind] === type[entityKind]) {\n return true;\n }\n cls = Object.getPrototypeOf(cls);\n }\n }\n return false;\n}\nexport {\n entityKind,\n hasOwnEntityKind,\n is\n};\n//# sourceMappingURL=entity.js.map","import { entityKind } from \"./entity.js\";\nclass Subquery {\n static [entityKind] = \"Subquery\";\n constructor(sql, fields, alias, isWith = false, usedTables = []) {\n this._ = {\n brand: \"Subquery\",\n sql,\n selectedFields: fields,\n alias,\n isWith,\n usedTables\n };\n }\n // getSQL(): SQL<unknown> {\n // \treturn new SQL([this]);\n // }\n}\nclass WithSubquery extends Subquery {\n static [entityKind] = \"WithSubquery\";\n}\nexport {\n Subquery,\n WithSubquery\n};\n//# sourceMappingURL=subquery.js.map","import { entityKind } from \"../../entity.js\";\nclass Cache {\n static [entityKind] = \"Cache\";\n}\nclass NoopCache extends Cache {\n strategy() {\n return \"all\";\n }\n static [entityKind] = \"NoopCache\";\n async get(_key) {\n return void 0;\n }\n async put(_hashedQuery, _response, _tables, _config) {\n }\n async onMutate(_params) {\n }\n}\nasync function hashQuery(sql, params) {\n const dataToHash = `${sql}-${JSON.stringify(params)}`;\n const encoder = new TextEncoder();\n const data = encoder.encode(dataToHash);\n const hashBuffer = await crypto.subtle.digest(\"SHA-256\", data);\n const hashArray = [...new Uint8Array(hashBuffer)];\n const hashHex = hashArray.map((b) => b.toString(16).padStart(2, \"0\")).join(\"\");\n return hashHex;\n}\nexport {\n Cache,\n NoopCache,\n hashQuery\n};\n//# sourceMappingURL=cache.js.map","import { entityKind } from \"./entity.js\";\nclass ColumnBuilder {\n static [entityKind] = \"ColumnBuilder\";\n config;\n constructor(name, dataType, columnType) {\n this.config = {\n name,\n keyAsName: name === \"\",\n notNull: false,\n default: void 0,\n hasDefault: false,\n primaryKey: false,\n isUnique: false,\n uniqueName: void 0,\n uniqueType: void 0,\n dataType,\n columnType,\n generated: void 0\n };\n }\n /**\n * Changes the data type of the column. Commonly used with `json` columns. Also, useful for branded types.\n *\n * @example\n * ```ts\n * const users = pgTable('users', {\n * \tid: integer('id').$type<UserId>().primaryKey(),\n * \tdetails: json('details').$type<UserDetails>().notNull(),\n * });\n * ```\n */\n $type() {\n return this;\n }\n /**\n * Adds a `not null` clause to the column definition.\n *\n * Affects the `select` model of the table - columns *without* `not null` will be nullable on select.\n */\n notNull() {\n this.config.notNull = true;\n return this;\n }\n /**\n * Adds a `default <value>` clause to the column definition.\n *\n * Affects the `insert` model of the table - columns *with* `default` are optional on insert.\n *\n * If you need to set a dynamic default value, use {@link $defaultFn} instead.\n */\n default(value) {\n this.config.default = value;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Adds a dynamic default value to the column.\n * The function will be called when the row is inserted, and the returned value will be used as the column value.\n *\n * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n */\n $defaultFn(fn) {\n this.config.defaultFn = fn;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Alias for {@link $defaultFn}.\n */\n $default = this.$defaultFn;\n /**\n * Adds a dynamic update value to the column.\n * The function will be called when the row is updated, and the returned value will be used as the column value if none is provided.\n * If no `default` (or `$defaultFn`) value is provided, the function will be called when the row is inserted as well, and the returned value will be used as the column value.\n *\n * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n */\n $onUpdateFn(fn) {\n this.config.onUpdateFn = fn;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Alias for {@link $onUpdateFn}.\n */\n $onUpdate = this.$onUpdateFn;\n /**\n * Adds a `primary key` clause to the column definition. This implicitly makes the column `not null`.\n *\n * In SQLite, `integer primary key` implicitly makes the column auto-incrementing.\n */\n primaryKey() {\n this.config.primaryKey = true;\n this.config.notNull = true;\n return this;\n }\n /** @internal Sets the name of the column to the key within the table definition if a name was not given. */\n setName(name) {\n if (this.config.name !== \"\") return;\n this.config.name = name;\n }\n}\nexport {\n ColumnBuilder\n};\n//# sourceMappingURL=column-builder.js.map","import { entityKind } from \"./entity.js\";\nclass ConsoleLogWriter {\n static [entityKind] = \"ConsoleLogWriter\";\n write(message) {\n console.log(message);\n }\n}\nclass DefaultLogger {\n static [entityKind] = \"DefaultLogger\";\n writer;\n constructor(config) {\n this.writer = config?.writer ?? new ConsoleLogWriter();\n }\n logQuery(query, params) {\n const stringifiedParams = params.map((p) => {\n try {\n return JSON.stringify(p);\n } catch {\n return String(p);\n }\n });\n const paramsStr = stringifiedParams.length ? ` -- params: [${stringifiedParams.join(\", \")}]` : \"\";\n this.writer.write(`Query: ${query}${paramsStr}`);\n }\n}\nclass NoopLogger {\n static [entityKind] = \"NoopLogger\";\n logQuery() {\n }\n}\nexport {\n ConsoleLogWriter,\n DefaultLogger,\n NoopLogger\n};\n//# sourceMappingURL=logger.js.map","import { entityKind } from \"./entity.js\";\nclass Column {\n constructor(table, config) {\n this.table = table;\n this.config = config;\n this.name = config.name;\n this.keyAsName = config.keyAsName;\n this.notNull = config.notNull;\n this.default = config.default;\n this.defaultFn = config.defaultFn;\n this.onUpdateFn = config.onUpdateFn;\n this.hasDefault = config.hasDefault;\n this.primary = config.primaryKey;\n this.isUnique = config.isUnique;\n this.uniqueName = config.uniqueName;\n this.uniqueType = config.uniqueType;\n this.dataType = config.dataType;\n this.columnType = config.columnType;\n this.generated = config.generated;\n this.generatedIdentity = config.generatedIdentity;\n }\n static [entityKind] = \"Column\";\n name;\n keyAsName;\n primary;\n notNull;\n default;\n defaultFn;\n onUpdateFn;\n hasDefault;\n isUnique;\n uniqueName;\n uniqueType;\n dataType;\n columnType;\n enumValues = void 0;\n generated = void 0;\n generatedIdentity = void 0;\n config;\n mapFromDriverValue(value) {\n return value;\n }\n mapToDriverValue(value) {\n return value;\n }\n // ** @internal */\n shouldDisableInsert() {\n return this.config.generated !== void 0 && this.config.generated.type !== \"byDefault\";\n }\n}\nexport {\n Column\n};\n//# sourceMappingURL=column.js.map","import { sql } from \"../sql.js\";\nfunction asc(column) {\n return sql`${column} asc`;\n}\nfunction desc(column) {\n return sql`${column} desc`;\n}\nexport {\n asc,\n desc\n};\n//# sourceMappingURL=select.js.map","import { entityKind } from \"./entity.js\";\nclass DrizzleError extends Error {\n static [entityKind] = \"DrizzleError\";\n constructor({ message, cause }) {\n super(message);\n this.name = \"DrizzleError\";\n this.cause = cause;\n }\n}\nclass DrizzleQueryError extends Error {\n constructor(query, params, cause) {\n super(`Failed query: ${query}\nparams: ${params}`);\n this.query = query;\n this.params = params;\n this.cause = cause;\n Error.captureStackTrace(this, DrizzleQueryError);\n if (cause) this.cause = cause;\n }\n}\nclass TransactionRollbackError extends DrizzleError {\n static [entityKind] = \"TransactionRollbackError\";\n constructor() {\n super({ message: \"Rollback\" });\n }\n}\nexport {\n DrizzleError,\n DrizzleQueryError,\n TransactionRollbackError\n};\n//# sourceMappingURL=errors.js.map","import { entityKind } from \"../entity.js\";\nclass TypedQueryBuilder {\n static [entityKind] = \"TypedQueryBuilder\";\n /** @internal */\n getSelectedFields() {\n return this._.selectedFields;\n }\n}\nexport {\n TypedQueryBuilder\n};\n//# sourceMappingURL=query-builder.js.map","import { entityKind } from \"./entity.js\";\nclass QueryPromise {\n static [entityKind] = \"QueryPromise\";\n [Symbol.toStringTag] = \"QueryPromise\";\n catch(onRejected) {\n return this.then(void 0, onRejected);\n }\n finally(onFinally) {\n return this.then(\n (value) => {\n onFinally?.();\n return value;\n },\n (reason) => {\n onFinally?.();\n throw reason;\n }\n );\n }\n then(onFulfilled, onRejected) {\n return this.execute().then(onFulfilled, onRejected);\n }\n}\nexport {\n QueryPromise\n};\n//# sourceMappingURL=query-promise.js.map","import { entityKind } from \"../entity.js\";\nclass CheckBuilder {\n constructor(name, value) {\n this.name = name;\n this.value = value;\n }\n static [entityKind] = \"SQLiteCheckBuilder\";\n brand;\n build(table) {\n return new Check(table, this);\n }\n}\nclass Check {\n constructor(table, builder) {\n this.table = table;\n this.name = builder.name;\n this.value = builder.value;\n }\n static [entityKind] = \"SQLiteCheck\";\n name;\n value;\n}\nfunction check(name, value) {\n return new CheckBuilder(name, value);\n}\nexport {\n Check,\n CheckBuilder,\n check\n};\n//# sourceMappingURL=checks.js.map","import { entityKind } from \"../entity.js\";\nclass IndexBuilderOn {\n constructor(name, unique) {\n this.name = name;\n this.unique = unique;\n }\n static [entityKind] = \"SQLiteIndexBuilderOn\";\n on(...columns) {\n return new IndexBuilder(this.name, columns, this.unique);\n }\n}\nclass IndexBuilder {\n static [entityKind] = \"SQLiteIndexBuilder\";\n /** @internal */\n config;\n constructor(name, columns, unique) {\n this.config = {\n name,\n columns,\n unique,\n where: void 0\n };\n }\n /**\n * Condition for partial index.\n */\n where(condition) {\n this.config.where = condition;\n return this;\n }\n /** @internal */\n build(table) {\n return new Index(this.config, table);\n }\n}\nclass Index {\n static [entityKind] = \"SQLiteIndex\";\n config;\n constructor(config, table) {\n this.config = { ...config, table };\n }\n}\nfunction index(name) {\n return new IndexBuilderOn(name, false);\n}\nfunction uniqueIndex(name) {\n return new IndexBuilderOn(name, true);\n}\nexport {\n Index,\n IndexBuilder,\n IndexBuilderOn,\n index,\n uniqueIndex\n};\n//# sourceMappingURL=indexes.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgBooleanBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgBooleanBuilder\";\n constructor(name) {\n super(name, \"boolean\", \"PgBoolean\");\n }\n /** @internal */\n build(table) {\n return new PgBoolean(table, this.config);\n }\n}\nclass PgBoolean extends PgColumn {\n static [entityKind] = \"PgBoolean\";\n getSQLType() {\n return \"boolean\";\n }\n}\nfunction boolean(name) {\n return new PgBooleanBuilder(name ?? \"\");\n}\nexport {\n PgBoolean,\n PgBooleanBuilder,\n boolean\n};\n//# sourceMappingURL=boolean.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgJsonbBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgJsonbBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgJsonb\");\n }\n /** @internal */\n build(table) {\n return new PgJsonb(table, this.config);\n }\n}\nclass PgJsonb extends PgColumn {\n static [entityKind] = \"PgJsonb\";\n constructor(table, config) {\n super(table, config);\n }\n getSQLType() {\n return \"jsonb\";\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n return value;\n }\n}\nfunction jsonb(name) {\n return new PgJsonbBuilder(name ?? \"\");\n}\nexport {\n PgJsonb,\n PgJsonbBuilder,\n jsonb\n};\n//# sourceMappingURL=jsonb.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgMacaddrBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgMacaddrBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgMacaddr\");\n }\n /** @internal */\n build(table) {\n return new PgMacaddr(table, this.config);\n }\n}\nclass PgMacaddr extends PgColumn {\n static [entityKind] = \"PgMacaddr\";\n getSQLType() {\n return \"macaddr\";\n }\n}\nfunction macaddr(name) {\n return new PgMacaddrBuilder(name ?? \"\");\n}\nexport {\n PgMacaddr,\n PgMacaddrBuilder,\n macaddr\n};\n//# sourceMappingURL=macaddr.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgMacaddr8Builder extends PgColumnBuilder {\n static [entityKind] = \"PgMacaddr8Builder\";\n constructor(name) {\n super(name, \"string\", \"PgMacaddr8\");\n }\n /** @internal */\n build(table) {\n return new PgMacaddr8(table, this.config);\n }\n}\nclass PgMacaddr8 extends PgColumn {\n static [entityKind] = \"PgMacaddr8\";\n getSQLType() {\n return \"macaddr8\";\n }\n}\nfunction macaddr8(name) {\n return new PgMacaddr8Builder(name ?? \"\");\n}\nexport {\n PgMacaddr8,\n PgMacaddr8Builder,\n macaddr8\n};\n//# sourceMappingURL=macaddr8.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgCidrBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgCidrBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgCidr\");\n }\n /** @internal */\n build(table) {\n return new PgCidr(table, this.config);\n }\n}\nclass PgCidr extends PgColumn {\n static [entityKind] = \"PgCidr\";\n getSQLType() {\n return \"cidr\";\n }\n}\nfunction cidr(name) {\n return new PgCidrBuilder(name ?? \"\");\n}\nexport {\n PgCidr,\n PgCidrBuilder,\n cidr\n};\n//# sourceMappingURL=cidr.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgDoublePrecisionBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgDoublePrecisionBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgDoublePrecision\");\n }\n /** @internal */\n build(table) {\n return new PgDoublePrecision(\n table,\n this.config\n );\n }\n}\nclass PgDoublePrecision extends PgColumn {\n static [entityKind] = \"PgDoublePrecision\";\n getSQLType() {\n return \"double precision\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n return Number.parseFloat(value);\n }\n return value;\n }\n}\nfunction doublePrecision(name) {\n return new PgDoublePrecisionBuilder(name ?? \"\");\n}\nexport {\n PgDoublePrecision,\n PgDoublePrecisionBuilder,\n doublePrecision\n};\n//# sourceMappingURL=double-precision.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgEnumObjectColumnBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgEnumObjectColumnBuilder\";\n constructor(name, enumInstance) {\n super(name, \"string\", \"PgEnumObjectColumn\");\n this.config.enum = enumInstance;\n }\n /** @internal */\n build(table) {\n return new PgEnumObjectColumn(\n table,\n this.config\n );\n }\n}\nclass PgEnumObjectColumn extends PgColumn {\n static [entityKind] = \"PgEnumObjectColumn\";\n enum;\n enumValues = this.config.enum.enumValues;\n constructor(table, config) {\n super(table, config);\n this.enum = config.enum;\n }\n getSQLType() {\n return this.enum.enumName;\n }\n}\nconst isPgEnumSym = Symbol.for(\"drizzle:isPgEnum\");\nfunction isPgEnum(obj) {\n return !!obj && typeof obj === \"function\" && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\nclass PgEnumColumnBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgEnumColumnBuilder\";\n constructor(name, enumInstance) {\n super(name, \"string\", \"PgEnumColumn\");\n this.config.enum = enumInstance;\n }\n /** @internal */\n build(table) {\n return new PgEnumColumn(\n table,\n this.config\n );\n }\n}\nclass PgEnumColumn extends PgColumn {\n static [entityKind] = \"PgEnumColumn\";\n enum = this.config.enum;\n enumValues = this.config.enum.enumValues;\n constructor(table, config) {\n super(table, config);\n this.enum = config.enum;\n }\n getSQLType() {\n return this.enum.enumName;\n }\n}\nfunction pgEnum(enumName, input) {\n return Array.isArray(input) ? pgEnumWithSchema(enumName, [...input], void 0) : pgEnumObjectWithSchema(enumName, input, void 0);\n}\nfunction pgEnumWithSchema(enumName, values, schema) {\n const enumInstance = Object.assign(\n (name) => new PgEnumColumnBuilder(name ?? \"\", enumInstance),\n {\n enumName,\n enumValues: values,\n schema,\n [isPgEnumSym]: true\n }\n );\n return enumInstance;\n}\nfunction pgEnumObjectWithSchema(enumName, values, schema) {\n const enumInstance = Object.assign(\n (name) => new PgEnumObjectColumnBuilder(name ?? \"\", enumInstance),\n {\n enumName,\n enumValues: Object.values(values),\n schema,\n [isPgEnumSym]: true\n }\n );\n return enumInstance;\n}\nexport {\n PgEnumColumn,\n PgEnumColumnBuilder,\n PgEnumObjectColumn,\n PgEnumObjectColumnBuilder,\n isPgEnum,\n pgEnum,\n pgEnumObjectWithSchema,\n pgEnumWithSchema\n};\n//# sourceMappingURL=enum.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgRealBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgRealBuilder\";\n constructor(name, length) {\n super(name, \"number\", \"PgReal\");\n this.config.length = length;\n }\n /** @internal */\n build(table) {\n return new PgReal(table, this.config);\n }\n}\nclass PgReal extends PgColumn {\n static [entityKind] = \"PgReal\";\n constructor(table, config) {\n super(table, config);\n }\n getSQLType() {\n return \"real\";\n }\n mapFromDriverValue = (value) => {\n if (typeof value === \"string\") {\n return Number.parseFloat(value);\n }\n return value;\n };\n}\nfunction real(name) {\n return new PgRealBuilder(name ?? \"\");\n}\nexport {\n PgReal,\n PgRealBuilder,\n real\n};\n//# sourceMappingURL=real.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgSerialBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgSerialBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgSerial\");\n this.config.hasDefault = true;\n this.config.notNull = true;\n }\n /** @internal */\n build(table) {\n return new PgSerial(table, this.config);\n }\n}\nclass PgSerial extends PgColumn {\n static [entityKind] = \"PgSerial\";\n getSQLType() {\n return \"serial\";\n }\n}\nfunction serial(name) {\n return new PgSerialBuilder(name ?? \"\");\n}\nexport {\n PgSerial,\n PgSerialBuilder,\n serial\n};\n//# sourceMappingURL=serial.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgSmallSerialBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgSmallSerialBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgSmallSerial\");\n this.config.hasDefault = true;\n this.config.notNull = true;\n }\n /** @internal */\n build(table) {\n return new PgSmallSerial(\n table,\n this.config\n );\n }\n}\nclass PgSmallSerial extends PgColumn {\n static [entityKind] = \"PgSmallSerial\";\n getSQLType() {\n return \"smallserial\";\n }\n}\nfunction smallserial(name) {\n return new PgSmallSerialBuilder(name ?? \"\");\n}\nexport {\n PgSmallSerial,\n PgSmallSerialBuilder,\n smallserial\n};\n//# sourceMappingURL=smallserial.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumnBuilder } from \"./common.js\";\nclass PgIntColumnBaseBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgIntColumnBaseBuilder\";\n generatedAlwaysAsIdentity(sequence) {\n if (sequence) {\n const { name, ...options } = sequence;\n this.config.generatedIdentity = {\n type: \"always\",\n sequenceName: name,\n sequenceOptions: options\n };\n } else {\n this.config.generatedIdentity = {\n type: \"always\"\n };\n }\n this.config.hasDefault = true;\n this.config.notNull = true;\n return this;\n }\n generatedByDefaultAsIdentity(sequence) {\n if (sequence) {\n const { name, ...options } = sequence;\n this.config.generatedIdentity = {\n type: \"byDefault\",\n sequenceName: name,\n sequenceOptions: options\n };\n } else {\n this.config.generatedIdentity = {\n type: \"byDefault\"\n };\n }\n this.config.hasDefault = true;\n this.config.notNull = true;\n return this;\n }\n}\nexport {\n PgIntColumnBaseBuilder\n};\n//# sourceMappingURL=int.common.js.map","import { entityKind } from \"../entity.js\";\nimport { PgTable } from \"./table.js\";\nfunction primaryKey(...config) {\n if (config[0].columns) {\n return new PrimaryKeyBuilder(config[0].columns, config[0].name);\n }\n return new PrimaryKeyBuilder(config);\n}\nclass PrimaryKeyBuilder {\n static [entityKind] = \"PgPrimaryKeyBuilder\";\n /** @internal */\n columns;\n /** @internal */\n name;\n constructor(columns, name) {\n this.columns = columns;\n this.name = name;\n }\n /** @internal */\n build(table) {\n return new PrimaryKey(table, this.columns, this.name);\n }\n}\nclass PrimaryKey {\n constructor(table, columns, name) {\n this.table = table;\n this.columns = columns;\n this.name = name;\n }\n static [entityKind] = \"PgPrimaryKey\";\n columns;\n name;\n getName() {\n return this.name ?? `${this.table[PgTable.Symbol.Name]}_${this.columns.map((column) => column.name).join(\"_\")}_pk`;\n }\n}\nexport {\n PrimaryKey,\n PrimaryKeyBuilder,\n primaryKey\n};\n//# sourceMappingURL=primary-keys.js.map","import { entityKind } from \"./entity.js\";\nimport { TableName } from \"./table.utils.js\";\nconst Schema = Symbol.for(\"drizzle:Schema\");\nconst Columns = Symbol.for(\"drizzle:Columns\");\nconst ExtraConfigColumns = Symbol.for(\"drizzle:ExtraConfigColumns\");\nconst OriginalName = Symbol.for(\"drizzle:OriginalName\");\nconst BaseName = Symbol.for(\"drizzle:BaseName\");\nconst IsAlias = Symbol.for(\"drizzle:IsAlias\");\nconst ExtraConfigBuilder = Symbol.for(\"drizzle:ExtraConfigBuilder\");\nconst IsDrizzleTable = Symbol.for(\"drizzle:IsDrizzleTable\");\nclass Table {\n static [entityKind] = \"Table\";\n /** @internal */\n static Symbol = {\n Name: TableName,\n Schema,\n OriginalName,\n Columns,\n ExtraConfigColumns,\n BaseName,\n IsAlias,\n ExtraConfigBuilder\n };\n /**\n * @internal\n * Can be changed if the table is aliased.\n */\n [TableName];\n /**\n * @internal\n * Used to store the original name of the table, before any aliasing.\n */\n [OriginalName];\n /** @internal */\n [Schema];\n /** @internal */\n [Columns];\n /** @internal */\n [ExtraConfigColumns];\n /**\n * @internal\n * Used to store the table name before the transformation via the `tableCreator` functions.\n */\n [BaseName];\n /** @internal */\n [IsAlias] = false;\n /** @internal */\n [IsDrizzleTable] = true;\n /** @internal */\n [ExtraConfigBuilder] = void 0;\n constructor(name, schema, baseName) {\n this[TableName] = this[OriginalName] = name;\n this[Schema] = schema;\n this[BaseName] = baseName;\n }\n}\nfunction isTable(table) {\n return typeof table === \"object\" && table !== null && IsDrizzleTable in table;\n}\nfunction getTableName(table) {\n return table[TableName];\n}\nfunction getTableUniqueName(table) {\n return `${table[Schema] ?? \"public\"}.${table[TableName]}`;\n}\nexport {\n BaseName,\n Columns,\n ExtraConfigBuilder,\n ExtraConfigColumns,\n IsAlias,\n OriginalName,\n Schema,\n Table,\n getTableName,\n getTableUniqueName,\n isTable\n};\n//# sourceMappingURL=table.js.map","import { entityKind } from \"./entity.js\";\nimport { Table } from \"./table.js\";\nfunction toSnakeCase(input) {\n const words = input.replace(/['\\u2019]/g, \"\").match(/[\\da-z]+|[A-Z]+(?![a-z])|[A-Z][\\da-z]+/g) ?? [];\n return words.map((word) => word.toLowerCase()).join(\"_\");\n}\nfunction toCamelCase(input) {\n const words = input.replace(/['\\u2019]/g, \"\").match(/[\\da-z]+|[A-Z]+(?![a-z])|[A-Z][\\da-z]+/g) ?? [];\n return words.reduce((acc, word, i) => {\n const formattedWord = i === 0 ? word.toLowerCase() : `${word[0].toUpperCase()}${word.slice(1)}`;\n return acc + formattedWord;\n }, \"\");\n}\nfunction noopCase(input) {\n return input;\n}\nclass CasingCache {\n static [entityKind] = \"CasingCache\";\n /** @internal */\n cache = {};\n cachedTables = {};\n convert;\n constructor(casing) {\n this.convert = casing === \"snake_case\" ? toSnakeCase : casing === \"camelCase\" ? toCamelCase : noopCase;\n }\n getColumnCasing(column) {\n if (!column.keyAsName) return column.name;\n const schema = column.table[Table.Symbol.Schema] ?? \"public\";\n const tableName = column.table[Table.Symbol.OriginalName];\n const key = `${schema}.${tableName}.${column.name}`;\n if (!this.cache[key]) {\n this.cacheTable(column.table);\n }\n return this.cache[key];\n }\n cacheTable(table) {\n const schema = table[Table.Symbol.Schema] ?? \"public\";\n const tableName = table[Table.Symbol.OriginalName];\n const tableKey = `${schema}.${tableName}`;\n if (!this.cachedTables[tableKey]) {\n for (const column of Object.values(table[Table.Symbol.Columns])) {\n const columnKey = `${tableKey}.${column.name}`;\n this.cache[columnKey] = this.convert(column.name);\n }\n this.cachedTables[tableKey] = true;\n }\n }\n clearCache() {\n this.cache = {};\n this.cachedTables = {};\n }\n}\nexport {\n CasingCache,\n toCamelCase,\n toSnakeCase\n};\n//# sourceMappingURL=casing.js.map","import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nclass ForeignKeyBuilder {\n static [entityKind] = \"SQLiteForeignKeyBuilder\";\n /** @internal */\n reference;\n /** @internal */\n _onUpdate;\n /** @internal */\n _onDelete;\n constructor(config, actions) {\n this.reference = () => {\n const { name, columns, foreignColumns } = config();\n return { name, columns, foreignTable: foreignColumns[0].table, foreignColumns };\n };\n if (actions) {\n this._onUpdate = actions.onUpdate;\n this._onDelete = actions.onDelete;\n }\n }\n onUpdate(action) {\n this._onUpdate = action;\n return this;\n }\n onDelete(action) {\n this._onDelete = action;\n return this;\n }\n /** @internal */\n build(table) {\n return new ForeignKey(table, this);\n }\n}\nclass ForeignKey {\n constructor(table, builder) {\n this.table = table;\n this.reference = builder.reference;\n this.onUpdate = builder._onUpdate;\n this.onDelete = builder._onDelete;\n }\n static [entityKind] = \"SQLiteForeignKey\";\n reference;\n onUpdate;\n onDelete;\n getName() {\n const { name, columns, foreignColumns } = this.reference();\n const columnNames = columns.map((column) => column.name);\n const foreignColumnNames = foreignColumns.map((column) => column.name);\n const chunks = [\n this.table[TableName],\n ...columnNames,\n foreignColumns[0].table[TableName],\n ...foreignColumnNames\n ];\n return name ?? `${chunks.join(\"_\")}_fk`;\n }\n}\nfunction foreignKey(config) {\n function mappedConfig() {\n if (typeof config === \"function\") {\n const { name, columns, foreignColumns } = config();\n return {\n name,\n columns,\n foreignColumns\n };\n }\n return config;\n }\n return new ForeignKeyBuilder(mappedConfig);\n}\nexport {\n ForeignKey,\n ForeignKeyBuilder,\n foreignKey\n};\n//# sourceMappingURL=foreign-keys.js.map","import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nfunction uniqueKeyName(table, columns) {\n return `${table[TableName]}_${columns.join(\"_\")}_unique`;\n}\nfunction unique(name) {\n return new UniqueOnConstraintBuilder(name);\n}\nclass UniqueConstraintBuilder {\n constructor(columns, name) {\n this.name = name;\n this.columns = columns;\n }\n static [entityKind] = \"SQLiteUniqueConstraintBuilder\";\n /** @internal */\n columns;\n /** @internal */\n build(table) {\n return new UniqueConstraint(table, this.columns, this.name);\n }\n}\nclass UniqueOnConstraintBuilder {\n static [entityKind] = \"SQLiteUniqueOnConstraintBuilder\";\n /** @internal */\n name;\n constructor(name) {\n this.name = name;\n }\n on(...columns) {\n return new UniqueConstraintBuilder(columns, this.name);\n }\n}\nclass UniqueConstraint {\n constructor(table, columns, name) {\n this.table = table;\n this.columns = columns;\n this.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n }\n static [entityKind] = \"SQLiteUniqueConstraint\";\n columns;\n name;\n getName() {\n return this.name;\n }\n}\nexport {\n UniqueConstraint,\n UniqueConstraintBuilder,\n UniqueOnConstraintBuilder,\n unique,\n uniqueKeyName\n};\n//# sourceMappingURL=unique-constraint.js.map","import { entityKind } from \"../../entity.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteRealBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteRealBuilder\";\n constructor(name) {\n super(name, \"number\", \"SQLiteReal\");\n }\n /** @internal */\n build(table) {\n return new SQLiteReal(table, this.config);\n }\n}\nclass SQLiteReal extends SQLiteColumn {\n static [entityKind] = \"SQLiteReal\";\n getSQLType() {\n return \"real\";\n }\n}\nfunction real(name) {\n return new SQLiteRealBuilder(name ?? \"\");\n}\nexport {\n SQLiteReal,\n SQLiteRealBuilder,\n real\n};\n//# sourceMappingURL=real.js.map","import { entityKind } from \"../entity.js\";\nimport { View } from \"../sql/sql.js\";\nclass SQLiteViewBase extends View {\n static [entityKind] = \"SQLiteViewBase\";\n}\nexport {\n SQLiteViewBase\n};\n//# sourceMappingURL=view-base.js.map","import { iife } from \"./tracing-utils.js\";\nimport { npmVersion } from \"./version.js\";\nlet otel;\nlet rawTracer;\nconst tracer = {\n startActiveSpan(name, fn) {\n if (!otel) {\n return fn();\n }\n if (!rawTracer) {\n rawTracer = otel.trace.getTracer(\"drizzle-orm\", npmVersion);\n }\n return iife(\n (otel2, rawTracer2) => rawTracer2.startActiveSpan(\n name,\n (span) => {\n try {\n return fn(span);\n } catch (e) {\n span.setStatus({\n code: otel2.SpanStatusCode.ERROR,\n message: e instanceof Error ? e.message : \"Unknown error\"\n // eslint-disable-line no-instanceof/no-instanceof\n });\n throw e;\n } finally {\n span.end();\n }\n }\n ),\n otel,\n rawTracer\n );\n }\n};\nexport {\n tracer\n};\n//# sourceMappingURL=tracing.js.map","import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nclass ForeignKeyBuilder {\n static [entityKind] = \"PgForeignKeyBuilder\";\n /** @internal */\n reference;\n /** @internal */\n _onUpdate = \"no action\";\n /** @internal */\n _onDelete = \"no action\";\n constructor(config, actions) {\n this.reference = () => {\n const { name, columns, foreignColumns } = config();\n return { name, columns, foreignTable: foreignColumns[0].table, foreignColumns };\n };\n if (actions) {\n this._onUpdate = actions.onUpdate;\n this._onDelete = actions.onDelete;\n }\n }\n onUpdate(action) {\n this._onUpdate = action === void 0 ? \"no action\" : action;\n return this;\n }\n onDelete(action) {\n this._onDelete = action === void 0 ? \"no action\" : action;\n return this;\n }\n /** @internal */\n build(table) {\n return new ForeignKey(table, this);\n }\n}\nclass ForeignKey {\n constructor(table, builder) {\n this.table = table;\n this.reference = builder.reference;\n this.onUpdate = builder._onUpdate;\n this.onDelete = builder._onDelete;\n }\n static [entityKind] = \"PgForeignKey\";\n reference;\n onUpdate;\n onDelete;\n getName() {\n const { name, columns, foreignColumns } = this.reference();\n const columnNames = columns.map((column) => column.name);\n const foreignColumnNames = foreignColumns.map((column) => column.name);\n const chunks = [\n this.table[TableName],\n ...columnNames,\n foreignColumns[0].table[TableName],\n ...foreignColumnNames\n ];\n return name ?? `${chunks.join(\"_\")}_fk`;\n }\n}\nfunction foreignKey(config) {\n function mappedConfig() {\n const { name, columns, foreignColumns } = config;\n return {\n name,\n columns,\n foreignColumns\n };\n }\n return new ForeignKeyBuilder(mappedConfig);\n}\nexport {\n ForeignKey,\n ForeignKeyBuilder,\n foreignKey\n};\n//# sourceMappingURL=foreign-keys.js.map","import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nfunction unique(name) {\n return new UniqueOnConstraintBuilder(name);\n}\nfunction uniqueKeyName(table, columns) {\n return `${table[TableName]}_${columns.join(\"_\")}_unique`;\n}\nclass UniqueConstraintBuilder {\n constructor(columns, name) {\n this.name = name;\n this.columns = columns;\n }\n static [entityKind] = \"PgUniqueConstraintBuilder\";\n /** @internal */\n columns;\n /** @internal */\n nullsNotDistinctConfig = false;\n nullsNotDistinct() {\n this.nullsNotDistinctConfig = true;\n return this;\n }\n /** @internal */\n build(table) {\n return new UniqueConstraint(table, this.columns, this.nullsNotDistinctConfig, this.name);\n }\n}\nclass UniqueOnConstraintBuilder {\n static [entityKind] = \"PgUniqueOnConstraintBuilder\";\n /** @internal */\n name;\n constructor(name) {\n this.name = name;\n }\n on(...columns) {\n return new UniqueConstraintBuilder(columns, this.name);\n }\n}\nclass UniqueConstraint {\n constructor(table, columns, nullsNotDistinct, name) {\n this.table = table;\n this.columns = columns;\n this.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n this.nullsNotDistinct = nullsNotDistinct;\n }\n static [entityKind] = \"PgUniqueConstraint\";\n columns;\n name;\n nullsNotDistinct = false;\n getName() {\n return this.name;\n }\n}\nexport {\n UniqueConstraint,\n UniqueConstraintBuilder,\n UniqueOnConstraintBuilder,\n unique,\n uniqueKeyName\n};\n//# sourceMappingURL=unique-constraint.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgInetBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgInetBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgInet\");\n }\n /** @internal */\n build(table) {\n return new PgInet(table, this.config);\n }\n}\nclass PgInet extends PgColumn {\n static [entityKind] = \"PgInet\";\n getSQLType() {\n return \"inet\";\n }\n}\nfunction inet(name) {\n return new PgInetBuilder(name ?? \"\");\n}\nexport {\n PgInet,\n PgInetBuilder,\n inet\n};\n//# sourceMappingURL=inet.js.map","import { entityKind } from \"../entity.js\";\nimport { SQLiteTable } from \"./table.js\";\nfunction primaryKey(...config) {\n if (config[0].columns) {\n return new PrimaryKeyBuilder(config[0].columns, config[0].name);\n }\n return new PrimaryKeyBuilder(config);\n}\nclass PrimaryKeyBuilder {\n static [entityKind] = \"SQLitePrimaryKeyBuilder\";\n /** @internal */\n columns;\n /** @internal */\n name;\n constructor(columns, name) {\n this.columns = columns;\n this.name = name;\n }\n /** @internal */\n build(table) {\n return new PrimaryKey(table, this.columns, this.name);\n }\n}\nclass PrimaryKey {\n constructor(table, columns, name) {\n this.table = table;\n this.columns = columns;\n this.name = name;\n }\n static [entityKind] = \"SQLitePrimaryKey\";\n columns;\n name;\n getName() {\n return this.name ?? `${this.table[SQLiteTable.Symbol.Name]}_${this.columns.map((column) => column.name).join(\"_\")}_pk`;\n }\n}\nexport {\n PrimaryKey,\n PrimaryKeyBuilder,\n primaryKey\n};\n//# sourceMappingURL=primary-keys.js.map","import { entityKind } from \"../../entity.js\";\nimport { SQL, sql } from \"../../sql/sql.js\";\nclass SQLiteCountBuilder extends SQL {\n constructor(params) {\n super(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n this.params = params;\n this.session = params.session;\n this.sql = SQLiteCountBuilder.buildCount(\n params.source,\n params.filters\n );\n }\n sql;\n static [entityKind] = \"SQLiteCountBuilderAsync\";\n [Symbol.toStringTag] = \"SQLiteCountBuilderAsync\";\n session;\n static buildEmbeddedCount(source, filters) {\n return sql`(select count(*) from ${source}${sql.raw(\" where \").if(filters)}${filters})`;\n }\n static buildCount(source, filters) {\n return sql`select count(*) from ${source}${sql.raw(\" where \").if(filters)}${filters}`;\n }\n then(onfulfilled, onrejected) {\n return Promise.resolve(this.session.count(this.sql)).then(\n onfulfilled,\n onrejected\n );\n }\n catch(onRejected) {\n return this.then(void 0, onRejected);\n }\n finally(onFinally) {\n return this.then(\n (value) => {\n onFinally?.();\n return value;\n },\n (reason) => {\n onFinally?.();\n throw reason;\n }\n );\n }\n}\nexport {\n SQLiteCountBuilder\n};\n//# sourceMappingURL=count.js.map","import { entityKind } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nclass SQLiteRaw extends QueryPromise {\n constructor(execute, getSQL, action, dialect, mapBatchResult) {\n super();\n this.execute = execute;\n this.getSQL = getSQL;\n this.dialect = dialect;\n this.mapBatchResult = mapBatchResult;\n this.config = { action };\n }\n static [entityKind] = \"SQLiteRaw\";\n /** @internal */\n config;\n getQuery() {\n return { ...this.dialect.sqlToQuery(this.getSQL()), method: this.config.action };\n }\n mapResult(result, isFromBatch) {\n return isFromBatch ? this.mapBatchResult(result) : result;\n }\n _prepare() {\n return this;\n }\n /** @internal */\n isResponseInArrayMode() {\n return false;\n }\n}\nexport {\n SQLiteRaw\n};\n//# sourceMappingURL=raw.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgJsonBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgJsonBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgJson\");\n }\n /** @internal */\n build(table) {\n return new PgJson(table, this.config);\n }\n}\nclass PgJson extends PgColumn {\n static [entityKind] = \"PgJson\";\n constructor(table, config) {\n super(table, config);\n }\n getSQLType() {\n return \"json\";\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n return value;\n }\n}\nfunction json(name) {\n return new PgJsonBuilder(name ?? \"\");\n}\nexport {\n PgJson,\n PgJsonBuilder,\n json\n};\n//# sourceMappingURL=json.js.map","import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nclass PgSparseVectorBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgSparseVectorBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgSparseVector\");\n this.config.dimensions = config.dimensions;\n }\n /** @internal */\n build(table) {\n return new PgSparseVector(\n table,\n this.config\n );\n }\n}\nclass PgSparseVector extends PgColumn {\n static [entityKind] = \"PgSparseVector\";\n dimensions = this.config.dimensions;\n getSQLType() {\n return `sparsevec(${this.dimensions})`;\n }\n}\nfunction sparsevec(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgSparseVectorBuilder(name, config);\n}\nexport {\n PgSparseVector,\n PgSparseVectorBuilder,\n sparsevec\n};\n//# sourceMappingURL=sparsevec.js.map","import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nclass PgVectorBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgVectorBuilder\";\n constructor(name, config) {\n super(name, \"array\", \"PgVector\");\n this.config.dimensions = config.dimensions;\n }\n /** @internal */\n build(table) {\n return new PgVector(\n table,\n this.config\n );\n }\n}\nclass PgVector extends PgColumn {\n static [entityKind] = \"PgVector\";\n dimensions = this.config.dimensions;\n getSQLType() {\n return `vector(${this.dimensions})`;\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n mapFromDriverValue(value) {\n return value.slice(1, -1).split(\",\").map((v) => Number.parseFloat(v));\n }\n}\nfunction vector(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgVectorBuilder(name, config);\n}\nexport {\n PgVector,\n PgVectorBuilder,\n vector\n};\n//# sourceMappingURL=vector.js.map","import { entityKind } from \"../entity.js\";\nimport { Table } from \"../table.js\";\nimport { getPgColumnBuilders } from \"./columns/all.js\";\nconst InlineForeignKeys = Symbol.for(\"drizzle:PgInlineForeignKeys\");\nconst EnableRLS = Symbol.for(\"drizzle:EnableRLS\");\nclass PgTable extends Table {\n static [entityKind] = \"PgTable\";\n /** @internal */\n static Symbol = Object.assign({}, Table.Symbol, {\n InlineForeignKeys,\n EnableRLS\n });\n /**@internal */\n [InlineForeignKeys] = [];\n /** @internal */\n [EnableRLS] = false;\n /** @internal */\n [Table.Symbol.ExtraConfigBuilder] = void 0;\n /** @internal */\n [Table.Symbol.ExtraConfigColumns] = {};\n}\nfunction pgTableWithSchema(name, columns, extraConfig, schema, baseName = name) {\n const rawTable = new PgTable(name, schema, baseName);\n const parsedColumns = typeof columns === \"function\" ? columns(getPgColumnBuilders()) : columns;\n const builtColumns = Object.fromEntries(\n Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n const colBuilder = colBuilderBase;\n colBuilder.setName(name2);\n const column = colBuilder.build(rawTable);\n rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n return [name2, column];\n })\n );\n const builtColumnsForExtraConfig = Object.fromEntries(\n Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n const colBuilder = colBuilderBase;\n colBuilder.setName(name2);\n const column = colBuilder.buildExtraConfigColumn(rawTable);\n return [name2, column];\n })\n );\n const table = Object.assign(rawTable, builtColumns);\n table[Table.Symbol.Columns] = builtColumns;\n table[Table.Symbol.ExtraConfigColumns] = builtColumnsForExtraConfig;\n if (extraConfig) {\n table[PgTable.Symbol.ExtraConfigBuilder] = extraConfig;\n }\n return Object.assign(table, {\n enableRLS: () => {\n table[PgTable.Symbol.EnableRLS] = true;\n return table;\n }\n });\n}\nconst pgTable = (name, columns, extraConfig) => {\n return pgTableWithSchema(name, columns, extraConfig, void 0);\n};\nfunction pgTableCreator(customizeTableName) {\n return (name, columns, extraConfig) => {\n return pgTableWithSchema(customizeTableName(name), columns, extraConfig, void 0, name);\n };\n}\nexport {\n EnableRLS,\n InlineForeignKeys,\n PgTable,\n pgTable,\n pgTableCreator,\n pgTableWithSchema\n};\n//# sourceMappingURL=table.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgIntColumnBaseBuilder } from \"./int.common.js\";\nclass PgSmallIntBuilder extends PgIntColumnBaseBuilder {\n static [entityKind] = \"PgSmallIntBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgSmallInt\");\n }\n /** @internal */\n build(table) {\n return new PgSmallInt(table, this.config);\n }\n}\nclass PgSmallInt extends PgColumn {\n static [entityKind] = \"PgSmallInt\";\n getSQLType() {\n return \"smallint\";\n }\n mapFromDriverValue = (value) => {\n if (typeof value === \"string\") {\n return Number(value);\n }\n return value;\n };\n}\nfunction smallint(name) {\n return new PgSmallIntBuilder(name ?? \"\");\n}\nexport {\n PgSmallInt,\n PgSmallIntBuilder,\n smallint\n};\n//# sourceMappingURL=smallint.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgLineBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgLineBuilder\";\n constructor(name) {\n super(name, \"array\", \"PgLine\");\n }\n /** @internal */\n build(table) {\n return new PgLineTuple(\n table,\n this.config\n );\n }\n}\nclass PgLineTuple extends PgColumn {\n static [entityKind] = \"PgLine\";\n getSQLType() {\n return \"line\";\n }\n mapFromDriverValue(value) {\n const [a, b, c] = value.slice(1, -1).split(\",\");\n return [Number.parseFloat(a), Number.parseFloat(b), Number.parseFloat(c)];\n }\n mapToDriverValue(value) {\n return `{${value[0]},${value[1]},${value[2]}}`;\n }\n}\nclass PgLineABCBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgLineABCBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgLineABC\");\n }\n /** @internal */\n build(table) {\n return new PgLineABC(\n table,\n this.config\n );\n }\n}\nclass PgLineABC extends PgColumn {\n static [entityKind] = \"PgLineABC\";\n getSQLType() {\n return \"line\";\n }\n mapFromDriverValue(value) {\n const [a, b, c] = value.slice(1, -1).split(\",\");\n return { a: Number.parseFloat(a), b: Number.parseFloat(b), c: Number.parseFloat(c) };\n }\n mapToDriverValue(value) {\n return `{${value.a},${value.b},${value.c}}`;\n }\n}\nfunction line(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (!config?.mode || config.mode === \"tuple\") {\n return new PgLineBuilder(name);\n }\n return new PgLineABCBuilder(name);\n}\nexport {\n PgLineABC,\n PgLineABCBuilder,\n PgLineBuilder,\n PgLineTuple,\n line\n};\n//# sourceMappingURL=line.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgCustomColumnBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgCustomColumnBuilder\";\n constructor(name, fieldConfig, customTypeParams) {\n super(name, \"custom\", \"PgCustomColumn\");\n this.config.fieldConfig = fieldConfig;\n this.config.customTypeParams = customTypeParams;\n }\n /** @internal */\n build(table) {\n return new PgCustomColumn(\n table,\n this.config\n );\n }\n}\nclass PgCustomColumn extends PgColumn {\n static [entityKind] = \"PgCustomColumn\";\n sqlName;\n mapTo;\n mapFrom;\n constructor(table, config) {\n super(table, config);\n this.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n this.mapTo = config.customTypeParams.toDriver;\n this.mapFrom = config.customTypeParams.fromDriver;\n }\n getSQLType() {\n return this.sqlName;\n }\n mapFromDriverValue(value) {\n return typeof this.mapFrom === \"function\" ? this.mapFrom(value) : value;\n }\n mapToDriverValue(value) {\n return typeof this.mapTo === \"function\" ? this.mapTo(value) : value;\n }\n}\nfunction customType(customTypeParams) {\n return (a, b) => {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgCustomColumnBuilder(name, config, customTypeParams);\n };\n}\nexport {\n PgCustomColumn,\n PgCustomColumnBuilder,\n customType\n};\n//# sourceMappingURL=custom.js.map","import { entityKind } from \"../../entity.js\";\nimport { sql } from \"../../sql/sql.js\";\nimport { PgColumnBuilder } from \"./common.js\";\nclass PgDateColumnBaseBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgDateColumnBaseBuilder\";\n defaultNow() {\n return this.default(sql`now()`);\n }\n}\nexport {\n PgDateColumnBaseBuilder\n};\n//# sourceMappingURL=date.common.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgTextBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgTextBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgText\");\n this.config.enumValues = config.enum;\n }\n /** @internal */\n build(table) {\n return new PgText(table, this.config);\n }\n}\nclass PgText extends PgColumn {\n static [entityKind] = \"PgText\";\n enumValues = this.config.enumValues;\n getSQLType() {\n return \"text\";\n }\n}\nfunction text(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgTextBuilder(name, config);\n}\nexport {\n PgText,\n PgTextBuilder,\n text\n};\n//# sourceMappingURL=text.js.map","import { entityKind } from \"../../entity.js\";\nimport { sql } from \"../../sql/sql.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgUUIDBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgUUIDBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgUUID\");\n }\n /**\n * Adds `default gen_random_uuid()` to the column definition.\n */\n defaultRandom() {\n return this.default(sql`gen_random_uuid()`);\n }\n /** @internal */\n build(table) {\n return new PgUUID(table, this.config);\n }\n}\nclass PgUUID extends PgColumn {\n static [entityKind] = \"PgUUID\";\n getSQLType() {\n return \"uuid\";\n }\n}\nfunction uuid(name) {\n return new PgUUIDBuilder(name ?? \"\");\n}\nexport {\n PgUUID,\n PgUUIDBuilder,\n uuid\n};\n//# sourceMappingURL=uuid.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgBigSerial53Builder extends PgColumnBuilder {\n static [entityKind] = \"PgBigSerial53Builder\";\n constructor(name) {\n super(name, \"number\", \"PgBigSerial53\");\n this.config.hasDefault = true;\n this.config.notNull = true;\n }\n /** @internal */\n build(table) {\n return new PgBigSerial53(\n table,\n this.config\n );\n }\n}\nclass PgBigSerial53 extends PgColumn {\n static [entityKind] = \"PgBigSerial53\";\n getSQLType() {\n return \"bigserial\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"number\") {\n return value;\n }\n return Number(value);\n }\n}\nclass PgBigSerial64Builder extends PgColumnBuilder {\n static [entityKind] = \"PgBigSerial64Builder\";\n constructor(name) {\n super(name, \"bigint\", \"PgBigSerial64\");\n this.config.hasDefault = true;\n }\n /** @internal */\n build(table) {\n return new PgBigSerial64(\n table,\n this.config\n );\n }\n}\nclass PgBigSerial64 extends PgColumn {\n static [entityKind] = \"PgBigSerial64\";\n getSQLType() {\n return \"bigserial\";\n }\n // eslint-disable-next-line unicorn/prefer-native-coercion-functions\n mapFromDriverValue(value) {\n return BigInt(value);\n }\n}\nfunction bigserial(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config.mode === \"number\") {\n return new PgBigSerial53Builder(name);\n }\n return new PgBigSerial64Builder(name);\n}\nexport {\n PgBigSerial53,\n PgBigSerial53Builder,\n PgBigSerial64,\n PgBigSerial64Builder,\n bigserial\n};\n//# sourceMappingURL=bigserial.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgVarcharBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgVarcharBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgVarchar\");\n this.config.length = config.length;\n this.config.enumValues = config.enum;\n }\n /** @internal */\n build(table) {\n return new PgVarchar(\n table,\n this.config\n );\n }\n}\nclass PgVarchar extends PgColumn {\n static [entityKind] = \"PgVarchar\";\n length = this.config.length;\n enumValues = this.config.enumValues;\n getSQLType() {\n return this.length === void 0 ? `varchar` : `varchar(${this.length})`;\n }\n}\nfunction varchar(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgVarcharBuilder(name, config);\n}\nexport {\n PgVarchar,\n PgVarcharBuilder,\n varchar\n};\n//# sourceMappingURL=varchar.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgNumericBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgNumericBuilder\";\n constructor(name, precision, scale) {\n super(name, \"string\", \"PgNumeric\");\n this.config.precision = precision;\n this.config.scale = scale;\n }\n /** @internal */\n build(table) {\n return new PgNumeric(table, this.config);\n }\n}\nclass PgNumeric extends PgColumn {\n static [entityKind] = \"PgNumeric\";\n precision;\n scale;\n constructor(table, config) {\n super(table, config);\n this.precision = config.precision;\n this.scale = config.scale;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return value;\n return String(value);\n }\n getSQLType() {\n if (this.precision !== void 0 && this.scale !== void 0) {\n return `numeric(${this.precision}, ${this.scale})`;\n } else if (this.precision === void 0) {\n return \"numeric\";\n } else {\n return `numeric(${this.precision})`;\n }\n }\n}\nclass PgNumericNumberBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgNumericNumberBuilder\";\n constructor(name, precision, scale) {\n super(name, \"number\", \"PgNumericNumber\");\n this.config.precision = precision;\n this.config.scale = scale;\n }\n /** @internal */\n build(table) {\n return new PgNumericNumber(\n table,\n this.config\n );\n }\n}\nclass PgNumericNumber extends PgColumn {\n static [entityKind] = \"PgNumericNumber\";\n precision;\n scale;\n constructor(table, config) {\n super(table, config);\n this.precision = config.precision;\n this.scale = config.scale;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"number\") return value;\n return Number(value);\n }\n mapToDriverValue = String;\n getSQLType() {\n if (this.precision !== void 0 && this.scale !== void 0) {\n return `numeric(${this.precision}, ${this.scale})`;\n } else if (this.precision === void 0) {\n return \"numeric\";\n } else {\n return `numeric(${this.precision})`;\n }\n }\n}\nclass PgNumericBigIntBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgNumericBigIntBuilder\";\n constructor(name, precision, scale) {\n super(name, \"bigint\", \"PgNumericBigInt\");\n this.config.precision = precision;\n this.config.scale = scale;\n }\n /** @internal */\n build(table) {\n return new PgNumericBigInt(\n table,\n this.config\n );\n }\n}\nclass PgNumericBigInt extends PgColumn {\n static [entityKind] = \"PgNumericBigInt\";\n precision;\n scale;\n constructor(table, config) {\n super(table, config);\n this.precision = config.precision;\n this.scale = config.scale;\n }\n mapFromDriverValue = BigInt;\n mapToDriverValue = String;\n getSQLType() {\n if (this.precision !== void 0 && this.scale !== void 0) {\n return `numeric(${this.precision}, ${this.scale})`;\n } else if (this.precision === void 0) {\n return \"numeric\";\n } else {\n return `numeric(${this.precision})`;\n }\n }\n}\nfunction numeric(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n const mode = config?.mode;\n return mode === \"number\" ? new PgNumericNumberBuilder(name, config?.precision, config?.scale) : mode === \"bigint\" ? new PgNumericBigIntBuilder(name, config?.precision, config?.scale) : new PgNumericBuilder(name, config?.precision, config?.scale);\n}\nconst decimal = numeric;\nexport {\n PgNumeric,\n PgNumericBigInt,\n PgNumericBigIntBuilder,\n PgNumericBuilder,\n PgNumericNumber,\n PgNumericNumberBuilder,\n decimal,\n numeric\n};\n//# sourceMappingURL=numeric.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgPointTupleBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgPointTupleBuilder\";\n constructor(name) {\n super(name, \"array\", \"PgPointTuple\");\n }\n /** @internal */\n build(table) {\n return new PgPointTuple(\n table,\n this.config\n );\n }\n}\nclass PgPointTuple extends PgColumn {\n static [entityKind] = \"PgPointTuple\";\n getSQLType() {\n return \"point\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n const [x, y] = value.slice(1, -1).split(\",\");\n return [Number.parseFloat(x), Number.parseFloat(y)];\n }\n return [value.x, value.y];\n }\n mapToDriverValue(value) {\n return `(${value[0]},${value[1]})`;\n }\n}\nclass PgPointObjectBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgPointObjectBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgPointObject\");\n }\n /** @internal */\n build(table) {\n return new PgPointObject(\n table,\n this.config\n );\n }\n}\nclass PgPointObject extends PgColumn {\n static [entityKind] = \"PgPointObject\";\n getSQLType() {\n return \"point\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n const [x, y] = value.slice(1, -1).split(\",\");\n return { x: Number.parseFloat(x), y: Number.parseFloat(y) };\n }\n return value;\n }\n mapToDriverValue(value) {\n return `(${value.x},${value.y})`;\n }\n}\nfunction point(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (!config?.mode || config.mode === \"tuple\") {\n return new PgPointTupleBuilder(name);\n }\n return new PgPointObjectBuilder(name);\n}\nexport {\n PgPointObject,\n PgPointObjectBuilder,\n PgPointTuple,\n PgPointTupleBuilder,\n point\n};\n//# sourceMappingURL=point.js.map","import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nclass PgBinaryVectorBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgBinaryVectorBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgBinaryVector\");\n this.config.dimensions = config.dimensions;\n }\n /** @internal */\n build(table) {\n return new PgBinaryVector(\n table,\n this.config\n );\n }\n}\nclass PgBinaryVector extends PgColumn {\n static [entityKind] = \"PgBinaryVector\";\n dimensions = this.config.dimensions;\n getSQLType() {\n return `bit(${this.dimensions})`;\n }\n}\nfunction bit(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgBinaryVectorBuilder(name, config);\n}\nexport {\n PgBinaryVector,\n PgBinaryVectorBuilder,\n bit\n};\n//# sourceMappingURL=bit.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig, textDecoder } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteBigIntBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteBigIntBuilder\";\n constructor(name) {\n super(name, \"bigint\", \"SQLiteBigInt\");\n }\n /** @internal */\n build(table) {\n return new SQLiteBigInt(table, this.config);\n }\n}\nclass SQLiteBigInt extends SQLiteColumn {\n static [entityKind] = \"SQLiteBigInt\";\n getSQLType() {\n return \"blob\";\n }\n mapFromDriverValue(value) {\n if (typeof Buffer !== \"undefined\" && Buffer.from) {\n const buf = Buffer.isBuffer(value) ? value : value instanceof ArrayBuffer ? Buffer.from(value) : value.buffer ? Buffer.from(value.buffer, value.byteOffset, value.byteLength) : Buffer.from(value);\n return BigInt(buf.toString(\"utf8\"));\n }\n return BigInt(textDecoder.decode(value));\n }\n mapToDriverValue(value) {\n return Buffer.from(value.toString());\n }\n}\nclass SQLiteBlobJsonBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteBlobJsonBuilder\";\n constructor(name) {\n super(name, \"json\", \"SQLiteBlobJson\");\n }\n /** @internal */\n build(table) {\n return new SQLiteBlobJson(\n table,\n this.config\n );\n }\n}\nclass SQLiteBlobJson extends SQLiteColumn {\n static [entityKind] = \"SQLiteBlobJson\";\n getSQLType() {\n return \"blob\";\n }\n mapFromDriverValue(value) {\n if (typeof Buffer !== \"undefined\" && Buffer.from) {\n const buf = Buffer.isBuffer(value) ? value : value instanceof ArrayBuffer ? Buffer.from(value) : value.buffer ? Buffer.from(value.buffer, value.byteOffset, value.byteLength) : Buffer.from(value);\n return JSON.parse(buf.toString(\"utf8\"));\n }\n return JSON.parse(textDecoder.decode(value));\n }\n mapToDriverValue(value) {\n return Buffer.from(JSON.stringify(value));\n }\n}\nclass SQLiteBlobBufferBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteBlobBufferBuilder\";\n constructor(name) {\n super(name, \"buffer\", \"SQLiteBlobBuffer\");\n }\n /** @internal */\n build(table) {\n return new SQLiteBlobBuffer(table, this.config);\n }\n}\nclass SQLiteBlobBuffer extends SQLiteColumn {\n static [entityKind] = \"SQLiteBlobBuffer\";\n mapFromDriverValue(value) {\n if (Buffer.isBuffer(value)) {\n return value;\n }\n return Buffer.from(value);\n }\n getSQLType() {\n return \"blob\";\n }\n}\nfunction blob(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config?.mode === \"json\") {\n return new SQLiteBlobJsonBuilder(name);\n }\n if (config?.mode === \"bigint\") {\n return new SQLiteBigIntBuilder(name);\n }\n return new SQLiteBlobBufferBuilder(name);\n}\nexport {\n SQLiteBigInt,\n SQLiteBigIntBuilder,\n SQLiteBlobBuffer,\n SQLiteBlobBufferBuilder,\n SQLiteBlobJson,\n SQLiteBlobJsonBuilder,\n blob\n};\n//# sourceMappingURL=blob.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteCustomColumnBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteCustomColumnBuilder\";\n constructor(name, fieldConfig, customTypeParams) {\n super(name, \"custom\", \"SQLiteCustomColumn\");\n this.config.fieldConfig = fieldConfig;\n this.config.customTypeParams = customTypeParams;\n }\n /** @internal */\n build(table) {\n return new SQLiteCustomColumn(\n table,\n this.config\n );\n }\n}\nclass SQLiteCustomColumn extends SQLiteColumn {\n static [entityKind] = \"SQLiteCustomColumn\";\n sqlName;\n mapTo;\n mapFrom;\n constructor(table, config) {\n super(table, config);\n this.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n this.mapTo = config.customTypeParams.toDriver;\n this.mapFrom = config.customTypeParams.fromDriver;\n }\n getSQLType() {\n return this.sqlName;\n }\n mapFromDriverValue(value) {\n return typeof this.mapFrom === \"function\" ? this.mapFrom(value) : value;\n }\n mapToDriverValue(value) {\n return typeof this.mapTo === \"function\" ? this.mapTo(value) : value;\n }\n}\nfunction customType(customTypeParams) {\n return (a, b) => {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new SQLiteCustomColumnBuilder(\n name,\n config,\n customTypeParams\n );\n };\n}\nexport {\n SQLiteCustomColumn,\n SQLiteCustomColumnBuilder,\n customType\n};\n//# sourceMappingURL=custom.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteNumericBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteNumericBuilder\";\n constructor(name) {\n super(name, \"string\", \"SQLiteNumeric\");\n }\n /** @internal */\n build(table) {\n return new SQLiteNumeric(\n table,\n this.config\n );\n }\n}\nclass SQLiteNumeric extends SQLiteColumn {\n static [entityKind] = \"SQLiteNumeric\";\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return value;\n return String(value);\n }\n getSQLType() {\n return \"numeric\";\n }\n}\nclass SQLiteNumericNumberBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteNumericNumberBuilder\";\n constructor(name) {\n super(name, \"number\", \"SQLiteNumericNumber\");\n }\n /** @internal */\n build(table) {\n return new SQLiteNumericNumber(\n table,\n this.config\n );\n }\n}\nclass SQLiteNumericNumber extends SQLiteColumn {\n static [entityKind] = \"SQLiteNumericNumber\";\n mapFromDriverValue(value) {\n if (typeof value === \"number\") return value;\n return Number(value);\n }\n mapToDriverValue = String;\n getSQLType() {\n return \"numeric\";\n }\n}\nclass SQLiteNumericBigIntBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteNumericBigIntBuilder\";\n constructor(name) {\n super(name, \"bigint\", \"SQLiteNumericBigInt\");\n }\n /** @internal */\n build(table) {\n return new SQLiteNumericBigInt(\n table,\n this.config\n );\n }\n}\nclass SQLiteNumericBigInt extends SQLiteColumn {\n static [entityKind] = \"SQLiteNumericBigInt\";\n mapFromDriverValue = BigInt;\n mapToDriverValue = String;\n getSQLType() {\n return \"numeric\";\n }\n}\nfunction numeric(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n const mode = config?.mode;\n return mode === \"number\" ? new SQLiteNumericNumberBuilder(name) : mode === \"bigint\" ? new SQLiteNumericBigIntBuilder(name) : new SQLiteNumericBuilder(name);\n}\nexport {\n SQLiteNumeric,\n SQLiteNumericBigInt,\n SQLiteNumericBigIntBuilder,\n SQLiteNumericBuilder,\n SQLiteNumericNumber,\n SQLiteNumericNumberBuilder,\n numeric\n};\n//# sourceMappingURL=numeric.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgCharBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgCharBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgChar\");\n this.config.length = config.length;\n this.config.enumValues = config.enum;\n }\n /** @internal */\n build(table) {\n return new PgChar(\n table,\n this.config\n );\n }\n}\nclass PgChar extends PgColumn {\n static [entityKind] = \"PgChar\";\n length = this.config.length;\n enumValues = this.config.enumValues;\n getSQLType() {\n return this.length === void 0 ? `char` : `char(${this.length})`;\n }\n}\nfunction char(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgCharBuilder(name, config);\n}\nexport {\n PgChar,\n PgCharBuilder,\n char\n};\n//# sourceMappingURL=char.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteTextBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteTextBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"SQLiteText\");\n this.config.enumValues = config.enum;\n this.config.length = config.length;\n }\n /** @internal */\n build(table) {\n return new SQLiteText(\n table,\n this.config\n );\n }\n}\nclass SQLiteText extends SQLiteColumn {\n static [entityKind] = \"SQLiteText\";\n enumValues = this.config.enumValues;\n length = this.config.length;\n constructor(table, config) {\n super(table, config);\n }\n getSQLType() {\n return `text${this.config.length ? `(${this.config.length})` : \"\"}`;\n }\n}\nclass SQLiteTextJsonBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteTextJsonBuilder\";\n constructor(name) {\n super(name, \"json\", \"SQLiteTextJson\");\n }\n /** @internal */\n build(table) {\n return new SQLiteTextJson(\n table,\n this.config\n );\n }\n}\nclass SQLiteTextJson extends SQLiteColumn {\n static [entityKind] = \"SQLiteTextJson\";\n getSQLType() {\n return \"text\";\n }\n mapFromDriverValue(value) {\n return JSON.parse(value);\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n}\nfunction text(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config.mode === \"json\") {\n return new SQLiteTextJsonBuilder(name);\n }\n return new SQLiteTextBuilder(name, config);\n}\nexport {\n SQLiteText,\n SQLiteTextBuilder,\n SQLiteTextJson,\n SQLiteTextJsonBuilder,\n text\n};\n//# sourceMappingURL=text.js.map","import { entityKind } from \"../entity.js\";\nimport { Table } from \"../table.js\";\nimport { getSQLiteColumnBuilders } from \"./columns/all.js\";\nconst InlineForeignKeys = Symbol.for(\"drizzle:SQLiteInlineForeignKeys\");\nclass SQLiteTable extends Table {\n static [entityKind] = \"SQLiteTable\";\n /** @internal */\n static Symbol = Object.assign({}, Table.Symbol, {\n InlineForeignKeys\n });\n /** @internal */\n [Table.Symbol.Columns];\n /** @internal */\n [InlineForeignKeys] = [];\n /** @internal */\n [Table.Symbol.ExtraConfigBuilder] = void 0;\n}\nfunction sqliteTableBase(name, columns, extraConfig, schema, baseName = name) {\n const rawTable = new SQLiteTable(name, schema, baseName);\n const parsedColumns = typeof columns === \"function\" ? columns(getSQLiteColumnBuilders()) : columns;\n const builtColumns = Object.fromEntries(\n Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n const colBuilder = colBuilderBase;\n colBuilder.setName(name2);\n const column = colBuilder.build(rawTable);\n rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n return [name2, column];\n })\n );\n const table = Object.assign(rawTable, builtColumns);\n table[Table.Symbol.Columns] = builtColumns;\n table[Table.Symbol.ExtraConfigColumns] = builtColumns;\n if (extraConfig) {\n table[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig;\n }\n return table;\n}\nconst sqliteTable = (name, columns, extraConfig) => {\n return sqliteTableBase(name, columns, extraConfig);\n};\nfunction sqliteTableCreator(customizeTableName) {\n return (name, columns, extraConfig) => {\n return sqliteTableBase(customizeTableName(name), columns, extraConfig, void 0, name);\n };\n}\nexport {\n InlineForeignKeys,\n SQLiteTable,\n sqliteTable,\n sqliteTableCreator\n};\n//# sourceMappingURL=table.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgIntColumnBaseBuilder } from \"./int.common.js\";\nclass PgIntegerBuilder extends PgIntColumnBaseBuilder {\n static [entityKind] = \"PgIntegerBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgInteger\");\n }\n /** @internal */\n build(table) {\n return new PgInteger(table, this.config);\n }\n}\nclass PgInteger extends PgColumn {\n static [entityKind] = \"PgInteger\";\n getSQLType() {\n return \"integer\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n return Number.parseInt(value);\n }\n return value;\n }\n}\nfunction integer(name) {\n return new PgIntegerBuilder(name ?? \"\");\n}\nexport {\n PgInteger,\n PgIntegerBuilder,\n integer\n};\n//# sourceMappingURL=integer.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgIntervalBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgIntervalBuilder\";\n constructor(name, intervalConfig) {\n super(name, \"string\", \"PgInterval\");\n this.config.intervalConfig = intervalConfig;\n }\n /** @internal */\n build(table) {\n return new PgInterval(table, this.config);\n }\n}\nclass PgInterval extends PgColumn {\n static [entityKind] = \"PgInterval\";\n fields = this.config.intervalConfig.fields;\n precision = this.config.intervalConfig.precision;\n getSQLType() {\n const fields = this.fields ? ` ${this.fields}` : \"\";\n const precision = this.precision ? `(${this.precision})` : \"\";\n return `interval${fields}${precision}`;\n }\n}\nfunction interval(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgIntervalBuilder(name, config);\n}\nexport {\n PgInterval,\n PgIntervalBuilder,\n interval\n};\n//# sourceMappingURL=interval.js.map","import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nclass PgHalfVectorBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgHalfVectorBuilder\";\n constructor(name, config) {\n super(name, \"array\", \"PgHalfVector\");\n this.config.dimensions = config.dimensions;\n }\n /** @internal */\n build(table) {\n return new PgHalfVector(\n table,\n this.config\n );\n }\n}\nclass PgHalfVector extends PgColumn {\n static [entityKind] = \"PgHalfVector\";\n dimensions = this.config.dimensions;\n getSQLType() {\n return `halfvec(${this.dimensions})`;\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n mapFromDriverValue(value) {\n return value.slice(1, -1).split(\",\").map((v) => Number.parseFloat(v));\n }\n}\nfunction halfvec(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgHalfVectorBuilder(name, config);\n}\nexport {\n PgHalfVector,\n PgHalfVectorBuilder,\n halfvec\n};\n//# sourceMappingURL=halfvec.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgDateColumnBaseBuilder } from \"./date.common.js\";\nclass PgDateBuilder extends PgDateColumnBaseBuilder {\n static [entityKind] = \"PgDateBuilder\";\n constructor(name) {\n super(name, \"date\", \"PgDate\");\n }\n /** @internal */\n build(table) {\n return new PgDate(table, this.config);\n }\n}\nclass PgDate extends PgColumn {\n static [entityKind] = \"PgDate\";\n getSQLType() {\n return \"date\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return new Date(value);\n return value;\n }\n mapToDriverValue(value) {\n return value.toISOString();\n }\n}\nclass PgDateStringBuilder extends PgDateColumnBaseBuilder {\n static [entityKind] = \"PgDateStringBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgDateString\");\n }\n /** @internal */\n build(table) {\n return new PgDateString(\n table,\n this.config\n );\n }\n}\nclass PgDateString extends PgColumn {\n static [entityKind] = \"PgDateString\";\n getSQLType() {\n return \"date\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return value;\n return value.toISOString().slice(0, -14);\n }\n}\nfunction date(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config?.mode === \"date\") {\n return new PgDateBuilder(name);\n }\n return new PgDateStringBuilder(name);\n}\nexport {\n PgDate,\n PgDateBuilder,\n PgDateString,\n PgDateStringBuilder,\n date\n};\n//# sourceMappingURL=date.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgDateColumnBaseBuilder } from \"./date.common.js\";\nclass PgTimeBuilder extends PgDateColumnBaseBuilder {\n constructor(name, withTimezone, precision) {\n super(name, \"string\", \"PgTime\");\n this.withTimezone = withTimezone;\n this.precision = precision;\n this.config.withTimezone = withTimezone;\n this.config.precision = precision;\n }\n static [entityKind] = \"PgTimeBuilder\";\n /** @internal */\n build(table) {\n return new PgTime(table, this.config);\n }\n}\nclass PgTime extends PgColumn {\n static [entityKind] = \"PgTime\";\n withTimezone;\n precision;\n constructor(table, config) {\n super(table, config);\n this.withTimezone = config.withTimezone;\n this.precision = config.precision;\n }\n getSQLType() {\n const precision = this.precision === void 0 ? \"\" : `(${this.precision})`;\n return `time${precision}${this.withTimezone ? \" with time zone\" : \"\"}`;\n }\n}\nfunction time(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgTimeBuilder(name, config.withTimezone ?? false, config.precision);\n}\nexport {\n PgTime,\n PgTimeBuilder,\n time\n};\n//# sourceMappingURL=time.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgIntColumnBaseBuilder } from \"./int.common.js\";\nclass PgBigInt53Builder extends PgIntColumnBaseBuilder {\n static [entityKind] = \"PgBigInt53Builder\";\n constructor(name) {\n super(name, \"number\", \"PgBigInt53\");\n }\n /** @internal */\n build(table) {\n return new PgBigInt53(table, this.config);\n }\n}\nclass PgBigInt53 extends PgColumn {\n static [entityKind] = \"PgBigInt53\";\n getSQLType() {\n return \"bigint\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"number\") {\n return value;\n }\n return Number(value);\n }\n}\nclass PgBigInt64Builder extends PgIntColumnBaseBuilder {\n static [entityKind] = \"PgBigInt64Builder\";\n constructor(name) {\n super(name, \"bigint\", \"PgBigInt64\");\n }\n /** @internal */\n build(table) {\n return new PgBigInt64(\n table,\n this.config\n );\n }\n}\nclass PgBigInt64 extends PgColumn {\n static [entityKind] = \"PgBigInt64\";\n getSQLType() {\n return \"bigint\";\n }\n // eslint-disable-next-line unicorn/prefer-native-coercion-functions\n mapFromDriverValue(value) {\n return BigInt(value);\n }\n}\nfunction bigint(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config.mode === \"number\") {\n return new PgBigInt53Builder(name);\n }\n return new PgBigInt64Builder(name);\n}\nexport {\n PgBigInt53,\n PgBigInt53Builder,\n PgBigInt64,\n PgBigInt64Builder,\n bigint\n};\n//# sourceMappingURL=bigint.js.map","import { entityKind } from \"../../entity.js\";\nimport { sql } from \"../../sql/sql.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteBaseIntegerBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteBaseIntegerBuilder\";\n constructor(name, dataType, columnType) {\n super(name, dataType, columnType);\n this.config.autoIncrement = false;\n }\n primaryKey(config) {\n if (config?.autoIncrement) {\n this.config.autoIncrement = true;\n }\n this.config.hasDefault = true;\n return super.primaryKey();\n }\n}\nclass SQLiteBaseInteger extends SQLiteColumn {\n static [entityKind] = \"SQLiteBaseInteger\";\n autoIncrement = this.config.autoIncrement;\n getSQLType() {\n return \"integer\";\n }\n}\nclass SQLiteIntegerBuilder extends SQLiteBaseIntegerBuilder {\n static [entityKind] = \"SQLiteIntegerBuilder\";\n constructor(name) {\n super(name, \"number\", \"SQLiteInteger\");\n }\n build(table) {\n return new SQLiteInteger(\n table,\n this.config\n );\n }\n}\nclass SQLiteInteger extends SQLiteBaseInteger {\n static [entityKind] = \"SQLiteInteger\";\n}\nclass SQLiteTimestampBuilder extends SQLiteBaseIntegerBuilder {\n static [entityKind] = \"SQLiteTimestampBuilder\";\n constructor(name, mode) {\n super(name, \"date\", \"SQLiteTimestamp\");\n this.config.mode = mode;\n }\n /**\n * @deprecated Use `default()` with your own expression instead.\n *\n * Adds `DEFAULT (cast((julianday('now') - 2440587.5)*86400000 as integer))` to the column, which is the current epoch timestamp in milliseconds.\n */\n defaultNow() {\n return this.default(sql`(cast((julianday('now') - 2440587.5)*86400000 as integer))`);\n }\n build(table) {\n return new SQLiteTimestamp(\n table,\n this.config\n );\n }\n}\nclass SQLiteTimestamp extends SQLiteBaseInteger {\n static [entityKind] = \"SQLiteTimestamp\";\n mode = this.config.mode;\n mapFromDriverValue(value) {\n if (this.config.mode === \"timestamp\") {\n return new Date(value * 1e3);\n }\n return new Date(value);\n }\n mapToDriverValue(value) {\n const unix = value.getTime();\n if (this.config.mode === \"timestamp\") {\n return Math.floor(unix / 1e3);\n }\n return unix;\n }\n}\nclass SQLiteBooleanBuilder extends SQLiteBaseIntegerBuilder {\n static [entityKind] = \"SQLiteBooleanBuilder\";\n constructor(name, mode) {\n super(name, \"boolean\", \"SQLiteBoolean\");\n this.config.mode = mode;\n }\n build(table) {\n return new SQLiteBoolean(\n table,\n this.config\n );\n }\n}\nclass SQLiteBoolean extends SQLiteBaseInteger {\n static [entityKind] = \"SQLiteBoolean\";\n mode = this.config.mode;\n mapFromDriverValue(value) {\n return Number(value) === 1;\n }\n mapToDriverValue(value) {\n return value ? 1 : 0;\n }\n}\nfunction integer(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config?.mode === \"timestamp\" || config?.mode === \"timestamp_ms\") {\n return new SQLiteTimestampBuilder(name, config.mode);\n }\n if (config?.mode === \"boolean\") {\n return new SQLiteBooleanBuilder(name, config.mode);\n }\n return new SQLiteIntegerBuilder(name);\n}\nconst int = integer;\nexport {\n SQLiteBaseInteger,\n SQLiteBaseIntegerBuilder,\n SQLiteBoolean,\n SQLiteBooleanBuilder,\n SQLiteInteger,\n SQLiteIntegerBuilder,\n SQLiteTimestamp,\n SQLiteTimestampBuilder,\n int,\n integer\n};\n//# sourceMappingURL=integer.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgDateColumnBaseBuilder } from \"./date.common.js\";\nclass PgTimestampBuilder extends PgDateColumnBaseBuilder {\n static [entityKind] = \"PgTimestampBuilder\";\n constructor(name, withTimezone, precision) {\n super(name, \"date\", \"PgTimestamp\");\n this.config.withTimezone = withTimezone;\n this.config.precision = precision;\n }\n /** @internal */\n build(table) {\n return new PgTimestamp(table, this.config);\n }\n}\nclass PgTimestamp extends PgColumn {\n static [entityKind] = \"PgTimestamp\";\n withTimezone;\n precision;\n constructor(table, config) {\n super(table, config);\n this.withTimezone = config.withTimezone;\n this.precision = config.precision;\n }\n getSQLType() {\n const precision = this.precision === void 0 ? \"\" : ` (${this.precision})`;\n return `timestamp${precision}${this.withTimezone ? \" with time zone\" : \"\"}`;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return new Date(this.withTimezone ? value : value + \"+0000\");\n return value;\n }\n mapToDriverValue = (value) => {\n return value.toISOString();\n };\n}\nclass PgTimestampStringBuilder extends PgDateColumnBaseBuilder {\n static [entityKind] = \"PgTimestampStringBuilder\";\n constructor(name, withTimezone, precision) {\n super(name, \"string\", \"PgTimestampString\");\n this.config.withTimezone = withTimezone;\n this.config.precision = precision;\n }\n /** @internal */\n build(table) {\n return new PgTimestampString(\n table,\n this.config\n );\n }\n}\nclass PgTimestampString extends PgColumn {\n static [entityKind] = \"PgTimestampString\";\n withTimezone;\n precision;\n constructor(table, config) {\n super(table, config);\n this.withTimezone = config.withTimezone;\n this.precision = config.precision;\n }\n getSQLType() {\n const precision = this.precision === void 0 ? \"\" : `(${this.precision})`;\n return `timestamp${precision}${this.withTimezone ? \" with time zone\" : \"\"}`;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return value;\n const shortened = value.toISOString().slice(0, -1).replace(\"T\", \" \");\n if (this.withTimezone) {\n const offset = value.getTimezoneOffset();\n const sign = offset <= 0 ? \"+\" : \"-\";\n return `${shortened}${sign}${Math.floor(Math.abs(offset) / 60).toString().padStart(2, \"0\")}`;\n }\n return shortened;\n }\n}\nfunction timestamp(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config?.mode === \"string\") {\n return new PgTimestampStringBuilder(name, config.withTimezone ?? false, config.precision);\n }\n return new PgTimestampBuilder(name, config?.withTimezone ?? false, config?.precision);\n}\nexport {\n PgTimestamp,\n PgTimestampBuilder,\n PgTimestampString,\n PgTimestampStringBuilder,\n timestamp\n};\n//# sourceMappingURL=timestamp.js.map","import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nimport { parseEWKB } from \"./utils.js\";\nclass PgGeometryBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgGeometryBuilder\";\n constructor(name) {\n super(name, \"array\", \"PgGeometry\");\n }\n /** @internal */\n build(table) {\n return new PgGeometry(\n table,\n this.config\n );\n }\n}\nclass PgGeometry extends PgColumn {\n static [entityKind] = \"PgGeometry\";\n getSQLType() {\n return \"geometry(point)\";\n }\n mapFromDriverValue(value) {\n return parseEWKB(value);\n }\n mapToDriverValue(value) {\n return `point(${value[0]} ${value[1]})`;\n }\n}\nclass PgGeometryObjectBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgGeometryObjectBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgGeometryObject\");\n }\n /** @internal */\n build(table) {\n return new PgGeometryObject(\n table,\n this.config\n );\n }\n}\nclass PgGeometryObject extends PgColumn {\n static [entityKind] = \"PgGeometryObject\";\n getSQLType() {\n return \"geometry(point)\";\n }\n mapFromDriverValue(value) {\n const parsed = parseEWKB(value);\n return { x: parsed[0], y: parsed[1] };\n }\n mapToDriverValue(value) {\n return `point(${value.x} ${value.y})`;\n }\n}\nfunction geometry(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (!config?.mode || config.mode === \"tuple\") {\n return new PgGeometryBuilder(name);\n }\n return new PgGeometryObjectBuilder(name);\n}\nexport {\n PgGeometry,\n PgGeometryBuilder,\n PgGeometryObject,\n PgGeometryObjectBuilder,\n geometry\n};\n//# sourceMappingURL=geometry.js.map","import { entityKind, is } from \"../../entity.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQLiteDialect, SQLiteSyncDialect } from \"../dialect.js\";\nimport { WithSubquery } from \"../../subquery.js\";\nimport { SQLiteSelectBuilder } from \"./select.js\";\nclass QueryBuilder {\n static [entityKind] = \"SQLiteQueryBuilder\";\n dialect;\n dialectConfig;\n constructor(dialect) {\n this.dialect = is(dialect, SQLiteDialect) ? dialect : void 0;\n this.dialectConfig = is(dialect, SQLiteDialect) ? void 0 : dialect;\n }\n $with = (alias, selection) => {\n const queryBuilder = this;\n const as = (qb) => {\n if (typeof qb === \"function\") {\n qb = qb(queryBuilder);\n }\n return new Proxy(\n new WithSubquery(\n qb.getSQL(),\n selection ?? (\"getSelectedFields\" in qb ? qb.getSelectedFields() ?? {} : {}),\n alias,\n true\n ),\n new SelectionProxyHandler({ alias, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n );\n };\n return { as };\n };\n with(...queries) {\n const self = this;\n function select(fields) {\n return new SQLiteSelectBuilder({\n fields: fields ?? void 0,\n session: void 0,\n dialect: self.getDialect(),\n withList: queries\n });\n }\n function selectDistinct(fields) {\n return new SQLiteSelectBuilder({\n fields: fields ?? void 0,\n session: void 0,\n dialect: self.getDialect(),\n withList: queries,\n distinct: true\n });\n }\n return { select, selectDistinct };\n }\n select(fields) {\n return new SQLiteSelectBuilder({ fields: fields ?? void 0, session: void 0, dialect: this.getDialect() });\n }\n selectDistinct(fields) {\n return new SQLiteSelectBuilder({\n fields: fields ?? void 0,\n session: void 0,\n dialect: this.getDialect(),\n distinct: true\n });\n }\n // Lazy load dialect to avoid circular dependency\n getDialect() {\n if (!this.dialect) {\n this.dialect = new SQLiteSyncDialect(this.dialectConfig);\n }\n return this.dialect;\n }\n}\nexport {\n QueryBuilder\n};\n//# sourceMappingURL=query-builder.js.map","import { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { SQL, sql } from \"./sql/sql.js\";\nimport { Table } from \"./table.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nclass ColumnAliasProxyHandler {\n constructor(table) {\n this.table = table;\n }\n static [entityKind] = \"ColumnAliasProxyHandler\";\n get(columnObj, prop) {\n if (prop === \"table\") {\n return this.table;\n }\n return columnObj[prop];\n }\n}\nclass TableAliasProxyHandler {\n constructor(alias, replaceOriginalName) {\n this.alias = alias;\n this.replaceOriginalName = replaceOriginalName;\n }\n static [entityKind] = \"TableAliasProxyHandler\";\n get(target, prop) {\n if (prop === Table.Symbol.IsAlias) {\n return true;\n }\n if (prop === Table.Symbol.Name) {\n return this.alias;\n }\n if (this.replaceOriginalName && prop === Table.Symbol.OriginalName) {\n return this.alias;\n }\n if (prop === ViewBaseConfig) {\n return {\n ...target[ViewBaseConfig],\n name: this.alias,\n isAlias: true\n };\n }\n if (prop === Table.Symbol.Columns) {\n const columns = target[Table.Symbol.Columns];\n if (!columns) {\n return columns;\n }\n const proxiedColumns = {};\n Object.keys(columns).map((key) => {\n proxiedColumns[key] = new Proxy(\n columns[key],\n new ColumnAliasProxyHandler(new Proxy(target, this))\n );\n });\n return proxiedColumns;\n }\n const value = target[prop];\n if (is(value, Column)) {\n return new Proxy(value, new ColumnAliasProxyHandler(new Proxy(target, this)));\n }\n return value;\n }\n}\nclass RelationTableAliasProxyHandler {\n constructor(alias) {\n this.alias = alias;\n }\n static [entityKind] = \"RelationTableAliasProxyHandler\";\n get(target, prop) {\n if (prop === \"sourceTable\") {\n return aliasedTable(target.sourceTable, this.alias);\n }\n return target[prop];\n }\n}\nfunction aliasedTable(table, tableAlias) {\n return new Proxy(table, new TableAliasProxyHandler(tableAlias, false));\n}\nfunction aliasedRelation(relation, tableAlias) {\n return new Proxy(relation, new RelationTableAliasProxyHandler(tableAlias));\n}\nfunction aliasedTableColumn(column, tableAlias) {\n return new Proxy(\n column,\n new ColumnAliasProxyHandler(new Proxy(column.table, new TableAliasProxyHandler(tableAlias, false)))\n );\n}\nfunction mapColumnsInAliasedSQLToAlias(query, alias) {\n return new SQL.Aliased(mapColumnsInSQLToAlias(query.sql, alias), query.fieldAlias);\n}\nfunction mapColumnsInSQLToAlias(query, alias) {\n return sql.join(query.queryChunks.map((c) => {\n if (is(c, Column)) {\n return aliasedTableColumn(c, alias);\n }\n if (is(c, SQL)) {\n return mapColumnsInSQLToAlias(c, alias);\n }\n if (is(c, SQL.Aliased)) {\n return mapColumnsInAliasedSQLToAlias(c, alias);\n }\n return c;\n }));\n}\nexport {\n ColumnAliasProxyHandler,\n RelationTableAliasProxyHandler,\n TableAliasProxyHandler,\n aliasedRelation,\n aliasedTable,\n aliasedTableColumn,\n mapColumnsInAliasedSQLToAlias,\n mapColumnsInSQLToAlias\n};\n//# sourceMappingURL=alias.js.map","import { entityKind } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport {\n mapRelationalRow\n} from \"../../relations.js\";\nclass RelationalQueryBuilder {\n constructor(mode, fullSchema, schema, tableNamesMap, table, tableConfig, dialect, session) {\n this.mode = mode;\n this.fullSchema = fullSchema;\n this.schema = schema;\n this.tableNamesMap = tableNamesMap;\n this.table = table;\n this.tableConfig = tableConfig;\n this.dialect = dialect;\n this.session = session;\n }\n static [entityKind] = \"SQLiteAsyncRelationalQueryBuilder\";\n findMany(config) {\n return this.mode === \"sync\" ? new SQLiteSyncRelationalQuery(\n this.fullSchema,\n this.schema,\n this.tableNamesMap,\n this.table,\n this.tableConfig,\n this.dialect,\n this.session,\n config ? config : {},\n \"many\"\n ) : new SQLiteRelationalQuery(\n this.fullSchema,\n this.schema,\n this.tableNamesMap,\n this.table,\n this.tableConfig,\n this.dialect,\n this.session,\n config ? config : {},\n \"many\"\n );\n }\n findFirst(config) {\n return this.mode === \"sync\" ? new SQLiteSyncRelationalQuery(\n this.fullSchema,\n this.schema,\n this.tableNamesMap,\n this.table,\n this.tableConfig,\n this.dialect,\n this.session,\n config ? { ...config, limit: 1 } : { limit: 1 },\n \"first\"\n ) : new SQLiteRelationalQuery(\n this.fullSchema,\n this.schema,\n this.tableNamesMap,\n this.table,\n this.tableConfig,\n this.dialect,\n this.session,\n config ? { ...config, limit: 1 } : { limit: 1 },\n \"first\"\n );\n }\n}\nclass SQLiteRelationalQuery extends QueryPromise {\n constructor(fullSchema, schema, tableNamesMap, table, tableConfig, dialect, session, config, mode) {\n super();\n this.fullSchema = fullSchema;\n this.schema = schema;\n this.tableNamesMap = tableNamesMap;\n this.table = table;\n this.tableConfig = tableConfig;\n this.dialect = dialect;\n this.session = session;\n this.config = config;\n this.mode = mode;\n }\n static [entityKind] = \"SQLiteAsyncRelationalQuery\";\n /** @internal */\n mode;\n /** @internal */\n getSQL() {\n return this.dialect.buildRelationalQuery({\n fullSchema: this.fullSchema,\n schema: this.schema,\n tableNamesMap: this.tableNamesMap,\n table: this.table,\n tableConfig: this.tableConfig,\n queryConfig: this.config,\n tableAlias: this.tableConfig.tsName\n }).sql;\n }\n /** @internal */\n _prepare(isOneTimeQuery = false) {\n const { query, builtQuery } = this._toSQL();\n return this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n builtQuery,\n void 0,\n this.mode === \"first\" ? \"get\" : \"all\",\n true,\n (rawRows, mapColumnValue) => {\n const rows = rawRows.map(\n (row) => mapRelationalRow(this.schema, this.tableConfig, row, query.selection, mapColumnValue)\n );\n if (this.mode === \"first\") {\n return rows[0];\n }\n return rows;\n }\n );\n }\n prepare() {\n return this._prepare(false);\n }\n _toSQL() {\n const query = this.dialect.buildRelationalQuery({\n fullSchema: this.fullSchema,\n schema: this.schema,\n tableNamesMap: this.tableNamesMap,\n table: this.table,\n tableConfig: this.tableConfig,\n queryConfig: this.config,\n tableAlias: this.tableConfig.tsName\n });\n const builtQuery = this.dialect.sqlToQuery(query.sql);\n return { query, builtQuery };\n }\n toSQL() {\n return this._toSQL().builtQuery;\n }\n /** @internal */\n executeRaw() {\n if (this.mode === \"first\") {\n return this._prepare(false).get();\n }\n return this._prepare(false).all();\n }\n async execute() {\n return this.executeRaw();\n }\n}\nclass SQLiteSyncRelationalQuery extends SQLiteRelationalQuery {\n static [entityKind] = \"SQLiteSyncRelationalQuery\";\n sync() {\n return this.executeRaw();\n }\n}\nexport {\n RelationalQueryBuilder,\n SQLiteRelationalQuery,\n SQLiteSyncRelationalQuery\n};\n//# sourceMappingURL=query.js.map","import { ColumnBuilder } from \"../../column-builder.js\";\nimport { Column } from \"../../column.js\";\nimport { entityKind } from \"../../entity.js\";\nimport { ForeignKeyBuilder } from \"../foreign-keys.js\";\nimport { uniqueKeyName } from \"../unique-constraint.js\";\nclass SQLiteColumnBuilder extends ColumnBuilder {\n static [entityKind] = \"SQLiteColumnBuilder\";\n foreignKeyConfigs = [];\n references(ref, actions = {}) {\n this.foreignKeyConfigs.push({ ref, actions });\n return this;\n }\n unique(name) {\n this.config.isUnique = true;\n this.config.uniqueName = name;\n return this;\n }\n generatedAlwaysAs(as, config) {\n this.config.generated = {\n as,\n type: \"always\",\n mode: config?.mode ?? \"virtual\"\n };\n return this;\n }\n /** @internal */\n buildForeignKeys(column, table) {\n return this.foreignKeyConfigs.map(({ ref, actions }) => {\n return ((ref2, actions2) => {\n const builder = new ForeignKeyBuilder(() => {\n const foreignColumn = ref2();\n return { columns: [column], foreignColumns: [foreignColumn] };\n });\n if (actions2.onUpdate) {\n builder.onUpdate(actions2.onUpdate);\n }\n if (actions2.onDelete) {\n builder.onDelete(actions2.onDelete);\n }\n return builder.build(table);\n })(ref, actions);\n });\n }\n}\nclass SQLiteColumn extends Column {\n constructor(table, config) {\n if (!config.uniqueName) {\n config.uniqueName = uniqueKeyName(table, [config.name]);\n }\n super(table, config);\n this.table = table;\n }\n static [entityKind] = \"SQLiteColumn\";\n}\nexport {\n SQLiteColumn,\n SQLiteColumnBuilder\n};\n//# sourceMappingURL=common.js.map","import { hashQuery, NoopCache } from \"../cache/core/cache.js\";\nimport { entityKind, is } from \"../entity.js\";\nimport { DrizzleError, DrizzleQueryError, TransactionRollbackError } from \"../errors.js\";\nimport { QueryPromise } from \"../query-promise.js\";\nimport { BaseSQLiteDatabase } from \"./db.js\";\nclass ExecuteResultSync extends QueryPromise {\n constructor(resultCb) {\n super();\n this.resultCb = resultCb;\n }\n static [entityKind] = \"ExecuteResultSync\";\n async execute() {\n return this.resultCb();\n }\n sync() {\n return this.resultCb();\n }\n}\nclass SQLitePreparedQuery {\n constructor(mode, executeMethod, query, cache, queryMetadata, cacheConfig) {\n this.mode = mode;\n this.executeMethod = executeMethod;\n this.query = query;\n this.cache = cache;\n this.queryMetadata = queryMetadata;\n this.cacheConfig = cacheConfig;\n if (cache && cache.strategy() === \"all\" && cacheConfig === void 0) {\n this.cacheConfig = { enable: true, autoInvalidate: true };\n }\n if (!this.cacheConfig?.enable) {\n this.cacheConfig = void 0;\n }\n }\n static [entityKind] = \"PreparedQuery\";\n /** @internal */\n joinsNotNullableMap;\n /** @internal */\n async queryWithCache(queryString, params, query) {\n if (this.cache === void 0 || is(this.cache, NoopCache) || this.queryMetadata === void 0) {\n try {\n return await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n if (this.cacheConfig && !this.cacheConfig.enable) {\n try {\n return await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n if ((this.queryMetadata.type === \"insert\" || this.queryMetadata.type === \"update\" || this.queryMetadata.type === \"delete\") && this.queryMetadata.tables.length > 0) {\n try {\n const [res] = await Promise.all([\n query(),\n this.cache.onMutate({ tables: this.queryMetadata.tables })\n ]);\n return res;\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n if (!this.cacheConfig) {\n try {\n return await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n if (this.queryMetadata.type === \"select\") {\n const fromCache = await this.cache.get(\n this.cacheConfig.tag ?? (await hashQuery(queryString, params)),\n this.queryMetadata.tables,\n this.cacheConfig.tag !== void 0,\n this.cacheConfig.autoInvalidate\n );\n if (fromCache === void 0) {\n let result;\n try {\n result = await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n await this.cache.put(\n this.cacheConfig.tag ?? (await hashQuery(queryString, params)),\n result,\n // make sure we send tables that were used in a query only if user wants to invalidate it on each write\n this.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n this.cacheConfig.tag !== void 0,\n this.cacheConfig.config\n );\n return result;\n }\n return fromCache;\n }\n try {\n return await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n getQuery() {\n return this.query;\n }\n mapRunResult(result, _isFromBatch) {\n return result;\n }\n mapAllResult(_result, _isFromBatch) {\n throw new Error(\"Not implemented\");\n }\n mapGetResult(_result, _isFromBatch) {\n throw new Error(\"Not implemented\");\n }\n execute(placeholderValues) {\n if (this.mode === \"async\") {\n return this[this.executeMethod](placeholderValues);\n }\n return new ExecuteResultSync(() => this[this.executeMethod](placeholderValues));\n }\n mapResult(response, isFromBatch) {\n switch (this.executeMethod) {\n case \"run\": {\n return this.mapRunResult(response, isFromBatch);\n }\n case \"all\": {\n return this.mapAllResult(response, isFromBatch);\n }\n case \"get\": {\n return this.mapGetResult(response, isFromBatch);\n }\n }\n }\n}\nclass SQLiteSession {\n constructor(dialect) {\n this.dialect = dialect;\n }\n static [entityKind] = \"SQLiteSession\";\n prepareOneTimeQuery(query, fields, executeMethod, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {\n return this.prepareQuery(\n query,\n fields,\n executeMethod,\n isResponseInArrayMode,\n customResultMapper,\n queryMetadata,\n cacheConfig\n );\n }\n run(query) {\n const staticQuery = this.dialect.sqlToQuery(query);\n try {\n return this.prepareOneTimeQuery(staticQuery, void 0, \"run\", false).run();\n } catch (err) {\n throw new DrizzleError({ cause: err, message: `Failed to run the query '${staticQuery.sql}'` });\n }\n }\n /** @internal */\n extractRawRunValueFromBatchResult(result) {\n return result;\n }\n all(query) {\n return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), void 0, \"run\", false).all();\n }\n /** @internal */\n extractRawAllValueFromBatchResult(_result) {\n throw new Error(\"Not implemented\");\n }\n get(query) {\n return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), void 0, \"run\", false).get();\n }\n /** @internal */\n extractRawGetValueFromBatchResult(_result) {\n throw new Error(\"Not implemented\");\n }\n values(query) {\n return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), void 0, \"run\", false).values();\n }\n async count(sql) {\n const result = await this.values(sql);\n return result[0][0];\n }\n /** @internal */\n extractRawValuesValueFromBatchResult(_result) {\n throw new Error(\"Not implemented\");\n }\n}\nclass SQLiteTransaction extends BaseSQLiteDatabase {\n constructor(resultType, dialect, session, schema, nestedIndex = 0) {\n super(resultType, dialect, session, schema);\n this.schema = schema;\n this.nestedIndex = nestedIndex;\n }\n static [entityKind] = \"SQLiteTransaction\";\n rollback() {\n throw new TransactionRollbackError();\n }\n}\nexport {\n ExecuteResultSync,\n SQLitePreparedQuery,\n SQLiteSession,\n SQLiteTransaction\n};\n//# sourceMappingURL=session.js.map","import { ColumnAliasProxyHandler, TableAliasProxyHandler } from \"./alias.js\";\nimport { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { SQL, View } from \"./sql/sql.js\";\nimport { Subquery } from \"./subquery.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nclass SelectionProxyHandler {\n static [entityKind] = \"SelectionProxyHandler\";\n config;\n constructor(config) {\n this.config = { ...config };\n }\n get(subquery, prop) {\n if (prop === \"_\") {\n return {\n ...subquery[\"_\"],\n selectedFields: new Proxy(\n subquery._.selectedFields,\n this\n )\n };\n }\n if (prop === ViewBaseConfig) {\n return {\n ...subquery[ViewBaseConfig],\n selectedFields: new Proxy(\n subquery[ViewBaseConfig].selectedFields,\n this\n )\n };\n }\n if (typeof prop === \"symbol\") {\n return subquery[prop];\n }\n const columns = is(subquery, Subquery) ? subquery._.selectedFields : is(subquery, View) ? subquery[ViewBaseConfig].selectedFields : subquery;\n const value = columns[prop];\n if (is(value, SQL.Aliased)) {\n if (this.config.sqlAliasedBehavior === \"sql\" && !value.isSelectionField) {\n return value.sql;\n }\n const newValue = value.clone();\n newValue.isSelectionField = true;\n return newValue;\n }\n if (is(value, SQL)) {\n if (this.config.sqlBehavior === \"sql\") {\n return value;\n }\n throw new Error(\n `You tried to reference \"${prop}\" field from a subquery, which is a raw SQL field, but it doesn't have an alias declared. Please add an alias to the field using \".as('alias')\" method.`\n );\n }\n if (is(value, Column)) {\n if (this.config.alias) {\n return new Proxy(\n value,\n new ColumnAliasProxyHandler(\n new Proxy(\n value.table,\n new TableAliasProxyHandler(this.config.alias, this.config.replaceOriginalName ?? false)\n )\n )\n );\n }\n return value;\n }\n if (typeof value !== \"object\" || value === null) {\n return value;\n }\n return new Proxy(value, new SelectionProxyHandler(this.config));\n }\n}\nexport {\n SelectionProxyHandler\n};\n//# sourceMappingURL=selection-proxy.js.map","import { Column } from \"./column.js\";\nimport { is } from \"./entity.js\";\nimport { Param, SQL, View } from \"./sql/sql.js\";\nimport { Subquery } from \"./subquery.js\";\nimport { getTableName, Table } from \"./table.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nfunction mapResultRow(columns, row, joinsNotNullableMap) {\n const nullifyMap = {};\n const result = columns.reduce(\n (result2, { path, field }, columnIndex) => {\n let decoder;\n if (is(field, Column)) {\n decoder = field;\n } else if (is(field, SQL)) {\n decoder = field.decoder;\n } else if (is(field, Subquery)) {\n decoder = field._.sql.decoder;\n } else {\n decoder = field.sql.decoder;\n }\n let node = result2;\n for (const [pathChunkIndex, pathChunk] of path.entries()) {\n if (pathChunkIndex < path.length - 1) {\n if (!(pathChunk in node)) {\n node[pathChunk] = {};\n }\n node = node[pathChunk];\n } else {\n const rawValue = row[columnIndex];\n const value = node[pathChunk] = rawValue === null ? null : decoder.mapFromDriverValue(rawValue);\n if (joinsNotNullableMap && is(field, Column) && path.length === 2) {\n const objectName = path[0];\n if (!(objectName in nullifyMap)) {\n nullifyMap[objectName] = value === null ? getTableName(field.table) : false;\n } else if (typeof nullifyMap[objectName] === \"string\" && nullifyMap[objectName] !== getTableName(field.table)) {\n nullifyMap[objectName] = false;\n }\n }\n }\n }\n return result2;\n },\n {}\n );\n if (joinsNotNullableMap && Object.keys(nullifyMap).length > 0) {\n for (const [objectName, tableName] of Object.entries(nullifyMap)) {\n if (typeof tableName === \"string\" && !joinsNotNullableMap[tableName]) {\n result[objectName] = null;\n }\n }\n }\n return result;\n}\nfunction orderSelectedFields(fields, pathPrefix) {\n return Object.entries(fields).reduce((result, [name, field]) => {\n if (typeof name !== \"string\") {\n return result;\n }\n const newPath = pathPrefix ? [...pathPrefix, name] : [name];\n if (is(field, Column) || is(field, SQL) || is(field, SQL.Aliased) || is(field, Subquery)) {\n result.push({ path: newPath, field });\n } else if (is(field, Table)) {\n result.push(...orderSelectedFields(field[Table.Symbol.Columns], newPath));\n } else {\n result.push(...orderSelectedFields(field, newPath));\n }\n return result;\n }, []);\n}\nfunction haveSameKeys(left, right) {\n const leftKeys = Object.keys(left);\n const rightKeys = Object.keys(right);\n if (leftKeys.length !== rightKeys.length) {\n return false;\n }\n for (const [index, key] of leftKeys.entries()) {\n if (key !== rightKeys[index]) {\n return false;\n }\n }\n return true;\n}\nfunction mapUpdateSet(table, values) {\n const entries = Object.entries(values).filter(([, value]) => value !== void 0).map(([key, value]) => {\n if (is(value, SQL) || is(value, Column)) {\n return [key, value];\n } else {\n return [key, new Param(value, table[Table.Symbol.Columns][key])];\n }\n });\n if (entries.length === 0) {\n throw new Error(\"No values to set\");\n }\n return Object.fromEntries(entries);\n}\nfunction applyMixins(baseClass, extendedClasses) {\n for (const extendedClass of extendedClasses) {\n for (const name of Object.getOwnPropertyNames(extendedClass.prototype)) {\n if (name === \"constructor\") continue;\n Object.defineProperty(\n baseClass.prototype,\n name,\n Object.getOwnPropertyDescriptor(extendedClass.prototype, name) || /* @__PURE__ */ Object.create(null)\n );\n }\n }\n}\nfunction getTableColumns(table) {\n return table[Table.Symbol.Columns];\n}\nfunction getViewSelectedFields(view) {\n return view[ViewBaseConfig].selectedFields;\n}\nfunction getTableLikeName(table) {\n return is(table, Subquery) ? table._.alias : is(table, View) ? table[ViewBaseConfig].name : is(table, SQL) ? void 0 : table[Table.Symbol.IsAlias] ? table[Table.Symbol.Name] : table[Table.Symbol.BaseName];\n}\nfunction getColumnNameAndConfig(a, b) {\n return {\n name: typeof a === \"string\" && a.length > 0 ? a : \"\",\n config: typeof a === \"object\" ? a : b\n };\n}\nconst _ = {};\nconst __ = {};\nfunction isConfig(data) {\n if (typeof data !== \"object\" || data === null) return false;\n if (data.constructor.name !== \"Object\") return false;\n if (\"logger\" in data) {\n const type = typeof data[\"logger\"];\n if (type !== \"boolean\" && (type !== \"object\" || typeof data[\"logger\"][\"logQuery\"] !== \"function\") && type !== \"undefined\") return false;\n return true;\n }\n if (\"schema\" in data) {\n const type = typeof data[\"schema\"];\n if (type !== \"object\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"casing\" in data) {\n const type = typeof data[\"casing\"];\n if (type !== \"string\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"mode\" in data) {\n if (data[\"mode\"] !== \"default\" || data[\"mode\"] !== \"planetscale\" || data[\"mode\"] !== void 0) return false;\n return true;\n }\n if (\"connection\" in data) {\n const type = typeof data[\"connection\"];\n if (type !== \"string\" && type !== \"object\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"client\" in data) {\n const type = typeof data[\"client\"];\n if (type !== \"object\" && type !== \"function\" && type !== \"undefined\") return false;\n return true;\n }\n if (Object.keys(data).length === 0) return true;\n return false;\n}\nconst textDecoder = typeof TextDecoder === \"undefined\" ? null : new TextDecoder();\nexport {\n applyMixins,\n getColumnNameAndConfig,\n getTableColumns,\n getTableLikeName,\n getViewSelectedFields,\n haveSameKeys,\n isConfig,\n mapResultRow,\n mapUpdateSet,\n orderSelectedFields,\n textDecoder\n};\n//# sourceMappingURL=utils.js.map","import { blob } from \"./blob.js\";\nimport { customType } from \"./custom.js\";\nimport { integer } from \"./integer.js\";\nimport { numeric } from \"./numeric.js\";\nimport { real } from \"./real.js\";\nimport { text } from \"./text.js\";\nfunction getSQLiteColumnBuilders() {\n return {\n blob,\n customType,\n integer,\n numeric,\n real,\n text\n };\n}\nexport {\n getSQLiteColumnBuilders\n};\n//# sourceMappingURL=all.js.map","import { ColumnBuilder } from \"../../column-builder.js\";\nimport { Column } from \"../../column.js\";\nimport { entityKind, is } from \"../../entity.js\";\nimport { ForeignKeyBuilder } from \"../foreign-keys.js\";\nimport { iife } from \"../../tracing-utils.js\";\nimport { uniqueKeyName } from \"../unique-constraint.js\";\nimport { makePgArray, parsePgArray } from \"../utils/array.js\";\nclass PgColumnBuilder extends ColumnBuilder {\n foreignKeyConfigs = [];\n static [entityKind] = \"PgColumnBuilder\";\n array(size) {\n return new PgArrayBuilder(this.config.name, this, size);\n }\n references(ref, actions = {}) {\n this.foreignKeyConfigs.push({ ref, actions });\n return this;\n }\n unique(name, config) {\n this.config.isUnique = true;\n this.config.uniqueName = name;\n this.config.uniqueType = config?.nulls;\n return this;\n }\n generatedAlwaysAs(as) {\n this.config.generated = {\n as,\n type: \"always\",\n mode: \"stored\"\n };\n return this;\n }\n /** @internal */\n buildForeignKeys(column, table) {\n return this.foreignKeyConfigs.map(({ ref, actions }) => {\n return iife(\n (ref2, actions2) => {\n const builder = new ForeignKeyBuilder(() => {\n const foreignColumn = ref2();\n return { columns: [column], foreignColumns: [foreignColumn] };\n });\n if (actions2.onUpdate) {\n builder.onUpdate(actions2.onUpdate);\n }\n if (actions2.onDelete) {\n builder.onDelete(actions2.onDelete);\n }\n return builder.build(table);\n },\n ref,\n actions\n );\n });\n }\n /** @internal */\n buildExtraConfigColumn(table) {\n return new ExtraConfigColumn(table, this.config);\n }\n}\nclass PgColumn extends Column {\n constructor(table, config) {\n if (!config.uniqueName) {\n config.uniqueName = uniqueKeyName(table, [config.name]);\n }\n super(table, config);\n this.table = table;\n }\n static [entityKind] = \"PgColumn\";\n}\nclass ExtraConfigColumn extends PgColumn {\n static [entityKind] = \"ExtraConfigColumn\";\n getSQLType() {\n return this.getSQLType();\n }\n indexConfig = {\n order: this.config.order ?? \"asc\",\n nulls: this.config.nulls ?? \"last\",\n opClass: this.config.opClass\n };\n defaultConfig = {\n order: \"asc\",\n nulls: \"last\",\n opClass: void 0\n };\n asc() {\n this.indexConfig.order = \"asc\";\n return this;\n }\n desc() {\n this.indexConfig.order = \"desc\";\n return this;\n }\n nullsFirst() {\n this.indexConfig.nulls = \"first\";\n return this;\n }\n nullsLast() {\n this.indexConfig.nulls = \"last\";\n return this;\n }\n /**\n * ### PostgreSQL documentation quote\n *\n * > An operator class with optional parameters can be specified for each column of an index.\n * The operator class identifies the operators to be used by the index for that column.\n * For example, a B-tree index on four-byte integers would use the int4_ops class;\n * this operator class includes comparison functions for four-byte integers.\n * In practice the default operator class for the column's data type is usually sufficient.\n * The main point of having operator classes is that for some data types, there could be more than one meaningful ordering.\n * For example, we might want to sort a complex-number data type either by absolute value or by real part.\n * We could do this by defining two operator classes for the data type and then selecting the proper class when creating an index.\n * More information about operator classes check:\n *\n * ### Useful links\n * https://www.postgresql.org/docs/current/sql-createindex.html\n *\n * https://www.postgresql.org/docs/current/indexes-opclass.html\n *\n * https://www.postgresql.org/docs/current/xindex.html\n *\n * ### Additional types\n * If you have the `pg_vector` extension installed in your database, you can use the\n * `vector_l2_ops`, `vector_ip_ops`, `vector_cosine_ops`, `vector_l1_ops`, `bit_hamming_ops`, `bit_jaccard_ops`, `halfvec_l2_ops`, `sparsevec_l2_ops` options, which are predefined types.\n *\n * **You can always specify any string you want in the operator class, in case Drizzle doesn't have it natively in its types**\n *\n * @param opClass\n * @returns\n */\n op(opClass) {\n this.indexConfig.opClass = opClass;\n return this;\n }\n}\nclass IndexedColumn {\n static [entityKind] = \"IndexedColumn\";\n constructor(name, keyAsName, type, indexConfig) {\n this.name = name;\n this.keyAsName = keyAsName;\n this.type = type;\n this.indexConfig = indexConfig;\n }\n name;\n keyAsName;\n type;\n indexConfig;\n}\nclass PgArrayBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgArrayBuilder\";\n constructor(name, baseBuilder, size) {\n super(name, \"array\", \"PgArray\");\n this.config.baseBuilder = baseBuilder;\n this.config.size = size;\n }\n /** @internal */\n build(table) {\n const baseColumn = this.config.baseBuilder.build(table);\n return new PgArray(\n table,\n this.config,\n baseColumn\n );\n }\n}\nclass PgArray extends PgColumn {\n constructor(table, config, baseColumn, range) {\n super(table, config);\n this.baseColumn = baseColumn;\n this.range = range;\n this.size = config.size;\n }\n size;\n static [entityKind] = \"PgArray\";\n getSQLType() {\n return `${this.baseColumn.getSQLType()}[${typeof this.size === \"number\" ? this.size : \"\"}]`;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n value = parsePgArray(value);\n }\n return value.map((v) => this.baseColumn.mapFromDriverValue(v));\n }\n mapToDriverValue(value, isNestedArray = false) {\n const a = value.map(\n (v) => v === null ? null : is(this.baseColumn, PgArray) ? this.baseColumn.mapToDriverValue(v, true) : this.baseColumn.mapToDriverValue(v)\n );\n if (isNestedArray) return a;\n return makePgArray(a);\n }\n}\nexport {\n ExtraConfigColumn,\n IndexedColumn,\n PgArray,\n PgArrayBuilder,\n PgColumn,\n PgColumnBuilder\n};\n//# sourceMappingURL=common.js.map","import { entityKind, is } from \"../entity.js\";\nimport { isPgEnum } from \"../pg-core/columns/enum.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { tracer } from \"../tracing.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { Column } from \"../column.js\";\nimport { IsAlias, Table } from \"../table.js\";\nclass FakePrimitiveParam {\n static [entityKind] = \"FakePrimitiveParam\";\n}\nfunction isSQLWrapper(value) {\n return value !== null && value !== void 0 && typeof value.getSQL === \"function\";\n}\nfunction mergeQueries(queries) {\n const result = { sql: \"\", params: [] };\n for (const query of queries) {\n result.sql += query.sql;\n result.params.push(...query.params);\n if (query.typings?.length) {\n if (!result.typings) {\n result.typings = [];\n }\n result.typings.push(...query.typings);\n }\n }\n return result;\n}\nclass StringChunk {\n static [entityKind] = \"StringChunk\";\n value;\n constructor(value) {\n this.value = Array.isArray(value) ? value : [value];\n }\n getSQL() {\n return new SQL([this]);\n }\n}\nclass SQL {\n constructor(queryChunks) {\n this.queryChunks = queryChunks;\n for (const chunk of queryChunks) {\n if (is(chunk, Table)) {\n const schemaName = chunk[Table.Symbol.Schema];\n this.usedTables.push(\n schemaName === void 0 ? chunk[Table.Symbol.Name] : schemaName + \".\" + chunk[Table.Symbol.Name]\n );\n }\n }\n }\n static [entityKind] = \"SQL\";\n /** @internal */\n decoder = noopDecoder;\n shouldInlineParams = false;\n /** @internal */\n usedTables = [];\n append(query) {\n this.queryChunks.push(...query.queryChunks);\n return this;\n }\n toQuery(config) {\n return tracer.startActiveSpan(\"drizzle.buildSQL\", (span) => {\n const query = this.buildQueryFromSourceParams(this.queryChunks, config);\n span?.setAttributes({\n \"drizzle.query.text\": query.sql,\n \"drizzle.query.params\": JSON.stringify(query.params)\n });\n return query;\n });\n }\n buildQueryFromSourceParams(chunks, _config) {\n const config = Object.assign({}, _config, {\n inlineParams: _config.inlineParams || this.shouldInlineParams,\n paramStartIndex: _config.paramStartIndex || { value: 0 }\n });\n const {\n casing,\n escapeName,\n escapeParam,\n prepareTyping,\n inlineParams,\n paramStartIndex\n } = config;\n return mergeQueries(chunks.map((chunk) => {\n if (is(chunk, StringChunk)) {\n return { sql: chunk.value.join(\"\"), params: [] };\n }\n if (is(chunk, Name)) {\n return { sql: escapeName(chunk.value), params: [] };\n }\n if (chunk === void 0) {\n return { sql: \"\", params: [] };\n }\n if (Array.isArray(chunk)) {\n const result = [new StringChunk(\"(\")];\n for (const [i, p] of chunk.entries()) {\n result.push(p);\n if (i < chunk.length - 1) {\n result.push(new StringChunk(\", \"));\n }\n }\n result.push(new StringChunk(\")\"));\n return this.buildQueryFromSourceParams(result, config);\n }\n if (is(chunk, SQL)) {\n return this.buildQueryFromSourceParams(chunk.queryChunks, {\n ...config,\n inlineParams: inlineParams || chunk.shouldInlineParams\n });\n }\n if (is(chunk, Table)) {\n const schemaName = chunk[Table.Symbol.Schema];\n const tableName = chunk[Table.Symbol.Name];\n return {\n sql: schemaName === void 0 || chunk[IsAlias] ? escapeName(tableName) : escapeName(schemaName) + \".\" + escapeName(tableName),\n params: []\n };\n }\n if (is(chunk, Column)) {\n const columnName = casing.getColumnCasing(chunk);\n if (_config.invokeSource === \"indexes\") {\n return { sql: escapeName(columnName), params: [] };\n }\n const schemaName = chunk.table[Table.Symbol.Schema];\n return {\n sql: chunk.table[IsAlias] || schemaName === void 0 ? escapeName(chunk.table[Table.Symbol.Name]) + \".\" + escapeName(columnName) : escapeName(schemaName) + \".\" + escapeName(chunk.table[Table.Symbol.Name]) + \".\" + escapeName(columnName),\n params: []\n };\n }\n if (is(chunk, View)) {\n const schemaName = chunk[ViewBaseConfig].schema;\n const viewName = chunk[ViewBaseConfig].name;\n return {\n sql: schemaName === void 0 || chunk[ViewBaseConfig].isAlias ? escapeName(viewName) : escapeName(schemaName) + \".\" + escapeName(viewName),\n params: []\n };\n }\n if (is(chunk, Param)) {\n if (is(chunk.value, Placeholder)) {\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }\n const mappedValue = chunk.value === null ? null : chunk.encoder.mapToDriverValue(chunk.value);\n if (is(mappedValue, SQL)) {\n return this.buildQueryFromSourceParams([mappedValue], config);\n }\n if (inlineParams) {\n return { sql: this.mapInlineParam(mappedValue, config), params: [] };\n }\n let typings = [\"none\"];\n if (prepareTyping) {\n typings = [prepareTyping(chunk.encoder)];\n }\n return { sql: escapeParam(paramStartIndex.value++, mappedValue), params: [mappedValue], typings };\n }\n if (is(chunk, Placeholder)) {\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }\n if (is(chunk, SQL.Aliased) && chunk.fieldAlias !== void 0) {\n return { sql: escapeName(chunk.fieldAlias), params: [] };\n }\n if (is(chunk, Subquery)) {\n if (chunk._.isWith) {\n return { sql: escapeName(chunk._.alias), params: [] };\n }\n return this.buildQueryFromSourceParams([\n new StringChunk(\"(\"),\n chunk._.sql,\n new StringChunk(\") \"),\n new Name(chunk._.alias)\n ], config);\n }\n if (isPgEnum(chunk)) {\n if (chunk.schema) {\n return { sql: escapeName(chunk.schema) + \".\" + escapeName(chunk.enumName), params: [] };\n }\n return { sql: escapeName(chunk.enumName), params: [] };\n }\n if (isSQLWrapper(chunk)) {\n if (chunk.shouldOmitSQLParens?.()) {\n return this.buildQueryFromSourceParams([chunk.getSQL()], config);\n }\n return this.buildQueryFromSourceParams([\n new StringChunk(\"(\"),\n chunk.getSQL(),\n new StringChunk(\")\")\n ], config);\n }\n if (inlineParams) {\n return { sql: this.mapInlineParam(chunk, config), params: [] };\n }\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }));\n }\n mapInlineParam(chunk, { escapeString }) {\n if (chunk === null) {\n return \"null\";\n }\n if (typeof chunk === \"number\" || typeof chunk === \"boolean\") {\n return chunk.toString();\n }\n if (typeof chunk === \"string\") {\n return escapeString(chunk);\n }\n if (typeof chunk === \"object\") {\n const mappedValueAsString = chunk.toString();\n if (mappedValueAsString === \"[object Object]\") {\n return escapeString(JSON.stringify(chunk));\n }\n return escapeString(mappedValueAsString);\n }\n throw new Error(\"Unexpected param value: \" + chunk);\n }\n getSQL() {\n return this;\n }\n as(alias) {\n if (alias === void 0) {\n return this;\n }\n return new SQL.Aliased(this, alias);\n }\n mapWith(decoder) {\n this.decoder = typeof decoder === \"function\" ? { mapFromDriverValue: decoder } : decoder;\n return this;\n }\n inlineParams() {\n this.shouldInlineParams = true;\n return this;\n }\n /**\n * This method is used to conditionally include a part of the query.\n *\n * @param condition - Condition to check\n * @returns itself if the condition is `true`, otherwise `undefined`\n */\n if(condition) {\n return condition ? this : void 0;\n }\n}\nclass Name {\n constructor(value) {\n this.value = value;\n }\n static [entityKind] = \"Name\";\n brand;\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction name(value) {\n return new Name(value);\n}\nfunction isDriverValueEncoder(value) {\n return typeof value === \"object\" && value !== null && \"mapToDriverValue\" in value && typeof value.mapToDriverValue === \"function\";\n}\nconst noopDecoder = {\n mapFromDriverValue: (value) => value\n};\nconst noopEncoder = {\n mapToDriverValue: (value) => value\n};\nconst noopMapper = {\n ...noopDecoder,\n ...noopEncoder\n};\nclass Param {\n /**\n * @param value - Parameter value\n * @param encoder - Encoder to convert the value to a driver parameter\n */\n constructor(value, encoder = noopEncoder) {\n this.value = value;\n this.encoder = encoder;\n }\n static [entityKind] = \"Param\";\n brand;\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction param(value, encoder) {\n return new Param(value, encoder);\n}\nfunction sql(strings, ...params) {\n const queryChunks = [];\n if (params.length > 0 || strings.length > 0 && strings[0] !== \"\") {\n queryChunks.push(new StringChunk(strings[0]));\n }\n for (const [paramIndex, param2] of params.entries()) {\n queryChunks.push(param2, new StringChunk(strings[paramIndex + 1]));\n }\n return new SQL(queryChunks);\n}\n((sql2) => {\n function empty() {\n return new SQL([]);\n }\n sql2.empty = empty;\n function fromList(list) {\n return new SQL(list);\n }\n sql2.fromList = fromList;\n function raw(str) {\n return new SQL([new StringChunk(str)]);\n }\n sql2.raw = raw;\n function join(chunks, separator) {\n const result = [];\n for (const [i, chunk] of chunks.entries()) {\n if (i > 0 && separator !== void 0) {\n result.push(separator);\n }\n result.push(chunk);\n }\n return new SQL(result);\n }\n sql2.join = join;\n function identifier(value) {\n return new Name(value);\n }\n sql2.identifier = identifier;\n function placeholder2(name2) {\n return new Placeholder(name2);\n }\n sql2.placeholder = placeholder2;\n function param2(value, encoder) {\n return new Param(value, encoder);\n }\n sql2.param = param2;\n})(sql || (sql = {}));\n((SQL2) => {\n class Aliased {\n constructor(sql2, fieldAlias) {\n this.sql = sql2;\n this.fieldAlias = fieldAlias;\n }\n static [entityKind] = \"SQL.Aliased\";\n /** @internal */\n isSelectionField = false;\n getSQL() {\n return this.sql;\n }\n /** @internal */\n clone() {\n return new Aliased(this.sql, this.fieldAlias);\n }\n }\n SQL2.Aliased = Aliased;\n})(SQL || (SQL = {}));\nclass Placeholder {\n constructor(name2) {\n this.name = name2;\n }\n static [entityKind] = \"Placeholder\";\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction placeholder(name2) {\n return new Placeholder(name2);\n}\nfunction fillPlaceholders(params, values) {\n return params.map((p) => {\n if (is(p, Placeholder)) {\n if (!(p.name in values)) {\n throw new Error(`No value for placeholder \"${p.name}\" was provided`);\n }\n return values[p.name];\n }\n if (is(p, Param) && is(p.value, Placeholder)) {\n if (!(p.value.name in values)) {\n throw new Error(`No value for placeholder \"${p.value.name}\" was provided`);\n }\n return p.encoder.mapToDriverValue(values[p.value.name]);\n }\n return p;\n });\n}\nconst IsDrizzleView = Symbol.for(\"drizzle:IsDrizzleView\");\nclass View {\n static [entityKind] = \"View\";\n /** @internal */\n [ViewBaseConfig];\n /** @internal */\n [IsDrizzleView] = true;\n constructor({ name: name2, schema, selectedFields, query }) {\n this[ViewBaseConfig] = {\n name: name2,\n originalName: name2,\n schema,\n selectedFields,\n query,\n isExisting: !query,\n isAlias: false\n };\n }\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction isView(view) {\n return typeof view === \"object\" && view !== null && IsDrizzleView in view;\n}\nfunction getViewName(view) {\n return view[ViewBaseConfig].name;\n}\nColumn.prototype.getSQL = function() {\n return new SQL([this]);\n};\nTable.prototype.getSQL = function() {\n return new SQL([this]);\n};\nSubquery.prototype.getSQL = function() {\n return new SQL([this]);\n};\nexport {\n FakePrimitiveParam,\n Name,\n Param,\n Placeholder,\n SQL,\n StringChunk,\n View,\n fillPlaceholders,\n getViewName,\n isDriverValueEncoder,\n isSQLWrapper,\n isView,\n name,\n noopDecoder,\n noopEncoder,\n noopMapper,\n param,\n placeholder,\n sql\n};\n//# sourceMappingURL=sql.js.map","import { entityKind } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQLiteTable } from \"../table.js\";\nimport { Table } from \"../../table.js\";\nimport { orderSelectedFields } from \"../../utils.js\";\nimport { extractUsedTable } from \"../utils.js\";\nclass SQLiteDeleteBase extends QueryPromise {\n constructor(table, session, dialect, withList) {\n super();\n this.table = table;\n this.session = session;\n this.dialect = dialect;\n this.config = { table, withList };\n }\n static [entityKind] = \"SQLiteDelete\";\n /** @internal */\n config;\n /**\n * Adds a `where` clause to the query.\n *\n * Calling this method will delete only those rows that fulfill a specified condition.\n *\n * See docs: {@link https://orm.drizzle.team/docs/delete}\n *\n * @param where the `where` clause.\n *\n * @example\n * You can use conditional operators and `sql function` to filter the rows to be deleted.\n *\n * ```ts\n * // Delete all cars with green color\n * db.delete(cars).where(eq(cars.color, 'green'));\n * // or\n * db.delete(cars).where(sql`${cars.color} = 'green'`)\n * ```\n *\n * You can logically combine conditional operators with `and()` and `or()` operators:\n *\n * ```ts\n * // Delete all BMW cars with a green color\n * db.delete(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n *\n * // Delete all cars with the green or blue color\n * db.delete(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n * ```\n */\n where(where) {\n this.config.where = where;\n return this;\n }\n orderBy(...columns) {\n if (typeof columns[0] === \"function\") {\n const orderBy = columns[0](\n new Proxy(\n this.config.table[Table.Symbol.Columns],\n new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n )\n );\n const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n this.config.orderBy = orderByArray;\n } else {\n const orderByArray = columns;\n this.config.orderBy = orderByArray;\n }\n return this;\n }\n limit(limit) {\n this.config.limit = limit;\n return this;\n }\n returning(fields = this.table[SQLiteTable.Symbol.Columns]) {\n this.config.returning = orderSelectedFields(fields);\n return this;\n }\n /** @internal */\n getSQL() {\n return this.dialect.buildDeleteQuery(this.config);\n }\n toSQL() {\n const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n return rest;\n }\n /** @internal */\n _prepare(isOneTimeQuery = true) {\n return this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n this.dialect.sqlToQuery(this.getSQL()),\n this.config.returning,\n this.config.returning ? \"all\" : \"run\",\n true,\n void 0,\n {\n type: \"delete\",\n tables: extractUsedTable(this.config.table)\n }\n );\n }\n prepare() {\n return this._prepare(false);\n }\n run = (placeholderValues) => {\n return this._prepare().run(placeholderValues);\n };\n all = (placeholderValues) => {\n return this._prepare().all(placeholderValues);\n };\n get = (placeholderValues) => {\n return this._prepare().get(placeholderValues);\n };\n values = (placeholderValues) => {\n return this._prepare().values(placeholderValues);\n };\n async execute(placeholderValues) {\n return this._prepare().execute(placeholderValues);\n }\n $dynamic() {\n return this;\n }\n}\nexport {\n SQLiteDeleteBase\n};\n//# sourceMappingURL=delete.js.map","import { entityKind, is } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { Param, SQL, sql } from \"../../sql/sql.js\";\nimport { SQLiteTable } from \"../table.js\";\nimport { Columns, Table } from \"../../table.js\";\nimport { haveSameKeys, mapUpdateSet, orderSelectedFields } from \"../../utils.js\";\nimport { extractUsedTable } from \"../utils.js\";\nimport { QueryBuilder } from \"./query-builder.js\";\nclass SQLiteInsertBuilder {\n constructor(table, session, dialect, withList) {\n this.table = table;\n this.session = session;\n this.dialect = dialect;\n this.withList = withList;\n }\n static [entityKind] = \"SQLiteInsertBuilder\";\n values(values) {\n values = Array.isArray(values) ? values : [values];\n if (values.length === 0) {\n throw new Error(\"values() must be called with at least one value\");\n }\n const mappedValues = values.map((entry) => {\n const result = {};\n const cols = this.table[Table.Symbol.Columns];\n for (const colKey of Object.keys(entry)) {\n const colValue = entry[colKey];\n result[colKey] = is(colValue, SQL) ? colValue : new Param(colValue, cols[colKey]);\n }\n return result;\n });\n return new SQLiteInsertBase(this.table, mappedValues, this.session, this.dialect, this.withList);\n }\n select(selectQuery) {\n const select = typeof selectQuery === \"function\" ? selectQuery(new QueryBuilder()) : selectQuery;\n if (!is(select, SQL) && !haveSameKeys(this.table[Columns], select._.selectedFields)) {\n throw new Error(\n \"Insert select error: selected fields are not the same or are in a different order compared to the table definition\"\n );\n }\n return new SQLiteInsertBase(this.table, select, this.session, this.dialect, this.withList, true);\n }\n}\nclass SQLiteInsertBase extends QueryPromise {\n constructor(table, values, session, dialect, withList, select) {\n super();\n this.session = session;\n this.dialect = dialect;\n this.config = { table, values, withList, select };\n }\n static [entityKind] = \"SQLiteInsert\";\n /** @internal */\n config;\n returning(fields = this.config.table[SQLiteTable.Symbol.Columns]) {\n this.config.returning = orderSelectedFields(fields);\n return this;\n }\n /**\n * Adds an `on conflict do nothing` clause to the query.\n *\n * Calling this method simply avoids inserting a row as its alternative action.\n *\n * See docs: {@link https://orm.drizzle.team/docs/insert#on-conflict-do-nothing}\n *\n * @param config The `target` and `where` clauses.\n *\n * @example\n * ```ts\n * // Insert one row and cancel the insert if there's a conflict\n * await db.insert(cars)\n * .values({ id: 1, brand: 'BMW' })\n * .onConflictDoNothing();\n *\n * // Explicitly specify conflict target\n * await db.insert(cars)\n * .values({ id: 1, brand: 'BMW' })\n * .onConflictDoNothing({ target: cars.id });\n * ```\n */\n onConflictDoNothing(config = {}) {\n if (!this.config.onConflict) this.config.onConflict = [];\n if (config.target === void 0) {\n this.config.onConflict.push(sql` on conflict do nothing`);\n } else {\n const targetSql = Array.isArray(config.target) ? sql`${config.target}` : sql`${[config.target]}`;\n const whereSql = config.where ? sql` where ${config.where}` : sql``;\n this.config.onConflict.push(sql` on conflict ${targetSql} do nothing${whereSql}`);\n }\n return this;\n }\n /**\n * Adds an `on conflict do update` clause to the query.\n *\n * Calling this method will update the existing row that conflicts with the row proposed for insertion as its alternative action.\n *\n * See docs: {@link https://orm.drizzle.team/docs/insert#upserts-and-conflicts}\n *\n * @param config The `target`, `set` and `where` clauses.\n *\n * @example\n * ```ts\n * // Update the row if there's a conflict\n * await db.insert(cars)\n * .values({ id: 1, brand: 'BMW' })\n * .onConflictDoUpdate({\n * target: cars.id,\n * set: { brand: 'Porsche' }\n * });\n *\n * // Upsert with 'where' clause\n * await db.insert(cars)\n * .values({ id: 1, brand: 'BMW' })\n * .onConflictDoUpdate({\n * target: cars.id,\n * set: { brand: 'newBMW' },\n * where: sql`${cars.createdAt} > '2023-01-01'::date`,\n * });\n * ```\n */\n onConflictDoUpdate(config) {\n if (config.where && (config.targetWhere || config.setWhere)) {\n throw new Error(\n 'You cannot use both \"where\" and \"targetWhere\"/\"setWhere\" at the same time - \"where\" is deprecated, use \"targetWhere\" or \"setWhere\" instead.'\n );\n }\n if (!this.config.onConflict) this.config.onConflict = [];\n const whereSql = config.where ? sql` where ${config.where}` : void 0;\n const targetWhereSql = config.targetWhere ? sql` where ${config.targetWhere}` : void 0;\n const setWhereSql = config.setWhere ? sql` where ${config.setWhere}` : void 0;\n const targetSql = Array.isArray(config.target) ? sql`${config.target}` : sql`${[config.target]}`;\n const setSql = this.dialect.buildUpdateSet(this.config.table, mapUpdateSet(this.config.table, config.set));\n this.config.onConflict.push(\n sql` on conflict ${targetSql}${targetWhereSql} do update set ${setSql}${whereSql}${setWhereSql}`\n );\n return this;\n }\n /** @internal */\n getSQL() {\n return this.dialect.buildInsertQuery(this.config);\n }\n toSQL() {\n const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n return rest;\n }\n /** @internal */\n _prepare(isOneTimeQuery = true) {\n return this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n this.dialect.sqlToQuery(this.getSQL()),\n this.config.returning,\n this.config.returning ? \"all\" : \"run\",\n true,\n void 0,\n {\n type: \"insert\",\n tables: extractUsedTable(this.config.table)\n }\n );\n }\n prepare() {\n return this._prepare(false);\n }\n run = (placeholderValues) => {\n return this._prepare().run(placeholderValues);\n };\n all = (placeholderValues) => {\n return this._prepare().all(placeholderValues);\n };\n get = (placeholderValues) => {\n return this._prepare().get(placeholderValues);\n };\n values = (placeholderValues) => {\n return this._prepare().values(placeholderValues);\n };\n async execute() {\n return this.config.returning ? this.all() : this.run();\n }\n $dynamic() {\n return this;\n }\n}\nexport {\n SQLiteInsertBase,\n SQLiteInsertBuilder\n};\n//# sourceMappingURL=insert.js.map","import { NoopCache } from \"../cache/core/index.js\";\nimport { entityKind } from \"../entity.js\";\nimport { NoopLogger } from \"../logger.js\";\nimport { fillPlaceholders, sql } from \"../sql/sql.js\";\nimport { SQLiteTransaction } from \"../sqlite-core/index.js\";\nimport {\n SQLitePreparedQuery as PreparedQueryBase,\n SQLiteSession\n} from \"../sqlite-core/session.js\";\nimport { mapResultRow } from \"../utils.js\";\nclass BetterSQLiteSession extends SQLiteSession {\n constructor(client, dialect, schema, options = {}) {\n super(dialect);\n this.client = client;\n this.schema = schema;\n this.logger = options.logger ?? new NoopLogger();\n this.cache = options.cache ?? new NoopCache();\n }\n static [entityKind] = \"BetterSQLiteSession\";\n logger;\n cache;\n prepareQuery(query, fields, executeMethod, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {\n const stmt = this.client.prepare(query.sql);\n return new PreparedQuery(\n stmt,\n query,\n this.logger,\n this.cache,\n queryMetadata,\n cacheConfig,\n fields,\n executeMethod,\n isResponseInArrayMode,\n customResultMapper\n );\n }\n transaction(transaction, config = {}) {\n const tx = new BetterSQLiteTransaction(\"sync\", this.dialect, this, this.schema);\n const nativeTx = this.client.transaction(transaction);\n return nativeTx[config.behavior ?? \"deferred\"](tx);\n }\n}\nclass BetterSQLiteTransaction extends SQLiteTransaction {\n static [entityKind] = \"BetterSQLiteTransaction\";\n transaction(transaction) {\n const savepointName = `sp${this.nestedIndex}`;\n const tx = new BetterSQLiteTransaction(\"sync\", this.dialect, this.session, this.schema, this.nestedIndex + 1);\n this.session.run(sql.raw(`savepoint ${savepointName}`));\n try {\n const result = transaction(tx);\n this.session.run(sql.raw(`release savepoint ${savepointName}`));\n return result;\n } catch (err) {\n this.session.run(sql.raw(`rollback to savepoint ${savepointName}`));\n throw err;\n }\n }\n}\nclass PreparedQuery extends PreparedQueryBase {\n constructor(stmt, query, logger, cache, queryMetadata, cacheConfig, fields, executeMethod, _isResponseInArrayMode, customResultMapper) {\n super(\"sync\", executeMethod, query, cache, queryMetadata, cacheConfig);\n this.stmt = stmt;\n this.logger = logger;\n this.fields = fields;\n this._isResponseInArrayMode = _isResponseInArrayMode;\n this.customResultMapper = customResultMapper;\n }\n static [entityKind] = \"BetterSQLitePreparedQuery\";\n run(placeholderValues) {\n const params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n this.logger.logQuery(this.query.sql, params);\n return this.stmt.run(...params);\n }\n all(placeholderValues) {\n const { fields, joinsNotNullableMap, query, logger, stmt, customResultMapper } = this;\n if (!fields && !customResultMapper) {\n const params = fillPlaceholders(query.params, placeholderValues ?? {});\n logger.logQuery(query.sql, params);\n return stmt.all(...params);\n }\n const rows = this.values(placeholderValues);\n if (customResultMapper) {\n return customResultMapper(rows);\n }\n return rows.map((row) => mapResultRow(fields, row, joinsNotNullableMap));\n }\n get(placeholderValues) {\n const params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n this.logger.logQuery(this.query.sql, params);\n const { fields, stmt, joinsNotNullableMap, customResultMapper } = this;\n if (!fields && !customResultMapper) {\n return stmt.get(...params);\n }\n const row = stmt.raw().get(...params);\n if (!row) {\n return void 0;\n }\n if (customResultMapper) {\n return customResultMapper([row]);\n }\n return mapResultRow(fields, row, joinsNotNullableMap);\n }\n values(placeholderValues) {\n const params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n this.logger.logQuery(this.query.sql, params);\n return this.stmt.raw().all(...params);\n }\n /** @internal */\n isResponseInArrayMode() {\n return this._isResponseInArrayMode;\n }\n}\nexport {\n BetterSQLiteSession,\n BetterSQLiteTransaction,\n PreparedQuery\n};\n//# sourceMappingURL=session.js.map","import Client from \"better-sqlite3\";\nimport { entityKind } from \"../entity.js\";\nimport { DefaultLogger } from \"../logger.js\";\nimport {\n createTableRelationsHelpers,\n extractTablesRelationalConfig\n} from \"../relations.js\";\nimport { BaseSQLiteDatabase } from \"../sqlite-core/db.js\";\nimport { SQLiteSyncDialect } from \"../sqlite-core/dialect.js\";\nimport { isConfig } from \"../utils.js\";\nimport { BetterSQLiteSession } from \"./session.js\";\nclass BetterSQLite3Database extends BaseSQLiteDatabase {\n static [entityKind] = \"BetterSQLite3Database\";\n}\nfunction construct(client, config = {}) {\n const dialect = new SQLiteSyncDialect({ casing: config.casing });\n let logger;\n if (config.logger === true) {\n logger = new DefaultLogger();\n } else if (config.logger !== false) {\n logger = config.logger;\n }\n let schema;\n if (config.schema) {\n const tablesConfig = extractTablesRelationalConfig(\n config.schema,\n createTableRelationsHelpers\n );\n schema = {\n fullSchema: config.schema,\n schema: tablesConfig.tables,\n tableNamesMap: tablesConfig.tableNamesMap\n };\n }\n const session = new BetterSQLiteSession(client, dialect, schema, { logger });\n const db = new BetterSQLite3Database(\"sync\", dialect, session, schema);\n db.$client = client;\n return db;\n}\nfunction drizzle(...params) {\n if (params[0] === void 0 || typeof params[0] === \"string\") {\n const instance = params[0] === void 0 ? new Client() : new Client(params[0]);\n return construct(instance, params[1]);\n }\n if (isConfig(params[0])) {\n const { connection, client, ...drizzleConfig } = params[0];\n if (client) return construct(client, drizzleConfig);\n if (typeof connection === \"object\") {\n const { source, ...options } = connection;\n const instance2 = new Client(source, options);\n return construct(instance2, drizzleConfig);\n }\n const instance = new Client(connection);\n return construct(instance, drizzleConfig);\n }\n return construct(params[0], params[1]);\n}\n((drizzle2) => {\n function mock(config) {\n return construct({}, config);\n }\n drizzle2.mock = mock;\n})(drizzle || (drizzle = {}));\nexport {\n BetterSQLite3Database,\n drizzle\n};\n//# sourceMappingURL=driver.js.map","import { is } from \"../entity.js\";\nimport { SQL } from \"../sql/sql.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { Table } from \"../table.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { CheckBuilder } from \"./checks.js\";\nimport { ForeignKeyBuilder } from \"./foreign-keys.js\";\nimport { IndexBuilder } from \"./indexes.js\";\nimport { PrimaryKeyBuilder } from \"./primary-keys.js\";\nimport { SQLiteTable } from \"./table.js\";\nimport { UniqueConstraintBuilder } from \"./unique-constraint.js\";\nfunction getTableConfig(table) {\n const columns = Object.values(table[SQLiteTable.Symbol.Columns]);\n const indexes = [];\n const checks = [];\n const primaryKeys = [];\n const uniqueConstraints = [];\n const foreignKeys = Object.values(table[SQLiteTable.Symbol.InlineForeignKeys]);\n const name = table[Table.Symbol.Name];\n const extraConfigBuilder = table[SQLiteTable.Symbol.ExtraConfigBuilder];\n if (extraConfigBuilder !== void 0) {\n const extraConfig = extraConfigBuilder(table[SQLiteTable.Symbol.Columns]);\n const extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) : Object.values(extraConfig);\n for (const builder of Object.values(extraValues)) {\n if (is(builder, IndexBuilder)) {\n indexes.push(builder.build(table));\n } else if (is(builder, CheckBuilder)) {\n checks.push(builder.build(table));\n } else if (is(builder, UniqueConstraintBuilder)) {\n uniqueConstraints.push(builder.build(table));\n } else if (is(builder, PrimaryKeyBuilder)) {\n primaryKeys.push(builder.build(table));\n } else if (is(builder, ForeignKeyBuilder)) {\n foreignKeys.push(builder.build(table));\n }\n }\n }\n return {\n columns,\n indexes,\n foreignKeys,\n checks,\n primaryKeys,\n uniqueConstraints,\n name\n };\n}\nfunction extractUsedTable(table) {\n if (is(table, SQLiteTable)) {\n return [`${table[Table.Symbol.BaseName]}`];\n }\n if (is(table, Subquery)) {\n return table._.usedTables ?? [];\n }\n if (is(table, SQL)) {\n return table.usedTables ?? [];\n }\n return [];\n}\nfunction getViewConfig(view) {\n return {\n ...view[ViewBaseConfig]\n // ...view[SQLiteViewConfig],\n };\n}\nexport {\n extractUsedTable,\n getTableConfig,\n getViewConfig\n};\n//# sourceMappingURL=utils.js.map","import { Column } from \"../../column.js\";\nimport { is } from \"../../entity.js\";\nimport { Table } from \"../../table.js\";\nimport {\n isDriverValueEncoder,\n isSQLWrapper,\n Param,\n Placeholder,\n SQL,\n sql,\n StringChunk,\n View\n} from \"../sql.js\";\nfunction bindIfParam(value, column) {\n if (isDriverValueEncoder(column) && !isSQLWrapper(value) && !is(value, Param) && !is(value, Placeholder) && !is(value, Column) && !is(value, Table) && !is(value, View)) {\n return new Param(value, column);\n }\n return value;\n}\nconst eq = (left, right) => {\n return sql`${left} = ${bindIfParam(right, left)}`;\n};\nconst ne = (left, right) => {\n return sql`${left} <> ${bindIfParam(right, left)}`;\n};\nfunction and(...unfilteredConditions) {\n const conditions = unfilteredConditions.filter(\n (c) => c !== void 0\n );\n if (conditions.length === 0) {\n return void 0;\n }\n if (conditions.length === 1) {\n return new SQL(conditions);\n }\n return new SQL([\n new StringChunk(\"(\"),\n sql.join(conditions, new StringChunk(\" and \")),\n new StringChunk(\")\")\n ]);\n}\nfunction or(...unfilteredConditions) {\n const conditions = unfilteredConditions.filter(\n (c) => c !== void 0\n );\n if (conditions.length === 0) {\n return void 0;\n }\n if (conditions.length === 1) {\n return new SQL(conditions);\n }\n return new SQL([\n new StringChunk(\"(\"),\n sql.join(conditions, new StringChunk(\" or \")),\n new StringChunk(\")\")\n ]);\n}\nfunction not(condition) {\n return sql`not ${condition}`;\n}\nconst gt = (left, right) => {\n return sql`${left} > ${bindIfParam(right, left)}`;\n};\nconst gte = (left, right) => {\n return sql`${left} >= ${bindIfParam(right, left)}`;\n};\nconst lt = (left, right) => {\n return sql`${left} < ${bindIfParam(right, left)}`;\n};\nconst lte = (left, right) => {\n return sql`${left} <= ${bindIfParam(right, left)}`;\n};\nfunction inArray(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n return sql`false`;\n }\n return sql`${column} in ${values.map((v) => bindIfParam(v, column))}`;\n }\n return sql`${column} in ${bindIfParam(values, column)}`;\n}\nfunction notInArray(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n return sql`true`;\n }\n return sql`${column} not in ${values.map((v) => bindIfParam(v, column))}`;\n }\n return sql`${column} not in ${bindIfParam(values, column)}`;\n}\nfunction isNull(value) {\n return sql`${value} is null`;\n}\nfunction isNotNull(value) {\n return sql`${value} is not null`;\n}\nfunction exists(subquery) {\n return sql`exists ${subquery}`;\n}\nfunction notExists(subquery) {\n return sql`not exists ${subquery}`;\n}\nfunction between(column, min, max) {\n return sql`${column} between ${bindIfParam(min, column)} and ${bindIfParam(\n max,\n column\n )}`;\n}\nfunction notBetween(column, min, max) {\n return sql`${column} not between ${bindIfParam(\n min,\n column\n )} and ${bindIfParam(max, column)}`;\n}\nfunction like(column, value) {\n return sql`${column} like ${value}`;\n}\nfunction notLike(column, value) {\n return sql`${column} not like ${value}`;\n}\nfunction ilike(column, value) {\n return sql`${column} ilike ${value}`;\n}\nfunction notIlike(column, value) {\n return sql`${column} not ilike ${value}`;\n}\nfunction arrayContains(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayContains requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} @> ${array}`;\n }\n return sql`${column} @> ${bindIfParam(values, column)}`;\n}\nfunction arrayContained(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayContained requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} <@ ${array}`;\n }\n return sql`${column} <@ ${bindIfParam(values, column)}`;\n}\nfunction arrayOverlaps(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayOverlaps requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} && ${array}`;\n }\n return sql`${column} && ${bindIfParam(values, column)}`;\n}\nexport {\n and,\n arrayContained,\n arrayContains,\n arrayOverlaps,\n between,\n bindIfParam,\n eq,\n exists,\n gt,\n gte,\n ilike,\n inArray,\n isNotNull,\n isNull,\n like,\n lt,\n lte,\n ne,\n not,\n notBetween,\n notExists,\n notIlike,\n notInArray,\n notLike,\n or\n};\n//# sourceMappingURL=conditions.js.map","import { entityKind, is } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQLiteTable } from \"../table.js\";\nimport { Subquery } from \"../../subquery.js\";\nimport { Table } from \"../../table.js\";\nimport {\n getTableLikeName,\n mapUpdateSet,\n orderSelectedFields\n} from \"../../utils.js\";\nimport { ViewBaseConfig } from \"../../view-common.js\";\nimport { extractUsedTable } from \"../utils.js\";\nimport { SQLiteViewBase } from \"../view-base.js\";\nclass SQLiteUpdateBuilder {\n constructor(table, session, dialect, withList) {\n this.table = table;\n this.session = session;\n this.dialect = dialect;\n this.withList = withList;\n }\n static [entityKind] = \"SQLiteUpdateBuilder\";\n set(values) {\n return new SQLiteUpdateBase(\n this.table,\n mapUpdateSet(this.table, values),\n this.session,\n this.dialect,\n this.withList\n );\n }\n}\nclass SQLiteUpdateBase extends QueryPromise {\n constructor(table, set, session, dialect, withList) {\n super();\n this.session = session;\n this.dialect = dialect;\n this.config = { set, table, withList, joins: [] };\n }\n static [entityKind] = \"SQLiteUpdate\";\n /** @internal */\n config;\n from(source) {\n this.config.from = source;\n return this;\n }\n createJoin(joinType) {\n return (table, on) => {\n const tableName = getTableLikeName(table);\n if (typeof tableName === \"string\" && this.config.joins.some((join) => join.alias === tableName)) {\n throw new Error(`Alias \"${tableName}\" is already used in this query`);\n }\n if (typeof on === \"function\") {\n const from = this.config.from ? is(table, SQLiteTable) ? table[Table.Symbol.Columns] : is(table, Subquery) ? table._.selectedFields : is(table, SQLiteViewBase) ? table[ViewBaseConfig].selectedFields : void 0 : void 0;\n on = on(\n new Proxy(\n this.config.table[Table.Symbol.Columns],\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n ),\n from && new Proxy(\n from,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n this.config.joins.push({ on, table, joinType, alias: tableName });\n return this;\n };\n }\n leftJoin = this.createJoin(\"left\");\n rightJoin = this.createJoin(\"right\");\n innerJoin = this.createJoin(\"inner\");\n fullJoin = this.createJoin(\"full\");\n /**\n * Adds a 'where' clause to the query.\n *\n * Calling this method will update only those rows that fulfill a specified condition.\n *\n * See docs: {@link https://orm.drizzle.team/docs/update}\n *\n * @param where the 'where' clause.\n *\n * @example\n * You can use conditional operators and `sql function` to filter the rows to be updated.\n *\n * ```ts\n * // Update all cars with green color\n * db.update(cars).set({ color: 'red' })\n * .where(eq(cars.color, 'green'));\n * // or\n * db.update(cars).set({ color: 'red' })\n * .where(sql`${cars.color} = 'green'`)\n * ```\n *\n * You can logically combine conditional operators with `and()` and `or()` operators:\n *\n * ```ts\n * // Update all BMW cars with a green color\n * db.update(cars).set({ color: 'red' })\n * .where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n *\n * // Update all cars with the green or blue color\n * db.update(cars).set({ color: 'red' })\n * .where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n * ```\n */\n where(where) {\n this.config.where = where;\n return this;\n }\n orderBy(...columns) {\n if (typeof columns[0] === \"function\") {\n const orderBy = columns[0](\n new Proxy(\n this.config.table[Table.Symbol.Columns],\n new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n )\n );\n const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n this.config.orderBy = orderByArray;\n } else {\n const orderByArray = columns;\n this.config.orderBy = orderByArray;\n }\n return this;\n }\n limit(limit) {\n this.config.limit = limit;\n return this;\n }\n returning(fields = this.config.table[SQLiteTable.Symbol.Columns]) {\n this.config.returning = orderSelectedFields(fields);\n return this;\n }\n /** @internal */\n getSQL() {\n return this.dialect.buildUpdateQuery(this.config);\n }\n toSQL() {\n const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n return rest;\n }\n /** @internal */\n _prepare(isOneTimeQuery = true) {\n return this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n this.dialect.sqlToQuery(this.getSQL()),\n this.config.returning,\n this.config.returning ? \"all\" : \"run\",\n true,\n void 0,\n {\n type: \"insert\",\n tables: extractUsedTable(this.config.table)\n }\n );\n }\n prepare() {\n return this._prepare(false);\n }\n run = (placeholderValues) => {\n return this._prepare().run(placeholderValues);\n };\n all = (placeholderValues) => {\n return this._prepare().all(placeholderValues);\n };\n get = (placeholderValues) => {\n return this._prepare().get(placeholderValues);\n };\n values = (placeholderValues) => {\n return this._prepare().values(placeholderValues);\n };\n async execute() {\n return this.config.returning ? this.all() : this.run();\n }\n $dynamic() {\n return this;\n }\n}\nexport {\n SQLiteUpdateBase,\n SQLiteUpdateBuilder\n};\n//# sourceMappingURL=update.js.map","import { entityKind } from \"../entity.js\";\nimport { SelectionProxyHandler } from \"../selection-proxy.js\";\nimport { sql } from \"../sql/sql.js\";\nimport {\n QueryBuilder,\n SQLiteDeleteBase,\n SQLiteInsertBuilder,\n SQLiteSelectBuilder,\n SQLiteUpdateBuilder\n} from \"./query-builders/index.js\";\nimport { WithSubquery } from \"../subquery.js\";\nimport { SQLiteCountBuilder } from \"./query-builders/count.js\";\nimport { RelationalQueryBuilder } from \"./query-builders/query.js\";\nimport { SQLiteRaw } from \"./query-builders/raw.js\";\nclass BaseSQLiteDatabase {\n constructor(resultKind, dialect, session, schema) {\n this.resultKind = resultKind;\n this.dialect = dialect;\n this.session = session;\n this._ = schema ? {\n schema: schema.schema,\n fullSchema: schema.fullSchema,\n tableNamesMap: schema.tableNamesMap\n } : {\n schema: void 0,\n fullSchema: {},\n tableNamesMap: {}\n };\n this.query = {};\n const query = this.query;\n if (this._.schema) {\n for (const [tableName, columns] of Object.entries(this._.schema)) {\n query[tableName] = new RelationalQueryBuilder(\n resultKind,\n schema.fullSchema,\n this._.schema,\n this._.tableNamesMap,\n schema.fullSchema[tableName],\n columns,\n dialect,\n session\n );\n }\n }\n this.$cache = { invalidate: async (_params) => {\n } };\n }\n static [entityKind] = \"BaseSQLiteDatabase\";\n query;\n /**\n * Creates a subquery that defines a temporary named result set as a CTE.\n *\n * It is useful for breaking down complex queries into simpler parts and for reusing the result set in subsequent parts of the query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#with-clause}\n *\n * @param alias The alias for the subquery.\n *\n * Failure to provide an alias will result in a DrizzleTypeError, preventing the subquery from being referenced in other queries.\n *\n * @example\n *\n * ```ts\n * // Create a subquery with alias 'sq' and use it in the select query\n * const sq = db.$with('sq').as(db.select().from(users).where(eq(users.id, 42)));\n *\n * const result = await db.with(sq).select().from(sq);\n * ```\n *\n * To select arbitrary SQL values as fields in a CTE and reference them in other CTEs or in the main query, you need to add aliases to them:\n *\n * ```ts\n * // Select an arbitrary SQL value as a field in a CTE and reference it in the main query\n * const sq = db.$with('sq').as(db.select({\n * name: sql<string>`upper(${users.name})`.as('name'),\n * })\n * .from(users));\n *\n * const result = await db.with(sq).select({ name: sq.name }).from(sq);\n * ```\n */\n $with = (alias, selection) => {\n const self = this;\n const as = (qb) => {\n if (typeof qb === \"function\") {\n qb = qb(new QueryBuilder(self.dialect));\n }\n return new Proxy(\n new WithSubquery(\n qb.getSQL(),\n selection ?? (\"getSelectedFields\" in qb ? qb.getSelectedFields() ?? {} : {}),\n alias,\n true\n ),\n new SelectionProxyHandler({ alias, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n );\n };\n return { as };\n };\n $count(source, filters) {\n return new SQLiteCountBuilder({ source, filters, session: this.session });\n }\n /**\n * Incorporates a previously defined CTE (using `$with`) into the main query.\n *\n * This method allows the main query to reference a temporary named result set.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#with-clause}\n *\n * @param queries The CTEs to incorporate into the main query.\n *\n * @example\n *\n * ```ts\n * // Define a subquery 'sq' as a CTE using $with\n * const sq = db.$with('sq').as(db.select().from(users).where(eq(users.id, 42)));\n *\n * // Incorporate the CTE 'sq' into the main query and select from it\n * const result = await db.with(sq).select().from(sq);\n * ```\n */\n with(...queries) {\n const self = this;\n function select(fields) {\n return new SQLiteSelectBuilder({\n fields: fields ?? void 0,\n session: self.session,\n dialect: self.dialect,\n withList: queries\n });\n }\n function selectDistinct(fields) {\n return new SQLiteSelectBuilder({\n fields: fields ?? void 0,\n session: self.session,\n dialect: self.dialect,\n withList: queries,\n distinct: true\n });\n }\n function update(table) {\n return new SQLiteUpdateBuilder(table, self.session, self.dialect, queries);\n }\n function insert(into) {\n return new SQLiteInsertBuilder(into, self.session, self.dialect, queries);\n }\n function delete_(from) {\n return new SQLiteDeleteBase(from, self.session, self.dialect, queries);\n }\n return { select, selectDistinct, update, insert, delete: delete_ };\n }\n select(fields) {\n return new SQLiteSelectBuilder({ fields: fields ?? void 0, session: this.session, dialect: this.dialect });\n }\n selectDistinct(fields) {\n return new SQLiteSelectBuilder({\n fields: fields ?? void 0,\n session: this.session,\n dialect: this.dialect,\n distinct: true\n });\n }\n /**\n * Creates an update query.\n *\n * Calling this method without `.where()` clause will update all rows in a table. The `.where()` clause specifies which rows should be updated.\n *\n * Use `.set()` method to specify which values to update.\n *\n * See docs: {@link https://orm.drizzle.team/docs/update}\n *\n * @param table The table to update.\n *\n * @example\n *\n * ```ts\n * // Update all rows in the 'cars' table\n * await db.update(cars).set({ color: 'red' });\n *\n * // Update rows with filters and conditions\n * await db.update(cars).set({ color: 'red' }).where(eq(cars.brand, 'BMW'));\n *\n * // Update with returning clause\n * const updatedCar: Car[] = await db.update(cars)\n * .set({ color: 'red' })\n * .where(eq(cars.id, 1))\n * .returning();\n * ```\n */\n update(table) {\n return new SQLiteUpdateBuilder(table, this.session, this.dialect);\n }\n $cache;\n /**\n * Creates an insert query.\n *\n * Calling this method will create new rows in a table. Use `.values()` method to specify which values to insert.\n *\n * See docs: {@link https://orm.drizzle.team/docs/insert}\n *\n * @param table The table to insert into.\n *\n * @example\n *\n * ```ts\n * // Insert one row\n * await db.insert(cars).values({ brand: 'BMW' });\n *\n * // Insert multiple rows\n * await db.insert(cars).values([{ brand: 'BMW' }, { brand: 'Porsche' }]);\n *\n * // Insert with returning clause\n * const insertedCar: Car[] = await db.insert(cars)\n * .values({ brand: 'BMW' })\n * .returning();\n * ```\n */\n insert(into) {\n return new SQLiteInsertBuilder(into, this.session, this.dialect);\n }\n /**\n * Creates a delete query.\n *\n * Calling this method without `.where()` clause will delete all rows in a table. The `.where()` clause specifies which rows should be deleted.\n *\n * See docs: {@link https://orm.drizzle.team/docs/delete}\n *\n * @param table The table to delete from.\n *\n * @example\n *\n * ```ts\n * // Delete all rows in the 'cars' table\n * await db.delete(cars);\n *\n * // Delete rows with filters and conditions\n * await db.delete(cars).where(eq(cars.color, 'green'));\n *\n * // Delete with returning clause\n * const deletedCar: Car[] = await db.delete(cars)\n * .where(eq(cars.id, 1))\n * .returning();\n * ```\n */\n delete(from) {\n return new SQLiteDeleteBase(from, this.session, this.dialect);\n }\n run(query) {\n const sequel = typeof query === \"string\" ? sql.raw(query) : query.getSQL();\n if (this.resultKind === \"async\") {\n return new SQLiteRaw(\n async () => this.session.run(sequel),\n () => sequel,\n \"run\",\n this.dialect,\n this.session.extractRawRunValueFromBatchResult.bind(this.session)\n );\n }\n return this.session.run(sequel);\n }\n all(query) {\n const sequel = typeof query === \"string\" ? sql.raw(query) : query.getSQL();\n if (this.resultKind === \"async\") {\n return new SQLiteRaw(\n async () => this.session.all(sequel),\n () => sequel,\n \"all\",\n this.dialect,\n this.session.extractRawAllValueFromBatchResult.bind(this.session)\n );\n }\n return this.session.all(sequel);\n }\n get(query) {\n const sequel = typeof query === \"string\" ? sql.raw(query) : query.getSQL();\n if (this.resultKind === \"async\") {\n return new SQLiteRaw(\n async () => this.session.get(sequel),\n () => sequel,\n \"get\",\n this.dialect,\n this.session.extractRawGetValueFromBatchResult.bind(this.session)\n );\n }\n return this.session.get(sequel);\n }\n values(query) {\n const sequel = typeof query === \"string\" ? sql.raw(query) : query.getSQL();\n if (this.resultKind === \"async\") {\n return new SQLiteRaw(\n async () => this.session.values(sequel),\n () => sequel,\n \"values\",\n this.dialect,\n this.session.extractRawValuesValueFromBatchResult.bind(this.session)\n );\n }\n return this.session.values(sequel);\n }\n transaction(transaction, config) {\n return this.session.transaction(transaction, config);\n }\n}\nconst withReplicas = (primary, replicas, getReplica = () => replicas[Math.floor(Math.random() * replicas.length)]) => {\n const select = (...args) => getReplica(replicas).select(...args);\n const selectDistinct = (...args) => getReplica(replicas).selectDistinct(...args);\n const $count = (...args) => getReplica(replicas).$count(...args);\n const $with = (...args) => getReplica(replicas).with(...args);\n const update = (...args) => primary.update(...args);\n const insert = (...args) => primary.insert(...args);\n const $delete = (...args) => primary.delete(...args);\n const run = (...args) => primary.run(...args);\n const all = (...args) => primary.all(...args);\n const get = (...args) => primary.get(...args);\n const values = (...args) => primary.values(...args);\n const transaction = (...args) => primary.transaction(...args);\n return {\n ...primary,\n update,\n insert,\n delete: $delete,\n run,\n all,\n get,\n values,\n transaction,\n $primary: primary,\n $replicas: replicas,\n select,\n selectDistinct,\n $count,\n with: $with,\n get query() {\n return getReplica(replicas).query;\n }\n };\n};\nexport {\n BaseSQLiteDatabase,\n withReplicas\n};\n//# sourceMappingURL=db.js.map","import { entityKind, is } from \"../../entity.js\";\nimport { TypedQueryBuilder } from \"../../query-builders/query-builder.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQL, View } from \"../../sql/sql.js\";\nimport { Subquery } from \"../../subquery.js\";\nimport { Table } from \"../../table.js\";\nimport {\n applyMixins,\n getTableColumns,\n getTableLikeName,\n haveSameKeys,\n orderSelectedFields\n} from \"../../utils.js\";\nimport { ViewBaseConfig } from \"../../view-common.js\";\nimport { extractUsedTable } from \"../utils.js\";\nimport { SQLiteViewBase } from \"../view-base.js\";\nclass SQLiteSelectBuilder {\n static [entityKind] = \"SQLiteSelectBuilder\";\n fields;\n session;\n dialect;\n withList;\n distinct;\n constructor(config) {\n this.fields = config.fields;\n this.session = config.session;\n this.dialect = config.dialect;\n this.withList = config.withList;\n this.distinct = config.distinct;\n }\n from(source) {\n const isPartialSelect = !!this.fields;\n let fields;\n if (this.fields) {\n fields = this.fields;\n } else if (is(source, Subquery)) {\n fields = Object.fromEntries(\n Object.keys(source._.selectedFields).map((key) => [key, source[key]])\n );\n } else if (is(source, SQLiteViewBase)) {\n fields = source[ViewBaseConfig].selectedFields;\n } else if (is(source, SQL)) {\n fields = {};\n } else {\n fields = getTableColumns(source);\n }\n return new SQLiteSelectBase({\n table: source,\n fields,\n isPartialSelect,\n session: this.session,\n dialect: this.dialect,\n withList: this.withList,\n distinct: this.distinct\n });\n }\n}\nclass SQLiteSelectQueryBuilderBase extends TypedQueryBuilder {\n static [entityKind] = \"SQLiteSelectQueryBuilder\";\n _;\n /** @internal */\n config;\n joinsNotNullableMap;\n tableName;\n isPartialSelect;\n session;\n dialect;\n cacheConfig = void 0;\n usedTables = /* @__PURE__ */ new Set();\n constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct }) {\n super();\n this.config = {\n withList,\n table,\n fields: { ...fields },\n distinct,\n setOperators: []\n };\n this.isPartialSelect = isPartialSelect;\n this.session = session;\n this.dialect = dialect;\n this._ = {\n selectedFields: fields,\n config: this.config\n };\n this.tableName = getTableLikeName(table);\n this.joinsNotNullableMap = typeof this.tableName === \"string\" ? { [this.tableName]: true } : {};\n for (const item of extractUsedTable(table)) this.usedTables.add(item);\n }\n /** @internal */\n getUsedTables() {\n return [...this.usedTables];\n }\n createJoin(joinType) {\n return (table, on) => {\n const baseTableName = this.tableName;\n const tableName = getTableLikeName(table);\n for (const item of extractUsedTable(table)) this.usedTables.add(item);\n if (typeof tableName === \"string\" && this.config.joins?.some((join) => join.alias === tableName)) {\n throw new Error(`Alias \"${tableName}\" is already used in this query`);\n }\n if (!this.isPartialSelect) {\n if (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === \"string\") {\n this.config.fields = {\n [baseTableName]: this.config.fields\n };\n }\n if (typeof tableName === \"string\" && !is(table, SQL)) {\n const selection = is(table, Subquery) ? table._.selectedFields : is(table, View) ? table[ViewBaseConfig].selectedFields : table[Table.Symbol.Columns];\n this.config.fields[tableName] = selection;\n }\n }\n if (typeof on === \"function\") {\n on = on(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n if (!this.config.joins) {\n this.config.joins = [];\n }\n this.config.joins.push({ on, table, joinType, alias: tableName });\n if (typeof tableName === \"string\") {\n switch (joinType) {\n case \"left\": {\n this.joinsNotNullableMap[tableName] = false;\n break;\n }\n case \"right\": {\n this.joinsNotNullableMap = Object.fromEntries(\n Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n );\n this.joinsNotNullableMap[tableName] = true;\n break;\n }\n case \"cross\":\n case \"inner\": {\n this.joinsNotNullableMap[tableName] = true;\n break;\n }\n case \"full\": {\n this.joinsNotNullableMap = Object.fromEntries(\n Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n );\n this.joinsNotNullableMap[tableName] = false;\n break;\n }\n }\n }\n return this;\n };\n }\n /**\n * Executes a `left join` operation by adding another table to the current query.\n *\n * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()\n * .from(users)\n * .leftJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .leftJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n leftJoin = this.createJoin(\"left\");\n /**\n * Executes a `right join` operation by adding another table to the current query.\n *\n * Calling this method associates each row of the joined table with the corresponding row from the main table, if a match is found. If no matching row exists, it sets all columns of the main table to null.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()\n * .from(users)\n * .rightJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .rightJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n rightJoin = this.createJoin(\"right\");\n /**\n * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.\n *\n * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n * .from(users)\n * .innerJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .innerJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n innerJoin = this.createJoin(\"inner\");\n /**\n * Executes a `full join` operation by combining rows from two tables into a new table.\n *\n * Calling this method retrieves all rows from both main and joined tables, merging rows with matching values and filling in `null` for non-matching columns.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()\n * .from(users)\n * .fullJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .fullJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n fullJoin = this.createJoin(\"full\");\n /**\n * Executes a `cross join` operation by combining rows from two tables into a new table.\n *\n * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}\n *\n * @param table the table to join.\n *\n * @example\n *\n * ```ts\n * // Select all users, each user with every pet\n * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n * .from(users)\n * .crossJoin(pets)\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .crossJoin(pets)\n * ```\n */\n crossJoin = this.createJoin(\"cross\");\n createSetOperator(type, isAll) {\n return (rightSelection) => {\n const rightSelect = typeof rightSelection === \"function\" ? rightSelection(getSQLiteSetOperators()) : rightSelection;\n if (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {\n throw new Error(\n \"Set operator error (union / intersect / except): selected fields are not the same or are in a different order\"\n );\n }\n this.config.setOperators.push({ type, isAll, rightSelect });\n return this;\n };\n }\n /**\n * Adds `union` set operator to the query.\n *\n * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}\n *\n * @example\n *\n * ```ts\n * // Select all unique names from customers and users tables\n * await db.select({ name: users.name })\n * .from(users)\n * .union(\n * db.select({ name: customers.name }).from(customers)\n * );\n * // or\n * import { union } from 'drizzle-orm/sqlite-core'\n *\n * await union(\n * db.select({ name: users.name }).from(users),\n * db.select({ name: customers.name }).from(customers)\n * );\n * ```\n */\n union = this.createSetOperator(\"union\", false);\n /**\n * Adds `union all` set operator to the query.\n *\n * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}\n *\n * @example\n *\n * ```ts\n * // Select all transaction ids from both online and in-store sales\n * await db.select({ transaction: onlineSales.transactionId })\n * .from(onlineSales)\n * .unionAll(\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * // or\n * import { unionAll } from 'drizzle-orm/sqlite-core'\n *\n * await unionAll(\n * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * ```\n */\n unionAll = this.createSetOperator(\"union\", true);\n /**\n * Adds `intersect` set operator to the query.\n *\n * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}\n *\n * @example\n *\n * ```ts\n * // Select course names that are offered in both departments A and B\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .intersect(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * import { intersect } from 'drizzle-orm/sqlite-core'\n *\n * await intersect(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\n intersect = this.createSetOperator(\"intersect\", false);\n /**\n * Adds `except` set operator to the query.\n *\n * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}\n *\n * @example\n *\n * ```ts\n * // Select all courses offered in department A but not in department B\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .except(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * import { except } from 'drizzle-orm/sqlite-core'\n *\n * await except(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\n except = this.createSetOperator(\"except\", false);\n /** @internal */\n addSetOperators(setOperators) {\n this.config.setOperators.push(...setOperators);\n return this;\n }\n /**\n * Adds a `where` clause to the query.\n *\n * Calling this method will select only those rows that fulfill a specified condition.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#filtering}\n *\n * @param where the `where` clause.\n *\n * @example\n * You can use conditional operators and `sql function` to filter the rows to be selected.\n *\n * ```ts\n * // Select all cars with green color\n * await db.select().from(cars).where(eq(cars.color, 'green'));\n * // or\n * await db.select().from(cars).where(sql`${cars.color} = 'green'`)\n * ```\n *\n * You can logically combine conditional operators with `and()` and `or()` operators:\n *\n * ```ts\n * // Select all BMW cars with a green color\n * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n *\n * // Select all cars with the green or blue color\n * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n * ```\n */\n where(where) {\n if (typeof where === \"function\") {\n where = where(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n this.config.where = where;\n return this;\n }\n /**\n * Adds a `having` clause to the query.\n *\n * Calling this method will select only those rows that fulfill a specified condition. It is typically used with aggregate functions to filter the aggregated data based on a specified condition.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n *\n * @param having the `having` clause.\n *\n * @example\n *\n * ```ts\n * // Select all brands with more than one car\n * await db.select({\n * \tbrand: cars.brand,\n * \tcount: sql<number>`cast(count(${cars.id}) as int)`,\n * })\n * .from(cars)\n * .groupBy(cars.brand)\n * .having(({ count }) => gt(count, 1));\n * ```\n */\n having(having) {\n if (typeof having === \"function\") {\n having = having(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n this.config.having = having;\n return this;\n }\n groupBy(...columns) {\n if (typeof columns[0] === \"function\") {\n const groupBy = columns[0](\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n )\n );\n this.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];\n } else {\n this.config.groupBy = columns;\n }\n return this;\n }\n orderBy(...columns) {\n if (typeof columns[0] === \"function\") {\n const orderBy = columns[0](\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n )\n );\n const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).orderBy = orderByArray;\n } else {\n this.config.orderBy = orderByArray;\n }\n } else {\n const orderByArray = columns;\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).orderBy = orderByArray;\n } else {\n this.config.orderBy = orderByArray;\n }\n }\n return this;\n }\n /**\n * Adds a `limit` clause to the query.\n *\n * Calling this method will set the maximum number of rows that will be returned by this query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n *\n * @param limit the `limit` clause.\n *\n * @example\n *\n * ```ts\n * // Get the first 10 people from this query.\n * await db.select().from(people).limit(10);\n * ```\n */\n limit(limit) {\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).limit = limit;\n } else {\n this.config.limit = limit;\n }\n return this;\n }\n /**\n * Adds an `offset` clause to the query.\n *\n * Calling this method will skip a number of rows when returning results from this query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n *\n * @param offset the `offset` clause.\n *\n * @example\n *\n * ```ts\n * // Get the 10th-20th people from this query.\n * await db.select().from(people).offset(10).limit(10);\n * ```\n */\n offset(offset) {\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).offset = offset;\n } else {\n this.config.offset = offset;\n }\n return this;\n }\n /** @internal */\n getSQL() {\n return this.dialect.buildSelectQuery(this.config);\n }\n toSQL() {\n const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n return rest;\n }\n as(alias) {\n const usedTables = [];\n usedTables.push(...extractUsedTable(this.config.table));\n if (this.config.joins) {\n for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table));\n }\n return new Proxy(\n new Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]),\n new SelectionProxyHandler({ alias, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n );\n }\n /** @internal */\n getSelectedFields() {\n return new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n );\n }\n $dynamic() {\n return this;\n }\n}\nclass SQLiteSelectBase extends SQLiteSelectQueryBuilderBase {\n static [entityKind] = \"SQLiteSelect\";\n /** @internal */\n _prepare(isOneTimeQuery = true) {\n if (!this.session) {\n throw new Error(\"Cannot execute a query on a query builder. Please use a database instance instead.\");\n }\n const fieldsList = orderSelectedFields(this.config.fields);\n const query = this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n this.dialect.sqlToQuery(this.getSQL()),\n fieldsList,\n \"all\",\n true,\n void 0,\n {\n type: \"select\",\n tables: [...this.usedTables]\n },\n this.cacheConfig\n );\n query.joinsNotNullableMap = this.joinsNotNullableMap;\n return query;\n }\n $withCache(config) {\n this.cacheConfig = config === void 0 ? { config: {}, enable: true, autoInvalidate: true } : config === false ? { enable: false } : { enable: true, autoInvalidate: true, ...config };\n return this;\n }\n prepare() {\n return this._prepare(false);\n }\n run = (placeholderValues) => {\n return this._prepare().run(placeholderValues);\n };\n all = (placeholderValues) => {\n return this._prepare().all(placeholderValues);\n };\n get = (placeholderValues) => {\n return this._prepare().get(placeholderValues);\n };\n values = (placeholderValues) => {\n return this._prepare().values(placeholderValues);\n };\n async execute() {\n return this.all();\n }\n}\napplyMixins(SQLiteSelectBase, [QueryPromise]);\nfunction createSetOperator(type, isAll) {\n return (leftSelect, rightSelect, ...restSelects) => {\n const setOperators = [rightSelect, ...restSelects].map((select) => ({\n type,\n isAll,\n rightSelect: select\n }));\n for (const setOperator of setOperators) {\n if (!haveSameKeys(leftSelect.getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {\n throw new Error(\n \"Set operator error (union / intersect / except): selected fields are not the same or are in a different order\"\n );\n }\n }\n return leftSelect.addSetOperators(setOperators);\n };\n}\nconst getSQLiteSetOperators = () => ({\n union,\n unionAll,\n intersect,\n except\n});\nconst union = createSetOperator(\"union\", false);\nconst unionAll = createSetOperator(\"union\", true);\nconst intersect = createSetOperator(\"intersect\", false);\nconst except = createSetOperator(\"except\", false);\nexport {\n SQLiteSelectBase,\n SQLiteSelectBuilder,\n SQLiteSelectQueryBuilderBase,\n except,\n intersect,\n union,\n unionAll\n};\n//# sourceMappingURL=select.js.map","import { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from \"../alias.js\";\nimport { CasingCache } from \"../casing.js\";\nimport { Column } from \"../column.js\";\nimport { entityKind, is } from \"../entity.js\";\nimport { DrizzleError } from \"../errors.js\";\nimport {\n getOperators,\n getOrderByOperators,\n Many,\n normalizeRelation,\n One\n} from \"../relations.js\";\nimport { and, eq } from \"../sql/index.js\";\nimport { Param, SQL, sql } from \"../sql/sql.js\";\nimport { SQLiteColumn } from \"./columns/index.js\";\nimport { SQLiteTable } from \"./table.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { getTableName, getTableUniqueName, Table } from \"../table.js\";\nimport { orderSelectedFields } from \"../utils.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { SQLiteViewBase } from \"./view-base.js\";\nclass SQLiteDialect {\n static [entityKind] = \"SQLiteDialect\";\n /** @internal */\n casing;\n constructor(config) {\n this.casing = new CasingCache(config?.casing);\n }\n escapeName(name) {\n return `\"${name.replace(/\"/g, '\"\"')}\"`;\n }\n escapeParam(_num) {\n return \"?\";\n }\n escapeString(str) {\n return `'${str.replace(/'/g, \"''\")}'`;\n }\n buildWithCTE(queries) {\n if (!queries?.length) return void 0;\n const withSqlChunks = [sql`with `];\n for (const [i, w] of queries.entries()) {\n withSqlChunks.push(sql`${sql.identifier(w._.alias)} as (${w._.sql})`);\n if (i < queries.length - 1) {\n withSqlChunks.push(sql`, `);\n }\n }\n withSqlChunks.push(sql` `);\n return sql.join(withSqlChunks);\n }\n buildDeleteQuery({\n table,\n where,\n returning,\n withList,\n limit,\n orderBy\n }) {\n const withSql = this.buildWithCTE(withList);\n const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;\n const whereSql = where ? sql` where ${where}` : void 0;\n const orderBySql = this.buildOrderBy(orderBy);\n const limitSql = this.buildLimit(limit);\n return sql`${withSql}delete from ${table}${whereSql}${returningSql}${orderBySql}${limitSql}`;\n }\n buildUpdateSet(table, set) {\n const tableColumns = table[Table.Symbol.Columns];\n const columnNames = Object.keys(tableColumns).filter(\n (colName) => set[colName] !== void 0 || tableColumns[colName]?.onUpdateFn !== void 0\n );\n const setSize = columnNames.length;\n return sql.join(\n columnNames.flatMap((colName, i) => {\n const col = tableColumns[colName];\n const onUpdateFnResult = col.onUpdateFn?.();\n const value = set[colName] ?? (is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col));\n const res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;\n if (i < setSize - 1) {\n return [res, sql.raw(\", \")];\n }\n return [res];\n })\n );\n }\n buildUpdateQuery({\n table,\n set,\n where,\n returning,\n withList,\n joins,\n from,\n limit,\n orderBy\n }) {\n const withSql = this.buildWithCTE(withList);\n const setSql = this.buildUpdateSet(table, set);\n const fromSql = from && sql.join([sql.raw(\" from \"), this.buildFromTable(from)]);\n const joinsSql = this.buildJoins(joins);\n const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;\n const whereSql = where ? sql` where ${where}` : void 0;\n const orderBySql = this.buildOrderBy(orderBy);\n const limitSql = this.buildLimit(limit);\n return sql`${withSql}update ${table} set ${setSql}${fromSql}${joinsSql}${whereSql}${returningSql}${orderBySql}${limitSql}`;\n }\n /**\n * Builds selection SQL with provided fields/expressions\n *\n * Examples:\n *\n * `select <selection> from`\n *\n * `insert ... returning <selection>`\n *\n * If `isSingleTable` is true, then columns won't be prefixed with table name\n */\n buildSelection(fields, { isSingleTable = false } = {}) {\n const columnsLen = fields.length;\n const chunks = fields.flatMap(({ field }, i) => {\n const chunk = [];\n if (is(field, SQL.Aliased) && field.isSelectionField) {\n chunk.push(sql.identifier(field.fieldAlias));\n } else if (is(field, SQL.Aliased) || is(field, SQL)) {\n const query = is(field, SQL.Aliased) ? field.sql : field;\n if (isSingleTable) {\n chunk.push(\n new SQL(\n query.queryChunks.map((c) => {\n if (is(c, Column)) {\n return sql.identifier(this.casing.getColumnCasing(c));\n }\n return c;\n })\n )\n );\n } else {\n chunk.push(query);\n }\n if (is(field, SQL.Aliased)) {\n chunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);\n }\n } else if (is(field, Column)) {\n const tableName = field.table[Table.Symbol.Name];\n if (field.columnType === \"SQLiteNumericBigInt\") {\n if (isSingleTable) {\n chunk.push(\n sql`cast(${sql.identifier(this.casing.getColumnCasing(field))} as text)`\n );\n } else {\n chunk.push(\n sql`cast(${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))} as text)`\n );\n }\n } else {\n if (isSingleTable) {\n chunk.push(sql.identifier(this.casing.getColumnCasing(field)));\n } else {\n chunk.push(\n sql`${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))}`\n );\n }\n }\n } else if (is(field, Subquery)) {\n const entries = Object.entries(field._.selectedFields);\n if (entries.length === 1) {\n const entry = entries[0][1];\n const fieldDecoder = is(entry, SQL) ? entry.decoder : is(entry, Column) ? { mapFromDriverValue: (v) => entry.mapFromDriverValue(v) } : entry.sql.decoder;\n if (fieldDecoder) field._.sql.decoder = fieldDecoder;\n }\n chunk.push(field);\n }\n if (i < columnsLen - 1) {\n chunk.push(sql`, `);\n }\n return chunk;\n });\n return sql.join(chunks);\n }\n buildJoins(joins) {\n if (!joins || joins.length === 0) {\n return void 0;\n }\n const joinsArray = [];\n if (joins) {\n for (const [index, joinMeta] of joins.entries()) {\n if (index === 0) {\n joinsArray.push(sql` `);\n }\n const table = joinMeta.table;\n const onSql = joinMeta.on ? sql` on ${joinMeta.on}` : void 0;\n if (is(table, SQLiteTable)) {\n const tableName = table[SQLiteTable.Symbol.Name];\n const tableSchema = table[SQLiteTable.Symbol.Schema];\n const origTableName = table[SQLiteTable.Symbol.OriginalName];\n const alias = tableName === origTableName ? void 0 : joinMeta.alias;\n joinsArray.push(\n sql`${sql.raw(joinMeta.joinType)} join ${tableSchema ? sql`${sql.identifier(tableSchema)}.` : void 0}${sql.identifier(\n origTableName\n )}${alias && sql` ${sql.identifier(alias)}`}${onSql}`\n );\n } else {\n joinsArray.push(\n sql`${sql.raw(joinMeta.joinType)} join ${table}${onSql}`\n );\n }\n if (index < joins.length - 1) {\n joinsArray.push(sql` `);\n }\n }\n }\n return sql.join(joinsArray);\n }\n buildLimit(limit) {\n return typeof limit === \"object\" || typeof limit === \"number\" && limit >= 0 ? sql` limit ${limit}` : void 0;\n }\n buildOrderBy(orderBy) {\n const orderByList = [];\n if (orderBy) {\n for (const [index, orderByValue] of orderBy.entries()) {\n orderByList.push(orderByValue);\n if (index < orderBy.length - 1) {\n orderByList.push(sql`, `);\n }\n }\n }\n return orderByList.length > 0 ? sql` order by ${sql.join(orderByList)}` : void 0;\n }\n buildFromTable(table) {\n if (is(table, Table) && table[Table.Symbol.IsAlias]) {\n return sql`${sql`${sql.identifier(table[Table.Symbol.Schema] ?? \"\")}.`.if(table[Table.Symbol.Schema])}${sql.identifier(\n table[Table.Symbol.OriginalName]\n )} ${sql.identifier(table[Table.Symbol.Name])}`;\n }\n return table;\n }\n buildSelectQuery({\n withList,\n fields,\n fieldsFlat,\n where,\n having,\n table,\n joins,\n orderBy,\n groupBy,\n limit,\n offset,\n distinct,\n setOperators\n }) {\n const fieldsList = fieldsFlat ?? orderSelectedFields(fields);\n for (const f of fieldsList) {\n if (is(f.field, Column) && getTableName(f.field.table) !== (is(table, Subquery) ? table._.alias : is(table, SQLiteViewBase) ? table[ViewBaseConfig].name : is(table, SQL) ? void 0 : getTableName(table)) && !((table2) => joins?.some(\n ({ alias }) => alias === (table2[Table.Symbol.IsAlias] ? getTableName(table2) : table2[Table.Symbol.BaseName])\n ))(f.field.table)) {\n const tableName = getTableName(f.field.table);\n throw new Error(\n `Your \"${f.path.join(\n \"->\"\n )}\" field references a column \"${tableName}\".\"${f.field.name}\", but the table \"${tableName}\" is not part of the query! Did you forget to join it?`\n );\n }\n }\n const isSingleTable = !joins || joins.length === 0;\n const withSql = this.buildWithCTE(withList);\n const distinctSql = distinct ? sql` distinct` : void 0;\n const selection = this.buildSelection(fieldsList, { isSingleTable });\n const tableSql = this.buildFromTable(table);\n const joinsSql = this.buildJoins(joins);\n const whereSql = where ? sql` where ${where}` : void 0;\n const havingSql = having ? sql` having ${having}` : void 0;\n const groupByList = [];\n if (groupBy) {\n for (const [index, groupByValue] of groupBy.entries()) {\n groupByList.push(groupByValue);\n if (index < groupBy.length - 1) {\n groupByList.push(sql`, `);\n }\n }\n }\n const groupBySql = groupByList.length > 0 ? sql` group by ${sql.join(groupByList)}` : void 0;\n const orderBySql = this.buildOrderBy(orderBy);\n const limitSql = this.buildLimit(limit);\n const offsetSql = offset ? sql` offset ${offset}` : void 0;\n const finalQuery = sql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}`;\n if (setOperators.length > 0) {\n return this.buildSetOperations(finalQuery, setOperators);\n }\n return finalQuery;\n }\n buildSetOperations(leftSelect, setOperators) {\n const [setOperator, ...rest] = setOperators;\n if (!setOperator) {\n throw new Error(\"Cannot pass undefined values to any set operator\");\n }\n if (rest.length === 0) {\n return this.buildSetOperationQuery({ leftSelect, setOperator });\n }\n return this.buildSetOperations(\n this.buildSetOperationQuery({ leftSelect, setOperator }),\n rest\n );\n }\n buildSetOperationQuery({\n leftSelect,\n setOperator: { type, isAll, rightSelect, limit, orderBy, offset }\n }) {\n const leftChunk = sql`${leftSelect.getSQL()} `;\n const rightChunk = sql`${rightSelect.getSQL()}`;\n let orderBySql;\n if (orderBy && orderBy.length > 0) {\n const orderByValues = [];\n for (const singleOrderBy of orderBy) {\n if (is(singleOrderBy, SQLiteColumn)) {\n orderByValues.push(sql.identifier(singleOrderBy.name));\n } else if (is(singleOrderBy, SQL)) {\n for (let i = 0; i < singleOrderBy.queryChunks.length; i++) {\n const chunk = singleOrderBy.queryChunks[i];\n if (is(chunk, SQLiteColumn)) {\n singleOrderBy.queryChunks[i] = sql.identifier(\n this.casing.getColumnCasing(chunk)\n );\n }\n }\n orderByValues.push(sql`${singleOrderBy}`);\n } else {\n orderByValues.push(sql`${singleOrderBy}`);\n }\n }\n orderBySql = sql` order by ${sql.join(orderByValues, sql`, `)}`;\n }\n const limitSql = typeof limit === \"object\" || typeof limit === \"number\" && limit >= 0 ? sql` limit ${limit}` : void 0;\n const operatorChunk = sql.raw(`${type} ${isAll ? \"all \" : \"\"}`);\n const offsetSql = offset ? sql` offset ${offset}` : void 0;\n return sql`${leftChunk}${operatorChunk}${rightChunk}${orderBySql}${limitSql}${offsetSql}`;\n }\n buildInsertQuery({\n table,\n values: valuesOrSelect,\n onConflict,\n returning,\n withList,\n select\n }) {\n const valuesSqlList = [];\n const columns = table[Table.Symbol.Columns];\n const colEntries = Object.entries(columns).filter(\n ([_, col]) => !col.shouldDisableInsert()\n );\n const insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));\n if (select) {\n const select2 = valuesOrSelect;\n if (is(select2, SQL)) {\n valuesSqlList.push(select2);\n } else {\n valuesSqlList.push(select2.getSQL());\n }\n } else {\n const values = valuesOrSelect;\n valuesSqlList.push(sql.raw(\"values \"));\n for (const [valueIndex, value] of values.entries()) {\n const valueList = [];\n for (const [fieldName, col] of colEntries) {\n const colValue = value[fieldName];\n if (colValue === void 0 || is(colValue, Param) && colValue.value === void 0) {\n let defaultValue;\n if (col.default !== null && col.default !== void 0) {\n defaultValue = is(col.default, SQL) ? col.default : sql.param(col.default, col);\n } else if (col.defaultFn !== void 0) {\n const defaultFnResult = col.defaultFn();\n defaultValue = is(defaultFnResult, SQL) ? defaultFnResult : sql.param(defaultFnResult, col);\n } else if (!col.default && col.onUpdateFn !== void 0) {\n const onUpdateFnResult = col.onUpdateFn();\n defaultValue = is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col);\n } else {\n defaultValue = sql`null`;\n }\n valueList.push(defaultValue);\n } else {\n valueList.push(colValue);\n }\n }\n valuesSqlList.push(valueList);\n if (valueIndex < values.length - 1) {\n valuesSqlList.push(sql`, `);\n }\n }\n }\n const withSql = this.buildWithCTE(withList);\n const valuesSql = sql.join(valuesSqlList);\n const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;\n const onConflictSql = onConflict?.length ? sql.join(onConflict) : void 0;\n return sql`${withSql}insert into ${table} ${insertOrder} ${valuesSql}${onConflictSql}${returningSql}`;\n }\n sqlToQuery(sql2, invokeSource) {\n return sql2.toQuery({\n casing: this.casing,\n escapeName: this.escapeName,\n escapeParam: this.escapeParam,\n escapeString: this.escapeString,\n invokeSource\n });\n }\n buildRelationalQuery({\n fullSchema,\n schema,\n tableNamesMap,\n table,\n tableConfig,\n queryConfig: config,\n tableAlias,\n nestedQueryRelation,\n joinOn\n }) {\n let selection = [];\n let limit, offset, orderBy = [], where;\n const joins = [];\n if (config === true) {\n const selectionEntries = Object.entries(tableConfig.columns);\n selection = selectionEntries.map(([key, value]) => ({\n dbKey: value.name,\n tsKey: key,\n field: aliasedTableColumn(value, tableAlias),\n relationTableTsKey: void 0,\n isJson: false,\n selection: []\n }));\n } else {\n const aliasedColumns = Object.fromEntries(\n Object.entries(tableConfig.columns).map(([key, value]) => [\n key,\n aliasedTableColumn(value, tableAlias)\n ])\n );\n if (config.where) {\n const whereSql = typeof config.where === \"function\" ? config.where(aliasedColumns, getOperators()) : config.where;\n where = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);\n }\n const fieldsSelection = [];\n let selectedColumns = [];\n if (config.columns) {\n let isIncludeMode = false;\n for (const [field, value] of Object.entries(config.columns)) {\n if (value === void 0) {\n continue;\n }\n if (field in tableConfig.columns) {\n if (!isIncludeMode && value === true) {\n isIncludeMode = true;\n }\n selectedColumns.push(field);\n }\n }\n if (selectedColumns.length > 0) {\n selectedColumns = isIncludeMode ? selectedColumns.filter((c) => config.columns?.[c] === true) : Object.keys(tableConfig.columns).filter(\n (key) => !selectedColumns.includes(key)\n );\n }\n } else {\n selectedColumns = Object.keys(tableConfig.columns);\n }\n for (const field of selectedColumns) {\n const column = tableConfig.columns[field];\n fieldsSelection.push({ tsKey: field, value: column });\n }\n let selectedRelations = [];\n if (config.with) {\n selectedRelations = Object.entries(config.with).filter(\n (entry) => !!entry[1]\n ).map(([tsKey, queryConfig]) => ({\n tsKey,\n queryConfig,\n relation: tableConfig.relations[tsKey]\n }));\n }\n let extras;\n if (config.extras) {\n extras = typeof config.extras === \"function\" ? config.extras(aliasedColumns, { sql }) : config.extras;\n for (const [tsKey, value] of Object.entries(extras)) {\n fieldsSelection.push({\n tsKey,\n value: mapColumnsInAliasedSQLToAlias(value, tableAlias)\n });\n }\n }\n for (const { tsKey, value } of fieldsSelection) {\n selection.push({\n dbKey: is(value, SQL.Aliased) ? value.fieldAlias : tableConfig.columns[tsKey].name,\n tsKey,\n field: is(value, Column) ? aliasedTableColumn(value, tableAlias) : value,\n relationTableTsKey: void 0,\n isJson: false,\n selection: []\n });\n }\n let orderByOrig = typeof config.orderBy === \"function\" ? config.orderBy(aliasedColumns, getOrderByOperators()) : config.orderBy ?? [];\n if (!Array.isArray(orderByOrig)) {\n orderByOrig = [orderByOrig];\n }\n orderBy = orderByOrig.map((orderByValue) => {\n if (is(orderByValue, Column)) {\n return aliasedTableColumn(orderByValue, tableAlias);\n }\n return mapColumnsInSQLToAlias(orderByValue, tableAlias);\n });\n limit = config.limit;\n offset = config.offset;\n for (const {\n tsKey: selectedRelationTsKey,\n queryConfig: selectedRelationConfigValue,\n relation\n } of selectedRelations) {\n const normalizedRelation = normalizeRelation(\n schema,\n tableNamesMap,\n relation\n );\n const relationTableName = getTableUniqueName(relation.referencedTable);\n const relationTableTsName = tableNamesMap[relationTableName];\n const relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;\n const joinOn2 = and(\n ...normalizedRelation.fields.map(\n (field2, i) => eq(\n aliasedTableColumn(\n normalizedRelation.references[i],\n relationTableAlias\n ),\n aliasedTableColumn(field2, tableAlias)\n )\n )\n );\n const builtRelation = this.buildRelationalQuery({\n fullSchema,\n schema,\n tableNamesMap,\n table: fullSchema[relationTableTsName],\n tableConfig: schema[relationTableTsName],\n queryConfig: is(relation, One) ? selectedRelationConfigValue === true ? { limit: 1 } : { ...selectedRelationConfigValue, limit: 1 } : selectedRelationConfigValue,\n tableAlias: relationTableAlias,\n joinOn: joinOn2,\n nestedQueryRelation: relation\n });\n const field = sql`(${builtRelation.sql})`.as(selectedRelationTsKey);\n selection.push({\n dbKey: selectedRelationTsKey,\n tsKey: selectedRelationTsKey,\n field,\n relationTableTsKey: relationTableTsName,\n isJson: true,\n selection: builtRelation.selection\n });\n }\n }\n if (selection.length === 0) {\n throw new DrizzleError({\n message: `No fields selected for table \"${tableConfig.tsName}\" (\"${tableAlias}\"). You need to have at least one item in \"columns\", \"with\" or \"extras\". If you need to select all columns, omit the \"columns\" key or set it to undefined.`\n });\n }\n let result;\n where = and(joinOn, where);\n if (nestedQueryRelation) {\n let field = sql`json_array(${sql.join(\n selection.map(\n ({ field: field2 }) => is(field2, SQLiteColumn) ? sql.identifier(this.casing.getColumnCasing(field2)) : is(field2, SQL.Aliased) ? field2.sql : field2\n ),\n sql`, `\n )})`;\n if (is(nestedQueryRelation, Many)) {\n field = sql`coalesce(json_group_array(${field}), json_array())`;\n }\n const nestedSelection = [\n {\n dbKey: \"data\",\n tsKey: \"data\",\n field: field.as(\"data\"),\n isJson: true,\n relationTableTsKey: tableConfig.tsName,\n selection\n }\n ];\n const needsSubquery = limit !== void 0 || offset !== void 0 || orderBy.length > 0;\n if (needsSubquery) {\n result = this.buildSelectQuery({\n table: aliasedTable(table, tableAlias),\n fields: {},\n fieldsFlat: [\n {\n path: [],\n field: sql.raw(\"*\")\n }\n ],\n where,\n limit,\n offset,\n orderBy,\n setOperators: []\n });\n where = void 0;\n limit = void 0;\n offset = void 0;\n orderBy = void 0;\n } else {\n result = aliasedTable(table, tableAlias);\n }\n result = this.buildSelectQuery({\n table: is(result, SQLiteTable) ? result : new Subquery(result, {}, tableAlias),\n fields: {},\n fieldsFlat: nestedSelection.map(({ field: field2 }) => ({\n path: [],\n field: is(field2, Column) ? aliasedTableColumn(field2, tableAlias) : field2\n })),\n joins,\n where,\n limit,\n offset,\n orderBy,\n setOperators: []\n });\n } else {\n result = this.buildSelectQuery({\n table: aliasedTable(table, tableAlias),\n fields: {},\n fieldsFlat: selection.map(({ field }) => ({\n path: [],\n field: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field\n })),\n joins,\n where,\n limit,\n offset,\n orderBy,\n setOperators: []\n });\n }\n return {\n tableTsKey: tableConfig.tsName,\n sql: result,\n selection\n };\n }\n}\nclass SQLiteSyncDialect extends SQLiteDialect {\n static [entityKind] = \"SQLiteSyncDialect\";\n migrate(migrations, session, config) {\n const migrationsTable = config === void 0 ? \"__drizzle_migrations\" : typeof config === \"string\" ? \"__drizzle_migrations\" : config.migrationsTable ?? \"__drizzle_migrations\";\n const migrationTableCreate = sql`\n\t\t\tCREATE TABLE IF NOT EXISTS ${sql.identifier(migrationsTable)} (\n\t\t\t\tid SERIAL PRIMARY KEY,\n\t\t\t\thash text NOT NULL,\n\t\t\t\tcreated_at numeric\n\t\t\t)\n\t\t`;\n session.run(migrationTableCreate);\n const dbMigrations = session.values(\n sql`SELECT id, hash, created_at FROM ${sql.identifier(migrationsTable)} ORDER BY created_at DESC LIMIT 1`\n );\n const lastDbMigration = dbMigrations[0] ?? void 0;\n session.run(sql`BEGIN`);\n try {\n for (const migration of migrations) {\n if (!lastDbMigration || Number(lastDbMigration[2]) < migration.folderMillis) {\n for (const stmt of migration.sql) {\n session.run(sql.raw(stmt));\n }\n session.run(\n sql`INSERT INTO ${sql.identifier(\n migrationsTable\n )} (\"hash\", \"created_at\") VALUES(${migration.hash}, ${migration.folderMillis})`\n );\n }\n }\n session.run(sql`COMMIT`);\n } catch (e) {\n session.run(sql`ROLLBACK`);\n throw e;\n }\n }\n}\nclass SQLiteAsyncDialect extends SQLiteDialect {\n static [entityKind] = \"SQLiteAsyncDialect\";\n async migrate(migrations, session, config) {\n const migrationsTable = config === void 0 ? \"__drizzle_migrations\" : typeof config === \"string\" ? \"__drizzle_migrations\" : config.migrationsTable ?? \"__drizzle_migrations\";\n const migrationTableCreate = sql`\n\t\t\tCREATE TABLE IF NOT EXISTS ${sql.identifier(migrationsTable)} (\n\t\t\t\tid SERIAL PRIMARY KEY,\n\t\t\t\thash text NOT NULL,\n\t\t\t\tcreated_at numeric\n\t\t\t)\n\t\t`;\n await session.run(migrationTableCreate);\n const dbMigrations = await session.values(\n sql`SELECT id, hash, created_at FROM ${sql.identifier(migrationsTable)} ORDER BY created_at DESC LIMIT 1`\n );\n const lastDbMigration = dbMigrations[0] ?? void 0;\n await session.transaction(async (tx) => {\n for (const migration of migrations) {\n if (!lastDbMigration || Number(lastDbMigration[2]) < migration.folderMillis) {\n for (const stmt of migration.sql) {\n await tx.run(sql.raw(stmt));\n }\n await tx.run(\n sql`INSERT INTO ${sql.identifier(\n migrationsTable\n )} (\"hash\", \"created_at\") VALUES(${migration.hash}, ${migration.folderMillis})`\n );\n }\n }\n });\n }\n}\nexport {\n SQLiteAsyncDialect,\n SQLiteDialect,\n SQLiteSyncDialect\n};\n//# sourceMappingURL=dialect.js.map","import { getTableUniqueName, Table } from \"./table.js\";\nimport { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { PrimaryKeyBuilder } from \"./pg-core/primary-keys.js\";\nimport {\n and,\n asc,\n between,\n desc,\n eq,\n exists,\n gt,\n gte,\n ilike,\n inArray,\n isNotNull,\n isNull,\n like,\n lt,\n lte,\n ne,\n not,\n notBetween,\n notExists,\n notIlike,\n notInArray,\n notLike,\n or\n} from \"./sql/expressions/index.js\";\nimport { SQL, sql } from \"./sql/sql.js\";\nclass Relation {\n constructor(sourceTable, referencedTable, relationName) {\n this.sourceTable = sourceTable;\n this.referencedTable = referencedTable;\n this.relationName = relationName;\n this.referencedTableName = referencedTable[Table.Symbol.Name];\n }\n static [entityKind] = \"Relation\";\n referencedTableName;\n fieldName;\n}\nclass Relations {\n constructor(table, config) {\n this.table = table;\n this.config = config;\n }\n static [entityKind] = \"Relations\";\n}\nclass One extends Relation {\n constructor(sourceTable, referencedTable, config, isNullable) {\n super(sourceTable, referencedTable, config?.relationName);\n this.config = config;\n this.isNullable = isNullable;\n }\n static [entityKind] = \"One\";\n withFieldName(fieldName) {\n const relation = new One(\n this.sourceTable,\n this.referencedTable,\n this.config,\n this.isNullable\n );\n relation.fieldName = fieldName;\n return relation;\n }\n}\nclass Many extends Relation {\n constructor(sourceTable, referencedTable, config) {\n super(sourceTable, referencedTable, config?.relationName);\n this.config = config;\n }\n static [entityKind] = \"Many\";\n withFieldName(fieldName) {\n const relation = new Many(\n this.sourceTable,\n this.referencedTable,\n this.config\n );\n relation.fieldName = fieldName;\n return relation;\n }\n}\nfunction getOperators() {\n return {\n and,\n between,\n eq,\n exists,\n gt,\n gte,\n ilike,\n inArray,\n isNull,\n isNotNull,\n like,\n lt,\n lte,\n ne,\n not,\n notBetween,\n notExists,\n notLike,\n notIlike,\n notInArray,\n or,\n sql\n };\n}\nfunction getOrderByOperators() {\n return {\n sql,\n asc,\n desc\n };\n}\nfunction extractTablesRelationalConfig(schema, configHelpers) {\n if (Object.keys(schema).length === 1 && \"default\" in schema && !is(schema[\"default\"], Table)) {\n schema = schema[\"default\"];\n }\n const tableNamesMap = {};\n const relationsBuffer = {};\n const tablesConfig = {};\n for (const [key, value] of Object.entries(schema)) {\n if (is(value, Table)) {\n const dbName = getTableUniqueName(value);\n const bufferedRelations = relationsBuffer[dbName];\n tableNamesMap[dbName] = key;\n tablesConfig[key] = {\n tsName: key,\n dbName: value[Table.Symbol.Name],\n schema: value[Table.Symbol.Schema],\n columns: value[Table.Symbol.Columns],\n relations: bufferedRelations?.relations ?? {},\n primaryKey: bufferedRelations?.primaryKey ?? []\n };\n for (const column of Object.values(\n value[Table.Symbol.Columns]\n )) {\n if (column.primary) {\n tablesConfig[key].primaryKey.push(column);\n }\n }\n const extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.(value[Table.Symbol.ExtraConfigColumns]);\n if (extraConfig) {\n for (const configEntry of Object.values(extraConfig)) {\n if (is(configEntry, PrimaryKeyBuilder)) {\n tablesConfig[key].primaryKey.push(...configEntry.columns);\n }\n }\n }\n } else if (is(value, Relations)) {\n const dbName = getTableUniqueName(value.table);\n const tableName = tableNamesMap[dbName];\n const relations2 = value.config(\n configHelpers(value.table)\n );\n let primaryKey;\n for (const [relationName, relation] of Object.entries(relations2)) {\n if (tableName) {\n const tableConfig = tablesConfig[tableName];\n tableConfig.relations[relationName] = relation;\n if (primaryKey) {\n tableConfig.primaryKey.push(...primaryKey);\n }\n } else {\n if (!(dbName in relationsBuffer)) {\n relationsBuffer[dbName] = {\n relations: {},\n primaryKey\n };\n }\n relationsBuffer[dbName].relations[relationName] = relation;\n }\n }\n }\n }\n return { tables: tablesConfig, tableNamesMap };\n}\nfunction relations(table, relations2) {\n return new Relations(\n table,\n (helpers) => Object.fromEntries(\n Object.entries(relations2(helpers)).map(([key, value]) => [\n key,\n value.withFieldName(key)\n ])\n )\n );\n}\nfunction createOne(sourceTable) {\n return function one(table, config) {\n return new One(\n sourceTable,\n table,\n config,\n config?.fields.reduce((res, f) => res && f.notNull, true) ?? false\n );\n };\n}\nfunction createMany(sourceTable) {\n return function many(referencedTable, config) {\n return new Many(sourceTable, referencedTable, config);\n };\n}\nfunction normalizeRelation(schema, tableNamesMap, relation) {\n if (is(relation, One) && relation.config) {\n return {\n fields: relation.config.fields,\n references: relation.config.references\n };\n }\n const referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)];\n if (!referencedTableTsName) {\n throw new Error(\n `Table \"${relation.referencedTable[Table.Symbol.Name]}\" not found in schema`\n );\n }\n const referencedTableConfig = schema[referencedTableTsName];\n if (!referencedTableConfig) {\n throw new Error(`Table \"${referencedTableTsName}\" not found in schema`);\n }\n const sourceTable = relation.sourceTable;\n const sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)];\n if (!sourceTableTsName) {\n throw new Error(\n `Table \"${sourceTable[Table.Symbol.Name]}\" not found in schema`\n );\n }\n const reverseRelations = [];\n for (const referencedTableRelation of Object.values(\n referencedTableConfig.relations\n )) {\n if (relation.relationName && relation !== referencedTableRelation && referencedTableRelation.relationName === relation.relationName || !relation.relationName && referencedTableRelation.referencedTable === relation.sourceTable) {\n reverseRelations.push(referencedTableRelation);\n }\n }\n if (reverseRelations.length > 1) {\n throw relation.relationName ? new Error(\n `There are multiple relations with name \"${relation.relationName}\" in table \"${referencedTableTsName}\"`\n ) : new Error(\n `There are multiple relations between \"${referencedTableTsName}\" and \"${relation.sourceTable[Table.Symbol.Name]}\". Please specify relation name`\n );\n }\n if (reverseRelations[0] && is(reverseRelations[0], One) && reverseRelations[0].config) {\n return {\n fields: reverseRelations[0].config.references,\n references: reverseRelations[0].config.fields\n };\n }\n throw new Error(\n `There is not enough information to infer relation \"${sourceTableTsName}.${relation.fieldName}\"`\n );\n}\nfunction createTableRelationsHelpers(sourceTable) {\n return {\n one: createOne(sourceTable),\n many: createMany(sourceTable)\n };\n}\nfunction mapRelationalRow(tablesConfig, tableConfig, row, buildQueryResultSelection, mapColumnValue = (value) => value) {\n const result = {};\n for (const [\n selectionItemIndex,\n selectionItem\n ] of buildQueryResultSelection.entries()) {\n if (selectionItem.isJson) {\n const relation = tableConfig.relations[selectionItem.tsKey];\n const rawSubRows = row[selectionItemIndex];\n const subRows = typeof rawSubRows === \"string\" ? JSON.parse(rawSubRows) : rawSubRows;\n result[selectionItem.tsKey] = is(relation, One) ? subRows && mapRelationalRow(\n tablesConfig,\n tablesConfig[selectionItem.relationTableTsKey],\n subRows,\n selectionItem.selection,\n mapColumnValue\n ) : subRows.map(\n (subRow) => mapRelationalRow(\n tablesConfig,\n tablesConfig[selectionItem.relationTableTsKey],\n subRow,\n selectionItem.selection,\n mapColumnValue\n )\n );\n } else {\n const value = mapColumnValue(row[selectionItemIndex]);\n const field = selectionItem.field;\n let decoder;\n if (is(field, Column)) {\n decoder = field;\n } else if (is(field, SQL)) {\n decoder = field.decoder;\n } else {\n decoder = field.sql.decoder;\n }\n result[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n }\n }\n return result;\n}\nexport {\n Many,\n One,\n Relation,\n Relations,\n createMany,\n createOne,\n createTableRelationsHelpers,\n extractTablesRelationalConfig,\n getOperators,\n getOrderByOperators,\n mapRelationalRow,\n normalizeRelation,\n relations\n};\n//# sourceMappingURL=relations.js.map","import { bigint } from \"./bigint.js\";\nimport { bigserial } from \"./bigserial.js\";\nimport { boolean } from \"./boolean.js\";\nimport { char } from \"./char.js\";\nimport { cidr } from \"./cidr.js\";\nimport { customType } from \"./custom.js\";\nimport { date } from \"./date.js\";\nimport { doublePrecision } from \"./double-precision.js\";\nimport { inet } from \"./inet.js\";\nimport { integer } from \"./integer.js\";\nimport { interval } from \"./interval.js\";\nimport { json } from \"./json.js\";\nimport { jsonb } from \"./jsonb.js\";\nimport { line } from \"./line.js\";\nimport { macaddr } from \"./macaddr.js\";\nimport { macaddr8 } from \"./macaddr8.js\";\nimport { numeric } from \"./numeric.js\";\nimport { point } from \"./point.js\";\nimport { geometry } from \"./postgis_extension/geometry.js\";\nimport { real } from \"./real.js\";\nimport { serial } from \"./serial.js\";\nimport { smallint } from \"./smallint.js\";\nimport { smallserial } from \"./smallserial.js\";\nimport { text } from \"./text.js\";\nimport { time } from \"./time.js\";\nimport { timestamp } from \"./timestamp.js\";\nimport { uuid } from \"./uuid.js\";\nimport { varchar } from \"./varchar.js\";\nimport { bit } from \"./vector_extension/bit.js\";\nimport { halfvec } from \"./vector_extension/halfvec.js\";\nimport { sparsevec } from \"./vector_extension/sparsevec.js\";\nimport { vector } from \"./vector_extension/vector.js\";\nfunction getPgColumnBuilders() {\n return {\n bigint,\n bigserial,\n boolean,\n char,\n cidr,\n customType,\n date,\n doublePrecision,\n inet,\n integer,\n interval,\n json,\n jsonb,\n line,\n macaddr,\n macaddr8,\n numeric,\n point,\n geometry,\n real,\n serial,\n smallint,\n smallserial,\n text,\n time,\n timestamp,\n uuid,\n varchar,\n bit,\n halfvec,\n sparsevec,\n vector\n };\n}\nexport {\n getPgColumnBuilders\n};\n//# sourceMappingURL=all.js.map"],"names":[],"mappings":"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","ignoreList":[0,1,2,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95]}