dhis2-devs team mailing list archive
-
dhis2-devs team
-
Mailing list archive
-
Message #23653
[Branch ~dhis2-devs-core/dhis2/trunk] Rev 11524: schedule SMS for user group - program level
------------------------------------------------------------
revno: 11524
committer: Lai <lai.hispvietnam@xxxxxxxxx>
branch nick: dhis2
timestamp: Fri 2013-07-26 11:11:41 +0700
message:
schedule SMS for user group - program level
modified:
dhis-2/dhis-services/dhis-service-patient/src/main/java/org/hisp/dhis/program/hibernate/HibernateProgramInstanceStore.java
--
lp:dhis2
https://code.launchpad.net/~dhis2-devs-core/dhis2/trunk
Your team DHIS 2 developers is subscribed to branch lp:dhis2.
To unsubscribe from this branch go to https://code.launchpad.net/~dhis2-devs-core/dhis2/trunk/+edit-subscription
=== modified file 'dhis-2/dhis-services/dhis-service-patient/src/main/java/org/hisp/dhis/program/hibernate/HibernateProgramInstanceStore.java'
--- dhis-2/dhis-services/dhis-service-patient/src/main/java/org/hisp/dhis/program/hibernate/HibernateProgramInstanceStore.java 2013-07-26 02:37:52 +0000
+++ dhis-2/dhis-services/dhis-service-patient/src/main/java/org/hisp/dhis/program/hibernate/HibernateProgramInstanceStore.java 2013-07-26 04:11:41 +0000
@@ -219,6 +219,8 @@
sql += " UNION ( " + sendMessageToOrgunitRegisteredSql( dateToCompare ) + " ) ";
sql += " UNION ( " + sendMessageToUsersSql( dateToCompare ) + " ) ";
+
+ sql += " UNION ( " + sendMessageToUserGroupsSql( dateToCompare ) + " ) ";
SqlRowSet rs = jdbcTemplate.queryForRowSet( sql );
@@ -267,6 +269,12 @@
schedulingProgramObjects.add( schedulingProgramObject );
}
+ System.out.println(schedulingProgramObjects.size());
+ for( SchedulingProgramObject schedulingProgramObject : schedulingProgramObjects )
+ {
+ System.out.println(schedulingProgramObject.getProgramInstanceId());
+ }
+
return schedulingProgramObjects;
}
@@ -364,23 +372,20 @@
+ PatientReminder.SEND_TO_ALL_USERS_IN_ORGUGNIT_REGISTERED;
}
- private String sendMessageToUserGroupsSql()
+ private String sendMessageToUserGroupsSql( String dateToCompare )
{
+ System.out.println("String: "+dateToCompare);
return "select pi.programinstanceid, uif.phonenumber,prm.templatemessage, p.firstname, p.middlename, p.lastname, org.name as orgunitName ,"
- + " pg.name as programName, ps.name as programStageName, psi.duedate, "
- + "(DATE(now()) - DATE(psi.duedate) ) as days_since_due_date "
+ + " pg.name as programName, pi.dateofincident, pi.enrollmentdate, (DATE(now()) - DATE(pi.enrollmentdate) ) as days_since_erollment_date, "
+ + "(DATE(now()) - DATE(pi.dateofincident) ) as days_since_incident_date "
+ " from patient p INNER JOIN programinstance pi "
+ " ON p.patientid=pi.patientid "
- + " INNER JOIN programstageinstance psi "
- + " ON psi.programinstanceid=pi.programinstanceid "
+ " INNER JOIN program pg "
+ " ON pg.programid=pi.programid "
- + " INNER JOIN programstage ps "
- + " ON ps.programstageid=psi.programstageid "
- + " INNER JOIN patientreminder prm "
- + " ON prm.programstageid = ps.programstageid "
+ " INNER JOIN organisationunit org "
+ " ON org.organisationunitid = p.organisationunitid "
+ + " INNER JOIN patientreminder prm "
+ + " ON prm.programid = pg.programid "
+ " INNER JOIN usergroupmembers ugm "
+ " ON ugm.usergroupid = prm.usergroupid "
+ " INNER JOIN userinfo uif "
@@ -390,10 +395,8 @@
+ " and uif.phonenumber is not NULL and uif.phonenumber != '' "
+ " and prm.templatemessage is not NULL and prm.templatemessage != '' "
+ " and pg.type=1 and prm.daysallowedsendmessage is not null "
- + " and psi.executiondate is not null "
- + " and ( DATE(now()) - DATE(psi.duedate) ) = prm.daysallowedsendmessage "
+ + " and ( DATE(now()) - DATE("+ dateToCompare +") ) = prm.daysallowedsendmessage "
+ " and prm.whentosend is null "
- //+ " and prm.whentosend = " + PatientReminder.SEND_WHEN_TO_EMROLLEMENT
+ " and prm.sendto = " + PatientReminder.SEND_TO_USER_GROUP;
}
}