From c133336b986583edab7da84b86881a266d7a1c6e Mon Sep 17 00:00:00 2001 From: Marco Villeneuve Date: Wed, 7 Aug 2024 12:04:28 -0700 Subject: [PATCH] Added endpoint to pull all school funding groups. --- .../controller/v1/SchoolAPIController.java | 21 ++- .../endpoint/v1/SchoolAPIEndpoint.java | 8 ++ .../service/v1/SchoolFundingGroupService.java | 21 +++ .../struct/v1/SchoolFundingGroup.java | 32 +++++ .../controller/v1/SchoolControllerTest.java | 123 +++++++++--------- api/target/classes/META-INF/spring.components | 2 + 6 files changed, 139 insertions(+), 68 deletions(-) create mode 100644 api/src/main/java/ca/bc/gov/educ/api/institute/service/v1/SchoolFundingGroupService.java create mode 100644 api/src/main/java/ca/bc/gov/educ/api/institute/struct/v1/SchoolFundingGroup.java diff --git a/api/src/main/java/ca/bc/gov/educ/api/institute/controller/v1/SchoolAPIController.java b/api/src/main/java/ca/bc/gov/educ/api/institute/controller/v1/SchoolAPIController.java index f671a6c8..5e9ee8e5 100644 --- a/api/src/main/java/ca/bc/gov/educ/api/institute/controller/v1/SchoolAPIController.java +++ b/api/src/main/java/ca/bc/gov/educ/api/institute/controller/v1/SchoolAPIController.java @@ -4,12 +4,8 @@ import ca.bc.gov.educ.api.institute.exception.EntityNotFoundException; import ca.bc.gov.educ.api.institute.exception.InvalidPayloadException; import ca.bc.gov.educ.api.institute.exception.errors.ApiError; -import ca.bc.gov.educ.api.institute.mapper.v1.NoteMapper; -import ca.bc.gov.educ.api.institute.mapper.v1.SchoolContactMapper; -import ca.bc.gov.educ.api.institute.mapper.v1.SchoolMapper; -import ca.bc.gov.educ.api.institute.mapper.v1.SchoolTombstoneMapper; +import ca.bc.gov.educ.api.institute.mapper.v1.*; import ca.bc.gov.educ.api.institute.messaging.jetstream.Publisher; -import ca.bc.gov.educ.api.institute.model.v1.InstituteEvent; import ca.bc.gov.educ.api.institute.model.v1.SchoolContactTombstoneEntity; import ca.bc.gov.educ.api.institute.model.v1.SchoolEntity; import ca.bc.gov.educ.api.institute.model.v1.SchoolHistoryEntity; @@ -55,6 +51,8 @@ public class SchoolAPIController implements SchoolAPIEndpoint { private static final SchoolTombstoneMapper tombstoneMapper = SchoolTombstoneMapper.mapper; + private static final IndependentSchoolFundingGroupMapper independentSchoolFundingGroupMapper = IndependentSchoolFundingGroupMapper.mapper; + private static final SchoolContactMapper schoolContactMapper = SchoolContactMapper.mapper; private static final NoteMapper noteMapper = NoteMapper.mapper; @@ -62,6 +60,9 @@ public class SchoolAPIController implements SchoolAPIEndpoint { @Getter(AccessLevel.PRIVATE) private final SchoolService schoolService; + @Getter(AccessLevel.PRIVATE) + private final SchoolFundingGroupService schoolFundingGroupService; + @Getter(AccessLevel.PRIVATE) private final SchoolContactSearchService schoolContactSearchService; @@ -79,9 +80,10 @@ public class SchoolAPIController implements SchoolAPIEndpoint { private final NotePayloadValidator notePayloadValidator; @Autowired - public SchoolAPIController(Publisher publisher, final SchoolService schoolService, SchoolContactSearchService schoolContactSearchService, final SchoolHistoryService schoolHistoryService, SchoolSearchService schoolSearchService, SchoolHistorySearchService schoolHistorySearchService, final SchoolPayloadValidator payloadValidator, SchoolContactPayloadValidator contactPayloadValidator, NotePayloadValidator notePayloadValidator) { + public SchoolAPIController(Publisher publisher, final SchoolService schoolService, SchoolFundingGroupService schoolFundingGroupService, SchoolContactSearchService schoolContactSearchService, final SchoolHistoryService schoolHistoryService, SchoolSearchService schoolSearchService, SchoolHistorySearchService schoolHistorySearchService, final SchoolPayloadValidator payloadValidator, SchoolContactPayloadValidator contactPayloadValidator, NotePayloadValidator notePayloadValidator) { this.publisher = publisher; this.schoolService = schoolService; + this.schoolFundingGroupService = schoolFundingGroupService; this.schoolContactSearchService = schoolContactSearchService; this.schoolHistoryService = schoolHistoryService; this.schoolSearchService = schoolSearchService; @@ -143,7 +145,7 @@ private void validatePayload(Supplier> validator) { @Override public List getAllSchools() { - return getSchoolService().getAllSchoolsList().stream().map(tombstoneMapper::toStructure).collect(Collectors.toList()); + return getSchoolService().getAllSchoolsList().stream().map(tombstoneMapper::toStructure).toList(); } @Override @@ -211,6 +213,11 @@ public CompletableFuture> findAllContacts(Integer pageNumber return this.schoolContactSearchService.findAll(schoolSpecs, pageNumber, pageSize, sorts).thenApplyAsync(schoolEntities -> schoolEntities.map(schoolContactMapper::toStructure)); } + @Override + public List getAllSchoolFundingGroups() { + return getSchoolFundingGroupService().getAllSchoolFundingGroups().stream().map(independentSchoolFundingGroupMapper::toStructure).toList(); + } + @Override public Note updateSchoolNote(UUID schoolId, UUID noteId, Note note) { validatePayload(() -> this.notePayloadValidator.validateUpdatePayload(note)); diff --git a/api/src/main/java/ca/bc/gov/educ/api/institute/endpoint/v1/SchoolAPIEndpoint.java b/api/src/main/java/ca/bc/gov/educ/api/institute/endpoint/v1/SchoolAPIEndpoint.java index 5612fe91..c92b65ac 100644 --- a/api/src/main/java/ca/bc/gov/educ/api/institute/endpoint/v1/SchoolAPIEndpoint.java +++ b/api/src/main/java/ca/bc/gov/educ/api/institute/endpoint/v1/SchoolAPIEndpoint.java @@ -166,4 +166,12 @@ CompletableFuture> findAllContacts(@RequestParam(name = "pag @RequestParam(name = "sort", defaultValue = "") String sortCriteriaJson, @RequestParam(name = "searchCriteriaList", required = false) String searchCriteriaListJson); + @GetMapping("/funding-groups") + @PreAuthorize("hasAuthority('SCOPE_READ_SCHOOL')") + @ApiResponses(value = {@ApiResponse(responseCode = "200", description = "OK")}) + @Transactional(readOnly = true) + @Tag(name = "School Entity", description = "Endpoints for school entity.") + @Schema(name = "IndependentSchoolFundingGroup", implementation = IndependentSchoolFundingGroup.class) + List getAllSchoolFundingGroups(); + } diff --git a/api/src/main/java/ca/bc/gov/educ/api/institute/service/v1/SchoolFundingGroupService.java b/api/src/main/java/ca/bc/gov/educ/api/institute/service/v1/SchoolFundingGroupService.java new file mode 100644 index 00000000..ada03ebe --- /dev/null +++ b/api/src/main/java/ca/bc/gov/educ/api/institute/service/v1/SchoolFundingGroupService.java @@ -0,0 +1,21 @@ +package ca.bc.gov.educ.api.institute.service.v1; + +import ca.bc.gov.educ.api.institute.model.v1.IndependentSchoolFundingGroupEntity; +import ca.bc.gov.educ.api.institute.repository.v1.IndependentSchoolFundingGroupRepository; +import org.springframework.stereotype.Service; + +import java.util.List; + +@Service +public class SchoolFundingGroupService { + + private final IndependentSchoolFundingGroupRepository independentSchoolFundingGroupRepository; + + public SchoolFundingGroupService(IndependentSchoolFundingGroupRepository independentSchoolFundingGroupRepository) { + this.independentSchoolFundingGroupRepository = independentSchoolFundingGroupRepository; + } + + public List getAllSchoolFundingGroups() { + return independentSchoolFundingGroupRepository.findAll(); + } +} diff --git a/api/src/main/java/ca/bc/gov/educ/api/institute/struct/v1/SchoolFundingGroup.java b/api/src/main/java/ca/bc/gov/educ/api/institute/struct/v1/SchoolFundingGroup.java new file mode 100644 index 00000000..dc824643 --- /dev/null +++ b/api/src/main/java/ca/bc/gov/educ/api/institute/struct/v1/SchoolFundingGroup.java @@ -0,0 +1,32 @@ +package ca.bc.gov.educ.api.institute.struct.v1; + +import lombok.AllArgsConstructor; +import lombok.Builder; +import lombok.Data; +import lombok.NoArgsConstructor; + +import java.io.Serializable; + +@Data +@AllArgsConstructor +@NoArgsConstructor +@Builder +@SuppressWarnings("squid:S1700") +public class SchoolFundingGroup implements Serializable { + + private static final long serialVersionUID = 6118916290604876032L; + + private String schoolId; + + private String schoolFundingGroupCode; + + private String label; + + private String description; + + private Integer displayOrder; + + private String effectiveDate; + + private String expiryDate; +} diff --git a/api/src/test/java/ca/bc/gov/educ/api/institute/controller/v1/SchoolControllerTest.java b/api/src/test/java/ca/bc/gov/educ/api/institute/controller/v1/SchoolControllerTest.java index bcf7987f..04473384 100644 --- a/api/src/test/java/ca/bc/gov/educ/api/institute/controller/v1/SchoolControllerTest.java +++ b/api/src/test/java/ca/bc/gov/educ/api/institute/controller/v1/SchoolControllerTest.java @@ -118,6 +118,9 @@ public class SchoolControllerTest { @Autowired SchoolFundingGroupCodeRepository schoolFundingGroupCodeRepository; + @Autowired + IndependentSchoolFundingGroupRepository independentSchoolFundingGroupRepository; + @BeforeEach public void before(){ MockitoAnnotations.openMocks(this); @@ -151,6 +154,7 @@ public void after() { this.schoolOrganizationCodeRepository.deleteAll(); this.schoolReportingRequirementCodeRepository.deleteAll(); this.facilityTypeCodeRepository.deleteAll(); + this.independentSchoolFundingGroupRepository.deleteAll(); } @Test @@ -167,41 +171,51 @@ void testAllSchools_GivenValidID_ShouldReturnStatusOK() throws Exception { } @Test - void testAllSchoolsCheckDistrict_GivenValidID_ShouldReturnStatusOK() throws Exception { + void testAllSchoolsFundingGroups_ShouldReturnStatusOK() throws Exception { final GrantedAuthority grantedAuthority = () -> "SCOPE_READ_SCHOOL"; final var mockAuthority = oidcLogin().authorities(grantedAuthority); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolEntity = this.createSchoolData(); schoolEntity.setDistrictEntity(dist); final SchoolEntity entity = this.schoolRepository.save(schoolEntity); - this.mockMvc.perform(get(URL.BASE_URL_SCHOOL).with(mockAuthority)) - .andDo(print()).andExpect(status().isOk()).andExpect(MockMvcResultMatchers.jsonPath("$.[0].schoolId") - .value(entity.getSchoolId().toString())).andExpect(MockMvcResultMatchers.jsonPath("$.[0].mincode") - .value(entity.getDistrictEntity().getDistrictNumber() + entity.getSchoolNumber())); + + IndependentSchoolFundingGroupEntity fundingGroup = new IndependentSchoolFundingGroupEntity(); + fundingGroup.setSchoolFundingGroupCode("GROUP01"); + fundingGroup.setSchoolGradeCode("01"); + fundingGroup.setCreateUser("ABC"); + fundingGroup.setUpdateUser("ABC"); + fundingGroup.setCreateDate(LocalDateTime.now()); + fundingGroup.setUpdateDate(LocalDateTime.now()); + fundingGroup.setSchoolEntity(entity); + this.independentSchoolFundingGroupRepository.save(fundingGroup); + + this.mockMvc.perform(get(URL.BASE_URL_SCHOOL + "/funding-groups").with(mockAuthority)) + .andDo(print()).andExpect(status().isOk()).andExpect(MockMvcResultMatchers.jsonPath("$.[0].schoolID") + .value(entity.getSchoolId().toString())); } @Test - void testRetrieveSchool_GivenValidID_ShouldReturnStatusOK() throws Exception { + void testAllSchoolsCheckDistrict_GivenValidID_ShouldReturnStatusOK() throws Exception { final GrantedAuthority grantedAuthority = () -> "SCOPE_READ_SCHOOL"; final var mockAuthority = oidcLogin().authorities(grantedAuthority); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolEntity = this.createSchoolData(); schoolEntity.setDistrictEntity(dist); final SchoolEntity entity = this.schoolRepository.save(schoolEntity); - this.mockMvc.perform(get(URL.BASE_URL_SCHOOL + "/" + entity.getSchoolId()).with(mockAuthority)) - .andDo(print()).andExpect(status().isOk()).andExpect(MockMvcResultMatchers.jsonPath("$.schoolId") - .value(entity.getSchoolId().toString())); + this.mockMvc.perform(get(URL.BASE_URL_SCHOOL).with(mockAuthority)) + .andDo(print()).andExpect(status().isOk()).andExpect(MockMvcResultMatchers.jsonPath("$.[0].schoolId") + .value(entity.getSchoolId().toString())).andExpect(MockMvcResultMatchers.jsonPath("$.[0].mincode") + .value(entity.getDistrictEntity().getDistrictNumber() + entity.getSchoolNumber())); } @Test - void testRetrieveSchoolWithAddress_GivenValidID_ShouldReturnStatusOK() throws Exception { + void testRetrieveSchool_GivenValidID_ShouldReturnStatusOK() throws Exception { final GrantedAuthority grantedAuthority = () -> "SCOPE_READ_SCHOOL"; final var mockAuthority = oidcLogin().authorities(grantedAuthority); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolEntity = this.createSchoolData(); schoolEntity.setDistrictEntity(dist); final SchoolEntity entity = this.schoolRepository.save(schoolEntity); - this.mockMvc.perform(get(URL.BASE_URL_SCHOOL + "/" + entity.getSchoolId()).with(mockAuthority)) .andDo(print()).andExpect(status().isOk()).andExpect(MockMvcResultMatchers.jsonPath("$.schoolId") .value(entity.getSchoolId().toString())); @@ -266,7 +280,7 @@ void testDeleteSchool_GivenValidID_ShouldReturnStatusOK() throws Exception { .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(entity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "DELETE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "DELETE_SCHOOL")))) .andDo(print()) .andExpect(status().isNoContent()); @@ -276,7 +290,7 @@ void testDeleteSchool_GivenValidID_ShouldReturnStatusOK() throws Exception { @Test void testUpdateSchool_GivenValidPayload_ShouldReturnStatusCreated() throws Exception { - final var school = this.createSchoolData(); + this.createSchoolData(); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolEntity = this.createSchoolData(); schoolEntity.setDistrictEntity(dist); @@ -293,7 +307,7 @@ void testUpdateSchool_GivenValidPayload_ShouldReturnStatusCreated() throws Excep .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(schoolStruct)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.displayName").value(entity.getDisplayName())); @@ -301,7 +315,7 @@ void testUpdateSchool_GivenValidPayload_ShouldReturnStatusCreated() throws Excep @Test void testUpdateSchool_GivenValidPayloadWithNoSpecCharDisplayName_ShouldReturnStatusCreated() throws Exception { - final var school = this.createSchoolData(); + this.createSchoolData(); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolEntity = this.createSchoolData(); schoolEntity.setDistrictEntity(dist); @@ -319,7 +333,7 @@ void testUpdateSchool_GivenValidPayloadWithNoSpecCharDisplayName_ShouldReturnSta .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(schoolStruct)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.displayNameNoSpecialChars").value(entity.getDisplayNameNoSpecialChars())); @@ -327,7 +341,7 @@ void testUpdateSchool_GivenValidPayloadWithNoSpecCharDisplayName_ShouldReturnSta @Test void testUpdateSchool_GivenInvalidURLSchoolId_ShouldReturnNotFound() throws Exception { - final var school = this.createSchoolData(); + this.createSchoolData(); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolEntity = this.createSchoolData(); schoolEntity.setDistrictEntity(dist); @@ -343,7 +357,7 @@ void testUpdateSchool_GivenInvalidURLSchoolId_ShouldReturnNotFound() throws Exce .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(schoolStruct)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isNotFound()); } @@ -351,7 +365,7 @@ void testUpdateSchool_GivenInvalidURLSchoolId_ShouldReturnNotFound() throws Exce @Test void testUpdateSchool_GivenInvalidPayload_ShouldReturnNotFound() throws Exception { UUID badSchoolId = UUID.randomUUID(); - final var school = this.createSchoolData(); + this.createSchoolData(); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolEntity = this.createSchoolData(); schoolEntity.setDistrictEntity(dist); @@ -368,13 +382,13 @@ void testUpdateSchool_GivenInvalidPayload_ShouldReturnNotFound() throws Exceptio .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(schoolStruct)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isNotFound()); } @Test void testUpdateSchoolWithAddress_GivenValidPayload_ShouldReturnStatusCreated() throws Exception { - final var school = this.createSchoolData(); + this.createSchoolData(); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolEntity = this.createSchoolData(); schoolEntity.setDistrictEntity(dist); @@ -397,7 +411,7 @@ void testUpdateSchoolWithAddress_GivenValidPayload_ShouldReturnStatusCreated() t .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(schoolStruct)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.displayName").value(entity.getDisplayName())); @@ -425,7 +439,7 @@ void testUpdateSchoolWithAddress_GivenValidPayload_ShouldReturnStatusCreated() t .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(auth)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.addresses.[1].addressLine1").value("123 TESTING")); @@ -453,7 +467,7 @@ void testAddSchoolGrade_GivenValidPayload_ShouldReturnStatusOk() throws Exceptio .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(mappedSchool)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.grades[0].schoolGradeCode").value("01")); @@ -481,7 +495,7 @@ void testAddSchoolFundingGroup_GivenValidPayload_ShouldReturnStatusOk() throws E .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(mappedSchool)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.schoolFundingGroups[0].schoolFundingGroupCode").value("GROUP01")); @@ -515,7 +529,7 @@ void testAddSchoolFundingGroupAndRemove_GivenValidPayload_ShouldReturnStatusOk() .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(mappedSchool)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.schoolFundingGroups[0].schoolFundingGroupCode").value("GROUP01")); @@ -535,7 +549,7 @@ void testAddSchoolFundingGroupAndRemove_GivenValidPayload_ShouldReturnStatusOk() .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(mappedSchool2)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.schoolFundingGroups", hasSize(2))); @@ -559,7 +573,7 @@ void testAddSchoolNeighborhoodLearning_GivenValidPayload_ShouldReturnStatusOk() .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(school)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.neighborhoodLearning[0].neighborhoodLearningTypeCode").value("COMM_USE")); @@ -583,7 +597,7 @@ void testUpdateSchoolNeighborhoodLearning_GivenValidPayload_ShouldReturnStatusOk .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(school)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.neighborhoodLearning[0].neighborhoodLearningTypeCode").value("COMM_USE")); @@ -600,7 +614,7 @@ void testUpdateSchoolNeighborhoodLearning_GivenValidPayload_ShouldReturnStatusOk .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(schoolReturn)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.neighborhoodLearning[0].neighborhoodLearningId").value(schoolReturn.getNeighborhoodLearning().get(0).getNeighborhoodLearningId())); @@ -630,7 +644,7 @@ void testCreateSchool_GivenValidPayload_ShouldReturnStatusOK() throws Exception .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(mappedSchool)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isCreated()) .andExpect(MockMvcResultMatchers.jsonPath("$.schoolNumber").exists()) @@ -652,7 +666,7 @@ void testCreateSchool_GivenInvalidPayload_ShouldReturnStatusBadRequest() throws .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(school)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isBadRequest()); } @@ -665,7 +679,7 @@ void testCreateSchoolContact_GivenValidPayload_ShouldReturnStatusCreated() throw .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contactEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isCreated()) .andExpect(MockMvcResultMatchers.jsonPath("$.lastName").value(contactEntity.getLastName())); @@ -681,7 +695,7 @@ void testCreateSchoolContact_GivenValidPayloadNoFirstName_ShouldReturnStatusCrea .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contactEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isCreated()) .andExpect(MockMvcResultMatchers.jsonPath("$.lastName").value(contactEntity.getLastName())); @@ -702,7 +716,7 @@ void testCreateSchoolContactExtFields_GivenValidPayload_ShouldReturnStatusCreate .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contactEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isCreated()) .andExpect(MockMvcResultMatchers.jsonPath("$.lastName").value(contactEntity.getLastName())) @@ -724,7 +738,7 @@ void testCreateSchoolContact_GivenInvalidPayload_ShouldReturnStatusCreated() thr .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contactEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isBadRequest()); } @@ -739,7 +753,7 @@ void testCreateSchoolContact_GivenInvalidTypeCodePayload_ShouldReturnStatusCreat .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contactEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isBadRequest()); } @@ -753,7 +767,7 @@ void testCreateSchoolContact_GivenInvalidSchoolIdURL_ShouldReturnNotFound() thro .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contactEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isNotFound()); } @@ -769,7 +783,7 @@ void testDeleteSchoolContact_GivenValidID_ShouldReturnStatusOK() throws Exceptio .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(schoolEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "DELETE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "DELETE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isNoContent()); @@ -802,7 +816,7 @@ void testUpdateSchoolContact_GivenValidPayload_ShouldReturnStatusCreated() throw .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contact)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.firstName").value(contact.getFirstName())); @@ -820,7 +834,7 @@ void testUpdateSchoolContact_GivenInvalidSchoolIdURL_ShouldReturnNotFound() thro .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contact)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isNotFound()); } @@ -837,7 +851,7 @@ void testUpdateSchoolContact_GivenInvalidContactIdURL_ShouldReturnNotFound() thr .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(contact)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_CONTACT")))) .andDo(print()) .andExpect(status().isNotFound()); } @@ -862,7 +876,7 @@ void testCreateSchoolNote_GivenValidPayload_ShouldReturnStatusCreated() throws E .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(noteEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_NOTE")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_NOTE")))) .andDo(print()) .andExpect(status().isCreated()) .andExpect(MockMvcResultMatchers.jsonPath("$.content").value(noteEntity.getContent())); @@ -877,7 +891,7 @@ void testCreateSchoolNote_GivenInvalidSchoolIdURL_ShouldReturnNotFound() throws .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(noteEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_NOTE")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_NOTE")))) .andDo(print()) .andExpect(status().isNotFound()); } @@ -893,7 +907,7 @@ void testDeleteSchoolNote_GivenValidID_ShouldReturnStatusOK() throws Exception { .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(schoolEntity)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "DELETE_SCHOOL_NOTE")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "DELETE_SCHOOL_NOTE")))) .andDo(print()) .andExpect(status().isNoContent()); @@ -939,7 +953,7 @@ void testUpdateSchoolNote_GivenValidPayload_ShouldReturnStatusCreated() throws E .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(asJsonString(note)) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL_NOTE")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL_NOTE")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.content").value(note.getContent())); @@ -951,13 +965,12 @@ void testReadSchoolPaginated_givenValueNull_ShouldReturnStatusOk() throws Except final var mockAuthority = oidcLogin().authorities(grantedAuthority); this.schoolRepository.save(createSchoolData()); - val entitiesFromDB = this.schoolRepository.findAll(); + this.schoolRepository.findAll(); final SearchCriteria criteria = SearchCriteria.builder().key("website").operation(FilterOperation.EQUAL).value(null).valueType(ValueType.STRING).build(); final List criteriaList = new ArrayList<>(); criteriaList.add(criteria); final List searches = new LinkedList<>(); searches.add(Search.builder().searchCriteriaList(criteriaList).build()); - final ObjectMapper objectMapper = new ObjectMapper(); final String criteriaJSON = objectMapper.writeValueAsString(searches); this.mockMvc.perform(get(URL.BASE_URL_SCHOOL + "/paginated").with(mockAuthority).param("searchCriteriaList", criteriaJSON) .contentType(APPLICATION_JSON)).andDo(print()).andExpect(status().isOk()); @@ -968,7 +981,6 @@ void testReadStudentPaginated_GivenSchoolNameFilter_ShouldReturnStatusOk() throw final GrantedAuthority grantedAuthority = () -> "SCOPE_READ_SCHOOL"; final var mockAuthority = oidcLogin().authorities(grantedAuthority); - final ObjectMapper objectMapper = new ObjectMapper(); final DistrictTombstoneEntity dist = this.districtTombstoneRepository.save(this.createDistrictData()); var schoolData = createSchoolData(); @@ -1024,7 +1036,7 @@ void testCreateSchoolWithGradeAndNeighbourhoodLearning_GivenValidData_SchoolHist .contentType(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON) .content(updatedSchool) - .with(jwt().jwt((jwt) -> jwt.claim("scope", "WRITE_SCHOOL")))) + .with(jwt().jwt(jwt -> jwt.claim("scope", "WRITE_SCHOOL")))) .andDo(print()) .andExpect(status().isOk()) .andExpect(MockMvcResultMatchers.jsonPath("$.displayName").value(entity.getDisplayName())); @@ -1051,7 +1063,6 @@ void testReadSchoolHistoryPaginated_givenValueNull_ShouldReturnStatusOk() throws criteriaList.add(criteria); final List searches = new LinkedList<>(); searches.add(Search.builder().searchCriteriaList(criteriaList).build()); - final ObjectMapper objectMapper = new ObjectMapper(); final String criteriaJSON = objectMapper.writeValueAsString(searches); final MvcResult result = this.mockMvc.perform(get(URL.BASE_URL_SCHOOL + "/history/paginated").with(mockAuthority).param("searchCriteriaList", criteriaJSON) .contentType(APPLICATION_JSON)).andReturn(); @@ -1070,7 +1081,6 @@ void testReadSchoolHistoryPaginated_givenWrongRole_ShouldReturnStatusForbidden() criteriaList.add(criteria); final List searches = new LinkedList<>(); searches.add(Search.builder().searchCriteriaList(criteriaList).build()); - final ObjectMapper objectMapper = new ObjectMapper(); final String criteriaJSON = objectMapper.writeValueAsString(searches); final ResultActions result = this.mockMvc.perform(get(URL.BASE_URL_SCHOOL + "/history/paginated").with(mockAuthority).param("searchCriteriaList", criteriaJSON) .contentType(APPLICATION_JSON)).andDo(print()); @@ -1097,7 +1107,6 @@ void testReadSchoolHistoryPaginated_givenMultipleSearchCriteriaIncludingLowerCas criteriaList.add(criteriaSchoolPhoneNumber); final List searches = new LinkedList<>(); searches.add(Search.builder().searchCriteriaList(criteriaList).build()); - final ObjectMapper objectMapper = new ObjectMapper(); final String criteriaJSON = objectMapper.writeValueAsString(searches); final MvcResult result = this.mockMvc.perform(get(URL.BASE_URL_SCHOOL + "/history/paginated").with(mockAuthority).param("searchCriteriaList", criteriaJSON) .contentType(APPLICATION_JSON)).andReturn(); @@ -1115,7 +1124,6 @@ void testReadSchoolHistoryPaginated_givenInvalidSearchCriteria_ShouldThrowExcept criteriaList.add(invalidCriteria); final List searches = new LinkedList<>(); searches.add(Search.builder().searchCriteriaList(criteriaList).build()); - final ObjectMapper objectMapper = new ObjectMapper(); final String criteriaJSON = objectMapper.writeValueAsString(searches); this.mockMvc.perform(get(URL.BASE_URL_SCHOOL + "/history/paginated").with(mockAuthority).param("searchCriteriaList", criteriaJSON) .contentType(APPLICATION_JSON)).andDo(print()).andExpect(status().isBadRequest()); @@ -1133,7 +1141,6 @@ void testReadSchoolContactPaginated_givenValueFirstName_ShouldReturnStatusOk() t criteriaList.add(criteria); final List searches = new LinkedList<>(); searches.add(Search.builder().searchCriteriaList(criteriaList).build()); - final ObjectMapper objectMapper = new ObjectMapper(); final String criteriaJSON = objectMapper.writeValueAsString(searches); final MvcResult result = this.mockMvc .perform(get(URL.BASE_URL_SCHOOL + "/contact/paginated").with(mockAuthority).param("searchCriteriaList", criteriaJSON) @@ -1155,7 +1162,6 @@ void testReadSchoolContactPaginated_givenValueSchoolID_ShouldReturnStatusOk() th criteriaList.add(criteria); final List searches = new LinkedList<>(); searches.add(Search.builder().searchCriteriaList(criteriaList).build()); - final ObjectMapper objectMapper = new ObjectMapper(); final String criteriaJSON = objectMapper.writeValueAsString(searches); final MvcResult result = this.mockMvc .perform(get(URL.BASE_URL_SCHOOL + "/contact/paginated").with(mockAuthority).param("searchCriteriaList", criteriaJSON) @@ -1312,11 +1318,6 @@ private NeighborhoodLearningEntity createNeighborhoodLearningData(SchoolEntity e return NeighborhoodLearningEntity.builder().schoolEntity(entity).neighborhoodLearningTypeCode("COMM_USE").createUser("TEST").updateUser("TEST").build(); } - private SchoolAddressEntity createAddressData(SchoolEntity entity) { - return SchoolAddressEntity.builder().schoolEntity(entity).addressTypeCode("MAILING").addressLine1("123 This Street").city("Compton") - .provinceCode("BC").countryCode("CA").postal("V1B9H2").build(); - } - private NoteEntity createNoteData(SchoolEntity entity) { return NoteEntity.builder().schoolID(entity.getSchoolId()).content("This is a note.").createUser("TEST").updateUser("TEST").build(); } diff --git a/api/target/classes/META-INF/spring.components b/api/target/classes/META-INF/spring.components index 2cb48581..d7df69db 100644 --- a/api/target/classes/META-INF/spring.components +++ b/api/target/classes/META-INF/spring.components @@ -1,4 +1,5 @@ ca.bc.gov.educ.api.institute.InstituteApiResourceApplication=org.springframework.stereotype.Component,org.springframework.boot.SpringBootConfiguration +ca.bc.gov.educ.api.institute.InstituteApiResourceApplication$WebSecurityConfiguration=org.springframework.stereotype.Component ca.bc.gov.educ.api.institute.adapter.CustomRequestBodyAdviceAdapter=org.springframework.stereotype.Component ca.bc.gov.educ.api.institute.config.AsyncConfiguration=org.springframework.stereotype.Component ca.bc.gov.educ.api.institute.config.InstituteAPIMVCConfig=org.springframework.stereotype.Component @@ -119,6 +120,7 @@ ca.bc.gov.educ.api.institute.service.v1.IndependentAuthorityHistoryService=org.s ca.bc.gov.educ.api.institute.service.v1.IndependentAuthorityService=org.springframework.stereotype.Component ca.bc.gov.educ.api.institute.service.v1.JetStreamEventHandlerService=org.springframework.stereotype.Component ca.bc.gov.educ.api.institute.service.v1.SchoolContactSearchService=org.springframework.stereotype.Component +ca.bc.gov.educ.api.institute.service.v1.SchoolFundingGroupService=org.springframework.stereotype.Component ca.bc.gov.educ.api.institute.service.v1.SchoolHistorySearchService=org.springframework.stereotype.Component ca.bc.gov.educ.api.institute.service.v1.SchoolHistoryService=org.springframework.stereotype.Component ca.bc.gov.educ.api.institute.service.v1.SchoolNumberGenerationService=org.springframework.stereotype.Component