Some work around refreshing pump data.
This commit is contained in:
parent
e9d3e90758
commit
a17cff7adf
1 changed files with 41 additions and 37 deletions
|
@ -7,6 +7,7 @@ import org.json.JSONObject;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
@ -83,6 +84,8 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
}
|
}
|
||||||
|
|
||||||
private void definePumpCapabilities() {
|
private void definePumpCapabilities() {
|
||||||
|
// these properties are static; they can't be changed on the pump, but only via
|
||||||
|
// desktop configuration software
|
||||||
pumpDescription.isBolusCapable = true;
|
pumpDescription.isBolusCapable = true;
|
||||||
pumpDescription.bolusStep = 0.1d;
|
pumpDescription.bolusStep = 0.1d;
|
||||||
|
|
||||||
|
@ -135,7 +138,9 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
|
|
||||||
String getStateSummary() {
|
String getStateSummary() {
|
||||||
PumpState ps = pump.state;
|
PumpState ps = pump.state;
|
||||||
if (ps.menu == null)
|
if (!pump.initialized) {
|
||||||
|
return MainApp.sResources.getString(R.string.combo_pump_state_initializing);
|
||||||
|
} else if (ps.menu == null)
|
||||||
return MainApp.sResources.getString(R.string.combo_pump_state_disconnected);
|
return MainApp.sResources.getString(R.string.combo_pump_state_disconnected);
|
||||||
else if (ps.suspended && (ps.batteryState == PumpState.EMPTY || ps.insulinState == PumpState.EMPTY))
|
else if (ps.suspended && (ps.batteryState == PumpState.EMPTY || ps.insulinState == PumpState.EMPTY))
|
||||||
return MainApp.sResources.getString(R.string.combo_pump_state_suspended_due_to_error);
|
return MainApp.sResources.getString(R.string.combo_pump_state_suspended_due_to_error);
|
||||||
|
@ -241,19 +246,28 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO reading profile, set clock; periodically and forced at startup (by setting/having profile/stateLastRead be 0
|
CommandResult stateResult = runCommand("Refreshing", 3, ruffyScripter::readReservoirLevelAndLastBolus);
|
||||||
CommandResult result = runCommand("Refreshing", 3, ruffyScripter::readReservoirLevelAndLastBolus);
|
checkForTbrMismatch(stateResult.state);
|
||||||
updateLocalData(result);
|
|
||||||
if (result.success)
|
int minutesOfDayNow = Calendar.getInstance().get(Calendar.HOUR) + Calendar.getInstance().get(Calendar.MINUTE) * 60;
|
||||||
pump.initialized = true;
|
if (!pump.initialized || (Math.abs(stateResult.state.pumpTimeMinutesOfDay - minutesOfDayNow) >= 2)) {
|
||||||
|
runCommand("Updating pump clock", 2, ruffyScripter::setDateAndTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!pump.initialized) {
|
||||||
|
runCommand("Reading basal profile", 2, ruffyScripter::readBasalProfile);
|
||||||
|
}
|
||||||
|
|
||||||
// TODO fuse the below into 'sync'? or make checkForTbrMismatch jut a trigger to issue a sync if needed; don't run sync twice as is nice
|
|
||||||
// checkForTbrMismatch();
|
|
||||||
checkPumpHistory();
|
checkPumpHistory();
|
||||||
// checkPumpDate()
|
|
||||||
|
|
||||||
|
// if (!pump.initialized) {
|
||||||
|
// pump.initialized = clockUpdated && basalProfileRead;
|
||||||
|
// }
|
||||||
|
pump.initialized = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// TODO currently testing if updating this after each command works well
|
||||||
private void updateLocalData(CommandResult result) {
|
private void updateLocalData(CommandResult result) {
|
||||||
if (result.reservoirLevel != PumpState.UNKNOWN) {
|
if (result.reservoirLevel != PumpState.UNKNOWN) {
|
||||||
pump.reservoirLevel = result.reservoirLevel;
|
pump.reservoirLevel = result.reservoirLevel;
|
||||||
|
@ -422,11 +436,6 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
comment(MainApp.sResources.getString(R.string.combo_pump_bolus_verification_failed));
|
comment(MainApp.sResources.getString(R.string.combo_pump_bolus_verification_failed));
|
||||||
}
|
}
|
||||||
|
|
||||||
// update local data
|
|
||||||
pump.reservoirLevel = reservoirBolusResult.reservoirLevel;
|
|
||||||
pump.lastBolus = lastPumpBolus;
|
|
||||||
pump.state = reservoirBolusResult.state;
|
|
||||||
|
|
||||||
// add treatment record to DB (if it wasn't cancelled)
|
// add treatment record to DB (if it wasn't cancelled)
|
||||||
if (lastPumpBolus != null && (lastPumpBolus.amount > 0)) {
|
if (lastPumpBolus != null && (lastPumpBolus.amount > 0)) {
|
||||||
detailedBolusInfo.insulin = lastPumpBolus.amount;
|
detailedBolusInfo.insulin = lastPumpBolus.amount;
|
||||||
|
@ -510,7 +519,6 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
ConfigBuilderPlugin treatmentsInterface = MainApp.getConfigBuilder();
|
ConfigBuilderPlugin treatmentsInterface = MainApp.getConfigBuilder();
|
||||||
treatmentsInterface.addToHistoryTempBasal(tempStart);
|
treatmentsInterface.addToHistoryTempBasal(tempStart);
|
||||||
|
|
||||||
pump.state = commandResult.state;
|
|
||||||
pump.tbrSetTime = state.timestamp;
|
pump.tbrSetTime = state.timestamp;
|
||||||
MainApp.bus().post(new EventComboPumpUpdateGUI());
|
MainApp.bus().post(new EventComboPumpUpdateGUI());
|
||||||
}
|
}
|
||||||
|
@ -536,7 +544,7 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
PumpEnactResult pumpEnactResult = new PumpEnactResult();
|
PumpEnactResult pumpEnactResult = new PumpEnactResult();
|
||||||
|
|
||||||
final TemporaryBasal activeTemp = MainApp.getConfigBuilder().getTempBasalFromHistory(System.currentTimeMillis());
|
final TemporaryBasal activeTemp = MainApp.getConfigBuilder().getTempBasalFromHistory(System.currentTimeMillis());
|
||||||
checkForTbrMismatch();
|
// checkForTbrMismatch();
|
||||||
|
|
||||||
if (activeTemp == null || userRequested) {
|
if (activeTemp == null || userRequested) {
|
||||||
/* v1 compatibility to sync DB to pump if they diverged (activeTemp == null) */
|
/* v1 compatibility to sync DB to pump if they diverged (activeTemp == null) */
|
||||||
|
@ -600,6 +608,8 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
CommandResult execute();
|
CommandResult execute();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO remove this method, make stuff explicit (state updates, activity updates)
|
||||||
|
// and only have a withRetries() method that simply retries a command?
|
||||||
/**
|
/**
|
||||||
* Runs a command, sets an activity if provided, retries if requested and updates fields
|
* Runs a command, sets an activity if provided, retries if requested and updates fields
|
||||||
* concerned with last connection.
|
* concerned with last connection.
|
||||||
|
@ -627,6 +637,10 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (commandResult.success) {
|
||||||
|
updateLocalData(commandResult);
|
||||||
|
}
|
||||||
|
|
||||||
checkForUnsupportedBoluses(commandResult);
|
checkForUnsupportedBoluses(commandResult);
|
||||||
|
|
||||||
pump.lastCmdResult = commandResult;
|
pump.lastCmdResult = commandResult;
|
||||||
|
@ -674,9 +688,8 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO rename to checkState or so and also check time (& date) of pump
|
/** Checks the main screen to determine if TBR on pump matches app state. */
|
||||||
// implicit param 'pump'
|
private boolean checkForTbrMismatch(PumpState state) {
|
||||||
private void checkForTbrMismatch() {
|
|
||||||
// detectTbrMismatch(): 'quick' check with no overhead on the pump side
|
// detectTbrMismatch(): 'quick' check with no overhead on the pump side
|
||||||
// TODO check if this works with pump suspend, esp. around pump suspend there'll be syncing to do;
|
// TODO check if this works with pump suspend, esp. around pump suspend there'll be syncing to do;
|
||||||
|
|
||||||
|
@ -685,24 +698,24 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
|
|
||||||
TemporaryBasal aapsTbr = MainApp.getConfigBuilder().getTempBasalFromHistory(System.currentTimeMillis());
|
TemporaryBasal aapsTbr = MainApp.getConfigBuilder().getTempBasalFromHistory(System.currentTimeMillis());
|
||||||
boolean sync = false;
|
boolean sync = false;
|
||||||
if (aapsTbr == null && pump.state.tbrActive) {
|
if (aapsTbr == null && state.tbrActive) {
|
||||||
// pump runs TBR AAPS is unaware off
|
// pump runs TBR AAPS is unaware off
|
||||||
log.debug("Pump runs TBR AAPS is unaware of, reading last 3h of pump TBR history");
|
log.debug("Pump runs TBR AAPS is unaware of, reading last 3h of pump TBR history");
|
||||||
sync = true;
|
sync = true;
|
||||||
} else if (aapsTbr != null && !pump.state.tbrActive) {
|
} else if (aapsTbr != null && !state.tbrActive) {
|
||||||
// AAPS has a TBR but the pump isn't running a TBR
|
// AAPS has a TBR but the pump isn't running a TBR
|
||||||
log.debug("AAPS shows TBR but pump isn't running a TBR; deleting TBR in AAPS and reading last 3h of pump TBR history");
|
log.debug("AAPS shows TBR but pump isn't running a TBR; deleting TBR in AAPS and reading last 3h of pump TBR history");
|
||||||
MainApp.getDbHelper().delete(aapsTbr);
|
MainApp.getDbHelper().delete(aapsTbr);
|
||||||
sync = true;
|
sync = true;
|
||||||
} else if (aapsTbr != null && pump.state.tbrActive) {
|
} else if (aapsTbr != null && state.tbrActive) {
|
||||||
// both AAPS and pump have a TBR ...
|
// both AAPS and pump have a TBR ...
|
||||||
if (aapsTbr.percentRate != pump.state.tbrPercent) {
|
if (aapsTbr.percentRate != state.tbrPercent) {
|
||||||
// ... but they have different percentages
|
// ... but they have different percentages
|
||||||
log.debug("TBR percentage differs between AAPS and pump; deleting TBR in AAPS and reading last 3h of pump TBR history");
|
log.debug("TBR percentage differs between AAPS and pump; deleting TBR in AAPS and reading last 3h of pump TBR history");
|
||||||
MainApp.getDbHelper().delete(aapsTbr);
|
MainApp.getDbHelper().delete(aapsTbr);
|
||||||
sync = true;
|
sync = true;
|
||||||
}
|
}
|
||||||
int durationDiff = Math.abs(aapsTbr.getPlannedRemainingMinutes() - pump.state.tbrRemainingDuration);
|
int durationDiff = Math.abs(aapsTbr.getPlannedRemainingMinutes() - state.tbrRemainingDuration);
|
||||||
if (durationDiff > 2) {
|
if (durationDiff > 2) {
|
||||||
// ... but they have different runtimes
|
// ... but they have different runtimes
|
||||||
log.debug("TBR duration differs between AAPS and pump; deleting TBR in AAPS and reading last 3h of pump TBR history");
|
log.debug("TBR duration differs between AAPS and pump; deleting TBR in AAPS and reading last 3h of pump TBR history");
|
||||||
|
@ -710,15 +723,8 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
sync = true;
|
sync = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (sync) {
|
|
||||||
// todo just return the PHR?
|
|
||||||
syncHistory(new PumpHistoryRequest().tbrHistory(System.currentTimeMillis() - 3 * 60 * 60 * 1000));
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO request a loop run to (re)apply a TBR/SMB given this new information? or just wait till next iteration?
|
|
||||||
// could take 15m or so if there are missed SGVs ...
|
|
||||||
// new sensitivity calc required, no?
|
|
||||||
|
|
||||||
|
return sync;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -833,18 +839,16 @@ public class ComboPlugin implements PluginBase, PumpInterface, ConstraintsInterf
|
||||||
// tdd
|
// tdd
|
||||||
// TODO v3
|
// TODO v3
|
||||||
|
|
||||||
CommandResult refreshResult = runCommand("Refreshing", 3, ruffyScripter::readReservoirLevelAndLastBolus);
|
// fetch state (updates local state as well)
|
||||||
updateLocalData(refreshResult);
|
runCommand(null, 3, ruffyScripter::readReservoirLevelAndLastBolus);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void forceSyncFullHistory() {
|
void forceSyncFullHistory() {
|
||||||
syncHistory(new PumpHistoryRequest()
|
syncHistory(new PumpHistoryRequest()
|
||||||
.bolusHistory(PumpHistoryRequest.FULL)
|
.bolusHistory(PumpHistoryRequest.FULL)
|
||||||
.tbrHistory(PumpHistoryRequest.FULL)
|
.tbrHistory(PumpHistoryRequest.FULL)
|
||||||
.errorHistory(PumpHistoryRequest.FULL)
|
.errorHistory(PumpHistoryRequest.FULL)
|
||||||
.tddHistory(PumpHistoryRequest.FULL));
|
.tddHistory(PumpHistoryRequest.FULL));
|
||||||
updateLocalData(runCommand(MainApp.sResources.getString(R.string.combo_pump_action_refreshing),
|
|
||||||
3, ruffyScripter::readPumpState));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in a new issue