@libs-for-dev/nestjs-typeorm-logger 1.0.0
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 +27 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +17 -0
- package/dist/typeorm-logger.d.ts +12 -0
- package/dist/typeorm-logger.js +50 -0
- package/package.json +60 -0
package/README.md
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
# NestJS TypeORM logger implementation
|
|
2
|
+
|
|
3
|
+
## Installation
|
|
4
|
+
```bash
|
|
5
|
+
yarn add @libs-for-dev/nestjs-typeorm-logger
|
|
6
|
+
```
|
|
7
|
+
|
|
8
|
+
## Usage
|
|
9
|
+
|
|
10
|
+
```typescript
|
|
11
|
+
import { TypeormLogger } from '@libs-for-dev/nestjs-typeorm-logger'
|
|
12
|
+
|
|
13
|
+
@Module({
|
|
14
|
+
imports: [
|
|
15
|
+
TypeOrmModule.forRootAsync({
|
|
16
|
+
inject: [PinoLogger],
|
|
17
|
+
useFactory: (logger: PinoLogger): TypeOrmModuleOptions => {
|
|
18
|
+
return {
|
|
19
|
+
logger: new TypeormLogger(logger),
|
|
20
|
+
// other TypeORM options
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
}),
|
|
24
|
+
]
|
|
25
|
+
})
|
|
26
|
+
export class ExampleModule {}
|
|
27
|
+
```
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './typeorm-logger';
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
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("./typeorm-logger"), exports);
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { PinoLogger } from 'nestjs-pino';
|
|
2
|
+
import { Logger } from 'typeorm';
|
|
3
|
+
export declare class TypeormLogger implements Logger {
|
|
4
|
+
private readonly logger;
|
|
5
|
+
constructor(logger: PinoLogger);
|
|
6
|
+
log(level: 'info' | 'log' | 'warn', message: object | string): void;
|
|
7
|
+
logMigration(message: string): void;
|
|
8
|
+
logQuery(query: string, parameters?: unknown[]): void;
|
|
9
|
+
logQueryError(error: string, query: string, parameters?: unknown[]): void;
|
|
10
|
+
logQuerySlow(time: number, query: string, parameters?: unknown[]): void;
|
|
11
|
+
logSchemaBuild(message: string): void;
|
|
12
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
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 TypeormLogger_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.TypeormLogger = void 0;
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const nestjs_pino_1 = require("nestjs-pino");
|
|
16
|
+
let TypeormLogger = TypeormLogger_1 = class TypeormLogger {
|
|
17
|
+
logger;
|
|
18
|
+
constructor(logger) {
|
|
19
|
+
this.logger = logger;
|
|
20
|
+
logger.setContext(TypeormLogger_1.name);
|
|
21
|
+
}
|
|
22
|
+
log(level, message) {
|
|
23
|
+
if (level === 'warn') {
|
|
24
|
+
this.logger.warn(message);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.logger.info(message);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
logMigration(message) {
|
|
31
|
+
this.logger.info(message);
|
|
32
|
+
}
|
|
33
|
+
logQuery(query, parameters) {
|
|
34
|
+
this.logger.info({ parameters, query });
|
|
35
|
+
}
|
|
36
|
+
logQueryError(error, query, parameters) {
|
|
37
|
+
this.logger.error({ error, parameters, query });
|
|
38
|
+
}
|
|
39
|
+
logQuerySlow(time, query, parameters) {
|
|
40
|
+
this.logger.warn({ parameters, query, queryTime: time });
|
|
41
|
+
}
|
|
42
|
+
logSchemaBuild(message) {
|
|
43
|
+
this.logger.info(message);
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
exports.TypeormLogger = TypeormLogger;
|
|
47
|
+
exports.TypeormLogger = TypeormLogger = TypeormLogger_1 = __decorate([
|
|
48
|
+
(0, common_1.Injectable)(),
|
|
49
|
+
__metadata("design:paramtypes", [nestjs_pino_1.PinoLogger])
|
|
50
|
+
], TypeormLogger);
|
package/package.json
ADDED
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
{
|
|
2
|
+
"description": "NestJS TypeORM logger",
|
|
3
|
+
"license": "MIT",
|
|
4
|
+
"main": "dist/index.js",
|
|
5
|
+
"name": "@libs-for-dev/nestjs-typeorm-logger",
|
|
6
|
+
"packageManager": "yarn@4.5.1",
|
|
7
|
+
"repository": "https://gitlab.com/libs-for-dev/nestjs/typeorm-logger",
|
|
8
|
+
"types": "dist/index.d.ts",
|
|
9
|
+
"version": "1.0.0",
|
|
10
|
+
"engines": {
|
|
11
|
+
"node": "^23.1.0"
|
|
12
|
+
},
|
|
13
|
+
"files": [
|
|
14
|
+
"dist/**/*"
|
|
15
|
+
],
|
|
16
|
+
"scripts": {
|
|
17
|
+
"build": "rm -rf ./dist && cti create ./src && tsc --project tsconfig.build.json && tsc-alias --project tsconfig.build.json && cti clean ./src",
|
|
18
|
+
"dev:quality": "yarn concurrently --timings --kill-others-on-fail 'yarn lint' 'yarn test'",
|
|
19
|
+
"dev:test:watch": "vitest",
|
|
20
|
+
"lint": "yarn concurrently --timings 'yarn:lint:*'",
|
|
21
|
+
"lint:audit": "yarn npm audit",
|
|
22
|
+
"lint:depcheck": "depcheck",
|
|
23
|
+
"lint:eslint": "eslint",
|
|
24
|
+
"lint:scriptlint": "scriptlint",
|
|
25
|
+
"lint:tsc": "tsc --noEmit --pretty --project .",
|
|
26
|
+
"test": "yarn concurrently --timings 'npm:test:*'",
|
|
27
|
+
"test:mutation": "yarn stryker run",
|
|
28
|
+
"test:unit": "vitest run"
|
|
29
|
+
},
|
|
30
|
+
"dependencies": {
|
|
31
|
+
"nestjs-pino": "^4.1.0"
|
|
32
|
+
},
|
|
33
|
+
"peerDependencies": {
|
|
34
|
+
"@nestjs/common": "^9.0.0 || ^10.0.0",
|
|
35
|
+
"pino-http": "^10.0.0",
|
|
36
|
+
"typeorm": "^0.3.20"
|
|
37
|
+
},
|
|
38
|
+
"devDependencies": {
|
|
39
|
+
"@libs-for-dev/eslint-rules": "1.0.0",
|
|
40
|
+
"@nestjs/common": "^10.4.7",
|
|
41
|
+
"@stryker-mutator/core": "^8.6.0",
|
|
42
|
+
"@stryker-mutator/vitest-runner": "^8.6.0",
|
|
43
|
+
"@types/node": "^22.9.0",
|
|
44
|
+
"@vitest/coverage-v8": "^2.1.4",
|
|
45
|
+
"concurrently": "^9.1.0",
|
|
46
|
+
"create-ts-index": "^1.14.0",
|
|
47
|
+
"depcheck": "^1.4.7",
|
|
48
|
+
"eslint": "^9.14.0",
|
|
49
|
+
"nestjs-pino": "^4.1.0",
|
|
50
|
+
"pino-http": "^10.3.0",
|
|
51
|
+
"prettier": "^3.3.3",
|
|
52
|
+
"reflect-metadata": "^0.2.2",
|
|
53
|
+
"scriptlint": "^3.0.0",
|
|
54
|
+
"tsc-alias": "^1.8.10",
|
|
55
|
+
"typeorm": "^0.3.20",
|
|
56
|
+
"typescript": "^5.6.3",
|
|
57
|
+
"vitest": "^2.1.4",
|
|
58
|
+
"yarn-audit-fix": "^10.1.0"
|
|
59
|
+
}
|
|
60
|
+
}
|