v0.1.2 Add more exception handlers, and updated REST API behaviour

This commit is contained in:
Murtadha 2024-10-16 00:18:56 -04:00
parent 85f61a6ce5
commit e248766073
4 changed files with 128 additions and 37 deletions

View file

@ -1,8 +1,11 @@
package io.titan.portfolio.controller; package io.titan.portfolio.controller;
import org.springframework.dao.DataAccessException;
import org.springframework.dao.EmptyResultDataAccessException;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity; import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.DeleteMapping; import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.PostMapping;
@ -26,39 +29,74 @@ public class EducationController {
} }
@GetMapping @GetMapping
List<Education> getAllEducation(){ public ResponseEntity<List<Education>> getAllEducation() {
return educationService.getAllEducation(); List<Education> educations = educationService.getAllEducation();
return ResponseEntity.ok(educations);
} }
@GetMapping("/{id}") @GetMapping("/{id}")
ResponseEntity<Education> getEducationById(@PathVariable Long id) { public ResponseEntity<Education> getEducationById(@PathVariable Long id) {
return educationService.getEducationById(id) return educationService.getEducationById(id)
.map(ResponseEntity::ok) .map(ResponseEntity::ok)
.orElse(ResponseEntity.notFound().build()); .orElse(ResponseEntity.notFound().build());
} }
@PostMapping @PostMapping
ResponseEntity<Void> createEducation(@RequestBody Education education) { public ResponseEntity<Education> createEducation(@RequestBody Education education) {
educationService.createEducation(education); try {
return ResponseEntity.status(HttpStatus.CREATED).build(); Education createdEducation = educationService.createEducation(education);
return ResponseEntity.status(HttpStatus.CREATED).body(createdEducation);
} catch (IllegalArgumentException e) {
return ResponseEntity.badRequest().body(null);
}
} }
@PutMapping("/{id}") @PutMapping("/{id}")
ResponseEntity<Void> updateEducation(@PathVariable Long id, @RequestBody Education education) { public ResponseEntity<Education> updateEducation(@PathVariable Long id, @RequestBody Education education) {
if (!id.equals(education.id())) { if (!id.equals(education.id())) {
return ResponseEntity.badRequest().build(); return ResponseEntity.badRequest().build();
} }
educationService.updateEducation(education); try {
return ResponseEntity.ok().build(); Education updatedEducation = educationService.updateEducation(education);
return ResponseEntity.ok(updatedEducation);
} catch (EmptyResultDataAccessException e) {
return ResponseEntity.notFound().build();
} catch (IllegalArgumentException e) {
return ResponseEntity.badRequest().body(null);
}
} }
@DeleteMapping("/{id}") @DeleteMapping("/{id}")
ResponseEntity<Void> deleteEducation(@PathVariable Long id) { public ResponseEntity<Void> deleteEducation(@PathVariable Long id) {
boolean deleted = educationService.deleteEducation(id); try {
if (deleted) { educationService.deleteEducation(id);
return ResponseEntity.ok().build(); return ResponseEntity.noContent().build();
} else { } catch (EmptyResultDataAccessException e) {
return ResponseEntity.notFound().build(); return ResponseEntity.notFound().build();
} }
} }
}
@ExceptionHandler(EmptyResultDataAccessException.class)
public ResponseEntity<String> handleNotFound(EmptyResultDataAccessException e) {
return ResponseEntity.status(HttpStatus.NOT_FOUND).body(e.getMessage());
}
@ExceptionHandler(IllegalArgumentException.class)
public ResponseEntity<String> handleBadRequest(IllegalArgumentException e) {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(e.getMessage());
}
@ExceptionHandler(DataAccessException.class)
public ResponseEntity<String> handleDataAccessException(DataAccessException e) {
// Log the exception
e.printStackTrace();
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("An unexpected error occurred");
}
@ExceptionHandler(Exception.class)
public ResponseEntity<String> handleGeneralException(Exception e) {
// Log the exception
e.printStackTrace();
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("An unexpected error occurred");
}
}

View file

@ -20,10 +20,10 @@ public record Education(
this(null, null, null, null, null, null, null, null, null, null, null, null); this(null, null, null, null, null, null, null, null, null, null, null, null);
} }
public Education(String title, String organization, String logo, String location, String duration, public Education(String title, String organization, String logo, String location, String duration,
String description, List<String> achievements, List<String> skills, String description, List<String> achievements, List<String> skills,
List<String> techStack, String skillsTitle, String techStackTitle) { List<String> techStack, String skillsTitle, String techStackTitle) {
this(null, title, organization, logo, location, duration, description, this(null, title, organization, logo, location, duration, description,
achievements, skills, techStack, skillsTitle, techStackTitle); achievements, skills, techStack, skillsTitle, techStackTitle);
} }
} }

View file

@ -2,6 +2,10 @@ package io.titan.portfolio.service;
import io.titan.portfolio.model.Education; import io.titan.portfolio.model.Education;
import io.titan.portfolio.repository.EducationRepository; import io.titan.portfolio.repository.EducationRepository;
import org.springframework.dao.DataAccessException;
import org.springframework.dao.DataIntegrityViolationException;
import org.springframework.dao.EmptyResultDataAccessException;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.List; import java.util.List;
@ -10,32 +14,81 @@ import java.util.Optional;
@Service @Service
public class EducationService{ public class EducationService{
private final EducationRepository educationRepository; private final EducationRepository educationRepository;
public EducationService(EducationRepository educationRepository){ public EducationService(EducationRepository educationRepository){
this.educationRepository = educationRepository; this.educationRepository = educationRepository;
} }
public List<Education> getAllEducation(){ public List<Education> getAllEducation() {
return educationRepository.findAll(); try {
return educationRepository.findAll();
} catch (DataAccessException e) {
// Log the error
System.err.println("Error retrieving all education records: " + e.getMessage());
throw new RuntimeException("Failed to retrieve education records", e);
}
} }
public Optional<Education> getEducationById(Long id){ public Optional<Education> getEducationById(Long id) {
return educationRepository.findById(id); try {
return educationRepository.findById(id);
} catch (DataAccessException e) {
// Log the error
System.err.println("Error retrieving education by id: " + e.getMessage());
throw new RuntimeException("Failed to retrieve education record", e);
}
} }
public Education createEducation(Education education) { public Education createEducation(Education education) {
return educationRepository.save(education); try {
} return educationRepository.save(education);
} catch (DataIntegrityViolationException e) {
public void updateEducation(Education education) { // Log the error
educationRepository.update(education); System.err.println("Error creating education record: " + e.getMessage());
} throw new IllegalArgumentException("Invalid education data: " + e.getMessage());
} catch (DataAccessException e) {
public boolean deleteEducation(Long id) { // Log the error
if (educationRepository.existsById(id)) { System.err.println("Error creating education record: " + e.getMessage());
educationRepository.deleteById(id); throw new RuntimeException("Failed to create education record", e);
return true; }
}
public Education updateEducation(Education education) {
try {
if (!educationRepository.existsById(education.id())) {
throw new EmptyResultDataAccessException("Education record not found with id: " + education.id(), 1);
}
educationRepository.update(education);
return education;
} catch (EmptyResultDataAccessException e) {
// Log the error
System.err.println("Education record not found: " + e.getMessage());
throw e;
} catch (DataIntegrityViolationException e) {
// Log the error
System.err.println("Error updating education record: " + e.getMessage());
throw new IllegalArgumentException("Invalid education data: " + e.getMessage());
} catch (DataAccessException e) {
// Log the error
System.err.println("Error updating education record: " + e.getMessage());
throw new RuntimeException("Failed to update education record", e);
}
}
public void deleteEducation(Long id) {
try {
if (!educationRepository.existsById(id)) {
throw new EmptyResultDataAccessException("Education record not found with id: " + id, 1);
}
educationRepository.deleteById(id);
} catch (EmptyResultDataAccessException e) {
// Log the error
System.err.println("Education record not found: " + e.getMessage());
throw e;
} catch (DataAccessException e) {
// Log the error
System.err.println("Error deleting education record: " + e.getMessage());
throw new RuntimeException("Failed to delete education record", e);
} }
return false;
} }
} }

View file

@ -1 +1 @@
0.1.1 0.1.2