upload pump status without loop too

This commit is contained in:
Milos Kozak 2016-07-15 23:18:31 +02:00
parent cd86476d6a
commit b69dc35716
4 changed files with 45 additions and 29 deletions

View file

@ -37,7 +37,7 @@
<ConfirmationsSetting value="0" id="Add" /> <ConfirmationsSetting value="0" id="Add" />
<ConfirmationsSetting value="0" id="Remove" /> <ConfirmationsSetting value="0" id="Remove" />
</component> </component>
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_7" default="true" assert-keyword="true" jdk-15="true" project-jdk-name="1.8" project-jdk-type="JavaSDK"> <component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" default="true" assert-keyword="true" jdk-15="true" project-jdk-name="1.8" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/build/classes" /> <output url="file://$PROJECT_DIR$/build/classes" />
</component> </component>
<component name="ProjectType"> <component name="ProjectType">

View file

@ -23,8 +23,8 @@ android {
applicationId "info.nightscout.androidaps" applicationId "info.nightscout.androidaps"
minSdkVersion 21 minSdkVersion 21
targetSdkVersion 23 targetSdkVersion 23
versionCode 1007 versionCode 1008
versionName "1.0.07" versionName "1.0.08"
} }
buildTypes { buildTypes {
release { release {

View file

@ -19,6 +19,8 @@ import android.widget.ListAdapter;
import android.widget.ListView; import android.widget.ListView;
import android.widget.TextView; import android.widget.TextView;
import com.squareup.otto.Subscribe;
import org.json.JSONException; import org.json.JSONException;
import org.json.JSONObject; import org.json.JSONObject;
import org.slf4j.Logger; import org.slf4j.Logger;
@ -37,6 +39,7 @@ import info.nightscout.androidaps.Services.Intents;
import info.nightscout.androidaps.data.PumpEnactResult; import info.nightscout.androidaps.data.PumpEnactResult;
import info.nightscout.androidaps.db.TempBasal; import info.nightscout.androidaps.db.TempBasal;
import info.nightscout.androidaps.db.Treatment; import info.nightscout.androidaps.db.Treatment;
import info.nightscout.androidaps.events.EventNewBG;
import info.nightscout.androidaps.events.EventRefreshGui; import info.nightscout.androidaps.events.EventRefreshGui;
import info.nightscout.androidaps.events.EventTempBasalChange; import info.nightscout.androidaps.events.EventTempBasalChange;
import info.nightscout.androidaps.events.EventTreatmentChange; import info.nightscout.androidaps.events.EventTreatmentChange;
@ -97,6 +100,8 @@ public class ConfigBuilderFragment extends Fragment implements PluginBase, PumpI
ArrayList<PluginBase> pluginList; ArrayList<PluginBase> pluginList;
Date lastDeviceStatusUpload = new Date(0);
// TODO: sorting // TODO: sorting
// TODO: Toast and sound when command failed // TODO: Toast and sound when command failed
@ -571,6 +576,7 @@ public class ConfigBuilderFragment extends Fragment implements PluginBase, PumpI
case PluginBase.APS: case PluginBase.APS:
case PluginBase.GENERAL: case PluginBase.GENERAL:
case PluginBase.CONSTRAINTS: case PluginBase.CONSTRAINTS:
case PluginBase.LOOP:
break; break;
// Single selection allowed // Single selection allowed
case PluginBase.PROFILE: case PluginBase.PROFILE:
@ -579,7 +585,6 @@ public class ConfigBuilderFragment extends Fragment implements PluginBase, PumpI
case PluginBase.BGSOURCE: case PluginBase.BGSOURCE:
pluginsInCategory = MainActivity.getSpecificPluginsListByInterface(BgSourceInterface.class); pluginsInCategory = MainActivity.getSpecificPluginsListByInterface(BgSourceInterface.class);
break; break;
case PluginBase.LOOP:
case PluginBase.TEMPBASAL: case PluginBase.TEMPBASAL:
case PluginBase.TREATMENT: case PluginBase.TREATMENT:
case PluginBase.PUMP: case PluginBase.PUMP:
@ -872,6 +877,20 @@ public class ConfigBuilderFragment extends Fragment implements PluginBase, PumpI
return maxIobAfterConstrain; return maxIobAfterConstrain;
} }
@Subscribe
public void onStatusEvent(final EventNewBG ev) {
// Give some time to Loop
try {
Thread.sleep(120* 1000L);
} catch (InterruptedException e) {
e.printStackTrace();
}
// if status not uploaded, upload pump status only
if (new Date().getTime() - lastDeviceStatusUpload.getTime() > 120 * 1000L) {
uploadDeviceStatus();
}
}
public static void uploadTempBasalStartAbsolute(Double absolute, double durationInMinutes) { public static void uploadTempBasalStartAbsolute(Double absolute, double durationInMinutes) {
try { try {
Context context = MainApp.instance().getApplicationContext(); Context context = MainApp.instance().getApplicationContext();
@ -972,10 +991,8 @@ public class ConfigBuilderFragment extends Fragment implements PluginBase, PumpI
DeviceStatus deviceStatus = new DeviceStatus(); DeviceStatus deviceStatus = new DeviceStatus();
try { try {
LoopFragment.LastRun lastRun = LoopFragment.lastRun; LoopFragment.LastRun lastRun = LoopFragment.lastRun;
if (lastRun == null) return; if (lastRun != null && lastRun.lastAPSRun.getTime() > new Date().getTime() - 60 * 1000L) {
if (lastRun.lastAPSRun.getTime() < new Date().getTime() - 60 * 1000L) // do not send if result is older than 1 min
return; // do not send if result is older than 1 min
APSResult apsResult = lastRun.request; APSResult apsResult = lastRun.request;
apsResult.json().put("timestamp", DateUtil.toISOString(lastRun.lastAPSRun)); apsResult.json().put("timestamp", DateUtil.toISOString(lastRun.lastAPSRun));
deviceStatus.suggested = apsResult.json(); deviceStatus.suggested = apsResult.json();
@ -997,13 +1014,14 @@ public class ConfigBuilderFragment extends Fragment implements PluginBase, PumpI
requested.put("temp", "absolute"); requested.put("temp", "absolute");
deviceStatus.enacted.put("requested", requested); deviceStatus.enacted.put("requested", requested);
} }
}
deviceStatus.device = "openaps://" + getActivePump().deviceID(); deviceStatus.device = "openaps://" + getActivePump().deviceID();
deviceStatus.pump = getActivePump().getJSONStatus(); deviceStatus.pump = getActivePump().getJSONStatus();
deviceStatus.created_at = DateUtil.toISOString(new Date()); deviceStatus.created_at = DateUtil.toISOString(new Date());
deviceStatus.sendToNSClient(); deviceStatus.sendToNSClient();
lastDeviceStatusUpload = new Date();
} catch (JSONException e) { } catch (JSONException e) {
e.printStackTrace(); e.printStackTrace();
} }

View file

@ -50,8 +50,6 @@ public class VirtualPumpFragment extends Fragment implements PluginBase, PumpInt
boolean fragmentVisible = true; boolean fragmentVisible = true;
boolean visibleNow = false; boolean visibleNow = false;
// TODO: upload pump status without Loop plugin too
@Override @Override
public String getName() { public String getName() {
return MainApp.instance().getString(R.string.virtualpump); return MainApp.instance().getString(R.string.virtualpump);