@social.dev/server-sdk 0.0.1-alpha.7 → 0.0.1-alpha.71
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 +3 -3
- package/dist/app.module.js +11 -6
- 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/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.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 +9 -5
- package/dist/auth/session/session.service.js.map +1 -1
- package/dist/bootstrap.d.ts +2 -1
- package/dist/bootstrap.js +6 -0
- 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 -2
- package/dist/chat/chat.module.js.map +1 -1
- package/dist/chat/chat.service.d.ts +63 -12
- package/dist/chat/chat.service.js +447 -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/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 +147 -20
- 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.service.d.ts +10 -2
- package/dist/configs/configs.service.js.map +1 -1
- 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 +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/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 +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/dto/media-response.dto.d.ts +2 -0
- package/dist/media/dto/media-response.dto.js +14 -1
- 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 -4
- 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/{common/entities/base.repository.js → notification/dto/delete-push-token.dto.js} +14 -20
- package/dist/notification/dto/delete-push-token.dto.js.map +1 -0
- package/dist/notification/dto/register-push-token.dto.d.ts +5 -0
- package/dist/notification/dto/register-push-token.dto.js +38 -0
- package/dist/notification/dto/register-push-token.dto.js.map +1 -0
- package/dist/notification/entities/push-token.entity.d.ts +11 -0
- package/dist/notification/entities/push-token.entity.js +60 -0
- package/dist/notification/entities/push-token.entity.js.map +1 -0
- package/dist/notification/enums/push-service.enum.d.ts +6 -0
- package/dist/notification/enums/push-service.enum.js +11 -0
- package/dist/notification/enums/push-service.enum.js.map +1 -0
- package/dist/notification/hook-listener.service.d.ts +13 -0
- package/dist/notification/hook-listener.service.js +58 -0
- package/dist/notification/hook-listener.service.js.map +1 -0
- package/dist/notification/notification.module.d.ts +2 -0
- package/dist/notification/notification.module.js +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 +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 +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 +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 +15 -4
- package/dist/1756201302119-migrations.d.ts +0 -6
- 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
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { CommunityService } from './community.service';
|
|
2
2
|
import { CreateCommunityDto } from './dto/create-community.dto';
|
|
3
|
-
import {
|
|
4
|
-
import { Community } from './entities/community.entity';
|
|
3
|
+
import { UpdateCommunityDto } from './dto/update-community.dto';
|
|
5
4
|
import { CommunityMembershipResponseDto, CommunityResponseDto } from './dto/community-response.dto';
|
|
6
5
|
import { PaginatedResponseDto } from '~/common/dto/paginated-response.dto';
|
|
7
6
|
import { CommunityMembershipListItemResponseDto } from './dto/community-members-response.dto';
|
|
@@ -12,14 +11,18 @@ export declare class CommunityController {
|
|
|
12
11
|
private readonly service;
|
|
13
12
|
private readonly userService;
|
|
14
13
|
constructor(service: CommunityService, userService: UserService);
|
|
15
|
-
create(dto: CreateCommunityDto): Promise<
|
|
14
|
+
create(dto: CreateCommunityDto): Promise<CommunityResponseDto>;
|
|
16
15
|
info(id: string): Promise<CommunityResponseDto>;
|
|
17
|
-
|
|
16
|
+
update(updateCommunityDto: UpdateCommunityDto): Promise<CommunityResponseDto>;
|
|
17
|
+
remove({ community: id }: CommunityIdDto): Promise<boolean>;
|
|
18
18
|
join(dto: CommunityIdDto): Promise<CommunityMembershipResponseDto>;
|
|
19
19
|
leave({ community: id }: CommunityIdDto): Promise<boolean>;
|
|
20
20
|
removeMember({ community: communityId, user: userId }: CommunityIdAndUserIdDto): Promise<boolean>;
|
|
21
|
+
inviteMember({ community: communityId, user: userId }: CommunityIdAndUserIdDto): Promise<import("./entities/community-member.entity").CommunityMember>;
|
|
21
22
|
acceptMember({ community: communityId, user: userId }: CommunityIdAndUserIdDto): Promise<boolean>;
|
|
23
|
+
acceptInvite({ community: communityId }: CommunityIdDto): Promise<boolean>;
|
|
24
|
+
declineInvite({ community: communityId }: CommunityIdDto): Promise<boolean>;
|
|
22
25
|
getFake(): CommunityMembershipListItemResponseDto;
|
|
23
26
|
members(communityId: string, limit?: number, offset?: number, status?: CommunityMemberStatus): Promise<PaginatedResponseDto<CommunityMembershipListItemResponseDto>>;
|
|
24
|
-
listCommunities(limit
|
|
27
|
+
listCommunities(limit?: number, offset?: number, status?: CommunityMemberStatus): Promise<PaginatedResponseDto<CommunityResponseDto>>;
|
|
25
28
|
}
|
|
@@ -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 }) {
|
|
@@ -77,6 +82,20 @@ let CommunityController = class CommunityController {
|
|
|
77
82
|
user,
|
|
78
83
|
});
|
|
79
84
|
}
|
|
85
|
+
async inviteMember({ community: communityId, user: userId }) {
|
|
86
|
+
const community = await this.service.findOne(+communityId);
|
|
87
|
+
if (!community) {
|
|
88
|
+
throw new common_1.NotFoundException('Community was not found');
|
|
89
|
+
}
|
|
90
|
+
const user = await this.userService.findOne(+userId);
|
|
91
|
+
if (!user) {
|
|
92
|
+
throw new common_1.NotFoundException('User was not found');
|
|
93
|
+
}
|
|
94
|
+
return await this.service.inviteMember({
|
|
95
|
+
community,
|
|
96
|
+
user,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
80
99
|
async acceptMember({ community: communityId, user: userId }) {
|
|
81
100
|
const community = await this.service.findOne(+communityId);
|
|
82
101
|
if (!community) {
|
|
@@ -91,6 +110,22 @@ let CommunityController = class CommunityController {
|
|
|
91
110
|
user,
|
|
92
111
|
});
|
|
93
112
|
}
|
|
113
|
+
async acceptInvite({ community: communityId }) {
|
|
114
|
+
const community = await this.service.findOne(+communityId);
|
|
115
|
+
if (!community) {
|
|
116
|
+
throw new common_1.NotFoundException('Community was not found');
|
|
117
|
+
}
|
|
118
|
+
const user = context_1.Context.getUser();
|
|
119
|
+
return await this.service.acceptInvite({ community, user });
|
|
120
|
+
}
|
|
121
|
+
async declineInvite({ community: communityId }) {
|
|
122
|
+
const community = await this.service.findOne(+communityId);
|
|
123
|
+
if (!community) {
|
|
124
|
+
throw new common_1.NotFoundException('Community was not found');
|
|
125
|
+
}
|
|
126
|
+
const user = context_1.Context.getUser();
|
|
127
|
+
return await this.service.declineInvite({ community, user });
|
|
128
|
+
}
|
|
94
129
|
getFake() {
|
|
95
130
|
return {};
|
|
96
131
|
}
|
|
@@ -108,19 +143,19 @@ let CommunityController = class CommunityController {
|
|
|
108
143
|
return {
|
|
109
144
|
result: result.map((member) => (0, class_transformer_1.plainToInstance)(community_members_response_dto_1.CommunityMembershipListItemResponseDto, member)),
|
|
110
145
|
count,
|
|
146
|
+
next: '',
|
|
147
|
+
previous: '',
|
|
111
148
|
};
|
|
112
149
|
}
|
|
113
|
-
async listCommunities(limit = 100, offset = 0,
|
|
150
|
+
async listCommunities(limit = 100, offset = 0, status) {
|
|
114
151
|
let result, count = 0;
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
}
|
|
118
|
-
else {
|
|
119
|
-
[result, count] = await this.service.findAll(limit, offset);
|
|
120
|
-
}
|
|
152
|
+
const user = context_1.Context.getUser();
|
|
153
|
+
[result, count] = await this.service.findAll(limit, offset, status);
|
|
121
154
|
return {
|
|
122
155
|
result: result.map((s) => (0, class_transformer_1.plainToInstance)(community_response_dto_1.CommunityResponseDto, s)),
|
|
123
156
|
count,
|
|
157
|
+
next: '',
|
|
158
|
+
previous: '',
|
|
124
159
|
};
|
|
125
160
|
}
|
|
126
161
|
};
|
|
@@ -132,11 +167,11 @@ __decorate([
|
|
|
132
167
|
If successful, the command returns a community entity.`,
|
|
133
168
|
}),
|
|
134
169
|
(0, common_1.Post)('community.create'),
|
|
135
|
-
openapi.ApiResponse({ status: 201, type: require("./
|
|
170
|
+
openapi.ApiResponse({ status: 201, type: require("./dto/community-response.dto").CommunityResponseDto }),
|
|
136
171
|
__param(0, (0, common_1.Body)()),
|
|
137
172
|
__metadata("design:type", Function),
|
|
138
173
|
__metadata("design:paramtypes", [create_community_dto_1.CreateCommunityDto]),
|
|
139
|
-
__metadata("design:returntype",
|
|
174
|
+
__metadata("design:returntype", Promise)
|
|
140
175
|
], CommunityController.prototype, "create", null);
|
|
141
176
|
__decorate([
|
|
142
177
|
(0, swagger_1.ApiOperation)({
|
|
@@ -150,13 +185,21 @@ __decorate([
|
|
|
150
185
|
__metadata("design:paramtypes", [String]),
|
|
151
186
|
__metadata("design:returntype", Promise)
|
|
152
187
|
], CommunityController.prototype, "info", null);
|
|
188
|
+
__decorate([
|
|
189
|
+
(0, common_1.Post)('community.update'),
|
|
190
|
+
openapi.ApiResponse({ status: 201, type: require("./dto/community-response.dto").CommunityResponseDto }),
|
|
191
|
+
__param(0, (0, common_1.Body)()),
|
|
192
|
+
__metadata("design:type", Function),
|
|
193
|
+
__metadata("design:paramtypes", [update_community_dto_1.UpdateCommunityDto]),
|
|
194
|
+
__metadata("design:returntype", Promise)
|
|
195
|
+
], CommunityController.prototype, "update", null);
|
|
153
196
|
__decorate([
|
|
154
197
|
(0, swagger_1.ApiOperation)({
|
|
155
198
|
summary: 'Delete a community',
|
|
156
199
|
description: `This Community API method deletes a community and all of its entities.`,
|
|
157
200
|
}),
|
|
158
201
|
(0, common_1.Post)('community.delete'),
|
|
159
|
-
openapi.ApiResponse({ status: 201, type:
|
|
202
|
+
openapi.ApiResponse({ status: 201, type: Boolean }),
|
|
160
203
|
__param(0, (0, common_1.Body)()),
|
|
161
204
|
__metadata("design:type", Function),
|
|
162
205
|
__metadata("design:paramtypes", [dto_1.CommunityIdDto]),
|
|
@@ -202,6 +245,19 @@ __decorate([
|
|
|
202
245
|
__metadata("design:paramtypes", [dto_1.CommunityIdAndUserIdDto]),
|
|
203
246
|
__metadata("design:returntype", Promise)
|
|
204
247
|
], CommunityController.prototype, "removeMember", null);
|
|
248
|
+
__decorate([
|
|
249
|
+
(0, swagger_1.ApiOperation)({
|
|
250
|
+
summary: 'Invite a user to a community',
|
|
251
|
+
description: `This Community API method invites a user to a community. The user will receive an invitation that they can accept or decline.`,
|
|
252
|
+
}),
|
|
253
|
+
(0, common_1.Post)('community.members.invite'),
|
|
254
|
+
(0, common_1.UseGuards)(auth_guard_1.AuthGuard),
|
|
255
|
+
openapi.ApiResponse({ status: 201, type: require("./entities/community-member.entity").CommunityMember }),
|
|
256
|
+
__param(0, (0, common_1.Body)()),
|
|
257
|
+
__metadata("design:type", Function),
|
|
258
|
+
__metadata("design:paramtypes", [dto_1.CommunityIdAndUserIdDto]),
|
|
259
|
+
__metadata("design:returntype", Promise)
|
|
260
|
+
], CommunityController.prototype, "inviteMember", null);
|
|
205
261
|
__decorate([
|
|
206
262
|
(0, swagger_1.ApiOperation)({
|
|
207
263
|
summary: 'Accept a member from a community',
|
|
@@ -215,6 +271,32 @@ __decorate([
|
|
|
215
271
|
__metadata("design:paramtypes", [dto_1.CommunityIdAndUserIdDto]),
|
|
216
272
|
__metadata("design:returntype", Promise)
|
|
217
273
|
], CommunityController.prototype, "acceptMember", null);
|
|
274
|
+
__decorate([
|
|
275
|
+
(0, swagger_1.ApiOperation)({
|
|
276
|
+
summary: 'Accept an invite to a community',
|
|
277
|
+
description: `This Community API method allows a user to accept their invitation to a community.`,
|
|
278
|
+
}),
|
|
279
|
+
(0, common_1.Post)('community.invite.accept'),
|
|
280
|
+
(0, common_1.UseGuards)(auth_guard_1.AuthGuard),
|
|
281
|
+
openapi.ApiResponse({ status: 201, type: Boolean }),
|
|
282
|
+
__param(0, (0, common_1.Body)()),
|
|
283
|
+
__metadata("design:type", Function),
|
|
284
|
+
__metadata("design:paramtypes", [dto_1.CommunityIdDto]),
|
|
285
|
+
__metadata("design:returntype", Promise)
|
|
286
|
+
], CommunityController.prototype, "acceptInvite", null);
|
|
287
|
+
__decorate([
|
|
288
|
+
(0, swagger_1.ApiOperation)({
|
|
289
|
+
summary: 'Decline an invite to a community',
|
|
290
|
+
description: `This Community API method allows a user to decline their invitation to a community.`,
|
|
291
|
+
}),
|
|
292
|
+
(0, common_1.Post)('community.invite.decline'),
|
|
293
|
+
(0, common_1.UseGuards)(auth_guard_1.AuthGuard),
|
|
294
|
+
openapi.ApiResponse({ status: 201, type: Boolean }),
|
|
295
|
+
__param(0, (0, common_1.Body)()),
|
|
296
|
+
__metadata("design:type", Function),
|
|
297
|
+
__metadata("design:paramtypes", [dto_1.CommunityIdDto]),
|
|
298
|
+
__metadata("design:returntype", Promise)
|
|
299
|
+
], CommunityController.prototype, "declineInvite", null);
|
|
218
300
|
__decorate([
|
|
219
301
|
(0, common_1.Get)('oogogogo'),
|
|
220
302
|
openapi.ApiResponse({ status: 200, type: require("./dto/community-members-response.dto").CommunityMembershipListItemResponseDto }),
|
|
@@ -253,16 +335,19 @@ __decorate([
|
|
|
253
335
|
(0, common_1.UseGuards)(auth_guard_1.AuthGuard),
|
|
254
336
|
(0, swagger_1.ApiQuery)({ name: 'limit', required: false }),
|
|
255
337
|
(0, swagger_1.ApiQuery)({ name: 'offset', required: false }),
|
|
256
|
-
(0, swagger_1.ApiQuery)({
|
|
338
|
+
(0, swagger_1.ApiQuery)({
|
|
339
|
+
name: 'status',
|
|
340
|
+
required: false,
|
|
341
|
+
enum: community_status_enum_1.default,
|
|
342
|
+
}),
|
|
257
343
|
(0, api_paginated_response_1.ApiPaginatedResponse)(community_response_dto_1.CommunityResponseDto),
|
|
258
344
|
openapi.ApiResponse({ status: 200 }),
|
|
259
345
|
__param(0, (0, common_1.Query)('limit')),
|
|
260
346
|
__param(0, (0, common_1.Optional)()),
|
|
261
347
|
__param(1, (0, common_1.Query)('offset')),
|
|
262
|
-
__param(2, (0, common_1.Query)('
|
|
263
|
-
__param(3, (0, common_1.Req)()),
|
|
348
|
+
__param(2, (0, common_1.Query)('status')),
|
|
264
349
|
__metadata("design:type", Function),
|
|
265
|
-
__metadata("design:paramtypes", [Number, Number,
|
|
350
|
+
__metadata("design:paramtypes", [Number, Number, String]),
|
|
266
351
|
__metadata("design:returntype", Promise)
|
|
267
352
|
], CommunityController.prototype, "listCommunities", null);
|
|
268
353
|
exports.CommunityController = CommunityController = __decorate([
|
|
@@ -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,37 +1,57 @@
|
|
|
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
|
-
findAll(limit?: number, offset?: number): Promise<[Community[], number]>;
|
|
18
|
+
findAll(limit?: number, offset?: number, status?: CommunityMemberStatus): 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;
|
|
25
32
|
user: User;
|
|
26
33
|
}): Promise<boolean>;
|
|
34
|
+
inviteMember({ community, user, }: {
|
|
35
|
+
community: Community;
|
|
36
|
+
user: User;
|
|
37
|
+
}): Promise<CommunityMember>;
|
|
27
38
|
acceptMember({ community, user, }: {
|
|
28
39
|
community: Community;
|
|
29
40
|
user: User;
|
|
30
41
|
}): Promise<boolean>;
|
|
42
|
+
acceptInvite({ community, user, }: {
|
|
43
|
+
community: Community;
|
|
44
|
+
user: User;
|
|
45
|
+
}): Promise<boolean>;
|
|
46
|
+
declineInvite({ community, user, }: {
|
|
47
|
+
community: Community;
|
|
48
|
+
user: User;
|
|
49
|
+
}): Promise<boolean>;
|
|
31
50
|
findMembers({ community, limit, offset, status, }: {
|
|
32
51
|
community: Community;
|
|
33
52
|
limit: number;
|
|
34
53
|
offset: number;
|
|
35
54
|
status?: CommunityMemberStatus;
|
|
36
55
|
}): Promise<[CommunityMember[], number]>;
|
|
56
|
+
getMembership(user: User, community: Community): CommunityMember | null;
|
|
37
57
|
}
|
|
@@ -31,26 +31,51 @@ let CommunityService = class CommunityService {
|
|
|
31
31
|
repository;
|
|
32
32
|
userRepository;
|
|
33
33
|
membershipRepository;
|
|
34
|
+
dataSource;
|
|
34
35
|
aclFactory;
|
|
35
|
-
constructor(repository, userRepository, membershipRepository, aclFactory) {
|
|
36
|
+
constructor(repository, userRepository, membershipRepository, dataSource, aclFactory) {
|
|
36
37
|
this.repository = repository;
|
|
37
38
|
this.userRepository = userRepository;
|
|
38
39
|
this.membershipRepository = membershipRepository;
|
|
40
|
+
this.dataSource = dataSource;
|
|
39
41
|
this.aclFactory = aclFactory;
|
|
40
42
|
}
|
|
41
43
|
async create(createCommunityDto) {
|
|
42
|
-
const
|
|
44
|
+
const queryRunner = this.dataSource.createQueryRunner();
|
|
45
|
+
await queryRunner.connect();
|
|
46
|
+
await queryRunner.startTransaction();
|
|
47
|
+
const community = queryRunner.manager.create(community_entity_1.Community, {
|
|
43
48
|
name: createCommunityDto.name,
|
|
44
|
-
|
|
49
|
+
privacy: createCommunityDto.privacy,
|
|
50
|
+
network: { id: context_1.Context.getNetwork().id },
|
|
45
51
|
});
|
|
46
|
-
await
|
|
47
|
-
|
|
52
|
+
await queryRunner.manager.insert(community_entity_1.Community, community);
|
|
53
|
+
await this.join({
|
|
54
|
+
community,
|
|
55
|
+
user: context_1.Context.getUser(),
|
|
56
|
+
role: community_role_enum_1.default.Owner,
|
|
57
|
+
status: community_status_enum_1.default.Active,
|
|
58
|
+
}, queryRunner);
|
|
59
|
+
await queryRunner.commitTransaction();
|
|
60
|
+
return community;
|
|
48
61
|
}
|
|
49
|
-
findAll(limit = 100, offset = 0) {
|
|
50
|
-
|
|
62
|
+
async findAll(limit = 100, offset = 0, status) {
|
|
63
|
+
const query = this.repository
|
|
51
64
|
.createQueryBuilder('c')
|
|
52
65
|
.loadRelationCountAndMap('c.membersCount', 'c.members')
|
|
53
|
-
.
|
|
66
|
+
.limit(limit)
|
|
67
|
+
.offset(offset);
|
|
68
|
+
if (status) {
|
|
69
|
+
const user = context_1.Context.getUser();
|
|
70
|
+
if (!user) {
|
|
71
|
+
throw new common_1.ForbiddenException();
|
|
72
|
+
}
|
|
73
|
+
query
|
|
74
|
+
.innerJoin('c.members', 'm')
|
|
75
|
+
.where('m.userId = :userId', { userId: user.id })
|
|
76
|
+
.andWhere('m.status = :status', { status });
|
|
77
|
+
}
|
|
78
|
+
return await query.getManyAndCount();
|
|
54
79
|
}
|
|
55
80
|
async findAllByMember(user, limit = 100, offset = 0) {
|
|
56
81
|
const query = await this.repository
|
|
@@ -66,27 +91,61 @@ let CommunityService = class CommunityService {
|
|
|
66
91
|
findOne(id) {
|
|
67
92
|
return this.repository.findOneBy({ id: id });
|
|
68
93
|
}
|
|
69
|
-
update(id, updateCommunityDto) {
|
|
70
|
-
|
|
94
|
+
async update(id, updateCommunityDto) {
|
|
95
|
+
const community = await this.findOne(id);
|
|
96
|
+
if (!community) {
|
|
97
|
+
throw new common_1.NotFoundException();
|
|
98
|
+
}
|
|
99
|
+
if (this.aclFactory
|
|
100
|
+
.withUser(context_1.Context.getUser())
|
|
101
|
+
.cannot(acl_factory_1.Action.Update, community)) {
|
|
102
|
+
throw new common_1.ForbiddenException();
|
|
103
|
+
}
|
|
104
|
+
const update = {
|
|
105
|
+
...updateCommunityDto,
|
|
106
|
+
community: undefined,
|
|
107
|
+
};
|
|
108
|
+
await this.repository.update({ network: { id: context_1.Context.getNetwork().id }, id: community.id }, update);
|
|
109
|
+
return {
|
|
110
|
+
...community,
|
|
111
|
+
...updateCommunityDto,
|
|
112
|
+
};
|
|
71
113
|
}
|
|
72
|
-
remove(id) {
|
|
73
|
-
|
|
114
|
+
async remove(id) {
|
|
115
|
+
const community = await this.findOne(id);
|
|
116
|
+
if (!community) {
|
|
117
|
+
throw new common_1.NotFoundException();
|
|
118
|
+
}
|
|
119
|
+
if (this.aclFactory
|
|
120
|
+
.withUser(context_1.Context.getUser())
|
|
121
|
+
.cannot(acl_factory_1.Action.Delete, community)) {
|
|
122
|
+
throw new common_1.ForbiddenException();
|
|
123
|
+
}
|
|
124
|
+
return ((await this.repository.delete({
|
|
125
|
+
id: community.id,
|
|
126
|
+
network: { id: context_1.Context.getNetwork().id },
|
|
127
|
+
})).affected === 1);
|
|
74
128
|
}
|
|
75
|
-
async join(community, user) {
|
|
129
|
+
async join({ community, user, role = community_role_enum_1.default.Member, status, }, queryRunner) {
|
|
130
|
+
if (!queryRunner) {
|
|
131
|
+
queryRunner = this.dataSource.createQueryRunner();
|
|
132
|
+
}
|
|
76
133
|
try {
|
|
77
134
|
if (community.privacy === community_privacy_enum_1.default.Hidden) {
|
|
78
135
|
throw 'Not implemented';
|
|
79
136
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
137
|
+
status =
|
|
138
|
+
status ||
|
|
139
|
+
(community.privacy === community_privacy_enum_1.default.Public
|
|
140
|
+
? community_status_enum_1.default.Active
|
|
141
|
+
: community_status_enum_1.default.Requested);
|
|
142
|
+
const membership = queryRunner.manager.create(community_member_entity_1.CommunityMember, {
|
|
84
143
|
user: user,
|
|
85
144
|
community: community,
|
|
86
|
-
role
|
|
145
|
+
role,
|
|
87
146
|
status,
|
|
88
147
|
});
|
|
89
|
-
await
|
|
148
|
+
await queryRunner.manager.save(membership);
|
|
90
149
|
return membership;
|
|
91
150
|
}
|
|
92
151
|
catch (err) {
|
|
@@ -137,6 +196,30 @@ let CommunityService = class CommunityService {
|
|
|
137
196
|
throw err;
|
|
138
197
|
}
|
|
139
198
|
}
|
|
199
|
+
async inviteMember({ community, user, }) {
|
|
200
|
+
if (this.aclFactory
|
|
201
|
+
.withUser(context_1.Context.getUser())
|
|
202
|
+
.cannot(acl_factory_1.Action.Update, community)) {
|
|
203
|
+
throw new common_1.ForbiddenException('You do not have permission to invite users to this community');
|
|
204
|
+
}
|
|
205
|
+
const existingMembership = await this.membershipRepository.findOneBy({
|
|
206
|
+
userId: user.id,
|
|
207
|
+
communityId: community.id,
|
|
208
|
+
});
|
|
209
|
+
if (existingMembership) {
|
|
210
|
+
throw new common_1.ConflictException('User is already a member or has been invited');
|
|
211
|
+
}
|
|
212
|
+
const queryRunner = this.dataSource.createQueryRunner();
|
|
213
|
+
await queryRunner.connect();
|
|
214
|
+
const membership = await this.join({
|
|
215
|
+
community,
|
|
216
|
+
user,
|
|
217
|
+
role: community_role_enum_1.default.Member,
|
|
218
|
+
status: community_status_enum_1.default.Invited,
|
|
219
|
+
}, queryRunner);
|
|
220
|
+
await queryRunner.release();
|
|
221
|
+
return membership;
|
|
222
|
+
}
|
|
140
223
|
async acceptMember({ community, user, }) {
|
|
141
224
|
try {
|
|
142
225
|
const membership = await this.membershipRepository.findOneBy({
|
|
@@ -169,15 +252,50 @@ let CommunityService = class CommunityService {
|
|
|
169
252
|
throw err;
|
|
170
253
|
}
|
|
171
254
|
}
|
|
255
|
+
async acceptInvite({ community, user, }) {
|
|
256
|
+
const membership = await this.membershipRepository.findOneBy({
|
|
257
|
+
userId: user.id,
|
|
258
|
+
communityId: community.id,
|
|
259
|
+
});
|
|
260
|
+
if (!membership) {
|
|
261
|
+
throw new common_1.NotFoundException('Invitation not found');
|
|
262
|
+
}
|
|
263
|
+
if (membership.status !== community_status_enum_1.default.Invited) {
|
|
264
|
+
throw new common_1.ConflictException('You do not have a pending invitation');
|
|
265
|
+
}
|
|
266
|
+
await this.membershipRepository.update({
|
|
267
|
+
userId: user.id,
|
|
268
|
+
communityId: community.id,
|
|
269
|
+
}, { status: community_status_enum_1.default.Active });
|
|
270
|
+
return true;
|
|
271
|
+
}
|
|
272
|
+
async declineInvite({ community, user, }) {
|
|
273
|
+
const membership = await this.membershipRepository.findOneBy({
|
|
274
|
+
userId: user.id,
|
|
275
|
+
communityId: community.id,
|
|
276
|
+
});
|
|
277
|
+
if (!membership) {
|
|
278
|
+
throw new common_1.NotFoundException('Invitation not found');
|
|
279
|
+
}
|
|
280
|
+
if (membership.status !== community_status_enum_1.default.Invited) {
|
|
281
|
+
throw new common_1.ConflictException('You do not have a pending invitation');
|
|
282
|
+
}
|
|
283
|
+
await this.membershipRepository.delete({
|
|
284
|
+
userId: user.id,
|
|
285
|
+
communityId: community.id,
|
|
286
|
+
});
|
|
287
|
+
return true;
|
|
288
|
+
}
|
|
172
289
|
async findMembers({ community, limit = 100, offset = 0, status, }) {
|
|
173
290
|
if (this.aclFactory
|
|
174
291
|
.withUser(context_1.Context.getUser())
|
|
175
292
|
.cannot(acl_factory_1.Action.Read, community)) {
|
|
293
|
+
console.log(community);
|
|
176
294
|
throw new common_1.ForbiddenException();
|
|
177
295
|
}
|
|
178
296
|
const result = await this.membershipRepository.findAndCount({
|
|
179
297
|
where: {
|
|
180
|
-
community,
|
|
298
|
+
community: { id: community.id },
|
|
181
299
|
status,
|
|
182
300
|
},
|
|
183
301
|
take: limit,
|
|
@@ -185,6 +303,14 @@ let CommunityService = class CommunityService {
|
|
|
185
303
|
});
|
|
186
304
|
return result;
|
|
187
305
|
}
|
|
306
|
+
getMembership(user, community) {
|
|
307
|
+
for (let membership of user.communities) {
|
|
308
|
+
if (membership.community.id === community.id) {
|
|
309
|
+
return membership;
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
return null;
|
|
313
|
+
}
|
|
188
314
|
};
|
|
189
315
|
exports.CommunityService = CommunityService;
|
|
190
316
|
exports.CommunityService = CommunityService = __decorate([
|
|
@@ -195,6 +321,7 @@ exports.CommunityService = CommunityService = __decorate([
|
|
|
195
321
|
__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
196
322
|
typeorm_2.Repository,
|
|
197
323
|
typeorm_2.Repository,
|
|
324
|
+
typeorm_2.DataSource,
|
|
198
325
|
acl_factory_1.AclFactory])
|
|
199
326
|
], CommunityService);
|
|
200
327
|
//# sourceMappingURL=community.service.js.map
|