use of org.openmrs.api.ProgramWorkflowService in project openmrs-core by openmrs.
the class MigrationHelper method importProgramsAndStatuses.
public static int importProgramsAndStatuses(List<String> programWorkflow) throws ParseException {
ProgramWorkflowService pws = Context.getProgramWorkflowService();
PatientService ps = Context.getPatientService();
List<PatientProgram> patientPrograms = new ArrayList<>();
Map<String, PatientProgram> knownPatientPrograms = new HashMap<>();
Map<String, Program> programsByName = new HashMap<>();
for (Program program : pws.getAllPrograms()) {
programsByName.put(program.getConcept().getName(Context.getLocale(), false).getName(), program);
}
for (String s : programWorkflow) {
// ENROLLMENT:HIVEMR-V1,9266,IMB HIV PROGRAM,2005-08-25,
log.debug(s);
if (s.startsWith("ENROLLMENT:")) {
s = s.substring(s.indexOf(":") + 1);
String[] temp = s.split(",");
PatientIdentifierType pit = ps.getPatientIdentifierTypeByName(temp[0]);
String identifier = temp[1];
List<PatientIdentifier> pis = ps.getPatientIdentifiers(identifier, Collections.singletonList(pit), null, null, null);
if (pis.size() != 1) {
throw new IllegalArgumentException("Found " + pis.size() + " instances of identifier " + identifier + " of type " + pit);
}
Patient p = pis.get(0).getPatient();
Program program = programsByName.get(temp[2]);
if (program == null) {
throw new RuntimeException("Couldn't find program \"" + temp[2] + "\" in " + programsByName);
}
Date enrollmentDate = temp.length < 4 ? null : parseDate(temp[3]);
Date completionDate = temp.length < 5 ? null : parseDate(temp[4]);
PatientProgram pp = new PatientProgram();
pp.setPatient(p);
pp.setProgram(program);
pp.setDateEnrolled(enrollmentDate);
pp.setDateCompleted(completionDate);
patientPrograms.add(pp);
// "HIVEMR-V1,9266,IMB HIV PROGRAM"
knownPatientPrograms.put(temp[0] + "," + temp[1] + "," + temp[2], pp);
} else if (s.startsWith("STATUS:")) {
// STATUS:HIVEMR-V1,9266,IMB HIV PROGRAM,TREATMENT STATUS,ACTIVE,2005-08-25,,
s = s.substring(s.indexOf(":") + 1);
String[] temp = s.split(",");
Program program = programsByName.get(temp[2]);
if (program == null) {
throw new RuntimeException("Couldn't find program \"" + temp[2] + "\" in " + programsByName);
}
ProgramWorkflow wf = program.getWorkflowByName(temp[3]);
if (wf == null) {
throw new RuntimeException("Couldn't find workflow \"" + temp[3] + "\" for program " + program + " (in " + program.getAllWorkflows() + ")");
}
ProgramWorkflowState st = wf.getStateByName(temp[4]);
if (st == null) {
throw new RuntimeException("Couldn't find state \"" + temp[4] + "\" for workflow " + wf + " (in " + wf.getStates() + ")");
}
Date startDate = temp.length < 6 ? null : parseDate(temp[5]);
Date endDate = temp.length < 7 ? null : parseDate(temp[6]);
PatientState state = new PatientState();
PatientProgram pp = knownPatientPrograms.get(temp[0] + "," + temp[1] + "," + temp[2]);
state.setPatientProgram(pp);
state.setState(st);
state.setStartDate(startDate);
state.setEndDate(endDate);
pp.getStates().add(state);
}
}
int numAdded = 0;
for (PatientProgram pp : knownPatientPrograms.values()) {
pws.savePatientProgram(pp);
++numAdded;
}
return numAdded;
}
use of org.openmrs.api.ProgramWorkflowService in project openmrs-core by openmrs.
the class PatientProgramValidatorTest method validate_shouldFailIfThereIsMoreThanOneStateWithANullStartDateInTheSameWorkflow.
/**
* @see PatientProgramValidator#validate(Object,Errors)
*/
@Test
public void validate_shouldFailIfThereIsMoreThanOneStateWithANullStartDateInTheSameWorkflow() {
ProgramWorkflowService pws = Context.getProgramWorkflowService();
Patient patient = Context.getPatientService().getPatient(6);
PatientProgram pp = new PatientProgram();
pp.setPatient(patient);
pp.setProgram(pws.getProgram(1));
ProgramWorkflow testWorkflow = pp.getProgram().getWorkflow(1);
// Add 2 other patient states with null start date
PatientState newPatientState1 = new PatientState();
newPatientState1.setState(testWorkflow.getState(1));
pp.getStates().add(newPatientState1);
PatientState newPatientState2 = new PatientState();
newPatientState2.setState(testWorkflow.getState(2));
pp.getStates().add(newPatientState2);
BindException errors = new BindException(pp, "");
new PatientProgramValidator().validate(pp, errors);
Assert.assertEquals(true, errors.hasFieldErrors("states"));
}
Aggregations