mirror change from https://github.com/binhkid2/FullStack-Blog-Nestjs-Nextjs-Postgres
This commit is contained in:
110
backend/src/auth/auth.controller.ts
Normal file
110
backend/src/auth/auth.controller.ts
Normal file
@@ -0,0 +1,110 @@
|
||||
import {
|
||||
Body,
|
||||
Controller,
|
||||
Get,
|
||||
Post,
|
||||
Query,
|
||||
Req,
|
||||
Res,
|
||||
UseGuards,
|
||||
} from '@nestjs/common';
|
||||
import { AuthGuard } from '@nestjs/passport';
|
||||
import { Request, Response } from 'express';
|
||||
import { AuthService } from './auth.service';
|
||||
import { LoginDto } from './dto/login.dto';
|
||||
import { MagicLinkRequestDto } from './dto/magic-link-request.dto';
|
||||
import { PasswordResetConfirmDto } from './dto/password-reset-confirm.dto';
|
||||
import { PasswordResetRequestDto } from './dto/password-reset-request.dto';
|
||||
import { RegisterDto } from './dto/register.dto';
|
||||
import { Public } from '../common/decorators/public.decorator';
|
||||
import { CurrentUser } from '../common/decorators/current-user.decorator';
|
||||
|
||||
@Controller('auth')
|
||||
export class AuthController {
|
||||
constructor(private readonly authService: AuthService) {}
|
||||
|
||||
/** Returns the JWT payload of the currently logged-in user.
|
||||
* Used by the frontend to restore auth state (e.g. after Google OAuth redirect). */
|
||||
@Get('me')
|
||||
me(@CurrentUser() user: any) {
|
||||
return { success: true, user };
|
||||
}
|
||||
|
||||
@Post('register')
|
||||
@Public()
|
||||
register(@Body() dto: RegisterDto, @Req() req: Request, @Res() res: Response) {
|
||||
return this.authService.register(dto, req, res);
|
||||
}
|
||||
|
||||
@Post('login')
|
||||
@Public()
|
||||
login(@Body() dto: LoginDto, @Req() req: Request, @Res() res: Response) {
|
||||
return this.authService.login(dto, req, res);
|
||||
}
|
||||
|
||||
@Post('refresh')
|
||||
@Public()
|
||||
refresh(@Req() req: Request, @Res() res: Response) {
|
||||
return this.authService.refresh(req, res);
|
||||
}
|
||||
|
||||
@Post('logout')
|
||||
@Public()
|
||||
logout(@Req() req: Request, @Res() res: Response) {
|
||||
return this.authService.logout(req, res);
|
||||
}
|
||||
|
||||
@Post('magic-link')
|
||||
@Public()
|
||||
requestMagicLink(
|
||||
@Body() dto: MagicLinkRequestDto,
|
||||
@Req() req: Request,
|
||||
@Res() res: Response,
|
||||
) {
|
||||
return this.authService.requestMagicLink(dto.email, req, res);
|
||||
}
|
||||
|
||||
@Get('magic-link/verify')
|
||||
@Public()
|
||||
verifyMagicLink(
|
||||
@Query('token') token: string,
|
||||
@Req() req: Request,
|
||||
@Res() res: Response,
|
||||
) {
|
||||
return this.authService.verifyMagicLink(token, req, res);
|
||||
}
|
||||
|
||||
@Post('password-reset/request')
|
||||
@Public()
|
||||
requestPasswordReset(
|
||||
@Body() dto: PasswordResetRequestDto,
|
||||
@Req() req: Request,
|
||||
@Res() res: Response,
|
||||
) {
|
||||
return this.authService.requestPasswordReset(dto.email, req, res);
|
||||
}
|
||||
|
||||
@Post('password-reset/confirm')
|
||||
@Public()
|
||||
confirmPasswordReset(
|
||||
@Body() dto: PasswordResetConfirmDto,
|
||||
@Req() req: Request,
|
||||
@Res() res: Response,
|
||||
) {
|
||||
return this.authService.confirmPasswordReset(dto, req, res);
|
||||
}
|
||||
|
||||
@Get('google')
|
||||
@Public()
|
||||
@UseGuards(AuthGuard('google'))
|
||||
googleAuth() {
|
||||
// Passport redirects to Google
|
||||
}
|
||||
|
||||
@Get('google/callback')
|
||||
@Public()
|
||||
@UseGuards(AuthGuard('google'))
|
||||
googleCallback(@Req() req: Request, @Res() res: Response) {
|
||||
return this.authService.handleGoogleCallback((req as any).user, req, res);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user