All files / src/modules/api/auth/strategies jwt.strategy.ts

0% Statements 0/11
0% Branches 0/2
0% Functions 0/3
0% Lines 0/10

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                           
import { Config } from "@/modules/shared/config/types";
import { UserEntity } from "@/modules/shared/database/entities";
import { Cookies, Services } from "@/types/Constants";
import { Inject, Injectable, UnauthorizedException } from "@nestjs/common";
import { ConfigService } from "@nestjs/config";
import { PassportStrategy } from "@nestjs/passport";
import { FastifyRequest } from "fastify";
import { ExtractJwt, Strategy } from "passport-jwt";
import { IAuthService } from "../interfaces/IAuthService.interface";
import { JwtPayload } from "../types";
 
@Injectable()
export class JwtStrategy extends PassportStrategy(Strategy, "JWT") {
	constructor(
		@Inject(Services.Auth) private readonly authService: IAuthService,
		private readonly configService: ConfigService,
	) {
		super({
			jwtFromRequest: ExtractJwt.fromExtractors([
				(request: FastifyRequest) => {
					const data = request?.cookies[Cookies.JWT];
					return data;
				},
			]),
			ignoreExpiration: false,
			secretOrKey: configService.getOrThrow<Config["API"]>("API").JwtSecret,
		});
	}
 
	async validate(payload: JwtPayload): Promise<UserEntity> {
		const user = await this.authService.get(payload);
		if (!user) {
			throw new UnauthorizedException();
		}
		return user;
	}
}