@social.dev/server-sdk 0.0.1-alpha.34 → 0.0.1-alpha.36

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.
Files changed (50) hide show
  1. package/dist/chat/chat.module.js +2 -0
  2. package/dist/chat/chat.module.js.map +1 -1
  3. package/dist/chat/chat.service.d.ts +3 -1
  4. package/dist/chat/chat.service.js +31 -10
  5. package/dist/chat/chat.service.js.map +1 -1
  6. package/dist/chat/dto/responses.dto.d.ts +4 -0
  7. package/dist/chat/dto/responses.dto.js +25 -1
  8. package/dist/chat/dto/responses.dto.js.map +1 -1
  9. package/dist/chat/entities/conversation-member.entity.js +1 -1
  10. package/dist/chat/entities/conversation-member.entity.js.map +1 -1
  11. package/dist/chat/entities/conversation.entity.d.ts +1 -0
  12. package/dist/chat/entities/conversation.entity.js +8 -1
  13. package/dist/chat/entities/conversation.entity.js.map +1 -1
  14. package/dist/chat/entities/message.entity.js.map +1 -1
  15. package/dist/common/decorators/api-paginated-response.d.ts +1 -1
  16. package/dist/common/decorators/api-paginated-response.js +2 -2
  17. package/dist/common/decorators/api-paginated-response.js.map +1 -1
  18. package/dist/notification/notification.module.js +3 -13
  19. package/dist/notification/notification.module.js.map +1 -1
  20. package/dist/notification/push-notification.module.d.ts +2 -0
  21. package/dist/notification/push-notification.module.js +27 -0
  22. package/dist/notification/push-notification.module.js.map +1 -0
  23. package/dist/tsconfig.build.tsbuildinfo +1 -1
  24. package/dist/user/avatar/avatar.controller.d.ts +10 -0
  25. package/dist/user/avatar/avatar.controller.js +89 -0
  26. package/dist/user/avatar/avatar.controller.js.map +1 -0
  27. package/dist/user/avatar/avatar.service.d.ts +12 -0
  28. package/dist/user/avatar/avatar.service.js +57 -0
  29. package/dist/user/avatar/avatar.service.js.map +1 -0
  30. package/dist/user/dto/update-profile.dto.d.ts +3 -0
  31. package/dist/user/dto/update-profile.dto.js +26 -0
  32. package/dist/user/dto/update-profile.dto.js.map +1 -0
  33. package/dist/user/dto/user-response.dto.d.ts +4 -0
  34. package/dist/user/dto/user-response.dto.js +29 -1
  35. package/dist/user/dto/user-response.dto.js.map +1 -1
  36. package/dist/user/entities/user.entity.d.ts +2 -0
  37. package/dist/user/entities/user.entity.js +9 -1
  38. package/dist/user/entities/user.entity.js.map +1 -1
  39. package/dist/user/user.controller.d.ts +2 -0
  40. package/dist/user/user.controller.js +27 -0
  41. package/dist/user/user.controller.js.map +1 -1
  42. package/dist/user/user.module.js +6 -2
  43. package/dist/user/user.module.js.map +1 -1
  44. package/dist/user/user.service.d.ts +2 -2
  45. package/dist/user/user.service.js +3 -2
  46. package/dist/user/user.service.js.map +1 -1
  47. package/package.json +2 -2
  48. package/dist/user/dto/update-user.dto.d.ts +0 -5
  49. package/dist/user/dto/update-user.dto.js +0 -13
  50. 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/: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,kCAAkC,CAAC;;IAErC,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,57 @@
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
+ exports.AVATAR_SIZES = [512, 192, 72, 48];
23
+ let UserAvatarService = class UserAvatarService {
24
+ fileStorage;
25
+ userService;
26
+ constructor(fileStorage, userService) {
27
+ this.fileStorage = fileStorage;
28
+ this.userService = userService;
29
+ }
30
+ async uploadAvatar(file) {
31
+ const user = context_1.Context.getUser();
32
+ if (!user) {
33
+ throw new common_1.ForbiddenException();
34
+ }
35
+ const userDir = (0, utils_1.getUserDir)(user) + 'avatar';
36
+ await this.fileStorage.putFile(await (0, sharp_1.default)(file.buffer).jpeg().toBuffer(), userDir + `/master.jpeg`, 'image/jpeg');
37
+ for (const size of exports.AVATAR_SIZES) {
38
+ await this.fileStorage.putFile(await (0, sharp_1.default)(file.buffer).jpeg().resize(size).toBuffer(), userDir + `/${size}.jpeg`, 'image/jpeg');
39
+ }
40
+ return true;
41
+ }
42
+ async downloadAvatar(userId, filename) {
43
+ const user = await this.userService.findOne(userId);
44
+ if (!user) {
45
+ return new common_1.NotFoundException();
46
+ }
47
+ const userDir = (0, utils_1.getUserDir)(user) + 'avatar';
48
+ return this.fileStorage.getFile(`${userDir}/${filename}`);
49
+ }
50
+ };
51
+ exports.UserAvatarService = UserAvatarService;
52
+ exports.UserAvatarService = UserAvatarService = __decorate([
53
+ (0, common_1.Injectable)(),
54
+ __metadata("design:paramtypes", [file_storage_service_1.FileStorageService,
55
+ user_service_1.UserService])
56
+ ], UserAvatarService);
57
+ //# 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;AAErC,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,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,IAAI,QAAQ,EAAE,CAAC,CAAC;IAC5D,CAAC;CACF,CAAA;AAjDY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAGY,yCAAkB;QAClB,0BAAW;GAHvB,iBAAiB,CAiD7B"}
@@ -0,0 +1,3 @@
1
+ export declare class UpdateProfileDto {
2
+ name: string;
3
+ }
@@ -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.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 } };
19
+ }
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,9 @@
1
+ import { AVATAR_SIZES } from '~/user/avatar/avatar.service';
1
2
  export declare class UserResponseDto {
2
3
  id: number;
3
4
  username: string;
4
5
  name: string;
6
+ avatar: Record<(typeof AVATAR_SIZES)[number], {
7
+ url: string;
8
+ }>;
5
9
  }
@@ -13,12 +13,15 @@ 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");
16
18
  class UserResponseDto {
17
19
  id;
18
20
  username;
19
21
  name;
22
+ avatar;
20
23
  static _OPENAPI_METADATA_FACTORY() {
21
- return { id: { required: true, type: () => Number }, username: { required: true, type: () => String }, name: { required: true, type: () => String } };
24
+ return { id: { required: true, type: () => Number }, username: { required: true, type: () => String }, name: { required: true, type: () => String }, avatar: { required: true, type: () => Object } };
22
25
  }
23
26
  }
24
27
  exports.UserResponseDto = UserResponseDto;
@@ -37,4 +40,29 @@ __decorate([
37
40
  (0, class_transformer_1.Expose)(),
38
41
  __metadata("design:type", String)
39
42
  ], UserResponseDto.prototype, "name", void 0);
43
+ __decorate([
44
+ (0, swagger_1.ApiProperty)({
45
+ description: 'Key/Value map of size to url of avatar',
46
+ type: 'object',
47
+ additionalProperties: {
48
+ type: 'object',
49
+ properties: {
50
+ url: {
51
+ type: 'string',
52
+ format: 'uri',
53
+ description: 'Absolute URL to the avatar image for the given size',
54
+ },
55
+ },
56
+ },
57
+ }),
58
+ (0, class_transformer_1.Expose)(),
59
+ (0, class_transformer_1.Transform)(({ obj }) => {
60
+ const baseUrl = context_1.Context.getNetwork().getBaseUrl() + 'api/assets/avatars/' + obj.id;
61
+ return avatar_service_1.AVATAR_SIZES.reduce((acc, size) => {
62
+ acc[size] = { url: `${baseUrl}/${size}.jpeg` };
63
+ return acc;
64
+ }, {});
65
+ }),
66
+ __metadata("design:type", Object)
67
+ ], UserResponseDto.prototype, "avatar", void 0);
40
68
  //# 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,yDAA2C;AAE3C,MAAa,eAAe;IAG1B,EAAE,CAAS;IAIX,QAAQ,CAAS;IAIjB,IAAI,CAAS;;;;CACd;AAZD,0CAYC;AATC;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"}
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;AAE5D,MAAa,eAAe;IAG1B,EAAE,CAAS;IAIX,QAAQ,CAAS;IAIjB,IAAI,CAAS;IAyBb,MAAM,CAAyD;;;;CAChE;AArCD,0CAqCC;AAlCC;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;AAyBb;IAvBC,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,EAAE,GAAG,EAAE,GAAG,OAAO,IAAI,IAAI,OAAO,EAAE,CAAC;YAC/C,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC,CAAC;;+CAC6D"}
@@ -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,5 @@ export declare class User {
8
9
  email: string;
9
10
  password: string;
10
11
  communities: CommunityMember[];
12
+ chats: ChatConversationMember[];
11
13
  }
@@ -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,9 @@ let User = class User {
23
24
  email;
24
25
  password;
25
26
  communities;
27
+ chats;
26
28
  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] } };
29
+ 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] } };
28
30
  }
29
31
  };
30
32
  exports.User = User;
@@ -59,6 +61,12 @@ __decorate([
59
61
  (0, typeorm_1.OneToMany)(() => community_member_entity_1.CommunityMember, (sub) => sub.user, { onDelete: 'CASCADE' }),
60
62
  __metadata("design:type", Array)
61
63
  ], User.prototype, "communities", void 0);
64
+ __decorate([
65
+ (0, typeorm_1.OneToMany)(() => conversation_member_entity_1.ChatConversationMember, (chat) => chat.user, {
66
+ onDelete: 'CASCADE',
67
+ }),
68
+ __metadata("design:type", Array)
69
+ ], User.prototype, "chats", void 0);
62
70
  exports.User = User = __decorate([
63
71
  (0, typeorm_1.Entity)()
64
72
  ], User);
@@ -1 +1 @@
1
- {"version":3,"file":"user.entity.js","sourceRoot":"","sources":["../../../src/user/entities/user.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,0EAA4D;AAE5D,qCASiB;AACjB,yDAA4C;AAC5C,8FAA+E;AAGxE,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;;;;CAChC,CAAA;AAjCY,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;eAhCpB,IAAI;IADhB,IAAA,gBAAM,GAAE;GACI,IAAI,CAiChB"}
1
+ {"version":3,"file":"user.entity.js","sourceRoot":"","sources":["../../../src/user/entities/user.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,0EAA4D;AAE5D,qCASiB;AACjB,yDAA4C;AAC5C,8FAA+E;AAC/E,+FAAoF;AAG7E,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;;;;CACjC,CAAA;AAzCY,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;eAxCrB,IAAI;IADhB,IAAA,gBAAM,GAAE;GACI,IAAI,CAyChB"}
@@ -1,4 +1,5 @@
1
1
  import { UserService } from './user.service';
2
+ import { UpdateProfileDto } from './dto/update-profile.dto';
2
3
  import { UserResponseDto } from './dto/user-response.dto';
3
4
  import { PaginatedResponseDto } from '~/common/dto/paginated-response.dto';
4
5
  export declare class UserController {
@@ -6,4 +7,5 @@ export declare class UserController {
6
7
  constructor(userService: UserService);
7
8
  findAll(): Promise<PaginatedResponseDto<UserResponseDto>>;
8
9
  findOne(id: string): Promise<UserResponseDto>;
10
+ updateProfile(dto: UpdateProfileDto): Promise<UserResponseDto>;
9
11
  }
@@ -16,10 +16,13 @@ exports.UserController = void 0;
16
16
  const openapi = require("@nestjs/swagger");
17
17
  const common_1 = require("@nestjs/common");
18
18
  const user_service_1 = require("./user.service");
19
+ const update_profile_dto_1 = require("./dto/update-profile.dto");
19
20
  const class_transformer_1 = require("class-transformer");
20
21
  const swagger_1 = require("@nestjs/swagger");
21
22
  const user_response_dto_1 = require("./dto/user-response.dto");
22
23
  const api_paginated_response_1 = require("../common/decorators/api-paginated-response");
24
+ const context_1 = require("../core/context/context");
25
+ const auth_guard_1 = require("../auth/auth.guard");
23
26
  let UserController = class UserController {
24
27
  userService;
25
28
  constructor(userService) {
@@ -40,6 +43,17 @@ let UserController = class UserController {
40
43
  }
41
44
  return (0, class_transformer_1.plainToInstance)(user_response_dto_1.UserResponseDto, this.userService.findOne(+id));
42
45
  }
46
+ async updateProfile(dto) {
47
+ const user = context_1.Context.getUser();
48
+ const res = await this.userService.updateProfile(dto, user);
49
+ console.log(res);
50
+ return (0, class_transformer_1.plainToInstance)(user_response_dto_1.UserResponseDto, res.affected === 1
51
+ ? {
52
+ ...user,
53
+ ...dto,
54
+ }
55
+ : user);
56
+ }
43
57
  };
44
58
  exports.UserController = UserController;
45
59
  __decorate([
@@ -66,6 +80,19 @@ __decorate([
66
80
  __metadata("design:paramtypes", [String]),
67
81
  __metadata("design:returntype", Promise)
68
82
  ], UserController.prototype, "findOne", null);
83
+ __decorate([
84
+ (0, common_1.UseGuards)(auth_guard_1.AuthGuard),
85
+ (0, swagger_1.ApiOperation)({
86
+ summary: 'Retrieve a user',
87
+ description: 'Returns a information about a user',
88
+ }),
89
+ (0, common_1.Post)('user.updateProfile'),
90
+ openapi.ApiResponse({ status: 201, type: require("./dto/user-response.dto").UserResponseDto }),
91
+ __param(0, (0, common_1.Body)()),
92
+ __metadata("design:type", Function),
93
+ __metadata("design:paramtypes", [update_profile_dto_1.UpdateProfileDto]),
94
+ __metadata("design:returntype", Promise)
95
+ ], UserController.prototype, "updateProfile", null);
69
96
  exports.UserController = UserController = __decorate([
70
97
  (0, common_1.Controller)(),
71
98
  __metadata("design:paramtypes", [user_service_1.UserService])
@@ -1 +1 @@
1
- {"version":3,"file":"user.controller.js","sourceRoot":"","sources":["../../src/user/user.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAUwB;AACxB,iDAA6C;AAI7C,yDAAoD;AAEpD,6CAA+C;AAC/C,+DAA0D;AAE1D,wFAAkF;AAG3E,IAAM,cAAc,GAApB,MAAM,cAAc;IACI;IAA7B,YAA6B,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAanD,AAAN,KAAK,CAAC,OAAO;QACX,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAE/C,OAAO;YACL,MAAM,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,mCAAe,EAAC,mCAAe,EAAE,CAAC,CAAC,CAAC;YAC7D,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,EAAE;YACR,QAAQ,EAAE,EAAE;SACb,CAAC;IACJ,CAAC;IAOK,AAAN,KAAK,CAAC,OAAO,CAAgB,EAAU;QACrC,IAAI,KAAK,CAAC,EAAS,CAAC,EAAE,CAAC;YACrB,OAAO,IAAA,mCAAe,EACpB,mCAAe,EACf,MAAM,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAC7C,CAAC;QACJ,CAAC;QACD,OAAO,IAAA,mCAAe,EAAC,mCAAe,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzE,CAAC;CAWF,CAAA;AAjDY,wCAAc;AAcnB;IANL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,4BAA4B;QACrC,WAAW,EAAE,iCAAiC;KAC/C,CAAC;IACD,IAAA,6CAAoB,EAAC,mCAAe,CAAC;IACrC,IAAA,YAAG,EAAC,WAAW,CAAC;;;;;6CAUhB;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,iBAAiB;QAC1B,WAAW,EAAE,oCAAoC;KAClD,CAAC;IACD,IAAA,YAAG,EAAC,WAAW,CAAC;;IACF,WAAA,IAAA,cAAK,EAAC,MAAM,CAAC,CAAA;;;;6CAQ3B;yBAtCU,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAE+B,0BAAW;GAD1C,cAAc,CAiD1B"}
1
+ {"version":3,"file":"user.controller.js","sourceRoot":"","sources":["../../src/user/user.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAWwB;AACxB,iDAA6C;AAC7C,iEAA4D;AAC5D,yDAAoD;AACpD,6CAA+C;AAC/C,+DAA0D;AAE1D,wFAAkF;AAClF,qDAAiD;AACjD,mDAA8C;AAIvC,IAAM,cAAc,GAApB,MAAM,cAAc;IACI;IAA7B,YAA6B,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAQnD,AAAN,KAAK,CAAC,OAAO;QACX,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAE/C,OAAO;YACL,MAAM,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,mCAAe,EAAC,mCAAe,EAAE,CAAC,CAAC,CAAC;YAC7D,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,EAAE;YACR,QAAQ,EAAE,EAAE;SACb,CAAC;IACJ,CAAC;IAOK,AAAN,KAAK,CAAC,OAAO,CAAgB,EAAU;QACrC,IAAI,KAAK,CAAC,EAAS,CAAC,EAAE,CAAC;YACrB,OAAO,IAAA,mCAAe,EACpB,mCAAe,EACf,MAAM,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAC7C,CAAC;QACJ,CAAC;QACD,OAAO,IAAA,mCAAe,EAAC,mCAAe,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzE,CAAC;IAQK,AAAN,KAAK,CAAC,aAAa,CAAS,GAAqB;QAC/C,MAAM,IAAI,GAAG,iBAAO,CAAC,OAAO,EAAU,CAAC;QACvC,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAC5D,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACjB,OAAO,IAAA,mCAAe,EACpB,mCAAe,EACf,GAAG,CAAC,QAAQ,KAAK,CAAC;YAChB,CAAC,CAAC;gBACE,GAAG,IAAI;gBACP,GAAG,GAAG;aACP;YACH,CAAC,CAAC,IAAI,CACT,CAAC;IACJ,CAAC;CACF,CAAA;AAvDY,wCAAc;AASnB;IANL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,4BAA4B;QACrC,WAAW,EAAE,iCAAiC;KAC/C,CAAC;IACD,IAAA,6CAAoB,EAAC,mCAAe,CAAC;IACrC,IAAA,YAAG,EAAC,WAAW,CAAC;;;;;6CAUhB;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,iBAAiB;QAC1B,WAAW,EAAE,oCAAoC;KAClD,CAAC;IACD,IAAA,YAAG,EAAC,WAAW,CAAC;;IACF,WAAA,IAAA,cAAK,EAAC,MAAM,CAAC,CAAA;;;;6CAQ3B;AAQK;IANL,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,iBAAiB;QAC1B,WAAW,EAAE,oCAAoC;KAClD,CAAC;IACD,IAAA,aAAI,EAAC,oBAAoB,CAAC;;IACN,WAAA,IAAA,aAAI,GAAE,CAAA;;qCAAM,qCAAgB;;mDAahD;yBAtDU,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAE+B,0BAAW;GAD1C,cAAc,CAuD1B"}
@@ -19,6 +19,9 @@ const post_module_1 = require("../post/post.module");
19
19
  const acl_module_1 = require("../core/acl/acl.module");
20
20
  const user_acl_1 = __importDefault(require("./user.acl"));
21
21
  const hook_module_1 = require("../core/hook/hook.module");
22
+ const avatar_controller_1 = require("./avatar/avatar.controller");
23
+ const avatar_service_1 = require("./avatar/avatar.service");
24
+ const file_storage_module_1 = require("../file-storage/file-storage.module");
22
25
  let UserModule = class UserModule {
23
26
  };
24
27
  exports.UserModule = UserModule;
@@ -29,9 +32,10 @@ exports.UserModule = UserModule = __decorate([
29
32
  (0, common_1.forwardRef)(() => post_module_1.PostModule),
30
33
  acl_module_1.AclModule.forChild(user_acl_1.default),
31
34
  hook_module_1.HookModule,
35
+ file_storage_module_1.FileStorageModule,
32
36
  ],
33
- controllers: [user_controller_1.UserController],
34
- providers: [user_service_1.UserService],
37
+ controllers: [user_controller_1.UserController, avatar_controller_1.UserAvatarController],
38
+ providers: [user_service_1.UserService, avatar_service_1.UserAvatarService],
35
39
  exports: [user_service_1.UserService],
36
40
  })
37
41
  ], UserModule);
@@ -1 +1 @@
1
- {"version":3,"file":"user.module.js","sourceRoot":"","sources":["../../src/user/user.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAoD;AACpD,iDAA6C;AAC7C,uDAAmD;AACnD,wDAA8C;AAC9C,6CAAgD;AAChD,qDAAgD;AAChD,uDAAkD;AAClD,0DAAsC;AACtC,0DAAqD;AAa9C,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAXtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,kBAAI,CAAC,CAAC;YAChC,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,sBAAS,CAAC,QAAQ,CAAC,kBAAY,CAAC;YAChC,wBAAU;SACX;QACD,WAAW,EAAE,CAAC,gCAAc,CAAC;QAC7B,SAAS,EAAE,CAAC,0BAAW,CAAC;QACxB,OAAO,EAAE,CAAC,0BAAW,CAAC;KACvB,CAAC;GACW,UAAU,CAAG"}
1
+ {"version":3,"file":"user.module.js","sourceRoot":"","sources":["../../src/user/user.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAoD;AACpD,iDAA6C;AAC7C,uDAAmD;AACnD,wDAA8C;AAC9C,6CAAgD;AAChD,qDAAgD;AAChD,uDAAkD;AAClD,0DAAsC;AACtC,0DAAqD;AACrD,kEAAkE;AAClE,4DAA4D;AAC5D,6EAAuE;AAchE,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAZtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,kBAAI,CAAC,CAAC;YAChC,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,sBAAS,CAAC,QAAQ,CAAC,kBAAY,CAAC;YAChC,wBAAU;YACV,uCAAiB;SAClB;QACD,WAAW,EAAE,CAAC,gCAAc,EAAE,wCAAoB,CAAC;QACnD,SAAS,EAAE,CAAC,0BAAW,EAAE,kCAAiB,CAAC;QAC3C,OAAO,EAAE,CAAC,0BAAW,CAAC;KACvB,CAAC;GACW,UAAU,CAAG"}
@@ -1,4 +1,4 @@
1
- import { UpdateUserDto } from './dto/update-user.dto';
1
+ import { UpdateProfileDto } from './dto/update-profile.dto';
2
2
  import { User } from './entities/user.entity';
3
3
  import { QueryRunner, Repository } from 'typeorm';
4
4
  import { DataSource } from 'typeorm';
@@ -19,6 +19,6 @@ export declare class UserService {
19
19
  findAll(): Promise<User[]>;
20
20
  findOne(id: number): Promise<User | null>;
21
21
  findOneByUsername(username: string): Promise<User | null>;
22
- update(id: number, updateUserDto: UpdateUserDto): string;
22
+ updateProfile(dto: UpdateProfileDto, user: User): Promise<import("typeorm").UpdateResult>;
23
23
  remove(id: number): string;
24
24
  }
@@ -73,6 +73,7 @@ let UserService = class UserService {
73
73
  return this.repository.find();
74
74
  }
75
75
  findOne(id) {
76
+ console.log('finding ' + id);
76
77
  return this.repository.findOne({
77
78
  where: { id },
78
79
  relations: ['communities', 'network'],
@@ -81,8 +82,8 @@ let UserService = class UserService {
81
82
  findOneByUsername(username) {
82
83
  return this.repository.findOneBy({ username });
83
84
  }
84
- update(id, updateUserDto) {
85
- return `This action updates a #${id} user`;
85
+ updateProfile(dto, user) {
86
+ return this.repository.update({ id: user.id }, dto);
86
87
  }
87
88
  remove(id) {
88
89
  return `This action removes a #${id} user`;
@@ -1 +1 @@
1
- {"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../src/user/user.service.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../src/user/user.service.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@social.dev/server-sdk",
3
- "version": "0.0.1-alpha.34",
3
+ "version": "0.0.1-alpha.36",
4
4
  "description": "",
5
5
  "author": "",
6
6
  "private": false,
@@ -43,6 +43,7 @@
43
43
  "rxjs": "^7.8.1",
44
44
  "sequelize": "^6.37.7",
45
45
  "sequelize-typescript": "^2.1.6",
46
+ "sharp": "^0.34.4",
46
47
  "typeorm": "^0.3.23"
47
48
  },
48
49
  "devDependencies": {
@@ -96,7 +97,6 @@
96
97
  },
97
98
  "scripts": {
98
99
  "build": "nest build",
99
- "build2": "tsc --build tsconfig.build.json",
100
100
  "format": "prettier --write \"src/**/*.ts\" \"test/**/*.ts\"",
101
101
  "start": "nest start",
102
102
  "dev": "nest build --watch",
@@ -1,5 +0,0 @@
1
- import { CreateUserDto } from './create-user.dto';
2
- declare const UpdateUserDto_base: import("@nestjs/common").Type<Partial<CreateUserDto>>;
3
- export declare class UpdateUserDto extends UpdateUserDto_base {
4
- }
5
- export {};
@@ -1,13 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.UpdateUserDto = void 0;
4
- const openapi = require("@nestjs/swagger");
5
- const swagger_1 = require("@nestjs/swagger");
6
- const create_user_dto_1 = require("./create-user.dto");
7
- class UpdateUserDto extends (0, swagger_1.PartialType)(create_user_dto_1.CreateUserDto) {
8
- static _OPENAPI_METADATA_FACTORY() {
9
- return {};
10
- }
11
- }
12
- exports.UpdateUserDto = UpdateUserDto;
13
- //# sourceMappingURL=update-user.dto.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"update-user.dto.js","sourceRoot":"","sources":["../../../src/user/dto/update-user.dto.ts"],"names":[],"mappings":";;;;AAAA,6CAA8C;AAC9C,uDAAkD;AAElD,MAAa,aAAc,SAAQ,IAAA,qBAAW,EAAC,+BAAa,CAAC;;;;CAAG;AAAhE,sCAAgE"}