@neogroup/neorm 0.0.1 → 0.0.2

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 (225) hide show
  1. package/README.md +1 -0
  2. package/dist/database/Connection.d.ts +10 -0
  3. package/dist/database/Connection.js +3 -0
  4. package/dist/database/Connection.js.map +1 -0
  5. package/dist/database/DB.d.ts +58 -0
  6. package/dist/database/DB.js +229 -0
  7. package/dist/database/DB.js.map +1 -0
  8. package/dist/database/DataConnection.d.ts +24 -0
  9. package/dist/database/DataConnection.js +99 -0
  10. package/dist/database/DataConnection.js.map +1 -0
  11. package/dist/database/DataSet.d.ts +3 -0
  12. package/dist/database/DataSet.js +3 -0
  13. package/dist/database/DataSet.js.map +1 -0
  14. package/dist/database/DataSource.d.ts +23 -0
  15. package/dist/database/DataSource.js +56 -0
  16. package/dist/database/DataSource.js.map +1 -0
  17. package/dist/database/DataTable.d.ts +19 -0
  18. package/dist/database/DataTable.js +75 -0
  19. package/dist/database/DataTable.js.map +1 -0
  20. package/dist/database/index.d.ts +7 -0
  21. package/dist/database/index.js +24 -0
  22. package/dist/database/index.js.map +1 -0
  23. package/dist/database/sources/index.d.ts +3 -0
  24. package/dist/database/sources/index.js +20 -0
  25. package/dist/database/sources/index.js.map +1 -0
  26. package/dist/database/sources/mysql/MysqlConnection.d.ts +14 -0
  27. package/dist/database/sources/mysql/MysqlConnection.js +36 -0
  28. package/dist/database/sources/mysql/MysqlConnection.js.map +1 -0
  29. package/dist/database/sources/mysql/MysqlDataSource.d.ts +24 -0
  30. package/dist/database/sources/mysql/MysqlDataSource.js +72 -0
  31. package/dist/database/sources/mysql/MysqlDataSource.js.map +1 -0
  32. package/dist/database/sources/mysql/MysqlQueryBuilder.d.ts +6 -0
  33. package/dist/database/sources/mysql/MysqlQueryBuilder.js +28 -0
  34. package/dist/database/sources/mysql/MysqlQueryBuilder.js.map +1 -0
  35. package/dist/database/sources/mysql/index.d.ts +3 -0
  36. package/dist/database/sources/mysql/index.js +20 -0
  37. package/dist/database/sources/mysql/index.js.map +1 -0
  38. package/dist/database/sources/postgres/PostgresConnection.d.ts +13 -0
  39. package/dist/database/sources/postgres/PostgresConnection.js +40 -0
  40. package/dist/database/sources/postgres/PostgresConnection.js.map +1 -0
  41. package/dist/database/sources/postgres/PostgresDataSource.d.ts +24 -0
  42. package/dist/database/sources/postgres/PostgresDataSource.js +73 -0
  43. package/dist/database/sources/postgres/PostgresDataSource.js.map +1 -0
  44. package/dist/database/sources/postgres/PostgresQueryBuilder.d.ts +5 -0
  45. package/dist/database/sources/postgres/PostgresQueryBuilder.js +13 -0
  46. package/dist/database/sources/postgres/PostgresQueryBuilder.js.map +1 -0
  47. package/dist/database/sources/postgres/index.d.ts +2 -0
  48. package/dist/database/sources/postgres/index.js +19 -0
  49. package/dist/database/sources/postgres/index.js.map +1 -0
  50. package/dist/database/sources/sqlite/SqliteConnection.d.ts +14 -0
  51. package/dist/database/sources/sqlite/SqliteConnection.js +37 -0
  52. package/dist/database/sources/sqlite/SqliteConnection.js.map +1 -0
  53. package/dist/database/sources/sqlite/SqliteDataSource.d.ts +11 -0
  54. package/dist/database/sources/sqlite/SqliteDataSource.js +34 -0
  55. package/dist/database/sources/sqlite/SqliteDataSource.js.map +1 -0
  56. package/dist/database/sources/sqlite/SqliteQueryBuilder.d.ts +6 -0
  57. package/dist/database/sources/sqlite/SqliteQueryBuilder.js +23 -0
  58. package/dist/database/sources/sqlite/SqliteQueryBuilder.js.map +1 -0
  59. package/dist/database/sources/sqlite/index.d.ts +3 -0
  60. package/dist/database/sources/sqlite/index.js +20 -0
  61. package/dist/database/sources/sqlite/index.js.map +1 -0
  62. package/dist/entities/CastType.d.ts +1 -0
  63. package/dist/entities/CastType.js +3 -0
  64. package/dist/entities/CastType.js.map +1 -0
  65. package/dist/entities/Entities.d.ts +14 -0
  66. package/dist/entities/Entities.js +85 -0
  67. package/dist/entities/Entities.js.map +1 -0
  68. package/dist/entities/EntityQuery.d.ts +60 -0
  69. package/dist/entities/EntityQuery.js +305 -0
  70. package/dist/entities/EntityQuery.js.map +1 -0
  71. package/dist/entities/RelationshipType.d.ts +1 -0
  72. package/dist/entities/RelationshipType.js +3 -0
  73. package/dist/entities/RelationshipType.js.map +1 -0
  74. package/dist/entities/decorators/BelongsTo.d.ts +2 -0
  75. package/dist/entities/decorators/BelongsTo.js +16 -0
  76. package/dist/entities/decorators/BelongsTo.js.map +1 -0
  77. package/dist/entities/decorators/Column.d.ts +13 -0
  78. package/dist/entities/decorators/Column.js +13 -0
  79. package/dist/entities/decorators/Column.js.map +1 -0
  80. package/dist/entities/decorators/Entity.d.ts +15 -0
  81. package/dist/entities/decorators/Entity.js +170 -0
  82. package/dist/entities/decorators/Entity.js.map +1 -0
  83. package/dist/entities/decorators/HasMany.d.ts +2 -0
  84. package/dist/entities/decorators/HasMany.js +16 -0
  85. package/dist/entities/decorators/HasMany.js.map +1 -0
  86. package/dist/entities/decorators/HasManyThrough.d.ts +2 -0
  87. package/dist/entities/decorators/HasManyThrough.js +24 -0
  88. package/dist/entities/decorators/HasManyThrough.js.map +1 -0
  89. package/dist/entities/decorators/HasOne.d.ts +2 -0
  90. package/dist/entities/decorators/HasOne.js +13 -0
  91. package/dist/entities/decorators/HasOne.js.map +1 -0
  92. package/dist/entities/decorators/HasOneThrough.d.ts +2 -0
  93. package/dist/entities/decorators/HasOneThrough.js +24 -0
  94. package/dist/entities/decorators/HasOneThrough.js.map +1 -0
  95. package/dist/entities/decorators/casts.d.ts +3 -0
  96. package/dist/entities/decorators/casts.js +39 -0
  97. package/dist/entities/decorators/casts.js.map +1 -0
  98. package/dist/entities/decorators/index.d.ts +7 -0
  99. package/dist/entities/decorators/index.js +24 -0
  100. package/dist/entities/decorators/index.js.map +1 -0
  101. package/dist/entities/decorators/metadata.d.ts +19 -0
  102. package/dist/entities/decorators/metadata.js +12 -0
  103. package/dist/entities/decorators/metadata.js.map +1 -0
  104. package/dist/entities/index.d.ts +5 -3
  105. package/dist/entities/index.js +5 -2
  106. package/dist/entities/index.js.map +1 -1
  107. package/dist/entities/relationship.d.ts +1 -6
  108. package/dist/entities/relationship.js +1 -22
  109. package/dist/entities/relationship.js.map +1 -1
  110. package/dist/index.d.ts +2 -9
  111. package/dist/index.js +2 -14
  112. package/dist/index.js.map +1 -1
  113. package/dist/query/DeleteQuery.d.ts +8 -0
  114. package/dist/query/DeleteQuery.js +17 -0
  115. package/dist/query/DeleteQuery.js.map +1 -0
  116. package/dist/query/InsertQuery.d.ts +8 -0
  117. package/dist/query/InsertQuery.js +17 -0
  118. package/dist/query/InsertQuery.js.map +1 -0
  119. package/dist/query/QueryTable.d.ts +7 -0
  120. package/dist/query/QueryTable.js +3 -0
  121. package/dist/query/QueryTable.js.map +1 -0
  122. package/dist/query/SelectQuery.d.ts +9 -0
  123. package/dist/query/SelectQuery.js +33 -0
  124. package/dist/query/SelectQuery.js.map +1 -0
  125. package/dist/query/UpdateQuery.d.ts +8 -0
  126. package/dist/query/UpdateQuery.js +17 -0
  127. package/dist/query/UpdateQuery.js.map +1 -0
  128. package/dist/query/builders/DefaultQueryBuilder.d.ts +87 -0
  129. package/dist/query/builders/DefaultQueryBuilder.js +524 -0
  130. package/dist/query/builders/DefaultQueryBuilder.js.map +1 -0
  131. package/dist/query/builders/QueryBuilder.d.ts +5 -0
  132. package/dist/query/builders/QueryBuilder.js +7 -0
  133. package/dist/query/builders/QueryBuilder.js.map +1 -0
  134. package/dist/query/builders/index.d.ts +2 -2
  135. package/dist/query/builders/index.js +2 -2
  136. package/dist/query/builders/index.js.map +1 -1
  137. package/dist/query/conditions/BasicCondition.d.ts +6 -0
  138. package/dist/query/conditions/BasicCondition.js +3 -0
  139. package/dist/query/conditions/BasicCondition.js.map +1 -0
  140. package/dist/query/conditions/ColumnCondition.d.ts +6 -0
  141. package/dist/query/conditions/ColumnCondition.js +3 -0
  142. package/dist/query/conditions/ColumnCondition.js.map +1 -0
  143. package/dist/query/conditions/Condition.d.ts +5 -0
  144. package/dist/query/conditions/Condition.js +3 -0
  145. package/dist/query/conditions/Condition.js.map +1 -0
  146. package/dist/query/conditions/ConditionConnector.d.ts +4 -0
  147. package/dist/query/conditions/ConditionConnector.js +9 -0
  148. package/dist/query/conditions/ConditionConnector.js.map +1 -0
  149. package/dist/query/conditions/ConditionGroup.d.ts +40 -0
  150. package/dist/query/conditions/ConditionGroup.js +138 -0
  151. package/dist/query/conditions/ConditionGroup.js.map +1 -0
  152. package/dist/query/conditions/ConnectedCondition.d.ts +6 -0
  153. package/dist/query/conditions/ConnectedCondition.js +3 -0
  154. package/dist/query/conditions/ConnectedCondition.js.map +1 -0
  155. package/dist/query/conditions/RawCondition.d.ts +4 -0
  156. package/dist/query/conditions/RawCondition.js +3 -0
  157. package/dist/query/conditions/RawCondition.js.map +1 -0
  158. package/dist/query/conditions/index.d.ts +7 -0
  159. package/dist/query/conditions/index.js +24 -0
  160. package/dist/query/conditions/index.js.map +1 -0
  161. package/dist/query/features/HasAlias.d.ts +6 -0
  162. package/dist/query/features/HasAlias.js +17 -0
  163. package/dist/query/features/HasAlias.js.map +1 -0
  164. package/dist/query/features/HasDistinct.d.ts +6 -0
  165. package/dist/query/features/HasDistinct.js +20 -0
  166. package/dist/query/features/HasDistinct.js.map +1 -0
  167. package/dist/query/features/HasFieldValues.d.ts +9 -0
  168. package/dist/query/features/HasFieldValues.js +27 -0
  169. package/dist/query/features/HasFieldValues.js.map +1 -0
  170. package/dist/query/features/HasGroupByFields.d.ts +7 -0
  171. package/dist/query/features/HasGroupByFields.js +21 -0
  172. package/dist/query/features/HasGroupByFields.js.map +1 -0
  173. package/dist/query/features/HasHavingConditions.d.ts +13 -0
  174. package/dist/query/features/HasHavingConditions.js +28 -0
  175. package/dist/query/features/HasHavingConditions.js.map +1 -0
  176. package/dist/query/features/HasJoins.d.ts +41 -0
  177. package/dist/query/features/HasJoins.js +66 -0
  178. package/dist/query/features/HasJoins.js.map +1 -0
  179. package/dist/query/features/HasLimit.d.ts +6 -0
  180. package/dist/query/features/HasLimit.js +20 -0
  181. package/dist/query/features/HasLimit.js.map +1 -0
  182. package/dist/query/features/HasOffset.d.ts +6 -0
  183. package/dist/query/features/HasOffset.js +20 -0
  184. package/dist/query/features/HasOffset.js.map +1 -0
  185. package/dist/query/features/HasOrderByFields.d.ts +15 -0
  186. package/dist/query/features/HasOrderByFields.js +38 -0
  187. package/dist/query/features/HasOrderByFields.js.map +1 -0
  188. package/dist/query/features/HasSelectFields.d.ts +11 -0
  189. package/dist/query/features/HasSelectFields.js +21 -0
  190. package/dist/query/features/HasSelectFields.js.map +1 -0
  191. package/dist/query/features/HasTable.d.ts +7 -0
  192. package/dist/query/features/HasTable.js +20 -0
  193. package/dist/query/features/HasTable.js.map +1 -0
  194. package/dist/query/features/HasUnions.d.ts +13 -0
  195. package/dist/query/features/HasUnions.js +21 -0
  196. package/dist/query/features/HasUnions.js.map +1 -0
  197. package/dist/query/features/HasWhen.d.ts +3 -0
  198. package/dist/query/features/HasWhen.js +13 -0
  199. package/dist/query/features/HasWhen.js.map +1 -0
  200. package/dist/query/features/HasWhereConditions.d.ts +35 -0
  201. package/dist/query/features/HasWhereConditions.js +92 -0
  202. package/dist/query/features/HasWhereConditions.js.map +1 -0
  203. package/dist/query/features/index.d.ts +14 -14
  204. package/dist/query/features/index.js +14 -14
  205. package/dist/query/features/index.js.map +1 -1
  206. package/dist/query/fields/BasicField.d.ts +5 -0
  207. package/dist/query/fields/BasicField.js +3 -0
  208. package/dist/query/fields/BasicField.js.map +1 -0
  209. package/dist/query/fields/Field.d.ts +3 -0
  210. package/dist/query/fields/Field.js +3 -0
  211. package/dist/query/fields/Field.js.map +1 -0
  212. package/dist/query/fields/RawField.d.ts +1 -0
  213. package/dist/query/fields/RawField.js +3 -0
  214. package/dist/query/fields/RawField.js.map +1 -0
  215. package/dist/query/fields/index.d.ts +3 -0
  216. package/dist/query/fields/index.js +20 -0
  217. package/dist/query/fields/index.js.map +1 -0
  218. package/dist/query/index.d.ts +7 -7
  219. package/dist/query/index.js +7 -7
  220. package/dist/query/index.js.map +1 -1
  221. package/dist/query/query.js +1 -1
  222. package/dist/query/query.js.map +1 -1
  223. package/dist/query/statement.js +1 -1
  224. package/dist/query/statement.js.map +1 -1
  225. package/package.json +14 -9
@@ -0,0 +1,6 @@
1
+ import { DefaultQueryBuilder } from '../../../query/builders/DefaultQueryBuilder';
2
+ import { SelectQuery } from '../../../query/SelectQuery';
3
+ import { Statement } from '../../../query/Statement';
4
+ export declare class SqliteQueryBuilder extends DefaultQueryBuilder {
5
+ protected buildLimitOffset(query: SelectQuery, statement: Statement): void;
6
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SqliteQueryBuilder = void 0;
4
+ const DefaultQueryBuilder_1 = require("../../../query/builders/DefaultQueryBuilder");
5
+ class SqliteQueryBuilder extends DefaultQueryBuilder_1.DefaultQueryBuilder {
6
+ buildLimitOffset(query, statement) {
7
+ // SQLite requiere LIMIT cuando se usa OFFSET; LIMIT -1 significa sin límite
8
+ if (query.getLimit() >= 0 || query.getOffset() >= 0) {
9
+ statement.sql += DefaultQueryBuilder_1.DefaultQueryBuilder.SPACE;
10
+ statement.sql += DefaultQueryBuilder_1.DefaultQueryBuilder.LIMIT;
11
+ statement.sql += DefaultQueryBuilder_1.DefaultQueryBuilder.SPACE;
12
+ statement.sql += query.getLimit() >= 0 ? query.getLimit() : -1;
13
+ }
14
+ if (query.getOffset() >= 0) {
15
+ statement.sql += DefaultQueryBuilder_1.DefaultQueryBuilder.SPACE;
16
+ statement.sql += DefaultQueryBuilder_1.DefaultQueryBuilder.OFFSET;
17
+ statement.sql += DefaultQueryBuilder_1.DefaultQueryBuilder.SPACE;
18
+ statement.sql += query.getOffset();
19
+ }
20
+ }
21
+ }
22
+ exports.SqliteQueryBuilder = SqliteQueryBuilder;
23
+ //# sourceMappingURL=SqliteQueryBuilder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SqliteQueryBuilder.js","sourceRoot":"","sources":["../../../../src/database/sources/sqlite/SqliteQueryBuilder.ts"],"names":[],"mappings":";;;AAAA,qFAAiF;AAIjF,MAAa,kBAAmB,SAAQ,yCAAmB;IAC/C,gBAAgB,CAAC,KAAkB,EAAE,SAAoB;QACjE,4EAA4E;QAC5E,IAAI,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,EAAE;YACnD,SAAS,CAAC,GAAG,IAAI,yCAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,yCAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,yCAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;SAC/D;QAED,IAAI,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,EAAE;YAC1B,SAAS,CAAC,GAAG,IAAI,yCAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,yCAAmB,CAAC,MAAM,CAAA;YAC3C,SAAS,CAAC,GAAG,IAAI,yCAAmB,CAAC,KAAK,CAAA;YAC1C,SAAS,CAAC,GAAG,IAAI,KAAK,CAAC,SAAS,EAAE,CAAA;SACnC;IACH,CAAC;CACF;AAjBD,gDAiBC"}
@@ -0,0 +1,3 @@
1
+ export * from './SqliteConnection';
2
+ export * from './SqliteDataSource';
3
+ export * from './SqliteQueryBuilder';
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./SqliteConnection"), exports);
18
+ __exportStar(require("./SqliteDataSource"), exports);
19
+ __exportStar(require("./SqliteQueryBuilder"), exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/sources/sqlite/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAkC;AAClC,qDAAkC;AAClC,uDAAoC"}
@@ -0,0 +1 @@
1
+ export type CastType = 'number' | 'boolean' | 'string' | 'json' | 'date';
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=CastType.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CastType.js","sourceRoot":"","sources":["../../src/entities/CastType.ts"],"names":[],"mappings":""}
@@ -0,0 +1,14 @@
1
+ export declare class Entities {
2
+ /**
3
+ * Persists an entity instance to the database.
4
+ * - If the primary key is set → UPDATE (auto-generated columns are excluded from SET).
5
+ * - If the primary key is null/undefined → INSERT (auto-generated columns are excluded;
6
+ * the generated PK is written back to the instance).
7
+ */
8
+ static save(entity: object): Promise<void>;
9
+ /**
10
+ * Deletes an entity instance from the database by its primary key.
11
+ * Throws if the primary key is not set.
12
+ */
13
+ static delete(entity: object): Promise<void>;
14
+ }
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Entities = void 0;
4
+ const DB_1 = require("../database/DB");
5
+ const query_1 = require("../query");
6
+ const casts_1 = require("./decorators/casts");
7
+ // ── Entities namespace ────────────────────────────────────────────────────────
8
+ class Entities {
9
+ /**
10
+ * Persists an entity instance to the database.
11
+ * - If the primary key is set → UPDATE (auto-generated columns are excluded from SET).
12
+ * - If the primary key is null/undefined → INSERT (auto-generated columns are excluded;
13
+ * the generated PK is written back to the instance).
14
+ */
15
+ static async save(entity) {
16
+ var _a, _b, _c, _d, _e, _f, _g;
17
+ const cls = entity.constructor;
18
+ const pk = cls.primaryKey;
19
+ const tableName = cls.table;
20
+ const fieldNames = (_a = cls.fields) !== null && _a !== void 0 ? _a : [];
21
+ const autoGeneratedFields = (_b = cls.autoGeneratedFields) !== null && _b !== void 0 ? _b : [];
22
+ const castsMap = (_c = cls.casts) !== null && _c !== void 0 ? _c : {};
23
+ const columnsMap = (_d = cls.columnsMap) !== null && _d !== void 0 ? _d : {};
24
+ const pkProp = (_e = Object.keys(columnsMap).find((p) => columnsMap[p] === pk)) !== null && _e !== void 0 ? _e : pk;
25
+ const source = (_f = cls.source) !== null && _f !== void 0 ? _f : DB_1.DB.getActiveSource();
26
+ // Build the row, skipping auto-generated columns (DB manages their values)
27
+ const row = {};
28
+ const cols = fieldNames.length > 0
29
+ ? fieldNames
30
+ : Object.keys(entity).filter((k) => typeof entity[k] !== 'function');
31
+ for (const col of cols) {
32
+ if (autoGeneratedFields.includes(col)) {
33
+ continue;
34
+ }
35
+ const value = entity[col];
36
+ if (value === undefined) {
37
+ continue;
38
+ }
39
+ const cast = castsMap[col];
40
+ row[(_g = columnsMap[col]) !== null && _g !== void 0 ? _g : col] = cast ? (0, casts_1.applyCastForStorage)(value, cast) : value;
41
+ }
42
+ if (entity[pkProp] != null) {
43
+ // UPDATE — also exclude PK from SET clause
44
+ const updateRow = Object.assign({}, row);
45
+ delete updateRow[pk];
46
+ await source
47
+ .table(tableName)
48
+ .where(pk, entity[pkProp])
49
+ .update(updateRow);
50
+ }
51
+ else {
52
+ // INSERT — get connection to read back the generated ID
53
+ const conn = await source.getConnection();
54
+ try {
55
+ await conn.execute(new query_1.InsertQuery().setTable(tableName).setFields(row));
56
+ if (autoGeneratedFields.includes(pkProp)) {
57
+ ;
58
+ entity[pkProp] = await conn.lastInsertId();
59
+ }
60
+ }
61
+ finally {
62
+ await conn.close();
63
+ }
64
+ }
65
+ }
66
+ /**
67
+ * Deletes an entity instance from the database by its primary key.
68
+ * Throws if the primary key is not set.
69
+ */
70
+ static async delete(entity) {
71
+ var _a, _b, _c;
72
+ const cls = entity.constructor;
73
+ const pk = cls.primaryKey;
74
+ const columnsMap = (_a = cls.columnsMap) !== null && _a !== void 0 ? _a : {};
75
+ const pkProp = (_b = Object.keys(columnsMap).find((p) => columnsMap[p] === pk)) !== null && _b !== void 0 ? _b : pk;
76
+ const pkValue = entity[pkProp];
77
+ if (pkValue == null) {
78
+ throw new Error('Cannot delete an entity without a primary key value.');
79
+ }
80
+ const source = (_c = cls.source) !== null && _c !== void 0 ? _c : DB_1.DB.getActiveSource();
81
+ await source.table(cls.table).where(pk, pkValue).delete();
82
+ }
83
+ }
84
+ exports.Entities = Entities;
85
+ //# sourceMappingURL=Entities.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Entities.js","sourceRoot":"","sources":["../../src/entities/Entities.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,60 @@
1
+ import { DataTable } from '../database/DataTable';
2
+ import { Field } from '../query';
3
+ import { Condition, ConditionGroup } from '../query/conditions';
4
+ import { OrderByDirection } from '../query/features/HasOrderByFields';
5
+ import { Relationship } from './Relationship';
6
+ type EntityClass<T> = (new () => T) & {
7
+ table: string;
8
+ primaryKey: string;
9
+ relationships: Record<string, Relationship>;
10
+ fromRow(row: Record<string, any>): T;
11
+ };
12
+ /**
13
+ * Chainable query builder for Entities. Wraps DataTable and hydrates rows
14
+ * into typed Entity instances when a terminal method is called.
15
+ */
16
+ export declare class EntityQuery<T> {
17
+ private _entityClass;
18
+ private _table;
19
+ private _withs;
20
+ constructor(entityClass: EntityClass<T>, table: DataTable);
21
+ with(relations: string | string[], ...rest: string[]): this;
22
+ joinRelationship(relationName: string): this;
23
+ innerJoinRelationship(relationName: string): this;
24
+ leftJoinRelationship(relationName: string): this;
25
+ private _applyJoin;
26
+ get(): Promise<T[]>;
27
+ first(): Promise<T | null>;
28
+ find(id: any): Promise<T | null>;
29
+ private _loadRelations;
30
+ where(callback: (group: ConditionGroup) => void): this;
31
+ where(condition: Condition): this;
32
+ where(field: Field, value: any): this;
33
+ where(field: Field, operator: string, value: any): this;
34
+ whereIn(field: Field, values: any[]): this;
35
+ whereNotIn(field: Field, values: any[]): this;
36
+ whereBetween(field: Field, range: [any, any]): this;
37
+ whereNotBetween(field: Field, range: [any, any]): this;
38
+ whereNull(field: Field): this;
39
+ whereNotNull(field: Field): this;
40
+ whereLike(field: Field, pattern: string): this;
41
+ whereNotLike(field: Field, pattern: string): this;
42
+ whereColumn(field: Field, column: Field): this;
43
+ whereColumn(field: Field, operator: string, column: Field): this;
44
+ orWhere(...args: any[]): this;
45
+ orWhereIn(field: Field, values: any[]): this;
46
+ orWhereNotIn(field: Field, values: any[]): this;
47
+ orWhereBetween(field: Field, range: [any, any]): this;
48
+ orWhereNotBetween(field: Field, range: [any, any]): this;
49
+ orWhereNull(field: Field): this;
50
+ orWhereNotNull(field: Field): this;
51
+ orWhereLike(field: Field, pattern: string): this;
52
+ orWhereNotLike(field: Field, pattern: string): this;
53
+ select(...fields: (Field | Field[])[]): this;
54
+ orderBy(field: Field, direction?: OrderByDirection): this;
55
+ groupBy(...fields: Field[]): this;
56
+ limit(value: number): this;
57
+ offset(value: number): this;
58
+ distinct(): this;
59
+ }
60
+ export {};
@@ -0,0 +1,305 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EntityQuery = void 0;
4
+ const HasJoins_1 = require("../query/features/HasJoins");
5
+ /**
6
+ * Chainable query builder for Entities. Wraps DataTable and hydrates rows
7
+ * into typed Entity instances when a terminal method is called.
8
+ */
9
+ class EntityQuery {
10
+ constructor(entityClass, table) {
11
+ this._withs = [];
12
+ this._entityClass = entityClass;
13
+ this._table = table;
14
+ }
15
+ // ── Eager loading ────────────────────────────────────────────────────────────
16
+ with(relations, ...rest) {
17
+ const toAdd = Array.isArray(relations) ? relations : [relations, ...rest];
18
+ this._withs.push(...toAdd);
19
+ return this;
20
+ }
21
+ // ── Join relationships ───────────────────────────────────────────────────────
22
+ joinRelationship(relationName) {
23
+ return this._applyJoin(HasJoins_1.JoinType.INNER_JOIN, relationName);
24
+ }
25
+ innerJoinRelationship(relationName) {
26
+ return this._applyJoin(HasJoins_1.JoinType.INNER_JOIN, relationName);
27
+ }
28
+ leftJoinRelationship(relationName) {
29
+ return this._applyJoin(HasJoins_1.JoinType.LEFT_JOIN, relationName);
30
+ }
31
+ _applyJoin(joinType, relationName) {
32
+ const rel = this._entityClass.relationships[relationName];
33
+ if (!rel) {
34
+ throw new Error(`Relationship "${relationName}" is not defined on ${this._entityClass.name}`);
35
+ }
36
+ const RelatedClass = rel.related();
37
+ const relatedTable = RelatedClass.table;
38
+ if (rel.type === 'hasOne' || rel.type === 'hasMany') {
39
+ // local table.localKey = related table.foreignKey
40
+ const sourceField = `${this._entityClass.table}.${rel.localKey}`;
41
+ const remoteField = `${relatedTable}.${rel.foreignKey}`;
42
+ this._table.join(joinType, relatedTable, sourceField, remoteField);
43
+ }
44
+ else if (rel.type === 'belongsTo') {
45
+ // local table.foreignKey = related table.localKey
46
+ const sourceField = `${this._entityClass.table}.${rel.foreignKey}`;
47
+ const remoteField = `${relatedTable}.${rel.localKey}`;
48
+ this._table.join(joinType, relatedTable, sourceField, remoteField);
49
+ }
50
+ else if (rel.type === 'hasOneThrough' || rel.type === 'hasManyThrough') {
51
+ // local → through → related
52
+ const ThroughClass = rel.through();
53
+ const throughTable = ThroughClass.table;
54
+ this._table.join(joinType, throughTable, `${this._entityClass.table}.${rel.localKey}`, `${throughTable}.${rel.throughForeignKey}`);
55
+ this._table.join(joinType, relatedTable, `${throughTable}.${rel.throughLocalKey}`, `${relatedTable}.${rel.foreignKey}`);
56
+ }
57
+ return this;
58
+ }
59
+ // ── Terminal methods ─────────────────────────────────────────────────────────
60
+ async get() {
61
+ const rows = await this._table.get();
62
+ const entities = rows.map((row) => this._entityClass.fromRow(row));
63
+ if (this._withs.length > 0) {
64
+ await this._loadRelations(entities, this._withs, this._entityClass);
65
+ }
66
+ return entities;
67
+ }
68
+ async first() {
69
+ const row = await this._table.first();
70
+ if (!row) {
71
+ return null;
72
+ }
73
+ const entity = this._entityClass.fromRow(row);
74
+ if (this._withs.length > 0) {
75
+ await this._loadRelations([entity], this._withs, this._entityClass);
76
+ }
77
+ return entity;
78
+ }
79
+ async find(id) {
80
+ const row = await this._table.where(this._entityClass.primaryKey, id).first();
81
+ if (!row) {
82
+ return null;
83
+ }
84
+ const entity = this._entityClass.fromRow(row);
85
+ if (this._withs.length > 0) {
86
+ await this._loadRelations([entity], this._withs, this._entityClass);
87
+ }
88
+ return entity;
89
+ }
90
+ // ── Eager-load implementation ────────────────────────────────────────────────
91
+ async _loadRelations(entities, relations, ParentClass) {
92
+ // Group by top-level relation name; accumulate nested paths
93
+ const groups = new Map();
94
+ for (const path of relations) {
95
+ const dot = path.indexOf('.');
96
+ const head = dot === -1 ? path : path.substring(0, dot);
97
+ const tail = dot === -1 ? null : path.substring(dot + 1);
98
+ if (!groups.has(head)) {
99
+ groups.set(head, []);
100
+ }
101
+ if (tail) {
102
+ groups.get(head).push(tail);
103
+ }
104
+ }
105
+ for (const [head, nested] of groups) {
106
+ const rel = ParentClass.relationships[head];
107
+ if (!rel) {
108
+ continue;
109
+ }
110
+ const RelatedClass = rel.related();
111
+ let relatedItems = [];
112
+ if (rel.type === 'hasOne' || rel.type === 'hasMany') {
113
+ const keys = [...new Set(entities.map((r) => r[rel.localKey]).filter((v) => v != null))];
114
+ if (keys.length === 0) {
115
+ continue;
116
+ }
117
+ relatedItems = await RelatedClass.whereIn(rel.foreignKey, keys).get();
118
+ // Build lookup: foreignKeyValue → items[]
119
+ const lookup = new Map();
120
+ relatedItems.forEach((item) => {
121
+ const k = item[rel.foreignKey];
122
+ if (!lookup.has(k)) {
123
+ lookup.set(k, []);
124
+ }
125
+ lookup.get(k).push(item);
126
+ });
127
+ entities.forEach((r) => {
128
+ var _a, _b;
129
+ const matched = (_a = lookup.get(r[rel.localKey])) !== null && _a !== void 0 ? _a : [];
130
+ r[head] = rel.type === 'hasOne' ? (_b = matched[0]) !== null && _b !== void 0 ? _b : null : matched;
131
+ });
132
+ }
133
+ else if (rel.type === 'belongsTo') {
134
+ const keys = [...new Set(entities.map((r) => r[rel.foreignKey]).filter((v) => v != null))];
135
+ if (keys.length === 0) {
136
+ continue;
137
+ }
138
+ relatedItems = await RelatedClass.whereIn(rel.localKey, keys).get();
139
+ // Build lookup: localKeyValue → item
140
+ const lookup = new Map();
141
+ relatedItems.forEach((item) => lookup.set(item[rel.localKey], item));
142
+ entities.forEach((r) => {
143
+ var _a;
144
+ r[head] = (_a = lookup.get(r[rel.foreignKey])) !== null && _a !== void 0 ? _a : null;
145
+ });
146
+ }
147
+ else if (rel.type === 'hasOneThrough' || rel.type === 'hasManyThrough') {
148
+ const ThroughClass = rel.through();
149
+ const localKeys = [...new Set(entities.map((r) => r[rel.localKey]).filter((v) => v != null))];
150
+ if (localKeys.length === 0) {
151
+ continue;
152
+ }
153
+ // Load through intermediates
154
+ const throughItems = await ThroughClass.whereIn(rel.throughForeignKey, localKeys).get();
155
+ const throughKeys = [
156
+ ...new Set(throughItems.map((t) => t[rel.throughLocalKey]).filter((v) => v != null))
157
+ ];
158
+ if (throughKeys.length === 0) {
159
+ continue;
160
+ }
161
+ // Map parent localKey → through items
162
+ const throughByParent = new Map();
163
+ throughItems.forEach((t) => {
164
+ const k = t[rel.throughForeignKey];
165
+ if (!throughByParent.has(k)) {
166
+ throughByParent.set(k, []);
167
+ }
168
+ throughByParent.get(k).push(t);
169
+ });
170
+ relatedItems = await RelatedClass.whereIn(rel.foreignKey, throughKeys).get();
171
+ // Map through localKey → related items
172
+ const relatedByThrough = new Map();
173
+ relatedItems.forEach((item) => {
174
+ const k = item[rel.foreignKey];
175
+ if (!relatedByThrough.has(k)) {
176
+ relatedByThrough.set(k, []);
177
+ }
178
+ relatedByThrough.get(k).push(item);
179
+ });
180
+ entities.forEach((r) => {
181
+ var _a, _b;
182
+ const throughs = (_a = throughByParent.get(r[rel.localKey])) !== null && _a !== void 0 ? _a : [];
183
+ const matched = [];
184
+ throughs.forEach((t) => {
185
+ var _a;
186
+ const items = (_a = relatedByThrough.get(t[rel.throughLocalKey])) !== null && _a !== void 0 ? _a : [];
187
+ matched.push(...items);
188
+ });
189
+ r[head] = rel.type === 'hasOneThrough' ? (_b = matched[0]) !== null && _b !== void 0 ? _b : null : matched;
190
+ });
191
+ }
192
+ // Recurse for nested dot-notation paths
193
+ if (nested.length > 0 && relatedItems.length > 0) {
194
+ await this._loadRelations(relatedItems, nested, RelatedClass);
195
+ }
196
+ }
197
+ }
198
+ where(...args) {
199
+ ;
200
+ this._table.where(...args);
201
+ return this;
202
+ }
203
+ whereIn(field, values) {
204
+ this._table.whereIn(field, values);
205
+ return this;
206
+ }
207
+ whereNotIn(field, values) {
208
+ this._table.whereNotIn(field, values);
209
+ return this;
210
+ }
211
+ whereBetween(field, range) {
212
+ this._table.whereBetween(field, range);
213
+ return this;
214
+ }
215
+ whereNotBetween(field, range) {
216
+ this._table.whereNotBetween(field, range);
217
+ return this;
218
+ }
219
+ whereNull(field) {
220
+ this._table.whereNull(field);
221
+ return this;
222
+ }
223
+ whereNotNull(field) {
224
+ this._table.whereNotNull(field);
225
+ return this;
226
+ }
227
+ whereLike(field, pattern) {
228
+ this._table.whereLike(field, pattern);
229
+ return this;
230
+ }
231
+ whereNotLike(field, pattern) {
232
+ this._table.whereNotLike(field, pattern);
233
+ return this;
234
+ }
235
+ whereColumn(...args) {
236
+ ;
237
+ this._table.whereColumn(...args);
238
+ return this;
239
+ }
240
+ orWhere(...args) {
241
+ ;
242
+ this._table.orWhere(...args);
243
+ return this;
244
+ }
245
+ orWhereIn(field, values) {
246
+ this._table.orWhereIn(field, values);
247
+ return this;
248
+ }
249
+ orWhereNotIn(field, values) {
250
+ this._table.orWhereNotIn(field, values);
251
+ return this;
252
+ }
253
+ orWhereBetween(field, range) {
254
+ this._table.orWhereBetween(field, range);
255
+ return this;
256
+ }
257
+ orWhereNotBetween(field, range) {
258
+ this._table.orWhereNotBetween(field, range);
259
+ return this;
260
+ }
261
+ orWhereNull(field) {
262
+ this._table.orWhereNull(field);
263
+ return this;
264
+ }
265
+ orWhereNotNull(field) {
266
+ this._table.orWhereNotNull(field);
267
+ return this;
268
+ }
269
+ orWhereLike(field, pattern) {
270
+ this._table.orWhereLike(field, pattern);
271
+ return this;
272
+ }
273
+ orWhereNotLike(field, pattern) {
274
+ this._table.orWhereNotLike(field, pattern);
275
+ return this;
276
+ }
277
+ select(...fields) {
278
+ ;
279
+ this._table.select(...fields);
280
+ return this;
281
+ }
282
+ orderBy(field, direction) {
283
+ this._table.orderBy(field, direction);
284
+ return this;
285
+ }
286
+ groupBy(...fields) {
287
+ ;
288
+ this._table.groupBy(...fields);
289
+ return this;
290
+ }
291
+ limit(value) {
292
+ this._table.setLimit(value);
293
+ return this;
294
+ }
295
+ offset(value) {
296
+ this._table.setOffset(value);
297
+ return this;
298
+ }
299
+ distinct() {
300
+ this._table.setDistinct(true);
301
+ return this;
302
+ }
303
+ }
304
+ exports.EntityQuery = EntityQuery;
305
+ //# sourceMappingURL=EntityQuery.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EntityQuery.js","sourceRoot":"","sources":["../../src/entities/EntityQuery.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export type RelationshipType = 'hasOne' | 'hasMany' | 'belongsTo' | 'hasOneThrough' | 'hasManyThrough';
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=RelationshipType.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RelationshipType.js","sourceRoot":"","sources":["../../src/entities/RelationshipType.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ /** Inverse of HasOne/HasMany: this model holds foreignKey that points to the related model. */
2
+ export declare function BelongsTo(related: () => any, foreignKey: string, localKey?: string): PropertyDecorator;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BelongsTo = void 0;
4
+ const metadata_1 = require("./metadata");
5
+ /** Inverse of HasOne/HasMany: this model holds foreignKey that points to the related model. */
6
+ function BelongsTo(related, foreignKey, localKey = 'id') {
7
+ return (target, propertyKey) => {
8
+ const m = (0, metadata_1.getOrCreate)(target);
9
+ m.relationships.push({
10
+ name: String(propertyKey),
11
+ relationship: { type: 'belongsTo', related, foreignKey, localKey }
12
+ });
13
+ };
14
+ }
15
+ exports.BelongsTo = BelongsTo;
16
+ //# sourceMappingURL=BelongsTo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BelongsTo.js","sourceRoot":"","sources":["../../../src/entities/decorators/BelongsTo.ts"],"names":[],"mappings":";;;AAAA,yCAAwC;AAExC,+FAA+F;AAC/F,SAAgB,SAAS,CAAC,OAAkB,EAAE,UAAkB,EAAE,QAAQ,GAAG,IAAI;IAC/E,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE;QAC7B,MAAM,CAAC,GAAG,IAAA,sBAAW,EAAC,MAAgB,CAAC,CAAA;QAEvC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC;YACnB,IAAI,EAAE,MAAM,CAAC,WAAW,CAAC;YACzB,YAAY,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE;SACnE,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC;AATD,8BASC"}
@@ -0,0 +1,13 @@
1
+ import { CastType } from '../CastType';
2
+ export interface ColumnOptions {
3
+ /** Database column name. Defaults to the property name. */
4
+ columnName?: string;
5
+ /** Automatic type coercion when reading from the database. */
6
+ cast?: CastType;
7
+ /** Mark this column as the primary key. */
8
+ primaryKey?: boolean;
9
+ /** Column value is generated by the database (e.g. AUTOINCREMENT). Excluded from INSERT/UPDATE. */
10
+ autoGenerated?: boolean;
11
+ }
12
+ /** Map a class property to a database column. */
13
+ export declare function Column(options?: ColumnOptions): PropertyDecorator;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Column = void 0;
4
+ const metadata_1 = require("./metadata");
5
+ /** Map a class property to a database column. */
6
+ function Column(options) {
7
+ return (target, propertyKey) => {
8
+ const m = (0, metadata_1.getOrCreate)(target);
9
+ m.columns.push(Object.assign({ name: String(propertyKey) }, options));
10
+ };
11
+ }
12
+ exports.Column = Column;
13
+ //# sourceMappingURL=Column.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Column.js","sourceRoot":"","sources":["../../../src/entities/decorators/Column.ts"],"names":[],"mappings":";;;AACA,yCAAwC;AAaxC,iDAAiD;AACjD,SAAgB,MAAM,CAAC,OAAuB;IAC5C,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE;QAC7B,MAAM,CAAC,GAAG,IAAA,sBAAW,EAAC,MAAgB,CAAC,CAAA;QAEvC,CAAC,CAAC,OAAO,CAAC,IAAI,iBAAG,IAAI,EAAE,MAAM,CAAC,WAAW,CAAC,IAAK,OAAO,EAAG,CAAA;IAC3D,CAAC,CAAA;AACH,CAAC;AAND,wBAMC"}