neoorm 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +86 -0
- package/dist/bin/neoorm.d.ts +3 -0
- package/dist/bin/neoorm.d.ts.map +1 -0
- package/dist/bin/neoorm.js +111 -0
- package/dist/bin/neoorm.js.map +1 -0
- package/dist/codegen/emit-includes.d.ts +3 -0
- package/dist/codegen/emit-includes.d.ts.map +1 -0
- package/dist/codegen/emit-includes.js +133 -0
- package/dist/codegen/emit-includes.js.map +1 -0
- package/dist/codegen/generate.d.ts +24 -0
- package/dist/codegen/generate.d.ts.map +1 -0
- package/dist/codegen/generate.js +156 -0
- package/dist/codegen/generate.js.map +1 -0
- package/dist/codegen/schema-to-manifest.d.ts +8 -0
- package/dist/codegen/schema-to-manifest.d.ts.map +1 -0
- package/dist/codegen/schema-to-manifest.js +210 -0
- package/dist/codegen/schema-to-manifest.js.map +1 -0
- package/dist/config.d.ts +11 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +17 -0
- package/dist/config.js.map +1 -0
- package/dist/dialect/index.d.ts +3 -0
- package/dist/dialect/index.d.ts.map +1 -0
- package/dist/dialect/index.js +2 -0
- package/dist/dialect/index.js.map +1 -0
- package/dist/dialect/postgres.d.ts +5 -0
- package/dist/dialect/postgres.d.ts.map +1 -0
- package/dist/dialect/postgres.js +112 -0
- package/dist/dialect/postgres.js.map +1 -0
- package/dist/dialect/types.d.ts +79 -0
- package/dist/dialect/types.d.ts.map +1 -0
- package/dist/dialect/types.js +2 -0
- package/dist/dialect/types.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/introspect/pull.d.ts +3 -0
- package/dist/introspect/pull.d.ts.map +1 -0
- package/dist/introspect/pull.js +91 -0
- package/dist/introspect/pull.js.map +1 -0
- package/dist/migrate/runner.d.ts +9 -0
- package/dist/migrate/runner.d.ts.map +1 -0
- package/dist/migrate/runner.js +70 -0
- package/dist/migrate/runner.js.map +1 -0
- package/dist/runtime/client.d.ts +61 -0
- package/dist/runtime/client.d.ts.map +1 -0
- package/dist/runtime/client.js +54 -0
- package/dist/runtime/client.js.map +1 -0
- package/dist/runtime/executor.d.ts +10 -0
- package/dist/runtime/executor.d.ts.map +1 -0
- package/dist/runtime/executor.js +62 -0
- package/dist/runtime/executor.js.map +1 -0
- package/dist/runtime/query/compile.d.ts +23 -0
- package/dist/runtime/query/compile.d.ts.map +1 -0
- package/dist/runtime/query/compile.js +182 -0
- package/dist/runtime/query/compile.js.map +1 -0
- package/dist/runtime/query/create.d.ts +8 -0
- package/dist/runtime/query/create.d.ts.map +1 -0
- package/dist/runtime/query/create.js +139 -0
- package/dist/runtime/query/create.js.map +1 -0
- package/dist/runtime/query/delete.d.ts +12 -0
- package/dist/runtime/query/delete.d.ts.map +1 -0
- package/dist/runtime/query/delete.js +35 -0
- package/dist/runtime/query/delete.js.map +1 -0
- package/dist/runtime/query/find.d.ts +21 -0
- package/dist/runtime/query/find.d.ts.map +1 -0
- package/dist/runtime/query/find.js +172 -0
- package/dist/runtime/query/find.js.map +1 -0
- package/dist/runtime/query/update.d.ts +17 -0
- package/dist/runtime/query/update.d.ts.map +1 -0
- package/dist/runtime/query/update.js +63 -0
- package/dist/runtime/query/update.js.map +1 -0
- package/dist/runtime/types.d.ts +48 -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/schema/column.d.ts +39 -0
- package/dist/schema/column.d.ts.map +1 -0
- package/dist/schema/column.js +70 -0
- package/dist/schema/column.js.map +1 -0
- package/dist/schema/define-schema.d.ts +6 -0
- package/dist/schema/define-schema.d.ts.map +1 -0
- package/dist/schema/define-schema.js +4 -0
- package/dist/schema/define-schema.js.map +1 -0
- package/dist/schema/index.d.ts +13 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +6 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/many-to-many.d.ts +21 -0
- package/dist/schema/many-to-many.d.ts.map +1 -0
- package/dist/schema/many-to-many.js +20 -0
- package/dist/schema/many-to-many.js.map +1 -0
- package/dist/schema/relation-types.d.ts +74 -0
- package/dist/schema/relation-types.d.ts.map +1 -0
- package/dist/schema/relation-types.js +2 -0
- package/dist/schema/relation-types.js.map +1 -0
- package/dist/schema/relation.d.ts +24 -0
- package/dist/schema/relation.d.ts.map +1 -0
- package/dist/schema/relation.js +25 -0
- package/dist/schema/relation.js.map +1 -0
- package/dist/schema/table.d.ts +28 -0
- package/dist/schema/table.d.ts.map +1 -0
- package/dist/schema/table.js +23 -0
- package/dist/schema/table.js.map +1 -0
- package/dist/schema/types.d.ts +115 -0
- package/dist/schema/types.d.ts.map +1 -0
- package/dist/schema/types.js +2 -0
- package/dist/schema/types.js.map +1 -0
- package/dist/sql/builder.d.ts +17 -0
- package/dist/sql/builder.d.ts.map +1 -0
- package/dist/sql/builder.js +51 -0
- package/dist/sql/builder.js.map +1 -0
- package/dist/sql/index.d.ts +7 -0
- package/dist/sql/index.d.ts.map +1 -0
- package/dist/sql/index.js +6 -0
- package/dist/sql/index.js.map +1 -0
- package/dist/sql/template.d.ts +16 -0
- package/dist/sql/template.d.ts.map +1 -0
- package/dist/sql/template.js +43 -0
- package/dist/sql/template.js.map +1 -0
- package/dist/utils/case.d.ts +5 -0
- package/dist/utils/case.d.ts.map +1 -0
- package/dist/utils/case.js +20 -0
- package/dist/utils/case.js.map +1 -0
- package/package.json +60 -0
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import { getManyToManyRegistry } from "../schema/many-to-many.js";
|
|
2
|
+
import { toSnakeCase } from "../utils/case.js";
|
|
3
|
+
function isFkBuilder(col) {
|
|
4
|
+
return "_meta" in col && col._meta.kind === "fk";
|
|
5
|
+
}
|
|
6
|
+
function isColumnBuilder(col) {
|
|
7
|
+
return "_meta" in col && col._meta.kind !== "fk";
|
|
8
|
+
}
|
|
9
|
+
function columnToManifest(tsName, col) {
|
|
10
|
+
if (isFkBuilder(col)) {
|
|
11
|
+
const meta = col._meta;
|
|
12
|
+
const result = {
|
|
13
|
+
tsName,
|
|
14
|
+
sqlName: toSnakeCase(tsName),
|
|
15
|
+
kind: "fk",
|
|
16
|
+
nullable: meta.nullable,
|
|
17
|
+
unique: meta.unique,
|
|
18
|
+
primary: meta.primary,
|
|
19
|
+
defaultNow: meta.defaultNow,
|
|
20
|
+
fkTarget: meta.target,
|
|
21
|
+
fkAs: meta.as,
|
|
22
|
+
fkInverse: meta.inverse,
|
|
23
|
+
};
|
|
24
|
+
if (meta.onDelete !== undefined) {
|
|
25
|
+
result.onDelete = meta.onDelete;
|
|
26
|
+
}
|
|
27
|
+
return result;
|
|
28
|
+
}
|
|
29
|
+
const meta = col._meta;
|
|
30
|
+
const result = {
|
|
31
|
+
tsName,
|
|
32
|
+
sqlName: toSnakeCase(tsName),
|
|
33
|
+
kind: meta.kind,
|
|
34
|
+
nullable: meta.nullable,
|
|
35
|
+
unique: meta.unique,
|
|
36
|
+
primary: meta.primary,
|
|
37
|
+
defaultNow: meta.defaultNow,
|
|
38
|
+
};
|
|
39
|
+
if (meta.defaultValue !== undefined) {
|
|
40
|
+
result.defaultValue = meta.defaultValue;
|
|
41
|
+
}
|
|
42
|
+
return result;
|
|
43
|
+
}
|
|
44
|
+
function extrasToManifest(extras) {
|
|
45
|
+
const indexes = [];
|
|
46
|
+
let primaryKey = [];
|
|
47
|
+
for (const [name, extra] of Object.entries(extras)) {
|
|
48
|
+
if (extra.kind === "index") {
|
|
49
|
+
indexes.push({
|
|
50
|
+
name,
|
|
51
|
+
columns: extra.columns.map(toSnakeCase),
|
|
52
|
+
unique: extra.unique,
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
else if (extra.kind === "primaryKey") {
|
|
56
|
+
primaryKey = extra.columns.map(toSnakeCase);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return { indexes, primaryKey };
|
|
60
|
+
}
|
|
61
|
+
function buildRelations(columns, accessorMap, sqlNameToAccessor) {
|
|
62
|
+
const relations = [];
|
|
63
|
+
for (const col of columns) {
|
|
64
|
+
if (col.kind !== "fk" || !col.fkTarget || !col.fkAs)
|
|
65
|
+
continue;
|
|
66
|
+
const [targetSqlName] = col.fkTarget.split(".");
|
|
67
|
+
const targetAccessor = sqlNameToAccessor[targetSqlName] ?? targetSqlName;
|
|
68
|
+
const cardinality = col.unique ? "one" : "many";
|
|
69
|
+
const rel = {
|
|
70
|
+
name: col.fkAs,
|
|
71
|
+
targetTable: targetSqlName,
|
|
72
|
+
targetAccessor,
|
|
73
|
+
fkColumn: col.tsName,
|
|
74
|
+
fkSqlColumn: col.sqlName,
|
|
75
|
+
targetColumn: "id",
|
|
76
|
+
cardinality,
|
|
77
|
+
inverse: col.fkInverse ?? col.fkAs,
|
|
78
|
+
};
|
|
79
|
+
if (col.onDelete !== undefined) {
|
|
80
|
+
rel.onDelete = col.onDelete;
|
|
81
|
+
}
|
|
82
|
+
relations.push(rel);
|
|
83
|
+
}
|
|
84
|
+
return relations;
|
|
85
|
+
}
|
|
86
|
+
export function schemaToManifest(schema, m2mDefs = getManyToManyRegistry()) {
|
|
87
|
+
const tables = schema._tables;
|
|
88
|
+
const sqlNameToAccessor = {};
|
|
89
|
+
for (const [accessor, table] of Object.entries(tables)) {
|
|
90
|
+
sqlNameToAccessor[table._tableName] = accessor;
|
|
91
|
+
}
|
|
92
|
+
const manifestTables = {};
|
|
93
|
+
for (const [accessor, tableDef] of Object.entries(tables)) {
|
|
94
|
+
const columns = Object.entries(tableDef._columns).map(([name, col]) => columnToManifest(name, col));
|
|
95
|
+
const { indexes, primaryKey } = extrasToManifest(tableDef._extras);
|
|
96
|
+
const pk = primaryKey.length > 0
|
|
97
|
+
? primaryKey
|
|
98
|
+
: columns.filter((c) => c.primary).map((c) => c.sqlName);
|
|
99
|
+
const relations = buildRelations(columns, {}, sqlNameToAccessor);
|
|
100
|
+
manifestTables[accessor] = {
|
|
101
|
+
accessor,
|
|
102
|
+
sqlName: tableDef._tableName,
|
|
103
|
+
columns,
|
|
104
|
+
relations,
|
|
105
|
+
indexes,
|
|
106
|
+
primaryKey: pk,
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
for (const table of Object.values(manifestTables)) {
|
|
110
|
+
const fkRelations = table.relations.filter((rel) => {
|
|
111
|
+
const col = table.columns.find((c) => c.fkAs === rel.name);
|
|
112
|
+
return col?.kind === "fk";
|
|
113
|
+
});
|
|
114
|
+
for (const rel of fkRelations) {
|
|
115
|
+
const inverseTable = manifestTables[rel.targetAccessor];
|
|
116
|
+
if (!inverseTable)
|
|
117
|
+
continue;
|
|
118
|
+
const alreadyExists = inverseTable.relations.some((r) => r.name === rel.inverse);
|
|
119
|
+
if (alreadyExists)
|
|
120
|
+
continue;
|
|
121
|
+
inverseTable.relations.push({
|
|
122
|
+
name: rel.inverse,
|
|
123
|
+
targetTable: table.sqlName,
|
|
124
|
+
targetAccessor: table.accessor,
|
|
125
|
+
fkColumn: rel.fkColumn,
|
|
126
|
+
fkSqlColumn: rel.fkSqlColumn,
|
|
127
|
+
targetColumn: rel.targetColumn,
|
|
128
|
+
cardinality: rel.cardinality === "one" ? "many" : "one",
|
|
129
|
+
inverse: rel.name,
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
const m2mDefsResolved = m2mDefs;
|
|
134
|
+
const manyToMany = m2mDefsResolved.map((m) => {
|
|
135
|
+
const throughAccessor = Object.entries(tables).find(([, t]) => t._tableName === m.throughKey)?.[0] ?? m.throughKey;
|
|
136
|
+
const leftAccessor = Object.entries(tables).find(([, t]) => t._tableName === m.leftKey)?.[0] ?? m.leftKey;
|
|
137
|
+
const rightAccessor = Object.entries(tables).find(([, t]) => t._tableName === m.rightKey)?.[0] ?? m.rightKey;
|
|
138
|
+
const throughTable = manifestTables[throughAccessor];
|
|
139
|
+
const leftFk = throughTable?.columns.find((c) => c.fkAs === m.leftRelation);
|
|
140
|
+
const rightFk = throughTable?.columns.find((c) => c.fkAs === m.rightRelation);
|
|
141
|
+
return {
|
|
142
|
+
leftTable: m.leftKey,
|
|
143
|
+
leftAccessor,
|
|
144
|
+
rightTable: m.rightKey,
|
|
145
|
+
rightAccessor,
|
|
146
|
+
throughTable: m.throughKey,
|
|
147
|
+
throughAccessor,
|
|
148
|
+
leftFkColumn: leftFk?.sqlName ?? "",
|
|
149
|
+
rightFkColumn: rightFk?.sqlName ?? "",
|
|
150
|
+
leftRelation: m.leftRelation,
|
|
151
|
+
rightRelation: m.rightRelation,
|
|
152
|
+
as: m.as,
|
|
153
|
+
inverse: m.inverse,
|
|
154
|
+
};
|
|
155
|
+
});
|
|
156
|
+
for (const m2m of manyToMany) {
|
|
157
|
+
const leftTable = manifestTables[m2m.leftAccessor];
|
|
158
|
+
const rightTable = manifestTables[m2m.rightAccessor];
|
|
159
|
+
if (leftTable) {
|
|
160
|
+
leftTable.relations.push({
|
|
161
|
+
name: m2m.as,
|
|
162
|
+
targetTable: m2m.rightTable,
|
|
163
|
+
targetAccessor: m2m.rightAccessor,
|
|
164
|
+
fkColumn: m2m.leftFkColumn,
|
|
165
|
+
fkSqlColumn: m2m.leftFkColumn,
|
|
166
|
+
targetColumn: "id",
|
|
167
|
+
cardinality: "many",
|
|
168
|
+
inverse: m2m.inverse,
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
if (rightTable) {
|
|
172
|
+
rightTable.relations.push({
|
|
173
|
+
name: m2m.inverse,
|
|
174
|
+
targetTable: m2m.leftTable,
|
|
175
|
+
targetAccessor: m2m.leftAccessor,
|
|
176
|
+
fkColumn: m2m.rightFkColumn,
|
|
177
|
+
fkSqlColumn: m2m.rightFkColumn,
|
|
178
|
+
targetColumn: "id",
|
|
179
|
+
cardinality: "many",
|
|
180
|
+
inverse: m2m.as,
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
return {
|
|
185
|
+
version: 1,
|
|
186
|
+
tables: manifestTables,
|
|
187
|
+
manyToMany,
|
|
188
|
+
};
|
|
189
|
+
}
|
|
190
|
+
export function validateManifest(manifest) {
|
|
191
|
+
const errors = [];
|
|
192
|
+
const sqlNames = new Set();
|
|
193
|
+
for (const table of Object.values(manifest.tables)) {
|
|
194
|
+
if (sqlNames.has(table.sqlName)) {
|
|
195
|
+
errors.push(`Duplicate table SQL name: ${table.sqlName}`);
|
|
196
|
+
}
|
|
197
|
+
sqlNames.add(table.sqlName);
|
|
198
|
+
for (const col of table.columns) {
|
|
199
|
+
if (col.kind === "fk" && col.fkTarget) {
|
|
200
|
+
const [targetTable] = col.fkTarget.split(".");
|
|
201
|
+
const exists = Object.values(manifest.tables).some((t) => t.sqlName === targetTable);
|
|
202
|
+
if (!exists) {
|
|
203
|
+
errors.push(`FK ${table.accessor}.${col.tsName} references unknown table ${targetTable}`);
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
return errors;
|
|
209
|
+
}
|
|
210
|
+
//# sourceMappingURL=schema-to-manifest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-to-manifest.js","sourceRoot":"","sources":["../../src/codegen/schema-to-manifest.ts"],"names":[],"mappings":"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"}
|
package/dist/config.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export type NeoOrmConfig = {
|
|
2
|
+
schema: string;
|
|
3
|
+
out: string;
|
|
4
|
+
datasource: {
|
|
5
|
+
provider: "postgresql";
|
|
6
|
+
url: string;
|
|
7
|
+
};
|
|
8
|
+
};
|
|
9
|
+
export declare function defineConfig(config: NeoOrmConfig): NeoOrmConfig;
|
|
10
|
+
export declare function loadConfig(cwd: string): Promise<NeoOrmConfig>;
|
|
11
|
+
//# sourceMappingURL=config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,EAAE;QACV,QAAQ,EAAE,YAAY,CAAC;QACvB,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;CACH,CAAC;AAEF,wBAAgB,YAAY,CAAC,MAAM,EAAE,YAAY,GAAG,YAAY,CAE/D;AAED,wBAAsB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAkBnE"}
|
package/dist/config.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export function defineConfig(config) {
|
|
2
|
+
return config;
|
|
3
|
+
}
|
|
4
|
+
export async function loadConfig(cwd) {
|
|
5
|
+
const { join } = await import("node:path");
|
|
6
|
+
const { pathToFileURL } = await import("node:url");
|
|
7
|
+
const { register } = await import("tsx/esm/api");
|
|
8
|
+
register();
|
|
9
|
+
const configPath = join(cwd, "neoorm.config.ts");
|
|
10
|
+
const mod = await import(pathToFileURL(configPath).href);
|
|
11
|
+
const config = mod.default ?? mod.config;
|
|
12
|
+
if (!config?.schema || !config?.out || !config?.datasource?.url) {
|
|
13
|
+
throw new Error("neoorm.config.ts must export defineConfig({ schema, out, datasource: { provider, url } })");
|
|
14
|
+
}
|
|
15
|
+
return config;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AASA,MAAM,UAAU,YAAY,CAAC,MAAoB;IAC/C,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,GAAW;IAC1C,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,CAAC;IAC3C,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,MAAM,CAAC,UAAU,CAAC,CAAC;IACnD,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,CAAC;IAEjD,QAAQ,EAAE,CAAC;IAEX,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC;IACjD,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC;IACzD,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,IAAI,GAAG,CAAC,MAAM,CAAC;IAEzC,IAAI,CAAC,MAAM,EAAE,MAAM,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC;QAChE,MAAM,IAAI,KAAK,CACb,2FAA2F,CAC5F,CAAC;IACJ,CAAC;IAED,OAAO,MAAsB,CAAC;AAChC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/dialect/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AACvJ,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/dialect/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres.d.ts","sourceRoot":"","sources":["../../src/dialect/postgres.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,OAAO,EAKR,MAAM,YAAY,CAAC;AAEpB,iBAAS,CAAC,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAE/B;AAqHD,eAAO,MAAM,eAAe,EAAE,OAQ7B,CAAC;AAEF,OAAO,EAAE,CAAC,IAAI,eAAe,EAAE,CAAC"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
function q(name) {
|
|
2
|
+
return `"${name.replace(/"/g, '""')}"`;
|
|
3
|
+
}
|
|
4
|
+
const whereOperators = {
|
|
5
|
+
equals: (col, i) => `${col} = $${i}`,
|
|
6
|
+
contains: (col, i) => `${col} ILIKE $${i}`,
|
|
7
|
+
startsWith: (col, i) => `${col} ILIKE $${i}`,
|
|
8
|
+
endsWith: (col, i) => `${col} ILIKE $${i}`,
|
|
9
|
+
gt: (col, i) => `${col} > $${i}`,
|
|
10
|
+
gte: (col, i) => `${col} >= $${i}`,
|
|
11
|
+
lt: (col, i) => `${col} < $${i}`,
|
|
12
|
+
lte: (col, i) => `${col} <= $${i}`,
|
|
13
|
+
in: (col, i) => `${col} = ANY($${i})`,
|
|
14
|
+
};
|
|
15
|
+
function columnType(col) {
|
|
16
|
+
switch (col.kind) {
|
|
17
|
+
case "id":
|
|
18
|
+
case "text":
|
|
19
|
+
case "fk":
|
|
20
|
+
return "TEXT";
|
|
21
|
+
case "bool":
|
|
22
|
+
return "BOOLEAN";
|
|
23
|
+
case "int":
|
|
24
|
+
return "INTEGER";
|
|
25
|
+
case "timestamp":
|
|
26
|
+
return "TIMESTAMPTZ";
|
|
27
|
+
default: {
|
|
28
|
+
const _exhaustive = col.kind;
|
|
29
|
+
return _exhaustive;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
function columnDef(col) {
|
|
34
|
+
const parts = [q(col.sqlName), columnType(col)];
|
|
35
|
+
if (col.primary) {
|
|
36
|
+
parts.push("PRIMARY KEY");
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
if (!col.nullable)
|
|
40
|
+
parts.push("NOT NULL");
|
|
41
|
+
if (col.unique)
|
|
42
|
+
parts.push("UNIQUE");
|
|
43
|
+
}
|
|
44
|
+
if (col.defaultNow) {
|
|
45
|
+
parts.push(`DEFAULT ${defaultNowExpression()}`);
|
|
46
|
+
}
|
|
47
|
+
else if (col.defaultValue !== undefined) {
|
|
48
|
+
const val = typeof col.defaultValue === "string"
|
|
49
|
+
? `'${col.defaultValue.replace(/'/g, "''")}'`
|
|
50
|
+
: String(col.defaultValue);
|
|
51
|
+
parts.push(`DEFAULT ${val}`);
|
|
52
|
+
}
|
|
53
|
+
return parts.join(" ");
|
|
54
|
+
}
|
|
55
|
+
function defaultNowExpression() {
|
|
56
|
+
return "NOW()";
|
|
57
|
+
}
|
|
58
|
+
function emitCreateTable(table) {
|
|
59
|
+
const lines = [];
|
|
60
|
+
for (const col of table.columns) {
|
|
61
|
+
if (col.primary && table.primaryKey.length <= 1) {
|
|
62
|
+
lines.push(` ${columnDef(col)}`);
|
|
63
|
+
}
|
|
64
|
+
else if (!col.primary) {
|
|
65
|
+
lines.push(` ${columnDef(col)}`);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
if (table.primaryKey.length > 1) {
|
|
69
|
+
const pkCols = table.primaryKey.map((c) => q(c)).join(", ");
|
|
70
|
+
lines.push(` PRIMARY KEY (${pkCols})`);
|
|
71
|
+
}
|
|
72
|
+
for (const idx of table.indexes) {
|
|
73
|
+
if (idx.unique) {
|
|
74
|
+
const cols = idx.columns.map((c) => q(c)).join(", ");
|
|
75
|
+
lines.push(` UNIQUE (${cols})`);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
for (const col of table.columns) {
|
|
79
|
+
if (col.kind === "fk" && col.fkTarget) {
|
|
80
|
+
const [targetTable, targetCol] = col.fkTarget.split(".");
|
|
81
|
+
const onDelete = col.onDelete ? ` ON DELETE ${col.onDelete.toUpperCase()}` : "";
|
|
82
|
+
lines.push(` FOREIGN KEY (${q(col.sqlName)}) REFERENCES ${q(targetTable)}(${q(targetCol)})${onDelete}`);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
const body = lines.join(",\n");
|
|
86
|
+
return `CREATE TABLE ${q(table.sqlName)} (\n${body}\n);`;
|
|
87
|
+
}
|
|
88
|
+
function emitAlterTable(_table, diff) {
|
|
89
|
+
const stmts = [];
|
|
90
|
+
if (diff.addColumns) {
|
|
91
|
+
for (const col of diff.addColumns) {
|
|
92
|
+
stmts.push(`ALTER TABLE ${q(_table.sqlName)} ADD COLUMN ${columnDef(col)};`);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
if (diff.dropColumns) {
|
|
96
|
+
for (const col of diff.dropColumns) {
|
|
97
|
+
stmts.push(`ALTER TABLE ${q(_table.sqlName)} DROP COLUMN ${q(col)};`);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return stmts;
|
|
101
|
+
}
|
|
102
|
+
export const postgresDialect = {
|
|
103
|
+
name: "postgresql",
|
|
104
|
+
quoteIdentifier: q,
|
|
105
|
+
columnType,
|
|
106
|
+
emitCreateTable,
|
|
107
|
+
emitAlterTable,
|
|
108
|
+
whereOperators,
|
|
109
|
+
defaultNowExpression,
|
|
110
|
+
};
|
|
111
|
+
export { q as quoteIdentifier };
|
|
112
|
+
//# sourceMappingURL=postgres.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres.js","sourceRoot":"","sources":["../../src/dialect/postgres.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
export type ColumnKindMeta = "id" | "text" | "bool" | "int" | "timestamp" | "fk";
|
|
2
|
+
export type ManifestColumn = {
|
|
3
|
+
tsName: string;
|
|
4
|
+
sqlName: string;
|
|
5
|
+
kind: ColumnKindMeta;
|
|
6
|
+
nullable: boolean;
|
|
7
|
+
unique: boolean;
|
|
8
|
+
primary: boolean;
|
|
9
|
+
defaultValue?: unknown;
|
|
10
|
+
defaultNow: boolean;
|
|
11
|
+
fkTarget?: string;
|
|
12
|
+
fkAs?: string;
|
|
13
|
+
fkInverse?: string;
|
|
14
|
+
onDelete?: string;
|
|
15
|
+
};
|
|
16
|
+
export type ManifestRelation = {
|
|
17
|
+
name: string;
|
|
18
|
+
targetTable: string;
|
|
19
|
+
targetAccessor: string;
|
|
20
|
+
fkColumn: string;
|
|
21
|
+
fkSqlColumn: string;
|
|
22
|
+
targetColumn: string;
|
|
23
|
+
cardinality: "one" | "many";
|
|
24
|
+
inverse: string;
|
|
25
|
+
onDelete?: string;
|
|
26
|
+
};
|
|
27
|
+
export type ManifestManyToMany = {
|
|
28
|
+
leftTable: string;
|
|
29
|
+
leftAccessor: string;
|
|
30
|
+
rightTable: string;
|
|
31
|
+
rightAccessor: string;
|
|
32
|
+
throughTable: string;
|
|
33
|
+
throughAccessor: string;
|
|
34
|
+
leftFkColumn: string;
|
|
35
|
+
rightFkColumn: string;
|
|
36
|
+
leftRelation: string;
|
|
37
|
+
rightRelation: string;
|
|
38
|
+
as: string;
|
|
39
|
+
inverse: string;
|
|
40
|
+
};
|
|
41
|
+
export type ManifestIndex = {
|
|
42
|
+
name: string;
|
|
43
|
+
columns: readonly string[];
|
|
44
|
+
unique: boolean;
|
|
45
|
+
};
|
|
46
|
+
export type ManifestTable = {
|
|
47
|
+
accessor: string;
|
|
48
|
+
sqlName: string;
|
|
49
|
+
columns: ManifestColumn[];
|
|
50
|
+
relations: ManifestRelation[];
|
|
51
|
+
indexes: ManifestIndex[];
|
|
52
|
+
primaryKey: readonly string[];
|
|
53
|
+
};
|
|
54
|
+
export type Manifest = {
|
|
55
|
+
version: 1;
|
|
56
|
+
tables: Record<string, ManifestTable>;
|
|
57
|
+
manyToMany: ManifestManyToMany[];
|
|
58
|
+
};
|
|
59
|
+
export type CompiledQuery = {
|
|
60
|
+
text: string;
|
|
61
|
+
params: unknown[];
|
|
62
|
+
};
|
|
63
|
+
export type WhereOperator = "equals" | "contains" | "startsWith" | "endsWith" | "gt" | "gte" | "lt" | "lte" | "in";
|
|
64
|
+
export type OperatorMap = Record<WhereOperator, (sqlColumn: string, paramIndex: number) => string>;
|
|
65
|
+
export type TableDiff = {
|
|
66
|
+
create?: ManifestTable;
|
|
67
|
+
addColumns?: ManifestColumn[];
|
|
68
|
+
dropColumns?: string[];
|
|
69
|
+
};
|
|
70
|
+
export type Dialect = {
|
|
71
|
+
readonly name: string;
|
|
72
|
+
quoteIdentifier(name: string): string;
|
|
73
|
+
columnType(col: ManifestColumn): string;
|
|
74
|
+
emitCreateTable(table: ManifestTable): string;
|
|
75
|
+
emitAlterTable(table: ManifestTable, diff: TableDiff): string[];
|
|
76
|
+
whereOperators: OperatorMap;
|
|
77
|
+
defaultNowExpression(): string;
|
|
78
|
+
};
|
|
79
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/dialect/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/dialect/types.ts"],"names":[],"mappings":""}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export { defineConfig, loadConfig } from "./config.js";
|
|
2
|
+
export type { NeoOrmConfig } from "./config.js";
|
|
3
|
+
export { createNeoOrmClient, createNeoOrmClientFromPool } from "./runtime/client.js";
|
|
4
|
+
export type { NeoOrmClient, TableRepository, TypedNeoOrmClient, TypedTableRepository, DefaultWithMap } from "./runtime/client.js";
|
|
5
|
+
export type { Manifest, ManifestTable, ManifestColumn, ManifestRelation, ManifestManyToMany } from "./dialect/types.js";
|
|
6
|
+
export { postgresDialect } from "./dialect/postgres.js";
|
|
7
|
+
export { generateFromSchema } from "./codegen/generate.js";
|
|
8
|
+
export { schemaToManifest, validateManifest } from "./codegen/schema-to-manifest.js";
|
|
9
|
+
export { migrateDeploy, dbPush } from "./migrate/runner.js";
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACvD,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEhD,OAAO,EAAE,kBAAkB,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AACrF,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAElI,YAAY,EAAE,QAAQ,EAAE,aAAa,EAAE,cAAc,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxH,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AAErF,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { defineConfig, loadConfig } from "./config.js";
|
|
2
|
+
export { createNeoOrmClient, createNeoOrmClientFromPool } from "./runtime/client.js";
|
|
3
|
+
export { postgresDialect } from "./dialect/postgres.js";
|
|
4
|
+
export { generateFromSchema } from "./codegen/generate.js";
|
|
5
|
+
export { schemaToManifest, validateManifest } from "./codegen/schema-to-manifest.js";
|
|
6
|
+
export { migrateDeploy, dbPush } from "./migrate/runner.js";
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAGvD,OAAO,EAAE,kBAAkB,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AAIrF,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AAErF,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pull.d.ts","sourceRoot":"","sources":["../../src/introspect/pull.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAiB/B,wBAAsB,kBAAkB,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAuFpE"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { toCamelCase } from "../utils/case.js";
|
|
2
|
+
export async function introspectPostgres(pool) {
|
|
3
|
+
const tablesResult = await pool.query(`
|
|
4
|
+
SELECT table_name
|
|
5
|
+
FROM information_schema.tables
|
|
6
|
+
WHERE table_schema = 'public'
|
|
7
|
+
AND table_type = 'BASE TABLE'
|
|
8
|
+
AND table_name NOT LIKE '_neoorm_%'
|
|
9
|
+
ORDER BY table_name
|
|
10
|
+
`);
|
|
11
|
+
const lines = [
|
|
12
|
+
`import {`,
|
|
13
|
+
` defineSchema,`,
|
|
14
|
+
` table,`,
|
|
15
|
+
` id,`,
|
|
16
|
+
` text,`,
|
|
17
|
+
` bool,`,
|
|
18
|
+
` int,`,
|
|
19
|
+
` timestamp,`,
|
|
20
|
+
` fk,`,
|
|
21
|
+
` index,`,
|
|
22
|
+
` primaryKey,`,
|
|
23
|
+
`} from "neoorm/schema";`,
|
|
24
|
+
``,
|
|
25
|
+
`export const schema = defineSchema({`,
|
|
26
|
+
];
|
|
27
|
+
for (const { table_name } of tablesResult.rows) {
|
|
28
|
+
const colsResult = await pool.query(`
|
|
29
|
+
SELECT column_name, data_type, is_nullable, column_default
|
|
30
|
+
FROM information_schema.columns
|
|
31
|
+
WHERE table_schema = 'public' AND table_name = $1
|
|
32
|
+
ORDER BY ordinal_position
|
|
33
|
+
`, [table_name]);
|
|
34
|
+
const fkResult = await pool.query(`
|
|
35
|
+
SELECT
|
|
36
|
+
kcu.column_name,
|
|
37
|
+
ccu.table_name AS foreign_table_name,
|
|
38
|
+
ccu.column_name AS foreign_column_name
|
|
39
|
+
FROM information_schema.table_constraints tc
|
|
40
|
+
JOIN information_schema.key_column_usage kcu
|
|
41
|
+
ON tc.constraint_name = kcu.constraint_name
|
|
42
|
+
JOIN information_schema.constraint_column_usage ccu
|
|
43
|
+
ON ccu.constraint_name = tc.constraint_name
|
|
44
|
+
WHERE tc.constraint_type = 'FOREIGN KEY'
|
|
45
|
+
AND tc.table_name = $1
|
|
46
|
+
`, [table_name]);
|
|
47
|
+
const fkMap = new Map(fkResult.rows.map((r) => [r.column_name, r]));
|
|
48
|
+
const accessor = toCamelCase(table_name.endsWith("s") ? table_name : `${table_name}s`);
|
|
49
|
+
lines.push(` ${accessor}: table("${table_name}", {`);
|
|
50
|
+
for (const col of colsResult.rows) {
|
|
51
|
+
const tsName = toCamelCase(col.column_name);
|
|
52
|
+
const fk = fkMap.get(col.column_name);
|
|
53
|
+
if (fk) {
|
|
54
|
+
const relName = tsName.replace(/Id$/, "");
|
|
55
|
+
lines.push(` ${tsName}: fk("${fk.foreign_table_name}.${fk.foreign_column_name}", {`, ` as: "${relName}",`, ` inverse: "${accessor}",`, ` nullable: ${col.is_nullable === "YES"},`, ` }),`);
|
|
56
|
+
}
|
|
57
|
+
else if (col.column_name === "id") {
|
|
58
|
+
lines.push(` id: id.primary(),`);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
const kind = pgTypeToKind(col.data_type);
|
|
62
|
+
let def = ` ${tsName}: ${kind}()`;
|
|
63
|
+
if (col.is_nullable === "NO")
|
|
64
|
+
def += `.notNull()`;
|
|
65
|
+
if (col.column_default?.includes("now()"))
|
|
66
|
+
def += `.defaultNow()`;
|
|
67
|
+
lines.push(`${def},`);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
lines.push(` }),`);
|
|
71
|
+
}
|
|
72
|
+
lines.push(`});`);
|
|
73
|
+
lines.push(``);
|
|
74
|
+
return lines.join("\n");
|
|
75
|
+
}
|
|
76
|
+
function pgTypeToKind(dataType) {
|
|
77
|
+
switch (dataType) {
|
|
78
|
+
case "boolean":
|
|
79
|
+
return "bool";
|
|
80
|
+
case "integer":
|
|
81
|
+
case "bigint":
|
|
82
|
+
case "smallint":
|
|
83
|
+
return "int";
|
|
84
|
+
case "timestamp with time zone":
|
|
85
|
+
case "timestamp without time zone":
|
|
86
|
+
return "timestamp";
|
|
87
|
+
default:
|
|
88
|
+
return "text";
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=pull.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pull.js","sourceRoot":"","sources":["../../src/introspect/pull.ts"],"names":[],"mappings":"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"}
|