Files
flashcards-api/src/modules/auth/use-cases/refresh-token-use-case.ts

44 lines
1.2 KiB
TypeScript

import { CommandHandler, ICommandHandler } from '@nestjs/cqrs'
import { addDays } from 'date-fns'
import * as jwt from 'jsonwebtoken'
import { AuthRepository } from '../infrastructure/auth.repository'
export class RefreshTokenCommand {
constructor(
public readonly userId: string,
public readonly shortAccessToken: boolean
) {}
}
@CommandHandler(RefreshTokenCommand)
export class RefreshTokenHandler implements ICommandHandler<RefreshTokenCommand> {
constructor(private readonly authRepository: AuthRepository) {}
async execute(command: RefreshTokenCommand) {
const { userId, shortAccessToken } = command
const accessSecretKey = process.env.ACCESS_JWT_SECRET_KEY
const refreshSecretKey = process.env.REFRESH_JWT_SECRET_KEY
const payload: { userId: string; date: Date } = {
userId,
date: new Date(),
}
const accessToken = jwt.sign(payload, accessSecretKey, {
expiresIn: shortAccessToken ? '10s' : '10m',
})
const refreshToken = jwt.sign(payload, refreshSecretKey, {
expiresIn: '30d',
})
const expiresIn = addDays(new Date(), 30)
await this.authRepository.createRefreshToken(userId, refreshToken, expiresIn)
return {
accessToken,
refreshToken,
}
}
}