AndroidAPS/app/src/main/java/info/nightscout/androidaps/MainApp.kt

255 lines
12 KiB
Kotlin
Raw Normal View History

package info.nightscout.androidaps
import android.bluetooth.BluetoothDevice
import android.content.Intent
import android.content.IntentFilter
import android.net.ConnectivityManager
import android.net.wifi.WifiManager
import android.os.Build
2022-04-03 00:54:32 +02:00
import android.os.Handler
import android.os.HandlerThread
import androidx.lifecycle.ProcessLifecycleOwner
2022-03-30 20:13:38 +02:00
import androidx.work.Data
import androidx.work.ExistingPeriodicWorkPolicy
import androidx.work.PeriodicWorkRequest
import androidx.work.WorkManager
import dagger.android.AndroidInjector
import dagger.android.DaggerApplication
import info.nightscout.androidaps.database.AppRepository
import info.nightscout.androidaps.database.entities.TherapyEvent
2021-04-10 11:35:38 +02:00
import info.nightscout.androidaps.database.entities.UserEntry
import info.nightscout.androidaps.database.transactions.InsertIfNewByTimestampTherapyEventTransaction
import info.nightscout.androidaps.database.transactions.VersionChangeTransaction
import info.nightscout.androidaps.db.CompatDBHelper
2022-01-06 17:45:00 +01:00
import info.nightscout.androidaps.di.DaggerAppComponent
2021-10-20 22:54:32 +02:00
import info.nightscout.androidaps.di.StaticInjector
2022-11-06 18:21:10 +01:00
import info.nightscout.interfaces.BuildHelper
import info.nightscout.interfaces.Config
2021-05-29 23:38:19 +02:00
import info.nightscout.androidaps.interfaces.ConfigBuilder
2022-11-06 18:21:10 +01:00
import info.nightscout.interfaces.LocalAlertUtils
import info.nightscout.androidaps.interfaces.PluginBase
2022-05-19 16:56:48 +02:00
import info.nightscout.androidaps.interfaces.ResourceHelper
2021-04-10 11:35:38 +02:00
import info.nightscout.androidaps.logging.UserEntryLogger
import info.nightscout.androidaps.plugins.configBuilder.PluginStore
import info.nightscout.androidaps.plugins.constraints.versionChecker.VersionCheckerUtils
2021-11-28 18:20:52 +01:00
import info.nightscout.androidaps.plugins.general.overview.notifications.Notification
import info.nightscout.androidaps.plugins.general.overview.notifications.NotificationStore
2022-04-11 14:25:00 +02:00
import info.nightscout.androidaps.receivers.BTReceiver
import info.nightscout.androidaps.receivers.ChargingStateReceiver
import info.nightscout.androidaps.receivers.KeepAliveWorker
import info.nightscout.androidaps.receivers.NetworkChangeReceiver
import info.nightscout.androidaps.receivers.TimeDateOrTZChangeReceiver
2021-10-26 13:41:48 +02:00
import info.nightscout.androidaps.services.AlarmSoundServiceHelper
import info.nightscout.androidaps.utils.DateUtil
import info.nightscout.androidaps.utils.ProcessLifecycleListener
2021-10-23 21:08:31 +02:00
import info.nightscout.androidaps.utils.locale.LocaleHelper
2022-11-06 12:28:35 +01:00
import info.nightscout.plugins.general.themes.ThemeSwitcherPlugin
import info.nightscout.rx.logging.AAPSLogger
import info.nightscout.rx.logging.LTag
2021-12-10 12:17:03 +01:00
import info.nightscout.shared.sharedPreferences.SP
2022-11-04 14:34:05 +01:00
import info.nightscout.ui.utils.ActivityMonitor
2022-11-02 11:22:34 +01:00
import info.nightscout.ui.widget.Widget
2022-02-10 19:11:58 +01:00
import io.reactivex.rxjava3.disposables.CompositeDisposable
import io.reactivex.rxjava3.exceptions.UndeliverableException
import io.reactivex.rxjava3.kotlin.plusAssign
import io.reactivex.rxjava3.plugins.RxJavaPlugins
2022-05-25 16:49:31 +02:00
import rxdogtag2.RxDogTag
2021-10-20 22:54:32 +02:00
import java.io.IOException
2022-03-30 20:13:38 +02:00
import java.util.concurrent.TimeUnit
import javax.inject.Inject
2022-05-19 16:56:48 +02:00
import javax.inject.Provider
class MainApp : DaggerApplication() {
private val disposable = CompositeDisposable()
@Inject lateinit var pluginStore: PluginStore
@Inject lateinit var aapsLogger: AAPSLogger
@Inject lateinit var activityMonitor: ActivityMonitor
@Inject lateinit var versionCheckersUtils: VersionCheckerUtils
@Inject lateinit var sp: SP
@Inject lateinit var config: Config
2021-11-28 18:20:52 +01:00
@Inject lateinit var buildHelper: BuildHelper
2021-04-13 23:27:55 +02:00
@Inject lateinit var configBuilder: ConfigBuilder
@Inject lateinit var plugins: List<@JvmSuppressWildcards PluginBase>
@Inject lateinit var compatDBHelper: CompatDBHelper
@Inject lateinit var repository: AppRepository
@Inject lateinit var dateUtil: DateUtil
2022-11-04 14:34:05 +01:00
@Suppress("unused") @Inject lateinit var staticInjector: StaticInjector// TODO avoid , here fake only to initialize
2021-04-10 11:35:38 +02:00
@Inject lateinit var uel: UserEntryLogger
2021-10-26 13:41:48 +02:00
@Inject lateinit var alarmSoundServiceHelper: AlarmSoundServiceHelper
2021-11-28 18:20:52 +01:00
@Inject lateinit var notificationStore: NotificationStore
2022-08-01 14:40:03 +02:00
@Inject lateinit var processLifecycleListener: Provider<ProcessLifecycleListener>
2022-03-18 16:04:08 +01:00
@Inject lateinit var profileSwitchPlugin: ThemeSwitcherPlugin
2022-03-30 20:13:38 +02:00
@Inject lateinit var localAlertUtils: LocalAlertUtils
2022-05-19 16:56:48 +02:00
@Inject lateinit var rh: Provider<ResourceHelper>
2022-04-03 00:54:32 +02:00
private var handler = Handler(HandlerThread(this::class.simpleName + "Handler").also { it.start() }.looper)
private lateinit var refreshWidget: Runnable
override fun onCreate() {
super.onCreate()
aapsLogger.debug("onCreate")
2021-10-10 18:05:55 +02:00
RxDogTag.install()
2021-10-20 22:54:32 +02:00
setRxErrorHandler()
2021-10-23 21:08:31 +02:00
LocaleHelper.update(this)
var gitRemote: String? = BuildConfig.REMOTE
var commitHash: String? = BuildConfig.HEAD
if (gitRemote?.contains("NoGitSystemAvailable") == true) {
gitRemote = null
commitHash = null
}
disposable += compatDBHelper.dbChangeDisposable()
registerActivityLifecycleCallbacks(activityMonitor)
2022-03-18 16:04:08 +01:00
profileSwitchPlugin.setThemeMode()
aapsLogger.debug("Version: " + BuildConfig.VERSION_NAME)
aapsLogger.debug("BuildVersion: " + BuildConfig.BUILDVERSION)
aapsLogger.debug("Remote: " + BuildConfig.REMOTE)
registerLocalBroadcastReceiver()
2021-11-28 18:20:52 +01:00
// trigger here to see the new version on app start after an update
versionCheckersUtils.triggerCheckVersion()
// Register all tabs in app here
pluginStore.plugins = plugins
2021-04-13 23:27:55 +02:00
configBuilder.initialize()
2022-03-30 20:13:38 +02:00
2022-05-19 16:56:48 +02:00
// delayed actions to make rh context updated for translations
handler.postDelayed(
{
// check if identification is set
if (buildHelper.isDev() && sp.getStringOrNull(R.string.key_email_for_crash_report, null).isNullOrBlank())
notificationStore.add(Notification(Notification.IDENTIFICATION_NOT_SET, rh.get().gs(R.string.identification_not_set), Notification.INFO))
// log version
disposable += repository.runTransaction(VersionChangeTransaction(BuildConfig.VERSION_NAME, BuildConfig.VERSION_CODE, gitRemote, commitHash)).subscribe()
// log app start
if (sp.getBoolean(R.string.key_ns_logappstartedevent, config.APS))
disposable += repository
.runTransaction(
InsertIfNewByTimestampTherapyEventTransaction(
timestamp = dateUtil.now(),
type = TherapyEvent.Type.NOTE,
note = rh.get().gs(info.nightscout.androidaps.core.R.string.androidaps_start) + " - " + Build.MANUFACTURER + " " + Build.MODEL,
glucoseUnit = TherapyEvent.GlucoseUnit.MGDL
)
)
.subscribe()
}, 10000
)
2022-03-30 20:13:38 +02:00
WorkManager.getInstance(this).enqueueUniquePeriodicWork(
2022-10-17 12:35:26 +02:00
KeepAliveWorker.KA_0,
2022-03-30 20:13:38 +02:00
ExistingPeriodicWorkPolicy.REPLACE,
PeriodicWorkRequest.Builder(KeepAliveWorker::class.java, 15, TimeUnit.MINUTES)
2022-10-17 12:35:26 +02:00
.setInputData(Data.Builder().putString("schedule", KeepAliveWorker.KA_0).build())
2022-03-30 20:13:38 +02:00
.setInitialDelay(5, TimeUnit.SECONDS)
.build()
)
localAlertUtils.shortenSnoozeInterval()
localAlertUtils.preSnoozeAlarms()
doMigrations()
2021-04-10 11:35:38 +02:00
uel.log(UserEntry.Action.START_AAPS, UserEntry.Sources.Aaps)
2022-08-01 14:40:03 +02:00
ProcessLifecycleOwner.get().lifecycle.addObserver(processLifecycleListener.get())
2022-04-03 00:54:32 +02:00
// schedule widget update
refreshWidget = Runnable {
handler.postDelayed(refreshWidget, 60000)
2022-11-02 11:22:34 +01:00
Widget.updateWidget(this)
2022-04-03 00:54:32 +02:00
}
handler.postDelayed(refreshWidget, 60000)
}
2021-10-20 22:54:32 +02:00
private fun setRxErrorHandler() {
RxJavaPlugins.setErrorHandler { t: Throwable ->
var e = t
if (e is UndeliverableException) {
e = e.cause!!
}
2022-11-04 14:34:05 +01:00
if (e is IOException) {
2021-10-20 22:54:32 +02:00
// fine, irrelevant network problem or API that throws on cancellation
return@setErrorHandler
}
if (e is InterruptedException) {
// fine, some blocking code was interrupted by a dispose call
return@setErrorHandler
}
if (e is NullPointerException || e is IllegalArgumentException) {
// that's likely a bug in the application
Thread.currentThread().uncaughtExceptionHandler?.uncaughtException(Thread.currentThread(), e)
return@setErrorHandler
}
if (e is IllegalStateException) {
// that's a bug in RxJava or in a custom operator
Thread.currentThread().uncaughtExceptionHandler?.uncaughtException(Thread.currentThread(), e)
return@setErrorHandler
}
2022-10-20 11:37:27 +02:00
aapsLogger.warn(LTag.CORE, "Undeliverable exception received, not sure what to do", e.toString())
2021-10-20 22:54:32 +02:00
}
}
2022-05-30 19:12:20 +02:00
@Suppress("SpellCheckingInspection")
private fun doMigrations() {
// set values for different builds
if (!sp.contains(R.string.key_ns_alarms)) sp.putBoolean(R.string.key_ns_alarms, config.NSCLIENT)
if (!sp.contains(R.string.key_ns_announcements)) sp.putBoolean(R.string.key_ns_announcements, config.NSCLIENT)
if (!sp.contains(R.string.key_language)) sp.putString(R.string.key_language, "default")
2022-05-30 19:12:20 +02:00
// 3.1.0
if (sp.contains("ns_wifionly")) {
if (sp.getBoolean("ns_wifionly", false)) {
sp.putBoolean(R.string.key_ns_cellular, false)
sp.putBoolean(R.string.key_ns_wifi, true)
} else {
sp.putBoolean(R.string.key_ns_cellular, true)
sp.putBoolean(R.string.key_ns_wifi, false)
}
sp.remove("ns_wifionly")
}
if (sp.contains("ns_charginonly")) {
if (sp.getBoolean("ns_charginonly", false)) {
sp.putBoolean(R.string.key_ns_battery, false)
sp.putBoolean(R.string.key_ns_charging, true)
} else {
sp.putBoolean(R.string.key_ns_battery, true)
sp.putBoolean(R.string.key_ns_charging, true)
}
sp.remove("ns_charginonly")
}
}
override fun applicationInjector(): AndroidInjector<out DaggerApplication> {
return DaggerAppComponent
.builder()
.application(this)
.build()
}
private fun registerLocalBroadcastReceiver() {
var filter = IntentFilter()
filter.addAction(Intent.ACTION_TIME_CHANGED)
filter.addAction(Intent.ACTION_TIMEZONE_CHANGED)
registerReceiver(TimeDateOrTZChangeReceiver(), filter)
filter = IntentFilter()
@Suppress("DEPRECATION")
filter.addAction(ConnectivityManager.CONNECTIVITY_ACTION)
filter.addAction(WifiManager.NETWORK_STATE_CHANGED_ACTION)
filter.addAction(WifiManager.WIFI_STATE_CHANGED_ACTION)
registerReceiver(NetworkChangeReceiver(), filter)
filter = IntentFilter()
filter.addAction(Intent.ACTION_POWER_CONNECTED)
filter.addAction(Intent.ACTION_POWER_DISCONNECTED)
filter.addAction(Intent.ACTION_BATTERY_CHANGED)
registerReceiver(ChargingStateReceiver(), filter)
filter = IntentFilter()
filter.addAction(BluetoothDevice.ACTION_ACL_CONNECTED)
filter.addAction(BluetoothDevice.ACTION_ACL_DISCONNECTED)
registerReceiver(BTReceiver(), filter)
}
override fun onTerminate() {
aapsLogger.debug(LTag.CORE, "onTerminate")
unregisterActivityLifecycleCallbacks(activityMonitor)
2022-06-08 13:39:08 +02:00
alarmSoundServiceHelper.stopService(this, "onTerminate")
super.onTerminate()
}
2021-10-10 18:05:55 +02:00
}