yingzios-platform-backend-shared 1.0.1
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 +51 -0
- package/dist/apollo/apollo.config.d.ts +26 -0
- package/dist/apollo/apollo.config.d.ts.map +1 -0
- package/dist/apollo/apollo.config.js +2 -0
- package/dist/apollo/apollo.module.d.ts +13 -0
- package/dist/apollo/apollo.module.d.ts.map +1 -0
- package/dist/apollo/apollo.module.js +61 -0
- package/dist/apollo/apollo.service.d.ts +17 -0
- package/dist/apollo/apollo.service.d.ts.map +1 -0
- package/dist/apollo/apollo.service.js +35 -0
- package/dist/apollo/index.d.ts +5 -0
- package/dist/apollo/index.d.ts.map +1 -0
- package/dist/apollo/index.js +17 -0
- package/dist/cache/cache.config.d.ts +28 -0
- package/dist/cache/cache.config.d.ts.map +1 -0
- package/dist/cache/cache.config.js +2 -0
- package/dist/cache/cache.module.d.ts +39 -0
- package/dist/cache/cache.module.d.ts.map +1 -0
- package/dist/cache/cache.module.js +75 -0
- package/dist/cache/cache.service.d.ts +49 -0
- package/dist/cache/cache.service.d.ts.map +1 -0
- package/dist/cache/cache.service.js +208 -0
- package/dist/cache/index.d.ts +4 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +19 -0
- package/dist/env/env-loader.d.ts +50 -0
- package/dist/env/env-loader.d.ts.map +1 -0
- package/dist/env/env-loader.js +159 -0
- package/dist/env/env.module.d.ts +11 -0
- package/dist/env/env.module.d.ts.map +1 -0
- package/dist/env/env.module.js +47 -0
- package/dist/env/env.service.d.ts +31 -0
- package/dist/env/env.service.d.ts.map +1 -0
- package/dist/env/env.service.js +195 -0
- package/dist/env/index.d.ts +4 -0
- package/dist/env/index.d.ts.map +1 -0
- package/dist/env/index.js +19 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +27 -0
- package/dist/internal-auth/decorators/caller.decorator.d.ts +29 -0
- package/dist/internal-auth/decorators/caller.decorator.d.ts.map +1 -0
- package/dist/internal-auth/decorators/caller.decorator.js +37 -0
- package/dist/internal-auth/decorators/index.d.ts +3 -0
- package/dist/internal-auth/decorators/index.d.ts.map +1 -0
- package/dist/internal-auth/decorators/index.js +18 -0
- package/dist/internal-auth/decorators/use-either-guard.decorator.d.ts +31 -0
- package/dist/internal-auth/decorators/use-either-guard.decorator.d.ts.map +1 -0
- package/dist/internal-auth/decorators/use-either-guard.decorator.js +79 -0
- package/dist/internal-auth/guards/index.d.ts +2 -0
- package/dist/internal-auth/guards/index.d.ts.map +1 -0
- package/dist/internal-auth/guards/index.js +17 -0
- package/dist/internal-auth/guards/service-key.guard.d.ts +36 -0
- package/dist/internal-auth/guards/service-key.guard.d.ts.map +1 -0
- package/dist/internal-auth/guards/service-key.guard.js +86 -0
- package/dist/internal-auth/index.d.ts +43 -0
- package/dist/internal-auth/index.d.ts.map +1 -0
- package/dist/internal-auth/index.js +62 -0
- package/dist/internal-auth/internal-auth.module.d.ts +62 -0
- package/dist/internal-auth/internal-auth.module.d.ts.map +1 -0
- package/dist/internal-auth/internal-auth.module.js +118 -0
- package/dist/internal-auth/internal-http.service.d.ts +72 -0
- package/dist/internal-auth/internal-http.service.d.ts.map +1 -0
- package/dist/internal-auth/internal-http.service.js +119 -0
- package/dist/jwt/auto-fill-user.pipe.d.ts +43 -0
- package/dist/jwt/auto-fill-user.pipe.d.ts.map +1 -0
- package/dist/jwt/auto-fill-user.pipe.js +166 -0
- package/dist/jwt/decorators/current-user.decorator.d.ts +37 -0
- package/dist/jwt/decorators/current-user.decorator.d.ts.map +1 -0
- package/dist/jwt/decorators/current-user.decorator.js +29 -0
- package/dist/jwt/decorators/public.decorator.d.ts +8 -0
- package/dist/jwt/decorators/public.decorator.d.ts.map +1 -0
- package/dist/jwt/decorators/public.decorator.js +12 -0
- package/dist/jwt/guards/jwt-auth.guard.d.ts +20 -0
- package/dist/jwt/guards/jwt-auth.guard.d.ts.map +1 -0
- package/dist/jwt/guards/jwt-auth.guard.js +88 -0
- package/dist/jwt/index.d.ts +8 -0
- package/dist/jwt/index.d.ts.map +1 -0
- package/dist/jwt/index.js +26 -0
- package/dist/jwt/jwt-config.service.d.ts +10 -0
- package/dist/jwt/jwt-config.service.d.ts.map +1 -0
- package/dist/jwt/jwt-config.service.js +40 -0
- package/dist/jwt/jwt.config.d.ts +15 -0
- package/dist/jwt/jwt.config.d.ts.map +1 -0
- package/dist/jwt/jwt.config.js +2 -0
- package/dist/jwt/jwt.module.d.ts +19 -0
- package/dist/jwt/jwt.module.d.ts.map +1 -0
- package/dist/jwt/jwt.module.js +100 -0
- package/dist/jwt/jwt.service.d.ts +31 -0
- package/dist/jwt/jwt.service.d.ts.map +1 -0
- package/dist/jwt/jwt.service.js +71 -0
- package/dist/jwt/strategies/jwt.strategy.d.ts +25 -0
- package/dist/jwt/strategies/jwt.strategy.d.ts.map +1 -0
- package/dist/jwt/strategies/jwt.strategy.js +150 -0
- package/dist/jwt/user-aware-axios.service.d.ts +17 -0
- package/dist/jwt/user-aware-axios.service.d.ts.map +1 -0
- package/dist/jwt/user-aware-axios.service.js +105 -0
- package/dist/jwt/utils/jwt.utils.d.ts +24 -0
- package/dist/jwt/utils/jwt.utils.d.ts.map +1 -0
- package/dist/jwt/utils/jwt.utils.js +40 -0
- package/dist/logger/index.d.ts +4 -0
- package/dist/logger/index.d.ts.map +1 -0
- package/dist/logger/index.js +19 -0
- package/dist/logger/logger.config.d.ts +41 -0
- package/dist/logger/logger.config.d.ts.map +1 -0
- package/dist/logger/logger.config.js +13 -0
- package/dist/logger/logger.module.d.ts +17 -0
- package/dist/logger/logger.module.d.ts.map +1 -0
- package/dist/logger/logger.module.js +49 -0
- package/dist/logger/logger.service.d.ts +62 -0
- package/dist/logger/logger.service.d.ts.map +1 -0
- package/dist/logger/logger.service.js +124 -0
- package/dist/logger/winston.config.d.ts +43 -0
- package/dist/logger/winston.config.d.ts.map +1 -0
- package/dist/logger/winston.config.js +183 -0
- package/dist/nacos/index.d.ts +4 -0
- package/dist/nacos/index.d.ts.map +1 -0
- package/dist/nacos/index.js +19 -0
- package/dist/nacos/nacos.config.d.ts +10 -0
- package/dist/nacos/nacos.config.d.ts.map +1 -0
- package/dist/nacos/nacos.config.js +2 -0
- package/dist/nacos/nacos.module.d.ts +9 -0
- package/dist/nacos/nacos.module.d.ts.map +1 -0
- package/dist/nacos/nacos.module.js +42 -0
- package/dist/nacos/nacos.service.d.ts +43 -0
- package/dist/nacos/nacos.service.d.ts.map +1 -0
- package/dist/nacos/nacos.service.js +212 -0
- package/dist/nacos/utils.d.ts +10 -0
- package/dist/nacos/utils.d.ts.map +1 -0
- package/dist/nacos/utils.js +65 -0
- package/dist/restful/current-request.util.d.ts +16 -0
- package/dist/restful/current-request.util.d.ts.map +1 -0
- package/dist/restful/current-request.util.js +34 -0
- package/dist/restful/http-exception.filter.d.ts +24 -0
- package/dist/restful/http-exception.filter.d.ts.map +1 -0
- package/dist/restful/http-exception.filter.js +126 -0
- package/dist/restful/index.d.ts +8 -0
- package/dist/restful/index.d.ts.map +1 -0
- package/dist/restful/index.js +23 -0
- package/dist/restful/request-context.middleware.d.ts +6 -0
- package/dist/restful/request-context.middleware.d.ts.map +1 -0
- package/dist/restful/request-context.middleware.js +25 -0
- package/dist/restful/response-codes.d.ts +104 -0
- package/dist/restful/response-codes.d.ts.map +1 -0
- package/dist/restful/response-codes.js +163 -0
- package/dist/restful/response.dto.d.ts +52 -0
- package/dist/restful/response.dto.d.ts.map +1 -0
- package/dist/restful/response.dto.js +146 -0
- package/dist/restful/response.interceptor.d.ts +17 -0
- package/dist/restful/response.interceptor.d.ts.map +1 -0
- package/dist/restful/response.interceptor.js +86 -0
- package/dist/restful/restful.module.d.ts +5 -0
- package/dist/restful/restful.module.d.ts.map +1 -0
- package/dist/restful/restful.module.js +26 -0
- package/dist/sequelize/index.d.ts +4 -0
- package/dist/sequelize/index.d.ts.map +1 -0
- package/dist/sequelize/index.js +19 -0
- package/dist/sequelize/sequelize.config.d.ts +24 -0
- package/dist/sequelize/sequelize.config.d.ts.map +1 -0
- package/dist/sequelize/sequelize.config.js +5 -0
- package/dist/sequelize/sequelize.module.d.ts +28 -0
- package/dist/sequelize/sequelize.module.d.ts.map +1 -0
- package/dist/sequelize/sequelize.module.js +50 -0
- package/dist/sequelize/sequelize.provider.d.ts +7 -0
- package/dist/sequelize/sequelize.provider.d.ts.map +1 -0
- package/dist/sequelize/sequelize.provider.js +154 -0
- package/dist/snowflake/index.d.ts +4 -0
- package/dist/snowflake/index.d.ts.map +1 -0
- package/dist/snowflake/index.js +19 -0
- package/dist/snowflake/snowflake.config.d.ts +30 -0
- package/dist/snowflake/snowflake.config.d.ts.map +1 -0
- package/dist/snowflake/snowflake.config.js +12 -0
- package/dist/snowflake/snowflake.module.d.ts +17 -0
- package/dist/snowflake/snowflake.module.d.ts.map +1 -0
- package/dist/snowflake/snowflake.module.js +58 -0
- package/dist/snowflake/snowflake.service.d.ts +21 -0
- package/dist/snowflake/snowflake.service.d.ts.map +1 -0
- package/dist/snowflake/snowflake.service.js +44 -0
- package/dist/swagger/index.d.ts +6 -0
- package/dist/swagger/index.d.ts.map +1 -0
- package/dist/swagger/index.js +19 -0
- package/dist/swagger/swagger.config.d.ts +45 -0
- package/dist/swagger/swagger.config.d.ts.map +1 -0
- package/dist/swagger/swagger.config.js +19 -0
- package/dist/swagger/swagger.decorators.d.ts +21 -0
- package/dist/swagger/swagger.decorators.d.ts.map +1 -0
- package/dist/swagger/swagger.decorators.js +112 -0
- package/dist/swagger/swagger.module.d.ts +15 -0
- package/dist/swagger/swagger.module.d.ts.map +1 -0
- package/dist/swagger/swagger.module.js +49 -0
- package/dist/swagger/swagger.service.d.ts +44 -0
- package/dist/swagger/swagger.service.d.ts.map +1 -0
- package/dist/swagger/swagger.service.js +202 -0
- package/package.json +75 -0
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* JWT工具函数
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.formatJwtOptions = formatJwtOptions;
|
|
7
|
+
/**
|
|
8
|
+
* 解析过期时间字符串为秒数
|
|
9
|
+
* @param expiresIn 过期时间,支持格式如 "60s", "5m", "1h", "7d"
|
|
10
|
+
* @returns 秒数
|
|
11
|
+
*/
|
|
12
|
+
function parseExpiresInToSeconds(expiresIn) {
|
|
13
|
+
const units = {
|
|
14
|
+
s: 1,
|
|
15
|
+
m: 60,
|
|
16
|
+
h: 3600,
|
|
17
|
+
d: 86400,
|
|
18
|
+
};
|
|
19
|
+
const match = expiresIn.match(/^(\d+)([smhd])$/);
|
|
20
|
+
if (!match) {
|
|
21
|
+
throw new Error(`Invalid expiresIn format: ${expiresIn}`);
|
|
22
|
+
}
|
|
23
|
+
const [, value, unit] = match;
|
|
24
|
+
return parseInt(value, 10) * units[unit];
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* 格式化JWT配置选项
|
|
28
|
+
*/
|
|
29
|
+
function formatJwtOptions(options) {
|
|
30
|
+
return {
|
|
31
|
+
secret: options.secret,
|
|
32
|
+
signOptions: {
|
|
33
|
+
expiresIn: typeof options.expiresIn === 'string'
|
|
34
|
+
? parseExpiresInToSeconds(options.expiresIn)
|
|
35
|
+
: options.expiresIn,
|
|
36
|
+
issuer: options.issuer,
|
|
37
|
+
audience: options.audience,
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/logger/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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("./logger.module"), exports);
|
|
18
|
+
__exportStar(require("./logger.service"), exports);
|
|
19
|
+
__exportStar(require("./logger.config"), exports);
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 默认日志配置
|
|
3
|
+
*/
|
|
4
|
+
export declare const DEFAULT_LOGGER_CONFIG: Partial<ILoggerConfig>;
|
|
5
|
+
/**
|
|
6
|
+
* 日志配置接口
|
|
7
|
+
*/
|
|
8
|
+
export interface ILoggerConfig {
|
|
9
|
+
/**
|
|
10
|
+
* 应用名称(可选)
|
|
11
|
+
* 用于区分不同应用的日志文件,会创建 logDir/app 子目录
|
|
12
|
+
* 如果为空字符串或不提供,直接使用 logDir
|
|
13
|
+
*/
|
|
14
|
+
app?: string;
|
|
15
|
+
/**
|
|
16
|
+
* 日志级别
|
|
17
|
+
* 默认: 'info'
|
|
18
|
+
*/
|
|
19
|
+
level?: string;
|
|
20
|
+
/**
|
|
21
|
+
* 日志目录
|
|
22
|
+
* 默认: 'logs'
|
|
23
|
+
*/
|
|
24
|
+
logDir?: string;
|
|
25
|
+
/**
|
|
26
|
+
* 普通日志保留天数
|
|
27
|
+
* 默认: 14
|
|
28
|
+
*/
|
|
29
|
+
maxFiles?: number | string;
|
|
30
|
+
/**
|
|
31
|
+
* 错误日志保留天数
|
|
32
|
+
* 默认: 30
|
|
33
|
+
*/
|
|
34
|
+
errorMaxFiles?: number | string;
|
|
35
|
+
/**
|
|
36
|
+
* 最大文件大小
|
|
37
|
+
* 默认: '20m'
|
|
38
|
+
*/
|
|
39
|
+
maxSize?: string;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=logger.config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.config.d.ts","sourceRoot":"","sources":["../../src/logger/logger.config.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,eAAO,MAAM,qBAAqB,EAAE,OAAO,CAAC,aAAa,CAMxD,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B;;;;OAIG;IACH,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAE3B;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAEhC;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DEFAULT_LOGGER_CONFIG = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* 默认日志配置
|
|
6
|
+
*/
|
|
7
|
+
exports.DEFAULT_LOGGER_CONFIG = {
|
|
8
|
+
level: 'info',
|
|
9
|
+
logDir: 'logs',
|
|
10
|
+
maxFiles: '14d',
|
|
11
|
+
errorMaxFiles: '30d',
|
|
12
|
+
maxSize: '5m',
|
|
13
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { DynamicModule } from '@nestjs/common';
|
|
2
|
+
import { ILoggerConfig } from './logger.config';
|
|
3
|
+
export type LoggerModuleOptions = {
|
|
4
|
+
isGlobal?: boolean;
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* 日志模块
|
|
8
|
+
* 支持 forRoot() 和 forFeature() 模式进行配置
|
|
9
|
+
*/
|
|
10
|
+
export declare class LoggerModule {
|
|
11
|
+
/**
|
|
12
|
+
* 静态方法:配置日志模块
|
|
13
|
+
* 用于根模块注册
|
|
14
|
+
*/
|
|
15
|
+
static forRoot(config: ILoggerConfig, options?: LoggerModuleOptions): DynamicModule;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=logger.module.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.module.d.ts","sourceRoot":"","sources":["../../src/logger/logger.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAoB,MAAM,gBAAgB,CAAC;AAEjE,OAAO,EAAE,aAAa,EAAyB,MAAM,iBAAiB,CAAC;AAEvE,MAAM,MAAM,mBAAmB,GAAG;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF;;;GAGG;AACH,qBACa,YAAY;IACvB;;;OAGG;IACH,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,aAAa,EAAE,OAAO,GAAE,mBAAwB,GAAG,aAAa;CAwBxF"}
|
|
@@ -0,0 +1,49 @@
|
|
|
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 LoggerModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.LoggerModule = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const logger_service_1 = require("./logger.service");
|
|
13
|
+
const logger_config_1 = require("./logger.config");
|
|
14
|
+
/**
|
|
15
|
+
* 日志模块
|
|
16
|
+
* 支持 forRoot() 和 forFeature() 模式进行配置
|
|
17
|
+
*/
|
|
18
|
+
let LoggerModule = LoggerModule_1 = class LoggerModule {
|
|
19
|
+
/**
|
|
20
|
+
* 静态方法:配置日志模块
|
|
21
|
+
* 用于根模块注册
|
|
22
|
+
*/
|
|
23
|
+
static forRoot(config, options = {}) {
|
|
24
|
+
const mergedConfig = {
|
|
25
|
+
...logger_config_1.DEFAULT_LOGGER_CONFIG,
|
|
26
|
+
...config,
|
|
27
|
+
};
|
|
28
|
+
const configProvider = {
|
|
29
|
+
provide: 'LOGGER_CONFIG',
|
|
30
|
+
useValue: mergedConfig,
|
|
31
|
+
};
|
|
32
|
+
return {
|
|
33
|
+
module: LoggerModule_1,
|
|
34
|
+
global: options.isGlobal ?? true,
|
|
35
|
+
providers: [
|
|
36
|
+
configProvider,
|
|
37
|
+
{
|
|
38
|
+
provide: 'APP_LOGGER',
|
|
39
|
+
useClass: logger_service_1.CustomLogger,
|
|
40
|
+
},
|
|
41
|
+
],
|
|
42
|
+
exports: ['APP_LOGGER'],
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
exports.LoggerModule = LoggerModule;
|
|
47
|
+
exports.LoggerModule = LoggerModule = LoggerModule_1 = __decorate([
|
|
48
|
+
(0, common_1.Module)({})
|
|
49
|
+
], LoggerModule);
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { LoggerService as NestLoggerService } from '@nestjs/common';
|
|
2
|
+
import type { ILoggerConfig } from './logger.config';
|
|
3
|
+
/**
|
|
4
|
+
* 自定义日志服务(基于Winston)
|
|
5
|
+
* 实现NestJS的LoggerService接口
|
|
6
|
+
*/
|
|
7
|
+
export declare class CustomLogger implements NestLoggerService {
|
|
8
|
+
protected config: ILoggerConfig;
|
|
9
|
+
private logger;
|
|
10
|
+
private context?;
|
|
11
|
+
constructor(config: ILoggerConfig, context?: string);
|
|
12
|
+
/**
|
|
13
|
+
* 设置日志上下文
|
|
14
|
+
*/
|
|
15
|
+
setContext(context: string): void;
|
|
16
|
+
/**
|
|
17
|
+
* 强制记录日志(不受日志级别限制)
|
|
18
|
+
*/
|
|
19
|
+
forceLog(message: string, context?: string): void;
|
|
20
|
+
/**
|
|
21
|
+
* 记录日志
|
|
22
|
+
*/
|
|
23
|
+
log(message: string, context?: string): void;
|
|
24
|
+
/**
|
|
25
|
+
* 记录错误
|
|
26
|
+
*/
|
|
27
|
+
error(message: string, trace?: string, context?: string): void;
|
|
28
|
+
/**
|
|
29
|
+
* 记录警告
|
|
30
|
+
*/
|
|
31
|
+
warn(message: string, context?: string): void;
|
|
32
|
+
/**
|
|
33
|
+
* 记录调试信息
|
|
34
|
+
*/
|
|
35
|
+
debug(message: string, context?: string): void;
|
|
36
|
+
/**
|
|
37
|
+
* 记录详细信息
|
|
38
|
+
*/
|
|
39
|
+
verbose(message: string, context?: string): void;
|
|
40
|
+
/**
|
|
41
|
+
* 获取日志文件列表
|
|
42
|
+
*/
|
|
43
|
+
getLogFiles(): string[];
|
|
44
|
+
/**
|
|
45
|
+
* 清理旧日志文件
|
|
46
|
+
* 注意:winston-daily-rotate-file会自动清理,这里只是兼容接口
|
|
47
|
+
*/
|
|
48
|
+
cleanupOldLogs(daysToKeep?: number): void;
|
|
49
|
+
/**
|
|
50
|
+
* 创建子日志器
|
|
51
|
+
*/
|
|
52
|
+
createChildLogger(context: string): CustomLogger;
|
|
53
|
+
/**
|
|
54
|
+
* 获取Winston原始日志器
|
|
55
|
+
*/
|
|
56
|
+
getWinstonLogger(): any;
|
|
57
|
+
/**
|
|
58
|
+
* 获取应用名称
|
|
59
|
+
*/
|
|
60
|
+
getAppName(): string;
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=logger.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.service.d.ts","sourceRoot":"","sources":["../../src/logger/logger.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,aAAa,IAAI,iBAAiB,EAAoB,MAAM,gBAAgB,CAAC;AAElG,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAErD;;;GAGG;AACH,qBACa,YAAa,YAAW,iBAAiB;IAMlD,SAAS,CAAC,MAAM,EAAE,aAAa;IALjC,OAAO,CAAC,MAAM,CAAC;IACf,OAAO,CAAC,OAAO,CAAC,CAAS;gBAIb,MAAM,EAAE,aAAa,EACO,OAAO,CAAC,EAAE,MAAM;IAMxD;;OAEG;IACH,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAKjC;;OAEG;IACH,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI;IAOjD;;OAEG;IACH,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI;IAK5C;;OAEG;IACH,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI;IAK9D;;OAEG;IACH,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI;IAK7C;;OAEG;IACH,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI;IAK9C;;OAEG;IACH,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI;IAKhD;;OAEG;IACH,WAAW,IAAI,MAAM,EAAE;IAMvB;;;OAGG;IACH,cAAc,CAAC,UAAU,GAAE,MAAU,GAAG,IAAI;IAI5C;;OAEG;IACH,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,YAAY;IAIhD;;OAEG;IACH,gBAAgB;IAIhB;;OAEG;IACH,UAAU,IAAI,MAAM;CAGrB"}
|
|
@@ -0,0 +1,124 @@
|
|
|
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 CustomLogger_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.CustomLogger = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const winston_config_1 = require("./winston.config");
|
|
19
|
+
/**
|
|
20
|
+
* 自定义日志服务(基于Winston)
|
|
21
|
+
* 实现NestJS的LoggerService接口
|
|
22
|
+
*/
|
|
23
|
+
let CustomLogger = CustomLogger_1 = class CustomLogger {
|
|
24
|
+
config;
|
|
25
|
+
logger;
|
|
26
|
+
context;
|
|
27
|
+
constructor(config, context) {
|
|
28
|
+
this.config = config;
|
|
29
|
+
this.context = context;
|
|
30
|
+
this.logger = (0, winston_config_1.createWinstonLogger)(config, context);
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* 设置日志上下文
|
|
34
|
+
*/
|
|
35
|
+
setContext(context) {
|
|
36
|
+
this.context = context;
|
|
37
|
+
this.logger = (0, winston_config_1.createWinstonLogger)(this.config, context);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* 强制记录日志(不受日志级别限制)
|
|
41
|
+
*/
|
|
42
|
+
forceLog(message, context) {
|
|
43
|
+
const logContext = context || this.context;
|
|
44
|
+
// 使用winston记录器输出,指定'info'级别确保会被输出
|
|
45
|
+
// 绕过日志级别控制,直接使用底层log方法
|
|
46
|
+
this.logger.log('info', `[FORCE] ${message}`, { context: logContext });
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* 记录日志
|
|
50
|
+
*/
|
|
51
|
+
log(message, context) {
|
|
52
|
+
const logContext = context || this.context;
|
|
53
|
+
this.logger.info(message, { context: logContext });
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* 记录错误
|
|
57
|
+
*/
|
|
58
|
+
error(message, trace, context) {
|
|
59
|
+
const logContext = context || this.context;
|
|
60
|
+
this.logger.error(message, { trace, context: logContext });
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* 记录警告
|
|
64
|
+
*/
|
|
65
|
+
warn(message, context) {
|
|
66
|
+
const logContext = context || this.context;
|
|
67
|
+
this.logger.warn(message, { context: logContext });
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* 记录调试信息
|
|
71
|
+
*/
|
|
72
|
+
debug(message, context) {
|
|
73
|
+
const logContext = context || this.context;
|
|
74
|
+
this.logger.debug(message, { context: logContext });
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* 记录详细信息
|
|
78
|
+
*/
|
|
79
|
+
verbose(message, context) {
|
|
80
|
+
const logContext = context || this.context;
|
|
81
|
+
this.logger.verbose(message, { context: logContext });
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* 获取日志文件列表
|
|
85
|
+
*/
|
|
86
|
+
getLogFiles() {
|
|
87
|
+
// 这里可以扩展为读取logs目录下的文件
|
|
88
|
+
// 由于winston-daily-rotate-file会自动管理文件,这里返回空数组
|
|
89
|
+
return [];
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* 清理旧日志文件
|
|
93
|
+
* 注意:winston-daily-rotate-file会自动清理,这里只是兼容接口
|
|
94
|
+
*/
|
|
95
|
+
cleanupOldLogs(daysToKeep = 7) {
|
|
96
|
+
this.logger.info(`日志自动清理功能由winston-daily-rotate-file处理,保留天数: ${daysToKeep}`);
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* 创建子日志器
|
|
100
|
+
*/
|
|
101
|
+
createChildLogger(context) {
|
|
102
|
+
return new CustomLogger_1(this.config, context);
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* 获取Winston原始日志器
|
|
106
|
+
*/
|
|
107
|
+
getWinstonLogger() {
|
|
108
|
+
return this.logger;
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* 获取应用名称
|
|
112
|
+
*/
|
|
113
|
+
getAppName() {
|
|
114
|
+
return this.config.app || 'app';
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
exports.CustomLogger = CustomLogger;
|
|
118
|
+
exports.CustomLogger = CustomLogger = CustomLogger_1 = __decorate([
|
|
119
|
+
(0, common_1.Injectable)(),
|
|
120
|
+
__param(0, (0, common_1.Inject)('LOGGER_CONFIG')),
|
|
121
|
+
__param(1, (0, common_1.Optional)()),
|
|
122
|
+
__param(1, (0, common_1.Inject)('LOGGER_CONTEXT')),
|
|
123
|
+
__metadata("design:paramtypes", [Object, String])
|
|
124
|
+
], CustomLogger);
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import * as winston from 'winston';
|
|
2
|
+
import DailyRotateFile from 'winston-daily-rotate-file';
|
|
3
|
+
import { ILoggerConfig } from './logger.config';
|
|
4
|
+
/**
|
|
5
|
+
* 创建Winston日志配置
|
|
6
|
+
*/
|
|
7
|
+
export declare const createWinstonConfig: (config: ILoggerConfig) => {
|
|
8
|
+
/**
|
|
9
|
+
* 日志格式
|
|
10
|
+
*/
|
|
11
|
+
format: winston.Logform.Format;
|
|
12
|
+
/**
|
|
13
|
+
* 默认元数据
|
|
14
|
+
*/
|
|
15
|
+
defaultMeta: {
|
|
16
|
+
service: string;
|
|
17
|
+
};
|
|
18
|
+
/**
|
|
19
|
+
* 日志级别
|
|
20
|
+
*/
|
|
21
|
+
level: string;
|
|
22
|
+
/**
|
|
23
|
+
* 日志传输器
|
|
24
|
+
*/
|
|
25
|
+
transports: (DailyRotateFile | winston.transports.ConsoleTransportInstance)[];
|
|
26
|
+
/**
|
|
27
|
+
* 异常处理 - 按天文件夹组织
|
|
28
|
+
*/
|
|
29
|
+
exceptionHandlers: DailyRotateFile[];
|
|
30
|
+
/**
|
|
31
|
+
* 拒绝处理 - 按天文件夹组织
|
|
32
|
+
*/
|
|
33
|
+
rejectionHandlers: DailyRotateFile[];
|
|
34
|
+
/**
|
|
35
|
+
* 退出时是否完成所有日志写入
|
|
36
|
+
*/
|
|
37
|
+
exitOnError: boolean;
|
|
38
|
+
};
|
|
39
|
+
/**
|
|
40
|
+
* 创建Winston日志实例
|
|
41
|
+
*/
|
|
42
|
+
export declare const createWinstonLogger: (config: ILoggerConfig, context?: string) => winston.Logger;
|
|
43
|
+
//# sourceMappingURL=winston.config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"winston.config.d.ts","sourceRoot":"","sources":["../../src/logger/winston.config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AACnC,OAAO,eAAe,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAIhD;;GAEG;AACH,eAAO,MAAM,mBAAmB,GAAI,QAAQ,aAAa;IAyBrD;;OAEG;;IAOH;;OAEG;;;;IAGH;;OAEG;;IAGH;;OAEG;;IAkFH;;OAEG;;IAeH;;OAEG;;IAeH;;OAEG;;CAGN,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,mBAAmB,GAAI,QAAQ,aAAa,EAAE,UAAU,MAAM,mBAU1E,CAAC"}
|
|
@@ -0,0 +1,183 @@
|
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.createWinstonLogger = exports.createWinstonConfig = void 0;
|
|
40
|
+
const winston = __importStar(require("winston"));
|
|
41
|
+
const winston_daily_rotate_file_1 = __importDefault(require("winston-daily-rotate-file"));
|
|
42
|
+
const fs = __importStar(require("fs"));
|
|
43
|
+
const path = __importStar(require("path"));
|
|
44
|
+
/**
|
|
45
|
+
* 创建Winston日志配置
|
|
46
|
+
*/
|
|
47
|
+
const createWinstonConfig = (config) => {
|
|
48
|
+
const { app, level = 'info', logDir = 'logs', maxFiles = '14d', errorMaxFiles = '30d', maxSize = '5m', } = config;
|
|
49
|
+
// 如果 app 为空字符串,直接使用 logDir;否则创建 logDir/app 子目录
|
|
50
|
+
const appLogDir = app && app.trim() ? path.join(logDir, app) : logDir;
|
|
51
|
+
if (!fs.existsSync(appLogDir)) {
|
|
52
|
+
fs.mkdirSync(appLogDir, { recursive: true });
|
|
53
|
+
}
|
|
54
|
+
// 普通文本格式(非 JSON)
|
|
55
|
+
const textFormat = winston.format.printf(({ timestamp, level, message, context, trace, ...meta }) => {
|
|
56
|
+
const contextStr = context ? `[${context}]` : '';
|
|
57
|
+
const traceStr = trace ? `\n${trace}` : '';
|
|
58
|
+
const metaStr = Object.keys(meta).length > 0 ? ` ${JSON.stringify(meta)}` : '';
|
|
59
|
+
return `${timestamp} ${level.toUpperCase()}: ${contextStr} ${message}${metaStr}${traceStr}`;
|
|
60
|
+
});
|
|
61
|
+
return {
|
|
62
|
+
/**
|
|
63
|
+
* 日志格式
|
|
64
|
+
*/
|
|
65
|
+
format: winston.format.combine(winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), winston.format.errors({ stack: true }), winston.format.splat()),
|
|
66
|
+
/**
|
|
67
|
+
* 默认元数据
|
|
68
|
+
*/
|
|
69
|
+
defaultMeta: { service: app || 'app' },
|
|
70
|
+
/**
|
|
71
|
+
* 日志级别
|
|
72
|
+
*/
|
|
73
|
+
level,
|
|
74
|
+
/**
|
|
75
|
+
* 日志传输器
|
|
76
|
+
*/
|
|
77
|
+
transports: [
|
|
78
|
+
/**
|
|
79
|
+
* 控制台输出
|
|
80
|
+
*/
|
|
81
|
+
new winston.transports.Console({
|
|
82
|
+
level,
|
|
83
|
+
format: winston.format.combine(winston.format.colorize(), winston.format.printf(({ timestamp, level, message, context, trace }) => {
|
|
84
|
+
const contextStr = context ? `[${context}]` : '';
|
|
85
|
+
const traceStr = trace ? `\n${trace}` : '';
|
|
86
|
+
return `${timestamp} ${level}: ${contextStr} ${message}${traceStr}`;
|
|
87
|
+
})),
|
|
88
|
+
}),
|
|
89
|
+
/**
|
|
90
|
+
* Error 级别日志 - 按天文件夹组织
|
|
91
|
+
*/
|
|
92
|
+
new winston_daily_rotate_file_1.default({
|
|
93
|
+
filename: path.join(appLogDir, '%DATE%', 'error.log'),
|
|
94
|
+
datePattern: 'YYYY-MM-DD',
|
|
95
|
+
maxSize,
|
|
96
|
+
maxFiles: errorMaxFiles,
|
|
97
|
+
level: 'error',
|
|
98
|
+
auditFile: path.join(appLogDir, '.error-audit.json'),
|
|
99
|
+
format: winston.format.combine(winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), textFormat),
|
|
100
|
+
}),
|
|
101
|
+
/**
|
|
102
|
+
* Warn 级别日志 - 按天文件夹组织
|
|
103
|
+
*/
|
|
104
|
+
new winston_daily_rotate_file_1.default({
|
|
105
|
+
filename: path.join(appLogDir, '%DATE%', 'warn.log'),
|
|
106
|
+
datePattern: 'YYYY-MM-DD',
|
|
107
|
+
maxSize,
|
|
108
|
+
maxFiles,
|
|
109
|
+
level: 'warn',
|
|
110
|
+
auditFile: path.join(appLogDir, '.warn-audit.json'),
|
|
111
|
+
format: winston.format.combine(winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), textFormat),
|
|
112
|
+
}),
|
|
113
|
+
/**
|
|
114
|
+
* Info 级别日志 - 按天文件夹组织
|
|
115
|
+
*/
|
|
116
|
+
new winston_daily_rotate_file_1.default({
|
|
117
|
+
filename: path.join(appLogDir, '%DATE%', 'info.log'),
|
|
118
|
+
datePattern: 'YYYY-MM-DD',
|
|
119
|
+
maxSize,
|
|
120
|
+
maxFiles,
|
|
121
|
+
level: 'info',
|
|
122
|
+
auditFile: path.join(appLogDir, '.info-audit.json'),
|
|
123
|
+
format: winston.format.combine(winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), textFormat),
|
|
124
|
+
}),
|
|
125
|
+
/**
|
|
126
|
+
* Debug 级别日志 - 按天文件夹组织
|
|
127
|
+
*/
|
|
128
|
+
new winston_daily_rotate_file_1.default({
|
|
129
|
+
filename: path.join(appLogDir, '%DATE%', 'debug.log'),
|
|
130
|
+
datePattern: 'YYYY-MM-DD',
|
|
131
|
+
maxSize,
|
|
132
|
+
maxFiles,
|
|
133
|
+
level: 'debug',
|
|
134
|
+
auditFile: path.join(appLogDir, '.debug-audit.json'),
|
|
135
|
+
format: winston.format.combine(winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), textFormat),
|
|
136
|
+
}),
|
|
137
|
+
],
|
|
138
|
+
/**
|
|
139
|
+
* 异常处理 - 按天文件夹组织
|
|
140
|
+
*/
|
|
141
|
+
exceptionHandlers: [
|
|
142
|
+
new winston_daily_rotate_file_1.default({
|
|
143
|
+
filename: path.join(appLogDir, '%DATE%', 'exceptions.log'),
|
|
144
|
+
datePattern: 'YYYY-MM-DD',
|
|
145
|
+
maxSize,
|
|
146
|
+
maxFiles: errorMaxFiles,
|
|
147
|
+
auditFile: path.join(appLogDir, '.exceptions-audit.json'),
|
|
148
|
+
format: winston.format.combine(winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), textFormat),
|
|
149
|
+
}),
|
|
150
|
+
],
|
|
151
|
+
/**
|
|
152
|
+
* 拒绝处理 - 按天文件夹组织
|
|
153
|
+
*/
|
|
154
|
+
rejectionHandlers: [
|
|
155
|
+
new winston_daily_rotate_file_1.default({
|
|
156
|
+
filename: path.join(appLogDir, '%DATE%', 'rejections.log'),
|
|
157
|
+
datePattern: 'YYYY-MM-DD',
|
|
158
|
+
maxSize,
|
|
159
|
+
maxFiles: errorMaxFiles,
|
|
160
|
+
auditFile: path.join(appLogDir, '.rejections-audit.json'),
|
|
161
|
+
format: winston.format.combine(winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), textFormat),
|
|
162
|
+
}),
|
|
163
|
+
],
|
|
164
|
+
/**
|
|
165
|
+
* 退出时是否完成所有日志写入
|
|
166
|
+
*/
|
|
167
|
+
exitOnError: false,
|
|
168
|
+
};
|
|
169
|
+
};
|
|
170
|
+
exports.createWinstonConfig = createWinstonConfig;
|
|
171
|
+
/**
|
|
172
|
+
* 创建Winston日志实例
|
|
173
|
+
*/
|
|
174
|
+
const createWinstonLogger = (config, context) => {
|
|
175
|
+
const winstonConfig = (0, exports.createWinstonConfig)(config);
|
|
176
|
+
const logger = winston.createLogger(winstonConfig);
|
|
177
|
+
// 添加上下文到日志
|
|
178
|
+
if (context) {
|
|
179
|
+
logger.defaultMeta = { ...logger.defaultMeta, context };
|
|
180
|
+
}
|
|
181
|
+
return logger;
|
|
182
|
+
};
|
|
183
|
+
exports.createWinstonLogger = createWinstonLogger;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/nacos/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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("./nacos.config"), exports);
|
|
18
|
+
__exportStar(require("./nacos.module"), exports);
|
|
19
|
+
__exportStar(require("./nacos.service"), exports);
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export interface INacosConfig {
|
|
2
|
+
serverAddr?: string;
|
|
3
|
+
namespace?: string;
|
|
4
|
+
username?: string;
|
|
5
|
+
password?: string;
|
|
6
|
+
serviceNames?: string[];
|
|
7
|
+
currentServiceName?: string;
|
|
8
|
+
currentServicePort?: string | number;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=nacos.config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nacos.config.d.ts","sourceRoot":"","sources":["../../src/nacos/nacos.config.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,kBAAkB,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACtC"}
|