Merge remote-tracking branch 'refs/remotes/origin/jpa' into jpa
This commit is contained in:
@@ -1,6 +1,8 @@
|
|||||||
package hackathon.FrisbYEE.jpa.dto;
|
package hackathon.FrisbYEE.jpa.dto;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
|
|||||||
@@ -5,9 +5,7 @@ import jakarta.persistence.Id;
|
|||||||
import jakarta.persistence.ManyToMany;
|
import jakarta.persistence.ManyToMany;
|
||||||
import jakarta.persistence.OneToOne;
|
import jakarta.persistence.OneToOne;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.Getter;
|
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
import lombok.Setter;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import jakarta.persistence.Access;
|
import jakarta.persistence.Access;
|
||||||
|
|||||||
@@ -3,8 +3,11 @@ package hackathon.FrisbYEE.jpa.service;
|
|||||||
import hackathon.FrisbYEE.jpa.metier.Activite;
|
import hackathon.FrisbYEE.jpa.metier.Activite;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
@Repository
|
@Repository
|
||||||
public interface ActiviteDAO extends JpaRepository<Activite, Integer> {
|
public interface ActiviteDAO extends JpaRepository<Activite, Integer> {
|
||||||
|
|
||||||
|
List<Activite> findByTheme(String theme);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -84,7 +84,8 @@ public class ActiviteResource {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/read/{id}")
|
@GetMapping("/{id}")
|
||||||
|
@PreAuthorize("hasRole('Coach') or hasRole('Athlete')")
|
||||||
@ResponseBody
|
@ResponseBody
|
||||||
public ResponseEntity<ActiviteDTO> getActivityById(@PathVariable("id") int id) {
|
public ResponseEntity<ActiviteDTO> getActivityById(@PathVariable("id") int id) {
|
||||||
try {
|
try {
|
||||||
@@ -104,6 +105,7 @@ public class ActiviteResource {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/all")
|
@GetMapping("/all")
|
||||||
|
@PreAuthorize("hasRole('Coach') or hasRole('Athlete')")
|
||||||
@ResponseBody
|
@ResponseBody
|
||||||
public ResponseEntity<List<ActiviteDTO>> getAllActivity() {
|
public ResponseEntity<List<ActiviteDTO>> getAllActivity() {
|
||||||
try {
|
try {
|
||||||
@@ -124,4 +126,28 @@ public class ActiviteResource {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GetMapping("/theme/{theme}")
|
||||||
|
@PreAuthorize("hasRole('Coach') or hasRole('Athlete')")
|
||||||
|
@ResponseBody
|
||||||
|
public ResponseEntity<List<ActiviteDTO>> getActivityByTheme(@PathVariable("theme") String theme) {
|
||||||
|
try {
|
||||||
|
List<Activite> activites = activiteDAO.findByTheme(theme);
|
||||||
|
List<ActiviteDTO> dtos = activites.stream().map(activite -> {
|
||||||
|
ActiviteDTO dto = new ActiviteDTO();
|
||||||
|
dto.setName(activite.getName());
|
||||||
|
dto.setId(activite.getId());
|
||||||
|
dto.setTheme(activite.getTheme());
|
||||||
|
dto.setDuree(activite.getDuree());
|
||||||
|
dto.setDataActivite(activite.getDataActivite());
|
||||||
|
dto.setSessionId(activite.getSession() != null ? activite.getSession().getId() : null);
|
||||||
|
return dto;
|
||||||
|
}).collect(Collectors.toList());
|
||||||
|
return ResponseEntity.ok(dtos);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
return ResponseEntity.status(HttpStatus.NOT_FOUND).body(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user