@comasoft/nestjs 0.1.2 → 0.1.7

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 (174) hide show
  1. package/README.md +2 -0
  2. package/dist/aws/aws-s3.service.js +1 -158
  3. package/dist/aws/aws.module.js +1 -25
  4. package/dist/aws/aws.service.js +1 -21
  5. package/dist/aws/constants/storage.constant.js +1 -25
  6. package/dist/aws/dto/create-s3-presigned.dto.js +1 -78
  7. package/dist/aws/dto/index.js +1 -18
  8. package/dist/aws/dto/response-s3-presigned.dto.js +1 -110
  9. package/dist/aws/index.js +1 -20
  10. package/dist/aws/types/s3.interface.js +1 -2
  11. package/dist/aws/types/storage.interface.js +1 -2
  12. package/dist/category/category.module.js +1 -23
  13. package/dist/category/category.service.d.ts +20 -8
  14. package/dist/category/category.service.js +1 -124
  15. package/dist/category/dto/create-category.dto.js +1 -34
  16. package/dist/category/dto/delete-category.dto.js +1 -6
  17. package/dist/category/dto/index.js +1 -21
  18. package/dist/category/dto/response-categories.dto.js +1 -52
  19. package/dist/category/dto/update-category-sort.dto.js +1 -33
  20. package/dist/category/dto/update-category.dto.js +1 -9
  21. package/dist/category/index.js +1 -19
  22. package/dist/comment/comment.module.js +1 -23
  23. package/dist/comment/comment.service.d.ts +12 -3
  24. package/dist/comment/comment.service.js +1 -240
  25. package/dist/comment/dto/create-comment.dto.d.ts +1 -0
  26. package/dist/comment/dto/create-comment.dto.js +1 -41
  27. package/dist/comment/dto/index.js +1 -19
  28. package/dist/comment/dto/response-comment.dto.d.ts +5 -2
  29. package/dist/comment/dto/response-comment.dto.js +1 -97
  30. package/dist/comment/dto/update-comment.dto.js +1 -22
  31. package/dist/comment/index.js +1 -19
  32. package/dist/database/entities/category.entity.js +1 -70
  33. package/dist/database/entities/comment.entity.d.ts +2 -0
  34. package/dist/database/entities/comment.entity.js +1 -77
  35. package/dist/database/entities/config.entity.js +1 -44
  36. package/dist/database/entities/file.entity.js +1 -91
  37. package/dist/database/entities/index.js +1 -26
  38. package/dist/database/entities/like.entity.d.ts +1 -0
  39. package/dist/database/entities/like.entity.js +1 -49
  40. package/dist/database/entities/logs-audit.entity.d.ts +3 -0
  41. package/dist/database/entities/logs-audit.entity.js +1 -72
  42. package/dist/database/entities/logs-event.entity.d.ts +2 -0
  43. package/dist/database/entities/logs-event.entity.js +1 -72
  44. package/dist/database/entities/notification-recipient.entity.d.ts +4 -0
  45. package/dist/database/entities/notification-recipient.entity.js +1 -74
  46. package/dist/database/entities/notification.entity.d.ts +4 -0
  47. package/dist/database/entities/notification.entity.js +1 -69
  48. package/dist/database/entities/role.entity.js +1 -54
  49. package/dist/decorators/api-custom-params.decorator.js +1 -35
  50. package/dist/decorators/auth.decorator.factory.js +1 -33
  51. package/dist/decorators/cookies.decorator.js +1 -9
  52. package/dist/decorators/custom-params.decorator.js +1 -16
  53. package/dist/decorators/index.d.ts +0 -2
  54. package/dist/decorators/index.js +1 -24
  55. package/dist/decorators/patch-body.decorator.js +1 -38
  56. package/dist/decorators/soft-delete.decorator.js +1 -10
  57. package/dist/decorators/timestamps.decorator.js +1 -23
  58. package/dist/decorators/user.decorator.js +1 -8
  59. package/dist/dto/auth-user-local.dto.js +1 -26
  60. package/dist/dto/auth-user-sso.dto.js +1 -21
  61. package/dist/dto/custom-params.dto.js +1 -46
  62. package/dist/dto/file.dto.js +1 -70
  63. package/dist/dto/index.js +1 -26
  64. package/dist/dto/jwt-user.dto.js +1 -6
  65. package/dist/dto/pagination.dto.js +1 -36
  66. package/dist/dto/remove-ids.dto.js +1 -23
  67. package/dist/dto/response-access-token.dto.js +1 -24
  68. package/dist/dto/response-id.dto.js +1 -35
  69. package/dist/dto/response-uid.dto.js +1 -35
  70. package/dist/dto/update-ids.dto.js +1 -45
  71. package/dist/dto/update-sort.dto.js +1 -50
  72. package/dist/enums.common.d.ts +2 -1
  73. package/dist/enums.common.js +1 -62
  74. package/dist/events/event-bus.module.js +1 -44
  75. package/dist/events/index.js +1 -20
  76. package/dist/events/listeners/audit-event.listener.js +1 -58
  77. package/dist/events/listeners/index.d.ts +1 -0
  78. package/dist/events/listeners/index.js +1 -17
  79. package/dist/events/listeners/notification-event.listener.d.ts +7 -0
  80. package/dist/events/listeners/notification-event.listener.js +1 -0
  81. package/dist/events/listeners/system-event.listener.js +1 -58
  82. package/dist/events/services/event-logger.service.js +1 -34
  83. package/dist/events/services/event-notification.service.js +1 -104
  84. package/dist/events/services/event-storage.service.js +1 -79
  85. package/dist/events/services/index.js +1 -20
  86. package/dist/events/services/token.service.d.ts +2 -4
  87. package/dist/events/services/token.service.js +1 -88
  88. package/dist/events/types/audit-events.type.d.ts +4 -1
  89. package/dist/events/types/audit-events.type.js +1 -2
  90. package/dist/events/types/index.js +1 -17
  91. package/dist/filters/http-exception.filter.d.ts +2 -2
  92. package/dist/filters/http-exception.filter.js +1 -75
  93. package/dist/filters/index.js +1 -17
  94. package/dist/guards/auth.guard.js +1 -60
  95. package/dist/guards/index.d.ts +3 -0
  96. package/dist/guards/index.js +1 -0
  97. package/dist/guards/jwt.guard.js +1 -17
  98. package/dist/guards/permission.guard.d.ts +10 -0
  99. package/dist/guards/permission.guard.js +1 -0
  100. package/dist/guards/role.guard.d.ts +8 -0
  101. package/dist/guards/role.guard.js +1 -0
  102. package/dist/index.d.ts +2 -1
  103. package/dist/index.js +1 -36
  104. package/dist/interceptors/error.interceptor.js +1 -26
  105. package/dist/interceptors/index.js +1 -18
  106. package/dist/interceptors/success.interceptor.d.ts +1 -1
  107. package/dist/interceptors/success.interceptor.js +1 -30
  108. package/dist/library.module.js +1 -20
  109. package/dist/like/dto/create-like.dto.js +1 -47
  110. package/dist/like/dto/index.js +1 -18
  111. package/dist/like/dto/response-like.dto.js +1 -79
  112. package/dist/like/index.js +1 -19
  113. package/dist/like/like.module.js +1 -23
  114. package/dist/like/like.service.d.ts +2 -2
  115. package/dist/like/like.service.js +1 -155
  116. package/dist/logger/index.js +1 -18
  117. package/dist/logger/pino-options.js +1 -77
  118. package/dist/logger/pino-pretty-transport.js +1 -164
  119. package/dist/notifications/index.d.ts +27 -4
  120. package/dist/notifications/index.js +1 -18
  121. package/dist/notifications/notification.module.js +1 -32
  122. package/dist/notifications/services/email.service.d.ts +5 -4
  123. package/dist/notifications/services/email.service.js +1 -69
  124. package/dist/notifications/services/index.d.ts +1 -0
  125. package/dist/notifications/services/index.js +1 -23
  126. package/dist/notifications/services/kakao.service.d.ts +17 -17
  127. package/dist/notifications/services/kakao.service.js +1 -94
  128. package/dist/notifications/services/message-template.service.d.ts +6 -2
  129. package/dist/notifications/services/message-template.service.js +1 -74
  130. package/dist/notifications/services/notification-send.service.d.ts +8 -12
  131. package/dist/notifications/services/notification-send.service.js +1 -146
  132. package/dist/notifications/services/notification.service.d.ts +3 -1
  133. package/dist/notifications/services/notification.service.js +1 -125
  134. package/dist/notifications/services/slack.service.d.ts +6 -1
  135. package/dist/notifications/services/slack.service.js +1 -53
  136. package/dist/notifications/services/sms.service.js +1 -62
  137. package/dist/notifications/services/web.service.d.ts +15 -0
  138. package/dist/notifications/services/web.service.js +1 -0
  139. package/dist/passport/google.strategy.d.ts +13 -0
  140. package/dist/passport/google.strategy.js +1 -0
  141. package/dist/passport/index.d.ts +4 -0
  142. package/dist/passport/index.js +1 -0
  143. package/dist/passport/jwt.strategy.js +1 -55
  144. package/dist/passport/kakao.strategy.d.ts +2 -1
  145. package/dist/passport/kakao.strategy.js +1 -36
  146. package/dist/passport/local.strategy.js +1 -41
  147. package/dist/redis/index.js +1 -18
  148. package/dist/redis/redis-constraint.js +1 -4
  149. package/dist/redis/redis.module.js +1 -62
  150. package/dist/redis/redis.service.js +1 -76
  151. package/dist/role/dto/create-role.dto.js +1 -41
  152. package/dist/role/dto/index.js +1 -19
  153. package/dist/role/dto/response-roles.dto.js +1 -62
  154. package/dist/role/dto/update-role.dto.js +1 -9
  155. package/dist/role/index.js +1 -19
  156. package/dist/role/role.module.js +1 -23
  157. package/dist/role/role.service.d.ts +20 -6
  158. package/dist/role/role.service.js +1 -144
  159. package/dist/services/file.service.d.ts +4 -4
  160. package/dist/services/file.service.js +1 -82
  161. package/dist/services/index.js +1 -18
  162. package/dist/services/permission-checker.service.js +1 -65
  163. package/dist/setup-swagger.js +1 -32
  164. package/dist/shared/error-codes.js +1 -9
  165. package/dist/utils/common.utils.js +1 -42
  166. package/dist/utils/enum.utils.js +1 -8
  167. package/dist/utils/file.utils.d.ts +6 -0
  168. package/dist/utils/file.utils.js +1 -0
  169. package/dist/utils/index.d.ts +1 -0
  170. package/dist/utils/index.js +1 -21
  171. package/dist/utils/object-diff.js +1 -33
  172. package/dist/utils/pagination-qb.utils.js +1 -154
  173. package/dist/utils/pagination.utils.js +1 -32
  174. package/package.json +3 -2
@@ -1,79 +1 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- var __metadata = (this && this.__metadata) || function (k, v) {
9
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.ResponseLikeStatsBaseDto = exports.ResponseLikeBaseDto = void 0;
13
- const swagger_1 = require("@nestjs/swagger");
14
- const class_transformer_1 = require("class-transformer");
15
- const enums_common_1 = require("../../enums.common");
16
- class ResponseUserDto {
17
- }
18
- __decorate([
19
- (0, swagger_1.ApiProperty)({ type: String, example: 'U0000001' }),
20
- (0, class_transformer_1.Expose)(),
21
- __metadata("design:type", String)
22
- ], ResponseUserDto.prototype, "uid", void 0);
23
- __decorate([
24
- (0, swagger_1.ApiProperty)({ type: String, example: 'John Doe' }),
25
- (0, class_transformer_1.Expose)(),
26
- __metadata("design:type", String)
27
- ], ResponseUserDto.prototype, "name", void 0);
28
- __decorate([
29
- (0, swagger_1.ApiProperty)({ type: Number, example: 1 }),
30
- (0, class_transformer_1.Expose)(),
31
- __metadata("design:type", Number)
32
- ], ResponseUserDto.prototype, "cnt_likes", void 0);
33
- class ResponseLikeBaseDto {
34
- }
35
- exports.ResponseLikeBaseDto = ResponseLikeBaseDto;
36
- __decorate([
37
- (0, swagger_1.ApiProperty)({ type: Number, example: 1 }),
38
- (0, class_transformer_1.Expose)(),
39
- __metadata("design:type", Number)
40
- ], ResponseLikeBaseDto.prototype, "id", void 0);
41
- __decorate([
42
- (0, swagger_1.ApiProperty)({ enum: enums_common_1.LIKE_TYPE, example: enums_common_1.LIKE_TYPE.LIKE }),
43
- (0, class_transformer_1.Expose)(),
44
- __metadata("design:type", String)
45
- ], ResponseLikeBaseDto.prototype, "type", void 0);
46
- __decorate([
47
- (0, swagger_1.ApiProperty)({ type: ResponseUserDto }),
48
- (0, class_transformer_1.Expose)(),
49
- (0, class_transformer_1.Type)(() => ResponseUserDto),
50
- __metadata("design:type", ResponseUserDto)
51
- ], ResponseLikeBaseDto.prototype, "user", void 0);
52
- __decorate([
53
- (0, swagger_1.ApiProperty)({ type: Date, example: '2023-01-01T00:00:00.000Z' }),
54
- (0, class_transformer_1.Expose)(),
55
- __metadata("design:type", Date)
56
- ], ResponseLikeBaseDto.prototype, "created_at", void 0);
57
- __decorate([
58
- (0, swagger_1.ApiProperty)({ type: Date, example: '2023-01-01T00:00:00.000Z' }),
59
- (0, class_transformer_1.Expose)(),
60
- __metadata("design:type", Date)
61
- ], ResponseLikeBaseDto.prototype, "updated_at", void 0);
62
- class ResponseLikeStatsBaseDto {
63
- }
64
- exports.ResponseLikeStatsBaseDto = ResponseLikeStatsBaseDto;
65
- __decorate([
66
- (0, swagger_1.ApiProperty)({ type: Number, example: 10 }),
67
- (0, class_transformer_1.Expose)(),
68
- __metadata("design:type", Number)
69
- ], ResponseLikeStatsBaseDto.prototype, "cnt_likes", void 0);
70
- __decorate([
71
- (0, swagger_1.ApiProperty)({ type: Number, example: 2 }),
72
- (0, class_transformer_1.Expose)(),
73
- __metadata("design:type", Number)
74
- ], ResponseLikeStatsBaseDto.prototype, "cnt_dislikes", void 0);
75
- __decorate([
76
- (0, swagger_1.ApiProperty)({ enum: enums_common_1.LIKE_TYPE, example: enums_common_1.LIKE_TYPE.LIKE, required: false }),
77
- (0, class_transformer_1.Expose)(),
78
- __metadata("design:type", String)
79
- ], ResponseLikeStatsBaseDto.prototype, "user_like_type", void 0);
1
+ var e=this&&this.__decorate||function(e,t,o,s){var p,r=arguments.length,i=r<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,o):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,o,s);else for(var n=e.length-1;n>=0;n--)(p=e[n])&&(i=(r<3?p(i):r>3?p(t,o,i):p(t,o))||i);return r>3&&i&&Object.defineProperty(t,o,i),i},t=this&&this.__metadata||function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)};Object.defineProperty(exports,"__esModule",{value:!0}),exports.ResponseLikeStatsBaseDto=exports.ResponseLikeBaseDto=void 0;const o=require("@nestjs/swagger"),s=require("class-transformer"),p=require("../../enums.common");class ResponseUserDto{}e([(0,o.ApiProperty)({type:String,example:"U0000001"}),(0,s.Expose)(),t("design:type",String)],ResponseUserDto.prototype,"uid",void 0),e([(0,o.ApiProperty)({type:String,example:"John Doe"}),(0,s.Expose)(),t("design:type",String)],ResponseUserDto.prototype,"name",void 0),e([(0,o.ApiProperty)({type:Number,example:1}),(0,s.Expose)(),t("design:type",Number)],ResponseUserDto.prototype,"cnt_likes",void 0);class ResponseLikeBaseDto{}exports.ResponseLikeBaseDto=ResponseLikeBaseDto,e([(0,o.ApiProperty)({type:Number,example:1}),(0,s.Expose)(),t("design:type",Number)],ResponseLikeBaseDto.prototype,"id",void 0),e([(0,o.ApiProperty)({enum:p.LIKE_TYPE,example:p.LIKE_TYPE.LIKE}),(0,s.Expose)(),t("design:type",String)],ResponseLikeBaseDto.prototype,"type",void 0),e([(0,o.ApiProperty)({type:ResponseUserDto}),(0,s.Expose)(),(0,s.Type)(()=>ResponseUserDto),t("design:type",ResponseUserDto)],ResponseLikeBaseDto.prototype,"user",void 0),e([(0,o.ApiProperty)({type:Date,example:"2023-01-01T00:00:00.000Z"}),(0,s.Expose)(),t("design:type",Date)],ResponseLikeBaseDto.prototype,"created_at",void 0),e([(0,o.ApiProperty)({type:Date,example:"2023-01-01T00:00:00.000Z"}),(0,s.Expose)(),t("design:type",Date)],ResponseLikeBaseDto.prototype,"updated_at",void 0);class ResponseLikeStatsBaseDto{}exports.ResponseLikeStatsBaseDto=ResponseLikeStatsBaseDto,e([(0,o.ApiProperty)({type:Number,example:10}),(0,s.Expose)(),t("design:type",Number)],ResponseLikeStatsBaseDto.prototype,"cnt_likes",void 0),e([(0,o.ApiProperty)({type:Number,example:2}),(0,s.Expose)(),t("design:type",Number)],ResponseLikeStatsBaseDto.prototype,"cnt_dislikes",void 0),e([(0,o.ApiProperty)({enum:p.LIKE_TYPE,example:p.LIKE_TYPE.LIKE,required:!1}),(0,s.Expose)(),t("design:type",String)],ResponseLikeStatsBaseDto.prototype,"user_like_type",void 0);
@@ -1,19 +1 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./like.module"), exports);
18
- __exportStar(require("./like.service"), exports);
19
- __exportStar(require("./dto"), exports);
1
+ var e=this&&this.__createBinding||(Object.create?function(e,r,t,i){void 0===i&&(i=t);var o=Object.getOwnPropertyDescriptor(r,t);o&&!("get"in o?!r.__esModule:o.writable||o.configurable)||(o={enumerable:!0,get:function(){return r[t]}}),Object.defineProperty(e,i,o)}:function(e,r,t,i){void 0===i&&(i=t),e[i]=r[t]}),r=this&&this.__exportStar||function(r,t){for(var i in r)"default"===i||Object.prototype.hasOwnProperty.call(t,i)||e(t,r,i)};Object.defineProperty(exports,"__esModule",{value:!0}),r(require("./like.module"),exports),r(require("./like.service"),exports),r(require("./dto"),exports);
@@ -1,23 +1 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.LikeModule = void 0;
10
- const common_1 = require("@nestjs/common");
11
- const typeorm_1 = require("@nestjs/typeorm");
12
- const entities_1 = require("../database/entities");
13
- const like_service_1 = require("./like.service");
14
- let LikeModule = class LikeModule {
15
- };
16
- exports.LikeModule = LikeModule;
17
- exports.LikeModule = LikeModule = __decorate([
18
- (0, common_1.Module)({
19
- imports: [typeorm_1.TypeOrmModule.forFeature([entities_1.Like])],
20
- providers: [like_service_1.LikeService],
21
- exports: [like_service_1.LikeService],
22
- })
23
- ], LikeModule);
1
+ var e=this&&this.__decorate||function(e,r,t,o){var i,s=arguments.length,c=s<3?r:null===o?o=Object.getOwnPropertyDescriptor(r,t):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)c=Reflect.decorate(e,r,t,o);else for(var l=e.length-1;l>=0;l--)(i=e[l])&&(c=(s<3?i(c):s>3?i(r,t,c):i(r,t))||c);return s>3&&c&&Object.defineProperty(r,t,c),c};Object.defineProperty(exports,"__esModule",{value:!0}),exports.LikeModule=void 0;const r=require("@nestjs/common"),t=require("@nestjs/typeorm"),o=require("../database/entities"),i=require("./like.service");let s=class LikeModule{};exports.LikeModule=s,exports.LikeModule=s=e([(0,r.Module)({imports:[t.TypeOrmModule.forFeature([o.Like])],providers:[i.LikeService],exports:[i.LikeService]})],s);
@@ -1,6 +1,6 @@
1
1
  import { DataSource, EntityManager, Repository } from 'typeorm';
2
2
  import { Like } from '../database/entities';
3
- import { CreateLikeBaseDto, ResponseLikeBaseDto, ResponseLikeStatsBaseDto } from './dto';
3
+ import { CreateLikeBaseDto, ResponseLikeStatsBaseDto } from './dto';
4
4
  export declare class LikeService<T = string> {
5
5
  protected readonly repository: Repository<Like>;
6
6
  protected readonly dataSource: DataSource;
@@ -8,6 +8,6 @@ export declare class LikeService<T = string> {
8
8
  protected resolveTargetId(target: T, target_id?: number, target_uid?: string): Promise<number>;
9
9
  protected validateTarget(target: T, target_id: number): Promise<void>;
10
10
  protected updateTargetLikeCount(manager: EntityManager, target: T, target_id: number, increment: number): Promise<void>;
11
- toggleLike(user_id: number, _body: CreateLikeBaseDto<T>): Promise<ResponseLikeBaseDto>;
11
+ toggleLike(user_id: number, _body: CreateLikeBaseDto<T>): Promise<Like>;
12
12
  getStats(target: T, target_id?: number, target_uid?: string, user_id?: number): Promise<ResponseLikeStatsBaseDto>;
13
13
  }
@@ -1,155 +1 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- var __metadata = (this && this.__metadata) || function (k, v) {
9
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
- };
11
- var __param = (this && this.__param) || function (paramIndex, decorator) {
12
- return function (target, key) { decorator(target, key, paramIndex); }
13
- };
14
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
15
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
16
- return new (P || (P = Promise))(function (resolve, reject) {
17
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
18
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
19
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
20
- step((generator = generator.apply(thisArg, _arguments || [])).next());
21
- });
22
- };
23
- Object.defineProperty(exports, "__esModule", { value: true });
24
- exports.LikeService = void 0;
25
- const common_1 = require("@nestjs/common");
26
- const typeorm_1 = require("@nestjs/typeorm");
27
- const class_transformer_1 = require("class-transformer");
28
- const typeorm_2 = require("typeorm");
29
- const entities_1 = require("../database/entities");
30
- const enums_common_1 = require("../enums.common");
31
- const dto_1 = require("./dto");
32
- let LikeService = class LikeService {
33
- constructor(repository, dataSource) {
34
- this.repository = repository;
35
- this.dataSource = dataSource;
36
- }
37
- resolveTargetId(target, target_id, target_uid) {
38
- return __awaiter(this, void 0, void 0, function* () {
39
- if (target_id)
40
- return target_id;
41
- if (!target_uid) {
42
- throw new common_1.BadRequestException('Either target_id or target_uid is required');
43
- }
44
- throw new common_1.BadRequestException('resolveTargetId must be implemented in app service');
45
- });
46
- }
47
- validateTarget(target, target_id) {
48
- return __awaiter(this, void 0, void 0, function* () {
49
- throw new common_1.BadRequestException('validateTarget must be implemented in app service');
50
- });
51
- }
52
- updateTargetLikeCount(manager, target, target_id, increment) {
53
- return __awaiter(this, void 0, void 0, function* () {
54
- throw new common_1.BadRequestException('updateTargetLikeCount must be implemented in app service');
55
- });
56
- }
57
- toggleLike(user_id, _body) {
58
- return __awaiter(this, void 0, void 0, function* () {
59
- const { target, target_id, target_uid, type } = _body;
60
- const resolved_target_id = yield this.resolveTargetId(target, target_id, target_uid);
61
- yield this.validateTarget(target, resolved_target_id);
62
- const finalLike = yield this.dataSource.transaction((manager) => __awaiter(this, void 0, void 0, function* () {
63
- const existingLike = yield manager.findOne(entities_1.Like, {
64
- where: {
65
- target: target,
66
- target_id: resolved_target_id,
67
- user_id,
68
- },
69
- });
70
- if (existingLike) {
71
- if (existingLike.type === type) {
72
- yield manager.update(entities_1.Like, existingLike.id, { type: enums_common_1.LIKE_TYPE.NONE });
73
- const countChange = type === enums_common_1.LIKE_TYPE.LIKE ? -1 : 0;
74
- if (countChange !== 0) {
75
- yield this.updateTargetLikeCount(manager, target, resolved_target_id, countChange);
76
- }
77
- }
78
- else {
79
- yield manager.update(entities_1.Like, existingLike.id, { type });
80
- const previousIncrement = existingLike.type === enums_common_1.LIKE_TYPE.LIKE ? -1 : 0;
81
- const newIncrement = type === enums_common_1.LIKE_TYPE.LIKE ? 1 : 0;
82
- const totalChange = previousIncrement + newIncrement;
83
- if (totalChange !== 0) {
84
- yield this.updateTargetLikeCount(manager, target, resolved_target_id, totalChange);
85
- }
86
- }
87
- }
88
- else {
89
- yield manager.save(entities_1.Like, {
90
- target: target,
91
- target_id: resolved_target_id,
92
- user_id,
93
- type,
94
- });
95
- const countChange = type === enums_common_1.LIKE_TYPE.LIKE ? 1 : 0;
96
- if (countChange !== 0) {
97
- yield this.updateTargetLikeCount(manager, target, resolved_target_id, countChange);
98
- }
99
- }
100
- return yield manager.findOne(entities_1.Like, {
101
- where: {
102
- target: target,
103
- target_id: resolved_target_id,
104
- user_id,
105
- },
106
- });
107
- }));
108
- return finalLike ? (0, class_transformer_1.plainToClass)(dto_1.ResponseLikeBaseDto, finalLike) : null;
109
- });
110
- }
111
- getStats(target, target_id, target_uid, user_id) {
112
- return __awaiter(this, void 0, void 0, function* () {
113
- const resolved_target_id = yield this.resolveTargetId(target, target_id, target_uid);
114
- yield this.validateTarget(target, resolved_target_id);
115
- const likeCount = yield this.repository.count({
116
- where: {
117
- target: target,
118
- target_id: resolved_target_id,
119
- type: enums_common_1.LIKE_TYPE.LIKE,
120
- },
121
- });
122
- const dislikeCount = yield this.repository.count({
123
- where: {
124
- target: target,
125
- target_id: resolved_target_id,
126
- type: enums_common_1.LIKE_TYPE.DISLIKE,
127
- },
128
- });
129
- const stats = {
130
- cnt_likes: likeCount,
131
- cnt_dislikes: dislikeCount,
132
- };
133
- if (user_id) {
134
- const userLike = yield this.repository.findOne({
135
- where: {
136
- target: target,
137
- target_id: resolved_target_id,
138
- user_id,
139
- },
140
- });
141
- if (userLike && userLike.type !== enums_common_1.LIKE_TYPE.NONE) {
142
- stats.user_like_type = userLike.type;
143
- }
144
- }
145
- return (0, class_transformer_1.plainToClass)(dto_1.ResponseLikeStatsBaseDto, stats);
146
- });
147
- }
148
- };
149
- exports.LikeService = LikeService;
150
- exports.LikeService = LikeService = __decorate([
151
- (0, common_1.Injectable)(),
152
- __param(0, (0, typeorm_1.InjectRepository)(entities_1.Like)),
153
- __metadata("design:paramtypes", [typeorm_2.Repository,
154
- typeorm_2.DataSource])
155
- ], LikeService);
1
+ var e=this&&this.__decorate||function(e,t,i,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,i):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,i,r);else for(var s=e.length-1;s>=0;s--)(n=e[s])&&(a=(o<3?n(a):o>3?n(t,i,a):n(t,i))||a);return o>3&&a&&Object.defineProperty(t,i,a),a},t=this&&this.__metadata||function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)},i=this&&this.__param||function(e,t){return function(i,r){t(i,r,e)}},r=this&&this.__awaiter||function(e,t,i,r){return new(i||(i=Promise))(function(n,o){function fulfilled(e){try{step(r.next(e))}catch(e){o(e)}}function rejected(e){try{step(r.throw(e))}catch(e){o(e)}}function step(e){e.done?n(e.value):function adopt(e){return e instanceof i?e:new i(function(t){t(e)})}(e.value).then(fulfilled,rejected)}step((r=r.apply(e,t||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.LikeService=void 0;const n=require("@nestjs/common"),o=require("@nestjs/typeorm"),a=require("typeorm"),s=require("../database/entities"),d=require("../enums.common");let u=class LikeService{constructor(e,t){this.repository=e,this.dataSource=t}resolveTargetId(e,t,i){return r(this,void 0,void 0,function*(){if(t)return t;if(!i)throw new n.BadRequestException("Either target_id or target_uid is required");throw new n.BadRequestException("resolveTargetId must be implemented in app service")})}validateTarget(e,t){return r(this,void 0,void 0,function*(){throw new n.BadRequestException("validateTarget must be implemented in app service")})}updateTargetLikeCount(e,t,i,o){return r(this,void 0,void 0,function*(){throw new n.BadRequestException("updateTargetLikeCount must be implemented in app service")})}toggleLike(e,t){return r(this,void 0,void 0,function*(){const{target:i,target_id:n,target_uid:o,type:a}=t,u=yield this.resolveTargetId(i,n,o);yield this.validateTarget(i,u);const c=yield this.dataSource.transaction(t=>r(this,void 0,void 0,function*(){const r=yield t.findOne(s.Like,{where:{target:i,target_id:u,user_id:e}});if(r)if(r.type===a){yield t.update(s.Like,r.id,{type:d.LIKE_TYPE.NONE});const e=a===d.LIKE_TYPE.LIKE?-1:0;0!==e&&(yield this.updateTargetLikeCount(t,i,u,e))}else{yield t.update(s.Like,r.id,{type:a});const e=(r.type===d.LIKE_TYPE.LIKE?-1:0)+(a===d.LIKE_TYPE.LIKE?1:0);0!==e&&(yield this.updateTargetLikeCount(t,i,u,e))}else{yield t.save(s.Like,{target:i,target_id:u,user_id:e,type:a});const r=a===d.LIKE_TYPE.LIKE?1:0;0!==r&&(yield this.updateTargetLikeCount(t,i,u,r))}return yield t.findOne(s.Like,{where:{target:i,target_id:u,user_id:e}})}));return c||null})}getStats(e,t,i,n){return r(this,void 0,void 0,function*(){const r=yield this.resolveTargetId(e,t,i);yield this.validateTarget(e,r);const o={cnt_likes:yield this.repository.count({where:{target:e,target_id:r,type:d.LIKE_TYPE.LIKE}}),cnt_dislikes:yield this.repository.count({where:{target:e,target_id:r,type:d.LIKE_TYPE.DISLIKE}})};if(n){const t=yield this.repository.findOne({where:{target:e,target_id:r,user_id:n}});t&&t.type!==d.LIKE_TYPE.NONE&&(o.user_like_type=t.type)}return o})}};exports.LikeService=u,exports.LikeService=u=e([(0,n.Injectable)(),i(0,(0,o.InjectRepository)(s.Like)),t("design:paramtypes",[a.Repository,a.DataSource])],u);
@@ -1,18 +1 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./pino-options"), exports);
18
- __exportStar(require("./pino-pretty-transport"), exports);
1
+ var e=this&&this.__createBinding||(Object.create?function(e,t,r,o){void 0===o&&(o=r);var i=Object.getOwnPropertyDescriptor(t,r);i&&!("get"in i?!t.__esModule:i.writable||i.configurable)||(i={enumerable:!0,get:function(){return t[r]}}),Object.defineProperty(e,o,i)}:function(e,t,r,o){void 0===o&&(o=r),e[o]=t[r]}),t=this&&this.__exportStar||function(t,r){for(var o in t)"default"===o||Object.prototype.hasOwnProperty.call(r,o)||e(r,t,o)};Object.defineProperty(exports,"__esModule",{value:!0}),t(require("./pino-options"),exports),t(require("./pino-pretty-transport"),exports);
@@ -1,77 +1 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.COMMON_LOGGER_OPTIONS = void 0;
4
- const ua_parser_js_1 = require("ua-parser-js");
5
- exports.COMMON_LOGGER_OPTIONS = {
6
- customLogLevel: (req, res, err) => {
7
- if (res.statusCode >= 400 && res.statusCode < 500)
8
- return 'warn';
9
- if (res.statusCode >= 500 || err)
10
- return 'error';
11
- return 'info';
12
- },
13
- customProps: (req, res) => {
14
- const uaParser = new ua_parser_js_1.UAParser(req.headers['user-agent']);
15
- const browser = uaParser.getBrowser();
16
- const os = uaParser.getOS();
17
- const deviceType = uaParser.getDevice().type || 'desktop';
18
- return {
19
- method: req.method,
20
- url: req.url,
21
- ip: req.headers['x-forwarded-for'] || req.connection.remoteAddress,
22
- statusCode: res.statusCode,
23
- browser: browser.name || 'unknown',
24
- os: os.name || 'unknown',
25
- deviceType: deviceType || 'unknown',
26
- };
27
- },
28
- serializers: {
29
- req: () => undefined,
30
- res: () => undefined,
31
- err(err) {
32
- var _a, _b;
33
- if (process.env.NODE_ENV !== 'production') {
34
- return {
35
- type: err === null || err === void 0 ? void 0 : err.name,
36
- message: err === null || err === void 0 ? void 0 : err.message,
37
- code: (_a = err === null || err === void 0 ? void 0 : err.response) === null || _a === void 0 ? void 0 : _a.code,
38
- stack: err === null || err === void 0 ? void 0 : err.stack,
39
- };
40
- }
41
- else {
42
- return {
43
- type: err === null || err === void 0 ? void 0 : err.name,
44
- message: err === null || err === void 0 ? void 0 : err.message,
45
- code: (_b = err === null || err === void 0 ? void 0 : err.response) === null || _b === void 0 ? void 0 : _b.code,
46
- };
47
- }
48
- },
49
- },
50
- redact: {
51
- remove: true,
52
- paths: [
53
- 'email',
54
- 'password',
55
- 'req.query',
56
- 'req.params',
57
- 'req.query',
58
- 'res.headers',
59
- 'req.headers.host',
60
- 'req.headers.connection',
61
- 'req.headers.accept',
62
- 'req.headers.origin',
63
- 'req.headers.referer',
64
- 'req.headers["content-type"]',
65
- 'req.headers["sec-ch-ua"]',
66
- 'req.headers["sec-ch-ua-mobile"]',
67
- 'req.headers["user-agent"]',
68
- 'req.headers["sec-ch-ua-platform"]',
69
- 'req.headers["sec-fetch-site"]',
70
- 'req.headers["sec-fetch-mode"]',
71
- 'req.headers["sec-fetch-dest"]',
72
- 'req.headers["accept-encoding"]',
73
- 'req.headers["accept-language"]',
74
- 'req.headers["if-none-match"]',
75
- ],
76
- },
77
- };
1
+ Object.defineProperty(exports,"__esModule",{value:!0}),exports.COMMON_LOGGER_OPTIONS=void 0;const e=require("ua-parser-js");exports.COMMON_LOGGER_OPTIONS={customLogLevel:(e,r,s)=>r.statusCode>=400&&r.statusCode<500?"warn":r.statusCode>=500||s?"error":"info",customProps:(r,s)=>{const o=new e.UAParser(r.headers["user-agent"]),a=o.getBrowser(),d=o.getOS(),t=o.getDevice().type||"desktop";return{method:r.method,url:r.url,ip:r.headers["x-forwarded-for"]||r.connection.remoteAddress,statusCode:s.statusCode,browser:a.name||"unknown",os:d.name||"unknown",deviceType:t||"unknown"}},serializers:{req:()=>{},res:()=>{},err(e){var r,s;return"production"!==process.env.NODE_ENV?{type:null==e?void 0:e.name,message:null==e?void 0:e.message,code:null===(r=null==e?void 0:e.response)||void 0===r?void 0:r.code,stack:null==e?void 0:e.stack}:{type:null==e?void 0:e.name,message:null==e?void 0:e.message,code:null===(s=null==e?void 0:e.response)||void 0===s?void 0:s.code}}},redact:{remove:!0,paths:["email","password","req.query","req.params","req.query","res.headers","req.headers.host","req.headers.connection","req.headers.accept","req.headers.origin","req.headers.referer",'req.headers["content-type"]','req.headers["sec-ch-ua"]','req.headers["sec-ch-ua-mobile"]','req.headers["user-agent"]','req.headers["sec-ch-ua-platform"]','req.headers["sec-fetch-site"]','req.headers["sec-fetch-mode"]','req.headers["sec-fetch-dest"]','req.headers["accept-encoding"]','req.headers["accept-language"]','req.headers["if-none-match"]']}};
@@ -1,164 +1 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const pinoPretty = require("pino-pretty");
4
- const date_fns_tz_1 = require("date-fns-tz");
5
- function getLevel(level, extras) {
6
- let levelStr, levelColor;
7
- switch (level) {
8
- case 10:
9
- levelStr = 'TRACE';
10
- levelColor = extras.colors.gray;
11
- break;
12
- case 20:
13
- levelStr = 'DEBUG';
14
- levelColor = extras.colors.blue;
15
- break;
16
- case 30:
17
- levelStr = 'INFO';
18
- levelColor = extras.colors.green;
19
- break;
20
- case 40:
21
- levelStr = 'WARN';
22
- levelColor = extras.colors.yellow;
23
- break;
24
- case 50:
25
- levelStr = 'ERROR';
26
- levelColor = extras.colors.red;
27
- break;
28
- case 60:
29
- levelStr = 'FATAL';
30
- levelColor = extras.colors.magenta;
31
- break;
32
- default:
33
- levelStr = `LEVEL:${level}`;
34
- levelColor = extras.colors.white;
35
- }
36
- return { levelStr, levelColor };
37
- }
38
- function getMethodInfo(method, colors) {
39
- let methodColor;
40
- switch (method.toUpperCase()) {
41
- case 'GET':
42
- methodColor = colors.blue;
43
- break;
44
- case 'POST':
45
- methodColor = colors.green;
46
- break;
47
- case 'PUT':
48
- methodColor = colors.yellow;
49
- break;
50
- case 'PATCH':
51
- methodColor = colors.blueBright;
52
- break;
53
- case 'DELETE':
54
- methodColor = colors.redBright;
55
- break;
56
- default:
57
- methodColor = colors.white;
58
- }
59
- return { methodColor, methodStr: method.toUpperCase() };
60
- }
61
- function getResponseTimeInfo(_responseTime, colors) {
62
- let responseTimeColor = colors.white;
63
- if (_responseTime) {
64
- if (_responseTime < 50)
65
- responseTimeColor = colors.gray;
66
- else if (_responseTime < 100)
67
- responseTimeColor = colors.yellow;
68
- else
69
- responseTimeColor = colors.red;
70
- }
71
- return { responseTimeColor, responseTimeStr: _responseTime + 'ms' };
72
- }
73
- function getStatusCodeInfo(statusCode, colors) {
74
- let statusCodeColor = colors.white;
75
- if (statusCode) {
76
- if (statusCode < 300)
77
- statusCodeColor = colors.green;
78
- else if (statusCode < 400)
79
- statusCodeColor = colors.cyan;
80
- else if (statusCode < 500)
81
- statusCodeColor = colors.red;
82
- else
83
- statusCodeColor = colors.redBright;
84
- }
85
- return { statusCodeColor, statusCodeStr: statusCode.toString() };
86
- }
87
- function pinoPrettyTransport(opts) {
88
- const timezone = opts.timezone || 'Asia/Seoul';
89
- const ignoreContext = opts.ignoreContext || [
90
- 'InstanceLoader',
91
- 'RouterExplorer',
92
- ];
93
- return pinoPretty(Object.assign(Object.assign({ singleLine: true, colorize: true, colorizeObjects: false, hideObject: true, ignore: 'time,pid,hostname,context,level' }, opts), { levelFirst: true, messageFormat(log, messageKey, levelLabel, extras) {
94
- if (ignoreContext.includes(log.context)) {
95
- return;
96
- }
97
- const timestamp = log.time
98
- ? (0, date_fns_tz_1.formatInTimeZone)(new Date(log.time), timezone, 'HH:mm:ss')
99
- : '';
100
- const tz = log.time
101
- ? (0, date_fns_tz_1.formatInTimeZone)(new Date(log.time), timezone, 'zzz')
102
- : '';
103
- if (log.method) {
104
- const { methodColor, methodStr } = getMethodInfo(log.method, extras.colors);
105
- const { responseTimeColor, responseTimeStr } = getResponseTimeInfo(log.responseTime, extras.colors);
106
- const { statusCodeColor, statusCodeStr } = getStatusCodeInfo(log.statusCode, extras.colors);
107
- if (log.err) {
108
- const arr = [
109
- extras.colors.dim(extras.colors.white(timestamp)),
110
- extras.colors.gray(tz),
111
- '',
112
- extras.colors.underline(statusCodeColor(statusCodeStr)),
113
- extras.colors.bold(methodColor(methodStr.padEnd(6))),
114
- methodColor(log.url),
115
- responseTimeColor(responseTimeStr),
116
- ];
117
- const err_arr = [];
118
- if (log.err.code)
119
- err_arr.push(extras.colors.italic(extras.colors.red(log.err.code)));
120
- if (log.err.stack)
121
- err_arr.push(extras.colors.red(log.err.stack));
122
- return arr.join(' ') + '\n' + err_arr.join('\n') + '\n';
123
- }
124
- else {
125
- const arr = [
126
- extras.colors.dim(extras.colors.white(timestamp)),
127
- extras.colors.gray(tz),
128
- '',
129
- statusCodeColor(statusCodeStr),
130
- extras.colors.bold(methodColor(methodStr.padEnd(6))),
131
- methodColor(log.url),
132
- responseTimeColor(responseTimeStr),
133
- ];
134
- return arr.join(' ') + '\n';
135
- }
136
- }
137
- const { levelStr, levelColor } = getLevel(log.level, extras);
138
- const context = log.context
139
- ? extras.colors.yellow(`[${log.context}]`)
140
- : '';
141
- const arr = [
142
- extras.colors.dim(extras.colors.white(timestamp)),
143
- extras.colors.gray(tz),
144
- '',
145
- levelColor(levelStr),
146
- context,
147
- levelColor(log[messageKey]),
148
- ];
149
- return arr.join(' ') + '\n';
150
- }, customPrettifiers: {
151
- time: (timestamp, key, log, extras) => {
152
- return `⏰ ${timestamp}`;
153
- },
154
- level: (logLevel, key, log, extras) => {
155
- return `LEVEL: ${logLevel} LABEL: ${extras.label} COLORIZED LABEL: ${extras.labelColorized}x`;
156
- },
157
- hostname: (hostname) => `MY HOST: ${hostname}`,
158
- pid: (pid) => pid,
159
- name: (name, key, log, { colors }) => `${colors.blue(name)}`,
160
- caller: (caller, key, log, { colors }) => `${colors.greenBright(caller)}`,
161
- myCustomLogProp: (value, key, log, { colors }) => `My Prop -> ${colors.bold(value)} <--`,
162
- } }));
163
- }
164
- module.exports = pinoPrettyTransport;
1
+ Object.defineProperty(exports,"__esModule",{value:!0});const e=require("date-fns-tz"),o=require("pino-pretty");module.exports=function pinoPrettyTransport(r){const t=r.timezone||"Asia/Seoul",s=r.ignoreContext||["InstanceLoader","RouterExplorer"];return o(Object.assign(Object.assign({singleLine:!0,colorize:!0,colorizeObjects:!1,hideObject:!0,ignore:"time,pid,hostname,context,level"},r),{levelFirst:!0,messageFormat(o,r,l,n){if(s.includes(o.context))return;const c=o.time?(0,e.formatInTimeZone)(new Date(o.time),t,"HH:mm:ss"):"",i=o.time?(0,e.formatInTimeZone)(new Date(o.time),t,"zzz"):"";if(o.method){const{methodColor:e,methodStr:r}=function getMethodInfo(e,o){let r;switch(e.toUpperCase()){case"GET":r=o.blue;break;case"POST":r=o.green;break;case"PUT":r=o.yellow;break;case"PATCH":r=o.blueBright;break;case"DELETE":r=o.redBright;break;default:r=o.white}return{methodColor:r,methodStr:e.toUpperCase()}}(o.method,n.colors),{responseTimeColor:t,responseTimeStr:s}=function getResponseTimeInfo(e,o){let r=o.white;return e&&(r=e<50?o.gray:e<100?o.yellow:o.red),{responseTimeColor:r,responseTimeStr:e+"ms"}}(o.responseTime,n.colors),{statusCodeColor:l,statusCodeStr:a}=function getStatusCodeInfo(e,o){let r=o.white;return e&&(r=e<300?o.green:e<400?o.cyan:e<500?o.red:o.redBright),{statusCodeColor:r,statusCodeStr:e.toString()}}(o.statusCode,n.colors);if(o.err){const d=[n.colors.dim(n.colors.white(c)),n.colors.gray(i),"",n.colors.underline(l(a)),n.colors.bold(e(r.padEnd(6))),e(o.url),t(s)],u=[];return o.err.code&&u.push(n.colors.italic(n.colors.red(o.err.code))),o.err.stack&&u.push(n.colors.red(o.err.stack)),d.join(" ")+"\n"+u.join("\n")+"\n"}return[n.colors.dim(n.colors.white(c)),n.colors.gray(i),"",l(a),n.colors.bold(e(r.padEnd(6))),e(o.url),t(s)].join(" ")+"\n"}const{levelStr:a,levelColor:d}=function getLevel(e,o){let r,t;switch(e){case 10:r="TRACE",t=o.colors.gray;break;case 20:r="DEBUG",t=o.colors.blue;break;case 30:r="INFO",t=o.colors.green;break;case 40:r="WARN",t=o.colors.yellow;break;case 50:r="ERROR",t=o.colors.red;break;case 60:r="FATAL",t=o.colors.magenta;break;default:r=`LEVEL:${e}`,t=o.colors.white}return{levelStr:r,levelColor:t}}(o.level,n),u=o.context?n.colors.yellow(`[${o.context}]`):"";return[n.colors.dim(n.colors.white(c)),n.colors.gray(i),"",d(a),u,d(o[r])].join(" ")+"\n"},customPrettifiers:{time:(e,o,r,t)=>`⏰ ${e}`,level:(e,o,r,t)=>`LEVEL: ${e} LABEL: ${t.label} COLORIZED LABEL: ${t.labelColorized}x`,hostname:e=>`MY HOST: ${e}`,pid:e=>e,name:(e,o,r,{colors:t})=>`${t.blue(e)}`,caller:(e,o,r,{colors:t})=>`${t.greenBright(e)}`,myCustomLogProp:(e,o,r,{colors:t})=>`My Prop -> ${t.bold(e)} <--`}}))};
@@ -6,6 +6,14 @@ export interface NotificationRecipient {
6
6
  variables?: Record<string, any>;
7
7
  }
8
8
  export interface NotificationOptions {
9
+ web?: {
10
+ recipients: NotificationRecipient[];
11
+ title?: string;
12
+ content?: string;
13
+ template_key?: string;
14
+ variables?: Record<string, any>;
15
+ meta?: Record<string, any>;
16
+ };
9
17
  email?: {
10
18
  recipients: NotificationRecipient[];
11
19
  subject?: string;
@@ -15,7 +23,7 @@ export interface NotificationOptions {
15
23
  };
16
24
  slack?: {
17
25
  channel: string;
18
- message?: string;
26
+ content?: string;
19
27
  template_key?: string;
20
28
  variables?: Record<string, any>;
21
29
  };
@@ -26,12 +34,27 @@ export interface NotificationOptions {
26
34
  };
27
35
  sms?: {
28
36
  recipients: NotificationRecipient[];
29
- message?: string;
37
+ content?: string;
30
38
  template_key?: string;
31
39
  variables?: Record<string, any>;
32
40
  };
33
41
  }
34
42
  export type NotificationPayload = {
43
+ type: 'web';
44
+ recipients: Array<{
45
+ recipient: string;
46
+ user_id: number;
47
+ title?: string;
48
+ content?: string;
49
+ variables?: Record<string, any>;
50
+ meta?: Record<string, any>;
51
+ }>;
52
+ title?: string;
53
+ content?: string;
54
+ template_key?: string;
55
+ variables?: Record<string, any>;
56
+ meta?: Record<string, any>;
57
+ } | {
35
58
  type: 'email';
36
59
  recipients: Array<{
37
60
  recipient: string;
@@ -49,7 +72,7 @@ export type NotificationPayload = {
49
72
  user_id: number;
50
73
  variables?: Record<string, any>;
51
74
  }>;
52
- message?: string;
75
+ content?: string;
53
76
  template_key?: string;
54
77
  variables?: Record<string, any>;
55
78
  } | {
@@ -64,7 +87,7 @@ export type NotificationPayload = {
64
87
  } | {
65
88
  type: 'slack';
66
89
  channel: string;
67
- message?: string;
90
+ content?: string;
68
91
  template_key?: string;
69
92
  variables?: Record<string, any>;
70
93
  };