From 01012d817cfdf8dcfb079afec63d793650143266 Mon Sep 17 00:00:00 2001 From: Roumen Georgiev Date: Tue, 12 Jun 2018 10:29:47 +0300 Subject: [PATCH 1/5] getting userOptions from v2 --- .../activities/DanaRUserOptionsActivity.java | 39 ++++++++++++++----- .../PumpDanaR/comm/MessageHashTable.java | 1 + .../PumpDanaR/comm/MsgGetUserOptions.java | 24 ++++++++---- .../PumpDanaR/comm/MsgSettingUserOptions.java | 18 ++++----- .../services/DanaRExecutionService.java | 26 +++++++++++++ .../plugins/PumpDanaRv2/DanaRv2Plugin.java | 6 +++ .../services/DanaRv2ExecutionService.java | 19 ++++++++- .../commands/CommandSetUserSettings.java | 7 ++++ 8 files changed, 113 insertions(+), 27 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java index 31b7d22147..b58148ff45 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java @@ -21,9 +21,11 @@ import info.nightscout.androidaps.R; import info.nightscout.androidaps.events.EventInitializationChanged; import info.nightscout.androidaps.interfaces.PluginType; import info.nightscout.androidaps.plugins.Overview.Dialogs.ErrorHelperActivity; +import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPlugin; import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPump; import info.nightscout.androidaps.plugins.PumpDanaRKorean.DanaRKoreanPlugin; import info.nightscout.androidaps.plugins.PumpDanaRS.DanaRSPlugin; +import info.nightscout.androidaps.plugins.PumpDanaRv2.DanaRv2Plugin; import info.nightscout.androidaps.queue.Callback; import info.nightscout.utils.NumberPicker; @@ -81,8 +83,7 @@ public class DanaRUserOptionsActivity extends Activity { saveToPumpButton.setOnClickListener(v -> onSaveClick()); - boolean isKorean = MainApp.getSpecificPlugin(DanaRKoreanPlugin.class) != null && MainApp.getSpecificPlugin(DanaRKoreanPlugin.class).isEnabled(PluginType.PUMP); - boolean isRS = MainApp.getSpecificPlugin(DanaRSPlugin.class) != null && MainApp.getSpecificPlugin(DanaRSPlugin.class).isEnabled(PluginType.PUMP); + boolean isv2 = MainApp.getSpecificPlugin(DanaRv2Plugin.class) != null && MainApp.getSpecificPlugin(DanaRv2Plugin.class).isEnabled(PluginType.PUMP); DanaRPump pump = DanaRPump.getInstance(); @@ -95,7 +96,20 @@ public class DanaRUserOptionsActivity extends Activity { + "\nbacklight:" + pump.backlightOnTimeSec + "\npumpUnits:" + pump.units + "\nlowReservoir:" + pump.lowReservoirRate); + log.debug("isV2:"+isv2); + if(isv2 && pump.lowReservoirRate < 10){ + log.debug("No user settings loaded forcing reload!"); + DanaRv2Plugin.getPlugin().getUserOptions(); + log.debug("UserOptionsLoaded:" + (System.currentTimeMillis() - pump.lastConnection) / 1000 + " s ago" + + "\ntimeDisplayType:" + pump.timeDisplayType + + "\nbuttonScroll:" + pump.buttonScrollOnOff + + "\ntimeDisplayType:" + pump.timeDisplayType + + "\nlcdOnTimeSec:" + pump.lcdOnTimeSec + + "\nbacklight:" + pump.backlightOnTimeSec + + "\npumpUnits:" + pump.units + + "\nlowReservoir:" + pump.lowReservoirRate); + } screenTimeout.setParams((double) pump.lcdOnTimeSec, 5d, 240d, 5d, new DecimalFormat("1"), false); backlightTimeout.setParams((double) pump.backlightOnTimeSec, 1d, 60d, 1d, new DecimalFormat("1"), false); @@ -111,9 +125,9 @@ public class DanaRUserOptionsActivity extends Activity { public void setData() { DanaRPump pump = DanaRPump.getInstance(); - timeFormat.setChecked(pump.timeDisplayType == 0); + timeFormat.setChecked(pump.timeDisplayType != 0); buttonScroll.setChecked(pump.buttonScrollOnOff != 0); - beep.setChecked(pump.beepAndAlarm != 0); + beep.setChecked(pump.beepAndAlarm < 5); screenTimeout.setValue((double) pump.lcdOnTimeSec); backlightTimeout.setValue((double) pump.backlightOnTimeSec); pumpUnits.setChecked(pump.getUnits() != null && pump.getUnits().equals(Constants.MMOL)); @@ -128,10 +142,15 @@ public class DanaRUserOptionsActivity extends Activity { public void onSaveClick() { boolean isRS = MainApp.getSpecificPlugin(DanaRSPlugin.class) != null && MainApp.getSpecificPlugin(DanaRSPlugin.class).isEnabled(PluginType.PUMP); - if (!isRS) { - //exit if pump is not DanaRS + boolean isDanaR = MainApp.getSpecificPlugin(DanaRPlugin.class) != null && MainApp.getSpecificPlugin(DanaRPlugin.class).isEnabled(PluginType.PUMP); + boolean isDanaRv2 = MainApp.getSpecificPlugin(DanaRv2Plugin.class) != null && MainApp.getSpecificPlugin(DanaRv2Plugin.class).isEnabled(PluginType.PUMP); + if (!isRS && !isDanaR && !isDanaRv2) { + //exit if pump is not DanaRS, Dana!, or DanaR with upgraded firmware return; } + if (isDanaRv2) { + DanaRv2Plugin.getPlugin().getUserOptions(); + } DanaRPump pump = DanaRPump.getInstance(); if (timeFormat.isChecked()) @@ -143,13 +162,13 @@ public class DanaRUserOptionsActivity extends Activity { else pump.buttonScrollOnOff = 0; // step is 5 seconds - int screenTimeoutValue = (Integer.parseInt(screenTimeout.getText().toString()) / 5) * 5; + int screenTimeoutValue = !screenTimeout.getText().isEmpty() ? (Integer.parseInt(screenTimeout.getText().toString()) / 5) * 5: 5; if (screenTimeoutValue > 4 && screenTimeoutValue < 241) { pump.lcdOnTimeSec = screenTimeoutValue; } else { pump.lcdOnTimeSec = 5; } - int backlightTimeoutValue = Integer.parseInt(backlightTimeout.getText().toString()); + int backlightTimeoutValue = !backlightTimeout.getText().isEmpty() ? Integer.parseInt(backlightTimeout.getText().toString()): 1; if (backlightTimeoutValue > 0 && backlightTimeoutValue < 61) { pump.backlightOnTimeSec = backlightTimeoutValue; } @@ -158,13 +177,13 @@ public class DanaRUserOptionsActivity extends Activity { } else { pump.units = 0; } - int shutDownValue = Integer.parseInt(shutdown.getText().toString()); + int shutDownValue = !shutdown.getText().isEmpty() ? Integer.parseInt(shutdown.getText().toString()) : 0; if (shutDownValue > -1 && shutDownValue < 25) { pump.shutdownHour = shutDownValue; } else { pump.shutdownHour = 0; } - int lowReservoirValue = (Integer.parseInt(lowReservoir.getText().toString()) * 10) / 10; + int lowReservoirValue = !lowReservoir.getText().isEmpty() ? (Integer.parseInt(lowReservoir.getText().toString()) * 10) / 10 : 10; if (lowReservoirValue > 9 && lowReservoirValue < 51) { pump.lowReservoirRate = lowReservoirValue; } else diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MessageHashTable.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MessageHashTable.java index 10d2c0b091..2d15d8236f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MessageHashTable.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MessageHashTable.java @@ -56,6 +56,7 @@ public class MessageHashTable { put(new MsgSettingGlucose()); // 0x3209 CMD_SETTING_V_GLUCOSEandEASY put(new MsgSettingPumpTime()); // 0x320A CMD_SETTING_V_TIME_I put(new MsgSettingUserOptions()); // 0x320B CMD_SETTING_V_USER_OPTIONS + put(new MsgGetUserOptions()); // 0x320B CMD_SETTING_V_USER_OPTIONS - trying to get uptions put(new MsgSettingActiveProfile()); // 0x320C CMD_SETTING_V_PROFILE_NUMBER put(new MsgSettingProfileRatiosAll()); // 0x320D CMD_SETTING_V_CIR_CF_VALUE put(new MsgSetSingleBasalProfile()); // 0x3302 CMD_SETTING_BASAL_INS_S diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgGetUserOptions.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgGetUserOptions.java index 33ab6b27e9..a8aeb5e84e 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgGetUserOptions.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgGetUserOptions.java @@ -34,16 +34,17 @@ public class MsgGetUserOptions extends MessageBase { SetCommand(0x320B); } - public void handleMessage(byte[] bytes) { + public void handleMessage(byte[] packet) { DanaRPump pump = DanaRPump.getInstance(); - pump.timeDisplayType = bytes[0] == (byte) 1 ? 0 : 1; - pump.buttonScrollOnOff = bytes[1]; - pump.beepAndAlarm = bytes[2]; + byte[] bytes = getDataBytes(packet, 0, packet.length - 10); + pump.timeDisplayType = bytes[0] == (byte) 1 ? 0 : 1; // 1 -> 24h 0 -> 12h + pump.buttonScrollOnOff = bytes[1] == (byte) 1 ? 1 : 0; // 1 -> ON, 0-> OFF + pump.beepAndAlarm = bytes[2]; // 1 -> Sound on alarm 2-> Vibrate on alarm 3-> Both on alarm 5-> Sound + beep 6-> vibrate + beep 7-> both + beep Beep adds 4 pump.lcdOnTimeSec = bytes[3] & 255; pump.backlightOnTimeSec = bytes[4] & 255; - pump.selectedLanguage = bytes[5]; + pump.selectedLanguage = bytes[5]; // on DanaRv2 is that needed ? pump.units = bytes[8]; - pump.shutdownHour = bytes[9] & 255; + pump.shutdownHour = bytes[9]; pump.lowReservoirRate = bytes[32] & 255; /* int selectableLanguage1 = bytes[10]; int selectableLanguage2 = bytes[11]; @@ -52,7 +53,8 @@ public class MsgGetUserOptions extends MessageBase { int selectableLanguage5 = bytes[14]; */ - if (Config.logDanaMessageDetail) { +// if (Config.logDanaMessageDetail) { + log.debug("timeDisplayType: " + pump.timeDisplayType); log.debug("Button scroll: " + pump.buttonScrollOnOff); log.debug("BeepAndAlarm: " + pump.beepAndAlarm); @@ -62,6 +64,14 @@ public class MsgGetUserOptions extends MessageBase { log.debug("Units: " + pump.getUnits()); log.debug("Shutdown: " + pump.shutdownHour); log.debug("Low reservoir: " + pump.lowReservoirRate); +// } + } + public static byte[] getDataBytes(byte[] bytes, int start, int len) { + if (bytes == null) { + return null; } + byte[] ret = new byte[len]; + System.arraycopy(bytes, start + 6, ret, 0, len); + return ret; } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java index f7af73f13f..d88deb5f1d 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java @@ -44,15 +44,15 @@ public class MsgSettingUserOptions extends MessageBase { this.cannulaVolume = cannulaVolume; this.refillRate = refillRate; - AddParamByte((byte) timeDisplayType); - AddParamByte((byte) buttonScrollOnOff); - AddParamByte((byte) beepAndAlarm); - AddParamByte((byte) lcdOnTimeSec); - AddParamByte((byte) backlightOnTimeSec); - AddParamByte((byte) selectedLanguage); - AddParamByte((byte) glucoseUnit); - AddParamByte((byte) shutdownHour); - AddParamByte((byte) lowReservoirRate); + AddParamInt(timeDisplayType); + AddParamInt(buttonScrollOnOff); + AddParamInt(beepAndAlarm); + AddParamInt(lcdOnTimeSec); + AddParamInt(backlightOnTimeSec); + AddParamInt(selectedLanguage); + AddParamInt(glucoseUnit); + AddParamInt(shutdownHour); + AddParamInt(lowReservoirRate); } private static Logger log = LoggerFactory.getLogger(MsgSettingUserOptions.class); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/services/DanaRExecutionService.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/services/DanaRExecutionService.java index 3d4245fb2a..de7eeb1591 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/services/DanaRExecutionService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/services/DanaRExecutionService.java @@ -18,6 +18,8 @@ import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.R; import info.nightscout.androidaps.data.Profile; import info.nightscout.androidaps.data.PumpEnactResult; +import info.nightscout.androidaps.plugins.PumpDanaR.comm.MsgGetUserOptions; +import info.nightscout.androidaps.plugins.PumpDanaR.comm.MsgSettingUserOptions; import info.nightscout.androidaps.plugins.Treatments.Treatment; import info.nightscout.androidaps.events.EventAppExit; import info.nightscout.androidaps.events.EventInitializationChanged; @@ -382,6 +384,30 @@ public class DanaRExecutionService extends AbstractDanaRExecutionService{ return true; } + public PumpEnactResult getUserOptions() { + if (!isConnected()) + return new PumpEnactResult().success(false); + DanaRPump pump = DanaRPump.getInstance(); + MsgGetUserOptions msg = new MsgGetUserOptions(); + mDanaRPump.lastConnection = System.currentTimeMillis(); + return new PumpEnactResult().success(true); + } + + public PumpEnactResult updateUserOptions() { + if (!isConnected()) + return new PumpEnactResult().success(false); + DanaRPump pump = DanaRPump.getInstance(); + MsgSettingUserOptions msg = new MsgSettingUserOptions(pump.timeDisplayType, pump.buttonScrollOnOff, pump.beepAndAlarm, pump.lcdOnTimeSec, pump.backlightOnTimeSec, pump.selectedLanguage, pump.units, pump.shutdownHour, pump.lowReservoirRate, 0, 0); + + mSerialIOThread.sendMessage(msg); + while (!msg.done && mRfcommSocket.isConnected()) { + SystemClock.sleep(100); + } + SystemClock.sleep(200); + mDanaRPump.lastConnection = System.currentTimeMillis(); + return new PumpEnactResult().success(true); + } + @Subscribe public void onStatusEvent(EventAppExit event) { if (Config.logFunctionCalls) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java index 0d50e74a51..35965c8d7d 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java @@ -394,4 +394,10 @@ public class DanaRv2Plugin extends AbstractDanaRPlugin { return null; } + public PumpEnactResult getUserOptions() { + DanaRv2ExecutionService service = new DanaRv2ExecutionService(); + log.debug("MsgGetUserOptions executed!"); + return service.getUserOptions(); + } + } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java index b16312a38c..4a45765bd2 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java @@ -18,6 +18,7 @@ import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.R; import info.nightscout.androidaps.data.Profile; import info.nightscout.androidaps.data.PumpEnactResult; +import info.nightscout.androidaps.plugins.PumpDanaR.comm.MsgGetUserOptions; import info.nightscout.androidaps.plugins.PumpDanaR.comm.MsgSettingUserOptions; import info.nightscout.androidaps.plugins.Treatments.Treatment; import info.nightscout.androidaps.events.EventAppExit; @@ -200,6 +201,8 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService { mSerialIOThread.sendMessage(new MsgSettingGlucose()); mSerialIOThread.sendMessage(new MsgSettingActiveProfile()); mSerialIOThread.sendMessage(new MsgSettingProfileRatios()); + //added by Roumen for testing + mSerialIOThread.sendMessage(new MsgGetUserOptions()); mSerialIOThread.sendMessage(new MsgSettingProfileRatiosAll()); MainApp.bus().post(new EventPumpStatusChanged(MainApp.gs(R.string.gettingpumptime))); mSerialIOThread.sendMessage(new MsgSettingPumpTime()); @@ -477,7 +480,8 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService { if (!isConnected()) return new PumpEnactResult().success(false); SystemClock.sleep(300); - MsgSettingUserOptions msg; + DanaRPump pump = DanaRPump.getInstance(); + MsgSettingUserOptions msg = new MsgSettingUserOptions(pump.timeDisplayType, pump.buttonScrollOnOff, pump.beepAndAlarm, pump.lcdOnTimeSec, pump.backlightOnTimeSec, pump.selectedLanguage, pump.units, pump.shutdownHour, pump.lowReservoirRate, 0, 0); mSerialIOThread.sendMessage(msg); while (!msg.done && mRfcommSocket.isConnected()) { @@ -487,4 +491,17 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService { mDanaRPump.lastConnection = System.currentTimeMillis(); return new PumpEnactResult().success(true); } + + public PumpEnactResult getUserOptions() { + if (!isConnected()) { + log.debug("MsgGetUserOptions fails - disconnected!"); + connect(); +// return new PumpEnactResult().success(false); + } + MsgGetUserOptions msg = new MsgGetUserOptions(); +// mSerialIOThread.sendMessage(msg); // == null + mDanaRPump.lastConnection = System.currentTimeMillis(); + log.debug("MsgGetUserOptions executed!"); + return new PumpEnactResult().success(true); + } } diff --git a/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java b/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java index cad3fe379c..f0c5223ad2 100644 --- a/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java +++ b/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java @@ -1,9 +1,12 @@ package info.nightscout.androidaps.queue.commands; +import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.data.PumpEnactResult; import info.nightscout.androidaps.interfaces.DanaRInterface; +import info.nightscout.androidaps.interfaces.PluginType; import info.nightscout.androidaps.interfaces.PumpInterface; import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin; +import info.nightscout.androidaps.plugins.PumpDanaRv2.DanaRv2Plugin; import info.nightscout.androidaps.queue.Callback; /** @@ -22,6 +25,10 @@ public class CommandSetUserSettings extends Command { PumpInterface pump = ConfigBuilderPlugin.getActivePump(); if (pump instanceof DanaRInterface) { DanaRInterface danaPump = (DanaRInterface) pump; + boolean isDanaRv2 = MainApp.getSpecificPlugin(DanaRv2Plugin.class) != null && MainApp.getSpecificPlugin(DanaRv2Plugin.class).isEnabled(PluginType.PUMP); + if(isDanaRv2){ + pump.getPumpStatus(); + } PumpEnactResult r = danaPump.setUserSettings(); if (callback != null) callback.result(r).run(); From f044ab15c00d66d64c335b974146118a4a7cc3e1 Mon Sep 17 00:00:00 2001 From: Roumen Georgiev Date: Tue, 12 Jun 2018 10:39:47 +0300 Subject: [PATCH 2/5] setting swithces in activity --- .../activities/DanaRUserOptionsActivity.java | 20 +++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java index b58148ff45..328a02f0e2 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java @@ -115,7 +115,23 @@ public class DanaRUserOptionsActivity extends Activity { backlightTimeout.setParams((double) pump.backlightOnTimeSec, 1d, 60d, 1d, new DecimalFormat("1"), false); shutdown.setParams((double) pump.shutdownHour, 0d, 24d, 1d, new DecimalFormat("1"), true); lowReservoir.setParams((double) pump.lowReservoirRate, 10d, 60d, 10d, new DecimalFormat("10"), false); - + switch (pump.beepAndAlarm) { + case 1: pumpAlarmSound.setChecked(true); + break; + case 2: pumpAlarmVibrate.setChecked(true); + break; + case 3: pumpAlarmBoth.setChecked(true); + break; + case 5: pumpAlarmSound.setChecked(true); + beep.setChecked(true); + break; + case 6: pumpAlarmVibrate.setChecked(true); + beep.setChecked(true); + break; + case 7: pumpAlarmBoth.setChecked(true); + beep.setChecked(true); + break; + } if (pump.lastSettingsRead == 0) log.debug("No settings loaded from pump!"); else @@ -127,7 +143,7 @@ public class DanaRUserOptionsActivity extends Activity { timeFormat.setChecked(pump.timeDisplayType != 0); buttonScroll.setChecked(pump.buttonScrollOnOff != 0); - beep.setChecked(pump.beepAndAlarm < 5); + beep.setChecked(pump.beepAndAlarm > 4); screenTimeout.setValue((double) pump.lcdOnTimeSec); backlightTimeout.setValue((double) pump.backlightOnTimeSec); pumpUnits.setChecked(pump.getUnits() != null && pump.getUnits().equals(Constants.MMOL)); From 978d94499fd803e5490ffaf38481f0af2e1f7a07 Mon Sep 17 00:00:00 2001 From: Roumen Georgiev Date: Tue, 12 Jun 2018 11:03:23 +0300 Subject: [PATCH 3/5] update method names --- .../nightscout/androidaps/interfaces/DanaRInterface.java | 2 +- .../PumpDanaR/activities/DanaRUserOptionsActivity.java | 4 ++++ .../androidaps/plugins/PumpDanaRS/DanaRSPlugin.java | 2 +- .../androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java | 6 ++++-- .../PumpDanaRv2/services/DanaRv2ExecutionService.java | 2 +- .../androidaps/queue/commands/CommandSetUserSettings.java | 3 ++- 6 files changed, 13 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/interfaces/DanaRInterface.java b/app/src/main/java/info/nightscout/androidaps/interfaces/DanaRInterface.java index a3e26c96d8..374d96890a 100644 --- a/app/src/main/java/info/nightscout/androidaps/interfaces/DanaRInterface.java +++ b/app/src/main/java/info/nightscout/androidaps/interfaces/DanaRInterface.java @@ -9,5 +9,5 @@ import info.nightscout.androidaps.data.PumpEnactResult; public interface DanaRInterface { PumpEnactResult loadHistory(byte type); // for history browser PumpEnactResult loadEvents(); // events history to build treatments from - PumpEnactResult setUserSettings(); // like AnyDana does + PumpEnactResult setUserOptions(); // like AnyDana does } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java index 328a02f0e2..b7b7a793f4 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/activities/DanaRUserOptionsActivity.java @@ -205,6 +205,10 @@ public class DanaRUserOptionsActivity extends Activity { } else pump.lowReservoirRate = 10; + if (isDanaRv2) { + DanaRv2Plugin.getPlugin().setUserOptions(); + } + MainApp.getConfigBuilder().getCommandQueue().setUserSettings(null); finish(); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java index 299d06503e..3457564cfb 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java @@ -224,7 +224,7 @@ public class DanaRSPlugin extends PluginBase implements PumpInterface, DanaRInte } @Override - public PumpEnactResult setUserSettings() { + public PumpEnactResult setUserOptions() { return danaRSService.setUserSettings(); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java index 35965c8d7d..606b0d0c76 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java @@ -390,8 +390,10 @@ public class DanaRv2Plugin extends AbstractDanaRPlugin { } @Override - public PumpEnactResult setUserSettings() { - return null; + public PumpEnactResult setUserOptions() { + DanaRv2ExecutionService service = new DanaRv2ExecutionService(); + log.debug("MsgSetingUserOptions executed!"); + return service.setUserOptions(); } public PumpEnactResult getUserOptions() { diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java index 4a45765bd2..5eab684bbd 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java @@ -476,7 +476,7 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService { } } - public PumpEnactResult updateUserSettings() { + public PumpEnactResult setUserOptions() { if (!isConnected()) return new PumpEnactResult().success(false); SystemClock.sleep(300); diff --git a/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java b/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java index f0c5223ad2..357c766652 100644 --- a/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java +++ b/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java @@ -28,8 +28,9 @@ public class CommandSetUserSettings extends Command { boolean isDanaRv2 = MainApp.getSpecificPlugin(DanaRv2Plugin.class) != null && MainApp.getSpecificPlugin(DanaRv2Plugin.class).isEnabled(PluginType.PUMP); if(isDanaRv2){ pump.getPumpStatus(); + danaPump.setUserOptions(); } - PumpEnactResult r = danaPump.setUserSettings(); + PumpEnactResult r = danaPump.setUserOptions(); if (callback != null) callback.result(r).run(); } From 06507bab2cc7815ef8afea0f8acbfa77522ee619 Mon Sep 17 00:00:00 2001 From: Roumen Georgiev Date: Tue, 12 Jun 2018 12:41:40 +0300 Subject: [PATCH 4/5] update method names --- .../plugins/PumpDanaR/DanaRPlugin.java | 2 +- .../PumpDanaR/comm/MsgSettingUserOptions.java | 25 ++++++++----------- .../PumpDanaRKorean/DanaRKoreanPlugin.java | 2 +- .../plugins/PumpDanaRv2/DanaRv2Plugin.java | 2 +- .../services/DanaRv2ExecutionService.java | 13 +++++++--- .../commands/CommandSetUserSettings.java | 8 +++--- 6 files changed, 29 insertions(+), 23 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java index c2143ad9ec..69c07ce706 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java @@ -381,7 +381,7 @@ public class DanaRPlugin extends AbstractDanaRPlugin { } @Override - public PumpEnactResult setUserSettings() { + public PumpEnactResult setUserOptions() { return null; } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java index d88deb5f1d..56a71d00f0 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java @@ -4,11 +4,6 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import info.nightscout.androidaps.Config; -import info.nightscout.androidaps.MainApp; -import info.nightscout.androidaps.R; -import info.nightscout.androidaps.plugins.Overview.events.EventNewNotification; -import info.nightscout.androidaps.plugins.Overview.notifications.Notification; -import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPump; /** * Created by mike on 05.07.2016. @@ -32,6 +27,7 @@ public class MsgSettingUserOptions extends MessageBase { public MsgSettingUserOptions(int timeDisplayType, int buttonScrollOnOff, int beepAndAlarm, int lcdOnTimeSec, int backlightOnTimeSec, int selectedLanguage, int glucoseUnit, int shutdownHour, int lowReservoirRate, int cannulaVolume, int refillRate) { this(); + log.debug(" initializing MsgSetUserOptions"); this.timeDisplayType = timeDisplayType; this.buttonScrollOnOff = buttonScrollOnOff; this.beepAndAlarm = beepAndAlarm; @@ -44,15 +40,15 @@ public class MsgSettingUserOptions extends MessageBase { this.cannulaVolume = cannulaVolume; this.refillRate = refillRate; - AddParamInt(timeDisplayType); - AddParamInt(buttonScrollOnOff); - AddParamInt(beepAndAlarm); - AddParamInt(lcdOnTimeSec); - AddParamInt(backlightOnTimeSec); - AddParamInt(selectedLanguage); - AddParamInt(glucoseUnit); - AddParamInt(shutdownHour); - AddParamInt(lowReservoirRate); + AddParamByte((byte) timeDisplayType); + AddParamByte((byte) buttonScrollOnOff); + AddParamByte((byte) beepAndAlarm); + AddParamByte((byte) lcdOnTimeSec); + AddParamByte((byte) backlightOnTimeSec); + AddParamByte((byte) selectedLanguage); + AddParamByte((byte) glucoseUnit); + AddParamByte((byte) shutdownHour); + AddParamByte((byte) lowReservoirRate); } private static Logger log = LoggerFactory.getLogger(MsgSettingUserOptions.class); @@ -62,6 +58,7 @@ public class MsgSettingUserOptions extends MessageBase { } public void handleMessage(byte[] bytes) { + log.debug("Entering handleMessage "); int result = intFromBuff(bytes, 0, 1); if (result != 1) { failed = true; diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java index 59430b8793..b7b100a3a6 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java @@ -382,7 +382,7 @@ public class DanaRKoreanPlugin extends AbstractDanaRPlugin { } @Override - public PumpEnactResult setUserSettings() { + public PumpEnactResult setUserOptions() { return null; } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java index 606b0d0c76..83d6b24a6b 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java @@ -392,7 +392,7 @@ public class DanaRv2Plugin extends AbstractDanaRPlugin { @Override public PumpEnactResult setUserOptions() { DanaRv2ExecutionService service = new DanaRv2ExecutionService(); - log.debug("MsgSetingUserOptions executed!"); + log.debug("MsgSetUserOptions executed!"); return service.setUserOptions(); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java index 5eab684bbd..0b646fde48 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/services/DanaRv2ExecutionService.java @@ -477,12 +477,19 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService { } public PumpEnactResult setUserOptions() { - if (!isConnected()) - return new PumpEnactResult().success(false); + if (!isConnected()) { + log.debug("MsgSetUserOptions - service is not connected"); +// return new PumpEnactResult().success(false); + connect(); + } SystemClock.sleep(300); DanaRPump pump = DanaRPump.getInstance(); MsgSettingUserOptions msg = new MsgSettingUserOptions(pump.timeDisplayType, pump.buttonScrollOnOff, pump.beepAndAlarm, pump.lcdOnTimeSec, pump.backlightOnTimeSec, pump.selectedLanguage, pump.units, pump.shutdownHour, pump.lowReservoirRate, 0, 0); - + if (mSerialIOThread != null) { + mSerialIOThread.disconnect("MsgSetUserOptions - Recreate SerialIOThread"); + } + mSerialIOThread = new SerialIOThread(mRfcommSocket); + MainApp.bus().post(new EventPumpStatusChanged(EventPumpStatusChanged.CONNECTED, 0)); mSerialIOThread.sendMessage(msg); while (!msg.done && mRfcommSocket.isConnected()) { SystemClock.sleep(100); diff --git a/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java b/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java index 357c766652..f3d9fe2a4b 100644 --- a/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java +++ b/app/src/main/java/info/nightscout/androidaps/queue/commands/CommandSetUserSettings.java @@ -1,5 +1,8 @@ package info.nightscout.androidaps.queue.commands; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.data.PumpEnactResult; import info.nightscout.androidaps.interfaces.DanaRInterface; @@ -14,7 +17,7 @@ import info.nightscout.androidaps.queue.Callback; */ public class CommandSetUserSettings extends Command { - + private static Logger log = LoggerFactory.getLogger(CommandSetUserSettings.class); public CommandSetUserSettings(Callback callback) { commandType = CommandType.SETUSERSETTINGS; this.callback = callback; @@ -27,8 +30,7 @@ public class CommandSetUserSettings extends Command { DanaRInterface danaPump = (DanaRInterface) pump; boolean isDanaRv2 = MainApp.getSpecificPlugin(DanaRv2Plugin.class) != null && MainApp.getSpecificPlugin(DanaRv2Plugin.class).isEnabled(PluginType.PUMP); if(isDanaRv2){ - pump.getPumpStatus(); - danaPump.setUserOptions(); + log.debug("MsgSetUserOptions detected for DanaRv2"); } PumpEnactResult r = danaPump.setUserOptions(); if (callback != null) From 1adf8718ae59cda647f5e1d900e923eb9528bae0 Mon Sep 17 00:00:00 2001 From: Roumen Georgiev Date: Tue, 12 Jun 2018 13:30:07 +0300 Subject: [PATCH 5/5] more debugging output --- .../plugins/PumpDanaR/comm/MsgGetUserOptions.java | 3 +++ .../PumpDanaR/comm/MsgSettingUserOptions.java | 12 +++++++++++- 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgGetUserOptions.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgGetUserOptions.java index a8aeb5e84e..aeffbd66df 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgGetUserOptions.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgGetUserOptions.java @@ -37,6 +37,9 @@ public class MsgGetUserOptions extends MessageBase { public void handleMessage(byte[] packet) { DanaRPump pump = DanaRPump.getInstance(); byte[] bytes = getDataBytes(packet, 0, packet.length - 10); + for(int pos=0; pos < bytes.length; pos++) { + log.debug("[" + pos + "]" + bytes[pos]); + } pump.timeDisplayType = bytes[0] == (byte) 1 ? 0 : 1; // 1 -> 24h 0 -> 12h pump.buttonScrollOnOff = bytes[1] == (byte) 1 ? 1 : 0; // 1 -> ON, 0-> OFF pump.beepAndAlarm = bytes[2]; // 1 -> Sound on alarm 2-> Vibrate on alarm 3-> Both on alarm 5-> Sound + beep 6-> vibrate + beep 7-> both + beep Beep adds 4 diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java index 56a71d00f0..48a4493f28 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/comm/MsgSettingUserOptions.java @@ -28,6 +28,15 @@ public class MsgSettingUserOptions extends MessageBase { public MsgSettingUserOptions(int timeDisplayType, int buttonScrollOnOff, int beepAndAlarm, int lcdOnTimeSec, int backlightOnTimeSec, int selectedLanguage, int glucoseUnit, int shutdownHour, int lowReservoirRate, int cannulaVolume, int refillRate) { this(); log.debug(" initializing MsgSetUserOptions"); + log.debug("timeDisplayType: " + (byte) timeDisplayType); + log.debug("Button scroll: " + (byte) buttonScrollOnOff); + log.debug("BeepAndAlarm: " + (byte) beepAndAlarm); + log.debug("screen timeout: " + (byte) lcdOnTimeSec); + log.debug("Backlight: " + (byte) backlightOnTimeSec); + log.debug("Selected language: " + (byte) selectedLanguage); + log.debug("Units: " + (byte) glucoseUnit); + log.debug("Shutdown: " + (byte) shutdownHour); + log.debug("Low reservoir: " + (byte) lowReservoirRate); this.timeDisplayType = timeDisplayType; this.buttonScrollOnOff = buttonScrollOnOff; this.beepAndAlarm = beepAndAlarm; @@ -39,7 +48,8 @@ public class MsgSettingUserOptions extends MessageBase { this.lowReservoirRate = lowReservoirRate; this.cannulaVolume = cannulaVolume; this.refillRate = refillRate; - + // need to organize here + // glucoseunit is at pos 8 and lowReservoirRate is at pos 27 AddParamByte((byte) timeDisplayType); AddParamByte((byte) buttonScrollOnOff); AddParamByte((byte) beepAndAlarm);