UCSBSubjectsController.java

package edu.ucsb.cs156.courses.controllers;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import edu.ucsb.cs156.courses.entities.UCSBSubject;
import edu.ucsb.cs156.courses.errors.EntityNotFoundException;
import edu.ucsb.cs156.courses.repositories.UCSBSubjectRepository;
import edu.ucsb.cs156.courses.services.UCSBSubjectsService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import java.util.List;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@Slf4j
@Tag(name = "API to handle CRUD operations for UCSB Subjects database")
@RequestMapping("/api/UCSBSubjects")
@RestController
public class UCSBSubjectsController extends ApiController /* implements ApplicationRunner */ {
  @Autowired UCSBSubjectRepository subjectRepository;

  @Autowired ObjectMapper mapper;

  @Autowired UCSBSubjectsService ucsbSubjectsService;

  @Operation(summary = "Get all UCSB Subjects")
  @GetMapping("/all")
  public Iterable<UCSBSubject> allSubjects() {
    Iterable<UCSBSubject> subjects = subjectRepository.findAll();
    return subjects;
  }

  @Operation(summary = "Load subjects into database from UCSB API")
  @PreAuthorize("hasRole('ROLE_ADMIN')")
  @PostMapping("/load")
  public List<UCSBSubject> loadSubjects() throws JsonProcessingException {
    List<UCSBSubject> savedSubjects = ucsbSubjectsService.loadAllSubjects();
    return savedSubjects;
  }

  @Operation(summary = "Get a single UCSB Subject by id if it is in the database")
  @PreAuthorize("hasRole('ROLE_USER') || hasRole('ROLE_ADMIN')")
  @GetMapping("")
  public UCSBSubject getSubjectById(
      @Parameter(name = "subjectCode") @RequestParam String subjectCode)
      throws JsonProcessingException {

    UCSBSubject subject =
        subjectRepository
            .findById(subjectCode)
            .orElseThrow(() -> new EntityNotFoundException(UCSBSubject.class, subjectCode));

    return subject;
  }

  @Operation(summary = "Delete a UCSB Subject by id")
  @PreAuthorize("hasRole('ROLE_ADMIN')")
  @DeleteMapping("")
  public Object deleteSubject(@Parameter(name = "subjectCode") @RequestParam String subjectCode) {

    UCSBSubject subject =
        subjectRepository
            .findById(subjectCode)
            .orElseThrow(() -> new EntityNotFoundException(UCSBSubject.class, subjectCode));

    subjectRepository.delete(subject);

    return genericMessage("UCSBSubject with id %s deleted".formatted(subjectCode));
  }

  @Operation(summary = "Delete all UCSB Subjects in the table")
  @PreAuthorize("hasRole('ROLE_ADMIN')")
  @DeleteMapping("/all")
  public Object deleteAllSubjects() {
    subjectRepository.deleteAll();
    return genericMessage("All UCSBSubject records deleted");
  }
}