-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #180 from boostcampwm2023/feat/178-stellar-route-api
[Feat] 별자리선 Entity 생성 및 API 구현
- Loading branch information
Showing
9 changed files
with
319 additions
and
39 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
import { IsNotEmpty, IsUUID } from "class-validator"; | ||
|
||
export class CreateLineDto { | ||
@IsUUID("4", { message: "별자리선 uuid1 값이 uuid 양식이어야 합니다." }) | ||
@IsNotEmpty({ message: "별자리선 uuid1는 비어있지 않아야 합니다." }) | ||
uuid1: string; | ||
|
||
@IsUUID("4", { message: "별자리선 uuid2 값이 uuid 양식이어야 합니다." }) | ||
@IsNotEmpty({ message: "별자리선 uuid2는 비어있지 않아야 합니다." }) | ||
uuid2: string; | ||
} | ||
|
||
export class ReadLineDto { | ||
id: number; | ||
first: { uuid: string; coordinate: { x: number; y: number; z: number } }; | ||
second: { uuid: string; coordinate: { x: number; y: number; z: number } }; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
import { | ||
Body, | ||
Controller, | ||
Delete, | ||
Get, | ||
HttpCode, | ||
Param, | ||
ParseIntPipe, | ||
Post, | ||
UseGuards, | ||
} from "@nestjs/common"; | ||
import { JwtAuthGuard } from "src/auth/guard/auth.jwt-guard"; | ||
import { LinesService } from "./lines.service"; | ||
import { CreateLineDto, ReadLineDto } from "./dto/lines.dto"; | ||
import { GetUser } from "src/auth/get-user.decorator"; | ||
import { User } from "src/auth/users.entity"; | ||
import { Line } from "./lines.entity"; | ||
import { getReadLineDtoFormat } from "src/utils/data-transform"; | ||
|
||
@Controller("lines") | ||
@UseGuards(JwtAuthGuard) | ||
export class LinesController { | ||
constructor(private linesService: LinesService) {} | ||
|
||
@Post() | ||
@HttpCode(201) | ||
async createLine( | ||
@Body() createLineDto: CreateLineDto, | ||
@GetUser() user: User, | ||
): Promise<{ id: number }> { | ||
const line: Line = await this.linesService.createLine(createLineDto, user); | ||
return { id: line.id }; | ||
} | ||
|
||
@Get() | ||
async getLinesByUser(@GetUser() user: User): Promise<ReadLineDto[]> { | ||
const lines: Line[] = await this.linesService.getLinesByUser(user); | ||
|
||
const readLineDtoList: ReadLineDto[] = lines.map((line) => | ||
getReadLineDtoFormat(line), | ||
); | ||
|
||
return readLineDtoList; | ||
} | ||
|
||
@Delete("/:id") | ||
@HttpCode(204) | ||
async deleteLine( | ||
@Param("id", ParseIntPipe) id: number, | ||
@GetUser() user: User, | ||
): Promise<void> { | ||
await this.linesService.deleteLine(id, user); | ||
return; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
import { User } from "src/auth/users.entity"; | ||
import { Diary } from "src/diaries/diaries.entity"; | ||
import { | ||
BaseEntity, | ||
Column, | ||
CreateDateColumn, | ||
DeleteDateColumn, | ||
Entity, | ||
ManyToOne, | ||
PrimaryGeneratedColumn, | ||
} from "typeorm"; | ||
|
||
@Entity({ name: "constellation" }) | ||
export class Line extends BaseEntity { | ||
@PrimaryGeneratedColumn() | ||
id: number; | ||
|
||
@ManyToOne(() => Diary, (diary) => diary.id, { | ||
nullable: false, | ||
eager: true, | ||
}) | ||
firstDiary: Diary; | ||
|
||
@ManyToOne(() => Diary, (diary) => diary.id, { | ||
nullable: false, | ||
eager: true, | ||
}) | ||
secondDiary: Diary; | ||
|
||
@ManyToOne(() => User, (user) => user.id, { | ||
nullable: false, | ||
eager: true, | ||
}) | ||
user: User; | ||
|
||
@CreateDateColumn({ type: "datetime" }) | ||
createdDate: Date; | ||
|
||
@DeleteDateColumn({ type: "datetime" }) | ||
deletedDate: Date; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
import { Module } from "@nestjs/common"; | ||
import { LinesController } from "./lines.controller"; | ||
import { LinesService } from "./lines.service"; | ||
import { TypeOrmModule } from "@nestjs/typeorm"; | ||
import { Line } from "./lines.entity"; | ||
import { DiariesModule } from "src/diaries/diaries.module"; | ||
import { DiariesRepository } from "src/diaries/diaries.repository"; | ||
import { LinesRepository } from "./lines.repository"; | ||
|
||
@Module({ | ||
imports: [TypeOrmModule.forFeature([Line]), DiariesModule], | ||
controllers: [LinesController], | ||
providers: [LinesService, LinesRepository, DiariesRepository], | ||
}) | ||
export class LinesModule {} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
import { Diary } from "src/diaries/diaries.entity"; | ||
import { Line } from "./lines.entity"; | ||
import { User } from "src/auth/users.entity"; | ||
import { NotFoundException } from "@nestjs/common"; | ||
|
||
export class LinesRepository { | ||
async createLine( | ||
firstDiary: Diary, | ||
secondDiary: Diary, | ||
user: User, | ||
): Promise<Line> { | ||
const newLine = Line.create({ | ||
firstDiary, | ||
secondDiary, | ||
user, | ||
}); | ||
await newLine.save(); | ||
|
||
return newLine; | ||
} | ||
|
||
async fetchLinesByUser(user: User): Promise<Line[]> { | ||
const linesList = await Line.find({ | ||
where: { user: { id: user.id } }, | ||
}); | ||
return linesList; | ||
} | ||
|
||
async deleteLine(id: number): Promise<void> { | ||
const line = await this.getLineById(id); | ||
await Line.softRemove(line); | ||
} | ||
|
||
async getLineById(id: number): Promise<Line> { | ||
const found = await Line.findOne({ where: { id } }); | ||
if (!found) { | ||
throw new NotFoundException("존재하지 않는 별자리선입니다."); | ||
} | ||
|
||
return found; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
import { | ||
BadRequestException, | ||
Injectable, | ||
NotFoundException, | ||
} from "@nestjs/common"; | ||
import { CreateLineDto } from "./dto/lines.dto"; | ||
import { User } from "src/auth/users.entity"; | ||
import { Line } from "./lines.entity"; | ||
import { LinesRepository } from "./lines.repository"; | ||
import { DiariesRepository } from "src/diaries/diaries.repository"; | ||
import { Diary } from "src/diaries/diaries.entity"; | ||
|
||
@Injectable() | ||
export class LinesService { | ||
constructor( | ||
private linesRepository: LinesRepository, | ||
private diariesRepository: DiariesRepository, | ||
) {} | ||
|
||
async createLine(createLineDto: CreateLineDto, user: User): Promise<Line> { | ||
const { uuid1, uuid2 } = createLineDto; | ||
|
||
if (uuid1 === uuid2) { | ||
throw new BadRequestException( | ||
"동일한 일기에 별자리선을 생성할 수 없습니다.", | ||
); | ||
} | ||
|
||
const firstDiary = await this.diariesRepository.getDiaryByUuid(uuid1); | ||
const secondDiary = await this.diariesRepository.getDiaryByUuid(uuid2); | ||
|
||
const isDuplicate = await this.isDuplicateLine( | ||
firstDiary, | ||
secondDiary, | ||
user, | ||
); | ||
if (isDuplicate) { | ||
throw new BadRequestException("이미 존재하는 별자리선입니다."); | ||
} | ||
|
||
if (firstDiary.user.id !== user.id || secondDiary.user.id !== user.id) { | ||
throw new NotFoundException("존재하지 않는 일기입니다."); | ||
} | ||
|
||
return this.linesRepository.createLine(firstDiary, secondDiary, user); | ||
} | ||
|
||
async getLinesByUser(user: User): Promise<Line[]> { | ||
return this.linesRepository.fetchLinesByUser(user); | ||
} | ||
|
||
async deleteLine(id: number, user: User): Promise<void> { | ||
const line = await this.linesRepository.getLineById(id); | ||
if (line.user.id !== user.id) { | ||
throw new NotFoundException("존재하지 않는 별자리선입니다."); | ||
} | ||
|
||
await this.linesRepository.deleteLine(id); | ||
} | ||
|
||
private async isDuplicateLine( | ||
firstDiary: Diary, | ||
secondDiary: Diary, | ||
user: User, | ||
): Promise<boolean> { | ||
const existingLine = await Line.findOne({ | ||
where: [ | ||
{ | ||
firstDiary: { id: firstDiary.id }, | ||
secondDiary: { id: secondDiary.id }, | ||
user: { id: user.id }, | ||
}, | ||
{ | ||
firstDiary: { id: secondDiary.id }, | ||
secondDiary: { id: firstDiary.id }, | ||
user: { id: user.id }, | ||
}, | ||
], | ||
}); | ||
|
||
return !!existingLine; | ||
} | ||
} |
Oops, something went wrong.