76 lines
3.0 KiB
TypeScript
76 lines
3.0 KiB
TypeScript
import { Body, CookieParam, JsonController, Post, Res } from 'routing-controllers';
|
|
import { OpenAPI, ResponseSchema } from 'routing-controllers-openapi';
|
|
import { IllegalJWTError, InvalidCredentialsError, JwtNotProvidedError, PasswordNeededError, RefreshTokenCountInvalidError, UsernameOrEmailNeededError } from '../errors/AuthError';
|
|
import { UserNotFoundError } from '../errors/UserErrors';
|
|
import { CreateAuth } from '../models/actions/CreateAuth';
|
|
import { HandleLogout } from '../models/actions/HandleLogout';
|
|
import { RefreshAuth } from '../models/actions/RefreshAuth';
|
|
import { Auth } from '../models/responses/ResponseAuth';
|
|
import { Logout } from '../models/responses/ResponseLogout';
|
|
|
|
@JsonController('/auth')
|
|
export class AuthController {
|
|
constructor() {
|
|
}
|
|
|
|
@Post("/login")
|
|
@ResponseSchema(Auth)
|
|
@ResponseSchema(InvalidCredentialsError)
|
|
@ResponseSchema(UserNotFoundError)
|
|
@ResponseSchema(UsernameOrEmailNeededError)
|
|
@ResponseSchema(PasswordNeededError)
|
|
@ResponseSchema(InvalidCredentialsError)
|
|
@OpenAPI({ description: 'Create a new access token object' })
|
|
async login(@Body({ validate: true }) createAuth: CreateAuth, @Res() response: any) {
|
|
let auth;
|
|
try {
|
|
auth = await createAuth.toAuth();
|
|
response.cookie('lfk_backend__refresh_token', auth.refresh_token, { expires: new Date(auth.refresh_token_expires_at * 1000), httpOnly: true });
|
|
response.cookie('lfk_backend__refresh_token_expires_at', auth.refresh_token_expires_at, { expires: new Date(auth.refresh_token_expires_at * 1000), httpOnly: true });
|
|
return response.send(auth)
|
|
} catch (error) {
|
|
throw error;
|
|
}
|
|
}
|
|
|
|
@Post("/logout")
|
|
@ResponseSchema(Logout)
|
|
@ResponseSchema(InvalidCredentialsError)
|
|
@ResponseSchema(UserNotFoundError)
|
|
@ResponseSchema(UsernameOrEmailNeededError)
|
|
@ResponseSchema(PasswordNeededError)
|
|
@ResponseSchema(InvalidCredentialsError)
|
|
@OpenAPI({ description: 'Create a new access token object' })
|
|
async logout(@Body({ validate: true }) handleLogout: HandleLogout) {
|
|
let logout;
|
|
try {
|
|
logout = await handleLogout.logout()
|
|
} catch (error) {
|
|
throw error;
|
|
}
|
|
return logout
|
|
}
|
|
|
|
@Post("/refresh")
|
|
@ResponseSchema(Auth)
|
|
@ResponseSchema(JwtNotProvidedError)
|
|
@ResponseSchema(IllegalJWTError)
|
|
@ResponseSchema(UserNotFoundError)
|
|
@ResponseSchema(RefreshTokenCountInvalidError)
|
|
@OpenAPI({ description: 'refresh a access token' })
|
|
async refresh(@CookieParam("lfk_backend__refresh_token") refresh_token: string, @Res() response: any, @Body({ validate: true }) refreshAuth: RefreshAuth) {
|
|
if (refresh_token && refresh_token.length != 0) {
|
|
refreshAuth.token = refresh_token;
|
|
}
|
|
let auth;
|
|
try {
|
|
auth = await refreshAuth.toAuth();
|
|
response.cookie('lfk_backend__refresh_token', auth.refresh_token, { expires: new Date(auth.refresh_token_expires_at * 1000), httpOnly: true });
|
|
response.cookie('lfk_backend__refresh_token_expires_at', auth.refresh_token_expires_at, { expires: new Date(auth.refresh_token_expires_at * 1000), httpOnly: true });
|
|
} catch (error) {
|
|
throw error;
|
|
}
|
|
return response.send(auth)
|
|
}
|
|
}
|