diff --git a/src/main/java/com/libraryman_api/member/MemberService.java b/src/main/java/com/libraryman_api/member/MemberService.java index 93c8843..96d1172 100644 --- a/src/main/java/com/libraryman_api/member/MemberService.java +++ b/src/main/java/com/libraryman_api/member/MemberService.java @@ -116,10 +116,29 @@ public void deleteMember(int memberId) { Members member = memberRepository.findById(memberId) .orElseThrow(() -> new ResourceNotFoundException("Member not found")); - // TODO: Implement logic to check if the member has any outstanding fines or borrowed books. - // If there are no pending obligations, delete all related notifications, borrowings, and fines. + // Check for outstanding fines + List outstandingFines = fineRepository.findByMemberIdAndIsPaidFalse(memberId); + if (!outstandingFines.isEmpty()) { + throw new MemberDeletionException("Cannot delete member with outstanding fines."); + } + // Check for borrowed books + List borrowedBooks = borrowingRepository.getAllBorrowingsOfAMember(memberId); + if (!borrowedBooks.isEmpty()) { + throw new MemberDeletionException("Cannot delete member with borrowed books."); + } + + // Delete related notifications + notificationRepository.deleteByMemberId(memberId); + + // Delete related borrowings and fines + borrowingRepository.deleteByMemberId(memberId); + fineRepository.deleteByMemberId(memberId); + + // Send account deletion notification notificationService.accountDeletionNotification(member); + + // Delete the member memberRepository.delete(member); } }