@neogroup/neorm 0.0.2 → 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 +35 -35
- package/dist/database/DB.d.ts +8 -3
- package/dist/database/DB.js +20 -2
- package/dist/database/DB.js.map +1 -1
- package/dist/database/DataConnection.d.ts +1 -1
- package/dist/database/DataConnection.js +1 -1
- package/dist/database/DataConnection.js.map +1 -1
- package/dist/database/DataSource.d.ts +1 -1
- package/dist/database/DataSource.js +1 -1
- package/dist/database/DataSource.js.map +1 -1
- package/dist/database/DataTable.d.ts +2 -2
- package/dist/database/DataTable.js +2 -2
- package/dist/database/DataTable.js.map +1 -1
- package/dist/database/index.d.ts +1 -0
- package/dist/database/index.js +1 -0
- package/dist/database/index.js.map +1 -1
- 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/mysql/MysqlDataSource.js.map +1 -1
- package/dist/database/sources/mysql/MysqlQueryBuilder.d.ts +1 -1
- package/dist/database/sources/mysql/MysqlQueryBuilder.js +1 -1
- package/dist/database/sources/mysql/MysqlQueryBuilder.js.map +1 -1
- package/dist/database/sources/postgres/PostgresConnection.js.map +1 -1
- package/dist/database/sources/postgres/PostgresDataSource.js.map +1 -1
- package/dist/database/sources/postgres/PostgresQueryBuilder.d.ts +1 -1
- package/dist/database/sources/postgres/PostgresQueryBuilder.js +1 -1
- package/dist/database/sources/postgres/PostgresQueryBuilder.js.map +1 -1
- package/dist/database/sources/sqlite/SqliteDataSource.js.map +1 -1
- package/dist/database/sources/sqlite/SqliteQueryBuilder.d.ts +3 -3
- package/dist/database/sources/sqlite/SqliteQueryBuilder.js +1 -1
- package/dist/database/sources/sqlite/SqliteQueryBuilder.js.map +1 -1
- 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/EntityQuery.d.ts +3 -3
- package/dist/entities/EntityQuery.js +1 -1
- package/dist/entities/EntityQuery.js.map +1 -1
- package/dist/entities/decorators/BelongsTo.js +1 -2
- package/dist/entities/decorators/BelongsTo.js.map +1 -1
- package/dist/entities/decorators/Column.js +1 -2
- package/dist/entities/decorators/Column.js.map +1 -1
- package/dist/entities/decorators/Entity.d.ts +11 -6
- package/dist/entities/decorators/Entity.js +19 -139
- package/dist/entities/decorators/Entity.js.map +1 -1
- package/dist/entities/decorators/HasMany.js +1 -2
- package/dist/entities/decorators/HasMany.js.map +1 -1
- package/dist/entities/decorators/HasManyThrough.js +1 -2
- package/dist/entities/decorators/HasManyThrough.js.map +1 -1
- package/dist/entities/decorators/HasOne.js +1 -2
- package/dist/entities/decorators/HasOne.js.map +1 -1
- package/dist/entities/decorators/HasOneThrough.js +1 -2
- package/dist/entities/decorators/HasOneThrough.js.map +1 -1
- package/dist/entities/decorators/casts.js +2 -3
- package/dist/entities/decorators/casts.js.map +1 -1
- package/dist/entities/decorators/metadata.js +2 -2
- package/dist/entities/decorators/metadata.js.map +1 -1
- package/dist/entities/index.d.ts +1 -1
- package/dist/entities/index.js +1 -1
- package/dist/entities/index.js.map +1 -1
- package/dist/index.d.ts +0 -1
- package/dist/index.js +0 -1
- package/dist/index.js.map +1 -1
- package/dist/utilities.js +2 -3
- package/dist/utilities.js.map +1 -1
- package/package.json +8 -4
|
@@ -1,22 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Entity =
|
|
4
|
-
const DB_1 = require("../../database/DB");
|
|
5
|
-
const EntityQuery_1 = require("../EntityQuery");
|
|
6
|
-
const casts_1 = require("./casts");
|
|
3
|
+
exports.Entity = Entity;
|
|
7
4
|
const metadata_1 = require("./metadata");
|
|
8
5
|
/**
|
|
9
6
|
* Marks a class as an Active Record entity.
|
|
10
|
-
*
|
|
11
|
-
*
|
|
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, …).
|
|
12
10
|
*/
|
|
13
11
|
function Entity(options) {
|
|
14
|
-
return function (
|
|
12
|
+
return function (EntityClass) {
|
|
15
13
|
var _a, _b, _c, _d, _e, _f;
|
|
16
|
-
// Read metadata accumulated by property decorators on
|
|
17
|
-
const
|
|
18
|
-
const
|
|
19
|
-
const tableName = (_b = options === null || options === void 0 ? void 0 : options.table) !== null && _b !== void 0 ? _b : originalName.toLowerCase() + 's';
|
|
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';
|
|
20
17
|
const primaryKeyMeta = meta.columns.find((c) => c.primaryKey);
|
|
21
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';
|
|
22
19
|
const fieldNames = meta.columns.map((c) => c.name);
|
|
@@ -37,134 +34,17 @@ function Entity(options) {
|
|
|
37
34
|
meta.relationships.forEach((r) => {
|
|
38
35
|
relsMap[r.name] = r.relationship;
|
|
39
36
|
});
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
if (!(col in row)) {
|
|
52
|
-
continue;
|
|
53
|
-
}
|
|
54
|
-
const cast = castsMap[prop];
|
|
55
|
-
instance[prop] = cast ? (0, casts_1.applyCast)(row[col], cast) : row[col];
|
|
56
|
-
}
|
|
57
|
-
return instance;
|
|
58
|
-
}
|
|
59
|
-
function buildQuery() {
|
|
60
|
-
return new EntityQuery_1.EntityQuery(Enhanced, resolveSource().table(tableName));
|
|
61
|
-
}
|
|
62
|
-
// ── Enhanced class — wraps BaseClass and injects all methods ──────────
|
|
63
|
-
class Enhanced extends BaseClass {
|
|
64
|
-
static fromRow(row) {
|
|
65
|
-
return hydrateRow(row);
|
|
66
|
-
}
|
|
67
|
-
toJSON() {
|
|
68
|
-
const result = {};
|
|
69
|
-
// Own enumerable properties — column values set by hydrateRow
|
|
70
|
-
for (const key of Object.keys(this)) {
|
|
71
|
-
result[key] = this[key];
|
|
72
|
-
}
|
|
73
|
-
// Getters defined on the user's class prototype (computed attributes)
|
|
74
|
-
for (const key of Object.getOwnPropertyNames(BaseClass.prototype)) {
|
|
75
|
-
if (key === 'constructor' || key in result) {
|
|
76
|
-
continue;
|
|
77
|
-
}
|
|
78
|
-
const descriptor = Object.getOwnPropertyDescriptor(BaseClass.prototype, key);
|
|
79
|
-
if (descriptor && typeof descriptor.get === 'function') {
|
|
80
|
-
try {
|
|
81
|
-
result[key] = this[key];
|
|
82
|
-
}
|
|
83
|
-
catch (_a) {
|
|
84
|
-
// skip getters that throw (e.g. unloaded relationships)
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
return result;
|
|
89
|
-
}
|
|
90
|
-
// ── Static query methods ───────────────────────────────────────────
|
|
91
|
-
static async find(id) {
|
|
92
|
-
return buildQuery().find(id);
|
|
93
|
-
}
|
|
94
|
-
static async get() {
|
|
95
|
-
return buildQuery().get();
|
|
96
|
-
}
|
|
97
|
-
static async first() {
|
|
98
|
-
return buildQuery().first();
|
|
99
|
-
}
|
|
100
|
-
static where(...args) {
|
|
101
|
-
return buildQuery().where(...args);
|
|
102
|
-
}
|
|
103
|
-
static whereIn(field, values) {
|
|
104
|
-
return buildQuery().whereIn(field, values);
|
|
105
|
-
}
|
|
106
|
-
static whereNotIn(field, values) {
|
|
107
|
-
return buildQuery().whereNotIn(field, values);
|
|
108
|
-
}
|
|
109
|
-
static whereBetween(field, range) {
|
|
110
|
-
return buildQuery().whereBetween(field, range);
|
|
111
|
-
}
|
|
112
|
-
static whereNotBetween(field, range) {
|
|
113
|
-
return buildQuery().whereNotBetween(field, range);
|
|
114
|
-
}
|
|
115
|
-
static whereNull(field) {
|
|
116
|
-
return buildQuery().whereNull(field);
|
|
117
|
-
}
|
|
118
|
-
static whereNotNull(field) {
|
|
119
|
-
return buildQuery().whereNotNull(field);
|
|
120
|
-
}
|
|
121
|
-
static whereLike(field, pattern) {
|
|
122
|
-
return buildQuery().whereLike(field, pattern);
|
|
123
|
-
}
|
|
124
|
-
static whereNotLike(field, pattern) {
|
|
125
|
-
return buildQuery().whereNotLike(field, pattern);
|
|
126
|
-
}
|
|
127
|
-
static whereColumn(...args) {
|
|
128
|
-
return buildQuery().whereColumn(...args);
|
|
129
|
-
}
|
|
130
|
-
static orderBy(field, direction) {
|
|
131
|
-
return buildQuery().orderBy(field, direction);
|
|
132
|
-
}
|
|
133
|
-
static limit(value) {
|
|
134
|
-
return buildQuery().limit(value);
|
|
135
|
-
}
|
|
136
|
-
static offset(value) {
|
|
137
|
-
return buildQuery().offset(value);
|
|
138
|
-
}
|
|
139
|
-
static select(...args) {
|
|
140
|
-
return buildQuery().select(...args);
|
|
141
|
-
}
|
|
142
|
-
static with(relations, ...rest) {
|
|
143
|
-
return buildQuery().with(relations, ...rest);
|
|
144
|
-
}
|
|
145
|
-
static joinRelationship(name) {
|
|
146
|
-
return buildQuery().joinRelationship(name);
|
|
147
|
-
}
|
|
148
|
-
static innerJoinRelationship(name) {
|
|
149
|
-
return buildQuery().innerJoinRelationship(name);
|
|
150
|
-
}
|
|
151
|
-
static leftJoinRelationship(name) {
|
|
152
|
-
return buildQuery().leftJoinRelationship(name);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
// Static metadata (also used by EntityQuery internals)
|
|
156
|
-
Enhanced.table = tableName;
|
|
157
|
-
Enhanced.primaryKey = primaryKeyCol;
|
|
158
|
-
Enhanced.fields = fieldNames;
|
|
159
|
-
Enhanced.columnsMap = columnsMap;
|
|
160
|
-
Enhanced.autoGeneratedFields = autoGeneratedFields;
|
|
161
|
-
Enhanced.casts = castsMap;
|
|
162
|
-
Enhanced.relationships = relsMap;
|
|
163
|
-
Enhanced.source = configuredSource;
|
|
164
|
-
// Preserve the original class name so default table names and stack traces stay clean.
|
|
165
|
-
Object.defineProperty(Enhanced, 'name', { value: originalName });
|
|
166
|
-
return Enhanced;
|
|
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;
|
|
167
48
|
};
|
|
168
49
|
}
|
|
169
|
-
exports.Entity = Entity;
|
|
170
50
|
//# sourceMappingURL=Entity.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Entity.js","sourceRoot":"","sources":["../../../src/entities/decorators/Entity.ts"],"names":[],"mappings":"
|
|
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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.HasMany =
|
|
3
|
+
exports.HasMany = HasMany;
|
|
4
4
|
const metadata_1 = require("./metadata");
|
|
5
5
|
/** One-to-many: this model's primary key appears as foreignKey on the related model. */
|
|
6
6
|
function HasMany(related, foreignKey, localKey = 'id') {
|
|
@@ -12,5 +12,4 @@ function HasMany(related, foreignKey, localKey = 'id') {
|
|
|
12
12
|
});
|
|
13
13
|
};
|
|
14
14
|
}
|
|
15
|
-
exports.HasMany = HasMany;
|
|
16
15
|
//# sourceMappingURL=HasMany.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HasMany.js","sourceRoot":"","sources":["../../../src/entities/decorators/HasMany.ts"],"names":[],"mappings":"
|
|
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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.HasManyThrough =
|
|
3
|
+
exports.HasManyThrough = HasManyThrough;
|
|
4
4
|
const metadata_1 = require("./metadata");
|
|
5
5
|
/** Has-many through an intermediate model. */
|
|
6
6
|
function HasManyThrough(related, through, foreignKey, throughForeignKey, localKey = 'id', throughLocalKey = 'id') {
|
|
@@ -20,5 +20,4 @@ function HasManyThrough(related, through, foreignKey, throughForeignKey, localKe
|
|
|
20
20
|
});
|
|
21
21
|
};
|
|
22
22
|
}
|
|
23
|
-
exports.HasManyThrough = HasManyThrough;
|
|
24
23
|
//# sourceMappingURL=HasManyThrough.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HasManyThrough.js","sourceRoot":"","sources":["../../../src/entities/decorators/HasManyThrough.ts"],"names":[],"mappings":"
|
|
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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.HasOne =
|
|
3
|
+
exports.HasOne = HasOne;
|
|
4
4
|
const metadata_1 = require("./metadata");
|
|
5
5
|
/** One-to-one: this model's primary key appears as foreignKey on the related model. */
|
|
6
6
|
function HasOne(related, foreignKey, localKey = 'id') {
|
|
@@ -9,5 +9,4 @@ function HasOne(related, foreignKey, localKey = 'id') {
|
|
|
9
9
|
m.relationships.push({ name: String(propertyKey), relationship: { type: 'hasOne', related, foreignKey, localKey } });
|
|
10
10
|
};
|
|
11
11
|
}
|
|
12
|
-
exports.HasOne = HasOne;
|
|
13
12
|
//# sourceMappingURL=HasOne.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HasOne.js","sourceRoot":"","sources":["../../../src/entities/decorators/HasOne.ts"],"names":[],"mappings":"
|
|
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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.HasOneThrough =
|
|
3
|
+
exports.HasOneThrough = HasOneThrough;
|
|
4
4
|
const metadata_1 = require("./metadata");
|
|
5
5
|
/** Has-one through an intermediate model. */
|
|
6
6
|
function HasOneThrough(related, through, foreignKey, throughForeignKey, localKey = 'id', throughLocalKey = 'id') {
|
|
@@ -20,5 +20,4 @@ function HasOneThrough(related, through, foreignKey, throughForeignKey, localKey
|
|
|
20
20
|
});
|
|
21
21
|
};
|
|
22
22
|
}
|
|
23
|
-
exports.HasOneThrough = HasOneThrough;
|
|
24
23
|
//# sourceMappingURL=HasOneThrough.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HasOneThrough.js","sourceRoot":"","sources":["../../../src/entities/decorators/HasOneThrough.ts"],"names":[],"mappings":"
|
|
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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.applyCast = applyCast;
|
|
4
|
+
exports.applyCastForStorage = applyCastForStorage;
|
|
4
5
|
// ── Cast helpers ──────────────────────────────────────────────────────────────
|
|
5
6
|
function applyCast(value, type) {
|
|
6
7
|
if (value == null) {
|
|
@@ -19,7 +20,6 @@ function applyCast(value, type) {
|
|
|
19
20
|
return value instanceof Date ? value : new Date(value);
|
|
20
21
|
}
|
|
21
22
|
}
|
|
22
|
-
exports.applyCast = applyCast;
|
|
23
23
|
function applyCastForStorage(value, type) {
|
|
24
24
|
if (value == null) {
|
|
25
25
|
return null;
|
|
@@ -35,5 +35,4 @@ function applyCastForStorage(value, type) {
|
|
|
35
35
|
return value;
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
|
-
exports.applyCastForStorage = applyCastForStorage;
|
|
39
38
|
//# sourceMappingURL=casts.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"casts.js","sourceRoot":"","sources":["../../../src/entities/decorators/casts.ts"],"names":[],"mappings":"
|
|
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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.registry = void 0;
|
|
4
|
+
exports.getOrCreate = getOrCreate;
|
|
4
5
|
exports.registry = new WeakMap();
|
|
5
6
|
function getOrCreate(proto) {
|
|
6
7
|
if (!exports.registry.has(proto)) {
|
|
@@ -8,5 +9,4 @@ function getOrCreate(proto) {
|
|
|
8
9
|
}
|
|
9
10
|
return exports.registry.get(proto);
|
|
10
11
|
}
|
|
11
|
-
exports.getOrCreate = getOrCreate;
|
|
12
12
|
//# sourceMappingURL=metadata.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../../src/entities/decorators/metadata.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../../src/entities/decorators/metadata.ts"],"names":[],"mappings":";;;AA2BA,kCAMC;AARY,QAAA,QAAQ,GAAG,IAAI,OAAO,EAAyB,CAAA;AAE5D,SAAgB,WAAW,CAAC,KAAa;IACvC,IAAI,CAAC,gBAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;QACzB,gBAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC,CAAA;IACzD,CAAC;IAED,OAAO,gBAAQ,CAAC,GAAG,CAAC,KAAK,CAAE,CAAA;AAC7B,CAAC"}
|
package/dist/entities/index.d.ts
CHANGED
package/dist/entities/index.js
CHANGED
|
@@ -14,9 +14,9 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./BaseEntity"), exports);
|
|
17
18
|
__exportStar(require("./CastType"), exports);
|
|
18
19
|
__exportStar(require("./decorators"), exports);
|
|
19
|
-
__exportStar(require("./Entities"), exports);
|
|
20
20
|
__exportStar(require("./EntityQuery"), exports);
|
|
21
21
|
__exportStar(require("./Relationship"), exports);
|
|
22
22
|
__exportStar(require("./RelationshipType"), exports);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/entities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA0B;AAC1B,+CAA4B;AAC5B,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/entities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA4B;AAC5B,6CAA0B;AAC1B,+CAA4B;AAC5B,gDAA6B;AAC7B,iDAA8B;AAC9B,qDAAkC"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -16,5 +16,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./database"), exports);
|
|
18
18
|
__exportStar(require("./entities"), exports);
|
|
19
|
-
__exportStar(require("./query"), exports);
|
|
20
19
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA0B;AAC1B,6CAA0B
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA0B;AAC1B,6CAA0B"}
|
package/dist/utilities.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.applyMixins = applyMixins;
|
|
4
|
+
exports.debugLog = debugLog;
|
|
4
5
|
function applyMixins(derivedCtor, constructors) {
|
|
5
6
|
constructors.forEach((baseCtor) => {
|
|
6
7
|
Object.getOwnPropertyNames(baseCtor.prototype).forEach((name) => {
|
|
@@ -8,10 +9,8 @@ function applyMixins(derivedCtor, constructors) {
|
|
|
8
9
|
});
|
|
9
10
|
});
|
|
10
11
|
}
|
|
11
|
-
exports.applyMixins = applyMixins;
|
|
12
12
|
function debugLog(message) {
|
|
13
13
|
// eslint-disable-next-line no-console
|
|
14
14
|
console.log(message);
|
|
15
15
|
}
|
|
16
|
-
exports.debugLog = debugLog;
|
|
17
16
|
//# sourceMappingURL=utilities.js.map
|
package/dist/utilities.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utilities.js","sourceRoot":"","sources":["../src/utilities.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utilities.js","sourceRoot":"","sources":["../src/utilities.ts"],"names":[],"mappings":";;AAAA,kCAUC;AAED,4BAGC;AAfD,SAAgB,WAAW,CAAC,WAAgB,EAAE,YAAmB;IAC/D,YAAY,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;QAChC,MAAM,CAAC,mBAAmB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC9D,MAAM,CAAC,cAAc,CACnB,WAAW,CAAC,SAAS,EACrB,IAAI,EACJ,MAAM,CAAC,wBAAwB,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CACjF,CAAA;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,SAAgB,QAAQ,CAAC,OAAe;IACtC,sCAAsC;IACtC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;AACtB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@neogroup/neorm",
|
|
3
|
-
"version": "0.0.
|
|
4
|
-
"description": "Database connector for javascript",
|
|
3
|
+
"version": "0.0.3",
|
|
4
|
+
"description": "Database connector and ORM for javascript",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
7
7
|
"exports": {
|
|
@@ -20,7 +20,11 @@
|
|
|
20
20
|
"keywords": [
|
|
21
21
|
"database",
|
|
22
22
|
"connector",
|
|
23
|
-
"javascript"
|
|
23
|
+
"javascript",
|
|
24
|
+
"typescript",
|
|
25
|
+
"orm",
|
|
26
|
+
"mysql",
|
|
27
|
+
"postgres"
|
|
24
28
|
],
|
|
25
29
|
"files": [
|
|
26
30
|
"dist"
|
|
@@ -35,6 +39,7 @@
|
|
|
35
39
|
"scripts": {
|
|
36
40
|
"build": "jest --passWithNoTests && tsc",
|
|
37
41
|
"test": "jest",
|
|
42
|
+
"lint": "eslint src test --ext .ts,.js --fix",
|
|
38
43
|
"prepublishOnly": "npm run build"
|
|
39
44
|
},
|
|
40
45
|
"devDependencies": {
|
|
@@ -44,7 +49,6 @@
|
|
|
44
49
|
"@typescript-eslint/parser": "^5.47.0",
|
|
45
50
|
"dotenv": "^16.0.3",
|
|
46
51
|
"eslint": "^8.57.0",
|
|
47
|
-
"eslint-config-next": "^15.0.0",
|
|
48
52
|
"eslint-config-prettier": "^8.5.0",
|
|
49
53
|
"eslint-plugin-absolute-imports-only": "^1.0.1",
|
|
50
54
|
"eslint-plugin-prettier": "^5.0.1",
|