From cccc446b80145ea51614c97c681d29035ba7452b Mon Sep 17 00:00:00 2001 From: Shinwoo PARK Date: Sun, 3 Dec 2023 20:00:00 +0900 Subject: [PATCH] docs: update README --- README.md | 84 +++++++++++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 75 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index b79b8b3..cbcb8e9 100644 --- a/README.md +++ b/README.md @@ -6,8 +6,8 @@ It only uses Logger provided by @nestjs/common package and some dependencies req ### Route Logging ```ts -import {Controller, Get} from "@nestjs/common"; -import {LoggedRoute} from "nlogdec"; +import { Controller, Get } from "@nestjs/common"; +import { LoggedRoute } from "nlogdec"; @Controller('whatever') export class WhateverController { @@ -31,15 +31,15 @@ It will automatically log the call and response. If function throws any exception, it will also catch exception, log that, and throw it again. ```ts -import {BadRequestException, Controller, Get} from "@nestjs/common"; -import {LoggedRoute} from "nlogdec"; +import { BadRequestException, Controller, Get } from "@nestjs/common"; +import { LoggedRoute } from "nlogdec"; @Controller('whatever') export class WhateverController { constructor() {} @Get('/you/like') - @LoggedRoute('/you/like') + @LoggedRoute() public async whateverYouLikeImpl() { throw new BadRequestException("I don't like this") // Throwing HTTP exception here } @@ -53,9 +53,36 @@ export class WhateverController { Not only HTTP exception, it will also catch all exceptions and log it. +If you want to provide another route instead of path you provided to method decorators like Get, Post, you can give a string to LoggedRoute decorator to replace it. + +```ts +import { BadRequestException, Controller, Get } from "@nestjs/common"; +import { LoggedRoute } from "nlogdec"; + +@Controller('whatever') +export class WhateverController { + constructor() {} + + @Get('/you/like') + @LoggedRoute('you/like') + public async whateverYouLikeImpl() { + throw new BadRequestException("I don't like this") // Throwing HTTP exception here + } +} +``` + +``` +[Nest] 000000 - 00/00/0000, 00:00:00 AM LOG [WhateverController] HIT HTTP WhateverController/you/like (whateverYouLikeImpl) +[Nest] 000000 - 00/00/0000, 00:00:00 AM LOG [WhateverController] WHILE HTTP WhateverController/you/like (whateverYouLikeImpl) ERROR BadRequestException: I don't like this +``` + +You feel the change? + +Logged path is slightly changed from `WhateverController//you/like` to `WhateverController/you/like`. + ### Function Logging ```ts -import {LoggedFunction} from "nlogdec"; +import { LoggedFunction } from "nlogdec"; @LoggedFunction // This decorator will do the magic for you export async function doILikeThis(stuff: "apple" | "banana"): "yes" | "no" { @@ -65,14 +92,14 @@ export async function doILikeThis(stuff: "apple" | "banana"): "yes" | "no" { LoggedFunction decorator will log function calls and returns for you. -**Note: This decorator is expected to be used with a class method like Service. (we will upgrade that later, so you can use it without class)** +**Note: This decorator is expected to be used with a class method. You can't use this outside of class** Like `LoggedRoute` decorator, it will automatically catch all exceptions, log it, and throw it again. ### Parameter Logging ```ts -import {LoggedParam, LoggedFunction} from "nlogdec"; +import { LoggedParam, LoggedFunction } from "nlogdec"; @LoggedFunction export async function doILikeThis( @@ -93,6 +120,45 @@ The name of parameter is decided by the first parameter of LoggedParam decorator This decorator also can be used with `LoggedRoute`. +### Class Logging +You can make all method in injectable classes to logged function. + +```ts +import { LoggedInjectable } from "nlogdec"; + +@LoggedInjectable() +export class InjectableService { + constructor() {} + + public async getHello(@LoggedParam('name') name: string = 'world'): Promise { + return `Hello, ${name}!`; + } +} +``` + +It will make all methods to logged function, so it internally uses LoggedFunction decorator. + +You can do same thing with controller. + +```ts +import { Get, Query } from "@nestjs/common"; +import { LoggedController } from "nlogdec"; + +@LoggedController('path') +export class Controller { + constructor(private injectableService: InjectableService) {} + + @Get('/hello') + public async getHello(@LoggedParam('name') @Query() query: { name: string }): Promise { + return await this.injectableService.getHello(query.name); + } +} +``` + +It is exactly same using LoggedFunction and LoggedRoute, but it is much simpler because you don't have to write decorator to every method. + +But still, if you don't want to log every method, you can use LoggedFunction and LoggedRoute decorator. + ### Scoped Logging You can do scoped logging with `InjectLogger` decorator. @@ -122,7 +188,7 @@ export async function doILikeThis( Then, in controller: ```ts -import {BadRequestException, Controller, Get, Param} from "@nestjs/common"; +import { BadRequestException, Controller, Get, Param } from "@nestjs/common"; import { LoggedRoute, InjectLogger,