keep alive dagger
This commit is contained in:
parent
1eb375af09
commit
fa8197f7f9
2 changed files with 17 additions and 22 deletions
|
@ -179,6 +179,7 @@ public class MainApp extends DaggerApplication {
|
||||||
@Inject VirtualPumpPlugin virtualPumpPlugin;
|
@Inject VirtualPumpPlugin virtualPumpPlugin;
|
||||||
@Inject VersionCheckerPlugin versionCheckerPlugin;
|
@Inject VersionCheckerPlugin versionCheckerPlugin;
|
||||||
@Inject WearPlugin wearPlugin;
|
@Inject WearPlugin wearPlugin;
|
||||||
|
@Inject KeepAliveReceiver.KeepAliveManager keepAliveManager;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate() {
|
public void onCreate() {
|
||||||
|
@ -302,7 +303,7 @@ public class MainApp extends DaggerApplication {
|
||||||
}).start();
|
}).start();
|
||||||
}
|
}
|
||||||
|
|
||||||
new Thread(() -> KeepAliveReceiver.setAlarm(this)).start();
|
new Thread(() -> keepAliveManager.setAlarm(this)).start();
|
||||||
doMigrations();
|
doMigrations();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -508,7 +509,7 @@ public class MainApp extends DaggerApplication {
|
||||||
if (timeDateOrTZChangeReceiver != null)
|
if (timeDateOrTZChangeReceiver != null)
|
||||||
unregisterReceiver(timeDateOrTZChangeReceiver);
|
unregisterReceiver(timeDateOrTZChangeReceiver);
|
||||||
unregisterActivityLifecycleCallbacks(activityMonitor);
|
unregisterActivityLifecycleCallbacks(activityMonitor);
|
||||||
KeepAliveReceiver.cancelAlarm(this);
|
keepAliveManager.cancelAlarm(this);
|
||||||
super.onTerminate();
|
super.onTerminate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@ import info.nightscout.androidaps.Config
|
||||||
import info.nightscout.androidaps.db.DatabaseHelper
|
import info.nightscout.androidaps.db.DatabaseHelper
|
||||||
import info.nightscout.androidaps.events.EventProfileNeedsUpdate
|
import info.nightscout.androidaps.events.EventProfileNeedsUpdate
|
||||||
import info.nightscout.androidaps.logging.AAPSLogger
|
import info.nightscout.androidaps.logging.AAPSLogger
|
||||||
import info.nightscout.androidaps.logging.L
|
import info.nightscout.androidaps.logging.LTag
|
||||||
import info.nightscout.androidaps.plugins.aps.loop.LoopPlugin
|
import info.nightscout.androidaps.plugins.aps.loop.LoopPlugin
|
||||||
import info.nightscout.androidaps.plugins.bus.RxBusWrapper
|
import info.nightscout.androidaps.plugins.bus.RxBusWrapper
|
||||||
import info.nightscout.androidaps.plugins.configBuilder.ConfigBuilderPlugin
|
import info.nightscout.androidaps.plugins.configBuilder.ConfigBuilderPlugin
|
||||||
|
@ -23,7 +23,6 @@ import info.nightscout.androidaps.utils.DateUtil
|
||||||
import info.nightscout.androidaps.utils.FabricPrivacy
|
import info.nightscout.androidaps.utils.FabricPrivacy
|
||||||
import info.nightscout.androidaps.utils.LocalAlertUtils
|
import info.nightscout.androidaps.utils.LocalAlertUtils
|
||||||
import info.nightscout.androidaps.utils.T
|
import info.nightscout.androidaps.utils.T
|
||||||
import org.slf4j.LoggerFactory
|
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
import kotlin.math.abs
|
import kotlin.math.abs
|
||||||
|
|
||||||
|
@ -40,8 +39,7 @@ class KeepAliveReceiver : DaggerBroadcastReceiver() {
|
||||||
|
|
||||||
override fun onReceive(context: Context, intent: Intent) {
|
override fun onReceive(context: Context, intent: Intent) {
|
||||||
super.onReceive(context, intent)
|
super.onReceive(context, intent)
|
||||||
if (L.isEnabled(L.CORE))
|
aapsLogger.debug(LTag.CORE, "KeepAlive received");
|
||||||
log.debug("KeepAlive received")
|
|
||||||
val pm = context.getSystemService(Context.POWER_SERVICE) as PowerManager
|
val pm = context.getSystemService(Context.POWER_SERVICE) as PowerManager
|
||||||
val wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "AndroidAPS:KeepAliveReceiver")
|
val wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "AndroidAPS:KeepAliveReceiver")
|
||||||
wl.acquire(T.mins(2).msecs())
|
wl.acquire(T.mins(2).msecs())
|
||||||
|
@ -52,18 +50,10 @@ class KeepAliveReceiver : DaggerBroadcastReceiver() {
|
||||||
wl.release()
|
wl.release()
|
||||||
}
|
}
|
||||||
|
|
||||||
companion object {
|
class KeepAliveManager @Inject constructor(val aapsLogger: AAPSLogger) {
|
||||||
private val log = LoggerFactory.getLogger(L.CORE)
|
|
||||||
|
|
||||||
private val KEEP_ALIVE_MILLISECONDS = T.mins(5).msecs()
|
|
||||||
private val STATUS_UPDATE_FREQUENCY = T.mins(15).msecs()
|
|
||||||
private val IOB_UPDATE_FREQUENCY = T.mins(5).msecs()
|
|
||||||
|
|
||||||
//called by MainApp at first app start
|
//called by MainApp at first app start
|
||||||
@JvmStatic
|
|
||||||
fun setAlarm(context: Context) {
|
fun setAlarm(context: Context) {
|
||||||
if (L.isEnabled(L.CORE))
|
aapsLogger.debug(LTag.CORE, "KeepAlive scheduled")
|
||||||
log.debug("KeepAlive scheduled")
|
|
||||||
SystemClock.sleep(5000) // wait for app initialization
|
SystemClock.sleep(5000) // wait for app initialization
|
||||||
LocalAlertUtils.shortenSnoozeInterval()
|
LocalAlertUtils.shortenSnoozeInterval()
|
||||||
LocalAlertUtils.presnoozeAlarms()
|
LocalAlertUtils.presnoozeAlarms()
|
||||||
|
@ -78,10 +68,8 @@ class KeepAliveReceiver : DaggerBroadcastReceiver() {
|
||||||
am.setInexactRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(), KEEP_ALIVE_MILLISECONDS, pi)
|
am.setInexactRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(), KEEP_ALIVE_MILLISECONDS, pi)
|
||||||
}
|
}
|
||||||
|
|
||||||
@JvmStatic
|
|
||||||
fun cancelAlarm(context: Context) {
|
fun cancelAlarm(context: Context) {
|
||||||
if (L.isEnabled(L.CORE))
|
aapsLogger.debug(LTag.CORE, "KeepAlive canceled")
|
||||||
log.debug("KeepAlive canceled")
|
|
||||||
val intent = Intent(context, KeepAliveReceiver::class.java)
|
val intent = Intent(context, KeepAliveReceiver::class.java)
|
||||||
val sender = PendingIntent.getBroadcast(context, 0, intent, 0)
|
val sender = PendingIntent.getBroadcast(context, 0, intent, 0)
|
||||||
val alarmManager = context.getSystemService(Context.ALARM_SERVICE) as AlarmManager
|
val alarmManager = context.getSystemService(Context.ALARM_SERVICE) as AlarmManager
|
||||||
|
@ -89,6 +77,13 @@ class KeepAliveReceiver : DaggerBroadcastReceiver() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
private val KEEP_ALIVE_MILLISECONDS = T.mins(5).msecs()
|
||||||
|
private val STATUS_UPDATE_FREQUENCY = T.mins(15).msecs()
|
||||||
|
private val IOB_UPDATE_FREQUENCY = T.mins(5).msecs()
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
// Usually devicestatus is uploaded through LoopPlugin after every loop cycle.
|
// Usually devicestatus is uploaded through LoopPlugin after every loop cycle.
|
||||||
// if there is no BG available, we have to upload anyway to have correct
|
// if there is no BG available, we have to upload anyway to have correct
|
||||||
// IOB displayed in NS
|
// IOB displayed in NS
|
||||||
|
@ -112,8 +107,7 @@ class KeepAliveReceiver : DaggerBroadcastReceiver() {
|
||||||
val lastConnection = pump.lastDataTime()
|
val lastConnection = pump.lastDataTime()
|
||||||
val isStatusOutdated = lastConnection + STATUS_UPDATE_FREQUENCY < System.currentTimeMillis()
|
val isStatusOutdated = lastConnection + STATUS_UPDATE_FREQUENCY < System.currentTimeMillis()
|
||||||
val isBasalOutdated = abs(profile.basal - pump.baseBasalRate) > pump.pumpDescription.basalStep
|
val isBasalOutdated = abs(profile.basal - pump.baseBasalRate) > pump.pumpDescription.basalStep
|
||||||
if (L.isEnabled(L.CORE))
|
aapsLogger.debug(LTag.CORE, "Last connection: " + DateUtil.dateAndTimeString(lastConnection))
|
||||||
log.debug("Last connection: " + DateUtil.dateAndTimeString(lastConnection))
|
|
||||||
// sometimes keep alive broadcast stops
|
// sometimes keep alive broadcast stops
|
||||||
// as as workaround test if readStatus was requested before an alarm is generated
|
// as as workaround test if readStatus was requested before an alarm is generated
|
||||||
if (lastReadStatus != 0L && lastReadStatus > System.currentTimeMillis() - T.mins(5).msecs()) {
|
if (lastReadStatus != 0L && lastReadStatus > System.currentTimeMillis() - T.mins(5).msecs()) {
|
||||||
|
@ -129,7 +123,7 @@ class KeepAliveReceiver : DaggerBroadcastReceiver() {
|
||||||
configBuilderPlugin.commandQueue.readStatus("KeepAlive. Basal outdated.", null)
|
configBuilderPlugin.commandQueue.readStatus("KeepAlive. Basal outdated.", null)
|
||||||
}
|
}
|
||||||
if (lastRun != 0L && System.currentTimeMillis() - lastRun > T.mins(10).msecs()) {
|
if (lastRun != 0L && System.currentTimeMillis() - lastRun > T.mins(10).msecs()) {
|
||||||
log.error("KeepAlive fail")
|
aapsLogger.error(LTag.CORE, "KeepAlive fail")
|
||||||
FabricPrivacy.getInstance().logCustom("KeepAliveFail")
|
FabricPrivacy.getInstance().logCustom("KeepAliveFail")
|
||||||
}
|
}
|
||||||
lastRun = System.currentTimeMillis()
|
lastRun = System.currentTimeMillis()
|
||||||
|
|
Loading…
Reference in a new issue