@danielfgray/pg-sourcerer 0.2.2 → 0.4.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/bin/pgsourcerer +2 -0
- package/dist/__tests__/fixtures/index.d.ts +15 -0
- package/dist/__tests__/fixtures/index.d.ts.map +1 -0
- package/dist/__tests__/fixtures/index.js +19 -0
- package/dist/__tests__/fixtures/index.js.map +1 -0
- package/dist/__tests__/fixtures/introspection.json +40522 -0
- package/dist/cli.d.ts +0 -1
- package/dist/cli.js +7 -46
- package/dist/cli.js.map +1 -1
- package/dist/config.d.ts +38 -5
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +13 -2
- package/dist/config.js.map +1 -1
- package/dist/{lib/conjure.d.ts → conjure/index.d.ts} +62 -3
- package/dist/conjure/index.d.ts.map +1 -0
- package/dist/{lib/conjure.js → conjure/index.js} +124 -3
- package/dist/conjure/index.js.map +1 -0
- package/dist/conjure/signature.d.ts +85 -0
- package/dist/conjure/signature.d.ts.map +1 -0
- package/dist/conjure/signature.js +130 -0
- package/dist/conjure/signature.js.map +1 -0
- package/dist/conjure/types.d.ts +97 -0
- package/dist/conjure/types.d.ts.map +1 -0
- package/dist/conjure/types.js +206 -0
- package/dist/conjure/types.js.map +1 -0
- package/dist/errors.d.ts +114 -139
- package/dist/errors.d.ts.map +1 -1
- package/dist/errors.js +82 -36
- package/dist/errors.js.map +1 -1
- package/dist/generate.d.ts +45 -46
- package/dist/generate.d.ts.map +1 -1
- package/dist/generate.js +86 -59
- package/dist/generate.js.map +1 -1
- package/dist/hex/builder.d.ts +12 -0
- package/dist/hex/builder.d.ts.map +1 -0
- package/dist/hex/builder.js +64 -0
- package/dist/hex/builder.js.map +1 -0
- package/dist/hex/ddl.d.ts +53 -0
- package/dist/hex/ddl.d.ts.map +1 -0
- package/dist/hex/ddl.js +306 -0
- package/dist/hex/ddl.js.map +1 -0
- package/dist/hex/index.d.ts +105 -0
- package/dist/hex/index.d.ts.map +1 -0
- package/dist/hex/index.js +81 -0
- package/dist/hex/index.js.map +1 -0
- package/dist/hex/primitives.d.ts +23 -0
- package/dist/hex/primitives.d.ts.map +1 -0
- package/dist/hex/primitives.js +38 -0
- package/dist/hex/primitives.js.map +1 -0
- package/dist/hex/query.d.ts +116 -0
- package/dist/hex/query.d.ts.map +1 -0
- package/dist/hex/query.js +219 -0
- package/dist/hex/query.js.map +1 -0
- package/dist/hex/types.d.ts +287 -0
- package/dist/hex/types.d.ts.map +1 -0
- package/dist/hex/types.js +431 -0
- package/dist/hex/types.js.map +1 -0
- package/dist/index.d.ts +17 -25
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +33 -44
- package/dist/index.js.map +1 -1
- package/dist/init.d.ts.map +1 -1
- package/dist/init.js +76 -140
- package/dist/init.js.map +1 -1
- package/dist/ir/extensions/queries.d.ts +6 -6
- package/dist/ir/extensions/queries.d.ts.map +1 -1
- package/dist/ir/extensions/queries.js +6 -4
- package/dist/ir/extensions/queries.js.map +1 -1
- package/dist/ir/extensions/schema-builder.d.ts.map +1 -1
- package/dist/ir/extensions/schema-builder.js.map +1 -1
- package/dist/ir/index.d.ts.map +1 -1
- package/dist/ir/index.js.map +1 -1
- package/dist/ir/relation-graph.d.ts.map +1 -1
- package/dist/ir/relation-graph.js +8 -8
- package/dist/ir/relation-graph.js.map +1 -1
- package/dist/ir/semantic-ir.d.ts +38 -0
- package/dist/ir/semantic-ir.d.ts.map +1 -1
- package/dist/ir/semantic-ir.js +50 -2
- package/dist/ir/semantic-ir.js.map +1 -1
- package/dist/ir/smart-tags.d.ts.map +1 -1
- package/dist/ir/smart-tags.js.map +1 -1
- package/dist/lib/field-utils.d.ts.map +1 -1
- package/dist/lib/field-utils.js +7 -7
- package/dist/lib/field-utils.js.map +1 -1
- package/dist/lib/join-graph.d.ts +95 -0
- package/dist/lib/join-graph.d.ts.map +1 -0
- package/dist/lib/join-graph.js +305 -0
- package/dist/lib/join-graph.js.map +1 -0
- package/dist/lib/picker.d.ts +60 -0
- package/dist/lib/picker.d.ts.map +1 -0
- package/dist/lib/picker.js +325 -0
- package/dist/lib/picker.js.map +1 -0
- package/dist/plugins/arktype.d.ts +20 -24
- package/dist/plugins/arktype.d.ts.map +1 -1
- package/dist/plugins/arktype.js +462 -386
- package/dist/plugins/arktype.js.map +1 -1
- package/dist/plugins/effect/http.d.ts +7 -0
- package/dist/plugins/effect/http.d.ts.map +1 -0
- package/dist/plugins/effect/http.js +460 -0
- package/dist/plugins/effect/http.js.map +1 -0
- package/dist/plugins/effect/index.d.ts +22 -0
- package/dist/plugins/effect/index.d.ts.map +1 -0
- package/dist/plugins/effect/index.js +65 -0
- package/dist/plugins/effect/index.js.map +1 -0
- package/dist/plugins/effect/models.d.ts +6 -0
- package/dist/plugins/effect/models.d.ts.map +1 -0
- package/dist/plugins/effect/models.js +116 -0
- package/dist/plugins/effect/models.js.map +1 -0
- package/dist/plugins/effect/repos.d.ts +21 -0
- package/dist/plugins/effect/repos.d.ts.map +1 -0
- package/dist/plugins/effect/repos.js +131 -0
- package/dist/plugins/effect/repos.js.map +1 -0
- package/dist/plugins/effect/schemas.d.ts +7 -0
- package/dist/plugins/effect/schemas.d.ts.map +1 -0
- package/dist/plugins/effect/schemas.js +75 -0
- package/dist/plugins/effect/schemas.js.map +1 -0
- package/dist/plugins/effect/shared.d.ts +116 -0
- package/dist/plugins/effect/shared.d.ts.map +1 -0
- package/dist/plugins/effect/shared.js +164 -0
- package/dist/plugins/effect/shared.js.map +1 -0
- package/dist/plugins/http-elysia.d.ts +20 -27
- package/dist/plugins/http-elysia.d.ts.map +1 -1
- package/dist/plugins/http-elysia.js +350 -475
- package/dist/plugins/http-elysia.js.map +1 -1
- package/dist/plugins/http-express.d.ts +20 -31
- package/dist/plugins/http-express.d.ts.map +1 -1
- package/dist/plugins/http-express.js +281 -268
- package/dist/plugins/http-express.js.map +1 -1
- package/dist/plugins/http-hono.d.ts +17 -33
- package/dist/plugins/http-hono.d.ts.map +1 -1
- package/dist/plugins/http-hono.js +317 -341
- package/dist/plugins/http-hono.js.map +1 -1
- package/dist/plugins/http-orpc.d.ts +34 -33
- package/dist/plugins/http-orpc.d.ts.map +1 -1
- package/dist/plugins/http-orpc.js +345 -257
- package/dist/plugins/http-orpc.js.map +1 -1
- package/dist/plugins/http-trpc.d.ts +33 -35
- package/dist/plugins/http-trpc.d.ts.map +1 -1
- package/dist/plugins/http-trpc.js +337 -241
- package/dist/plugins/http-trpc.js.map +1 -1
- package/dist/plugins/kysely.d.ts +54 -59
- package/dist/plugins/kysely.d.ts.map +1 -1
- package/dist/plugins/kysely.js +826 -687
- package/dist/plugins/kysely.js.map +1 -1
- package/dist/plugins/sql-queries.d.ts +38 -44
- package/dist/plugins/sql-queries.d.ts.map +1 -1
- package/dist/plugins/sql-queries.js +497 -897
- package/dist/plugins/sql-queries.js.map +1 -1
- package/dist/plugins/types.d.ts +12 -20
- package/dist/plugins/types.d.ts.map +1 -1
- package/dist/plugins/types.js +84 -227
- package/dist/plugins/types.js.map +1 -1
- package/dist/plugins/valibot.d.ts +7 -44
- package/dist/plugins/valibot.d.ts.map +1 -1
- package/dist/plugins/valibot.js +376 -382
- package/dist/plugins/valibot.js.map +1 -1
- package/dist/plugins/zod.d.ts +20 -24
- package/dist/plugins/zod.d.ts.map +1 -1
- package/dist/plugins/zod.js +370 -367
- package/dist/plugins/zod.js.map +1 -1
- package/dist/runtime/emit.d.ts +64 -0
- package/dist/runtime/emit.d.ts.map +1 -0
- package/dist/runtime/emit.js +445 -0
- package/dist/runtime/emit.js.map +1 -0
- package/dist/runtime/errors.d.ts +36 -0
- package/dist/runtime/errors.d.ts.map +1 -0
- package/dist/runtime/errors.js +29 -0
- package/dist/runtime/errors.js.map +1 -0
- package/dist/runtime/file-assignment.d.ts +161 -0
- package/dist/runtime/file-assignment.d.ts.map +1 -0
- package/dist/runtime/file-assignment.js +195 -0
- package/dist/runtime/file-assignment.js.map +1 -0
- package/dist/runtime/orchestrator.d.ts +62 -0
- package/dist/runtime/orchestrator.d.ts.map +1 -0
- package/dist/runtime/orchestrator.js +99 -0
- package/dist/runtime/orchestrator.js.map +1 -0
- package/dist/runtime/registry.d.ts +268 -0
- package/dist/runtime/registry.d.ts.map +1 -0
- package/dist/runtime/registry.js +436 -0
- package/dist/runtime/registry.js.map +1 -0
- package/dist/runtime/types.d.ts +182 -0
- package/dist/runtime/types.d.ts.map +1 -0
- package/dist/runtime/types.js +2 -0
- package/dist/runtime/types.js.map +1 -0
- package/dist/runtime/validation.d.ts +41 -0
- package/dist/runtime/validation.d.ts.map +1 -0
- package/dist/runtime/validation.js +70 -0
- package/dist/runtime/validation.js.map +1 -0
- package/dist/services/config-loader.d.ts.map +1 -1
- package/dist/services/config-loader.js +15 -6
- package/dist/services/config-loader.js.map +1 -1
- package/dist/services/config.d.ts +55 -25
- package/dist/services/config.d.ts.map +1 -1
- package/dist/services/config.js +60 -34
- package/dist/services/config.js.map +1 -1
- package/dist/services/file-writer.d.ts +3 -3
- package/dist/services/file-writer.d.ts.map +1 -1
- package/dist/services/file-writer.js +6 -8
- package/dist/services/file-writer.js.map +1 -1
- package/dist/services/inflection.d.ts +126 -27
- package/dist/services/inflection.d.ts.map +1 -1
- package/dist/services/inflection.js +300 -72
- package/dist/services/inflection.js.map +1 -1
- package/dist/services/introspection.d.ts.map +1 -1
- package/dist/services/introspection.js +6 -6
- package/dist/services/introspection.js.map +1 -1
- package/dist/services/ir-builder.d.ts.map +1 -1
- package/dist/services/ir-builder.js +73 -77
- package/dist/services/ir-builder.js.map +1 -1
- package/dist/services/ir.d.ts.map +1 -1
- package/dist/services/ir.js.map +1 -1
- package/dist/services/pg-types.d.ts.map +1 -1
- package/dist/services/pg-types.js +3 -3
- package/dist/services/pg-types.js.map +1 -1
- package/dist/services/smart-tags-parser.d.ts.map +1 -1
- package/dist/services/smart-tags-parser.js +4 -4
- package/dist/services/smart-tags-parser.js.map +1 -1
- package/dist/services/type-hints.d.ts.map +1 -1
- package/dist/services/type-hints.js +1 -1
- package/dist/services/type-hints.js.map +1 -1
- package/dist/services/user-module-parser.d.ts +46 -0
- package/dist/services/user-module-parser.d.ts.map +1 -0
- package/dist/services/user-module-parser.js +181 -0
- package/dist/services/user-module-parser.js.map +1 -0
- package/dist/shared/converters.d.ts +60 -0
- package/dist/shared/converters.d.ts.map +1 -0
- package/dist/shared/converters.js +168 -0
- package/dist/shared/converters.js.map +1 -0
- package/dist/shared/query-types.d.ts +95 -0
- package/dist/shared/query-types.d.ts.map +1 -0
- package/dist/shared/query-types.js +9 -0
- package/dist/shared/query-types.js.map +1 -0
- package/dist/testing.d.ts +125 -37
- package/dist/testing.d.ts.map +1 -1
- package/dist/testing.js +134 -42
- package/dist/testing.js.map +1 -1
- package/dist/user-module.d.ts +86 -0
- package/dist/user-module.d.ts.map +1 -0
- package/dist/user-module.js +55 -0
- package/dist/user-module.js.map +1 -0
- package/package.json +10 -6
- package/dist/lib/conjure.d.ts.map +0 -1
- package/dist/lib/conjure.js.map +0 -1
- package/dist/lib/hex.d.ts +0 -119
- package/dist/lib/hex.d.ts.map +0 -1
- package/dist/lib/hex.js +0 -188
- package/dist/lib/hex.js.map +0 -1
- package/dist/plugins/effect.d.ts +0 -53
- package/dist/plugins/effect.d.ts.map +0 -1
- package/dist/plugins/effect.js +0 -1074
- package/dist/plugins/effect.js.map +0 -1
- package/dist/plugins/kysely/queries.d.ts +0 -92
- package/dist/plugins/kysely/queries.d.ts.map +0 -1
- package/dist/plugins/kysely/queries.js +0 -1169
- package/dist/plugins/kysely/queries.js.map +0 -1
- package/dist/plugins/kysely/shared.d.ts +0 -59
- package/dist/plugins/kysely/shared.d.ts.map +0 -1
- package/dist/plugins/kysely/shared.js +0 -247
- package/dist/plugins/kysely/shared.js.map +0 -1
- package/dist/plugins/kysely/types.d.ts +0 -22
- package/dist/plugins/kysely/types.d.ts.map +0 -1
- package/dist/plugins/kysely/types.js +0 -428
- package/dist/plugins/kysely/types.js.map +0 -1
- package/dist/services/artifact-store.d.ts +0 -65
- package/dist/services/artifact-store.d.ts.map +0 -1
- package/dist/services/artifact-store.js +0 -57
- package/dist/services/artifact-store.js.map +0 -1
- package/dist/services/core-providers.d.ts +0 -15
- package/dist/services/core-providers.d.ts.map +0 -1
- package/dist/services/core-providers.js +0 -23
- package/dist/services/core-providers.js.map +0 -1
- package/dist/services/emissions.d.ts +0 -103
- package/dist/services/emissions.d.ts.map +0 -1
- package/dist/services/emissions.js +0 -241
- package/dist/services/emissions.js.map +0 -1
- package/dist/services/execution.d.ts +0 -35
- package/dist/services/execution.d.ts.map +0 -1
- package/dist/services/execution.js +0 -86
- package/dist/services/execution.js.map +0 -1
- package/dist/services/file-builder.d.ts +0 -85
- package/dist/services/file-builder.d.ts.map +0 -1
- package/dist/services/file-builder.js +0 -112
- package/dist/services/file-builder.js.map +0 -1
- package/dist/services/plugin-meta.d.ts +0 -33
- package/dist/services/plugin-meta.d.ts.map +0 -1
- package/dist/services/plugin-meta.js +0 -24
- package/dist/services/plugin-meta.js.map +0 -1
- package/dist/services/plugin-runner.d.ts +0 -42
- package/dist/services/plugin-runner.d.ts.map +0 -1
- package/dist/services/plugin-runner.js +0 -84
- package/dist/services/plugin-runner.js.map +0 -1
- package/dist/services/plugin.d.ts +0 -421
- package/dist/services/plugin.d.ts.map +0 -1
- package/dist/services/plugin.js +0 -197
- package/dist/services/plugin.js.map +0 -1
- package/dist/services/resolution.d.ts +0 -38
- package/dist/services/resolution.d.ts.map +0 -1
- package/dist/services/resolution.js +0 -242
- package/dist/services/resolution.js.map +0 -1
- package/dist/services/service-registry.d.ts +0 -74
- package/dist/services/service-registry.d.ts.map +0 -1
- package/dist/services/service-registry.js +0 -61
- package/dist/services/service-registry.js.map +0 -1
- package/dist/services/symbols.d.ts +0 -144
- package/dist/services/symbols.d.ts.map +0 -1
- package/dist/services/symbols.js +0 -144
- package/dist/services/symbols.js.map +0 -1
package/dist/hex/ddl.js
ADDED
|
@@ -0,0 +1,306 @@
|
|
|
1
|
+
function quoteIdent(name) {
|
|
2
|
+
if (/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(name) && !name.match(/^(true|false|null)$/i)) {
|
|
3
|
+
return name;
|
|
4
|
+
}
|
|
5
|
+
return `"${name.replace(/"/g, '""')}"`;
|
|
6
|
+
}
|
|
7
|
+
function buildSchemaObjectName(name, schema) {
|
|
8
|
+
const parts = name.split(".");
|
|
9
|
+
if (parts.length > 1) {
|
|
10
|
+
return `${quoteIdent(parts[0])}.${quoteIdent(parts[1])}`;
|
|
11
|
+
}
|
|
12
|
+
return schema ? `${quoteIdent(schema)}.${quoteIdent(name)}` : quoteIdent(name);
|
|
13
|
+
}
|
|
14
|
+
function buildColumnDefinition(column) {
|
|
15
|
+
const parts = [quoteIdent(column.name), column.pgType];
|
|
16
|
+
if (column.isIdentity) {
|
|
17
|
+
parts.push("GENERATED");
|
|
18
|
+
if (column.generationKind === "always") {
|
|
19
|
+
parts.push("ALWAYS");
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
parts.push("BY DEFAULT");
|
|
23
|
+
}
|
|
24
|
+
parts.push("AS IDENTITY");
|
|
25
|
+
}
|
|
26
|
+
if (!column.nullable) {
|
|
27
|
+
parts.push("NOT NULL");
|
|
28
|
+
}
|
|
29
|
+
if (column.hasDefault && column.defaultValue !== undefined) {
|
|
30
|
+
parts.push(`DEFAULT ${column.defaultValue}`);
|
|
31
|
+
}
|
|
32
|
+
if (column.isArray) {
|
|
33
|
+
parts[parts.length - 1] += "[]";
|
|
34
|
+
}
|
|
35
|
+
return parts.join(" ");
|
|
36
|
+
}
|
|
37
|
+
function buildIndexColumns(index) {
|
|
38
|
+
if (index.include && index.include.length > 0) {
|
|
39
|
+
const indexCols = index.columns.map(c => quoteIdent(c)).join(", ");
|
|
40
|
+
const includeCols = index.include.map(c => quoteIdent(c)).join(", ");
|
|
41
|
+
return `(${indexCols}) INCLUDE (${includeCols})`;
|
|
42
|
+
}
|
|
43
|
+
return index.columns.map(c => quoteIdent(c)).join(", ");
|
|
44
|
+
}
|
|
45
|
+
function buildIndexSpec(index) {
|
|
46
|
+
const name = index.name ? `CONCURRENTLY ${quoteIdent(index.name)}` : "";
|
|
47
|
+
const unique = index.unique ? "UNIQUE " : "";
|
|
48
|
+
const method = index.method ? ` USING ${index.method.toUpperCase()}` : "";
|
|
49
|
+
const columns = buildIndexColumns(index);
|
|
50
|
+
const where = index.where ? ` WHERE ${index.where}` : "";
|
|
51
|
+
return `${unique}${name}${method} (${columns})${where}`;
|
|
52
|
+
}
|
|
53
|
+
function buildForeignKey(foreignKey) {
|
|
54
|
+
const columns = foreignKey.columns.map(quoteIdent).join(", ");
|
|
55
|
+
const targetParts = foreignKey.targetTable.split(".");
|
|
56
|
+
const target = targetParts.length > 1
|
|
57
|
+
? `${quoteIdent(targetParts[0])}.${quoteIdent(targetParts[1])}`
|
|
58
|
+
: quoteIdent(foreignKey.targetTable);
|
|
59
|
+
const targetColumns = foreignKey.targetColumns.map(quoteIdent).join(", ");
|
|
60
|
+
const actions = [];
|
|
61
|
+
if (foreignKey.onDelete) {
|
|
62
|
+
actions.push(`ON DELETE ${foreignKey.onDelete.toUpperCase().replace(/ /g, " ")}`);
|
|
63
|
+
}
|
|
64
|
+
if (foreignKey.onUpdate) {
|
|
65
|
+
actions.push(`ON UPDATE ${foreignKey.onUpdate.toUpperCase().replace(/ /g, " ")}`);
|
|
66
|
+
}
|
|
67
|
+
const fkName = foreignKey.name ? `CONSTRAINT ${quoteIdent(foreignKey.name)} ` : "";
|
|
68
|
+
return `${fkName}FOREIGN KEY (${columns}) REFERENCES ${target} (${targetColumns})${actions.length > 0 ? " " + actions.join(" ") : ""}`;
|
|
69
|
+
}
|
|
70
|
+
function buildConstraint(constraint) {
|
|
71
|
+
switch (constraint.kind) {
|
|
72
|
+
case "primaryKey": {
|
|
73
|
+
const name = constraint.name ? `CONSTRAINT ${quoteIdent(constraint.name)}` : "";
|
|
74
|
+
const columns = constraint.columns.map(quoteIdent).join(", ");
|
|
75
|
+
return `${name} PRIMARY KEY (${columns})`;
|
|
76
|
+
}
|
|
77
|
+
case "unique": {
|
|
78
|
+
const name = constraint.name ? `CONSTRAINT ${quoteIdent(constraint.name)}` : "";
|
|
79
|
+
const columns = constraint.columns.map(quoteIdent).join(", ");
|
|
80
|
+
const where = constraint.where ? ` WHERE ${constraint.where}` : "";
|
|
81
|
+
return `${name} UNIQUE (${columns})${where}`;
|
|
82
|
+
}
|
|
83
|
+
case "exclude": {
|
|
84
|
+
const name = constraint.name ? `CONSTRAINT ${quoteIdent(constraint.name)}` : "";
|
|
85
|
+
const using = constraint.elements.some(e => e.opclass) ? "USING gist" : "";
|
|
86
|
+
const elements = constraint.elements
|
|
87
|
+
.map(e => {
|
|
88
|
+
if (e.opclass) {
|
|
89
|
+
return `${quoteIdent(e.column)} WITH ${e.opclass}`;
|
|
90
|
+
}
|
|
91
|
+
return quoteIdent(e.column);
|
|
92
|
+
})
|
|
93
|
+
.join(", ");
|
|
94
|
+
return `${name} EXCLUDE ${using} (${elements})`;
|
|
95
|
+
}
|
|
96
|
+
default:
|
|
97
|
+
throw new Error(`Unknown constraint kind: ${constraint.kind}`);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
export function createTable(_ir, spec) {
|
|
101
|
+
const ifNotExists = spec.ifNotExists ? "IF NOT EXISTS " : "";
|
|
102
|
+
const tableName = spec.schema
|
|
103
|
+
? `${quoteIdent(spec.schema)}.${quoteIdent(spec.table)}`
|
|
104
|
+
: quoteIdent(spec.table);
|
|
105
|
+
const lines = [`CREATE TABLE ${ifNotExists}${tableName} (`];
|
|
106
|
+
const columnDefs = spec.columns.map(buildColumnDefinition);
|
|
107
|
+
const constraintDefs = (spec.constraints ?? []).map(buildConstraint);
|
|
108
|
+
const allDefs = [...columnDefs];
|
|
109
|
+
if (spec.primaryKey) {
|
|
110
|
+
const pkName = spec.primaryKey.name ? `CONSTRAINT ${quoteIdent(spec.primaryKey.name)}` : "";
|
|
111
|
+
const pkCols = spec.primaryKey.columns.map(quoteIdent).join(", ");
|
|
112
|
+
allDefs.push(`${pkName} PRIMARY KEY (${pkCols})`);
|
|
113
|
+
}
|
|
114
|
+
allDefs.push(...constraintDefs);
|
|
115
|
+
if (spec.indexes && spec.indexes.length > 0) {
|
|
116
|
+
for (const idx of spec.indexes) {
|
|
117
|
+
if (idx.isPrimaryKey)
|
|
118
|
+
continue;
|
|
119
|
+
allDefs.push(` CONSTRAINT ${quoteIdent(idx.name)} CHECK (true)`);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
lines.push(allDefs.map(d => ` ${d}`).join(",\n"));
|
|
123
|
+
if (spec.foreignKeys && spec.foreignKeys.length > 0) {
|
|
124
|
+
for (const fk of spec.foreignKeys) {
|
|
125
|
+
lines.push(`, ${buildForeignKey(fk)}`);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
if (spec.inherits && spec.inherits.length > 0) {
|
|
129
|
+
const inherits = spec.inherits.map(t => buildSchemaObjectName(t)).join(", ");
|
|
130
|
+
lines.push(`) INHERITS (${inherits})`);
|
|
131
|
+
}
|
|
132
|
+
else if (spec.like) {
|
|
133
|
+
const likeTable = buildSchemaObjectName(spec.like.table);
|
|
134
|
+
const including = spec.like.including ? `INCLUDING ${spec.like.including.join(" ")}` : "";
|
|
135
|
+
const excluding = spec.like.excluding ? `EXCLUDING ${spec.like.excluding.join(" ")}` : "";
|
|
136
|
+
lines.push(`) LIKE ${likeTable} ${including} ${excluding}`);
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
lines.push(")");
|
|
140
|
+
}
|
|
141
|
+
return lines.join("\n");
|
|
142
|
+
}
|
|
143
|
+
export function createIndex(_ir, tableName, index, options = {}) {
|
|
144
|
+
const concurrently = options.concurrently ? "CONCURRENTLY " : "";
|
|
145
|
+
const ifNotExists = options.ifNotExists ? "IF NOT EXISTS " : "";
|
|
146
|
+
const table = options.schema
|
|
147
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(tableName)}`
|
|
148
|
+
: quoteIdent(tableName);
|
|
149
|
+
return `CREATE ${index.unique ? "UNIQUE " : ""}INDEX ${concurrently}${ifNotExists}${quoteIdent(index.name)} ON ${table}${index.method ? ` USING ${index.method.toUpperCase()}` : ""} (${buildIndexColumns(index)}${index.where ? ` WHERE ${index.where}` : ""})`;
|
|
150
|
+
}
|
|
151
|
+
export function createPrimaryKeyIndex(_ir, tableName, columns, indexName, options = {}) {
|
|
152
|
+
const concurrently = options.concurrently ? "CONCURRENTLY " : "";
|
|
153
|
+
const table = options.schema
|
|
154
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(tableName)}`
|
|
155
|
+
: quoteIdent(tableName);
|
|
156
|
+
const indexCols = columns.map(quoteIdent).join(", ");
|
|
157
|
+
return `CREATE UNIQUE INDEX ${concurrently}${quoteIdent(indexName)} ON ${table} USING btree (${indexCols})`;
|
|
158
|
+
}
|
|
159
|
+
export function addForeignKey(_ir, tableName, foreignKey, options = {}) {
|
|
160
|
+
const table = options.schema
|
|
161
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(tableName)}`
|
|
162
|
+
: quoteIdent(tableName);
|
|
163
|
+
return `ALTER TABLE ${table} ADD ${buildForeignKey(foreignKey)}`;
|
|
164
|
+
}
|
|
165
|
+
export function dropForeignKey(_ir, tableName, constraintName, options = {}) {
|
|
166
|
+
const table = options.schema
|
|
167
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(tableName)}`
|
|
168
|
+
: quoteIdent(tableName);
|
|
169
|
+
const ifExists = options.ifExists ? "IF EXISTS " : "";
|
|
170
|
+
const cascade = options.cascade ? " CASCADE" : "";
|
|
171
|
+
return `ALTER TABLE ${table} DROP CONSTRAINT ${ifExists}${quoteIdent(constraintName)}${cascade}`;
|
|
172
|
+
}
|
|
173
|
+
export function dropIndex(indexName, options = {}) {
|
|
174
|
+
const ifExists = options.ifExists ? "IF EXISTS " : "";
|
|
175
|
+
const concurrently = options.concurrently ? "CONCURRENTLY " : "";
|
|
176
|
+
const cascade = options.cascade ? " CASCADE" : "";
|
|
177
|
+
return `DROP INDEX ${concurrently}${ifExists}${quoteIdent(indexName)}${cascade}`;
|
|
178
|
+
}
|
|
179
|
+
export function dropTable(tableName, options = {}) {
|
|
180
|
+
const ifExists = options.ifExists ? "IF EXISTS " : "";
|
|
181
|
+
const cascade = options.cascade ? " CASCADE" : "";
|
|
182
|
+
const table = options.schema
|
|
183
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(tableName)}`
|
|
184
|
+
: quoteIdent(tableName);
|
|
185
|
+
return `DROP TABLE ${ifExists}${table}${cascade}`;
|
|
186
|
+
}
|
|
187
|
+
export function alterTable(_ir, spec) {
|
|
188
|
+
const table = spec.schema
|
|
189
|
+
? `${quoteIdent(spec.schema)}.${quoteIdent(spec.table)}`
|
|
190
|
+
: quoteIdent(spec.table);
|
|
191
|
+
const actions = spec.actions.map(action => {
|
|
192
|
+
switch (action.kind) {
|
|
193
|
+
case "addColumn": {
|
|
194
|
+
return ` ADD COLUMN ${buildColumnDefinition(action.column)}`;
|
|
195
|
+
}
|
|
196
|
+
case "dropColumn": {
|
|
197
|
+
const cascade = action.cascade ? " CASCADE" : "";
|
|
198
|
+
return ` DROP COLUMN ${quoteIdent(action.column)}${cascade}`;
|
|
199
|
+
}
|
|
200
|
+
case "alterColumnSetDefault": {
|
|
201
|
+
const defaultValue = action.setDefault === null ? "DROP DEFAULT" : `SET DEFAULT ${action.setDefault}`;
|
|
202
|
+
return ` ALTER COLUMN ${quoteIdent(action.column)} ${defaultValue}`;
|
|
203
|
+
}
|
|
204
|
+
case "alterColumnSetNotNull": {
|
|
205
|
+
return ` ALTER COLUMN ${quoteIdent(action.column)} SET NOT NULL`;
|
|
206
|
+
}
|
|
207
|
+
case "alterColumnDropNotNull": {
|
|
208
|
+
return ` ALTER COLUMN ${quoteIdent(action.column)} DROP NOT NULL`;
|
|
209
|
+
}
|
|
210
|
+
case "addConstraint": {
|
|
211
|
+
return ` ADD ${buildConstraint(action.constraint)}`;
|
|
212
|
+
}
|
|
213
|
+
case "dropConstraint": {
|
|
214
|
+
const cascade = action.cascade ? " CASCADE" : "";
|
|
215
|
+
return ` DROP CONSTRAINT ${quoteIdent(action.name)}${cascade}`;
|
|
216
|
+
}
|
|
217
|
+
case "addForeignKey": {
|
|
218
|
+
return ` ADD ${buildForeignKey(action.foreignKey)}`;
|
|
219
|
+
}
|
|
220
|
+
case "dropForeignKey": {
|
|
221
|
+
const cascade = action.cascade ? " CASCADE" : "";
|
|
222
|
+
return ` DROP CONSTRAINT ${quoteIdent(action.name)}${cascade}`;
|
|
223
|
+
}
|
|
224
|
+
case "renameTo": {
|
|
225
|
+
return ` RENAME TO ${quoteIdent(action.newName)}`;
|
|
226
|
+
}
|
|
227
|
+
case "renameColumn": {
|
|
228
|
+
return ` RENAME COLUMN ${quoteIdent(action.from)} TO ${quoteIdent(action.to)}`;
|
|
229
|
+
}
|
|
230
|
+
default: {
|
|
231
|
+
const _exhaustive = action;
|
|
232
|
+
throw new Error(`Unknown alter action: ${_exhaustive.kind}`);
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
}).filter(Boolean);
|
|
236
|
+
if (actions.length === 0) {
|
|
237
|
+
return `-- No changes for ${table}`;
|
|
238
|
+
}
|
|
239
|
+
return `ALTER TABLE ${table}\n${actions.join("\n")}`;
|
|
240
|
+
}
|
|
241
|
+
export function drop(spec) {
|
|
242
|
+
const ifExists = spec.ifExists ? "IF EXISTS " : "";
|
|
243
|
+
const cascade = spec.cascade ? " CASCADE" : "";
|
|
244
|
+
const schema = spec.schema ? `${quoteIdent(spec.schema)}.` : "";
|
|
245
|
+
switch (spec.kind) {
|
|
246
|
+
case "table":
|
|
247
|
+
return `DROP TABLE ${ifExists}${schema}${quoteIdent(spec.name)}${cascade}`;
|
|
248
|
+
case "column":
|
|
249
|
+
return `ALTER TABLE ${schema}${quoteIdent(spec.name)} DROP COLUMN ${ifExists}${cascade}`;
|
|
250
|
+
case "constraint":
|
|
251
|
+
return `ALTER TABLE ${schema}${quoteIdent(spec.name)} DROP CONSTRAINT ${ifExists}${cascade}`;
|
|
252
|
+
case "index":
|
|
253
|
+
return `DROP INDEX ${ifExists}${schema}${quoteIdent(spec.name)}${cascade}`;
|
|
254
|
+
case "foreignKey": {
|
|
255
|
+
const parts = spec.name.split(".");
|
|
256
|
+
const hasSchema = parts.length > 1;
|
|
257
|
+
const table = hasSchema ? parts[0] : spec.table ?? "";
|
|
258
|
+
const constraint = hasSchema ? parts[1] : parts[0];
|
|
259
|
+
const tableSchema = spec.schema ? `${quoteIdent(spec.schema)}.` : "";
|
|
260
|
+
const tableName = table ? `${tableSchema}${quoteIdent(table)}` : "";
|
|
261
|
+
return `ALTER TABLE ${tableName} DROP CONSTRAINT ${ifExists}${quoteIdent(constraint)}${cascade}`;
|
|
262
|
+
}
|
|
263
|
+
case "schema":
|
|
264
|
+
return `DROP SCHEMA ${ifExists}${schema}${cascade}`;
|
|
265
|
+
case "type":
|
|
266
|
+
return `DROP TYPE ${ifExists}${schema}${quoteIdent(spec.name)}${cascade}`;
|
|
267
|
+
case "function": {
|
|
268
|
+
const argList = spec.name.includes("(") ? spec.name.slice(spec.name.indexOf("(")) : "";
|
|
269
|
+
const funcName = spec.name.includes("(") ? spec.name.slice(0, spec.name.indexOf("(")) : spec.name;
|
|
270
|
+
return `DROP FUNCTION ${ifExists}${schema}${quoteIdent(funcName)}${argList}${cascade}`;
|
|
271
|
+
}
|
|
272
|
+
case "trigger":
|
|
273
|
+
return `DROP TRIGGER ${ifExists}${quoteIdent(spec.name)} ON ${schema}${quoteIdent(spec.table ?? "")}${cascade}`;
|
|
274
|
+
case "rule":
|
|
275
|
+
return `DROP RULE ${ifExists}${quoteIdent(spec.name)} ON ${schema}${quoteIdent(spec.table ?? "")}${cascade}`;
|
|
276
|
+
default:
|
|
277
|
+
throw new Error(`Unknown drop kind: ${spec.kind}`);
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
export function renameTable(oldName, newName, options = {}) {
|
|
281
|
+
const table = options.schema
|
|
282
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(oldName)}`
|
|
283
|
+
: quoteIdent(oldName);
|
|
284
|
+
const newTableName = options.schema
|
|
285
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(newName)}`
|
|
286
|
+
: quoteIdent(newName);
|
|
287
|
+
return `ALTER TABLE ${table} RENAME TO ${newTableName}`;
|
|
288
|
+
}
|
|
289
|
+
export function renameColumn(tableName, oldColumn, newColumn, options = {}) {
|
|
290
|
+
const table = options.schema
|
|
291
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(tableName)}`
|
|
292
|
+
: quoteIdent(tableName);
|
|
293
|
+
return `ALTER TABLE ${table} RENAME COLUMN ${quoteIdent(oldColumn)} TO ${quoteIdent(newColumn)}`;
|
|
294
|
+
}
|
|
295
|
+
export function renameConstraint(tableName, oldConstraint, newConstraint, options = {}) {
|
|
296
|
+
const table = options.schema
|
|
297
|
+
? `${quoteIdent(options.schema)}.${quoteIdent(tableName)}`
|
|
298
|
+
: quoteIdent(tableName);
|
|
299
|
+
return `ALTER TABLE ${table} RENAME CONSTRAINT ${quoteIdent(oldConstraint)} TO ${quoteIdent(newConstraint)}`;
|
|
300
|
+
}
|
|
301
|
+
export function setSchema(objectName, newSchema, options = {}) {
|
|
302
|
+
const cascade = options.cascade ? " CASCADE" : "";
|
|
303
|
+
const currentSchema = options.schema ? `${quoteIdent(options.schema)}.` : "";
|
|
304
|
+
return `ALTER ${currentSchema}${quoteIdent(objectName)} SET SCHEMA ${quoteIdent(newSchema)}${cascade}`;
|
|
305
|
+
}
|
|
306
|
+
//# sourceMappingURL=ddl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ddl.js","sourceRoot":"","sources":["../../src/hex/ddl.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hex - SQL Query Builder
|
|
3
|
+
*
|
|
4
|
+
* IR-aware declarative query builder that integrates with SemanticIR
|
|
5
|
+
* for automatic type resolution and validation.
|
|
6
|
+
*
|
|
7
|
+
* Also provides template-based primitives for advanced use cases.
|
|
8
|
+
*
|
|
9
|
+
* Design principles:
|
|
10
|
+
* - Specify WHAT, not HOW - plugins declare intent, builder constructs SQL
|
|
11
|
+
* - IR integration for automatic type resolution (reduces plugin overhead)
|
|
12
|
+
* - Full PostgreSQL feature support (LATERAL, CTEs, subqueries, etc.)
|
|
13
|
+
* - Validation against schema at build time
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```typescript
|
|
17
|
+
* import { hex } from "./index.js"
|
|
18
|
+
*
|
|
19
|
+
* // Declarative API (recommended)
|
|
20
|
+
* const query = hex.select(ir, {
|
|
21
|
+
* selects: [{ kind: "column", from: "x", column: "c1" }],
|
|
22
|
+
* from: { kind: "table", table: "x" },
|
|
23
|
+
* where: [{ kind: "equals", column: "x.id", value: { name: "id", pgType: "int4" } }],
|
|
24
|
+
* })
|
|
25
|
+
*
|
|
26
|
+
* // Template-based API (for advanced/custom queries)
|
|
27
|
+
* const descriptor = hex.toDescriptor(
|
|
28
|
+
* "findUserById",
|
|
29
|
+
* "User",
|
|
30
|
+
* "select",
|
|
31
|
+
* { templateParts: ["SELECT * FROM users WHERE id = ", ""] },
|
|
32
|
+
* { mode: "oneOrNone", fields: userFields },
|
|
33
|
+
* [{ name: "id", tsType: "string", pgType: "uuid", nullable: false }]
|
|
34
|
+
* )
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
export * from "./types.js";
|
|
38
|
+
export * from "./builder.js";
|
|
39
|
+
export * from "./primitives.js";
|
|
40
|
+
export * from "./query.js";
|
|
41
|
+
export * from "./ddl.js";
|
|
42
|
+
export { Query, createQuery } from "./query.js";
|
|
43
|
+
import type { SemanticIR } from "../ir/semantic-ir.js";
|
|
44
|
+
import type { SelectSpec, MutationSpec, ParamSpec, CreateTableSpec, AlterTableSpec, IndexSpec, ForeignKeySpec, DropSpec } from "./types.js";
|
|
45
|
+
import { select, mutate, call } from "./builder.js";
|
|
46
|
+
import { toQueryDescriptor, buildReturnDescriptor, buildParamDescriptor, buildFieldDescriptor } from "./primitives.js";
|
|
47
|
+
import { createQuery } from "./query.js";
|
|
48
|
+
export declare const hex: {
|
|
49
|
+
readonly select: (ir: SemanticIR, spec: SelectSpec) => import("./query.js").Query;
|
|
50
|
+
readonly mutate: (ir: SemanticIR, spec: MutationSpec) => import("./query.js").Query;
|
|
51
|
+
readonly call: (ir: SemanticIR, funcName: string, args: ParamSpec[]) => import("./query.js").Query;
|
|
52
|
+
readonly createQuery: typeof createQuery;
|
|
53
|
+
readonly toDescriptor: typeof toQueryDescriptor;
|
|
54
|
+
readonly buildReturn: typeof buildReturnDescriptor;
|
|
55
|
+
readonly buildParam: typeof buildParamDescriptor;
|
|
56
|
+
readonly buildField: typeof buildFieldDescriptor;
|
|
57
|
+
readonly rawSelect: typeof select;
|
|
58
|
+
readonly rawMutate: typeof mutate;
|
|
59
|
+
readonly rawCall: typeof call;
|
|
60
|
+
readonly createTable: (ir: SemanticIR, spec: CreateTableSpec) => string;
|
|
61
|
+
readonly createIndex: (ir: SemanticIR, tableName: string, index: IndexSpec, options?: {
|
|
62
|
+
concurrently?: boolean;
|
|
63
|
+
ifNotExists?: boolean;
|
|
64
|
+
schema?: string;
|
|
65
|
+
}) => string;
|
|
66
|
+
readonly createPrimaryKeyIndex: (ir: SemanticIR, tableName: string, columns: string[], indexName: string, options?: {
|
|
67
|
+
concurrently?: boolean;
|
|
68
|
+
schema?: string;
|
|
69
|
+
}) => string;
|
|
70
|
+
readonly addForeignKey: (ir: SemanticIR, tableName: string, foreignKey: ForeignKeySpec, options?: {
|
|
71
|
+
schema?: string;
|
|
72
|
+
}) => string;
|
|
73
|
+
readonly dropForeignKey: (ir: SemanticIR, tableName: string, constraintName: string, options?: {
|
|
74
|
+
schema?: string;
|
|
75
|
+
ifExists?: boolean;
|
|
76
|
+
cascade?: boolean;
|
|
77
|
+
}) => string;
|
|
78
|
+
readonly dropIndex: (indexName: string, options?: {
|
|
79
|
+
ifExists?: boolean;
|
|
80
|
+
cascade?: boolean;
|
|
81
|
+
concurrently?: boolean;
|
|
82
|
+
}) => string;
|
|
83
|
+
readonly dropTable: (tableName: string, options?: {
|
|
84
|
+
schema?: string;
|
|
85
|
+
ifExists?: boolean;
|
|
86
|
+
cascade?: boolean;
|
|
87
|
+
}) => string;
|
|
88
|
+
readonly alterTable: (ir: SemanticIR, spec: AlterTableSpec) => string;
|
|
89
|
+
readonly drop: (spec: DropSpec) => string;
|
|
90
|
+
readonly renameTable: (oldName: string, newName: string, options?: {
|
|
91
|
+
schema?: string;
|
|
92
|
+
}) => string;
|
|
93
|
+
readonly renameColumn: (tableName: string, oldColumn: string, newColumn: string, options?: {
|
|
94
|
+
schema?: string;
|
|
95
|
+
}) => string;
|
|
96
|
+
readonly renameConstraint: (tableName: string, oldConstraint: string, newConstraint: string, options?: {
|
|
97
|
+
schema?: string;
|
|
98
|
+
}) => string;
|
|
99
|
+
readonly setSchema: (objectName: string, newSchema: string, options?: {
|
|
100
|
+
schema?: string;
|
|
101
|
+
cascade?: boolean;
|
|
102
|
+
}) => string;
|
|
103
|
+
};
|
|
104
|
+
export default hex;
|
|
105
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hex/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AAGH,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AAGzB,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAGhD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,SAAS,EAAE,eAAe,EAAE,cAAc,EAAE,SAAS,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC5I,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvH,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAGzC,eAAO,MAAM,GAAG;0BAED,UAAU,QAAQ,UAAU;0BAC5B,UAAU,QAAQ,YAAY;wBAChC,UAAU,YAAY,MAAM,QAAQ,SAAS,EAAE;;;;;;;;;+BAiBxC,UAAU,QAAQ,eAAe;+BACjC,UAAU,aAAa,MAAM,SAAS,SAAS,YAAY;QAAE,YAAY,CAAC,EAAE,OAAO,CAAC;QAAC,WAAW,CAAC,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;yCACnH,UAAU,aAAa,MAAM,WAAW,MAAM,EAAE,aAAa,MAAM,YAAY;QAAE,YAAY,CAAC,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;iCAClI,UAAU,aAAa,MAAM,cAAc,cAAc,YAAY;QAAE,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;kCACvF,UAAU,aAAa,MAAM,kBAAkB,MAAM,YAAY;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;QAAC,OAAO,CAAC,EAAE,OAAO,CAAA;KAAE;oCACzH,MAAM,YAAY;QAAE,QAAQ,CAAC,EAAE,OAAO,CAAC;QAAC,OAAO,CAAC,EAAE,OAAO,CAAC;QAAC,YAAY,CAAC,EAAE,OAAO,CAAA;KAAE;oCACnF,MAAM,YAAY;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;QAAC,OAAO,CAAC,EAAE,OAAO,CAAA;KAAE;8BAClF,UAAU,QAAQ,cAAc;0BACpC,QAAQ;oCACE,MAAM,WAAW,MAAM,YAAY;QAAE,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;uCACnD,MAAM,aAAa,MAAM,aAAa,MAAM,YAAY;QAAE,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;2CACvE,MAAM,iBAAiB,MAAM,iBAAiB,MAAM,YAAY;QAAE,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;qCACzF,MAAM,aAAa,MAAM,YAAY;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,OAAO,CAAA;KAAE;CAC3F,CAAC;AAEX,eAAe,GAAG,CAAC"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hex - SQL Query Builder
|
|
3
|
+
*
|
|
4
|
+
* IR-aware declarative query builder that integrates with SemanticIR
|
|
5
|
+
* for automatic type resolution and validation.
|
|
6
|
+
*
|
|
7
|
+
* Also provides template-based primitives for advanced use cases.
|
|
8
|
+
*
|
|
9
|
+
* Design principles:
|
|
10
|
+
* - Specify WHAT, not HOW - plugins declare intent, builder constructs SQL
|
|
11
|
+
* - IR integration for automatic type resolution (reduces plugin overhead)
|
|
12
|
+
* - Full PostgreSQL feature support (LATERAL, CTEs, subqueries, etc.)
|
|
13
|
+
* - Validation against schema at build time
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```typescript
|
|
17
|
+
* import { hex } from "./index.js"
|
|
18
|
+
*
|
|
19
|
+
* // Declarative API (recommended)
|
|
20
|
+
* const query = hex.select(ir, {
|
|
21
|
+
* selects: [{ kind: "column", from: "x", column: "c1" }],
|
|
22
|
+
* from: { kind: "table", table: "x" },
|
|
23
|
+
* where: [{ kind: "equals", column: "x.id", value: { name: "id", pgType: "int4" } }],
|
|
24
|
+
* })
|
|
25
|
+
*
|
|
26
|
+
* // Template-based API (for advanced/custom queries)
|
|
27
|
+
* const descriptor = hex.toDescriptor(
|
|
28
|
+
* "findUserById",
|
|
29
|
+
* "User",
|
|
30
|
+
* "select",
|
|
31
|
+
* { templateParts: ["SELECT * FROM users WHERE id = ", ""] },
|
|
32
|
+
* { mode: "oneOrNone", fields: userFields },
|
|
33
|
+
* [{ name: "id", tsType: "string", pgType: "uuid", nullable: false }]
|
|
34
|
+
* )
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
// Re-export all public APIs
|
|
38
|
+
export * from "./types.js";
|
|
39
|
+
export * from "./builder.js";
|
|
40
|
+
export * from "./primitives.js";
|
|
41
|
+
export * from "./query.js";
|
|
42
|
+
export * from "./ddl.js";
|
|
43
|
+
// Re-export Query class and factory
|
|
44
|
+
export { Query, createQuery } from "./query.js";
|
|
45
|
+
import { select, mutate, call } from "./builder.js";
|
|
46
|
+
import { toQueryDescriptor, buildReturnDescriptor, buildParamDescriptor, buildFieldDescriptor } from "./primitives.js";
|
|
47
|
+
import { createQuery } from "./query.js";
|
|
48
|
+
import { createTable, createIndex, createPrimaryKeyIndex, addForeignKey, dropForeignKey, dropIndex, dropTable, alterTable, drop, renameTable, renameColumn, renameConstraint, setSchema } from "./ddl.js";
|
|
49
|
+
export const hex = {
|
|
50
|
+
// Declarative API (returns Query objects)
|
|
51
|
+
select: (ir, spec) => createQuery(select(ir, spec)),
|
|
52
|
+
mutate: (ir, spec) => createQuery(mutate(ir, spec)),
|
|
53
|
+
call: (ir, funcName, args) => createQuery(call(ir, funcName, args)),
|
|
54
|
+
// Create Query from descriptor (for custom descriptors)
|
|
55
|
+
createQuery,
|
|
56
|
+
// Template-based API (legacy - returns raw QueryDescriptor)
|
|
57
|
+
toDescriptor: toQueryDescriptor,
|
|
58
|
+
buildReturn: buildReturnDescriptor,
|
|
59
|
+
buildParam: buildParamDescriptor,
|
|
60
|
+
buildField: buildFieldDescriptor,
|
|
61
|
+
// Direct access to descriptor builders (for when you need raw descriptors)
|
|
62
|
+
rawSelect: select,
|
|
63
|
+
rawMutate: mutate,
|
|
64
|
+
rawCall: call,
|
|
65
|
+
// DDL builders
|
|
66
|
+
createTable: (ir, spec) => createTable(ir, spec),
|
|
67
|
+
createIndex: (ir, tableName, index, options) => createIndex(ir, tableName, index, options),
|
|
68
|
+
createPrimaryKeyIndex: (ir, tableName, columns, indexName, options) => createPrimaryKeyIndex(ir, tableName, columns, indexName, options),
|
|
69
|
+
addForeignKey: (ir, tableName, foreignKey, options) => addForeignKey(ir, tableName, foreignKey, options),
|
|
70
|
+
dropForeignKey: (ir, tableName, constraintName, options) => dropForeignKey(ir, tableName, constraintName, options),
|
|
71
|
+
dropIndex: (indexName, options) => dropIndex(indexName, options),
|
|
72
|
+
dropTable: (tableName, options) => dropTable(tableName, options),
|
|
73
|
+
alterTable: (ir, spec) => alterTable(ir, spec),
|
|
74
|
+
drop: (spec) => drop(spec),
|
|
75
|
+
renameTable: (oldName, newName, options) => renameTable(oldName, newName, options),
|
|
76
|
+
renameColumn: (tableName, oldColumn, newColumn, options) => renameColumn(tableName, oldColumn, newColumn, options),
|
|
77
|
+
renameConstraint: (tableName, oldConstraint, newConstraint, options) => renameConstraint(tableName, oldConstraint, newConstraint, options),
|
|
78
|
+
setSchema: (objectName, newSchema, options) => setSchema(objectName, newSchema, options),
|
|
79
|
+
};
|
|
80
|
+
export default hex;
|
|
81
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/hex/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hex - Template-Based Primitives
|
|
3
|
+
*
|
|
4
|
+
* Lower-level template-based query building utilities.
|
|
5
|
+
*/
|
|
6
|
+
import type { QueryDescriptor, ParamDescriptor, ReturnDescriptor, FieldDescriptor, ReturnMode, QueryOperation, QueryMetadata } from "../shared/query-types.js";
|
|
7
|
+
export interface QueryParts {
|
|
8
|
+
readonly templateParts: readonly string[];
|
|
9
|
+
}
|
|
10
|
+
export declare function toQueryDescriptor(name: string, entityName: string, operation: QueryOperation, parts: QueryParts, returns: ReturnDescriptor, params: readonly ParamDescriptor[], options?: {
|
|
11
|
+
variant?: string;
|
|
12
|
+
meta?: QueryMetadata;
|
|
13
|
+
}): QueryDescriptor;
|
|
14
|
+
export declare function buildReturnDescriptor(mode: ReturnMode, fields: readonly FieldDescriptor[]): ReturnDescriptor;
|
|
15
|
+
export declare function buildParamDescriptor(name: string, tsType: string, pgType: string, options?: {
|
|
16
|
+
nullable?: boolean;
|
|
17
|
+
hasDefault?: boolean;
|
|
18
|
+
}): ParamDescriptor;
|
|
19
|
+
export declare function buildFieldDescriptor(name: string, tsType: string, pgType: string, options?: {
|
|
20
|
+
nullable?: boolean;
|
|
21
|
+
isArray?: boolean;
|
|
22
|
+
}): FieldDescriptor;
|
|
23
|
+
//# sourceMappingURL=primitives.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"primitives.d.ts","sourceRoot":"","sources":["../../src/hex/primitives.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,KAAK,EACV,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,UAAU,EACV,cAAc,EACd,aAAa,EACd,MAAM,0BAA0B,CAAC;AAGlC,MAAM,WAAW,UAAU;IACzB,QAAQ,CAAC,aAAa,EAAE,SAAS,MAAM,EAAE,CAAC;CAC3C;AAED,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,MAAM,EACZ,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,cAAc,EACzB,KAAK,EAAE,UAAU,EACjB,OAAO,EAAE,gBAAgB,EACzB,MAAM,EAAE,SAAS,eAAe,EAAE,EAClC,OAAO,CAAC,EAAE;IACR,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,aAAa,CAAC;CACtB,GACA,eAAe,CAajB;AAED,wBAAgB,qBAAqB,CACnC,IAAI,EAAE,UAAU,EAChB,MAAM,EAAE,SAAS,eAAe,EAAE,GACjC,gBAAgB,CAElB;AAED,wBAAgB,oBAAoB,CAClC,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE;IACR,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB,GACA,eAAe,CAQjB;AAED,wBAAgB,oBAAoB,CAClC,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE;IACR,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,GACA,eAAe,CAQjB"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
export function toQueryDescriptor(name, entityName, operation, parts, returns, params, options) {
|
|
2
|
+
const sql = buildParameterizedSql(parts.templateParts);
|
|
3
|
+
return {
|
|
4
|
+
name,
|
|
5
|
+
entityName,
|
|
6
|
+
operation,
|
|
7
|
+
variant: options?.variant,
|
|
8
|
+
sql,
|
|
9
|
+
params,
|
|
10
|
+
returns,
|
|
11
|
+
meta: options?.meta,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export function buildReturnDescriptor(mode, fields) {
|
|
15
|
+
return { mode, fields };
|
|
16
|
+
}
|
|
17
|
+
export function buildParamDescriptor(name, tsType, pgType, options) {
|
|
18
|
+
return {
|
|
19
|
+
name,
|
|
20
|
+
tsType,
|
|
21
|
+
pgType,
|
|
22
|
+
nullable: options?.nullable ?? false,
|
|
23
|
+
hasDefault: options?.hasDefault,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
export function buildFieldDescriptor(name, tsType, pgType, options) {
|
|
27
|
+
return {
|
|
28
|
+
name,
|
|
29
|
+
tsType,
|
|
30
|
+
pgType,
|
|
31
|
+
nullable: options?.nullable ?? false,
|
|
32
|
+
isArray: options?.isArray,
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
function buildParameterizedSql(parts) {
|
|
36
|
+
return parts.map((part, i) => (i === 0 ? part : `$${i}${part}`)).join("");
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=primitives.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"primitives.js","sourceRoot":"","sources":["../../src/hex/primitives.ts"],"names":[],"mappings":"AAoBA,MAAM,UAAU,iBAAiB,CAC/B,IAAY,EACZ,UAAkB,EAClB,SAAyB,EACzB,KAAiB,EACjB,OAAyB,EACzB,MAAkC,EAClC,OAGC;IAED,MAAM,GAAG,GAAG,qBAAqB,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;IAEvD,OAAO;QACL,IAAI;QACJ,UAAU;QACV,SAAS;QACT,OAAO,EAAE,OAAO,EAAE,OAAO;QACzB,GAAG;QACH,MAAM;QACN,OAAO;QACP,IAAI,EAAE,OAAO,EAAE,IAAI;KACpB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,qBAAqB,CACnC,IAAgB,EAChB,MAAkC;IAElC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,IAAY,EACZ,MAAc,EACd,MAAc,EACd,OAGC;IAED,OAAO;QACL,IAAI;QACJ,MAAM;QACN,MAAM;QACN,QAAQ,EAAE,OAAO,EAAE,QAAQ,IAAI,KAAK;QACpC,UAAU,EAAE,OAAO,EAAE,UAAU;KAChC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,IAAY,EACZ,MAAc,EACd,MAAc,EACd,OAGC;IAED,OAAO;QACL,IAAI;QACJ,MAAM;QACN,MAAM;QACN,QAAQ,EAAE,OAAO,EAAE,QAAQ,IAAI,KAAK;QACpC,OAAO,EAAE,OAAO,EAAE,OAAO;KAC1B,CAAC;AACJ,CAAC;AAED,SAAS,qBAAqB,CAAC,KAAwB;IACrD,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC5E,CAAC"}
|