AndroidAPS/app/src/main/java/info/nightscout/androidaps/receivers/KeepAliveReceiver.java

89 lines
3.6 KiB
Java
Raw Normal View History

2016-07-07 00:56:31 +02:00
package info.nightscout.androidaps.receivers;
/**
* Created by mike on 07.07.2016.
*/
import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
2016-07-18 12:02:33 +02:00
import android.content.ComponentName;
2016-07-07 00:56:31 +02:00
import android.content.Context;
import android.content.Intent;
2016-07-18 12:02:33 +02:00
import android.content.ServiceConnection;
import android.os.IBinder;
2016-07-07 00:56:31 +02:00
import android.os.PowerManager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
2016-08-02 15:43:21 +02:00
import java.util.Date;
2016-07-07 10:34:20 +02:00
import info.nightscout.androidaps.Config;
2016-07-07 00:56:31 +02:00
import info.nightscout.androidaps.Constants;
2016-07-08 13:41:53 +02:00
import info.nightscout.androidaps.MainActivity;
2016-07-18 12:02:33 +02:00
import info.nightscout.androidaps.MainApp;
2016-07-11 14:04:57 +02:00
import info.nightscout.androidaps.interfaces.PluginBase;
2016-07-08 13:41:53 +02:00
import info.nightscout.androidaps.plugins.DanaR.DanaRFragment;
2016-08-05 23:54:03 +02:00
import info.nightscout.androidaps.plugins.DanaR.DanaRPlugin;
2016-07-18 12:02:33 +02:00
import info.nightscout.androidaps.plugins.DanaR.Services.ExecutionService;
2016-12-03 17:42:08 +01:00
import info.nightscout.androidaps.plugins.DanaRKorean.DanaRKoreanPlugin;
2016-07-18 12:02:33 +02:00
import info.nightscout.utils.ToastUtils;
2016-07-07 00:56:31 +02:00
public class KeepAliveReceiver extends BroadcastReceiver {
private static Logger log = LoggerFactory.getLogger(KeepAliveReceiver.class);
@Override
2016-07-07 10:34:20 +02:00
public void onReceive(Context context, Intent rIntent) {
2016-07-07 00:56:31 +02:00
PowerManager pm = (PowerManager) context.getSystemService(Context.POWER_SERVICE);
PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "");
wl.acquire();
log.debug("KeepAlive received");
2016-08-05 23:54:03 +02:00
final DanaRPlugin danaRPlugin = (DanaRPlugin) MainApp.getSpecificPlugin(DanaRPlugin.class);
2016-09-08 16:53:48 +02:00
if (danaRPlugin != null && Config.DANAR && danaRPlugin.isEnabled(PluginBase.PUMP)) {
2016-08-05 23:54:03 +02:00
if (danaRPlugin.getDanaRPump().lastConnection.getTime() + 30 * 60 * 1000L < new Date().getTime() && !danaRPlugin.isConnected() && !danaRPlugin.isConnecting()) {
2016-08-02 15:43:21 +02:00
Thread t = new Thread(new Runnable() {
@Override
public void run() {
2016-08-05 23:54:03 +02:00
danaRPlugin.doConnect("KeepAlive");
2016-08-02 15:43:21 +02:00
}
});
t.start();
}
2016-07-07 10:34:20 +02:00
}
2016-12-03 17:42:08 +01:00
final DanaRKoreanPlugin danaRKoreanPlugin = (DanaRKoreanPlugin) MainApp.getSpecificPlugin(DanaRKoreanPlugin.class);
if (danaRKoreanPlugin != null && Config.DANAR && danaRKoreanPlugin.isEnabled(PluginBase.PUMP)) {
if (danaRKoreanPlugin.getDanaRPump().lastConnection.getTime() + 30 * 60 * 1000L < new Date().getTime() && !danaRKoreanPlugin.isConnected() && !danaRKoreanPlugin.isConnecting()) {
Thread t = new Thread(new Runnable() {
@Override
public void run() {
danaRKoreanPlugin.doConnect("KeepAlive");
}
});
t.start();
}
}
2016-07-07 00:56:31 +02:00
wl.release();
}
public void setAlarm(Context context) {
AlarmManager am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
Intent i = new Intent(context, KeepAliveReceiver.class);
PendingIntent pi = PendingIntent.getBroadcast(context, 0, i, 0);
try {
pi.send();
} catch (PendingIntent.CanceledException e) {
}
am.cancel(pi);
am.setInexactRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(), Constants.keepAliveMsecs, pi);
}
public void cancelAlarm(Context context) {
Intent intent = new Intent(context, KeepAliveReceiver.class);
PendingIntent sender = PendingIntent.getBroadcast(context, 0, intent, 0);
AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
alarmManager.cancel(sender);
}
}