diff --git a/app/src/main/java/info/nightscout/androidaps/MainApp.java b/app/src/main/java/info/nightscout/androidaps/MainApp.java index d3701c94b0..e39516934f 100644 --- a/app/src/main/java/info/nightscout/androidaps/MainApp.java +++ b/app/src/main/java/info/nightscout/androidaps/MainApp.java @@ -217,16 +217,6 @@ public class MainApp extends DaggerApplication { return sResources.getString(id, args); } - @Deprecated - public static int gc(@ColorRes int id) { - return ContextCompat.getColor(instance(), id); - } - - @Deprecated - public static Resources resources() { - return sResources; - } - @Deprecated public static MainApp instance() { return sInstance; diff --git a/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt b/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt index 0a1c7c4267..b06276114d 100644 --- a/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt +++ b/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt @@ -275,13 +275,13 @@ class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChang } else if (pref.text != null) { pref.dialogMessage = pref.dialogMessage pref.setSummary(pref.text) - } else { - for (plugin in pluginStore.plugins) { - plugin.updatePreferenceSummary(pref) - } } } + for (plugin in pluginStore.plugins) { + pref?.let { pref-> pref.getKey()?.let { plugin.updatePreferenceSummary(pref) }} + } + val hmacPasswords = arrayOf( resourceHelper.gs(R.string.key_bolus_password), resourceHelper.gs(R.string.key_master_password), diff --git a/app/src/main/java/info/nightscout/androidaps/db/CareportalEvent.java b/app/src/main/java/info/nightscout/androidaps/db/CareportalEvent.java index db05730aea..bfe24a008b 100644 --- a/app/src/main/java/info/nightscout/androidaps/db/CareportalEvent.java +++ b/app/src/main/java/info/nightscout/androidaps/db/CareportalEvent.java @@ -42,6 +42,7 @@ public class CareportalEvent implements DataPointWithLabelInterface, Interval { @Inject ProfileFunction profileFunction; @Inject ResourceHelper resourceHelper; @Inject AAPSLogger aapsLogger; + @Inject Translator translator; @DatabaseField(id = true) public long date; @@ -227,7 +228,7 @@ public class CareportalEvent implements DataPointWithLabelInterface, Interval { } catch (JSONException e) { aapsLogger.error("Unhandled exception", e); } - return Translator.translate(eventType); + return translator.translate(eventType); } public String getNotes() { diff --git a/app/src/main/java/info/nightscout/androidaps/db/TDD.java b/app/src/main/java/info/nightscout/androidaps/db/TDD.java index 3b4727a100..8d6a2e2576 100644 --- a/app/src/main/java/info/nightscout/androidaps/db/TDD.java +++ b/app/src/main/java/info/nightscout/androidaps/db/TDD.java @@ -3,15 +3,12 @@ package info.nightscout.androidaps.db; import com.j256.ormlite.field.DatabaseField; import com.j256.ormlite.table.DatabaseTable; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; +import java.util.Locale; -import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.R; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; import info.nightscout.androidaps.plugins.pump.common.utils.DateTimeUtil; import info.nightscout.androidaps.utils.DateUtil; +import info.nightscout.androidaps.utils.resources.ResourceHelper; /** * Created by mike on 20.09.2017. @@ -20,7 +17,6 @@ import info.nightscout.androidaps.utils.DateUtil; @DatabaseTable(tableName = DatabaseHelper.DATABASE_TDDS) public class TDD { - private static Logger log = StacktraceLoggerWrapper.getLogger(L.DATABASE); @DatabaseField(id = true) public long date; @@ -35,14 +31,15 @@ public class TDD { public double total; - public double getTotal(){ - return (total > 0d) ? total:(bolus+basal); + public double getTotal() { + return (total > 0d) ? total : (bolus + basal); } - public TDD() { } + public TDD() { + } - public TDD(long date, double bolus, double basal, double total){ + public TDD(long date, double bolus, double basal, double total) { this.date = date; this.bolus = bolus; this.basal = basal; @@ -61,11 +58,11 @@ public class TDD { ']'; } - public String toText() { - return MainApp.gs(R.string.tddformat, DateUtil.dateStringShort(date), total, bolus, basal); + public String toText(ResourceHelper resourceHelper) { + return resourceHelper.gs(R.string.tddformat, DateUtil.dateStringShort(date), total, bolus, basal); } - public String toText(int days) { - return MainApp.gs(R.string.tddformat, String.format("%d ", days) + MainApp.gs(R.string.days), total, bolus, basal); + public String toText(ResourceHelper resourceHelper, int days) { + return resourceHelper.gs(R.string.tddformat, String.format(Locale.getDefault(), "%d ", days) + resourceHelper.gs(R.string.days), total, bolus, basal); } } diff --git a/app/src/main/java/info/nightscout/androidaps/dependencyInjection/AppComponent.kt b/app/src/main/java/info/nightscout/androidaps/dependencyInjection/AppComponent.kt index ccb6b2eb46..7d9dcac987 100644 --- a/app/src/main/java/info/nightscout/androidaps/dependencyInjection/AppComponent.kt +++ b/app/src/main/java/info/nightscout/androidaps/dependencyInjection/AppComponent.kt @@ -29,6 +29,16 @@ import info.nightscout.androidaps.plugins.iob.iobCobCalculator.AutosensData import info.nightscout.androidaps.plugins.iob.iobCobCalculator.GlucoseStatus import info.nightscout.androidaps.plugins.iob.iobCobCalculator.IobCobOref1Thread import info.nightscout.androidaps.plugins.iob.iobCobCalculator.IobCobThread +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkCommunicationManager +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RFSpy +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkBLE +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command.SendAndListen +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command.SetPreamble +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RadioPacket +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RadioResponse +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.* +import info.nightscout.androidaps.plugins.pump.medtronic.comm.MedtronicCommunicationManager +import info.nightscout.androidaps.plugins.pump.medtronic.comm.ui.MedtronicUITask import info.nightscout.androidaps.plugins.treatments.Treatment import info.nightscout.androidaps.queue.CommandQueue import info.nightscout.androidaps.queue.commands.* @@ -185,6 +195,23 @@ interface AppComponent : AndroidInjector { fun injectGraphData(graphData: GraphData) + //Medtronic + fun injectRileyLinkCommunicationManager(rileyLinkCommunicationManager: RileyLinkCommunicationManager) + fun injectMedtronicCommunicationManager(medtronicCommunicationManager: MedtronicCommunicationManager) + fun injectMedtronicUITask(medtronicUITask: MedtronicUITask) + fun injectServiceTask(serviceTask: ServiceTask) + fun injectPumpTask(pumpTask: PumpTask) + fun injectDiscoverGattServicesTask(discoverGattServicesTask: DiscoverGattServicesTask) + fun injectInitializePumpManagerTask(initializePumpManagerTask: InitializePumpManagerTask) + fun injectResetRileyLinkConfigurationTask(resetRileyLinkConfigurationTask: ResetRileyLinkConfigurationTask) + fun injectWakeAndTuneTask(wakeAndTuneTask: WakeAndTuneTask) + fun injectRadioResponse(radioResponse: RadioResponse) + fun injectRileyLinkBLE(rileyLinkBLE: RileyLinkBLE) + fun injectRFSpy(rfSpy: RFSpy) + fun injectSendAndListen(sendAndListen: SendAndListen) + fun injectSetPreamble(setPreamble: SetPreamble) + fun injectRadioPacket(radioPacket: RadioPacket) + @Component.Builder interface Builder { diff --git a/app/src/main/java/info/nightscout/androidaps/dependencyInjection/AppModule.kt b/app/src/main/java/info/nightscout/androidaps/dependencyInjection/AppModule.kt index 1dd34b8100..6d334aa3d4 100644 --- a/app/src/main/java/info/nightscout/androidaps/dependencyInjection/AppModule.kt +++ b/app/src/main/java/info/nightscout/androidaps/dependencyInjection/AppModule.kt @@ -46,6 +46,16 @@ import info.nightscout.androidaps.plugins.iob.iobCobCalculator.AutosensData import info.nightscout.androidaps.plugins.iob.iobCobCalculator.GlucoseStatus import info.nightscout.androidaps.plugins.iob.iobCobCalculator.IobCobOref1Thread import info.nightscout.androidaps.plugins.iob.iobCobCalculator.IobCobThread +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkCommunicationManager +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RFSpy +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkBLE +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command.SendAndListen +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command.SetPreamble +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RadioPacket +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RadioResponse +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.* +import info.nightscout.androidaps.plugins.pump.medtronic.comm.MedtronicCommunicationManager +import info.nightscout.androidaps.plugins.pump.medtronic.comm.ui.MedtronicUITask import info.nightscout.androidaps.plugins.treatments.Treatment import info.nightscout.androidaps.queue.CommandQueue import info.nightscout.androidaps.queue.commands.* @@ -278,6 +288,23 @@ open class AppModule { @Binds fun bindContext(mainApp: MainApp): Context @Binds fun bindInjector(mainApp: MainApp): HasAndroidInjector + // Medtronic + @ContributesAndroidInjector fun rileyLinkCommunicationManagerProvider(): RileyLinkCommunicationManager + @ContributesAndroidInjector fun medtronicCommunicationManagerProvider(): MedtronicCommunicationManager + @ContributesAndroidInjector fun medtronicUITaskProvider(): MedtronicUITask + @ContributesAndroidInjector fun serviceTaskProvider(): ServiceTask + @ContributesAndroidInjector fun pumpTaskProvider(): PumpTask + @ContributesAndroidInjector fun discoverGattServicesTaskProvider(): DiscoverGattServicesTask + @ContributesAndroidInjector fun initializePumpManagerTaskProvider(): InitializePumpManagerTask + @ContributesAndroidInjector fun resetRileyLinkConfigurationTaskProvider(): ResetRileyLinkConfigurationTask + @ContributesAndroidInjector fun wakeAndTuneTaskProvider(): WakeAndTuneTask + @ContributesAndroidInjector fun radioResponseProvider(): RadioResponse + @ContributesAndroidInjector fun rileyLinkBLEProvider(): RileyLinkBLE + @ContributesAndroidInjector fun rfSpyProvider(): RFSpy + @ContributesAndroidInjector fun sendAndListenProvider(): SendAndListen + @ContributesAndroidInjector fun setPreambleProvider(): SetPreamble + @ContributesAndroidInjector fun radioPacketProvider(): RadioPacket + @Binds fun bindActivePluginProvider(pluginStore: PluginStore): ActivePluginProvider diff --git a/app/src/main/java/info/nightscout/androidaps/dependencyInjection/FragmentsModule.kt b/app/src/main/java/info/nightscout/androidaps/dependencyInjection/FragmentsModule.kt index 164dd0def0..87129bbb37 100644 --- a/app/src/main/java/info/nightscout/androidaps/dependencyInjection/FragmentsModule.kt +++ b/app/src/main/java/info/nightscout/androidaps/dependencyInjection/FragmentsModule.kt @@ -32,9 +32,12 @@ import info.nightscout.androidaps.plugins.insulin.InsulinFragment import info.nightscout.androidaps.plugins.profile.local.LocalProfileFragment import info.nightscout.androidaps.plugins.profile.ns.NSProfileFragment import info.nightscout.androidaps.plugins.pump.combo.ComboFragment +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.dialog.RileyLinkStatusGeneralFragment +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.dialog.RileyLinkStatusHistoryFragment import info.nightscout.androidaps.plugins.pump.danaR.DanaRFragment import info.nightscout.androidaps.plugins.pump.insight.LocalInsightFragment import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicFragment +import info.nightscout.androidaps.plugins.pump.medtronic.dialog.RileyLinkStatusDeviceMedtronic import info.nightscout.androidaps.plugins.pump.virtual.VirtualPumpFragment import info.nightscout.androidaps.plugins.source.BGSourceFragment import info.nightscout.androidaps.plugins.treatments.TreatmentsFragment @@ -113,4 +116,8 @@ abstract class FragmentsModule { @ContributesAndroidInjector abstract fun contributesWizardInfoDialog(): WizardInfoDialog @ContributesAndroidInjector abstract fun contributesPasswordCheck(): PasswordCheck + + @ContributesAndroidInjector abstract fun contributesRileyLinkStatusGeneral(): RileyLinkStatusGeneralFragment + @ContributesAndroidInjector abstract fun contributesRileyLinkStatusHistoryFragment(): RileyLinkStatusHistoryFragment + @ContributesAndroidInjector abstract fun contributesRileyLinkStatusDeviceMedtronic(): RileyLinkStatusDeviceMedtronic } \ No newline at end of file diff --git a/app/src/main/java/info/nightscout/androidaps/dependencyInjection/ReceiversModule.kt b/app/src/main/java/info/nightscout/androidaps/dependencyInjection/ReceiversModule.kt index 6aa97bee69..0921ed7cd0 100644 --- a/app/src/main/java/info/nightscout/androidaps/dependencyInjection/ReceiversModule.kt +++ b/app/src/main/java/info/nightscout/androidaps/dependencyInjection/ReceiversModule.kt @@ -3,6 +3,7 @@ package info.nightscout.androidaps.dependencyInjection import dagger.Module import dagger.android.ContributesAndroidInjector import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkBluetoothStateReceiver +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkBroadcastReceiver import info.nightscout.androidaps.receivers.* @Module @@ -17,4 +18,6 @@ abstract class ReceiversModule { @ContributesAndroidInjector abstract fun contributesRileyLinkBluetoothStateReceiver(): RileyLinkBluetoothStateReceiver @ContributesAndroidInjector abstract fun contributesSmsReceiver(): SmsReceiver @ContributesAndroidInjector abstract fun contributesTimeDateOrTZChangeReceiver(): TimeDateOrTZChangeReceiver + + @ContributesAndroidInjector abstract fun contributesRileyLinkBroadcastReceiver(): RileyLinkBroadcastReceiver } \ No newline at end of file diff --git a/app/src/main/java/info/nightscout/androidaps/dialogs/CareDialog.kt b/app/src/main/java/info/nightscout/androidaps/dialogs/CareDialog.kt index 3ca03ead97..e561cb0890 100644 --- a/app/src/main/java/info/nightscout/androidaps/dialogs/CareDialog.kt +++ b/app/src/main/java/info/nightscout/androidaps/dialogs/CareDialog.kt @@ -36,6 +36,7 @@ class CareDialog : DialogFragmentWithDate() { @Inject lateinit var mainApp: MainApp @Inject lateinit var resourceHelper: ResourceHelper @Inject lateinit var profileFunction: ProfileFunction + @Inject lateinit var translator: Translator enum class EventType { BGCHECK, @@ -149,7 +150,7 @@ class CareDialog : DialogFragmentWithDate() { actions_care_sensor.isChecked -> "Sensor" else -> "Manual" } - actions.add(resourceHelper.gs(R.string.careportal_newnstreatment_glucosetype) + ": " + Translator.translate(type)) + actions.add(resourceHelper.gs(R.string.careportal_newnstreatment_glucosetype) + ": " + translator.translate(type)) actions.add(resourceHelper.gs(R.string.treatments_wizard_bg_label) + ": " + Profile.toCurrentUnitsString(profileFunction, actions_care_bg.value) + " " + resourceHelper.gs(unitResId)) json.put("glucose", actions_care_bg.value) json.put("glucoseType", type) diff --git a/app/src/main/java/info/nightscout/androidaps/logging/AAPSLogger.kt b/app/src/main/java/info/nightscout/androidaps/logging/AAPSLogger.kt index 8c24805261..fe47fea99d 100644 --- a/app/src/main/java/info/nightscout/androidaps/logging/AAPSLogger.kt +++ b/app/src/main/java/info/nightscout/androidaps/logging/AAPSLogger.kt @@ -11,6 +11,7 @@ interface AAPSLogger { fun debug(tag: LTag, message: String) fun debug(tag: LTag, format: String, vararg arguments: Any?) fun warn(tag: LTag, message: String) + fun warn(tag: LTag, format: String, vararg arguments: Any?) fun info(tag: LTag, message: String) fun info(tag: LTag, format: String, vararg arguments: Any?) fun error(tag: LTag, message: String) diff --git a/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerDebug.kt b/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerDebug.kt index b930eb4728..ba7f88712d 100644 --- a/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerDebug.kt +++ b/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerDebug.kt @@ -28,6 +28,10 @@ class AAPSLoggerDebug : AAPSLogger { Log.w(tag.tag, message) } + override fun warn(tag: LTag, format: String, vararg arguments: Any?) { + Log.w(tag.tag, String.format(format, arguments)) + } + override fun info(tag: LTag, message: String) { Log.i(tag.tag, message) } diff --git a/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerProduction.kt b/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerProduction.kt index 27b0946749..3b71419cab 100644 --- a/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerProduction.kt +++ b/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerProduction.kt @@ -26,7 +26,7 @@ class AAPSLoggerProduction : AAPSLogger { override fun debug(tag: LTag, format: String, vararg arguments: Any?) { if (L.isEnabled(tag.tag)) - LoggerFactory.getLogger(tag.tag).debug(stackLogMarker() + String.format(format, arguments)) + LoggerFactory.getLogger(tag.tag).debug(stackLogMarker() + format, arguments) } override fun warn(tag: LTag, message: String) { @@ -35,6 +35,10 @@ class AAPSLoggerProduction : AAPSLogger { } } + override fun warn(tag: LTag, format: String, vararg arguments: Any?) { + LoggerFactory.getLogger(tag.tag).warn(stackLogMarker() + format, arguments) + } + override fun info(tag: LTag, message: String) { if (L.isEnabled(tag.tag)) { LoggerFactory.getLogger(tag.tag).info(stackLogMarker() + message) @@ -43,7 +47,7 @@ class AAPSLoggerProduction : AAPSLogger { } override fun info(tag: LTag, format: String, vararg arguments: Any?) { - LoggerFactory.getLogger(tag.tag).info(stackLogMarker() + String.format(format, arguments)) + LoggerFactory.getLogger(tag.tag).info(stackLogMarker() + format, arguments) } override fun error(tag: LTag, message: String) { @@ -61,7 +65,7 @@ class AAPSLoggerProduction : AAPSLogger { } override fun error(format: String, vararg arguments: Any?) { - LoggerFactory.getLogger(LTag.CORE.tag).error(stackLogMarker() + String.format(format, arguments)) + LoggerFactory.getLogger(LTag.CORE.tag).error(stackLogMarker() + format, arguments) } override fun error(tag: LTag, message: String, throwable: Throwable) { @@ -72,7 +76,7 @@ class AAPSLoggerProduction : AAPSLogger { override fun error(tag: LTag, format: String, vararg arguments: Any?) { if (L.isEnabled(tag.tag)) { - LoggerFactory.getLogger(tag.tag).error(stackLogMarker() + String.format(format, arguments)) + LoggerFactory.getLogger(tag.tag).error(stackLogMarker() + format, arguments) } } } diff --git a/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerTest.kt b/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerTest.kt index 0503db143f..5f6b798e36 100644 --- a/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerTest.kt +++ b/app/src/main/java/info/nightscout/androidaps/logging/AAPSLoggerTest.kt @@ -26,6 +26,10 @@ class AAPSLoggerTest : AAPSLogger { println("WARN: " + tag.tag + " " + message) } + override fun warn(tag: LTag, format: String, vararg arguments: Any?) { + println("INFO: : " + tag.tag + " " + String.format(format, arguments)) + } + override fun info(tag: LTag, message: String) { println("INFO: " + tag.tag + " " + message) } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/general/careportal/Dialogs/NewNSTreatmentDialog.java b/app/src/main/java/info/nightscout/androidaps/plugins/general/careportal/Dialogs/NewNSTreatmentDialog.java index f155d3e3f2..0c7dd11e83 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/general/careportal/Dialogs/NewNSTreatmentDialog.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/general/careportal/Dialogs/NewNSTreatmentDialog.java @@ -78,6 +78,7 @@ public class NewNSTreatmentDialog extends DaggerDialogFragment implements View.O @Inject ActivePluginProvider activePlugin; @Inject TreatmentsPlugin treatmentsPlugin; @Inject HardLimits hardLimits; + @Inject Translator translator; private static OptionsToShow options; private static @StringRes int event; @@ -623,7 +624,7 @@ public class NewNSTreatmentDialog extends DaggerDialogFragment implements View.O if (data.has("glucoseType")) { ret += resourceHelper.gs(R.string.careportal_newnstreatment_glucosetype); ret += ": "; - ret += Translator.translate(JsonHelper.safeGetString(data, "glucoseType", "")); + ret += translator.translate(JsonHelper.safeGetString(data, "glucoseType", "")); ret += "\n"; } if (data.has("carbs")) { @@ -712,7 +713,7 @@ public class NewNSTreatmentDialog extends DaggerDialogFragment implements View.O private void confirmNSTreatmentCreation() { final JSONObject data = gatherData(); - OKDialog.showConfirmation(getContext(), Translator.translate(JsonHelper.safeGetString(data, "eventType", resourceHelper.gs(R.string.overview_treatment_label))), buildConfirmText(data), () -> NSUpload.createNSTreatment(data, profileStore, profileFunction, eventTime.getTime())); + OKDialog.showConfirmation(getContext(), translator.translate(JsonHelper.safeGetString(data, "eventType", resourceHelper.gs(R.string.overview_treatment_label))), buildConfirmText(data), () -> NSUpload.createNSTreatment(data, profileStore, profileFunction, eventTime.getTime())); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/PumpPluginAbstract.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/PumpPluginAbstract.java index ebea05f906..efca466951 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/PumpPluginAbstract.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/PumpPluginAbstract.java @@ -37,6 +37,7 @@ import info.nightscout.androidaps.plugins.general.overview.events.EventOverviewB import info.nightscout.androidaps.plugins.pump.common.data.PumpStatus; import info.nightscout.androidaps.plugins.pump.common.defs.PumpDriverState; import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkService; import info.nightscout.androidaps.plugins.pump.medtronic.data.MedtronicHistoryData; import info.nightscout.androidaps.plugins.treatments.Treatment; import info.nightscout.androidaps.utils.DateUtil; @@ -70,7 +71,6 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI .enacted(false).comment(MainApp.gs(R.string.pump_operation_not_yet_supported_by_pump)); */ protected PumpDescription pumpDescription = new PumpDescription(); - protected PumpStatus pumpStatus; protected ServiceConnection serviceConnection = null; protected boolean serviceRunning = false; // protected boolean isInitialized = false; @@ -109,6 +109,11 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI public abstract void initPumpStatusData(); + public abstract void resetRileyLinkConfiguration(); + + public abstract void doTuneUpDevice(); + + public abstract RileyLinkService getRileyLinkService(); @Override protected void onStart() { @@ -124,7 +129,7 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI disposable.add(rxBus .toObservable(EventAppExit.class) .observeOn(Schedulers.io()) - .subscribe(event -> context.unbindService(serviceConnection), exception -> fabricPrivacy.logException(exception)) + .subscribe(event -> context.unbindService(serviceConnection), fabricPrivacy::logException) ); onStartCustomActions(); } @@ -153,9 +158,7 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI */ public abstract Class getServiceClass(); - public PumpStatus getPumpStatusData() { - return pumpStatus; - } + public abstract PumpStatus getPumpStatusData(); public boolean isInitialized() { @@ -219,12 +222,6 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI aapsLogger.debug(LTag.PUMP, "finishHandshaking [PumpPluginAbstract] - default (empty) implementation."); } - - public void getPumpStatus() { - aapsLogger.debug(LTag.PUMP, "getPumpStatus [PumpPluginAbstract] - Not implemented."); - } - - // Upload to pump new basal profile @NonNull public PumpEnactResult setNewBasalProfile(Profile profile) { aapsLogger.debug(LTag.PUMP, "setNewBasalProfile [PumpPluginAbstract] - Not implemented."); @@ -240,7 +237,7 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI public long lastDataTime() { aapsLogger.debug(LTag.PUMP, "lastDataTime [PumpPluginAbstract]."); - return pumpStatus.lastConnection; + return getPumpStatusData().lastConnection; } @@ -329,7 +326,7 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI @NonNull @Override public JSONObject getJSONStatus(Profile profile, String profileName) { - if ((pumpStatus.lastConnection + 5 * 60 * 1000L) < System.currentTimeMillis()) { + if ((getPumpStatusData().lastConnection + 5 * 60 * 1000L) < System.currentTimeMillis()) { return new JSONObject(); } @@ -338,8 +335,8 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI JSONObject status = new JSONObject(); JSONObject extended = new JSONObject(); try { - battery.put("percent", pumpStatus.batteryRemaining); - status.put("status", pumpStatus.pumpStatusType != null ? pumpStatus.pumpStatusType.getStatus() : "normal"); + battery.put("percent", getPumpStatusData().batteryRemaining); + status.put("status", getPumpStatusData().pumpStatusType != null ? getPumpStatusData().pumpStatusType.getStatus() : "normal"); extended.put("Version", BuildConfig.VERSION_NAME + "-" + BuildConfig.BUILDVERSION); try { extended.put("ActiveProfile", profileName); @@ -366,7 +363,7 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI pump.put("battery", battery); pump.put("status", status); pump.put("extended", extended); - pump.put("reservoir", pumpStatus.reservoirRemainingUnits); + pump.put("reservoir", getPumpStatusData().reservoirRemainingUnits); pump.put("clock", DateUtil.toISOString(new Date())); } catch (JSONException e) { aapsLogger.error("Unhandled exception", e); @@ -379,14 +376,14 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI @NonNull @Override public String shortStatus(boolean veryShort) { String ret = ""; - if (pumpStatus.lastConnection != 0) { - long agoMsec = System.currentTimeMillis() - pumpStatus.lastConnection; + if (getPumpStatusData().lastConnection != 0) { + long agoMsec = System.currentTimeMillis() - getPumpStatusData().lastConnection; int agoMin = (int) (agoMsec / 60d / 1000d); ret += "LastConn: " + agoMin + " min ago\n"; } - if (pumpStatus.lastBolusTime != null && pumpStatus.lastBolusTime.getTime() != 0) { - ret += "LastBolus: " + DecimalFormatter.to2Decimal(pumpStatus.lastBolusAmount) + "U @" + // - android.text.format.DateFormat.format("HH:mm", pumpStatus.lastBolusTime) + "\n"; + if (getPumpStatusData().lastBolusTime != null && getPumpStatusData().lastBolusTime.getTime() != 0) { + ret += "LastBolus: " + DecimalFormatter.to2Decimal(getPumpStatusData().lastBolusAmount) + "U @" + // + android.text.format.DateFormat.format("HH:mm", getPumpStatusData().lastBolusTime) + "\n"; } TemporaryBasal activeTemp = activePlugin.getActiveTreatments().getRealTempBasalFromHistory(System.currentTimeMillis()); if (activeTemp != null) { @@ -401,9 +398,9 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI // ret += "TDD: " + DecimalFormatter.to0Decimal(pumpStatus.dailyTotalUnits) + " / " // + pumpStatus.maxDailyTotalUnits + " U\n"; // } - ret += "IOB: " + pumpStatus.iob + "U\n"; - ret += "Reserv: " + DecimalFormatter.to0Decimal(pumpStatus.reservoirRemainingUnits) + "U\n"; - ret += "Batt: " + pumpStatus.batteryRemaining + "\n"; + ret += "IOB: " + getPumpStatusData().iob + "U\n"; + ret += "Reserv: " + DecimalFormatter.to0Decimal(getPumpStatusData().reservoirRemainingUnits) + "U\n"; + ret += "Batt: " + getPumpStatusData().batteryRemaining + "\n"; return ret; } @@ -451,7 +448,7 @@ public abstract class PumpPluginAbstract extends PumpPluginBase implements PumpI public ManufacturerType manufacturer() { - return pumpType.getManufacturer() ; + return pumpType.getManufacturer(); } @NotNull diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/data/PumpStatus.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/data/PumpStatus.java index fee0ac914d..b704de584f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/data/PumpStatus.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/data/PumpStatus.java @@ -1,13 +1,11 @@ package info.nightscout.androidaps.plugins.pump.common.data; -import org.joda.time.LocalDateTime; - import java.util.Date; import info.nightscout.androidaps.data.ProfileStore; -import info.nightscout.androidaps.interfaces.PumpDescription; import info.nightscout.androidaps.plugins.pump.common.defs.PumpStatusType; import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; +import info.nightscout.androidaps.utils.DateUtil; /** * Created by andy on 4/28/18. @@ -16,7 +14,7 @@ import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; public abstract class PumpStatus { // connection - public LocalDateTime lastDataTime; + public long lastDataTime; public long lastConnection = 0L; public long previousConnection = 0L; // here should be stored last connection of previous session (so needs to be // read before lastConnection is modified for first time). @@ -42,7 +40,6 @@ public abstract class PumpStatus { public Double dailyTotalUnits; public String maxDailyTotalUnits; public boolean validBasalRateProfileSelectedOnPump = true; - public PumpType pumpType = PumpType.GenericAAPS; public ProfileStore profileStore; public String units; // Constants.MGDL or Constants.MMOL public PumpStatusType pumpStatusType = PumpStatusType.Running; @@ -52,21 +49,19 @@ public abstract class PumpStatus { public int tempBasalRatio = 0; public int tempBasalRemainMin = 0; public Date tempBasalStart; - protected PumpDescription pumpDescription; + //protected PumpDescription pumpDescription; - public PumpStatus(PumpDescription pumpDescription) { - this.pumpDescription = pumpDescription; + public PumpStatus() { + // public PumpStatus(PumpDescription pumpDescription) { + // this.pumpDescription = pumpDescription; - this.initSettings(); +// this.initSettings(); } - public abstract void initSettings(); - - public void setLastCommunicationToNow() { - this.lastDataTime = LocalDateTime.now(); + this.lastDataTime = DateUtil.now(); this.lastConnection = System.currentTimeMillis(); } @@ -74,23 +69,5 @@ public abstract class PumpStatus { this.lastErrorConnection = System.currentTimeMillis(); } - public abstract String getErrorInfo(); - - - public abstract void refreshConfiguration(); - - - public PumpType getPumpType() { - return pumpType; - } - - - public void setPumpType(PumpType pumpType) { - this.pumpType = pumpType; - } - - // public Date last_bolus_time; - // public double last_bolus_amount = 0; - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/data/TempBasalPair.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/data/TempBasalPair.java index 1e53734b5f..08ff0c3b49 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/data/TempBasalPair.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/data/TempBasalPair.java @@ -9,8 +9,6 @@ import info.nightscout.androidaps.logging.L; public class TempBasalPair { - private static final Logger LOG = LoggerFactory.getLogger(L.PUMPCOMM); - @Expose protected double insulinRate = 0.0d; @Expose diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/dialog/RileyLinkBLEScanActivity.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/dialog/RileyLinkBLEScanActivity.java index e292808ded..50a617a94b 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/dialog/RileyLinkBLEScanActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/dialog/RileyLinkBLEScanActivity.java @@ -47,9 +47,8 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkCons import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.GattAttributes; import info.nightscout.androidaps.plugins.pump.common.utils.LocationHelper; -import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpStatus; +import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.events.EventMedtronicPumpConfigurationChanged; -import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; import info.nightscout.androidaps.utils.resources.ResourceHelper; import info.nightscout.androidaps.utils.sharedPreferences.SP; @@ -60,6 +59,9 @@ public class RileyLinkBLEScanActivity extends NoSplashAppCompatActivity { @Inject SP sp; @Inject RxBusWrapper rxBus; @Inject ResourceHelper resourceHelper; + @Inject RileyLinkUtil rileyLinkUtil; + // TODO change this. Currently verifyConfiguration uses MDT data not only RL + @Inject MedtronicPumpPlugin medtronicPumpPlugin; private static final int PERMISSION_REQUEST_COARSE_LOCATION = 30241; // arbitrary. private static final int REQUEST_ENABLE_BT = 30242; // arbitrary @@ -108,10 +110,7 @@ public class RileyLinkBLEScanActivity extends NoSplashAppCompatActivity { sp.putString(RileyLinkConst.Prefs.RileyLinkAddress, bleAddress); - RileyLinkUtil.getRileyLinkSelectPreference().setSummary(bleAddress); - - MedtronicPumpStatus pumpStatus = MedtronicUtil.getPumpStatus(); - pumpStatus.verifyConfiguration(); // force reloading of address + medtronicPumpPlugin.getRileyLinkService().verifyConfiguration(); // force reloading of address rxBus.send(new EventMedtronicPumpConfigurationChanged()); @@ -189,7 +188,7 @@ public class RileyLinkBLEScanActivity extends NoSplashAppCompatActivity { } // disable currently selected RL, so that we can discover it - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkDisconnect); + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkDisconnect, this); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/RileyLinkCommunicationManager.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/RileyLinkCommunicationManager.java index 47d2181252..4887d3d4a3 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/RileyLinkCommunicationManager.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/RileyLinkCommunicationManager.java @@ -1,10 +1,10 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; +import javax.inject.Inject; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.data.PumpStatus; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RFSpy; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkCommunicationException; @@ -21,8 +21,8 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.WakeAndTuneTask; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; -import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; -import info.nightscout.androidaps.utils.SP; +import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpStatus; +import info.nightscout.androidaps.utils.sharedPreferences.SP; /** * This is abstract class for RileyLink Communication, this one needs to be extended by specific "Pump" class. @@ -31,83 +31,83 @@ import info.nightscout.androidaps.utils.SP; */ public abstract class RileyLinkCommunicationManager { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + @Inject protected AAPSLogger aapsLogger; + @Inject protected SP sp; - private static final int SCAN_TIMEOUT = 1500; - private static final int ALLOWED_PUMP_UNREACHABLE = 10 * 60 * 1000; // 10 minutes + @Inject MedtronicPumpStatus medtronicPumpStatus; + @Inject RileyLinkServiceData rileyLinkServiceData; + @Inject ServiceTaskExecutor serviceTaskExecutor; + + private final int SCAN_TIMEOUT = 1500; + private final int ALLOWED_PUMP_UNREACHABLE = 10 * 60 * 1000; // 10 minutes + + protected final HasAndroidInjector injector; protected final RFSpy rfspy; protected int receiverDeviceAwakeForMinutes = 1; // override this in constructor of specific implementation protected String receiverDeviceID; // String representation of receiver device (ex. Pump (xxxxxx) or Pod (yyyyyy)) protected long lastGoodReceiverCommunicationTime = 0; - protected PumpStatus pumpStatus; - protected RileyLinkServiceData rileyLinkServiceData; + // protected PumpStatus pumpStatus; private long nextWakeUpRequired = 0L; - // internal flag - private boolean showPumpMessages = true; private int timeoutCount = 0; - public RileyLinkCommunicationManager(RFSpy rfspy) { + public RileyLinkCommunicationManager(HasAndroidInjector injector, RFSpy rfspy) { + this.injector = injector; + injector.androidInjector().inject(this); this.rfspy = rfspy; - this.rileyLinkServiceData = RileyLinkUtil.getRileyLinkServiceData(); - RileyLinkUtil.setRileyLinkCommunicationManager(this); - - configurePumpSpecificSettings(); } - protected abstract void configurePumpSpecificSettings(); - - // All pump communications go through this function. - public E sendAndListen(RLMessage msg, int timeout_ms, Class clazz) + protected E sendAndListen(RLMessage msg, int timeout_ms, Class clazz) throws RileyLinkCommunicationException { return sendAndListen(msg, timeout_ms, null, clazz); } - public E sendAndListen(RLMessage msg, int timeout_ms, Integer extendPreamble_ms, Class clazz) + private E sendAndListen(RLMessage msg, int timeout_ms, Integer extendPreamble_ms, Class clazz) throws RileyLinkCommunicationException { return sendAndListen(msg, timeout_ms, 0, extendPreamble_ms, clazz); } // For backward compatibility - public E sendAndListen(RLMessage msg, int timeout_ms, int repeatCount, Integer extendPreamble_ms, Class clazz) + private E sendAndListen(RLMessage msg, int timeout_ms, int repeatCount, Integer extendPreamble_ms, Class clazz) throws RileyLinkCommunicationException { return sendAndListen(msg, timeout_ms, repeatCount, 0, extendPreamble_ms, clazz); } - public E sendAndListen(RLMessage msg, int timeout_ms, int repeatCount, int retryCount, Integer extendPreamble_ms, Class clazz) + private E sendAndListen(RLMessage msg, int timeout_ms, int repeatCount, int retryCount, Integer extendPreamble_ms, Class clazz) throws RileyLinkCommunicationException { + // internal flag + boolean showPumpMessages = true; if (showPumpMessages) { - if (isLogEnabled()) - LOG.info("Sent:" + ByteUtil.shortHexString(msg.getTxData())); + aapsLogger.info(LTag.PUMPCOMM, "Sent:" + ByteUtil.shortHexString(msg.getTxData())); } - RFSpyResponse rfSpyResponse = rfspy.transmitThenReceive(new RadioPacket(msg.getTxData()), - (byte)0, (byte)repeatCount, (byte)0, (byte)0, timeout_ms, (byte)retryCount, extendPreamble_ms); + RFSpyResponse rfSpyResponse = rfspy.transmitThenReceive(new RadioPacket(injector, msg.getTxData()), + (byte) 0, (byte) repeatCount, (byte) 0, (byte) 0, timeout_ms, (byte) retryCount, extendPreamble_ms); - RadioResponse radioResponse = rfSpyResponse.getRadioResponse(); + RadioResponse radioResponse = rfSpyResponse.getRadioResponse(injector); E response = createResponseMessage(radioResponse.getPayload(), clazz); if (response.isValid()) { // Mark this as the last time we heard from the pump. rememberLastGoodDeviceCommunicationTime(); } else { - LOG.warn("isDeviceReachable. Response is invalid ! [interrupted={}, timeout={}, unknownCommand={}, invalidParam={}]", rfSpyResponse.wasInterrupted(), + aapsLogger.warn(LTag.PUMPCOMM, "isDeviceReachable. Response is invalid ! [interrupted={}, timeout={}, unknownCommand={}, invalidParam={}]", rfSpyResponse.wasInterrupted(), rfSpyResponse.wasTimeout(), rfSpyResponse.isUnknownCommand(), rfSpyResponse.isInvalidParam()); if (rfSpyResponse.wasTimeout()) { if (hasTunning()) { timeoutCount++; - long diff = System.currentTimeMillis() - pumpStatus.lastConnection; + long diff = System.currentTimeMillis() - getPumpStatus().lastConnection; if (diff > ALLOWED_PUMP_UNREACHABLE) { - LOG.warn("We reached max time that Pump can be unreachable. Starting Tuning."); - ServiceTaskExecutor.startTask(new WakeAndTuneTask()); + aapsLogger.warn(LTag.PUMPCOMM, "We reached max time that Pump can be unreachable. Starting Tuning."); + serviceTaskExecutor.startTask(new WakeAndTuneTask(injector)); timeoutCount = 0; } } @@ -119,8 +119,7 @@ public abstract class RileyLinkCommunicationManager { } if (showPumpMessages) { - if (isLogEnabled()) - LOG.info("Received:" + ByteUtil.shortHexString(rfSpyResponse.getRadioResponse().getPayload())); + aapsLogger.info(LTag.PUMPCOMM, "Received:" + ByteUtil.shortHexString(rfSpyResponse.getRadioResponse(injector).getPayload())); } return response; @@ -151,27 +150,24 @@ public abstract class RileyLinkCommunicationManager { // **** FIXME: this wakeup doesn't seem to work well... must revisit // receiverDeviceAwakeForMinutes = duration_minutes; - MedtronicUtil.setPumpDeviceState(PumpDeviceState.WakingUp); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.WakingUp); if (force) nextWakeUpRequired = 0L; if (System.currentTimeMillis() > nextWakeUpRequired) { - if (isLogEnabled()) - LOG.info("Waking pump..."); + aapsLogger.info(LTag.PUMPCOMM, "Waking pump..."); byte[] pumpMsgContent = createPumpMessageContent(RLMessageType.ReadSimpleData); // simple - RFSpyResponse resp = rfspy.transmitThenReceive(new RadioPacket(pumpMsgContent), (byte)0, (byte)200, - (byte)0, (byte)0, 25000, (byte)0); - if (isLogEnabled()) - LOG.info("wakeup: raw response is " + ByteUtil.shortHexString(resp.getRaw())); + RFSpyResponse resp = rfspy.transmitThenReceive(new RadioPacket(injector, pumpMsgContent), (byte) 0, (byte) 200, + (byte) 0, (byte) 0, 25000, (byte) 0); + aapsLogger.info(LTag.PUMPCOMM, "wakeup: raw response is " + ByteUtil.shortHexString(resp.getRaw())); // FIXME wakeUp successful !!!!!!!!!!!!!!!!!! nextWakeUpRequired = System.currentTimeMillis() + (receiverDeviceAwakeForMinutes * 60 * 1000); } else { - if (isLogEnabled()) - LOG.trace("Last pump communication was recent, not waking pump."); + aapsLogger.debug(LTag.PUMPCOMM, "Last pump communication was recent, not waking pump."); } // long lastGoodPlus = getLastGoodReceiverCommunicationTime() + (receiverDeviceAwakeForMinutes * 60 * 1000); @@ -195,7 +191,7 @@ public abstract class RileyLinkCommunicationManager { public double tuneForDevice() { - return scanForDevice(RileyLinkUtil.getRileyLinkTargetFrequency().getScanFrequencies()); + return scanForDevice(rileyLinkServiceData.rileyLinkTargetFrequency.getScanFrequencies()); } @@ -209,7 +205,7 @@ public abstract class RileyLinkCommunicationManager { */ public boolean isValidFrequency(double frequency) { - double[] scanFrequencies = RileyLinkUtil.getRileyLinkTargetFrequency().getScanFrequencies(); + double[] scanFrequencies = rileyLinkServiceData.rileyLinkTargetFrequency.getScanFrequencies(); if (scanFrequencies.length == 1) { return RileyLinkUtil.isSame(scanFrequencies[0], frequency); @@ -227,9 +223,8 @@ public abstract class RileyLinkCommunicationManager { public abstract boolean tryToConnectToDevice(); - public double scanForDevice(double[] frequencies) { - if (isLogEnabled()) - LOG.info("Scanning for receiver ({})", receiverDeviceID); + private double scanForDevice(double[] frequencies) { + aapsLogger.info(LTag.PUMPCOMM, "Scanning for receiver ({})", receiverDeviceID); wakeUp(receiverDeviceAwakeForMinutes, false); FrequencyScanResults results = new FrequencyScanResults(); @@ -243,12 +238,12 @@ public abstract class RileyLinkCommunicationManager { for (int j = 0; j < tries; j++) { byte[] pumpMsgContent = createPumpMessageContent(RLMessageType.ReadSimpleData); - RFSpyResponse resp = rfspy.transmitThenReceive(new RadioPacket(pumpMsgContent), (byte)0, (byte)0, - (byte)0, (byte)0, 1250, (byte)0); + RFSpyResponse resp = rfspy.transmitThenReceive(new RadioPacket(injector, pumpMsgContent), (byte) 0, (byte) 0, + (byte) 0, (byte) 0, 1250, (byte) 0); if (resp.wasTimeout()) { - LOG.error("scanForPump: Failed to find pump at frequency {}", frequencies[i]); + aapsLogger.error(LTag.PUMPCOMM, "scanForPump: Failed to find pump at frequency {}", frequencies[i]); } else if (resp.looksLikeRadioPacket()) { - RadioResponse radioResponse = new RadioResponse(); + RadioResponse radioResponse = new RadioResponse(injector); try { @@ -260,23 +255,23 @@ public abstract class RileyLinkCommunicationManager { trial.rssiList.add(rssi); trial.successes++; } else { - LOG.warn("Failed to parse radio response: " + ByteUtil.shortHexString(resp.getRaw())); + aapsLogger.warn(LTag.PUMPCOMM, "Failed to parse radio response: " + ByteUtil.shortHexString(resp.getRaw())); trial.rssiList.add(-99); } } catch (RileyLinkCommunicationException rle) { - LOG.warn("Failed to decode radio response: " + ByteUtil.shortHexString(resp.getRaw())); + aapsLogger.warn(LTag.PUMPCOMM, "Failed to decode radio response: " + ByteUtil.shortHexString(resp.getRaw())); trial.rssiList.add(-99); } } else { - LOG.error("scanForPump: raw response is " + ByteUtil.shortHexString(resp.getRaw())); + aapsLogger.error(LTag.PUMPCOMM, "scanForPump: raw response is " + ByteUtil.shortHexString(resp.getRaw())); trial.rssiList.add(-99); } trial.tries++; } sumRSSI += -99.0 * (trial.tries - trial.successes); - trial.averageRSSI2 = (double)(sumRSSI) / (double)(trial.tries); + trial.averageRSSI2 = (double) (sumRSSI) / (double) (trial.tries); trial.calculateAverage(); @@ -291,10 +286,10 @@ public abstract class RileyLinkCommunicationManager { FrequencyTrial one = results.trials.get(k); stringBuilder.append(String.format("Scan Result[%s]: Freq=%s, avg RSSI = %s\n", "" + k, "" - + one.frequencyMHz, "" + one.averageRSSI + ", RSSIs =" + one.rssiList)); + + one.frequencyMHz, "" + one.averageRSSI + ", RSSIs =" + one.rssiList)); } - LOG.info(stringBuilder.toString()); + aapsLogger.info(LTag.PUMPCOMM, stringBuilder.toString()); results.sort(); // sorts in ascending order @@ -302,11 +297,10 @@ public abstract class RileyLinkCommunicationManager { results.bestFrequencyMHz = bestTrial.frequencyMHz; if (bestTrial.successes > 0) { rfspy.setBaseFrequency(results.bestFrequencyMHz); - if (isLogEnabled()) - LOG.debug("Best frequency found: " + results.bestFrequencyMHz); + aapsLogger.debug(LTag.PUMPCOMM, "Best frequency found: " + results.bestFrequencyMHz); return results.bestFrequencyMHz; } else { - LOG.error("No pump response during scan."); + aapsLogger.error(LTag.PUMPCOMM, "No pump response during scan."); return 0.0; } } @@ -332,25 +326,25 @@ public abstract class RileyLinkCommunicationManager { rfspy.setBaseFrequency(freqMHz); // RLMessage msg = makeRLMessage(RLMessageType.ReadSimpleData); byte[] pumpMsgContent = createPumpMessageContent(RLMessageType.ReadSimpleData); - RadioPacket pkt = new RadioPacket(pumpMsgContent); - RFSpyResponse resp = rfspy.transmitThenReceive(pkt, (byte)0, (byte)0, (byte)0, (byte)0, SCAN_TIMEOUT, (byte)0); + RadioPacket pkt = new RadioPacket(injector, pumpMsgContent); + RFSpyResponse resp = rfspy.transmitThenReceive(pkt, (byte) 0, (byte) 0, (byte) 0, (byte) 0, SCAN_TIMEOUT, (byte) 0); if (resp.wasTimeout()) { - LOG.warn("tune_tryFrequency: no pump response at frequency {}", freqMHz); + aapsLogger.warn(LTag.PUMPCOMM, "tune_tryFrequency: no pump response at frequency {}", freqMHz); } else if (resp.looksLikeRadioPacket()) { - RadioResponse radioResponse = new RadioResponse(); + RadioResponse radioResponse = new RadioResponse(injector); try { radioResponse.init(resp.getRaw()); if (radioResponse.isValid()) { - LOG.warn("tune_tryFrequency: saw response level {} at frequency {}", radioResponse.rssi, freqMHz); + aapsLogger.warn(LTag.PUMPCOMM, "tune_tryFrequency: saw response level {} at frequency {}", radioResponse.rssi, freqMHz); return calculateRssi(radioResponse.rssi); } else { - LOG.warn("tune_tryFrequency: invalid radio response:" - + ByteUtil.shortHexString(radioResponse.getPayload())); + aapsLogger.warn(LTag.PUMPCOMM, "tune_tryFrequency: invalid radio response:" + + ByteUtil.shortHexString(radioResponse.getPayload())); } } catch (RileyLinkCommunicationException e) { - LOG.warn("Failed to decode radio response: " + ByteUtil.shortHexString(resp.getRaw())); + aapsLogger.warn(LTag.PUMPCOMM, "Failed to decode radio response: " + ByteUtil.shortHexString(resp.getRaw())); } } @@ -368,7 +362,7 @@ public abstract class RileyLinkCommunicationManager { // Try again at larger step size stepsize += 0.05; } else { - if ((int)(evenBetterFrequency * 100) == (int)(betterFrequency * 100)) { + if ((int) (evenBetterFrequency * 100) == (int) (betterFrequency * 100)) { // value did not change, so we're done. break; } @@ -377,16 +371,13 @@ public abstract class RileyLinkCommunicationManager { } if (betterFrequency == 0.0) { // we've failed... caller should try a full scan for pump - if (isLogEnabled()) - LOG.error("quickTuneForPump: failed to find pump"); + aapsLogger.error(LTag.PUMPCOMM, "quickTuneForPump: failed to find pump"); } else { rfspy.setBaseFrequency(betterFrequency); if (betterFrequency != startFrequencyMHz) { - if (isLogEnabled()) - LOG.info("quickTuneForPump: new frequency is {}MHz", betterFrequency); + aapsLogger.info(LTag.PUMPCOMM, "quickTuneForPump: new frequency is {}MHz", betterFrequency); } else { - if (isLogEnabled()) - LOG.info("quickTuneForPump: pump frequency is the same: {}MHz", startFrequencyMHz); + aapsLogger.info(LTag.PUMPCOMM, "quickTuneForPump: pump frequency is the same: {}MHz", startFrequencyMHz); } } return betterFrequency; @@ -394,8 +385,7 @@ public abstract class RileyLinkCommunicationManager { private double quickTunePumpStep(double startFrequencyMHz, double stepSizeMHz) { - if (isLogEnabled()) - LOG.info("Doing quick radio tune for receiver ({})", receiverDeviceID); + aapsLogger.info(LTag.PUMPCOMM, "Doing quick radio tune for receiver ({})", receiverDeviceID); wakeUp(false); int startRssi = tune_tryFrequency(startFrequencyMHz); double lowerFrequency = startFrequencyMHz - stepSizeMHz; @@ -421,42 +411,29 @@ public abstract class RileyLinkCommunicationManager { protected void rememberLastGoodDeviceCommunicationTime() { lastGoodReceiverCommunicationTime = System.currentTimeMillis(); - SP.putLong(RileyLinkConst.Prefs.LastGoodDeviceCommunicationTime, lastGoodReceiverCommunicationTime); - if(pumpStatus != null) { - pumpStatus.setLastCommunicationToNow(); - } + sp.putLong(RileyLinkConst.Prefs.LastGoodDeviceCommunicationTime, lastGoodReceiverCommunicationTime); + getPumpStatus().setLastCommunicationToNow(); } private long getLastGoodReceiverCommunicationTime() { // If we have a value of zero, we need to load from prefs. if (lastGoodReceiverCommunicationTime == 0L) { - lastGoodReceiverCommunicationTime = SP.getLong(RileyLinkConst.Prefs.LastGoodDeviceCommunicationTime, 0L); + lastGoodReceiverCommunicationTime = sp.getLong(RileyLinkConst.Prefs.LastGoodDeviceCommunicationTime, 0L); // Might still be zero, but that's fine. } double minutesAgo = (System.currentTimeMillis() - lastGoodReceiverCommunicationTime) / (1000.0 * 60.0); - if (isLogEnabled()) - LOG.trace("Last good pump communication was " + minutesAgo + " minutes ago."); + aapsLogger.debug(LTag.PUMPCOMM, "Last good pump communication was " + minutesAgo + " minutes ago."); return lastGoodReceiverCommunicationTime; } - - public PumpStatus getPumpStatus() { - return pumpStatus; - } - - public void clearNotConnectedCount() { if (rfspy != null) { rfspy.notConnectedCount = 0; } } - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPCOMM); - } + public abstract PumpStatus getPumpStatus(); - public void setPumpStatus(PumpStatus pumpStatus) { - this.pumpStatus = pumpStatus; - } + public abstract boolean isDeviceReachable(); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/RileyLinkUtil.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/RileyLinkUtil.java index 71006e2c34..8fc900aa90 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/RileyLinkUtil.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/RileyLinkUtil.java @@ -5,9 +5,6 @@ import android.content.Intent; import androidx.localbroadcastmanager.content.LocalBroadcastManager; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import java.nio.ByteBuffer; import java.nio.ByteOrder; import java.nio.charset.StandardCharsets; @@ -15,180 +12,56 @@ import java.util.ArrayList; import java.util.List; import java.util.UUID; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; -import info.nightscout.androidaps.plugins.bus.RxBus; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkBLE; +import javax.inject.Inject; +import javax.inject.Singleton; + import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.encoding.Encoding4b6b; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.encoding.Encoding4b6bGeoff; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkEncodingType; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkFirmwareVersion; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkTargetFrequency; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.data.BleAdvertisedData; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.data.RLHistoryItem; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkError; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkService; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceNotification; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceResult; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceTransport; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.ServiceTask; -import info.nightscout.androidaps.plugins.pump.common.ui.RileyLinkSelectPreference; -import info.nightscout.androidaps.plugins.pump.medtronic.events.EventMedtronicDeviceStatusChange; /** * Created by andy on 17/05/2018. */ +@Singleton public class RileyLinkUtil { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMP); - protected static List historyRileyLink = new ArrayList<>(); - protected static RileyLinkCommunicationManager rileyLinkCommunicationManager; - static ServiceTask currentTask; - private static Context context; - private static RileyLinkBLE rileyLinkBLE; - private static RileyLinkServiceData rileyLinkServiceData; - private static RileyLinkService rileyLinkService; - private static RileyLinkTargetFrequency rileyLinkTargetFrequency; + private List historyRileyLink = new ArrayList<>(); + private ServiceTask currentTask; - private static RileyLinkTargetDevice targetDevice; - private static RileyLinkEncodingType encoding; - private static RileyLinkSelectPreference rileyLinkSelectPreference; - private static Encoding4b6b encoding4b6b; - private static RileyLinkFirmwareVersion firmwareVersion; + private RileyLinkEncodingType encoding; + private Encoding4b6b encoding4b6b; - - public static void setContext(Context contextIn) { - RileyLinkUtil.context = contextIn; + @Inject + public RileyLinkUtil() { } - - public static RileyLinkEncodingType getEncoding() { + public RileyLinkEncodingType getEncoding() { return encoding; } - public static void setEncoding(RileyLinkEncodingType encoding) { - RileyLinkUtil.encoding = encoding; + public void setEncoding(RileyLinkEncodingType encoding) { + this.encoding = encoding; if (encoding == RileyLinkEncodingType.FourByteSixByteLocal) { - RileyLinkUtil.encoding4b6b = new Encoding4b6bGeoff(); + this.encoding4b6b = new Encoding4b6bGeoff(); } } - public static void sendBroadcastMessage(String message) { - if (context != null) { - Intent intent = new Intent(message); - LocalBroadcastManager.getInstance(RileyLinkUtil.context).sendBroadcast(intent); - } + public void sendBroadcastMessage(String message, Context context) { + Intent intent = new Intent(message); + LocalBroadcastManager.getInstance(context).sendBroadcast(intent); } - - public static void setServiceState(RileyLinkServiceState newState) { - setServiceState(newState, null); - } - - - public static RileyLinkError getError() { - if (RileyLinkUtil.rileyLinkServiceData != null) - return RileyLinkUtil.rileyLinkServiceData.errorCode; - else - return null; - } - - - public static RileyLinkServiceState getServiceState() { - return workWithServiceState(null, null, false); - } - - - public static void setServiceState(RileyLinkServiceState newState, RileyLinkError errorCode) { - workWithServiceState(newState, errorCode, true); - } - - - private static synchronized RileyLinkServiceState workWithServiceState(RileyLinkServiceState newState, - RileyLinkError errorCode, boolean set) { - - if (set) { - - RileyLinkUtil.rileyLinkServiceData.serviceState = newState; - RileyLinkUtil.rileyLinkServiceData.errorCode = errorCode; - - if (L.isEnabled(L.PUMP)) - LOG.info("RileyLink State Changed: {} {}", newState, errorCode == null ? "" : " - Error State: " - + errorCode.name()); - - RileyLinkUtil.historyRileyLink.add(new RLHistoryItem(RileyLinkUtil.rileyLinkServiceData.serviceState, - RileyLinkUtil.rileyLinkServiceData.errorCode, targetDevice)); - RxBus.Companion.getINSTANCE().send(new EventMedtronicDeviceStatusChange(newState, errorCode)); - return null; - - } else { - return (RileyLinkUtil.rileyLinkServiceData == null || RileyLinkUtil.rileyLinkServiceData.serviceState == null) ? // - RileyLinkServiceState.NotStarted - : RileyLinkUtil.rileyLinkServiceData.serviceState; - } - - } - - - public static RileyLinkBLE getRileyLinkBLE() { - return RileyLinkUtil.rileyLinkBLE; - } - - - public static void setRileyLinkBLE(RileyLinkBLE rileyLinkBLEIn) { - RileyLinkUtil.rileyLinkBLE = rileyLinkBLEIn; - } - - - public static RileyLinkServiceData getRileyLinkServiceData() { - return RileyLinkUtil.rileyLinkServiceData; - } - - - public static void setRileyLinkServiceData(RileyLinkServiceData rileyLinkServiceData) { - RileyLinkUtil.rileyLinkServiceData = rileyLinkServiceData; - } - - - public static boolean hasPumpBeenTunned() { - return RileyLinkUtil.rileyLinkServiceData.tuneUpDone; - } - - - public static RileyLinkService getRileyLinkService() { - return RileyLinkUtil.rileyLinkService; - } - - - public static void setRileyLinkService(RileyLinkService rileyLinkService) { - RileyLinkUtil.rileyLinkService = rileyLinkService; - } - - - public static RileyLinkCommunicationManager getRileyLinkCommunicationManager() { - return RileyLinkUtil.rileyLinkCommunicationManager; - } - - - public static void setRileyLinkCommunicationManager(RileyLinkCommunicationManager rileyLinkCommunicationManager) { - RileyLinkUtil.rileyLinkCommunicationManager = rileyLinkCommunicationManager; - } - - - public static boolean sendNotification(ServiceNotification notification, Integer clientHashcode) { - return false; - } - - // FIXME remove ? - public static void setCurrentTask(ServiceTask task) { + public void setCurrentTask(ServiceTask task) { if (currentTask == null) { currentTask = task; } else { @@ -197,7 +70,7 @@ public class RileyLinkUtil { } - public static void finishCurrentTask(ServiceTask task) { + public void finishCurrentTask(ServiceTask task) { if (task != currentTask) { //LOG.error("finishCurrentTask: task does not match"); } @@ -211,7 +84,7 @@ public class RileyLinkUtil { } - public static void sendServiceTransportResponse(ServiceTransport transport, ServiceResult serviceResult) { + private static void sendServiceTransportResponse(ServiceTransport transport, ServiceResult serviceResult) { // get the key (hashcode) of the client who requested this Integer clientHashcode = transport.getSenderHashcode(); // make a new bundle to send as the message data @@ -222,16 +95,6 @@ public class RileyLinkUtil { } - public static RileyLinkTargetFrequency getRileyLinkTargetFrequency() { - return RileyLinkUtil.rileyLinkTargetFrequency; - } - - - public static void setRileyLinkTargetFrequency(RileyLinkTargetFrequency rileyLinkTargetFrequency) { - RileyLinkUtil.rileyLinkTargetFrequency = rileyLinkTargetFrequency; - } - - public static boolean isSame(Double d1, Double d2) { double diff = d1 - d2; @@ -239,7 +102,6 @@ public class RileyLinkUtil { } - @Deprecated public static BleAdvertisedData parseAdertisedData(byte[] advertisedData) { List uuids = new ArrayList(); String name = null; @@ -285,45 +147,11 @@ public class RileyLinkUtil { return new BleAdvertisedData(uuids, name); } - - public static List getRileyLinkHistory() { + public List getRileyLinkHistory() { return historyRileyLink; } - - public static RileyLinkTargetDevice getTargetDevice() { - return targetDevice; - } - - - public static void setTargetDevice(RileyLinkTargetDevice targetDevice) { - RileyLinkUtil.targetDevice = targetDevice; - } - - - public static void setRileyLinkSelectPreference(RileyLinkSelectPreference rileyLinkSelectPreference) { - - RileyLinkUtil.rileyLinkSelectPreference = rileyLinkSelectPreference; - } - - - public static RileyLinkSelectPreference getRileyLinkSelectPreference() { - - return rileyLinkSelectPreference; - } - - - public static Encoding4b6b getEncoding4b6b() { - return RileyLinkUtil.encoding4b6b; - } - - - public static void setFirmwareVersion(RileyLinkFirmwareVersion firmwareVersion) { - RileyLinkUtil.firmwareVersion = firmwareVersion; - } - - - public static RileyLinkFirmwareVersion getFirmwareVersion() { - return firmwareVersion; + public Encoding4b6b getEncoding4b6b() { + return encoding4b6b; } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RFSpy.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RFSpy.java index bb5f435f5f..ef3641fa02 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RFSpy.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RFSpy.java @@ -2,15 +2,14 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble; import android.os.SystemClock; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import java.util.UUID; -import info.nightscout.androidaps.MainApp; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.R; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command.Reset; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command.RileyLinkCommand; @@ -28,45 +27,47 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.Rile import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkFirmwareVersion; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkTargetFrequency; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.operations.BLECommOperationResult; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.common.utils.StringUtil; import info.nightscout.androidaps.plugins.pump.common.utils.ThreadUtil; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicConst; - -import info.nightscout.androidaps.utils.SP; +import info.nightscout.androidaps.utils.resources.ResourceHelper; +import info.nightscout.androidaps.utils.sharedPreferences.SP; /** * Created by geoff on 5/26/16. */ public class RFSpy { - public static final long RILEYLINK_FREQ_XTAL = 24000000; - public static final int EXPECTED_MAX_BLUETOOTH_LATENCY_MS = 7500; // 1500 - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPBTCOMM); + @Inject AAPSLogger aapsLogger; + @Inject ResourceHelper resourceHelper; + @Inject SP sp; + @Inject RileyLinkServiceData rileyLinkServiceData; + @Inject RileyLinkUtil rileyLinkUtil; + + private final HasAndroidInjector injector; + + private static final long RILEYLINK_FREQ_XTAL = 24000000; + private static final int EXPECTED_MAX_BLUETOOTH_LATENCY_MS = 7500; // 1500 public int notConnectedCount = 0; private RileyLinkBLE rileyLinkBle; private RFSpyReader reader; - private RileyLinkTargetFrequency selectedTargetFrequency; private UUID radioServiceUUID = UUID.fromString(GattAttributes.SERVICE_RADIO); private UUID radioDataUUID = UUID.fromString(GattAttributes.CHARA_RADIO_DATA); private UUID radioVersionUUID = UUID.fromString(GattAttributes.CHARA_RADIO_VERSION); private UUID responseCountUUID = UUID.fromString(GattAttributes.CHARA_RADIO_RESPONSE_COUNT); - private RileyLinkFirmwareVersion firmwareVersion; private String bleVersion; // We don't use it so no need of sofisticated logic - Double currentFrequencyMHz; + private Double currentFrequencyMHz; - public RFSpy(RileyLinkBLE rileyLinkBle) { + public RFSpy(HasAndroidInjector injector, RileyLinkBLE rileyLinkBle) { + injector.androidInjector().inject(this); + this.injector = injector; this.rileyLinkBle = rileyLinkBle; - reader = new RFSpyReader(rileyLinkBle); + reader = new RFSpyReader(aapsLogger, rileyLinkBle); } - - public RileyLinkFirmwareVersion getRLVersionCached() { - return firmwareVersion; - } - - public String getBLEVersionCached() { return bleVersion; } @@ -75,13 +76,7 @@ public class RFSpy { // Call this after the RL services are discovered. // Starts an async task to read when data is available public void startReader() { - rileyLinkBle.registerRadioResponseCountNotification(new Runnable() { - - @Override - public void run() { - newDataIsAvailable(); - } - }); + rileyLinkBle.registerRadioResponseCountNotification(this::newDataIsAvailable); reader.start(); } @@ -90,13 +85,12 @@ public class RFSpy { // firmware version public void initializeRileyLink() { bleVersion = getVersion(); - firmwareVersion = getFirmwareVersion(); - RileyLinkUtil.setFirmwareVersion(firmwareVersion); + rileyLinkServiceData.firmwareVersion = getFirmwareVersion(); } // Call this from the "response count" notification handler. - public void newDataIsAvailable() { + private void newDataIsAvailable() { // pass the message to the reader (which should be internal to RFSpy) reader.newDataIsAvailable(); } @@ -108,11 +102,10 @@ public class RFSpy { BLECommOperationResult result = rileyLinkBle.readCharacteristic_blocking(radioServiceUUID, radioVersionUUID); if (result.resultCode == BLECommOperationResult.RESULT_SUCCESS) { String version = StringUtil.fromBytes(result.value); - if (isLogEnabled()) - LOG.debug("BLE Version: " + version); + aapsLogger.debug(LTag.PUMPBTCOMM, "BLE Version: " + version); return version; } else { - LOG.error("getVersion failed with code: " + result.resultCode); + aapsLogger.error(LTag.PUMPBTCOMM, "getVersion failed with code: " + result.resultCode); return "(null)"; } } @@ -120,14 +113,13 @@ public class RFSpy { public boolean isRileyLinkStillAvailable() { RileyLinkFirmwareVersion firmwareVersion = getFirmwareVersion(); - return (firmwareVersion!= RileyLinkFirmwareVersion.UnknownVersion); + return (firmwareVersion != RileyLinkFirmwareVersion.UnknownVersion); } - public RileyLinkFirmwareVersion getFirmwareVersion() { + private RileyLinkFirmwareVersion getFirmwareVersion() { - if (isLogEnabled()) - LOG.debug("Firmware Version. Get Version - Start"); + aapsLogger.debug(LTag.PUMPBTCOMM, "Firmware Version. Get Version - Start"); for (int i = 0; i < 5; i++) { // We have to call raw version of communication to get firmware version @@ -136,8 +128,7 @@ public class RFSpy { byte[] getVersionRaw = getByteArray(RileyLinkCommandType.GetVersion.code); byte[] response = writeToDataRaw(getVersionRaw, 5000); - if (isLogEnabled()) - LOG.debug("Firmware Version. GetVersion [response={}]", ByteUtil.shortHexString(response)); + aapsLogger.debug(LTag.PUMPBTCOMM, "Firmware Version. GetVersion [response={}]", ByteUtil.shortHexString(response)); if (response != null) { // && response[0] == (byte) 0xDD) { @@ -146,8 +137,7 @@ public class RFSpy { RileyLinkFirmwareVersion version = RileyLinkFirmwareVersion.getByVersionString(StringUtil .fromBytes(response)); - if (isLogEnabled()) - LOG.trace("Firmware Version string: {}, resolved to {}.", versionString, version); + aapsLogger.debug(LTag.PUMPBTCOMM, "Firmware Version string: {}, resolved to {}.", versionString, version); if (version != RileyLinkFirmwareVersion.UnknownVersion) return version; @@ -156,7 +146,7 @@ public class RFSpy { } } - LOG.error("Firmware Version can't be determined. Checking with BLE Version [{}].", bleVersion); + aapsLogger.error(LTag.PUMPBTCOMM, "Firmware Version can't be determined. Checking with BLE Version [{}].", bleVersion); if (bleVersion.contains(" 2.")) { return RileyLinkFirmwareVersion.Version_2_0; @@ -172,7 +162,7 @@ public class RFSpy { byte[] junkInBuffer = reader.poll(0); while (junkInBuffer != null) { - LOG.warn(ThreadUtil.sig() + "writeToData: draining read queue, found this: " + aapsLogger.warn(LTag.PUMPBTCOMM, ThreadUtil.sig() + "writeToData: draining read queue, found this: " + ByteUtil.shortHexString(junkInBuffer)); junkInBuffer = reader.poll(0); } @@ -180,12 +170,12 @@ public class RFSpy { // prepend length, and send it. byte[] prepended = ByteUtil.concat(new byte[]{(byte) (bytes.length)}, bytes); - LOG.debug("writeToData (raw={})", ByteUtil.shortHexString(prepended)); + aapsLogger.debug(LTag.PUMPBTCOMM, "writeToData (raw={})", ByteUtil.shortHexString(prepended)); BLECommOperationResult writeCheck = rileyLinkBle.writeCharacteristic_blocking(radioServiceUUID, radioDataUUID, prepended); if (writeCheck.resultCode != BLECommOperationResult.RESULT_SUCCESS) { - LOG.error("BLE Write operation failed, code=" + writeCheck.resultCode); + aapsLogger.error(LTag.PUMPBTCOMM, "BLE Write operation failed, code=" + writeCheck.resultCode); return null; // will be a null (invalid) response } SystemClock.sleep(100); @@ -204,23 +194,22 @@ public class RFSpy { RFSpyResponse resp = new RFSpyResponse(command, rawResponse); if (rawResponse == null) { - LOG.error("writeToData: No response from RileyLink"); + aapsLogger.error(LTag.PUMPBTCOMM, "writeToData: No response from RileyLink"); notConnectedCount++; } else { if (resp.wasInterrupted()) { - LOG.error("writeToData: RileyLink was interrupted"); + aapsLogger.error(LTag.PUMPBTCOMM, "writeToData: RileyLink was interrupted"); } else if (resp.wasTimeout()) { - LOG.error("writeToData: RileyLink reports timeout"); + aapsLogger.error(LTag.PUMPBTCOMM, "writeToData: RileyLink reports timeout"); notConnectedCount++; } else if (resp.isOK()) { - LOG.warn("writeToData: RileyLink reports OK"); + aapsLogger.warn(LTag.PUMPBTCOMM, "writeToData: RileyLink reports OK"); resetNotConnectedCount(); } else { if (resp.looksLikeRadioPacket()) { // RadioResponse radioResp = resp.getRadioResponse(); // byte[] responsePayload = radioResp.getPayload(); - if (isLogEnabled()) - LOG.trace("writeToData: received radio response. Will decode at upper level"); + aapsLogger.debug(LTag.PUMPBTCOMM, "writeToData: received radio response. Will decode at upper level"); resetNotConnectedCount(); } // Log.i(TAG, "writeToData: raw response is " + ByteUtil.shortHexString(rawResponse)); @@ -274,14 +263,14 @@ public class RFSpy { int sendDelay = repeatCount * delay_ms; int receiveDelay = timeout_ms * (retryCount + 1); - SendAndListen command = new SendAndListen(sendChannel, repeatCount, delay_ms, listenChannel, timeout_ms, + SendAndListen command = new SendAndListen(injector, sendChannel, repeatCount, delay_ms, listenChannel, timeout_ms, retryCount, extendPreamble_ms, pkt); return writeToData(command, sendDelay + receiveDelay + EXPECTED_MAX_BLUETOOTH_LATENCY_MS); } - public RFSpyResponse updateRegister(CC111XRegister reg, int val) { + private RFSpyResponse updateRegister(CC111XRegister reg, int val) { RFSpyResponse resp = writeToData(new UpdateRegister(reg, (byte) val), EXPECTED_MAX_BLUETOOTH_LATENCY_MS); return resp; } @@ -292,11 +281,11 @@ public class RFSpy { updateRegister(CC111XRegister.freq0, (byte) (value & 0xff)); updateRegister(CC111XRegister.freq1, (byte) ((value >> 8) & 0xff)); updateRegister(CC111XRegister.freq2, (byte) ((value >> 16) & 0xff)); - LOG.info("Set frequency to {} MHz", freqMHz); + aapsLogger.info(LTag.PUMPBTCOMM, "Set frequency to {} MHz", freqMHz); this.currentFrequencyMHz = freqMHz; - configureRadioForRegion(RileyLinkUtil.getRileyLinkTargetFrequency()); + configureRadioForRegion(rileyLinkServiceData.rileyLinkTargetFrequency); } @@ -362,35 +351,32 @@ public class RFSpy { } break; default: - LOG.warn("No region configuration for RfSpy and {}", frequency.name()); + aapsLogger.warn(LTag.PUMPBTCOMM, "No region configuration for RfSpy and {}", frequency.name()); break; } - - this.selectedTargetFrequency = frequency; } private void setMedtronicEncoding() { RileyLinkEncodingType encoding = RileyLinkEncodingType.FourByteSixByteLocal; - if (RileyLinkFirmwareVersion.isSameVersion(this.firmwareVersion, RileyLinkFirmwareVersion.Version2AndHigher)) { - if (SP.getString(MedtronicConst.Prefs.Encoding, "None").equals(MainApp.gs(R.string.key_medtronic_pump_encoding_4b6b_rileylink))) { + if (RileyLinkFirmwareVersion.isSameVersion(rileyLinkServiceData.firmwareVersion, RileyLinkFirmwareVersion.Version2AndHigher)) { + if (sp.getString(MedtronicConst.Prefs.Encoding, "None").equals(resourceHelper.gs(R.string.key_medtronic_pump_encoding_4b6b_rileylink))) { encoding = RileyLinkEncodingType.FourByteSixByteRileyLink; } } setRileyLinkEncoding(encoding); - if (isLogEnabled()) - LOG.debug("Set Encoding for Medtronic: " + encoding.name()); + aapsLogger.debug(LTag.PUMPBTCOMM, "Set Encoding for Medtronic: " + encoding.name()); } private RFSpyResponse setPreamble(int preamble) { RFSpyResponse resp = null; try { - resp = writeToData(new SetPreamble(preamble), EXPECTED_MAX_BLUETOOTH_LATENCY_MS); + resp = writeToData(new SetPreamble(injector, preamble), EXPECTED_MAX_BLUETOOTH_LATENCY_MS); } catch (Exception e) { e.toString(); } @@ -403,7 +389,7 @@ public class RFSpy { if (resp.isOK()) { reader.setRileyLinkEncodingType(encoding); - RileyLinkUtil.setEncoding(encoding); + rileyLinkUtil.setEncoding(encoding); } return resp; @@ -431,16 +417,10 @@ public class RFSpy { RFSpyResponse resp = null; try { resp = writeToData(new Reset(), EXPECTED_MAX_BLUETOOTH_LATENCY_MS); - if (isLogEnabled()) - LOG.debug("Reset command send, response: {}", resp); + aapsLogger.debug(LTag.PUMPBTCOMM, "Reset command send, response: {}", resp); } catch (Exception e) { e.toString(); } return resp; } - - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPBTCOMM); - } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RFSpyReader.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RFSpyReader.java index 595da51847..5a3d459154 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RFSpyReader.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RFSpyReader.java @@ -1,19 +1,15 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble; +import android.os.AsyncTask; +import android.os.SystemClock; + import java.util.UUID; import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.Semaphore; import java.util.concurrent.TimeUnit; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import android.os.AsyncTask; -import android.os.SystemClock; - -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.GattAttributes; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkEncodingType; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.operations.BLECommOperationResult; @@ -25,7 +21,7 @@ import info.nightscout.androidaps.plugins.pump.common.utils.ThreadUtil; */ public class RFSpyReader { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPBTCOMM); + private final AAPSLogger aapsLogger; private static AsyncTask readerTask; private RileyLinkBLE rileyLinkBle; private Semaphore waitForRadioData = new Semaphore(0, true); @@ -35,13 +31,9 @@ public class RFSpyReader { private boolean stopAtNull = true; - public RFSpyReader(RileyLinkBLE rileyLinkBle) { + RFSpyReader(AAPSLogger aapsLogger, RileyLinkBLE rileyLinkBle) { this.rileyLinkBle = rileyLinkBle; - } - - - public void init(RileyLinkBLE rileyLinkBLE) { - this.rileyLinkBle = rileyLinkBLE; + this.aapsLogger = aapsLogger; } @@ -52,16 +44,15 @@ public class RFSpyReader { this.rileyLinkBle = rileyLinkBle; } - public void setRileyLinkEncodingType(RileyLinkEncodingType encodingType) { + void setRileyLinkEncodingType(RileyLinkEncodingType encodingType) { stopAtNull = !(encodingType == RileyLinkEncodingType.Manchester || // encodingType == RileyLinkEncodingType.FourByteSixByteRileyLink); } // This timeout must be coordinated with the length of the RFSpy radio operation or Bad Things Happen. - public byte[] poll(int timeout_ms) { - if (isLogEnabled()) - LOG.trace(ThreadUtil.sig() + "Entering poll at t==" + SystemClock.uptimeMillis() + ", timeout is " + timeout_ms + byte[] poll(int timeout_ms) { + aapsLogger.debug(LTag.PUMPBTCOMM, ThreadUtil.sig() + "Entering poll at t==" + SystemClock.uptimeMillis() + ", timeout is " + timeout_ms + " mDataQueue size is " + mDataQueue.size()); if (mDataQueue.isEmpty()) { @@ -70,16 +61,14 @@ public class RFSpyReader { // returns null if timeout. byte[] dataFromQueue = mDataQueue.poll(timeout_ms, TimeUnit.MILLISECONDS); if (dataFromQueue != null) { - if (isLogEnabled()) - LOG.debug("Got data [" + ByteUtil.shortHexString(dataFromQueue) + "] at t==" - + SystemClock.uptimeMillis()); + aapsLogger.debug(LTag.PUMPBTCOMM, "Got data [" + ByteUtil.shortHexString(dataFromQueue) + "] at t==" + + SystemClock.uptimeMillis()); } else { - if (isLogEnabled()) - LOG.debug("Got data [null] at t==" + SystemClock.uptimeMillis()); + aapsLogger.debug(LTag.PUMPBTCOMM, "Got data [null] at t==" + SystemClock.uptimeMillis()); } return dataFromQueue; } catch (InterruptedException e) { - LOG.error("poll: Interrupted waiting for data"); + aapsLogger.error(LTag.PUMPBTCOMM, "poll: Interrupted waiting for data"); } } @@ -88,11 +77,10 @@ public class RFSpyReader { // Call this from the "response count" notification handler. - public void newDataIsAvailable() { + void newDataIsAvailable() { releaseCount++; - if (isLogEnabled()) - LOG.trace(ThreadUtil.sig() + "waitForRadioData released(count=" + releaseCount + ") at t=" + aapsLogger.debug(LTag.PUMPBTCOMM, ThreadUtil.sig() + "waitForRadioData released(count=" + releaseCount + ") at t=" + SystemClock.uptimeMillis()); waitForRadioData.release(); } @@ -110,8 +98,7 @@ public class RFSpyReader { try { acquireCount++; waitForRadioData.acquire(); - if (isLogEnabled()) - LOG.trace(ThreadUtil.sig() + "waitForRadioData acquired (count=" + acquireCount + ") at t=" + aapsLogger.debug(LTag.PUMPBTCOMM, ThreadUtil.sig() + "waitForRadioData acquired (count=" + acquireCount + ") at t=" + SystemClock.uptimeMillis()); SystemClock.sleep(100); SystemClock.sleep(1); @@ -130,24 +117,19 @@ public class RFSpyReader { } mDataQueue.add(result.value); } else if (result.resultCode == BLECommOperationResult.RESULT_INTERRUPTED) { - LOG.error("Read operation was interrupted"); + aapsLogger.error(LTag.PUMPBTCOMM, "Read operation was interrupted"); } else if (result.resultCode == BLECommOperationResult.RESULT_TIMEOUT) { - LOG.error("Read operation on Radio Data timed out"); + aapsLogger.error(LTag.PUMPBTCOMM, "Read operation on Radio Data timed out"); } else if (result.resultCode == BLECommOperationResult.RESULT_BUSY) { - LOG.error("FAIL: RileyLinkBLE reports operation already in progress"); + aapsLogger.error(LTag.PUMPBTCOMM, "FAIL: RileyLinkBLE reports operation already in progress"); } else if (result.resultCode == BLECommOperationResult.RESULT_NONE) { - LOG.error("FAIL: got invalid result code: " + result.resultCode); + aapsLogger.error(LTag.PUMPBTCOMM, "FAIL: got invalid result code: " + result.resultCode); } } catch (InterruptedException e) { - LOG.error("Interrupted while waiting for data"); + aapsLogger.error(LTag.PUMPBTCOMM, "Interrupted while waiting for data"); } } } }.execute(); } - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPBTCOMM); - } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RileyLinkBLE.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RileyLinkBLE.java index 42b7f8ce6e..bf71a19fe5 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RileyLinkBLE.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/RileyLinkBLE.java @@ -12,15 +12,16 @@ import android.content.Context; import android.os.SystemClock; import org.apache.commons.lang3.StringUtils; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import java.util.List; import java.util.UUID; import java.util.concurrent.Semaphore; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.GattAttributes; @@ -31,6 +32,7 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.operation import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.operations.DescriptorWriteOperation; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkError; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.common.utils.ThreadUtil; @@ -40,11 +42,13 @@ import info.nightscout.androidaps.plugins.pump.common.utils.ThreadUtil; */ public class RileyLinkBLE { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPBTCOMM); + @Inject AAPSLogger aapsLogger; + @Inject RileyLinkServiceData rileyLinkServiceData; + @Inject RileyLinkUtil rileyLinkUtil; private final Context context; - public boolean gattDebugEnabled = true; - boolean manualDisconnect = false; + private boolean gattDebugEnabled = true; + private boolean manualDisconnect = false; private BluetoothAdapter bluetoothAdapter; private BluetoothGattCallback bluetoothGattCallback; private BluetoothDevice rileyLinkDevice; @@ -55,24 +59,24 @@ public class RileyLinkBLE { private boolean mIsConnected = false; - public RileyLinkBLE(final Context context) { + public RileyLinkBLE(HasAndroidInjector injector, final Context context) { + injector.androidInjector().inject(this); this.context = context; this.bluetoothAdapter = BluetoothAdapter.getDefaultAdapter(); - if (isLogEnabled()) - LOG.debug("BT Adapter: " + this.bluetoothAdapter); + aapsLogger.debug(LTag.PUMPBTCOMM, "BT Adapter: " + this.bluetoothAdapter); bluetoothGattCallback = new BluetoothGattCallback() { @Override public void onCharacteristicChanged(final BluetoothGatt gatt, final BluetoothGattCharacteristic characteristic) { super.onCharacteristicChanged(gatt, characteristic); - if (gattDebugEnabled && isLogEnabled()) { - LOG.trace(ThreadUtil.sig() + "onCharacteristicChanged " + if (gattDebugEnabled) { + aapsLogger.debug(LTag.PUMPBTCOMM, ThreadUtil.sig() + "onCharacteristicChanged " + GattAttributes.lookup(characteristic.getUuid()) + " " + ByteUtil.getHex(characteristic.getValue())); if (characteristic.getUuid().equals(UUID.fromString(GattAttributes.CHARA_RADIO_RESPONSE_COUNT))) { - LOG.debug("Response Count is " + ByteUtil.shortHexString(characteristic.getValue())); + aapsLogger.debug(LTag.PUMPBTCOMM, "Response Count is " + ByteUtil.shortHexString(characteristic.getValue())); } } if (radioResponseCountNotified != null) { @@ -87,8 +91,8 @@ public class RileyLinkBLE { super.onCharacteristicRead(gatt, characteristic, status); final String statusMessage = getGattStatusMessage(status); - if (gattDebugEnabled && isLogEnabled()) { - LOG.trace(ThreadUtil.sig() + "onCharacteristicRead (" + if (gattDebugEnabled) { + aapsLogger.debug(LTag.PUMPBTCOMM, ThreadUtil.sig() + "onCharacteristicRead (" + GattAttributes.lookup(characteristic.getUuid()) + ") " + statusMessage + ":" + ByteUtil.getHex(characteristic.getValue())); } @@ -102,8 +106,8 @@ public class RileyLinkBLE { super.onCharacteristicWrite(gatt, characteristic, status); final String uuidString = GattAttributes.lookup(characteristic.getUuid()); - if (gattDebugEnabled && isLogEnabled()) { - LOG.trace(ThreadUtil.sig() + "onCharacteristicWrite " + getGattStatusMessage(status) + " " + if (gattDebugEnabled) { + aapsLogger.debug(LTag.PUMPBTCOMM, ThreadUtil.sig() + "onCharacteristicWrite " + getGattStatusMessage(status) + " " + uuidString + " " + ByteUtil.shortHexString(characteristic.getValue())); } mCurrentOperation.gattOperationCompletionCallback(characteristic.getUuid(), characteristic.getValue()); @@ -116,7 +120,7 @@ public class RileyLinkBLE { // https://github.com/NordicSemiconductor/puck-central-android/blob/master/PuckCentral/app/src/main/java/no/nordicsemi/puckcentral/bluetooth/gatt/GattManager.java#L117 if (status == 133) { - LOG.error("Got the status 133 bug, closing gatt"); + aapsLogger.error(LTag.PUMPBTCOMM, "Got the status 133 bug, closing gatt"); disconnect(); SystemClock.sleep(500); return; @@ -136,29 +140,27 @@ public class RileyLinkBLE { stateMessage = "UNKNOWN newState (" + newState + ")"; } - if (isLogEnabled()) - LOG.warn("onConnectionStateChange " + getGattStatusMessage(status) + " " + stateMessage); + aapsLogger.warn(LTag.PUMPBTCOMM, "onConnectionStateChange " + getGattStatusMessage(status) + " " + stateMessage); } if (newState == BluetoothProfile.STATE_CONNECTED) { if (status == BluetoothGatt.GATT_SUCCESS) { - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.BluetoothConnected); + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.BluetoothConnected, context); } else { - if (isLogEnabled()) - LOG.debug("BT State connected, GATT status {} ({})", status, getGattStatusMessage(status)); + aapsLogger.debug(LTag.PUMPBTCOMM, "BT State connected, GATT status {} ({})", status, getGattStatusMessage(status)); } } else if ((newState == BluetoothProfile.STATE_CONNECTING) || // (newState == BluetoothProfile.STATE_DISCONNECTING)) { - // LOG.debug("We are in {} state.", status == BluetoothProfile.STATE_CONNECTING ? "Connecting" : + // aapsLogger.debug(LTag.PUMPBTCOMM,"We are in {} state.", status == BluetoothProfile.STATE_CONNECTING ? "Connecting" : // "Disconnecting"); } else if (newState == BluetoothProfile.STATE_DISCONNECTED) { - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkDisconnected); + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkDisconnected, context); if (manualDisconnect) close(); - LOG.warn("RileyLink Disconnected."); + aapsLogger.warn(LTag.PUMPBTCOMM, "RileyLink Disconnected."); } else { - LOG.warn("Some other state: (status={},newState={})", status, newState); + aapsLogger.warn(LTag.PUMPBTCOMM, "Some other state: (status={},newState={})", status, newState); } } @@ -166,8 +168,8 @@ public class RileyLinkBLE { @Override public void onDescriptorWrite(BluetoothGatt gatt, BluetoothGattDescriptor descriptor, int status) { super.onDescriptorWrite(gatt, descriptor, status); - if (gattDebugEnabled && isLogEnabled()) { - LOG.warn("onDescriptorWrite " + GattAttributes.lookup(descriptor.getUuid()) + " " + if (gattDebugEnabled) { + aapsLogger.warn(LTag.PUMPBTCOMM, "onDescriptorWrite " + GattAttributes.lookup(descriptor.getUuid()) + " " + getGattStatusMessage(status) + " written: " + ByteUtil.getHex(descriptor.getValue())); } mCurrentOperation.gattOperationCompletionCallback(descriptor.getUuid(), descriptor.getValue()); @@ -178,8 +180,8 @@ public class RileyLinkBLE { public void onDescriptorRead(BluetoothGatt gatt, BluetoothGattDescriptor descriptor, int status) { super.onDescriptorRead(gatt, descriptor, status); mCurrentOperation.gattOperationCompletionCallback(descriptor.getUuid(), descriptor.getValue()); - if (gattDebugEnabled && isLogEnabled()) { - LOG.warn("onDescriptorRead " + getGattStatusMessage(status) + " status " + descriptor); + if (gattDebugEnabled) { + aapsLogger.warn(LTag.PUMPBTCOMM, "onDescriptorRead " + getGattStatusMessage(status) + " status " + descriptor); } } @@ -187,8 +189,8 @@ public class RileyLinkBLE { @Override public void onMtuChanged(BluetoothGatt gatt, int mtu, int status) { super.onMtuChanged(gatt, mtu, status); - if (gattDebugEnabled && isLogEnabled()) { - LOG.warn("onMtuChanged " + mtu + " status " + status); + if (gattDebugEnabled) { + aapsLogger.warn(LTag.PUMPBTCOMM, "onMtuChanged " + mtu + " status " + status); } } @@ -196,8 +198,8 @@ public class RileyLinkBLE { @Override public void onReadRemoteRssi(final BluetoothGatt gatt, int rssi, int status) { super.onReadRemoteRssi(gatt, rssi, status); - if (gattDebugEnabled && isLogEnabled()) { - LOG.warn("onReadRemoteRssi " + getGattStatusMessage(status) + ": " + rssi); + if (gattDebugEnabled) { + aapsLogger.warn(LTag.PUMPBTCOMM, "onReadRemoteRssi " + getGattStatusMessage(status) + ": " + rssi); } } @@ -205,8 +207,8 @@ public class RileyLinkBLE { @Override public void onReliableWriteCompleted(BluetoothGatt gatt, int status) { super.onReliableWriteCompleted(gatt, status); - if (gattDebugEnabled && isLogEnabled()) { - LOG.warn("onReliableWriteCompleted status " + status); + if (gattDebugEnabled) { + aapsLogger.warn(LTag.PUMPBTCOMM, "onReliableWriteCompleted status " + status); } } @@ -232,27 +234,26 @@ public class RileyLinkBLE { } } - if (gattDebugEnabled && isLogEnabled()) { - LOG.warn("onServicesDiscovered " + getGattStatusMessage(status)); + if (gattDebugEnabled) { + aapsLogger.warn(LTag.PUMPBTCOMM, "onServicesDiscovered " + getGattStatusMessage(status)); } - LOG.info("Gatt device is RileyLink device: " + rileyLinkFound); + aapsLogger.info(LTag.PUMPBTCOMM, "Gatt device is RileyLink device: " + rileyLinkFound); if (rileyLinkFound) { mIsConnected = true; - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkReady); + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkReady, context); // RileyLinkUtil.sendNotification(new // ServiceNotification(RileyLinkConst.Intents.RileyLinkReady), null); } else { mIsConnected = false; - RileyLinkUtil.setServiceState(RileyLinkServiceState.RileyLinkError, + rileyLinkServiceData.setServiceState(RileyLinkServiceState.RileyLinkError, RileyLinkError.DeviceIsNotRileyLink); } } else { - if (isLogEnabled()) - LOG.debug("onServicesDiscovered " + getGattStatusMessage(status)); - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkGattFailed); + aapsLogger.debug(LTag.PUMPBTCOMM, "onServicesDiscovered " + getGattStatusMessage(status)); + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkGattFailed, context); } } }; @@ -261,9 +262,7 @@ public class RileyLinkBLE { private boolean isAnyRileyLinkServiceFound(BluetoothGattService service) { - boolean found = false; - - found = GattAttributes.isRileyLink(service.getUuid()); + boolean found = GattAttributes.isRileyLink(service.getUuid()); if (found) { return true; @@ -313,7 +312,7 @@ public class RileyLinkBLE { stringBuilder.append("\n\n"); - LOG.warn(stringBuilder.toString()); + aapsLogger.warn(LTag.PUMPBTCOMM, stringBuilder.toString()); List includedServices = service.getIncludedServices(); @@ -324,7 +323,7 @@ public class RileyLinkBLE { } - public void registerRadioResponseCountNotification(Runnable notifier) { + void registerRadioResponseCountNotification(Runnable notifier) { radioResponseCountNotified = notifier; } @@ -342,11 +341,10 @@ public class RileyLinkBLE { } if (bluetoothConnectionGatt.discoverServices()) { - if (isLogEnabled()) - LOG.warn("Starting to discover GATT Services."); + aapsLogger.warn(LTag.PUMPBTCOMM, "Starting to discover GATT Services."); return true; } else { - LOG.error("Cannot discover GATT Services."); + aapsLogger.error(LTag.PUMPBTCOMM, "Cannot discover GATT Services."); return false; } } @@ -356,7 +354,7 @@ public class RileyLinkBLE { BLECommOperationResult result = setNotification_blocking(UUID.fromString(GattAttributes.SERVICE_RADIO), // UUID.fromString(GattAttributes.CHARA_RADIO_RESPONSE_COUNT)); if (result.resultCode != BLECommOperationResult.RESULT_SUCCESS) { - LOG.error("Error setting response count notification"); + aapsLogger.error(LTag.PUMPBTCOMM, "Error setting response count notification"); return false; } return true; @@ -364,36 +362,34 @@ public class RileyLinkBLE { public void findRileyLink(String RileyLinkAddress) { - if (isLogEnabled()) - LOG.debug("RileyLink address: " + RileyLinkAddress); + aapsLogger.debug(LTag.PUMPBTCOMM, "RileyLink address: " + RileyLinkAddress); // Must verify that this is a valid MAC, or crash. rileyLinkDevice = bluetoothAdapter.getRemoteDevice(RileyLinkAddress); // if this succeeds, we get a connection state change callback? - if (rileyLinkDevice!=null) { + if (rileyLinkDevice != null) { connectGatt(); } else { - LOG.error("RileyLink device not found with address: " + RileyLinkAddress); + aapsLogger.error(LTag.PUMPBTCOMM, "RileyLink device not found with address: " + RileyLinkAddress); } } // This function must be run on UI thread. public void connectGatt() { - if (this.rileyLinkDevice==null) { - LOG.error("RileyLink device is null, can't do connectGatt."); + if (this.rileyLinkDevice == null) { + aapsLogger.error(LTag.PUMPBTCOMM, "RileyLink device is null, can't do connectGatt."); return; } bluetoothConnectionGatt = rileyLinkDevice.connectGatt(context, true, bluetoothGattCallback); // , BluetoothDevice.TRANSPORT_LE if (bluetoothConnectionGatt == null) { - LOG.error("Failed to connect to Bluetooth Low Energy device at " + bluetoothAdapter.getAddress()); + aapsLogger.error(LTag.PUMPBTCOMM, "Failed to connect to Bluetooth Low Energy device at " + bluetoothAdapter.getAddress()); } else { if (gattDebugEnabled) { - if (isLogEnabled()) - LOG.debug("Gatt Connected."); + aapsLogger.debug(LTag.PUMPBTCOMM, "Gatt Connected."); } } } @@ -401,8 +397,7 @@ public class RileyLinkBLE { public void disconnect() { mIsConnected = false; - if (isLogEnabled()) - LOG.warn("Closing GATT connection"); + aapsLogger.warn(LTag.PUMPBTCOMM, "Closing GATT connection"); // Close old conenction if (bluetoothConnectionGatt != null) { // Not sure if to disconnect or to close first.. @@ -420,7 +415,7 @@ public class RileyLinkBLE { } - public BLECommOperationResult setNotification_blocking(UUID serviceUUID, UUID charaUUID) { + private BLECommOperationResult setNotification_blocking(UUID serviceUUID, UUID charaUUID) { BLECommOperationResult rval = new BLECommOperationResult(); if (bluetoothConnectionGatt != null) { @@ -428,7 +423,7 @@ public class RileyLinkBLE { gattOperationSema.acquire(); SystemClock.sleep(1); // attempting to yield thread, to make sequence of events easier to follow } catch (InterruptedException e) { - LOG.error("setNotification_blocking: interrupted waiting for gattOperationSema"); + aapsLogger.error(LTag.PUMPBTCOMM, "setNotification_blocking: interrupted waiting for gattOperationSema"); return rval; } if (mCurrentOperation != null) { @@ -437,7 +432,7 @@ public class RileyLinkBLE { if (bluetoothConnectionGatt.getService(serviceUUID) == null) { // Catch if the service is not supported by the BLE device rval.resultCode = BLECommOperationResult.RESULT_NONE; - LOG.error("BT Device not supported"); + aapsLogger.error(LTag.PUMPBTCOMM, "BT Device not supported"); // TODO: 11/07/2016 UI update for user } else { BluetoothGattCharacteristic chara = bluetoothConnectionGatt.getService(serviceUUID) @@ -447,13 +442,12 @@ public class RileyLinkBLE { List list = chara.getDescriptors(); if (gattDebugEnabled) { for (int i = 0; i < list.size(); i++) { - if (isLogEnabled()) - LOG.debug("Found descriptor: " + list.get(i).toString()); + aapsLogger.debug(LTag.PUMPBTCOMM, "Found descriptor: " + list.get(i).toString()); } } BluetoothGattDescriptor descr = list.get(0); // Tell the remote device to send the notifications - mCurrentOperation = new DescriptorWriteOperation(bluetoothConnectionGatt, descr, + mCurrentOperation = new DescriptorWriteOperation(aapsLogger, bluetoothConnectionGatt, descr, BluetoothGattDescriptor.ENABLE_NOTIFICATION_VALUE); mCurrentOperation.execute(this); if (mCurrentOperation.timedOut) { @@ -468,7 +462,7 @@ public class RileyLinkBLE { gattOperationSema.release(); } } else { - LOG.error("setNotification_blocking: not configured!"); + aapsLogger.error(LTag.PUMPBTCOMM, "setNotification_blocking: not configured!"); rval.resultCode = BLECommOperationResult.RESULT_NOT_CONFIGURED; } return rval; @@ -476,7 +470,7 @@ public class RileyLinkBLE { // call from main - public BLECommOperationResult writeCharacteristic_blocking(UUID serviceUUID, UUID charaUUID, byte[] value) { + BLECommOperationResult writeCharacteristic_blocking(UUID serviceUUID, UUID charaUUID, byte[] value) { BLECommOperationResult rval = new BLECommOperationResult(); if (bluetoothConnectionGatt != null) { rval.value = value; @@ -484,7 +478,7 @@ public class RileyLinkBLE { gattOperationSema.acquire(); SystemClock.sleep(1); // attempting to yield thread, to make sequence of events easier to follow } catch (InterruptedException e) { - LOG.error("writeCharacteristic_blocking: interrupted waiting for gattOperationSema"); + aapsLogger.error(LTag.PUMPBTCOMM, "writeCharacteristic_blocking: interrupted waiting for gattOperationSema"); return rval; } @@ -497,12 +491,12 @@ public class RileyLinkBLE { // app that created the bluetoothConnectionGatt has been destroyed/created, // e.g. when the user switches from portrait to landscape. rval.resultCode = BLECommOperationResult.RESULT_NONE; - LOG.error("BT Device not supported"); + aapsLogger.error(LTag.PUMPBTCOMM, "BT Device not supported"); // TODO: 11/07/2016 UI update for user } else { BluetoothGattCharacteristic chara = bluetoothConnectionGatt.getService(serviceUUID) .getCharacteristic(charaUUID); - mCurrentOperation = new CharacteristicWriteOperation(bluetoothConnectionGatt, chara, value); + mCurrentOperation = new CharacteristicWriteOperation(aapsLogger, bluetoothConnectionGatt, chara, value); mCurrentOperation.execute(this); if (mCurrentOperation.timedOut) { rval.resultCode = BLECommOperationResult.RESULT_TIMEOUT; @@ -516,21 +510,21 @@ public class RileyLinkBLE { gattOperationSema.release(); } } else { - LOG.error("writeCharacteristic_blocking: not configured!"); + aapsLogger.error(LTag.PUMPBTCOMM, "writeCharacteristic_blocking: not configured!"); rval.resultCode = BLECommOperationResult.RESULT_NOT_CONFIGURED; } return rval; } - public BLECommOperationResult readCharacteristic_blocking(UUID serviceUUID, UUID charaUUID) { + BLECommOperationResult readCharacteristic_blocking(UUID serviceUUID, UUID charaUUID) { BLECommOperationResult rval = new BLECommOperationResult(); if (bluetoothConnectionGatt != null) { try { gattOperationSema.acquire(); SystemClock.sleep(1); // attempting to yield thread, to make sequence of events easier to follow } catch (InterruptedException e) { - LOG.error("readCharacteristic_blocking: Interrupted waiting for gattOperationSema"); + aapsLogger.error(LTag.PUMPBTCOMM, "readCharacteristic_blocking: Interrupted waiting for gattOperationSema"); return rval; } if (mCurrentOperation != null) { @@ -539,12 +533,12 @@ public class RileyLinkBLE { if (bluetoothConnectionGatt.getService(serviceUUID) == null) { // Catch if the service is not supported by the BLE device rval.resultCode = BLECommOperationResult.RESULT_NONE; - LOG.error("BT Device not supported"); + aapsLogger.error(LTag.PUMPBTCOMM, "BT Device not supported"); // TODO: 11/07/2016 UI update for user } else { BluetoothGattCharacteristic chara = bluetoothConnectionGatt.getService(serviceUUID).getCharacteristic( charaUUID); - mCurrentOperation = new CharacteristicReadOperation(bluetoothConnectionGatt, chara); + mCurrentOperation = new CharacteristicReadOperation(aapsLogger, bluetoothConnectionGatt, chara); mCurrentOperation.execute(this); if (mCurrentOperation.timedOut) { rval.resultCode = BLECommOperationResult.RESULT_TIMEOUT; @@ -559,7 +553,7 @@ public class RileyLinkBLE { mCurrentOperation = null; gattOperationSema.release(); } else { - LOG.error("readCharacteristic_blocking: not configured!"); + aapsLogger.error(LTag.PUMPBTCOMM, "readCharacteristic_blocking: not configured!"); rval.resultCode = BLECommOperationResult.RESULT_NOT_CONFIGURED; } return rval; @@ -582,9 +576,4 @@ public class RileyLinkBLE { return statusMessage; } - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPBTCOMM); - } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/command/SendAndListen.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/command/SendAndListen.java index 900275a05f..6304567751 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/command/SendAndListen.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/command/SendAndListen.java @@ -3,14 +3,20 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command; import java.nio.ByteBuffer; import java.util.ArrayList; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RadioPacket; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkCommandType; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkFirmwareVersion; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; public class SendAndListen extends RileyLinkCommand { + @Inject RileyLinkServiceData rileyLinkServiceData; + private byte sendChannel; private byte repeatCount; private int delayBetweenPackets_ms; @@ -21,20 +27,21 @@ public class SendAndListen extends RileyLinkCommand { private RadioPacket packetToSend; - public SendAndListen(byte sendChannel, byte repeatCount, byte delayBetweenPackets_ms, byte listenChannel, + public SendAndListen(HasAndroidInjector injector, byte sendChannel, byte repeatCount, byte delayBetweenPackets_ms, byte listenChannel, int timeout_ms, byte retryCount, RadioPacket packetToSend ) { - this(sendChannel, repeatCount, delayBetweenPackets_ms, listenChannel, timeout_ms, retryCount, null, + this(injector, sendChannel, repeatCount, delayBetweenPackets_ms, listenChannel, timeout_ms, retryCount, null, packetToSend); } - public SendAndListen(byte sendChannel, byte repeatCount, int delayBetweenPackets_ms, byte listenChannel, - int timeout_ms, byte retryCount, Integer preambleExtension_ms, RadioPacket packetToSend + public SendAndListen(HasAndroidInjector injector, byte sendChannel, byte repeatCount, int delayBetweenPackets_ms, byte listenChannel, + int timeout_ms, byte retryCount, Integer preambleExtension_ms, RadioPacket packetToSend ) { super(); + injector.androidInjector().inject(this); this.sendChannel = sendChannel; this.repeatCount = repeatCount; this.delayBetweenPackets_ms = delayBetweenPackets_ms; @@ -57,8 +64,8 @@ public class SendAndListen extends RileyLinkCommand { // If firmware version is not set (error reading version from device, shouldn't happen), // we will default to version 2 - boolean isPacketV2 = RileyLinkUtil.getFirmwareVersion() != null ? RileyLinkUtil.getFirmwareVersion() - .isSameVersion(RileyLinkFirmwareVersion.Version2AndHigher) : true; + boolean isPacketV2 = rileyLinkServiceData.firmwareVersion == null || rileyLinkServiceData.firmwareVersion + .isSameVersion(RileyLinkFirmwareVersion.Version2AndHigher); ArrayList bytes = new ArrayList(); bytes.add(this.getCommandType().code); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/command/SetPreamble.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/command/SetPreamble.java index 7333459f2b..d58525deb0 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/command/SetPreamble.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/command/SetPreamble.java @@ -4,20 +4,26 @@ import java.nio.ByteBuffer; import org.apache.commons.lang3.NotImplementedException; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkCommandType; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkFirmwareVersion; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; public class SetPreamble extends RileyLinkCommand { + @Inject RileyLinkServiceData rileyLinkServiceData; + private int preamble; - public SetPreamble(int preamble) throws Exception { + public SetPreamble(HasAndroidInjector injector, int preamble) throws Exception { super(); // this command was not supported before 2.0 - if (!RileyLinkUtil.getFirmwareVersion().isSameVersion(RileyLinkFirmwareVersion.Version2AndHigher)) { + if (!rileyLinkServiceData.firmwareVersion.isSameVersion(RileyLinkFirmwareVersion.Version2AndHigher)) { throw new NotImplementedException("Old firmware does not support SetPreamble command"); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RFSpyResponse.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RFSpyResponse.java index cf5362427c..a766e92266 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RFSpyResponse.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RFSpyResponse.java @@ -1,5 +1,6 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data; +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkCommunicationException; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command.RileyLinkCommand; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RFSpyRLResponse; @@ -48,12 +49,12 @@ public class RFSpyResponse { } - public RadioResponse getRadioResponse() throws RileyLinkCommunicationException { + public RadioResponse getRadioResponse(HasAndroidInjector injector) throws RileyLinkCommunicationException { if (looksLikeRadioPacket()) { - radioResponse = new RadioResponse(command); + radioResponse = new RadioResponse(injector, command); radioResponse.init(raw); } else { - radioResponse = new RadioResponse(); + radioResponse = new RadioResponse(injector); } return radioResponse; } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RadioPacket.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RadioPacket.java index a48e3de208..cff7c1b9d1 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RadioPacket.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RadioPacket.java @@ -2,6 +2,9 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data; import org.apache.commons.lang3.NotImplementedException; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.common.utils.CRC; @@ -12,10 +15,13 @@ import info.nightscout.androidaps.plugins.pump.common.utils.CRC; public class RadioPacket { - protected byte[] pkt; + @Inject RileyLinkUtil rileyLinkUtil; + + private byte[] pkt; - public RadioPacket(byte[] pkt) { + public RadioPacket(HasAndroidInjector injector, byte[] pkt) { + injector.androidInjector().inject(this); this.pkt = pkt; } @@ -25,7 +31,7 @@ public class RadioPacket { } - public byte[] getWithCRC() { + private byte[] getWithCRC() { byte[] withCRC = ByteUtil.concat(pkt, CRC.crc8(pkt)); return withCRC; } @@ -33,7 +39,7 @@ public class RadioPacket { public byte[] getEncoded() { - switch (RileyLinkUtil.getEncoding()) { + switch (rileyLinkUtil.getEncoding()) { case Manchester: { // We have this encoding in RL firmware return pkt; } @@ -41,8 +47,8 @@ public class RadioPacket { case FourByteSixByteLocal: { byte[] withCRC = getWithCRC(); - byte[] encoded = RileyLinkUtil.getEncoding4b6b().encode4b6b(withCRC); - return ByteUtil.concat(encoded, (byte)0); + byte[] encoded = rileyLinkUtil.getEncoding4b6b().encode4b6b(withCRC); + return ByteUtil.concat(encoded, (byte) 0); } case FourByteSixByteRileyLink: { @@ -50,8 +56,7 @@ public class RadioPacket { } default: - throw new NotImplementedException(("Encoding not supported: " + RileyLinkUtil.getEncoding().toString())); + throw new NotImplementedException(("Encoding not supported: " + rileyLinkUtil.getEncoding().toString())); } } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RadioResponse.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RadioResponse.java index 2b170cd0fb..785691e4c2 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RadioResponse.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/data/RadioResponse.java @@ -1,17 +1,19 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data; import org.apache.commons.lang3.NotImplementedException; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkCommunicationException; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.command.RileyLinkCommand; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkBLEError; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkCommandType; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkFirmwareVersion; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.common.utils.CRC; @@ -20,26 +22,25 @@ import info.nightscout.androidaps.plugins.pump.common.utils.CRC; */ public class RadioResponse { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPBTCOMM); - public boolean decodedOK = false; + @Inject AAPSLogger aapsLogger; + @Inject RileyLinkServiceData rileyLinkServiceData; + @Inject RileyLinkUtil rileyLinkUtil; + + private boolean decodedOK = false; public int rssi; - public int responseNumber; - public byte[] decodedPayload = new byte[0]; - public byte receivedCRC; + private int responseNumber; + private byte[] decodedPayload = new byte[0]; + private byte receivedCRC; private RileyLinkCommand command; - public RadioResponse() { - + public RadioResponse(HasAndroidInjector injector) { + injector.androidInjector().inject(this); } - - // public RadioResponse(byte[] rxData) { - // init(rxData); - // } - - public RadioResponse(RileyLinkCommand command /* , byte[] raw */) { + public RadioResponse(HasAndroidInjector injector, RileyLinkCommand command /* , byte[] raw */) { + this(injector); this.command = command; // init(raw); } @@ -75,8 +76,8 @@ public class RadioResponse { } byte[] encodedPayload; - if (RileyLinkFirmwareVersion.isSameVersion(RileyLinkUtil.getRileyLinkServiceData().versionCC110, - RileyLinkFirmwareVersion.Version2)) { + if (RileyLinkFirmwareVersion.isSameVersion(rileyLinkServiceData.versionCC110, + RileyLinkFirmwareVersion.Version2)) { encodedPayload = ByteUtil.substring(rxData, 3, rxData.length - 3); rssi = rxData[1]; responseNumber = rxData[2]; @@ -92,23 +93,23 @@ public class RadioResponse { // well, for non-radio commands we shouldn't even reach this point // but getVersion is kind of exception if (command != null && // - command.getCommandType() != RileyLinkCommandType.SendAndListen) { + command.getCommandType() != RileyLinkCommandType.SendAndListen) { decodedOK = true; decodedPayload = encodedPayload; return; } - switch (RileyLinkUtil.getEncoding()) { + switch (rileyLinkUtil.getEncoding()) { case Manchester: case FourByteSixByteRileyLink: { decodedOK = true; decodedPayload = encodedPayload; } - break; + break; case FourByteSixByteLocal: { - byte[] decodeThis = RileyLinkUtil.getEncoding4b6b().decode4b6b(encodedPayload); + byte[] decodeThis = rileyLinkUtil.getEncoding4b6b().decode4b6b(encodedPayload); if (decodeThis != null && decodeThis.length > 2) { decodedOK = true; @@ -117,22 +118,22 @@ public class RadioResponse { receivedCRC = decodeThis[decodeThis.length - 1]; byte calculatedCRC = CRC.crc8(decodedPayload); if (receivedCRC != calculatedCRC) { - LOG.error(String.format("RadioResponse: CRC mismatch, calculated 0x%02x, received 0x%02x", - calculatedCRC, receivedCRC)); + aapsLogger.error(LTag.PUMPCOMM, String.format("RadioResponse: CRC mismatch, calculated 0x%02x, received 0x%02x", + calculatedCRC, receivedCRC)); } } else { throw new RileyLinkCommunicationException(RileyLinkBLEError.TooShortOrNullResponse); } } - break; + break; default: - throw new NotImplementedException("this {" + RileyLinkUtil.getEncoding().toString() - + "} encoding is not supported"); + throw new NotImplementedException("this {" + rileyLinkUtil.getEncoding().toString() + + "} encoding is not supported"); } } catch (NumberFormatException e) { decodedOK = false; - LOG.error("Failed to decode radio data: " + ByteUtil.shortHexString(encodedPayload)); + aapsLogger.error(LTag.PUMPBTCOMM, "Failed to decode radio data: " + ByteUtil.shortHexString(encodedPayload)); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/CharacteristicReadOperation.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/CharacteristicReadOperation.java index a891fce501..09a3c58469 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/CharacteristicReadOperation.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/CharacteristicReadOperation.java @@ -1,17 +1,14 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.operations; -import java.util.UUID; -import java.util.concurrent.TimeUnit; - -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import android.bluetooth.BluetoothGatt; import android.bluetooth.BluetoothGattCharacteristic; import android.os.SystemClock; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import java.util.UUID; +import java.util.concurrent.TimeUnit; + +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkBLE; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.GattAttributes; @@ -20,12 +17,13 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.Gatt */ public class CharacteristicReadOperation extends BLECommOperation { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPBTCOMM); + private final AAPSLogger aapsLogger; private BluetoothGattCharacteristic characteristic; - public CharacteristicReadOperation(BluetoothGatt gatt, BluetoothGattCharacteristic chara) { + public CharacteristicReadOperation(AAPSLogger aapsLogger, BluetoothGatt gatt, BluetoothGattCharacteristic chara) { + this.aapsLogger = aapsLogger; this.gatt = gatt; this.characteristic = chara; } @@ -39,15 +37,14 @@ public class CharacteristicReadOperation extends BLECommOperation { boolean didAcquire = operationComplete.tryAcquire(getGattOperationTimeout_ms(), TimeUnit.MILLISECONDS); if (didAcquire) { SystemClock.sleep(1); // This is to allow the IBinder thread to exit before we continue, allowing easier - // understanding of the sequence of events. + // understanding of the sequence of events. // success } else { - LOG.error("Timeout waiting for gatt write operation to complete"); + aapsLogger.error(LTag.PUMPBTCOMM, "Timeout waiting for gatt write operation to complete"); timedOut = true; } } catch (InterruptedException e) { - if (isLogEnabled()) - LOG.error("Interrupted while waiting for gatt write operation to complete"); + aapsLogger.error(LTag.PUMPBTCOMM, "Interrupted while waiting for gatt write operation to complete"); interrupted = true; } value = characteristic.getValue(); @@ -58,15 +55,10 @@ public class CharacteristicReadOperation extends BLECommOperation { public void gattOperationCompletionCallback(UUID uuid, byte[] value) { super.gattOperationCompletionCallback(uuid, value); if (!characteristic.getUuid().equals(uuid)) { - LOG.error(String.format( - "Completion callback: UUID does not match! out of sequence? Found: %s, should be %s", - GattAttributes.lookup(characteristic.getUuid()), GattAttributes.lookup(uuid))); + aapsLogger.error(LTag.PUMPCOMM, String.format( + "Completion callback: UUID does not match! out of sequence? Found: %s, should be %s", + GattAttributes.lookup(characteristic.getUuid()), GattAttributes.lookup(uuid))); } operationComplete.release(); } - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPBTCOMM); - } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/CharacteristicWriteOperation.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/CharacteristicWriteOperation.java index 54f20d517d..011135e7ac 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/CharacteristicWriteOperation.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/CharacteristicWriteOperation.java @@ -1,17 +1,14 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.operations; -import java.util.UUID; -import java.util.concurrent.TimeUnit; - -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import android.bluetooth.BluetoothGatt; import android.bluetooth.BluetoothGattCharacteristic; import android.os.SystemClock; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import java.util.UUID; +import java.util.concurrent.TimeUnit; + +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkBLE; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.GattAttributes; @@ -20,12 +17,13 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.Gatt */ public class CharacteristicWriteOperation extends BLECommOperation { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPBTCOMM); + private final AAPSLogger aapsLogger; private BluetoothGattCharacteristic characteristic; - public CharacteristicWriteOperation(BluetoothGatt gatt, BluetoothGattCharacteristic chara, byte[] value) { + public CharacteristicWriteOperation(AAPSLogger aapsLogger, BluetoothGatt gatt, BluetoothGattCharacteristic chara, byte[] value) { + this.aapsLogger = aapsLogger; this.gatt = gatt; this.characteristic = chara; this.value = value; @@ -42,14 +40,14 @@ public class CharacteristicWriteOperation extends BLECommOperation { boolean didAcquire = operationComplete.tryAcquire(getGattOperationTimeout_ms(), TimeUnit.MILLISECONDS); if (didAcquire) { SystemClock.sleep(1); // This is to allow the IBinder thread to exit before we continue, allowing easier - // understanding of the sequence of events. + // understanding of the sequence of events. // success } else { - LOG.error("Timeout waiting for gatt write operation to complete"); + aapsLogger.error(LTag.PUMPBTCOMM, "Timeout waiting for gatt write operation to complete"); timedOut = true; } } catch (InterruptedException e) { - LOG.error("Interrupted while waiting for gatt write operation to complete"); + aapsLogger.error(LTag.PUMPBTCOMM, "Interrupted while waiting for gatt write operation to complete"); interrupted = true; } @@ -60,16 +58,10 @@ public class CharacteristicWriteOperation extends BLECommOperation { @Override public void gattOperationCompletionCallback(UUID uuid, byte[] value) { if (!characteristic.getUuid().equals(uuid)) { - LOG.error(String.format( - "Completion callback: UUID does not match! out of sequence? Found: %s, should be %s", - GattAttributes.lookup(characteristic.getUuid()), GattAttributes.lookup(uuid))); + aapsLogger.error(LTag.PUMPCOMM, String.format( + "Completion callback: UUID does not match! out of sequence? Found: %s, should be %s", + GattAttributes.lookup(characteristic.getUuid()), GattAttributes.lookup(uuid))); } operationComplete.release(); } - - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPBTCOMM); - } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/DescriptorWriteOperation.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/DescriptorWriteOperation.java index 82f3359198..49c912e997 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/DescriptorWriteOperation.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/ble/operations/DescriptorWriteOperation.java @@ -1,16 +1,14 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.operations; -import java.util.UUID; -import java.util.concurrent.TimeUnit; - -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import android.bluetooth.BluetoothGatt; import android.bluetooth.BluetoothGattDescriptor; import android.os.SystemClock; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import java.util.UUID; +import java.util.concurrent.TimeUnit; + +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkBLE; /** @@ -18,12 +16,13 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLink */ public class DescriptorWriteOperation extends BLECommOperation { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(DescriptorWriteOperation.class); + private final AAPSLogger aapsLogger; private BluetoothGattDescriptor descr; - public DescriptorWriteOperation(BluetoothGatt gatt, BluetoothGattDescriptor descr, byte[] value) { + public DescriptorWriteOperation(AAPSLogger aapsLogger, BluetoothGatt gatt, BluetoothGattDescriptor descr, byte[] value) { + this.aapsLogger = aapsLogger; this.gatt = gatt; this.descr = descr; this.value = value; @@ -46,14 +45,14 @@ public class DescriptorWriteOperation extends BLECommOperation { boolean didAcquire = operationComplete.tryAcquire(getGattOperationTimeout_ms(), TimeUnit.MILLISECONDS); if (didAcquire) { SystemClock.sleep(1); // This is to allow the IBinder thread to exit before we continue, allowing easier - // understanding of the sequence of events. + // understanding of the sequence of events. // success } else { - LOG.error("Timeout waiting for descriptor write operation to complete"); + aapsLogger.error(LTag.PUMPBTCOMM, "Timeout waiting for descriptor write operation to complete"); timedOut = true; } } catch (InterruptedException e) { - LOG.error("Interrupted while waiting for descriptor write operation to complete"); + aapsLogger.error(LTag.PUMPBTCOMM, "Interrupted while waiting for descriptor write operation to complete"); interrupted = true; } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/data/RLHistoryItem.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/data/RLHistoryItem.java index be6cfb3e2d..f8d1909bad 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/data/RLHistoryItem.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/data/RLHistoryItem.java @@ -2,12 +2,12 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.data; import org.joda.time.LocalDateTime; -import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkError; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicCommandType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; +import info.nightscout.androidaps.utils.resources.ResourceHelper; /** * Created by andy on 5/19/18. @@ -26,7 +26,7 @@ public class RLHistoryItem { public RLHistoryItem(RileyLinkServiceState serviceState, RileyLinkError errorCode, - RileyLinkTargetDevice targetDevice) { + RileyLinkTargetDevice targetDevice) { this.targetDevice = targetDevice; this.dateTime = new LocalDateTime(); this.serviceState = serviceState; @@ -65,16 +65,16 @@ public class RLHistoryItem { } - public String getDescription() { + public String getDescription(ResourceHelper resourceHelper) { // TODO extend when we have Omnipod switch (this.source) { case RileyLink: - return "State: " + MainApp.gs(serviceState.getResourceId(targetDevice)) - + (this.errorCode == null ? "" : ", Error Code: " + errorCode); + return "State: " + resourceHelper.gs(serviceState.getResourceId(targetDevice)) + + (this.errorCode == null ? "" : ", Error Code: " + errorCode); case MedtronicPump: - return MainApp.gs(pumpDeviceState.getResourceId()); + return resourceHelper.gs(pumpDeviceState.getResourceId()); case MedtronicCommand: return medtronicCommandType.name(); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusActivity.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusActivity.java index 5d6b2a655b..57aa01123f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusActivity.java @@ -26,12 +26,13 @@ import info.nightscout.androidaps.utils.resources.ResourceHelper; public class RileyLinkStatusActivity extends NoSplashAppCompatActivity { @Inject ResourceHelper resourceHelper; + @Inject RileyLinkUtil rileyLinkUtil; + @Inject RileyLinkServiceData rileyLinkServiceData; TextView connectionStatus; TextView configuredAddress; TextView connectedDevice; TextView connectionError; - RileyLinkServiceData rileyLinkServiceData; private SectionsPagerAdapter mSectionsPagerAdapter; private FloatingActionButton floatingActionButton; @@ -76,8 +77,6 @@ public class RileyLinkStatusActivity extends NoSplashAppCompatActivity { this.connectedDevice = findViewById(R.id.rls_t1_connected_device); this.connectionError = findViewById(R.id.rls_t1_connection_error); - rileyLinkServiceData = RileyLinkUtil.getRileyLinkServiceData(); - // // 7-12 // int[] ids = {R.id.rls_t1_tv02, R.id.rls_t1_tv03, R.id.rls_t1_tv04, R.id.rls_t1_tv05, R.id.rls_t1_tv07, // // R.id.rls_t1_tv08, R.id.rls_t1_tv09, R.id.rls_t1_tv10, R.id.rls_t1_tv11, R.id.rls_t1_tv12}; @@ -97,12 +96,12 @@ public class RileyLinkStatusActivity extends NoSplashAppCompatActivity { public void refreshData(int position) { if (position == 0) { // FIXME i18n - this.connectionStatus.setText(rileyLinkServiceData.serviceState.name()); + this.connectionStatus.setText(rileyLinkServiceData.rileyLinkServiceState.name()); this.configuredAddress.setText(rileyLinkServiceData.rileylinkAddress); // FIXME this.connectedDevice.setText("???"); // FIXME i18n - this.connectionError.setText(rileyLinkServiceData.errorCode.name()); + this.connectionError.setText(rileyLinkServiceData.rileyLinkError.name()); } else { } @@ -114,8 +113,8 @@ public class RileyLinkStatusActivity extends NoSplashAppCompatActivity { mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager()); - mSectionsPagerAdapter.addFragment(new RileyLinkStatusGeneral(), resourceHelper.gs(R.string.rileylink_settings_tab1)); - mSectionsPagerAdapter.addFragment(new RileyLinkStatusHistory(), resourceHelper.gs(R.string.rileylink_settings_tab2)); + mSectionsPagerAdapter.addFragment(new RileyLinkStatusGeneralFragment(), resourceHelper.gs(R.string.rileylink_settings_tab1)); + mSectionsPagerAdapter.addFragment(new RileyLinkStatusHistoryFragment(), resourceHelper.gs(R.string.rileylink_settings_tab2)); //mSectionsPagerAdapter.addFragment(new RileyLinkStatusDevice(), "Medtronic"); mViewPager.setAdapter(mSectionsPagerAdapter); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusGeneral.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusGeneralFragment.java similarity index 74% rename from app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusGeneral.java rename to app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusGeneralFragment.java index 021d1ee068..34833f707e 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusGeneral.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusGeneralFragment.java @@ -1,7 +1,6 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.dialog; import android.os.Bundle; -import androidx.fragment.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; @@ -11,23 +10,33 @@ import org.joda.time.LocalDateTime; import java.util.Locale; -import info.nightscout.androidaps.MainApp; +import javax.inject.Inject; + +import dagger.android.support.DaggerFragment; import info.nightscout.androidaps.R; import info.nightscout.androidaps.plugins.pump.common.dialog.RefreshableInterface; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkFirmwareVersion; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.utils.StringUtil; +import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpStatus; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; +import info.nightscout.androidaps.utils.resources.ResourceHelper; /** * Created by andy on 5/19/18. */ -public class RileyLinkStatusGeneral extends Fragment implements RefreshableInterface { +public class RileyLinkStatusGeneralFragment extends DaggerFragment implements RefreshableInterface { + + @Inject RileyLinkUtil rileyLinkUtil; + @Inject MedtronicUtil medtronicUtil; + @Inject MedtronicPumpStatus medtronicPumpStatus; + @Inject ResourceHelper resourceHelper; + @Inject MedtronicPumpPlugin medtronicPumpPlugin; + @Inject RileyLinkServiceData rileyLinkServiceData; TextView connectionStatus; TextView configuredAddress; @@ -41,9 +50,6 @@ public class RileyLinkStatusGeneral extends Fragment implements RefreshableInter TextView lastDeviceContact; TextView firmwareVersion; - RileyLinkServiceData rileyLinkServiceData; - - MedtronicPumpStatus medtronicPumpStatus; boolean first = false; @@ -58,7 +64,6 @@ public class RileyLinkStatusGeneral extends Fragment implements RefreshableInter @Override public void onStart() { super.onStart(); - rileyLinkServiceData = RileyLinkUtil.getRileyLinkServiceData(); this.connectionStatus = getActivity().findViewById(R.id.rls_t1_connection_status); this.configuredAddress = getActivity().findViewById(R.id.rls_t1_configured_address); @@ -93,23 +98,20 @@ public class RileyLinkStatusGeneral extends Fragment implements RefreshableInter public void refreshData() { - RileyLinkTargetDevice targetDevice = RileyLinkUtil.getTargetDevice(); + RileyLinkTargetDevice targetDevice = rileyLinkServiceData.targetDevice; - if (RileyLinkUtil.getServiceState()==null) - this.connectionStatus.setText(MainApp.gs(RileyLinkServiceState.NotStarted.getResourceId(targetDevice))); - else - this.connectionStatus.setText(MainApp.gs(RileyLinkUtil.getServiceState().getResourceId(targetDevice))); + this.connectionStatus.setText(resourceHelper.gs(rileyLinkServiceData.rileyLinkServiceState.getResourceId(targetDevice))); if (rileyLinkServiceData != null) { this.configuredAddress.setText(rileyLinkServiceData.rileylinkAddress); - this.connectionError.setText(rileyLinkServiceData.errorCode == null ? // + this.connectionError.setText(rileyLinkServiceData.rileyLinkError == null ? // "-" - : MainApp.gs(rileyLinkServiceData.errorCode.getResourceId(targetDevice))); + : resourceHelper.gs(rileyLinkServiceData.rileyLinkError.getResourceId(targetDevice))); RileyLinkFirmwareVersion firmwareVersion = rileyLinkServiceData.versionCC110; - if (firmwareVersion==null) { + if (firmwareVersion == null) { this.firmwareVersion.setText("BLE113: -\nCC110: -"); } else { this.firmwareVersion.setText("BLE113: " + rileyLinkServiceData.versionBLE113 + // @@ -119,18 +121,17 @@ public class RileyLinkStatusGeneral extends Fragment implements RefreshableInter } // TODO add handling for Omnipod pump status - this.medtronicPumpStatus = MedtronicUtil.getPumpStatus(); if (medtronicPumpStatus != null) { - this.deviceType.setText(MainApp.gs(RileyLinkTargetDevice.MedtronicPump.getResourceId())); - this.deviceModel.setText(medtronicPumpStatus.pumpType.getDescription()); + this.deviceType.setText(resourceHelper.gs(RileyLinkTargetDevice.MedtronicPump.getResourceId())); + this.deviceModel.setText(medtronicPumpPlugin.getPumpDescription().pumpType.getDescription()); this.serialNumber.setText(medtronicPumpStatus.serialNumber); - this.pumpFrequency.setText(MainApp.gs(medtronicPumpStatus.pumpFrequency.equals("medtronic_pump_frequency_us_ca") ? R.string.medtronic_pump_frequency_us_ca : R.string.medtronic_pump_frequency_worldwide)); + this.pumpFrequency.setText(resourceHelper.gs(medtronicPumpStatus.pumpFrequency.equals("medtronic_pump_frequency_us_ca") ? R.string.medtronic_pump_frequency_us_ca : R.string.medtronic_pump_frequency_worldwide)); // TODO extend when Omnipod used - if (MedtronicUtil.getMedtronicPumpModel() != null) - this.connectedDevice.setText("Medtronic " + MedtronicUtil.getMedtronicPumpModel().getPumpModel()); + if (medtronicUtil.getMedtronicPumpModel() != null) + this.connectedDevice.setText("Medtronic " + medtronicUtil.getMedtronicPumpModel().getPumpModel()); else this.connectedDevice.setText("???"); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusHistory.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusHistoryFragment.java similarity index 74% rename from app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusHistory.java rename to app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusHistoryFragment.java index ae32018111..f8f79c821a 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusHistory.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/dialog/RileyLinkStatusHistoryFragment.java @@ -1,33 +1,39 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.dialog; -import java.util.ArrayList; -import java.util.Collections; -import java.util.List; - import android.os.Bundle; -import androidx.fragment.app.Fragment; -import androidx.recyclerview.widget.LinearLayoutManager; -import androidx.recyclerview.widget.RecyclerView; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView; +import androidx.recyclerview.widget.LinearLayoutManager; +import androidx.recyclerview.widget.RecyclerView; + import org.jetbrains.annotations.NotNull; +import java.util.ArrayList; +import java.util.Collections; +import java.util.List; + +import javax.inject.Inject; + +import dagger.android.support.DaggerFragment; import info.nightscout.androidaps.R; import info.nightscout.androidaps.plugins.pump.common.dialog.RefreshableInterface; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.data.RLHistoryItem; -import info.nightscout.androidaps.plugins.pump.common.utils.StringUtil; import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; import info.nightscout.androidaps.utils.DateUtil; +import info.nightscout.androidaps.utils.resources.ResourceHelper; /** * Created by andy on 5/19/18. */ -public class RileyLinkStatusHistory extends Fragment implements RefreshableInterface { +public class RileyLinkStatusHistoryFragment extends DaggerFragment implements RefreshableInterface { + + @Inject RileyLinkUtil rileyLinkUtil; + @Inject ResourceHelper resourceHelper; RecyclerView recyclerView; RecyclerViewAdapter recyclerViewAdapter; @@ -40,10 +46,10 @@ public class RileyLinkStatusHistory extends Fragment implements RefreshableInter public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View rootView = inflater.inflate(R.layout.rileylink_status_history, container, false); - recyclerView = (RecyclerView)rootView.findViewById(R.id.rileylink_history_list); + recyclerView = (RecyclerView) rootView.findViewById(R.id.rileylink_history_list); recyclerView.setHasFixedSize(true); - llm = new LinearLayoutManager(getActivity().getApplicationContext()); + llm = new LinearLayoutManager(rootView.getContext()); recyclerView.setLayoutManager(llm); recyclerViewAdapter = new RecyclerViewAdapter(filteredHistoryList); @@ -63,13 +69,13 @@ public class RileyLinkStatusHistory extends Fragment implements RefreshableInter @Override public void refreshData() { - if (RileyLinkUtil.getRileyLinkHistory()!=null) { - recyclerViewAdapter.addItemsAndClean(RileyLinkUtil.getRileyLinkHistory()); + if (rileyLinkUtil.getRileyLinkHistory() != null) { + recyclerViewAdapter.addItemsAndClean(rileyLinkUtil.getRileyLinkHistory()); } } - public static class RecyclerViewAdapter extends RecyclerView.Adapter { + public class RecyclerViewAdapter extends RecyclerView.Adapter { List historyList; @@ -104,11 +110,11 @@ public class RileyLinkStatusHistory extends Fragment implements RefreshableInter PumpDeviceState pumpState = item.getPumpDeviceState(); - if ((pumpState != null) && // - (pumpState == PumpDeviceState.Sleeping || // + // + if ((pumpState == PumpDeviceState.Sleeping || // pumpState == PumpDeviceState.Active || // - pumpState == PumpDeviceState.WakingUp // - )) + pumpState == PumpDeviceState.WakingUp // + )) return false; return true; @@ -120,7 +126,7 @@ public class RileyLinkStatusHistory extends Fragment implements RefreshableInter @Override public RecyclerViewAdapter.HistoryViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) { View v = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.rileylink_status_history_item, // - viewGroup, false); + viewGroup, false); return new RecyclerViewAdapter.HistoryViewHolder(v); } @@ -132,7 +138,7 @@ public class RileyLinkStatusHistory extends Fragment implements RefreshableInter if (item != null) { holder.timeView.setText(DateUtil.dateAndTimeAndSecondsString(item.getDateTime().toDateTime().getMillis())); holder.typeView.setText(item.getSource().getDesc()); - holder.valueView.setText(item.getDescription()); + holder.valueView.setText(item.getDescription(resourceHelper)); } } @@ -148,7 +154,7 @@ public class RileyLinkStatusHistory extends Fragment implements RefreshableInter super.onAttachedToRecyclerView(recyclerView); } - static class HistoryViewHolder extends RecyclerView.ViewHolder { + class HistoryViewHolder extends RecyclerView.ViewHolder { TextView timeView; TextView typeView; @@ -158,9 +164,9 @@ public class RileyLinkStatusHistory extends Fragment implements RefreshableInter HistoryViewHolder(View itemView) { super(itemView); - timeView = (TextView)itemView.findViewById(R.id.rileylink_history_time); - typeView = (TextView)itemView.findViewById(R.id.rileylink_history_source); - valueView = (TextView)itemView.findViewById(R.id.rileylink_history_description); + timeView = (TextView) itemView.findViewById(R.id.rileylink_history_time); + typeView = (TextView) itemView.findViewById(R.id.rileylink_history_source); + valueView = (TextView) itemView.findViewById(R.id.rileylink_history_description); } } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkBluetoothStateReceiver.kt b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkBluetoothStateReceiver.kt index c677ae0c1e..54e2f59cbd 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkBluetoothStateReceiver.kt +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkBluetoothStateReceiver.kt @@ -1,7 +1,6 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service import android.bluetooth.BluetoothAdapter -import android.content.BroadcastReceiver import android.content.Context import android.content.Intent import android.content.IntentFilter @@ -15,6 +14,7 @@ import javax.inject.Inject class RileyLinkBluetoothStateReceiver : DaggerBroadcastReceiver() { @Inject lateinit var aapsLogger: AAPSLogger @Inject lateinit var activePlugin: ActivePluginProvider + @Inject lateinit var rileyLinkUtil: RileyLinkUtil override fun onReceive(context: Context, intent: Intent) { super.onReceive(context, intent) @@ -27,7 +27,7 @@ class RileyLinkBluetoothStateReceiver : DaggerBroadcastReceiver() { BluetoothAdapter.STATE_ON -> { aapsLogger.debug("RileyLinkBluetoothStateReceiver: Bluetooth back on. Sending broadcast to RileyLink Framework") - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.BluetoothReconnected) + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.BluetoothReconnected, context) } } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkBroadcastReceiver.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkBroadcastReceiver.java index 9dfb05fc63..f7d3b686e0 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkBroadcastReceiver.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkBroadcastReceiver.java @@ -5,24 +5,24 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service; */ import android.bluetooth.BluetoothAdapter; -import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.content.IntentFilter; -import androidx.localbroadcastmanager.content.LocalBroadcastManager; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; +import androidx.localbroadcastmanager.content.LocalBroadcastManager; import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import javax.inject.Inject; + +import dagger.android.DaggerBroadcastReceiver; +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkFirmwareVersion; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkError; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; @@ -31,26 +31,27 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.ServiceTask; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.ServiceTaskExecutor; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.WakeAndTuneTask; -import info.nightscout.androidaps.utils.SP; +import info.nightscout.androidaps.utils.sharedPreferences.SP; /** * I added this class outside of RileyLinkService, because for now it's very important part of RL framework and * where we get a lot of problems. Especially merging between AAPS and RileyLinkAAPS. I might put it back at * later time */ -public class RileyLinkBroadcastReceiver extends BroadcastReceiver { +public class RileyLinkBroadcastReceiver extends DaggerBroadcastReceiver { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + @Inject HasAndroidInjector injector; + @Inject SP sp; + @Inject AAPSLogger aapsLogger; + @Inject RileyLinkServiceData rileyLinkServiceData; + @Inject ServiceTaskExecutor serviceTaskExecutor; RileyLinkService serviceInstance; protected Map> broadcastIdentifiers = null; String deviceSpecificPrefix; - Context context; - - public RileyLinkBroadcastReceiver(RileyLinkService serviceInstance, Context context) { + public RileyLinkBroadcastReceiver(RileyLinkService serviceInstance) { this.serviceInstance = serviceInstance; - this.context = context; createBroadcastIdentifiers(); } @@ -88,31 +89,31 @@ public class RileyLinkBroadcastReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { + super.onReceive(context, intent); if (intent == null) { - LOG.error("onReceive: received null intent"); + aapsLogger.error(LTag.PUMPCOMM, "onReceive: received null intent"); } else { String action = intent.getAction(); if (action == null) { - LOG.error("onReceive: null action"); + aapsLogger.error("onReceive: null action"); } else { - if (isLoggingEnabled()) - LOG.debug("Received Broadcast: " + action); + aapsLogger.debug(LTag.PUMPCOMM, "Received Broadcast: " + action); if (!processBluetoothBroadcasts(action) && // - !processRileyLinkBroadcasts(action) && // + !processRileyLinkBroadcasts(action, context) && // !processTuneUpBroadcasts(action) && // !processDeviceSpecificBroadcasts(action, intent) && // !processApplicationSpecificBroadcasts(action, intent) // ) { - LOG.error("Unhandled broadcast: action=" + action); + aapsLogger.error(LTag.PUMPCOMM, "Unhandled broadcast: action=" + action); } } } } - public void registerBroadcasts() { + public void registerBroadcasts(Context context) { IntentFilter intentFilter = new IntentFilter(); @@ -131,61 +132,55 @@ public class RileyLinkBroadcastReceiver extends BroadcastReceiver { } - private boolean processRileyLinkBroadcasts(String action) { + private boolean processRileyLinkBroadcasts(String action, Context context) { if (action.equals(RileyLinkConst.Intents.RileyLinkDisconnected)) { if (BluetoothAdapter.getDefaultAdapter().isEnabled()) { - RileyLinkUtil - .setServiceState(RileyLinkServiceState.BluetoothError, RileyLinkError.RileyLinkUnreachable); + rileyLinkServiceData.setServiceState(RileyLinkServiceState.BluetoothError, RileyLinkError.RileyLinkUnreachable); } else { - RileyLinkUtil.setServiceState(RileyLinkServiceState.BluetoothError, RileyLinkError.BluetoothDisabled); + rileyLinkServiceData.setServiceState(RileyLinkServiceState.BluetoothError, RileyLinkError.BluetoothDisabled); } return true; } else if (action.equals(RileyLinkConst.Intents.RileyLinkReady)) { - if (isLoggingEnabled()) - LOG.warn("MedtronicConst.Intents.RileyLinkReady"); + aapsLogger.warn(LTag.PUMPCOMM, "MedtronicConst.Intents.RileyLinkReady"); // sendIPCNotification(RT2Const.IPC.MSG_note_WakingPump); - if (this.serviceInstance.rileyLinkBLE == null) - return false; + serviceInstance.rileyLinkBLE.enableNotifications(); + serviceInstance.rfspy.startReader(); // call startReader from outside? - this.serviceInstance.rileyLinkBLE.enableNotifications(); - this.serviceInstance.rfspy.startReader(); // call startReader from outside? - - this.serviceInstance.rfspy.initializeRileyLink(); - String bleVersion = this.serviceInstance.rfspy.getBLEVersionCached(); - RileyLinkFirmwareVersion rlVersion = this.serviceInstance.rfspy.getRLVersionCached(); + serviceInstance.rfspy.initializeRileyLink(); + String bleVersion = serviceInstance.rfspy.getBLEVersionCached(); + RileyLinkFirmwareVersion rlVersion = rileyLinkServiceData.firmwareVersion; // if (isLoggingEnabled()) - LOG.debug("RfSpy version (BLE113): " + bleVersion); - this.serviceInstance.rileyLinkServiceData.versionBLE113 = bleVersion; + aapsLogger.debug(LTag.PUMPCOMM, "RfSpy version (BLE113): " + bleVersion); + serviceInstance.rileyLinkServiceData.versionBLE113 = bleVersion; // if (isLoggingEnabled()) - LOG.debug("RfSpy Radio version (CC110): " + rlVersion.name()); - this.serviceInstance.rileyLinkServiceData.versionCC110 = rlVersion; + aapsLogger.debug(LTag.PUMPCOMM, "RfSpy Radio version (CC110): " + rlVersion.name()); + serviceInstance.rileyLinkServiceData.versionCC110 = rlVersion; - ServiceTask task = new InitializePumpManagerTask(RileyLinkUtil.getTargetDevice()); - ServiceTaskExecutor.startTask(task); - if (isLoggingEnabled()) - LOG.info("Announcing RileyLink open For business"); + ServiceTask task = new InitializePumpManagerTask(injector, context); + serviceTaskExecutor.startTask(task); + aapsLogger.info(LTag.PUMPCOMM, "Announcing RileyLink open For business"); return true; } else if (action.equals(RileyLinkConst.Intents.RileyLinkNewAddressSet)) { - String RileylinkBLEAddress = SP.getString(RileyLinkConst.Prefs.RileyLinkAddress, ""); + String RileylinkBLEAddress = sp.getString(RileyLinkConst.Prefs.RileyLinkAddress, ""); if (RileylinkBLEAddress.equals("")) { - LOG.error("No Rileylink BLE Address saved in app"); + aapsLogger.error("No Rileylink BLE Address saved in app"); } else { // showBusy("Configuring Service", 50); // rileyLinkBLE.findRileyLink(RileylinkBLEAddress); - this.serviceInstance.reconfigureRileyLink(RileylinkBLEAddress); + serviceInstance.reconfigureRileyLink(RileylinkBLEAddress); // MainApp.getServiceClientConnection().setThisRileylink(RileylinkBLEAddress); } return true; } else if (action.equals(RileyLinkConst.Intents.RileyLinkDisconnect)) { - this.serviceInstance.disconnectRileyLink(); + serviceInstance.disconnectRileyLink(); return true; } else { @@ -198,18 +193,16 @@ public class RileyLinkBroadcastReceiver extends BroadcastReceiver { public boolean processBluetoothBroadcasts(String action) { if (action.equals(RileyLinkConst.Intents.BluetoothConnected)) { - if (isLoggingEnabled()) - LOG.debug("Bluetooth - Connected"); - ServiceTaskExecutor.startTask(new DiscoverGattServicesTask()); + aapsLogger.debug(LTag.PUMPCOMM, "Bluetooth - Connected"); + serviceTaskExecutor.startTask(new DiscoverGattServicesTask(injector)); return true; } else if (action.equals(RileyLinkConst.Intents.BluetoothReconnected)) { - if (isLoggingEnabled()) - LOG.debug("Bluetooth - Reconnecting"); + aapsLogger.debug(LTag.PUMPCOMM, "Bluetooth - Reconnecting"); serviceInstance.bluetoothInit(); - ServiceTaskExecutor.startTask(new DiscoverGattServicesTask(true)); + serviceTaskExecutor.startTask(new DiscoverGattServicesTask(injector, true)); return true; } else { @@ -224,7 +217,7 @@ public class RileyLinkBroadcastReceiver extends BroadcastReceiver { if (this.broadcastIdentifiers.get("TuneUp").contains(action)) { if (serviceInstance.getRileyLinkTargetDevice().isTuneUpEnabled()) { - ServiceTaskExecutor.startTask(new WakeAndTuneTask()); + serviceTaskExecutor.startTask(new WakeAndTuneTask(injector)); } return true; } else { @@ -240,7 +233,7 @@ public class RileyLinkBroadcastReceiver extends BroadcastReceiver { } if (action.startsWith(this.deviceSpecificPrefix)) { - return this.serviceInstance.handleDeviceSpecificBroadcasts(intent); + return serviceInstance.handleDeviceSpecificBroadcasts(intent); } else return false; } @@ -250,12 +243,7 @@ public class RileyLinkBroadcastReceiver extends BroadcastReceiver { return false; } - - public boolean isLoggingEnabled() { - return (L.isEnabled(L.PUMPCOMM)); - } - - public void unregisterBroadcasts() { + public void unregisterBroadcasts(Context context) { LocalBroadcastManager.getInstance(context).unregisterReceiver(this); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkService.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkService.java index 41c4028f96..414bc6177b 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkService.java @@ -5,11 +5,14 @@ import android.content.Context; import android.content.Intent; import android.content.IntentFilter; +import org.jetbrains.annotations.NotNull; + import javax.inject.Inject; import dagger.android.DaggerService; import info.nightscout.androidaps.logging.AAPSLogger; import info.nightscout.androidaps.logging.LTag; +import info.nightscout.androidaps.plugins.bus.RxBusWrapper; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkCommunicationManager; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; @@ -22,11 +25,10 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLin import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceResult; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceTransport; import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; +import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpStatus; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; import info.nightscout.androidaps.utils.sharedPreferences.SP; -import static info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil.getRileyLinkCommunicationManager; - /** * Created by andy on 5/6/18. * Split from original file and renamed. @@ -36,26 +38,28 @@ public abstract class RileyLinkService extends DaggerService { @Inject protected AAPSLogger aapsLogger; @Inject protected SP sp; @Inject protected Context context; + @Inject protected RxBusWrapper rxBus; + @Inject protected RileyLinkUtil rileyLinkUtil; + @Inject protected MedtronicUtil medtronicUtil; // TODO should be avoided here as it's MDT + @Inject protected RileyLinkServiceData rileyLinkServiceData; + @Inject protected MedtronicPumpStatus medtronicPumpStatus; - - public RileyLinkBLE rileyLinkBLE; // android-bluetooth management + @NotNull protected RileyLinkBLE rileyLinkBLE; // android-bluetooth management, must be set in initRileyLinkServiceData protected BluetoothAdapter bluetoothAdapter; protected RFSpy rfspy; // interface for RL xxx Mhz radio. protected RileyLinkBroadcastReceiver mBroadcastReceiver; - protected RileyLinkServiceData rileyLinkServiceData; protected RileyLinkBluetoothStateReceiver bluetoothStateReceiver; + @Override public void onCreate() { super.onCreate(); - RileyLinkUtil.setContext(this.context); - RileyLinkUtil.setRileyLinkService(this); - RileyLinkUtil.setEncoding(getEncoding()); + rileyLinkUtil.setEncoding(getEncoding()); initRileyLinkServiceData(); - mBroadcastReceiver = new RileyLinkBroadcastReceiver(this, this.context); - mBroadcastReceiver.registerBroadcasts(); + mBroadcastReceiver = new RileyLinkBroadcastReceiver(this); + mBroadcastReceiver.registerBroadcasts(this); bluetoothStateReceiver = new RileyLinkBluetoothStateReceiver(); @@ -93,13 +97,10 @@ public abstract class RileyLinkService extends DaggerService { super.onDestroy(); //LOG.error("I die! I die!"); - if (rileyLinkBLE != null) { - rileyLinkBLE.disconnect(); // dispose of Gatt (disconnect and close) - rileyLinkBLE = null; - } + rileyLinkBLE.disconnect(); // dispose of Gatt (disconnect and close) if (mBroadcastReceiver != null) { - mBroadcastReceiver.unregisterBroadcasts(); + mBroadcastReceiver.unregisterBroadcasts(this); } if (bluetoothStateReceiver != null) { @@ -126,32 +127,30 @@ public abstract class RileyLinkService extends DaggerService { public abstract RileyLinkCommunicationManager getDeviceCommunicationManager(); - // Here is where the wake-lock begins: // We've received a service startCommand, we grab the lock. @Override public int onStartCommand(Intent intent, int flags, int startId) { - RileyLinkUtil.setContext(getApplicationContext()); return (START_STICKY); } public boolean bluetoothInit() { aapsLogger.debug(LTag.PUMPCOMM, "bluetoothInit: attempting to get an adapter"); - RileyLinkUtil.setServiceState(RileyLinkServiceState.BluetoothInitializing); + rileyLinkServiceData.setRileyLinkServiceState(RileyLinkServiceState.BluetoothInitializing); bluetoothAdapter = BluetoothAdapter.getDefaultAdapter(); if (bluetoothAdapter == null) { aapsLogger.error("Unable to obtain a BluetoothAdapter."); - RileyLinkUtil.setServiceState(RileyLinkServiceState.BluetoothError, RileyLinkError.NoBluetoothAdapter); + rileyLinkServiceData.setServiceState(RileyLinkServiceState.BluetoothError, RileyLinkError.NoBluetoothAdapter); } else { if (!bluetoothAdapter.isEnabled()) { aapsLogger.error("Bluetooth is not enabled."); - RileyLinkUtil.setServiceState(RileyLinkServiceState.BluetoothError, RileyLinkError.BluetoothDisabled); + rileyLinkServiceData.setServiceState(RileyLinkServiceState.BluetoothError, RileyLinkError.BluetoothDisabled); } else { - RileyLinkUtil.setServiceState(RileyLinkServiceState.BluetoothReady); + rileyLinkServiceData.setRileyLinkServiceState(RileyLinkServiceState.BluetoothReady); return true; } } @@ -163,12 +162,7 @@ public abstract class RileyLinkService extends DaggerService { // returns true if our Rileylink configuration changed public boolean reconfigureRileyLink(String deviceAddress) { - if (rileyLinkBLE == null) { - RileyLinkUtil.setServiceState(RileyLinkServiceState.BluetoothInitializing); - return false; - } - - RileyLinkUtil.setServiceState(RileyLinkServiceState.RileyLinkInitializing); + rileyLinkServiceData.setRileyLinkServiceState(RileyLinkServiceState.RileyLinkInitializing); if (rileyLinkBLE.isConnected()) { if (deviceAddress.equals(rileyLinkServiceData.rileylinkAddress)) { @@ -189,10 +183,10 @@ public abstract class RileyLinkService extends DaggerService { } else { aapsLogger.debug(LTag.PUMPCOMM, "Using RL " + deviceAddress); - if (RileyLinkUtil.getServiceState() == RileyLinkServiceState.NotStarted) { + if (rileyLinkServiceData.getRileyLinkServiceState() == RileyLinkServiceState.NotStarted) { if (!bluetoothInit()) { aapsLogger.error("RileyLink can't get activated, Bluetooth is not functioning correctly. {}", - RileyLinkUtil.getError() != null ? RileyLinkUtil.getError().name() : "Unknown error (null)"); + getError() != null ? getError().name() : "Unknown error (null)"); return false; } } @@ -211,8 +205,8 @@ public abstract class RileyLinkService extends DaggerService { // FIXME: This needs to be run in a session so that is interruptable, has a separate thread, etc. public void doTuneUpDevice() { - RileyLinkUtil.setServiceState(RileyLinkServiceState.TuneUpDevice); - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + rileyLinkServiceData.setRileyLinkServiceState(RileyLinkServiceState.TuneUpDevice); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); double lastGoodFrequency = 0.0d; @@ -236,25 +230,27 @@ public abstract class RileyLinkService extends DaggerService { if (newFrequency == 0.0d) { // error tuning pump, pump not present ?? - RileyLinkUtil - .setServiceState(RileyLinkServiceState.PumpConnectorError, RileyLinkError.TuneUpOfDeviceFailed); + rileyLinkServiceData.setServiceState(RileyLinkServiceState.PumpConnectorError, RileyLinkError.TuneUpOfDeviceFailed); } else { - getRileyLinkCommunicationManager().clearNotConnectedCount(); - RileyLinkUtil.setServiceState(RileyLinkServiceState.PumpConnectorReady); + getDeviceCommunicationManager().clearNotConnectedCount(); + rileyLinkServiceData.setRileyLinkServiceState(RileyLinkServiceState.PumpConnectorReady); } } public void disconnectRileyLink() { - if (this.rileyLinkBLE != null && this.rileyLinkBLE.isConnected()) { - this.rileyLinkBLE.disconnect(); + if (rileyLinkBLE.isConnected()) { + rileyLinkBLE.disconnect(); rileyLinkServiceData.rileylinkAddress = null; } - RileyLinkUtil.setServiceState(RileyLinkServiceState.BluetoothReady); + rileyLinkServiceData.setRileyLinkServiceState(RileyLinkServiceState.BluetoothReady); } + @NotNull public RileyLinkBLE getRileyLinkBLE() { + return rileyLinkBLE; + } /** * Get Target Device for Service @@ -269,4 +265,11 @@ public abstract class RileyLinkService extends DaggerService { rfspy.setRileyLinkEncoding(encodingType); } } + + public RileyLinkError getError() { + if (rileyLinkServiceData != null) + return rileyLinkServiceData.rileyLinkError; + else + return null; + } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkServiceData.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkServiceData.java index dd66255da4..b16c4971b9 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkServiceData.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/RileyLinkServiceData.java @@ -1,21 +1,39 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service; +import javax.inject.Inject; +import javax.inject.Singleton; + +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; +import info.nightscout.androidaps.plugins.bus.RxBusWrapper; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkFirmwareVersion; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkTargetFrequency; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.data.RLHistoryItem; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkError; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice; +import info.nightscout.androidaps.plugins.pump.medtronic.events.EventMedtronicDeviceStatusChange; /** * Created by andy on 16/05/2018. */ +@Singleton public class RileyLinkServiceData { - public boolean tuneUpDone = false; - public RileyLinkError errorCode; - public RileyLinkServiceState serviceState = RileyLinkServiceState.NotStarted; + @Inject AAPSLogger aapsLogger; + @Inject RileyLinkUtil rileyLinkUtil; + @Inject RxBusWrapper rxBus; + + boolean tuneUpDone = false; + public RileyLinkError rileyLinkError; + public RileyLinkServiceState rileyLinkServiceState = RileyLinkServiceState.NotStarted; + public RileyLinkFirmwareVersion firmwareVersion; + public RileyLinkTargetFrequency rileyLinkTargetFrequency; + public String rileylinkAddress; - public long lastTuneUpTime = 0L; + long lastTuneUpTime = 0L; public Double lastGoodFrequency; // bt version @@ -29,15 +47,45 @@ public class RileyLinkServiceData { public String pumpID; public byte[] pumpIDBytes; - - public RileyLinkServiceData(RileyLinkTargetDevice targetDevice) { - this.targetDevice = targetDevice; - } - + @Inject + public RileyLinkServiceData() {} public void setPumpID(String pumpId, byte[] pumpIdBytes) { this.pumpID = pumpId; this.pumpIDBytes = pumpIdBytes; } + public void setRileyLinkServiceState(RileyLinkServiceState newState) { + setServiceState(newState, null); + } + + public RileyLinkServiceState getRileyLinkServiceState() { + return workWithServiceState(null, null, false); + } + + + public void setServiceState(RileyLinkServiceState newState, RileyLinkError errorCode) { + workWithServiceState(newState, errorCode, true); + } + + + private synchronized RileyLinkServiceState workWithServiceState(RileyLinkServiceState newState, RileyLinkError errorCode, boolean set) { + + if (set) { + + rileyLinkServiceState = newState; + this.rileyLinkError = errorCode; + + aapsLogger.info(LTag.PUMP, "RileyLink State Changed: {} {}", newState, errorCode == null ? "" : " - Error State: " + errorCode.name()); + + rileyLinkUtil.getRileyLinkHistory().add(new RLHistoryItem(rileyLinkServiceState, errorCode, targetDevice)); + rxBus.send(new EventMedtronicDeviceStatusChange(newState, errorCode)); + return null; + + } else { + return rileyLinkServiceState; + } + + } + } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/DiscoverGattServicesTask.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/DiscoverGattServicesTask.java index 5f807c3e89..383eb57cb6 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/DiscoverGattServicesTask.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/DiscoverGattServicesTask.java @@ -1,20 +1,28 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; +import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; /** * Created by geoff on 7/9/16. */ public class DiscoverGattServicesTask extends ServiceTask { + @Inject MedtronicPumpPlugin medtronicPumpPlugin; + public boolean needToConnect = false; - public DiscoverGattServicesTask() { + public DiscoverGattServicesTask(HasAndroidInjector injector) { + super(injector); } - public DiscoverGattServicesTask(boolean needToConnect) { + public DiscoverGattServicesTask(HasAndroidInjector injector, boolean needToConnect) { + super(injector); this.needToConnect = needToConnect; } @@ -23,8 +31,8 @@ public class DiscoverGattServicesTask extends ServiceTask { public void run() { if (needToConnect) - RileyLinkUtil.getRileyLinkBLE().connectGatt(); + medtronicPumpPlugin.getRileyLinkService().getRileyLinkBLE().connectGatt(); - RileyLinkUtil.getRileyLinkBLE().discoverServices(); + medtronicPumpPlugin.getRileyLinkService().getRileyLinkBLE().discoverServices(); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/InitializePumpManagerTask.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/InitializePumpManagerTask.java index 1697e0640d..d97399e6a1 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/InitializePumpManagerTask.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/InitializePumpManagerTask.java @@ -1,20 +1,22 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks; -import android.util.Log; +import android.content.Context; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; +import javax.inject.Inject; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.interfaces.ActivePluginProvider; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; +import info.nightscout.androidaps.plugins.pump.common.PumpPluginAbstract; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkCommunicationManager; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkError; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceTransport; -import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicConst; -import info.nightscout.androidaps.utils.SP; +import info.nightscout.androidaps.utils.sharedPreferences.SP; /** * Created by geoff on 7/9/16. @@ -23,62 +25,66 @@ import info.nightscout.androidaps.utils.SP; */ public class InitializePumpManagerTask extends ServiceTask { - private static final String TAG = "InitPumpManagerTask"; - private RileyLinkTargetDevice targetDevice; - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + @Inject AAPSLogger aapsLogger; + @Inject ActivePluginProvider activePlugin; + @Inject SP sp; + @Inject RileyLinkServiceData rileyLinkServiceData; + @Inject RileyLinkUtil rileyLinkUtil; - public InitializePumpManagerTask(RileyLinkTargetDevice targetDevice) { - super(); - this.targetDevice = targetDevice; + private final Context context; + + public InitializePumpManagerTask(HasAndroidInjector injector, Context context) { + super(injector); + this.context = context; } - - public InitializePumpManagerTask(ServiceTransport transport) { - super(transport); + public InitializePumpManagerTask(HasAndroidInjector injector, Context context, ServiceTransport transport) { + super(injector, transport); + this.context = context; } - @Override public void run() { - double lastGoodFrequency = 0.0d; + double lastGoodFrequency; - if (RileyLinkUtil.getRileyLinkServiceData().lastGoodFrequency==null) { + if (rileyLinkServiceData.lastGoodFrequency == null) { - lastGoodFrequency = SP.getDouble(RileyLinkConst.Prefs.LastGoodDeviceFrequency, 0.0d); + lastGoodFrequency = sp.getDouble(RileyLinkConst.Prefs.LastGoodDeviceFrequency, 0.0d); lastGoodFrequency = Math.round(lastGoodFrequency * 1000d) / 1000d; - RileyLinkUtil.getRileyLinkServiceData().lastGoodFrequency = lastGoodFrequency; + rileyLinkServiceData.lastGoodFrequency = lastGoodFrequency; // if (RileyLinkUtil.getRileyLinkTargetFrequency() == null) { // String pumpFrequency = SP.getString(MedtronicConst.Prefs.PumpFrequency, null); // } } else { - lastGoodFrequency = RileyLinkUtil.getRileyLinkServiceData().lastGoodFrequency; + lastGoodFrequency = rileyLinkServiceData.lastGoodFrequency; } + RileyLinkCommunicationManager rileyLinkCommunicationManager = ((PumpPluginAbstract) activePlugin.getActivePump()).getRileyLinkService().getDeviceCommunicationManager(); + if ((lastGoodFrequency > 0.0d) - && RileyLinkUtil.getRileyLinkCommunicationManager().isValidFrequency(lastGoodFrequency)) { + && rileyLinkCommunicationManager.isValidFrequency(lastGoodFrequency)) { - RileyLinkUtil.setServiceState(RileyLinkServiceState.RileyLinkReady); + rileyLinkServiceData.setRileyLinkServiceState(RileyLinkServiceState.RileyLinkReady); - if (L.isEnabled(L.PUMPCOMM)) - LOG.info("Setting radio frequency to {} MHz", lastGoodFrequency); + aapsLogger.info(LTag.PUMPCOMM, "Setting radio frequency to {} MHz", lastGoodFrequency); - RileyLinkUtil.getRileyLinkCommunicationManager().setRadioFrequencyForPump(lastGoodFrequency); + rileyLinkCommunicationManager.setRadioFrequencyForPump(lastGoodFrequency); - boolean foundThePump = RileyLinkUtil.getRileyLinkCommunicationManager().tryToConnectToDevice(); + boolean foundThePump = rileyLinkCommunicationManager.tryToConnectToDevice(); if (foundThePump) { - RileyLinkUtil.setServiceState(RileyLinkServiceState.PumpConnectorReady); + rileyLinkServiceData.setRileyLinkServiceState(RileyLinkServiceState.PumpConnectorReady); } else { - RileyLinkUtil.setServiceState(RileyLinkServiceState.PumpConnectorError, - RileyLinkError.NoContactWithDevice); - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.IPC.MSG_PUMP_tunePump); + rileyLinkServiceData.setServiceState(RileyLinkServiceState.PumpConnectorError, + RileyLinkError.NoContactWithDevice); + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.IPC.MSG_PUMP_tunePump, context); } } else { - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.IPC.MSG_PUMP_tunePump); + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.IPC.MSG_PUMP_tunePump, context); } } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/PumpTask.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/PumpTask.java index c307a43590..66aeb7ae07 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/PumpTask.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/PumpTask.java @@ -1,5 +1,6 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks; +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceTransport; /** @@ -7,12 +8,12 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data. */ public class PumpTask extends ServiceTask { - public PumpTask() { - super(); + public PumpTask(HasAndroidInjector injector) { + super(injector); } - public PumpTask(ServiceTransport transport) { - super(transport); + public PumpTask(HasAndroidInjector injector, ServiceTransport transport) { + super(injector, transport); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ResetRileyLinkConfigurationTask.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ResetRileyLinkConfigurationTask.java index cc17f81b45..fb738a241c 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ResetRileyLinkConfigurationTask.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ResetRileyLinkConfigurationTask.java @@ -1,6 +1,13 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.interfaces.ActivePluginProvider; +import info.nightscout.androidaps.interfaces.PumpInterface; import info.nightscout.androidaps.plugins.bus.RxBus; +import info.nightscout.androidaps.plugins.bus.RxBusWrapper; +import info.nightscout.androidaps.plugins.pump.common.PumpPluginAbstract; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceTransport; import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.events.EventRefreshButtonState; @@ -11,25 +18,30 @@ import info.nightscout.androidaps.plugins.pump.medtronic.service.RileyLinkMedtro */ public class ResetRileyLinkConfigurationTask extends PumpTask { + @Inject ActivePluginProvider activePlugin; + @Inject RxBusWrapper rxBus; + private static final String TAG = "ResetRileyLinkTask"; - public ResetRileyLinkConfigurationTask() { + public ResetRileyLinkConfigurationTask(HasAndroidInjector injector) { + super(injector); } - public ResetRileyLinkConfigurationTask(ServiceTransport transport) { - super(transport); + public ResetRileyLinkConfigurationTask(HasAndroidInjector injector, ServiceTransport transport) { + super(injector, transport); } @Override public void run() { - RxBus.Companion.getINSTANCE().send(new EventRefreshButtonState(false)); + PumpPluginAbstract pump = (PumpPluginAbstract) activePlugin.getActivePump(); + rxBus.send(new EventRefreshButtonState(false)); MedtronicPumpPlugin.isBusy = true; - RileyLinkMedtronicService.getInstance().resetRileyLinkConfiguration(); + pump.resetRileyLinkConfiguration(); MedtronicPumpPlugin.isBusy = false; - RxBus.Companion.getINSTANCE().send(new EventRefreshButtonState(true)); + rxBus.send(new EventRefreshButtonState(true)); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ServiceTask.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ServiceTask.java index e287b63e17..7fff8e225a 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ServiceTask.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ServiceTask.java @@ -1,5 +1,6 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks; +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceTransport; /** @@ -7,17 +8,21 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data. */ public class ServiceTask implements Runnable { - private static final String TAG = "ServiceTask(base)"; public boolean completed = false; protected ServiceTransport mTransport; + protected HasAndroidInjector injector; - public ServiceTask() { + public ServiceTask(HasAndroidInjector injector) { + this.injector = injector; + injector.androidInjector().inject(this); init(new ServiceTransport()); } - public ServiceTask(ServiceTransport transport) { + public ServiceTask(HasAndroidInjector injector, ServiceTransport transport) { + this.injector = injector; + injector.androidInjector().inject(this); init(transport); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ServiceTaskExecutor.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ServiceTaskExecutor.java index 1c6f33b071..5f430be89f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ServiceTaskExecutor.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/ServiceTaskExecutor.java @@ -4,46 +4,40 @@ import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; -import android.util.Log; +import javax.inject.Inject; +import javax.inject.Singleton; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; /** * Created by geoff on 7/9/16. */ +@Singleton public class ServiceTaskExecutor extends ThreadPoolExecutor { - private static final String TAG = "ServiceTaskExecutor"; - private static ServiceTaskExecutor instance; + @Inject RileyLinkUtil rileyLinkUtil; + @Inject AAPSLogger aapsLogger; + private static LinkedBlockingQueue taskQueue = new LinkedBlockingQueue<>(); - static { - instance = new ServiceTaskExecutor(); - } - - - private ServiceTaskExecutor() { + @Inject + public ServiceTaskExecutor() { super(1, 1, 10000, TimeUnit.MILLISECONDS, taskQueue); } - - public static ServiceTaskExecutor getInstance() { - return instance; - } - - - public static ServiceTask startTask(ServiceTask task) { - instance.execute(task); // task will be run on async thread from pool. + public ServiceTask startTask(ServiceTask task) { + execute(task); // task will be run on async thread from pool. return task; } - // FIXME protected void beforeExecute(Thread t, Runnable r) { // This is run on either caller UI thread or Service UI thread. - ServiceTask task = (ServiceTask)r; - Log.v(TAG, "About to run task " + task.getClass().getSimpleName()); - RileyLinkUtil.setCurrentTask(task); + ServiceTask task = (ServiceTask) r; + aapsLogger.debug(LTag.PUMPBTCOMM, "About to run task " + task.getClass().getSimpleName()); + rileyLinkUtil.setCurrentTask(task); task.preOp(); } @@ -51,9 +45,9 @@ public class ServiceTaskExecutor extends ThreadPoolExecutor { // FIXME protected void afterExecute(Runnable r, Throwable t) { // This is run on either caller UI thread or Service UI thread. - ServiceTask task = (ServiceTask)r; + ServiceTask task = (ServiceTask) r; task.postOp(); - Log.v(TAG, "Finishing task " + task.getClass().getSimpleName()); - RileyLinkUtil.finishCurrentTask(task); + aapsLogger.debug(LTag.PUMPBTCOMM, "Finishing task " + task.getClass().getSimpleName()); + rileyLinkUtil.finishCurrentTask(task); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/WakeAndTuneTask.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/WakeAndTuneTask.java index 1035d7d2d8..d7eed28ef4 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/WakeAndTuneTask.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/hw/rileylink/service/tasks/WakeAndTuneTask.java @@ -1,34 +1,43 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks; -import info.nightscout.androidaps.plugins.bus.RxBus; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.interfaces.ActivePluginProvider; +import info.nightscout.androidaps.plugins.bus.RxBusWrapper; +import info.nightscout.androidaps.plugins.pump.common.PumpPluginAbstract; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.data.ServiceTransport; import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.events.EventRefreshButtonState; -import info.nightscout.androidaps.plugins.pump.medtronic.service.RileyLinkMedtronicService; /** * Created by geoff on 7/16/16. */ public class WakeAndTuneTask extends PumpTask { + @Inject ActivePluginProvider activePlugin; + @Inject RxBusWrapper rxBus; + private static final String TAG = "WakeAndTuneTask"; - public WakeAndTuneTask() { + public WakeAndTuneTask(HasAndroidInjector injector) { + super(injector); } - public WakeAndTuneTask(ServiceTransport transport) { - super(transport); + public WakeAndTuneTask(HasAndroidInjector injector, ServiceTransport transport) { + super(injector, transport); } @Override public void run() { - RxBus.Companion.getINSTANCE().send(new EventRefreshButtonState(false)); + PumpPluginAbstract pump = (PumpPluginAbstract) activePlugin.getActivePump(); + rxBus.send(new EventRefreshButtonState(false)); MedtronicPumpPlugin.isBusy = true; - RileyLinkMedtronicService.getInstance().doTuneUpDevice(); + pump.doTuneUpDevice(); MedtronicPumpPlugin.isBusy = false; - RxBus.Companion.getINSTANCE().send(new EventRefreshButtonState(true)); + rxBus.send(new EventRefreshButtonState(true)); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/ui/RileyLinkSelectPreference.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/ui/RileyLinkSelectPreference.java deleted file mode 100644 index 360f6e4798..0000000000 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/ui/RileyLinkSelectPreference.java +++ /dev/null @@ -1,40 +0,0 @@ -package info.nightscout.androidaps.plugins.pump.common.ui; - -import android.content.Context; -import androidx.preference.Preference; -import android.util.AttributeSet; - -import info.nightscout.androidaps.MainApp; -import info.nightscout.androidaps.R; -import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; -import info.nightscout.androidaps.utils.SP; - -/** - * Created by andy on 10/18/18. - */ - -public class RileyLinkSelectPreference extends Preference { - - public RileyLinkSelectPreference(Context context) { - super(context); - setInitialSummaryValue(); - - MedtronicUtil.setRileyLinkSelectPreference(this); - } - - - public RileyLinkSelectPreference(Context context, AttributeSet attrs) { - super(context, attrs); - setInitialSummaryValue(); - - MedtronicUtil.setRileyLinkSelectPreference(this); - } - - - private void setInitialSummaryValue() { - String value = SP.getString("pref_rileylink_mac_address", null); - - setSummary(value == null ? MainApp.gs(R.string.rileylink_error_address_not_set_short) : value); - } - -} diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/utils/DateTimeUtil.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/utils/DateTimeUtil.java index 7db9fcfb5a..20c19c644c 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/utils/DateTimeUtil.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/utils/DateTimeUtil.java @@ -20,14 +20,13 @@ import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; */ public class DateTimeUtil { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); - /** * DateTime is packed as long: yyyymmddHHMMss * * @param atechDateTime * @return */ + @Deprecated // use joda instead public static LocalDateTime toLocalDateTime(long atechDateTime) { int year = (int) (atechDateTime / 10000000000L); atechDateTime -= year * 10000000000L; @@ -49,8 +48,7 @@ public class DateTimeUtil { try { return new LocalDateTime(year, month, dayOfMonth, hourOfDay, minute, second); } catch (Exception ex) { - if (L.isEnabled(L.PUMPCOMM)) - LOG.error("Error creating LocalDateTime from values [atechDateTime={}, year={}, month={}, day={}, hour={}, minute={}, second={}]. Exception: {}", atechDateTime, year, month, dayOfMonth, hourOfDay, minute, second, ex.getMessage()); + //LOG.error("Error creating LocalDateTime from values [atechDateTime={}, year={}, month={}, day={}, hour={}, minute={}, second={}]. Exception: {}", atechDateTime, year, month, dayOfMonth, hourOfDay, minute, second, ex.getMessage()); //return null; throw ex; } @@ -63,6 +61,7 @@ public class DateTimeUtil { * @param atechDateTime * @return */ + @Deprecated // use joda instead public static GregorianCalendar toGregorianCalendar(long atechDateTime) { int year = (int) (atechDateTime / 10000000000L); atechDateTime -= year * 10000000000L; @@ -84,8 +83,7 @@ public class DateTimeUtil { try { return new GregorianCalendar(year, month - 1, dayOfMonth, hourOfDay, minute, second); } catch (Exception ex) { - if (L.isEnabled(L.PUMPCOMM)) - LOG.error("DateTimeUtil", String.format("Error creating GregorianCalendar from values [atechDateTime=%d, year=%d, month=%d, day=%d, hour=%d, minute=%d, second=%d]", atechDateTime, year, month, dayOfMonth, hourOfDay, minute, second)); + //LOG.error("DateTimeUtil", String.format("Error creating GregorianCalendar from values [atechDateTime=%d, year=%d, month=%d, day=%d, hour=%d, minute=%d, second=%d]", atechDateTime, year, month, dayOfMonth, hourOfDay, minute, second)); //return null; throw ex; } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/utils/LocationHelper.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/utils/LocationHelper.java index 21f496fcdc..03b42b730f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/utils/LocationHelper.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/common/utils/LocationHelper.java @@ -5,7 +5,6 @@ import android.content.Context; import android.content.Intent; import android.location.LocationManager; -import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.R; import info.nightscout.androidaps.utils.alertDialogs.OKDialog; @@ -44,7 +43,7 @@ public class LocationHelper { } // Shamelessly borrowed from http://stackoverflow.com/a/10311877/868533 - OKDialog.showConfirmation(parent, MainApp.gs(R.string.location_not_found_title), MainApp.gs(R.string.location_not_found_message), () -> { + OKDialog.showConfirmation(parent, parent.getString(R.string.location_not_found_title), parent.getString(R.string.location_not_found_message), () -> { parent.startActivity(new Intent(android.provider.Settings.ACTION_LOCATION_SOURCE_SETTINGS)); }); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicFragment.kt b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicFragment.kt index 7237dab948..da9a2321f6 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicFragment.kt +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicFragment.kt @@ -19,10 +19,10 @@ import info.nightscout.androidaps.logging.AAPSLogger import info.nightscout.androidaps.logging.LTag import info.nightscout.androidaps.plugins.bus.RxBusWrapper import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkError import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.dialog.RileyLinkStatusActivity +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData import info.nightscout.androidaps.plugins.pump.medtronic.defs.BatteryType import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicCommandType import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState @@ -37,9 +37,9 @@ import info.nightscout.androidaps.queue.Callback import info.nightscout.androidaps.queue.events.EventQueueChanged import info.nightscout.androidaps.utils.DateUtil import info.nightscout.androidaps.utils.FabricPrivacy -import info.nightscout.androidaps.utils.alertDialogs.OKDialog import info.nightscout.androidaps.utils.T import info.nightscout.androidaps.utils.WarnColors +import info.nightscout.androidaps.utils.alertDialogs.OKDialog import info.nightscout.androidaps.utils.extensions.plusAssign import info.nightscout.androidaps.utils.resources.ResourceHelper import io.reactivex.android.schedulers.AndroidSchedulers @@ -57,6 +57,10 @@ class MedtronicFragment : DaggerFragment() { @Inject lateinit var activePlugin: ActivePluginProvider @Inject lateinit var medtronicPumpPlugin: MedtronicPumpPlugin @Inject lateinit var warnColors: WarnColors + @Inject lateinit var rileyLinkUtil: RileyLinkUtil + @Inject lateinit var medtronicUtil: MedtronicUtil + @Inject lateinit var medtronicPumpStatus: MedtronicPumpStatus + @Inject lateinit var rileyLinkServiceData: RileyLinkServiceData private var disposable: CompositeDisposable = CompositeDisposable() @@ -85,7 +89,7 @@ class MedtronicFragment : DaggerFragment() { medtronic_pump_status.text = "{fa-bed}" medtronic_history.setOnClickListener { - if (MedtronicUtil.getPumpStatus().verifyConfiguration()) { + if (medtronicPumpPlugin.rileyLinkService?.verifyConfiguration() == true) { startActivity(Intent(context, MedtronicHistoryActivity::class.java)) } else { displayNotConfiguredDialog() @@ -93,7 +97,7 @@ class MedtronicFragment : DaggerFragment() { } medtronic_refresh.setOnClickListener { - if (!MedtronicUtil.getPumpStatus().verifyConfiguration()) { + if (medtronicPumpPlugin.rileyLinkService?.verifyConfiguration() != true) { displayNotConfiguredDialog() } else { medtronic_refresh.isEnabled = false @@ -107,7 +111,7 @@ class MedtronicFragment : DaggerFragment() { } medtronic_stats.setOnClickListener { - if (MedtronicUtil.getPumpStatus().verifyConfiguration()) { + if (medtronicPumpPlugin.rileyLinkService?.verifyConfiguration() == true) { startActivity(Intent(context, RileyLinkStatusActivity::class.java)) } else { displayNotConfiguredDialog() @@ -147,7 +151,7 @@ class MedtronicFragment : DaggerFragment() { .observeOn(AndroidSchedulers.mainThread()) .subscribe({ aapsLogger.debug(LTag.PUMP, "EventMedtronicPumpConfigurationChanged triggered") - MedtronicUtil.getPumpStatus().verifyConfiguration() + medtronicPumpPlugin.rileyLinkService?.verifyConfiguration() updateGUI() }, { fabricPrivacy.logException(it) }) disposable += rxBus @@ -171,33 +175,24 @@ class MedtronicFragment : DaggerFragment() { @Synchronized private fun setDeviceStatus() { - val pumpStatus: MedtronicPumpStatus = MedtronicUtil.getPumpStatus() - pumpStatus.rileyLinkServiceState = checkStatusSet(pumpStatus.rileyLinkServiceState, - RileyLinkUtil.getServiceState()) as RileyLinkServiceState? - - val resourceId = pumpStatus.rileyLinkServiceState.getResourceId(RileyLinkTargetDevice.MedtronicPump) - val rileyLinkError = RileyLinkUtil.getError() + val resourceId = rileyLinkServiceData.rileyLinkServiceState.getResourceId(RileyLinkTargetDevice.MedtronicPump) + val rileyLinkError = medtronicPumpPlugin.rileyLinkService?.error medtronic_rl_status.text = when { - pumpStatus.rileyLinkServiceState == RileyLinkServiceState.NotStarted -> resourceHelper.gs(resourceId) - pumpStatus.rileyLinkServiceState.isConnecting -> "{fa-bluetooth-b spin} " + resourceHelper.gs(resourceId) - pumpStatus.rileyLinkServiceState.isError && rileyLinkError == null -> "{fa-bluetooth-b} " + resourceHelper.gs(resourceId) - pumpStatus.rileyLinkServiceState.isError && rileyLinkError != null -> "{fa-bluetooth-b} " + resourceHelper.gs(rileyLinkError.getResourceId(RileyLinkTargetDevice.MedtronicPump)) - else -> "{fa-bluetooth-b} " + resourceHelper.gs(resourceId) + rileyLinkServiceData.rileyLinkServiceState == RileyLinkServiceState.NotStarted -> resourceHelper.gs(resourceId) + rileyLinkServiceData.rileyLinkServiceState.isConnecting -> "{fa-bluetooth-b spin} " + resourceHelper.gs(resourceId) + rileyLinkServiceData.rileyLinkServiceState.isError && rileyLinkError == null -> "{fa-bluetooth-b} " + resourceHelper.gs(resourceId) + rileyLinkServiceData.rileyLinkServiceState.isError && rileyLinkError != null -> "{fa-bluetooth-b} " + resourceHelper.gs(rileyLinkError.getResourceId(RileyLinkTargetDevice.MedtronicPump)) + else -> "{fa-bluetooth-b} " + resourceHelper.gs(resourceId) } medtronic_rl_status.setTextColor(if (rileyLinkError != null) Color.RED else Color.WHITE) - pumpStatus.rileyLinkError = checkStatusSet(pumpStatus.rileyLinkError, RileyLinkUtil.getError()) as RileyLinkError? - medtronic_errors.text = - pumpStatus.rileyLinkError?.let { + rileyLinkServiceData.rileyLinkError?.let { resourceHelper.gs(it.getResourceId(RileyLinkTargetDevice.MedtronicPump)) } ?: "-" - pumpStatus.pumpDeviceState = checkStatusSet(pumpStatus.pumpDeviceState, - MedtronicUtil.getPumpDeviceState()) as PumpDeviceState? - - when (pumpStatus.pumpDeviceState) { + when (medtronicPumpStatus.pumpDeviceState) { null, PumpDeviceState.Sleeping -> medtronic_pump_status.text = "{fa-bed} " // + pumpStatus.pumpDeviceState.name()); PumpDeviceState.NeverContacted, @@ -205,20 +200,20 @@ class MedtronicFragment : DaggerFragment() { PumpDeviceState.PumpUnreachable, PumpDeviceState.ErrorWhenCommunicating, PumpDeviceState.TimeoutWhenCommunicating, - PumpDeviceState.InvalidConfiguration -> medtronic_pump_status.text = " " + resourceHelper.gs(pumpStatus.pumpDeviceState.resourceId) + PumpDeviceState.InvalidConfiguration -> medtronic_pump_status.text = " " + resourceHelper.gs(medtronicPumpStatus.pumpDeviceState.resourceId) PumpDeviceState.Active -> { - val cmd = MedtronicUtil.getCurrentCommand() + val cmd = medtronicUtil.getCurrentCommand() if (cmd == null) - medtronic_pump_status.text = " " + resourceHelper.gs(pumpStatus.pumpDeviceState.resourceId) + medtronic_pump_status.text = " " + resourceHelper.gs(medtronicPumpStatus.pumpDeviceState.resourceId) else { aapsLogger.debug(LTag.PUMP, "Command: " + cmd) val cmdResourceId = cmd.resourceId if (cmd == MedtronicCommandType.GetHistoryData) { - medtronic_pump_status.text = MedtronicUtil.frameNumber?.let { - resourceHelper.gs(cmdResourceId, MedtronicUtil.pageNumber, MedtronicUtil.frameNumber) + medtronic_pump_status.text = medtronicUtil.frameNumber?.let { + resourceHelper.gs(cmdResourceId, medtronicUtil.pageNumber, medtronicUtil.frameNumber) } - ?: resourceHelper.gs(R.string.medtronic_cmd_desc_get_history_request, MedtronicUtil.pageNumber) + ?: resourceHelper.gs(R.string.medtronic_cmd_desc_get_history_request, medtronicUtil.pageNumber) } else { medtronic_pump_status.text = " " + (cmdResourceId?.let { resourceHelper.gs(it) } ?: cmd.getCommandDescription()) @@ -226,7 +221,7 @@ class MedtronicFragment : DaggerFragment() { } } - else -> aapsLogger.warn(LTag.PUMP, "Unknown pump state: " + pumpStatus.pumpDeviceState) + else -> aapsLogger.warn(LTag.PUMP, "Unknown pump state: " + medtronicPumpStatus.pumpDeviceState) } val status = commandQueue.spannedStatus() @@ -238,17 +233,6 @@ class MedtronicFragment : DaggerFragment() { } } - private fun checkStatusSet(object1: Any?, object2: Any?): Any? { - return if (object1 == null) { - object2 - } else { - if (object1 != object2) { - object2 - } else - object1 - } - } - private fun displayNotConfiguredDialog() { context?.let { OKDialog.show(it, resourceHelper.gs(R.string.combo_warning), @@ -260,18 +244,17 @@ class MedtronicFragment : DaggerFragment() { @Synchronized fun updateGUI() { if (medtronic_rl_status == null) return - val pumpStatus = MedtronicUtil.getPumpStatus() setDeviceStatus() // last connection - if (pumpStatus.lastConnection != 0L) { - val minAgo = DateUtil.minAgo(resourceHelper, pumpStatus.lastConnection) - val min = (System.currentTimeMillis() - pumpStatus.lastConnection) / 1000 / 60 - if (pumpStatus.lastConnection + 60 * 1000 > System.currentTimeMillis()) { + if (medtronicPumpStatus.lastConnection != 0L) { + val minAgo = DateUtil.minAgo(resourceHelper, medtronicPumpStatus.lastConnection) + val min = (System.currentTimeMillis() - medtronicPumpStatus.lastConnection) / 1000 / 60 + if (medtronicPumpStatus.lastConnection + 60 * 1000 > System.currentTimeMillis()) { medtronic_lastconnection.setText(R.string.combo_pump_connected_now) medtronic_lastconnection.setTextColor(Color.WHITE) - } else if (pumpStatus.lastConnection + 30 * 60 * 1000 < System.currentTimeMillis()) { + } else if (medtronicPumpStatus.lastConnection + 30 * 60 * 1000 < System.currentTimeMillis()) { if (min < 60) { medtronic_lastconnection.text = resourceHelper.gs(R.string.minago, min) @@ -294,19 +277,19 @@ class MedtronicFragment : DaggerFragment() { } // last bolus - val bolus = pumpStatus.lastBolusAmount - val bolusTime = pumpStatus.lastBolusTime + val bolus = medtronicPumpStatus.lastBolusAmount + val bolusTime = medtronicPumpStatus.lastBolusTime if (bolus != null && bolusTime != null) { - val agoMsc = System.currentTimeMillis() - pumpStatus.lastBolusTime.time + val agoMsc = System.currentTimeMillis() - medtronicPumpStatus.lastBolusTime.time val bolusMinAgo = agoMsc.toDouble() / 60.0 / 1000.0 val unit = resourceHelper.gs(R.string.insulin_unit_shortname) val ago: String if (agoMsc < 60 * 1000) { ago = resourceHelper.gs(R.string.combo_pump_connected_now) } else if (bolusMinAgo < 60) { - ago = DateUtil.minAgo(resourceHelper, pumpStatus.lastBolusTime.time) + ago = DateUtil.minAgo(resourceHelper, medtronicPumpStatus.lastBolusTime.time) } else { - ago = DateUtil.hourAgo(pumpStatus.lastBolusTime.time, resourceHelper) + ago = DateUtil.hourAgo(medtronicPumpStatus.lastBolusTime.time, resourceHelper) } medtronic_lastbolus.text = resourceHelper.gs(R.string.combo_last_bolus, bolus, unit, ago) } else { @@ -314,24 +297,25 @@ class MedtronicFragment : DaggerFragment() { } // base basal rate - medtronic_basabasalrate.text = ("(" + pumpStatus.activeProfileName + ") " + medtronic_basabasalrate.text = ("(" + medtronicPumpStatus.activeProfileName + ") " + resourceHelper.gs(R.string.pump_basebasalrate, medtronicPumpPlugin.baseBasalRate)) medtronic_tempbasal.text = activePlugin.activeTreatments.getTempBasalFromHistory(System.currentTimeMillis())?.toStringFull() ?: "" // battery - if (MedtronicUtil.getBatteryType() == BatteryType.None || pumpStatus.batteryVoltage == null) { - medtronic_pumpstate_battery.text = "{fa-battery-" + pumpStatus.batteryRemaining / 25 + "} " + if (medtronicPumpStatus.batteryType == BatteryType.None || medtronicPumpStatus.batteryVoltage == null) { + medtronic_pumpstate_battery.text = "{fa-battery-" + medtronicPumpStatus.batteryRemaining / 25 + "} " } else { - medtronic_pumpstate_battery.text = "{fa-battery-" + pumpStatus.batteryRemaining / 25 + "} " + pumpStatus.batteryRemaining + "%" + String.format(" (%.2f V)", pumpStatus.batteryVoltage) + medtronic_pumpstate_battery.text = "{fa-battery-" + medtronicPumpStatus.batteryRemaining / 25 + "} " + medtronicPumpStatus.batteryRemaining + "%" + String.format(" (%.2f V)", medtronicPumpStatus.batteryVoltage) } - warnColors.setColorInverse(medtronic_pumpstate_battery, pumpStatus.batteryRemaining.toDouble(), 25.0, 10.0) + warnColors.setColorInverse(medtronic_pumpstate_battery, medtronicPumpStatus.batteryRemaining.toDouble(), 25.0, 10.0) // reservoir - medtronic_reservoir.text = resourceHelper.gs(R.string.reservoirvalue, pumpStatus.reservoirRemainingUnits, pumpStatus.reservoirFullUnits) - warnColors.setColorInverse(medtronic_reservoir, pumpStatus.reservoirRemainingUnits, 50.0, 20.0) + medtronic_reservoir.text = resourceHelper.gs(R.string.reservoirvalue, medtronicPumpStatus.reservoirRemainingUnits, medtronicPumpStatus.reservoirFullUnits) + warnColors.setColorInverse(medtronic_reservoir, medtronicPumpStatus.reservoirRemainingUnits, 50.0, 20.0) - medtronic_errors.text = pumpStatus.errorInfo + medtronicPumpPlugin.rileyLinkService?.verifyConfiguration() + medtronic_errors.text = medtronicPumpStatus.errorInfo } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicPumpPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicPumpPlugin.java index 523a9c5f53..45ed524fdf 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicPumpPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicPumpPlugin.java @@ -8,7 +8,10 @@ import android.os.IBinder; import android.os.SystemClock; import androidx.annotation.NonNull; +import androidx.annotation.Nullable; +import androidx.preference.Preference; +import org.jetbrains.annotations.NotNull; import org.joda.time.LocalDateTime; import java.util.ArrayList; @@ -34,7 +37,6 @@ import info.nightscout.androidaps.data.Profile; import info.nightscout.androidaps.data.PumpEnactResult; import info.nightscout.androidaps.db.Source; import info.nightscout.androidaps.db.TemporaryBasal; -import info.nightscout.androidaps.events.EventCustomActionsChanged; import info.nightscout.androidaps.events.EventRefreshOverview; import info.nightscout.androidaps.interfaces.ActivePluginProvider; import info.nightscout.androidaps.interfaces.CommandQueueProvider; @@ -50,18 +52,19 @@ import info.nightscout.androidaps.plugins.general.actions.defs.CustomActionType; import info.nightscout.androidaps.plugins.general.overview.events.EventNewNotification; import info.nightscout.androidaps.plugins.general.overview.notifications.Notification; import info.nightscout.androidaps.plugins.pump.common.PumpPluginAbstract; +import info.nightscout.androidaps.plugins.pump.common.data.PumpStatus; import info.nightscout.androidaps.plugins.pump.common.defs.PumpDriverState; import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.ResetRileyLinkConfigurationTask; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.ServiceTaskExecutor; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.WakeAndTuneTask; import info.nightscout.androidaps.plugins.pump.common.utils.DateTimeUtil; -import info.nightscout.androidaps.plugins.pump.medtronic.comm.MedtronicCommunicationManager; import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump.PumpHistoryEntry; import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump.PumpHistoryResult; -import info.nightscout.androidaps.plugins.pump.medtronic.comm.ui.MedtronicUIComm; import info.nightscout.androidaps.plugins.pump.medtronic.comm.ui.MedtronicUITask; import info.nightscout.androidaps.plugins.pump.medtronic.data.MedtronicHistoryData; import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.BasalProfile; @@ -85,7 +88,6 @@ import info.nightscout.androidaps.utils.TimeChangeType; import info.nightscout.androidaps.utils.resources.ResourceHelper; import info.nightscout.androidaps.utils.sharedPreferences.SP; -import static info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil.sendNotification; /** * Created by andy on 23.04.18. @@ -95,18 +97,22 @@ import static info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUt @Singleton public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInterface { + private final SP sp; + private final RileyLinkUtil rileyLinkUtil; + private final MedtronicUtil medtronicUtil; + private final MedtronicPumpStatus medtronicPumpStatus; + private final MedtronicHistoryData medtronicHistoryData; + private final RileyLinkServiceData rileyLinkServiceData; + private final ServiceTaskExecutor serviceTaskExecutor; + protected static MedtronicPumpPlugin plugin = null; - private RileyLinkMedtronicService medtronicService; - private MedtronicPumpStatus pumpStatusLocal = null; - private MedtronicUIComm medtronicUIComm; + private RileyLinkMedtronicService rileyLinkMedtronicService; // variables for handling statuses and history private boolean firstRun = true; private boolean isRefresh = false; private Map statusRefreshMap = new HashMap<>(); private boolean isInitialized = false; - private MedtronicHistoryData medtronicHistoryData; - private MedtronicCommunicationManager medtronicCommunicationManager; private PumpHistoryEntry lastPumpHistoryEntry; public static boolean isBusy = false; @@ -124,7 +130,13 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter ActivePluginProvider activePlugin, SP sp, CommandQueueProvider commandQueue, - FabricPrivacy fabricPrivacy + FabricPrivacy fabricPrivacy, + RileyLinkUtil rileyLinkUtil, + MedtronicUtil medtronicUtil, + MedtronicPumpStatus medtronicPumpStatus, + MedtronicHistoryData medtronicHistoryData, + RileyLinkServiceData rileyLinkServiceData, + ServiceTaskExecutor serviceTaskExecutor ) { super(new PluginDescription() // @@ -132,14 +144,20 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter .fragmentClass(MedtronicFragment.class.getName()) // .pluginName(R.string.medtronic_name) // .shortName(R.string.medtronic_name_short) // - .preferencesId(R.xml.pref_medtronic).description(R.string.description_pump_medtronic), // + .preferencesId(R.xml.pref_medtronic) + .description(R.string.description_pump_medtronic), // PumpType.Medtronic_522_722, // we default to most basic model, correct model from config is loaded later injector, resourceHelper, aapsLogger, commandQueue, rxBus, activePlugin, sp, context, fabricPrivacy ); this.plugin = this; - this.rxBus = rxBus; + this.rileyLinkUtil = rileyLinkUtil; + this.medtronicUtil = medtronicUtil; this.sp = sp; + this.medtronicPumpStatus = medtronicPumpStatus; + this.medtronicHistoryData = medtronicHistoryData; + this.rileyLinkServiceData = rileyLinkServiceData; + this.serviceTaskExecutor = serviceTaskExecutor; displayConnectionMessages = false; @@ -147,24 +165,22 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter public void onServiceDisconnected(ComponentName name) { aapsLogger.debug(LTag.PUMP, "RileyLinkMedtronicService is disconnected"); - medtronicService = null; + rileyLinkMedtronicService = null; } public void onServiceConnected(ComponentName name, IBinder service) { aapsLogger.debug(LTag.PUMP, "RileyLinkMedtronicService is connected"); RileyLinkMedtronicService.LocalBinder mLocalBinder = (RileyLinkMedtronicService.LocalBinder) service; - medtronicService = mLocalBinder.getServiceInstance(); + rileyLinkMedtronicService = mLocalBinder.getServiceInstance(); new Thread(() -> { for (int i = 0; i < 20; i++) { SystemClock.sleep(5000); - if (MedtronicUtil.getPumpStatus() != null) { - aapsLogger.debug(LTag.PUMP, "Starting Medtronic-RileyLink service"); - if (MedtronicUtil.getPumpStatus().setNotInPreInit()) { - break; - } + aapsLogger.debug(LTag.PUMP, "Starting Medtronic-RileyLink service"); + if (rileyLinkMedtronicService.setNotInPreInit()) { + break; } } }).start(); @@ -176,8 +192,6 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter @Override protected void onStart() { super.onStart(); - medtronicUIComm = new MedtronicUIComm(aapsLogger, rxBus, getResourceHelper()); - medtronicHistoryData = new MedtronicHistoryData(aapsLogger, sp, activePlugin); } @Deprecated @@ -188,34 +202,33 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter } + @Override + public void updatePreferenceSummary(@NotNull Preference pref) { + super.updatePreferenceSummary(pref); + + if (pref.getKey().equals(getResourceHelper().gs(R.string.key_rileylink_mac_address))) { + String value = sp.getStringOrNull(R.string.key_rileylink_mac_address, null); + pref.setSummary(value == null ? getResourceHelper().gs(R.string.rileylink_error_address_not_set_short) : value); + } + } + private String getLogPrefix() { return "MedtronicPumpPlugin::"; } - - public MedtronicHistoryData getMedtronicHistoryData() { - return this.medtronicHistoryData; - } - - @Override public void initPumpStatusData() { - this.pumpStatusLocal = new MedtronicPumpStatus(pumpDescription); - MedtronicUtil.setPumpStatus(pumpStatusLocal); + medtronicPumpStatus.lastConnection = sp.getLong(RileyLinkConst.Prefs.LastGoodDeviceCommunicationTime, 0L); + medtronicPumpStatus.lastDataTime = medtronicPumpStatus.lastConnection; + medtronicPumpStatus.previousConnection = medtronicPumpStatus.lastConnection; - pumpStatusLocal.lastConnection = sp.getLong(RileyLinkConst.Prefs.LastGoodDeviceCommunicationTime, 0L); - pumpStatusLocal.lastDataTime = new LocalDateTime(pumpStatusLocal.lastConnection); - pumpStatusLocal.previousConnection = pumpStatusLocal.lastConnection; + if (rileyLinkMedtronicService != null) rileyLinkMedtronicService.verifyConfiguration(); - pumpStatusLocal.refreshConfiguration(); - - aapsLogger.debug(LTag.PUMP, "initPumpStatusData: " + this.pumpStatusLocal); - - this.pumpStatus = pumpStatusLocal; + aapsLogger.debug(LTag.PUMP, "initPumpStatusData: " + this.medtronicPumpStatus); // this is only thing that can change, by being configured - pumpDescription.maxTempAbsolute = (pumpStatusLocal.maxBasal != null) ? pumpStatusLocal.maxBasal : 35.0d; + pumpDescription.maxTempAbsolute = (medtronicPumpStatus.maxBasal != null) ? medtronicPumpStatus.maxBasal : 35.0d; // set first Medtronic Pump Start if (!sp.contains(MedtronicConst.Statistics.FirstPumpStart)) { @@ -226,6 +239,15 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter } + @Override + public void resetRileyLinkConfiguration() { + rileyLinkMedtronicService.resetRileyLinkConfiguration(); + } + + @Override public void doTuneUpDevice() { + rileyLinkMedtronicService.doTuneUpDevice(); + } + private void migrateSettings() { if ("US (916 MHz)".equals(sp.getString(MedtronicConst.Prefs.PumpFrequency, "US (916 MHz)"))) { @@ -276,6 +298,9 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter return RileyLinkMedtronicService.class; } + @Override public PumpStatus getPumpStatusData() { + return medtronicPumpStatus; + } @Override public String deviceID() { @@ -298,9 +323,13 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter // Pump Plugin private boolean isServiceSet() { - return medtronicService != null; + return rileyLinkMedtronicService != null; } + @Nullable + public RileyLinkMedtronicService getRileyLinkService() { + return rileyLinkMedtronicService; + } @Override public boolean isInitialized() { @@ -365,7 +394,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter public boolean isConnected() { if (displayConnectionMessages) aapsLogger.debug(LTag.PUMP, "MedtronicPumpPlugin::isConnected"); - return isServiceSet() && medtronicService.isInitialized(); + return isServiceSet() && rileyLinkMedtronicService.isInitialized(); } @@ -373,15 +402,13 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter public boolean isConnecting() { if (displayConnectionMessages) aapsLogger.debug(LTag.PUMP, "MedtronicPumpPlugin::isConnecting"); - return !isServiceSet() || !medtronicService.isInitialized(); + return !isServiceSet() || !rileyLinkMedtronicService.isInitialized(); } @Override public void getPumpStatus() { - getMDTPumpStatus(); - if (firstRun) { initializePump(!isRefresh); } else { @@ -400,7 +427,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter private boolean isPumpNotReachable() { - RileyLinkServiceState rileyLinkServiceState = MedtronicUtil.getServiceState(); + RileyLinkServiceState rileyLinkServiceState = rileyLinkServiceData.rileyLinkServiceState; if (rileyLinkServiceState == null) { aapsLogger.debug(LTag.PUMP, "RileyLink unreachable. RileyLinkServiceState is null."); @@ -414,7 +441,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter return false; } - return (!medtronicCommunicationManager.isDeviceReachable()); + return (!rileyLinkMedtronicService.getDeviceCommunicationManager().isDeviceReachable()); } @@ -431,12 +458,12 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter if (isPumpNotReachable()) { aapsLogger.error("Pump unreachable."); - MedtronicUtil.sendNotification(MedtronicNotificationType.PumpUnreachable, getResourceHelper(), rxBus); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpUnreachable, getResourceHelper(), rxBus); return; } - MedtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); + medtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); if (hasTimeDateOrTimeZoneChanged) { @@ -470,14 +497,14 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter case BatteryStatus: case RemainingInsulin: { - medtronicUIComm.executeCommand(refreshType.getKey().getCommandType()); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(refreshType.getKey().getCommandType(medtronicUtil.getMedtronicPumpModel())); refreshTypesNeededToReschedule.add(refreshType.getKey()); resetTime = true; } break; case Configuration: { - medtronicUIComm.executeCommand(refreshType.getKey().getCommandType()); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(refreshType.getKey().getCommandType(medtronicUtil.getMedtronicPumpModel())); resetTime = true; } break; @@ -492,7 +519,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter } if (resetTime) - pumpStatusLocal.setLastCommunicationToNow(); + medtronicPumpStatus.setLastCommunicationToNow(); } @@ -519,35 +546,30 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter aapsLogger.info(LTag.PUMP, getLogPrefix() + "initializePump - start"); - if (medtronicCommunicationManager == null) { - medtronicCommunicationManager = MedtronicCommunicationManager.getInstance(); - medtronicCommunicationManager.setDoWakeUpBeforeCommand(false); - } + rileyLinkMedtronicService.getDeviceCommunicationManager().setDoWakeUpBeforeCommand(false); setRefreshButtonEnabled(false); - getMDTPumpStatus(); - if (isRefresh) { if (isPumpNotReachable()) { aapsLogger.error(getLogPrefix() + "initializePump::Pump unreachable."); - MedtronicUtil.sendNotification(MedtronicNotificationType.PumpUnreachable, getResourceHelper(), rxBus); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpUnreachable, getResourceHelper(), rxBus); setRefreshButtonEnabled(true); return; } - MedtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); + medtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); } // model (once) - if (MedtronicUtil.getMedtronicPumpModel() == null) { - medtronicUIComm.executeCommand(MedtronicCommandType.PumpModel); + if (medtronicUtil.getMedtronicPumpModel() == null) { + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.PumpModel); } else { - if (pumpStatusLocal.medtronicDeviceType != MedtronicUtil.getMedtronicPumpModel()) { + if (medtronicPumpStatus.medtronicDeviceType != medtronicUtil.getMedtronicPumpModel()) { aapsLogger.warn(LTag.PUMP, getLogPrefix() + "Configured pump is not the same as one detected."); - MedtronicUtil.sendNotification(MedtronicNotificationType.PumpTypeNotSame, getResourceHelper(), rxBus); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpTypeNotSame, getResourceHelper(), rxBus); } } @@ -559,29 +581,29 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter readPumpHistory(); // remaining insulin (>50 = 4h; 50-20 = 1h; 15m) - medtronicUIComm.executeCommand(MedtronicCommandType.GetRemainingInsulin); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.GetRemainingInsulin); scheduleNextRefresh(MedtronicStatusRefreshType.RemainingInsulin, 10); // remaining power (1h) - medtronicUIComm.executeCommand(MedtronicCommandType.GetBatteryStatus); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.GetBatteryStatus); scheduleNextRefresh(MedtronicStatusRefreshType.BatteryStatus, 20); // configuration (once and then if history shows config changes) - medtronicUIComm.executeCommand(MedtronicCommandType.getSettings(MedtronicUtil.getMedtronicPumpModel())); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.getSettings(medtronicUtil.getMedtronicPumpModel())); // read profile (once, later its controlled by isThisProfileSet method) getBasalProfiles(); - int errorCount = medtronicUIComm.getInvalidResponsesCount(); + int errorCount = rileyLinkMedtronicService.getMedtronicUIComm().getInvalidResponsesCount(); if (errorCount >= 5) { aapsLogger.error("Number of error counts was 5 or more. Starting tunning."); setRefreshButtonEnabled(true); - ServiceTaskExecutor.startTask(new WakeAndTuneTask()); + serviceTaskExecutor.startTask(new WakeAndTuneTask(getInjector())); return; } - pumpStatusLocal.setLastCommunicationToNow(); + medtronicPumpStatus.setLastCommunicationToNow(); setRefreshButtonEnabled(true); if (!isRefresh) { @@ -596,42 +618,37 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter private void getBasalProfiles() { - MedtronicUITask medtronicUITask = medtronicUIComm.executeCommand(MedtronicCommandType.GetBasalProfileSTD); + MedtronicUITask medtronicUITask = rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.GetBasalProfileSTD); if (medtronicUITask.getResponseType() == MedtronicUIResponseType.Error) { - medtronicUIComm.executeCommand(MedtronicCommandType.GetBasalProfileSTD); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.GetBasalProfileSTD); } } @Override public boolean isThisProfileSet(Profile profile) { - MedtronicPumpStatus mdtPumpStatus = getMDTPumpStatus(); - aapsLogger.debug(LTag.PUMP, "isThisProfileSet: basalInitalized=" + mdtPumpStatus.basalProfileStatus); + aapsLogger.debug(LTag.PUMP, "isThisProfileSet: basalInitalized=" + medtronicPumpStatus.basalProfileStatus); if (!isInitialized) return true; - if (mdtPumpStatus.basalProfileStatus == BasalProfileStatus.NotInitialized) { + if (medtronicPumpStatus.basalProfileStatus == BasalProfileStatus.NotInitialized) { // this shouldn't happen, but if there was problem we try again getBasalProfiles(); return isProfileSame(profile); - } else if (mdtPumpStatus.basalProfileStatus == BasalProfileStatus.ProfileChanged) { + } else if (medtronicPumpStatus.basalProfileStatus == BasalProfileStatus.ProfileChanged) { return false; - } else { - } - - return (getMDTPumpStatus().basalProfileStatus != BasalProfileStatus.ProfileOK) || isProfileSame(profile); + return (medtronicPumpStatus.basalProfileStatus != BasalProfileStatus.ProfileOK) || isProfileSame(profile); } private boolean isProfileSame(Profile profile) { boolean invalid = false; - Double[] basalsByHour = getMDTPumpStatus().basalsByHour; - PumpType pumpType = getMDTPumpStatus().getPumpType(); + Double[] basalsByHour = medtronicPumpStatus.basalsByHour; aapsLogger.debug(LTag.PUMP, "Current Basals (h): " + (basalsByHour == null ? "null" : BasalProfile.getProfilesByHourToString(basalsByHour))); @@ -645,11 +662,11 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter for (Profile.ProfileValue basalValue : profile.getBasalValues()) { - double basalValueValue = pumpType.determineCorrectBasalSize(basalValue.value); + double basalValueValue = pumpDescription.pumpType.determineCorrectBasalSize(basalValue.value); int hour = basalValue.timeAsSeconds / (60 * 60); - if (!MedtronicUtil.isSame(basalsByHour[hour], basalValueValue)) { + if (!medtronicUtil.isSame(basalsByHour[hour], basalValueValue)) { invalid = true; } @@ -671,10 +688,9 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter @Override public long lastDataTime() { - getMDTPumpStatus(); - if (pumpStatusLocal.lastConnection != 0) { - return pumpStatusLocal.lastConnection; + if (medtronicPumpStatus.lastConnection != 0) { + return medtronicPumpStatus.lastConnection; } return System.currentTimeMillis(); @@ -683,33 +699,21 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter @Override public double getBaseBasalRate() { - return getMDTPumpStatus().getBasalProfileForHour(); + return medtronicPumpStatus.getBasalProfileForHour(); } @Override public double getReservoirLevel() { - return getMDTPumpStatus().reservoirRemainingUnits; + return medtronicPumpStatus.reservoirRemainingUnits; } @Override public int getBatteryLevel() { - return getMDTPumpStatus().batteryRemaining; + return medtronicPumpStatus.batteryRemaining; } - - private MedtronicPumpStatus getMDTPumpStatus() { - if (pumpStatusLocal == null) { - // FIXME I don't know why this happens - aapsLogger.warn(LTag.PUMP, "!!!! Reset Pump Status Local"); - pumpStatusLocal = MedtronicUtil.getPumpStatus(); - } - - return pumpStatusLocal; - } - - protected void triggerUIChange() { rxBus.send(new EventMedtronicPumpValuesChanged()); } @@ -736,16 +740,16 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter return; } - MedtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); + medtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); - medtronicUIComm.executeCommand(MedtronicCommandType.GetRealTimeClock); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.GetRealTimeClock); - ClockDTO clock = MedtronicUtil.getPumpTime(); + ClockDTO clock = medtronicUtil.getPumpTime(); if (clock == null) { // retry - medtronicUIComm.executeCommand(MedtronicCommandType.GetRealTimeClock); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.GetRealTimeClock); - clock = MedtronicUtil.getPumpTime(); + clock = medtronicUtil.getPumpTime(); } if (clock == null) @@ -759,7 +763,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter aapsLogger.info(LTag.PUMP, "MedtronicPumpPlugin::checkTimeAndOptionallySetTime - Time difference is {} s. Set time on pump." + timeDiff); - medtronicUIComm.executeCommand(MedtronicCommandType.SetRealTimeClock); + rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.SetRealTimeClock); if (clock.timeDifference == 0) { Notification notification = new Notification(Notification.INSIGHT_DATE_TIME_UPDATED, getResourceHelper().gs(R.string.pump_time_updated), Notification.INFO, 60); @@ -768,7 +772,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter } else { if ((clock.localDeviceTime.getYear() > 2015)) { aapsLogger.error("MedtronicPumpPlugin::checkTimeAndOptionallySetTime - Time difference over 24h requested [diff={}]. Doing nothing." + timeDiff); - sendNotification(MedtronicNotificationType.TimeChangeOver24h, getResourceHelper(), rxBus); + medtronicUtil.sendNotification(MedtronicNotificationType.TimeChangeOver24h, getResourceHelper(), rxBus); } } @@ -787,14 +791,12 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter setRefreshButtonEnabled(false); - MedtronicPumpStatus mdtPumpStatus = getMDTPumpStatus(); - - if (detailedBolusInfo.insulin > mdtPumpStatus.reservoirRemainingUnits) { + if (detailedBolusInfo.insulin > medtronicPumpStatus.reservoirRemainingUnits) { return new PumpEnactResult(getInjector()) // .success(false) // .enacted(false) // .comment(getResourceHelper().gs(R.string.medtronic_cmd_bolus_could_not_be_delivered_no_insulin, - mdtPumpStatus.reservoirRemainingUnits, + medtronicPumpStatus.reservoirRemainingUnits, detailedBolusInfo.insulin)); } @@ -805,7 +807,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter return setNotReachable(true, false); } - MedtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); + medtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); if (bolusDeliveryType == BolusDeliveryType.CancelDelivery) { // LOG.debug("MedtronicPumpPlugin::deliverBolus - Delivery Canceled."); @@ -831,7 +833,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter // LOG.debug("MedtronicPumpPlugin::deliverBolus - Start delivery"); - MedtronicUITask responseTask = medtronicUIComm.executeCommand(MedtronicCommandType.SetBolus, + MedtronicUITask responseTask = rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.SetBolus, detailedBolusInfo.insulin); Boolean response = (Boolean) responseTask.returnData; @@ -870,7 +872,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter activePlugin.getActiveTreatments().addToHistoryTreatment(detailedBolusInfo, true); // we subtract insulin, exact amount will be visible with next remainingInsulin update. - getMDTPumpStatus().reservoirRemainingUnits -= detailedBolusInfo.insulin; + medtronicPumpStatus.reservoirRemainingUnits -= detailedBolusInfo.insulin; incrementStatistics(detailedBolusInfo.isSMB ? MedtronicConst.Statistics.SMBBoluses : MedtronicConst.Statistics.StandardBoluses); @@ -956,9 +958,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter .comment(getResourceHelper().gs(R.string.medtronic_pump_status_pump_unreachable)); } - MedtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); - - getMDTPumpStatus(); + medtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); aapsLogger.info(LTag.PUMP, getLogPrefix() + "setTempBasalAbsolute: rate: " + absoluteRate + ", duration=" + durationInMinutes); @@ -976,10 +976,10 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter if (!enforceNew) { - if (MedtronicUtil.isSame(tbrCurrent.getInsulinRate(), absoluteRate)) { + if (medtronicUtil.isSame(tbrCurrent.getInsulinRate(), absoluteRate)) { boolean sameRate = true; - if (MedtronicUtil.isSame(0.0d, absoluteRate) && durationInMinutes > 0) { + if (medtronicUtil.isSame(0.0d, absoluteRate) && durationInMinutes > 0) { // if rate is 0.0 and duration>0 then the rate is not the same sameRate = false; } @@ -999,7 +999,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter // CANCEL - MedtronicUITask responseTask2 = medtronicUIComm.executeCommand(MedtronicCommandType.CancelTBR); + MedtronicUITask responseTask2 = rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.CancelTBR); Boolean response = (Boolean) responseTask2.returnData; @@ -1016,7 +1016,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter } // now start new TBR - MedtronicUITask responseTask = medtronicUIComm.executeCommand(MedtronicCommandType.SetTemporaryBasal, + MedtronicUITask responseTask = rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.SetTemporaryBasal, absoluteRate, durationInMinutes); Boolean response = (Boolean) responseTask.returnData; @@ -1025,9 +1025,9 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter if (response) { // FIXME put this into UIPostProcessor - pumpStatusLocal.tempBasalStart = new Date(); - pumpStatusLocal.tempBasalAmount = absoluteRate; - pumpStatusLocal.tempBasalLength = durationInMinutes; + medtronicPumpStatus.tempBasalStart = new Date(); + medtronicPumpStatus.tempBasalAmount = absoluteRate; + medtronicPumpStatus.tempBasalLength = durationInMinutes; TemporaryBasal tempStart = new TemporaryBasal(getInjector()) // .date(System.currentTimeMillis()) // @@ -1061,8 +1061,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter return setTempBasalAbsolute(0.0d, durationInMinutes, profile, enforceNew); } else { double absoluteValue = profile.getBasal() * (percent / 100.0d); - getMDTPumpStatus(); - absoluteValue = pumpStatusLocal.pumpType.determineCorrectBasalSize(absoluteValue); + absoluteValue = pumpDescription.pumpType.determineCorrectBasalSize(absoluteValue); aapsLogger.warn(LTag.PUMP, "setTempBasalPercent [MedtronicPumpPlugin] - You are trying to use setTempBasalPercent with percent other then 0% (" + percent + "). This will start setTempBasalAbsolute, with calculated value (" + absoluteValue + "). Result might not be 100% correct."); return setTempBasalAbsolute(absoluteValue, durationInMinutes, profile, enforceNew); } @@ -1097,9 +1096,9 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter scheduleNextRefresh(MedtronicStatusRefreshType.PumpTime, -1); } - if (this.getMDTPumpStatus().basalProfileStatus != BasalProfileStatus.NotInitialized + if (this.medtronicPumpStatus.basalProfileStatus != BasalProfileStatus.NotInitialized && medtronicHistoryData.hasBasalProfileChanged()) { - medtronicHistoryData.processLastBasalProfileChange(getMDTPumpStatus()); + medtronicHistoryData.processLastBasalProfileChange(pumpDescription.pumpType, medtronicPumpStatus); } PumpDriverState previousState = this.pumpState; @@ -1162,7 +1161,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter aapsLogger.debug(LTag.PUMP, getLogPrefix() + "readPumpHistoryLogic(): targetDate: " + targetDate); } } else { - aapsLogger.debug(LTag.PUMP, getLogPrefix() + "readPumpHistoryLogic(): lastPumpHistoryEntry: not null - " + MedtronicUtil.gsonInstance.toJson(lastPumpHistoryEntry)); + aapsLogger.debug(LTag.PUMP, getLogPrefix() + "readPumpHistoryLogic(): lastPumpHistoryEntry: not null - " + medtronicUtil.gsonInstance.toJson(lastPumpHistoryEntry)); medtronicHistoryData.setIsInInit(false); // medtronicHistoryData.setLastHistoryRecordTime(lastPumpHistoryEntry.atechDateTime); @@ -1171,7 +1170,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter aapsLogger.debug(LTag.PUMP, "HST: Target Date: " + targetDate); - MedtronicUITask responseTask2 = medtronicUIComm.executeCommand(MedtronicCommandType.GetHistoryData, + MedtronicUITask responseTask2 = rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.GetHistoryData, lastPumpHistoryEntry, targetDate); aapsLogger.debug(LTag.PUMP, "HST: After task"); @@ -1247,7 +1246,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter switch (refreshType) { case RemainingInsulin: { - double remaining = pumpStatusLocal.reservoirRemainingUnits; + double remaining = medtronicPumpStatus.reservoirRemainingUnits; int min; if (remaining > 50) min = 4 * 60; @@ -1311,7 +1310,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter private TempBasalPair readTBR() { - MedtronicUITask responseTask = medtronicUIComm.executeCommand(MedtronicCommandType.ReadTemporaryBasal); + MedtronicUITask responseTask = rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.ReadTemporaryBasal); if (responseTask.hasData()) { TempBasalPair tbr = (TempBasalPair) responseTask.returnData; @@ -1343,7 +1342,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter .comment(getResourceHelper().gs(R.string.medtronic_pump_status_pump_unreachable)); } - MedtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); + medtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); setRefreshButtonEnabled(false); TempBasalPair tbrCurrent = readTBR(); @@ -1361,7 +1360,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter .comment(getResourceHelper().gs(R.string.medtronic_cmd_cant_read_tbr)); } - MedtronicUITask responseTask2 = medtronicUIComm.executeCommand(MedtronicCommandType.CancelTBR); + MedtronicUITask responseTask2 = rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.CancelTBR); Boolean response = (Boolean) responseTask2.returnData; @@ -1389,17 +1388,17 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter @NonNull @Override public ManufacturerType manufacturer() { - return getMDTPumpStatus().pumpType.getManufacturer(); + return pumpDescription.pumpType.getManufacturer(); } @NonNull @Override public PumpType model() { - return getMDTPumpStatus().pumpType; + return pumpDescription.pumpType; } @NonNull @Override public String serialNumber() { - return getMDTPumpStatus().serialNumber; + return medtronicPumpStatus.serialNumber; } @NonNull @Override @@ -1426,7 +1425,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter .comment(getResourceHelper().gs(R.string.medtronic_pump_status_pump_unreachable)); } - MedtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); + medtronicUtil.dismissNotification(MedtronicNotificationType.PumpUnreachable, rxBus); BasalProfile basalProfile = convertProfileToMedtronicProfile(profile); @@ -1439,7 +1438,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter .comment(getResourceHelper().gs(R.string.medtronic_cmd_set_profile_pattern_overflow, profileInvalid)); } - MedtronicUITask responseTask = medtronicUIComm.executeCommand(MedtronicCommandType.SetBasalProfileSTD, + MedtronicUITask responseTask = rileyLinkMedtronicService.getMedtronicUIComm().executeCommand(MedtronicCommandType.SetBasalProfileSTD, basalProfile); Boolean response = (Boolean) responseTask.returnData; @@ -1459,14 +1458,12 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter StringBuilder stringBuilder = new StringBuilder(); - MedtronicPumpStatus pumpStatus = getMDTPumpStatus(); - - if (pumpStatus.maxBasal == null) + if (medtronicPumpStatus.maxBasal == null) return null; for (BasalProfileEntry profileEntry : basalProfile.getEntries()) { - if (profileEntry.rate > pumpStatus.maxBasal) { + if (profileEntry.rate > medtronicPumpStatus.maxBasal) { stringBuilder.append(profileEntry.startTime.toString("HH:mm")); stringBuilder.append("="); stringBuilder.append(profileEntry.rate); @@ -1480,16 +1477,12 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter @NonNull private BasalProfile convertProfileToMedtronicProfile(Profile profile) { - MedtronicPumpStatus pumpStatus = getMDTPumpStatus(); - - PumpType pumpType = pumpStatus.pumpType; - - BasalProfile basalProfile = new BasalProfile(); + BasalProfile basalProfile = new BasalProfile(aapsLogger); for (int i = 0; i < 24; i++) { double rate = profile.getBasalTimeFromMidnight(i * 60 * 60); - double v = pumpType.determineCorrectBasalSize(rate); + double v = pumpDescription.pumpType.determineCorrectBasalSize(rate); BasalProfileEntry basalEntry = new BasalProfileEntry(v, i, 0); basalProfile.addEntry(basalEntry); @@ -1536,8 +1529,8 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter switch (mcat) { case WakeUpAndTune: { - if (MedtronicUtil.getPumpStatus().verifyConfiguration()) { - ServiceTaskExecutor.startTask(new WakeAndTuneTask()); + if (rileyLinkMedtronicService.verifyConfiguration()) { + serviceTaskExecutor.startTask(new WakeAndTuneTask(getInjector())); } else { Intent i = new Intent(context, ErrorHelperActivity.class); i.putExtra("soundid", R.raw.boluserror); @@ -1557,7 +1550,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter break; case ResetRileyLinkConfiguration: { - ServiceTaskExecutor.startTask(new ResetRileyLinkConfigurationTask()); + serviceTaskExecutor.startTask(new ResetRileyLinkConfigurationTask(getInjector())); } break; @@ -1576,7 +1569,7 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter } - public void setEnableCustomAction(MedtronicCustomActionType customAction, boolean isEnabled) { + private void setEnableCustomAction(MedtronicCustomActionType customAction, boolean isEnabled) { if (customAction == MedtronicCustomActionType.ClearBolusBlock) { this.customActionClearBolusBlock.setEnabled(isEnabled); @@ -1586,6 +1579,4 @@ public class MedtronicPumpPlugin extends PumpPluginAbstract implements PumpInter refreshCustomActionsList(); } - - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicCommunicationManager.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicCommunicationManager.java index 261e53e7ab..348110c671 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicCommunicationManager.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicCommunicationManager.java @@ -3,16 +3,18 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm; import android.os.SystemClock; import org.joda.time.LocalDateTime; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import java.util.Calendar; import java.util.GregorianCalendar; import java.util.List; import java.util.Map; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; +import info.nightscout.androidaps.plugins.pump.common.data.PumpStatus; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkCommunicationManager; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RFSpy; @@ -22,10 +24,12 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RLMe import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RadioPacket; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RadioResponse; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RLMessageType; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.ServiceTaskExecutor; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.WakeAndTuneTask; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.common.utils.DateTimeUtil; +import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.RawHistoryPage; import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump.MedtronicPumpHistoryDecoder; import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump.PumpHistoryEntry; @@ -45,8 +49,8 @@ import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.TempBasalPair; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicCommandType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicDeviceType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; +import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpStatus; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; -import info.nightscout.androidaps.utils.SP; /** * Original file created by geoff on 5/30/16. @@ -57,53 +61,43 @@ import info.nightscout.androidaps.utils.SP; */ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); - private static final int MAX_COMMAND_TRIES = 3; - private static final int DEFAULT_TIMEOUT = 2000; - private static final long RILEYLINK_TIMEOUT = 15 * 60 * 1000; // 15 min + @Inject AAPSLogger aapsLogger; + @Inject MedtronicPumpStatus medtronicPumpStatus; + @Inject MedtronicPumpPlugin medtronicPumpPlugin; + @Inject MedtronicConverter medtronicConverter; + @Inject MedtronicUtil medtronicUtil; + @Inject MedtronicPumpHistoryDecoder medtronicPumpHistoryDecoder; + @Inject RileyLinkServiceData rileyLinkServiceData; + @Inject ServiceTaskExecutor serviceTaskExecutor; - static MedtronicCommunicationManager medtronicCommunicationManager; - String errorMessage; - private MedtronicConverter medtronicConverter; + private final int MAX_COMMAND_TRIES = 3; + private final int DEFAULT_TIMEOUT = 2000; + private final long RILEYLINK_TIMEOUT = 15 * 60 * 1000; // 15 min + + private String errorMessage; private boolean debugSetCommands = false; - private MedtronicPumpHistoryDecoder pumpHistoryDecoder; private boolean doWakeUpBeforeCommand = true; - public MedtronicCommunicationManager(RFSpy rfspy) { - super(rfspy); - medtronicCommunicationManager = this; - this.medtronicConverter = new MedtronicConverter(); - this.pumpHistoryDecoder = new MedtronicPumpHistoryDecoder(); - MedtronicUtil.getPumpStatus().previousConnection = SP.getLong( + public MedtronicCommunicationManager(HasAndroidInjector injector, RFSpy rfspy) { + super(injector, rfspy); + medtronicPumpStatus.previousConnection = sp.getLong( RileyLinkConst.Prefs.LastGoodDeviceCommunicationTime, 0L); } - - public static MedtronicCommunicationManager getInstance() { - return medtronicCommunicationManager; - } - - - @Override - protected void configurePumpSpecificSettings() { - pumpStatus = MedtronicUtil.getPumpStatus(); - } - - @Override public E createResponseMessage(byte[] payload, Class clazz) { - PumpMessage pumpMessage = new PumpMessage(payload); + PumpMessage pumpMessage = new PumpMessage(aapsLogger, payload); return (E) pumpMessage; } - public void setDoWakeUpBeforeCommand(boolean doWakeUp) { this.doWakeUpBeforeCommand = doWakeUp; } + @Override public boolean isDeviceReachable() { return isDeviceReachable(false); } @@ -117,15 +111,14 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager */ public boolean isDeviceReachable(boolean canPreventTuneUp) { - PumpDeviceState state = MedtronicUtil.getPumpDeviceState(); + PumpDeviceState state = medtronicPumpStatus.getPumpDeviceState(); if (state != PumpDeviceState.PumpUnreachable) - MedtronicUtil.setPumpDeviceState(PumpDeviceState.WakingUp); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.WakingUp); for (int retry = 0; retry < 5; retry++) { - if (isLogEnabled()) - LOG.debug("isDeviceReachable. Waking pump... " + (retry != 0 ? " (retry " + retry + ")" : "")); + aapsLogger.debug(LTag.PUMPCOMM, "isDeviceReachable. Waking pump... " + (retry != 0 ? " (retry " + retry + ")" : "")); boolean connected = connectToDevice(); @@ -137,14 +130,14 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager } if (state != PumpDeviceState.PumpUnreachable) - MedtronicUtil.setPumpDeviceState(PumpDeviceState.PumpUnreachable); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.PumpUnreachable); if (!canPreventTuneUp) { - long diff = System.currentTimeMillis() - MedtronicUtil.getPumpStatus().lastConnection; + long diff = System.currentTimeMillis() - medtronicPumpStatus.lastConnection; if (diff > RILEYLINK_TIMEOUT) { - ServiceTaskExecutor.startTask(new WakeAndTuneTask()); + serviceTaskExecutor.startTask(new WakeAndTuneTask(injector)); } } @@ -154,18 +147,17 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager private boolean connectToDevice() { - PumpDeviceState state = MedtronicUtil.getPumpDeviceState(); + PumpDeviceState state = medtronicPumpStatus.getPumpDeviceState(); byte[] pumpMsgContent = createPumpMessageContent(RLMessageType.ReadSimpleData); // simple - RFSpyResponse rfSpyResponse = rfspy.transmitThenReceive(new RadioPacket(pumpMsgContent), (byte) 0, (byte) 200, + RFSpyResponse rfSpyResponse = rfspy.transmitThenReceive(new RadioPacket(injector, pumpMsgContent), (byte) 0, (byte) 200, (byte) 0, (byte) 0, 25000, (byte) 0); - if (isLogEnabled()) - LOG.info("wakeup: raw response is " + ByteUtil.shortHexString(rfSpyResponse.getRaw())); + aapsLogger.info(LTag.PUMPCOMM, "wakeup: raw response is " + ByteUtil.shortHexString(rfSpyResponse.getRaw())); if (rfSpyResponse.wasTimeout()) { - LOG.error("isDeviceReachable. Failed to find pump (timeout)."); + aapsLogger.error(LTag.PUMPCOMM, "isDeviceReachable. Failed to find pump (timeout)."); } else if (rfSpyResponse.looksLikeRadioPacket()) { - RadioResponse radioResponse = new RadioResponse(); + RadioResponse radioResponse = new RadioResponse(injector); try { @@ -176,30 +168,29 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager PumpMessage pumpResponse = createResponseMessage(radioResponse.getPayload(), PumpMessage.class); if (!pumpResponse.isValid()) { - LOG.warn("Response is invalid ! [interrupted={}, timeout={}]", rfSpyResponse.wasInterrupted(), + aapsLogger.warn(LTag.PUMPCOMM, "Response is invalid ! [interrupted={}, timeout={}]", rfSpyResponse.wasInterrupted(), rfSpyResponse.wasTimeout()); } else { // radioResponse.rssi; - Object dataResponse = medtronicConverter.convertResponse(MedtronicCommandType.PumpModel, + Object dataResponse = medtronicConverter.convertResponse(medtronicPumpPlugin.getPumpDescription().pumpType, MedtronicCommandType.PumpModel, pumpResponse.getRawContent()); MedtronicDeviceType pumpModel = (MedtronicDeviceType) dataResponse; boolean valid = (pumpModel != MedtronicDeviceType.Unknown_Device); - if (MedtronicUtil.getMedtronicPumpModel() == null && valid) { - MedtronicUtil.setMedtronicPumpModel(pumpModel); + if (medtronicUtil.getMedtronicPumpModel() == null && valid) { + medtronicUtil.setMedtronicPumpModel(pumpModel); } - if (isLogEnabled()) - LOG.debug("isDeviceReachable. PumpModel is {} - Valid: {} (rssi={})", pumpModel.name(), valid, - radioResponse.rssi); + aapsLogger.debug(LTag.PUMPCOMM, "isDeviceReachable. PumpModel is {} - Valid: {} (rssi={})", pumpModel.name(), valid, + radioResponse.rssi); if (valid) { if (state == PumpDeviceState.PumpUnreachable) - MedtronicUtil.setPumpDeviceState(PumpDeviceState.WakingUp); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.WakingUp); else - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); rememberLastGoodDeviceCommunicationTime(); @@ -207,23 +198,23 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager } else { if (state != PumpDeviceState.PumpUnreachable) - MedtronicUtil.setPumpDeviceState(PumpDeviceState.PumpUnreachable); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.PumpUnreachable); } } } else { - LOG.warn("isDeviceReachable. Failed to parse radio response: " + aapsLogger.warn(LTag.PUMPCOMM, "isDeviceReachable. Failed to parse radio response: " + ByteUtil.shortHexString(rfSpyResponse.getRaw())); } } catch (RileyLinkCommunicationException e) { - LOG.warn("isDeviceReachable. Failed to decode radio response: " + aapsLogger.warn(LTag.PUMPCOMM, "isDeviceReachable. Failed to decode radio response: " + ByteUtil.shortHexString(rfSpyResponse.getRaw())); } } else { - LOG.warn("isDeviceReachable. Unknown response: " + ByteUtil.shortHexString(rfSpyResponse.getRaw())); + aapsLogger.warn(LTag.PUMPCOMM, "isDeviceReachable. Unknown response: " + ByteUtil.shortHexString(rfSpyResponse.getRaw())); } return false; @@ -239,7 +230,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager private PumpMessage runCommandWithArgs(PumpMessage msg) throws RileyLinkCommunicationException { if (debugSetCommands) - LOG.debug("Run command with Args: "); + aapsLogger.debug(LTag.PUMPCOMM, "Run command with Args: "); PumpMessage rval; PumpMessage shortMessage = makePumpMessage(msg.commandType, new CarelinkShortMessageBody(new byte[]{0})); @@ -247,17 +238,16 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager PumpMessage shortResponse = sendAndListen(shortMessage); if (shortResponse.commandType == MedtronicCommandType.CommandACK) { if (debugSetCommands) - LOG.debug("Run command with Args: Got ACK response"); + aapsLogger.debug(LTag.PUMPCOMM, "Run command with Args: Got ACK response"); rval = sendAndListen(msg); if (debugSetCommands) - LOG.debug("2nd Response: {}", rval); + aapsLogger.debug(LTag.PUMPCOMM, "2nd Response: {}", rval); return rval; } else { - if (isLogEnabled()) - LOG.error("runCommandWithArgs: Pump did not ack Attention packet"); - return new PumpMessage("No ACK after Attention packet."); + aapsLogger.error(LTag.PUMPCOMM, "runCommandWithArgs: Pump did not ack Attention packet"); + return new PumpMessage(aapsLogger, "No ACK after Attention packet."); } } @@ -265,8 +255,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager private PumpMessage runCommandWithFrames(MedtronicCommandType commandType, List> frames) throws RileyLinkCommunicationException { - if (isLogEnabled()) - LOG.debug("Run command with Frames: {}", commandType.name()); + aapsLogger.debug(LTag.PUMPCOMM, "Run command with Frames: {}", commandType.name()); PumpMessage rval = null; PumpMessage shortMessage = makePumpMessage(commandType, new CarelinkShortMessageBody(new byte[]{0})); @@ -274,39 +263,36 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager PumpMessage shortResponse = sendAndListen(shortMessage); if (shortResponse.commandType != MedtronicCommandType.CommandACK) { - if (isLogEnabled()) - LOG.error("runCommandWithFrames: Pump did not ack Attention packet"); + aapsLogger.error(LTag.PUMPCOMM, "runCommandWithFrames: Pump did not ack Attention packet"); - return new PumpMessage("No ACK after start message."); + return new PumpMessage(aapsLogger, "No ACK after start message."); } else { - if (isLogEnabled()) - LOG.debug("Run command with Frames: Got ACK response for Attention packet"); + aapsLogger.debug(LTag.PUMPCOMM, "Run command with Frames: Got ACK response for Attention packet"); } int frameNr = 1; for (List frame : frames) { - byte[] frameData = MedtronicUtil.createByteArray(frame); + byte[] frameData = medtronicUtil.createByteArray(frame); - // LOG.debug("Frame {} data:\n{}", frameNr, ByteUtil.getCompactString(frameData)); + // aapsLogger.debug(LTag.PUMPCOMM,"Frame {} data:\n{}", frameNr, ByteUtil.getCompactString(frameData)); PumpMessage msg = makePumpMessage(commandType, new CarelinkLongMessageBody(frameData)); rval = sendAndListen(msg); - // LOG.debug("PumpResponse: " + rval); + // aapsLogger.debug(LTag.PUMPCOMM,"PumpResponse: " + rval); if (rval.commandType != MedtronicCommandType.CommandACK) { - LOG.error("runCommandWithFrames: Pump did not ACK frame #{}", frameNr); + aapsLogger.error(LTag.PUMPCOMM, "runCommandWithFrames: Pump did not ACK frame #{}", frameNr); - LOG.error("Run command with Frames FAILED (command={}, response={})", commandType.name(), + aapsLogger.error(LTag.PUMPCOMM, "Run command with Frames FAILED (command={}, response={})", commandType.name(), rval.toString()); - return new PumpMessage("No ACK after frame #" + frameNr); + return new PumpMessage(aapsLogger, "No ACK after frame #" + frameNr); } else { - if (isLogEnabled()) - LOG.debug("Run command with Frames: Got ACK response for frame #{}", (frameNr)); + aapsLogger.debug(LTag.PUMPCOMM, "Run command with Frames: Got ACK response for frame #{}", (frameNr)); } frameNr++; @@ -319,34 +305,32 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager public PumpHistoryResult getPumpHistory(PumpHistoryEntry lastEntry, LocalDateTime targetDate) { - PumpHistoryResult pumpTotalResult = new PumpHistoryResult(lastEntry, targetDate == null ? null + PumpHistoryResult pumpTotalResult = new PumpHistoryResult(aapsLogger, lastEntry, targetDate == null ? null : DateTimeUtil.toATechDate(targetDate)); if (doWakeUpBeforeCommand) wakeUp(receiverDeviceAwakeForMinutes, false); - if (isLogEnabled()) - LOG.debug("Current command: " + MedtronicUtil.getCurrentCommand()); + aapsLogger.debug(LTag.PUMPCOMM, "Current command: " + medtronicUtil.getCurrentCommand()); - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Active); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Active); boolean doneWithError = false; for (int pageNumber = 0; pageNumber < 5; pageNumber++) { - RawHistoryPage rawHistoryPage = new RawHistoryPage(); + RawHistoryPage rawHistoryPage = new RawHistoryPage(aapsLogger); // wakeUp(receiverDeviceAwakeForMinutes, false); PumpMessage getHistoryMsg = makePumpMessage(MedtronicCommandType.GetHistoryData, new GetHistoryPageCarelinkMessageBody(pageNumber)); - if (isLogEnabled()) - LOG.info("getPumpHistory: Page {}", pageNumber); - // LOG.info("getPumpHistoryPage("+pageNumber+"): "+ByteUtil.shortHexString(getHistoryMsg.getTxData())); + aapsLogger.info(LTag.PUMPCOMM, "getPumpHistory: Page {}", pageNumber); + // aapsLogger.info(LTag.PUMPCOMM,"getPumpHistoryPage("+pageNumber+"): "+ByteUtil.shortHexString(getHistoryMsg.getTxData())); // Ask the pump to transfer history (we get first frame?) PumpMessage firstResponse = null; boolean failed = false; - MedtronicUtil.setCurrentCommand(MedtronicCommandType.GetHistoryData, pageNumber, null); + medtronicUtil.setCurrentCommand(MedtronicCommandType.GetHistoryData, pageNumber, null); for (int retries = 0; retries < MAX_COMMAND_TRIES; retries++) { @@ -355,18 +339,17 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager failed = false; break; } catch (RileyLinkCommunicationException e) { - if (isLogEnabled()) - LOG.error("First call for PumpHistory failed (retry={})", retries); + aapsLogger.error(LTag.PUMPCOMM, "First call for PumpHistory failed (retry={})", retries); failed = true; } } if (failed) { - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); return pumpTotalResult; } - // LOG.info("getPumpHistoryPage("+pageNumber+"): " + ByteUtil.shortHexString(firstResponse.getContents())); + // aapsLogger.info(LTag.PUMPCOMM,"getPumpHistoryPage("+pageNumber+"): " + ByteUtil.shortHexString(firstResponse.getContents())); PumpMessage ackMsg = makePumpMessage(MedtronicCommandType.CommandACK, new PumpAckMessageBody()); GetHistoryPageCarelinkMessageBody currentResponse = new GetHistoryPageCarelinkMessageBody(firstResponse @@ -383,19 +366,17 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager && currentResponse.getFrameNumber() == expectedFrameNum) { // success! got a frame. if (frameData.length != 64) { - if (isLogEnabled()) - LOG.warn("Expected frame of length 64, got frame of length " + frameData.length); + aapsLogger.warn(LTag.PUMPCOMM, "Expected frame of length 64, got frame of length " + frameData.length); // but append it anyway? } // handle successful frame data rawHistoryPage.appendData(currentResponse.getFrameData()); // RileyLinkMedtronicService.getInstance().announceProgress(((100 / 16) * // currentResponse.getFrameNumber() + 1)); - MedtronicUtil.setCurrentCommand(MedtronicCommandType.GetHistoryData, pageNumber, + medtronicUtil.setCurrentCommand(MedtronicCommandType.GetHistoryData, pageNumber, currentResponse.getFrameNumber()); - if (isLogEnabled()) - LOG.info("getPumpHistory: Got frame {} of Page {}", currentResponse.getFrameNumber(), pageNumber); + aapsLogger.info(LTag.PUMPCOMM, "getPumpHistory: Got frame {} of Page {}", currentResponse.getFrameNumber(), pageNumber); // Do we need to ask for the next frame? if (expectedFrameNum < 16) { // This number may not be correct for pumps other than 522/722 expectedFrameNum++; @@ -404,22 +385,18 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager } } else { if (frameData == null) { - if (isLogEnabled()) - LOG.error("null frame data, retrying"); + aapsLogger.error(LTag.PUMPCOMM, "null frame data, retrying"); } else if (currentResponse.getFrameNumber() != expectedFrameNum) { - if (isLogEnabled()) - LOG.warn("Expected frame number {}, received {} (retrying)", expectedFrameNum, - currentResponse.getFrameNumber()); + aapsLogger.warn(LTag.PUMPCOMM, "Expected frame number {}, received {} (retrying)", expectedFrameNum, + currentResponse.getFrameNumber()); } else if (frameData.length == 0) { - if (isLogEnabled()) - LOG.warn("Frame has zero length, retrying"); + aapsLogger.warn(LTag.PUMPCOMM, "Frame has zero length, retrying"); } failures++; if (failures == 6) { - if (isLogEnabled()) - LOG.error( - "getPumpHistory: 6 failures in attempting to download frame {} of page {}, giving up.", - expectedFrameNum, pageNumber); + aapsLogger.error(LTag.PUMPCOMM, + "getPumpHistory: 6 failures in attempting to download frame {} of page {}, giving up.", + expectedFrameNum, pageNumber); done = true; // failure completion. doneWithError = true; } @@ -435,59 +412,52 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager nextMsg = sendAndListen(ackMsg); break; } catch (RileyLinkCommunicationException e) { - if (isLogEnabled()) - LOG.error("Problem acknowledging frame response. (retry={})", retries); + aapsLogger.error(LTag.PUMPCOMM, "Problem acknowledging frame response. (retry={})", retries); } } if (nextMsg != null) currentResponse = new GetHistoryPageCarelinkMessageBody(nextMsg.getMessageBody().getTxData()); else { - if (isLogEnabled()) - LOG.error("We couldn't acknowledge frame from pump, aborting operation."); + aapsLogger.error(LTag.PUMPCOMM, "We couldn't acknowledge frame from pump, aborting operation."); } } } if (rawHistoryPage.getLength() != 1024) { - if (isLogEnabled()) - LOG.warn("getPumpHistory: short page. Expected length of 1024, found length of " - + rawHistoryPage.getLength()); + aapsLogger.warn(LTag.PUMPCOMM, "getPumpHistory: short page. Expected length of 1024, found length of " + + rawHistoryPage.getLength()); doneWithError = true; } if (!rawHistoryPage.isChecksumOK()) { - if (isLogEnabled()) - LOG.error("getPumpHistory: checksum is wrong"); + aapsLogger.error(LTag.PUMPCOMM, "getPumpHistory: checksum is wrong"); doneWithError = true; } if (doneWithError) { - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); return pumpTotalResult; } rawHistoryPage.dumpToDebug(); - List medtronicHistoryEntries = pumpHistoryDecoder - .processPageAndCreateRecords(rawHistoryPage); + List medtronicHistoryEntries = medtronicPumpHistoryDecoder.processPageAndCreateRecords(rawHistoryPage); - if (isLogEnabled()) - LOG.debug("getPumpHistory: Found {} history entries.", medtronicHistoryEntries.size()); + aapsLogger.debug(LTag.PUMPCOMM, "getPumpHistory: Found {} history entries.", medtronicHistoryEntries.size()); pumpTotalResult.addHistoryEntries(medtronicHistoryEntries, pageNumber); - if (isLogEnabled()) - LOG.debug("getPumpHistory: Search status: Search finished: {}", pumpTotalResult.isSearchFinished()); + aapsLogger.debug(LTag.PUMPCOMM, "getPumpHistory: Search status: Search finished: {}", pumpTotalResult.isSearchFinished()); if (pumpTotalResult.isSearchFinished()) { - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); return pumpTotalResult; } } - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); return pumpTotalResult; @@ -503,11 +473,11 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager public byte[] createPumpMessageContent(RLMessageType type) { switch (type) { case PowerOn: - return MedtronicUtil.buildCommandPayload(MedtronicCommandType.RFPowerOn, // + return medtronicUtil.buildCommandPayload(rileyLinkServiceData, MedtronicCommandType.RFPowerOn, // new byte[]{2, 1, (byte) receiverDeviceAwakeForMinutes}); // maybe this is better FIXME case ReadSimpleData: - return MedtronicUtil.buildCommandPayload(MedtronicCommandType.PumpModel, null); + return medtronicUtil.buildCommandPayload(rileyLinkServiceData, MedtronicCommandType.PumpModel, null); } return new byte[0]; } @@ -525,7 +495,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager private PumpMessage makePumpMessage(MedtronicCommandType messageType, MessageBody messageBody) { - PumpMessage msg = new PumpMessage(); + PumpMessage msg = new PumpMessage(aapsLogger); msg.init(PacketType.Carelink, rileyLinkServiceData.pumpIDBytes, messageType, messageBody); return msg; } @@ -551,7 +521,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager if (doWakeUpBeforeCommand) wakeUp(receiverDeviceAwakeForMinutes, false); - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Active); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Active); // create message PumpMessage msg; @@ -564,7 +534,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager // send and wait for response PumpMessage response = sendAndListen(msg, timeoutMs); - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); return response; } @@ -589,27 +559,22 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager private Object sendAndGetResponseWithCheck(MedtronicCommandType commandType, byte[] bodyData) { - if (isLogEnabled()) - LOG.debug("getDataFromPump: {}", commandType); + aapsLogger.debug(LTag.PUMPCOMM, "getDataFromPump: {}", commandType); for (int retries = 0; retries < MAX_COMMAND_TRIES; retries++) { try { - PumpMessage response = null; + PumpMessage response = sendAndGetResponse(commandType, bodyData, DEFAULT_TIMEOUT + (DEFAULT_TIMEOUT * retries)); - response = sendAndGetResponse(commandType, bodyData, DEFAULT_TIMEOUT + (DEFAULT_TIMEOUT * retries)); - - String check = checkResponseContent(response, commandType.commandDescription, - commandType.expectedLength); + String check = checkResponseContent(response, commandType.commandDescription, commandType.expectedLength); if (check == null) { - Object dataResponse = medtronicConverter.convertResponse(commandType, response.getRawContent()); + Object dataResponse = medtronicConverter.convertResponse(medtronicPumpPlugin.getPumpDescription().pumpType, commandType, response.getRawContent()); if (dataResponse != null) { this.errorMessage = null; - if (isLogEnabled()) - LOG.debug("Converted response for {} is {}.", commandType.name(), dataResponse); + aapsLogger.debug(LTag.PUMPCOMM, "Converted response for {} is {}.", commandType.name(), dataResponse); return dataResponse; } else { @@ -621,8 +586,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager } } catch (RileyLinkCommunicationException e) { - if (isLogEnabled()) - LOG.warn("Error getting response from RileyLink (error={}, retry={})", e.getMessage(), retries + 1); + aapsLogger.warn(LTag.PUMPCOMM, "Error getting response from RileyLink (error={}, retry={})", e.getMessage(), retries + 1); } } @@ -635,8 +599,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager if (!response.isValid()) { String responseData = String.format("%s: Invalid response.", method); - if (isLogEnabled()) - LOG.warn(responseData); + aapsLogger.warn(LTag.PUMPCOMM, responseData); return responseData; } @@ -644,7 +607,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager if (contents != null) { if (contents.length >= expectedLength) { - LOG.trace("{}: Content: {}", method, ByteUtil.shortHexString(contents)); + aapsLogger.debug(LTag.PUMPCOMM, "{}: Content: {}", method, ByteUtil.shortHexString(contents)); return null; } else { @@ -652,13 +615,12 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager "%s: Cannot return data. Data is too short [expected=%s, received=%s].", method, "" + expectedLength, "" + contents.length); - if (isLogEnabled()) - LOG.warn(responseData); + aapsLogger.warn(LTag.PUMPCOMM, responseData); return responseData; } } else { String responseData = String.format("%s: Cannot return data. Null response.", method); - LOG.warn(responseData); + aapsLogger.warn(LTag.PUMPCOMM, responseData); return responseData; } } @@ -690,12 +652,11 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager MedtronicCommandType commandType = MedtronicCommandType.GetBasalProfileSTD; - if (isLogEnabled()) - LOG.debug("getDataFromPump: {}", commandType); + aapsLogger.debug(LTag.PUMPCOMM, "getDataFromPump: {}", commandType); - MedtronicUtil.setCurrentCommand(commandType); + medtronicUtil.setCurrentCommand(commandType); - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Active); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Active); for (int retries = 0; retries <= MAX_COMMAND_TRIES; retries++) { @@ -706,12 +667,11 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager msg = makePumpMessage(commandType); // send and wait for response - PumpMessage response = null; - response = sendAndListen(msg, DEFAULT_TIMEOUT + (DEFAULT_TIMEOUT * retries)); + PumpMessage response = sendAndListen(msg, DEFAULT_TIMEOUT + (DEFAULT_TIMEOUT * retries)); -// LOG.debug("1st Response: " + HexDump.toHexStringDisplayable(response.getRawContent())); -// LOG.debug("1st Response: " + HexDump.toHexStringDisplayable(response.getMessageBody().getTxData())); +// aapsLogger.debug(LTag.PUMPCOMM,"1st Response: " + HexDump.toHexStringDisplayable(response.getRawContent())); +// aapsLogger.debug(LTag.PUMPCOMM,"1st Response: " + HexDump.toHexStringDisplayable(response.getMessageBody().getTxData())); String check = checkResponseContent(response, commandType.commandDescription, 1); @@ -727,8 +687,8 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager response = sendAndListen(ackMsg, DEFAULT_TIMEOUT + (DEFAULT_TIMEOUT * retries)); -// LOG.debug("{} Response: {}", runs, HexDump.toHexStringDisplayable(response2.getRawContent())); -// LOG.debug("{} Response: {}", runs, +// aapsLogger.debug(LTag.PUMPCOMM,"{} Response: {}", runs, HexDump.toHexStringDisplayable(response2.getRawContent())); +// aapsLogger.debug(LTag.PUMPCOMM,"{} Response: {}", runs, // HexDump.toHexStringDisplayable(response2.getMessageBody().getTxData())); String check2 = checkResponseContent(response, commandType.commandDescription, 1); @@ -739,7 +699,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager } else { this.errorMessage = check2; - LOG.error("Error with response got GetProfile: " + check2); + aapsLogger.error(LTag.PUMPCOMM, "Error with response got GetProfile: " + check2); } } @@ -747,26 +707,25 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager errorMessage = check; } - BasalProfile basalProfile = (BasalProfile) medtronicConverter.convertResponse(commandType, data); + BasalProfile basalProfile = (BasalProfile) medtronicConverter.convertResponse(medtronicPumpPlugin.getPumpDescription().pumpType, commandType, data); if (basalProfile != null) { - if (isLogEnabled()) - LOG.debug("Converted response for {} is {}.", commandType.name(), basalProfile); + aapsLogger.debug(LTag.PUMPCOMM, "Converted response for {} is {}.", commandType.name(), basalProfile); - MedtronicUtil.setCurrentCommand(null); - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + medtronicUtil.setCurrentCommand(null); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); return basalProfile; } } catch (RileyLinkCommunicationException e) { - LOG.error("Error getting response from RileyLink (error={}, retry={})", e.getMessage(), retries + 1); + aapsLogger.error(LTag.PUMPCOMM, "Error getting response from RileyLink (error={}, retry={})", e.getMessage(), retries + 1); } } - LOG.warn("Error reading profile in max retries."); - MedtronicUtil.setCurrentCommand(null); - MedtronicUtil.setPumpDeviceState(PumpDeviceState.Sleeping); + aapsLogger.warn(LTag.PUMPCOMM, "Error reading profile in max retries."); + medtronicUtil.setCurrentCommand(null); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.Sleeping); return null; @@ -782,7 +741,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager int last = responseRaw.length - 1; - LOG.debug("Length: " + data.length); + aapsLogger.debug(LTag.PUMPCOMM, "Length: " + data.length); if (data.length >= BasalProfile.MAX_RAW_DATA_SIZE) { return false; @@ -825,7 +784,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager public Map getPumpSettings() { - Object responseObject = sendAndGetResponseWithCheck(MedtronicCommandType.getSettings(MedtronicUtil + Object responseObject = sendAndGetResponseWithCheck(MedtronicCommandType.getSettings(medtronicUtil .getMedtronicPumpModel())); return responseObject == null ? null : (Map) responseObject; @@ -834,18 +793,16 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager public Boolean setBolus(double units) { - if (isLogEnabled()) - LOG.info("setBolus: " + units); + aapsLogger.info(LTag.PUMPCOMM, "setBolus: " + units); - return setCommand(MedtronicCommandType.SetBolus, MedtronicUtil.getBolusStrokes(units)); + return setCommand(MedtronicCommandType.SetBolus, medtronicUtil.getBolusStrokes(units)); } public boolean setTBR(TempBasalPair tbr) { - if (isLogEnabled()) - LOG.info("setTBR: " + tbr.getDescription()); + aapsLogger.info(LTag.PUMPCOMM, "setTBR: " + tbr.getDescription()); return setCommand(MedtronicCommandType.SetTemporaryBasal, tbr.getAsRawData()); } @@ -856,8 +813,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager GregorianCalendar gc = new GregorianCalendar(); gc.add(Calendar.SECOND, 5); - if (isLogEnabled()) - LOG.info("setPumpTime: " + DateTimeUtil.toString(gc)); + aapsLogger.info(LTag.PUMPCOMM, "setPumpTime: " + DateTimeUtil.toString(gc)); int i = 1; byte[] data = new byte[8]; @@ -866,7 +822,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager data[i + 1] = (byte) gc.get(Calendar.MINUTE); data[i + 2] = (byte) gc.get(Calendar.SECOND); - byte[] yearByte = MedtronicUtil.getByteArrayFromUnsignedShort(gc.get(Calendar.YEAR), true); + byte[] yearByte = medtronicUtil.getByteArrayFromUnsignedShort(gc.get(Calendar.YEAR), true); data[i + 3] = yearByte[0]; data[i + 4] = yearByte[1]; @@ -874,7 +830,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager data[i + 5] = (byte) (gc.get(Calendar.MONTH) + 1); data[i + 6] = (byte) gc.get(Calendar.DAY_OF_MONTH); - //LOG.info("setPumpTime: Body: " + ByteUtil.getHex(data)); + //aapsLogger.info(LTag.PUMPCOMM,"setPumpTime: Body: " + ByteUtil.getHex(data)); return setCommand(MedtronicCommandType.SetRealTimeClock, data); @@ -890,7 +846,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager wakeUp(false); if (debugSetCommands) - LOG.debug("{}: Body - {}", commandType.getCommandDescription(), + aapsLogger.debug(LTag.PUMPCOMM, "{}: Body - {}", commandType.getCommandDescription(), ByteUtil.getHex(body)); PumpMessage msg = makePumpMessage(commandType, new CarelinkLongMessageBody(body)); @@ -898,17 +854,16 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager PumpMessage pumpMessage = runCommandWithArgs(msg); if (debugSetCommands) - LOG.debug("{}: {}", commandType.getCommandDescription(), pumpMessage.getResponseContent()); + aapsLogger.debug(LTag.PUMPCOMM, "{}: {}", commandType.getCommandDescription(), pumpMessage.getResponseContent()); if (pumpMessage.commandType == MedtronicCommandType.CommandACK) { return true; } else { - LOG.warn("We received non-ACK response from pump: {}", pumpMessage.getResponseContent()); + aapsLogger.warn(LTag.PUMPCOMM, "We received non-ACK response from pump: {}", pumpMessage.getResponseContent()); } } catch (RileyLinkCommunicationException e) { - if (isLogEnabled()) - LOG.warn("Error getting response from RileyLink (error={}, retry={})", e.getMessage(), retries + 1); + aapsLogger.warn(LTag.PUMPCOMM, "Error getting response from RileyLink (error={}, retry={})", e.getMessage(), retries + 1); } } @@ -931,7 +886,7 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager public Boolean setBasalProfile(BasalProfile basalProfile) { - List> basalProfileFrames = MedtronicUtil.getBasalProfileFrames(basalProfile.getRawData()); + List> basalProfileFrames = medtronicUtil.getBasalProfileFrames(basalProfile.getRawData()); for (int retries = 0; retries <= MAX_COMMAND_TRIES; retries++) { @@ -944,23 +899,20 @@ public class MedtronicCommunicationManager extends RileyLinkCommunicationManager return true; } catch (RileyLinkCommunicationException e) { - LOG.warn("Error getting response from RileyLink (error={}, retry={})", e.getMessage(), retries + 1); + aapsLogger.warn(LTag.PUMPCOMM, "Error getting response from RileyLink (error={}, retry={})", e.getMessage(), retries + 1); } if (responseMessage != null) - LOG.warn("Set Basal Profile: Invalid response: commandType={},rawData={}", responseMessage.commandType, ByteUtil.shortHexString(responseMessage.getRawContent())); + aapsLogger.warn(LTag.PUMPCOMM, "Set Basal Profile: Invalid response: commandType={},rawData={}", responseMessage.commandType, ByteUtil.shortHexString(responseMessage.getRawContent())); else - LOG.warn("Set Basal Profile: Null response."); + aapsLogger.warn(LTag.PUMPCOMM, "Set Basal Profile: Null response."); } return false; } - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPCOMM); + @Override public PumpStatus getPumpStatus() { + return medtronicPumpStatus; } - - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicConverter.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicConverter.java index 9fb871c45a..5ad6c51ceb 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicConverter.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicConverter.java @@ -2,14 +2,16 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm; import org.joda.time.IllegalFieldValueException; import org.joda.time.LocalDateTime; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import java.util.HashMap; import java.util.Map; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import javax.inject.Inject; +import javax.inject.Singleton; + +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; +import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.common.utils.StringUtil; import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.BasalProfile; @@ -26,25 +28,30 @@ import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; * High level decoder for data returned through MedtroniUIComm */ +@Singleton public class MedtronicConverter { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + private final AAPSLogger aapsLogger; + private final MedtronicUtil medtronicUtil; - MedtronicDeviceType pumpModel; + @Inject + public MedtronicConverter( + AAPSLogger aapsLogger, + MedtronicUtil medtronicUtil + ) { + this.aapsLogger = aapsLogger; + this.medtronicUtil = medtronicUtil; + } - - public Object convertResponse(MedtronicCommandType commandType, byte[] rawContent) { + Object convertResponse(PumpType pumpType, MedtronicCommandType commandType, byte[] rawContent) { if ((rawContent == null || rawContent.length < 1) && commandType != MedtronicCommandType.PumpModel) { - LOG.warn("Content is empty or too short, no data to convert (type={},isNull={},length={})", + aapsLogger.warn(LTag.PUMPCOMM, "Content is empty or too short, no data to convert (type={},isNull={},length={})", commandType.name(), rawContent == null, rawContent == null ? "-" : rawContent.length); return null; } - if (isLogEnabled()) - LOG.debug("Raw response before convert: " + ByteUtil.shortHexString(rawContent)); - - this.pumpModel = MedtronicUtil.getMedtronicPumpModel(); + aapsLogger.debug(LTag.PUMPCOMM, "Raw response before convert: " + ByteUtil.shortHexString(rawContent)); switch (commandType) { @@ -67,12 +74,12 @@ public class MedtronicConverter { case GetBasalProfileSTD: case GetBasalProfileA: case GetBasalProfileB: { - return decodeBasalProfile(rawContent); + return decodeBasalProfile(pumpType, rawContent); } case ReadTemporaryBasal: { - return new TempBasalPair(rawContent); // 5 + return new TempBasalPair(aapsLogger, rawContent); // 5 } case Settings_512: { @@ -96,29 +103,28 @@ public class MedtronicConverter { } - private BasalProfile decodeBasalProfile(byte[] rawContent) { + private BasalProfile decodeBasalProfile(PumpType pumpType, byte[] rawContent) { - BasalProfile basalProfile = new BasalProfile(rawContent); + BasalProfile basalProfile = new BasalProfile(aapsLogger, rawContent); - return basalProfile.verify() ? basalProfile : null; + return basalProfile.verify(pumpType) ? basalProfile : null; } private MedtronicDeviceType decodeModel(byte[] rawContent) { if ((rawContent == null || rawContent.length < 4)) { - LOG.warn("Error reading PumpModel, returning Unknown_Device"); + aapsLogger.warn(LTag.PUMPCOMM, "Error reading PumpModel, returning Unknown_Device"); return MedtronicDeviceType.Unknown_Device; } String rawModel = StringUtil.fromBytes(ByteUtil.substring(rawContent, 1, 3)); MedtronicDeviceType pumpModel = MedtronicDeviceType.getByDescription(rawModel); - if (isLogEnabled()) - LOG.debug("PumpModel: [raw={}, resolved={}]", rawModel, pumpModel.name()); + aapsLogger.debug(LTag.PUMPCOMM, "PumpModel: [raw={}, resolved={}]", rawModel, pumpModel.name()); if (pumpModel != MedtronicDeviceType.Unknown_Device) { - if (!MedtronicUtil.isModelSet()) { - MedtronicUtil.setMedtronicPumpModel(pumpModel); + if (!medtronicUtil.isModelSet()) { + medtronicUtil.setMedtronicPumpModel(pumpModel); } } @@ -154,10 +160,10 @@ public class MedtronicConverter { } - protected Float decodeRemainingInsulin(byte[] rawData) { + private Float decodeRemainingInsulin(byte[] rawData) { int startIdx = 0; - this.pumpModel = MedtronicUtil.getMedtronicPumpModel(); + MedtronicDeviceType pumpModel = medtronicUtil.getMedtronicPumpModel(); int strokes = pumpModel == null ? 10 : pumpModel.getBolusStrokes(); @@ -167,8 +173,7 @@ public class MedtronicConverter { float value = ByteUtil.toInt(rawData[startIdx], rawData[startIdx + 1]) / (1.0f * strokes); - if (isLogEnabled()) - LOG.debug("Remaining insulin: " + value); + aapsLogger.debug(LTag.PUMPCOMM, "Remaining insulin: " + value); return value; } @@ -185,7 +190,7 @@ public class MedtronicConverter { LocalDateTime pumpTime = new LocalDateTime(year, month, day, hours, minutes, seconds); return pumpTime; } catch (IllegalFieldValueException e) { - LOG.error( + aapsLogger.error(LTag.PUMPCOMM, "decodeTime: Failed to parse pump time value: year=%d, month=%d, hours=%d, minutes=%d, seconds=%d", year, month, day, hours, minutes, seconds); return null; @@ -194,7 +199,7 @@ public class MedtronicConverter { } - public Map decodeSettingsLoop(byte[] rd) { + private Map decodeSettingsLoop(byte[] rd) { Map map = new HashMap<>(); @@ -271,7 +276,7 @@ public class MedtronicConverter { addSettingToMap("CFG_BASE_CLOCK_MODE", rd[getSettingIndexTimeDisplayFormat()] == 0 ? "12h" : "24h", PumpConfigurationGroup.General, map); - if (MedtronicDeviceType.isSameDevice(pumpModel, MedtronicDeviceType.Medtronic_523andHigher)) { + if (MedtronicDeviceType.isSameDevice(medtronicUtil.getMedtronicPumpModel(), MedtronicDeviceType.Medtronic_523andHigher)) { addSettingToMap("PCFG_INSULIN_CONCENTRATION", "" + (rd[9] == 0 ? 50 : 100), PumpConfigurationGroup.Insulin, map); // LOG.debug("Insulin concentration: " + rd[9]); @@ -323,7 +328,7 @@ public class MedtronicConverter { } - public void addSettingToMap(String key, String value, PumpConfigurationGroup group, Map map) { + private void addSettingToMap(String key, String value, PumpConfigurationGroup group, Map map) { map.put(key, new PumpSettingDTO(key, value, group)); } @@ -339,7 +344,7 @@ public class MedtronicConverter { addSettingToMap("CFG_MM_KEYPAD_LOCKED", parseResultEnable(rd[20]), PumpConfigurationGroup.Other, map); - if (MedtronicDeviceType.isSameDevice(pumpModel, MedtronicDeviceType.Medtronic_523andHigher)) { + if (MedtronicDeviceType.isSameDevice(medtronicUtil.getMedtronicPumpModel(), MedtronicDeviceType.Medtronic_523andHigher)) { addSettingToMap("PCFG_BOLUS_SCROLL_STEP_SIZE", "" + rd[21], PumpConfigurationGroup.Bolus, map); addSettingToMap("PCFG_CAPTURE_EVENT_ENABLE", parseResultEnable(rd[22]), PumpConfigurationGroup.Other, map); @@ -352,7 +357,7 @@ public class MedtronicConverter { } - protected String parseResultEnable(int i) { + private String parseResultEnable(int i) { switch (i) { case 0: return "No"; @@ -364,19 +369,19 @@ public class MedtronicConverter { } - public float getStrokesPerUnit(boolean isBasal) { + private float getStrokesPerUnit(boolean isBasal) { return isBasal ? 40.0f : 10; // pumpModel.getBolusStrokes(); } // 512 - public void decodeInsulinActionSetting(byte[] ai, Map map) { - if (MedtronicDeviceType.isSameDevice(pumpModel, MedtronicDeviceType.Medtronic_512_712)) { + private void decodeInsulinActionSetting(byte[] ai, Map map) { + if (MedtronicDeviceType.isSameDevice(medtronicUtil.getMedtronicPumpModel(), MedtronicDeviceType.Medtronic_512_712)) { addSettingToMap("PCFG_INSULIN_ACTION_TYPE", (ai[17] != 0 ? "Regular" : "Fast"), PumpConfigurationGroup.Insulin, map); } else { int i = ai[17]; - String s = ""; + String s; if ((i == 0) || (i == 1)) { s = ai[17] != 0 ? "Regular" : "Fast"; @@ -392,12 +397,12 @@ public class MedtronicConverter { } - public double decodeBasalInsulin(int i) { + private double decodeBasalInsulin(int i) { return (double) i / (double) getStrokesPerUnit(true); } - public double decodeBolusInsulin(int i) { + private double decodeBolusInsulin(int i) { return (double) i / (double) getStrokesPerUnit(false); } @@ -413,19 +418,13 @@ public class MedtronicConverter { } - public double decodeMaxBolus(byte[] ai) { + private double decodeMaxBolus(byte[] ai) { return is523orHigher() ? decodeBolusInsulin(ByteUtil.toInt(ai[5], ai[6])) : decodeBolusInsulin(ByteUtil .asUINT8(ai[5])); } private boolean is523orHigher() { - return (MedtronicDeviceType.isSameDevice(pumpModel, MedtronicDeviceType.Medtronic_523andHigher)); + return (MedtronicDeviceType.isSameDevice(medtronicUtil.getMedtronicPumpModel(), MedtronicDeviceType.Medtronic_523andHigher)); } - - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPCOMM); - } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/MedtronicHistoryDecoder.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/MedtronicHistoryDecoder.java index 4a2fa12a28..450425b26c 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/MedtronicHistoryDecoder.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/MedtronicHistoryDecoder.java @@ -1,32 +1,32 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm.history; import org.apache.commons.lang3.StringUtils; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import javax.inject.Inject; + +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.common.utils.StringUtil; -import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicDeviceType; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; /** * This file was taken from GGC - GNU Gluco Control (ggc.sourceforge.net), application for diabetes * management and modified/extended for AAPS. - * + *

* Author: Andy {andy.rozman@gmail.com} */ public abstract class MedtronicHistoryDecoder implements MedtronicHistoryDecoderInterface { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + @Inject AAPSLogger aapsLogger; + @Inject MedtronicUtil medtronicUtil; protected ByteUtil bitUtils; @@ -34,7 +34,6 @@ public abstract class MedtronicHistoryDecoder i protected boolean statisticsEnabled = true; protected Map unknownOpCodes; protected Map> mapStatistics; - protected MedtronicDeviceType deviceType; public MedtronicHistoryDecoder() { @@ -62,8 +61,8 @@ public abstract class MedtronicHistoryDecoder i // return byteList; // } - if (MedtronicUtil.getMedtronicPumpModel() == null) { - LOG.error("Device Type is not defined."); + if (medtronicUtil.getMedtronicPumpModel() == null) { + aapsLogger.error(LTag.PUMPCOMM, "Device Type is not defined."); return byteList; } @@ -86,17 +85,16 @@ public abstract class MedtronicHistoryDecoder i if (!statisticsEnabled) return; - unknownOpCodes = new HashMap(); - mapStatistics = new HashMap>(); + unknownOpCodes = new HashMap<>(); + mapStatistics = new HashMap<>(); for (RecordDecodeStatus stat : RecordDecodeStatus.values()) { - mapStatistics.put(stat, new HashMap()); + mapStatistics.put(stat, new HashMap<>()); } } - protected void addToStatistics(MedtronicHistoryEntryInterface pumpHistoryEntry, RecordDecodeStatus status, - Integer opCode) { + protected void addToStatistics(MedtronicHistoryEntryInterface pumpHistoryEntry, RecordDecodeStatus status, Integer opCode) { if (!statisticsEnabled) return; @@ -120,11 +118,10 @@ public abstract class MedtronicHistoryDecoder i StringUtil.appendToStringBuilder(sb, "" + unknownEntry.getKey(), ", "); } - if (isLogEnabled()) - LOG.debug("STATISTICS OF PUMP DECODE"); + aapsLogger.error(LTag.PUMPCOMM, "STATISTICS OF PUMP DECODE"); if (unknownOpCodes.size() > 0) { - LOG.warn("Unknown Op Codes: {}", sb.toString()); + aapsLogger.warn(LTag.PUMPCOMM, "Unknown Op Codes: {}", sb.toString()); } for (Map.Entry> entry : mapStatistics.entrySet()) { @@ -140,12 +137,9 @@ public abstract class MedtronicHistoryDecoder i String spaces = StringUtils.repeat(" ", 14 - entry.getKey().name().length()); - if (isLogEnabled()) - LOG.debug(" {}{} - {}. Elements: {}", entry.getKey().name(), spaces, entry.getValue().size(), - sb.toString()); + aapsLogger.error(LTag.PUMPCOMM, " {}{} - {}. Elements: {}", entry.getKey().name(), spaces, entry.getValue().size(), sb.toString()); } else { - if (isLogEnabled()) - LOG.debug(" {} - {}", entry.getKey().name(), entry.getValue().size()); + aapsLogger.error(LTag.PUMPCOMM, " {} - {}", entry.getKey().name(), entry.getValue().size()); } } } @@ -184,9 +178,4 @@ public abstract class MedtronicHistoryDecoder i return records; } - - protected boolean isLogEnabled() { - return L.isEnabled(L.PUMPCOMM); - } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/RawHistoryPage.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/RawHistoryPage.java index 86c463cc0f..3203283e4d 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/RawHistoryPage.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/RawHistoryPage.java @@ -2,11 +2,8 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm.history; import java.util.Arrays; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.common.utils.CRC; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; @@ -16,12 +13,13 @@ import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; */ public class RawHistoryPage { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPBTCOMM); + private final AAPSLogger aapsLogger; private byte[] data = new byte[0]; - public RawHistoryPage() { + public RawHistoryPage(AAPSLogger aapsLogger) { + this.aapsLogger = aapsLogger; } @@ -35,7 +33,7 @@ public class RawHistoryPage { } - public byte[] getOnlyData() { + byte[] getOnlyData() { return Arrays.copyOfRange(data, 0, 1022); } @@ -55,11 +53,11 @@ public class RawHistoryPage { int crcStored = ByteUtil.toInt(data[1022], data[1023]); if (crcCalculated != crcStored) { - LOG.error("Stored CRC ({}) is different than calculated ({}), but ignored for now.", crcStored, - crcCalculated); + aapsLogger.error(LTag.PUMPBTCOMM, "Stored CRC ({}) is different than calculated ({}), but ignored for now.", crcStored, + crcCalculated); } else { if (MedtronicUtil.isLowLevelDebug()) - LOG.debug("CRC ok."); + aapsLogger.debug(LTag.PUMPBTCOMM, "CRC ok."); } return crcCalculated == crcStored; @@ -70,7 +68,7 @@ public class RawHistoryPage { int linesize = 80; int offset = 0; - StringBuffer sb = new StringBuffer(); + StringBuilder sb = new StringBuilder(); while (offset < data.length) { int bytesToLog = linesize; @@ -83,7 +81,6 @@ public class RawHistoryPage { offset += linesize; } - LOG.debug("History Page Data:\n{}", sb.toString()); + aapsLogger.debug(LTag.PUMPBTCOMM, "History Page Data:\n{}", sb.toString()); } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/cgms/MedtronicCGMSHistoryDecoder.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/cgms/MedtronicCGMSHistoryDecoder.java index e2bf3a4935..c3d39954a0 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/cgms/MedtronicCGMSHistoryDecoder.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/cgms/MedtronicCGMSHistoryDecoder.java @@ -17,7 +17,7 @@ import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.RecordDeco /** * This file was taken from GGC - GNU Gluco Control (ggc.sourceforge.net), application for diabetes * management and modified/extended for AAPS. - * + *

* Author: Andy {andy.rozman@gmail.com} */ @@ -209,8 +209,7 @@ public class MedtronicCGMSHistoryDecoder extends MedtronicHistoryDecoder * Author: Andy {andy.rozman@gmail.com} */ +@Singleton public class MedtronicPumpHistoryDecoder extends MedtronicHistoryDecoder { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + private final AAPSLogger aapsLogger; + private final MedtronicUtil medtronicUtil; private PumpHistoryEntry tbrPreviousRecord; private PumpHistoryEntry changeTimeRecord; - private MedtronicDeviceType deviceType; - private static final String TAG = "MdtPumpHistoryDecoder"; - - public MedtronicPumpHistoryDecoder() { + @Inject + public MedtronicPumpHistoryDecoder( + AAPSLogger aapsLogger, + MedtronicUtil medtronicUtil + ) { + this.aapsLogger = aapsLogger; + this.medtronicUtil = medtronicUtil; } @@ -50,15 +53,13 @@ public class MedtronicPumpHistoryDecoder extends MedtronicHistoryDecoder outList = new ArrayList(); + List outList = new ArrayList<>(); String skipped = null; - int elementStart = 0; if (dataClear.size() == 0) { - Log.e(TAG, "Empty page."); + aapsLogger.error(LTag.PUMPBTCOMM, "Empty page."); return outList; } @@ -76,7 +77,7 @@ public class MedtronicPumpHistoryDecoder extends MedtronicHistoryDecoder listRawData = new ArrayList(); + List listRawData = new ArrayList<>(); listRawData.add((byte) opCode); if (entryType == PumpHistoryEntryType.UnabsorbedInsulin - || entryType == PumpHistoryEntryType.UnabsorbedInsulin512) { + || entryType == PumpHistoryEntryType.UnabsorbedInsulin512) { int elements = dataClear.get(counter); listRawData.add((byte) elements); counter++; @@ -105,20 +106,20 @@ public class MedtronicPumpHistoryDecoder extends MedtronicHistoryDecoder 0) { decodeDateTime(entry); @@ -260,7 +261,7 @@ public class MedtronicPumpHistoryDecoder extends MedtronicHistoryDecoder * Author: Andy {andy.rozman@gmail.com} */ @@ -159,8 +158,7 @@ public enum PumpHistoryEntryType // implements CodeEnum TempBasalCombined(0xfe, "TBR", PumpHistoryEntryGroup.Basal), // UnknownBasePacket(0xff, "Unknown Base Packet", PumpHistoryEntryGroup.Unknown); - private static Map opCodeMap = new HashMap(); - private static PumpHistoryEntryType tddType; + private static Map opCodeMap = new HashMap<>(); static { for (PumpHistoryEntryType type : values()) { @@ -172,7 +170,7 @@ public enum PumpHistoryEntryType // implements CodeEnum private int opCode; private String description; - private int headLength = 0; + private int headLength; private int dateLength; // private MinimedDeviceType deviceType; private int bodyLength; @@ -182,8 +180,7 @@ public enum PumpHistoryEntryType // implements CodeEnum private List specialRulesHead; private List specialRulesBody; private boolean hasSpecialRules = false; - private PumpHistoryEntryGroup group = PumpHistoryEntryGroup.Unknown; - private static Object TDDType; + private PumpHistoryEntryGroup group; PumpHistoryEntryType(int opCode, String name, PumpHistoryEntryGroup group) { @@ -289,9 +286,9 @@ public enum PumpHistoryEntryType // implements CodeEnum } - public int getTotalLength() { + public int getTotalLength(MedtronicDeviceType medtronicDeviceType) { if (hasSpecialRules()) { - return getHeadLength() + getBodyLength() + getDateLength(); + return getHeadLength(medtronicDeviceType) + getBodyLength(medtronicDeviceType) + getDateLength(); } else { return totalLength; } @@ -305,7 +302,7 @@ public enum PumpHistoryEntryType // implements CodeEnum void addSpecialRuleHead(SpecialRule rule) { if (isEmpty(specialRulesHead)) { - specialRulesHead = new ArrayList(); + specialRulesHead = new ArrayList<>(); } specialRulesHead.add(rule); @@ -315,7 +312,7 @@ public enum PumpHistoryEntryType // implements CodeEnum void addSpecialRuleBody(SpecialRule rule) { if (isEmpty(specialRulesBody)) { - specialRulesBody = new ArrayList(); + specialRulesBody = new ArrayList<>(); } specialRulesBody.add(rule); @@ -333,10 +330,10 @@ public enum PumpHistoryEntryType // implements CodeEnum } - public int getHeadLength() { + public int getHeadLength(MedtronicDeviceType medtronicDeviceType) { if (hasSpecialRules) { if (isNotEmpty(specialRulesHead)) { - return determineSizeByRule(headLength, specialRulesHead); + return determineSizeByRule(medtronicDeviceType, headLength, specialRulesHead); } else { return headLength; } @@ -351,10 +348,10 @@ public enum PumpHistoryEntryType // implements CodeEnum } - public int getBodyLength() { + public int getBodyLength(MedtronicDeviceType medtronicDeviceType) { if (hasSpecialRules) { if (isNotEmpty(specialRulesBody)) { - return determineSizeByRule(bodyLength, specialRulesBody); + return determineSizeByRule(medtronicDeviceType, bodyLength, specialRulesBody); } else { return bodyLength; } @@ -376,11 +373,11 @@ public enum PumpHistoryEntryType // implements CodeEnum // byte[] dh = { 2, 3 }; - private int determineSizeByRule(int defaultValue, List rules) { + private int determineSizeByRule(MedtronicDeviceType medtronicDeviceType, int defaultValue, List rules) { int size = defaultValue; for (SpecialRule rule : rules) { - if (MedtronicDeviceType.isSameDevice(MedtronicUtil.getMedtronicPumpModel(), rule.deviceType)) { + if (MedtronicDeviceType.isSameDevice(medtronicDeviceType, rule.deviceType)) { size = rule.size; break; } @@ -395,36 +392,13 @@ public enum PumpHistoryEntryType // implements CodeEnum return group; } - enum DateFormat { - None(0), // - LongDate(5), // - ShortDate(2); - - private int length; - - - DateFormat(int length) { - this.length = length; - } - - - public int getLength() { - return length; - } - - - public void setLength(int length) { - this.length = length; - } - } - public static class SpecialRule { MedtronicDeviceType deviceType; int size; - public SpecialRule(MedtronicDeviceType deviceType, int size) { + SpecialRule(MedtronicDeviceType deviceType, int size) { this.deviceType = deviceType; this.size = size; } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/PumpHistoryResult.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/PumpHistoryResult.java index f5ffb13a73..349ac1bf2a 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/PumpHistoryResult.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/PumpHistoryResult.java @@ -1,24 +1,21 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import java.util.ArrayList; import java.util.Collections; import java.util.List; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.utils.DateTimeUtil; /** * History page contains data, sorted from newest to oldest (0=newest..n=oldest) - * + *

* Created by andy on 9/23/18. */ public class PumpHistoryResult { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + private final AAPSLogger aapsLogger; private boolean searchFinished = false; private PumpHistoryEntry searchEntry = null; @@ -28,23 +25,22 @@ public class PumpHistoryResult { public List validEntries; - public PumpHistoryResult(PumpHistoryEntry searchEntry, Long targetDate) { + public PumpHistoryResult(AAPSLogger aapsLogger, PumpHistoryEntry searchEntry, Long targetDate) { + this.aapsLogger = aapsLogger; if (searchEntry != null) { /* * this.searchEntry = searchEntry; * this.searchType = SearchType.LastEntry; - * LOG.debug("PumpHistoryResult. Search parameters: Last Entry: " + searchEntry.atechDateTime + " type=" + * aapsLogger.debug(LTag.PUMPCOMM,"PumpHistoryResult. Search parameters: Last Entry: " + searchEntry.atechDateTime + " type=" * + searchEntry.getEntryType().name()); */ this.searchDate = searchEntry.atechDateTime; this.searchType = SearchType.Date; - if (isLogEnabled()) - LOG.debug("PumpHistoryResult. Search parameters: Date(with searchEntry): " + targetDate); + aapsLogger.debug(LTag.PUMPCOMM, "PumpHistoryResult. Search parameters: Date(with searchEntry): " + targetDate); } else if (targetDate != null) { this.searchDate = targetDate; this.searchType = SearchType.Date; - if (isLogEnabled()) - LOG.debug("PumpHistoryResult. Search parameters: Date: " + targetDate); + aapsLogger.debug(LTag.PUMPCOMM, "PumpHistoryResult. Search parameters: Date: " + targetDate); } // this.unprocessedEntries = new ArrayList<>(); @@ -54,7 +50,7 @@ public class PumpHistoryResult { public void addHistoryEntries(List entries, int page) { this.unprocessedEntries = entries; - //LOG.debug("PumpHistoryResult. Unprocessed entries: {}", MedtronicUtil.getGsonInstance().toJson(entries)); + //aapsLogger.debug(LTag.PUMPCOMM,"PumpHistoryResult. Unprocessed entries: {}", MedtronicUtil.getGsonInstance().toJson(entries)); processEntries(); } @@ -66,47 +62,47 @@ public class PumpHistoryResult { switch (searchType) { case None: - //LOG.debug("PE. None search"); + //aapsLogger.debug(LTag.PUMPCOMM,"PE. None search"); this.validEntries.addAll(this.unprocessedEntries); break; case LastEntry: { - LOG.debug("PE. Last entry search"); + aapsLogger.debug(LTag.PUMPCOMM, "PE. Last entry search"); //Collections.sort(this.unprocessedEntries, new PumpHistoryEntry.Comparator()); - LOG.debug("PE. PumpHistoryResult. Search entry date: " + searchEntry.atechDateTime); + aapsLogger.debug(LTag.PUMPCOMM, "PE. PumpHistoryResult. Search entry date: " + searchEntry.atechDateTime); Long date = searchEntry.atechDateTime; for (PumpHistoryEntry unprocessedEntry : unprocessedEntries) { if (unprocessedEntry.equals(searchEntry)) { - //LOG.debug("PE. Item found {}.", unprocessedEntry); + //aapsLogger.debug(LTag.PUMPCOMM,"PE. Item found {}.", unprocessedEntry); searchFinished = true; break; } - //LOG.debug("PE. Entry {} added.", unprocessedEntry); + //aapsLogger.debug(LTag.PUMPCOMM,"PE. Entry {} added.", unprocessedEntry); this.validEntries.add(unprocessedEntry); } } break; case Date: { - LOG.debug("PE. Date search: Search date: {}", this.searchDate); + aapsLogger.debug(LTag.PUMPCOMM, "PE. Date search: Search date: {}", this.searchDate); for (PumpHistoryEntry unprocessedEntry : unprocessedEntries) { if (unprocessedEntry.atechDateTime == null || unprocessedEntry.atechDateTime == 0) { - LOG.debug("PE. PumpHistoryResult. Search entry date: Entry with no date: {}", unprocessedEntry); + aapsLogger.debug(LTag.PUMPCOMM, "PE. PumpHistoryResult. Search entry date: Entry with no date: {}", unprocessedEntry); continue; } if (unprocessedEntry.isAfter(this.searchDate)) { this.validEntries.add(unprocessedEntry); } else { -// LOG.debug("PE. PumpHistoryResult. Not after.. Unprocessed Entry [year={},entry={}]", +// aapsLogger.debug(LTag.PUMPCOMM,"PE. PumpHistoryResult. Not after.. Unprocessed Entry [year={},entry={}]", // DateTimeUtil.getYear(unprocessedEntry.atechDateTime), unprocessedEntry); if (DateTimeUtil.getYear(unprocessedEntry.atechDateTime) > 2015) olderEntries++; @@ -123,7 +119,7 @@ public class PumpHistoryResult { } // switch - //LOG.debug("PE. Valid Entries: {}", validEntries); + //aapsLogger.debug(LTag.PUMPCOMM,"PE. Valid Entries: {}", validEntries); } @@ -178,11 +174,4 @@ public class PumpHistoryResult { LastEntry, // Date } - - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPCOMM); - } - - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/CarelinkLongMessageBody.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/CarelinkLongMessageBody.java index 67b773999e..7f2c51e032 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/CarelinkLongMessageBody.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/CarelinkLongMessageBody.java @@ -1,19 +1,15 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm.message; -import java.util.List; - -import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; - /** * Created by geoff on 6/2/16. */ public class CarelinkLongMessageBody extends MessageBody { - public static final int LONG_MESSAGE_BODY_LENGTH = 65; + private static final int LONG_MESSAGE_BODY_LENGTH = 65; protected byte[] data; - public CarelinkLongMessageBody() { + CarelinkLongMessageBody() { init(new byte[0]); } @@ -22,12 +18,6 @@ public class CarelinkLongMessageBody extends MessageBody { init(payload); } - - public CarelinkLongMessageBody(List payload) { - init(MedtronicUtil.createByteArray(payload)); - } - - @Override public void init(byte[] rxData) { diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/PacketType.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/PacketType.java index 8d02063d66..03b1ad153c 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/PacketType.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/PacketType.java @@ -25,7 +25,7 @@ public enum PacketType { } } - private byte value = 0; + private byte value; PacketType(int value) { diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/PumpMessage.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/PumpMessage.java index 9d63574748..8c7eb0bcee 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/PumpMessage.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/message/PumpMessage.java @@ -1,10 +1,7 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm.message; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.data.RLMessage; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicCommandType; @@ -14,9 +11,9 @@ import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicCommandTy */ public class PumpMessage implements RLMessage { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + private final AAPSLogger aapsLogger; - public PacketType packetType = PacketType.Carelink; + private PacketType packetType = PacketType.Carelink; public byte[] address = new byte[]{0, 0, 0}; public MedtronicCommandType commandType; public Byte invalidCommandType; @@ -26,18 +23,20 @@ public class PumpMessage implements RLMessage { public static final int FRAME_DATA_LENGTH = 64; - public PumpMessage(String error) { + public PumpMessage(AAPSLogger aapsLogger, String error) { this.error = error; + this.aapsLogger = aapsLogger; } - public PumpMessage(byte[] rxData) { + public PumpMessage(AAPSLogger aapsLogger, byte[] rxData) { init(rxData); + this.aapsLogger = aapsLogger; } - public PumpMessage() { - + public PumpMessage(AAPSLogger aapsLogger) { + this.aapsLogger = aapsLogger; } @@ -67,8 +66,7 @@ public class PumpMessage implements RLMessage { if (rxData.length > 4) { this.commandType = MedtronicCommandType.getByCode(rxData[4]); if (this.commandType == MedtronicCommandType.InvalidCommand) { - if (isLogEnabled()) - LOG.error("PumpMessage - Unknown commandType " + rxData[4]); + aapsLogger.error(LTag.PUMPCOMM, "PumpMessage - Unknown commandType " + rxData[4]); } } if (rxData.length > 5) { @@ -80,7 +78,7 @@ public class PumpMessage implements RLMessage { @Override public byte[] getTxData() { - byte[] rval = ByteUtil.concat(new byte[]{(byte) packetType.getValue()}, address); + byte[] rval = ByteUtil.concat(new byte[]{packetType.getValue()}, address); rval = ByteUtil.concat(rval, commandType.getCommandCode()); rval = ByteUtil.concat(rval, messageBody.getTxData()); return rval; @@ -211,10 +209,4 @@ public class PumpMessage implements RLMessage { return sb.toString(); } - - - private boolean isLogEnabled() { - return L.isEnabled(L.PUMPCOMM); - } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUIComm.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUIComm.java index b4cebbb1cf..f0731d2d8a 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUIComm.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUIComm.java @@ -1,113 +1,58 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm.ui; +import dagger.android.HasAndroidInjector; import info.nightscout.androidaps.logging.AAPSLogger; import info.nightscout.androidaps.logging.LTag; -import info.nightscout.androidaps.plugins.bus.RxBusWrapper; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.medtronic.comm.MedtronicCommunicationManager; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicCommandType; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; -import info.nightscout.androidaps.utils.resources.ResourceHelper; /** * Created by andy on 6/14/18. */ public class MedtronicUIComm { + private final HasAndroidInjector injector; private final AAPSLogger aapsLogger; - - MedtronicCommunicationManager mcmInstance = null; - MedtronicUIPostprocessor uiPostprocessor; + private final MedtronicUtil medtronicUtil; + private final MedtronicCommunicationManager medtronicCommunicationManager; + private final MedtronicUIPostprocessor medtronicUIPostprocessor; public MedtronicUIComm( + HasAndroidInjector injector, AAPSLogger aapsLogger, - RxBusWrapper rxBus, - ResourceHelper resourceHelper + MedtronicUtil medtronicUtil, + MedtronicUIPostprocessor medtronicUIPostprocessor, + MedtronicCommunicationManager medtronicCommunicationManager ) { + this.injector = injector; this.aapsLogger = aapsLogger; - - uiPostprocessor = new MedtronicUIPostprocessor(aapsLogger, rxBus, resourceHelper); + this.medtronicUtil = medtronicUtil; + this.medtronicUIPostprocessor = medtronicUIPostprocessor; + this.medtronicCommunicationManager = medtronicCommunicationManager; } - - private MedtronicCommunicationManager getCommunicationManager() { - if (mcmInstance == null) { - mcmInstance = MedtronicCommunicationManager.getInstance(); - } - - return mcmInstance; - } - - public synchronized MedtronicUITask executeCommand(MedtronicCommandType commandType, Object... parameters) { aapsLogger.warn(LTag.PUMP, "Execute Command: " + commandType.name()); - MedtronicUITask task = new MedtronicUITask(commandType, parameters); + MedtronicUITask task = new MedtronicUITask(injector, commandType, parameters); - MedtronicUtil.setCurrentCommand(commandType); + medtronicUtil.setCurrentCommand(commandType); - // new Thread(() -> { - // LOG.warn("@@@ Start Thread"); - // - // task.execute(getCommunicationManager()); - // - // LOG.warn("@@@ End Thread"); - // }); - - task.execute(getCommunicationManager()); - - // for (int i = 0; i < getMaxWaitTime(commandType); i++) { - // synchronized (task) { - // // try { - // // - // // //task.wait(1000); - // // } catch (InterruptedException e) { - // // LOG.error("executeCommand InterruptedException", e); - // // } - // - // - // SystemClock.sleep(1000); - // } - // - // if (task.isReceived()) { - // break; - // } - // } + task.execute(medtronicCommunicationManager); if (!task.isReceived()) { aapsLogger.warn(LTag.PUMP, "Reply not received for " + commandType); } - task.postProcess(uiPostprocessor); + task.postProcess(medtronicUIPostprocessor); return task; } - - /** - * We return 25s as waitTime (17 for wakeUp, and addtional 8 for data retrieval) for normal commands and - * 120s for History. Real time for returning data would be arround 5s, but lets be sure. - * - * @param commandType - * @return - */ - private int getMaxWaitTime(MedtronicCommandType commandType) { - if (commandType == MedtronicCommandType.GetHistoryData) - return 120; - else - return 25; - } - - public int getInvalidResponsesCount() { - return getCommunicationManager().getNotConnectedCount(); - } - - - public void startTunning() { - RileyLinkUtil.sendBroadcastMessage(RileyLinkConst.IPC.MSG_PUMP_tunePump); + return medtronicCommunicationManager.getNotConnectedCount(); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUIPostprocessor.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUIPostprocessor.java index 0875ffe186..364337d019 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUIPostprocessor.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUIPostprocessor.java @@ -6,9 +6,13 @@ import org.joda.time.Duration; import java.util.Date; import java.util.Map; +import javax.inject.Inject; +import javax.inject.Singleton; + import info.nightscout.androidaps.logging.AAPSLogger; import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.bus.RxBusWrapper; +import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.BasalProfile; import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.BatteryStatusDTO; import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.ClockDTO; @@ -20,34 +24,41 @@ import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpSta import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; import info.nightscout.androidaps.utils.resources.ResourceHelper; -import static info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil.sendNotification; /** * Created by andy on 6/15/18. */ -class MedtronicUIPostprocessor { +@Singleton +public class MedtronicUIPostprocessor { private final AAPSLogger aapsLogger; private final RxBusWrapper rxBus; private final ResourceHelper resourceHelper; + private final MedtronicUtil medtronicUtil; + private final MedtronicPumpStatus medtronicPumpStatus; + private final MedtronicPumpPlugin medtronicPumpPlugin; - - private MedtronicPumpStatus pumpStatus; - - - - public MedtronicUIPostprocessor(AAPSLogger aapsLogger, RxBusWrapper rxBus, ResourceHelper resourceHelper) { + @Inject + public MedtronicUIPostprocessor( + AAPSLogger aapsLogger, + RxBusWrapper rxBus, + ResourceHelper resourceHelper, + MedtronicUtil medtronicUtil, + MedtronicPumpStatus medtronicPumpStatus, + MedtronicPumpPlugin medtronicPumpPlugin) { this.aapsLogger = aapsLogger; this.rxBus = rxBus; this.resourceHelper = resourceHelper; - pumpStatus = MedtronicUtil.getPumpStatus(); + this.medtronicUtil = medtronicUtil; + this.medtronicPumpStatus = medtronicPumpStatus; + this.medtronicPumpPlugin = medtronicPumpPlugin; } // this is mostly intended for command that return certain statuses (Remaining Insulin, ...), and // where responses won't be directly used - public void postProcessData(MedtronicUITask uiTask) { + void postProcessData(MedtronicUITask uiTask) { switch (uiTask.commandType) { @@ -57,7 +68,7 @@ class MedtronicUIPostprocessor { if (response) { BasalProfile basalProfile = (BasalProfile) uiTask.getParameter(0); - pumpStatus.basalsByHour = basalProfile.getProfilesByHour(); + medtronicPumpStatus.basalsByHour = basalProfile.getProfilesByHour(medtronicPumpPlugin.getPumpDescription().pumpType); } } break; @@ -66,11 +77,11 @@ class MedtronicUIPostprocessor { BasalProfile basalProfile = (BasalProfile) uiTask.returnData; try { - Double[] profilesByHour = basalProfile.getProfilesByHour(); + Double[] profilesByHour = basalProfile.getProfilesByHour(medtronicPumpPlugin.getPumpDescription().pumpType); if (profilesByHour != null) { - pumpStatus.basalsByHour = profilesByHour; - pumpStatus.basalProfileStatus = BasalProfileStatus.ProfileOK; + medtronicPumpStatus.basalsByHour = profilesByHour; + medtronicPumpStatus.basalProfileStatus = BasalProfileStatus.ProfileOK; } else { uiTask.responseType = MedtronicUIResponseType.Error; uiTask.errorDescription = "No profile found."; @@ -85,20 +96,20 @@ class MedtronicUIPostprocessor { break; case SetBolus: { - pumpStatus.lastBolusAmount = uiTask.getDoubleFromParameters(0); - pumpStatus.lastBolusTime = new Date(); + medtronicPumpStatus.lastBolusAmount = uiTask.getDoubleFromParameters(0); + medtronicPumpStatus.lastBolusTime = new Date(); } break; case GetRemainingInsulin: { - pumpStatus.reservoirRemainingUnits = (Float) uiTask.returnData; + medtronicPumpStatus.reservoirRemainingUnits = (Float) uiTask.returnData; } break; case CancelTBR: { - pumpStatus.tempBasalStart = null; - pumpStatus.tempBasalAmount = null; - pumpStatus.tempBasalLength = null; + medtronicPumpStatus.tempBasalStart = null; + medtronicPumpStatus.tempBasalAmount = null; + medtronicPumpStatus.tempBasalLength = null; } break; @@ -113,7 +124,7 @@ class MedtronicUIPostprocessor { aapsLogger.debug(LTag.PUMP, "New time was {} set.", response ? "" : "NOT"); if (response) { - MedtronicUtil.getPumpTime().timeDifference = 0; + medtronicUtil.getPumpTime().timeDifference = 0; } } break; @@ -122,10 +133,10 @@ class MedtronicUIPostprocessor { case GetBatteryStatus: { BatteryStatusDTO batteryStatusDTO = (BatteryStatusDTO) uiTask.returnData; - pumpStatus.batteryRemaining = batteryStatusDTO.getCalculatedPercent(pumpStatus.batteryType); + medtronicPumpStatus.batteryRemaining = batteryStatusDTO.getCalculatedPercent(medtronicPumpStatus.batteryType); if (batteryStatusDTO.voltage != null) { - pumpStatus.batteryVoltage = batteryStatusDTO.voltage; + medtronicPumpStatus.batteryVoltage = batteryStatusDTO.voltage; } aapsLogger.debug(LTag.PUMP, "BatteryStatus: {}", batteryStatusDTO.toString()); @@ -134,9 +145,9 @@ class MedtronicUIPostprocessor { break; case PumpModel: { - if (pumpStatus.medtronicDeviceType != MedtronicUtil.getMedtronicPumpModel()) { + if (medtronicPumpStatus.medtronicDeviceType != medtronicUtil.getMedtronicPumpModel()) { aapsLogger.warn(LTag.PUMP, "Configured pump is different then pump detected !"); - sendNotification(MedtronicNotificationType.PumpTypeNotSame, resourceHelper, rxBus); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpTypeNotSame, resourceHelper, rxBus); } } break; @@ -166,7 +177,7 @@ class MedtronicUIPostprocessor { clockDTO.timeDifference = (int) dur.getStandardSeconds(); - MedtronicUtil.setPumpTime(clockDTO); + medtronicUtil.setPumpTime(clockDTO); aapsLogger.debug(LTag.PUMP, "Pump Time: " + clockDTO.localDeviceTime + ", DeviceTime=" + clockDTO.pumpTime + // ", diff: " + dur.getStandardSeconds() + " s"); @@ -190,29 +201,23 @@ class MedtronicUIPostprocessor { Map settings = (Map) uiTask.returnData; - MedtronicUtil.setSettings(settings); + medtronicUtil.setSettings(settings); - PumpSettingDTO checkValue = null; + PumpSettingDTO checkValue; - if (pumpStatus == null) { - aapsLogger.debug(LTag.PUMP, "Pump Status: was null"); - pumpStatus = MedtronicUtil.getPumpStatus(); - aapsLogger.debug(LTag.PUMP, "Pump Status: " + this.pumpStatus); - } - - this.pumpStatus.verifyConfiguration(); + medtronicPumpPlugin.getRileyLinkService().verifyConfiguration(); // check profile if (!"Yes".equals(settings.get("PCFG_BASAL_PROFILES_ENABLED").value)) { aapsLogger.error(LTag.PUMP, "Basal profiles are not enabled on pump."); - sendNotification(MedtronicNotificationType.PumpBasalProfilesNotEnabled, resourceHelper, rxBus); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpBasalProfilesNotEnabled, resourceHelper, rxBus); } else { checkValue = settings.get("PCFG_ACTIVE_BASAL_PROFILE"); if (!"STD".equals(checkValue.value)) { aapsLogger.error("Basal profile set on pump is incorrect (must be STD)."); - sendNotification(MedtronicNotificationType.PumpIncorrectBasalProfileSelected, resourceHelper, rxBus); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpIncorrectBasalProfileSelected, resourceHelper, rxBus); } } @@ -222,23 +227,23 @@ class MedtronicUIPostprocessor { if (!"Units".equals(checkValue.value)) { aapsLogger.error("Wrong TBR type set on pump (must be Absolute)."); - sendNotification(MedtronicNotificationType.PumpWrongTBRTypeSet, resourceHelper, rxBus); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpWrongTBRTypeSet, resourceHelper, rxBus); } // MAXes checkValue = settings.get("PCFG_MAX_BOLUS"); - if (!MedtronicUtil.isSame(Double.parseDouble(checkValue.value), pumpStatus.maxBolus)) { - aapsLogger.error("Wrong Max Bolus set on Pump (current={}, required={}).", checkValue.value, pumpStatus.maxBolus); - sendNotification(MedtronicNotificationType.PumpWrongMaxBolusSet, resourceHelper, rxBus, pumpStatus.maxBolus); + if (!medtronicUtil.isSame(Double.parseDouble(checkValue.value), medtronicPumpStatus.maxBolus)) { + aapsLogger.error("Wrong Max Bolus set on Pump (current={}, required={}).", checkValue.value, medtronicPumpStatus.maxBolus); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpWrongMaxBolusSet, resourceHelper, rxBus, medtronicPumpStatus.maxBolus); } checkValue = settings.get("PCFG_MAX_BASAL"); - if (!MedtronicUtil.isSame(Double.parseDouble(checkValue.value), pumpStatus.maxBasal)) { - aapsLogger.error("Wrong Max Basal set on Pump (current={}, required={}).", checkValue.value, pumpStatus.maxBasal); - sendNotification(MedtronicNotificationType.PumpWrongMaxBasalSet, resourceHelper, rxBus, pumpStatus.maxBasal); + if (!medtronicUtil.isSame(Double.parseDouble(checkValue.value), medtronicPumpStatus.maxBasal)) { + aapsLogger.error("Wrong Max Basal set on Pump (current={}, required={}).", checkValue.value, medtronicPumpStatus.maxBasal); + medtronicUtil.sendNotification(MedtronicNotificationType.PumpWrongMaxBasalSet, resourceHelper, rxBus, medtronicPumpStatus.maxBasal); } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUITask.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUITask.java index 0a52785e40..51a8020fcd 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUITask.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/ui/MedtronicUITask.java @@ -1,13 +1,13 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm.ui; import org.joda.time.LocalDateTime; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; -import info.nightscout.androidaps.MainApp; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; -import info.nightscout.androidaps.plugins.bus.RxBus; +import javax.inject.Inject; + +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; +import info.nightscout.androidaps.plugins.bus.RxBusWrapper; import info.nightscout.androidaps.plugins.pump.medtronic.comm.MedtronicCommunicationManager; import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump.PumpHistoryEntry; import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.BasalProfile; @@ -15,6 +15,7 @@ import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.TempBasalPair; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicCommandType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicUIResponseType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; +import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpStatus; import info.nightscout.androidaps.plugins.pump.medtronic.events.EventMedtronicDeviceStatusChange; import info.nightscout.androidaps.plugins.pump.medtronic.events.EventMedtronicPumpValuesChanged; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; @@ -25,7 +26,12 @@ import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; public class MedtronicUITask { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMP); + @Inject RxBusWrapper rxBus; + @Inject AAPSLogger aapsLogger; + @Inject MedtronicPumpStatus medtronicPumpStatus; + @Inject MedtronicUtil medtronicUtil; + + private final HasAndroidInjector injector; public MedtronicCommandType commandType; public Object returnData; @@ -36,12 +42,16 @@ public class MedtronicUITask { MedtronicUIResponseType responseType; - public MedtronicUITask(MedtronicCommandType commandType) { + public MedtronicUITask(HasAndroidInjector injector, MedtronicCommandType commandType) { + this.injector = injector; + this.injector.androidInjector().inject(this); this.commandType = commandType; } - public MedtronicUITask(MedtronicCommandType commandType, Object... parameters) { + public MedtronicUITask(HasAndroidInjector injector, MedtronicCommandType commandType, Object... parameters) { + this.injector = injector; + this.injector.androidInjector().inject(this); this.commandType = commandType; this.parameters = parameters; } @@ -49,8 +59,7 @@ public class MedtronicUITask { public void execute(MedtronicCommunicationManager communicationManager) { - if (isLogEnabled()) - LOG.debug("MedtronicUITask: @@@ In execute. {}", commandType); + aapsLogger.debug(LTag.PUMP, "MedtronicUITask: @@@ In execute. {}", commandType); switch (commandType) { case PumpModel: { @@ -70,7 +79,7 @@ public class MedtronicUITask { case GetRealTimeClock: { returnData = communicationManager.getPumpTime(); - MedtronicUtil.setPumpTime(null); + medtronicUtil.setPumpTime(null); } break; @@ -132,7 +141,7 @@ public class MedtronicUITask { break; default: { - LOG.warn("This commandType is not supported (yet) - {}.", commandType); + aapsLogger.warn(LTag.PUMP, "This commandType is not supported (yet) - {}.", commandType); // invalid = true; responseType = MedtronicUIResponseType.Invalid; } @@ -163,12 +172,12 @@ public class MedtronicUITask { } - public Double getDoubleFromParameters(int index) { + Double getDoubleFromParameters(int index) { return (Double) parameters[index]; } - public Integer getIntegerFromParameters(int index) { + private Integer getIntegerFromParameters(int index) { return (Integer) parameters[index]; } @@ -185,25 +194,24 @@ public class MedtronicUITask { void postProcess(MedtronicUIPostprocessor postprocessor) { - if (isLogEnabled()) - LOG.debug("MedtronicUITask: @@@ In execute. {}", commandType); + aapsLogger.debug(LTag.PUMP, "MedtronicUITask: @@@ In execute. {}", commandType); if (responseType == MedtronicUIResponseType.Data) { postprocessor.postProcessData(this); } if (responseType == MedtronicUIResponseType.Invalid) { - RxBus.Companion.getINSTANCE().send(new EventMedtronicDeviceStatusChange(PumpDeviceState.ErrorWhenCommunicating, + rxBus.send(new EventMedtronicDeviceStatusChange(PumpDeviceState.ErrorWhenCommunicating, "Unsupported command in MedtronicUITask")); } else if (responseType == MedtronicUIResponseType.Error) { - RxBus.Companion.getINSTANCE().send(new EventMedtronicDeviceStatusChange(PumpDeviceState.ErrorWhenCommunicating, + rxBus.send(new EventMedtronicDeviceStatusChange(PumpDeviceState.ErrorWhenCommunicating, errorDescription)); } else { - RxBus.Companion.getINSTANCE().send(new EventMedtronicPumpValuesChanged()); - MedtronicUtil.getPumpStatus().setLastCommunicationToNow(); + rxBus.send(new EventMedtronicPumpValuesChanged()); + medtronicPumpStatus.setLastCommunicationToNow(); } - MedtronicUtil.setCurrentCommand(null); + medtronicUtil.setCurrentCommand(null); } @@ -212,16 +220,11 @@ public class MedtronicUITask { } - public Object getParameter(int index) { + Object getParameter(int index) { return parameters[index]; } - private boolean isLogEnabled() { - return L.isEnabled(L.PUMP); - } - - public MedtronicUIResponseType getResponseType() { return this.responseType; } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/MedtronicHistoryData.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/MedtronicHistoryData.java index ac07c9a337..cfa3fdcc51 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/MedtronicHistoryData.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/MedtronicHistoryData.java @@ -18,10 +18,12 @@ import java.util.List; import java.util.Locale; import java.util.Map; +import javax.inject.Inject; +import javax.inject.Singleton; + import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.data.DetailedBolusInfo; import info.nightscout.androidaps.db.CareportalEvent; -import info.nightscout.androidaps.db.DatabaseHelper; import info.nightscout.androidaps.db.DbObjectBase; import info.nightscout.androidaps.db.ExtendedBolus; import info.nightscout.androidaps.db.Source; @@ -31,6 +33,7 @@ import info.nightscout.androidaps.interfaces.ActivePluginProvider; import info.nightscout.androidaps.logging.AAPSLogger; import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.general.nsclient.NSUpload; +import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.utils.DateTimeUtil; import info.nightscout.androidaps.plugins.pump.common.utils.StringUtil; @@ -67,22 +70,23 @@ import info.nightscout.androidaps.utils.sharedPreferences.SP; // All things marked with "TODO: Fix db code" needs to be updated in new 2.5 database code +@Singleton public class MedtronicHistoryData { - private static AAPSLogger aapsLogger; - private SP sp; - private ActivePluginProvider activePlugin; + private final AAPSLogger aapsLogger; + private final SP sp; + private final ActivePluginProvider activePlugin; + private final MedtronicUtil medtronicUtil; + private final MedtronicPumpHistoryDecoder medtronicPumpHistoryDecoder; - private List allHistory = null; + private List allHistory; private List newHistory = null; - private Long lastHistoryRecordTime; private boolean isInit = false; - private Gson gson; - private Gson gsonCore; + private Gson gson; // cannot be initialized in constructor because of injection + private Gson gsonCore; // cannot be initialized in constructor because of injection - private DatabaseHelper databaseHelper = MainApp.getDbHelper(); private ClockDTO pumpTime; private long lastIdUsed = 0; @@ -94,25 +98,32 @@ public class MedtronicHistoryData { */ public static boolean doubleBolusDebug = false; - - public MedtronicHistoryData(AAPSLogger aapsLogger, SP sp, ActivePluginProvider activePlugin) { + @Inject + public MedtronicHistoryData( + AAPSLogger aapsLogger, + SP sp, + ActivePluginProvider activePlugin, + MedtronicUtil medtronicUtil, + MedtronicPumpHistoryDecoder medtronicPumpHistoryDecoder + ) { this.allHistory = new ArrayList<>(); - this.gson = MedtronicUtil.gsonInstance; - this.gsonCore = MedtronicUtil.getGsonInstanceCore(); this.aapsLogger = aapsLogger; this.sp = sp; this.activePlugin = activePlugin; - - if (this.gson == null) { - this.gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create(); - } - - if (this.gsonCore == null) { - this.gsonCore = new GsonBuilder().create(); - } + this.medtronicUtil = medtronicUtil; + this.medtronicPumpHistoryDecoder = medtronicPumpHistoryDecoder; } + private Gson gson() { + if (gson == null) gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create(); + return gson; + } + + private Gson gsonCore() { + if (gsonCore == null) gsonCore = new GsonBuilder().create(); + return gsonCore; + } /** * Add New History entries @@ -134,11 +145,11 @@ public class MedtronicHistoryData { this.newHistory = newEntries; - showLogs("List of history (before filtering): [" + this.newHistory.size() + "]", gson.toJson(this.newHistory)); + showLogs("List of history (before filtering): [" + this.newHistory.size() + "]", gson().toJson(this.newHistory)); } - private static void showLogs(String header, String data) { + private void showLogs(String header, String data) { if (header != null) { aapsLogger.debug(LTag.PUMP, header); } @@ -208,7 +219,7 @@ public class MedtronicHistoryData { aapsLogger.debug(LTag.PUMP, "New History entries found: {}", this.newHistory.size()); - showLogs("List of history (after filtering): [" + this.newHistory.size() + "]", gson.toJson(this.newHistory)); + showLogs("List of history (after filtering): [" + this.newHistory.size() + "]", gson().toJson(this.newHistory)); } @@ -321,7 +332,7 @@ public class MedtronicHistoryData { List items = getDataForPumpSuspends(); - showLogs("isPumpSuspended: ", MedtronicUtil.gsonInstance.toJson(items)); + showLogs("isPumpSuspended: ", gson().toJson(items)); if (isCollectionNotEmpty(items)) { @@ -407,7 +418,7 @@ public class MedtronicHistoryData { // Prime (for reseting autosense) List primeRecords = getFilteredItems(PumpHistoryEntryType.Prime); - aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: Prime [count={}, items={}]", primeRecords.size(), gson.toJson(primeRecords)); + aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: Prime [count={}, items={}]", primeRecords.size(), gson().toJson(primeRecords)); if (isCollectionNotEmpty(primeRecords)) { try { @@ -421,7 +432,7 @@ public class MedtronicHistoryData { // TDD List tdds = getFilteredItems(PumpHistoryEntryType.EndResultTotals, getTDDType()); - aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: TDD [count={}, items={}]", tdds.size(), gson.toJson(tdds)); + aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: TDD [count={}, items={}]", tdds.size(), gson().toJson(tdds)); if (isCollectionNotEmpty(tdds)) { try { @@ -432,12 +443,12 @@ public class MedtronicHistoryData { } } - pumpTime = MedtronicUtil.getPumpTime(); + pumpTime = medtronicUtil.getPumpTime(); // Bolus List treatments = getFilteredItems(PumpHistoryEntryType.Bolus); - aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: Bolus [count={}, items={}]", treatments.size(), gson.toJson(treatments)); + aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: Bolus [count={}, items={}]", treatments.size(), gson().toJson(treatments)); if (treatments.size() > 0) { try { @@ -451,7 +462,7 @@ public class MedtronicHistoryData { // TBR List tbrs = getFilteredItems(PumpHistoryEntryType.TempBasalCombined); - aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: TBRs Processed [count={}, items={}]", tbrs.size(), gson.toJson(tbrs)); + aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: TBRs Processed [count={}, items={}]", tbrs.size(), gson().toJson(tbrs)); if (tbrs.size() > 0) { try { @@ -463,7 +474,7 @@ public class MedtronicHistoryData { } // 'Delivery Suspend' - List suspends = null; + List suspends; try { suspends = getSuspends(); @@ -473,7 +484,7 @@ public class MedtronicHistoryData { } aapsLogger.debug(LTag.PUMP, "ProcessHistoryData: 'Delivery Suspend' Processed [count={}, items={}]", suspends.size(), - gson.toJson(suspends)); + gson().toJson(suspends)); if (isCollectionNotEmpty(suspends)) { try { @@ -539,9 +550,9 @@ public class MedtronicHistoryData { List tdds = filterTDDs(tddsIn); - aapsLogger.debug(LTag.PUMP, getLogPrefix() + "TDDs found: {}.\n{}", tdds.size(), gson.toJson(tdds)); + aapsLogger.debug(LTag.PUMP, getLogPrefix() + "TDDs found: {}.\n{}", tdds.size(), gson().toJson(tdds)); - List tddsDb = databaseHelper.getTDDsForLastXDays(3); + List tddsDb = MainApp.getDbHelper().getTDDsForLastXDays(3); for (PumpHistoryEntry tdd : tdds) { @@ -557,7 +568,7 @@ public class MedtronicHistoryData { aapsLogger.debug(LTag.PUMP, "TDD Add: {}", tddNew); - databaseHelper.createOrUpdateTDD(tddNew); + MainApp.getDbHelper().createOrUpdateTDD(tddNew); } else { @@ -566,7 +577,7 @@ public class MedtronicHistoryData { aapsLogger.debug(LTag.PUMP, "TDD Edit: {}", tddDbEntry); - databaseHelper.createOrUpdateTDD(tddDbEntry); + MainApp.getDbHelper().createOrUpdateTDD(tddDbEntry); } } } @@ -595,13 +606,11 @@ public class MedtronicHistoryData { long oldestTimestamp = getOldestTimestamp(entryList); - Gson gson = MedtronicUtil.getGsonInstance(); - List entriesFromHistory = getDatabaseEntriesByLastTimestamp(oldestTimestamp, ProcessHistoryRecord.Bolus); if (doubleBolusDebug) - aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: List (before filter): {}, FromDb={}", gson.toJson(entryList), - gsonCore.toJson(entriesFromHistory)); + aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: List (before filter): {}, FromDb={}", gson().toJson(entryList), + gsonCore().toJson(entriesFromHistory)); filterOutAlreadyAddedEntries(entryList, entriesFromHistory); @@ -614,8 +623,8 @@ public class MedtronicHistoryData { filterOutNonInsulinEntries(entriesFromHistory); if (doubleBolusDebug) - aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: List (after filter): {}, FromDb={}", gson.toJson(entryList), - gsonCore.toJson(entriesFromHistory)); + aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: List (after filter): {}, FromDb={}", gson().toJson(entryList), + gsonCore().toJson(entriesFromHistory)); if (isCollectionEmpty(entriesFromHistory)) { for (PumpHistoryEntry treatment : entryList) { @@ -678,8 +687,8 @@ public class MedtronicHistoryData { List entriesFromHistory = getDatabaseEntriesByLastTimestamp(oldestTimestamp, ProcessHistoryRecord.TBR); - aapsLogger.debug(LTag.PUMP, ProcessHistoryRecord.TBR.getDescription() + " List (before filter): {}, FromDb={}", gson.toJson(entryList), - gson.toJson(entriesFromHistory)); + aapsLogger.debug(LTag.PUMP, ProcessHistoryRecord.TBR.getDescription() + " List (before filter): {}, FromDb={}", gson().toJson(entryList), + gson().toJson(entriesFromHistory)); TempBasalProcessDTO processDTO = null; @@ -729,7 +738,7 @@ public class MedtronicHistoryData { tempBasal.durationInMinutes = tempBasalProcessDTO.getDuration(); - databaseHelper.createOrUpdate(tempBasal); + MainApp.getDbHelper().createOrUpdate(tempBasal); aapsLogger.debug(LTag.PUMP, "Edit " + ProcessHistoryRecord.TBR.getDescription() + " - (entryFromDb={}) ", tempBasal); } else { @@ -777,7 +786,7 @@ public class MedtronicHistoryData { } } - TemporaryBasal tempBasal = databaseHelper.findTempBasalByPumpId(pumpId); + TemporaryBasal tempBasal = MainApp.getDbHelper().findTempBasalByPumpId(pumpId); return tempBasal; } @@ -798,7 +807,7 @@ public class MedtronicHistoryData { //proposedTime += (this.pumpTime.timeDifference * 1000); if (doubleBolusDebug) - aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: findDbEntry Treatment={}, FromDb={}", treatment, gson.toJson(entriesFromHistory)); + aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: findDbEntry Treatment={}, FromDb={}", treatment, gson().toJson(entriesFromHistory)); if (entriesFromHistory.size() == 0) { if (doubleBolusDebug) @@ -852,10 +861,10 @@ public class MedtronicHistoryData { if (min == 0 && sec == 10 && outList.size() > 1) { aapsLogger.error("Too many entries (with too small diff): (timeDiff=[min={},sec={}],count={},list={})", - min, sec, outList.size(), gson.toJson(outList)); + min, sec, outList.size(), gson().toJson(outList)); if (doubleBolusDebug) aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: findDbEntry Error - Too many entries (with too small diff): (timeDiff=[min={},sec={}],count={},list={})", - min, sec, outList.size(), gson.toJson(outList)); + min, sec, outList.size(), gson().toJson(outList)); } } } @@ -868,7 +877,7 @@ public class MedtronicHistoryData { if (processHistoryRecord == ProcessHistoryRecord.Bolus) { return activePlugin.getActiveTreatments().getTreatmentsFromHistoryAfterTimestamp(startTimestamp); } else { - return databaseHelper.getTemporaryBasalsDataFromTime(startTimestamp, true); + return MainApp.getDbHelper().getTemporaryBasalsDataFromTime(startTimestamp, true); } } @@ -905,8 +914,8 @@ public class MedtronicHistoryData { if (doubleBolusDebug) aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: filterOutAlreadyAddedEntries: PumpHistory={}, Treatments={}", - gson.toJson(removeTreatmentsFromPH), - gsonCore.toJson(removeTreatmentsFromHistory)); + gson().toJson(removeTreatmentsFromPH), + gsonCore().toJson(removeTreatmentsFromHistory)); treatmentsFromHistory.removeAll(removeTreatmentsFromHistory); } @@ -976,7 +985,7 @@ public class MedtronicHistoryData { treatment.pumpId = bolus.getPumpId(); treatment.insulin = bolusDTO.getDeliveredAmount(); - TreatmentService.UpdateReturn updateReturn = ((TreatmentsPlugin)activePlugin.getActiveTreatments()).getService().createOrUpdateMedtronic(treatment, false); + TreatmentService.UpdateReturn updateReturn = ((TreatmentsPlugin) activePlugin.getActiveTreatments()).getService().createOrUpdateMedtronic(treatment, false); if (doubleBolusDebug) aapsLogger.debug(LTag.PUMP, "DoubleBolusDebug: addBolus(tretament!=null): NewTreatment={}, UpdateReturn={}", treatment, updateReturn); @@ -1026,7 +1035,7 @@ public class MedtronicHistoryData { treatment.setLinkedObject(temporaryBasalDb); - databaseHelper.createOrUpdate(temporaryBasalDb); + MainApp.getDbHelper().createOrUpdate(temporaryBasalDb); aapsLogger.debug(LTag.PUMP, operation + " - [date={},pumpId={}, rate={} {}, duration={}]", // temporaryBasalDb.date, // @@ -1042,7 +1051,7 @@ public class MedtronicHistoryData { for (TempBasalProcessDTO tempBasalProcess : tempBasalProcessList) { - TemporaryBasal tempBasal = databaseHelper.findTempBasalByPumpId(tempBasalProcess.itemOne.getPumpId()); + TemporaryBasal tempBasal = MainApp.getDbHelper().findTempBasalByPumpId(tempBasalProcess.itemOne.getPumpId()); if (tempBasal == null) { // add @@ -1058,7 +1067,7 @@ public class MedtronicHistoryData { tempBasalProcess.itemOne.setLinkedObject(tempBasal); tempBasalProcess.itemTwo.setLinkedObject(tempBasal); - databaseHelper.createOrUpdate(tempBasal); + MainApp.getDbHelper().createOrUpdate(tempBasal); } } @@ -1205,11 +1214,11 @@ public class MedtronicHistoryData { if (!finishedItems) { - showLogs("NoDeliveryRewindPrimeRecords: Not finished Items: ", gson.toJson(tempData)); + showLogs("NoDeliveryRewindPrimeRecords: Not finished Items: ", gson().toJson(tempData)); return outList; } - showLogs("NoDeliveryRewindPrimeRecords: Records to evaluate: ", gson.toJson(tempData)); + showLogs("NoDeliveryRewindPrimeRecords: Records to evaluate: ", gson().toJson(tempData)); List items = getFilteredItems(tempData, // PumpHistoryEntryType.Prime @@ -1305,7 +1314,7 @@ public class MedtronicHistoryData { } } - LocalDateTime oldestEntryTime = null; + LocalDateTime oldestEntryTime; try { @@ -1370,11 +1379,11 @@ public class MedtronicHistoryData { private PumpHistoryEntryType getTDDType() { - if (MedtronicUtil.getMedtronicPumpModel() == null) { + if (medtronicUtil.getMedtronicPumpModel() == null) { return PumpHistoryEntryType.EndResultTotals; } - switch (MedtronicUtil.getMedtronicPumpModel()) { + switch (medtronicUtil.getMedtronicPumpModel()) { case Medtronic_515: case Medtronic_715: @@ -1401,13 +1410,13 @@ public class MedtronicHistoryData { List filteredItems = getFilteredItems(PumpHistoryEntryType.ChangeBasalProfile_NewProfile); - aapsLogger.debug(LTag.PUMP, "hasBasalProfileChanged. Items: " + gson.toJson(filteredItems)); + aapsLogger.debug(LTag.PUMP, "hasBasalProfileChanged. Items: " + gson().toJson(filteredItems)); return (filteredItems.size() > 0); } - public void processLastBasalProfileChange(MedtronicPumpStatus mdtPumpStatus) { + public void processLastBasalProfileChange(PumpType pumpType, MedtronicPumpStatus mdtPumpStatus) { List filteredItems = getFilteredItems(PumpHistoryEntryType.ChangeBasalProfile_NewProfile); @@ -1433,7 +1442,7 @@ public class MedtronicHistoryData { aapsLogger.debug(LTag.PUMP, "processLastBasalProfileChange. item found, setting new basalProfileLocally: " + newProfile); BasalProfile basalProfile = (BasalProfile) newProfile.getDecodedData().get("Object"); - mdtPumpStatus.basalsByHour = basalProfile.getProfilesByHour(); + mdtPumpStatus.basalsByHour = basalProfile.getProfilesByHour(pumpType); } } @@ -1447,7 +1456,6 @@ public class MedtronicHistoryData { public void setLastHistoryRecordTime(Long lastHistoryRecordTime) { // this.previousLastHistoryRecordTime = this.lastHistoryRecordTime; - this.lastHistoryRecordTime = lastHistoryRecordTime; } @@ -1470,8 +1478,8 @@ public class MedtronicHistoryData { for (PumpHistoryEntry pumpHistoryEntry : TBRs_Input) { if (map.containsKey(pumpHistoryEntry.DT)) { - MedtronicPumpHistoryDecoder.decodeTempBasal(map.get(pumpHistoryEntry.DT), pumpHistoryEntry); - pumpHistoryEntry.setEntryType(PumpHistoryEntryType.TempBasalCombined); + medtronicPumpHistoryDecoder.decodeTempBasal(map.get(pumpHistoryEntry.DT), pumpHistoryEntry); + pumpHistoryEntry.setEntryType(medtronicUtil.getMedtronicPumpModel(), PumpHistoryEntryType.TempBasalCombined); TBRs.add(pumpHistoryEntry); map.remove(pumpHistoryEntry.DT); } else { diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfile.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfile.java index 9956e9103e..475066cb6c 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfile.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfile.java @@ -3,14 +3,13 @@ package info.nightscout.androidaps.plugins.pump.medtronic.data.dto; import com.google.gson.annotations.Expose; import org.joda.time.Instant; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import java.util.ArrayList; import java.util.List; +import info.nightscout.androidaps.logging.AAPSLogger; import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; @@ -32,7 +31,7 @@ import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; */ public class BasalProfile { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); + private final AAPSLogger aapsLogger; public static final int MAX_RAW_DATA_SIZE = (48 * 3) + 1; private static final boolean DEBUG_BASALPROFILE = false; @@ -41,18 +40,20 @@ public class BasalProfile { private List listEntries; - public BasalProfile() { + public BasalProfile(AAPSLogger aapsLogger) { + this.aapsLogger = aapsLogger; init(); } - public BasalProfile(byte[] data) { + public BasalProfile(AAPSLogger aapsLogger, byte[] data) { + this .aapsLogger = aapsLogger; setRawData(data); } // this asUINT8 should be combined with Record.asUINT8, and placed in a new util class. - protected static int readUnsignedByte(byte b) { + private static int readUnsignedByte(byte b) { return (b < 0) ? b + 256 : b; } @@ -65,9 +66,9 @@ public class BasalProfile { } - public boolean setRawData(byte[] data) { + private boolean setRawData(byte[] data) { if (data == null) { - LOG.error("setRawData: buffer is null!"); + aapsLogger.error(LTag.PUMPCOMM,"setRawData: buffer is null!"); return false; } @@ -90,7 +91,7 @@ public class BasalProfile { public boolean setRawDataFromHistory(byte[] data) { if (data == null) { - LOG.error("setRawData: buffer is null!"); + aapsLogger.error(LTag.PUMPCOMM,"setRawData: buffer is null!"); return false; } @@ -115,13 +116,13 @@ public class BasalProfile { public void dumpBasalProfile() { - LOG.debug("Basal Profile entries:"); + aapsLogger.debug(LTag.PUMPCOMM,"Basal Profile entries:"); List entries = getEntries(); for (int i = 0; i < entries.size(); i++) { BasalProfileEntry entry = entries.get(i); String startString = entry.startTime.toString("HH:mm"); // this doesn't work - LOG.debug(String.format("Entry %d, rate=%.3f (0x%02X), start=%s (0x%02X)", i + 1, entry.rate, + aapsLogger.debug(LTag.PUMPCOMM,String.format("Entry %d, rate=%.3f (0x%02X), start=%s (0x%02X)", i + 1, entry.rate, entry.rate_raw, startString, entry.startTime_raw)); } @@ -168,14 +169,14 @@ public class BasalProfile { BasalProfileEntry rval = new BasalProfileEntry(); List entries = getEntries(); if (entries.size() == 0) { - LOG.warn(String.format("getEntryForTime(%s): table is empty", + aapsLogger.warn(LTag.PUMPCOMM,String.format("getEntryForTime(%s): table is empty", when.toDateTime().toLocalTime().toString("HH:mm"))); return rval; } // Log.w(TAG,"Assuming first entry"); rval = entries.get(0); if (entries.size() == 1) { - LOG.debug("getEntryForTime: Only one entry in profile"); + aapsLogger.debug(LTag.PUMPCOMM,"getEntryForTime: Only one entry in profile"); return rval; } @@ -185,17 +186,17 @@ public class BasalProfile { while (!done) { BasalProfileEntry entry = entries.get(i); if (DEBUG_BASALPROFILE) { - LOG.debug(String.format("Comparing 'now'=%s to entry 'start time'=%s", when.toDateTime().toLocalTime() + aapsLogger.debug(LTag.PUMPCOMM,String.format("Comparing 'now'=%s to entry 'start time'=%s", when.toDateTime().toLocalTime() .toString("HH:mm"), entry.startTime.toString("HH:mm"))); } if (localMillis >= entry.startTime.getMillisOfDay()) { rval = entry; if (DEBUG_BASALPROFILE) - LOG.debug("Accepted Entry"); + aapsLogger.debug(LTag.PUMPCOMM,"Accepted Entry"); } else { // entry at i has later start time, keep older entry if (DEBUG_BASALPROFILE) - LOG.debug("Rejected Entry"); + aapsLogger.debug(LTag.PUMPCOMM,"Rejected Entry"); done = true; } i++; @@ -204,7 +205,7 @@ public class BasalProfile { } } if (DEBUG_BASALPROFILE) { - LOG.debug(String.format("getEntryForTime(%s): Returning entry: rate=%.3f (%d), start=%s (%d)", when + aapsLogger.debug(LTag.PUMPCOMM,String.format("getEntryForTime(%s): Returning entry: rate=%.3f (%d), start=%s (%d)", when .toDateTime().toLocalTime().toString("HH:mm"), rval.rate, rval.rate_raw, rval.startTime.toString("HH:mm"), rval.startTime_raw)); } @@ -216,7 +217,7 @@ public class BasalProfile { List entries = new ArrayList<>(); if (mRawData == null || mRawData[2] == 0x3f) { - LOG.warn("Raw Data is empty."); + aapsLogger.warn(LTag.PUMPCOMM,"Raw Data is empty."); return entries; // an empty list } boolean done = false; @@ -234,9 +235,9 @@ public class BasalProfile { st = readUnsignedByte(mRawData[i + 2]); try { - entries.add(new BasalProfileEntry(r, st)); + entries.add(new BasalProfileEntry(aapsLogger, r, st)); } catch (Exception ex) { - LOG.error("Error decoding basal profile from bytes: {}", ByteUtil.shortHexString(mRawData)); + aapsLogger.error(LTag.PUMPCOMM,"Error decoding basal profile from bytes: {}", ByteUtil.shortHexString(mRawData)); throw ex; } @@ -278,17 +279,17 @@ public class BasalProfile { } - public Double[] getProfilesByHour() { + public Double[] getProfilesByHour(PumpType pumpType) { List entries = null; try { entries = getEntries(); } catch (Exception ex) { - LOG.error("============================================================================="); - LOG.error(" Error generating entries. Ex.: " + ex, ex); - LOG.error(" rawBasalValues: " + ByteUtil.shortHexString(this.getRawData())); - LOG.error("============================================================================="); + aapsLogger.error(LTag.PUMPCOMM,"============================================================================="); + aapsLogger.error(LTag.PUMPCOMM," Error generating entries. Ex.: " + ex, ex); + aapsLogger.error(LTag.PUMPCOMM," rawBasalValues: " + ByteUtil.shortHexString(this.getRawData())); + aapsLogger.error(LTag.PUMPCOMM,"============================================================================="); //FabricUtil.createEvent("MedtronicBasalProfileGetByHourError", null); } @@ -305,8 +306,6 @@ public class BasalProfile { Double[] basalByHour = new Double[24]; - PumpType pumpType = MedtronicUtil.getPumpStatus().pumpType; - for (int i = 0; i < entries.size(); i++) { BasalProfileEntry current = entries.get(i); @@ -368,7 +367,7 @@ public class BasalProfile { return L.isEnabled(L.PUMPCOMM); } - public boolean verify() { + public boolean verify(PumpType pumpType) { try { getEntries(); @@ -376,7 +375,7 @@ public class BasalProfile { return false; } - Double[] profilesByHour = getProfilesByHour(); + Double[] profilesByHour = getProfilesByHour(pumpType); for (Double aDouble : profilesByHour) { if (aDouble > 35.0d) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfileEntry.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfileEntry.java index 757ffc2f79..05d8eaaa16 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfileEntry.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfileEntry.java @@ -1,11 +1,9 @@ package info.nightscout.androidaps.plugins.pump.medtronic.data.dto; import org.joda.time.LocalTime; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; /** @@ -15,22 +13,18 @@ import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; */ public class BasalProfileEntry { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); - - public byte[] rate_raw; + byte[] rate_raw; public double rate; - public byte startTime_raw; + byte startTime_raw; public LocalTime startTime; // Just a "time of day" - public BasalProfileEntry() { rate = -9.999E6; rate_raw = MedtronicUtil.getByteArrayFromUnsignedShort(0xFF, true); startTime = new LocalTime(0); - startTime_raw = (byte)0xFF; + startTime_raw = (byte) 0xFF; } - public BasalProfileEntry(double rate, int hour, int minutes) { byte[] data = MedtronicUtil.getBasalStrokes(rate, true); @@ -44,47 +38,42 @@ public class BasalProfileEntry { interval++; } - startTime_raw = (byte)interval; + startTime_raw = (byte) interval; startTime = new LocalTime(hour, minutes == 30 ? 30 : 0); } - - public BasalProfileEntry(int rateStrokes, int startTimeInterval) { + BasalProfileEntry(AAPSLogger aapsLogger, int rateStrokes, int startTimeInterval) { // rateByte is insulin delivery rate, U/hr, in 0.025 U increments // startTimeByte is time-of-day, in 30 minute increments rate_raw = MedtronicUtil.getByteArrayFromUnsignedShort(rateStrokes, true); rate = rateStrokes * 0.025; - startTime_raw = (byte)startTimeInterval; + startTime_raw = (byte) startTimeInterval; try { startTime = new LocalTime(startTimeInterval / 2, (startTimeInterval % 2) * 30); } catch (Exception ex) { - LOG.error( - "Error creating BasalProfileEntry: startTimeInterval={}, startTime_raw={}, hours={}, rateStrokes={}", - startTimeInterval, startTime_raw, startTimeInterval / 2, rateStrokes); + aapsLogger.error(LTag.PUMPCOMM, + "Error creating BasalProfileEntry: startTimeInterval={}, startTime_raw={}, hours={}, rateStrokes={}", + startTimeInterval, startTime_raw, startTimeInterval / 2, rateStrokes); throw ex; } } - - public BasalProfileEntry(byte rateByte, int startTimeByte) { + BasalProfileEntry(byte rateByte, int startTimeByte) { // rateByte is insulin delivery rate, U/hr, in 0.025 U increments // startTimeByte is time-of-day, in 30 minute increments rate_raw = MedtronicUtil.getByteArrayFromUnsignedShort(rateByte, true); rate = rateByte * 0.025; - startTime_raw = (byte)startTimeByte; + startTime_raw = (byte) startTimeByte; startTime = new LocalTime(startTimeByte / 2, (startTimeByte % 2) * 30); } - public void setStartTime(LocalTime localTime) { this.startTime = localTime; } - public void setRate(double rate) { this.rate = rate; } - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/DailyTotalsDTO.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/DailyTotalsDTO.java index 01327a8ea4..8ca17e152f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/DailyTotalsDTO.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/DailyTotalsDTO.java @@ -24,8 +24,6 @@ import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump.PumpH public class DailyTotalsDTO { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); - // bg avg, bg low hi, number Bgs, // Sen Avg, Sen Lo/Hi, Sens Cal/Data = 0/0, // Insulin=19.8[8,9], Basal[10,11], Bolus[13,14], Carbs, diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/TempBasalPair.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/TempBasalPair.java index 83ee3baf03..09dd929074 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/TempBasalPair.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/TempBasalPair.java @@ -1,14 +1,14 @@ package info.nightscout.androidaps.plugins.pump.medtronic.data.dto; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; +import org.jetbrains.annotations.NotNull; import java.util.ArrayList; import java.util.List; import java.util.Locale; +import info.nightscout.androidaps.logging.AAPSLogger; import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; @@ -19,12 +19,6 @@ import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; */ public class TempBasalPair extends info.nightscout.androidaps.plugins.pump.common.data.TempBasalPair { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); - - public TempBasalPair() { - } - - /** * This constructor is for use with PumpHistoryDecoder * @@ -34,7 +28,6 @@ public class TempBasalPair extends info.nightscout.androidaps.plugins.pump.commo */ public TempBasalPair(byte rateByte, int startTimeByte, boolean isPercent) { super(); - int rateInt = ByteUtil.asUINT8(rateByte); if (isPercent) @@ -46,10 +39,11 @@ public class TempBasalPair extends info.nightscout.androidaps.plugins.pump.commo } - public TempBasalPair(byte[] response) { + public TempBasalPair(AAPSLogger aapsLogger, byte[] response) { + super(); if (L.isEnabled(L.PUMPCOMM)) - LOG.debug("Received TempBasal response: " + ByteUtil.getHex(response)); + aapsLogger.debug(LTag.PUMPBTCOMM, "Received TempBasal response: " + ByteUtil.getHex(response)); isPercent = response[0] == 1; @@ -61,13 +55,13 @@ public class TempBasalPair extends info.nightscout.androidaps.plugins.pump.commo insulinRate = strokes / 40.0d; } - if (response.length<6) { + if (response.length < 6) { durationMinutes = ByteUtil.asUINT8(response[4]); } else { durationMinutes = MedtronicUtil.makeUnsignedShort(response[4], response[5]); } - LOG.warn("TempBasalPair (with {} byte response): {}", response.length, toString()); + aapsLogger.warn(LTag.PUMPBTCOMM, "TempBasalPair (with {} byte response): {}", response.length, toString()); } @@ -79,7 +73,7 @@ public class TempBasalPair extends info.nightscout.androidaps.plugins.pump.commo public byte[] getAsRawData() { - List list = new ArrayList(); + List list = new ArrayList<>(); list.add((byte) 5); @@ -128,7 +122,7 @@ public class TempBasalPair extends info.nightscout.androidaps.plugins.pump.commo } - @Override + @NotNull @Override public String toString() { return "TempBasalPair [" + "Rate=" + insulinRate + ", DurationMinutes=" + durationMinutes + ", IsPercent=" + isPercent + "]"; diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/defs/BatteryType.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/defs/BatteryType.java index 9ae1b8921a..7552b50d7f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/defs/BatteryType.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/defs/BatteryType.java @@ -1,5 +1,7 @@ package info.nightscout.androidaps.plugins.pump.medtronic.defs; +import androidx.annotation.StringRes; + import java.util.HashMap; import java.util.Map; @@ -19,30 +21,14 @@ public enum BatteryType { NiMH(R.string.key_medtronic_pump_battery_nimh, 1.10d, 1.40d) // ; - private final String description; - public double lowVoltage; - public double highVoltage; + public final @StringRes int description; + public final double lowVoltage; + public final double highVoltage; - static Map mapByDescription; - - static { - mapByDescription = new HashMap<>(); - - for (BatteryType value : values()) { - mapByDescription.put(value.description, value); - } - } BatteryType(int resId, double lowVoltage, double highVoltage) { - this.description = MainApp.gs(resId); + this.description = resId; this.lowVoltage = lowVoltage; this.highVoltage = highVoltage; } - - public static BatteryType getByDescription(String batteryTypeStr) { - if (mapByDescription.containsKey(batteryTypeStr)) { - return mapByDescription.get(batteryTypeStr); - } - return BatteryType.None; - } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/defs/MedtronicStatusRefreshType.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/defs/MedtronicStatusRefreshType.java index 55dc9b1a49..09af9f3554 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/defs/MedtronicStatusRefreshType.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/defs/MedtronicStatusRefreshType.java @@ -1,7 +1,5 @@ package info.nightscout.androidaps.plugins.pump.medtronic.defs; -import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; - /** * Created by andy on 6/28/18. */ @@ -30,9 +28,9 @@ public enum MedtronicStatusRefreshType { } - public MedtronicCommandType getCommandType() { + public MedtronicCommandType getCommandType(MedtronicDeviceType medtronicDeviceType) { if (this == Configuration) { - return MedtronicCommandType.getSettings(MedtronicUtil.getMedtronicPumpModel()); + return MedtronicCommandType.getSettings(medtronicDeviceType); } else return commandType; } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/dialog/MedtronicHistoryActivity.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/dialog/MedtronicHistoryActivity.java index e4673fbc5d..cb3aad5f94 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/dialog/MedtronicHistoryActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/dialog/MedtronicHistoryActivity.java @@ -21,13 +21,13 @@ import javax.inject.Inject; import info.nightscout.androidaps.R; import info.nightscout.androidaps.activities.NoSplashAppCompatActivity; import info.nightscout.androidaps.plugins.pump.common.defs.PumpHistoryEntryGroup; -import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump.PumpHistoryEntry; +import info.nightscout.androidaps.plugins.pump.medtronic.data.MedtronicHistoryData; public class MedtronicHistoryActivity extends NoSplashAppCompatActivity { - @Inject MedtronicPumpPlugin medtronicPumpPlugin; + @Inject MedtronicHistoryData medtronicHistoryData; Spinner historyTypeSpinner; TextView statusView; @@ -49,7 +49,7 @@ public class MedtronicHistoryActivity extends NoSplashAppCompatActivity { this.filteredHistoryList.clear(); List list = new ArrayList<>(); - list.addAll(medtronicPumpPlugin.getMedtronicHistoryData().getAllHistory()); + list.addAll(medtronicHistoryData.getAllHistory()); //LOG.debug("Items on full list: {}", list.size()); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/dialog/RileyLinkStatusDeviceMedtronic.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/dialog/RileyLinkStatusDeviceMedtronic.java index 2d7252cb7c..2a7ffa2ce4 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/dialog/RileyLinkStatusDeviceMedtronic.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/dialog/RileyLinkStatusDeviceMedtronic.java @@ -1,7 +1,6 @@ package info.nightscout.androidaps.plugins.pump.medtronic.dialog; import android.os.Bundle; -import androidx.fragment.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; @@ -12,10 +11,14 @@ import android.widget.TextView; import java.util.ArrayList; import java.util.List; +import javax.inject.Inject; + +import dagger.android.support.DaggerFragment; import info.nightscout.androidaps.R; import info.nightscout.androidaps.plugins.pump.common.dialog.RefreshableInterface; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.data.RLHistoryItem; import info.nightscout.androidaps.plugins.pump.common.utils.StringUtil; +import info.nightscout.androidaps.utils.resources.ResourceHelper; /** * Created by andy on 5/19/18. @@ -26,7 +29,9 @@ import info.nightscout.androidaps.plugins.pump.common.utils.StringUtil; */ // TODO needs to be implemented -public class RileyLinkStatusDeviceMedtronic extends Fragment implements RefreshableInterface { +public class RileyLinkStatusDeviceMedtronic extends DaggerFragment implements RefreshableInterface { + + @Inject ResourceHelper resourceHelper; // @BindView(R.id.rileylink_history_list) ListView listView; @@ -150,7 +155,7 @@ public class RileyLinkStatusDeviceMedtronic extends Fragment implements Refresha RLHistoryItem item = historyItemList.get(i); viewHolder.itemTime.setText(StringUtil.toDateTimeString(item.getDateTime())); viewHolder.itemSource.setText("Riley Link"); // for now - viewHolder.itemDescription.setText(item.getDescription()); + viewHolder.itemDescription.setText(item.getDescription(resourceHelper)); return view; } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/driver/MedtronicPumpStatus.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/driver/MedtronicPumpStatus.java index 315aeb0869..02f08e93d7 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/driver/MedtronicPumpStatus.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/driver/MedtronicPumpStatus.java @@ -1,8 +1,6 @@ package info.nightscout.androidaps.plugins.pump.medtronic.driver; -import org.joda.time.LocalDateTime; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; +import org.jetbrains.annotations.NotNull; import java.util.Calendar; import java.util.Date; @@ -10,84 +8,74 @@ import java.util.GregorianCalendar; import java.util.HashMap; import java.util.Map; -import info.nightscout.androidaps.MainApp; -import info.nightscout.androidaps.R; -import info.nightscout.androidaps.interfaces.PumpDescription; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; +import javax.inject.Inject; +import javax.inject.Singleton; + +import info.nightscout.androidaps.plugins.bus.RxBusWrapper; import info.nightscout.androidaps.plugins.pump.common.data.PumpStatus; import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkEncodingType; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkTargetFrequency; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkError; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; -import info.nightscout.androidaps.plugins.pump.medtronic.data.MedtronicHistoryData; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.data.RLHistoryItem; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice; import info.nightscout.androidaps.plugins.pump.medtronic.defs.BasalProfileStatus; import info.nightscout.androidaps.plugins.pump.medtronic.defs.BatteryType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicDeviceType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; +import info.nightscout.androidaps.plugins.pump.medtronic.events.EventMedtronicDeviceStatusChange; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicConst; -import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; -import info.nightscout.androidaps.utils.SP; +import info.nightscout.androidaps.utils.resources.ResourceHelper; +import info.nightscout.androidaps.utils.sharedPreferences.SP; /** * Created by andy on 4/28/18. */ +@Singleton public class MedtronicPumpStatus extends PumpStatus { - private static Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMP); + private final ResourceHelper resourceHelper; + private final SP sp; + private final RileyLinkUtil rileyLinkUtil; + private final RxBusWrapper rxBus; public String errorDescription = null; public String serialNumber; public String pumpFrequency = null; - public String rileyLinkAddress = null; public Double maxBolus; public Double maxBasal; - public boolean inPreInit = true; // statuses - public RileyLinkServiceState rileyLinkServiceState = RileyLinkServiceState.NotStarted; - public RileyLinkError rileyLinkError; - public PumpDeviceState pumpDeviceState = PumpDeviceState.NeverContacted; + private PumpDeviceState pumpDeviceState = PumpDeviceState.NeverContacted; public MedtronicDeviceType medtronicDeviceType = null; - public double currentBasal = 0; - public int tempBasalInProgress = 0; - public int tempBasalRatio = 0; - public int tempBasalRemainMin = 0; public Date tempBasalStart; public Double tempBasalAmount = 0.0d; // fixme public Integer tempBasalLength = 0; - private String regexMac = "([\\da-fA-F]{1,2}(?:\\:|$)){6}"; - private String regexSN = "[0-9]{6}"; - - private boolean serialChanged = false; - private boolean rileyLinkAddressChanged = false; - private boolean encodingChanged = false; - private boolean targetFrequencyChanged = false; - - private RileyLinkEncodingType encodingType; - private String[] frequencies; - private boolean isFrequencyUS = false; private Map medtronicPumpMap = null; private Map medtronicDeviceTypeMap = null; - private RileyLinkTargetFrequency targetFrequency; public BasalProfileStatus basalProfileStatus = BasalProfileStatus.NotInitialized; public BatteryType batteryType = BatteryType.None; - public MedtronicPumpStatus(PumpDescription pumpDescription) { - super(pumpDescription); + @Inject + public MedtronicPumpStatus( + ResourceHelper resourceHelper, + SP sp, + RxBusWrapper rxBus, + RileyLinkUtil rileyLinkUtil + ) { + super(); + this.resourceHelper = resourceHelper; + this.sp = sp; + this.rxBus = rxBus; + this.rileyLinkUtil = rileyLinkUtil; + initSettings(); } - @Override - public void initSettings() { + private void initSettings() { this.activeProfileName = "STD"; this.reservoirRemainingUnits = 75d; @@ -99,8 +87,8 @@ public class MedtronicPumpStatus extends PumpStatus { if (this.medtronicDeviceTypeMap == null) createMedtronicDeviceTypeMap(); - this.lastConnection = SP.getLong(MedtronicConst.Statistics.LastGoodPumpCommunicationTime, 0L); - this.lastDataTime = new LocalDateTime(this.lastConnection); + this.lastConnection = sp.getLong(MedtronicConst.Statistics.LastGoodPumpCommunicationTime, 0L); + this.lastDataTime = this.lastConnection; } @@ -135,244 +123,16 @@ public class MedtronicPumpStatus extends PumpStatus { medtronicPumpMap.put("554", PumpType.Medtronic_554_754_Veo); medtronicPumpMap.put("754", PumpType.Medtronic_554_754_Veo); - frequencies = new String[2]; - frequencies[0] = MainApp.gs(R.string.key_medtronic_pump_frequency_us_ca); - frequencies[1] = MainApp.gs(R.string.key_medtronic_pump_frequency_worldwide); } - - public boolean verifyConfiguration() { - try { - - // FIXME don't reload information several times - if (this.medtronicPumpMap == null) - createMedtronicPumpMap(); - - if (this.medtronicDeviceTypeMap == null) - createMedtronicDeviceTypeMap(); - - this.errorDescription = "-"; - - String serialNr = SP.getString(MedtronicConst.Prefs.PumpSerial, null); - - if (serialNr == null) { - this.errorDescription = MainApp.gs(R.string.medtronic_error_serial_not_set); - return false; - } else { - if (!serialNr.matches(regexSN)) { - this.errorDescription = MainApp.gs(R.string.medtronic_error_serial_invalid); - return false; - } else { - if (!serialNr.equals(this.serialNumber)) { - this.serialNumber = serialNr; - serialChanged = true; - } - } - } - - String pumpType = SP.getString(MedtronicConst.Prefs.PumpType, null); - - if (pumpType == null) { - this.errorDescription = MainApp.gs(R.string.medtronic_error_pump_type_not_set); - return false; - } else { - String pumpTypePart = pumpType.substring(0, 3); - - if (!pumpTypePart.matches("[0-9]{3}")) { - this.errorDescription = MainApp.gs(R.string.medtronic_error_pump_type_invalid); - return false; - } else { - this.pumpType = medtronicPumpMap.get(pumpTypePart); - this.medtronicDeviceType = medtronicDeviceTypeMap.get(pumpTypePart); - this.pumpDescription.setPumpDescription(this.pumpType); - - if (pumpTypePart.startsWith("7")) - this.reservoirFullUnits = 300; - else - this.reservoirFullUnits = 176; - } - } - - String pumpFrequency = SP.getString(MedtronicConst.Prefs.PumpFrequency, null); - - if (pumpFrequency == null) { - this.errorDescription = MainApp.gs(R.string.medtronic_error_pump_frequency_not_set); - return false; - } else { - if (!pumpFrequency.equals(frequencies[0]) && !pumpFrequency.equals(frequencies[1])) { - this.errorDescription = MainApp.gs(R.string.medtronic_error_pump_frequency_invalid); - return false; - } else { - this.pumpFrequency = pumpFrequency; - this.isFrequencyUS = pumpFrequency.equals(frequencies[0]); - - RileyLinkTargetFrequency newTargetFrequency = this.isFrequencyUS ? // - RileyLinkTargetFrequency.Medtronic_US - : RileyLinkTargetFrequency.Medtronic_WorldWide; - - if (targetFrequency != newTargetFrequency) { - RileyLinkUtil.setRileyLinkTargetFrequency(newTargetFrequency); - targetFrequency = newTargetFrequency; - targetFrequencyChanged = true; - } - - } - } - - String rileyLinkAddress = SP.getString(RileyLinkConst.Prefs.RileyLinkAddress, null); - - if (rileyLinkAddress == null) { - if (isLogEnabled()) - LOG.debug("RileyLink address invalid: null"); - this.errorDescription = MainApp.gs(R.string.medtronic_error_rileylink_address_invalid); - return false; - } else { - if (!rileyLinkAddress.matches(regexMac)) { - this.errorDescription = MainApp.gs(R.string.medtronic_error_rileylink_address_invalid); - if (isLogEnabled()) - LOG.debug("RileyLink address invalid: {}", rileyLinkAddress); - } else { - if (!rileyLinkAddress.equals(this.rileyLinkAddress)) { - this.rileyLinkAddress = rileyLinkAddress; - rileyLinkAddressChanged = true; - } - } - } - - double maxBolusLcl = checkParameterValue(MedtronicConst.Prefs.MaxBolus, "25.0", 25.0d); - - if (maxBolus == null || !maxBolus.equals(maxBolusLcl)) { - maxBolus = maxBolusLcl; - - //LOG.debug("Max Bolus from AAPS settings is " + maxBolus); - } - - double maxBasalLcl = checkParameterValue(MedtronicConst.Prefs.MaxBasal, "35.0", 35.0d); - - if (maxBasal == null || !maxBasal.equals(maxBasalLcl)) { - maxBasal = maxBasalLcl; - - //LOG.debug("Max Basal from AAPS settings is " + maxBasal); - } - - - String encodingTypeStr = SP.getString(MedtronicConst.Prefs.Encoding, null); - - if (encodingTypeStr == null) { - return false; - } - - RileyLinkEncodingType newEncodingType = RileyLinkEncodingType.getByDescription(encodingTypeStr); - - if (this.encodingType == null) { - this.encodingType = newEncodingType; - } else if (this.encodingType != newEncodingType) { - this.encodingType = newEncodingType; - this.encodingChanged = true; - } - - String batteryTypeStr = SP.getString(MedtronicConst.Prefs.BatteryType, null); - - if (batteryTypeStr == null) - return false; - - BatteryType batteryType = BatteryType.getByDescription(batteryTypeStr); - - if (this.batteryType != batteryType) { - this.batteryType = batteryType; - MedtronicUtil.setBatteryType(this.batteryType); - } - - String bolusDebugEnabled = SP.getString(MedtronicConst.Prefs.BolusDebugEnabled, null); - - boolean bolusDebug = bolusDebugEnabled != null && bolusDebugEnabled.equals(MainApp.gs(R.string.common_on)); - - MedtronicHistoryData.doubleBolusDebug = bolusDebug; - - reconfigureService(); - - return true; - - } catch (Exception ex) { - this.errorDescription = ex.getMessage(); - LOG.error("Error on Verification: " + ex.getMessage(), ex); - return false; - } + public Map getMedtronicPumpMap() { + return medtronicPumpMap; } - - private boolean reconfigureService() { - - if (!inPreInit && MedtronicUtil.getMedtronicService() != null) { - - if (serialChanged) { - MedtronicUtil.getMedtronicService().setPumpIDString(this.serialNumber); // short operation - serialChanged = false; - } - - if (rileyLinkAddressChanged) { - MedtronicUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkNewAddressSet); - rileyLinkAddressChanged = false; - } - - if (encodingChanged) { - RileyLinkUtil.getRileyLinkService().changeRileyLinkEncoding(encodingType); - encodingChanged = false; - } - } - - - // if (targetFrequencyChanged && !inPreInit && MedtronicUtil.getMedtronicService() != null) { - // RileyLinkUtil.setRileyLinkTargetFrequency(targetFrequency); - // // RileyLinkUtil.getRileyLinkCommunicationManager().refreshRileyLinkTargetFrequency(); - // targetFrequencyChanged = false; - // } - - return (!rileyLinkAddressChanged && !serialChanged && !encodingChanged); // && !targetFrequencyChanged); + public Map getMedtronicDeviceTypeMap() { + return medtronicDeviceTypeMap; } - - private double checkParameterValue(int key, String defaultValue, double defaultValueDouble) { - double val = 0.0d; - - String value = SP.getString(key, defaultValue); - - try { - val = Double.parseDouble(value); - } catch (Exception ex) { - LOG.error("Error parsing setting: {}, value found {}", key, value); - val = defaultValueDouble; - } - - if (val > defaultValueDouble) { - SP.putString(key, defaultValue); - val = defaultValueDouble; - } - - return val; - } - - - public String getErrorInfo() { - verifyConfiguration(); - - return (this.errorDescription == null) ? "-" : this.errorDescription; - } - - - @Override - public void refreshConfiguration() { - verifyConfiguration(); - } - - - public boolean setNotInPreInit() { - this.inPreInit = false; - - return reconfigureService(); - } - - public double getBasalProfileForHour() { if (basalsByHour != null) { GregorianCalendar c = new GregorianCalendar(); @@ -384,8 +144,37 @@ public class MedtronicPumpStatus extends PumpStatus { return 0; } - private boolean isLogEnabled() { - return L.isEnabled(L.PUMP); + // Battery type + private Map mapByDescription; + + public BatteryType getBatteryTypeByDescription(String batteryTypeStr) { + if (mapByDescription == null) { + mapByDescription = new HashMap<>(); + for (BatteryType value : BatteryType.values()) { + mapByDescription.put(resourceHelper.gs(value.description), value); + } + } + if (mapByDescription.containsKey(batteryTypeStr)) { + return mapByDescription.get(batteryTypeStr); + } + return BatteryType.None; } + @NotNull + public String getErrorInfo() { + return (errorDescription == null) ? "-" : errorDescription; + } + + public PumpDeviceState getPumpDeviceState() { + return pumpDeviceState; + } + + + public void setPumpDeviceState(PumpDeviceState pumpDeviceState) { + this.pumpDeviceState = pumpDeviceState; + + rileyLinkUtil.getRileyLinkHistory().add(new RLHistoryItem(pumpDeviceState, RileyLinkTargetDevice.MedtronicPump)); + + rxBus.send(new EventMedtronicDeviceStatusChange(pumpDeviceState)); + } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/service/RileyLinkMedtronicService.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/service/RileyLinkMedtronicService.java index 0de5e3f355..ac88f946aa 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/service/RileyLinkMedtronicService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/service/RileyLinkMedtronicService.java @@ -1,6 +1,5 @@ package info.nightscout.androidaps.plugins.pump.medtronic.service; -import android.content.Context; import android.content.Intent; import android.content.IntentFilter; import android.content.res.Configuration; @@ -9,55 +8,58 @@ import android.os.IBinder; import javax.inject.Inject; -import info.nightscout.androidaps.logging.AAPSLogger; +import dagger.android.HasAndroidInjector; +import info.nightscout.androidaps.R; import info.nightscout.androidaps.logging.LTag; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkCommunicationManager; +import info.nightscout.androidaps.plugins.pump.common.defs.PumpType; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkConst; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RFSpy; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.RileyLinkBLE; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkEncodingType; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.defs.RileyLinkTargetFrequency; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkServiceState; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkService; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.tasks.ServiceTask; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.comm.MedtronicCommunicationManager; +import info.nightscout.androidaps.plugins.pump.medtronic.comm.ui.MedtronicUIComm; +import info.nightscout.androidaps.plugins.pump.medtronic.comm.ui.MedtronicUIPostprocessor; +import info.nightscout.androidaps.plugins.pump.medtronic.data.MedtronicHistoryData; +import info.nightscout.androidaps.plugins.pump.medtronic.defs.BatteryType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpStatus; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicConst; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; -import info.nightscout.androidaps.utils.sharedPreferences.SP; +import info.nightscout.androidaps.utils.resources.ResourceHelper; /** * RileyLinkMedtronicService is intended to stay running when the gui-app is closed. */ public class RileyLinkMedtronicService extends RileyLinkService { - //@Inject AAPSLogger aapsLogger; - //@Inject Context context; + @Inject HasAndroidInjector injector; + @Inject ResourceHelper resourceHelper; @Inject MedtronicPumpPlugin medtronicPumpPlugin; - //@Inject SP sp; + @Inject MedtronicUtil medtronicUtil; + @Inject MedtronicUIPostprocessor medtronicUIPostprocessor; + @Inject MedtronicPumpStatus medtronicPumpStatus; - private static RileyLinkMedtronicService instance; - private static ServiceTask currentTask = null; - - // cache of most recently received set of pump history pages. Probably shouldn't be here. - public MedtronicCommunicationManager medtronicCommunicationManager; - MedtronicPumpStatus pumpStatus = null; + private MedtronicUIComm medtronicUIComm; + private MedtronicCommunicationManager medtronicCommunicationManager; private IBinder mBinder = new LocalBinder(); + private boolean serialChanged = false; + private String[] frequencies; + private String rileyLinkAddress = null; + private boolean rileyLinkAddressChanged = false; + private RileyLinkEncodingType encodingType; + private boolean encodingChanged = false; + private boolean inPreInit = true; + public RileyLinkMedtronicService() { super(); - instance = this; - } - - - public static RileyLinkMedtronicService getInstance() { - return instance; } @@ -85,29 +87,26 @@ public class RileyLinkMedtronicService extends RileyLinkService { */ public void initRileyLinkServiceData() { - rileyLinkServiceData = new RileyLinkServiceData(RileyLinkTargetDevice.MedtronicPump); + frequencies = new String[2]; + frequencies[0] = resourceHelper.gs(R.string.key_medtronic_pump_frequency_us_ca); + frequencies[1] = resourceHelper.gs(R.string.key_medtronic_pump_frequency_worldwide); - RileyLinkUtil.setRileyLinkServiceData(rileyLinkServiceData); - RileyLinkUtil.setTargetDevice(RileyLinkTargetDevice.MedtronicPump); + rileyLinkServiceData.targetDevice = RileyLinkTargetDevice.MedtronicPump; setPumpIDString(sp.getString(MedtronicConst.Prefs.PumpSerial, "000000")); // get most recently used RileyLink address rileyLinkServiceData.rileylinkAddress = sp.getString(RileyLinkConst.Prefs.RileyLinkAddress, ""); - rileyLinkBLE = new RileyLinkBLE(this.context); // or this - rfspy = new RFSpy(rileyLinkBLE); + rileyLinkBLE = new RileyLinkBLE(injector, this); // or this + rfspy = new RFSpy(injector, rileyLinkBLE); rfspy.startReader(); - RileyLinkUtil.setRileyLinkBLE(rileyLinkBLE); - // init rileyLinkCommunicationManager - medtronicCommunicationManager = new MedtronicCommunicationManager(rfspy); + medtronicCommunicationManager = new MedtronicCommunicationManager(injector, rfspy); + medtronicUIComm = new MedtronicUIComm(injector, aapsLogger, medtronicUtil, medtronicUIPostprocessor, medtronicCommunicationManager); aapsLogger.debug(LTag.PUMPCOMM, "RileyLinkMedtronicService newly constructed"); - MedtronicUtil.setMedtronicService(this); - pumpStatus = (MedtronicPumpStatus) medtronicPumpPlugin.getPumpStatusData(); - } @@ -116,12 +115,15 @@ public class RileyLinkMedtronicService extends RileyLinkService { } - @Override - public RileyLinkCommunicationManager getDeviceCommunicationManager() { + public MedtronicCommunicationManager getDeviceCommunicationManager() { return this.medtronicCommunicationManager; } + public MedtronicUIComm getMedtronicUIComm() { + return medtronicUIComm; + } + public void setPumpIDString(String pumpID) { if (pumpID.length() != 6) { aapsLogger.error("setPumpIDString: invalid pump id string: " + pumpID); @@ -153,13 +155,13 @@ public class RileyLinkMedtronicService extends RileyLinkService { rileyLinkServiceData.setPumpID(pumpID, pumpIDBytes); if (oldId != null && !oldId.equals(pumpID)) { - MedtronicUtil.setMedtronicPumpModel(null); // if we change pumpId, model probably changed too + medtronicUtil.setMedtronicPumpModel(null); // if we change pumpId, model probably changed too } return; } - MedtronicUtil.setPumpDeviceState(PumpDeviceState.InvalidConfiguration); + medtronicPumpStatus.setPumpDeviceState(PumpDeviceState.InvalidConfiguration); // LOG.info("setPumpIDString: saved pumpID " + idString); } @@ -177,7 +179,7 @@ public class RileyLinkMedtronicService extends RileyLinkService { // PumpInterface - REMOVE public boolean isInitialized() { - return RileyLinkServiceState.isReady(RileyLinkUtil.getRileyLinkServiceData().serviceState); + return RileyLinkServiceState.isReady(rileyLinkServiceData.rileyLinkServiceState); } @@ -195,4 +197,209 @@ public class RileyLinkMedtronicService extends RileyLinkService { @Override public void registerDeviceSpecificBroadcasts(IntentFilter intentFilter) { } + + public boolean verifyConfiguration() { + try { + String regexSN = "[0-9]{6}"; + String regexMac = "([\\da-fA-F]{1,2}(?:\\:|$)){6}"; + + medtronicPumpStatus.errorDescription = "-"; + + String serialNr = sp.getStringOrNull(MedtronicConst.Prefs.PumpSerial, null); + + if (serialNr == null) { + medtronicPumpStatus.errorDescription = resourceHelper.gs(R.string.medtronic_error_serial_not_set); + return false; + } else { + if (!serialNr.matches(regexSN)) { + medtronicPumpStatus.errorDescription = resourceHelper.gs(R.string.medtronic_error_serial_invalid); + return false; + } else { + if (!serialNr.equals(medtronicPumpStatus.serialNumber)) { + medtronicPumpStatus.serialNumber = serialNr; + serialChanged = true; + } + } + } + + String pumpTypePref = sp.getStringOrNull(MedtronicConst.Prefs.PumpType, null); + + if (pumpTypePref == null) { + medtronicPumpStatus.errorDescription = resourceHelper.gs(R.string.medtronic_error_pump_type_not_set); + return false; + } else { + String pumpTypePart = pumpTypePref.substring(0, 3); + + if (!pumpTypePart.matches("[0-9]{3}")) { + medtronicPumpStatus.errorDescription = resourceHelper.gs(R.string.medtronic_error_pump_type_invalid); + return false; + } else { + PumpType pumpType = medtronicPumpStatus.getMedtronicPumpMap().get(pumpTypePart); + medtronicPumpStatus.medtronicDeviceType = medtronicPumpStatus.getMedtronicDeviceTypeMap().get(pumpTypePart); + medtronicPumpPlugin.getPumpDescription().setPumpDescription(pumpType); + + if (pumpTypePart.startsWith("7")) + medtronicPumpStatus.reservoirFullUnits = 300; + else + medtronicPumpStatus.reservoirFullUnits = 176; + } + } + + String pumpFrequency = sp.getStringOrNull(MedtronicConst.Prefs.PumpFrequency, null); + + if (pumpFrequency == null) { + medtronicPumpStatus.errorDescription = resourceHelper.gs(R.string.medtronic_error_pump_frequency_not_set); + return false; + } else { + if (!pumpFrequency.equals(frequencies[0]) && !pumpFrequency.equals(frequencies[1])) { + medtronicPumpStatus.errorDescription = resourceHelper.gs(R.string.medtronic_error_pump_frequency_invalid); + return false; + } else { + medtronicPumpStatus.pumpFrequency = pumpFrequency; + boolean isFrequencyUS = pumpFrequency.equals(frequencies[0]); + + RileyLinkTargetFrequency newTargetFrequency = isFrequencyUS ? // + RileyLinkTargetFrequency.Medtronic_US + : RileyLinkTargetFrequency.Medtronic_WorldWide; + + if (rileyLinkServiceData.rileyLinkTargetFrequency != newTargetFrequency) { + rileyLinkServiceData.rileyLinkTargetFrequency = newTargetFrequency; + } + + } + } + + String rileyLinkAddress = sp.getStringOrNull(RileyLinkConst.Prefs.RileyLinkAddress, null); + + if (rileyLinkAddress == null) { + aapsLogger.debug(LTag.PUMP, "RileyLink address invalid: null"); + medtronicPumpStatus.errorDescription = resourceHelper.gs(R.string.medtronic_error_rileylink_address_invalid); + return false; + } else { + if (!rileyLinkAddress.matches(regexMac)) { + medtronicPumpStatus.errorDescription = resourceHelper.gs(R.string.medtronic_error_rileylink_address_invalid); + aapsLogger.debug(LTag.PUMP, "RileyLink address invalid: {}", rileyLinkAddress); + } else { + if (!rileyLinkAddress.equals(this.rileyLinkAddress)) { + this.rileyLinkAddress = rileyLinkAddress; + rileyLinkAddressChanged = true; + } + } + } + + double maxBolusLcl = checkParameterValue(MedtronicConst.Prefs.MaxBolus, "25.0", 25.0d); + + if (medtronicPumpStatus.maxBolus == null || !medtronicPumpStatus.maxBolus.equals(maxBolusLcl)) { + medtronicPumpStatus.maxBolus = maxBolusLcl; + + //LOG.debug("Max Bolus from AAPS settings is " + maxBolus); + } + + double maxBasalLcl = checkParameterValue(MedtronicConst.Prefs.MaxBasal, "35.0", 35.0d); + + if (medtronicPumpStatus.maxBasal == null || !medtronicPumpStatus.maxBasal.equals(maxBasalLcl)) { + medtronicPumpStatus.maxBasal = maxBasalLcl; + + //LOG.debug("Max Basal from AAPS settings is " + maxBasal); + } + + + String encodingTypeStr = sp.getStringOrNull(MedtronicConst.Prefs.Encoding, null); + + if (encodingTypeStr == null) { + return false; + } + + RileyLinkEncodingType newEncodingType = RileyLinkEncodingType.getByDescription(encodingTypeStr); + + if (encodingType == null) { + encodingType = newEncodingType; + } else if (encodingType != newEncodingType) { + encodingType = newEncodingType; + encodingChanged = true; + } + + String batteryTypeStr = sp.getStringOrNull(MedtronicConst.Prefs.BatteryType, null); + + if (batteryTypeStr == null) + return false; + + BatteryType batteryType = medtronicPumpStatus.getBatteryTypeByDescription(batteryTypeStr); + + if (medtronicPumpStatus.batteryType != batteryType) { + medtronicPumpStatus.batteryType = batteryType; + } + + String bolusDebugEnabled = sp.getStringOrNull(MedtronicConst.Prefs.BolusDebugEnabled, null); + + boolean bolusDebug = bolusDebugEnabled != null && bolusDebugEnabled.equals(resourceHelper.gs(R.string.common_on)); + + MedtronicHistoryData.doubleBolusDebug = bolusDebug; + + reconfigureService(); + + return true; + + } catch (Exception ex) { + medtronicPumpStatus.errorDescription = ex.getMessage(); + aapsLogger.error(LTag.PUMP, "Error on Verification: " + ex.getMessage(), ex); + return false; + } + } + + private boolean reconfigureService() { + + if (!inPreInit) { + + if (serialChanged) { + setPumpIDString(medtronicPumpStatus.serialNumber); // short operation + serialChanged = false; + } + + if (rileyLinkAddressChanged) { + rileyLinkUtil.sendBroadcastMessage(RileyLinkConst.Intents.RileyLinkNewAddressSet, this); + rileyLinkAddressChanged = false; + } + + if (encodingChanged) { + changeRileyLinkEncoding(encodingType); + encodingChanged = false; + } + } + + + // if (targetFrequencyChanged && !inPreInit && MedtronicUtil.getMedtronicService() != null) { + // RileyLinkUtil.setRileyLinkTargetFrequency(targetFrequency); + // // RileyLinkUtil.getRileyLinkCommunicationManager().refreshRileyLinkTargetFrequency(); + // targetFrequencyChanged = false; + // } + + return (!rileyLinkAddressChanged && !serialChanged && !encodingChanged); // && !targetFrequencyChanged); + } + + private double checkParameterValue(int key, String defaultValue, double defaultValueDouble) { + double val; + + String value = sp.getString(key, defaultValue); + + try { + val = Double.parseDouble(value); + } catch (Exception ex) { + aapsLogger.error("Error parsing setting: {}, value found {}", key, value); + val = defaultValueDouble; + } + + if (val > defaultValueDouble) { + sp.putString(key, defaultValue); + val = defaultValueDouble; + } + + return val; + } + + public boolean setNotInPreInit() { + this.inPreInit = false; + + return reconfigureService(); + } } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/util/MedtronicUtil.java b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/util/MedtronicUtil.java index 7f02a42d21..a4e7a51ec2 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/util/MedtronicUtil.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/util/MedtronicUtil.java @@ -4,7 +4,6 @@ import com.google.gson.Gson; import com.google.gson.GsonBuilder; import org.joda.time.LocalTime; -import org.slf4j.Logger; import java.nio.ByteBuffer; import java.nio.ByteOrder; @@ -12,67 +11,64 @@ import java.util.ArrayList; import java.util.List; import java.util.Map; -import info.nightscout.androidaps.interfaces.PluginType; -import info.nightscout.androidaps.logging.L; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; -import info.nightscout.androidaps.plugins.bus.RxBus; +import javax.inject.Inject; +import javax.inject.Singleton; + +import info.nightscout.androidaps.logging.AAPSLogger; +import info.nightscout.androidaps.logging.LTag; import info.nightscout.androidaps.plugins.bus.RxBusWrapper; import info.nightscout.androidaps.plugins.general.overview.events.EventDismissNotification; import info.nightscout.androidaps.plugins.general.overview.events.EventNewNotification; import info.nightscout.androidaps.plugins.general.overview.notifications.Notification; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil; import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.data.RLHistoryItem; -import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.defs.RileyLinkTargetDevice; +import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; -import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; -import info.nightscout.androidaps.plugins.pump.medtronic.comm.MedtronicCommunicationManager; import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.ClockDTO; import info.nightscout.androidaps.plugins.pump.medtronic.data.dto.PumpSettingDTO; -import info.nightscout.androidaps.plugins.pump.medtronic.defs.BatteryType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicCommandType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicDeviceType; import info.nightscout.androidaps.plugins.pump.medtronic.defs.MedtronicNotificationType; -import info.nightscout.androidaps.plugins.pump.medtronic.defs.PumpDeviceState; import info.nightscout.androidaps.plugins.pump.medtronic.driver.MedtronicPumpStatus; import info.nightscout.androidaps.plugins.pump.medtronic.events.EventMedtronicDeviceStatusChange; -import info.nightscout.androidaps.plugins.pump.medtronic.service.RileyLinkMedtronicService; import info.nightscout.androidaps.utils.resources.ResourceHelper; /** * Created by andy on 5/9/18. */ -public class MedtronicUtil extends RileyLinkUtil { +@Singleton +public class MedtronicUtil { - private static final Logger LOG = StacktraceLoggerWrapper.getLogger(L.PUMPCOMM); - static int ENVELOPE_SIZE = 4; // 0xA7 S1 S2 S3 CMD PARAM_COUNT [PARAMS] - static int CRC_SIZE = 1; + private int ENVELOPE_SIZE = 4; // 0xA7 S1 S2 S3 CMD PARAM_COUNT [PARAMS] private static boolean lowLevelDebug = true; - private static PumpDeviceState pumpDeviceState; - private static MedtronicDeviceType medtronicPumpModel; - private static RileyLinkMedtronicService medtronicService; - private static MedtronicPumpStatus medtronicPumpStatus; - private static MedtronicCommandType currentCommand; - private static Map settings; - private static int BIG_FRAME_LENGTH = 65; - private static int doneBit = 1 << 7; - private static ClockDTO pumpTime; - public static Gson gsonInstance = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create(); - public static Gson gsonInstanceCore = new GsonBuilder().create(); - private static BatteryType batteryType = BatteryType.None; + private MedtronicDeviceType medtronicPumpModel; + private MedtronicCommandType currentCommand; + private Map settings; + private int BIG_FRAME_LENGTH = 65; + private int doneBit = 1 << 7; + private ClockDTO pumpTime; + public Gson gsonInstance = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create(); + private final AAPSLogger aapsLogger; + private final RxBusWrapper rxBus; + private final RileyLinkUtil rileyLinkUtil; + private final MedtronicPumpStatus medtronicPumpStatus; - public static Gson getGsonInstance() { - return gsonInstance; + @Inject + public MedtronicUtil( + AAPSLogger aapsLogger, + RxBusWrapper rxBus, + RileyLinkUtil rileyLinkUtil, + MedtronicPumpStatus medtronicPumpStatus + ) { + this.aapsLogger = aapsLogger; + this.rxBus = rxBus; + this.rileyLinkUtil = rileyLinkUtil; + this.medtronicPumpStatus = medtronicPumpStatus; } - - public static Gson getGsonInstanceCore() { - return gsonInstanceCore; - } - - - public static LocalTime getTimeFrom30MinInterval(int interval) { + public LocalTime getTimeFrom30MinInterval(int interval) { if (interval % 2 == 0) { return new LocalTime(interval / 2, 0); } else { @@ -91,12 +87,6 @@ public class MedtronicUtil extends RileyLinkUtil { return k; } - public static boolean isMedtronicPump() { - return MedtronicPumpPlugin.getPlugin().isEnabled(PluginType.PUMP); - //return ConfigBuilderPlugin.getPlugin().getActivePump().deviceID().equals("Medtronic"); - } - - public static byte[] getByteArrayFromUnsignedShort(int shortValue, boolean returnFixedSize) { byte highByte = (byte) (shortValue >> 8 & 0xFF); byte lowByte = (byte) (shortValue & 0xFF); @@ -127,17 +117,17 @@ public class MedtronicUtil extends RileyLinkUtil { } - public static double decodeBasalInsulin(int i, int j) { + public double decodeBasalInsulin(int i, int j) { return decodeBasalInsulin(makeUnsignedShort(i, j)); } - public static double decodeBasalInsulin(int i) { + public double decodeBasalInsulin(int i) { return (double) i / 40.0d; } - public static byte[] getBasalStrokes(double amount) { + public byte[] getBasalStrokes(double amount) { return getBasalStrokes(amount, false); } @@ -147,12 +137,12 @@ public class MedtronicUtil extends RileyLinkUtil { } - public static int getBasalStrokesInt(double amount) { + public int getBasalStrokesInt(double amount) { return getStrokesInt(amount, 40); } - public static byte[] getBolusStrokes(double amount) { + public byte[] getBolusStrokes(double amount) { int strokesPerUnit = medtronicPumpModel.getBolusStrokes(); @@ -184,7 +174,7 @@ public class MedtronicUtil extends RileyLinkUtil { } - public static byte[] createCommandBody(byte[] input) { + public byte[] createCommandBody(byte[] input) { return ByteUtil.concat((byte) input.length, input); } @@ -223,7 +213,7 @@ public class MedtronicUtil extends RileyLinkUtil { } - public static void sendNotification(MedtronicNotificationType notificationType, ResourceHelper resourceHelper, RxBusWrapper rxBus) { + public void sendNotification(MedtronicNotificationType notificationType, ResourceHelper resourceHelper, RxBusWrapper rxBus) { Notification notification = new Notification( // notificationType.getNotificationType(), // resourceHelper.gs(notificationType.getResourceId()), // @@ -232,7 +222,7 @@ public class MedtronicUtil extends RileyLinkUtil { } - public static void sendNotification(MedtronicNotificationType notificationType, ResourceHelper resourceHelper, RxBusWrapper rxBus, Object... parameters) { + public void sendNotification(MedtronicNotificationType notificationType, ResourceHelper resourceHelper, RxBusWrapper rxBus, Object... parameters) { Notification notification = new Notification( // notificationType.getNotificationType(), // resourceHelper.gs(notificationType.getResourceId(), parameters), // @@ -241,22 +231,22 @@ public class MedtronicUtil extends RileyLinkUtil { } - public static void dismissNotification(MedtronicNotificationType notificationType, RxBusWrapper rxBus) { + public void dismissNotification(MedtronicNotificationType notificationType, RxBusWrapper rxBus) { rxBus.send(new EventDismissNotification(notificationType.getNotificationType())); } -// public static byte[] buildCommandPayload(MessageType commandType, byte[] parameters) { +// public byte[] buildCommandPayload(MessageType commandType, byte[] parameters) { // return buildCommandPayload(commandType.getValue(), parameters); // } - public static byte[] buildCommandPayload(MedtronicCommandType commandType, byte[] parameters) { - return buildCommandPayload((byte) commandType.commandCode, parameters); + public byte[] buildCommandPayload(RileyLinkServiceData rileyLinkServiceData, MedtronicCommandType commandType, byte[] parameters) { + return buildCommandPayload(rileyLinkServiceData, (byte) commandType.commandCode, parameters); } - public static byte[] buildCommandPayload(byte commandType, byte[] parameters) { + public byte[] buildCommandPayload(RileyLinkServiceData rileyLinkServiceData, byte commandType, byte[] parameters) { // A7 31 65 51 C0 00 52 byte commandLength = (byte) (parameters == null ? 2 : 2 + parameters.length); @@ -264,7 +254,7 @@ public class MedtronicUtil extends RileyLinkUtil { ByteBuffer sendPayloadBuffer = ByteBuffer.allocate(ENVELOPE_SIZE + commandLength); // + CRC_SIZE sendPayloadBuffer.order(ByteOrder.BIG_ENDIAN); - byte[] serialNumberBCD = RileyLinkUtil.getRileyLinkServiceData().pumpIDBytes; + byte[] serialNumberBCD = rileyLinkServiceData.pumpIDBytes; sendPayloadBuffer.put((byte) 0xA7); sendPayloadBuffer.put(serialNumberBCD[0]); @@ -285,8 +275,7 @@ public class MedtronicUtil extends RileyLinkUtil { byte[] payload = sendPayloadBuffer.array(); - if (L.isEnabled(L.PUMPCOMM)) - LOG.debug("buildCommandPayload [{}]", ByteUtil.shortHexString(payload)); + aapsLogger.debug(LTag.PUMPCOMM, "buildCommandPayload [{}]", ByteUtil.shortHexString(payload)); // int crc = computeCRC8WithPolynomial(payload, 0, payload.length - 1); @@ -300,7 +289,7 @@ public class MedtronicUtil extends RileyLinkUtil { // Note: at the moment supported only for 24 items, if you will use it for more than // that you will need to add - public static List> getBasalProfileFrames(byte[] data) { + public List> getBasalProfileFrames(byte[] data) { boolean done = false; int start = 0; @@ -372,7 +361,7 @@ public class MedtronicUtil extends RileyLinkUtil { } - private static void checkAndAppenLastFrame(List frameData) { + private void checkAndAppenLastFrame(List frameData) { if (frameData.size() == BIG_FRAME_LENGTH) return; @@ -385,7 +374,7 @@ public class MedtronicUtil extends RileyLinkUtil { } - private static boolean isEmptyFrame(List frameData) { + private boolean isEmptyFrame(List frameData) { for (Byte frameDateEntry : frameData) { if (frameDateEntry != 0x00) { @@ -401,92 +390,43 @@ public class MedtronicUtil extends RileyLinkUtil { return lowLevelDebug; } - - public static void setLowLevelDebug(boolean lowLevelDebug) { - MedtronicUtil.lowLevelDebug = lowLevelDebug; + public boolean isModelSet() { + return medtronicPumpModel != null; } - - public static PumpDeviceState getPumpDeviceState() { - return pumpDeviceState; + public MedtronicDeviceType getMedtronicPumpModel() { + return medtronicPumpModel; } - - public static void setPumpDeviceState(PumpDeviceState pumpDeviceState) { - MedtronicUtil.pumpDeviceState = pumpDeviceState; - - historyRileyLink.add(new RLHistoryItem(pumpDeviceState, RileyLinkTargetDevice.MedtronicPump)); - - RxBus.Companion.getINSTANCE().send(new EventMedtronicDeviceStatusChange(pumpDeviceState)); + public void setMedtronicPumpModel(MedtronicDeviceType medtronicPumpModel) { + this.medtronicPumpModel = medtronicPumpModel; } - - public static boolean isModelSet() { - return MedtronicUtil.medtronicPumpModel != null; + public MedtronicCommandType getCurrentCommand() { + return this.currentCommand; } - - public static MedtronicDeviceType getMedtronicPumpModel() { - return MedtronicUtil.medtronicPumpModel; - } - - - public static void setMedtronicPumpModel(MedtronicDeviceType medtronicPumpModel) { - MedtronicUtil.medtronicPumpModel = medtronicPumpModel; - } - - - public static MedtronicCommunicationManager getMedtronicCommunicationManager() { - return (MedtronicCommunicationManager) RileyLinkUtil.rileyLinkCommunicationManager; - } - - - public static RileyLinkMedtronicService getMedtronicService() { - return MedtronicUtil.medtronicService; - } - - - public static void setMedtronicService(RileyLinkMedtronicService medtronicService) { - MedtronicUtil.medtronicService = medtronicService; - } - - - public static MedtronicPumpStatus getPumpStatus() { - return MedtronicUtil.medtronicPumpStatus; - } - - - public static void setPumpStatus(MedtronicPumpStatus medtronicPumpStatus) { - MedtronicUtil.medtronicPumpStatus = medtronicPumpStatus; - } - - - public static MedtronicCommandType getCurrentCommand() { - return MedtronicUtil.currentCommand; - } - - - public static void setCurrentCommand(MedtronicCommandType currentCommand) { - MedtronicUtil.currentCommand = currentCommand; + public void setCurrentCommand(MedtronicCommandType currentCommand) { + this.currentCommand = currentCommand; if (currentCommand != null) - historyRileyLink.add(new RLHistoryItem(currentCommand)); + rileyLinkUtil.getRileyLinkHistory().add(new RLHistoryItem(currentCommand)); } - public static int pageNumber; - public static Integer frameNumber; + public int pageNumber; + public Integer frameNumber; - public static void setCurrentCommand(MedtronicCommandType currentCommand, int pageNumber_, Integer frameNumber_) { + public void setCurrentCommand(MedtronicCommandType currentCommand, int pageNumber_, Integer frameNumber_) { pageNumber = pageNumber_; frameNumber = frameNumber_; - if (MedtronicUtil.currentCommand != currentCommand) { + if (this.currentCommand != currentCommand) { setCurrentCommand(currentCommand); } - RxBus.Companion.getINSTANCE().send(new EventMedtronicDeviceStatusChange(pumpDeviceState)); + rxBus.send(new EventMedtronicDeviceStatusChange(medtronicPumpStatus.getPumpDeviceState())); } @@ -497,33 +437,19 @@ public class MedtronicUtil extends RileyLinkUtil { } - public static Map getSettings() { + public Map getSettings() { return settings; } - - public static void setSettings(Map settings) { - MedtronicUtil.settings = settings; + public void setSettings(Map settings) { + this.settings = settings; } - - public static void setPumpTime(ClockDTO pumpTime) { - MedtronicUtil.pumpTime = pumpTime; + public void setPumpTime(ClockDTO pumpTime) { + this.pumpTime = pumpTime; } - - public static ClockDTO getPumpTime() { - return MedtronicUtil.pumpTime; + public ClockDTO getPumpTime() { + return this.pumpTime; } - - public static void setBatteryType(BatteryType batteryType) { - MedtronicUtil.batteryType = batteryType; - } - - - public static BatteryType getBatteryType() { - return MedtronicUtil.batteryType; - } - - } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/treatments/TreatmentService.java b/app/src/main/java/info/nightscout/androidaps/plugins/treatments/TreatmentService.java index a6207e595b..6e250bd851 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/treatments/TreatmentService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/treatments/TreatmentService.java @@ -40,6 +40,7 @@ import info.nightscout.androidaps.logging.L; import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; import info.nightscout.androidaps.plugins.bus.RxBus; import info.nightscout.androidaps.plugins.iob.iobCobCalculator.events.EventNewHistoryData; +import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.data.MedtronicHistoryData; import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; import info.nightscout.androidaps.utils.FabricPrivacy; @@ -265,9 +266,9 @@ public class TreatmentService extends OrmLiteBaseService { if (treatment != null) { if (MedtronicHistoryData.doubleBolusDebug) - log.debug("DoubleBolusDebug: createTreatmentFromJsonIfNotExists:: medtronicPump={}", MedtronicUtil.isMedtronicPump()); + log.debug("DoubleBolusDebug: createTreatmentFromJsonIfNotExists:: medtronicPump={}", MedtronicPumpPlugin.getPlugin().isEnabled()); - if (!MedtronicUtil.isMedtronicPump()) + if (!MedtronicPumpPlugin.getPlugin().isEnabled()) createOrUpdate(treatment); else createOrUpdateMedtronic(treatment, true); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/treatments/TreatmentsPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/treatments/TreatmentsPlugin.java index c91e06a4a0..f5a514b24e 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/treatments/TreatmentsPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/treatments/TreatmentsPlugin.java @@ -8,6 +8,7 @@ import androidx.annotation.NonNull; import androidx.annotation.Nullable; import com.google.firebase.analytics.FirebaseAnalytics; +import com.google.gson.GsonBuilder; import org.jetbrains.annotations.NotNull; @@ -56,7 +57,6 @@ import info.nightscout.androidaps.plugins.general.overview.notifications.Notific import info.nightscout.androidaps.plugins.iob.iobCobCalculator.AutosensResult; import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin; import info.nightscout.androidaps.plugins.pump.medtronic.data.MedtronicHistoryData; -import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; import info.nightscout.androidaps.utils.DateUtil; import info.nightscout.androidaps.utils.FabricPrivacy; import info.nightscout.androidaps.utils.T; @@ -300,13 +300,13 @@ public class TreatmentsPlugin extends PluginBase implements TreatmentsInterface long time = System.currentTimeMillis(); synchronized (treatments) { - getAapsLogger().debug(MedtronicHistoryData.doubleBolusDebug, LTag.DATATREATMENTS, "DoubleBolusDebug: AllTreatmentsInDb: " + MedtronicUtil.getGsonInstanceCore().toJson(treatments)); + getAapsLogger().debug(MedtronicHistoryData.doubleBolusDebug, LTag.DATATREATMENTS, "DoubleBolusDebug: AllTreatmentsInDb: " + new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create().toJson(treatments)); for (Treatment t : treatments) { if (t.date <= time && t.date >= fromTimestamp) in5minback.add(t); } - getAapsLogger().debug(MedtronicHistoryData.doubleBolusDebug, LTag.DATATREATMENTS, "DoubleBolusDebug: FilteredTreatments: AfterTime={}, Items={} " + fromTimestamp + " " + MedtronicUtil.getGsonInstanceCore().toJson(in5minback)); + getAapsLogger().debug(MedtronicHistoryData.doubleBolusDebug, LTag.DATATREATMENTS, "DoubleBolusDebug: FilteredTreatments: AfterTime={}, Items={} " + fromTimestamp + " " + new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create().toJson(in5minback)); return in5minback; } } @@ -452,7 +452,7 @@ public class TreatmentsPlugin extends PluginBase implements TreatmentsInterface TemporaryBasal runningTBR = getTempBasalFromHistory(i); double running = basal; if (runningTBR != null) { - running = runningTBR.tempBasalConvertedToAbsolute(i, profile); + running = runningTBR.tempBasalConvertedToAbsolute(i, profile); } Treatment treatment = new Treatment(getInjector()); treatment.date = i; diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/treatments/fragments/TreatmentsCareportalFragment.kt b/app/src/main/java/info/nightscout/androidaps/plugins/treatments/fragments/TreatmentsCareportalFragment.kt index 956da1c30c..d7a5e99496 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/treatments/fragments/TreatmentsCareportalFragment.kt +++ b/app/src/main/java/info/nightscout/androidaps/plugins/treatments/fragments/TreatmentsCareportalFragment.kt @@ -37,6 +37,7 @@ class TreatmentsCareportalFragment : DaggerFragment() { @Inject lateinit var sp: SP @Inject lateinit var resourceHelper: ResourceHelper @Inject lateinit var fabricPrivacy: FabricPrivacy + @Inject lateinit var translator: Translator override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? { @@ -108,7 +109,7 @@ class TreatmentsCareportalFragment : DaggerFragment() { holder.date.text = DateUtil.dateAndTimeString(careportalEvent.date) holder.duration.text = if (careportalEvent.durationInMsec() == 0L) "" else DateUtil.niceTimeScalar(careportalEvent.durationInMsec(), resourceHelper) holder.note.text = careportalEvent.notes - holder.type.text = Translator.translate(careportalEvent.eventType) + holder.type.text = translator.translate(careportalEvent.eventType) holder.remove.tag = careportalEvent } @@ -129,7 +130,7 @@ class TreatmentsCareportalFragment : DaggerFragment() { remove.setOnClickListener { v: View -> val careportalEvent = v.tag as CareportalEvent activity?.let { activity -> - val text = resourceHelper.gs(R.string.careportal_newnstreatment_eventtype) + ": " + Translator.translate(careportalEvent.eventType) + "\n" + + val text = resourceHelper.gs(R.string.careportal_newnstreatment_eventtype) + ": " + translator.translate(careportalEvent.eventType) + "\n" + resourceHelper.gs(R.string.careportal_newnstreatment_notes_label) + ": " + careportalEvent.notes + "\n" + resourceHelper.gs(R.string.date) + ": " + DateUtil.dateAndTimeString(careportalEvent.date) OKDialog.showConfirmation(activity, resourceHelper.gs(R.string.removerecord), text, Runnable { diff --git a/app/src/main/java/info/nightscout/androidaps/receivers/TimeDateOrTZChangeReceiver.kt b/app/src/main/java/info/nightscout/androidaps/receivers/TimeDateOrTZChangeReceiver.kt index 46cf58d99f..916239ae82 100644 --- a/app/src/main/java/info/nightscout/androidaps/receivers/TimeDateOrTZChangeReceiver.kt +++ b/app/src/main/java/info/nightscout/androidaps/receivers/TimeDateOrTZChangeReceiver.kt @@ -15,13 +15,12 @@ import javax.inject.Inject class TimeDateOrTZChangeReceiver : DaggerBroadcastReceiver() { @Inject lateinit var aapsLogger: AAPSLogger @Inject lateinit var activePlugin: ActivePluginProvider - var gson: Gson + val gson: Gson = Gson() private var isDST = false init { isDST = calculateDST() - gson = Gson() } private fun calculateDST(): Boolean { @@ -38,10 +37,6 @@ class TimeDateOrTZChangeReceiver : DaggerBroadcastReceiver() { super.onReceive(context, intent) val action = intent.action val activePump: PumpInterface = activePlugin.activePump - if (activePump == null) { - aapsLogger.debug(LTag.PUMP,"TimeDateOrTZChangeReceiver::Time and/or TimeZone changed. [action={}]. Pump is null, exiting.", action) - return - } aapsLogger.debug(LTag.PUMP,"TimeDateOrTZChangeReceiver::Date, Time and/or TimeZone changed. [action={}]", action) aapsLogger.debug(LTag.PUMP,"TimeDateOrTZChangeReceiver::Intent::{}", gson.toJson(intent)) diff --git a/app/src/main/java/info/nightscout/androidaps/utils/NumberPicker.java b/app/src/main/java/info/nightscout/androidaps/utils/NumberPicker.java index 7ffabaec82..775582473e 100644 --- a/app/src/main/java/info/nightscout/androidaps/utils/NumberPicker.java +++ b/app/src/main/java/info/nightscout/androidaps/utils/NumberPicker.java @@ -5,7 +5,6 @@ import android.os.Handler; import android.os.Message; import android.text.Editable; import android.text.TextWatcher; -import android.text.method.DigitsKeyListener; import android.util.AttributeSet; import android.view.KeyEvent; import android.view.LayoutInflater; @@ -15,24 +14,18 @@ import android.widget.Button; import android.widget.EditText; import android.widget.LinearLayout; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import java.text.NumberFormat; import java.util.concurrent.Executors; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.TimeUnit; -import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.R; -import info.nightscout.androidaps.logging.StacktraceLoggerWrapper; /** * Created by mike on 28.06.2016. */ public class NumberPicker extends LinearLayout implements View.OnKeyListener, View.OnTouchListener, View.OnClickListener { - private static Logger log = StacktraceLoggerWrapper.getLogger(NumberPicker.class); public interface OnValueChangedListener { void onValueChanged(double value); @@ -172,14 +165,14 @@ public class NumberPicker extends LinearLayout implements View.OnKeyListener, value = SafeParse.stringToDouble(editText.getText().toString()); if (value > maxValue) { value = maxValue; - ToastUtils.showToastInUiThread(MainApp.instance().getApplicationContext(), MainApp.gs(R.string.youareonallowedlimit)); + ToastUtils.showToastInUiThread(getContext(), getContext().getString(R.string.youareonallowedlimit)); updateEditText(); if (okButton != null) okButton.setVisibility(VISIBLE); } if (value < minValue) { value = minValue; - ToastUtils.showToastInUiThread(MainApp.instance().getApplicationContext(), MainApp.gs(R.string.youareonallowedlimit)); + ToastUtils.showToastInUiThread(getContext(), getContext().getString(R.string.youareonallowedlimit)); updateEditText(); if (okButton != null) okButton.setVisibility(VISIBLE); @@ -244,7 +237,7 @@ public class NumberPicker extends LinearLayout implements View.OnKeyListener, if (value > maxValue) { value = maxValue; callValueChangedListener(); - ToastUtils.showToastInUiThread(MainApp.instance().getApplicationContext(), MainApp.gs(R.string.youareonallowedlimit)); + ToastUtils.showToastInUiThread(getContext(), getContext().getString(R.string.youareonallowedlimit)); stopUpdating(); } updateEditText(); @@ -255,7 +248,7 @@ public class NumberPicker extends LinearLayout implements View.OnKeyListener, if (value < minValue) { value = minValue; callValueChangedListener(); - ToastUtils.showToastInUiThread(MainApp.instance().getApplicationContext(), MainApp.gs(R.string.youareonallowedlimit)); + ToastUtils.showToastInUiThread(getContext(), getContext().getString(R.string.youareonallowedlimit)); stopUpdating(); } updateEditText(); @@ -275,7 +268,7 @@ public class NumberPicker extends LinearLayout implements View.OnKeyListener, private void startUpdating(boolean inc) { if (mUpdater != null) { - log.debug("Another executor is still active"); + //log.debug("Another executor is still active"); return; } mUpdater = Executors.newSingleThreadScheduledExecutor(); diff --git a/app/src/main/java/info/nightscout/androidaps/utils/ToastUtils.java b/app/src/main/java/info/nightscout/androidaps/utils/ToastUtils.java index 26062011f6..ec165e4ba5 100644 --- a/app/src/main/java/info/nightscout/androidaps/utils/ToastUtils.java +++ b/app/src/main/java/info/nightscout/androidaps/utils/ToastUtils.java @@ -14,7 +14,6 @@ import android.widget.Toast; import androidx.annotation.DrawableRes; import androidx.appcompat.view.ContextThemeWrapper; -import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.R; import info.nightscout.androidaps.plugins.bus.RxBusWrapper; import info.nightscout.androidaps.plugins.general.overview.events.EventNewNotification; @@ -30,20 +29,20 @@ public class ToastUtils { } public static void infoToast(final Context ctx, final String string) { - graphicalToast(ctx, string, R.drawable.ic_toast_info,false); + graphicalToast(ctx, string, R.drawable.ic_toast_info, false); } public static void okToast(final Context ctx, final String string) { - graphicalToast(ctx, string, R.drawable.ic_toast_check,false); + graphicalToast(ctx, string, R.drawable.ic_toast_check, false); } public static void errorToast(final Context ctx, final String string) { - graphicalToast(ctx, string, R.drawable.ic_toast_error,false); + graphicalToast(ctx, string, R.drawable.ic_toast_error, false); } } public static void showToastInUiThread(final Context ctx, final int stringId) { - showToastInUiThread(ctx, MainApp.gs(stringId)); + showToastInUiThread(ctx, ctx.getString(stringId)); } public static void warnToast(final Context ctx, final String string) { @@ -70,7 +69,7 @@ public class ToastUtils { public static void graphicalToast(final Context ctx, final String string, @DrawableRes int iconId, boolean isShort) { Handler mainThread = new Handler(Looper.getMainLooper()); mainThread.post(() -> { - View toastRoot =LayoutInflater.from(new ContextThemeWrapper(ctx, R.style.AppTheme)).inflate(R.layout.toast, null); + View toastRoot = LayoutInflater.from(new ContextThemeWrapper(ctx, R.style.AppTheme)).inflate(R.layout.toast, null); TextView toastMessage = toastRoot.findViewById(android.R.id.message); toastMessage.setText(string); @@ -86,9 +85,7 @@ public class ToastUtils { public static void showToastInUiThread(final Context ctx, final String string) { Handler mainThread = new Handler(Looper.getMainLooper()); - mainThread.post(() -> { - Toast.makeText(ctx, string, Toast.LENGTH_SHORT).show(); - }); + mainThread.post(() -> Toast.makeText(ctx, string, Toast.LENGTH_SHORT).show()); } public static void showToastInUiThread(final Context ctx, final RxBusWrapper rxBus, diff --git a/app/src/main/java/info/nightscout/androidaps/utils/Translator.java b/app/src/main/java/info/nightscout/androidaps/utils/Translator.java deleted file mode 100644 index e25c083a7b..0000000000 --- a/app/src/main/java/info/nightscout/androidaps/utils/Translator.java +++ /dev/null @@ -1,65 +0,0 @@ -package info.nightscout.androidaps.utils; - -import info.nightscout.androidaps.MainApp; -import info.nightscout.androidaps.R; - -/** - * Created by mike on 15.07.2016. - */ -public class Translator { - - public static String translate(String text) { - switch (text) { - - case "BG Check": - return MainApp.gs(R.string.careportal_bgcheck); - case "Snack Bolus": - return MainApp.gs(R.string.careportal_snackbolus); - case "Meal Bolus": - return MainApp.gs(R.string.careportal_mealbolus); - case "Correction Bolus": - return MainApp.gs(R.string.careportal_correctionbolus); - case "Carb Correction": - return MainApp.gs(R.string.careportal_carbscorrection); - case "Combo Bolus": - return MainApp.gs(R.string.careportal_combobolus); - case "Announcement": - return MainApp.gs(R.string.careportal_announcement); - case "Note": - return MainApp.gs(R.string.careportal_note); - case "Question": - return MainApp.gs(R.string.careportal_question); - case "Exercise": - return MainApp.gs(R.string.careportal_exercise); - case "Site Change": - return MainApp.gs(R.string.careportal_pumpsitechange); - case "Pump Battery Change": - return MainApp.gs(R.string.careportal_pumpbatterychange); - case "Sensor Start": - return MainApp.gs(R.string.careportal_cgmsensorstart); - case "Sensor Change": - return MainApp.gs(R.string.careportal_cgmsensorinsert); - case "Insulin Change": - return MainApp.gs(R.string.careportal_insulincartridgechange); - case "Temp Basal Start": - return MainApp.gs(R.string.careportal_tempbasalstart); - case "Temp Basal End": - return MainApp.gs(R.string.careportal_tempbasalend); - case "Profile Switch": - return MainApp.gs(R.string.careportal_profileswitch); - case "Temporary Target": - return MainApp.gs(R.string.careportal_temporarytarget); - case "Temporary Target Cancel": - return MainApp.gs(R.string.careportal_temporarytargetcancel); - case "OpenAPS Offline": - return MainApp.gs(R.string.careportal_openapsoffline); - case "Finger": - return MainApp.gs(R.string.glucosetype_finger); - case "Sensor": - return MainApp.gs(R.string.glucosetype_sensor); - case "Manual": - return MainApp.gs(R.string.manual); - } - return text; - } -} diff --git a/app/src/main/java/info/nightscout/androidaps/utils/Translator.kt b/app/src/main/java/info/nightscout/androidaps/utils/Translator.kt new file mode 100644 index 0000000000..b68fb74194 --- /dev/null +++ b/app/src/main/java/info/nightscout/androidaps/utils/Translator.kt @@ -0,0 +1,44 @@ +package info.nightscout.androidaps.utils + +import info.nightscout.androidaps.R +import info.nightscout.androidaps.utils.resources.ResourceHelper +import javax.inject.Inject +import javax.inject.Singleton + +/** + * Created by mike on 15.07.2016. + */ +@Singleton +class Translator @Inject internal constructor( + private val resourceHelper: ResourceHelper +) { + + fun translate(text: String): String = + when (text) { + "BG Check" -> resourceHelper.gs(R.string.careportal_bgcheck) + "Snack Bolus" -> resourceHelper.gs(R.string.careportal_snackbolus) + "Meal Bolus" -> resourceHelper.gs(R.string.careportal_mealbolus) + "Correction Bolus" -> resourceHelper.gs(R.string.careportal_correctionbolus) + "Carb Correction" -> resourceHelper.gs(R.string.careportal_carbscorrection) + "Combo Bolus" -> resourceHelper.gs(R.string.careportal_combobolus) + "Announcement" -> resourceHelper.gs(R.string.careportal_announcement) + "Note" -> resourceHelper.gs(R.string.careportal_note) + "Question" -> resourceHelper.gs(R.string.careportal_question) + "Exercise" -> resourceHelper.gs(R.string.careportal_exercise) + "Site Change" -> resourceHelper.gs(R.string.careportal_pumpsitechange) + "Pump Battery Change" -> resourceHelper.gs(R.string.careportal_pumpbatterychange) + "Sensor Start" -> resourceHelper.gs(R.string.careportal_cgmsensorstart) + "Sensor Change" -> resourceHelper.gs(R.string.careportal_cgmsensorinsert) + "Insulin Change" -> resourceHelper.gs(R.string.careportal_insulincartridgechange) + "Temp Basal Start" -> resourceHelper.gs(R.string.careportal_tempbasalstart) + "Temp Basal End" -> resourceHelper.gs(R.string.careportal_tempbasalend) + "Profile Switch" -> resourceHelper.gs(R.string.careportal_profileswitch) + "Temporary Target" -> resourceHelper.gs(R.string.careportal_temporarytarget) + "Temporary Target Cancel" -> resourceHelper.gs(R.string.careportal_temporarytargetcancel) + "OpenAPS Offline" -> resourceHelper.gs(R.string.careportal_openapsoffline) + "Finger" -> resourceHelper.gs(R.string.glucosetype_finger) + "Sensor" -> resourceHelper.gs(R.string.glucosetype_sensor) + "Manual" -> resourceHelper.gs(R.string.manual) + else -> resourceHelper.gs(R.string.unknown) + } +} \ No newline at end of file diff --git a/app/src/main/java/info/nightscout/androidaps/utils/stats/TddCalculator.kt b/app/src/main/java/info/nightscout/androidaps/utils/stats/TddCalculator.kt index 247d4c22d4..0dc0cab7f3 100644 --- a/app/src/main/java/info/nightscout/androidaps/utils/stats/TddCalculator.kt +++ b/app/src/main/java/info/nightscout/androidaps/utils/stats/TddCalculator.kt @@ -92,14 +92,14 @@ class TddCalculator @Inject constructor( "" + resourceHelper.gs(R.string.tdd) + ":
" + toText(tdds) + "" + resourceHelper.gs(R.string.average) + ":
" + - averageTdd.toText(tdds.size()) + averageTdd.toText(resourceHelper, tdds.size()) ) } private fun toText(tdds: LongSparseArray): String { var t = "" for (i in 0 until tdds.size()) { - t += "${tdds.valueAt(i).toText()}
" + t += "${tdds.valueAt(i).toText(resourceHelper)}
" } return t } diff --git a/app/src/main/res/layout/rileylink_status_general.xml b/app/src/main/res/layout/rileylink_status_general.xml index e1a841b301..42f5cd5abb 100644 --- a/app/src/main/res/layout/rileylink_status_general.xml +++ b/app/src/main/res/layout/rileylink_status_general.xml @@ -2,7 +2,7 @@ xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" - tools:context=".plugins.pump.common.hw.rileylink.dialog.RileyLinkStatusGeneral"> + tools:context=".plugins.pump.common.hw.rileylink.dialog.RileyLinkStatusGeneralFragment"> + tools:context=".plugins.pump.common.hw.rileylink.dialog.RileyLinkStatusHistoryFragment"> Delta: Konfigurasie bouer Doelstellings - OpenAPS MA Oorsig Ns Profiel Maklike profiel diff --git a/app/src/main/res/values-bg-rBG/objectives.xml b/app/src/main/res/values-bg-rBG/objectives.xml index 633ff84c99..16339650fd 100644 --- a/app/src/main/res/values-bg-rBG/objectives.xml +++ b/app/src/main/res/values-bg-rBG/objectives.xml @@ -46,6 +46,9 @@ Код (request code): %1$s (отбележете всички правилни отговори) https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#what-to-do-when-taking-a-shower-or-bath + https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/Screenshots.html#the-homescreen + https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/Screenshots.html#config-builder + https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/Screenshots.html#the-homescreen Няма връзка с Интернет! Не може да се вземе времето Задачите не са изпълнени diff --git a/app/src/main/res/values-bg-rBG/strings.xml b/app/src/main/res/values-bg-rBG/strings.xml index d508c88e48..2811beea92 100644 --- a/app/src/main/res/values-bg-rBG/strings.xml +++ b/app/src/main/res/values-bg-rBG/strings.xml @@ -43,6 +43,7 @@ Писалки - За хората, които правят множество ежедневни инжекции ( интензифицирано лечение с писалки) За помпи, който все още не работят с AndroidAPS(Open Loop) Чувствителността се изчислява по същия начин като в Oref0, но можете да зададете времева рамка. Минимална въглехидрати абсорбция се изчислява от Макс време за усвояване на въглехидратите в опциите. + Чувствителността се изчислява за 8 или 24 назад в миналото, а въглехидрати (ако не са се абсорбирали) изчезват след изтичане на срока от настройките. Това е необходимо за изчисление на необявени хранения (UAM). Чувствителността се изчислява като среднопретеглена стойност от отклоненията. По-новите отклонения имат по-високо тегло. Минималната абсорбция на въглехидрати се изчислява от Време за макс усвояване на въглехидрати от опциите. Този алгоритъм е най-бързият при проследяването на промени в чувствителността. Получава данни за КЗ от модифицираното приложение на Eversense. Получава данни за КЗ от Glimp. @@ -105,7 +106,6 @@ Изменение (делта): Конфигурация Цели - OpenAPS МА Общ NS Профил Обикновен профил @@ -543,8 +543,6 @@ Разреши използването на Суперболус Разреши функцията суперболус в съветника. Не я разрешавайте докато не научите какво наистина прави. ТОВА МОЖЕ ДА СЪЗДАДЕ ОПАСНОСТ ОТ ПРЕДОЗИРАНЕ С ИНСУЛИН. Покажи статус светлини на началния екран - Покажи статус светлини с подробности на началния екран - Показвай подробни статус светлини за канула, инсулин, сензор, резервоар и батерията на началния екран. Ниво за аларма за останал инсулин в резервоара [Е] Критично ниво на останал инсулин в резервоар [Е] Аларма при заряд на батерия под [%] @@ -979,6 +977,7 @@ Внимание: Ако активирате и свържете с хардуерна помпа, AndroidAPS ще копира основните настройки от профила в помпата, като презапише съществуващата базова скорост, съхранявана на помпата. Уверете се, че имате правилните основни настройки в AndroidAPS. Ако не сте сигурни или не искате да презапишете основните настройки на помпата, натиснете Cancel и повторете превключването към помпата по-късно. Данните за лечението не са пълни Настройки за поддръжка + Имейл Брой логове за изпращане Поддръжка ПОДДР diff --git a/app/src/main/res/values-cs-rCZ/objectives.xml b/app/src/main/res/values-cs-rCZ/objectives.xml index b47865c3ef..bbebc9fc02 100644 --- a/app/src/main/res/values-cs-rCZ/objectives.xml +++ b/app/src/main/res/values-cs-rCZ/objectives.xml @@ -20,7 +20,9 @@ Jeden týden úspěšného používání s běžným příjmem sacharidů Povolení doplňkový funkcí pro každodenní použití, jako např. pokročilý jídelní asistent (AMA) Povolit další funkce pro běžné používání jako SMB + Povolení automatizace Přečíst si dokumentaci a zvýšit maximální IOB, aby mohlo SMB fungovat. Pro začátek se dá použít velikost běžného bolusu + 3x maximální denní bazál + Přečtěte si na wiki, jak automatizace funguje. Nejdříve nastavte pouze jednoduchá pravidla. Namísto provádění akcí nechte AAPS zobrazovat pouze oznámení. Pokud jste si jistí, že je automatizace je spuštěna v pravý čas, můžete oznámení nahradit prováděním akce. (https://androidaps.readdocs.io/en/latest/CROWDIN/cs/Usage/Automation.html) Glykémie dostupná v NS Stav pumpy dostupný v NS Ručně spuštěno diff --git a/app/src/main/res/values-cs-rCZ/protection.xml b/app/src/main/res/values-cs-rCZ/protection.xml index 07c76f4ff9..01ec1022d6 100644 --- a/app/src/main/res/values-cs-rCZ/protection.xml +++ b/app/src/main/res/values-cs-rCZ/protection.xml @@ -4,4 +4,20 @@ Položte prst na čtečku otisků prstů pro ověření vaší totožnosti Ochrana nastavení Ochrana aplikace + Ochrana bolusu + Hlavní heslo + Heslo pro nastavení + Heslo aplikace + Heslo pro bolus + Odemknout nastavení + Biometrie + Vlastní heslo + Bez ochrany + Ochrana + Hlavní heslo není nastaveno!\n\nProsím nastavte své hlavní heslo v Preferencích (%1$s → %2$s) + Heslo nastaveno! + Heslo není nastavené + Heslo nezměněno + Heslo vymazáno! + Zadejte heslo diff --git a/app/src/main/res/values-cs-rCZ/strings.xml b/app/src/main/res/values-cs-rCZ/strings.xml index 281a97be63..52cdbe4638 100644 --- a/app/src/main/res/values-cs-rCZ/strings.xml +++ b/app/src/main/res/values-cs-rCZ/strings.xml @@ -106,7 +106,6 @@ Rozdíl: Konfigurace Cíle - OpenAPS MA Přehled NS profil Jednoduchý profil @@ -585,8 +584,14 @@ Povolit superbolus Povolení superbolusu v kalkulátoru. Nepovolujte, dokud se nenaučíte, co to opravdu dělá. MŮŽE ZPŮSOBIT PŘEDÁVKOVÁNÍ INZULÍNEM PŘI NESPRÁVNÉM POUŽITÍ! Zobrazit stavové indikátory na domovské obrazovce - Zobrazit rozšířené stavové indikátory na domovské obrazovce - Povolí rozšířené stavové indikátory pro stáří kanyly, inzulínu, senzoru, zásobníku a baterie na domovské obrazovce. + Úroveň varování stáří kanyly [h] + Úroveň kritického stáří kanyly [h] + Úroveň varování stáří inzulínu [h] + Úroveň kritického stáří inzulínu [h] + Úroveň varování stáří senzoru [h] + Úroveň kritického stáří senzoru [h] + Úroveň varování stáří baterie [h] + Úroveň kritického varování stáří baterie [h] Úroveň varování stavu zásobníku [U] Úroveň kritického varování stavu zásobníku [U] Úroveň varování stavu baterie [%] @@ -1523,4 +1528,12 @@ Při odpojení Predikce Odchylka sklonu + Autorizace selhala + Absolutní inzulin + Hlavní heslo se používá pro šifrování zálohy a pro \"přebití\" zabezpečení v aplikaci. Dobře si ho zapamatujte nebo uložte na bezpečném místě. + Hesla se neshodují + Aktuální hlavní heslo + Stavové indikátory + Zkopírovat nastavení z NS + Zkopírovat nastavení NS (existuje-li)? diff --git a/app/src/main/res/values-de-rDE/objectives.xml b/app/src/main/res/values-de-rDE/objectives.xml index e094670b18..b9ea574d3e 100644 --- a/app/src/main/res/values-de-rDE/objectives.xml +++ b/app/src/main/res/values-de-rDE/objectives.xml @@ -20,8 +20,10 @@ Loope eine Woche tagsüber mit regelmäßiger Kohlenhydrat-Eingabe Aktiviere zusätzliche Funktionen für die Nutzung tagsüber wie z. B. den erweiterten Mahlzeitenassistenten (AMA) Aktiviere zusätzliche Funktionen für die Nutzung tagsüber wie z. B. SMB + Automatisierung aktivieren Lies das Wiki und erhöhe maxIOB, damit der SMB gut funktioniert. Ein guter Anfang ist die Formel maxIOB = durchschnittlicher Essensbolus + 3 x höchste Basalrate + Lies in den Docs wie Automatisierung funktioniert und erstelle dann eine erste einfache Regel. Verwende eine Benachrichtigung statt der tatsächlichen Aktion. Wenn die Automatisierung zum richtigen Zeitpunkt auslöst, ersetze die Benachrichtigung durch die gewünschte Aktion. (https://androidaps.readthedocs.io/en/latest/CROWDIN/de/Usage/Automation.html) BZ in Nightscout verfügbar Pumpen-Status in Nightscout verfügbar Manuelle Aktionen diff --git a/app/src/main/res/values-de-rDE/protection.xml b/app/src/main/res/values-de-rDE/protection.xml index 3ea04e700d..0c6f2dd337 100644 --- a/app/src/main/res/values-de-rDE/protection.xml +++ b/app/src/main/res/values-de-rDE/protection.xml @@ -1,2 +1,23 @@ - + + Authentifizierung erforderlich + Legen Deinen Finger auf den Fingerabdrucksensors, um Deine Identität zu bestätigen. + Schutz der Einstellungen + Schutz der App + Bolus-Schutz + Master-Passwort + Passwort für Einstellungen + Anwendungspasswort + Passwort für Boli + Einstellungen freischalten + Biometrisch + Benutzerdefiniertes Passwort + Kein Schutz + Schutz + Das Master-Passwort ist nicht festgelegt!\n\nLege Dein Master-Passwort bitte in en Einstellungen fest (%1$s → %2$s) + Passwort festgelegt! + Passwort nicht festgelegt + Passwort nicht geändert + Passwort gelöscht! + Passwort hier eingeben + diff --git a/app/src/main/res/values-de-rDE/strings.xml b/app/src/main/res/values-de-rDE/strings.xml index 0418722968..db4a75a29c 100644 --- a/app/src/main/res/values-de-rDE/strings.xml +++ b/app/src/main/res/values-de-rDE/strings.xml @@ -43,6 +43,7 @@ Pumpen-Integration für Personen, die täglich mehrere Injektionen für ihre Diabetestherapie vornehmen Pumpen-Integration für Pumpen, die noch nicht über einen Treiber verfügen (Open Loop) Die Sensitivität wird genauso wie bei Oref0 berechnet, aber Du kannst dafür ein Zeitfenster bestimmen. Die minimale Kohlenhydrat-Absorptionsrate wird aus der maximalen Absorptionsdauer aus den Einstellungen abgeleitet. + Die Sensitivität wird aus den Daten der letzten 8 Stunden berechnet und Kohlenhydrate (falls nicht bereits absorbiert) werden nach der in den Einstellungen angegebenen Zeit als absorbiert betrachtet. Das Plugin bezieht Zeiträume, in denen UAM annimmt, dass Kohlenhydrate aktiv waren, nicht mit in die Berechnung ein. Die Sensitivität wird aus den Abweichungen errechnet. Dabei werden neuere Abweichungen stärker gewichtet als ältere. Die minimale Kohlenhydrat-Aufnahme wird aus der in den Präferenzen angegebenen maximalen Kohlenhydrat-Resorptionszeit abgeleitet. Dieser Algorithmus reagiert am schnellsten auf Änderungen der Empfindlichkeit. Empfange BZ-Werte von der gepatchten Eversense App. Empfange Blutzucker-Werte von Glimp. @@ -105,7 +106,6 @@ Delta: Konfiguration Zielsetzungen - OpenAPS MA Übersicht Nightscout-Profil Einfaches Profil @@ -218,6 +218,44 @@ Maximales Basal-IOB, das OpenAPS abgeben darf [IE] Maximale Menge von nicht Bolus-IOB, die OpenAPs abgeben kann. VERWERFEN + Du wirst nach dem Master-Passwort gefragt. Mit diesem werden die exportierten Einstellungen verschlüsselt. + Du wirst nach dem Master-Passwort gefragt. Mit diesem werden die importierten Einstellungen entschlüsselt. + Export abgebrochen! Einstellungen wurden NICHT exportiert! + Import abgebrochen! Einstellungen wurden NICHT importiert! + Überprüfe die Einstellungen vor dem Import: + Einstellungen können nicht importiert werden! + Einstellungen sollten nicht importiert werden! + Beschreibe die Import-Probleme... + Details zu den Import-Problemen + Importieren + Trotzdem importieren (GEFÄHRLICH!) + Einstellungen wurden mit einer anderen Variante von AAPS erstellt (%1$s). Du nutzt: %2$s.\n\nEinige Einstellungen können fehlen oder ungültig sein - überprüfe und aktualisiere Deine Einstellungen nach dem Import . + Einstellungen wurden auf einem anderen Gerät erstellt. Das ist OK, wenn Du von einem älteren/anderen Handy importierst. Stelle aber sicher, dass die importierten Einstellungen korrekt sind! + Du verwendest das veraltete Format einer alten AAPS-Version das nicht sicher ist! Verwende dieses nur als letzte Möglichkeit, wenn Du keinen Export im aktuellen JSON-Format hast. + Die importierten Einstellungen sind bereits %1$s Tage alt! Hast Du aktuellere Einstellungen oder evtl. die falsche Datei gewählt? Denke daran, die Einstellungen regelmäßig zu exportieren. + Ungültiges Datums-/Zeitformat! + Dateiformat + Erstellt am + AAPS-Version + Build-Variante + Patientenname des exportierenden Geräts + Modell des exportierenden Geräts + Dateiverschlüsselung + Altes Exportformat + Neues verschlüsseltes Format + Neues Debugformat (unverschlüsselt) + Unbekanntes Export-Format + Einstellungen-Datei wurde manipuliert. + Einstellungsdatei ist sicher. + Nicht sicheres, unverschlüsseltes Einstellungsformat verwenden + Fehler im JSON-Format, fehlendes erforderliches Feld (Format, Inhalt, Metadaten oder Sicherheit) + Entschlüsselungsfehler. Das angegebene Passwort kann die Datei nicht entschlüsseln. + Datei-Prüfsumme (hash) fehlt. Einstellungen können nicht auf Echtheit überprüft werden! + Datei wurde nach dem Export verändert! + Entschlüsselungsfehler, Analyse der Einstellungen fehlgeschlagen! + Entschlüsselungsfehler. Das angegebene Passwort ist ungültig oder die Einstellungsdatei wurde verändert! Evtl. wurde die importierte Datei mit einem anderen Master-Passwort exportiert. + Fehlende Verschlüsselungskonfiguration, Einstellungsformat ist ungültig! + Nicht unterstützter oder nicht angegebener Verschlüsselungsalgorithmus! DanaR Verbinden Verbunden @@ -507,6 +545,9 @@ Erwachsener Insulinresistenter Erwachsener Bitte wähle das Patientenalter, um die Sicherheits-Limits festzulegen + Name des Patienten + Gib den Namen des Patienten oder einen Spitznamen für die Unterscheidung zwischen mehreren Setups an. + Nutzer Glimp %1$s benötigt eine deaktivierte Akku-Leistungsoptimierung, um korrekt arbeiten zu können. Loop pausiert @@ -543,8 +584,14 @@ Aktiviere Superbolus im Wizard Aktiviere die SuperBolus-Funktion im Wizard. Nicht aktivieren, wenn Du nicht weißt, welche Auswirkungen dieser Bolus hat! ES KANN ZU EINER ÜBERDOSIERUNG AN INSULIN KOMMEN! Statusanzeige auf Homescreen - Erweiterte Statusanzeige auf Homescreen - Erweiterte Statusanzeige für CAGE, IAGE, SAGE, Reservoir- und Batteriestand auf dem Homescreen. + Warnschwelle Kanülenalter [h] + Warnschwelle kritisches Kanülenalter [h] + Warnschwelle Insulinalter [h] + Warnschwelle kritisches Insulinalter [h] + Warnschwelle Sensoralter [h] + Warnschwelle kritisches Sensoralter [h] + Warnschwelle Batteriealter [h] + Warnschwelle kritisches Batteriealter [h] Warnschwelle Reservoirstand [IE] Warnschwelle kritischer Reservoirstand [IE] Warnschwelle Batteriestand [%] @@ -704,8 +751,12 @@ BZ Upload Einstellungen Zeige detailliertes Delta Delta wird mit Dezimalstelle angezeigt. + Wie häufig SMBs angegeben werden (in Min.) SMB max. Minuten SMB Basal-Limit in Minuten + UAM SMB max minutes + SMB Basal-Limit in Minuten für UAM + Schwellenwert für KH-Empfehlung Nicht unterstützte Pumpen-Firmware Sende BZ-Werte zu xDrip+ Wähle in xDrip+ 640g/Eversense als Daten-Quelle. @@ -772,6 +823,7 @@ her %1$.2f h %1$d mins + %1$dm SMB immer aktivieren Aktiviere SMB immer, unabhängig von Boli. Dies ist nur möglich, wenn eine BZ-Quelle genutzt wird, die die Daten besonders gut filtert wie z. B. G5. Aktiviere SMB nach Mahlzeiten. @@ -970,6 +1022,10 @@ = 100.]]> Niedrige temporäre Ziele senken die Sensitivität + Resistenz senkt Zielwert + Wenn Resistenz festgestellt wird, senke den Glukose-Zielwert + Empfindlichkeit erhöht den Zielwert + Wenn eine höhere Empfindlichkeit festgestellt wird, wird der Glukose-Zielwert erhöht. Ungültige Pumpen-Einstellungen. Lies das Wiki und stelle mit der 360° Konfigurations-Software sicher, dass das Quick-Info-Menü \"QUICK INFO\" heißt. Benutzerdefiniert Große Zeitdifferenz @@ -979,6 +1035,8 @@ WARNUNG: Wenn Du eine echte Pumpe aktivierst und anschließt, kopiert AndroidAPS die Basaleinstellungen vom aktiven Profil zur Pumpe (und behält sie bei). Die Einstellungen in der Pumpe werden hierbei überschrieben. Wenn Du Dir nicht sicher bist oder die Basaleinstellungen in der Pumpe nicht überschreiben möchten, drücke \"Abbrechen\" und vollziehe den Wechsel zur Pumpe später. Behandlungsdaten unvollständig Wartungseinstellungen + E-Mail + Exportierte Einstellungen verschlüsseln Anzahl der zu sendenden Logs Wartung WRTNG @@ -1187,6 +1245,8 @@ Unerwartetes Verhalten. existiert existiert nicht Temporäres Ziel %1$s + Bluetooth-Verbindung mit Gerät %1$s %2$s + Mit Bluetooth-Gerät verbinden WiFi SSID %1$s %2$s Autosens %1$s %2$s %% Autosens % @@ -1241,6 +1301,7 @@ Unerwartetes Verhalten. Alkaline Batterie (erweiterte Ansicht) Lithium Batterie (erweiterte Ansicht) Nickel-Zink-Akku (erweiterte Ansicht) + Nickel-Zink-Akku (erweiterte Ansicht) Fehlersuche Bolus/Behandlungen SCANNEN @@ -1256,6 +1317,7 @@ Unerwartetes Verhalten. Scannt Scannen abgeschlossen Scanfehler: %1$d + Nie Einstellungen Verlauf @@ -1389,6 +1451,7 @@ Unerwartetes Verhalten. Ziel neu starten Zeiterkennung Möchtest Du den Start der Ziele zurücksetzen? Du verlierst Deine Fortschritte. + Zeit- und/oder Zeitzonenänderung an der Pumpe Keine Pumpe ausgewählt Wähle die Einheit, in der die Werte angezeigt werden sollen. Lade die Änderungen des lokalen Profils zu NS hoch. @@ -1445,4 +1508,34 @@ Unerwartetes Verhalten. Temp. BR Ausführungszeit Insight Pumpenalarme + von der Authentifizierungs-App für: %1$s + Authentifizierung einschalten + Authentifiziere Befehle mit Einmal-Passwörtern, die von Google Authenticator oder ähnlichen Apps zur 2-Faktor-Authentifizierung generiert wurden. + Zusätzliche PIN am Ende des Tokens + Zusätzliche Ziffern, die auswendig gelernt und am Ende jedes generierten Einmal-Passworts angehängt werden sollten. + Konfiguration des Authentifikators + Zu überprüfendes OTP: + Authentifikators zurücksetzen + Authentifikatorschlüssel zurücksetzen + Willst Du wirklich den Authentifikatorschlüssel zurücksetzen? Dies wird alle momentan genutzten Authentifikatoren ungültig machen und Du musst sie neu einrichten. + Neuer Authentifizierungsschlüssel generiert! Bitte verwende den aktualisierten QR-Code für die Bereitstellung von Authentifikatoren. + 1. Authentifikator installieren + 2. Scanne den Code zum Einrichten von AndroidAPS OTP-Codes + 3. Teste das Einmal-Passwort + Authentifikators zurücksetzen + Installiere auf jedem Folloer-Phone eine Authenticator-App, die RFC 6238 TOTP-Token unterstützt. Beliebte kostenlose Apps sind:\n Authy\n Google Authenticator\n LastPass Authenticator\n FreeOTP Authenticator + Diesen Code NICHT ONLINE TEILEN!\nVerwende ihn nur zur Einrichtung der Authenticator App auf den Follower-Phones. + Wenn Du den Authentifikator zurücksetzt werden alle bestehenden Authentifikatoren ungültig. Du musst sie dann neu einrichten! + Beim Verbinden + Beim Trennen + Predictions (Vorhersagen) + Steigung der Abweichung + Autorisierung fehlgeschlagen + Gesamtinsulin + Das Master-Passwort wird für die Backup-Verschlüsselung und zur Außerkraftsetzung der Sicherheit in der Anwendung verwendet. Merke es Dir oder bewahre es an einem sicheren Ort auf. + Die Passwörter stimmen nicht überein. + Aktuelles Master-Passwort + Statusanzeige + Einstellung aus NS kopieren + NS-Einstellungen kopieren (falls vorhanden)? diff --git a/app/src/main/res/values-de-rDE/validator.xml b/app/src/main/res/values-de-rDE/validator.xml index 3ea04e700d..37392b77d7 100644 --- a/app/src/main/res/values-de-rDE/validator.xml +++ b/app/src/main/res/values-de-rDE/validator.xml @@ -1,2 +1,21 @@ - + + Nur numerische Ziffern zulässig. + Bitte verwende nur Ziffern von %1$s - %2$s. + Dieses Feld darf kein Sonderzeichen enthalten. + Nur Standard-Buchstaben sind erlaubt + Das Feld darf nicht leer sein. + E-Mail Adresse ungültig + Kreditkartennummer ist ungültig. + Telefonnummer ist nicht gültig + Domain-Name nicht gültig + IP-Adresse nicht gültig + Web-Adresse (URL) ungültig + Kein gültiger Vor- oder Nachname + Kein gültiger vollständiger Name. + Ungültig Format + Bitte 4-stellige Zahl verwenden + Bitte 6-stellige Zahl verwenden + Mindestlänge nicht erreicht + Pin sollte 3- bis 6-stellig sein, unterschiedliche und nicht aufeinanderfolgende Zahlen enthalten. + diff --git a/app/src/main/res/values-el-rGR/strings.xml b/app/src/main/res/values-el-rGR/strings.xml index b710a364fe..df59b1b91a 100644 --- a/app/src/main/res/values-el-rGR/strings.xml +++ b/app/src/main/res/values-el-rGR/strings.xml @@ -105,7 +105,6 @@ Διαφορά: Διαμόρφωση Βήματα - OpenAPS MA Επισκόπηση Προφίλ NS Απλό Προφίλ @@ -518,8 +517,6 @@ Ενεργοποίηση superbolus στον σύντομο οδηγό Ενεργοποιήστε την λειτουργία superbolus στον σύντομο οδηγό. Μην το κάνετε μέχρι να μάθετε τι ακριβώς κάνει. ΜΠΟΡΕΙ ΝΑ ΕΓΧΥΣΕΙ ΠΑΡΑΠΑΝΩ ΔΟΣΕΙΣ ΙΝΣΟΥΛΙΝΗΣ ΑΝ ΧΡΗΣΙΜΟΠΟΙΗΘΕΙ ΛΑΝΘΑΣΜΕΝΑ! Εμφάνιση του φωτισμού κατάστασης στην αρχική οθόνη - Εμφάνιση του φωτισμού κατάστασης στην αρχική οθόνη - Ενεργοποίηση του φωτισμού κατάστασης για cage, iage, sage, reservoir και επίπεδο μπαταρίας στην αρχική οθόνη. Όριο προειδοποίησης χαμηλής αμπούλας [U] Όριο προειδοποίησης πολύ χαμηλής αμπούλας [U] Όριο προειδοποίησης χαμηλής μπαταρίας [%] diff --git a/app/src/main/res/values-es-rES/strings.xml b/app/src/main/res/values-es-rES/strings.xml index 09bb718f0e..b7498bed57 100644 --- a/app/src/main/res/values-es-rES/strings.xml +++ b/app/src/main/res/values-es-rES/strings.xml @@ -105,7 +105,6 @@ Variación: Tabla de configuraciones Objetivos - OpenAPS MA Inicio Perfil NS Perfil simple @@ -218,6 +217,36 @@ Max IOB basal que OpenAPs puede emitir [U] Este valor es llamado Max Iob en el OpenAPS\nEsta es la máxima insulina en [U] que APS puede entregar a la vez. DESCARTAR + Se le solicitará la contraseña maestra, que se utilizará para cifrar las preferencias exportadas. + Se le solicitará la contraseña maestra, que es necesaria para descifrar las preferencias importadas. + ¡Exportación cancelada! ¡Las preferencias NO se han exportado! + ¡Importación cancelada! ¡Las preferencias NO se han importado! + Por favor, compruebe las preferencias antes de importar: + ¡Las preferencias no se pueden importar! + ¡Las preferencias no se deben importar! + Explicar problemas de importación… + Importar + Importar de todos modos (¡PELIGROSO!) + Las preferencias se han creado en un dispositivo distinto. Está bien si va a importar desde un teléfono más antiguo/diferente, pero ¡asegúrese de que las preferencias importadas son correctas! + ¡Estás usando el obsoleto formato heredado de versiones antiguas de AAPS, que no es seguro! Únicamente utilizarlo como último recurso, si no tiene una exportación en formato JSON actual. + Las preferencias importadas ya tienen %1$s días! ¿Tal vez tengas preferencias más actualizadas o eligiste el archivo equivocado? ¡Recuerda exportar las preferencias regularmente! + ¡Formato de fecha no válido! + Formato del archivo + Creado el + Versión de AAPS + Exportar el nombre del paciente del dispositivo + Exportar modelo de dispositivo + Encriptación de archivos + Formato de exportación antiguo + Nuevo formato cifrado + Nuevo formato de depuración (sin cifrar) + Formato de exportación desconocido + Archivo de configuración alterado + El archivo de configuración es seguro + Error de descifrado, la contraseña proporcionada no puede descifrar el archivo + ¡El archivo se ha modificado tras la exportación! + Error de descifrado, ¡el análisis de las preferencias ha fallado! + ¡Algoritmo de cifrado no soportado o no especificado! DanaR Conectando Conectado @@ -507,6 +536,9 @@ Adulto Adulto resistente a la insulina Por favor elige la edad del paciente para ajustar los límites de seguridad + Nombre del paciente + Proporcione el nombre de paciente o el apodo para diferenciar entre varias configuraciones + Usuario Glimp %1$s necesita una optimización de la batería para funcionar óptimamente Loop desactivado @@ -543,8 +575,6 @@ Activar superbolo en asistente Activar función superbolo en asistente. No lo actives hasta que hayas aprendido lo que realmente hace. ¡PUEDE CAUSAR SOBREDOSIS DE INSULINA usándolo sin precaución! Mostrar luces de estado en la pantalla de inicio - Mostrar luces de estado extendidas en pantalla de inicio - Habilita luces de estado extendidas para tiempo de cánula, tiempo de insulina, tiempo del sensor, reservorio y nivel de batería en pantalla de inicio. Umbral de advertencia de nivel de reservorio [U] Umbral crítico de nivel de reservorio [U] Umbral de advertencia de nivel de pila [%] @@ -704,8 +734,12 @@ Ajuste de subida de datos de glucosa Mostrar detalles delta Mostrar delta con un decimal mas + Con qué frecuencia se administrarán los SMB en min Minutos máximos SMB Minutos máximos de basal para limitar SMB + Minutos máximos de UAM SMB + Minutos máximos de basal para limitar SMB para UAM + Umbral de sugerencia de Carbohidratos Firmware de la bomba no soportado Mandar datos BG a xDrip+ En xDrip+ elige 640g/Eversense como fuente de datos @@ -969,6 +1003,7 @@ = 100]]> Objetivo temporal bajo reduce sensibilidad + Sensibilidad aumenta objetivo Configuración de la bomba incorrecta, leer la documentación y comprobar que el menú de Quick Info se llama QUICK INFO usando el software de configuración 360. Personalizado Diferencia de tiempo grande @@ -978,6 +1013,8 @@ Atención: si activas y conectas al hardware de la bomba, AndroidAPS copiará los ajustes basales del perfil de la bomba, sobrescribiendo el actual perfil basal de la bomba. Comprueba que tengas el perfil basal correcto en AndroidAPS. Si no estás seguro o no quieres sobrescribir los ajustes basales en la bomba, presiona cancelar y repite cambio de la bomba más tarde. Datos de tratamiento incompletos Ajustes de mantenimiento + Email + Cifrar valores exportados Ningún registro para enviar Mantenimiento MANT @@ -1185,6 +1222,8 @@ existe no existe Objetivo temporal %1$s + Conexión Bluetooth con el dispositivo %1$s %2$s + Conectar con dispositivo Bluetooth SSID WiFi %1$s %2$s Autosens %1$s %2$s %% Autosens % @@ -1239,6 +1278,7 @@ Alcalina (vista extendida) Litio (vista extendida) NiZn (vista ampliada) + NiMH (vista extendida) Bolos/Depuración de Tratamientos ESCANEAR @@ -1439,4 +1479,14 @@ Tiempo requerido de SMB Tiempo de ejecución de SMB + Habilitar autentificador + Configuración de autentificación + ¿Está seguro de que desea restablecer la clave del autenticador? Los autenticadores configurados actualmente no seran válidos, y tendrá que volver a configurarlos. + ¡Se ha generado una clave de autenticador nueva! Utilice QRCode actualizado para suministrar autenticadores. + 1. Instalar autenticador + Restablecer autentificadores + Al resetear el autenticador haces que todos los autenticadores ya provistos no sean válidos. ¡Necesitarás configurarlos de nuevo! + Al conectar + Al desconectar + Predicciones diff --git a/app/src/main/res/values-fr-rFR/objectives.xml b/app/src/main/res/values-fr-rFR/objectives.xml index 58f83d4a9c..a9031a324e 100644 --- a/app/src/main/res/values-fr-rFR/objectives.xml +++ b/app/src/main/res/values-fr-rFR/objectives.xml @@ -20,7 +20,9 @@ 1 semaine de Boucle Fermée en journée en saisissant régulièrement les glucides Activation de fonctionnalités supplémentaires en journée, comme l\'Aide au Repas Améliorée ARA (AMA) Activation de fonctionnalités supplémentaires pour l\'utilisation en journée, telles que la fonction SMB + Activation de l\'automatisation Lisez le wiki et augmentez le maxIA pour que les SMBs fonctionnent correctement ! Un bon début est maxIA = moyenne des Bolus Repas + 3 x maximum débit Basal quotidien + Lisez la documentation comment l\'automatisation fonctionne. Configurez vos premières règles simples. Au lieu de mettre une action, configurez une notification. Quand vous êtes sûr que l\'automatisation est déclenchée au bon moment, remplacez la notification par une action réelle. (https://androidaps.readthedocs.io/en/latest/CROWDIN/fr/Usage/Automation.html) Glycémie disponible sur NS Statut de la pompe disponible sur NS Activation manuelle diff --git a/app/src/main/res/values-fr-rFR/protection.xml b/app/src/main/res/values-fr-rFR/protection.xml index 3ea04e700d..4b38aa53da 100644 --- a/app/src/main/res/values-fr-rFR/protection.xml +++ b/app/src/main/res/values-fr-rFR/protection.xml @@ -1,2 +1,23 @@ - + + Authentification requise + Placez votre doigt sur le lecteur d\'empreintes digitales pour vérifier votre identité + Protection des paramètres + Protection de l\'Application + Protection des bolus + Mot de passe principal + Mot de passe des paramètres + Mot de passe de l\'application + Mot de passe des bolus + Déverrouiller les paramètres + Biométrique + Mot de passe personnalisé + Pas de Protection + Protection + Le mot de passe principal n\'est pas défini !\n\nVeuillez définir votre mot de passe principal dans les préférences (%1$s → %2$s) + Mot de passe défini ! + Mot de passe non défini + Mot de passe non modifié + Mot de passe supprimé ! + Entrez le mot de passe ici + diff --git a/app/src/main/res/values-fr-rFR/strings.xml b/app/src/main/res/values-fr-rFR/strings.xml index bb30f2183d..92b4ec3892 100644 --- a/app/src/main/res/values-fr-rFR/strings.xml +++ b/app/src/main/res/values-fr-rFR/strings.xml @@ -43,6 +43,7 @@ Intégration pompe pour les personnes qui font des injections quotidiennes multiples pour le traitement de leur diabète Intégration pour les pompes qui n’ont pas encore de pilote (Boucle Ouverte) La sensibilité est calculée de la même manière que Oref0, mais vous pouvez spécifier la période concernée. L\'absorption minimale des glucides est calculée à partir des temps d’absorption max des glucides du menu préférences. + La sensibilité est calculée à partir des données des dernières 8 heures et les glucides (si non absorbés) ne sont plus pris en compte après le temps spécifié dans les préférences. Le plugin calcule également les RNS (UAM). La sensibilité est calculée comme une moyenne pondérée des écarts. Les écarts les plus récents ont un poids plus élevé. L\'absorption minimale des glucides est calculée à partir des temps d’absorption des glucides max du menu préférences. Cet algorithme est le plus rapide pour s\'adapter aux changements de sensibilité. Recevoir les valeurs de glycémie de l’app Eversense patchée. Recevoir les glycémies depuis Glimp. @@ -105,7 +106,6 @@ Delta: Générateur de configuration Objectifs - OpenAPS MA Aperçu Profil NS Profil simple @@ -218,6 +218,44 @@ IA basale max que OpenAPS pourra délivrer [U] Cette valeur est appelée Max IA (Insuline Active) dans le contexte OpenAPS\nC\'estlle maximum d\'insuline en [U] que APS peut délivrer en une seule fois. FERMER + Le mot de passe principal vous sera demandé pour crypter les préférences exportées. + Le mot de passe principal vous sera demandé pour décrypter les préférences exportées. + Export annulé ! Les préférences n\'ont PAS été exportées ! + Import annulé ! Les préférences n\'ont PAS été importées ! + Vérifiez les préférences avant d\'importer : + Les préférences ne peuvent pas être importées ! + Les préférences ne doivent pas être importées ! + Explication des problèmes d\'importation… + Détails des problèmes d\'importation + Import + Importer quand même (DANGEREUX !) + Des préférences ont été créées avec des variantes différentes d\'AAPS (%1$s) quand vous avez : %2$s.\n\nCertains paramètres peuvent manquer ou ou ne pas être valides après l\'import, vérifiez et mettez à jour vos préférences. + Les préférences ont été créées sur un autre périphérique. C\'est OK si vous importez à partir d\'un téléphone ancien/différent, mais vérifiez les préférences importées sont correctes ! + Vous utilisez le format obsolète des anciennes versions d\'APPS qui n\'est pas sécurisé ! Utilisez-le uniquement en dernier recours, si vous n\'avez pas d\'export au format JSON actuel. + Les préférences importées ont déjà %1$s jours ! Vous avez peut-être des préférences plus récentes ou vous avez sélectionné un mauvais fichier ? N\'oubliez pas d\'exporter vos préférences régulièrement ! + Format de date invalide ! + Format de fichier + Créé le + Version d\'AAPS + Variante de Build + Export du nom du patient de l\'appareil + Export du modèle de l\'appareil + Cryptage du fichier + Ancien format d\'export + Nouveau format crypté + Nouveau format de débug (non crypté) + Format d\'export inconnu + Fichier paramètres altérés + Fichier paramètres sécurisé + Utilisation non sécurisée, fichier paramètres non crypté + Erreur de format JSON, zone obligatoire manquante (format, contenu, métadonnées ou sécurité) + Erreur de décryptage, le mot de passe indiqué ne permet pas le décryptage du fichier + Checksum du fichier manquant, vérification de l\'authenticité des pararamètres impossible ! + Le fichier a été modifié après l\'export ! + Erreur de décryptage, échec de l\'import des préférences ! + Erreur de décryptage, le mot de passe fourni est invalide ou le fichier de paramètres à été modifié ! Cela peut arriver si le fichier a été exporté avec un mot de passe principal différent. + Configuration du cryptage manquant, format des paramètres invalide ! + Algorithme de cryptage non pris en charge ou non spécifié ! DanaR Connection en cours Connectée @@ -253,8 +291,8 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S Pour injecter le bolus repas de %1$.2fU renvoyer le code %2$s Pour définir la Cible Temp %1$s renvoyer le code %2$s Pour annuler la Cible Temp renvoyer le code %1$s - Pour désactiver les commandes à distance SMS renvoyer le code %1$s.\n\nGardez à l\'esprit que vous ne pourrez le réactiver que directement à partir de l\'application AAPS du smartphone maitre. - Service de commande à distance SMS arrêté. Pour le réactiver, utilisez AAPS sur le smartphone maitre. + Pour désactiver les commandes à distance SMS renvoyer le code %1$s.\n\nGardez à l\'esprit que vous ne pourrez le réactiver que directement à partir de l\'application AAPS du smartphone maître. + Service de commande à distance SMS arrêté. Pour le réactiver, utilisez AAPS sur le smartphone maître. Renvoyer le code %2$s pour envoyer la calibration %1$.2f Échec du Bolus Nombre minimum de minutes qu\'il doit y avoir entre un bolus distant et le suivant @@ -508,6 +546,9 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S Adulte Adulte résistant à l\'insuline Veuillez svp sélectionner l’âge du patient pour définir les limites de sécurité + Nom du patient + Veuillez indiquer un nom ou pseudo du patient pour différencier plusieurs configurations + Patient Glimp %1$s a besoin d\'optimisation de la batterie (whitelisting) pour une performance correcte La Boucle est suspendue @@ -544,8 +585,14 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S Activer les Superbolus dans l’Assistant Activer la fonctionnalité SuperBolus dans l’Assistant. Ne pas l’activer avant de bien comprendre comment cela fonctionne réellement. IL PEUT PROVOQUER UNE OVERDOSE D’INSULINE SI UTILISÉ AVEUGLÉMENT ! Afficher les voyants d\'état sur l\'écran d\'accueil - Afficher les voyants d\'état prolongés sur l\'écran d\'accueil - Activer les voyants d\'état prolongés pour AgeC, AgeI, AgeS, niveaux du réservoir et de batterie sur l\'écran d\'accueil. + Seuil d\'alerte âge canule [h] + Seuil critique âge canule [h] + Seuil d\'alerte âge insuline [h] + Seuil critique âge insuline [h] + Seuil d\'alerte âge capteur [h] + Seuil critique âge capteur [h] + Seuil d\'alerte niveau pile [h] + Seuil critique niveau pile [h] Seuil d\'avertissement de niveau du réservoir [U] Seuil critique de niveau du réservoir [U] Seuil d’avertissement du niveau de batterie [%] @@ -705,8 +752,13 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S Paramètres de téléchargement des glycémies Afficher le delta détaillé Afficher delta avec une décimale supplémentaire + Fréquence des SMB en min SMB minutes max Max. minutes de basal pour limiter le SMB + SMB RNS minutes max + Minutes de basal max pour limiter les SMB des RNS + Seuil de suggestionde glucides + Quantité de glucides à partir de laquelle une notification est envoyée Firmware pompe incompatible Transmettre les Gly vers xDrip+ Dans xDrip+ veuillez séléctionner 640g/Eversense comme source de données @@ -773,6 +825,7 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S passé(e)s %1$.2f h %1$d min + %1$dm Activer en permanence les SMB Activer toujours SMB de manière autonome pour les bolus. Ceci est possible uniquement avec une source de glycémie ayant un très bon filtrage de données comme le G5 Activer SMB après ingestion de glucides @@ -971,6 +1024,10 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S = 100]]> Cible temp. basse abaisse la sensibilité + La résistance diminue la cible + Quand une résistance est détectée, baisse de la glycémie cible + Sensibilité augmente la cible + Quand une sensibilité est détectée, augmentation de la glycémie cible Paramétrage de la pompe invalide. Vérifiez la documentation et le menu QUICK INFO en utilisant le logiciel de configuration 360. Personnalisé Différence horaire importante @@ -980,6 +1037,8 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S ATTENTION : Si vous activez et connectez à une vraie pompe, AndroidAPS copiera les paramètres Basals du profil vers la pompe, écrasant le taux basal existant stocké sur la pompe. Assurez-vous d\'avoir correctement saisi et réglé les paramètres Basal dans AndroidAPS. Si vous ne savez pas ou si ne voulez pas écraser les paramètres Basal sur votre pompe, appuyez sur Annuler et reporter le passage à la pompe à une date ultérieure. Données de traitement incomplètes Paramètres de maintenance + E-mail + Crypter les paramètres exportés Nombre de journaux (Logs) à envoyer Maintenance MAINT @@ -1187,6 +1246,8 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S existe n\'existe pas Cible Temp. %1$s + Connexion Bluetooth à l\'appareil %1$s %2$s + Connecter à un appareil Bluetooth SSID WiFi %1$s %2$s Autosens %1$s %2$s %% Autosens % @@ -1241,6 +1302,7 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S Alcaline (vue étendue) Lithium (vue étendue) NiZn (vue étendue) + NiMH (vue Étendue) Débogage de Bolus/Traitements SCANNER @@ -1256,6 +1318,7 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S Recherche en cours Recherche finie Erreur de recherche : %1$d + Jamais Paramètres Historique @@ -1389,6 +1452,7 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S Suppression démarrée Détection de temps Voulez-vous réinitialiser le début de l\'objectif ? Vous risquez de perdre vos progrès. + Heure et/ou fuseau horaire changé sur la pompe Aucune pompe sélectionnée Sélectionnez les unités dans lesquelles vous souhaitez afficher les valeurs Remonter les modifications de profil local dans NS @@ -1445,4 +1509,34 @@ L\'ENSEMBLE DES RISQUES LIÉS À LA QUALITÉ ET À LA PERFORMANCE DU PROGRAMME S Heure d\'exécution basal temp Alertes Pompe Insight + depuis l\'appli. Authenticateur pour : %1$s + Activer l\'Authentificateur + Authentifier les commandes à l\'aide des mots de passe uniques (OTP) générés par Google Authenticator ou des applications 2FA similaires. + Code PIN supplémentaire à la fin de l\'OTP + Chiffres supplémentaires qui doivent être mémorisés et collés à la fin de chaque OTP généré + Configuration de l\'Authentificateur + OTP à vérifier : + Réinitialiser les authentificateurs + Réinitialiser la clé de l\'Authentificateur + Voulez-vous réinitialiser la clé de l\'Authenticateur ? Cela rendra tous authentificateurs configurés invalides, et vous devrez les configurer à nouveau. + Nouvelle clé de l\'Authenticateur générée ! Veuillez utiliser le QRCode mis à jour pour les authentificateurs. + 1. Installation l\'Authentificateur + 2. Scan du code pour configurer les codes OTP AndroidAPS + 3. Test Mot-de-Passe-Unique (OTP) + Réinitialiser les authentificateurs + Sur chaque téléphone suiveur, installez une appli. Authentificateur qui prend en charge les jetons RFC 6238 TOTP. Les applications libres populaires sont:\n • Authy\n • Google Authenticator\n • LastPass Authenticator\n • FreeOTP Authenticator + NE PAS PARTAGER ce code en ligne !\nUtilisez-le uniquement pour configurer l\'appli. Authenticateur sur les téléphones suiveurs. + En réinitialisant l\'Authentificateur, vous invalidez tous les authentificateurs déjà initialisés. Vous devrez les reconfigurer ! + À la connexion + À la déconnexion + Prédictions + Pente de déviations + Echec de l\'authentification + Insuline absolue + Le mot de passe principal est utilisé pour crypter les sauvegardes et superviser la sécurité de l\'application. Rappelez-vous en ou stockez le en lieu sûr. + Les mots de passe ne correspondent pas + Mot de passe principal actuel + Voyants d\'état + Copier les paramètres depuis NS + Copier les paramètres NS (s\'ils existent)? diff --git a/app/src/main/res/values-fr-rFR/validator.xml b/app/src/main/res/values-fr-rFR/validator.xml index 3ea04e700d..f18febf0f4 100644 --- a/app/src/main/res/values-fr-rFR/validator.xml +++ b/app/src/main/res/values-fr-rFR/validator.xml @@ -1,2 +1,21 @@ - + + Seuls les chiffres sont autorisés + Seuls les chiffres entre %1$s et %2$s sont autorisés + Ce champ ne doit pas contenir de caractères spéciaux + Seules les lettres standard sont autorisées + Le champ ne doit pas être vide + Adresse email non valide + Numéro de carte de crédit non valide + Téléphone non valide + Nom de domaine non valide + Adresse IP non valide + Url Web non valide. + Prénom ou Nom non valide + Nom complet non valide + Format non valide + Doit être 4 chiffres + Doit être 6 chiffres + Longueur minimale non respectée + le PIN doit être entre 3 et 6 chiffres différents et non en série + diff --git a/app/src/main/res/values-it-rIT/objectives.xml b/app/src/main/res/values-it-rIT/objectives.xml index 84a9152c3d..ba4a3d013f 100644 --- a/app/src/main/res/values-it-rIT/objectives.xml +++ b/app/src/main/res/values-it-rIT/objectives.xml @@ -20,7 +20,10 @@ 1 settimana di looping diurno con inserimento regolare dei carboidrati, eseguito con successo Abilitazione funzioni aggiuntive per l\'uso diurno, ad esempio AMA (advanced meal assist - assistenza avanzata del pasto) Abilitazione funzioni aggiuntive per l\'uso diurno, come SMB + Abilitazione automazione È necessario leggere il wiki e aumentare maxIOB affinché le azioni di SMB funzionino adeguatamente! Un buon inizio è maxIOB = media bolo posto + 3 x max basale giornaliera + Leggi la documentazione su come funziona l\'automazione. Configura le tue prime semplici regole. Consenti ad AAPS solo di visualizzare una notifica, non di eseguire un\'azione. Quando sei sicuro che l\'automazione viene attivata al momento giusto, sostituisci la notifica con un\'azione reale. +(https://androidaps.readthedocs.io/en/latest/EN/Usage/Automation.html) Glicemia disponibile in NS Stato micro disponibile in NS Attivazioni manuali diff --git a/app/src/main/res/values-it-rIT/protection.xml b/app/src/main/res/values-it-rIT/protection.xml index 3ea04e700d..bb153b84e7 100644 --- a/app/src/main/res/values-it-rIT/protection.xml +++ b/app/src/main/res/values-it-rIT/protection.xml @@ -1,2 +1,23 @@ - + + Autenticazione richiesta + Posiziona il tuo dito sul lettore di impronte digitali per verificare la tua identità + Protezione impostazioni + Protezione applicazione + Protezione bolo + Password Master + Password impostazioni + Password applicazione + Password bolo + Impostazioni sblocco + Biometrico + Password personalizzata + Nessuna protezione + Protezione + La password master non è impostata!\n\nImposta la tua password Master in Preferenze (%1$s → %2$s) + Password impostata! + Password non impostata + Password non modificata + Password cancellata! + Inserisci qui la password + diff --git a/app/src/main/res/values-it-rIT/strings.xml b/app/src/main/res/values-it-rIT/strings.xml index bdeb463adb..cc4b846a9b 100644 --- a/app/src/main/res/values-it-rIT/strings.xml +++ b/app/src/main/res/values-it-rIT/strings.xml @@ -106,7 +106,6 @@ Delta: Configuratore strutturale Obiettivi - OpenAPS MA Panoramica Profilo NS Profilo semplice @@ -220,8 +219,43 @@ Questo valore è chiamato Max IOB nel contesto OpenAPS\nIndica l\'insulina massima in [U] che APS può erogare in contemporanea. RIMUOVI Ti verrà richiesta la password principale, che verrà utilizzata per crittografare le preferenze esportate. + Ti verrà chiesta la password master, che è necessaria per decrittare le preferenze importate. + Esportazione annullata! Le preferenze NON sono state esportate! + Importazione annullata! Le preferenze NON sono state importate! + Verifica le preferenze prima dell\'importazione: Le preferenze non possono essere importate! Le preferenze non dovrebbero essere importate! + Descrivi i problemi importazione… + Dettagli dei problemi di importazione + Importa + Importa comunque (PERICOLOSO!) + Le preferenze sono state create con una differente versione di AAPS (%1$s) mentre invece tu hai: %2$s.\n\nAlcune impostazioni potrebbero mancare o non essere valide - dopo l\'importazione controlla e aggiornare le tue preferenze. + Le preferenze sono state create su un dispositivo diverso. Va bene importarle da un vecchio/diverso telefono, ma assicurati che le preferenze importate siano corrette! + Stai utilizzando il formato precedente (obsoleto) delle vecchie versioni di APPS, che non è sicuro! Utilizzalo solo come ultima risorsa, se non hai un\'esportazione nel corrente formato JSON. + Le preferenze importate hanno già %1$s giorni! Forse hai preferenze più aggiornate. Hai scelto il file sbagliato? Ricorda di esportare le preferenze regolarmente! + Formato data-ora non valido! + Formato file + Creato: + Versione AAPS + Variante build + Nome paziente del dispositivo esportatore + Modello dispositivo esportatore + Crittografia file + Vecchio formato esportazione + Nuovo formato crittografato + Nuovo formato di debug (non crittografato) + Formato esportazione sconosciuto + File delle impostazioni manomesso + Il file delle impostazioni è sicuro + Utilizzo non sicuro, formato impostazioni non crittografato + Errore formato JSON, campo obbligatorio mancante (formato, contenuto, metadati o sicurezza) + Errore decrittazione, la password data non può decrittare il file + File checksum (hash) mancante, impossibile verificare l\'autenticità delle impostazioni! + Il file è stato modificato dopo l\'esportazione! + Errore decrittazione, analisi preferenze fallita! + Errore decrittazione, la password fornita è errata o il file delle impostazioni è stato modificato! È possibile che il file importato sia stato esportato con una diversa password master. + Configurazione crittografia mancante, il formato delle impostazioni non è valido! + Algoritmo di crittografia non supportato o non specificato! DanaR Connessione Connesso @@ -511,6 +545,9 @@ Adulto Adulto insulino-resistente Seleziona l\'età del paziente per impostare i limiti di sicurezza + Nome paziente + Fornisci il nome del paziente o il nickname per distinguere questa configurazione tra altre + Utente Glimp Per un buon funzionamento, %1$s ha bisogno di essere nella whitelist della funzione \"ottimizzazione batteria\" di Android Loop sospeso @@ -547,8 +584,14 @@ Abilita superbolo nel calcolatore Abilita la funzionalità superbolo nel calcolatore. Non abilitare fino a quando non impari ciò che realmente fa. PUÒ CAUSARE SOVRADOSAGGIO DI INSULINA SE USATO IMPROPRIAMENTE! Mostra indicatori di stato sulla home - Mostra indicatori estesi sulla home - Abilita indicatori di stato estesi per \"età\" cannula, insulina, sensore, serbatoio e livello batteria sulla schermata iniziale. + Soglia di avviso età cannula [h] + Soglia età cannula critica [h] + Soglia di avviso età insulina [h] + Soglia età insulina critica [h] + Soglia di avviso età sensore [h] + Soglia età sensore critica [h] + Soglia di avviso età batteria [h] + Soglia età batteria critica [h] Soglia di avviso livello serbatoio [U] Soglia livello serbatoio critico [U] Soglia di avviso livello batteria [%] @@ -708,8 +751,13 @@ Impostazioni caricamento BG Mostra delta dettagliato Mostra delta con una cifra decimale in più + Frequenza di erogazione SMB (min) Max minuti SMB Max minuti di basale a cui limitare SMB + SMB UAM max minuti + Max minuti di basale a cui limitare SMB per UAM + Soglia proposta CHO + Quando vengono proposti carboidrati, la quantità minima per la quale verrà mostrata una notifica Firmware del micro non supportato Invia dati BG a xDrip+ In xDrip+ seleziona origine dati 640g/Eversense @@ -776,6 +824,7 @@ fa %1$.2f h %1$d min + %1$dm Abilita SMB sempre Abilita SMB sempre, indipendentemente dai boli. Possibile solo con sorgente glicemia con un buon filtraggio dei dati, come G5 Abilita SMB dopo i CHO @@ -926,7 +975,7 @@ Lettura stato Le modifiche devono essere fatte in NS Salta configurazione guidata - Premi il tasto in basso per permettere ad AndroidAPS di suggerire/fare modifiche alla basale + Premi il tasto in basso per permettere ad AndroidAPS di proporre/fare modifiche alla basale Configura il plugin APS Configura il plugin di Sensibilità Il plugin di Sensibilità è utilizzato per il rilevamento della sensibilità all\'insulina e il calcolo di COB. Per ulteriori informazioni visita: @@ -974,6 +1023,10 @@ = 100]]> Temp-Target \"basso\" riduce la sensibilità + La resistenza abbassa il target + Quando viene rilevata resistenza, ridurre la glicemia target + La sensibilità aumenta il target + Quando viene rilevata sensibilità, aumentare la glicemia target Configurazione micro non valida, controlla la documentazione e verifica che il menu Quick Info sia denominato QUICK INFO utilizzando \"360 configuration software\". Personalizzato Grande differenza oraria @@ -983,6 +1036,8 @@ Attenzione: se attivi e connetti un micro, AndroidAPS copierà le impostazioni della basale dal profilo al micro, sovrascrivendo la velocità basale esistente memorizzata sul micro. Assicurati di avere la giusta impostazione della basale in AndroidAPS. Se non sei sicuro o non vuoi sovrascrivere le impostazioni della basale sul micro, premi annulla e ripeti il processo in un altro momento. Dati trattamento incompleti Impostazioni manutenzione + Destinatario email + Crittografa impostazioni esportate Numero di log da inviare Manutenzione MANUT @@ -1190,6 +1245,8 @@ esiste non esiste Temp-Target %1$s + Connessione Bluetooth a dispositivo %1$s %2$s + Connessione a dispositivo Bluetooth WiFi SSID %1$s %2$s Autosens %1$s %2$s %% Autosens % @@ -1244,6 +1301,7 @@ Alcalina (Extended view) Litio (Extended view) NiZn (Extended view) + NiMH (Extended view) Debug Bolo/Trattamenti SCAN @@ -1259,6 +1317,7 @@ Scansione Scansione terminata Errore scansione: %1$d + Mai Impostazioni Storico @@ -1392,6 +1451,7 @@ Cancella avvio Rilevazione tempo Vuoi resettare l\'avvio dell\'obiettivo? Potresti perdere i tuoi progressi. + Cambio di ora e/o fuso orario sul micro Nessun micro selezionato Seleziona le unità in cui vuoi visualizzare i valori Carica modifiche al profilo locale in NS @@ -1448,4 +1508,34 @@ Esecuzione basale temporanea (momento) Avvisi micro Insight + da app Autenticatore per: %1$s + Abilita Autenticatore + Autentica i comandi utilizzando OTP (One Time Password) generate da Google Authenticator o app 2FA simili. + PIN aggiuntivo a fine token + Cifre aggiuntive che devono essere memorizzate e incollate alla fine di ogni OTP generata + Configurazione Autenticatore + OTP per verifica: + Resetta Autenticatori + Resetta Chiave Autenticatore + Sei sicuro di resettare la chiave Autenticatore? Renderà non validi tutti gli Autenticatori attualmente configurati e sarà necessario configurarli nuovamente. + La nuova Chiave Autenticatore è stata generata! Utilizza il QRCode aggiornato per fornire gli autenticatori. + 1. Installa l\'Autenticatore + 2. Scansione il codice per configurare i codici OTP di AndroidAPS + 3. Testa OTP + Resetta Autenticatori + Su ogni telefono follower installa una app Autenticatore che supporta i token RFC 6238 TOTP. App gratuite popolari sono:\n • Authy\n • Google Authenticator\n • LastPass Authenticator\n • FreeOTP Authenticator + NON CONDIVIDERE questo codice online!\nUtilizzalo solo per configurare l\'app Autenticatore sui telefoni follower. + Resettando l\'autenticatore rendi non validi tutti gli autenticatori già forniti. Dovrai configurarli di nuovo! + Alla connessione + Alla disconnessione + Predizioni + Pendenza deviazione + Autorizzazione fallita + Insulina assoluta + La password master viene utilizzata per la crittografia del backup e per gestire la sicurezza nell\'applicazione. Ricordala o conservala in un luogo sicuro. + Le password non coincidono + Password Master corrente + Indicatori di stato + Copia impostazioni da NS + Copiare impostazioni NS (se esiste)? diff --git a/app/src/main/res/values-it-rIT/validator.xml b/app/src/main/res/values-it-rIT/validator.xml index 3ea04e700d..032f0bbddd 100644 --- a/app/src/main/res/values-it-rIT/validator.xml +++ b/app/src/main/res/values-it-rIT/validator.xml @@ -1,2 +1,21 @@ - + + Sono consentite solo cifre numeriche. + Sono consentite solo cifre numeriche nel range %1$s - %2$s. + Questo campo non può contenere alcun carattere speciale + Sono consentite solo lettere standard + Il campo non deve essere vuoto + Indirizzo email non valido + Il numero della carta di credito non è valido + Numero di telefono non valido + Nome dominio non valido + Indirizzo IP non valido + L\'URL non è valido + Nome o Cognome non valido. + Nome completo non valido. + Formato non valido + Deve essere un numero di 4 cifre + Deve essere un numero di 6 cifre + Lunghezza minima non soddisfatta + Il PIN deve contenere da 3 a 6 cifre, non uguali o in serie + diff --git a/app/src/main/res/values-ko-rKR/strings.xml b/app/src/main/res/values-ko-rKR/strings.xml index 63a2e057da..414d29fbd6 100644 --- a/app/src/main/res/values-ko-rKR/strings.xml +++ b/app/src/main/res/values-ko-rKR/strings.xml @@ -105,7 +105,6 @@ Delta: 구성 관리자 목표 - OpenAPS MA NS 프로파일 Simple 프로파일 @@ -543,8 +542,6 @@ 마법사에서 Superbolus 활성화하기 마법사에서 Superbolus 기능을 활성화합니다. 어떤 기능인지 확실히 알기전까지 활성화 하지 마세요. 제대로 알지 못하고 사용하면 일슐린이 과다 주입될 수 있습니다! 홈화면에 상태 표시등 보여주기 - 홈화면에 확장 상태등 표시하기 - 홈화면에 캐뉼라 사용기간(cage), 인슐린 사용기간(iage), 센서 사용기간(sage), 펌프용 주사기(reservoir)와 배터리(battery) 남은 양에 대한 확장 표시등을 활성화합니다. 주사기량 경고 기준값[U] 주사기량 위험 기준값[U] 배터리 잔량 경고값 [%] diff --git a/app/src/main/res/values-lt-rLT/exam.xml b/app/src/main/res/values-lt-rLT/exam.xml index 36253d4dab..2eb97c9785 100644 --- a/app/src/main/res/values-lt-rLT/exam.xml +++ b/app/src/main/res/values-lt-rLT/exam.xml @@ -6,7 +6,7 @@ Mažiausia reikšmė - 5 valandos. https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html?#insulin Jis yra lygus IVT parametrui, kuris naudojamas pompoje. - Jūs turite nustatyti jūsų individualias vertes (bet ne mažiau kaip 5 valandas). + Jūs turite nustatyti savo individualią reikšmę (bet ne mažiau kaip 5 val.). Tema: Hipo Laikinas tikslas Kokia yra pagrindinė priežastis nustatyti hipo laikiną tikslą? Užkirsti kelią kristi gliukozės kiekiui kraujyje, kai jau veikia nulinė laikina bazė. diff --git a/app/src/main/res/values-lt-rLT/objectives.xml b/app/src/main/res/values-lt-rLT/objectives.xml index 06357e3814..2ef9dbd944 100644 --- a/app/src/main/res/values-lt-rLT/objectives.xml +++ b/app/src/main/res/values-lt-rLT/objectives.xml @@ -35,6 +35,7 @@ Parodyti Ciklo įskiepio turinį Panaudokite vaizdo dydžio keitimo funkciją ilgai spaudžiant ant glikemijos kreivės Įeiti + Jei turite bent 3 mėnesių uždaro ciklo patirties kitose sistemose, galite gauti kodą, leidžiantį praleisti tikslus. Visą informaciją galite rasti čia: https://androidaps.readthedocs.io/en/latest/EN/Usage/Objectives.html#skip-objectives. Kodas priimtas Neteisingas kodas Patvirtinkite savo žinias @@ -52,21 +53,21 @@ Nepavyko nuskaityti laiko Tikslo reikalavimai neįvykdyti - %1$d diena - %1$d dienos(-ų) - %1$d dienos(-ų) - %1$d dienos(-ų) + %1$d d. + %1$d d. + %1$d d. + %1$d d. - %1$d valanda - %1$d valandos(-ų) - %1$d valandos(-ų) - %1$d valandos(-ų) + %1$d val. + %1$d val. + %1$d val. + %1$d val. - %1$d minutė - %1$d minutės(-čių) - %1$d minutės(-čių) - %1$d minutės(-čių) + %1$d min. + %1$d min. + %1$d min. + %1$d min. diff --git a/app/src/main/res/values-lt-rLT/strings.xml b/app/src/main/res/values-lt-rLT/strings.xml index 85e82fa262..31c388d786 100644 --- a/app/src/main/res/values-lt-rLT/strings.xml +++ b/app/src/main/res/values-lt-rLT/strings.xml @@ -43,6 +43,7 @@ Integracija žmonėms, naudojantiems insulino injektorius Integracija pompoms, kurios dar neturi reikalingo valdiklio (Atviras Ciklas) Jautrumas insulinui apskaičiuojamas taip pat kaip ir Oref0, tačiau jūs galite nustatyti, koks praeities laikotarpis bus naudojamas. Minimalus angliavandenių įsisavinimo greitis apskaičiuojamas remiantis maksimaliu angliavandenių įsisavinimo greičiu, kuris įvestas Nustatymuose. + Jautrumas insulinui apskaičiuojamas remiantis praėjusių 8 val. duomenimis, o (neįsisavinti) angliavandeniai neįtraukiami į skaičiavimus praėjus Nustatymuose nurodytam laikui. Įskiepis taip pat įskaičiuoja NDM (nedeklaruotą maistą). Jautrumas insulinui apskaičiuojamas kaip nuokrypių svertinis vidurkis. Naujausių nuokrypių svoris yra didesnis. Minimalus angliavandenių įsisavinimo greitis apskaičiuojamas iš maksimalaus angliavandenių įsisavinimo greičio, kuris nurodytas Nustatymuose. Šis algoritmas greičiausiai aptinka pasikeitusį jautrumą insulinui. Gauti kraujo gliukozės vertes iš modifikuotos Eversense programėlės. Gauti kraujo gliukozės vertes iš Glimp. @@ -54,9 +55,9 @@ Rodyti Ciklo informaciją laikrodyje, xDrip+ pradžios ekrane. Nuotolinis AndroidAPS valdymas naudojant SMS komandas. Vienetai - IVT (Insulino Veikimo Trukmė) - IA (insulino/angliavandenių santykis) - JIF (jautrumo insulinui faktorius) + IVT + IA + JIF Valandinė bazė Tikslas Nenustatytas profilis @@ -75,7 +76,7 @@ LT AV Korekcija - vv + V Bolusų AIO Paleisti dabar Virtuali pompa @@ -105,7 +106,6 @@ Pokytis: Konfigūracija Tikslai - OpenAPS MA Apžvalga NS profilis Paprastas profilis @@ -123,7 +123,7 @@ Bendrieji Bendrieji įskiepiai, kurie gali praversti. Kokie apribojimai taikomi? - dienos(-ų) + d. Apribojimai Ciklas Ciklas @@ -152,7 +152,7 @@ Valandinė bazė: AV Pakeiskite įvestus duomenis! - KG šaltinis + Glikemijos šaltinis Iš kur AndroidAPS gaus duomenis? xDrip DKS režimas @@ -166,16 +166,16 @@ CIKLAS NEAKTYVUS DĖL APRIBOJIMŲ Bazės AIO Pritaikytas boluso apribojimas - Pritaikytas angliavandenių apribojimas + Pritaikytas AV apribojimas KG testas Pranešimas Pastaba Klausimas Fizinis aktyvumas Kateterio keitimas - NGJ sensoriaus įvedimas - NGJ sensoriaus paleidimas - Insulino rezervuaro keitimas + NGJ įvedimas + NGJ paleidimas + Rezervuaro keitimas Profilio keitimas Bolusas užkandžiui Bolusas valgiui @@ -183,13 +183,13 @@ Kombinuotas bolusas Pradėta laikina bazė Užbaigta laikina bazė - Angliavandeniai korekcijai + AV korekcijai OpenAPS neprisijungus Įvykio tipas Kiti Matuoklis Sensorius - Angliavandeniai + AV Insulinas AV laikas Išskaidyti @@ -218,6 +218,44 @@ Didžiausias valandinės bazės insulino kiekis, kurį gali suleisti OpenAPS [U] Ši vertė OpenAPS kontekste vadinama Maks AIO\nTai maksimalus insulino vienetų [U] skaičius, kurį DKS gali suleisti vienu metu. ATMESTI + Jūsų paprašys nustatyti slaptažodį, kuris bus naudojamas užšifruojant eksportuojamus nustatymus. + Jūsų paprašys nustatyti slaptažodį, kuris bus naudojamas atšifruojant importuotus nustatymus. + Eksportas nutrauktas! Nustatymai NE eksportuoti! + Importas nutrauktas! Nustatymai NE importuoti! + Prašom patikrinti nustatymus prieš importuojant: + Nustatymai negali būti importuoti! + Nustatymai neturėtų būti importuoti! + Importo sutrikimų paaiškinimas… + Importo sutrikimų detalės + Importas + Importuoti vistiek (PAVOJINGA!) + Nustatymai sukurti naudojant skirtingą AAPS versiją (%1$s), jūsų turima: %2$s.\n\nKai kurių nustatymų gali trūkti arba jie gali būti neteisingi - po importavimo patikrinkite ir atnaujinkite nustatymus. + Nustatymai buvo sukurti naudojant kitą prietaisą. Viskas gerai, jei importuojante iš senesnio/kito telefono, tačiau įsitikinkite, kad visi importuoti nustatymai yra teisingi! + Jūs naudojate pasenusį formatą iš senos AAPS versijos, kuris nėra saugus! Naudokite tik kraštutiniu atveju, jei neturite nustatymų failo dabartiniu, JSON formatu. + Importuoti nustatymai yra %1$s d. senumo! Patikrinkite, gal pasirinkote neteisingą failą ir turite naujesnius? Nepamirškite reguliariai eksportuoti nustatymų! + Neteisingas datos ir laiko formatas! + Failo formatas + Sukurta + AAPS versija + Versijos variantas + Eksportuojamas paciento vardas + Eksportuojamas prietaiso modelis + Failo šifravimas + Senas eksporto formatas + Naujas šifruotas formatas + Naujas derinimo formatas (nešifruotas) + Nežinomas eksporto formatas + Nustatymų failas sugadintas + Nustatymų failas yra saugus + Naudojamas nesaugus, nešifruotas nustatymų formatas + JSON formato klaida, neužpildyti reikalingi laukai (formatas, turinys, metaduomenys arba saugumas) + Iššifravimo klaida, netinkamas slaptažodis + Trūksta failo kontrolinės žymės, neįmanoma patikrinti autentiškumo! + Failas pakeistas po eksportavimo! + Iššifravimo klaida, nustatymų analizė neįvyko! + Iššifravimas klaida, slaptažodis yra neteisingas arba nustatymų failas buvo pakeistas! Taip nutinka, jei importuotas failas buvo eksportuotas su kitu slaptažodžiu. + Trūksta šifravimo sąrankos parametrų, nustatymų formatas yra neteisingas! + Nepalaikomas arba nepatikslintas šifravimo algoritmas! DanaR Jungiamasi Prisijungta @@ -233,7 +271,7 @@ Pompos AIO Paros insulinas Paskutinis bolusas - Prieš %1$.1f valandų + Prieš %1$.1f val. Neteisingai įvesti duomenys Vertė nėra tinkamai nustatyta Atnaujinti profilį @@ -263,8 +301,8 @@ Bus suleista %1$.2fvv %1$.2fvv bolusas sėkmingai suleistas Bolusas %1$.2fvv sėkmingai suleistas - Tikslas %1$s %2$d minutėms - Tikslas %1$s %2$d minutėms nustatytas sėkmingai + Tikslas %1$s %2$d min. + Tikslas %1$s %2$d min. nustatytas sėkmingai Laikinas tikslas atšauktas sėkmingai Leidžiama %1$.2fvv Leisti nuotolines komandas SMS žinutėmis @@ -286,14 +324,14 @@ užpildymas valandinė bazė gliukozė - angliavandeniai + AV aliarmas Įkelta %1$d įrašų Paprastas bolusas Aliarmai Valandinė bazė Bolusai - Angliavandeniai + AV Paros insulinas Klaidos Gliukozė @@ -369,7 +407,7 @@ Vienetai mg/dl mmol/l - IVT (Insulino Veikimo Trukmė) + IVT Tikslinis diapazonas: Vizualizacijos diapazonas Aukštoji ir žemoji riba Apžvalgos grafikuose bei išmaniuosiuose laikrodžiuose @@ -420,7 +458,7 @@ BPD Data Koeficientas - # dienų + # d. Svoris Duomenys netikslūs, jei bolusai naudojami kateterių užpildymui! Duomenys seni, spauskite \"ATNAUJINTI\" @@ -507,6 +545,9 @@ Suaugęs Insulinui rezistentiškas suaugęs Pasirinkite paciento amžių saugumo riboms nustatyti + Paciento vardas + Pateikite paciento vardą arba slapyvardį, kad galima būtų atskirti tarp skirtingų konfigūracijų. + Vartotojas Glimp %1$s įtraukite į baterijos optimizavimo baltąjį sąrašą tinkamam veikimui užtikrinti Ciklas sustabdytas @@ -543,8 +584,6 @@ Įgalinti superbolusus skaičiuoklėje Įgalina superbolusų naudojimą insulino skaičiuoklėje. Nenaudokite, kol nesuprantate, ką superbolus funkcija atlieka. NAUDODAMI AKLAI GALITE PERDOZUOTI INSULINO! Pradžios ekrane rodyti spalvotus indikatorius - Pradžios ekrane rodyti papildomus šviesos indikatorius - Pradžios ekrane rodyti papildomus šviesos indikatorius kateterio, insulino, sensoriaus naudojimo trukmei bei baterijos įkrovimo lygiui. Įspėjimo apie žemą rezervuaro lygį riba [U] Įspėjimo apie kritiškai žemą rezervuaro lygį riba [U] Įspėjimo apie žemą baterijos įkrovimo lygį riba [%] @@ -570,11 +609,11 @@ Sensorius Kateteris Insulinas - valandos + val. Netinkamas profilis!!! Profilio keitimas - Pompos baterija - Pompos baterijos keitimas + Baterija + Baterijos keitimas Aliarmų nustatymai Kritiškai aukštas Aukštas @@ -673,7 +712,7 @@ Prijungimo laikas baigėsi Maistas g - min + min. val d ]]> @@ -704,8 +743,13 @@ KG duomenų perdavimo nustatymai Rodyti gliukozės pokyčio detales Rodyti pokytį su reikšme po kablelio - SMB max minutės + Kaip dažnai SMB bus leidžiami, min. + SMB maks. minutės SMB atitinka valandinės bazės insulino kiekį, kuris gaunamas ne daugiau, kaip per + NDM SMB maks. min. + NDM SMB atitinka valandinės bazės insulino kiekį, kuris gaunamas ne daugiau, kaip per + Angliavandenių pasiūlymo riba + Kai angliavandeniai yra siūlomi, kaip gramų angliavandenių aktyvuos pranešimą Pompos programinės įrangos versija nepalaikoma Siųsti KG duomenis į xDrip+ Xdrip+ pasirinkite 640g/Eversense duomenų šaltinį @@ -771,7 +815,8 @@ Sight prieš %1$.2f h - %1$d minutės + %1$d min. + %1$dm Leisti SMB visada Leisti SMB visada, nepriklausomai nuo bolusų. Įmanoma tik naudojant patikimų, filtruotų KG duomenų šaltinį, pvz.: Dexcom G5 Leisti SMB po angliavandenių įvedimo @@ -819,7 +864,7 @@ Nuokrypiai Aktyvūs angliavandeniai Aktyvus insulinas organizme - Valandinės bazės + Bazė Veiksmas nepasirinktas, nieko neįvyks Pradėti \"Hipo\" LT Naudojama neužbaigta versija. Uždaras ciklas neaktyvus. @@ -853,7 +898,7 @@ reikšmė turi būti teigiama maksimalus bazės daugiklis maksimalus paros bazės daugiklis - Bolusas buvo suleistas per paskutines 3 minutes, praleidžiant SMB + Bolusas buvo suleistas per paskutines 3 minutes, SMB praleidžiamas Bazė nustatyta teisingai Ribojamas maks procentų kiekis %1$d%%, nes %2$s Bolusas ribojamas iki %1$.1f vv dėl %2$s @@ -935,6 +980,7 @@ Pradėti jūsų pirmąjį tikslą Leidimas Prašyti leidimo + Norint gauti pranešimus, programai reikalingas sisteminio lango leidimas Aplikacijai reikia vietos nustatymo leidimo BT skenavimui atlikti Aplikacijai reikia leidimo prieigai prie saugyklos, kad galėtų išsaugoti žurnalo įrašus Užklausa @@ -969,6 +1015,9 @@ = 100]]> Pasyvus laikinas tikslas mažina jautrumą + Rezistencija mažina tikslą + Kai nustatoma rezistencija, tikslinė gliukozės vertė sumažinama + Jautrumas didina tikslą Netinkami pompos nustatymai, patikrinkite dokumentaciją ir įsitikinkite, kad Quick info meniu yra pavadintas QUICK INFO, naudojant 360 configuration software. Pasirinktinis Didelis laiko neatitikimas @@ -978,6 +1027,7 @@ Dėmesio: jei aktyvuosite ir prijungsite prie aparatinės pompos, AndroidAPS nukopijuos bazės nustatymus iš profilio į pompą, pakeisdamas esančius nustatymus pompoje. Įsitikinkite, kad turimi bazės nustatymai AndroidAPS yra teisingi. Jei nesate tikri arba nenorite iš naujo keisti bazės nustatymų jūsų pompoje, paspauskite atšaukti ir pakartokite prijungimą prie pompos kitą kartą. Terapijos duomenys nepilni Serviso nustatymai + Gavėjo el. paštas Siunčiamų įrašų skaičius Servisas Serv @@ -1120,14 +1170,14 @@ Tomato (MiaoMiao) Tomato sekundė - minutė - valanda - diena + min. + val. + d. savaitė sekundės - minutės - valandos - dienų + min. + val. + d. savaičių Jūsų Tidepool vartotojo vardas, įprastai jūsų el. pašto adresas Vartotojo vardas @@ -1169,7 +1219,7 @@ Nustatyta, kad naudojate neteisingą versiją. Ciklas išjungtas! sena versija labai sena versija - Nauja versija pasiekiama mažiausiai %1$d dienų! Po %2$d grįšite prie stabdymo prie žemo, po %3$d ciklas bus išjungtas + Nauja versija pasiekiama mažiausiai %1$d d.! Po %2$d grįšite prie stabdymo prie žemo, po %3$d ciklas bus išjungtas 2 val %1$.2fV Dexcom programėlė (modifikuota) @@ -1234,7 +1284,7 @@ Pažadinti ir nustatyti Išvalyti Boluso bloką Išvalyti RileyLink nustatymus - Baterijos tipas (galios vaizdas) + Baterijos tipas (pagal galią) Nepasirinkta (paprastas vaizdas) Šarminė (išplėstinis vaizdas) Ličio (išplėstinis vaizdas) @@ -1311,7 +1361,7 @@ Operacija negalima. \n\n Pirmiausia turite sukonfigūruoti Medronic pompą prieš atliekant šią operaciją. Laiko pokytis didesnis nei 24 val. - Valandinės bazės + Bazė Nustatymai Pranešimai Statistika @@ -1328,7 +1378,7 @@ Aktyvi Užmigusi - Atšaukėte Bolusą, kuris jau buvo nustatytas pompoje. Medronic pompa nepalaiko šio atšaukimo, todėl turite jį atšaukti rankiniu būdu. Sustabdykite pompą ir vėl ją paleiskite (jei vis dar norite atšaukti Bolusą). Aplikacija perims pokyčius su kitu atnaujinimu (per mažiau nei 5 minutes). + Atšaukėte bolusą, kuris jau buvo nustatytas pompoje. Medronic pompa nepalaiko šio atšaukimo, todėl turite jį atšaukti rankiniu būdu. Sustabdykite pompą ir vėl ją paleiskite (jei vis dar norite atšaukti bolusą). Aplikacija perims pokyčius su kitu atnaujinimu (per mažiau nei 5 minutes). Negalima sužinoti dabartinės laikinos bazės. Negalima atšaukti dabartinės laikinos bazės. Operacija stabdoma. Profilio nustatymas nepavyko dėl per didelės nustatytos bazės: %1$s @@ -1390,9 +1440,9 @@ Pompa nepasirinkta Pasirinkite vienetus, kurių vertes norite parodyti Įkelti vietinio profilio pakeitimus į NS - IVT (Insulino Veikimo Trukmė) - IA (insulino/angliavandenių santykis) - JIF (jautrumo insulinui faktorius) + IVT + IA + JIF TIKSLAS Klonuoti Pirmiausia išsaugoti arba anuliuoti dabartinius pokyčius @@ -1434,5 +1484,13 @@ Ištęsto boluso funkcija sustabdys uždaro ciklo režimą ištęsto boluso veikimo metu. Ar tikrai norite patvirtinti savo pasirinkimą? Uždara ciklas išjungtas dėl ištęsto boluso veikimo IB (Ištęstas bolusas) + \"PhoneChecker\" + Grafiko meniu + AS + SMB užklausos laikas + SMB įvykdymo laikas + Laikinos bazės užklausos laikas + Laikinos bazės įvykdymo laikas + Insight pompos aliarmai diff --git a/app/src/main/res/values-nl-rNL/strings.xml b/app/src/main/res/values-nl-rNL/strings.xml index f35d153c0d..1d91d77a7f 100644 --- a/app/src/main/res/values-nl-rNL/strings.xml +++ b/app/src/main/res/values-nl-rNL/strings.xml @@ -105,7 +105,6 @@ Verschil: Configurator Doelen - OpenAPS MA Overzicht NS Profiel Eenvoudig profiel @@ -543,8 +542,6 @@ Activeer superbolus in de wizard Activeer de superbolus functie in de wizard. Activeer deze niet tot je begrijpt wat dit doet. OVERDOSIS IS MOGELIJK BIJ BLINDELINGS GEBRUIK! Toon statusindicatoren op startscherm - Toon uitgebreide statusindicatoren op overzicht scherm - Statusindicatoren inschakelen voor cage, iage, sage, reservoir en batterijniveau op het overzicht scherm. Drempel waarschuwing reservoir niveau [E] Drempel alarm reservoir niveau [E] Drempel waarschuwing batterij niveau [%] diff --git a/app/src/main/res/values-pl-rPL/objectives.xml b/app/src/main/res/values-pl-rPL/objectives.xml index a2be1d375e..d2daad672f 100644 --- a/app/src/main/res/values-pl-rPL/objectives.xml +++ b/app/src/main/res/values-pl-rPL/objectives.xml @@ -20,7 +20,9 @@ 1 tydzień sukcesu w działaniu pętli w ciągu dnia z regularnym wprowadzaniem spożywanych węglowodanów Włączanie dodatkowych funkcji do użytku, jak AMA Włączanie dodatkowych funkcji do użytku, jak SMB (Super Mikro Bolusy) + Włączanie automatyzacji Musisz przeczytać wiki i zwiększyć maxIOB, aby SMB działało dobrze! Dobrym początkiem jest maxIOB = średni bolus + 3 x maks. dzienna dawka bazowa + Przeczytaj dokumenty jak działa automatyzacja. Skonfiguruj swoje pierwsze proste zasady. Na początku zamiast działań pozwól AAPS wyświetlać powiadomienia. Gdy jesteś pewien, że automatyzacja jest uruchamiana we właściwym czasie, zastąp powiadomienie prawdziwymi działaniami. (https://androidaps.readthedocs.io/en/latest/EN/Usage/Automation.html) BG dostępne w NS Status pompy dostępny w NS Ręczne zarządzanie @@ -35,6 +37,7 @@ Wyświetl zawartość wtyczki Pętla (Loop) Użyj funkcji skalowania przez dłuższe przytrzymanie wykresu glikemii Wprowadź + Jeśli masz co najmniej 3 miesiące doświadczenia w zamkniętej pętli z innymi systemami, możesz zakwalifikować się do otrzymania kodu do pominięcia etapu nauki. Zobacz https://androidaps.readthedocs.io/en/latest/EN/Usage/Objectives.html#skip-targets. Kod został zaakceptowany Niepoprawny kod Potwierdź swoje umiejętności diff --git a/app/src/main/res/values-pl-rPL/protection.xml b/app/src/main/res/values-pl-rPL/protection.xml index 3ea04e700d..d2b1b43d2a 100644 --- a/app/src/main/res/values-pl-rPL/protection.xml +++ b/app/src/main/res/values-pl-rPL/protection.xml @@ -1,2 +1,23 @@ - + + Wymagane uwierzytelnienie + Umieść palec na czytniku linii papilarnych, aby zweryfikować swoją tożsamość + Ochrona ustawień + Ochrona aplikacji + Ochrona Bolusa + Hasło główne + Hasło ustawień + Hasło aplikacji + Hasło bolusa + Odblokuj ustawienia + Biometryczne + Hasło użytkownika + Bez ochrony + Z ochroną + Hasło główne nie jest ustawione!\n\nProszę ustawić swoje hasło główne w preferencjach (%1$s → %2$s) + Hasło ustawione! + Hasło nie ustawione + Hasło nie zostało zmienione + Hasło usunięte! + Wpisz hasło tutaj + diff --git a/app/src/main/res/values-pl-rPL/strings.xml b/app/src/main/res/values-pl-rPL/strings.xml index 1e75d9a959..769d87d688 100644 --- a/app/src/main/res/values-pl-rPL/strings.xml +++ b/app/src/main/res/values-pl-rPL/strings.xml @@ -105,7 +105,6 @@ Delta: Konfiguracja Zadania - OpenAPS MA Przegląd Profil Nightscout Prosty profil @@ -543,8 +542,14 @@ Zezwalaj na superbolus w kalkulatorze Włącz funkcję Superbolus w kalkulatorze. Nie uruchamiaj, dopóki nie nauczysz się jak ta funkcja działa. MOŻESZ DOPROWADZIĆ DO PRZEDAWKOWANIA INSULINY JEŻELI UŻYJESZ TEJ FUNKCJI NIE POSIADAJĄC ODPOWIEDNIEJ WIEDZY! Pokaż diody stanu na ekranie głównym - Pokaż diody stanu na ekranie głównym - Włącz diody stanu dla cage, iage, sage, rezerwuar i poziom baterii na ekranie głównym. + Ostrzeżenie o czasie wkłucia [h] + Krytyczny czas wkłucia [h] + Ostrzeżenie o czasie insuliny [h] + Krytyczny czas insuliny [h] + Ostrzeżenie o czasie sensora CGM [h] + Krytyczny czas sensora CGM [h] + Ostrzeżenie o czasie baterii [h] + Krytyczny czas baterii [h] Próg ostrzeżenia o poziomie zbiornika [U] Próg ostrzeżenia o krytycznym poziomie zbiornika [U] Próg ostrzeżenia o poziomie baterii [%] @@ -1433,4 +1438,6 @@ Wiadomość Wyczyścić kolejkę? Wszystkie dane w kolejce zostaną utracone! + Wskaźniki stanu + Kopiowanie ustawień z NS diff --git a/app/src/main/res/values-pt-rBR/objectives.xml b/app/src/main/res/values-pt-rBR/objectives.xml index 3ff8541944..76c269ca71 100644 --- a/app/src/main/res/values-pt-rBR/objectives.xml +++ b/app/src/main/res/values-pt-rBR/objectives.xml @@ -20,6 +20,7 @@ 1 semana de looping durante o dia com sucesso com entrada regular de hidratos de carbono A activar recursos adicionais para uso durante o dia, como assistente avançado de refeição Activando recursos adicionais para uso durante o dia, como SMB + A activar a automação Deverá ler a wiki e aumentar a IOB máx para que os SMBs funcionem devidamente! Inicialmente poderá considerar maxIOB=média dos bólus + 3 x a basal máxima Glic disponível no NS Estado da Bomba disponível no NS diff --git a/app/src/main/res/values-pt-rBR/protection.xml b/app/src/main/res/values-pt-rBR/protection.xml index 3ea04e700d..67ae6b40c1 100644 --- a/app/src/main/res/values-pt-rBR/protection.xml +++ b/app/src/main/res/values-pt-rBR/protection.xml @@ -1,2 +1,23 @@ - + + Autenticação necessária + Coloque o dedo sobre o leitor de impressões digitais para verificar a sua identidade + Definições Protecção + Protecção Aplicação + Protecção Bólus + Password Mestre + Definições Password + Password Aplicação + Password Bólus + Definições Desbloqueio + Biométrico + Password Personalizada + Sem Protecção + Protecção + A Password Mestre não está definida!\n\nPor favor, configure Password Mestre em Preferências (%1$s → %2$s) + Password foi definida! + Password não foi definida + Password não foi alterada + Password apagada! + Insira a password aqui + diff --git a/app/src/main/res/values-pt-rBR/strings.xml b/app/src/main/res/values-pt-rBR/strings.xml index dfe11392ab..93f7ede06e 100644 --- a/app/src/main/res/values-pt-rBR/strings.xml +++ b/app/src/main/res/values-pt-rBR/strings.xml @@ -43,6 +43,7 @@ Integração para as pessoas que fazem múltiplas injeções diárias para a sua terapia de diabetes Integração para as bombas que não têm qualquer driver ainda (Open Loop) A sensibilidade é calculada da mesma forma que Oref0, mas você pode especificar o período de tempo para o passado. A absorção mínima de hidratos de carbono é calculada a partir do tempo máximo de absorção de hidratos de carbono das preferências. + A sensibilidade é calculada a partir de dados das últimas 8h ou 24h (usando qualquer um que é mais sensível). Hidratos são cortados (se não absorvidos) após o tempo especificado nas preferências. O Plugin também calcula o UAM. A sensibilidade é calculada como uma média ponderada de desvios. Desvios mais recentes têm maior peso. A absorção mínima de hidratos de carbono é calculada a partir do tempo máximo de absorção de hidratos de carbono das preferências. Este algoritmo é o mais rápido em seguir as mudanças de sensibilidade. Receber valores de Glicose da aplicação Eversense modificada. Receber valores BG do Glimp. @@ -105,7 +106,6 @@ Delta: Configurador Objetivos - OpenAPS MA Visão geral Perfil NS Perfil simples @@ -218,17 +218,44 @@ Basal Máxima IOB que OpenAPS pode dar [U] Este valor é denominado Max IOB em contexto OpenAPS \nEste é o valor máximo de insulina em [U] que APS pode dar de uma vez. Dispensar + Será perguntado pela password mestre, que será usada para encriptar preferências exportadas. + Será perguntado pela password mestre, que será necessária para desencriptar preferências importadas. + Exportação cancelada! Preferências NÃO foram exportadas! + Importação cancelada! Preferências NÃO foram importadas! + Por favor, verifique as preferências antes da importação: + Preferências não podem ser importadas! + As preferências não devem ser importadas! Explicar problemas de importação… Detalhes de problemas de importação Importar Importar mesmo assim (PERIGOSO!) + As preferências foram criadas com uma variante diferente do AAPS (%1$s) enquanto tem: %2$s.\n\nAlgumas configurações podem estar ausentes ou inválidas - após a importação, por favor verifique e actualize suas preferências. + Preferências foram criadas num dispositivo diferente. Não há problema se estiver a importar de telefone diferente/antigo, mas se certifique que as preferências importadas estão corretas! + Está a usar formato ultrapassado herdado a partir de versões antigas do AAPS, o que não é seguro! Use-o apenas como um último recurso, se não tiver uma exportação no actual no formato JSON. + Preferências importadas já são %1$s dias antigas! Talvez tenha preferências mais actualizadas ou escolheu o ficheiro errado? Lembre-se de exportar preferências regularmente! + Formato de data-hora inválido! Formato do ficheiro Criado em Versão AAPS Variante de Compilação + A exportar nome do paciente do dispositivo + A exportar modelo do dispositivo Encriptação do Ficheiro Antigo Formato de Exportação Novo formato de encriptação + Novo formato de depuração (não encriptado) + Formato de exportação desconhecido + Ficheiro de configurações adulterado + Ficheiro de configurações é seguro + A usar um formato de configurações não seguro e não encriptado + Erro de formato JSON, campo necessário ausente (formato, conteúdo, metadados ou segurança) + Erro ao desencriptar, a password inserida não pode desencriptar o ficheiro + Ficheiro de verificação (hash) em falta, não é possível verificar a autenticidade de configurações! + Ficheiro foi modificado após exportação! + Erro Desencriptação, a análise de preferências falhou! + Erro de Desencriptação, a password é inválida ou configurações de arquivo foram modificadas! Pode acontecer que o ficheiro importado foi exportado com uma Password Mestre diferente. + Configuração de encriptação ausente, formato de configurações é inválido! + Algoritmo de encriptação não suportado ou não especificado! DanaR Conectando Conectado @@ -518,6 +545,8 @@ Adulto Adulto resistente insulina Por favor seleccione a idade do diabético para definir os limites de segurança + Nome do Paciente + Por favor, forneça nome do paciente ou alcunha para diferenciar entre várias configurações Utilizador Glimp %1$s necessita de autorizar a não optimização da bateria para assegurar a performance necessária @@ -555,8 +584,6 @@ Activar superbólus no assistente Habilite a funcionalidade de superbolus no assistente. Não habilite até que aprenda o funcionamento. PODE CAUSAR OVERDOSE DE INSULINA SE USAR INDISCRIMINADAMENTE! Mostrar luzes de estado no ecrã principal - Mostrar luzes de estado estendido no ecrã principal - Ativar as luzes de status estendida para idade da cânula, insulina, sensor, reservatório e bateria no ecrã inicial. Limite de aviso de nível de reservatório [U] Limite crítico de nível de reservatório [U] Limite de aviso de nível de bateria [%] @@ -716,8 +743,13 @@ Configurações de upload de BG Mostrar Delta detalho Mostrar delta com mais um ponto decimal + Com que frequência em min os SMBs serão dados SMB máx. minutos Limite de minutos de basal para SMB + UAM SMB máx minutos + Max minutos de basal para limitar SMB para UAM + Limite Sugestão de Hidratos + Quando Hidratos são sugeridos, quantos hidratos irá solicitar uma notificação Firmware bomba não suportado Enviar dados Glic. para xDrip+ Seleccionar 640g/Eversense como fonte no xDrip+ @@ -983,6 +1015,10 @@ = 100]]> Baixo alvotemp baixa sensibilidade + Resistência reduz alvo + Quando a resistência for detectada, diminui o alvo de glicose + Sensibilidade aumenta o alvo + Quando a sensibilidade é detectada, aumenta o alvo glicose Configuração da bomba inválida, verifique a documentação e se o menu de informações rápidas está nomeado de QUICK INFO utilizando o programa de configuração 360. Personalizado Grande diferença Horária @@ -992,6 +1028,8 @@ Atenção: Se conectar à sua bomba física e activar o perfil, o AndroidAPS irá copiar as definições desse perfil para as definições da bomba, apagando o memorizado na bomba. Por favor verifique que o que preencheu no perfil da app tem os mesmos valores que estão na bomba. Em caso contrario pressione imediatamente cancelar e corrija antes de voltar a ligar à bomba. Dados tratamento incompletos Configurações de manutenção + Email destinatário + Encriptar configurações exportadas Nr. de registos a enviar Manutenção MANU @@ -1199,6 +1237,8 @@ existe não existe Alvo Temp %1$s + Ligação Bluetooth com o dispositivo %1$s %2$s + Ligação ao dispositivo Bluetooth WiFi SSID %1$s %2$s Autosens %1$s %2$s %% Autosens % @@ -1458,7 +1498,31 @@ Hora de execução Basal Temp Alertas Bomba Insight + a partir da app Autenticador para: %1$s + Activar Autenticador + Autenticar comandos usando Uma-Password-Única que sejam geradas pelo Google Authenticator ou app 2FA similar. + PIN adicional no token final + Dígitos adicionais que devem ser memorizados e colados no final de cada Uma-Password-Única que seja gerada + Configuração do Autenticador + OTP para verificar: + Repor Autenticadores + Repor Chave Autenticador + Tem certeza de redefinir chave Authenticador? Ele tornará todos os Authenticators configurados actualmente como inválidos, e precisará de os configurar novamente. + Nova Chave do Autenticador foi gerada! Por favor, use o QRCode actualizado para os autenticadores. + 1. Instalar Autenticador + 2. Pesquise o código para configurar os códigos OTP do AndroidAPS + 3. Teste Uma-Password-Única + Repor Autenticadores + Instalar uma app Autenticador que suporte Tokens RFC 6238 TOTP em cada telefone seguidor. Populares aplicativos gratuitos são:\n • Authy\n • o Google Authenticator\n • LastPass Autenticador\n • FreeOTP Autenticador + NÃO PARTILHE este código online!\nUse-o apenas para a instalação da app Autenticador nos telefones seguidores. + Ao repor o autenticador, torna inválidos todos os autenticadores já provisionados. Precisará de os configurar novamente! Ao ligar Ao desligar Previsões + Desvio de inclinação + Falha na autorização + Insulina absoluta + Password Mestre é usada para encriptação da cópia de segurança e substituir segurança na aplicação. Lembre-se dela ou guarde-a em um lugar seguro. + As passwords não coincidem + Password Mestre actual diff --git a/app/src/main/res/values-pt-rBR/validator.xml b/app/src/main/res/values-pt-rBR/validator.xml index 3ea04e700d..d15d4fb95f 100644 --- a/app/src/main/res/values-pt-rBR/validator.xml +++ b/app/src/main/res/values-pt-rBR/validator.xml @@ -1,2 +1,21 @@ - + + Apenas dígitos numéricos são permitidos. + Apenas dígitos numéricos dentro de um intervalo de %1$s - %2$s são permitidos. + Este campo não pode conter qualquer carácter especial + Apenas letras padrão são permitidas + Este campo não deve estar vazio + Endereço de e-mail inválido + Número de cartão de crédito inválido + Número de telefone inválido + Nome de domínio inválido + Endereço IP inválido + Url do site não é válido + Não é um nome ou sobrenome válido. + Nome completo inválido. + Formato inválido + Deve ser número de 4 dígitos + Deve ser número de 6 dígitos + Não um comprimento mínimo + Pin deve ser de 3 a 6 dígitos, não o mesmo ou em série + diff --git a/app/src/main/res/values-pt-rPT/objectives.xml b/app/src/main/res/values-pt-rPT/objectives.xml index 4722ee8fa8..195da54c80 100644 --- a/app/src/main/res/values-pt-rPT/objectives.xml +++ b/app/src/main/res/values-pt-rPT/objectives.xml @@ -20,7 +20,9 @@ 1 semana de looping durante o dia com sucesso com entrada regular de hidratos de carbono A activar recursos adicionais para uso durante o dia, como assistente avançado de refeição Activando recursos adicionais para uso durante o dia, como SMB + A activar a automação Deverá ler a wiki e aumentar a IOB máx para que os SMBs funcionem devidamente! Inicialmente poderá considerar maxIOB=média dos bólus + 3 x a basal máxima + Leia os documentos de como a automação funciona. Configure primeiro regras simples. Em vez de acção deixe AAPS apresentar apenas a notificação. Quando tem certeza de automação é accionada no momento certo substitua a notificação por acção real. (https://androidaps.readthedocs.io/en/latest/EN/Usage/Automation.html) Glic disponível no NS Estado da Bomba disponível no NS Execução manual diff --git a/app/src/main/res/values-pt-rPT/protection.xml b/app/src/main/res/values-pt-rPT/protection.xml index 3ea04e700d..67ae6b40c1 100644 --- a/app/src/main/res/values-pt-rPT/protection.xml +++ b/app/src/main/res/values-pt-rPT/protection.xml @@ -1,2 +1,23 @@ - + + Autenticação necessária + Coloque o dedo sobre o leitor de impressões digitais para verificar a sua identidade + Definições Protecção + Protecção Aplicação + Protecção Bólus + Password Mestre + Definições Password + Password Aplicação + Password Bólus + Definições Desbloqueio + Biométrico + Password Personalizada + Sem Protecção + Protecção + A Password Mestre não está definida!\n\nPor favor, configure Password Mestre em Preferências (%1$s → %2$s) + Password foi definida! + Password não foi definida + Password não foi alterada + Password apagada! + Insira a password aqui + diff --git a/app/src/main/res/values-pt-rPT/strings.xml b/app/src/main/res/values-pt-rPT/strings.xml index c4ca9542cc..b31fcdf7d7 100644 --- a/app/src/main/res/values-pt-rPT/strings.xml +++ b/app/src/main/res/values-pt-rPT/strings.xml @@ -43,6 +43,7 @@ Integração para as pessoas que fazem múltiplas injeções diárias para a sua terapia de diabetes Integração para as bombas que não têm qualquer driver ainda (Open Loop) A sensibilidade é calculada da mesma forma que Oref0, mas você pode especificar o período de tempo para o passado. A absorção mínima de hidratos de carbono é calculada a partir do tempo máximo de absorção de hidratos de carbono das preferências. + A sensibilidade é calculada a partir de dados das últimas 8h ou 24h (usando qualquer um que é mais sensível). Hidratos são cortados (se não absorvidos) após o tempo especificado nas preferências. O Plugin também calcula o UAM. A sensibilidade é calculada como uma média ponderada de desvios. Desvios mais recentes têm maior peso. A absorção mínima de hidratos de carbono é calculada a partir do tempo máximo de absorção de hidratos de carbono das preferências. Este algoritmo é o mais rápido em seguir as mudanças de sensibilidade. Receber valores de Glicose da aplicação Eversense modificada. Receber valores Glucose do Glimp. @@ -105,7 +106,6 @@ Delta: Configurador Objetivos - OpenAPS MA Visão geral Perfil NS Perfil simples @@ -218,17 +218,44 @@ Basal Máxima IOB que OpenAPS pode dar [U] Este valor é denominado Max IOB em contexto OpenAPS \nEste é o valor máximo de insulina em [U] que APS pode dar de uma vez. Dispensar + Será perguntado pela password mestre, que será usada para encriptar preferências exportadas. + Será perguntado pela password mestre, que será necessária para desencriptar preferências importadas. + Exportação cancelada! Preferências NÃO foram exportadas! + Importação cancelada! Preferências NÃO foram importadas! + Por favor, verifique as preferências antes da importação: + Preferências não podem ser importadas! + As preferências não devem ser importadas! Explicar problemas de importação… Detalhes de problemas de importação Importar Importar mesmo assim (PERIGOSO!) + As preferências foram criadas com uma variante diferente do AAPS (%1$s) enquanto tem: %2$s.\n\nAlgumas configurações podem estar ausentes ou inválidas - após a importação, por favor verifique e actualize suas preferências. + Preferências foram criadas num dispositivo diferente. Não há problema se estiver a importar de telefone diferente/antigo, mas se certifique que as preferências importadas estão corretas! + Está a usar formato ultrapassado herdado a partir de versões antigas do AAPS, o que não é seguro! Use-o apenas como um último recurso, se não tiver uma exportação no actual no formato JSON. + Preferências importadas já são %1$s dias antigas! Talvez tenha preferências mais actualizadas ou escolheu o ficheiro errado? Lembre-se de exportar preferências regularmente! + Formato de data-hora inválido! Formato do ficheiro Criado em Versão AAPS Variante de Compilação + A exportar nome do paciente do dispositivo + A exportar modelo do dispositivo Encriptação do Ficheiro Antigo Formato de Exportação Novo formato de encriptação + Novo formato de depuração (não encriptado) + Formato de exportação desconhecido + Ficheiro de configurações adulterado + Ficheiro de configurações é seguro + A usar um formato de configurações não seguro e não encriptado + Erro de formato JSON, campo necessário ausente (formato, conteúdo, metadados ou segurança) + Erro ao desencriptar, a password inserida não pode desencriptar o ficheiro + Ficheiro de verificação (hash) em falta, não é possível verificar a autenticidade de configurações! + Ficheiro foi modificado após exportação! + Erro Desencriptação, a análise de preferências falhou! + Erro de Desencriptação, a password é inválida ou configurações de arquivo foram modificadas! Pode acontecer que o ficheiro importado foi exportado com uma Password Mestre diferente. + Configuração de encriptação ausente, formato de configurações é inválido! + Algoritmo de encriptação não suportado ou não especificado! DanaR A ligar Ligado @@ -518,6 +545,8 @@ Adulto Adulto resistente insulina Por favor seleccione a idade do diabético para definir os limites de segurança + Nome do Paciente + Por favor, forneça nome do paciente ou alcunha para diferenciar entre várias configurações Utilizador Glimp %1$s necessita de autorizar a não optimização da bateria para assegurar a performance necessária @@ -555,8 +584,14 @@ Activar superbólus no assistente Habilite a funcionalidade de superbolus no assistente. Não habilite até que aprenda o funcionamento. PODE CAUSAR OVERDOSE DE INSULINA SE USAR INDISCRIMINADAMENTE! Mostrar luzes de estado no ecrã principal - Mostrar luzes de estado no ecrã principal - Activar as luzes de estado para idade da cânula, idade da insulina, idade do sensor, reservatório e bateria no ecrã inicial. + Limite aviso idade canula [h] + Limite Crítico Idade Canula [h] + Limite aviso idade insulina [h] + Limite crítico idade insulina [h] + Limite aviso idade sensor [h] + Limite crítico idade sensor [h] + Limite de aviso de nível de bateria [h] + Limite crítico de nível de bateria [h] Limite de aviso de nível de reservatório [U] Limite crítico de nível de reservatório [U] Limite de aviso de nível de bateria [%] @@ -716,8 +751,13 @@ Configurações de upload de BG Mostrar Delta detalho Mostrar delta com mais um ponto decimal + Com que frequência em min os SMBs serão dados SMB máx. minutos Limite de minutos de basal para SMB + UAM SMB máx minutos + Max minutos de basal para limitar SMB para UAM + Limite Sugestão de Hidratos + Quando Hidratos são sugeridos, quantos hidratos irá solicitar uma notificação Firmware bomba não suportado Enviar dados Glic. para xDrip+ Seleccionar 640g/Eversense como fonte no xDrip+ @@ -983,6 +1023,10 @@ = 100]]> Baixo alvotemp baixa sensibilidade + Resistência reduz alvo + Quando a resistência for detectada, diminui o alvo de glicose + Sensibilidade aumenta o alvo + Quando a sensibilidade é detectada, aumenta o alvo glicose Configuração da bomba inválida, verifique a documentação e se o menu de informações rápidas está nomeado de QUICK INFO utilizando o programa de configuração 360. Personalizado Grande diferença Horária @@ -992,6 +1036,8 @@ Atenção: Se conectar à sua bomba física e activar o perfil, o AndroidAPS irá copiar as definições desse perfil para as definições da bomba, apagando o memorizado na bomba. Por favor verifique que o que preencheu no perfil da app tem os mesmos valores que estão na bomba. Em caso contrario pressione imediatamente cancelar e corrija antes de voltar a ligar à bomba. Dados tratamento incompletos Configurações de manutenção + Email destinatário + Encriptar configurações exportadas Nr. de registos a enviar Manutenção MANU @@ -1199,6 +1245,8 @@ existe não existe Alvo Temp %1$s + Ligação Bluetooth com o dispositivo %1$s %2$s + Ligação ao dispositivo Bluetooth WiFi SSID %1$s %2$s Autosens %1$s %2$s %% Autosens % @@ -1458,7 +1506,31 @@ Hora de execução Basal Temp Alertas Bomba Insight + a partir da app Autenticador para: %1$s + Activar Autenticador + Autenticar comandos usando Uma-Password-Única que sejam geradas pelo Google Authenticator ou app 2FA similar. + PIN adicional no token final + Dígitos adicionais que devem ser memorizados e colados no final de cada Uma-Password-Única que seja gerada + Configuração do Autenticador + OTP para verificar: + Repor Autenticadores + Repor Chave Autenticador + Tem certeza de redefinir chave Authenticador? Ele tornará todos os Authenticators configurados actualmente como inválidos, e precisará de os configurar novamente. + Nova Chave do Autenticador foi gerada! Por favor, use o QRCode actualizado para os autenticadores. + 1. Instalar Autenticador + 2. Pesquise o código para configurar os códigos OTP do AndroidAPS + 3. Teste Uma-Password-Única + Repor Autenticadores + Instalar uma app Autenticador que suporte Tokens RFC 6238 TOTP em cada telefone seguidor. Populares aplicativos gratuitos são:\n • Authy\n • o Google Authenticator\n • LastPass Autenticador\n • FreeOTP Autenticador + NÃO PARTILHE este código online!\nUse-o apenas para a instalação da app Autenticador nos telefones seguidores. + Ao repor o autenticador, torna inválidos todos os autenticadores já provisionados. Precisará de os configurar novamente! Ao ligar Ao desligar Previsões + Desvio de inclinação + Falha na autorização + Insulina absoluta + Password Mestre é usada para encriptação da cópia de segurança e substituir segurança na aplicação. Lembre-se dela ou guarde-a em um lugar seguro. + As passwords não coincidem + Password Mestre actual diff --git a/app/src/main/res/values-pt-rPT/validator.xml b/app/src/main/res/values-pt-rPT/validator.xml index 3ea04e700d..d15d4fb95f 100644 --- a/app/src/main/res/values-pt-rPT/validator.xml +++ b/app/src/main/res/values-pt-rPT/validator.xml @@ -1,2 +1,21 @@ - + + Apenas dígitos numéricos são permitidos. + Apenas dígitos numéricos dentro de um intervalo de %1$s - %2$s são permitidos. + Este campo não pode conter qualquer carácter especial + Apenas letras padrão são permitidas + Este campo não deve estar vazio + Endereço de e-mail inválido + Número de cartão de crédito inválido + Número de telefone inválido + Nome de domínio inválido + Endereço IP inválido + Url do site não é válido + Não é um nome ou sobrenome válido. + Nome completo inválido. + Formato inválido + Deve ser número de 4 dígitos + Deve ser número de 6 dígitos + Não um comprimento mínimo + Pin deve ser de 3 a 6 dígitos, não o mesmo ou em série + diff --git a/app/src/main/res/values-ro-rRO/strings.xml b/app/src/main/res/values-ro-rRO/strings.xml index b72c1dadd9..f4f0cf24c9 100644 --- a/app/src/main/res/values-ro-rRO/strings.xml +++ b/app/src/main/res/values-ro-rRO/strings.xml @@ -104,7 +104,6 @@ Diferență: Configurator Obiective - OpenAPS MA Privire de ansamblu Profil NS Profil simplu @@ -517,8 +516,6 @@ Activează superbolus în asistent Activează funcționalitatea de superbolus în asistentul de buclă. Nu activați până nu înțelegeți ce face cu adevărat. DACĂ ESTE FOLOSIT ÎN NECUNOȘTINȚĂ DE CAUZĂ POATE DUCE LA SUPRADOZĂ DE INSULINĂ! Afișați indicatorii luminoși ai pompei pe ecranul de start - Afișați indicatorii luminoși referitori la starea detaliată a pompei pe ecranul principal - Activați indicatori pentru CAGE, IAGE, SAGE, nivel baterie și rezervor pe ecranul principal. Pragul de avertisment pentru insulina din rezervor [U] Pragul critic al nivelului insulinei în rezervor [U] IOB diff --git a/app/src/main/res/values-ru-rRU/objectives.xml b/app/src/main/res/values-ru-rRU/objectives.xml index 38c25925e7..bc0e840894 100644 --- a/app/src/main/res/values-ru-rRU/objectives.xml +++ b/app/src/main/res/values-ru-rRU/objectives.xml @@ -20,7 +20,9 @@ 1 неделя успешной дневной работы с регулярным введением углеводов Активация таких доп функций для дневного времени как расширенный калькулятор болюса advanced meal assist Активация таких доп функций для дневного времени как супер микро болюс SMB + Включение автоматизации Прочтите wiki и увеличьте maxIOB чтобы супер микро болюс SMB заработал как положено! Хорошее начало – maxIOB = средний болюс на еду + троекратный максимальный суточный базал + Прочтите документацию по автоматизации. Настройте свои первые простые правила. Вместо действия позвольте AAPS только выводить уведомления. Если вы уверены, что автоматизация инициируется в нужное время, замените уведомление реальным действием. гликемия доступна в NS Статус помпы доступен в NS Ввод вручную diff --git a/app/src/main/res/values-ru-rRU/protection.xml b/app/src/main/res/values-ru-rRU/protection.xml index 3ea04e700d..6198bca5d9 100644 --- a/app/src/main/res/values-ru-rRU/protection.xml +++ b/app/src/main/res/values-ru-rRU/protection.xml @@ -1,2 +1,23 @@ - + + Требуется авторизация + Поместите палец на устройство считывания отпечатков, чтобы подтвердить свою идентичность + Защита настроек + Защита приложения + Защита болюсов + Главный пароль + Пароль параметров + Пароль приложения + Пароль болюсов + Разблокировать настройки + Биометрия + Настраиваемый пароль + Без защиты + Защита + Не задан главный пароль!\n\nЗадайте главный пароль в настройках (%1$s → %2$s) + Пароль задан! + Пароль не задан + Пароль не был изменён + Пароль сброшен! + Введите пароль здесь + diff --git a/app/src/main/res/values-ru-rRU/strings.xml b/app/src/main/res/values-ru-rRU/strings.xml index 7f549201e0..dc101ab364 100644 --- a/app/src/main/res/values-ru-rRU/strings.xml +++ b/app/src/main/res/values-ru-rRU/strings.xml @@ -43,6 +43,7 @@ Интеграция с помпой для тех, кто делает многочисленные подколки для компенсации диабета Интеграция с помпами, еще не имеющими драйвера (незамкнутый цикл) Чувствительность вычисляется аналогично алгоритму oref0, но можно включить период прошлого. Минимальное усвоение углеводов вычисляется на основе макс усвоения из настроек. + Чувствительность рассчитывается на основе данных за прошедшие 8 часов и (неусвоенные) углеводы не учитываются после времени указанного в настройках. Плагин также вычисляет UAM. Чувствительность рассчитывается как средневзвешенное от отклонений (deviations). Более поздние отклонения имеют больший вес. Минимальное усвоение углеводов рассчитывается на основе макс времени усвоения углеводов в настройках. Этот алгоритм быстрее всего отслеживает изменения чувствительности. Получать данные гликемии от пропатченного приложения Eversense. Получать данные гликемии от Glimp. @@ -105,7 +106,6 @@ дельта: конфигуратор Цели - Помощник болюса OpenAPS MA начало профиль NS простой профиль @@ -218,6 +218,44 @@ макс базал активн инс подаваемый с OpenAPS (ед) Эта величина называется Max IOB (макс активн инс) в OpenAPS\n. Это макс кол-во инсулина в ед. [U] которое APS может подать единовременно. отклонить + Будет предложено ввести главный пароль, который будет использоваться для шифрования экспортированных параметров. + Вам будет предложено ввести главный пароль, необходимый для расшифровки импортированных настроек. + Экспорт отменен! Настройки НЕ экспортированы! + Импорт отменен! Настройки не импортированы! + Проверьте настройки перед импортом: + Не удается импортировать настройки! + Не следует импортировать настройки! + Объяснить проблемы импорта… + Сведения о проблемах импорта + Импортировать + Импортировать в любом случае (ОПАСНО!) + Параметры были созданы с другим вариантом AAPS (%1$s) в то время как у вас: %2$s.\n\nНекоторые параметры могут отсутствать или быть недопустимы-после импорта проверьте и обновите параметры. + Параметры созданы на другом устройстве. Это нормально, если вы импортируете из старого/другого телефона, но убедитесь, что импортированные параметры - верные! + Вы используете устаревший формат из старых версий AAPS, который не безопасен! Используйте его только в крайнем случае, если у вас нет экспорта в текущем формате JSON. + Импортируемым параметрам уже %1$s дней! Может быть у вас есть более актуальные параметры или вы выбрали неправильный файл? Не забудьте регулярно экспортировать параметры! + Недопустимый формат даты и времени! + Формат файла + Дата создания + Версия AAPS + Версия сборки + Имя пациента экспортируемого устройства + Модель экспортируемого устройства + Шифрование файла + Старый формат экспорта + Новый зашифрованный формат + Новый формат отладки (незашифрованный) + Неизвестный формат экспорта + Файл параметров несанкционированно изменен + Файл настроек безопасен + Применяется незащищенный, незашифрованный формат параметров + Ошибка формата JSON, отсутствует обязательное поле (формат, содержимое, метаданные или защита) + Ошибка расшифровки, указанный пароль не может расшифровать файл + Отсутствует контрольная сумма файла (хэш), не удалось проверить подлинность параметров! + Файл был изменен после экспорта! + Ошибка расшифровки, не удалось проанализировать настройки! + Ошибка расшифровки, указан недопустимый пароль или файл параметров изменен! Возможно, импортированный файл был экспортирован с использованием другого главного пароля. + Отсутствует конфигурация шифрования, формат параметров недопустим! + Неподдерживаемый или не прописанный алгоритм шифрования! DanaR соединение устанавливается соединение установлено @@ -507,6 +545,9 @@ взрослый Инсулинорезистентный взрослый выберите возраст пациента для определения ограничителей безопасности + Имя пациента + Укажите имя или псевдоним пациента, чтобы распознавать разные настройки + Пользователь Glimp %1$s необходимо включить в белый список оптимизации батареи для корректной работы ЗЦ остановлен @@ -543,8 +584,14 @@ активировать суперболюс активировать возможность суперболюса в мастере. не активируйте если не знаете что это. МОЖЕТ ВЫЗВАТЬ ПЕРЕДОЗИРОВКУ ИНСУЛИНА ЕСЛИ ИСПОЛЬЗУЕТСЯ ВСЛЕПУЮ Показать индикаторы состояния на главном экране - Показывать подробные индикаторы состояния на главном экране - Включить на главном экране подробные индикаторы отработанного времени для канюли помпы, инсулина, сенсора, резервуара, а также уровня заряда батареи. + Порог предупреждения о времени, отработанном катетером [h] + Критический порог предупреждения о времени, отработанном катетером [h] + Порог предупреждения о времени, отработанном инсулином [h] + Критический порог предупреждения о времени, отработанном инсулином [h] + Порог предупреждения о времени, отработанном сенсором [h] + Критический порог предупреждения о времени, отработанном сенсором [h] + Порог предупреждения о разрядке батареи [h] + Порог предупреждения о критическом уровне разрядки батареи [h] Порог уровня наполненности резервуара для оповещения [ед.] Порог критического уровня наполненности резервуара [U] Порог предупреждения о разрядке батареи [%] @@ -704,8 +751,13 @@ Параметры загрузки СК Показать подробно дельту Показать дельту еще с одним десятичным знаком + Как часто SMB будут подаваться в минутах Максимум минут микроболюса SMB Верхний лимит минут базала на SMB + Максимум минут микроболюса SMB для непредвиденного приема пищи UAM + Максимум минут базала ограничивающего микроболюсы SMB на непредвиденный прием пищи UAM + Порог предлагаемых углеводов + Когда предлагаются углеводы, какое количество инициирует уведомление Неподдерживаемая версия прошивки помпы Отправить данные СК на xDrip+ В xDrip + выберите источник данных 640g/Eversense @@ -772,6 +824,7 @@ тому назад %1$.2f ч %1$d мин + %1$dm Всегда включать супер микро болюс SMB Всегда включать супер микро болюс SMB независимо от болюсов. Возможно только для источников СК с хорошей фильтрацией данных вроде G5 Активировать супер микро болюс SMB после углеводов @@ -972,6 +1025,10 @@ Context | Edit Context = 100]]> Низкая временная цель temptarget снижает чувствительность = 100]]> + Сопротивляемость понижает цель + При обнаружении сопротивляемости целевой уровень гликемии понижается + Чувствительность поднимает цель + При обнаружении чувствительности целевой уровень глюкозы повышается Недопустимые установки помпы, проверьте документацию и убедитесь, что меню Quick Info называется QUICK INFO, используя приложение 360 для конфигурации помпы. Пользовательские Большая разница во времени @@ -981,6 +1038,8 @@ Context | Edit Context Внимание: Если вы активируете подключение к невиртуальной помпе, AndroidAPS скопирует настройки базала в профиль помпы, перезаписывая существующие настройки, хранящиеся в ней. Убедитесь, что настройки базала в AndroidAPS корректны. Если вы не уверены или не хотите перезаписать настройки базала на помпу, нажмите отменить и повторите подключение в другое время. Данные терапии неполные Параметры обслуживания + Адрес электронной почты + Зашифровать экспортируемые параметры Количество логов для отправки Обслуживание ОБСЛУЖ @@ -1188,6 +1247,8 @@ Context | Edit Context существует не существует Врем цель %1$s + Подключение Bluetooth к устройству %1$s %2$s + Соединение с устройством Bluetooth WiFi SSID %1$s %2$s Автосенс %1$s %2$s %% Автосенс % @@ -1242,6 +1303,7 @@ Context | Edit Context Щелочная (Подробный вид) Литиевая (Подробный вид) NiZn (Подробный вид) + Никель-металлогидридная (подробно) Отладка Болюс/Назначения СКАН @@ -1257,6 +1319,7 @@ Context | Edit Context Сканирование Сканирование завершено Ошибка сканирования: %1$d + Никогда Настройки История @@ -1390,6 +1453,7 @@ Context | Edit Context Очистить начатые Определение времени Хотите сбросить начатую цель? Можете потерять уже достигнутое. + Изменение времени и/или часового пояса на помпе Помпа не выбрана Выберите единицы, в которых вы хотите отображать значения Перенести изменения локального профиля в NS @@ -1446,4 +1510,34 @@ Context | Edit Context Время выполнения временной базальной скорости Оповещения помпы Insight + из приложения Authenticator на: %1$s + Включить аутентификатор + Аутентифицировать команды с помощью одноразовых паролей, сгенерированных Google Authenticator или похожими приложениями 2FA. + Дополнительный PIN-код в конце маркера + Дополнительные цифры, которые должны быть запомнены и добавлены в конце каждого сгенерированного одноразового пароля + Настройка аутентификации + OTP для проверки: + Сбросить аутентификаторы + Сбросить ключ идентификации + Вы действительно хотите сбросить ключ аутентификации? Все сконфигурированные в настоящее время ключи станут недопустимы, и придется их настроить заново. + Создан новый ключ аутентификации! Для идентификации используйте обновленный QRCode. + 1. Установить Аутентификатор + 2. Код сканирования для настройки кодов OTP AndroidAPS + 3. Одноразовый Пароль + Сбросить аутентификаторы + В каждом отслеживающем телефоне установите приложение Authenticator, поддерживающее маркеры TOTP RFC 6238. Популярные бесплатные приложения: \n Authy\n Google Authenticator\n LastPass Authenticator\n FreeOTP Authenticator + Не переправляйте этот код через интернет!\nИспользуйте его только для настройки приложения Authenticator на отслеживающих телефонах. + После сброса аутентификатора вы делаете все созданные идентификаторы недействительными. Вам нужно будет снова создать их! + При подключении + При отключении + Прогнозирование + Линия отклонения + Ошибка авторизации + Абсолютный инсулин + Главный пароль используется для шифрования резервных копий и для переопределения защиты в приложении. Запомните его или храните в безопасном месте. + Пароли не совпадают + Текущий главный пароль + Индикаторы состояния + Копировать параметры из NS + Копировать настройки NS (если есть)? diff --git a/app/src/main/res/values-ru-rRU/validator.xml b/app/src/main/res/values-ru-rRU/validator.xml index 3ea04e700d..38ad359082 100644 --- a/app/src/main/res/values-ru-rRU/validator.xml +++ b/app/src/main/res/values-ru-rRU/validator.xml @@ -1,2 +1,21 @@ - + + Можно вводить только цифры. + Разрешены только цифровые значения в диапазоне %1$s - %2$s. + Это поле не может содержать специальные символы + Разрешены только стандартные буквы + Поле не может быть пустым + Недопустимый адрес электронной почты + Недопустимый номер кредитной карты + Некорректный номер телефона + Недопустимое имя домена + Недопустимый IP + Недопустимый Url-адрес + Недопустимое имя или фамилия. + Недопустимое полное имя. + Недопустимый формат + Должен быть 4-значным числом + Должен быть 6-значным числом + Не минимальной длины + Пин-код должен состоять из 3-6 цифр, не одинаковых или идущих подряд + diff --git a/app/src/main/res/values-sk-rSK/objectives.xml b/app/src/main/res/values-sk-rSK/objectives.xml index 5da99833ad..b76ff17397 100644 --- a/app/src/main/res/values-sk-rSK/objectives.xml +++ b/app/src/main/res/values-sk-rSK/objectives.xml @@ -20,7 +20,9 @@ Jeden týždeň úspešného používania s bežným príjmom sacharidov Povolenie doplnkových funkcií pre každodenné použitie, ako napr. pokročilý asistent jedál (AMA) Povoliť ďalšie funkcie pre bežné používanie ako SMB + Povolenie automatiky Prečítať si dokumentáciu a zvýšiť maximálne IOB, aby mohlo správne fungovať SMB! Pre začiatok sa dá použiť veľkosť bežného bolusu + 3x maximálny denný bazál + Prečítajte si dokumentáciu na wiki, ako automatika funguje. Najskôr nastavte iba jednoduché pravidlá. Namiesto vykonávania akcií nechajte AAPS zobrazovať iba oznámenia. Pokiaľ ste si istý, že automatika je spustená v správnom čase, môžete oznámenie nahradiť vykonaním akcie.(https://androidaps.readdocs.io/en/latest/CROWDIN/cs/Usage/Automation.html) Glykémia dostupná v NS Stav pumpy dostupný v NS Spustené manuálne diff --git a/app/src/main/res/values-sk-rSK/protection.xml b/app/src/main/res/values-sk-rSK/protection.xml index 3ea04e700d..99bcd7815b 100644 --- a/app/src/main/res/values-sk-rSK/protection.xml +++ b/app/src/main/res/values-sk-rSK/protection.xml @@ -1,2 +1,23 @@ - + + Vyžaduje sa autentifikácia + Priložte prst na čítačku odtlačkov prstov pre overenie vašej totožnosti + Ochrana nastavení + Ochrana aplikácie + Ochrana bolusu + Hlavné heslo + Heslo pre nastavenia + Heslo aplikácie + Heslo pre bolus + Odomknúť nastavenia + Biometria + Vlastné heslo + Bez ochrany + Ochrana + Hlavné heslo nie je nastavené!\n\nProsím nastavte svoje hlavné heslo v nastaveniach (%1$s → %2$s) + Heslo nastavené! + Heslo nie je nastavené + Heslo nezmenené + Heslo vymazané! + Zadajte heslo + diff --git a/app/src/main/res/values-sk-rSK/strings.xml b/app/src/main/res/values-sk-rSK/strings.xml index 62336b935b..572d405cf4 100644 --- a/app/src/main/res/values-sk-rSK/strings.xml +++ b/app/src/main/res/values-sk-rSK/strings.xml @@ -43,6 +43,7 @@ Ovládač pumpy pre užívateľov používajúcich k liečbe diabetu inzulínové perá Ovládač pumpy pre užívateľov bez podporovanej pumpy (Otvorený okruh) Citlivosť je počítaná tým istým spôsobom ako v Oref0, ale je možné špecifikovať časové okno do minulosti. Minimálne vstrebávanie sacharidov je počítané dynamicky z maximálnej doby vstrebávania, definovanej v nastaveniach. + Citlivosť je počítaná za posledných 8h, alebo 24h (použiť to, ktoré je citlivejšie) a sacharidy (pokiaľ nie sú vstrebané), sú orezané po čase definovanom v nastaveniach. Modul tiež počíta s UAM (neoznámené jedlo). Citlivosť je počítaná ako vážený priemer z odchýlok. Novšie majú vyššiu prioritu. Minimálna vstrebateľnosť sacharidov je počítaná dynamicky z maximálnej doby vstrebateľnosti definovanej v nastaveniach. Tento algoritmus je najrýchlejší v sledovaní zmien citlivosti. Získavať glykémie z upravenej Eversense aplikácie. Získavať hodnoty glykémií z aplikácie Glimp. @@ -105,7 +106,6 @@ Rozdiel: Konfigurácia Ciele - OpenAPS MA Prehľad NS Profil Jednoduchý profil @@ -218,6 +218,44 @@ Maximálny bazálny IOB, ktorý OpenAPS môže podať [JI] Táto hodnota je nazývaná v kontexte OpenAPS ako max IOB, je to maximálne množstvo inzulínu v [JI], ktoré APS môže naraz podať. POTVRDIŤ + Budete vyzvaný na zadanie hlavného hesla, ktoré bude použité na dešifrovanie exportovaných nastavení. + Budete vyzvaný na zadanie hlavného hesla, ktoré bude použité na dešifrovanie importovaných nastavení. + Export zrušený! Nastavenia neboli exportované! + Import zrušený! Nastavenia neboli importované! + Prosím skontrolujte nastavenia predtým, ako importujete: + Nastavenia nemôžu byť importované! + Nastavenia by nemali byť importované! + Vysvetli chyby pri importe... + Podrobnosti chýb pri importe + Importovať + Importovať rovnako (NEBEZPEČNÉ!) + Nastavenia boli vytvorené inou verziou AAPS (%1$s) pretože máte: %2$s.\n\nNiektoré nastavenia môžu chýbať, alebo byť poškodené - po importovaní prosím skontrolujte a upravte nastavenia. + Nastavenia boli vytvorené na inom zariadení. Je to v poriadku, keď importujete zo staršieho/iného telefónu, ale skontrolujte, že importované nastavenia sú správne! + Používate zastaralý formát zo staršej verzie AAPS, čo nie je bezpečné! Používajte len ako poslednú možnosť, ak nemáte export v aktuálnom, JSON formáte. + Importované nastavenia sú už %1$s dní staré! Možno máte viacero novších nastavení, alebo ste zvolili nesprávny súbor? Nezabúdajte pravidelne exportovať nastavenia! + Nesprávny formát dátumu a času! + Formát súboru + Vytvorené + Verzia AAPS + Verzia zostavy + Meno pacienta použité pri exporte + Model zariadenia použitý pri exporte + Šifrovanie súborov + Zastaralý formát exportu + Nový šifrovaný formát + Nový formát pre ladenie (nešifrovaný) + Neznámy formát exportu + Súbor s nastaveniami poškodený + Súbor s nastaveniami je zabezpečený + Použitie nezabezpečeného, nešifrovaného formátu nastavení + Chyba formátu JSON, chýba povinné pole (formát, obsah, metadáta, alebo zabezpečenie) + Chyba dešifrovania, dané heslo nemôže dešifrovať súbor + Chýba kontrolný súčet súboru (hash), nedá sa overiť pravosť nastavení! + Súbor bol po exporte zmenený! + Chyba dešifrovania, analýza nastavení zlyhala! + Chyba dešifrovania, zadané heslo je neplatné, alebo bol súbor nastavení zmenený! Môže sa stať, že importovaný súbor bol exportovaný s iným hlavným heslom. + Chýba konfigurácia šifrovania, formát nastavení je neplatný! + Nepodporovaný alebo neurčený šifrovací algoritmus! DanaR Pripájanie Pripojené @@ -507,6 +545,9 @@ Dospelý Dospelý s nízkou citlivosťou Vyberte vek pacienta pre nastavenie bezpečnostných limitov + Meno pacienta + Zadajte meno pacienta, alebo prezývku pre rozlíšenie medzi viacerými nastaveniami + Používateľ Glimp %1$s potrebuje vypnúť optimalizáciu batérie pre optimálny výkon Uzavretý okruh pozastavený @@ -543,8 +584,14 @@ Povoliť superbolus Povolenie superbolusu v kalkulátore. Nepovoľujte, pokiaľ se nenaučíte, čo to v skutočnosti robí. MÔŽE SPÔSOBIŤ PREDÁVKOVANIE INZULÍNOM PRI NESPRÁVNOM POUŽITÍ! Zobraziť indikátory stavu na domovskej obrazovke - Zobraziť rozšírené indikátory stavu na domovskej obrazovke - Povoliť rozšírené indikátory stavu pre CAGE, IAGE, SAGE, Reservoir a Battery Level na domovskej obrazovke. + Prah upozornenia na vek kanyly [h] + Prah kritického veku kanyly [h] + Prah upozornenia na vek inzulínu [h] + Prah kritického veku inzulínu [h] + Prah upozornenia na vek senzora [h] + Prah kritického veku senzora [h] + Prah upozornenia na úroveň batérie [h] + Prah kritickej úrovne batérie [h] Prah upozornenia na úroveň hladiny zásobníka [JI] Prah kritickej úrovne hladiny zásobníka [JI] Prah upozornenia na úroveň batérie [%] @@ -704,8 +751,13 @@ Nastavenie nahrávania glykémie Zobrazovať detailné zmeny Zobrazovať rozdiel s jedným desatinným miestom naviac + Ako často budú SMB podávané (v minutách) SMB max. minút Maximálny počet minút bazálu, ku ktorým se limituje SMB + UAM SMB max. minút + Maximální počet minút bazálu, ku ktorým sa limituje SMB pre UAM + Prahová hodnota doporučenia sacharidov + Po navrhnutí sacharidov, aké množstvo sacharidov vyvolá upozornenie Nepodporovaný firmware v pumpe Odosielať glykémie do xDrip+ V xDrip+ vyberte zdroj dát 640g/Eversense @@ -772,6 +824,7 @@ pred %1$.2f h %1$d min + %1$dm Vždy povoliť SMB Povoliť SMB nezávisle na bolusoch. Možno iba zo zdrojom glykémií s dobrým filtrovaním dát, ako napr. G5 Povoliť SMB po jedle @@ -970,6 +1023,10 @@ = 5.5]]> Nízky dočasný cieľ zníži citlivosť + Rezistancia znižuje cieľ + Ak je zistená rezistancia, znížiť cieľovú hladinu glykémie + Citlivosť zvyšuje cieľ + Ak je zistená vyššia citlivosť, zvýši cieľovú hladinu glykémie Chybné nastavenie pumpy. Prejdite si dokumentáciu a presvedčte sa, že menu Quick Info se nazýva QUICK INFO, s použitím 360° Configuration Software. Voliteľný Veľký rozdiel v čase @@ -979,6 +1036,8 @@ POZOR: Pokiaľ aktivujete a pripojíte skutočnú pumpu, AndroidAPS nakopíruje (a bude udržiavať) nastavenie bazálu z aktívneho profilu do pumpy. Nastavenie bazálu v pumpe bude prepísané. Pokiaľ si nieste istí, alebo nechcete prepísať bazály v pumpe, stlačte Zrušiť a opakujte prepnutie na inú pumpu neskôr. Dáta ošetrení neúplné Nastavenie údržby + E-Mail + Šifrovať exportované nastavenia Počet protokolov na odoslanie Údržba Údržba @@ -1186,6 +1245,8 @@ existuje neexistuje Dočasný cieľ %1$s + Pripojenie Bluetooth k zariadeniu %1$s %2$s + Pripojenie k zariadeniu Bluetooth WiFi SSID %1$s %2$s Autosens %1$s %2$s %% Autosens % @@ -1240,6 +1301,7 @@ Alkalické (rozšírené zobrazenie) Líthiové (rozšírené zobrazenie) NiZn (Rozšírené) + NiMH (Rozšírené zobrazenie) Bolus/Ošetrenia ladenie VYHĽADAŤ @@ -1255,6 +1317,7 @@ Vyhľadávanie Vyhľadávanie dokončené Chyba vyhľadávania: %1$d + Nikdy Nastavenia História @@ -1388,6 +1451,7 @@ Vymazanie začaté Detekcia času Chcete resetovať začiatok cieľa? Môžete prísť o svoj pokrok. + Zmena času a/alebo časovej zóny na pumpe Nie je vybraná žiadna pumpa Vyberte jednotky, v ktorých chcete zobraziť hodnoty Odoslať zmeny lokálneho profilu do NS @@ -1444,4 +1508,34 @@ Čas spustenia dočasného bazálu Výstrahy pumpy Insight + z aplikácie Authenticator pre: %1$s + Povoliť Autentifikátor + Autentifikačné príkazy používajú jednorázové heslá generované Google Authenticator, alebo podobnými 2FA aplikáciami. + Ďalší PIN na konci tokenu + Ďalšie číslice, ktoré by mali byť zapamätané a pridané na koniec každého vygenerovaného jednorázového hesla + Nastavenie autentifikátora + OTP pre kontrolu: + Resetovať autentifikátory + Resetovať autentifikačný kľúč + Ste si istý, že chcete obnoviť autentifikačný kľúč? Vyresetujete tým všetky aktuálne nakonfigurované autentikátory a budete ich musieť znovu nastaviť. + Bol vygenerovaný nový autentifikačný kľúč! Prosím, použite aktualizovaný QR kód pre nastavenie autentifikátorov. + 1. Nainštalujte Autentifikátor + 2. Naskenujte kód pre nastavenie AndroidAPS OTP kódov + 3. Odtestujte jednorázové heslo + Resetovať autentifikátory + Na každom sledovacom telefóne nainštalujte Autentifikátor, ktorý podporuje tokeny TOTP RFC 6238. Najobľúbenejšie bezplatné aplikácie sú:\n • Authy\n • Google Authenticator\n • LastPass Authenticator\n • FreeOTP Authenticator + NEZDIEĽAJTE tento kód on-line!\nPoužiť iba na nastavenie Autentifikátora na sledujúcich telefónoch. + Resetovaním autentifikátora budú všetky už poskytnuté autentifikátory neplatné. Budete ich musieť znovu nastaviť! + Pri pripojení + Pri odpojení + Predikcie + Odchýlka sklonu + Autorizácia zlyhala + Celkový inzulín + Hlavné heslo sa používa na šifrovanie zálohy a na \"prebitie\" zabezpečenia v aplikácii. Dobre si ho zapamätajte, alebo uložte na bezpečnom mieste. + Heslá sa nezhodujú + Aktuálne hlavné heslo + Indikátory stavu + Kopírovať nastavenia z NS + Skopírovať nastavenia NS (ak existujú)? diff --git a/app/src/main/res/values-sk-rSK/validator.xml b/app/src/main/res/values-sk-rSK/validator.xml index 3ea04e700d..4962884868 100644 --- a/app/src/main/res/values-sk-rSK/validator.xml +++ b/app/src/main/res/values-sk-rSK/validator.xml @@ -1,2 +1,21 @@ - + + Povolené sú iba číslice. + Povolené iba čísla v rozsahu %1$s - %2$s. + Toto pole nemôže obsahovať žiadne špeciálne znaky + Sú povolené iba štandardné písmená + Toto pole nesmie byť prázdne + E-mailová adresa je neplatná + Číslo kreditnej karty je neplatné + Neplatné telefónne čislo + Názov domény je neplatný + IP Adresa je neplatná + Webová adresa je neplatná + Neplatné krstné meno, alebo priezvisko. + Nie je platné celé meno. + Formát nie je platný + Musí byť 4-miestne číslo + Musí byť 6-miestne číslo + Nie je splnená minimálna dĺžka + PIN by mal byť z 3 až 6 číslic, nie rovnakých, alebo za sebou nasledujúcich číslic + diff --git a/app/src/main/res/values-sv-rSE/objectives.xml b/app/src/main/res/values-sv-rSE/objectives.xml index 94b2ba5549..6f53a9be76 100644 --- a/app/src/main/res/values-sv-rSE/objectives.xml +++ b/app/src/main/res/values-sv-rSE/objectives.xml @@ -20,7 +20,9 @@ 1 veckas lyckad looping dagtid, där alla måltider lagts in Aktiverar extra funktioner som kan användas dagtid, såsom avancerad måltidsassistans, AMA Aktiverar ytterligare funktioner för användning dagtid, t ex SMB + Aktivera automatisering Du måste läsa på wikin och öka max IOB för att få SMB att fungera bra. En bra start är att sätta max IOB till din genomsnittliga måltidsbolus plus 3 gånger den högsta basalen du har under ett dygn + Läs dokumentationen hur automatisering fungerar. Konfigurera dina första enkla regler. I stället för att ange en åtgärd, låt bara AAPS visa en avisering. När du är säker på att automatisering utlöses vid rätt tidpunkt ersätt aviseringen med verklig åtgärd. (https://androidaps.readthedocs.io/en/latest/EN/Usage/Automation.html) BG är tillängligt i Nightscout Pumpstatus tillgängligt i Nightscout Manuella justeringar diff --git a/app/src/main/res/values-sv-rSE/protection.xml b/app/src/main/res/values-sv-rSE/protection.xml index 3ea04e700d..2586a94122 100644 --- a/app/src/main/res/values-sv-rSE/protection.xml +++ b/app/src/main/res/values-sv-rSE/protection.xml @@ -1,2 +1,23 @@ - + + Autentisering krävs + Placera fingret på fingeravtrycksläsaren för att verifiera din identitet + Skydd för inställningar + Skydd för app + Bolusskydd + Huvudlösenord + Lösenord för inställningar + Lösenord för app + Lösenord för bolus + Lås upp inställningar + Biometri + Eget lösenord + Inget skydd + Skydd + Huvudlösenord har inte angetts.\n\nAnge huvudlösenord i Inställningar (%1$s → %2$s) + Lösenord sparat! + Lösenord inte inställt + Lösenordet har inte ändrats + Lösenordet togs bort! + Ange lösenord här + diff --git a/app/src/main/res/values-sv-rSE/strings.xml b/app/src/main/res/values-sv-rSE/strings.xml index bd32a29734..7c4cc40f29 100644 --- a/app/src/main/res/values-sv-rSE/strings.xml +++ b/app/src/main/res/values-sv-rSE/strings.xml @@ -43,6 +43,7 @@ Integration för de som endast använder insulinpennor Integration för pumpar som ännu inte stöds av AndroidAPS (Open loop) Känsligheten beräknas på samma sätt som i Oref0, men du kan specificera hur mycket av historiken som ska tas med i beräkningen. Minimalt upptag av kolhydrater beräknas utifrån maximal upptagstid för kolhydrater som angetts i Inställningar. + Känsligheten beräknas både från 8 och 24 timmars data från historiken och väljer det resultat som har högst insulinkänslighet. Kolhydrater som ännu inte räknats av ignoreras efter tiden som ställts in i inställningarna. Insticksprogrammet beräknar också icke inmatade måltider, UAM. Känsligheten beräknas som ett viktat medelvärde av avvikelserna. Senare avvikelser får en högre vikt. Minimal upptagning av kolhydrater beräknas utifrån maximal upptagstid för kolhydrater som angetts i inställningarna. Den här algoritmen är den snabbaste att justera förändringar i känsligheten. Ta emot BG-data från den modifierade Eversense-appen. @@ -106,7 +107,6 @@ Eversense-appen. Delta: Konfigurationsverktyg Mål - OpenAPS MA Översikt NS-profil Enkel profil @@ -219,6 +219,44 @@ Eversense-appen. Maximal basal IOB som OpenAPS kan ge [E] Detta värde kallas Max IOB i OpenAPS. Det är ställt till noll från start. Efter flera dagar till veckor, beroende på hur du känner, kan du välja att justera denna. TA BORT + Du kommer att bli tillfrågad om huvudlösenordet som sedan kommer att användas för att kryptera exporterade inställningar. + Du kommer att bli tillfrågad om huvudlösenordet som sedan kommer att användas för att avkryptera importerade inställningar. + Exporten avbröts. Inställningarna har INTE exporterats! + Importen avbröts. Inställningarna har inte importerats! + Vänligen kontrollera inställningarna innan du importerar: + Inställningarna kan inte importeras! + Inställningar bör inte importeras! + Förklara importproblem… + Detaljer kring importproblem + Importera + Importera ändå (FARLIGT!) + Inställningar skapades med en annan variant av AAPS (%1$s). Du kör nu: %2$s.\n\nVissa inställningar kan saknas eller är ogiltiga. Efter att du importerat bör du kontrollera och uppdatera inställningarna. + Inställningar skapades på en annan enhet. Det är OK om du importerar från en äldre eller en annan telefon, men se till att importerade inställningar är korrekta! + Du använder det gamla formatet (från äldre versioner av AAPS) som inte är säkert. Använd det bara som en sista utväg om du inte har någon export i aktuellt format, JSON. + Importerade inställningar är %1$s dagar gamla. Du kanske har mer aktuella inställningar eller väljer du fel fil? Kom ihåg att exportera dina inställningar regelbundet! + Ogiltigt datumformat! + Filformat + Skapad + AAPS-version + Build-variant + Exporterar patientens namn + Exporterar enhetsmodell + · Filkryptering + Gammalt exportformat + Nytt krypterat format + Nytt debug-format (okrypterat) + Okänt exportformat + Inställningsfil manipulerad + Inställningsfilen är intakt + Använder icke säkrat, okrypterat format + JSON-formatfel, saknar obligatoriskt fält (format, innehåll, metadata eller säkerhet) + Dekrypteringsfel. Det angivna lösenordet kan inte dekryptera filen + Filen checksumma (hash) saknas. Det går inte att verifiera inställningarna! + Filen har ändrats efter export! + Dekrypteringsfel. Det gick inte att tolka inställningarna. + Dekrypteringsfel. Det angivna lösenordet är ogiltigt eller så har inställningsfilen ändrats. Filen verkar ha exporterats med ett annat lösenord. + Krypteringskonfigurationen saknas. Inställningsformatet är ogiltigt! + Ej stödd eller ej angiven krypteringsalgoritm! Dana R Ansluter Ansluten @@ -508,6 +546,9 @@ Eversense-appen. Vuxen Insulinresistent vuxen Vg ange personens ålder för inställningar av gränser + Patientens namn + Vänligen ange patientens namn eller smeknamn för att kunna skilja mellan flera uppsättningar av inställningar + Ditt namn Glimp %1$s behöver kunna kringgå batterisparfunktionerna för att fungera korrekt Loop pausad @@ -544,8 +585,6 @@ Eversense-appen. Aktivera superbolus i kalkylatorn Aktiverar superbolusfunktionen i kalkylatorn. Aktivera inte innan du förstått hur den fungerar. DEN KAN ORSAKA ÖVERDOSERING AV INSULIN OM INSIKT SAKNAS OM FUNKTIONEN! Visa \"statuslampor\" på hemskärmen - Visa utökade statusindikatorer - Aktivera statusindikatorerna för cage, iage, sage, reservoar och batterinivå på hemskärmen. Varningsnivå för reservoar [U] Akut varningsnivå för reservoar [U] Varningsnivå för batteri [%] @@ -705,8 +744,13 @@ Eversense-appen. Uppladdningsinställningar för BG Visa detaljerad delta Visa delta med en extra decimal + Minsta antal minuter mellan SMB SMB max minuter Max antal minuter som kan bli SMB + UAM SMB max minuter + Max antal minuter basal som kan bli SMB vid UAM + Min föreslagen mängd kolhydrater + När kolhydrater rekommenderas som korrektion, ange minsta mängd KH som ger notifiering Pumpens firmware stöds inte Skicka BG-data till xDrip+ Välj \"640G/Eversense\" som datakälla i xDrip+ @@ -773,6 +817,7 @@ Eversense-appen. sedan %1$.2f h %1$d min + %1$dm Använd alltid SMB Använd alltid SMB oberoende av bolus. Endast möjligt med en bra filtrerad BG-källa, t ex Dexcom G5. Använd SMB efter kolhydrater @@ -971,6 +1016,10 @@ Eversense-appen. Lågt målvärde sänker känsligheten + Insulinresistens sänker mål-BG + Om systemet upptäcker tillfällig insulinresistens, sänk mål-BG för att på så sätt tillåta mer insulin + Insulinkänslighet höjer mål-BG + Om systemet upptäcker tillfällig insulinkänslighet, höj mål-BG för att på så sätt minska insulindoseringen Felaktig pumpinstallation. Kontrollera dokumentationen och verifiera att Snabbmenyn heter QUICK INFO med hjälp av 360-mjukvaran. Anpassad Stor tidsskillnad @@ -980,6 +1029,8 @@ Eversense-appen. Varning: Om du aktiverar och ansluter en pump, kommer AndroidAPS skriva över pumpens basalprofil med den aktiva profilen i AndroidAPS. Se till att ha rätt inställningar i appen innan du ansluter. Om du är osäker, tryck på Avbryt och anslut pumpen på nytt vid ett senare tillfälle. Behandlingsdata ofullständigt Underhållsinställningar + e-postmottagare + Kryptera exporterade inställningar Antal loggar att skicka Underhåll UH @@ -1187,6 +1238,8 @@ Eversense-appen. finns finns inte Temp mål %1$s + Bluetooth-anslutning till enhet %1$s %2$s + Anslutning till Bluetooth-enhet WiFi SSID %1$s %2$s Autosens %1$s %2$s %% Autosens % @@ -1241,6 +1294,7 @@ Eversense-appen. Alkaliskt Litium NiZn (utökad vy) + NiMH (utökad vy) Avlusning av Bolus/Behandlingar SÖK @@ -1445,4 +1499,31 @@ Eversense-appen. Basalförändring utförd Pumpvarningar Insight + från autentiseringsapp för: %1$s + Aktivera autentiseraren + Autentisera kommandon med hjälp av engångslösenord som genererats av Google Authenticator eller liknande appar för tvåfaktorsautentisering. + Extra PIN-kod + Ytterligare siffror som ska memoreras och läggas till i slutet av varje genererat engångslösenord + Konfiguration av tvåfaktorsautentisering + Engångslösenord att kontrollera: + Återställ autentiserare + Återställ autentiseringsnyckel + Är du säker på att återställa autentiseringsnyckeln? Det gör alla konfigurerade autentiseringsappar ogiltiga och du kommer behöva ställa in dem igen. + Ny autentiseringsnyckel genererades! Använd uppdaterad QR-kod till att aktivera autentiserare. + 1. Installera autentiseringsapp + 2. Scanna koden för att ställa in engångslösenord för AndroidAPS + 3. Testa engångslösenord + Återställ autentiserare + På varje följartelefon behöver man installera en autentiseringsapp som stöder RFC 6238 TOTP tokens. Populära gratisappar är:\n • Authy\n • Google Authenticator\n • LastPass Authenticator\n • FreeOTP Authenticator + DELA INTE denna kod online!\nAnvänd den endast för att installera autentiseringsappen på följartelefoner. + Genom att återställa autentiseringsfunktionen kommer alla redan driftsatta autentiserare bli ogiltiga. Du kommer behöva sätta upp dem igen! + Vid anslutning + Vid frånkoppling + Beräknade resultat + Avvikelsekurva + Behörighetskontroll misslyckades + Absolut insulinmängd + Huvudlösenordet används för att kryptera backuper och för att åsidosätta vissa säkerhetsfunktioner i applikationen. Kom ihåg det eller förvara det på ett säkert ställe. + Lösenorden stämmer inte överens + Nuvarande huvudlösenord diff --git a/app/src/main/res/values-sv-rSE/validator.xml b/app/src/main/res/values-sv-rSE/validator.xml index 3ea04e700d..3b2288d895 100644 --- a/app/src/main/res/values-sv-rSE/validator.xml +++ b/app/src/main/res/values-sv-rSE/validator.xml @@ -1,2 +1,21 @@ - + + Endast siffror tillåtna. + Endast siffror mellan %1$s - %2$s är tillåtna. + Det här fältet får inte innehålla något specialtecken + Endast vanliga bokstäver är tillåtna + Detta fält får inte vara tomt + Ogiltig e-postadress + Ogiltigt kreditkortsnummer + Ogiltigt telefonnummer + Ogiltigt domännamn + Ogiltig IP-adress + Ogiltig URL + Ogiltigt för- eller efternamn. + Ogiltigt namn + Ogiltigt format + Måste vara fyra siffror + Måste vara sex siffror + För kort + Pin ska vara 3-6 siffror, inte samma eller efter varandra + diff --git a/app/src/main/res/values-tr-rTR/strings.xml b/app/src/main/res/values-tr-rTR/strings.xml index e596cbc9b0..733b287549 100644 --- a/app/src/main/res/values-tr-rTR/strings.xml +++ b/app/src/main/res/values-tr-rTR/strings.xml @@ -100,7 +100,6 @@ Delta: Konfigurasyon oluştur Hedefler - OpenAPS MA Genel Bakış Nightscout Profil Basit Profil diff --git a/app/src/main/res/values-zh-rCN/strings.xml b/app/src/main/res/values-zh-rCN/strings.xml index 9afcdb66e9..0ae0966cf2 100644 --- a/app/src/main/res/values-zh-rCN/strings.xml +++ b/app/src/main/res/values-zh-rCN/strings.xml @@ -102,7 +102,6 @@ 增量: 配置生成器 目标 - OpenAPS MA 首页概览 NS 配置文件 简单配置文件 diff --git a/app/src/main/res/xml/pref_medtronic.xml b/app/src/main/res/xml/pref_medtronic.xml index 0d6349489b..fd9a84ab64 100644 --- a/app/src/main/res/xml/pref_medtronic.xml +++ b/app/src/main/res/xml/pref_medtronic.xml @@ -90,13 +90,13 @@ android:selectable="true" android:title="@string/medtronic_bolus_debugging" /> - - + diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicConverterUTest.java b/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicConverterUTest.java index 67c205fa37..1e10544e88 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicConverterUTest.java +++ b/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicConverterUTest.java @@ -2,6 +2,7 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm; import java.util.Map; +import org.junit.Ignore; import org.junit.Test; import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; @@ -13,8 +14,9 @@ import info.nightscout.androidaps.plugins.pump.medtronic.util.MedtronicUtil; /** * Created by andy on 1/30/19. */ +@Ignore public class MedtronicConverterUTest { - +/* MedtronicConverter converter = new MedtronicConverter(); @@ -35,5 +37,5 @@ public class MedtronicConverterUTest { // byte[] data = new byte[] { 00 03 00 05 01 00 C8 00 A0 01 01 00 01 00 00 64 01 05 00 14 00 64 01 00 00 }; } - +*/ } diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicHistoryDataUTest.java b/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicHistoryDataUTest.java index cd395842bd..4db64d90b1 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicHistoryDataUTest.java +++ b/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/MedtronicHistoryDataUTest.java @@ -21,7 +21,7 @@ import static org.mockito.Mockito.when; * Created by andy on 3/10/19. */ public class MedtronicHistoryDataUTest { - +/* //TestLogger LOGGER = TestLoggerFactory.getTestLogger(MedtronicHistoryDataUTest.class); byte[] historyPageData = ByteUtil @@ -123,5 +123,5 @@ public class MedtronicHistoryDataUTest { } } - +*/ } diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/MedtronicPumpHistoryDecoderUTest.java b/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/MedtronicPumpHistoryDecoderUTest.java index 3233d4e1e4..0420dba922 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/MedtronicPumpHistoryDecoderUTest.java +++ b/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/MedtronicPumpHistoryDecoderUTest.java @@ -11,7 +11,7 @@ import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil; */ @Ignore public class MedtronicPumpHistoryDecoderUTest { - +/* MedtronicPumpHistoryDecoder decoder = new MedtronicPumpHistoryDecoder(); @@ -152,5 +152,5 @@ public class MedtronicPumpHistoryDecoderUTest { System.out.println("Record: " + phe); } - +*/ } diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfileUTest.java b/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfileUTest.java index 6511117e9b..21b98660d6 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfileUTest.java +++ b/app/src/test/java/info/nightscout/androidaps/plugins/pump/medtronic/data/dto/BasalProfileUTest.java @@ -23,15 +23,10 @@ import static org.mockito.Mockito.when; //@PrepareForTest({ MainApp.class, DatabaseHelper.class, DateUtil.class, SP.class }) @Ignore public class BasalProfileUTest { - +/* // MainApp mainApp = new MainApp(); @Before public void initMocking() { -// AAPSMocker.mockMainApp(); -// AAPSMocker.mockStrings(); -// AAPSMocker.mockDatabaseHelper(); - -// SPMocker.prepareMock(); PowerMockito.mockStatic(DateUtil.class); when(DateUtil.now()).thenReturn(1514766900000L + T.mins(1).msecs()); @@ -161,5 +156,5 @@ public class BasalProfileUTest { // 1.800 1.600 1.400 1.450 1.450 1.450 1.250 1.250 0.950 0.950 1.150 1.150 1.250 0.950 0.950 0.950 0.650 0.650 // 0.650 0.650 0.650 0.500 0.500 0.500 } - +*/ }