@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.
- package/README.md +2 -0
- package/dist/aws/aws-s3.service.js +1 -158
- package/dist/aws/aws.module.js +1 -25
- package/dist/aws/aws.service.js +1 -21
- package/dist/aws/constants/storage.constant.js +1 -25
- package/dist/aws/dto/create-s3-presigned.dto.js +1 -78
- package/dist/aws/dto/index.js +1 -18
- package/dist/aws/dto/response-s3-presigned.dto.js +1 -110
- package/dist/aws/index.js +1 -20
- package/dist/aws/types/s3.interface.js +1 -2
- package/dist/aws/types/storage.interface.js +1 -2
- package/dist/category/category.module.js +1 -23
- package/dist/category/category.service.d.ts +20 -8
- package/dist/category/category.service.js +1 -124
- package/dist/category/dto/create-category.dto.js +1 -34
- package/dist/category/dto/delete-category.dto.js +1 -6
- package/dist/category/dto/index.js +1 -21
- package/dist/category/dto/response-categories.dto.js +1 -52
- package/dist/category/dto/update-category-sort.dto.js +1 -33
- package/dist/category/dto/update-category.dto.js +1 -9
- package/dist/category/index.js +1 -19
- package/dist/comment/comment.module.js +1 -23
- package/dist/comment/comment.service.d.ts +12 -3
- package/dist/comment/comment.service.js +1 -240
- package/dist/comment/dto/create-comment.dto.d.ts +1 -0
- package/dist/comment/dto/create-comment.dto.js +1 -41
- package/dist/comment/dto/index.js +1 -19
- package/dist/comment/dto/response-comment.dto.d.ts +5 -2
- package/dist/comment/dto/response-comment.dto.js +1 -97
- package/dist/comment/dto/update-comment.dto.js +1 -22
- package/dist/comment/index.js +1 -19
- package/dist/database/entities/category.entity.js +1 -70
- package/dist/database/entities/comment.entity.d.ts +2 -0
- package/dist/database/entities/comment.entity.js +1 -77
- package/dist/database/entities/config.entity.js +1 -44
- package/dist/database/entities/file.entity.js +1 -91
- package/dist/database/entities/index.js +1 -26
- package/dist/database/entities/like.entity.d.ts +1 -0
- package/dist/database/entities/like.entity.js +1 -49
- package/dist/database/entities/logs-audit.entity.d.ts +3 -0
- package/dist/database/entities/logs-audit.entity.js +1 -72
- package/dist/database/entities/logs-event.entity.d.ts +2 -0
- package/dist/database/entities/logs-event.entity.js +1 -72
- package/dist/database/entities/notification-recipient.entity.d.ts +4 -0
- package/dist/database/entities/notification-recipient.entity.js +1 -74
- package/dist/database/entities/notification.entity.d.ts +4 -0
- package/dist/database/entities/notification.entity.js +1 -69
- package/dist/database/entities/role.entity.js +1 -54
- package/dist/decorators/api-custom-params.decorator.js +1 -35
- package/dist/decorators/auth.decorator.factory.js +1 -33
- package/dist/decorators/cookies.decorator.js +1 -9
- package/dist/decorators/custom-params.decorator.js +1 -16
- package/dist/decorators/index.d.ts +0 -2
- package/dist/decorators/index.js +1 -24
- package/dist/decorators/patch-body.decorator.js +1 -38
- package/dist/decorators/soft-delete.decorator.js +1 -10
- package/dist/decorators/timestamps.decorator.js +1 -23
- package/dist/decorators/user.decorator.js +1 -8
- package/dist/dto/auth-user-local.dto.js +1 -26
- package/dist/dto/auth-user-sso.dto.js +1 -21
- package/dist/dto/custom-params.dto.js +1 -46
- package/dist/dto/file.dto.js +1 -70
- package/dist/dto/index.js +1 -26
- package/dist/dto/jwt-user.dto.js +1 -6
- package/dist/dto/pagination.dto.js +1 -36
- package/dist/dto/remove-ids.dto.js +1 -23
- package/dist/dto/response-access-token.dto.js +1 -24
- package/dist/dto/response-id.dto.js +1 -35
- package/dist/dto/response-uid.dto.js +1 -35
- package/dist/dto/update-ids.dto.js +1 -45
- package/dist/dto/update-sort.dto.js +1 -50
- package/dist/enums.common.d.ts +2 -1
- package/dist/enums.common.js +1 -62
- package/dist/events/event-bus.module.js +1 -44
- package/dist/events/index.js +1 -20
- package/dist/events/listeners/audit-event.listener.js +1 -58
- package/dist/events/listeners/index.d.ts +1 -0
- package/dist/events/listeners/index.js +1 -17
- package/dist/events/listeners/notification-event.listener.d.ts +7 -0
- package/dist/events/listeners/notification-event.listener.js +1 -0
- package/dist/events/listeners/system-event.listener.js +1 -58
- package/dist/events/services/event-logger.service.js +1 -34
- package/dist/events/services/event-notification.service.js +1 -104
- package/dist/events/services/event-storage.service.js +1 -79
- package/dist/events/services/index.js +1 -20
- package/dist/events/services/token.service.d.ts +2 -4
- package/dist/events/services/token.service.js +1 -88
- package/dist/events/types/audit-events.type.d.ts +4 -1
- package/dist/events/types/audit-events.type.js +1 -2
- package/dist/events/types/index.js +1 -17
- package/dist/filters/http-exception.filter.d.ts +2 -2
- package/dist/filters/http-exception.filter.js +1 -75
- package/dist/filters/index.js +1 -17
- package/dist/guards/auth.guard.js +1 -60
- package/dist/guards/index.d.ts +3 -0
- package/dist/guards/index.js +1 -0
- package/dist/guards/jwt.guard.js +1 -17
- package/dist/guards/permission.guard.d.ts +10 -0
- package/dist/guards/permission.guard.js +1 -0
- package/dist/guards/role.guard.d.ts +8 -0
- package/dist/guards/role.guard.js +1 -0
- package/dist/index.d.ts +2 -1
- package/dist/index.js +1 -36
- package/dist/interceptors/error.interceptor.js +1 -26
- package/dist/interceptors/index.js +1 -18
- package/dist/interceptors/success.interceptor.d.ts +1 -1
- package/dist/interceptors/success.interceptor.js +1 -30
- package/dist/library.module.js +1 -20
- package/dist/like/dto/create-like.dto.js +1 -47
- package/dist/like/dto/index.js +1 -18
- package/dist/like/dto/response-like.dto.js +1 -79
- package/dist/like/index.js +1 -19
- package/dist/like/like.module.js +1 -23
- package/dist/like/like.service.d.ts +2 -2
- package/dist/like/like.service.js +1 -155
- package/dist/logger/index.js +1 -18
- package/dist/logger/pino-options.js +1 -77
- package/dist/logger/pino-pretty-transport.js +1 -164
- package/dist/notifications/index.d.ts +27 -4
- package/dist/notifications/index.js +1 -18
- package/dist/notifications/notification.module.js +1 -32
- package/dist/notifications/services/email.service.d.ts +5 -4
- package/dist/notifications/services/email.service.js +1 -69
- package/dist/notifications/services/index.d.ts +1 -0
- package/dist/notifications/services/index.js +1 -23
- package/dist/notifications/services/kakao.service.d.ts +17 -17
- package/dist/notifications/services/kakao.service.js +1 -94
- package/dist/notifications/services/message-template.service.d.ts +6 -2
- package/dist/notifications/services/message-template.service.js +1 -74
- package/dist/notifications/services/notification-send.service.d.ts +8 -12
- package/dist/notifications/services/notification-send.service.js +1 -146
- package/dist/notifications/services/notification.service.d.ts +3 -1
- package/dist/notifications/services/notification.service.js +1 -125
- package/dist/notifications/services/slack.service.d.ts +6 -1
- package/dist/notifications/services/slack.service.js +1 -53
- package/dist/notifications/services/sms.service.js +1 -62
- package/dist/notifications/services/web.service.d.ts +15 -0
- package/dist/notifications/services/web.service.js +1 -0
- package/dist/passport/google.strategy.d.ts +13 -0
- package/dist/passport/google.strategy.js +1 -0
- package/dist/passport/index.d.ts +4 -0
- package/dist/passport/index.js +1 -0
- package/dist/passport/jwt.strategy.js +1 -55
- package/dist/passport/kakao.strategy.d.ts +2 -1
- package/dist/passport/kakao.strategy.js +1 -36
- package/dist/passport/local.strategy.js +1 -41
- package/dist/redis/index.js +1 -18
- package/dist/redis/redis-constraint.js +1 -4
- package/dist/redis/redis.module.js +1 -62
- package/dist/redis/redis.service.js +1 -76
- package/dist/role/dto/create-role.dto.js +1 -41
- package/dist/role/dto/index.js +1 -19
- package/dist/role/dto/response-roles.dto.js +1 -62
- package/dist/role/dto/update-role.dto.js +1 -9
- package/dist/role/index.js +1 -19
- package/dist/role/role.module.js +1 -23
- package/dist/role/role.service.d.ts +20 -6
- package/dist/role/role.service.js +1 -144
- package/dist/services/file.service.d.ts +4 -4
- package/dist/services/file.service.js +1 -82
- package/dist/services/index.js +1 -18
- package/dist/services/permission-checker.service.js +1 -65
- package/dist/setup-swagger.js +1 -32
- package/dist/shared/error-codes.js +1 -9
- package/dist/utils/common.utils.js +1 -42
- package/dist/utils/enum.utils.js +1 -8
- package/dist/utils/file.utils.d.ts +6 -0
- package/dist/utils/file.utils.js +1 -0
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +1 -21
- package/dist/utils/object-diff.js +1 -33
- package/dist/utils/pagination-qb.utils.js +1 -154
- package/dist/utils/pagination.utils.js +1 -32
- package/package.json +3 -2
|
@@ -1,79 +1 @@
|
|
|
1
|
-
"
|
|
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);
|
package/dist/like/index.js
CHANGED
|
@@ -1,19 +1 @@
|
|
|
1
|
-
"
|
|
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);
|
package/dist/like/like.module.js
CHANGED
|
@@ -1,23 +1 @@
|
|
|
1
|
-
"
|
|
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,
|
|
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<
|
|
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
|
-
"
|
|
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);
|
package/dist/logger/index.js
CHANGED
|
@@ -1,18 +1 @@
|
|
|
1
|
-
"
|
|
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
|
-
"
|
|
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
|
-
"
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
90
|
+
content?: string;
|
|
68
91
|
template_key?: string;
|
|
69
92
|
variables?: Record<string, any>;
|
|
70
93
|
};
|