From 442ff12aa1aa94dc4e5f87be4adc58d8a356f9e6 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 29 May 2017 11:39:12 +0200 Subject: [PATCH] initialize treatment data first by another message --- .../androidaps/Services/DataService.java | 173 ++++-------------- .../androidaps/db/DatabaseHelper.java | 55 ++++++ .../events/EventReloadTempBasalData.java | 8 + .../events/EventReloadTreatmentData.java | 8 + .../ConfigBuilder/ConfigBuilderPlugin.java | 1 - .../services/NSClientService.java | 1 - .../plugins/Treatments/TreatmentsPlugin.java | 25 ++- 7 files changed, 113 insertions(+), 158 deletions(-) create mode 100644 app/src/main/java/info/nightscout/androidaps/events/EventReloadTempBasalData.java create mode 100644 app/src/main/java/info/nightscout/androidaps/events/EventReloadTreatmentData.java diff --git a/app/src/main/java/info/nightscout/androidaps/Services/DataService.java b/app/src/main/java/info/nightscout/androidaps/Services/DataService.java index 274e86c2a2..b63f9026f7 100644 --- a/app/src/main/java/info/nightscout/androidaps/Services/DataService.java +++ b/app/src/main/java/info/nightscout/androidaps/Services/DataService.java @@ -7,15 +7,12 @@ import android.os.Bundle; import android.preference.PreferenceManager; import android.provider.Telephony; -import com.j256.ormlite.dao.Dao; - import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import java.sql.SQLException; import java.util.Date; import info.nightscout.androidaps.Config; @@ -24,20 +21,19 @@ import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.R; import info.nightscout.androidaps.db.BgReading; import info.nightscout.androidaps.db.CareportalEvent; -import info.nightscout.androidaps.db.Treatment; import info.nightscout.androidaps.events.EventNewBasalProfile; -import info.nightscout.androidaps.interfaces.InsulinInterface; import info.nightscout.androidaps.interfaces.PluginBase; import info.nightscout.androidaps.interfaces.PumpInterface; import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin; -import info.nightscout.androidaps.plugins.PumpDanaR.History.DanaRNSHistorySync; -import info.nightscout.androidaps.plugins.InsulinFastacting.InsulinFastactingFragment; -import info.nightscout.androidaps.plugins.ProfileNS.NSProfilePlugin; import info.nightscout.androidaps.plugins.ConstraintsObjectives.ObjectivesPlugin; +import info.nightscout.androidaps.plugins.NSClientInternal.data.NSProfile; +import info.nightscout.androidaps.plugins.NSClientInternal.data.NSSgv; import info.nightscout.androidaps.plugins.Overview.Notification; import info.nightscout.androidaps.plugins.Overview.OverviewPlugin; import info.nightscout.androidaps.plugins.Overview.events.EventDismissNotification; import info.nightscout.androidaps.plugins.Overview.events.EventNewNotification; +import info.nightscout.androidaps.plugins.ProfileNS.NSProfilePlugin; +import info.nightscout.androidaps.plugins.PumpDanaR.History.DanaRNSHistorySync; import info.nightscout.androidaps.plugins.SmsCommunicator.SmsCommunicatorPlugin; import info.nightscout.androidaps.plugins.SmsCommunicator.events.EventNewSMS; import info.nightscout.androidaps.plugins.SourceGlimp.SourceGlimpPlugin; @@ -45,8 +41,6 @@ import info.nightscout.androidaps.plugins.SourceMM640g.SourceMM640gPlugin; import info.nightscout.androidaps.plugins.SourceNSClient.SourceNSClientPlugin; import info.nightscout.androidaps.plugins.SourceXdrip.SourceXdripPlugin; import info.nightscout.androidaps.receivers.DataReceiver; -import info.nightscout.androidaps.plugins.NSClientInternal.data.NSProfile; -import info.nightscout.androidaps.plugins.NSClientInternal.data.NSSgv; import info.nightscout.utils.SP; @@ -358,7 +352,7 @@ public class DataService extends IntentService { try { if (bundles.containsKey("treatment")) { String trstring = bundles.getString("treatment"); - handleAddedTreatment(trstring); + handleAddChangeDataFromNS(trstring); } if (bundles.containsKey("treatments")) { String trstring = bundles.getString("treatments"); @@ -366,7 +360,7 @@ public class DataService extends IntentService { for (int i = 0; i < jsonArray.length(); i++) { JSONObject trJson = jsonArray.getJSONObject(i); String trstr = trJson.toString(); - handleAddedTreatment(trstr); + handleAddChangeDataFromNS(trstr); } } } catch (Exception e) { @@ -379,7 +373,7 @@ public class DataService extends IntentService { try { if (bundles.containsKey("treatment")) { String trstring = bundles.getString("treatment"); - handleChangedTreatment(trstring); + handleAddChangeDataFromNS(trstring); } if (bundles.containsKey("treatments")) { String trstring = bundles.getString("treatments"); @@ -387,7 +381,7 @@ public class DataService extends IntentService { for (int i = 0; i < jsonArray.length(); i++) { JSONObject trJson = jsonArray.getJSONObject(i); String trstr = trJson.toString(); - handleChangedTreatment(trstr); + handleAddChangeDataFromNS(trstr); } } } catch (Exception e) { @@ -401,11 +395,7 @@ public class DataService extends IntentService { String trstring = bundles.getString("treatment"); JSONObject trJson = new JSONObject(trstring); String _id = trJson.getString("_id"); - MainApp.getDbHelper().deleteTreatmentById(_id); - MainApp.getDbHelper().deleteTempTargetById(trJson.getString("_id")); - MainApp.getDbHelper().deleteTempBasalById(trJson.getString("_id")); - MainApp.getDbHelper().deleteExtendedBolusById(trJson.getString("_id")); - MainApp.getDbHelper().deleteCareportalEventById(trJson.getString("_id")); + handleRemovedRecordFromNS(_id); } if (bundles.containsKey("treatments")) { @@ -414,11 +404,7 @@ public class DataService extends IntentService { for (int i = 0; i < jsonArray.length(); i++) { JSONObject trJson = jsonArray.getJSONObject(i); String _id = trJson.getString("_id"); - MainApp.getDbHelper().deleteTreatmentById(_id); - MainApp.getDbHelper().deleteTempTargetById(trJson.getString("_id")); - MainApp.getDbHelper().deleteTempBasalById(trJson.getString("_id")); - MainApp.getDbHelper().deleteExtendedBolusById(trJson.getString("_id")); - MainApp.getDbHelper().deleteCareportalEventById(trJson.getString("_id")); + handleRemovedRecordFromNS(_id); } } } catch (Exception e) { @@ -470,128 +456,22 @@ public class DataService extends IntentService { } } - private void handleAddedTreatment(String trstring) throws JSONException, SQLException { - JSONObject trJson = new JSONObject(trstring); - handleDanaRHistoryRecords(trJson); // update record _id in history - handleAddChangeTempTargetRecord(trJson); - handleAddChangeTempBasalRecord(trJson); - handleAddChangeExtendedBolusRecord(trJson); - handleAddChangeCareportalEventRecord(trJson); - if (!trJson.has("insulin") && !trJson.has("carbs")) { - if (Config.logIncommingData) - log.debug("Ignoring non insulin/carbs record: " + trstring); - return; - } - - Treatment stored = null; - String _id = trJson.getString("_id"); - - if (trJson.has("date")) { - if (Config.logIncommingData) - log.debug("ADD: date found: " + trstring); - stored = MainApp.getDbHelper().findTreatmentByTimeIndex(trJson.getLong("date")); - } else { - stored = MainApp.getDbHelper().findTreatmentById(_id); - } - - if (stored != null) { - if (Config.logIncommingData) - log.debug("ADD: Existing treatment: " + trstring); - if (trJson.has("date")) { - stored._id = _id; - int updated = MainApp.getDbHelper().update(stored); - if (Config.logIncommingData) - log.debug("Records updated: " + updated); - } - } else { - if (Config.logIncommingData) - log.debug("ADD: New treatment: " + trstring); - InsulinInterface insulinInterface = MainApp.getConfigBuilder().getActiveInsulin(); - if (insulinInterface == null) insulinInterface = InsulinFastactingFragment.getPlugin(); - Treatment treatment = new Treatment(insulinInterface); - treatment._id = _id; - treatment.carbs = trJson.has("carbs") ? trJson.getDouble("carbs") : 0; - treatment.insulin = trJson.has("insulin") ? trJson.getDouble("insulin") : 0d; - treatment.date = trJson.getLong("mills"); - if (trJson.has("eventType")) { - treatment.mealBolus = true; - if (trJson.get("eventType").equals("Correction Bolus")) - treatment.mealBolus = false; - double carbs = treatment.carbs; - if (trJson.has("boluscalc")) { - JSONObject boluscalc = trJson.getJSONObject("boluscalc"); - if (boluscalc.has("carbs")) { - carbs = Math.max(boluscalc.getDouble("carbs"), carbs); - } - } - if (carbs <= 0) - treatment.mealBolus = false; - } - MainApp.getDbHelper().createOrUpdate(treatment); - if (Config.logIncommingData) - log.debug("ADD: Stored treatment: " + treatment.log()); - } + private void handleRemovedRecordFromNS(String _id) { + MainApp.getDbHelper().deleteTreatmentById(_id); + MainApp.getDbHelper().deleteTempTargetById(_id); + MainApp.getDbHelper().deleteTempBasalById(_id); + MainApp.getDbHelper().deleteExtendedBolusById(_id); + MainApp.getDbHelper().deleteCareportalEventById(_id); } - private void handleChangedTreatment(String trstring) throws JSONException, SQLException { + private void handleAddChangeDataFromNS(String trstring) throws JSONException { JSONObject trJson = new JSONObject(trstring); handleDanaRHistoryRecords(trJson); // update record _id in history handleAddChangeTempTargetRecord(trJson); handleAddChangeTempBasalRecord(trJson); handleAddChangeExtendedBolusRecord(trJson); handleAddChangeCareportalEventRecord(trJson); - if (!trJson.has("insulin") && !trJson.has("carbs")) { - if (Config.logIncommingData) - log.debug("CHANGE: Uninterested treatment: " + trstring); - return; - } - String _id = trJson.getString("_id"); - - Treatment stored; - - if (trJson.has("date")) { - if (Config.logIncommingData) - log.debug("ADD: date found: " + trstring); - stored = MainApp.getDbHelper().findTreatmentByTimeIndex(trJson.getLong("date")); - } else { - stored = MainApp.getDbHelper().findTreatmentById(_id); - } - - if (stored != null) { - if (Config.logIncommingData) - log.debug("CHANGE: Removing old: " + trstring); - MainApp.getDbHelper().deleteTreatmentById(_id); - } - - if (Config.logIncommingData) - log.debug("CHANGE: Adding new treatment: " + trstring); - InsulinInterface insulinInterface = MainApp.getConfigBuilder().getActiveInsulin(); - if (insulinInterface == null) insulinInterface = InsulinFastactingFragment.getPlugin(); - Treatment treatment = new Treatment(insulinInterface); - treatment._id = _id; - treatment.carbs = trJson.has("carbs") ? trJson.getDouble("carbs") : 0; - treatment.insulin = trJson.has("insulin") ? trJson.getDouble("insulin") : 0d; - //treatment.created_at = DateUtil.fromISODateString(trJson.getString("created_at")); - treatment.date = trJson.getLong("mills"); - if (trJson.has("eventType")) { - treatment.mealBolus = true; - if (trJson.get("eventType").equals("Correction Bolus")) - treatment.mealBolus = false; - double carbs = treatment.carbs; - if (trJson.has("boluscalc")) { - JSONObject boluscalc = trJson.getJSONObject("boluscalc"); - if (boluscalc.has("carbs")) { - carbs = Math.max(boluscalc.getDouble("carbs"), carbs); - } - } - if (carbs <= 0) - treatment.mealBolus = false; - } - Dao.CreateOrUpdateStatus status = MainApp.getDbHelper().createOrUpdate(treatment); - if (Config.logIncommingData) - log.debug("Records updated: " + status.getNumLinesChanged()); - if (Config.logIncommingData) - log.debug("CHANGE: Stored treatment: " + treatment.log()); + handleAddChangeTreatmentRecord(trJson); } public void handleDanaRHistoryRecords(JSONObject trJson) { @@ -600,7 +480,16 @@ public class DataService extends IntentService { } } - public void handleAddChangeTempTargetRecord(JSONObject trJson) throws JSONException, SQLException { + public void handleAddChangeTreatmentRecord(JSONObject trJson) throws JSONException { + if (trJson.has("insulin") || trJson.has("carbs")) { + if (Config.logIncommingData) + log.debug("Processing Treatment record: " + trJson.toString()); + MainApp.getDbHelper().createTreatmentFromJsonIfNotExists(trJson); + return; + } + } + + public void handleAddChangeTempTargetRecord(JSONObject trJson) throws JSONException { if (trJson.has("eventType") && trJson.getString("eventType").equals(CareportalEvent.TEMPORARYTARGET)) { if (Config.logIncommingData) log.debug("Processing TempTarget record: " + trJson.toString()); @@ -608,7 +497,7 @@ public class DataService extends IntentService { } } - public void handleAddChangeTempBasalRecord(JSONObject trJson) throws JSONException, SQLException { + public void handleAddChangeTempBasalRecord(JSONObject trJson) throws JSONException { if (trJson.has("eventType") && trJson.getString("eventType").equals(CareportalEvent.TEMPBASAL)) { if (Config.logIncommingData) log.debug("Processing TempBasal record: " + trJson.toString()); @@ -616,7 +505,7 @@ public class DataService extends IntentService { } } - public void handleAddChangeExtendedBolusRecord(JSONObject trJson) throws JSONException, SQLException { + public void handleAddChangeExtendedBolusRecord(JSONObject trJson) throws JSONException { if (trJson.has("eventType") && trJson.getString("eventType").equals(CareportalEvent.COMBOBOLUS)) { if (Config.logIncommingData) log.debug("Processing Extended Bolus record: " + trJson.toString()); @@ -624,7 +513,7 @@ public class DataService extends IntentService { } } - public void handleAddChangeCareportalEventRecord(JSONObject trJson) throws JSONException, SQLException { + public void handleAddChangeCareportalEventRecord(JSONObject trJson) throws JSONException { if (trJson.has("eventType") && ( trJson.getString("eventType").equals(CareportalEvent.SITECHANGE) || trJson.getString("eventType").equals(CareportalEvent.INSULINCHANGE) || diff --git a/app/src/main/java/info/nightscout/androidaps/db/DatabaseHelper.java b/app/src/main/java/info/nightscout/androidaps/db/DatabaseHelper.java index d0573654ae..21bae7df8d 100644 --- a/app/src/main/java/info/nightscout/androidaps/db/DatabaseHelper.java +++ b/app/src/main/java/info/nightscout/androidaps/db/DatabaseHelper.java @@ -34,6 +34,8 @@ import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.events.EventCareportalEventChange; import info.nightscout.androidaps.events.EventExtendedBolusChange; import info.nightscout.androidaps.events.EventNewBG; +import info.nightscout.androidaps.events.EventReloadTempBasalData; +import info.nightscout.androidaps.events.EventReloadTreatmentData; import info.nightscout.androidaps.events.EventTempBasalChange; import info.nightscout.androidaps.events.EventTempTargetChange; import info.nightscout.androidaps.events.EventTreatmentChange; @@ -562,6 +564,7 @@ public class DatabaseHelper extends OrmLiteSqliteOpenHelper { static public void scheduleTreatmentChange() { class PostRunnable implements Runnable { public void run() { + MainApp.bus().post(new EventReloadTreatmentData()); MainApp.bus().post(new EventTreatmentChange()); if (latestTreatmentChange != null) MainApp.bus().post(new EventNewHistoryData(latestTreatmentChange)); @@ -596,6 +599,56 @@ public class DatabaseHelper extends OrmLiteSqliteOpenHelper { return new ArrayList(); } + public void createTreatmentFromJsonIfNotExists(JSONObject trJson) { + try { + QueryBuilder queryBuilder = null; + queryBuilder = getDaoTreatments().queryBuilder(); + Where where = queryBuilder.where(); + where.eq("_id", trJson.getString("_id")).or().eq("date", trJson.getLong("mills")); + PreparedQuery preparedQuery = queryBuilder.prepare(); + List list = getDaoTreatments().query(preparedQuery); + Treatment treatment; + if (list.size() == 0) { + treatment = new Treatment(); + treatment.source = Source.NIGHTSCOUT; + if (Config.logIncommingData) + log.debug("Adding Treatment record to database: " + trJson.toString()); + // Record does not exists. add + } else if (list.size() == 1) { + treatment = list.get(0); + if (Config.logIncommingData) + log.debug("Updating Treatment record in database: " + trJson.toString()); + } else { + log.error("Something went wrong"); + return; + } + treatment.date = trJson.getLong("mills"); + treatment.carbs = trJson.has("carbs") ? trJson.getDouble("carbs") : 0; + treatment.insulin = trJson.has("insulin") ? trJson.getDouble("insulin") : 0d; + treatment._id = trJson.getString("_id"); + if (trJson.has("eventType")) { + treatment.mealBolus = true; + if (trJson.get("eventType").equals("Correction Bolus")) + treatment.mealBolus = false; + double carbs = treatment.carbs; + if (trJson.has("boluscalc")) { + JSONObject boluscalc = trJson.getJSONObject("boluscalc"); + if (boluscalc.has("carbs")) { + carbs = Math.max(boluscalc.getDouble("carbs"), carbs); + } + } + if (carbs <= 0) + treatment.mealBolus = false; + } + createOrUpdate(treatment); + scheduleTreatmentChange(); + } catch (SQLException e) { + e.printStackTrace(); + } catch (JSONException e) { + e.printStackTrace(); + } + } + // ---------------- TempTargets handling --------------- public List getTemptargetsDataFromTime(long mills, boolean ascending) { @@ -835,6 +888,7 @@ public class DatabaseHelper extends OrmLiteSqliteOpenHelper { static public void scheduleTemporaryBasalChange() { class PostRunnable implements Runnable { public void run() { + MainApp.bus().post(new EventReloadTempBasalData()); MainApp.bus().post(new EventTempBasalChange()); scheduledTemBasalsPost = null; } @@ -1123,6 +1177,7 @@ public class DatabaseHelper extends OrmLiteSqliteOpenHelper { static public void scheduleExtendedBolusChange() { class PostRunnable implements Runnable { public void run() { + MainApp.bus().post(new EventReloadTreatmentData()); MainApp.bus().post(new EventExtendedBolusChange()); scheduledExtendedBolusPost = null; log.debug("Firing EventExtendedBolusChange"); diff --git a/app/src/main/java/info/nightscout/androidaps/events/EventReloadTempBasalData.java b/app/src/main/java/info/nightscout/androidaps/events/EventReloadTempBasalData.java new file mode 100644 index 0000000000..38b1b86186 --- /dev/null +++ b/app/src/main/java/info/nightscout/androidaps/events/EventReloadTempBasalData.java @@ -0,0 +1,8 @@ +package info.nightscout.androidaps.events; + +/** + * Created by mike on 29.05.2017. + */ + +public class EventReloadTempBasalData { +} diff --git a/app/src/main/java/info/nightscout/androidaps/events/EventReloadTreatmentData.java b/app/src/main/java/info/nightscout/androidaps/events/EventReloadTreatmentData.java new file mode 100644 index 0000000000..a488a9c7a4 --- /dev/null +++ b/app/src/main/java/info/nightscout/androidaps/events/EventReloadTreatmentData.java @@ -0,0 +1,8 @@ +package info.nightscout.androidaps.events; + +/** + * Created by mike on 29.05.2017. + */ + +public class EventReloadTreatmentData { +} diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java index f307d19d60..e76b15f887 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java @@ -565,7 +565,6 @@ public class ConfigBuilderPlugin implements PluginBase, PumpInterface, Constrain log.debug("setExtendedBolus rate: " + rateAfterConstraints + " durationInMinutes: " + durationInMinutes + " success: " + result.success + " enacted: " + result.enacted); if (result.enacted && result.success) { NSUpload.uploadExtendedBolus(result.bolusDelivered, result.duration); - MainApp.bus().post(new EventTreatmentChange()); } return result; } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/NSClientInternal/services/NSClientService.java b/app/src/main/java/info/nightscout/androidaps/plugins/NSClientInternal/services/NSClientService.java index c558dc0b1b..28011cd55d 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/NSClientInternal/services/NSClientService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/NSClientInternal/services/NSClientService.java @@ -57,7 +57,6 @@ import info.nightscout.androidaps.plugins.NSClientInternal.events.EventNSClientS import info.nightscout.androidaps.plugins.Overview.Notification; import info.nightscout.androidaps.plugins.Overview.events.EventDismissNotification; import info.nightscout.androidaps.plugins.Overview.events.EventNewNotification; -import info.nightscout.androidaps.plugins.PumpDanaR.Services.ExecutionService; import info.nightscout.utils.DateUtil; import info.nightscout.utils.SP; import io.socket.client.IO; diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/Treatments/TreatmentsPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/Treatments/TreatmentsPlugin.java index a1efb315c9..ec9f298df9 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/Treatments/TreatmentsPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/Treatments/TreatmentsPlugin.java @@ -22,9 +22,9 @@ import info.nightscout.androidaps.db.TempTarget; import info.nightscout.androidaps.db.TemporaryBasal; import info.nightscout.androidaps.db.Treatment; import info.nightscout.androidaps.events.EventExtendedBolusChange; -import info.nightscout.androidaps.events.EventTempBasalChange; +import info.nightscout.androidaps.events.EventReloadTempBasalData; +import info.nightscout.androidaps.events.EventReloadTreatmentData; import info.nightscout.androidaps.events.EventTempTargetChange; -import info.nightscout.androidaps.events.EventTreatmentChange; import info.nightscout.androidaps.interfaces.PluginBase; import info.nightscout.androidaps.interfaces.PumpInterface; import info.nightscout.androidaps.interfaces.TreatmentsInterface; @@ -274,23 +274,20 @@ public class TreatmentsPlugin implements PluginBase, TreatmentsInterface { } @Subscribe - public void onStatusEvent(final EventTreatmentChange ev) { + public void onStatusEvent(final EventReloadTreatmentData ev) { + log.debug("EventReloadTreatmentData"); initializeTreatmentData(); - updateTotalIOBTreatments(); - } - - @Subscribe - public void onStatusEvent(final EventTempBasalChange ev) { - initializeTempBasalData(); - updateTotalIOBTempBasals(); - } - - @Subscribe - public void onStatusEvent(final EventExtendedBolusChange ev) { initializeExtendedBolusData(); updateTotalIOBTreatments(); } + @Subscribe + public void onStatusEvent(final EventReloadTempBasalData ev) { + log.debug("EventReloadTempBasalData"); + initializeTempBasalData(); + updateTotalIOBTempBasals(); + } + @Override public IobTotal getLastCalculationTempBasals() { return lastTempBasalsCalculation;