@zeronsh/orbit 0.1.0 → 0.3.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/{chunk-N2NAKHMU.js → chunk-EX4WSUC3.js} +41 -13
- package/dist/chunk-EX4WSUC3.js.map +1 -0
- package/dist/{chunk-7CMFTRDQ.js → chunk-G6NWZNQR.js} +3 -3
- package/dist/{chunk-7CMFTRDQ.js.map → chunk-G6NWZNQR.js.map} +1 -1
- package/dist/{chunk-QR3NSGHJ.js → chunk-PSGVTMOB.js} +3 -3
- package/dist/{chunk-QR3NSGHJ.js.map → chunk-PSGVTMOB.js.map} +1 -1
- package/dist/client.d.ts +13 -7
- package/dist/client.js +1 -1
- package/dist/custom-JYDcHl9n.d.ts +135 -0
- package/dist/drizzle/cli/bin.js +3 -3
- package/dist/drizzle/cli.js +3 -3
- package/dist/drizzle.js +2 -2
- package/dist/orm-core.js +2 -2
- package/dist/{query-BMK1cXAS.d.ts → query-C2tqtwBQ.d.ts} +1 -5
- package/dist/react.d.ts +1 -1
- package/dist/server/pg.d.ts +3 -2
- package/dist/server.d.ts +4 -3
- package/dist/server.js +5 -3
- package/dist/server.js.map +1 -1
- package/package.json +2 -1
- package/dist/chunk-N2NAKHMU.js.map +0 -1
- package/dist/custom-DzMQ-nY2.d.ts +0 -81
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../orm-core/src/adapter.ts","../orm-core/src/build.ts","../orm-core/src/emit.ts"],"names":[],"mappings":"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","file":"chunk-7CMFTRDQ.js","sourcesContent":["// The adapter contract. An ORM adapter converts its native schema into the\n// {@link SchemaIR}. That's the entire surface a new ORM has to implement —\n// everything downstream (runtime build + codegen) is shared.\n\nimport type { SchemaIR } from './ir.ts';\n\n/**\n * Converts an ORM's native schema (`Input`) into Orbit's normalized {@link SchemaIR}.\n *\n * @typeParam Input the ORM's schema object (e.g. a Drizzle `* as schema` import).\n * @typeParam Config adapter-specific options (table/column selection, casing, …).\n */\nexport interface OrmAdapter<Input = unknown, Config = unknown> {\n /** Stable adapter id, e.g. `'drizzle'`. Used in generated-file headers. */\n readonly name: string;\n /** Produce the normalized IR for the given schema + options. */\n toIR(input: Input, config?: Config): SchemaIR;\n}\n\n/** Helper to define an adapter with inferred generics. */\nexport function defineAdapter<Input, Config>(adapter: OrmAdapter<Input, Config>): OrmAdapter<Input, Config> {\n return adapter;\n}\n","// Runtime: turn a {@link SchemaIR} into a live Orbit `SchemaDef` (the same object\n// `createSchema(...)` would produce). Used by adapters' `defineOrbitSchema(...)`\n// runtime entry point. Custom `$type<>()` types are type-level only and do not\n// exist at runtime, so this produces the plain column types; for full custom-type\n// fidelity, use the codegen emitter (`emit.ts`) instead.\n\nimport {\n boolean as boolCol,\n createSchema,\n json as jsonCol,\n number as numCol,\n optional,\n relationships,\n string as strCol,\n table,\n type Column,\n type RelationshipsDef,\n type SchemaDef,\n type TableDef,\n} from '../../client/src/index.ts';\nimport type { IRColumn, IRRelationship, SchemaIR } from './ir.ts';\n\nfunction makeColumn(c: IRColumn): Column {\n const base =\n c.type === 'number' ? numCol() : c.type === 'boolean' ? boolCol() : c.type === 'json' ? jsonCol() : strCol();\n return c.optional ? optional(base as Column) : (base as Column);\n}\n\n/** Build a live Orbit schema object from the IR. */\nexport function buildOrbitSchema(ir: SchemaIR): SchemaDef {\n const tableDefs = new Map<string, TableDef>();\n const tables: TableDef[] = [];\n\n for (const t of ir.tables) {\n const columns: Record<string, Column> = {};\n for (const c of t.columns) columns[c.name] = makeColumn(c);\n const pk = (t.primaryKey.length ? t.primaryKey : ['id']) as [string, ...string[]];\n const def = table(t.name)\n .columns(columns as never)\n .primaryKey(...pk) as unknown as TableDef;\n tableDefs.set(t.name, def);\n tables.push(def);\n }\n\n // `relationships()` is per source table, and `createSchema` rejects a table\n // whose relationships are declared twice — so group all of a table's\n // relationships into one call.\n const byTable = new Map<string, IRRelationship[]>();\n for (const r of ir.relationships) {\n const list = byTable.get(r.table) ?? [];\n list.push(r);\n byTable.set(r.table, list);\n }\n\n const rels: RelationshipsDef[] = [];\n for (const [tableName, list] of byTable) {\n const src = tableDefs.get(tableName);\n if (!src) continue;\n rels.push(\n relationships(src, ({ one, many }) => {\n const out: Record<string, unknown> = {};\n for (const r of list) {\n const last = r.chain[r.chain.length - 1];\n const connect = last.cardinality === 'one' ? one : many;\n const args = r.chain.map((c) => {\n const dest = tableDefs.get(c.destSchema);\n if (!dest) throw new Error(`@orbit/orm-core: relationship \"${tableName}.${r.name}\" references unknown table \"${c.destSchema}\"`);\n return { sourceField: [...c.sourceField], destField: [...c.destField], destSchema: dest };\n });\n // `one`/`many` accept 1 (direct) or 2 (junction) hops.\n out[r.name] = (connect as (...a: unknown[]) => unknown)(...args);\n }\n return out as never;\n }),\n );\n }\n\n return createSchema({ tables: tables as never, relationships: rels as never });\n}\n","// Codegen: turn a {@link SchemaIR} into Orbit-schema TypeScript *source*. Unlike\n// the runtime builder, this preserves each column's custom `$type<>()` and enum\n// types (emitted as `string<...>()` / `json<...>()`), so the generated schema is\n// fully typed. Output is plain text; the CLI optionally runs Prettier over it.\n\nimport type { IRColumn, IRRelationship, IRTable, SchemaIR } from './ir.ts';\n\nexport interface EmitOptions {\n /** Module the Orbit schema helpers are imported from. Default `@orbit/client`. */\n readonly importFrom?: string;\n /** Append `.js` to the import (Node16/NodeNext ESM). Default false. */\n readonly jsExtension?: boolean;\n /** Exported schema const name. Default `schema`. */\n readonly schemaName?: string;\n /** Also emit `export type <Table> = RowOf<typeof <table>>` for each table. Default true. */\n readonly rowTypes?: boolean;\n /** Header comment lines (without leading `//`). */\n readonly header?: readonly string[];\n /**\n * Extra `import type { ... } from '...'` lines to prepend — used to bring in the\n * named TypeScript types referenced by resolved custom column types (e.g. a\n * `jsonb().$type<PostMeta>()` resolves to `PostMeta`, imported from the schema).\n */\n readonly typeImports?: readonly { readonly module: string; readonly names: readonly string[] }[];\n}\n\nconst RESERVED = new Set([\n 'break', 'case', 'catch', 'class', 'const', 'continue', 'debugger', 'default', 'delete', 'do', 'else',\n 'export', 'extends', 'false', 'finally', 'for', 'function', 'if', 'import', 'in', 'instanceof', 'new',\n 'null', 'return', 'super', 'switch', 'this', 'throw', 'true', 'try', 'typeof', 'var', 'void', 'while',\n 'with', 'yield', 'let', 'static', 'enum', 'await', 'implements', 'package', 'protected', 'interface',\n 'private', 'public', 'schema', 'table', 'string', 'number', 'boolean', 'json', 'optional', 'createSchema',\n 'relationships', 'RowOf', 'one', 'many',\n]);\n\nconst IDENT_RE = /^[A-Za-z_$][A-Za-z0-9_$]*$/;\n\nfunction isValidIdent(s: string): boolean {\n return IDENT_RE.test(s);\n}\n\n/** A stable, collision-free identifier for each table name (used as the const). */\nfunction tableIdentifiers(tables: readonly IRTable[]): Map<string, string> {\n const out = new Map<string, string>();\n const used = new Set<string>();\n for (const t of tables) {\n let base = t.name.replace(/[^A-Za-z0-9_$]/g, '_');\n if (!IDENT_RE.test(base) || base.startsWith('_') === false && /^[0-9]/.test(base)) base = `t_${base}`;\n if (RESERVED.has(base)) base = `${base}_`;\n let ident = base;\n let i = 2;\n while (used.has(ident)) ident = `${base}${i++}`;\n used.add(ident);\n out.set(t.name, ident);\n }\n return out;\n}\n\nfunction pascal(name: string): string {\n return name\n .split(/[^A-Za-z0-9]+/)\n .filter(Boolean)\n .map((p) => p.charAt(0).toUpperCase() + p.slice(1))\n .join('') || 'Row';\n}\n\nfunction keyLiteral(name: string): string {\n return isValidIdent(name) && !RESERVED.has(name) ? name : JSON.stringify(name);\n}\n\nfunction fieldArray(fields: readonly string[]): string {\n return `[${fields.map((f) => JSON.stringify(f)).join(', ')}]`;\n}\n\nfunction columnExpr(c: IRColumn): string {\n const generic = c.customType ? `<${c.customType}>` : '';\n const call = `${c.type}${generic}()`;\n return c.optional ? `optional(${call})` : call;\n}\n\nfunction emitTable(t: IRTable, ident: string): string {\n const cols = t.columns.map((c) => ` ${keyLiteral(c.name)}: ${columnExpr(c)},`).join('\\n');\n const pk = (t.primaryKey.length ? t.primaryKey : ['id']).map((k) => JSON.stringify(k)).join(', ');\n return `const ${ident} = table(${JSON.stringify(t.name)})\\n .columns({\\n${cols}\\n })\\n .primaryKey(${pk});`;\n}\n\nfunction emitRelationshipsBlock(\n tableName: string,\n rels: readonly IRRelationship[],\n idents: Map<string, string>,\n): string {\n const srcIdent = idents.get(tableName)!;\n const entries = rels\n .map((r) => {\n const last = r.chain[r.chain.length - 1];\n const fn = last.cardinality === 'one' ? 'one' : 'many';\n const hops = r.chain.map((c) => {\n const destIdent = idents.get(c.destSchema);\n if (!destIdent) throw new Error(`@orbit/orm-core: relationship \"${tableName}.${r.name}\" references unknown table \"${c.destSchema}\"`);\n return `{ sourceField: ${fieldArray(c.sourceField)}, destField: ${fieldArray(c.destField)}, destSchema: ${destIdent} }`;\n });\n const body = hops.length === 1 ? `${fn}(${hops[0]})` : `${fn}(\\n ${hops.join(',\\n ')},\\n )`;\n return ` ${keyLiteral(r.name)}: ${body},`;\n })\n .join('\\n');\n return ` relationships(${srcIdent}, ({ one, many }) => ({\\n${entries}\\n })),`;\n}\n\n/** Emit the full Orbit-schema TypeScript source for an IR. */\nexport function emitSchema(ir: SchemaIR, options: EmitOptions = {}): string {\n const {\n importFrom = '@zeronsh/orbit/client',\n jsExtension = false,\n schemaName = 'schema',\n rowTypes = true,\n header = ['Generated by @orbit/orm-core — do not edit by hand.'],\n } = options;\n\n const idents = tableIdentifiers(ir.tables);\n\n // Which helpers do we actually use?\n const used = new Set<string>(['createSchema', 'table']);\n for (const t of ir.tables) {\n for (const c of t.columns) {\n used.add(c.type);\n if (c.optional) used.add('optional');\n }\n }\n const hasRels = ir.relationships.length > 0;\n if (hasRels) used.add('relationships');\n if (rowTypes) used.add('RowOf');\n\n // `RowOf` is a type-only export; keep it in a separate `import type` for clarity.\n const valueImports = [...used].filter((u) => u !== 'RowOf');\n const order = ['createSchema', 'relationships', 'table', 'string', 'number', 'boolean', 'json', 'optional'];\n valueImports.sort((a, b) => {\n const ia = order.indexOf(a);\n const ib = order.indexOf(b);\n return (ia < 0 ? 99 : ia) - (ib < 0 ? 99 : ib);\n });\n\n const spec = jsExtension ? `${importFrom}` : importFrom; // import path unchanged; subpath rarely needs .js\n const lines: string[] = [];\n\n for (const h of header) lines.push(`// ${h}`);\n if (header.length) lines.push('');\n\n lines.push(`import {`);\n for (const v of valueImports) lines.push(` ${v},`);\n lines.push(`} from ${JSON.stringify(spec)};`);\n if (rowTypes) lines.push(`import type { RowOf } from ${JSON.stringify(spec)};`);\n for (const imp of options.typeImports ?? []) {\n if (imp.names.length) lines.push(`import type { ${[...imp.names].join(', ')} } from ${JSON.stringify(imp.module)};`);\n }\n lines.push('');\n\n // Tables.\n for (const t of ir.tables) {\n lines.push(emitTable(t, idents.get(t.name)!));\n lines.push('');\n }\n\n // Schema.\n const tableList = ir.tables.map((t) => idents.get(t.name)!).join(', ');\n lines.push(`export const ${schemaName} = createSchema({`);\n lines.push(` tables: [${tableList}],`);\n if (hasRels) {\n const byTable = new Map<string, IRRelationship[]>();\n for (const r of ir.relationships) {\n const l = byTable.get(r.table) ?? [];\n l.push(r);\n byTable.set(r.table, l);\n }\n lines.push(` relationships: [`);\n for (const t of ir.tables) {\n const list = byTable.get(t.name);\n if (list && list.length) lines.push(emitRelationshipsBlock(t.name, list, idents));\n }\n lines.push(` ],`);\n }\n lines.push(`});`);\n lines.push('');\n lines.push(`export type ${pascal(schemaName)} = typeof ${schemaName};`);\n\n // Row types.\n if (rowTypes) {\n lines.push('');\n const seen = new Set<string>([pascal(schemaName)]);\n for (const t of ir.tables) {\n let name = pascal(t.name);\n while (seen.has(name)) name = `${name}Row`;\n seen.add(name);\n lines.push(`export type ${name} = RowOf<typeof ${idents.get(t.name)!}>;`);\n }\n }\n\n return lines.join('\\n') + '\\n';\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../orm-core/src/adapter.ts","../orm-core/src/build.ts","../orm-core/src/emit.ts"],"names":[],"mappings":"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","file":"chunk-G6NWZNQR.js","sourcesContent":["// The adapter contract. An ORM adapter converts its native schema into the\n// {@link SchemaIR}. That's the entire surface a new ORM has to implement —\n// everything downstream (runtime build + codegen) is shared.\n\nimport type { SchemaIR } from './ir.ts';\n\n/**\n * Converts an ORM's native schema (`Input`) into Orbit's normalized {@link SchemaIR}.\n *\n * @typeParam Input the ORM's schema object (e.g. a Drizzle `* as schema` import).\n * @typeParam Config adapter-specific options (table/column selection, casing, …).\n */\nexport interface OrmAdapter<Input = unknown, Config = unknown> {\n /** Stable adapter id, e.g. `'drizzle'`. Used in generated-file headers. */\n readonly name: string;\n /** Produce the normalized IR for the given schema + options. */\n toIR(input: Input, config?: Config): SchemaIR;\n}\n\n/** Helper to define an adapter with inferred generics. */\nexport function defineAdapter<Input, Config>(adapter: OrmAdapter<Input, Config>): OrmAdapter<Input, Config> {\n return adapter;\n}\n","// Runtime: turn a {@link SchemaIR} into a live Orbit `SchemaDef` (the same object\n// `createSchema(...)` would produce). Used by adapters' `defineOrbitSchema(...)`\n// runtime entry point. Custom `$type<>()` types are type-level only and do not\n// exist at runtime, so this produces the plain column types; for full custom-type\n// fidelity, use the codegen emitter (`emit.ts`) instead.\n\nimport {\n boolean as boolCol,\n createSchema,\n json as jsonCol,\n number as numCol,\n optional,\n relationships,\n string as strCol,\n table,\n type Column,\n type RelationshipsDef,\n type SchemaDef,\n type TableDef,\n} from '../../client/src/index.ts';\nimport type { IRColumn, IRRelationship, SchemaIR } from './ir.ts';\n\nfunction makeColumn(c: IRColumn): Column {\n const base =\n c.type === 'number' ? numCol() : c.type === 'boolean' ? boolCol() : c.type === 'json' ? jsonCol() : strCol();\n return c.optional ? optional(base as Column) : (base as Column);\n}\n\n/** Build a live Orbit schema object from the IR. */\nexport function buildOrbitSchema(ir: SchemaIR): SchemaDef {\n const tableDefs = new Map<string, TableDef>();\n const tables: TableDef[] = [];\n\n for (const t of ir.tables) {\n const columns: Record<string, Column> = {};\n for (const c of t.columns) columns[c.name] = makeColumn(c);\n const pk = (t.primaryKey.length ? t.primaryKey : ['id']) as [string, ...string[]];\n const def = table(t.name)\n .columns(columns as never)\n .primaryKey(...pk) as unknown as TableDef;\n tableDefs.set(t.name, def);\n tables.push(def);\n }\n\n // `relationships()` is per source table, and `createSchema` rejects a table\n // whose relationships are declared twice — so group all of a table's\n // relationships into one call.\n const byTable = new Map<string, IRRelationship[]>();\n for (const r of ir.relationships) {\n const list = byTable.get(r.table) ?? [];\n list.push(r);\n byTable.set(r.table, list);\n }\n\n const rels: RelationshipsDef[] = [];\n for (const [tableName, list] of byTable) {\n const src = tableDefs.get(tableName);\n if (!src) continue;\n rels.push(\n relationships(src, ({ one, many }) => {\n const out: Record<string, unknown> = {};\n for (const r of list) {\n const last = r.chain[r.chain.length - 1];\n const connect = last.cardinality === 'one' ? one : many;\n const args = r.chain.map((c) => {\n const dest = tableDefs.get(c.destSchema);\n if (!dest) throw new Error(`@orbit/orm-core: relationship \"${tableName}.${r.name}\" references unknown table \"${c.destSchema}\"`);\n return { sourceField: [...c.sourceField], destField: [...c.destField], destSchema: dest };\n });\n // `one`/`many` accept 1 (direct) or 2 (junction) hops.\n out[r.name] = (connect as (...a: unknown[]) => unknown)(...args);\n }\n return out as never;\n }),\n );\n }\n\n return createSchema({ tables: tables as never, relationships: rels as never });\n}\n","// Codegen: turn a {@link SchemaIR} into Orbit-schema TypeScript *source*. Unlike\n// the runtime builder, this preserves each column's custom `$type<>()` and enum\n// types (emitted as `string<...>()` / `json<...>()`), so the generated schema is\n// fully typed. Output is plain text; the CLI optionally runs Prettier over it.\n\nimport type { IRColumn, IRRelationship, IRTable, SchemaIR } from './ir.ts';\n\nexport interface EmitOptions {\n /** Module the Orbit schema helpers are imported from. Default `@orbit/client`. */\n readonly importFrom?: string;\n /** Append `.js` to the import (Node16/NodeNext ESM). Default false. */\n readonly jsExtension?: boolean;\n /** Exported schema const name. Default `schema`. */\n readonly schemaName?: string;\n /** Also emit `export type <Table> = RowOf<typeof <table>>` for each table. Default true. */\n readonly rowTypes?: boolean;\n /** Header comment lines (without leading `//`). */\n readonly header?: readonly string[];\n /**\n * Extra `import type { ... } from '...'` lines to prepend — used to bring in the\n * named TypeScript types referenced by resolved custom column types (e.g. a\n * `jsonb().$type<PostMeta>()` resolves to `PostMeta`, imported from the schema).\n */\n readonly typeImports?: readonly { readonly module: string; readonly names: readonly string[] }[];\n}\n\nconst RESERVED = new Set([\n 'break', 'case', 'catch', 'class', 'const', 'continue', 'debugger', 'default', 'delete', 'do', 'else',\n 'export', 'extends', 'false', 'finally', 'for', 'function', 'if', 'import', 'in', 'instanceof', 'new',\n 'null', 'return', 'super', 'switch', 'this', 'throw', 'true', 'try', 'typeof', 'var', 'void', 'while',\n 'with', 'yield', 'let', 'static', 'enum', 'await', 'implements', 'package', 'protected', 'interface',\n 'private', 'public', 'schema', 'table', 'string', 'number', 'boolean', 'json', 'optional', 'createSchema',\n 'relationships', 'RowOf', 'one', 'many',\n]);\n\nconst IDENT_RE = /^[A-Za-z_$][A-Za-z0-9_$]*$/;\n\nfunction isValidIdent(s: string): boolean {\n return IDENT_RE.test(s);\n}\n\n/** A stable, collision-free identifier for each table name (used as the const). */\nfunction tableIdentifiers(tables: readonly IRTable[]): Map<string, string> {\n const out = new Map<string, string>();\n const used = new Set<string>();\n for (const t of tables) {\n let base = t.name.replace(/[^A-Za-z0-9_$]/g, '_');\n if (!IDENT_RE.test(base) || base.startsWith('_') === false && /^[0-9]/.test(base)) base = `t_${base}`;\n if (RESERVED.has(base)) base = `${base}_`;\n let ident = base;\n let i = 2;\n while (used.has(ident)) ident = `${base}${i++}`;\n used.add(ident);\n out.set(t.name, ident);\n }\n return out;\n}\n\nfunction pascal(name: string): string {\n return name\n .split(/[^A-Za-z0-9]+/)\n .filter(Boolean)\n .map((p) => p.charAt(0).toUpperCase() + p.slice(1))\n .join('') || 'Row';\n}\n\nfunction keyLiteral(name: string): string {\n return isValidIdent(name) && !RESERVED.has(name) ? name : JSON.stringify(name);\n}\n\nfunction fieldArray(fields: readonly string[]): string {\n return `[${fields.map((f) => JSON.stringify(f)).join(', ')}]`;\n}\n\nfunction columnExpr(c: IRColumn): string {\n const generic = c.customType ? `<${c.customType}>` : '';\n const call = `${c.type}${generic}()`;\n return c.optional ? `optional(${call})` : call;\n}\n\nfunction emitTable(t: IRTable, ident: string): string {\n const cols = t.columns.map((c) => ` ${keyLiteral(c.name)}: ${columnExpr(c)},`).join('\\n');\n const pk = (t.primaryKey.length ? t.primaryKey : ['id']).map((k) => JSON.stringify(k)).join(', ');\n return `const ${ident} = table(${JSON.stringify(t.name)})\\n .columns({\\n${cols}\\n })\\n .primaryKey(${pk});`;\n}\n\nfunction emitRelationshipsBlock(\n tableName: string,\n rels: readonly IRRelationship[],\n idents: Map<string, string>,\n): string {\n const srcIdent = idents.get(tableName)!;\n const entries = rels\n .map((r) => {\n const last = r.chain[r.chain.length - 1];\n const fn = last.cardinality === 'one' ? 'one' : 'many';\n const hops = r.chain.map((c) => {\n const destIdent = idents.get(c.destSchema);\n if (!destIdent) throw new Error(`@orbit/orm-core: relationship \"${tableName}.${r.name}\" references unknown table \"${c.destSchema}\"`);\n return `{ sourceField: ${fieldArray(c.sourceField)}, destField: ${fieldArray(c.destField)}, destSchema: ${destIdent} }`;\n });\n const body = hops.length === 1 ? `${fn}(${hops[0]})` : `${fn}(\\n ${hops.join(',\\n ')},\\n )`;\n return ` ${keyLiteral(r.name)}: ${body},`;\n })\n .join('\\n');\n return ` relationships(${srcIdent}, ({ one, many }) => ({\\n${entries}\\n })),`;\n}\n\n/** Emit the full Orbit-schema TypeScript source for an IR. */\nexport function emitSchema(ir: SchemaIR, options: EmitOptions = {}): string {\n const {\n importFrom = '@zeronsh/orbit/client',\n jsExtension = false,\n schemaName = 'schema',\n rowTypes = true,\n header = ['Generated by @orbit/orm-core — do not edit by hand.'],\n } = options;\n\n const idents = tableIdentifiers(ir.tables);\n\n // Which helpers do we actually use?\n const used = new Set<string>(['createSchema', 'table']);\n for (const t of ir.tables) {\n for (const c of t.columns) {\n used.add(c.type);\n if (c.optional) used.add('optional');\n }\n }\n const hasRels = ir.relationships.length > 0;\n if (hasRels) used.add('relationships');\n if (rowTypes) used.add('RowOf');\n\n // `RowOf` is a type-only export; keep it in a separate `import type` for clarity.\n const valueImports = [...used].filter((u) => u !== 'RowOf');\n const order = ['createSchema', 'relationships', 'table', 'string', 'number', 'boolean', 'json', 'optional'];\n valueImports.sort((a, b) => {\n const ia = order.indexOf(a);\n const ib = order.indexOf(b);\n return (ia < 0 ? 99 : ia) - (ib < 0 ? 99 : ib);\n });\n\n const spec = jsExtension ? `${importFrom}` : importFrom; // import path unchanged; subpath rarely needs .js\n const lines: string[] = [];\n\n for (const h of header) lines.push(`// ${h}`);\n if (header.length) lines.push('');\n\n lines.push(`import {`);\n for (const v of valueImports) lines.push(` ${v},`);\n lines.push(`} from ${JSON.stringify(spec)};`);\n if (rowTypes) lines.push(`import type { RowOf } from ${JSON.stringify(spec)};`);\n for (const imp of options.typeImports ?? []) {\n if (imp.names.length) lines.push(`import type { ${[...imp.names].join(', ')} } from ${JSON.stringify(imp.module)};`);\n }\n lines.push('');\n\n // Tables.\n for (const t of ir.tables) {\n lines.push(emitTable(t, idents.get(t.name)!));\n lines.push('');\n }\n\n // Schema.\n const tableList = ir.tables.map((t) => idents.get(t.name)!).join(', ');\n lines.push(`export const ${schemaName} = createSchema({`);\n lines.push(` tables: [${tableList}],`);\n if (hasRels) {\n const byTable = new Map<string, IRRelationship[]>();\n for (const r of ir.relationships) {\n const l = byTable.get(r.table) ?? [];\n l.push(r);\n byTable.set(r.table, l);\n }\n lines.push(` relationships: [`);\n for (const t of ir.tables) {\n const list = byTable.get(t.name);\n if (list && list.length) lines.push(emitRelationshipsBlock(t.name, list, idents));\n }\n lines.push(` ],`);\n }\n lines.push(`});`);\n lines.push('');\n lines.push(`export type ${pascal(schemaName)} = typeof ${schemaName};`);\n\n // Row types.\n if (rowTypes) {\n lines.push('');\n const seen = new Set<string>([pascal(schemaName)]);\n for (const t of ir.tables) {\n let name = pascal(t.name);\n while (seen.has(name)) name = `${name}Row`;\n seen.add(name);\n lines.push(`export type ${name} = RowOf<typeof ${idents.get(t.name)!}>;`);\n }\n }\n\n return lines.join('\\n') + '\\n';\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { orbitTypeOf, drizzleToIR } from './chunk-2R6QPZNI.js';
|
|
2
|
-
import { emitSchema } from './chunk-
|
|
2
|
+
import { emitSchema } from './chunk-G6NWZNQR.js';
|
|
3
3
|
import * as path from 'path';
|
|
4
4
|
import * as fs from 'fs/promises';
|
|
5
5
|
import { pathToFileURL } from 'url';
|
|
@@ -127,5 +127,5 @@ async function formatWithPrettier(source, filepath) {
|
|
|
127
127
|
}
|
|
128
128
|
|
|
129
129
|
export { generate, resolveCustomTypes };
|
|
130
|
-
//# sourceMappingURL=chunk-
|
|
131
|
-
//# sourceMappingURL=chunk-
|
|
130
|
+
//# sourceMappingURL=chunk-PSGVTMOB.js.map
|
|
131
|
+
//# sourceMappingURL=chunk-PSGVTMOB.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../drizzle/src/cli/type-resolution.ts","../drizzle/src/cli/generate.ts"],"names":["path2"],"mappings":"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","file":"chunk-QR3NSGHJ.js","sourcesContent":["// Resolve each column's *TypeScript* type with the compiler (via ts-morph), so a\n// Drizzle `.$type<...>()` and enum unions survive into the generated schema —\n// information that does not exist at runtime. For column `c` of table exported as\n// `user`, we resolve `InferSelectModel<typeof user>['c']` (the canonical Drizzle\n// row-type accessor), strip nullability (Orbit models it with `optional()`), and\n// keep the result as the column's custom type. Named types it references (e.g.\n// `PostMeta`, or `import(\"…/country\").Country`) are rewritten to bare names and\n// collected as `import type` lines for the generated file.\n\nimport * as path from 'node:path';\n\nexport interface ResolveColumn {\n readonly jsKey: string;\n readonly dbName: string;\n readonly baseType: 'string' | 'number' | 'boolean' | 'json';\n}\n\nexport interface ResolveTable {\n /** The export name of the table in the schema module (e.g. `user`). */\n readonly exportName: string;\n /** The Orbit/database table name. */\n readonly tableName: string;\n readonly columns: readonly ResolveColumn[];\n}\n\nexport interface ResolveOptions {\n /** Absolute path to the user's Drizzle schema module. */\n readonly schemaModulePath: string;\n /** Absolute path of the file being generated (for relative import specifiers). */\n readonly outputFilePath: string;\n /** Optional tsconfig for module resolution. */\n readonly tsConfigFilePath?: string;\n /** Append `.js` to emitted relative import specifiers (Node16/NodeNext). */\n readonly jsExtension?: boolean;\n}\n\nexport interface ResolvedTypes {\n /** `tableName → dbColumnName → TS type expression`. */\n readonly customTypes: Record<string, Record<string, string>>;\n /** `import type` lines the generated file needs for named custom types. */\n readonly typeImports: { module: string; names: string[] }[];\n}\n\nconst TRIVIAL = new Set(['string', 'number', 'boolean', 'unknown', 'any', 'never', '{}', 'object']);\nconst NS = '__orbitDrizzleSchema';\n\nfunction stripNull(text: string): string {\n return text\n .replace(/\\s*\\|\\s*null\\b/g, '')\n .replace(/\\bnull\\s*\\|\\s*/g, '')\n .replace(/\\s*\\|\\s*undefined\\b/g, '')\n .trim();\n}\n\n/** Module specifier from `from` (the generated file) to `to` (a TS module). */\nfunction relSpecifier(fromFile: string, toModule: string, jsExtension: boolean): string {\n let rel = path.relative(path.dirname(fromFile), toModule).replace(/\\\\/g, '/');\n if (!rel.startsWith('.')) rel = `./${rel}`;\n rel = rel.replace(/\\.tsx?$/, '');\n return jsExtension ? `${rel}.js` : rel;\n}\n\nexport async function resolveCustomTypes(tables: readonly ResolveTable[], options: ResolveOptions): Promise<ResolvedTypes> {\n // ts-morph is an optional peer dependency; import lazily so the runtime path\n // never needs it.\n const { Project, ts } = await import('ts-morph');\n\n const project = options.tsConfigFilePath\n ? new Project({ tsConfigFilePath: options.tsConfigFilePath, skipAddingFilesFromTsConfig: true })\n : new Project({\n compilerOptions: { strict: true, moduleResolution: ts.ModuleResolutionKind.Bundler, target: ts.ScriptTarget.ES2022 },\n skipAddingFilesFromTsConfig: true,\n });\n\n project.addSourceFileAtPath(options.schemaModulePath);\n\n const schemaDir = path.dirname(options.schemaModulePath);\n const schemaSpecifier = `./${path.basename(options.schemaModulePath).replace(/\\.tsx?$/, '')}`;\n\n // One type alias per column, plus an index so we can map back.\n const aliases: { name: string; tableName: string; dbName: string; baseType: ResolveColumn['baseType'] }[] = [];\n let body = `import type { InferSelectModel } from 'drizzle-orm';\\nimport type * as ${NS} from ${JSON.stringify(schemaSpecifier)};\\n`;\n let i = 0;\n for (const t of tables) {\n for (const c of t.columns) {\n const name = `C_${i++}`;\n body += `type ${name} = InferSelectModel<typeof ${NS}.${t.exportName}>[${JSON.stringify(c.jsKey)}];\\n`;\n aliases.push({ name, tableName: t.tableName, dbName: c.dbName, baseType: c.baseType });\n }\n }\n\n const probe = project.createSourceFile(path.join(schemaDir, '__orbit_drizzle_probe__.ts'), body, { overwrite: true });\n const flags = ts.TypeFormatFlags.NoTruncation;\n\n const customTypes: Record<string, Record<string, string>> = {};\n // module specifier → set of imported names\n const importsByModule = new Map<string, Set<string>>();\n const addImport = (moduleSpecifier: string, name: string) => {\n const set = importsByModule.get(moduleSpecifier) ?? new Set<string>();\n set.add(name);\n importsByModule.set(moduleSpecifier, set);\n };\n\n for (const a of aliases) {\n const alias = probe.getTypeAliasOrThrow(a.name);\n const fullType = alias.getType();\n const constituents = fullType.isUnion() ? fullType.getUnionTypes() : [fullType];\n const nonNull = constituents.filter((c) => !c.isNull() && !c.isUndefined());\n\n // Keep a custom type only when it's a genuine *subtype* of the column's Orbit\n // base type. Otherwise the base type is the right one (e.g. a `timestamp`\n // maps to `number`, even though its Drizzle TS type is `Date`).\n const compatible =\n a.baseType === 'json'\n ? true\n : nonNull.length > 0 &&\n nonNull.every((c) => {\n if (a.baseType === 'string') return c.isString() || c.isStringLiteral() || c.isTemplateLiteral();\n if (a.baseType === 'number') return c.isNumber() || c.isNumberLiteral();\n return c.isBoolean() || c.isBooleanLiteral();\n });\n if (!compatible) continue;\n\n let text = stripNull(fullType.getText(alias, flags));\n\n // Rewrite `import(\"ABS\").Name` → `Name`, collecting an import from ABS.\n text = text.replace(/import\\(\"([^\"]+)\"\\)\\.(\\w+)/g, (_m, abs: string, name: string) => {\n const spec = relSpecifier(options.outputFilePath, abs, Boolean(options.jsExtension));\n addImport(spec, name);\n return name;\n });\n\n // Rewrite `__orbitDrizzleSchema.Name` → `Name`, importing from the schema module.\n const schemaImportSpec = relSpecifier(options.outputFilePath, options.schemaModulePath, Boolean(options.jsExtension));\n text = text.replace(new RegExp(`${NS}\\\\.(\\\\w+)`, 'g'), (_m, name: string) => {\n addImport(schemaImportSpec, name);\n return name;\n });\n\n // Drop trivial types; for json keep only meaningful object/array/named types.\n if (TRIVIAL.has(text) || text === '') continue;\n if (a.baseType === 'json' && (text === 'unknown' || text === 'any')) continue;\n\n (customTypes[a.tableName] ??= {})[a.dbName] = text;\n }\n\n project.removeSourceFile(probe);\n\n const typeImports = [...importsByModule.entries()].map(([module, names]) => ({ module, names: [...names].sort() }));\n return { customTypes, typeImports };\n}\n","// The `orbit-drizzle generate` pipeline:\n// import schema (runtime) → resolve custom types (ts-morph) → IR → emit → write.\n\nimport * as fs from 'node:fs/promises';\nimport * as path from 'node:path';\nimport { pathToFileURL } from 'node:url';\nimport { getTableColumns, getTableName, is, Table } from 'drizzle-orm';\nimport { emitSchema } from '../../../orm-core/src/index.ts';\nimport { drizzleToIR, type DrizzleAdapterConfig } from '../introspect.ts';\nimport { orbitTypeOf, type DrizzleColumnLike } from '../type-map.ts';\nimport { resolveCustomTypes, type ResolveTable } from './type-resolution.ts';\n\nexport interface GenerateOptions {\n /** Path to the Drizzle schema module (a single `.ts` file exporting tables + relations). */\n readonly schemaPath: string;\n /** Output path. Default `./orbit-schema.gen.ts`. */\n readonly outputPath?: string;\n /** tsconfig for type resolution + module resolution. */\n readonly tsConfigPath?: string;\n /** Run Prettier over the output if available. */\n readonly format?: boolean;\n /** Append `.js` to relative imports (Node16/NodeNext ESM). */\n readonly jsExtension?: boolean;\n /** Module the Orbit schema helpers are imported from. Default `@orbit/client`. */\n readonly importFrom?: string;\n /** Exported schema const name. Default `schema`. */\n readonly schemaName?: string;\n /** Table/column selection (see {@link DrizzleAdapterConfig.tables}). */\n readonly tables?: DrizzleAdapterConfig['tables'];\n readonly debug?: boolean;\n}\n\nexport interface GenerateResult {\n readonly outputPath: string;\n readonly source: string;\n}\n\n/** Generate an Orbit schema source file from a Drizzle schema. */\nexport async function generate(options: GenerateOptions): Promise<GenerateResult> {\n const schemaModulePath = path.resolve(options.schemaPath);\n const outputPath = path.resolve(options.outputPath ?? './orbit-schema.gen.ts');\n\n // 1. Load the schema module at runtime (tables + relations).\n const moduleObj = (await import(pathToFileURL(schemaModulePath).href)) as Record<string, unknown>;\n\n // 2. Collect per-table resolution metadata (export name, jsKey ↔ dbName).\n const resolveTables: ResolveTable[] = [];\n for (const [exportName, value] of Object.entries(moduleObj)) {\n if (!is(value, Table)) continue;\n const table = value as Table;\n const tableName = getTableName(table);\n if (options.tables && options.tables[tableName] === false) continue;\n const cols = getTableColumns(table) as Record<string, DrizzleColumnLike & { name: string }>;\n const columns = Object.entries(cols)\n .map(([jsKey, col]) => {\n const base = orbitTypeOf(col);\n return base ? { jsKey, dbName: col.name, baseType: base } : null;\n })\n .filter((c): c is NonNullable<typeof c> => c !== null);\n resolveTables.push({ exportName, tableName, columns });\n }\n\n // 3. Resolve custom `$type<>()` / enum types via the TypeScript compiler.\n const { customTypes, typeImports } = await resolveCustomTypes(resolveTables, {\n schemaModulePath,\n outputFilePath: outputPath,\n tsConfigFilePath: options.tsConfigPath,\n jsExtension: options.jsExtension,\n });\n\n // 4. Build the IR with the resolved custom types folded in.\n const ir = drizzleToIR(moduleObj, { customTypes, tables: options.tables, debug: options.debug });\n\n // 5. Emit the Orbit schema source.\n let source = emitSchema(ir, {\n importFrom: options.importFrom ?? '@zeronsh/orbit/client',\n schemaName: options.schemaName,\n jsExtension: options.jsExtension,\n typeImports,\n header: [\n `Generated by @orbit/drizzle from ${path.basename(schemaModulePath)} — do not edit by hand.`,\n `Re-run \\`orbit-drizzle generate\\` to update.`,\n ],\n });\n\n // 6. Optional Prettier.\n if (options.format) source = await formatWithPrettier(source, outputPath);\n\n await fs.writeFile(outputPath, source, 'utf8');\n return { outputPath, source };\n}\n\nasync function formatWithPrettier(source: string, filepath: string): Promise<string> {\n try {\n const prettier = await import('prettier');\n const config = (await prettier.resolveConfig(filepath)) ?? {};\n return prettier.format(source, { ...config, parser: 'typescript' });\n } catch {\n console.warn('⚠️ orbit-drizzle: prettier not found — skipping formatting.');\n return source;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../drizzle/src/cli/type-resolution.ts","../drizzle/src/cli/generate.ts"],"names":["path2"],"mappings":"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","file":"chunk-PSGVTMOB.js","sourcesContent":["// Resolve each column's *TypeScript* type with the compiler (via ts-morph), so a\n// Drizzle `.$type<...>()` and enum unions survive into the generated schema —\n// information that does not exist at runtime. For column `c` of table exported as\n// `user`, we resolve `InferSelectModel<typeof user>['c']` (the canonical Drizzle\n// row-type accessor), strip nullability (Orbit models it with `optional()`), and\n// keep the result as the column's custom type. Named types it references (e.g.\n// `PostMeta`, or `import(\"…/country\").Country`) are rewritten to bare names and\n// collected as `import type` lines for the generated file.\n\nimport * as path from 'node:path';\n\nexport interface ResolveColumn {\n readonly jsKey: string;\n readonly dbName: string;\n readonly baseType: 'string' | 'number' | 'boolean' | 'json';\n}\n\nexport interface ResolveTable {\n /** The export name of the table in the schema module (e.g. `user`). */\n readonly exportName: string;\n /** The Orbit/database table name. */\n readonly tableName: string;\n readonly columns: readonly ResolveColumn[];\n}\n\nexport interface ResolveOptions {\n /** Absolute path to the user's Drizzle schema module. */\n readonly schemaModulePath: string;\n /** Absolute path of the file being generated (for relative import specifiers). */\n readonly outputFilePath: string;\n /** Optional tsconfig for module resolution. */\n readonly tsConfigFilePath?: string;\n /** Append `.js` to emitted relative import specifiers (Node16/NodeNext). */\n readonly jsExtension?: boolean;\n}\n\nexport interface ResolvedTypes {\n /** `tableName → dbColumnName → TS type expression`. */\n readonly customTypes: Record<string, Record<string, string>>;\n /** `import type` lines the generated file needs for named custom types. */\n readonly typeImports: { module: string; names: string[] }[];\n}\n\nconst TRIVIAL = new Set(['string', 'number', 'boolean', 'unknown', 'any', 'never', '{}', 'object']);\nconst NS = '__orbitDrizzleSchema';\n\nfunction stripNull(text: string): string {\n return text\n .replace(/\\s*\\|\\s*null\\b/g, '')\n .replace(/\\bnull\\s*\\|\\s*/g, '')\n .replace(/\\s*\\|\\s*undefined\\b/g, '')\n .trim();\n}\n\n/** Module specifier from `from` (the generated file) to `to` (a TS module). */\nfunction relSpecifier(fromFile: string, toModule: string, jsExtension: boolean): string {\n let rel = path.relative(path.dirname(fromFile), toModule).replace(/\\\\/g, '/');\n if (!rel.startsWith('.')) rel = `./${rel}`;\n rel = rel.replace(/\\.tsx?$/, '');\n return jsExtension ? `${rel}.js` : rel;\n}\n\nexport async function resolveCustomTypes(tables: readonly ResolveTable[], options: ResolveOptions): Promise<ResolvedTypes> {\n // ts-morph is an optional peer dependency; import lazily so the runtime path\n // never needs it.\n const { Project, ts } = await import('ts-morph');\n\n const project = options.tsConfigFilePath\n ? new Project({ tsConfigFilePath: options.tsConfigFilePath, skipAddingFilesFromTsConfig: true })\n : new Project({\n compilerOptions: { strict: true, moduleResolution: ts.ModuleResolutionKind.Bundler, target: ts.ScriptTarget.ES2022 },\n skipAddingFilesFromTsConfig: true,\n });\n\n project.addSourceFileAtPath(options.schemaModulePath);\n\n const schemaDir = path.dirname(options.schemaModulePath);\n const schemaSpecifier = `./${path.basename(options.schemaModulePath).replace(/\\.tsx?$/, '')}`;\n\n // One type alias per column, plus an index so we can map back.\n const aliases: { name: string; tableName: string; dbName: string; baseType: ResolveColumn['baseType'] }[] = [];\n let body = `import type { InferSelectModel } from 'drizzle-orm';\\nimport type * as ${NS} from ${JSON.stringify(schemaSpecifier)};\\n`;\n let i = 0;\n for (const t of tables) {\n for (const c of t.columns) {\n const name = `C_${i++}`;\n body += `type ${name} = InferSelectModel<typeof ${NS}.${t.exportName}>[${JSON.stringify(c.jsKey)}];\\n`;\n aliases.push({ name, tableName: t.tableName, dbName: c.dbName, baseType: c.baseType });\n }\n }\n\n const probe = project.createSourceFile(path.join(schemaDir, '__orbit_drizzle_probe__.ts'), body, { overwrite: true });\n const flags = ts.TypeFormatFlags.NoTruncation;\n\n const customTypes: Record<string, Record<string, string>> = {};\n // module specifier → set of imported names\n const importsByModule = new Map<string, Set<string>>();\n const addImport = (moduleSpecifier: string, name: string) => {\n const set = importsByModule.get(moduleSpecifier) ?? new Set<string>();\n set.add(name);\n importsByModule.set(moduleSpecifier, set);\n };\n\n for (const a of aliases) {\n const alias = probe.getTypeAliasOrThrow(a.name);\n const fullType = alias.getType();\n const constituents = fullType.isUnion() ? fullType.getUnionTypes() : [fullType];\n const nonNull = constituents.filter((c) => !c.isNull() && !c.isUndefined());\n\n // Keep a custom type only when it's a genuine *subtype* of the column's Orbit\n // base type. Otherwise the base type is the right one (e.g. a `timestamp`\n // maps to `number`, even though its Drizzle TS type is `Date`).\n const compatible =\n a.baseType === 'json'\n ? true\n : nonNull.length > 0 &&\n nonNull.every((c) => {\n if (a.baseType === 'string') return c.isString() || c.isStringLiteral() || c.isTemplateLiteral();\n if (a.baseType === 'number') return c.isNumber() || c.isNumberLiteral();\n return c.isBoolean() || c.isBooleanLiteral();\n });\n if (!compatible) continue;\n\n let text = stripNull(fullType.getText(alias, flags));\n\n // Rewrite `import(\"ABS\").Name` → `Name`, collecting an import from ABS.\n text = text.replace(/import\\(\"([^\"]+)\"\\)\\.(\\w+)/g, (_m, abs: string, name: string) => {\n const spec = relSpecifier(options.outputFilePath, abs, Boolean(options.jsExtension));\n addImport(spec, name);\n return name;\n });\n\n // Rewrite `__orbitDrizzleSchema.Name` → `Name`, importing from the schema module.\n const schemaImportSpec = relSpecifier(options.outputFilePath, options.schemaModulePath, Boolean(options.jsExtension));\n text = text.replace(new RegExp(`${NS}\\\\.(\\\\w+)`, 'g'), (_m, name: string) => {\n addImport(schemaImportSpec, name);\n return name;\n });\n\n // Drop trivial types; for json keep only meaningful object/array/named types.\n if (TRIVIAL.has(text) || text === '') continue;\n if (a.baseType === 'json' && (text === 'unknown' || text === 'any')) continue;\n\n (customTypes[a.tableName] ??= {})[a.dbName] = text;\n }\n\n project.removeSourceFile(probe);\n\n const typeImports = [...importsByModule.entries()].map(([module, names]) => ({ module, names: [...names].sort() }));\n return { customTypes, typeImports };\n}\n","// The `orbit-drizzle generate` pipeline:\n// import schema (runtime) → resolve custom types (ts-morph) → IR → emit → write.\n\nimport * as fs from 'node:fs/promises';\nimport * as path from 'node:path';\nimport { pathToFileURL } from 'node:url';\nimport { getTableColumns, getTableName, is, Table } from 'drizzle-orm';\nimport { emitSchema } from '../../../orm-core/src/index.ts';\nimport { drizzleToIR, type DrizzleAdapterConfig } from '../introspect.ts';\nimport { orbitTypeOf, type DrizzleColumnLike } from '../type-map.ts';\nimport { resolveCustomTypes, type ResolveTable } from './type-resolution.ts';\n\nexport interface GenerateOptions {\n /** Path to the Drizzle schema module (a single `.ts` file exporting tables + relations). */\n readonly schemaPath: string;\n /** Output path. Default `./orbit-schema.gen.ts`. */\n readonly outputPath?: string;\n /** tsconfig for type resolution + module resolution. */\n readonly tsConfigPath?: string;\n /** Run Prettier over the output if available. */\n readonly format?: boolean;\n /** Append `.js` to relative imports (Node16/NodeNext ESM). */\n readonly jsExtension?: boolean;\n /** Module the Orbit schema helpers are imported from. Default `@orbit/client`. */\n readonly importFrom?: string;\n /** Exported schema const name. Default `schema`. */\n readonly schemaName?: string;\n /** Table/column selection (see {@link DrizzleAdapterConfig.tables}). */\n readonly tables?: DrizzleAdapterConfig['tables'];\n readonly debug?: boolean;\n}\n\nexport interface GenerateResult {\n readonly outputPath: string;\n readonly source: string;\n}\n\n/** Generate an Orbit schema source file from a Drizzle schema. */\nexport async function generate(options: GenerateOptions): Promise<GenerateResult> {\n const schemaModulePath = path.resolve(options.schemaPath);\n const outputPath = path.resolve(options.outputPath ?? './orbit-schema.gen.ts');\n\n // 1. Load the schema module at runtime (tables + relations).\n const moduleObj = (await import(pathToFileURL(schemaModulePath).href)) as Record<string, unknown>;\n\n // 2. Collect per-table resolution metadata (export name, jsKey ↔ dbName).\n const resolveTables: ResolveTable[] = [];\n for (const [exportName, value] of Object.entries(moduleObj)) {\n if (!is(value, Table)) continue;\n const table = value as Table;\n const tableName = getTableName(table);\n if (options.tables && options.tables[tableName] === false) continue;\n const cols = getTableColumns(table) as Record<string, DrizzleColumnLike & { name: string }>;\n const columns = Object.entries(cols)\n .map(([jsKey, col]) => {\n const base = orbitTypeOf(col);\n return base ? { jsKey, dbName: col.name, baseType: base } : null;\n })\n .filter((c): c is NonNullable<typeof c> => c !== null);\n resolveTables.push({ exportName, tableName, columns });\n }\n\n // 3. Resolve custom `$type<>()` / enum types via the TypeScript compiler.\n const { customTypes, typeImports } = await resolveCustomTypes(resolveTables, {\n schemaModulePath,\n outputFilePath: outputPath,\n tsConfigFilePath: options.tsConfigPath,\n jsExtension: options.jsExtension,\n });\n\n // 4. Build the IR with the resolved custom types folded in.\n const ir = drizzleToIR(moduleObj, { customTypes, tables: options.tables, debug: options.debug });\n\n // 5. Emit the Orbit schema source.\n let source = emitSchema(ir, {\n importFrom: options.importFrom ?? '@zeronsh/orbit/client',\n schemaName: options.schemaName,\n jsExtension: options.jsExtension,\n typeImports,\n header: [\n `Generated by @orbit/drizzle from ${path.basename(schemaModulePath)} — do not edit by hand.`,\n `Re-run \\`orbit-drizzle generate\\` to update.`,\n ],\n });\n\n // 6. Optional Prettier.\n if (options.format) source = await formatWithPrettier(source, outputPath);\n\n await fs.writeFile(outputPath, source, 'utf8');\n return { outputPath, source };\n}\n\nasync function formatWithPrettier(source: string, filepath: string): Promise<string> {\n try {\n const prettier = await import('prettier');\n const config = (await prettier.resolveConfig(filepath)) ?? {};\n return prettier.format(source, { ...config, parser: 'typescript' });\n } catch {\n console.warn('⚠️ orbit-drizzle: prettier not found — skipping formatting.');\n return source;\n }\n}\n"]}
|
package/dist/client.d.ts
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export { f as Condition, g as CorrelatedSubquery, h as Correlation, D as Direction, i as Downstream, P as PROTOCOL_VERSION, Q as QueryBuilder, j as SchemaQuery, k as SimpleOperator, S as Subscribable, T as TypedQuery, U as Upstream, l as ValuePosition, m as ViewLike, n as buildSchemaQueries, o as createBuilder, p as hashAST, q as hashString } from './query-
|
|
1
|
+
import { b as QueriesPatchOp, R as Row, c as RowPatchOp, C as CrudOp, M as Mutation, d as QueryHost, a as SchemaQueries, e as Query, A as AST, V as Value, O as OrderPart } from './query-C2tqtwBQ.js';
|
|
2
|
+
export { f as Condition, g as CorrelatedSubquery, h as Correlation, D as Direction, i as Downstream, P as PROTOCOL_VERSION, Q as QueryBuilder, j as SchemaQuery, k as SimpleOperator, S as Subscribable, T as TypedQuery, U as Upstream, l as ValuePosition, m as ViewLike, n as buildSchemaQueries, o as createBuilder, p as hashAST, q as hashString } from './query-C2tqtwBQ.js';
|
|
3
3
|
import { S as SchemaDef, R as RowOf, P as PkOf, A as AnySchema } from './schema-BNM6bks7.js';
|
|
4
4
|
export { b as Cardinality, c as Column, d as Columns, C as Connection, a as Relationship, e as RelationshipsDef, f as RelationshipsMap, T as TableDef, V as ValueType, g as boolean, h as createSchema, j as json, n as number, o as optional, r as relationships, s as string, t as table } from './schema-BNM6bks7.js';
|
|
5
|
-
import { a as
|
|
6
|
-
export { M as
|
|
5
|
+
import { a as MutationDefs, b as QueryDefs, c as QueriesAPI, d as MutateAPI, C as CtxOf } from './custom-JYDcHl9n.js';
|
|
6
|
+
export { I as InferArgs, e as MutationConfig, M as MutationDef, f as QueryConfig, Q as QueryDef, S as SchemaCRUD, T as TableCRUD, g as Transaction, V as Validator, h as collectOps, i as createOrbitApi, j as defineMutation, k as defineQuery, v as validateArgs } from './custom-JYDcHl9n.js';
|
|
7
|
+
import '@standard-schema/spec';
|
|
7
8
|
|
|
8
9
|
/** The `put` variant of a desired-query patch op (always has a `hash`). */
|
|
9
10
|
type QueryPut = Extract<QueriesPatchOp, {
|
|
@@ -155,7 +156,11 @@ declare class View<T extends Row = Row> {
|
|
|
155
156
|
/** Stop reacting to store changes + release the query subscription (Zero's `view.destroy()`). */
|
|
156
157
|
destroy(): void;
|
|
157
158
|
}
|
|
158
|
-
|
|
159
|
+
/** A context value or a (sync) getter for it. */
|
|
160
|
+
type CtxInput<C> = C | (() => C);
|
|
161
|
+
/** The Ctx the handlers expect, inferred from the mutator/query defs. */
|
|
162
|
+
type ResolveCtx<MD, QD> = MD extends MutationDefs ? CtxOf<MD> : QD extends QueryDefs ? CtxOf<QD> : unknown;
|
|
163
|
+
declare class Orbit<S extends SchemaDef = AnySchema, MD extends MutationDefs | undefined = undefined, QD extends QueryDefs | undefined = undefined> implements QueryHost {
|
|
159
164
|
#private;
|
|
160
165
|
clientID: string;
|
|
161
166
|
clientGroupID: string;
|
|
@@ -168,10 +173,11 @@ declare class Orbit<S extends SchemaDef = AnySchema, MD extends MutatorDefs | un
|
|
|
168
173
|
* (`orbit.mutate.createTodo(args)`); otherwise per-table CRUD
|
|
169
174
|
* (`orbit.mutate.todo.insert(...)`).
|
|
170
175
|
*/
|
|
171
|
-
readonly mutate: MD extends
|
|
176
|
+
readonly mutate: MD extends MutationDefs ? MutateAPI<MD> : MutateAccess<S>;
|
|
172
177
|
constructor(opts: OrbitOptions<S> & {
|
|
173
178
|
mutators?: MD;
|
|
174
179
|
queries?: QD;
|
|
180
|
+
context?: CtxInput<ResolveCtx<MD, QD>>;
|
|
175
181
|
});
|
|
176
182
|
/** Build a raw (untyped) query against `table` — escape hatch. */
|
|
177
183
|
queryRaw(table: string): Query;
|
|
@@ -346,4 +352,4 @@ declare function nodeToRow(node: {
|
|
|
346
352
|
}[]>;
|
|
347
353
|
}, ast: AST): Record<string, unknown>;
|
|
348
354
|
|
|
349
|
-
export { AST, AnySchema, type Change, type Comparator, CrudOp, type FetchRequest, IDBKV, type KV, MaterializedView, MemoryKV, MemorySource, MemorySourceProvider, MutateAPI, type MutateAccess, Mutation,
|
|
355
|
+
export { AST, AnySchema, type Change, type Comparator, CrudOp, CtxOf, type FetchRequest, IDBKV, type KV, MaterializedView, MemoryKV, MemorySource, MemorySourceProvider, MutateAPI, type MutateAccess, Mutation, MutationDefs, type Node, type Op, Orbit, type OrbitOptions, OrderPart, PkOf, QueriesAPI, QueriesPatchOp, Query, type QueryAccess, QueryDefs, QueryHost, QueryManager, type QueryPut, type ResultRow, Row, RowOf, RowPatchOp, type Scheduler, SchemaDef, SchemaQueries, type SourceChange, SourceConnection, type SourceProvider, Store, StoreProvider, type TTL, type TableMutator, Value, View, buildPipeline, compareValues, evaluate, nodeToRow, parseTTL, tablesOf, unwrapSingular, valuesEqual };
|
package/dist/client.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { IDBKV, MaterializedView, MemoryKV, MemorySource, MemorySourceProvider, Orbit, PROTOCOL_VERSION, Query, QueryManager, SchemaQuery, SourceConnection, Store, StoreProvider, TypedQuery, View, boolean, buildPipeline, buildSchemaQueries, collectOps, compareValues, createBuilder, createSchema,
|
|
1
|
+
export { IDBKV, MaterializedView, MemoryKV, MemorySource, MemorySourceProvider, Orbit, PROTOCOL_VERSION, Query, QueryManager, SchemaQuery, SourceConnection, Store, StoreProvider, TypedQuery, View, boolean, buildPipeline, buildSchemaQueries, collectOps, compareValues, createBuilder, createOrbitApi, createSchema, defineMutation, defineQuery, evaluate, hashAST, hashString, json, nodeToRow, number, optional, parseTTL, relationships, string, table, tablesOf, unwrapSingular, validateArgs, valuesEqual } from './chunk-EX4WSUC3.js';
|
|
2
2
|
//# sourceMappingURL=client.js.map
|
|
3
3
|
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import { StandardSchemaV1 } from '@standard-schema/spec';
|
|
2
|
+
import { R as Row, Q as QueryBuilder, S as Subscribable, C as CrudOp, a as SchemaQueries } from './query-C2tqtwBQ.js';
|
|
3
|
+
import { S as SchemaDef, R as RowOf, P as PkOf, A as AnySchema } from './schema-BNM6bks7.js';
|
|
4
|
+
|
|
5
|
+
/** A Standard Schema validator (e.g. a Zod/Valibot/ArkType schema). */
|
|
6
|
+
type Validator<Output = unknown> = StandardSchemaV1<unknown, Output>;
|
|
7
|
+
/** The parsed (output) args type of a validator, or `void` when there's none. */
|
|
8
|
+
type InferArgs<A> = A extends StandardSchemaV1 ? StandardSchemaV1.InferOutput<A> : void;
|
|
9
|
+
/** Typed CRUD surface for one table inside a mutator transaction. */
|
|
10
|
+
type TableCRUD<T extends Row, PK extends keyof T> = {
|
|
11
|
+
insert(value: T): void;
|
|
12
|
+
upsert(value: T): void;
|
|
13
|
+
update(value: Pick<T, PK> & Partial<T>): void;
|
|
14
|
+
delete(value: Pick<T, PK>): void;
|
|
15
|
+
};
|
|
16
|
+
/** `tx.mutate.<table>` for every table in the schema. */
|
|
17
|
+
type SchemaCRUD<S extends SchemaDef> = {
|
|
18
|
+
[K in keyof S['tables']]: TableCRUD<RowOf<S['tables'][K]>, PkOf<S['tables'][K]>>;
|
|
19
|
+
};
|
|
20
|
+
/** The transaction passed to a mutator (mirrors Zero's `Transaction`). */
|
|
21
|
+
type Transaction<S extends SchemaDef> = {
|
|
22
|
+
readonly location: 'client';
|
|
23
|
+
readonly mutate: SchemaCRUD<S>;
|
|
24
|
+
};
|
|
25
|
+
/** A mutator definition: an optional `args` validator + a `handler`. */
|
|
26
|
+
type MutationConfig<S extends SchemaDef, Ctx, A extends StandardSchemaV1 | undefined> = {
|
|
27
|
+
args?: A;
|
|
28
|
+
handler: (c: {
|
|
29
|
+
tx: Transaction<S>;
|
|
30
|
+
args: InferArgs<A>;
|
|
31
|
+
ctx: Ctx;
|
|
32
|
+
}) => void | Promise<void>;
|
|
33
|
+
};
|
|
34
|
+
/** A query definition: an optional `args` validator + a `handler` returning a query. */
|
|
35
|
+
type QueryConfig<S extends SchemaDef, Ctx, A extends StandardSchemaV1 | undefined, T extends Row> = {
|
|
36
|
+
args?: A;
|
|
37
|
+
handler: (c: {
|
|
38
|
+
args: InferArgs<A>;
|
|
39
|
+
ctx: Ctx;
|
|
40
|
+
}) => QueryBuilder<T>;
|
|
41
|
+
};
|
|
42
|
+
/** A stored mutator definition. (`any` in the type positions keeps specific defs
|
|
43
|
+
* assignable to the `MutationDefs` record while preserving Args/Ctx for inference.) */
|
|
44
|
+
type MutationDef<Args = any, Ctx = any> = {
|
|
45
|
+
args?: StandardSchemaV1;
|
|
46
|
+
handler: (c: {
|
|
47
|
+
tx: Transaction<any>;
|
|
48
|
+
args: Args;
|
|
49
|
+
ctx: Ctx;
|
|
50
|
+
}) => void | Promise<void>;
|
|
51
|
+
};
|
|
52
|
+
/** A stored query definition (its args + result row + ctx types are inferred). */
|
|
53
|
+
type QueryDef<Args = any, T extends Row = Row, Ctx = any> = {
|
|
54
|
+
args?: StandardSchemaV1;
|
|
55
|
+
handler: (c: {
|
|
56
|
+
args: Args;
|
|
57
|
+
ctx: Ctx;
|
|
58
|
+
}) => QueryBuilder<T>;
|
|
59
|
+
};
|
|
60
|
+
/**
|
|
61
|
+
* The schema- and context-bound authoring API returned by {@link createOrbitApi}:
|
|
62
|
+
* `defineQuery`/`defineMutation` whose handlers are fully typed (`tx`, `args`, `ctx`)
|
|
63
|
+
* with no per-def annotations, plus a `builder` for the bound schema.
|
|
64
|
+
*/
|
|
65
|
+
interface OrbitApi<S extends SchemaDef, Ctx> {
|
|
66
|
+
builder: SchemaQueries<S>;
|
|
67
|
+
defineMutation<A extends StandardSchemaV1 | undefined = undefined>(config: MutationConfig<S, Ctx, A>): MutationDef<InferArgs<A>, Ctx>;
|
|
68
|
+
defineQuery<A extends StandardSchemaV1 | undefined = undefined, T extends Row = Row>(config: QueryConfig<S, Ctx, A, T>): QueryDef<InferArgs<A>, T, Ctx>;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Bind the schema + context types once and get `defineQuery`/`defineMutation`/`builder`
|
|
72
|
+
* whose handlers are fully typed (`tx`, `args`, `ctx`) with no per-def annotations.
|
|
73
|
+
*/
|
|
74
|
+
declare function createOrbitApi<S extends SchemaDef, Ctx = unknown>(opts: {
|
|
75
|
+
schema: S;
|
|
76
|
+
}): OrbitApi<S, Ctx>;
|
|
77
|
+
/** Define a custom mutator without a factory (`tx` loosely typed, `ctx` is `unknown`).
|
|
78
|
+
* Prefer {@link createOrbitApi} for fully-typed `tx`/`ctx`. */
|
|
79
|
+
declare function defineMutation<A extends StandardSchemaV1 | undefined = undefined>(config: {
|
|
80
|
+
args?: A;
|
|
81
|
+
handler: (c: {
|
|
82
|
+
tx: Transaction<AnySchema>;
|
|
83
|
+
args: InferArgs<A>;
|
|
84
|
+
ctx: unknown;
|
|
85
|
+
}) => void | Promise<void>;
|
|
86
|
+
}): MutationDef<InferArgs<A>, unknown>;
|
|
87
|
+
/** Define a custom (named) query without a factory (`ctx` is `unknown`).
|
|
88
|
+
* Prefer {@link createOrbitApi} for a fully-typed `ctx`. */
|
|
89
|
+
declare function defineQuery<A extends StandardSchemaV1 | undefined = undefined, T extends Row = Row>(config: {
|
|
90
|
+
args?: A;
|
|
91
|
+
handler: (c: {
|
|
92
|
+
args: InferArgs<A>;
|
|
93
|
+
ctx: unknown;
|
|
94
|
+
}) => QueryBuilder<T>;
|
|
95
|
+
}): QueryDef<InferArgs<A>, T, unknown>;
|
|
96
|
+
type MutationDefs = Record<string, MutationDef>;
|
|
97
|
+
type QueryDefs = Record<string, QueryDef>;
|
|
98
|
+
/** The handler's parameter object (`{ tx?, args, ctx }`). Captured whole so that
|
|
99
|
+
* `args`/`ctx` can be picked without tripping over function-param contravariance. */
|
|
100
|
+
type ParamOf<D> = D extends {
|
|
101
|
+
handler: (c: infer C) => unknown;
|
|
102
|
+
} ? C : never;
|
|
103
|
+
type ArgsOf<M> = ParamOf<M> extends {
|
|
104
|
+
args: infer A;
|
|
105
|
+
} ? A : never;
|
|
106
|
+
type QArgsOf<Q> = ArgsOf<Q>;
|
|
107
|
+
type QRowOf<Q> = Q extends {
|
|
108
|
+
handler: (...a: any[]) => QueryBuilder<infer T>;
|
|
109
|
+
} ? T : never;
|
|
110
|
+
/** The Ctx type shared by a record of defs (used to type the client's `context`). */
|
|
111
|
+
type CtxOf<D> = ParamOf<D[keyof D]> extends {
|
|
112
|
+
ctx: infer C;
|
|
113
|
+
} ? C : unknown;
|
|
114
|
+
/** `orbit.mutate` derived from mutator defs — `tx` stripped, args kept. */
|
|
115
|
+
type MutateAPI<MD extends MutationDefs> = {
|
|
116
|
+
[K in keyof MD]: ArgsOf<MD[K]> extends void | undefined ? () => void : (args: ArgsOf<MD[K]>) => void;
|
|
117
|
+
};
|
|
118
|
+
/** `orbit.queries` derived from query defs — call with args, get a `Subscribable`. */
|
|
119
|
+
type QueriesAPI<QD extends QueryDefs> = {
|
|
120
|
+
[K in keyof QD]: QArgsOf<QD[K]> extends void | undefined ? () => Subscribable<QRowOf<QD[K]>> : (args: QArgsOf<QD[K]>) => Subscribable<QRowOf<QD[K]>>;
|
|
121
|
+
};
|
|
122
|
+
/**
|
|
123
|
+
* Validate (and parse) `args` against a Standard Schema validator. Returns the
|
|
124
|
+
* parsed value; throws on invalid input. With no validator, returns args as-is.
|
|
125
|
+
* Used by the server processors on untrusted client input.
|
|
126
|
+
*/
|
|
127
|
+
declare function validateArgs(validator: StandardSchemaV1 | undefined, args: unknown): Promise<unknown>;
|
|
128
|
+
/**
|
|
129
|
+
* Run a mutator definition against a recording transaction and return the CRUD
|
|
130
|
+
* ops it produced. Use this on **your push endpoint** (the server forwarded the
|
|
131
|
+
* mutation to) to execute a mutator with context, then apply the ops to your DB.
|
|
132
|
+
*/
|
|
133
|
+
declare function collectOps<S extends SchemaDef>(schema: S, def: MutationDef, args: unknown, ctx?: unknown): CrudOp[];
|
|
134
|
+
|
|
135
|
+
export { type CtxOf as C, type InferArgs as I, type MutationDef as M, type QueryDef as Q, type SchemaCRUD as S, type TableCRUD as T, type Validator as V, type MutationDefs as a, type QueryDefs as b, type QueriesAPI as c, type MutateAPI as d, type MutationConfig as e, type QueryConfig as f, type Transaction as g, collectOps as h, createOrbitApi as i, defineMutation as j, defineQuery as k, validateArgs as v };
|
package/dist/drizzle/cli/bin.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import { generate } from '../../chunk-
|
|
2
|
+
import { generate } from '../../chunk-PSGVTMOB.js';
|
|
3
3
|
import '../../chunk-2R6QPZNI.js';
|
|
4
|
-
import '../../chunk-
|
|
5
|
-
import '../../chunk-
|
|
4
|
+
import '../../chunk-G6NWZNQR.js';
|
|
5
|
+
import '../../chunk-EX4WSUC3.js';
|
|
6
6
|
import * as fs from 'fs';
|
|
7
7
|
import * as path from 'path';
|
|
8
8
|
import { pathToFileURL } from 'url';
|
package/dist/drizzle/cli.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { generate, resolveCustomTypes } from '../chunk-
|
|
1
|
+
export { generate, resolveCustomTypes } from '../chunk-PSGVTMOB.js';
|
|
2
2
|
import '../chunk-2R6QPZNI.js';
|
|
3
|
-
import '../chunk-
|
|
4
|
-
import '../chunk-
|
|
3
|
+
import '../chunk-G6NWZNQR.js';
|
|
4
|
+
import '../chunk-EX4WSUC3.js';
|
|
5
5
|
//# sourceMappingURL=cli.js.map
|
|
6
6
|
//# sourceMappingURL=cli.js.map
|
package/dist/drizzle.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { drizzleToIR } from './chunk-2R6QPZNI.js';
|
|
2
2
|
export { drizzleToIR } from './chunk-2R6QPZNI.js';
|
|
3
|
-
import { buildOrbitSchema } from './chunk-
|
|
4
|
-
import './chunk-
|
|
3
|
+
import { buildOrbitSchema } from './chunk-G6NWZNQR.js';
|
|
4
|
+
import './chunk-EX4WSUC3.js';
|
|
5
5
|
|
|
6
6
|
// drizzle/src/index.ts
|
|
7
7
|
var drizzleAdapter = {
|
package/dist/orm-core.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { buildOrbitSchema, defineAdapter, emitSchema } from './chunk-
|
|
2
|
-
import './chunk-
|
|
1
|
+
export { buildOrbitSchema, defineAdapter, emitSchema } from './chunk-G6NWZNQR.js';
|
|
2
|
+
import './chunk-EX4WSUC3.js';
|
|
3
3
|
//# sourceMappingURL=orm-core.js.map
|
|
4
4
|
//# sourceMappingURL=orm-core.js.map
|
|
@@ -11,10 +11,6 @@ type ValuePosition = {
|
|
|
11
11
|
} | {
|
|
12
12
|
type: 'column';
|
|
13
13
|
name: string;
|
|
14
|
-
} | {
|
|
15
|
-
type: 'static';
|
|
16
|
-
anchor: 'authData' | 'preMutationRow';
|
|
17
|
-
field: string | string[];
|
|
18
14
|
};
|
|
19
15
|
type Condition = {
|
|
20
16
|
type: 'simple';
|
|
@@ -293,4 +289,4 @@ declare function createBuilder<S extends SchemaDef>(schema: S): SchemaQueries<S>
|
|
|
293
289
|
/** Build the per-table {@link SchemaQuery} map, optionally bound to a host. */
|
|
294
290
|
declare function buildSchemaQueries<S extends SchemaDef>(schema: S, host: QueryHost | null): SchemaQueries<S>;
|
|
295
291
|
|
|
296
|
-
export { type AST as A, type CrudOp as C, type Direction as D, type Mutation as M, type OrderPart as O, PROTOCOL_VERSION as P, type QueryBuilder as Q, type Row as R, type Subscribable as S, TypedQuery as T, type Upstream as U, type Value as V, type
|
|
292
|
+
export { type AST as A, type CrudOp as C, type Direction as D, type Mutation as M, type OrderPart as O, PROTOCOL_VERSION as P, type QueryBuilder as Q, type Row as R, type Subscribable as S, TypedQuery as T, type Upstream as U, type Value as V, type SchemaQueries as a, type QueriesPatchOp as b, type RowPatchOp as c, type QueryHost as d, Query as e, type Condition as f, type CorrelatedSubquery as g, type Correlation as h, type Downstream as i, SchemaQuery as j, type SimpleOperator as k, type ValuePosition as l, type ViewLike as m, buildSchemaQueries as n, createBuilder as o, hashAST as p, hashString as q };
|
package/dist/react.d.ts
CHANGED
package/dist/server/pg.d.ts
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import pg from 'pg';
|
|
2
2
|
import { DBConnection } from '../server.js';
|
|
3
|
-
import '../query-
|
|
3
|
+
import '../query-C2tqtwBQ.js';
|
|
4
4
|
import '../schema-BNM6bks7.js';
|
|
5
|
-
import '../custom-
|
|
5
|
+
import '../custom-JYDcHl9n.js';
|
|
6
|
+
import '@standard-schema/spec';
|
|
6
7
|
|
|
7
8
|
/**
|
|
8
9
|
* Wrap a node-postgres `Pool`/`Client` (or a connection string / config) as a
|
package/dist/server.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { C as CrudOp } from './query-
|
|
1
|
+
import { C as CrudOp } from './query-C2tqtwBQ.js';
|
|
2
2
|
import { S as SchemaDef } from './schema-BNM6bks7.js';
|
|
3
|
-
import { M as
|
|
3
|
+
import { M as MutationDef, Q as QueryDef } from './custom-JYDcHl9n.js';
|
|
4
|
+
import '@standard-schema/spec';
|
|
4
5
|
|
|
5
6
|
/** A transaction handle: run a parameterized SQL statement. */
|
|
6
7
|
interface DBTransaction {
|
|
@@ -26,7 +27,7 @@ declare class PushProcessor<Ctx = unknown> {
|
|
|
26
27
|
schema: SchemaDef;
|
|
27
28
|
context: ContextFn<Ctx>;
|
|
28
29
|
});
|
|
29
|
-
process(mutators: Record<string,
|
|
30
|
+
process(mutators: Record<string, MutationDef>, request: Request): Promise<Response>;
|
|
30
31
|
}
|
|
31
32
|
/** Resolves named queries forwarded to your query endpoint. One line per route:
|
|
32
33
|
* `POST: ({request}) => queryProcessor.process(queries, request)`. */
|
package/dist/server.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { collectOps } from './chunk-
|
|
1
|
+
import { validateArgs, collectOps } from './chunk-EX4WSUC3.js';
|
|
2
2
|
|
|
3
3
|
// server/src/index.ts
|
|
4
4
|
var ident = (s) => '"' + s.replace(/"/g, '""') + '"';
|
|
@@ -52,7 +52,8 @@ var PushProcessor = class {
|
|
|
52
52
|
[m.clientID, m.id]
|
|
53
53
|
);
|
|
54
54
|
if (advanced.length === 0) continue;
|
|
55
|
-
|
|
55
|
+
const args = await validateArgs(def.args, m.args?.[0]);
|
|
56
|
+
for (const op of collectOps(this.#schema, def, args, ctx)) {
|
|
56
57
|
await applyCrudOp(tx, op);
|
|
57
58
|
}
|
|
58
59
|
}
|
|
@@ -71,7 +72,8 @@ var QueryProcessor = class {
|
|
|
71
72
|
const body = await request.json();
|
|
72
73
|
const def = queries[body.name];
|
|
73
74
|
if (!def) return new Response("unknown query", { status: 404 });
|
|
74
|
-
const
|
|
75
|
+
const args = await validateArgs(def.args, (body.args ?? [])[0]);
|
|
76
|
+
const ast = def.handler({ args, ctx }).ast();
|
|
75
77
|
return Response.json({ ast });
|
|
76
78
|
}
|
|
77
79
|
};
|
package/dist/server.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../server/src/index.ts"],"names":[],"mappings":";;;AAyBA,IAAM,KAAA,GAAQ,CAAC,CAAA,KAAc,GAAA,GAAM,EAAE,OAAA,CAAQ,IAAA,EAAM,IAAI,CAAA,GAAI,GAAA;AAI3D,eAAsB,WAAA,CAAY,IAAmB,EAAA,EAA2B;AAC9E,EAAA,MAAM,QAAQ,EAAA,CAAG,KAAA;AACjB,EAAA,IAAI,EAAA,CAAG,EAAA,KAAO,QAAA,IAAY,EAAA,CAAG,OAAO,QAAA,EAAU;AAC5C,IAAA,MAAM,IAAA,GAAO,MAAA,CAAO,IAAA,CAAK,KAAK,CAAA;AAC9B,IAAA,MAAM,YAAA,GAAe,IAAA,CAAK,GAAA,CAAI,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,CAAA,EAAI,CAAA,GAAI,CAAC,CAAA,CAAE,CAAA,CAAE,IAAA,CAAK,IAAI,CAAA;AAC9D,IAAA,IAAI,GAAA,GAAM,CAAA,YAAA,EAAe,KAAA,CAAM,EAAA,CAAG,SAAS,CAAC,CAAA,EAAA,EAAK,IAAA,CAAK,GAAA,CAAI,KAAK,CAAA,CAAE,IAAA,CAAK,IAAI,CAAC,aAAa,YAAY,CAAA,CAAA,CAAA;AACpG,IAAA,IAAI,EAAA,CAAG,OAAO,QAAA,EAAU;AACtB,MAAA,MAAM,GAAA,GAAM,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,EAAA,CAAG,UAAA,CAAW,QAAA,CAAS,CAAC,CAAC,CAAA;AACzD,MAAA,GAAA,IACE,CAAA,cAAA,EAAiB,EAAA,CAAG,UAAA,CAAW,GAAA,CAAI,KAAK,CAAA,CAAE,IAAA,CAAK,IAAI,CAAC,CAAA,KAAA,CAAA,IACnD,GAAA,CAAI,MAAA,GAAS,cAAc,GAAA,CAAI,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,EAAG,KAAA,CAAM,CAAC,CAAC,CAAA,UAAA,EAAa,KAAA,CAAM,CAAC,CAAC,CAAA,CAAE,CAAA,CAAE,IAAA,CAAK,IAAI,CAAC,CAAA,CAAA,GAAK,SAAA,CAAA;AAAA,IAClG;AACA,IAAA,MAAM,EAAA,CAAG,KAAA,CAAM,GAAA,EAAK,IAAA,CAAK,GAAA,CAAI,CAAC,CAAA,KAAM,KAAA,CAAM,CAAC,CAAC,CAAC,CAAA;AAAA,EAC/C,CAAA,MAAA,IAAW,EAAA,CAAG,EAAA,KAAO,QAAA,EAAU;AAC7B,IAAA,MAAM,GAAA,GAAM,MAAA,CAAO,IAAA,CAAK,KAAK,CAAA,CAAE,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,EAAA,CAAG,UAAA,CAAW,QAAA,CAAS,CAAC,CAAC,CAAA;AACvE,IAAA,MAAM,GAAA,GACJ,UAAU,KAAA,CAAM,EAAA,CAAG,SAAS,CAAC,CAAA,KAAA,EAAQ,IAAI,GAAA,CAAI,CAAC,GAAG,CAAA,KAAM,CAAA,EAAG,MAAM,CAAC,CAAC,KAAK,CAAA,GAAI,CAAC,EAAE,CAAA,CAAE,IAAA,CAAK,IAAI,CAAC,CAAA,OAAA,EACjF,GAAG,UAAA,CAAW,GAAA,CAAI,CAAC,CAAA,EAAG,CAAA,KAAM,GAAG,KAAA,CAAM,CAAC,CAAC,CAAA,EAAA,EAAK,GAAA,CAAI,SAAS,CAAA,GAAI,CAAC,EAAE,CAAA,CAAE,IAAA,CAAK,OAAO,CAAC,CAAA,CAAA;AAC1F,IAAA,MAAM,EAAA,CAAG,MAAM,GAAA,EAAK,CAAC,GAAG,GAAA,CAAI,GAAA,CAAI,CAAC,CAAA,KAAM,KAAA,CAAM,CAAC,CAAC,CAAA,EAAG,GAAG,EAAA,CAAG,UAAA,CAAW,GAAA,CAAI,CAAC,MAAM,KAAA,CAAM,CAAC,CAAC,CAAC,CAAC,CAAA;AAAA,EAC1F,CAAA,MAAA,IAAW,EAAA,CAAG,EAAA,KAAO,QAAA,EAAU;AAC7B,IAAA,MAAM,GAAA,GAAM,CAAA,YAAA,EAAe,KAAA,CAAM,EAAA,CAAG,SAAS,CAAC,CAAA,OAAA,EAAU,EAAA,CAAG,UAAA,CAAW,GAAA,CAAI,CAAC,CAAA,EAAG,MAAM,CAAA,EAAG,KAAA,CAAM,CAAC,CAAC,CAAA,EAAA,EAAK,CAAA,GAAI,CAAC,CAAA,CAAE,CAAA,CAAE,IAAA,CAAK,OAAO,CAAC,CAAA,CAAA;AAC1H,IAAA,MAAM,EAAA,CAAG,KAAA,CAAM,GAAA,EAAK,EAAA,CAAG,UAAA,CAAW,GAAA,CAAI,CAAC,CAAA,KAAM,KAAA,CAAM,CAAC,CAAC,CAAC,CAAA;AAAA,EACxD;AACF;AAIO,IAAM,gBAAN,MAAmC;AAAA,EAC/B,WAAA;AAAA,EACA,OAAA;AAAA,EACA,QAAA;AAAA,EACT,YAAA,GAAe,KAAA;AAAA,EAEf,YAAY,IAAA,EAAgF;AAC1F,IAAA,IAAA,CAAK,cAAc,IAAA,CAAK,UAAA;AACxB,IAAA,IAAA,CAAK,UAAU,IAAA,CAAK,MAAA;AACpB,IAAA,IAAA,CAAK,WAAW,IAAA,CAAK,OAAA;AAAA,EACvB;AAAA,EAEA,MAAM,OAAA,CAAQ,QAAA,EAAsC,OAAA,EAAqC;AACvF,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,QAAA,CAAS,OAAO,CAAA;AACvC,IAAA,IAAI,GAAA,IAAO,MAAM,OAAO,IAAI,SAAS,cAAA,EAAgB,EAAE,MAAA,EAAQ,GAAA,EAAK,CAAA;AACpE,IAAA,MAAM,IAAA,GAAO,MAAM,OAAA,CAAQ,IAAA,EAAK;AAChC,IAAA,MAAM,IAAA,CAAK,WAAA,CAAY,WAAA,CAAY,OAAO,EAAA,KAAO;AAC/C,MAAA,IAAI,CAAC,KAAK,YAAA,EAAc;AACtB,QAAA,MAAM,EAAA,CAAG,KAAA;AAAA,UACP,kHAAA;AAAA,UAEA;AAAC,SACH;AACA,QAAA,IAAA,CAAK,YAAA,GAAe,IAAA;AAAA,MACtB;AACA,MAAA,KAAA,MAAW,CAAA,IAAM,IAAA,CAAK,SAAA,IAAa,EAAC,EAA0E;AAC5G,QAAA,MAAM,GAAA,GAAM,QAAA,CAAS,CAAA,CAAE,IAAI,CAAA;AAC3B,QAAA,IAAI,CAAC,GAAA,EAAK;AAKV,QAAA,MAAM,QAAA,GAAW,MAAM,EAAA,CAAG,KAAA;AAAA,UACxB,mQAAA;AAAA,UAGA,CAAC,CAAA,CAAE,QAAA,EAAU,CAAA,CAAE,EAAE;AAAA,SACnB;AACA,QAAA,IAAI,QAAA,CAAS,WAAW,CAAA,EAAG;AAC3B,QAAA,KAAA,MAAW,EAAA,IAAM,UAAA,CAAW,IAAA,CAAK,OAAA,EAAS,GAAA,EAAK,EAAE,IAAA,GAAO,CAAC,CAAA,EAAG,GAAG,CAAA,EAAG;AAChE,UAAA,MAAM,WAAA,CAAY,IAAI,EAAE,CAAA;AAAA,QAC1B;AAAA,MACF;AAAA,IACF,CAAC,CAAA;AACD,IAAA,OAAO,QAAA,CAAS,IAAA,CAAK,EAAE,CAAA;AAAA,EACzB;AACF;AAIO,IAAM,iBAAN,MAAoC;AAAA,EAChC,QAAA;AAAA,EAET,YAAY,IAAA,EAAmC;AAC7C,IAAA,IAAA,CAAK,WAAW,IAAA,CAAK,OAAA;AAAA,EACvB;AAAA,EAEA,MAAM,OAAA,CAAQ,OAAA,EAAmC,OAAA,EAAqC;AACpF,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,QAAA,CAAS,OAAO,CAAA;AACvC,IAAA,IAAI,GAAA,IAAO,MAAM,OAAO,IAAI,SAAS,cAAA,EAAgB,EAAE,MAAA,EAAQ,GAAA,EAAK,CAAA;AACpE,IAAA,MAAM,IAAA,GAAO,MAAM,OAAA,CAAQ,IAAA,EAAK;AAChC,IAAA,MAAM,GAAA,GAAM,OAAA,CAAQ,IAAA,CAAK,IAAI,CAAA;AAC7B,IAAA,IAAI,CAAC,KAAK,OAAO,IAAI,SAAS,eAAA,EAAiB,EAAE,MAAA,EAAQ,GAAA,EAAK,CAAA;AAC9D,IAAA,MAAM,GAAA,GAAM,GAAA,CAAI,EAAE,IAAA,EAAA,CAAO,IAAA,CAAK,IAAA,IAAQ,EAAC,EAAG,CAAC,CAAA,EAAG,GAAA,EAAK,EAAE,GAAA,EAAI;AACzD,IAAA,OAAO,QAAA,CAAS,IAAA,CAAK,EAAE,GAAA,EAAK,CAAA;AAAA,EAC9B;AACF","file":"server.js","sourcesContent":["// @orbit/server — server-side helpers for the endpoints orbit-cache forwards to\n// (push + query). Mirrors Zero's `@rocicorp/zero/server`: a `PushProcessor`\n// runs your custom mutators against a pluggable database `connection`, and a\n// `QueryProcessor` resolves named queries. The database is abstracted behind a\n// small `DBConnection` interface, so any adapter works (a `pg` one ships in\n// `@orbit/server/pg`; a Drizzle/Kysely/etc. adapter just implements the same\n// interface).\n\nimport { collectOps, type CrudOp, type MutatorDef, type QueryDef, type SchemaDef } from '../../client/src/index.ts';\n\n/** A transaction handle: run a parameterized SQL statement. */\nexport interface DBTransaction {\n query(sql: string, params: unknown[]): Promise<unknown[]>;\n}\n\n/** A database connection: run work inside a transaction. Implement this to add\n * a new adapter (the built-in `@orbit/server/pg` adapter implements it). */\nexport interface DBConnection {\n transaction<R>(fn: (tx: DBTransaction) => Promise<R>): Promise<R>;\n}\n\n/** Derive the authenticated context from the forwarded request (return `null`\n * to reject with 401). This is where auth lives. */\nexport type ContextFn<Ctx> = (request: Request) => Ctx | null | Promise<Ctx | null>;\n\nconst ident = (s: string) => '\"' + s.replace(/\"/g, '\"\"') + '\"';\n\n/** Apply one CRUD op as parameterized SQL via the adapter's `query`. The SQL is\n * generated here (shared); the adapter only executes it. */\nexport async function applyCrudOp(tx: DBTransaction, op: CrudOp): Promise<void> {\n const value = op.value as Record<string, unknown>;\n if (op.op === 'insert' || op.op === 'upsert') {\n const cols = Object.keys(value);\n const placeholders = cols.map((_, i) => `$${i + 1}`).join(', ');\n let sql = `INSERT INTO ${ident(op.tableName)} (${cols.map(ident).join(', ')}) VALUES (${placeholders})`;\n if (op.op === 'upsert') {\n const set = cols.filter((c) => !op.primaryKey.includes(c));\n sql +=\n ` ON CONFLICT (${op.primaryKey.map(ident).join(', ')}) DO ` +\n (set.length ? `UPDATE SET ${set.map((c) => `${ident(c)}=EXCLUDED.${ident(c)}`).join(', ')}` : 'NOTHING');\n }\n await tx.query(sql, cols.map((c) => value[c]));\n } else if (op.op === 'update') {\n const set = Object.keys(value).filter((c) => !op.primaryKey.includes(c));\n const sql =\n `UPDATE ${ident(op.tableName)} SET ${set.map((c, i) => `${ident(c)}=$${i + 1}`).join(', ')} ` +\n `WHERE ${op.primaryKey.map((c, i) => `${ident(c)}=$${set.length + i + 1}`).join(' AND ')}`;\n await tx.query(sql, [...set.map((c) => value[c]), ...op.primaryKey.map((c) => value[c])]);\n } else if (op.op === 'delete') {\n const sql = `DELETE FROM ${ident(op.tableName)} WHERE ${op.primaryKey.map((c, i) => `${ident(c)}=$${i + 1}`).join(' AND ')}`;\n await tx.query(sql, op.primaryKey.map((c) => value[c]));\n }\n}\n\n/** Runs custom mutators forwarded to your push endpoint. One line per route:\n * `POST: ({request}) => pushProcessor.process(mutators, request)`. */\nexport class PushProcessor<Ctx = unknown> {\n readonly #connection: DBConnection;\n readonly #schema: SchemaDef;\n readonly #context: ContextFn<Ctx>;\n #schemaReady = false;\n\n constructor(opts: { connection: DBConnection; schema: SchemaDef; context: ContextFn<Ctx> }) {\n this.#connection = opts.connection;\n this.#schema = opts.schema;\n this.#context = opts.context;\n }\n\n async process(mutators: Record<string, MutatorDef>, request: Request): Promise<Response> {\n const ctx = await this.#context(request);\n if (ctx == null) return new Response('unauthorized', { status: 401 });\n const body = await request.json();\n await this.#connection.transaction(async (tx) => {\n if (!this.#schemaReady) {\n await tx.query(\n 'CREATE TABLE IF NOT EXISTS orbit_client_mutations (' +\n 'client_id text PRIMARY KEY, last_mutation_id bigint NOT NULL)',\n [],\n );\n this.#schemaReady = true;\n }\n for (const m of (body.mutations ?? []) as { name: string; args?: unknown[]; id: number; clientID: string }[]) {\n const def = mutators[m.name];\n if (!def) continue;\n // Exactly-once: advance the client's lastMutationID, skipping mutations\n // already applied (a client re-sends unconfirmed mutations on reconnect —\n // to this or, in multinode, any other node). The WHERE guard makes the\n // advance + skip atomic in this transaction.\n const advanced = await tx.query(\n 'INSERT INTO orbit_client_mutations (client_id, last_mutation_id) VALUES ($1, $2) ' +\n 'ON CONFLICT (client_id) DO UPDATE SET last_mutation_id = EXCLUDED.last_mutation_id ' +\n 'WHERE orbit_client_mutations.last_mutation_id < EXCLUDED.last_mutation_id RETURNING client_id',\n [m.clientID, m.id],\n );\n if (advanced.length === 0) continue; // already applied — skip\n for (const op of collectOps(this.#schema, def, m.args?.[0], ctx)) {\n await applyCrudOp(tx, op);\n }\n }\n });\n return Response.json({});\n }\n}\n\n/** Resolves named queries forwarded to your query endpoint. One line per route:\n * `POST: ({request}) => queryProcessor.process(queries, request)`. */\nexport class QueryProcessor<Ctx = unknown> {\n readonly #context: ContextFn<Ctx>;\n\n constructor(opts: { context: ContextFn<Ctx> }) {\n this.#context = opts.context;\n }\n\n async process(queries: Record<string, QueryDef>, request: Request): Promise<Response> {\n const ctx = await this.#context(request);\n if (ctx == null) return new Response('unauthorized', { status: 401 });\n const body = await request.json();\n const def = queries[body.name];\n if (!def) return new Response('unknown query', { status: 404 });\n const ast = def({ args: (body.args ?? [])[0], ctx }).ast();\n return Response.json({ ast });\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../server/src/index.ts"],"names":[],"mappings":"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","file":"server.js","sourcesContent":["// @orbit/server — server-side helpers for the endpoints orbit-cache forwards to\n// (push + query). Mirrors Zero's `@rocicorp/zero/server`: a `PushProcessor`\n// runs your custom mutators against a pluggable database `connection`, and a\n// `QueryProcessor` resolves named queries. The database is abstracted behind a\n// small `DBConnection` interface, so any adapter works (a `pg` one ships in\n// `@orbit/server/pg`; a Drizzle/Kysely/etc. adapter just implements the same\n// interface).\n\nimport {\n collectOps,\n validateArgs,\n type CrudOp,\n type MutationDef,\n type QueryDef,\n type SchemaDef,\n} from '../../client/src/index.ts';\n\n/** A transaction handle: run a parameterized SQL statement. */\nexport interface DBTransaction {\n query(sql: string, params: unknown[]): Promise<unknown[]>;\n}\n\n/** A database connection: run work inside a transaction. Implement this to add\n * a new adapter (the built-in `@orbit/server/pg` adapter implements it). */\nexport interface DBConnection {\n transaction<R>(fn: (tx: DBTransaction) => Promise<R>): Promise<R>;\n}\n\n/** Derive the authenticated context from the forwarded request (return `null`\n * to reject with 401). This is where auth lives. */\nexport type ContextFn<Ctx> = (request: Request) => Ctx | null | Promise<Ctx | null>;\n\nconst ident = (s: string) => '\"' + s.replace(/\"/g, '\"\"') + '\"';\n\n/** Apply one CRUD op as parameterized SQL via the adapter's `query`. The SQL is\n * generated here (shared); the adapter only executes it. */\nexport async function applyCrudOp(tx: DBTransaction, op: CrudOp): Promise<void> {\n const value = op.value as Record<string, unknown>;\n if (op.op === 'insert' || op.op === 'upsert') {\n const cols = Object.keys(value);\n const placeholders = cols.map((_, i) => `$${i + 1}`).join(', ');\n let sql = `INSERT INTO ${ident(op.tableName)} (${cols.map(ident).join(', ')}) VALUES (${placeholders})`;\n if (op.op === 'upsert') {\n const set = cols.filter((c) => !op.primaryKey.includes(c));\n sql +=\n ` ON CONFLICT (${op.primaryKey.map(ident).join(', ')}) DO ` +\n (set.length ? `UPDATE SET ${set.map((c) => `${ident(c)}=EXCLUDED.${ident(c)}`).join(', ')}` : 'NOTHING');\n }\n await tx.query(sql, cols.map((c) => value[c]));\n } else if (op.op === 'update') {\n const set = Object.keys(value).filter((c) => !op.primaryKey.includes(c));\n const sql =\n `UPDATE ${ident(op.tableName)} SET ${set.map((c, i) => `${ident(c)}=$${i + 1}`).join(', ')} ` +\n `WHERE ${op.primaryKey.map((c, i) => `${ident(c)}=$${set.length + i + 1}`).join(' AND ')}`;\n await tx.query(sql, [...set.map((c) => value[c]), ...op.primaryKey.map((c) => value[c])]);\n } else if (op.op === 'delete') {\n const sql = `DELETE FROM ${ident(op.tableName)} WHERE ${op.primaryKey.map((c, i) => `${ident(c)}=$${i + 1}`).join(' AND ')}`;\n await tx.query(sql, op.primaryKey.map((c) => value[c]));\n }\n}\n\n/** Runs custom mutators forwarded to your push endpoint. One line per route:\n * `POST: ({request}) => pushProcessor.process(mutators, request)`. */\nexport class PushProcessor<Ctx = unknown> {\n readonly #connection: DBConnection;\n readonly #schema: SchemaDef;\n readonly #context: ContextFn<Ctx>;\n #schemaReady = false;\n\n constructor(opts: { connection: DBConnection; schema: SchemaDef; context: ContextFn<Ctx> }) {\n this.#connection = opts.connection;\n this.#schema = opts.schema;\n this.#context = opts.context;\n }\n\n async process(mutators: Record<string, MutationDef>, request: Request): Promise<Response> {\n const ctx = await this.#context(request);\n if (ctx == null) return new Response('unauthorized', { status: 401 });\n const body = await request.json();\n await this.#connection.transaction(async (tx) => {\n if (!this.#schemaReady) {\n await tx.query(\n 'CREATE TABLE IF NOT EXISTS orbit_client_mutations (' +\n 'client_id text PRIMARY KEY, last_mutation_id bigint NOT NULL)',\n [],\n );\n this.#schemaReady = true;\n }\n for (const m of (body.mutations ?? []) as { name: string; args?: unknown[]; id: number; clientID: string }[]) {\n const def = mutators[m.name];\n if (!def) continue;\n // Exactly-once: advance the client's lastMutationID, skipping mutations\n // already applied (a client re-sends unconfirmed mutations on reconnect —\n // to this or, in multinode, any other node). The WHERE guard makes the\n // advance + skip atomic in this transaction.\n const advanced = await tx.query(\n 'INSERT INTO orbit_client_mutations (client_id, last_mutation_id) VALUES ($1, $2) ' +\n 'ON CONFLICT (client_id) DO UPDATE SET last_mutation_id = EXCLUDED.last_mutation_id ' +\n 'WHERE orbit_client_mutations.last_mutation_id < EXCLUDED.last_mutation_id RETURNING client_id',\n [m.clientID, m.id],\n );\n if (advanced.length === 0) continue; // already applied — skip\n // Validate the client-supplied args against the def's schema (untrusted input).\n const args = await validateArgs(def.args, m.args?.[0]);\n for (const op of collectOps(this.#schema, def, args, ctx)) {\n await applyCrudOp(tx, op);\n }\n }\n });\n return Response.json({});\n }\n}\n\n/** Resolves named queries forwarded to your query endpoint. One line per route:\n * `POST: ({request}) => queryProcessor.process(queries, request)`. */\nexport class QueryProcessor<Ctx = unknown> {\n readonly #context: ContextFn<Ctx>;\n\n constructor(opts: { context: ContextFn<Ctx> }) {\n this.#context = opts.context;\n }\n\n async process(queries: Record<string, QueryDef>, request: Request): Promise<Response> {\n const ctx = await this.#context(request);\n if (ctx == null) return new Response('unauthorized', { status: 401 });\n const body = await request.json();\n const def = queries[body.name];\n if (!def) return new Response('unknown query', { status: 404 });\n const args = await validateArgs(def.args, (body.args ?? [])[0]);\n const ast = def.handler({ args, ctx }).ast();\n return Response.json({ ast });\n }\n}\n"]}
|