5b9bd2adfc
- little change in scanning - added error checking into RadioResponse and BasalProfile, also added events - disabled quick scan - synchronized RileyLink state changes - proofed MedtronicConverter - fixed 10 errors found on fabric - fixed SetBasalProfile, after merge
497 lines
19 KiB
Java
497 lines
19 KiB
Java
package info.nightscout.androidaps;
|
|
|
|
import java.io.File;
|
|
import java.util.ArrayList;
|
|
|
|
import net.danlew.android.joda.JodaTimeAndroid;
|
|
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import android.app.Application;
|
|
import android.bluetooth.BluetoothAdapter;
|
|
import android.content.BroadcastReceiver;
|
|
import android.content.Context;
|
|
import android.content.Intent;
|
|
import android.content.IntentFilter;
|
|
import android.content.res.Resources;
|
|
import android.os.SystemClock;
|
|
import android.support.annotation.Nullable;
|
|
import android.support.annotation.PluralsRes;
|
|
import android.support.v4.content.LocalBroadcastManager;
|
|
import android.util.Log;
|
|
|
|
import com.crashlytics.android.Crashlytics;
|
|
import com.crashlytics.android.answers.Answers;
|
|
import com.j256.ormlite.android.apptools.OpenHelperManager;
|
|
import com.squareup.otto.Bus;
|
|
import com.squareup.otto.LoggingBus;
|
|
import com.squareup.otto.ThreadEnforcer;
|
|
|
|
import info.nightscout.androidaps.data.ConstraintChecker;
|
|
import info.nightscout.androidaps.db.DatabaseHelper;
|
|
import info.nightscout.androidaps.interfaces.PluginBase;
|
|
import info.nightscout.androidaps.interfaces.PluginType;
|
|
import info.nightscout.androidaps.interfaces.PumpInterface;
|
|
import info.nightscout.androidaps.logging.L;
|
|
import info.nightscout.androidaps.plugins.Actions.ActionsFragment;
|
|
import info.nightscout.androidaps.plugins.Careportal.CareportalPlugin;
|
|
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
|
import info.nightscout.androidaps.plugins.ConstraintsObjectives.ObjectivesPlugin;
|
|
import info.nightscout.androidaps.plugins.ConstraintsSafety.SafetyPlugin;
|
|
import info.nightscout.androidaps.plugins.Food.FoodPlugin;
|
|
import info.nightscout.androidaps.plugins.Insulin.InsulinOrefFreePeakPlugin;
|
|
import info.nightscout.androidaps.plugins.Insulin.InsulinOrefRapidActingPlugin;
|
|
import info.nightscout.androidaps.plugins.Insulin.InsulinOrefUltraRapidActingPlugin;
|
|
import info.nightscout.androidaps.plugins.IobCobCalculator.IobCobCalculatorPlugin;
|
|
import info.nightscout.androidaps.plugins.Loop.LoopPlugin;
|
|
import info.nightscout.androidaps.plugins.Maintenance.LoggerUtils;
|
|
import info.nightscout.androidaps.plugins.Maintenance.MaintenancePlugin;
|
|
import info.nightscout.androidaps.plugins.NSClientInternal.NSClientPlugin;
|
|
import info.nightscout.androidaps.plugins.NSClientInternal.NSUpload;
|
|
import info.nightscout.androidaps.plugins.NSClientInternal.receivers.AckAlarmReceiver;
|
|
import info.nightscout.androidaps.plugins.NSClientInternal.receivers.DBAccessReceiver;
|
|
import info.nightscout.androidaps.plugins.OpenAPSAMA.OpenAPSAMAPlugin;
|
|
import info.nightscout.androidaps.plugins.OpenAPSMA.OpenAPSMAPlugin;
|
|
import info.nightscout.androidaps.plugins.OpenAPSSMB.OpenAPSSMBPlugin;
|
|
import info.nightscout.androidaps.plugins.Overview.OverviewPlugin;
|
|
import info.nightscout.androidaps.plugins.Persistentnotification.PersistentNotificationPlugin;
|
|
import info.nightscout.androidaps.plugins.ProfileLocal.LocalProfilePlugin;
|
|
import info.nightscout.androidaps.plugins.ProfileNS.NSProfilePlugin;
|
|
import info.nightscout.androidaps.plugins.ProfileSimple.SimpleProfilePlugin;
|
|
import info.nightscout.androidaps.plugins.PumpCombo.ComboPlugin;
|
|
import info.nightscout.androidaps.plugins.PumpCommon.hw.rileylink.RileyLinkConst;
|
|
import info.nightscout.androidaps.plugins.PumpCommon.hw.rileylink.RileyLinkUtil;
|
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPlugin;
|
|
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.plugins.PumpInsight.InsightPlugin;
|
|
import info.nightscout.androidaps.plugins.PumpMDI.MDIPlugin;
|
|
import info.nightscout.androidaps.plugins.PumpMedtronic.MedtronicPumpPlugin;
|
|
import info.nightscout.androidaps.plugins.PumpVirtual.VirtualPumpPlugin;
|
|
import info.nightscout.androidaps.plugins.Sensitivity.SensitivityAAPSPlugin;
|
|
import info.nightscout.androidaps.plugins.Sensitivity.SensitivityOref0Plugin;
|
|
import info.nightscout.androidaps.plugins.Sensitivity.SensitivityOref1Plugin;
|
|
import info.nightscout.androidaps.plugins.Sensitivity.SensitivityWeightedAveragePlugin;
|
|
import info.nightscout.androidaps.plugins.SmsCommunicator.SmsCommunicatorPlugin;
|
|
import info.nightscout.androidaps.plugins.Source.SourceDexcomG5Plugin;
|
|
import info.nightscout.androidaps.plugins.Source.SourceGlimpPlugin;
|
|
import info.nightscout.androidaps.plugins.Source.SourceMM640gPlugin;
|
|
import info.nightscout.androidaps.plugins.Source.SourceNSClientPlugin;
|
|
import info.nightscout.androidaps.plugins.Source.SourcePoctechPlugin;
|
|
import info.nightscout.androidaps.plugins.Source.SourceXdripPlugin;
|
|
import info.nightscout.androidaps.plugins.Treatments.TreatmentsPlugin;
|
|
import info.nightscout.androidaps.plugins.Wear.WearPlugin;
|
|
import info.nightscout.androidaps.plugins.XDripStatusline.StatuslinePlugin;
|
|
import info.nightscout.androidaps.receivers.DataReceiver;
|
|
import info.nightscout.androidaps.receivers.KeepAliveReceiver;
|
|
import info.nightscout.androidaps.receivers.NSAlarmReceiver;
|
|
import info.nightscout.androidaps.services.Intents;
|
|
import info.nightscout.utils.FabricPrivacy;
|
|
import io.fabric.sdk.android.Fabric;
|
|
|
|
public class MainApp extends Application {
|
|
|
|
private static Logger log = LoggerFactory.getLogger(L.CORE);
|
|
private static KeepAliveReceiver keepAliveReceiver;
|
|
|
|
private static Bus sBus;
|
|
private static MainApp sInstance;
|
|
public static Resources sResources;
|
|
|
|
private static DatabaseHelper sDatabaseHelper = null;
|
|
private static ConstraintChecker sConstraintsChecker = null;
|
|
|
|
private static ArrayList<PluginBase> pluginsList = null;
|
|
|
|
private static DataReceiver dataReceiver = new DataReceiver();
|
|
private static NSAlarmReceiver alarmReciever = new NSAlarmReceiver();
|
|
private static AckAlarmReceiver ackAlarmReciever = new AckAlarmReceiver();
|
|
private static DBAccessReceiver dbAccessReciever = new DBAccessReceiver();
|
|
private LocalBroadcastManager lbm;
|
|
private BroadcastReceiver btReceiver; // used for RileyLink (Medtronic and Omnipod)
|
|
|
|
public static boolean devBranch;
|
|
public static boolean engineeringMode;
|
|
|
|
|
|
@Override
|
|
public void onCreate() {
|
|
super.onCreate();
|
|
log.debug("onCreate");
|
|
sInstance = this;
|
|
sResources = getResources();
|
|
sConstraintsChecker = new ConstraintChecker(this);
|
|
sDatabaseHelper = OpenHelperManager.getHelper(sInstance, DatabaseHelper.class);
|
|
|
|
try {
|
|
if (FabricPrivacy.fabricEnabled()) {
|
|
Fabric.with(this, new Crashlytics());
|
|
Fabric.with(this, new Answers());
|
|
Crashlytics.setString("BUILDVERSION", BuildConfig.BUILDVERSION);
|
|
}
|
|
} catch (Exception e) {
|
|
log.error("Error with Fabric init! " + e);
|
|
}
|
|
|
|
JodaTimeAndroid.init(this);
|
|
|
|
log.info("Version: " + BuildConfig.VERSION_NAME);
|
|
log.info("BuildVersion: " + BuildConfig.BUILDVERSION);
|
|
|
|
String extFilesDir = LoggerUtils.getLogDirectory();
|
|
File engineeringModeSemaphore = new File(extFilesDir, "engineering_mode");
|
|
|
|
engineeringMode = engineeringModeSemaphore.exists() && engineeringModeSemaphore.isFile();
|
|
devBranch = BuildConfig.VERSION.contains("dev");
|
|
|
|
sBus = L.isEnabled(L.EVENTS) && devBranch ? new LoggingBus(ThreadEnforcer.ANY) : new Bus(ThreadEnforcer.ANY);
|
|
|
|
registerLocalBroadcastReceiver();
|
|
|
|
setBTReceiver();
|
|
|
|
if (pluginsList == null) {
|
|
pluginsList = new ArrayList<>();
|
|
// Register all tabs in app here
|
|
pluginsList.add(OverviewPlugin.getPlugin());
|
|
pluginsList.add(IobCobCalculatorPlugin.getPlugin());
|
|
if (Config.ACTION)
|
|
pluginsList.add(ActionsFragment.getPlugin());
|
|
pluginsList.add(InsulinOrefRapidActingPlugin.getPlugin());
|
|
pluginsList.add(InsulinOrefUltraRapidActingPlugin.getPlugin());
|
|
pluginsList.add(InsulinOrefFreePeakPlugin.getPlugin());
|
|
pluginsList.add(SensitivityOref0Plugin.getPlugin());
|
|
pluginsList.add(SensitivityAAPSPlugin.getPlugin());
|
|
pluginsList.add(SensitivityWeightedAveragePlugin.getPlugin());
|
|
pluginsList.add(SensitivityOref1Plugin.getPlugin());
|
|
if (Config.PUMPDRIVERS)
|
|
pluginsList.add(DanaRPlugin.getPlugin());
|
|
if (Config.PUMPDRIVERS)
|
|
pluginsList.add(DanaRKoreanPlugin.getPlugin());
|
|
if (Config.PUMPDRIVERS)
|
|
pluginsList.add(DanaRv2Plugin.getPlugin());
|
|
if (Config.PUMPDRIVERS)
|
|
pluginsList.add(DanaRSPlugin.getPlugin());
|
|
pluginsList.add(CareportalPlugin.getPlugin());
|
|
if (Config.PUMPDRIVERS && engineeringMode) {
|
|
pluginsList.add(InsightPlugin.getPlugin()); // <-- Enable Insight plugin here
|
|
pluginsList.add(MedtronicPumpPlugin.getPlugin());
|
|
}
|
|
if (Config.PUMPDRIVERS)
|
|
pluginsList.add(ComboPlugin.getPlugin());
|
|
if (Config.MDI)
|
|
pluginsList.add(MDIPlugin.getPlugin());
|
|
pluginsList.add(VirtualPumpPlugin.getPlugin());
|
|
if (Config.APS)
|
|
pluginsList.add(LoopPlugin.getPlugin());
|
|
if (Config.APS)
|
|
pluginsList.add(OpenAPSMAPlugin.getPlugin());
|
|
if (Config.APS)
|
|
pluginsList.add(OpenAPSAMAPlugin.getPlugin());
|
|
if (Config.APS)
|
|
pluginsList.add(OpenAPSSMBPlugin.getPlugin());
|
|
pluginsList.add(NSProfilePlugin.getPlugin());
|
|
if (Config.OTHERPROFILES)
|
|
pluginsList.add(SimpleProfilePlugin.getPlugin());
|
|
if (Config.OTHERPROFILES)
|
|
pluginsList.add(LocalProfilePlugin.getPlugin());
|
|
pluginsList.add(TreatmentsPlugin.getPlugin());
|
|
if (Config.SAFETY)
|
|
pluginsList.add(SafetyPlugin.getPlugin());
|
|
if (Config.APS)
|
|
pluginsList.add(ObjectivesPlugin.getPlugin());
|
|
pluginsList.add(SourceXdripPlugin.getPlugin());
|
|
pluginsList.add(SourceNSClientPlugin.getPlugin());
|
|
pluginsList.add(SourceMM640gPlugin.getPlugin());
|
|
pluginsList.add(SourceGlimpPlugin.getPlugin());
|
|
pluginsList.add(SourceDexcomG5Plugin.getPlugin());
|
|
pluginsList.add(SourcePoctechPlugin.getPlugin());
|
|
if (Config.SMSCOMMUNICATORENABLED)
|
|
pluginsList.add(SmsCommunicatorPlugin.getPlugin());
|
|
pluginsList.add(FoodPlugin.getPlugin());
|
|
|
|
pluginsList.add(WearPlugin.initPlugin(this));
|
|
pluginsList.add(StatuslinePlugin.initPlugin(this));
|
|
pluginsList.add(PersistentNotificationPlugin.getPlugin());
|
|
pluginsList.add(NSClientPlugin.getPlugin());
|
|
pluginsList.add(MaintenancePlugin.initPlugin(this));
|
|
|
|
pluginsList.add(ConfigBuilderPlugin.getPlugin());
|
|
|
|
ConfigBuilderPlugin.getPlugin().initialize();
|
|
}
|
|
|
|
NSUpload.uploadAppStart();
|
|
|
|
final PumpInterface pump = ConfigBuilderPlugin.getPlugin().getActivePump();
|
|
if (pump != null) {
|
|
new Thread(() -> {
|
|
SystemClock.sleep(5000);
|
|
ConfigBuilderPlugin.getPlugin().getCommandQueue().readStatus("Initialization", null);
|
|
startKeepAliveService();
|
|
}).start();
|
|
}
|
|
}
|
|
|
|
|
|
private void registerLocalBroadcastReceiver() {
|
|
lbm = LocalBroadcastManager.getInstance(this);
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_NEW_TREATMENT));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_CHANGED_TREATMENT));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_REMOVED_TREATMENT));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_NEW_FOOD));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_CHANGED_FOOD));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_REMOVED_FOOD));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_NEW_SGV));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_NEW_PROFILE));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_NEW_STATUS));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_NEW_MBG));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_NEW_DEVICESTATUS));
|
|
lbm.registerReceiver(dataReceiver, new IntentFilter(Intents.ACTION_NEW_CAL));
|
|
|
|
// register alarms
|
|
lbm.registerReceiver(alarmReciever, new IntentFilter(Intents.ACTION_ALARM));
|
|
lbm.registerReceiver(alarmReciever, new IntentFilter(Intents.ACTION_ANNOUNCEMENT));
|
|
lbm.registerReceiver(alarmReciever, new IntentFilter(Intents.ACTION_CLEAR_ALARM));
|
|
lbm.registerReceiver(alarmReciever, new IntentFilter(Intents.ACTION_URGENT_ALARM));
|
|
|
|
// register ack alarm
|
|
lbm.registerReceiver(ackAlarmReciever, new IntentFilter(Intents.ACTION_ACK_ALARM));
|
|
|
|
// register dbaccess
|
|
lbm.registerReceiver(dbAccessReciever, new IntentFilter(Intents.ACTION_DATABASE));
|
|
}
|
|
|
|
|
|
private void setBTReceiver() {
|
|
|
|
// SP.putDouble(RileyLinkConst.Prefs.LastGoodDeviceFrequency, null);
|
|
// SP.remove(RileyLinkConst.Prefs.LastGoodDeviceFrequency);
|
|
|
|
// RileyLink framework needs to know, when BT was reconnected, so that we can reconnect to RL device
|
|
btReceiver = new BroadcastReceiver() {
|
|
|
|
@Override
|
|
public void onReceive(Context context, Intent intent) {
|
|
final String action = intent.getAction();
|
|
|
|
if (action.equals(BluetoothAdapter.ACTION_STATE_CHANGED)) {
|
|
final int state = intent.getIntExtra(BluetoothAdapter.EXTRA_STATE, BluetoothAdapter.ERROR);
|
|
switch (state) {
|
|
case BluetoothAdapter.STATE_OFF:
|
|
case BluetoothAdapter.STATE_TURNING_OFF:
|
|
case BluetoothAdapter.STATE_TURNING_ON:
|
|
break;
|
|
|
|
case BluetoothAdapter.STATE_ON:
|
|
Log.v("MainApp", "Bluetooth on");
|
|
RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.BluetoothReconnected);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
// Register for broadcasts on BluetoothAdapter state change
|
|
IntentFilter filter = new IntentFilter(BluetoothAdapter.ACTION_STATE_CHANGED);
|
|
registerReceiver(btReceiver, filter);
|
|
|
|
}
|
|
|
|
|
|
private void startKeepAliveService() {
|
|
if (keepAliveReceiver == null) {
|
|
keepAliveReceiver = new KeepAliveReceiver();
|
|
keepAliveReceiver.setAlarm(this);
|
|
}
|
|
}
|
|
|
|
|
|
public void stopKeepAliveService() {
|
|
if (keepAliveReceiver != null)
|
|
KeepAliveReceiver.cancelAlarm(this);
|
|
}
|
|
|
|
|
|
public static void subscribe(Object subscriber) {
|
|
try {
|
|
bus().register(subscriber);
|
|
} catch (IllegalArgumentException e) {
|
|
// already registered
|
|
}
|
|
}
|
|
|
|
|
|
public static void unsubscribe(Object subscriber) {
|
|
try {
|
|
bus().unregister(subscriber);
|
|
} catch (IllegalArgumentException e) {
|
|
// already unregistered
|
|
}
|
|
}
|
|
|
|
|
|
public static Bus bus() {
|
|
return sBus;
|
|
}
|
|
|
|
|
|
public static String gs(int id) {
|
|
return sResources.getString(id);
|
|
}
|
|
|
|
|
|
public static String gs(int id, Object... args) {
|
|
return sResources.getString(id, args);
|
|
}
|
|
|
|
|
|
public static String gq(@PluralsRes int id, int quantity, Object... args) {
|
|
return sResources.getQuantityString(id, quantity, args);
|
|
}
|
|
|
|
|
|
public static int gc(int id) {
|
|
return sResources.getColor(id);
|
|
}
|
|
|
|
|
|
public static MainApp instance() {
|
|
return sInstance;
|
|
}
|
|
|
|
|
|
public static DatabaseHelper getDbHelper() {
|
|
return sDatabaseHelper;
|
|
}
|
|
|
|
|
|
public static void closeDbHelper() {
|
|
if (sDatabaseHelper != null) {
|
|
sDatabaseHelper.close();
|
|
sDatabaseHelper = null;
|
|
}
|
|
}
|
|
|
|
|
|
public static ConstraintChecker getConstraintChecker() {
|
|
return sConstraintsChecker;
|
|
}
|
|
|
|
|
|
public static ArrayList<PluginBase> getPluginsList() {
|
|
return pluginsList;
|
|
}
|
|
|
|
|
|
public static ArrayList<PluginBase> getSpecificPluginsList(PluginType type) {
|
|
ArrayList<PluginBase> newList = new ArrayList<>();
|
|
|
|
if (pluginsList != null) {
|
|
for (PluginBase p : pluginsList) {
|
|
if (p.getType() == type)
|
|
newList.add(p);
|
|
}
|
|
} else {
|
|
log.error("pluginsList=null");
|
|
}
|
|
return newList;
|
|
}
|
|
|
|
|
|
public static ArrayList<PluginBase> getSpecificPluginsVisibleInList(PluginType type) {
|
|
ArrayList<PluginBase> newList = new ArrayList<>();
|
|
|
|
if (pluginsList != null) {
|
|
for (PluginBase p : pluginsList) {
|
|
if (p.getType() == type)
|
|
if (p.showInList(type))
|
|
newList.add(p);
|
|
}
|
|
} else {
|
|
log.error("pluginsList=null");
|
|
}
|
|
return newList;
|
|
}
|
|
|
|
|
|
public static ArrayList<PluginBase> getSpecificPluginsListByInterface(Class interfaceClass) {
|
|
ArrayList<PluginBase> newList = new ArrayList<>();
|
|
|
|
if (pluginsList != null) {
|
|
for (PluginBase p : pluginsList) {
|
|
if (p.getClass() != ConfigBuilderPlugin.class && interfaceClass.isAssignableFrom(p.getClass()))
|
|
newList.add(p);
|
|
}
|
|
} else {
|
|
log.error("pluginsList=null");
|
|
}
|
|
return newList;
|
|
}
|
|
|
|
|
|
public static ArrayList<PluginBase> getSpecificPluginsVisibleInListByInterface(Class interfaceClass, PluginType type) {
|
|
ArrayList<PluginBase> newList = new ArrayList<>();
|
|
|
|
if (pluginsList != null) {
|
|
for (PluginBase p : pluginsList) {
|
|
if (p.getClass() != ConfigBuilderPlugin.class && interfaceClass.isAssignableFrom(p.getClass()))
|
|
if (p.showInList(type))
|
|
newList.add(p);
|
|
}
|
|
} else {
|
|
log.error("pluginsList=null");
|
|
}
|
|
return newList;
|
|
}
|
|
|
|
|
|
@Nullable
|
|
public static <T extends PluginBase> T getSpecificPlugin(Class<T> pluginClass) {
|
|
if (pluginsList != null) {
|
|
for (PluginBase p : pluginsList) {
|
|
if (pluginClass.isAssignableFrom(p.getClass()))
|
|
return (T)p;
|
|
}
|
|
} else {
|
|
log.error("pluginsList=null");
|
|
}
|
|
return null;
|
|
}
|
|
|
|
|
|
public static boolean isEngineeringModeOrRelease() {
|
|
if (!Config.APS)
|
|
return true;
|
|
return engineeringMode || !devBranch;
|
|
}
|
|
|
|
|
|
public static boolean isEngineeringMode() {
|
|
return engineeringMode;
|
|
}
|
|
|
|
|
|
public static boolean isDev() {
|
|
return devBranch;
|
|
}
|
|
|
|
|
|
@Override
|
|
public void onTerminate() {
|
|
if (L.isEnabled(L.CORE))
|
|
log.debug("onTerminate");
|
|
super.onTerminate();
|
|
if (sDatabaseHelper != null) {
|
|
sDatabaseHelper.close();
|
|
sDatabaseHelper = null;
|
|
}
|
|
|
|
if (btReceiver != null) {
|
|
unregisterReceiver(btReceiver);
|
|
}
|
|
}
|
|
}
|