Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(be): implement admin announcement module #1270

Closed
wants to merge 33 commits into from

Conversation

Lee-won-hyeok
Copy link
Contributor

@Lee-won-hyeok Lee-won-hyeok commented Jan 29, 2024

Description

closes #1047

Admin announcement 모듈을 구현하였습니다.

  • Admin 권한을 통해 CRUD를 수행할 수 있습니다.

Additional context

생성하려는 announcment의 problem Id, content 쌍이 이미 존재한다면 Duplicated Error를 발생시키고 있습니다. 이 때의 에러 메시지를 수정할 필요가 있어 보입니다.


Before submitting the PR, please make sure you do the following

@Lee-won-hyeok Lee-won-hyeok self-assigned this Jan 29, 2024
@Lee-won-hyeok Lee-won-hyeok linked an issue Jan 29, 2024 that may be closed by this pull request
3 tasks
Copy link

vercel bot commented Jan 29, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated (UTC)
codedang ✅ Ready (Inspect) Visit Preview Apr 29, 2024 0:13am

@gyunseo gyunseo self-requested a review January 31, 2024 13:16
Copy link
Contributor

@gyunseo gyunseo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

제가 코멘트 단 부분 수정해 주시면 감사하겠습니다!!

Copy link
Contributor

@gyunseo gyunseo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

죄송합니다. 어제 정신혼미 상태에서 리뷰하다 보니 조금 말이 안되는 코멘트를 하나 남겼었네요.

Copy link
Contributor

@cho-to cho-to left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

혹시 리뷰 몇 개 남겼는데 봐주실 수 있을까요?!
무조건 고치라는 뜻은 아니니 한 번 보시고 의견 남겨주시면 감사하겠습니다 :)

@Query(() => [Announcement], { name: 'announcement' })
findAll() {
return this.announcementService.findAll()
@Query(() => [Announcement], { name: 'getAnnouncements' })
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

이거 Query name을 따로 'getAnnouncements'로 지정하지 않아도 밑에 메소드 이름으로 적용될거에요!

}

@Mutation(() => Announcement)
removeAnnouncement(@Args('id', { type: () => Int }) id: number) {
return this.announcementService.remove(id)
async removeAnnouncement(@Args('id', { type: () => Int }) id: number) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

진짜진짜 사소한건데... CRUD니까 remove대신 delete 어떨까요 ㅎㅎ..

Comment on lines +17 to +26
const announcement = await this.prisma.announcement.findFirst({
where: {
...(announcementInput.problemId && {
problemId: announcementInput.problemId
}),
contestId: announcementInput.contestId,
content: announcementInput.content
}
})
if (announcement) throw new DuplicateFoundException('announcement')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

create에 announcement를 중복체크하는 로직이 필요있을까요??
content까지 중복되게 create할 일이 없을 것 같아서 저는 없애도 괜찮을 것 같아요!
그리고 만약 중복되게 create한데도 create할때마다 중복체크하는 것보다는 중복으로 잘못만든 것을 delete하는게 더 좋은 것 같은데 혹시 어떻게 생각하시나요!

@@ -20,7 +20,7 @@
"paths": {
"@admin/*": ["./apps/admin/src/*"],
"@client/*": ["./apps/client/src/*"],
"@generated": ["./apps/admin/src/@generated"],
"@generated": ["apps/admin/src/@generated"],
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

호옥시 path는 왜 바꿨을까요...??! 궁금해서 여쭤봅니다 !


constructor(private readonly prisma: PrismaService) {}

async createAnnouncement(announcementInput: AnnouncementInput) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

혹시 보다가 생각난건데 createAnnouncement 할 때 요청을 보낸 user가 해당 contest에서 열리는 group의 리더인지 검증하는 로직이 필요할까요??
이렇게 구현한다면 group 1 에 대해서 contest 1을 개최했을 때, group 1에 속하지 않은 다른 Admin 계정도 contest 1에서 annoucement를 작성하는 게 가능할 것 같아서요!

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

여쭤봤는데.. 아직 group에 대해서 기획 확실히 정해진게 없어서 기획팀께 문의해보기로 하였습니다 🥹

})
.catch((error) => {
if (error.name == 'NotFoundError') {
throw new EntityNotExistException('contestProblem')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

혹시 에러 return할 때 contestProblem으로 EntityNotExistException을 보내도 괜찮을까요?
ContestProblem이 하나의 Entity라고 인식하기 어려울 수 있을까 싶어서요! (problem, contest 등에 비해)
그리고 만약 problemId를 주지않고 contestId로만 announcement를 생성한다면 이때 contest가 없어서 뜨는 에러에서 ContestProblem이라고 뜨면 부자연스러울 것 같은데 혹시 어떻게 생각하시나요?
더 자세히 에러를 적는게 나을까요 아니면 이렇게 contestProblem으로 에러를 보내도 사용자가 이해하기 쉬울까요..?!

@@ -0,0 +1,38 @@
meta {
name: Error: Duplicated Announcement
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

혹시 그 에러 이름 양식 맞춰서 작성해주실 수 있을까요?
UNPROCESSABLE (1) (2) ... (에러 네임) 이렇게 적기로 저번 겨울 방학에 정했는데, 관련 회의록 찾아보고 있으면 드릴게요!

Comment on lines +41 to +44
### Args
| 이름 | 타입 | 설명|
|--|--|--|
|id|int|조회할 Announcement의 id|
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

앗 Args는 그 bruno schema 연동하면 args 다 보여주기 때문에 굳이 적으실 필요는 없어요!
그래도 수고하셨습니다 ... !!

@gyunseo gyunseo closed this Jan 3, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Implement Admin Announcement Module
4 participants