You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
31 lines
829 B
31 lines
829 B
|
3 months ago
|
import {
|
||
|
|
Injectable,
|
||
|
|
NestInterceptor,
|
||
|
|
ExecutionContext,
|
||
|
|
CallHandler,
|
||
|
|
} from '@nestjs/common';
|
||
|
|
import { Observable } from 'rxjs';
|
||
|
|
import { tap } from 'rxjs/operators';
|
||
|
|
|
||
|
|
@Injectable()
|
||
|
|
export class LoggingInterceptor implements NestInterceptor {
|
||
|
|
intercept(context: ExecutionContext, next: CallHandler): Observable<any> {
|
||
|
|
const request = context.switchToHttp().getRequest();
|
||
|
|
const method = request.method;
|
||
|
|
const url = request.url;
|
||
|
|
const now = Date.now();
|
||
|
|
|
||
|
|
return next.handle().pipe(
|
||
|
|
tap(() => {
|
||
|
|
const response = context.switchToHttp().getResponse();
|
||
|
|
const statusCode = response.statusCode;
|
||
|
|
const delay = Date.now() - now;
|
||
|
|
|
||
|
|
console.log(
|
||
|
|
`[${new Date().toISOString()}] ${method} ${url} ${statusCode} - ${delay}ms`,
|
||
|
|
);
|
||
|
|
}),
|
||
|
|
);
|
||
|
|
}
|
||
|
|
}
|