@spinajs/orm 2.0.180 → 2.0.181
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/lib/cjs/builders.d.ts +643 -643
- package/lib/cjs/builders.js +1602 -1602
- package/lib/cjs/builders.js.map +1 -1
- package/lib/cjs/converters.d.ts +34 -34
- package/lib/cjs/converters.js +104 -104
- package/lib/cjs/decorators.d.ts +152 -152
- package/lib/cjs/decorators.js +449 -449
- package/lib/cjs/dehydrators.d.ts +10 -10
- package/lib/cjs/dehydrators.js +47 -47
- package/lib/cjs/driver.d.ts +82 -82
- package/lib/cjs/driver.js +102 -102
- package/lib/cjs/driver.js.map +1 -1
- package/lib/cjs/enums.d.ts +116 -116
- package/lib/cjs/enums.js +126 -126
- package/lib/cjs/enums.js.map +1 -1
- package/lib/cjs/exceptions.d.ts +6 -6
- package/lib/cjs/exceptions.js +10 -10
- package/lib/cjs/hydrators.d.ts +19 -19
- package/lib/cjs/hydrators.js +132 -132
- package/lib/cjs/hydrators.js.map +1 -1
- package/lib/cjs/index.d.ts +17 -17
- package/lib/cjs/index.js +33 -33
- package/lib/cjs/interfaces.d.ts +919 -919
- package/lib/cjs/interfaces.js +279 -279
- package/lib/cjs/interfaces.js.map +1 -1
- package/lib/cjs/middlewares.d.ts +62 -62
- package/lib/cjs/middlewares.js +258 -258
- package/lib/cjs/model.d.ts +284 -284
- package/lib/cjs/model.js +810 -810
- package/lib/cjs/orm.d.ts +61 -61
- package/lib/cjs/orm.js +333 -333
- package/lib/cjs/orm.js.map +1 -1
- package/lib/cjs/relation-objects.d.ts +108 -108
- package/lib/cjs/relation-objects.js +221 -221
- package/lib/cjs/relations.d.ts +61 -61
- package/lib/cjs/relations.js +194 -194
- package/lib/cjs/relations.js.map +1 -1
- package/lib/cjs/statements.d.ts +143 -143
- package/lib/cjs/statements.js +309 -309
- package/lib/cjs/statements.js.map +1 -1
- package/lib/cjs/types.d.ts +32 -32
- package/lib/cjs/types.js +2 -2
- package/lib/cjs/wrappers.d.ts +5 -5
- package/lib/cjs/wrappers.js +12 -12
- package/lib/mjs/builders.d.ts +643 -643
- package/lib/mjs/builders.js +1594 -1594
- package/lib/mjs/builders.js.map +1 -1
- package/lib/mjs/converters.d.ts +34 -34
- package/lib/mjs/converters.js +96 -96
- package/lib/mjs/decorators.d.ts +152 -152
- package/lib/mjs/decorators.js +422 -422
- package/lib/mjs/dehydrators.d.ts +10 -10
- package/lib/mjs/dehydrators.js +41 -41
- package/lib/mjs/driver.d.ts +82 -82
- package/lib/mjs/driver.js +98 -98
- package/lib/mjs/driver.js.map +1 -1
- package/lib/mjs/enums.d.ts +116 -116
- package/lib/mjs/enums.js +123 -123
- package/lib/mjs/enums.js.map +1 -1
- package/lib/mjs/exceptions.d.ts +6 -6
- package/lib/mjs/exceptions.js +6 -6
- package/lib/mjs/hydrators.d.ts +19 -19
- package/lib/mjs/hydrators.js +128 -128
- package/lib/mjs/hydrators.js.map +1 -1
- package/lib/mjs/index.d.ts +17 -17
- package/lib/mjs/index.js +17 -17
- package/lib/mjs/interfaces.d.ts +919 -919
- package/lib/mjs/interfaces.js +267 -267
- package/lib/mjs/interfaces.js.map +1 -1
- package/lib/mjs/middlewares.d.ts +62 -62
- package/lib/mjs/middlewares.js +249 -249
- package/lib/mjs/model.d.ts +284 -284
- package/lib/mjs/model.js +800 -800
- package/lib/mjs/orm.d.ts +61 -61
- package/lib/mjs/orm.js +326 -326
- package/lib/mjs/orm.js.map +1 -1
- package/lib/mjs/relation-objects.d.ts +108 -108
- package/lib/mjs/relation-objects.js +211 -211
- package/lib/mjs/relations.d.ts +61 -61
- package/lib/mjs/relations.js +191 -191
- package/lib/mjs/relations.js.map +1 -1
- package/lib/mjs/statements.d.ts +143 -143
- package/lib/mjs/statements.js +301 -301
- package/lib/mjs/statements.js.map +1 -1
- package/lib/mjs/types.d.ts +32 -32
- package/lib/mjs/types.js +1 -1
- package/lib/mjs/wrappers.d.ts +5 -5
- package/lib/mjs/wrappers.js +9 -9
- package/lib/tsconfig.cjs.tsbuildinfo +1 -1
- package/lib/tsconfig.mjs.tsbuildinfo +1 -1
- package/package.json +5 -5
package/lib/cjs/relations.js
CHANGED
|
@@ -1,195 +1,195 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
-
};
|
|
11
|
-
var BelongsToRelation_1;
|
|
12
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
exports.ManyToManyRelation = exports.OneToManyRelation = exports.BelongsToRecursiveRelation = exports.BelongsToRelation = exports.OrmRelation = void 0;
|
|
14
|
-
/* eslint-disable prettier/prettier */
|
|
15
|
-
const exceptions_1 = require("@spinajs/exceptions");
|
|
16
|
-
const interfaces_js_1 = require("./interfaces.js");
|
|
17
|
-
const di_1 = require("@spinajs/di");
|
|
18
|
-
const middlewares_js_1 = require("./middlewares.js");
|
|
19
|
-
const model_js_1 = require("./model.js");
|
|
20
|
-
const orm_js_1 = require("./orm.js");
|
|
21
|
-
function _paramCheck(callback, err) {
|
|
22
|
-
const val = callback();
|
|
23
|
-
if (!callback()) {
|
|
24
|
-
throw new Error(err);
|
|
25
|
-
}
|
|
26
|
-
return val;
|
|
27
|
-
}
|
|
28
|
-
let OrmRelation = class OrmRelation {
|
|
29
|
-
get Alias() {
|
|
30
|
-
return this.parentRelation ? `${this.parentRelation.Alias}.${this._separator}${this._description.Name}${this._separator}` : `${this._separator}${this._description.Name}${this._separator}`;
|
|
31
|
-
}
|
|
32
|
-
constructor(_container, _query, _description, parentRelation) {
|
|
33
|
-
this._container = _container;
|
|
34
|
-
this._query = _query;
|
|
35
|
-
this._description = _description;
|
|
36
|
-
this.parentRelation = parentRelation;
|
|
37
|
-
this._targetModel = this._description.TargetModel;
|
|
38
|
-
this._targetModelDescriptor = _paramCheck(() => (0, model_js_1.extractModelDescriptor)(this._targetModel), `Model ${this._targetModel?.name} does not have model descriptor set`);
|
|
39
|
-
this._driver = _paramCheck(() => di_1.DI.resolve("OrmConnection", [this._targetModelDescriptor.Connection]), `Connection ${this._targetModelDescriptor.Connection} is not set in configuration file`);
|
|
40
|
-
this._relationQuery = this._container.resolve("SelectQueryBuilder", [this._driver, this._targetModel, this]);
|
|
41
|
-
this._separator = this._driver.Options.AliasSeparator;
|
|
42
|
-
if (this._driver.Options.Database) {
|
|
43
|
-
this._relationQuery.database(this._driver.Options.Database);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
executeOnQuery(callback) {
|
|
47
|
-
callback.call(this._relationQuery, [this]);
|
|
48
|
-
}
|
|
49
|
-
};
|
|
50
|
-
OrmRelation =
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
let BelongsToRelation = BelongsToRelation_1 = class BelongsToRelation extends OrmRelation {
|
|
56
|
-
constructor(_container, _query, _description, _parentRelation) {
|
|
57
|
-
super(_container, _query, _description, _parentRelation);
|
|
58
|
-
this._relationQuery.from(this._targetModelDescriptor.TableName, this.Alias);
|
|
59
|
-
this._targetModelDescriptor.Columns.forEach((c) => {
|
|
60
|
-
this._relationQuery.select(c.Name, `${this.Alias}.${c.Name}`);
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
execute(callback) {
|
|
64
|
-
if (!this.parentRelation && !this._query.TableAlias) {
|
|
65
|
-
this._query.setAlias(`${this._separator}${this._description.SourceModel.name}${this._separator}`);
|
|
66
|
-
}
|
|
67
|
-
this._query.leftJoin(this._targetModelDescriptor.TableName, this.Alias, this._description.ForeignKey, `${this._description.PrimaryKey}`, this._targetModelDescriptor.Driver.Options.Database);
|
|
68
|
-
if (callback) {
|
|
69
|
-
callback.call(this._relationQuery, [this]);
|
|
70
|
-
}
|
|
71
|
-
// todo: fix this cast
|
|
72
|
-
this._query.mergeBuilder(this._relationQuery);
|
|
73
|
-
this._query.middleware(new middlewares_js_1.BelongsToPopulateDataMiddleware(this._description, this));
|
|
74
|
-
if (!this.parentRelation || !(this.parentRelation instanceof BelongsToRelation_1)) {
|
|
75
|
-
// if we are on top of the belongsTo relation stack
|
|
76
|
-
// add transform middleware
|
|
77
|
-
// we do this becouse belongsTo modifies query (not creating new like oneToMany and manyToMany)
|
|
78
|
-
// and we only need to run transform once
|
|
79
|
-
this._query.middleware(new middlewares_js_1.BelongsToRelationResultTransformMiddleware());
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
};
|
|
83
|
-
BelongsToRelation =
|
|
84
|
-
|
|
85
|
-
(0, di_1.
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
let BelongsToRecursiveRelation = class BelongsToRecursiveRelation extends OrmRelation {
|
|
90
|
-
constructor(_container, _query, _description, _parentRelation) {
|
|
91
|
-
super(_container, _query, _description, _parentRelation);
|
|
92
|
-
this._relationQuery.withRecursive(this._description.ForeignKey, this._description.PrimaryKey).from(this._targetModelDescriptor.TableName, this.Alias);
|
|
93
|
-
this._targetModelDescriptor.Columns.forEach((c) => {
|
|
94
|
-
this._relationQuery.select(c.Name, `${this.Alias}.${c.Name}`);
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
execute(callback) {
|
|
98
|
-
if (callback) {
|
|
99
|
-
callback.call(this._relationQuery, [this]);
|
|
100
|
-
}
|
|
101
|
-
this._query.middleware(new middlewares_js_1.BelongsToRelationRecursiveMiddleware(this._relationQuery, this._description, this._targetModelDescriptor));
|
|
102
|
-
}
|
|
103
|
-
};
|
|
104
|
-
BelongsToRecursiveRelation =
|
|
105
|
-
|
|
106
|
-
(0, di_1.
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
let OneToManyRelation = class OneToManyRelation extends OrmRelation {
|
|
111
|
-
constructor(_container, _query, _description, _parentRelation) {
|
|
112
|
-
super(_container, _query, _description, _parentRelation);
|
|
113
|
-
this._relationQuery.from(this._targetModelDescriptor.TableName, this.Alias);
|
|
114
|
-
this._relationQuery.columns(this._targetModelDescriptor.Columns.map((c) => {
|
|
115
|
-
return c.Name;
|
|
116
|
-
}));
|
|
117
|
-
}
|
|
118
|
-
execute(callback) {
|
|
119
|
-
if (!this.parentRelation && !this._query.TableAlias) {
|
|
120
|
-
this._query.setAlias(`${this._separator}${this._description.SourceModel.name}${this._separator}`);
|
|
121
|
-
}
|
|
122
|
-
if (callback) {
|
|
123
|
-
callback.call(this._relationQuery, [this]);
|
|
124
|
-
}
|
|
125
|
-
this._query.middleware(new middlewares_js_1.DiscriminationMapMiddleware(this._targetModelDescriptor));
|
|
126
|
-
this._query.middleware(new middlewares_js_1.HasManyRelationMiddleware(this._relationQuery, this._description, null));
|
|
127
|
-
}
|
|
128
|
-
};
|
|
129
|
-
OneToManyRelation =
|
|
130
|
-
|
|
131
|
-
(0, di_1.
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
let ManyToManyRelation = class ManyToManyRelation extends OrmRelation {
|
|
136
|
-
get TableJoinQuery() {
|
|
137
|
-
return this._joinQuery;
|
|
138
|
-
}
|
|
139
|
-
get RelationQuery() {
|
|
140
|
-
return this._relationQuery;
|
|
141
|
-
}
|
|
142
|
-
constructor(_container, _orm, _query, _description, _parentRelation) {
|
|
143
|
-
super(_container, _query, _description, _parentRelation);
|
|
144
|
-
this._orm = _orm;
|
|
145
|
-
this._joinModel = this._orm.Models.find((m) => m.name === this._description.JunctionModel?.name)?.type ?? undefined;
|
|
146
|
-
if (this._joinModel === undefined) {
|
|
147
|
-
throw new exceptions_1.InvalidOperation(`model ${this._description.JunctionModel} not exists in orm module`);
|
|
148
|
-
}
|
|
149
|
-
this._joinModelDescriptor = (0, model_js_1.extractModelDescriptor)(this._joinModel);
|
|
150
|
-
const orm = di_1.DI.get(orm_js_1.Orm);
|
|
151
|
-
const driver = orm.Connections.get(this._joinModelDescriptor.Connection);
|
|
152
|
-
const cnt = driver.Container;
|
|
153
|
-
this._joinQuery = cnt.resolve("SelectQueryBuilder", [driver, this._targetModel, this]);
|
|
154
|
-
if (driver.Options.Database) {
|
|
155
|
-
this._joinQuery.database(driver.Options.Database);
|
|
156
|
-
}
|
|
157
|
-
this._joinQuery.from(this._joinModelDescriptor.TableName, `${this._separator}${this._joinModelDescriptor.TableName}${this._separator}`);
|
|
158
|
-
this._joinQuery.columns(this._joinModelDescriptor.Columns.map((c) => {
|
|
159
|
-
return c.Name;
|
|
160
|
-
}));
|
|
161
|
-
this._relationQuery.from(this._targetModelDescriptor.TableName, this.Alias);
|
|
162
|
-
this._targetModelDescriptor.Columns.forEach((c) => {
|
|
163
|
-
this._relationQuery.select(c.Name, `${this.Alias}.${c.Name}`);
|
|
164
|
-
});
|
|
165
|
-
}
|
|
166
|
-
execute(callback) {
|
|
167
|
-
this._joinQuery.leftJoin(this._targetModelDescriptor.TableName, this.Alias, this._description.JunctionModelTargetModelFKey_Name, this._description.ForeignKey, this._targetModelDescriptor.Driver.Options.Database);
|
|
168
|
-
// execute callbacks on join query that is executed
|
|
169
|
-
// for junction model, so we can execute any further queries on it after relation is populated
|
|
170
|
-
if (callback) {
|
|
171
|
-
callback.call(this._relationQuery, [this]);
|
|
172
|
-
}
|
|
173
|
-
const joinRelationDescriptor = {
|
|
174
|
-
Name: this._description.Name,
|
|
175
|
-
Type: interfaces_js_1.RelationType.Many,
|
|
176
|
-
TargetModelType: this._description.JunctionModel,
|
|
177
|
-
TargetModel: this._description.JunctionModel,
|
|
178
|
-
SourceModel: this._description.SourceModel,
|
|
179
|
-
ForeignKey: this._description.JunctionModelSourceModelFKey_Name,
|
|
180
|
-
PrimaryKey: this._description.PrimaryKey,
|
|
181
|
-
Recursive: false,
|
|
182
|
-
};
|
|
183
|
-
// todo fix this cast
|
|
184
|
-
this._joinQuery.mergeBuilder(this._relationQuery);
|
|
185
|
-
this._joinQuery.mergeRelations(this._relationQuery);
|
|
186
|
-
this._query.middleware(new middlewares_js_1.HasManyToManyRelationMiddleware(this._joinQuery, joinRelationDescriptor, this._targetModelDescriptor));
|
|
187
|
-
}
|
|
188
|
-
};
|
|
189
|
-
ManyToManyRelation =
|
|
190
|
-
|
|
191
|
-
(0, di_1.
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var BelongsToRelation_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.ManyToManyRelation = exports.OneToManyRelation = exports.BelongsToRecursiveRelation = exports.BelongsToRelation = exports.OrmRelation = void 0;
|
|
14
|
+
/* eslint-disable prettier/prettier */
|
|
15
|
+
const exceptions_1 = require("@spinajs/exceptions");
|
|
16
|
+
const interfaces_js_1 = require("./interfaces.js");
|
|
17
|
+
const di_1 = require("@spinajs/di");
|
|
18
|
+
const middlewares_js_1 = require("./middlewares.js");
|
|
19
|
+
const model_js_1 = require("./model.js");
|
|
20
|
+
const orm_js_1 = require("./orm.js");
|
|
21
|
+
function _paramCheck(callback, err) {
|
|
22
|
+
const val = callback();
|
|
23
|
+
if (!callback()) {
|
|
24
|
+
throw new Error(err);
|
|
25
|
+
}
|
|
26
|
+
return val;
|
|
27
|
+
}
|
|
28
|
+
let OrmRelation = class OrmRelation {
|
|
29
|
+
get Alias() {
|
|
30
|
+
return this.parentRelation ? `${this.parentRelation.Alias}.${this._separator}${this._description.Name}${this._separator}` : `${this._separator}${this._description.Name}${this._separator}`;
|
|
31
|
+
}
|
|
32
|
+
constructor(_container, _query, _description, parentRelation) {
|
|
33
|
+
this._container = _container;
|
|
34
|
+
this._query = _query;
|
|
35
|
+
this._description = _description;
|
|
36
|
+
this.parentRelation = parentRelation;
|
|
37
|
+
this._targetModel = this._description.TargetModel;
|
|
38
|
+
this._targetModelDescriptor = _paramCheck(() => (0, model_js_1.extractModelDescriptor)(this._targetModel), `Model ${this._targetModel?.name} does not have model descriptor set`);
|
|
39
|
+
this._driver = _paramCheck(() => di_1.DI.resolve("OrmConnection", [this._targetModelDescriptor.Connection]), `Connection ${this._targetModelDescriptor.Connection} is not set in configuration file`);
|
|
40
|
+
this._relationQuery = this._container.resolve("SelectQueryBuilder", [this._driver, this._targetModel, this]);
|
|
41
|
+
this._separator = this._driver.Options.AliasSeparator;
|
|
42
|
+
if (this._driver.Options.Database) {
|
|
43
|
+
this._relationQuery.database(this._driver.Options.Database);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
executeOnQuery(callback) {
|
|
47
|
+
callback.call(this._relationQuery, [this]);
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
exports.OrmRelation = OrmRelation;
|
|
51
|
+
exports.OrmRelation = OrmRelation = __decorate([
|
|
52
|
+
(0, di_1.Inject)(di_1.Container),
|
|
53
|
+
__metadata("design:paramtypes", [di_1.Container, Object, Object, OrmRelation])
|
|
54
|
+
], OrmRelation);
|
|
55
|
+
let BelongsToRelation = BelongsToRelation_1 = class BelongsToRelation extends OrmRelation {
|
|
56
|
+
constructor(_container, _query, _description, _parentRelation) {
|
|
57
|
+
super(_container, _query, _description, _parentRelation);
|
|
58
|
+
this._relationQuery.from(this._targetModelDescriptor.TableName, this.Alias);
|
|
59
|
+
this._targetModelDescriptor.Columns.forEach((c) => {
|
|
60
|
+
this._relationQuery.select(c.Name, `${this.Alias}.${c.Name}`);
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
execute(callback) {
|
|
64
|
+
if (!this.parentRelation && !this._query.TableAlias) {
|
|
65
|
+
this._query.setAlias(`${this._separator}${this._description.SourceModel.name}${this._separator}`);
|
|
66
|
+
}
|
|
67
|
+
this._query.leftJoin(this._targetModelDescriptor.TableName, this.Alias, this._description.ForeignKey, `${this._description.PrimaryKey}`, this._targetModelDescriptor.Driver.Options.Database);
|
|
68
|
+
if (callback) {
|
|
69
|
+
callback.call(this._relationQuery, [this]);
|
|
70
|
+
}
|
|
71
|
+
// todo: fix this cast
|
|
72
|
+
this._query.mergeBuilder(this._relationQuery);
|
|
73
|
+
this._query.middleware(new middlewares_js_1.BelongsToPopulateDataMiddleware(this._description, this));
|
|
74
|
+
if (!this.parentRelation || !(this.parentRelation instanceof BelongsToRelation_1)) {
|
|
75
|
+
// if we are on top of the belongsTo relation stack
|
|
76
|
+
// add transform middleware
|
|
77
|
+
// we do this becouse belongsTo modifies query (not creating new like oneToMany and manyToMany)
|
|
78
|
+
// and we only need to run transform once
|
|
79
|
+
this._query.middleware(new middlewares_js_1.BelongsToRelationResultTransformMiddleware());
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
exports.BelongsToRelation = BelongsToRelation;
|
|
84
|
+
exports.BelongsToRelation = BelongsToRelation = BelongsToRelation_1 = __decorate([
|
|
85
|
+
(0, di_1.NewInstance)(),
|
|
86
|
+
(0, di_1.Inject)(di_1.Container),
|
|
87
|
+
__metadata("design:paramtypes", [di_1.Container, Object, Object, OrmRelation])
|
|
88
|
+
], BelongsToRelation);
|
|
89
|
+
let BelongsToRecursiveRelation = class BelongsToRecursiveRelation extends OrmRelation {
|
|
90
|
+
constructor(_container, _query, _description, _parentRelation) {
|
|
91
|
+
super(_container, _query, _description, _parentRelation);
|
|
92
|
+
this._relationQuery.withRecursive(this._description.ForeignKey, this._description.PrimaryKey).from(this._targetModelDescriptor.TableName, this.Alias);
|
|
93
|
+
this._targetModelDescriptor.Columns.forEach((c) => {
|
|
94
|
+
this._relationQuery.select(c.Name, `${this.Alias}.${c.Name}`);
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
execute(callback) {
|
|
98
|
+
if (callback) {
|
|
99
|
+
callback.call(this._relationQuery, [this]);
|
|
100
|
+
}
|
|
101
|
+
this._query.middleware(new middlewares_js_1.BelongsToRelationRecursiveMiddleware(this._relationQuery, this._description, this._targetModelDescriptor));
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
exports.BelongsToRecursiveRelation = BelongsToRecursiveRelation;
|
|
105
|
+
exports.BelongsToRecursiveRelation = BelongsToRecursiveRelation = __decorate([
|
|
106
|
+
(0, di_1.NewInstance)(),
|
|
107
|
+
(0, di_1.Inject)(di_1.Container),
|
|
108
|
+
__metadata("design:paramtypes", [di_1.Container, Object, Object, OrmRelation])
|
|
109
|
+
], BelongsToRecursiveRelation);
|
|
110
|
+
let OneToManyRelation = class OneToManyRelation extends OrmRelation {
|
|
111
|
+
constructor(_container, _query, _description, _parentRelation) {
|
|
112
|
+
super(_container, _query, _description, _parentRelation);
|
|
113
|
+
this._relationQuery.from(this._targetModelDescriptor.TableName, this.Alias);
|
|
114
|
+
this._relationQuery.columns(this._targetModelDescriptor.Columns.map((c) => {
|
|
115
|
+
return c.Name;
|
|
116
|
+
}));
|
|
117
|
+
}
|
|
118
|
+
execute(callback) {
|
|
119
|
+
if (!this.parentRelation && !this._query.TableAlias) {
|
|
120
|
+
this._query.setAlias(`${this._separator}${this._description.SourceModel.name}${this._separator}`);
|
|
121
|
+
}
|
|
122
|
+
if (callback) {
|
|
123
|
+
callback.call(this._relationQuery, [this]);
|
|
124
|
+
}
|
|
125
|
+
this._query.middleware(new middlewares_js_1.DiscriminationMapMiddleware(this._targetModelDescriptor));
|
|
126
|
+
this._query.middleware(new middlewares_js_1.HasManyRelationMiddleware(this._relationQuery, this._description, null));
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
exports.OneToManyRelation = OneToManyRelation;
|
|
130
|
+
exports.OneToManyRelation = OneToManyRelation = __decorate([
|
|
131
|
+
(0, di_1.NewInstance)(),
|
|
132
|
+
(0, di_1.Inject)(di_1.Container),
|
|
133
|
+
__metadata("design:paramtypes", [di_1.Container, Object, Object, OrmRelation])
|
|
134
|
+
], OneToManyRelation);
|
|
135
|
+
let ManyToManyRelation = class ManyToManyRelation extends OrmRelation {
|
|
136
|
+
get TableJoinQuery() {
|
|
137
|
+
return this._joinQuery;
|
|
138
|
+
}
|
|
139
|
+
get RelationQuery() {
|
|
140
|
+
return this._relationQuery;
|
|
141
|
+
}
|
|
142
|
+
constructor(_container, _orm, _query, _description, _parentRelation) {
|
|
143
|
+
super(_container, _query, _description, _parentRelation);
|
|
144
|
+
this._orm = _orm;
|
|
145
|
+
this._joinModel = this._orm.Models.find((m) => m.name === this._description.JunctionModel?.name)?.type ?? undefined;
|
|
146
|
+
if (this._joinModel === undefined) {
|
|
147
|
+
throw new exceptions_1.InvalidOperation(`model ${this._description.JunctionModel} not exists in orm module`);
|
|
148
|
+
}
|
|
149
|
+
this._joinModelDescriptor = (0, model_js_1.extractModelDescriptor)(this._joinModel);
|
|
150
|
+
const orm = di_1.DI.get(orm_js_1.Orm);
|
|
151
|
+
const driver = orm.Connections.get(this._joinModelDescriptor.Connection);
|
|
152
|
+
const cnt = driver.Container;
|
|
153
|
+
this._joinQuery = cnt.resolve("SelectQueryBuilder", [driver, this._targetModel, this]);
|
|
154
|
+
if (driver.Options.Database) {
|
|
155
|
+
this._joinQuery.database(driver.Options.Database);
|
|
156
|
+
}
|
|
157
|
+
this._joinQuery.from(this._joinModelDescriptor.TableName, `${this._separator}${this._joinModelDescriptor.TableName}${this._separator}`);
|
|
158
|
+
this._joinQuery.columns(this._joinModelDescriptor.Columns.map((c) => {
|
|
159
|
+
return c.Name;
|
|
160
|
+
}));
|
|
161
|
+
this._relationQuery.from(this._targetModelDescriptor.TableName, this.Alias);
|
|
162
|
+
this._targetModelDescriptor.Columns.forEach((c) => {
|
|
163
|
+
this._relationQuery.select(c.Name, `${this.Alias}.${c.Name}`);
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
execute(callback) {
|
|
167
|
+
this._joinQuery.leftJoin(this._targetModelDescriptor.TableName, this.Alias, this._description.JunctionModelTargetModelFKey_Name, this._description.ForeignKey, this._targetModelDescriptor.Driver.Options.Database);
|
|
168
|
+
// execute callbacks on join query that is executed
|
|
169
|
+
// for junction model, so we can execute any further queries on it after relation is populated
|
|
170
|
+
if (callback) {
|
|
171
|
+
callback.call(this._relationQuery, [this]);
|
|
172
|
+
}
|
|
173
|
+
const joinRelationDescriptor = {
|
|
174
|
+
Name: this._description.Name,
|
|
175
|
+
Type: interfaces_js_1.RelationType.Many,
|
|
176
|
+
TargetModelType: this._description.JunctionModel,
|
|
177
|
+
TargetModel: this._description.JunctionModel,
|
|
178
|
+
SourceModel: this._description.SourceModel,
|
|
179
|
+
ForeignKey: this._description.JunctionModelSourceModelFKey_Name,
|
|
180
|
+
PrimaryKey: this._description.PrimaryKey,
|
|
181
|
+
Recursive: false,
|
|
182
|
+
};
|
|
183
|
+
// todo fix this cast
|
|
184
|
+
this._joinQuery.mergeBuilder(this._relationQuery);
|
|
185
|
+
this._joinQuery.mergeRelations(this._relationQuery);
|
|
186
|
+
this._query.middleware(new middlewares_js_1.HasManyToManyRelationMiddleware(this._joinQuery, joinRelationDescriptor, this._targetModelDescriptor));
|
|
187
|
+
}
|
|
188
|
+
};
|
|
189
|
+
exports.ManyToManyRelation = ManyToManyRelation;
|
|
190
|
+
exports.ManyToManyRelation = ManyToManyRelation = __decorate([
|
|
191
|
+
(0, di_1.NewInstance)(),
|
|
192
|
+
(0, di_1.Inject)(di_1.Container, orm_js_1.Orm),
|
|
193
|
+
__metadata("design:paramtypes", [di_1.Container, orm_js_1.Orm, Object, Object, OrmRelation])
|
|
194
|
+
], ManyToManyRelation);
|
|
195
195
|
//# sourceMappingURL=relations.js.map
|
package/lib/cjs/relations.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"relations.js","sourceRoot":"","sources":["../../src/relations.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,sCAAsC;AACtC,oDAAuD;AACvD,mDAA+H;AAC/H,oCAA8E;AAE9E,qDAA8O;AAC9O,yCAA+D;AAC/D,qCAA+B;AAyB/B,SAAS,WAAW,CAAI,QAAiB,EAAE,GAAW;IACpD,MAAM,GAAG,GAAG,QAAQ,EAAE,CAAC;IACvB,IAAI,CAAC,QAAQ,EAAE,EAAE;QACf,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;KACtB;IAED,OAAO,GAAG,CAAC;AACb,CAAC;AAGM,IAAe,WAAW,GAA1B,MAAe,WAAW;IAS/B,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;IAC9L,CAAC;IAED,YAAsB,UAAqB,EAAY,MAA2B,EAAY,YAAiC,EAAS,cAA4B;QAA9I,eAAU,GAAV,UAAU,CAAW;QAAY,WAAM,GAAN,MAAM,CAAqB;QAAY,iBAAY,GAAZ,YAAY,CAAqB;QAAS,mBAAc,GAAd,cAAc,CAAc;QAClK,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;QAClD,IAAI,CAAC,sBAAsB,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAA,iCAAsB,EAAC,IAAI,CAAC,YAAY,CAAC,EAAE,SAAS,IAAI,CAAC,YAAY,EAAE,IAAI,qCAAqC,CAAC,CAAC;QAClK,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,OAAE,CAAC,OAAO,CAAY,eAAe,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAAC,CAAC,EAAE,cAAc,IAAI,CAAC,sBAAsB,CAAC,UAAU,mCAAmC,CAAC,CAAA;QAC3M,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,oBAAoB,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC,CAAC;QAC7G,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC;QAEtD,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE;YACjC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;SAC7D;IACH,CAAC;IAIM,cAAc,CAAC,QAAyE;QAC7F,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAC7C,CAAC;CACF,CAAA;AA9BqB,WAAW;IADhC,IAAA,WAAM,EAAC,cAAS,CAAC;qCAckB,cAAS,kBAA8G,WAAW;GAbhJ,WAAW,CA8BhC;
|
|
1
|
+
{"version":3,"file":"relations.js","sourceRoot":"","sources":["../../src/relations.ts"],"names":[],"mappings":"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"}
|