@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.
- package/README.md +1 -0
- 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 +58 -0
- package/dist/database/DB.js +229 -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 +7 -0
- package/dist/database/index.js +24 -0
- package/dist/database/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/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 +16 -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 +13 -0
- package/dist/entities/decorators/Column.js.map +1 -0
- package/dist/entities/decorators/Entity.d.ts +15 -0
- package/dist/entities/decorators/Entity.js +170 -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 +16 -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 +24 -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 +13 -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 +24 -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 +39 -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 +2 -9
- package/dist/index.js +2 -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/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,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 @@
|
|
|
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 @@
|
|
|
1
|
+
{"version":3,"file":"RelationshipType.js","sourceRoot":"","sources":["../../src/entities/RelationshipType.ts"],"names":[],"mappings":""}
|
|
@@ -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"}
|