Merge pull request 'fix/bossraid-slot-reuse' (#2) from fix/bossraid-slot-reuse into main
All checks were successful
Server CI/CD / lint-and-build (push) Successful in 18s
Server CI/CD / deploy (push) Successful in 57s

Reviewed-on: #2
This commit was merged in pull request #2.
This commit is contained in:
2026-03-19 04:18:32 +00:00
2 changed files with 16 additions and 8 deletions

View File

@@ -252,7 +252,10 @@ func (s *Service) CompleteRaid(sessionName string, rewards []PlayerReward) (*Bos
} }
} }
// Reset slot to idle so it can accept new raids // BossRoom 삭제 후 슬롯 리셋 — 다음 파티가 즉시 슬롯 재사용 가능
if err := s.repo.DeleteRoomBySessionName(sessionName); err != nil {
log.Printf("BossRoom 삭제 실패 (complete): %s: %v", sessionName, err)
}
if err := s.repo.ResetRoomSlot(sessionName); err != nil { if err := s.repo.ResetRoomSlot(sessionName); err != nil {
log.Printf("슬롯 리셋 실패 (complete): %s: %v", sessionName, err) log.Printf("슬롯 리셋 실패 (complete): %s: %v", sessionName, err)
} }
@@ -276,15 +279,20 @@ func (s *Service) FailRaid(sessionName string) (*BossRoom, error) {
return nil, fmt.Errorf("상태 업데이트 실패: %w", err) return nil, fmt.Errorf("상태 업데이트 실패: %w", err)
} }
// Reset slot to idle so it can accept new raids // 응답용 room 조회 (삭제 전에 수행)
if err := s.repo.ResetRoomSlot(sessionName); err != nil {
log.Printf("슬롯 리셋 실패 (fail): %s: %v", sessionName, err)
}
room, err := s.repo.FindBySessionName(sessionName) room, err := s.repo.FindBySessionName(sessionName)
if err != nil { if err != nil {
return nil, fmt.Errorf("방을 찾을 수 없습니다: %w", err) return nil, fmt.Errorf("방을 찾을 수 없습니다: %w", err)
} }
// BossRoom 삭제 후 슬롯 리셋 — 다음 파티가 즉시 슬롯 재사용 가능
if err := s.repo.DeleteRoomBySessionName(sessionName); err != nil {
log.Printf("BossRoom 삭제 실패 (fail): %s: %v", sessionName, err)
}
if err := s.repo.ResetRoomSlot(sessionName); err != nil {
log.Printf("슬롯 리셋 실패 (fail): %s: %v", sessionName, err)
}
return room, nil return room, nil
} }

View File

@@ -167,9 +167,9 @@ func (s *Service) SaveGameDataByUsername(username string, data *GameDataRequest)
// GrantExperience adds experience to a player and handles level ups + stat recalculation. // GrantExperience adds experience to a player and handles level ups + stat recalculation.
func (s *Service) GrantExperience(userID uint, exp int) (*LevelUpResult, error) { func (s *Service) GrantExperience(userID uint, exp int) (*LevelUpResult, error) {
profile, err := s.repo.FindByUserID(userID) profile, err := s.GetProfile(userID)
if err != nil { if err != nil {
return nil, fmt.Errorf("프로필이 존재하지 않습니다") return nil, fmt.Errorf("프로필 조회/생성 실패: %w", err)
} }
result := ApplyExperience(profile.Level, profile.Experience, exp) result := ApplyExperience(profile.Level, profile.Experience, exp)