@neogroup/neorm 0.0.1 → 0.0.3
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/README.md +36 -35
- package/dist/database/Connection.d.ts +10 -0
- package/dist/database/Connection.js +3 -0
- package/dist/database/Connection.js.map +1 -0
- package/dist/database/DB.d.ts +63 -0
- package/dist/database/DB.js +247 -0
- package/dist/database/DB.js.map +1 -0
- package/dist/database/DataConnection.d.ts +24 -0
- package/dist/database/DataConnection.js +99 -0
- package/dist/database/DataConnection.js.map +1 -0
- package/dist/database/DataSet.d.ts +3 -0
- package/dist/database/DataSet.js +3 -0
- package/dist/database/DataSet.js.map +1 -0
- package/dist/database/DataSource.d.ts +23 -0
- package/dist/database/DataSource.js +56 -0
- package/dist/database/DataSource.js.map +1 -0
- package/dist/database/DataTable.d.ts +19 -0
- package/dist/database/DataTable.js +75 -0
- package/dist/database/DataTable.js.map +1 -0
- package/dist/database/index.d.ts +8 -0
- package/dist/database/index.js +25 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/query/DeleteQuery.d.ts +8 -0
- package/dist/database/query/DeleteQuery.js +17 -0
- package/dist/database/query/DeleteQuery.js.map +1 -0
- package/dist/database/query/InsertQuery.d.ts +8 -0
- package/dist/database/query/InsertQuery.js +17 -0
- package/dist/database/query/InsertQuery.js.map +1 -0
- package/dist/database/query/Query.d.ts +2 -0
- package/dist/database/query/Query.js +7 -0
- package/dist/database/query/Query.js.map +1 -0
- package/dist/database/query/QueryTable.d.ts +7 -0
- package/dist/database/query/QueryTable.js +3 -0
- package/dist/database/query/QueryTable.js.map +1 -0
- package/dist/database/query/SelectQuery.d.ts +9 -0
- package/dist/database/query/SelectQuery.js +33 -0
- package/dist/database/query/SelectQuery.js.map +1 -0
- package/dist/database/query/Statement.d.ts +4 -0
- package/dist/database/query/Statement.js +3 -0
- package/dist/database/query/Statement.js.map +1 -0
- package/dist/database/query/UpdateQuery.d.ts +8 -0
- package/dist/database/query/UpdateQuery.js +17 -0
- package/dist/database/query/UpdateQuery.js.map +1 -0
- package/dist/database/query/builders/DefaultQueryBuilder.d.ts +87 -0
- package/dist/database/query/builders/DefaultQueryBuilder.js +524 -0
- package/dist/database/query/builders/DefaultQueryBuilder.js.map +1 -0
- package/dist/database/query/builders/QueryBuilder.d.ts +5 -0
- package/dist/database/query/builders/QueryBuilder.js +7 -0
- package/dist/database/query/builders/QueryBuilder.js.map +1 -0
- package/dist/database/query/builders/index.d.ts +2 -0
- package/dist/database/query/builders/index.js +19 -0
- package/dist/database/query/builders/index.js.map +1 -0
- package/dist/database/query/conditions/BasicCondition.d.ts +6 -0
- package/dist/database/query/conditions/BasicCondition.js +3 -0
- package/dist/database/query/conditions/BasicCondition.js.map +1 -0
- package/dist/database/query/conditions/ColumnCondition.d.ts +6 -0
- package/dist/database/query/conditions/ColumnCondition.js +3 -0
- package/dist/database/query/conditions/ColumnCondition.js.map +1 -0
- package/dist/database/query/conditions/Condition.d.ts +5 -0
- package/dist/database/query/conditions/Condition.js +3 -0
- package/dist/database/query/conditions/Condition.js.map +1 -0
- package/dist/database/query/conditions/ConditionConnector.d.ts +4 -0
- package/dist/database/query/conditions/ConditionConnector.js +9 -0
- package/dist/database/query/conditions/ConditionConnector.js.map +1 -0
- package/dist/database/query/conditions/ConditionGroup.d.ts +40 -0
- package/dist/database/query/conditions/ConditionGroup.js +138 -0
- package/dist/database/query/conditions/ConditionGroup.js.map +1 -0
- package/dist/database/query/conditions/ConnectedCondition.d.ts +6 -0
- package/dist/database/query/conditions/ConnectedCondition.js +3 -0
- package/dist/database/query/conditions/ConnectedCondition.js.map +1 -0
- package/dist/database/query/conditions/RawCondition.d.ts +4 -0
- package/dist/database/query/conditions/RawCondition.js +3 -0
- package/dist/database/query/conditions/RawCondition.js.map +1 -0
- package/dist/database/query/conditions/index.d.ts +7 -0
- package/dist/database/query/conditions/index.js +24 -0
- package/dist/database/query/conditions/index.js.map +1 -0
- package/dist/database/query/features/HasAlias.d.ts +6 -0
- package/dist/database/query/features/HasAlias.js +17 -0
- package/dist/database/query/features/HasAlias.js.map +1 -0
- package/dist/database/query/features/HasDistinct.d.ts +6 -0
- package/dist/database/query/features/HasDistinct.js +20 -0
- package/dist/database/query/features/HasDistinct.js.map +1 -0
- package/dist/database/query/features/HasFieldValues.d.ts +9 -0
- package/dist/database/query/features/HasFieldValues.js +27 -0
- package/dist/database/query/features/HasFieldValues.js.map +1 -0
- package/dist/database/query/features/HasGroupByFields.d.ts +7 -0
- package/dist/database/query/features/HasGroupByFields.js +21 -0
- package/dist/database/query/features/HasGroupByFields.js.map +1 -0
- package/dist/database/query/features/HasHavingConditions.d.ts +13 -0
- package/dist/database/query/features/HasHavingConditions.js +28 -0
- package/dist/database/query/features/HasHavingConditions.js.map +1 -0
- package/dist/database/query/features/HasJoins.d.ts +41 -0
- package/dist/database/query/features/HasJoins.js +66 -0
- package/dist/database/query/features/HasJoins.js.map +1 -0
- package/dist/database/query/features/HasLimit.d.ts +6 -0
- package/dist/database/query/features/HasLimit.js +20 -0
- package/dist/database/query/features/HasLimit.js.map +1 -0
- package/dist/database/query/features/HasOffset.d.ts +6 -0
- package/dist/database/query/features/HasOffset.js +20 -0
- package/dist/database/query/features/HasOffset.js.map +1 -0
- package/dist/database/query/features/HasOrderByFields.d.ts +15 -0
- package/dist/database/query/features/HasOrderByFields.js +38 -0
- package/dist/database/query/features/HasOrderByFields.js.map +1 -0
- package/dist/database/query/features/HasSelectFields.d.ts +11 -0
- package/dist/database/query/features/HasSelectFields.js +21 -0
- package/dist/database/query/features/HasSelectFields.js.map +1 -0
- package/dist/database/query/features/HasTable.d.ts +7 -0
- package/dist/database/query/features/HasTable.js +20 -0
- package/dist/database/query/features/HasTable.js.map +1 -0
- package/dist/database/query/features/HasUnions.d.ts +13 -0
- package/dist/database/query/features/HasUnions.js +21 -0
- package/dist/database/query/features/HasUnions.js.map +1 -0
- package/dist/database/query/features/HasWhen.d.ts +3 -0
- package/dist/database/query/features/HasWhen.js +13 -0
- package/dist/database/query/features/HasWhen.js.map +1 -0
- package/dist/database/query/features/HasWhereConditions.d.ts +35 -0
- package/dist/database/query/features/HasWhereConditions.js +92 -0
- package/dist/database/query/features/HasWhereConditions.js.map +1 -0
- package/dist/database/query/features/index.d.ts +14 -0
- package/dist/database/query/features/index.js +31 -0
- package/dist/database/query/features/index.js.map +1 -0
- package/dist/database/query/fields/BasicField.d.ts +5 -0
- package/dist/database/query/fields/BasicField.js +3 -0
- package/dist/database/query/fields/BasicField.js.map +1 -0
- package/dist/database/query/fields/Field.d.ts +3 -0
- package/dist/database/query/fields/Field.js +3 -0
- package/dist/database/query/fields/Field.js.map +1 -0
- package/dist/database/query/fields/RawField.d.ts +1 -0
- package/dist/database/query/fields/RawField.js +3 -0
- package/dist/database/query/fields/RawField.js.map +1 -0
- package/dist/database/query/fields/index.d.ts +3 -0
- package/dist/database/query/fields/index.js +20 -0
- package/dist/database/query/fields/index.js.map +1 -0
- package/dist/database/query/index.d.ts +11 -0
- package/dist/database/query/index.js +28 -0
- package/dist/database/query/index.js.map +1 -0
- package/dist/database/sources/index.d.ts +3 -0
- package/dist/database/sources/index.js +20 -0
- package/dist/database/sources/index.js.map +1 -0
- package/dist/database/sources/mysql/MysqlConnection.d.ts +14 -0
- package/dist/database/sources/mysql/MysqlConnection.js +36 -0
- package/dist/database/sources/mysql/MysqlConnection.js.map +1 -0
- package/dist/database/sources/mysql/MysqlDataSource.d.ts +24 -0
- package/dist/database/sources/mysql/MysqlDataSource.js +72 -0
- package/dist/database/sources/mysql/MysqlDataSource.js.map +1 -0
- package/dist/database/sources/mysql/MysqlQueryBuilder.d.ts +6 -0
- package/dist/database/sources/mysql/MysqlQueryBuilder.js +28 -0
- package/dist/database/sources/mysql/MysqlQueryBuilder.js.map +1 -0
- package/dist/database/sources/mysql/index.d.ts +3 -0
- package/dist/database/sources/mysql/index.js +20 -0
- package/dist/database/sources/mysql/index.js.map +1 -0
- package/dist/database/sources/postgres/PostgresConnection.d.ts +13 -0
- package/dist/database/sources/postgres/PostgresConnection.js +40 -0
- package/dist/database/sources/postgres/PostgresConnection.js.map +1 -0
- package/dist/database/sources/postgres/PostgresDataSource.d.ts +24 -0
- package/dist/database/sources/postgres/PostgresDataSource.js +73 -0
- package/dist/database/sources/postgres/PostgresDataSource.js.map +1 -0
- package/dist/database/sources/postgres/PostgresQueryBuilder.d.ts +5 -0
- package/dist/database/sources/postgres/PostgresQueryBuilder.js +13 -0
- package/dist/database/sources/postgres/PostgresQueryBuilder.js.map +1 -0
- package/dist/database/sources/postgres/index.d.ts +2 -0
- package/dist/database/sources/postgres/index.js +19 -0
- package/dist/database/sources/postgres/index.js.map +1 -0
- package/dist/database/sources/sqlite/SqliteConnection.d.ts +14 -0
- package/dist/database/sources/sqlite/SqliteConnection.js +37 -0
- package/dist/database/sources/sqlite/SqliteConnection.js.map +1 -0
- package/dist/database/sources/sqlite/SqliteDataSource.d.ts +11 -0
- package/dist/database/sources/sqlite/SqliteDataSource.js +34 -0
- package/dist/database/sources/sqlite/SqliteDataSource.js.map +1 -0
- package/dist/database/sources/sqlite/SqliteQueryBuilder.d.ts +6 -0
- package/dist/database/sources/sqlite/SqliteQueryBuilder.js +23 -0
- package/dist/database/sources/sqlite/SqliteQueryBuilder.js.map +1 -0
- package/dist/database/sources/sqlite/index.d.ts +3 -0
- package/dist/database/sources/sqlite/index.js +20 -0
- package/dist/database/sources/sqlite/index.js.map +1 -0
- package/dist/entities/BaseEntity.d.ts +76 -0
- package/dist/entities/BaseEntity.js +208 -0
- package/dist/entities/BaseEntity.js.map +1 -0
- package/dist/entities/CastType.d.ts +1 -0
- package/dist/entities/CastType.js +3 -0
- package/dist/entities/CastType.js.map +1 -0
- package/dist/entities/Entities.d.ts +14 -0
- package/dist/entities/Entities.js +85 -0
- package/dist/entities/Entities.js.map +1 -0
- package/dist/entities/EntityQuery.d.ts +60 -0
- package/dist/entities/EntityQuery.js +305 -0
- package/dist/entities/EntityQuery.js.map +1 -0
- package/dist/entities/RelationshipType.d.ts +1 -0
- package/dist/entities/RelationshipType.js +3 -0
- package/dist/entities/RelationshipType.js.map +1 -0
- package/dist/entities/decorators/BelongsTo.d.ts +2 -0
- package/dist/entities/decorators/BelongsTo.js +15 -0
- package/dist/entities/decorators/BelongsTo.js.map +1 -0
- package/dist/entities/decorators/Column.d.ts +13 -0
- package/dist/entities/decorators/Column.js +12 -0
- package/dist/entities/decorators/Column.js.map +1 -0
- package/dist/entities/decorators/Entity.d.ts +20 -0
- package/dist/entities/decorators/Entity.js +50 -0
- package/dist/entities/decorators/Entity.js.map +1 -0
- package/dist/entities/decorators/HasMany.d.ts +2 -0
- package/dist/entities/decorators/HasMany.js +15 -0
- package/dist/entities/decorators/HasMany.js.map +1 -0
- package/dist/entities/decorators/HasManyThrough.d.ts +2 -0
- package/dist/entities/decorators/HasManyThrough.js +23 -0
- package/dist/entities/decorators/HasManyThrough.js.map +1 -0
- package/dist/entities/decorators/HasOne.d.ts +2 -0
- package/dist/entities/decorators/HasOne.js +12 -0
- package/dist/entities/decorators/HasOne.js.map +1 -0
- package/dist/entities/decorators/HasOneThrough.d.ts +2 -0
- package/dist/entities/decorators/HasOneThrough.js +23 -0
- package/dist/entities/decorators/HasOneThrough.js.map +1 -0
- package/dist/entities/decorators/casts.d.ts +3 -0
- package/dist/entities/decorators/casts.js +38 -0
- package/dist/entities/decorators/casts.js.map +1 -0
- package/dist/entities/decorators/index.d.ts +7 -0
- package/dist/entities/decorators/index.js +24 -0
- package/dist/entities/decorators/index.js.map +1 -0
- package/dist/entities/decorators/metadata.d.ts +19 -0
- package/dist/entities/decorators/metadata.js +12 -0
- package/dist/entities/decorators/metadata.js.map +1 -0
- package/dist/entities/index.d.ts +5 -3
- package/dist/entities/index.js +5 -2
- package/dist/entities/index.js.map +1 -1
- package/dist/entities/relationship.d.ts +1 -6
- package/dist/entities/relationship.js +1 -22
- package/dist/entities/relationship.js.map +1 -1
- package/dist/index.d.ts +1 -9
- package/dist/index.js +1 -14
- package/dist/index.js.map +1 -1
- package/dist/query/DeleteQuery.d.ts +8 -0
- package/dist/query/DeleteQuery.js +17 -0
- package/dist/query/DeleteQuery.js.map +1 -0
- package/dist/query/InsertQuery.d.ts +8 -0
- package/dist/query/InsertQuery.js +17 -0
- package/dist/query/InsertQuery.js.map +1 -0
- package/dist/query/QueryTable.d.ts +7 -0
- package/dist/query/QueryTable.js +3 -0
- package/dist/query/QueryTable.js.map +1 -0
- package/dist/query/SelectQuery.d.ts +9 -0
- package/dist/query/SelectQuery.js +33 -0
- package/dist/query/SelectQuery.js.map +1 -0
- package/dist/query/UpdateQuery.d.ts +8 -0
- package/dist/query/UpdateQuery.js +17 -0
- package/dist/query/UpdateQuery.js.map +1 -0
- package/dist/query/builders/DefaultQueryBuilder.d.ts +87 -0
- package/dist/query/builders/DefaultQueryBuilder.js +524 -0
- package/dist/query/builders/DefaultQueryBuilder.js.map +1 -0
- package/dist/query/builders/QueryBuilder.d.ts +5 -0
- package/dist/query/builders/QueryBuilder.js +7 -0
- package/dist/query/builders/QueryBuilder.js.map +1 -0
- package/dist/query/builders/index.d.ts +2 -2
- package/dist/query/builders/index.js +2 -2
- package/dist/query/builders/index.js.map +1 -1
- package/dist/query/conditions/BasicCondition.d.ts +6 -0
- package/dist/query/conditions/BasicCondition.js +3 -0
- package/dist/query/conditions/BasicCondition.js.map +1 -0
- package/dist/query/conditions/ColumnCondition.d.ts +6 -0
- package/dist/query/conditions/ColumnCondition.js +3 -0
- package/dist/query/conditions/ColumnCondition.js.map +1 -0
- package/dist/query/conditions/Condition.d.ts +5 -0
- package/dist/query/conditions/Condition.js +3 -0
- package/dist/query/conditions/Condition.js.map +1 -0
- package/dist/query/conditions/ConditionConnector.d.ts +4 -0
- package/dist/query/conditions/ConditionConnector.js +9 -0
- package/dist/query/conditions/ConditionConnector.js.map +1 -0
- package/dist/query/conditions/ConditionGroup.d.ts +40 -0
- package/dist/query/conditions/ConditionGroup.js +138 -0
- package/dist/query/conditions/ConditionGroup.js.map +1 -0
- package/dist/query/conditions/ConnectedCondition.d.ts +6 -0
- package/dist/query/conditions/ConnectedCondition.js +3 -0
- package/dist/query/conditions/ConnectedCondition.js.map +1 -0
- package/dist/query/conditions/RawCondition.d.ts +4 -0
- package/dist/query/conditions/RawCondition.js +3 -0
- package/dist/query/conditions/RawCondition.js.map +1 -0
- package/dist/query/conditions/index.d.ts +7 -0
- package/dist/query/conditions/index.js +24 -0
- package/dist/query/conditions/index.js.map +1 -0
- package/dist/query/features/HasAlias.d.ts +6 -0
- package/dist/query/features/HasAlias.js +17 -0
- package/dist/query/features/HasAlias.js.map +1 -0
- package/dist/query/features/HasDistinct.d.ts +6 -0
- package/dist/query/features/HasDistinct.js +20 -0
- package/dist/query/features/HasDistinct.js.map +1 -0
- package/dist/query/features/HasFieldValues.d.ts +9 -0
- package/dist/query/features/HasFieldValues.js +27 -0
- package/dist/query/features/HasFieldValues.js.map +1 -0
- package/dist/query/features/HasGroupByFields.d.ts +7 -0
- package/dist/query/features/HasGroupByFields.js +21 -0
- package/dist/query/features/HasGroupByFields.js.map +1 -0
- package/dist/query/features/HasHavingConditions.d.ts +13 -0
- package/dist/query/features/HasHavingConditions.js +28 -0
- package/dist/query/features/HasHavingConditions.js.map +1 -0
- package/dist/query/features/HasJoins.d.ts +41 -0
- package/dist/query/features/HasJoins.js +66 -0
- package/dist/query/features/HasJoins.js.map +1 -0
- package/dist/query/features/HasLimit.d.ts +6 -0
- package/dist/query/features/HasLimit.js +20 -0
- package/dist/query/features/HasLimit.js.map +1 -0
- package/dist/query/features/HasOffset.d.ts +6 -0
- package/dist/query/features/HasOffset.js +20 -0
- package/dist/query/features/HasOffset.js.map +1 -0
- package/dist/query/features/HasOrderByFields.d.ts +15 -0
- package/dist/query/features/HasOrderByFields.js +38 -0
- package/dist/query/features/HasOrderByFields.js.map +1 -0
- package/dist/query/features/HasSelectFields.d.ts +11 -0
- package/dist/query/features/HasSelectFields.js +21 -0
- package/dist/query/features/HasSelectFields.js.map +1 -0
- package/dist/query/features/HasTable.d.ts +7 -0
- package/dist/query/features/HasTable.js +20 -0
- package/dist/query/features/HasTable.js.map +1 -0
- package/dist/query/features/HasUnions.d.ts +13 -0
- package/dist/query/features/HasUnions.js +21 -0
- package/dist/query/features/HasUnions.js.map +1 -0
- package/dist/query/features/HasWhen.d.ts +3 -0
- package/dist/query/features/HasWhen.js +13 -0
- package/dist/query/features/HasWhen.js.map +1 -0
- package/dist/query/features/HasWhereConditions.d.ts +35 -0
- package/dist/query/features/HasWhereConditions.js +92 -0
- package/dist/query/features/HasWhereConditions.js.map +1 -0
- package/dist/query/features/index.d.ts +14 -14
- package/dist/query/features/index.js +14 -14
- package/dist/query/features/index.js.map +1 -1
- package/dist/query/fields/BasicField.d.ts +5 -0
- package/dist/query/fields/BasicField.js +3 -0
- package/dist/query/fields/BasicField.js.map +1 -0
- package/dist/query/fields/Field.d.ts +3 -0
- package/dist/query/fields/Field.js +3 -0
- package/dist/query/fields/Field.js.map +1 -0
- package/dist/query/fields/RawField.d.ts +1 -0
- package/dist/query/fields/RawField.js +3 -0
- package/dist/query/fields/RawField.js.map +1 -0
- package/dist/query/fields/index.d.ts +3 -0
- package/dist/query/fields/index.js +20 -0
- package/dist/query/fields/index.js.map +1 -0
- package/dist/query/index.d.ts +7 -7
- package/dist/query/index.js +7 -7
- package/dist/query/index.js.map +1 -1
- package/dist/query/query.js +1 -1
- package/dist/query/query.js.map +1 -1
- package/dist/query/statement.js +1 -1
- package/dist/query/statement.js.map +1 -1
- package/dist/utilities.js +2 -3
- package/dist/utilities.js.map +1 -1
- package/package.json +21 -12
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EntityQuery = void 0;
|
|
4
|
+
const HasJoins_1 = require("../database/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 @@
|
|
|
1
|
+
{"version":3,"file":"RelationshipType.js","sourceRoot":"","sources":["../../src/entities/RelationshipType.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BelongsTo = BelongsTo;
|
|
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
|
+
//# sourceMappingURL=BelongsTo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BelongsTo.js","sourceRoot":"","sources":["../../../src/entities/decorators/BelongsTo.ts"],"names":[],"mappings":";;AAGA,8BASC;AAZD,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"}
|
|
@@ -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,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Column = Column;
|
|
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
|
+
//# sourceMappingURL=Column.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Column.js","sourceRoot":"","sources":["../../../src/entities/decorators/Column.ts"],"names":[],"mappings":";;AAeA,wBAMC;AApBD,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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export interface EntityOptions {
|
|
2
|
+
/** Database table name. Defaults to lowercase class name + 's'. */
|
|
3
|
+
table?: string;
|
|
4
|
+
/** Primary key column name. Defaults to 'id'. */
|
|
5
|
+
primaryKey?: string;
|
|
6
|
+
/**
|
|
7
|
+
* Registered DataSource name. When set, the entity operates on
|
|
8
|
+
* DB.source(sourceName); otherwise it operates directly on DB.
|
|
9
|
+
*/
|
|
10
|
+
source?: string | null;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Marks a class as an Active Record entity.
|
|
14
|
+
* The class must extend BaseEntity; this decorator reads the metadata
|
|
15
|
+
* accumulated by the property decorators (@Column, @HasMany, …) and assigns
|
|
16
|
+
* it to the static fields BaseEntity expects (table, primaryKey, fields, …).
|
|
17
|
+
*/
|
|
18
|
+
export declare function Entity(options?: EntityOptions): <T extends {
|
|
19
|
+
new (...args: any[]): {};
|
|
20
|
+
}>(EntityClass: T) => T;
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Entity = Entity;
|
|
4
|
+
const metadata_1 = require("./metadata");
|
|
5
|
+
/**
|
|
6
|
+
* Marks a class as an Active Record entity.
|
|
7
|
+
* The class must extend BaseEntity; this decorator reads the metadata
|
|
8
|
+
* accumulated by the property decorators (@Column, @HasMany, …) and assigns
|
|
9
|
+
* it to the static fields BaseEntity expects (table, primaryKey, fields, …).
|
|
10
|
+
*/
|
|
11
|
+
function Entity(options) {
|
|
12
|
+
return function (EntityClass) {
|
|
13
|
+
var _a, _b, _c, _d, _e, _f;
|
|
14
|
+
// Read metadata accumulated by property decorators on the class prototype.
|
|
15
|
+
const meta = (_a = metadata_1.registry.get(EntityClass.prototype)) !== null && _a !== void 0 ? _a : { columns: [], relationships: [] };
|
|
16
|
+
const tableName = (_b = options === null || options === void 0 ? void 0 : options.table) !== null && _b !== void 0 ? _b : EntityClass.name.toLowerCase() + 's';
|
|
17
|
+
const primaryKeyMeta = meta.columns.find((c) => c.primaryKey);
|
|
18
|
+
const primaryKeyCol = (_e = (_d = (primaryKeyMeta && ((_c = primaryKeyMeta.columnName) !== null && _c !== void 0 ? _c : primaryKeyMeta.name))) !== null && _d !== void 0 ? _d : options === null || options === void 0 ? void 0 : options.primaryKey) !== null && _e !== void 0 ? _e : 'id';
|
|
19
|
+
const fieldNames = meta.columns.map((c) => c.name);
|
|
20
|
+
// Property name → database column name (defaults to the property name)
|
|
21
|
+
const columnsMap = {};
|
|
22
|
+
meta.columns.forEach((c) => {
|
|
23
|
+
var _a;
|
|
24
|
+
columnsMap[c.name] = (_a = c.columnName) !== null && _a !== void 0 ? _a : c.name;
|
|
25
|
+
});
|
|
26
|
+
const autoGeneratedFields = meta.columns.filter((c) => c.autoGenerated).map((c) => c.name);
|
|
27
|
+
const castsMap = {};
|
|
28
|
+
meta.columns.forEach((c) => {
|
|
29
|
+
if (c.cast) {
|
|
30
|
+
castsMap[c.name] = c.cast;
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
const relsMap = {};
|
|
34
|
+
meta.relationships.forEach((r) => {
|
|
35
|
+
relsMap[r.name] = r.relationship;
|
|
36
|
+
});
|
|
37
|
+
// Assign the static metadata consumed by BaseEntity / EntityQuery.
|
|
38
|
+
const cls = EntityClass;
|
|
39
|
+
cls.table = tableName;
|
|
40
|
+
cls.primaryKey = primaryKeyCol;
|
|
41
|
+
cls.fields = fieldNames;
|
|
42
|
+
cls.columnsMap = columnsMap;
|
|
43
|
+
cls.autoGeneratedFields = autoGeneratedFields;
|
|
44
|
+
cls.casts = castsMap;
|
|
45
|
+
cls.relationships = relsMap;
|
|
46
|
+
cls.source = (_f = options === null || options === void 0 ? void 0 : options.source) !== null && _f !== void 0 ? _f : null;
|
|
47
|
+
return EntityClass;
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=Entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Entity.js","sourceRoot":"","sources":["../../../src/entities/decorators/Entity.ts"],"names":[],"mappings":";;AAsBA,wBA2CC;AA/DD,yCAAqC;AAcrC;;;;;GAKG;AACH,SAAgB,MAAM,CAAC,OAAuB;IAC5C,OAAO,UAAkD,WAAc;;QACrE,2EAA2E;QAC3E,MAAM,IAAI,GAAG,MAAA,mBAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,SAAS,CAAC,mCAAI,EAAE,OAAO,EAAE,EAAE,EAAE,aAAa,EAAE,EAAE,EAAE,CAAA;QACtF,MAAM,SAAS,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,mCAAI,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,GAAG,CAAA;QACxE,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAA;QAC7D,MAAM,aAAa,GACjB,MAAA,MAAA,CAAC,cAAc,IAAI,CAAC,MAAA,cAAc,CAAC,UAAU,mCAAI,cAAc,CAAC,IAAI,CAAC,CAAC,mCAAI,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,UAAU,mCAAI,IAAI,CAAA;QACvG,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;QAClD,uEAAuE;QACvE,MAAM,UAAU,GAA2B,EAAE,CAAA;QAE7C,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;;YACzB,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,MAAA,CAAC,CAAC,UAAU,mCAAI,CAAC,CAAC,IAAI,CAAA;QAC7C,CAAC,CAAC,CAAA;QACF,MAAM,mBAAmB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;QAC1F,MAAM,QAAQ,GAA6B,EAAE,CAAA;QAE7C,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YACzB,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;gBACX,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAA;YAC3B,CAAC;QACH,CAAC,CAAC,CAAA;QACF,MAAM,OAAO,GAAiC,EAAE,CAAA;QAEhD,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YAC/B,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,YAAY,CAAA;QAClC,CAAC,CAAC,CAAA;QAEF,mEAAmE;QACnE,MAAM,GAAG,GAAG,WAAkB,CAAA;QAE9B,GAAG,CAAC,KAAK,GAAG,SAAS,CAAA;QACrB,GAAG,CAAC,UAAU,GAAG,aAAa,CAAA;QAC9B,GAAG,CAAC,MAAM,GAAG,UAAU,CAAA;QACvB,GAAG,CAAC,UAAU,GAAG,UAAU,CAAA;QAC3B,GAAG,CAAC,mBAAmB,GAAG,mBAAmB,CAAA;QAC7C,GAAG,CAAC,KAAK,GAAG,QAAQ,CAAA;QACpB,GAAG,CAAC,aAAa,GAAG,OAAO,CAAA;QAC3B,GAAG,CAAC,MAAM,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,mCAAI,IAAI,CAAA;QAEpC,OAAO,WAAW,CAAA;IACpB,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HasMany = HasMany;
|
|
4
|
+
const metadata_1 = require("./metadata");
|
|
5
|
+
/** One-to-many: this model's primary key appears as foreignKey on the related model. */
|
|
6
|
+
function HasMany(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: 'hasMany', related, foreignKey, localKey }
|
|
12
|
+
});
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=HasMany.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HasMany.js","sourceRoot":"","sources":["../../../src/entities/decorators/HasMany.ts"],"names":[],"mappings":";;AAGA,0BASC;AAZD,yCAAwC;AAExC,wFAAwF;AACxF,SAAgB,OAAO,CAAC,OAAkB,EAAE,UAAkB,EAAE,QAAQ,GAAG,IAAI;IAC7E,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,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE;SACjE,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HasManyThrough = HasManyThrough;
|
|
4
|
+
const metadata_1 = require("./metadata");
|
|
5
|
+
/** Has-many through an intermediate model. */
|
|
6
|
+
function HasManyThrough(related, through, foreignKey, throughForeignKey, localKey = 'id', throughLocalKey = 'id') {
|
|
7
|
+
return (target, propertyKey) => {
|
|
8
|
+
const m = (0, metadata_1.getOrCreate)(target);
|
|
9
|
+
m.relationships.push({
|
|
10
|
+
name: String(propertyKey),
|
|
11
|
+
relationship: {
|
|
12
|
+
type: 'hasManyThrough',
|
|
13
|
+
related,
|
|
14
|
+
through,
|
|
15
|
+
foreignKey,
|
|
16
|
+
throughForeignKey,
|
|
17
|
+
localKey,
|
|
18
|
+
throughLocalKey
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=HasManyThrough.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HasManyThrough.js","sourceRoot":"","sources":["../../../src/entities/decorators/HasManyThrough.ts"],"names":[],"mappings":";;AAGA,wCAwBC;AA3BD,yCAAwC;AAExC,8CAA8C;AAC9C,SAAgB,cAAc,CAC5B,OAAkB,EAClB,OAAkB,EAClB,UAAkB,EAClB,iBAAyB,EACzB,QAAQ,GAAG,IAAI,EACf,eAAe,GAAG,IAAI;IAEtB,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;gBACZ,IAAI,EAAE,gBAAgB;gBACtB,OAAO;gBACP,OAAO;gBACP,UAAU;gBACV,iBAAiB;gBACjB,QAAQ;gBACR,eAAe;aAChB;SACF,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HasOne = HasOne;
|
|
4
|
+
const metadata_1 = require("./metadata");
|
|
5
|
+
/** One-to-one: this model's primary key appears as foreignKey on the related model. */
|
|
6
|
+
function HasOne(related, foreignKey, localKey = 'id') {
|
|
7
|
+
return (target, propertyKey) => {
|
|
8
|
+
const m = (0, metadata_1.getOrCreate)(target);
|
|
9
|
+
m.relationships.push({ name: String(propertyKey), relationship: { type: 'hasOne', related, foreignKey, localKey } });
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=HasOne.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HasOne.js","sourceRoot":"","sources":["../../../src/entities/decorators/HasOne.ts"],"names":[],"mappings":";;AAGA,wBAMC;AATD,yCAAwC;AAExC,uFAAuF;AACvF,SAAgB,MAAM,CAAC,OAAkB,EAAE,UAAkB,EAAE,QAAQ,GAAG,IAAI;IAC5E,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE;QAC7B,MAAM,CAAC,GAAG,IAAA,sBAAW,EAAC,MAAgB,CAAC,CAAA;QAEvC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,WAAW,CAAC,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAA;IACtH,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HasOneThrough = HasOneThrough;
|
|
4
|
+
const metadata_1 = require("./metadata");
|
|
5
|
+
/** Has-one through an intermediate model. */
|
|
6
|
+
function HasOneThrough(related, through, foreignKey, throughForeignKey, localKey = 'id', throughLocalKey = 'id') {
|
|
7
|
+
return (target, propertyKey) => {
|
|
8
|
+
const m = (0, metadata_1.getOrCreate)(target);
|
|
9
|
+
m.relationships.push({
|
|
10
|
+
name: String(propertyKey),
|
|
11
|
+
relationship: {
|
|
12
|
+
type: 'hasOneThrough',
|
|
13
|
+
related,
|
|
14
|
+
through,
|
|
15
|
+
foreignKey,
|
|
16
|
+
throughForeignKey,
|
|
17
|
+
localKey,
|
|
18
|
+
throughLocalKey
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=HasOneThrough.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HasOneThrough.js","sourceRoot":"","sources":["../../../src/entities/decorators/HasOneThrough.ts"],"names":[],"mappings":";;AAGA,sCAwBC;AA3BD,yCAAwC;AAExC,6CAA6C;AAC7C,SAAgB,aAAa,CAC3B,OAAkB,EAClB,OAAkB,EAClB,UAAkB,EAClB,iBAAyB,EACzB,QAAQ,GAAG,IAAI,EACf,eAAe,GAAG,IAAI;IAEtB,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;gBACZ,IAAI,EAAE,eAAe;gBACrB,OAAO;gBACP,OAAO;gBACP,UAAU;gBACV,iBAAiB;gBACjB,QAAQ;gBACR,eAAe;aAChB;SACF,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.applyCast = applyCast;
|
|
4
|
+
exports.applyCastForStorage = applyCastForStorage;
|
|
5
|
+
// ── Cast helpers ──────────────────────────────────────────────────────────────
|
|
6
|
+
function applyCast(value, type) {
|
|
7
|
+
if (value == null) {
|
|
8
|
+
return null;
|
|
9
|
+
}
|
|
10
|
+
switch (type) {
|
|
11
|
+
case 'number':
|
|
12
|
+
return Number(value);
|
|
13
|
+
case 'boolean':
|
|
14
|
+
return value === true || value === 1 || value === '1' || value === 'true';
|
|
15
|
+
case 'string':
|
|
16
|
+
return String(value);
|
|
17
|
+
case 'json':
|
|
18
|
+
return typeof value === 'string' ? JSON.parse(value) : value;
|
|
19
|
+
case 'date':
|
|
20
|
+
return value instanceof Date ? value : new Date(value);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function applyCastForStorage(value, type) {
|
|
24
|
+
if (value == null) {
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
switch (type) {
|
|
28
|
+
case 'boolean':
|
|
29
|
+
return value ? 1 : 0;
|
|
30
|
+
case 'json':
|
|
31
|
+
return typeof value === 'string' ? value : JSON.stringify(value);
|
|
32
|
+
case 'date':
|
|
33
|
+
return value instanceof Date ? value.toISOString() : value;
|
|
34
|
+
default:
|
|
35
|
+
return value;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=casts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"casts.js","sourceRoot":"","sources":["../../../src/entities/decorators/casts.ts"],"names":[],"mappings":";;AAIA,8BAiBC;AAED,kDAeC;AApCD,iFAAiF;AAEjF,SAAgB,SAAS,CAAC,KAAU,EAAE,IAAc;IAClD,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;QAClB,OAAO,IAAI,CAAA;IACb,CAAC;IAED,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,QAAQ;YACX,OAAO,MAAM,CAAC,KAAK,CAAC,CAAA;QACtB,KAAK,SAAS;YACZ,OAAO,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,CAAC,IAAI,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,MAAM,CAAA;QAC3E,KAAK,QAAQ;YACX,OAAO,MAAM,CAAC,KAAK,CAAC,CAAA;QACtB,KAAK,MAAM;YACT,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;QAC9D,KAAK,MAAM;YACT,OAAO,KAAK,YAAY,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAA;IAC1D,CAAC;AACH,CAAC;AAED,SAAgB,mBAAmB,CAAC,KAAU,EAAE,IAAc;IAC5D,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;QAClB,OAAO,IAAI,CAAA;IACb,CAAC;IAED,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,SAAS;YACZ,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACtB,KAAK,MAAM;YACT,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;QAClE,KAAK,MAAM;YACT,OAAO,KAAK,YAAY,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,KAAK,CAAA;QAC5D;YACE,OAAO,KAAK,CAAA;IAChB,CAAC;AACH,CAAC"}
|