Skip to content

Commit

Permalink
feat: auth API 명세
Browse files Browse the repository at this point in the history
기존 API와 1:1 대응되게 옮겼습니다.
  • Loading branch information
scarf005 committed Sep 24, 2024
1 parent 9e902d6 commit 8dbb9e2
Show file tree
Hide file tree
Showing 2 changed files with 195 additions and 0 deletions.
18 changes: 18 additions & 0 deletions backend/src/auth/auth.controller.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import { Test, TestingModule } from '@nestjs/testing';
import { AuthController } from './auth.controller';

describe('AuthController', () => {
let controller: AuthController;

beforeEach(async () => {
const module: TestingModule = await Test.createTestingModule({
controllers: [AuthController],
}).compile();

controller = module.get<AuthController>(AuthController);
});

it('should be defined', () => {
expect(controller).toBeDefined();
});
});
177 changes: 177 additions & 0 deletions backend/src/auth/auth.controller.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,177 @@
import { createZodDto } from '@anatine/zod-nestjs';
import { Body, Controller, Get, Post } from '@nestjs/common';
import {
ApiFoundResponse,
ApiGoneResponse,
ApiNoContentResponse,
ApiOperation,
ApiTags,
ApiUnauthorizedResponse,
} from '@nestjs/swagger';
import { z } from 'zod';

const locationSchema = z.string().url();

Check warning on line 13 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / build (20)

'locationSchema' is assigned a value but never used

Check warning on line 13 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / autofix

'locationSchema' is assigned a value but never used

Check warning on line 13 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / build (22)

'locationSchema' is assigned a value but never used

const errorSchema = z.object({
code: z.number(),
message: z.string(),
});
class ErrorResponseDto extends createZodDto(errorSchema) {}

const userSchema = z.object({
id: z.number().describe('로그인한 유저의 PK'),
intra: z.string().describe('인트라 아이디 (인트라아이디가 없다면 email)'),
librarian: z.boolean().describe('사서 여부'),
email: z.string().email(),
});
class UserResponseDto extends createZodDto(userSchema) {}

const loginSchema = z.object({
id: z.string(),
password: z.string(),
});
class LoginDto extends createZodDto(loginSchema) {}

@Controller('auth')
@ApiTags('auth')
export class AuthController {
constructor() {}

@Get('oauth')
@ApiOperation({
summary: '42 Api에 API key값을 추가해서 요청합니다.',
description:
'42 Api에 API key값을 추가해서 요청합니다. redirect 되기에 반환값을 확인할 수 없습니다.',
})
@ApiFoundResponse({
description: '정상적으로 42 Api로 이동합니다.',
headers: {
Location: {
description: '42 Api 주소로 이동합니다.',
schema: { type: 'string', format: 'uri' },
},
},
})
async oauth() {}

@Get('token')
@ApiOperation({
summary: '42 OAuth Api의 반환값을 이용하여 토큰을 발급합니다.',
description:
'42 OAuth Api의 반환값을 이용하여 토큰을 발급합니다. redirect 되기에 반환값을 확인할 수 없습니다.',
})
@ApiFoundResponse({
description: '성공적으로 토큰 발급',
headers: {
Location: {
description:
'브라우저에 유저정보를 저장 하는 frontend /auth 주소로 이동',
schema: { type: 'string', format: 'uri' },
},
},
})
@ApiUnauthorizedResponse({
description:
'42 api와 연동된 ID가 없음, [front에서 알림 후 회원가입창으로 이동]',
type: ErrorResponseDto,
})
async token() {}

@Get('me')
@ApiOperation({
summary: '클라이언트의 로그인된 유저 정보를 받아옵니다.',
description: '클라이언트의 로그인된 유저 정보를 받아옵니다.',
})
@ApiFoundResponse({
description: '로그인 되어 있는 유저의 정보를 반환합니다.',
type: UserResponseDto,
})
@ApiUnauthorizedResponse({
description: '토큰이 없을 경우 에러',
type: ErrorResponseDto,
})
@ApiUnauthorizedResponse({
description: '권한이 맞지 않을때 에러',
type: ErrorResponseDto,
})
@ApiGoneResponse({
description: '해당 토큰의 유저가 DB에 없을 경우의 에러',
type: ErrorResponseDto,
})
async me() {}

@Post('login')
@ApiOperation({
summary: '로그인',
description:
'입력된 회원정보를 Users DB에서 확인하여, Token을 발급해 쿠키에 저장해줍니다.',
})
@ApiNoContentResponse({
description: '성공적으로 토큰 발급',
})
@ApiUnauthorizedResponse({
description: 'ID를 찾을 수 없는 경우',
type: ErrorResponseDto,
})
@ApiUnauthorizedResponse({
description: 'PW가 틀린 경우',
type: ErrorResponseDto,
})
async login(@Body() { id, password }: LoginDto) {}

Check warning on line 120 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / build (20)

'id' is defined but never used

Check warning on line 120 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / build (20)

'password' is defined but never used

Check warning on line 120 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / autofix

'id' is defined but never used

Check warning on line 120 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / autofix

'password' is defined but never used

Check warning on line 120 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / build (22)

'id' is defined but never used

Check warning on line 120 in backend/src/auth/auth.controller.ts

View workflow job for this annotation

GitHub Actions / build (22)

'password' is defined but never used

@Post('logout')
@ApiOperation({
summary: '로그아웃',
description: '발급한 token을 소멸시킵니다.',
})
@ApiNoContentResponse({
description: '정상적으로 token 삭제 완료',
})
async logout() {}

@Get('getIntraAuthentication')
@ApiOperation({
summary: '42 intra에 접근합니다.',
description: 'redirect 되어 들어오기에 반환값을 확인할 수 없습니다.',
})
@ApiFoundResponse({
description: '성공적으로 토큰 발급',
headers: {
Location: {
description:
'브라우저에 유저정보를 저장 하는 frontend /auth 주소로 이동',
schema: { type: 'string', format: 'uri' },
},
},
})
getIntraAuthentication() {}

@Get('intraAuthentication')
@ApiOperation({
summary: '42 intra 인증을 실시합니다.',
description: 'redirect 되어 들어오기에 반환값을 확인할 수 없습니다.',
})
@ApiFoundResponse({
description: '성공적으로 토큰 발급',
headers: {
Location: {
description:
'브라우저에 유저정보를 저장 하는 frontend /auth 주소로 이동',
schema: { type: 'string', format: 'uri' },
},
},
})
@ApiUnauthorizedResponse({
description: 'ID, PW 값이 없는 잘못된 요청',
type: ErrorResponseDto,
})
@ApiUnauthorizedResponse({
description: '토큰이 없을 경우, 이미 인증된 회원의 경우',
type: ErrorResponseDto,
})
@ApiGoneResponse({
description: '해당 토큰의 유저가 DB에 없을 경우의 에러',
type: ErrorResponseDto,
})
intraAuthentication() {}
}

0 comments on commit 8dbb9e2

Please sign in to comment.