mongodb-dynamic-api 4.7.0 → 4.9.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/CHANGELOG.md +23 -0
- package/README.md +1 -0
- package/package.json +2 -1
- package/src/guards/base-policies.guard.d.ts +3 -1
- package/src/guards/base-policies.guard.js +2 -2
- package/src/guards/base-policies.guard.js.map +1 -1
- package/src/helpers/mixin-data.helper.d.ts +3 -2
- package/src/helpers/mixin-data.helper.js +2 -1
- package/src/helpers/mixin-data.helper.js.map +1 -1
- package/src/index.d.ts +2 -0
- package/src/index.js +2 -0
- package/src/index.js.map +1 -1
- package/src/interfaces/dynamic-api-ability.interface.d.ts +2 -1
- package/src/interfaces/dynamic-api-cascade-config.interface.d.ts +9 -0
- package/src/interfaces/dynamic-api-cascade-config.interface.js +3 -0
- package/src/interfaces/dynamic-api-cascade-config.interface.js.map +1 -0
- package/src/interfaces/dynamic-api-presence.interface.d.ts +22 -0
- package/src/interfaces/dynamic-api-presence.interface.js +6 -0
- package/src/interfaces/dynamic-api-presence.interface.js.map +1 -0
- package/src/interfaces/dynamic-api-route-config.interface.d.ts +6 -2
- package/src/interfaces/dynamic-api-service-before-save-callback.interface.d.ts +4 -1
- package/src/interfaces/dynamic-api-service-callback.interface.d.ts +26 -1
- package/src/interfaces/index.d.ts +2 -0
- package/src/interfaces/index.js +2 -0
- package/src/interfaces/index.js.map +1 -1
- package/src/mixins/policies-guard.mixin.d.ts +9 -3
- package/src/mixins/policies-guard.mixin.js +5 -2
- package/src/mixins/policies-guard.mixin.js.map +1 -1
- package/src/modules/presence/adapters/in-memory-presence.adapter.d.ts +10 -0
- package/src/modules/presence/adapters/in-memory-presence.adapter.js +64 -0
- package/src/modules/presence/adapters/in-memory-presence.adapter.js.map +1 -0
- package/src/modules/presence/adapters/redis-presence.adapter.d.ts +17 -0
- package/src/modules/presence/adapters/redis-presence.adapter.js +80 -0
- package/src/modules/presence/adapters/redis-presence.adapter.js.map +1 -0
- package/src/modules/presence/index.d.ts +5 -0
- package/src/modules/presence/index.js +22 -0
- package/src/modules/presence/index.js.map +1 -0
- package/src/modules/presence/presence.controller.d.ts +6 -0
- package/src/modules/presence/presence.controller.js +55 -0
- package/src/modules/presence/presence.controller.js.map +1 -0
- package/src/modules/presence/presence.gateway.d.ts +13 -0
- package/src/modules/presence/presence.gateway.js +79 -0
- package/src/modules/presence/presence.gateway.js.map +1 -0
- package/src/modules/presence/presence.module.d.ts +5 -0
- package/src/modules/presence/presence.module.js +50 -0
- package/src/modules/presence/presence.module.js.map +1 -0
- package/src/routes/aggregate/aggregate-controller.mixin.js +2 -2
- package/src/routes/aggregate/aggregate-controller.mixin.js.map +1 -1
- package/src/routes/aggregate/aggregate-gateway.mixin.js +2 -2
- package/src/routes/aggregate/aggregate-gateway.mixin.js.map +1 -1
- package/src/routes/aggregate/aggregate.helper.d.ts +2 -2
- package/src/routes/aggregate/aggregate.helper.js +3 -1
- package/src/routes/aggregate/aggregate.helper.js.map +1 -1
- package/src/routes/aggregate/aggregate.module.js +1 -1
- package/src/routes/aggregate/aggregate.module.js.map +1 -1
- package/src/routes/aggregate/base-aggregate.service.d.ts +3 -1
- package/src/routes/aggregate/base-aggregate.service.js +6 -1
- package/src/routes/aggregate/base-aggregate.service.js.map +1 -1
- package/src/routes/create-many/create-many-gateway.mixin.js +1 -1
- package/src/routes/create-many/create-many-gateway.mixin.js.map +1 -1
- package/src/routes/create-one/create-one-gateway.mixin.js +1 -1
- package/src/routes/create-one/create-one-gateway.mixin.js.map +1 -1
- package/src/routes/delete-many/base-delete-many.service.d.ts +3 -1
- package/src/routes/delete-many/base-delete-many.service.js +22 -9
- package/src/routes/delete-many/base-delete-many.service.js.map +1 -1
- package/src/routes/delete-many/delete-many-gateway.mixin.js +1 -1
- package/src/routes/delete-many/delete-many-gateway.mixin.js.map +1 -1
- package/src/routes/delete-many/delete-many.helper.d.ts +2 -2
- package/src/routes/delete-many/delete-many.helper.js +3 -1
- package/src/routes/delete-many/delete-many.helper.js.map +1 -1
- package/src/routes/delete-many/delete-many.module.js +1 -1
- package/src/routes/delete-many/delete-many.module.js.map +1 -1
- package/src/routes/delete-one/base-delete-one.service.d.ts +4 -1
- package/src/routes/delete-one/base-delete-one.service.js +30 -9
- package/src/routes/delete-one/base-delete-one.service.js.map +1 -1
- package/src/routes/delete-one/delete-one-gateway.mixin.js +1 -1
- package/src/routes/delete-one/delete-one-gateway.mixin.js.map +1 -1
- package/src/routes/delete-one/delete-one.helper.d.ts +2 -2
- package/src/routes/delete-one/delete-one.helper.js +3 -1
- package/src/routes/delete-one/delete-one.helper.js.map +1 -1
- package/src/routes/delete-one/delete-one.module.js +1 -1
- package/src/routes/delete-one/delete-one.module.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js +1 -1
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js +1 -1
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js.map +1 -1
- package/src/routes/get-many/base-get-many.service.d.ts +3 -1
- package/src/routes/get-many/base-get-many.service.js +5 -1
- package/src/routes/get-many/base-get-many.service.js.map +1 -1
- package/src/routes/get-many/get-many-controller.mixin.js +2 -2
- package/src/routes/get-many/get-many-controller.mixin.js.map +1 -1
- package/src/routes/get-many/get-many-gateway.mixin.js +2 -2
- package/src/routes/get-many/get-many-gateway.mixin.js.map +1 -1
- package/src/routes/get-many/get-many.helper.d.ts +2 -2
- package/src/routes/get-many/get-many.helper.js +3 -1
- package/src/routes/get-many/get-many.helper.js.map +1 -1
- package/src/routes/get-many/get-many.module.js +1 -1
- package/src/routes/get-many/get-many.module.js.map +1 -1
- package/src/routes/get-one/get-one-gateway.mixin.js +1 -1
- package/src/routes/get-one/get-one-gateway.mixin.js.map +1 -1
- package/src/routes/replace-one/replace-one-gateway.mixin.js +1 -1
- package/src/routes/replace-one/replace-one-gateway.mixin.js.map +1 -1
- package/src/routes/update-many/update-many-gateway.mixin.js +1 -1
- package/src/routes/update-many/update-many-gateway.mixin.js.map +1 -1
- package/src/routes/update-one/update-one-gateway.mixin.js +1 -1
- package/src/routes/update-one/update-one-gateway.mixin.js.map +1 -1
- package/src/services/base/base.service.d.ts +5 -1
- package/src/services/base/base.service.js +36 -0
- package/src/services/base/base.service.js.map +1 -1
- package/src/version.json +1 -1
- package/test/for-feature/ability-predicate-filter.e2e-spec.d.ts +1 -0
- package/test/for-feature/ability-predicate-filter.e2e-spec.js +106 -0
- package/test/for-feature/ability-predicate-filter.e2e-spec.js.map +1 -0
- package/test/for-feature/cascade-and-before-delete.e2e-spec.d.ts +1 -0
- package/test/for-feature/cascade-and-before-delete.e2e-spec.js +304 -0
- package/test/for-feature/cascade-and-before-delete.e2e-spec.js.map +1 -0
- package/test/for-feature/presence.e2e-spec.d.ts +1 -0
- package/test/for-feature/presence.e2e-spec.js +169 -0
- package/test/for-feature/presence.e2e-spec.js.map +1 -0
- package/test/for-feature/raw-update-callback-methods.e2e-spec.d.ts +1 -0
- package/test/for-feature/raw-update-callback-methods.e2e-spec.js +263 -0
- package/test/for-feature/raw-update-callback-methods.e2e-spec.js.map +1 -0
- package/tsconfig.tsbuildinfo +1 -1
|
@@ -0,0 +1,80 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.RedisPresenceAdapter = exports.DEFAULT_REDIS_PRESENCE_TTL = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const ioredis_1 = require("ioredis");
|
|
15
|
+
exports.DEFAULT_REDIS_PRESENCE_TTL = 60;
|
|
16
|
+
const LUA_SREM_DEL_IF_EMPTY = `
|
|
17
|
+
local removed = redis.call('SREM', KEYS[1], ARGV[1])
|
|
18
|
+
if redis.call('SCARD', KEYS[1]) == 0 then
|
|
19
|
+
redis.call('DEL', KEYS[1])
|
|
20
|
+
end
|
|
21
|
+
return removed
|
|
22
|
+
`;
|
|
23
|
+
let RedisPresenceAdapter = class RedisPresenceAdapter {
|
|
24
|
+
constructor(redisUrlOrClient, ttlSeconds = exports.DEFAULT_REDIS_PRESENCE_TTL) {
|
|
25
|
+
this.redis =
|
|
26
|
+
typeof redisUrlOrClient === 'string'
|
|
27
|
+
? new ioredis_1.default(redisUrlOrClient, { lazyConnect: true })
|
|
28
|
+
: redisUrlOrClient;
|
|
29
|
+
this.ttl = ttlSeconds;
|
|
30
|
+
}
|
|
31
|
+
async onModuleDestroy() {
|
|
32
|
+
await this.redis.quit();
|
|
33
|
+
}
|
|
34
|
+
socketsKey(userId) {
|
|
35
|
+
return `presence:sockets:${userId}`;
|
|
36
|
+
}
|
|
37
|
+
roomKey(roomId) {
|
|
38
|
+
return `presence:room:${roomId}`;
|
|
39
|
+
}
|
|
40
|
+
async setOnline(userId, socketId, room) {
|
|
41
|
+
const sockKey = this.socketsKey(userId);
|
|
42
|
+
await this.redis.sadd(sockKey, socketId);
|
|
43
|
+
await this.redis.expire(sockKey, this.ttl);
|
|
44
|
+
if (room) {
|
|
45
|
+
const rKey = this.roomKey(room);
|
|
46
|
+
await this.redis.sadd(rKey, userId);
|
|
47
|
+
await this.redis.expire(rKey, this.ttl);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async setOffline(userId, socketId) {
|
|
51
|
+
await this.redis.eval(LUA_SREM_DEL_IF_EMPTY, 1, this.socketsKey(userId), socketId);
|
|
52
|
+
const remaining = await this.redis.scard(this.socketsKey(userId));
|
|
53
|
+
if (remaining === 0) {
|
|
54
|
+
const roomKeys = await this.redis.keys('presence:room:*');
|
|
55
|
+
if (roomKeys.length > 0) {
|
|
56
|
+
await Promise.all(roomKeys.map((k) => this.redis.srem(k, userId)));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
async isOnline(userId) {
|
|
61
|
+
const count = await this.redis.scard(this.socketsKey(userId));
|
|
62
|
+
return count > 0;
|
|
63
|
+
}
|
|
64
|
+
async getOnlineUserIds(room) {
|
|
65
|
+
if (!room) {
|
|
66
|
+
const keys = await this.redis.keys('presence:sockets:*');
|
|
67
|
+
return keys.map((k) => k.replace('presence:sockets:', ''));
|
|
68
|
+
}
|
|
69
|
+
return this.redis.smembers(this.roomKey(room));
|
|
70
|
+
}
|
|
71
|
+
async getSocketCount(userId) {
|
|
72
|
+
return this.redis.scard(this.socketsKey(userId));
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
exports.RedisPresenceAdapter = RedisPresenceAdapter;
|
|
76
|
+
exports.RedisPresenceAdapter = RedisPresenceAdapter = __decorate([
|
|
77
|
+
(0, common_1.Injectable)(),
|
|
78
|
+
__metadata("design:paramtypes", [Object, Number])
|
|
79
|
+
], RedisPresenceAdapter);
|
|
80
|
+
//# sourceMappingURL=redis-presence.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis-presence.adapter.js","sourceRoot":"","sources":["../../../../../libs/dynamic-api/src/modules/presence/adapters/redis-presence.adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./adapters/in-memory-presence.adapter"), exports);
|
|
18
|
+
__exportStar(require("./adapters/redis-presence.adapter"), exports);
|
|
19
|
+
__exportStar(require("./presence.controller"), exports);
|
|
20
|
+
__exportStar(require("./presence.gateway"), exports);
|
|
21
|
+
__exportStar(require("./presence.module"), exports);
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/modules/presence/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wEAAsD;AACtD,oEAAkD;AAClD,wDAAsC;AACtC,qDAAmC;AACnC,oDAAkC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
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 __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PresenceController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
18
|
+
const decorators_1 = require("../../decorators");
|
|
19
|
+
const interfaces_1 = require("../../interfaces");
|
|
20
|
+
let PresenceController = class PresenceController {
|
|
21
|
+
constructor(presenceAdapter) {
|
|
22
|
+
this.presenceAdapter = presenceAdapter;
|
|
23
|
+
}
|
|
24
|
+
async getOnlineUsers(room) {
|
|
25
|
+
const onlineUserIds = await this.presenceAdapter.getOnlineUserIds(room);
|
|
26
|
+
return { onlineUserIds };
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
exports.PresenceController = PresenceController;
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, decorators_1.Public)(),
|
|
32
|
+
(0, common_1.Get)(),
|
|
33
|
+
(0, swagger_1.ApiOperation)({ summary: 'Get online user IDs (optionally filtered by room)' }),
|
|
34
|
+
(0, swagger_1.ApiQuery)({ name: 'room', required: false, type: String }),
|
|
35
|
+
(0, swagger_1.ApiOkResponse)({
|
|
36
|
+
description: 'List of online user IDs.',
|
|
37
|
+
schema: {
|
|
38
|
+
type: 'object',
|
|
39
|
+
properties: {
|
|
40
|
+
onlineUserIds: { type: 'array', items: { type: 'string' } },
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
}),
|
|
44
|
+
__param(0, (0, common_1.Query)('room')),
|
|
45
|
+
__metadata("design:type", Function),
|
|
46
|
+
__metadata("design:paramtypes", [String]),
|
|
47
|
+
__metadata("design:returntype", Promise)
|
|
48
|
+
], PresenceController.prototype, "getOnlineUsers", null);
|
|
49
|
+
exports.PresenceController = PresenceController = __decorate([
|
|
50
|
+
(0, swagger_1.ApiTags)('Presence'),
|
|
51
|
+
(0, common_1.Controller)('presence'),
|
|
52
|
+
__param(0, (0, common_1.Inject)(interfaces_1.DYNAMIC_API_PRESENCE_ADAPTER)),
|
|
53
|
+
__metadata("design:paramtypes", [Object])
|
|
54
|
+
], PresenceController);
|
|
55
|
+
//# sourceMappingURL=presence.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"presence.controller.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/modules/presence/presence.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAgE;AAChE,6CAAiF;AACjF,iDAA0C;AAC1C,iDAI0B;AAgBnB,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC7B,YAEmB,eAAgC;QAAhC,oBAAe,GAAf,eAAe,CAAiB;IAChD,CAAC;IAeE,AAAN,KAAK,CAAC,cAAc,CAAgB,IAAa;QAC/C,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACxE,OAAO,EAAE,aAAa,EAAE,CAAC;IAC3B,CAAC;CACF,CAAA;AAvBY,gDAAkB;AAmBvB;IAbL,IAAA,mBAAM,GAAE;IACR,IAAA,YAAG,GAAE;IACL,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,mDAAmD,EAAE,CAAC;IAC9E,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;IACzD,IAAA,uBAAa,EAAC;QACb,WAAW,EAAE,0BAA0B;QACvC,MAAM,EAAE;YACN,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,aAAa,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE;aAC5D;SACF;KACF,CAAC;IACoB,WAAA,IAAA,cAAK,EAAC,MAAM,CAAC,CAAA;;;;wDAGlC;6BAtBU,kBAAkB;IAF9B,IAAA,iBAAO,EAAC,UAAU,CAAC;IACnB,IAAA,mBAAU,EAAC,UAAU,CAAC;IAGlB,WAAA,IAAA,eAAM,EAAC,yCAA4B,CAAC,CAAA;;GAF5B,kBAAkB,CAuB9B"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Server } from 'socket.io';
|
|
2
|
+
import { ExtendedSocket, GatewayOptions, PresenceAdapter } from '../../interfaces';
|
|
3
|
+
import { MongoDBDynamicApiLogger } from '../../logger';
|
|
4
|
+
export declare function createPresenceGateway(options?: GatewayOptions): {
|
|
5
|
+
new (presenceAdapter: PresenceAdapter): {
|
|
6
|
+
readonly logger: MongoDBDynamicApiLogger;
|
|
7
|
+
server: Server;
|
|
8
|
+
readonly presenceAdapter: PresenceAdapter;
|
|
9
|
+
afterInit(server: Server): void;
|
|
10
|
+
onSocketConnection(server: Server, socket: ExtendedSocket): void;
|
|
11
|
+
onSocketDisconnect(server: Server, userId: string, socketId: string): void;
|
|
12
|
+
};
|
|
13
|
+
};
|
|
@@ -0,0 +1,79 @@
|
|
|
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 __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.createPresenceGateway = createPresenceGateway;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const websockets_1 = require("@nestjs/websockets");
|
|
18
|
+
const socket_io_1 = require("socket.io");
|
|
19
|
+
const helpers_1 = require("../../helpers");
|
|
20
|
+
const interfaces_1 = require("../../interfaces");
|
|
21
|
+
const logger_1 = require("../../logger");
|
|
22
|
+
function createPresenceGateway(options = {}) {
|
|
23
|
+
let PresenceGateway = class PresenceGateway {
|
|
24
|
+
constructor(presenceAdapter) {
|
|
25
|
+
this.presenceAdapter = presenceAdapter;
|
|
26
|
+
this.logger = new logger_1.MongoDBDynamicApiLogger('PresenceGateway');
|
|
27
|
+
}
|
|
28
|
+
afterInit(server) {
|
|
29
|
+
server.on('connection', (socket) => {
|
|
30
|
+
this.onSocketConnection(server, socket);
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
onSocketConnection(server, socket) {
|
|
34
|
+
const userId = socket.user?.id;
|
|
35
|
+
if (!userId) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
this.presenceAdapter.setOnline(userId, socket.id).then(() => {
|
|
39
|
+
const payload = { userId };
|
|
40
|
+
server.emit('user:online', payload);
|
|
41
|
+
if (helpers_1.DynamicApiWsConfigStore.debug) {
|
|
42
|
+
this.logger.log(`[Presence] user:online – userId=${userId}, socketId=${socket.id}`);
|
|
43
|
+
}
|
|
44
|
+
socket.on('disconnect', () => {
|
|
45
|
+
this.onSocketDisconnect(server, userId, socket.id);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
onSocketDisconnect(server, userId, socketId) {
|
|
50
|
+
this.presenceAdapter
|
|
51
|
+
.setOffline(userId, socketId)
|
|
52
|
+
.then(() => this.presenceAdapter.getSocketCount(userId))
|
|
53
|
+
.then((count) => {
|
|
54
|
+
if (helpers_1.DynamicApiWsConfigStore.debug) {
|
|
55
|
+
this.logger.log(`[Presence] user:offline – userId=${userId}, socketId=${socketId}, remainingSockets=${count}`);
|
|
56
|
+
}
|
|
57
|
+
if (count === 0) {
|
|
58
|
+
const payload = { userId };
|
|
59
|
+
server.emit('user:offline', payload);
|
|
60
|
+
}
|
|
61
|
+
})
|
|
62
|
+
.catch((err) => {
|
|
63
|
+
const message = err instanceof Error ? err.message : JSON.stringify(err);
|
|
64
|
+
this.logger.error(`[Presence] disconnect handler error: ${message}`);
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
__decorate([
|
|
69
|
+
(0, websockets_1.WebSocketServer)(),
|
|
70
|
+
__metadata("design:type", socket_io_1.Server)
|
|
71
|
+
], PresenceGateway.prototype, "server", void 0);
|
|
72
|
+
PresenceGateway = __decorate([
|
|
73
|
+
(0, websockets_1.WebSocketGateway)(options),
|
|
74
|
+
__param(0, (0, common_1.Inject)(interfaces_1.DYNAMIC_API_PRESENCE_ADAPTER)),
|
|
75
|
+
__metadata("design:paramtypes", [Object])
|
|
76
|
+
], PresenceGateway);
|
|
77
|
+
return PresenceGateway;
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=presence.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"presence.gateway.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/modules/presence/presence.gateway.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,50 @@
|
|
|
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 DynamicApiPresenceModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.DynamicApiPresenceModule = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const interfaces_1 = require("../../interfaces");
|
|
13
|
+
const dynamic_api_module_1 = require("../../dynamic-api.module");
|
|
14
|
+
const in_memory_presence_adapter_1 = require("./adapters/in-memory-presence.adapter");
|
|
15
|
+
const redis_presence_adapter_1 = require("./adapters/redis-presence.adapter");
|
|
16
|
+
const presence_controller_1 = require("./presence.controller");
|
|
17
|
+
const presence_gateway_1 = require("./presence.gateway");
|
|
18
|
+
let DynamicApiPresenceModule = DynamicApiPresenceModule_1 = class DynamicApiPresenceModule {
|
|
19
|
+
static register(options) {
|
|
20
|
+
const { adapter, redisUrl, redisTtlSeconds, enableController = false, } = options;
|
|
21
|
+
if (adapter === 'redis' && !redisUrl) {
|
|
22
|
+
throw new Error('DynamicApiPresenceModule: `redisUrl` is required when adapter is "redis".');
|
|
23
|
+
}
|
|
24
|
+
const adapterInstance = adapter === 'redis'
|
|
25
|
+
? new redis_presence_adapter_1.RedisPresenceAdapter(redisUrl, redisTtlSeconds)
|
|
26
|
+
: new in_memory_presence_adapter_1.InMemoryPresenceAdapter();
|
|
27
|
+
const adapterProvider = {
|
|
28
|
+
provide: interfaces_1.DYNAMIC_API_PRESENCE_ADAPTER,
|
|
29
|
+
useValue: adapterInstance,
|
|
30
|
+
};
|
|
31
|
+
const gatewayOptions = dynamic_api_module_1.DynamicApiModule.state.get('gatewayOptions') ??
|
|
32
|
+
dynamic_api_module_1.DynamicApiModule.state.get('broadcastGatewayOptions') ??
|
|
33
|
+
{};
|
|
34
|
+
const GatewayClass = (0, presence_gateway_1.createPresenceGateway)(gatewayOptions);
|
|
35
|
+
return {
|
|
36
|
+
module: DynamicApiPresenceModule_1,
|
|
37
|
+
providers: [
|
|
38
|
+
adapterProvider,
|
|
39
|
+
{ provide: GatewayClass, useClass: GatewayClass },
|
|
40
|
+
],
|
|
41
|
+
controllers: enableController ? [presence_controller_1.PresenceController] : [],
|
|
42
|
+
exports: [interfaces_1.DYNAMIC_API_PRESENCE_ADAPTER],
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
exports.DynamicApiPresenceModule = DynamicApiPresenceModule;
|
|
47
|
+
exports.DynamicApiPresenceModule = DynamicApiPresenceModule = DynamicApiPresenceModule_1 = __decorate([
|
|
48
|
+
(0, common_1.Module)({})
|
|
49
|
+
], DynamicApiPresenceModule);
|
|
50
|
+
//# sourceMappingURL=presence.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"presence.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/modules/presence/presence.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAuD;AACvD,iDAG0B;AAC1B,iEAA4D;AAC5D,sFAAgF;AAChF,8EAAyE;AACzE,+DAA2D;AAC3D,yDAA2D;AAwBpD,IAAM,wBAAwB,gCAA9B,MAAM,wBAAwB;IACnC,MAAM,CAAC,QAAQ,CAAC,OAAgC;QAC9C,MAAM,EACJ,OAAO,EACP,QAAQ,EACR,eAAe,EACf,gBAAgB,GAAG,KAAK,GACzB,GAAG,OAAO,CAAC;QAEZ,IAAI,OAAO,KAAK,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrC,MAAM,IAAI,KAAK,CACb,2EAA2E,CAC5E,CAAC;QACJ,CAAC;QAED,MAAM,eAAe,GACnB,OAAO,KAAK,OAAO;YACjB,CAAC,CAAC,IAAI,6CAAoB,CAAC,QAAS,EAAE,eAAe,CAAC;YACtD,CAAC,CAAC,IAAI,oDAAuB,EAAE,CAAC;QAEpC,MAAM,eAAe,GAAG;YACtB,OAAO,EAAE,yCAA4B;YACrC,QAAQ,EAAE,eAAe;SAC1B,CAAC;QAEF,MAAM,cAAc,GAClB,qCAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,gBAAgB,CAAC;YAC5C,qCAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,yBAAyB,CAAC;YACrD,EAAE,CAAC;QAEL,MAAM,YAAY,GAAG,IAAA,wCAAqB,EAAC,cAAc,CAAC,CAAC;QAE3D,OAAO;YACL,MAAM,EAAE,0BAAwB;YAChC,SAAS,EAAE;gBACT,eAAe;gBACf,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,YAAY,EAAE;aAClD;YACD,WAAW,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,wCAAkB,CAAC,CAAC,CAAC,CAAC,EAAE;YACzD,OAAO,EAAE,CAAC,yCAA4B,CAAC;SACxC,CAAC;IACJ,CAAC;CACF,CAAA;AA1CY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,wBAAwB,CA0CpC"}
|
|
@@ -21,7 +21,7 @@ const helpers_1 = require("../../helpers");
|
|
|
21
21
|
const mixins_1 = require("../../mixins");
|
|
22
22
|
const aggregate_presenter_mixin_1 = require("./aggregate-presenter.mixin");
|
|
23
23
|
function AggregateControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], isArrayResponse, ...routeConfig }, version) {
|
|
24
|
-
const { routeType, displayedName, description, isPublic, disableCache, abilityPredicate, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
24
|
+
const { routeType, displayedName, description, isPublic, disableCache, abilityPredicate, predicateBehavior, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
25
25
|
if (!dTOs?.query) {
|
|
26
26
|
throw new common_1.BadRequestException('Query DTO is required');
|
|
27
27
|
}
|
|
@@ -43,7 +43,7 @@ function AggregateControllerMixin(entity, controllerOptions, { dTOs, useIntercep
|
|
|
43
43
|
presenter: AggregatePresenter,
|
|
44
44
|
}, isArrayResponse);
|
|
45
45
|
const toPipeline = AggregateQuery.toPipeline;
|
|
46
|
-
class AggregatePoliciesGuard extends (0, mixins_1.RoutePoliciesGuardMixin)(entity, routeType, displayedName, version, abilityPredicate, toPipeline) {
|
|
46
|
+
class AggregatePoliciesGuard extends (0, mixins_1.RoutePoliciesGuardMixin)(entity, routeType, displayedName, version, abilityPredicate, toPipeline, predicateBehavior) {
|
|
47
47
|
}
|
|
48
48
|
class BaseAggregateController {
|
|
49
49
|
constructor(service) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aggregate-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/aggregate-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"aggregate-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/aggregate-controller.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -23,7 +23,7 @@ const helpers_1 = require("../../helpers");
|
|
|
23
23
|
const mixins_1 = require("../../mixins");
|
|
24
24
|
const aggregate_presenter_mixin_1 = require("./aggregate-presenter.mixin");
|
|
25
25
|
function AggregateGatewayMixin(entity, controllerOptions, { dTOs, useInterceptors = [], ...routeConfig }, version) {
|
|
26
|
-
const { routeType, displayedName, isPublic, event, abilityPredicate, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig, true);
|
|
26
|
+
const { routeType, displayedName, isPublic, event, abilityPredicate, predicateBehavior, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig, true);
|
|
27
27
|
if (!dTOs?.query) {
|
|
28
28
|
throw new websockets_1.WsException('Query DTO is required');
|
|
29
29
|
}
|
|
@@ -41,7 +41,7 @@ function AggregateGatewayMixin(entity, controllerOptions, { dTOs, useInterceptor
|
|
|
41
41
|
: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Response`,
|
|
42
42
|
writable: false,
|
|
43
43
|
});
|
|
44
|
-
class AggregatePoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, abilityPredicate, isPublic) {
|
|
44
|
+
class AggregatePoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, { abilityPredicate, isPublic, predicateBehavior }) {
|
|
45
45
|
}
|
|
46
46
|
class BaseAggregateGateway extends gateways_1.BaseGateway {
|
|
47
47
|
constructor(service, jwtService) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aggregate-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/aggregate-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAyHS,sDAAqB;AAzH9B,2CAA8E;AAE9E,mDAAiG;AACjG,yDAAoD;AACpD,2CAA4D;AAC5D,6CAA6C;AAC7C,yCAA8C;AAC9C,2CAA4E;AAS5E,yCAAwD;AAGxD,2EAAsE;AAGtE,SAAS,qBAAqB,CAC5B,MAAoB,EACpB,iBAAsD,EACtD,EAAE,IAAI,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,WAAW,EAAiC,EAC7E,OAAgB;IAEhB,MAAM,EACJ,SAAS,EACT,aAAa,EACb,QAAQ,EACR,KAAK,EACL,gBAAgB,
|
|
1
|
+
{"version":3,"file":"aggregate-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/aggregate-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAyHS,sDAAqB;AAzH9B,2CAA8E;AAE9E,mDAAiG;AACjG,yDAAoD;AACpD,2CAA4D;AAC5D,6CAA6C;AAC7C,yCAA8C;AAC9C,2CAA4E;AAS5E,yCAAwD;AAGxD,2EAAsE;AAGtE,SAAS,qBAAqB,CAC5B,MAAoB,EACpB,iBAAsD,EACtD,EAAE,IAAI,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,WAAW,EAAiC,EAC7E,OAAgB;IAEhB,MAAM,EACJ,SAAS,EACT,aAAa,EACb,QAAQ,EACR,KAAK,EACL,gBAAgB,EAChB,iBAAiB,GAClB,GAAG,IAAA,sBAAY,EACd,MAAM,EACN,iBAAiB,EACjB,WAAW,EACX,IAAI,CACL,CAAC;IAEF,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC;QACjB,MAAM,IAAI,wBAAW,CAAC,uBAAuB,CAAC,CAAC;IACjD,CAAC;IAED,MAAM,aAAc,SAAQ,IAAI,CAAC,KAAK;KAAG;IAEzC,MAAM,CAAC,cAAc,CAAC,aAAa,EAAE,MAAM,EAAE;QAC3C,KAAK,EAAE,GAAG,SAAS,GAAG,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,MAAM;QACrE,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,MAAM,iBAAkB,SAAQ,IAAA,mDAAuB,EAAC,MAAM,EAAE,IAAI,EAAE,SAAS,CAAC;KAAG;IAEnF,MAAM,CAAC,cAAc,CAAC,iBAAiB,EAAE,MAAM,EAAE;QAC/C,KAAK,EAAE,IAAI,EAAE,SAAS;YACpB,CAAC,CAAC,GAAG,SAAS,GAAG,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,UAAU;YACpE,CAAC,CAAC,GAAG,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,UAAU;QAC1D,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,MAAM,sBAAuB,SAAQ,IAAA,iCAAwB,EAC3D,MAAM,EACN,SAAS,EACT,KAAK,EACL,OAAO,EACP,EAAE,gBAAgB,EAAE,QAAQ,EAAE,iBAAiB,EAAE,CAClD;KAAG;IAEJ,MAAM,oBAAqB,SAAQ,sBAAmB;QAOpD,YACqB,OAAiC,EACjC,UAAsB;YAEzC,KAAK,CAAC,UAAU,CAAC,CAAC;YAHC,YAAO,GAAP,OAAO,CAA0B;YACjC,eAAU,GAAV,UAAU,CAAY;YAJxB,WAAM,GAAG,MAAM,CAAC;QAOnC,CAAC;QAMK,AAAN,KAAK,CAAC,SAAS,CACM,OAA+B,EACnC,IAAmB;YAElC,MAAM,UAAU,GACd,aACD,CAAC,UAAU,CAAC;YAEb,IAAI,CAAC,UAAU,EAAE,CAAC;gBAChB,MAAM,IAAI,wBAAW,CAAC,8CAA8C,CAAC,CAAC;YACxE,CAAC;YAED,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,IAAA,mCAAe,EAAC,aAAa,EAAE,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;YAEjI,MAAM,aAAa,GACjB,iBACD,CAAC,aAAa,CAAC;YAEhB,OAAO;gBACL,KAAK;gBACL,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI;aACnE,CAAC;QACJ,CAAC;KACF;IAvBO;QAJL,IAAA,mBAAU,EAAC,IAAI,qCAA2B,EAAE,CAAC;QAC7C,IAAA,kBAAS,EAAC,IAAI,uBAAc,CAAC,QAAQ,CAAC,EAAE,sBAAsB,CAAC;QAC/D,IAAA,wBAAe,EAAC,GAAG,eAAe,CAAC;QACnC,IAAA,6BAAgB,EAAC,KAAK,CAAC;QAErB,WAAA,IAAA,4BAAe,GAAE,CAAA;QACjB,WAAA,IAAA,wBAAW,GAAE,CAAA;;iDAAO,aAAa;;yDAoBnC;IAGH,MAAM,CAAC,cAAc,CAAC,oBAAoB,EAAE,MAAM,EAAE;QAClD,KAAK,EAAE,OAAO,IAAA,qBAAW,EAAC,SAAS,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE;QACzE,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,OAAO,oBAAoB,CAAC;AAC9B,CAAC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, AbilityPredicate, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions, PredicateBehavior } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { AggregateControllerConstructor } from './aggregate-controller.interface';
|
|
5
5
|
import { AggregateGatewayConstructor } from './aggregate-gateway.interface';
|
|
6
|
-
declare function createAggregateServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
6
|
+
declare function createAggregateServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, abilityPredicate?: AbilityPredicate<Entity>, predicateBehavior?: PredicateBehavior): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createAggregateController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): AggregateControllerConstructor<Entity>;
|
|
8
8
|
declare function createAggregateGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): AggregateGatewayConstructor<Entity>;
|
|
9
9
|
export { createAggregateController, createAggregateGateway, createAggregateServiceProvider };
|
|
@@ -27,13 +27,15 @@ const helpers_1 = require("../../helpers");
|
|
|
27
27
|
const base_aggregate_service_1 = require("./base-aggregate.service");
|
|
28
28
|
const aggregate_controller_mixin_1 = require("./aggregate-controller.mixin");
|
|
29
29
|
const aggregate_gateway_mixin_1 = require("./aggregate-gateway.mixin");
|
|
30
|
-
function createAggregateServiceProvider(entity, displayedName, version, callback) {
|
|
30
|
+
function createAggregateServiceProvider(entity, displayedName, version, callback, abilityPredicate, predicateBehavior) {
|
|
31
31
|
let AggregateService = class AggregateService extends base_aggregate_service_1.BaseAggregateService {
|
|
32
32
|
constructor(model) {
|
|
33
33
|
super(model);
|
|
34
34
|
this.model = model;
|
|
35
35
|
this.entity = entity;
|
|
36
36
|
this.callback = callback;
|
|
37
|
+
this.abilityPredicate = abilityPredicate;
|
|
38
|
+
this.predicateBehavior = predicateBehavior;
|
|
37
39
|
}
|
|
38
40
|
};
|
|
39
41
|
AggregateService = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aggregate.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/aggregate.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"aggregate.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/aggregate.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -16,7 +16,7 @@ let AggregateModule = AggregateModule_1 = class AggregateModule {
|
|
|
16
16
|
static forFeature(databaseModule, entity, controllerOptions, routeConfig, version, validationPipeOptions, webSocket, extraImports, extraProviders, extraControllers) {
|
|
17
17
|
const displayedName = (0, helpers_1.getDisplayedName)(controllerOptions.apiTag, entity.name, routeConfig.subPath);
|
|
18
18
|
const controller = (0, aggregate_helper_1.createAggregateController)(entity, displayedName, controllerOptions, routeConfig, version, validationPipeOptions);
|
|
19
|
-
const ServiceProvider = (0, aggregate_helper_1.createAggregateServiceProvider)(entity, displayedName, version, routeConfig.callback);
|
|
19
|
+
const ServiceProvider = (0, aggregate_helper_1.createAggregateServiceProvider)(entity, displayedName, version, routeConfig.callback, routeConfig.abilityPredicate, routeConfig.predicateBehavior);
|
|
20
20
|
const gatewayOptions = webSocket
|
|
21
21
|
? (0, helpers_1.initializeConfigFromOptions)(webSocket)
|
|
22
22
|
: dynamic_api_module_1.DynamicApiModule.state.get('gatewayOptions') ?? null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aggregate.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/aggregate.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,yDAI4B;AAIrB,IAAM,eAAe,uBAArB,MAAM,eAAe;IAC1B,MAAM,CAAC,UAAU,CACf,cAA6B,EAC7B,MAAoB,EACpB,iBAAsD,EACtD,WAA0C,EAC1C,OAAgB,EAChB,qBAA6C,EAC7C,SAAsC,EACtC,YAAwC,EACxC,cAA4C,EAC5C,gBAAgD;QAEhD,MAAM,aAAa,GAAG,IAAA,0BAAgB,EAAC,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;QAEnG,MAAM,UAAU,GAAG,IAAA,4CAAyB,EAC1C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,iDAA8B,
|
|
1
|
+
{"version":3,"file":"aggregate.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/aggregate.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,yDAI4B;AAIrB,IAAM,eAAe,uBAArB,MAAM,eAAe;IAC1B,MAAM,CAAC,UAAU,CACf,cAA6B,EAC7B,MAAoB,EACpB,iBAAsD,EACtD,WAA0C,EAC1C,OAAgB,EAChB,qBAA6C,EAC7C,SAAsC,EACtC,YAAwC,EACxC,cAA4C,EAC5C,gBAAgD;QAEhD,MAAM,aAAa,GAAG,IAAA,0BAAgB,EAAC,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;QAEnG,MAAM,UAAU,GAAG,IAAA,4CAAyB,EAC1C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,iDAA8B,EACpD,MAAM,EACN,aAAa,EACb,OAAO,EACP,WAAW,CAAC,QAAQ,EACpB,WAAW,CAAC,gBAAgB,EAC5B,WAAW,CAAC,iBAAiB,CAC9B,CAAC;QAEF,MAAM,cAAc,GAAG,SAAS;YAC9B,CAAC,CAAC,IAAA,qCAA2B,EAAC,SAAS,CAAC;YACxC,CAAC,CAAC,qCAAgB,CAAC,KAAK,CAAC,GAAG,CAAkB,gBAAgB,CAAC,IAAI,IAAI,CAAC;QAE1E,OAAO;YACL,MAAM,EAAE,iBAAe;YACvB,OAAO,EAAE,CAAC,cAAc,EAAE,GAAG,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;YAClD,WAAW,EAAE,CAAC,UAAU,EAAE,GAAG,CAAC,gBAAgB,IAAI,EAAE,CAAC,CAAC;YACtD,SAAS,EAAE;gBACT,eAAe;gBACf,GAAG,CACD,cAAc,CAAC,CAAC,CAAC;oBACf,IAAA,yCAAsB,EACpB,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,EACrB,cAAc,CACf;iBACF,CAAC,CAAC,CAAC,EAAE,CACP;gBACD,GAAG,CAAC,cAAc,IAAI,EAAE,CAAC;aAC1B;SACF,CAAC;IACJ,CAAC;CACF,CAAA;AA3DY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,eAAe,CA2D3B"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { PipelineStage } from 'mongodb-pipeline-builder';
|
|
3
3
|
import { Model } from 'mongoose';
|
|
4
|
-
import { AfterSaveCallback } from '../../interfaces';
|
|
4
|
+
import { AbilityPredicate, AfterSaveCallback, PredicateBehavior } from '../../interfaces';
|
|
5
5
|
import { BaseEntity } from '../../models';
|
|
6
6
|
import { BaseService } from '../../services';
|
|
7
7
|
import { AggregateService } from './aggregate-service.interface';
|
|
@@ -9,6 +9,8 @@ export declare abstract class BaseAggregateService<Entity extends BaseEntity> ex
|
|
|
9
9
|
protected readonly model: Model<Entity>;
|
|
10
10
|
protected readonly entity: Type<Entity>;
|
|
11
11
|
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
12
|
+
protected readonly abilityPredicate: AbilityPredicate<Entity> | undefined;
|
|
13
|
+
protected readonly predicateBehavior: PredicateBehavior | undefined;
|
|
12
14
|
protected constructor(model: Model<Entity>);
|
|
13
15
|
aggregate(pipeline: PipelineStage[], user?: unknown): Promise<{
|
|
14
16
|
list: Entity[];
|
|
@@ -28,7 +28,12 @@ class BaseAggregateService extends services_1.BaseService {
|
|
|
28
28
|
if (this.callback && documents.length) {
|
|
29
29
|
await Promise.all(documents.map((document) => this.callback(this.addDocumentId(document), this.callbackMethods, user)));
|
|
30
30
|
}
|
|
31
|
-
|
|
31
|
+
const list = documents.map((d) => this.buildInstance(d));
|
|
32
|
+
if (this.predicateBehavior === 'filter' && this.abilityPredicate) {
|
|
33
|
+
const filtered = list.filter((instance) => this.abilityPredicate(instance, user));
|
|
34
|
+
return { list: filtered, count: filtered.length, totalPage };
|
|
35
|
+
}
|
|
36
|
+
return { list, count, totalPage };
|
|
32
37
|
}
|
|
33
38
|
catch (error) {
|
|
34
39
|
this.handleMongoErrors(error, false);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-aggregate.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/base-aggregate.service.ts"],"names":[],"mappings":";;;AACA,uEAAqF;AAIrF,6CAA6C;AAG7C,MAAsB,oBACpB,SAAQ,sBAAmB;
|
|
1
|
+
{"version":3,"file":"base-aggregate.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/aggregate/base-aggregate.service.ts"],"names":[],"mappings":";;;AACA,uEAAqF;AAIrF,6CAA6C;AAG7C,MAAsB,oBACpB,SAAQ,sBAAmB;IAQ3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,QAAyB,EAAE,IAAc;QACvD,IAAI,CAAC;YACH,IAAI,SAAmB,CAAC;YACxB,IAAI,KAAa,CAAC;YAClB,IAAI,SAAiB,CAAC;YAEtB,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAClC,MAAM,YAAY,GAAG,MAAM,IAAA,0CAAe,EAAS,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;gBACzE,SAAS,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC;gBACnC,KAAK,GAAG,YAAY,CAAC,QAAQ,EAAE,CAAC;gBAChC,SAAS,GAAG,YAAY,CAAC,kBAAkB,EAAE,CAAC;YAChD,CAAC;iBAAM,CAAC;gBACN,MAAM,MAAM,GAAG,MAAM,IAAA,oCAAS,EAAS,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;gBAC7D,SAAS,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC;gBAC7B,KAAK,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;gBAC1B,SAAS,GAAG,CAAC,CAAC;YAChB,CAAC;YAED,IAAI,IAAI,CAAC,QAAQ,IAAI,SAAS,CAAC,MAAM,EAAE,CAAC;gBACtC,MAAM,OAAO,CAAC,GAAG,CACf,SAAS,CAAC,GAAG,CACX,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CACtF,CACF,CAAC;YACJ,CAAC;YAED,MAAM,IAAI,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;YAEzD,IAAI,IAAI,CAAC,iBAAiB,KAAK,QAAQ,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACjE,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;gBAClF,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC;YAC/D,CAAC;YAED,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;QACpC,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAEO,cAAc,CAAC,QAAyB;QAC9C,MAAM,eAAe,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;QAC3C,IAAI,CAAC,eAAe,EAAE,CAAC;YACrB,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAC5F,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QAE/F,OAAO,YAAY,IAAI,aAAa,CAAC;IACvC,CAAC;CACF;AAhED,oDAgEC"}
|
|
@@ -38,7 +38,7 @@ function CreateManyGatewayMixin(entity, controllerOptions, { dTOs, useIntercepto
|
|
|
38
38
|
: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Response`,
|
|
39
39
|
writable: false,
|
|
40
40
|
});
|
|
41
|
-
class CreateManyPoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, abilityPredicate, isPublic) {
|
|
41
|
+
class CreateManyPoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, { abilityPredicate, isPublic }) {
|
|
42
42
|
}
|
|
43
43
|
class BaseCreateManyGateway extends gateways_1.BaseGateway {
|
|
44
44
|
constructor(service, jwtService) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-many-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/create-many-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"create-many-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/create-many-gateway.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -36,7 +36,7 @@ function CreateOneGatewayMixin(entity, controllerOptions, { dTOs, useInterceptor
|
|
|
36
36
|
: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Response`,
|
|
37
37
|
writable: false,
|
|
38
38
|
});
|
|
39
|
-
class CreateOnePoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, abilityPredicate, isPublic) {
|
|
39
|
+
class CreateOnePoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, { abilityPredicate, isPublic }) {
|
|
40
40
|
}
|
|
41
41
|
class BaseCreateOneGateway extends gateways_1.BaseGateway {
|
|
42
42
|
constructor(service, jwtService) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-one-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-one/create-one-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"create-one-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-one/create-one-gateway.mixin.ts"],"names":[],"mappings":"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"}
|