Skip to content

Commit

Permalink
책이나 글의 제목을 비워놓을 수 있는 오류 수정 작업 (#278)
Browse files Browse the repository at this point in the history
  • Loading branch information
doputer authored Dec 9, 2022
2 parents 6920f5b + 6ecede1 commit 227888a
Show file tree
Hide file tree
Showing 6 changed files with 95 additions and 86 deletions.
60 changes: 30 additions & 30 deletions backend/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions backend/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
"lint": "eslint ."
},
"dependencies": {
"@prisma/client": "^4.7.0",
"@prisma/client": "^4.7.1",
"aws-sdk": "^2.1259.0",
"axios": "^1.1.3",
"bcrypt": "^5.1.0",
Expand Down Expand Up @@ -38,7 +38,7 @@
"eslint-plugin-import": "^2.26.0",
"eslint-plugin-prettier": "^4.2.1",
"prettier": "^2.7.1",
"prisma": "^4.7.0",
"prisma": "^4.7.1",
"ts-node": "^10.9.1",
"tsc-watch": "^5.0.3",
"tsconfig-paths": "^4.1.0",
Expand Down
99 changes: 48 additions & 51 deletions backend/prisma/schema.prisma
Original file line number Diff line number Diff line change
@@ -1,8 +1,5 @@
// This is your Prisma schema file,
// learn more about it in the docs: https://pris.ly/d/prisma-schema

generator client {
provider = "prisma-client-js"
provider = "prisma-client-js"
previewFeatures = ["fullTextSearch", "fullTextIndex"]
}

Expand All @@ -12,77 +9,77 @@ datasource db {
}

model User {
id Int @id @default(autoincrement())
username String @db.VarChar(20)
password String @db.VarChar(100)
nickname String @db.VarChar(20) @unique
description String @db.VarChar(100)
profile_image String @db.VarChar(255) @default("https://kr.object.ncloudstorage.com/j027/522da4f3-c9d7-403d-a98f-2b09cabefc47.png")
provider String @db.VarChar(20)
created_at DateTime @default(now())
deleted_at DateTime?
books Book[]
bookmarks Bookmark[]
id Int @id @default(autoincrement())
username String @db.VarChar(20)
password String @db.VarChar(100)
nickname String @unique @db.VarChar(20)
description String @db.VarChar(100)
profile_image String @default("https://kr.object.ncloudstorage.com/j027/522da4f3-c9d7-403d-a98f-2b09cabefc47.png") @db.VarChar(255)
provider String @db.VarChar(20)
created_at DateTime @default(now())
deleted_at DateTime?
books Book[]
bookmarks Bookmark[]
temporary_article TemporaryArticle?
token Token?
token Token?
}

model Book {
id Int @id @default(autoincrement())
thumbnail_image String @db.VarChar(255) @default("https://kr.object.ncloudstorage.com/j027/3947d647-f26e-43cc-9834-82d59703cd9c.png")
title String @db.VarChar(50)
created_at DateTime @default(now())
deleted_at DateTime?
user User @relation(fields: [user_id], references: [id])
user_id Int
articles Article[]
scraps Scrap[]
bookmarks Bookmark[]
id Int @id @default(autoincrement())
thumbnail_image String @default("https://kr.object.ncloudstorage.com/j027/3947d647-f26e-43cc-9834-82d59703cd9c.png") @db.VarChar(255)
title String @db.VarChar(50)
created_at DateTime @default(now())
deleted_at DateTime?
user User @relation(fields: [user_id], references: [id])
user_id Int
articles Article[]
scraps Scrap[]
bookmarks Bookmark[]
@@fulltext([title])
@@fulltext([title], map: "title")
}

model Article {
id Int @id @default(autoincrement())
title String @db.VarChar(50)
content String @db.Text
created_at DateTime @default(now())
id Int @id @default(autoincrement())
title String @db.VarChar(100)
content String @db.Text
created_at DateTime @default(now())
deleted_at DateTime?
book Book @relation(fields: [book_id], references: [id])
book_id Int
scraps Scrap[]
book Book @relation(fields: [book_id], references: [id])
book_id Int
scraps Scrap[]
@@fulltext([content, title])
@@fulltext([title, content], map: "title_content")
}

model Scrap {
id Int @id @default(autoincrement())
order Int
id Int @id @default(autoincrement())
order Int
is_original Boolean
article Article @relation(fields: [article_id], references: [id])
article_id Int
book Book @relation(fields: [book_id], references: [id])
book_id Int
article Article @relation(fields: [article_id], references: [id])
article_id Int
book Book @relation(fields: [book_id], references: [id])
book_id Int
}

model Bookmark {
id Int @id @default(autoincrement())
user User @relation(fields: [user_id], references: [id])
id Int @id @default(autoincrement())
user User @relation(fields: [user_id], references: [id])
user_id Int
book Book @relation(fields: [book_id], references: [id])
book Book @relation(fields: [book_id], references: [id])
book_id Int
}

model TemporaryArticle {
id Int @id @default(autoincrement())
title String @db.VarChar(50)
id Int @id @default(autoincrement())
title String @db.VarChar(50)
content String @db.Text
user User @relation(fields: [user_id], references: [id])
user_id Int @unique
user User @relation(fields: [user_id], references: [id])
user_id Int @unique
}

model Token {
refresh_token String @db.VarChar(200)
user User @relation(fields: [user_id], references: [id])
user_id Int @unique
}
user User @relation(fields: [user_id], references: [id])
user_id Int @unique
}
5 changes: 5 additions & 0 deletions backend/src/apis/articles/articles.controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { SearchArticles } from '@apis/articles/articles.interface';
import articlesService from '@apis/articles/articles.service';
import { IScrap } from '@apis/scraps/scraps.interface';
import scrapsService from '@apis/scraps/scraps.service';
import { Forbidden, Message } from '@errors';

const searchArticles = async (req: Request, res: Response) => {
const { query, page, take, userId } = req.query as unknown as SearchArticles;
Expand All @@ -23,6 +24,8 @@ const getArticle = async (req: Request, res: Response) => {
const createArticle = async (req: Request, res: Response) => {
const { article, scraps } = req.body;

if (!article.title.length) throw new Forbidden(Message.ARTICLE_INVALID_TITLE);

const createdArticle = await articlesService.createArticle({
title: article.title,
content: article.content,
Expand All @@ -49,6 +52,8 @@ const createArticle = async (req: Request, res: Response) => {
const updateArticle = async (req: Request, res: Response) => {
const { article, scraps } = req.body;

if (!article.title.length) throw new Forbidden(Message.ARTICLE_INVALID_TITLE);

const articleId = Number(req.params.articleId);

const modifiedArticle = await articlesService.updateArticle(articleId, {
Expand Down
5 changes: 5 additions & 0 deletions backend/src/apis/books/books.controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { FindBooks, SearchBooks } from '@apis/books/books.interface';
import booksService from '@apis/books/books.service';
import { IScrap } from '@apis/scraps/scraps.interface';
import scrapsService from '@apis/scraps/scraps.service';
import { Forbidden, Message } from '@errors';

const getBook = async (req: Request, res: Response) => {
const { bookId } = req.params;
Expand Down Expand Up @@ -40,6 +41,8 @@ const searchBooks = async (req: Request, res: Response) => {
const createBook = async (req: Request, res: Response) => {
const { title } = req.body;

if (!title.length) throw new Forbidden(Message.BOOK_INVALID_TITLE);

const userId = res.locals.user.id;

const book = await booksService.createBook({ title, userId });
Expand All @@ -52,6 +55,8 @@ const createBook = async (req: Request, res: Response) => {
const updateBook = async (req: Request, res: Response) => {
const { id, title, thumbnail_image, scraps } = req.body;

if (!title.length) throw new Forbidden(Message.BOOK_INVALID_TITLE);

const userId = res.locals.user.id;

const book = await booksService.updateBook({ id, title, thumbnail_image });
Expand Down
8 changes: 5 additions & 3 deletions backend/src/errors/message.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,13 @@ export default {
AUTH_WRONG: '아이디 또는 비밀번호가 일치하지 않습니다.',
AUTH_USERNAME_OVERLAP: '중복되는 아이디가 존재합니다.',
AUTH_NICKNAME_OVERLAP: '중복되는 닉네임이 존재합니다.',
SCRAP_OVERLAP: '이미 스크랩되어 있는 글입니다.',
ARTICLE_NOTFOUND: '일치하는 글이 없습니다.',
BOOK_NOTFOUND: '일치하는 책이 없습니다.',
USER_NOTFOUND: '일치하는 유저가 없습니다.',
TOKEN_EXPIRED: '로그인이 필요합니다.',
TOKEN_MALFORMED: '로그인이 필요합니다.',
BOOK_NOTFOUND: '일치하는 책이 없습니다.',
BOOK_INVALID_TITLE: '책 제목이 비어있습니다.',
BOOKMARK_NOTFOUND: '북마크된 책이 아닙니다.',
ARTICLE_NOTFOUND: '일치하는 글이 없습니다.',
ARTICLE_INVALID_TITLE: '글 제목이 비어있습니다.',
SCRAP_OVERLAP: '이미 스크랩되어 있는 글입니다.',
};

0 comments on commit 227888a

Please sign in to comment.