Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
hanazaq committed Nov 25, 2024
2 parents 6811952 + ef5aebd commit ec316ec
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 30 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package com.group7.demo.controllers;

import com.group7.demo.services.SearchService;
import jakarta.servlet.http.HttpServletRequest;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
Expand Down Expand Up @@ -37,14 +38,14 @@ public SearchController(SearchService searchService) {
// return ResponseEntity.ok(results);
// }
@GetMapping("/search")
public ResponseEntity<Map<String, Object>> search(@RequestParam("q") String query) {
public ResponseEntity<Map<String, Object>> search(@RequestParam("q") String query, HttpServletRequest request) {
// String[] keywords = query.split("\\s+");
// List<String> keywordList = Arrays.stream(keywords)
// .map(String::trim)
// .filter(k -> !k.isEmpty())
// .toList();

Map<String, Object> results = searchService.search(query);
Map<String, Object> results = searchService.search(query, request);

return ResponseEntity.ok(results);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import com.group7.demo.dtos.TrainingProgramResponse;
import com.group7.demo.dtos.UserTrainingProgramResponse;
import com.group7.demo.services.TrainingProgramService;
import jakarta.persistence.EntityNotFoundException;
import jakarta.servlet.http.HttpServletRequest;
import lombok.AllArgsConstructor;
import org.springframework.http.HttpStatus;
Expand Down Expand Up @@ -61,14 +62,22 @@ public ResponseEntity<Void> deleteTrainingProgram(@PathVariable Long id, HttpSer

@PostMapping("/{programId}/join")
public ResponseEntity<UserTrainingProgramResponse> joinTrainingProgram(@PathVariable Long programId , HttpServletRequest request) {
UserTrainingProgramResponse response = trainingProgramService.joinTrainingProgram(programId ,request);
return ResponseEntity.ok(response);
try {
UserTrainingProgramResponse response = trainingProgramService.joinTrainingProgram(programId ,request);
return ResponseEntity.ok(response);
} catch (IllegalStateException | EntityNotFoundException e) {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).build();
}
}

@DeleteMapping("/{programId}/leave")
public ResponseEntity<UserTrainingProgramResponse> leaveProgram(@PathVariable Long programId, HttpServletRequest request) {
UserTrainingProgramResponse response = trainingProgramService.leaveTrainingProgram(programId, request);
return ResponseEntity.ok(response);
try {
UserTrainingProgramResponse response = trainingProgramService.leaveTrainingProgram(programId, request);
return ResponseEntity.ok(response);
} catch (IllegalStateException e) {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).build();
}
}

@GetMapping("/{programId}/participants")
Expand All @@ -90,26 +99,38 @@ public ResponseEntity<UserTrainingProgramResponse> markExerciseAsCompleted(
@PathVariable Long exerciseId,
HttpServletRequest request
) {
UserTrainingProgramResponse response = trainingProgramService.markExerciseAsCompleted(trainingProgramId, exerciseId, request);
return ResponseEntity.ok(response);
try{
UserTrainingProgramResponse response = trainingProgramService.markExerciseAsCompleted(trainingProgramId, exerciseId, request);
return ResponseEntity.ok(response);
} catch (IllegalStateException e) {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).build();
}
}

@PostMapping("/{trainingProgramId}/exercises/{exerciseId}/uncomplete")
public ResponseEntity<UserTrainingProgramResponse> unmarkExerciseAsCompleted(
@PathVariable Long trainingProgramId,
@PathVariable Long exerciseId,
HttpServletRequest request) {
UserTrainingProgramResponse response = trainingProgramService.unmarkExerciseAsCompleted(trainingProgramId, exerciseId, request);
return ResponseEntity.ok(response);
try{
UserTrainingProgramResponse response = trainingProgramService.unmarkExerciseAsCompleted(trainingProgramId, exerciseId, request);
return ResponseEntity.ok(response);
} catch (IllegalStateException e) {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).build();
}
}

@PostMapping("/{trainingProgramId}/complete")
public ResponseEntity<UserTrainingProgramResponse> markTrainingProgramAsCompleted(
@PathVariable Long trainingProgramId,
HttpServletRequest request
) {
UserTrainingProgramResponse response = trainingProgramService.markTrainingProgramAsCompleted(trainingProgramId, request);
return ResponseEntity.ok(response);
try {
UserTrainingProgramResponse response = trainingProgramService.markTrainingProgramAsCompleted(trainingProgramId, request);
return ResponseEntity.ok(response);
} catch (IllegalStateException e) {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).build();
}
}

@GetMapping("/joined/{username}")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,14 @@

import com.group7.demo.models.User;
import com.group7.demo.models.UserTrainingProgram;
import com.group7.demo.models.enums.UserTrainingProgramStatus;
import org.springframework.data.jpa.repository.JpaRepository;

import java.util.List;
import java.util.Optional;

public interface UserTrainingProgramRepository extends JpaRepository<UserTrainingProgram, Long> {
List<UserTrainingProgram> findAllByUserAndTrainingProgramId(User user, Long trainingProgramId);
Optional<UserTrainingProgram> findByUserIdAndTrainingProgramId(Long userId, Long programId);

boolean existsByUserAndTrainingProgramIdAndStatus(User user, Long trainingProgramId, UserTrainingProgramStatus status);
List<UserTrainingProgram> findByUserAndTrainingProgramIdAndStatus(User user, Long trainingProgramId, UserTrainingProgramStatus status);
List<UserTrainingProgram> findByUser(User user);

}
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
import com.group7.demo.repository.ExerciseRepository;
import com.group7.demo.repository.PostRepository;
import com.group7.demo.repository.TrainingProgramRepository;
import jakarta.servlet.http.HttpServletRequest;
import org.springframework.stereotype.Service;

import java.util.*;
Expand Down Expand Up @@ -82,7 +83,7 @@ public SearchService(ExerciseRepository exerciseRepository,
//
// return results;
// }
public Map<String, Object> search(String query) {
public Map<String, Object> search(String query, HttpServletRequest request) {
// Split the query into individual keywords
String[] keywords = query.trim().split("\\s+");

Expand All @@ -100,7 +101,7 @@ public Map<String, Object> search(String query) {

// Map entities to DTOs
List<PostResponse> postResponses = posts.stream()
.map(mapper::mapToPostResponse)
.map(post -> mapper.mapToPostResponse(post, request))
.collect(Collectors.toList());

List<Exercise> exerciseResponses = exercises.stream()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -133,13 +133,10 @@ public UserTrainingProgramResponse joinTrainingProgram(Long trainingProgramId ,
TrainingProgram trainingProgram = trainingProgramRepository.findById(trainingProgramId)
.orElseThrow(() -> new EntityNotFoundException("Training Program not found with id: " + trainingProgramId));

// Check for all past participations
List<UserTrainingProgram> pastEntries = userTrainingProgramRepository.findAllByUserAndTrainingProgramId(user, trainingProgramId);
// Check if the user is already actively participating in this training program
boolean hasOngoingProgram = userTrainingProgramRepository.existsByUserAndTrainingProgramIdAndStatus(user, trainingProgramId, UserTrainingProgramStatus.ONGOING);

boolean hasOngoingEntry = pastEntries.stream()
.anyMatch(entry -> entry.getStatus() == UserTrainingProgramStatus.ONGOING);

if (hasOngoingEntry) {
if (hasOngoingProgram) {
throw new IllegalStateException("User is already actively participating in this training program.");
}

Expand Down Expand Up @@ -199,12 +196,15 @@ public List<UserTrainingProgramResponse> getJoinedTrainingPrograms(String userna
}

private UserTrainingProgram getOngoingUserTrainingProgram(User user, Long trainingProgramId) {
// Fetch all entries and filter the ongoing one
return userTrainingProgramRepository.findAllByUserAndTrainingProgramId(user, trainingProgramId)
.stream()
.filter(entry -> entry.getStatus() == UserTrainingProgramStatus.ONGOING)
.findFirst()
.orElseThrow(() -> new IllegalStateException("No ongoing training program found."));
List<UserTrainingProgram> ongoingPrograms = userTrainingProgramRepository.findByUserAndTrainingProgramIdAndStatus(user, trainingProgramId, UserTrainingProgramStatus.ONGOING);

if (ongoingPrograms.isEmpty()) {
throw new IllegalStateException("No ongoing training program found.");
}

// Return the first ongoing program if available
return ongoingPrograms.get(0);

}

@Transactional
Expand Down

0 comments on commit ec316ec

Please sign in to comment.