-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
PEN Merges enhancement & csv export.
- Loading branch information
1 parent
46d3763
commit d62fc19
Showing
16 changed files
with
423 additions
and
88 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
13 changes: 13 additions & 0 deletions
13
api/src/main/java/ca/bc/gov/educ/eas/api/constants/v1/reports/PenMergesHeader.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
package ca.bc.gov.educ.eas.api.constants.v1.reports; | ||
|
||
import lombok.Getter; | ||
|
||
@Getter | ||
public enum PenMergesHeader { | ||
|
||
CURRENT_PEN("Current PEN"), | ||
MERGED_PEN("Merged PEN"); | ||
|
||
private final String code; | ||
PenMergesHeader(String code) { this.code = code; } | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
16 changes: 16 additions & 0 deletions
16
api/src/main/java/ca/bc/gov/educ/eas/api/mappers/v1/StudentMergeMapper.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
package ca.bc.gov.educ.eas.api.mappers.v1; | ||
|
||
import ca.bc.gov.educ.eas.api.mappers.LocalDateTimeMapper; | ||
import ca.bc.gov.educ.eas.api.mappers.UUIDMapper; | ||
import ca.bc.gov.educ.eas.api.struct.v1.StudentMerge; | ||
import ca.bc.gov.educ.eas.api.struct.v1.StudentMergeResult; | ||
import org.mapstruct.Mapper; | ||
import org.mapstruct.factory.Mappers; | ||
|
||
@Mapper(uses = {UUIDMapper.class, LocalDateTimeMapper.class, AssessmentMapper.class}) | ||
public interface StudentMergeMapper { | ||
|
||
StudentMergeMapper mapper = Mappers.getMapper(StudentMergeMapper.class); | ||
|
||
StudentMergeResult toStructure(StudentMerge studentMerge); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
38 changes: 33 additions & 5 deletions
38
api/src/main/java/ca/bc/gov/educ/eas/api/service/v1/StudentMergeService.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,28 +1,56 @@ | ||
package ca.bc.gov.educ.eas.api.service.v1; | ||
|
||
import ca.bc.gov.educ.eas.api.mappers.v1.StudentMergeMapper; | ||
import ca.bc.gov.educ.eas.api.rest.RestUtils; | ||
import ca.bc.gov.educ.eas.api.struct.external.studentapi.v1.Student; | ||
import ca.bc.gov.educ.eas.api.struct.v1.StudentMerge; | ||
import ca.bc.gov.educ.eas.api.struct.v1.StudentMergeResult; | ||
import lombok.extern.slf4j.Slf4j; | ||
import org.apache.commons.collections4.CollectionUtils; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.stereotype.Service; | ||
|
||
import java.util.List; | ||
import java.util.UUID; | ||
import java.util.*; | ||
import java.util.stream.Collectors; | ||
import java.util.stream.Stream; | ||
|
||
@Service | ||
@Slf4j | ||
public class StudentMergeService { | ||
|
||
private static final StudentMergeMapper mapper = StudentMergeMapper.mapper; | ||
private final RestUtils restUtils; | ||
|
||
@Autowired | ||
public StudentMergeService(RestUtils restUtils){ | ||
public StudentMergeService(RestUtils restUtils) { | ||
this.restUtils = restUtils; | ||
} | ||
|
||
public List<StudentMerge> getMergedStudentsForDateRange(String createDateStart, String createDateEnd){ | ||
public List<StudentMergeResult> getMergedStudentsForDateRange(String createDateStart, String createDateEnd) { | ||
UUID correlationID = UUID.randomUUID(); | ||
List<StudentMergeResult> mergeStudentResults = new ArrayList<>(); | ||
log.info("Fetching student merge records created between {} and {} with correlation ID: {}", createDateStart, createDateEnd, correlationID); | ||
return restUtils.getMergedStudentsForDateRange(correlationID, createDateStart, createDateEnd); | ||
List<StudentMerge> results = restUtils.getMergedStudentsForDateRange(correlationID, createDateStart, createDateEnd); | ||
if (!CollectionUtils.isEmpty(results)) { | ||
Set<String> studentIDs = results.stream() | ||
.flatMap(studentMerge -> Stream.of(studentMerge.getStudentID(), studentMerge.getMergeStudentID())) | ||
.collect(Collectors.toSet()); | ||
List<Student> students = Optional.ofNullable(restUtils.getStudents(correlationID, studentIDs)).orElseGet(Collections::emptyList); | ||
results.stream() | ||
.forEach(studentMerge -> { | ||
StudentMergeResult studentMergeResult = mapper.toStructure(studentMerge); | ||
Optional<Student> mergedPEN = students.stream() | ||
.filter(student -> student.getStudentID().equals(studentMerge.getStudentID())) | ||
.findFirst(); | ||
Optional<Student> currentPEN = students.stream() | ||
.filter(student -> student.getStudentID().equals(studentMerge.getMergeStudentID())) | ||
.findFirst(); | ||
|
||
currentPEN.ifPresent(pen -> studentMergeResult.setCurrentPEN(pen.getPen())); | ||
mergedPEN.ifPresent(pen -> studentMergeResult.setMergedPEN(pen.getPen())); | ||
mergeStudentResults.add(studentMergeResult); | ||
}); | ||
} | ||
return mergeStudentResults; | ||
} | ||
} |
Oops, something went wrong.