@biref/scanner 0.0.2 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/codegen/cli.js.map +1 -1
- package/dist/index.cjs +1124 -157
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +205 -63
- package/dist/index.d.ts +205 -63
- package/dist/index.js +1118 -158
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/codegen/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../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/domain/model/DataModel.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/PostgresRawQueryRunner.ts","../../src/parsing/DefaultRecordParser.ts","../../src/adapters/postgres/PostgresRecordParser.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/codegen/cli.ts"],"names":["candidate"],"mappings":"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","file":"cli.js","sourcesContent":["/**\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 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 { 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 { 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 { 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(['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 { 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';\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 { existsSync } from 'node:fs';\nimport { mkdir, writeFile } from 'node:fs/promises';\nimport { dirname, resolve } from 'node:path';\nimport { parseArgs } from 'node:util';\nimport { postgresAdapter } from '@/adapters/postgres/postgresAdapter';\nimport { overridesScaffold } from '@/codegen/OverridesScaffold';\nimport {\n generateSchema,\n generateSchemaFiles,\n type SchemaFile,\n} from '@/codegen/SchemaEmitter';\nimport { Biref } from '@/core/Biref';\nimport type { DataModel } from '@/domain/model/DataModel';\n\n/**\n * Arguments accepted by the `biref` CLI.\n */\nexport interface GenOptions {\n readonly url?: string;\n readonly out?: string;\n readonly adapter?: string;\n readonly namespaces?: readonly string[] | 'all';\n /** When true, emit per-entity files + an index instead of a single file. */\n readonly split?: boolean;\n /**\n * When true, regenerating overwrites any generated files already on\n * disk (the overrides file is still preserved). When false, runGen\n * errors if any generated target file already exists - useful for\n * CI checks that want to catch out-of-date schemas.\n */\n readonly overwrite?: boolean;\n}\n\nexport interface GenerateFromUrlDeps {\n readonly readSchemaFromUrl: (\n url: string,\n options: ResolvedIntrospectOptions,\n ) => Promise<DataModel>;\n readonly writeFile: (path: string, content: string) => Promise<void>;\n readonly fileExists: (path: string) => boolean;\n readonly log: (message: string) => void;\n}\n\nexport interface ResolvedIntrospectOptions {\n readonly namespaces?: readonly string[] | 'all';\n}\n\n/**\n * Run the `gen` subcommand programmatically.\n *\n * Effects are injected via `deps` so tests can assert on writes and\n * logs without touching the filesystem or opening a real connection.\n */\nexport async function runGen(\n options: GenOptions,\n deps: GenerateFromUrlDeps,\n): Promise<void> {\n if (!options.url) {\n throw new Error(\n 'biref gen: --url is required (for example --url postgres://user:pass@host/db).',\n );\n }\n\n const overwrite = options.overwrite !== false;\n const model = await deps.readSchemaFromUrl(options.url, {\n namespaces: options.namespaces,\n });\n\n if (options.split) {\n await writeSplitOutput(model, options.out, overwrite, deps);\n } else {\n await writeSingleOutput(model, options.out, overwrite, deps);\n }\n}\n\nasync function writeSingleOutput(\n model: DataModel,\n outArg: string | undefined,\n overwrite: boolean,\n deps: GenerateFromUrlDeps,\n): Promise<void> {\n const outPath = resolve(outArg ?? './biref/biref.schema.ts');\n const overridesPath = resolve(dirname(outPath), 'biref.schema.overrides.ts');\n\n if (!overwrite && deps.fileExists(outPath)) {\n throw new Error(\n `biref gen: refusing to overwrite ${outPath} (run with --overwrite to replace).`,\n );\n }\n\n const schema = generateSchema(model);\n await deps.writeFile(outPath, schema);\n deps.log(`biref gen: wrote ${outPath}`);\n\n if (deps.fileExists(overridesPath)) {\n deps.log(\n `biref gen: skipped ${overridesPath} (already exists, edits preserved)`,\n );\n } else {\n await deps.writeFile(overridesPath, overridesScaffold());\n deps.log(`biref gen: wrote ${overridesPath} (scaffold)`);\n }\n}\n\nasync function writeSplitOutput(\n model: DataModel,\n outArg: string | undefined,\n overwrite: boolean,\n deps: GenerateFromUrlDeps,\n): Promise<void> {\n const outDir = resolve(outArg ?? './biref');\n const files = generateSchemaFiles(model);\n\n if (!overwrite) {\n for (const file of files) {\n const absolute = resolve(outDir, file.path);\n if (deps.fileExists(absolute)) {\n throw new Error(\n `biref gen: refusing to overwrite ${absolute} (run with --overwrite to replace).`,\n );\n }\n }\n }\n\n for (const file of files) {\n const absolute = resolve(outDir, file.path);\n await deps.writeFile(absolute, file.content);\n deps.log(`biref gen: wrote ${absolute}`);\n }\n\n const overridesPath = resolve(outDir, 'biref.schema.overrides.ts');\n if (deps.fileExists(overridesPath)) {\n deps.log(\n `biref gen: skipped ${overridesPath} (already exists, edits preserved)`,\n );\n } else {\n await deps.writeFile(overridesPath, overridesScaffold());\n deps.log(`biref gen: wrote ${overridesPath} (scaffold)`);\n }\n}\n\n/**\n * Parse raw `process.argv` into `GenOptions`.\n *\n * Exported for testing: pass a fake argv to assert parsing\n * independently of process state.\n */\nexport function parseCliArgs(argv: readonly string[]): {\n command: 'gen';\n options: GenOptions;\n} {\n const [command, ...rest] = argv;\n if (command !== 'gen') {\n throw new Error(`biref: unknown command \"${command ?? ''}\". Expected: gen`);\n }\n const { values } = parseArgs({\n args: [...rest],\n options: {\n url: { type: 'string' },\n out: { type: 'string' },\n adapter: { type: 'string' },\n namespace: { type: 'string', multiple: true },\n 'all-namespaces': { type: 'boolean' },\n split: { type: 'boolean' },\n overwrite: { type: 'boolean' },\n 'no-overwrite': { type: 'boolean' },\n },\n strict: true,\n allowPositionals: false,\n });\n\n const namespacesFlag = values['all-namespaces'];\n const namespaceList = values.namespace;\n if (namespacesFlag && namespaceList && namespaceList.length > 0) {\n throw new Error(\n 'biref gen: --all-namespaces cannot be combined with --namespace; pick one.',\n );\n }\n const namespaces: readonly string[] | 'all' | undefined = namespacesFlag\n ? 'all'\n : namespaceList;\n\n const overwrite =\n values['no-overwrite'] === true\n ? false\n : values.overwrite === true\n ? true\n : undefined;\n\n return {\n command: 'gen',\n options: {\n url: values.url,\n out: values.out,\n adapter: values.adapter,\n namespaces,\n split: values.split === true ? true : undefined,\n overwrite,\n },\n };\n}\n\n/**\n * Default dependency wiring for the CLI: dynamically imports `pg`\n * (so the SDK itself has no runtime dep on it), opens a client with\n * the given URL, scans via the Postgres adapter, and hands the model\n * to `runGen`.\n */\nexport function defaultDeps(): GenerateFromUrlDeps {\n return {\n async readSchemaFromUrl(url, resolved) {\n const pgModule = (await import('pg')) as unknown as {\n default: {\n Client: new (config: {\n connectionString: string;\n }) => {\n connect(): Promise<void>;\n end(): Promise<void>;\n query<TRow = unknown>(\n text: string,\n params?: readonly unknown[],\n ): Promise<{ rows: TRow[] }>;\n };\n };\n };\n const client = new pgModule.default.Client({ connectionString: url });\n await client.connect();\n try {\n const biref = Biref.builder()\n .withAdapter(postgresAdapter.create(client))\n .build();\n if (resolved.namespaces !== undefined) {\n return await biref.scan({ namespaces: resolved.namespaces });\n }\n return await biref.scan();\n } finally {\n await client.end();\n }\n },\n async writeFile(path, content) {\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, content, 'utf8');\n },\n fileExists(path) {\n return existsSync(path);\n },\n log(message) {\n // eslint-disable-next-line no-console\n console.log(message);\n },\n };\n}\n\n/**\n * CLI entry point. Reads `process.argv.slice(2)`, parses, runs the\n * matching command with the default dependency bundle.\n */\nexport async function main(argv: readonly string[]): Promise<void> {\n const parsed = parseCliArgs(argv);\n if (parsed.command === 'gen') {\n await runGen(parsed.options, defaultDeps());\n }\n}\n\n/**\n * Split the `SchemaFile` list produced by `generateSchemaFiles` into\n * an object keyed by relative path. Handy for tests and tooling that\n * want to assert on specific generated files without iterating.\n */\nexport function indexSchemaFiles(\n files: readonly SchemaFile[],\n): Record<string, string> {\n const out: Record<string, string> = {};\n for (const file of files) {\n out[file.path] = file.content;\n }\n return out;\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../../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/domain/model/DataModel.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/PostgresRawQueryRunner.ts","../../src/parsing/DefaultRecordParser.ts","../../src/adapters/postgres/PostgresRecordParser.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/codegen/cli.ts"],"names":["candidate"],"mappings":"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","file":"cli.js","sourcesContent":["/**\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 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 { 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 { 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 { 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(['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 { 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 { existsSync } from 'node:fs';\nimport { mkdir, writeFile } from 'node:fs/promises';\nimport { dirname, resolve } from 'node:path';\nimport { parseArgs } from 'node:util';\nimport { postgresAdapter } from '@/adapters/postgres/postgresAdapter';\nimport { overridesScaffold } from '@/codegen/OverridesScaffold';\nimport {\n generateSchema,\n generateSchemaFiles,\n type SchemaFile,\n} from '@/codegen/SchemaEmitter';\nimport { Biref } from '@/core/Biref';\nimport type { DataModel } from '@/domain/model/DataModel';\n\n/**\n * Arguments accepted by the `biref` CLI.\n */\nexport interface GenOptions {\n readonly url?: string;\n readonly out?: string;\n readonly adapter?: string;\n readonly namespaces?: readonly string[] | 'all';\n /** When true, emit per-entity files + an index instead of a single file. */\n readonly split?: boolean;\n /**\n * When true, regenerating overwrites any generated files already on\n * disk (the overrides file is still preserved). When false, runGen\n * errors if any generated target file already exists - useful for\n * CI checks that want to catch out-of-date schemas.\n */\n readonly overwrite?: boolean;\n}\n\nexport interface GenerateFromUrlDeps {\n readonly readSchemaFromUrl: (\n url: string,\n options: ResolvedIntrospectOptions,\n ) => Promise<DataModel>;\n readonly writeFile: (path: string, content: string) => Promise<void>;\n readonly fileExists: (path: string) => boolean;\n readonly log: (message: string) => void;\n}\n\nexport interface ResolvedIntrospectOptions {\n readonly namespaces?: readonly string[] | 'all';\n}\n\n/**\n * Run the `gen` subcommand programmatically.\n *\n * Effects are injected via `deps` so tests can assert on writes and\n * logs without touching the filesystem or opening a real connection.\n */\nexport async function runGen(\n options: GenOptions,\n deps: GenerateFromUrlDeps,\n): Promise<void> {\n if (!options.url) {\n throw new Error(\n 'biref gen: --url is required (for example --url postgres://user:pass@host/db).',\n );\n }\n\n const overwrite = options.overwrite !== false;\n const model = await deps.readSchemaFromUrl(options.url, {\n namespaces: options.namespaces,\n });\n\n if (options.split) {\n await writeSplitOutput(model, options.out, overwrite, deps);\n } else {\n await writeSingleOutput(model, options.out, overwrite, deps);\n }\n}\n\nasync function writeSingleOutput(\n model: DataModel,\n outArg: string | undefined,\n overwrite: boolean,\n deps: GenerateFromUrlDeps,\n): Promise<void> {\n const outPath = resolve(outArg ?? './biref/biref.schema.ts');\n const overridesPath = resolve(dirname(outPath), 'biref.schema.overrides.ts');\n\n if (!overwrite && deps.fileExists(outPath)) {\n throw new Error(\n `biref gen: refusing to overwrite ${outPath} (run with --overwrite to replace).`,\n );\n }\n\n const schema = generateSchema(model);\n await deps.writeFile(outPath, schema);\n deps.log(`biref gen: wrote ${outPath}`);\n\n if (deps.fileExists(overridesPath)) {\n deps.log(\n `biref gen: skipped ${overridesPath} (already exists, edits preserved)`,\n );\n } else {\n await deps.writeFile(overridesPath, overridesScaffold());\n deps.log(`biref gen: wrote ${overridesPath} (scaffold)`);\n }\n}\n\nasync function writeSplitOutput(\n model: DataModel,\n outArg: string | undefined,\n overwrite: boolean,\n deps: GenerateFromUrlDeps,\n): Promise<void> {\n const outDir = resolve(outArg ?? './biref');\n const files = generateSchemaFiles(model);\n\n if (!overwrite) {\n for (const file of files) {\n const absolute = resolve(outDir, file.path);\n if (deps.fileExists(absolute)) {\n throw new Error(\n `biref gen: refusing to overwrite ${absolute} (run with --overwrite to replace).`,\n );\n }\n }\n }\n\n for (const file of files) {\n const absolute = resolve(outDir, file.path);\n await deps.writeFile(absolute, file.content);\n deps.log(`biref gen: wrote ${absolute}`);\n }\n\n const overridesPath = resolve(outDir, 'biref.schema.overrides.ts');\n if (deps.fileExists(overridesPath)) {\n deps.log(\n `biref gen: skipped ${overridesPath} (already exists, edits preserved)`,\n );\n } else {\n await deps.writeFile(overridesPath, overridesScaffold());\n deps.log(`biref gen: wrote ${overridesPath} (scaffold)`);\n }\n}\n\n/**\n * Parse raw `process.argv` into `GenOptions`.\n *\n * Exported for testing: pass a fake argv to assert parsing\n * independently of process state.\n */\nexport function parseCliArgs(argv: readonly string[]): {\n command: 'gen';\n options: GenOptions;\n} {\n const [command, ...rest] = argv;\n if (command !== 'gen') {\n throw new Error(`biref: unknown command \"${command ?? ''}\". Expected: gen`);\n }\n const { values } = parseArgs({\n args: [...rest],\n options: {\n url: { type: 'string' },\n out: { type: 'string' },\n adapter: { type: 'string' },\n namespace: { type: 'string', multiple: true },\n 'all-namespaces': { type: 'boolean' },\n split: { type: 'boolean' },\n overwrite: { type: 'boolean' },\n 'no-overwrite': { type: 'boolean' },\n },\n strict: true,\n allowPositionals: false,\n });\n\n const namespacesFlag = values['all-namespaces'];\n const namespaceList = values.namespace;\n if (namespacesFlag && namespaceList && namespaceList.length > 0) {\n throw new Error(\n 'biref gen: --all-namespaces cannot be combined with --namespace; pick one.',\n );\n }\n const namespaces: readonly string[] | 'all' | undefined = namespacesFlag\n ? 'all'\n : namespaceList;\n\n const overwrite =\n values['no-overwrite'] === true\n ? false\n : values.overwrite === true\n ? true\n : undefined;\n\n return {\n command: 'gen',\n options: {\n url: values.url,\n out: values.out,\n adapter: values.adapter,\n namespaces,\n split: values.split === true ? true : undefined,\n overwrite,\n },\n };\n}\n\n/**\n * Default dependency wiring for the CLI: dynamically imports `pg`\n * (so the SDK itself has no runtime dep on it), opens a client with\n * the given URL, scans via the Postgres adapter, and hands the model\n * to `runGen`.\n */\nexport function defaultDeps(): GenerateFromUrlDeps {\n return {\n async readSchemaFromUrl(url, resolved) {\n const pgModule = (await import('pg')) as unknown as {\n default: {\n Client: new (config: {\n connectionString: string;\n }) => {\n connect(): Promise<void>;\n end(): Promise<void>;\n query<TRow = unknown>(\n text: string,\n params?: readonly unknown[],\n ): Promise<{ rows: TRow[] }>;\n };\n };\n };\n const client = new pgModule.default.Client({ connectionString: url });\n await client.connect();\n try {\n const biref = Biref.builder()\n .withAdapter(postgresAdapter.create(client))\n .build();\n if (resolved.namespaces !== undefined) {\n return await biref.scan({ namespaces: resolved.namespaces });\n }\n return await biref.scan();\n } finally {\n await client.end();\n }\n },\n async writeFile(path, content) {\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, content, 'utf8');\n },\n fileExists(path) {\n return existsSync(path);\n },\n log(message) {\n // eslint-disable-next-line no-console\n console.log(message);\n },\n };\n}\n\n/**\n * CLI entry point. Reads `process.argv.slice(2)`, parses, runs the\n * matching command with the default dependency bundle.\n */\nexport async function main(argv: readonly string[]): Promise<void> {\n const parsed = parseCliArgs(argv);\n if (parsed.command === 'gen') {\n await runGen(parsed.options, defaultDeps());\n }\n}\n\n/**\n * Split the `SchemaFile` list produced by `generateSchemaFiles` into\n * an object keyed by relative path. Handy for tests and tooling that\n * want to assert on specific generated files without iterating.\n */\nexport function indexSchemaFiles(\n files: readonly SchemaFile[],\n): Record<string, string> {\n const out: Record<string, string> = {};\n for (const file of files) {\n out[file.path] = file.content;\n }\n return out;\n}\n"]}
|