@social.dev/server-sdk 0.0.1-alpha.3 → 0.0.1-alpha.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -65
- package/dist/app.module.js +2 -0
- package/dist/app.module.js.map +1 -1
- package/dist/auth/auth.controller.d.ts +2 -0
- package/dist/auth/auth.controller.js +26 -0
- package/dist/auth/auth.controller.js.map +1 -1
- package/dist/auth/auth.module.js +2 -0
- package/dist/auth/auth.module.js.map +1 -1
- package/dist/auth/auth.service.d.ts +4 -8
- package/dist/auth/auth.service.js +6 -18
- package/dist/auth/auth.service.js.map +1 -1
- package/dist/auth/dto/login-success.dto.d.ts +1 -1
- package/dist/auth/dto/login-success.dto.js +3 -3
- package/dist/auth/dto/login-success.dto.js.map +1 -1
- package/dist/auth/enums/auth-method.enum.d.ts +2 -2
- package/dist/auth/enums/auth-method.enum.js +2 -2
- package/dist/auth/enums/auth-method.enum.js.map +1 -1
- package/dist/auth/oidc/dto/requests.d.ts +6 -0
- package/dist/auth/oidc/dto/requests.js +47 -0
- package/dist/auth/oidc/dto/requests.js.map +1 -0
- package/dist/auth/oidc/dto/responses.js +1 -1
- package/dist/auth/oidc/dto/responses.js.map +1 -1
- package/dist/auth/oidc/oidc.controller.d.ts +6 -2
- package/dist/auth/oidc/oidc.controller.js +25 -17
- package/dist/auth/oidc/oidc.controller.js.map +1 -1
- package/dist/auth/oidc/oidc.module.js +2 -0
- package/dist/auth/oidc/oidc.module.js.map +1 -1
- package/dist/auth/oidc/oidc.service.d.ts +13 -7
- package/dist/auth/oidc/oidc.service.js +38 -30
- package/dist/auth/oidc/oidc.service.js.map +1 -1
- package/dist/auth/session/session.controller.js +3 -3
- package/dist/auth/session/session.controller.js.map +1 -1
- package/dist/auth/session/session.service.d.ts +2 -2
- package/dist/auth/session/session.service.js +4 -4
- package/dist/auth/session/session.service.js.map +1 -1
- package/dist/bootstrap.d.ts +2 -1
- package/dist/bootstrap.js +3 -1
- package/dist/bootstrap.js.map +1 -1
- package/dist/chat/chat.controller.d.ts +1 -2
- package/dist/chat/chat.controller.js +8 -4
- package/dist/chat/chat.controller.js.map +1 -1
- package/dist/chat/chat.module.js +2 -0
- package/dist/chat/chat.module.js.map +1 -1
- package/dist/chat/chat.service.d.ts +6 -2
- package/dist/chat/chat.service.js +38 -7
- package/dist/chat/chat.service.js.map +1 -1
- package/dist/common/dto/paginated-response.dto.d.ts +2 -0
- package/dist/common/dto/paginated-response.dto.js +14 -3
- package/dist/common/dto/paginated-response.dto.js.map +1 -1
- package/dist/common/injection-tokens.d.ts +2 -0
- package/dist/common/injection-tokens.js +6 -0
- package/dist/common/injection-tokens.js.map +1 -0
- package/dist/community/community.controller.d.ts +1 -2
- package/dist/community/community.controller.js +9 -5
- package/dist/community/community.controller.js.map +1 -1
- package/dist/community/community.module.js +1 -0
- package/dist/community/community.module.js.map +1 -1
- package/dist/community/community.service.d.ts +10 -3
- package/dist/community/community.service.js +30 -12
- package/dist/community/community.service.js.map +1 -1
- package/dist/configs/configs.module.js +3 -0
- package/dist/configs/configs.module.js.map +1 -1
- package/dist/configs/configs.service.d.ts +20 -0
- package/dist/configs/configs.service.js +14 -1
- package/dist/configs/configs.service.js.map +1 -1
- package/dist/core/context/context.store.d.ts +1 -0
- package/dist/core/hook/hook.module.d.ts +4 -0
- package/dist/core/hook/hook.module.js +30 -0
- package/dist/core/hook/hook.module.js.map +1 -0
- package/dist/core/hook/hook.service.d.ts +7 -0
- package/dist/core/{plugin/plugin-hook.service.js → hook/hook.service.js} +10 -10
- package/dist/core/hook/hook.service.js.map +1 -0
- package/dist/core/plugin/plugin.module.js +7 -5
- package/dist/core/plugin/plugin.module.js.map +1 -1
- package/dist/db.js +1 -1
- package/dist/db.js.map +1 -1
- package/dist/file-storage/file-storage.service.d.ts +1 -1
- package/dist/file-storage/file-storage.service.js +6 -6
- package/dist/file-storage/file-storage.service.js.map +1 -1
- package/dist/file-storage/utils.js +1 -1
- package/dist/file-storage/utils.js.map +1 -1
- package/dist/index.d.ts +0 -1
- package/dist/index.js +1 -3
- package/dist/index.js.map +1 -1
- package/dist/media/entities/media.entity.js +1 -1
- package/dist/media/entities/media.entity.js.map +1 -1
- package/dist/media/media.acl.d.ts +2 -4
- package/dist/media/media.acl.js +3 -0
- package/dist/media/media.acl.js.map +1 -1
- package/dist/media/media.service.js +15 -12
- package/dist/media/media.service.js.map +1 -1
- package/dist/{1756201302119-migrations.d.ts → migrations/1757061785934-PushNotificationTokens.d.ts} +1 -1
- package/dist/migrations/1757061785934-PushNotificationTokens.js +20 -0
- package/dist/migrations/1757061785934-PushNotificationTokens.js.map +1 -0
- package/dist/network/network.middleware.js +6 -2
- package/dist/network/network.middleware.js.map +1 -1
- package/dist/network/network.module.js +2 -1
- package/dist/network/network.module.js.map +1 -1
- package/dist/network/network.service.d.ts +5 -2
- package/dist/network/network.service.js +23 -6
- package/dist/network/network.service.js.map +1 -1
- package/dist/notification/dto/delete-push-token.dto.d.ts +3 -0
- package/dist/{common/entities/base.repository.js → notification/dto/delete-push-token.dto.js} +14 -20
- package/dist/notification/dto/delete-push-token.dto.js.map +1 -0
- package/dist/notification/dto/register-push-token.dto.d.ts +5 -0
- package/dist/notification/dto/register-push-token.dto.js +38 -0
- package/dist/notification/dto/register-push-token.dto.js.map +1 -0
- package/dist/notification/entities/push-token.entity.d.ts +11 -0
- package/dist/notification/entities/push-token.entity.js +60 -0
- package/dist/notification/entities/push-token.entity.js.map +1 -0
- package/dist/notification/enums/push-service.enum.d.ts +6 -0
- package/dist/notification/enums/push-service.enum.js +11 -0
- package/dist/notification/enums/push-service.enum.js.map +1 -0
- package/dist/notification/hook-listener.service.d.ts +13 -0
- package/dist/notification/hook-listener.service.js +58 -0
- package/dist/notification/hook-listener.service.js.map +1 -0
- package/dist/notification/notification.module.d.ts +2 -0
- package/dist/notification/notification.module.js +34 -0
- package/dist/notification/notification.module.js.map +1 -0
- package/dist/notification/push-notification.controller.d.ts +9 -0
- package/dist/notification/push-notification.controller.js +69 -0
- package/dist/notification/push-notification.controller.js.map +1 -0
- package/dist/notification/push-notification.service.d.ts +22 -0
- package/dist/notification/push-notification.service.js +84 -0
- package/dist/notification/push-notification.service.js.map +1 -0
- package/dist/post/post.controller.d.ts +3 -2
- package/dist/post/post.controller.js +28 -8
- package/dist/post/post.controller.js.map +1 -1
- package/dist/post/post.module.js +2 -0
- package/dist/post/post.module.js.map +1 -1
- package/dist/post/post.service.d.ts +7 -3
- package/dist/post/post.service.js +18 -8
- package/dist/post/post.service.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/user/constants.d.ts +1 -0
- package/dist/user/constants.js +5 -0
- package/dist/user/constants.js.map +1 -0
- package/dist/user/user.controller.d.ts +2 -1
- package/dist/user/user.controller.js +9 -4
- package/dist/user/user.controller.js.map +1 -1
- package/dist/user/user.module.js +2 -0
- package/dist/user/user.module.js.map +1 -1
- package/dist/user/user.service.d.ts +3 -1
- package/dist/user/user.service.js +12 -3
- package/dist/user/user.service.js.map +1 -1
- package/package.json +1 -1
- package/dist/1756201302119-migrations.js +0 -84
- package/dist/1756201302119-migrations.js.map +0 -1
- package/dist/auth/enums/auth-methods.enum.d.ts +0 -2
- package/dist/auth/enums/auth-methods.enum.js +0 -7
- package/dist/auth/enums/auth-methods.enum.js.map +0 -1
- package/dist/auth/session/auth.controller.d.ts +0 -10
- package/dist/auth/session/auth.controller.js +0 -92
- package/dist/auth/session/auth.controller.js.map +0 -1
- package/dist/auth/session/auth.service.d.ts +0 -12
- package/dist/auth/session/auth.service.js +0 -46
- package/dist/auth/session/auth.service.js.map +0 -1
- package/dist/common/entities/base.repository.d.ts +0 -7
- package/dist/common/entities/base.repository.js.map +0 -1
- package/dist/core/plugin/plugin-hook.service.d.ts +0 -7
- package/dist/core/plugin/plugin-hook.service.js.map +0 -1
|
@@ -26,7 +26,6 @@ const ffprobe_1 = require("../common/utils/ffprobe");
|
|
|
26
26
|
const fs_1 = require("../common/utils/fs");
|
|
27
27
|
const ffmpeg_1 = require("../common/utils/ffmpeg");
|
|
28
28
|
const utils_1 = require("../file-storage/utils");
|
|
29
|
-
const node_path_1 = __importDefault(require("node:path"));
|
|
30
29
|
const context_1 = require("../core/context/context");
|
|
31
30
|
const acl_factory_1 = require("../core/acl/acl.factory");
|
|
32
31
|
let MediaService = class MediaService {
|
|
@@ -39,7 +38,15 @@ let MediaService = class MediaService {
|
|
|
39
38
|
this.aclFactory = aclFactory;
|
|
40
39
|
}
|
|
41
40
|
async uploadAudioFile(file, owner) {
|
|
42
|
-
|
|
41
|
+
const ownerDir = (0, utils_1.getUserDir)(owner) + 'audio';
|
|
42
|
+
const entity = this.audioRepository.create({
|
|
43
|
+
network: owner.network,
|
|
44
|
+
owner: owner,
|
|
45
|
+
durationSecs: 0,
|
|
46
|
+
sizeBytes: 0,
|
|
47
|
+
});
|
|
48
|
+
const { id } = await this.audioRepository.save(entity);
|
|
49
|
+
await this.fileStorage.putFile(file.buffer, ownerDir + `/${id}/input.mp3`, 'audio/mp3');
|
|
43
50
|
const input = (0, fs_1.tmpFile)() + '.webm';
|
|
44
51
|
const output = (0, fs_1.tmpFile)() + '.mp3';
|
|
45
52
|
try {
|
|
@@ -61,22 +68,18 @@ let MediaService = class MediaService {
|
|
|
61
68
|
console.error(err);
|
|
62
69
|
throw new common_1.InternalServerErrorException(500, 'Unable to convert the uploaded file');
|
|
63
70
|
}
|
|
64
|
-
const ownerDir = node_path_1.default.resolve((0, utils_1.getUserDir)(owner), 'audio');
|
|
65
|
-
const entity = this.audioRepository.create({
|
|
66
|
-
network: owner.network,
|
|
67
|
-
owner: owner,
|
|
68
|
-
durationSecs,
|
|
69
|
-
sizeBytes,
|
|
70
|
-
});
|
|
71
|
-
const { id } = await this.audioRepository.save(entity);
|
|
72
71
|
try {
|
|
73
|
-
this.fileStorage.putFile(await node_fs_1.default.promises.readFile(output), ownerDir + `/${id}.mp3`, 'audio/mp3');
|
|
72
|
+
await this.fileStorage.putFile(await node_fs_1.default.promises.readFile(output), ownerDir + `/${id}/output.mp3`, 'audio/mp3');
|
|
74
73
|
}
|
|
75
74
|
catch (err) {
|
|
76
75
|
console.error(err);
|
|
77
76
|
throw new common_1.InternalServerErrorException(500, 'Unable to upload the converted file to the file storage service');
|
|
78
77
|
}
|
|
79
|
-
this.audioRepository.update(id, {
|
|
78
|
+
await this.audioRepository.update(id, {
|
|
79
|
+
pathname: ownerDir + `/${id}/output.mp3`,
|
|
80
|
+
durationSecs,
|
|
81
|
+
sizeBytes,
|
|
82
|
+
});
|
|
80
83
|
return { ...entity, id };
|
|
81
84
|
}
|
|
82
85
|
catch (err) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"media.service.js","sourceRoot":"","sources":["../../src/media/media.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,2CAA0E;AAC1E,6CAAmD;AACnD,qCAAqC;AAErC,0DAAgD;AAChD,+EAA0E;AAC1E,sDAAyB;AAEzB,qDAAiD;AACjD,2CAA4C;AAC5C,mDAA+C;AAE/C,iDAAkD;
|
|
1
|
+
{"version":3,"file":"media.service.js","sourceRoot":"","sources":["../../src/media/media.service.ts"],"names":[],"mappings":"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"}
|
package/dist/{1756201302119-migrations.d.ts → migrations/1757061785934-PushNotificationTokens.d.ts}
RENAMED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { MigrationInterface, QueryRunner } from "typeorm";
|
|
2
|
-
export declare class
|
|
2
|
+
export declare class PushNotificationTokens1757061785934 implements MigrationInterface {
|
|
3
3
|
name: string;
|
|
4
4
|
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
5
|
down(queryRunner: QueryRunner): Promise<void>;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PushNotificationTokens1757061785934 = void 0;
|
|
4
|
+
class PushNotificationTokens1757061785934 {
|
|
5
|
+
name = 'PushNotificationTokens1757061785934';
|
|
6
|
+
async up(queryRunner) {
|
|
7
|
+
await queryRunner.query(`CREATE TYPE "public"."push_notification_token_service_enum" AS ENUM('EXPO', 'FCM', 'APNS')`);
|
|
8
|
+
await queryRunner.query(`CREATE TABLE "push_notification_token" ("service" "public"."push_notification_token_service_enum" NOT NULL, "token" character varying NOT NULL, "createdAt" TIMESTAMP NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP NOT NULL DEFAULT now(), "networkId" integer NOT NULL, "userId" integer NOT NULL, CONSTRAINT "PK_0ea253e8437482d1858c6bdc4d0" PRIMARY KEY ("token"))`);
|
|
9
|
+
await queryRunner.query(`ALTER TABLE "push_notification_token" ADD CONSTRAINT "FK_93311d0f1b246e7d6aa7a35623f" FOREIGN KEY ("networkId") REFERENCES "network"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
10
|
+
await queryRunner.query(`ALTER TABLE "push_notification_token" ADD CONSTRAINT "FK_6ff0b307da861bb462b7f9843ce" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
11
|
+
}
|
|
12
|
+
async down(queryRunner) {
|
|
13
|
+
await queryRunner.query(`ALTER TABLE "push_notification_token" DROP CONSTRAINT "FK_6ff0b307da861bb462b7f9843ce"`);
|
|
14
|
+
await queryRunner.query(`ALTER TABLE "push_notification_token" DROP CONSTRAINT "FK_93311d0f1b246e7d6aa7a35623f"`);
|
|
15
|
+
await queryRunner.query(`DROP TABLE "push_notification_token"`);
|
|
16
|
+
await queryRunner.query(`DROP TYPE "public"."push_notification_token_service_enum"`);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.PushNotificationTokens1757061785934 = PushNotificationTokens1757061785934;
|
|
20
|
+
//# sourceMappingURL=1757061785934-PushNotificationTokens.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1757061785934-PushNotificationTokens.js","sourceRoot":"","sources":["../../src/migrations/1757061785934-PushNotificationTokens.ts"],"names":[],"mappings":";;;AAEA,MAAa,mCAAmC;IAC5C,IAAI,GAAG,qCAAqC,CAAA;IAErC,KAAK,CAAC,EAAE,CAAC,WAAwB;QACpC,MAAM,WAAW,CAAC,KAAK,CAAC,4FAA4F,CAAC,CAAC;QACtH,MAAM,WAAW,CAAC,KAAK,CAAC,yWAAyW,CAAC,CAAC;QACnY,MAAM,WAAW,CAAC,KAAK,CAAC,kLAAkL,CAAC,CAAC;QAC5M,MAAM,WAAW,CAAC,KAAK,CAAC,4KAA4K,CAAC,CAAC;IAC1M,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,WAAwB;QACtC,MAAM,WAAW,CAAC,KAAK,CAAC,wFAAwF,CAAC,CAAC;QAClH,MAAM,WAAW,CAAC,KAAK,CAAC,wFAAwF,CAAC,CAAC;QAClH,MAAM,WAAW,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;QAChE,MAAM,WAAW,CAAC,KAAK,CAAC,2DAA2D,CAAC,CAAC;IACzF,CAAC;CAEJ;AAjBD,kFAiBC"}
|
|
@@ -13,6 +13,7 @@ exports.NetworkContextMiddleware = void 0;
|
|
|
13
13
|
const common_1 = require("@nestjs/common");
|
|
14
14
|
const network_service_1 = require("./network.service");
|
|
15
15
|
const context_service_1 = require("../core/context/context.service");
|
|
16
|
+
const injection_tokens_1 = require("../common/injection-tokens");
|
|
16
17
|
let NetworkContextMiddleware = class NetworkContextMiddleware {
|
|
17
18
|
service;
|
|
18
19
|
contextService;
|
|
@@ -21,11 +22,14 @@ let NetworkContextMiddleware = class NetworkContextMiddleware {
|
|
|
21
22
|
this.contextService = contextService;
|
|
22
23
|
}
|
|
23
24
|
async use(req, res, next) {
|
|
24
|
-
const network = await this.service.
|
|
25
|
+
const network = await this.service.findByDomainAlias(req.host);
|
|
25
26
|
if (!network) {
|
|
26
27
|
throw new common_1.NotFoundException('The network could not be found.');
|
|
27
28
|
}
|
|
28
|
-
this.contextService.set(
|
|
29
|
+
this.contextService.set(injection_tokens_1.NETWORK, network);
|
|
30
|
+
this.contextService.set(injection_tokens_1.HOST, network.fqdn === '*'
|
|
31
|
+
? req.headers['x-forwarded-host'] || req.header['host']
|
|
32
|
+
: network.fqdn);
|
|
29
33
|
req['network'] = network;
|
|
30
34
|
next();
|
|
31
35
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"network.middleware.js","sourceRoot":"","sources":["../../src/network/network.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AAExB,uDAAmD;AACnD,qEAAgE;
|
|
1
|
+
{"version":3,"file":"network.middleware.js","sourceRoot":"","sources":["../../src/network/network.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AAExB,uDAAmD;AACnD,qEAAgE;AAChE,iEAA0D;AAOnD,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAEzB;IACA;IAFV,YACU,OAAuB,EACvB,cAA8B;QAD9B,YAAO,GAAP,OAAO,CAAgB;QACvB,mBAAc,GAAd,cAAc,CAAgB;IACrC,CAAC;IAEJ,KAAK,CAAC,GAAG,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB;QACvD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAE/D,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,0BAAiB,CAAC,iCAAiC,CAAC,CAAC;QACjE,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,0BAAO,EAAE,OAAO,CAAC,CAAC;QAC1C,IAAI,CAAC,cAAc,CAAC,GAAG,CACrB,uBAAI,EACJ,OAAO,CAAC,IAAI,KAAK,GAAG;YAClB,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,kBAAkB,CAAC,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC;YACvD,CAAC,CAAC,OAAO,CAAC,IAAI,CACjB,CAAC;QAEF,GAAG,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC;QACzB,IAAI,EAAE,CAAC;IACT,CAAC;CACF,CAAA;AAxBY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,mBAAU,GAAE;qCAGQ,gCAAc;QACP,gCAAc;GAH7B,wBAAwB,CAwBpC"}
|
|
@@ -11,12 +11,13 @@ const common_1 = require("@nestjs/common");
|
|
|
11
11
|
const network_service_1 = require("./network.service");
|
|
12
12
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
13
13
|
const network_entity_1 = require("./entities/network.entity");
|
|
14
|
+
const configs_module_1 = require("../configs/configs.module");
|
|
14
15
|
let NetworkModule = class NetworkModule {
|
|
15
16
|
};
|
|
16
17
|
exports.NetworkModule = NetworkModule;
|
|
17
18
|
exports.NetworkModule = NetworkModule = __decorate([
|
|
18
19
|
(0, common_1.Module)({
|
|
19
|
-
imports: [typeorm_1.TypeOrmModule.forFeature([network_entity_1.Network])],
|
|
20
|
+
imports: [typeorm_1.TypeOrmModule.forFeature([network_entity_1.Network]), configs_module_1.ConfigsModule],
|
|
20
21
|
providers: [network_service_1.NetworkService],
|
|
21
22
|
exports: [network_service_1.NetworkService],
|
|
22
23
|
})
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"network.module.js","sourceRoot":"","sources":["../../src/network/network.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,uDAAmD;AACnD,6CAAgD;AAChD,8DAAoD;
|
|
1
|
+
{"version":3,"file":"network.module.js","sourceRoot":"","sources":["../../src/network/network.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,uDAAmD;AACnD,6CAAgD;AAChD,8DAAoD;AACpD,8DAAyD;AAOlD,IAAM,aAAa,GAAnB,MAAM,aAAa;CAAG,CAAA;AAAhB,sCAAa;wBAAb,aAAa;IALzB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,uBAAa,CAAC,UAAU,CAAC,CAAC,wBAAO,CAAC,CAAC,EAAE,8BAAa,CAAC;QAC7D,SAAS,EAAE,CAAC,gCAAc,CAAC;QAC3B,OAAO,EAAE,CAAC,gCAAc,CAAC;KAC1B,CAAC;GACW,aAAa,CAAG"}
|
|
@@ -2,12 +2,15 @@ import { CreateNetworkDto } from './dto/create-network.dto';
|
|
|
2
2
|
import { UpdateNetworkDto } from './dto/update-network.dto';
|
|
3
3
|
import { Network } from './entities/network.entity';
|
|
4
4
|
import { Repository } from 'typeorm';
|
|
5
|
+
import { ConfigsService } from '~/configs/configs.service';
|
|
5
6
|
export declare class NetworkService {
|
|
6
7
|
private readonly networkRepository;
|
|
7
|
-
|
|
8
|
+
private readonly configs;
|
|
9
|
+
constructor(networkRepository: Repository<Network>, configs: ConfigsService);
|
|
8
10
|
create(createNetworkDto: CreateNetworkDto): string;
|
|
9
11
|
findAll(): string;
|
|
10
|
-
|
|
12
|
+
findBy(id: number): Promise<Network | null>;
|
|
13
|
+
findByDomainAlias(alias: string): Promise<Network | null>;
|
|
11
14
|
findByFqdn(fqdn: string): Promise<Network | null>;
|
|
12
15
|
update(id: number, updateNetworkDto: UpdateNetworkDto): string;
|
|
13
16
|
remove(id: number): string;
|
|
@@ -17,10 +17,13 @@ const common_1 = require("@nestjs/common");
|
|
|
17
17
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
18
18
|
const network_entity_1 = require("./entities/network.entity");
|
|
19
19
|
const typeorm_2 = require("typeorm");
|
|
20
|
+
const configs_service_1 = require("../configs/configs.service");
|
|
20
21
|
let NetworkService = class NetworkService {
|
|
21
22
|
networkRepository;
|
|
22
|
-
|
|
23
|
+
configs;
|
|
24
|
+
constructor(networkRepository, configs) {
|
|
23
25
|
this.networkRepository = networkRepository;
|
|
26
|
+
this.configs = configs;
|
|
24
27
|
}
|
|
25
28
|
create(createNetworkDto) {
|
|
26
29
|
return 'This action adds a new network';
|
|
@@ -28,11 +31,24 @@ let NetworkService = class NetworkService {
|
|
|
28
31
|
findAll() {
|
|
29
32
|
return `This action returns all network`;
|
|
30
33
|
}
|
|
31
|
-
|
|
32
|
-
|
|
34
|
+
async findBy(id) {
|
|
35
|
+
const network = await this.networkRepository.findOneBy({
|
|
36
|
+
id,
|
|
37
|
+
});
|
|
38
|
+
return network;
|
|
33
39
|
}
|
|
34
|
-
|
|
35
|
-
|
|
40
|
+
async findByDomainAlias(alias) {
|
|
41
|
+
const networkId = this.configs.get('network')?.domainAliasMap[alias];
|
|
42
|
+
if (!networkId) {
|
|
43
|
+
return null;
|
|
44
|
+
}
|
|
45
|
+
return this.findBy(networkId);
|
|
46
|
+
}
|
|
47
|
+
async findByFqdn(fqdn) {
|
|
48
|
+
const network = await this.networkRepository.findOneBy({
|
|
49
|
+
fqdn: (0, typeorm_2.In)([fqdn, '*']),
|
|
50
|
+
});
|
|
51
|
+
return network;
|
|
36
52
|
}
|
|
37
53
|
update(id, updateNetworkDto) {
|
|
38
54
|
return `This action updates a #${id} network`;
|
|
@@ -45,6 +61,7 @@ exports.NetworkService = NetworkService;
|
|
|
45
61
|
exports.NetworkService = NetworkService = __decorate([
|
|
46
62
|
(0, common_1.Injectable)(),
|
|
47
63
|
__param(0, (0, typeorm_1.InjectRepository)(network_entity_1.Network)),
|
|
48
|
-
__metadata("design:paramtypes", [typeorm_2.Repository
|
|
64
|
+
__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
65
|
+
configs_service_1.ConfigsService])
|
|
49
66
|
], NetworkService);
|
|
50
67
|
//# sourceMappingURL=network.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"network.service.js","sourceRoot":"","sources":["../../src/network/network.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAG5C,6CAAmD;AACnD,8DAAoD;AACpD,qCAAyC;
|
|
1
|
+
{"version":3,"file":"network.service.js","sourceRoot":"","sources":["../../src/network/network.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAG5C,6CAAmD;AACnD,8DAAoD;AACpD,qCAAyC;AACzC,gEAA2D;AAGpD,IAAM,cAAc,GAApB,MAAM,cAAc;IAGN;IACA;IAHnB,YAEmB,iBAAsC,EACtC,OAAuB;QADvB,sBAAiB,GAAjB,iBAAiB,CAAqB;QACtC,YAAO,GAAP,OAAO,CAAgB;IACvC,CAAC;IACJ,MAAM,CAAC,gBAAkC;QACvC,OAAO,gCAAgC,CAAC;IAC1C,CAAC;IAED,OAAO;QACL,OAAO,iCAAiC,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,EAAU;QACrB,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC;YACrD,EAAE;SACH,CAAC,CAAC;QACH,OAAO,OAAO,CAAC;IACjB,CAAC;IAMD,KAAK,CAAC,iBAAiB,CAAC,KAAa;QACnC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,cAAc,CAAC,KAAK,CAAC,CAAC;QACrE,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IAChC,CAAC;IAKD,KAAK,CAAC,UAAU,CAAC,IAAY;QAC3B,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC;YACrD,IAAI,EAAE,IAAA,YAAE,EAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SACtB,CAAC,CAAC;QACH,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,MAAM,CAAC,EAAU,EAAE,gBAAkC;QACnD,OAAO,0BAA0B,EAAE,UAAU,CAAC;IAChD,CAAC;IAED,MAAM,CAAC,EAAU;QACf,OAAO,0BAA0B,EAAE,UAAU,CAAC;IAChD,CAAC;CACF,CAAA;AAlDY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,0BAAgB,EAAC,wBAAO,CAAC,CAAA;qCACU,oBAAU;QACpB,gCAAc;GAJ/B,cAAc,CAkD1B"}
|
package/dist/{common/entities/base.repository.js → notification/dto/delete-push-token.dto.js}
RENAMED
|
@@ -8,25 +8,19 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
-
var BaseRepository_1;
|
|
12
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
exports.
|
|
14
|
-
const
|
|
15
|
-
const
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
constructor(dataSource) {
|
|
21
|
-
this.dataSource = dataSource;
|
|
12
|
+
exports.DeletePushNotificationTokenDto = void 0;
|
|
13
|
+
const openapi = require("@nestjs/swagger");
|
|
14
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
15
|
+
class DeletePushNotificationTokenDto {
|
|
16
|
+
token;
|
|
17
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
18
|
+
return { token: { required: true, type: () => String } };
|
|
22
19
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
__metadata("design:paramtypes", [typeorm_1.DataSource])
|
|
31
|
-
], BaseRepository);
|
|
32
|
-
//# sourceMappingURL=base.repository.js.map
|
|
20
|
+
}
|
|
21
|
+
exports.DeletePushNotificationTokenDto = DeletePushNotificationTokenDto;
|
|
22
|
+
__decorate([
|
|
23
|
+
(0, swagger_1.ApiProperty)({ description: 'Device token' }),
|
|
24
|
+
__metadata("design:type", String)
|
|
25
|
+
], DeletePushNotificationTokenDto.prototype, "token", void 0);
|
|
26
|
+
//# sourceMappingURL=delete-push-token.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-push-token.dto.js","sourceRoot":"","sources":["../../../src/notification/dto/delete-push-token.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAE9C,MAAa,8BAA8B;IAEzC,KAAK,CAAS;;;;CACf;AAHD,wEAGC;AADC;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC;;6DAC/B"}
|
|
@@ -0,0 +1,38 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.RegisterPushNotificationTokenDto = void 0;
|
|
16
|
+
const openapi = require("@nestjs/swagger");
|
|
17
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
18
|
+
const push_service_enum_1 = __importDefault(require("../enums/push-service.enum"));
|
|
19
|
+
class RegisterPushNotificationTokenDto {
|
|
20
|
+
service;
|
|
21
|
+
token;
|
|
22
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
23
|
+
return { service: { required: true, enum: require("../enums/push-service.enum").PushService }, token: { required: true, type: () => String } };
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
exports.RegisterPushNotificationTokenDto = RegisterPushNotificationTokenDto;
|
|
27
|
+
__decorate([
|
|
28
|
+
(0, swagger_1.ApiProperty)({
|
|
29
|
+
description: 'Service the token is relevant for. ie. Expo, APNS, FCM',
|
|
30
|
+
enum: push_service_enum_1.default,
|
|
31
|
+
}),
|
|
32
|
+
__metadata("design:type", String)
|
|
33
|
+
], RegisterPushNotificationTokenDto.prototype, "service", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, swagger_1.ApiProperty)({ description: 'Device token' }),
|
|
36
|
+
__metadata("design:type", String)
|
|
37
|
+
], RegisterPushNotificationTokenDto.prototype, "token", void 0);
|
|
38
|
+
//# sourceMappingURL=register-push-token.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register-push-token.dto.js","sourceRoot":"","sources":["../../../src/notification/dto/register-push-token.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,mFAAqD;AAErD,MAAa,gCAAgC;IAK3C,OAAO,CAAc;IAGrB,KAAK,CAAS;;;;CACf;AATD,4EASC;AAJC;IAJC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,wDAAwD;QACrE,IAAI,EAAE,2BAAW;KAClB,CAAC;;iEACmB;AAGrB;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC;;+DAC/B"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Network } from '~/network/entities/network.entity';
|
|
2
|
+
import { User } from '~/user/entities/user.entity';
|
|
3
|
+
import PushService from '../enums/push-service.enum';
|
|
4
|
+
export declare class PushNotificationToken {
|
|
5
|
+
network: Network;
|
|
6
|
+
user: User;
|
|
7
|
+
service: PushService;
|
|
8
|
+
token: string;
|
|
9
|
+
createdAt: Date;
|
|
10
|
+
updatedAt: Date;
|
|
11
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PushNotificationToken = void 0;
|
|
16
|
+
const openapi = require("@nestjs/swagger");
|
|
17
|
+
const typeorm_1 = require("typeorm");
|
|
18
|
+
const network_entity_1 = require("../../network/entities/network.entity");
|
|
19
|
+
const user_entity_1 = require("../../user/entities/user.entity");
|
|
20
|
+
const push_service_enum_1 = __importDefault(require("../enums/push-service.enum"));
|
|
21
|
+
let PushNotificationToken = class PushNotificationToken {
|
|
22
|
+
network;
|
|
23
|
+
user;
|
|
24
|
+
service;
|
|
25
|
+
token;
|
|
26
|
+
createdAt;
|
|
27
|
+
updatedAt;
|
|
28
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
29
|
+
return { network: { required: true, type: () => require("../../network/entities/network.entity").Network }, user: { required: true, type: () => require("../../user/entities/user.entity").User }, service: { required: true, enum: require("../enums/push-service.enum").PushService }, token: { required: true, type: () => String }, createdAt: { required: true, type: () => Date }, updatedAt: { required: true, type: () => Date } };
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
exports.PushNotificationToken = PushNotificationToken;
|
|
33
|
+
__decorate([
|
|
34
|
+
(0, typeorm_1.ManyToOne)(() => network_entity_1.Network, { onDelete: 'CASCADE', nullable: false }),
|
|
35
|
+
__metadata("design:type", network_entity_1.Network)
|
|
36
|
+
], PushNotificationToken.prototype, "network", void 0);
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, typeorm_1.ManyToOne)(() => user_entity_1.User, { onDelete: 'CASCADE', nullable: false, eager: true }),
|
|
39
|
+
__metadata("design:type", user_entity_1.User)
|
|
40
|
+
], PushNotificationToken.prototype, "user", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, typeorm_1.Column)({ type: 'enum', enum: push_service_enum_1.default, nullable: false }),
|
|
43
|
+
__metadata("design:type", String)
|
|
44
|
+
], PushNotificationToken.prototype, "service", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
(0, typeorm_1.PrimaryColumn)(),
|
|
47
|
+
__metadata("design:type", String)
|
|
48
|
+
], PushNotificationToken.prototype, "token", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, typeorm_1.CreateDateColumn)(),
|
|
51
|
+
__metadata("design:type", Date)
|
|
52
|
+
], PushNotificationToken.prototype, "createdAt", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
(0, typeorm_1.UpdateDateColumn)(),
|
|
55
|
+
__metadata("design:type", Date)
|
|
56
|
+
], PushNotificationToken.prototype, "updatedAt", void 0);
|
|
57
|
+
exports.PushNotificationToken = PushNotificationToken = __decorate([
|
|
58
|
+
(0, typeorm_1.Entity)()
|
|
59
|
+
], PushNotificationToken);
|
|
60
|
+
//# sourceMappingURL=push-token.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"push-token.entity.js","sourceRoot":"","sources":["../../../src/notification/entities/push-token.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qCAOiB;AACjB,0EAA4D;AAC5D,iEAAmD;AACnD,mFAAqD;AAG9C,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAKhC,OAAO,CAAU;IAMjB,IAAI,CAAO;IAMX,OAAO,CAAc;IAMrB,KAAK,CAAS;IAMd,SAAS,CAAO;IAMhB,SAAS,CAAO;;;;CACjB,CAAA;AApCY,sDAAqB;AAKhC;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,wBAAO,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;8BAC1D,wBAAO;sDAAC;AAMjB;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;8BACvE,kBAAI;mDAAC;AAMX;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,2BAAW,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;;sDACxC;AAMrB;IADC,IAAA,uBAAa,GAAE;;oDACF;AAMd;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;wDAAC;AAMhB;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;wDAAC;gCAnCL,qBAAqB;IADjC,IAAA,gBAAM,GAAE;GACI,qBAAqB,CAoCjC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PushService = void 0;
|
|
4
|
+
var PushService;
|
|
5
|
+
(function (PushService) {
|
|
6
|
+
PushService["Expo"] = "EXPO";
|
|
7
|
+
PushService["Fcm"] = "FCM";
|
|
8
|
+
PushService["Apns"] = "APNS";
|
|
9
|
+
})(PushService || (exports.PushService = PushService = {}));
|
|
10
|
+
exports.default = PushService;
|
|
11
|
+
//# sourceMappingURL=push-service.enum.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"push-service.enum.js","sourceRoot":"","sources":["../../../src/notification/enums/push-service.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,WAIX;AAJD,WAAY,WAAW;IACrB,4BAAa,CAAA;IACb,0BAAW,CAAA;IACX,4BAAa,CAAA;AACf,CAAC,EAJW,WAAW,2BAAX,WAAW,QAItB;AACD,kBAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { HookService } from '~/core/hook/hook.service';
|
|
2
|
+
import { PushNotificationService } from './push-notification.service';
|
|
3
|
+
import { Post } from '~/post/entities/post.entity';
|
|
4
|
+
import { CommunityService } from '~/community/community.service';
|
|
5
|
+
export declare class NotificationHookListener {
|
|
6
|
+
private hookService;
|
|
7
|
+
private pushService;
|
|
8
|
+
private commuityService;
|
|
9
|
+
constructor(hookService: HookService, pushService: PushNotificationService, commuityService: CommunityService);
|
|
10
|
+
sendToCommunityMembers({ post }: {
|
|
11
|
+
post: Post;
|
|
12
|
+
}): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
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.NotificationHookListener = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const hook_service_1 = require("../core/hook/hook.service");
|
|
15
|
+
const push_notification_service_1 = require("./push-notification.service");
|
|
16
|
+
const community_service_1 = require("../community/community.service");
|
|
17
|
+
let NotificationHookListener = class NotificationHookListener {
|
|
18
|
+
hookService;
|
|
19
|
+
pushService;
|
|
20
|
+
commuityService;
|
|
21
|
+
constructor(hookService, pushService, commuityService) {
|
|
22
|
+
this.hookService = hookService;
|
|
23
|
+
this.pushService = pushService;
|
|
24
|
+
this.commuityService = commuityService;
|
|
25
|
+
this.hookService.listen('POST_SAVED', this.sendToCommunityMembers.bind(this));
|
|
26
|
+
}
|
|
27
|
+
async sendToCommunityMembers({ post }) {
|
|
28
|
+
if (post.community) {
|
|
29
|
+
const community = await this.commuityService.findOne(post.community.id);
|
|
30
|
+
if (!community) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const [members] = await this.commuityService.findMembers({
|
|
34
|
+
community,
|
|
35
|
+
limit: 100,
|
|
36
|
+
offset: 0,
|
|
37
|
+
});
|
|
38
|
+
for (const member of members) {
|
|
39
|
+
const tokens = await this.pushService.getTokensByUser(member.user.id);
|
|
40
|
+
if (tokens) {
|
|
41
|
+
await this.pushService.sendPush({
|
|
42
|
+
title: community?.name,
|
|
43
|
+
body: post.owner.name + ': ' + post.message,
|
|
44
|
+
}, tokens);
|
|
45
|
+
console.log('Sent push to ' + member.user.id);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
exports.NotificationHookListener = NotificationHookListener;
|
|
52
|
+
exports.NotificationHookListener = NotificationHookListener = __decorate([
|
|
53
|
+
(0, common_1.Injectable)(),
|
|
54
|
+
__metadata("design:paramtypes", [hook_service_1.HookService,
|
|
55
|
+
push_notification_service_1.PushNotificationService,
|
|
56
|
+
community_service_1.CommunityService])
|
|
57
|
+
], NotificationHookListener);
|
|
58
|
+
//# sourceMappingURL=hook-listener.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hook-listener.service.js","sourceRoot":"","sources":["../../src/notification/hook-listener.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,4DAAuD;AACvD,2EAAsE;AAEtE,sEAAiE;AAG1D,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAEzB;IACA;IACA;IAHV,YACU,WAAwB,EACxB,WAAoC,EACpC,eAAiC;QAFjC,gBAAW,GAAX,WAAW,CAAa;QACxB,gBAAW,GAAX,WAAW,CAAyB;QACpC,oBAAe,GAAf,eAAe,CAAkB;QAEzC,IAAI,CAAC,WAAW,CAAC,MAAM,CACrB,YAAY,EACZ,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CACvC,CAAC;IACJ,CAAC;IAKD,KAAK,CAAC,sBAAsB,CAAC,EAAE,IAAI,EAAkB;QACnD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YAEnB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YACxE,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,OAAO;YACT,CAAC;YAED,MAAM,CAAC,OAAO,CAAC,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC;gBACvD,SAAS;gBACT,KAAK,EAAE,GAAG;gBACV,MAAM,EAAE,CAAC;aACV,CAAC,CAAC;YAEH,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC7B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACtE,IAAI,MAAM,EAAE,CAAC;oBACX,MAAM,IAAI,CAAC,WAAW,CAAC,QAAQ,CAC7B;wBACE,KAAK,EAAE,SAAS,EAAE,IAAI;wBACtB,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,OAAO;qBAC5C,EACD,MAAM,CACP,CAAC;oBACF,OAAO,CAAC,GAAG,CAAC,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAChD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;CACF,CAAA;AA5CY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,mBAAU,GAAE;qCAGY,0BAAW;QACX,mDAAuB;QACnB,oCAAgB;GAJhC,wBAAwB,CA4CpC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.NotificationModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
12
|
+
const push_token_entity_1 = require("./entities/push-token.entity");
|
|
13
|
+
const push_notification_controller_1 = require("./push-notification.controller");
|
|
14
|
+
const push_notification_service_1 = require("./push-notification.service");
|
|
15
|
+
const axios_1 = require("@nestjs/axios");
|
|
16
|
+
const hook_listener_service_1 = require("./hook-listener.service");
|
|
17
|
+
const hook_module_1 = require("../core/hook/hook.module");
|
|
18
|
+
const community_module_1 = require("../community/community.module");
|
|
19
|
+
let NotificationModule = class NotificationModule {
|
|
20
|
+
};
|
|
21
|
+
exports.NotificationModule = NotificationModule;
|
|
22
|
+
exports.NotificationModule = NotificationModule = __decorate([
|
|
23
|
+
(0, common_1.Module)({
|
|
24
|
+
imports: [
|
|
25
|
+
typeorm_1.TypeOrmModule.forFeature([push_token_entity_1.PushNotificationToken]),
|
|
26
|
+
axios_1.HttpModule,
|
|
27
|
+
hook_module_1.HookModule,
|
|
28
|
+
community_module_1.CommunityModule,
|
|
29
|
+
],
|
|
30
|
+
controllers: [push_notification_controller_1.PushNotificationController],
|
|
31
|
+
providers: [push_notification_service_1.PushNotificationService, hook_listener_service_1.NotificationHookListener],
|
|
32
|
+
})
|
|
33
|
+
], NotificationModule);
|
|
34
|
+
//# sourceMappingURL=notification.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notification.module.js","sourceRoot":"","sources":["../../src/notification/notification.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,6CAAgD;AAChD,oEAAqE;AACrE,iFAA4E;AAC5E,2EAAsE;AACtE,yCAA2C;AAC3C,mEAAmE;AACnE,0DAAqD;AACrD,oEAA+D;AAYxD,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;CAAG,CAAA;AAArB,gDAAkB;6BAAlB,kBAAkB;IAV9B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,yCAAqB,CAAC,CAAC;YACjD,kBAAU;YACV,wBAAU;YACV,kCAAe;SAChB;QACD,WAAW,EAAE,CAAC,yDAA0B,CAAC;QACzC,SAAS,EAAE,CAAC,mDAAuB,EAAE,gDAAwB,CAAC;KAC/D,CAAC;GACW,kBAAkB,CAAG"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { RegisterPushNotificationTokenDto } from './dto/register-push-token.dto';
|
|
2
|
+
import { DeletePushNotificationTokenDto } from './dto/delete-push-token.dto';
|
|
3
|
+
import { PushNotificationService } from './push-notification.service';
|
|
4
|
+
export declare class PushNotificationController {
|
|
5
|
+
private service;
|
|
6
|
+
constructor(service: PushNotificationService);
|
|
7
|
+
registerToken(dto: RegisterPushNotificationTokenDto): Promise<import("typeorm").InsertResult>;
|
|
8
|
+
deleteToken(dto: DeletePushNotificationTokenDto): Promise<import("typeorm").DeleteResult>;
|
|
9
|
+
}
|