oak-domain 2.0.2 → 2.1.0
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/actions/action.d.ts +16 -16
- package/lib/actions/action.js +17 -17
- package/lib/actions/relation.d.ts +1 -1
- package/lib/actions/relation.js +2 -2
- package/lib/base-app-domain/ActionDefDict.d.ts +5 -5
- package/lib/base-app-domain/ActionDefDict.js +7 -7
- package/lib/base-app-domain/EntityDict.d.ts +12 -12
- package/lib/base-app-domain/EntityDict.js +2 -2
- package/lib/base-app-domain/Modi/Action.d.ts +10 -10
- package/lib/base-app-domain/Modi/Action.js +14 -14
- package/lib/base-app-domain/Modi/Schema.d.ts +161 -161
- package/lib/base-app-domain/Modi/Schema.js +2 -2
- package/lib/base-app-domain/Modi/Storage.d.ts +3 -3
- package/lib/base-app-domain/Modi/Storage.js +60 -60
- package/lib/base-app-domain/ModiEntity/Schema.d.ts +176 -176
- package/lib/base-app-domain/ModiEntity/Schema.js +2 -2
- package/lib/base-app-domain/ModiEntity/Storage.d.ts +3 -3
- package/lib/base-app-domain/ModiEntity/Storage.js +26 -26
- package/lib/base-app-domain/Oper/Schema.d.ts +158 -158
- package/lib/base-app-domain/Oper/Schema.js +2 -2
- package/lib/base-app-domain/Oper/Storage.d.ts +3 -3
- package/lib/base-app-domain/Oper/Storage.js +29 -29
- package/lib/base-app-domain/OperEntity/Schema.d.ts +193 -193
- package/lib/base-app-domain/OperEntity/Schema.js +2 -2
- package/lib/base-app-domain/OperEntity/Storage.d.ts +3 -3
- package/lib/base-app-domain/OperEntity/Storage.js +26 -26
- package/lib/base-app-domain/Storage.d.ts +3 -3
- package/lib/base-app-domain/Storage.js +15 -15
- package/lib/base-app-domain/User/Schema.d.ts +137 -137
- package/lib/base-app-domain/User/Schema.js +2 -2
- package/lib/base-app-domain/User/Storage.d.ts +3 -3
- package/lib/base-app-domain/User/Storage.js +25 -25
- package/lib/base-app-domain/_SubQuery.d.ts +36 -36
- package/lib/base-app-domain/_SubQuery.js +2 -2
- package/lib/base-app-domain/index.d.ts +3 -3
- package/lib/base-app-domain/index.js +6 -6
- package/lib/checkers/index.d.ts +5 -5
- package/lib/checkers/index.js +8 -8
- package/lib/compiler/env.d.ts +11 -11
- package/lib/compiler/env.js +39 -39
- package/lib/compiler/schemalBuilder.d.ts +2 -2
- package/lib/compiler/schemalBuilder.js +3137 -3137
- package/lib/compiler/uiBuilder.d.ts +1 -1
- package/lib/compiler/uiBuilder.js +3 -3
- package/lib/entities/Modi.d.ts +11 -11
- package/lib/entities/Modi.js +46 -46
- package/lib/entities/ModiEntity.d.ts +8 -8
- package/lib/entities/ModiEntity.js +15 -15
- package/lib/entities/Oper.d.ts +10 -10
- package/lib/entities/Oper.js +17 -17
- package/lib/entities/OperEntity.d.ts +8 -8
- package/lib/entities/OperEntity.js +15 -15
- package/lib/entities/User.d.ts +7 -7
- package/lib/entities/User.js +12 -12
- package/lib/store/AsyncRowStore.d.ts +45 -45
- package/lib/store/AsyncRowStore.js +180 -180
- package/lib/store/CascadeStore.d.ts +89 -89
- package/lib/store/CascadeStore.js +1515 -1511
- package/lib/store/SyncRowStore.d.ts +26 -26
- package/lib/store/SyncRowStore.js +45 -45
- package/lib/store/TriggerExecutor.d.ts +32 -32
- package/lib/store/TriggerExecutor.js +470 -470
- package/lib/store/actionDef.d.ts +9 -9
- package/lib/store/actionDef.js +135 -135
- package/lib/store/checker.d.ts +6 -6
- package/lib/store/checker.js +218 -165
- package/lib/store/filter.d.ts +99 -99
- package/lib/store/filter.js +855 -855
- package/lib/store/modi.d.ts +13 -13
- package/lib/store/modi.js +172 -172
- package/lib/store/relation.d.ts +13 -13
- package/lib/store/relation.js +64 -64
- package/lib/store/selection.d.ts +7 -7
- package/lib/store/selection.js +228 -228
- package/lib/triggers/index.d.ts +6 -6
- package/lib/triggers/index.js +11 -11
- package/lib/triggers/modi.d.ts +5 -5
- package/lib/triggers/modi.js +72 -72
- package/lib/types/Action.d.ts +14 -14
- package/lib/types/Action.js +2 -2
- package/lib/types/AppLoader.d.ts +11 -11
- package/lib/types/AppLoader.js +10 -10
- package/lib/types/Aspect.d.ts +12 -12
- package/lib/types/Aspect.js +4 -4
- package/lib/types/Auth.d.ts +57 -31
- package/lib/types/Auth.js +2 -2
- package/lib/types/Connector.d.ts +26 -26
- package/lib/types/Connector.js +9 -9
- package/lib/types/Context.d.ts +6 -6
- package/lib/types/Context.js +3 -3
- package/lib/types/DataType.d.ts +18 -18
- package/lib/types/DataType.js +5 -5
- package/lib/types/Demand.d.ts +77 -77
- package/lib/types/Demand.js +9 -9
- package/lib/types/Entity.d.ts +159 -159
- package/lib/types/Entity.js +15 -15
- package/lib/types/Exception.d.ts +83 -83
- package/lib/types/Exception.js +252 -252
- package/lib/types/Expression.d.ts +141 -141
- package/lib/types/Expression.js +387 -387
- package/lib/types/Geo.d.ts +18 -18
- package/lib/types/Geo.js +2 -2
- package/lib/types/Locale.d.ts +24 -24
- package/lib/types/Locale.js +2 -2
- package/lib/types/Logger.d.ts +5 -5
- package/lib/types/Logger.js +3 -3
- package/lib/types/Polyfill.d.ts +23 -23
- package/lib/types/Polyfill.js +2 -2
- package/lib/types/RowStore.d.ts +12 -12
- package/lib/types/RowStore.js +34 -34
- package/lib/types/Storage.d.ts +55 -55
- package/lib/types/Storage.js +2 -2
- package/lib/types/Trigger.d.ts +88 -89
- package/lib/types/Trigger.js +39 -39
- package/lib/types/Txn.d.ts +2 -2
- package/lib/types/Txn.js +3 -3
- package/lib/types/Watcher.d.ts +19 -19
- package/lib/types/Watcher.js +4 -4
- package/lib/types/index.d.ts +18 -18
- package/lib/types/index.js +21 -21
- package/lib/types/schema/DataTypes.d.ts +32 -32
- package/lib/types/schema/DataTypes.js +3 -3
- package/lib/utils/SimpleConnector.d.ts +30 -30
- package/lib/utils/SimpleConnector.js +102 -102
- package/lib/utils/assert.d.ts +5 -5
- package/lib/utils/assert.js +9 -9
- package/lib/utils/concurrent.d.ts +15 -15
- package/lib/utils/concurrent.js +89 -89
- package/lib/utils/geo.d.ts +4 -4
- package/lib/utils/geo.js +24 -24
- package/lib/utils/lodash.d.ts +5 -5
- package/lib/utils/lodash.js +38 -38
- package/lib/utils/random/random.d.ts +1 -1
- package/lib/utils/random/random.js +24 -24
- package/lib/utils/random/random.mp.d.ts +1 -1
- package/lib/utils/random/random.mp.js +25 -25
- package/lib/utils/random/random.web.d.ts +1 -1
- package/lib/utils/random/random.web.js +17 -17
- package/lib/utils/string.d.ts +22 -22
- package/lib/utils/string.js +70 -70
- package/lib/utils/uuid.d.ts +12 -12
- package/lib/utils/uuid.js +182 -182
- package/lib/utils/validator.d.ts +23 -23
- package/lib/utils/validator.js +123 -123
- package/package.json +47 -47
- package/src/entities/Modi.ts +68 -68
- package/src/entities/ModiEntity.ts +24 -24
- package/src/entities/Oper.ts +28 -28
- package/src/entities/OperEntity.ts +24 -24
- package/src/entities/User.ts +19 -19
|
@@ -1,180 +1,180 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AsyncContext = void 0;
|
|
4
|
-
var tslib_1 = require("tslib");
|
|
5
|
-
var assert_1 = tslib_1.__importDefault(require("assert"));
|
|
6
|
-
var AsyncContext = /** @class */ (function () {
|
|
7
|
-
function AsyncContext(store, headers) {
|
|
8
|
-
this.rowStore = store;
|
|
9
|
-
this.opRecords = [];
|
|
10
|
-
this.events = {
|
|
11
|
-
commit: [],
|
|
12
|
-
rollback: [],
|
|
13
|
-
};
|
|
14
|
-
if (headers) {
|
|
15
|
-
this.headers = headers;
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
AsyncContext.prototype.setHeaders = function (headers) {
|
|
19
|
-
this.headers = headers;
|
|
20
|
-
};
|
|
21
|
-
AsyncContext.prototype.getHeader = function (key) {
|
|
22
|
-
if (this.headers) {
|
|
23
|
-
return this.headers[key];
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
AsyncContext.prototype.getScene = function () {
|
|
27
|
-
return this.scene;
|
|
28
|
-
};
|
|
29
|
-
AsyncContext.prototype.setScene = function (scene) {
|
|
30
|
-
this.scene = scene;
|
|
31
|
-
};
|
|
32
|
-
AsyncContext.prototype.resetEvents = function () {
|
|
33
|
-
this.events = {
|
|
34
|
-
commit: [],
|
|
35
|
-
rollback: [],
|
|
36
|
-
};
|
|
37
|
-
};
|
|
38
|
-
AsyncContext.prototype.on = function (event, callback) {
|
|
39
|
-
this.uuid && this.events[event].push(callback);
|
|
40
|
-
};
|
|
41
|
-
/**
|
|
42
|
-
* 一个context中不应该有并发的事务,这里将事务串行化,使用的时候千万要注意不要自己等自己
|
|
43
|
-
* @param options
|
|
44
|
-
*/
|
|
45
|
-
AsyncContext.prototype.begin = function (options) {
|
|
46
|
-
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
47
|
-
var _a;
|
|
48
|
-
return tslib_1.__generator(this, function (_b) {
|
|
49
|
-
switch (_b.label) {
|
|
50
|
-
case 0:
|
|
51
|
-
if (!!this.uuid) return [3 /*break*/, 2];
|
|
52
|
-
_a = this;
|
|
53
|
-
return [4 /*yield*/, this.rowStore.begin(options)];
|
|
54
|
-
case 1:
|
|
55
|
-
_a.uuid = _b.sent();
|
|
56
|
-
return [3 /*break*/, 3];
|
|
57
|
-
case 2:
|
|
58
|
-
(0, assert_1.default)(false);
|
|
59
|
-
_b.label = 3;
|
|
60
|
-
case 3: return [2 /*return*/];
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
});
|
|
64
|
-
};
|
|
65
|
-
AsyncContext.prototype.commit = function () {
|
|
66
|
-
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
67
|
-
var _a, _b, e, e_1_1;
|
|
68
|
-
var e_1, _c;
|
|
69
|
-
return tslib_1.__generator(this, function (_d) {
|
|
70
|
-
switch (_d.label) {
|
|
71
|
-
case 0:
|
|
72
|
-
if (!this.uuid) return [3 /*break*/, 10];
|
|
73
|
-
return [4 /*yield*/, this.rowStore.commit(this.uuid)];
|
|
74
|
-
case 1:
|
|
75
|
-
_d.sent();
|
|
76
|
-
this.uuid = undefined;
|
|
77
|
-
_d.label = 2;
|
|
78
|
-
case 2:
|
|
79
|
-
_d.trys.push([2, 7, 8, 9]);
|
|
80
|
-
_a = tslib_1.__values(this.events.commit), _b = _a.next();
|
|
81
|
-
_d.label = 3;
|
|
82
|
-
case 3:
|
|
83
|
-
if (!!_b.done) return [3 /*break*/, 6];
|
|
84
|
-
e = _b.value;
|
|
85
|
-
return [4 /*yield*/, e()];
|
|
86
|
-
case 4:
|
|
87
|
-
_d.sent();
|
|
88
|
-
_d.label = 5;
|
|
89
|
-
case 5:
|
|
90
|
-
_b = _a.next();
|
|
91
|
-
return [3 /*break*/, 3];
|
|
92
|
-
case 6: return [3 /*break*/, 9];
|
|
93
|
-
case 7:
|
|
94
|
-
e_1_1 = _d.sent();
|
|
95
|
-
e_1 = { error: e_1_1 };
|
|
96
|
-
return [3 /*break*/, 9];
|
|
97
|
-
case 8:
|
|
98
|
-
try {
|
|
99
|
-
if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
|
|
100
|
-
}
|
|
101
|
-
finally { if (e_1) throw e_1.error; }
|
|
102
|
-
return [7 /*endfinally*/];
|
|
103
|
-
case 9:
|
|
104
|
-
this.resetEvents();
|
|
105
|
-
_d.label = 10;
|
|
106
|
-
case 10: return [2 /*return*/];
|
|
107
|
-
}
|
|
108
|
-
});
|
|
109
|
-
});
|
|
110
|
-
};
|
|
111
|
-
AsyncContext.prototype.rollback = function () {
|
|
112
|
-
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
113
|
-
var _a, _b, e, e_2_1;
|
|
114
|
-
var e_2, _c;
|
|
115
|
-
return tslib_1.__generator(this, function (_d) {
|
|
116
|
-
switch (_d.label) {
|
|
117
|
-
case 0:
|
|
118
|
-
if (!this.uuid) return [3 /*break*/, 10];
|
|
119
|
-
return [4 /*yield*/, this.rowStore.rollback(this.uuid)];
|
|
120
|
-
case 1:
|
|
121
|
-
_d.sent();
|
|
122
|
-
// console.log('rollback', this.uuid);
|
|
123
|
-
this.uuid = undefined;
|
|
124
|
-
_d.label = 2;
|
|
125
|
-
case 2:
|
|
126
|
-
_d.trys.push([2, 7, 8, 9]);
|
|
127
|
-
_a = tslib_1.__values(this.events.rollback), _b = _a.next();
|
|
128
|
-
_d.label = 3;
|
|
129
|
-
case 3:
|
|
130
|
-
if (!!_b.done) return [3 /*break*/, 6];
|
|
131
|
-
e = _b.value;
|
|
132
|
-
return [4 /*yield*/, e()];
|
|
133
|
-
case 4:
|
|
134
|
-
_d.sent();
|
|
135
|
-
_d.label = 5;
|
|
136
|
-
case 5:
|
|
137
|
-
_b = _a.next();
|
|
138
|
-
return [3 /*break*/, 3];
|
|
139
|
-
case 6: return [3 /*break*/, 9];
|
|
140
|
-
case 7:
|
|
141
|
-
e_2_1 = _d.sent();
|
|
142
|
-
e_2 = { error: e_2_1 };
|
|
143
|
-
return [3 /*break*/, 9];
|
|
144
|
-
case 8:
|
|
145
|
-
try {
|
|
146
|
-
if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
|
|
147
|
-
}
|
|
148
|
-
finally { if (e_2) throw e_2.error; }
|
|
149
|
-
return [7 /*endfinally*/];
|
|
150
|
-
case 9:
|
|
151
|
-
this.resetEvents();
|
|
152
|
-
_d.label = 10;
|
|
153
|
-
case 10: return [2 /*return*/];
|
|
154
|
-
}
|
|
155
|
-
});
|
|
156
|
-
});
|
|
157
|
-
};
|
|
158
|
-
AsyncContext.prototype.operate = function (entity, operation, option) {
|
|
159
|
-
return this.rowStore.operate(entity, operation, this, option);
|
|
160
|
-
};
|
|
161
|
-
AsyncContext.prototype.select = function (entity, selection, option) {
|
|
162
|
-
return this.rowStore.select(entity, selection, this, option);
|
|
163
|
-
};
|
|
164
|
-
AsyncContext.prototype.count = function (entity, selection, option) {
|
|
165
|
-
return this.rowStore.count(entity, selection, this, option);
|
|
166
|
-
};
|
|
167
|
-
AsyncContext.prototype.mergeMultipleResults = function (toBeMerged) {
|
|
168
|
-
return this.rowStore.mergeMultipleResults(toBeMerged);
|
|
169
|
-
};
|
|
170
|
-
AsyncContext.prototype.getCurrentTxnId = function () {
|
|
171
|
-
return this.uuid;
|
|
172
|
-
};
|
|
173
|
-
AsyncContext.prototype.getSchema = function () {
|
|
174
|
-
return this.rowStore.getSchema();
|
|
175
|
-
};
|
|
176
|
-
return AsyncContext;
|
|
177
|
-
}());
|
|
178
|
-
exports.AsyncContext = AsyncContext;
|
|
179
|
-
;
|
|
180
|
-
;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AsyncContext = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
var assert_1 = tslib_1.__importDefault(require("assert"));
|
|
6
|
+
var AsyncContext = /** @class */ (function () {
|
|
7
|
+
function AsyncContext(store, headers) {
|
|
8
|
+
this.rowStore = store;
|
|
9
|
+
this.opRecords = [];
|
|
10
|
+
this.events = {
|
|
11
|
+
commit: [],
|
|
12
|
+
rollback: [],
|
|
13
|
+
};
|
|
14
|
+
if (headers) {
|
|
15
|
+
this.headers = headers;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
AsyncContext.prototype.setHeaders = function (headers) {
|
|
19
|
+
this.headers = headers;
|
|
20
|
+
};
|
|
21
|
+
AsyncContext.prototype.getHeader = function (key) {
|
|
22
|
+
if (this.headers) {
|
|
23
|
+
return this.headers[key];
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
AsyncContext.prototype.getScene = function () {
|
|
27
|
+
return this.scene;
|
|
28
|
+
};
|
|
29
|
+
AsyncContext.prototype.setScene = function (scene) {
|
|
30
|
+
this.scene = scene;
|
|
31
|
+
};
|
|
32
|
+
AsyncContext.prototype.resetEvents = function () {
|
|
33
|
+
this.events = {
|
|
34
|
+
commit: [],
|
|
35
|
+
rollback: [],
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
AsyncContext.prototype.on = function (event, callback) {
|
|
39
|
+
this.uuid && this.events[event].push(callback);
|
|
40
|
+
};
|
|
41
|
+
/**
|
|
42
|
+
* 一个context中不应该有并发的事务,这里将事务串行化,使用的时候千万要注意不要自己等自己
|
|
43
|
+
* @param options
|
|
44
|
+
*/
|
|
45
|
+
AsyncContext.prototype.begin = function (options) {
|
|
46
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
47
|
+
var _a;
|
|
48
|
+
return tslib_1.__generator(this, function (_b) {
|
|
49
|
+
switch (_b.label) {
|
|
50
|
+
case 0:
|
|
51
|
+
if (!!this.uuid) return [3 /*break*/, 2];
|
|
52
|
+
_a = this;
|
|
53
|
+
return [4 /*yield*/, this.rowStore.begin(options)];
|
|
54
|
+
case 1:
|
|
55
|
+
_a.uuid = _b.sent();
|
|
56
|
+
return [3 /*break*/, 3];
|
|
57
|
+
case 2:
|
|
58
|
+
(0, assert_1.default)(false);
|
|
59
|
+
_b.label = 3;
|
|
60
|
+
case 3: return [2 /*return*/];
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
};
|
|
65
|
+
AsyncContext.prototype.commit = function () {
|
|
66
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
67
|
+
var _a, _b, e, e_1_1;
|
|
68
|
+
var e_1, _c;
|
|
69
|
+
return tslib_1.__generator(this, function (_d) {
|
|
70
|
+
switch (_d.label) {
|
|
71
|
+
case 0:
|
|
72
|
+
if (!this.uuid) return [3 /*break*/, 10];
|
|
73
|
+
return [4 /*yield*/, this.rowStore.commit(this.uuid)];
|
|
74
|
+
case 1:
|
|
75
|
+
_d.sent();
|
|
76
|
+
this.uuid = undefined;
|
|
77
|
+
_d.label = 2;
|
|
78
|
+
case 2:
|
|
79
|
+
_d.trys.push([2, 7, 8, 9]);
|
|
80
|
+
_a = tslib_1.__values(this.events.commit), _b = _a.next();
|
|
81
|
+
_d.label = 3;
|
|
82
|
+
case 3:
|
|
83
|
+
if (!!_b.done) return [3 /*break*/, 6];
|
|
84
|
+
e = _b.value;
|
|
85
|
+
return [4 /*yield*/, e()];
|
|
86
|
+
case 4:
|
|
87
|
+
_d.sent();
|
|
88
|
+
_d.label = 5;
|
|
89
|
+
case 5:
|
|
90
|
+
_b = _a.next();
|
|
91
|
+
return [3 /*break*/, 3];
|
|
92
|
+
case 6: return [3 /*break*/, 9];
|
|
93
|
+
case 7:
|
|
94
|
+
e_1_1 = _d.sent();
|
|
95
|
+
e_1 = { error: e_1_1 };
|
|
96
|
+
return [3 /*break*/, 9];
|
|
97
|
+
case 8:
|
|
98
|
+
try {
|
|
99
|
+
if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
|
|
100
|
+
}
|
|
101
|
+
finally { if (e_1) throw e_1.error; }
|
|
102
|
+
return [7 /*endfinally*/];
|
|
103
|
+
case 9:
|
|
104
|
+
this.resetEvents();
|
|
105
|
+
_d.label = 10;
|
|
106
|
+
case 10: return [2 /*return*/];
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
};
|
|
111
|
+
AsyncContext.prototype.rollback = function () {
|
|
112
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
113
|
+
var _a, _b, e, e_2_1;
|
|
114
|
+
var e_2, _c;
|
|
115
|
+
return tslib_1.__generator(this, function (_d) {
|
|
116
|
+
switch (_d.label) {
|
|
117
|
+
case 0:
|
|
118
|
+
if (!this.uuid) return [3 /*break*/, 10];
|
|
119
|
+
return [4 /*yield*/, this.rowStore.rollback(this.uuid)];
|
|
120
|
+
case 1:
|
|
121
|
+
_d.sent();
|
|
122
|
+
// console.log('rollback', this.uuid);
|
|
123
|
+
this.uuid = undefined;
|
|
124
|
+
_d.label = 2;
|
|
125
|
+
case 2:
|
|
126
|
+
_d.trys.push([2, 7, 8, 9]);
|
|
127
|
+
_a = tslib_1.__values(this.events.rollback), _b = _a.next();
|
|
128
|
+
_d.label = 3;
|
|
129
|
+
case 3:
|
|
130
|
+
if (!!_b.done) return [3 /*break*/, 6];
|
|
131
|
+
e = _b.value;
|
|
132
|
+
return [4 /*yield*/, e()];
|
|
133
|
+
case 4:
|
|
134
|
+
_d.sent();
|
|
135
|
+
_d.label = 5;
|
|
136
|
+
case 5:
|
|
137
|
+
_b = _a.next();
|
|
138
|
+
return [3 /*break*/, 3];
|
|
139
|
+
case 6: return [3 /*break*/, 9];
|
|
140
|
+
case 7:
|
|
141
|
+
e_2_1 = _d.sent();
|
|
142
|
+
e_2 = { error: e_2_1 };
|
|
143
|
+
return [3 /*break*/, 9];
|
|
144
|
+
case 8:
|
|
145
|
+
try {
|
|
146
|
+
if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
|
|
147
|
+
}
|
|
148
|
+
finally { if (e_2) throw e_2.error; }
|
|
149
|
+
return [7 /*endfinally*/];
|
|
150
|
+
case 9:
|
|
151
|
+
this.resetEvents();
|
|
152
|
+
_d.label = 10;
|
|
153
|
+
case 10: return [2 /*return*/];
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
};
|
|
158
|
+
AsyncContext.prototype.operate = function (entity, operation, option) {
|
|
159
|
+
return this.rowStore.operate(entity, operation, this, option);
|
|
160
|
+
};
|
|
161
|
+
AsyncContext.prototype.select = function (entity, selection, option) {
|
|
162
|
+
return this.rowStore.select(entity, selection, this, option);
|
|
163
|
+
};
|
|
164
|
+
AsyncContext.prototype.count = function (entity, selection, option) {
|
|
165
|
+
return this.rowStore.count(entity, selection, this, option);
|
|
166
|
+
};
|
|
167
|
+
AsyncContext.prototype.mergeMultipleResults = function (toBeMerged) {
|
|
168
|
+
return this.rowStore.mergeMultipleResults(toBeMerged);
|
|
169
|
+
};
|
|
170
|
+
AsyncContext.prototype.getCurrentTxnId = function () {
|
|
171
|
+
return this.uuid;
|
|
172
|
+
};
|
|
173
|
+
AsyncContext.prototype.getSchema = function () {
|
|
174
|
+
return this.rowStore.getSchema();
|
|
175
|
+
};
|
|
176
|
+
return AsyncContext;
|
|
177
|
+
}());
|
|
178
|
+
exports.AsyncContext = AsyncContext;
|
|
179
|
+
;
|
|
180
|
+
;
|
|
@@ -1,89 +1,89 @@
|
|
|
1
|
-
import { EntityDict, OperateOption, SelectOption, OperationResult, DeduceFilter } from "../types/Entity";
|
|
2
|
-
import { EntityDict as BaseEntityDict } from '../base-app-domain';
|
|
3
|
-
import { RowStore } from '../types/RowStore';
|
|
4
|
-
import { StorageSchema } from '../types/Storage';
|
|
5
|
-
import { SyncContext } from "./SyncRowStore";
|
|
6
|
-
import { AsyncContext } from "./AsyncRowStore";
|
|
7
|
-
/**这个用来处理级联的select和update,对不同能力的 */
|
|
8
|
-
export declare abstract class CascadeStore<ED extends EntityDict & BaseEntityDict> extends RowStore<ED> {
|
|
9
|
-
constructor(storageSchema: StorageSchema<ED>);
|
|
10
|
-
protected abstract supportManyToOneJoin(): boolean;
|
|
11
|
-
protected abstract supportMultipleCreate(): boolean;
|
|
12
|
-
protected abstract selectAbjointRow<T extends keyof ED, OP extends SelectOption, Cxt extends SyncContext<ED>>(entity: T, selection: ED[T]['Selection'], context: Cxt, option: OP): Partial<ED[T]['Schema']>[];
|
|
13
|
-
protected abstract updateAbjointRow<T extends keyof ED, OP extends OperateOption, Cxt extends SyncContext<ED>>(entity: T, operation: ED[T]['Operation'], context: Cxt, option: OP): number;
|
|
14
|
-
protected abstract selectAbjointRowAsync<T extends keyof ED, OP extends SelectOption, Cxt extends AsyncContext<ED>>(entity: T, selection: ED[T]['Selection'], context: Cxt, option: OP): Promise<Partial<ED[T]['Schema']>[]>;
|
|
15
|
-
protected abstract updateAbjointRowAsync<T extends keyof ED, OP extends OperateOption, Cxt extends AsyncContext<ED>>(entity: T, operation: ED[T]['Create'] | ED[T]['Update'] | ED[T]['Remove'], context: Cxt, option: OP): Promise<number>;
|
|
16
|
-
protected destructCascadeSelect<T extends keyof ED, OP extends SelectOption, Cxt extends SyncContext<ED> | AsyncContext<ED>, R>(entity: T, projection2: ED[T]['Selection']['data'], context: Cxt, cascadeSelect: <T2 extends keyof ED>(entity2: T2, selection: ED[T2]['Selection'], context: Cxt, op: OP) => R, option: OP): {
|
|
17
|
-
projection: ED[T]["Selection"]["data"];
|
|
18
|
-
cascadeSelectionFns: ((result: Partial<ED[T]['Schema']>[]) => Promise<void> | void)[];
|
|
19
|
-
};
|
|
20
|
-
/**
|
|
21
|
-
* 级联更新
|
|
22
|
-
* A --> B
|
|
23
|
-
多对一:A CREATE/B CREATE,B data的主键赋到A的data上
|
|
24
|
-
A CREATE/B UPDATE,B filter的主键来自A的data
|
|
25
|
-
A UPDATE/B CREATE,B data的主键赋到A的data上
|
|
26
|
-
A UPDATE/B UPDATE,B filter的主键来自A的row
|
|
27
|
-
A UPDATE/B REMOVE,B filter的主键来自A的row
|
|
28
|
-
A REMOVE/B UPDATE,B filter的主键来自A的row
|
|
29
|
-
A REMOVE/B REMOVE,B filter的主键来自A的row
|
|
30
|
-
|
|
31
|
-
一对多:A CREATE/B CREATE,A data上的主键赋到B的data上
|
|
32
|
-
A CREATE/B UPDATE,A data上的主键赋到B的data上
|
|
33
|
-
A UPDATE/B CREATE,A filter上的主键赋到B的data上(一定是带主键的filter)
|
|
34
|
-
A UPDATE/B UPDATE,A filter上的主键赋到B的filter上(一定是带主键的filter)
|
|
35
|
-
A UPDATE/B REMOVE,A filter上的主键赋到B的filter上(一定是带主键的filter)
|
|
36
|
-
A REMOVE/B UPDATE,A filter上的主键赋到B的filter上(且B关于A的外键清空)
|
|
37
|
-
A REMOVE/B REMOVE,A filter上的主键赋到B的filter上
|
|
38
|
-
*
|
|
39
|
-
* 延时更新,
|
|
40
|
-
* A(业务级别的申请对象) ---> B(业务级别需要更新的对象)
|
|
41
|
-
* 两者必须通过entity/entityId关联
|
|
42
|
-
* 此时需要把对B的更新记录成一条新插入的Modi对象,并将A上的entity/entityId指向该对象(新生成的Modi对象的id与此operation的id保持一致)
|
|
43
|
-
* @param entity
|
|
44
|
-
* @param action
|
|
45
|
-
* @param data
|
|
46
|
-
* @param context
|
|
47
|
-
* @param option
|
|
48
|
-
* @param result
|
|
49
|
-
* @param filter
|
|
50
|
-
* @returns
|
|
51
|
-
*/
|
|
52
|
-
protected destructCascadeUpdate<T extends keyof ED, Cxt extends SyncContext<ED> | AsyncContext<ED>, OP extends OperateOption, R>(entity: T, action: ED[T]['Action'], data: ED[T]['CreateSingle']['data'] | ED[T]['Update']['data'] | ED[T]['Remove']['data'], context: Cxt, option: OP, cascadeUpdate: <T2 extends keyof ED>(entity: T2, operation: ED[T2]['Operation'], context: Cxt, option: OP) => R, filter?: DeduceFilter<ED[T]['Schema']>): {
|
|
53
|
-
data: Record<string, any>;
|
|
54
|
-
beforeFns: (() => R)[];
|
|
55
|
-
afterFns: (() => R)[];
|
|
56
|
-
};
|
|
57
|
-
protected preProcessDataCreated<T extends keyof ED>(entity: T, data: ED[T]['Create']['data']): void;
|
|
58
|
-
protected preProcessDataUpdated<T extends keyof ED>(data: ED[T]['Update']['data']): void;
|
|
59
|
-
judgeRelation(entity: keyof ED, attr: string): string | 2 | 1 | string[] | 0;
|
|
60
|
-
/**
|
|
61
|
-
* 和具体的update过程无关的例程放在这里,包括对later动作的处理、对oper的记录以及对record的收集等
|
|
62
|
-
* @param entity
|
|
63
|
-
* @param operation
|
|
64
|
-
* @param context
|
|
65
|
-
* @param option
|
|
66
|
-
*/
|
|
67
|
-
private doUpdateSingleRowAsync;
|
|
68
|
-
private doUpdateSingleRow;
|
|
69
|
-
protected cascadeUpdate<T extends keyof ED, Cxt extends SyncContext<ED>, OP extends OperateOption>(entity: T, operation: ED[T]['Operation'], context: Cxt, option: OP): OperationResult<ED>;
|
|
70
|
-
/**
|
|
71
|
-
*
|
|
72
|
-
* @param entity
|
|
73
|
-
* @param operation
|
|
74
|
-
* @param context
|
|
75
|
-
* @param option
|
|
76
|
-
*/
|
|
77
|
-
protected cascadeUpdateAsync<T extends keyof ED, Cxt extends AsyncContext<ED>, OP extends OperateOption>(entity: T, operation: ED[T]['Operation'], context: Cxt, option: OP): Promise<OperationResult<ED>>;
|
|
78
|
-
protected cascadeSelect<T extends keyof ED, OP extends SelectOption, Cxt extends SyncContext<ED>>(entity: T, selection: ED[T]['Selection'], context: Cxt, option: OP): Partial<ED[T]['Schema']>[];
|
|
79
|
-
/**
|
|
80
|
-
* 将一次查询的结果集加入result
|
|
81
|
-
* todo 如果是supportMtoOJoin,这里还要解构(未充分测试)
|
|
82
|
-
* @param entity
|
|
83
|
-
* @param rows
|
|
84
|
-
* @param context
|
|
85
|
-
*/
|
|
86
|
-
private addToResultSelections;
|
|
87
|
-
private addSingleRowToResultSelections;
|
|
88
|
-
protected cascadeSelectAsync<T extends keyof ED, OP extends SelectOption, Cxt extends AsyncContext<ED>>(entity: T, selection: ED[T]['Selection'], context: Cxt, option: OP): Promise<Partial<ED[T]['Schema']>[]>;
|
|
89
|
-
}
|
|
1
|
+
import { EntityDict, OperateOption, SelectOption, OperationResult, DeduceFilter } from "../types/Entity";
|
|
2
|
+
import { EntityDict as BaseEntityDict } from '../base-app-domain';
|
|
3
|
+
import { RowStore } from '../types/RowStore';
|
|
4
|
+
import { StorageSchema } from '../types/Storage';
|
|
5
|
+
import { SyncContext } from "./SyncRowStore";
|
|
6
|
+
import { AsyncContext } from "./AsyncRowStore";
|
|
7
|
+
/**这个用来处理级联的select和update,对不同能力的 */
|
|
8
|
+
export declare abstract class CascadeStore<ED extends EntityDict & BaseEntityDict> extends RowStore<ED> {
|
|
9
|
+
constructor(storageSchema: StorageSchema<ED>);
|
|
10
|
+
protected abstract supportManyToOneJoin(): boolean;
|
|
11
|
+
protected abstract supportMultipleCreate(): boolean;
|
|
12
|
+
protected abstract selectAbjointRow<T extends keyof ED, OP extends SelectOption, Cxt extends SyncContext<ED>>(entity: T, selection: ED[T]['Selection'], context: Cxt, option: OP): Partial<ED[T]['Schema']>[];
|
|
13
|
+
protected abstract updateAbjointRow<T extends keyof ED, OP extends OperateOption, Cxt extends SyncContext<ED>>(entity: T, operation: ED[T]['Operation'], context: Cxt, option: OP): number;
|
|
14
|
+
protected abstract selectAbjointRowAsync<T extends keyof ED, OP extends SelectOption, Cxt extends AsyncContext<ED>>(entity: T, selection: ED[T]['Selection'], context: Cxt, option: OP): Promise<Partial<ED[T]['Schema']>[]>;
|
|
15
|
+
protected abstract updateAbjointRowAsync<T extends keyof ED, OP extends OperateOption, Cxt extends AsyncContext<ED>>(entity: T, operation: ED[T]['Create'] | ED[T]['Update'] | ED[T]['Remove'], context: Cxt, option: OP): Promise<number>;
|
|
16
|
+
protected destructCascadeSelect<T extends keyof ED, OP extends SelectOption, Cxt extends SyncContext<ED> | AsyncContext<ED>, R>(entity: T, projection2: ED[T]['Selection']['data'], context: Cxt, cascadeSelect: <T2 extends keyof ED>(entity2: T2, selection: ED[T2]['Selection'], context: Cxt, op: OP) => R, option: OP): {
|
|
17
|
+
projection: ED[T]["Selection"]["data"];
|
|
18
|
+
cascadeSelectionFns: ((result: Partial<ED[T]['Schema']>[]) => Promise<void> | void)[];
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* 级联更新
|
|
22
|
+
* A --> B
|
|
23
|
+
多对一:A CREATE/B CREATE,B data的主键赋到A的data上
|
|
24
|
+
A CREATE/B UPDATE,B filter的主键来自A的data
|
|
25
|
+
A UPDATE/B CREATE,B data的主键赋到A的data上
|
|
26
|
+
A UPDATE/B UPDATE,B filter的主键来自A的row
|
|
27
|
+
A UPDATE/B REMOVE,B filter的主键来自A的row
|
|
28
|
+
A REMOVE/B UPDATE,B filter的主键来自A的row
|
|
29
|
+
A REMOVE/B REMOVE,B filter的主键来自A的row
|
|
30
|
+
|
|
31
|
+
一对多:A CREATE/B CREATE,A data上的主键赋到B的data上
|
|
32
|
+
A CREATE/B UPDATE,A data上的主键赋到B的data上
|
|
33
|
+
A UPDATE/B CREATE,A filter上的主键赋到B的data上(一定是带主键的filter)
|
|
34
|
+
A UPDATE/B UPDATE,A filter上的主键赋到B的filter上(一定是带主键的filter)
|
|
35
|
+
A UPDATE/B REMOVE,A filter上的主键赋到B的filter上(一定是带主键的filter)
|
|
36
|
+
A REMOVE/B UPDATE,A filter上的主键赋到B的filter上(且B关于A的外键清空)
|
|
37
|
+
A REMOVE/B REMOVE,A filter上的主键赋到B的filter上
|
|
38
|
+
*
|
|
39
|
+
* 延时更新,
|
|
40
|
+
* A(业务级别的申请对象) ---> B(业务级别需要更新的对象)
|
|
41
|
+
* 两者必须通过entity/entityId关联
|
|
42
|
+
* 此时需要把对B的更新记录成一条新插入的Modi对象,并将A上的entity/entityId指向该对象(新生成的Modi对象的id与此operation的id保持一致)
|
|
43
|
+
* @param entity
|
|
44
|
+
* @param action
|
|
45
|
+
* @param data
|
|
46
|
+
* @param context
|
|
47
|
+
* @param option
|
|
48
|
+
* @param result
|
|
49
|
+
* @param filter
|
|
50
|
+
* @returns
|
|
51
|
+
*/
|
|
52
|
+
protected destructCascadeUpdate<T extends keyof ED, Cxt extends SyncContext<ED> | AsyncContext<ED>, OP extends OperateOption, R>(entity: T, action: ED[T]['Action'], data: ED[T]['CreateSingle']['data'] | ED[T]['Update']['data'] | ED[T]['Remove']['data'], context: Cxt, option: OP, cascadeUpdate: <T2 extends keyof ED>(entity: T2, operation: ED[T2]['Operation'], context: Cxt, option: OP) => R, filter?: DeduceFilter<ED[T]['Schema']>): {
|
|
53
|
+
data: Record<string, any>;
|
|
54
|
+
beforeFns: (() => R)[];
|
|
55
|
+
afterFns: (() => R)[];
|
|
56
|
+
};
|
|
57
|
+
protected preProcessDataCreated<T extends keyof ED>(entity: T, data: ED[T]['Create']['data']): void;
|
|
58
|
+
protected preProcessDataUpdated<T extends keyof ED>(data: ED[T]['Update']['data']): void;
|
|
59
|
+
judgeRelation(entity: keyof ED, attr: string): string | 2 | 1 | string[] | 0;
|
|
60
|
+
/**
|
|
61
|
+
* 和具体的update过程无关的例程放在这里,包括对later动作的处理、对oper的记录以及对record的收集等
|
|
62
|
+
* @param entity
|
|
63
|
+
* @param operation
|
|
64
|
+
* @param context
|
|
65
|
+
* @param option
|
|
66
|
+
*/
|
|
67
|
+
private doUpdateSingleRowAsync;
|
|
68
|
+
private doUpdateSingleRow;
|
|
69
|
+
protected cascadeUpdate<T extends keyof ED, Cxt extends SyncContext<ED>, OP extends OperateOption>(entity: T, operation: ED[T]['Operation'], context: Cxt, option: OP): OperationResult<ED>;
|
|
70
|
+
/**
|
|
71
|
+
*
|
|
72
|
+
* @param entity
|
|
73
|
+
* @param operation
|
|
74
|
+
* @param context
|
|
75
|
+
* @param option
|
|
76
|
+
*/
|
|
77
|
+
protected cascadeUpdateAsync<T extends keyof ED, Cxt extends AsyncContext<ED>, OP extends OperateOption>(entity: T, operation: ED[T]['Operation'], context: Cxt, option: OP): Promise<OperationResult<ED>>;
|
|
78
|
+
protected cascadeSelect<T extends keyof ED, OP extends SelectOption, Cxt extends SyncContext<ED>>(entity: T, selection: ED[T]['Selection'], context: Cxt, option: OP): Partial<ED[T]['Schema']>[];
|
|
79
|
+
/**
|
|
80
|
+
* 将一次查询的结果集加入result
|
|
81
|
+
* todo 如果是supportMtoOJoin,这里还要解构(未充分测试)
|
|
82
|
+
* @param entity
|
|
83
|
+
* @param rows
|
|
84
|
+
* @param context
|
|
85
|
+
*/
|
|
86
|
+
private addToResultSelections;
|
|
87
|
+
private addSingleRowToResultSelections;
|
|
88
|
+
protected cascadeSelectAsync<T extends keyof ED, OP extends SelectOption, Cxt extends AsyncContext<ED>>(entity: T, selection: ED[T]['Selection'], context: Cxt, option: OP): Promise<Partial<ED[T]['Schema']>[]>;
|
|
89
|
+
}
|