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.
Files changed (127) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +86 -0
  3. package/dist/bin/neoorm.d.ts +3 -0
  4. package/dist/bin/neoorm.d.ts.map +1 -0
  5. package/dist/bin/neoorm.js +111 -0
  6. package/dist/bin/neoorm.js.map +1 -0
  7. package/dist/codegen/emit-includes.d.ts +3 -0
  8. package/dist/codegen/emit-includes.d.ts.map +1 -0
  9. package/dist/codegen/emit-includes.js +133 -0
  10. package/dist/codegen/emit-includes.js.map +1 -0
  11. package/dist/codegen/generate.d.ts +24 -0
  12. package/dist/codegen/generate.d.ts.map +1 -0
  13. package/dist/codegen/generate.js +156 -0
  14. package/dist/codegen/generate.js.map +1 -0
  15. package/dist/codegen/schema-to-manifest.d.ts +8 -0
  16. package/dist/codegen/schema-to-manifest.d.ts.map +1 -0
  17. package/dist/codegen/schema-to-manifest.js +210 -0
  18. package/dist/codegen/schema-to-manifest.js.map +1 -0
  19. package/dist/config.d.ts +11 -0
  20. package/dist/config.d.ts.map +1 -0
  21. package/dist/config.js +17 -0
  22. package/dist/config.js.map +1 -0
  23. package/dist/dialect/index.d.ts +3 -0
  24. package/dist/dialect/index.d.ts.map +1 -0
  25. package/dist/dialect/index.js +2 -0
  26. package/dist/dialect/index.js.map +1 -0
  27. package/dist/dialect/postgres.d.ts +5 -0
  28. package/dist/dialect/postgres.d.ts.map +1 -0
  29. package/dist/dialect/postgres.js +112 -0
  30. package/dist/dialect/postgres.js.map +1 -0
  31. package/dist/dialect/types.d.ts +79 -0
  32. package/dist/dialect/types.d.ts.map +1 -0
  33. package/dist/dialect/types.js +2 -0
  34. package/dist/dialect/types.js.map +1 -0
  35. package/dist/index.d.ts +10 -0
  36. package/dist/index.d.ts.map +1 -0
  37. package/dist/index.js +7 -0
  38. package/dist/index.js.map +1 -0
  39. package/dist/introspect/pull.d.ts +3 -0
  40. package/dist/introspect/pull.d.ts.map +1 -0
  41. package/dist/introspect/pull.js +91 -0
  42. package/dist/introspect/pull.js.map +1 -0
  43. package/dist/migrate/runner.d.ts +9 -0
  44. package/dist/migrate/runner.d.ts.map +1 -0
  45. package/dist/migrate/runner.js +70 -0
  46. package/dist/migrate/runner.js.map +1 -0
  47. package/dist/runtime/client.d.ts +61 -0
  48. package/dist/runtime/client.d.ts.map +1 -0
  49. package/dist/runtime/client.js +54 -0
  50. package/dist/runtime/client.js.map +1 -0
  51. package/dist/runtime/executor.d.ts +10 -0
  52. package/dist/runtime/executor.d.ts.map +1 -0
  53. package/dist/runtime/executor.js +62 -0
  54. package/dist/runtime/executor.js.map +1 -0
  55. package/dist/runtime/query/compile.d.ts +23 -0
  56. package/dist/runtime/query/compile.d.ts.map +1 -0
  57. package/dist/runtime/query/compile.js +182 -0
  58. package/dist/runtime/query/compile.js.map +1 -0
  59. package/dist/runtime/query/create.d.ts +8 -0
  60. package/dist/runtime/query/create.d.ts.map +1 -0
  61. package/dist/runtime/query/create.js +139 -0
  62. package/dist/runtime/query/create.js.map +1 -0
  63. package/dist/runtime/query/delete.d.ts +12 -0
  64. package/dist/runtime/query/delete.d.ts.map +1 -0
  65. package/dist/runtime/query/delete.js +35 -0
  66. package/dist/runtime/query/delete.js.map +1 -0
  67. package/dist/runtime/query/find.d.ts +21 -0
  68. package/dist/runtime/query/find.d.ts.map +1 -0
  69. package/dist/runtime/query/find.js +172 -0
  70. package/dist/runtime/query/find.js.map +1 -0
  71. package/dist/runtime/query/update.d.ts +17 -0
  72. package/dist/runtime/query/update.d.ts.map +1 -0
  73. package/dist/runtime/query/update.js +63 -0
  74. package/dist/runtime/query/update.js.map +1 -0
  75. package/dist/runtime/types.d.ts +48 -0
  76. package/dist/runtime/types.d.ts.map +1 -0
  77. package/dist/runtime/types.js +2 -0
  78. package/dist/runtime/types.js.map +1 -0
  79. package/dist/schema/column.d.ts +39 -0
  80. package/dist/schema/column.d.ts.map +1 -0
  81. package/dist/schema/column.js +70 -0
  82. package/dist/schema/column.js.map +1 -0
  83. package/dist/schema/define-schema.d.ts +6 -0
  84. package/dist/schema/define-schema.d.ts.map +1 -0
  85. package/dist/schema/define-schema.js +4 -0
  86. package/dist/schema/define-schema.js.map +1 -0
  87. package/dist/schema/index.d.ts +13 -0
  88. package/dist/schema/index.d.ts.map +1 -0
  89. package/dist/schema/index.js +6 -0
  90. package/dist/schema/index.js.map +1 -0
  91. package/dist/schema/many-to-many.d.ts +21 -0
  92. package/dist/schema/many-to-many.d.ts.map +1 -0
  93. package/dist/schema/many-to-many.js +20 -0
  94. package/dist/schema/many-to-many.js.map +1 -0
  95. package/dist/schema/relation-types.d.ts +74 -0
  96. package/dist/schema/relation-types.d.ts.map +1 -0
  97. package/dist/schema/relation-types.js +2 -0
  98. package/dist/schema/relation-types.js.map +1 -0
  99. package/dist/schema/relation.d.ts +24 -0
  100. package/dist/schema/relation.d.ts.map +1 -0
  101. package/dist/schema/relation.js +25 -0
  102. package/dist/schema/relation.js.map +1 -0
  103. package/dist/schema/table.d.ts +28 -0
  104. package/dist/schema/table.d.ts.map +1 -0
  105. package/dist/schema/table.js +23 -0
  106. package/dist/schema/table.js.map +1 -0
  107. package/dist/schema/types.d.ts +115 -0
  108. package/dist/schema/types.d.ts.map +1 -0
  109. package/dist/schema/types.js +2 -0
  110. package/dist/schema/types.js.map +1 -0
  111. package/dist/sql/builder.d.ts +17 -0
  112. package/dist/sql/builder.d.ts.map +1 -0
  113. package/dist/sql/builder.js +51 -0
  114. package/dist/sql/builder.js.map +1 -0
  115. package/dist/sql/index.d.ts +7 -0
  116. package/dist/sql/index.d.ts.map +1 -0
  117. package/dist/sql/index.js +6 -0
  118. package/dist/sql/index.js.map +1 -0
  119. package/dist/sql/template.d.ts +16 -0
  120. package/dist/sql/template.d.ts.map +1 -0
  121. package/dist/sql/template.js +43 -0
  122. package/dist/sql/template.js.map +1 -0
  123. package/dist/utils/case.d.ts +5 -0
  124. package/dist/utils/case.d.ts.map +1 -0
  125. package/dist/utils/case.js +20 -0
  126. package/dist/utils/case.js.map +1 -0
  127. 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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"}
@@ -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,3 @@
1
+ export type { Dialect, Manifest, ManifestColumn, ManifestManyToMany, ManifestRelation, ManifestTable, CompiledQuery, WhereOperator } from "./types.js";
2
+ export { postgresDialect, quoteIdentifier } from "./postgres.js";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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,2 @@
1
+ export { postgresDialect, quoteIdentifier } from "./postgres.js";
2
+ //# sourceMappingURL=index.js.map
@@ -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,5 @@
1
+ import type { Dialect } from "./types.js";
2
+ declare function q(name: string): string;
3
+ export declare const postgresDialect: Dialect;
4
+ export { q as quoteIdentifier };
5
+ //# sourceMappingURL=postgres.d.ts.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/dialect/types.ts"],"names":[],"mappings":""}
@@ -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,3 @@
1
+ import type { Pool } from "pg";
2
+ export declare function introspectPostgres(pool: Pool): Promise<string>;
3
+ //# sourceMappingURL=pull.d.ts.map
@@ -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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"}