@biref/scanner 0.1.0 → 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/adapters/mysql/MySQLMeta.ts","../src/adapters/mysql/mapping/ConstraintMapper.ts","../src/adapters/mysql/mapping/FieldMapper.ts","../src/adapters/mysql/mysqlEnums.ts","../src/adapters/mysql/mapping/IndexMapper.ts","../src/adapters/mysql/mapping/ReferenceMapper.ts","../src/adapters/mysql/mapping/EntityAssembler.ts","../src/adapters/mysql/queries/inPlaceholders.ts","../src/adapters/mysql/queries/ColumnsQuery.ts","../src/adapters/mysql/queries/ConstraintsQuery.ts","../src/adapters/mysql/queries/ForeignKeysQuery.ts","../src/adapters/mysql/queries/IndexesQuery.ts","../src/adapters/mysql/queries/PrimaryKeysQuery.ts","../src/adapters/mysql/queries/TablesQuery.ts","../src/domain/model/DataModel.ts","../src/adapters/mysql/MySQLIntrospector.ts","../src/adapters/mysql/query/SqlIdentifier.ts","../src/adapters/mysql/query/FilterBuilder.ts","../src/adapters/mysql/query/SqlParamList.ts","../src/adapters/mysql/MySQLQueryEngine.ts","../src/parsing/DefaultRecordParser.ts","../src/adapters/mysql/MySQLRecordParser.ts","../src/adapters/mysql/MySQLRawQueryRunner.ts","../src/adapters/mysql/mysqlAdapter.ts","../src/adapters/postgres/pgEnums.ts","../src/adapters/postgres/mapping/ConstraintMapper.ts","../src/adapters/postgres/mapping/FieldMapper.ts","../src/adapters/postgres/mapping/IndexMapper.ts","../src/adapters/postgres/mapping/ReferenceMapper.ts","../src/adapters/postgres/mapping/EntityAssembler.ts","../src/adapters/postgres/PostgresMeta.ts","../src/adapters/postgres/queries/ColumnsQuery.ts","../src/adapters/postgres/queries/ConstraintsQuery.ts","../src/adapters/postgres/queries/ForeignKeysQuery.ts","../src/adapters/postgres/queries/IndexesQuery.ts","../src/adapters/postgres/queries/PrimaryKeysQuery.ts","../src/adapters/postgres/queries/TablesQuery.ts","../src/adapters/postgres/PostgresIntrospector.ts","../src/adapters/postgres/query/SqlIdentifier.ts","../src/adapters/postgres/query/FilterBuilder.ts","../src/adapters/postgres/query/SqlParamList.ts","../src/adapters/postgres/PostgresQueryEngine.ts","../src/adapters/postgres/PostgresRecordParser.ts","../src/adapters/postgres/PostgresRawQueryRunner.ts","../src/adapters/postgres/postgresAdapter.ts","../src/codegen/OverridesScaffold.ts","../src/codegen/TsTypeMapper.ts","../src/query/relationNaming.ts","../src/codegen/SchemaEmitter.ts","../src/core/AdapterRegistry.ts","../src/core/QueryPlanExecutor.ts","../src/query/ChainBuilder.ts","../src/query/NamespaceProxy.ts","../src/core/Biref.ts","../src/core/Scanner.ts","../src/output/CsvFormatter.ts","../src/output/JsonFormatter.ts","../src/output/RawFormatter.ts"],"names":["ConstraintMapper","FieldMapper","IndexMapper","ReferenceMapper","EntityAssembler","ColumnsQuery","ConstraintsQuery","ForeignKeysQuery","IndexesQuery","PrimaryKeysQuery","TablesQuery","SqlIdentifier","FilterBuilder","SqlParamList","BIGINT_NATIVE_TYPES","candidate","indent"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Adapter metadata constants for MySQL.\n *\n * Centralized so the rest of the adapter never references the literal\n * string 'mysql' or the URL schemes by hand.\n */\n\nexport const MYSQL_ADAPTER_NAME = 'mysql';\n\n/** Literal type for the MySQL adapter name, used for discrimination. */\nexport type MySQLAdapterName = typeof MYSQL_ADAPTER_NAME;\n\nexport const MYSQL_URL_SCHEMES: readonly string[] = ['mysql', 'mariadb'];\n","import type { RawConstraint } from '@/adapters/mysql/queries/ConstraintsQuery';\nimport type { Constraint, ConstraintKind } from '@/domain/model/Constraint';\n\n/**\n * Converts a raw constraint row from `ConstraintsQuery` into a\n * paradigm-neutral `Constraint`.\n *\n * Handles unique and check constraints. Primary keys and foreign keys\n * are exposed through `identifier` and `relationships` respectively.\n */\nexport class ConstraintMapper {\n static toConstraint(raw: RawConstraint): Constraint {\n return {\n name: raw.name,\n kind: ConstraintMapper.toKind(raw.kind),\n fields: raw.columns,\n expression: raw.definition,\n };\n }\n\n private static toKind(kind: string): ConstraintKind {\n switch (kind) {\n case 'UNIQUE': {\n return 'unique';\n }\n case 'CHECK': {\n return 'check';\n }\n default: {\n return 'custom';\n }\n }\n }\n}\n","import type { RawColumn } from '@/adapters/mysql/queries/ColumnsQuery';\nimport type { Field } from '@/domain/model/Field';\nimport type { FieldType, FieldTypeCategory } from '@/domain/model/FieldType';\n\nconst ENUM_VALUES_RE = /^enum\\((.+)\\)$/i;\nconst SET_VALUES_RE = /^set\\((.+)\\)$/i;\nconst QUOTED_VALUE_RE = /'([^']*)'/g;\n\n/**\n * Converts a raw column row from `ColumnsQuery` into a paradigm-neutral\n * `Field`, including the normalized `FieldType` category.\n */\nexport class FieldMapper {\n static toField(col: RawColumn, isIdentifier: boolean): Field {\n return {\n name: col.name,\n type: FieldMapper.toType(col),\n nullable: col.nullable,\n isIdentifier,\n defaultValue: col.default_value,\n description: col.description,\n };\n }\n\n private static toType(col: RawColumn): FieldType {\n const dataType = col.data_type.toLowerCase();\n\n if (dataType === 'enum') {\n return {\n category: 'enum',\n nativeType: col.column_type,\n enumValues: FieldMapper.parseEnumValues(col.column_type),\n };\n }\n\n if (dataType === 'set') {\n return {\n category: 'enum',\n nativeType: col.column_type,\n enumValues: FieldMapper.parseSetValues(col.column_type),\n };\n }\n\n // tinyint(1) is conventionally used as boolean in MySQL\n if (col.column_type.toLowerCase() === 'tinyint(1)') {\n return {\n category: 'boolean',\n nativeType: col.column_type,\n };\n }\n\n const base: FieldType = {\n category: FieldMapper.categorize(dataType),\n nativeType: col.column_type,\n };\n\n if (\n col.numeric_precision !== null &&\n (dataType === 'decimal' || dataType === 'numeric')\n ) {\n return {\n ...base,\n precision: col.numeric_precision,\n scale: col.numeric_scale ?? undefined,\n };\n }\n\n if (col.character_max_length !== null) {\n return { ...base, length: col.character_max_length };\n }\n\n return base;\n }\n\n private static parseEnumValues(columnType: string): readonly string[] {\n const match = ENUM_VALUES_RE.exec(columnType);\n if (!match) {\n return [];\n }\n return FieldMapper.extractQuotedValues(match[1]!);\n }\n\n private static parseSetValues(columnType: string): readonly string[] {\n const match = SET_VALUES_RE.exec(columnType);\n if (!match) {\n return [];\n }\n return FieldMapper.extractQuotedValues(match[1]!);\n }\n\n private static extractQuotedValues(raw: string): string[] {\n return Array.from(raw.matchAll(QUOTED_VALUE_RE), (m) => m[1]!);\n }\n\n private static categorize(dataType: string): FieldTypeCategory {\n switch (dataType) {\n case 'varchar':\n case 'char':\n case 'text':\n case 'tinytext':\n case 'mediumtext':\n case 'longtext': {\n return 'string';\n }\n case 'tinyint':\n case 'smallint':\n case 'mediumint':\n case 'int':\n case 'bigint': {\n return 'integer';\n }\n case 'decimal':\n case 'numeric':\n case 'float':\n case 'double':\n case 'real': {\n return 'decimal';\n }\n case 'bit': {\n return 'binary';\n }\n case 'date':\n case 'year': {\n return 'date';\n }\n case 'datetime':\n case 'timestamp': {\n return 'timestamp';\n }\n case 'time': {\n return 'time';\n }\n case 'json': {\n return 'json';\n }\n case 'binary':\n case 'varbinary':\n case 'blob':\n case 'tinyblob':\n case 'mediumblob':\n case 'longblob': {\n return 'binary';\n }\n default: {\n return 'unknown';\n }\n }\n }\n}\n","/**\n * Referential action strings returned by\n * `information_schema.REFERENTIAL_CONSTRAINTS`.\n */\nexport const MySQLReferentialAction = {\n Restrict: 'RESTRICT',\n Cascade: 'CASCADE',\n SetNull: 'SET NULL',\n NoAction: 'NO ACTION',\n SetDefault: 'SET DEFAULT',\n} as const;\n\nexport type MySQLReferentialAction =\n (typeof MySQLReferentialAction)[keyof typeof MySQLReferentialAction];\n\n/**\n * Index method strings returned by `information_schema.STATISTICS`.\n */\nexport const MySQLIndexMethod = {\n BTree: 'BTREE',\n Hash: 'HASH',\n Fulltext: 'FULLTEXT',\n Spatial: 'RTREE',\n} as const;\n\nexport type MySQLIndexMethod =\n (typeof MySQLIndexMethod)[keyof typeof MySQLIndexMethod];\n","import { MySQLIndexMethod } from '@/adapters/mysql/mysqlEnums';\nimport type { RawIndex } from '@/adapters/mysql/queries/IndexesQuery';\nimport type { Index, IndexKind } from '@/domain/model/Index';\n\n/**\n * Converts a raw index row from `IndexesQuery` into a paradigm-neutral\n * `Index`, mapping the MySQL index type onto an `IndexKind`.\n */\nexport class IndexMapper {\n static toIndex(raw: RawIndex): Index {\n return {\n name: raw.name,\n fields: raw.columns,\n unique: raw.unique,\n kind: IndexMapper.toKind(raw.method),\n partial: false,\n definition: null,\n };\n }\n\n private static toKind(method: string): IndexKind {\n switch (method.toUpperCase()) {\n case MySQLIndexMethod.BTree: {\n return 'btree';\n }\n case MySQLIndexMethod.Hash: {\n return 'hash';\n }\n default: {\n return 'unknown';\n }\n }\n }\n}\n","import { MySQLReferentialAction } from '@/adapters/mysql/mysqlEnums';\nimport type { RawForeignKey } from '@/adapters/mysql/queries/ForeignKeysQuery';\nimport type { Reference, ReferentialAction } from '@/domain/model/Reference';\n\n/**\n * Converts a raw foreign key from `ForeignKeysQuery` into a\n * paradigm-neutral `Reference`.\n *\n * MySQL foreign keys are declared, so `confidence` is always 1.\n */\nexport class ReferenceMapper {\n static toReference(fk: RawForeignKey): Reference {\n return {\n name: fk.name,\n fromEntity: { namespace: fk.from_namespace, name: fk.from_table },\n fromFields: fk.from_columns,\n toEntity: { namespace: fk.to_namespace, name: fk.to_table },\n toFields: fk.to_columns,\n confidence: 1,\n onUpdate: ReferenceMapper.toAction(fk.update_action),\n onDelete: ReferenceMapper.toAction(fk.delete_action),\n };\n }\n\n private static toAction(rule: string): ReferentialAction {\n switch (rule) {\n case MySQLReferentialAction.Restrict: {\n return 'restrict';\n }\n case MySQLReferentialAction.Cascade: {\n return 'cascade';\n }\n case MySQLReferentialAction.SetNull: {\n return 'set-null';\n }\n case MySQLReferentialAction.SetDefault: {\n return 'set-default';\n }\n case MySQLReferentialAction.NoAction: {\n return 'no-action';\n }\n default: {\n return 'no-action';\n }\n }\n }\n}\n","import { ConstraintMapper } from '@/adapters/mysql/mapping/ConstraintMapper';\nimport { FieldMapper } from '@/adapters/mysql/mapping/FieldMapper';\nimport { IndexMapper } from '@/adapters/mysql/mapping/IndexMapper';\nimport { ReferenceMapper } from '@/adapters/mysql/mapping/ReferenceMapper';\nimport type { RawColumn } from '@/adapters/mysql/queries/ColumnsQuery';\nimport type { RawConstraint } from '@/adapters/mysql/queries/ConstraintsQuery';\nimport type { RawForeignKey } from '@/adapters/mysql/queries/ForeignKeysQuery';\nimport type { RawIndex } from '@/adapters/mysql/queries/IndexesQuery';\nimport type { RawPrimaryKey } from '@/adapters/mysql/queries/PrimaryKeysQuery';\nimport type { RawTable } from '@/adapters/mysql/queries/TablesQuery';\nimport type { Constraint } from '@/domain/model/Constraint';\nimport type { Entity } from '@/domain/model/Entity';\nimport type { Field } from '@/domain/model/Field';\nimport type { Index } from '@/domain/model/Index';\nimport type { Relationship } from '@/domain/model/Relationship';\n\n/**\n * Raw query results handed to `EntityAssembler.assemble`.\n */\nexport interface AssembleInputs {\n readonly tables: readonly RawTable[];\n readonly columns: readonly RawColumn[];\n readonly primaryKeys: readonly RawPrimaryKey[];\n readonly foreignKeys: readonly RawForeignKey[];\n readonly indexes: readonly RawIndex[];\n readonly constraints: readonly RawConstraint[];\n}\n\n/**\n * Stitches raw `information_schema` query results into paradigm-neutral\n * `Entity` objects.\n *\n * For every foreign key the assembler emits an `outbound` relationship\n * on the source entity AND an `inbound` relationship on the target\n * entity. Rows whose entity is not present in `inputs.tables` (e.g. a\n * FK pointing to a schema the caller did not request) are skipped.\n */\nexport class EntityAssembler {\n static assemble(inputs: AssembleInputs): Entity[] {\n const tableKeys = new Set(\n inputs.tables.map((t) => EntityAssembler.qualified(t.namespace, t.name)),\n );\n\n const pkByEntity = EntityAssembler.indexPrimaryKeys(inputs.primaryKeys);\n const colsByEntity = EntityAssembler.indexColumns(inputs.columns);\n const relsByEntity = EntityAssembler.buildRelationships(\n inputs.foreignKeys,\n tableKeys,\n );\n const indexesByEntity = EntityAssembler.buildIndexes(\n inputs.indexes,\n tableKeys,\n );\n const constraintsByEntity = EntityAssembler.buildConstraints(\n inputs.constraints,\n tableKeys,\n );\n\n return inputs.tables.map((table) => {\n const key = EntityAssembler.qualified(table.namespace, table.name);\n const pkColumns = pkByEntity.get(key) ?? [];\n const pkSet = new Set(pkColumns);\n const rawCols = colsByEntity.get(key) ?? [];\n const fields: Field[] = rawCols.map((col) =>\n FieldMapper.toField(col, pkSet.has(col.name)),\n );\n\n return {\n namespace: table.namespace,\n name: table.name,\n fields,\n identifier: pkColumns,\n relationships: relsByEntity.get(key) ?? [],\n constraints: constraintsByEntity.get(key) ?? [],\n indexes: indexesByEntity.get(key) ?? [],\n description: table.description,\n };\n });\n }\n\n private static indexPrimaryKeys(\n primaryKeys: readonly RawPrimaryKey[],\n ): Map<string, readonly string[]> {\n const map = new Map<string, readonly string[]>();\n for (const pk of primaryKeys) {\n map.set(\n EntityAssembler.qualified(pk.namespace, pk.table_name),\n pk.columns,\n );\n }\n return map;\n }\n\n private static indexColumns(\n columns: readonly RawColumn[],\n ): Map<string, RawColumn[]> {\n const map = new Map<string, RawColumn[]>();\n for (const col of columns) {\n const key = EntityAssembler.qualified(col.namespace, col.table_name);\n const list = map.get(key);\n if (list) {\n list.push(col);\n } else {\n map.set(key, [col]);\n }\n }\n return map;\n }\n\n private static buildRelationships(\n foreignKeys: readonly RawForeignKey[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Relationship[]> {\n const map = new Map<string, Relationship[]>();\n for (const fk of foreignKeys) {\n const reference = ReferenceMapper.toReference(fk);\n const fromKey = EntityAssembler.qualified(\n fk.from_namespace,\n fk.from_table,\n );\n const toKey = EntityAssembler.qualified(fk.to_namespace, fk.to_table);\n\n if (tableKeys.has(fromKey)) {\n EntityAssembler.push(map, fromKey, {\n direction: 'outbound',\n reference,\n });\n }\n if (tableKeys.has(toKey)) {\n EntityAssembler.push(map, toKey, {\n direction: 'inbound',\n reference,\n });\n }\n }\n return map;\n }\n\n private static buildIndexes(\n indexes: readonly RawIndex[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Index[]> {\n const map = new Map<string, Index[]>();\n for (const idx of indexes) {\n const key = EntityAssembler.qualified(idx.namespace, idx.table_name);\n if (!tableKeys.has(key)) {\n continue;\n }\n EntityAssembler.push(map, key, IndexMapper.toIndex(idx));\n }\n return map;\n }\n\n private static buildConstraints(\n constraints: readonly RawConstraint[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Constraint[]> {\n const map = new Map<string, Constraint[]>();\n for (const cn of constraints) {\n const key = EntityAssembler.qualified(cn.namespace, cn.table_name);\n if (!tableKeys.has(key)) {\n continue;\n }\n EntityAssembler.push(map, key, ConstraintMapper.toConstraint(cn));\n }\n return map;\n }\n\n private static push<T>(map: Map<string, T[]>, key: string, value: T): void {\n const list = map.get(key);\n if (list) {\n list.push(value);\n } else {\n map.set(key, [value]);\n }\n }\n\n private static qualified(namespace: string, name: string): string {\n return `${namespace}.${name}`;\n }\n}\n","/**\n * Builds a `?, ?, ?` placeholder string for use in MySQL `IN (...)` clauses.\n *\n * MySQL does not support array parameters like Postgres's `= ANY($1)`,\n * so each element needs its own `?` placeholder.\n */\nexport function inPlaceholders(count: number): string {\n return Array.from({ length: count }, () => '?').join(', ');\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\nexport interface RawColumn {\n namespace: string;\n table_name: string;\n name: string;\n data_type: string;\n column_type: string;\n nullable: boolean;\n default_value: string | null;\n description: string | null;\n character_max_length: number | null;\n numeric_precision: number | null;\n numeric_scale: number | null;\n}\n\ninterface RawColumnRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n COLUMN_NAME: string;\n DATA_TYPE: string;\n COLUMN_TYPE: string;\n IS_NULLABLE: string;\n COLUMN_DEFAULT: string | null;\n COLUMN_COMMENT: string;\n CHARACTER_MAXIMUM_LENGTH: number | null;\n NUMERIC_PRECISION: number | null;\n NUMERIC_SCALE: number | null;\n}\n\nexport class ColumnsQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawColumn[]> {\n const sql = `\nSELECT\n c.TABLE_SCHEMA,\n c.TABLE_NAME,\n c.COLUMN_NAME,\n c.DATA_TYPE,\n c.COLUMN_TYPE,\n c.IS_NULLABLE,\n c.COLUMN_DEFAULT,\n c.COLUMN_COMMENT,\n c.CHARACTER_MAXIMUM_LENGTH,\n c.NUMERIC_PRECISION,\n c.NUMERIC_SCALE\nFROM information_schema.COLUMNS c\nJOIN information_schema.TABLES t\n ON t.TABLE_SCHEMA = c.TABLE_SCHEMA\n AND t.TABLE_NAME = c.TABLE_NAME\nWHERE t.TABLE_TYPE = 'BASE TABLE'\n AND c.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY c.TABLE_SCHEMA, c.TABLE_NAME, c.ORDINAL_POSITION\n`;\n const [rows] = await client.execute<RawColumnRow>(sql, [...namespaces]);\n return rows.map((row) => ({\n namespace: row.TABLE_SCHEMA,\n table_name: row.TABLE_NAME,\n name: row.COLUMN_NAME,\n data_type: row.DATA_TYPE,\n column_type: row.COLUMN_TYPE,\n nullable: row.IS_NULLABLE === 'YES',\n default_value: row.COLUMN_DEFAULT,\n description: row.COLUMN_COMMENT || null,\n character_max_length: row.CHARACTER_MAXIMUM_LENGTH,\n numeric_precision: row.NUMERIC_PRECISION,\n numeric_scale: row.NUMERIC_SCALE,\n }));\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `ConstraintsQuery.fetch`.\n *\n * Covers `unique` and `check` constraints. Foreign keys and primary\n * keys are fetched separately. Check constraints require MySQL 8.0.16+.\n */\nexport interface RawConstraint {\n namespace: string;\n table_name: string;\n name: string;\n kind: 'UNIQUE' | 'CHECK';\n definition: string | null;\n columns: string[];\n}\n\ninterface RawUniqueRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n CONSTRAINT_NAME: string;\n COLUMN_NAME: string;\n}\n\ninterface RawCheckRow {\n CONSTRAINT_SCHEMA: string;\n TABLE_NAME: string;\n CONSTRAINT_NAME: string;\n CHECK_CLAUSE: string;\n}\n\n/**\n * Reads unique and check constraints from `information_schema` for the\n * given schemas. Unique constraint columns are aggregated in ordinal\n * order. Check constraints (MySQL 8.0.16+) are fetched separately and\n * merged; failures are silently ignored for MySQL versions that lack\n * `CHECK_CONSTRAINTS`.\n */\nexport class ConstraintsQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawConstraint[]> {\n const [uniques, checks] = await Promise.all([\n ConstraintsQuery.fetchUniques(client, namespaces),\n ConstraintsQuery.fetchChecks(client, namespaces),\n ]);\n return [...uniques, ...checks];\n }\n\n private static async fetchUniques(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<RawConstraint[]> {\n const sql = `\nSELECT\n kcu.TABLE_SCHEMA,\n kcu.TABLE_NAME,\n kcu.CONSTRAINT_NAME,\n kcu.COLUMN_NAME\nFROM information_schema.KEY_COLUMN_USAGE kcu\nJOIN information_schema.TABLE_CONSTRAINTS tc\n ON tc.CONSTRAINT_SCHEMA = kcu.CONSTRAINT_SCHEMA\n AND tc.CONSTRAINT_NAME = kcu.CONSTRAINT_NAME\n AND tc.TABLE_NAME = kcu.TABLE_NAME\nWHERE tc.CONSTRAINT_TYPE = 'UNIQUE'\n AND kcu.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY kcu.TABLE_SCHEMA, kcu.TABLE_NAME, kcu.CONSTRAINT_NAME, kcu.ORDINAL_POSITION\n`;\n const [rows] = await client.execute<RawUniqueRow>(sql, [...namespaces]);\n return ConstraintsQuery.aggregateUniques(rows);\n }\n\n private static aggregateUniques(\n rows: readonly RawUniqueRow[],\n ): RawConstraint[] {\n const map = new Map<string, RawConstraint>();\n for (const row of rows) {\n const key = `${row.TABLE_SCHEMA}.${row.TABLE_NAME}.${row.CONSTRAINT_NAME}`;\n const existing = map.get(key);\n if (existing) {\n existing.columns.push(row.COLUMN_NAME);\n } else {\n map.set(key, {\n namespace: row.TABLE_SCHEMA,\n table_name: row.TABLE_NAME,\n name: row.CONSTRAINT_NAME,\n kind: 'UNIQUE',\n definition: null,\n columns: [row.COLUMN_NAME],\n });\n }\n }\n return [...map.values()];\n }\n\n private static async fetchChecks(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<RawConstraint[]> {\n const sql = `\nSELECT\n cc.CONSTRAINT_SCHEMA,\n tc.TABLE_NAME,\n cc.CONSTRAINT_NAME,\n cc.CHECK_CLAUSE\nFROM information_schema.CHECK_CONSTRAINTS cc\nJOIN information_schema.TABLE_CONSTRAINTS tc\n ON tc.CONSTRAINT_SCHEMA = cc.CONSTRAINT_SCHEMA\n AND tc.CONSTRAINT_NAME = cc.CONSTRAINT_NAME\nWHERE tc.CONSTRAINT_TYPE = 'CHECK'\n AND cc.CONSTRAINT_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY cc.CONSTRAINT_SCHEMA, tc.TABLE_NAME, cc.CONSTRAINT_NAME\n`;\n try {\n const [rows] = await client.execute<RawCheckRow>(sql, [...namespaces]);\n return rows.map((row) => ({\n namespace: row.CONSTRAINT_SCHEMA,\n table_name: row.TABLE_NAME,\n name: row.CONSTRAINT_NAME,\n kind: 'CHECK' as const,\n definition: row.CHECK_CLAUSE,\n columns: [],\n }));\n } catch {\n // CHECK_CONSTRAINTS table does not exist before MySQL 8.0.16\n return [];\n }\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `ForeignKeysQuery.fetch` after aggregation.\n *\n * Each entry corresponds to one declared foreign key constraint with\n * aggregated column lists, matching the Postgres adapter's shape.\n */\nexport interface RawForeignKey {\n name: string;\n from_namespace: string;\n from_table: string;\n from_columns: string[];\n to_namespace: string;\n to_table: string;\n to_columns: string[];\n update_action: string;\n delete_action: string;\n}\n\ninterface RawForeignKeyRow {\n CONSTRAINT_NAME: string;\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n COLUMN_NAME: string;\n REFERENCED_TABLE_SCHEMA: string;\n REFERENCED_TABLE_NAME: string;\n REFERENCED_COLUMN_NAME: string;\n UPDATE_RULE: string;\n DELETE_RULE: string;\n}\n\n/**\n * Reads foreign key constraints from `information_schema.KEY_COLUMN_USAGE`\n * joined with `REFERENTIAL_CONSTRAINTS` for the given schemas. Returns\n * one entry per FK with aggregated column lists.\n */\nexport class ForeignKeysQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawForeignKey[]> {\n const sql = `\nSELECT\n kcu.CONSTRAINT_NAME,\n kcu.TABLE_SCHEMA,\n kcu.TABLE_NAME,\n kcu.COLUMN_NAME,\n kcu.REFERENCED_TABLE_SCHEMA,\n kcu.REFERENCED_TABLE_NAME,\n kcu.REFERENCED_COLUMN_NAME,\n rc.UPDATE_RULE,\n rc.DELETE_RULE\nFROM information_schema.KEY_COLUMN_USAGE kcu\nJOIN information_schema.REFERENTIAL_CONSTRAINTS rc\n ON rc.CONSTRAINT_SCHEMA = kcu.CONSTRAINT_SCHEMA\n AND rc.CONSTRAINT_NAME = kcu.CONSTRAINT_NAME\nWHERE kcu.REFERENCED_TABLE_NAME IS NOT NULL\n AND kcu.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY kcu.TABLE_SCHEMA, kcu.TABLE_NAME, kcu.CONSTRAINT_NAME, kcu.ORDINAL_POSITION\n`;\n const [rows] = await client.execute<RawForeignKeyRow>(sql, [...namespaces]);\n return ForeignKeysQuery.aggregate(rows);\n }\n\n private static aggregate(rows: readonly RawForeignKeyRow[]): RawForeignKey[] {\n const map = new Map<string, RawForeignKey>();\n for (const row of rows) {\n const key = `${row.TABLE_SCHEMA}.${row.TABLE_NAME}.${row.CONSTRAINT_NAME}`;\n const existing = map.get(key);\n if (existing) {\n existing.from_columns.push(row.COLUMN_NAME);\n existing.to_columns.push(row.REFERENCED_COLUMN_NAME);\n } else {\n map.set(key, {\n name: row.CONSTRAINT_NAME,\n from_namespace: row.TABLE_SCHEMA,\n from_table: row.TABLE_NAME,\n from_columns: [row.COLUMN_NAME],\n to_namespace: row.REFERENCED_TABLE_SCHEMA,\n to_table: row.REFERENCED_TABLE_NAME,\n to_columns: [row.REFERENCED_COLUMN_NAME],\n update_action: row.UPDATE_RULE,\n delete_action: row.DELETE_RULE,\n });\n }\n }\n return [...map.values()];\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `IndexesQuery.fetch` after aggregation.\n *\n * `columns` carries the indexed columns in declaration order.\n * MySQL does not support partial indexes, so `partial` is always false.\n */\nexport interface RawIndex {\n namespace: string;\n table_name: string;\n name: string;\n method: string;\n unique: boolean;\n partial: false;\n definition: null;\n columns: string[];\n}\n\ninterface RawIndexRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n INDEX_NAME: string;\n INDEX_TYPE: string;\n NON_UNIQUE: number;\n COLUMN_NAME: string;\n}\n\n/**\n * Reads non-primary indexes from `information_schema.STATISTICS` for\n * the given schemas. The primary key index is excluded because the\n * primary key columns are already exposed through the entity's\n * `identifier`.\n */\nexport class IndexesQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawIndex[]> {\n const sql = `\nSELECT\n s.TABLE_SCHEMA,\n s.TABLE_NAME,\n s.INDEX_NAME,\n s.INDEX_TYPE,\n s.NON_UNIQUE,\n s.COLUMN_NAME\nFROM information_schema.STATISTICS s\nWHERE s.INDEX_NAME <> 'PRIMARY'\n AND s.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY s.TABLE_SCHEMA, s.TABLE_NAME, s.INDEX_NAME, s.SEQ_IN_INDEX\n`;\n const [rows] = await client.execute<RawIndexRow>(sql, [...namespaces]);\n return IndexesQuery.aggregate(rows);\n }\n\n private static aggregate(rows: readonly RawIndexRow[]): RawIndex[] {\n const map = new Map<string, RawIndex>();\n for (const row of rows) {\n const key = `${row.TABLE_SCHEMA}.${row.TABLE_NAME}.${row.INDEX_NAME}`;\n const existing = map.get(key);\n if (existing) {\n existing.columns.push(row.COLUMN_NAME);\n } else {\n map.set(key, {\n namespace: row.TABLE_SCHEMA,\n table_name: row.TABLE_NAME,\n name: row.INDEX_NAME,\n method: row.INDEX_TYPE,\n unique: row.NON_UNIQUE === 0,\n partial: false,\n definition: null,\n columns: [row.COLUMN_NAME],\n });\n }\n }\n return [...map.values()];\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `PrimaryKeysQuery.fetch`.\n *\n * `columns` carries the columns in declaration order, supporting\n * composite primary keys without flattening them.\n */\nexport interface RawPrimaryKey {\n namespace: string;\n table_name: string;\n columns: string[];\n}\n\ninterface RawPrimaryKeyRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n COLUMN_NAME: string;\n}\n\n/**\n * Reads primary key columns from `information_schema.KEY_COLUMN_USAGE`\n * for the given schemas. Composite keys are aggregated into a single\n * row with all columns ordered by their ordinal position.\n */\nexport class PrimaryKeysQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawPrimaryKey[]> {\n const sql = `\nSELECT\n kcu.TABLE_SCHEMA,\n kcu.TABLE_NAME,\n kcu.COLUMN_NAME\nFROM information_schema.KEY_COLUMN_USAGE kcu\nJOIN information_schema.TABLE_CONSTRAINTS tc\n ON tc.CONSTRAINT_SCHEMA = kcu.CONSTRAINT_SCHEMA\n AND tc.CONSTRAINT_NAME = kcu.CONSTRAINT_NAME\n AND tc.TABLE_NAME = kcu.TABLE_NAME\nWHERE tc.CONSTRAINT_TYPE = 'PRIMARY KEY'\n AND kcu.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY kcu.TABLE_SCHEMA, kcu.TABLE_NAME, kcu.ORDINAL_POSITION\n`;\n const [rows] = await client.execute<RawPrimaryKeyRow>(sql, [...namespaces]);\n return PrimaryKeysQuery.aggregate(rows);\n }\n\n private static aggregate(rows: readonly RawPrimaryKeyRow[]): RawPrimaryKey[] {\n const map = new Map<string, RawPrimaryKey>();\n for (const row of rows) {\n const key = `${row.TABLE_SCHEMA}.${row.TABLE_NAME}`;\n const existing = map.get(key);\n if (existing) {\n existing.columns.push(row.COLUMN_NAME);\n } else {\n map.set(key, {\n namespace: row.TABLE_SCHEMA,\n table_name: row.TABLE_NAME,\n columns: [row.COLUMN_NAME],\n });\n }\n }\n return [...map.values()];\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `TablesQuery.fetch`.\n *\n * Mirrors the columns selected from `information_schema.TABLES` for\n * each base table.\n */\nexport interface RawTable {\n namespace: string;\n name: string;\n description: string | null;\n}\n\ninterface RawTableRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n TABLE_COMMENT: string;\n}\n\n/**\n * Reads base tables from `information_schema.TABLES` for the given\n * schemas (databases), along with their table comment.\n */\nexport class TablesQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawTable[]> {\n const sql = `\nSELECT\n t.TABLE_SCHEMA AS TABLE_SCHEMA,\n t.TABLE_NAME AS TABLE_NAME,\n t.TABLE_COMMENT AS TABLE_COMMENT\nFROM information_schema.TABLES t\nWHERE t.TABLE_TYPE = 'BASE TABLE'\n AND t.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY t.TABLE_SCHEMA, t.TABLE_NAME\n`;\n const [rows] = await client.execute<RawTableRow>(sql, [...namespaces]);\n return rows.map((row) => ({\n namespace: row.TABLE_SCHEMA,\n name: row.TABLE_NAME,\n description: row.TABLE_COMMENT || null,\n }));\n }\n}\n","import type { EngineKind } from '@/domain/model/EngineKind';\nimport type { Entity } from '@/domain/model/Entity';\nimport type { Relationship } from '@/domain/model/Relationship';\n\n/**\n * The aggregate root for an introspected data store.\n *\n * Holds all entities discovered by an `Introspector`, indexed for\n * efficient lookup, and exposes navigation helpers around relationships.\n *\n * Paradigm-neutral: the same shape is returned for relational, document,\n * graph, and other data stores. Use `kind` to branch when needed.\n */\nexport class DataModel {\n private readonly index: ReadonlyMap<string, Entity>;\n\n constructor(\n public readonly kind: EngineKind,\n public readonly entities: readonly Entity[],\n ) {\n this.index = new Map(\n entities.map((e) => [DataModel.qualifiedName(e.namespace, e.name), e]),\n );\n }\n\n /**\n * Build the lookup key for an entity. Exposed as a static helper so\n * consumers can compute keys consistently when building their own\n * indexes on top of a `DataModel`.\n */\n static qualifiedName(namespace: string, name: string): string {\n return `${namespace}.${name}`;\n }\n\n getEntity(namespace: string, name: string): Entity | undefined {\n return this.index.get(DataModel.qualifiedName(namespace, name));\n }\n\n hasEntity(namespace: string, name: string): boolean {\n return this.index.has(DataModel.qualifiedName(namespace, name));\n }\n\n /**\n * All relationships an entity participates in, in both directions.\n * Returns an empty array if the entity is unknown.\n */\n relationshipsOf(namespace: string, name: string): readonly Relationship[] {\n return this.getEntity(namespace, name)?.relationships ?? [];\n }\n\n /**\n * Outbound relationships: this entity holds the reference.\n * In a relational store these correspond to FOREIGN KEY constraints\n * declared by the entity itself.\n */\n outboundRelationshipsOf(\n namespace: string,\n name: string,\n ): readonly Relationship[] {\n return this.relationshipsOf(namespace, name).filter(\n (r) => r.direction === 'outbound',\n );\n }\n\n /**\n * Inbound relationships: other entities hold references pointing here.\n *\n * This is the differentiating feature of the SDK. Most introspection\n * tools only surface outbound relationships, requiring consumers to\n * know which other entities reference theirs ahead of time.\n */\n inboundRelationshipsOf(\n namespace: string,\n name: string,\n ): readonly Relationship[] {\n return this.relationshipsOf(namespace, name).filter(\n (r) => r.direction === 'inbound',\n );\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { MYSQL_ADAPTER_NAME } from '@/adapters/mysql/MySQLMeta';\nimport { EntityAssembler } from '@/adapters/mysql/mapping/EntityAssembler';\nimport {\n ColumnsQuery,\n type RawColumn,\n} from '@/adapters/mysql/queries/ColumnsQuery';\nimport {\n ConstraintsQuery,\n type RawConstraint,\n} from '@/adapters/mysql/queries/ConstraintsQuery';\nimport {\n ForeignKeysQuery,\n type RawForeignKey,\n} from '@/adapters/mysql/queries/ForeignKeysQuery';\nimport {\n IndexesQuery,\n type RawIndex,\n} from '@/adapters/mysql/queries/IndexesQuery';\nimport {\n PrimaryKeysQuery,\n type RawPrimaryKey,\n} from '@/adapters/mysql/queries/PrimaryKeysQuery';\nimport {\n type RawTable,\n TablesQuery,\n} from '@/adapters/mysql/queries/TablesQuery';\nimport { DataModel } from '@/domain/model/DataModel';\nimport type { IntrospectOptions, Introspector } from '@/ports/Introspector';\n\n/**\n * MySQL implementation of the `Introspector` port.\n *\n * Runs six queries against `information_schema` in parallel (tables,\n * columns, primary keys, foreign keys, indexes, constraints) and hands\n * the result to `EntityAssembler`, which stitches them into a paradigm-\n * neutral `DataModel`.\n *\n * What it returns for each entity:\n * - fields with normalized type categories\n * - identifier (primary key columns)\n * - relationships in BOTH directions\n * - constraints (unique, check)\n * - indexes (excluding the primary key index)\n *\n * Accepts any client that satisfies `MySQLClient`, so it works with\n * `mysql2/promise` Connection, Pool, or any compatible library without\n * the SDK importing `mysql2`.\n */\nexport class MySQLIntrospector implements Introspector {\n readonly name = MYSQL_ADAPTER_NAME;\n readonly kind = 'relational' as const;\n\n constructor(private readonly client: MySQLClient) {}\n\n async introspect(options: IntrospectOptions = {}): Promise<DataModel> {\n const namespaces = await this.resolveNamespaces(options.namespaces);\n\n const [tables, columns, primaryKeys, foreignKeys, indexes, constraints]: [\n readonly RawTable[],\n readonly RawColumn[],\n readonly RawPrimaryKey[],\n readonly RawForeignKey[],\n readonly RawIndex[],\n readonly RawConstraint[],\n ] = await Promise.all([\n TablesQuery.fetch(this.client, namespaces),\n ColumnsQuery.fetch(this.client, namespaces),\n PrimaryKeysQuery.fetch(this.client, namespaces),\n ForeignKeysQuery.fetch(this.client, namespaces),\n IndexesQuery.fetch(this.client, namespaces),\n ConstraintsQuery.fetch(this.client, namespaces),\n ]);\n\n const filteredTables = MySQLIntrospector.applyEntityFilters(\n tables,\n options,\n );\n\n const entities = EntityAssembler.assemble({\n tables: filteredTables,\n columns,\n primaryKeys,\n foreignKeys,\n indexes,\n constraints,\n });\n\n return new DataModel('relational', entities);\n }\n\n private async resolveNamespaces(\n raw: readonly string[] | 'all' | undefined,\n ): Promise<readonly string[]> {\n if (raw === undefined) {\n return this.currentDatabase();\n }\n if (raw === 'all') {\n const [rows] = await this.client.execute<{ SCHEMA_NAME: string }>(\n MySQLIntrospector.ALL_SCHEMAS_SQL,\n );\n return rows.map((row) => row.SCHEMA_NAME);\n }\n return raw;\n }\n\n private async currentDatabase(): Promise<readonly string[]> {\n const [rows] = await this.client.execute<{ db: string }>(\n 'SELECT DATABASE() AS db',\n );\n const db = rows[0]?.db;\n if (!db) {\n throw new Error(\n 'No database selected. Pass explicit namespaces or connect to a specific database.',\n );\n }\n return [db];\n }\n\n private static readonly ALL_SCHEMAS_SQL = `\nSELECT s.SCHEMA_NAME\nFROM information_schema.SCHEMATA s\nWHERE s.SCHEMA_NAME NOT IN ('information_schema', 'mysql', 'performance_schema', 'sys')\nORDER BY s.SCHEMA_NAME\n`;\n\n private static applyEntityFilters(\n tables: readonly RawTable[],\n options: IntrospectOptions,\n ): readonly RawTable[] {\n const { includeEntities: allow, excludeEntities: deny } = options;\n if (!allow && !deny) {\n return tables;\n }\n return tables.filter((t) => {\n if (allow && !allow.includes(t.name)) {\n return false;\n }\n if (deny?.includes(t.name)) {\n return false;\n }\n return true;\n });\n }\n}\n","/**\n * Quoting helpers for MySQL SQL identifiers.\n *\n * Wraps identifiers in backticks and escapes any embedded backticks\n * by doubling them, matching the MySQL identifier grammar. Always\n * quotes, even for identifiers that would not strictly require it,\n * so reserved words and mixed case are handled without special cases.\n */\nexport class SqlIdentifier {\n static quote(id: string): string {\n return `\\`${id.replace(/`/g, '``')}\\``;\n }\n\n static qualified(namespace: string, name: string): string {\n return `${SqlIdentifier.quote(namespace)}.${SqlIdentifier.quote(name)}`;\n }\n}\n","import { SqlIdentifier } from '@/adapters/mysql/query/SqlIdentifier';\nimport type { SqlParamList } from '@/adapters/mysql/query/SqlParamList';\nimport type { Filter } from '@/domain/query/QuerySpec';\n\n/**\n * Turns a `Filter` into a MySQL SQL WHERE fragment, binding its\n * values on a shared `SqlParamList`.\n *\n * Handles every `FilterOperator`:\n * eq, neq, lt, lte, gt, gte, like, ilike, in, not-in,\n * is-null, is-not-null, between\n *\n * MySQL `LIKE` is case-insensitive by default with most collations.\n * For `ilike`, `LOWER()` is applied to both sides to guarantee\n * case-insensitive behavior regardless of collation.\n */\nexport class FilterBuilder {\n constructor(private readonly params: SqlParamList) {}\n\n build(filter: Filter): string {\n const col = SqlIdentifier.quote(filter.field);\n\n switch (filter.operator) {\n case 'eq': {\n return `${col} = ${this.params.add(filter.value)}`;\n }\n case 'neq': {\n return `${col} <> ${this.params.add(filter.value)}`;\n }\n case 'lt': {\n return `${col} < ${this.params.add(filter.value)}`;\n }\n case 'lte': {\n return `${col} <= ${this.params.add(filter.value)}`;\n }\n case 'gt': {\n return `${col} > ${this.params.add(filter.value)}`;\n }\n case 'gte': {\n return `${col} >= ${this.params.add(filter.value)}`;\n }\n case 'like': {\n return `${col} LIKE ${this.params.add(filter.value)}`;\n }\n case 'ilike': {\n return `LOWER(${col}) LIKE LOWER(${this.params.add(filter.value)})`;\n }\n case 'is-null': {\n return `${col} IS NULL`;\n }\n case 'is-not-null': {\n return `${col} IS NOT NULL`;\n }\n case 'in': {\n return this.buildInClause(col, filter.value, 'FALSE', 'IN');\n }\n case 'not-in': {\n return this.buildInClause(col, filter.value, 'TRUE', 'NOT IN');\n }\n case 'between': {\n return this.buildBetween(col, filter.value);\n }\n default: {\n const exhaustive: never = filter.operator;\n throw new Error(`Unknown filter operator: ${String(exhaustive)}`);\n }\n }\n }\n\n private buildInClause(\n col: string,\n value: unknown,\n emptyFallback: string,\n keyword: 'IN' | 'NOT IN',\n ): string {\n if (!Array.isArray(value)) {\n throw new Error(\n `Operator '${keyword.toLowerCase()}' requires an array value.`,\n );\n }\n const values = value as readonly unknown[];\n if (values.length === 0) {\n return emptyFallback;\n }\n const placeholders = this.params.addAll(values);\n return `${col} ${keyword} (${placeholders.join(', ')})`;\n }\n\n private buildBetween(col: string, value: unknown): string {\n if (!Array.isArray(value) || value.length !== 2) {\n throw new Error(\"Operator 'between' requires a [min, max] tuple.\");\n }\n const tuple = value as readonly unknown[];\n const lo = this.params.add(tuple[0]);\n const hi = this.params.add(tuple[1]);\n return `${col} BETWEEN ${lo} AND ${hi}`;\n }\n}\n","/**\n * Mutable bound parameter list for MySQL query building.\n *\n * Keeps track of the ordered values and hands out `?` placeholder\n * strings as they are added. Shared across the filter, limit, and\n * offset stages so parameter order matches the SQL text.\n */\nexport class SqlParamList {\n private readonly values: unknown[] = [];\n\n /**\n * Append a value and return a `?` placeholder.\n */\n add(value: unknown): string {\n this.values.push(value);\n return '?';\n }\n\n /**\n * Append many values and return their placeholders in order.\n */\n addAll(values: readonly unknown[]): readonly string[] {\n return values.map((v) => this.add(v));\n }\n\n /** Number of values currently bound. */\n get size(): number {\n return this.values.length;\n }\n\n /**\n * Return a read-only copy of the bound values. The returned array\n * is not backed by the internal storage.\n */\n toArray(): readonly unknown[] {\n return [...this.values];\n }\n}\n","import { MYSQL_ADAPTER_NAME } from '@/adapters/mysql/MySQLMeta';\nimport { FilterBuilder } from '@/adapters/mysql/query/FilterBuilder';\nimport { SqlIdentifier } from '@/adapters/mysql/query/SqlIdentifier';\nimport { SqlParamList } from '@/adapters/mysql/query/SqlParamList';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { BuiltQuery } from '@/domain/query/BuiltQuery';\nimport type { QuerySpec } from '@/domain/query/QuerySpec';\nimport type { QueryEngine } from '@/ports/QueryEngine';\n\n/**\n * MySQL implementation of the `QueryEngine` port.\n *\n * Produces parameterized SQL using `?` placeholders and backtick-quoted\n * identifiers. Validates the spec against the `DataModel` before\n * emitting any SQL: unknown entities or fields throw rather than\n * yielding a broken query.\n *\n * Scope:\n * - SELECT against a single entity\n * - WHERE filters (every `FilterOperator`)\n * - ORDER BY\n * - LIMIT and OFFSET\n */\nexport class MySQLQueryEngine implements QueryEngine<string> {\n readonly name = MYSQL_ADAPTER_NAME;\n readonly kind = 'relational' as const;\n\n build(spec: QuerySpec, model: DataModel): BuiltQuery<string> {\n const entity = model.getEntity(spec.namespace, spec.entity);\n if (!entity) {\n throw new Error(\n `Entity \"${spec.namespace}.${spec.entity}\" not found in the data model.`,\n );\n }\n\n const fieldNames = new Set(entity.fields.map((f) => f.name));\n const selectedFields =\n spec.select && spec.select.length > 0\n ? [...spec.select]\n : entity.fields.map((f) => f.name);\n\n for (const field of selectedFields) {\n if (!fieldNames.has(field)) {\n throw new Error(\n `Field \"${field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n }\n\n const params = new SqlParamList();\n const filterBuilder = new FilterBuilder(params);\n\n const selectClause = selectedFields.map(SqlIdentifier.quote).join(', ');\n const fromClause = SqlIdentifier.qualified(spec.namespace, spec.entity);\n\n let sql = `SELECT ${selectClause} FROM ${fromClause}`;\n\n if (spec.filters && spec.filters.length > 0) {\n const wherePieces = spec.filters.map((filter) => {\n if (!fieldNames.has(filter.field)) {\n throw new Error(\n `Filter field \"${filter.field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n return filterBuilder.build(filter);\n });\n sql += ` WHERE ${wherePieces.join(' AND ')}`;\n }\n\n if (spec.orderBy && spec.orderBy.length > 0) {\n const orderPieces = spec.orderBy.map((order) => {\n if (!fieldNames.has(order.field)) {\n throw new Error(\n `Order field \"${order.field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n return `${SqlIdentifier.quote(order.field)} ${order.direction.toUpperCase()}`;\n });\n sql += ` ORDER BY ${orderPieces.join(', ')}`;\n }\n\n if (spec.limit !== undefined) {\n sql += ` LIMIT ${params.add(spec.limit)}`;\n }\n\n if (spec.offset !== undefined) {\n sql += ` OFFSET ${params.add(spec.offset)}`;\n }\n\n return {\n command: sql,\n params: params.toArray(),\n metadata: {\n engine: MYSQL_ADAPTER_NAME,\n paramCount: params.size,\n },\n };\n }\n}\n","import type { Entity } from '@/domain/model/Entity';\nimport type { Field } from '@/domain/model/Field';\nimport type { ParsedRecord, ParsedValue } from '@/parsing/ParsedRecord';\nimport type { RecordParser } from '@/parsing/RecordParser';\n\n/**\n * Default `RecordParser` used when no adapter-specific parser is needed.\n *\n * Coerces raw driver output to JS values using the field type\n * categories from the `DataModel`:\n * string | uuid | enum -> JS string\n * integer -> JS number (or bigint if raw is bigint)\n * decimal -> JS string (preserves precision)\n * boolean -> JS boolean\n * date | timestamp | time -> JS Date\n * json -> pass-through\n * binary -> pass-through\n * array -> pass-through if already an array, else []\n * reference -> pass-through\n * unknown -> pass-through\n *\n * Null and undefined raw values become `null`. Fields on the entity\n * that are absent from the row are omitted from the result, so a\n * partial projection only emits the keys that were selected.\n *\n * The `coerce` method is `protected` so adapter-specific subclasses\n * (for example `PostgresRecordParser`) can override or extend it.\n */\nexport class DefaultRecordParser implements RecordParser {\n parse(entity: Entity, row: Readonly<Record<string, unknown>>): ParsedRecord {\n const result: Record<string, ParsedValue> = {};\n for (const field of entity.fields) {\n if (field.name in row) {\n result[field.name] = this.coerce(field, row[field.name]);\n }\n }\n return result;\n }\n\n parseMany(\n entity: Entity,\n rows: readonly Readonly<Record<string, unknown>>[],\n ): readonly ParsedRecord[] {\n return rows.map((row) => this.parse(entity, row));\n }\n\n protected coerce(field: Field, raw: unknown): ParsedValue {\n if (raw === null || raw === undefined) {\n return null;\n }\n\n switch (field.type.category) {\n case 'string':\n case 'uuid':\n case 'enum': {\n return String(raw);\n }\n\n case 'integer': {\n if (typeof raw === 'bigint') {\n return raw;\n }\n if (typeof raw === 'number') {\n return raw;\n }\n return Number(raw);\n }\n\n case 'decimal': {\n return typeof raw === 'string' ? raw : String(raw);\n }\n\n case 'boolean': {\n return Boolean(raw);\n }\n\n case 'date':\n case 'timestamp':\n case 'time': {\n if (raw instanceof Date) {\n return raw;\n }\n if (typeof raw === 'string' || typeof raw === 'number') {\n return new Date(raw);\n }\n return null;\n }\n\n case 'json':\n case 'binary':\n case 'reference':\n case 'unknown': {\n return raw as ParsedValue;\n }\n\n case 'array': {\n return Array.isArray(raw) ? (raw as ParsedValue[]) : [];\n }\n\n default: {\n const exhaustive: never = field.type.category;\n return exhaustive;\n }\n }\n }\n}\n","import type { Field } from '@/domain/model/Field';\nimport { DefaultRecordParser } from '@/parsing/DefaultRecordParser';\nimport type { ParsedValue } from '@/parsing/ParsedRecord';\n\nconst BIGINT_NATIVE_TYPES: ReadonlySet<string> = new Set(['bigint']);\n\n/**\n * MySQL-aware `RecordParser`.\n *\n * Extends `DefaultRecordParser` with behavior that matches how `mysql2`\n * returns MySQL values:\n *\n * - `bigint` columns are returned by `mysql2` as strings by default\n * (unless `supportBigNumbers` + `bigNumberStrings` are configured).\n * This parser converts them to JS `bigint`.\n *\n * - `tinyint(1)` columns (category `boolean`) may arrive as `0`/`1`\n * numbers. This parser normalizes them to JS `boolean`.\n *\n * - `json` columns may arrive as strings depending on driver config.\n * This parser parses them when needed.\n *\n * - `decimal` columns are returned as strings by `mysql2` to\n * preserve precision. Passed through as-is.\n *\n * - All other categories fall through to `DefaultRecordParser`.\n */\nexport class MySQLRecordParser extends DefaultRecordParser {\n protected override coerce(field: Field, raw: unknown): ParsedValue {\n if (raw === null || raw === undefined) {\n return null;\n }\n\n if (\n field.type.category === 'integer' &&\n BIGINT_NATIVE_TYPES.has(field.type.nativeType.toLowerCase())\n ) {\n if (typeof raw === 'bigint') {\n return raw;\n }\n if (typeof raw === 'string' || typeof raw === 'number') {\n return BigInt(raw);\n }\n return null;\n }\n\n if (field.type.category === 'boolean') {\n if (typeof raw === 'number') {\n return raw !== 0;\n }\n return Boolean(raw);\n }\n\n if (field.type.category === 'json' && typeof raw === 'string') {\n try {\n return JSON.parse(raw) as ParsedValue;\n } catch {\n return raw;\n }\n }\n\n return super.coerce(field, raw);\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport type { BuiltQuery } from '@/domain/query/BuiltQuery';\nimport type { RawQueryRunner } from '@/ports/RawQueryRunner';\n\n/**\n * MySQL implementation of `RawQueryRunner`.\n *\n * Holds a `MySQLClient` and forwards `BuiltQuery` instances to its\n * `execute(sql, params)` method, returning the driver's rows array\n * unchanged. Parsing into typed `ParsedRecord`s is the next stage.\n */\nexport class MySQLRawQueryRunner implements RawQueryRunner {\n constructor(private readonly client: MySQLClient) {}\n\n async run<TRow = unknown>(built: BuiltQuery): Promise<readonly TRow[]> {\n const [rows] = await this.client.execute<TRow>(built.command as string, [\n ...built.params,\n ]);\n return rows;\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { MySQLIntrospector } from '@/adapters/mysql/MySQLIntrospector';\nimport {\n MYSQL_ADAPTER_NAME,\n MYSQL_URL_SCHEMES,\n type MySQLAdapterName,\n} from '@/adapters/mysql/MySQLMeta';\nimport { MySQLQueryEngine } from '@/adapters/mysql/MySQLQueryEngine';\nimport { MySQLRawQueryRunner } from '@/adapters/mysql/MySQLRawQueryRunner';\nimport { MySQLRecordParser } from '@/adapters/mysql/MySQLRecordParser';\nimport type { Adapter } from '@/core/AdapterRegistry';\nimport type { AdapterFactory } from '@/ports/AdapterFactory';\n\n/**\n * MySQL adapter factory.\n *\n * Implements `AdapterFactory<MySQLClient, MySQLAdapterName>`.\n * `create` builds an `Adapter` bound to the user-provided client.\n *\n * @example\n * ```ts\n * import mysql from 'mysql2/promise';\n * import { Biref, mysqlAdapter } from '@biref/scanner';\n *\n * const connection = await mysql.createConnection({ ... });\n *\n * const biref = Biref.builder()\n * .withAdapter(mysqlAdapter.create(connection))\n * .build();\n *\n * const model = await biref.scan();\n * ```\n */\nexport const mysqlAdapter: AdapterFactory<MySQLClient, MySQLAdapterName> = {\n name: MYSQL_ADAPTER_NAME,\n urlSchemes: MYSQL_URL_SCHEMES,\n create(client: MySQLClient): Adapter<MySQLAdapterName> {\n return {\n name: MYSQL_ADAPTER_NAME,\n introspector: new MySQLIntrospector(client),\n engine: new MySQLQueryEngine(),\n runner: new MySQLRawQueryRunner(client),\n parser: new MySQLRecordParser(),\n urlSchemes: MYSQL_URL_SCHEMES,\n };\n },\n};\n\n/**\n * Type guard: narrows a generic `Adapter` to an `Adapter<MySQLAdapterName>`.\n */\nexport function isMySQLAdapter(\n adapter: Adapter,\n): adapter is Adapter<MySQLAdapterName> {\n return adapter.name === MYSQL_ADAPTER_NAME;\n}\n","/**\n * Single-character codes returned by `pg_type.typcategory`.\n *\n * Used by the column introspector to detect arrays, enums, and other\n * type families without inspecting `udt_name` directly.\n */\nexport const PgTypeCategory = {\n Array: 'A',\n Boolean: 'B',\n Composite: 'C',\n DateTime: 'D',\n Enum: 'E',\n Geometric: 'G',\n Network: 'I',\n Numeric: 'N',\n Pseudo: 'P',\n Range: 'R',\n String: 'S',\n Timespan: 'T',\n UserDefined: 'U',\n BitString: 'V',\n Unknown: 'X',\n InternalUse: 'Z',\n} as const;\n\nexport type PgTypeCategory =\n (typeof PgTypeCategory)[keyof typeof PgTypeCategory];\n\n/**\n * Single-character codes returned by `pg_type.typtype`.\n *\n * Distinguishes base types, composites, domains, enums, ranges, etc.\n */\nexport const PgTypeKind = {\n Base: 'b',\n Composite: 'c',\n Domain: 'd',\n Enum: 'e',\n MultiRange: 'm',\n Pseudo: 'p',\n Range: 'r',\n} as const;\n\nexport type PgTypeKind = (typeof PgTypeKind)[keyof typeof PgTypeKind];\n\n/**\n * Single-character codes returned by `pg_constraint.contype`.\n */\nexport const PgConstraintKind = {\n Check: 'c',\n ForeignKey: 'f',\n PrimaryKey: 'p',\n Trigger: 't',\n Unique: 'u',\n Exclusion: 'x',\n} as const;\n\nexport type PgConstraintKind =\n (typeof PgConstraintKind)[keyof typeof PgConstraintKind];\n\n/**\n * Single-character codes returned by `pg_constraint.confupdtype`\n * and `pg_constraint.confdeltype`.\n */\nexport const PgReferentialAction = {\n NoAction: 'a',\n Restrict: 'r',\n Cascade: 'c',\n SetNull: 'n',\n SetDefault: 'd',\n} as const;\n\nexport type PgReferentialAction =\n (typeof PgReferentialAction)[keyof typeof PgReferentialAction];\n\n/**\n * Names returned by `pg_am.amname` for index access methods.\n */\nexport const PgIndexMethod = {\n BTree: 'btree',\n Hash: 'hash',\n Gin: 'gin',\n Gist: 'gist',\n Brin: 'brin',\n SpGist: 'spgist',\n} as const;\n\nexport type PgIndexMethod = (typeof PgIndexMethod)[keyof typeof PgIndexMethod];\n","import { PgConstraintKind } from '@/adapters/postgres/pgEnums';\nimport type { RawConstraint } from '@/adapters/postgres/queries/ConstraintsQuery';\nimport type { Constraint, ConstraintKind } from '@/domain/model/Constraint';\n\n/**\n * Converts a raw constraint row from `ConstraintsQuery` into a\n * paradigm-neutral `Constraint`.\n *\n * Only handles check, unique, and exclusion constraints. Primary keys\n * are exposed through the entity's `identifier`; foreign keys are\n * exposed through `relationships`.\n */\nexport class ConstraintMapper {\n static toConstraint(raw: RawConstraint): Constraint {\n return {\n name: raw.name,\n kind: ConstraintMapper.toKind(raw.kind_code),\n fields: raw.columns,\n expression: raw.definition,\n };\n }\n\n private static toKind(code: string): ConstraintKind {\n switch (code) {\n case PgConstraintKind.Check: {\n return 'check';\n }\n case PgConstraintKind.Unique: {\n return 'unique';\n }\n case PgConstraintKind.Exclusion: {\n return 'exclusion';\n }\n default: {\n return 'custom';\n }\n }\n }\n}\n","import { PgTypeCategory, PgTypeKind } from '@/adapters/postgres/pgEnums';\nimport type { RawColumn } from '@/adapters/postgres/queries/ColumnsQuery';\nimport type { Field } from '@/domain/model/Field';\nimport type { FieldType, FieldTypeCategory } from '@/domain/model/FieldType';\n\n/**\n * Converts a raw column row from `ColumnsQuery` into a paradigm-neutral\n * `Field`, including the normalized `FieldType` category.\n */\nexport class FieldMapper {\n static toField(col: RawColumn, isIdentifier: boolean): Field {\n return {\n name: col.name,\n type: FieldMapper.toType(col),\n nullable: col.nullable,\n isIdentifier,\n defaultValue: col.default_value,\n description: col.description,\n };\n }\n\n private static toType(col: RawColumn): FieldType {\n if (col.type_category === PgTypeCategory.Array) {\n return {\n category: 'array',\n nativeType: col.native_type,\n elementType: FieldMapper.toElementType(col),\n };\n }\n\n if (col.type_kind === PgTypeKind.Enum) {\n return {\n category: 'enum',\n nativeType: col.native_type,\n enumValues: col.enum_values ?? [],\n };\n }\n\n return {\n category: FieldMapper.categorize(col.udt_name),\n nativeType: col.native_type,\n };\n }\n\n private static toElementType(col: RawColumn): FieldType {\n const elementUdt =\n col.element_udt_name ??\n (col.udt_name.startsWith('_') ? col.udt_name.slice(1) : col.udt_name);\n\n if (col.element_type_kind === PgTypeKind.Enum) {\n return {\n category: 'enum',\n nativeType: elementUdt,\n enumValues: col.element_enum_values ?? [],\n };\n }\n\n return {\n category: FieldMapper.categorize(elementUdt),\n nativeType: elementUdt,\n };\n }\n\n private static categorize(udt: string): FieldTypeCategory {\n switch (udt.toLowerCase()) {\n case 'varchar':\n case 'bpchar':\n case 'char':\n case 'text':\n case 'name':\n case 'citext': {\n return 'string';\n }\n case 'int2':\n case 'int4':\n case 'int8':\n case 'smallint':\n case 'integer':\n case 'bigint': {\n return 'integer';\n }\n case 'numeric':\n case 'decimal':\n case 'float4':\n case 'float8':\n case 'real':\n case 'money': {\n return 'decimal';\n }\n case 'bool':\n case 'boolean': {\n return 'boolean';\n }\n case 'date': {\n return 'date';\n }\n case 'timestamp':\n case 'timestamptz': {\n return 'timestamp';\n }\n case 'time':\n case 'timetz': {\n return 'time';\n }\n case 'json':\n case 'jsonb': {\n return 'json';\n }\n case 'uuid': {\n return 'uuid';\n }\n case 'bytea': {\n return 'binary';\n }\n default: {\n return 'unknown';\n }\n }\n }\n}\n","import { PgIndexMethod } from '@/adapters/postgres/pgEnums';\nimport type { RawIndex } from '@/adapters/postgres/queries/IndexesQuery';\nimport type { Index, IndexKind } from '@/domain/model/Index';\n\n/**\n * Converts a raw index row from `IndexesQuery` into a paradigm-neutral\n * `Index`, mapping the Postgres access method onto an `IndexKind`.\n */\nexport class IndexMapper {\n static toIndex(raw: RawIndex): Index {\n return {\n name: raw.name,\n fields: raw.columns,\n unique: raw.unique,\n kind: IndexMapper.toKind(raw.method),\n partial: raw.partial,\n definition: raw.definition,\n };\n }\n\n private static toKind(method: string): IndexKind {\n switch (method.toLowerCase()) {\n case PgIndexMethod.BTree: {\n return 'btree';\n }\n case PgIndexMethod.Hash: {\n return 'hash';\n }\n case PgIndexMethod.Gin: {\n return 'gin';\n }\n case PgIndexMethod.Gist: {\n return 'gist';\n }\n case PgIndexMethod.Brin: {\n return 'brin';\n }\n case PgIndexMethod.SpGist: {\n return 'spgist';\n }\n default: {\n return 'unknown';\n }\n }\n }\n}\n","import { PgReferentialAction } from '@/adapters/postgres/pgEnums';\nimport type { RawForeignKey } from '@/adapters/postgres/queries/ForeignKeysQuery';\nimport type { Reference, ReferentialAction } from '@/domain/model/Reference';\n\n/**\n * Converts a raw foreign key row from `ForeignKeysQuery` into a\n * paradigm-neutral `Reference`.\n *\n * The resulting `Reference` uses `confidence: 1` since Postgres foreign\n * keys are declared rather than inferred.\n */\nexport class ReferenceMapper {\n static toReference(fk: RawForeignKey): Reference {\n return {\n name: fk.name,\n fromEntity: { namespace: fk.from_namespace, name: fk.from_table },\n fromFields: fk.from_columns,\n toEntity: { namespace: fk.to_namespace, name: fk.to_table },\n toFields: fk.to_columns,\n confidence: 1,\n onUpdate: ReferenceMapper.toAction(fk.update_action_code),\n onDelete: ReferenceMapper.toAction(fk.delete_action_code),\n };\n }\n\n private static toAction(code: string): ReferentialAction {\n switch (code) {\n case PgReferentialAction.NoAction: {\n return 'no-action';\n }\n case PgReferentialAction.Restrict: {\n return 'restrict';\n }\n case PgReferentialAction.Cascade: {\n return 'cascade';\n }\n case PgReferentialAction.SetNull: {\n return 'set-null';\n }\n case PgReferentialAction.SetDefault: {\n return 'set-default';\n }\n default: {\n return 'no-action';\n }\n }\n }\n}\n","import { ConstraintMapper } from '@/adapters/postgres/mapping/ConstraintMapper';\nimport { FieldMapper } from '@/adapters/postgres/mapping/FieldMapper';\nimport { IndexMapper } from '@/adapters/postgres/mapping/IndexMapper';\nimport { ReferenceMapper } from '@/adapters/postgres/mapping/ReferenceMapper';\nimport type { RawColumn } from '@/adapters/postgres/queries/ColumnsQuery';\nimport type { RawConstraint } from '@/adapters/postgres/queries/ConstraintsQuery';\nimport type { RawForeignKey } from '@/adapters/postgres/queries/ForeignKeysQuery';\nimport type { RawIndex } from '@/adapters/postgres/queries/IndexesQuery';\nimport type { RawPrimaryKey } from '@/adapters/postgres/queries/PrimaryKeysQuery';\nimport type { RawTable } from '@/adapters/postgres/queries/TablesQuery';\nimport type { Constraint } from '@/domain/model/Constraint';\nimport type { Entity } from '@/domain/model/Entity';\nimport type { Field } from '@/domain/model/Field';\nimport type { Index } from '@/domain/model/Index';\nimport type { Relationship } from '@/domain/model/Relationship';\n\n/**\n * Raw query results handed to `EntityAssembler.assemble`.\n */\nexport interface AssembleInputs {\n readonly tables: readonly RawTable[];\n readonly columns: readonly RawColumn[];\n readonly primaryKeys: readonly RawPrimaryKey[];\n readonly foreignKeys: readonly RawForeignKey[];\n readonly indexes: readonly RawIndex[];\n readonly constraints: readonly RawConstraint[];\n}\n\n/**\n * Stitches raw `pg_catalog` query results into paradigm-neutral\n * `Entity` objects.\n *\n * For every foreign key the assembler emits an `outbound` relationship\n * on the source entity AND an `inbound` relationship on the target\n * entity. Rows whose entity is not present in `inputs.tables` (e.g. a\n * FK pointing to a namespace the caller did not request) are skipped.\n */\nexport class EntityAssembler {\n static assemble(inputs: AssembleInputs): Entity[] {\n const tableKeys = new Set(\n inputs.tables.map((t) => EntityAssembler.qualified(t.namespace, t.name)),\n );\n\n const pkByEntity = EntityAssembler.indexPrimaryKeys(inputs.primaryKeys);\n const colsByEntity = EntityAssembler.indexColumns(inputs.columns);\n const relsByEntity = EntityAssembler.buildRelationships(\n inputs.foreignKeys,\n tableKeys,\n );\n const indexesByEntity = EntityAssembler.buildIndexes(\n inputs.indexes,\n tableKeys,\n );\n const constraintsByEntity = EntityAssembler.buildConstraints(\n inputs.constraints,\n tableKeys,\n );\n\n return inputs.tables.map((table) => {\n const key = EntityAssembler.qualified(table.namespace, table.name);\n const pkColumns = pkByEntity.get(key) ?? [];\n const pkSet = new Set(pkColumns);\n const rawCols = colsByEntity.get(key) ?? [];\n const fields: Field[] = rawCols.map((col) =>\n FieldMapper.toField(col, pkSet.has(col.name)),\n );\n\n return {\n namespace: table.namespace,\n name: table.name,\n fields,\n identifier: pkColumns,\n relationships: relsByEntity.get(key) ?? [],\n constraints: constraintsByEntity.get(key) ?? [],\n indexes: indexesByEntity.get(key) ?? [],\n description: table.description,\n };\n });\n }\n\n private static indexPrimaryKeys(\n primaryKeys: readonly RawPrimaryKey[],\n ): Map<string, readonly string[]> {\n const map = new Map<string, readonly string[]>();\n for (const pk of primaryKeys) {\n map.set(\n EntityAssembler.qualified(pk.namespace, pk.table_name),\n pk.columns,\n );\n }\n return map;\n }\n\n private static indexColumns(\n columns: readonly RawColumn[],\n ): Map<string, RawColumn[]> {\n const map = new Map<string, RawColumn[]>();\n for (const col of columns) {\n const key = EntityAssembler.qualified(col.namespace, col.table_name);\n const list = map.get(key);\n if (list) {\n list.push(col);\n } else {\n map.set(key, [col]);\n }\n }\n return map;\n }\n\n private static buildRelationships(\n foreignKeys: readonly RawForeignKey[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Relationship[]> {\n const map = new Map<string, Relationship[]>();\n for (const fk of foreignKeys) {\n const reference = ReferenceMapper.toReference(fk);\n const fromKey = EntityAssembler.qualified(\n fk.from_namespace,\n fk.from_table,\n );\n const toKey = EntityAssembler.qualified(fk.to_namespace, fk.to_table);\n\n if (tableKeys.has(fromKey)) {\n EntityAssembler.push(map, fromKey, {\n direction: 'outbound',\n reference,\n });\n }\n if (tableKeys.has(toKey)) {\n EntityAssembler.push(map, toKey, {\n direction: 'inbound',\n reference,\n });\n }\n }\n return map;\n }\n\n private static buildIndexes(\n indexes: readonly RawIndex[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Index[]> {\n const map = new Map<string, Index[]>();\n for (const idx of indexes) {\n const key = EntityAssembler.qualified(idx.namespace, idx.table_name);\n if (!tableKeys.has(key)) {\n continue;\n }\n EntityAssembler.push(map, key, IndexMapper.toIndex(idx));\n }\n return map;\n }\n\n private static buildConstraints(\n constraints: readonly RawConstraint[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Constraint[]> {\n const map = new Map<string, Constraint[]>();\n for (const cn of constraints) {\n const key = EntityAssembler.qualified(cn.namespace, cn.table_name);\n if (!tableKeys.has(key)) {\n continue;\n }\n EntityAssembler.push(map, key, ConstraintMapper.toConstraint(cn));\n }\n return map;\n }\n\n private static push<T>(map: Map<string, T[]>, key: string, value: T): void {\n const list = map.get(key);\n if (list) {\n list.push(value);\n } else {\n map.set(key, [value]);\n }\n }\n\n private static qualified(namespace: string, name: string): string {\n return `${namespace}.${name}`;\n }\n}\n","/**\n * Adapter metadata constants for Postgres.\n *\n * Centralized so the rest of the adapter never references the literal\n * string 'postgres' or the URL schemes by hand. Anywhere those values\n * are needed, import the constant.\n */\n\nexport const POSTGRES_ADAPTER_NAME = 'postgres';\n\n/** Literal type for the Postgres adapter name, used for discrimination. */\nexport type PostgresAdapterName = typeof POSTGRES_ADAPTER_NAME;\n\nexport const POSTGRES_URL_SCHEMES: readonly string[] = [\n 'postgres',\n 'postgresql',\n];\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\nexport interface RawColumn {\n namespace: string;\n table_name: string;\n name: string;\n native_type: string;\n udt_name: string;\n type_category: string;\n type_kind: string;\n nullable: boolean;\n default_value: string | null;\n description: string | null;\n enum_values: string[] | null;\n element_udt_name: string | null;\n element_type_category: string | null;\n element_type_kind: string | null;\n element_enum_values: string[] | null;\n}\n\nexport class ColumnsQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n c.relname AS table_name,\n a.attname AS name,\n format_type(a.atttypid, a.atttypmod) AS native_type,\n t.typname AS udt_name,\n t.typcategory AS type_category,\n t.typtype AS type_kind,\n NOT a.attnotnull AS nullable,\n pg_get_expr(d.adbin, d.adrelid) AS default_value,\n col_description(c.oid, a.attnum) AS description,\n CASE\n WHEN t.typtype = 'e' THEN (\n SELECT array_agg(enumlabel ORDER BY enumsortorder)::text[]\n FROM pg_enum\n WHERE enumtypid = a.atttypid\n )\n ELSE NULL\n END AS enum_values,\n et.typname AS element_udt_name,\n et.typcategory AS element_type_category,\n et.typtype AS element_type_kind,\n CASE\n WHEN et.typtype = 'e' THEN (\n SELECT array_agg(enumlabel ORDER BY enumsortorder)::text[]\n FROM pg_enum\n WHERE enumtypid = et.oid\n )\n ELSE NULL\n END AS element_enum_values\nFROM pg_attribute a\nJOIN pg_class c ON c.oid = a.attrelid\nJOIN pg_namespace n ON n.oid = c.relnamespace\nJOIN pg_type t ON t.oid = a.atttypid\nLEFT JOIN pg_type et ON et.oid = t.typelem AND t.typcategory = 'A'\nLEFT JOIN pg_attrdef d ON d.adrelid = c.oid AND d.adnum = a.attnum\nWHERE c.relkind IN ('r', 'p')\n AND a.attnum > 0\n AND NOT a.attisdropped\n AND n.nspname = ANY($1)\nORDER BY n.nspname, c.relname, a.attnum\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawColumn[]> {\n const result = await client.query<RawColumn>(ColumnsQuery.SQL, [\n namespaces,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `ConstraintsQuery.fetch`.\n *\n * Covers `check`, `unique`, and `exclusion` constraints. Foreign keys\n * and primary keys are fetched separately.\n */\nexport interface RawConstraint {\n namespace: string;\n table_name: string;\n name: string;\n kind_code: string;\n definition: string | null;\n columns: string[];\n}\n\n/**\n * Reads check, unique, and exclusion constraints from `pg_constraint`\n * for the given namespaces. The constraint definition is the textual\n * form returned by `pg_get_constraintdef`.\n */\nexport class ConstraintsQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n cls.relname AS table_name,\n c.conname AS name,\n c.contype AS kind_code,\n pg_get_constraintdef(c.oid) AS definition,\n CASE\n WHEN array_length(c.conkey, 1) > 0 THEN\n (SELECT array_agg(att.attname ORDER BY u.ord)::text[]\n FROM unnest(c.conkey) WITH ORDINALITY AS u(attnum, ord)\n JOIN pg_attribute att\n ON att.attrelid = c.conrelid AND att.attnum = u.attnum)\n ELSE ARRAY[]::text[]\n END AS columns\nFROM pg_constraint c\nJOIN pg_class cls ON cls.oid = c.conrelid\nJOIN pg_namespace n ON n.oid = cls.relnamespace\nWHERE c.contype IN ('c', 'u', 'x')\n AND n.nspname = ANY($1)\nORDER BY n.nspname, cls.relname, c.conname\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawConstraint[]> {\n const result = await client.query<RawConstraint>(ConstraintsQuery.SQL, [\n namespaces,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `ForeignKeysQuery.fetch`.\n *\n * Each row corresponds to one declared foreign key constraint and\n * already aggregates the from/to columns in declaration order, so\n * composite keys are returned as a single row.\n */\nexport interface RawForeignKey {\n name: string;\n from_namespace: string;\n from_table: string;\n from_columns: string[];\n to_namespace: string;\n to_table: string;\n to_columns: string[];\n update_action_code: string;\n delete_action_code: string;\n}\n\n/**\n * Reads foreign key constraints from `pg_constraint` for the given\n * namespaces. Returns the source and target columns and the update\n * and delete action codes (single character codes from\n * `confupdtype` / `confdeltype`).\n */\nexport class ForeignKeysQuery {\n private static readonly SQL = `\nSELECT\n c.conname AS name,\n fn.nspname AS from_namespace,\n fc.relname AS from_table,\n (SELECT array_agg(att.attname ORDER BY u.ord)::text[]\n FROM unnest(c.conkey) WITH ORDINALITY AS u(attnum, ord)\n JOIN pg_attribute att\n ON att.attrelid = c.conrelid AND att.attnum = u.attnum\n ) AS from_columns,\n tn.nspname AS to_namespace,\n tc.relname AS to_table,\n (SELECT array_agg(att.attname ORDER BY u.ord)::text[]\n FROM unnest(c.confkey) WITH ORDINALITY AS u(attnum, ord)\n JOIN pg_attribute att\n ON att.attrelid = c.confrelid AND att.attnum = u.attnum\n ) AS to_columns,\n c.confupdtype AS update_action_code,\n c.confdeltype AS delete_action_code\nFROM pg_constraint c\nJOIN pg_class fc ON fc.oid = c.conrelid\nJOIN pg_namespace fn ON fn.oid = fc.relnamespace\nJOIN pg_class tc ON tc.oid = c.confrelid\nJOIN pg_namespace tn ON tn.oid = tc.relnamespace\nWHERE c.contype = 'f'\n AND fn.nspname = ANY($1)\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawForeignKey[]> {\n const result = await client.query<RawForeignKey>(ForeignKeysQuery.SQL, [\n namespaces,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `IndexesQuery.fetch`.\n *\n * `columns` carries the indexed columns in their order within the\n * index. `partial` is true when the index has a `WHERE` clause.\n * `definition` is the textual `CREATE INDEX` statement.\n */\nexport interface RawIndex {\n namespace: string;\n table_name: string;\n name: string;\n method: string;\n unique: boolean;\n partial: boolean;\n definition: string | null;\n columns: string[];\n}\n\n/**\n * Reads non-primary indexes from `pg_index` for the given namespaces.\n * The primary key index is excluded because the primary key columns\n * are already exposed through the entity's `identifier`.\n */\nexport class IndexesQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n t.relname AS table_name,\n i.relname AS name,\n am.amname AS method,\n ix.indisunique AS unique,\n (ix.indpred IS NOT NULL) AS partial,\n pg_get_indexdef(ix.indexrelid) AS definition,\n ARRAY(\n SELECT a.attname\n FROM unnest(ix.indkey::int[]) WITH ORDINALITY AS k(attnum, ord)\n JOIN pg_attribute a\n ON a.attrelid = t.oid AND a.attnum = k.attnum\n ORDER BY k.ord\n )::text[] AS columns\nFROM pg_index ix\nJOIN pg_class i ON i.oid = ix.indexrelid\nJOIN pg_class t ON t.oid = ix.indrelid\nJOIN pg_namespace n ON n.oid = t.relnamespace\nJOIN pg_am am ON am.oid = i.relam\nWHERE NOT ix.indisprimary\n AND n.nspname = ANY($1)\nORDER BY n.nspname, t.relname, i.relname\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawIndex[]> {\n const result = await client.query<RawIndex>(IndexesQuery.SQL, [namespaces]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `PrimaryKeysQuery.fetch`.\n *\n * `columns` carries the columns in declaration order, supporting\n * composite primary keys without flattening them.\n */\nexport interface RawPrimaryKey {\n namespace: string;\n table_name: string;\n columns: string[];\n}\n\n/**\n * Reads primary key constraints from `pg_constraint` for the given\n * namespaces. Composite keys are returned as a single row with all\n * columns ordered by their position in the constraint.\n */\nexport class PrimaryKeysQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n cls.relname AS table_name,\n (SELECT array_agg(att.attname ORDER BY u.ord)::text[]\n FROM unnest(c.conkey) WITH ORDINALITY AS u(attnum, ord)\n JOIN pg_attribute att\n ON att.attrelid = c.conrelid AND att.attnum = u.attnum\n ) AS columns\nFROM pg_constraint c\nJOIN pg_class cls ON cls.oid = c.conrelid\nJOIN pg_namespace n ON n.oid = cls.relnamespace\nWHERE c.contype = 'p'\n AND n.nspname = ANY($1)\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawPrimaryKey[]> {\n const result = await client.query<RawPrimaryKey>(PrimaryKeysQuery.SQL, [\n namespaces,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `TablesQuery.fetch`.\n *\n * Mirrors the columns selected from `pg_class` and `pg_namespace` for\n * each relation: regular tables and partitioned tables.\n */\nexport interface RawTable {\n namespace: string;\n name: string;\n description: string | null;\n}\n\n/**\n * Reads relations (tables and partitioned tables) from the given\n * namespaces, along with their pg_class comment.\n */\nexport class TablesQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n c.relname AS name,\n obj_description(c.oid, 'pg_class') AS description\nFROM pg_class c\nJOIN pg_namespace n ON n.oid = c.relnamespace\nWHERE c.relkind IN ('r', 'p')\n AND n.nspname = ANY($1)\nORDER BY n.nspname, c.relname\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawTable[]> {\n const result = await client.query<RawTable>(TablesQuery.SQL, [namespaces]);\n return result.rows;\n }\n}\n","import { EntityAssembler } from '@/adapters/postgres/mapping/EntityAssembler';\nimport type { PostgresClient } from '@/adapters/postgres/PostgresClient';\nimport { POSTGRES_ADAPTER_NAME } from '@/adapters/postgres/PostgresMeta';\nimport {\n ColumnsQuery,\n type RawColumn,\n} from '@/adapters/postgres/queries/ColumnsQuery';\nimport {\n ConstraintsQuery,\n type RawConstraint,\n} from '@/adapters/postgres/queries/ConstraintsQuery';\nimport {\n ForeignKeysQuery,\n type RawForeignKey,\n} from '@/adapters/postgres/queries/ForeignKeysQuery';\nimport {\n IndexesQuery,\n type RawIndex,\n} from '@/adapters/postgres/queries/IndexesQuery';\nimport {\n PrimaryKeysQuery,\n type RawPrimaryKey,\n} from '@/adapters/postgres/queries/PrimaryKeysQuery';\nimport {\n type RawTable,\n TablesQuery,\n} from '@/adapters/postgres/queries/TablesQuery';\nimport { DataModel } from '@/domain/model/DataModel';\nimport type { IntrospectOptions, Introspector } from '@/ports/Introspector';\n\nconst DEFAULT_NAMESPACES: readonly string[] = ['public'];\n\n/**\n * Postgres implementation of the `Introspector` port.\n *\n * Runs six queries against `pg_catalog` in parallel (tables, columns,\n * primary keys, foreign keys, indexes, constraints) and hands the\n * result to `EntityAssembler`, which stitches them into a paradigm-\n * neutral `DataModel`.\n *\n * What it returns for each entity:\n * - fields with normalized type categories\n * - identifier (primary key columns)\n * - relationships in BOTH directions\n * - constraints (unique, check, exclusion)\n * - indexes (excluding the primary key index)\n *\n * Accepts any client that satisfies `PostgresClient`, so it works with\n * `pg.Client`, `pg.Pool`, or any compatible library without the SDK\n * importing `pg`.\n */\nexport class PostgresIntrospector implements Introspector {\n readonly name = POSTGRES_ADAPTER_NAME;\n readonly kind = 'relational' as const;\n\n constructor(private readonly client: PostgresClient) {}\n\n async introspect(options: IntrospectOptions = {}): Promise<DataModel> {\n const namespaces = await this.resolveNamespaces(options.namespaces);\n\n const [tables, columns, primaryKeys, foreignKeys, indexes, constraints]: [\n readonly RawTable[],\n readonly RawColumn[],\n readonly RawPrimaryKey[],\n readonly RawForeignKey[],\n readonly RawIndex[],\n readonly RawConstraint[],\n ] = await Promise.all([\n TablesQuery.fetch(this.client, namespaces),\n ColumnsQuery.fetch(this.client, namespaces),\n PrimaryKeysQuery.fetch(this.client, namespaces),\n ForeignKeysQuery.fetch(this.client, namespaces),\n IndexesQuery.fetch(this.client, namespaces),\n ConstraintsQuery.fetch(this.client, namespaces),\n ]);\n\n const filteredTables = PostgresIntrospector.applyEntityFilters(\n tables,\n options,\n );\n\n const entities = EntityAssembler.assemble({\n tables: filteredTables,\n columns,\n primaryKeys,\n foreignKeys,\n indexes,\n constraints,\n });\n\n return new DataModel('relational', entities);\n }\n\n private async resolveNamespaces(\n raw: readonly string[] | 'all' | undefined,\n ): Promise<readonly string[]> {\n if (raw === undefined) {\n return DEFAULT_NAMESPACES;\n }\n if (raw === 'all') {\n const result = await this.client.query<{ nspname: string }>(\n PostgresIntrospector.ALL_NAMESPACES_SQL,\n );\n return result.rows.map((row) => row.nspname);\n }\n return raw;\n }\n\n private static readonly ALL_NAMESPACES_SQL = `\nSELECT n.nspname\nFROM pg_namespace n\nWHERE n.nspname NOT IN ('pg_catalog', 'information_schema')\n AND n.nspname NOT LIKE 'pg_toast%'\n AND n.nspname NOT LIKE 'pg_temp_%'\nORDER BY n.nspname\n`;\n\n private static applyEntityFilters(\n tables: readonly RawTable[],\n options: IntrospectOptions,\n ): readonly RawTable[] {\n const { includeEntities: allow, excludeEntities: deny } = options;\n if (!allow && !deny) {\n return tables;\n }\n return tables.filter((t) => {\n if (allow && !allow.includes(t.name)) {\n return false;\n }\n if (deny?.includes(t.name)) {\n return false;\n }\n return true;\n });\n }\n}\n","/**\n * Quoting helpers for Postgres SQL identifiers.\n *\n * Wraps identifiers in double quotes and escapes any embedded double\n * quotes by doubling them, matching the Postgres identifier grammar.\n * Always quotes, even for identifiers that would not strictly require\n * it, so mixed case and reserved words are handled without special\n * cases.\n */\nexport class SqlIdentifier {\n static quote(id: string): string {\n return `\"${id.replace(/\"/g, '\"\"')}\"`;\n }\n\n static qualified(namespace: string, name: string): string {\n return `${SqlIdentifier.quote(namespace)}.${SqlIdentifier.quote(name)}`;\n }\n}\n","import { SqlIdentifier } from '@/adapters/postgres/query/SqlIdentifier';\nimport type { SqlParamList } from '@/adapters/postgres/query/SqlParamList';\nimport type { Filter } from '@/domain/query/QuerySpec';\n\n/**\n * Turns a `Filter` into a Postgres SQL WHERE fragment, binding its\n * values on a shared `SqlParamList`.\n *\n * The builder does not quote field names itself beyond what\n * `SqlIdentifier.quote` does: it assumes the caller has already\n * validated that the field exists on the target entity.\n *\n * Handles every `FilterOperator`:\n * eq, neq, lt, lte, gt, gte, like, ilike, in, not-in,\n * is-null, is-not-null, between\n *\n * Throws on malformed values (e.g. 'in' with a non-array) rather than\n * producing broken SQL.\n */\nexport class FilterBuilder {\n constructor(private readonly params: SqlParamList) {}\n\n build(filter: Filter): string {\n const col = SqlIdentifier.quote(filter.field);\n\n switch (filter.operator) {\n case 'eq': {\n return `${col} = ${this.params.add(filter.value)}`;\n }\n case 'neq': {\n return `${col} <> ${this.params.add(filter.value)}`;\n }\n case 'lt': {\n return `${col} < ${this.params.add(filter.value)}`;\n }\n case 'lte': {\n return `${col} <= ${this.params.add(filter.value)}`;\n }\n case 'gt': {\n return `${col} > ${this.params.add(filter.value)}`;\n }\n case 'gte': {\n return `${col} >= ${this.params.add(filter.value)}`;\n }\n case 'like': {\n return `${col} LIKE ${this.params.add(filter.value)}`;\n }\n case 'ilike': {\n return `${col} ILIKE ${this.params.add(filter.value)}`;\n }\n case 'is-null': {\n return `${col} IS NULL`;\n }\n case 'is-not-null': {\n return `${col} IS NOT NULL`;\n }\n case 'in': {\n return this.buildInClause(col, filter.value, 'FALSE', 'IN');\n }\n case 'not-in': {\n return this.buildInClause(col, filter.value, 'TRUE', 'NOT IN');\n }\n case 'between': {\n return this.buildBetween(col, filter.value);\n }\n default: {\n const exhaustive: never = filter.operator;\n throw new Error(`Unknown filter operator: ${String(exhaustive)}`);\n }\n }\n }\n\n private buildInClause(\n col: string,\n value: unknown,\n emptyFallback: string,\n keyword: 'IN' | 'NOT IN',\n ): string {\n if (!Array.isArray(value)) {\n throw new Error(\n `Operator '${keyword.toLowerCase()}' requires an array value.`,\n );\n }\n const values = value as readonly unknown[];\n if (values.length === 0) {\n return emptyFallback;\n }\n const placeholders = this.params.addAll(values);\n return `${col} ${keyword} (${placeholders.join(', ')})`;\n }\n\n private buildBetween(col: string, value: unknown): string {\n if (!Array.isArray(value) || value.length !== 2) {\n throw new Error(\"Operator 'between' requires a [min, max] tuple.\");\n }\n const tuple = value as readonly unknown[];\n const lo = this.params.add(tuple[0]);\n const hi = this.params.add(tuple[1]);\n return `${col} BETWEEN ${lo} AND ${hi}`;\n }\n}\n","/**\n * Mutable bound parameter list for Postgres query building.\n *\n * Keeps track of the ordered values and hands out `$N` placeholder\n * strings as they are added. Shared across the filter, limit, and\n * offset stages so every placeholder number is unique and sequential.\n */\nexport class SqlParamList {\n private readonly values: unknown[] = [];\n\n /**\n * Append a value and return its placeholder (`$N`, where N is the\n * 1-based position of the value in the list).\n */\n add(value: unknown): string {\n this.values.push(value);\n return `$${this.values.length}`;\n }\n\n /**\n * Append many values and return their placeholders in order.\n */\n addAll(values: readonly unknown[]): readonly string[] {\n return values.map((v) => this.add(v));\n }\n\n /** Number of values currently bound. */\n get size(): number {\n return this.values.length;\n }\n\n /**\n * Return a read-only copy of the bound values. The returned array\n * is not backed by the internal storage.\n */\n toArray(): readonly unknown[] {\n return [...this.values];\n }\n}\n","import { POSTGRES_ADAPTER_NAME } from '@/adapters/postgres/PostgresMeta';\nimport { FilterBuilder } from '@/adapters/postgres/query/FilterBuilder';\nimport { SqlIdentifier } from '@/adapters/postgres/query/SqlIdentifier';\nimport { SqlParamList } from '@/adapters/postgres/query/SqlParamList';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { BuiltQuery } from '@/domain/query/BuiltQuery';\nimport type { QuerySpec } from '@/domain/query/QuerySpec';\nimport type { QueryEngine } from '@/ports/QueryEngine';\n\n/**\n * Postgres implementation of the `QueryEngine` port.\n *\n * Produces parameterized SQL using `$1`, `$2`, ... placeholders and\n * double-quoted identifiers. Validates the spec against the\n * `DataModel` before emitting any SQL: unknown entities or fields\n * throw rather than yielding a broken query.\n *\n * Scope:\n * - SELECT against a single entity\n * - WHERE filters (every `FilterOperator`)\n * - ORDER BY\n * - LIMIT and OFFSET\n * - No joins, group by, or aggregates yet\n */\nexport class PostgresQueryEngine implements QueryEngine<string> {\n readonly name = POSTGRES_ADAPTER_NAME;\n readonly kind = 'relational' as const;\n\n build(spec: QuerySpec, model: DataModel): BuiltQuery<string> {\n const entity = model.getEntity(spec.namespace, spec.entity);\n if (!entity) {\n throw new Error(\n `Entity \"${spec.namespace}.${spec.entity}\" not found in the data model.`,\n );\n }\n\n const fieldNames = new Set(entity.fields.map((f) => f.name));\n const selectedFields =\n spec.select && spec.select.length > 0\n ? [...spec.select]\n : entity.fields.map((f) => f.name);\n\n for (const field of selectedFields) {\n if (!fieldNames.has(field)) {\n throw new Error(\n `Field \"${field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n }\n\n const params = new SqlParamList();\n const filterBuilder = new FilterBuilder(params);\n\n const selectClause = selectedFields.map(SqlIdentifier.quote).join(', ');\n const fromClause = SqlIdentifier.qualified(spec.namespace, spec.entity);\n\n let sql = `SELECT ${selectClause} FROM ${fromClause}`;\n\n if (spec.filters && spec.filters.length > 0) {\n const wherePieces = spec.filters.map((filter) => {\n if (!fieldNames.has(filter.field)) {\n throw new Error(\n `Filter field \"${filter.field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n return filterBuilder.build(filter);\n });\n sql += ` WHERE ${wherePieces.join(' AND ')}`;\n }\n\n if (spec.orderBy && spec.orderBy.length > 0) {\n const orderPieces = spec.orderBy.map((order) => {\n if (!fieldNames.has(order.field)) {\n throw new Error(\n `Order field \"${order.field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n return `${SqlIdentifier.quote(order.field)} ${order.direction.toUpperCase()}`;\n });\n sql += ` ORDER BY ${orderPieces.join(', ')}`;\n }\n\n if (spec.limit !== undefined) {\n sql += ` LIMIT ${params.add(spec.limit)}`;\n }\n\n if (spec.offset !== undefined) {\n sql += ` OFFSET ${params.add(spec.offset)}`;\n }\n\n return {\n command: sql,\n params: params.toArray(),\n metadata: {\n engine: POSTGRES_ADAPTER_NAME,\n paramCount: params.size,\n },\n };\n }\n}\n","import type { Field } from '@/domain/model/Field';\nimport { DefaultRecordParser } from '@/parsing/DefaultRecordParser';\nimport type { ParsedValue } from '@/parsing/ParsedRecord';\n\nconst BIGINT_NATIVE_TYPES: ReadonlySet<string> = new Set(['int8', 'bigint']);\n\n/**\n * Postgres-aware `RecordParser`.\n *\n * Extends `DefaultRecordParser` with behavior that matches how the\n * `pg` driver returns Postgres values:\n *\n * - `int8` / `bigint` columns are returned by `pg` as strings by\n * default (to preserve precision). This parser converts them to\n * JS `bigint` so downstream code does not silently lose digits.\n *\n * - `json` / `jsonb` columns are usually already parsed by `pg`,\n * but when they arrive as strings (for example from drivers that\n * do not auto-parse) this parser parses them.\n *\n * - All other categories fall through to `DefaultRecordParser`.\n *\n * Use this parser when consuming rows that come from a `pg.Client` or\n * `pg.Pool`. For adapters that handle these concerns themselves, the\n * default parser is still appropriate.\n */\nexport class PostgresRecordParser extends DefaultRecordParser {\n protected override coerce(field: Field, raw: unknown): ParsedValue {\n if (raw === null || raw === undefined) {\n return null;\n }\n\n if (\n field.type.category === 'integer' &&\n BIGINT_NATIVE_TYPES.has(field.type.nativeType.toLowerCase())\n ) {\n if (typeof raw === 'bigint') {\n return raw;\n }\n if (typeof raw === 'string' || typeof raw === 'number') {\n return BigInt(raw);\n }\n return null;\n }\n\n if (field.type.category === 'json' && typeof raw === 'string') {\n try {\n return JSON.parse(raw) as ParsedValue;\n } catch {\n return raw;\n }\n }\n\n return super.coerce(field, raw);\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\nimport type { BuiltQuery } from '@/domain/query/BuiltQuery';\nimport type { RawQueryRunner } from '@/ports/RawQueryRunner';\n\n/**\n * Postgres implementation of `RawQueryRunner`.\n *\n * Holds a `PostgresClient` and forwards `BuiltQuery` instances to its\n * `query(text, params)` method, returning the driver's `rows` array\n * unchanged. Parsing into typed `ParsedRecord`s is the next stage.\n */\nexport class PostgresRawQueryRunner implements RawQueryRunner {\n constructor(private readonly client: PostgresClient) {}\n\n async run<TRow = unknown>(built: BuiltQuery): Promise<readonly TRow[]> {\n const result = await this.client.query<TRow>(built.command as string, [\n ...built.params,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\nimport { PostgresIntrospector } from '@/adapters/postgres/PostgresIntrospector';\nimport {\n POSTGRES_ADAPTER_NAME,\n POSTGRES_URL_SCHEMES,\n type PostgresAdapterName,\n} from '@/adapters/postgres/PostgresMeta';\nimport { PostgresQueryEngine } from '@/adapters/postgres/PostgresQueryEngine';\nimport { PostgresRawQueryRunner } from '@/adapters/postgres/PostgresRawQueryRunner';\nimport { PostgresRecordParser } from '@/adapters/postgres/PostgresRecordParser';\nimport type { Adapter } from '@/core/AdapterRegistry';\nimport type { AdapterFactory } from '@/ports/AdapterFactory';\n\n/**\n * Postgres adapter factory.\n *\n * Implements `AdapterFactory<PostgresClient, PostgresAdapterName>`.\n * `create` builds an `Adapter` bound to the user-provided client.\n *\n * @example\n * ```ts\n * import pg from 'pg';\n * import { Biref, postgresAdapter } from '@biref/scanner';\n *\n * const client = new pg.Client({ ... });\n * await client.connect();\n *\n * const biref = Biref.builder()\n * .withAdapter(postgresAdapter.create(client))\n * .build();\n *\n * const model = await biref.scan();\n * ```\n */\nexport const postgresAdapter: AdapterFactory<\n PostgresClient,\n PostgresAdapterName\n> = {\n name: POSTGRES_ADAPTER_NAME,\n urlSchemes: POSTGRES_URL_SCHEMES,\n create(client: PostgresClient): Adapter<PostgresAdapterName> {\n return {\n name: POSTGRES_ADAPTER_NAME,\n introspector: new PostgresIntrospector(client),\n engine: new PostgresQueryEngine(),\n runner: new PostgresRawQueryRunner(client),\n parser: new PostgresRecordParser(),\n urlSchemes: POSTGRES_URL_SCHEMES,\n };\n },\n};\n\n/**\n * Type guard: narrows a generic `Adapter` to an `Adapter<PostgresAdapterName>`.\n *\n * @example\n * ```ts\n * if (isPostgresAdapter(adapter)) {\n * // adapter.name is now typed as 'postgres'\n * }\n * ```\n */\nexport function isPostgresAdapter(\n adapter: Adapter,\n): adapter is Adapter<PostgresAdapterName> {\n return adapter.name === POSTGRES_ADAPTER_NAME;\n}\n","const SCAFFOLD = `// biref.schema.overrides.ts - edit freely, regen will NOT touch this file.\n//\n// Use this file to attach concrete TypeScript types to columns whose\n// shape the database scanner cannot see - typically jsonb payloads.\n// Key each override by qualified entity name ('namespace.entity')\n// and list the fields you want to type.\n//\n// @example\n// export interface Overrides extends BirefOverridesShape {\n// 'identity.users': {\n// profile: { plan: 'free' | 'pro'; prefs: { darkMode: boolean } };\n// };\n// }\n\nimport type { BirefOverridesShape } from '@biref/scanner';\n\nexport interface Overrides extends BirefOverridesShape {}\n`;\n\n/**\n * Content of the first-run overrides file scaffold.\n *\n * The CLI only writes this if the target path does not already\n * exist - once the user has started editing it, regenerating the\n * schema never overwrites their work.\n */\nexport function overridesScaffold(): string {\n return SCAFFOLD;\n}\n","import type { FieldType, FieldTypeCategory } from '@/domain/model/FieldType';\n\n/**\n * Maps a paradigm-neutral `FieldType` to the TypeScript type literal\n * string emitted into the codegen-generated schema.\n *\n * JSON / JSONB categories map to `unknown` (users replace them via\n * the sibling overrides file). Enum categories with known values map\n * to a union of string literals. Array categories recurse on the\n * element type. Everything else follows the fixed table described in\n * the README.\n */\nexport function tsTypeFor(type: FieldType, nullable: boolean): string {\n const base = baseType(type);\n return nullable ? `${base} | null` : base;\n}\n\nfunction baseType(type: FieldType): string {\n switch (type.category) {\n case 'string':\n case 'uuid': {\n return 'string';\n }\n case 'enum': {\n if (type.enumValues && type.enumValues.length > 0) {\n return type.enumValues\n .map((value) => `'${escapeSingleQuote(value)}'`)\n .join(' | ');\n }\n return 'string';\n }\n case 'integer': {\n return 'number';\n }\n case 'decimal': {\n return 'string';\n }\n case 'boolean': {\n return 'boolean';\n }\n case 'date':\n case 'timestamp':\n case 'time': {\n return 'Date';\n }\n case 'json': {\n return 'unknown';\n }\n case 'binary': {\n return 'Uint8Array';\n }\n case 'array': {\n const element = type.elementType ? baseType(type.elementType) : 'unknown';\n return `ReadonlyArray<${element}>`;\n }\n case 'reference':\n case 'unknown': {\n return 'unknown';\n }\n default: {\n return assertNever(type.category);\n }\n }\n}\n\nfunction escapeSingleQuote(value: string): string {\n return value.replace(/\\\\/g, '\\\\\\\\').replace(/'/g, \"\\\\'\");\n}\n\nfunction assertNever(value: never): never {\n throw new Error(`Unhandled FieldTypeCategory: ${String(value)}`);\n}\n\n/**\n * Exported purely so tests can assert the full domain.\n */\nexport const ALL_CATEGORIES: readonly FieldTypeCategory[] = [\n 'string',\n 'integer',\n 'decimal',\n 'boolean',\n 'date',\n 'timestamp',\n 'time',\n 'json',\n 'uuid',\n 'binary',\n 'enum',\n 'array',\n 'reference',\n 'unknown',\n];\n","import type { Entity } from '@/domain/model/Entity';\nimport type { Relationship } from '@/domain/model/Relationship';\n\n/**\n * Build a map from friendly relation name to the underlying\n * `Relationship` for a given entity.\n *\n * Outbound relations (this entity holds the FK) are named after the\n * FK **column** with the trailing `_id` / `Id` stripped. This maps\n * directly to what developers see on the row: `customer.kyc_id` → the\n * relation is `kyc`, `order.created_by_user_id` → `created_by_user`,\n * `invoice.payer_id` → `payer`. A composite FK uses every column name,\n * stripped and joined with `_`.\n *\n * Inbound relations (another entity points here) use the source\n * entity's bare name: `public.orders` inbound on `public.users` is\n * exposed as `orders`. When two inbound FKs come from the same source\n * table (e.g. `orders.created_by_user_id` and\n * `orders.modified_by_user_id` both pointing at `users`) the second\n * one is disambiguated as `<source>_by_<stripped-column>` so both\n * remain discoverable.\n *\n * Self-referential FKs use the conventional `'parent'` / `'children'`\n * names so the outbound / inbound collision on the same entity does\n * not need disambiguation.\n *\n * If every other strategy collides, the resolver falls back to the\n * underlying foreign key constraint name. That keeps the relation\n * map total - every relation is always addressable by some string -\n * even for pathological schemas.\n */\nexport function buildRelationNameMap(\n entity: Entity,\n): ReadonlyMap<string, Relationship> {\n const result = new Map<string, Relationship>();\n const used = new Set<string>();\n\n // Pass 1: assign a primary proposed name to each relationship.\n const proposals: Array<{ rel: Relationship; name: string; order: number }> =\n [];\n entity.relationships.forEach((rel, order) => {\n const other =\n rel.direction === 'outbound'\n ? rel.reference.toEntity\n : rel.reference.fromEntity;\n const isSelfRef =\n other.namespace === entity.namespace && other.name === entity.name;\n\n let name: string;\n if (isSelfRef) {\n name = rel.direction === 'outbound' ? 'parent' : 'children';\n } else if (rel.direction === 'outbound') {\n name = nameFromColumns(rel.reference.fromFields) ?? other.name;\n } else {\n name = other.name;\n }\n proposals.push({ rel, name, order });\n });\n\n // Sort so outbound proposals always win collisions over inbound\n // ones. Within a direction, preserve the original iteration order\n // for determinism. This makes `.include('kyc', ...)` always resolve\n // to the outbound `customers.kyc_id → kyc.id` relation even when an\n // inbound `kyc.customer_id → customers.id` would otherwise propose\n // the same name - the outbound is how a developer reading the\n // source table's columns thinks about it.\n proposals.sort((a, b) => {\n if (a.rel.direction !== b.rel.direction) {\n return a.rel.direction === 'outbound' ? -1 : 1;\n }\n return a.order - b.order;\n });\n\n // Pass 2: walk proposals in order, disambiguating collisions.\n for (const { rel, name } of proposals) {\n let final = name;\n if (used.has(final)) {\n final = disambiguate(rel, name, used);\n }\n used.add(final);\n result.set(final, rel);\n }\n\n return result;\n}\n\n/**\n * Derive a relation name from one or more FK column names:\n *\n * ['user_id'] -> 'user'\n * ['created_by_user_id'] -> 'created_by_user'\n * ['tenant_id', 'user_id'] -> 'tenant_user'\n * ['customerId'] -> 'customer'\n * ['id'] -> null (not usable - collides with PK)\n * [] -> null\n */\nfunction nameFromColumns(columns: readonly string[]): string | null {\n if (columns.length === 0) {\n return null;\n }\n const pieces = columns\n .map(stripIdSuffix)\n .map((piece) => piece.trim())\n .filter((piece) => piece.length > 0 && piece.toLowerCase() !== 'id');\n if (pieces.length === 0) {\n return null;\n }\n return pieces.join('_');\n}\n\nfunction stripIdSuffix(column: string): string {\n // Trailing \"_id\" or \"Id\" (the two conventions), case-insensitive on\n // the underscore variant.\n const underscore = column.match(/^(.*)_id$/i);\n if (underscore?.[1] !== undefined) {\n return underscore[1];\n }\n const camel = column.match(/^(.*)Id$/);\n if (camel?.[1] !== undefined) {\n return camel[1];\n }\n return column;\n}\n\n/**\n * Produce a collision-free name for `rel` given the set of names\n * already taken. Tries increasingly specific fallbacks:\n *\n * 1. For inbound collisions, append `_by_<fk-column-stripped>`.\n * 2. For outbound collisions, append `_<target-entity>`.\n * 3. Fall back to the FK constraint name.\n * 4. Append `_2`, `_3`, … to the constraint name.\n */\nfunction disambiguate(\n rel: Relationship,\n base: string,\n used: ReadonlySet<string>,\n): string {\n if (rel.direction === 'inbound') {\n const suffix = nameFromColumns(rel.reference.fromFields);\n if (suffix) {\n const candidate = `${base}_by_${suffix}`;\n if (!used.has(candidate)) {\n return candidate;\n }\n }\n } else {\n const targetName =\n rel.direction === 'outbound' ? rel.reference.toEntity.name : null;\n if (targetName) {\n const candidate = `${base}_${targetName}`;\n if (!used.has(candidate)) {\n return candidate;\n }\n }\n }\n\n let candidate = rel.reference.name;\n if (!used.has(candidate)) {\n return candidate;\n }\n let counter = 2;\n while (used.has(candidate)) {\n candidate = `${rel.reference.name}_${counter}`;\n counter += 1;\n }\n return candidate;\n}\n","import { tsTypeFor } from '@/codegen/TsTypeMapper';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { Entity } from '@/domain/model/Entity';\nimport type { Field } from '@/domain/model/Field';\nimport type { Relationship } from '@/domain/model/Relationship';\nimport { buildRelationNameMap } from '@/query/relationNaming';\n\nconst GENERATED_BANNER = `// This file is generated by @biref/scanner. Do not edit by hand.\n// Re-run \\`biref gen\\` to regenerate it from a live database scan.\n//\n// Overrides live in the sibling \\`biref.schema.overrides.ts\\` file\n// (never regenerated) and are deep-merged into \\`BirefSchema\\` via\n// \\`ApplySchemaOverrides\\`.`;\n\n/**\n * A single file produced by split-mode codegen.\n *\n * Paths are always relative to the output folder the user passed to\n * the CLI (or to `writeSchemaFiles`) and use forward slashes. The\n * caller is responsible for joining them onto an absolute path and\n * creating any intermediate directories.\n */\nexport interface SchemaFile {\n readonly path: string;\n readonly content: string;\n}\n\n/**\n * Emit a TypeScript schema declaration from a scanned `DataModel` as\n * a single self-contained `.ts` file.\n *\n * The output exports:\n *\n * - `RawBirefSchema`: the literal schema shape the model discovered\n * - `BirefSchema`: `RawBirefSchema` with user overrides applied\n *\n * Deterministic: the same `DataModel` input always produces the same\n * string, suitable for snapshot tests and stable git diffs.\n *\n * Use this when you want everything in one file. For larger schemas\n * `generateSchemaFiles` emits one file per entity plus an index and\n * tends to be easier to browse.\n */\nexport function generateSchema(model: DataModel): string {\n const namespaces = groupByNamespace(model);\n const sortedNamespaces = [...namespaces.keys()].sort();\n\n const lines: string[] = [];\n lines.push(GENERATED_BANNER);\n lines.push('');\n lines.push(\"import type { ApplySchemaOverrides } from '@biref/scanner';\");\n lines.push(\"import type { Overrides } from './biref.schema.overrides.js';\");\n lines.push('');\n lines.push('export interface RawBirefSchema {');\n\n for (const namespace of sortedNamespaces) {\n const entities = namespaces.get(namespace);\n if (!entities) {\n continue;\n }\n lines.push(` readonly ${quoteKey(namespace)}: {`);\n const sortedEntities = [...entities].sort((a, b) =>\n a.name.localeCompare(b.name),\n );\n for (const entity of sortedEntities) {\n lines.push(` readonly ${quoteKey(entity.name)}: {`);\n lines.push(' readonly fields: {');\n for (const field of entity.fields) {\n lines.push(indent(formatFieldDescriptor(field), 4));\n }\n lines.push(' };');\n lines.push(` readonly identifier: ${formatIdentifier(entity)};`);\n const relations = sortedRelations(entity);\n if (relations.length === 0) {\n lines.push(' readonly relations: Record<string, never>;');\n } else {\n lines.push(' readonly relations: {');\n for (const [name, relationship] of relations) {\n lines.push(indent(formatRelationDescriptor(name, relationship), 4));\n }\n lines.push(' };');\n }\n lines.push(' };');\n }\n lines.push(' };');\n }\n lines.push('}');\n lines.push('');\n lines.push(\n 'export type BirefSchema = ApplySchemaOverrides<RawBirefSchema, Overrides>;',\n );\n lines.push('');\n return lines.join('\\n');\n}\n\n/**\n * Emit a folder of split schema files from a scanned `DataModel`.\n *\n * Layout:\n *\n * index.ts Root file re-exporting every per-entity\n * interface and composing `RawBirefSchema`\n * plus `BirefSchema`.\n * <namespace>/<entity>.ts One file per entity with its field\n * descriptor, identifier tuple, and\n * relations map.\n *\n * The overrides file is **not** emitted by this function - it is\n * scaffolded once by the CLI and never touched again.\n *\n * Returns the files in a deterministic order so consumers can write\n * them or snapshot-test them safely.\n */\nexport function generateSchemaFiles(model: DataModel): readonly SchemaFile[] {\n const namespaces = groupByNamespace(model);\n const sortedNamespaces = [...namespaces.keys()].sort();\n const files: SchemaFile[] = [];\n\n for (const namespace of sortedNamespaces) {\n const entities = namespaces.get(namespace);\n if (!entities) {\n continue;\n }\n const sortedEntities = [...entities].sort((a, b) =>\n a.name.localeCompare(b.name),\n );\n for (const entity of sortedEntities) {\n files.push({\n path: `${safeSegment(namespace)}/${safeSegment(entity.name)}.ts`,\n content: emitEntityFile(entity),\n });\n }\n }\n\n files.push({\n path: 'index.ts',\n content: emitIndexFile(model),\n });\n\n return files;\n}\n\nfunction emitEntityFile(entity: Entity): string {\n const interfaceName = entityInterfaceName(entity.namespace, entity.name);\n const lines: string[] = [];\n lines.push(GENERATED_BANNER);\n lines.push('');\n lines.push(`export interface ${interfaceName} {`);\n lines.push(' readonly fields: {');\n for (const field of entity.fields) {\n lines.push(indent(formatFieldDescriptor(field), 2));\n }\n lines.push(' };');\n lines.push(` readonly identifier: ${formatIdentifier(entity)};`);\n const relations = sortedRelations(entity);\n if (relations.length === 0) {\n lines.push(' readonly relations: Record<string, never>;');\n } else {\n lines.push(' readonly relations: {');\n for (const [name, relationship] of relations) {\n lines.push(indent(formatRelationDescriptor(name, relationship), 2));\n }\n lines.push(' };');\n }\n lines.push('}');\n lines.push('');\n return lines.join('\\n');\n}\n\nfunction emitIndexFile(model: DataModel): string {\n const namespaces = groupByNamespace(model);\n const sortedNamespaces = [...namespaces.keys()].sort();\n\n const lines: string[] = [];\n lines.push(GENERATED_BANNER);\n lines.push('');\n lines.push(\"import type { ApplySchemaOverrides } from '@biref/scanner';\");\n lines.push(\"import type { Overrides } from './biref.schema.overrides.js';\");\n lines.push('');\n\n const allEntities: { namespace: string; entity: Entity }[] = [];\n for (const namespace of sortedNamespaces) {\n const entities = namespaces.get(namespace);\n if (!entities) {\n continue;\n }\n for (const entity of [...entities].sort((a, b) =>\n a.name.localeCompare(b.name),\n )) {\n allEntities.push({ namespace, entity });\n }\n }\n\n // Imports first, then re-exports, then the schema interface.\n // .js extensions on relative imports are required by Node's ESM\n // resolution (NodeNext / node16) and harmless under Bundler mode.\n for (const { namespace, entity } of allEntities) {\n const iface = entityInterfaceName(namespace, entity.name);\n lines.push(\n `import type { ${iface} } from './${safeSegment(namespace)}/${safeSegment(entity.name)}.js';`,\n );\n }\n lines.push('');\n for (const { namespace, entity } of allEntities) {\n const iface = entityInterfaceName(namespace, entity.name);\n lines.push(\n `export type { ${iface} } from './${safeSegment(namespace)}/${safeSegment(entity.name)}.js';`,\n );\n }\n lines.push('');\n lines.push('export interface RawBirefSchema {');\n for (const namespace of sortedNamespaces) {\n const entities = namespaces.get(namespace);\n if (!entities) {\n continue;\n }\n lines.push(` readonly ${quoteKey(namespace)}: {`);\n const sortedEntities = [...entities].sort((a, b) =>\n a.name.localeCompare(b.name),\n );\n for (const entity of sortedEntities) {\n const iface = entityInterfaceName(namespace, entity.name);\n lines.push(` readonly ${quoteKey(entity.name)}: ${iface};`);\n }\n lines.push(' };');\n }\n lines.push('}');\n lines.push('');\n lines.push(\n 'export type BirefSchema = ApplySchemaOverrides<RawBirefSchema, Overrides>;',\n );\n lines.push('');\n return lines.join('\\n');\n}\n\nfunction groupByNamespace(model: DataModel): Map<string, Entity[]> {\n const map = new Map<string, Entity[]>();\n for (const entity of model.entities) {\n const bucket = map.get(entity.namespace);\n if (bucket) {\n bucket.push(entity);\n } else {\n map.set(entity.namespace, [entity]);\n }\n }\n return map;\n}\n\nfunction sortedRelations(\n entity: Entity,\n): readonly (readonly [string, Relationship])[] {\n return [...buildRelationNameMap(entity).entries()].sort(([a], [b]) =>\n a.localeCompare(b),\n );\n}\n\nfunction formatFieldDescriptor(field: Field): string {\n const ts = tsTypeFor(field.type, field.nullable);\n const nullable = field.nullable ? 'true' : 'false';\n const isIdentifier = field.isIdentifier ? 'true' : 'false';\n const category = `'${field.type.category}'`;\n return ` readonly ${quoteKey(field.name)}: { readonly ts: ${ts}; readonly nullable: ${nullable}; readonly isIdentifier: ${isIdentifier}; readonly category: ${category} };`;\n}\n\nfunction formatIdentifier(entity: Entity): string {\n if (entity.identifier.length === 0) {\n return 'readonly []';\n }\n const items = entity.identifier.map((name) => `'${escapeString(name)}'`);\n return `readonly [${items.join(', ')}]`;\n}\n\nfunction formatRelationDescriptor(\n name: string,\n relationship: Relationship,\n): string {\n const target =\n relationship.direction === 'outbound'\n ? relationship.reference.toEntity\n : relationship.reference.fromEntity;\n const qualifiedTarget = `'${escapeString(target.namespace)}.${escapeString(target.name)}'`;\n const fromFields = formatStringArray(relationship.reference.fromFields);\n const toFields = formatStringArray(relationship.reference.toFields);\n const cardinality =\n relationship.direction === 'outbound' ? \"'one'\" : \"'many'\";\n const direction = `'${relationship.direction}'`;\n return ` readonly ${quoteKey(name)}: { readonly direction: ${direction}; readonly target: ${qualifiedTarget}; readonly fromFields: ${fromFields}; readonly toFields: ${toFields}; readonly cardinality: ${cardinality} };`;\n}\n\nfunction formatStringArray(values: readonly string[]): string {\n if (values.length === 0) {\n return 'readonly []';\n }\n return `readonly [${values.map((v) => `'${escapeString(v)}'`).join(', ')}]`;\n}\n\nfunction quoteKey(key: string): string {\n if (/^[A-Za-z_$][A-Za-z0-9_$]*$/.test(key)) {\n return key;\n }\n return `'${escapeString(key)}'`;\n}\n\nfunction escapeString(value: string): string {\n return value.replace(/\\\\/g, '\\\\\\\\').replace(/'/g, \"\\\\'\");\n}\n\n/**\n * Produce a PascalCase TypeScript identifier from a\n * namespace + entity pair:\n *\n * ('identity', 'users') -> 'IdentityUsers'\n * ('commerce', 'order_items') -> 'CommerceOrderItems'\n */\nfunction entityInterfaceName(namespace: string, entity: string): string {\n return toPascalCase(namespace) + toPascalCase(entity);\n}\n\nfunction toPascalCase(value: string): string {\n return value\n .split(/[^A-Za-z0-9]+/)\n .filter((segment) => segment.length > 0)\n .map(\n (segment) =>\n segment.charAt(0).toUpperCase() + segment.slice(1).toLowerCase(),\n )\n .join('');\n}\n\n/**\n * Sanitize a namespace or entity name for use as a filesystem segment.\n *\n * Replaces anything outside `[A-Za-z0-9_-]` with `_` so identifiers\n * like `weird\"ns` or `mixed case` still produce a valid path.\n */\nfunction safeSegment(name: string): string {\n return name.replace(/[^A-Za-z0-9_-]/g, '_');\n}\n\nfunction indent(text: string, spaces: number): string {\n const pad = ' '.repeat(spaces);\n return text\n .split('\\n')\n .map((line) => (line.length === 0 ? line : `${pad}${line}`))\n .join('\\n');\n}\n","import type { RecordParser } from '@/parsing/RecordParser';\nimport type { Introspector } from '@/ports/Introspector';\nimport type { QueryEngine } from '@/ports/QueryEngine';\nimport type { RawQueryRunner } from '@/ports/RawQueryRunner';\n\n/**\n * Names of the adapters that ship with the SDK.\n *\n * Grows as new adapters are added. Consumers can still register custom\n * adapters with any name; the type accepts arbitrary strings in\n * addition to the known ones (see `AdapterName`).\n */\nexport type KnownAdapterName = 'postgres' | 'mysql';\n\n/**\n * Adapter name type.\n *\n * Known adapter names appear in IDE autocomplete when calling\n * `Biref.scan(...)`, `AdapterRegistry.get(...)`, and similar APIs.\n * Any other string is still accepted so consumers can register\n * adapters the SDK does not know about.\n *\n * Pattern: `KnownAdapterName | (string & {})` preserves literal\n * suggestions while also accepting the broader string type.\n */\nexport type AdapterName = KnownAdapterName | (string & {});\n\n/**\n * An adapter packaged for registration with `Biref` or `AdapterRegistry`.\n *\n * Generic over `TName` so each adapter declares its name as a literal\n * string type. Consumers narrow by comparing `adapter.name` against an\n * exported constant from the adapter module:\n *\n * import { POSTGRES_ADAPTER_NAME } from '@biref/scanner';\n *\n * if (adapter.name === POSTGRES_ADAPTER_NAME) {\n * // adapter is narrowed to Adapter<'postgres'>\n * }\n *\n * Fields:\n * name: literal name of the adapter (e.g. 'postgres')\n * introspector: produces a `DataModel` from the data store\n * engine: turns a `QuerySpec` into a `BuiltQuery`\n * runner: executes a `BuiltQuery` and returns raw rows\n * parser: coerces raw rows into typed `ParsedRecord`s\n * urlSchemes: URL schemes the adapter handles, for auto-detection\n *\n * `runner` and `parser` are optional on the interface so older adapter\n * modules stay source-compatible. The typed query API requires both.\n */\nexport interface Adapter<TName extends AdapterName = AdapterName> {\n readonly name: TName;\n readonly introspector: Introspector;\n readonly engine: QueryEngine;\n readonly runner?: RawQueryRunner;\n readonly parser?: RecordParser;\n readonly urlSchemes?: readonly string[];\n}\n\n/**\n * Registry of `Adapter` instances keyed by name.\n *\n * Looked up by `Biref` and the lower-level facades. Registration is\n * explicit: the SDK has zero runtime dependencies and cannot know\n * which adapters are installed.\n */\nexport class AdapterRegistry {\n private readonly adapters = new Map<string, Adapter>();\n\n register(adapter: Adapter): void {\n if (this.adapters.has(adapter.name)) {\n throw new Error(`Adapter \"${adapter.name}\" is already registered.`);\n }\n this.adapters.set(adapter.name, adapter);\n }\n\n unregister(name: AdapterName): boolean {\n return this.adapters.delete(name);\n }\n\n get(name: AdapterName): Adapter {\n const adapter = this.adapters.get(name);\n if (!adapter) {\n const known = [...this.adapters.keys()].join(', ') || '(none)';\n throw new Error(\n `No adapter registered under \"${name}\". Registered adapters: ${known}.`,\n );\n }\n return adapter;\n }\n\n has(name: AdapterName): boolean {\n return this.adapters.has(name);\n }\n\n list(): readonly string[] {\n return [...this.adapters.keys()];\n }\n\n /**\n * Find an adapter that claims the given URL scheme. Case-insensitive.\n * Returns `undefined` if no adapter handles it.\n */\n findByUrlScheme(scheme: string): Adapter | undefined {\n const normalized = scheme.toLowerCase();\n for (const adapter of this.adapters.values()) {\n const matches = adapter.urlSchemes?.some(\n (s) => s.toLowerCase() === normalized,\n );\n if (matches) {\n return adapter;\n }\n }\n return undefined;\n }\n\n /**\n * Same as `findByUrlScheme` but throws a helpful error listing the\n * known schemes when no match is found.\n */\n getByUrlScheme(scheme: string): Adapter {\n const adapter = this.findByUrlScheme(scheme);\n if (!adapter) {\n const known =\n [...this.adapters.values()]\n .flatMap((a) => a.urlSchemes ?? [])\n .join(', ') || '(none)';\n throw new Error(\n `No adapter registered for URL scheme \"${scheme}\". Known schemes: ${known}.`,\n );\n }\n return adapter;\n }\n}\n","import type { DataModel } from '@/domain/model/DataModel';\nimport type { Filter, QuerySpec } from '@/domain/query/QuerySpec';\nimport type { ParsedRecord, ParsedValue } from '@/parsing/ParsedRecord';\nimport type { RecordParser } from '@/parsing/RecordParser';\nimport type { QueryEngine } from '@/ports/QueryEngine';\nimport type { RawQueryRunner } from '@/ports/RawQueryRunner';\nimport type { QueryInclude, QueryPlan } from '@/query/QueryPlan';\n\n/**\n * Executes a `QueryPlan` tree against an adapter's engine, runner, and\n * parser, stitching include results into nested shapes on the parent.\n *\n * Runs one query per plan node - root first, then one query per\n * include level, filtered to the parent keys it just collected. This\n * matches Prisma's approach: sequential sub-queries with in-process\n * hydration, rather than SQL JOINs. It keeps the engine layer\n * paradigm-neutral and works without any JOIN support in the\n * adapter's `QueryEngine`.\n *\n * Projection honoring: join-key columns are transparently added to\n * both the parent's and each child's SELECT so the stitcher can read\n * them, then removed from the final hydrated records so the caller\n * sees only the columns they originally asked for.\n */\nexport class QueryPlanExecutor {\n constructor(\n private readonly engine: QueryEngine,\n private readonly runner: RawQueryRunner,\n private readonly parser: RecordParser,\n ) {}\n\n async execute(\n plan: QueryPlan,\n model: DataModel,\n ): Promise<readonly ParsedRecord[]> {\n const entity = model.getEntity(plan.spec.namespace, plan.spec.entity);\n if (!entity) {\n throw new Error(\n `Entity \"${plan.spec.namespace}.${plan.spec.entity}\" not found in the data model.`,\n );\n }\n\n const exposedKeys = QueryPlanExecutor.resolveExposedKeys(\n plan.spec,\n entity,\n plan.includes,\n );\n const normalizedSpec = QueryPlanExecutor.injectFields(\n plan.spec,\n QueryPlanExecutor.collectParentKeys(plan.includes),\n );\n\n const built = this.engine.build(normalizedSpec, model);\n const rawRows = await this.runner.run<Record<string, unknown>>(built);\n const parentRecords = this.parser.parseMany(entity, rawRows);\n\n if (plan.includes.length === 0) {\n return QueryPlanExecutor.project(parentRecords, exposedKeys);\n }\n\n return this.attachIncludes(\n parentRecords,\n plan.includes,\n exposedKeys,\n model,\n );\n }\n\n private async attachIncludes(\n parents: readonly ParsedRecord[],\n includes: readonly QueryInclude[],\n parentUserSelect: ReadonlySet<string>,\n model: DataModel,\n ): Promise<readonly ParsedRecord[]> {\n // Mutable working copies preserve every field (including the join\n // keys that were injected into the parent select) across include\n // iterations. Without this, the first include's projection would\n // strip the parent keys that subsequent includes need to stitch.\n // We fold each include's hydrated result onto the working record\n // in-place and only apply the final user projection once at the\n // very end.\n const working: Record<string, ParsedValue>[] = parents.map((p) => ({\n ...p,\n }));\n\n for (const include of includes) {\n const childPlan = QueryPlanExecutor.prepareChildPlan(include, working);\n if (childPlan === null) {\n for (const parent of working) {\n parent[include.relationName] =\n include.cardinality === 'one' ? null : [];\n }\n continue;\n }\n\n const rawChildren = await this.execute(childPlan, model);\n const childExposedKeys = QueryPlanExecutor.resolveChildExposedKeys(\n include.plan,\n model,\n );\n const indexingKeys = new Set(childExposedKeys);\n for (const key of include.childKeys) {\n indexingKeys.add(key);\n }\n const byKey = QueryPlanExecutor.indexByKey(\n rawChildren.map((c) => QueryPlanExecutor.filterKeys(c, indexingKeys)),\n include.childKeys,\n );\n\n for (const parent of working) {\n const lookupKey = QueryPlanExecutor.buildKey(\n parent,\n include.parentKeys,\n );\n const matches = lookupKey === null ? [] : (byKey.get(lookupKey) ?? []);\n const projectedMatches = QueryPlanExecutor.project(\n matches,\n childExposedKeys,\n );\n parent[include.relationName] =\n include.cardinality === 'one'\n ? (projectedMatches[0] ?? null)\n : [...projectedMatches];\n }\n }\n\n // Final projection: now that every include has stitched, strip\n // the injected join keys and any other fields the user did not\n // ask for.\n return working.map((parent) =>\n QueryPlanExecutor.filterKeys(parent, parentUserSelect),\n );\n }\n\n private static prepareChildPlan(\n include: QueryInclude,\n parents: readonly ParsedRecord[],\n ): QueryPlan | null {\n if (parents.length === 0) {\n return null;\n }\n if (include.parentKeys.length === 0 || include.childKeys.length === 0) {\n return null;\n }\n\n // Collect per-column parent key values.\n const collected: unknown[][] = include.parentKeys.map(() => []);\n let anyMatch = false;\n for (const parent of parents) {\n let hasAll = true;\n const tuple: unknown[] = [];\n for (const key of include.parentKeys) {\n const value = parent[key];\n if (value === null || value === undefined) {\n hasAll = false;\n break;\n }\n tuple.push(value);\n }\n if (!hasAll) {\n continue;\n }\n for (let i = 0; i < tuple.length; i += 1) {\n const bucket = collected[i];\n if (bucket) {\n bucket.push(tuple[i]);\n }\n }\n anyMatch = true;\n }\n if (!anyMatch) {\n return null;\n }\n\n // Inject child join keys into the select so the stitcher can read them.\n let plan: QueryPlan = {\n ...include.plan,\n spec: QueryPlanExecutor.injectFields(\n include.plan.spec,\n include.childKeys,\n ),\n };\n\n // Apply one `in` filter per child key column against the distinct\n // parent values we just collected.\n for (let i = 0; i < include.childKeys.length; i += 1) {\n const childKey = include.childKeys[i];\n const bucket = collected[i];\n if (childKey === undefined || bucket === undefined) {\n return null;\n }\n const unique = Array.from(new Set(bucket));\n const filter: Filter = {\n field: childKey,\n operator: 'in',\n value: unique,\n };\n plan = {\n ...plan,\n spec: {\n ...plan.spec,\n filters: [...(plan.spec.filters ?? []), filter],\n },\n };\n }\n return plan;\n }\n\n private static injectFields(\n spec: QuerySpec,\n fields: readonly string[],\n ): QuerySpec {\n if (!spec.select || spec.select.length === 0) {\n // An undefined/empty select already means \"all columns\" - nothing\n // to inject.\n return spec;\n }\n if (fields.length === 0) {\n return spec;\n }\n const seen = new Set(spec.select);\n const extras: string[] = [];\n for (const field of fields) {\n if (!seen.has(field)) {\n seen.add(field);\n extras.push(field);\n }\n }\n if (extras.length === 0) {\n return spec;\n }\n return { ...spec, select: [...spec.select, ...extras] };\n }\n\n private static collectParentKeys(\n includes: readonly QueryInclude[],\n ): readonly string[] {\n const keys: string[] = [];\n for (const include of includes) {\n for (const key of include.parentKeys) {\n keys.push(key);\n }\n }\n return keys;\n }\n\n /**\n * Compute the set of keys a hydrated record should expose to the\n * caller: the user's selected fields (or every entity field when\n * no select was given) plus every nested include's relation name\n * so attached children survive the final filter step.\n */\n private static resolveExposedKeys(\n spec: QuerySpec,\n entity: { readonly fields: readonly { readonly name: string }[] },\n includes: readonly QueryInclude[],\n ): ReadonlySet<string> {\n const set = new Set<string>();\n if (spec.select && spec.select.length > 0) {\n for (const field of spec.select) {\n set.add(field);\n }\n } else {\n for (const field of entity.fields) {\n set.add(field.name);\n }\n }\n for (const include of includes) {\n set.add(include.relationName);\n }\n return set;\n }\n\n /**\n * Resolve the exposed-keys set for an include's nested plan.\n *\n * Uses the ORIGINAL include.plan (not the mutated child plan we\n * handed to the executor) so injected join keys do not leak into\n * the final output.\n */\n private static resolveChildExposedKeys(\n plan: QueryPlan,\n model: DataModel,\n ): ReadonlySet<string> {\n const entity = model.getEntity(plan.spec.namespace, plan.spec.entity);\n if (!entity) {\n return new Set();\n }\n return QueryPlanExecutor.resolveExposedKeys(\n plan.spec,\n entity,\n plan.includes,\n );\n }\n\n private static project(\n records: readonly ParsedRecord[],\n allow: ReadonlySet<string>,\n ): readonly ParsedRecord[] {\n return records.map((record) => QueryPlanExecutor.filterKeys(record, allow));\n }\n\n private static indexByKey(\n records: readonly ParsedRecord[],\n keys: readonly string[],\n ): Map<string, ParsedRecord[]> {\n const map = new Map<string, ParsedRecord[]>();\n for (const record of records) {\n const key = QueryPlanExecutor.buildKey(record, keys);\n if (key === null) {\n continue;\n }\n const bucket = map.get(key);\n if (bucket) {\n bucket.push(record);\n } else {\n map.set(key, [record]);\n }\n }\n return map;\n }\n\n private static buildKey(\n record: ParsedRecord,\n keys: readonly string[],\n ): string | null {\n if (keys.length === 0) {\n return '';\n }\n const parts: unknown[] = [];\n for (const key of keys) {\n const value = record[key];\n if (value === null || value === undefined) {\n return null;\n }\n parts.push(\n typeof value === 'bigint' ? `bigint:${value.toString()}` : value,\n );\n }\n return JSON.stringify(parts);\n }\n\n private static filterKeys(\n record: ParsedRecord,\n allow: ReadonlySet<string>,\n ): ParsedRecord {\n const result: Record<string, ParsedValue> = {};\n for (const [key, value] of Object.entries(record)) {\n if (allow.has(key)) {\n result[key] = value;\n }\n }\n return result;\n }\n}\n","import type { QueryPlanExecutor } from '@/core/QueryPlanExecutor';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type {\n Filter,\n FilterOperator,\n OrderBy,\n QuerySpec,\n} from '@/domain/query/QuerySpec';\nimport type { ParsedRecord } from '@/parsing/ParsedRecord';\nimport type { QueryInclude, QueryPlan } from '@/query/QueryPlan';\nimport { buildRelationNameMap } from '@/query/relationNaming';\n\n/**\n * Runtime context threaded through every `ChainBuilder` instance.\n *\n * Holds the scanned `DataModel` used for validation and the\n * `QueryPlanExecutor` that actually runs terminal methods like\n * `findMany` / `findFirst`.\n */\nexport interface ChainBuilderContext {\n readonly model: DataModel;\n readonly executor: QueryPlanExecutor;\n}\n\n/**\n * Immutable fluent builder that accumulates a `QueryPlan`.\n *\n * Each mutating method (`select`, `where`, `orderBy`, `limit`,\n * `offset`, `include`) returns a **new** `ChainBuilder` - chains are\n * safe to fork.\n *\n * Field and relation names are validated against the `DataModel` at\n * call time so mistakes throw immediately with a clear message.\n * Compile-time typing comes from the generic parameters (see\n * `src/query/types/*`); the runtime implementation here is\n * schema-agnostic.\n */\nexport class ChainBuilder {\n constructor(\n private readonly ctx: ChainBuilderContext,\n private readonly plan: QueryPlan,\n ) {}\n\n /**\n * Narrow the projection to a specific set of fields.\n *\n * .select('id', 'email') -- only these two columns\n * .select('*') -- every field of the entity\n * .select() -- equivalent to '*', kept for ergonomic parity\n *\n * Unknown field names throw immediately with a clear error; the\n * wildcard sentinel skips validation and leaves the plan's `select`\n * undefined so the engine emits every column the adapter reported.\n */\n select(...fields: readonly string[]): ChainBuilder {\n if (fields.length === 0 || fields.some((f) => f === '*')) {\n if (fields.some((f) => f !== '*')) {\n throw new Error(\n \"select('*') cannot be combined with other field names. Pass either '*' or the specific columns you want.\",\n );\n }\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: { ...this.plan.spec, select: undefined },\n });\n }\n const entity = this.requireEntity();\n const known = new Set(entity.fields.map((f) => f.name));\n for (const field of fields) {\n if (!known.has(field)) {\n throw new Error(\n `Field \"${field}\" does not exist on \"${this.plan.spec.namespace}.${this.plan.spec.entity}\".`,\n );\n }\n }\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: { ...this.plan.spec, select: [...fields] },\n });\n }\n\n where(\n field: string,\n operator: FilterOperator,\n value?: unknown,\n ): ChainBuilder {\n const entity = this.requireEntity();\n if (!entity.fields.some((f) => f.name === field)) {\n throw new Error(\n `Filter field \"${field}\" does not exist on \"${this.plan.spec.namespace}.${this.plan.spec.entity}\".`,\n );\n }\n const filter: Filter = {\n field,\n operator,\n value: value ?? null,\n };\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: {\n ...this.plan.spec,\n filters: [...(this.plan.spec.filters ?? []), filter],\n },\n });\n }\n\n orderBy(field: string, direction: 'asc' | 'desc' = 'asc'): ChainBuilder {\n const entity = this.requireEntity();\n if (!entity.fields.some((f) => f.name === field)) {\n throw new Error(\n `Order field \"${field}\" does not exist on \"${this.plan.spec.namespace}.${this.plan.spec.entity}\".`,\n );\n }\n const order: OrderBy = { field, direction };\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: {\n ...this.plan.spec,\n orderBy: [...(this.plan.spec.orderBy ?? []), order],\n },\n });\n }\n\n limit(count: number): ChainBuilder {\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: { ...this.plan.spec, limit: count },\n });\n }\n\n offset(count: number): ChainBuilder {\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: { ...this.plan.spec, offset: count },\n });\n }\n\n /**\n * Attach a nested include to the plan.\n *\n * Three call shapes are supported:\n *\n * .include('orders') -- all fields, no nested\n * .include('orders', (q) => q.select('id', 'total')) -- narrow the child\n * .include('*') -- every relation on this entity\n *\n * The callback is optional. When omitted, the child plan uses the\n * default projection (all fields of the related entity) and no\n * further includes. Pass a callback when you want to narrow the\n * projection or chain additional nested includes.\n *\n * The wildcard `'*'` expands to one include per relation discovered\n * on the current entity. Each expanded include uses the default\n * projection. Combining `'*'` with a callback is not supported -\n * the sub-builder's shape differs per relation, so a single\n * callback cannot narrow all of them coherently.\n */\n include(\n relationName: string,\n build?: (q: ChainBuilder) => ChainBuilder,\n ): ChainBuilder {\n const entity = this.requireEntity();\n const relationMap = buildRelationNameMap(entity);\n\n if (relationName === '*') {\n if (build) {\n throw new Error(\n \"Wildcard include '*' does not accept a builder callback. Use named includes to narrow individual relations.\",\n );\n }\n let current: ChainBuilder = this;\n for (const name of relationMap.keys()) {\n current = current.include(name);\n }\n return current;\n }\n\n const relationship = relationMap.get(relationName);\n if (!relationship) {\n const known = [...relationMap.keys()].join(', ') || '(none)';\n throw new Error(\n `Relation \"${relationName}\" does not exist on \"${this.plan.spec.namespace}.${this.plan.spec.entity}\". Known relations: ${known}.`,\n );\n }\n\n const target =\n relationship.direction === 'outbound'\n ? relationship.reference.toEntity\n : relationship.reference.fromEntity;\n\n const childSpec: QuerySpec = {\n namespace: target.namespace,\n entity: target.name,\n };\n const childBuilder = new ChainBuilder(this.ctx, {\n spec: childSpec,\n includes: [],\n });\n const finishedChild = build ? build(childBuilder) : childBuilder;\n\n const parentKeys =\n relationship.direction === 'outbound'\n ? relationship.reference.fromFields\n : relationship.reference.toFields;\n const childKeys =\n relationship.direction === 'outbound'\n ? relationship.reference.toFields\n : relationship.reference.fromFields;\n\n const include: QueryInclude = {\n relationName,\n plan: finishedChild.plan,\n direction: relationship.direction,\n parentKeys,\n childKeys,\n cardinality: relationship.direction === 'outbound' ? 'one' : 'many',\n };\n\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n includes: [...this.plan.includes, include],\n });\n }\n\n async findMany(): Promise<readonly ParsedRecord[]> {\n return this.ctx.executor.execute(this.plan, this.ctx.model);\n }\n\n async findFirst(): Promise<ParsedRecord | null> {\n const limited: QueryPlan = {\n ...this.plan,\n spec: { ...this.plan.spec, limit: 1 },\n };\n const rows = await this.ctx.executor.execute(limited, this.ctx.model);\n return rows[0] ?? null;\n }\n\n /**\n * Escape hatch for advanced callers (tests, tooling): exposes the\n * accumulated plan without executing it. The typed builder's public\n * surface does not reference this directly.\n */\n toPlan(): QueryPlan {\n return this.plan;\n }\n\n private requireEntity() {\n const entity = this.ctx.model.getEntity(\n this.plan.spec.namespace,\n this.plan.spec.entity,\n );\n if (!entity) {\n throw new Error(\n `Entity \"${this.plan.spec.namespace}.${this.plan.spec.entity}\" not found in the data model.`,\n );\n }\n return entity;\n }\n}\n","import type { DataModel } from '@/domain/model/DataModel';\nimport { ChainBuilder, type ChainBuilderContext } from '@/query/ChainBuilder';\n\n/**\n * Two-layer Proxy surface for `biref.query(model)`:\n *\n * root[namespace][entity] -> fresh ChainBuilder\n *\n * Property access on the root returns an entity proxy bound to the\n * given namespace. Property access on the entity proxy returns a\n * zero-state `ChainBuilder` targeting that entity.\n *\n * Both layers answer `ownKeys` / `has` / `getOwnPropertyDescriptor`\n * from the scanned `DataModel`, so `Object.keys(root)` and\n * `Object.keys(root.public)` reflect what's actually in the database.\n */\nexport function createNamespaceProxy(\n ctx: ChainBuilderContext,\n): Record<string, Record<string, ChainBuilder>> {\n const namespaces = collectNamespaces(ctx.model);\n\n return new Proxy(Object.create(null) as Record<string, unknown>, {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n if (!namespaces.has(prop)) {\n return undefined;\n }\n return createEntityProxy(ctx, prop);\n },\n has(_target, prop) {\n return typeof prop === 'string' && namespaces.has(prop);\n },\n ownKeys() {\n return [...namespaces];\n },\n getOwnPropertyDescriptor(_target, prop) {\n if (typeof prop !== 'string' || !namespaces.has(prop)) {\n return undefined;\n }\n return {\n enumerable: true,\n configurable: true,\n value: createEntityProxy(ctx, prop),\n };\n },\n }) as Record<string, Record<string, ChainBuilder>>;\n}\n\nfunction createEntityProxy(\n ctx: ChainBuilderContext,\n namespace: string,\n): Record<string, ChainBuilder> {\n const entities = collectEntities(ctx.model, namespace);\n\n return new Proxy(Object.create(null) as Record<string, unknown>, {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n if (!entities.has(prop)) {\n return undefined;\n }\n return new ChainBuilder(ctx, {\n spec: { namespace, entity: prop },\n includes: [],\n });\n },\n has(_target, prop) {\n return typeof prop === 'string' && entities.has(prop);\n },\n ownKeys() {\n return [...entities];\n },\n getOwnPropertyDescriptor(_target, prop) {\n if (typeof prop !== 'string' || !entities.has(prop)) {\n return undefined;\n }\n return {\n enumerable: true,\n configurable: true,\n value: new ChainBuilder(ctx, {\n spec: { namespace, entity: prop },\n includes: [],\n }),\n };\n },\n }) as Record<string, ChainBuilder>;\n}\n\nfunction collectNamespaces(model: DataModel): ReadonlySet<string> {\n const namespaces = new Set<string>();\n for (const entity of model.entities) {\n namespaces.add(entity.namespace);\n }\n return namespaces;\n}\n\nfunction collectEntities(\n model: DataModel,\n namespace: string,\n): ReadonlySet<string> {\n const entities = new Set<string>();\n for (const entity of model.entities) {\n if (entity.namespace === namespace) {\n entities.add(entity.name);\n }\n }\n return entities;\n}\n","import type { Adapter, AdapterName } from '@/core/AdapterRegistry';\nimport { AdapterRegistry } from '@/core/AdapterRegistry';\nimport { QueryPlanExecutor } from '@/core/QueryPlanExecutor';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { IntrospectOptions } from '@/ports/Introspector';\nimport type { ChainBuilder } from '@/query/ChainBuilder';\nimport { createNamespaceProxy } from '@/query/NamespaceProxy';\nimport type { BirefSchemaShape } from '@/query/types/Schema';\nimport type { TypedQueryRoot } from '@/query/types/TypedChain';\n\n/**\n * Top-level facade for the SDK.\n *\n * Wraps a configured `AdapterRegistry` and exposes scanning and the\n * typed query builder. The API is ergonomic for the common case of a\n * single registered adapter and still supports multi-adapter\n * scenarios via explicit names or URL scheme detection.\n *\n * @example\n * ```ts\n * const biref = Biref.builder()\n * .withAdapter(somePostgresAdapter)\n * .build();\n * const model = await biref.scan();\n * const rows = await biref.query(model).public.users.findMany();\n * ```\n */\nexport class Biref {\n constructor(private readonly registry: AdapterRegistry) {}\n\n /** Entry point for the fluent builder. */\n static builder(): BirefBuilder {\n return new BirefBuilder();\n }\n\n /**\n * Introspect a data store. With a single registered adapter, no\n * arguments are needed. Pass `IntrospectOptions` to customize the\n * scan, or an adapter name when more than one adapter is registered.\n */\n scan(): Promise<DataModel>;\n scan(options: IntrospectOptions): Promise<DataModel>;\n scan(\n adapterName: AdapterName,\n options?: IntrospectOptions,\n ): Promise<DataModel>;\n async scan(\n adapterNameOrOptions?: AdapterName | IntrospectOptions,\n maybeOptions?: IntrospectOptions,\n ): Promise<DataModel> {\n const { adapter, options } = this.resolveScanArgs(\n adapterNameOrOptions,\n maybeOptions,\n );\n return adapter.introspector.introspect(options);\n }\n\n /**\n * Introspect a data store using whichever registered adapter handles\n * the URL's scheme. The URL is only used to pick the adapter; the\n * actual connection is still owned by the client the user passed to\n * the adapter at construction time.\n */\n async scanByUrl(\n url: string,\n options?: IntrospectOptions,\n ): Promise<DataModel> {\n const scheme = parseUrlScheme(url);\n return this.registry\n .getByUrlScheme(scheme)\n .introspector.introspect(options);\n }\n\n /**\n * Typed query entry point. Returns a namespace-level Proxy over the\n * given `DataModel`:\n *\n * biref.query(model).public.users\n * .select('id', 'email')\n * .where('active', 'eq', true)\n * .include('orders', (q) => q.select('id', 'total'))\n * .findMany();\n *\n * The Proxy layers (`namespace` → `entity`) enumerate what's\n * actually in the scanned model, so `Object.keys(biref.query(model))`\n * returns the discovered namespaces. Access to a non-existent\n * namespace or entity returns `undefined`; the chain methods throw\n * with a clear error when given unknown fields or relations.\n *\n * With a single registered adapter, the adapter is picked\n * automatically. Pass `adapterName` explicitly to target a specific\n * adapter when more than one is registered.\n */\n query<Schema extends BirefSchemaShape = never>(\n model: DataModel,\n adapterName?: AdapterName,\n ): [Schema] extends [never] ? UntypedQueryRoot : TypedQueryRoot<Schema> {\n const adapter = adapterName\n ? this.registry.get(adapterName)\n : this.requireSingleAdapter('query');\n const executor = this.executorFor(adapter);\n const proxy = createNamespaceProxy({ model, executor });\n return proxy as [Schema] extends [never]\n ? UntypedQueryRoot\n : TypedQueryRoot<Schema>;\n }\n\n /** Direct access to the underlying registry. */\n get adapters(): AdapterRegistry {\n return this.registry;\n }\n\n private executorFor(adapter: Adapter): QueryPlanExecutor {\n if (!adapter.runner) {\n throw new Error(\n `Adapter \"${adapter.name}\" does not expose a RawQueryRunner. Update the adapter factory to attach one before calling biref.query(...).`,\n );\n }\n if (!adapter.parser) {\n throw new Error(\n `Adapter \"${adapter.name}\" does not expose a RecordParser. Update the adapter factory to attach one before calling biref.query(...).`,\n );\n }\n return new QueryPlanExecutor(\n adapter.engine,\n adapter.runner,\n adapter.parser,\n );\n }\n\n private resolveScanArgs(\n adapterNameOrOptions: AdapterName | IntrospectOptions | undefined,\n maybeOptions: IntrospectOptions | undefined,\n ): { adapter: Adapter; options: IntrospectOptions | undefined } {\n if (typeof adapterNameOrOptions === 'string') {\n return {\n adapter: this.registry.get(adapterNameOrOptions),\n options: maybeOptions,\n };\n }\n return {\n adapter: this.requireSingleAdapter('scan'),\n options: adapterNameOrOptions,\n };\n }\n\n private requireSingleAdapter(operation: string): Adapter {\n const names = this.registry.list();\n if (names.length === 0) {\n throw new Error(\n `Biref.${operation}() called with no adapter argument, but no adapters are registered. Register one via Biref.builder().withAdapter(...).`,\n );\n }\n if (names.length > 1) {\n throw new Error(\n `Biref.${operation}() called with no adapter argument, but multiple adapters are registered (${names.join(', ')}). Pass an adapter name explicitly.`,\n );\n }\n const onlyName = names[0];\n if (onlyName === undefined) {\n throw new Error(\n 'Internal error: adapter list reported a length of 1 but produced no name.',\n );\n }\n return this.registry.get(onlyName);\n }\n}\n\n/**\n * Fallback return type for `biref.query(model)` when called without a\n * schema generic. Degrades to a two-layer record of dynamic\n * `ChainBuilder`s so chains still work at runtime - callers just\n * don't get the narrowed compile-time shapes.\n */\nexport type UntypedQueryRoot = Readonly<\n Record<string, Readonly<Record<string, ChainBuilder>>>\n>;\n\n/**\n * Fluent builder for `Biref`. Collects adapters and produces a wired\n * `Biref` facade. Call `build()` once and discard the builder.\n */\nexport class BirefBuilder {\n private readonly pending: Adapter[] = [];\n\n /**\n * Register an adapter. The adapter's `name` is used as the lookup\n * key when calling `Biref.scan(name)`. Its optional `urlSchemes` are\n * used by `Biref.scanByUrl(url)`.\n */\n withAdapter(adapter: Adapter): this {\n this.pending.push(adapter);\n return this;\n }\n\n /** Convenience for registering multiple adapters in one call. */\n withAdapters(...adapters: readonly Adapter[]): this {\n for (const adapter of adapters) {\n this.pending.push(adapter);\n }\n return this;\n }\n\n /**\n * Materialize the builder into a `Biref` facade. Throws if any\n * adapter has a duplicate name.\n */\n build(): Biref {\n const registry = new AdapterRegistry();\n for (const adapter of this.pending) {\n registry.register(adapter);\n }\n return new Biref(registry);\n }\n}\n\n/**\n * Extract the scheme from a URL string.\n *\n * Supports the standard URI scheme grammar (RFC 3986): a letter\n * followed by letters, digits, or `+`, `.`, `-`.\n *\n * \"postgres://...\" -> \"postgres\"\n * \"postgresql://...\" -> \"postgresql\"\n * \"mongodb+srv://...\" -> \"mongodb+srv\"\n */\nfunction parseUrlScheme(url: string): string {\n const match = /^([a-zA-Z][a-zA-Z0-9+.-]*):/.exec(url);\n if (!match?.[1]) {\n throw new Error(`Cannot determine driver scheme from URL: \"${url}\"`);\n }\n return match[1].toLowerCase();\n}\n","import type { AdapterRegistry } from '@/core/AdapterRegistry';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { IntrospectOptions } from '@/ports/Introspector';\n\n/**\n * Public facade for introspection.\n *\n * Takes an `AdapterRegistry`, looks up an adapter by name, and runs\n * its introspector to produce a `DataModel`. Used for low-level\n * scenarios where `Biref` is too high-level; most consumers should\n * prefer `Biref` instead.\n *\n * @example\n * ```ts\n * const registry = new AdapterRegistry();\n * registry.register(somePostgresAdapter);\n * const scanner = new Scanner(registry);\n * const model = await scanner.scan('postgres');\n * ```\n */\nexport class Scanner {\n constructor(private readonly registry: AdapterRegistry) {}\n\n /**\n * Scan a data store using the named adapter and return a paradigm-\n * neutral `DataModel`.\n */\n async scan(\n adapterName: string,\n options?: IntrospectOptions,\n ): Promise<DataModel> {\n return this.registry.get(adapterName).introspector.introspect(options);\n }\n}\n","import type { Formatter, SerializeOptions } from '@/output/Formatter';\nimport type { ParsedRecord, ParsedValue } from '@/parsing/ParsedRecord';\n\nexport interface CsvFormatterOptions {\n /** Delimiter character. Defaults to ','. */\n readonly delimiter?: string;\n /** Whether to emit a header row. Defaults to true. */\n readonly includeHeader?: boolean;\n /** Line terminator. Defaults to '\\n'. */\n readonly lineTerminator?: string;\n}\n\n/**\n * Serializes parsed records to a CSV string.\n *\n * Field order:\n * 1. `options.fields` from the call site, if provided\n * 2. The keys of the first record, otherwise\n * 3. Empty string when there are no records\n *\n * Escaping follows RFC 4180: cells containing the delimiter, double\n * quotes, or newlines are wrapped in double quotes, with internal double\n * quotes doubled.\n *\n * Non-string cell values are coerced as follows:\n * - `Date` → ISO 8601 string\n * - `bigint` → decimal string\n * - object/array → JSON-encoded string\n * - `null` / `undefined` → empty cell\n */\nexport class CsvFormatter implements Formatter<string> {\n readonly format = 'csv';\n readonly contentType = 'text/csv';\n\n constructor(private readonly options: CsvFormatterOptions = {}) {}\n\n serialize(\n records: readonly ParsedRecord[],\n options?: SerializeOptions,\n ): string {\n const delimiter = this.options.delimiter ?? ',';\n const lineTerminator = this.options.lineTerminator ?? '\\n';\n const includeHeader = this.options.includeHeader ?? true;\n\n const fields = this.resolveFields(records, options);\n if (fields.length === 0) {\n return '';\n }\n\n const lines: string[] = [];\n\n if (includeHeader) {\n lines.push(fields.map((f) => this.escape(f, delimiter)).join(delimiter));\n }\n\n for (const record of records) {\n const cells = fields.map((field) =>\n this.serializeCell(record[field], delimiter),\n );\n lines.push(cells.join(delimiter));\n }\n\n return lines.join(lineTerminator);\n }\n\n private resolveFields(\n records: readonly ParsedRecord[],\n options: SerializeOptions | undefined,\n ): readonly string[] {\n if (options?.fields && options.fields.length > 0) {\n return options.fields;\n }\n const first = records[0];\n return first ? Object.keys(first) : [];\n }\n\n private serializeCell(\n value: ParsedValue | undefined,\n delimiter: string,\n ): string {\n if (value === null || value === undefined) {\n return '';\n }\n if (value instanceof Date) {\n return this.escape(value.toISOString(), delimiter);\n }\n if (typeof value === 'bigint') {\n return this.escape(value.toString(), delimiter);\n }\n if (typeof value === 'object') {\n return this.escape(JSON.stringify(value), delimiter);\n }\n return this.escape(String(value), delimiter);\n }\n\n private escape(value: string, delimiter: string): string {\n if (\n value.includes(delimiter) ||\n value.includes('\"') ||\n value.includes('\\n') ||\n value.includes('\\r')\n ) {\n return `\"${value.replace(/\"/g, '\"\"')}\"`;\n }\n return value;\n }\n}\n","import type { Formatter } from '@/output/Formatter';\nimport type { ParsedRecord } from '@/parsing/ParsedRecord';\n\nexport interface JsonFormatterOptions {\n /** Indent the output with 2 spaces if true. Defaults to false. */\n readonly pretty?: boolean;\n}\n\n/**\n * Serializes parsed records to a JSON array string.\n *\n * Handles values that `JSON.stringify` does not natively support:\n * - `Date` → ISO 8601 string\n * - `bigint` → decimal string\n */\nexport class JsonFormatter implements Formatter<string> {\n readonly format = 'json';\n readonly contentType = 'application/json';\n\n constructor(private readonly options: JsonFormatterOptions = {}) {}\n\n serialize(records: readonly ParsedRecord[]): string {\n const indent = this.options.pretty ? 2 : undefined;\n return JSON.stringify(records, JsonFormatter.replacer, indent);\n }\n\n private static replacer(_key: string, value: unknown): unknown {\n if (value instanceof Date) {\n return value.toISOString();\n }\n if (typeof value === 'bigint') {\n return value.toString();\n }\n return value;\n }\n}\n","import type { Formatter } from '@/output/Formatter';\nimport type { ParsedRecord } from '@/parsing/ParsedRecord';\n\n/**\n * \"Raw\" formatter: returns the parsed records as-is, without\n * serialization. Useful when the consumer wants to keep working with\n * native JS values (e.g. piping into another JS function) instead of\n * converting to a string format.\n *\n * Unlike the other built-in formatters, this one's `TOutput` is the\n * record array itself rather than a string. The `Formatter` interface\n * is generic precisely so this case fits without special-casing.\n */\nexport class RawFormatter implements Formatter<readonly ParsedRecord[]> {\n readonly format = 'raw';\n readonly contentType = 'application/javascript';\n\n serialize(records: readonly ParsedRecord[]): readonly ParsedRecord[] {\n return records;\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/adapters/mysql/MySQLMeta.ts","../src/adapters/mysql/mapping/ConstraintMapper.ts","../src/adapters/mysql/mapping/FieldMapper.ts","../src/adapters/mysql/mysqlEnums.ts","../src/adapters/mysql/mapping/IndexMapper.ts","../src/adapters/mysql/mapping/ReferenceMapper.ts","../src/adapters/mysql/mapping/EntityAssembler.ts","../src/adapters/mysql/queries/inPlaceholders.ts","../src/adapters/mysql/queries/ColumnsQuery.ts","../src/adapters/mysql/queries/ConstraintsQuery.ts","../src/adapters/mysql/queries/ForeignKeysQuery.ts","../src/adapters/mysql/queries/IndexesQuery.ts","../src/adapters/mysql/queries/PrimaryKeysQuery.ts","../src/adapters/mysql/queries/TablesQuery.ts","../src/domain/model/DataModel.ts","../src/adapters/mysql/MySQLIntrospector.ts","../src/adapters/mysql/query/SqlIdentifier.ts","../src/adapters/mysql/query/FilterBuilder.ts","../src/adapters/mysql/query/SqlParamList.ts","../src/adapters/mysql/MySQLQueryEngine.ts","../src/parsing/DefaultRecordParser.ts","../src/adapters/mysql/MySQLRecordParser.ts","../src/adapters/mysql/MySQLRawQueryRunner.ts","../src/adapters/mysql/mysqlAdapter.ts","../src/adapters/postgres/pgEnums.ts","../src/adapters/postgres/mapping/ConstraintMapper.ts","../src/adapters/postgres/mapping/FieldMapper.ts","../src/adapters/postgres/mapping/IndexMapper.ts","../src/adapters/postgres/mapping/ReferenceMapper.ts","../src/adapters/postgres/mapping/EntityAssembler.ts","../src/adapters/postgres/PostgresMeta.ts","../src/adapters/postgres/queries/ColumnsQuery.ts","../src/adapters/postgres/queries/ConstraintsQuery.ts","../src/adapters/postgres/queries/ForeignKeysQuery.ts","../src/adapters/postgres/queries/IndexesQuery.ts","../src/adapters/postgres/queries/PrimaryKeysQuery.ts","../src/adapters/postgres/queries/TablesQuery.ts","../src/adapters/postgres/PostgresIntrospector.ts","../src/adapters/postgres/query/SqlIdentifier.ts","../src/adapters/postgres/query/FilterBuilder.ts","../src/adapters/postgres/query/SqlParamList.ts","../src/adapters/postgres/PostgresQueryEngine.ts","../src/adapters/postgres/PostgresRecordParser.ts","../src/adapters/postgres/PostgresRawQueryRunner.ts","../src/adapters/postgres/postgresAdapter.ts","../src/codegen/OverridesScaffold.ts","../src/codegen/TsTypeMapper.ts","../src/query/relationNaming.ts","../src/codegen/SchemaEmitter.ts","../src/core/AdapterRegistry.ts","../src/core/QueryPlanExecutor.ts","../src/query/ChainBuilder.ts","../src/query/NamespaceProxy.ts","../src/core/Biref.ts","../src/core/Scanner.ts","../src/output/CsvFormatter.ts","../src/output/JsonFormatter.ts","../src/output/RawFormatter.ts"],"names":["ConstraintMapper","FieldMapper","IndexMapper","ReferenceMapper","EntityAssembler","ColumnsQuery","ConstraintsQuery","ForeignKeysQuery","IndexesQuery","PrimaryKeysQuery","TablesQuery","SqlIdentifier","FilterBuilder","SqlParamList","BIGINT_NATIVE_TYPES","candidate","indent"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Adapter metadata constants for MySQL.\n *\n * Centralized so the rest of the adapter never references the literal\n * string 'mysql' or the URL schemes by hand.\n */\n\nexport const MYSQL_ADAPTER_NAME = 'mysql';\n\n/** Literal type for the MySQL adapter name, used for discrimination. */\nexport type MySQLAdapterName = typeof MYSQL_ADAPTER_NAME;\n\nexport const MYSQL_URL_SCHEMES: readonly string[] = ['mysql', 'mariadb'];\n","import type { RawConstraint } from '@/adapters/mysql/queries/ConstraintsQuery';\nimport type { Constraint, ConstraintKind } from '@/domain/model/Constraint';\n\n/**\n * Converts a raw constraint row from `ConstraintsQuery` into a\n * paradigm-neutral `Constraint`.\n *\n * Handles unique and check constraints. Primary keys and foreign keys\n * are exposed through `identifier` and `relationships` respectively.\n */\nexport class ConstraintMapper {\n static toConstraint(raw: RawConstraint): Constraint {\n return {\n name: raw.name,\n kind: ConstraintMapper.toKind(raw.kind),\n fields: raw.columns,\n expression: raw.definition,\n };\n }\n\n private static toKind(kind: string): ConstraintKind {\n switch (kind) {\n case 'UNIQUE': {\n return 'unique';\n }\n case 'CHECK': {\n return 'check';\n }\n default: {\n return 'custom';\n }\n }\n }\n}\n","import type { RawColumn } from '@/adapters/mysql/queries/ColumnsQuery';\nimport type { Field } from '@/domain/model/Field';\nimport type { FieldType, FieldTypeCategory } from '@/domain/model/FieldType';\n\nconst ENUM_VALUES_RE = /^enum\\((.+)\\)$/i;\nconst SET_VALUES_RE = /^set\\((.+)\\)$/i;\nconst QUOTED_VALUE_RE = /'([^']*)'/g;\n\n/**\n * Converts a raw column row from `ColumnsQuery` into a paradigm-neutral\n * `Field`, including the normalized `FieldType` category.\n */\nexport class FieldMapper {\n static toField(col: RawColumn, isIdentifier: boolean): Field {\n return {\n name: col.name,\n type: FieldMapper.toType(col),\n nullable: col.nullable,\n isIdentifier,\n defaultValue: col.default_value,\n description: col.description,\n };\n }\n\n private static toType(col: RawColumn): FieldType {\n const dataType = col.data_type.toLowerCase();\n\n if (dataType === 'enum') {\n return {\n category: 'enum',\n nativeType: col.column_type,\n enumValues: FieldMapper.parseEnumValues(col.column_type),\n };\n }\n\n if (dataType === 'set') {\n return {\n category: 'enum',\n nativeType: col.column_type,\n enumValues: FieldMapper.parseSetValues(col.column_type),\n };\n }\n\n // tinyint(1) is conventionally used as boolean in MySQL\n if (col.column_type.toLowerCase() === 'tinyint(1)') {\n return {\n category: 'boolean',\n nativeType: col.column_type,\n };\n }\n\n const base: FieldType = {\n category: FieldMapper.categorize(dataType),\n nativeType: col.column_type,\n };\n\n if (\n col.numeric_precision !== null &&\n (dataType === 'decimal' || dataType === 'numeric')\n ) {\n return {\n ...base,\n precision: col.numeric_precision,\n scale: col.numeric_scale ?? undefined,\n };\n }\n\n if (col.character_max_length !== null) {\n return { ...base, length: col.character_max_length };\n }\n\n return base;\n }\n\n private static parseEnumValues(columnType: string): readonly string[] {\n const match = ENUM_VALUES_RE.exec(columnType);\n if (!match) {\n return [];\n }\n return FieldMapper.extractQuotedValues(match[1]!);\n }\n\n private static parseSetValues(columnType: string): readonly string[] {\n const match = SET_VALUES_RE.exec(columnType);\n if (!match) {\n return [];\n }\n return FieldMapper.extractQuotedValues(match[1]!);\n }\n\n private static extractQuotedValues(raw: string): string[] {\n return Array.from(raw.matchAll(QUOTED_VALUE_RE), (m) => m[1]!);\n }\n\n private static categorize(dataType: string): FieldTypeCategory {\n switch (dataType) {\n case 'varchar':\n case 'char':\n case 'text':\n case 'tinytext':\n case 'mediumtext':\n case 'longtext': {\n return 'string';\n }\n case 'tinyint':\n case 'smallint':\n case 'mediumint':\n case 'int':\n case 'bigint': {\n return 'integer';\n }\n case 'decimal':\n case 'numeric':\n case 'float':\n case 'double':\n case 'real': {\n return 'decimal';\n }\n case 'bit': {\n return 'binary';\n }\n case 'date':\n case 'year': {\n return 'date';\n }\n case 'datetime':\n case 'timestamp': {\n return 'timestamp';\n }\n case 'time': {\n return 'time';\n }\n case 'json': {\n return 'json';\n }\n case 'binary':\n case 'varbinary':\n case 'blob':\n case 'tinyblob':\n case 'mediumblob':\n case 'longblob': {\n return 'binary';\n }\n default: {\n return 'unknown';\n }\n }\n }\n}\n","/**\n * Referential action strings returned by\n * `information_schema.REFERENTIAL_CONSTRAINTS`.\n */\nexport const MySQLReferentialAction = {\n Restrict: 'RESTRICT',\n Cascade: 'CASCADE',\n SetNull: 'SET NULL',\n NoAction: 'NO ACTION',\n SetDefault: 'SET DEFAULT',\n} as const;\n\nexport type MySQLReferentialAction =\n (typeof MySQLReferentialAction)[keyof typeof MySQLReferentialAction];\n\n/**\n * Index method strings returned by `information_schema.STATISTICS`.\n */\nexport const MySQLIndexMethod = {\n BTree: 'BTREE',\n Hash: 'HASH',\n Fulltext: 'FULLTEXT',\n Spatial: 'RTREE',\n} as const;\n\nexport type MySQLIndexMethod =\n (typeof MySQLIndexMethod)[keyof typeof MySQLIndexMethod];\n","import { MySQLIndexMethod } from '@/adapters/mysql/mysqlEnums';\nimport type { RawIndex } from '@/adapters/mysql/queries/IndexesQuery';\nimport type { Index, IndexKind } from '@/domain/model/Index';\n\n/**\n * Converts a raw index row from `IndexesQuery` into a paradigm-neutral\n * `Index`, mapping the MySQL index type onto an `IndexKind`.\n */\nexport class IndexMapper {\n static toIndex(raw: RawIndex): Index {\n return {\n name: raw.name,\n fields: raw.columns,\n unique: raw.unique,\n kind: IndexMapper.toKind(raw.method),\n partial: false,\n definition: null,\n };\n }\n\n private static toKind(method: string): IndexKind {\n switch (method.toUpperCase()) {\n case MySQLIndexMethod.BTree: {\n return 'btree';\n }\n case MySQLIndexMethod.Hash: {\n return 'hash';\n }\n default: {\n return 'unknown';\n }\n }\n }\n}\n","import { MySQLReferentialAction } from '@/adapters/mysql/mysqlEnums';\nimport type { RawForeignKey } from '@/adapters/mysql/queries/ForeignKeysQuery';\nimport type { Reference, ReferentialAction } from '@/domain/model/Reference';\n\n/**\n * Converts a raw foreign key from `ForeignKeysQuery` into a\n * paradigm-neutral `Reference`.\n *\n * MySQL foreign keys are declared, so `confidence` is always 1.\n */\nexport class ReferenceMapper {\n static toReference(fk: RawForeignKey): Reference {\n return {\n name: fk.name,\n fromEntity: { namespace: fk.from_namespace, name: fk.from_table },\n fromFields: fk.from_columns,\n toEntity: { namespace: fk.to_namespace, name: fk.to_table },\n toFields: fk.to_columns,\n confidence: 1,\n onUpdate: ReferenceMapper.toAction(fk.update_action),\n onDelete: ReferenceMapper.toAction(fk.delete_action),\n };\n }\n\n private static toAction(rule: string): ReferentialAction {\n switch (rule) {\n case MySQLReferentialAction.Restrict: {\n return 'restrict';\n }\n case MySQLReferentialAction.Cascade: {\n return 'cascade';\n }\n case MySQLReferentialAction.SetNull: {\n return 'set-null';\n }\n case MySQLReferentialAction.SetDefault: {\n return 'set-default';\n }\n case MySQLReferentialAction.NoAction: {\n return 'no-action';\n }\n default: {\n return 'no-action';\n }\n }\n }\n}\n","import { ConstraintMapper } from '@/adapters/mysql/mapping/ConstraintMapper';\nimport { FieldMapper } from '@/adapters/mysql/mapping/FieldMapper';\nimport { IndexMapper } from '@/adapters/mysql/mapping/IndexMapper';\nimport { ReferenceMapper } from '@/adapters/mysql/mapping/ReferenceMapper';\nimport type { RawColumn } from '@/adapters/mysql/queries/ColumnsQuery';\nimport type { RawConstraint } from '@/adapters/mysql/queries/ConstraintsQuery';\nimport type { RawForeignKey } from '@/adapters/mysql/queries/ForeignKeysQuery';\nimport type { RawIndex } from '@/adapters/mysql/queries/IndexesQuery';\nimport type { RawPrimaryKey } from '@/adapters/mysql/queries/PrimaryKeysQuery';\nimport type { RawTable } from '@/adapters/mysql/queries/TablesQuery';\nimport type { Constraint } from '@/domain/model/Constraint';\nimport type { Entity } from '@/domain/model/Entity';\nimport type { Field } from '@/domain/model/Field';\nimport type { Index } from '@/domain/model/Index';\nimport type { Relationship } from '@/domain/model/Relationship';\n\n/**\n * Raw query results handed to `EntityAssembler.assemble`.\n */\nexport interface AssembleInputs {\n readonly tables: readonly RawTable[];\n readonly columns: readonly RawColumn[];\n readonly primaryKeys: readonly RawPrimaryKey[];\n readonly foreignKeys: readonly RawForeignKey[];\n readonly indexes: readonly RawIndex[];\n readonly constraints: readonly RawConstraint[];\n}\n\n/**\n * Stitches raw `information_schema` query results into paradigm-neutral\n * `Entity` objects.\n *\n * For every foreign key the assembler emits an `outbound` relationship\n * on the source entity AND an `inbound` relationship on the target\n * entity. Rows whose entity is not present in `inputs.tables` (e.g. a\n * FK pointing to a schema the caller did not request) are skipped.\n */\nexport class EntityAssembler {\n static assemble(inputs: AssembleInputs): Entity[] {\n const tableKeys = new Set(\n inputs.tables.map((t) => EntityAssembler.qualified(t.namespace, t.name)),\n );\n\n const pkByEntity = EntityAssembler.indexPrimaryKeys(inputs.primaryKeys);\n const colsByEntity = EntityAssembler.indexColumns(inputs.columns);\n const relsByEntity = EntityAssembler.buildRelationships(\n inputs.foreignKeys,\n tableKeys,\n );\n const indexesByEntity = EntityAssembler.buildIndexes(\n inputs.indexes,\n tableKeys,\n );\n const constraintsByEntity = EntityAssembler.buildConstraints(\n inputs.constraints,\n tableKeys,\n );\n\n return inputs.tables.map((table) => {\n const key = EntityAssembler.qualified(table.namespace, table.name);\n const pkColumns = pkByEntity.get(key) ?? [];\n const pkSet = new Set(pkColumns);\n const rawCols = colsByEntity.get(key) ?? [];\n const fields: Field[] = rawCols.map((col) =>\n FieldMapper.toField(col, pkSet.has(col.name)),\n );\n\n return {\n namespace: table.namespace,\n name: table.name,\n fields,\n identifier: pkColumns,\n relationships: relsByEntity.get(key) ?? [],\n constraints: constraintsByEntity.get(key) ?? [],\n indexes: indexesByEntity.get(key) ?? [],\n description: table.description,\n };\n });\n }\n\n private static indexPrimaryKeys(\n primaryKeys: readonly RawPrimaryKey[],\n ): Map<string, readonly string[]> {\n const map = new Map<string, readonly string[]>();\n for (const pk of primaryKeys) {\n map.set(\n EntityAssembler.qualified(pk.namespace, pk.table_name),\n pk.columns,\n );\n }\n return map;\n }\n\n private static indexColumns(\n columns: readonly RawColumn[],\n ): Map<string, RawColumn[]> {\n const map = new Map<string, RawColumn[]>();\n for (const col of columns) {\n const key = EntityAssembler.qualified(col.namespace, col.table_name);\n const list = map.get(key);\n if (list) {\n list.push(col);\n } else {\n map.set(key, [col]);\n }\n }\n return map;\n }\n\n private static buildRelationships(\n foreignKeys: readonly RawForeignKey[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Relationship[]> {\n const map = new Map<string, Relationship[]>();\n for (const fk of foreignKeys) {\n const reference = ReferenceMapper.toReference(fk);\n const fromKey = EntityAssembler.qualified(\n fk.from_namespace,\n fk.from_table,\n );\n const toKey = EntityAssembler.qualified(fk.to_namespace, fk.to_table);\n\n if (tableKeys.has(fromKey)) {\n EntityAssembler.push(map, fromKey, {\n direction: 'outbound',\n reference,\n });\n }\n if (tableKeys.has(toKey)) {\n EntityAssembler.push(map, toKey, {\n direction: 'inbound',\n reference,\n });\n }\n }\n return map;\n }\n\n private static buildIndexes(\n indexes: readonly RawIndex[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Index[]> {\n const map = new Map<string, Index[]>();\n for (const idx of indexes) {\n const key = EntityAssembler.qualified(idx.namespace, idx.table_name);\n if (!tableKeys.has(key)) {\n continue;\n }\n EntityAssembler.push(map, key, IndexMapper.toIndex(idx));\n }\n return map;\n }\n\n private static buildConstraints(\n constraints: readonly RawConstraint[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Constraint[]> {\n const map = new Map<string, Constraint[]>();\n for (const cn of constraints) {\n const key = EntityAssembler.qualified(cn.namespace, cn.table_name);\n if (!tableKeys.has(key)) {\n continue;\n }\n EntityAssembler.push(map, key, ConstraintMapper.toConstraint(cn));\n }\n return map;\n }\n\n private static push<T>(map: Map<string, T[]>, key: string, value: T): void {\n const list = map.get(key);\n if (list) {\n list.push(value);\n } else {\n map.set(key, [value]);\n }\n }\n\n private static qualified(namespace: string, name: string): string {\n return `${namespace}.${name}`;\n }\n}\n","/**\n * Builds a `?, ?, ?` placeholder string for use in MySQL `IN (...)` clauses.\n *\n * MySQL does not support array parameters like Postgres's `= ANY($1)`,\n * so each element needs its own `?` placeholder.\n */\nexport function inPlaceholders(count: number): string {\n return Array.from({ length: count }, () => '?').join(', ');\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\nexport interface RawColumn {\n namespace: string;\n table_name: string;\n name: string;\n data_type: string;\n column_type: string;\n nullable: boolean;\n default_value: string | null;\n description: string | null;\n character_max_length: number | null;\n numeric_precision: number | null;\n numeric_scale: number | null;\n}\n\ninterface RawColumnRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n COLUMN_NAME: string;\n DATA_TYPE: string;\n COLUMN_TYPE: string;\n IS_NULLABLE: string;\n COLUMN_DEFAULT: string | null;\n COLUMN_COMMENT: string;\n CHARACTER_MAXIMUM_LENGTH: number | null;\n NUMERIC_PRECISION: number | null;\n NUMERIC_SCALE: number | null;\n}\n\nexport class ColumnsQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawColumn[]> {\n const sql = `\nSELECT\n c.TABLE_SCHEMA,\n c.TABLE_NAME,\n c.COLUMN_NAME,\n c.DATA_TYPE,\n c.COLUMN_TYPE,\n c.IS_NULLABLE,\n c.COLUMN_DEFAULT,\n c.COLUMN_COMMENT,\n c.CHARACTER_MAXIMUM_LENGTH,\n c.NUMERIC_PRECISION,\n c.NUMERIC_SCALE\nFROM information_schema.COLUMNS c\nJOIN information_schema.TABLES t\n ON t.TABLE_SCHEMA = c.TABLE_SCHEMA\n AND t.TABLE_NAME = c.TABLE_NAME\nWHERE t.TABLE_TYPE = 'BASE TABLE'\n AND c.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY c.TABLE_SCHEMA, c.TABLE_NAME, c.ORDINAL_POSITION\n`;\n const [rows] = await client.execute<RawColumnRow>(sql, [...namespaces]);\n return rows.map((row) => ({\n namespace: row.TABLE_SCHEMA,\n table_name: row.TABLE_NAME,\n name: row.COLUMN_NAME,\n data_type: row.DATA_TYPE,\n column_type: row.COLUMN_TYPE,\n nullable: row.IS_NULLABLE === 'YES',\n default_value: row.COLUMN_DEFAULT,\n description: row.COLUMN_COMMENT || null,\n character_max_length: row.CHARACTER_MAXIMUM_LENGTH,\n numeric_precision: row.NUMERIC_PRECISION,\n numeric_scale: row.NUMERIC_SCALE,\n }));\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `ConstraintsQuery.fetch`.\n *\n * Covers `unique` and `check` constraints. Foreign keys and primary\n * keys are fetched separately. Check constraints require MySQL 8.0.16+.\n */\nexport interface RawConstraint {\n namespace: string;\n table_name: string;\n name: string;\n kind: 'UNIQUE' | 'CHECK';\n definition: string | null;\n columns: string[];\n}\n\ninterface RawUniqueRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n CONSTRAINT_NAME: string;\n COLUMN_NAME: string;\n}\n\ninterface RawCheckRow {\n CONSTRAINT_SCHEMA: string;\n TABLE_NAME: string;\n CONSTRAINT_NAME: string;\n CHECK_CLAUSE: string;\n}\n\n/**\n * Reads unique and check constraints from `information_schema` for the\n * given schemas. Unique constraint columns are aggregated in ordinal\n * order. Check constraints (MySQL 8.0.16+) are fetched separately and\n * merged; failures are silently ignored for MySQL versions that lack\n * `CHECK_CONSTRAINTS`.\n */\nexport class ConstraintsQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawConstraint[]> {\n const [uniques, checks] = await Promise.all([\n ConstraintsQuery.fetchUniques(client, namespaces),\n ConstraintsQuery.fetchChecks(client, namespaces),\n ]);\n return [...uniques, ...checks];\n }\n\n private static async fetchUniques(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<RawConstraint[]> {\n const sql = `\nSELECT\n kcu.TABLE_SCHEMA,\n kcu.TABLE_NAME,\n kcu.CONSTRAINT_NAME,\n kcu.COLUMN_NAME\nFROM information_schema.KEY_COLUMN_USAGE kcu\nJOIN information_schema.TABLE_CONSTRAINTS tc\n ON tc.CONSTRAINT_SCHEMA = kcu.CONSTRAINT_SCHEMA\n AND tc.CONSTRAINT_NAME = kcu.CONSTRAINT_NAME\n AND tc.TABLE_NAME = kcu.TABLE_NAME\nWHERE tc.CONSTRAINT_TYPE = 'UNIQUE'\n AND kcu.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY kcu.TABLE_SCHEMA, kcu.TABLE_NAME, kcu.CONSTRAINT_NAME, kcu.ORDINAL_POSITION\n`;\n const [rows] = await client.execute<RawUniqueRow>(sql, [...namespaces]);\n return ConstraintsQuery.aggregateUniques(rows);\n }\n\n private static aggregateUniques(\n rows: readonly RawUniqueRow[],\n ): RawConstraint[] {\n const map = new Map<string, RawConstraint>();\n for (const row of rows) {\n const key = `${row.TABLE_SCHEMA}.${row.TABLE_NAME}.${row.CONSTRAINT_NAME}`;\n const existing = map.get(key);\n if (existing) {\n existing.columns.push(row.COLUMN_NAME);\n } else {\n map.set(key, {\n namespace: row.TABLE_SCHEMA,\n table_name: row.TABLE_NAME,\n name: row.CONSTRAINT_NAME,\n kind: 'UNIQUE',\n definition: null,\n columns: [row.COLUMN_NAME],\n });\n }\n }\n return [...map.values()];\n }\n\n private static async fetchChecks(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<RawConstraint[]> {\n const sql = `\nSELECT\n cc.CONSTRAINT_SCHEMA,\n tc.TABLE_NAME,\n cc.CONSTRAINT_NAME,\n cc.CHECK_CLAUSE\nFROM information_schema.CHECK_CONSTRAINTS cc\nJOIN information_schema.TABLE_CONSTRAINTS tc\n ON tc.CONSTRAINT_SCHEMA = cc.CONSTRAINT_SCHEMA\n AND tc.CONSTRAINT_NAME = cc.CONSTRAINT_NAME\nWHERE tc.CONSTRAINT_TYPE = 'CHECK'\n AND cc.CONSTRAINT_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY cc.CONSTRAINT_SCHEMA, tc.TABLE_NAME, cc.CONSTRAINT_NAME\n`;\n try {\n const [rows] = await client.execute<RawCheckRow>(sql, [...namespaces]);\n return rows.map((row) => ({\n namespace: row.CONSTRAINT_SCHEMA,\n table_name: row.TABLE_NAME,\n name: row.CONSTRAINT_NAME,\n kind: 'CHECK' as const,\n definition: row.CHECK_CLAUSE,\n columns: [],\n }));\n } catch {\n // CHECK_CONSTRAINTS table does not exist before MySQL 8.0.16\n return [];\n }\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `ForeignKeysQuery.fetch` after aggregation.\n *\n * Each entry corresponds to one declared foreign key constraint with\n * aggregated column lists, matching the Postgres adapter's shape.\n */\nexport interface RawForeignKey {\n name: string;\n from_namespace: string;\n from_table: string;\n from_columns: string[];\n to_namespace: string;\n to_table: string;\n to_columns: string[];\n update_action: string;\n delete_action: string;\n}\n\ninterface RawForeignKeyRow {\n CONSTRAINT_NAME: string;\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n COLUMN_NAME: string;\n REFERENCED_TABLE_SCHEMA: string;\n REFERENCED_TABLE_NAME: string;\n REFERENCED_COLUMN_NAME: string;\n UPDATE_RULE: string;\n DELETE_RULE: string;\n}\n\n/**\n * Reads foreign key constraints from `information_schema.KEY_COLUMN_USAGE`\n * joined with `REFERENTIAL_CONSTRAINTS` for the given schemas. Returns\n * one entry per FK with aggregated column lists.\n */\nexport class ForeignKeysQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawForeignKey[]> {\n const sql = `\nSELECT\n kcu.CONSTRAINT_NAME,\n kcu.TABLE_SCHEMA,\n kcu.TABLE_NAME,\n kcu.COLUMN_NAME,\n kcu.REFERENCED_TABLE_SCHEMA,\n kcu.REFERENCED_TABLE_NAME,\n kcu.REFERENCED_COLUMN_NAME,\n rc.UPDATE_RULE,\n rc.DELETE_RULE\nFROM information_schema.KEY_COLUMN_USAGE kcu\nJOIN information_schema.REFERENTIAL_CONSTRAINTS rc\n ON rc.CONSTRAINT_SCHEMA = kcu.CONSTRAINT_SCHEMA\n AND rc.CONSTRAINT_NAME = kcu.CONSTRAINT_NAME\nWHERE kcu.REFERENCED_TABLE_NAME IS NOT NULL\n AND kcu.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY kcu.TABLE_SCHEMA, kcu.TABLE_NAME, kcu.CONSTRAINT_NAME, kcu.ORDINAL_POSITION\n`;\n const [rows] = await client.execute<RawForeignKeyRow>(sql, [...namespaces]);\n return ForeignKeysQuery.aggregate(rows);\n }\n\n private static aggregate(rows: readonly RawForeignKeyRow[]): RawForeignKey[] {\n const map = new Map<string, RawForeignKey>();\n for (const row of rows) {\n const key = `${row.TABLE_SCHEMA}.${row.TABLE_NAME}.${row.CONSTRAINT_NAME}`;\n const existing = map.get(key);\n if (existing) {\n existing.from_columns.push(row.COLUMN_NAME);\n existing.to_columns.push(row.REFERENCED_COLUMN_NAME);\n } else {\n map.set(key, {\n name: row.CONSTRAINT_NAME,\n from_namespace: row.TABLE_SCHEMA,\n from_table: row.TABLE_NAME,\n from_columns: [row.COLUMN_NAME],\n to_namespace: row.REFERENCED_TABLE_SCHEMA,\n to_table: row.REFERENCED_TABLE_NAME,\n to_columns: [row.REFERENCED_COLUMN_NAME],\n update_action: row.UPDATE_RULE,\n delete_action: row.DELETE_RULE,\n });\n }\n }\n return [...map.values()];\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `IndexesQuery.fetch` after aggregation.\n *\n * `columns` carries the indexed columns in declaration order.\n * MySQL does not support partial indexes, so `partial` is always false.\n */\nexport interface RawIndex {\n namespace: string;\n table_name: string;\n name: string;\n method: string;\n unique: boolean;\n partial: false;\n definition: null;\n columns: string[];\n}\n\ninterface RawIndexRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n INDEX_NAME: string;\n INDEX_TYPE: string;\n NON_UNIQUE: number;\n COLUMN_NAME: string;\n}\n\n/**\n * Reads non-primary indexes from `information_schema.STATISTICS` for\n * the given schemas. The primary key index is excluded because the\n * primary key columns are already exposed through the entity's\n * `identifier`.\n */\nexport class IndexesQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawIndex[]> {\n const sql = `\nSELECT\n s.TABLE_SCHEMA,\n s.TABLE_NAME,\n s.INDEX_NAME,\n s.INDEX_TYPE,\n s.NON_UNIQUE,\n s.COLUMN_NAME\nFROM information_schema.STATISTICS s\nWHERE s.INDEX_NAME <> 'PRIMARY'\n AND s.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY s.TABLE_SCHEMA, s.TABLE_NAME, s.INDEX_NAME, s.SEQ_IN_INDEX\n`;\n const [rows] = await client.execute<RawIndexRow>(sql, [...namespaces]);\n return IndexesQuery.aggregate(rows);\n }\n\n private static aggregate(rows: readonly RawIndexRow[]): RawIndex[] {\n const map = new Map<string, RawIndex>();\n for (const row of rows) {\n const key = `${row.TABLE_SCHEMA}.${row.TABLE_NAME}.${row.INDEX_NAME}`;\n const existing = map.get(key);\n if (existing) {\n existing.columns.push(row.COLUMN_NAME);\n } else {\n map.set(key, {\n namespace: row.TABLE_SCHEMA,\n table_name: row.TABLE_NAME,\n name: row.INDEX_NAME,\n method: row.INDEX_TYPE,\n unique: row.NON_UNIQUE === 0,\n partial: false,\n definition: null,\n columns: [row.COLUMN_NAME],\n });\n }\n }\n return [...map.values()];\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `PrimaryKeysQuery.fetch`.\n *\n * `columns` carries the columns in declaration order, supporting\n * composite primary keys without flattening them.\n */\nexport interface RawPrimaryKey {\n namespace: string;\n table_name: string;\n columns: string[];\n}\n\ninterface RawPrimaryKeyRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n COLUMN_NAME: string;\n}\n\n/**\n * Reads primary key columns from `information_schema.KEY_COLUMN_USAGE`\n * for the given schemas. Composite keys are aggregated into a single\n * row with all columns ordered by their ordinal position.\n */\nexport class PrimaryKeysQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawPrimaryKey[]> {\n const sql = `\nSELECT\n kcu.TABLE_SCHEMA,\n kcu.TABLE_NAME,\n kcu.COLUMN_NAME\nFROM information_schema.KEY_COLUMN_USAGE kcu\nJOIN information_schema.TABLE_CONSTRAINTS tc\n ON tc.CONSTRAINT_SCHEMA = kcu.CONSTRAINT_SCHEMA\n AND tc.CONSTRAINT_NAME = kcu.CONSTRAINT_NAME\n AND tc.TABLE_NAME = kcu.TABLE_NAME\nWHERE tc.CONSTRAINT_TYPE = 'PRIMARY KEY'\n AND kcu.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY kcu.TABLE_SCHEMA, kcu.TABLE_NAME, kcu.ORDINAL_POSITION\n`;\n const [rows] = await client.execute<RawPrimaryKeyRow>(sql, [...namespaces]);\n return PrimaryKeysQuery.aggregate(rows);\n }\n\n private static aggregate(rows: readonly RawPrimaryKeyRow[]): RawPrimaryKey[] {\n const map = new Map<string, RawPrimaryKey>();\n for (const row of rows) {\n const key = `${row.TABLE_SCHEMA}.${row.TABLE_NAME}`;\n const existing = map.get(key);\n if (existing) {\n existing.columns.push(row.COLUMN_NAME);\n } else {\n map.set(key, {\n namespace: row.TABLE_SCHEMA,\n table_name: row.TABLE_NAME,\n columns: [row.COLUMN_NAME],\n });\n }\n }\n return [...map.values()];\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { inPlaceholders } from '@/adapters/mysql/queries/inPlaceholders';\n\n/**\n * Row produced by `TablesQuery.fetch`.\n *\n * Mirrors the columns selected from `information_schema.TABLES` for\n * each base table.\n */\nexport interface RawTable {\n namespace: string;\n name: string;\n description: string | null;\n}\n\ninterface RawTableRow {\n TABLE_SCHEMA: string;\n TABLE_NAME: string;\n TABLE_COMMENT: string;\n}\n\n/**\n * Reads base tables from `information_schema.TABLES` for the given\n * schemas (databases), along with their table comment.\n */\nexport class TablesQuery {\n static async fetch(\n client: MySQLClient,\n namespaces: readonly string[],\n ): Promise<readonly RawTable[]> {\n const sql = `\nSELECT\n t.TABLE_SCHEMA AS TABLE_SCHEMA,\n t.TABLE_NAME AS TABLE_NAME,\n t.TABLE_COMMENT AS TABLE_COMMENT\nFROM information_schema.TABLES t\nWHERE t.TABLE_TYPE = 'BASE TABLE'\n AND t.TABLE_SCHEMA IN (${inPlaceholders(namespaces.length)})\nORDER BY t.TABLE_SCHEMA, t.TABLE_NAME\n`;\n const [rows] = await client.execute<RawTableRow>(sql, [...namespaces]);\n return rows.map((row) => ({\n namespace: row.TABLE_SCHEMA,\n name: row.TABLE_NAME,\n description: row.TABLE_COMMENT || null,\n }));\n }\n}\n","import type { EngineKind } from '@/domain/model/EngineKind';\nimport type { Entity } from '@/domain/model/Entity';\nimport type { Relationship } from '@/domain/model/Relationship';\n\n/**\n * The aggregate root for an introspected data store.\n *\n * Holds all entities discovered by an `Introspector`, indexed for\n * efficient lookup, and exposes navigation helpers around relationships.\n *\n * Paradigm-neutral: the same shape is returned for relational, document,\n * graph, and other data stores. Use `kind` to branch when needed.\n */\nexport class DataModel {\n private readonly index: ReadonlyMap<string, Entity>;\n\n constructor(\n public readonly kind: EngineKind,\n public readonly entities: readonly Entity[],\n ) {\n this.index = new Map(\n entities.map((e) => [DataModel.qualifiedName(e.namespace, e.name), e]),\n );\n }\n\n /**\n * Build the lookup key for an entity. Exposed as a static helper so\n * consumers can compute keys consistently when building their own\n * indexes on top of a `DataModel`.\n */\n static qualifiedName(namespace: string, name: string): string {\n return `${namespace}.${name}`;\n }\n\n getEntity(namespace: string, name: string): Entity | undefined {\n return this.index.get(DataModel.qualifiedName(namespace, name));\n }\n\n hasEntity(namespace: string, name: string): boolean {\n return this.index.has(DataModel.qualifiedName(namespace, name));\n }\n\n /**\n * All relationships an entity participates in, in both directions.\n * Returns an empty array if the entity is unknown.\n */\n relationshipsOf(namespace: string, name: string): readonly Relationship[] {\n return this.getEntity(namespace, name)?.relationships ?? [];\n }\n\n /**\n * Outbound relationships: this entity holds the reference.\n * In a relational store these correspond to FOREIGN KEY constraints\n * declared by the entity itself.\n */\n outboundRelationshipsOf(\n namespace: string,\n name: string,\n ): readonly Relationship[] {\n return this.relationshipsOf(namespace, name).filter(\n (r) => r.direction === 'outbound',\n );\n }\n\n /**\n * Inbound relationships: other entities hold references pointing here.\n *\n * This is the differentiating feature of the SDK. Most introspection\n * tools only surface outbound relationships, requiring consumers to\n * know which other entities reference theirs ahead of time.\n */\n inboundRelationshipsOf(\n namespace: string,\n name: string,\n ): readonly Relationship[] {\n return this.relationshipsOf(namespace, name).filter(\n (r) => r.direction === 'inbound',\n );\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { MYSQL_ADAPTER_NAME } from '@/adapters/mysql/MySQLMeta';\nimport { EntityAssembler } from '@/adapters/mysql/mapping/EntityAssembler';\nimport {\n ColumnsQuery,\n type RawColumn,\n} from '@/adapters/mysql/queries/ColumnsQuery';\nimport {\n ConstraintsQuery,\n type RawConstraint,\n} from '@/adapters/mysql/queries/ConstraintsQuery';\nimport {\n ForeignKeysQuery,\n type RawForeignKey,\n} from '@/adapters/mysql/queries/ForeignKeysQuery';\nimport {\n IndexesQuery,\n type RawIndex,\n} from '@/adapters/mysql/queries/IndexesQuery';\nimport {\n PrimaryKeysQuery,\n type RawPrimaryKey,\n} from '@/adapters/mysql/queries/PrimaryKeysQuery';\nimport {\n type RawTable,\n TablesQuery,\n} from '@/adapters/mysql/queries/TablesQuery';\nimport { DataModel } from '@/domain/model/DataModel';\nimport type { IntrospectOptions, Introspector } from '@/ports/Introspector';\n\n/**\n * MySQL implementation of the `Introspector` port.\n *\n * Runs six queries against `information_schema` in parallel (tables,\n * columns, primary keys, foreign keys, indexes, constraints) and hands\n * the result to `EntityAssembler`, which stitches them into a paradigm-\n * neutral `DataModel`.\n *\n * What it returns for each entity:\n * - fields with normalized type categories\n * - identifier (primary key columns)\n * - relationships in BOTH directions\n * - constraints (unique, check)\n * - indexes (excluding the primary key index)\n *\n * Accepts any client that satisfies `MySQLClient`, so it works with\n * `mysql2/promise` Connection, Pool, or any compatible library without\n * the SDK importing `mysql2`.\n */\nexport class MySQLIntrospector implements Introspector {\n readonly name = MYSQL_ADAPTER_NAME;\n readonly kind = 'relational' as const;\n\n constructor(private readonly client: MySQLClient) {}\n\n async introspect(options: IntrospectOptions = {}): Promise<DataModel> {\n const namespaces = await this.resolveNamespaces(options.namespaces);\n\n const [tables, columns, primaryKeys, foreignKeys, indexes, constraints]: [\n readonly RawTable[],\n readonly RawColumn[],\n readonly RawPrimaryKey[],\n readonly RawForeignKey[],\n readonly RawIndex[],\n readonly RawConstraint[],\n ] = await Promise.all([\n TablesQuery.fetch(this.client, namespaces),\n ColumnsQuery.fetch(this.client, namespaces),\n PrimaryKeysQuery.fetch(this.client, namespaces),\n ForeignKeysQuery.fetch(this.client, namespaces),\n IndexesQuery.fetch(this.client, namespaces),\n ConstraintsQuery.fetch(this.client, namespaces),\n ]);\n\n const filteredTables = MySQLIntrospector.applyEntityFilters(\n tables,\n options,\n );\n\n const entities = EntityAssembler.assemble({\n tables: filteredTables,\n columns,\n primaryKeys,\n foreignKeys,\n indexes,\n constraints,\n });\n\n return new DataModel('relational', entities);\n }\n\n private async resolveNamespaces(\n raw: readonly string[] | 'all' | undefined,\n ): Promise<readonly string[]> {\n if (raw === undefined) {\n return this.currentDatabase();\n }\n if (raw === 'all') {\n const [rows] = await this.client.execute<{ SCHEMA_NAME: string }>(\n MySQLIntrospector.ALL_SCHEMAS_SQL,\n );\n return rows.map((row) => row.SCHEMA_NAME);\n }\n return raw;\n }\n\n private async currentDatabase(): Promise<readonly string[]> {\n const [rows] = await this.client.execute<{ db: string }>(\n 'SELECT DATABASE() AS db',\n );\n const db = rows[0]?.db;\n if (!db) {\n throw new Error(\n 'No database selected. Pass explicit namespaces or connect to a specific database.',\n );\n }\n return [db];\n }\n\n private static readonly ALL_SCHEMAS_SQL = `\nSELECT s.SCHEMA_NAME\nFROM information_schema.SCHEMATA s\nWHERE s.SCHEMA_NAME NOT IN ('information_schema', 'mysql', 'performance_schema', 'sys')\nORDER BY s.SCHEMA_NAME\n`;\n\n private static applyEntityFilters(\n tables: readonly RawTable[],\n options: IntrospectOptions,\n ): readonly RawTable[] {\n const { includeEntities: allow, excludeEntities: deny } = options;\n if (!allow && !deny) {\n return tables;\n }\n return tables.filter((t) => {\n if (allow && !allow.includes(t.name)) {\n return false;\n }\n if (deny?.includes(t.name)) {\n return false;\n }\n return true;\n });\n }\n}\n","/**\n * Quoting helpers for MySQL SQL identifiers.\n *\n * Wraps identifiers in backticks and escapes any embedded backticks\n * by doubling them, matching the MySQL identifier grammar. Always\n * quotes, even for identifiers that would not strictly require it,\n * so reserved words and mixed case are handled without special cases.\n */\nexport class SqlIdentifier {\n static quote(id: string): string {\n return `\\`${id.replace(/`/g, '``')}\\``;\n }\n\n static qualified(namespace: string, name: string): string {\n return `${SqlIdentifier.quote(namespace)}.${SqlIdentifier.quote(name)}`;\n }\n}\n","import { SqlIdentifier } from '@/adapters/mysql/query/SqlIdentifier';\nimport type { SqlParamList } from '@/adapters/mysql/query/SqlParamList';\nimport type { Filter } from '@/domain/query/QuerySpec';\n\n/**\n * Turns a `Filter` into a MySQL SQL WHERE fragment, binding its\n * values on a shared `SqlParamList`.\n *\n * Handles every `FilterOperator`:\n * eq, neq, lt, lte, gt, gte, like, ilike, in, not-in,\n * is-null, is-not-null, between\n *\n * MySQL `LIKE` is case-insensitive by default with most collations.\n * For `ilike`, `LOWER()` is applied to both sides to guarantee\n * case-insensitive behavior regardless of collation.\n */\nexport class FilterBuilder {\n constructor(private readonly params: SqlParamList) {}\n\n build(filter: Filter): string {\n const col = SqlIdentifier.quote(filter.field);\n\n switch (filter.operator) {\n case 'eq': {\n return `${col} = ${this.params.add(filter.value)}`;\n }\n case 'neq': {\n return `${col} <> ${this.params.add(filter.value)}`;\n }\n case 'lt': {\n return `${col} < ${this.params.add(filter.value)}`;\n }\n case 'lte': {\n return `${col} <= ${this.params.add(filter.value)}`;\n }\n case 'gt': {\n return `${col} > ${this.params.add(filter.value)}`;\n }\n case 'gte': {\n return `${col} >= ${this.params.add(filter.value)}`;\n }\n case 'like': {\n return `${col} LIKE ${this.params.add(filter.value)}`;\n }\n case 'ilike': {\n return `LOWER(${col}) LIKE LOWER(${this.params.add(filter.value)})`;\n }\n case 'is-null': {\n return `${col} IS NULL`;\n }\n case 'is-not-null': {\n return `${col} IS NOT NULL`;\n }\n case 'in': {\n return this.buildInClause(col, filter.value, 'FALSE', 'IN');\n }\n case 'not-in': {\n return this.buildInClause(col, filter.value, 'TRUE', 'NOT IN');\n }\n case 'between': {\n return this.buildBetween(col, filter.value);\n }\n default: {\n const exhaustive: never = filter.operator;\n throw new Error(`Unknown filter operator: ${String(exhaustive)}`);\n }\n }\n }\n\n private buildInClause(\n col: string,\n value: unknown,\n emptyFallback: string,\n keyword: 'IN' | 'NOT IN',\n ): string {\n if (!Array.isArray(value)) {\n throw new Error(\n `Operator '${keyword.toLowerCase()}' requires an array value.`,\n );\n }\n const values = value as readonly unknown[];\n if (values.length === 0) {\n return emptyFallback;\n }\n const placeholders = this.params.addAll(values);\n return `${col} ${keyword} (${placeholders.join(', ')})`;\n }\n\n private buildBetween(col: string, value: unknown): string {\n if (!Array.isArray(value) || value.length !== 2) {\n throw new Error(\"Operator 'between' requires a [min, max] tuple.\");\n }\n const tuple = value as readonly unknown[];\n const lo = this.params.add(tuple[0]);\n const hi = this.params.add(tuple[1]);\n return `${col} BETWEEN ${lo} AND ${hi}`;\n }\n}\n","/**\n * Mutable bound parameter list for MySQL query building.\n *\n * Keeps track of the ordered values and hands out `?` placeholder\n * strings as they are added. Shared across the filter, limit, and\n * offset stages so parameter order matches the SQL text.\n */\nexport class SqlParamList {\n private readonly values: unknown[] = [];\n\n /**\n * Append a value and return a `?` placeholder.\n */\n add(value: unknown): string {\n this.values.push(value);\n return '?';\n }\n\n /**\n * Append many values and return their placeholders in order.\n */\n addAll(values: readonly unknown[]): readonly string[] {\n return values.map((v) => this.add(v));\n }\n\n /** Number of values currently bound. */\n get size(): number {\n return this.values.length;\n }\n\n /**\n * Return a read-only copy of the bound values. The returned array\n * is not backed by the internal storage.\n */\n toArray(): readonly unknown[] {\n return [...this.values];\n }\n}\n","import { MYSQL_ADAPTER_NAME } from '@/adapters/mysql/MySQLMeta';\nimport { FilterBuilder } from '@/adapters/mysql/query/FilterBuilder';\nimport { SqlIdentifier } from '@/adapters/mysql/query/SqlIdentifier';\nimport { SqlParamList } from '@/adapters/mysql/query/SqlParamList';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { BuiltQuery } from '@/domain/query/BuiltQuery';\nimport type { QuerySpec } from '@/domain/query/QuerySpec';\nimport type { QueryEngine } from '@/ports/QueryEngine';\n\n/**\n * MySQL implementation of the `QueryEngine` port.\n *\n * Produces parameterized SQL using `?` placeholders and backtick-quoted\n * identifiers. Validates the spec against the `DataModel` before\n * emitting any SQL: unknown entities or fields throw rather than\n * yielding a broken query.\n *\n * Scope:\n * - SELECT against a single entity\n * - WHERE filters (every `FilterOperator`)\n * - ORDER BY\n * - LIMIT and OFFSET\n */\nexport class MySQLQueryEngine implements QueryEngine<string> {\n readonly name = MYSQL_ADAPTER_NAME;\n readonly kind = 'relational' as const;\n\n build(spec: QuerySpec, model: DataModel): BuiltQuery<string> {\n const entity = model.getEntity(spec.namespace, spec.entity);\n if (!entity) {\n throw new Error(\n `Entity \"${spec.namespace}.${spec.entity}\" not found in the data model.`,\n );\n }\n\n const fieldNames = new Set(entity.fields.map((f) => f.name));\n const selectedFields =\n spec.select && spec.select.length > 0\n ? [...spec.select]\n : entity.fields.map((f) => f.name);\n\n for (const field of selectedFields) {\n if (!fieldNames.has(field)) {\n throw new Error(\n `Field \"${field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n }\n\n const params = new SqlParamList();\n const filterBuilder = new FilterBuilder(params);\n\n const selectClause = selectedFields.map(SqlIdentifier.quote).join(', ');\n const fromClause = SqlIdentifier.qualified(spec.namespace, spec.entity);\n\n let sql = `SELECT ${selectClause} FROM ${fromClause}`;\n\n if (spec.filters && spec.filters.length > 0) {\n const wherePieces = spec.filters.map((filter) => {\n if (!fieldNames.has(filter.field)) {\n throw new Error(\n `Filter field \"${filter.field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n return filterBuilder.build(filter);\n });\n sql += ` WHERE ${wherePieces.join(' AND ')}`;\n }\n\n if (spec.orderBy && spec.orderBy.length > 0) {\n const orderPieces = spec.orderBy.map((order) => {\n if (!fieldNames.has(order.field)) {\n throw new Error(\n `Order field \"${order.field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n return `${SqlIdentifier.quote(order.field)} ${order.direction.toUpperCase()}`;\n });\n sql += ` ORDER BY ${orderPieces.join(', ')}`;\n }\n\n if (spec.limit !== undefined) {\n sql += ` LIMIT ${Number(spec.limit)}`;\n }\n\n if (spec.offset !== undefined) {\n sql += ` OFFSET ${Number(spec.offset)}`;\n }\n\n return {\n command: sql,\n params: params.toArray(),\n metadata: {\n engine: MYSQL_ADAPTER_NAME,\n paramCount: params.size,\n },\n };\n }\n}\n","import type { Entity } from '@/domain/model/Entity';\nimport type { Field } from '@/domain/model/Field';\nimport type { ParsedRecord, ParsedValue } from '@/parsing/ParsedRecord';\nimport type { RecordParser } from '@/parsing/RecordParser';\n\n/**\n * Default `RecordParser` used when no adapter-specific parser is needed.\n *\n * Coerces raw driver output to JS values using the field type\n * categories from the `DataModel`:\n * string | uuid | enum -> JS string\n * integer -> JS number (or bigint if raw is bigint)\n * decimal -> JS string (preserves precision)\n * boolean -> JS boolean\n * date | timestamp | time -> JS Date\n * json -> pass-through\n * binary -> pass-through\n * array -> pass-through if already an array, else []\n * reference -> pass-through\n * unknown -> pass-through\n *\n * Null and undefined raw values become `null`. Fields on the entity\n * that are absent from the row are omitted from the result, so a\n * partial projection only emits the keys that were selected.\n *\n * The `coerce` method is `protected` so adapter-specific subclasses\n * (for example `PostgresRecordParser`) can override or extend it.\n */\nexport class DefaultRecordParser implements RecordParser {\n parse(entity: Entity, row: Readonly<Record<string, unknown>>): ParsedRecord {\n const result: Record<string, ParsedValue> = {};\n for (const field of entity.fields) {\n if (field.name in row) {\n result[field.name] = this.coerce(field, row[field.name]);\n }\n }\n return result;\n }\n\n parseMany(\n entity: Entity,\n rows: readonly Readonly<Record<string, unknown>>[],\n ): readonly ParsedRecord[] {\n return rows.map((row) => this.parse(entity, row));\n }\n\n protected coerce(field: Field, raw: unknown): ParsedValue {\n if (raw === null || raw === undefined) {\n return null;\n }\n\n switch (field.type.category) {\n case 'string':\n case 'uuid':\n case 'enum': {\n return String(raw);\n }\n\n case 'integer': {\n if (typeof raw === 'bigint') {\n return raw;\n }\n if (typeof raw === 'number') {\n return raw;\n }\n return Number(raw);\n }\n\n case 'decimal': {\n return typeof raw === 'string' ? raw : String(raw);\n }\n\n case 'boolean': {\n return Boolean(raw);\n }\n\n case 'date':\n case 'timestamp':\n case 'time': {\n if (raw instanceof Date) {\n return raw;\n }\n if (typeof raw === 'string' || typeof raw === 'number') {\n return new Date(raw);\n }\n return null;\n }\n\n case 'json':\n case 'binary':\n case 'reference':\n case 'unknown': {\n return raw as ParsedValue;\n }\n\n case 'array': {\n return Array.isArray(raw) ? (raw as ParsedValue[]) : [];\n }\n\n default: {\n const exhaustive: never = field.type.category;\n return exhaustive;\n }\n }\n }\n}\n","import type { Field } from '@/domain/model/Field';\nimport { DefaultRecordParser } from '@/parsing/DefaultRecordParser';\nimport type { ParsedValue } from '@/parsing/ParsedRecord';\n\nconst BIGINT_NATIVE_TYPES: ReadonlySet<string> = new Set(['bigint']);\n\n/**\n * MySQL-aware `RecordParser`.\n *\n * Extends `DefaultRecordParser` with behavior that matches how `mysql2`\n * returns MySQL values:\n *\n * - `bigint` columns are returned by `mysql2` as strings by default\n * (unless `supportBigNumbers` + `bigNumberStrings` are configured).\n * This parser converts them to JS `bigint`.\n *\n * - `tinyint(1)` columns (category `boolean`) may arrive as `0`/`1`\n * numbers. This parser normalizes them to JS `boolean`.\n *\n * - `json` columns may arrive as strings depending on driver config.\n * This parser parses them when needed.\n *\n * - `decimal` columns are returned as strings by `mysql2` to\n * preserve precision. Passed through as-is.\n *\n * - All other categories fall through to `DefaultRecordParser`.\n */\nexport class MySQLRecordParser extends DefaultRecordParser {\n protected override coerce(field: Field, raw: unknown): ParsedValue {\n if (raw === null || raw === undefined) {\n return null;\n }\n\n if (\n field.type.category === 'integer' &&\n BIGINT_NATIVE_TYPES.has(field.type.nativeType.toLowerCase())\n ) {\n if (typeof raw === 'bigint') {\n return raw;\n }\n if (typeof raw === 'string' || typeof raw === 'number') {\n return BigInt(raw);\n }\n return null;\n }\n\n if (field.type.category === 'boolean') {\n if (typeof raw === 'number') {\n return raw !== 0;\n }\n return Boolean(raw);\n }\n\n if (field.type.category === 'json' && typeof raw === 'string') {\n try {\n return JSON.parse(raw) as ParsedValue;\n } catch {\n return raw;\n }\n }\n\n return super.coerce(field, raw);\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport type { BuiltQuery } from '@/domain/query/BuiltQuery';\nimport type { RawQueryRunner } from '@/ports/RawQueryRunner';\n\n/**\n * MySQL implementation of `RawQueryRunner`.\n *\n * Holds a `MySQLClient` and forwards `BuiltQuery` instances to its\n * `execute(sql, params)` method, returning the driver's rows array\n * unchanged. Parsing into typed `ParsedRecord`s is the next stage.\n */\nexport class MySQLRawQueryRunner implements RawQueryRunner {\n constructor(private readonly client: MySQLClient) {}\n\n async run<TRow = unknown>(built: BuiltQuery): Promise<readonly TRow[]> {\n const [rows] = await this.client.execute<TRow>(built.command as string, [\n ...built.params,\n ]);\n return rows;\n }\n}\n","import type { MySQLClient } from '@/adapters/mysql/MySQLClient';\nimport { MySQLIntrospector } from '@/adapters/mysql/MySQLIntrospector';\nimport {\n MYSQL_ADAPTER_NAME,\n MYSQL_URL_SCHEMES,\n type MySQLAdapterName,\n} from '@/adapters/mysql/MySQLMeta';\nimport { MySQLQueryEngine } from '@/adapters/mysql/MySQLQueryEngine';\nimport { MySQLRawQueryRunner } from '@/adapters/mysql/MySQLRawQueryRunner';\nimport { MySQLRecordParser } from '@/adapters/mysql/MySQLRecordParser';\nimport type { Adapter } from '@/core/AdapterRegistry';\nimport type { AdapterFactory } from '@/ports/AdapterFactory';\n\n/**\n * MySQL adapter factory.\n *\n * Implements `AdapterFactory<MySQLClient, MySQLAdapterName>`.\n * `create` builds an `Adapter` bound to the user-provided client.\n *\n * @example\n * ```ts\n * import mysql from 'mysql2/promise';\n * import { Biref, mysqlAdapter } from '@biref/scanner';\n *\n * const connection = await mysql.createConnection({ ... });\n *\n * const biref = Biref.builder()\n * .withAdapter(mysqlAdapter.create(connection))\n * .build();\n *\n * const model = await biref.scan();\n * ```\n */\nexport const mysqlAdapter: AdapterFactory<MySQLClient, MySQLAdapterName> = {\n name: MYSQL_ADAPTER_NAME,\n urlSchemes: MYSQL_URL_SCHEMES,\n create(client: MySQLClient): Adapter<MySQLAdapterName> {\n return {\n name: MYSQL_ADAPTER_NAME,\n introspector: new MySQLIntrospector(client),\n engine: new MySQLQueryEngine(),\n runner: new MySQLRawQueryRunner(client),\n parser: new MySQLRecordParser(),\n urlSchemes: MYSQL_URL_SCHEMES,\n };\n },\n};\n\n/**\n * Type guard: narrows a generic `Adapter` to an `Adapter<MySQLAdapterName>`.\n */\nexport function isMySQLAdapter(\n adapter: Adapter,\n): adapter is Adapter<MySQLAdapterName> {\n return adapter.name === MYSQL_ADAPTER_NAME;\n}\n","/**\n * Single-character codes returned by `pg_type.typcategory`.\n *\n * Used by the column introspector to detect arrays, enums, and other\n * type families without inspecting `udt_name` directly.\n */\nexport const PgTypeCategory = {\n Array: 'A',\n Boolean: 'B',\n Composite: 'C',\n DateTime: 'D',\n Enum: 'E',\n Geometric: 'G',\n Network: 'I',\n Numeric: 'N',\n Pseudo: 'P',\n Range: 'R',\n String: 'S',\n Timespan: 'T',\n UserDefined: 'U',\n BitString: 'V',\n Unknown: 'X',\n InternalUse: 'Z',\n} as const;\n\nexport type PgTypeCategory =\n (typeof PgTypeCategory)[keyof typeof PgTypeCategory];\n\n/**\n * Single-character codes returned by `pg_type.typtype`.\n *\n * Distinguishes base types, composites, domains, enums, ranges, etc.\n */\nexport const PgTypeKind = {\n Base: 'b',\n Composite: 'c',\n Domain: 'd',\n Enum: 'e',\n MultiRange: 'm',\n Pseudo: 'p',\n Range: 'r',\n} as const;\n\nexport type PgTypeKind = (typeof PgTypeKind)[keyof typeof PgTypeKind];\n\n/**\n * Single-character codes returned by `pg_constraint.contype`.\n */\nexport const PgConstraintKind = {\n Check: 'c',\n ForeignKey: 'f',\n PrimaryKey: 'p',\n Trigger: 't',\n Unique: 'u',\n Exclusion: 'x',\n} as const;\n\nexport type PgConstraintKind =\n (typeof PgConstraintKind)[keyof typeof PgConstraintKind];\n\n/**\n * Single-character codes returned by `pg_constraint.confupdtype`\n * and `pg_constraint.confdeltype`.\n */\nexport const PgReferentialAction = {\n NoAction: 'a',\n Restrict: 'r',\n Cascade: 'c',\n SetNull: 'n',\n SetDefault: 'd',\n} as const;\n\nexport type PgReferentialAction =\n (typeof PgReferentialAction)[keyof typeof PgReferentialAction];\n\n/**\n * Names returned by `pg_am.amname` for index access methods.\n */\nexport const PgIndexMethod = {\n BTree: 'btree',\n Hash: 'hash',\n Gin: 'gin',\n Gist: 'gist',\n Brin: 'brin',\n SpGist: 'spgist',\n} as const;\n\nexport type PgIndexMethod = (typeof PgIndexMethod)[keyof typeof PgIndexMethod];\n","import { PgConstraintKind } from '@/adapters/postgres/pgEnums';\nimport type { RawConstraint } from '@/adapters/postgres/queries/ConstraintsQuery';\nimport type { Constraint, ConstraintKind } from '@/domain/model/Constraint';\n\n/**\n * Converts a raw constraint row from `ConstraintsQuery` into a\n * paradigm-neutral `Constraint`.\n *\n * Only handles check, unique, and exclusion constraints. Primary keys\n * are exposed through the entity's `identifier`; foreign keys are\n * exposed through `relationships`.\n */\nexport class ConstraintMapper {\n static toConstraint(raw: RawConstraint): Constraint {\n return {\n name: raw.name,\n kind: ConstraintMapper.toKind(raw.kind_code),\n fields: raw.columns,\n expression: raw.definition,\n };\n }\n\n private static toKind(code: string): ConstraintKind {\n switch (code) {\n case PgConstraintKind.Check: {\n return 'check';\n }\n case PgConstraintKind.Unique: {\n return 'unique';\n }\n case PgConstraintKind.Exclusion: {\n return 'exclusion';\n }\n default: {\n return 'custom';\n }\n }\n }\n}\n","import { PgTypeCategory, PgTypeKind } from '@/adapters/postgres/pgEnums';\nimport type { RawColumn } from '@/adapters/postgres/queries/ColumnsQuery';\nimport type { Field } from '@/domain/model/Field';\nimport type { FieldType, FieldTypeCategory } from '@/domain/model/FieldType';\n\n/**\n * Converts a raw column row from `ColumnsQuery` into a paradigm-neutral\n * `Field`, including the normalized `FieldType` category.\n */\nexport class FieldMapper {\n static toField(col: RawColumn, isIdentifier: boolean): Field {\n return {\n name: col.name,\n type: FieldMapper.toType(col),\n nullable: col.nullable,\n isIdentifier,\n defaultValue: col.default_value,\n description: col.description,\n };\n }\n\n private static toType(col: RawColumn): FieldType {\n if (col.type_category === PgTypeCategory.Array) {\n return {\n category: 'array',\n nativeType: col.native_type,\n elementType: FieldMapper.toElementType(col),\n };\n }\n\n if (col.type_kind === PgTypeKind.Enum) {\n return {\n category: 'enum',\n nativeType: col.native_type,\n enumValues: col.enum_values ?? [],\n };\n }\n\n return {\n category: FieldMapper.categorize(col.udt_name),\n nativeType: col.native_type,\n };\n }\n\n private static toElementType(col: RawColumn): FieldType {\n const elementUdt =\n col.element_udt_name ??\n (col.udt_name.startsWith('_') ? col.udt_name.slice(1) : col.udt_name);\n\n if (col.element_type_kind === PgTypeKind.Enum) {\n return {\n category: 'enum',\n nativeType: elementUdt,\n enumValues: col.element_enum_values ?? [],\n };\n }\n\n return {\n category: FieldMapper.categorize(elementUdt),\n nativeType: elementUdt,\n };\n }\n\n private static categorize(udt: string): FieldTypeCategory {\n switch (udt.toLowerCase()) {\n case 'varchar':\n case 'bpchar':\n case 'char':\n case 'text':\n case 'name':\n case 'citext': {\n return 'string';\n }\n case 'int2':\n case 'int4':\n case 'int8':\n case 'smallint':\n case 'integer':\n case 'bigint': {\n return 'integer';\n }\n case 'numeric':\n case 'decimal':\n case 'float4':\n case 'float8':\n case 'real':\n case 'money': {\n return 'decimal';\n }\n case 'bool':\n case 'boolean': {\n return 'boolean';\n }\n case 'date': {\n return 'date';\n }\n case 'timestamp':\n case 'timestamptz': {\n return 'timestamp';\n }\n case 'time':\n case 'timetz': {\n return 'time';\n }\n case 'json':\n case 'jsonb': {\n return 'json';\n }\n case 'uuid': {\n return 'uuid';\n }\n case 'bytea': {\n return 'binary';\n }\n default: {\n return 'unknown';\n }\n }\n }\n}\n","import { PgIndexMethod } from '@/adapters/postgres/pgEnums';\nimport type { RawIndex } from '@/adapters/postgres/queries/IndexesQuery';\nimport type { Index, IndexKind } from '@/domain/model/Index';\n\n/**\n * Converts a raw index row from `IndexesQuery` into a paradigm-neutral\n * `Index`, mapping the Postgres access method onto an `IndexKind`.\n */\nexport class IndexMapper {\n static toIndex(raw: RawIndex): Index {\n return {\n name: raw.name,\n fields: raw.columns,\n unique: raw.unique,\n kind: IndexMapper.toKind(raw.method),\n partial: raw.partial,\n definition: raw.definition,\n };\n }\n\n private static toKind(method: string): IndexKind {\n switch (method.toLowerCase()) {\n case PgIndexMethod.BTree: {\n return 'btree';\n }\n case PgIndexMethod.Hash: {\n return 'hash';\n }\n case PgIndexMethod.Gin: {\n return 'gin';\n }\n case PgIndexMethod.Gist: {\n return 'gist';\n }\n case PgIndexMethod.Brin: {\n return 'brin';\n }\n case PgIndexMethod.SpGist: {\n return 'spgist';\n }\n default: {\n return 'unknown';\n }\n }\n }\n}\n","import { PgReferentialAction } from '@/adapters/postgres/pgEnums';\nimport type { RawForeignKey } from '@/adapters/postgres/queries/ForeignKeysQuery';\nimport type { Reference, ReferentialAction } from '@/domain/model/Reference';\n\n/**\n * Converts a raw foreign key row from `ForeignKeysQuery` into a\n * paradigm-neutral `Reference`.\n *\n * The resulting `Reference` uses `confidence: 1` since Postgres foreign\n * keys are declared rather than inferred.\n */\nexport class ReferenceMapper {\n static toReference(fk: RawForeignKey): Reference {\n return {\n name: fk.name,\n fromEntity: { namespace: fk.from_namespace, name: fk.from_table },\n fromFields: fk.from_columns,\n toEntity: { namespace: fk.to_namespace, name: fk.to_table },\n toFields: fk.to_columns,\n confidence: 1,\n onUpdate: ReferenceMapper.toAction(fk.update_action_code),\n onDelete: ReferenceMapper.toAction(fk.delete_action_code),\n };\n }\n\n private static toAction(code: string): ReferentialAction {\n switch (code) {\n case PgReferentialAction.NoAction: {\n return 'no-action';\n }\n case PgReferentialAction.Restrict: {\n return 'restrict';\n }\n case PgReferentialAction.Cascade: {\n return 'cascade';\n }\n case PgReferentialAction.SetNull: {\n return 'set-null';\n }\n case PgReferentialAction.SetDefault: {\n return 'set-default';\n }\n default: {\n return 'no-action';\n }\n }\n }\n}\n","import { ConstraintMapper } from '@/adapters/postgres/mapping/ConstraintMapper';\nimport { FieldMapper } from '@/adapters/postgres/mapping/FieldMapper';\nimport { IndexMapper } from '@/adapters/postgres/mapping/IndexMapper';\nimport { ReferenceMapper } from '@/adapters/postgres/mapping/ReferenceMapper';\nimport type { RawColumn } from '@/adapters/postgres/queries/ColumnsQuery';\nimport type { RawConstraint } from '@/adapters/postgres/queries/ConstraintsQuery';\nimport type { RawForeignKey } from '@/adapters/postgres/queries/ForeignKeysQuery';\nimport type { RawIndex } from '@/adapters/postgres/queries/IndexesQuery';\nimport type { RawPrimaryKey } from '@/adapters/postgres/queries/PrimaryKeysQuery';\nimport type { RawTable } from '@/adapters/postgres/queries/TablesQuery';\nimport type { Constraint } from '@/domain/model/Constraint';\nimport type { Entity } from '@/domain/model/Entity';\nimport type { Field } from '@/domain/model/Field';\nimport type { Index } from '@/domain/model/Index';\nimport type { Relationship } from '@/domain/model/Relationship';\n\n/**\n * Raw query results handed to `EntityAssembler.assemble`.\n */\nexport interface AssembleInputs {\n readonly tables: readonly RawTable[];\n readonly columns: readonly RawColumn[];\n readonly primaryKeys: readonly RawPrimaryKey[];\n readonly foreignKeys: readonly RawForeignKey[];\n readonly indexes: readonly RawIndex[];\n readonly constraints: readonly RawConstraint[];\n}\n\n/**\n * Stitches raw `pg_catalog` query results into paradigm-neutral\n * `Entity` objects.\n *\n * For every foreign key the assembler emits an `outbound` relationship\n * on the source entity AND an `inbound` relationship on the target\n * entity. Rows whose entity is not present in `inputs.tables` (e.g. a\n * FK pointing to a namespace the caller did not request) are skipped.\n */\nexport class EntityAssembler {\n static assemble(inputs: AssembleInputs): Entity[] {\n const tableKeys = new Set(\n inputs.tables.map((t) => EntityAssembler.qualified(t.namespace, t.name)),\n );\n\n const pkByEntity = EntityAssembler.indexPrimaryKeys(inputs.primaryKeys);\n const colsByEntity = EntityAssembler.indexColumns(inputs.columns);\n const relsByEntity = EntityAssembler.buildRelationships(\n inputs.foreignKeys,\n tableKeys,\n );\n const indexesByEntity = EntityAssembler.buildIndexes(\n inputs.indexes,\n tableKeys,\n );\n const constraintsByEntity = EntityAssembler.buildConstraints(\n inputs.constraints,\n tableKeys,\n );\n\n return inputs.tables.map((table) => {\n const key = EntityAssembler.qualified(table.namespace, table.name);\n const pkColumns = pkByEntity.get(key) ?? [];\n const pkSet = new Set(pkColumns);\n const rawCols = colsByEntity.get(key) ?? [];\n const fields: Field[] = rawCols.map((col) =>\n FieldMapper.toField(col, pkSet.has(col.name)),\n );\n\n return {\n namespace: table.namespace,\n name: table.name,\n fields,\n identifier: pkColumns,\n relationships: relsByEntity.get(key) ?? [],\n constraints: constraintsByEntity.get(key) ?? [],\n indexes: indexesByEntity.get(key) ?? [],\n description: table.description,\n };\n });\n }\n\n private static indexPrimaryKeys(\n primaryKeys: readonly RawPrimaryKey[],\n ): Map<string, readonly string[]> {\n const map = new Map<string, readonly string[]>();\n for (const pk of primaryKeys) {\n map.set(\n EntityAssembler.qualified(pk.namespace, pk.table_name),\n pk.columns,\n );\n }\n return map;\n }\n\n private static indexColumns(\n columns: readonly RawColumn[],\n ): Map<string, RawColumn[]> {\n const map = new Map<string, RawColumn[]>();\n for (const col of columns) {\n const key = EntityAssembler.qualified(col.namespace, col.table_name);\n const list = map.get(key);\n if (list) {\n list.push(col);\n } else {\n map.set(key, [col]);\n }\n }\n return map;\n }\n\n private static buildRelationships(\n foreignKeys: readonly RawForeignKey[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Relationship[]> {\n const map = new Map<string, Relationship[]>();\n for (const fk of foreignKeys) {\n const reference = ReferenceMapper.toReference(fk);\n const fromKey = EntityAssembler.qualified(\n fk.from_namespace,\n fk.from_table,\n );\n const toKey = EntityAssembler.qualified(fk.to_namespace, fk.to_table);\n\n if (tableKeys.has(fromKey)) {\n EntityAssembler.push(map, fromKey, {\n direction: 'outbound',\n reference,\n });\n }\n if (tableKeys.has(toKey)) {\n EntityAssembler.push(map, toKey, {\n direction: 'inbound',\n reference,\n });\n }\n }\n return map;\n }\n\n private static buildIndexes(\n indexes: readonly RawIndex[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Index[]> {\n const map = new Map<string, Index[]>();\n for (const idx of indexes) {\n const key = EntityAssembler.qualified(idx.namespace, idx.table_name);\n if (!tableKeys.has(key)) {\n continue;\n }\n EntityAssembler.push(map, key, IndexMapper.toIndex(idx));\n }\n return map;\n }\n\n private static buildConstraints(\n constraints: readonly RawConstraint[],\n tableKeys: ReadonlySet<string>,\n ): Map<string, Constraint[]> {\n const map = new Map<string, Constraint[]>();\n for (const cn of constraints) {\n const key = EntityAssembler.qualified(cn.namespace, cn.table_name);\n if (!tableKeys.has(key)) {\n continue;\n }\n EntityAssembler.push(map, key, ConstraintMapper.toConstraint(cn));\n }\n return map;\n }\n\n private static push<T>(map: Map<string, T[]>, key: string, value: T): void {\n const list = map.get(key);\n if (list) {\n list.push(value);\n } else {\n map.set(key, [value]);\n }\n }\n\n private static qualified(namespace: string, name: string): string {\n return `${namespace}.${name}`;\n }\n}\n","/**\n * Adapter metadata constants for Postgres.\n *\n * Centralized so the rest of the adapter never references the literal\n * string 'postgres' or the URL schemes by hand. Anywhere those values\n * are needed, import the constant.\n */\n\nexport const POSTGRES_ADAPTER_NAME = 'postgres';\n\n/** Literal type for the Postgres adapter name, used for discrimination. */\nexport type PostgresAdapterName = typeof POSTGRES_ADAPTER_NAME;\n\nexport const POSTGRES_URL_SCHEMES: readonly string[] = [\n 'postgres',\n 'postgresql',\n];\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\nexport interface RawColumn {\n namespace: string;\n table_name: string;\n name: string;\n native_type: string;\n udt_name: string;\n type_category: string;\n type_kind: string;\n nullable: boolean;\n default_value: string | null;\n description: string | null;\n enum_values: string[] | null;\n element_udt_name: string | null;\n element_type_category: string | null;\n element_type_kind: string | null;\n element_enum_values: string[] | null;\n}\n\nexport class ColumnsQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n c.relname AS table_name,\n a.attname AS name,\n format_type(a.atttypid, a.atttypmod) AS native_type,\n t.typname AS udt_name,\n t.typcategory AS type_category,\n t.typtype AS type_kind,\n NOT a.attnotnull AS nullable,\n pg_get_expr(d.adbin, d.adrelid) AS default_value,\n col_description(c.oid, a.attnum) AS description,\n CASE\n WHEN t.typtype = 'e' THEN (\n SELECT array_agg(enumlabel ORDER BY enumsortorder)::text[]\n FROM pg_enum\n WHERE enumtypid = a.atttypid\n )\n ELSE NULL\n END AS enum_values,\n et.typname AS element_udt_name,\n et.typcategory AS element_type_category,\n et.typtype AS element_type_kind,\n CASE\n WHEN et.typtype = 'e' THEN (\n SELECT array_agg(enumlabel ORDER BY enumsortorder)::text[]\n FROM pg_enum\n WHERE enumtypid = et.oid\n )\n ELSE NULL\n END AS element_enum_values\nFROM pg_attribute a\nJOIN pg_class c ON c.oid = a.attrelid\nJOIN pg_namespace n ON n.oid = c.relnamespace\nJOIN pg_type t ON t.oid = a.atttypid\nLEFT JOIN pg_type et ON et.oid = t.typelem AND t.typcategory = 'A'\nLEFT JOIN pg_attrdef d ON d.adrelid = c.oid AND d.adnum = a.attnum\nWHERE c.relkind IN ('r', 'p')\n AND a.attnum > 0\n AND NOT a.attisdropped\n AND n.nspname = ANY($1)\nORDER BY n.nspname, c.relname, a.attnum\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawColumn[]> {\n const result = await client.query<RawColumn>(ColumnsQuery.SQL, [\n namespaces,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `ConstraintsQuery.fetch`.\n *\n * Covers `check`, `unique`, and `exclusion` constraints. Foreign keys\n * and primary keys are fetched separately.\n */\nexport interface RawConstraint {\n namespace: string;\n table_name: string;\n name: string;\n kind_code: string;\n definition: string | null;\n columns: string[];\n}\n\n/**\n * Reads check, unique, and exclusion constraints from `pg_constraint`\n * for the given namespaces. The constraint definition is the textual\n * form returned by `pg_get_constraintdef`.\n */\nexport class ConstraintsQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n cls.relname AS table_name,\n c.conname AS name,\n c.contype AS kind_code,\n pg_get_constraintdef(c.oid) AS definition,\n CASE\n WHEN array_length(c.conkey, 1) > 0 THEN\n (SELECT array_agg(att.attname ORDER BY u.ord)::text[]\n FROM unnest(c.conkey) WITH ORDINALITY AS u(attnum, ord)\n JOIN pg_attribute att\n ON att.attrelid = c.conrelid AND att.attnum = u.attnum)\n ELSE ARRAY[]::text[]\n END AS columns\nFROM pg_constraint c\nJOIN pg_class cls ON cls.oid = c.conrelid\nJOIN pg_namespace n ON n.oid = cls.relnamespace\nWHERE c.contype IN ('c', 'u', 'x')\n AND n.nspname = ANY($1)\nORDER BY n.nspname, cls.relname, c.conname\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawConstraint[]> {\n const result = await client.query<RawConstraint>(ConstraintsQuery.SQL, [\n namespaces,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `ForeignKeysQuery.fetch`.\n *\n * Each row corresponds to one declared foreign key constraint and\n * already aggregates the from/to columns in declaration order, so\n * composite keys are returned as a single row.\n */\nexport interface RawForeignKey {\n name: string;\n from_namespace: string;\n from_table: string;\n from_columns: string[];\n to_namespace: string;\n to_table: string;\n to_columns: string[];\n update_action_code: string;\n delete_action_code: string;\n}\n\n/**\n * Reads foreign key constraints from `pg_constraint` for the given\n * namespaces. Returns the source and target columns and the update\n * and delete action codes (single character codes from\n * `confupdtype` / `confdeltype`).\n */\nexport class ForeignKeysQuery {\n private static readonly SQL = `\nSELECT\n c.conname AS name,\n fn.nspname AS from_namespace,\n fc.relname AS from_table,\n (SELECT array_agg(att.attname ORDER BY u.ord)::text[]\n FROM unnest(c.conkey) WITH ORDINALITY AS u(attnum, ord)\n JOIN pg_attribute att\n ON att.attrelid = c.conrelid AND att.attnum = u.attnum\n ) AS from_columns,\n tn.nspname AS to_namespace,\n tc.relname AS to_table,\n (SELECT array_agg(att.attname ORDER BY u.ord)::text[]\n FROM unnest(c.confkey) WITH ORDINALITY AS u(attnum, ord)\n JOIN pg_attribute att\n ON att.attrelid = c.confrelid AND att.attnum = u.attnum\n ) AS to_columns,\n c.confupdtype AS update_action_code,\n c.confdeltype AS delete_action_code\nFROM pg_constraint c\nJOIN pg_class fc ON fc.oid = c.conrelid\nJOIN pg_namespace fn ON fn.oid = fc.relnamespace\nJOIN pg_class tc ON tc.oid = c.confrelid\nJOIN pg_namespace tn ON tn.oid = tc.relnamespace\nWHERE c.contype = 'f'\n AND fn.nspname = ANY($1)\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawForeignKey[]> {\n const result = await client.query<RawForeignKey>(ForeignKeysQuery.SQL, [\n namespaces,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `IndexesQuery.fetch`.\n *\n * `columns` carries the indexed columns in their order within the\n * index. `partial` is true when the index has a `WHERE` clause.\n * `definition` is the textual `CREATE INDEX` statement.\n */\nexport interface RawIndex {\n namespace: string;\n table_name: string;\n name: string;\n method: string;\n unique: boolean;\n partial: boolean;\n definition: string | null;\n columns: string[];\n}\n\n/**\n * Reads non-primary indexes from `pg_index` for the given namespaces.\n * The primary key index is excluded because the primary key columns\n * are already exposed through the entity's `identifier`.\n */\nexport class IndexesQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n t.relname AS table_name,\n i.relname AS name,\n am.amname AS method,\n ix.indisunique AS unique,\n (ix.indpred IS NOT NULL) AS partial,\n pg_get_indexdef(ix.indexrelid) AS definition,\n ARRAY(\n SELECT a.attname\n FROM unnest(ix.indkey::int[]) WITH ORDINALITY AS k(attnum, ord)\n JOIN pg_attribute a\n ON a.attrelid = t.oid AND a.attnum = k.attnum\n ORDER BY k.ord\n )::text[] AS columns\nFROM pg_index ix\nJOIN pg_class i ON i.oid = ix.indexrelid\nJOIN pg_class t ON t.oid = ix.indrelid\nJOIN pg_namespace n ON n.oid = t.relnamespace\nJOIN pg_am am ON am.oid = i.relam\nWHERE NOT ix.indisprimary\n AND n.nspname = ANY($1)\nORDER BY n.nspname, t.relname, i.relname\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawIndex[]> {\n const result = await client.query<RawIndex>(IndexesQuery.SQL, [namespaces]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `PrimaryKeysQuery.fetch`.\n *\n * `columns` carries the columns in declaration order, supporting\n * composite primary keys without flattening them.\n */\nexport interface RawPrimaryKey {\n namespace: string;\n table_name: string;\n columns: string[];\n}\n\n/**\n * Reads primary key constraints from `pg_constraint` for the given\n * namespaces. Composite keys are returned as a single row with all\n * columns ordered by their position in the constraint.\n */\nexport class PrimaryKeysQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n cls.relname AS table_name,\n (SELECT array_agg(att.attname ORDER BY u.ord)::text[]\n FROM unnest(c.conkey) WITH ORDINALITY AS u(attnum, ord)\n JOIN pg_attribute att\n ON att.attrelid = c.conrelid AND att.attnum = u.attnum\n ) AS columns\nFROM pg_constraint c\nJOIN pg_class cls ON cls.oid = c.conrelid\nJOIN pg_namespace n ON n.oid = cls.relnamespace\nWHERE c.contype = 'p'\n AND n.nspname = ANY($1)\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawPrimaryKey[]> {\n const result = await client.query<RawPrimaryKey>(PrimaryKeysQuery.SQL, [\n namespaces,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\n\n/**\n * Row produced by `TablesQuery.fetch`.\n *\n * Mirrors the columns selected from `pg_class` and `pg_namespace` for\n * each relation: regular tables and partitioned tables.\n */\nexport interface RawTable {\n namespace: string;\n name: string;\n description: string | null;\n}\n\n/**\n * Reads relations (tables and partitioned tables) from the given\n * namespaces, along with their pg_class comment.\n */\nexport class TablesQuery {\n private static readonly SQL = `\nSELECT\n n.nspname AS namespace,\n c.relname AS name,\n obj_description(c.oid, 'pg_class') AS description\nFROM pg_class c\nJOIN pg_namespace n ON n.oid = c.relnamespace\nWHERE c.relkind IN ('r', 'p')\n AND n.nspname = ANY($1)\nORDER BY n.nspname, c.relname\n`;\n\n static async fetch(\n client: PostgresClient,\n namespaces: readonly string[],\n ): Promise<readonly RawTable[]> {\n const result = await client.query<RawTable>(TablesQuery.SQL, [namespaces]);\n return result.rows;\n }\n}\n","import { EntityAssembler } from '@/adapters/postgres/mapping/EntityAssembler';\nimport type { PostgresClient } from '@/adapters/postgres/PostgresClient';\nimport { POSTGRES_ADAPTER_NAME } from '@/adapters/postgres/PostgresMeta';\nimport {\n ColumnsQuery,\n type RawColumn,\n} from '@/adapters/postgres/queries/ColumnsQuery';\nimport {\n ConstraintsQuery,\n type RawConstraint,\n} from '@/adapters/postgres/queries/ConstraintsQuery';\nimport {\n ForeignKeysQuery,\n type RawForeignKey,\n} from '@/adapters/postgres/queries/ForeignKeysQuery';\nimport {\n IndexesQuery,\n type RawIndex,\n} from '@/adapters/postgres/queries/IndexesQuery';\nimport {\n PrimaryKeysQuery,\n type RawPrimaryKey,\n} from '@/adapters/postgres/queries/PrimaryKeysQuery';\nimport {\n type RawTable,\n TablesQuery,\n} from '@/adapters/postgres/queries/TablesQuery';\nimport { DataModel } from '@/domain/model/DataModel';\nimport type { IntrospectOptions, Introspector } from '@/ports/Introspector';\n\nconst DEFAULT_NAMESPACES: readonly string[] = ['public'];\n\n/**\n * Postgres implementation of the `Introspector` port.\n *\n * Runs six queries against `pg_catalog` in parallel (tables, columns,\n * primary keys, foreign keys, indexes, constraints) and hands the\n * result to `EntityAssembler`, which stitches them into a paradigm-\n * neutral `DataModel`.\n *\n * What it returns for each entity:\n * - fields with normalized type categories\n * - identifier (primary key columns)\n * - relationships in BOTH directions\n * - constraints (unique, check, exclusion)\n * - indexes (excluding the primary key index)\n *\n * Accepts any client that satisfies `PostgresClient`, so it works with\n * `pg.Client`, `pg.Pool`, or any compatible library without the SDK\n * importing `pg`.\n */\nexport class PostgresIntrospector implements Introspector {\n readonly name = POSTGRES_ADAPTER_NAME;\n readonly kind = 'relational' as const;\n\n constructor(private readonly client: PostgresClient) {}\n\n async introspect(options: IntrospectOptions = {}): Promise<DataModel> {\n const namespaces = await this.resolveNamespaces(options.namespaces);\n\n const [tables, columns, primaryKeys, foreignKeys, indexes, constraints]: [\n readonly RawTable[],\n readonly RawColumn[],\n readonly RawPrimaryKey[],\n readonly RawForeignKey[],\n readonly RawIndex[],\n readonly RawConstraint[],\n ] = await Promise.all([\n TablesQuery.fetch(this.client, namespaces),\n ColumnsQuery.fetch(this.client, namespaces),\n PrimaryKeysQuery.fetch(this.client, namespaces),\n ForeignKeysQuery.fetch(this.client, namespaces),\n IndexesQuery.fetch(this.client, namespaces),\n ConstraintsQuery.fetch(this.client, namespaces),\n ]);\n\n const filteredTables = PostgresIntrospector.applyEntityFilters(\n tables,\n options,\n );\n\n const entities = EntityAssembler.assemble({\n tables: filteredTables,\n columns,\n primaryKeys,\n foreignKeys,\n indexes,\n constraints,\n });\n\n return new DataModel('relational', entities);\n }\n\n private async resolveNamespaces(\n raw: readonly string[] | 'all' | undefined,\n ): Promise<readonly string[]> {\n if (raw === undefined) {\n return DEFAULT_NAMESPACES;\n }\n if (raw === 'all') {\n const result = await this.client.query<{ nspname: string }>(\n PostgresIntrospector.ALL_NAMESPACES_SQL,\n );\n return result.rows.map((row) => row.nspname);\n }\n return raw;\n }\n\n private static readonly ALL_NAMESPACES_SQL = `\nSELECT n.nspname\nFROM pg_namespace n\nWHERE n.nspname NOT IN ('pg_catalog', 'information_schema')\n AND n.nspname NOT LIKE 'pg_toast%'\n AND n.nspname NOT LIKE 'pg_temp_%'\nORDER BY n.nspname\n`;\n\n private static applyEntityFilters(\n tables: readonly RawTable[],\n options: IntrospectOptions,\n ): readonly RawTable[] {\n const { includeEntities: allow, excludeEntities: deny } = options;\n if (!allow && !deny) {\n return tables;\n }\n return tables.filter((t) => {\n if (allow && !allow.includes(t.name)) {\n return false;\n }\n if (deny?.includes(t.name)) {\n return false;\n }\n return true;\n });\n }\n}\n","/**\n * Quoting helpers for Postgres SQL identifiers.\n *\n * Wraps identifiers in double quotes and escapes any embedded double\n * quotes by doubling them, matching the Postgres identifier grammar.\n * Always quotes, even for identifiers that would not strictly require\n * it, so mixed case and reserved words are handled without special\n * cases.\n */\nexport class SqlIdentifier {\n static quote(id: string): string {\n return `\"${id.replace(/\"/g, '\"\"')}\"`;\n }\n\n static qualified(namespace: string, name: string): string {\n return `${SqlIdentifier.quote(namespace)}.${SqlIdentifier.quote(name)}`;\n }\n}\n","import { SqlIdentifier } from '@/adapters/postgres/query/SqlIdentifier';\nimport type { SqlParamList } from '@/adapters/postgres/query/SqlParamList';\nimport type { Filter } from '@/domain/query/QuerySpec';\n\n/**\n * Turns a `Filter` into a Postgres SQL WHERE fragment, binding its\n * values on a shared `SqlParamList`.\n *\n * The builder does not quote field names itself beyond what\n * `SqlIdentifier.quote` does: it assumes the caller has already\n * validated that the field exists on the target entity.\n *\n * Handles every `FilterOperator`:\n * eq, neq, lt, lte, gt, gte, like, ilike, in, not-in,\n * is-null, is-not-null, between\n *\n * Throws on malformed values (e.g. 'in' with a non-array) rather than\n * producing broken SQL.\n */\nexport class FilterBuilder {\n constructor(private readonly params: SqlParamList) {}\n\n build(filter: Filter): string {\n const col = SqlIdentifier.quote(filter.field);\n\n switch (filter.operator) {\n case 'eq': {\n return `${col} = ${this.params.add(filter.value)}`;\n }\n case 'neq': {\n return `${col} <> ${this.params.add(filter.value)}`;\n }\n case 'lt': {\n return `${col} < ${this.params.add(filter.value)}`;\n }\n case 'lte': {\n return `${col} <= ${this.params.add(filter.value)}`;\n }\n case 'gt': {\n return `${col} > ${this.params.add(filter.value)}`;\n }\n case 'gte': {\n return `${col} >= ${this.params.add(filter.value)}`;\n }\n case 'like': {\n return `${col} LIKE ${this.params.add(filter.value)}`;\n }\n case 'ilike': {\n return `${col} ILIKE ${this.params.add(filter.value)}`;\n }\n case 'is-null': {\n return `${col} IS NULL`;\n }\n case 'is-not-null': {\n return `${col} IS NOT NULL`;\n }\n case 'in': {\n return this.buildInClause(col, filter.value, 'FALSE', 'IN');\n }\n case 'not-in': {\n return this.buildInClause(col, filter.value, 'TRUE', 'NOT IN');\n }\n case 'between': {\n return this.buildBetween(col, filter.value);\n }\n default: {\n const exhaustive: never = filter.operator;\n throw new Error(`Unknown filter operator: ${String(exhaustive)}`);\n }\n }\n }\n\n private buildInClause(\n col: string,\n value: unknown,\n emptyFallback: string,\n keyword: 'IN' | 'NOT IN',\n ): string {\n if (!Array.isArray(value)) {\n throw new Error(\n `Operator '${keyword.toLowerCase()}' requires an array value.`,\n );\n }\n const values = value as readonly unknown[];\n if (values.length === 0) {\n return emptyFallback;\n }\n const placeholders = this.params.addAll(values);\n return `${col} ${keyword} (${placeholders.join(', ')})`;\n }\n\n private buildBetween(col: string, value: unknown): string {\n if (!Array.isArray(value) || value.length !== 2) {\n throw new Error(\"Operator 'between' requires a [min, max] tuple.\");\n }\n const tuple = value as readonly unknown[];\n const lo = this.params.add(tuple[0]);\n const hi = this.params.add(tuple[1]);\n return `${col} BETWEEN ${lo} AND ${hi}`;\n }\n}\n","/**\n * Mutable bound parameter list for Postgres query building.\n *\n * Keeps track of the ordered values and hands out `$N` placeholder\n * strings as they are added. Shared across the filter, limit, and\n * offset stages so every placeholder number is unique and sequential.\n */\nexport class SqlParamList {\n private readonly values: unknown[] = [];\n\n /**\n * Append a value and return its placeholder (`$N`, where N is the\n * 1-based position of the value in the list).\n */\n add(value: unknown): string {\n this.values.push(value);\n return `$${this.values.length}`;\n }\n\n /**\n * Append many values and return their placeholders in order.\n */\n addAll(values: readonly unknown[]): readonly string[] {\n return values.map((v) => this.add(v));\n }\n\n /** Number of values currently bound. */\n get size(): number {\n return this.values.length;\n }\n\n /**\n * Return a read-only copy of the bound values. The returned array\n * is not backed by the internal storage.\n */\n toArray(): readonly unknown[] {\n return [...this.values];\n }\n}\n","import { POSTGRES_ADAPTER_NAME } from '@/adapters/postgres/PostgresMeta';\nimport { FilterBuilder } from '@/adapters/postgres/query/FilterBuilder';\nimport { SqlIdentifier } from '@/adapters/postgres/query/SqlIdentifier';\nimport { SqlParamList } from '@/adapters/postgres/query/SqlParamList';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { BuiltQuery } from '@/domain/query/BuiltQuery';\nimport type { QuerySpec } from '@/domain/query/QuerySpec';\nimport type { QueryEngine } from '@/ports/QueryEngine';\n\n/**\n * Postgres implementation of the `QueryEngine` port.\n *\n * Produces parameterized SQL using `$1`, `$2`, ... placeholders and\n * double-quoted identifiers. Validates the spec against the\n * `DataModel` before emitting any SQL: unknown entities or fields\n * throw rather than yielding a broken query.\n *\n * Scope:\n * - SELECT against a single entity\n * - WHERE filters (every `FilterOperator`)\n * - ORDER BY\n * - LIMIT and OFFSET\n * - No joins, group by, or aggregates yet\n */\nexport class PostgresQueryEngine implements QueryEngine<string> {\n readonly name = POSTGRES_ADAPTER_NAME;\n readonly kind = 'relational' as const;\n\n build(spec: QuerySpec, model: DataModel): BuiltQuery<string> {\n const entity = model.getEntity(spec.namespace, spec.entity);\n if (!entity) {\n throw new Error(\n `Entity \"${spec.namespace}.${spec.entity}\" not found in the data model.`,\n );\n }\n\n const fieldNames = new Set(entity.fields.map((f) => f.name));\n const selectedFields =\n spec.select && spec.select.length > 0\n ? [...spec.select]\n : entity.fields.map((f) => f.name);\n\n for (const field of selectedFields) {\n if (!fieldNames.has(field)) {\n throw new Error(\n `Field \"${field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n }\n\n const params = new SqlParamList();\n const filterBuilder = new FilterBuilder(params);\n\n const selectClause = selectedFields.map(SqlIdentifier.quote).join(', ');\n const fromClause = SqlIdentifier.qualified(spec.namespace, spec.entity);\n\n let sql = `SELECT ${selectClause} FROM ${fromClause}`;\n\n if (spec.filters && spec.filters.length > 0) {\n const wherePieces = spec.filters.map((filter) => {\n if (!fieldNames.has(filter.field)) {\n throw new Error(\n `Filter field \"${filter.field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n return filterBuilder.build(filter);\n });\n sql += ` WHERE ${wherePieces.join(' AND ')}`;\n }\n\n if (spec.orderBy && spec.orderBy.length > 0) {\n const orderPieces = spec.orderBy.map((order) => {\n if (!fieldNames.has(order.field)) {\n throw new Error(\n `Order field \"${order.field}\" does not exist on \"${spec.namespace}.${spec.entity}\".`,\n );\n }\n return `${SqlIdentifier.quote(order.field)} ${order.direction.toUpperCase()}`;\n });\n sql += ` ORDER BY ${orderPieces.join(', ')}`;\n }\n\n if (spec.limit !== undefined) {\n sql += ` LIMIT ${params.add(spec.limit)}`;\n }\n\n if (spec.offset !== undefined) {\n sql += ` OFFSET ${params.add(spec.offset)}`;\n }\n\n return {\n command: sql,\n params: params.toArray(),\n metadata: {\n engine: POSTGRES_ADAPTER_NAME,\n paramCount: params.size,\n },\n };\n }\n}\n","import type { Field } from '@/domain/model/Field';\nimport { DefaultRecordParser } from '@/parsing/DefaultRecordParser';\nimport type { ParsedValue } from '@/parsing/ParsedRecord';\n\nconst BIGINT_NATIVE_TYPES: ReadonlySet<string> = new Set(['int8', 'bigint']);\n\n/**\n * Postgres-aware `RecordParser`.\n *\n * Extends `DefaultRecordParser` with behavior that matches how the\n * `pg` driver returns Postgres values:\n *\n * - `int8` / `bigint` columns are returned by `pg` as strings by\n * default (to preserve precision). This parser converts them to\n * JS `bigint` so downstream code does not silently lose digits.\n *\n * - `json` / `jsonb` columns are usually already parsed by `pg`,\n * but when they arrive as strings (for example from drivers that\n * do not auto-parse) this parser parses them.\n *\n * - All other categories fall through to `DefaultRecordParser`.\n *\n * Use this parser when consuming rows that come from a `pg.Client` or\n * `pg.Pool`. For adapters that handle these concerns themselves, the\n * default parser is still appropriate.\n */\nexport class PostgresRecordParser extends DefaultRecordParser {\n protected override coerce(field: Field, raw: unknown): ParsedValue {\n if (raw === null || raw === undefined) {\n return null;\n }\n\n if (\n field.type.category === 'integer' &&\n BIGINT_NATIVE_TYPES.has(field.type.nativeType.toLowerCase())\n ) {\n if (typeof raw === 'bigint') {\n return raw;\n }\n if (typeof raw === 'string' || typeof raw === 'number') {\n return BigInt(raw);\n }\n return null;\n }\n\n if (field.type.category === 'json' && typeof raw === 'string') {\n try {\n return JSON.parse(raw) as ParsedValue;\n } catch {\n return raw;\n }\n }\n\n return super.coerce(field, raw);\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\nimport type { BuiltQuery } from '@/domain/query/BuiltQuery';\nimport type { RawQueryRunner } from '@/ports/RawQueryRunner';\n\n/**\n * Postgres implementation of `RawQueryRunner`.\n *\n * Holds a `PostgresClient` and forwards `BuiltQuery` instances to its\n * `query(text, params)` method, returning the driver's `rows` array\n * unchanged. Parsing into typed `ParsedRecord`s is the next stage.\n */\nexport class PostgresRawQueryRunner implements RawQueryRunner {\n constructor(private readonly client: PostgresClient) {}\n\n async run<TRow = unknown>(built: BuiltQuery): Promise<readonly TRow[]> {\n const result = await this.client.query<TRow>(built.command as string, [\n ...built.params,\n ]);\n return result.rows;\n }\n}\n","import type { PostgresClient } from '@/adapters/postgres/PostgresClient';\nimport { PostgresIntrospector } from '@/adapters/postgres/PostgresIntrospector';\nimport {\n POSTGRES_ADAPTER_NAME,\n POSTGRES_URL_SCHEMES,\n type PostgresAdapterName,\n} from '@/adapters/postgres/PostgresMeta';\nimport { PostgresQueryEngine } from '@/adapters/postgres/PostgresQueryEngine';\nimport { PostgresRawQueryRunner } from '@/adapters/postgres/PostgresRawQueryRunner';\nimport { PostgresRecordParser } from '@/adapters/postgres/PostgresRecordParser';\nimport type { Adapter } from '@/core/AdapterRegistry';\nimport type { AdapterFactory } from '@/ports/AdapterFactory';\n\n/**\n * Postgres adapter factory.\n *\n * Implements `AdapterFactory<PostgresClient, PostgresAdapterName>`.\n * `create` builds an `Adapter` bound to the user-provided client.\n *\n * @example\n * ```ts\n * import pg from 'pg';\n * import { Biref, postgresAdapter } from '@biref/scanner';\n *\n * const client = new pg.Client({ ... });\n * await client.connect();\n *\n * const biref = Biref.builder()\n * .withAdapter(postgresAdapter.create(client))\n * .build();\n *\n * const model = await biref.scan();\n * ```\n */\nexport const postgresAdapter: AdapterFactory<\n PostgresClient,\n PostgresAdapterName\n> = {\n name: POSTGRES_ADAPTER_NAME,\n urlSchemes: POSTGRES_URL_SCHEMES,\n create(client: PostgresClient): Adapter<PostgresAdapterName> {\n return {\n name: POSTGRES_ADAPTER_NAME,\n introspector: new PostgresIntrospector(client),\n engine: new PostgresQueryEngine(),\n runner: new PostgresRawQueryRunner(client),\n parser: new PostgresRecordParser(),\n urlSchemes: POSTGRES_URL_SCHEMES,\n };\n },\n};\n\n/**\n * Type guard: narrows a generic `Adapter` to an `Adapter<PostgresAdapterName>`.\n *\n * @example\n * ```ts\n * if (isPostgresAdapter(adapter)) {\n * // adapter.name is now typed as 'postgres'\n * }\n * ```\n */\nexport function isPostgresAdapter(\n adapter: Adapter,\n): adapter is Adapter<PostgresAdapterName> {\n return adapter.name === POSTGRES_ADAPTER_NAME;\n}\n","const SCAFFOLD = `// biref.schema.overrides.ts - edit freely, regen will NOT touch this file.\n//\n// Use this file to attach concrete TypeScript types to columns whose\n// shape the database scanner cannot see - typically jsonb payloads.\n// Key each override by qualified entity name ('namespace.entity')\n// and list the fields you want to type.\n//\n// @example\n// export interface Overrides extends BirefOverridesShape {\n// 'identity.users': {\n// profile: { plan: 'free' | 'pro'; prefs: { darkMode: boolean } };\n// };\n// }\n\nimport type { BirefOverridesShape } from '@biref/scanner';\n\nexport interface Overrides extends BirefOverridesShape {}\n`;\n\n/**\n * Content of the first-run overrides file scaffold.\n *\n * The CLI only writes this if the target path does not already\n * exist - once the user has started editing it, regenerating the\n * schema never overwrites their work.\n */\nexport function overridesScaffold(): string {\n return SCAFFOLD;\n}\n","import type { FieldType, FieldTypeCategory } from '@/domain/model/FieldType';\n\n/**\n * Maps a paradigm-neutral `FieldType` to the TypeScript type literal\n * string emitted into the codegen-generated schema.\n *\n * JSON / JSONB categories map to `unknown` (users replace them via\n * the sibling overrides file). Enum categories with known values map\n * to a union of string literals. Array categories recurse on the\n * element type. Everything else follows the fixed table described in\n * the README.\n */\nexport function tsTypeFor(type: FieldType, nullable: boolean): string {\n const base = baseType(type);\n return nullable ? `${base} | null` : base;\n}\n\nfunction baseType(type: FieldType): string {\n switch (type.category) {\n case 'string':\n case 'uuid': {\n return 'string';\n }\n case 'enum': {\n if (type.enumValues && type.enumValues.length > 0) {\n return type.enumValues\n .map((value) => `'${escapeSingleQuote(value)}'`)\n .join(' | ');\n }\n return 'string';\n }\n case 'integer': {\n return 'number';\n }\n case 'decimal': {\n return 'string';\n }\n case 'boolean': {\n return 'boolean';\n }\n case 'date':\n case 'timestamp':\n case 'time': {\n return 'Date';\n }\n case 'json': {\n return 'unknown';\n }\n case 'binary': {\n return 'Uint8Array';\n }\n case 'array': {\n const element = type.elementType ? baseType(type.elementType) : 'unknown';\n return `ReadonlyArray<${element}>`;\n }\n case 'reference':\n case 'unknown': {\n return 'unknown';\n }\n default: {\n return assertNever(type.category);\n }\n }\n}\n\nfunction escapeSingleQuote(value: string): string {\n return value.replace(/\\\\/g, '\\\\\\\\').replace(/'/g, \"\\\\'\");\n}\n\nfunction assertNever(value: never): never {\n throw new Error(`Unhandled FieldTypeCategory: ${String(value)}`);\n}\n\n/**\n * Exported purely so tests can assert the full domain.\n */\nexport const ALL_CATEGORIES: readonly FieldTypeCategory[] = [\n 'string',\n 'integer',\n 'decimal',\n 'boolean',\n 'date',\n 'timestamp',\n 'time',\n 'json',\n 'uuid',\n 'binary',\n 'enum',\n 'array',\n 'reference',\n 'unknown',\n];\n","import type { Entity } from '@/domain/model/Entity';\nimport type { Relationship } from '@/domain/model/Relationship';\n\n/**\n * Build a map from friendly relation name to the underlying\n * `Relationship` for a given entity.\n *\n * Outbound relations (this entity holds the FK) are named after the\n * FK **column** with the trailing `_id` / `Id` stripped. This maps\n * directly to what developers see on the row: `customer.kyc_id` → the\n * relation is `kyc`, `order.created_by_user_id` → `created_by_user`,\n * `invoice.payer_id` → `payer`. A composite FK uses every column name,\n * stripped and joined with `_`.\n *\n * Inbound relations (another entity points here) use the source\n * entity's bare name: `public.orders` inbound on `public.users` is\n * exposed as `orders`. When two inbound FKs come from the same source\n * table (e.g. `orders.created_by_user_id` and\n * `orders.modified_by_user_id` both pointing at `users`) the second\n * one is disambiguated as `<source>_by_<stripped-column>` so both\n * remain discoverable.\n *\n * Self-referential FKs use the conventional `'parent'` / `'children'`\n * names so the outbound / inbound collision on the same entity does\n * not need disambiguation.\n *\n * If every other strategy collides, the resolver falls back to the\n * underlying foreign key constraint name. That keeps the relation\n * map total - every relation is always addressable by some string -\n * even for pathological schemas.\n */\nexport function buildRelationNameMap(\n entity: Entity,\n): ReadonlyMap<string, Relationship> {\n const result = new Map<string, Relationship>();\n const used = new Set<string>();\n\n // Pass 1: assign a primary proposed name to each relationship.\n const proposals: Array<{ rel: Relationship; name: string; order: number }> =\n [];\n entity.relationships.forEach((rel, order) => {\n const other =\n rel.direction === 'outbound'\n ? rel.reference.toEntity\n : rel.reference.fromEntity;\n const isSelfRef =\n other.namespace === entity.namespace && other.name === entity.name;\n\n let name: string;\n if (isSelfRef) {\n name = rel.direction === 'outbound' ? 'parent' : 'children';\n } else if (rel.direction === 'outbound') {\n name = nameFromColumns(rel.reference.fromFields) ?? other.name;\n } else {\n name = other.name;\n }\n proposals.push({ rel, name, order });\n });\n\n // Sort so outbound proposals always win collisions over inbound\n // ones. Within a direction, preserve the original iteration order\n // for determinism. This makes `.include('kyc', ...)` always resolve\n // to the outbound `customers.kyc_id → kyc.id` relation even when an\n // inbound `kyc.customer_id → customers.id` would otherwise propose\n // the same name - the outbound is how a developer reading the\n // source table's columns thinks about it.\n proposals.sort((a, b) => {\n if (a.rel.direction !== b.rel.direction) {\n return a.rel.direction === 'outbound' ? -1 : 1;\n }\n return a.order - b.order;\n });\n\n // Pass 2: walk proposals in order, disambiguating collisions.\n for (const { rel, name } of proposals) {\n let final = name;\n if (used.has(final)) {\n final = disambiguate(rel, name, used);\n }\n used.add(final);\n result.set(final, rel);\n }\n\n return result;\n}\n\n/**\n * Derive a relation name from one or more FK column names:\n *\n * ['user_id'] -> 'user'\n * ['created_by_user_id'] -> 'created_by_user'\n * ['tenant_id', 'user_id'] -> 'tenant_user'\n * ['customerId'] -> 'customer'\n * ['id'] -> null (not usable - collides with PK)\n * [] -> null\n */\nfunction nameFromColumns(columns: readonly string[]): string | null {\n if (columns.length === 0) {\n return null;\n }\n const pieces = columns\n .map(stripIdSuffix)\n .map((piece) => piece.trim())\n .filter((piece) => piece.length > 0 && piece.toLowerCase() !== 'id');\n if (pieces.length === 0) {\n return null;\n }\n return pieces.join('_');\n}\n\nfunction stripIdSuffix(column: string): string {\n // Trailing \"_id\" or \"Id\" (the two conventions), case-insensitive on\n // the underscore variant.\n const underscore = column.match(/^(.*)_id$/i);\n if (underscore?.[1] !== undefined) {\n return underscore[1];\n }\n const camel = column.match(/^(.*)Id$/);\n if (camel?.[1] !== undefined) {\n return camel[1];\n }\n return column;\n}\n\n/**\n * Produce a collision-free name for `rel` given the set of names\n * already taken. Tries increasingly specific fallbacks:\n *\n * 1. For inbound collisions, append `_by_<fk-column-stripped>`.\n * 2. For outbound collisions, append `_<target-entity>`.\n * 3. Fall back to the FK constraint name.\n * 4. Append `_2`, `_3`, … to the constraint name.\n */\nfunction disambiguate(\n rel: Relationship,\n base: string,\n used: ReadonlySet<string>,\n): string {\n if (rel.direction === 'inbound') {\n const suffix = nameFromColumns(rel.reference.fromFields);\n if (suffix) {\n const candidate = `${base}_by_${suffix}`;\n if (!used.has(candidate)) {\n return candidate;\n }\n }\n } else {\n const targetName =\n rel.direction === 'outbound' ? rel.reference.toEntity.name : null;\n if (targetName) {\n const candidate = `${base}_${targetName}`;\n if (!used.has(candidate)) {\n return candidate;\n }\n }\n }\n\n let candidate = rel.reference.name;\n if (!used.has(candidate)) {\n return candidate;\n }\n let counter = 2;\n while (used.has(candidate)) {\n candidate = `${rel.reference.name}_${counter}`;\n counter += 1;\n }\n return candidate;\n}\n","import { tsTypeFor } from '@/codegen/TsTypeMapper';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { Entity } from '@/domain/model/Entity';\nimport type { Field } from '@/domain/model/Field';\nimport type { Relationship } from '@/domain/model/Relationship';\nimport { buildRelationNameMap } from '@/query/relationNaming';\n\nconst GENERATED_BANNER = `// This file is generated by @biref/scanner. Do not edit by hand.\n// Re-run \\`biref gen\\` to regenerate it from a live database scan.\n//\n// Overrides live in the sibling \\`biref.schema.overrides.ts\\` file\n// (never regenerated) and are deep-merged into \\`BirefSchema\\` via\n// \\`ApplySchemaOverrides\\`.`;\n\n/**\n * A single file produced by split-mode codegen.\n *\n * Paths are always relative to the output folder the user passed to\n * the CLI (or to `writeSchemaFiles`) and use forward slashes. The\n * caller is responsible for joining them onto an absolute path and\n * creating any intermediate directories.\n */\nexport interface SchemaFile {\n readonly path: string;\n readonly content: string;\n}\n\n/**\n * Emit a TypeScript schema declaration from a scanned `DataModel` as\n * a single self-contained `.ts` file.\n *\n * The output exports:\n *\n * - `RawBirefSchema`: the literal schema shape the model discovered\n * - `BirefSchema`: `RawBirefSchema` with user overrides applied\n *\n * Deterministic: the same `DataModel` input always produces the same\n * string, suitable for snapshot tests and stable git diffs.\n *\n * Use this when you want everything in one file. For larger schemas\n * `generateSchemaFiles` emits one file per entity plus an index and\n * tends to be easier to browse.\n */\nexport function generateSchema(model: DataModel): string {\n const namespaces = groupByNamespace(model);\n const sortedNamespaces = [...namespaces.keys()].sort();\n\n const lines: string[] = [];\n lines.push(GENERATED_BANNER);\n lines.push('');\n lines.push(\"import type { ApplySchemaOverrides } from '@biref/scanner';\");\n lines.push(\"import type { Overrides } from './biref.schema.overrides.js';\");\n lines.push('');\n lines.push('export interface RawBirefSchema {');\n\n for (const namespace of sortedNamespaces) {\n const entities = namespaces.get(namespace);\n if (!entities) {\n continue;\n }\n lines.push(` readonly ${quoteKey(namespace)}: {`);\n const sortedEntities = [...entities].sort((a, b) =>\n a.name.localeCompare(b.name),\n );\n for (const entity of sortedEntities) {\n lines.push(` readonly ${quoteKey(entity.name)}: {`);\n lines.push(' readonly fields: {');\n for (const field of entity.fields) {\n lines.push(indent(formatFieldDescriptor(field), 4));\n }\n lines.push(' };');\n lines.push(` readonly identifier: ${formatIdentifier(entity)};`);\n const relations = sortedRelations(entity);\n if (relations.length === 0) {\n lines.push(' readonly relations: Record<string, never>;');\n } else {\n lines.push(' readonly relations: {');\n for (const [name, relationship] of relations) {\n lines.push(indent(formatRelationDescriptor(name, relationship), 4));\n }\n lines.push(' };');\n }\n lines.push(' };');\n }\n lines.push(' };');\n }\n lines.push('}');\n lines.push('');\n lines.push(\n 'export type BirefSchema = ApplySchemaOverrides<RawBirefSchema, Overrides>;',\n );\n lines.push('');\n return lines.join('\\n');\n}\n\n/**\n * Emit a folder of split schema files from a scanned `DataModel`.\n *\n * Layout:\n *\n * index.ts Root file re-exporting every per-entity\n * interface and composing `RawBirefSchema`\n * plus `BirefSchema`.\n * <namespace>/<entity>.ts One file per entity with its field\n * descriptor, identifier tuple, and\n * relations map.\n *\n * The overrides file is **not** emitted by this function - it is\n * scaffolded once by the CLI and never touched again.\n *\n * Returns the files in a deterministic order so consumers can write\n * them or snapshot-test them safely.\n */\nexport function generateSchemaFiles(model: DataModel): readonly SchemaFile[] {\n const namespaces = groupByNamespace(model);\n const sortedNamespaces = [...namespaces.keys()].sort();\n const files: SchemaFile[] = [];\n\n for (const namespace of sortedNamespaces) {\n const entities = namespaces.get(namespace);\n if (!entities) {\n continue;\n }\n const sortedEntities = [...entities].sort((a, b) =>\n a.name.localeCompare(b.name),\n );\n for (const entity of sortedEntities) {\n files.push({\n path: `${safeSegment(namespace)}/${safeSegment(entity.name)}.ts`,\n content: emitEntityFile(entity),\n });\n }\n }\n\n files.push({\n path: 'index.ts',\n content: emitIndexFile(model),\n });\n\n return files;\n}\n\nfunction emitEntityFile(entity: Entity): string {\n const interfaceName = entityInterfaceName(entity.namespace, entity.name);\n const lines: string[] = [];\n lines.push(GENERATED_BANNER);\n lines.push('');\n lines.push(`export interface ${interfaceName} {`);\n lines.push(' readonly fields: {');\n for (const field of entity.fields) {\n lines.push(indent(formatFieldDescriptor(field), 2));\n }\n lines.push(' };');\n lines.push(` readonly identifier: ${formatIdentifier(entity)};`);\n const relations = sortedRelations(entity);\n if (relations.length === 0) {\n lines.push(' readonly relations: Record<string, never>;');\n } else {\n lines.push(' readonly relations: {');\n for (const [name, relationship] of relations) {\n lines.push(indent(formatRelationDescriptor(name, relationship), 2));\n }\n lines.push(' };');\n }\n lines.push('}');\n lines.push('');\n return lines.join('\\n');\n}\n\nfunction emitIndexFile(model: DataModel): string {\n const namespaces = groupByNamespace(model);\n const sortedNamespaces = [...namespaces.keys()].sort();\n\n const lines: string[] = [];\n lines.push(GENERATED_BANNER);\n lines.push('');\n lines.push(\"import type { ApplySchemaOverrides } from '@biref/scanner';\");\n lines.push(\"import type { Overrides } from './biref.schema.overrides.js';\");\n lines.push('');\n\n const allEntities: { namespace: string; entity: Entity }[] = [];\n for (const namespace of sortedNamespaces) {\n const entities = namespaces.get(namespace);\n if (!entities) {\n continue;\n }\n for (const entity of [...entities].sort((a, b) =>\n a.name.localeCompare(b.name),\n )) {\n allEntities.push({ namespace, entity });\n }\n }\n\n // Imports first, then re-exports, then the schema interface.\n // .js extensions on relative imports are required by Node's ESM\n // resolution (NodeNext / node16) and harmless under Bundler mode.\n for (const { namespace, entity } of allEntities) {\n const iface = entityInterfaceName(namespace, entity.name);\n lines.push(\n `import type { ${iface} } from './${safeSegment(namespace)}/${safeSegment(entity.name)}.js';`,\n );\n }\n lines.push('');\n for (const { namespace, entity } of allEntities) {\n const iface = entityInterfaceName(namespace, entity.name);\n lines.push(\n `export type { ${iface} } from './${safeSegment(namespace)}/${safeSegment(entity.name)}.js';`,\n );\n }\n lines.push('');\n lines.push('export interface RawBirefSchema {');\n for (const namespace of sortedNamespaces) {\n const entities = namespaces.get(namespace);\n if (!entities) {\n continue;\n }\n lines.push(` readonly ${quoteKey(namespace)}: {`);\n const sortedEntities = [...entities].sort((a, b) =>\n a.name.localeCompare(b.name),\n );\n for (const entity of sortedEntities) {\n const iface = entityInterfaceName(namespace, entity.name);\n lines.push(` readonly ${quoteKey(entity.name)}: ${iface};`);\n }\n lines.push(' };');\n }\n lines.push('}');\n lines.push('');\n lines.push(\n 'export type BirefSchema = ApplySchemaOverrides<RawBirefSchema, Overrides>;',\n );\n lines.push('');\n return lines.join('\\n');\n}\n\nfunction groupByNamespace(model: DataModel): Map<string, Entity[]> {\n const map = new Map<string, Entity[]>();\n for (const entity of model.entities) {\n const bucket = map.get(entity.namespace);\n if (bucket) {\n bucket.push(entity);\n } else {\n map.set(entity.namespace, [entity]);\n }\n }\n return map;\n}\n\nfunction sortedRelations(\n entity: Entity,\n): readonly (readonly [string, Relationship])[] {\n return [...buildRelationNameMap(entity).entries()].sort(([a], [b]) =>\n a.localeCompare(b),\n );\n}\n\nfunction formatFieldDescriptor(field: Field): string {\n const ts = tsTypeFor(field.type, field.nullable);\n const nullable = field.nullable ? 'true' : 'false';\n const isIdentifier = field.isIdentifier ? 'true' : 'false';\n const category = `'${field.type.category}'`;\n return ` readonly ${quoteKey(field.name)}: { readonly ts: ${ts}; readonly nullable: ${nullable}; readonly isIdentifier: ${isIdentifier}; readonly category: ${category} };`;\n}\n\nfunction formatIdentifier(entity: Entity): string {\n if (entity.identifier.length === 0) {\n return 'readonly []';\n }\n const items = entity.identifier.map((name) => `'${escapeString(name)}'`);\n return `readonly [${items.join(', ')}]`;\n}\n\nfunction formatRelationDescriptor(\n name: string,\n relationship: Relationship,\n): string {\n const target =\n relationship.direction === 'outbound'\n ? relationship.reference.toEntity\n : relationship.reference.fromEntity;\n const qualifiedTarget = `'${escapeString(target.namespace)}.${escapeString(target.name)}'`;\n const fromFields = formatStringArray(relationship.reference.fromFields);\n const toFields = formatStringArray(relationship.reference.toFields);\n const cardinality =\n relationship.direction === 'outbound' ? \"'one'\" : \"'many'\";\n const direction = `'${relationship.direction}'`;\n return ` readonly ${quoteKey(name)}: { readonly direction: ${direction}; readonly target: ${qualifiedTarget}; readonly fromFields: ${fromFields}; readonly toFields: ${toFields}; readonly cardinality: ${cardinality} };`;\n}\n\nfunction formatStringArray(values: readonly string[]): string {\n if (values.length === 0) {\n return 'readonly []';\n }\n return `readonly [${values.map((v) => `'${escapeString(v)}'`).join(', ')}]`;\n}\n\nfunction quoteKey(key: string): string {\n if (/^[A-Za-z_$][A-Za-z0-9_$]*$/.test(key)) {\n return key;\n }\n return `'${escapeString(key)}'`;\n}\n\nfunction escapeString(value: string): string {\n return value.replace(/\\\\/g, '\\\\\\\\').replace(/'/g, \"\\\\'\");\n}\n\n/**\n * Produce a PascalCase TypeScript identifier from a\n * namespace + entity pair:\n *\n * ('identity', 'users') -> 'IdentityUsers'\n * ('commerce', 'order_items') -> 'CommerceOrderItems'\n */\nfunction entityInterfaceName(namespace: string, entity: string): string {\n return toPascalCase(namespace) + toPascalCase(entity);\n}\n\nfunction toPascalCase(value: string): string {\n return value\n .split(/[^A-Za-z0-9]+/)\n .filter((segment) => segment.length > 0)\n .map(\n (segment) =>\n segment.charAt(0).toUpperCase() + segment.slice(1).toLowerCase(),\n )\n .join('');\n}\n\n/**\n * Sanitize a namespace or entity name for use as a filesystem segment.\n *\n * Replaces anything outside `[A-Za-z0-9_-]` with `_` so identifiers\n * like `weird\"ns` or `mixed case` still produce a valid path.\n */\nfunction safeSegment(name: string): string {\n return name.replace(/[^A-Za-z0-9_-]/g, '_');\n}\n\nfunction indent(text: string, spaces: number): string {\n const pad = ' '.repeat(spaces);\n return text\n .split('\\n')\n .map((line) => (line.length === 0 ? line : `${pad}${line}`))\n .join('\\n');\n}\n","import type { RecordParser } from '@/parsing/RecordParser';\nimport type { Introspector } from '@/ports/Introspector';\nimport type { QueryEngine } from '@/ports/QueryEngine';\nimport type { RawQueryRunner } from '@/ports/RawQueryRunner';\n\n/**\n * Names of the adapters that ship with the SDK.\n *\n * Grows as new adapters are added. Consumers can still register custom\n * adapters with any name; the type accepts arbitrary strings in\n * addition to the known ones (see `AdapterName`).\n */\nexport type KnownAdapterName = 'postgres' | 'mysql';\n\n/**\n * Adapter name type.\n *\n * Known adapter names appear in IDE autocomplete when calling\n * `Biref.scan(...)`, `AdapterRegistry.get(...)`, and similar APIs.\n * Any other string is still accepted so consumers can register\n * adapters the SDK does not know about.\n *\n * Pattern: `KnownAdapterName | (string & {})` preserves literal\n * suggestions while also accepting the broader string type.\n */\nexport type AdapterName = KnownAdapterName | (string & {});\n\n/**\n * An adapter packaged for registration with `Biref` or `AdapterRegistry`.\n *\n * Generic over `TName` so each adapter declares its name as a literal\n * string type. Consumers narrow by comparing `adapter.name` against an\n * exported constant from the adapter module:\n *\n * import { POSTGRES_ADAPTER_NAME } from '@biref/scanner';\n *\n * if (adapter.name === POSTGRES_ADAPTER_NAME) {\n * // adapter is narrowed to Adapter<'postgres'>\n * }\n *\n * Fields:\n * name: literal name of the adapter (e.g. 'postgres')\n * introspector: produces a `DataModel` from the data store\n * engine: turns a `QuerySpec` into a `BuiltQuery`\n * runner: executes a `BuiltQuery` and returns raw rows\n * parser: coerces raw rows into typed `ParsedRecord`s\n * urlSchemes: URL schemes the adapter handles, for auto-detection\n *\n * `runner` and `parser` are optional on the interface so older adapter\n * modules stay source-compatible. The typed query API requires both.\n */\nexport interface Adapter<TName extends AdapterName = AdapterName> {\n readonly name: TName;\n readonly introspector: Introspector;\n readonly engine: QueryEngine;\n readonly runner?: RawQueryRunner;\n readonly parser?: RecordParser;\n readonly urlSchemes?: readonly string[];\n}\n\n/**\n * Registry of `Adapter` instances keyed by name.\n *\n * Looked up by `Biref` and the lower-level facades. Registration is\n * explicit: the SDK has zero runtime dependencies and cannot know\n * which adapters are installed.\n */\nexport class AdapterRegistry {\n private readonly adapters = new Map<string, Adapter>();\n\n register(adapter: Adapter): void {\n if (this.adapters.has(adapter.name)) {\n throw new Error(`Adapter \"${adapter.name}\" is already registered.`);\n }\n this.adapters.set(adapter.name, adapter);\n }\n\n unregister(name: AdapterName): boolean {\n return this.adapters.delete(name);\n }\n\n get(name: AdapterName): Adapter {\n const adapter = this.adapters.get(name);\n if (!adapter) {\n const known = [...this.adapters.keys()].join(', ') || '(none)';\n throw new Error(\n `No adapter registered under \"${name}\". Registered adapters: ${known}.`,\n );\n }\n return adapter;\n }\n\n has(name: AdapterName): boolean {\n return this.adapters.has(name);\n }\n\n list(): readonly string[] {\n return [...this.adapters.keys()];\n }\n\n /**\n * Find an adapter that claims the given URL scheme. Case-insensitive.\n * Returns `undefined` if no adapter handles it.\n */\n findByUrlScheme(scheme: string): Adapter | undefined {\n const normalized = scheme.toLowerCase();\n for (const adapter of this.adapters.values()) {\n const matches = adapter.urlSchemes?.some(\n (s) => s.toLowerCase() === normalized,\n );\n if (matches) {\n return adapter;\n }\n }\n return undefined;\n }\n\n /**\n * Same as `findByUrlScheme` but throws a helpful error listing the\n * known schemes when no match is found.\n */\n getByUrlScheme(scheme: string): Adapter {\n const adapter = this.findByUrlScheme(scheme);\n if (!adapter) {\n const known =\n [...this.adapters.values()]\n .flatMap((a) => a.urlSchemes ?? [])\n .join(', ') || '(none)';\n throw new Error(\n `No adapter registered for URL scheme \"${scheme}\". Known schemes: ${known}.`,\n );\n }\n return adapter;\n }\n}\n","import type { DataModel } from '@/domain/model/DataModel';\nimport type { Filter, QuerySpec } from '@/domain/query/QuerySpec';\nimport type { ParsedRecord, ParsedValue } from '@/parsing/ParsedRecord';\nimport type { RecordParser } from '@/parsing/RecordParser';\nimport type { QueryEngine } from '@/ports/QueryEngine';\nimport type { RawQueryRunner } from '@/ports/RawQueryRunner';\nimport type { QueryInclude, QueryPlan } from '@/query/QueryPlan';\n\n/**\n * Executes a `QueryPlan` tree against an adapter's engine, runner, and\n * parser, stitching include results into nested shapes on the parent.\n *\n * Runs one query per plan node - root first, then one query per\n * include level, filtered to the parent keys it just collected. This\n * matches Prisma's approach: sequential sub-queries with in-process\n * hydration, rather than SQL JOINs. It keeps the engine layer\n * paradigm-neutral and works without any JOIN support in the\n * adapter's `QueryEngine`.\n *\n * Projection honoring: join-key columns are transparently added to\n * both the parent's and each child's SELECT so the stitcher can read\n * them, then removed from the final hydrated records so the caller\n * sees only the columns they originally asked for.\n */\nexport class QueryPlanExecutor {\n constructor(\n private readonly engine: QueryEngine,\n private readonly runner: RawQueryRunner,\n private readonly parser: RecordParser,\n ) {}\n\n async execute(\n plan: QueryPlan,\n model: DataModel,\n ): Promise<readonly ParsedRecord[]> {\n const entity = model.getEntity(plan.spec.namespace, plan.spec.entity);\n if (!entity) {\n throw new Error(\n `Entity \"${plan.spec.namespace}.${plan.spec.entity}\" not found in the data model.`,\n );\n }\n\n const exposedKeys = QueryPlanExecutor.resolveExposedKeys(\n plan.spec,\n entity,\n plan.includes,\n );\n const normalizedSpec = QueryPlanExecutor.injectFields(\n plan.spec,\n QueryPlanExecutor.collectParentKeys(plan.includes),\n );\n\n const built = this.engine.build(normalizedSpec, model);\n const rawRows = await this.runner.run<Record<string, unknown>>(built);\n const parentRecords = this.parser.parseMany(entity, rawRows);\n\n if (plan.includes.length === 0) {\n return QueryPlanExecutor.project(parentRecords, exposedKeys);\n }\n\n return this.attachIncludes(\n parentRecords,\n plan.includes,\n exposedKeys,\n model,\n );\n }\n\n private async attachIncludes(\n parents: readonly ParsedRecord[],\n includes: readonly QueryInclude[],\n parentUserSelect: ReadonlySet<string>,\n model: DataModel,\n ): Promise<readonly ParsedRecord[]> {\n // Mutable working copies preserve every field (including the join\n // keys that were injected into the parent select) across include\n // iterations. Without this, the first include's projection would\n // strip the parent keys that subsequent includes need to stitch.\n // We fold each include's hydrated result onto the working record\n // in-place and only apply the final user projection once at the\n // very end.\n const working: Record<string, ParsedValue>[] = parents.map((p) => ({\n ...p,\n }));\n\n for (const include of includes) {\n const childPlan = QueryPlanExecutor.prepareChildPlan(include, working);\n if (childPlan === null) {\n for (const parent of working) {\n parent[include.relationName] =\n include.cardinality === 'one' ? null : [];\n }\n continue;\n }\n\n const rawChildren = await this.execute(childPlan, model);\n const childExposedKeys = QueryPlanExecutor.resolveChildExposedKeys(\n include.plan,\n model,\n );\n const indexingKeys = new Set(childExposedKeys);\n for (const key of include.childKeys) {\n indexingKeys.add(key);\n }\n const byKey = QueryPlanExecutor.indexByKey(\n rawChildren.map((c) => QueryPlanExecutor.filterKeys(c, indexingKeys)),\n include.childKeys,\n );\n\n for (const parent of working) {\n const lookupKey = QueryPlanExecutor.buildKey(\n parent,\n include.parentKeys,\n );\n const matches = lookupKey === null ? [] : (byKey.get(lookupKey) ?? []);\n const projectedMatches = QueryPlanExecutor.project(\n matches,\n childExposedKeys,\n );\n parent[include.relationName] =\n include.cardinality === 'one'\n ? (projectedMatches[0] ?? null)\n : [...projectedMatches];\n }\n }\n\n // Final projection: now that every include has stitched, strip\n // the injected join keys and any other fields the user did not\n // ask for.\n return working.map((parent) =>\n QueryPlanExecutor.filterKeys(parent, parentUserSelect),\n );\n }\n\n private static prepareChildPlan(\n include: QueryInclude,\n parents: readonly ParsedRecord[],\n ): QueryPlan | null {\n if (parents.length === 0) {\n return null;\n }\n if (include.parentKeys.length === 0 || include.childKeys.length === 0) {\n return null;\n }\n\n // Collect per-column parent key values.\n const collected: unknown[][] = include.parentKeys.map(() => []);\n let anyMatch = false;\n for (const parent of parents) {\n let hasAll = true;\n const tuple: unknown[] = [];\n for (const key of include.parentKeys) {\n const value = parent[key];\n if (value === null || value === undefined) {\n hasAll = false;\n break;\n }\n tuple.push(value);\n }\n if (!hasAll) {\n continue;\n }\n for (let i = 0; i < tuple.length; i += 1) {\n const bucket = collected[i];\n if (bucket) {\n bucket.push(tuple[i]);\n }\n }\n anyMatch = true;\n }\n if (!anyMatch) {\n return null;\n }\n\n // Inject child join keys into the select so the stitcher can read them.\n let plan: QueryPlan = {\n ...include.plan,\n spec: QueryPlanExecutor.injectFields(\n include.plan.spec,\n include.childKeys,\n ),\n };\n\n // Apply one `in` filter per child key column against the distinct\n // parent values we just collected.\n for (let i = 0; i < include.childKeys.length; i += 1) {\n const childKey = include.childKeys[i];\n const bucket = collected[i];\n if (childKey === undefined || bucket === undefined) {\n return null;\n }\n const unique = Array.from(new Set(bucket));\n const filter: Filter = {\n field: childKey,\n operator: 'in',\n value: unique,\n };\n plan = {\n ...plan,\n spec: {\n ...plan.spec,\n filters: [...(plan.spec.filters ?? []), filter],\n },\n };\n }\n return plan;\n }\n\n private static injectFields(\n spec: QuerySpec,\n fields: readonly string[],\n ): QuerySpec {\n if (!spec.select || spec.select.length === 0) {\n // An undefined/empty select already means \"all columns\" - nothing\n // to inject.\n return spec;\n }\n if (fields.length === 0) {\n return spec;\n }\n const seen = new Set(spec.select);\n const extras: string[] = [];\n for (const field of fields) {\n if (!seen.has(field)) {\n seen.add(field);\n extras.push(field);\n }\n }\n if (extras.length === 0) {\n return spec;\n }\n return { ...spec, select: [...spec.select, ...extras] };\n }\n\n private static collectParentKeys(\n includes: readonly QueryInclude[],\n ): readonly string[] {\n const keys: string[] = [];\n for (const include of includes) {\n for (const key of include.parentKeys) {\n keys.push(key);\n }\n }\n return keys;\n }\n\n /**\n * Compute the set of keys a hydrated record should expose to the\n * caller: the user's selected fields (or every entity field when\n * no select was given) plus every nested include's relation name\n * so attached children survive the final filter step.\n */\n private static resolveExposedKeys(\n spec: QuerySpec,\n entity: { readonly fields: readonly { readonly name: string }[] },\n includes: readonly QueryInclude[],\n ): ReadonlySet<string> {\n const set = new Set<string>();\n if (spec.select && spec.select.length > 0) {\n for (const field of spec.select) {\n set.add(field);\n }\n } else {\n for (const field of entity.fields) {\n set.add(field.name);\n }\n }\n for (const include of includes) {\n set.add(include.relationName);\n }\n return set;\n }\n\n /**\n * Resolve the exposed-keys set for an include's nested plan.\n *\n * Uses the ORIGINAL include.plan (not the mutated child plan we\n * handed to the executor) so injected join keys do not leak into\n * the final output.\n */\n private static resolveChildExposedKeys(\n plan: QueryPlan,\n model: DataModel,\n ): ReadonlySet<string> {\n const entity = model.getEntity(plan.spec.namespace, plan.spec.entity);\n if (!entity) {\n return new Set();\n }\n return QueryPlanExecutor.resolveExposedKeys(\n plan.spec,\n entity,\n plan.includes,\n );\n }\n\n private static project(\n records: readonly ParsedRecord[],\n allow: ReadonlySet<string>,\n ): readonly ParsedRecord[] {\n return records.map((record) => QueryPlanExecutor.filterKeys(record, allow));\n }\n\n private static indexByKey(\n records: readonly ParsedRecord[],\n keys: readonly string[],\n ): Map<string, ParsedRecord[]> {\n const map = new Map<string, ParsedRecord[]>();\n for (const record of records) {\n const key = QueryPlanExecutor.buildKey(record, keys);\n if (key === null) {\n continue;\n }\n const bucket = map.get(key);\n if (bucket) {\n bucket.push(record);\n } else {\n map.set(key, [record]);\n }\n }\n return map;\n }\n\n private static buildKey(\n record: ParsedRecord,\n keys: readonly string[],\n ): string | null {\n if (keys.length === 0) {\n return '';\n }\n const parts: unknown[] = [];\n for (const key of keys) {\n const value = record[key];\n if (value === null || value === undefined) {\n return null;\n }\n parts.push(\n typeof value === 'bigint' ? `bigint:${value.toString()}` : value,\n );\n }\n return JSON.stringify(parts);\n }\n\n private static filterKeys(\n record: ParsedRecord,\n allow: ReadonlySet<string>,\n ): ParsedRecord {\n const result: Record<string, ParsedValue> = {};\n for (const [key, value] of Object.entries(record)) {\n if (allow.has(key)) {\n result[key] = value;\n }\n }\n return result;\n }\n}\n","import type { QueryPlanExecutor } from '@/core/QueryPlanExecutor';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type {\n Filter,\n FilterOperator,\n OrderBy,\n QuerySpec,\n} from '@/domain/query/QuerySpec';\nimport type { ParsedRecord } from '@/parsing/ParsedRecord';\nimport type { QueryInclude, QueryPlan } from '@/query/QueryPlan';\nimport { buildRelationNameMap } from '@/query/relationNaming';\n\n/**\n * Runtime context threaded through every `ChainBuilder` instance.\n *\n * Holds the scanned `DataModel` used for validation and the\n * `QueryPlanExecutor` that actually runs terminal methods like\n * `findMany` / `findFirst`.\n */\nexport interface ChainBuilderContext {\n readonly model: DataModel;\n readonly executor: QueryPlanExecutor;\n}\n\n/**\n * Immutable fluent builder that accumulates a `QueryPlan`.\n *\n * Each mutating method (`select`, `where`, `orderBy`, `limit`,\n * `offset`, `include`) returns a **new** `ChainBuilder` - chains are\n * safe to fork.\n *\n * Field and relation names are validated against the `DataModel` at\n * call time so mistakes throw immediately with a clear message.\n * Compile-time typing comes from the generic parameters (see\n * `src/query/types/*`); the runtime implementation here is\n * schema-agnostic.\n */\nexport class ChainBuilder {\n constructor(\n private readonly ctx: ChainBuilderContext,\n private readonly plan: QueryPlan,\n ) {}\n\n /**\n * Narrow the projection to a specific set of fields.\n *\n * .select('id', 'email') -- only these two columns\n * .select('*') -- every field of the entity\n * .select() -- equivalent to '*', kept for ergonomic parity\n *\n * Unknown field names throw immediately with a clear error; the\n * wildcard sentinel skips validation and leaves the plan's `select`\n * undefined so the engine emits every column the adapter reported.\n */\n select(...fields: readonly string[]): ChainBuilder {\n if (fields.length === 0 || fields.some((f) => f === '*')) {\n if (fields.some((f) => f !== '*')) {\n throw new Error(\n \"select('*') cannot be combined with other field names. Pass either '*' or the specific columns you want.\",\n );\n }\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: { ...this.plan.spec, select: undefined },\n });\n }\n const entity = this.requireEntity();\n const known = new Set(entity.fields.map((f) => f.name));\n for (const field of fields) {\n if (!known.has(field)) {\n throw new Error(\n `Field \"${field}\" does not exist on \"${this.plan.spec.namespace}.${this.plan.spec.entity}\".`,\n );\n }\n }\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: { ...this.plan.spec, select: [...fields] },\n });\n }\n\n where(\n field: string,\n operator: FilterOperator,\n value?: unknown,\n ): ChainBuilder {\n const entity = this.requireEntity();\n if (!entity.fields.some((f) => f.name === field)) {\n throw new Error(\n `Filter field \"${field}\" does not exist on \"${this.plan.spec.namespace}.${this.plan.spec.entity}\".`,\n );\n }\n const filter: Filter = {\n field,\n operator,\n value: value ?? null,\n };\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: {\n ...this.plan.spec,\n filters: [...(this.plan.spec.filters ?? []), filter],\n },\n });\n }\n\n orderBy(field: string, direction: 'asc' | 'desc' = 'asc'): ChainBuilder {\n const entity = this.requireEntity();\n if (!entity.fields.some((f) => f.name === field)) {\n throw new Error(\n `Order field \"${field}\" does not exist on \"${this.plan.spec.namespace}.${this.plan.spec.entity}\".`,\n );\n }\n const order: OrderBy = { field, direction };\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: {\n ...this.plan.spec,\n orderBy: [...(this.plan.spec.orderBy ?? []), order],\n },\n });\n }\n\n limit(count: number): ChainBuilder {\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: { ...this.plan.spec, limit: count },\n });\n }\n\n offset(count: number): ChainBuilder {\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n spec: { ...this.plan.spec, offset: count },\n });\n }\n\n /**\n * Attach a nested include to the plan.\n *\n * Three call shapes are supported:\n *\n * .include('orders') -- all fields, no nested\n * .include('orders', (q) => q.select('id', 'total')) -- narrow the child\n * .include('*') -- every relation on this entity\n *\n * The callback is optional. When omitted, the child plan uses the\n * default projection (all fields of the related entity) and no\n * further includes. Pass a callback when you want to narrow the\n * projection or chain additional nested includes.\n *\n * The wildcard `'*'` expands to one include per relation discovered\n * on the current entity. Each expanded include uses the default\n * projection. Combining `'*'` with a callback is not supported -\n * the sub-builder's shape differs per relation, so a single\n * callback cannot narrow all of them coherently.\n */\n include(\n relationName: string,\n build?: (q: ChainBuilder) => ChainBuilder,\n ): ChainBuilder {\n const entity = this.requireEntity();\n const relationMap = buildRelationNameMap(entity);\n\n if (relationName === '*') {\n if (build) {\n throw new Error(\n \"Wildcard include '*' does not accept a builder callback. Use named includes to narrow individual relations.\",\n );\n }\n let current: ChainBuilder = this;\n for (const name of relationMap.keys()) {\n current = current.include(name);\n }\n return current;\n }\n\n const relationship = relationMap.get(relationName);\n if (!relationship) {\n const known = [...relationMap.keys()].join(', ') || '(none)';\n throw new Error(\n `Relation \"${relationName}\" does not exist on \"${this.plan.spec.namespace}.${this.plan.spec.entity}\". Known relations: ${known}.`,\n );\n }\n\n const target =\n relationship.direction === 'outbound'\n ? relationship.reference.toEntity\n : relationship.reference.fromEntity;\n\n const childSpec: QuerySpec = {\n namespace: target.namespace,\n entity: target.name,\n };\n const childBuilder = new ChainBuilder(this.ctx, {\n spec: childSpec,\n includes: [],\n });\n const finishedChild = build ? build(childBuilder) : childBuilder;\n\n const parentKeys =\n relationship.direction === 'outbound'\n ? relationship.reference.fromFields\n : relationship.reference.toFields;\n const childKeys =\n relationship.direction === 'outbound'\n ? relationship.reference.toFields\n : relationship.reference.fromFields;\n\n const include: QueryInclude = {\n relationName,\n plan: finishedChild.plan,\n direction: relationship.direction,\n parentKeys,\n childKeys,\n cardinality: relationship.direction === 'outbound' ? 'one' : 'many',\n };\n\n return new ChainBuilder(this.ctx, {\n ...this.plan,\n includes: [...this.plan.includes, include],\n });\n }\n\n async findMany(): Promise<readonly ParsedRecord[]> {\n return this.ctx.executor.execute(this.plan, this.ctx.model);\n }\n\n async findFirst(): Promise<ParsedRecord | null> {\n const limited: QueryPlan = {\n ...this.plan,\n spec: { ...this.plan.spec, limit: 1 },\n };\n const rows = await this.ctx.executor.execute(limited, this.ctx.model);\n return rows[0] ?? null;\n }\n\n /**\n * Escape hatch for advanced callers (tests, tooling): exposes the\n * accumulated plan without executing it. The typed builder's public\n * surface does not reference this directly.\n */\n toPlan(): QueryPlan {\n return this.plan;\n }\n\n private requireEntity() {\n const entity = this.ctx.model.getEntity(\n this.plan.spec.namespace,\n this.plan.spec.entity,\n );\n if (!entity) {\n throw new Error(\n `Entity \"${this.plan.spec.namespace}.${this.plan.spec.entity}\" not found in the data model.`,\n );\n }\n return entity;\n }\n}\n","import type { DataModel } from '@/domain/model/DataModel';\nimport { ChainBuilder, type ChainBuilderContext } from '@/query/ChainBuilder';\n\n/**\n * Two-layer Proxy surface for `biref.query(model)`:\n *\n * root[namespace][entity] -> fresh ChainBuilder\n *\n * Property access on the root returns an entity proxy bound to the\n * given namespace. Property access on the entity proxy returns a\n * zero-state `ChainBuilder` targeting that entity.\n *\n * Both layers answer `ownKeys` / `has` / `getOwnPropertyDescriptor`\n * from the scanned `DataModel`, so `Object.keys(root)` and\n * `Object.keys(root.public)` reflect what's actually in the database.\n */\nexport function createNamespaceProxy(\n ctx: ChainBuilderContext,\n): Record<string, Record<string, ChainBuilder>> {\n const namespaces = collectNamespaces(ctx.model);\n\n return new Proxy(Object.create(null) as Record<string, unknown>, {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n if (!namespaces.has(prop)) {\n return undefined;\n }\n return createEntityProxy(ctx, prop);\n },\n has(_target, prop) {\n return typeof prop === 'string' && namespaces.has(prop);\n },\n ownKeys() {\n return [...namespaces];\n },\n getOwnPropertyDescriptor(_target, prop) {\n if (typeof prop !== 'string' || !namespaces.has(prop)) {\n return undefined;\n }\n return {\n enumerable: true,\n configurable: true,\n value: createEntityProxy(ctx, prop),\n };\n },\n }) as Record<string, Record<string, ChainBuilder>>;\n}\n\nfunction createEntityProxy(\n ctx: ChainBuilderContext,\n namespace: string,\n): Record<string, ChainBuilder> {\n const entities = collectEntities(ctx.model, namespace);\n\n return new Proxy(Object.create(null) as Record<string, unknown>, {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n if (!entities.has(prop)) {\n return undefined;\n }\n return new ChainBuilder(ctx, {\n spec: { namespace, entity: prop },\n includes: [],\n });\n },\n has(_target, prop) {\n return typeof prop === 'string' && entities.has(prop);\n },\n ownKeys() {\n return [...entities];\n },\n getOwnPropertyDescriptor(_target, prop) {\n if (typeof prop !== 'string' || !entities.has(prop)) {\n return undefined;\n }\n return {\n enumerable: true,\n configurable: true,\n value: new ChainBuilder(ctx, {\n spec: { namespace, entity: prop },\n includes: [],\n }),\n };\n },\n }) as Record<string, ChainBuilder>;\n}\n\nfunction collectNamespaces(model: DataModel): ReadonlySet<string> {\n const namespaces = new Set<string>();\n for (const entity of model.entities) {\n namespaces.add(entity.namespace);\n }\n return namespaces;\n}\n\nfunction collectEntities(\n model: DataModel,\n namespace: string,\n): ReadonlySet<string> {\n const entities = new Set<string>();\n for (const entity of model.entities) {\n if (entity.namespace === namespace) {\n entities.add(entity.name);\n }\n }\n return entities;\n}\n","import type { Adapter, AdapterName } from '@/core/AdapterRegistry';\nimport { AdapterRegistry } from '@/core/AdapterRegistry';\nimport { QueryPlanExecutor } from '@/core/QueryPlanExecutor';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { IntrospectOptions } from '@/ports/Introspector';\nimport type { ChainBuilder } from '@/query/ChainBuilder';\nimport { createNamespaceProxy } from '@/query/NamespaceProxy';\nimport type { BirefSchemaShape } from '@/query/types/Schema';\nimport type { TypedQueryRoot } from '@/query/types/TypedChain';\n\n/**\n * Top-level facade for the SDK.\n *\n * Wraps a configured `AdapterRegistry` and exposes scanning and the\n * typed query builder. The API is ergonomic for the common case of a\n * single registered adapter and still supports multi-adapter\n * scenarios via explicit names or URL scheme detection.\n *\n * @example\n * ```ts\n * const biref = Biref.builder()\n * .withAdapter(somePostgresAdapter)\n * .build();\n * const model = await biref.scan();\n * const rows = await biref.query(model).public.users.findMany();\n * ```\n */\nexport class Biref {\n constructor(private readonly registry: AdapterRegistry) {}\n\n /** Entry point for the fluent builder. */\n static builder(): BirefBuilder {\n return new BirefBuilder();\n }\n\n /**\n * Introspect a data store. With a single registered adapter, no\n * arguments are needed. Pass `IntrospectOptions` to customize the\n * scan, or an adapter name when more than one adapter is registered.\n */\n scan(): Promise<DataModel>;\n scan(options: IntrospectOptions): Promise<DataModel>;\n scan(\n adapterName: AdapterName,\n options?: IntrospectOptions,\n ): Promise<DataModel>;\n async scan(\n adapterNameOrOptions?: AdapterName | IntrospectOptions,\n maybeOptions?: IntrospectOptions,\n ): Promise<DataModel> {\n const { adapter, options } = this.resolveScanArgs(\n adapterNameOrOptions,\n maybeOptions,\n );\n return adapter.introspector.introspect(options);\n }\n\n /**\n * Introspect a data store using whichever registered adapter handles\n * the URL's scheme. The URL is only used to pick the adapter; the\n * actual connection is still owned by the client the user passed to\n * the adapter at construction time.\n */\n async scanByUrl(\n url: string,\n options?: IntrospectOptions,\n ): Promise<DataModel> {\n const scheme = parseUrlScheme(url);\n return this.registry\n .getByUrlScheme(scheme)\n .introspector.introspect(options);\n }\n\n /**\n * Typed query entry point. Returns a namespace-level Proxy over the\n * given `DataModel`:\n *\n * biref.query(model).public.users\n * .select('id', 'email')\n * .where('active', 'eq', true)\n * .include('orders', (q) => q.select('id', 'total'))\n * .findMany();\n *\n * The Proxy layers (`namespace` → `entity`) enumerate what's\n * actually in the scanned model, so `Object.keys(biref.query(model))`\n * returns the discovered namespaces. Access to a non-existent\n * namespace or entity returns `undefined`; the chain methods throw\n * with a clear error when given unknown fields or relations.\n *\n * With a single registered adapter, the adapter is picked\n * automatically. Pass `adapterName` explicitly to target a specific\n * adapter when more than one is registered.\n */\n query<Schema extends BirefSchemaShape = never>(\n model: DataModel,\n adapterName?: AdapterName,\n ): [Schema] extends [never] ? UntypedQueryRoot : TypedQueryRoot<Schema> {\n const adapter = adapterName\n ? this.registry.get(adapterName)\n : this.requireSingleAdapter('query');\n const executor = this.executorFor(adapter);\n const proxy = createNamespaceProxy({ model, executor });\n return proxy as [Schema] extends [never]\n ? UntypedQueryRoot\n : TypedQueryRoot<Schema>;\n }\n\n /** Direct access to the underlying registry. */\n get adapters(): AdapterRegistry {\n return this.registry;\n }\n\n private executorFor(adapter: Adapter): QueryPlanExecutor {\n if (!adapter.runner) {\n throw new Error(\n `Adapter \"${adapter.name}\" does not expose a RawQueryRunner. Update the adapter factory to attach one before calling biref.query(...).`,\n );\n }\n if (!adapter.parser) {\n throw new Error(\n `Adapter \"${adapter.name}\" does not expose a RecordParser. Update the adapter factory to attach one before calling biref.query(...).`,\n );\n }\n return new QueryPlanExecutor(\n adapter.engine,\n adapter.runner,\n adapter.parser,\n );\n }\n\n private resolveScanArgs(\n adapterNameOrOptions: AdapterName | IntrospectOptions | undefined,\n maybeOptions: IntrospectOptions | undefined,\n ): { adapter: Adapter; options: IntrospectOptions | undefined } {\n if (typeof adapterNameOrOptions === 'string') {\n return {\n adapter: this.registry.get(adapterNameOrOptions),\n options: maybeOptions,\n };\n }\n return {\n adapter: this.requireSingleAdapter('scan'),\n options: adapterNameOrOptions,\n };\n }\n\n private requireSingleAdapter(operation: string): Adapter {\n const names = this.registry.list();\n if (names.length === 0) {\n throw new Error(\n `Biref.${operation}() called with no adapter argument, but no adapters are registered. Register one via Biref.builder().withAdapter(...).`,\n );\n }\n if (names.length > 1) {\n throw new Error(\n `Biref.${operation}() called with no adapter argument, but multiple adapters are registered (${names.join(', ')}). Pass an adapter name explicitly.`,\n );\n }\n const onlyName = names[0];\n if (onlyName === undefined) {\n throw new Error(\n 'Internal error: adapter list reported a length of 1 but produced no name.',\n );\n }\n return this.registry.get(onlyName);\n }\n}\n\n/**\n * Fallback return type for `biref.query(model)` when called without a\n * schema generic. Degrades to a two-layer record of dynamic\n * `ChainBuilder`s so chains still work at runtime - callers just\n * don't get the narrowed compile-time shapes.\n */\nexport type UntypedQueryRoot = Readonly<\n Record<string, Readonly<Record<string, ChainBuilder>>>\n>;\n\n/**\n * Fluent builder for `Biref`. Collects adapters and produces a wired\n * `Biref` facade. Call `build()` once and discard the builder.\n */\nexport class BirefBuilder {\n private readonly pending: Adapter[] = [];\n\n /**\n * Register an adapter. The adapter's `name` is used as the lookup\n * key when calling `Biref.scan(name)`. Its optional `urlSchemes` are\n * used by `Biref.scanByUrl(url)`.\n */\n withAdapter(adapter: Adapter): this {\n this.pending.push(adapter);\n return this;\n }\n\n /** Convenience for registering multiple adapters in one call. */\n withAdapters(...adapters: readonly Adapter[]): this {\n for (const adapter of adapters) {\n this.pending.push(adapter);\n }\n return this;\n }\n\n /**\n * Materialize the builder into a `Biref` facade. Throws if any\n * adapter has a duplicate name.\n */\n build(): Biref {\n const registry = new AdapterRegistry();\n for (const adapter of this.pending) {\n registry.register(adapter);\n }\n return new Biref(registry);\n }\n}\n\n/**\n * Extract the scheme from a URL string.\n *\n * Supports the standard URI scheme grammar (RFC 3986): a letter\n * followed by letters, digits, or `+`, `.`, `-`.\n *\n * \"postgres://...\" -> \"postgres\"\n * \"postgresql://...\" -> \"postgresql\"\n * \"mongodb+srv://...\" -> \"mongodb+srv\"\n */\nfunction parseUrlScheme(url: string): string {\n const match = /^([a-zA-Z][a-zA-Z0-9+.-]*):/.exec(url);\n if (!match?.[1]) {\n throw new Error(`Cannot determine driver scheme from URL: \"${url}\"`);\n }\n return match[1].toLowerCase();\n}\n","import type { AdapterRegistry } from '@/core/AdapterRegistry';\nimport type { DataModel } from '@/domain/model/DataModel';\nimport type { IntrospectOptions } from '@/ports/Introspector';\n\n/**\n * Public facade for introspection.\n *\n * Takes an `AdapterRegistry`, looks up an adapter by name, and runs\n * its introspector to produce a `DataModel`. Used for low-level\n * scenarios where `Biref` is too high-level; most consumers should\n * prefer `Biref` instead.\n *\n * @example\n * ```ts\n * const registry = new AdapterRegistry();\n * registry.register(somePostgresAdapter);\n * const scanner = new Scanner(registry);\n * const model = await scanner.scan('postgres');\n * ```\n */\nexport class Scanner {\n constructor(private readonly registry: AdapterRegistry) {}\n\n /**\n * Scan a data store using the named adapter and return a paradigm-\n * neutral `DataModel`.\n */\n async scan(\n adapterName: string,\n options?: IntrospectOptions,\n ): Promise<DataModel> {\n return this.registry.get(adapterName).introspector.introspect(options);\n }\n}\n","import type { Formatter, SerializeOptions } from '@/output/Formatter';\nimport type { ParsedRecord, ParsedValue } from '@/parsing/ParsedRecord';\n\nexport interface CsvFormatterOptions {\n /** Delimiter character. Defaults to ','. */\n readonly delimiter?: string;\n /** Whether to emit a header row. Defaults to true. */\n readonly includeHeader?: boolean;\n /** Line terminator. Defaults to '\\n'. */\n readonly lineTerminator?: string;\n}\n\n/**\n * Serializes parsed records to a CSV string.\n *\n * Field order:\n * 1. `options.fields` from the call site, if provided\n * 2. The keys of the first record, otherwise\n * 3. Empty string when there are no records\n *\n * Escaping follows RFC 4180: cells containing the delimiter, double\n * quotes, or newlines are wrapped in double quotes, with internal double\n * quotes doubled.\n *\n * Non-string cell values are coerced as follows:\n * - `Date` → ISO 8601 string\n * - `bigint` → decimal string\n * - object/array → JSON-encoded string\n * - `null` / `undefined` → empty cell\n */\nexport class CsvFormatter implements Formatter<string> {\n readonly format = 'csv';\n readonly contentType = 'text/csv';\n\n constructor(private readonly options: CsvFormatterOptions = {}) {}\n\n serialize(\n records: readonly ParsedRecord[],\n options?: SerializeOptions,\n ): string {\n const delimiter = this.options.delimiter ?? ',';\n const lineTerminator = this.options.lineTerminator ?? '\\n';\n const includeHeader = this.options.includeHeader ?? true;\n\n const fields = this.resolveFields(records, options);\n if (fields.length === 0) {\n return '';\n }\n\n const lines: string[] = [];\n\n if (includeHeader) {\n lines.push(fields.map((f) => this.escape(f, delimiter)).join(delimiter));\n }\n\n for (const record of records) {\n const cells = fields.map((field) =>\n this.serializeCell(record[field], delimiter),\n );\n lines.push(cells.join(delimiter));\n }\n\n return lines.join(lineTerminator);\n }\n\n private resolveFields(\n records: readonly ParsedRecord[],\n options: SerializeOptions | undefined,\n ): readonly string[] {\n if (options?.fields && options.fields.length > 0) {\n return options.fields;\n }\n const first = records[0];\n return first ? Object.keys(first) : [];\n }\n\n private serializeCell(\n value: ParsedValue | undefined,\n delimiter: string,\n ): string {\n if (value === null || value === undefined) {\n return '';\n }\n if (value instanceof Date) {\n return this.escape(value.toISOString(), delimiter);\n }\n if (typeof value === 'bigint') {\n return this.escape(value.toString(), delimiter);\n }\n if (typeof value === 'object') {\n return this.escape(JSON.stringify(value), delimiter);\n }\n return this.escape(String(value), delimiter);\n }\n\n private escape(value: string, delimiter: string): string {\n if (\n value.includes(delimiter) ||\n value.includes('\"') ||\n value.includes('\\n') ||\n value.includes('\\r')\n ) {\n return `\"${value.replace(/\"/g, '\"\"')}\"`;\n }\n return value;\n }\n}\n","import type { Formatter } from '@/output/Formatter';\nimport type { ParsedRecord } from '@/parsing/ParsedRecord';\n\nexport interface JsonFormatterOptions {\n /** Indent the output with 2 spaces if true. Defaults to false. */\n readonly pretty?: boolean;\n}\n\n/**\n * Serializes parsed records to a JSON array string.\n *\n * Handles values that `JSON.stringify` does not natively support:\n * - `Date` → ISO 8601 string\n * - `bigint` → decimal string\n */\nexport class JsonFormatter implements Formatter<string> {\n readonly format = 'json';\n readonly contentType = 'application/json';\n\n constructor(private readonly options: JsonFormatterOptions = {}) {}\n\n serialize(records: readonly ParsedRecord[]): string {\n const indent = this.options.pretty ? 2 : undefined;\n return JSON.stringify(records, JsonFormatter.replacer, indent);\n }\n\n private static replacer(_key: string, value: unknown): unknown {\n if (value instanceof Date) {\n return value.toISOString();\n }\n if (typeof value === 'bigint') {\n return value.toString();\n }\n return value;\n }\n}\n","import type { Formatter } from '@/output/Formatter';\nimport type { ParsedRecord } from '@/parsing/ParsedRecord';\n\n/**\n * \"Raw\" formatter: returns the parsed records as-is, without\n * serialization. Useful when the consumer wants to keep working with\n * native JS values (e.g. piping into another JS function) instead of\n * converting to a string format.\n *\n * Unlike the other built-in formatters, this one's `TOutput` is the\n * record array itself rather than a string. The `Formatter` interface\n * is generic precisely so this case fits without special-casing.\n */\nexport class RawFormatter implements Formatter<readonly ParsedRecord[]> {\n readonly format = 'raw';\n readonly contentType = 'application/javascript';\n\n serialize(records: readonly ParsedRecord[]): readonly ParsedRecord[] {\n return records;\n }\n}\n"]}