@social.dev/server-sdk 0.0.1-alpha.5 → 0.0.1-alpha.51
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 +696 -40
- package/dist/app.module.d.ts +3 -3
- package/dist/app.module.js +11 -6
- package/dist/app.module.js.map +1 -1
- package/dist/auth/auth.controller.d.ts +9 -1
- package/dist/auth/auth.controller.js +53 -2
- package/dist/auth/auth.controller.js.map +1 -1
- package/dist/auth/auth.module.js +4 -0
- package/dist/auth/auth.module.js.map +1 -1
- package/dist/auth/auth.service.d.ts +7 -6
- package/dist/auth/auth.service.js +18 -15
- 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 +6 -3
- package/dist/auth/dto/login-success.dto.js.map +1 -1
- package/dist/auth/dto/register-success.dto.d.ts +3 -0
- package/dist/auth/dto/register-success.dto.js +12 -0
- package/dist/auth/dto/register-success.dto.js.map +1 -0
- package/dist/auth/dto/register.dto.d.ts +6 -0
- package/dist/auth/dto/register.dto.js +45 -0
- package/dist/auth/dto/register.dto.js.map +1 -0
- 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 +7 -2
- package/dist/auth/oidc/oidc.controller.js +31 -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 +8 -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 +9 -5
- package/dist/auth/session/session.service.js.map +1 -1
- package/dist/bootstrap.d.ts +2 -1
- package/dist/bootstrap.js +7 -1
- package/dist/bootstrap.js.map +1 -1
- package/dist/chat/chat.acl.d.ts +3 -0
- package/dist/chat/chat.acl.js +39 -0
- package/dist/chat/chat.acl.js.map +1 -0
- package/dist/chat/chat.controller.d.ts +9 -5
- package/dist/chat/chat.controller.js +99 -10
- package/dist/chat/chat.controller.js.map +1 -1
- package/dist/chat/chat.module.d.ts +3 -0
- package/dist/chat/chat.module.js +26 -2
- package/dist/chat/chat.module.js.map +1 -1
- package/dist/chat/chat.service.d.ts +44 -12
- package/dist/chat/chat.service.js +273 -37
- package/dist/chat/chat.service.js.map +1 -1
- package/dist/chat/dto/create-message.dto.d.ts +2 -1
- package/dist/chat/dto/create-message.dto.js +8 -1
- package/dist/chat/dto/create-message.dto.js.map +1 -1
- package/dist/chat/dto/responses.dto.d.ts +19 -5
- package/dist/chat/dto/responses.dto.js +109 -20
- package/dist/chat/dto/responses.dto.js.map +1 -1
- package/dist/chat/dto/update-cursor.dto.d.ts +5 -0
- package/dist/chat/dto/update-cursor.dto.js +36 -0
- package/dist/chat/dto/update-cursor.dto.js.map +1 -0
- package/dist/chat/entities/conversation-member.entity.js +1 -1
- package/dist/chat/entities/conversation-member.entity.js.map +1 -1
- package/dist/chat/entities/conversation.entity.d.ts +4 -0
- package/dist/chat/entities/conversation.entity.js +13 -1
- package/dist/chat/entities/conversation.entity.js.map +1 -1
- package/dist/chat/entities/message.entity.d.ts +2 -0
- package/dist/chat/entities/message.entity.js +8 -2
- package/dist/chat/entities/message.entity.js.map +1 -1
- package/dist/chat/entities/read-cursor.entity.d.ts +10 -0
- package/dist/chat/entities/read-cursor.entity.js +64 -0
- package/dist/chat/entities/read-cursor.entity.js.map +1 -0
- package/dist/chat/enums/conversation-type.enum.d.ts +2 -1
- package/dist/chat/enums/conversation-type.enum.js +1 -0
- package/dist/chat/enums/conversation-type.enum.js.map +1 -1
- package/dist/common/decorators/api-paginated-response.d.ts +1 -1
- package/dist/common/decorators/api-paginated-response.js +2 -2
- package/dist/common/decorators/api-paginated-response.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/utils/cursor.d.ts +2 -0
- package/dist/common/utils/cursor.js +12 -0
- package/dist/common/utils/cursor.js.map +1 -0
- package/dist/community/avatar/avatar.controller.d.ts +11 -0
- package/dist/community/avatar/avatar.controller.js +90 -0
- package/dist/community/avatar/avatar.controller.js.map +1 -0
- package/dist/community/avatar/avatar.service.d.ts +13 -0
- package/dist/community/avatar/avatar.service.js +78 -0
- package/dist/community/avatar/avatar.service.js.map +1 -0
- package/dist/community/community.acl.d.ts +6 -3
- package/dist/community/community.acl.js +58 -35
- package/dist/community/community.acl.js.map +1 -1
- package/dist/community/community.controller.d.ts +4 -3
- package/dist/community/community.controller.js +23 -6
- package/dist/community/community.controller.js.map +1 -1
- package/dist/community/community.module.d.ts +3 -0
- package/dist/community/community.module.js +17 -7
- package/dist/community/community.module.js.map +1 -1
- package/dist/community/community.service.d.ts +13 -5
- package/dist/community/community.service.js +74 -17
- package/dist/community/community.service.js.map +1 -1
- package/dist/community/dto/community-response.dto.d.ts +5 -1
- package/dist/community/dto/community-response.dto.js +32 -1
- package/dist/community/dto/community-response.dto.js.map +1 -1
- package/dist/community/dto/create-community.dto.d.ts +2 -0
- package/dist/community/dto/create-community.dto.js +14 -2
- package/dist/community/dto/create-community.dto.js.map +1 -1
- package/dist/community/dto/update-community.dto.d.ts +2 -0
- package/dist/community/dto/update-community.dto.js +15 -1
- package/dist/community/dto/update-community.dto.js.map +1 -1
- package/dist/community/entities/community-member.entity.js +1 -0
- package/dist/community/entities/community-member.entity.js.map +1 -1
- package/dist/community/entities/community.entity.d.ts +2 -0
- package/dist/community/entities/community.entity.js +11 -1
- package/dist/community/entities/community.entity.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 +23 -0
- package/dist/configs/configs.service.js +14 -1
- package/dist/configs/configs.service.js.map +1 -1
- package/dist/core/event-stream/event-stream-processor.interface.d.ts +8 -0
- package/dist/core/event-stream/event-stream-processor.interface.js +3 -0
- package/dist/core/event-stream/event-stream-processor.interface.js.map +1 -0
- package/dist/core/event-stream/event-stream-processor.service.d.ts +13 -0
- package/dist/core/event-stream/event-stream-processor.service.js +55 -0
- package/dist/core/event-stream/event-stream-processor.service.js.map +1 -0
- package/dist/core/event-stream/event-stream.module.d.ts +11 -0
- package/dist/core/event-stream/event-stream.module.js +49 -0
- package/dist/core/event-stream/event-stream.module.js.map +1 -0
- package/dist/core/event-stream/event-stream.service.d.ts +16 -0
- package/dist/core/event-stream/event-stream.service.js +100 -0
- package/dist/core/event-stream/event-stream.service.js.map +1 -0
- package/dist/core/event-stream/types.d.ts +2 -0
- package/dist/core/event-stream/types.js +3 -0
- package/dist/core/event-stream/types.js.map +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.d.ts +2 -0
- package/dist/file-storage/utils.js +9 -2
- 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/manage-db.d.ts +1 -0
- package/dist/manage-db.js +10 -0
- package/dist/manage-db.js.map +1 -0
- package/dist/media/entities/audio.entity.d.ts +2 -2
- package/dist/media/entities/audio.entity.js +2 -2
- package/dist/media/entities/audio.entity.js.map +1 -1
- package/dist/media/entities/media.entity.d.ts +6 -0
- package/dist/media/entities/media.entity.js +25 -2
- 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/migrations/1757061785934-PushNotificationTokens.d.ts +6 -0
- package/dist/migrations/1757061785934-PushNotificationTokens.js +20 -0
- package/dist/migrations/1757061785934-PushNotificationTokens.js.map +1 -0
- package/dist/migrations/1758623241397-AddUserTimestamps.d.ts +6 -0
- package/dist/migrations/1758623241397-AddUserTimestamps.js +16 -0
- package/dist/migrations/1758623241397-AddUserTimestamps.js.map +1 -0
- package/dist/{1756201302119-migrations.d.ts → migrations/1758704603161-UserFollows.d.ts} +1 -1
- package/dist/migrations/1758704603161-UserFollows.js +18 -0
- package/dist/migrations/1758704603161-UserFollows.js.map +1 -0
- package/dist/migrations/1759757532702-UpdateCommunityCascades.d.ts +6 -0
- package/dist/migrations/1759757532702-UpdateCommunityCascades.js +20 -0
- package/dist/migrations/1759757532702-UpdateCommunityCascades.js.map +1 -0
- package/dist/migrations/1759766474808-UpdateCommunityTimestamps.d.ts +6 -0
- package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js +16 -0
- package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js.map +1 -0
- package/dist/migrations/1759919335188-CommunityChats.d.ts +6 -0
- package/dist/migrations/1759919335188-CommunityChats.js +28 -0
- package/dist/migrations/1759919335188-CommunityChats.js.map +1 -0
- package/dist/migrations/1760363804673-ChatVoiceNotes.d.ts +6 -0
- package/dist/migrations/1760363804673-ChatVoiceNotes.js +24 -0
- package/dist/migrations/1760363804673-ChatVoiceNotes.js.map +1 -0
- package/dist/migrations/1760444646328-ChatReadCursor.d.ts +6 -0
- package/dist/migrations/1760444646328-ChatReadCursor.js +18 -0
- package/dist/migrations/1760444646328-ChatReadCursor.js.map +1 -0
- package/dist/network/entities/network.entity.js +0 -3
- package/dist/network/entities/network.entity.js.map +1 -1
- package/dist/network/network.middleware.js +1 -1
- 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/{media/entities/post-media.entity.js → notification/dto/delete-push-token.dto.js} +11 -16
- 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 +24 -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.module.d.ts +2 -0
- package/dist/notification/push-notification.module.js +27 -0
- package/dist/notification/push-notification.module.js.map +1 -0
- package/dist/notification/push-notification.service.d.ts +22 -0
- package/dist/notification/push-notification.service.js +86 -0
- package/dist/notification/push-notification.service.js.map +1 -0
- package/dist/post/entities/post.entity.js +3 -3
- package/dist/post/entities/post.entity.js.map +1 -1
- 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/avatar/avatar.controller.d.ts +10 -0
- package/dist/user/avatar/avatar.controller.js +89 -0
- package/dist/user/avatar/avatar.controller.js.map +1 -0
- package/dist/user/avatar/avatar.service.d.ts +12 -0
- package/dist/user/avatar/avatar.service.js +68 -0
- package/dist/user/avatar/avatar.service.js.map +1 -0
- 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/dto/update-profile.dto.d.ts +3 -0
- package/dist/{common/entities/base.repository.js → user/dto/update-profile.dto.js} +14 -20
- package/dist/user/dto/update-profile.dto.js.map +1 -0
- package/dist/user/dto/user-response.dto.d.ts +6 -0
- package/dist/user/dto/user-response.dto.js +37 -1
- package/dist/user/dto/user-response.dto.js.map +1 -1
- package/dist/user/dto/user.dto.d.ts +8 -0
- package/dist/user/dto/user.dto.js +21 -0
- package/dist/user/dto/user.dto.js.map +1 -0
- package/dist/user/entities/user.entity.d.ts +4 -0
- package/dist/user/entities/user.entity.js +19 -1
- package/dist/user/entities/user.entity.js.map +1 -1
- package/dist/user/follow/dto/follow-response.dto.d.ts +4 -0
- package/dist/user/follow/dto/follow-response.dto.js +38 -0
- package/dist/user/follow/dto/follow-response.dto.js.map +1 -0
- package/dist/user/follow/dto/follow.dto.d.ts +4 -0
- package/dist/user/follow/dto/follow.dto.js +26 -0
- package/dist/user/follow/dto/follow.dto.js.map +1 -0
- package/dist/user/follow/entities/follow.entity.d.ts +10 -0
- package/dist/user/follow/entities/follow.entity.js +60 -0
- package/dist/user/follow/entities/follow.entity.js.map +1 -0
- package/dist/user/follow/follow.controller.d.ts +9 -0
- package/dist/user/follow/follow.controller.js +56 -0
- package/dist/user/follow/follow.controller.js.map +1 -0
- package/dist/user/follow/follow.module.d.ts +2 -0
- package/dist/user/follow/follow.module.js +26 -0
- package/dist/user/follow/follow.module.js.map +1 -0
- package/dist/user/follow/follow.service.d.ts +11 -0
- package/dist/user/follow/follow.service.js +56 -0
- package/dist/user/follow/follow.service.js.map +1 -0
- package/dist/user/user.controller.d.ts +6 -2
- package/dist/user/user.controller.js +47 -8
- package/dist/user/user.controller.js.map +1 -1
- package/dist/user/user.module.js +12 -3
- package/dist/user/user.module.js.map +1 -1
- package/dist/user/user.service.d.ts +12 -5
- package/dist/user/user.service.js +49 -11
- package/dist/user/user.service.js.map +1 -1
- package/package.json +6 -3
- 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/constants.d.ts +0 -1
- package/dist/common/constants.js +0 -5
- package/dist/common/constants.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
- package/dist/media/entities/post-media.entity.d.ts +0 -5
- package/dist/media/entities/post-media.entity.js.map +0 -1
- package/dist/user/dto/update-user.dto.d.ts +0 -5
- package/dist/user/dto/update-user.dto.js +0 -13
- package/dist/user/dto/update-user.dto.js.map +0 -1
|
@@ -0,0 +1,90 @@
|
|
|
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.CommunityAvatarController = void 0;
|
|
16
|
+
const openapi = require("@nestjs/swagger");
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const platform_express_1 = require("@nestjs/platform-express");
|
|
19
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
20
|
+
const auth_guard_1 = require("../../auth/auth.guard");
|
|
21
|
+
const class_transformer_1 = require("class-transformer");
|
|
22
|
+
const community_response_dto_1 = require("../dto/community-response.dto");
|
|
23
|
+
const avatar_service_1 = require("./avatar.service");
|
|
24
|
+
const dto_1 = require("../dto");
|
|
25
|
+
let CommunityAvatarController = class CommunityAvatarController {
|
|
26
|
+
service;
|
|
27
|
+
constructor(service) {
|
|
28
|
+
this.service = service;
|
|
29
|
+
}
|
|
30
|
+
async uploadAvatar(dto, file) {
|
|
31
|
+
const community = await this.service.uploadAvatar(+dto.community, file);
|
|
32
|
+
return (0, class_transformer_1.plainToInstance)(community_response_dto_1.CommunityResponseDto, community);
|
|
33
|
+
}
|
|
34
|
+
async downloadAvatar(userId, filename) {
|
|
35
|
+
const stream = await this.service.downloadAvatar(userId, filename);
|
|
36
|
+
const { Readable } = await import('stream');
|
|
37
|
+
const nodeStream = Readable.fromWeb(stream);
|
|
38
|
+
return new common_1.StreamableFile(nodeStream, {
|
|
39
|
+
type: 'image/jpeg',
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
exports.CommunityAvatarController = CommunityAvatarController;
|
|
44
|
+
__decorate([
|
|
45
|
+
(0, swagger_1.ApiOperation)({
|
|
46
|
+
summary: 'Upload an avatar to your profile',
|
|
47
|
+
description: 'This Community API method uploads and stores and image to be used as a profile avatar.',
|
|
48
|
+
}),
|
|
49
|
+
(0, common_1.UseGuards)(auth_guard_1.AuthGuard),
|
|
50
|
+
(0, swagger_1.ApiConsumes)('multipart/form-data'),
|
|
51
|
+
(0, swagger_1.ApiBody)({
|
|
52
|
+
schema: {
|
|
53
|
+
type: 'object',
|
|
54
|
+
properties: {
|
|
55
|
+
file: {
|
|
56
|
+
type: 'string',
|
|
57
|
+
format: 'binary',
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
},
|
|
61
|
+
}),
|
|
62
|
+
(0, common_1.UseInterceptors)((0, platform_express_1.FileInterceptor)('file')),
|
|
63
|
+
(0, common_1.Post)('community.uploadAvatar'),
|
|
64
|
+
openapi.ApiResponse({ status: 201, type: require("../dto/community-response.dto").CommunityResponseDto }),
|
|
65
|
+
__param(0, (0, common_1.Body)()),
|
|
66
|
+
__param(1, (0, common_1.UploadedFile)()),
|
|
67
|
+
__metadata("design:type", Function),
|
|
68
|
+
__metadata("design:paramtypes", [dto_1.CommunityIdDto, Object]),
|
|
69
|
+
__metadata("design:returntype", Promise)
|
|
70
|
+
], CommunityAvatarController.prototype, "uploadAvatar", null);
|
|
71
|
+
__decorate([
|
|
72
|
+
(0, swagger_1.ApiTags)('Assets'),
|
|
73
|
+
(0, swagger_1.ApiOperation)({
|
|
74
|
+
summary: 'Download an avatar for a community',
|
|
75
|
+
description: 'This Community API method displays an avatar. If one if not available, a default avatar is generated.',
|
|
76
|
+
}),
|
|
77
|
+
(0, common_1.Get)('assets/community/avatars/:communityId/:timestamp/:filename'),
|
|
78
|
+
openapi.ApiResponse({ status: 200 }),
|
|
79
|
+
__param(0, (0, common_1.Param)('communityId')),
|
|
80
|
+
__param(1, (0, common_1.Param)('filename')),
|
|
81
|
+
__metadata("design:type", Function),
|
|
82
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
83
|
+
__metadata("design:returntype", Promise)
|
|
84
|
+
], CommunityAvatarController.prototype, "downloadAvatar", null);
|
|
85
|
+
exports.CommunityAvatarController = CommunityAvatarController = __decorate([
|
|
86
|
+
(0, swagger_1.ApiTags)('Community'),
|
|
87
|
+
(0, common_1.Controller)(),
|
|
88
|
+
__metadata("design:paramtypes", [avatar_service_1.CommunityAvatarService])
|
|
89
|
+
], CommunityAvatarController);
|
|
90
|
+
//# sourceMappingURL=avatar.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar.controller.js","sourceRoot":"","sources":["../../../src/community/avatar/avatar.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAWwB;AACxB,+DAA2D;AAC3D,6CAA8E;AAC9E,sDAA8C;AAG9C,yDAAoD;AACpD,0EAAqE;AACrE,qDAA0D;AAC1D,gCAAwC;AAIjC,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAChB;IAApB,YAAoB,OAA+B;QAA/B,YAAO,GAAP,OAAO,CAAwB;IAAG,CAAC;IAsBjD,AAAN,KAAK,CAAC,YAAY,CACR,GAAmB,EACX,IAAyB;QAEzC,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QACxE,OAAO,IAAA,mCAAe,EAAC,6CAAoB,EAAE,SAAS,CAAC,CAAC;IAC1D,CAAC;IASK,AAAN,KAAK,CAAC,cAAc,CACI,MAAkB,EACrB,QAAQ;QAE3B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAEnE,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,UAAU,GAAG,QAAQ,CAAC,OAAO,CAAC,MAAa,CAAC,CAAC;QAEnD,OAAO,IAAI,uBAAc,CAAC,UAAU,EAAE;YACpC,IAAI,EAAE,YAAY;SACnB,CAAC,CAAC;IACL,CAAC;CACF,CAAA;AAnDY,8DAAyB;AAuB9B;IApBL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,kCAAkC;QAC3C,WAAW,EACT,wFAAwF;KAC3F,CAAC;IACD,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,qBAAW,EAAC,qBAAqB,CAAC;IAClC,IAAA,iBAAO,EAAC;QACP,MAAM,EAAE;YACN,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,IAAI,EAAE;oBACJ,IAAI,EAAE,QAAQ;oBACd,MAAM,EAAE,QAAQ;iBACjB;aACF;SACF;KACF,CAAC;IACD,IAAA,wBAAe,EAAC,IAAA,kCAAe,EAAC,MAAM,CAAC,CAAC;IACxC,IAAA,aAAI,EAAC,wBAAwB,CAAC;;IAE5B,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,qBAAY,GAAE,CAAA;;qCADF,oBAAc;;6DAK5B;AASK;IAPL,IAAA,iBAAO,EAAC,QAAQ,CAAC;IACjB,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,oCAAoC;QAC7C,WAAW,EACT,uGAAuG;KAC1G,CAAC;IACD,IAAA,YAAG,EAAC,4DAA4D,CAAC;;IAE/D,WAAA,IAAA,cAAK,EAAC,aAAa,CAAC,CAAA;IACpB,WAAA,IAAA,cAAK,EAAC,UAAU,CAAC,CAAA;;;;+DAUnB;oCAlDU,yBAAyB;IAFrC,IAAA,iBAAO,EAAC,WAAW,CAAC;IACpB,IAAA,mBAAU,GAAE;qCAEkB,uCAAsB;GADxC,yBAAyB,CAmDrC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { NotFoundException } from '@nestjs/common';
|
|
2
|
+
import { FileStorageService } from '~/file-storage/file-storage.service';
|
|
3
|
+
import { CommunityService } from '../community.service';
|
|
4
|
+
import { Community } from '../entities/community.entity';
|
|
5
|
+
import { AclFactory } from '~/core/acl/acl.factory';
|
|
6
|
+
export declare class CommunityAvatarService {
|
|
7
|
+
private fileStorage;
|
|
8
|
+
private communityService;
|
|
9
|
+
private aclFactory;
|
|
10
|
+
constructor(fileStorage: FileStorageService, communityService: CommunityService, aclFactory: AclFactory);
|
|
11
|
+
uploadAvatar(id: Community['id'], file: Express.Multer.File): Promise<boolean>;
|
|
12
|
+
downloadAvatar(id: Community['id'], filename: string): Promise<ReadableStream<any> | NotFoundException | undefined>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
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.CommunityAvatarService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const context_1 = require("../../core/context/context");
|
|
18
|
+
const file_storage_service_1 = require("../../file-storage/file-storage.service");
|
|
19
|
+
const utils_1 = require("../../file-storage/utils");
|
|
20
|
+
const sharp_1 = __importDefault(require("sharp"));
|
|
21
|
+
const client_s3_1 = require("@aws-sdk/client-s3");
|
|
22
|
+
const community_service_1 = require("../community.service");
|
|
23
|
+
const acl_factory_1 = require("../../core/acl/acl.factory");
|
|
24
|
+
const avatar_service_1 = require("../../user/avatar/avatar.service");
|
|
25
|
+
let CommunityAvatarService = class CommunityAvatarService {
|
|
26
|
+
fileStorage;
|
|
27
|
+
communityService;
|
|
28
|
+
aclFactory;
|
|
29
|
+
constructor(fileStorage, communityService, aclFactory) {
|
|
30
|
+
this.fileStorage = fileStorage;
|
|
31
|
+
this.communityService = communityService;
|
|
32
|
+
this.aclFactory = aclFactory;
|
|
33
|
+
}
|
|
34
|
+
async uploadAvatar(id, file) {
|
|
35
|
+
const community = await this.communityService.findOne(id);
|
|
36
|
+
if (!community ||
|
|
37
|
+
!this.aclFactory.withUser(context_1.Context.getUser()).can(acl_factory_1.Action.Update, community)) {
|
|
38
|
+
throw new common_1.ForbiddenException();
|
|
39
|
+
}
|
|
40
|
+
console.log(this.aclFactory
|
|
41
|
+
.withUser(context_1.Context.getUser())
|
|
42
|
+
.relevantRuleFor('foofoo', community));
|
|
43
|
+
const dir = (0, utils_1.getCommunityDir)(community) + 'avatar';
|
|
44
|
+
await this.fileStorage.putFile(await (0, sharp_1.default)(file.buffer).jpeg().toBuffer(), dir + `/master.jpeg`, 'image/jpeg');
|
|
45
|
+
for (const size of avatar_service_1.AVATAR_SIZES) {
|
|
46
|
+
await this.fileStorage.putFile(await (0, sharp_1.default)(file.buffer).jpeg().resize(size).toBuffer(), dir + `/${size}.jpeg`, 'image/jpeg');
|
|
47
|
+
}
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
async downloadAvatar(id, filename) {
|
|
51
|
+
const community = await this.communityService.findOne(id);
|
|
52
|
+
if (!community) {
|
|
53
|
+
return new common_1.NotFoundException();
|
|
54
|
+
}
|
|
55
|
+
const dir = (0, utils_1.getCommunityDir)(community) + 'avatar';
|
|
56
|
+
try {
|
|
57
|
+
console.log(`${dir}/${filename}`);
|
|
58
|
+
return await this.fileStorage.getFile(`${dir}/${filename}`);
|
|
59
|
+
}
|
|
60
|
+
catch (err) {
|
|
61
|
+
console.log(err);
|
|
62
|
+
if (err instanceof client_s3_1.NoSuchKey) {
|
|
63
|
+
throw new common_1.NotFoundException();
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
throw err;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
exports.CommunityAvatarService = CommunityAvatarService;
|
|
72
|
+
exports.CommunityAvatarService = CommunityAvatarService = __decorate([
|
|
73
|
+
(0, common_1.Injectable)(),
|
|
74
|
+
__metadata("design:paramtypes", [file_storage_service_1.FileStorageService,
|
|
75
|
+
community_service_1.CommunityService,
|
|
76
|
+
acl_factory_1.AclFactory])
|
|
77
|
+
], CommunityAvatarService);
|
|
78
|
+
//# sourceMappingURL=avatar.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar.service.js","sourceRoot":"","sources":["../../../src/community/avatar/avatar.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAIwB;AACxB,wDAAiD;AACjD,kFAAyE;AACzE,oDAAuD;AACvD,kDAA0B;AAC1B,kDAA+C;AAC/C,4DAAwD;AAExD,4DAA4D;AAC5D,qEAA4D;AAGrD,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAEvB;IACA;IACA;IAHV,YACU,WAA+B,EAC/B,gBAAkC,EAClC,UAAsB;QAFtB,gBAAW,GAAX,WAAW,CAAoB;QAC/B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAKJ,KAAK,CAAC,YAAY,CAChB,EAAmB,EACnB,IAAyB;QAEzB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAE1D,IACE,CAAC,SAAS;YACV,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,iBAAO,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,oBAAM,CAAC,MAAM,EAAE,SAAS,CAAC,EAC1E,CAAC;YACD,MAAM,IAAI,2BAAkB,EAAE,CAAC;QACjC,CAAC;QACD,OAAO,CAAC,GAAG,CACT,IAAI,CAAC,UAAU;aACZ,QAAQ,CAAC,iBAAO,CAAC,OAAO,EAAE,CAAC;aAC3B,eAAe,CAAC,QAAQ,EAAE,SAAS,CAAC,CACxC,CAAC;QAEF,MAAM,GAAG,GAAG,IAAA,uBAAe,EAAC,SAAS,CAAC,GAAG,QAAQ,CAAC;QAGlD,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAC5B,MAAM,IAAA,eAAK,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE,EAC1C,GAAG,GAAG,cAAc,EACpB,YAAY,CACb,CAAC;QAEF,KAAK,MAAM,IAAI,IAAI,6BAAY,EAAE,CAAC;YAChC,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAC5B,MAAM,IAAA,eAAK,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EACvD,GAAG,GAAG,IAAI,IAAI,OAAO,EACrB,YAAY,CACb,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAKD,KAAK,CAAC,cAAc,CAAC,EAAmB,EAAE,QAAgB;QACxD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAE1D,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,IAAI,0BAAiB,EAAE,CAAC;QACjC,CAAC;QAED,MAAM,GAAG,GAAG,IAAA,uBAAe,EAAC,SAAS,CAAC,GAAG,QAAQ,CAAC;QAClD,IAAI,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,IAAI,QAAQ,EAAE,CAAC,CAAC;YAClC,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,QAAQ,EAAE,CAAC,CAAC;QAC9D,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACjB,IAAI,GAAG,YAAY,qBAAS,EAAE,CAAC;gBAC7B,MAAM,IAAI,0BAAiB,EAAE,CAAC;YAChC,CAAC;iBAAM,CAAC;gBACN,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;IACH,CAAC;CACF,CAAA;AAvEY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;qCAGY,yCAAkB;QACb,oCAAgB;QACtB,wBAAU;GAJrB,sBAAsB,CAuElC"}
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
declare
|
|
3
|
-
|
|
1
|
+
import { CommunityService } from './community.service';
|
|
2
|
+
export declare class CommunityAclService {
|
|
3
|
+
private communityService;
|
|
4
|
+
constructor(communityService: CommunityService);
|
|
5
|
+
}
|
|
6
|
+
export default CommunityAclService;
|
|
@@ -1,49 +1,72 @@
|
|
|
1
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
|
+
};
|
|
2
11
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
13
|
};
|
|
5
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.CommunityAclService = void 0;
|
|
6
16
|
const acl_factory_1 = require("../core/acl/acl.factory");
|
|
7
17
|
const community_entity_1 = require("./entities/community.entity");
|
|
8
18
|
const community_status_enum_1 = __importDefault(require("./enums/community-status.enum"));
|
|
9
19
|
const community_member_entity_1 = require("./entities/community-member.entity");
|
|
10
20
|
const community_role_enum_1 = __importDefault(require("./enums/community-role.enum"));
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
21
|
+
const community_service_1 = require("./community.service");
|
|
22
|
+
const common_1 = require("@nestjs/common");
|
|
23
|
+
let CommunityAclService = class CommunityAclService {
|
|
24
|
+
communityService;
|
|
25
|
+
constructor(communityService) {
|
|
26
|
+
this.communityService = communityService;
|
|
27
|
+
const CommunityAclRules = [
|
|
28
|
+
({ can, user }) => can(acl_factory_1.Action.Read, community_entity_1.Community, (community) => {
|
|
29
|
+
if (!user) {
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
const membership = this.communityService.getMembership(user, community);
|
|
33
|
+
if (membership?.status === community_status_enum_1.default.Active) {
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
return false;
|
|
37
|
+
}),
|
|
38
|
+
({ can, user }) => can(acl_factory_1.Action.Update, community_entity_1.Community, (community) => {
|
|
39
|
+
console.log('Action.Update', community);
|
|
40
|
+
return false;
|
|
41
|
+
}),
|
|
42
|
+
({ can, user }) => can(acl_factory_1.Action.Manage, community_entity_1.Community, (community) => {
|
|
43
|
+
if (!user) {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
const membership = this.communityService.getMembership(user, community);
|
|
47
|
+
return (membership?.status === community_status_enum_1.default.Active &&
|
|
48
|
+
(membership.role === community_role_enum_1.default.Admin ||
|
|
49
|
+
membership.role === community_role_enum_1.default.Owner));
|
|
50
|
+
}),
|
|
51
|
+
({ can, user }) => can(acl_factory_1.Action.Delete, community_member_entity_1.CommunityMember, (membership) => {
|
|
52
|
+
return membership.user.id === user?.id;
|
|
53
|
+
}),
|
|
54
|
+
({ can, getAbility }) => can(acl_factory_1.Action.Manage, community_member_entity_1.CommunityMember, (membership) => {
|
|
55
|
+
return getAbility().can(acl_factory_1.Action.Manage, membership.community);
|
|
56
|
+
}),
|
|
57
|
+
({ can, getAbility }) => can(acl_factory_1.Action.Delete, community_member_entity_1.CommunityMember, (membership) => {
|
|
58
|
+
return getAbility().can(acl_factory_1.Action.Manage, membership.community);
|
|
59
|
+
}),
|
|
60
|
+
];
|
|
61
|
+
for (let rule of CommunityAclRules) {
|
|
62
|
+
acl_factory_1.AclFactory.addRule(rule.bind(this));
|
|
15
63
|
}
|
|
16
64
|
}
|
|
17
65
|
};
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
if (membership?.status === community_status_enum_1.default.Active) {
|
|
25
|
-
return true;
|
|
26
|
-
}
|
|
27
|
-
return false;
|
|
28
|
-
}),
|
|
29
|
-
({ can, user }) => can(acl_factory_1.Action.Manage, community_entity_1.Community, (community) => {
|
|
30
|
-
if (!user) {
|
|
31
|
-
return false;
|
|
32
|
-
}
|
|
33
|
-
const membership = getMembershipForCommunity(user, community);
|
|
34
|
-
return (membership?.status === community_status_enum_1.default.Active &&
|
|
35
|
-
(membership.role === community_role_enum_1.default.Admin ||
|
|
36
|
-
membership.role === community_role_enum_1.default.Owner));
|
|
37
|
-
}),
|
|
38
|
-
({ can, user }) => can(acl_factory_1.Action.Delete, community_member_entity_1.CommunityMember, (membership) => {
|
|
39
|
-
return membership.user.id === user?.id;
|
|
40
|
-
}),
|
|
41
|
-
({ can, getAbility }) => can(acl_factory_1.Action.Manage, community_member_entity_1.CommunityMember, (membership) => {
|
|
42
|
-
return getAbility().can(acl_factory_1.Action.Manage, membership.community);
|
|
43
|
-
}),
|
|
44
|
-
({ can, getAbility }) => can(acl_factory_1.Action.Delete, community_member_entity_1.CommunityMember, (membership) => {
|
|
45
|
-
return getAbility().can(acl_factory_1.Action.Manage, membership.community);
|
|
46
|
-
}),
|
|
47
|
-
];
|
|
48
|
-
exports.default = CommunityAclRules;
|
|
66
|
+
exports.CommunityAclService = CommunityAclService;
|
|
67
|
+
exports.CommunityAclService = CommunityAclService = __decorate([
|
|
68
|
+
(0, common_1.Injectable)(),
|
|
69
|
+
__metadata("design:paramtypes", [community_service_1.CommunityService])
|
|
70
|
+
], CommunityAclService);
|
|
71
|
+
exports.default = CommunityAclService;
|
|
49
72
|
//# sourceMappingURL=community.acl.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"community.acl.js","sourceRoot":"","sources":["../../src/community/community.acl.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"community.acl.js","sourceRoot":"","sources":["../../src/community/community.acl.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { CommunityService } from './community.service';
|
|
2
2
|
import { CreateCommunityDto } from './dto/create-community.dto';
|
|
3
|
+
import { UpdateCommunityDto } from './dto/update-community.dto';
|
|
3
4
|
import { Request } from 'express';
|
|
4
|
-
import { Community } from './entities/community.entity';
|
|
5
5
|
import { CommunityMembershipResponseDto, CommunityResponseDto } from './dto/community-response.dto';
|
|
6
6
|
import { PaginatedResponseDto } from '~/common/dto/paginated-response.dto';
|
|
7
7
|
import { CommunityMembershipListItemResponseDto } from './dto/community-members-response.dto';
|
|
@@ -12,9 +12,10 @@ export declare class CommunityController {
|
|
|
12
12
|
private readonly service;
|
|
13
13
|
private readonly userService;
|
|
14
14
|
constructor(service: CommunityService, userService: UserService);
|
|
15
|
-
create(dto: CreateCommunityDto): Promise<
|
|
15
|
+
create(dto: CreateCommunityDto): Promise<CommunityResponseDto>;
|
|
16
16
|
info(id: string): Promise<CommunityResponseDto>;
|
|
17
|
-
|
|
17
|
+
update(updateCommunityDto: UpdateCommunityDto): Promise<CommunityResponseDto>;
|
|
18
|
+
remove({ community: id }: CommunityIdDto): Promise<boolean>;
|
|
18
19
|
join(dto: CommunityIdDto): Promise<CommunityMembershipResponseDto>;
|
|
19
20
|
leave({ community: id }: CommunityIdDto): Promise<boolean>;
|
|
20
21
|
removeMember({ community: communityId, user: userId }: CommunityIdAndUserIdDto): Promise<boolean>;
|
|
@@ -20,6 +20,7 @@ const openapi = require("@nestjs/swagger");
|
|
|
20
20
|
const common_1 = require("@nestjs/common");
|
|
21
21
|
const community_service_1 = require("./community.service");
|
|
22
22
|
const create_community_dto_1 = require("./dto/create-community.dto");
|
|
23
|
+
const update_community_dto_1 = require("./dto/update-community.dto");
|
|
23
24
|
const auth_guard_1 = require("../auth/auth.guard");
|
|
24
25
|
const swagger_1 = require("@nestjs/swagger");
|
|
25
26
|
const community_response_dto_1 = require("./dto/community-response.dto");
|
|
@@ -37,12 +38,16 @@ let CommunityController = class CommunityController {
|
|
|
37
38
|
this.service = service;
|
|
38
39
|
this.userService = userService;
|
|
39
40
|
}
|
|
40
|
-
create(dto) {
|
|
41
|
-
return this.service.create(dto);
|
|
41
|
+
async create(dto) {
|
|
42
|
+
return (0, class_transformer_1.plainToInstance)(community_response_dto_1.CommunityResponseDto, await this.service.create(dto));
|
|
42
43
|
}
|
|
43
44
|
async info(id) {
|
|
44
45
|
return (0, class_transformer_1.plainToInstance)(community_response_dto_1.CommunityResponseDto, this.service.findOne(+id));
|
|
45
46
|
}
|
|
47
|
+
async update(updateCommunityDto) {
|
|
48
|
+
const community = await this.service.update(updateCommunityDto.community, updateCommunityDto);
|
|
49
|
+
return (0, class_transformer_1.plainToInstance)(community_response_dto_1.CommunityResponseDto, community);
|
|
50
|
+
}
|
|
46
51
|
remove({ community: id }) {
|
|
47
52
|
return this.service.remove(+id);
|
|
48
53
|
}
|
|
@@ -52,7 +57,7 @@ let CommunityController = class CommunityController {
|
|
|
52
57
|
throw new common_1.NotFoundException();
|
|
53
58
|
}
|
|
54
59
|
const user = context_1.Context.getUser();
|
|
55
|
-
const membership = await this.service.join(community, user);
|
|
60
|
+
const membership = await this.service.join({ community, user });
|
|
56
61
|
return (0, class_transformer_1.plainToInstance)(community_response_dto_1.CommunityMembershipResponseDto, membership);
|
|
57
62
|
}
|
|
58
63
|
async leave({ community: id }) {
|
|
@@ -108,6 +113,8 @@ let CommunityController = class CommunityController {
|
|
|
108
113
|
return {
|
|
109
114
|
result: result.map((member) => (0, class_transformer_1.plainToInstance)(community_members_response_dto_1.CommunityMembershipListItemResponseDto, member)),
|
|
110
115
|
count,
|
|
116
|
+
next: '',
|
|
117
|
+
previous: '',
|
|
111
118
|
};
|
|
112
119
|
}
|
|
113
120
|
async listCommunities(limit = 100, offset = 0, member = false, req) {
|
|
@@ -121,6 +128,8 @@ let CommunityController = class CommunityController {
|
|
|
121
128
|
return {
|
|
122
129
|
result: result.map((s) => (0, class_transformer_1.plainToInstance)(community_response_dto_1.CommunityResponseDto, s)),
|
|
123
130
|
count,
|
|
131
|
+
next: '',
|
|
132
|
+
previous: '',
|
|
124
133
|
};
|
|
125
134
|
}
|
|
126
135
|
};
|
|
@@ -132,11 +141,11 @@ __decorate([
|
|
|
132
141
|
If successful, the command returns a community entity.`,
|
|
133
142
|
}),
|
|
134
143
|
(0, common_1.Post)('community.create'),
|
|
135
|
-
openapi.ApiResponse({ status: 201, type: require("./
|
|
144
|
+
openapi.ApiResponse({ status: 201, type: require("./dto/community-response.dto").CommunityResponseDto }),
|
|
136
145
|
__param(0, (0, common_1.Body)()),
|
|
137
146
|
__metadata("design:type", Function),
|
|
138
147
|
__metadata("design:paramtypes", [create_community_dto_1.CreateCommunityDto]),
|
|
139
|
-
__metadata("design:returntype",
|
|
148
|
+
__metadata("design:returntype", Promise)
|
|
140
149
|
], CommunityController.prototype, "create", null);
|
|
141
150
|
__decorate([
|
|
142
151
|
(0, swagger_1.ApiOperation)({
|
|
@@ -150,13 +159,21 @@ __decorate([
|
|
|
150
159
|
__metadata("design:paramtypes", [String]),
|
|
151
160
|
__metadata("design:returntype", Promise)
|
|
152
161
|
], CommunityController.prototype, "info", null);
|
|
162
|
+
__decorate([
|
|
163
|
+
(0, common_1.Post)('community.update'),
|
|
164
|
+
openapi.ApiResponse({ status: 201, type: require("./dto/community-response.dto").CommunityResponseDto }),
|
|
165
|
+
__param(0, (0, common_1.Body)()),
|
|
166
|
+
__metadata("design:type", Function),
|
|
167
|
+
__metadata("design:paramtypes", [update_community_dto_1.UpdateCommunityDto]),
|
|
168
|
+
__metadata("design:returntype", Promise)
|
|
169
|
+
], CommunityController.prototype, "update", null);
|
|
153
170
|
__decorate([
|
|
154
171
|
(0, swagger_1.ApiOperation)({
|
|
155
172
|
summary: 'Delete a community',
|
|
156
173
|
description: `This Community API method deletes a community and all of its entities.`,
|
|
157
174
|
}),
|
|
158
175
|
(0, common_1.Post)('community.delete'),
|
|
159
|
-
openapi.ApiResponse({ status: 201, type:
|
|
176
|
+
openapi.ApiResponse({ status: 201, type: Boolean }),
|
|
160
177
|
__param(0, (0, common_1.Body)()),
|
|
161
178
|
__metadata("design:type", Function),
|
|
162
179
|
__metadata("design:paramtypes", [dto_1.CommunityIdDto]),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"community.controller.js","sourceRoot":"","sources":["../../src/community/community.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;AAAA,2CAawB;AACxB,2DAAuD;AACvD,qEAAgE;
|
|
1
|
+
{"version":3,"file":"community.controller.js","sourceRoot":"","sources":["../../src/community/community.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,8 +5,8 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
5
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
6
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
7
|
};
|
|
8
|
-
var
|
|
9
|
-
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.CommunityModule = void 0;
|
|
@@ -20,8 +20,15 @@ const user_entity_1 = require("../user/entities/user.entity");
|
|
|
20
20
|
const post_module_1 = require("../post/post.module");
|
|
21
21
|
const community_member_entity_1 = require("./entities/community-member.entity");
|
|
22
22
|
const acl_module_1 = require("../core/acl/acl.module");
|
|
23
|
-
const community_acl_1 =
|
|
23
|
+
const community_acl_1 = require("./community.acl");
|
|
24
|
+
const avatar_service_1 = require("./avatar/avatar.service");
|
|
25
|
+
const avatar_controller_1 = require("./avatar/avatar.controller");
|
|
26
|
+
const file_storage_module_1 = require("../file-storage/file-storage.module");
|
|
24
27
|
let CommunityModule = class CommunityModule {
|
|
28
|
+
acl;
|
|
29
|
+
constructor(acl) {
|
|
30
|
+
this.acl = acl;
|
|
31
|
+
}
|
|
25
32
|
};
|
|
26
33
|
exports.CommunityModule = CommunityModule;
|
|
27
34
|
exports.CommunityModule = CommunityModule = __decorate([
|
|
@@ -30,10 +37,13 @@ exports.CommunityModule = CommunityModule = __decorate([
|
|
|
30
37
|
typeorm_1.TypeOrmModule.forFeature([community_entity_1.Community, community_member_entity_1.CommunityMember, user_entity_1.User]),
|
|
31
38
|
user_module_1.UserModule,
|
|
32
39
|
post_module_1.PostModule,
|
|
33
|
-
|
|
40
|
+
file_storage_module_1.FileStorageModule,
|
|
41
|
+
acl_module_1.AclModule,
|
|
34
42
|
],
|
|
35
|
-
controllers: [community_controller_1.CommunityController],
|
|
36
|
-
providers: [community_service_1.CommunityService],
|
|
37
|
-
|
|
43
|
+
controllers: [community_controller_1.CommunityController, avatar_controller_1.CommunityAvatarController],
|
|
44
|
+
providers: [community_service_1.CommunityService, avatar_service_1.CommunityAvatarService, community_acl_1.CommunityAclService],
|
|
45
|
+
exports: [community_service_1.CommunityService],
|
|
46
|
+
}),
|
|
47
|
+
__metadata("design:paramtypes", [community_acl_1.CommunityAclService])
|
|
38
48
|
], CommunityModule);
|
|
39
49
|
//# sourceMappingURL=community.module.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"community.module.js","sourceRoot":"","sources":["../../src/community/community.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAwC;AACxC,2DAAuD;AACvD,iEAA6D;AAC7D,6CAAgD;AAChD,kEAAwD;AACxD,qDAAgD;AAChD,8DAAmD;AACnD,qDAAgD;AAChD,gFAAqE;AACrE,uDAAkD;AAClD,
|
|
1
|
+
{"version":3,"file":"community.module.js","sourceRoot":"","sources":["../../src/community/community.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAwC;AACxC,2DAAuD;AACvD,iEAA6D;AAC7D,6CAAgD;AAChD,kEAAwD;AACxD,qDAAgD;AAChD,8DAAmD;AACnD,qDAAgD;AAChD,gFAAqE;AACrE,uDAAkD;AAClD,mDAAsD;AACtD,4DAAiE;AACjE,kEAAuE;AACvE,6EAAuE;AAchE,IAAM,eAAe,GAArB,MAAM,eAAe;IACN;IAApB,YAAoB,GAAwB;QAAxB,QAAG,GAAH,GAAG,CAAqB;IAAG,CAAC;CACjD,CAAA;AAFY,0CAAe;0BAAf,eAAe;IAZ3B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,4BAAS,EAAE,yCAAe,EAAE,kBAAI,CAAC,CAAC;YAC5D,wBAAU;YACV,wBAAU;YACV,uCAAiB;YACjB,sBAAS;SACV;QACD,WAAW,EAAE,CAAC,0CAAmB,EAAE,6CAAyB,CAAC;QAC7D,SAAS,EAAE,CAAC,oCAAgB,EAAE,uCAAsB,EAAE,mCAAmB,CAAC;QAC1E,OAAO,EAAE,CAAC,oCAAgB,CAAC;KAC5B,CAAC;qCAEyB,mCAAmB;GADjC,eAAe,CAE3B"}
|
|
@@ -1,24 +1,31 @@
|
|
|
1
1
|
import { CreateCommunityDto } from './dto/create-community.dto';
|
|
2
2
|
import { UpdateCommunityDto } from './dto/update-community.dto';
|
|
3
|
-
import { Repository } from 'typeorm';
|
|
3
|
+
import { DataSource, QueryRunner, Repository } from 'typeorm';
|
|
4
4
|
import { Community } from './entities/community.entity';
|
|
5
5
|
import { User } from '~/user/entities/user.entity';
|
|
6
6
|
import { CommunityMember } from './entities/community-member.entity';
|
|
7
|
+
import CommunityMemberRole from './enums/community-role.enum';
|
|
7
8
|
import CommunityMemberStatus from './enums/community-status.enum';
|
|
8
9
|
import { AclFactory } from '~/core/acl/acl.factory';
|
|
9
10
|
export declare class CommunityService {
|
|
10
11
|
private readonly repository;
|
|
11
12
|
private readonly userRepository;
|
|
12
13
|
private readonly membershipRepository;
|
|
14
|
+
private readonly dataSource;
|
|
13
15
|
private aclFactory;
|
|
14
|
-
constructor(repository: Repository<Community>, userRepository: Repository<User>, membershipRepository: Repository<CommunityMember>, aclFactory: AclFactory);
|
|
16
|
+
constructor(repository: Repository<Community>, userRepository: Repository<User>, membershipRepository: Repository<CommunityMember>, dataSource: DataSource, aclFactory: AclFactory);
|
|
15
17
|
create(createCommunityDto: CreateCommunityDto): Promise<Community>;
|
|
16
18
|
findAll(limit?: number, offset?: number): Promise<[Community[], number]>;
|
|
17
19
|
findAllByMember(user: User, limit?: number, offset?: number): Promise<[Community[], number]>;
|
|
18
20
|
findOne(id: number): Promise<Community | null>;
|
|
19
|
-
update(id: number, updateCommunityDto: UpdateCommunityDto):
|
|
20
|
-
remove(id: number):
|
|
21
|
-
join(community
|
|
21
|
+
update(id: number, updateCommunityDto: UpdateCommunityDto): Promise<Community>;
|
|
22
|
+
remove(id: number): Promise<boolean>;
|
|
23
|
+
join({ community, user, role, status, }: {
|
|
24
|
+
community: Community;
|
|
25
|
+
user: User;
|
|
26
|
+
role?: CommunityMemberRole;
|
|
27
|
+
status?: CommunityMemberStatus;
|
|
28
|
+
}, queryRunner?: QueryRunner): Promise<CommunityMember>;
|
|
22
29
|
leave(community: Community, user: User): Promise<boolean>;
|
|
23
30
|
removeMember({ community, user, }: {
|
|
24
31
|
community: Community;
|
|
@@ -34,4 +41,5 @@ export declare class CommunityService {
|
|
|
34
41
|
offset: number;
|
|
35
42
|
status?: CommunityMemberStatus;
|
|
36
43
|
}): Promise<[CommunityMember[], number]>;
|
|
44
|
+
getMembership(user: User, community: Community): CommunityMember | null;
|
|
37
45
|
}
|