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;
}
}
|