@social.dev/server-sdk 0.0.1-alpha.8 → 0.0.1-alpha.80
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/__mocks__/kafka.mock.d.ts +11 -0
- package/dist/__mocks__/kafka.mock.js +15 -0
- package/dist/__mocks__/kafka.mock.js.map +1 -0
- package/dist/app.module.d.ts +4 -4
- package/dist/app.module.js +17 -7
- package/dist/app.module.js.map +1 -1
- package/dist/auth/auth.controller.d.ts +7 -1
- package/dist/auth/auth.controller.js +28 -3
- package/dist/auth/auth.controller.js.map +1 -1
- package/dist/auth/auth.middleware.d.ts +3 -5
- package/dist/auth/auth.middleware.js +7 -15
- package/dist/auth/auth.middleware.js.map +1 -1
- package/dist/auth/auth.module.js +4 -1
- package/dist/auth/auth.module.js.map +1 -1
- package/dist/auth/auth.service.d.ts +9 -1
- package/dist/auth/auth.service.js +34 -2
- package/dist/auth/auth.service.js.map +1 -1
- package/dist/auth/constants.js +2 -1
- package/dist/auth/constants.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/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/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.service.d.ts +9 -4
- package/dist/auth/oidc/oidc.service.js +64 -38
- 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 +14 -7
- 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 +50 -0
- package/dist/chat/chat.acl.js.map +1 -0
- package/dist/chat/chat.controller.d.ts +15 -6
- package/dist/chat/chat.controller.js +153 -14
- package/dist/chat/chat.controller.js.map +1 -1
- package/dist/chat/chat.module.d.ts +3 -0
- package/dist/chat/chat.module.js +30 -4
- package/dist/chat/chat.module.js.map +1 -1
- package/dist/chat/chat.service.d.ts +63 -12
- package/dist/chat/chat.service.js +468 -36
- package/dist/chat/chat.service.js.map +1 -1
- package/dist/chat/dto/add-reaction.dto.d.ts +5 -0
- package/dist/chat/dto/add-reaction.dto.js +42 -0
- package/dist/chat/dto/add-reaction.dto.js.map +1 -0
- package/dist/chat/dto/create-message.dto.d.ts +4 -1
- package/dist/chat/dto/create-message.dto.js +23 -1
- package/dist/chat/dto/create-message.dto.js.map +1 -1
- package/dist/chat/dto/edit-message.dto.d.ts +5 -0
- package/dist/chat/dto/edit-message.dto.js +31 -0
- package/dist/chat/dto/edit-message.dto.js.map +1 -0
- package/dist/chat/dto/responses.dto.d.ts +27 -5
- package/dist/chat/dto/responses.dto.js +177 -18
- 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 +8 -0
- package/dist/chat/entities/message.entity.js +32 -2
- package/dist/chat/entities/message.entity.js.map +1 -1
- package/dist/chat/entities/reaction.entity.d.ts +10 -0
- package/dist/chat/entities/reaction.entity.js +62 -0
- package/dist/chat/entities/reaction.entity.js.map +1 -0
- 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/injection-tokens.d.ts +2 -0
- package/dist/common/injection-tokens.js +3 -1
- package/dist/common/injection-tokens.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 +8 -5
- package/dist/community/community.controller.js +102 -17
- 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 +26 -6
- package/dist/community/community.service.js +152 -23
- 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 +30 -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.service.d.ts +12 -2
- package/dist/configs/configs.service.js.map +1 -1
- package/dist/core/context/context.d.ts +3 -0
- package/dist/core/context/context.js +15 -0
- package/dist/core/context/context.js.map +1 -1
- package/dist/core/context/context.store.d.ts +2 -0
- package/dist/core/core.module.js +2 -1
- package/dist/core/core.module.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 +60 -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 +18 -0
- package/dist/core/event-stream/event-stream.service.js +107 -0
- package/dist/core/event-stream/event-stream.service.js.map +1 -0
- package/dist/core/event-stream/types.d.ts +3 -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 +5 -6
- package/dist/core/plugin/plugin.module.js.map +1 -1
- package/dist/core/websocket/gateway.service.d.ts +24 -0
- package/dist/core/websocket/gateway.service.js +150 -0
- package/dist/core/websocket/gateway.service.js.map +1 -0
- package/dist/core/websocket/websocket.module.d.ts +2 -0
- package/dist/core/websocket/websocket.module.js +24 -0
- package/dist/core/websocket/websocket.module.js.map +1 -0
- package/dist/db.js +2 -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/dto/media-response.dto.d.ts +2 -0
- package/dist/media/dto/media-response.dto.js +15 -2
- package/dist/media/dto/media-response.dto.js.map +1 -1
- 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/image.entity.d.ts +5 -0
- package/dist/media/entities/{post-media.entity.js → image.entity.js} +16 -12
- package/dist/media/entities/image.entity.js.map +1 -0
- 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 +22 -1
- package/dist/media/media.acl.js.map +1 -1
- package/dist/media/media.controller.d.ts +2 -0
- package/dist/media/media.controller.js +58 -0
- package/dist/media/media.controller.js.map +1 -1
- package/dist/media/media.module.js +2 -1
- package/dist/media/media.module.js.map +1 -1
- package/dist/media/media.service.d.ts +6 -3
- package/dist/media/media.service.js +118 -19
- 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/migrations/1758704603161-UserFollows.d.ts +6 -0
- 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/migrations/1761598291629-AddChatImages.d.ts +6 -0
- package/dist/migrations/1761598291629-AddChatImages.js +16 -0
- package/dist/migrations/1761598291629-AddChatImages.js.map +1 -0
- package/dist/migrations/1761648419807-ChatReactions.d.ts +6 -0
- package/dist/migrations/1761648419807-ChatReactions.js +18 -0
- package/dist/migrations/1761648419807-ChatReactions.js.map +1 -0
- package/dist/migrations/1762953835109-AddChatReplies.d.ts +6 -0
- package/dist/migrations/1762953835109-AddChatReplies.js +22 -0
- package/dist/migrations/1762953835109-AddChatReplies.js.map +1 -0
- package/dist/network/entities/network.entity.js +1 -3
- package/dist/network/entities/network.entity.js.map +1 -1
- package/dist/network/network.middleware.d.ts +3 -1
- package/dist/network/network.middleware.js +12 -4
- 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 +4 -2
- package/dist/network/network.service.js +16 -6
- package/dist/network/network.service.js.map +1 -1
- package/dist/notification/dto/delete-push-token.dto.d.ts +3 -0
- package/dist/notification/dto/delete-push-token.dto.js +26 -0
- 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 +23 -0
- package/dist/notification/push-notification.service.js +89 -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 +72 -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/user/dto/update-profile.dto.js +26 -0
- 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 +4 -1
- package/dist/user/user.controller.js +38 -4
- 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 +16 -5
- 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,62 @@
|
|
|
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.ChatMessageReaction = void 0;
|
|
13
|
+
const openapi = require("@nestjs/swagger");
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
const user_entity_1 = require("../../user/entities/user.entity");
|
|
16
|
+
const message_entity_1 = require("./message.entity");
|
|
17
|
+
let ChatMessageReaction = class ChatMessageReaction {
|
|
18
|
+
messageId;
|
|
19
|
+
message;
|
|
20
|
+
userId;
|
|
21
|
+
user;
|
|
22
|
+
emoji;
|
|
23
|
+
createdAt;
|
|
24
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
25
|
+
return { messageId: { required: true, type: () => Number }, message: { required: true, type: () => require("./message.entity").ChatMessage }, userId: { required: true, type: () => Number }, user: { required: true, type: () => require("../../user/entities/user.entity").User }, emoji: { required: true, type: () => String }, createdAt: { required: true, type: () => Date } };
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
exports.ChatMessageReaction = ChatMessageReaction;
|
|
29
|
+
__decorate([
|
|
30
|
+
(0, typeorm_1.PrimaryColumn)(),
|
|
31
|
+
__metadata("design:type", Object)
|
|
32
|
+
], ChatMessageReaction.prototype, "messageId", void 0);
|
|
33
|
+
__decorate([
|
|
34
|
+
(0, typeorm_1.ManyToOne)(() => message_entity_1.ChatMessage, (message) => message.reactions, {
|
|
35
|
+
cascade: true,
|
|
36
|
+
}),
|
|
37
|
+
(0, typeorm_1.JoinColumn)({ name: 'messageId' }),
|
|
38
|
+
__metadata("design:type", message_entity_1.ChatMessage)
|
|
39
|
+
], ChatMessageReaction.prototype, "message", void 0);
|
|
40
|
+
__decorate([
|
|
41
|
+
(0, typeorm_1.PrimaryColumn)(),
|
|
42
|
+
__metadata("design:type", Object)
|
|
43
|
+
], ChatMessageReaction.prototype, "userId", void 0);
|
|
44
|
+
__decorate([
|
|
45
|
+
(0, typeorm_1.ManyToOne)(() => user_entity_1.User, (user) => user.chats, {
|
|
46
|
+
cascade: true,
|
|
47
|
+
}),
|
|
48
|
+
(0, typeorm_1.JoinColumn)({ name: 'userId' }),
|
|
49
|
+
__metadata("design:type", user_entity_1.User)
|
|
50
|
+
], ChatMessageReaction.prototype, "user", void 0);
|
|
51
|
+
__decorate([
|
|
52
|
+
(0, typeorm_1.Column)(),
|
|
53
|
+
__metadata("design:type", String)
|
|
54
|
+
], ChatMessageReaction.prototype, "emoji", void 0);
|
|
55
|
+
__decorate([
|
|
56
|
+
(0, typeorm_1.CreateDateColumn)(),
|
|
57
|
+
__metadata("design:type", Date)
|
|
58
|
+
], ChatMessageReaction.prototype, "createdAt", void 0);
|
|
59
|
+
exports.ChatMessageReaction = ChatMessageReaction = __decorate([
|
|
60
|
+
(0, typeorm_1.Entity)()
|
|
61
|
+
], ChatMessageReaction);
|
|
62
|
+
//# sourceMappingURL=reaction.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reaction.entity.js","sourceRoot":"","sources":["../../../src/chat/entities/reaction.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAOiB;AACjB,iEAAmD;AAEnD,qDAA+C;AAGxC,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAKrB,SAAS,CAAoB;IAStC,OAAO,CAAc;IAMZ,MAAM,CAAa;IAS5B,IAAI,CAAO;IAMX,KAAK,CAAS;IAGd,SAAS,CAAO;;;;CACjB,CAAA;AAvCY,kDAAmB;AAKrB;IADR,IAAA,uBAAa,GAAE;;sDACsB;AAStC;IAJC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,4BAAW,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE;QAC5D,OAAO,EAAE,IAAI;KACd,CAAC;IACD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;8BACzB,4BAAW;oDAAC;AAMZ;IADR,IAAA,uBAAa,GAAE;;mDACY;AAS5B;IAJC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE;QAC3C,OAAO,EAAE,IAAI;KACd,CAAC;IACD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;8BACzB,kBAAI;iDAAC;AAMX;IADC,IAAA,gBAAM,GAAE;;kDACK;AAGd;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;sDAAC;8BAtCL,mBAAmB;IAD/B,IAAA,gBAAM,GAAE;GACI,mBAAmB,CAuC/B"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ChatConversation } from './conversation.entity';
|
|
2
|
+
import { User } from '~/user/entities/user.entity';
|
|
3
|
+
export declare class ChatReadCursor {
|
|
4
|
+
readonly conversationId: ChatConversation['id'];
|
|
5
|
+
conversation: ChatConversation;
|
|
6
|
+
readonly userId: User['id'];
|
|
7
|
+
user: User;
|
|
8
|
+
ts: Date;
|
|
9
|
+
updatedAt: Date;
|
|
10
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
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.ChatReadCursor = void 0;
|
|
13
|
+
const openapi = require("@nestjs/swagger");
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
const conversation_entity_1 = require("./conversation.entity");
|
|
16
|
+
const user_entity_1 = require("../../user/entities/user.entity");
|
|
17
|
+
let ChatReadCursor = class ChatReadCursor {
|
|
18
|
+
conversationId;
|
|
19
|
+
conversation;
|
|
20
|
+
userId;
|
|
21
|
+
user;
|
|
22
|
+
ts;
|
|
23
|
+
updatedAt;
|
|
24
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
25
|
+
return { conversationId: { required: true, type: () => Number }, conversation: { required: true, type: () => require("./conversation.entity").ChatConversation }, userId: { required: true, type: () => Number }, user: { required: true, type: () => require("../../user/entities/user.entity").User }, ts: { required: true, type: () => Date }, updatedAt: { required: true, type: () => Date } };
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
exports.ChatReadCursor = ChatReadCursor;
|
|
29
|
+
__decorate([
|
|
30
|
+
(0, typeorm_1.PrimaryColumn)(),
|
|
31
|
+
__metadata("design:type", Object)
|
|
32
|
+
], ChatReadCursor.prototype, "conversationId", void 0);
|
|
33
|
+
__decorate([
|
|
34
|
+
(0, typeorm_1.ManyToOne)(() => conversation_entity_1.ChatConversation, (conversation) => conversation.members, {
|
|
35
|
+
eager: true,
|
|
36
|
+
cascade: true,
|
|
37
|
+
}),
|
|
38
|
+
(0, typeorm_1.JoinColumn)({ name: 'conversationId' }),
|
|
39
|
+
__metadata("design:type", conversation_entity_1.ChatConversation)
|
|
40
|
+
], ChatReadCursor.prototype, "conversation", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, typeorm_1.PrimaryColumn)(),
|
|
43
|
+
__metadata("design:type", Object)
|
|
44
|
+
], ChatReadCursor.prototype, "userId", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
(0, typeorm_1.ManyToOne)(() => user_entity_1.User, (user) => user.chats, {
|
|
47
|
+
eager: true,
|
|
48
|
+
cascade: true,
|
|
49
|
+
}),
|
|
50
|
+
(0, typeorm_1.JoinColumn)({ name: 'userId' }),
|
|
51
|
+
__metadata("design:type", user_entity_1.User)
|
|
52
|
+
], ChatReadCursor.prototype, "user", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
(0, typeorm_1.Column)(),
|
|
55
|
+
__metadata("design:type", Date)
|
|
56
|
+
], ChatReadCursor.prototype, "ts", void 0);
|
|
57
|
+
__decorate([
|
|
58
|
+
(0, typeorm_1.UpdateDateColumn)(),
|
|
59
|
+
__metadata("design:type", Date)
|
|
60
|
+
], ChatReadCursor.prototype, "updatedAt", void 0);
|
|
61
|
+
exports.ChatReadCursor = ChatReadCursor = __decorate([
|
|
62
|
+
(0, typeorm_1.Entity)()
|
|
63
|
+
], ChatReadCursor);
|
|
64
|
+
//# sourceMappingURL=read-cursor.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"read-cursor.entity.js","sourceRoot":"","sources":["../../../src/chat/entities/read-cursor.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAQiB;AACjB,+DAAyD;AACzD,iEAAmD;AAG5C,IAAM,cAAc,GAApB,MAAM,cAAc;IAKhB,cAAc,CAAyB;IAUhD,YAAY,CAAmB;IAMtB,MAAM,CAAa;IAU5B,IAAI,CAAO;IAGX,EAAE,CAAO;IAGT,SAAS,CAAO;;;;CACjB,CAAA;AAtCY,wCAAc;AAKhB;IADR,IAAA,uBAAa,GAAE;;sDACgC;AAUhD;IALC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,sCAAgB,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE;QACzE,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,IAAI;KACd,CAAC;IACD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,CAAC;8BACzB,sCAAgB;oDAAC;AAMtB;IADR,IAAA,uBAAa,GAAE;;8CACY;AAU5B;IALC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE;QAC3C,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,IAAI;KACd,CAAC;IACD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;8BACzB,kBAAI;4CAAC;AAGX;IADC,IAAA,gBAAM,GAAE;8BACL,IAAI;0CAAC;AAGT;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;iDAAC;yBArCL,cAAc;IAD1B,IAAA,gBAAM,GAAE;GACI,cAAc,CAsC1B"}
|
|
@@ -4,5 +4,6 @@ exports.ConversationType = void 0;
|
|
|
4
4
|
var ConversationType;
|
|
5
5
|
(function (ConversationType) {
|
|
6
6
|
ConversationType["OneOnOne"] = "ONE_ON_ONE";
|
|
7
|
+
ConversationType["Community"] = "COMMUNITY";
|
|
7
8
|
})(ConversationType || (exports.ConversationType = ConversationType = {}));
|
|
8
9
|
//# sourceMappingURL=conversation-type.enum.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"conversation-type.enum.js","sourceRoot":"","sources":["../../../src/chat/enums/conversation-type.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,
|
|
1
|
+
{"version":3,"file":"conversation-type.enum.js","sourceRoot":"","sources":["../../../src/chat/enums/conversation-type.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,gBAMX;AAND,WAAY,gBAAgB;IAI1B,2CAAuB,CAAA;IACvB,2CAAuB,CAAA;AACzB,CAAC,EANW,gBAAgB,gCAAhB,gBAAgB,QAM3B"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
|
-
export declare const ApiPaginatedResponse: <TDto extends Type<
|
|
2
|
+
export declare const ApiPaginatedResponse: <TDto extends Type<unknown>>(dto: TDto) => <TFunction extends Function, Y>(target: TFunction | object, propertyKey?: string | symbol, descriptor?: TypedPropertyDescriptor<Y>) => void;
|
|
@@ -5,11 +5,11 @@ const common_1 = require("@nestjs/common");
|
|
|
5
5
|
const swagger_1 = require("@nestjs/swagger");
|
|
6
6
|
const paginated_response_dto_1 = require("../dto/paginated-response.dto");
|
|
7
7
|
const ApiPaginatedResponse = (dto) => {
|
|
8
|
-
return (0, common_1.applyDecorators)((0, swagger_1.ApiExtraModels)(paginated_response_dto_1.PaginatedResponseDto), (0, swagger_1.ApiOkResponse)({
|
|
8
|
+
return (0, common_1.applyDecorators)((0, swagger_1.ApiExtraModels)(paginated_response_dto_1.PaginatedResponseDto, dto), (0, swagger_1.ApiOkResponse)({
|
|
9
9
|
description: 'Successfully received paginated list of ' + dto.name,
|
|
10
10
|
schema: {
|
|
11
11
|
allOf: [
|
|
12
|
-
{ $ref: (0, swagger_1.getSchemaPath)(
|
|
12
|
+
{ $ref: (0, swagger_1.getSchemaPath)(paginated_response_dto_1.PaginatedResponseDto) },
|
|
13
13
|
{
|
|
14
14
|
properties: {
|
|
15
15
|
result: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api-paginated-response.js","sourceRoot":"","sources":["../../../src/common/decorators/api-paginated-response.ts"],"names":[],"mappings":";;;AAAA,2CAAuD;AACvD,6CAA+E;AAC/E,0EAAqE;AAE9D,MAAM,oBAAoB,GAAG,
|
|
1
|
+
{"version":3,"file":"api-paginated-response.js","sourceRoot":"","sources":["../../../src/common/decorators/api-paginated-response.ts"],"names":[],"mappings":";;;AAAA,2CAAuD;AACvD,6CAA+E;AAC/E,0EAAqE;AAE9D,MAAM,oBAAoB,GAAG,CAA6B,GAAS,EAAE,EAAE;IAC5E,OAAO,IAAA,wBAAe,EACpB,IAAA,wBAAc,EAAC,6CAAoB,EAAE,GAAG,CAAC,EACzC,IAAA,uBAAa,EAAC;QACZ,WAAW,EAAE,0CAA0C,GAAG,GAAG,CAAC,IAAI;QAClE,MAAM,EAAE;YACN,KAAK,EAAE;gBACL,EAAE,IAAI,EAAE,IAAA,uBAAa,EAAC,6CAAoB,CAAC,EAAE;gBAC7C;oBACE,UAAU,EAAE;wBACV,MAAM,EAAE;4BACN,IAAI,EAAE,OAAO;4BACb,KAAK,EAAE,EAAE,IAAI,EAAE,IAAA,uBAAa,EAAC,GAAG,CAAC,EAAE;yBACpC;qBACF;iBACF;aACF;SACF;KACF,CAAC,CACH,CAAC;AACJ,CAAC,CAAC;AApBW,QAAA,oBAAoB,wBAoB/B"}
|
|
@@ -16,19 +16,30 @@ const class_transformer_1 = require("class-transformer");
|
|
|
16
16
|
class PaginatedResponseDto {
|
|
17
17
|
result;
|
|
18
18
|
count;
|
|
19
|
+
next;
|
|
20
|
+
previous;
|
|
19
21
|
static _OPENAPI_METADATA_FACTORY() {
|
|
20
|
-
return { result: { required: true }, count: { required: true, type: () => Number } };
|
|
22
|
+
return { result: { required: true }, count: { required: true, type: () => Number }, next: { required: false, type: () => String }, previous: { required: false, type: () => String } };
|
|
21
23
|
}
|
|
22
24
|
}
|
|
23
25
|
exports.PaginatedResponseDto = PaginatedResponseDto;
|
|
24
26
|
__decorate([
|
|
25
|
-
(0, swagger_1.ApiProperty)({ description: '
|
|
27
|
+
(0, swagger_1.ApiProperty)({ description: 'Results', isArray: true }),
|
|
26
28
|
(0, class_transformer_1.Expose)(),
|
|
27
29
|
__metadata("design:type", Array)
|
|
28
30
|
], PaginatedResponseDto.prototype, "result", void 0);
|
|
29
31
|
__decorate([
|
|
30
|
-
(0, swagger_1.ApiProperty)({ description: '
|
|
32
|
+
(0, swagger_1.ApiProperty)({ description: 'Total number available' }),
|
|
31
33
|
(0, class_transformer_1.Expose)(),
|
|
32
34
|
__metadata("design:type", Number)
|
|
33
35
|
], PaginatedResponseDto.prototype, "count", void 0);
|
|
36
|
+
__decorate([
|
|
37
|
+
(0, swagger_1.ApiProperty)({ description: 'Cursor to use for the next page' }),
|
|
38
|
+
(0, class_transformer_1.Expose)(),
|
|
39
|
+
__metadata("design:type", String)
|
|
40
|
+
], PaginatedResponseDto.prototype, "next", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, swagger_1.ApiProperty)({ description: 'Cursor to use for the previous page' }),
|
|
43
|
+
__metadata("design:type", String)
|
|
44
|
+
], PaginatedResponseDto.prototype, "previous", void 0);
|
|
34
45
|
//# sourceMappingURL=paginated-response.dto.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"paginated-response.dto.js","sourceRoot":"","sources":["../../../src/common/dto/paginated-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAAiD;AAEjD,MAAa,oBAAoB;IAG/B,MAAM,CAAM;IAIZ,KAAK,CAAS;;;;
|
|
1
|
+
{"version":3,"file":"paginated-response.dto.js","sourceRoot":"","sources":["../../../src/common/dto/paginated-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAAiD;AAEjD,MAAa,oBAAoB;IAG/B,MAAM,CAAM;IAIZ,KAAK,CAAS;IAId,IAAI,CAAU;IAGd,QAAQ,CAAU;;;;CACnB;AAfD,oDAeC;AAZC;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IACtD,IAAA,0BAAM,GAAE;;oDACG;AAIZ;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,wBAAwB,EAAE,CAAC;IACtD,IAAA,0BAAM,GAAE;;mDACK;AAId;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,iCAAiC,EAAE,CAAC;IAC/D,IAAA,0BAAM,GAAE;;kDACK;AAGd;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,qCAAqC,EAAE,CAAC;;sDAClD"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NETWORK = exports.HOST = void 0;
|
|
3
|
+
exports.NETWORK = exports.BASE_URL = exports.HOST = exports.SCHEME = void 0;
|
|
4
|
+
exports.SCHEME = 'scheme';
|
|
4
5
|
exports.HOST = 'host';
|
|
6
|
+
exports.BASE_URL = 'baseUrl';
|
|
5
7
|
exports.NETWORK = 'network';
|
|
6
8
|
//# sourceMappingURL=injection-tokens.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"injection-tokens.js","sourceRoot":"","sources":["../../src/common/injection-tokens.ts"],"names":[],"mappings":";;;AAAa,QAAA,IAAI,GAAG,MAAM,CAAC;AACd,QAAA,OAAO,GAAG,SAAS,CAAC"}
|
|
1
|
+
{"version":3,"file":"injection-tokens.js","sourceRoot":"","sources":["../../src/common/injection-tokens.ts"],"names":[],"mappings":";;;AAAa,QAAA,MAAM,GAAG,QAAQ,CAAC;AAClB,QAAA,IAAI,GAAG,MAAM,CAAC;AACd,QAAA,QAAQ,GAAG,SAAS,CAAC;AACrB,QAAA,OAAO,GAAG,SAAS,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decodeCursor = exports.createCursor = void 0;
|
|
4
|
+
const createCursor = (field, op, value) => {
|
|
5
|
+
return Buffer.from(JSON.stringify([field, op, value]), 'utf8').toString('base64');
|
|
6
|
+
};
|
|
7
|
+
exports.createCursor = createCursor;
|
|
8
|
+
const decodeCursor = (cursor) => {
|
|
9
|
+
return JSON.parse(Buffer.from(cursor, 'base64').toString());
|
|
10
|
+
};
|
|
11
|
+
exports.decodeCursor = decodeCursor;
|
|
12
|
+
//# sourceMappingURL=cursor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cursor.js","sourceRoot":"","sources":["../../../src/common/utils/cursor.ts"],"names":[],"mappings":";;;AAGO,MAAM,YAAY,GAAG,CAC1B,KAAa,EACb,EAAe,EACf,KAAsB,EACd,EAAE;IACV,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,QAAQ,CACrE,QAAQ,CACT,CAAC;AACJ,CAAC,CAAC;AARW,QAAA,YAAY,gBAQvB;AAMK,MAAM,YAAY,GAAG,CAC1B,MAAc,EAC0B,EAAE;IAC1C,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;AAC9D,CAAC,CAAC;AAJW,QAAA,YAAY,gBAIvB"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { StreamableFile } from '@nestjs/common';
|
|
2
|
+
import { User } from '~/user/entities/user.entity';
|
|
3
|
+
import { CommunityResponseDto } from '../dto/community-response.dto';
|
|
4
|
+
import { CommunityAvatarService } from './avatar.service';
|
|
5
|
+
import { CommunityIdDto } from '../dto';
|
|
6
|
+
export declare class CommunityAvatarController {
|
|
7
|
+
private service;
|
|
8
|
+
constructor(service: CommunityAvatarService);
|
|
9
|
+
uploadAvatar(dto: CommunityIdDto, file: Express.Multer.File): Promise<CommunityResponseDto>;
|
|
10
|
+
downloadAvatar(userId: User['id'], filename: any): Promise<StreamableFile>;
|
|
11
|
+
}
|
|
@@ -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
|