Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
W
WebBack
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Container registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
websystem
WebBack
Compare revisions
4cdd8110cd013015ecabbd625a48cf45b1ade9a4 to 454bf03649f7f7642a376b5f3672b08b344fcf1b
Compare revisions
Changes are shown as if the
source
revision was being merged into the
target
revision.
Learn more about comparing revisions.
Source
websystem1/webback
Select target project
No results found
454bf03649f7f7642a376b5f3672b08b344fcf1b
Select Git revision
Swap
Target
websystem1/webback
Select target project
websystem1/webback
1 result
4cdd8110cd013015ecabbd625a48cf45b1ade9a4
Select Git revision
Show changes
Only incoming changes from source
Include changes to target since source was created
Compare
Commits on Source (4)
refactor: 미팅 상세 정보 조회 로직 수정에 따른 dto 수정 (
#19
)
· 8c693802
조대희
authored
5 months ago
8c693802
refactor: 미팅 목록/상세 정보 조회 수정 (
#19
)
· 3d4eadc9
조대희
authored
5 months ago
3d4eadc9
test, refactor: 미팅 목록/상세 정보 조회 테스트 코드 (
#19
)
· 00225eaa
조대희
authored
5 months ago
00225eaa
fix: 중복 코드 삭제 / 고정 시간대 설정 변경 (
#19
)
· 454bf036
조대희
authored
5 months ago
454bf036
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
dtos/MeetingDetailResponseDTO.js
+2
-1
2 additions, 1 deletion
dtos/MeetingDetailResponseDTO.js
services/meetingService.js
+38
-140
38 additions, 140 deletions
services/meetingService.js
services/meetingService.test.js
+449
-465
449 additions, 465 deletions
services/meetingService.test.js
with
489 additions
and
606 deletions
dtos/MeetingDetailResponseDTO.js
View file @
454bf036
// dtos/MeetingResponseDTO.js
class
MeetingDetailResponseDTO
{
constructor
(
meeting
)
{
constructor
(
meeting
,
isScheduleConflict
)
{
this
.
id
=
meeting
.
id
;
this
.
title
=
meeting
.
title
;
this
.
description
=
meeting
.
description
;
...
...
@@ -10,6 +10,7 @@ class MeetingDetailResponseDTO {
this
.
time_idx_deadline
=
meeting
.
time_idx_deadline
;
this
.
type
=
meeting
.
type
;
this
.
creatorName
=
meeting
.
creator
?
meeting
.
creator
.
name
:
'
Unknown
'
;
this
.
isScheduleConflict
=
isScheduleConflict
;
this
.
participants
=
meeting
.
participants
.
map
(
participant
=>
({
userId
:
participant
.
user_id
,
name
:
participant
.
participantUser
?
participant
.
participantUser
.
name
:
'
Unknown
'
,
...
...
This diff is collapsed.
Click to expand it.
services/meetingService.js
View file @
454bf036
...
...
@@ -253,7 +253,7 @@ class MeetingService {
{
userId
:
userId
,
title
:
`번개 모임:
${
meeting
.
title
}
`
,
is_fixed
:
tru
e
,
is_fixed
:
fals
e
,
events
:
events
,
},
transaction
...
...
@@ -299,21 +299,34 @@ class MeetingService {
{
model
:
MeetingParticipant
,
as
:
'
participants
'
,
where
:
{
user_id
:
userId
},
// userId와 매핑된 미팅만 가져옴
attributes
:
[],
required
:
false
,
attributes
:
[],
},
{
model
:
User
,
as
:
'
creator
'
,
attributes
:
[
'
name
'
],
// 미팅 생성자의 이름만 필요
}
,
]
,
attributes
:
[
'
name
'
],
}
]
});
return
meetings
.
map
((
meeting
)
=>
{
return
Promise
.
all
(
meetings
.
map
(
async
(
meeting
)
=>
{
const
isParticipant
=
await
MeetingParticipant
.
findOne
({
where
:
{
meeting_id
:
meeting
.
id
,
user_id
:
userId
}
});
const
hasConflict
=
await
ScheduleService
.
checkScheduleOverlapByTime
(
userId
,
meeting
.
time_idx_start
,
meeting
.
time_idx_end
);
const
creatorName
=
meeting
.
creator
?
meeting
.
creator
.
name
:
'
Unknown
'
;
return
new
MeetingResponseDTO
(
meeting
,
true
,
false
,
creatorName
);
});
return
new
MeetingResponseDTO
(
meeting
,
!!
isParticipant
,
hasConflict
,
creatorName
);
})
)
;
}
...
...
@@ -329,129 +342,8 @@ class MeetingService {
await
meeting
.
save
();
return
meeting
;
}
async
joinMeeting
(
meetingId
,
userId
)
{
const
meeting
=
await
Meeting
.
findByPk
(
meetingId
);
console
.
log
(
`참여하려는 모임:
${
JSON
.
stringify
(
meeting
)}
`
);
if
(
!
meeting
)
{
throw
new
Error
(
'
모임을 찾을 수 없습니다.
'
);
}
if
(
meeting
.
type
===
'
CLOSE
'
)
{
throw
new
Error
(
'
이미 마감된 모임입니다.
'
);
}
if
(
meeting
.
time_idx_deadline
!==
undefined
)
{
const
currentTimeIdx
=
this
.
getCurrentTimeIdx
();
// 현재 시간 인덱스
if
(
currentTimeIdx
>=
meeting
.
time_idx_deadline
)
{
throw
new
Error
(
'
참가 신청이 마감되었습니다.
'
);
}
}
const
existingParticipant
=
await
MeetingParticipant
.
findOne
({
where
:
{
meeting_id
:
meetingId
,
user_id
:
userId
},
});
if
(
existingParticipant
)
{
throw
new
Error
(
'
이미 참가한 사용자입니다.
'
);
}
// 트랜잭션을 사용하여 참가자 추가 및 스케줄 업데이트를 원자적으로 처리
await
sequelize
.
transaction
(
async
(
transaction
)
=>
{
// 스케줄 충돌 확인
// 현재 인원 수 확인
if
(
meeting
.
cur_num
>=
meeting
.
max_num
)
{
throw
new
Error
(
"
모임 인원이 모두 찼습니다.
"
);
}
const
hasConflict
=
await
ScheduleService
.
checkScheduleOverlapByTime
(
userId
,
meeting
.
time_idx_start
,
meeting
.
time_idx_end
,
transaction
);
console
.
log
(
`스케줄 충돌 결과:
${
hasConflict
}
`
);
if
(
hasConflict
)
{
throw
new
Error
(
"
스케줄이 겹칩니다. 다른 모임에 참가하세요.
"
);
}
// 참가자 추가
await
MeetingParticipant
.
create
(
{
meeting_id
:
meetingId
,
user_id
:
userId
},
{
transaction
}
);
// 스케줄 생성 (모임 시간 범위 내 모든 time_idx에 대해 생성)
const
events
=
[];
for
(
let
idx
=
meeting
.
time_idx_start
;
idx
<=
meeting
.
time_idx_end
;
idx
++
)
{
events
.
push
({
time_idx
:
idx
});
}
await
ScheduleService
.
createSchedules
(
{
userId
:
userId
,
title
:
`번개 모임:
${
meeting
.
title
}
`
,
is_fixed
:
true
,
events
:
events
,
},
transaction
);
// 채팅방 참가 (MongoDB)
const
user
=
await
User
.
findOne
({
where
:
{
id
:
userId
},
transaction
,
});
const
chatRoom
=
await
ChatRooms
.
findOne
({
chatRoomId
:
meeting
.
chatRoomId
,
});
if
(
chatRoom
&&
!
chatRoom
.
participants
.
includes
(
user
.
name
))
{
chatRoom
.
participants
.
push
(
user
.
name
);
chatRoom
.
isOnline
.
set
(
user
.
name
,
true
);
chatRoom
.
lastReadAt
.
set
(
user
.
name
,
new
Date
());
chatRoom
.
lastReadLogId
.
set
(
user
.
name
,
null
);
await
chatRoom
.
save
();
}
// 현재 인원 수 증가
await
meeting
.
increment
(
"
cur_num
"
,
{
by
:
1
,
transaction
});
await
Meeting
.
sequelize
.
transaction
(
async
(
transaction
)
=>
{
const
hasConflict
=
await
ScheduleService
.
checkScheduleOverlap
(
userId
,
new
Date
(
meeting
.
start_time
),
new
Date
(
meeting
.
end_time
)
);
if
(
hasConflict
)
{
throw
new
Error
(
'
스케줄이 겹칩니다. 다른 모임에 참가하세요.
'
);
}
await
MeetingParticipant
.
create
({
meeting_id
:
meetingId
,
user_id
:
userId
},
{
transaction
});
await
ScheduleService
.
createSchedule
({
userId
,
title
:
`번개 모임:
${
meeting
.
title
}
`
,
start_time
:
new
Date
(
meeting
.
start_time
),
end_time
:
new
Date
(
meeting
.
end_time
),
is_fixed
:
true
,
});
// 사용자와 FCM 토큰 조회
const
user
=
await
this
.
_findUserWithFcmTokens
(
userId
);
const
userFcmTokens
=
user
.
fcmTokenList
.
map
((
fcmToken
)
=>
fcmToken
.
token
);
const
chatRoom
=
await
ChatRoom
.
findOne
({
chatRoomId
:
meeting
.
chatRoomId
});
if
(
chatRoom
)
{
console
.
log
(
"
채팅방 찾음
"
);
this
.
_addParticipantToChatRoom
(
chatRoom
,
user
,
userFcmTokens
);
}
});
});
}
async
getMeetingDetail
(
meetingId
)
{
async
getMeetingDetail
(
meetingId
,
userId
)
{
const
meeting
=
await
Meeting
.
findByPk
(
meetingId
,
{
include
:
[
{
...
...
@@ -465,19 +357,25 @@ class MeetingService {
include
:
[
{
model
:
User
,
as
:
"
user
"
,
// 'participantUser'에서 'user'로 수정
as
:
"
user
"
,
attributes
:
[
"
name
"
,
"
email
"
],
}
,
]
,
}
,
]
,
}
]
}
]
});
if
(
!
meeting
)
{
throw
new
Error
(
"
모임을 찾을 수 없습니다.
"
);
}
return
new
MeetingDetailResponseDTO
(
meeting
);
const
hasConflict
=
await
ScheduleService
.
checkScheduleOverlapByTime
(
userId
,
meeting
.
time_idx_start
,
meeting
.
time_idx_end
);
return
new
MeetingDetailResponseDTO
(
meeting
,
hasConflict
);
}
/**
...
...
This diff is collapsed.
Click to expand it.
services/meetingService.test.js
View file @
454bf036
This diff is collapsed.
Click to expand it.