@social.dev/server-sdk 0.0.1-alpha.5 → 0.0.1-alpha.50
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +696 -40
- package/dist/app.module.d.ts +3 -3
- package/dist/app.module.js +11 -6
- package/dist/app.module.js.map +1 -1
- package/dist/auth/auth.controller.d.ts +9 -1
- package/dist/auth/auth.controller.js +53 -2
- package/dist/auth/auth.controller.js.map +1 -1
- package/dist/auth/auth.module.js +4 -0
- package/dist/auth/auth.module.js.map +1 -1
- package/dist/auth/auth.service.d.ts +7 -6
- package/dist/auth/auth.service.js +18 -15
- package/dist/auth/auth.service.js.map +1 -1
- package/dist/auth/dto/login-success.dto.d.ts +1 -1
- package/dist/auth/dto/login-success.dto.js +6 -3
- package/dist/auth/dto/login-success.dto.js.map +1 -1
- package/dist/auth/dto/register-success.dto.d.ts +3 -0
- package/dist/auth/dto/register-success.dto.js +12 -0
- package/dist/auth/dto/register-success.dto.js.map +1 -0
- package/dist/auth/dto/register.dto.d.ts +6 -0
- package/dist/auth/dto/register.dto.js +45 -0
- package/dist/auth/dto/register.dto.js.map +1 -0
- package/dist/auth/enums/auth-method.enum.d.ts +2 -2
- package/dist/auth/enums/auth-method.enum.js +2 -2
- package/dist/auth/enums/auth-method.enum.js.map +1 -1
- package/dist/auth/oidc/dto/requests.d.ts +6 -0
- package/dist/auth/oidc/dto/requests.js +47 -0
- package/dist/auth/oidc/dto/requests.js.map +1 -0
- package/dist/auth/oidc/dto/responses.js +1 -1
- package/dist/auth/oidc/dto/responses.js.map +1 -1
- package/dist/auth/oidc/oidc.controller.d.ts +7 -2
- package/dist/auth/oidc/oidc.controller.js +31 -17
- package/dist/auth/oidc/oidc.controller.js.map +1 -1
- package/dist/auth/oidc/oidc.module.js +2 -0
- package/dist/auth/oidc/oidc.module.js.map +1 -1
- package/dist/auth/oidc/oidc.service.d.ts +13 -7
- package/dist/auth/oidc/oidc.service.js +38 -30
- package/dist/auth/oidc/oidc.service.js.map +1 -1
- package/dist/auth/session/session.controller.js +8 -3
- package/dist/auth/session/session.controller.js.map +1 -1
- package/dist/auth/session/session.service.d.ts +2 -2
- package/dist/auth/session/session.service.js +9 -5
- package/dist/auth/session/session.service.js.map +1 -1
- package/dist/bootstrap.d.ts +2 -1
- package/dist/bootstrap.js +7 -1
- package/dist/bootstrap.js.map +1 -1
- package/dist/chat/chat.acl.d.ts +3 -0
- package/dist/chat/chat.acl.js +42 -0
- package/dist/chat/chat.acl.js.map +1 -0
- package/dist/chat/chat.controller.d.ts +4 -4
- package/dist/chat/chat.controller.js +62 -9
- package/dist/chat/chat.controller.js.map +1 -1
- package/dist/chat/chat.module.d.ts +3 -0
- package/dist/chat/chat.module.js +24 -2
- package/dist/chat/chat.module.js.map +1 -1
- package/dist/chat/chat.service.d.ts +33 -11
- package/dist/chat/chat.service.js +238 -35
- package/dist/chat/chat.service.js.map +1 -1
- package/dist/chat/dto/create-message.dto.d.ts +2 -1
- package/dist/chat/dto/create-message.dto.js +8 -1
- package/dist/chat/dto/create-message.dto.js.map +1 -1
- package/dist/chat/dto/responses.dto.d.ts +7 -1
- package/dist/chat/dto/responses.dto.js +36 -2
- package/dist/chat/dto/responses.dto.js.map +1 -1
- 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 +3 -0
- package/dist/chat/entities/conversation.entity.js +14 -1
- package/dist/chat/entities/conversation.entity.js.map +1 -1
- package/dist/chat/entities/message.entity.d.ts +2 -0
- package/dist/chat/entities/message.entity.js +8 -2
- package/dist/chat/entities/message.entity.js.map +1 -1
- package/dist/chat/enums/conversation-type.enum.d.ts +2 -1
- package/dist/chat/enums/conversation-type.enum.js +1 -0
- package/dist/chat/enums/conversation-type.enum.js.map +1 -1
- package/dist/common/decorators/api-paginated-response.d.ts +1 -1
- package/dist/common/decorators/api-paginated-response.js +2 -2
- package/dist/common/decorators/api-paginated-response.js.map +1 -1
- package/dist/common/dto/paginated-response.dto.d.ts +2 -0
- package/dist/common/dto/paginated-response.dto.js +14 -3
- package/dist/common/dto/paginated-response.dto.js.map +1 -1
- package/dist/common/utils/cursor.d.ts +2 -0
- package/dist/common/utils/cursor.js +12 -0
- package/dist/common/utils/cursor.js.map +1 -0
- package/dist/community/avatar/avatar.controller.d.ts +11 -0
- package/dist/community/avatar/avatar.controller.js +90 -0
- package/dist/community/avatar/avatar.controller.js.map +1 -0
- package/dist/community/avatar/avatar.service.d.ts +13 -0
- package/dist/community/avatar/avatar.service.js +78 -0
- package/dist/community/avatar/avatar.service.js.map +1 -0
- package/dist/community/community.acl.d.ts +6 -3
- package/dist/community/community.acl.js +58 -35
- package/dist/community/community.acl.js.map +1 -1
- package/dist/community/community.controller.d.ts +4 -3
- package/dist/community/community.controller.js +23 -6
- package/dist/community/community.controller.js.map +1 -1
- package/dist/community/community.module.d.ts +3 -0
- package/dist/community/community.module.js +17 -7
- package/dist/community/community.module.js.map +1 -1
- package/dist/community/community.service.d.ts +13 -5
- package/dist/community/community.service.js +74 -17
- package/dist/community/community.service.js.map +1 -1
- package/dist/community/dto/community-response.dto.d.ts +5 -1
- package/dist/community/dto/community-response.dto.js +32 -1
- package/dist/community/dto/community-response.dto.js.map +1 -1
- package/dist/community/dto/create-community.dto.d.ts +2 -0
- package/dist/community/dto/create-community.dto.js +14 -2
- package/dist/community/dto/create-community.dto.js.map +1 -1
- package/dist/community/dto/update-community.dto.d.ts +2 -0
- package/dist/community/dto/update-community.dto.js +15 -1
- package/dist/community/dto/update-community.dto.js.map +1 -1
- package/dist/community/entities/community-member.entity.js +1 -0
- package/dist/community/entities/community-member.entity.js.map +1 -1
- package/dist/community/entities/community.entity.d.ts +2 -0
- package/dist/community/entities/community.entity.js +11 -1
- package/dist/community/entities/community.entity.js.map +1 -1
- package/dist/configs/configs.module.js +3 -0
- package/dist/configs/configs.module.js.map +1 -1
- package/dist/configs/configs.service.d.ts +23 -0
- package/dist/configs/configs.service.js +14 -1
- package/dist/configs/configs.service.js.map +1 -1
- package/dist/core/event-stream/event-stream-processor.interface.d.ts +8 -0
- package/dist/core/event-stream/event-stream-processor.interface.js +3 -0
- package/dist/core/event-stream/event-stream-processor.interface.js.map +1 -0
- package/dist/core/event-stream/event-stream-processor.service.d.ts +13 -0
- package/dist/core/event-stream/event-stream-processor.service.js +55 -0
- package/dist/core/event-stream/event-stream-processor.service.js.map +1 -0
- package/dist/core/event-stream/event-stream.module.d.ts +11 -0
- package/dist/core/event-stream/event-stream.module.js +49 -0
- package/dist/core/event-stream/event-stream.module.js.map +1 -0
- package/dist/core/event-stream/event-stream.service.d.ts +16 -0
- package/dist/core/event-stream/event-stream.service.js +100 -0
- package/dist/core/event-stream/event-stream.service.js.map +1 -0
- package/dist/core/event-stream/types.d.ts +2 -0
- package/dist/core/event-stream/types.js +3 -0
- package/dist/core/event-stream/types.js.map +1 -0
- package/dist/core/hook/hook.module.d.ts +4 -0
- package/dist/core/hook/hook.module.js +30 -0
- package/dist/core/hook/hook.module.js.map +1 -0
- package/dist/core/hook/hook.service.d.ts +7 -0
- package/dist/core/{plugin/plugin-hook.service.js → hook/hook.service.js} +10 -10
- package/dist/core/hook/hook.service.js.map +1 -0
- package/dist/core/plugin/plugin.module.js +7 -5
- package/dist/core/plugin/plugin.module.js.map +1 -1
- package/dist/db.js +1 -1
- package/dist/db.js.map +1 -1
- package/dist/file-storage/file-storage.service.d.ts +1 -1
- package/dist/file-storage/file-storage.service.js +6 -6
- package/dist/file-storage/file-storage.service.js.map +1 -1
- package/dist/file-storage/utils.d.ts +2 -0
- package/dist/file-storage/utils.js +9 -2
- package/dist/file-storage/utils.js.map +1 -1
- package/dist/index.d.ts +0 -1
- package/dist/index.js +1 -3
- package/dist/index.js.map +1 -1
- package/dist/manage-db.d.ts +1 -0
- package/dist/manage-db.js +10 -0
- package/dist/manage-db.js.map +1 -0
- package/dist/media/entities/audio.entity.d.ts +2 -2
- package/dist/media/entities/audio.entity.js +2 -2
- package/dist/media/entities/audio.entity.js.map +1 -1
- package/dist/media/entities/media.entity.d.ts +6 -0
- package/dist/media/entities/media.entity.js +25 -2
- package/dist/media/entities/media.entity.js.map +1 -1
- package/dist/media/media.acl.d.ts +2 -4
- package/dist/media/media.acl.js +3 -0
- package/dist/media/media.acl.js.map +1 -1
- package/dist/media/media.service.js +15 -12
- package/dist/media/media.service.js.map +1 -1
- package/dist/migrations/1757061785934-PushNotificationTokens.d.ts +6 -0
- package/dist/migrations/1757061785934-PushNotificationTokens.js +20 -0
- package/dist/migrations/1757061785934-PushNotificationTokens.js.map +1 -0
- package/dist/migrations/1758623241397-AddUserTimestamps.d.ts +6 -0
- package/dist/migrations/1758623241397-AddUserTimestamps.js +16 -0
- package/dist/migrations/1758623241397-AddUserTimestamps.js.map +1 -0
- package/dist/{1756201302119-migrations.d.ts → migrations/1758704603161-UserFollows.d.ts} +1 -1
- package/dist/migrations/1758704603161-UserFollows.js +18 -0
- package/dist/migrations/1758704603161-UserFollows.js.map +1 -0
- package/dist/migrations/1759757532702-UpdateCommunityCascades.d.ts +6 -0
- package/dist/migrations/1759757532702-UpdateCommunityCascades.js +20 -0
- package/dist/migrations/1759757532702-UpdateCommunityCascades.js.map +1 -0
- package/dist/migrations/1759766474808-UpdateCommunityTimestamps.d.ts +6 -0
- package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js +16 -0
- package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js.map +1 -0
- package/dist/migrations/1759919335188-CommunityChats.d.ts +6 -0
- package/dist/migrations/1759919335188-CommunityChats.js +28 -0
- package/dist/migrations/1759919335188-CommunityChats.js.map +1 -0
- package/dist/migrations/1760363804673-ChatVoiceNotes.d.ts +6 -0
- package/dist/migrations/1760363804673-ChatVoiceNotes.js +24 -0
- package/dist/migrations/1760363804673-ChatVoiceNotes.js.map +1 -0
- package/dist/network/entities/network.entity.js +0 -3
- package/dist/network/entities/network.entity.js.map +1 -1
- package/dist/network/network.middleware.js +1 -1
- package/dist/network/network.middleware.js.map +1 -1
- package/dist/network/network.module.js +2 -1
- package/dist/network/network.module.js.map +1 -1
- package/dist/network/network.service.d.ts +5 -2
- package/dist/network/network.service.js +23 -6
- package/dist/network/network.service.js.map +1 -1
- package/dist/notification/dto/delete-push-token.dto.d.ts +3 -0
- package/dist/{media/entities/post-media.entity.js → notification/dto/delete-push-token.dto.js} +11 -16
- package/dist/notification/dto/delete-push-token.dto.js.map +1 -0
- package/dist/notification/dto/register-push-token.dto.d.ts +5 -0
- package/dist/notification/dto/register-push-token.dto.js +38 -0
- package/dist/notification/dto/register-push-token.dto.js.map +1 -0
- package/dist/notification/entities/push-token.entity.d.ts +11 -0
- package/dist/notification/entities/push-token.entity.js +60 -0
- package/dist/notification/entities/push-token.entity.js.map +1 -0
- package/dist/notification/enums/push-service.enum.d.ts +6 -0
- package/dist/notification/enums/push-service.enum.js +11 -0
- package/dist/notification/enums/push-service.enum.js.map +1 -0
- package/dist/notification/hook-listener.service.d.ts +13 -0
- package/dist/notification/hook-listener.service.js +58 -0
- package/dist/notification/hook-listener.service.js.map +1 -0
- package/dist/notification/notification.module.d.ts +2 -0
- package/dist/notification/notification.module.js +24 -0
- package/dist/notification/notification.module.js.map +1 -0
- package/dist/notification/push-notification.controller.d.ts +9 -0
- package/dist/notification/push-notification.controller.js +69 -0
- package/dist/notification/push-notification.controller.js.map +1 -0
- package/dist/notification/push-notification.module.d.ts +2 -0
- package/dist/notification/push-notification.module.js +27 -0
- package/dist/notification/push-notification.module.js.map +1 -0
- package/dist/notification/push-notification.service.d.ts +22 -0
- package/dist/notification/push-notification.service.js +86 -0
- package/dist/notification/push-notification.service.js.map +1 -0
- package/dist/post/entities/post.entity.js +3 -3
- package/dist/post/entities/post.entity.js.map +1 -1
- package/dist/post/post.controller.d.ts +3 -2
- package/dist/post/post.controller.js +28 -8
- package/dist/post/post.controller.js.map +1 -1
- package/dist/post/post.module.js +2 -0
- package/dist/post/post.module.js.map +1 -1
- package/dist/post/post.service.d.ts +7 -3
- package/dist/post/post.service.js +18 -8
- package/dist/post/post.service.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/user/avatar/avatar.controller.d.ts +10 -0
- package/dist/user/avatar/avatar.controller.js +89 -0
- package/dist/user/avatar/avatar.controller.js.map +1 -0
- package/dist/user/avatar/avatar.service.d.ts +12 -0
- package/dist/user/avatar/avatar.service.js +68 -0
- package/dist/user/avatar/avatar.service.js.map +1 -0
- package/dist/user/constants.d.ts +1 -0
- package/dist/user/constants.js +5 -0
- package/dist/user/constants.js.map +1 -0
- package/dist/user/dto/update-profile.dto.d.ts +3 -0
- package/dist/{common/entities/base.repository.js → user/dto/update-profile.dto.js} +14 -20
- package/dist/user/dto/update-profile.dto.js.map +1 -0
- package/dist/user/dto/user-response.dto.d.ts +6 -0
- package/dist/user/dto/user-response.dto.js +37 -1
- package/dist/user/dto/user-response.dto.js.map +1 -1
- package/dist/user/dto/user.dto.d.ts +8 -0
- package/dist/user/dto/user.dto.js +21 -0
- package/dist/user/dto/user.dto.js.map +1 -0
- package/dist/user/entities/user.entity.d.ts +4 -0
- package/dist/user/entities/user.entity.js +19 -1
- package/dist/user/entities/user.entity.js.map +1 -1
- package/dist/user/follow/dto/follow-response.dto.d.ts +4 -0
- package/dist/user/follow/dto/follow-response.dto.js +38 -0
- package/dist/user/follow/dto/follow-response.dto.js.map +1 -0
- package/dist/user/follow/dto/follow.dto.d.ts +4 -0
- package/dist/user/follow/dto/follow.dto.js +26 -0
- package/dist/user/follow/dto/follow.dto.js.map +1 -0
- package/dist/user/follow/entities/follow.entity.d.ts +10 -0
- package/dist/user/follow/entities/follow.entity.js +60 -0
- package/dist/user/follow/entities/follow.entity.js.map +1 -0
- package/dist/user/follow/follow.controller.d.ts +9 -0
- package/dist/user/follow/follow.controller.js +56 -0
- package/dist/user/follow/follow.controller.js.map +1 -0
- package/dist/user/follow/follow.module.d.ts +2 -0
- package/dist/user/follow/follow.module.js +26 -0
- package/dist/user/follow/follow.module.js.map +1 -0
- package/dist/user/follow/follow.service.d.ts +11 -0
- package/dist/user/follow/follow.service.js +56 -0
- package/dist/user/follow/follow.service.js.map +1 -0
- package/dist/user/user.controller.d.ts +6 -2
- package/dist/user/user.controller.js +47 -8
- package/dist/user/user.controller.js.map +1 -1
- package/dist/user/user.module.js +12 -3
- package/dist/user/user.module.js.map +1 -1
- package/dist/user/user.service.d.ts +12 -5
- package/dist/user/user.service.js +49 -11
- package/dist/user/user.service.js.map +1 -1
- package/package.json +6 -3
- package/dist/1756201302119-migrations.js +0 -84
- package/dist/1756201302119-migrations.js.map +0 -1
- package/dist/auth/enums/auth-methods.enum.d.ts +0 -2
- package/dist/auth/enums/auth-methods.enum.js +0 -7
- package/dist/auth/enums/auth-methods.enum.js.map +0 -1
- package/dist/auth/session/auth.controller.d.ts +0 -10
- package/dist/auth/session/auth.controller.js +0 -92
- package/dist/auth/session/auth.controller.js.map +0 -1
- package/dist/auth/session/auth.service.d.ts +0 -12
- package/dist/auth/session/auth.service.js +0 -46
- package/dist/auth/session/auth.service.js.map +0 -1
- package/dist/common/constants.d.ts +0 -1
- package/dist/common/constants.js +0 -5
- package/dist/common/constants.js.map +0 -1
- package/dist/common/entities/base.repository.d.ts +0 -7
- package/dist/common/entities/base.repository.js.map +0 -1
- package/dist/core/plugin/plugin-hook.service.d.ts +0 -7
- package/dist/core/plugin/plugin-hook.service.js.map +0 -1
- package/dist/media/entities/post-media.entity.d.ts +0 -5
- package/dist/media/entities/post-media.entity.js.map +0 -1
- package/dist/user/dto/update-user.dto.d.ts +0 -5
- package/dist/user/dto/update-user.dto.js +0 -13
- package/dist/user/dto/update-user.dto.js.map +0 -1
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { StreamableFile } from '@nestjs/common';
|
|
2
|
+
import { User } from '~/user/entities/user.entity';
|
|
3
|
+
import { UserAvatarService } from './avatar.service';
|
|
4
|
+
import { UserResponseDto } from '../dto/user-response.dto';
|
|
5
|
+
export declare class UserAvatarController {
|
|
6
|
+
private service;
|
|
7
|
+
constructor(service: UserAvatarService);
|
|
8
|
+
uploadAvatar(file: Express.Multer.File): Promise<UserResponseDto>;
|
|
9
|
+
downloadAvatar(userId: User['id'], filename: any): Promise<StreamableFile>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
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.UserAvatarController = 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 avatar_service_1 = require("./avatar.service");
|
|
22
|
+
const user_response_dto_1 = require("../dto/user-response.dto");
|
|
23
|
+
const class_transformer_1 = require("class-transformer");
|
|
24
|
+
const context_1 = require("../../core/context/context");
|
|
25
|
+
let UserAvatarController = class UserAvatarController {
|
|
26
|
+
service;
|
|
27
|
+
constructor(service) {
|
|
28
|
+
this.service = service;
|
|
29
|
+
}
|
|
30
|
+
async uploadAvatar(file) {
|
|
31
|
+
await this.service.uploadAvatar(file);
|
|
32
|
+
return (0, class_transformer_1.plainToInstance)(user_response_dto_1.UserResponseDto, context_1.Context.getUser());
|
|
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.UserAvatarController = UserAvatarController;
|
|
44
|
+
__decorate([
|
|
45
|
+
(0, swagger_1.ApiOperation)({
|
|
46
|
+
summary: 'Upload an avatar to your profile',
|
|
47
|
+
description: 'This Profile 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)('user.uploadAvatar'),
|
|
64
|
+
openapi.ApiResponse({ status: 201, type: require("../dto/user-response.dto").UserResponseDto }),
|
|
65
|
+
__param(0, (0, common_1.UploadedFile)()),
|
|
66
|
+
__metadata("design:type", Function),
|
|
67
|
+
__metadata("design:paramtypes", [Object]),
|
|
68
|
+
__metadata("design:returntype", Promise)
|
|
69
|
+
], UserAvatarController.prototype, "uploadAvatar", null);
|
|
70
|
+
__decorate([
|
|
71
|
+
(0, swagger_1.ApiTags)('Assets'),
|
|
72
|
+
(0, swagger_1.ApiOperation)({
|
|
73
|
+
summary: 'Download an avatar for a profile',
|
|
74
|
+
description: 'This Profile API method displays an avatar. If one if not available, a default avatar is generated.',
|
|
75
|
+
}),
|
|
76
|
+
(0, common_1.Get)('assets/avatars/:userId/:timestamp/:filename'),
|
|
77
|
+
openapi.ApiResponse({ status: 200 }),
|
|
78
|
+
__param(0, (0, common_1.Param)('userId')),
|
|
79
|
+
__param(1, (0, common_1.Param)('filename')),
|
|
80
|
+
__metadata("design:type", Function),
|
|
81
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
82
|
+
__metadata("design:returntype", Promise)
|
|
83
|
+
], UserAvatarController.prototype, "downloadAvatar", null);
|
|
84
|
+
exports.UserAvatarController = UserAvatarController = __decorate([
|
|
85
|
+
(0, swagger_1.ApiTags)('User'),
|
|
86
|
+
(0, common_1.Controller)(),
|
|
87
|
+
__metadata("design:paramtypes", [avatar_service_1.UserAvatarService])
|
|
88
|
+
], UserAvatarController);
|
|
89
|
+
//# sourceMappingURL=avatar.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar.controller.js","sourceRoot":"","sources":["../../../src/user/avatar/avatar.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAUwB;AACxB,+DAA2D;AAC3D,6CAA8E;AAC9E,sDAA8C;AAE9C,qDAAqD;AACrD,gEAA2D;AAC3D,yDAAoD;AACpD,wDAAiD;AAI1C,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IACX;IAApB,YAAoB,OAA0B;QAA1B,YAAO,GAAP,OAAO,CAAmB;IAAG,CAAC;IAsB5C,AAAN,KAAK,CAAC,YAAY,CACA,IAAyB;QAEzC,MAAM,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QACtC,OAAO,IAAA,mCAAe,EAAC,mCAAe,EAAE,iBAAO,CAAC,OAAO,EAAU,CAAC,CAAC;IACrE,CAAC;IASK,AAAN,KAAK,CAAC,cAAc,CACD,MAAkB,EAChB,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;AAlDY,oDAAoB;AAuBzB;IApBL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,kCAAkC;QAC3C,WAAW,EACT,sFAAsF;KACzF,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,mBAAmB,CAAC;;IAEvB,WAAA,IAAA,qBAAY,GAAE,CAAA;;;;wDAIhB;AASK;IAPL,IAAA,iBAAO,EAAC,QAAQ,CAAC;IACjB,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,kCAAkC;QAC3C,WAAW,EACT,qGAAqG;KACxG,CAAC;IACD,IAAA,YAAG,EAAC,6CAA6C,CAAC;;IAEhD,WAAA,IAAA,cAAK,EAAC,QAAQ,CAAC,CAAA;IACf,WAAA,IAAA,cAAK,EAAC,UAAU,CAAC,CAAA;;;;0DAUnB;+BAjDU,oBAAoB;IAFhC,IAAA,iBAAO,EAAC,MAAM,CAAC;IACf,IAAA,mBAAU,GAAE;qCAEkB,kCAAiB;GADnC,oBAAoB,CAkDhC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { NotFoundException } from '@nestjs/common';
|
|
2
|
+
import { FileStorageService } from '~/file-storage/file-storage.service';
|
|
3
|
+
import { User } from '~/user/entities/user.entity';
|
|
4
|
+
import { UserService } from '~/user/user.service';
|
|
5
|
+
export declare const AVATAR_SIZES: readonly [512, 192, 72, 48];
|
|
6
|
+
export declare class UserAvatarService {
|
|
7
|
+
private fileStorage;
|
|
8
|
+
private userService;
|
|
9
|
+
constructor(fileStorage: FileStorageService, userService: UserService);
|
|
10
|
+
uploadAvatar(file: Express.Multer.File): Promise<boolean>;
|
|
11
|
+
downloadAvatar(userId: User['id'], filename: string): Promise<ReadableStream<any> | NotFoundException | undefined>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
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.UserAvatarService = exports.AVATAR_SIZES = 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 user_service_1 = require("../user.service");
|
|
22
|
+
const client_s3_1 = require("@aws-sdk/client-s3");
|
|
23
|
+
exports.AVATAR_SIZES = [512, 192, 72, 48];
|
|
24
|
+
let UserAvatarService = class UserAvatarService {
|
|
25
|
+
fileStorage;
|
|
26
|
+
userService;
|
|
27
|
+
constructor(fileStorage, userService) {
|
|
28
|
+
this.fileStorage = fileStorage;
|
|
29
|
+
this.userService = userService;
|
|
30
|
+
}
|
|
31
|
+
async uploadAvatar(file) {
|
|
32
|
+
const user = context_1.Context.getUser();
|
|
33
|
+
if (!user) {
|
|
34
|
+
throw new common_1.ForbiddenException();
|
|
35
|
+
}
|
|
36
|
+
const userDir = (0, utils_1.getUserDir)(user) + 'avatar';
|
|
37
|
+
await this.fileStorage.putFile(await (0, sharp_1.default)(file.buffer).jpeg().toBuffer(), userDir + `/master.jpeg`, 'image/jpeg');
|
|
38
|
+
for (const size of exports.AVATAR_SIZES) {
|
|
39
|
+
await this.fileStorage.putFile(await (0, sharp_1.default)(file.buffer).jpeg().resize(size).toBuffer(), userDir + `/${size}.jpeg`, 'image/jpeg');
|
|
40
|
+
}
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
async downloadAvatar(userId, filename) {
|
|
44
|
+
const user = await this.userService.findOne(userId);
|
|
45
|
+
if (!user) {
|
|
46
|
+
return new common_1.NotFoundException();
|
|
47
|
+
}
|
|
48
|
+
const userDir = (0, utils_1.getUserDir)(user) + 'avatar';
|
|
49
|
+
try {
|
|
50
|
+
return await this.fileStorage.getFile(`${userDir}/${filename}`);
|
|
51
|
+
}
|
|
52
|
+
catch (err) {
|
|
53
|
+
if (err instanceof client_s3_1.NoSuchKey) {
|
|
54
|
+
throw new common_1.NotFoundException();
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
throw err;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
exports.UserAvatarService = UserAvatarService;
|
|
63
|
+
exports.UserAvatarService = UserAvatarService = __decorate([
|
|
64
|
+
(0, common_1.Injectable)(),
|
|
65
|
+
__metadata("design:paramtypes", [file_storage_service_1.FileStorageService,
|
|
66
|
+
user_service_1.UserService])
|
|
67
|
+
], UserAvatarService);
|
|
68
|
+
//# sourceMappingURL=avatar.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar.service.js","sourceRoot":"","sources":["../../../src/user/avatar/avatar.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAKwB;AACxB,wDAAiD;AACjD,kFAAyE;AACzE,oDAAkD;AAClD,kDAA0B;AAE1B,kDAAkD;AAClD,kDAA+C;AAElC,QAAA,YAAY,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,CAAU,CAAC;AAGjD,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAElB;IACA;IAFV,YACU,WAA+B,EAC/B,WAAwB;QADxB,gBAAW,GAAX,WAAW,CAAoB;QAC/B,gBAAW,GAAX,WAAW,CAAa;IAC/B,CAAC;IAKJ,KAAK,CAAC,YAAY,CAAC,IAAyB;QAC1C,MAAM,IAAI,GAAG,iBAAO,CAAC,OAAO,EAAE,CAAC;QAE/B,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,2BAAkB,EAAE,CAAC;QACjC,CAAC;QAED,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,IAAI,CAAC,GAAG,QAAQ,CAAC;QAG5C,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAC5B,MAAM,IAAA,eAAK,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE,EAC1C,OAAO,GAAG,cAAc,EACxB,YAAY,CACb,CAAC;QAEF,KAAK,MAAM,IAAI,IAAI,oBAAY,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,OAAO,GAAG,IAAI,IAAI,OAAO,EACzB,YAAY,CACb,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAKD,KAAK,CAAC,cAAc,CAAC,MAAkB,EAAE,QAAgB;QACvD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAEpD,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,OAAO,IAAI,0BAAiB,EAAE,CAAC;QACjC,CAAC;QAED,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,IAAI,CAAC,GAAG,QAAQ,CAAC;QAC5C,IAAI,CAAC;YACH,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,IAAI,QAAQ,EAAE,CAAC,CAAC;QAClE,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,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;AAzDY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAGY,yCAAkB;QAClB,0BAAW;GAHvB,iBAAiB,CAyD7B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const USER_CREATED = "USER_CREATED";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/user/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,YAAY,GAAG,cAAc,CAAC"}
|
|
@@ -8,25 +8,19 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
-
var BaseRepository_1;
|
|
12
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
exports.
|
|
14
|
-
const
|
|
15
|
-
const
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
constructor(dataSource) {
|
|
21
|
-
this.dataSource = dataSource;
|
|
12
|
+
exports.UpdateProfileDto = void 0;
|
|
13
|
+
const openapi = require("@nestjs/swagger");
|
|
14
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
15
|
+
class UpdateProfileDto {
|
|
16
|
+
name;
|
|
17
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
18
|
+
return { name: { required: true, type: () => String } };
|
|
22
19
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
__metadata("design:paramtypes", [typeorm_1.DataSource])
|
|
31
|
-
], BaseRepository);
|
|
32
|
-
//# sourceMappingURL=base.repository.js.map
|
|
20
|
+
}
|
|
21
|
+
exports.UpdateProfileDto = UpdateProfileDto;
|
|
22
|
+
__decorate([
|
|
23
|
+
(0, swagger_1.ApiProperty)({ description: 'Display name of the user' }),
|
|
24
|
+
__metadata("design:type", String)
|
|
25
|
+
], UpdateProfileDto.prototype, "name", void 0);
|
|
26
|
+
//# sourceMappingURL=update-profile.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update-profile.dto.js","sourceRoot":"","sources":["../../../src/user/dto/update-profile.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAE9C,MAAa,gBAAgB;IAE3B,IAAI,CAAS;;;;CACd;AAHD,4CAGC;AADC;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,0BAA0B,EAAE,CAAC;;8CAC5C"}
|
|
@@ -1,5 +1,11 @@
|
|
|
1
|
+
import { AVATAR_SIZES } from '~/user/avatar/avatar.service';
|
|
2
|
+
import { UserRelationsDto } from './user.dto';
|
|
1
3
|
export declare class UserResponseDto {
|
|
2
4
|
id: number;
|
|
3
5
|
username: string;
|
|
4
6
|
name: string;
|
|
7
|
+
avatar: Record<(typeof AVATAR_SIZES)[number], {
|
|
8
|
+
url: string;
|
|
9
|
+
}>;
|
|
10
|
+
relations: UserRelationsDto;
|
|
5
11
|
}
|
|
@@ -13,12 +13,17 @@ exports.UserResponseDto = void 0;
|
|
|
13
13
|
const openapi = require("@nestjs/swagger");
|
|
14
14
|
const swagger_1 = require("@nestjs/swagger");
|
|
15
15
|
const class_transformer_1 = require("class-transformer");
|
|
16
|
+
const context_1 = require("../../core/context/context");
|
|
17
|
+
const avatar_service_1 = require("../avatar/avatar.service");
|
|
18
|
+
const user_dto_1 = require("./user.dto");
|
|
16
19
|
class UserResponseDto {
|
|
17
20
|
id;
|
|
18
21
|
username;
|
|
19
22
|
name;
|
|
23
|
+
avatar;
|
|
24
|
+
relations;
|
|
20
25
|
static _OPENAPI_METADATA_FACTORY() {
|
|
21
|
-
return { id: { required: true, type: () => Number }, username: { required: true, type: () => String }, name: { required: true, type: () => String } };
|
|
26
|
+
return { id: { required: true, type: () => Number }, username: { required: true, type: () => String }, name: { required: true, type: () => String }, avatar: { required: true, type: () => Object }, relations: { required: true, type: () => require("./user.dto").UserRelationsDto } };
|
|
22
27
|
}
|
|
23
28
|
}
|
|
24
29
|
exports.UserResponseDto = UserResponseDto;
|
|
@@ -37,4 +42,35 @@ __decorate([
|
|
|
37
42
|
(0, class_transformer_1.Expose)(),
|
|
38
43
|
__metadata("design:type", String)
|
|
39
44
|
], UserResponseDto.prototype, "name", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
(0, swagger_1.ApiProperty)({
|
|
47
|
+
description: 'Key/Value map of size to url of avatar',
|
|
48
|
+
type: 'object',
|
|
49
|
+
additionalProperties: {
|
|
50
|
+
type: 'object',
|
|
51
|
+
properties: {
|
|
52
|
+
url: {
|
|
53
|
+
type: 'string',
|
|
54
|
+
format: 'uri',
|
|
55
|
+
description: 'Absolute URL to the avatar image for the given size',
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
}),
|
|
60
|
+
(0, class_transformer_1.Expose)(),
|
|
61
|
+
(0, class_transformer_1.Transform)(({ obj }) => {
|
|
62
|
+
const baseUrl = context_1.Context.getNetwork().getBaseUrl() + 'api/assets/avatars/' + obj.id;
|
|
63
|
+
return avatar_service_1.AVATAR_SIZES.reduce((acc, size) => {
|
|
64
|
+
acc[size] = {
|
|
65
|
+
url: `${baseUrl}/${obj.updatedAt?.getTime()}/${size}.jpeg`,
|
|
66
|
+
};
|
|
67
|
+
return acc;
|
|
68
|
+
}, {});
|
|
69
|
+
}),
|
|
70
|
+
__metadata("design:type", Object)
|
|
71
|
+
], UserResponseDto.prototype, "avatar", void 0);
|
|
72
|
+
__decorate([
|
|
73
|
+
(0, class_transformer_1.Expose)(),
|
|
74
|
+
__metadata("design:type", user_dto_1.UserRelationsDto)
|
|
75
|
+
], UserResponseDto.prototype, "relations", void 0);
|
|
40
76
|
//# sourceMappingURL=user-response.dto.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user-response.dto.js","sourceRoot":"","sources":["../../../src/user/dto/user-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,
|
|
1
|
+
{"version":3,"file":"user-response.dto.js","sourceRoot":"","sources":["../../../src/user/dto/user-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAAsD;AACtD,wDAAiD;AACjD,6DAA4D;AAC5D,yCAA8C;AAE9C,MAAa,eAAe;IAG1B,EAAE,CAAS;IAIX,QAAQ,CAAS;IAIjB,IAAI,CAAS;IA2Bb,MAAM,CAAyD;IAG/D,SAAS,CAAmB;;;;CAC7B;AA1CD,0CA0CC;AAvCC;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,mCAAmC,EAAE,CAAC;IACjE,IAAA,0BAAM,GAAE;;2CACE;AAIX;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,8BAA8B,EAAE,CAAC;IAC5D,IAAA,0BAAM,GAAE;;iDACQ;AAIjB;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,2CAA2C,EAAE,CAAC;IACzE,IAAA,0BAAM,GAAE;;6CACI;AA2Bb;IAzBC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,wCAAwC;QACrD,IAAI,EAAE,QAAQ;QACd,oBAAoB,EAAE;YACpB,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,GAAG,EAAE;oBACH,IAAI,EAAE,QAAQ;oBACd,MAAM,EAAE,KAAK;oBACb,WAAW,EAAE,qDAAqD;iBACnE;aACF;SACF;KACF,CAAC;IACD,IAAA,0BAAM,GAAE;IACR,IAAA,6BAAS,EAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;QACrB,MAAM,OAAO,GACX,iBAAO,CAAC,UAAU,EAAE,CAAC,UAAU,EAAE,GAAG,qBAAqB,GAAG,GAAG,CAAC,EAAE,CAAC;QACrE,OAAO,6BAAY,CAAC,MAAM,CAAkC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;YACxE,GAAG,CAAC,IAAI,CAAC,GAAG;gBACV,GAAG,EAAE,GAAG,OAAO,IAAI,GAAG,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,IAAI,OAAO;aAC3D,CAAC;YACF,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC,CAAC;;+CAC6D;AAG/D;IADC,IAAA,0BAAM,GAAE;8BACE,2BAAgB;kDAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserRelationsDto = exports.UserDto = void 0;
|
|
4
|
+
const openapi = require("@nestjs/swagger");
|
|
5
|
+
const user_entity_1 = require("../entities/user.entity");
|
|
6
|
+
class UserDto extends user_entity_1.User {
|
|
7
|
+
relations;
|
|
8
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
9
|
+
return { relations: { required: true, type: () => require("./user.dto").UserRelationsDto } };
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
exports.UserDto = UserDto;
|
|
13
|
+
class UserRelationsDto {
|
|
14
|
+
isFollowing;
|
|
15
|
+
isFollowed;
|
|
16
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
17
|
+
return { isFollowing: { required: false, type: () => Boolean }, isFollowed: { required: false, type: () => Boolean } };
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.UserRelationsDto = UserRelationsDto;
|
|
21
|
+
//# sourceMappingURL=user.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.dto.js","sourceRoot":"","sources":["../../../src/user/dto/user.dto.ts"],"names":[],"mappings":";;;;AAAA,yDAA+C;AAE/C,MAAa,OAAQ,SAAQ,kBAAI;IAI/B,SAAS,CAAmB;;;;CAC7B;AALD,0BAKC;AAED,MAAa,gBAAgB;IAC3B,WAAW,CAAW;IACtB,UAAU,CAAW;;;;CACtB;AAHD,4CAGC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Network } from '~/network/entities/network.entity';
|
|
2
2
|
import { CommunityMember } from '~/community/entities/community-member.entity';
|
|
3
|
+
import { ChatConversationMember } from '~/chat/entities/conversation-member.entity';
|
|
3
4
|
export declare class User {
|
|
4
5
|
network: Network;
|
|
5
6
|
id: number;
|
|
@@ -8,4 +9,7 @@ export declare class User {
|
|
|
8
9
|
email: string;
|
|
9
10
|
password: string;
|
|
10
11
|
communities: CommunityMember[];
|
|
12
|
+
chats: ChatConversationMember[];
|
|
13
|
+
createdAt: Date;
|
|
14
|
+
updatedAt: Date;
|
|
11
15
|
}
|
|
@@ -15,6 +15,7 @@ const network_entity_1 = require("../../network/entities/network.entity");
|
|
|
15
15
|
const typeorm_1 = require("typeorm");
|
|
16
16
|
const class_transformer_1 = require("class-transformer");
|
|
17
17
|
const community_member_entity_1 = require("../../community/entities/community-member.entity");
|
|
18
|
+
const conversation_member_entity_1 = require("../../chat/entities/conversation-member.entity");
|
|
18
19
|
let User = class User {
|
|
19
20
|
network;
|
|
20
21
|
id;
|
|
@@ -23,8 +24,11 @@ let User = class User {
|
|
|
23
24
|
email;
|
|
24
25
|
password;
|
|
25
26
|
communities;
|
|
27
|
+
chats;
|
|
28
|
+
createdAt;
|
|
29
|
+
updatedAt;
|
|
26
30
|
static _OPENAPI_METADATA_FACTORY() {
|
|
27
|
-
return { network: { required: true, type: () => require("../../network/entities/network.entity").Network }, id: { required: true, type: () => Number }, name: { required: true, type: () => String }, username: { required: true, type: () => String }, email: { required: true, type: () => String }, password: { required: true, type: () => String }, communities: { required: true, type: () => [require("../../community/entities/community-member.entity").CommunityMember] } };
|
|
31
|
+
return { network: { required: true, type: () => require("../../network/entities/network.entity").Network }, id: { required: true, type: () => Number }, name: { required: true, type: () => String }, username: { required: true, type: () => String }, email: { required: true, type: () => String }, password: { required: true, type: () => String }, communities: { required: true, type: () => [require("../../community/entities/community-member.entity").CommunityMember] }, chats: { required: true, type: () => [require("../../chat/entities/conversation-member.entity").ChatConversationMember] }, createdAt: { required: true, type: () => Date }, updatedAt: { required: true, type: () => Date } };
|
|
28
32
|
}
|
|
29
33
|
};
|
|
30
34
|
exports.User = User;
|
|
@@ -59,6 +63,20 @@ __decorate([
|
|
|
59
63
|
(0, typeorm_1.OneToMany)(() => community_member_entity_1.CommunityMember, (sub) => sub.user, { onDelete: 'CASCADE' }),
|
|
60
64
|
__metadata("design:type", Array)
|
|
61
65
|
], User.prototype, "communities", void 0);
|
|
66
|
+
__decorate([
|
|
67
|
+
(0, typeorm_1.OneToMany)(() => conversation_member_entity_1.ChatConversationMember, (chat) => chat.user, {
|
|
68
|
+
onDelete: 'CASCADE',
|
|
69
|
+
}),
|
|
70
|
+
__metadata("design:type", Array)
|
|
71
|
+
], User.prototype, "chats", void 0);
|
|
72
|
+
__decorate([
|
|
73
|
+
(0, typeorm_1.CreateDateColumn)(),
|
|
74
|
+
__metadata("design:type", Date)
|
|
75
|
+
], User.prototype, "createdAt", void 0);
|
|
76
|
+
__decorate([
|
|
77
|
+
(0, typeorm_1.UpdateDateColumn)(),
|
|
78
|
+
__metadata("design:type", Date)
|
|
79
|
+
], User.prototype, "updatedAt", void 0);
|
|
62
80
|
exports.User = User = __decorate([
|
|
63
81
|
(0, typeorm_1.Entity)()
|
|
64
82
|
], User);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.entity.js","sourceRoot":"","sources":["../../../src/user/entities/user.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,0EAA4D;AAE5D,
|
|
1
|
+
{"version":3,"file":"user.entity.js","sourceRoot":"","sources":["../../../src/user/entities/user.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,0EAA4D;AAE5D,qCAYiB;AACjB,yDAA4C;AAC5C,8FAA+E;AAC/E,+FAAoF;AAK7E,IAAM,IAAI,GAAV,MAAM,IAAI;IAKf,OAAO,CAAU;IAMjB,EAAE,CAAS;IAGX,IAAI,CAAS;IAIb,QAAQ,CAAS;IAIjB,KAAK,CAAS;IAId,QAAQ,CAAS;IAMjB,WAAW,CAAoB;IAQ/B,KAAK,CAA2B;IAMhC,SAAS,CAAO;IAMhB,SAAS,CAAO;;;;CACjB,CAAA;AArDY,oBAAI;AAKf;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,wBAAO,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;8BACzC,wBAAO;qCAAC;AAMjB;IADC,IAAA,gCAAsB,GAAE;;gCACd;AAGX;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;;kCAC3B;AAIb;IAFC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IACvC,IAAA,gBAAM,EAAC,iBAAiB,EAAE,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;;sCAClC;AAIjB;IAFC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IACvC,IAAA,2BAAO,GAAE;;mCACI;AAId;IAFC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC3C,IAAA,2BAAO,GAAE;;sCACO;AAMjB;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,yCAAe,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;;yCAC9C;AAQ/B;IAHC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,mDAAsB,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE;QAC5D,QAAQ,EAAE,SAAS;KACpB,CAAC;;mCAC8B;AAMhC;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;uCAAC;AAMhB;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;uCAAC;eApDL,IAAI;IADhB,IAAA,gBAAM,GAAE;GACI,IAAI,CAqDhB"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.FollowResponseDto = void 0;
|
|
13
|
+
const openapi = require("@nestjs/swagger");
|
|
14
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
15
|
+
const class_transformer_1 = require("class-transformer");
|
|
16
|
+
class FollowResponseDto {
|
|
17
|
+
following;
|
|
18
|
+
approved;
|
|
19
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
20
|
+
return { following: { required: true, type: () => Boolean }, approved: { required: true, type: () => Boolean } };
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.FollowResponseDto = FollowResponseDto;
|
|
24
|
+
__decorate([
|
|
25
|
+
(0, swagger_1.ApiProperty)({
|
|
26
|
+
description: 'True/False of the following state',
|
|
27
|
+
}),
|
|
28
|
+
(0, class_transformer_1.Expose)(),
|
|
29
|
+
__metadata("design:type", Boolean)
|
|
30
|
+
], FollowResponseDto.prototype, "following", void 0);
|
|
31
|
+
__decorate([
|
|
32
|
+
(0, swagger_1.ApiProperty)({
|
|
33
|
+
description: 'Status of the follow. If false, the target user needs to approve.',
|
|
34
|
+
}),
|
|
35
|
+
(0, class_transformer_1.Expose)(),
|
|
36
|
+
__metadata("design:type", Boolean)
|
|
37
|
+
], FollowResponseDto.prototype, "approved", void 0);
|
|
38
|
+
//# sourceMappingURL=follow-response.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"follow-response.dto.js","sourceRoot":"","sources":["../../../../src/user/follow/dto/follow-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAA2C;AAE3C,MAAa,iBAAiB;IAK5B,SAAS,CAAU;IAOnB,QAAQ,CAAU;;;;CACnB;AAbD,8CAaC;AARC;IAJC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,mCAAmC;KACjD,CAAC;IACD,IAAA,0BAAM,GAAE;;oDACU;AAOnB;IALC,IAAA,qBAAW,EAAC;QACX,WAAW,EACT,mEAAmE;KACtE,CAAC;IACD,IAAA,0BAAM,GAAE;;mDACS"}
|
|
@@ -0,0 +1,26 @@
|
|
|
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.FollowDto = void 0;
|
|
13
|
+
const openapi = require("@nestjs/swagger");
|
|
14
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
15
|
+
class FollowDto {
|
|
16
|
+
user;
|
|
17
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
18
|
+
return { user: { required: true, type: () => Number } };
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
exports.FollowDto = FollowDto;
|
|
22
|
+
__decorate([
|
|
23
|
+
(0, swagger_1.ApiProperty)({ description: 'Target user to follow or unfollow' }),
|
|
24
|
+
__metadata("design:type", Object)
|
|
25
|
+
], FollowDto.prototype, "user", void 0);
|
|
26
|
+
//# sourceMappingURL=follow.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"follow.dto.js","sourceRoot":"","sources":["../../../../src/user/follow/dto/follow.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAG9C,MAAa,SAAS;IAEpB,IAAI,CAAa;;;;CAClB;AAHD,8BAGC;AADC;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,mCAAmC,EAAE,CAAC;;uCACjD"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.Follow = void 0;
|
|
13
|
+
const openapi = require("@nestjs/swagger");
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
const user_entity_1 = require("../../entities/user.entity");
|
|
16
|
+
let Follow = class Follow {
|
|
17
|
+
userId;
|
|
18
|
+
user;
|
|
19
|
+
targetUserId;
|
|
20
|
+
targetUser;
|
|
21
|
+
approved;
|
|
22
|
+
createdAt;
|
|
23
|
+
updatedAt;
|
|
24
|
+
static _OPENAPI_METADATA_FACTORY() {
|
|
25
|
+
return { userId: { required: true, type: () => Number }, user: { required: true, type: () => require("../../entities/user.entity").User }, targetUserId: { required: true, type: () => Number }, targetUser: { required: true, type: () => require("../../entities/user.entity").User }, approved: { required: true, type: () => Boolean }, createdAt: { required: true, type: () => Date }, updatedAt: { required: true, type: () => Date } };
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
exports.Follow = Follow;
|
|
29
|
+
__decorate([
|
|
30
|
+
(0, typeorm_1.PrimaryColumn)(),
|
|
31
|
+
__metadata("design:type", Object)
|
|
32
|
+
], Follow.prototype, "userId", void 0);
|
|
33
|
+
__decorate([
|
|
34
|
+
(0, typeorm_1.ManyToOne)(() => user_entity_1.User),
|
|
35
|
+
__metadata("design:type", user_entity_1.User)
|
|
36
|
+
], Follow.prototype, "user", void 0);
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, typeorm_1.PrimaryColumn)(),
|
|
39
|
+
__metadata("design:type", Object)
|
|
40
|
+
], Follow.prototype, "targetUserId", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, typeorm_1.ManyToOne)(() => user_entity_1.User),
|
|
43
|
+
__metadata("design:type", user_entity_1.User)
|
|
44
|
+
], Follow.prototype, "targetUser", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
(0, typeorm_1.Column)({ default: true }),
|
|
47
|
+
__metadata("design:type", Boolean)
|
|
48
|
+
], Follow.prototype, "approved", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, typeorm_1.CreateDateColumn)(),
|
|
51
|
+
__metadata("design:type", Date)
|
|
52
|
+
], Follow.prototype, "createdAt", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
(0, typeorm_1.UpdateDateColumn)(),
|
|
55
|
+
__metadata("design:type", Date)
|
|
56
|
+
], Follow.prototype, "updatedAt", void 0);
|
|
57
|
+
exports.Follow = Follow = __decorate([
|
|
58
|
+
(0, typeorm_1.Entity)()
|
|
59
|
+
], Follow);
|
|
60
|
+
//# sourceMappingURL=follow.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"follow.entity.js","sourceRoot":"","sources":["../../../../src/user/follow/entities/follow.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAOiB;AACjB,4DAAmD;AAG5C,IAAM,MAAM,GAAZ,MAAM,MAAM;IAMR,MAAM,CAAa;IAM5B,IAAI,CAAO;IAOF,YAAY,CAAa;IAMlC,UAAU,CAAO;IAQjB,QAAQ,CAAU;IAMlB,SAAS,CAAO;IAMhB,SAAS,CAAO;;;;CACjB,CAAA;AA9CY,wBAAM;AAMR;IADR,IAAA,uBAAa,GAAE;;sCACY;AAM5B;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,CAAC;8BAChB,kBAAI;oCAAC;AAOF;IADR,IAAA,uBAAa,GAAE;;4CACkB;AAMlC;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,CAAC;8BACV,kBAAI;0CAAC;AAQjB;IADC,IAAA,gBAAM,EAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;;wCACR;AAMlB;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;yCAAC;AAMhB;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;yCAAC;iBA7CL,MAAM;IADlB,IAAA,gBAAM,GAAE;GACI,MAAM,CA8ClB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { FollowDto } from './dto/follow.dto';
|
|
2
|
+
import { FollowResponseDto } from './dto/follow-response.dto';
|
|
3
|
+
import { FollowService } from './follow.service';
|
|
4
|
+
export declare class FollowController {
|
|
5
|
+
private service;
|
|
6
|
+
constructor(service: FollowService);
|
|
7
|
+
follow(dto: FollowDto): Promise<FollowResponseDto>;
|
|
8
|
+
unfollow(dto: FollowDto): Promise<FollowResponseDto>;
|
|
9
|
+
}
|