From f5c2d1a1ffe78e2176b91d81fb4048470a0ad5ac Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 7 Dec 2022 08:02:20 +0000 Subject: [PATCH 01/48] chore(deps): bump junit-jupiter-engine from 5.7.0 to 5.9.1 Bumps [junit-jupiter-engine](https://github.com/junit-team/junit5) from 5.7.0 to 5.9.1. - [Release notes](https://github.com/junit-team/junit5/releases) - [Commits](https://github.com/junit-team/junit5/compare/r5.7.0...r5.9.1) --- updated-dependencies: - dependency-name: org.junit.jupiter:junit-jupiter-engine dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] --- build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.gradle b/build.gradle index 258c9ee7d1..c57b449a5e 100644 --- a/build.gradle +++ b/build.gradle @@ -32,7 +32,7 @@ buildscript { swipe_version = '1.1.0' junit_version = '4.13.2' - junit_jupiter_version = '5.7.0' + junit_jupiter_version = '5.9.1' mockito_version = '4.6.1' dexmaker_version = '1.2' retrofit2_version = '2.9.0' From cd7832a6e168725ecfdbac8e398deca3055031fe Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Wed, 7 Dec 2022 09:52:52 +0100 Subject: [PATCH 02/48] Fix password reset feature --- app/src/main/java/info/nightscout/androidaps/MainActivity.kt | 5 +---- .../nightscout/androidaps/danar/AbstractDanaRPlugin.java | 1 + .../main/java/info/nightscout/pump/danars/DanaRSPlugin.kt | 1 + 3 files changed, 3 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/MainActivity.kt b/app/src/main/java/info/nightscout/androidaps/MainActivity.kt index de431719af..1eca9dadd1 100644 --- a/app/src/main/java/info/nightscout/androidaps/MainActivity.kt +++ b/app/src/main/java/info/nightscout/androidaps/MainActivity.kt @@ -151,10 +151,6 @@ class MainActivity : DaggerAppCompatActivityWithResult() { .toObservable(EventPreferenceChange::class.java) .observeOn(aapsSchedulers.main) .subscribe({ processPreferenceChange(it) }, fabricPrivacy::logException) - disposable += rxBus - .toObservable(EventInitializationChanged::class.java) - .observeOn(aapsSchedulers.main) - .subscribe({ passwordResetCheck(this) }, fabricPrivacy::logException) if (startWizard() && !isRunningRealPumpTest()) { protectionCheck.queryProtection(this, ProtectionCheck.Protection.PREFERENCES, { startActivity(Intent(this, SetupWizardActivity::class.java)) @@ -168,6 +164,7 @@ class MainActivity : DaggerAppCompatActivityWithResult() { androidPermission.notifyForSystemWindowPermissions(this) androidPermission.notifyForBtConnectPermission(this) } + passwordResetCheck(this) } private fun checkPluginPreferences(viewPager: ViewPager2) { diff --git a/pump/danar/src/main/java/info/nightscout/androidaps/danar/AbstractDanaRPlugin.java b/pump/danar/src/main/java/info/nightscout/androidaps/danar/AbstractDanaRPlugin.java index e2245e4d41..4501712c26 100644 --- a/pump/danar/src/main/java/info/nightscout/androidaps/danar/AbstractDanaRPlugin.java +++ b/pump/danar/src/main/java/info/nightscout/androidaps/danar/AbstractDanaRPlugin.java @@ -120,6 +120,7 @@ public abstract class AbstractDanaRPlugin extends PumpPluginBase implements Pump } }) ); + danaPump.setSerialNumber(sp.getString(info.nightscout.pump.dana.R.string.key_danar_bt_name, "")); // fill at start to allow password reset } @Override protected void onStop() { diff --git a/pump/danars/src/main/java/info/nightscout/pump/danars/DanaRSPlugin.kt b/pump/danars/src/main/java/info/nightscout/pump/danars/DanaRSPlugin.kt index 0be916a6fb..b1c6c51bea 100644 --- a/pump/danars/src/main/java/info/nightscout/pump/danars/DanaRSPlugin.kt +++ b/pump/danars/src/main/java/info/nightscout/pump/danars/DanaRSPlugin.kt @@ -154,6 +154,7 @@ class DanaRSPlugin @Inject constructor( fun changePump() { mDeviceAddress = sp.getString(info.nightscout.pump.dana.R.string.key_danars_address, "") mDeviceName = sp.getString(info.nightscout.pump.dana.R.string.key_danars_name, "") + danaPump.serialNumber = sp.getString(info.nightscout.pump.dana.R.string.key_danars_name, "") danaPump.reset() commandQueue.readStatus(rh.gs(info.nightscout.core.ui.R.string.device_changed), null) } From 5d3a3f861a3d5ba41d5166b3841cf1a616147b8d Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Wed, 7 Dec 2022 10:43:52 +0100 Subject: [PATCH 03/48] improve BgQualityCheckPlugin, fix test --- .../androidaps/interfaces/ConstraintsCheckerTest.kt | 5 +++++ .../constraints/bgQualityCheck/BgQualityCheckPlugin.kt | 9 +++++++-- .../androidaps/plugins/pump/danaR/DanaRPluginTest.kt | 1 + .../plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt | 1 + .../plugins/pump/danaRv2/DanaRv2PluginTest.kt | 10 ++++++---- .../info/nightscout/pump/danars/DanaRSPluginTest.kt | 1 + 6 files changed, 21 insertions(+), 6 deletions(-) diff --git a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt index 9547d3bb5a..041b19ed2c 100644 --- a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt @@ -42,12 +42,14 @@ import info.nightscout.plugins.source.GlimpPlugin import info.nightscout.pump.combo.ComboPlugin import info.nightscout.pump.combo.ruffyscripter.RuffyScripter import info.nightscout.pump.dana.DanaPump +import info.nightscout.pump.dana.R import info.nightscout.pump.dana.database.DanaHistoryDatabase import info.nightscout.shared.sharedPreferences.SP import org.junit.Assert import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock +import org.mockito.Mockito import org.mockito.Mockito.`when` /** @@ -131,7 +133,10 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { `when`(rh.gs(info.nightscout.plugins.R.string.objectivenotstarted)).thenReturn("Objective %1\$d not started") // RS constructor + `when`(sp.getString(R.string.key_danars_name, "")).thenReturn("") `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danars_address, "")).thenReturn("") + // R + `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danar_bt_name, "")).thenReturn("") //SafetyPlugin `when`(activePlugin.activePump).thenReturn(virtualPumpPlugin) diff --git a/plugins/support/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt b/plugins/support/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt index 6a5c845cb1..769c318936 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt +++ b/plugins/support/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt @@ -26,6 +26,7 @@ import io.reactivex.rxjava3.kotlin.plusAssign import javax.inject.Inject import javax.inject.Singleton import kotlin.math.abs +import kotlin.math.max import kotlin.math.min @Singleton @@ -115,9 +116,13 @@ class BgQualityCheckPlugin @Inject constructor( if (data[data.size - 1].timestamp > now - 45 * 60 * 1000L) return null // data too fresh to detect if (data[0].timestamp < now - 7 * 60 * 1000L) return null // data is old + var bgmin: Double = lastBg + var bgmax: Double = bgmin for (bg in data) { if (bg.timestamp < offset) break - if (abs(lastBg - bg.value) > maxDelta) return false + bgmin = min(bgmin, bg.value) + bgmax = max(bgmax, bg.value) + if (bgmax - bgmin > maxDelta) return false } return true } @@ -142,6 +147,6 @@ class BgQualityCheckPlugin @Inject constructor( companion object { const val staleBgCheckPeriodMinutes = 45L - const val staleBgMaxDeltaMgdl = 1.0 + const val staleBgMaxDeltaMgdl = 2.0 } } \ No newline at end of file diff --git a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/DanaRPluginTest.kt b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/DanaRPluginTest.kt index 741146e966..88df0104e5 100644 --- a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/DanaRPluginTest.kt +++ b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/DanaRPluginTest.kt @@ -42,6 +42,7 @@ class DanaRPluginTest : TestBaseWithProfile() { @BeforeEach fun prepareMocks() { `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danars_address, "")).thenReturn("") + `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danar_bt_name, "")).thenReturn("") `when`(rh.gs(info.nightscout.core.ui.R.string.pumplimit)).thenReturn("pump limit") `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") diff --git a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt index 9cbf50c879..6079c62d6a 100644 --- a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt +++ b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt @@ -42,6 +42,7 @@ class DanaRKoreanPluginTest : TestBaseWithProfile() { @BeforeEach fun prepareMocks() { `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danars_address, "")).thenReturn("") + `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danar_bt_name, "")).thenReturn("") `when`(rh.gs(info.nightscout.core.ui.R.string.pumplimit)).thenReturn("pump limit") `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") diff --git a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRv2/DanaRv2PluginTest.kt b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRv2/DanaRv2PluginTest.kt index f660f5f3d2..06ed276026 100644 --- a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRv2/DanaRv2PluginTest.kt +++ b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRv2/DanaRv2PluginTest.kt @@ -44,15 +44,17 @@ class DanaRv2PluginTest : TestBaseWithProfile() { @BeforeEach fun prepareMocks() { - `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danars_address, "")) - .thenReturn("") + `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danar_bt_name, "")).thenReturn("") + `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danars_address, "")).thenReturn("") `when`(rh.gs(info.nightscout.core.ui.R.string.pumplimit)).thenReturn("pump limit") `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingpercentrate)).thenReturn("Limiting max percent rate to %1\$d%% because of %2\$s") danaPump = DanaPump(aapsLogger, sp, dateUtil, profileInstantiator) - danaRv2Plugin = DanaRv2Plugin(injector, aapsLogger, aapsSchedulers, rxBus, context, rh, constraintChecker, activePluginProvider, sp, commandQueue, danaPump, detailedBolusInfoStorage, - temporaryBasalStorage, dateUtil, fabricPrivacy, pumpSync, uiInteraction, danaHistoryDatabase) + danaRv2Plugin = DanaRv2Plugin( + injector, aapsLogger, aapsSchedulers, rxBus, context, rh, constraintChecker, activePluginProvider, sp, commandQueue, danaPump, detailedBolusInfoStorage, + temporaryBasalStorage, dateUtil, fabricPrivacy, pumpSync, uiInteraction, danaHistoryDatabase + ) } @Test diff --git a/pump/danars/src/test/java/info/nightscout/pump/danars/DanaRSPluginTest.kt b/pump/danars/src/test/java/info/nightscout/pump/danars/DanaRSPluginTest.kt index 0a5cf06126..912a7bccb6 100644 --- a/pump/danars/src/test/java/info/nightscout/pump/danars/DanaRSPluginTest.kt +++ b/pump/danars/src/test/java/info/nightscout/pump/danars/DanaRSPluginTest.kt @@ -57,6 +57,7 @@ class DanaRSPluginTest : DanaRSTestBase() { @BeforeEach fun prepareMocks() { + Mockito.`when`(sp.getString(info.nightscout.pump.dana.R.string.key_danars_name, "")).thenReturn("") Mockito.`when`(sp.getString(info.nightscout.pump.dana.R.string.key_danars_address, "")).thenReturn("") Mockito.`when`(rh.gs(eq(info.nightscout.core.ui.R.string.limitingbasalratio), anyObject(), anyObject())).thenReturn("limitingbasalratio") Mockito.`when`(rh.gs(eq(info.nightscout.core.ui.R.string.limitingpercentrate), anyObject(), anyObject())).thenReturn("limitingpercentrate") From 81a8080942a851896c52441c200933a51ba37f12 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Wed, 7 Dec 2022 12:26:49 +0100 Subject: [PATCH 04/48] EOPatch: lineup preferences --- pump/eopatch/src/main/res/xml/pref_eopatch.xml | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/pump/eopatch/src/main/res/xml/pref_eopatch.xml b/pump/eopatch/src/main/res/xml/pref_eopatch.xml index 22cf391ea4..c726b01111 100644 --- a/pump/eopatch/src/main/res/xml/pref_eopatch.xml +++ b/pump/eopatch/src/main/res/xml/pref_eopatch.xml @@ -1,7 +1,11 @@ - + + + - + + \ No newline at end of file From 14c39ee05eb8d400cf54c71fd756ec7d20896a35 Mon Sep 17 00:00:00 2001 From: Carlos Rafael Giani Date: Tue, 6 Dec 2022 21:56:42 +0100 Subject: [PATCH 05/48] Fix comboctl unit test integration Signed-off-by: Carlos Rafael Giani --- pump/combov2/comboctl/build.gradle | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/pump/combov2/comboctl/build.gradle b/pump/combov2/comboctl/build.gradle index ba5ea343da..645f764f7c 100644 --- a/pump/combov2/comboctl/build.gradle +++ b/pump/combov2/comboctl/build.gradle @@ -1,8 +1,14 @@ -apply plugin: 'com.android.library' -apply plugin: 'kotlin-android' +plugins { + id 'com.android.library' + id 'kotlin-android' + id 'kotlin-kapt' + id 'com.hiya.jacoco-android' +} apply from: "${project.rootDir}/core/main/android_dependencies.gradle" +apply from: "${project.rootDir}/core/main/android_module_dependencies.gradle" apply from: "${project.rootDir}/core/main/test_dependencies.gradle" +apply from: "${project.rootDir}/core/main/jacoco_global.gradle" android { namespace 'info.nightscout.comboctl' From ad381e3c261b97761548760e7623606ca533b4a6 Mon Sep 17 00:00:00 2001 From: Carlos Rafael Giani Date: Tue, 6 Dec 2022 23:14:54 +0100 Subject: [PATCH 06/48] comboctl: main: Improvements to Pump.setTbr() * Don't set a fake 100% TBR again if the current fake 100% TBR is finished within 15 minutes (reduces number of TBR operations and allows the Combo to return to a non-TBR state). * If the expected TBR percentage was a non-100% one, but not we see a non-TBR main screen, check if the expected TBR duration was <= 2 minutes. This covers the edge case when the TBR ends at the same time when we run this check. * Inform callers about the exact outcome of the setTbr() call. It could be that it set the TBR normally. Or, it might have set a fake 100% TBR (if the user requested a 100% TBR and force100Percent was set to false), and so on. Signed-off-by: Carlos Rafael Giani --- .../info/nightscout/comboctl/main/Pump.kt | 42 ++++++++++++++++++- 1 file changed, 41 insertions(+), 1 deletion(-) diff --git a/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt b/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt index 0507cfe41b..745e23276c 100644 --- a/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt +++ b/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt @@ -1166,6 +1166,19 @@ class Pump( */ val setTbrProgressFlow = setTbrProgressReporter.progressFlow + /** + * Detail about the outcome of a successful [setTbr] call. + * + * Note that all of these describe a success. In case of failure, + * [setTbr] throws an exception. + */ + enum class SetTbrOutcome { + SET_NORMAL_TBR, + SET_EMULATED_100_TBR, + LETTING_EMULATED_100_TBR_FINISH, + IGNORED_REDUNDANT_100_TBR + } + /** * Sets the Combo's current temporary basal rate (TBR) via the remote terminal (RT) mode. * @@ -1199,6 +1212,9 @@ class Pump( * via the [onEvent] callback. Likewise, when a TBR finishes or is cancelled, * [Event.TbrEnded] is emitted. * + * When this function finishes successfully, it informs about the exact + * outcome through its return value. + * * @param percentage TBR percentage to set. * @param durationInMinutes TBR duration in minutes to set. * This argument is not used if [percentage] is 100. @@ -1209,6 +1225,7 @@ class Pump( * cancelling an ongoing TBR, which produces a W6 warning) or to fake a * 100% TBR by setting 90% / 110% TBRs (see above). * This argument is only used if [percentage] is 100. + * @return The specific outcome if setting the TBR succeeds. * @throws IllegalArgumentException if the percentage is not in the 0-500 range, * or if the percentage value is not an integer multiple of 10, or if * the duration is <15 or not an integer multiple of 15 (see the note @@ -1244,6 +1261,7 @@ class Pump( val currentStatus = statusFlow.value ?: throw IllegalStateException("Cannot start TBR without a known pump status") var expectedTbrPercentage: Int var expectedTbrDuration: Int + val result: SetTbrOutcome // In the code below, we always create a Tbr object _before_ calling // setCurrentTbr to make use of the checks in the Tbr constructor. @@ -1258,6 +1276,20 @@ class Pump( reportOngoingTbrAsStopped() expectedTbrPercentage = 100 expectedTbrDuration = 0 + result = SetTbrOutcome.SET_NORMAL_TBR + } else if ((currentStatus.tbrPercentage in 90..110) && (currentStatus.remainingTbrDurationInMinutes <= 15)) { + // If the current TBR is in the 90-110% range, it is pretty much a fake 100% TBR. + // So, if that fake TBR is done within 15 minutes, we don't actually set anything. + // Instead, we just let it run. That way, the pump can actually reach 100% TBR, + // and the amount of TBR adjustments is reduced. + expectedTbrPercentage = currentStatus.tbrPercentage + expectedTbrDuration = currentStatus.remainingTbrDurationInMinutes + result = SetTbrOutcome.LETTING_EMULATED_100_TBR_FINISH + logger(LogLevel.INFO) { + "Current TBR percentage is in the 90-110% range (${currentStatus.tbrPercentage}%)," + + "and it will finish in ${currentStatus.remainingTbrDurationInMinutes} minute(s); " + + "letting it finish and faking a successful TBR set operation" + } } else { val newPercentage = if (currentStatus.tbrPercentage < 100) 110 else 90 val tbr = Tbr( @@ -1270,6 +1302,7 @@ class Pump( reportStartedTbr(tbr) expectedTbrPercentage = newPercentage expectedTbrDuration = 15 + result = SetTbrOutcome.SET_EMULATED_100_TBR } } else { // Current status shows that there is no TBR ongoing. This is @@ -1278,6 +1311,7 @@ class Pump( expectedTbrPercentage = 100 expectedTbrDuration = 0 logger(LogLevel.INFO) { "TBR was already cancelled" } + result = SetTbrOutcome.IGNORED_REDUNDANT_100_TBR } } else { val tbr = Tbr( @@ -1291,6 +1325,7 @@ class Pump( reportStartedTbr(tbr) expectedTbrPercentage = percentage expectedTbrDuration = durationInMinutes + result = SetTbrOutcome.SET_NORMAL_TBR } // We just set the TBR. Now check the main screen contents to see if @@ -1314,9 +1349,12 @@ class Pump( throw ExtendedOrMultiwaveBolusActiveException(mainScreenContent) is MainScreenContent.Normal -> { - if (expectedTbrPercentage != 100) { + if ((expectedTbrPercentage != 100) && (expectedTbrDuration >= 2)) { // We expected a TBR to be active, but there isn't any; // we aren't seen any TBR main screen contents. + // Only consider this an error if the duration is >2 minutes. + // Otherwise, this was a TBR that was about to end, so it + // might have ended while these checks here were running. throw UnexpectedTbrStateException( expectedTbrPercentage = expectedTbrPercentage, expectedTbrDuration = expectedTbrDuration, @@ -1349,6 +1387,8 @@ class Pump( } } } + + return@executeCommand result } /** From 9fdc89ee72cc1c9610e75e8dd1272757f14f5d08 Mon Sep 17 00:00:00 2001 From: Carlos Rafael Giani Date: Tue, 6 Dec 2022 23:23:52 +0100 Subject: [PATCH 07/48] combov2: Use more specific PumpEnactResult comment after setTbr() finishes Signed-off-by: Carlos Rafael Giani --- .../nightscout/pump/combov2/ComboV2Plugin.kt | 31 ++++++++++++++----- pump/combov2/src/main/res/values/strings.xml | 3 ++ 2 files changed, 27 insertions(+), 7 deletions(-) diff --git a/pump/combov2/src/main/kotlin/info/nightscout/pump/combov2/ComboV2Plugin.kt b/pump/combov2/src/main/kotlin/info/nightscout/pump/combov2/ComboV2Plugin.kt index b2e19253db..6a71eef58a 100644 --- a/pump/combov2/src/main/kotlin/info/nightscout/pump/combov2/ComboV2Plugin.kt +++ b/pump/combov2/src/main/kotlin/info/nightscout/pump/combov2/ComboV2Plugin.kt @@ -1091,17 +1091,34 @@ class ComboV2Plugin @Inject constructor ( return pumpEnactResult } - private fun setTbrInternal(percentage: Int, durationInMinutes: Int, tbrType: ComboCtlTbr.Type, force100Percent: Boolean, pumpEnactResult: PumpEnactResult) { + private fun setTbrInternal( + percentage: Int, + durationInMinutes: Int, + tbrType: ComboCtlTbr.Type, + force100Percent: Boolean, + pumpEnactResult: PumpEnactResult + ) { runBlocking { try { executeCommand { - pump!!.setTbr(percentage, durationInMinutes, tbrType, force100Percent) - } + val setTbrOutcome = pump!!.setTbr(percentage, durationInMinutes, tbrType, force100Percent) - pumpEnactResult.apply { - success = true - enacted = true - comment = rh.gs(R.string.combov2_setting_tbr_succeeded) + val tbrComment = when (setTbrOutcome) { + ComboCtlPump.SetTbrOutcome.SET_NORMAL_TBR -> + rh.gs(R.string.combov2_setting_tbr_succeeded) + ComboCtlPump.SetTbrOutcome.SET_EMULATED_100_TBR -> + rh.gs(R.string.combov2_set_emulated_100_tbr) + ComboCtlPump.SetTbrOutcome.LETTING_EMULATED_100_TBR_FINISH -> + rh.gs(R.string.combov2_letting_emulated_100_tbr_finish) + ComboCtlPump.SetTbrOutcome.IGNORED_REDUNDANT_100_TBR -> + rh.gs(R.string.combov2_ignoring_redundant_100_tbr) + } + + pumpEnactResult.apply { + success = true + enacted = true + comment = tbrComment + } } } catch (e: QuantityNotChangingException) { aapsLogger.error(LTag.PUMP, "TBR percentage adjustment hit a limit: $e") diff --git a/pump/combov2/src/main/res/values/strings.xml b/pump/combov2/src/main/res/values/strings.xml index 0e0516736b..ca0047ff78 100644 --- a/pump/combov2/src/main/res/values/strings.xml +++ b/pump/combov2/src/main/res/values/strings.xml @@ -107,6 +107,9 @@ buttons at the same time to cancel pairing)\n Pump reservoir level is low Setting TBR succeeded Setting TBR failed + Set emulated 100% TBR + Letting ongoing emulated 100% TBR finish + Ignoring redundant 100% TBR request Unexpected limit encountered while adjusting TBR: target percentage was %1$d%%, hit a limit at %1$d%% Cannot set absolute TBR if base basal rate is zero Pair AndroidAPS and Android with a currently unpaired Accu-Chek Combo pump From d261bbad09a04d854ee3169eaf927f5502d8c7a2 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Wed, 7 Dec 2022 15:56:59 +0100 Subject: [PATCH 08/48] NSC: fix duration sync --- .../impl/transactions/SyncNsCarbsTransaction.kt | 5 +++-- .../transactions/SyncNsExtendedBolusTransaction.kt | 4 ++-- .../transactions/SyncNsOfflineEventTransaction.kt | 4 ++-- .../transactions/SyncNsTemporaryBasalTransaction.kt | 4 ++-- .../transactions/SyncNsTemporaryTargetTransaction.kt | 4 ++-- .../transactions/SyncNsTherapyEventTransaction.kt | 4 ++-- .../plugins/sync/nsShared/StoreDataForDbImpl.kt | 12 ++++++------ 7 files changed, 19 insertions(+), 18 deletions(-) diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/SyncNsCarbsTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/SyncNsCarbsTransaction.kt index f633bd1108..c228bc1c4d 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/SyncNsCarbsTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/SyncNsCarbsTransaction.kt @@ -5,7 +5,8 @@ import info.nightscout.database.entities.Carbs /** * Sync the carbs from NS */ -class SyncNsCarbsTransaction(private val carbs: List) : Transaction() { +class SyncNsCarbsTransaction(private val carbs: List, private val nsClientMode: Boolean) : + Transaction() { override fun run(): TransactionResult { val result = TransactionResult() @@ -24,7 +25,7 @@ class SyncNsCarbsTransaction(private val carbs: List) : Transaction) : +class SyncNsExtendedBolusTransaction(private val extendedBoluses: List, private val nsClientMode: Boolean) : Transaction() { override fun run(): TransactionResult { @@ -28,7 +28,7 @@ class SyncNsExtendedBolusTransaction(private val extendedBoluses: List) : +class SyncNsOfflineEventTransaction(private val offlineEvents: List, private val nsClientMode: Boolean) : Transaction() { override fun run(): TransactionResult { @@ -28,7 +28,7 @@ class SyncNsOfflineEventTransaction(private val offlineEvents: List) : Transaction() { +class SyncNsTemporaryBasalTransaction(private val temporaryBasals: List, private val nsClientMode: Boolean) : Transaction() { override fun run(): TransactionResult { val result = TransactionResult() @@ -28,7 +28,7 @@ class SyncNsTemporaryBasalTransaction(private val temporaryBasals: List) : +class SyncNsTemporaryTargetTransaction(private val temporaryTargets: List, private val nsClientMode: Boolean) : Transaction() { override fun run(): TransactionResult { @@ -28,7 +28,7 @@ class SyncNsTemporaryTargetTransaction(private val temporaryTargets: List) : +class SyncNsTherapyEventTransaction(private val therapyEvents: List, private val nsClientMode: Boolean) : Transaction() { override fun run(): TransactionResult { @@ -24,7 +24,7 @@ class SyncNsTherapyEventTransaction(private val therapyEvents: List Date: Thu, 8 Dec 2022 08:02:03 +0000 Subject: [PATCH 09/48] chore(deps): bump fragment-ktx from 1.5.4 to 1.5.5 Bumps fragment-ktx from 1.5.4 to 1.5.5. --- updated-dependencies: - dependency-name: androidx.fragment:fragment-ktx dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.gradle b/build.gradle index c57b449a5e..b6eedb5faf 100644 --- a/build.gradle +++ b/build.gradle @@ -12,7 +12,7 @@ buildscript { dagger_version = '2.44.2' coroutines_version = '1.6.4' activity_version = '1.6.1' - fragmentktx_version = '1.5.4' + fragmentktx_version = '1.5.5' ormLite_version = '4.46' gson_version = '2.10' nav_version = '2.5.3' From 621d0f305759f66607f953dfc495a2efb4ee1e00 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Thu, 8 Dec 2022 11:38:50 +0100 Subject: [PATCH 10/48] DiaconnG8: pump log sync bug fix --- .../nightscout/pump/diaconn/service/BLECommonService.kt | 8 ++++++++ .../nightscout/pump/diaconn/service/DiaconnG8Service.kt | 7 +++++-- 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/BLECommonService.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/BLECommonService.kt index a89787b58f..102b456358 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/BLECommonService.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/BLECommonService.kt @@ -104,6 +104,14 @@ class BLECommonService @Inject internal constructor( return false } + bluetoothGatt?.let { + it.disconnect() + SystemClock.sleep(200) + it.close() + SystemClock.sleep(200) + bluetoothGatt = null + } + val device = bluetoothAdapter?.getRemoteDevice(address) if (device == null) { aapsLogger.error("Device not found. Unable to connect from: $from") diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/DiaconnG8Service.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/DiaconnG8Service.kt index 772d4f5f32..ca627bb3fd 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/DiaconnG8Service.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/DiaconnG8Service.kt @@ -295,18 +295,21 @@ class DiaconnG8Service : DaggerService() { if (apsWrappingCount == -1 && apsLastLogNum == 9999) { apsWrappingCount = pumpWrappingCount apsLastLogNum = if (pumpLastNum - 1 < 0) 0 else pumpLastNum - 2 + aapsLogger.debug(LTag.PUMPCOMM, "first install app apsWrappingCount : $apsWrappingCount, apsLastLogNum : $apsLastLogNum") } // if another pump if (pumpSerialNo != diaconnG8Pump.serialNo) { apsWrappingCount = pumpWrappingCount apsLastLogNum = if (pumpLastNum - 1 < 0) 0 else pumpLastNum - 2 sp.putInt(rh.gs(R.string.pumpserialno), diaconnG8Pump.serialNo) + aapsLogger.debug(LTag.PUMPCOMM, "Pump serialNo is different apsWrappingCount : $apsWrappingCount, apsLastLogNum : $apsLastLogNum") } // if pump reset if (apsIncarnationNum != diaconnG8Pump.pumpIncarnationNum) { apsWrappingCount = pumpWrappingCount apsLastLogNum = if (pumpLastNum - 1 < 0) 0 else pumpLastNum - 2 - sp.putInt(R.string.apsIncarnationNo, apsIncarnationNum) + sp.putInt(R.string.apsIncarnationNo, diaconnG8Pump.pumpIncarnationNum) + aapsLogger.debug(LTag.PUMPCOMM, "Pump incarnationNum is different apsWrappingCount : $apsWrappingCount, apsLastLogNum : $apsLastLogNum") } aapsLogger.debug(LTag.PUMPCOMM, "apsWrappingCount : $apsWrappingCount, apsLastLogNum : $apsLastLogNum") @@ -375,7 +378,7 @@ class DiaconnG8Service : DaggerService() { val end: Int // log sync end number1311 aapsLogger.debug(LTag.PUMPCOMM, "lastLogNum : $lastLogNum, wrappingCount : $wrappingCount , pumpLastNum: $pumpLastNum, pumpWrappingCount : $pumpWrappingCount") - if (pumpWrappingCount > wrappingCount && lastLogNum < 9999) { + if (pumpWrappingCount > wrappingCount) { start = (lastLogNum + 1) end = 10000 } else { From be647d8b5b198fa24e77abd4ca8e3af3d28f8ea3 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Wed, 7 Dec 2022 19:55:08 +0100 Subject: [PATCH 11/48] GlucoseStatusProviderImpl --- .../interfaces/ConstraintsCheckerTest.kt | 83 +- .../plugins/safety/SafetyPluginTest.kt | 94 +- .../interfaces/iob/GlucoseStatusProvider.kt | 6 + .../nightscout/core/wizard/BolusWizard.kt | 2 +- .../core/wizard/QuickWizardEntry.kt | 2 +- .../androidaps/ProfileStoreObject.kt | 107 -- .../androidaps/TestBaseWithProfile.kt | 42 +- .../iobCobCalculator/AutosensDataStoreTest.kt | 316 ---- .../implementation/di/ImplementationModule.kt | 3 + .../iob/GlucoseStatusProviderImpl.kt | 11 +- .../profile/ProfileStoreObject.kt | 3 +- .../nightscout/androidaps/HardLimitsMock.kt | 83 ++ .../androidaps/TestBaseWithProfile.kt | 44 +- .../nightscout/androidaps/TestPumpPlugin.kt | 2 +- .../implementation/iob}/GlucoseStatusTest.kt | 127 +- .../profile}/ProfileStoreTest.kt | 2 +- .../queue/CommandQueueImplementationTest.kt | 176 ++- .../implementation/queue/QueueThreadTest.kt | 2 - .../implementation}/wizard/BolusWizardTest.kt | 26 +- .../aps/openAPSAMA/OpenAPSAMAPlugin.kt | 2 +- .../aps/openAPSSMB/OpenAPSSMBPlugin.kt | 2 +- .../OpenAPSSMBDynamicISFPlugin.kt | 2 +- plugins/automation/build.gradle | 2 + .../actions/ActionCarePortalEvent.kt | 2 +- .../nightscout/automation/triggers/Trigger.kt | 2 +- .../automation/triggers/TriggerTestBase.kt | 4 +- plugins/main/build.gradle | 2 + .../dataBroadcaster/DataBroadcastPlugin.kt | 6 +- .../general/overview/OverviewFragment.kt | 2 +- .../PersistentNotificationPlugin.kt | 2 +- .../general/smsCommunicator/AuthRequest.kt | 2 +- .../smsCommunicator/SmsCommunicatorPlugin.kt | 2 +- .../wear/wearintegration/DataHandlerMobile.kt | 2 +- .../IobCobCalculatorPlugin.kt | 2 +- .../data}/AutosensDataStoreObject.kt | 8 +- .../SmsCommunicatorPluginTest.kt | 517 ++++--- .../plugins/iob/AutosensDataStoreTest.kt | 1323 +++++++++++++++++ .../ui/dialogs/CalibrationDialog.kt | 2 +- .../info/nightscout/ui/dialogs/CarbsDialog.kt | 2 +- .../info/nightscout/ui/dialogs/CareDialog.kt | 2 +- .../java/info/nightscout/ui/widget/Widget.kt | 2 +- 41 files changed, 2022 insertions(+), 1001 deletions(-) create mode 100644 core/interfaces/src/main/java/info/nightscout/interfaces/iob/GlucoseStatusProvider.kt delete mode 100644 core/main/src/test/java/info/nightscout/androidaps/ProfileStoreObject.kt delete mode 100644 core/main/src/test/java/info/nightscout/androidaps/plugins/iob/iobCobCalculator/AutosensDataStoreTest.kt rename core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/GlucoseStatusProvider.kt => implementation/src/main/java/info/nightscout/implementation/iob/GlucoseStatusProviderImpl.kt (93%) create mode 100644 implementation/src/test/java/info/nightscout/androidaps/HardLimitsMock.kt rename {core/main/src/test/java/info/nightscout/androidaps/plugins/iob/iobCalculator => implementation/src/test/java/info/nightscout/implementation/iob}/GlucoseStatusTest.kt (64%) rename {core/main/src/test/java/info/nightscout/androidaps/interfaces => implementation/src/test/java/info/nightscout/implementation/profile}/ProfileStoreTest.kt (96%) rename {core/main/src/test/java/info/nightscout/core => implementation/src/test/java/info/nightscout/implementation}/wizard/BolusWizardTest.kt (83%) rename {core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator => plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data}/AutosensDataStoreObject.kt (99%) create mode 100644 plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt diff --git a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt index 041b19ed2c..b56861ef42 100644 --- a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt @@ -10,9 +10,9 @@ import info.nightscout.androidaps.insight.database.InsightDatabase import info.nightscout.androidaps.insight.database.InsightDatabaseDao import info.nightscout.androidaps.insight.database.InsightDbHelper import info.nightscout.androidaps.plugins.pump.insight.LocalInsightPlugin -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.database.impl.AppRepository import info.nightscout.implementation.constraints.ConstraintsImpl +import info.nightscout.implementation.iob.GlucoseStatusProviderImpl import info.nightscout.interfaces.bgQualityCheck.BgQualityCheck import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints @@ -45,11 +45,10 @@ import info.nightscout.pump.dana.DanaPump import info.nightscout.pump.dana.R import info.nightscout.pump.dana.database.DanaHistoryDatabase import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock -import org.mockito.Mockito import org.mockito.Mockito.`when` /** @@ -134,15 +133,15 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { // RS constructor `when`(sp.getString(R.string.key_danars_name, "")).thenReturn("") - `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danars_address, "")).thenReturn("") + `when`(sp.getString(R.string.key_danars_address, "")).thenReturn("") // R - `when`(sp.getString(info.nightscout.pump.dana.R.string.key_danar_bt_name, "")).thenReturn("") + `when`(sp.getString(R.string.key_danar_bt_name, "")).thenReturn("") //SafetyPlugin `when`(activePlugin.activePump).thenReturn(virtualPumpPlugin) constraintChecker = ConstraintsImpl(activePlugin) - val glucoseStatusProvider = GlucoseStatusProvider(aapsLogger = aapsLogger, iobCobCalculator = iobCobCalculator, dateUtil = dateUtil) + val glucoseStatusProvider = GlucoseStatusProviderImpl(aapsLogger = aapsLogger, iobCobCalculator = iobCobCalculator, dateUtil = dateUtil) hardLimits = HardLimitsMock(sp, rh) insightDbHelper = InsightDbHelper(insightDatabaseDao) @@ -265,9 +264,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { comboPlugin.setPluginEnabled(PluginType.PUMP, true) comboPlugin.setValidBasalRateProfileSelectedOnPump(false) val c = constraintChecker.isLoopInvocationAllowed() - Assert.assertEquals(true, c.reasonList.size == 2) // Combo & Objectives - Assert.assertEquals(true, c.mostLimitedReasonList.size == 2) // Combo & Objectives - Assert.assertEquals(java.lang.Boolean.FALSE, c.value()) + Assertions.assertEquals(true, c.reasonList.size == 2) // Combo & Objectives + Assertions.assertEquals(true, c.mostLimitedReasonList.size == 2) // Combo & Objectives + Assertions.assertEquals(java.lang.Boolean.FALSE, c.value()) } // Safety & Objectives @@ -278,13 +277,13 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { objectivesPlugin.objectives[Objectives.MAXIOB_ZERO_CL_OBJECTIVE].startedOn = 0 var c: Constraint = constraintChecker.isClosedLoopAllowed() aapsLogger.debug("Reason list: " + c.reasonList.toString()) -// Assert.assertTrue(c.reasonList[0].toString().contains("Closed loop is disabled")) // Safety & Objectives - Assert.assertEquals(false, c.value()) +// Assertions.assertTrue(c.reasonList[0].toString().contains("Closed loop is disabled")) // Safety & Objectives + Assertions.assertEquals(false, c.value()) `when`(sp.getString(info.nightscout.core.utils.R.string.key_aps_mode, "open")).thenReturn("open") c = constraintChecker.isClosedLoopAllowed() - Assert.assertTrue(c.reasonList[0].contains("Closed loop mode disabled in preferences")) // Safety & Objectives -// Assert.assertEquals(3, c.reasonList.size) // 2x Safety & Objectives - Assert.assertEquals(false, c.value()) + Assertions.assertTrue(c.reasonList[0].contains("Closed loop mode disabled in preferences")) // Safety & Objectives +// Assertions.assertEquals(3, c.reasonList.size) // 2x Safety & Objectives + Assertions.assertEquals(false, c.value()) } // Safety & Objectives @@ -294,9 +293,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { objectivesPlugin.objectives[Objectives.AUTOSENS_OBJECTIVE].startedOn = 0 `when`(sp.getBoolean(info.nightscout.plugins.aps.R.string.key_openapsama_use_autosens, false)).thenReturn(false) val c = constraintChecker.isAutosensModeEnabled() - Assert.assertEquals(true, c.reasonList.size == 2) // Safety & Objectives - Assert.assertEquals(true, c.mostLimitedReasonList.size == 2) // Safety & Objectives - Assert.assertEquals(java.lang.Boolean.FALSE, c.value()) + Assertions.assertEquals(true, c.reasonList.size == 2) // Safety & Objectives + Assertions.assertEquals(true, c.mostLimitedReasonList.size == 2) // Safety & Objectives + Assertions.assertEquals(java.lang.Boolean.FALSE, c.value()) } // Safety @@ -304,9 +303,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { fun isAdvancedFilteringEnabledTest() { `when`(activePlugin.activeBgSource).thenReturn(glimpPlugin) val c = constraintChecker.isAdvancedFilteringEnabled() - Assert.assertEquals(true, c.reasonList.size == 1) // Safety - Assert.assertEquals(true, c.mostLimitedReasonList.size == 1) // Safety - Assert.assertEquals(false, c.value()) + Assertions.assertEquals(true, c.reasonList.size == 1) // Safety + Assertions.assertEquals(true, c.mostLimitedReasonList.size == 1) // Safety + Assertions.assertEquals(false, c.value()) } // SMB should limit @@ -314,7 +313,7 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { fun isSuperBolusEnabledTest() { openAPSSMBPlugin.setPluginEnabled(PluginType.APS, true) val c = constraintChecker.isSuperBolusEnabled() - Assert.assertEquals(java.lang.Boolean.FALSE, c.value()) // SMB should limit + Assertions.assertEquals(java.lang.Boolean.FALSE, c.value()) // SMB should limit } // Safety & Objectives @@ -326,9 +325,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { `when`(sp.getString(info.nightscout.core.utils.R.string.key_aps_mode, "open")).thenReturn("open") // `when`(constraintChecker.isClosedLoopAllowed()).thenReturn(Constraint(true)) val c = constraintChecker.isSMBModeEnabled() - Assert.assertEquals(true, c.reasonList.size == 3) // 2x Safety & Objectives - Assert.assertEquals(true, c.mostLimitedReasonList.size == 3) // 2x Safety & Objectives - Assert.assertEquals(false, c.value()) + Assertions.assertEquals(true, c.reasonList.size == 3) // 2x Safety & Objectives + Assertions.assertEquals(true, c.mostLimitedReasonList.size == 3) // 2x Safety & Objectives + Assertions.assertEquals(false, c.value()) } // applyBasalConstraints tests @@ -354,9 +353,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { // Apply all limits val d = constraintChecker.getMaxBasalAllowed(validProfile) - Assert.assertEquals(0.8, d.value(), 0.01) - Assert.assertEquals(3, d.reasonList.size) - Assert.assertEquals("DanaR: Limiting max basal rate to 0.80 U/h because of pump limit", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(0.8, d.value(), 0.01) + Assertions.assertEquals(3, d.reasonList.size) + Assertions.assertEquals("DanaR: Limiting max basal rate to 0.80 U/h because of pump limit", d.getMostLimitedReasons(aapsLogger)) } @Test @@ -381,9 +380,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { // Apply all limits val i = constraintChecker.getMaxBasalPercentAllowed(validProfile) - Assert.assertEquals(200, i.value()) - Assert.assertEquals(6, i.reasonList.size) - Assert.assertEquals("Safety: Limiting max percent rate to 200% because of pump limit", i.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(200, i.value()) + Assertions.assertEquals(6, i.reasonList.size) + Assertions.assertEquals("Safety: Limiting max percent rate to 200% because of pump limit", i.getMostLimitedReasons(aapsLogger)) } // applyBolusConstraints tests @@ -408,9 +407,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { // Apply all limits val d = constraintChecker.getMaxBolusAllowed() - Assert.assertEquals(3.0, d.value(), 0.01) - Assert.assertEquals(4, d.reasonList.size) // 2x Safety & RS & R - Assert.assertEquals("Safety: Limiting bolus to 3.0 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(3.0, d.value(), 0.01) + Assertions.assertEquals(4, d.reasonList.size) // 2x Safety & RS & R + Assertions.assertEquals("Safety: Limiting bolus to 3.0 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) } // applyCarbsConstraints tests @@ -421,9 +420,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { // Apply all limits val i = constraintChecker.getMaxCarbsAllowed() - Assert.assertEquals(48, i.value()) - Assert.assertEquals(true, i.reasonList.size == 1) - Assert.assertEquals("Safety: Limiting carbs to 48 g because of max value in preferences", i.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(48, i.value()) + Assertions.assertEquals(true, i.reasonList.size == 1) + Assertions.assertEquals("Safety: Limiting carbs to 48 g because of max value in preferences", i.getMostLimitedReasons(aapsLogger)) } // applyMaxIOBConstraints tests @@ -438,9 +437,9 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { // Apply all limits val d = constraintChecker.getMaxIOBAllowed() - Assert.assertEquals(1.5, d.value(), 0.01) - Assert.assertEquals(d.reasonList.toString(), 2, d.reasonList.size) - Assert.assertEquals("OpenAPSAMA: Limiting IOB to 1.5 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(1.5, d.value(), 0.01) + Assertions.assertEquals(2, d.reasonList.size) + Assertions.assertEquals("OpenAPSAMA: Limiting IOB to 1.5 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) } @Test @@ -454,8 +453,8 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { // Apply all limits val d = constraintChecker.getMaxIOBAllowed() - Assert.assertEquals(3.0, d.value(), 0.01) - Assert.assertEquals(d.reasonList.toString(), 2, d.reasonList.size) - Assert.assertEquals("OpenAPSSMB: Limiting IOB to 3.0 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(3.0, d.value(), 0.01) + Assertions.assertEquals(2, d.reasonList.size) + Assertions.assertEquals("OpenAPSSMB: Limiting IOB to 3.0 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) } } \ No newline at end of file diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt index 644d36b923..e87048c860 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt @@ -4,12 +4,12 @@ import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.androidaps.HardLimitsMock import info.nightscout.androidaps.TestBaseWithProfile -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.database.impl.AppRepository import info.nightscout.interfaces.Constants import info.nightscout.interfaces.bgQualityCheck.BgQualityCheck import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.profiling.Profiler @@ -22,7 +22,7 @@ import info.nightscout.plugins.constraints.safety.SafetyPlugin import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin import info.nightscout.plugins.source.GlimpPlugin import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -91,8 +91,8 @@ class SafetyPluginTest : TestBaseWithProfile() { pumpDescription.isTempBasalCapable = false var c = Constraint(true) c = safetyPlugin.isLoopInvocationAllowed(c) - Assert.assertEquals("Safety: Pump is not temp basal capable", c.getReasons(aapsLogger)) - Assert.assertEquals(false, c.value()) + Assertions.assertEquals("Safety: Pump is not temp basal capable", c.getReasons(aapsLogger)) + Assertions.assertEquals(false, c.value()) } @Test @@ -101,8 +101,8 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(config.isEngineeringModeOrRelease()).thenReturn(false) var c = Constraint(true) c = safetyPlugin.isClosedLoopAllowed(c) - Assert.assertTrue(c.getReasons(aapsLogger).contains("Running dev version. Closed loop is disabled.")) - Assert.assertEquals(false, c.value()) + Assertions.assertTrue(c.getReasons(aapsLogger).contains("Running dev version. Closed loop is disabled.")) + Assertions.assertEquals(false, c.value()) } @Test @@ -110,8 +110,8 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(sp.getString(info.nightscout.core.utils.R.string.key_aps_mode, "open")).thenReturn("open") var c = Constraint(true) c = safetyPlugin.isClosedLoopAllowed(c) - Assert.assertTrue(c.getReasons(aapsLogger).contains("Closed loop mode disabled in preferences")) - Assert.assertEquals(false, c.value()) + Assertions.assertTrue(c.getReasons(aapsLogger).contains("Closed loop mode disabled in preferences")) + Assertions.assertEquals(false, c.value()) } @Test @@ -120,8 +120,8 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(constraintChecker.isClosedLoopAllowed(anyObject())).thenReturn(Constraint(true)) var c = Constraint(true) c = openAPSSMBPlugin.isSMBModeEnabled(c) - Assert.assertTrue(c.getReasons(aapsLogger).contains("SMB disabled in preferences")) - Assert.assertEquals(false, c.value()) + Assertions.assertTrue(c.getReasons(aapsLogger).contains("SMB disabled in preferences")) + Assertions.assertEquals(false, c.value()) } @Test @@ -130,8 +130,8 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(constraintChecker.isClosedLoopAllowed(anyObject())).thenReturn(Constraint(false)) var c = Constraint(true) c = safetyPlugin.isSMBModeEnabled(c) - Assert.assertTrue(c.getReasons(aapsLogger).contains("SMB not allowed in open loop mode")) - Assert.assertEquals(false, c.value()) + Assertions.assertTrue(c.getReasons(aapsLogger).contains("SMB not allowed in open loop mode")) + Assertions.assertEquals(false, c.value()) } @Test @@ -139,8 +139,8 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(activePlugin.activeBgSource).thenReturn(glimpPlugin) var c = Constraint(true) c = safetyPlugin.isAdvancedFilteringEnabled(c) - Assert.assertEquals("Safety: SMB always and after carbs disabled because active BG source doesn\\'t support advanced filtering", c.getReasons(aapsLogger)) - Assert.assertEquals(false, c.value()) + Assertions.assertEquals("Safety: SMB always and after carbs disabled because active BG source doesn\\'t support advanced filtering", c.getReasons(aapsLogger)) + Assertions.assertEquals(false, c.value()) } @Test @@ -151,13 +151,13 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(sp.getString(info.nightscout.core.utils.R.string.key_age, "")).thenReturn("child") val c = Constraint(Constants.REALLYHIGHBASALRATE) safetyPlugin.applyBasalConstraints(c, validProfile) - Assert.assertEquals(2.0, c.value(), 0.01) - Assert.assertEquals( + Assertions.assertEquals(2.0, c.value(), 0.01) + Assertions.assertEquals( """ Safety: Limiting max basal rate to 2.00 U/h because of hard limit """.trimIndent(), c.getReasons(aapsLogger) ) - Assert.assertEquals("Safety: Limiting max basal rate to 2.00 U/h because of hard limit", c.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals("Safety: Limiting max basal rate to 2.00 U/h because of hard limit", c.getMostLimitedReasons(aapsLogger)) } @Test @@ -165,8 +165,8 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(sp.getString(info.nightscout.core.utils.R.string.key_age, "")).thenReturn("child") val d = Constraint(-0.5) safetyPlugin.applyBasalConstraints(d, validProfile) - Assert.assertEquals(0.0, d.value(), 0.01) - Assert.assertEquals("Safety: Limiting max basal rate to 0.00 U/h because of it must be positive value", d.getReasons(aapsLogger)) + Assertions.assertEquals(0.0, d.value(), 0.01) + Assertions.assertEquals("Safety: Limiting max basal rate to 0.00 U/h because of it must be positive value", d.getReasons(aapsLogger)) } @Test @@ -178,8 +178,8 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(sp.getString(info.nightscout.core.utils.R.string.key_age, "")).thenReturn("child") val i = Constraint(Constants.REALLYHIGHPERCENTBASALRATE) safetyPlugin.applyBasalPercentConstraints(i, validProfile) - Assert.assertEquals(200, i.value()) - Assert.assertEquals( + Assertions.assertEquals(200, i.value()) + Assertions.assertEquals( """ Safety: Percent rate 1111111% recalculated to 11111.11 U/h with current basal 1.00 U/h Safety: Limiting max basal rate to 2.00 U/h because of hard limit @@ -187,7 +187,7 @@ Safety: Limiting max percent rate to 200% because of pump limit Safety: Limiting max basal rate to 500.00 U/h because of pump limit """.trimIndent(), i.getReasons(aapsLogger) ) - Assert.assertEquals("Safety: Limiting max percent rate to 200% because of pump limit", i.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals("Safety: Limiting max percent rate to 200% because of pump limit", i.getMostLimitedReasons(aapsLogger)) } @Test @@ -200,15 +200,15 @@ Safety: Limiting max basal rate to 500.00 U/h because of pump limit openAPSSMBPlugin.setPluginEnabled(PluginType.APS, true) val i = Constraint(Constants.REALLYHIGHBASALRATE) openAPSSMBPlugin.applyBasalConstraints(i, validProfile) - Assert.assertEquals(1.0, i.value(), 0.01) - Assert.assertEquals( + Assertions.assertEquals(1.0, i.value(), 0.01) + Assertions.assertEquals( """ OpenAPSSMB: Limiting max basal rate to 1.00 U/h because of max value in preferences OpenAPSSMB: Limiting max basal rate to 4.00 U/h because of max basal multiplier OpenAPSSMB: Limiting max basal rate to 3.00 U/h because of max daily basal multiplier """.trimIndent(), i.getReasons(aapsLogger) ) - Assert.assertEquals("OpenAPSSMB: Limiting max basal rate to 1.00 U/h because of max value in preferences", i.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals("OpenAPSSMB: Limiting max basal rate to 1.00 U/h because of max value in preferences", i.getMostLimitedReasons(aapsLogger)) } @Test @@ -216,15 +216,15 @@ Safety: Limiting max basal rate to 500.00 U/h because of pump limit `when`(sp.getString(info.nightscout.core.utils.R.string.key_age, "")).thenReturn("child") val i = Constraint(-22) safetyPlugin.applyBasalPercentConstraints(i, validProfile) - Assert.assertEquals(0, i.value()) - Assert.assertEquals( + Assertions.assertEquals(0, i.value()) + Assertions.assertEquals( """ Safety: Percent rate -22% recalculated to -0.22 U/h with current basal 1.00 U/h Safety: Limiting max basal rate to 0.00 U/h because of it must be positive value Safety: Limiting max percent rate to 0% because of pump limit """.trimIndent(), i.getReasons(aapsLogger) ) - Assert.assertEquals("Safety: Limiting max percent rate to 0% because of pump limit", i.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals("Safety: Limiting max percent rate to 0% because of pump limit", i.getMostLimitedReasons(aapsLogger)) } @Test @@ -233,14 +233,14 @@ Safety: Limiting max basal rate to 500.00 U/h because of pump limit `when`(sp.getString(info.nightscout.core.utils.R.string.key_age, "")).thenReturn("child") var d = Constraint(Constants.REALLYHIGHBOLUS) d = safetyPlugin.applyBolusConstraints(d) - Assert.assertEquals(3.0, d.value(), 0.01) - Assert.assertEquals( + Assertions.assertEquals(3.0, d.value(), 0.01) + Assertions.assertEquals( """ Safety: Limiting bolus to 3.0 U because of max value in preferences Safety: Limiting bolus to 5.0 U because of hard limit """.trimIndent(), d.getReasons(aapsLogger) ) - Assert.assertEquals("Safety: Limiting bolus to 3.0 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals("Safety: Limiting bolus to 3.0 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) } @Test @@ -249,9 +249,9 @@ Safety: Limiting max basal rate to 500.00 U/h because of pump limit `when`(sp.getString(info.nightscout.core.utils.R.string.key_age, "")).thenReturn("child") var d = Constraint(-22.0) d = safetyPlugin.applyBolusConstraints(d) - Assert.assertEquals(0.0, d.value(), 0.01) - Assert.assertEquals("Safety: Limiting bolus to 0.0 U because of it must be positive value", d.getReasons(aapsLogger)) - Assert.assertEquals("Safety: Limiting bolus to 0.0 U because of it must be positive value", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(0.0, d.value(), 0.01) + Assertions.assertEquals("Safety: Limiting bolus to 0.0 U because of it must be positive value", d.getReasons(aapsLogger)) + Assertions.assertEquals("Safety: Limiting bolus to 0.0 U because of it must be positive value", d.getMostLimitedReasons(aapsLogger)) } @Test @@ -262,13 +262,13 @@ Safety: Limiting max basal rate to 500.00 U/h because of pump limit // Negative carbs not allowed var i = Constraint(-22) safetyPlugin.applyCarbsConstraints(i) - Assert.assertEquals(0, i.value()) - Assert.assertEquals("Safety: Limiting carbs to 0 g because of it must be positive value", i.getReasons(aapsLogger)) + Assertions.assertEquals(0, i.value()) + Assertions.assertEquals("Safety: Limiting carbs to 0 g because of it must be positive value", i.getReasons(aapsLogger)) // Apply all limits i = safetyPlugin.applyCarbsConstraints(Constraint(Constants.REALLYHIGHCARBS)) - Assert.assertEquals(48, i.value()) - Assert.assertEquals("Safety: Limiting carbs to 48 g because of max value in preferences", i.getReasons(aapsLogger)) + Assertions.assertEquals(48, i.value()) + Assertions.assertEquals("Safety: Limiting carbs to 48 g because of max value in preferences", i.getReasons(aapsLogger)) } @Test @@ -285,22 +285,22 @@ Safety: Limiting max basal rate to 500.00 U/h because of pump limit // Apply all limits var d = Constraint(Constants.REALLYHIGHIOB) d = safetyPlugin.applyMaxIOBConstraints(d) - Assert.assertEquals(HardLimits.MAX_IOB_LGS, d.value(), 0.01) - Assert.assertEquals("Safety: Limiting IOB to 0.0 U because of Low Glucose Suspend", d.getReasons(aapsLogger)) - Assert.assertEquals("Safety: Limiting IOB to 0.0 U because of Low Glucose Suspend", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(HardLimits.MAX_IOB_LGS, d.value(), 0.01) + Assertions.assertEquals("Safety: Limiting IOB to 0.0 U because of Low Glucose Suspend", d.getReasons(aapsLogger)) + Assertions.assertEquals("Safety: Limiting IOB to 0.0 U because of Low Glucose Suspend", d.getMostLimitedReasons(aapsLogger)) // Apply all limits d = Constraint(Constants.REALLYHIGHIOB) val a = openAPSAMAPlugin.applyMaxIOBConstraints(d) - Assert.assertEquals(1.5, a.value(), 0.01) - Assert.assertEquals("OpenAPSAMA: Limiting IOB to 1.5 U because of max value in preferences\nOpenAPSAMA: Limiting IOB to 7.0 U because of hard limit", d.getReasons(aapsLogger)) - Assert.assertEquals("OpenAPSAMA: Limiting IOB to 1.5 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(1.5, a.value(), 0.01) + Assertions.assertEquals("OpenAPSAMA: Limiting IOB to 1.5 U because of max value in preferences\nOpenAPSAMA: Limiting IOB to 7.0 U because of hard limit", d.getReasons(aapsLogger)) + Assertions.assertEquals("OpenAPSAMA: Limiting IOB to 1.5 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) // Apply all limits d = Constraint(Constants.REALLYHIGHIOB) val s = openAPSSMBPlugin.applyMaxIOBConstraints(d) - Assert.assertEquals(3.0, s.value(), 0.01) - Assert.assertEquals("OpenAPSSMB: Limiting IOB to 3.0 U because of max value in preferences\nOpenAPSSMB: Limiting IOB to 22.0 U because of hard limit", d.getReasons(aapsLogger)) - Assert.assertEquals("OpenAPSSMB: Limiting IOB to 3.0 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(3.0, s.value(), 0.01) + Assertions.assertEquals("OpenAPSSMB: Limiting IOB to 3.0 U because of max value in preferences\nOpenAPSSMB: Limiting IOB to 22.0 U because of hard limit", d.getReasons(aapsLogger)) + Assertions.assertEquals("OpenAPSSMB: Limiting IOB to 3.0 U because of max value in preferences", d.getMostLimitedReasons(aapsLogger)) } } \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/iob/GlucoseStatusProvider.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/iob/GlucoseStatusProvider.kt new file mode 100644 index 0000000000..8dffab46fe --- /dev/null +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/iob/GlucoseStatusProvider.kt @@ -0,0 +1,6 @@ +package info.nightscout.interfaces.iob + +interface GlucoseStatusProvider { + val glucoseStatusData: GlucoseStatus? + fun getGlucoseStatusData(allowOldData: Boolean = false): GlucoseStatus? +} \ No newline at end of file diff --git a/core/main/src/main/java/info/nightscout/core/wizard/BolusWizard.kt b/core/main/src/main/java/info/nightscout/core/wizard/BolusWizard.kt index d044b23f0e..49182208cf 100644 --- a/core/main/src/main/java/info/nightscout/core/wizard/BolusWizard.kt +++ b/core/main/src/main/java/info/nightscout/core/wizard/BolusWizard.kt @@ -6,7 +6,6 @@ import com.google.common.base.Joiner import dagger.android.HasAndroidInjector import info.nightscout.core.extensions.highValueToUnitsToString import info.nightscout.core.extensions.lowValueToUnitsToString -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.iob.round import info.nightscout.core.ui.dialogs.OKDialog import info.nightscout.core.utils.extensions.formatColor @@ -24,6 +23,7 @@ import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.db.PersistenceLayer import info.nightscout.interfaces.iob.GlucoseStatus +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.plugin.ActivePlugin diff --git a/core/main/src/main/java/info/nightscout/core/wizard/QuickWizardEntry.kt b/core/main/src/main/java/info/nightscout/core/wizard/QuickWizardEntry.kt index a4e9323523..1a489bd7af 100644 --- a/core/main/src/main/java/info/nightscout/core/wizard/QuickWizardEntry.kt +++ b/core/main/src/main/java/info/nightscout/core/wizard/QuickWizardEntry.kt @@ -3,13 +3,13 @@ package info.nightscout.core.wizard import dagger.android.HasAndroidInjector import info.nightscout.androidaps.annotations.OpenForTesting import info.nightscout.core.extensions.valueToUnits -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.iob.round import info.nightscout.core.utils.MidnightUtils import info.nightscout.database.ValueWrapper import info.nightscout.database.entities.GlucoseValue import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.db.PersistenceLayer +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.profile.Profile diff --git a/core/main/src/test/java/info/nightscout/androidaps/ProfileStoreObject.kt b/core/main/src/test/java/info/nightscout/androidaps/ProfileStoreObject.kt deleted file mode 100644 index e4040d0369..0000000000 --- a/core/main/src/test/java/info/nightscout/androidaps/ProfileStoreObject.kt +++ /dev/null @@ -1,107 +0,0 @@ -package info.nightscout.androidaps - -import androidx.collection.ArrayMap -import dagger.android.HasAndroidInjector -import info.nightscout.core.extensions.pureProfileFromJson -import info.nightscout.core.profile.ProfileSealed -import info.nightscout.interfaces.Config -import info.nightscout.interfaces.plugin.ActivePlugin -import info.nightscout.interfaces.profile.ProfileStore -import info.nightscout.interfaces.profile.PureProfile -import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.interfaces.utils.JsonHelper -import info.nightscout.rx.bus.RxBus -import info.nightscout.rx.logging.AAPSLogger -import info.nightscout.shared.interfaces.ResourceHelper -import info.nightscout.shared.utils.DateUtil -import org.json.JSONException -import org.json.JSONObject -import javax.inject.Inject - -class ProfileStoreObject(val injector: HasAndroidInjector, override val data: JSONObject, val dateUtil: DateUtil) : ProfileStore { - - @Inject lateinit var aapsLogger: AAPSLogger - @Inject lateinit var activePlugin: ActivePlugin - @Inject lateinit var config: Config - @Inject lateinit var rh: ResourceHelper - @Inject lateinit var rxBus: RxBus - @Inject lateinit var hardLimits: HardLimits - - init { - injector.androidInjector().inject(this) - } - - private val cachedObjects = ArrayMap() - - private fun storeUnits(): String? = JsonHelper.safeGetStringAllowNull(data, "units", null) - - private fun getStore(): JSONObject? { - try { - if (data.has("store")) return data.getJSONObject("store") - } catch (e: JSONException) { - aapsLogger.error("Unhandled exception", e) - } - return null - } - - override fun getStartDate(): Long { - val iso = JsonHelper.safeGetString(data, "startDate") ?: return 0 - return try { - dateUtil.fromISODateString(iso) - } catch (e: Exception) { - 0 - } - } - - override fun getDefaultProfile(): PureProfile? = getDefaultProfileName()?.let { getSpecificProfile(it) } - override fun getDefaultProfileJson(): JSONObject? = getDefaultProfileName()?.let { getSpecificProfileJson(it) } - - override fun getDefaultProfileName(): String? { - val defaultProfileName = data.optString("defaultProfile") - return if (defaultProfileName.isNotEmpty()) getStore()?.has(defaultProfileName)?.let { defaultProfileName } else null - } - - override fun getProfileList(): ArrayList { - val ret = ArrayList() - getStore()?.keys()?.let { keys -> - while (keys.hasNext()) { - val profileName = keys.next() as String - ret.add(profileName) - } - } - return ret - } - - @Synchronized - override fun getSpecificProfile(profileName: String): PureProfile? { - var profile: PureProfile? = null - val units = JsonHelper.safeGetStringAllowNull(data, "units", storeUnits()) - getStore()?.let { store -> - if (store.has(profileName)) { - profile = cachedObjects[profileName] - if (profile == null) { - JsonHelper.safeGetJSONObject(store, profileName, null)?.let { profileObject -> - profile = pureProfileFromJson(profileObject, dateUtil, units) - profile?.let { cachedObjects[profileName] = profile } - } - } - } - } - return profile - } - - private fun getSpecificProfileJson(profileName: String): JSONObject? { - getStore()?.let { store -> - if (store.has(profileName)) - return JsonHelper.safeGetJSONObject(store, profileName, null) - } - return null - } - - override val allProfilesValid: Boolean - get() = getProfileList() - .asSequence() - .map { profileName -> getSpecificProfile(profileName.toString()) } - .map { pureProfile -> pureProfile?.let { ProfileSealed.Pure(pureProfile).isValid("allProfilesValid", activePlugin.activePump, config, rh, rxBus, hardLimits, false) } } - .all { it?.isValid == true } -} \ No newline at end of file diff --git a/core/main/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt b/core/main/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt index 526edeab98..002bb7cab6 100644 --- a/core/main/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt +++ b/core/main/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt @@ -10,7 +10,6 @@ import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.DefaultValueHelper import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.ProfileStore import info.nightscout.interfaces.utils.HardLimits import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper @@ -38,18 +37,7 @@ open class TestBaseWithProfile : TestBase() { val rxBus = RxBus(aapsSchedulers, aapsLogger) - val profileInjector = HasAndroidInjector { - AndroidInjector { - if (it is ProfileStoreObject) { - it.aapsLogger = aapsLogger - it.activePlugin = activePluginProvider - it.config = config - it.rh = rh - it.rxBus = rxBus - it.hardLimits = hardLimits - } - } - } + val profileInjector = HasAndroidInjector { AndroidInjector { } } private lateinit var invalidProfileJSON: String private lateinit var validProfileJSON: String @@ -70,32 +58,4 @@ open class TestBaseWithProfile : TestBase() { `when`(activePluginProvider.activePump).thenReturn(testPumpPlugin) hardLimits = HardLimitsMock(sp, rh) } - - fun getValidProfileStore(): ProfileStore { - val json = JSONObject() - val store = JSONObject() - store.put(TESTPROFILENAME, JSONObject(validProfileJSON)) - json.put("defaultProfile", TESTPROFILENAME) - json.put("store", store) - return ProfileStoreObject(profileInjector, json, dateUtil) - } - - fun getInvalidProfileStore1(): ProfileStore { - val json = JSONObject() - val store = JSONObject() - store.put(TESTPROFILENAME, JSONObject(invalidProfileJSON)) - json.put("defaultProfile", TESTPROFILENAME) - json.put("store", store) - return ProfileStoreObject(profileInjector, json, dateUtil) - } - - fun getInvalidProfileStore2(): ProfileStore { - val json = JSONObject() - val store = JSONObject() - store.put(TESTPROFILENAME, JSONObject(validProfileJSON)) - store.put("invalid", JSONObject(invalidProfileJSON)) - json.put("defaultProfile", TESTPROFILENAME + "invalid") - json.put("store", store) - return ProfileStoreObject(profileInjector, json, dateUtil) - } } diff --git a/core/main/src/test/java/info/nightscout/androidaps/plugins/iob/iobCobCalculator/AutosensDataStoreTest.kt b/core/main/src/test/java/info/nightscout/androidaps/plugins/iob/iobCobCalculator/AutosensDataStoreTest.kt deleted file mode 100644 index 907e21d8bb..0000000000 --- a/core/main/src/test/java/info/nightscout/androidaps/plugins/iob/iobCobCalculator/AutosensDataStoreTest.kt +++ /dev/null @@ -1,316 +0,0 @@ -package info.nightscout.androidaps.plugins.iob.iobCobCalculator - -import android.content.Context -import info.nightscout.androidaps.TestBase -import info.nightscout.core.iob.iobCobCalculator.AutosensDataStoreObject -import info.nightscout.database.entities.GlucoseValue -import info.nightscout.shared.utils.DateUtil -import info.nightscout.shared.utils.T -import org.junit.Assert -import org.junit.jupiter.api.BeforeEach -import org.junit.jupiter.api.Test -import org.mockito.Mock - -class AutosensDataStoreTest : TestBase() { - - @Mock lateinit var context: Context - - lateinit var dateUtil: DateUtil - - private val autosensDataStore = AutosensDataStoreObject() - - @BeforeEach - fun mock() { - dateUtil = DateUtil(context) - } - - @Test - fun isAbout5minDataTest() { - val bgReadingList: MutableList = ArrayList() - - // Super data should not be touched - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(15).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - - // too much shifted data should return false - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(15).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(9).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) - - // too much shifted and missing data should return false - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(9).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) - - // too much shifted and missing data should return false - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(83).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(78).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(73).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(68).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(63).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(58).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(53).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(48).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(43).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(38).plus(T.secs(40)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(33).plus(T.secs(1)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(28).plus(T.secs(0)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(23).plus(T.secs(0)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(16).plus(T.secs(36)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) - - // slightly shifted data should return true - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(15).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).plus(T.secs(10)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - - // slightly shifted and missing data should return true - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).plus(T.secs(10)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - } - - @Test - fun createBucketedData5minTest1() { - val bgReadingList: MutableList = ArrayList() - - // Super data should not be touched - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(15).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(bgReadingList[0].timestamp, autosensDataStore.bucketedData!![0].timestamp) - Assert.assertEquals(bgReadingList[3].timestamp, autosensDataStore.bucketedData!![3].timestamp) - Assert.assertEquals(bgReadingList.size.toLong(), autosensDataStore.bucketedData!!.size.toLong()) - - // Missing value should be replaced - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).plus(T.secs(10)).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(bgReadingList[0].timestamp, autosensDataStore.bucketedData!![0].timestamp) - Assert.assertEquals(bgReadingList[2].timestamp, autosensDataStore.bucketedData!![3].timestamp) - Assert.assertEquals(bgReadingList.size + 1.toLong(), autosensDataStore.bucketedData!!.size.toLong()) - - // drift should be cleared - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(15).msecs() + T.secs(10).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).msecs() + T.secs(10).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs() + T.secs(10).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(0).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![0].timestamp) - Assert.assertEquals(T.mins(15).msecs(), autosensDataStore.bucketedData!![1].timestamp) - Assert.assertEquals(T.mins(10).msecs(), autosensDataStore.bucketedData!![2].timestamp) - Assert.assertEquals(T.mins(5).msecs(), autosensDataStore.bucketedData!![3].timestamp) - Assert.assertEquals(bgReadingList.size.toLong(), autosensDataStore.bucketedData!!.size.toLong()) - - // bucketed data should return null if not enough bg data - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(30).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(null, autosensDataStore.bucketedData) - - // data should be reconstructed - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(50).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 90.0, timestamp = T.mins(45).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 40.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(T.mins(50).msecs(), autosensDataStore.bucketedData!![0].timestamp) - Assert.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![6].timestamp) - Assert.assertEquals(7, autosensDataStore.bucketedData!!.size.toLong()) - Assert.assertEquals(100.0, autosensDataStore.bucketedData!![0].value, 1.0) - Assert.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) - Assert.assertEquals(50.0, autosensDataStore.bucketedData!![5].value, 1.0) - Assert.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) - - // non 5min data should be reconstructed - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(50).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 96.0, timestamp = T.mins(48).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 40.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(T.mins(50).msecs(), autosensDataStore.bucketedData!![0].timestamp) - Assert.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![6].timestamp) - Assert.assertEquals(7, autosensDataStore.bucketedData!!.size.toLong()) - Assert.assertEquals(100.0, autosensDataStore.bucketedData!![0].value, 1.0) - Assert.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) - Assert.assertEquals(50.0, autosensDataStore.bucketedData!![5].value, 1.0) - Assert.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) - } - - @Test - fun createBucketedData5minTest2() { - val bgReadingList: MutableList = ArrayList() - - //bucketed data should be null if no bg data available - autosensDataStore.bgReadings = ArrayList() - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(null, autosensDataStore.bucketedData) - - // real data gap test - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T13:34:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T13:14:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T13:09:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T13:04:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:59:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:54:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:49:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:44:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:39:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:34:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:29:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:24:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:19:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:14:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:09:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T12:04:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T11:59:55Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T04:29:57Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T04:24:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T04:19:57Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T04:14:57Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T04:10:03Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T04:04:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T03:59:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T03:54:56Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T03:50:03Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-09-05T03:44:57Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - autosensDataStore.referenceTime = -1 - Assert.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(dateUtil.fromISODateString("2018-09-05T13:34:57Z"), autosensDataStore.bucketedData!![0].timestamp) - Assert.assertEquals(dateUtil.fromISODateString("2018-09-05T03:44:57Z"), autosensDataStore.bucketedData!![autosensDataStore.bucketedData!!.size - 1].timestamp) - - // 5min 4sec data - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T06:33:40Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T06:28:36Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T06:23:32Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T06:18:28Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T06:13:24Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T06:08:19Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T06:03:16Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:58:11Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:53:07Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:48:03Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:42:58Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:37:54Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:32:51Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:27:46Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:22:42Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:17:38Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:12:33Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:07:29Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T05:02:26Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T04:57:21Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = dateUtil.fromISODateString("2018-10-05T04:52:17Z"), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) - } - - @Test - fun bgReadingsTest() { - val bgReadingList: List = ArrayList() - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(bgReadingList, autosensDataStore.bgReadings) - } - - @Test - fun roundUpTimeTest() { - Assert.assertEquals(T.mins(3).msecs(), autosensDataStore.roundUpTime(T.secs(155).msecs())) - } - - @Test - fun findNewerTest() { - val bgReadingList: MutableList = ArrayList() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(15).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(T.mins(10).msecs(), autosensDataStore.findNewer(T.mins(8).msecs())!!.timestamp) - Assert.assertEquals(T.mins(5).msecs(), autosensDataStore.findNewer(T.mins(5).msecs())!!.timestamp) - Assert.assertEquals(T.mins(10).msecs(), autosensDataStore.findNewer(T.mins(10).msecs())!!.timestamp) - Assert.assertEquals(T.mins(20).msecs(), autosensDataStore.findNewer(T.mins(20).msecs())!!.timestamp) - Assert.assertEquals(null, autosensDataStore.findNewer(T.mins(22).msecs())) - } - - @Test - fun findOlderTest() { - val bgReadingList: MutableList = ArrayList() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(15).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - Assert.assertEquals(T.mins(5).msecs(), autosensDataStore.findOlder(T.mins(8).msecs())!!.timestamp) - Assert.assertEquals(T.mins(5).msecs(), autosensDataStore.findOlder(T.mins(5).msecs())!!.timestamp) - Assert.assertEquals(T.mins(10).msecs(), autosensDataStore.findOlder(T.mins(10).msecs())!!.timestamp) - Assert.assertEquals(T.mins(20).msecs(), autosensDataStore.findOlder(T.mins(20).msecs())!!.timestamp) - Assert.assertEquals(null, autosensDataStore.findOlder(T.mins(4).msecs())) - } - - @Test - fun findPreviousTimeFromBucketedDataTest() { - val bgReadingList: MutableList = ArrayList() - autosensDataStore.bgReadings = bgReadingList - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(null, autosensDataStore.findPreviousTimeFromBucketedData(1000)) - - // Super data should not be touched - bgReadingList.clear() - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(20).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(15).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(10).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - bgReadingList.add(GlucoseValue(raw = 0.0, noise = 0.0, value = 100.0, timestamp = T.mins(5).msecs(), sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) - autosensDataStore.bgReadings = bgReadingList - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assert.assertEquals(null, autosensDataStore.findPreviousTimeFromBucketedData(T.mins(4).msecs())) - Assert.assertEquals(T.mins(5).msecs(), autosensDataStore.findPreviousTimeFromBucketedData(T.mins(6).msecs())) - Assert.assertEquals(T.mins(20).msecs(), autosensDataStore.findPreviousTimeFromBucketedData(T.mins(20).msecs())) - Assert.assertEquals(T.mins(20).msecs(), autosensDataStore.findPreviousTimeFromBucketedData(T.mins(25).msecs())) - } -} \ No newline at end of file diff --git a/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt b/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt index 1ede1e97a9..cf5844835e 100644 --- a/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt +++ b/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt @@ -16,6 +16,7 @@ import info.nightscout.implementation.XDripBroadcastImpl import info.nightscout.implementation.androidNotification.NotificationHolderImpl import info.nightscout.implementation.constraints.ConstraintsImpl import info.nightscout.implementation.db.PersistenceLayerImpl +import info.nightscout.implementation.iob.GlucoseStatusProviderImpl import info.nightscout.implementation.logging.LoggerUtilsImpl import info.nightscout.implementation.overview.OverviewDataImpl import info.nightscout.implementation.plugin.PluginStore @@ -48,6 +49,7 @@ import info.nightscout.interfaces.Translator import info.nightscout.interfaces.XDripBroadcast import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.db.PersistenceLayer +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.logging.LoggerUtils import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.plugin.ActivePlugin @@ -124,5 +126,6 @@ abstract class ImplementationModule { @Binds fun bindsStorage(fileStorage: FileStorage): Storage @Binds fun bindsReceiverStatusStore(receiverStatusStoreImpl: ReceiverStatusStoreImpl): ReceiverStatusStore @Binds fun bindsUserEntryPresentationHelper(userEntryPresentationHelperImpl: UserEntryPresentationHelperImpl): UserEntryPresentationHelper + @Binds fun bindsGlucoseStatusProvider(glucoseStatusProviderImpl: GlucoseStatusProviderImpl): GlucoseStatusProvider } } \ No newline at end of file diff --git a/core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/GlucoseStatusProvider.kt b/implementation/src/main/java/info/nightscout/implementation/iob/GlucoseStatusProviderImpl.kt similarity index 93% rename from core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/GlucoseStatusProvider.kt rename to implementation/src/main/java/info/nightscout/implementation/iob/GlucoseStatusProviderImpl.kt index 37ba784d5d..881550c74f 100644 --- a/core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/GlucoseStatusProvider.kt +++ b/implementation/src/main/java/info/nightscout/implementation/iob/GlucoseStatusProviderImpl.kt @@ -1,10 +1,11 @@ -package info.nightscout.core.iob.iobCobCalculator +package info.nightscout.implementation.iob import dagger.Reusable import info.nightscout.androidaps.annotations.OpenForTesting import info.nightscout.core.iob.asRounded import info.nightscout.core.iob.log import info.nightscout.interfaces.iob.GlucoseStatus +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag @@ -14,16 +15,16 @@ import kotlin.math.roundToLong @Reusable @OpenForTesting -class GlucoseStatusProvider @Inject constructor( +class GlucoseStatusProviderImpl @Inject constructor( private val aapsLogger: AAPSLogger, private val iobCobCalculator: IobCobCalculator, private val dateUtil: DateUtil -) { +) : GlucoseStatusProvider { - val glucoseStatusData: GlucoseStatus? + override val glucoseStatusData: GlucoseStatus? get() = getGlucoseStatusData() - fun getGlucoseStatusData(allowOldData: Boolean = false): GlucoseStatus? { + override fun getGlucoseStatusData(allowOldData: Boolean): GlucoseStatus? { val data = iobCobCalculator.ads.getBgReadingsDataTableCopy() val sizeRecords = data.size if (sizeRecords == 0) { diff --git a/implementation/src/main/java/info/nightscout/implementation/profile/ProfileStoreObject.kt b/implementation/src/main/java/info/nightscout/implementation/profile/ProfileStoreObject.kt index 6eb1d28002..e431221327 100644 --- a/implementation/src/main/java/info/nightscout/implementation/profile/ProfileStoreObject.kt +++ b/implementation/src/main/java/info/nightscout/implementation/profile/ProfileStoreObject.kt @@ -54,7 +54,8 @@ class ProfileStoreObject(val injector: HasAndroidInjector, override val data: JS } override fun getDefaultProfile(): PureProfile? = getDefaultProfileName()?.let { getSpecificProfile(it) } - override fun getDefaultProfileJson(): JSONObject? = getDefaultProfileName()?.let { getSpecificProfileJson(it) } + override fun getDefaultProfileJson(): JSONObject? = + getDefaultProfileName()?.let { getSpecificProfileJson(it) } override fun getDefaultProfileName(): String? { val defaultProfileName = data.optString("defaultProfile") diff --git a/implementation/src/test/java/info/nightscout/androidaps/HardLimitsMock.kt b/implementation/src/test/java/info/nightscout/androidaps/HardLimitsMock.kt new file mode 100644 index 0000000000..288eaf084a --- /dev/null +++ b/implementation/src/test/java/info/nightscout/androidaps/HardLimitsMock.kt @@ -0,0 +1,83 @@ +package info.nightscout.androidaps + +import info.nightscout.interfaces.utils.HardLimits +import info.nightscout.shared.interfaces.ResourceHelper +import info.nightscout.shared.sharedPreferences.SP +import javax.inject.Inject +import kotlin.math.max +import kotlin.math.min + +class HardLimitsMock @Inject constructor( + private val sp: SP, + private val rh: ResourceHelper +) : HardLimits { + + companion object { + + private const val CHILD = 0 + private const val TEENAGE = 1 + private const val ADULT = 2 + private const val RESISTANT_ADULT = 3 + private const val PREGNANT = 4 + private val MAX_BOLUS = doubleArrayOf(5.0, 10.0, 17.0, 25.0, 60.0) + + // Very Hard Limits Ranges + // First value is the Lowest and second value is the Highest a Limit can define + val VERY_HARD_LIMIT_MIN_BG = doubleArrayOf(80.0, 180.0) + val VERY_HARD_LIMIT_MAX_BG = doubleArrayOf(90.0, 200.0) + val VERY_HARD_LIMIT_TARGET_BG = doubleArrayOf(80.0, 200.0) + + // Very Hard Limits Ranges for Temp Targets + val VERY_HARD_LIMIT_TEMP_MIN_BG = intArrayOf(72, 180) + val VERY_HARD_LIMIT_TEMP_MAX_BG = intArrayOf(72, 270) + val VERY_HARD_LIMIT_TEMP_TARGET_BG = intArrayOf(72, 200) + val MIN_DIA = doubleArrayOf(5.0, 5.0, 5.0, 5.0, 5.0) + val MAX_DIA = doubleArrayOf(9.0, 9.0, 9.0, 9.0, 10.0) + val MIN_IC = doubleArrayOf(2.0, 2.0, 2.0, 2.0, 0.3) + val MAX_IC = doubleArrayOf(100.0, 100.0, 100.0, 100.0, 100.0) + const val MIN_ISF = 2.0 // mgdl + const val MAX_ISF = 1000.0 // mgdl + val MAX_IOB_AMA = doubleArrayOf(3.0, 5.0, 7.0, 12.0, 25.0) + val MAX_IOB_SMB = doubleArrayOf(7.0, 13.0, 22.0, 30.0, 70.0) + val MAX_BASAL = doubleArrayOf(2.0, 5.0, 10.0, 12.0, 25.0) + + //LGS Hard limits + //No IOB at all + const val MAX_IOB_LGS = 0.0 + + } + + private fun loadAge(): Int = when (sp.getString(info.nightscout.core.utils.R.string.key_age, "")) { + rh.gs(info.nightscout.core.utils.R.string.key_child) -> CHILD + rh.gs(info.nightscout.core.utils.R.string.key_teenage) -> TEENAGE + rh.gs(info.nightscout.core.utils.R.string.key_adult) -> ADULT + rh.gs(info.nightscout.core.utils.R.string.key_resistantadult) -> RESISTANT_ADULT + rh.gs(info.nightscout.core.utils.R.string.key_pregnant) -> PREGNANT + else -> ADULT + } + + override fun maxBolus(): Double = MAX_BOLUS[loadAge()] + override fun maxIobAMA(): Double = MAX_IOB_AMA[loadAge()] + override fun maxIobSMB(): Double = MAX_IOB_SMB[loadAge()] + override fun maxBasal(): Double = MAX_BASAL[loadAge()] + override fun minDia(): Double = MIN_DIA[loadAge()] + override fun maxDia(): Double = MAX_DIA[loadAge()] + override fun minIC(): Double = MIN_IC[loadAge()] + override fun maxIC(): Double = MAX_IC[loadAge()] + + // safety checks + override fun checkHardLimits(value: Double, valueName: Int, lowLimit: Double, highLimit: Double): Boolean = + value == verifyHardLimits(value, valueName, lowLimit, highLimit) + + override fun isInRange(value: Double, lowLimit: Double, highLimit: Double): Boolean = + value in lowLimit..highLimit + + override fun verifyHardLimits(value: Double, valueName: Int, lowLimit: Double, highLimit: Double): Double { + var newValue = value + if (newValue < lowLimit || newValue > highLimit) { + newValue = max(newValue, lowLimit) + newValue = min(newValue, highLimit) + } + return newValue + } +} \ No newline at end of file diff --git a/implementation/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt b/implementation/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt index 194a53c0d4..fd1a936d76 100644 --- a/implementation/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt +++ b/implementation/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt @@ -14,8 +14,10 @@ import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.profile.ProfileStore +import info.nightscout.interfaces.utils.HardLimits import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper +import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil import org.json.JSONObject import org.junit.jupiter.api.BeforeEach @@ -37,25 +39,46 @@ open class TestBaseWithProfile : TestBase() { @Mock lateinit var profileFunction: ProfileFunction @Mock lateinit var config: Config @Mock lateinit var context: Context + @Mock lateinit var sp: SP + private lateinit var hardLimits: HardLimits lateinit var dateUtil: DateUtil val rxBus = RxBus(aapsSchedulers, aapsLogger) - val profileInjector = HasAndroidInjector { AndroidInjector { } } + val profileInjector = HasAndroidInjector { + AndroidInjector { + if (it is ProfileStoreObject) { + it.aapsLogger = aapsLogger + it.activePlugin = activePluginProvider + it.config = config + it.rh = rh + it.rxBus = rxBus + it.hardLimits = hardLimits + } + } + } private lateinit var validProfileJSON: String + private lateinit var invalidProfileJSON: String lateinit var validProfile: ProfileSealed.Pure lateinit var effectiveProfileSwitch: EffectiveProfileSwitch + lateinit var testPumpPlugin: TestPumpPlugin @Suppress("PropertyName") val TESTPROFILENAME = "someProfile" @BeforeEach fun prepareMock() { + invalidProfileJSON = "{\"dia\":\"1\",\"carbratio\":[{\"time\":\"00:00\",\"value\":\"30\"}],\"carbs_hr\":\"20\",\"delay\":\"20\",\"sens\":[{\"time\":\"00:00\",\"value\":\"3\"}," + + "{\"time\":\"2:00\",\"value\":\"3.4\"}],\"timezone\":\"UTC\",\"basal\":[{\"time\":\"00:00\",\"value\":\"1\"}],\"target_low\":[{\"time\":\"00:00\",\"value\":\"4.5\"}]," + + "\"target_high\":[{\"time\":\"00:00\",\"value\":\"7\"}],\"startDate\":\"1970-01-01T00:00:00.000Z\",\"units\":\"mmol\"}" validProfileJSON = "{\"dia\":\"5\",\"carbratio\":[{\"time\":\"00:00\",\"value\":\"30\"}],\"carbs_hr\":\"20\",\"delay\":\"20\",\"sens\":[{\"time\":\"00:00\",\"value\":\"3\"}," + "{\"time\":\"2:00\",\"value\":\"3.4\"}],\"timezone\":\"UTC\",\"basal\":[{\"time\":\"00:00\",\"value\":\"1\"}],\"target_low\":[{\"time\":\"00:00\",\"value\":\"4.5\"}]," + "\"target_high\":[{\"time\":\"00:00\",\"value\":\"7\"}],\"startDate\":\"1970-01-01T00:00:00.000Z\",\"units\":\"mmol\"}" + testPumpPlugin = TestPumpPlugin(profileInjector) + `when`(activePluginProvider.activePump).thenReturn(testPumpPlugin) dateUtil = Mockito.spy(DateUtil(context)) `when`(dateUtil.now()).thenReturn(1656358822000) + hardLimits = HardLimitsMock(sp, rh) validProfile = ProfileSealed.Pure(pureProfileFromJson(JSONObject(validProfileJSON), dateUtil)!!) effectiveProfileSwitch = EffectiveProfileSwitch( timestamp = dateUtil.now(), @@ -175,4 +198,23 @@ open class TestBaseWithProfile : TestBase() { json.put("store", store) return ProfileStoreObject(profileInjector, json, dateUtil) } + + fun getInvalidProfileStore1(): ProfileStore { + val json = JSONObject() + val store = JSONObject() + store.put(TESTPROFILENAME, JSONObject(invalidProfileJSON)) + json.put("defaultProfile", TESTPROFILENAME) + json.put("store", store) + return ProfileStoreObject(profileInjector, json, dateUtil) + } + + fun getInvalidProfileStore2(): ProfileStore { + val json = JSONObject() + val store = JSONObject() + store.put(TESTPROFILENAME, JSONObject(validProfileJSON)) + store.put("invalid", JSONObject(invalidProfileJSON)) + json.put("defaultProfile", TESTPROFILENAME + "invalid") + json.put("store", store) + return ProfileStoreObject(profileInjector, json, dateUtil) + } } diff --git a/implementation/src/test/java/info/nightscout/androidaps/TestPumpPlugin.kt b/implementation/src/test/java/info/nightscout/androidaps/TestPumpPlugin.kt index b3cdd8a6f8..9c4cae2277 100644 --- a/implementation/src/test/java/info/nightscout/androidaps/TestPumpPlugin.kt +++ b/implementation/src/test/java/info/nightscout/androidaps/TestPumpPlugin.kt @@ -26,7 +26,7 @@ class TestPumpPlugin(val injector: HasAndroidInjector) : Pump { val lastData = 0L val baseBasal = 0.0 - override val pumpDescription = PumpDescription() + override var pumpDescription = PumpDescription() override fun isInitialized(): Boolean = true override fun isSuspended(): Boolean = false diff --git a/core/main/src/test/java/info/nightscout/androidaps/plugins/iob/iobCalculator/GlucoseStatusTest.kt b/implementation/src/test/java/info/nightscout/implementation/iob/GlucoseStatusTest.kt similarity index 64% rename from core/main/src/test/java/info/nightscout/androidaps/plugins/iob/iobCalculator/GlucoseStatusTest.kt rename to implementation/src/test/java/info/nightscout/implementation/iob/GlucoseStatusTest.kt index bf229f9cd2..bb823a51e3 100644 --- a/core/main/src/test/java/info/nightscout/androidaps/plugins/iob/iobCalculator/GlucoseStatusTest.kt +++ b/implementation/src/test/java/info/nightscout/implementation/iob/GlucoseStatusTest.kt @@ -1,8 +1,7 @@ -package info.nightscout.androidaps.plugins.iob.iobCalculator +package info.nightscout.implementation.iob import info.nightscout.androidaps.TestBase import info.nightscout.core.iob.asRounded -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.iob.log import info.nightscout.database.entities.GlucoseValue import info.nightscout.interfaces.aps.AutosensDataStore @@ -10,16 +9,15 @@ import info.nightscout.interfaces.iob.GlucoseStatus import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.shared.utils.DateUtil import info.nightscout.shared.utils.T -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock -import org.mockito.Mockito.`when` +import org.mockito.Mockito /** * Created by mike on 26.03.2018. */ -@Suppress("SpellCheckingInspection") class GlucoseStatusTest : TestBase() { @Mock lateinit var dateUtil: DateUtil @@ -28,85 +26,85 @@ class GlucoseStatusTest : TestBase() { @BeforeEach fun prepare() { - `when`(iobCobCalculatorPlugin.ads).thenReturn(autosensDataStore) + Mockito.`when`(iobCobCalculatorPlugin.ads).thenReturn(autosensDataStore) } @Test fun toStringShouldBeOverloaded() { val glucoseStatus = GlucoseStatus(glucose = 0.0, noise = 0.0, delta = 0.0, shortAvgDelta = 0.0, longAvgDelta = 0.0, date = 0) - Assert.assertEquals(true, glucoseStatus.log().contains("Delta")) + Assertions.assertEquals(true, glucoseStatus.log().contains("Delta")) } @Test fun roundTest() { val glucoseStatus = GlucoseStatus(glucose = 100.11111, noise = 0.0, delta = 0.0, shortAvgDelta = 0.0, longAvgDelta = 0.0, date = 0) - Assert.assertEquals(100.1, glucoseStatus.asRounded().glucose, 0.0001) + Assertions.assertEquals(100.1, glucoseStatus.asRounded().glucose, 0.0001) } @Test fun calculateValidGlucoseStatus() { - `when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateValidBgData()) - val glucoseStatus = GlucoseStatusProvider(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData!! - Assert.assertEquals(214.0, glucoseStatus.glucose, 0.001) - Assert.assertEquals(-2.0, glucoseStatus.delta, 0.001) - Assert.assertEquals(-2.5, glucoseStatus.shortAvgDelta, 0.001) // -2 -2.5 -3 deltas are relative to current value - Assert.assertEquals(-2.0, glucoseStatus.longAvgDelta, 0.001) // -2 -2 -2 -2 - Assert.assertEquals(1514766900000L, glucoseStatus.date) // latest date + Mockito.`when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateValidBgData()) + val glucoseStatus = GlucoseStatusProviderImpl(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData!! + Assertions.assertEquals(214.0, glucoseStatus.glucose, 0.001) + Assertions.assertEquals(-2.0, glucoseStatus.delta, 0.001) + Assertions.assertEquals(-2.5, glucoseStatus.shortAvgDelta, 0.001) // -2 -2.5 -3 deltas are relative to current value + Assertions.assertEquals(-2.0, glucoseStatus.longAvgDelta, 0.001) // -2 -2 -2 -2 + Assertions.assertEquals(1514766900000L, glucoseStatus.date) // latest date } @Test fun calculateMostRecentGlucoseStatus() { - `when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateMostRecentBgData()) - val glucoseStatus: GlucoseStatus = GlucoseStatusProvider(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData!! - Assert.assertEquals(215.0, glucoseStatus.glucose, 0.001) // (214+216) / 2 - Assert.assertEquals(-1.0, glucoseStatus.delta, 0.001) - Assert.assertEquals(-1.0, glucoseStatus.shortAvgDelta, 0.001) - Assert.assertEquals(0.0, glucoseStatus.longAvgDelta, 0.001) - Assert.assertEquals(1514766900000L, glucoseStatus.date) // latest date, even when averaging + Mockito.`when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateMostRecentBgData()) + val glucoseStatus: GlucoseStatus = GlucoseStatusProviderImpl(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData!! + Assertions.assertEquals(215.0, glucoseStatus.glucose, 0.001) // (214+216) / 2 + Assertions.assertEquals(-1.0, glucoseStatus.delta, 0.001) + Assertions.assertEquals(-1.0, glucoseStatus.shortAvgDelta, 0.001) + Assertions.assertEquals(0.0, glucoseStatus.longAvgDelta, 0.001) + Assertions.assertEquals(1514766900000L, glucoseStatus.date) // latest date, even when averaging } @Test fun oneRecordShouldProduceZeroDeltas() { - `when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateOneCurrentRecordBgData()) - val glucoseStatus: GlucoseStatus = GlucoseStatusProvider(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData!! - Assert.assertEquals(214.0, glucoseStatus.glucose, 0.001) - Assert.assertEquals(0.0, glucoseStatus.delta, 0.001) - Assert.assertEquals(0.0, glucoseStatus.shortAvgDelta, 0.001) // -2 -2.5 -3 deltas are relative to current value - Assert.assertEquals(0.0, glucoseStatus.longAvgDelta, 0.001) // -2 -2 -2 -2 - Assert.assertEquals(1514766900000L, glucoseStatus.date) // latest date + Mockito.`when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateOneCurrentRecordBgData()) + val glucoseStatus: GlucoseStatus = GlucoseStatusProviderImpl(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData!! + Assertions.assertEquals(214.0, glucoseStatus.glucose, 0.001) + Assertions.assertEquals(0.0, glucoseStatus.delta, 0.001) + Assertions.assertEquals(0.0, glucoseStatus.shortAvgDelta, 0.001) // -2 -2.5 -3 deltas are relative to current value + Assertions.assertEquals(0.0, glucoseStatus.longAvgDelta, 0.001) // -2 -2 -2 -2 + Assertions.assertEquals(1514766900000L, glucoseStatus.date) // latest date } @Test fun insufficientDataShouldReturnNull() { - `when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateInsufficientBgData()) - val glucoseStatus: GlucoseStatus? = GlucoseStatusProvider(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData - Assert.assertEquals(null, glucoseStatus) + Mockito.`when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateInsufficientBgData()) + val glucoseStatus: GlucoseStatus? = GlucoseStatusProviderImpl(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData + Assertions.assertEquals(null, glucoseStatus) } @Test fun oldDataShouldReturnNull() { - `when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateOldBgData()) - val glucoseStatus: GlucoseStatus? = GlucoseStatusProvider(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData - Assert.assertEquals(null, glucoseStatus) + Mockito.`when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateOldBgData()) + val glucoseStatus: GlucoseStatus? = GlucoseStatusProviderImpl(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData + Assertions.assertEquals(null, glucoseStatus) } @Test fun returnOldDataIfAllowed() { - `when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateOldBgData()) - val glucoseStatus: GlucoseStatus? = GlucoseStatusProvider(aapsLogger, iobCobCalculatorPlugin, dateUtil).getGlucoseStatusData(true) - Assert.assertNotEquals(null, glucoseStatus) + Mockito.`when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateOldBgData()) + val glucoseStatus: GlucoseStatus? = GlucoseStatusProviderImpl(aapsLogger, iobCobCalculatorPlugin, dateUtil).getGlucoseStatusData(true) + Assertions.assertNotEquals(null, glucoseStatus) } @Test fun averageShouldNotFailOnEmptyArray() { - Assert.assertEquals(0.0, GlucoseStatusProvider.average(ArrayList()), 0.001) + Assertions.assertEquals(0.0, GlucoseStatusProviderImpl.average(ArrayList()), 0.001) } @Test fun calculateGlucoseStatusForLibreTestBgData() { - `when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateLibreTestData()) - val glucoseStatus: GlucoseStatus = GlucoseStatusProvider(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData!! - Assert.assertEquals(100.0, glucoseStatus.glucose, 0.001) // - Assert.assertEquals(-10.0, glucoseStatus.delta, 0.001) - Assert.assertEquals(-10.0, glucoseStatus.shortAvgDelta, 0.001) - Assert.assertEquals(-10.0, glucoseStatus.longAvgDelta, 0.001) - Assert.assertEquals(1514766900000L, glucoseStatus.date) // latest date + Mockito.`when`(autosensDataStore.getBgReadingsDataTableCopy()).thenReturn(generateLibreTestData()) + val glucoseStatus: GlucoseStatus = GlucoseStatusProviderImpl(aapsLogger, iobCobCalculatorPlugin, dateUtil).glucoseStatusData!! + Assertions.assertEquals(100.0, glucoseStatus.glucose, 0.001) // + Assertions.assertEquals(-10.0, glucoseStatus.delta, 0.001) + Assertions.assertEquals(-10.0, glucoseStatus.shortAvgDelta, 0.001) + Assertions.assertEquals(-10.0, glucoseStatus.longAvgDelta, 0.001) + Assertions.assertEquals(1514766900000L, glucoseStatus.date) // latest date } @BeforeEach fun initMocking() { - `when`(dateUtil.now()).thenReturn(1514766900000L + T.mins(1).msecs()) - `when`(iobCobCalculatorPlugin.ads).thenReturn(autosensDataStore) + Mockito.`when`(dateUtil.now()).thenReturn(1514766900000L + T.mins(1).msecs()) + Mockito.`when`(iobCobCalculatorPlugin.ads).thenReturn(autosensDataStore) } // [{"mgdl":214,"mills":1521895773113,"device":"xDrip-DexcomG5","direction":"Flat","filtered":191040,"unfiltered":205024,"noise":1,"rssi":100},{"mgdl":219,"mills":1521896073352,"device":"xDrip-DexcomG5","direction":"Flat","filtered":200160,"unfiltered":209760,"noise":1,"rssi":100},{"mgdl":222,"mills":1521896372890,"device":"xDrip-DexcomG5","direction":"Flat","filtered":207360,"unfiltered":212512,"noise":1,"rssi":100},{"mgdl":220,"mills":1521896673062,"device":"xDrip-DexcomG5","direction":"Flat","filtered":211488,"unfiltered":210688,"noise":1,"rssi":100},{"mgdl":193,"mills":1521896972933,"device":"xDrip-DexcomG5","direction":"Flat","filtered":212384,"unfiltered":208960,"noise":1,"rssi":100},{"mgdl":181,"mills":1521897273336,"device":"xDrip-DexcomG5","direction":"SingleDown","filtered":210592,"unfiltered":204320,"noise":1,"rssi":100},{"mgdl":176,"mills":1521897572875,"device":"xDrip-DexcomG5","direction":"FortyFiveDown","filtered":206720,"unfiltered":197440,"noise":1,"rssi":100},{"mgdl":168,"mills":1521897872929,"device":"xDrip-DexcomG5","direction":"FortyFiveDown","filtered":201024,"unfiltered":187904,"noise":1,"rssi":100},{"mgdl":161,"mills":1521898172814,"device":"xDrip-DexcomG5","direction":"FortyFiveDown","filtered":193376,"unfiltered":178144,"noise":1,"rssi":100},{"mgdl":148,"mills":1521898472879,"device":"xDrip-DexcomG5","direction":"SingleDown","filtered":183264,"unfiltered":161216,"noise":1,"rssi":100},{"mgdl":139,"mills":1521898772862,"device":"xDrip-DexcomG5","direction":"FortyFiveDown","filtered":170784,"unfiltered":148928,"noise":1,"rssi":100},{"mgdl":132,"mills":1521899072896,"device":"xDrip-DexcomG5","direction":"FortyFiveDown","filtered":157248,"unfiltered":139552,"noise":1,"rssi":100},{"mgdl":125,"mills":1521899372834,"device":"xDrip-DexcomG5","direction":"FortyFiveDown","filtered":144416,"unfiltered":129616.00000000001,"noise":1,"rssi":100},{"mgdl":128,"mills":1521899973456,"device":"xDrip-DexcomG5","direction":"Flat","filtered":130240.00000000001,"unfiltered":133536,"noise":1,"rssi":100},{"mgdl":132,"mills":1521900573287,"device":"xDrip-DexcomG5","direction":"Flat","filtered":133504,"unfiltered":138720,"noise":1,"rssi":100},{"mgdl":127,"mills":1521900873711,"device":"xDrip-DexcomG5","direction":"Flat","filtered":136480,"unfiltered":132992,"noise":1,"rssi":100},{"mgdl":127,"mills":1521901180151,"device":"xDrip-DexcomG5","direction":"Flat","filtered":136896,"unfiltered":132128,"noise":1,"rssi":100},{"mgdl":125,"mills":1521901473582,"device":"xDrip-DexcomG5","direction":"Flat","filtered":134624,"unfiltered":129696,"noise":1,"rssi":100},{"mgdl":120,"mills":1521901773597,"device":"xDrip-DexcomG5","direction":"Flat","filtered":130704.00000000001,"unfiltered":123376,"noise":1,"rssi":100},{"mgdl":116,"mills":1521902075855,"device":"xDrip-DexcomG5","direction":"Flat","filtered":126272,"unfiltered":118448,"noise":1,"rssi":100}] @@ -154,13 +152,40 @@ class GlucoseStatusTest : TestBase() { // Now list.add(GlucoseValue(raw = 0.0, noise = 0.0, value = latestReading, timestamp = endTime, sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) // One minute ago - list.add(GlucoseValue(raw = 0.0, noise = 0.0, value = latestReading, timestamp = endTime - 1000 * 60 * 1, sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) + list.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = latestReading, + timestamp = endTime - 1000 * 60 * 1, + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) // Two minutes ago - list.add(GlucoseValue(raw = 0.0, noise = 0.0, value = latestReading, timestamp = endTime - 1000 * 60 * 2, sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) + list.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = latestReading, + timestamp = endTime - 1000 * 60 * 2, + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) // Three minutes and beyond at constant rate for (i in 3..49) - list.add(GlucoseValue(raw = 0.0, noise = 0.0, value = latestReading + i * 2, timestamp = endTime - 1000 * 60 * i, sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, trendArrow = GlucoseValue.TrendArrow.FLAT)) + list.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = latestReading + i * 2, + timestamp = endTime - 1000 * 60 * i, + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) return list } } \ No newline at end of file diff --git a/core/main/src/test/java/info/nightscout/androidaps/interfaces/ProfileStoreTest.kt b/implementation/src/test/java/info/nightscout/implementation/profile/ProfileStoreTest.kt similarity index 96% rename from core/main/src/test/java/info/nightscout/androidaps/interfaces/ProfileStoreTest.kt rename to implementation/src/test/java/info/nightscout/implementation/profile/ProfileStoreTest.kt index 678117dec1..241255ade2 100644 --- a/core/main/src/test/java/info/nightscout/androidaps/interfaces/ProfileStoreTest.kt +++ b/implementation/src/test/java/info/nightscout/implementation/profile/ProfileStoreTest.kt @@ -1,4 +1,4 @@ -package info.nightscout.androidaps.interfaces +package info.nightscout.implementation.profile import info.nightscout.androidaps.TestBaseWithProfile import info.nightscout.interfaces.profile.PureProfile diff --git a/implementation/src/test/java/info/nightscout/implementation/queue/CommandQueueImplementationTest.kt b/implementation/src/test/java/info/nightscout/implementation/queue/CommandQueueImplementationTest.kt index dd00e2975f..0df16d3d8d 100644 --- a/implementation/src/test/java/info/nightscout/implementation/queue/CommandQueueImplementationTest.kt +++ b/implementation/src/test/java/info/nightscout/implementation/queue/CommandQueueImplementationTest.kt @@ -37,7 +37,7 @@ import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil import io.reactivex.rxjava3.core.Single -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -51,7 +51,6 @@ class CommandQueueImplementationTest : TestBaseWithProfile() { @Mock lateinit var constraintChecker: Constraints @Mock lateinit var activePlugin: ActivePlugin - @Mock lateinit var sp: SP @Mock lateinit var powerManager: PowerManager @Mock lateinit var repository: AppRepository @Mock lateinit var uiInteraction: UiInteraction @@ -115,7 +114,6 @@ class CommandQueueImplementationTest : TestBaseWithProfile() { } private lateinit var commandQueue: CommandQueueImplementation - private lateinit var testPumpPlugin: TestPumpPlugin @BeforeEach fun prepare() { @@ -170,108 +168,108 @@ class CommandQueueImplementationTest : TestBaseWithProfile() { commandQueue.handler = handler // start with empty queue - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // add bolus command commandQueue.bolus(DetailedBolusInfo(), null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) commandQueue.waitForFinishedThread() Thread.sleep(1000) - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) } @Test fun doTests() { // start with empty queue - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // add bolus command commandQueue.bolus(DetailedBolusInfo(), null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) // add READSTATUS commandQueue.readStatus("anyString", null) - Assert.assertEquals(2, commandQueue.size()) + Assertions.assertEquals(2, commandQueue.size()) // adding another bolus should remove the first one (size still == 2) commandQueue.bolus(DetailedBolusInfo(), null) - Assert.assertEquals(2, commandQueue.size()) + Assertions.assertEquals(2, commandQueue.size()) // clear the queue should reset size commandQueue.clear() - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // add tempbasal commandQueue.tempBasalAbsolute(0.0, 30, true, validProfile, PumpSync.TemporaryBasalType.NORMAL, null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) // add tempbasal percent. it should replace previous TEMPBASAL commandQueue.tempBasalPercent(0, 30, true, validProfile, PumpSync.TemporaryBasalType.NORMAL, null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) // cancel tempbasal it should replace previous TEMPBASAL commandQueue.cancelTempBasal(false, null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) // add extended bolus commandQueue.extendedBolus(1.0, 30, null) - Assert.assertEquals(2, commandQueue.size()) + Assertions.assertEquals(2, commandQueue.size()) // add extended should remove previous extended setting commandQueue.extendedBolus(1.0, 30, null) - Assert.assertEquals(2, commandQueue.size()) + Assertions.assertEquals(2, commandQueue.size()) // cancel extended bolus should replace previous extended commandQueue.cancelExtended(null) - Assert.assertEquals(2, commandQueue.size()) + Assertions.assertEquals(2, commandQueue.size()) // add setProfile // TODO: this crash the test // commandQueue.setProfile(validProfile, null) - // Assert.assertEquals(3, commandQueue.size()) + // Assertions.assertEquals(3, commandQueue.size()) // add loadHistory commandQueue.loadHistory(0.toByte(), null) - Assert.assertEquals(3, commandQueue.size()) + Assertions.assertEquals(3, commandQueue.size()) // add loadEvents commandQueue.loadEvents(null) - Assert.assertEquals(4, commandQueue.size()) + Assertions.assertEquals(4, commandQueue.size()) commandQueue.clear() commandQueue.tempBasalAbsolute(0.0, 30, true, validProfile, PumpSync.TemporaryBasalType.NORMAL, null) commandQueue.pickup() - Assert.assertEquals(0, commandQueue.size()) - Assert.assertNotNull(commandQueue.performing) - Assert.assertEquals(Command.CommandType.TEMPBASAL, commandQueue.performing?.commandType) + Assertions.assertEquals(0, commandQueue.size()) + Assertions.assertNotNull(commandQueue.performing) + Assertions.assertEquals(Command.CommandType.TEMPBASAL, commandQueue.performing?.commandType) commandQueue.resetPerforming() - Assert.assertNull(commandQueue.performing) + Assertions.assertNull(commandQueue.performing) } @Test fun callingCancelAllBolusesClearsQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) val smb = DetailedBolusInfo() smb.lastKnownBolusTime = System.currentTimeMillis() smb.bolusType = DetailedBolusInfo.BolusType.SMB commandQueue.bolus(smb, null) commandQueue.bolus(DetailedBolusInfo(), null) - Assert.assertEquals(2, commandQueue.size()) + Assertions.assertEquals(2, commandQueue.size()) // when commandQueue.cancelAllBoluses(null) // then - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) } @Test fun smbIsRejectedIfABolusIsQueued() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when commandQueue.bolus(DetailedBolusInfo(), null) @@ -280,14 +278,14 @@ class CommandQueueImplementationTest : TestBaseWithProfile() { val queued: Boolean = commandQueue.bolus(smb, null) // then - Assert.assertFalse(queued) - Assert.assertEquals(commandQueue.size(), 1) + Assertions.assertFalse(queued) + Assertions.assertEquals(commandQueue.size(), 1) } @Test fun smbIsRejectedIfLastKnownBolusIsOutdated() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when val bolus = DetailedBolusInfo() @@ -296,14 +294,14 @@ class CommandQueueImplementationTest : TestBaseWithProfile() { val queued: Boolean = commandQueue.bolus(bolus, null) // then - Assert.assertFalse(queued) - Assert.assertEquals(commandQueue.size(), 0) + Assertions.assertFalse(queued) + Assertions.assertEquals(commandQueue.size(), 0) } @Test fun isCustomCommandRunning() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when val queued1 = commandQueue.customCommand(CustomCommand1(), null) @@ -311,201 +309,201 @@ class CommandQueueImplementationTest : TestBaseWithProfile() { commandQueue.pickup() // then - Assert.assertTrue(queued1) - Assert.assertTrue(queued2) - Assert.assertTrue(commandQueue.isCustomCommandInQueue(CustomCommand1::class.java)) - Assert.assertTrue(commandQueue.isCustomCommandInQueue(CustomCommand2::class.java)) - Assert.assertFalse(commandQueue.isCustomCommandInQueue(CustomCommand3::class.java)) + Assertions.assertTrue(queued1) + Assertions.assertTrue(queued2) + Assertions.assertTrue(commandQueue.isCustomCommandInQueue(CustomCommand1::class.java)) + Assertions.assertTrue(commandQueue.isCustomCommandInQueue(CustomCommand2::class.java)) + Assertions.assertFalse(commandQueue.isCustomCommandInQueue(CustomCommand3::class.java)) - Assert.assertTrue(commandQueue.isCustomCommandRunning(CustomCommand1::class.java)) - Assert.assertFalse(commandQueue.isCustomCommandRunning(CustomCommand2::class.java)) - Assert.assertFalse(commandQueue.isCustomCommandRunning(CustomCommand3::class.java)) + Assertions.assertTrue(commandQueue.isCustomCommandRunning(CustomCommand1::class.java)) + Assertions.assertFalse(commandQueue.isCustomCommandRunning(CustomCommand2::class.java)) + Assertions.assertFalse(commandQueue.isCustomCommandRunning(CustomCommand3::class.java)) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun isSetUserOptionsCommandInQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when commandQueue.setUserOptions(null) // then - Assert.assertTrue(commandQueue.isLastScheduled(Command.CommandType.SET_USER_SETTINGS)) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertTrue(commandQueue.isLastScheduled(Command.CommandType.SET_USER_SETTINGS)) + Assertions.assertEquals(1, commandQueue.size()) // next should be ignored commandQueue.setUserOptions(null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun isLoadEventsCommandInQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when commandQueue.loadEvents(null) // then - Assert.assertTrue(commandQueue.isLastScheduled(Command.CommandType.LOAD_EVENTS)) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertTrue(commandQueue.isLastScheduled(Command.CommandType.LOAD_EVENTS)) + Assertions.assertEquals(1, commandQueue.size()) // next should be ignored commandQueue.loadEvents(null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun isLoadTDDsCommandInQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when commandQueue.loadTDDs(null) // then - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) // next should be ignored commandQueue.loadTDDs(null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun isLoadHistoryCommandInQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when commandQueue.loadHistory(0, null) // then - Assert.assertTrue(commandQueue.isLastScheduled(Command.CommandType.LOAD_HISTORY)) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertTrue(commandQueue.isLastScheduled(Command.CommandType.LOAD_HISTORY)) + Assertions.assertEquals(1, commandQueue.size()) // next should be ignored commandQueue.loadHistory(0, null) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun isProfileSetCommandInQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when testPumpPlugin.isProfileSet = true commandQueue.setProfile(validProfile, false, object : Callback() { override fun run() { - Assert.assertTrue(result.success) - Assert.assertFalse(result.enacted) + Assertions.assertTrue(result.success) + Assertions.assertFalse(result.enacted) } }) // then // the same profile -> ignore - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // different should be added testPumpPlugin.isProfileSet = false commandQueue.setProfile(validProfile, false, object : Callback() { override fun run() { - Assert.assertTrue(result.success) - Assert.assertTrue(result.enacted) + Assertions.assertTrue(result.success) + Assertions.assertTrue(result.enacted) } }) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) // next should be ignored commandQueue.setProfile(validProfile, false, object : Callback() { override fun run() { - Assert.assertTrue(result.success) + Assertions.assertTrue(result.success) } }) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertEquals(1, commandQueue.size()) testPumpPlugin.isProfileSet = true } @Test fun isStopCommandInQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when commandQueue.stopPump(null) // then - Assert.assertTrue(commandQueue.isLastScheduled(Command.CommandType.STOP_PUMP)) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertTrue(commandQueue.isLastScheduled(Command.CommandType.STOP_PUMP)) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun isStarCommandInQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when commandQueue.startPump(null) // then - Assert.assertTrue(commandQueue.isLastScheduled(Command.CommandType.START_PUMP)) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertTrue(commandQueue.isLastScheduled(Command.CommandType.START_PUMP)) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun isSetTbrNotificationCommandInQueue() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when commandQueue.setTBROverNotification(null, true) // then - Assert.assertTrue(commandQueue.isLastScheduled(Command.CommandType.INSIGHT_SET_TBR_OVER_ALARM)) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertTrue(commandQueue.isLastScheduled(Command.CommandType.INSIGHT_SET_TBR_OVER_ALARM)) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun differentCustomCommandsAllowed() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when val queued1 = commandQueue.customCommand(CustomCommand1(), null) val queued2 = commandQueue.customCommand(CustomCommand2(), null) // then - Assert.assertTrue(queued1) - Assert.assertTrue(queued2) - Assert.assertEquals(2, commandQueue.size()) + Assertions.assertTrue(queued1) + Assertions.assertTrue(queued2) + Assertions.assertEquals(2, commandQueue.size()) } @Test fun sameCustomCommandNotAllowed() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when val queued1 = commandQueue.customCommand(CustomCommand1(), null) val queued2 = commandQueue.customCommand(CustomCommand1(), null) // then - Assert.assertTrue(queued1) - Assert.assertFalse(queued2) - Assert.assertEquals(1, commandQueue.size()) + Assertions.assertTrue(queued1) + Assertions.assertFalse(queued2) + Assertions.assertEquals(1, commandQueue.size()) } @Test fun readStatusTwiceIsNotAllowed() { // given - Assert.assertEquals(0, commandQueue.size()) + Assertions.assertEquals(0, commandQueue.size()) // when val queued1 = commandQueue.readStatus("1", null) val queued2 = commandQueue.readStatus("2", null) // then - Assert.assertTrue(queued1) - Assert.assertFalse(queued2) - Assert.assertEquals(1, commandQueue.size()) - Assert.assertTrue(commandQueue.statusInQueue()) + Assertions.assertTrue(queued1) + Assertions.assertFalse(queued2) + Assertions.assertEquals(1, commandQueue.size()) + Assertions.assertTrue(commandQueue.statusInQueue()) } private class CustomCommand1 : CustomCommand { diff --git a/implementation/src/test/java/info/nightscout/implementation/queue/QueueThreadTest.kt b/implementation/src/test/java/info/nightscout/implementation/queue/QueueThreadTest.kt index e8a3ee2952..63da7bcedd 100644 --- a/implementation/src/test/java/info/nightscout/implementation/queue/QueueThreadTest.kt +++ b/implementation/src/test/java/info/nightscout/implementation/queue/QueueThreadTest.kt @@ -17,7 +17,6 @@ import info.nightscout.interfaces.pump.PumpSync import info.nightscout.interfaces.pump.defs.PumpDescription import info.nightscout.interfaces.queue.Command import info.nightscout.interfaces.ui.UiInteraction -import info.nightscout.shared.sharedPreferences.SP import org.junit.Assert import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test @@ -29,7 +28,6 @@ class QueueThreadTest : TestBaseWithProfile() { @Mock lateinit var constraintChecker: Constraints @Mock lateinit var activePlugin: ActivePlugin - @Mock lateinit var sp: SP @Mock lateinit var powerManager: PowerManager @Mock lateinit var repository: AppRepository @Mock lateinit var androidPermission: AndroidPermission diff --git a/core/main/src/test/java/info/nightscout/core/wizard/BolusWizardTest.kt b/implementation/src/test/java/info/nightscout/implementation/wizard/BolusWizardTest.kt similarity index 83% rename from core/main/src/test/java/info/nightscout/core/wizard/BolusWizardTest.kt rename to implementation/src/test/java/info/nightscout/implementation/wizard/BolusWizardTest.kt index 37f0f3e5eb..caa826177d 100644 --- a/core/main/src/test/java/info/nightscout/core/wizard/BolusWizardTest.kt +++ b/implementation/src/test/java/info/nightscout/implementation/wizard/BolusWizardTest.kt @@ -1,11 +1,12 @@ -package info.nightscout.core.wizard +package info.nightscout.implementation.wizard import android.content.Context import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBase import info.nightscout.androidaps.TestPumpPlugin -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider +import info.nightscout.core.wizard.BolusWizard +import info.nightscout.implementation.iob.GlucoseStatusProviderImpl import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.aps.AutosensDataStore import info.nightscout.interfaces.aps.Loop @@ -25,7 +26,6 @@ import org.junit.Assert import org.junit.jupiter.api.Test import org.mockito.Mock import org.mockito.Mockito -import org.mockito.Mockito.`when` import org.mockito.invocation.InvocationOnMock class BolusWizardTest : TestBase() { @@ -56,7 +56,7 @@ class BolusWizardTest : TestBase() { it.loop = loop it.dateUtil = dateUtil it.iobCobCalculator = iobCobCalculator - it.glucoseStatusProvider = GlucoseStatusProvider(aapsLogger = aapsLogger, iobCobCalculator = iobCobCalculator, dateUtil = dateUtil) + it.glucoseStatusProvider = GlucoseStatusProviderImpl(aapsLogger = aapsLogger, iobCobCalculator = iobCobCalculator, dateUtil = dateUtil) } } } @@ -66,19 +66,19 @@ class BolusWizardTest : TestBase() { @Suppress("SameParameterValue") private fun setupProfile(targetLow: Double, targetHigh: Double, insulinSensitivityFactor: Double, insulinToCarbRatio: Double): Profile { val profile = Mockito.mock(Profile::class.java) - `when`(profile.getTargetLowMgdl()).thenReturn(targetLow) - `when`(profile.getTargetLowMgdl()).thenReturn(targetHigh) - `when`(profile.getIsfMgdl()).thenReturn(insulinSensitivityFactor) - `when`(profile.getIc()).thenReturn(insulinToCarbRatio) + Mockito.`when`(profile.getTargetLowMgdl()).thenReturn(targetLow) + Mockito.`when`(profile.getTargetLowMgdl()).thenReturn(targetHigh) + Mockito.`when`(profile.getIsfMgdl()).thenReturn(insulinSensitivityFactor) + Mockito.`when`(profile.getIc()).thenReturn(insulinToCarbRatio) - `when`(profileFunction.getUnits()).thenReturn(GlucoseUnit.MGDL) - `when`(iobCobCalculator.calculateIobFromBolus()).thenReturn(IobTotal(System.currentTimeMillis())) - `when`(iobCobCalculator.calculateIobFromTempBasalsIncludingConvertedExtended()).thenReturn(IobTotal(System.currentTimeMillis())) - `when`(activePlugin.activePump).thenReturn(testPumpPlugin) + Mockito.`when`(profileFunction.getUnits()).thenReturn(GlucoseUnit.MGDL) + Mockito.`when`(iobCobCalculator.calculateIobFromBolus()).thenReturn(IobTotal(System.currentTimeMillis())) + Mockito.`when`(iobCobCalculator.calculateIobFromTempBasalsIncludingConvertedExtended()).thenReturn(IobTotal(System.currentTimeMillis())) + Mockito.`when`(activePlugin.activePump).thenReturn(testPumpPlugin) testPumpPlugin.pumpDescription = PumpDescription().also { it.bolusStep = pumpBolusStep } - `when`(iobCobCalculator.ads).thenReturn(autosensDataStore) + Mockito.`when`(iobCobCalculator.ads).thenReturn(autosensDataStore) Mockito.doAnswer { invocation: InvocationOnMock -> invocation.getArgument>(0) diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/OpenAPSAMAPlugin.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/OpenAPSAMAPlugin.kt index c76ee7d1ae..9e8ba9502c 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/OpenAPSAMAPlugin.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/OpenAPSAMAPlugin.kt @@ -4,7 +4,6 @@ import android.content.Context import dagger.android.HasAndroidInjector import info.nightscout.androidaps.annotations.OpenForTesting import info.nightscout.core.extensions.target -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.utils.MidnightUtils import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.database.ValueWrapper @@ -14,6 +13,7 @@ import info.nightscout.interfaces.aps.AutosensResult import info.nightscout.interfaces.aps.DetermineBasalAdapter import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/OpenAPSSMBPlugin.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/OpenAPSSMBPlugin.kt index 861a0c7272..5364a88101 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/OpenAPSSMBPlugin.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/OpenAPSSMBPlugin.kt @@ -6,7 +6,6 @@ import androidx.preference.SwitchPreference import dagger.android.HasAndroidInjector import info.nightscout.androidaps.annotations.OpenForTesting import info.nightscout.core.extensions.target -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.utils.MidnightUtils import info.nightscout.database.ValueWrapper import info.nightscout.database.impl.AppRepository @@ -17,6 +16,7 @@ import info.nightscout.interfaces.aps.SMBDefaults import info.nightscout.interfaces.bgQualityCheck.BgQualityCheck import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMBDynamicISF/OpenAPSSMBDynamicISFPlugin.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMBDynamicISF/OpenAPSSMBDynamicISFPlugin.kt index fc9b4207ee..bc004da0ff 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMBDynamicISF/OpenAPSSMBDynamicISFPlugin.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMBDynamicISF/OpenAPSSMBDynamicISFPlugin.kt @@ -3,12 +3,12 @@ package info.nightscout.plugins.aps.openAPSSMBDynamicISF import android.content.Context import dagger.android.HasAndroidInjector import info.nightscout.androidaps.annotations.OpenForTesting -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.database.impl.AppRepository import info.nightscout.interfaces.Config import info.nightscout.interfaces.aps.DetermineBasalAdapter import info.nightscout.interfaces.bgQualityCheck.BgQualityCheck import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.ProfileFunction diff --git a/plugins/automation/build.gradle b/plugins/automation/build.gradle index dd0a4967b8..304374ca9c 100644 --- a/plugins/automation/build.gradle +++ b/plugins/automation/build.gradle @@ -27,6 +27,8 @@ dependencies { implementation project(':app-wear-shared:shared') implementation project(':core:interfaces') + testImplementation project(':implementation') + api "androidx.constraintlayout:constraintlayout:$constraintlayout_version" api "com.google.android.gms:play-services-location:$play_services_location_version" } \ No newline at end of file diff --git a/plugins/automation/src/main/java/info/nightscout/automation/actions/ActionCarePortalEvent.kt b/plugins/automation/src/main/java/info/nightscout/automation/actions/ActionCarePortalEvent.kt index 61f2987167..2bcd2b2e0e 100644 --- a/plugins/automation/src/main/java/info/nightscout/automation/actions/ActionCarePortalEvent.kt +++ b/plugins/automation/src/main/java/info/nightscout/automation/actions/ActionCarePortalEvent.kt @@ -9,12 +9,12 @@ import info.nightscout.automation.elements.InputString import info.nightscout.automation.elements.LabelWithElement import info.nightscout.automation.elements.LayoutBuilder import info.nightscout.core.extensions.fromConstant -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.database.entities.TherapyEvent import info.nightscout.database.entities.UserEntry import info.nightscout.database.entities.ValueWithUnit import info.nightscout.database.impl.AppRepository import info.nightscout.database.impl.transactions.InsertIfNewByTimestampTherapyEventTransaction +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.queue.Callback diff --git a/plugins/automation/src/main/java/info/nightscout/automation/triggers/Trigger.kt b/plugins/automation/src/main/java/info/nightscout/automation/triggers/Trigger.kt index e3dbef231f..b12b24be5e 100644 --- a/plugins/automation/src/main/java/info/nightscout/automation/triggers/Trigger.kt +++ b/plugins/automation/src/main/java/info/nightscout/automation/triggers/Trigger.kt @@ -15,8 +15,8 @@ import info.nightscout.automation.events.EventTriggerChanged import info.nightscout.automation.events.EventTriggerClone import info.nightscout.automation.events.EventTriggerRemove import info.nightscout.automation.services.LastLocationDataContainer -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.database.impl.AppRepository +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.ProfileFunction diff --git a/plugins/automation/src/test/java/info/nightscout/automation/triggers/TriggerTestBase.kt b/plugins/automation/src/test/java/info/nightscout/automation/triggers/TriggerTestBase.kt index 9141d549fc..6f6981409d 100644 --- a/plugins/automation/src/test/java/info/nightscout/automation/triggers/TriggerTestBase.kt +++ b/plugins/automation/src/test/java/info/nightscout/automation/triggers/TriggerTestBase.kt @@ -7,7 +7,7 @@ import info.nightscout.androidaps.TestBaseWithProfile import info.nightscout.androidaps.TestPumpPlugin import info.nightscout.automation.AutomationPlugin import info.nightscout.automation.services.LastLocationDataContainer -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider +import info.nightscout.implementation.iob.GlucoseStatusProviderImpl import info.nightscout.interfaces.aps.AutosensDataStore import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin @@ -51,7 +51,7 @@ open class TriggerTestBase : TestBaseWithProfile() { it.repository = repository it.activePlugin = activePlugin it.iobCobCalculator = iobCobCalculator - it.glucoseStatusProvider = GlucoseStatusProvider(aapsLogger, iobCobCalculator, dateUtil) + it.glucoseStatusProvider = GlucoseStatusProviderImpl(aapsLogger, iobCobCalculator, dateUtil) it.dateUtil = dateUtil } if (it is TriggerBg) { diff --git a/plugins/main/build.gradle b/plugins/main/build.gradle index 910e5916cf..9d87109946 100644 --- a/plugins/main/build.gradle +++ b/plugins/main/build.gradle @@ -28,6 +28,8 @@ dependencies { implementation project(':core:utils') implementation project(':core:validators') + testImplementation project(':implementation') + api "androidx.appcompat:appcompat:$appcompat_version" api "com.google.android.material:material:$material_version" diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/dataBroadcaster/DataBroadcastPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/dataBroadcaster/DataBroadcastPlugin.kt index 2c55dbc982..5341b0dbe3 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/dataBroadcaster/DataBroadcastPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/dataBroadcaster/DataBroadcastPlugin.kt @@ -7,13 +7,13 @@ import android.os.Bundle import dagger.android.HasAndroidInjector import info.nightscout.core.extensions.durationInMinutes import info.nightscout.core.extensions.toStringFull -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.iob.round import info.nightscout.core.utils.fabric.FabricPrivacy -import info.nightscout.interfaces.receivers.ReceiverStatusStore import info.nightscout.interfaces.Config import info.nightscout.interfaces.aps.Loop +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator +import info.nightscout.interfaces.nsclient.ProcessedDeviceStatusData import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription @@ -21,8 +21,8 @@ import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.profile.DefaultValueHelper import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.receivers.Intents +import info.nightscout.interfaces.receivers.ReceiverStatusStore import info.nightscout.plugins.R -import info.nightscout.interfaces.nsclient.ProcessedDeviceStatusData import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.Event diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt index 24a2f75281..b8da15234c 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt @@ -31,7 +31,6 @@ import info.nightscout.core.extensions.directionToIcon import info.nightscout.core.extensions.valueToUnitsString import info.nightscout.core.graph.OverviewData import info.nightscout.core.iob.displayText -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.profile.ProfileSealed import info.nightscout.core.ui.UIRunnable import info.nightscout.core.ui.dialogs.OKDialog @@ -52,6 +51,7 @@ import info.nightscout.interfaces.automation.Automation import info.nightscout.interfaces.bgQualityCheck.BgQualityCheck import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.nsclient.NSSettingsStatus diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/persistentNotification/PersistentNotificationPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/persistentNotification/PersistentNotificationPlugin.kt index 8ef2653ebe..4bd40cecee 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/persistentNotification/PersistentNotificationPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/persistentNotification/PersistentNotificationPlugin.kt @@ -10,11 +10,11 @@ import dagger.android.HasAndroidInjector import info.nightscout.core.extensions.toStringShort import info.nightscout.core.extensions.valueToUnitsString import info.nightscout.core.iob.generateCOBString -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.iob.round import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.interfaces.Constants import info.nightscout.interfaces.NotificationHolder +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/smsCommunicator/AuthRequest.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/smsCommunicator/AuthRequest.kt index daa2c085e9..31f8232882 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/smsCommunicator/AuthRequest.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/smsCommunicator/AuthRequest.kt @@ -16,7 +16,7 @@ import info.nightscout.shared.utils.DateUtil import info.nightscout.shared.utils.T import javax.inject.Inject -class AuthRequest internal constructor( +class AuthRequest( injector: HasAndroidInjector, var requester: Sms, requestText: String, diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/smsCommunicator/SmsCommunicatorPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/smsCommunicator/SmsCommunicatorPlugin.kt index 21ff73ca69..f9cf0d41a2 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/smsCommunicator/SmsCommunicatorPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/smsCommunicator/SmsCommunicatorPlugin.kt @@ -14,7 +14,6 @@ import info.nightscout.androidaps.annotations.OpenForTesting import info.nightscout.core.events.EventNewNotification import info.nightscout.core.extensions.valueToUnitsString import info.nightscout.core.iob.generateCOBString -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.iob.round import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.core.utils.receivers.DataWorkerStorage @@ -37,6 +36,7 @@ import info.nightscout.interfaces.XDripBroadcast import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.notifications.Notification diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/wear/wearintegration/DataHandlerMobile.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/wear/wearintegration/DataHandlerMobile.kt index 848c519933..8efbf91571 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/wear/wearintegration/DataHandlerMobile.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/wear/wearintegration/DataHandlerMobile.kt @@ -9,7 +9,6 @@ import info.nightscout.core.extensions.valueToUnits import info.nightscout.core.extensions.valueToUnitsString import info.nightscout.core.graph.data.GlucoseValueDataPoint import info.nightscout.core.iob.generateCOBString -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.iob.round import info.nightscout.core.ui.toast.ToastUtils import info.nightscout.core.utils.fabric.FabricPrivacy @@ -34,6 +33,7 @@ import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.nsclient.ProcessedDeviceStatusData diff --git a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt index 83bef9ea1e..2890d9b828 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt @@ -10,7 +10,6 @@ import info.nightscout.core.graph.OverviewData import info.nightscout.core.iob.combine import info.nightscout.core.iob.copy import info.nightscout.core.iob.determineBasalJson -import info.nightscout.core.iob.iobCobCalculator.AutosensDataStoreObject import info.nightscout.core.iob.plus import info.nightscout.core.iob.round import info.nightscout.core.utils.fabric.FabricPrivacy @@ -39,6 +38,7 @@ import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.utils.DecimalFormatter import info.nightscout.interfaces.utils.MidnightTime import info.nightscout.plugins.R +import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataStoreObject import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.Event diff --git a/core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/AutosensDataStoreObject.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt similarity index 99% rename from core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/AutosensDataStoreObject.kt rename to plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt index d2bf135416..ebf1fae6b9 100644 --- a/core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/AutosensDataStoreObject.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt @@ -1,4 +1,4 @@ -package info.nightscout.core.iob.iobCobCalculator +package info.nightscout.plugins.iob.iobCobCalculator.data import androidx.collection.LongSparseArray import androidx.collection.size @@ -310,7 +310,9 @@ class AutosensDataStoreObject : AutosensDataStore { val previous = bData[i + 1] val mSecDiff = current.timestamp - previous.timestamp val adjusted = (mSecDiff - T.mins(5).msecs()) / 1000 - aapsLogger.debug(LTag.AUTOSENS) { "Adjusting bucketed data time. Current: ${dateUtil.dateAndTimeAndSecondsString(current.timestamp)} to: ${dateUtil.dateAndTimeAndSecondsString(previous.timestamp + T.mins(5).msecs())} by $adjusted sec" } + aapsLogger.debug(LTag.AUTOSENS) { "Adjusting bucketed data time. Current: ${dateUtil.dateAndTimeAndSecondsString(current.timestamp)} to: ${dateUtil.dateAndTimeAndSecondsString(previous.timestamp + T.mins( + 5 + ).msecs())} by $adjusted sec" } if (abs(adjusted) > 90) { // too big adjustment, fallback to non 5 min data aapsLogger.debug(LTag.AUTOSENS, "Fallback to non 5 min data") @@ -337,4 +339,4 @@ class AutosensDataStoreObject : AutosensDataStore { } return if (count != 0) sum / count else 0.0 } -} +} \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/general/smsCommunicator/SmsCommunicatorPluginTest.kt b/plugins/main/src/test/java/info/nightscout/plugins/general/smsCommunicator/SmsCommunicatorPluginTest.kt index 5717d0b9eb..f61e28ef2f 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/general/smsCommunicator/SmsCommunicatorPluginTest.kt +++ b/plugins/main/src/test/java/info/nightscout/plugins/general/smsCommunicator/SmsCommunicatorPluginTest.kt @@ -5,13 +5,13 @@ import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBaseWithProfile import info.nightscout.androidaps.TestPumpPlugin -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.database.entities.GlucoseValue import info.nightscout.database.impl.AppRepository import info.nightscout.database.impl.transactions.CancelCurrentOfflineEventIfAnyTransaction import info.nightscout.database.impl.transactions.InsertAndCancelCurrentOfflineEventTransaction import info.nightscout.database.impl.transactions.InsertAndCancelCurrentTemporaryTargetTransaction import info.nightscout.database.impl.transactions.Transaction +import info.nightscout.implementation.iob.GlucoseStatusProviderImpl import info.nightscout.interfaces.Constants import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.XDripBroadcast @@ -38,11 +38,10 @@ import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil import info.nightscout.shared.utils.T import io.reactivex.rxjava3.core.Single -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.ArgumentMatchers -import org.mockito.ArgumentMatchers.anyString import org.mockito.ArgumentMatchers.eq import org.mockito.Mock import org.mockito.Mockito @@ -102,7 +101,7 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { repository.runTransactionForResult(anyObject()) ).thenReturn(Single.just(InsertAndCancelCurrentTemporaryTargetTransaction.TransactionResult().apply { })) - val glucoseStatusProvider = GlucoseStatusProvider(aapsLogger = aapsLogger, iobCobCalculator = iobCobCalculator, dateUtil = dateUtilMocked) + val glucoseStatusProvider = GlucoseStatusProviderImpl(aapsLogger = aapsLogger, iobCobCalculator = iobCobCalculator, dateUtil = dateUtilMocked) smsCommunicatorPlugin = SmsCommunicatorPlugin( injector, aapsLogger, rh, smsManager, aapsSchedulers, sp, constraintChecker, rxBus, profileFunction, fabricPrivacy, activePlugin, commandQueue, @@ -171,7 +170,7 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { `when`(profileFunction.getUnits()).thenReturn(GlucoseUnit.MGDL) `when`(otp.name()).thenReturn("User") - `when`(otp.checkOTP(anyString())).thenReturn(OneTimePasswordValidationResult.OK) + `when`(otp.checkOTP(ArgumentMatchers.anyString())).thenReturn(OneTimePasswordValidationResult.OK) `when`(rh.gs(R.string.smscommunicator_remote_command_not_allowed)).thenReturn("Remote command is not allowed") `when`(rh.gs(R.string.sms_wrong_code)).thenReturn("Wrong code. Command cancelled.") @@ -255,27 +254,27 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { @Test fun processSettingsTest() { // called from constructor - Assert.assertEquals("1234", smsCommunicatorPlugin.allowedNumbers[0]) - Assert.assertEquals("5678", smsCommunicatorPlugin.allowedNumbers[1]) - Assert.assertEquals(2, smsCommunicatorPlugin.allowedNumbers.size) + Assertions.assertEquals("1234", smsCommunicatorPlugin.allowedNumbers[0]) + Assertions.assertEquals("5678", smsCommunicatorPlugin.allowedNumbers[1]) + Assertions.assertEquals(2, smsCommunicatorPlugin.allowedNumbers.size) } @Test fun isCommandTest() { - Assert.assertTrue(smsCommunicatorPlugin.isCommand("BOLUS", "")) + Assertions.assertTrue(smsCommunicatorPlugin.isCommand("BOLUS", "")) smsCommunicatorPlugin.messageToConfirm = null - Assert.assertFalse(smsCommunicatorPlugin.isCommand("BLB", "")) + Assertions.assertFalse(smsCommunicatorPlugin.isCommand("BLB", "")) smsCommunicatorPlugin.messageToConfirm = AuthRequest(injector, Sms("1234", "ddd"), "RequestText", "ccode", object : SmsAction(false) { override fun run() {} }) - Assert.assertTrue(smsCommunicatorPlugin.isCommand("BLB", "1234")) - Assert.assertFalse(smsCommunicatorPlugin.isCommand("BLB", "2345")) + Assertions.assertTrue(smsCommunicatorPlugin.isCommand("BLB", "1234")) + Assertions.assertFalse(smsCommunicatorPlugin.isCommand("BLB", "2345")) smsCommunicatorPlugin.messageToConfirm = null } @Test fun isAllowedNumberTest() { - Assert.assertTrue(smsCommunicatorPlugin.isAllowedNumber("5678")) - Assert.assertFalse(smsCommunicatorPlugin.isAllowedNumber("56")) + Assertions.assertTrue(smsCommunicatorPlugin.isAllowedNumber("5678")) + Assertions.assertFalse(smsCommunicatorPlugin.isAllowedNumber("56")) } @Test fun processSmsTest() { @@ -284,32 +283,32 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() var sms = Sms("12", "aText") smsCommunicatorPlugin.processSms(sms) - Assert.assertTrue(sms.ignored) - Assert.assertEquals("aText", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(sms.ignored) + Assertions.assertEquals("aText", smsCommunicatorPlugin.messages[0].text) //UNKNOWN smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "UNKNOWN") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("UNKNOWN", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("UNKNOWN", smsCommunicatorPlugin.messages[0].text) //BG smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BG") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BG", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("IOB:")) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("Last BG: 100")) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("COB: 10(2)g")) + Assertions.assertEquals("BG", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("IOB:")) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("Last BG: 100")) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("COB: 10(2)g")) // LOOP : test remote control disabled `when`(sp.getBoolean(R.string.key_smscommunicator_remote_commands_allowed, false)).thenReturn(false) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP STATUS") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP STATUS", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("Remote command is not allowed")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP STATUS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("Remote command is not allowed")) `when`(sp.getBoolean(R.string.key_smscommunicator_remote_commands_allowed, false)).thenReturn(true) //LOOP STATUS : disabled @@ -317,8 +316,8 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP STATUS") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("LOOP STATUS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Loop is disabled", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("LOOP STATUS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Loop is disabled", smsCommunicatorPlugin.messages[1].text) //LOOP STATUS : suspended `when`(loop.minutesToEndOfSuspend()).thenReturn(10) @@ -327,8 +326,8 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP STATUS") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("LOOP STATUS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Suspended (10 m)", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("LOOP STATUS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Suspended (10 m)", smsCommunicatorPlugin.messages[1].text) //LOOP STATUS : enabled `when`(loop.enabled).thenReturn(true) @@ -336,27 +335,27 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP STATUS") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP STATUS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Loop is enabled", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP STATUS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Loop is enabled", smsCommunicatorPlugin.messages[1].text) //LOOP : wrong format `when`(loop.enabled).thenReturn(true) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //LOOP DISABLE : already disabled `when`(loop.enabled).thenReturn(false) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP DISABLE") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP DISABLE", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Loop is disabled", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP DISABLE", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Loop is disabled", smsCommunicatorPlugin.messages[1].text) //LOOP DISABLE : from enabled hasBeenRun = false @@ -368,23 +367,23 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP DISABLE") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP DISABLE", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To disable loop reply with code ")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP DISABLE", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To disable loop reply with code ")) var passCode: String = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Loop has been disabled Temp basal canceled", smsCommunicatorPlugin.messages[3].text) - //Assert.assertTrue(hasBeenRun) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Loop has been disabled Temp basal canceled", smsCommunicatorPlugin.messages[3].text) + //Assertions.assertTrue(hasBeenRun) //LOOP ENABLE : already enabled `when`(loop.enabled).thenReturn(true) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP ENABLE") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP ENABLE", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Loop is enabled", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP ENABLE", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Loop is enabled", smsCommunicatorPlugin.messages[1].text) //LOOP ENABLE : from disabled hasBeenRun = false @@ -396,14 +395,14 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP ENABLE") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP ENABLE", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To enable loop reply with code ")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP ENABLE", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To enable loop reply with code ")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Loop has been enabled", smsCommunicatorPlugin.messages[3].text) - //Assert.assertTrue(hasBeenRun) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Loop has been enabled", smsCommunicatorPlugin.messages[3].text) + //Assertions.assertTrue(hasBeenRun) //LOOP RESUME : already enabled `when`( @@ -413,29 +412,29 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP RESUME") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP RESUME", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To resume loop reply with code ")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP RESUME", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To resume loop reply with code ")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Loop resumed", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Loop resumed", smsCommunicatorPlugin.messages[3].text) //LOOP SUSPEND 1 2: wrong format smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP SUSPEND 1 2") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP SUSPEND 1 2", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP SUSPEND 1 2", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //LOOP SUSPEND 0 : wrong duration smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP SUSPEND 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP SUSPEND 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong duration", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP SUSPEND 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong duration", smsCommunicatorPlugin.messages[1].text) //LOOP SUSPEND 100 : suspend for 100 min + correct answer `when`( @@ -445,41 +444,41 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP SUSPEND 100") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP SUSPEND 100", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To suspend loop for 100 minutes reply with code ")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP SUSPEND 100", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To suspend loop for 100 minutes reply with code ")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Loop suspended Temp basal canceled", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Loop suspended Temp basal canceled", smsCommunicatorPlugin.messages[3].text) //LOOP SUSPEND 200 : limit to 180 min + wrong answer smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP SUSPEND 200") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP SUSPEND 200", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To suspend loop for 180 minutes reply with code ")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP SUSPEND 200", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To suspend loop for 180 minutes reply with code ")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! // ignore from other number smsCommunicatorPlugin.processSms(Sms("5678", passCode)) `when`(otp.checkOTP(ArgumentMatchers.anyString())).thenReturn(OneTimePasswordValidationResult.ERROR_WRONG_OTP) smsCommunicatorPlugin.processSms(Sms("1234", "XXXX")) `when`(otp.checkOTP(ArgumentMatchers.anyString())).thenReturn(OneTimePasswordValidationResult.OK) - Assert.assertEquals("XXXX", smsCommunicatorPlugin.messages[3].text) - Assert.assertEquals("Wrong code. Command cancelled.", smsCommunicatorPlugin.messages[4].text) + Assertions.assertEquals("XXXX", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals("Wrong code. Command cancelled.", smsCommunicatorPlugin.messages[4].text) //then correct code should not work smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[5].text) - Assert.assertEquals(6, smsCommunicatorPlugin.messages.size.toLong()) // processed as common message + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[5].text) + Assertions.assertEquals(6, smsCommunicatorPlugin.messages.size.toLong()) // processed as common message //LOOP BLABLA smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "LOOP BLABLA") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("LOOP BLABLA", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("LOOP BLABLA", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //NSCLIENT RESTART `when`(loop.isEnabled()).thenReturn(true) @@ -487,9 +486,9 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "NSCLIENT RESTART") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("NSCLIENT RESTART", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("NSCLIENT RESTART")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("NSCLIENT RESTART", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("NSCLIENT RESTART")) //NSCLIENT BLA BLA `when`(loop.isEnabled()).thenReturn(true) @@ -497,9 +496,9 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "NSCLIENT BLA BLA") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("NSCLIENT BLA BLA", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("NSCLIENT BLA BLA", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //NSCLIENT BLABLA `when`(loop.isEnabled()).thenReturn(true) @@ -507,32 +506,32 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "NSCLIENT BLABLA") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("NSCLIENT BLABLA", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("NSCLIENT BLABLA", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //PUMP smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PUMP") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PUMP", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Virtual Pump", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PUMP", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Virtual Pump", smsCommunicatorPlugin.messages[1].text) //PUMP CONNECT 1 2: wrong format smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PUMP CONNECT 1 2") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("PUMP CONNECT 1 2", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("PUMP CONNECT 1 2", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //PUMP CONNECT BLABLA smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PUMP BLABLA") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("PUMP BLABLA", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("PUMP BLABLA", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //PUMP CONNECT `when`( @@ -543,116 +542,116 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PUMP CONNECT") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("PUMP CONNECT", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To connect pump reply with code ")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("PUMP CONNECT", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To connect pump reply with code ")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Pump reconnected", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Pump reconnected", smsCommunicatorPlugin.messages[3].text) //PUMP DISCONNECT 1 2: wrong format smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PUMP DISCONNECT 1 2") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("PUMP DISCONNECT 1 2", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("PUMP DISCONNECT 1 2", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //PUMP DISCONNECT 0 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PUMP DISCONNECT 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("Wrong duration", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("Wrong duration", smsCommunicatorPlugin.messages[1].text) //PUMP DISCONNECT 30 `when`(profileFunction.getProfile()).thenReturn(validProfile) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PUMP DISCONNECT 30") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("PUMP DISCONNECT 30", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To disconnect pump for")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("PUMP DISCONNECT 30", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To disconnect pump for")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Pump disconnected", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Pump disconnected", smsCommunicatorPlugin.messages[3].text) //PUMP DISCONNECT 30 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PUMP DISCONNECT 200") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("PUMP DISCONNECT 200", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To disconnect pump for")) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("PUMP DISCONNECT 200", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To disconnect pump for")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Pump disconnected", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Pump disconnected", smsCommunicatorPlugin.messages[3].text) //HELP smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "HELP") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("HELP", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("PUMP")) + Assertions.assertEquals("HELP", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("PUMP")) //HELP PUMP smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "HELP PUMP") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("HELP PUMP", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("PUMP")) + Assertions.assertEquals("HELP PUMP", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("PUMP")) //SMS : wrong format smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "SMS") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("SMS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("SMS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //SMS STOP smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "SMS DISABLE") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("SMS DISABLE", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To disable the SMS Remote Service reply with code")) + Assertions.assertEquals("SMS DISABLE", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To disable the SMS Remote Service reply with code")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("SMS Remote Service stopped. To reactivate it, use AAPS on master smartphone.")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("SMS Remote Service stopped. To reactivate it, use AAPS on master smartphone.")) //TARGET : wrong format smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "TARGET") smsCommunicatorPlugin.processSms(sms) - Assert.assertFalse(sms.ignored) - Assert.assertEquals("TARGET", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertFalse(sms.ignored) + Assertions.assertEquals("TARGET", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //TARGET MEAL smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "TARGET MEAL") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("TARGET MEAL", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To set the Temp Target")) + Assertions.assertEquals("TARGET MEAL", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To set the Temp Target")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("set successfully")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("set successfully")) //TARGET STOP/CANCEL smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "TARGET STOP") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("TARGET STOP", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To cancel Temp Target reply with code")) + Assertions.assertEquals("TARGET STOP", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To cancel Temp Target reply with code")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("Temp Target canceled successfully")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("Temp Target canceled successfully")) } @Test fun processProfileTest() { @@ -661,23 +660,23 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() var sms = Sms("1234", "PROFILE") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PROFILE", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) `when`(sp.getBoolean(R.string.key_smscommunicator_remote_commands_allowed, false)).thenReturn(true) //PROFILE smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PROFILE", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //PROFILE LIST (no profile defined) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE LIST") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE LIST", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Not configured", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PROFILE LIST", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Not configured", smsCommunicatorPlugin.messages[1].text) `when`(profileSource.profile).thenReturn(getValidProfileStore()) `when`(profileFunction.getProfileName()).thenReturn(TESTPROFILENAME) @@ -686,55 +685,55 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE STATUS") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE STATUS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals(TESTPROFILENAME, smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PROFILE STATUS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals(TESTPROFILENAME, smsCommunicatorPlugin.messages[1].text) //PROFILE LIST smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE LIST") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE LIST", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("1. $TESTPROFILENAME", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PROFILE LIST", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("1. $TESTPROFILENAME", smsCommunicatorPlugin.messages[1].text) //PROFILE 2 (non existing) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE 2") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE 2", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PROFILE 2", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //PROFILE 1 0(wrong percentage) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE 1 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE 1 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PROFILE 1 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //PROFILE 0(wrong index) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("PROFILE 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //PROFILE 1(OK) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE 1") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE 1", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To switch profile to someProfile 100% reply with code")) + Assertions.assertEquals("PROFILE 1", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To switch profile to someProfile 100% reply with code")) //PROFILE 1 90(OK) `when`(profileFunction.createProfileSwitch(anyObject(), Mockito.anyString(), Mockito.anyInt(), Mockito.anyInt(), Mockito.anyInt(), anyLong())).thenReturn(true) smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "PROFILE 1 90") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("PROFILE 1 90", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To switch profile to someProfile 90% reply with code")) + Assertions.assertEquals("PROFILE 1 90", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To switch profile to someProfile 90% reply with code")) val passCode: String = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Profile switch created", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Profile switch created", smsCommunicatorPlugin.messages[3].text) } @Test fun processBasalTest() { @@ -743,95 +742,95 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() var sms = Sms("1234", "BASAL") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BASAL", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) `when`(sp.getBoolean(R.string.key_smscommunicator_remote_commands_allowed, false)).thenReturn(true) //BASAL smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BASAL", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //BASAL CANCEL smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL CANCEL") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL CANCEL", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To stop temp basal reply with code")) + Assertions.assertEquals("BASAL CANCEL", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To stop temp basal reply with code")) var passCode: String = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("Temp basal canceled")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("Temp basal canceled")) `when`(profileFunction.getProfile()).thenReturn(validProfile) //BASAL a% smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL a%") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL a%", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BASAL a%", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //BASAL 10% 0 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL 10% 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL 10% 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("TBR duration must be a multiple of 30 minutes and greater than 0.", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BASAL 10% 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("TBR duration must be a multiple of 30 minutes and greater than 0.", smsCommunicatorPlugin.messages[1].text) //BASAL 20% 20 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL 20% 20") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL 20% 20", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("TBR duration must be a multiple of 30 minutes and greater than 0.", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BASAL 20% 20", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("TBR duration must be a multiple of 30 minutes and greater than 0.", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyBasalPercentConstraints(anyObject(), anyObject())).thenReturn(Constraint(20)) //BASAL 20% 30 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL 20% 30") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL 20% 30", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To start basal 20% for 30 min reply with code")) + Assertions.assertEquals("BASAL 20% 30", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To start basal 20% for 30 min reply with code")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Temp basal 20% for 30 min started successfully\nVirtual Pump", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Temp basal 20% for 30 min started successfully\nVirtual Pump", smsCommunicatorPlugin.messages[3].text) //BASAL a smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL a") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL a", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BASAL a", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //BASAL 1 0 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL 1 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL 1 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("TBR duration must be a multiple of 30 minutes and greater than 0.", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BASAL 1 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("TBR duration must be a multiple of 30 minutes and greater than 0.", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyBasalConstraints(anyObject(), anyObject())).thenReturn(Constraint(1.0)) //BASAL 1 20 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL 1 20") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL 1 20", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("TBR duration must be a multiple of 30 minutes and greater than 0.", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BASAL 1 20", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("TBR duration must be a multiple of 30 minutes and greater than 0.", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyBasalConstraints(anyObject(), anyObject())).thenReturn(Constraint(1.0)) //BASAL 1 30 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BASAL 1 30") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BASAL 1 30", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To start basal 1.00U/h for 30 min reply with code")) + Assertions.assertEquals("BASAL 1 30", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To start basal 1.00U/h for 30 min reply with code")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Temp basal 1.00U/h for 30 min started successfully\nVirtual Pump", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Temp basal 1.00U/h for 30 min started successfully\nVirtual Pump", smsCommunicatorPlugin.messages[3].text) } @Test fun processExtendedTest() { @@ -840,53 +839,53 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() var sms = Sms("1234", "EXTENDED") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("EXTENDED", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("EXTENDED", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) `when`(sp.getBoolean(R.string.key_smscommunicator_remote_commands_allowed, false)).thenReturn(true) //EXTENDED smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "EXTENDED") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("EXTENDED", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("EXTENDED", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //EXTENDED CANCEL smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "EXTENDED CANCEL") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("EXTENDED CANCEL", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To stop extended bolus reply with code")) + Assertions.assertEquals("EXTENDED CANCEL", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To stop extended bolus reply with code")) var passCode: String = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("Extended bolus canceled")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("Extended bolus canceled")) //EXTENDED a% smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "EXTENDED a%") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("EXTENDED a%", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("EXTENDED a%", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyExtendedBolusConstraints(anyObject())).thenReturn(Constraint(1.0)) //EXTENDED 1 0 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "EXTENDED 1 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("EXTENDED 1 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("EXTENDED 1 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //EXTENDED 1 20 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "EXTENDED 1 20") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("EXTENDED 1 20", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To start extended bolus 1.00U for 20 min reply with code")) + Assertions.assertEquals("EXTENDED 1 20", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To start extended bolus 1.00U for 20 min reply with code")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Extended bolus 1.00U for 20 min started successfully\nVirtual Pump", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Extended bolus 1.00U for 20 min started successfully\nVirtual Pump", smsCommunicatorPlugin.messages[3].text) } @Test fun processBolusTest() { @@ -895,16 +894,16 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() var sms = Sms("1234", "BOLUS") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BOLUS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) `when`(sp.getBoolean(R.string.key_smscommunicator_remote_commands_allowed, false)).thenReturn(true) //BOLUS smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BOLUS") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BOLUS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyBolusConstraints(anyObject())).thenReturn(Constraint(1.0)) `when`(dateUtilMocked.now()).thenReturn(1000L) `when`(sp.getLong(R.string.key_smscommunicator_remote_bolus_min_distance, T.msecs(Constants.remoteBolusMinDistance).mins())).thenReturn(15L) @@ -912,8 +911,8 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BOLUS 1") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS 1", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Remote bolus not available. Try again later.", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BOLUS 1", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Remote bolus not available. Try again later.", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyBolusConstraints(anyObject())).thenReturn(Constraint(0.0)) `when`(dateUtilMocked.now()).thenReturn(Constants.remoteBolusMinDistance + 1002L) @@ -921,15 +920,15 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BOLUS 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BOLUS 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //BOLUS a smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BOLUS a") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS a", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BOLUS a", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyExtendedBolusConstraints(anyObject())).thenReturn(Constraint(1.0)) `when`(constraintChecker.applyBolusConstraints(anyObject())).thenReturn(Constraint(1.0)) @@ -937,12 +936,12 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BOLUS 1") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS 1", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To deliver bolus 1.00U reply with code")) + Assertions.assertEquals("BOLUS 1", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To deliver bolus 1.00U reply with code")) var passCode: String = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("Bolus 1.00U delivered successfully")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.contains("Bolus 1.00U delivered successfully")) //BOLUS 1 (Suspended pump) smsCommunicatorPlugin.lastRemoteBolusTime = 0 @@ -950,28 +949,28 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BOLUS 1") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS 1", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Pump suspended", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BOLUS 1", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Pump suspended", smsCommunicatorPlugin.messages[1].text) `when`(testPumpPlugin.isSuspended()).thenReturn(false) //BOLUS 1 a smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BOLUS 1 a") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS 1 a", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("BOLUS 1 a", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) `when`(profileFunction.getProfile()).thenReturn(validProfile) //BOLUS 1 MEAL smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "BOLUS 1 MEAL") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("BOLUS 1 MEAL", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To deliver meal bolus 1.00U reply with code")) + Assertions.assertEquals("BOLUS 1 MEAL", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To deliver meal bolus 1.00U reply with code")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Meal Bolus 1.00U delivered successfully\nVirtual Pump\nTarget 5.0 for 45 minutes", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Meal Bolus 1.00U delivered successfully\nVirtual Pump\nTarget 5.0 for 45 minutes", smsCommunicatorPlugin.messages[3].text) } @Test fun processCalTest() { @@ -980,34 +979,34 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() var sms = Sms("1234", "CAL") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CAL", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("CAL", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) `when`(sp.getBoolean(R.string.key_smscommunicator_remote_commands_allowed, false)).thenReturn(true) //CAL smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CAL") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CAL", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("CAL", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) //CAL 0 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CAL 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CAL 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("CAL 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) `when`(xDripBroadcast.sendCalibration(ArgumentMatchers.anyDouble())).thenReturn(true) //CAL 1 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CAL 1") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CAL 1", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To send calibration 1.00 reply with code")) + Assertions.assertEquals("CAL 1", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To send calibration 1.00 reply with code")) val passCode: String = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertEquals("Calibration sent. Receiving must be enabled in xDrip.", smsCommunicatorPlugin.messages[3].text) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertEquals("Calibration sent. Receiving must be enabled in xDrip.", smsCommunicatorPlugin.messages[3].text) } @Test fun processCarbsTest() { @@ -1018,80 +1017,80 @@ class SmsCommunicatorPluginTest : TestBaseWithProfile() { smsCommunicatorPlugin.messages = ArrayList() var sms = Sms("1234", "CARBS") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CARBS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("CARBS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Remote command is not allowed", smsCommunicatorPlugin.messages[1].text) `when`(sp.getBoolean(R.string.key_smscommunicator_remote_commands_allowed, false)).thenReturn(true) //CARBS smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CARBS") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CARBS", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("CARBS", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyCarbsConstraints(anyObject())).thenReturn(Constraint(0)) //CARBS 0 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CARBS 0") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CARBS 0", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("CARBS 0", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("Wrong format", smsCommunicatorPlugin.messages[1].text) `when`(constraintChecker.applyCarbsConstraints(anyObject())).thenReturn(Constraint(1)) //CARBS 1 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CARBS 1") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CARBS 1", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To enter 1g at")) + Assertions.assertEquals("CARBS 1", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To enter 1g at")) var passCode: String = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.startsWith("Carbs 1g entered successfully")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.startsWith("Carbs 1g entered successfully")) //CARBS 1 a smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CARBS 1 a") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CARBS 1 a", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("Wrong format")) + Assertions.assertEquals("CARBS 1 a", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("Wrong format")) //CARBS 1 00 smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CARBS 1 00") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CARBS 1 00", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("Wrong format")) + Assertions.assertEquals("CARBS 1 00", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("Wrong format")) //CARBS 1 12:01 `when`(dateUtilMocked.timeString(anyLong())).thenReturn("12:01PM") smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CARBS 1 12:01") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CARBS 1 12:01", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To enter 1g at 12:01PM reply with code")) + Assertions.assertEquals("CARBS 1 12:01", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To enter 1g at 12:01PM reply with code")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.startsWith("Carbs 1g entered successfully")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.startsWith("Carbs 1g entered successfully")) //CARBS 1 3:01AM `when`(dateUtilMocked.timeString(anyLong())).thenReturn("03:01AM") smsCommunicatorPlugin.messages = ArrayList() sms = Sms("1234", "CARBS 1 3:01AM") smsCommunicatorPlugin.processSms(sms) - Assert.assertEquals("CARBS 1 3:01AM", smsCommunicatorPlugin.messages[0].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To enter 1g at 03:01AM reply with code")) + Assertions.assertEquals("CARBS 1 3:01AM", smsCommunicatorPlugin.messages[0].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[1].text.contains("To enter 1g at 03:01AM reply with code")) passCode = smsCommunicatorPlugin.messageToConfirm?.confirmCode!! smsCommunicatorPlugin.processSms(Sms("1234", passCode)) - Assert.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) - Assert.assertTrue(smsCommunicatorPlugin.messages[3].text.startsWith("Carbs 1g entered successfully")) + Assertions.assertEquals(passCode, smsCommunicatorPlugin.messages[2].text) + Assertions.assertTrue(smsCommunicatorPlugin.messages[3].text.startsWith("Carbs 1g entered successfully")) } @Test fun sendNotificationToAllNumbers() { smsCommunicatorPlugin.messages = ArrayList() smsCommunicatorPlugin.sendNotificationToAllNumbers("abc") - Assert.assertEquals("abc", smsCommunicatorPlugin.messages[0].text) - Assert.assertEquals("abc", smsCommunicatorPlugin.messages[1].text) + Assertions.assertEquals("abc", smsCommunicatorPlugin.messages[0].text) + Assertions.assertEquals("abc", smsCommunicatorPlugin.messages[1].text) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt new file mode 100644 index 0000000000..861534e11d --- /dev/null +++ b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt @@ -0,0 +1,1323 @@ +package info.nightscout.plugins.iob + +import android.content.Context +import info.nightscout.androidaps.TestBase +import info.nightscout.database.entities.GlucoseValue +import info.nightscout.shared.utils.DateUtil +import info.nightscout.shared.utils.T +import org.junit.jupiter.api.Assertions +import org.junit.jupiter.api.BeforeEach +import org.junit.jupiter.api.Test +import org.mockito.Mock + +class AutosensDataStoreTest : TestBase() { + + @Mock lateinit var context: Context + + private lateinit var dateUtil: DateUtil + + private val autosensDataStore = info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataStoreObject() + + @BeforeEach + fun mock() { + dateUtil = DateUtil(context) + } + + @Test + fun isAbout5minDataTest() { + val bgReadingList: MutableList = ArrayList() + + // Super data should not be touched + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(15).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + + // too much shifted data should return false + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(15).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(9).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + + // too much shifted and missing data should return false + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(9).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + + // too much shifted and missing data should return false + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(83).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(78).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(73).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(68).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(63).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(58).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(53).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(48).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(43).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(38).plus(T.secs(40)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(33).plus(T.secs(1)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(28).plus(T.secs(0)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(23).plus(T.secs(0)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(16).plus(T.secs(36)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + + // slightly shifted data should return true + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(15).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).plus(T.secs(10)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + + // slightly shifted and missing data should return true + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).plus(T.secs(10)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + } + + @Test + fun createBucketedData5minTest1() { + val bgReadingList: MutableList = ArrayList() + + // Super data should not be touched + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(15).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(bgReadingList[0].timestamp, autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(bgReadingList[3].timestamp, autosensDataStore.bucketedData!![3].timestamp) + Assertions.assertEquals(bgReadingList.size.toLong(), autosensDataStore.bucketedData!!.size.toLong()) + + // Missing value should be replaced + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).plus(T.secs(10)).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(bgReadingList[0].timestamp, autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(bgReadingList[2].timestamp, autosensDataStore.bucketedData!![3].timestamp) + Assertions.assertEquals(bgReadingList.size + 1.toLong(), autosensDataStore.bucketedData!!.size.toLong()) + + // drift should be cleared + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(15).msecs() + T.secs(10).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).msecs() + T.secs(10).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs() + T.secs(10).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(0).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(T.mins(15).msecs(), autosensDataStore.bucketedData!![1].timestamp) + Assertions.assertEquals(T.mins(10).msecs(), autosensDataStore.bucketedData!![2].timestamp) + Assertions.assertEquals(T.mins(5).msecs(), autosensDataStore.bucketedData!![3].timestamp) + Assertions.assertEquals(bgReadingList.size.toLong(), autosensDataStore.bucketedData!!.size.toLong()) + + // bucketed data should return null if not enough bg data + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(30).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(null, autosensDataStore.bucketedData) + + // data should be reconstructed + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(50).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 90.0, + timestamp = T.mins(45).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 40.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(T.mins(50).msecs(), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![6].timestamp) + Assertions.assertEquals(7, autosensDataStore.bucketedData!!.size.toLong()) + Assertions.assertEquals(100.0, autosensDataStore.bucketedData!![0].value, 1.0) + Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) + Assertions.assertEquals(50.0, autosensDataStore.bucketedData!![5].value, 1.0) + Assertions.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) + + // non 5min data should be reconstructed + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(50).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 96.0, + timestamp = T.mins(48).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 40.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(T.mins(50).msecs(), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![6].timestamp) + Assertions.assertEquals(7, autosensDataStore.bucketedData!!.size.toLong()) + Assertions.assertEquals(100.0, autosensDataStore.bucketedData!![0].value, 1.0) + Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) + Assertions.assertEquals(50.0, autosensDataStore.bucketedData!![5].value, 1.0) + Assertions.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) + } + + @Test + fun createBucketedData5minTest2() { + val bgReadingList: MutableList = ArrayList() + + //bucketed data should be null if no bg data available + autosensDataStore.bgReadings = ArrayList() + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(null, autosensDataStore.bucketedData) + + // real data gap test + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T13:34:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T13:14:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T13:09:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T13:04:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:59:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:54:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:49:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:44:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:39:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:34:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:29:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:24:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:19:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:14:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:09:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T12:04:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T11:59:55Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T04:29:57Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T04:24:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T04:19:57Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T04:14:57Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T04:10:03Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T04:04:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T03:59:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T03:54:56Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T03:50:03Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-09-05T03:44:57Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + autosensDataStore.referenceTime = -1 + Assertions.assertEquals(true, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(dateUtil.fromISODateString("2018-09-05T13:34:57Z"), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(dateUtil.fromISODateString("2018-09-05T03:44:57Z"), autosensDataStore.bucketedData!![autosensDataStore.bucketedData!!.size - 1].timestamp) + + // 5min 4sec data + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T06:33:40Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T06:28:36Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T06:23:32Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T06:18:28Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T06:13:24Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T06:08:19Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T06:03:16Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:58:11Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:53:07Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:48:03Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:42:58Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:37:54Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:32:51Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:27:46Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:22:42Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:17:38Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:12:33Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:07:29Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T05:02:26Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T04:57:21Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = dateUtil.fromISODateString("2018-10-05T04:52:17Z"), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + } + + @Test + fun bgReadingsTest() { + val bgReadingList: List = ArrayList() + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(bgReadingList, autosensDataStore.bgReadings) + } + + @Test + fun roundUpTimeTest() { + Assertions.assertEquals(T.mins(3).msecs(), autosensDataStore.roundUpTime(T.secs(155).msecs())) + } + + @Test + fun findNewerTest() { + val bgReadingList: MutableList = ArrayList() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(15).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(T.mins(10).msecs(), autosensDataStore.findNewer(T.mins(8).msecs())!!.timestamp) + Assertions.assertEquals(T.mins(5).msecs(), autosensDataStore.findNewer(T.mins(5).msecs())!!.timestamp) + Assertions.assertEquals(T.mins(10).msecs(), autosensDataStore.findNewer(T.mins(10).msecs())!!.timestamp) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.findNewer(T.mins(20).msecs())!!.timestamp) + Assertions.assertEquals(null, autosensDataStore.findNewer(T.mins(22).msecs())) + } + + @Test + fun findOlderTest() { + val bgReadingList: MutableList = ArrayList() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(15).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(T.mins(5).msecs(), autosensDataStore.findOlder(T.mins(8).msecs())!!.timestamp) + Assertions.assertEquals(T.mins(5).msecs(), autosensDataStore.findOlder(T.mins(5).msecs())!!.timestamp) + Assertions.assertEquals(T.mins(10).msecs(), autosensDataStore.findOlder(T.mins(10).msecs())!!.timestamp) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.findOlder(T.mins(20).msecs())!!.timestamp) + Assertions.assertEquals(null, autosensDataStore.findOlder(T.mins(4).msecs())) + } + + @Test + fun findPreviousTimeFromBucketedDataTest() { + val bgReadingList: MutableList = ArrayList() + autosensDataStore.bgReadings = bgReadingList + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(null, autosensDataStore.findPreviousTimeFromBucketedData(1000)) + + // Super data should not be touched + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(20).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(15).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(10).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(5).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(null, autosensDataStore.findPreviousTimeFromBucketedData(T.mins(4).msecs())) + Assertions.assertEquals(T.mins(5).msecs(), autosensDataStore.findPreviousTimeFromBucketedData(T.mins(6).msecs())) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.findPreviousTimeFromBucketedData(T.mins(20).msecs())) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.findPreviousTimeFromBucketedData(T.mins(25).msecs())) + } +} \ No newline at end of file diff --git a/ui/src/main/java/info/nightscout/ui/dialogs/CalibrationDialog.kt b/ui/src/main/java/info/nightscout/ui/dialogs/CalibrationDialog.kt index 85b1ac77b1..18371ce520 100644 --- a/ui/src/main/java/info/nightscout/ui/dialogs/CalibrationDialog.kt +++ b/ui/src/main/java/info/nightscout/ui/dialogs/CalibrationDialog.kt @@ -6,13 +6,13 @@ import android.view.View import android.view.ViewGroup import com.google.common.base.Joiner import dagger.android.HasAndroidInjector -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.ui.dialogs.OKDialog import info.nightscout.database.entities.UserEntry.Action import info.nightscout.database.entities.UserEntry.Sources import info.nightscout.database.entities.ValueWithUnit import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.XDripBroadcast +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction diff --git a/ui/src/main/java/info/nightscout/ui/dialogs/CarbsDialog.kt b/ui/src/main/java/info/nightscout/ui/dialogs/CarbsDialog.kt index b63fec4793..878f721741 100644 --- a/ui/src/main/java/info/nightscout/ui/dialogs/CarbsDialog.kt +++ b/ui/src/main/java/info/nightscout/ui/dialogs/CarbsDialog.kt @@ -8,7 +8,6 @@ import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import com.google.common.base.Joiner -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.ui.dialogs.OKDialog import info.nightscout.core.ui.toast.ToastUtils import info.nightscout.core.utils.extensions.formatColor @@ -26,6 +25,7 @@ import info.nightscout.interfaces.Constants.CARBS_FAV3_DEFAULT import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.profile.DefaultValueHelper diff --git a/ui/src/main/java/info/nightscout/ui/dialogs/CareDialog.kt b/ui/src/main/java/info/nightscout/ui/dialogs/CareDialog.kt index 258619a934..d95fa40f03 100644 --- a/ui/src/main/java/info/nightscout/ui/dialogs/CareDialog.kt +++ b/ui/src/main/java/info/nightscout/ui/dialogs/CareDialog.kt @@ -11,7 +11,6 @@ import androidx.annotation.StringRes import com.google.common.base.Joiner import dagger.android.HasAndroidInjector import info.nightscout.core.extensions.fromConstant -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.ui.dialogs.OKDialog import info.nightscout.database.entities.TherapyEvent import info.nightscout.database.entities.UserEntry @@ -21,6 +20,7 @@ import info.nightscout.database.impl.transactions.InsertIfNewByTimestampTherapyE import info.nightscout.interfaces.Constants import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.Translator +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction diff --git a/ui/src/main/java/info/nightscout/ui/widget/Widget.kt b/ui/src/main/java/info/nightscout/ui/widget/Widget.kt index 5cb254fcff..be5899e126 100644 --- a/ui/src/main/java/info/nightscout/ui/widget/Widget.kt +++ b/ui/src/main/java/info/nightscout/ui/widget/Widget.kt @@ -17,7 +17,6 @@ import info.nightscout.core.extensions.directionToIcon import info.nightscout.core.extensions.valueToUnitsString import info.nightscout.core.graph.OverviewData import info.nightscout.core.iob.displayText -import info.nightscout.core.iob.iobCobCalculator.GlucoseStatusProvider import info.nightscout.core.profile.ProfileSealed import info.nightscout.database.entities.interfaces.end import info.nightscout.interfaces.Config @@ -26,6 +25,7 @@ import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.aps.VariableSensitivityResult import info.nightscout.interfaces.constraints.Constraints +import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.Profile From ed6858bee7708766912d9c96e41335fa7801933b Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Thu, 8 Dec 2022 11:46:32 +0100 Subject: [PATCH 12/48] MDT: fix crash caused by code changes --- .../info/nightscout/pump/common/sync/PumpSyncStorage.kt | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/pump/pump-common/src/main/java/info/nightscout/pump/common/sync/PumpSyncStorage.kt b/pump/pump-common/src/main/java/info/nightscout/pump/common/sync/PumpSyncStorage.kt index b481e1c3b0..1de834263e 100644 --- a/pump/pump-common/src/main/java/info/nightscout/pump/common/sync/PumpSyncStorage.kt +++ b/pump/pump-common/src/main/java/info/nightscout/pump/common/sync/PumpSyncStorage.kt @@ -50,8 +50,11 @@ class PumpSyncStorage @Inject constructor( if (jsonData.isNotBlank()) { @Suppress("UNCHECKED_CAST") - pumpSyncStorageBolus = xstream.fromXML(jsonData, MutableList::class.java) as - MutableList + pumpSyncStorageBolus = try { + xstream.fromXML(jsonData, MutableList::class.java) as MutableList + } catch (e: Exception) { + mutableListOf() + } aapsLogger.debug(LTag.PUMP, "Loading Pump Sync Storage Bolus: boluses=${pumpSyncStorageBolus.size}") aapsLogger.debug(LTag.PUMP, "DD: PumpSyncStorageBolus=$pumpSyncStorageBolus") From 1a9f6474e5f1c9af16d77a6cadc0cbaaa33ebc4c Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Thu, 8 Dec 2022 17:59:29 +0100 Subject: [PATCH 13/48] consolidate constraints plugins --- app/build.gradle | 2 +- .../nightscout/androidaps/di/AppComponent.kt | 4 +- .../interfaces/ConstraintsCheckerTest.kt | 21 +++++----- .../plugins/safety/SafetyPluginTest.kt | 21 +++++----- .../nightscout/interfaces/actions/Actions.kt | 3 ++ .../interfaces/db/PersistenceLayer.kt | 2 + .../src/main/res/drawable/ic_graduation.xml | 0 .../drawable/ic_trending_flat_white_48dp.xml | 10 +++++ core/ui/src/main/res/values/strings.xml | 3 ++ .../core/utils}/extensions/JSONObjectExt.kt | 0 core/utils/src/main/res/values/keys.xml | 3 ++ crowdin.yml | 4 +- .../implementation/db/PersistenceLayerImpl.kt | 2 + .../implementation/di/ImplementationModule.kt | 3 -- .../UserEntryPresentationHelperImpl.kt | 2 +- plugins/{support => constraints}/.gitignore | 0 plugins/{support => constraints}/build.gradle | 3 +- .../consumer-rules.pro | 0 .../proguard-rules.pro | 0 .../constraints/src/main/AndroidManifest.xml | 4 ++ .../plugins}/constraints/ConstraintsImpl.kt | 2 +- .../bgQualityCheck/BgQualityCheckPlugin.kt | 2 +- .../constraints/di/ObjectivesModule.kt | 25 ++++++++++++ .../di/PluginsConstraintsModule.kt} | 9 +++-- .../constraints/dstHelper/DstHelperPlugin.kt | 2 +- .../objectives/ObjectivesFragment.kt | 6 +-- .../objectives/ObjectivesPlugin.kt | 8 ++-- .../constraints/objectives/SntpClient.kt | 0 .../activities/ObjectivesExamDialog.kt | 4 +- .../objectives/dialogs/NtpProgressDialog.kt | 2 +- .../events/EventObjectivesUpdateGui.kt | 0 .../objectives/objectives/Objective.kt | 2 +- .../objectives/objectives/Objective0.kt | 16 ++++---- .../objectives/objectives/Objective1.kt | 14 ++++--- .../objectives/objectives/Objective10.kt | 2 +- .../objectives/objectives/Objective2.kt | 4 +- .../objectives/objectives/Objective3.kt | 2 +- .../objectives/objectives/Objective4.kt | 2 +- .../objectives/objectives/Objective5.kt | 2 +- .../objectives/objectives/Objective6.kt | 2 +- .../objectives/objectives/Objective7.kt | 2 +- .../objectives/objectives/Objective9.kt | 2 +- .../objectives/objectives/SntpClient.kt | 0 .../phoneChecker/PhoneCheckerPlugin.kt | 2 +- .../constraints/safety/SafetyPlugin.kt | 10 ++--- .../SignatureVerifierPlugin.kt | 2 +- .../storage/StorageConstraintPlugin.kt | 2 +- .../versionChecker/VersionCheckerPlugin.kt | 2 +- .../versionChecker/VersionCheckerUtilsImpl.kt | 2 +- .../drawable/ic_baseline_trending_flat_24.xml | 0 .../drawable/ic_baseline_warning_24_red.xml | 0 .../ic_baseline_warning_24_yellow.xml | 0 .../main/res/layout/dialog_ntp_progress.xml | 0 .../res/layout/objectives_exam_fragment.xml | 2 +- .../main/res/layout/objectives_fragment.xml | 0 .../src/main/res/layout/objectives_item.xml | 0 .../src/main/res/values-af-rZA/exam.xml | 0 .../src/main/res/values-af-rZA/objectives.xml | 0 .../src/main/res/values-af-rZA/strings.xml | 0 .../src/main/res/values-bg-rBG/exam.xml | 0 .../src/main/res/values-bg-rBG/objectives.xml | 0 .../src/main/res/values-bg-rBG/strings.xml | 0 .../src/main/res/values-ca-rES/exam.xml | 0 .../src/main/res/values-ca-rES/objectives.xml | 0 .../src/main/res/values-ca-rES/strings.xml | 0 .../src/main/res/values-cs-rCZ/exam.xml | 0 .../src/main/res/values-cs-rCZ/objectives.xml | 0 .../src/main/res/values-cs-rCZ/strings.xml | 0 .../src/main/res/values-da-rDK/exam.xml | 0 .../src/main/res/values-da-rDK/objectives.xml | 0 .../src/main/res/values-da-rDK/strings.xml | 0 .../src/main/res/values-de-rDE/exam.xml | 0 .../src/main/res/values-de-rDE/objectives.xml | 0 .../src/main/res/values-de-rDE/strings.xml | 0 .../src/main/res/values-el-rGR/exam.xml | 0 .../src/main/res/values-el-rGR/objectives.xml | 0 .../src/main/res/values-el-rGR/strings.xml | 0 .../src/main/res/values-es-rES/exam.xml | 0 .../src/main/res/values-es-rES/objectives.xml | 0 .../src/main/res/values-es-rES/strings.xml | 0 .../src/main/res/values-fr-rFR/exam.xml | 0 .../src/main/res/values-fr-rFR/objectives.xml | 0 .../src/main/res/values-fr-rFR/strings.xml | 0 .../src/main/res/values-ga-rIE/exam.xml | 0 .../src/main/res/values-ga-rIE/objectives.xml | 0 .../src/main/res/values-ga-rIE/strings.xml | 0 .../src/main/res/values-hr-rHR/exam.xml | 0 .../src/main/res/values-hr-rHR/objectives.xml | 0 .../src/main/res/values-hr-rHR/strings.xml | 0 .../src/main/res/values-hu-rHU/exam.xml | 0 .../src/main/res/values-hu-rHU/objectives.xml | 0 .../src/main/res/values-hu-rHU/strings.xml | 0 .../src/main/res/values-it-rIT/exam.xml | 0 .../src/main/res/values-it-rIT/objectives.xml | 0 .../src/main/res/values-it-rIT/strings.xml | 0 .../src/main/res/values-iw-rIL/exam.xml | 0 .../src/main/res/values-iw-rIL/objectives.xml | 0 .../src/main/res/values-iw-rIL/strings.xml | 0 .../src/main/res/values-ja-rJP/exam.xml | 0 .../src/main/res/values-ja-rJP/objectives.xml | 0 .../src/main/res/values-ja-rJP/strings.xml | 0 .../src/main/res/values-ko-rKR/exam.xml | 0 .../src/main/res/values-ko-rKR/objectives.xml | 0 .../src/main/res/values-ko-rKR/strings.xml | 0 .../src/main/res/values-lt-rLT/exam.xml | 0 .../src/main/res/values-lt-rLT/objectives.xml | 0 .../src/main/res/values-lt-rLT/strings.xml | 0 .../src/main/res/values-nl-rNL/exam.xml | 0 .../src/main/res/values-nl-rNL/objectives.xml | 0 .../src/main/res/values-nl-rNL/strings.xml | 0 .../src/main/res/values-no-rNO/exam.xml | 0 .../src/main/res/values-no-rNO/objectives.xml | 0 .../src/main/res/values-no-rNO/strings.xml | 0 .../src/main/res/values-pl-rPL/exam.xml | 0 .../src/main/res/values-pl-rPL/objectives.xml | 0 .../src/main/res/values-pl-rPL/strings.xml | 0 .../src/main/res/values-pt-rBR/exam.xml | 0 .../src/main/res/values-pt-rBR/objectives.xml | 0 .../src/main/res/values-pt-rBR/strings.xml | 0 .../src/main/res/values-pt-rPT/exam.xml | 0 .../src/main/res/values-pt-rPT/objectives.xml | 0 .../src/main/res/values-pt-rPT/strings.xml | 0 .../src/main/res/values-ro-rRO/exam.xml | 0 .../src/main/res/values-ro-rRO/objectives.xml | 0 .../src/main/res/values-ro-rRO/strings.xml | 0 .../src/main/res/values-ru-rRU/exam.xml | 0 .../src/main/res/values-ru-rRU/objectives.xml | 0 .../src/main/res/values-ru-rRU/strings.xml | 0 .../src/main/res/values-sk-rSK/exam.xml | 0 .../src/main/res/values-sk-rSK/objectives.xml | 0 .../src/main/res/values-sk-rSK/strings.xml | 0 .../src/main/res/values-sr-rCS/exam.xml | 0 .../src/main/res/values-sr-rCS/objectives.xml | 0 .../src/main/res/values-sr-rCS/strings.xml | 0 .../src/main/res/values-sv-rSE/exam.xml | 0 .../src/main/res/values-sv-rSE/objectives.xml | 0 .../src/main/res/values-sv-rSE/strings.xml | 0 .../src/main/res/values-tr-rTR/exam.xml | 0 .../src/main/res/values-tr-rTR/objectives.xml | 0 .../src/main/res/values-tr-rTR/strings.xml | 0 .../src/main/res/values-zh-rCN/exam.xml | 0 .../src/main/res/values-zh-rCN/objectives.xml | 0 .../src/main/res/values-zh-rCN/strings.xml | 0 .../src/main/res/values/exam.xml | 2 - .../src/main/res/values/objectives.xml | 2 - .../src/main/res/values/strings.xml | 34 ++++++++++++++++ .../src/main/res/xml/pref_safety.xml | 0 .../info/nightscout/androidaps/TestBase.kt | 0 .../BgQualityCheckPluginTest.kt | 2 +- .../dstHelper/DstHelperPluginTest.kt | 0 .../objectives/ObjectivesPluginTest.kt | 23 ++++++----- .../constraints/objectives/SntpClientTest.kt | 4 +- .../SignatureVerifierPluginTest.kt | 0 .../VersionCheckerUtilsKtTest.kt | 0 .../storage/StorageConstraintPluginTest.kt | 0 .../versionChecker/AllowedVersionsTest.kt | 0 .../nightscout/plugins/di/ObjectivesModule.kt | 39 ------------------- .../nightscout/plugins/di/PluginsModule.kt | 1 - .../general/actions/ActionsFragment.kt | 2 +- .../plugins/general/actions/ActionsPlugin.kt | 3 +- .../general/overview/OverviewFragment.kt | 6 +-- .../plugins/pump/virtual/VirtualPumpPlugin.kt | 4 +- plugins/main/src/main/res/values/strings.xml | 35 ----------------- plugins/support/src/main/AndroidManifest.xml | 4 -- settings.gradle | 2 +- 165 files changed, 196 insertions(+), 186 deletions(-) create mode 100644 core/interfaces/src/main/java/info/nightscout/interfaces/actions/Actions.kt rename core/{main => ui}/src/main/res/drawable/ic_graduation.xml (100%) create mode 100644 core/ui/src/main/res/drawable/ic_trending_flat_white_48dp.xml rename core/{main/src/main/java/info/nightscout/core => utils/src/main/java/info/nightscout/core/utils}/extensions/JSONObjectExt.kt (100%) rename plugins/{support => constraints}/.gitignore (100%) rename plugins/{support => constraints}/build.gradle (89%) rename plugins/{support => constraints}/consumer-rules.pro (100%) rename plugins/{support => constraints}/proguard-rules.pro (100%) create mode 100644 plugins/constraints/src/main/AndroidManifest.xml rename {implementation/src/main/java/info/nightscout/implementation => plugins/constraints/src/main/java/info/nightscout/plugins}/constraints/ConstraintsImpl.kt (99%) rename plugins/{support => constraints}/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt (99%) create mode 100644 plugins/constraints/src/main/java/info/nightscout/plugins/constraints/di/ObjectivesModule.kt rename plugins/{support/src/main/java/info/nightscout/plugins/support/di/PluginsSupportModule.kt => constraints/src/main/java/info/nightscout/plugins/constraints/di/PluginsConstraintsModule.kt} (64%) rename plugins/{support => constraints}/src/main/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPlugin.kt (98%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesFragment.kt (98%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesPlugin.kt (95%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/SntpClient.kt (100%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/activities/ObjectivesExamDialog.kt (97%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/dialogs/NtpProgressDialog.kt (97%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/events/EventObjectivesUpdateGui.kt (100%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective.kt (99%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective0.kt (80%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective1.kt (76%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective10.kt (89%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective2.kt (98%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective3.kt (96%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective4.kt (86%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective5.kt (95%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective6.kt (95%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective7.kt (89%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective9.kt (89%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/SntpClient.kt (100%) rename plugins/{support => constraints}/src/main/java/info/nightscout/plugins/constraints/phoneChecker/PhoneCheckerPlugin.kt (97%) rename plugins/{main => constraints}/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt (96%) rename plugins/{support => constraints}/src/main/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPlugin.kt (99%) rename plugins/{support => constraints}/src/main/java/info/nightscout/plugins/constraints/storage/StorageConstraintPlugin.kt (98%) rename plugins/{support => constraints}/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerPlugin.kt (99%) rename plugins/{support => constraints}/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerUtilsImpl.kt (99%) rename plugins/{support => constraints}/src/main/res/drawable/ic_baseline_trending_flat_24.xml (100%) rename plugins/{support => constraints}/src/main/res/drawable/ic_baseline_warning_24_red.xml (100%) rename plugins/{support => constraints}/src/main/res/drawable/ic_baseline_warning_24_yellow.xml (100%) rename plugins/{main => constraints}/src/main/res/layout/dialog_ntp_progress.xml (100%) rename plugins/{main => constraints}/src/main/res/layout/objectives_exam_fragment.xml (98%) rename plugins/{main => constraints}/src/main/res/layout/objectives_fragment.xml (100%) rename plugins/{main => constraints}/src/main/res/layout/objectives_item.xml (100%) rename plugins/{main => constraints}/src/main/res/values-af-rZA/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-af-rZA/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-af-rZA/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-bg-rBG/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-bg-rBG/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-bg-rBG/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ca-rES/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ca-rES/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-ca-rES/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-cs-rCZ/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-cs-rCZ/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-cs-rCZ/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-da-rDK/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-da-rDK/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-da-rDK/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-de-rDE/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-de-rDE/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-de-rDE/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-el-rGR/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-el-rGR/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-el-rGR/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-es-rES/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-es-rES/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-es-rES/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-fr-rFR/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-fr-rFR/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-fr-rFR/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ga-rIE/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ga-rIE/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-ga-rIE/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-hr-rHR/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-hr-rHR/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-hr-rHR/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-hu-rHU/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-hu-rHU/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-hu-rHU/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-it-rIT/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-it-rIT/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-it-rIT/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-iw-rIL/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-iw-rIL/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-iw-rIL/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ja-rJP/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ja-rJP/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-ja-rJP/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ko-rKR/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ko-rKR/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-ko-rKR/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-lt-rLT/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-lt-rLT/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-lt-rLT/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-nl-rNL/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-nl-rNL/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-nl-rNL/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-no-rNO/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-no-rNO/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-no-rNO/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-pl-rPL/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-pl-rPL/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-pl-rPL/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-pt-rBR/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-pt-rBR/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-pt-rBR/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-pt-rPT/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-pt-rPT/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-pt-rPT/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ro-rRO/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ro-rRO/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-ro-rRO/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ru-rRU/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-ru-rRU/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-ru-rRU/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-sk-rSK/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-sk-rSK/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-sk-rSK/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-sr-rCS/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-sr-rCS/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-sr-rCS/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-sv-rSE/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-sv-rSE/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-sv-rSE/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-tr-rTR/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-tr-rTR/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-tr-rTR/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values-zh-rCN/exam.xml (100%) rename plugins/{main => constraints}/src/main/res/values-zh-rCN/objectives.xml (100%) rename plugins/{support => constraints}/src/main/res/values-zh-rCN/strings.xml (100%) rename plugins/{main => constraints}/src/main/res/values/exam.xml (99%) rename plugins/{main => constraints}/src/main/res/values/objectives.xml (97%) rename plugins/{support => constraints}/src/main/res/values/strings.xml (55%) rename plugins/{main => constraints}/src/main/res/xml/pref_safety.xml (100%) rename plugins/{support => constraints}/src/test/java/info/nightscout/androidaps/TestBase.kt (100%) rename plugins/{support => constraints}/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt (99%) rename plugins/{support => constraints}/src/test/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPluginTest.kt (100%) rename plugins/{main => constraints}/src/test/java/info/nightscout/plugins/constraints/objectives/ObjectivesPluginTest.kt (77%) rename plugins/{main => constraints}/src/test/java/info/nightscout/plugins/constraints/objectives/SntpClientTest.kt (69%) rename plugins/{support => constraints}/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt (100%) rename plugins/{support => constraints}/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/VersionCheckerUtilsKtTest.kt (100%) rename plugins/{support => constraints}/src/test/java/info/nightscout/plugins/constraints/storage/StorageConstraintPluginTest.kt (100%) rename plugins/{support => constraints}/src/test/java/info/nightscout/plugins/constraints/versionChecker/AllowedVersionsTest.kt (100%) delete mode 100644 plugins/main/src/main/java/info/nightscout/plugins/di/ObjectivesModule.kt delete mode 100644 plugins/support/src/main/AndroidManifest.xml diff --git a/app/build.gradle b/app/build.gradle index 79d8cc32b9..034941a068 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -198,10 +198,10 @@ dependencies { implementation project(':plugins:aps') implementation project(':plugins:automation') implementation project(':plugins:configuration') + implementation project(':plugins:constraints') implementation project(':plugins:main') implementation project(':plugins:openhumans') implementation project(':plugins:sensitivity') - implementation project(':plugins:support') implementation project(':plugins:sync') implementation project(':implementation') implementation project(':database:entities') diff --git a/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt b/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt index b69132a683..0acbea340a 100644 --- a/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt +++ b/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt @@ -21,8 +21,8 @@ import info.nightscout.core.validators.di.ValidatorsModule import info.nightscout.database.impl.DatabaseModule import info.nightscout.implementation.di.ImplementationModule import info.nightscout.plugins.aps.di.ApsModule +import info.nightscout.plugins.constraints.di.PluginsConstraintsModule import info.nightscout.plugins.di.PluginsModule -import info.nightscout.plugins.support.di.PluginsSupportModule import info.nightscout.plugins.sync.di.SyncModule import info.nightscout.pump.combo.di.ComboModule import info.nightscout.pump.combov2.di.ComboV2Module @@ -62,7 +62,7 @@ import javax.inject.Singleton SharedImplModule::class, UiModule::class, ValidatorsModule::class, - PluginsSupportModule::class, + PluginsConstraintsModule::class, SyncModule::class, WorkflowModule::class, diff --git a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt index b56861ef42..848cf738a2 100644 --- a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt @@ -11,7 +11,6 @@ import info.nightscout.androidaps.insight.database.InsightDatabaseDao import info.nightscout.androidaps.insight.database.InsightDbHelper import info.nightscout.androidaps.plugins.pump.insight.LocalInsightPlugin import info.nightscout.database.impl.AppRepository -import info.nightscout.implementation.constraints.ConstraintsImpl import info.nightscout.implementation.iob.GlucoseStatusProviderImpl import info.nightscout.interfaces.bgQualityCheck.BgQualityCheck import info.nightscout.interfaces.constraints.Constraint @@ -34,6 +33,7 @@ import info.nightscout.interfaces.utils.HardLimits import info.nightscout.plugins.aps.openAPSAMA.OpenAPSAMAPlugin import info.nightscout.plugins.aps.openAPSSMB.OpenAPSSMBPlugin import info.nightscout.plugins.aps.openAPSSMBDynamicISF.OpenAPSSMBDynamicISFPlugin +import info.nightscout.plugins.constraints.ConstraintsImpl import info.nightscout.plugins.constraints.objectives.ObjectivesPlugin import info.nightscout.plugins.constraints.objectives.objectives.Objective import info.nightscout.plugins.constraints.safety.SafetyPlugin @@ -103,33 +103,33 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { @BeforeEach fun prepare() { - `when`(rh.gs(info.nightscout.plugins.R.string.closed_loop_disabled_on_dev_branch)).thenReturn("Running dev version. Closed loop is disabled.") - `when`(rh.gs(info.nightscout.plugins.R.string.closedmodedisabledinpreferences)).thenReturn("Closed loop mode disabled in preferences") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.closed_loop_disabled_on_dev_branch)).thenReturn("Running dev version. Closed loop is disabled.") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.closedmodedisabledinpreferences)).thenReturn("Closed loop mode disabled in preferences") `when`(rh.gs(info.nightscout.core.ui.R.string.no_valid_basal_rate)).thenReturn("No valid basal rate read from pump") `when`(rh.gs(info.nightscout.plugins.aps.R.string.autosens_disabled_in_preferences)).thenReturn("Autosens disabled in preferences") `when`(rh.gs(info.nightscout.plugins.aps.R.string.smb_disabled_in_preferences)).thenReturn("SMB disabled in preferences") `when`(rh.gs(info.nightscout.core.ui.R.string.pumplimit)).thenReturn("pump limit") `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") - `when`(rh.gs(info.nightscout.plugins.R.string.maxvalueinpreferences)).thenReturn("max value in preferences") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.maxvalueinpreferences)).thenReturn("max value in preferences") `when`(rh.gs(info.nightscout.plugins.aps.R.string.max_basal_multiplier)).thenReturn("max basal multiplier") `when`(rh.gs(info.nightscout.plugins.aps.R.string.max_daily_basal_multiplier)).thenReturn("max daily basal multiplier") `when`(rh.gs(info.nightscout.core.ui.R.string.pumplimit)).thenReturn("pump limit") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbolus)).thenReturn("Limiting bolus to %.1f U because of %s") - `when`(rh.gs(info.nightscout.plugins.R.string.hardlimit)).thenReturn("hard limit") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.hardlimit)).thenReturn("hard limit") `when`(rh.gs(info.nightscout.core.utils.R.string.key_child)).thenReturn("child") - `when`(rh.gs(info.nightscout.plugins.R.string.limitingcarbs)).thenReturn("Limiting carbs to %d g because of %s") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.limitingcarbs)).thenReturn("Limiting carbs to %d g because of %s") `when`(rh.gs(info.nightscout.plugins.aps.R.string.limiting_iob)).thenReturn("Limiting IOB to %.1f U because of %s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingpercentrate)).thenReturn("Limiting max percent rate to %1\$d%% because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") - `when`(rh.gs(info.nightscout.plugins.R.string.smbnotallowedinopenloopmode)).thenReturn("SMB not allowed in open loop mode") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.smbnotallowedinopenloopmode)).thenReturn("SMB not allowed in open loop mode") `when`(rh.gs(info.nightscout.core.ui.R.string.pumplimit)).thenReturn("pump limit") - `when`(rh.gs(info.nightscout.plugins.R.string.smbalwaysdisabled)).thenReturn("SMB always and after carbs disabled because active BG source doesn\\'t support advanced filtering") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.smbalwaysdisabled)).thenReturn("SMB always and after carbs disabled because active BG source doesn\\'t support advanced filtering") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingpercentrate)).thenReturn("Limiting max percent rate to %1\$d%% because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbolus)).thenReturn("Limiting bolus to %1\$.1f U because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") `when`(context.getString(info.nightscout.pump.combo.R.string.combo_pump_unsupported_operation)).thenReturn("Requested operation not supported by pump") - `when`(rh.gs(info.nightscout.plugins.R.string.objectivenotstarted)).thenReturn("Objective %1\$d not started") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.objectivenotstarted)).thenReturn("Objective %1\$d not started") // RS constructor `when`(sp.getString(R.string.key_danars_name, "")).thenReturn("") @@ -242,7 +242,8 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { hardLimits, ConfigImpl(fileListProvider), iobCobCalculator, - dateUtil + dateUtil, + uiInteraction ) val constraintsPluginsList = ArrayList() constraintsPluginsList.add(safetyPlugin) diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt index e87048c860..2f121b9197 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt @@ -14,8 +14,8 @@ import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.profiling.Profiler import info.nightscout.interfaces.pump.defs.PumpDescription +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.plugins.aps.openAPSAMA.OpenAPSAMAPlugin import info.nightscout.plugins.aps.openAPSSMB.OpenAPSSMBPlugin import info.nightscout.plugins.constraints.safety.SafetyPlugin @@ -39,6 +39,7 @@ class SafetyPluginTest : TestBaseWithProfile() { @Mock lateinit var repository: AppRepository @Mock lateinit var glucoseStatusProvider: GlucoseStatusProvider @Mock lateinit var bgQualityCheck: BgQualityCheck + @Mock lateinit var uiInteraction: UiInteraction private lateinit var hardLimits: HardLimits private lateinit var safetyPlugin: SafetyPlugin @@ -50,24 +51,24 @@ class SafetyPluginTest : TestBaseWithProfile() { @BeforeEach fun prepare() { - `when`(rh.gs(R.string.hardlimit)).thenReturn("hard limit") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.hardlimit)).thenReturn("hard limit") `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") `when`(rh.gs(info.nightscout.core.ui.R.string.pumplimit)).thenReturn("pump limit") - `when`(rh.gs(R.string.maxvalueinpreferences)).thenReturn("max value in preferences") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.maxvalueinpreferences)).thenReturn("max value in preferences") `when`(rh.gs(info.nightscout.plugins.aps.R.string.max_daily_basal_multiplier)).thenReturn("max daily basal multiplier") `when`(rh.gs(info.nightscout.plugins.aps.R.string.max_basal_multiplier)).thenReturn("max basal multiplier") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbolus)).thenReturn("Limiting bolus to %1\$.1f U because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limiting_iob)).thenReturn("Limiting IOB to %1\$.1f U because of %2\$s") - `when`(rh.gs(R.string.limitingcarbs)).thenReturn("Limiting carbs to %1\$d g because of %2\$s") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.limitingcarbs)).thenReturn("Limiting carbs to %1\$d g because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingpercentrate)).thenReturn("Limiting max percent rate to %1\$d%% because of %2\$s") - `when`(rh.gs(R.string.pumpisnottempbasalcapable)).thenReturn("Pump is not temp basal capable") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.pumpisnottempbasalcapable)).thenReturn("Pump is not temp basal capable") `when`(rh.gs(info.nightscout.plugins.aps.R.string.increasing_max_basal)).thenReturn("Increasing max basal value because setting is lower than your max basal in profile") `when`(rh.gs(info.nightscout.plugins.aps.R.string.smb_disabled_in_preferences)).thenReturn("SMB disabled in preferences") - `when`(rh.gs(R.string.closedmodedisabledinpreferences)).thenReturn("Closed loop mode disabled in preferences") - `when`(rh.gs(R.string.closed_loop_disabled_on_dev_branch)).thenReturn("Running dev version. Closed loop is disabled.") - `when`(rh.gs(R.string.smbalwaysdisabled)).thenReturn("SMB always and after carbs disabled because active BG source doesn\\'t support advanced filtering") - `when`(rh.gs(R.string.smbnotallowedinopenloopmode)).thenReturn("SMB not allowed in open loop mode") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.closedmodedisabledinpreferences)).thenReturn("Closed loop mode disabled in preferences") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.closed_loop_disabled_on_dev_branch)).thenReturn("Running dev version. Closed loop is disabled.") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.smbalwaysdisabled)).thenReturn("SMB always and after carbs disabled because active BG source doesn\\'t support advanced filtering") + `when`(rh.gs(info.nightscout.plugins.constraints.R.string.smbnotallowedinopenloopmode)).thenReturn("SMB not allowed in open loop mode") `when`(rh.gs(info.nightscout.core.utils.R.string.key_child)).thenReturn("child") `when`(rh.gs(info.nightscout.core.ui.R.string.lowglucosesuspend)).thenReturn("Low Glucose Suspend") @@ -75,7 +76,7 @@ class SafetyPluginTest : TestBaseWithProfile() { `when`(virtualPumpPlugin.pumpDescription).thenReturn(pumpDescription) `when`(config.APS).thenReturn(true) hardLimits = HardLimitsMock(sp, rh) - safetyPlugin = SafetyPlugin(injector, aapsLogger, rh, sp, rxBus, constraintChecker, activePlugin, hardLimits, config, iobCobCalculator, dateUtil) + safetyPlugin = SafetyPlugin(injector, aapsLogger, rh, sp, rxBus, constraintChecker, activePlugin, hardLimits, config, iobCobCalculator, dateUtil, uiInteraction) openAPSAMAPlugin = OpenAPSAMAPlugin( injector, aapsLogger, rxBus, constraintChecker, rh, profileFunction, context, activePlugin, iobCobCalculator, hardLimits, profiler, fabricPrivacy, dateUtil, repository, glucoseStatusProvider, sp diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/actions/Actions.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/actions/Actions.kt new file mode 100644 index 0000000000..5aea890d62 --- /dev/null +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/actions/Actions.kt @@ -0,0 +1,3 @@ +package info.nightscout.interfaces.actions + +interface Actions \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/db/PersistenceLayer.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/db/PersistenceLayer.kt index 6e79d87efb..265dfd1e38 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/db/PersistenceLayer.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/db/PersistenceLayer.kt @@ -5,6 +5,7 @@ import info.nightscout.database.ValueWrapper import info.nightscout.database.entities.Bolus import info.nightscout.database.entities.BolusCalculatorResult import info.nightscout.database.entities.Carbs +import info.nightscout.database.entities.EffectiveProfileSwitch import info.nightscout.database.entities.TemporaryTarget import info.nightscout.database.entities.UserEntry import info.nightscout.interfaces.queue.Callback @@ -20,4 +21,5 @@ interface PersistenceLayer { fun getTemporaryTargetActiveAt(timestamp: Long): Single> fun getUserEntryFilteredDataFromTime(timestamp: Long): Single> + fun getEffectiveProfileSwitchActiveAt(timestamp: Long): Single> } \ No newline at end of file diff --git a/core/main/src/main/res/drawable/ic_graduation.xml b/core/ui/src/main/res/drawable/ic_graduation.xml similarity index 100% rename from core/main/src/main/res/drawable/ic_graduation.xml rename to core/ui/src/main/res/drawable/ic_graduation.xml diff --git a/core/ui/src/main/res/drawable/ic_trending_flat_white_48dp.xml b/core/ui/src/main/res/drawable/ic_trending_flat_white_48dp.xml new file mode 100644 index 0000000000..616da59765 --- /dev/null +++ b/core/ui/src/main/res/drawable/ic_trending_flat_white_48dp.xml @@ -0,0 +1,10 @@ + + + diff --git a/core/ui/src/main/res/values/strings.xml b/core/ui/src/main/res/values/strings.xml index ab131ced6f..fff892689b 100644 --- a/core/ui/src/main/res/values/strings.xml +++ b/core/ui/src/main/res/values/strings.xml @@ -165,6 +165,9 @@ ISF Canceling of temporary basal failed Canceling of extended bolus failed + Upload status to NS + Disabled/Suspended loop + Insulin on Board (IOB) Wrong password diff --git a/core/main/src/main/java/info/nightscout/core/extensions/JSONObjectExt.kt b/core/utils/src/main/java/info/nightscout/core/utils/extensions/JSONObjectExt.kt similarity index 100% rename from core/main/src/main/java/info/nightscout/core/extensions/JSONObjectExt.kt rename to core/utils/src/main/java/info/nightscout/core/utils/extensions/JSONObjectExt.kt diff --git a/core/utils/src/main/res/values/keys.xml b/core/utils/src/main/res/values/keys.xml index 0625a13e03..8377c4b5d7 100644 --- a/core/utils/src/main/res/values/keys.xml +++ b/core/utils/src/main/res/values/keys.xml @@ -145,5 +145,8 @@ protection_timeout ObjectivesLoopUsed ObjectivesmanualEnacts + ObjectivesActionsUsed + ObjectivesScaleUsed + virtualpump_uploadstatus \ No newline at end of file diff --git a/crowdin.yml b/crowdin.yml index f74a364df2..cc973cac47 100644 --- a/crowdin.yml +++ b/crowdin.yml @@ -27,8 +27,8 @@ files: translation: /plugins/sync/src/main/res/values-%android_code%/strings.xml translate_attributes: 0 content_segmentation: 0 - - source: /plugins/support/src/main/res/values/strings.xml - translation: /plugins/support/src/main/res/values-%android_code%/strings.xml + - source: /plugins/constraints/src/main/res/values/strings.xml + translation: /plugins/constraints/src/main/res/values-%android_code%/strings.xml - source: /core/graph/src/main/res/values/strings.xml translation: /core/graph/src/main/res/values-%android_code%/strings.xml - source: /core/interfaces/src/main/res/values/strings.xml diff --git a/implementation/src/main/java/info/nightscout/implementation/db/PersistenceLayerImpl.kt b/implementation/src/main/java/info/nightscout/implementation/db/PersistenceLayerImpl.kt index a66b479b59..6b99d9a8ca 100644 --- a/implementation/src/main/java/info/nightscout/implementation/db/PersistenceLayerImpl.kt +++ b/implementation/src/main/java/info/nightscout/implementation/db/PersistenceLayerImpl.kt @@ -6,6 +6,7 @@ import info.nightscout.database.ValueWrapper import info.nightscout.database.entities.Bolus import info.nightscout.database.entities.BolusCalculatorResult import info.nightscout.database.entities.Carbs +import info.nightscout.database.entities.EffectiveProfileSwitch import info.nightscout.database.entities.TemporaryTarget import info.nightscout.database.entities.UserEntry import info.nightscout.database.impl.AppRepository @@ -68,4 +69,5 @@ class PersistenceLayerImpl @Inject constructor( override fun getTemporaryTargetActiveAt(timestamp: Long): Single> = repository.getTemporaryTargetActiveAt(timestamp) override fun getUserEntryFilteredDataFromTime(timestamp: Long): Single> = repository.getUserEntryFilteredDataFromTime(timestamp) + override fun getEffectiveProfileSwitchActiveAt(timestamp: Long): Single> = repository.getEffectiveProfileSwitchActiveAt(timestamp) } diff --git a/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt b/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt index cf5844835e..d230e45523 100644 --- a/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt +++ b/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt @@ -14,7 +14,6 @@ import info.nightscout.implementation.TrendCalculatorImpl import info.nightscout.implementation.UserEntryLoggerImpl import info.nightscout.implementation.XDripBroadcastImpl import info.nightscout.implementation.androidNotification.NotificationHolderImpl -import info.nightscout.implementation.constraints.ConstraintsImpl import info.nightscout.implementation.db.PersistenceLayerImpl import info.nightscout.implementation.iob.GlucoseStatusProviderImpl import info.nightscout.implementation.logging.LoggerUtilsImpl @@ -47,7 +46,6 @@ import info.nightscout.interfaces.LocalAlertUtils import info.nightscout.interfaces.NotificationHolder import info.nightscout.interfaces.Translator import info.nightscout.interfaces.XDripBroadcast -import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.db.PersistenceLayer import info.nightscout.interfaces.iob.GlucoseStatusProvider import info.nightscout.interfaces.logging.LoggerUtils @@ -121,7 +119,6 @@ abstract class ImplementationModule { @Binds fun bindIconsProviderInterface(iconsProvider: IconsProviderImplementation): IconsProvider @Binds fun bindNotificationHolderInterface(notificationHolder: NotificationHolderImpl): NotificationHolder @Binds fun bindCommandQueue(commandQueue: CommandQueueImplementation): CommandQueue - @Binds fun bindsConstraints(constraintsImpl: ConstraintsImpl): Constraints @Binds fun bindsProfileFunction(profileFunctionImpl: ProfileFunctionImpl): ProfileFunction @Binds fun bindsStorage(fileStorage: FileStorage): Storage @Binds fun bindsReceiverStatusStore(receiverStatusStoreImpl: ReceiverStatusStoreImpl): ReceiverStatusStore diff --git a/implementation/src/main/java/info/nightscout/implementation/userEntry/UserEntryPresentationHelperImpl.kt b/implementation/src/main/java/info/nightscout/implementation/userEntry/UserEntryPresentationHelperImpl.kt index c39b5ede07..e3b0417edd 100644 --- a/implementation/src/main/java/info/nightscout/implementation/userEntry/UserEntryPresentationHelperImpl.kt +++ b/implementation/src/main/java/info/nightscout/implementation/userEntry/UserEntryPresentationHelperImpl.kt @@ -81,7 +81,7 @@ class UserEntryPresentationHelperImpl @Inject constructor( Sources.Maintenance -> info.nightscout.core.ui.R.drawable.ic_maintenance Sources.NSClient -> info.nightscout.core.ui.R.drawable.ic_nightscout_syncs Sources.NSProfile -> R.drawable.ic_nightscout_profile - Sources.Objectives -> R.drawable.ic_graduation + Sources.Objectives -> info.nightscout.core.ui.R.drawable.ic_graduation Sources.Pump -> info.nightscout.core.ui.R.drawable.ic_generic_icon Sources.Dana -> info.nightscout.core.ui.R.drawable.ic_danars_128 Sources.DanaR -> info.nightscout.core.ui.R.drawable.ic_danars_128 diff --git a/plugins/support/.gitignore b/plugins/constraints/.gitignore similarity index 100% rename from plugins/support/.gitignore rename to plugins/constraints/.gitignore diff --git a/plugins/support/build.gradle b/plugins/constraints/build.gradle similarity index 89% rename from plugins/support/build.gradle rename to plugins/constraints/build.gradle index 628361f6ae..84ee406dd7 100644 --- a/plugins/support/build.gradle +++ b/plugins/constraints/build.gradle @@ -12,7 +12,7 @@ apply from: "${project.rootDir}/core/main/test_dependencies.gradle" apply from: "${project.rootDir}/core/main/allopen_dependencies.gradle" apply from: "${project.rootDir}/core/main/jacoco_global.gradle" android { - namespace 'info.nightscout.plugins.support' + namespace 'info.nightscout.plugins.constraints' } dependencies { @@ -20,6 +20,7 @@ dependencies { implementation project(':core:interfaces') implementation project(':core:ui') implementation project(':core:utils') + implementation project(':core:validators') implementation project(':database:entities') // Phone checker diff --git a/plugins/support/consumer-rules.pro b/plugins/constraints/consumer-rules.pro similarity index 100% rename from plugins/support/consumer-rules.pro rename to plugins/constraints/consumer-rules.pro diff --git a/plugins/support/proguard-rules.pro b/plugins/constraints/proguard-rules.pro similarity index 100% rename from plugins/support/proguard-rules.pro rename to plugins/constraints/proguard-rules.pro diff --git a/plugins/constraints/src/main/AndroidManifest.xml b/plugins/constraints/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..44008a4332 --- /dev/null +++ b/plugins/constraints/src/main/AndroidManifest.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/implementation/src/main/java/info/nightscout/implementation/constraints/ConstraintsImpl.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/ConstraintsImpl.kt similarity index 99% rename from implementation/src/main/java/info/nightscout/implementation/constraints/ConstraintsImpl.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/ConstraintsImpl.kt index c589264403..923619063e 100644 --- a/implementation/src/main/java/info/nightscout/implementation/constraints/ConstraintsImpl.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/ConstraintsImpl.kt @@ -1,4 +1,4 @@ -package info.nightscout.implementation.constraints +package info.nightscout.plugins.constraints import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints diff --git a/plugins/support/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt similarity index 99% rename from plugins/support/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt index 769c318936..744c215204 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPlugin.kt @@ -12,7 +12,7 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.DexcomBoyda -import info.nightscout.plugins.support.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventBucketedDataCreated diff --git a/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/di/ObjectivesModule.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/di/ObjectivesModule.kt new file mode 100644 index 0000000000..00cc3d6825 --- /dev/null +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/di/ObjectivesModule.kt @@ -0,0 +1,25 @@ +package info.nightscout.plugins.constraints.di + +import dagger.Module +import dagger.android.ContributesAndroidInjector + +@Module +@Suppress("unused") +abstract class ObjectivesModule { + + @ContributesAndroidInjector abstract fun contributesObjectivesFragment(): info.nightscout.plugins.constraints.objectives.ObjectivesFragment + @ContributesAndroidInjector abstract fun contributesObjectivesExamDialog(): info.nightscout.plugins.constraints.objectives.activities.ObjectivesExamDialog + @ContributesAndroidInjector abstract fun contributesNtpProgressDialog(): info.nightscout.plugins.constraints.objectives.dialogs.NtpProgressDialog + + @ContributesAndroidInjector abstract fun objectiveInjector(): info.nightscout.plugins.constraints.objectives.objectives.Objective + @ContributesAndroidInjector abstract fun objective0Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective0 + @ContributesAndroidInjector abstract fun objective1Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective1 + @ContributesAndroidInjector abstract fun objective2Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective2 + @ContributesAndroidInjector abstract fun objective3Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective3 + @ContributesAndroidInjector abstract fun objective4Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective4 + @ContributesAndroidInjector abstract fun objective5Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective5 + @ContributesAndroidInjector abstract fun objective6Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective6 + @ContributesAndroidInjector abstract fun objective7Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective7 + @ContributesAndroidInjector abstract fun objective9Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective9 + @ContributesAndroidInjector abstract fun objective10Injector(): info.nightscout.plugins.constraints.objectives.objectives.Objective10 +} \ No newline at end of file diff --git a/plugins/support/src/main/java/info/nightscout/plugins/support/di/PluginsSupportModule.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/di/PluginsConstraintsModule.kt similarity index 64% rename from plugins/support/src/main/java/info/nightscout/plugins/support/di/PluginsSupportModule.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/di/PluginsConstraintsModule.kt index 17ed884fd1..c3da1e525a 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/support/di/PluginsSupportModule.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/di/PluginsConstraintsModule.kt @@ -1,25 +1,28 @@ -package info.nightscout.plugins.support.di +package info.nightscout.plugins.constraints.di import dagger.Binds import dagger.Module import info.nightscout.interfaces.bgQualityCheck.BgQualityCheck +import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.versionChecker.VersionCheckerUtils import info.nightscout.plugins.constraints.bgQualityCheck.BgQualityCheckPlugin import info.nightscout.plugins.constraints.versionChecker.VersionCheckerUtilsImpl @Module( includes = [ - PluginsSupportModule.Bindings::class + PluginsConstraintsModule.Bindings::class, + ObjectivesModule::class ] ) @Suppress("unused") -abstract class PluginsSupportModule { +abstract class PluginsConstraintsModule { @Module interface Bindings { @Binds fun bindProcessedDeviceStatusData(versionCheckerUtils: VersionCheckerUtilsImpl): VersionCheckerUtils @Binds fun bindBgQualityCheck(bgQualityCheck: BgQualityCheckPlugin): BgQualityCheck + @Binds fun bindsConstraints(constraintsImpl: info.nightscout.plugins.constraints.ConstraintsImpl): Constraints } } \ No newline at end of file diff --git a/plugins/support/src/main/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPlugin.kt similarity index 98% rename from plugins/support/src/main/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPlugin.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPlugin.kt index 67c7d4350b..ba7293a6ee 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPlugin.kt @@ -9,7 +9,7 @@ import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType -import info.nightscout.plugins.support.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesFragment.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesFragment.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesFragment.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesFragment.kt index 09086dbdb7..4988d893d3 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesFragment.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesFragment.kt @@ -24,13 +24,13 @@ import info.nightscout.database.entities.ValueWithUnit import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.receivers.ReceiverStatusStore import info.nightscout.interfaces.utils.HtmlHelper -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R +import info.nightscout.plugins.constraints.databinding.ObjectivesFragmentBinding +import info.nightscout.plugins.constraints.databinding.ObjectivesItemBinding import info.nightscout.plugins.constraints.objectives.activities.ObjectivesExamDialog import info.nightscout.plugins.constraints.objectives.dialogs.NtpProgressDialog import info.nightscout.plugins.constraints.objectives.events.EventObjectivesUpdateGui import info.nightscout.plugins.constraints.objectives.objectives.Objective.ExamTask -import info.nightscout.plugins.databinding.ObjectivesFragmentBinding -import info.nightscout.plugins.databinding.ObjectivesItemBinding import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventNtpStatus diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesPlugin.kt similarity index 95% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesPlugin.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesPlugin.kt index 87bac53864..5495d609a6 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/ObjectivesPlugin.kt @@ -15,7 +15,7 @@ import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.plugins.constraints.objectives.objectives.Objective import info.nightscout.plugins.constraints.objectives.objectives.Objective0 import info.nightscout.plugins.constraints.objectives.objectives.Objective1 @@ -47,7 +47,7 @@ class ObjectivesPlugin @Inject constructor( .fragmentClass(ObjectivesFragment::class.qualifiedName) .alwaysEnabled(config.APS) .showInList(config.APS) - .pluginIcon(info.nightscout.core.main.R.drawable.ic_graduation) + .pluginIcon(info.nightscout.core.ui.R.drawable.ic_graduation) .pluginName(info.nightscout.core.ui.R.string.objectives) .shortName(R.string.objectives_shortname) .description(R.string.description_objectives), @@ -91,9 +91,9 @@ class ObjectivesPlugin @Inject constructor( sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveusedisconnect, false) sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveusereconnect, false) sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveusetemptarget, false) - sp.putBoolean(R.string.key_objectiveuseactions, false) + sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveuseactions, false) sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveuseloop, false) - sp.putBoolean(R.string.key_objectiveusescale, false) + sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveusescale, false) } fun allPriorAccomplished(position: Int): Boolean { diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/SntpClient.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/SntpClient.kt similarity index 100% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/SntpClient.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/SntpClient.kt diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/activities/ObjectivesExamDialog.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/activities/ObjectivesExamDialog.kt similarity index 97% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/activities/ObjectivesExamDialog.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/activities/ObjectivesExamDialog.kt index 12ff59c4a6..3ac4ebfdda 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/activities/ObjectivesExamDialog.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/activities/ObjectivesExamDialog.kt @@ -6,12 +6,12 @@ import android.view.View import android.view.ViewGroup import dagger.android.support.DaggerDialogFragment import info.nightscout.core.ui.toast.ToastUtils -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R +import info.nightscout.plugins.constraints.databinding.ObjectivesExamFragmentBinding import info.nightscout.plugins.constraints.objectives.events.EventObjectivesUpdateGui import info.nightscout.plugins.constraints.objectives.objectives.Objective import info.nightscout.plugins.constraints.objectives.objectives.Objective.ExamTask import info.nightscout.plugins.constraints.objectives.objectives.Objective.Option -import info.nightscout.plugins.databinding.ObjectivesExamFragmentBinding import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.utils.DateUtil diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/dialogs/NtpProgressDialog.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/dialogs/NtpProgressDialog.kt similarity index 97% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/dialogs/NtpProgressDialog.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/dialogs/NtpProgressDialog.kt index 57ccf39b78..0c8b0738e8 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/dialogs/NtpProgressDialog.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/dialogs/NtpProgressDialog.kt @@ -7,7 +7,7 @@ import android.view.View import android.view.ViewGroup import dagger.android.support.DaggerDialogFragment import info.nightscout.core.utils.fabric.FabricPrivacy -import info.nightscout.plugins.databinding.DialogNtpProgressBinding +import info.nightscout.plugins.constraints.databinding.DialogNtpProgressBinding import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventNtpStatus diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/events/EventObjectivesUpdateGui.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/events/EventObjectivesUpdateGui.kt similarity index 100% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/events/EventObjectivesUpdateGui.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/events/EventObjectivesUpdateGui.kt diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective.kt similarity index 99% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective.kt index 2997e5205a..1240acc248 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective.kt @@ -7,7 +7,7 @@ import android.widget.TextView import androidx.annotation.StringRes import androidx.fragment.app.FragmentActivity import dagger.android.HasAndroidInjector -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective0.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective0.kt similarity index 80% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective0.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective0.kt index d9cf32069d..d995f6e897 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective0.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective0.kt @@ -2,20 +2,20 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector import info.nightscout.database.ValueWrapper -import info.nightscout.database.impl.AppRepository import info.nightscout.interfaces.aps.Loop +import info.nightscout.interfaces.db.PersistenceLayer import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase -import info.nightscout.plugins.R -import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin +import info.nightscout.interfaces.pump.VirtualPump +import info.nightscout.plugins.constraints.R import javax.inject.Inject class Objective0(injector: HasAndroidInjector) : Objective(injector, "config", R.string.objectives_0_objective, R.string.objectives_0_gate) { @Inject lateinit var activePlugin: ActivePlugin - @Inject lateinit var virtualPumpPlugin: VirtualPumpPlugin - @Inject lateinit var repository: AppRepository + @Inject lateinit var virtualPumpPlugin: VirtualPump + @Inject lateinit var persistenceLayer: PersistenceLayer @Inject lateinit var loop: Loop @Inject lateinit var iobCobCalculator: IobCobCalculator @@ -30,9 +30,9 @@ class Objective0(injector: HasAndroidInjector) : Objective(injector, "config", R return activePlugin.firstActiveSync?.hasWritePermission == true } }) - tasks.add(object : Task(this, R.string.virtualpump_uploadstatus_title) { + tasks.add(object : Task(this, info.nightscout.core.ui.R.string.virtualpump_uploadstatus_title) { override fun isCompleted(): Boolean { - return sp.getBoolean(R.string.key_virtual_pump_upload_status, false) + return sp.getBoolean(info.nightscout.core.utils.R.string.key_virtual_pump_upload_status, false) } override fun shouldBeIgnored(): Boolean { @@ -62,7 +62,7 @@ class Objective0(injector: HasAndroidInjector) : Objective(injector, "config", R }) tasks.add(object : Task(this, info.nightscout.core.ui.R.string.activate_profile) { override fun isCompleted(): Boolean { - return repository.getEffectiveProfileSwitchActiveAt(dateUtil.now()).blockingGet() is ValueWrapper.Existing + return persistenceLayer.getEffectiveProfileSwitchActiveAt(dateUtil.now()).blockingGet() is ValueWrapper.Existing } }) } diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective1.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective1.kt similarity index 76% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective1.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective1.kt index bc396d2757..63f9fee48c 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective1.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective1.kt @@ -1,13 +1,17 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector -import info.nightscout.plugins.R -import info.nightscout.plugins.general.actions.ActionsPlugin +import info.nightscout.interfaces.actions.Actions +import info.nightscout.interfaces.plugin.ActivePlugin +import info.nightscout.interfaces.plugin.PluginBase +import info.nightscout.plugins.constraints.R import javax.inject.Inject class Objective1 @Inject constructor(injector: HasAndroidInjector) : Objective(injector, "usage", R.string.objectives_usage_objective, R.string.objectives_usage_gate) { - @Inject lateinit var actionsPlugin: ActionsPlugin + @Inject lateinit var activePlugin: ActivePlugin + val actionsPlugin: PluginBase + get() = activePlugin.getSpecificPluginsListByInterface(Actions::class.java)[0] init { tasks.add(object : Task(this, R.string.objectives_useprofileswitch) { @@ -32,7 +36,7 @@ class Objective1 @Inject constructor(injector: HasAndroidInjector) : Objective(i }.hint(Hint(R.string.usetemptarget_hint))) tasks.add(object : Task(this, R.string.objectives_useactions) { override fun isCompleted(): Boolean { - return sp.getBoolean(R.string.key_objectiveuseactions, false) && actionsPlugin.isEnabled() && actionsPlugin.isFragmentVisible() + return sp.getBoolean(info.nightscout.core.utils.R.string.key_objectiveuseactions, false) && actionsPlugin.isEnabled() && actionsPlugin.isFragmentVisible() } }.hint(Hint(R.string.useaction_hint))) tasks.add(object : Task(this, R.string.objectives_useloop) { @@ -42,7 +46,7 @@ class Objective1 @Inject constructor(injector: HasAndroidInjector) : Objective(i }.hint(Hint(R.string.useaction_hint))) tasks.add(object : Task(this, R.string.objectives_usescale) { override fun isCompleted(): Boolean { - return sp.getBoolean(R.string.key_objectiveusescale, false) + return sp.getBoolean(info.nightscout.core.utils.R.string.key_objectiveusescale, false) } }.hint(Hint(R.string.usescale_hint))) } diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective10.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective10.kt similarity index 89% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective10.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective10.kt index 45e9375d78..191a39e3af 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective10.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective10.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.shared.utils.T class Objective10(injector: HasAndroidInjector) : Objective(injector, "auto", R.string.objectives_auto_objective, R.string.objectives_auto_gate) { diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective2.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective2.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective2.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective2.kt index 827870976b..d4df12668a 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective2.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective2.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R @Suppress("SpellCheckingInspection") class Objective2(injector: HasAndroidInjector) : Objective(injector, "exam", R.string.objectives_exam_objective, R.string.objectives_exam_gate) { @@ -172,7 +172,7 @@ class Objective2(injector: HasAndroidInjector) : Objective(injector, "exam", R.s .option(Option(R.string.wronginsulin_prime, true)) .option(Option(R.string.wrongcarbs_donothing, false)) ) - tasks.add(ExamTask(this, R.string.iob_label, R.string.blank, "iob") + tasks.add(ExamTask(this, info.nightscout.core.ui.R.string.iob_label, R.string.blank, "iob") .option(Option(R.string.iob_value, true)) .option(Option(R.string.iob_hightemp, false)) .option(Option(R.string.iob_negiob, true)) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective3.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective3.kt similarity index 96% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective3.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective3.kt index 8ca5e8334c..d2b7c83a1c 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective3.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective3.kt @@ -2,7 +2,7 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector import info.nightscout.interfaces.plugin.ActivePlugin -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.shared.utils.T import javax.inject.Inject diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective4.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective4.kt similarity index 86% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective4.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective4.kt index 1871038194..83f6ec9603 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective4.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective4.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R @Suppress("SpellCheckingInspection") class Objective4(injector: HasAndroidInjector) : Objective(injector, "maxbasal", R.string.objectives_maxbasal_objective, R.string.objectives_maxbasal_gate) \ No newline at end of file diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective5.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective5.kt similarity index 95% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective5.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective5.kt index 35b5024cc0..3ce315df93 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective5.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective5.kt @@ -2,7 +2,7 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector import info.nightscout.interfaces.constraints.Constraint -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.plugins.constraints.safety.SafetyPlugin import info.nightscout.shared.utils.T import javax.inject.Inject diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective6.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective6.kt similarity index 95% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective6.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective6.kt index 3e03e9782d..2411aa7697 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective6.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective6.kt @@ -2,7 +2,7 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector import info.nightscout.interfaces.constraints.Constraints -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.shared.utils.T import javax.inject.Inject diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective7.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective7.kt similarity index 89% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective7.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective7.kt index 4ace165453..6893df0814 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective7.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective7.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.shared.utils.T class Objective7(injector: HasAndroidInjector) : Objective(injector, "autosens", R.string.objectives_autosens_objective, R.string.objectives_autosens_gate) { diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective9.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective9.kt similarity index 89% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective9.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective9.kt index 3031f9d283..340e451162 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective9.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/Objective9.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.constraints.objectives.objectives import dagger.android.HasAndroidInjector -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.shared.utils.T class Objective9(injector: HasAndroidInjector) : Objective(injector, "smb", R.string.objectives_smb_objective, R.string.objectives_smb_gate) { diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/SntpClient.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/SntpClient.kt similarity index 100% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/SntpClient.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/objectives/objectives/SntpClient.kt diff --git a/plugins/support/src/main/java/info/nightscout/plugins/constraints/phoneChecker/PhoneCheckerPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/phoneChecker/PhoneCheckerPlugin.kt similarity index 97% rename from plugins/support/src/main/java/info/nightscout/plugins/constraints/phoneChecker/PhoneCheckerPlugin.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/phoneChecker/PhoneCheckerPlugin.kt index 351738d076..689bdd57a0 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/constraints/phoneChecker/PhoneCheckerPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/phoneChecker/PhoneCheckerPlugin.kt @@ -8,7 +8,7 @@ import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType -import info.nightscout.plugins.support.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper import javax.inject.Inject diff --git a/plugins/main/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt similarity index 96% rename from plugins/main/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt index 8d79bf7d42..7dfaa68fcb 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt @@ -1,7 +1,6 @@ package info.nightscout.plugins.constraints.safety import dagger.android.HasAndroidInjector -import info.nightscout.core.events.EventNewNotification import info.nightscout.core.extensions.putDouble import info.nightscout.core.extensions.putInt import info.nightscout.core.extensions.putString @@ -20,10 +19,11 @@ import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.pump.defs.PumpDescription +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.DecimalFormatter import info.nightscout.interfaces.utils.HardLimits import info.nightscout.interfaces.utils.Round -import info.nightscout.plugins.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper @@ -45,7 +45,8 @@ class SafetyPlugin @Inject constructor( private val hardLimits: HardLimits, private val config: Config, private val iobCobCalculator: IobCobCalculator, - private val dateUtil: DateUtil + private val dateUtil: DateUtil, + private val uiInteraction: UiInteraction ) : PluginBase( PluginDescription() .mainType(PluginType.CONSTRAINTS) @@ -70,8 +71,7 @@ class SafetyPlugin @Inject constructor( if (mode == "open") value.set(aapsLogger, false, rh.gs(R.string.closedmodedisabledinpreferences), this) if (!config.isEngineeringModeOrRelease()) { if (value.value()) { - val n = Notification(Notification.TOAST_ALARM, rh.gs(R.string.closed_loop_disabled_on_dev_branch), Notification.NORMAL) - rxBus.send(EventNewNotification(n)) + uiInteraction.addNotification(Notification.TOAST_ALARM, rh.gs(R.string.closed_loop_disabled_on_dev_branch), Notification.NORMAL) } value.set(aapsLogger, false, rh.gs(R.string.closed_loop_disabled_on_dev_branch), this) } diff --git a/plugins/support/src/main/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPlugin.kt similarity index 99% rename from plugins/support/src/main/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPlugin.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPlugin.kt index 6283c3c6bb..6aaff96f09 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPlugin.kt @@ -12,7 +12,7 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.ui.UiInteraction -import info.nightscout.plugins.support.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP diff --git a/plugins/support/src/main/java/info/nightscout/plugins/constraints/storage/StorageConstraintPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/storage/StorageConstraintPlugin.kt similarity index 98% rename from plugins/support/src/main/java/info/nightscout/plugins/constraints/storage/StorageConstraintPlugin.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/storage/StorageConstraintPlugin.kt index 801b43c4c2..7fbc119539 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/constraints/storage/StorageConstraintPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/storage/StorageConstraintPlugin.kt @@ -12,7 +12,7 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.ui.UiInteraction -import info.nightscout.plugins.support.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/support/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerPlugin.kt similarity index 99% rename from plugins/support/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerPlugin.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerPlugin.kt index 0022644fb1..47b67fa3ab 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerPlugin.kt @@ -10,7 +10,7 @@ import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.versionChecker.VersionCheckerUtils -import info.nightscout.plugins.support.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/support/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerUtilsImpl.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerUtilsImpl.kt similarity index 99% rename from plugins/support/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerUtilsImpl.kt rename to plugins/constraints/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerUtilsImpl.kt index 2996bf6562..c688ec10d9 100644 --- a/plugins/support/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerUtilsImpl.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/versionChecker/VersionCheckerUtilsImpl.kt @@ -8,7 +8,7 @@ import info.nightscout.interfaces.notifications.Notification import info.nightscout.interfaces.receivers.ReceiverStatusStore import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.versionChecker.VersionCheckerUtils -import info.nightscout.plugins.support.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/support/src/main/res/drawable/ic_baseline_trending_flat_24.xml b/plugins/constraints/src/main/res/drawable/ic_baseline_trending_flat_24.xml similarity index 100% rename from plugins/support/src/main/res/drawable/ic_baseline_trending_flat_24.xml rename to plugins/constraints/src/main/res/drawable/ic_baseline_trending_flat_24.xml diff --git a/plugins/support/src/main/res/drawable/ic_baseline_warning_24_red.xml b/plugins/constraints/src/main/res/drawable/ic_baseline_warning_24_red.xml similarity index 100% rename from plugins/support/src/main/res/drawable/ic_baseline_warning_24_red.xml rename to plugins/constraints/src/main/res/drawable/ic_baseline_warning_24_red.xml diff --git a/plugins/support/src/main/res/drawable/ic_baseline_warning_24_yellow.xml b/plugins/constraints/src/main/res/drawable/ic_baseline_warning_24_yellow.xml similarity index 100% rename from plugins/support/src/main/res/drawable/ic_baseline_warning_24_yellow.xml rename to plugins/constraints/src/main/res/drawable/ic_baseline_warning_24_yellow.xml diff --git a/plugins/main/src/main/res/layout/dialog_ntp_progress.xml b/plugins/constraints/src/main/res/layout/dialog_ntp_progress.xml similarity index 100% rename from plugins/main/src/main/res/layout/dialog_ntp_progress.xml rename to plugins/constraints/src/main/res/layout/dialog_ntp_progress.xml diff --git a/plugins/main/src/main/res/layout/objectives_exam_fragment.xml b/plugins/constraints/src/main/res/layout/objectives_exam_fragment.xml similarity index 98% rename from plugins/main/src/main/res/layout/objectives_exam_fragment.xml rename to plugins/constraints/src/main/res/layout/objectives_exam_fragment.xml index d4a0f4d59b..6e1334a7da 100644 --- a/plugins/main/src/main/res/layout/objectives_exam_fragment.xml +++ b/plugins/constraints/src/main/res/layout/objectives_exam_fragment.xml @@ -4,7 +4,7 @@ xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" - tools:context="constraints.objectives.activities.ObjectivesExamDialog"> + tools:context=".constraints.objectives.activities.ObjectivesExamDialog"> Leave your blood glucose target unchanged. Wait until blood glucose drops below your hypo temp target and then eat 15 g of fast acting carbohydrates. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Disabled/Suspended loop Do I receive insulin when the loop is disabled/suspended? Yes, basal insulin continues to be delivered. No, delivery of insulin is stopped. @@ -149,7 +148,6 @@ Setting profile to 150% will take absorbing carbs a longer time Setting profile to 150% will take absorbing carbs a shorter time Setting profile to 150% will not affect calculated carbs absorption - Insulin on Board (IOB) IOB value is affected by issued temporary basals. High temp basal will not be given when your blood sugar is below target. Negative IOB for a substantial period in the absence of exercise suggests your profile is too strong and less insulin is needed in your settings. diff --git a/plugins/main/src/main/res/values/objectives.xml b/plugins/constraints/src/main/res/values/objectives.xml similarity index 97% rename from plugins/main/src/main/res/values/objectives.xml rename to plugins/constraints/src/main/res/values/objectives.xml index 20a67d7b8a..578c31677a 100644 --- a/plugins/main/src/main/res/values/objectives.xml +++ b/plugins/constraints/src/main/res/values/objectives.xml @@ -1,7 +1,5 @@ - ObjectivesActionsUsed - ObjectivesScaleUsed objectives_request_code Start diff --git a/plugins/support/src/main/res/values/strings.xml b/plugins/constraints/src/main/res/values/strings.xml similarity index 55% rename from plugins/support/src/main/res/values/strings.xml rename to plugins/constraints/src/main/res/values/strings.xml index fd881037b8..c6aa95b54d 100644 --- a/plugins/support/src/main/res/values/strings.xml +++ b/plugins/constraints/src/main/res/values/strings.xml @@ -41,4 +41,38 @@ double entries Flat data. Considered to be wrong + + Limiting extended bolus to %1$.1f U because of %2$s + Limiting carbs to %1$d g because of %2$s + + Safety + Pump is not temp basal capable + Closed loop mode disabled in preferences + Running dev version. Closed loop is disabled. + Closed loop disabled because of running Extended bolus + SMB always and after carbs disabled because active BG source doesn\'t support advanced filtering + SMB not allowed in open loop mode + max value in preferences + hard limit + Treatments safety + + + Completed, well done! + Not completed yet + Time elapsed + Maximal IOB set properly + BG available from selected source + Synchronization service has write permission + Loop enabled + APS selected + Closed mode enabled + OBJ + Learning program + Do you want reset objective start? You may lose your progress. + Next + Prev + Clear finished + Clear started + + \ No newline at end of file diff --git a/plugins/main/src/main/res/xml/pref_safety.xml b/plugins/constraints/src/main/res/xml/pref_safety.xml similarity index 100% rename from plugins/main/src/main/res/xml/pref_safety.xml rename to plugins/constraints/src/main/res/xml/pref_safety.xml diff --git a/plugins/support/src/test/java/info/nightscout/androidaps/TestBase.kt b/plugins/constraints/src/test/java/info/nightscout/androidaps/TestBase.kt similarity index 100% rename from plugins/support/src/test/java/info/nightscout/androidaps/TestBase.kt rename to plugins/constraints/src/test/java/info/nightscout/androidaps/TestBase.kt diff --git a/plugins/support/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt similarity index 99% rename from plugins/support/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt rename to plugins/constraints/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt index 6cd80f9448..308804fed9 100644 --- a/plugins/support/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt +++ b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt @@ -12,7 +12,7 @@ import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.source.BgSource import info.nightscout.interfaces.source.DexcomBoyda -import info.nightscout.plugins.support.R +import info.nightscout.plugins.constraints.R import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.utils.DateUtil diff --git a/plugins/support/src/test/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPluginTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPluginTest.kt similarity index 100% rename from plugins/support/src/test/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPluginTest.kt rename to plugins/constraints/src/test/java/info/nightscout/plugins/constraints/dstHelper/DstHelperPluginTest.kt diff --git a/plugins/main/src/test/java/info/nightscout/plugins/constraints/objectives/ObjectivesPluginTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/objectives/ObjectivesPluginTest.kt similarity index 77% rename from plugins/main/src/test/java/info/nightscout/plugins/constraints/objectives/ObjectivesPluginTest.kt rename to plugins/constraints/src/test/java/info/nightscout/plugins/constraints/objectives/ObjectivesPluginTest.kt index dccee93785..ca38062636 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/constraints/objectives/ObjectivesPluginTest.kt +++ b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/objectives/ObjectivesPluginTest.kt @@ -7,12 +7,11 @@ import info.nightscout.interfaces.Config import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Objectives import info.nightscout.interfaces.plugin.ActivePlugin -import info.nightscout.plugins.R -import info.nightscout.plugins.constraints.objectives.objectives.Objective +import info.nightscout.plugins.constraints.R import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -30,7 +29,7 @@ class ObjectivesPluginTest : TestBase() { val injector = HasAndroidInjector { AndroidInjector { - if (it is Objective) { + if (it is info.nightscout.plugins.constraints.objectives.objectives.Objective) { it.sp = sp it.rh = rh it.dateUtil = dateUtil @@ -51,8 +50,8 @@ class ObjectivesPluginTest : TestBase() { objectivesPlugin.objectives[Objectives.FIRST_OBJECTIVE].startedOn = 0 var c = Constraint(true) c = objectivesPlugin.isLoopInvocationAllowed(c) - Assert.assertEquals("Objectives: Objective 1 not started", c.getReasons(aapsLogger)) - Assert.assertEquals(false, c.value()) + Assertions.assertEquals("Objectives: Objective 1 not started", c.getReasons(aapsLogger)) + Assertions.assertEquals(false, c.value()) objectivesPlugin.objectives[Objectives.FIRST_OBJECTIVE].startedOn = dateUtil.now() } @@ -60,23 +59,23 @@ class ObjectivesPluginTest : TestBase() { objectivesPlugin.objectives[Objectives.MAXIOB_ZERO_CL_OBJECTIVE].startedOn = 0 var c = Constraint(true) c = objectivesPlugin.isClosedLoopAllowed(c) - Assert.assertEquals(true, c.getReasons(aapsLogger).contains("Objective 6 not started")) - Assert.assertEquals(false, c.value()) + Assertions.assertEquals(true, c.getReasons(aapsLogger).contains("Objective 6 not started")) + Assertions.assertEquals(false, c.value()) } @Test fun notStartedObjective8ShouldLimitAutosensMode() { objectivesPlugin.objectives[Objectives.AUTOSENS_OBJECTIVE].startedOn = 0 var c = Constraint(true) c = objectivesPlugin.isAutosensModeEnabled(c) - Assert.assertEquals(true, c.getReasons(aapsLogger).contains("Objective 8 not started")) - Assert.assertEquals(false, c.value()) + Assertions.assertEquals(true, c.getReasons(aapsLogger).contains("Objective 8 not started")) + Assertions.assertEquals(false, c.value()) } @Test fun notStartedObjective10ShouldLimitSMBMode() { objectivesPlugin.objectives[Objectives.SMB_OBJECTIVE].startedOn = 0 var c = Constraint(true) c = objectivesPlugin.isSMBModeEnabled(c) - Assert.assertEquals(true, c.getReasons(aapsLogger).contains("Objective 9 not started")) - Assert.assertEquals(false, c.value()) + Assertions.assertEquals(true, c.getReasons(aapsLogger).contains("Objective 9 not started")) + Assertions.assertEquals(false, c.value()) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/constraints/objectives/SntpClientTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/objectives/SntpClientTest.kt similarity index 69% rename from plugins/main/src/test/java/info/nightscout/plugins/constraints/objectives/SntpClientTest.kt rename to plugins/constraints/src/test/java/info/nightscout/plugins/constraints/objectives/SntpClientTest.kt index 520bebd1b3..8f7382d271 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/constraints/objectives/SntpClientTest.kt +++ b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/objectives/SntpClientTest.kt @@ -13,7 +13,7 @@ class SntpClientTest : TestBase() { @Test fun ntpTimeTest() { // no internet - SntpClient(aapsLogger, dateUtil).ntpTime(object : SntpClient.Callback() { + info.nightscout.plugins.constraints.objectives.SntpClient(aapsLogger, dateUtil).ntpTime(object : info.nightscout.plugins.constraints.objectives.SntpClient.Callback() { override fun run() { Assert.assertFalse(networkConnected) Assert.assertFalse(success) @@ -21,7 +21,7 @@ class SntpClientTest : TestBase() { } }, false) // internet - SntpClient(aapsLogger, dateUtil).doNtpTime(object : SntpClient.Callback() { + info.nightscout.plugins.constraints.objectives.SntpClient(aapsLogger, dateUtil).doNtpTime(object : info.nightscout.plugins.constraints.objectives.SntpClient.Callback() { override fun run() { Assert.assertTrue(success) Assert.assertTrue(abs(time - System.currentTimeMillis()) < 60000) diff --git a/plugins/support/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt similarity index 100% rename from plugins/support/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt rename to plugins/constraints/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/SignatureVerifierPluginTest.kt diff --git a/plugins/support/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/VersionCheckerUtilsKtTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/VersionCheckerUtilsKtTest.kt similarity index 100% rename from plugins/support/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/VersionCheckerUtilsKtTest.kt rename to plugins/constraints/src/test/java/info/nightscout/plugins/constraints/signatureVerifier/VersionCheckerUtilsKtTest.kt diff --git a/plugins/support/src/test/java/info/nightscout/plugins/constraints/storage/StorageConstraintPluginTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/storage/StorageConstraintPluginTest.kt similarity index 100% rename from plugins/support/src/test/java/info/nightscout/plugins/constraints/storage/StorageConstraintPluginTest.kt rename to plugins/constraints/src/test/java/info/nightscout/plugins/constraints/storage/StorageConstraintPluginTest.kt diff --git a/plugins/support/src/test/java/info/nightscout/plugins/constraints/versionChecker/AllowedVersionsTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/versionChecker/AllowedVersionsTest.kt similarity index 100% rename from plugins/support/src/test/java/info/nightscout/plugins/constraints/versionChecker/AllowedVersionsTest.kt rename to plugins/constraints/src/test/java/info/nightscout/plugins/constraints/versionChecker/AllowedVersionsTest.kt diff --git a/plugins/main/src/main/java/info/nightscout/plugins/di/ObjectivesModule.kt b/plugins/main/src/main/java/info/nightscout/plugins/di/ObjectivesModule.kt deleted file mode 100644 index c6adf3c874..0000000000 --- a/plugins/main/src/main/java/info/nightscout/plugins/di/ObjectivesModule.kt +++ /dev/null @@ -1,39 +0,0 @@ -package info.nightscout.plugins.di - -import dagger.Module -import dagger.android.ContributesAndroidInjector -import info.nightscout.plugins.constraints.objectives.ObjectivesFragment -import info.nightscout.plugins.constraints.objectives.activities.ObjectivesExamDialog -import info.nightscout.plugins.constraints.objectives.dialogs.NtpProgressDialog -import info.nightscout.plugins.constraints.objectives.objectives.Objective -import info.nightscout.plugins.constraints.objectives.objectives.Objective0 -import info.nightscout.plugins.constraints.objectives.objectives.Objective1 -import info.nightscout.plugins.constraints.objectives.objectives.Objective10 -import info.nightscout.plugins.constraints.objectives.objectives.Objective2 -import info.nightscout.plugins.constraints.objectives.objectives.Objective3 -import info.nightscout.plugins.constraints.objectives.objectives.Objective4 -import info.nightscout.plugins.constraints.objectives.objectives.Objective5 -import info.nightscout.plugins.constraints.objectives.objectives.Objective6 -import info.nightscout.plugins.constraints.objectives.objectives.Objective7 -import info.nightscout.plugins.constraints.objectives.objectives.Objective9 - -@Module -@Suppress("unused") -abstract class ObjectivesModule { - - @ContributesAndroidInjector abstract fun contributesObjectivesFragment(): ObjectivesFragment - @ContributesAndroidInjector abstract fun contributesObjectivesExamDialog(): ObjectivesExamDialog - @ContributesAndroidInjector abstract fun contributesNtpProgressDialog(): NtpProgressDialog - - @ContributesAndroidInjector abstract fun objectiveInjector(): Objective - @ContributesAndroidInjector abstract fun objective0Injector(): Objective0 - @ContributesAndroidInjector abstract fun objective1Injector(): Objective1 - @ContributesAndroidInjector abstract fun objective2Injector(): Objective2 - @ContributesAndroidInjector abstract fun objective3Injector(): Objective3 - @ContributesAndroidInjector abstract fun objective4Injector(): Objective4 - @ContributesAndroidInjector abstract fun objective5Injector(): Objective5 - @ContributesAndroidInjector abstract fun objective6Injector(): Objective6 - @ContributesAndroidInjector abstract fun objective7Injector(): Objective7 - @ContributesAndroidInjector abstract fun objective9Injector(): Objective9 - @ContributesAndroidInjector abstract fun objective10Injector(): Objective10 -} \ No newline at end of file diff --git a/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt b/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt index 3d20e2e34a..ea1fe6c73b 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt @@ -19,7 +19,6 @@ import info.nightscout.plugins.iob.iobCobCalculator.IobCobCalculatorPlugin ProfileModule::class, SourceModule::class, VirtualPumpModule::class, - ObjectivesModule::class, SkinsModule::class, SkinsUiModule::class, ActionsModule::class, diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/actions/ActionsFragment.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/actions/ActionsFragment.kt index 0ad254168d..6db0614ff5 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/actions/ActionsFragment.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/actions/ActionsFragment.kt @@ -193,7 +193,7 @@ class ActionsFragment : DaggerFragment() { uiInteraction.runCareDialog(childFragmentManager, UiInteraction.EventType.ANNOUNCEMENT, info.nightscout.core.ui.R.string.careportal_announcement) } - sp.putBoolean(R.string.key_objectiveuseactions, true) + sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveuseactions, true) } @Synchronized diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/actions/ActionsPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/actions/ActionsPlugin.kt index 906af9a50d..c4d93b566b 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/actions/ActionsPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/actions/ActionsPlugin.kt @@ -2,6 +2,7 @@ package info.nightscout.plugins.general.actions import dagger.android.HasAndroidInjector import info.nightscout.interfaces.Config +import info.nightscout.interfaces.actions.Actions import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType @@ -28,4 +29,4 @@ class ActionsPlugin @Inject constructor( .shortName(R.string.actions_shortname) .description(R.string.description_actions), aapsLogger, rh, injector -) +), Actions diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt index b8da15234c..3b5f145058 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt @@ -209,7 +209,7 @@ class OverviewFragment : DaggerFragment(), View.OnClickListener, OnLongClickList overviewData.rangeToDisplay = if (overviewData.rangeToDisplay > 24) 6 else overviewData.rangeToDisplay sp.putInt(info.nightscout.core.utils.R.string.key_rangetodisplay, overviewData.rangeToDisplay) rxBus.send(EventPreferenceChange(rh.gs(info.nightscout.core.utils.R.string.key_rangetodisplay))) - sp.putBoolean(R.string.key_objectiveusescale, true) + sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveusescale, true) false } prepareGraphsIfNeeded(overviewMenus.setting.size) @@ -273,7 +273,7 @@ class OverviewFragment : DaggerFragment(), View.OnClickListener, OnLongClickList overviewData.rangeToDisplay = it.hours sp.putInt(info.nightscout.core.utils.R.string.key_rangetodisplay, it.hours) rxBus.send(EventPreferenceChange(rh.gs(info.nightscout.core.utils.R.string.key_rangetodisplay))) - sp.putBoolean(R.string.key_objectiveusescale, true) + sp.putBoolean(info.nightscout.core.utils.R.string.key_objectiveusescale, true) }, fabricPrivacy::logException) disposable += rxBus .toObservable(EventNewBG::class.java) @@ -659,7 +659,7 @@ class OverviewFragment : DaggerFragment(), View.OnClickListener, OnLongClickList (loop as PluginBase).isEnabled() && loop.isSuspended -> { binding.infoLayout.apsMode.setImageResource(info.nightscout.core.ui.R.drawable.ic_loop_paused) - apsModeSetA11yLabel(R.string.suspendloop_label) + apsModeSetA11yLabel(info.nightscout.core.ui.R.string.suspendloop_label) binding.infoLayout.apsModeText.text = dateUtil.age(loop.minutesToEndOfSuspend() * 60000L, true, rh) binding.infoLayout.apsModeText.visibility = View.VISIBLE } diff --git a/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpPlugin.kt index 6aace87e40..0bf57732be 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpPlugin.kt @@ -124,7 +124,7 @@ open class VirtualPumpPlugin @Inject constructor( override fun preprocessPreferences(preferenceFragment: PreferenceFragmentCompat) { super.preprocessPreferences(preferenceFragment) - val uploadStatus = preferenceFragment.findPreference(rh.gs(R.string.key_virtual_pump_upload_status)) as SwitchPreference? + val uploadStatus = preferenceFragment.findPreference(rh.gs(info.nightscout.core.utils.R.string.key_virtual_pump_upload_status)) as SwitchPreference? ?: return uploadStatus.isVisible = !config.NSCLIENT } @@ -340,7 +340,7 @@ open class VirtualPumpPlugin @Inject constructor( override fun getJSONStatus(profile: Profile, profileName: String, version: String): JSONObject { val now = System.currentTimeMillis() - if (!sp.getBoolean(R.string.key_virtual_pump_upload_status, false)) { + if (!sp.getBoolean(info.nightscout.core.utils.R.string.key_virtual_pump_upload_status, false)) { return JSONObject() } val pump = JSONObject() diff --git a/plugins/main/src/main/res/values/strings.xml b/plugins/main/src/main/res/values/strings.xml index 7cf8ce96cf..8ad09cd9e3 100644 --- a/plugins/main/src/main/res/values/strings.xml +++ b/plugins/main/src/main/res/values/strings.xml @@ -195,24 +195,6 @@ TARG BAS - - Completed, well done! - Not completed yet - Time elapsed - Maximal IOB set properly - BG available from selected source - Synchronization service has write permission - Loop enabled - APS selected - Closed mode enabled - OBJ - Learning program - Do you want reset objective start? You may lose your progress. - Next - Prev - Clear finished - Clear started - Actions Some buttons to quickly access common features @@ -233,21 +215,6 @@ patch pump age Patch pump - - Limiting extended bolus to %1$.1f U because of %2$s - Limiting carbs to %1$d g because of %2$s - - Safety - Pump is not temp basal capable - Closed loop mode disabled in preferences - Running dev version. Closed loop is disabled. - Closed loop disabled because of running Extended bolus - SMB always and after carbs disabled because active BG source doesn\'t support advanced filtering - SMB not allowed in open loop mode - max value in preferences - hard limit - Treatments safety - show_calibration_button show_cgm_button @@ -397,7 +364,6 @@ Graph - virtualpump_uploadstatus Virtual Pump Type Pump Definition Bolus: Step=%1$s\nExtended Bolus: [Step=%2$s, Duration=%3$smin-%4$sh]\nBasal: Step=%5$s\nTBR: %6$s (by %7$s), Duration=%8$smin-%9$sh\n%10$s @@ -406,7 +372,6 @@ Pump integration for pumps which don\'t have any driver yet (Open Loop) VIRTUAL PUMP Virtual pump settings - Upload status to NS dexcom_lognssensorchange diff --git a/plugins/support/src/main/AndroidManifest.xml b/plugins/support/src/main/AndroidManifest.xml deleted file mode 100644 index a5918e68ab..0000000000 --- a/plugins/support/src/main/AndroidManifest.xml +++ /dev/null @@ -1,4 +0,0 @@ - - - - \ No newline at end of file diff --git a/settings.gradle b/settings.gradle index 6a419e7a21..a7ff95a7d4 100644 --- a/settings.gradle +++ b/settings.gradle @@ -21,7 +21,7 @@ include ':plugins:configuration' include ':plugins:main' include ':plugins:openhumans' include ':plugins:sensitivity' -include ':plugins:support' +include ':plugins:constraints' include ':pump:combo' include ':pump:combov2' include ':pump:combov2:comboctl' From f702e9b839f679782f445ef8f43a5e938ee5fcbf Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Thu, 8 Dec 2022 18:49:22 +0100 Subject: [PATCH 14/48] remove :ui dependency --- .../implementations/UiInteractionImpl.kt | 5 +++++ .../nightscout/interfaces/ui/UiInteraction.kt | 3 +++ .../ui}/src/main/res/mipmap-hdpi/ic_launcher.png | Bin .../main/res/mipmap-hdpi/ic_launcher_round.png | Bin .../src/main/res/mipmap-hdpi/ic_pumpcontrol.png | Bin .../src/main/res/mipmap-hdpi/ic_yellowowl.png | Bin .../ui}/src/main/res/mipmap-mdpi/ic_launcher.png | Bin .../main/res/mipmap-mdpi/ic_launcher_round.png | Bin .../src/main/res/mipmap-mdpi/ic_pumpcontrol.png | Bin .../src/main/res/mipmap-mdpi/ic_yellowowl.png | Bin .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin .../main/res/mipmap-xhdpi/ic_launcher_round.png | Bin .../src/main/res/mipmap-xhdpi/ic_pumpcontrol.png | Bin .../src/main/res/mipmap-xhdpi/ic_yellowowl.png | Bin .../src/main/res/mipmap-xxhdpi/ic_launcher.png | Bin .../main/res/mipmap-xxhdpi/ic_launcher_round.png | Bin .../main/res/mipmap-xxhdpi/ic_pumpcontrol.png | Bin .../src/main/res/mipmap-xxhdpi/ic_yellowowl.png | Bin .../src/main/res/mipmap-xxxhdpi/ic_launcher.png | Bin .../res/mipmap-xxxhdpi/ic_launcher_round.png | Bin .../main/res/mipmap-xxxhdpi/ic_pumpcontrol.png | Bin .../src/main/res/mipmap-xxxhdpi/ic_yellowowl.png | Bin implementation/build.gradle | 1 - .../implementation/db/CompatDBHelper.kt | 15 ++++++++------- .../resources/IconsProviderImplementation.kt | 6 +++--- 25 files changed, 19 insertions(+), 11 deletions(-) rename {ui => core/ui}/src/main/res/mipmap-hdpi/ic_launcher.png (100%) rename {ui => core/ui}/src/main/res/mipmap-hdpi/ic_launcher_round.png (100%) rename {ui => core/ui}/src/main/res/mipmap-hdpi/ic_pumpcontrol.png (100%) rename {ui => core/ui}/src/main/res/mipmap-hdpi/ic_yellowowl.png (100%) rename {ui => core/ui}/src/main/res/mipmap-mdpi/ic_launcher.png (100%) rename {ui => core/ui}/src/main/res/mipmap-mdpi/ic_launcher_round.png (100%) rename {ui => core/ui}/src/main/res/mipmap-mdpi/ic_pumpcontrol.png (100%) rename {ui => core/ui}/src/main/res/mipmap-mdpi/ic_yellowowl.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xhdpi/ic_launcher.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xhdpi/ic_launcher_round.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xhdpi/ic_pumpcontrol.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xhdpi/ic_yellowowl.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xxhdpi/ic_launcher.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xxhdpi/ic_launcher_round.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xxhdpi/ic_pumpcontrol.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xxhdpi/ic_yellowowl.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xxxhdpi/ic_launcher.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xxxhdpi/ic_pumpcontrol.png (100%) rename {ui => core/ui}/src/main/res/mipmap-xxxhdpi/ic_yellowowl.png (100%) diff --git a/app/src/main/java/info/nightscout/androidaps/implementations/UiInteractionImpl.kt b/app/src/main/java/info/nightscout/androidaps/implementations/UiInteractionImpl.kt index a8f9c228ff..c72df73813 100644 --- a/app/src/main/java/info/nightscout/androidaps/implementations/UiInteractionImpl.kt +++ b/app/src/main/java/info/nightscout/androidaps/implementations/UiInteractionImpl.kt @@ -39,6 +39,7 @@ import info.nightscout.ui.dialogs.TempBasalDialog import info.nightscout.ui.dialogs.TempTargetDialog import info.nightscout.ui.dialogs.TreatmentDialog import info.nightscout.ui.dialogs.WizardDialog +import info.nightscout.ui.widget.Widget import javax.inject.Inject class UiInteractionImpl @Inject constructor( @@ -67,6 +68,10 @@ class UiInteractionImpl @Inject constructor( context.startActivity(i) } + override fun updateWidget(context: Context) { + Widget.updateWidget(context) + } + override fun runWizardDialog(fragmentManager: FragmentManager, carbs: Int?, name: String?) { WizardDialog().also { dialog -> dialog.arguments = Bundle().also { bundle -> diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/ui/UiInteraction.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/ui/UiInteraction.kt index 3638508369..e2867cb3da 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/ui/UiInteraction.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/ui/UiInteraction.kt @@ -31,6 +31,9 @@ interface UiInteraction { * @param soundId sound resource. if == 0 alarm is not started */ fun runAlarm(status: String, title: String, @RawRes soundId: Int = 0) + + fun updateWidget(context: Context) + fun runWizardDialog(fragmentManager: FragmentManager, carbs: Int? = null, name: String? = null) fun runLoopDialog(fragmentManager: FragmentManager, showOkCancel: Int) fun runProfileSwitchDialog(fragmentManager: FragmentManager, profileName: String? = null) diff --git a/ui/src/main/res/mipmap-hdpi/ic_launcher.png b/core/ui/src/main/res/mipmap-hdpi/ic_launcher.png similarity index 100% rename from ui/src/main/res/mipmap-hdpi/ic_launcher.png rename to core/ui/src/main/res/mipmap-hdpi/ic_launcher.png diff --git a/ui/src/main/res/mipmap-hdpi/ic_launcher_round.png b/core/ui/src/main/res/mipmap-hdpi/ic_launcher_round.png similarity index 100% rename from ui/src/main/res/mipmap-hdpi/ic_launcher_round.png rename to core/ui/src/main/res/mipmap-hdpi/ic_launcher_round.png diff --git a/ui/src/main/res/mipmap-hdpi/ic_pumpcontrol.png b/core/ui/src/main/res/mipmap-hdpi/ic_pumpcontrol.png similarity index 100% rename from ui/src/main/res/mipmap-hdpi/ic_pumpcontrol.png rename to core/ui/src/main/res/mipmap-hdpi/ic_pumpcontrol.png diff --git a/ui/src/main/res/mipmap-hdpi/ic_yellowowl.png b/core/ui/src/main/res/mipmap-hdpi/ic_yellowowl.png similarity index 100% rename from ui/src/main/res/mipmap-hdpi/ic_yellowowl.png rename to core/ui/src/main/res/mipmap-hdpi/ic_yellowowl.png diff --git a/ui/src/main/res/mipmap-mdpi/ic_launcher.png b/core/ui/src/main/res/mipmap-mdpi/ic_launcher.png similarity index 100% rename from ui/src/main/res/mipmap-mdpi/ic_launcher.png rename to core/ui/src/main/res/mipmap-mdpi/ic_launcher.png diff --git a/ui/src/main/res/mipmap-mdpi/ic_launcher_round.png b/core/ui/src/main/res/mipmap-mdpi/ic_launcher_round.png similarity index 100% rename from ui/src/main/res/mipmap-mdpi/ic_launcher_round.png rename to core/ui/src/main/res/mipmap-mdpi/ic_launcher_round.png diff --git a/ui/src/main/res/mipmap-mdpi/ic_pumpcontrol.png b/core/ui/src/main/res/mipmap-mdpi/ic_pumpcontrol.png similarity index 100% rename from ui/src/main/res/mipmap-mdpi/ic_pumpcontrol.png rename to core/ui/src/main/res/mipmap-mdpi/ic_pumpcontrol.png diff --git a/ui/src/main/res/mipmap-mdpi/ic_yellowowl.png b/core/ui/src/main/res/mipmap-mdpi/ic_yellowowl.png similarity index 100% rename from ui/src/main/res/mipmap-mdpi/ic_yellowowl.png rename to core/ui/src/main/res/mipmap-mdpi/ic_yellowowl.png diff --git a/ui/src/main/res/mipmap-xhdpi/ic_launcher.png b/core/ui/src/main/res/mipmap-xhdpi/ic_launcher.png similarity index 100% rename from ui/src/main/res/mipmap-xhdpi/ic_launcher.png rename to core/ui/src/main/res/mipmap-xhdpi/ic_launcher.png diff --git a/ui/src/main/res/mipmap-xhdpi/ic_launcher_round.png b/core/ui/src/main/res/mipmap-xhdpi/ic_launcher_round.png similarity index 100% rename from ui/src/main/res/mipmap-xhdpi/ic_launcher_round.png rename to core/ui/src/main/res/mipmap-xhdpi/ic_launcher_round.png diff --git a/ui/src/main/res/mipmap-xhdpi/ic_pumpcontrol.png b/core/ui/src/main/res/mipmap-xhdpi/ic_pumpcontrol.png similarity index 100% rename from ui/src/main/res/mipmap-xhdpi/ic_pumpcontrol.png rename to core/ui/src/main/res/mipmap-xhdpi/ic_pumpcontrol.png diff --git a/ui/src/main/res/mipmap-xhdpi/ic_yellowowl.png b/core/ui/src/main/res/mipmap-xhdpi/ic_yellowowl.png similarity index 100% rename from ui/src/main/res/mipmap-xhdpi/ic_yellowowl.png rename to core/ui/src/main/res/mipmap-xhdpi/ic_yellowowl.png diff --git a/ui/src/main/res/mipmap-xxhdpi/ic_launcher.png b/core/ui/src/main/res/mipmap-xxhdpi/ic_launcher.png similarity index 100% rename from ui/src/main/res/mipmap-xxhdpi/ic_launcher.png rename to core/ui/src/main/res/mipmap-xxhdpi/ic_launcher.png diff --git a/ui/src/main/res/mipmap-xxhdpi/ic_launcher_round.png b/core/ui/src/main/res/mipmap-xxhdpi/ic_launcher_round.png similarity index 100% rename from ui/src/main/res/mipmap-xxhdpi/ic_launcher_round.png rename to core/ui/src/main/res/mipmap-xxhdpi/ic_launcher_round.png diff --git a/ui/src/main/res/mipmap-xxhdpi/ic_pumpcontrol.png b/core/ui/src/main/res/mipmap-xxhdpi/ic_pumpcontrol.png similarity index 100% rename from ui/src/main/res/mipmap-xxhdpi/ic_pumpcontrol.png rename to core/ui/src/main/res/mipmap-xxhdpi/ic_pumpcontrol.png diff --git a/ui/src/main/res/mipmap-xxhdpi/ic_yellowowl.png b/core/ui/src/main/res/mipmap-xxhdpi/ic_yellowowl.png similarity index 100% rename from ui/src/main/res/mipmap-xxhdpi/ic_yellowowl.png rename to core/ui/src/main/res/mipmap-xxhdpi/ic_yellowowl.png diff --git a/ui/src/main/res/mipmap-xxxhdpi/ic_launcher.png b/core/ui/src/main/res/mipmap-xxxhdpi/ic_launcher.png similarity index 100% rename from ui/src/main/res/mipmap-xxxhdpi/ic_launcher.png rename to core/ui/src/main/res/mipmap-xxxhdpi/ic_launcher.png diff --git a/ui/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png b/core/ui/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png similarity index 100% rename from ui/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png rename to core/ui/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png diff --git a/ui/src/main/res/mipmap-xxxhdpi/ic_pumpcontrol.png b/core/ui/src/main/res/mipmap-xxxhdpi/ic_pumpcontrol.png similarity index 100% rename from ui/src/main/res/mipmap-xxxhdpi/ic_pumpcontrol.png rename to core/ui/src/main/res/mipmap-xxxhdpi/ic_pumpcontrol.png diff --git a/ui/src/main/res/mipmap-xxxhdpi/ic_yellowowl.png b/core/ui/src/main/res/mipmap-xxxhdpi/ic_yellowowl.png similarity index 100% rename from ui/src/main/res/mipmap-xxxhdpi/ic_yellowowl.png rename to core/ui/src/main/res/mipmap-xxxhdpi/ic_yellowowl.png diff --git a/implementation/build.gradle b/implementation/build.gradle index 867e1cd101..38a71e9581 100644 --- a/implementation/build.gradle +++ b/implementation/build.gradle @@ -26,7 +26,6 @@ dependencies { implementation project(':core:interfaces') implementation project(':core:ui') implementation project(':core:utils') - implementation project(':ui') // Protection api 'androidx.biometric:biometric:1.1.0' diff --git a/implementation/src/main/java/info/nightscout/implementation/db/CompatDBHelper.kt b/implementation/src/main/java/info/nightscout/implementation/db/CompatDBHelper.kt index 6c3b5034fb..56515fb76f 100644 --- a/implementation/src/main/java/info/nightscout/implementation/db/CompatDBHelper.kt +++ b/implementation/src/main/java/info/nightscout/implementation/db/CompatDBHelper.kt @@ -13,6 +13,7 @@ import info.nightscout.database.entities.TemporaryBasal import info.nightscout.database.entities.TemporaryTarget import info.nightscout.database.entities.TherapyEvent import info.nightscout.database.impl.AppRepository +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventEffectiveProfileSwitchChanged import info.nightscout.rx.events.EventExtendedBolusChange @@ -27,24 +28,24 @@ import info.nightscout.rx.events.EventTherapyEventChange import info.nightscout.rx.events.EventTreatmentChange import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag -import info.nightscout.ui.widget.Widget import io.reactivex.rxjava3.disposables.Disposable import javax.inject.Inject import javax.inject.Singleton @Singleton class CompatDBHelper @Inject constructor( - val aapsLogger: AAPSLogger, - val repository: AppRepository, - val rxBus: RxBus, - val context: Context + private val aapsLogger: AAPSLogger, + private val repository: AppRepository, + private val rxBus: RxBus, + private val context: Context, + private val uiInteraction: UiInteraction ) { fun dbChangeDisposable(): Disposable = repository .changeObservable() .doOnSubscribe { rxBus.send(EventNewBG(null)) - Widget.updateWidget(context) + uiInteraction.updateWidget(context) } .subscribe { /** @@ -57,7 +58,7 @@ class CompatDBHelper @Inject constructor( it.filterIsInstance().maxByOrNull { gv -> gv.timestamp }?.let { gv -> aapsLogger.debug(LTag.DATABASE, "Firing EventNewBg $gv") rxBus.send(EventNewBG(gv.timestamp)) - Widget.updateWidget(context) + uiInteraction.updateWidget(context) newestGlucoseValue = gv } it.filterIsInstance().minOfOrNull { gv -> gv.timestamp }?.let { timestamp -> diff --git a/implementation/src/main/java/info/nightscout/implementation/resources/IconsProviderImplementation.kt b/implementation/src/main/java/info/nightscout/implementation/resources/IconsProviderImplementation.kt index e4c735fb6a..b252cb654c 100644 --- a/implementation/src/main/java/info/nightscout/implementation/resources/IconsProviderImplementation.kt +++ b/implementation/src/main/java/info/nightscout/implementation/resources/IconsProviderImplementation.kt @@ -11,9 +11,9 @@ class IconsProviderImplementation @Inject constructor(private val config: Config override fun getIcon(): Int = when { - config.NSCLIENT -> info.nightscout.ui.R.mipmap.ic_yellowowl - config.PUMPCONTROL -> info.nightscout.ui.R.mipmap.ic_pumpcontrol - else -> info.nightscout.ui.R.mipmap.ic_launcher + config.NSCLIENT -> info.nightscout.core.ui.R.mipmap.ic_yellowowl + config.PUMPCONTROL -> info.nightscout.core.ui.R.mipmap.ic_pumpcontrol + else -> info.nightscout.core.ui.R.mipmap.ic_launcher } override fun getNotificationIcon(): Int = From bc8b4f4a1caf081469aeb1de53ed3b174a1876d5 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 9 Dec 2022 08:02:05 +0000 Subject: [PATCH 15/48] chore(deps): bump firebase-bom from 31.1.0 to 31.1.1 Bumps firebase-bom from 31.1.0 to 31.1.1. --- updated-dependencies: - dependency-name: com.google.firebase:firebase-bom dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- core/utils/build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/utils/build.gradle b/core/utils/build.gradle index a56b9a2250..dbc2e82c6f 100644 --- a/core/utils/build.gradle +++ b/core/utils/build.gradle @@ -22,7 +22,7 @@ dependencies { implementation project(':app-wear-shared:shared') //Firebase - api platform('com.google.firebase:firebase-bom:31.1.0') + api platform('com.google.firebase:firebase-bom:31.1.1') api "com.google.firebase:firebase-analytics-ktx" api "com.google.firebase:firebase-crashlytics-ktx" // StatsActivity not in use now From e2f96fd70def8b244847a7ca0d3d40a629ab6e8c Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 09:21:47 +0100 Subject: [PATCH 16/48] crowdin --- crowdin.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/crowdin.yml b/crowdin.yml index cc973cac47..8a46e75627 100644 --- a/crowdin.yml +++ b/crowdin.yml @@ -11,10 +11,10 @@ files: translation: /plugins/aps/src/main/res/values-%android_code%/strings.xml - source: /plugins/main/src/main/res/values/strings.xml translation: /plugins/main/src/main/res/values-%android_code%/strings.xml - - source: /plugins/main/src/main/res/values/exam.xml - translation: /plugins/main/src/main/res/values-%android_code%/%original_file_name% - - source: /plugins/main/src/main/res/values/objectives.xml - translation: /plugins/main/src/main/res/values-%android_code%/%original_file_name% + - source: /plugins/constraints/src/main/res/values/exam.xml + translation: /plugins/constraints/src/main/res/values-%android_code%/%original_file_name% + - source: /plugins/constraints/src/main/res/values/objectives.xml + translation: /plugins/constraints/src/main/res/values-%android_code%/%original_file_name% - source: /plugins/automation/src/main/res/values/strings.xml translation: /plugins/automation/src/main/res/values-%android_code%/strings.xml - source: /plugins/openhumans/src/main/res/values/strings.xml From d34bcbf74f9e296591975765fe635795c869e21b Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 10:16:38 +0100 Subject: [PATCH 17/48] remove :automation dependency --- app/src/main/res/values/strings.xml | 1 - .../info/nightscout/interfaces/BolusTimer.kt | 14 --- .../info/nightscout/interfaces/CarbTimer.kt | 21 ---- .../interfaces/automation/Automation.kt | 30 +++++ .../nightscout/core/wizard/BolusWizard.kt | 14 +-- implementation/build.gradle | 1 - .../implementation/BolusTimerImpl.kt | 55 --------- .../implementation/CarbTimerImpl.kt | 102 ---------------- .../implementation/di/ImplementationModule.kt | 6 - .../src/main/res/values/strings.xml | 2 - .../nightscout/automation/AutomationPlugin.kt | 113 +++++++++++++++++- .../src/main/res/values/strings.xml | 4 + .../automation}/BolusTimerImplTest.kt | 30 ++--- .../automation}/CarbTimerImplTest.kt | 31 +++-- .../info/nightscout/ui/dialogs/CarbsDialog.kt | 12 +- .../nightscout/ui/dialogs/InsulinDialog.kt | 8 +- 16 files changed, 190 insertions(+), 254 deletions(-) delete mode 100644 core/interfaces/src/main/java/info/nightscout/interfaces/BolusTimer.kt delete mode 100644 core/interfaces/src/main/java/info/nightscout/interfaces/CarbTimer.kt delete mode 100644 implementation/src/main/java/info/nightscout/implementation/BolusTimerImpl.kt delete mode 100644 implementation/src/main/java/info/nightscout/implementation/CarbTimerImpl.kt rename {implementation/src/test/java/info/nightscout/implementation => plugins/automation/src/test/java/info/nightscout/automation}/BolusTimerImplTest.kt (71%) rename {implementation/src/test/java/info/nightscout/implementation => plugins/automation/src/test/java/info/nightscout/automation}/CarbTimerImplTest.kt (73%) diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 6450e854e0..854ed3570b 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -79,7 +79,6 @@ Authorization failed Unable to create profile. Profile is invalid. Don\'t kill my app? - Time to eat!\nRun Bolus wizard and do calculation again. Crash logs upload disabled! Clear filter Cannula diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/BolusTimer.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/BolusTimer.kt deleted file mode 100644 index 2ac46cc560..0000000000 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/BolusTimer.kt +++ /dev/null @@ -1,14 +0,0 @@ -package info.nightscout.interfaces - -interface BolusTimer { - - /** - * Create new Automation event to alarm when is time to bolus - */ - fun scheduleAutomationEventBolusReminder() - - /** - * Remove Automation event - */ - fun removeAutomationEventBolusReminder() -} \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/CarbTimer.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/CarbTimer.kt deleted file mode 100644 index b7c472a775..0000000000 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/CarbTimer.kt +++ /dev/null @@ -1,21 +0,0 @@ -package info.nightscout.interfaces - -interface CarbTimer { - - /** - * Generate reminder via [info.nightscout.androidaps.utils.TimerUtil] - * - * @param seconds seconds to the future - */ - fun scheduleTimeToEatReminder(seconds: Int) - - /** - * Create new Automation event to alarm when is time to eat - */ - fun scheduleAutomationEventEatReminder() - - /** - * Remove Automation event - */ - fun removeAutomationEventEatReminder() -} \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/automation/Automation.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/automation/Automation.kt index 9f26a97cda..4ad566d6c1 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/automation/Automation.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/automation/Automation.kt @@ -1,6 +1,36 @@ package info.nightscout.interfaces.automation interface Automation { + fun userEvents(): List fun processEvent(someEvent: AutomationEvent) + + /** + * Generate reminder via [info.nightscout.interfaces.utils.TimerUtil] + * + */ + fun scheduleAutomationEventBolusReminder() + + /** + * Remove scheduled reminder from automations + * + */ + fun removeAutomationEventBolusReminder() + + /** + * Generate reminder via [info.nightscout.interfaces.utils.TimerUtil] + * + * @param seconds seconds to the future + */ + fun scheduleTimeToEatReminder(seconds: Int) + + /** + * Remove Automation event + */ + fun removeAutomationEventEatReminder() + + /** + * Create new Automation event to alarm when is time to eat + */ + fun scheduleAutomationEventEatReminder() } \ No newline at end of file diff --git a/core/main/src/main/java/info/nightscout/core/wizard/BolusWizard.kt b/core/main/src/main/java/info/nightscout/core/wizard/BolusWizard.kt index 49182208cf..201d36ea78 100644 --- a/core/main/src/main/java/info/nightscout/core/wizard/BolusWizard.kt +++ b/core/main/src/main/java/info/nightscout/core/wizard/BolusWizard.kt @@ -15,10 +15,9 @@ import info.nightscout.database.entities.TemporaryTarget import info.nightscout.database.entities.UserEntry.Action import info.nightscout.database.entities.UserEntry.Sources import info.nightscout.database.entities.ValueWithUnit -import info.nightscout.interfaces.BolusTimer -import info.nightscout.interfaces.CarbTimer import info.nightscout.interfaces.Config import info.nightscout.interfaces.aps.Loop +import info.nightscout.interfaces.automation.Automation import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.db.PersistenceLayer @@ -69,8 +68,7 @@ class BolusWizard @Inject constructor( @Inject lateinit var dateUtil: DateUtil @Inject lateinit var config: Config @Inject lateinit var uel: UserEntryLogger - @Inject lateinit var carbTimer: CarbTimer - @Inject lateinit var bolusTimer: BolusTimer + @Inject lateinit var automation: Automation @Inject lateinit var glucoseStatusProvider: GlucoseStatusProvider @Inject lateinit var uiInteraction: UiInteraction @Inject lateinit var persistenceLayer: PersistenceLayer @@ -361,9 +359,9 @@ class BolusWizard @Inject constructor( } accepted = true if (calculatedTotalInsulin > 0.0) - bolusTimer.removeAutomationEventBolusReminder() + automation.removeAutomationEventBolusReminder() if (carbs > 0.0) - carbTimer.removeAutomationEventEatReminder() + automation.removeAutomationEventEatReminder() if (sp.getBoolean(info.nightscout.core.ui.R.string.key_usebolusadvisor, false) && Profile.toMgdl(bg, profile.units) > 180 && carbs > 0 && carbTime >= 0) OKDialog.showYesNoCancel(ctx, rh.gs(info.nightscout.core.ui.R.string.bolus_advisor), rh.gs(info.nightscout.core.ui.R.string.bolus_advisor_message), { bolusAdvisorProcessing(ctx) }, @@ -402,7 +400,7 @@ class BolusWizard @Inject constructor( if (!result.success) { uiInteraction.runAlarm(result.comment, rh.gs(info.nightscout.core.ui.R.string.treatmentdeliveryerror), info.nightscout.core.ui.R.raw.boluserror) } else - carbTimer.scheduleAutomationEventEatReminder() + automation.scheduleAutomationEventEatReminder() } }) } @@ -494,7 +492,7 @@ class BolusWizard @Inject constructor( bolusCalculatorResult?.let { persistenceLayer.insertOrUpdate(it) } } if (useAlarm && carbs > 0 && carbTime > 0) { - carbTimer.scheduleTimeToEatReminder(T.mins(carbTime.toLong()).secs().toInt()) + automation.scheduleTimeToEatReminder(T.mins(carbTime.toLong()).secs().toInt()) } } }) diff --git a/implementation/build.gradle b/implementation/build.gradle index 38a71e9581..a4c72a5c4d 100644 --- a/implementation/build.gradle +++ b/implementation/build.gradle @@ -19,7 +19,6 @@ dependencies { implementation project(':app-wear-shared:shared') implementation project(':database:entities') implementation project(':database:impl') - implementation project(':plugins:automation') implementation project(':core:main') implementation project(':core:graph') implementation project(':core:graphview') diff --git a/implementation/src/main/java/info/nightscout/implementation/BolusTimerImpl.kt b/implementation/src/main/java/info/nightscout/implementation/BolusTimerImpl.kt deleted file mode 100644 index 0e54ea7dbf..0000000000 --- a/implementation/src/main/java/info/nightscout/implementation/BolusTimerImpl.kt +++ /dev/null @@ -1,55 +0,0 @@ -package info.nightscout.implementation - -import dagger.android.HasAndroidInjector -import info.nightscout.automation.AutomationEventObject -import info.nightscout.automation.AutomationPlugin -import info.nightscout.automation.actions.ActionAlarm -import info.nightscout.automation.elements.Comparator -import info.nightscout.automation.elements.InputDelta -import info.nightscout.automation.triggers.TriggerBg -import info.nightscout.automation.triggers.TriggerConnector -import info.nightscout.automation.triggers.TriggerDelta -import info.nightscout.interfaces.BolusTimer -import info.nightscout.interfaces.GlucoseUnit -import info.nightscout.shared.interfaces.ResourceHelper -import java.text.DecimalFormat -import javax.inject.Inject -import javax.inject.Singleton - -@Singleton -class BolusTimerImpl @Inject constructor( - private val injector: HasAndroidInjector, - private val rh: ResourceHelper, - private val automationPlugin: AutomationPlugin, -) : BolusTimer { - - override fun scheduleAutomationEventBolusReminder() { - val event = AutomationEventObject(injector).apply { - title = rh.gs(info.nightscout.core.ui.R.string.bolus_reminder) - readOnly = true - systemAction = true - autoRemove = true - trigger = TriggerConnector(injector, TriggerConnector.Type.AND).apply { - - // Bg above 70 mgdl and delta positive mgdl - list.add(TriggerBg(injector, 70.0, GlucoseUnit.MGDL, Comparator.Compare.IS_EQUAL_OR_GREATER)) - list.add( - TriggerDelta( - injector, InputDelta(rh, 0.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.DELTA), GlucoseUnit.MGDL, Comparator.Compare - .IS_GREATER - ) - ) - } - actions.add(ActionAlarm(injector, rh.gs(R.string.time_to_bolus))) - } - - automationPlugin.addIfNotExists(event) - } - - override fun removeAutomationEventBolusReminder() { - val event = AutomationEventObject(injector).apply { - title = rh.gs(info.nightscout.core.ui.R.string.bolus_reminder) - } - automationPlugin.removeIfExists(event) - } -} \ No newline at end of file diff --git a/implementation/src/main/java/info/nightscout/implementation/CarbTimerImpl.kt b/implementation/src/main/java/info/nightscout/implementation/CarbTimerImpl.kt deleted file mode 100644 index 0ca958cf65..0000000000 --- a/implementation/src/main/java/info/nightscout/implementation/CarbTimerImpl.kt +++ /dev/null @@ -1,102 +0,0 @@ -package info.nightscout.implementation - -import dagger.android.HasAndroidInjector -import info.nightscout.automation.AutomationEventObject -import info.nightscout.automation.AutomationPlugin -import info.nightscout.automation.actions.ActionAlarm -import info.nightscout.automation.elements.Comparator -import info.nightscout.automation.elements.InputDelta -import info.nightscout.automation.triggers.TriggerBg -import info.nightscout.automation.triggers.TriggerConnector -import info.nightscout.automation.triggers.TriggerDelta -import info.nightscout.interfaces.CarbTimer -import info.nightscout.interfaces.GlucoseUnit -import info.nightscout.interfaces.utils.TimerUtil -import info.nightscout.shared.interfaces.ResourceHelper -import java.text.DecimalFormat -import javax.inject.Inject -import javax.inject.Singleton - -@Singleton -class CarbTimerImpl @Inject constructor( - private val injector: HasAndroidInjector, - private val rh: ResourceHelper, - private val automationPlugin: AutomationPlugin, - private val timerUtil: TimerUtil -) : CarbTimer { - - /** - * Generate reminder via [info.nightscout.androidaps.utils.TimerUtil] - * - * @param seconds seconds to the future - */ - override fun scheduleTimeToEatReminder(seconds: Int) = - timerUtil.scheduleReminder(seconds, rh.gs(R.string.time_to_eat)) - - /** - * Create new Automation event to alarm when is time to eat - */ - override fun scheduleAutomationEventEatReminder() { - val event = AutomationEventObject(injector).apply { - title = rh.gs(info.nightscout.core.ui.R.string.bolus_advisor) - readOnly = true - systemAction = true - autoRemove = true - trigger = TriggerConnector(injector, TriggerConnector.Type.OR).apply { - - // Bg under 180 mgdl and dropping by 15 mgdl - list.add(TriggerConnector(injector, TriggerConnector.Type.AND).apply { - list.add(TriggerBg(injector, 180.0, GlucoseUnit.MGDL, Comparator.Compare.IS_LESSER)) - list.add(TriggerDelta(injector, InputDelta(rh, -15.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.DELTA), GlucoseUnit.MGDL, Comparator.Compare.IS_EQUAL_OR_LESSER)) - list.add( - TriggerDelta( - injector, - InputDelta(rh, -8.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.SHORT_AVERAGE), - GlucoseUnit.MGDL, - Comparator.Compare.IS_EQUAL_OR_LESSER - ) - ) - }) - // Bg under 160 mgdl and dropping by 9 mgdl - list.add(TriggerConnector(injector, TriggerConnector.Type.AND).apply { - list.add(TriggerBg(injector, 160.0, GlucoseUnit.MGDL, Comparator.Compare.IS_LESSER)) - list.add(TriggerDelta(injector, InputDelta(rh, -9.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.DELTA), GlucoseUnit.MGDL, Comparator.Compare.IS_EQUAL_OR_LESSER)) - list.add( - TriggerDelta( - injector, - InputDelta(rh, -5.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.SHORT_AVERAGE), - GlucoseUnit.MGDL, - Comparator.Compare.IS_EQUAL_OR_LESSER - ) - ) - }) - // Bg under 145 mgdl and dropping - list.add(TriggerConnector(injector, TriggerConnector.Type.AND).apply { - list.add(TriggerBg(injector, 145.0, GlucoseUnit.MGDL, Comparator.Compare.IS_LESSER)) - list.add(TriggerDelta(injector, InputDelta(rh, 0.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.DELTA), GlucoseUnit.MGDL, Comparator.Compare.IS_EQUAL_OR_LESSER)) - list.add( - TriggerDelta( - injector, - InputDelta(rh, 0.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.SHORT_AVERAGE), - GlucoseUnit.MGDL, - Comparator.Compare.IS_EQUAL_OR_LESSER - ) - ) - }) - } - actions.add(ActionAlarm(injector, rh.gs(R.string.time_to_eat))) - } - - automationPlugin.addIfNotExists(event) - } - - /** - * Remove Automation event - */ - override fun removeAutomationEventEatReminder() { - val event = AutomationEventObject(injector).apply { - title = rh.gs(info.nightscout.core.ui.R.string.bolus_advisor) - } - automationPlugin.removeIfExists(event) - } -} \ No newline at end of file diff --git a/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt b/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt index d230e45523..3fce4b146b 100644 --- a/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt +++ b/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt @@ -4,8 +4,6 @@ import dagger.Binds import dagger.Module import dagger.android.ContributesAndroidInjector import info.nightscout.core.graph.OverviewData -import info.nightscout.implementation.BolusTimerImpl -import info.nightscout.implementation.CarbTimerImpl import info.nightscout.implementation.DefaultValueHelperImpl import info.nightscout.implementation.HardLimitsImpl import info.nightscout.implementation.LocalAlertUtilsImpl @@ -40,8 +38,6 @@ import info.nightscout.implementation.stats.TddCalculatorImpl import info.nightscout.implementation.stats.TirCalculatorImpl import info.nightscout.implementation.storage.FileStorage import info.nightscout.implementation.userEntry.UserEntryPresentationHelperImpl -import info.nightscout.interfaces.BolusTimer -import info.nightscout.interfaces.CarbTimer import info.nightscout.interfaces.LocalAlertUtils import info.nightscout.interfaces.NotificationHolder import info.nightscout.interfaces.Translator @@ -113,8 +109,6 @@ abstract class ImplementationModule { @Binds fun bindDexcomTirCalculatorInterface(dexcomTirCalculator: DexcomTirCalculatorImpl): DexcomTirCalculator @Binds fun bindPumpSyncInterface(pumpSyncImplementation: PumpSyncImplementation): PumpSync @Binds fun bindXDripBroadcastInterface(xDripBroadcastImpl: XDripBroadcastImpl): XDripBroadcast - @Binds fun bindCarbTimerInterface(carbTimer: CarbTimerImpl): CarbTimer - @Binds fun bindBolusTimerInterface(bolusTimer: BolusTimerImpl): BolusTimer @Binds fun bindLocalAlertUtilsInterface(localAlertUtils: LocalAlertUtilsImpl): LocalAlertUtils @Binds fun bindIconsProviderInterface(iconsProvider: IconsProviderImplementation): IconsProvider @Binds fun bindNotificationHolderInterface(notificationHolder: NotificationHolderImpl): NotificationHolder diff --git a/implementation/src/main/res/values/strings.xml b/implementation/src/main/res/values/strings.xml index d89f8e5c41..6df0df72ce 100644 --- a/implementation/src/main/res/values/strings.xml +++ b/implementation/src/main/res/values/strings.xml @@ -5,8 +5,6 @@ BG - Time to eat - Time to bolus!\nRun Bolus wizard and do calculation again. Command is executed right now Basal value below minimum. Profile not set! Permission diff --git a/plugins/automation/src/main/java/info/nightscout/automation/AutomationPlugin.kt b/plugins/automation/src/main/java/info/nightscout/automation/AutomationPlugin.kt index 7a19ef89ea..996345a787 100644 --- a/plugins/automation/src/main/java/info/nightscout/automation/AutomationPlugin.kt +++ b/plugins/automation/src/main/java/info/nightscout/automation/AutomationPlugin.kt @@ -17,6 +17,8 @@ import info.nightscout.automation.actions.ActionSendSMS import info.nightscout.automation.actions.ActionStartTempTarget import info.nightscout.automation.actions.ActionStopProcessing import info.nightscout.automation.actions.ActionStopTempTarget +import info.nightscout.automation.elements.Comparator +import info.nightscout.automation.elements.InputDelta import info.nightscout.automation.events.EventAutomationDataChanged import info.nightscout.automation.events.EventAutomationUpdateGui import info.nightscout.automation.events.EventLocationChange @@ -41,6 +43,7 @@ import info.nightscout.automation.triggers.TriggerTimeRange import info.nightscout.automation.triggers.TriggerWifiSsid import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.interfaces.Config +import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.automation.Automation import info.nightscout.interfaces.automation.AutomationEvent @@ -50,6 +53,7 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.queue.Callback +import info.nightscout.interfaces.utils.TimerUtil import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventBTChange @@ -67,6 +71,7 @@ import io.reactivex.rxjava3.kotlin.plusAssign import org.json.JSONArray import org.json.JSONException import org.json.JSONObject +import java.text.DecimalFormat import java.util.Collections import javax.inject.Inject import javax.inject.Singleton @@ -87,7 +92,8 @@ class AutomationPlugin @Inject constructor( private val config: Config, private val locationServiceHelper: LocationServiceHelper, private val dateUtil: DateUtil, - private val activePlugin: ActivePlugin + private val activePlugin: ActivePlugin, + private val timerUtil: TimerUtil ) : PluginBase( PluginDescription() .mainType(PluginType.GENERAL) @@ -402,4 +408,109 @@ class AutomationPlugin @Inject constructor( TriggerBTDevice(injector), ) } + + /** + * Generate reminder via [info.nightscout.interfaces.utils.TimerUtil] + * + * @param seconds seconds to the future + */ + override fun scheduleTimeToEatReminder(seconds: Int) = + timerUtil.scheduleReminder(seconds, rh.gs(R.string.time_to_eat)) + + /** + * Create new Automation event to alarm when is time to eat + */ + override fun scheduleAutomationEventEatReminder() { + val event = AutomationEventObject(injector).apply { + title = rh.gs(info.nightscout.core.ui.R.string.bolus_advisor) + readOnly = true + systemAction = true + autoRemove = true + trigger = TriggerConnector(injector, TriggerConnector.Type.OR).apply { + + // Bg under 180 mgdl and dropping by 15 mgdl + list.add(TriggerConnector(injector, TriggerConnector.Type.AND).apply { + list.add(TriggerBg(injector, 180.0, GlucoseUnit.MGDL, Comparator.Compare.IS_LESSER)) + list.add(TriggerDelta(injector, InputDelta(rh, -15.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.DELTA), GlucoseUnit.MGDL, Comparator.Compare.IS_EQUAL_OR_LESSER)) + list.add( + TriggerDelta( + injector, + InputDelta(rh, -8.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.SHORT_AVERAGE), + GlucoseUnit.MGDL, + Comparator.Compare.IS_EQUAL_OR_LESSER + ) + ) + }) + // Bg under 160 mgdl and dropping by 9 mgdl + list.add(TriggerConnector(injector, TriggerConnector.Type.AND).apply { + list.add(TriggerBg(injector, 160.0, GlucoseUnit.MGDL, Comparator.Compare.IS_LESSER)) + list.add(TriggerDelta(injector, InputDelta(rh, -9.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.DELTA), GlucoseUnit.MGDL, Comparator.Compare.IS_EQUAL_OR_LESSER)) + list.add( + TriggerDelta( + injector, + InputDelta(rh, -5.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.SHORT_AVERAGE), + GlucoseUnit.MGDL, + Comparator.Compare.IS_EQUAL_OR_LESSER + ) + ) + }) + // Bg under 145 mgdl and dropping + list.add(TriggerConnector(injector, TriggerConnector.Type.AND).apply { + list.add(TriggerBg(injector, 145.0, GlucoseUnit.MGDL, Comparator.Compare.IS_LESSER)) + list.add(TriggerDelta(injector, InputDelta(rh, 0.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.DELTA), GlucoseUnit.MGDL, Comparator.Compare.IS_EQUAL_OR_LESSER)) + list.add( + TriggerDelta( + injector, + InputDelta(rh, 0.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.SHORT_AVERAGE), + GlucoseUnit.MGDL, + Comparator.Compare.IS_EQUAL_OR_LESSER + ) + ) + }) + } + actions.add(ActionAlarm(injector, rh.gs(R.string.time_to_eat))) + } + + addIfNotExists(event) + } + + /** + * Remove Automation event + */ + override fun removeAutomationEventEatReminder() { + val event = AutomationEventObject(injector).apply { + title = rh.gs(info.nightscout.core.ui.R.string.bolus_advisor) + } + removeIfExists(event) + } + + override fun scheduleAutomationEventBolusReminder() { + val event = AutomationEventObject(injector).apply { + title = rh.gs(info.nightscout.core.ui.R.string.bolus_reminder) + readOnly = true + systemAction = true + autoRemove = true + trigger = TriggerConnector(injector, TriggerConnector.Type.AND).apply { + + // Bg above 70 mgdl and delta positive mgdl + list.add(TriggerBg(injector, 70.0, GlucoseUnit.MGDL, Comparator.Compare.IS_EQUAL_OR_GREATER)) + list.add( + TriggerDelta( + injector, InputDelta(rh, 0.0, -360.0, 360.0, 1.0, DecimalFormat("0"), InputDelta.DeltaType.DELTA), GlucoseUnit.MGDL, Comparator.Compare + .IS_GREATER + ) + ) + } + actions.add(ActionAlarm(injector, rh.gs(R.string.time_to_bolus))) + } + + addIfNotExists(event) + } + + override fun removeAutomationEventBolusReminder() { + val event = AutomationEventObject(injector).apply { + title = rh.gs(info.nightscout.core.ui.R.string.bolus_reminder) + } + removeIfExists(event) + } } diff --git a/plugins/automation/src/main/res/values/strings.xml b/plugins/automation/src/main/res/values/strings.xml index 377a27bc7b..7764be8f19 100644 --- a/plugins/automation/src/main/res/values/strings.xml +++ b/plugins/automation/src/main/res/values/strings.xml @@ -131,4 +131,8 @@ S S + + Time to eat!\nRun Bolus wizard and do calculation again. + Time to bolus!\nRun Bolus wizard and do calculation again. + \ No newline at end of file diff --git a/implementation/src/test/java/info/nightscout/implementation/BolusTimerImplTest.kt b/plugins/automation/src/test/java/info/nightscout/automation/BolusTimerImplTest.kt similarity index 71% rename from implementation/src/test/java/info/nightscout/implementation/BolusTimerImplTest.kt rename to plugins/automation/src/test/java/info/nightscout/automation/BolusTimerImplTest.kt index 8a97bad30a..799a48864d 100644 --- a/implementation/src/test/java/info/nightscout/implementation/BolusTimerImplTest.kt +++ b/plugins/automation/src/test/java/info/nightscout/automation/BolusTimerImplTest.kt @@ -1,10 +1,9 @@ -package info.nightscout.implementation +package info.nightscout.automation import android.content.Context import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBase -import info.nightscout.automation.AutomationPlugin import info.nightscout.automation.services.LocationServiceHelper import info.nightscout.automation.triggers.Trigger import info.nightscout.core.utils.fabric.FabricPrivacy @@ -14,16 +13,17 @@ import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.utils.TimerUtil import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test +import org.mockito.ArgumentMatchers.anyInt import org.mockito.Mock -import org.mockito.Mockito.anyInt -import org.mockito.Mockito.`when` +import org.mockito.Mockito class BolusTimerImplTest : TestBase() { @@ -38,6 +38,7 @@ class BolusTimerImplTest : TestBase() { @Mock lateinit var locationServiceHelper: LocationServiceHelper @Mock lateinit var activePlugin: ActivePlugin @Mock lateinit var profileFunction: ProfileFunction + @Mock lateinit var timerUtil: TimerUtil private val injector = HasAndroidInjector { AndroidInjector { @@ -50,23 +51,22 @@ class BolusTimerImplTest : TestBase() { private lateinit var dateUtil: DateUtil private lateinit var automationPlugin: AutomationPlugin - private lateinit var sut: BolusTimerImpl @BeforeEach fun init() { - `when`(rh.gs(anyInt())).thenReturn("") - `when`(profileFunction.getUnits()).thenReturn(GlucoseUnit.MGDL) + Mockito.`when`(rh.gs(anyInt())).thenReturn("") + Mockito.`when`(profileFunction.getUnits()).thenReturn(GlucoseUnit.MGDL) dateUtil = DateUtil(context) - automationPlugin = AutomationPlugin(injector, rh, context, sp, fabricPrivacy, loop, rxBus, constraintChecker, aapsLogger, aapsSchedulers, config, locationServiceHelper, dateUtil, activePlugin) - sut = BolusTimerImpl(injector, rh, automationPlugin) + automationPlugin = AutomationPlugin(injector, rh, context, sp, fabricPrivacy, loop, rxBus, constraintChecker, aapsLogger, aapsSchedulers, config, locationServiceHelper, dateUtil, + activePlugin, timerUtil) } @Test fun doTest() { - Assert.assertEquals(0, automationPlugin.size()) - sut.scheduleAutomationEventBolusReminder() - Assert.assertEquals(1, automationPlugin.size()) - sut.removeAutomationEventBolusReminder() - Assert.assertEquals(0, automationPlugin.size()) + Assertions.assertEquals(0, automationPlugin.size()) + automationPlugin.scheduleAutomationEventBolusReminder() + Assertions.assertEquals(1, automationPlugin.size()) + automationPlugin.removeAutomationEventBolusReminder() + Assertions.assertEquals(0, automationPlugin.size()) } } \ No newline at end of file diff --git a/implementation/src/test/java/info/nightscout/implementation/CarbTimerImplTest.kt b/plugins/automation/src/test/java/info/nightscout/automation/CarbTimerImplTest.kt similarity index 73% rename from implementation/src/test/java/info/nightscout/implementation/CarbTimerImplTest.kt rename to plugins/automation/src/test/java/info/nightscout/automation/CarbTimerImplTest.kt index 87d82e2961..00bb7d4451 100644 --- a/implementation/src/test/java/info/nightscout/implementation/CarbTimerImplTest.kt +++ b/plugins/automation/src/test/java/info/nightscout/automation/CarbTimerImplTest.kt @@ -1,10 +1,9 @@ -package info.nightscout.implementation +package info.nightscout.automation import android.content.Context import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBase -import info.nightscout.automation.AutomationPlugin import info.nightscout.automation.services.LocationServiceHelper import info.nightscout.automation.triggers.Trigger import info.nightscout.core.utils.fabric.FabricPrivacy @@ -19,14 +18,13 @@ import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test +import org.mockito.ArgumentMatchers.any +import org.mockito.ArgumentMatchers.anyInt import org.mockito.Mock import org.mockito.Mockito -import org.mockito.Mockito.any -import org.mockito.Mockito.anyInt -import org.mockito.Mockito.`when` class CarbTimerImplTest : TestBase() { @@ -54,27 +52,26 @@ class CarbTimerImplTest : TestBase() { private lateinit var timerUtil: TimerUtil private lateinit var automationPlugin: AutomationPlugin - private lateinit var sut: CarbTimerImpl @BeforeEach fun init() { - `when`(rh.gs(anyInt())).thenReturn("") - `when`(profileFunction.getUnits()).thenReturn(GlucoseUnit.MGDL) + Mockito.`when`(rh.gs(anyInt())).thenReturn("") + Mockito.`when`(profileFunction.getUnits()).thenReturn(GlucoseUnit.MGDL) dateUtil = DateUtil(context) timerUtil = TimerUtil(context) - automationPlugin = AutomationPlugin(injector, rh, context, sp, fabricPrivacy, loop, rxBus, constraintChecker, aapsLogger, aapsSchedulers, config, locationServiceHelper, dateUtil, activePlugin) - sut = CarbTimerImpl(injector, rh, automationPlugin, timerUtil) + automationPlugin = AutomationPlugin(injector, rh, context, sp, fabricPrivacy, loop, rxBus, constraintChecker, aapsLogger, aapsSchedulers, config, locationServiceHelper, dateUtil, + activePlugin, timerUtil) } @Test fun doTest() { - Assert.assertEquals(0, automationPlugin.size()) - sut.scheduleAutomationEventEatReminder() - Assert.assertEquals(1, automationPlugin.size()) - sut.removeAutomationEventEatReminder() - Assert.assertEquals(0, automationPlugin.size()) + Assertions.assertEquals(0, automationPlugin.size()) + automationPlugin.scheduleAutomationEventEatReminder() + Assertions.assertEquals(1, automationPlugin.size()) + automationPlugin.removeAutomationEventEatReminder() + Assertions.assertEquals(0, automationPlugin.size()) - sut.scheduleTimeToEatReminder(1) + automationPlugin.scheduleTimeToEatReminder(1) Mockito.verify(context, Mockito.times(1)).startActivity(any()) } } \ No newline at end of file diff --git a/ui/src/main/java/info/nightscout/ui/dialogs/CarbsDialog.kt b/ui/src/main/java/info/nightscout/ui/dialogs/CarbsDialog.kt index 878f721741..4809067612 100644 --- a/ui/src/main/java/info/nightscout/ui/dialogs/CarbsDialog.kt +++ b/ui/src/main/java/info/nightscout/ui/dialogs/CarbsDialog.kt @@ -17,12 +17,11 @@ import info.nightscout.database.entities.UserEntry.Sources import info.nightscout.database.entities.ValueWithUnit import info.nightscout.database.impl.AppRepository import info.nightscout.database.impl.transactions.InsertAndCancelCurrentTemporaryTargetTransaction -import info.nightscout.interfaces.BolusTimer -import info.nightscout.interfaces.CarbTimer import info.nightscout.interfaces.Constants.CARBS_FAV1_DEFAULT import info.nightscout.interfaces.Constants.CARBS_FAV2_DEFAULT import info.nightscout.interfaces.Constants.CARBS_FAV3_DEFAULT import info.nightscout.interfaces.GlucoseUnit +import info.nightscout.interfaces.automation.Automation import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.iob.GlucoseStatusProvider @@ -62,8 +61,7 @@ class CarbsDialog : DialogFragmentWithDate() { @Inject lateinit var iobCobCalculator: IobCobCalculator @Inject lateinit var glucoseStatusProvider: GlucoseStatusProvider @Inject lateinit var uel: UserEntryLogger - @Inject lateinit var carbTimer: CarbTimer - @Inject lateinit var bolusTimer: BolusTimer + @Inject lateinit var automation: Automation @Inject lateinit var commandQueue: CommandQueue @Inject lateinit var repository: AppRepository @Inject lateinit var protectionCheck: ProtectionCheck @@ -372,16 +370,16 @@ class CarbsDialog : DialogFragmentWithDate() { ValueWithUnit.Hour(duration).takeIf { duration != 0 }) commandQueue.bolus(detailedBolusInfo, object : Callback() { override fun run() { - carbTimer.removeAutomationEventEatReminder() + automation.removeAutomationEventEatReminder() if (!result.success) { uiInteraction.runAlarm(result.comment, rh.gs(info.nightscout.core.ui.R.string.treatmentdeliveryerror), info.nightscout.core.ui.R.raw.boluserror) } else if (sp.getBoolean(info.nightscout.core.utils.R.string.key_usebolusreminder, false) && remindBolus) - bolusTimer.scheduleAutomationEventBolusReminder() + automation.scheduleAutomationEventBolusReminder() } }) } if (useAlarm && carbs > 0 && timeOffset > 0) { - carbTimer.scheduleTimeToEatReminder(T.mins(timeOffset.toLong()).secs().toInt()) + automation.scheduleTimeToEatReminder(T.mins(timeOffset.toLong()).secs().toInt()) } }, null) } diff --git a/ui/src/main/java/info/nightscout/ui/dialogs/InsulinDialog.kt b/ui/src/main/java/info/nightscout/ui/dialogs/InsulinDialog.kt index 2d8854343b..d60a56e887 100644 --- a/ui/src/main/java/info/nightscout/ui/dialogs/InsulinDialog.kt +++ b/ui/src/main/java/info/nightscout/ui/dialogs/InsulinDialog.kt @@ -16,12 +16,12 @@ import info.nightscout.database.entities.UserEntry import info.nightscout.database.entities.ValueWithUnit import info.nightscout.database.impl.AppRepository import info.nightscout.database.impl.transactions.InsertAndCancelCurrentTemporaryTargetTransaction -import info.nightscout.interfaces.BolusTimer import info.nightscout.interfaces.Config import info.nightscout.interfaces.Constants.INSULIN_PLUS1_DEFAULT import info.nightscout.interfaces.Constants.INSULIN_PLUS2_DEFAULT import info.nightscout.interfaces.Constants.INSULIN_PLUS3_DEFAULT import info.nightscout.interfaces.GlucoseUnit +import info.nightscout.interfaces.automation.Automation import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.db.PersistenceLayer @@ -65,7 +65,7 @@ class InsulinDialog : DialogFragmentWithDate() { @Inject lateinit var ctx: Context @Inject lateinit var repository: AppRepository @Inject lateinit var config: Config - @Inject lateinit var bolusTimer: BolusTimer + @Inject lateinit var automation: Automation @Inject lateinit var uel: UserEntryLogger @Inject lateinit var protectionCheck: ProtectionCheck @Inject lateinit var uiInteraction: UiInteraction @@ -256,7 +256,7 @@ class InsulinDialog : DialogFragmentWithDate() { ValueWithUnit.Minute(timeOffset).takeIf { timeOffset != 0 }) persistenceLayer.insertOrUpdateBolus(detailedBolusInfo.createBolus()) if (timeOffset == 0) - bolusTimer.removeAutomationEventBolusReminder() + automation.removeAutomationEventBolusReminder() } else { uel.log( UserEntry.Action.BOLUS, UserEntry.Sources.InsulinDialog, @@ -268,7 +268,7 @@ class InsulinDialog : DialogFragmentWithDate() { if (!result.success) { uiInteraction.runAlarm(result.comment, rh.gs(info.nightscout.core.ui.R.string.treatmentdeliveryerror), info.nightscout.core.ui.R.raw.boluserror) } else { - bolusTimer.removeAutomationEventBolusReminder() + automation.removeAutomationEventBolusReminder() } } }) From 8791e93cc920c10e1f595f7a3f22f19daa13c729 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 11:47:57 +0100 Subject: [PATCH 18/48] move out of :core:main --- app/src/main/AndroidManifest.xml | 2 +- .../implementations/UiInteractionImpl.kt | 4 +- .../nightscout/interfaces/aps/APSResult.kt | 1 + .../nightscout/interfaces/aps/AutosensData.kt | 7 +++ .../info/nightscout/interfaces/aps/Loop.kt | 2 + .../interfaces/iob/IobCobCalculator.kt | 2 + .../core/di/CoreDataClassesModule.kt | 4 -- .../info/nightscout/core/di/CoreModule.kt | 5 +- .../info/nightscout/core/di/ServicesModule.kt | 12 ---- .../core/profile/ProfileStoreObject.kt | 2 - .../plugins}/aps/APSResultObject.kt | 13 ++-- .../nightscout/plugins/aps/di/ApsModule.kt | 3 + .../nightscout/plugins/aps/di/LoopModule.kt | 6 +- .../nightscout/plugins/aps/loop/LoopPlugin.kt | 4 ++ .../openAPSAMA/DetermineBasalAdapterAMAJS.kt | 2 +- .../aps/openAPSAMA/DetermineBasalResultAMA.kt | 2 +- .../openAPSSMB/DetermineBasalAdapterSMBJS.kt | 2 +- .../aps/openAPSSMB/DetermineBasalResultSMB.kt | 2 +- .../androidaps/TestBaseWithProfile.kt | 3 + .../plugins/aps/loop/APSResultTest.kt | 61 +++++++++---------- plugins/automation/build.gradle | 1 + .../automation/actions/ActionsTestBase.kt | 8 ++- .../triggers/TriggerAutosensValueTest.kt | 44 ++++++------- .../nightscout/plugins/di/PluginsModule.kt | 3 + .../IobCobCalculatorPlugin.kt | 3 + .../data/AutosensDataObject.kt | 23 +++---- .../data/ProcessedDeviceStatusDataImpl.kt | 16 ++--- .../ui/activities/ErrorHelperActivity.kt | 2 +- .../java/info/nightscout/ui/di/UiModule.kt | 3 + .../ui}/services/AlarmSoundService.kt | 2 +- .../ui}/services/AlarmSoundServiceHelper.kt | 2 +- .../androidaps/testing/mocks/BundleMock.java | 3 +- .../PrepareIobAutosensGraphDataWorker.kt | 6 +- .../workflow/iob/IobCobOref1Worker.kt | 3 +- .../workflow/iob/IobCobOrefWorker.kt | 13 ++-- 35 files changed, 146 insertions(+), 125 deletions(-) delete mode 100644 core/main/src/main/java/info/nightscout/core/di/ServicesModule.kt delete mode 100644 core/main/src/main/java/info/nightscout/core/profile/ProfileStoreObject.kt rename {core/main/src/main/java/info/nightscout/core => plugins/aps/src/main/java/info/nightscout/plugins}/aps/APSResultObject.kt (98%) rename {core/main/src/test/java/info/nightscout/androidaps => plugins/aps/src/test/java/info/nightscout}/plugins/aps/loop/APSResultTest.kt (84%) rename {core/main/src/main/java/info/nightscout/core => plugins/main/src/main/java/info/nightscout/plugins}/iob/iobCobCalculator/data/AutosensDataObject.kt (91%) rename {core/main/src/main/java/info/nightscout/core => ui/src/main/java/info/nightscout/ui}/services/AlarmSoundService.kt (99%) rename {core/main/src/main/java/info/nightscout/core => ui/src/main/java/info/nightscout/ui}/services/AlarmSoundServiceHelper.kt (98%) diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 7af9821bee..124d50535e 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -132,7 +132,7 @@ + var absorbed: Double var carbsFromBolus: Double var cob: Double + var bgi: Double + var delta: Double + var avgDelta: Double var slopeFromMaxDeviation: Double var slopeFromMinDeviation: Double var usedMinCarbsImpact: Double @@ -37,4 +42,6 @@ interface AutosensData { var autosensResult: AutosensResult fun cloneCarbsList(): MutableList + fun deductAbsorbedCarbs() + fun removeOldCarbs(toTime: Long, isAAPSOrWeighted: Boolean) } \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/aps/Loop.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/aps/Loop.kt index c0eac9f4eb..dc96f4ea91 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/aps/Loop.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/aps/Loop.kt @@ -57,4 +57,6 @@ interface Loop { runningConfiguration: RunningConfiguration, version: String ): DeviceStatus? + + fun provideEmptyAPSResultObject(): APSResult } \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/iob/IobCobCalculator.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/iob/IobCobCalculator.kt index a88237a838..66a1af0fd6 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/iob/IobCobCalculator.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/iob/IobCobCalculator.kt @@ -104,4 +104,6 @@ interface IobCobCalculator { * @return IobTotal */ fun calculateIobFromTempBasalsIncludingConvertedExtended(): IobTotal + + fun provideEmptyAutosensDataObject(): AutosensData } \ No newline at end of file diff --git a/core/main/src/main/java/info/nightscout/core/di/CoreDataClassesModule.kt b/core/main/src/main/java/info/nightscout/core/di/CoreDataClassesModule.kt index d5e6d5431d..e94b388f44 100644 --- a/core/main/src/main/java/info/nightscout/core/di/CoreDataClassesModule.kt +++ b/core/main/src/main/java/info/nightscout/core/di/CoreDataClassesModule.kt @@ -2,8 +2,6 @@ package info.nightscout.core.di import dagger.Module import dagger.android.ContributesAndroidInjector -import info.nightscout.core.aps.APSResultObject -import info.nightscout.core.iob.iobCobCalculator.data.AutosensDataObject import info.nightscout.core.wizard.BolusWizard import info.nightscout.core.wizard.QuickWizardEntry import info.nightscout.interfaces.pump.PumpEnactResult @@ -13,8 +11,6 @@ import info.nightscout.interfaces.pump.PumpEnactResult abstract class CoreDataClassesModule { @ContributesAndroidInjector abstract fun pumpEnactResultInjector(): PumpEnactResult - @ContributesAndroidInjector abstract fun apsResultInjector(): APSResultObject - @ContributesAndroidInjector abstract fun autosensDataInjector(): AutosensDataObject @ContributesAndroidInjector abstract fun bolusWizardInjector(): BolusWizard @ContributesAndroidInjector abstract fun quickWizardEntryInjector(): QuickWizardEntry } diff --git a/core/main/src/main/java/info/nightscout/core/di/CoreModule.kt b/core/main/src/main/java/info/nightscout/core/di/CoreModule.kt index 627e0d0f24..5d49cc0571 100644 --- a/core/main/src/main/java/info/nightscout/core/di/CoreModule.kt +++ b/core/main/src/main/java/info/nightscout/core/di/CoreModule.kt @@ -5,14 +5,11 @@ import android.os.Build import android.telephony.SmsManager import dagger.Module import dagger.Provides -import dagger.android.ContributesAndroidInjector -import info.nightscout.core.services.AlarmSoundService @Module( includes = [ CoreDataClassesModule::class, - PreferencesModule::class, - ServicesModule::class + PreferencesModule::class ] ) open class CoreModule { diff --git a/core/main/src/main/java/info/nightscout/core/di/ServicesModule.kt b/core/main/src/main/java/info/nightscout/core/di/ServicesModule.kt deleted file mode 100644 index 3debe1c342..0000000000 --- a/core/main/src/main/java/info/nightscout/core/di/ServicesModule.kt +++ /dev/null @@ -1,12 +0,0 @@ -package info.nightscout.core.di - -import dagger.Module -import dagger.android.ContributesAndroidInjector -import info.nightscout.core.services.AlarmSoundService - -@Module -@Suppress("unused") -abstract class ServicesModule { - - @ContributesAndroidInjector abstract fun contributesAlarmSoundService(): AlarmSoundService -} \ No newline at end of file diff --git a/core/main/src/main/java/info/nightscout/core/profile/ProfileStoreObject.kt b/core/main/src/main/java/info/nightscout/core/profile/ProfileStoreObject.kt deleted file mode 100644 index d857c4eab2..0000000000 --- a/core/main/src/main/java/info/nightscout/core/profile/ProfileStoreObject.kt +++ /dev/null @@ -1,2 +0,0 @@ -package info.nightscout.core.profile - diff --git a/core/main/src/main/java/info/nightscout/core/aps/APSResultObject.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/APSResultObject.kt similarity index 98% rename from core/main/src/main/java/info/nightscout/core/aps/APSResultObject.kt rename to plugins/aps/src/main/java/info/nightscout/plugins/aps/APSResultObject.kt index 1914d740f7..1e86c69c53 100644 --- a/core/main/src/main/java/info/nightscout/core/aps/APSResultObject.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/APSResultObject.kt @@ -1,9 +1,10 @@ -package info.nightscout.core.aps +package info.nightscout.plugins.aps import android.text.Spanned import dagger.android.HasAndroidInjector import info.nightscout.core.extensions.convertedToAbsolute import info.nightscout.core.extensions.convertedToPercent +import info.nightscout.core.ui.R import info.nightscout.database.entities.GlucoseValue import info.nightscout.interfaces.aps.APSResult import info.nightscout.interfaces.constraints.Constraint @@ -14,7 +15,7 @@ import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.pump.defs.PumpDescription import info.nightscout.interfaces.utils.DecimalFormatter -import info.nightscout.interfaces.utils.HtmlHelper.fromHtml +import info.nightscout.interfaces.utils.HtmlHelper import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper @@ -41,7 +42,7 @@ open class APSResultObject @Inject constructor(val injector: HasAndroidInjector) @Inject lateinit var rh: ResourceHelper @Inject lateinit var dateUtil: DateUtil - var date: Long = 0 + override var date: Long = 0 override var reason: String = "" override var rate = 0.0 override var percent = 0 @@ -116,11 +117,11 @@ open class APSResultObject @Inject constructor(val injector: HasAndroidInjector) // reason ret += "" + rh.gs(info.nightscout.core.ui.R.string.reason) + ": " + reason.replace("<", "<").replace(">", ">") - return fromHtml(ret) + return HtmlHelper.fromHtml(ret) } return if (isCarbsRequired) { - fromHtml(carbsRequiredText) - } else fromHtml(rh.gs(info.nightscout.core.ui.R.string.nochangerequested)) + HtmlHelper.fromHtml(carbsRequiredText) + } else HtmlHelper.fromHtml(rh.gs(R.string.nochangerequested)) } override fun newAndClone(injector: HasAndroidInjector): APSResult { diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/di/ApsModule.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/di/ApsModule.kt index 305571b652..db2efe7902 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/di/ApsModule.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/di/ApsModule.kt @@ -3,8 +3,10 @@ package info.nightscout.plugins.aps.di import dagger.Binds import dagger.Module import dagger.android.ContributesAndroidInjector +import info.nightscout.interfaces.aps.APSResult import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.autotune.Autotune +import info.nightscout.plugins.aps.APSResultObject import info.nightscout.plugins.aps.OpenAPSFragment import info.nightscout.plugins.aps.loop.LoopPlugin import info.nightscout.plugins.general.autotune.AutotunePlugin @@ -22,6 +24,7 @@ import info.nightscout.plugins.general.autotune.AutotunePlugin abstract class ApsModule { @ContributesAndroidInjector abstract fun contributesOpenAPSFragment(): OpenAPSFragment + @ContributesAndroidInjector abstract fun apsResultInjector(): APSResultObject @Module interface Bindings { diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/di/LoopModule.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/di/LoopModule.kt index e827400c1c..d04bee6705 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/di/LoopModule.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/di/LoopModule.kt @@ -2,10 +2,12 @@ package info.nightscout.plugins.aps.di import dagger.Module import dagger.android.ContributesAndroidInjector +import info.nightscout.plugins.aps.loop.CarbSuggestionReceiver +import info.nightscout.plugins.aps.loop.LoopFragment @Module @Suppress("unused") abstract class LoopModule { - @ContributesAndroidInjector abstract fun contributesLoopFragment(): info.nightscout.plugins.aps.loop.LoopFragment - @ContributesAndroidInjector abstract fun contributesCarbSuggestionReceiver(): info.nightscout.plugins.aps.loop.CarbSuggestionReceiver + @ContributesAndroidInjector abstract fun contributesLoopFragment(): LoopFragment + @ContributesAndroidInjector abstract fun contributesCarbSuggestionReceiver(): CarbSuggestionReceiver } \ No newline at end of file diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/loop/LoopPlugin.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/loop/LoopPlugin.kt index 934fd1c9e8..7ae6516800 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/loop/LoopPlugin.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/loop/LoopPlugin.kt @@ -57,6 +57,7 @@ import info.nightscout.interfaces.queue.CommandQueue import info.nightscout.interfaces.receivers.ReceiverStatusStore import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits +import info.nightscout.plugins.aps.APSResultObject import info.nightscout.plugins.aps.R import info.nightscout.plugins.aps.loop.events.EventLoopSetLastRunGui import info.nightscout.plugins.aps.loop.extensions.json @@ -782,6 +783,9 @@ class LoopPlugin @Inject constructor( configuration = runningConfiguration.configuration().toString() ) } + + override fun provideEmptyAPSResultObject(): APSResult = APSResultObject(injector) + companion object { private const val CHANNEL_ID = "AAPS-OpenLoop" diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/DetermineBasalAdapterAMAJS.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/DetermineBasalAdapterAMAJS.kt index 34c6253160..e65441e276 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/DetermineBasalAdapterAMAJS.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/DetermineBasalAdapterAMAJS.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.aps.openAPSAMA import dagger.android.HasAndroidInjector -import info.nightscout.core.aps.APSResultObject +import info.nightscout.plugins.aps.APSResultObject import info.nightscout.core.extensions.convertedToAbsolute import info.nightscout.core.extensions.getPassedDurationToTimeInMinutes import info.nightscout.core.extensions.plannedRemainingMinutes diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/DetermineBasalResultAMA.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/DetermineBasalResultAMA.kt index e79082c38a..46560190a0 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/DetermineBasalResultAMA.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSAMA/DetermineBasalResultAMA.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.aps.openAPSAMA import dagger.android.HasAndroidInjector -import info.nightscout.core.aps.APSResultObject +import info.nightscout.plugins.aps.APSResultObject import info.nightscout.rx.logging.LTag import org.json.JSONException import org.json.JSONObject diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/DetermineBasalAdapterSMBJS.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/DetermineBasalAdapterSMBJS.kt index 2adf294d8a..c882fc9e8f 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/DetermineBasalAdapterSMBJS.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/DetermineBasalAdapterSMBJS.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.aps.openAPSSMB import dagger.android.HasAndroidInjector -import info.nightscout.core.aps.APSResultObject +import info.nightscout.plugins.aps.APSResultObject import info.nightscout.core.extensions.convertedToAbsolute import info.nightscout.core.extensions.getPassedDurationToTimeInMinutes import info.nightscout.core.extensions.plannedRemainingMinutes diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/DetermineBasalResultSMB.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/DetermineBasalResultSMB.kt index 446b09a952..6fa9f3d375 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/DetermineBasalResultSMB.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/openAPSSMB/DetermineBasalResultSMB.kt @@ -1,7 +1,7 @@ package info.nightscout.plugins.aps.openAPSSMB import dagger.android.HasAndroidInjector -import info.nightscout.core.aps.APSResultObject +import info.nightscout.plugins.aps.APSResultObject import info.nightscout.interfaces.aps.VariableSensitivityResult import info.nightscout.rx.logging.LTag import org.json.JSONException diff --git a/plugins/aps/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt b/plugins/aps/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt index ef46cbe7e0..7e219660cf 100644 --- a/plugins/aps/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt +++ b/plugins/aps/src/test/java/info/nightscout/androidaps/TestBaseWithProfile.kt @@ -38,6 +38,7 @@ open class TestBaseWithProfile : TestBase() { @Mock lateinit var context: Context lateinit var dateUtil: DateUtil + lateinit var testPumpPlugin: TestPumpPlugin val rxBus = RxBus(aapsSchedulers, aapsLogger) val profileInjector = HasAndroidInjector { AndroidInjector { } } @@ -56,6 +57,8 @@ open class TestBaseWithProfile : TestBase() { dateUtil = Mockito.spy(DateUtil(context)) `when`(dateUtil.now()).thenReturn(1656358822000) validProfile = ProfileSealed.Pure(pureProfileFromJson(JSONObject(validProfileJSON), dateUtil)!!) + testPumpPlugin = TestPumpPlugin(profileInjector) + `when`(activePluginProvider.activePump).thenReturn(testPumpPlugin) effectiveProfileSwitch = EffectiveProfileSwitch( timestamp = dateUtil.now(), basalBlocks = validProfile.basalBlocks, diff --git a/core/main/src/test/java/info/nightscout/androidaps/plugins/aps/loop/APSResultTest.kt b/plugins/aps/src/test/java/info/nightscout/plugins/aps/loop/APSResultTest.kt similarity index 84% rename from core/main/src/test/java/info/nightscout/androidaps/plugins/aps/loop/APSResultTest.kt rename to plugins/aps/src/test/java/info/nightscout/plugins/aps/loop/APSResultTest.kt index 758c2260de..f747c1a22d 100644 --- a/core/main/src/test/java/info/nightscout/androidaps/plugins/aps/loop/APSResultTest.kt +++ b/plugins/aps/src/test/java/info/nightscout/plugins/aps/loop/APSResultTest.kt @@ -1,17 +1,16 @@ -package info.nightscout.androidaps.plugins.aps.loop +package info.nightscout.plugins.aps.loop import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBaseWithProfile -import info.nightscout.core.aps.APSResultObject import info.nightscout.database.entities.TemporaryBasal import info.nightscout.interfaces.aps.APSResult import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints -import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.pump.defs.PumpType import info.nightscout.interfaces.utils.JsonHelper.safeGetDouble -import org.junit.Assert +import info.nightscout.shared.sharedPreferences.SP +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.ArgumentMatchers @@ -21,7 +20,7 @@ import org.mockito.Mockito.`when` class APSResultTest : TestBaseWithProfile() { @Mock lateinit var constraints: Constraints - @Mock lateinit var iobCobCalculator: IobCobCalculator + @Mock lateinit var sp: SP private val injector = HasAndroidInjector { AndroidInjector { } } @@ -55,7 +54,7 @@ class APSResultTest : TestBaseWithProfile() { @Test fun changeRequestedTest() { - val apsResult = APSResultObject { AndroidInjector { } } + val apsResult = info.nightscout.plugins.aps.APSResultObject { AndroidInjector { } } .also { it.aapsLogger = aapsLogger it.constraintChecker = constraints @@ -76,21 +75,21 @@ class APSResultTest : TestBaseWithProfile() { closedLoopEnabled.set(aapsLogger, true) `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn(null) apsResult.tempBasalRequested(false) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) apsResult.tempBasalRequested(true).percent(200).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) // open loop closedLoopEnabled.set(aapsLogger, false) // no change requested `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn(null) apsResult.tempBasalRequested(false) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) // request 100% when no temp is running `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn(null) apsResult.tempBasalRequested(true).percent(100).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) // request equal temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -103,7 +102,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).percent(70).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) // request zero temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -116,7 +115,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).percent(0).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) // request high temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -129,7 +128,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).percent(200).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) // request slightly different temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -142,7 +141,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).percent(80).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) // request different temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -155,7 +154,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).percent(120).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) // it should work with absolute temps too // request different temp @@ -169,7 +168,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).percent(100).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( TemporaryBasal( timestamp = 0, @@ -180,7 +179,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).percent(50).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) // **** ABSOLUTE pump **** testPumpPlugin.pumpDescription.fillFor(PumpType.MEDTRONIC_515_715) // U/h based @@ -191,7 +190,7 @@ class APSResultTest : TestBaseWithProfile() { // request 100% when no temp is running `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn(null) apsResult.tempBasalRequested(true).rate(1.0).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) // request equal temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -204,7 +203,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).rate(2.0).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( TemporaryBasal( timestamp = 0, @@ -215,7 +214,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).rate(2.0).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) // request zero temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -228,7 +227,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).rate(0.0).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) // request high temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -241,7 +240,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).rate(35.0).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) // request slightly different temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -254,7 +253,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).rate(1.2).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) // request different temp `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( @@ -267,7 +266,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).rate(1.5).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) // it should work with percent temps too // request different temp @@ -281,7 +280,7 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).rate(1.1).duration(30) - Assert.assertEquals(false, apsResult.isChangeRequested) + Assertions.assertEquals(false, apsResult.isChangeRequested) `when`(iobCobCalculator.getTempBasalIncludingConvertedExtended(ArgumentMatchers.anyLong())).thenReturn( TemporaryBasal( timestamp = 0, @@ -292,11 +291,11 @@ class APSResultTest : TestBaseWithProfile() { ) ) apsResult.tempBasalRequested(true).rate(0.5).duration(30) - Assert.assertEquals(true, apsResult.isChangeRequested) + Assertions.assertEquals(true, apsResult.isChangeRequested) } @Test fun cloneTest() { - val apsResult = APSResultObject { AndroidInjector { } } + val apsResult = info.nightscout.plugins.aps.APSResultObject { AndroidInjector { } } .also { it.aapsLogger = aapsLogger it.constraintChecker = constraints @@ -308,12 +307,12 @@ class APSResultTest : TestBaseWithProfile() { } apsResult.rate(10.0) val apsResult2 = apsResult.newAndClone(injector) - Assert.assertEquals(apsResult.rate, apsResult2.rate, 0.0) + Assertions.assertEquals(apsResult.rate, apsResult2.rate, 0.0) } @Test fun jsonTest() { closedLoopEnabled.set(aapsLogger, true) - val apsResult = APSResultObject { AndroidInjector { } } + val apsResult = info.nightscout.plugins.aps.APSResultObject { AndroidInjector { } } .also { it.aapsLogger = aapsLogger it.constraintChecker = constraints @@ -324,9 +323,9 @@ class APSResultTest : TestBaseWithProfile() { it.rh = rh } apsResult.rate(20.0).tempBasalRequested(true) - Assert.assertEquals(20.0, safeGetDouble(apsResult.json(), "rate"), 0.0) + Assertions.assertEquals(20.0, safeGetDouble(apsResult.json(), "rate"), 0.0) apsResult.rate(20.0).tempBasalRequested(false) - Assert.assertEquals(false, apsResult.json()?.has("rate")) + Assertions.assertEquals(false, apsResult.json()?.has("rate")) } @BeforeEach diff --git a/plugins/automation/build.gradle b/plugins/automation/build.gradle index 304374ca9c..c1b50cd96f 100644 --- a/plugins/automation/build.gradle +++ b/plugins/automation/build.gradle @@ -28,6 +28,7 @@ dependencies { implementation project(':core:interfaces') testImplementation project(':implementation') + testImplementation project(':plugins:main') api "androidx.constraintlayout:constraintlayout:$constraintlayout_version" api "com.google.android.gms:play-services-location:$play_services_location_version" diff --git a/plugins/automation/src/test/java/info/nightscout/automation/actions/ActionsTestBase.kt b/plugins/automation/src/test/java/info/nightscout/automation/actions/ActionsTestBase.kt index f286296d47..c8972b3510 100644 --- a/plugins/automation/src/test/java/info/nightscout/automation/actions/ActionsTestBase.kt +++ b/plugins/automation/src/test/java/info/nightscout/automation/actions/ActionsTestBase.kt @@ -10,6 +10,7 @@ import info.nightscout.database.entities.DeviceStatus import info.nightscout.database.entities.OfflineEvent import info.nightscout.interfaces.ConfigBuilder import info.nightscout.interfaces.GlucoseUnit +import info.nightscout.interfaces.aps.APSResult import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.configBuilder.RunningConfiguration import info.nightscout.interfaces.constraints.Constraint @@ -42,7 +43,8 @@ ActionsTestBase : TestBaseWithProfile() { aapsLogger: AAPSLogger, rh: ResourceHelper, injector: HasAndroidInjector, - pluginDescription: PluginDescription + pluginDescription: PluginDescription, + private val apsResult: APSResult ) : PluginBase( pluginDescription, aapsLogger, rh, injector ), Loop { @@ -75,6 +77,9 @@ ActionsTestBase : TestBaseWithProfile() { runningConfiguration: RunningConfiguration, version: String ): DeviceStatus? = null + + override fun provideEmptyAPSResultObject(): APSResult = apsResult + override fun setPluginEnabled(type: PluginType, newState: Boolean) {} } @@ -87,6 +92,7 @@ ActionsTestBase : TestBaseWithProfile() { @Mock lateinit var loopPlugin: TestLoopPlugin @Mock lateinit var uel: UserEntryLogger @Mock lateinit var context: Context + @Mock lateinit var apsResult: APSResult private val pluginDescription = PluginDescription() lateinit var testPumpPlugin: TestPumpPlugin diff --git a/plugins/automation/src/test/java/info/nightscout/automation/triggers/TriggerAutosensValueTest.kt b/plugins/automation/src/test/java/info/nightscout/automation/triggers/TriggerAutosensValueTest.kt index e059d38390..7ed8250f79 100644 --- a/plugins/automation/src/test/java/info/nightscout/automation/triggers/TriggerAutosensValueTest.kt +++ b/plugins/automation/src/test/java/info/nightscout/automation/triggers/TriggerAutosensValueTest.kt @@ -3,9 +3,9 @@ package info.nightscout.automation.triggers import com.google.common.base.Optional import info.nightscout.automation.R import info.nightscout.automation.elements.Comparator -import info.nightscout.core.iob.iobCobCalculator.data.AutosensDataObject +import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataObject import org.json.JSONObject -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.ArgumentMatchers @@ -22,53 +22,53 @@ class TriggerAutosensValueTest : TriggerTestBase() { var t = TriggerAutosensValue(injector) t.autosens.value = 110.0 t.comparator.value = Comparator.Compare.IS_EQUAL - Assert.assertEquals(110.0, t.autosens.value, 0.01) - Assert.assertEquals(Comparator.Compare.IS_EQUAL, t.comparator.value) - Assert.assertFalse(t.shouldRun()) + Assertions.assertEquals(110.0, t.autosens.value, 0.01) + Assertions.assertEquals(Comparator.Compare.IS_EQUAL, t.comparator.value) + Assertions.assertFalse(t.shouldRun()) t = TriggerAutosensValue(injector) t.autosens.value = 100.0 t.comparator.value = Comparator.Compare.IS_EQUAL - Assert.assertEquals(100.0, t.autosens.value, 0.01) - Assert.assertTrue(t.shouldRun()) + Assertions.assertEquals(100.0, t.autosens.value, 0.01) + Assertions.assertTrue(t.shouldRun()) t = TriggerAutosensValue(injector) t.autosens.value = 50.0 t.comparator.value = Comparator.Compare.IS_EQUAL_OR_GREATER - Assert.assertTrue(t.shouldRun()) + Assertions.assertTrue(t.shouldRun()) t = TriggerAutosensValue(injector) t.autosens.value = 310.0 t.comparator.value = Comparator.Compare.IS_EQUAL_OR_LESSER - Assert.assertTrue(t.shouldRun()) + Assertions.assertTrue(t.shouldRun()) t = TriggerAutosensValue(injector) t.autosens.value = 420.0 t.comparator.value = Comparator.Compare.IS_EQUAL - Assert.assertFalse(t.shouldRun()) + Assertions.assertFalse(t.shouldRun()) t = TriggerAutosensValue(injector) t.autosens.value = 390.0 t.comparator.value = Comparator.Compare.IS_EQUAL_OR_LESSER - Assert.assertTrue(t.shouldRun()) + Assertions.assertTrue(t.shouldRun()) t = TriggerAutosensValue(injector) t.autosens.value = 390.0 t.comparator.value = Comparator.Compare.IS_EQUAL_OR_GREATER - Assert.assertFalse(t.shouldRun()) + Assertions.assertFalse(t.shouldRun()) t = TriggerAutosensValue(injector) t.autosens.value = 20.0 t.comparator.value = Comparator.Compare.IS_EQUAL_OR_GREATER - Assert.assertTrue(t.shouldRun()) + Assertions.assertTrue(t.shouldRun()) t = TriggerAutosensValue(injector) t.autosens.value = 390.0 t.comparator.value = Comparator.Compare.IS_EQUAL_OR_LESSER - Assert.assertTrue(t.shouldRun()) + Assertions.assertTrue(t.shouldRun()) `when`(autosensDataStore.getLastAutosensData(anyObject(), anyObject(), anyObject())).thenReturn(AutosensDataObject(injector)) t = TriggerAutosensValue(injector) t.autosens.value = 80.0 t.comparator.value = Comparator.Compare.IS_EQUAL_OR_LESSER - Assert.assertFalse(t.shouldRun()) + Assertions.assertFalse(t.shouldRun()) // Test autosensData == null and Comparator == IS_NOT_AVAILABLE `when`(autosensDataStore.getLastAutosensData(anyObject(), anyObject(), anyObject())).thenReturn(null) t = TriggerAutosensValue(injector) t.comparator.value = Comparator.Compare.IS_NOT_AVAILABLE - Assert.assertTrue(t.shouldRun()) + Assertions.assertTrue(t.shouldRun()) } @Test @@ -77,8 +77,8 @@ class TriggerAutosensValueTest : TriggerTestBase() { t.autosens.value = 213.0 t.comparator.value = Comparator.Compare.IS_EQUAL_OR_LESSER val t1 = t.duplicate() as TriggerAutosensValue - Assert.assertEquals(213.0, t1.autosens.value, 0.01) - Assert.assertEquals(Comparator.Compare.IS_EQUAL_OR_LESSER, t.comparator.value) + Assertions.assertEquals(213.0, t1.autosens.value, 0.01) + Assertions.assertEquals(Comparator.Compare.IS_EQUAL_OR_LESSER, t.comparator.value) } private var asJson = "{\"data\":{\"comparator\":\"IS_EQUAL\",\"value\":410},\"type\":\"TriggerAutosensValue\"}" @@ -88,7 +88,7 @@ class TriggerAutosensValueTest : TriggerTestBase() { val t = TriggerAutosensValue(injector) t.autosens.value = 410.0 t.comparator.value = Comparator.Compare.IS_EQUAL - Assert.assertEquals(asJson, t.toJSON()) + Assertions.assertEquals(asJson, t.toJSON()) } @Test @@ -97,12 +97,12 @@ class TriggerAutosensValueTest : TriggerTestBase() { t.autosens.value = 410.0 t.comparator.value = Comparator.Compare.IS_EQUAL val t2 = TriggerDummy(injector).instantiate(JSONObject(t.toJSON())) as TriggerAutosensValue - Assert.assertEquals(Comparator.Compare.IS_EQUAL, t2.comparator.value) - Assert.assertEquals(410.0, t2.autosens.value, 0.01) + Assertions.assertEquals(Comparator.Compare.IS_EQUAL, t2.comparator.value) + Assertions.assertEquals(410.0, t2.autosens.value, 0.01) } @Test fun iconTest() { - Assert.assertEquals(Optional.of(R.drawable.ic_as), TriggerAutosensValue(injector).icon()) + Assertions.assertEquals(Optional.of(R.drawable.ic_as), TriggerAutosensValue(injector).icon()) } @BeforeEach diff --git a/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt b/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt index ea1fe6c73b..5fda8f728e 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt @@ -9,6 +9,7 @@ import info.nightscout.plugins.general.persistentNotification.DummyService import info.nightscout.plugins.general.smsCommunicator.SmsCommunicatorPlugin import info.nightscout.plugins.general.wear.WearFragment import info.nightscout.plugins.iob.iobCobCalculator.IobCobCalculatorPlugin +import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataObject @Module( includes = [ @@ -32,6 +33,8 @@ abstract class PluginsModule { @ContributesAndroidInjector abstract fun contributesWearFragment(): WearFragment @ContributesAndroidInjector abstract fun contributesDummyService(): DummyService + @ContributesAndroidInjector abstract fun autosensDataObjectInjector(): AutosensDataObject + @Module interface Bindings { diff --git a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt index 2890d9b828..345005de50 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt @@ -38,6 +38,7 @@ import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.utils.DecimalFormatter import info.nightscout.interfaces.utils.MidnightTime import info.nightscout.plugins.R +import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataObject import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataStoreObject import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus @@ -599,6 +600,8 @@ class IobCobCalculatorPlugin @Inject constructor( override fun calculateIobFromTempBasalsIncludingConvertedExtended(): IobTotal = calculateIobToTimeFromTempBasalsIncludingConvertedExtended(dateUtil.now()) + override fun provideEmptyAutosensDataObject(): AutosensData = AutosensDataObject(injector) + override fun calculateIobToTimeFromTempBasalsIncludingConvertedExtended(toTime: Long): IobTotal { val total = IobTotal(toTime) val now = dateUtil.now() diff --git a/core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/data/AutosensDataObject.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataObject.kt similarity index 91% rename from core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/data/AutosensDataObject.kt rename to plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataObject.kt index 84064cbaa2..523ebb57eb 100644 --- a/core/main/src/main/java/info/nightscout/core/iob/iobCobCalculator/data/AutosensDataObject.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataObject.kt @@ -1,4 +1,4 @@ -package info.nightscout.core.iob.iobCobCalculator.data +package info.nightscout.plugins.iob.iobCobCalculator.data import dagger.android.HasAndroidInjector import info.nightscout.interfaces.Constants @@ -22,18 +22,22 @@ class AutosensDataObject(injector: HasAndroidInjector) : AutosensData { @Inject lateinit var profileFunction: ProfileFunction @Inject lateinit var dateUtil: DateUtil + init { + injector.androidInjector().inject(this) + } + override var time = 0L override var bg = 0.0 // mgdl override var pastSensitivity = "" override var deviation = 0.0 override var validDeviation = false - var activeCarbsList: MutableList = ArrayList() - var absorbed = 0.0 + override var activeCarbsList: MutableList = ArrayList() + override var absorbed = 0.0 override var carbsFromBolus = 0.0 override var cob = 0.0 - var bgi = 0.0 - var delta = 0.0 - var avgDelta = 0.0 + override var bgi = 0.0 + override var delta = 0.0 + override var avgDelta = 0.0 override var avgDeviation = 0.0 override var autosensResult = AutosensResult() override var slopeFromMaxDeviation = 0.0 @@ -86,7 +90,7 @@ class AutosensDataObject(injector: HasAndroidInjector) : AutosensData { } // remove carbs older than timeframe - fun removeOldCarbs(toTime: Long, isAAPSOrWeighted: Boolean) { + override fun removeOldCarbs(toTime: Long, isAAPSOrWeighted: Boolean) { val maxAbsorptionHours: Double = if (isAAPSOrWeighted) sp.getDouble(info.nightscout.core.utils.R.string.key_absorption_maxtime, Constants.DEFAULT_MAX_ABSORPTION_TIME) else sp.getDouble(info.nightscout.core.utils.R.string.key_absorption_cutoff, Constants.DEFAULT_MAX_ABSORPTION_TIME) @@ -102,7 +106,7 @@ class AutosensDataObject(injector: HasAndroidInjector) : AutosensData { } } - fun deductAbsorbedCarbs() { + override fun deductAbsorbedCarbs() { var ac = absorbed var i = 0 while (i < activeCarbsList.size && ac > 0) { @@ -115,7 +119,4 @@ class AutosensDataObject(injector: HasAndroidInjector) : AutosensData { i++ } } - init { - injector.androidInjector().inject(this) - } } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/data/ProcessedDeviceStatusDataImpl.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/data/ProcessedDeviceStatusDataImpl.kt index 8131e49195..9f71a1bdb2 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/data/ProcessedDeviceStatusDataImpl.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/data/ProcessedDeviceStatusDataImpl.kt @@ -1,8 +1,10 @@ package info.nightscout.plugins.sync.nsclient.data import android.text.Spanned +import dagger.Lazy import dagger.android.HasAndroidInjector -import info.nightscout.core.aps.APSResultObject +import info.nightscout.interfaces.aps.APSResult +import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.nsclient.NSSettingsStatus import info.nightscout.interfaces.nsclient.ProcessedDeviceStatusData import info.nightscout.interfaces.utils.HtmlHelper @@ -21,7 +23,8 @@ import javax.inject.Singleton class ProcessedDeviceStatusDataImpl @Inject constructor( private val rh: ResourceHelper, private val dateUtil: DateUtil, - private val sp: SP + private val sp: SP, + private val loop: Lazy ) : ProcessedDeviceStatusData { override var pumpData: ProcessedDeviceStatusData.PumpData? = null @@ -112,11 +115,10 @@ class ProcessedDeviceStatusDataImpl @Inject constructor( override val openApsTimestamp: Long get() = if (openAPSData.clockSuggested != 0L) openAPSData.clockSuggested else -1 - override fun getAPSResult(injector: HasAndroidInjector): APSResultObject { - val result = APSResultObject(injector) - result.json = openAPSData.suggested - result.date = openAPSData.clockSuggested - return result + override fun getAPSResult(injector: HasAndroidInjector): APSResult = + loop.get().provideEmptyAPSResultObject().also { + it.json = openAPSData.suggested + it.date = openAPSData.clockSuggested } override val uploaderStatus: String get() { diff --git a/ui/src/main/java/info/nightscout/ui/activities/ErrorHelperActivity.kt b/ui/src/main/java/info/nightscout/ui/activities/ErrorHelperActivity.kt index 055dfa9a49..f3339c054d 100644 --- a/ui/src/main/java/info/nightscout/ui/activities/ErrorHelperActivity.kt +++ b/ui/src/main/java/info/nightscout/ui/activities/ErrorHelperActivity.kt @@ -1,7 +1,7 @@ package info.nightscout.ui.activities import android.os.Bundle -import info.nightscout.core.services.AlarmSoundService +import info.nightscout.ui.services.AlarmSoundService import info.nightscout.core.ui.activities.DialogAppCompatActivity import info.nightscout.database.impl.AppRepository import info.nightscout.database.impl.transactions.InsertTherapyEventAnnouncementTransaction diff --git a/ui/src/main/java/info/nightscout/ui/di/UiModule.kt b/ui/src/main/java/info/nightscout/ui/di/UiModule.kt index 7cc9ab99d0..47158c0980 100644 --- a/ui/src/main/java/info/nightscout/ui/di/UiModule.kt +++ b/ui/src/main/java/info/nightscout/ui/di/UiModule.kt @@ -32,6 +32,7 @@ import info.nightscout.ui.dialogs.TempTargetDialog import info.nightscout.ui.dialogs.TreatmentDialog import info.nightscout.ui.dialogs.WizardDialog import info.nightscout.ui.dialogs.WizardInfoDialog +import info.nightscout.ui.services.AlarmSoundService import info.nightscout.ui.widget.Widget import info.nightscout.ui.widget.WidgetConfigureActivity @@ -39,6 +40,8 @@ import info.nightscout.ui.widget.WidgetConfigureActivity @Suppress("unused") abstract class UiModule { + @ContributesAndroidInjector abstract fun contributesAlarmSoundService(): AlarmSoundService + @ContributesAndroidInjector abstract fun contributesWidget(): Widget @ContributesAndroidInjector abstract fun contributesWidgetConfigureActivity(): WidgetConfigureActivity diff --git a/core/main/src/main/java/info/nightscout/core/services/AlarmSoundService.kt b/ui/src/main/java/info/nightscout/ui/services/AlarmSoundService.kt similarity index 99% rename from core/main/src/main/java/info/nightscout/core/services/AlarmSoundService.kt rename to ui/src/main/java/info/nightscout/ui/services/AlarmSoundService.kt index 8932c239d1..86e1aabe8e 100644 --- a/core/main/src/main/java/info/nightscout/core/services/AlarmSoundService.kt +++ b/ui/src/main/java/info/nightscout/ui/services/AlarmSoundService.kt @@ -1,4 +1,4 @@ -package info.nightscout.core.services +package info.nightscout.ui.services import android.content.Context import android.content.Intent diff --git a/core/main/src/main/java/info/nightscout/core/services/AlarmSoundServiceHelper.kt b/ui/src/main/java/info/nightscout/ui/services/AlarmSoundServiceHelper.kt similarity index 98% rename from core/main/src/main/java/info/nightscout/core/services/AlarmSoundServiceHelper.kt rename to ui/src/main/java/info/nightscout/ui/services/AlarmSoundServiceHelper.kt index 042f462afb..42aca554a5 100644 --- a/core/main/src/main/java/info/nightscout/core/services/AlarmSoundServiceHelper.kt +++ b/ui/src/main/java/info/nightscout/ui/services/AlarmSoundServiceHelper.kt @@ -1,4 +1,4 @@ -package info.nightscout.core.services +package info.nightscout.ui.services import android.content.ComponentName import android.content.Context diff --git a/wear/src/test/java/info/nightscout/androidaps/testing/mocks/BundleMock.java b/wear/src/test/java/info/nightscout/androidaps/testing/mocks/BundleMock.java index 47586d3597..0f04d47276 100644 --- a/wear/src/test/java/info/nightscout/androidaps/testing/mocks/BundleMock.java +++ b/wear/src/test/java/info/nightscout/androidaps/testing/mocks/BundleMock.java @@ -28,7 +28,7 @@ import java.util.HashMap; @SuppressWarnings({"unused", "rawtypes", "SuspiciousMethodCalls", "unchecked"}) public final class BundleMock { - +/* public static Bundle mock() { return mock(new HashMap<>()); } @@ -180,4 +180,5 @@ public final class BundleMock { return bundle; } + */ } \ No newline at end of file diff --git a/workflow/src/main/java/info/nightscout/workflow/PrepareIobAutosensGraphDataWorker.kt b/workflow/src/main/java/info/nightscout/workflow/PrepareIobAutosensGraphDataWorker.kt index 40bb033065..27898f8724 100644 --- a/workflow/src/main/java/info/nightscout/workflow/PrepareIobAutosensGraphDataWorker.kt +++ b/workflow/src/main/java/info/nightscout/workflow/PrepareIobAutosensGraphDataWorker.kt @@ -17,12 +17,12 @@ import info.nightscout.core.graph.data.Scale import info.nightscout.core.graph.data.ScaledDataPoint import info.nightscout.core.iob.combine import info.nightscout.core.iob.copy -import info.nightscout.core.iob.iobCobCalculator.data.AutosensDataObject import info.nightscout.core.utils.receivers.DataWorkerStorage import info.nightscout.core.utils.worker.LoggingWorker import info.nightscout.core.workflow.CalculationWorkflow import info.nightscout.database.ValueWrapper import info.nightscout.database.impl.AppRepository +import info.nightscout.interfaces.aps.AutosensData import info.nightscout.interfaces.aps.AutosensResult import info.nightscout.interfaces.aps.SMBDefaults import info.nightscout.interfaces.iob.IobCobCalculator @@ -94,7 +94,7 @@ class PrepareIobAutosensGraphDataWorker( } class AutosensDataPoint( - private val ad: AutosensDataObject, + private val ad: AutosensData, private val scale: Scale, private val chartTime: Long, private val rh: ResourceHelper @@ -163,7 +163,7 @@ class PrepareIobAutosensGraphDataWorker( val iob = data.iobCobCalculator.calculateFromTreatmentsAndTemps(time, profile) val baseBasalIob = data.iobCobCalculator.calculateAbsoluteIobFromBaseBasals(time) val absIob = IobTotal.combine(iob, baseBasalIob) - val autosensData = adsData.getAutosensDataAtTime(time) as AutosensDataObject? + val autosensData = adsData.getAutosensDataAtTime(time) if (abs(lastIob - iob.iob) > 0.02) { if (abs(lastIob - iob.iob) > 0.2) iobArray.add(ScaledDataPoint(time, lastIob, data.overviewData.iobScale)) iobArray.add(ScaledDataPoint(time, iob.iob, data.overviewData.iobScale)) diff --git a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt index 795764b0bc..fa06f39be7 100644 --- a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt +++ b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt @@ -7,7 +7,6 @@ import androidx.work.workDataOf import dagger.android.HasAndroidInjector import info.nightscout.core.events.EventIobCalculationProgress import info.nightscout.core.extensions.target -import info.nightscout.core.iob.iobCobCalculator.data.AutosensDataObject import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.core.utils.receivers.DataWorkerStorage import info.nightscout.core.utils.worker.LoggingWorker @@ -115,7 +114,7 @@ class IobCobOref1Worker( } aapsLogger.debug(LTag.AUTOSENS, "Processing calculation thread: ${data.reason} ($i/${bucketedData.size})") val sens = profile.getIsfMgdl(bgTime) - val autosensData = AutosensDataObject(data.injector) + val autosensData = data.iobCobCalculator.provideEmptyAutosensDataObject() autosensData.time = bgTime if (previous != null) autosensData.activeCarbsList = previous.cloneCarbsList() else autosensData.activeCarbsList = ArrayList() diff --git a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt index 9abf378e38..d371a78f74 100644 --- a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt +++ b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt @@ -6,7 +6,6 @@ import androidx.work.WorkerParameters import androidx.work.workDataOf import dagger.android.HasAndroidInjector import info.nightscout.core.events.EventIobCalculationProgress -import info.nightscout.core.iob.iobCobCalculator.data.AutosensDataObject import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.core.utils.receivers.DataWorkerStorage import info.nightscout.core.utils.worker.LoggingWorker @@ -56,7 +55,7 @@ class IobCobOrefWorker @Inject internal constructor( class IobCobOrefWorkerData( val injector: HasAndroidInjector, - val iobCobCalculatorPlugin: IobCobCalculator, // cannot be injected : HistoryBrowser uses different instance + val iobCobCalculator: IobCobCalculator, // cannot be injected : HistoryBrowser uses different instance val reason: String, val end: Long, val limitDataToOldestAvailable: Boolean, @@ -75,9 +74,9 @@ class IobCobOrefWorker @Inject internal constructor( return Result.success(workDataOf("Error" to "app still initializing")) } //log.debug("Locking calculateSensitivityData"); - val oldestTimeWithData = data.iobCobCalculatorPlugin.calculateDetectionStart(data.end, data.limitDataToOldestAvailable) + val oldestTimeWithData = data.iobCobCalculator.calculateDetectionStart(data.end, data.limitDataToOldestAvailable) // work on local copy and set back when finished - val ads = data.iobCobCalculatorPlugin.ads.clone() + val ads = data.iobCobCalculator.ads.clone() val bucketedData = ads.bucketedData val autosensDataTable = ads.autosensDataTable if (bucketedData == null || bucketedData.size < 3) { @@ -110,7 +109,7 @@ class IobCobOrefWorker @Inject internal constructor( } aapsLogger.debug(LTag.AUTOSENS, "Processing calculation thread: ${data.reason} ($i/${bucketedData.size})") val sens = profile.getIsfMgdl(bgTime) - val autosensData = AutosensDataObject(data.injector) + val autosensData = data.iobCobCalculator.provideEmptyAutosensDataObject() autosensData.time = bgTime if (previous != null) autosensData.activeCarbsList = previous.cloneCarbsList() else autosensData.activeCarbsList = ArrayList() @@ -125,7 +124,7 @@ class IobCobOrefWorker @Inject internal constructor( autosensData.bg = bg delta = bg - bucketedData[i + 1].value avgDelta = (bg - bucketedData[i + 3].value) / 3 - val iob = data.iobCobCalculatorPlugin.calculateFromTreatmentsAndTemps(bgTime, profile) + val iob = data.iobCobCalculator.calculateFromTreatmentsAndTemps(bgTime, profile) val bgi = -iob.activity * sens * 5 val deviation = delta - bgi val avgDeviation = ((avgDelta - bgi) * 1000).roundToLong() / 1000.0 @@ -260,7 +259,7 @@ class IobCobOrefWorker @Inject internal constructor( autosensData.autosensResult = sensitivity aapsLogger.debug(LTag.AUTOSENS, autosensData.toString()) } - data.iobCobCalculatorPlugin.ads = ads + data.iobCobCalculator.ads = ads Thread { SystemClock.sleep(1000) rxBus.send(EventAutosensCalculationFinished(data.cause)) From 2024956aefa80005897b6c27104e2d75c839708c Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 13:13:21 +0100 Subject: [PATCH 19/48] :plugins:insulin module --- app/build.gradle | 1 + .../activities/MyPreferenceFragment.kt | 2 +- .../nightscout/androidaps/di/AppComponent.kt | 2 + .../androidaps/di/PluginsListModule.kt | 10 ++--- .../nightscout/core/graph}/ActivityGraph.kt | 2 +- crowdin.yml | 2 + plugins/insulin/.gitignore | 1 + plugins/insulin/build.gradle | 28 ++++++++++++++ plugins/insulin/consumer-rules.pro | 0 plugins/insulin/proguard-rules.pro | 21 +++++++++++ plugins/insulin/src/main/AndroidManifest.xml | 4 ++ .../nightscout}/insulin/InsulinFragment.kt | 4 +- .../insulin/InsulinLyumjevPlugin.kt | 9 +++-- .../insulin/InsulinOrefBasePlugin.kt | 11 +++--- .../insulin/InsulinOrefFreePeakPlugin.kt | 15 ++++---- .../insulin/InsulinOrefRapidActingPlugin.kt | 9 +++-- .../InsulinOrefUltraRapidActingPlugin.kt | 9 +++-- .../nightscout/insulin}/di/InsulinModule.kt | 4 +- .../src/main/res/drawable/ic_insulin.xml | 0 .../src/main/res/layout/insulin_fragment.xml | 4 +- .../insulin/src/main/res/values/strings.xml | 22 +++++++++++ .../main/res/xml/pref_insulinoreffreepeak.xml | 0 .../info/nightscout/androidaps/TestBase.kt | 37 +++++++++++++++++++ .../insulin/InsulinLyumjevPluginTest.kt | 17 +++++---- .../insulin/InsulinOrefBasePluginTest.kt | 26 +++++++------ .../insulin/InsulinOrefFreePeakPluginTest.kt | 21 ++++++----- .../InsulinOrefRapidActingPluginTest.kt | 17 +++++---- .../InsulinOrefUltraRapidActingPluginTest.kt | 17 +++++---- .../nightscout/plugins/di/PluginsModule.kt | 1 - .../IobCobCalculatorPlugin.kt | 2 +- .../src/main/res/layout/profile_fragment.xml | 2 +- plugins/main/src/main/res/values/strings.xml | 19 ---------- settings.gradle | 1 + 33 files changed, 214 insertions(+), 106 deletions(-) rename {plugins/main/src/main/java/info/nightscout/plugins/insulin => core/graph/src/main/java/info/nightscout/core/graph}/ActivityGraph.kt (98%) create mode 100644 plugins/insulin/.gitignore create mode 100644 plugins/insulin/build.gradle create mode 100644 plugins/insulin/consumer-rules.pro create mode 100644 plugins/insulin/proguard-rules.pro create mode 100644 plugins/insulin/src/main/AndroidManifest.xml rename plugins/{main/src/main/java/info/nightscout/plugins => insulin/src/main/java/info/nightscout}/insulin/InsulinFragment.kt (93%) rename plugins/{main/src/main/java/info/nightscout/plugins => insulin/src/main/java/info/nightscout}/insulin/InsulinLyumjevPlugin.kt (87%) rename plugins/{main/src/main/java/info/nightscout/plugins => insulin/src/main/java/info/nightscout}/insulin/InsulinOrefBasePlugin.kt (91%) rename plugins/{main/src/main/java/info/nightscout/plugins => insulin/src/main/java/info/nightscout}/insulin/InsulinOrefFreePeakPlugin.kt (79%) rename plugins/{main/src/main/java/info/nightscout/plugins => insulin/src/main/java/info/nightscout}/insulin/InsulinOrefRapidActingPlugin.kt (88%) rename plugins/{main/src/main/java/info/nightscout/plugins => insulin/src/main/java/info/nightscout}/insulin/InsulinOrefUltraRapidActingPlugin.kt (87%) rename plugins/{main/src/main/java/info/nightscout/plugins => insulin/src/main/java/info/nightscout/insulin}/di/InsulinModule.kt (71%) rename plugins/{main => insulin}/src/main/res/drawable/ic_insulin.xml (100%) rename plugins/{main => insulin}/src/main/res/layout/insulin_fragment.xml (92%) create mode 100644 plugins/insulin/src/main/res/values/strings.xml rename plugins/{main => insulin}/src/main/res/xml/pref_insulinoreffreepeak.xml (100%) create mode 100644 plugins/insulin/src/test/java/info/nightscout/androidaps/TestBase.kt rename plugins/{main/src/test/java/info/nightscout/plugins => insulin/src/test/java/info/nightscout}/insulin/InsulinLyumjevPluginTest.kt (78%) rename plugins/{main/src/test/java/info/nightscout/plugins => insulin/src/test/java/info/nightscout}/insulin/InsulinOrefBasePluginTest.kt (77%) rename plugins/{main/src/test/java/info/nightscout/plugins => insulin/src/test/java/info/nightscout}/insulin/InsulinOrefFreePeakPluginTest.kt (69%) rename plugins/{main/src/test/java/info/nightscout/plugins => insulin/src/test/java/info/nightscout}/insulin/InsulinOrefRapidActingPluginTest.kt (77%) rename plugins/{main/src/test/java/info/nightscout/plugins => insulin/src/test/java/info/nightscout}/insulin/InsulinOrefUltraRapidActingPluginTest.kt (78%) diff --git a/app/build.gradle b/app/build.gradle index 034941a068..28cc2ab5b7 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -199,6 +199,7 @@ dependencies { implementation project(':plugins:automation') implementation project(':plugins:configuration') implementation project(':plugins:constraints') + implementation project(':plugins:insulin') implementation project(':plugins:main') implementation project(':plugins:openhumans') implementation project(':plugins:sensitivity') 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 c7354fa881..b7ceb50785 100644 --- a/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt +++ b/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt @@ -28,6 +28,7 @@ import info.nightscout.automation.AutomationPlugin import info.nightscout.configuration.maintenance.MaintenancePlugin import info.nightscout.core.ui.dialogs.OKDialog import info.nightscout.implementation.plugin.PluginStore +import info.nightscout.insulin.InsulinOrefFreePeakPlugin import info.nightscout.interfaces.Config import info.nightscout.interfaces.nsclient.NSSettingsStatus import info.nightscout.interfaces.plugin.PluginBase @@ -47,7 +48,6 @@ import info.nightscout.plugins.general.autotune.AutotunePlugin import info.nightscout.plugins.general.smsCommunicator.SmsCommunicatorPlugin import info.nightscout.plugins.general.wear.WearPlugin import info.nightscout.plugins.general.xdripStatusline.StatusLinePlugin -import info.nightscout.plugins.insulin.InsulinOrefFreePeakPlugin import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin import info.nightscout.plugins.source.AidexPlugin import info.nightscout.plugins.source.DexcomPlugin diff --git a/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt b/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt index 0acbea340a..ba16aa612b 100644 --- a/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt +++ b/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt @@ -20,6 +20,7 @@ import info.nightscout.core.di.CoreModule import info.nightscout.core.validators.di.ValidatorsModule import info.nightscout.database.impl.DatabaseModule import info.nightscout.implementation.di.ImplementationModule +import info.nightscout.insulin.di.InsulinModule import info.nightscout.plugins.aps.di.ApsModule import info.nightscout.plugins.constraints.di.PluginsConstraintsModule import info.nightscout.plugins.di.PluginsModule @@ -55,6 +56,7 @@ import javax.inject.Singleton CoreModule::class, DatabaseModule::class, ImplementationModule::class, + InsulinModule::class, OpenHumansModule::class, PluginsModule::class, RxModule::class, diff --git a/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt b/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt index f3dded5cc3..40922d18dc 100644 --- a/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt +++ b/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt @@ -8,7 +8,6 @@ import info.nightscout.androidaps.danaRKorean.DanaRKoreanPlugin import info.nightscout.androidaps.danaRv2.DanaRv2Plugin import info.nightscout.androidaps.danar.DanaRPlugin import info.nightscout.androidaps.plugin.general.openhumans.OpenHumansUploaderPlugin -import info.nightscout.plugins.general.persistentNotification.PersistentNotificationPlugin import info.nightscout.androidaps.plugins.pump.eopatch.EopatchPumpPlugin import info.nightscout.androidaps.plugins.pump.insight.LocalInsightPlugin import info.nightscout.androidaps.plugins.pump.medtronic.MedtronicPumpPlugin @@ -17,6 +16,10 @@ import info.nightscout.androidaps.plugins.pump.omnipod.eros.OmnipodErosPumpPlugi import info.nightscout.automation.AutomationPlugin import info.nightscout.configuration.configBuilder.ConfigBuilderPlugin import info.nightscout.configuration.maintenance.MaintenancePlugin +import info.nightscout.insulin.InsulinLyumjevPlugin +import info.nightscout.insulin.InsulinOrefFreePeakPlugin +import info.nightscout.insulin.InsulinOrefRapidActingPlugin +import info.nightscout.insulin.InsulinOrefUltraRapidActingPlugin import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.plugins.aps.loop.LoopPlugin import info.nightscout.plugins.aps.openAPSAMA.OpenAPSAMAPlugin @@ -31,14 +34,11 @@ import info.nightscout.plugins.general.autotune.AutotunePlugin import info.nightscout.plugins.general.dataBroadcaster.DataBroadcastPlugin import info.nightscout.plugins.general.food.FoodPlugin import info.nightscout.plugins.general.overview.OverviewPlugin +import info.nightscout.plugins.general.persistentNotification.PersistentNotificationPlugin import info.nightscout.plugins.general.smsCommunicator.SmsCommunicatorPlugin import info.nightscout.plugins.general.themes.ThemeSwitcherPlugin import info.nightscout.plugins.general.wear.WearPlugin import info.nightscout.plugins.general.xdripStatusline.StatusLinePlugin -import info.nightscout.plugins.insulin.InsulinLyumjevPlugin -import info.nightscout.plugins.insulin.InsulinOrefFreePeakPlugin -import info.nightscout.plugins.insulin.InsulinOrefRapidActingPlugin -import info.nightscout.plugins.insulin.InsulinOrefUltraRapidActingPlugin import info.nightscout.plugins.iob.iobCobCalculator.IobCobCalculatorPlugin import info.nightscout.plugins.profile.ProfilePlugin import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin diff --git a/plugins/main/src/main/java/info/nightscout/plugins/insulin/ActivityGraph.kt b/core/graph/src/main/java/info/nightscout/core/graph/ActivityGraph.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/insulin/ActivityGraph.kt rename to core/graph/src/main/java/info/nightscout/core/graph/ActivityGraph.kt index beb9055f23..9f887ea40f 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/insulin/ActivityGraph.kt +++ b/core/graph/src/main/java/info/nightscout/core/graph/ActivityGraph.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.insulin +package info.nightscout.core.graph import android.content.Context import android.graphics.Color diff --git a/crowdin.yml b/crowdin.yml index 8a46e75627..bad417b724 100644 --- a/crowdin.yml +++ b/crowdin.yml @@ -21,6 +21,8 @@ files: translation: /plugins/openhumans/src/main/res/values-%android_code%/strings.xml - source: /plugins/sensitivity/src/main/res/values/strings.xml translation: /plugins/sensitivity/src/main/res/values-%android_code%/strings.xml + - source: /plugins/insulin/src/main/res/values/strings.xml + translation: /plugins/insulin/src/main/res/values-%android_code%/strings.xml - source: /plugins/configuration/src/main/res/values/strings.xml translation: /plugins/configuration/src/main/res/values-%android_code%/strings.xml - source: /plugins/sync/src/main/res/values/strings.xml diff --git a/plugins/insulin/.gitignore b/plugins/insulin/.gitignore new file mode 100644 index 0000000000..42afabfd2a --- /dev/null +++ b/plugins/insulin/.gitignore @@ -0,0 +1 @@ +/build \ No newline at end of file diff --git a/plugins/insulin/build.gradle b/plugins/insulin/build.gradle new file mode 100644 index 0000000000..4ebac085b2 --- /dev/null +++ b/plugins/insulin/build.gradle @@ -0,0 +1,28 @@ +plugins { + id 'com.android.library' + id 'kotlin-android' + id 'kotlin-kapt' + id 'kotlin-allopen' + id 'com.hiya.jacoco-android' +} + +apply from: "${project.rootDir}/core/main/android_dependencies.gradle" +apply from: "${project.rootDir}/core/main/android_module_dependencies.gradle" +apply from: "${project.rootDir}/core/main/allopen_dependencies.gradle" +apply from: "${project.rootDir}/core/main/test_dependencies.gradle" +apply from: "${project.rootDir}/core/main/jacoco_global.gradle" +android { + namespace 'info.nightscout.insulin' +} + + +dependencies { + implementation project(':app-wear-shared:shared') + implementation project(':core:graph') + implementation project(':core:graphview') + implementation project(':core:interfaces') + implementation project(':core:ui') + implementation project(':core:utils') + implementation project(':core:validators') + implementation project(':database:entities') +} \ No newline at end of file diff --git a/plugins/insulin/consumer-rules.pro b/plugins/insulin/consumer-rules.pro new file mode 100644 index 0000000000..e69de29bb2 diff --git a/plugins/insulin/proguard-rules.pro b/plugins/insulin/proguard-rules.pro new file mode 100644 index 0000000000..481bb43481 --- /dev/null +++ b/plugins/insulin/proguard-rules.pro @@ -0,0 +1,21 @@ +# Add project specific ProGuard rules here. +# You can control the set of applied configuration files using the +# proguardFiles setting in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} + +# Uncomment this to preserve the line number information for +# debugging stack traces. +#-keepattributes SourceFile,LineNumberTable + +# If you keep the line number information, uncomment this to +# hide the original source file name. +#-renamesourcefileattribute SourceFile \ No newline at end of file diff --git a/plugins/insulin/src/main/AndroidManifest.xml b/plugins/insulin/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..44008a4332 --- /dev/null +++ b/plugins/insulin/src/main/AndroidManifest.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinFragment.kt b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinFragment.kt similarity index 93% rename from plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinFragment.kt rename to plugins/insulin/src/main/java/info/nightscout/insulin/InsulinFragment.kt index a53150caa0..6c55e30cce 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinFragment.kt +++ b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinFragment.kt @@ -1,12 +1,12 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import android.os.Bundle import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import dagger.android.support.DaggerFragment +import info.nightscout.insulin.databinding.InsulinFragmentBinding import info.nightscout.interfaces.plugin.ActivePlugin -import info.nightscout.plugins.databinding.InsulinFragmentBinding import info.nightscout.shared.interfaces.ResourceHelper import javax.inject.Inject diff --git a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinLyumjevPlugin.kt b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinLyumjevPlugin.kt similarity index 87% rename from plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinLyumjevPlugin.kt rename to plugins/insulin/src/main/java/info/nightscout/insulin/InsulinLyumjevPlugin.kt index 6f05cea720..dbd270c221 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinLyumjevPlugin.kt +++ b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinLyumjevPlugin.kt @@ -1,11 +1,11 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.HasAndroidInjector import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper @@ -21,8 +21,9 @@ class InsulinLyumjevPlugin @Inject constructor( rxBus: RxBus, aapsLogger: AAPSLogger, config: Config, - hardLimits: HardLimits -) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) { + hardLimits: HardLimits, + uiInteraction: UiInteraction +) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) { override val id get(): Insulin.InsulinType = Insulin.InsulinType.OREF_LYUMJEV override val friendlyName get(): String = rh.gs(R.string.lyumjev) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefBasePlugin.kt b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefBasePlugin.kt similarity index 91% rename from plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefBasePlugin.kt rename to plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefBasePlugin.kt index 2623e81cc2..4e5d3582ef 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefBasePlugin.kt +++ b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefBasePlugin.kt @@ -1,7 +1,6 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.HasAndroidInjector -import info.nightscout.core.events.EventNewNotification import info.nightscout.database.entities.Bolus import info.nightscout.database.entities.embedments.InsulinConfiguration import info.nightscout.interfaces.Config @@ -12,8 +11,8 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper @@ -34,7 +33,8 @@ abstract class InsulinOrefBasePlugin( val rxBus: RxBus, aapsLogger: AAPSLogger, config: Config, - val hardLimits: HardLimits + val hardLimits: HardLimits, + val uiInteraction: UiInteraction ) : PluginBase( PluginDescription() .mainType(PluginType.INSULIN) @@ -61,8 +61,7 @@ abstract class InsulinOrefBasePlugin( open fun sendShortDiaNotification(dia: Double) { if (System.currentTimeMillis() - lastWarned > 60 * 1000) { lastWarned = System.currentTimeMillis() - val notification = Notification(Notification.SHORT_DIA, String.format(notificationPattern, dia, hardLimits.minDia()), Notification.URGENT) - rxBus.send(EventNewNotification(notification)) + uiInteraction.addNotification(Notification.SHORT_DIA, String.format(notificationPattern, dia, hardLimits.minDia()), Notification.URGENT) } } diff --git a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefFreePeakPlugin.kt b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefFreePeakPlugin.kt similarity index 79% rename from plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefFreePeakPlugin.kt rename to plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefFreePeakPlugin.kt index 85a9037799..30ed94d058 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefFreePeakPlugin.kt +++ b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefFreePeakPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.HasAndroidInjector import info.nightscout.core.extensions.putInt @@ -6,8 +6,8 @@ import info.nightscout.core.extensions.storeInt import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper @@ -28,16 +28,17 @@ class InsulinOrefFreePeakPlugin @Inject constructor( rxBus: RxBus, aapsLogger: AAPSLogger, config: Config, - hardLimits: HardLimits -) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) { + hardLimits: HardLimits, + uiInteraction: UiInteraction +) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) { override val id get(): Insulin.InsulinType = Insulin.InsulinType.OREF_FREE_PEAK override val friendlyName get(): String = rh.gs(R.string.free_peak_oref) - override fun configuration(): JSONObject = JSONObject().putInt(R.string.key_insulin_oref_peak, sp, rh) + override fun configuration(): JSONObject = JSONObject().putInt(info.nightscout.core.utils.R.string.key_insulin_oref_peak, sp, rh) override fun applyConfiguration(configuration: JSONObject) { - configuration.storeInt(R.string.key_insulin_oref_peak, sp, rh) + configuration.storeInt(info.nightscout.core.utils.R.string.key_insulin_oref_peak, sp, rh) } override fun commentStandardText(): String { @@ -45,7 +46,7 @@ class InsulinOrefFreePeakPlugin @Inject constructor( } override val peak: Int - get() = sp.getInt(R.string.key_insulin_oref_peak, DEFAULT_PEAK) + get() = sp.getInt(info.nightscout.core.utils.R.string.key_insulin_oref_peak, DEFAULT_PEAK) companion object { diff --git a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefRapidActingPlugin.kt b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefRapidActingPlugin.kt similarity index 88% rename from plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefRapidActingPlugin.kt rename to plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefRapidActingPlugin.kt index e86c6a3261..16d4764b96 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefRapidActingPlugin.kt +++ b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefRapidActingPlugin.kt @@ -1,11 +1,11 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.HasAndroidInjector import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper @@ -24,8 +24,9 @@ class InsulinOrefRapidActingPlugin @Inject constructor( rxBus: RxBus, aapsLogger: AAPSLogger, config: Config, - hardLimits: HardLimits -) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) { + hardLimits: HardLimits, + uiInteraction: UiInteraction +) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) { override val id get(): Insulin.InsulinType = Insulin.InsulinType.OREF_RAPID_ACTING override val friendlyName get(): String = rh.gs(R.string.rapid_acting_oref) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefUltraRapidActingPlugin.kt b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefUltraRapidActingPlugin.kt similarity index 87% rename from plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefUltraRapidActingPlugin.kt rename to plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefUltraRapidActingPlugin.kt index 180eb731cd..b4a0bb19a5 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/insulin/InsulinOrefUltraRapidActingPlugin.kt +++ b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefUltraRapidActingPlugin.kt @@ -1,11 +1,11 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.HasAndroidInjector import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper @@ -24,8 +24,9 @@ class InsulinOrefUltraRapidActingPlugin @Inject constructor( rxBus: RxBus, aapsLogger: AAPSLogger, config: Config, - hardLimits: HardLimits -) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) { + hardLimits: HardLimits, + uiInteraction: UiInteraction +) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) { override val id get(): Insulin.InsulinType = Insulin.InsulinType.OREF_ULTRA_RAPID_ACTING override val friendlyName get(): String = rh.gs(R.string.ultra_rapid_oref) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/di/InsulinModule.kt b/plugins/insulin/src/main/java/info/nightscout/insulin/di/InsulinModule.kt similarity index 71% rename from plugins/main/src/main/java/info/nightscout/plugins/di/InsulinModule.kt rename to plugins/insulin/src/main/java/info/nightscout/insulin/di/InsulinModule.kt index 42cce3d1f1..0f0e3af34a 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/di/InsulinModule.kt +++ b/plugins/insulin/src/main/java/info/nightscout/insulin/di/InsulinModule.kt @@ -1,8 +1,8 @@ -package info.nightscout.plugins.di +package info.nightscout.insulin.di import dagger.Module import dagger.android.ContributesAndroidInjector -import info.nightscout.plugins.insulin.InsulinFragment +import info.nightscout.insulin.InsulinFragment @Module @Suppress("unused") diff --git a/plugins/main/src/main/res/drawable/ic_insulin.xml b/plugins/insulin/src/main/res/drawable/ic_insulin.xml similarity index 100% rename from plugins/main/src/main/res/drawable/ic_insulin.xml rename to plugins/insulin/src/main/res/drawable/ic_insulin.xml diff --git a/plugins/main/src/main/res/layout/insulin_fragment.xml b/plugins/insulin/src/main/res/layout/insulin_fragment.xml similarity index 92% rename from plugins/main/src/main/res/layout/insulin_fragment.xml rename to plugins/insulin/src/main/res/layout/insulin_fragment.xml index 7733829b41..4d07600c91 100644 --- a/plugins/main/src/main/res/layout/insulin_fragment.xml +++ b/plugins/insulin/src/main/res/layout/insulin_fragment.xml @@ -2,7 +2,7 @@ xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" - tools:context=".insulin.InsulinFragment"> + tools:context="info.nightscout.insulin.InsulinFragment"> - + + + insulin_oref_peak_settings + + Lyumjev + Insulin preset for Humalog and NovoRapid / NovoLog + Insulin preset for Fiasp + Insulin preset for Lyumjev + Allows you to define the peak of the insulin activity and should only be used by advanced users + INS + IOB Curve Peak Time + Peak Time [min] + Free-Peak Oref + Rapid-Acting Oref + Ultra-Rapid Oref + DIA of %1$f too short - using %2$f instead! + Novorapid, Novolog, Humalog + Fiasp + + + \ No newline at end of file diff --git a/plugins/main/src/main/res/xml/pref_insulinoreffreepeak.xml b/plugins/insulin/src/main/res/xml/pref_insulinoreffreepeak.xml similarity index 100% rename from plugins/main/src/main/res/xml/pref_insulinoreffreepeak.xml rename to plugins/insulin/src/main/res/xml/pref_insulinoreffreepeak.xml diff --git a/plugins/insulin/src/test/java/info/nightscout/androidaps/TestBase.kt b/plugins/insulin/src/test/java/info/nightscout/androidaps/TestBase.kt new file mode 100644 index 0000000000..4fd2aef548 --- /dev/null +++ b/plugins/insulin/src/test/java/info/nightscout/androidaps/TestBase.kt @@ -0,0 +1,37 @@ +package info.nightscout.androidaps + +import info.nightscout.rx.AapsSchedulers +import info.nightscout.rx.TestAapsSchedulers +import info.nightscout.rx.logging.AAPSLoggerTest +import org.junit.jupiter.api.BeforeEach +import org.junit.jupiter.api.extension.ExtendWith +import org.mockito.Mockito +import org.mockito.junit.jupiter.MockitoExtension +import org.mockito.junit.jupiter.MockitoSettings +import org.mockito.quality.Strictness +import java.util.Locale + +@ExtendWith(MockitoExtension::class) +@MockitoSettings(strictness = Strictness.LENIENT) +open class TestBase { + + val aapsLogger = AAPSLoggerTest() + val aapsSchedulers: AapsSchedulers = TestAapsSchedulers() + + @BeforeEach + fun setupLocale() { + Locale.setDefault(Locale.ENGLISH) + System.setProperty("disableFirebase", "true") + } + + // Workaround for Kotlin nullability. + // https://medium.com/@elye.project/befriending-kotlin-and-mockito-1c2e7b0ef791 + // https://stackoverflow.com/questions/30305217/is-it-possible-to-use-mockito-in-kotlin + fun anyObject(): T { + Mockito.any() + return uninitialized() + } + + @Suppress("Unchecked_Cast") + fun uninitialized(): T = null as T +} \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinLyumjevPluginTest.kt b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinLyumjevPluginTest.kt similarity index 78% rename from plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinLyumjevPluginTest.kt rename to plugins/insulin/src/test/java/info/nightscout/insulin/InsulinLyumjevPluginTest.kt index 0987238522..e03fce024a 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinLyumjevPluginTest.kt +++ b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinLyumjevPluginTest.kt @@ -1,16 +1,16 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper -import org.junit.Assert.assertEquals +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.junit.jupiter.api.extension.ExtendWith @@ -33,6 +33,7 @@ class InsulinLyumjevPluginTest { @Mock lateinit var aapsLogger: AAPSLogger @Mock lateinit var config: Config @Mock lateinit var hardLimits: HardLimits + @Mock lateinit var uiInteraction: UiInteraction private var injector: HasAndroidInjector = HasAndroidInjector { AndroidInjector { @@ -41,29 +42,29 @@ class InsulinLyumjevPluginTest { @BeforeEach fun setup() { - sut = InsulinLyumjevPlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) + sut = InsulinLyumjevPlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) } @Test fun `simple peak test`() { - assertEquals(45, sut.peak) + Assertions.assertEquals(45, sut.peak) } @Test fun getIdTest() { - assertEquals(Insulin.InsulinType.OREF_LYUMJEV, sut.id) + Assertions.assertEquals(Insulin.InsulinType.OREF_LYUMJEV, sut.id) } @Test fun commentStandardTextTest() { `when`(rh.gs(eq(R.string.lyumjev))).thenReturn("Lyumjev") - assertEquals("Lyumjev", sut.commentStandardText()) + Assertions.assertEquals("Lyumjev", sut.commentStandardText()) } @Test fun getFriendlyNameTest() { `when`(rh.gs(eq(R.string.lyumjev))).thenReturn("Lyumjev") - assertEquals("Lyumjev", sut.friendlyName) + Assertions.assertEquals("Lyumjev", sut.friendlyName) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefBasePluginTest.kt b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefBasePluginTest.kt similarity index 77% rename from plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefBasePluginTest.kt rename to plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefBasePluginTest.kt index 5ad4a08781..4a3550392a 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefBasePluginTest.kt +++ b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefBasePluginTest.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector @@ -7,12 +7,13 @@ import info.nightscout.interfaces.Config import info.nightscout.interfaces.Constants import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper import org.json.JSONObject -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.junit.jupiter.api.extension.ExtendWith @@ -38,7 +39,7 @@ class InsulinOrefBasePluginTest { aapsLogger: AAPSLogger, config: Config, hardLimits: HardLimits - ) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) { + ) : InsulinOrefBasePlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) { override fun sendShortDiaNotification(dia: Double) { shortDiaNotificationSend = true @@ -65,6 +66,7 @@ class InsulinOrefBasePluginTest { @Mock lateinit var aapsLogger: AAPSLogger @Mock lateinit var config: Config @Mock lateinit var hardLimits: HardLimits + @Mock lateinit var uiInteraction: UiInteraction private var injector: HasAndroidInjector = HasAndroidInjector { AndroidInjector { @@ -79,12 +81,12 @@ class InsulinOrefBasePluginTest { @Test fun testGetDia() { - Assert.assertEquals(5.0, sut.dia, 0.0) + Assertions.assertEquals(5.0, sut.dia, 0.0) testUserDefinedDia = 5.0 + 1 - Assert.assertEquals(5.0 + 1, sut.dia, 0.0) + Assertions.assertEquals(5.0 + 1, sut.dia, 0.0) testUserDefinedDia = 5.0 - 1 - Assert.assertEquals(5.0, sut.dia, 0.0) - Assert.assertTrue(shortDiaNotificationSend) + Assertions.assertEquals(5.0, sut.dia, 0.0) + Assertions.assertTrue(shortDiaNotificationSend) } @Test @@ -96,22 +98,22 @@ class InsulinOrefBasePluginTest { // check directly after bolus treatment.timestamp = time treatment.amount = 10.0 - Assert.assertEquals(10.0, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) + Assertions.assertEquals(10.0, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) // check after 1 hour treatment.timestamp = time - 1 * 60 * 60 * 1000 // 1 hour treatment.amount = 10.0 - Assert.assertEquals(3.92, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) + Assertions.assertEquals(3.92, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) // check after 2 hour treatment.timestamp = time - 2 * 60 * 60 * 1000 // 2 hours treatment.amount = 10.0 - Assert.assertEquals(0.77, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) + Assertions.assertEquals(0.77, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) // check after 3 hour treatment.timestamp = time - 3 * 60 * 60 * 1000 // 3 hours treatment.amount = 10.0 - Assert.assertEquals(0.10, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) + Assertions.assertEquals(0.10, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) // check after dia treatment.timestamp = time - 4 * 60 * 60 * 1000 // 4 hours treatment.amount = 10.0 - Assert.assertEquals(0.0, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) + Assertions.assertEquals(0.0, sut.iobCalcForTreatment(treatment, time, Constants.defaultDIA).iobContrib, 0.1) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefFreePeakPluginTest.kt b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefFreePeakPluginTest.kt similarity index 69% rename from plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefFreePeakPluginTest.kt rename to plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefFreePeakPluginTest.kt index 0974ba91b5..5e20dc2eb1 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefFreePeakPluginTest.kt +++ b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefFreePeakPluginTest.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector @@ -6,12 +6,12 @@ import info.nightscout.androidaps.TestBase import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert.assertEquals +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.ArgumentMatchers.anyInt @@ -33,6 +33,7 @@ class InsulinOrefFreePeakPluginTest : TestBase() { @Mock lateinit var profileFunction: ProfileFunction @Mock lateinit var config: Config @Mock lateinit var hardLimits: HardLimits + @Mock lateinit var uiInteraction: UiInteraction private var injector: HasAndroidInjector = HasAndroidInjector { AndroidInjector { @@ -41,30 +42,30 @@ class InsulinOrefFreePeakPluginTest : TestBase() { @BeforeEach fun setup() { - sut = InsulinOrefFreePeakPlugin(injector, sp, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) + sut = InsulinOrefFreePeakPlugin(injector, sp, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) } @Test fun `simple peak test`() { - `when`(sp.getInt(eq(R.string.key_insulin_oref_peak), anyInt())).thenReturn(90) - assertEquals(90, sut.peak) + `when`(sp.getInt(eq(info.nightscout.core.utils.R.string.key_insulin_oref_peak), anyInt())).thenReturn(90) + Assertions.assertEquals(90, sut.peak) } @Test fun getIdTest() { - assertEquals(Insulin.InsulinType.OREF_FREE_PEAK, sut.id) + Assertions.assertEquals(Insulin.InsulinType.OREF_FREE_PEAK, sut.id) } @Test fun commentStandardTextTest() { - `when`(sp.getInt(eq(R.string.key_insulin_oref_peak), anyInt())).thenReturn(90) + `when`(sp.getInt(eq(info.nightscout.core.utils.R.string.key_insulin_oref_peak), anyInt())).thenReturn(90) `when`(rh.gs(eq(R.string.insulin_peak_time))).thenReturn("Peak Time [min]") - assertEquals("Peak Time [min]: 90", sut.commentStandardText()) + Assertions.assertEquals("Peak Time [min]: 90", sut.commentStandardText()) } @Test fun getFriendlyNameTest() { `when`(rh.gs(eq(R.string.free_peak_oref))).thenReturn("Free-Peak Oref") - assertEquals("Free-Peak Oref", sut.friendlyName) + Assertions.assertEquals("Free-Peak Oref", sut.friendlyName) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefRapidActingPluginTest.kt b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefRapidActingPluginTest.kt similarity index 77% rename from plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefRapidActingPluginTest.kt rename to plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefRapidActingPluginTest.kt index cf1898abcf..d8d7d2a697 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefRapidActingPluginTest.kt +++ b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefRapidActingPluginTest.kt @@ -1,16 +1,16 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper -import org.junit.Assert.assertEquals +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.junit.jupiter.api.extension.ExtendWith @@ -33,6 +33,7 @@ class InsulinOrefRapidActingPluginTest { @Mock lateinit var aapsLogger: AAPSLogger @Mock lateinit var config: Config @Mock lateinit var hardLimits: HardLimits + @Mock lateinit var uiInteraction: UiInteraction private var injector: HasAndroidInjector = HasAndroidInjector { AndroidInjector { @@ -41,29 +42,29 @@ class InsulinOrefRapidActingPluginTest { @BeforeEach fun setup() { - sut = InsulinOrefRapidActingPlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) + sut = InsulinOrefRapidActingPlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) } @Test fun `simple peak test`() { - assertEquals(75, sut.peak) + Assertions.assertEquals(75, sut.peak) } @Test fun getIdTest() { - assertEquals(Insulin.InsulinType.OREF_RAPID_ACTING, sut.id) + Assertions.assertEquals(Insulin.InsulinType.OREF_RAPID_ACTING, sut.id) } @Test fun commentStandardTextTest() { `when`(rh.gs(eq(R.string.fast_acting_insulin_comment))).thenReturn("Novorapid, Novolog, Humalog") - assertEquals("Novorapid, Novolog, Humalog", sut.commentStandardText()) + Assertions.assertEquals("Novorapid, Novolog, Humalog", sut.commentStandardText()) } @Test fun getFriendlyNameTest() { `when`(rh.gs(eq(R.string.rapid_acting_oref))).thenReturn("Rapid-Acting Oref") - assertEquals("Rapid-Acting Oref", sut.friendlyName) + Assertions.assertEquals("Rapid-Acting Oref", sut.friendlyName) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefUltraRapidActingPluginTest.kt b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefUltraRapidActingPluginTest.kt similarity index 78% rename from plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefUltraRapidActingPluginTest.kt rename to plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefUltraRapidActingPluginTest.kt index 9ae7fe1964..ec8dc09c5e 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/insulin/InsulinOrefUltraRapidActingPluginTest.kt +++ b/plugins/insulin/src/test/java/info/nightscout/insulin/InsulinOrefUltraRapidActingPluginTest.kt @@ -1,16 +1,16 @@ -package info.nightscout.plugins.insulin +package info.nightscout.insulin import dagger.android.AndroidInjector import dagger.android.HasAndroidInjector import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction +import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger import info.nightscout.shared.interfaces.ResourceHelper -import org.junit.Assert.assertEquals +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.junit.jupiter.api.extension.ExtendWith @@ -33,6 +33,7 @@ class InsulinOrefUltraRapidActingPluginTest { @Mock lateinit var aapsLogger: AAPSLogger @Mock lateinit var config: Config @Mock lateinit var hardLimits: HardLimits + @Mock lateinit var uiInteraction: UiInteraction private var injector: HasAndroidInjector = HasAndroidInjector { AndroidInjector { @@ -41,29 +42,29 @@ class InsulinOrefUltraRapidActingPluginTest { @BeforeEach fun setup() { - sut = InsulinOrefUltraRapidActingPlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits) + sut = InsulinOrefUltraRapidActingPlugin(injector, rh, profileFunction, rxBus, aapsLogger, config, hardLimits, uiInteraction) } @Test fun `simple peak test`() { - assertEquals(55, sut.peak) + Assertions.assertEquals(55, sut.peak) } @Test fun getIdTest() { - assertEquals(Insulin.InsulinType.OREF_ULTRA_RAPID_ACTING, sut.id) + Assertions.assertEquals(Insulin.InsulinType.OREF_ULTRA_RAPID_ACTING, sut.id) } @Test fun commentStandardTextTest() { `when`(rh.gs(eq(R.string.ultra_fast_acting_insulin_comment))).thenReturn("Fiasp") - assertEquals("Fiasp", sut.commentStandardText()) + Assertions.assertEquals("Fiasp", sut.commentStandardText()) } @Test fun getFriendlyNameTest() { `when`(rh.gs(eq(R.string.ultra_rapid_oref))).thenReturn("Ultra-Rapid Oref") - assertEquals("Ultra-Rapid Oref", sut.friendlyName) + Assertions.assertEquals("Ultra-Rapid Oref", sut.friendlyName) } } \ No newline at end of file diff --git a/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt b/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt index 5fda8f728e..412cd23353 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt @@ -14,7 +14,6 @@ import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataObject @Module( includes = [ PluginsModule.Bindings::class, - InsulinModule::class, FoodModule::class, SMSCommunicatorModule::class, ProfileModule::class, diff --git a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt index 345005de50..44d4f8b4ff 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt @@ -129,7 +129,7 @@ class IobCobCalculatorPlugin @Inject constructor( event.isChanged(rh.gs(info.nightscout.core.utils.R.string.key_absorption_cutoff)) || event.isChanged(rh.gs(info.nightscout.core.utils.R.string.key_openapsama_autosens_max)) || event.isChanged(rh.gs(info.nightscout.core.utils.R.string.key_openapsama_autosens_min)) || - event.isChanged(rh.gs(R.string.key_insulin_oref_peak)) + event.isChanged(rh.gs(info.nightscout.core.utils.R.string.key_insulin_oref_peak)) ) { resetDataAndRunCalculation("onEventPreferenceChange", event) } diff --git a/plugins/main/src/main/res/layout/profile_fragment.xml b/plugins/main/src/main/res/layout/profile_fragment.xml index 00f9d49681..b1936437f4 100644 --- a/plugins/main/src/main/res/layout/profile_fragment.xml +++ b/plugins/main/src/main/res/layout/profile_fragment.xml @@ -198,7 +198,7 @@ - TBR duration must be a multiple of %1$d minutes and greater than 0. QR Code for setup one time password - - insulin_oref_peak - insulin_oref_peak_settings - - Lyumjev - Insulin preset for Humalog and NovoRapid / NovoLog - Insulin preset for Fiasp - Insulin preset for Lyumjev - Allows you to define the peak of the insulin activity and should only be used by advanced users - INS - IOB Curve Peak Time - Peak Time [min] - Free-Peak Oref - Rapid-Acting Oref - Ultra-Rapid Oref - DIA of %1$f too short - using %2$f instead! - Novorapid, Novolog, Humalog - Fiasp - xdripstatus_detailediob xdripstatus_showbgi diff --git a/settings.gradle b/settings.gradle index a7ff95a7d4..f47c3e1f04 100644 --- a/settings.gradle +++ b/settings.gradle @@ -18,6 +18,7 @@ include ':implementation' include ':plugins:aps' include ':plugins:automation' include ':plugins:configuration' +include ':plugins:insulin' include ':plugins:main' include ':plugins:openhumans' include ':plugins:sensitivity' From 53e29aaf33a037660a9da1514b848ae25093d157 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 14:21:28 +0100 Subject: [PATCH 20/48] minor cleanup --- .../nightscout/plugins/general/overview/OverviewFragment.kt | 2 +- plugins/main/src/main/res/layout/overview_buttons_layout.xml | 3 +-- plugins/main/src/main/res/layout/overview_fragment.xml | 2 +- plugins/main/src/main/res/layout/overview_graphs_layout.xml | 1 + .../main/src/main/res/layout/overview_statuslights_layout.xml | 2 +- pump/combov2/comboctl/src/androidMain/AndroidManifest.xml | 3 ++- 6 files changed, 7 insertions(+), 6 deletions(-) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt index 3b5f145058..5b341e4c4e 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewFragment.kt @@ -908,7 +908,7 @@ class OverviewFragment : DaggerFragment(), View.OnClickListener, OnLongClickList val useBatteryLevel = (pump.model() == PumpType.OMNIPOD_EROS) || (pump.model() != PumpType.ACCU_CHEK_COMBO && pump.model() != PumpType.OMNIPOD_DASH) batteryLevel.visibility = useBatteryLevel.toVisibility() - statusLights.visibility = (sp.getBoolean(R.string.key_show_statuslights, true) || config.NSCLIENT).toVisibility() + statusLightsLayout.visibility = (sp.getBoolean(R.string.key_show_statuslights, true) || config.NSCLIENT).toVisibility() } statusLightHandler.updateStatusLights( binding.statusLightsLayout.cannulaAge, diff --git a/plugins/main/src/main/res/layout/overview_buttons_layout.xml b/plugins/main/src/main/res/layout/overview_buttons_layout.xml index 2006e2d11c..7ca8af1466 100644 --- a/plugins/main/src/main/res/layout/overview_buttons_layout.xml +++ b/plugins/main/src/main/res/layout/overview_buttons_layout.xml @@ -1,7 +1,7 @@ @@ -28,7 +28,6 @@ + tools:context=".general.overview.OverviewFragment"> diff --git a/plugins/main/src/main/res/layout/overview_statuslights_layout.xml b/plugins/main/src/main/res/layout/overview_statuslights_layout.xml index b33b5fd50e..31462213c0 100644 --- a/plugins/main/src/main/res/layout/overview_statuslights_layout.xml +++ b/plugins/main/src/main/res/layout/overview_statuslights_layout.xml @@ -2,7 +2,7 @@ - + + From 16bf64129d4911c993aca9bbf256816e29df81c7 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 15:34:11 +0100 Subject: [PATCH 21/48] :pump:virtual --- app/build.gradle | 3 +- .../activities/MyPreferenceFragment.kt | 2 +- .../nightscout/androidaps/di/AppComponent.kt | 4 +- .../androidaps/di/PluginsListModule.kt | 2 +- .../androidaps/pump/PumpEnactResultTest.kt | 2 +- crowdin.yml | 2 + .../nightscout/plugins/di/PluginsModule.kt | 1 - .../plugins/source/RandomBgPlugin.kt | 6 +-- plugins/main/src/main/res/values/arrays.xml | 32 ---------------- plugins/main/src/main/res/values/strings.xml | 10 ----- pump/virtual/.gitignore | 1 + pump/virtual/build.gradle | 27 ++++++++++++++ pump/virtual/consumer-rules.pro | 0 pump/virtual/proguard-rules.pro | 21 +++++++++++ pump/virtual/src/main/AndroidManifest.xml | 3 ++ .../pump/virtual/VirtualPumpFragment.kt | 7 ++-- .../pump/virtual/VirtualPumpPlugin.kt | 7 ++-- .../pump/virtual}/di/VirtualPumpModule.kt | 6 +-- .../events/EventVirtualPumpUpdateGui.kt | 2 +- .../extensions/PumpEnactResultExtension.kt | 2 +- .../main/res/layout/virtual_pump_fragment.xml | 2 +- pump/virtual/src/main/res/values/arrays.xml | 35 ++++++++++++++++++ pump/virtual/src/main/res/values/strings.xml | 13 +++++++ .../src/main/res/xml/pref_virtual_pump.xml | 0 .../info/nightscout/androidaps/TestBase.kt | 37 +++++++++++++++++++ .../pump/virtual/VirtualPumpPluginUTest.kt | 10 ++--- settings.gradle | 1 + 27 files changed, 168 insertions(+), 70 deletions(-) create mode 100644 pump/virtual/.gitignore create mode 100644 pump/virtual/build.gradle create mode 100644 pump/virtual/consumer-rules.pro create mode 100644 pump/virtual/proguard-rules.pro create mode 100644 pump/virtual/src/main/AndroidManifest.xml rename {plugins/main/src/main/java/info/nightscout/plugins => pump/virtual/src/main/java/info/nightscout}/pump/virtual/VirtualPumpFragment.kt (95%) rename {plugins/main/src/main/java/info/nightscout/plugins => pump/virtual/src/main/java/info/nightscout}/pump/virtual/VirtualPumpPlugin.kt (98%) rename {plugins/main/src/main/java/info/nightscout/plugins => pump/virtual/src/main/java/info/nightscout/pump/virtual}/di/VirtualPumpModule.kt (75%) rename {plugins/main/src/main/java/info/nightscout/plugins => pump/virtual/src/main/java/info/nightscout}/pump/virtual/events/EventVirtualPumpUpdateGui.kt (65%) rename {plugins/main/src/main/java/info/nightscout/plugins => pump/virtual/src/main/java/info/nightscout/pump/virtual}/extensions/PumpEnactResultExtension.kt (97%) rename {plugins/main => pump/virtual}/src/main/res/layout/virtual_pump_fragment.xml (99%) create mode 100644 pump/virtual/src/main/res/values/arrays.xml create mode 100644 pump/virtual/src/main/res/values/strings.xml rename {plugins/main => pump/virtual}/src/main/res/xml/pref_virtual_pump.xml (100%) create mode 100644 pump/virtual/src/test/java/info/nightscout/androidaps/TestBase.kt rename {plugins/main/src/test/java/info/nightscout/plugins => pump/virtual/src/test/java/info/nightscout}/pump/virtual/VirtualPumpPluginUTest.kt (87%) diff --git a/app/build.gradle b/app/build.gradle index 28cc2ab5b7..0c80acd2d7 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -218,10 +218,11 @@ dependencies { implementation project(':pump:medtronic') implementation project(':pump:pump-common') implementation project(':pump:pump-core') - implementation project(':pump:rileylink') implementation project(':pump:omnipod-common') implementation project(':pump:omnipod-eros') implementation project(':pump:omnipod-dash') + implementation project(':pump:rileylink') + implementation project(':pump:virtual') implementation project(':workflow') implementation fileTree(include: ['*.jar'], dir: 'libs') 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 b7ceb50785..b6b06fb5c5 100644 --- a/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt +++ b/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt @@ -48,7 +48,6 @@ import info.nightscout.plugins.general.autotune.AutotunePlugin import info.nightscout.plugins.general.smsCommunicator.SmsCommunicatorPlugin import info.nightscout.plugins.general.wear.WearPlugin import info.nightscout.plugins.general.xdripStatusline.StatusLinePlugin -import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin import info.nightscout.plugins.source.AidexPlugin import info.nightscout.plugins.source.DexcomPlugin import info.nightscout.plugins.source.EversensePlugin @@ -63,6 +62,7 @@ import info.nightscout.plugins.sync.tidepool.TidepoolPlugin import info.nightscout.pump.combo.ComboPlugin import info.nightscout.pump.combov2.ComboV2Plugin import info.nightscout.pump.diaconn.DiaconnG8Plugin +import info.nightscout.pump.virtual.VirtualPumpPlugin import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventPreferenceChange import info.nightscout.rx.events.EventRebuildTabs diff --git a/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt b/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt index ba16aa612b..7ba9ed8947 100644 --- a/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt +++ b/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt @@ -32,6 +32,7 @@ import info.nightscout.pump.dana.di.DanaHistoryModule import info.nightscout.pump.dana.di.DanaModule import info.nightscout.pump.danars.di.DanaRSModule import info.nightscout.pump.diaconn.di.DiaconnG8Module +import info.nightscout.pump.virtual.di.VirtualPumpModule import info.nightscout.rx.di.RxModule import info.nightscout.shared.di.SharedModule import info.nightscout.shared.impl.di.SharedImplModule @@ -83,7 +84,8 @@ import javax.inject.Singleton OmnipodDashModule::class, OmnipodErosModule::class, PumpCommonModule::class, - RileyLinkModule::class + RileyLinkModule::class, + VirtualPumpModule::class ] ) interface AppComponent : AndroidInjector { diff --git a/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt b/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt index 40922d18dc..3010832bd9 100644 --- a/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt +++ b/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt @@ -41,7 +41,6 @@ import info.nightscout.plugins.general.wear.WearPlugin import info.nightscout.plugins.general.xdripStatusline.StatusLinePlugin import info.nightscout.plugins.iob.iobCobCalculator.IobCobCalculatorPlugin import info.nightscout.plugins.profile.ProfilePlugin -import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin import info.nightscout.plugins.source.AidexPlugin import info.nightscout.plugins.source.DexcomPlugin import info.nightscout.plugins.source.GlimpPlugin @@ -59,6 +58,7 @@ import info.nightscout.plugins.sync.tidepool.TidepoolPlugin import info.nightscout.pump.combo.ComboPlugin import info.nightscout.pump.combov2.ComboV2Plugin import info.nightscout.pump.diaconn.DiaconnG8Plugin +import info.nightscout.pump.virtual.VirtualPumpPlugin import info.nightscout.sensitivity.SensitivityAAPSPlugin import info.nightscout.sensitivity.SensitivityOref1Plugin import info.nightscout.sensitivity.SensitivityWeightedAveragePlugin diff --git a/app/src/test/java/info/nightscout/androidaps/pump/PumpEnactResultTest.kt b/app/src/test/java/info/nightscout/androidaps/pump/PumpEnactResultTest.kt index 30c579d7b8..70a588210d 100644 --- a/app/src/test/java/info/nightscout/androidaps/pump/PumpEnactResultTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/pump/PumpEnactResultTest.kt @@ -6,7 +6,7 @@ import info.nightscout.androidaps.TestBaseWithProfile import info.nightscout.core.pump.toHtml import info.nightscout.interfaces.pump.PumpEnactResult import info.nightscout.plugins.aps.loop.extensions.json -import info.nightscout.plugins.extensions.toText +import info.nightscout.pump.virtual.extensions.toText import info.nightscout.plugins.sync.nsShared.extensions.log import org.json.JSONObject import org.junit.jupiter.api.Assertions diff --git a/crowdin.yml b/crowdin.yml index bad417b724..42dc0118d9 100644 --- a/crowdin.yml +++ b/crowdin.yml @@ -71,6 +71,8 @@ files: translation: /pump/omnipod-eros/src/main/res/values-%android_code%/strings.xml - source: /pump/rileylink/src/main/res/values/strings.xml translation: /pump/rileylink/src/main/res/values-%android_code%/strings.xml + - source: /pump/virtual/src/main/res/values/strings.xml + translation: /pump/virtual/src/main/res/values-%android_code%/strings.xml - source: /insight/src/main/res/values/strings.xml translation: /insight/src/main/res/values-%android_code%/strings.xml - source: /insight/src/main/res/values/alert_codes.xml diff --git a/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt b/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt index 412cd23353..35e8fe88ad 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/di/PluginsModule.kt @@ -18,7 +18,6 @@ import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataObject SMSCommunicatorModule::class, ProfileModule::class, SourceModule::class, - VirtualPumpModule::class, SkinsModule::class, SkinsUiModule::class, ActionsModule::class, diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/RandomBgPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/source/RandomBgPlugin.kt index 5fec0528bc..c11fbbfe47 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/RandomBgPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/source/RandomBgPlugin.kt @@ -14,9 +14,9 @@ import info.nightscout.interfaces.XDripBroadcast import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType +import info.nightscout.interfaces.pump.VirtualPump import info.nightscout.interfaces.source.BgSource import info.nightscout.plugins.R -import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper @@ -39,7 +39,7 @@ class RandomBgPlugin @Inject constructor( private val sp: SP, private val repository: AppRepository, private val xDripBroadcast: XDripBroadcast, - private val virtualPumpPlugin: VirtualPumpPlugin, + private val virtualPump: VirtualPump, private val config: Config ) : PluginBase( PluginDescription() @@ -94,7 +94,7 @@ class RandomBgPlugin @Inject constructor( } override fun specialEnableCondition(): Boolean { - return isRunningTest() || config.isUnfinishedMode() || virtualPumpPlugin.isEnabled() && config.isEngineeringMode() + return isRunningTest() || config.isUnfinishedMode() || virtualPump.isEnabled() && config.isEngineeringMode() } private fun handleNewData() { diff --git a/plugins/main/src/main/res/values/arrays.xml b/plugins/main/src/main/res/values/arrays.xml index 0e75db8ee1..3360615473 100644 --- a/plugins/main/src/main/res/values/arrays.xml +++ b/plugins/main/src/main/res/values/arrays.xml @@ -12,36 +12,4 @@ @string/value_system_theme - - Generic AAPS - MDI - Accu-Chek Combo - Accu-Chek Spirit - Accu-Chek Insight - Accu-Chek Solo - Animas Ping - Animas Vibe - Cellnovo - DanaR - DanaR Korean - DanaRS - DanaRv2 - DanaI - Diaconn G8 - Eoflow Eopatch2 - Medtronic 512/712 - Medtronic 515/715 - Medtronic 522/722 - Medtronic 523/723 (Revel) - Medtronic 554/754 (Veo) - Medtronic 640G - Omnipod Dash - Omnipod Eros - Tandem t:slim - Tandem t:flex - Tandem t:slim G4 - Tandem t:slim X2 - YpsoPump - - \ No newline at end of file diff --git a/plugins/main/src/main/res/values/strings.xml b/plugins/main/src/main/res/values/strings.xml index 5087bd5cec..0e61329d58 100644 --- a/plugins/main/src/main/res/values/strings.xml +++ b/plugins/main/src/main/res/values/strings.xml @@ -344,16 +344,6 @@ Graph scale Graph - - Virtual Pump Type - Pump Definition - Bolus: Step=%1$s\nExtended Bolus: [Step=%2$s, Duration=%3$smin-%4$sh]\nBasal: Step=%5$s\nTBR: %6$s (by %7$s), Duration=%8$smin-%9$sh\n%10$s - - VPUMP - Pump integration for pumps which don\'t have any driver yet (Open Loop) - VIRTUAL PUMP - Virtual pump settings - dexcom_lognssensorchange last_processed_glunovo_timestamp diff --git a/pump/virtual/.gitignore b/pump/virtual/.gitignore new file mode 100644 index 0000000000..796b96d1c4 --- /dev/null +++ b/pump/virtual/.gitignore @@ -0,0 +1 @@ +/build diff --git a/pump/virtual/build.gradle b/pump/virtual/build.gradle new file mode 100644 index 0000000000..3f2bc9b9ac --- /dev/null +++ b/pump/virtual/build.gradle @@ -0,0 +1,27 @@ +plugins { + id 'com.android.library' + id 'kotlin-android' + id 'kotlin-kapt' + id 'kotlin-allopen' + id 'com.hiya.jacoco-android' +} + +apply from: "${project.rootDir}/core/main/android_dependencies.gradle" +apply from: "${project.rootDir}/core/main/android_module_dependencies.gradle" +apply from: "${project.rootDir}/core/main/allopen_dependencies.gradle" +apply from: "${project.rootDir}/core/main/test_dependencies.gradle" +apply from: "${project.rootDir}/core/main/jacoco_global.gradle" + +android { + + namespace 'info.nightscout.pump.virtual' +} + +dependencies { + implementation project(':app-wear-shared:shared') + implementation project(':database:entities') + implementation project(':core:interfaces') + implementation project(':core:main') + implementation project(':core:ui') + implementation project(':core:utils') +} \ No newline at end of file diff --git a/pump/virtual/consumer-rules.pro b/pump/virtual/consumer-rules.pro new file mode 100644 index 0000000000..e69de29bb2 diff --git a/pump/virtual/proguard-rules.pro b/pump/virtual/proguard-rules.pro new file mode 100644 index 0000000000..f1b424510d --- /dev/null +++ b/pump/virtual/proguard-rules.pro @@ -0,0 +1,21 @@ +# Add project specific ProGuard rules here. +# You can control the set of applied configuration files using the +# proguardFiles setting in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} + +# Uncomment this to preserve the line number information for +# debugging stack traces. +#-keepattributes SourceFile,LineNumberTable + +# If you keep the line number information, uncomment this to +# hide the original source file name. +#-renamesourcefileattribute SourceFile diff --git a/pump/virtual/src/main/AndroidManifest.xml b/pump/virtual/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..0a0938ae37 --- /dev/null +++ b/pump/virtual/src/main/AndroidManifest.xml @@ -0,0 +1,3 @@ + + + diff --git a/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpFragment.kt b/pump/virtual/src/main/java/info/nightscout/pump/virtual/VirtualPumpFragment.kt similarity index 95% rename from plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpFragment.kt rename to pump/virtual/src/main/java/info/nightscout/pump/virtual/VirtualPumpFragment.kt index f528521824..15c1cf15b0 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpFragment.kt +++ b/pump/virtual/src/main/java/info/nightscout/pump/virtual/VirtualPumpFragment.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.pump.virtual +package info.nightscout.pump.virtual import android.os.Bundle import android.os.Handler @@ -11,9 +11,8 @@ import info.nightscout.core.extensions.toStringFull import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.plugins.R -import info.nightscout.plugins.databinding.VirtualPumpFragmentBinding -import info.nightscout.plugins.pump.virtual.events.EventVirtualPumpUpdateGui +import info.nightscout.pump.virtual.databinding.VirtualPumpFragmentBinding +import info.nightscout.pump.virtual.events.EventVirtualPumpUpdateGui import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventExtendedBolusChange diff --git a/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpPlugin.kt b/pump/virtual/src/main/java/info/nightscout/pump/virtual/VirtualPumpPlugin.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpPlugin.kt rename to pump/virtual/src/main/java/info/nightscout/pump/virtual/VirtualPumpPlugin.kt index 0bf57732be..9db3437861 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/VirtualPumpPlugin.kt +++ b/pump/virtual/src/main/java/info/nightscout/pump/virtual/VirtualPumpPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.pump.virtual +package info.nightscout.pump.virtual import android.os.SystemClock import androidx.preference.PreferenceFragmentCompat @@ -28,9 +28,8 @@ import info.nightscout.interfaces.pump.defs.PumpDescription import info.nightscout.interfaces.pump.defs.PumpType import info.nightscout.interfaces.queue.CommandQueue import info.nightscout.interfaces.utils.TimeChangeType -import info.nightscout.plugins.R -import info.nightscout.plugins.extensions.toText -import info.nightscout.plugins.pump.virtual.events.EventVirtualPumpUpdateGui +import info.nightscout.pump.virtual.events.EventVirtualPumpUpdateGui +import info.nightscout.pump.virtual.extensions.toText import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventOverviewBolusProgress diff --git a/plugins/main/src/main/java/info/nightscout/plugins/di/VirtualPumpModule.kt b/pump/virtual/src/main/java/info/nightscout/pump/virtual/di/VirtualPumpModule.kt similarity index 75% rename from plugins/main/src/main/java/info/nightscout/plugins/di/VirtualPumpModule.kt rename to pump/virtual/src/main/java/info/nightscout/pump/virtual/di/VirtualPumpModule.kt index f931269ecf..156c1bd0f5 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/di/VirtualPumpModule.kt +++ b/pump/virtual/src/main/java/info/nightscout/pump/virtual/di/VirtualPumpModule.kt @@ -1,11 +1,11 @@ -package info.nightscout.plugins.di +package info.nightscout.pump.virtual.di import dagger.Binds import dagger.Module import dagger.android.ContributesAndroidInjector import info.nightscout.interfaces.pump.VirtualPump -import info.nightscout.plugins.pump.virtual.VirtualPumpFragment -import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin +import info.nightscout.pump.virtual.VirtualPumpFragment +import info.nightscout.pump.virtual.VirtualPumpPlugin @Module( includes = [ diff --git a/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/events/EventVirtualPumpUpdateGui.kt b/pump/virtual/src/main/java/info/nightscout/pump/virtual/events/EventVirtualPumpUpdateGui.kt similarity index 65% rename from plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/events/EventVirtualPumpUpdateGui.kt rename to pump/virtual/src/main/java/info/nightscout/pump/virtual/events/EventVirtualPumpUpdateGui.kt index 55457db925..4bb49eb4fb 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/pump/virtual/events/EventVirtualPumpUpdateGui.kt +++ b/pump/virtual/src/main/java/info/nightscout/pump/virtual/events/EventVirtualPumpUpdateGui.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.pump.virtual.events +package info.nightscout.pump.virtual.events import info.nightscout.rx.events.EventUpdateGui diff --git a/plugins/main/src/main/java/info/nightscout/plugins/extensions/PumpEnactResultExtension.kt b/pump/virtual/src/main/java/info/nightscout/pump/virtual/extensions/PumpEnactResultExtension.kt similarity index 97% rename from plugins/main/src/main/java/info/nightscout/plugins/extensions/PumpEnactResultExtension.kt rename to pump/virtual/src/main/java/info/nightscout/pump/virtual/extensions/PumpEnactResultExtension.kt index 145156340c..664fdea6b2 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/extensions/PumpEnactResultExtension.kt +++ b/pump/virtual/src/main/java/info/nightscout/pump/virtual/extensions/PumpEnactResultExtension.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.extensions +package info.nightscout.pump.virtual.extensions import info.nightscout.interfaces.pump.PumpEnactResult import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/res/layout/virtual_pump_fragment.xml b/pump/virtual/src/main/res/layout/virtual_pump_fragment.xml similarity index 99% rename from plugins/main/src/main/res/layout/virtual_pump_fragment.xml rename to pump/virtual/src/main/res/layout/virtual_pump_fragment.xml index 33d875cf98..f961d691e3 100644 --- a/plugins/main/src/main/res/layout/virtual_pump_fragment.xml +++ b/pump/virtual/src/main/res/layout/virtual_pump_fragment.xml @@ -2,7 +2,7 @@ xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" - tools:context=".pump.virtual.VirtualPumpFragment"> + tools:context=".VirtualPumpFragment"> + + + Generic AAPS + MDI + Accu-Chek Combo + Accu-Chek Spirit + Accu-Chek Insight + Accu-Chek Solo + Animas Ping + Animas Vibe + Cellnovo + DanaR + DanaR Korean + DanaRS + DanaRv2 + DanaI + Diaconn G8 + Eoflow Eopatch2 + Medtronic 512/712 + Medtronic 515/715 + Medtronic 522/722 + Medtronic 523/723 (Revel) + Medtronic 554/754 (Veo) + Medtronic 640G + Omnipod Dash + Omnipod Eros + Tandem t:slim + Tandem t:flex + Tandem t:slim G4 + Tandem t:slim X2 + YpsoPump + + + \ No newline at end of file diff --git a/pump/virtual/src/main/res/values/strings.xml b/pump/virtual/src/main/res/values/strings.xml new file mode 100644 index 0000000000..3535a191cc --- /dev/null +++ b/pump/virtual/src/main/res/values/strings.xml @@ -0,0 +1,13 @@ + + + + Virtual Pump Type + Pump Definition + Bolus: Step=%1$s\nExtended Bolus: [Step=%2$s, Duration=%3$smin-%4$sh]\nBasal: Step=%5$s\nTBR: %6$s (by %7$s), Duration=%8$smin-%9$sh\n%10$s + + VPUMP + Pump integration for pumps which don\'t have any driver yet (Open Loop) + VIRTUAL PUMP + Virtual pump settings + + diff --git a/plugins/main/src/main/res/xml/pref_virtual_pump.xml b/pump/virtual/src/main/res/xml/pref_virtual_pump.xml similarity index 100% rename from plugins/main/src/main/res/xml/pref_virtual_pump.xml rename to pump/virtual/src/main/res/xml/pref_virtual_pump.xml diff --git a/pump/virtual/src/test/java/info/nightscout/androidaps/TestBase.kt b/pump/virtual/src/test/java/info/nightscout/androidaps/TestBase.kt new file mode 100644 index 0000000000..4fd2aef548 --- /dev/null +++ b/pump/virtual/src/test/java/info/nightscout/androidaps/TestBase.kt @@ -0,0 +1,37 @@ +package info.nightscout.androidaps + +import info.nightscout.rx.AapsSchedulers +import info.nightscout.rx.TestAapsSchedulers +import info.nightscout.rx.logging.AAPSLoggerTest +import org.junit.jupiter.api.BeforeEach +import org.junit.jupiter.api.extension.ExtendWith +import org.mockito.Mockito +import org.mockito.junit.jupiter.MockitoExtension +import org.mockito.junit.jupiter.MockitoSettings +import org.mockito.quality.Strictness +import java.util.Locale + +@ExtendWith(MockitoExtension::class) +@MockitoSettings(strictness = Strictness.LENIENT) +open class TestBase { + + val aapsLogger = AAPSLoggerTest() + val aapsSchedulers: AapsSchedulers = TestAapsSchedulers() + + @BeforeEach + fun setupLocale() { + Locale.setDefault(Locale.ENGLISH) + System.setProperty("disableFirebase", "true") + } + + // Workaround for Kotlin nullability. + // https://medium.com/@elye.project/befriending-kotlin-and-mockito-1c2e7b0ef791 + // https://stackoverflow.com/questions/30305217/is-it-possible-to-use-mockito-in-kotlin + fun anyObject(): T { + Mockito.any() + return uninitialized() + } + + @Suppress("Unchecked_Cast") + fun uninitialized(): T = null as T +} \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/pump/virtual/VirtualPumpPluginUTest.kt b/pump/virtual/src/test/java/info/nightscout/pump/virtual/VirtualPumpPluginUTest.kt similarity index 87% rename from plugins/main/src/test/java/info/nightscout/plugins/pump/virtual/VirtualPumpPluginUTest.kt rename to pump/virtual/src/test/java/info/nightscout/pump/virtual/VirtualPumpPluginUTest.kt index 7cc6f28978..872bb7c8eb 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/pump/virtual/VirtualPumpPluginUTest.kt +++ b/pump/virtual/src/test/java/info/nightscout/pump/virtual/VirtualPumpPluginUTest.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.pump.virtual +package info.nightscout.pump.virtual import dagger.android.AndroidInjector import info.nightscout.androidaps.TestBase @@ -13,7 +13,7 @@ import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -32,7 +32,7 @@ class VirtualPumpPluginUTest : TestBase() { @Mock lateinit var pumpSync: PumpSync @Mock lateinit var config: Config - lateinit var virtualPumpPlugin: VirtualPumpPlugin + private lateinit var virtualPumpPlugin: VirtualPumpPlugin @BeforeEach fun prepareMocks() { @@ -43,7 +43,7 @@ class VirtualPumpPluginUTest : TestBase() { fun refreshConfiguration() { `when`(sp.getString(info.nightscout.core.utils.R.string.key_virtualpump_type, "Generic AAPS")).thenReturn("Accu-Chek Combo") virtualPumpPlugin.refreshConfiguration() - Assert.assertEquals(PumpType.ACCU_CHEK_COMBO, virtualPumpPlugin.pumpType) + Assertions.assertEquals(PumpType.ACCU_CHEK_COMBO, virtualPumpPlugin.pumpType) } @Test @@ -52,6 +52,6 @@ class VirtualPumpPluginUTest : TestBase() { virtualPumpPlugin.refreshConfiguration() `when`(sp.getString(info.nightscout.core.utils.R.string.key_virtualpump_type, "Generic AAPS")).thenReturn("Accu-Chek Combo") virtualPumpPlugin.refreshConfiguration() - Assert.assertEquals(PumpType.ACCU_CHEK_COMBO, virtualPumpPlugin.pumpType) + Assertions.assertEquals(PumpType.ACCU_CHEK_COMBO, virtualPumpPlugin.pumpType) } } \ No newline at end of file diff --git a/settings.gradle b/settings.gradle index f47c3e1f04..dae8b065c8 100644 --- a/settings.gradle +++ b/settings.gradle @@ -40,5 +40,6 @@ include ':pump:omnipod-dash' include ':pump:pump-common' include ':pump:pump-core' include ':pump:rileylink' +include ':pump:virtual' include ':plugins:sync' include ':workflow' From bc9ec4c9c541bca07f8b6feb1962e6be3e57c75b Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 16:20:40 +0100 Subject: [PATCH 22/48] :plugins:source module --- app/build.gradle | 1 + .../activities/MyPreferenceFragment.kt | 16 +++---- .../nightscout/androidaps/di/AppComponent.kt | 2 + .../androidaps/di/PluginsListModule.kt | 22 ++++----- .../androidaps/receivers/DataReceiver.kt | 16 +++---- .../androidaps/workflow/WorkerClassesImpl.kt | 2 +- .../interfaces/ConstraintsCheckerTest.kt | 4 +- .../plugins/aps/loop/LoopPluginTest.kt | 2 +- .../plugins/safety/SafetyPluginTest.kt | 4 +- .../interfaces/source/DexcomBoyda.kt | 7 ++- .../nightscout/interfaces/source/XDrip.kt | 5 ++ crowdin.yml | 2 + .../queue/CommandQueueImplementationTest.kt | 2 +- .../BgQualityCheckPluginTest.kt | 5 +- plugins/main/src/main/AndroidManifest.xml | 4 -- .../nightscout/plugins/di/PluginsModule.kt | 1 - .../nightscout/plugins/di/ProfileModule.kt | 2 + .../general/overview/OverviewFragment.kt | 25 +++++----- plugins/main/src/main/res/values/strings.xml | 42 ----------------- plugins/source/.gitignore | 1 + plugins/source/build.gradle | 28 +++++++++++ plugins/source/consumer-rules.pro | 0 plugins/source/proguard-rules.pro | 21 +++++++++ plugins/source/src/main/AndroidManifest.xml | 12 +++++ .../info/nightscout}/source/AidexPlugin.kt | 3 +- .../nightscout}/source/BGSourceFragment.kt | 7 ++- .../info/nightscout}/source/DexcomPlugin.kt | 44 ++++++++--------- .../nightscout}/source/EversensePlugin.kt | 3 +- .../info/nightscout}/source/GlimpPlugin.kt | 3 +- .../info/nightscout}/source/GlunovoPlugin.kt | 3 +- .../nightscout}/source/IntelligoPlugin.kt | 3 +- .../info/nightscout}/source/MM640gPlugin.kt | 3 +- .../source/NSClientSourcePlugin.kt | 3 +- .../info/nightscout}/source/PoctechPlugin.kt | 3 +- .../info/nightscout}/source/RandomBgPlugin.kt | 3 +- .../info/nightscout}/source/TomatoPlugin.kt | 3 +- .../info/nightscout}/source/XdripPlugin.kt | 6 +-- .../RequestDexcomPermissionActivity.kt | 4 +- .../nightscout/source}/di/SourceModule.kt | 31 ++++++------ .../src/main/res/drawable/ic_dice.xml | 0 .../src/main/res/layout/source_fragment.xml | 2 +- .../src/main/res/layout/source_item.xml | 3 +- .../source/src/main/res/values/strings.xml | 47 +++++++++++++++++++ .../src/main/res/xml/pref_bgsource.xml | 0 .../src/main/res/xml/pref_dexcom.xml | 0 .../info/nightscout/androidaps/TestBase.kt | 37 +++++++++++++++ .../nightscout}/source/GlimpPluginTest.kt | 10 ++-- .../nightscout}/source/MM640GPluginTest.kt | 10 ++-- .../nightscout}/source/NSClientPluginTest.kt | 12 ++--- .../nightscout}/source/XdripPluginTest.kt | 10 ++-- settings.gradle | 1 + 51 files changed, 290 insertions(+), 190 deletions(-) create mode 100644 core/interfaces/src/main/java/info/nightscout/interfaces/source/XDrip.kt create mode 100644 plugins/source/.gitignore create mode 100644 plugins/source/build.gradle create mode 100644 plugins/source/consumer-rules.pro create mode 100644 plugins/source/proguard-rules.pro create mode 100644 plugins/source/src/main/AndroidManifest.xml rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/AidexPlugin.kt (98%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/BGSourceFragment.kt (98%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/DexcomPlugin.kt (92%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/EversensePlugin.kt (99%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/GlimpPlugin.kt (98%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/GlunovoPlugin.kt (99%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/IntelligoPlugin.kt (99%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/MM640gPlugin.kt (98%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/NSClientSourcePlugin.kt (99%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/PoctechPlugin.kt (98%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/RandomBgPlugin.kt (98%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/TomatoPlugin.kt (98%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/XdripPlugin.kt (97%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout}/source/activities/RequestDexcomPermissionActivity.kt (86%) rename plugins/{main/src/main/java/info/nightscout/plugins => source/src/main/java/info/nightscout/source}/di/SourceModule.kt (65%) rename plugins/{main => source}/src/main/res/drawable/ic_dice.xml (100%) rename plugins/{main => source}/src/main/res/layout/source_fragment.xml (91%) rename plugins/{main => source}/src/main/res/layout/source_item.xml (96%) create mode 100644 plugins/source/src/main/res/values/strings.xml rename plugins/{main => source}/src/main/res/xml/pref_bgsource.xml (100%) rename plugins/{main => source}/src/main/res/xml/pref_dexcom.xml (100%) create mode 100644 plugins/source/src/test/java/info/nightscout/androidaps/TestBase.kt rename plugins/{main/src/test/java/info/nightscout/plugins => source/src/test/java/info/nightscout}/source/GlimpPluginTest.kt (61%) rename plugins/{main/src/test/java/info/nightscout/plugins => source/src/test/java/info/nightscout}/source/MM640GPluginTest.kt (61%) rename plugins/{main/src/test/java/info/nightscout/plugins => source/src/test/java/info/nightscout}/source/NSClientPluginTest.kt (51%) rename plugins/{main/src/test/java/info/nightscout/plugins => source/src/test/java/info/nightscout}/source/XdripPluginTest.kt (57%) diff --git a/app/build.gradle b/app/build.gradle index 0c80acd2d7..8fe98aa880 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -203,6 +203,7 @@ dependencies { implementation project(':plugins:main') implementation project(':plugins:openhumans') implementation project(':plugins:sensitivity') + implementation project(':plugins:source') implementation project(':plugins:sync') implementation project(':implementation') implementation project(':database:entities') 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 b6b06fb5c5..a0d9cbf38f 100644 --- a/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt +++ b/app/src/main/java/info/nightscout/androidaps/activities/MyPreferenceFragment.kt @@ -48,14 +48,6 @@ import info.nightscout.plugins.general.autotune.AutotunePlugin import info.nightscout.plugins.general.smsCommunicator.SmsCommunicatorPlugin import info.nightscout.plugins.general.wear.WearPlugin import info.nightscout.plugins.general.xdripStatusline.StatusLinePlugin -import info.nightscout.plugins.source.AidexPlugin -import info.nightscout.plugins.source.DexcomPlugin -import info.nightscout.plugins.source.EversensePlugin -import info.nightscout.plugins.source.GlimpPlugin -import info.nightscout.plugins.source.GlunovoPlugin -import info.nightscout.plugins.source.IntelligoPlugin -import info.nightscout.plugins.source.PoctechPlugin -import info.nightscout.plugins.source.TomatoPlugin import info.nightscout.plugins.sync.nsclient.NSClientPlugin import info.nightscout.plugins.sync.nsclientV3.NSClientV3Plugin import info.nightscout.plugins.sync.tidepool.TidepoolPlugin @@ -72,6 +64,14 @@ import info.nightscout.sensitivity.SensitivityWeightedAveragePlugin import info.nightscout.shared.SafeParse import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP +import info.nightscout.source.AidexPlugin +import info.nightscout.source.DexcomPlugin +import info.nightscout.source.EversensePlugin +import info.nightscout.source.GlimpPlugin +import info.nightscout.source.GlunovoPlugin +import info.nightscout.source.IntelligoPlugin +import info.nightscout.source.PoctechPlugin +import info.nightscout.source.TomatoPlugin import javax.inject.Inject class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChangeListener { diff --git a/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt b/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt index 7ba9ed8947..229407090f 100644 --- a/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt +++ b/app/src/main/java/info/nightscout/androidaps/di/AppComponent.kt @@ -36,6 +36,7 @@ import info.nightscout.pump.virtual.di.VirtualPumpModule import info.nightscout.rx.di.RxModule import info.nightscout.shared.di.SharedModule import info.nightscout.shared.impl.di.SharedImplModule +import info.nightscout.source.di.SourceModule import info.nightscout.ui.di.UiModule import info.nightscout.workflow.di.WorkflowModule import javax.inject.Singleton @@ -66,6 +67,7 @@ import javax.inject.Singleton UiModule::class, ValidatorsModule::class, PluginsConstraintsModule::class, + SourceModule::class, SyncModule::class, WorkflowModule::class, diff --git a/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt b/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt index 3010832bd9..868b3b5c5a 100644 --- a/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt +++ b/app/src/main/java/info/nightscout/androidaps/di/PluginsListModule.kt @@ -41,17 +41,6 @@ import info.nightscout.plugins.general.wear.WearPlugin import info.nightscout.plugins.general.xdripStatusline.StatusLinePlugin import info.nightscout.plugins.iob.iobCobCalculator.IobCobCalculatorPlugin import info.nightscout.plugins.profile.ProfilePlugin -import info.nightscout.plugins.source.AidexPlugin -import info.nightscout.plugins.source.DexcomPlugin -import info.nightscout.plugins.source.GlimpPlugin -import info.nightscout.plugins.source.GlunovoPlugin -import info.nightscout.plugins.source.IntelligoPlugin -import info.nightscout.plugins.source.MM640gPlugin -import info.nightscout.plugins.source.NSClientSourcePlugin -import info.nightscout.plugins.source.PoctechPlugin -import info.nightscout.plugins.source.RandomBgPlugin -import info.nightscout.plugins.source.TomatoPlugin -import info.nightscout.plugins.source.XdripPlugin import info.nightscout.plugins.sync.nsclient.NSClientPlugin import info.nightscout.plugins.sync.nsclientV3.NSClientV3Plugin import info.nightscout.plugins.sync.tidepool.TidepoolPlugin @@ -62,6 +51,17 @@ import info.nightscout.pump.virtual.VirtualPumpPlugin import info.nightscout.sensitivity.SensitivityAAPSPlugin import info.nightscout.sensitivity.SensitivityOref1Plugin import info.nightscout.sensitivity.SensitivityWeightedAveragePlugin +import info.nightscout.source.AidexPlugin +import info.nightscout.source.DexcomPlugin +import info.nightscout.source.GlimpPlugin +import info.nightscout.source.GlunovoPlugin +import info.nightscout.source.IntelligoPlugin +import info.nightscout.source.MM640gPlugin +import info.nightscout.source.NSClientSourcePlugin +import info.nightscout.source.PoctechPlugin +import info.nightscout.source.RandomBgPlugin +import info.nightscout.source.TomatoPlugin +import info.nightscout.source.XdripPlugin import javax.inject.Qualifier @Suppress("unused") diff --git a/app/src/main/java/info/nightscout/androidaps/receivers/DataReceiver.kt b/app/src/main/java/info/nightscout/androidaps/receivers/DataReceiver.kt index e459c0223c..1c681f7330 100644 --- a/app/src/main/java/info/nightscout/androidaps/receivers/DataReceiver.kt +++ b/app/src/main/java/info/nightscout/androidaps/receivers/DataReceiver.kt @@ -12,17 +12,17 @@ import info.nightscout.core.utils.extensions.copyString import info.nightscout.core.utils.receivers.DataWorkerStorage import info.nightscout.interfaces.receivers.Intents import info.nightscout.plugins.general.smsCommunicator.SmsCommunicatorPlugin -import info.nightscout.plugins.source.AidexPlugin -import info.nightscout.plugins.source.DexcomPlugin -import info.nightscout.plugins.source.EversensePlugin -import info.nightscout.plugins.source.GlimpPlugin -import info.nightscout.plugins.source.MM640gPlugin -import info.nightscout.plugins.source.PoctechPlugin -import info.nightscout.plugins.source.TomatoPlugin -import info.nightscout.plugins.source.XdripPlugin import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.BundleLogger import info.nightscout.rx.logging.LTag +import info.nightscout.source.AidexPlugin +import info.nightscout.source.DexcomPlugin +import info.nightscout.source.EversensePlugin +import info.nightscout.source.GlimpPlugin +import info.nightscout.source.MM640gPlugin +import info.nightscout.source.PoctechPlugin +import info.nightscout.source.TomatoPlugin +import info.nightscout.source.XdripPlugin import javax.inject.Inject open class DataReceiver : DaggerBroadcastReceiver() { diff --git a/app/src/main/java/info/nightscout/androidaps/workflow/WorkerClassesImpl.kt b/app/src/main/java/info/nightscout/androidaps/workflow/WorkerClassesImpl.kt index b92c6549d0..80a696e6ce 100644 --- a/app/src/main/java/info/nightscout/androidaps/workflow/WorkerClassesImpl.kt +++ b/app/src/main/java/info/nightscout/androidaps/workflow/WorkerClassesImpl.kt @@ -3,7 +3,7 @@ package info.nightscout.androidaps.workflow import info.nightscout.interfaces.workflow.WorkerClasses import info.nightscout.plugins.general.food.FoodPlugin import info.nightscout.plugins.profile.ProfilePlugin -import info.nightscout.plugins.source.NSClientSourcePlugin +import info.nightscout.source.NSClientSourcePlugin import javax.inject.Inject class WorkerClassesImpl @Inject constructor(): WorkerClasses{ diff --git a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt index 848cf738a2..2a64a243cb 100644 --- a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt @@ -37,14 +37,14 @@ import info.nightscout.plugins.constraints.ConstraintsImpl import info.nightscout.plugins.constraints.objectives.ObjectivesPlugin import info.nightscout.plugins.constraints.objectives.objectives.Objective import info.nightscout.plugins.constraints.safety.SafetyPlugin -import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin -import info.nightscout.plugins.source.GlimpPlugin import info.nightscout.pump.combo.ComboPlugin import info.nightscout.pump.combo.ruffyscripter.RuffyScripter import info.nightscout.pump.dana.DanaPump import info.nightscout.pump.dana.R import info.nightscout.pump.dana.database.DanaHistoryDatabase +import info.nightscout.pump.virtual.VirtualPumpPlugin import info.nightscout.shared.sharedPreferences.SP +import info.nightscout.source.GlimpPlugin import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/aps/loop/LoopPluginTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/aps/loop/LoopPluginTest.kt index 9fb9023c32..457d495db7 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/aps/loop/LoopPluginTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/aps/loop/LoopPluginTest.kt @@ -21,7 +21,7 @@ import info.nightscout.interfaces.receivers.ReceiverStatusStore import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.plugins.aps.loop.LoopFragment import info.nightscout.plugins.aps.loop.LoopPlugin -import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin +import info.nightscout.pump.virtual.VirtualPumpPlugin import info.nightscout.rx.bus.RxBus import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP diff --git a/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt b/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt index 2f121b9197..49be77219c 100644 --- a/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/plugins/safety/SafetyPluginTest.kt @@ -19,9 +19,9 @@ import info.nightscout.interfaces.utils.HardLimits import info.nightscout.plugins.aps.openAPSAMA.OpenAPSAMAPlugin import info.nightscout.plugins.aps.openAPSSMB.OpenAPSSMBPlugin import info.nightscout.plugins.constraints.safety.SafetyPlugin -import info.nightscout.plugins.pump.virtual.VirtualPumpPlugin -import info.nightscout.plugins.source.GlimpPlugin +import info.nightscout.pump.virtual.VirtualPumpPlugin import info.nightscout.shared.sharedPreferences.SP +import info.nightscout.source.GlimpPlugin import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/source/DexcomBoyda.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/source/DexcomBoyda.kt index e786103b4a..0b4c4cb0bc 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/source/DexcomBoyda.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/source/DexcomBoyda.kt @@ -1,3 +1,8 @@ package info.nightscout.interfaces.source -interface DexcomBoyda \ No newline at end of file +interface DexcomBoyda { + + fun isEnabled(): Boolean + fun requestPermissionIfNeeded() + fun findDexcomPackageName(): String? +} \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/source/XDrip.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/source/XDrip.kt new file mode 100644 index 0000000000..efa60ce74f --- /dev/null +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/source/XDrip.kt @@ -0,0 +1,5 @@ +package info.nightscout.interfaces.source + +interface XDrip { + fun isEnabled(): Boolean +} \ No newline at end of file diff --git a/crowdin.yml b/crowdin.yml index 42dc0118d9..a68389e204 100644 --- a/crowdin.yml +++ b/crowdin.yml @@ -21,6 +21,8 @@ files: translation: /plugins/openhumans/src/main/res/values-%android_code%/strings.xml - source: /plugins/sensitivity/src/main/res/values/strings.xml translation: /plugins/sensitivity/src/main/res/values-%android_code%/strings.xml + - source: /plugins/source/src/main/res/values/strings.xml + translation: /plugins/source/src/main/res/values-%android_code%/strings.xml - source: /plugins/insulin/src/main/res/values/strings.xml translation: /plugins/insulin/src/main/res/values-%android_code%/strings.xml - source: /plugins/configuration/src/main/res/values/strings.xml diff --git a/implementation/src/test/java/info/nightscout/implementation/queue/CommandQueueImplementationTest.kt b/implementation/src/test/java/info/nightscout/implementation/queue/CommandQueueImplementationTest.kt index 0df16d3d8d..aaaa6657ce 100644 --- a/implementation/src/test/java/info/nightscout/implementation/queue/CommandQueueImplementationTest.kt +++ b/implementation/src/test/java/info/nightscout/implementation/queue/CommandQueueImplementationTest.kt @@ -85,7 +85,7 @@ class CommandQueueImplementationTest : TestBaseWithProfile() { } - val injector = HasAndroidInjector { + private val injector = HasAndroidInjector { AndroidInjector { if (it is Command) { it.aapsLogger = aapsLogger diff --git a/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt index 308804fed9..1dfe6d458d 100644 --- a/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt +++ b/plugins/constraints/src/test/java/info/nightscout/plugins/constraints/bgQualityCheck/BgQualityCheckPluginTest.kt @@ -37,7 +37,7 @@ class BgQualityCheckPluginTest : TestBase() { private lateinit var plugin: BgQualityCheckPlugin private val injector = HasAndroidInjector { AndroidInjector { } } - val now = 100000000L + private val now = 100000000L //private val autosensDataStore = AutosensDataStoreObject() @BeforeEach @@ -234,6 +234,9 @@ class BgQualityCheckPluginTest : TestBase() { class DexcomPlugin : BgSource, DexcomBoyda { override fun shouldUploadToNs(glucoseValue: GlucoseValue): Boolean = true + override fun isEnabled(): Boolean = false + override fun requestPermissionIfNeeded() {} + override fun findDexcomPackageName(): String? = null } `when`(activePlugin.activeBgSource).thenReturn(DexcomPlugin()) plugin.processBgData() diff --git a/plugins/main/src/main/AndroidManifest.xml b/plugins/main/src/main/AndroidManifest.xml index 41f19bc508..aff7ae7188 100644 --- a/plugins/main/src/main/AndroidManifest.xml +++ b/plugins/main/src/main/AndroidManifest.xml @@ -19,10 +19,6 @@ - - { - if (xdripPlugin.isEnabled()) + if (xDrip.isEnabled()) openCgmApp("com.eveningoutpost.dexdrip") - else if (dexcomPlugin.isEnabled()) { - dexcomMediator.findDexcomPackageName()?.let { + else if (dexcomBoyda.isEnabled()) { + dexcomBoyda.findDexcomPackageName()?.let { openCgmApp(it) } ?: ToastUtils.infoToast(activity, rh.gs(R.string.dexcom_app_not_installed)) @@ -411,11 +410,11 @@ class OverviewFragment : DaggerFragment(), View.OnClickListener, OnLongClickList } R.id.calibration_button -> { - if (xdripPlugin.isEnabled()) { + if (xDrip.isEnabled()) { uiInteraction.runCalibrationDialog(childFragmentManager) - } else if (dexcomPlugin.isEnabled()) { + } else if (dexcomBoyda.isEnabled()) { try { - dexcomMediator.findDexcomPackageName()?.let { + dexcomBoyda.findDexcomPackageName()?.let { startActivity( Intent("com.dexcom.cgm.activities.MeterEntryActivity") .setPackage(it) @@ -577,8 +576,8 @@ class OverviewFragment : DaggerFragment(), View.OnClickListener, OnLongClickList && sp.getBoolean(R.string.key_show_insulin_button, true)).toVisibility() // **** Calibration & CGM buttons **** - val xDripIsBgSource = xdripPlugin.isEnabled() - val dexcomIsSource = dexcomPlugin.isEnabled() + val xDripIsBgSource = xDrip.isEnabled() + val dexcomIsSource = dexcomBoyda.isEnabled() binding.buttonsLayout.calibrationButton.visibility = (xDripIsBgSource && actualBG != null && sp.getBoolean(R.string.key_show_calibration_button, true)).toVisibility() if (dexcomIsSource) { binding.buttonsLayout.cgmButton.setCompoundDrawablesWithIntrinsicBounds(null, rh.gd(R.drawable.ic_byoda), null, null) diff --git a/plugins/main/src/main/res/values/strings.xml b/plugins/main/src/main/res/values/strings.xml index 0e61329d58..ca6256df31 100644 --- a/plugins/main/src/main/res/values/strings.xml +++ b/plugins/main/src/main/res/values/strings.xml @@ -344,48 +344,6 @@ Graph scale Graph - - dexcom_lognssensorchange - last_processed_glunovo_timestamp - last_processed_intelligo_timestamp - - NSClient BG - NS BG - Downloads BG data from Nightscout - xDrip+ - Receive BG values from xDrip+. - BYODA - BYODA - Receive BG values from the \'Build Your Own Dexcom App\'. - Eversense App (patched) - EVR - Receive BG values from the patched Eversense app. - Glimp - Receive BG values from Glimp. - MM640g - Receive BG values from the 600SeriesAndroidUploader. - Poctech - Receive BG values from Poctech app - Glunovo - Receive values from Glunovo app - Intelligo - Receive values from Intelligo app - Tomato (MiaoMiao) - Tomato - Receive BG values from Tomato app (MiaoMiao device) - GlucoRx Aidex - Aidex - Receive BG values from GlucoRx Aidex CGMS. - Random BG - Generate random BG data (Demo mode only) - BG - - Send BG data to xDrip+ - In xDrip+ select 640g/Eversense data source - BG upload settings - Log sensor change to NS - Create event \"Sensor Change\" in NS automatically on sensor start - skin diff --git a/plugins/source/.gitignore b/plugins/source/.gitignore new file mode 100644 index 0000000000..42afabfd2a --- /dev/null +++ b/plugins/source/.gitignore @@ -0,0 +1 @@ +/build \ No newline at end of file diff --git a/plugins/source/build.gradle b/plugins/source/build.gradle new file mode 100644 index 0000000000..5cbae0f81f --- /dev/null +++ b/plugins/source/build.gradle @@ -0,0 +1,28 @@ +plugins { + id 'com.android.library' + id 'kotlin-android' + id 'kotlin-kapt' + id 'kotlin-allopen' + id 'com.hiya.jacoco-android' +} + +apply from: "${project.rootDir}/core/main/android_dependencies.gradle" +apply from: "${project.rootDir}/core/main/android_module_dependencies.gradle" +apply from: "${project.rootDir}/core/main/allopen_dependencies.gradle" +apply from: "${project.rootDir}/core/main/test_dependencies.gradle" +apply from: "${project.rootDir}/core/main/jacoco_global.gradle" +android { + namespace 'info.nightscout.source' +} + + +dependencies { + implementation project(':app-wear-shared:shared') + implementation project(':database:entities') + implementation project(':database:impl') + implementation project(':core:interfaces') + implementation project(':core:main') + implementation project(':core:ns-sdk') + implementation project(':core:ui') + implementation project(':core:utils') +} \ No newline at end of file diff --git a/plugins/source/consumer-rules.pro b/plugins/source/consumer-rules.pro new file mode 100644 index 0000000000..e69de29bb2 diff --git a/plugins/source/proguard-rules.pro b/plugins/source/proguard-rules.pro new file mode 100644 index 0000000000..481bb43481 --- /dev/null +++ b/plugins/source/proguard-rules.pro @@ -0,0 +1,21 @@ +# Add project specific ProGuard rules here. +# You can control the set of applied configuration files using the +# proguardFiles setting in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} + +# Uncomment this to preserve the line number information for +# debugging stack traces. +#-keepattributes SourceFile,LineNumberTable + +# If you keep the line number information, uncomment this to +# hide the original source file name. +#-renamesourcefileattribute SourceFile \ No newline at end of file diff --git a/plugins/source/src/main/AndroidManifest.xml b/plugins/source/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..8ab266755d --- /dev/null +++ b/plugins/source/src/main/AndroidManifest.xml @@ -0,0 +1,12 @@ + + + + + + + + + + \ No newline at end of file diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/AidexPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/AidexPlugin.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/source/AidexPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/AidexPlugin.kt index 4a1a6f5aab..837b0ee908 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/AidexPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/AidexPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import androidx.work.WorkerParameters @@ -17,7 +17,6 @@ import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.receivers.Intents import info.nightscout.interfaces.source.BgSource -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/BGSourceFragment.kt b/plugins/source/src/main/java/info/nightscout/source/BGSourceFragment.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/source/BGSourceFragment.kt rename to plugins/source/src/main/java/info/nightscout/source/BGSourceFragment.kt index 048bc4317c..29808634f9 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/BGSourceFragment.kt +++ b/plugins/source/src/main/java/info/nightscout/source/BGSourceFragment.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.os.Bundle import android.util.SparseArray @@ -29,9 +29,6 @@ import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.plugins.R -import info.nightscout.plugins.databinding.SourceFragmentBinding -import info.nightscout.plugins.databinding.SourceItemBinding import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventNewBG @@ -41,6 +38,8 @@ import info.nightscout.shared.extensions.toVisibility import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.utils.DateUtil import info.nightscout.shared.utils.T +import info.nightscout.source.databinding.SourceFragmentBinding +import info.nightscout.source.databinding.SourceItemBinding import io.reactivex.rxjava3.disposables.CompositeDisposable import io.reactivex.rxjava3.kotlin.plusAssign import java.util.concurrent.TimeUnit diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/DexcomPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/DexcomPlugin.kt similarity index 92% rename from plugins/main/src/main/java/info/nightscout/plugins/source/DexcomPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/DexcomPlugin.kt index 1217e047d5..c3471ccee7 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/DexcomPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/DexcomPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import android.content.Intent @@ -28,8 +28,6 @@ import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.source.BgSource import info.nightscout.interfaces.source.DexcomBoyda -import info.nightscout.plugins.R -import info.nightscout.plugins.source.activities.RequestDexcomPermissionActivity import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.extensions.safeGetInstalledPackages @@ -37,6 +35,7 @@ import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil import info.nightscout.shared.utils.T +import info.nightscout.source.activities.RequestDexcomPermissionActivity import javax.inject.Inject import javax.inject.Singleton import kotlin.math.abs @@ -47,7 +46,7 @@ class DexcomPlugin @Inject constructor( rh: ResourceHelper, aapsLogger: AAPSLogger, private val sp: SP, - private val dexcomMediator: DexcomMediator, + private val context: Context, config: Config ) : PluginBase( PluginDescription() @@ -77,7 +76,7 @@ class DexcomPlugin @Inject constructor( override fun onStart() { super.onStart() - dexcomMediator.requestPermissionIfNeeded() + requestPermissionIfNeeded() } // cannot be inner class because of needed injection @@ -222,6 +221,22 @@ class DexcomPlugin @Inject constructor( } } + override fun requestPermissionIfNeeded() { + if (ContextCompat.checkSelfPermission(context, PERMISSION) != PackageManager.PERMISSION_GRANTED) { + val intent = Intent(context, RequestDexcomPermissionActivity::class.java) + intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK) + context.startActivity(intent) + } + } + + override fun findDexcomPackageName(): String? { + val packageManager = context.packageManager + for (packageInfo in packageManager.safeGetInstalledPackages(0)) { + if (PACKAGE_NAMES.contains(packageInfo.packageName)) return packageInfo.packageName + } + return null + } + companion object { private val PACKAGE_NAMES = arrayOf( @@ -232,23 +247,4 @@ class DexcomPlugin @Inject constructor( ) const val PERMISSION = "com.dexcom.cgm.EXTERNAL_PERMISSION" } - - class DexcomMediator @Inject constructor(val context: Context) { - - fun requestPermissionIfNeeded() { - if (ContextCompat.checkSelfPermission(context, PERMISSION) != PackageManager.PERMISSION_GRANTED) { - val intent = Intent(context, RequestDexcomPermissionActivity::class.java) - intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK) - context.startActivity(intent) - } - } - - fun findDexcomPackageName(): String? { - val packageManager = context.packageManager - for (packageInfo in packageManager.safeGetInstalledPackages(0)) { - if (PACKAGE_NAMES.contains(packageInfo.packageName)) return packageInfo.packageName - } - return null - } - } } diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/EversensePlugin.kt b/plugins/source/src/main/java/info/nightscout/source/EversensePlugin.kt similarity index 99% rename from plugins/main/src/main/java/info/nightscout/plugins/source/EversensePlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/EversensePlugin.kt index ea965806fa..1d6167d0ae 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/EversensePlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/EversensePlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import androidx.work.WorkerParameters @@ -17,7 +17,6 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.BgSource -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/GlimpPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/GlimpPlugin.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/source/GlimpPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/GlimpPlugin.kt index d529078a33..65292352f7 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/GlimpPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/GlimpPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import androidx.work.WorkerParameters @@ -15,7 +15,6 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.BgSource -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/GlunovoPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/GlunovoPlugin.kt similarity index 99% rename from plugins/main/src/main/java/info/nightscout/plugins/source/GlunovoPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/GlunovoPlugin.kt index cb283f732f..367ac7580e 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/GlunovoPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/GlunovoPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import android.net.Uri @@ -20,7 +20,6 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.BgSource -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/IntelligoPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/IntelligoPlugin.kt similarity index 99% rename from plugins/main/src/main/java/info/nightscout/plugins/source/IntelligoPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/IntelligoPlugin.kt index e17b655aa0..25b4511871 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/IntelligoPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/IntelligoPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import android.content.pm.PackageManager @@ -22,7 +22,6 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.BgSource -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.extensions.safeGetInstalledPackages diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/MM640gPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/MM640gPlugin.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/source/MM640gPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/MM640gPlugin.kt index 027e6bdc67..6b7dc0d46a 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/MM640gPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/MM640gPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import androidx.work.WorkerParameters @@ -15,7 +15,6 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.BgSource -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/NSClientSourcePlugin.kt b/plugins/source/src/main/java/info/nightscout/source/NSClientSourcePlugin.kt similarity index 99% rename from plugins/main/src/main/java/info/nightscout/plugins/source/NSClientSourcePlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/NSClientSourcePlugin.kt index 0f2edb1158..7e8f9309f0 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/NSClientSourcePlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/NSClientSourcePlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import androidx.work.WorkerParameters @@ -21,7 +21,6 @@ import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.BgSource import info.nightscout.interfaces.source.DoingOwnUploadSource import info.nightscout.interfaces.source.NSClientSource -import info.nightscout.plugins.R import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventDismissNotification import info.nightscout.rx.logging.AAPSLogger diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/PoctechPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/PoctechPlugin.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/source/PoctechPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/PoctechPlugin.kt index 7e9de5b405..3bd3712103 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/PoctechPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/PoctechPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import androidx.work.WorkerParameters @@ -16,7 +16,6 @@ import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.BgSource import info.nightscout.interfaces.utils.JsonHelper.safeGetString -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/RandomBgPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/RandomBgPlugin.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/source/RandomBgPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/RandomBgPlugin.kt index c11fbbfe47..2aeaf1b002 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/RandomBgPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/RandomBgPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.os.Handler import android.os.HandlerThread @@ -16,7 +16,6 @@ import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.pump.VirtualPump import info.nightscout.interfaces.source.BgSource -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/TomatoPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/TomatoPlugin.kt similarity index 98% rename from plugins/main/src/main/java/info/nightscout/plugins/source/TomatoPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/TomatoPlugin.kt index 93afb3bf50..07d56fc0f5 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/TomatoPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/TomatoPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import androidx.work.WorkerParameters @@ -14,7 +14,6 @@ import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.source.BgSource -import info.nightscout.plugins.R import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/XdripPlugin.kt b/plugins/source/src/main/java/info/nightscout/source/XdripPlugin.kt similarity index 97% rename from plugins/main/src/main/java/info/nightscout/plugins/source/XdripPlugin.kt rename to plugins/source/src/main/java/info/nightscout/source/XdripPlugin.kt index a6b8d715dd..9d2ea18dd7 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/XdripPlugin.kt +++ b/plugins/source/src/main/java/info/nightscout/source/XdripPlugin.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.source +package info.nightscout.source import android.content.Context import androidx.work.WorkerParameters @@ -16,7 +16,7 @@ import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.receivers.Intents import info.nightscout.interfaces.source.BgSource import info.nightscout.interfaces.source.DoingOwnUploadSource -import info.nightscout.plugins.R +import info.nightscout.interfaces.source.XDrip import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper @@ -36,7 +36,7 @@ class XdripPlugin @Inject constructor( .pluginName(R.string.xdrip) .description(R.string.description_source_xdrip), aapsLogger, rh, injector -), BgSource, DoingOwnUploadSource { +), BgSource, DoingOwnUploadSource, XDrip { private var advancedFiltering = false override var sensorBatteryLevel = -1 diff --git a/plugins/main/src/main/java/info/nightscout/plugins/source/activities/RequestDexcomPermissionActivity.kt b/plugins/source/src/main/java/info/nightscout/source/activities/RequestDexcomPermissionActivity.kt similarity index 86% rename from plugins/main/src/main/java/info/nightscout/plugins/source/activities/RequestDexcomPermissionActivity.kt rename to plugins/source/src/main/java/info/nightscout/source/activities/RequestDexcomPermissionActivity.kt index 97d2ecba8c..142601e644 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/source/activities/RequestDexcomPermissionActivity.kt +++ b/plugins/source/src/main/java/info/nightscout/source/activities/RequestDexcomPermissionActivity.kt @@ -1,8 +1,8 @@ -package info.nightscout.plugins.source.activities +package info.nightscout.source.activities import android.os.Bundle import info.nightscout.core.ui.activities.DialogAppCompatActivity -import info.nightscout.plugins.source.DexcomPlugin +import info.nightscout.source.DexcomPlugin class RequestDexcomPermissionActivity : DialogAppCompatActivity() { diff --git a/plugins/main/src/main/java/info/nightscout/plugins/di/SourceModule.kt b/plugins/source/src/main/java/info/nightscout/source/di/SourceModule.kt similarity index 65% rename from plugins/main/src/main/java/info/nightscout/plugins/di/SourceModule.kt rename to plugins/source/src/main/java/info/nightscout/source/di/SourceModule.kt index cc2fcb366a..2aec6c6d5a 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/di/SourceModule.kt +++ b/plugins/source/src/main/java/info/nightscout/source/di/SourceModule.kt @@ -1,21 +1,22 @@ -package info.nightscout.plugins.di +package info.nightscout.source.di import dagger.Binds import dagger.Module import dagger.android.ContributesAndroidInjector +import info.nightscout.interfaces.source.DexcomBoyda import info.nightscout.interfaces.source.NSClientSource -import info.nightscout.plugins.profile.ProfilePlugin -import info.nightscout.plugins.source.AidexPlugin -import info.nightscout.plugins.source.BGSourceFragment -import info.nightscout.plugins.source.DexcomPlugin -import info.nightscout.plugins.source.EversensePlugin -import info.nightscout.plugins.source.GlimpPlugin -import info.nightscout.plugins.source.MM640gPlugin -import info.nightscout.plugins.source.NSClientSourcePlugin -import info.nightscout.plugins.source.PoctechPlugin -import info.nightscout.plugins.source.TomatoPlugin -import info.nightscout.plugins.source.XdripPlugin -import info.nightscout.plugins.source.activities.RequestDexcomPermissionActivity +import info.nightscout.interfaces.source.XDrip +import info.nightscout.source.AidexPlugin +import info.nightscout.source.BGSourceFragment +import info.nightscout.source.DexcomPlugin +import info.nightscout.source.EversensePlugin +import info.nightscout.source.GlimpPlugin +import info.nightscout.source.MM640gPlugin +import info.nightscout.source.NSClientSourcePlugin +import info.nightscout.source.PoctechPlugin +import info.nightscout.source.TomatoPlugin +import info.nightscout.source.XdripPlugin +import info.nightscout.source.activities.RequestDexcomPermissionActivity @Module( includes = [ @@ -28,7 +29,6 @@ abstract class SourceModule { @ContributesAndroidInjector abstract fun contributesBGSourceFragment(): BGSourceFragment - @ContributesAndroidInjector abstract fun contributesNSProfileWorker(): ProfilePlugin.NSProfileWorker @ContributesAndroidInjector abstract fun contributesNSClientSourceWorker(): NSClientSourcePlugin.NSClientSourceWorker @ContributesAndroidInjector abstract fun contributesXdripWorker(): XdripPlugin.XdripWorker @ContributesAndroidInjector abstract fun contributesDexcomWorker(): DexcomPlugin.DexcomWorker @@ -43,6 +43,9 @@ abstract class SourceModule { @Module interface Bindings { + @Binds fun bindNSClientSource(nsClientSourcePlugin: NSClientSourcePlugin): NSClientSource + @Binds fun bindDexcomBoyda(dexcomPlugin: DexcomPlugin): DexcomBoyda + @Binds fun bindXDrip(xdripPlugin: XdripPlugin): XDrip } } \ No newline at end of file diff --git a/plugins/main/src/main/res/drawable/ic_dice.xml b/plugins/source/src/main/res/drawable/ic_dice.xml similarity index 100% rename from plugins/main/src/main/res/drawable/ic_dice.xml rename to plugins/source/src/main/res/drawable/ic_dice.xml diff --git a/plugins/main/src/main/res/layout/source_fragment.xml b/plugins/source/src/main/res/layout/source_fragment.xml similarity index 91% rename from plugins/main/src/main/res/layout/source_fragment.xml rename to plugins/source/src/main/res/layout/source_fragment.xml index f56d3e838c..e31cab2e0a 100644 --- a/plugins/main/src/main/res/layout/source_fragment.xml +++ b/plugins/source/src/main/res/layout/source_fragment.xml @@ -4,7 +4,7 @@ android:layout_height="match_parent" android:orientation="vertical" android:paddingTop="2dp" - tools:context=".source.BGSourceFragment"> + tools:context=".BGSourceFragment"> + app:srcCompat="@drawable/ic_flat" + android:contentDescription="@string/direction" /> + + + dexcom_lognssensorchange + last_processed_glunovo_timestamp + last_processed_intelligo_timestamp + + NSClient BG + NS BG + Downloads BG data from Nightscout + xDrip+ + Receive BG values from xDrip+. + BYODA + BYODA + Receive BG values from the \'Build Your Own Dexcom App\'. + Eversense App (patched) + EVR + Receive BG values from the patched Eversense app. + Glimp + Receive BG values from Glimp. + MM640g + Receive BG values from the 600SeriesAndroidUploader. + Poctech + Receive BG values from Poctech app + Glunovo + Receive values from Glunovo app + Intelligo + Receive values from Intelligo app + Tomato (MiaoMiao) + Tomato + Receive BG values from Tomato app (MiaoMiao device) + GlucoRx Aidex + Aidex + Receive BG values from GlucoRx Aidex CGMS. + Random BG + Generate random BG data (Demo mode only) + BG + + Send BG data to xDrip+ + In xDrip+ select 640g/Eversense data source + BG upload settings + Log sensor change to NS + Create event \"Sensor Change\" in NS automatically on sensor start + direction + + + \ No newline at end of file diff --git a/plugins/main/src/main/res/xml/pref_bgsource.xml b/plugins/source/src/main/res/xml/pref_bgsource.xml similarity index 100% rename from plugins/main/src/main/res/xml/pref_bgsource.xml rename to plugins/source/src/main/res/xml/pref_bgsource.xml diff --git a/plugins/main/src/main/res/xml/pref_dexcom.xml b/plugins/source/src/main/res/xml/pref_dexcom.xml similarity index 100% rename from plugins/main/src/main/res/xml/pref_dexcom.xml rename to plugins/source/src/main/res/xml/pref_dexcom.xml diff --git a/plugins/source/src/test/java/info/nightscout/androidaps/TestBase.kt b/plugins/source/src/test/java/info/nightscout/androidaps/TestBase.kt new file mode 100644 index 0000000000..4fd2aef548 --- /dev/null +++ b/plugins/source/src/test/java/info/nightscout/androidaps/TestBase.kt @@ -0,0 +1,37 @@ +package info.nightscout.androidaps + +import info.nightscout.rx.AapsSchedulers +import info.nightscout.rx.TestAapsSchedulers +import info.nightscout.rx.logging.AAPSLoggerTest +import org.junit.jupiter.api.BeforeEach +import org.junit.jupiter.api.extension.ExtendWith +import org.mockito.Mockito +import org.mockito.junit.jupiter.MockitoExtension +import org.mockito.junit.jupiter.MockitoSettings +import org.mockito.quality.Strictness +import java.util.Locale + +@ExtendWith(MockitoExtension::class) +@MockitoSettings(strictness = Strictness.LENIENT) +open class TestBase { + + val aapsLogger = AAPSLoggerTest() + val aapsSchedulers: AapsSchedulers = TestAapsSchedulers() + + @BeforeEach + fun setupLocale() { + Locale.setDefault(Locale.ENGLISH) + System.setProperty("disableFirebase", "true") + } + + // Workaround for Kotlin nullability. + // https://medium.com/@elye.project/befriending-kotlin-and-mockito-1c2e7b0ef791 + // https://stackoverflow.com/questions/30305217/is-it-possible-to-use-mockito-in-kotlin + fun anyObject(): T { + Mockito.any() + return uninitialized() + } + + @Suppress("Unchecked_Cast") + fun uninitialized(): T = null as T +} \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/source/GlimpPluginTest.kt b/plugins/source/src/test/java/info/nightscout/source/GlimpPluginTest.kt similarity index 61% rename from plugins/main/src/test/java/info/nightscout/plugins/source/GlimpPluginTest.kt rename to plugins/source/src/test/java/info/nightscout/source/GlimpPluginTest.kt index 517ef7fed1..be6fc799ba 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/source/GlimpPluginTest.kt +++ b/plugins/source/src/test/java/info/nightscout/source/GlimpPluginTest.kt @@ -1,12 +1,10 @@ -package info.nightscout.androidaps.plugins.source +package info.nightscout.source import dagger.android.AndroidInjector -import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBase -import info.nightscout.plugins.source.GlimpPlugin import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -20,10 +18,10 @@ class GlimpPluginTest : TestBase() { @BeforeEach fun setup() { - glimpPlugin = GlimpPlugin(HasAndroidInjector { AndroidInjector { } }, rh, aapsLogger, sp) + glimpPlugin = GlimpPlugin({ AndroidInjector { } }, rh, aapsLogger, sp) } @Test fun advancedFilteringSupported() { - Assert.assertEquals(false, glimpPlugin.advancedFilteringSupported()) + Assertions.assertEquals(false, glimpPlugin.advancedFilteringSupported()) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/source/MM640GPluginTest.kt b/plugins/source/src/test/java/info/nightscout/source/MM640GPluginTest.kt similarity index 61% rename from plugins/main/src/test/java/info/nightscout/plugins/source/MM640GPluginTest.kt rename to plugins/source/src/test/java/info/nightscout/source/MM640GPluginTest.kt index 5ef860f425..4d71051ef7 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/source/MM640GPluginTest.kt +++ b/plugins/source/src/test/java/info/nightscout/source/MM640GPluginTest.kt @@ -1,12 +1,10 @@ -package info.nightscout.androidaps.plugins.source +package info.nightscout.source import dagger.android.AndroidInjector -import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBase -import info.nightscout.plugins.source.MM640gPlugin import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -20,10 +18,10 @@ class MM640GPluginTest : TestBase() { @BeforeEach fun setup() { - mM640gPlugin = MM640gPlugin(HasAndroidInjector { AndroidInjector { } }, rh, aapsLogger, sp) + mM640gPlugin = MM640gPlugin({ AndroidInjector { } }, rh, aapsLogger, sp) } @Test fun advancedFilteringSupported() { - Assert.assertEquals(false, mM640gPlugin.advancedFilteringSupported()) + Assertions.assertEquals(false, mM640gPlugin.advancedFilteringSupported()) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/source/NSClientPluginTest.kt b/plugins/source/src/test/java/info/nightscout/source/NSClientPluginTest.kt similarity index 51% rename from plugins/main/src/test/java/info/nightscout/plugins/source/NSClientPluginTest.kt rename to plugins/source/src/test/java/info/nightscout/source/NSClientPluginTest.kt index 6e74ff7be3..636520b90d 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/source/NSClientPluginTest.kt +++ b/plugins/source/src/test/java/info/nightscout/source/NSClientPluginTest.kt @@ -1,29 +1,27 @@ -package info.nightscout.androidaps.plugins.source +package info.nightscout.source import dagger.android.AndroidInjector import info.nightscout.androidaps.TestBase import info.nightscout.interfaces.Config import info.nightscout.shared.interfaces.ResourceHelper -import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock class NSClientPluginTest : TestBase() { - private lateinit var nsClientSourcePlugin: info.nightscout.plugins.source.NSClientSourcePlugin + private lateinit var nsClientSourcePlugin: NSClientSourcePlugin @Mock lateinit var rh: ResourceHelper - @Mock lateinit var sp: SP @Mock lateinit var config: Config @BeforeEach fun setup() { - nsClientSourcePlugin = info.nightscout.plugins.source.NSClientSourcePlugin({ AndroidInjector { } }, rh, aapsLogger, config) + nsClientSourcePlugin = NSClientSourcePlugin({ AndroidInjector { } }, rh, aapsLogger, config) } @Test fun advancedFilteringSupported() { - Assert.assertEquals(false, nsClientSourcePlugin.advancedFilteringSupported()) + Assertions.assertEquals(false, nsClientSourcePlugin.advancedFilteringSupported()) } } \ No newline at end of file diff --git a/plugins/main/src/test/java/info/nightscout/plugins/source/XdripPluginTest.kt b/plugins/source/src/test/java/info/nightscout/source/XdripPluginTest.kt similarity index 57% rename from plugins/main/src/test/java/info/nightscout/plugins/source/XdripPluginTest.kt rename to plugins/source/src/test/java/info/nightscout/source/XdripPluginTest.kt index 49ac33fc0f..2524a18db6 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/source/XdripPluginTest.kt +++ b/plugins/source/src/test/java/info/nightscout/source/XdripPluginTest.kt @@ -1,11 +1,9 @@ -package info.nightscout.androidaps.plugins.source +package info.nightscout.source import dagger.android.AndroidInjector -import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBase -import info.nightscout.plugins.source.XdripPlugin import info.nightscout.shared.interfaces.ResourceHelper -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -18,10 +16,10 @@ class XdripPluginTest : TestBase() { @BeforeEach fun setup() { - xdripPlugin = XdripPlugin(HasAndroidInjector { AndroidInjector { } }, rh, aapsLogger) + xdripPlugin = XdripPlugin({ AndroidInjector { } }, rh, aapsLogger) } @Test fun advancedFilteringSupported() { - Assert.assertEquals(false, xdripPlugin.advancedFilteringSupported()) + Assertions.assertEquals(false, xdripPlugin.advancedFilteringSupported()) } } \ No newline at end of file diff --git a/settings.gradle b/settings.gradle index dae8b065c8..994e5fa516 100644 --- a/settings.gradle +++ b/settings.gradle @@ -22,6 +22,7 @@ include ':plugins:insulin' include ':plugins:main' include ':plugins:openhumans' include ':plugins:sensitivity' +include ':plugins:source' include ':plugins:constraints' include ':pump:combo' include ':pump:combov2' From c8113bf4fc5251c597f538f7e5ba6dbd6468deb9 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 16:49:33 +0100 Subject: [PATCH 23/48] Instantiator --- .../nightscout/androidaps/di/AppModule.kt | 6 +++- .../implementations/InstantiatorImpl.kt | 28 +++++++++++++++++++ .../interfaces/ConstraintsCheckerTest.kt | 6 ++-- .../info/nightscout/interfaces/aps/Loop.kt | 2 -- .../interfaces/iob/IobCobCalculator.kt | 2 -- .../interfaces/profile/Instantiator.kt | 12 ++++++++ .../interfaces/profile/ProfileInstantiator.kt | 7 ----- .../implementation/di/ImplementationModule.kt | 3 -- .../profile/ProfileInstantiatorImpl.kt | 17 ----------- .../nightscout/plugins/aps/loop/LoopPlugin.kt | 3 -- .../general/autotune/AutotuneFragment.kt | 8 +++--- .../general/autotune/AutotunePlugin.kt | 6 ++-- .../general/autotune/data/ATProfile.kt | 6 ++-- .../automation/actions/ActionsTestBase.kt | 7 +---- .../IobCobCalculatorPlugin.kt | 3 -- .../plugins/profile/ProfilePlugin.kt | 10 +++---- .../data/ProcessedDeviceStatusDataImpl.kt | 7 ++--- .../info/nightscout/pump/dana/DanaPump.kt | 6 ++-- .../androidaps/dana/DanaPumpTest.kt | 10 +++---- .../plugins/pump/danaR/DanaRPluginTest.kt | 26 +++++++++-------- .../plugins/pump/danaR/comm/DanaRTestBase.kt | 8 ++---- .../pump/danaRKorean/DanaRKoreanPluginTest.kt | 20 ++++++------- .../plugins/pump/danaRv2/DanaRv2PluginTest.kt | 19 +++++++------ .../nightscout/pump/danars/DanaRSTestBase.kt | 10 ++----- .../workflow/iob/IobCobOref1Worker.kt | 4 ++- .../workflow/iob/IobCobOrefWorker.kt | 4 ++- 26 files changed, 121 insertions(+), 119 deletions(-) create mode 100644 app/src/main/java/info/nightscout/androidaps/implementations/InstantiatorImpl.kt create mode 100644 core/interfaces/src/main/java/info/nightscout/interfaces/profile/Instantiator.kt delete mode 100644 core/interfaces/src/main/java/info/nightscout/interfaces/profile/ProfileInstantiator.kt delete mode 100644 implementation/src/main/java/info/nightscout/implementation/profile/ProfileInstantiatorImpl.kt diff --git a/app/src/main/java/info/nightscout/androidaps/di/AppModule.kt b/app/src/main/java/info/nightscout/androidaps/di/AppModule.kt index 1611893464..5c38128af0 100644 --- a/app/src/main/java/info/nightscout/androidaps/di/AppModule.kt +++ b/app/src/main/java/info/nightscout/androidaps/di/AppModule.kt @@ -7,13 +7,15 @@ import dagger.Module import dagger.Provides import dagger.android.HasAndroidInjector import info.nightscout.androidaps.MainApp -import info.nightscout.androidaps.implementations.UiInteractionImpl import info.nightscout.androidaps.implementations.ConfigImpl +import info.nightscout.androidaps.implementations.InstantiatorImpl +import info.nightscout.androidaps.implementations.UiInteractionImpl import info.nightscout.androidaps.workflow.CalculationWorkflowImpl import info.nightscout.androidaps.workflow.WorkerClassesImpl import info.nightscout.core.workflow.CalculationWorkflow import info.nightscout.interfaces.Config import info.nightscout.interfaces.plugin.PluginBase +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.workflow.WorkerClasses @@ -53,6 +55,8 @@ open class AppModule { @Binds fun bindActivityNames(activityNames: UiInteractionImpl): UiInteraction @Binds fun bindWorkerClasses(workerClassesImpl: WorkerClassesImpl): WorkerClasses @Binds fun bindCalculationWorkflow(calculationWorkflow: CalculationWorkflowImpl): CalculationWorkflow + @Binds fun bindInstantiator(instantiatorImpl: InstantiatorImpl): Instantiator + } } diff --git a/app/src/main/java/info/nightscout/androidaps/implementations/InstantiatorImpl.kt b/app/src/main/java/info/nightscout/androidaps/implementations/InstantiatorImpl.kt new file mode 100644 index 0000000000..eaab048da7 --- /dev/null +++ b/app/src/main/java/info/nightscout/androidaps/implementations/InstantiatorImpl.kt @@ -0,0 +1,28 @@ +package info.nightscout.androidaps.implementations + +import dagger.Reusable +import dagger.android.HasAndroidInjector +import info.nightscout.implementation.profile.ProfileStoreObject +import info.nightscout.interfaces.aps.APSResult +import info.nightscout.interfaces.aps.AutosensData +import info.nightscout.interfaces.profile.Instantiator +import info.nightscout.interfaces.profile.ProfileStore +import info.nightscout.plugins.aps.APSResultObject +import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataObject +import info.nightscout.shared.utils.DateUtil +import org.json.JSONObject +import javax.inject.Inject + +@Reusable +class InstantiatorImpl @Inject constructor( + private val injector: HasAndroidInjector, + private val dateUtil: DateUtil +) : Instantiator { + + override fun provideProfileStore(jsonObject: JSONObject): ProfileStore = + ProfileStoreObject(injector, jsonObject, dateUtil) + + override fun provideAPSResultObject(): APSResult = APSResultObject(injector) + + override fun provideAutosensDataObject(): AutosensData = AutosensDataObject(injector) +} \ No newline at end of file diff --git a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt index 2a64a243cb..d9af92f46c 100644 --- a/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt +++ b/app/src/test/java/info/nightscout/androidaps/interfaces/ConstraintsCheckerTest.kt @@ -20,7 +20,7 @@ import info.nightscout.interfaces.maintenance.PrefFileListProvider import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginType -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profiling.Profiler import info.nightscout.interfaces.pump.DetailedBolusInfoStorage import info.nightscout.interfaces.pump.PumpEnactResult @@ -70,7 +70,7 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { @Mock lateinit var insightDatabaseDao: InsightDatabaseDao @Mock lateinit var ruffyScripter: RuffyScripter @Mock lateinit var uiInteraction: UiInteraction - @Mock lateinit var profileInstantiator: ProfileInstantiator + @Mock lateinit var instantiator: Instantiator @Mock lateinit var danaHistoryDatabase: DanaHistoryDatabase @Mock lateinit var insightDatabase: InsightDatabase @Mock lateinit var bgQualityCheck: BgQualityCheck @@ -145,7 +145,7 @@ class ConstraintsCheckerTest : TestBaseWithProfile() { hardLimits = HardLimitsMock(sp, rh) insightDbHelper = InsightDbHelper(insightDatabaseDao) - danaPump = DanaPump(aapsLogger, sp, dateUtil, profileInstantiator) + danaPump = DanaPump(aapsLogger, sp, dateUtil, instantiator) objectivesPlugin = ObjectivesPlugin(injector, aapsLogger, rh, activePlugin, sp, config) comboPlugin = ComboPlugin(injector, aapsLogger, rxBus, rh, profileFunction, sp, commandQueue, pumpSync, dateUtil, ruffyScripter, uiInteraction) danaRPlugin = DanaRPlugin(injector, aapsLogger, aapsSchedulers, rxBus, context, rh, constraintChecker, activePlugin, sp, commandQueue, danaPump, dateUtil, fabricPrivacy, pumpSync, diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/aps/Loop.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/aps/Loop.kt index dc96f4ea91..c0eac9f4eb 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/aps/Loop.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/aps/Loop.kt @@ -57,6 +57,4 @@ interface Loop { runningConfiguration: RunningConfiguration, version: String ): DeviceStatus? - - fun provideEmptyAPSResultObject(): APSResult } \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/iob/IobCobCalculator.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/iob/IobCobCalculator.kt index 66a1af0fd6..a88237a838 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/iob/IobCobCalculator.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/iob/IobCobCalculator.kt @@ -104,6 +104,4 @@ interface IobCobCalculator { * @return IobTotal */ fun calculateIobFromTempBasalsIncludingConvertedExtended(): IobTotal - - fun provideEmptyAutosensDataObject(): AutosensData } \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/profile/Instantiator.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/profile/Instantiator.kt new file mode 100644 index 0000000000..e4d88b4eb6 --- /dev/null +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/profile/Instantiator.kt @@ -0,0 +1,12 @@ +package info.nightscout.interfaces.profile + +import info.nightscout.interfaces.aps.APSResult +import info.nightscout.interfaces.aps.AutosensData +import org.json.JSONObject + +interface Instantiator { + + fun provideProfileStore(jsonObject: JSONObject): ProfileStore + fun provideAPSResultObject(): APSResult + fun provideAutosensDataObject(): AutosensData +} \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/profile/ProfileInstantiator.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/profile/ProfileInstantiator.kt deleted file mode 100644 index 6537cb1862..0000000000 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/profile/ProfileInstantiator.kt +++ /dev/null @@ -1,7 +0,0 @@ -package info.nightscout.interfaces.profile - -import org.json.JSONObject - -interface ProfileInstantiator { - fun storeInstance(jsonObject: JSONObject): ProfileStore -} \ No newline at end of file diff --git a/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt b/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt index 3fce4b146b..5a665df59c 100644 --- a/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt +++ b/implementation/src/main/java/info/nightscout/implementation/di/ImplementationModule.kt @@ -18,7 +18,6 @@ import info.nightscout.implementation.logging.LoggerUtilsImpl import info.nightscout.implementation.overview.OverviewDataImpl import info.nightscout.implementation.plugin.PluginStore import info.nightscout.implementation.profile.ProfileFunctionImpl -import info.nightscout.implementation.profile.ProfileInstantiatorImpl import info.nightscout.implementation.profile.ProfileStoreObject import info.nightscout.implementation.profiling.ProfilerImpl import info.nightscout.implementation.protection.PasswordCheckImpl @@ -49,7 +48,6 @@ import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.DefaultValueHelper import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.ProfileInstantiator import info.nightscout.interfaces.profiling.Profiler import info.nightscout.interfaces.protection.PasswordCheck import info.nightscout.interfaces.protection.ProtectionCheck @@ -100,7 +98,6 @@ abstract class ImplementationModule { @Binds fun bindWarnColors(warnColorsImpl: WarnColorsImpl): WarnColors @Binds fun bindHardLimits(hardLimitsImpl: HardLimitsImpl): HardLimits @Binds fun bindResourceHelper(resourceHelperImpl: ResourceHelperImpl): ResourceHelper - @Binds fun bindProfileStoreInstantiator(profileStoreInstantiatorImpl: ProfileInstantiatorImpl): ProfileInstantiator @Binds fun bindBlePreCheck(blePreCheckImpl: BlePreCheckImpl): BlePreCheck @Binds fun bindTrendCalculatorInterface(trendCalculator: TrendCalculatorImpl): TrendCalculator diff --git a/implementation/src/main/java/info/nightscout/implementation/profile/ProfileInstantiatorImpl.kt b/implementation/src/main/java/info/nightscout/implementation/profile/ProfileInstantiatorImpl.kt deleted file mode 100644 index e801af2193..0000000000 --- a/implementation/src/main/java/info/nightscout/implementation/profile/ProfileInstantiatorImpl.kt +++ /dev/null @@ -1,17 +0,0 @@ -package info.nightscout.implementation.profile - -import dagger.android.HasAndroidInjector -import info.nightscout.interfaces.profile.ProfileInstantiator -import info.nightscout.interfaces.profile.ProfileStore -import info.nightscout.shared.utils.DateUtil -import org.json.JSONObject -import javax.inject.Inject - -class ProfileInstantiatorImpl @Inject constructor( - private val injector: HasAndroidInjector, - private val dateUtil: DateUtil -): ProfileInstantiator { - - override fun storeInstance(jsonObject: JSONObject): ProfileStore = - ProfileStoreObject(injector, jsonObject, dateUtil) -} \ No newline at end of file diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/aps/loop/LoopPlugin.kt b/plugins/aps/src/main/java/info/nightscout/plugins/aps/loop/LoopPlugin.kt index 7ae6516800..05faef4c3f 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/aps/loop/LoopPlugin.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/aps/loop/LoopPlugin.kt @@ -57,7 +57,6 @@ import info.nightscout.interfaces.queue.CommandQueue import info.nightscout.interfaces.receivers.ReceiverStatusStore import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.HardLimits -import info.nightscout.plugins.aps.APSResultObject import info.nightscout.plugins.aps.R import info.nightscout.plugins.aps.loop.events.EventLoopSetLastRunGui import info.nightscout.plugins.aps.loop.extensions.json @@ -784,8 +783,6 @@ class LoopPlugin @Inject constructor( ) } - override fun provideEmptyAPSResultObject(): APSResult = APSResultObject(injector) - companion object { private const val CHANNEL_ID = "AAPS-OpenLoop" diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFragment.kt b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFragment.kt index e66b5db497..2bfd3b5e14 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFragment.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFragment.kt @@ -30,7 +30,7 @@ import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileStore import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.MidnightTime @@ -70,7 +70,7 @@ class AutotuneFragment : DaggerFragment() { @Inject lateinit var injector: HasAndroidInjector @Inject lateinit var aapsSchedulers: AapsSchedulers @Inject lateinit var uiInteraction: UiInteraction - @Inject lateinit var profileInstantiator: ProfileInstantiator + @Inject lateinit var instantiator: Instantiator private var disposable: CompositeDisposable = CompositeDisposable() private var handler = Handler(HandlerThread(this::class.simpleName + "Handler").also { it.start() }.looper) @@ -97,7 +97,7 @@ class AutotuneFragment : DaggerFragment() { if (autotunePlugin.lastNbDays.isEmpty()) autotunePlugin.lastNbDays = sp.getInt(info.nightscout.core.utils.R.string.key_autotune_default_tune_days, 5).toString() val defaultValue = sp.getInt(info.nightscout.core.utils.R.string.key_autotune_default_tune_days, 5).toDouble() - profileStore = activePlugin.activeProfileSource.profile ?: profileInstantiator.storeInstance(JSONObject()) + profileStore = activePlugin.activeProfileSource.profile ?: instantiator.provideProfileStore(JSONObject()) profileName = if (binding.profileList.text.toString() == rh.gs(info.nightscout.core.ui.R.string.active)) "" else binding.profileList.text.toString() profileFunction.getProfile()?.let { currentProfile -> profile = ATProfile(profileStore.getSpecificProfile(profileName)?.let { ProfileSealed.Pure(it) } ?: currentProfile, LocalInsulin(""), injector) @@ -295,7 +295,7 @@ class AutotuneFragment : DaggerFragment() { @Synchronized private fun updateGui() { _binding ?: return - profileStore = activePlugin.activeProfileSource.profile ?: profileInstantiator.storeInstance(JSONObject()) + profileStore = activePlugin.activeProfileSource.profile ?: instantiator.provideProfileStore(JSONObject()) profileName = if (binding.profileList.text.toString() == rh.gs(info.nightscout.core.ui.R.string.active)) "" else binding.profileList.text.toString() profileFunction.getProfile()?.let { currentProfile -> profile = ATProfile(profileStore.getSpecificProfile(profileName)?.let { ProfileSealed.Pure(it) } ?: currentProfile, LocalInsulin(""), injector) diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotunePlugin.kt b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotunePlugin.kt index 35349cc00d..50c4ab61c2 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotunePlugin.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotunePlugin.kt @@ -16,7 +16,7 @@ import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.utils.JsonHelper import info.nightscout.interfaces.utils.MidnightTime import info.nightscout.plugins.aps.R @@ -61,7 +61,7 @@ class AutotunePlugin @Inject constructor( private val config: Config, private val uel: UserEntryLogger, aapsLogger: AAPSLogger, - private val profileInstantiator: ProfileInstantiator + private val instantiator: Instantiator ) : PluginBase( PluginDescription() .mainType(PluginType.GENERAL) @@ -325,7 +325,7 @@ class AutotunePlugin @Inject constructor( if (newProfile == null) return val profilePlugin = activePlugin.activeProfileSource val circadian = sp.getBoolean(info.nightscout.core.utils.R.string.key_autotune_circadian_ic_isf, false) - val profileStore = activePlugin.activeProfileSource.profile ?: profileInstantiator.storeInstance(JSONObject()) + val profileStore = activePlugin.activeProfileSource.profile ?: instantiator.provideProfileStore(JSONObject()) val profileList: ArrayList = profileStore.getProfileList() var indexLocalProfile = -1 for (p in profileList.indices) diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/data/ATProfile.kt b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/data/ATProfile.kt index d6ecea8797..f8b139736a 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/data/ATProfile.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/data/ATProfile.kt @@ -12,7 +12,7 @@ import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileStore import info.nightscout.interfaces.profile.PureProfile import info.nightscout.interfaces.utils.Round @@ -38,7 +38,7 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: @Inject lateinit var config: Config @Inject lateinit var rxBus: RxBus @Inject lateinit var rh: ResourceHelper - @Inject lateinit var profileInstantiator: ProfileInstantiator + @Inject lateinit var instantiator: Instantiator var profile: ProfileSealed var circadianProfile: ProfileSealed @@ -179,7 +179,7 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: json.put("defaultProfile", profilename) json.put("store", store) json.put("startDate", dateUtil.toISOAsUTC(dateUtil.now())) - profileStore = profileInstantiator.storeInstance(json) + profileStore = instantiator.provideProfileStore(json) } catch (e: JSONException) { } return profileStore diff --git a/plugins/automation/src/test/java/info/nightscout/automation/actions/ActionsTestBase.kt b/plugins/automation/src/test/java/info/nightscout/automation/actions/ActionsTestBase.kt index c8972b3510..f4dc4bb946 100644 --- a/plugins/automation/src/test/java/info/nightscout/automation/actions/ActionsTestBase.kt +++ b/plugins/automation/src/test/java/info/nightscout/automation/actions/ActionsTestBase.kt @@ -10,7 +10,6 @@ import info.nightscout.database.entities.DeviceStatus import info.nightscout.database.entities.OfflineEvent import info.nightscout.interfaces.ConfigBuilder import info.nightscout.interfaces.GlucoseUnit -import info.nightscout.interfaces.aps.APSResult import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.configBuilder.RunningConfiguration import info.nightscout.interfaces.constraints.Constraint @@ -43,8 +42,7 @@ ActionsTestBase : TestBaseWithProfile() { aapsLogger: AAPSLogger, rh: ResourceHelper, injector: HasAndroidInjector, - pluginDescription: PluginDescription, - private val apsResult: APSResult + pluginDescription: PluginDescription ) : PluginBase( pluginDescription, aapsLogger, rh, injector ), Loop { @@ -78,8 +76,6 @@ ActionsTestBase : TestBaseWithProfile() { version: String ): DeviceStatus? = null - override fun provideEmptyAPSResultObject(): APSResult = apsResult - override fun setPluginEnabled(type: PluginType, newState: Boolean) {} } @@ -92,7 +88,6 @@ ActionsTestBase : TestBaseWithProfile() { @Mock lateinit var loopPlugin: TestLoopPlugin @Mock lateinit var uel: UserEntryLogger @Mock lateinit var context: Context - @Mock lateinit var apsResult: APSResult private val pluginDescription = PluginDescription() lateinit var testPumpPlugin: TestPumpPlugin diff --git a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt index 44d4f8b4ff..b63d5f81e8 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/IobCobCalculatorPlugin.kt @@ -38,7 +38,6 @@ import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.utils.DecimalFormatter import info.nightscout.interfaces.utils.MidnightTime import info.nightscout.plugins.R -import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataObject import info.nightscout.plugins.iob.iobCobCalculator.data.AutosensDataStoreObject import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus @@ -600,8 +599,6 @@ class IobCobCalculatorPlugin @Inject constructor( override fun calculateIobFromTempBasalsIncludingConvertedExtended(): IobTotal = calculateIobToTimeFromTempBasalsIncludingConvertedExtended(dateUtil.now()) - override fun provideEmptyAutosensDataObject(): AutosensData = AutosensDataObject(injector) - override fun calculateIobToTimeFromTempBasalsIncludingConvertedExtended(toTime: Long): IobTotal { val total = IobTotal(toTime) val now = dateUtil.now() diff --git a/plugins/main/src/main/java/info/nightscout/plugins/profile/ProfilePlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/profile/ProfilePlugin.kt index f0c83c1e40..bbcec9b28b 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/profile/ProfilePlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/profile/ProfilePlugin.kt @@ -24,7 +24,7 @@ import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileSource import info.nightscout.interfaces.profile.ProfileStore import info.nightscout.interfaces.profile.PureProfile @@ -60,7 +60,7 @@ class ProfilePlugin @Inject constructor( private val hardLimits: HardLimits, private val dateUtil: DateUtil, private val config: Config, - private val profileInstantiator: ProfileInstantiator + private val instantiator: Instantiator ) : PluginBase( PluginDescription() .mainType(PluginType.PROFILE) @@ -419,7 +419,7 @@ class ProfilePlugin @Inject constructor( aapsLogger.error("Unhandled exception", e) } - return profileInstantiator.storeInstance(json) + return instantiator.provideProfileStore(json) } override val profile: ProfileStore? @@ -444,14 +444,14 @@ class ProfilePlugin @Inject constructor( @Inject lateinit var config: Config @Inject lateinit var profilePlugin: ProfilePlugin @Inject lateinit var xDripBroadcast: XDripBroadcast - @Inject lateinit var profileInstantiator: ProfileInstantiator + @Inject lateinit var instantiator: Instantiator override fun doWorkAndLog(): Result { val profileJson = dataWorkerStorage.pickupJSONObject(inputData.getLong(DataWorkerStorage.STORE_KEY, -1)) ?: return Result.failure(workDataOf("Error" to "missing input data")) xDripBroadcast.sendProfile(profileJson) if (sp.getBoolean(info.nightscout.core.utils.R.string.key_ns_receive_profile_store, true) || config.NSCLIENT) { - val store = profileInstantiator.storeInstance(profileJson) + val store = instantiator.provideProfileStore(profileJson) val createdAt = store.getStartDate() val lastLocalChange = sp.getLong(info.nightscout.core.utils.R.string.key_local_profile_last_change, 0) aapsLogger.debug(LTag.PROFILE, "Received profileStore: createdAt: $createdAt Local last modification: $lastLocalChange") diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/data/ProcessedDeviceStatusDataImpl.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/data/ProcessedDeviceStatusDataImpl.kt index 9f71a1bdb2..d65d63dad4 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/data/ProcessedDeviceStatusDataImpl.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/data/ProcessedDeviceStatusDataImpl.kt @@ -1,12 +1,11 @@ package info.nightscout.plugins.sync.nsclient.data import android.text.Spanned -import dagger.Lazy import dagger.android.HasAndroidInjector import info.nightscout.interfaces.aps.APSResult -import info.nightscout.interfaces.aps.Loop import info.nightscout.interfaces.nsclient.NSSettingsStatus import info.nightscout.interfaces.nsclient.ProcessedDeviceStatusData +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.utils.HtmlHelper import info.nightscout.interfaces.utils.JsonHelper import info.nightscout.interfaces.utils.Round @@ -24,7 +23,7 @@ class ProcessedDeviceStatusDataImpl @Inject constructor( private val rh: ResourceHelper, private val dateUtil: DateUtil, private val sp: SP, - private val loop: Lazy + private val instantiator: Instantiator ) : ProcessedDeviceStatusData { override var pumpData: ProcessedDeviceStatusData.PumpData? = null @@ -116,7 +115,7 @@ class ProcessedDeviceStatusDataImpl @Inject constructor( get() = if (openAPSData.clockSuggested != 0L) openAPSData.clockSuggested else -1 override fun getAPSResult(injector: HasAndroidInjector): APSResult = - loop.get().provideEmptyAPSResultObject().also { + instantiator.provideAPSResultObject().also { it.json = openAPSData.suggested it.date = openAPSData.clockSuggested } diff --git a/pump/dana/src/main/java/info/nightscout/pump/dana/DanaPump.kt b/pump/dana/src/main/java/info/nightscout/pump/dana/DanaPump.kt index d4a6fb50d0..f266dae18e 100644 --- a/pump/dana/src/main/java/info/nightscout/pump/dana/DanaPump.kt +++ b/pump/dana/src/main/java/info/nightscout/pump/dana/DanaPump.kt @@ -2,7 +2,7 @@ package info.nightscout.pump.dana import info.nightscout.interfaces.Constants import info.nightscout.interfaces.profile.Profile -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileStore import info.nightscout.interfaces.pump.PumpSync import info.nightscout.interfaces.pump.defs.PumpType @@ -33,7 +33,7 @@ class DanaPump @Inject constructor( private val aapsLogger: AAPSLogger, private val sp: SP, private val dateUtil: DateUtil, - private val profileInstantiator: ProfileInstantiator + private val instantiator: Instantiator ) { @Suppress("unused") @@ -380,7 +380,7 @@ class DanaPump @Inject constructor( } catch (e: Exception) { return null } - return profileInstantiator.storeInstance(json) + return instantiator.provideProfileStore(json) } return null } diff --git a/pump/dana/src/test/java/info/nightscout/androidaps/dana/DanaPumpTest.kt b/pump/dana/src/test/java/info/nightscout/androidaps/dana/DanaPumpTest.kt index 2c874d7f48..7dab933399 100644 --- a/pump/dana/src/test/java/info/nightscout/androidaps/dana/DanaPumpTest.kt +++ b/pump/dana/src/test/java/info/nightscout/androidaps/dana/DanaPumpTest.kt @@ -1,10 +1,10 @@ package info.nightscout.androidaps.dana import info.nightscout.androidaps.TestBaseWithProfile -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.pump.dana.DanaPump import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -12,18 +12,18 @@ import org.mockito.Mock class DanaPumpTest : TestBaseWithProfile() { @Mock lateinit var sp: SP - @Mock lateinit var profileInstantiator: ProfileInstantiator + @Mock lateinit var instantiator: Instantiator private lateinit var sut: DanaPump @BeforeEach fun setup() { - sut = DanaPump(aapsLogger, sp, dateUtil, profileInstantiator) + sut = DanaPump(aapsLogger, sp, dateUtil, instantiator) } @Test fun detectDanaRS() { sut.hwModel = 0x05 - Assert.assertTrue(sut.modelFriendlyName().contains("DanaRS")) + Assertions.assertTrue(sut.modelFriendlyName().contains("DanaRS")) } } \ No newline at end of file diff --git a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/DanaRPluginTest.kt b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/DanaRPluginTest.kt index 88df0104e5..ad3e1b068a 100644 --- a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/DanaRPluginTest.kt +++ b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/DanaRPluginTest.kt @@ -8,14 +8,14 @@ import info.nightscout.interfaces.Constants import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.plugin.PluginType -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.pump.PumpSync import info.nightscout.interfaces.queue.CommandQueue import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.pump.dana.DanaPump import info.nightscout.pump.dana.database.DanaHistoryDatabase import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -27,7 +27,7 @@ class DanaRPluginTest : TestBaseWithProfile() { @Mock lateinit var sp: SP @Mock lateinit var commandQueue: CommandQueue @Mock lateinit var pumpSync: PumpSync - @Mock lateinit var profileInstantiator: ProfileInstantiator + @Mock lateinit var instantiator: Instantiator @Mock lateinit var uiInteraction: UiInteraction @Mock lateinit var danaHistoryDatabase: DanaHistoryDatabase @@ -47,9 +47,11 @@ class DanaRPluginTest : TestBaseWithProfile() { `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingpercentrate)).thenReturn("Limiting max percent rate to %1\$d%% because of %2\$s") - danaPump = DanaPump(aapsLogger, sp, dateUtil, profileInstantiator) - danaRPlugin = DanaRPlugin(injector, aapsLogger, aapsSchedulers, rxBus, context, rh, constraintChecker, activePluginProvider, sp, commandQueue, danaPump, dateUtil, fabricPrivacy, pumpSync, - uiInteraction, danaHistoryDatabase) + danaPump = DanaPump(aapsLogger, sp, dateUtil, instantiator) + danaRPlugin = DanaRPlugin( + injector, aapsLogger, aapsSchedulers, rxBus, context, rh, constraintChecker, activePluginProvider, sp, commandQueue, danaPump, dateUtil, fabricPrivacy, pumpSync, + uiInteraction, danaHistoryDatabase + ) } @Test @Throws(Exception::class) @@ -59,9 +61,9 @@ class DanaRPluginTest : TestBaseWithProfile() { danaPump.maxBasal = 0.8 val c = Constraint(Constants.REALLYHIGHBASALRATE) danaRPlugin.applyBasalConstraints(c, validProfile) - Assert.assertEquals(0.8, c.value(), 0.01) - Assert.assertEquals("DanaR: Limiting max basal rate to 0.80 U/h because of pump limit", c.getReasons(aapsLogger)) - Assert.assertEquals("DanaR: Limiting max basal rate to 0.80 U/h because of pump limit", c.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(0.8, c.value(), 0.01) + Assertions.assertEquals("DanaR: Limiting max basal rate to 0.80 U/h because of pump limit", c.getReasons(aapsLogger)) + Assertions.assertEquals("DanaR: Limiting max basal rate to 0.80 U/h because of pump limit", c.getMostLimitedReasons(aapsLogger)) } @Test @Throws(Exception::class) @@ -71,8 +73,8 @@ class DanaRPluginTest : TestBaseWithProfile() { danaPump.maxBasal = 0.8 val c = Constraint(Constants.REALLYHIGHPERCENTBASALRATE) danaRPlugin.applyBasalPercentConstraints(c, validProfile) - Assert.assertEquals(200, c.value()) - Assert.assertEquals("DanaR: Limiting max percent rate to 200% because of pump limit", c.getReasons(aapsLogger)) - Assert.assertEquals("DanaR: Limiting max percent rate to 200% because of pump limit", c.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(200, c.value()) + Assertions.assertEquals("DanaR: Limiting max percent rate to 200% because of pump limit", c.getReasons(aapsLogger)) + Assertions.assertEquals("DanaR: Limiting max percent rate to 200% because of pump limit", c.getMostLimitedReasons(aapsLogger)) } } \ No newline at end of file diff --git a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/comm/DanaRTestBase.kt b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/comm/DanaRTestBase.kt index 8e40bf2cae..b14fad7e87 100644 --- a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/comm/DanaRTestBase.kt +++ b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaR/comm/DanaRTestBase.kt @@ -11,8 +11,7 @@ import info.nightscout.androidaps.danar.comm.MessageBase import info.nightscout.interfaces.ConfigBuilder import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.plugin.ActivePlugin -import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.pump.DetailedBolusInfoStorage import info.nightscout.interfaces.pump.PumpSync import info.nightscout.interfaces.queue.CommandQueue @@ -33,7 +32,6 @@ import org.mockito.kotlin.doNothing open class DanaRTestBase : TestBase() { @Mock lateinit var sp: SP - @Mock lateinit var profileFunction: ProfileFunction @Mock lateinit var activePlugin: ActivePlugin @Mock lateinit var dateUtil: DateUtil @Mock lateinit var danaRPlugin: DanaRPlugin @@ -46,14 +44,14 @@ open class DanaRTestBase : TestBase() { @Mock lateinit var constraintChecker: Constraints @Mock lateinit var pumpSync: PumpSync @Mock lateinit var danaHistoryRecordDao: DanaHistoryRecordDao - @Mock lateinit var profileInstantiator: ProfileInstantiator + @Mock lateinit var instantiator: Instantiator @Mock lateinit var uiInteraction: UiInteraction private lateinit var testPumpPlugin: TestPumpPlugin @BeforeEach fun setup() { - danaPump = DanaPump(aapsLogger, sp, dateUtil, profileInstantiator) + danaPump = DanaPump(aapsLogger, sp, dateUtil, instantiator) testPumpPlugin = TestPumpPlugin(injector) `when`(activePlugin.activePump).thenReturn(testPumpPlugin) doNothing().`when`(danaRKoreanPlugin).setPluginEnabled(anyObject(), anyBoolean()) diff --git a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt index 6079c62d6a..2c593f191a 100644 --- a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt +++ b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRKorean/DanaRKoreanPluginTest.kt @@ -8,14 +8,14 @@ import info.nightscout.interfaces.Constants import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.plugin.PluginType -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.pump.PumpSync import info.nightscout.interfaces.queue.CommandQueue import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.pump.dana.DanaPump import info.nightscout.pump.dana.database.DanaHistoryDatabase import info.nightscout.shared.sharedPreferences.SP -import org.junit.Assert +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -27,7 +27,7 @@ class DanaRKoreanPluginTest : TestBaseWithProfile() { @Mock lateinit var sp: SP @Mock lateinit var commandQueue: CommandQueue @Mock lateinit var pumpSync: PumpSync - @Mock lateinit var profileInstantiator: ProfileInstantiator + @Mock lateinit var instantiator: Instantiator @Mock lateinit var uiInteraction: UiInteraction @Mock lateinit var danaHistoryDatabase: DanaHistoryDatabase @@ -47,7 +47,7 @@ class DanaRKoreanPluginTest : TestBaseWithProfile() { `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingpercentrate)).thenReturn("Limiting max percent rate to %1\$d%% because of %2\$s") - danaPump = DanaPump(aapsLogger, sp, dateUtil, profileInstantiator) + danaPump = DanaPump(aapsLogger, sp, dateUtil, instantiator) danaRPlugin = DanaRKoreanPlugin(injector, aapsLogger, aapsSchedulers, rxBus, context, rh, constraintChecker, activePluginProvider, sp, commandQueue, danaPump, dateUtil, fabricPrivacy, pumpSync, uiInteraction, danaHistoryDatabase) } @@ -59,9 +59,9 @@ class DanaRKoreanPluginTest : TestBaseWithProfile() { danaPump.maxBasal = 0.8 val c = Constraint(Constants.REALLYHIGHBASALRATE) danaRPlugin.applyBasalConstraints(c, validProfile) - Assert.assertEquals(0.8, c.value(), 0.01) - Assert.assertEquals("DanaRKorean: Limiting max basal rate to 0.80 U/h because of pump limit", c.getReasons(aapsLogger)) - Assert.assertEquals("DanaRKorean: Limiting max basal rate to 0.80 U/h because of pump limit", c.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(0.8, c.value(), 0.01) + Assertions.assertEquals("DanaRKorean: Limiting max basal rate to 0.80 U/h because of pump limit", c.getReasons(aapsLogger)) + Assertions.assertEquals("DanaRKorean: Limiting max basal rate to 0.80 U/h because of pump limit", c.getMostLimitedReasons(aapsLogger)) } @Test @Throws(Exception::class) @@ -71,8 +71,8 @@ class DanaRKoreanPluginTest : TestBaseWithProfile() { danaPump.maxBasal = 0.8 val c = Constraint(Constants.REALLYHIGHPERCENTBASALRATE) danaRPlugin.applyBasalPercentConstraints(c, validProfile) - Assert.assertEquals(200, c.value()) - Assert.assertEquals("DanaRKorean: Limiting max percent rate to 200% because of pump limit", c.getReasons(aapsLogger)) - Assert.assertEquals("DanaRKorean: Limiting max percent rate to 200% because of pump limit", c.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(200, c.value()) + Assertions.assertEquals("DanaRKorean: Limiting max percent rate to 200% because of pump limit", c.getReasons(aapsLogger)) + Assertions.assertEquals("DanaRKorean: Limiting max percent rate to 200% because of pump limit", c.getMostLimitedReasons(aapsLogger)) } } \ No newline at end of file diff --git a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRv2/DanaRv2PluginTest.kt b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRv2/DanaRv2PluginTest.kt index 06ed276026..39fb63ab9b 100644 --- a/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRv2/DanaRv2PluginTest.kt +++ b/pump/danar/src/test/java/info/nightscout/androidaps/plugins/pump/danaRv2/DanaRv2PluginTest.kt @@ -8,7 +8,7 @@ import info.nightscout.interfaces.Constants import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints import info.nightscout.interfaces.plugin.PluginType -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.pump.DetailedBolusInfoStorage import info.nightscout.interfaces.pump.PumpSync import info.nightscout.interfaces.pump.TemporaryBasalStorage @@ -17,6 +17,7 @@ import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.pump.dana.DanaPump import info.nightscout.pump.dana.database.DanaHistoryDatabase import info.nightscout.shared.sharedPreferences.SP +import org.junit.jupiter.api.Assertions import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test import org.mockito.Mock @@ -30,7 +31,7 @@ class DanaRv2PluginTest : TestBaseWithProfile() { @Mock lateinit var detailedBolusInfoStorage: DetailedBolusInfoStorage @Mock lateinit var temporaryBasalStorage: TemporaryBasalStorage @Mock lateinit var pumpSync: PumpSync - @Mock lateinit var profileInstantiator: ProfileInstantiator + @Mock lateinit var instantiator: Instantiator @Mock lateinit var uiInteraction: UiInteraction @Mock lateinit var danaHistoryDatabase: DanaHistoryDatabase @@ -50,7 +51,7 @@ class DanaRv2PluginTest : TestBaseWithProfile() { `when`(rh.gs(info.nightscout.core.ui.R.string.itmustbepositivevalue)).thenReturn("it must be positive value") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingbasalratio)).thenReturn("Limiting max basal rate to %1\$.2f U/h because of %2\$s") `when`(rh.gs(info.nightscout.core.ui.R.string.limitingpercentrate)).thenReturn("Limiting max percent rate to %1\$d%% because of %2\$s") - danaPump = DanaPump(aapsLogger, sp, dateUtil, profileInstantiator) + danaPump = DanaPump(aapsLogger, sp, dateUtil, instantiator) danaRv2Plugin = DanaRv2Plugin( injector, aapsLogger, aapsSchedulers, rxBus, context, rh, constraintChecker, activePluginProvider, sp, commandQueue, danaPump, detailedBolusInfoStorage, temporaryBasalStorage, dateUtil, fabricPrivacy, pumpSync, uiInteraction, danaHistoryDatabase @@ -64,9 +65,9 @@ class DanaRv2PluginTest : TestBaseWithProfile() { danaPump.maxBasal = 0.8 val c = Constraint(Constants.REALLYHIGHBASALRATE) danaRv2Plugin.applyBasalConstraints(c, validProfile) - org.junit.Assert.assertEquals(0.8, c.value(), 0.01) - org.junit.Assert.assertEquals("DanaRv2: Limiting max basal rate to 0.80 U/h because of pump limit", c.getReasons(aapsLogger)) - org.junit.Assert.assertEquals("DanaRv2: Limiting max basal rate to 0.80 U/h because of pump limit", c.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(0.8, c.value(), 0.01) + Assertions.assertEquals("DanaRv2: Limiting max basal rate to 0.80 U/h because of pump limit", c.getReasons(aapsLogger)) + Assertions.assertEquals("DanaRv2: Limiting max basal rate to 0.80 U/h because of pump limit", c.getMostLimitedReasons(aapsLogger)) } @Test @@ -76,8 +77,8 @@ class DanaRv2PluginTest : TestBaseWithProfile() { danaPump.maxBasal = 0.8 val c = Constraint(Constants.REALLYHIGHPERCENTBASALRATE) danaRv2Plugin.applyBasalPercentConstraints(c, validProfile) - org.junit.Assert.assertEquals(200, c.value()) - org.junit.Assert.assertEquals("DanaRv2: Limiting max percent rate to 200% because of pump limit", c.getReasons(aapsLogger)) - org.junit.Assert.assertEquals("DanaRv2: Limiting max percent rate to 200% because of pump limit", c.getMostLimitedReasons(aapsLogger)) + Assertions.assertEquals(200, c.value()) + Assertions.assertEquals("DanaRv2: Limiting max percent rate to 200% because of pump limit", c.getReasons(aapsLogger)) + Assertions.assertEquals("DanaRv2: Limiting max percent rate to 200% because of pump limit", c.getMostLimitedReasons(aapsLogger)) } } \ No newline at end of file diff --git a/pump/danars/src/test/java/info/nightscout/pump/danars/DanaRSTestBase.kt b/pump/danars/src/test/java/info/nightscout/pump/danars/DanaRSTestBase.kt index 49ca424f53..19881b22a2 100644 --- a/pump/danars/src/test/java/info/nightscout/pump/danars/DanaRSTestBase.kt +++ b/pump/danars/src/test/java/info/nightscout/pump/danars/DanaRSTestBase.kt @@ -1,9 +1,7 @@ package info.nightscout.pump.danars -import dagger.android.AndroidInjector -import dagger.android.HasAndroidInjector import info.nightscout.androidaps.TestBaseWithProfile -import info.nightscout.interfaces.profile.ProfileInstantiator +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.pump.dana.DanaPump import info.nightscout.pump.danars.comm.DanaRSPacket @@ -16,11 +14,9 @@ import org.mockito.Mockito open class DanaRSTestBase : TestBaseWithProfile() { @Mock lateinit var sp: SP - @Mock lateinit var profileInstantiator: ProfileInstantiator + @Mock lateinit var instantiator: Instantiator @Mock lateinit var uiInteraction: UiInteraction - val injector = HasAndroidInjector { AndroidInjector { } } - lateinit var danaPump: DanaPump @BeforeEach @@ -58,6 +54,6 @@ open class DanaRSTestBase : TestBaseWithProfile() { @BeforeEach fun setup() { - danaPump = DanaPump(aapsLogger, sp, dateUtil, profileInstantiator) + danaPump = DanaPump(aapsLogger, sp, dateUtil, instantiator) } } \ No newline at end of file diff --git a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt index fa06f39be7..95657f8da3 100644 --- a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt +++ b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt @@ -19,6 +19,7 @@ import info.nightscout.interfaces.aps.AutosensData import info.nightscout.interfaces.aps.SMBDefaults import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.profiling.Profiler import info.nightscout.interfaces.utils.DecimalFormatter @@ -56,6 +57,7 @@ class IobCobOref1Worker( @Inject lateinit var dateUtil: DateUtil @Inject lateinit var repository: AppRepository @Inject lateinit var dataWorkerStorage: DataWorkerStorage + @Inject lateinit var instantiator: Instantiator class IobCobOref1WorkerData( val injector: HasAndroidInjector, @@ -114,7 +116,7 @@ class IobCobOref1Worker( } aapsLogger.debug(LTag.AUTOSENS, "Processing calculation thread: ${data.reason} ($i/${bucketedData.size})") val sens = profile.getIsfMgdl(bgTime) - val autosensData = data.iobCobCalculator.provideEmptyAutosensDataObject() + val autosensData = instantiator.provideAutosensDataObject() autosensData.time = bgTime if (previous != null) autosensData.activeCarbsList = previous.cloneCarbsList() else autosensData.activeCarbsList = ArrayList() diff --git a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt index d371a78f74..39b02048fe 100644 --- a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt +++ b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt @@ -17,6 +17,7 @@ import info.nightscout.interfaces.aps.AutosensData import info.nightscout.interfaces.aps.SMBDefaults import info.nightscout.interfaces.iob.IobCobCalculator import info.nightscout.interfaces.plugin.ActivePlugin +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.profiling.Profiler import info.nightscout.interfaces.utils.DecimalFormatter @@ -52,6 +53,7 @@ class IobCobOrefWorker @Inject internal constructor( @Inject lateinit var dateUtil: DateUtil @Inject lateinit var repository: AppRepository @Inject lateinit var dataWorkerStorage: DataWorkerStorage + @Inject lateinit var instantiator: Instantiator class IobCobOrefWorkerData( val injector: HasAndroidInjector, @@ -109,7 +111,7 @@ class IobCobOrefWorker @Inject internal constructor( } aapsLogger.debug(LTag.AUTOSENS, "Processing calculation thread: ${data.reason} ($i/${bucketedData.size})") val sens = profile.getIsfMgdl(bgTime) - val autosensData = data.iobCobCalculator.provideEmptyAutosensDataObject() + val autosensData = instantiator.provideAutosensDataObject() autosensData.time = bgTime if (previous != null) autosensData.activeCarbsList = previous.cloneCarbsList() else autosensData.activeCarbsList = ArrayList() From cf254c5c72b8c73d9bbd58ec3370bb5ebcc0e6e4 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 17:23:17 +0100 Subject: [PATCH 24/48] 3.1.0.3-dev-e --- app/build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/build.gradle b/app/build.gradle index 8fe98aa880..25a419aac7 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -111,7 +111,7 @@ android { defaultConfig { multiDexEnabled true versionCode 1500 - version "3.1.0.3-dev-d" + version "3.1.0.3-dev-e" buildConfigField "String", "VERSION", '"' + version + '"' buildConfigField "String", "BUILDVERSION", '"' + generateGitBuild() + '-' + generateDate() + '"' buildConfigField "String", "REMOTE", '"' + generateGitRemote() + '"' From 30e7e5ed77bc64c1d40bbf073200b76e8ec5a6ce Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 17:50:33 +0100 Subject: [PATCH 25/48] New Crowdin updates (#2269) * New translations strings.xml (German) * New translations strings.xml (Hebrew) * New translations strings.xml (Italian) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Romanian) * New translations strings.xml (French) * New translations strings.xml (Spanish) * New translations strings.xml (Bulgarian) * New translations strings.xml (Catalan) * New translations strings.xml (Czech) * New translations strings.xml (Danish) * New translations strings.xml (German) * New translations strings.xml (Hebrew) * New translations strings.xml (Hungarian) * New translations strings.xml (Italian) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Croatian) * New translations strings.xml (Romanian) * New translations strings.xml (French) * New translations strings.xml (Spanish) * New translations strings.xml (Afrikaans) * New translations strings.xml (Bulgarian) * New translations strings.xml (Catalan) * New translations strings.xml (Czech) * New translations strings.xml (Danish) * New translations strings.xml (German) * New translations strings.xml (Greek) * New translations strings.xml (Irish) * New translations strings.xml (Hebrew) * New translations strings.xml (Hungarian) * New translations strings.xml (Italian) * New translations strings.xml (Japanese) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Croatian) * New translations strings.xml (Serbian (Latin)) * New translations strings.xml (Czech) * New translations strings.xml (Norwegian) * New translations strings.xml (Norwegian) * Update source file strings.xml * Update source file strings.xml * New translations strings.xml (Romanian) * New translations strings.xml (French) * New translations strings.xml (Spanish) * New translations strings.xml (Afrikaans) * New translations strings.xml (Bulgarian) * New translations strings.xml (Catalan) * New translations strings.xml (Czech) * New translations strings.xml (Danish) * New translations strings.xml (German) * New translations strings.xml (Greek) * New translations strings.xml (Irish) * New translations strings.xml (Hebrew) * New translations strings.xml (Hungarian) * New translations strings.xml (Italian) * New translations strings.xml (Japanese) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Croatian) * New translations strings.xml (Serbian (Latin)) * New translations strings.xml (Romanian) * New translations strings.xml (French) * New translations strings.xml (Spanish) * New translations strings.xml (Afrikaans) * New translations strings.xml (Bulgarian) * New translations strings.xml (Catalan) * New translations strings.xml (Czech) * New translations strings.xml (Danish) * New translations strings.xml (German) * New translations strings.xml (Greek) * New translations strings.xml (Irish) * New translations strings.xml (Hebrew) * New translations strings.xml (Hungarian) * New translations strings.xml (Italian) * New translations strings.xml (Japanese) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Croatian) * New translations strings.xml (Serbian (Latin)) * Update source file strings.xml * Update source file strings.xml * Update source file strings.xml * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Romanian) * New translations strings.xml (French) * New translations strings.xml (Spanish) * New translations strings.xml (Afrikaans) * New translations strings.xml (Bulgarian) * New translations strings.xml (Catalan) * New translations strings.xml (Czech) * New translations strings.xml (Danish) * New translations strings.xml (German) * New translations strings.xml (Greek) * New translations strings.xml (Irish) * New translations strings.xml (Hebrew) * New translations strings.xml (Hungarian) * New translations strings.xml (Italian) * New translations strings.xml (Japanese) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Croatian) * New translations strings.xml (Serbian (Latin)) * New translations protection.xml (Portuguese, Brazilian) * New translations strings.xml (French) * New translations strings.xml (Spanish) * New translations strings.xml (Afrikaans) * New translations strings.xml (Bulgarian) * New translations strings.xml (Catalan) * New translations strings.xml (Czech) * New translations strings.xml (Danish) * New translations strings.xml (German) * New translations strings.xml (Greek) * New translations strings.xml (Irish) * New translations strings.xml (Hebrew) * New translations strings.xml (Hungarian) * New translations strings.xml (Italian) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Croatian) * New translations strings.xml (Serbian (Latin)) * New translations strings.xml (Romanian) * New translations strings.xml (French) * New translations strings.xml (Spanish) * New translations strings.xml (Afrikaans) * New translations strings.xml (Bulgarian) * New translations strings.xml (Catalan) * New translations strings.xml (Czech) * New translations strings.xml (Danish) * New translations strings.xml (German) * New translations strings.xml (Greek) * New translations strings.xml (Irish) * New translations strings.xml (Hebrew) * New translations strings.xml (Hungarian) * New translations strings.xml (Italian) * New translations strings.xml (Japanese) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Croatian) * New translations strings.xml (Serbian (Latin)) * New translations strings.xml (Romanian) * New translations strings.xml (French) * New translations strings.xml (Spanish) * New translations strings.xml (Afrikaans) * New translations strings.xml (Bulgarian) * New translations strings.xml (Catalan) * New translations strings.xml (Czech) * New translations strings.xml (Danish) * New translations strings.xml (German) * New translations strings.xml (Greek) * New translations strings.xml (Irish) * New translations strings.xml (Hebrew) * New translations strings.xml (Hungarian) * New translations strings.xml (Italian) * New translations strings.xml (Japanese) * New translations strings.xml (Korean) * New translations strings.xml (Lithuanian) * New translations strings.xml (Dutch) * New translations strings.xml (Norwegian) * New translations strings.xml (Polish) * New translations strings.xml (Portuguese) * New translations strings.xml (Russian) * New translations strings.xml (Slovak) * New translations strings.xml (Swedish) * New translations strings.xml (Turkish) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) * New translations strings.xml (Croatian) * New translations strings.xml (Serbian (Latin)) --- app/src/main/res/values-bg-rBG/strings.xml | 1 - app/src/main/res/values-ca-rES/strings.xml | 1 - app/src/main/res/values-cs-rCZ/strings.xml | 1 - app/src/main/res/values-da-rDK/strings.xml | 1 - app/src/main/res/values-de-rDE/strings.xml | 1 - app/src/main/res/values-es-rES/strings.xml | 1 - app/src/main/res/values-fr-rFR/strings.xml | 1 - app/src/main/res/values-it-rIT/strings.xml | 1 - app/src/main/res/values-iw-rIL/strings.xml | 1 - app/src/main/res/values-ko-rKR/strings.xml | 1 - app/src/main/res/values-lt-rLT/strings.xml | 1 - app/src/main/res/values-nl-rNL/strings.xml | 1 - app/src/main/res/values-no-rNO/strings.xml | 1 - app/src/main/res/values-pl-rPL/strings.xml | 1 - app/src/main/res/values-pt-rBR/strings.xml | 1 - app/src/main/res/values-pt-rPT/strings.xml | 1 - app/src/main/res/values-ro-rRO/strings.xml | 1 - app/src/main/res/values-ru-rRU/strings.xml | 1 - app/src/main/res/values-sk-rSK/strings.xml | 1 - app/src/main/res/values-sv-rSE/strings.xml | 1 - app/src/main/res/values-tr-rTR/strings.xml | 1 - app/src/main/res/values-zh-rCN/strings.xml | 1 - .../ui/src/main/res/values-af-rZA/strings.xml | 1 + .../ui/src/main/res/values-bg-rBG/strings.xml | 1 + .../ui/src/main/res/values-ca-rES/strings.xml | 3 + .../ui/src/main/res/values-cs-rCZ/strings.xml | 3 + .../ui/src/main/res/values-da-rDK/strings.xml | 3 + .../ui/src/main/res/values-de-rDE/strings.xml | 5 ++ .../ui/src/main/res/values-el-rGR/strings.xml | 1 + .../ui/src/main/res/values-es-rES/strings.xml | 3 + .../ui/src/main/res/values-fr-rFR/strings.xml | 3 + .../ui/src/main/res/values-hr-rHR/strings.xml | 1 + .../ui/src/main/res/values-it-rIT/strings.xml | 3 + .../ui/src/main/res/values-iw-rIL/strings.xml | 3 + .../ui/src/main/res/values-ko-rKR/strings.xml | 3 + .../ui/src/main/res/values-lt-rLT/strings.xml | 3 + .../ui/src/main/res/values-nl-rNL/strings.xml | 3 + .../ui/src/main/res/values-no-rNO/strings.xml | 3 + .../ui/src/main/res/values-pl-rPL/strings.xml | 3 + .../src/main/res/values-pt-rBR/protection.xml | 13 +++ .../ui/src/main/res/values-pt-rBR/strings.xml | 27 ++++++ .../ui/src/main/res/values-pt-rPT/strings.xml | 3 + .../ui/src/main/res/values-ro-rRO/strings.xml | 3 + .../ui/src/main/res/values-ru-rRU/strings.xml | 3 + .../ui/src/main/res/values-sk-rSK/strings.xml | 3 + .../ui/src/main/res/values-sv-rSE/strings.xml | 3 + .../ui/src/main/res/values-tr-rTR/strings.xml | 3 + .../ui/src/main/res/values-zh-rCN/strings.xml | 3 + .../src/main/res/values-bg-rBG/strings.xml | 2 - .../src/main/res/values-ca-rES/strings.xml | 2 - .../src/main/res/values-cs-rCZ/strings.xml | 2 - .../src/main/res/values-da-rDK/strings.xml | 2 - .../src/main/res/values-de-rDE/strings.xml | 2 - .../src/main/res/values-es-rES/strings.xml | 2 - .../src/main/res/values-fr-rFR/strings.xml | 2 - .../src/main/res/values-hr-rHR/strings.xml | 2 - .../src/main/res/values-hu-rHU/strings.xml | 1 - .../src/main/res/values-it-rIT/strings.xml | 1 - .../src/main/res/values-iw-rIL/strings.xml | 2 - .../src/main/res/values-ko-rKR/strings.xml | 1 - .../src/main/res/values-lt-rLT/strings.xml | 2 - .../src/main/res/values-nl-rNL/strings.xml | 2 - .../src/main/res/values-no-rNO/strings.xml | 2 - .../src/main/res/values-pl-rPL/strings.xml | 2 - .../src/main/res/values-pt-rBR/strings.xml | 2 - .../src/main/res/values-pt-rPT/strings.xml | 2 - .../src/main/res/values-ro-rRO/strings.xml | 2 - .../src/main/res/values-ru-rRU/strings.xml | 2 - .../src/main/res/values-sk-rSK/strings.xml | 2 - .../src/main/res/values-sv-rSE/strings.xml | 2 - .../src/main/res/values-tr-rTR/strings.xml | 2 - .../src/main/res/values-zh-rCN/strings.xml | 2 - .../src/main/res/values-af-rZA/strings.xml | 1 + .../src/main/res/values-bg-rBG/strings.xml | 2 + .../src/main/res/values-ca-rES/strings.xml | 2 + .../src/main/res/values-cs-rCZ/strings.xml | 3 + .../src/main/res/values-da-rDK/strings.xml | 2 + .../src/main/res/values-de-rDE/strings.xml | 2 + .../src/main/res/values-el-rGR/strings.xml | 1 + .../src/main/res/values-es-rES/strings.xml | 3 + .../src/main/res/values-fr-rFR/strings.xml | 2 + .../src/main/res/values-ga-rIE/strings.xml | 1 + .../src/main/res/values-hr-rHR/strings.xml | 2 + .../src/main/res/values-hu-rHU/strings.xml | 1 + .../src/main/res/values-it-rIT/strings.xml | 2 + .../src/main/res/values-iw-rIL/strings.xml | 2 + .../src/main/res/values-ja-rJP/strings.xml | 1 + .../src/main/res/values-ko-rKR/strings.xml | 1 + .../src/main/res/values-lt-rLT/strings.xml | 2 + .../src/main/res/values-nl-rNL/strings.xml | 2 + .../src/main/res/values-no-rNO/strings.xml | 3 + .../src/main/res/values-pl-rPL/strings.xml | 2 + .../src/main/res/values-pt-rBR/strings.xml | 2 + .../src/main/res/values-pt-rPT/strings.xml | 2 + .../src/main/res/values-ro-rRO/strings.xml | 2 + .../src/main/res/values-ru-rRU/strings.xml | 2 + .../src/main/res/values-sk-rSK/strings.xml | 2 + .../src/main/res/values-sr-rCS/strings.xml | 1 + .../src/main/res/values-sv-rSE/strings.xml | 2 + .../src/main/res/values-tr-rTR/strings.xml | 2 + .../src/main/res/values-zh-rCN/strings.xml | 2 + .../src/main/res/values-af-rZA/exam.xml | 21 ----- .../src/main/res/values-af-rZA/strings.xml | 24 ++++- .../src/main/res/values-bg-rBG/strings.xml | 34 ++++--- .../src/main/res/values-ca-rES/exam.xml | 5 -- .../src/main/res/values-ca-rES/strings.xml | 35 +++++--- .../src/main/res/values-cs-rCZ/exam.xml | 2 - .../src/main/res/values-cs-rCZ/strings.xml | 32 ++++++- .../src/main/res/values-da-rDK/exam.xml | 3 - .../src/main/res/values-da-rDK/strings.xml | 37 +++++--- .../src/main/res/values-de-rDE/exam.xml | 8 +- .../src/main/res/values-de-rDE/strings.xml | 36 +++++--- .../src/main/res/values-el-rGR/exam.xml | 11 --- .../src/main/res/values-el-rGR/strings.xml | 24 ++++- .../src/main/res/values-es-rES/exam.xml | 2 - .../src/main/res/values-es-rES/strings.xml | 32 ++++++- .../src/main/res/values-fr-rFR/exam.xml | 2 - .../src/main/res/values-fr-rFR/strings.xml | 43 ++++++--- .../src/main/res/values-ga-rIE/exam.xml | 4 +- .../src/main/res/values-ga-rIE/objectives.xml | 1 - .../src/main/res/values-ga-rIE/strings.xml | 4 + .../src/main/res/values-hr-rHR/exam.xml | 25 ------ .../src/main/res/values-hr-rHR/objectives.xml | 4 - .../src/main/res/values-hr-rHR/strings.xml | 21 ++--- .../src/main/res/values-hu-rHU/exam.xml | 4 +- .../src/main/res/values-hu-rHU/strings.xml | 7 +- .../src/main/res/values-it-rIT/exam.xml | 3 - .../src/main/res/values-it-rIT/strings.xml | 38 +++++--- .../src/main/res/values-iw-rIL/exam.xml | 3 - .../src/main/res/values-iw-rIL/strings.xml | 37 +++++--- .../src/main/res/values-ja-rJP/strings.xml | 2 + .../src/main/res/values-ko-rKR/exam.xml | 5 -- .../src/main/res/values-ko-rKR/strings.xml | 31 +++++-- .../src/main/res/values-lt-rLT/exam.xml | 5 -- .../src/main/res/values-lt-rLT/strings.xml | 35 +++++--- .../src/main/res/values-nl-rNL/exam.xml | 3 - .../src/main/res/values-nl-rNL/strings.xml | 41 ++++++--- .../src/main/res/values-no-rNO/exam.xml | 2 - .../src/main/res/values-no-rNO/strings.xml | 35 +++++++- .../src/main/res/values-pl-rPL/exam.xml | 5 -- .../src/main/res/values-pl-rPL/strings.xml | 35 +++++--- .../src/main/res/values-pt-rBR/exam.xml | 3 - .../src/main/res/values-pt-rBR/strings.xml | 40 ++++++--- .../src/main/res/values-pt-rPT/exam.xml | 5 -- .../src/main/res/values-pt-rPT/strings.xml | 35 +++++--- .../src/main/res/values-ro-rRO/exam.xml | 5 -- .../src/main/res/values-ro-rRO/strings.xml | 35 +++++--- .../src/main/res/values-ru-rRU/exam.xml | 3 - .../src/main/res/values-ru-rRU/strings.xml | 41 ++++++--- .../src/main/res/values-sk-rSK/exam.xml | 2 - .../src/main/res/values-sk-rSK/strings.xml | 42 ++++++--- .../src/main/res/values-sr-rCS/strings.xml | 4 + .../src/main/res/values-sv-rSE/exam.xml | 5 -- .../src/main/res/values-sv-rSE/strings.xml | 37 +++++--- .../src/main/res/values-tr-rTR/exam.xml | 2 - .../src/main/res/values-tr-rTR/strings.xml | 25 +++--- .../src/main/res/values-zh-rCN/exam.xml | 3 - .../src/main/res/values-zh-rCN/strings.xml | 37 +++++--- .../src/main/res/values-af-rZA/strings.xml | 13 +++ .../src/main/res/values-bg-rBG/strings.xml | 15 ++++ .../src/main/res/values-ca-rES/strings.xml | 15 ++++ .../src/main/res/values-cs-rCZ/strings.xml | 18 ++++ .../src/main/res/values-da-rDK/strings.xml | 15 ++++ .../src/main/res/values-de-rDE/strings.xml | 15 ++++ .../src/main/res/values-el-rGR/strings.xml | 14 +++ .../src/main/res/values-es-rES/strings.xml | 18 ++++ .../src/main/res/values-fr-rFR/strings.xml | 8 ++ .../src/main/res/values-ga-rIE/strings.xml | 8 ++ .../src/main/res/values-hr-rHR/strings.xml | 18 ++++ .../src/main/res/values-hu-rHU/strings.xml | 5 ++ .../src/main/res/values-it-rIT/strings.xml | 18 ++++ .../src/main/res/values-iw-rIL/strings.xml | 15 ++++ .../src/main/res/values-ja-rJP/strings.xml | 4 + .../src/main/res/values-ko-rKR/strings.xml | 15 ++++ .../src/main/res/values-lt-rLT/strings.xml | 15 ++++ .../src/main/res/values-nl-rNL/strings.xml | 18 ++++ .../src/main/res/values-no-rNO/strings.xml | 18 ++++ .../src/main/res/values-pl-rPL/strings.xml | 15 ++++ .../src/main/res/values-pt-rBR/strings.xml | 15 ++++ .../src/main/res/values-pt-rPT/strings.xml | 15 ++++ .../src/main/res/values-ro-rRO/strings.xml | 4 + .../src/main/res/values-ru-rRU/strings.xml | 18 ++++ .../src/main/res/values-sk-rSK/strings.xml | 18 ++++ .../src/main/res/values-sr-rCS/strings.xml | 8 ++ .../src/main/res/values-sv-rSE/strings.xml | 15 ++++ .../src/main/res/values-tr-rTR/strings.xml | 11 +++ .../src/main/res/values-zh-rCN/strings.xml | 15 ++++ .../src/main/res/values-af-rZA/strings.xml | 67 -------------- .../src/main/res/values-bg-rBG/strings.xml | 80 ----------------- .../src/main/res/values-ca-rES/strings.xml | 81 ----------------- .../src/main/res/values-cs-rCZ/strings.xml | 90 +------------------ .../src/main/res/values-da-rDK/strings.xml | 86 ------------------ .../src/main/res/values-de-rDE/strings.xml | 85 ------------------ .../src/main/res/values-el-rGR/strings.xml | 68 -------------- .../src/main/res/values-es-rES/strings.xml | 88 ------------------ .../src/main/res/values-fr-rFR/strings.xml | 88 ------------------ .../src/main/res/values-ga-rIE/strings.xml | 25 ------ .../src/main/res/values-hr-rHR/strings.xml | 45 ---------- .../src/main/res/values-hu-rHU/strings.xml | 20 ----- .../src/main/res/values-it-rIT/strings.xml | 87 ------------------ .../src/main/res/values-iw-rIL/strings.xml | 87 ------------------ .../src/main/res/values-ja-rJP/strings.xml | 5 -- .../src/main/res/values-ko-rKR/strings.xml | 75 ---------------- .../src/main/res/values-lt-rLT/strings.xml | 86 ------------------ .../src/main/res/values-nl-rNL/strings.xml | 88 ------------------ .../src/main/res/values-no-rNO/strings.xml | 88 ------------------ .../src/main/res/values-pl-rPL/strings.xml | 81 ----------------- .../src/main/res/values-pt-rBR/strings.xml | 87 ------------------ .../src/main/res/values-pt-rPT/strings.xml | 81 ----------------- .../src/main/res/values-ro-rRO/strings.xml | 81 ----------------- .../src/main/res/values-ru-rRU/strings.xml | 88 ------------------ .../src/main/res/values-sk-rSK/strings.xml | 88 ------------------ .../src/main/res/values-sr-rCS/strings.xml | 20 ----- .../src/main/res/values-sv-rSE/strings.xml | 82 ----------------- .../src/main/res/values-tr-rTR/strings.xml | 88 ------------------ .../src/main/res/values-zh-rCN/strings.xml | 84 ----------------- .../src/main/res/values-af-rZA/strings.xml | 15 ++++ .../src/main/res/values-bg-rBG/strings.xml | 21 +++++ .../src/main/res/values-ca-rES/strings.xml | 22 +++++ .../src/main/res/values-cs-rCZ/strings.xml | 39 ++++++++ .../src/main/res/values-da-rDK/strings.xml | 26 ++++++ .../src/main/res/values-de-rDE/strings.xml | 26 ++++++ .../src/main/res/values-el-rGR/strings.xml | 15 ++++ .../src/main/res/values-es-rES/strings.xml | 38 ++++++++ .../src/main/res/values-fr-rFR/strings.xml | 38 ++++++++ .../src/main/res/values-ga-rIE/strings.xml | 11 +++ .../src/main/res/values-hr-rHR/strings.xml | 13 +++ .../src/main/res/values-hu-rHU/strings.xml | 7 ++ .../src/main/res/values-it-rIT/strings.xml | 38 ++++++++ .../src/main/res/values-iw-rIL/strings.xml | 26 ++++++ .../src/main/res/values-ja-rJP/strings.xml | 4 + .../src/main/res/values-ko-rKR/strings.xml | 17 ++++ .../src/main/res/values-lt-rLT/strings.xml | 27 ++++++ .../src/main/res/values-nl-rNL/strings.xml | 31 +++++++ .../src/main/res/values-no-rNO/strings.xml | 38 ++++++++ .../src/main/res/values-pl-rPL/strings.xml | 22 +++++ .../src/main/res/values-pt-rBR/strings.xml | 26 ++++++ .../src/main/res/values-pt-rPT/strings.xml | 22 +++++ .../src/main/res/values-ro-rRO/strings.xml | 22 +++++ .../src/main/res/values-ru-rRU/strings.xml | 33 +++++++ .../src/main/res/values-sk-rSK/strings.xml | 38 ++++++++ .../src/main/res/values-sr-rCS/strings.xml | 10 +++ .../src/main/res/values-sv-rSE/strings.xml | 23 +++++ .../src/main/res/values-tr-rTR/strings.xml | 38 ++++++++ .../src/main/res/values-zh-rCN/strings.xml | 24 +++++ .../src/main/res/values-cs-rCZ/strings.xml | 3 + .../src/main/res/values-es-rES/strings.xml | 3 + .../src/main/res/values-no-rNO/strings.xml | 3 + .../src/main/res/values-af-rZA/strings.xml | 6 ++ .../src/main/res/values-bg-rBG/strings.xml | 6 ++ .../src/main/res/values-ca-rES/strings.xml | 6 ++ .../src/main/res/values-cs-rCZ/strings.xml | 11 +++ .../src/main/res/values-da-rDK/strings.xml | 6 ++ .../src/main/res/values-de-rDE/strings.xml | 6 ++ .../src/main/res/values-el-rGR/strings.xml | 6 ++ .../src/main/res/values-es-rES/strings.xml | 10 +++ .../src/main/res/values-fr-rFR/strings.xml | 10 +++ .../src/main/res/values-ga-rIE/strings.xml | 4 + .../src/main/res/values-hr-rHR/strings.xml | 9 ++ .../src/main/res/values-hu-rHU/strings.xml | 4 + .../src/main/res/values-it-rIT/strings.xml | 10 +++ .../src/main/res/values-iw-rIL/strings.xml | 6 ++ .../src/main/res/values-ja-rJP/strings.xml | 4 + .../src/main/res/values-ko-rKR/strings.xml | 6 ++ .../src/main/res/values-lt-rLT/strings.xml | 6 ++ .../src/main/res/values-nl-rNL/strings.xml | 10 +++ .../src/main/res/values-no-rNO/strings.xml | 10 +++ .../src/main/res/values-pl-rPL/strings.xml | 6 ++ .../src/main/res/values-pt-rBR/strings.xml | 6 ++ .../src/main/res/values-pt-rPT/strings.xml | 6 ++ .../src/main/res/values-ro-rRO/strings.xml | 6 ++ .../src/main/res/values-ru-rRU/strings.xml | 6 ++ .../src/main/res/values-sk-rSK/strings.xml | 10 +++ .../src/main/res/values-sr-rCS/strings.xml | 5 ++ .../src/main/res/values-sv-rSE/strings.xml | 6 ++ .../src/main/res/values-tr-rTR/strings.xml | 10 +++ .../src/main/res/values-zh-rCN/strings.xml | 6 ++ 277 files changed, 2103 insertions(+), 2589 deletions(-) create mode 100644 plugins/insulin/src/main/res/values-af-rZA/strings.xml create mode 100644 plugins/insulin/src/main/res/values-bg-rBG/strings.xml create mode 100644 plugins/insulin/src/main/res/values-ca-rES/strings.xml create mode 100644 plugins/insulin/src/main/res/values-cs-rCZ/strings.xml create mode 100644 plugins/insulin/src/main/res/values-da-rDK/strings.xml create mode 100644 plugins/insulin/src/main/res/values-de-rDE/strings.xml create mode 100644 plugins/insulin/src/main/res/values-el-rGR/strings.xml create mode 100644 plugins/insulin/src/main/res/values-es-rES/strings.xml create mode 100644 plugins/insulin/src/main/res/values-fr-rFR/strings.xml create mode 100644 plugins/insulin/src/main/res/values-ga-rIE/strings.xml create mode 100644 plugins/insulin/src/main/res/values-hr-rHR/strings.xml create mode 100644 plugins/insulin/src/main/res/values-hu-rHU/strings.xml create mode 100644 plugins/insulin/src/main/res/values-it-rIT/strings.xml create mode 100644 plugins/insulin/src/main/res/values-iw-rIL/strings.xml create mode 100644 plugins/insulin/src/main/res/values-ja-rJP/strings.xml create mode 100644 plugins/insulin/src/main/res/values-ko-rKR/strings.xml create mode 100644 plugins/insulin/src/main/res/values-lt-rLT/strings.xml create mode 100644 plugins/insulin/src/main/res/values-nl-rNL/strings.xml create mode 100644 plugins/insulin/src/main/res/values-no-rNO/strings.xml create mode 100644 plugins/insulin/src/main/res/values-pl-rPL/strings.xml create mode 100644 plugins/insulin/src/main/res/values-pt-rBR/strings.xml create mode 100644 plugins/insulin/src/main/res/values-pt-rPT/strings.xml create mode 100644 plugins/insulin/src/main/res/values-ro-rRO/strings.xml create mode 100644 plugins/insulin/src/main/res/values-ru-rRU/strings.xml create mode 100644 plugins/insulin/src/main/res/values-sk-rSK/strings.xml create mode 100644 plugins/insulin/src/main/res/values-sr-rCS/strings.xml create mode 100644 plugins/insulin/src/main/res/values-sv-rSE/strings.xml create mode 100644 plugins/insulin/src/main/res/values-tr-rTR/strings.xml create mode 100644 plugins/insulin/src/main/res/values-zh-rCN/strings.xml create mode 100644 plugins/source/src/main/res/values-af-rZA/strings.xml create mode 100644 plugins/source/src/main/res/values-bg-rBG/strings.xml create mode 100644 plugins/source/src/main/res/values-ca-rES/strings.xml create mode 100644 plugins/source/src/main/res/values-cs-rCZ/strings.xml create mode 100644 plugins/source/src/main/res/values-da-rDK/strings.xml create mode 100644 plugins/source/src/main/res/values-de-rDE/strings.xml create mode 100644 plugins/source/src/main/res/values-el-rGR/strings.xml create mode 100644 plugins/source/src/main/res/values-es-rES/strings.xml create mode 100644 plugins/source/src/main/res/values-fr-rFR/strings.xml create mode 100644 plugins/source/src/main/res/values-ga-rIE/strings.xml create mode 100644 plugins/source/src/main/res/values-hr-rHR/strings.xml create mode 100644 plugins/source/src/main/res/values-hu-rHU/strings.xml create mode 100644 plugins/source/src/main/res/values-it-rIT/strings.xml create mode 100644 plugins/source/src/main/res/values-iw-rIL/strings.xml create mode 100644 plugins/source/src/main/res/values-ja-rJP/strings.xml create mode 100644 plugins/source/src/main/res/values-ko-rKR/strings.xml create mode 100644 plugins/source/src/main/res/values-lt-rLT/strings.xml create mode 100644 plugins/source/src/main/res/values-nl-rNL/strings.xml create mode 100644 plugins/source/src/main/res/values-no-rNO/strings.xml create mode 100644 plugins/source/src/main/res/values-pl-rPL/strings.xml create mode 100644 plugins/source/src/main/res/values-pt-rBR/strings.xml create mode 100644 plugins/source/src/main/res/values-pt-rPT/strings.xml create mode 100644 plugins/source/src/main/res/values-ro-rRO/strings.xml create mode 100644 plugins/source/src/main/res/values-ru-rRU/strings.xml create mode 100644 plugins/source/src/main/res/values-sk-rSK/strings.xml create mode 100644 plugins/source/src/main/res/values-sr-rCS/strings.xml create mode 100644 plugins/source/src/main/res/values-sv-rSE/strings.xml create mode 100644 plugins/source/src/main/res/values-tr-rTR/strings.xml create mode 100644 plugins/source/src/main/res/values-zh-rCN/strings.xml create mode 100644 pump/virtual/src/main/res/values-af-rZA/strings.xml create mode 100644 pump/virtual/src/main/res/values-bg-rBG/strings.xml create mode 100644 pump/virtual/src/main/res/values-ca-rES/strings.xml create mode 100644 pump/virtual/src/main/res/values-cs-rCZ/strings.xml create mode 100644 pump/virtual/src/main/res/values-da-rDK/strings.xml create mode 100644 pump/virtual/src/main/res/values-de-rDE/strings.xml create mode 100644 pump/virtual/src/main/res/values-el-rGR/strings.xml create mode 100644 pump/virtual/src/main/res/values-es-rES/strings.xml create mode 100644 pump/virtual/src/main/res/values-fr-rFR/strings.xml create mode 100644 pump/virtual/src/main/res/values-ga-rIE/strings.xml create mode 100644 pump/virtual/src/main/res/values-hr-rHR/strings.xml create mode 100644 pump/virtual/src/main/res/values-hu-rHU/strings.xml create mode 100644 pump/virtual/src/main/res/values-it-rIT/strings.xml create mode 100644 pump/virtual/src/main/res/values-iw-rIL/strings.xml create mode 100644 pump/virtual/src/main/res/values-ja-rJP/strings.xml create mode 100644 pump/virtual/src/main/res/values-ko-rKR/strings.xml create mode 100644 pump/virtual/src/main/res/values-lt-rLT/strings.xml create mode 100644 pump/virtual/src/main/res/values-nl-rNL/strings.xml create mode 100644 pump/virtual/src/main/res/values-no-rNO/strings.xml create mode 100644 pump/virtual/src/main/res/values-pl-rPL/strings.xml create mode 100644 pump/virtual/src/main/res/values-pt-rBR/strings.xml create mode 100644 pump/virtual/src/main/res/values-pt-rPT/strings.xml create mode 100644 pump/virtual/src/main/res/values-ro-rRO/strings.xml create mode 100644 pump/virtual/src/main/res/values-ru-rRU/strings.xml create mode 100644 pump/virtual/src/main/res/values-sk-rSK/strings.xml create mode 100644 pump/virtual/src/main/res/values-sr-rCS/strings.xml create mode 100644 pump/virtual/src/main/res/values-sv-rSE/strings.xml create mode 100644 pump/virtual/src/main/res/values-tr-rTR/strings.xml create mode 100644 pump/virtual/src/main/res/values-zh-rCN/strings.xml diff --git a/app/src/main/res/values-bg-rBG/strings.xml b/app/src/main/res/values-bg-rBG/strings.xml index 1a7db0dd5c..f42b91b134 100644 --- a/app/src/main/res/values-bg-rBG/strings.xml +++ b/app/src/main/res/values-bg-rBG/strings.xml @@ -46,7 +46,6 @@ Удостоверяването неуспешно Създаването на профила невъзможно. Профилът е невалиден. Не убивай приложението? - Време за ядене!\nИзпълнете болус съветника и направете изчисления отново. Качването на данни за проблеми е забранено!(Fabric) Премахни филтъра Канюла diff --git a/app/src/main/res/values-ca-rES/strings.xml b/app/src/main/res/values-ca-rES/strings.xml index 664addee47..9aa0159769 100644 --- a/app/src/main/res/values-ca-rES/strings.xml +++ b/app/src/main/res/values-ca-rES/strings.xml @@ -44,7 +44,6 @@ L\'autorització ha fallat No s\'ha pogut crear el perfil local. Perfil no vàlid. No matar la meva app? - Hora de menjar!\nExecuteu l\'assistent de bolus i torneu a fer els càlculs. Enviament de logs d\'error desactivat! Netejar filtres Cànula diff --git a/app/src/main/res/values-cs-rCZ/strings.xml b/app/src/main/res/values-cs-rCZ/strings.xml index 2345b42700..76402c65fb 100644 --- a/app/src/main/res/values-cs-rCZ/strings.xml +++ b/app/src/main/res/values-cs-rCZ/strings.xml @@ -46,7 +46,6 @@ Autorizace selhala Nelze vytvořit profil. Profil je neplatný. Nezabíjet mou aplikaci? - Čas k jídlu!\nSpusťte Bolusovou kalkulačku a proveďte výpočet znovu. Nahrávání protokolů o pádech zakázáno! Vymazat filtr Kanyla diff --git a/app/src/main/res/values-da-rDK/strings.xml b/app/src/main/res/values-da-rDK/strings.xml index 1db0beb3e9..f5d3a39f62 100644 --- a/app/src/main/res/values-da-rDK/strings.xml +++ b/app/src/main/res/values-da-rDK/strings.xml @@ -46,7 +46,6 @@ Godkendelse mislykkedes Kunne ikke oprette profil. Profilen er ugyldig. Luk ikke min app? - Tid til at spise!\nKør Bolus guiden og lav beregning igen. Upload af Crash logs deaktiveret! Nulstil filter Kanyle diff --git a/app/src/main/res/values-de-rDE/strings.xml b/app/src/main/res/values-de-rDE/strings.xml index 31c649effa..3d8646bd4f 100644 --- a/app/src/main/res/values-de-rDE/strings.xml +++ b/app/src/main/res/values-de-rDE/strings.xml @@ -46,7 +46,6 @@ Autorisierung fehlgeschlagen Profil kann nicht erstellt werden. Profil ist ungültig. Don\'t kill my app? - Zeit zum Essen!\nStarte den Bolus-Rechner und gib die KH ein. Hochladen von Crash-Protokollen deaktiviert! Filter löschen Kanüle diff --git a/app/src/main/res/values-es-rES/strings.xml b/app/src/main/res/values-es-rES/strings.xml index a832b3d914..93e3a6dfb3 100644 --- a/app/src/main/res/values-es-rES/strings.xml +++ b/app/src/main/res/values-es-rES/strings.xml @@ -46,7 +46,6 @@ Ha fallado la autorización No se puede crear el perfil. El perfil es inválido. ¿No matar mi aplicación? - ¡Hora de comer!\nEjecutar el asistente de bolo y calcular de nuevo. ¡Carga de registros de errores desactivada! Borrar filtro Cánula diff --git a/app/src/main/res/values-fr-rFR/strings.xml b/app/src/main/res/values-fr-rFR/strings.xml index f1a7419126..4dd1c84b24 100644 --- a/app/src/main/res/values-fr-rFR/strings.xml +++ b/app/src/main/res/values-fr-rFR/strings.xml @@ -46,7 +46,6 @@ Echec de l\'authentification Impossible de créer le profil. Le profil est invalide. Garder l\'appli en arrière plan ? - Il est temps de manger !\nExécutez l\'assistant Bolus et refaites le calcul. Téléchargement logs crashs désactivé! Effacer le filtre Canule diff --git a/app/src/main/res/values-it-rIT/strings.xml b/app/src/main/res/values-it-rIT/strings.xml index 6cea5dd5aa..ba4bf39d49 100644 --- a/app/src/main/res/values-it-rIT/strings.xml +++ b/app/src/main/res/values-it-rIT/strings.xml @@ -46,7 +46,6 @@ Autorizzazione fallita Impossibile creare il profilo. Il profilo non è valido. Non terminare l\'app? - Tempo di mangiare!\nEsegui il calcolatore e fai di nuovi i calcoli. Caricamento log dei crash disabilitato! Cancella filtro Cannula diff --git a/app/src/main/res/values-iw-rIL/strings.xml b/app/src/main/res/values-iw-rIL/strings.xml index ef523eb712..a07111a2a0 100644 --- a/app/src/main/res/values-iw-rIL/strings.xml +++ b/app/src/main/res/values-iw-rIL/strings.xml @@ -46,7 +46,6 @@ ההרשאה נכשלה לא ניתן ליצור פרופיל מקומי. הפרופיל אינו חוקי. איך לא להשבית את האפליקציה שלי? - זמן לאכול!\nהפעילו את אשף הבולוסים וחשבו בולוס חדש. העלאת רשומות קריסה מושבתת! נקה סינון צינורית diff --git a/app/src/main/res/values-ko-rKR/strings.xml b/app/src/main/res/values-ko-rKR/strings.xml index 6e2e601e50..eaf67357d2 100644 --- a/app/src/main/res/values-ko-rKR/strings.xml +++ b/app/src/main/res/values-ko-rKR/strings.xml @@ -43,7 +43,6 @@ 차트 메뉴 인증 실패 앱이 종료되지 않도록 합니다? - 식사할 시간입니다! \nBolus wizard를 켜고 다시 계산하십시오. 충돌 로그 업로드가 작동하지 않습니다. 필터 지우기 캐뉼라 diff --git a/app/src/main/res/values-lt-rLT/strings.xml b/app/src/main/res/values-lt-rLT/strings.xml index 5a1e454810..6954c628bf 100644 --- a/app/src/main/res/values-lt-rLT/strings.xml +++ b/app/src/main/res/values-lt-rLT/strings.xml @@ -46,7 +46,6 @@ Autorizacija nepavyko Nepavyksta sukurti profilio. Profilis neteisingas. Don\'t kill my app? - Laikas valgyti!\nĮjunkite Boluso patarėją ir atlikite skaičiavimą dar kartą. Sutrikimų žurnalo įrašų įkėlimas išjungtas! Valyti filtrą Kaniulė diff --git a/app/src/main/res/values-nl-rNL/strings.xml b/app/src/main/res/values-nl-rNL/strings.xml index fc3900a149..02e0b87228 100644 --- a/app/src/main/res/values-nl-rNL/strings.xml +++ b/app/src/main/res/values-nl-rNL/strings.xml @@ -46,7 +46,6 @@ Autorisatie mislukt Kan profiel niet aanmaken. Profiel is ongeldig. Don\'t kill my app? - Tijd om te eten!\nVoer de boluswizard opnieuw uit. Upload van crashrapporten is uitgeschakeld! Verwijder filter Canule diff --git a/app/src/main/res/values-no-rNO/strings.xml b/app/src/main/res/values-no-rNO/strings.xml index 1780e7999c..e556fd19ba 100644 --- a/app/src/main/res/values-no-rNO/strings.xml +++ b/app/src/main/res/values-no-rNO/strings.xml @@ -46,7 +46,6 @@ Autentisering feilet Klarte ikke å opprette profil. Profilen er ikke gyldig. Avslutte app? - Nå må du spise!\Bruk bolus veiviseren og beregn på nytt. Opplast av krasj logger er deaktivert! Nullstill filtre Kanyle diff --git a/app/src/main/res/values-pl-rPL/strings.xml b/app/src/main/res/values-pl-rPL/strings.xml index 32ab99571c..b400c4310d 100644 --- a/app/src/main/res/values-pl-rPL/strings.xml +++ b/app/src/main/res/values-pl-rPL/strings.xml @@ -44,7 +44,6 @@ Autoryzacja nie powiodła się Nie można utworzyć profilu. Profil jest nieprawidłowy. Nie zabij mojej aplikacji? - Czas jeść!\nUruchom kreatora bolusa i zrób obliczenia ponownie. Przesyłanie dzienników awarii jest wyłączone! Wyczyść filtr Kaniula diff --git a/app/src/main/res/values-pt-rBR/strings.xml b/app/src/main/res/values-pt-rBR/strings.xml index 06d026d264..7c1a2074f1 100644 --- a/app/src/main/res/values-pt-rBR/strings.xml +++ b/app/src/main/res/values-pt-rBR/strings.xml @@ -46,7 +46,6 @@ Falha na autorização Não foi possível criar o perfil. Perfil inválido. Não encerre meu aplicativo? - Hora de comer!\nAbra o assistente de bolus e faça o cálculo novamente. Envio de logs de erro desativado! Limpar filtro Cânula diff --git a/app/src/main/res/values-pt-rPT/strings.xml b/app/src/main/res/values-pt-rPT/strings.xml index e57116ad69..ab64e43735 100644 --- a/app/src/main/res/values-pt-rPT/strings.xml +++ b/app/src/main/res/values-pt-rPT/strings.xml @@ -44,7 +44,6 @@ Falha na autorização Não é possível criar o perfil. O perfil é inválido. Não encerre minha app? - Hora de comer!\nExecutar assistente de Bólus e fazer cálculo novamente. Envio de registos de erro desativado! Limpar filtros Cânula diff --git a/app/src/main/res/values-ro-rRO/strings.xml b/app/src/main/res/values-ro-rRO/strings.xml index 8a8aa9b8df..3ea8624597 100644 --- a/app/src/main/res/values-ro-rRO/strings.xml +++ b/app/src/main/res/values-ro-rRO/strings.xml @@ -44,7 +44,6 @@ Autorizarea a eșuat Nu se poate crea profilul. Profilul este invalid. Nu-mi opri aplicația? - Timpul sa mănânci!\nRuleaza Calculatorul de Bolus pentru a face calculele din nou. Încărcarea jurnalelor de erori este dezactivata! Șterge filtru Canula diff --git a/app/src/main/res/values-ru-rRU/strings.xml b/app/src/main/res/values-ru-rRU/strings.xml index 835b8abfe4..0c5dec9871 100644 --- a/app/src/main/res/values-ru-rRU/strings.xml +++ b/app/src/main/res/values-ru-rRU/strings.xml @@ -46,7 +46,6 @@ Ошибка авторизации Не удается создать локальный профиль. Настройки профиля неправильны. Не закрывать приложение? - Пора есть!\nЗапустите помощник болюса снова для подсчета. Загрузка журналов сбоя на сервер отключена! Очистить фильтр Катетер помпы diff --git a/app/src/main/res/values-sk-rSK/strings.xml b/app/src/main/res/values-sk-rSK/strings.xml index 6b908ff304..771d8a4f51 100644 --- a/app/src/main/res/values-sk-rSK/strings.xml +++ b/app/src/main/res/values-sk-rSK/strings.xml @@ -46,7 +46,6 @@ Autorizácia zlyhala Nie je možné vytvoriť lokálny profil. Profil je neplatný. Nepotláčať moju aplikáciu? - Čas na jedlo!\nSpustite Bolusovú kalkulačku a urobte výpočet znova. Odosielanie protokolov o zlyhaní je zakázané! Vyčistiť filter Kanyla diff --git a/app/src/main/res/values-sv-rSE/strings.xml b/app/src/main/res/values-sv-rSE/strings.xml index d4ac53d28c..d4f2f7f4cc 100644 --- a/app/src/main/res/values-sv-rSE/strings.xml +++ b/app/src/main/res/values-sv-rSE/strings.xml @@ -44,7 +44,6 @@ Behörighetskontroll misslyckades Kan inte att skapa profilen. Profilen är felaktig. Döda inte min app? - Dags att äta!\nKör bolusguiden igen för ny beräkning. Uppladdning av kraschloggar inaktiverad! Rensa filter Kanyl diff --git a/app/src/main/res/values-tr-rTR/strings.xml b/app/src/main/res/values-tr-rTR/strings.xml index db88fc05c8..e727c94fac 100644 --- a/app/src/main/res/values-tr-rTR/strings.xml +++ b/app/src/main/res/values-tr-rTR/strings.xml @@ -46,7 +46,6 @@ Yetkilendirme başarısız oldu Profil oluşturulamıyor. Profil geçersiz. Uygulamamı devre dışı bırakma? - Yemek zamanı!\nBolus sihirbazını çalıştırın ve yeniden hesaplama yapın. Çökme günlükleri yükleme devre dışı bırakıldı! Filtreyi temizle Kanül diff --git a/app/src/main/res/values-zh-rCN/strings.xml b/app/src/main/res/values-zh-rCN/strings.xml index d2b96a9b61..0a5b99d13e 100644 --- a/app/src/main/res/values-zh-rCN/strings.xml +++ b/app/src/main/res/values-zh-rCN/strings.xml @@ -46,7 +46,6 @@ 授权失败 无法创建配置文件。配置文件无效。 不要杀死我的应用程序? - 吃饭时间到了!\n请运行大剂量向导,然后进行计算。 已禁用崩溃日志上传! 清除筛选 输注导管 diff --git a/core/ui/src/main/res/values-af-rZA/strings.xml b/core/ui/src/main/res/values-af-rZA/strings.xml index b034c45d97..f4a299a001 100644 --- a/core/ui/src/main/res/values-af-rZA/strings.xml +++ b/core/ui/src/main/res/values-af-rZA/strings.xml @@ -113,6 +113,7 @@ Geslote lus Oop lus DIA + Oplaaistatus aan NS Verkeerde wagwoord diff --git a/core/ui/src/main/res/values-bg-rBG/strings.xml b/core/ui/src/main/res/values-bg-rBG/strings.xml index e5ccf673f8..dec4c15896 100644 --- a/core/ui/src/main/res/values-bg-rBG/strings.xml +++ b/core/ui/src/main/res/values-bg-rBG/strings.xml @@ -138,6 +138,7 @@ DIA И / Въгл Чувств + Качва статуса в NS Грешна парола Паролите не съвпадат diff --git a/core/ui/src/main/res/values-ca-rES/strings.xml b/core/ui/src/main/res/values-ca-rES/strings.xml index 27c09850c3..77a503114a 100644 --- a/core/ui/src/main/res/values-ca-rES/strings.xml +++ b/core/ui/src/main/res/values-ca-rES/strings.xml @@ -137,6 +137,9 @@ DIA (Durada de l\'Acció de la Insulina) IC ISF + Enviar estat a NS + Llaç desactivat/aturat + Insulina \"a bord\" (IOB) Contrasenya incorrecta Les contrasenyes no coincideixen diff --git a/core/ui/src/main/res/values-cs-rCZ/strings.xml b/core/ui/src/main/res/values-cs-rCZ/strings.xml index 00eefa7fca..359b8c7e08 100644 --- a/core/ui/src/main/res/values-cs-rCZ/strings.xml +++ b/core/ui/src/main/res/values-cs-rCZ/strings.xml @@ -164,6 +164,9 @@ ISF Rušení dočasného bazálu selhalo Zastavení prodlouženého bolusu selhalo + Nahrávat status do NS + Zakázaná/pozastavená smyčka + Aktivní inzulín (IOB) Chybné heslo Nesprávný PIN diff --git a/core/ui/src/main/res/values-da-rDK/strings.xml b/core/ui/src/main/res/values-da-rDK/strings.xml index 1957375bfb..914927f484 100644 --- a/core/ui/src/main/res/values-da-rDK/strings.xml +++ b/core/ui/src/main/res/values-da-rDK/strings.xml @@ -155,6 +155,9 @@ DIA IC ISF + Upload status til NS + Deaktiveret/Suspendéret Loop + Insulin om bord (IOB) Forkert kodeord Forkert pinkode diff --git a/core/ui/src/main/res/values-de-rDE/strings.xml b/core/ui/src/main/res/values-de-rDE/strings.xml index 977918bf6c..09a8cd1872 100644 --- a/core/ui/src/main/res/values-de-rDE/strings.xml +++ b/core/ui/src/main/res/values-de-rDE/strings.xml @@ -101,6 +101,7 @@ Lade… Notizen Löschen + Neu hinzufügen Neu oben hinzufügen Daten kommen von einer anderen Pumpe. Wechsle den Pumpentreiber. BZ @@ -155,6 +156,9 @@ DIA IC ISF + Status zu Nightscout hochladen + Deaktiviere/Pausiere den Loop + Aktives Insulin (IOB) Falsches Passwort Falsche PIN @@ -316,6 +320,7 @@ EINSTELLUNGEN EXPORTIEREN EINSTELLUNGEN IMPORTIEREN DATENBANK ZURÜCKSETZEN + DATENBANKEN BEREINIGEN DATENBANK EXPORTIEREN DATENBANK IMPORTIEREN OTP EXPORT diff --git a/core/ui/src/main/res/values-el-rGR/strings.xml b/core/ui/src/main/res/values-el-rGR/strings.xml index 56ad6faf47..c4df755597 100644 --- a/core/ui/src/main/res/values-el-rGR/strings.xml +++ b/core/ui/src/main/res/values-el-rGR/strings.xml @@ -116,6 +116,7 @@ Κλειστό Κύκλωμα Ανοιχτό Κύκλωμα Αναστολή Χαμηλής Γλυκόζης + Φόρτωση κατάστασης στο NS Λάθος κωδικός diff --git a/core/ui/src/main/res/values-es-rES/strings.xml b/core/ui/src/main/res/values-es-rES/strings.xml index ca6539ff4b..e246d677e8 100644 --- a/core/ui/src/main/res/values-es-rES/strings.xml +++ b/core/ui/src/main/res/values-es-rES/strings.xml @@ -164,6 +164,9 @@ ISF Error cancelando la basal temporal Error cancelando el bolo extendido + Subir estado a Nightscout + Desactiva/suspende el lazo + Insulina a bordo (IOB) Contraseña incorrecta Pin erróneo diff --git a/core/ui/src/main/res/values-fr-rFR/strings.xml b/core/ui/src/main/res/values-fr-rFR/strings.xml index 5253d3c963..4e0d6017eb 100644 --- a/core/ui/src/main/res/values-fr-rFR/strings.xml +++ b/core/ui/src/main/res/values-fr-rFR/strings.xml @@ -161,6 +161,9 @@ DAI G/I SI + Remontée des informations vers NS + Boucle désactivée/suspendue + Insuline Active (IA) Mot de passe incorrect Code PIN incorrect diff --git a/core/ui/src/main/res/values-hr-rHR/strings.xml b/core/ui/src/main/res/values-hr-rHR/strings.xml index d54ebac72f..8fe1732817 100644 --- a/core/ui/src/main/res/values-hr-rHR/strings.xml +++ b/core/ui/src/main/res/values-hr-rHR/strings.xml @@ -108,6 +108,7 @@ DIA IC ISF + Prijenos statusa u NS Pogrešna lozinka Pogrešan PIN diff --git a/core/ui/src/main/res/values-it-rIT/strings.xml b/core/ui/src/main/res/values-it-rIT/strings.xml index 62fa0720ce..5867022486 100644 --- a/core/ui/src/main/res/values-it-rIT/strings.xml +++ b/core/ui/src/main/res/values-it-rIT/strings.xml @@ -156,6 +156,9 @@ DIA IC ISF + Carica stato in NS + Loop disabilitato/sospeso + Insulina attiva (IOB) Password errata PIN errato diff --git a/core/ui/src/main/res/values-iw-rIL/strings.xml b/core/ui/src/main/res/values-iw-rIL/strings.xml index 25f8fac1f6..c99a6fcdea 100644 --- a/core/ui/src/main/res/values-iw-rIL/strings.xml +++ b/core/ui/src/main/res/values-iw-rIL/strings.xml @@ -156,6 +156,9 @@ משך פעילות אינסולין IC ISF + טוען מצב ל-Nightscout + השבתת \\ השהיית לולאה + אינסולין פעיל בגוף (IOB) סיסמה שגויה קוד PIN שגוי diff --git a/core/ui/src/main/res/values-ko-rKR/strings.xml b/core/ui/src/main/res/values-ko-rKR/strings.xml index 6f44561f90..e6c511e6c5 100644 --- a/core/ui/src/main/res/values-ko-rKR/strings.xml +++ b/core/ui/src/main/res/values-ko-rKR/strings.xml @@ -136,6 +136,9 @@ DIA IC ISF + NS에 상태 업로드하기 + 중지 또는 일시중지된 loop + 활성 인슐린 (IOB) 잘못된 비밀번호 비밀번호가 일치하지 않습니다. diff --git a/core/ui/src/main/res/values-lt-rLT/strings.xml b/core/ui/src/main/res/values-lt-rLT/strings.xml index a247458036..e88c71198a 100644 --- a/core/ui/src/main/res/values-lt-rLT/strings.xml +++ b/core/ui/src/main/res/values-lt-rLT/strings.xml @@ -141,6 +141,9 @@ IVT IA JIF + Perduoti būsenos duomenis į NS + Ciklas išjungtas/sustabdytas + Aktyvus insulinas organizme (AIO) Neteisingas slaptažodis Slaptažodžiai nesutampa diff --git a/core/ui/src/main/res/values-nl-rNL/strings.xml b/core/ui/src/main/res/values-nl-rNL/strings.xml index feaa7500a1..001d79204d 100644 --- a/core/ui/src/main/res/values-nl-rNL/strings.xml +++ b/core/ui/src/main/res/values-nl-rNL/strings.xml @@ -158,6 +158,9 @@ DIA KH-ratio ISF + Upload status naar NS + Uitgeschakelde/onderbroken loop + Insuline aan boord (IOB) Verkeerd wachtwoord Onjuiste PIN-code diff --git a/core/ui/src/main/res/values-no-rNO/strings.xml b/core/ui/src/main/res/values-no-rNO/strings.xml index cc59c713bb..c26b75ec52 100644 --- a/core/ui/src/main/res/values-no-rNO/strings.xml +++ b/core/ui/src/main/res/values-no-rNO/strings.xml @@ -164,6 +164,9 @@ ISF Kansellering av Temp Basal feilet Kansellering av forlenget bolus feilet + Last opp status til Nightscout + Deaktiver/pause loop + Aktivt insulin (IOB) Feil passord Feil PIN-kode diff --git a/core/ui/src/main/res/values-pl-rPL/strings.xml b/core/ui/src/main/res/values-pl-rPL/strings.xml index 029f265d00..0899124568 100644 --- a/core/ui/src/main/res/values-pl-rPL/strings.xml +++ b/core/ui/src/main/res/values-pl-rPL/strings.xml @@ -141,6 +141,9 @@ DIA IC ISF + Przesyłaj status do NS + Wyłączona/zawieszona pętla + Aktywna insulina (IOB) Złe hasło Hasła się nie zgadzają diff --git a/core/ui/src/main/res/values-pt-rBR/protection.xml b/core/ui/src/main/res/values-pt-rBR/protection.xml index 272d4c10ba..86522c3e44 100644 --- a/core/ui/src/main/res/values-pt-rBR/protection.xml +++ b/core/ui/src/main/res/values-pt-rBR/protection.xml @@ -6,13 +6,26 @@ Proteção Aplicação Proteção Bólus Definições de senha + Configurações do PIN Senha da aplicação + PIN do Aplicativo Senha do bólus + Bolus PIN + PIN e senha de segurança + Tempo até que a senha ou PIN sejam inseridos Biometria Senha personalizada + PIN personalizado Sem proteção + Retorno Inseguro + Para ser eficaz, a proteção biométrica precisa de uma senha mestra definida para a substituição.\n\nPor favor defina uma senha mestra! Senha foi definida! + PIN definido! Senha não foi definida + PIN não definido Senha não foi alterada + PIN não alterado + PIN apagado! Insira a senha aqui + Insira o PIN aqui diff --git a/core/ui/src/main/res/values-pt-rBR/strings.xml b/core/ui/src/main/res/values-pt-rBR/strings.xml index 7a5a500da2..add6078c4b 100644 --- a/core/ui/src/main/res/values-pt-rBR/strings.xml +++ b/core/ui/src/main/res/values-pt-rBR/strings.xml @@ -14,6 +14,7 @@ %1$.2f U/h Bomba não inicializada, perfil não definido! Falha ao atualizar o perfil basal + Bolus %1$.2f U aplicado com sucesso Nenhum valor de basal temporaria valido foi lido da bomba A limitar IOB para %1$.1f U porque %2$s LOOP DESATIVADO POR RESTRIÇÕES @@ -46,6 +47,7 @@ Sucesso Configurações Avançadas Erro na entrega Bólus Estendido + Modo APS Bólus estendido Pausado DDT Total @@ -60,6 +62,8 @@ Por favor aguarde… Parar Carbos + Perfil inválido! + SEM PERFIL DEFINIDO ]]> Data Unidades @@ -149,6 +153,7 @@ IOB Basal INVÁLIDO Login + Purgar/Preencher Insulina Parar Alvo Temp Loop Fechado @@ -157,6 +162,11 @@ DIA IC FSI + Cancelamento do basal temporário falhou + Falhou o cancelamento do bolus extendido + Enviar estado para NS + Loop Desativado/Suspenso + Insulina ativa (IA) Senha incorreta PIN incorreto @@ -172,6 +182,7 @@ Iniciar perfil %1$d%% para %2$d min + Cancelar basal temporário Deixa o basal temporário em andamento Rácio Duração @@ -193,9 +204,12 @@ Observação: %1$s Questão : %1$s Exercício : %1$s + Alteração do local do cateter + Colocação do Sensor CGM Início do Sensor CGM Parar Sensor CGM Alerta D.A.D + Troca de Reservatório de Insulina Troca de Perfil Bólus Lanche Bólus Refeição @@ -205,6 +219,8 @@ Fim do Basal Temp Correção Carboidratos OpenAPS Offline + Troca de Bateria da Bomba + Alvo Temporário Valor do Alvo Temporário Cancelar alvo temporário Assistente de Bólus @@ -233,6 +249,7 @@ %1$d g de carboidratos necessários em %2$d minutos + Dose diária acumulada (TDD) Dose diária exponencialmente ponderada Basal Bólus @@ -431,9 +448,13 @@ Alarme Urgente INFO + Assistente de bolus + Sua glicemia está alta. Em vez de comer agora, é recomendado esperar por uma glicemia melhor. Quer fazer um bolus de correção agora e ser lembrado de quando for hora de comer? Neste caso, nenhum carboidrato será registrado e você deverá usar o assistente novamente quando lembrarmos você. CA vs IA !!!!! Absorção lenta de hidratos detectada: %2$d%% do tempo. Verifique o seu cálculo. COB pode estar sobreestimado, assim mais insulina pode ser dada !!!]]> Entregue esta parte do resultado do assistente de bólus [%] + Restrição de bólus aplicada: %1$.2f U para %2$.2f U + Bolus será apenas registrado (não administrado pela bomba) Disparar alarme quando for a hora de comer Nenhuma acção seleccionada, nada irá acontecer Nenhuma glicemia recente para base de cálculo! @@ -453,9 +474,15 @@ %1$s para %2$s Nenhuma bomba disponível! + Criança Adolescente Adulto + Adulto resistente à insulina Grávida + Selecione o tipo de paciente para configurar os limites de segurança + Máximo bolus permitido [U] + Máximo de carbs permitidos [g] + Tipo de paciente Definições de desbloqueio diff --git a/core/ui/src/main/res/values-pt-rPT/strings.xml b/core/ui/src/main/res/values-pt-rPT/strings.xml index 3918c63e3c..2261b66379 100644 --- a/core/ui/src/main/res/values-pt-rPT/strings.xml +++ b/core/ui/src/main/res/values-pt-rPT/strings.xml @@ -139,6 +139,9 @@ DIA IHC FSI + Enviar estado para NS + Loop Desactivado/Suspenso + Insulina ativa (IA ) Palavra-passe incorreta Palavras-passe não correspondem diff --git a/core/ui/src/main/res/values-ro-rRO/strings.xml b/core/ui/src/main/res/values-ro-rRO/strings.xml index db4936ab40..cae13b03b8 100644 --- a/core/ui/src/main/res/values-ro-rRO/strings.xml +++ b/core/ui/src/main/res/values-ro-rRO/strings.xml @@ -140,6 +140,9 @@ DIA IC ISF + Trimitere status către NS + Buclă dezactivată/suspendată + Insulină activă (IOB) Parola greșită Parolele nu corespund diff --git a/core/ui/src/main/res/values-ru-rRU/strings.xml b/core/ui/src/main/res/values-ru-rRU/strings.xml index 113c3e0715..90bb6dbab1 100644 --- a/core/ui/src/main/res/values-ru-rRU/strings.xml +++ b/core/ui/src/main/res/values-ru-rRU/strings.xml @@ -162,6 +162,9 @@ Время действия инсулина DIA IC углкоэф ГУ/инс ISF (чувствительность к инсулину) + статус передачи данных в NS + Отключенный/приостановленный цикл + Активный инсулин (IOB) Неверный пароль Неверный PIN-код diff --git a/core/ui/src/main/res/values-sk-rSK/strings.xml b/core/ui/src/main/res/values-sk-rSK/strings.xml index 547f6a389b..d49b2f6c1f 100644 --- a/core/ui/src/main/res/values-sk-rSK/strings.xml +++ b/core/ui/src/main/res/values-sk-rSK/strings.xml @@ -162,6 +162,9 @@ DIA I:C ISF + Nahrať stav do NS + Deaktivovaný/pozastavený uzavretý okruh + Aktívny inzulín (IOB) Nesprávne heslo Nesprávny PIN diff --git a/core/ui/src/main/res/values-sv-rSE/strings.xml b/core/ui/src/main/res/values-sv-rSE/strings.xml index 44781af85c..595d802f63 100644 --- a/core/ui/src/main/res/values-sv-rSE/strings.xml +++ b/core/ui/src/main/res/values-sv-rSE/strings.xml @@ -153,6 +153,9 @@ Duration IC ISF + Ladda upp status till Nightscout + Inaktiverad/pausad loop + Aktivt Insulin (IOB) Fel lösenord Lösenorden stämmer inte överens diff --git a/core/ui/src/main/res/values-tr-rTR/strings.xml b/core/ui/src/main/res/values-tr-rTR/strings.xml index b15948f734..4f04e95b60 100644 --- a/core/ui/src/main/res/values-tr-rTR/strings.xml +++ b/core/ui/src/main/res/values-tr-rTR/strings.xml @@ -160,6 +160,9 @@ İES IC Karbonhidrat İnsülin Oranı IDF İnsülin Duyarlılık Faktörü + Nightscout\'a durum aktar + Döngüyü Devre Dışı bırakma/Askıya alma + Aktif İnsülin (AİNS) Hatalı parola Yanlış PIN diff --git a/core/ui/src/main/res/values-zh-rCN/strings.xml b/core/ui/src/main/res/values-zh-rCN/strings.xml index f75e73850b..1c13a48a4c 100644 --- a/core/ui/src/main/res/values-zh-rCN/strings.xml +++ b/core/ui/src/main/res/values-zh-rCN/strings.xml @@ -154,6 +154,9 @@ DIA IC ISF + 将状态上传到 NS + 禁用/暂停闭环 + 活性胰岛素(IOB) 密码错误 PIN 码错误 diff --git a/implementation/src/main/res/values-bg-rBG/strings.xml b/implementation/src/main/res/values-bg-rBG/strings.xml index 053c3762b7..626a596679 100644 --- a/implementation/src/main/res/values-bg-rBG/strings.xml +++ b/implementation/src/main/res/values-bg-rBG/strings.xml @@ -3,8 +3,6 @@ xDrip+ не е инсталиран Калибрацията е изпратена към xDrip+ КЗ - Време е за ядене - Време е за болус!\nВключи болус съветника и направи изчисление отново. Командата се изпълнява в момента Базалните стойности са под минимума. Не е зададен профил! Разрешение diff --git a/implementation/src/main/res/values-ca-rES/strings.xml b/implementation/src/main/res/values-ca-rES/strings.xml index 477ec540ed..e52c6270fc 100644 --- a/implementation/src/main/res/values-ca-rES/strings.xml +++ b/implementation/src/main/res/values-ca-rES/strings.xml @@ -3,8 +3,6 @@ xDrip+ no instal·lat Calibració enviada a xDrip+ Glucèmia - Hora de menjar - Hora d’aplicar bolus!\nExecuteu l\'assistent de bolus i torneu a fer els càlculs. Ordre executant-se ara mateix Valor de basal per sota del mínim. Perfil no definit! Permís diff --git a/implementation/src/main/res/values-cs-rCZ/strings.xml b/implementation/src/main/res/values-cs-rCZ/strings.xml index 618307654f..eeaa565d54 100644 --- a/implementation/src/main/res/values-cs-rCZ/strings.xml +++ b/implementation/src/main/res/values-cs-rCZ/strings.xml @@ -3,8 +3,6 @@ xDrip+ není nainstalován Kalibrace odeslána do xDripu+ Gly - Čas k jídlu - Čas na bolus!\nSpusťte Bolusovou kalkulačku a proveďte výpočet znovu. Příkaz je právě prováděn Hodnota bazálu pod povoleným minimem. Nenastaveno! Povolení diff --git a/implementation/src/main/res/values-da-rDK/strings.xml b/implementation/src/main/res/values-da-rDK/strings.xml index 8e92f5775d..bbbf8750dd 100644 --- a/implementation/src/main/res/values-da-rDK/strings.xml +++ b/implementation/src/main/res/values-da-rDK/strings.xml @@ -3,8 +3,6 @@ xDrip+ ikke installeret Kalibrering sendt til xDrip+ BG - Tid til at spise - Tid til bolus!\nKør Bolus-guiden og lav beregningen igen. Kommando udføres lige nu Basal værdi under minimum. Profil ikke angivet! Tilladelse diff --git a/implementation/src/main/res/values-de-rDE/strings.xml b/implementation/src/main/res/values-de-rDE/strings.xml index d65647d9d3..5c4bd725c7 100644 --- a/implementation/src/main/res/values-de-rDE/strings.xml +++ b/implementation/src/main/res/values-de-rDE/strings.xml @@ -3,8 +3,6 @@ xDrip+ nicht installiert Kalibrierung an xDrip+ gesendet+ BZ - Zeit zum Essen - Zeit für den nächsten Bolus!\nFühre den Bolus-Assistenten aus, um die Berechnung erneut durchzuführen. Befehl wird zurzeit ausgeführt Wert der Basalrate unter Minimum. Profil nicht gesetzt! Berechtigung diff --git a/implementation/src/main/res/values-es-rES/strings.xml b/implementation/src/main/res/values-es-rES/strings.xml index f26267d73c..fdcd036346 100644 --- a/implementation/src/main/res/values-es-rES/strings.xml +++ b/implementation/src/main/res/values-es-rES/strings.xml @@ -3,8 +3,6 @@ xDrip+ no se encuentra instalado Calibración enviada a xDrip+ BG - Hora de comer - ¡Hora de comer!\nEjecutar el asistente de bolo y calcular de nuevo. Orden se esta efectuando en este momento Valor basal por debajo del mínimo. Perfil no establecido. Permiso diff --git a/implementation/src/main/res/values-fr-rFR/strings.xml b/implementation/src/main/res/values-fr-rFR/strings.xml index 67e5c10fc9..58811711e8 100644 --- a/implementation/src/main/res/values-fr-rFR/strings.xml +++ b/implementation/src/main/res/values-fr-rFR/strings.xml @@ -3,8 +3,6 @@ xDrip+ n\'est pas installé Étalonnage envoyé à xDrip+ Gly - Il est temps de manger - Il est temps de faire le bolus !\nExécutez l\'Assistant et faites de nouveau le calcul. Commande exécutée à l\'instant Le débit Basal est inférieur au minimum autorisé. Profil non accepté ! Autorisation diff --git a/implementation/src/main/res/values-hr-rHR/strings.xml b/implementation/src/main/res/values-hr-rHR/strings.xml index 920aa62f37..105a2e32eb 100644 --- a/implementation/src/main/res/values-hr-rHR/strings.xml +++ b/implementation/src/main/res/values-hr-rHR/strings.xml @@ -3,8 +3,6 @@ xDrip+ nije instaliran Kalibracija poslana na xDrip+ GUK - Vrijeme za jelo - Vrijeme je za bolus!\nPokrenite čarobnjak za bolus i ponovite izračun. Naredba se izvršava upravo sada Bazalna vrijednost ispod minimuma. Profil nije postavljen! Dozvola diff --git a/implementation/src/main/res/values-hu-rHU/strings.xml b/implementation/src/main/res/values-hu-rHU/strings.xml index b943c52e03..7b0ced20c0 100644 --- a/implementation/src/main/res/values-hu-rHU/strings.xml +++ b/implementation/src/main/res/values-hu-rHU/strings.xml @@ -2,7 +2,6 @@ xDrip+ nincs telepítve VC - Ideje enni Alacsony Magas diff --git a/implementation/src/main/res/values-it-rIT/strings.xml b/implementation/src/main/res/values-it-rIT/strings.xml index 4d40d46a57..4d146e6414 100644 --- a/implementation/src/main/res/values-it-rIT/strings.xml +++ b/implementation/src/main/res/values-it-rIT/strings.xml @@ -3,7 +3,6 @@ xDrip+ non installato Calibrazione inviata a xDrip+ BG - Tempo di fare un bolo!\nEsegui il calcolatore e fai di nuovi i calcoli. Il comando sarà eseguito ora Valore basale inferiore al minimo. Profilo non impostato! Autorizzazione diff --git a/implementation/src/main/res/values-iw-rIL/strings.xml b/implementation/src/main/res/values-iw-rIL/strings.xml index a9e70d1725..a53bab2a40 100644 --- a/implementation/src/main/res/values-iw-rIL/strings.xml +++ b/implementation/src/main/res/values-iw-rIL/strings.xml @@ -3,8 +3,6 @@ xDrip+ אינו מותקן כיול נשלח ל-xDrip+ BG - זמן לאכול - זמן להזריק בולוס!\nהשתמשו במחשבון וחשבו מחדש. הפקודה מבוצעת כעת ערך הבסיס מתחת למינימום. פרופיל אינו מוגדר! הרשאה diff --git a/implementation/src/main/res/values-ko-rKR/strings.xml b/implementation/src/main/res/values-ko-rKR/strings.xml index 57f9ab29de..72fe956529 100644 --- a/implementation/src/main/res/values-ko-rKR/strings.xml +++ b/implementation/src/main/res/values-ko-rKR/strings.xml @@ -3,7 +3,6 @@ xDrip+가 설치되지 않았습니다 보정이 xDrip으로 전송되었습니다+ 혈당 - 식사할 시간 명령을 지금 실행합니다. Basal값이 최소값 이하입니다. 프로파일이 설정되지 않습니다! 권한 diff --git a/implementation/src/main/res/values-lt-rLT/strings.xml b/implementation/src/main/res/values-lt-rLT/strings.xml index 5ce414e2c2..af293a1316 100644 --- a/implementation/src/main/res/values-lt-rLT/strings.xml +++ b/implementation/src/main/res/values-lt-rLT/strings.xml @@ -3,8 +3,6 @@ xDrip+ neįdiegta Kalibracija nusiųsta į xDrip+ KG - Laikas valgyti - Laikas bolusui!\nĮjunkite Skaičiuotuvą ir pakartokite skaičiavimus. Komanda vykdoma Valandinės bazės vertė mažesnė už minimalią. Profilis nenustatytas! Leidimas diff --git a/implementation/src/main/res/values-nl-rNL/strings.xml b/implementation/src/main/res/values-nl-rNL/strings.xml index bccd5c6419..09e67b5431 100644 --- a/implementation/src/main/res/values-nl-rNL/strings.xml +++ b/implementation/src/main/res/values-nl-rNL/strings.xml @@ -3,8 +3,6 @@ xDrip+ niet geïnstalleerd Kalibratie verzonden naar xDrip+ BG - Tijd om te eten - Tijd om te bolussen!\nVoer de boluswizard uit en maak de berekening opnieuw. Opdracht wordt nu uitgevoerd Basaalwaarde onder minimum. Profiel niet ingesteld! Toestemming diff --git a/implementation/src/main/res/values-no-rNO/strings.xml b/implementation/src/main/res/values-no-rNO/strings.xml index 78cbec0a4b..12bfa0f41b 100644 --- a/implementation/src/main/res/values-no-rNO/strings.xml +++ b/implementation/src/main/res/values-no-rNO/strings.xml @@ -3,8 +3,6 @@ xDrip+ ikke installert Kalibrering er sendt til xDrip+ BS - Nå må du spise - Tid for bolus!\nStart bolus-veiviser og gjør beregning på nytt. Kommandoen utføres akkurat nå Basalverdi under minimum. Profilen settes ikke! Tillatelse diff --git a/implementation/src/main/res/values-pl-rPL/strings.xml b/implementation/src/main/res/values-pl-rPL/strings.xml index 816d781504..01697b1533 100644 --- a/implementation/src/main/res/values-pl-rPL/strings.xml +++ b/implementation/src/main/res/values-pl-rPL/strings.xml @@ -3,8 +3,6 @@ xDrip+ nie zainstalowany Kalibracja przesłana do xDrip+ BG - Czas na jedzenie - Czas na bolus!\nUruchom Kalkulator bolusa aby ponownie wykonać obliczenia. Polecenie jest teraz wykonywane Wartość bazy poniżej minimum. Nie ustawiono profilu! Uprawnienia diff --git a/implementation/src/main/res/values-pt-rBR/strings.xml b/implementation/src/main/res/values-pt-rBR/strings.xml index f2767da327..cedd2a45c0 100644 --- a/implementation/src/main/res/values-pt-rBR/strings.xml +++ b/implementation/src/main/res/values-pt-rBR/strings.xml @@ -3,8 +3,6 @@ xDrip+ não está instalado Calibração enviada para o xDrip+ GLIC - Hora de comer - Hora do bolus!\nAbra o assistente de bolus e faça o cálculo novamente. Comando será executado agora Valor da basal abaixo do mínimo. Perfil não definido! Permissão diff --git a/implementation/src/main/res/values-pt-rPT/strings.xml b/implementation/src/main/res/values-pt-rPT/strings.xml index c54dab06f6..17e7004db1 100644 --- a/implementation/src/main/res/values-pt-rPT/strings.xml +++ b/implementation/src/main/res/values-pt-rPT/strings.xml @@ -3,8 +3,6 @@ xDrip+ não está instalado Calibração enviada para xDrip+ GLIC - Hora de comer - Hora de fazer o bólus!\nExecute o assistente de bólus e faça o cálculo novamente. Comando será executado agora Valor da basal abaixo do mínimo. Perfil não definido! Permissão diff --git a/implementation/src/main/res/values-ro-rRO/strings.xml b/implementation/src/main/res/values-ro-rRO/strings.xml index 15656fca6b..9b05ddf2a9 100644 --- a/implementation/src/main/res/values-ro-rRO/strings.xml +++ b/implementation/src/main/res/values-ro-rRO/strings.xml @@ -3,8 +3,6 @@ xDrip+ nu este instalat. Calibrare trimisă către xDrip+ Gl - Timpul sa mănânci - Timpul sa faci bolus!\nRuleaza Calculatorul de Bolus pentru a face calculele din nou. Se execută comanda chiar acum Valoarea bazalei este sub minimul permis. Profilul nu este setat! Permisiune diff --git a/implementation/src/main/res/values-ru-rRU/strings.xml b/implementation/src/main/res/values-ru-rRU/strings.xml index fdf3b00b2e..f0ed2effbf 100644 --- a/implementation/src/main/res/values-ru-rRU/strings.xml +++ b/implementation/src/main/res/values-ru-rRU/strings.xml @@ -3,8 +3,6 @@ xdrip+ не установлен Калибровка отправлена на xDrip+ ГК - Пора есть - Пора дать болюс!\nЗапустите помощник болюса и повторите расчет. Команда выполняется значение базала ниже минимума. профиль не создан! Права доступа diff --git a/implementation/src/main/res/values-sk-rSK/strings.xml b/implementation/src/main/res/values-sk-rSK/strings.xml index dfb4deef39..9aca0897f2 100644 --- a/implementation/src/main/res/values-sk-rSK/strings.xml +++ b/implementation/src/main/res/values-sk-rSK/strings.xml @@ -3,8 +3,6 @@ xDrip+ nie je nainštalovaný Kalibrácia odoslaná do xDrip+ Glykémia - Čas na jedlo - Čas na bolus!\nSpustite Bolusovú kalkulačku a urobte výpočet znova. Príkaz sa práve vykonáva Hodnota bazálu pod povoleným minimom. Profil nenastavený! Povolenie diff --git a/implementation/src/main/res/values-sv-rSE/strings.xml b/implementation/src/main/res/values-sv-rSE/strings.xml index 9cb53165f8..3896d8c132 100644 --- a/implementation/src/main/res/values-sv-rSE/strings.xml +++ b/implementation/src/main/res/values-sv-rSE/strings.xml @@ -3,8 +3,6 @@ xDrip+ inte installerat Kalibrering skickad till xDrip+ BG - Dags att äta - Dags för bolus!\nKör Bolusguiden och gör beräkningar igen. Kommando körs just nu Basal understiger miniminivå. Profilen sattes inte. Behörighet diff --git a/implementation/src/main/res/values-tr-rTR/strings.xml b/implementation/src/main/res/values-tr-rTR/strings.xml index 7cdb7e4005..a8372bce29 100644 --- a/implementation/src/main/res/values-tr-rTR/strings.xml +++ b/implementation/src/main/res/values-tr-rTR/strings.xml @@ -3,8 +3,6 @@ xDrip+ uygulaması yüklenmemiş Kalibrasyon xDrip+ a gönderildi - Yemek zamanı - Bolus zamanı!\nBolus sihirbazını çalıştırın ve yeniden hesaplama yapın. Komut şu anda çalıştırıldı Bazal değer minimumun altında. Profil ayarlanmadı! Yetki diff --git a/implementation/src/main/res/values-zh-rCN/strings.xml b/implementation/src/main/res/values-zh-rCN/strings.xml index 7d9b1e84cd..2c1ec08e5b 100644 --- a/implementation/src/main/res/values-zh-rCN/strings.xml +++ b/implementation/src/main/res/values-zh-rCN/strings.xml @@ -3,8 +3,6 @@ 没有安装xDrip+ 校准发送到 xDrip+ 血糖 - 吃饭时间 - 输注胰岛素时间到了!\n请运行大剂量向导,然后再次进行计算。 现在命令被执行了 基础率值低于泵支持的最小值。配置文件没有设定 权限 diff --git a/plugins/automation/src/main/res/values-af-rZA/strings.xml b/plugins/automation/src/main/res/values-af-rZA/strings.xml index 6071a92bd3..d2cba784db 100644 --- a/plugins/automation/src/main/res/values-af-rZA/strings.xml +++ b/plugins/automation/src/main/res/values-af-rZA/strings.xml @@ -87,4 +87,5 @@ Snellers: Vereistes: + diff --git a/plugins/automation/src/main/res/values-bg-rBG/strings.xml b/plugins/automation/src/main/res/values-bg-rBG/strings.xml index e6a790c349..2e8f09e316 100644 --- a/plugins/automation/src/main/res/values-bg-rBG/strings.xml +++ b/plugins/automation/src/main/res/values-bg-rBG/strings.xml @@ -117,4 +117,6 @@ П С Н + + Време е за болус!\nВключи болус съветника и направи изчисление отново. diff --git a/plugins/automation/src/main/res/values-ca-rES/strings.xml b/plugins/automation/src/main/res/values-ca-rES/strings.xml index da4005636f..9bc7028faa 100644 --- a/plugins/automation/src/main/res/values-ca-rES/strings.xml +++ b/plugins/automation/src/main/res/values-ca-rES/strings.xml @@ -117,4 +117,6 @@ Dv Ds Dg + + Hora d’aplicar bolus!\nExecuteu l\'assistent de bolus i torneu a fer els càlculs. diff --git a/plugins/automation/src/main/res/values-cs-rCZ/strings.xml b/plugins/automation/src/main/res/values-cs-rCZ/strings.xml index 42e3c7c566..3d2f3e84ab 100644 --- a/plugins/automation/src/main/res/values-cs-rCZ/strings.xml +++ b/plugins/automation/src/main/res/values-cs-rCZ/strings.xml @@ -126,4 +126,7 @@ So Ne + + Čas k jídlu!\nSpusťte Bolusovou kalkulačku a proveďte výpočet znovu. + Čas na bolus!\nSpusťte Bolusovou kalkulačku a proveďte výpočet znovu. diff --git a/plugins/automation/src/main/res/values-da-rDK/strings.xml b/plugins/automation/src/main/res/values-da-rDK/strings.xml index 5f965468d2..8dd3478e8c 100644 --- a/plugins/automation/src/main/res/values-da-rDK/strings.xml +++ b/plugins/automation/src/main/res/values-da-rDK/strings.xml @@ -126,4 +126,6 @@ Fr + + Tid til bolus!\nKør Bolus-guiden og lav beregningen igen. diff --git a/plugins/automation/src/main/res/values-de-rDE/strings.xml b/plugins/automation/src/main/res/values-de-rDE/strings.xml index 401e8fb630..d7468ab9bf 100644 --- a/plugins/automation/src/main/res/values-de-rDE/strings.xml +++ b/plugins/automation/src/main/res/values-de-rDE/strings.xml @@ -126,4 +126,6 @@ Fr Sa So + + Zeit für den nächsten Bolus!\nFühre den Bolus-Assistenten aus, um die Berechnung erneut durchzuführen. diff --git a/plugins/automation/src/main/res/values-el-rGR/strings.xml b/plugins/automation/src/main/res/values-el-rGR/strings.xml index 0a64d4244e..3639370d1a 100644 --- a/plugins/automation/src/main/res/values-el-rGR/strings.xml +++ b/plugins/automation/src/main/res/values-el-rGR/strings.xml @@ -88,4 +88,5 @@ Ενεργοποιήσεις: Προϋποθέσεις: + diff --git a/plugins/automation/src/main/res/values-es-rES/strings.xml b/plugins/automation/src/main/res/values-es-rES/strings.xml index 355310430c..0955fe90a1 100644 --- a/plugins/automation/src/main/res/values-es-rES/strings.xml +++ b/plugins/automation/src/main/res/values-es-rES/strings.xml @@ -126,4 +126,7 @@ V S D + + ¡Hora de comer!\nEjecuta el asistente de bolo y calcula de nuevo. + ¡Hora de comer!\nEjecutar el asistente de bolo y calcular de nuevo. diff --git a/plugins/automation/src/main/res/values-fr-rFR/strings.xml b/plugins/automation/src/main/res/values-fr-rFR/strings.xml index 3d4d01bafd..f93499276f 100644 --- a/plugins/automation/src/main/res/values-fr-rFR/strings.xml +++ b/plugins/automation/src/main/res/values-fr-rFR/strings.xml @@ -126,4 +126,6 @@ V S D + + Il est temps de faire le bolus !\nExécutez l\'Assistant et faites de nouveau le calcul. diff --git a/plugins/automation/src/main/res/values-ga-rIE/strings.xml b/plugins/automation/src/main/res/values-ga-rIE/strings.xml index 7460b5a67a..64389c84ce 100644 --- a/plugins/automation/src/main/res/values-ga-rIE/strings.xml +++ b/plugins/automation/src/main/res/values-ga-rIE/strings.xml @@ -17,4 +17,5 @@ Riamh Gníomh: + diff --git a/plugins/automation/src/main/res/values-hr-rHR/strings.xml b/plugins/automation/src/main/res/values-hr-rHR/strings.xml index 8146812719..a9e556cff8 100644 --- a/plugins/automation/src/main/res/values-hr-rHR/strings.xml +++ b/plugins/automation/src/main/res/values-hr-rHR/strings.xml @@ -13,4 +13,6 @@ Pe Su Ne + + Vrijeme je za bolus!\nPokrenite čarobnjak za bolus i ponovite izračun. diff --git a/plugins/automation/src/main/res/values-hu-rHU/strings.xml b/plugins/automation/src/main/res/values-hu-rHU/strings.xml index 94dc40020d..54989ab1ed 100644 --- a/plugins/automation/src/main/res/values-hu-rHU/strings.xml +++ b/plugins/automation/src/main/res/values-hu-rHU/strings.xml @@ -26,4 +26,5 @@ Feladat neve SZERK + diff --git a/plugins/automation/src/main/res/values-it-rIT/strings.xml b/plugins/automation/src/main/res/values-it-rIT/strings.xml index 3a5f9103b5..996a86be31 100644 --- a/plugins/automation/src/main/res/values-it-rIT/strings.xml +++ b/plugins/automation/src/main/res/values-it-rIT/strings.xml @@ -126,4 +126,6 @@ V S D + + Tempo di fare un bolo!\nEsegui il calcolatore e fai di nuovi i calcoli. diff --git a/plugins/automation/src/main/res/values-iw-rIL/strings.xml b/plugins/automation/src/main/res/values-iw-rIL/strings.xml index 8f86752a1e..c91d3d325a 100644 --- a/plugins/automation/src/main/res/values-iw-rIL/strings.xml +++ b/plugins/automation/src/main/res/values-iw-rIL/strings.xml @@ -126,4 +126,6 @@ ו\' ש\' א\' + + זמן להזריק בולוס!\nהשתמשו במחשבון וחשבו מחדש. diff --git a/plugins/automation/src/main/res/values-ja-rJP/strings.xml b/plugins/automation/src/main/res/values-ja-rJP/strings.xml index 2a4513dffb..49a964a9e8 100644 --- a/plugins/automation/src/main/res/values-ja-rJP/strings.xml +++ b/plugins/automation/src/main/res/values-ja-rJP/strings.xml @@ -2,4 +2,5 @@ デルタ + diff --git a/plugins/automation/src/main/res/values-ko-rKR/strings.xml b/plugins/automation/src/main/res/values-ko-rKR/strings.xml index f4fe1d9b87..6ae81d9407 100644 --- a/plugins/automation/src/main/res/values-ko-rKR/strings.xml +++ b/plugins/automation/src/main/res/values-ko-rKR/strings.xml @@ -111,4 +111,5 @@ + diff --git a/plugins/automation/src/main/res/values-lt-rLT/strings.xml b/plugins/automation/src/main/res/values-lt-rLT/strings.xml index dc5742b296..4c9e4b76fd 100644 --- a/plugins/automation/src/main/res/values-lt-rLT/strings.xml +++ b/plugins/automation/src/main/res/values-lt-rLT/strings.xml @@ -119,4 +119,6 @@ Pn Š S + + Laikas bolusui!\nĮjunkite Skaičiuotuvą ir pakartokite skaičiavimus. diff --git a/plugins/automation/src/main/res/values-nl-rNL/strings.xml b/plugins/automation/src/main/res/values-nl-rNL/strings.xml index dba944f584..1b09437c7a 100644 --- a/plugins/automation/src/main/res/values-nl-rNL/strings.xml +++ b/plugins/automation/src/main/res/values-nl-rNL/strings.xml @@ -126,4 +126,6 @@ F S S + + Tijd om te bolussen!\nVoer de boluswizard uit en maak de berekening opnieuw. diff --git a/plugins/automation/src/main/res/values-no-rNO/strings.xml b/plugins/automation/src/main/res/values-no-rNO/strings.xml index c61bf347d3..07adfb90c3 100644 --- a/plugins/automation/src/main/res/values-no-rNO/strings.xml +++ b/plugins/automation/src/main/res/values-no-rNO/strings.xml @@ -126,4 +126,7 @@ F L S + + Nå må du spise!\nBruk bolus-veiviser og gjør beregning på nytt. + Tid for bolus!\nStart bolus-veiviser og gjør beregning på nytt. diff --git a/plugins/automation/src/main/res/values-pl-rPL/strings.xml b/plugins/automation/src/main/res/values-pl-rPL/strings.xml index b4060b648d..b2aa7f7531 100644 --- a/plugins/automation/src/main/res/values-pl-rPL/strings.xml +++ b/plugins/automation/src/main/res/values-pl-rPL/strings.xml @@ -122,4 +122,6 @@ P S N + + Czas na bolus!\nUruchom Kalkulator bolusa aby ponownie wykonać obliczenia. diff --git a/plugins/automation/src/main/res/values-pt-rBR/strings.xml b/plugins/automation/src/main/res/values-pt-rBR/strings.xml index 8e021ba8fc..43c664df79 100644 --- a/plugins/automation/src/main/res/values-pt-rBR/strings.xml +++ b/plugins/automation/src/main/res/values-pt-rBR/strings.xml @@ -126,4 +126,6 @@ 6a Sáb Dom + + Hora do bolus!\nAbra o assistente de bolus e faça o cálculo novamente. diff --git a/plugins/automation/src/main/res/values-pt-rPT/strings.xml b/plugins/automation/src/main/res/values-pt-rPT/strings.xml index f4771665f5..83970b1316 100644 --- a/plugins/automation/src/main/res/values-pt-rPT/strings.xml +++ b/plugins/automation/src/main/res/values-pt-rPT/strings.xml @@ -117,4 +117,6 @@ Se Sa D + + Hora de fazer o bólus!\nExecute o assistente de bólus e faça o cálculo novamente. diff --git a/plugins/automation/src/main/res/values-ro-rRO/strings.xml b/plugins/automation/src/main/res/values-ro-rRO/strings.xml index 2736a14a20..fc3fd75f29 100644 --- a/plugins/automation/src/main/res/values-ro-rRO/strings.xml +++ b/plugins/automation/src/main/res/values-ro-rRO/strings.xml @@ -119,4 +119,6 @@ V S D + + Timpul sa faci bolus!\nRuleaza Calculatorul de Bolus pentru a face calculele din nou. diff --git a/plugins/automation/src/main/res/values-ru-rRU/strings.xml b/plugins/automation/src/main/res/values-ru-rRU/strings.xml index 2362aa54e9..94eb511d5d 100644 --- a/plugins/automation/src/main/res/values-ru-rRU/strings.xml +++ b/plugins/automation/src/main/res/values-ru-rRU/strings.xml @@ -126,4 +126,6 @@ Пт Сб Вс + + Пора дать болюс!\nЗапустите помощник болюса и повторите расчет. diff --git a/plugins/automation/src/main/res/values-sk-rSK/strings.xml b/plugins/automation/src/main/res/values-sk-rSK/strings.xml index 6ed3b36e83..bc2f95cded 100644 --- a/plugins/automation/src/main/res/values-sk-rSK/strings.xml +++ b/plugins/automation/src/main/res/values-sk-rSK/strings.xml @@ -126,4 +126,6 @@ Pi So Ne + + Čas na bolus!\nSpustite Bolusovú kalkulačku a urobte výpočet znova. diff --git a/plugins/automation/src/main/res/values-sr-rCS/strings.xml b/plugins/automation/src/main/res/values-sr-rCS/strings.xml index e6bafe046d..b73b1e1ef6 100644 --- a/plugins/automation/src/main/res/values-sr-rCS/strings.xml +++ b/plugins/automation/src/main/res/values-sr-rCS/strings.xml @@ -2,4 +2,5 @@ Delta + diff --git a/plugins/automation/src/main/res/values-sv-rSE/strings.xml b/plugins/automation/src/main/res/values-sv-rSE/strings.xml index 66e28d04e2..aa0e8d2e4b 100644 --- a/plugins/automation/src/main/res/values-sv-rSE/strings.xml +++ b/plugins/automation/src/main/res/values-sv-rSE/strings.xml @@ -117,4 +117,6 @@ F L S + + Dags för bolus!\nKör Bolusguiden och gör beräkningar igen. diff --git a/plugins/automation/src/main/res/values-tr-rTR/strings.xml b/plugins/automation/src/main/res/values-tr-rTR/strings.xml index d3994580c3..66d19eade8 100644 --- a/plugins/automation/src/main/res/values-tr-rTR/strings.xml +++ b/plugins/automation/src/main/res/values-tr-rTR/strings.xml @@ -126,4 +126,6 @@ Cum Cmt Paz + + Bolus zamanı!\nBolus sihirbazını çalıştırın ve yeniden hesaplama yapın. diff --git a/plugins/automation/src/main/res/values-zh-rCN/strings.xml b/plugins/automation/src/main/res/values-zh-rCN/strings.xml index 2ba9c3f206..80659e0799 100644 --- a/plugins/automation/src/main/res/values-zh-rCN/strings.xml +++ b/plugins/automation/src/main/res/values-zh-rCN/strings.xml @@ -125,4 +125,6 @@ 周五 周六 周日 + + 输注胰岛素时间到了!\n请运行大剂量向导,然后再次进行计算。 diff --git a/plugins/constraints/src/main/res/values-af-rZA/exam.xml b/plugins/constraints/src/main/res/values-af-rZA/exam.xml index 4a1657dcab..34e814725d 100644 --- a/plugins/constraints/src/main/res/values-af-rZA/exam.xml +++ b/plugins/constraints/src/main/res/values-af-rZA/exam.xml @@ -13,30 +13,9 @@ https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#what-emergency-equipment-is-recommended-to-take-with-me Wat moet gedoen word as CGM data raserig is? https://androidaps.readthedocs.io/en/latest/EN/Usage/Smoothing-Blood-Glucose-Data-in-xDrip.html#smoothing-blood-glucose-data - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#androidaps-settings \'n Google-rekening. \'n Github rekening. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html \'n Slimhorlosie. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html - Kyk al die korrekte antwoorde. - https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#update-to-a-new-version-or-branch - https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting - https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - Fiasp® - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html#insulin - Kyk al die korrekte antwoorde. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#insulin-to-carb-ratio-ic-g-u - https://androidaps.readthedocs.io/en/latest/EN/Usage/Extended-Carbs.html - https://androidaps.readthedocs.io/en/latest/EN/Children/Children.html - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#insulin-sensitivity-factor-isf-mmol-l-u-or-mg-dl-u - https://androidaps.readthedocs.io/en/latest/EN/Usage/Profiles.html - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#carbohydrate-to-insulin-ratio-cr-g-u https://androidaps.readthedocs.io/en/latest/EN/Usage/Profiles.html?highlight=profile%20switch#profile-switch - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html#good-individual-dosage-algorithm-for-your-diabetes-therapy diff --git a/plugins/constraints/src/main/res/values-af-rZA/strings.xml b/plugins/constraints/src/main/res/values-af-rZA/strings.xml index c66f78b6b8..960ad5f64e 100644 --- a/plugins/constraints/src/main/res/values-af-rZA/strings.xml +++ b/plugins/constraints/src/main/res/values-af-rZA/strings.xml @@ -4,10 +4,26 @@ - ou weergawe - baie ou weergawe - Die weergawe is ongeldig. Lus afgeskakel! - Weergawe %1$s beskikbaar + + Beperk koolhidrate tot %1$d g agv %2$s + Pomp is nie tydelike basale bekwame + Geslote lus modus in voorkeure gedeaktiveer + Veranderende ontwikkelende weergawe. Geslote lus is gedeaktiveerd. + SMB is altyd na koolhidrate versper omdat aktiewe BG bron nie gevorderde filter ondersteun nie + SMB nie toegelaat in open lus modus + maks waarde in voorkeure + harde limiet + Behandelings veiligheid + + Nog nie voltooi nie + Tydsverloop + Maksimum IAB behoorlik gestel + BG beskikbaar vanaf geselekteerde bron + Lus geaktiveer + APS gekies + Geslote modus geaktiveer + OBJ + Onderrig program diff --git a/plugins/constraints/src/main/res/values-bg-rBG/strings.xml b/plugins/constraints/src/main/res/values-bg-rBG/strings.xml index 87f2d26078..55a4248b4d 100644 --- a/plugins/constraints/src/main/res/values-bg-rBG/strings.xml +++ b/plugins/constraints/src/main/res/values-bg-rBG/strings.xml @@ -2,18 +2,32 @@ - Смяна на времето след по-малко от 24ч - Смяна на времето след по-малко от 3 часа - минавам в отворен режим - стара версия - много стара версия - Прилагането изтече - Има нова версия от най-малко %1$d дни! Ще спре подаването на инсулин след %2$d дни, цикълът ще бъде изключен след %3$d дни - Използвате грешна версия. APS е изключен! - Има налично обновяване до версия %1$s - Рекалкулирани използвани данни - КЗ близо до:\n%1$s\n%2$s + + Ограничаване на въглехидрати до %1$d гр. поради %2$s + Помпата не поддържа временен базал + Затворения кръг е забранен в настройките + Използвате dev версия. Затворения кръг е недостъпен за Вас. + Затворен цикъл е недостъпен поради стартиран Удължен болус + SMB \"винаги включен\" и \"след въглехидрати\" е забранен, защото е активен източник на КЗ, който не поддържа необходимата филтрация + SMB не е позволен в режим Отворен кръг + макс. стойност в настройките + твърд лимит + Настройки на сигурността + + Все още не сме неприключили + Изминало време + Максимален IOB е зададен правилно + Има данни за КЗ от избрания източник + APS разрешен + Избран APS + APS - Затворен кръг е позволен + Цел + Разучаване на програмата + Искате ли да нулирате прогреса си? + Изчисти приключение + Изчисти стартираните diff --git a/plugins/constraints/src/main/res/values-ca-rES/exam.xml b/plugins/constraints/src/main/res/values-ca-rES/exam.xml index 5246dd2fa2..514d2315d1 100644 --- a/plugins/constraints/src/main/res/values-ca-rES/exam.xml +++ b/plugins/constraints/src/main/res/values-ca-rES/exam.xml @@ -55,7 +55,6 @@ Deixar l\'objectiu glucèmic com està. Esperar que la glucèmia baixi per sota del vostre objectiu temporal d\'hipoglucèmia i llavors prendre 15g de carbohidrats d\'acció ràpida. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Llaç desactivat/aturat Rebo insulina quan el llaç està desactivat/aturat? Sí, la insulina basal es continua lliurant. No, s\'atura el lliurament d\'insulina. @@ -99,8 +98,6 @@ Preguntant a la clínica on us porten la diabetis o a la vostra endocrinòloga. https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - Plugins d\'insulina Quina insulina s\'ha de fer servir amb el plugin Ultra-Rapid Oref? Fiasp® NovoRapid®/Novolog® @@ -113,7 +110,6 @@ L\'enregistrament d\'un canvi de cànula restableix la ràtio Autosens, deixant-lo de nou a un 100%. Algunes de les opcions de plugins es poden configurar segons rangs horaris que poden ser definits per l\'usuari. https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Errors d\'entrada de carbohidrats Què cal fer si feu una entrada incorrecta de carbohidrats? Elimineu la entrada incorrecta a Tractaments i introduïu el valor correcte de carbohidrats. @@ -123,7 +119,6 @@ Què cal fer si rebeu menys insulina de la que suggereix l\'historial de la bomba, p.ex. degut a una oclusió, a una cànula que no funciona o un oblit de reconnexió de la bomba després d\'una dutxa? Eliminar dades d\'insulina del portal de cures Nightscout per eliminar-les de l\'historial de la bomba. Lliurar un bolus amb part de la insulina que falta utilitzant una jeringa/ploma o el menú d\'encebat. - Insulina \"a bord\" (IOB) El valor d\'IOB es veu afectat per les basals temporals lliurades. Una basal temporal alta no serà lliurada si la glucèmia està per sota de l\'objectiu. Un valor d\'IOB negatiu durant un període de temps important i en absència d\'exercici físic suggereix que el vostre perfil és massa \"fort\" i necessiteu menys insulina en la vostra configuració. diff --git a/plugins/constraints/src/main/res/values-ca-rES/strings.xml b/plugins/constraints/src/main/res/values-ca-rES/strings.xml index 624e14fdb0..e9bb0c21b8 100644 --- a/plugins/constraints/src/main/res/values-ca-rES/strings.xml +++ b/plugins/constraints/src/main/res/values-ca-rES/strings.xml @@ -2,19 +2,32 @@ - Canvi a horari d\'estiu en 24h o menys - Canvi a horari d\'estiu fa menys de 3h - Llaç tancat desactivat - versió antiga - versió molt antiga - Aplicació expirada - Nova versió disponible almenys %1$d dies! Retorn a LGS (Low Glucose Suspend = suspensió per glucèmia baixa) en %2$d dies, el llaç serà desactivat en %3$d dies - Hem detectat que esteu executant una versió no vàlida. Llaç desactivat! - Versió %1$s disponible - Versió: %1$s | Mida: %2$s - Dades recalculades utilitzades - Glucèmia massa semblant: \n%1$s\n%2$s + + Limitant carbs a %1$d g a causa de %2$s + La bomba no té la funcionalitat de basals temporals + Mode llaç tancat desactivat a la configuració + Executant versió de desenvolupament. Llaç tancat no disponible. + Llaç tancat desactivat degut a bolus estès actiu + Les funcions \"SMB sempre\" i \"SMB després de carbohidrats\" estan desactivades pq la font de glucèmia no fa filtrat avançat + SMB no permès en mode llaç obert + valor màxim a la configuració + límit estricte + Seguretat tractaments + + No finalitzat encara + Temps transcorregut + Màx IOB correctament configurada + Glucèmia disponible des de la font seleccionada + Llaç activat + APS seleccionat + Llaç tancat activat + OBJ + Programa d\'aprenentatge + Voleu reiniciar l\'objectiu? Podeu perdre el vostre progrés. + Cancel·lar finalització + Cancel·lar inici diff --git a/plugins/constraints/src/main/res/values-cs-rCZ/exam.xml b/plugins/constraints/src/main/res/values-cs-rCZ/exam.xml index f9a9292403..f0732757a8 100644 --- a/plugins/constraints/src/main/res/values-cs-rCZ/exam.xml +++ b/plugins/constraints/src/main/res/values-cs-rCZ/exam.xml @@ -59,7 +59,6 @@ Nechte svůj cíl glykémie beze změny. Počkejte, dokud glykémie neklesne pod Váš dočasný cíl hypoglykémie a pak snězte15 g rychlých sacharidů. https://androidaps.readthedocs.io/en/latest/CROWDIN/cs/Usage/temptarget.html#docasny-cil-pri-pohybove-aktivite - Zakázaná/pozastavená smyčka Dostávám inzulín, když je smyčka zakázána/pozastavena? Ano, bazální inzulín se dále dodává. Ne, podávání inzulínu je zastaveno. @@ -149,7 +148,6 @@ Nastavením profilu na 150 % dojde k prodloužení doby absorpce sacharidů Nastavením profilu na 150 % dojde ke zkrácení doby absorpce sacharidů Nastavení profilu na 150% neovlivní vypočtenou absorpci sacharidů - Aktivní inzulín (IOB) Hodnota IOB je ovlivněna vydanými dočasnými bazály. Vysoký dočasný bazál nebude spuštěn, pokud je Vaše glykémie nižší než cíl. Negativní IOB po značnou dobu bez cvičení naznačuje, že váš profil je příliš \"silný\" a ve vašem profilu je potřeba méně inzulínu. diff --git a/plugins/constraints/src/main/res/values-cs-rCZ/strings.xml b/plugins/constraints/src/main/res/values-cs-rCZ/strings.xml index 30758c945d..5356c4ed95 100644 --- a/plugins/constraints/src/main/res/values-cs-rCZ/strings.xml +++ b/plugins/constraints/src/main/res/values-cs-rCZ/strings.xml @@ -19,5 +19,35 @@ Použita přepočítaná data Glykémie je příliš blízko:\n%1$s\n%2$s přepočítáno - dvojité položky + zdvojené záznamy + Neměnná data. Pravděpodobně jsou neplatná + + Prodloužený bolus omezen na %1$.1f U z důvodu %2$s + Sacharidy omezeny na %1$d g: %2$s + Pumpa nepodporuje dočasné bazály + Uzavřená smyčka zakázána v nastavení + Běží DEV verze. Uzavřená smyčka je zakázána. + Uzavřená smyčka je zastavena kvůli běžícímu prodlouženému bolusu + \"SMB vždy\" a \"po jídle\" zakázáno protože zdroj glykémie nepodporuje rozšířené filtrování + SBM není povoleno v otevřené smyčce + maximální hodnota v nastavení + pevný limit + Bezpečnost zadání ošetřeni + + Hotovo, gratulujeme! + Nedokončeno + Čas + Maximální IOB nastaveno správně + Glykémie dostupné z vybraného zdroje + Služba synchronizace má oprávnění k zápisu + Smyčka povolena + APS vybráno + Uzavřená smyčka povolena + CÍLE + Výukový program + Chcete resetovat začátek cíle? Můžete přijít o svůj pokrok. + Další + Zpět + Vymazat dokončeno + Vymazat start diff --git a/plugins/constraints/src/main/res/values-da-rDK/exam.xml b/plugins/constraints/src/main/res/values-da-rDK/exam.xml index 80b7c1e5dd..4adb828d08 100644 --- a/plugins/constraints/src/main/res/values-da-rDK/exam.xml +++ b/plugins/constraints/src/main/res/values-da-rDK/exam.xml @@ -59,7 +59,6 @@ Lad dit blodsukker være uændret. Vent, til blodsukkeret falder under din midlertidige hypo-basal, og spis 15g hurtigt virkende kulhydrater. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Deaktiveret/Suspendéret Loop Modtager jeg insulin, når Loop er deaktiveret/suspenderet? Ja, basal insulin fortsætter med at blive levereret. Nej, levering af insulin er stoppet. @@ -109,7 +108,6 @@ https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ https://discord.gg/4fQUWHZ4Mw - Insulin Plugins Hvilken insulin skal du bruge sammen med Ultra-Rapid Oref-pluginnet? Fiasp® NovoRapid®/Novolog® @@ -149,7 +147,6 @@ Ved indstilling af profil til 150%, vil kulhydrater være længere tid om at absorberes Ved indstilling af profil til 150%, vil kulhydrater være kortere tid om at absorberes Ved indstilling af profil til 150%, påvirkes absorbering af beregnet kulhydrat ikke - Insulin om bord (IOB) IOB-værdi påvirkes af midlertidige basaler. Høj midlertidlig basal vil ikke blive givet, når dit blodsukker er under målet. Negative IOB i en længere periode uden motion tyder på, at din profil er for stærk, og at der er behov for mindre insulin i dine indstillinger. diff --git a/plugins/constraints/src/main/res/values-da-rDK/strings.xml b/plugins/constraints/src/main/res/values-da-rDK/strings.xml index 10d59aee65..05ae83b335 100644 --- a/plugins/constraints/src/main/res/values-da-rDK/strings.xml +++ b/plugins/constraints/src/main/res/values-da-rDK/strings.xml @@ -2,21 +2,32 @@ - Sommertids ændring inden de næste 24 timer eller mindre - Sommertids ændring mindre end 3 timer siden - Lukket loop deaktiveret - gammel version - meget gammel version - Applikationen er udløbet - Ny version har været tilgængelig i mindst %1$d dage! Falder til LGS efter %2$d dage, loop vil blive deaktiveret efter %3$d dage - Vi har opdaget, at du kører en ugyldig version. Loop deaktiveret! - Version %1$s tilgængelig - Version %1$s udløber den %2$s - Genberegnede data anvendt - BG for tæt:\n%1$s\n%2$s - genberegnet - dobbelt postering + + Begrænser kulhydrater til %1$d g på grund af %2$s + Pumpe er ikke egnet til midlertidig basal + Lukket loop tilstand deaktiveret i præferencer + Kører dev version. Lukket loop er deaktiveret. + Lukket loop deaktiveret på grund af kørsel af forlænget bolus + SMB altid og efter kulhydrater deaktiveret, fordi den aktive BS kilde ikke understøtter avanceret filtrering + SMB er ikke tilladt i åben loop mode + max værdi i præferencer + hård grænse + Behandlings sikkerhed + + Ikke afsluttet endnu + Tid forløbet + Maksimal IOB sat korrekt + BS tilgængelig fra valgte kilde + Loop aktiveret + APS valgt + Lukket tilstand aktiveret + OBJ + Oplæringsprogram + Vil du nulstille objektiv start? Du kan miste dine fremskridt. + Ryd færdigt + Ryd startet diff --git a/plugins/constraints/src/main/res/values-de-rDE/exam.xml b/plugins/constraints/src/main/res/values-de-rDE/exam.xml index a2a18e2baa..670ac4c7f2 100644 --- a/plugins/constraints/src/main/res/values-de-rDE/exam.xml +++ b/plugins/constraints/src/main/res/values-de-rDE/exam.xml @@ -20,6 +20,8 @@ Nichts, da kein Insulin abgegeben wird, wenn die Pumpe physisch getrennt ist. Unterbricht die Insulinzufuhr nicht, wenn die Pumpe physikalisch verbunden bleibt. https://androidaps.readthedocs.io/en/latest/CROWDIN/de/Getting-Started/FAQ.html#andere-einstellungen + AAPS-Einstellungen + AAPS-Einstellungen Welches ist die empfohlene Vorgehensweise, um ein Backup Deiner Einstellungen zu erstellen? Du brauchst Deine Einstellungen nicht zu exportieren, sofern Du Dir diese notierst. Exportiere die Einstellungen nach Abschluss eines Objectives (Ziels). @@ -51,7 +53,6 @@ Lasse Dein Blutzuckerziel unverändert. Warte, bis die Blutglukose unter das temporäre Hypoziel abfällt und esse dann 15 g schnell wirkende Kohlenhydrate. https://androidaps.readthedocs.io/en/latest/CROWDIN/de/Usage/temptarget.html#aktivitaten-temp-target - Deaktiviere/Pausiere den Loop Bekomme ich Insulin, wenn der Loop deaktiviert/pausiert ist? Ja, Basalinsulin wird weiter abgegeben. Nein, die Insulinabgabe ist gestoppt. @@ -79,8 +80,10 @@ Voraussetzungen Überprüfte und belastbare Profileinstellungen (ISF, I:C Verhältnis, Basalraten, DIA etc.). Ein kompatibles Android-Gerät (z.B. Handy, Android-Uhr oder Tablet). + AAPS benötigt eine Internetverbindung, um im Closed Loop laufen zu können. Ein unterstütztes CGM und eine passende App, um Blutzuckerwerte auf dem Gerät zu erhalten. https://androidaps.readthedocs.io/en/latest/CROWDIN/de/Module/module.html + Aktualisiere AAPS Kreuze alle richtigen Antworten an. Du musst Git auf Deinem Computer installiert und konfiguriert haben. Du solltest den Speicherort des Keystores speichern und immer den gleichen Signaturschlüssel für Updates verwenden wie für die vorherige Installation. @@ -88,11 +91,11 @@ Wenn Du Schwierigkeiten beim Erstellen der apk hast, kannst Du eine apk installieren, die von einem Freund erstellt wurde. https://androidaps.readthedocs.io/en/latest/CROWDIN/de/Installing-AndroidAPS/Update-to-new-version.html Problembehandlung + Wo können Sie nach Hilfe bei AAPS suchen? Du solltest Deine Diabetesklinik / Deinen Diabetologen fragen. https://androidaps.readthedocs.io/en/latest/CROWDIN/de/Installing-AndroidAPS/Update-to-new-version.html#problembehandlung https://www.facebook.com/groups/loopedDE/ https://discord.gg/4fQUWHZ4Mw - Insulin-Plugins Welches Insulin kann mit dem Ultra-Rapid-Oref-Plugin verwendet werden? Fiasp® NovoRapid®/Novolog® @@ -128,7 +131,6 @@ Die Einstellung des Profils auf 150% verlängert die Zeit für Kohlenhydrataufnahme Die Einstellung des Profils auf 150% verkürzt die Zeit für Kohlenhydrataufnahme Die Einstellung des Profils auf 150% verändert die Zeit für die Kohlenhydrataufnahme nicht - Aktives Insulin (IOB) IOB wird von den abgegebenen temporären Basalraten beeinflusst. Eine hohe temporäre Basalrate wird nicht abgegeben, wenn der BZ unterhalb des Zielwerts liegt. Ein negativer IOB über einen längeren Zeitraum bei fehlender Bewegung deutet darauf hin, dass Dein Profil zu stark ist und weniger Insulin in Deinen Einstellungen benötigt wird. diff --git a/plugins/constraints/src/main/res/values-de-rDE/strings.xml b/plugins/constraints/src/main/res/values-de-rDE/strings.xml index b7796ca7ed..871093f4f9 100644 --- a/plugins/constraints/src/main/res/values-de-rDE/strings.xml +++ b/plugins/constraints/src/main/res/values-de-rDE/strings.xml @@ -2,21 +2,31 @@ - Zeitumstellung in weniger als 24 Stunden - Zeitumstellung vor weniger als 3 Stunden - Closed Loop deaktiviert - Vorherige Version - sehr alte Version - Anwendung abgelaufen - Neue Version seit mindestens %1$d Tagen verfügbar! Rückfall zur sensorunterstützten Pumpentherapie nach %2$d Tagen, Loop wird nach %3$d Tagen deaktiviert. - Wir haben festgestellt, dass Du eine ungültige Version verwendest. Loop deaktiviert! - Version %1$s ist verfügbar. - Version %1$s läuft am %2$s ab - Verwendete Daten neu berechnet - BZ zu nah:\n%1$s\n%2$s - neu berechnet - doppelte Einträge + + Begrenze Kohlenhydrate auf %1$d g wegen %2$s + Pumpe verfügt nicht über temporäre Basalraten + Closed-Loop-Modus in den Einstellungen deaktiviert + Entwickler-Version, Closed Loop ist nicht verfügbar. + Closed Loop wegen Verzögerungsbolus unterbrochen + SMB wird immer und nach Kohlenhydraten deaktiviert, weil die aktive BZ-Quelle keine geeignete Filterung der Werte unterstützt. + SMB sind im Open Loop Modus nicht erlaubt + Max. Wert in den Einstellungen + festem Grenzwert + Sicherheitseinstellungen der Behandlungen + + Verstrichene Zeit + Maximales IOB richtig gesetzt + BZ verfügbar von gewählter Quelle + Loop aktiviert + APS ausgewählt + Closed mode aktiviert + ZIEL + Das Programm kennenlernen + Möchtest Du den Start der Ziele zurücksetzen? Du verlierst Deine Fortschritte. + Ziel erneut öffnen + Ziel neu starten diff --git a/plugins/constraints/src/main/res/values-el-rGR/exam.xml b/plugins/constraints/src/main/res/values-el-rGR/exam.xml index fe556808fa..fdce573d26 100644 --- a/plugins/constraints/src/main/res/values-el-rGR/exam.xml +++ b/plugins/constraints/src/main/res/values-el-rGR/exam.xml @@ -2,7 +2,6 @@ Ποια είναι η αλήθεια για το DIA; https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html?#insulin - Υπογλυκαιμικός Ρυθμός-Στόχος https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html Ποιο προφίλ μπορεί να χρησιμοποιηθεί και να διαμορφωθεί χωρίς σύνδεση; Θέμα: Προφίλ Εκτός Σύνδεσης @@ -14,7 +13,6 @@ https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#what-emergency-equipment-is-recommended-to-take-with-me Τι πρέπει να κάνετε αν τα δεδομένα του CGM έχουν θόρυβο; https://androidaps.readthedocs.io/en/latest/EN/Usage/Smoothing-Blood-Glucose-Data-in-xDrip.html#smoothing-blood-glucose-data - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target Λαμβάνω ινσουλίνη όταν το κύκλωμα είναι απενεργοποιημένο/αναστολή; Ναι, ο βασικός ρυθμός συνεχίζει να χορηγείται. @@ -29,22 +27,15 @@ https://androidaps.readthedocs.io/en/latest/EN/Module/module.html Ένα Smartwatch. Ένα Υποστηριζόμενο CGM. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html - Ελέγξτε όλες τις σωστές απαντήσεις. Ποτέ μην αναβαθμίζετε εάν το σύστημα λειτουργεί καλά. https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#update-to-a-new-version-or-branch - Αντιμετώπιση προβλημάτων https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw Fiasp® Humalog® https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html#insulin - Ελέγξτε όλες τις σωστές απαντήσεις. https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Τι πρέπει να κάνετε αν γίνει μια λανθασμένη εισαγωγή υδατανθράκων; - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#insulin-to-carb-ratio-ic-g-u e-carbs https://androidaps.readthedocs.io/en/latest/EN/Usage/Extended-Carbs.html https://androidaps.readthedocs.io/en/latest/EN/Children/Children.html @@ -54,8 +45,6 @@ Αν έχετε 0 COB Ενεργούς Υδατ., αλλάζοντας την αναλογία IC θα οδηγήσει σε μια διαφορετική ποσότητα ινσουλίνης για να διορθωθεί μια συγκεκριμένη τιμή BG. https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#carbohydrate-to-insulin-ratio-cr-g-u https://androidaps.readthedocs.io/en/latest/EN/Usage/Profiles.html?highlight=profile%20switch#profile-switch - Ξεκινήστε μία αλλαγή προφίλ με χρονική μετατόπιση 2 - Ξεκινήστε μία αλλαγή προφίλ με χρονική μετατόπιση -2 https://androidaps.readthedocs.io/en/latest/EN/Usage/Profiles.html?highlight=profile%20switch#timeshift https://androidaps.readthedocs.io/en/latest/EN/Module/module.html#good-individual-dosage-algorithm-for-your-diabetes-therapy Πού θα πάτε για βοήθεια με Βασικό ρυθμό κτλ. diff --git a/plugins/constraints/src/main/res/values-el-rGR/strings.xml b/plugins/constraints/src/main/res/values-el-rGR/strings.xml index 5c05d758c6..9478ce1b3f 100644 --- a/plugins/constraints/src/main/res/values-el-rGR/strings.xml +++ b/plugins/constraints/src/main/res/values-el-rGR/strings.xml @@ -4,10 +4,26 @@ - παλιά έκδοση - πολύ παλιά έκδοση - Διαπιστώσαμε ότι εκτελείτε μη έγκυρη έκδοση. Κύκλωμα απενεργοποιήθηκε! - Έκδοση %1$s διαθέσιμη + + Περιορίζονται οι υδατάνθρακες σε %1$d g λόγω %2$s + Η αντλία δεν υποστηρίζει προσωρινό βασικό ρυθμό + Το κλειστό κύκλωμα είναι απενεργοποιημένο στις Επιλογές + Εκτελείται έκδοση Dev. Το κλειστό κύκλωμα είναι απενεργοποιημένο. + Το SMB πάντα και μετά το γεύμα απενεργοποιείται επειδή η ενεργή πηγή BG δεν υποστηρίζει προηγμένο φιλτράρισμα + To SMB δεν επιτρέπεται σε λειτουργία ανοιχτού κυκλώματος + μέγιστη τιμή στις Επιλογές + σταθερό όριο + Ασφάλεια Θεραπειών + + Δεν ολοκληρώθηκε ακόμη + Ο χρόνος που πέρασε + Το μέγιστο IOB έχει ρυθμιστεί σωστά + BG διαθέσιμη από επιλεγμένη πηγή + Κύκλωμα ενεργοποιημένο + Επιλέχθηκε APS + Ενεργοποιήθηκε η κλειστή λειτουργία + ΣΤΟΧΟΙ + Πρόγραμμα εκμάθησης diff --git a/plugins/constraints/src/main/res/values-es-rES/exam.xml b/plugins/constraints/src/main/res/values-es-rES/exam.xml index 5ef973f368..090ccceaa9 100644 --- a/plugins/constraints/src/main/res/values-es-rES/exam.xml +++ b/plugins/constraints/src/main/res/values-es-rES/exam.xml @@ -59,7 +59,6 @@ Deja tu objetivo de glucosa sanguíneo sin cambios. Espere hasta que la glucosa en sangre caiga por debajo de su objetivo de hipo temp y luego coma 15 g de hidratos de carbono de actividad rápida. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Desactiva/suspende el lazo ¿Recibo insulina cuando el lazo está desactivado/suspendido? Sí, la insulina basal sigue siendo entregada. No, la administración de la insulina está detenida. @@ -149,7 +148,6 @@ Establecer el perfil a 150% hará que los carbohidratos se absorban más lentamente Establecer el perfil a 150% hará que los carbohidratos se absorban más rápidamente Establecer el perfil a 150% no afectará la absorción calculada de carbohidratos - Insulina a bordo (IOB) El valor del IOB se ve afectado por las bases temporales ejecutadas. No se dará alta tasa basal temporal cuando su nivel de azúcar en sangre esté por debajo del objetivo. El IOB negativo durante un período sustancial en ausencia de ejercicio sugiere que tu perfil es demasiado fuerte y que se necesita menos insulina en tus ajustes. diff --git a/plugins/constraints/src/main/res/values-es-rES/strings.xml b/plugins/constraints/src/main/res/values-es-rES/strings.xml index d357cb7287..2a9a98586f 100644 --- a/plugins/constraints/src/main/res/values-es-rES/strings.xml +++ b/plugins/constraints/src/main/res/values-es-rES/strings.xml @@ -5,7 +5,7 @@ Cambio al horario de verano en menos de 24 horas Cambio al horario de verano hace menos de 3 horas - Lazo cerrado deshabilitado - Debe liberar al menos %1$d MB de almacenamiento interno. ¡Loop se encuentra desactivado! + Debe liberar al menos %1$d MB de almacenamiento interno. ¡El lazo se encuentra desactivado! versión antigua versión muy antigua @@ -20,4 +20,34 @@ Datos de glucosa demasiado cercanos:\n%1$s\n%2$s recalculado entradas dobles + Datos planos. Considerados erróneos + + Limitando el bolo extendido a %1$.1f U debido a %2$s + Limitando carbohidratos a %1$d g debido a %2$s + La bomba no tiene capacidad de basal temporal + Lazo cerrado deshabilitado en preferencias + Ejecutando la versión dev. Lazo cerrado no disponible. + Lazo cerrado deshabilitado debido a la ejecución de un bolo extendido + SMB siempre y después de carbohidratos desactivados porque la fuente activa de BG no soporta filtrado avanzado + SMB no permitido en modo de lazo abierto + valor máximo en preferencias + límite estricto + Seguridad de tratamientos + + ¡Completado, bien hecho! + No completado + Tiempo agotado + Máximo IOB ajustado correctamente + Glucosa disponible desde la fuente seleccionada + El servicio de sincronización tiene permiso de escritura + Lazo activado + APS seleccionado + Lazo cerrado activado + OBJ + Programa de aprendizaje + ¿Desea reiniciar el objetivo? Puedes perder tu progreso. + Siguiente + Anterior + Limpieza finalizada + Limpieza iniciada diff --git a/plugins/constraints/src/main/res/values-fr-rFR/exam.xml b/plugins/constraints/src/main/res/values-fr-rFR/exam.xml index c865261ea0..60e78065a4 100644 --- a/plugins/constraints/src/main/res/values-fr-rFR/exam.xml +++ b/plugins/constraints/src/main/res/values-fr-rFR/exam.xml @@ -59,7 +59,6 @@ Laissez votre cible de glycémie inchangée. Attendez que la glycémie tombe en dessous de votre cible temporaire d\'hypo, puis mangez 15 g de glucides à action rapide. https://androidaps.readthedocs.io/en/latest/CROWDIN/fr/Usage/temptarget.html#activity-temp-target - Boucle désactivée/suspendue Est-ce que je reçois de l\'insuline lorsque la boucle est désactivée / suspendue ? Oui, l\'insuline basale continue à être délivrée. Non, l\'injection d\'insuline est arrêtée. @@ -149,7 +148,6 @@ Définir le profil à 150% rendra l\'absorption des glucides plus longue Définir le profil à 150% réduira le temps d\'absorption des glucides Définir le profil à 150% n\'impactera pas le calcul de l\'absorption des glucides - Insuline Active (IA) La valeur de l\'IA est impactée par les débits de basal temporaires émis. Une basale temp haute ne sera pas donnée quand votre glycémie est en dessous de la cible. Une IA négative pendant une période significative en l\'absence d\'exercice indique que votre profil est trop fort et qu\'il faut moins d\'insuline dans vos paramètres. diff --git a/plugins/constraints/src/main/res/values-fr-rFR/strings.xml b/plugins/constraints/src/main/res/values-fr-rFR/strings.xml index aa028b63ec..4e6f7bd219 100644 --- a/plugins/constraints/src/main/res/values-fr-rFR/strings.xml +++ b/plugins/constraints/src/main/res/values-fr-rFR/strings.xml @@ -2,22 +2,37 @@ - Changement d\'heure d\'été/hiver dans moins de 24 heures - Changement d\'heure dans moins de 3 heures - Boucle fermée désactivée - Boucle désactivée ! Libérez au moins %1$d Mo du stockage interne ! - ancienne version - très ancienne version - Application expirée - Nouvelle version disponible depuis %1$d jours ! Retour à Arrêt Glycémie Basse (AGB) dans %2$d jours, la boucle sera désactivée dans %3$d jours - Nous avons détecté que vous utilisez une version invalide. Boucle désactivée ! - Version %1$s disponible - La version %1$s expire le %2$s - Données recalculées utilisées - Gly trop proche :\n%1$s\n%2$s - recalculé - entrées doubles + Données plates. Considérées comme incorrectes + + Limiter les glucides %1$d g à cause de %2$s + Pompe n’est pas capable de basals temporaires + Mode de Boucle Fermée désactivé dans les préférences + Version Dev. La Boucle Fermée est désactivée. + Boucle fermée désactivée à cause du bolus étendu + SMB toujours et post-ingestion de glucides désactivé car la source de glycémies actuelle ne supporte pas de filtrage avancé + SMB non autorisé en mode boucle ouverte + valeur Max dans les préférences + limite fixée + Traitements de sécurité + + Terminé, félicitations ! + Pas encore terminé + Temps écoulé + Maximum IA réglé correctement + Glycémie disponible depuis la source sélectionnée + Le service de synchronisation a l\'autorisation d\'écriture + Boucle activée + APS Sélectionné + Mode boucle fermée activé + OBJ + Programme d’apprentissage + Voulez-vous réinitialiser le début de l\'objectif ? Vous risquez de perdre vos progrès. + Suivant + Préc + Refaire l\'objectif + Suppression démarrée diff --git a/plugins/constraints/src/main/res/values-ga-rIE/exam.xml b/plugins/constraints/src/main/res/values-ga-rIE/exam.xml index 40c22282a9..3ea04e700d 100644 --- a/plugins/constraints/src/main/res/values-ga-rIE/exam.xml +++ b/plugins/constraints/src/main/res/values-ga-rIE/exam.xml @@ -1,4 +1,2 @@ - - Fiasp® - + diff --git a/plugins/constraints/src/main/res/values-ga-rIE/objectives.xml b/plugins/constraints/src/main/res/values-ga-rIE/objectives.xml index d9d309bd63..693890deb0 100644 --- a/plugins/constraints/src/main/res/values-ga-rIE/objectives.xml +++ b/plugins/constraints/src/main/res/values-ga-rIE/objectives.xml @@ -2,5 +2,4 @@ Tosaigh Fhíorú - Tosaigh ag lúb oscailte diff --git a/plugins/constraints/src/main/res/values-ga-rIE/strings.xml b/plugins/constraints/src/main/res/values-ga-rIE/strings.xml index bf1d7d9314..5d683010a5 100644 --- a/plugins/constraints/src/main/res/values-ga-rIE/strings.xml +++ b/plugins/constraints/src/main/res/values-ga-rIE/strings.xml @@ -6,4 +6,8 @@ + + + Lúb cumasaithe + APS roghnaithe diff --git a/plugins/constraints/src/main/res/values-hr-rHR/exam.xml b/plugins/constraints/src/main/res/values-hr-rHR/exam.xml index b4d6eabf2b..88a331afbf 100644 --- a/plugins/constraints/src/main/res/values-hr-rHR/exam.xml +++ b/plugins/constraints/src/main/res/values-hr-rHR/exam.xml @@ -3,63 +3,38 @@ Što je istina o DIA-i? Trajanje djelovanja inzulina (DIA) Trebali biste postaviti vrijednost za DIA u svom profilu. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html?#insulin Ako ste zadovoljni da je vrijednost za DIA koju ste koristili u svojoj pumpi prije AAPS-a, nema potrebe da je mijenjate kada počnete raditi u petlji. Kako bi se spriječilo pretjerano korigiranje AAPS-a za porast glukoze u krvi uzrokovan brzodjelujućim ugljikohidratima koji se koriste za tretiranje hipoglikemije. - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html#profile Razlozi za primjenu \"Otkači pumpu\" u AAPS Sprječava APPS da obračuna inzulin koji nije isporučen dok je pumpa fizički odspojena. Poslat će AAPS u način rada otvorene petlje. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#other-settings AAPS postavke AAPS postavke - https://androidaps.readthedocs.io/en/latest/EN/Usage/ExportImportSettings.html - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#what-emergency-equipment-is-recommended-to-take-with-me Ne činiti ništa - AAPS će se pozabaviti time. - https://androidaps.readthedocs.io/en/latest/EN/Usage/Smoothing-Blood-Glucose-Data-in-xDrip.html#smoothing-blood-glucose-data - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#androidaps-settings Što je bitno za postavljanje i korištenje AAPS-a? - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html Što je bitno za postavljanje i korištenje AAPS-a? AAPS zahtijeva internetsku vezu kako bi radio u zatvorenoj petlji. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html Ažuriranje AAPS-a Kada se objave ažurirane verzije AAPS-a, starije verzije mogu biti udaljeno ograničene nakon određenog vremena. - https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#update-to-a-new-version-or-branch Gdje možete potražiti pomoć za AAPS? Za savjet možete zatražiti u Facebook grupi Korisnici AAPS-a. Trebali biste pročitati (i ponovno pročitati) AAPS dokumentaciju. Možete zatražiti savjet i prijaviti tehničke probleme ili probleme u AAPS Discord. - https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting - https://www.facebook.com/groups/AndroidAPSUsers/ - Fiasp® - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html#insulin Dodaci za osjetljivost omogućuju AAPS-u da se prilagodi privremenim ili kratkotrajnim promjenama u osjetljivosti na inzulin (na primjer, hormonalne promjene ili problemi s apsorpcijom na mjestu infuzije). - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Ne poduzimati ništa – AAPS će izvršiti odgovarajuće prilagodbe. Usporedite vrijednosti u AAPS i povijesti pumpe (ako pumpa to podržava). Ne poduzimajte ništa i dopustite APPS-u da ispravi sve rezultirajuće visoke razine glukoze u krvi. AAPS koristi dinamički model za procjenu \"raspada\" ugljikohidrata i izračunavanje COB-a. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#insulin-to-carb-ratio-ic-g-u Za bilježenje \'besplatnih\' ugljikohidrata za vježbanje koje želite sakriti od AAPS-a. e-ugljikohidrati (distribuirani u budućnosti) mogu pomoći AAPS-u u rješavanju obroka s visokim udjelom masti/proteina. - https://androidaps.readthedocs.io/en/latest/EN/Usage/Extended-Carbs.html Kako možete nadzirati APPS (na primjer za svoje dijete) na daljinu? Aplikacija AAPSClient, aplikacija Nightscout i web stranica Nightscout omogućuju vam praćenje AAPS-a na daljinu. Da biste pratili AAPS na daljinu, oba uređaja moraju imati pristup internetu (npr. putem Wi-Fi ili podatkovne mreže mobilne/mobilne mreže). AAPSClient koji se koristi kao daljinski pratitelj nadzirat će i pružiti potpunu kontrolu nad AAPS-om. - https://androidaps.readthedocs.io/en/latest/EN/Children/Children.html ISF trebate unijeti u svoje postavke AAPS-a. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#insulin-sensitivity-factor-isf-mmol-l-u-or-mg-dl-u - https://androidaps.readthedocs.io/en/latest/EN/Usage/Profiles.html - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#carbohydrate-to-insulin-ratio-cr-g-u Ako ustanete 2 sata ranije nego inače, kako biste trebali obavijestiti AAPS o promjeni svog rasporeda? Aktiviranje promjena vašeg Nightscout profila zahtijeva da vaš AAPS telefon ima internetsku vezu. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html#good-individual-dosage-algorithm-for-your-diabetes-therapy AAPS smanjuje bazalne doze ili obustavlja isporuku inzulina radi povećanja šećera u krvi. Lijekovi iz klase inhibitora SGLT2 (gliflozini) mogu spriječiti povećanje glukoze u krvi i stoga mogu izazvati opasan nedostatak inzulina koji dovodi do DKA. \nUobičajeni brendovi su: Invokana®, Forxiga®, Jardiance®, Steglatro®, Suglat®, Apleway®, Deberza®, Synjardy®, Vokanamet®, Xigduo®.\n\nOvime obećavam da neću uzimati takve lijekove kada koristeći AAPS ili će deaktivirati petlju prije upotrebe takvih lijekova. diff --git a/plugins/constraints/src/main/res/values-hr-rHR/objectives.xml b/plugins/constraints/src/main/res/values-hr-rHR/objectives.xml index 1e9d56258e..01623f2c9e 100644 --- a/plugins/constraints/src/main/res/values-hr-rHR/objectives.xml +++ b/plugins/constraints/src/main/res/values-hr-rHR/objectives.xml @@ -2,8 +2,4 @@ Naučite kako kontrolirati AAPS Izvršite različite radnje u AAPS-u - 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/plugins/constraints/src/main/res/values-hr-rHR/strings.xml b/plugins/constraints/src/main/res/values-hr-rHR/strings.xml index d7dc1f9292..efc53c1b2c 100644 --- a/plugins/constraints/src/main/res/values-hr-rHR/strings.xml +++ b/plugins/constraints/src/main/res/values-hr-rHR/strings.xml @@ -2,22 +2,15 @@ - Promjena računanja vremena za 24 sata ili manje - Promjena računanja vremena prije manje od 3 sata - zatvorena petlja onemogućena - Oslobodite najmanje %1$d MB iz interne pohrane! Petlja onemogućena! - stara verzija - vrlo stara verzija - Aplikacija je istekla - Nova verzija dostupna najmanje %1$d dana! Vraćanje na LGS nakon %2$d dana, petlja će biti onemogućena nakon %3$d dana - Otkrili smo da koristite nevažeću verziju. Petlja onemogućena! - Dostupna je verzija %1$s - Verzija %1$s ističe %2$s - Korišteni preračunati podaci - BG preblizu:\n%1$s\n%2$s - preračunato - dvostruki unosi + + Sigurnosne postavke medikacije + + Dovršeno, bravo! + Nije još dovršeno + Prošlo vrijeme + Program učenja diff --git a/plugins/constraints/src/main/res/values-hu-rHU/exam.xml b/plugins/constraints/src/main/res/values-hu-rHU/exam.xml index 40c22282a9..3ea04e700d 100644 --- a/plugins/constraints/src/main/res/values-hu-rHU/exam.xml +++ b/plugins/constraints/src/main/res/values-hu-rHU/exam.xml @@ -1,4 +1,2 @@ - - Fiasp® - + diff --git a/plugins/constraints/src/main/res/values-hu-rHU/strings.xml b/plugins/constraints/src/main/res/values-hu-rHU/strings.xml index 7094a53c00..3fbb6840b8 100644 --- a/plugins/constraints/src/main/res/values-hu-rHU/strings.xml +++ b/plugins/constraints/src/main/res/values-hu-rHU/strings.xml @@ -4,9 +4,10 @@ - régi verzió - nagyon régi verzió - Alkalmazás lejárt + + + Eltelt idő + APS kiválasztva diff --git a/plugins/constraints/src/main/res/values-it-rIT/exam.xml b/plugins/constraints/src/main/res/values-it-rIT/exam.xml index b9986b1467..71e065f5bd 100644 --- a/plugins/constraints/src/main/res/values-it-rIT/exam.xml +++ b/plugins/constraints/src/main/res/values-it-rIT/exam.xml @@ -59,7 +59,6 @@ Lasciare il tuo target glicemico invariato. Attendere che la glicemia scenda al di sotto del tuo target temporaneo \"ipoglicemia\" e poi mangiare 15 g di carboidrati a rapido assorbimento. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Loop disabilitato/sospeso Ricevo insulina quando il loop è disabilitato/sospeso? Sì, l\'insulina basale continua a essere erogata. No, l\'erogazione di insulina è interrotta. @@ -109,7 +108,6 @@ https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/aapsitalia/ https://discord.gg/4fQUWHZ4Mw - Plugin insulina Quale insulina dovresti usare con il plugin Ultra-Rapid Oref? Fiasp® NovoRapid®/Novolog® @@ -149,7 +147,6 @@ Impostare il profilo al 150% richiederà un tempo maggiore per l\'assorbimento dei CHO Impostare il profilo al 150% richiederà un tempo minore per l\'assorbimento dei CHO Impostare il profilo al 150% non influirà sull\'assorbimento calcolato dei CHO - Insulina attiva (IOB) Il valore IOB è influenzato dalle basali temporanee emesse. Non verrà emessa una basale temporanea alta quando la tua glicemia è al di sotto del target. IOB negativo per un periodo considerevole in assenza di esercizio fisico suggerisce che il tuo profilo è troppo incisivo e che è necessaria meno insulina nelle tue impostazioni. diff --git a/plugins/constraints/src/main/res/values-it-rIT/strings.xml b/plugins/constraints/src/main/res/values-it-rIT/strings.xml index 0858490cec..ce0a2dec6e 100644 --- a/plugins/constraints/src/main/res/values-it-rIT/strings.xml +++ b/plugins/constraints/src/main/res/values-it-rIT/strings.xml @@ -2,22 +2,32 @@ - Cambio all\'ora legale/solare in 24h o meno - Cambio all\'ora legale/solare avvenuto meno di 3 ore fa - Loop chiuso disabilitato - Libera almeno %1$d MB dalla memoria interna! Loop disabilitato! - versione datata - versione molto datata - Applicazione scaduta - Nuova versione disponibile da almeno %1$d giorni! Ritorno a LGS dopo %2$d giorni, disattivazione del loop dopo %3$d giorni - Abbiamo rilevato che stai eseguendo una versione non valida. Loop disabilitato! - Versione %1$s disponibile - Versione: %1$s | Scadenza: %2$s - Dati ricalcolati usati - BG troppo vicino:\n%1$s\n%2$s - ricalcolato - doppi caricamenti + + Limitazione carboidrati a %1$d g a causa di: %2$s + Micro non in grado di impostare la basale temporanea + Modalità loop chiuso disabilitata nelle preferenze + Versione sviluppatore in esecuzione. Loop chiuso disabilitato. + Loop chiuso disabilitato a causa dell\'esecuzione di un bolo esteso + Le funzioni \"SMB sempre\" e \"SMB dopo i CHO\" sono disabilitate perché l\'attuale sorgente delle glicemie non supporta il filtraggio avanzato + SMB non consentito in modalità loop aperto + valore max nelle preferenze + limite fisso + Sicurezza trattamenti + + Non ancora completato + Tempo trascorso + Max IOB impostata correttamente + BG disponibile da sorgente selezionata + Loop abilitato + APS selezionato + Modalità chiusa abilitata + OBT + Programma di apprendimento + Vuoi resettare l\'avvio dell\'obiettivo? Potresti perdere i tuoi progressi. + Cancella completamento + Cancella avvio diff --git a/plugins/constraints/src/main/res/values-iw-rIL/exam.xml b/plugins/constraints/src/main/res/values-iw-rIL/exam.xml index 3a678aa5cf..d76b046268 100644 --- a/plugins/constraints/src/main/res/values-iw-rIL/exam.xml +++ b/plugins/constraints/src/main/res/values-iw-rIL/exam.xml @@ -59,7 +59,6 @@ השאירו את ערך מטרת הסוכר ללא שינוי. המתינו עד שהגלוקוז בדם יירד מתחת לערך המטרה של היפו ואז אכלו 15 גרם של פחמימות מהירות. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - השבתת \\ השהיית לולאה האם אני מקבל\\ת אינסולין כאשר הלולאה מושבתת\\מושהית? כן, אינסולין בזאלי ממשיך להינתן. לא, אספקת האינסולין נפסקת. @@ -109,7 +108,6 @@ https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ https://discord.gg/4fQUWHZ4Mw - תוספי אינסולין באיזה אינסולין להשתמש עם תוסף האולטרה מהיר? Fiasp® NovoRapid®/Novolog® @@ -149,7 +147,6 @@ הגדרת 150% פרופיל תגרום להארכת משך ספיגת הפחמימות הגדרת 150% פרופיל תגרום לקיצור משך ספיגת הפחמימות הגדרת 150% פרופיל לא תשפיע על חישוב משך ספיגת הפחמימות - אינסולין פעיל בגוף (IOB) ערך האינסולין הפעיל (IOB) מושפע ממינונים בזאליים זמניים שסופקו. מינון בזאלי גבוה לא יינתן כאשר רמת הסוכר נמוכה מערך המטרה. אינסולין פעיל שלילי לאורך זמן בו לא נעשית פעילות מצביע על כך שהפרופיל חזק מדי, נדרש פחות אינסולין ויש להגדיר זאת בפרופיל. diff --git a/plugins/constraints/src/main/res/values-iw-rIL/strings.xml b/plugins/constraints/src/main/res/values-iw-rIL/strings.xml index 9e57fd52ce..966fb64ff1 100644 --- a/plugins/constraints/src/main/res/values-iw-rIL/strings.xml +++ b/plugins/constraints/src/main/res/values-iw-rIL/strings.xml @@ -2,21 +2,32 @@ - שינוי לשעון קיץ ב-24 השעות הקרובות - חל מעבר לשעון קיץ לפני פחות מ-3 שעות - לולאה סגורה מושבתת - גרסה ישנה - גרסה ישנה מאוד - תוקף האפליקציה פג - גרסה חדשה זמינה כבר %1$d ימים! הגבלה להשהיה עקב סוכר נמוך תחל אחרי %2$d ימים, הלולאה תושבת אחרי %3$d ימים - זיהינו שאתם משתמשים בגרסה לא תקפה. הלולאה מושבתת! - גרסה %1$s זמינה - גרסה: %1$s תפוג תוקפה: %2$s - משתמש בנתונים מחושבים מחדש - רמת הסוכר קרובה מדי:\n%1$s\n%2$s - חושב מחדש - רישומים כפולים + + הגבלת פחמימות ל-%1$d גר\' בגלל %2$s + המשאבה אינה מסוגלת לבצע בזאלי זמני + מצב לולאה סגור מושבת בהעדפות + זוהי גרסת פיתוח. לולאה סגורה אינה מורשת. + הלולאה הסגורה מופסקת עקב מתן בולוס ממושך + SMB תמידי ו-SMB לאחר פחמימות מושבתים כיוון שמקור ערכי הסוכר הפעיל אינו תומך בסינון נתונים מתקדם + SMB אינו פעיל במצב לולאה פתוחה + ערך מקסימלי בהעדפות + מגבלה קשיחה + בטיחות טיפולים + + עוד לא הושלם + זמן שחלף + ערך IOB מקסימלי הוגדר כראוי + ערכי סוכר זמינים מהמקור הנבחר + הלולאה פעילה + נבחר APS + מצב סגור מופעל + OBJ + תוכנית הלימוד + האם ברצונכם לאפס את התחלת המשימה? אתם עלולים לאבד את התקדמותכם במשימה. + ביטול השלמה + ביטול התחלה diff --git a/plugins/constraints/src/main/res/values-ja-rJP/strings.xml b/plugins/constraints/src/main/res/values-ja-rJP/strings.xml index bf1d7d9314..25fed4a847 100644 --- a/plugins/constraints/src/main/res/values-ja-rJP/strings.xml +++ b/plugins/constraints/src/main/res/values-ja-rJP/strings.xml @@ -6,4 +6,6 @@ + + diff --git a/plugins/constraints/src/main/res/values-ko-rKR/exam.xml b/plugins/constraints/src/main/res/values-ko-rKR/exam.xml index 40db45293e..92f993064a 100644 --- a/plugins/constraints/src/main/res/values-ko-rKR/exam.xml +++ b/plugins/constraints/src/main/res/values-ko-rKR/exam.xml @@ -51,7 +51,6 @@ 임시 목표를 변경하지 않습니다. \"저혈당 임시 목표\"보다 혈당이 떨어질 때까지 기다린 후 빠르게 반응하는 탄수화물 15g을 섭취합니다. https://androidaps.readthedocs.io/en/latest/CROWDIN/ko/Usage/temptarget.html#activity-temp-target - 중지 또는 일시중지된 loop Loop가 중지/일시중지 되었을때 인슐린이 주입됩니까? 네, Basal 인슐린은 계속 주입됩니다. 아니오, 인슐린 주입이 모두 중지됩니다. @@ -91,8 +90,6 @@ 당뇨병 클리닉/내분비내과의사에게 문의해야 합니다. https://androidaps.readthedocs.io/en/latest/CROWDIN/ko/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - 인슐린 플러그인 어떤 인슐린에서 초-초속효성의 Oref 플러그인을 사용해야 할까요? 피아스프(Fiasp®) 노보래피드(NovoRapid®)/노보로그(Novolog®) @@ -105,7 +102,6 @@ 캐뉼라 교체를 입력하면 Autosens 비율은 100%로 되돌아갑니다. 일부 플러그인 옵션은 사용자가 설정 가능한 시간 범위를 갖습니다. https://androidaps.readthedocs.io/en/latest/CROWDIN/ko/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens 탄수화물 입력 오류 부적절한 탄수화물을 입력하였다면 어떻게 하여야 합니까? 관리 메뉴에서 잘못된 입력을 삭제하고, 새로운 탄수화물 양으로 수정합니다. @@ -115,7 +111,6 @@ 만약 펌프 기록에서 보여지는 것보다 인슐린이 적게 주입되었을 때 어떻게 해야 할까요? (예를 들어, 주입 막힘, 캐뉼라 문제, 샤워 후 펌프 재부착을 잊어버렸을 때) Nightscout 케어포탈에서 인슐린 데이터를 삭제하여 펌프 기록에서 이를 제거합니다. \"주입되지 않은\" 인슐린양을 계산하여 시린지/펜 또는 prime 기능을 사용하여 인슐린을 주입합니다. - 활성 인슐린 (IOB) IOB 값은 실행된 임시 basal의 영향을 받습니다. 혈당이 목표보다 낮을 경우 높은 임시 basal은 실행되지 않습니다. 운동 없이도 음수의 IOB (마이너스 IOB) 구간이 많을 경우, 프로파일이 너무 강한 것이며 인슐린 양을 적게 설정해야 합니다. diff --git a/plugins/constraints/src/main/res/values-ko-rKR/strings.xml b/plugins/constraints/src/main/res/values-ko-rKR/strings.xml index da17b37396..f240316029 100644 --- a/plugins/constraints/src/main/res/values-ko-rKR/strings.xml +++ b/plugins/constraints/src/main/res/values-ko-rKR/strings.xml @@ -2,15 +2,32 @@ - 24시간 미만의 썸머타임 변경 - 썸머타임 변경이 3시간 미만입니다 - Closed Loop 비활성됨 - 오래된 버전 - 아주 오래된 버전 - 최소 %1$d일 새버전이 가능합니다! %2$d일 후엔 LGS(저혈당주입중지)으로 복귀되며, %3$d일이후엔 Loop가 비활성화 될 것입니다 - 유효하지 않은 버전을 이용 중입니다. Loop가 비활성화 되었습니다! - %1$s 버전이 사용 가능합니다. + + %2$s로 인해 탄수화물이 %1$d g로 제한됩니다. + 이 펌프 임시Basal을 지원하지 않습니다. + 설정에서 Closed Loop 모드가 비활성화되었습니다. + 개발자버전을 실행중입니다. Closed Loop는 비활성화 됩니다. + 확장 Bolus 사용으로 인해 Closed Loop가 비활성화됨 + 선택한 혈당 출처가 고급 필터링을 지원하지 않기 때문에 SMB가 항상 비활성화됩니다. + Open Loop모드에선 SMB가 허용되지 않습니다. + 설정에서의 최대값 + 하드한계 + 관리 안전설정 + + 아직 완료되지 않았습니다. + 경과 시간 + 최대 IOB가 바르게 설정됨 + 선택한 소스에서 혈당이 들어옵니다. + Loop 활성화됨 + APS 선택됨 + Closed 모드가 활성화됨 + OBJ + 프로그램 배우기 + 목표를 초기화하시겠습니까? 진행상황이 삭제됩니다. + 완료 초기화 + 시작 초기화 diff --git a/plugins/constraints/src/main/res/values-lt-rLT/exam.xml b/plugins/constraints/src/main/res/values-lt-rLT/exam.xml index 83e8db76d9..84ca888a45 100644 --- a/plugins/constraints/src/main/res/values-lt-rLT/exam.xml +++ b/plugins/constraints/src/main/res/values-lt-rLT/exam.xml @@ -51,7 +51,6 @@ Palikti tikslinę glikemiją nepakeistą. Palaukti, kol glikemija nukris žemiau laikino hipoglikemijos tikslo, tada suvalgyti 15 g greitųjų angliavandenių. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Ciklas išjungtas/sustabdytas Ar man leidžiamas insulinas, kai ciklas yra išjungtas / pristabdytas? Taip, bazinis insulinas ir toliau leidžiamas. Ne, insulino tiekimas sustabdytas. @@ -91,8 +90,6 @@ Turėtumėte kreiptis į savo diabeto kliniką/endokrinologą. https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - Insulino įskiepiai Kurį insuliną reikėtų naudoti su Ultra-Rapid Oref įskiepiu? Fiasp® NovoRapid®/Novolog® @@ -105,7 +102,6 @@ Pažymėjus kaniulės pakeitimą, Autosens santykis vėl bus grąžintas į 100%. Kai kurios įskiepo parinktys turi konfigūruojamus laiko intervalus, kuriuos gali nustatyti vartotojas. https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Angliavandenių įvedimo klaidos Ką reikia daryti, jei įrašyti neteisingi angliavandeniai? Ištrinti neteisingą įrašą Terapijos skiltyje ir įvesti teisingą angliavandenių kiekį. @@ -115,7 +111,6 @@ Ką turėtumėte daryti, jei buvo suleista mažiau insulino nei rodo pompos istorija, pvz. dėl užsikimšimo, neveikiančios kaniulės ar pamiršus po dušo vėl pritvirtinti pompą?  Ištrinti insulino suleidimo įrašą per Nightscout Careportal, kad pašalintumėte jį iš pompos istorijos. Susileisti trūkstamą insulino kiekį švirkštu ar naudojantis infuzinės sistemos užpildymo funkcija. - Aktyvus insulinas organizme (AIO) AIO reikšmei įtakos turi nustatyta laikina valandinė bazė. Padidinta laikina bazė nebus nustatyta, jei kraujo glikemija yra žemiau nustatyto tikslo. Jei ilgą laiką stebima neigiama AIO reikšmė ir nėra fizinio aktyvumo, tai rodo, kad jūsų nustatymai yra per „agresyvūs“ ir kad jums reikia mažiau insulino nei nustatyta. diff --git a/plugins/constraints/src/main/res/values-lt-rLT/strings.xml b/plugins/constraints/src/main/res/values-lt-rLT/strings.xml index 3699f31ded..10a2171592 100644 --- a/plugins/constraints/src/main/res/values-lt-rLT/strings.xml +++ b/plugins/constraints/src/main/res/values-lt-rLT/strings.xml @@ -2,19 +2,32 @@ - Laiko persukimas įvyks po 24 val ar mažiau - Laiko persukimas įvyks po mažiau nei 3 val - Uždaras ciklas deaktyvuotas - sena versija - labai sena versija - Aplikacijos laikas baigėsi - Nauja versija pasiekiama mažiausiai %1$d d.! Po %2$d grįšite prie stabdymo prie žemo, po %3$d ciklas bus išjungtas - Nustatyta, kad naudojate neteisingą versiją. Ciklas išjungtas! - Versiją %1$s jau galima naudoti - Versija %1$s baigia galioti %2$s - Naudojami perskaičiuoti duomenys - KG per arti:\n%1$s\n%2$s + + Ribojami angliavandeniai iki %1$d g dėl %2$s + Pompa negali nustatyti laikinos bazės + Uždaro ciklo būsena išjungta nustatymuose + Naudojama neužbaigta versija. Uždaras ciklas neaktyvus. + Uždara ciklas išjungtas dėl ištęsto boluso veikimo + Funkcijos \"SMB visada\" ir \"SMB po angliavandenių\" išjungtos, nes kraujo gliukozės duomenų šaltinis neturi reikalingo filtravimo + SMB neleidžiami atviro ciklo režime + Maksimali reikšmė nustatymuose + Nekeičiama riba + Terapijos saugumas + + Dar nebaigta + Praėjo laiko + Maksimalus AIO nustatytas tinkamai + KG šaltinis pasirinktas teisingai + Ciklas aktyvuotas + DKS pasirinkta + Uždaras ciklas aktyvus + TIKSL + Mokymosi programa + Ar norite iš naujo nustatyti tikslų pradžią? Jūs galite prarasti jau pasiektus. + Išvalyti užbaigtus + Išvalyti pradėtus diff --git a/plugins/constraints/src/main/res/values-nl-rNL/exam.xml b/plugins/constraints/src/main/res/values-nl-rNL/exam.xml index cc969863bf..9700b08b4a 100644 --- a/plugins/constraints/src/main/res/values-nl-rNL/exam.xml +++ b/plugins/constraints/src/main/res/values-nl-rNL/exam.xml @@ -59,7 +59,6 @@ Je streefdoel ongewijzigd laten. Wachten totdat de bloedclose tot onder het Hypo tijdelijk streefdoel daalt en dan 15 g snelwerkende koolhydraten eten. https://androidaps.readthedocs.io/en/latest/CROWDIN/nl/Usage/temptarget.html#activiteit-tijdelijk-streefdoel - Uitgeschakelde/onderbroken loop Ontvang ik insuline wanneer de Loop is uitgeschakeld/onderbroken? Ja, de basale insuline wordt nog steeds geleverd. Nee, de levering van insuline is gestopt. @@ -109,7 +108,6 @@ https://androidaps.readthedocs.io/en/latest/CROWDIN/nl/Installing-AndroidAPS/Update-to-new-version.html#problemen-oplossen https://www.facebook.com/groups/AndroidAPSUsers/ https://discord.gg/4fQUWHZ4Mw - Insuline-plugins Welke insuline gebruik je met de Ultra-Rapid Oref plugin? Fiasp® NovoRapid®/Novolog® @@ -149,7 +147,6 @@ Instellen van een profiel op 150% zal de absorptie van koolhydraten vertragen Instellen van een profiel op 150% zal de absorptie van koolhydraten versnellen Instellen van profiel op 150% heeft geen invloed op berekende koolhydraten absorptie - Insuline aan boord (IOB) De IOB-waarde wordt beïnvloed door eerdere tijdelijke basaalstanden. Een hoge tijdelijke basaal zal niet worden ingesteld wanneer je bloedsuiker onder het streefdoel ligt. Negatieve IOB voor een aanzienlijke periode vrij van inspanning, suggereert dat je profiel te hoog is ingesteld, dus dat er minder insuline nodig is. diff --git a/plugins/constraints/src/main/res/values-nl-rNL/strings.xml b/plugins/constraints/src/main/res/values-nl-rNL/strings.xml index ec6caa9d12..d227f5c638 100644 --- a/plugins/constraints/src/main/res/values-nl-rNL/strings.xml +++ b/plugins/constraints/src/main/res/values-nl-rNL/strings.xml @@ -2,22 +2,35 @@ - Omschakeling van zomer- of wintertijd in 24 uur of minder - Omschakeling zomer/wintertijd minder dan 3 uur geleden - Gesloten Lus modus gedeactiveerd - Maak minstens %1$d MB vrij in interne opslag! Loop is uitgeschakeld! - oude versie - zeer oude versie - Applicatie is verlopen - Nieuwe versie al zeker %1$d dagen beschikbaar! Terugval LGS na %2$d dagen, loop zal worden uitgeschakeld na %3$d dagen - We hebben gedetecteerd dat je een ongeldige versie gebruikt. Loop is uitgeschakeld! - Versie %1$s is beschikbaar - Versie %1$s verloopt op %2$s - Herberekende data gebruikt - BG data interval to kort:\n%1$s\n%2$s - opnieuw berekend - dubbele items + Vlakke data. Beschouwd als onjuist + + Koolhydraten worden beperkt tot %1$d gr doordat %2$s + Pomp kan geen tijdelijk basaal aanvaarden + Closed Loop modus gedeactiveerd in de instellingen + Dev versie actief. Closed loop gedeactiveerd + Closed loop modus uitgeschakeld vanwege afgeven Vertraagde bolus + SMB altijd gedeactiveerd doordat de gekozen BG bron geen optimale filtering toepast + SMB niet toegestaan in Open Loop modus + Maximum waarde in instellingen + max limiet (SC) + Behandelingen veiligheid + + Voltooid, goed gedaan! + Nog niet voltooid + Verstreken tijd + Maximum IOB juist ingesteld + BG beschikbaar op gekozen bron + Synchronisatieservice heeft schrijfrechten + Loop Actief + APS geslecteerd + Closed modus actief + DOEL + Leerprogramma + Wil je dit leerdoel opnieuw starten? Je kunt je voortgang verliezen. + Voltooiing wissen + Start wissen diff --git a/plugins/constraints/src/main/res/values-no-rNO/exam.xml b/plugins/constraints/src/main/res/values-no-rNO/exam.xml index 708f615564..7e8a3f46da 100644 --- a/plugins/constraints/src/main/res/values-no-rNO/exam.xml +++ b/plugins/constraints/src/main/res/values-no-rNO/exam.xml @@ -59,7 +59,6 @@ La målverdien for ditt blodsukker være uforandret. Vent til blodsukkeret ditt synker under Hypo temp target og spis så 15 gram med hurtigvirkende karbohydrater. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#active temp-target - Deaktiver/pause loop Får jag insulin når loop er stanset/pauset? Ja, basal insulin vil fortsatt bli levert. Nei, levering av insulin er stanset. @@ -149,7 +148,6 @@ Ved å sette profilen til 150% vil karbohydrater absorberes over lengre tid Ved å sette profilen til 150% vil karbohydrater absorberes over kortere tid Ved å sette profilen til 150% påvirkes ikke beregningen av absorbering av karbohydrater - Aktivt insulin (IOB) IOB verdi påvirkes av midlertidige temp basaler. Høy temp basal vil ikke bli gitt når ditt blodsukker er under målverdi. Negativ IOB i en lengre periode selv om du ikke trener tyder på at profilen din gir for mye insulin og kanskje bør reduseres i innstillingene. diff --git a/plugins/constraints/src/main/res/values-no-rNO/strings.xml b/plugins/constraints/src/main/res/values-no-rNO/strings.xml index 1eeec3c0cd..a82a423259 100644 --- a/plugins/constraints/src/main/res/values-no-rNO/strings.xml +++ b/plugins/constraints/src/main/res/values-no-rNO/strings.xml @@ -9,16 +9,45 @@ gammel versjon veldig gammel versjon - Applikasjon utløpt - oppdater - Ny versjon tilgjengelig i minst %1$d dager! Systemet vil bytte til \"stopp innen lavt (LGS)\" etter %2$d dager og loop vil deaktiveres etter %3$d dager + Applikasjon utløpt + Ny versjon tilgjengelig i minst %1$d dager! Systemet vil bytte til \"stopp ved lavt BS (LGS)\" etter %2$d dager og loop vil deaktiveres etter %3$d dager Vi har oppdaget at du kjører en ugyldig versjon. Loop deaktivert! Versjon %1$s er tilgjengelig Versjon %1$s utløper den %2$s - Rekalkulerte siste data + Rekalkulerte data er brukt BS for nær:\n%1$s\n%2$s beregnet på nytt doble registreringer Flate verdier. Vurderer dette til å være feil + + Begrenser forlenget bolus til %1$.1f E på grunn av %2$s + Begrenser karbohydrater til %1$d g på grunn av %2$s + Pumpen støtter ikke temp basaler + Lukket Loop er eaktivert i innstillinger + Du kjører dev-versjonen. Lukket loop ikke aktivert. + Lukket loop deaktivert på grunn av forlenget bolus + SMB Alltid På og SMB Etter Karbohydrater er deaktivert fordi BS kilden ikke støtter avansert filtrering + SMB ikke tillatt i åpen loop + maks verdi i innstillingene + hard begrensning + Sikkerhet ved behandlinger + + Fullført, bra jobba! + Enda Ikke fullført + Tid brukt + Maks IOB er angitt riktig + BS tilgjengelig fra valgt kilde + Synkroniseringstjeneste har skriverettigheter + Loop er aktivert + APS valgt + Lukket loop aktivert + MÅL + Opplæringsprogram + Ønsker du å omstarte læringsmålet? Du vil miste fullførte trinn. + Neste + Forrige + Sletting ferdig + Sletting startet diff --git a/plugins/constraints/src/main/res/values-pl-rPL/exam.xml b/plugins/constraints/src/main/res/values-pl-rPL/exam.xml index 322f3d2f03..3a1674137c 100644 --- a/plugins/constraints/src/main/res/values-pl-rPL/exam.xml +++ b/plugins/constraints/src/main/res/values-pl-rPL/exam.xml @@ -51,7 +51,6 @@ Pozostaw cel poziomu glukozy we krwi niezmieniony. Poczekaj, aż poziom glukozy we krwi spadnie poniżej celu tymczasowego \"Hipo\", a następnie zjedz 15 g szybko działających węglowodanów. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Wyłączona/zawieszona pętla Czy otrzymuję insulinę, gdy pętla jest wyłączona/zawieszona? Tak, insulina bazowa nadal jest dostarczana. Nie, podawanie insuliny jest zatrzymane. @@ -91,8 +90,6 @@ Należy zwrócić się do diabetologa lub lekarza endokrynologa. https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - Wtyczki insuliny Która insulina powinna być używana z wtyczką Ultra-Rapid Oref? Fiasp® NovoRapid ® /Novolog ® @@ -105,7 +102,6 @@ Rejestracja zmiany wkłucia spowoduje zresetowanie współczynnika Autosens z powrotem do 100%. Niektóre z opcji wtyczki mają konfigurowalne zakresy czasu, które mogą być ustawiane przez użytkownika. https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Błędy wprowadzania węglowodanów Co powinieneś zrobić, gdy wprowadziłeś niewłaściwą ilość węglowodanów? Usuń niepoprawny wpis w leczeniu (Treat) i wprowadź poprawną nową wartość węglowodanów. @@ -115,7 +111,6 @@ Co należy zrobić, jeśli otrzymano mniej insuliny niż sugeruje historia pompy, np. z powodu niedrożności, uszkodzonej kaniuli lub zapomnienia o ponownym podłączeniu pompy po prysznicu? Usuń dane insuliny z portalu Nightscout aby usunąć je z historii pompy. Podaj obliczoną dawkę „pominiętej” insuliny za pomocą strzykawki / wstrzykiwacza lub za pomocą pompy funkcji wypełnienia. - Aktywna insulina (IOB) Na wartość IOB mają wpływ wykonane tymczasowe dawki bazowe. Wysoka tymczasowa dawka bazowa nie zostanie podana, gdy twóje poziom cukru we krwi jest poniżej poziomu docelowego. Negatywne IOB utrzymujące się przez znaczny okres czasu bez wysiłku fizycznego sugeruje, że Twój profil jest zbyt silny i mniej insuliny jest wymagane w Twoich ustawieniach. diff --git a/plugins/constraints/src/main/res/values-pl-rPL/strings.xml b/plugins/constraints/src/main/res/values-pl-rPL/strings.xml index 0af41a6505..4245afa1a4 100644 --- a/plugins/constraints/src/main/res/values-pl-rPL/strings.xml +++ b/plugins/constraints/src/main/res/values-pl-rPL/strings.xml @@ -2,19 +2,32 @@ - Zmiana czasu w 24h lub mniej - Zmiana czasu nastąpiła mniej niż 3 godziny temu - Zamknięta pętla wyłączona - stara wersja - bardzo stara wersja - Aplikacja wygasła - Nowa wersja dostępna co najmniej %1$d dni! Powrót do LGS (zawieszania podawania bazy przy niskim poziomie) po %2$d dniach, pętla zostanie wyłączona po %3$d dniach - Wykryliśmy, że używasz nieprawidlowej wersji. Pętla wyłączona! - Wersja %1$s dostępna - Wersja %1$s wygasa %2$s - Użyto przeliczonych wartości - Zbyt bliskie pomiary glikemii:\n%1$s\n%2$s + + Ograniczam węglow. do %1$d g z uwagi na %2$s + Pompa nie jest zdolna do wykonywania dawek bazowych tymczasowych + Tryb zamkniętej pętli wyłączony w ustawieniach + Uruchomiona jest wersja dev. Zamknięta pętla jest wyłączona. + Zamknięta pętla wyłączona, ponieważ działa Extended Bolus (bolus przedłużony) + SMB zawsze i po węglow. wyłączone z uwagi na brak źródła BG z zaawansowanym filtrowaniem + SMB nie dozwolone w trybie otwartej pętli + maks. wartość w ustawieniach + twarde ograniczenie + Bezpieczeństwo terapii + + Nie ukończono + Czas jaki upłynął + Maks. IOB ustawione poprawnie + BG dostępne z wybranego źródła + Pętla włączona + Wybrano APS + Tryb zamknięty włączony + OBJ + Program do nauki + Czy chcesz zresetować czas rozpoczęcia zadania? Możesz utracić postępy. + Wyczyść skończone + Wyczyść rozpoczęte diff --git a/plugins/constraints/src/main/res/values-pt-rBR/exam.xml b/plugins/constraints/src/main/res/values-pt-rBR/exam.xml index 28e1363397..9c1946d1da 100644 --- a/plugins/constraints/src/main/res/values-pt-rBR/exam.xml +++ b/plugins/constraints/src/main/res/values-pt-rBR/exam.xml @@ -59,7 +59,6 @@ Não altere o seu alvo de glicemia. Aguarde até que a glicemia fique abaixo do seu alvo temporário de hipoglicemia e coma 15g de carbos de ação rápida. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Loop Desativado/Suspenso Eu recebo insulina quando o loop estiver desactivado/suspenso? Sim, a insulina basal continua sendo administrada. Não, a administração da insulina será interrompida. @@ -109,7 +108,6 @@ https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ https://discord.gg/4fQUWHZ4Mw - Plugins de Insulina Qual insulina você deveria usar com o plugin \"Oref Ultra-Rapid\"? Fiasp® NovoRapid®/Novolog® @@ -149,7 +147,6 @@ Definir o perfil para 150% levará a absorção de carboidratos em mais tempo Definir o perfil para 150% levará a absorção de carboidratos em menos tempo Definir o perfil para 150% não afetará a absorção de carboidratos calculados - Insulina ativa (IA) O valor de IA é afetado por basais temporárias efetuadas. Um basal alto temporário não será efetuado quando sua glicose estiver abaixo do alvo. Insulina Ativa (IA) negativa por um período substancial na ausência de exercícios, sugere que seu perfil é muito agressivo e menos insulina deve ser considerada nas suas configurações. diff --git a/plugins/constraints/src/main/res/values-pt-rBR/strings.xml b/plugins/constraints/src/main/res/values-pt-rBR/strings.xml index 9b559db21b..09369c76e4 100644 --- a/plugins/constraints/src/main/res/values-pt-rBR/strings.xml +++ b/plugins/constraints/src/main/res/values-pt-rBR/strings.xml @@ -2,22 +2,34 @@ - Mudança do horário de verão em 24h ou menos - Alteração do horário de verão há menos de 3 horas. Circuito fechado desativado - Libere pelo menos %1$d MB do armazenamento interno! ‘Loop’ desativado! - versão antiga - versão muito antiga - Aplicativo expirado - Nova versão para pelo menos %1$d dias disponíveis! Retorno a LGS após %2$d dias, o loop será desativado após %3$d dias - Detectamos que você está executando uma versão inválida. \"Loop\" desativado! - Disponível %1$s disponível - A versão %1$s expira em %2$s - Dados recalculados foram utilizados - Glicemia muito próxima:\n%1$s\n%2$s - recalculado - entradas duplicadas + Dados fixos. Considere que podem ser imprecisos. + + A limitar hidratos para %1$d g porque %2$s + A bomba não é capaz de basais temporárias + Loop fecchado disabilitado nas preferências + A correr a versão dev. O Loop fechado está desabilitado. + Closed Loop desabilitado por causa da execução do Bólus Estendido + SMB sempre e depois dos hidratos desactivado por fonte da Glicemia activa não suportar filtro avançado + SMB não permitido no modo open loop + valor máx nas preferências + limite rígido + Segurança do Tratamento + + Incompleto + Tempo decorrido + IOB máxima definida correctamente + Glicemia disponivel desde a fonte selecionada + O serviço de sincronização tem permissão de escrita + Loop activado + APS seleccionado + Modo fechado ativado + OBJ + Programa de aprendizagem + Deseja reiniciar o objetivo? Pode perder seu progresso. + Limpeza terminado + Limpeza iniciado diff --git a/plugins/constraints/src/main/res/values-pt-rPT/exam.xml b/plugins/constraints/src/main/res/values-pt-rPT/exam.xml index c4adf5f331..7d76cf7ece 100644 --- a/plugins/constraints/src/main/res/values-pt-rPT/exam.xml +++ b/plugins/constraints/src/main/res/values-pt-rPT/exam.xml @@ -51,7 +51,6 @@ Deixe o seu alvo de glicose inalterado. Espere até que a glicose no sangue baixe abaixo do seu alvo temporário de hipo e, em seguida, coma 15 g de hidratos rápidos. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Loop Desactivado/Suspenso Eu recebo insulina quando o loop estiver desactivado/suspenso? Sim, a insulina basal continua a ser administrada. Não, administração da insulina está parada. @@ -91,8 +90,6 @@ Deveria pedir à sua clínica de diabetes/endocrinologista. https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - Plugins de Insulina Que insulina deve utilizar com o plugin Oref Ultra-Rápida ? Fiasp® NovoRapid®/Novolog® @@ -105,7 +102,6 @@ Registar uma mudança de cânula irá redefinir a taxa de Autosens de volta para 100%. Algumas opções de plugin têm intervalos de tempo configuráveis que podem ser configurados pelo utilizador. https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Erros de Entrada de Hidratos O que deve fazer se tiver feito uma entrada incorrecta de hidratos? Elimine a entrada incorreta em Tratamentos e insira o novo valor correto dos hidratos. @@ -115,7 +111,6 @@ O que deve fazer se receber menos insulina do que o histórico da bomba sugere por exemplo devido a uma oclusão, uma cânula danificada ou esquecer-se de reanexar a bomba após um banho? Elimine dados de insulina do Nightscout Careportal para removê-lo do histórico da bomba. Bólus uma proporção de insulina calculada \'não administrada\' ou com seringa/caneta ou purgando. - Insulina ativa (IA ) O valor do IA é afectado por basais temporárias emitidas. Basal temporária alta não será dada quando a sua glicose estiver abaixo do alvo. IA negativa por um período substancial na ausência de exercício, sugere que o seu perfil é muito alto e é necessária menos insulina nas suas configurações. diff --git a/plugins/constraints/src/main/res/values-pt-rPT/strings.xml b/plugins/constraints/src/main/res/values-pt-rPT/strings.xml index 066bc4b40f..df6b3be19b 100644 --- a/plugins/constraints/src/main/res/values-pt-rPT/strings.xml +++ b/plugins/constraints/src/main/res/values-pt-rPT/strings.xml @@ -2,19 +2,32 @@ - Horário de Verão em 24h ou menos - Horário de Verão a menos de 3 horas - Loop Fechado desativado - versão antiga - versão muito antiga - A aplicação expirou - Nova versão para pelo menos %1$d dias disponíveis! Retorno a SGB após %2$d dias, o loop será desactivado após %3$d dias - Detectamos que está a correr uma versão inválida. Loop desactivado! - Disponível %1$s disponível - Versão: %1$s criada em %2$s - Dados utilizados foram recalculados - Glicemia demasiado próxima:\n%1$s\n%2$s + + A limitar hidratos para %1$d g porque %2$s + A bomba não é capaz de basais temporárias + Loop fechado desativado nas preferências + A correr a versão dev. O Loop fechado está desativado. + Loop Fechado desativado por causa da execução do Bólus Prolongado + SMB sempre e depois dos hidratos desactivado por fonte da Glicose activa não suportar filtro avançado + SMB não permitido no modo open loop + valor máx nas preferências + limite rígido + Segurança de Tratamentos + + Não concluído ainda + Tempo decorrido + IA máxima definida corretamente + Glicose disponível da fonte seleccionada + Loop activado + APS seleccionado + Modo fechado ativado + OBJ + Programa de aprendizagem + Deseja reiniciar o objectivo? Pode perder seu progresso. + Limpar terminado + Limpar iniciado diff --git a/plugins/constraints/src/main/res/values-ro-rRO/exam.xml b/plugins/constraints/src/main/res/values-ro-rRO/exam.xml index 4154dffca1..18ea37c096 100644 --- a/plugins/constraints/src/main/res/values-ro-rRO/exam.xml +++ b/plugins/constraints/src/main/res/values-ro-rRO/exam.xml @@ -51,7 +51,6 @@ Lăsaţi valoarea ţintă a glicemiei dumneavoastră neschimbată. Aşteptaţi până când glicemia scade sub Ținta Temporară de hipoglicemie şi apoi mâncaţi 15 g de carbohidraţi cu acţiune rapidă. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Buclă dezactivată/suspendată Primesc insulina atunci când bucla închisă este dezactivata/suspendata? Da, insulina bazală este livrată în continuare. Nu, livrarea de insulină este oprită. @@ -91,8 +90,6 @@ Ar trebui să întrebați medicul diabetolog. https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - Plugin-uri insulină Ce insulină trebuie să utilizaţi cu plugin-ul Ultra-Rapid Oref? Fiasp® NovoRapid®/Novolog® @@ -105,7 +102,6 @@ Înregistrarea unei schimbări de canula va reseta raportul Autosens înapoi la 100%. Unele dintre opțiunile plugin-ului au intervale de timp configurabile care pot fi setate de către utilizator. https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Erori la introducerea carbohidraților Ce ar trebui sa faceți dacă ați introdus o cantitate de carbohidrați greșită? Ştergeţi intrarea incorectă din Tratamente şi introduceţi noua valoare de carbohidrați corectă. @@ -115,7 +111,6 @@ Ce trebuie să faci dacă ai primit mai putină insulină decât sugerează istoricul pompei, de exemplu datorită unei ocluzii, a unei canule defecte sau pentru ca ai uitat sa reatașezi pompa după un dus?  Șterge datele despre insulină din Nightscout Careportal pentru a le înlătura din istoricul pompei. Bolusati o cantitate parțiala de insulina din insulina calculata ca fiind lipsa utilizând seringa/penul sau amorsarea. - Insulină activă (IOB) Valoarea IOB este afectată de bazalele temporare emise. Rata bazala ridicata temporara nu va fi livrata atunci când glicemia este sub nivelul țintă. Un IOB negativ pentru o perioadă substanțială în absența exercițiilor fizice sugerează că profilul tău este prea puternic și este nevoie de mai puţină insulină în setările inițiale. diff --git a/plugins/constraints/src/main/res/values-ro-rRO/strings.xml b/plugins/constraints/src/main/res/values-ro-rRO/strings.xml index 5351f94628..f0e6785ec6 100644 --- a/plugins/constraints/src/main/res/values-ro-rRO/strings.xml +++ b/plugins/constraints/src/main/res/values-ro-rRO/strings.xml @@ -2,19 +2,32 @@ - Schimbare oră vară/iarnă în mai puțin de 24h - Schimbare oră vară/iarnă în mai puțin de 3 ore - buclă închisă dezactivată - versiune veche - versiune foarte veche - Aplicația a expirat - O versiune nouă este disponibilă de cel puțin %1$d zile! Reveniți la LGS după %2$d zile, bucla închisă va fi dezactivată după %3$d zile - S-a detectat rularea unei versiuni invalide. Buclă dezactivată! - Versiunea %1$s este disponibilă - Versiunea %1$s expiră pe %2$s - Date recalculate utilizate - BG prea aproape:\n%1$s\n%2$s + + Se limitează carbohidrații %1$d g datorită %2$s + Pompa nu suportă bazale temporare + Modul buclă închisă dezactivat în preferințe + Se folosește versiunea dev. Bucla închisă este dezactivată. + Bucla închisă dezactivată din cauza livrării bolusului extins + SMB dezactivat întotdeauna și după carbohidrați, deoarece sursa glicemiei nu suportă filtrare avansată + SMB nu este permis în mod buclă deschisă + valoare maximă în preferințe + limită fizică + Setări siguranță tratament + + Încă incomplet + Timp scurs + IOB maxim configurat corect + Glicemie disponibilă din sursa selectată + Buclă activată + APS selectat + Mod buclă închisă activat + OBI + Program de învăţare + Doriți să reîncepeți obiectivul? Vă puteți pierde progresul. + Șterge starea \"Terminat\" + Șterge starea \"Început\" diff --git a/plugins/constraints/src/main/res/values-ru-rRU/exam.xml b/plugins/constraints/src/main/res/values-ru-rRU/exam.xml index c5b2a36f02..92a6e8f53b 100644 --- a/plugins/constraints/src/main/res/values-ru-rRU/exam.xml +++ b/plugins/constraints/src/main/res/values-ru-rRU/exam.xml @@ -59,7 +59,6 @@ Оставить временную цель без изменений. Подождать пока глюкоза крови упадет ниже уровня цели \"Гипо\", а затем съесть 15г быстрых углеводов. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Отключенный/приостановленный цикл Получаю ли я инсулин, когда цикл отключен/приостановлен? Да, базальный инсулин продолжает подаваться. Нет, подача инсулина прекращается. @@ -109,7 +108,6 @@ https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ https://discord.gg/4fQUWHZ4Mw - Модули для инсулинов Какой инсулин следует использовать с модулем Сверхбыстрый Oref? Fiasp® Novoapid ® /Novolog ® @@ -149,7 +147,6 @@ Установка профиля на 150% потребует больше времени на усвоение углеводов Установка профиля на 150% потребует меньше времени на усвоение углеводов Установка профиля на 150% не повлияет на расчетное время усвоения углеводов - Активный инсулин (IOB) На величину IOB влияют устанавливаемые ВБС. Высокая ВБС не будет применяться, если уровень сахара в крови ниже целевого. Отрицательный IOB в течение длительного периода при отсутствии физнагрузки указывает на то, что ваш профиль завышен и требуется снизить кол-во инсулина в настройках. diff --git a/plugins/constraints/src/main/res/values-ru-rRU/strings.xml b/plugins/constraints/src/main/res/values-ru-rRU/strings.xml index f41072aac2..332dd41100 100644 --- a/plugins/constraints/src/main/res/values-ru-rRU/strings.xml +++ b/plugins/constraints/src/main/res/values-ru-rRU/strings.xml @@ -2,22 +2,35 @@ - Переход на летнее/зимнее время через 24 часа или менее - Изменение сезонного времени произошло меньше 3 часов назад-Закрытый цикл выключен - Освободите по крайней мере %1$d MB из внутренней памяти! Цикл остановлен! - старая версия - очень старая версия - Истек срок действия приложения - Новая версия доступна уже %1$d дней! По истечении %2$d дн алгоритм переходит в режим работы только с остановкой при низкой гликемии LGS, замкнутый цикл будет отключен через %3$d дн - Мы обнаружили, что вы используете недопустимую версию. Цикл отключен! - Доступна версия %1$s - Версия: %1$s истекает %2$s - Используются пересчитанные данные - ГК слишком близко к \n%1$s\n%2$s - пересчитано - двойные записи + + Ограничение углеводов до %1$d г. из-за %2$s + Помпа не рассчитана на подачу временного базала + Режим замкнутого цикла отключен в настройках + Работает версия разработчика. Замкнутый цикл отключен. + Замкнутый цикл отключен из-за работы Пролонгированного Болюса + Опция супер микро болюс всегда и после углеводов отключена т. к. активный источник ГК не поддерживает комплексное фильтрование + В режиме незамкнутого цикла open loop супер микро болюс SMB не допускается + максимальное значение в настройках + жесткий предел + Безопасность терапии + + Не завершено + Прошло времени + Максимум активного инсулина IOB установлен правильно + ГК доступна из выбранного источника + Служба синхронизации имеет разрешение на запись + Цикл активирован + Выбран APS + Режим замкнутого цикла включен + ЦЕЛИ + Обучающая программа + Хотите сбросить начатую цель? Можете потерять достигнутое. + Далее + Назад + Очистить завершенные + Очистить начатые diff --git a/plugins/constraints/src/main/res/values-sk-rSK/exam.xml b/plugins/constraints/src/main/res/values-sk-rSK/exam.xml index cb2a3d1ce9..c095f796c0 100644 --- a/plugins/constraints/src/main/res/values-sk-rSK/exam.xml +++ b/plugins/constraints/src/main/res/values-sk-rSK/exam.xml @@ -59,7 +59,6 @@ Nechajte svoju cieľovú glykémiu bez zmeny. Počkajte, kým glykémia neklesne pod Váš dočasný cieľ hypoglykémia a potom zjedzte 15 g rýchlych sacharidov. https://androidaps.readthedocs.io/en/latest/CROWDIN/cs/Usage/temptarget.html#docasny-cil-pri-pohybove-aktivite - Deaktivovaný/pozastavený uzavretý okruh Dostávam inzulín, keď je uzavretý okruh deaktivovaný/pozastavený? Áno, bazálny inzulín je podávaný naďalej. Nie, podávanie inzulínu je zastavené. @@ -149,7 +148,6 @@ Nastavením profilu na 150 % dôjde k predĺženiu doby absorbcie sacharidov Nastavením profilu na 150 % dôjde ku skráteniu doby absorbcie sacharidov Nastavenie profilu na 150% neovplyvní vypočítanú absorbciu sacharidov - Aktívny inzulín (IOB) Hodnota IOB je ovplyvnená vydanými dočasnými bazálmi. Vysoký dočasný bazál nebude spustený, pokiaľ je Vaša glykémia nižšia, ako cieľ. Negatívne IOB po značnú dobu bez cvičenia naznačuje, že váš profil je príliš \"silný\" a vo vašom profile je potrebného menej inzulínu. diff --git a/plugins/constraints/src/main/res/values-sk-rSK/strings.xml b/plugins/constraints/src/main/res/values-sk-rSK/strings.xml index 3a7cd92211..a07b76a8f2 100644 --- a/plugins/constraints/src/main/res/values-sk-rSK/strings.xml +++ b/plugins/constraints/src/main/res/values-sk-rSK/strings.xml @@ -2,22 +2,36 @@ - Zmena letného času za menej ako 24 hodín - Zmena letného času za menej ako 3 hodiny - Uzavretý okruh pozastavený - Uvoľnite aspoň %1$d MB z interného úložiska! Uzavretý okruh zakázaný! - stará verzia - veľmi stará verzia - Aplikácia expirovala - Nová verzia je dostupná minimálne %1$d dní! Prepnutie na ochranu pred nízkou glykémiou po %2$d dňoch, vypnutie uzavretého okruhu po %3$d dňoch - Zistili sme, že používate neplatnú verziu. Uzavretý okruh zakázaný! - Verzia %1$s je k dispozícii - Verzia %1$s expiruje dňa %2$s - Použité prepočítané dáta - Glykémia je príliš blízko:\n%1$s\n%2$s - prepočítané - dvojité zápisy + + Sacharidy obmedzené na %1$d g: %2$s + Pumpa nepodporuje dočasné bazály + Uzavretý okruh zakázaný v nastaveniach + Bežiaca vývojárska verzia. Uzavretý okruh je zakázaný. + Uzavretý okruh je zastavený kvôli prebiehajúcemu predĺženému bolusu + \"SMB vždy\" a \"po jedle\" zakázané pretože zdroj glykémie nepodporuje rozšírené filtrovánie + SBM nie sú povolené pri otvorenom okruhu + maximálna hodnota v nastaveniach + pevný limit + Bezpečnosť zadania ošetrenia + + Hotovo, gratulujeme! + Nedokončené + Uplynutý čas + Maximálne IOB nastavené správne + Glykémie dostupné z vybraného zdroja + Služba synchronizácie má oprávnenie k zápisu + Uzavretý okruh povolený + APS vybrané + Uzavretý okruh povolený + CIEĽ + Výukový program + Chcete resetovať začiatok cieľa? Môžete prísť o svoj pokrok. + Ďalej + Späť + Vymazanie dokončené + Vymazanie začaté diff --git a/plugins/constraints/src/main/res/values-sr-rCS/strings.xml b/plugins/constraints/src/main/res/values-sr-rCS/strings.xml index bf1d7d9314..33cd0ab853 100644 --- a/plugins/constraints/src/main/res/values-sr-rCS/strings.xml +++ b/plugins/constraints/src/main/res/values-sr-rCS/strings.xml @@ -6,4 +6,8 @@ + + Sigurnost tretmana + + Program učenja diff --git a/plugins/constraints/src/main/res/values-sv-rSE/exam.xml b/plugins/constraints/src/main/res/values-sv-rSE/exam.xml index 83c0266e5b..b602ecf91c 100644 --- a/plugins/constraints/src/main/res/values-sv-rSE/exam.xml +++ b/plugins/constraints/src/main/res/values-sv-rSE/exam.xml @@ -51,7 +51,6 @@ Lämna ditt målvärde oförändrat. Vänta tills blodglukosnivån sjunker under ditt Hypo temp mål och sen äter du 15 g av snabbverkande kolhydrater. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Inaktiverad/pausad loop Får jag insulin när loopen är avstängd eller pausad? Ja. Basalinsulin fortsätter att levereras. Nej, leverans av insulin är stoppad. @@ -91,8 +90,6 @@ Du bör fråga din diabetesklinik/endokrinolog. https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - Insulininställningar Vilket insulin ska du använda med insticksprogrammet Ultra-Rapid Oref? Fiasp® NovoRapid®/Novolog® @@ -105,7 +102,6 @@ Om du loggar ett kanylbyte återställs autosens-värdet tillbaka till 100%. Vissa av insticksprogrammen har konfigurerbara tidsintervall som kan ställas in av användaren. https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Fel i KH-inmatning Vad ska du göra om du har gjort en felaktig inmatning? Ta bort den felaktiga posten i Behandlingar och ange rätt kolhydratmängd. @@ -115,7 +111,6 @@ Vad ska du göra om du fått mindre insulin än vad pumpens historik visar, t.ex. på grund av en ocklusion, en felaktig kanyl eller om du glömt att sätta fast pumpen efter en dusch?  Ta bort insulindata från Nightscout för att ta bort den från pumpens historik. Ge en bolus med en del av det insulin du saknar antingen med penna eller genom att använda förfyllningsfunktionen. - Aktivt Insulin (IOB) IOB-värdet påverkas av temp basaler. Hög temp basal kommer inte att ges när ditt BG-värde är under målet. Negativ IOB under en längre period även om du inte motionerat, tyder på att din profil ger för mycket insulin. diff --git a/plugins/constraints/src/main/res/values-sv-rSE/strings.xml b/plugins/constraints/src/main/res/values-sv-rSE/strings.xml index 7e636e8e03..f5af7a434c 100644 --- a/plugins/constraints/src/main/res/values-sv-rSE/strings.xml +++ b/plugins/constraints/src/main/res/values-sv-rSE/strings.xml @@ -2,21 +2,32 @@ - Sommar/vintertid inträffar inom 24 timmar - Sommar/vintertid ändrades för mindre än 3 timmar sedan. Closed Loop avstängt - gammal version - väldigt gammal version - Applikationen inte giltig längre - Ny version tillgänglig för %1$d dagar sedan. Systemet kommer att byta läge till \"stopp innan lågt\" efter %2$d dagar och sluta loopa helt efter %3$d dagar - Du kör en ogiltig version. Loop avstängd! - Version %1$s tillgänglig - Version %1$s upphör att gälla %2$s - Omräknad data används - BG för nära:\n%1$s\n%2$s - omräknad - dubbla poster + + Begränsar kolhydrater till %1$d g pga %2$s + Pumpen kan inte hantera temp basaler + Closed Loop inaktiverat i Inställningar + Du kör nu dev-versionen. Closed Loop inaktiverat. + Closed Loop-läget inaktiverat pga att en förlängd bolus är aktiv + SMB Alltid På och SMB Efter Kolhydrater är inaktiverat pga att den aktiva BG-källan inte stöder avancerad filtrering + SMB inte tillåtet i Open Loop + maxvärde i Inställningar + hård begränsning + Säkerhetsbegränsningar + + Inte slutfört ännu + Förfluten tid + Max IOB är korrekt angivet + BG tillgängligt från vald källa + Loop aktiverad + APS vald + Closed loop aktiverad + Mål + Inlärningsprogram + Vill du starta om målet? Du kan förlora de steg du gjort hittills. + Rensa avslutade + Rensa påbörjade diff --git a/plugins/constraints/src/main/res/values-tr-rTR/exam.xml b/plugins/constraints/src/main/res/values-tr-rTR/exam.xml index 9e8cc068b7..71e5f8380a 100644 --- a/plugins/constraints/src/main/res/values-tr-rTR/exam.xml +++ b/plugins/constraints/src/main/res/values-tr-rTR/exam.xml @@ -59,7 +59,6 @@ Kan şekeri hedefinizi değiştirmeden bırakın. Kan şekeri, hipo geçici hedefinizin altına düşene kadar bekleyin ve ardından 15 g hızlı etkili karbonhidrat yiyin. https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Döngüyü Devre Dışı bırakma/Askıya alma Döngü devre dışı bırakıldığında/askıya alındığında insülin alır mıyım? Evet, bazal insülin verilmeye devam ediyor. Hayır, insülin iletimi durdurulur. @@ -149,7 +148,6 @@ Profili %150\'ye ayarlamak karbonhidratların daha uzun sürede emilmesini sağlar Profili %150\'ye ayarlamak karbonhidratların daha kısa sürede emilmesini sağlar Profili %150\'ye ayarlamak hesaplanan karbonhidrat emilimini etkilemez - Aktif İnsülin (AİNS) AİNS değeri, verilen geçici bazallardan etkilenir. Kan şekeriniz hedefin altına düştüğünde yüksek geçici bazal verilmeyecektir. Egzersiz yapmadığınız halde uzun bir dönem için negatif AİNS, profilinizin çok güçlü olduğunu ve ayarlarınızda daha az insüline ihtiyaç duyulduğunu gösterir. diff --git a/plugins/constraints/src/main/res/values-tr-rTR/strings.xml b/plugins/constraints/src/main/res/values-tr-rTR/strings.xml index bb9440f446..60355c3d2b 100644 --- a/plugins/constraints/src/main/res/values-tr-rTR/strings.xml +++ b/plugins/constraints/src/main/res/values-tr-rTR/strings.xml @@ -2,22 +2,19 @@ - 24 saat veya daha kısa süre içinde yaz saati değişikliği - Yaz Saati Uygulaması 3 saatten daha kısa bir süre önce değişti - Kapalı döngü devre dışı - Dahili depolama biriminden en az %1$d MB yer kaldı! Döngü devre dışı! - eski sürüm - çok eski sürüm - Uygulamanın süresi doldu - En az %1$d gündür yeni sürüm mevcut! %2$d gün sonra LGS\'ye (Düşük Glukoz gönderimine) dönülecek, %3$d gün sonra da döngü devre dışı bırakılacaktır - Geçersiz bir sürüm çalıştırdığınızı tespit ettik. Döngü devre dışı! - Sürüm %1$s mevcut - %1$s sürümünün süresi %2$s tarihinde sona eriyor - Kullanılan veriler yeniden hesaplandı - KŞ çok yakın:\n%1$s\n%2$s - tekrar hesaplandı - çift giriş + Düz veri. Yanlış kabul edildi + + %2$s\'den dolayı karbonhidratlar %1$d g ile sınırlandırılıyor + Pompa geçici bazal özellikli değil + Kapalı Döngü tercihlerde devre dışı bırakıldı + Geliştirici sürümü çalışıyor. Kapalı Döngü devre dışı. + Yayma bolus çalıştığı için kapalı döngü devre dışı bırakıldı + Aktif KŞ kaynağı gelişmiş filtrelemeyi desteklemediği için SMB (Super Micro Bolus) her zaman ve karbonhidratlardan sonra devre dışı bırakıldı + Açık Döngü modunda SMB\'ye (Super Micro Bolus) izin verilmiyor + tercihlerde maksimum değer + diff --git a/plugins/constraints/src/main/res/values-zh-rCN/exam.xml b/plugins/constraints/src/main/res/values-zh-rCN/exam.xml index 7148e5a434..46a8a8e815 100644 --- a/plugins/constraints/src/main/res/values-zh-rCN/exam.xml +++ b/plugins/constraints/src/main/res/values-zh-rCN/exam.xml @@ -51,7 +51,6 @@ 让你的血糖目标保持不变。 等血糖值低于你的低血糖警戒线之后,吃15克速升的活性碳水合物。 https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - 禁用/暂停闭环 在禁用/暂停闭环时,我是否接收了胰岛素输注? 是的,胰岛素基础率仍在继续输注。 不,胰岛素停止输注。 @@ -92,7 +91,6 @@ https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ https://discord.gg/4fQUWHZ4Mw - 胰岛素插件 在超速效Oref插件中你应该使用哪种胰岛素? Fiasp®速效门冬胰岛素(超速效) 诺和锐®/门冬胰岛素® @@ -128,7 +126,6 @@ 指定一个150%的配置文件切换会更快吸收碳水 指定一个150%的配置文件切换会更快吸收碳水 指定一个150%的配置文件切换不会影响碳水吸收 - 活性胰岛素(IOB) 活性胰岛素IOB数值受发布的临时基础率影响。 当您的血糖低于目标值时,不会被给予高临时基础率。 在没有运动的情况下,活性胰岛素IOB长时间负数表明你的个人配置太强,你需要在配置中减少的胰岛素用量。 diff --git a/plugins/constraints/src/main/res/values-zh-rCN/strings.xml b/plugins/constraints/src/main/res/values-zh-rCN/strings.xml index 3cbe0046ba..87a84b754d 100644 --- a/plugins/constraints/src/main/res/values-zh-rCN/strings.xml +++ b/plugins/constraints/src/main/res/values-zh-rCN/strings.xml @@ -2,21 +2,32 @@ - 在24小时或更少时间内变更\"夏令时\" - 夏令时变更在三小时内-已禁用闭环 - 旧版本 - 非常旧版本 - 应用版本已过期。 - 新版本已发布至少%1$d天!将在%2$d天后回退到LGS (低血糖维持模式),闭环功能将在%3$d天后禁用。 - 我们检测到您运行的版本无效。 已禁用循环! - 版本 %1$s 可用 - 版本 %1$s 将在 %2$s 过期 - 重新计算的数据 - 血糖间隔太近:\n%1$s\n%2$s - 重新计算 - 双重条目 + + 由于 %2$s, 将碳水化合物限制为 %1$d 克 + 这个泵无法设置临时基础率 + 在参数选项中禁用了闭环模式 + 正在运行开发版本,闭环被禁用了 + 由于运行扩展大剂量而禁用了闭环 + SMB always and after carbs disabled 因为实时的血糖来源不支持高级筛选 + 在开环模式下不允许使用SMB-微型大剂量 + 在参数选项里的最大值 + 硬限制 + 治疗安全 + + 尚未完成 + 已用时间 + 合理地设置最大 IOB + 所选的血糖值来源的血糖是可用的 + 闭环启用了 + APS已选择 + 闭环模式启用了 + 目标 + 学习计划 + 你想要重置已启动的目标? 你会失去已有的进度。 + 清除已完成 + 清除已启动 diff --git a/plugins/insulin/src/main/res/values-af-rZA/strings.xml b/plugins/insulin/src/main/res/values-af-rZA/strings.xml new file mode 100644 index 0000000000..5fb6d9b49a --- /dev/null +++ b/plugins/insulin/src/main/res/values-af-rZA/strings.xml @@ -0,0 +1,13 @@ + + + + Insulien voorkeure vir Humalog en NovoRapid / NovoLog + Insulien voorkeure vir Fiasp + Laat jou toe om die piek van die insulien aktiwiteit definieer en behoort slegs gebruik te word deur gevorderde gebruikers + INS + IAB kurwe piek tyd + Piek tyd [min] + Vry-piek Oref + Snelaksie Oref + DIA van %1$f is te kort - %2$f in stede gebruik! + diff --git a/plugins/insulin/src/main/res/values-bg-rBG/strings.xml b/plugins/insulin/src/main/res/values-bg-rBG/strings.xml new file mode 100644 index 0000000000..231eb1958f --- /dev/null +++ b/plugins/insulin/src/main/res/values-bg-rBG/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Действие на инсулините Humalog и NovoRapid / NovoLog + Действие на инсулин Fiasp + Действие на инсулин Lyumjev + Позволява да зададете сами пика на инсулиновата активност (не използвайте, ако сте нови потребители) + ИНС + Пик на кривата на IOB + Време на пик [мин.] + Със свободен пик по Oref + Бързодействащ по Oref + DIA от %1$f е твърде кратка - използвай %2$f вместо това! + diff --git a/plugins/insulin/src/main/res/values-ca-rES/strings.xml b/plugins/insulin/src/main/res/values-ca-rES/strings.xml new file mode 100644 index 0000000000..8e232783a9 --- /dev/null +++ b/plugins/insulin/src/main/res/values-ca-rES/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Configuració preestablerta per insulina Humalog i NovoRapid/NovoLog + Configuració preestablerta per insulina Fiasp + Configuració preestablerta per insulina Lyumjev + Permet definir el pic d\'activitat de la insulina. A utilitzar només per usuaris avançats + INS + Pic de la corba IOB + Temps del pic [min] + Oref sense pic + Oref ràpida + DIA de %1$f massa curt - utilitzant %2$f! + diff --git a/plugins/insulin/src/main/res/values-cs-rCZ/strings.xml b/plugins/insulin/src/main/res/values-cs-rCZ/strings.xml new file mode 100644 index 0000000000..c826e5ddc5 --- /dev/null +++ b/plugins/insulin/src/main/res/values-cs-rCZ/strings.xml @@ -0,0 +1,18 @@ + + + + Lyumjev + Předvolba pro Novorapid + Předvolba pro Fiasp + Předvolba pro Lyumjev + Možnost definice vrcholu účinnosti inzulínu pro pokročilé uživatele + INZ + Čas vrcholu IOB křivky + Vrchol křivky [min] + Volitelný vrchol - Oref + Rychle působící - Oref + Ultra rychlý - Oref + DIA %1$f je příliš krátké - použito %2$f ! + Novorapid + Fiasp + diff --git a/plugins/insulin/src/main/res/values-da-rDK/strings.xml b/plugins/insulin/src/main/res/values-da-rDK/strings.xml new file mode 100644 index 0000000000..f6c2efdda1 --- /dev/null +++ b/plugins/insulin/src/main/res/values-da-rDK/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Insulin forudindstillet til Humalog og NovoRapid / NovoLog + Insulinforudindstilling til Fiasp + Insulin forudindstillet til Lyumjev + Giver dig mulighed for at definere spidsbelastningen af insulin-aktiviteten og bør kun bruges af avancerede brugere + INS + IOB Kurve Peak-Tid + Spidstidspunkt [min] + Free-Peak Oref + Rapid-Acting Oref + DIA af %1$f for kort - bruger %2$f i stedet! + diff --git a/plugins/insulin/src/main/res/values-de-rDE/strings.xml b/plugins/insulin/src/main/res/values-de-rDE/strings.xml new file mode 100644 index 0000000000..154c9660a7 --- /dev/null +++ b/plugins/insulin/src/main/res/values-de-rDE/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Insulinprofil für Humalog und NovoRapid / NovoLog + Insulinprofil für Fiasp + Insulin-Voreinstellung für Lyumjev + Erlaubt dir, das Wirkmaximum der Insulinaktivität zu definieren, und sollte nur von erfahrenen Anwendern genutzt werden + INS + Wirkungshoch der IOB-Kurve + Wirkungshoch [min] + Free-Peak Oref + Rapid-Acting Oref + DIA von %1$f ist zu kurz - AAPS nutzt stattdessen %2$f! + diff --git a/plugins/insulin/src/main/res/values-el-rGR/strings.xml b/plugins/insulin/src/main/res/values-el-rGR/strings.xml new file mode 100644 index 0000000000..52f2b7adf4 --- /dev/null +++ b/plugins/insulin/src/main/res/values-el-rGR/strings.xml @@ -0,0 +1,14 @@ + + + + Η ινσουλίνη που ορίζεται Humalog και NovoRapid / NovoLog + Η ινσουλίνη που ορίζεται για Fiasp + Προκαθορισμός ινσουλίνης για την Lyumjev + Σας επιτρέπει να ορίσετε το μέγιστο της δράσης της ινσουλίνης και πρέπει να χρησιμοποιείται μόνο από προχωρημένους χρήστες + INS + Μέγιστη τιμή καμπύλης IOB + Μέγιστο καμπύλης [λεπτά] + Προαιρετικά-αιχμή Oref + Γρήγορη δράση - Oref + DIA για %1$f πολύ μικρή - χρησιμοποιήστε %2$f! + diff --git a/plugins/insulin/src/main/res/values-es-rES/strings.xml b/plugins/insulin/src/main/res/values-es-rES/strings.xml new file mode 100644 index 0000000000..cfae27e7b6 --- /dev/null +++ b/plugins/insulin/src/main/res/values-es-rES/strings.xml @@ -0,0 +1,18 @@ + + + + Lyumjev + Ajustes de insulina preestablecidos para Humalog y NovoRapid/NovoLog + Ajuste de insulina preestablecido para Fiasp + Ajuste de insulina preestablecido para Lyumjev + Permite personalizar el pico de acción máxima de la insulina. Debe ser utilizado únicamente por usuarios avanzados + INS + Tiempo del pico máximo de la curva de IOB + Tiempo del pico máximo de acción de la insulina [min] + Personalizar Pico + Acción Rápida + Ultra-Rápido Oref + DIA de %1$f demasiado corto - usando %2$f! + Novorapid, Novolog, Humalog + Fiasp + diff --git a/plugins/insulin/src/main/res/values-fr-rFR/strings.xml b/plugins/insulin/src/main/res/values-fr-rFR/strings.xml new file mode 100644 index 0000000000..9c694e762c --- /dev/null +++ b/plugins/insulin/src/main/res/values-fr-rFR/strings.xml @@ -0,0 +1,8 @@ + + + + Profil d\'insuline ajustable Oref + Insuline à Action Rapide Oref + Insuline Ultra Rapide Oref + Durée d’Action pour %1$f trop courte - utiliser %2$f à la place ! + diff --git a/plugins/insulin/src/main/res/values-ga-rIE/strings.xml b/plugins/insulin/src/main/res/values-ga-rIE/strings.xml new file mode 100644 index 0000000000..3a488759e1 --- /dev/null +++ b/plugins/insulin/src/main/res/values-ga-rIE/strings.xml @@ -0,0 +1,8 @@ + + + + Lyumjev + INS + Free-Peak Oref + Rapid-Acting Oref + diff --git a/plugins/insulin/src/main/res/values-hr-rHR/strings.xml b/plugins/insulin/src/main/res/values-hr-rHR/strings.xml new file mode 100644 index 0000000000..9ae27b2a08 --- /dev/null +++ b/plugins/insulin/src/main/res/values-hr-rHR/strings.xml @@ -0,0 +1,18 @@ + + + + Lyumjev + Unaprijed podešen predložak za inzulin Humalog i NovoRapid / NovoLog + Unaprijed podešen predložak za inzulin Fiasp + Unaprijed podešen predložak za inzulin Lyumjev + Omogućuje definiranje vrhunca aktivnosti inzulina i trebaju ga koristiti samo napredni korisnici + INS + Vršno vrijeme IOB krivulje + Špica [min] + Free-Peak Oref + Rapid-Acting Oref + Ultra-Rapid Oref + DIA od %1$f prekratak - umjesto njega koristite %2$f! + Novorapid, Novolog, Humalog + Fiasp + diff --git a/plugins/insulin/src/main/res/values-hu-rHU/strings.xml b/plugins/insulin/src/main/res/values-hu-rHU/strings.xml new file mode 100644 index 0000000000..66babda07f --- /dev/null +++ b/plugins/insulin/src/main/res/values-hu-rHU/strings.xml @@ -0,0 +1,5 @@ + + + + Lyumjev + diff --git a/plugins/insulin/src/main/res/values-it-rIT/strings.xml b/plugins/insulin/src/main/res/values-it-rIT/strings.xml new file mode 100644 index 0000000000..3a56fd08d9 --- /dev/null +++ b/plugins/insulin/src/main/res/values-it-rIT/strings.xml @@ -0,0 +1,18 @@ + + + + Lyumjev + Preset per insulina Humalog e NovoRapid / NovoLog + Preset per insulina Fiasp + Preset per insulina Lyumjev + Ti consente di definire il picco di attività dell\'insulina e dovrebbe essere usato solo dagli utenti avanzati + INS + Tempo picco Curva IOB + Tempo del picco [min] + Free-Peak Oref + Rapid-Acting Oref + Ultra-Rapid Oref + DIA di %1$f troppo breve - uso %2$f. + Novorapid, Novolog, Humalog + Fiasp + diff --git a/plugins/insulin/src/main/res/values-iw-rIL/strings.xml b/plugins/insulin/src/main/res/values-iw-rIL/strings.xml new file mode 100644 index 0000000000..c646250f3d --- /dev/null +++ b/plugins/insulin/src/main/res/values-iw-rIL/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + הגדרת אינסולין ל-Humalog ו- NovoRapid / Novolog + הגדרת אינסולין מסוג Fiasp + הגדרת אינסולין מסוג Lyumjev + מאפשר להגדיר את שיא פעילות האינסולין, לשימוש על ידי משתמשים מתקדמים בלבד + אינסולין + שעת שיא של עקומת IOB + זמן שיא [min] + Oref שיא חופשי + Oref אינסולין מהיר + DIA במשך %1$f הוא קצר מדי - משתמש ב-%2$f במקום! + diff --git a/plugins/insulin/src/main/res/values-ja-rJP/strings.xml b/plugins/insulin/src/main/res/values-ja-rJP/strings.xml new file mode 100644 index 0000000000..202a838052 --- /dev/null +++ b/plugins/insulin/src/main/res/values-ja-rJP/strings.xml @@ -0,0 +1,4 @@ + + + + diff --git a/plugins/insulin/src/main/res/values-ko-rKR/strings.xml b/plugins/insulin/src/main/res/values-ko-rKR/strings.xml new file mode 100644 index 0000000000..f7b478b739 --- /dev/null +++ b/plugins/insulin/src/main/res/values-ko-rKR/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + 휴마로그와 노보래피드에 대한 인슐린 설정 + 피아스프에 대한 인슐린 설정 + Lyumjev에 대한 인슐린 설정 + 인슐린활동의 피크를 직접 정의할 수 있습니다. 고급 사용자만 사용해야 합니다. + INS + IOB 커브 피크 시간 + 피크 시간 [min] + 사용자지정-피크 Oref + 초속효성 Oref + DIA %1$f는 너무 짧습니다. 대신 %2$f을 사용하세요! + diff --git a/plugins/insulin/src/main/res/values-lt-rLT/strings.xml b/plugins/insulin/src/main/res/values-lt-rLT/strings.xml new file mode 100644 index 0000000000..eefafe7eeb --- /dev/null +++ b/plugins/insulin/src/main/res/values-lt-rLT/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Nustatymai Humalog ir NovoRapid / NovoLog insulinams + Nustatymai Fiasp insulinui + Nustatymai Lyumjev insulinui + Leidžia pasirinkti insulino veikimo piką ir turėtų būti naudojama tik patyrusių vartotojų + INS + AIO kreivės pikas + Piko laikas [min] + Oref be piko + Greito veikimo Oref + IVT %1$f per trumpa - bus naudojama %2$f! + diff --git a/plugins/insulin/src/main/res/values-nl-rNL/strings.xml b/plugins/insulin/src/main/res/values-nl-rNL/strings.xml new file mode 100644 index 0000000000..34babec837 --- /dev/null +++ b/plugins/insulin/src/main/res/values-nl-rNL/strings.xml @@ -0,0 +1,18 @@ + + + + Lyumjev + Insuline instelling voor Humalog en NovoRapid / NovoLog + Insuline instelling voor Fiasp + Insuline instelling voor Lyumjev + Hiermee kan je de piek van de insulineactiviteit definiëren, mag alleen worden gebruikt door gevorderde gebruikers + INS + IOB curve piek tijd + Piek tijd [min] + Free-Peak Oref + Snel-werkende Oref + Ultra-Rapid Oref + DIA van %1$f te kort - %2$f wordt inplaats gebruikt! + Novorapid, Novolog, Humalog + Fiasp + diff --git a/plugins/insulin/src/main/res/values-no-rNO/strings.xml b/plugins/insulin/src/main/res/values-no-rNO/strings.xml new file mode 100644 index 0000000000..946d281446 --- /dev/null +++ b/plugins/insulin/src/main/res/values-no-rNO/strings.xml @@ -0,0 +1,18 @@ + + + + Lyumjev + Insulininnstillinger for Humalog og NovoRapid / NovoLog + Insulininnstillinger for Fiasp + Insulininnstillinger for Lyumjev + Lar deg definere toppen på insulinaktiviteten og skal kun brukes av avanserte brukere + INS + IOB-kurvens topptid + Topptid [min] + Egendefinert topp Oref + Hurtigvirkende Oref + Ultra-Rapid Oref + DIA på %1$f er for kort - bruker %2$f i stedet! + Novorapid, Novolog, Humalog + Fiasp + diff --git a/plugins/insulin/src/main/res/values-pl-rPL/strings.xml b/plugins/insulin/src/main/res/values-pl-rPL/strings.xml new file mode 100644 index 0000000000..617a4262c2 --- /dev/null +++ b/plugins/insulin/src/main/res/values-pl-rPL/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Profil insulinowy dla Humalog i Novorapid / NovoLog + Profil insulinowy dla Fiasp + Profil insulinowy dla Lyumjev + Pozwala na określenie czasu wartości szczytowej działania insuliny i powinno być używane tylko przez zaawansowanych użytkowników + INS + IOB Czas piku krzywej działania insuliny + Czas piku [min] + Swobodny-Pik Oref + Szybko-Działający Oref + DIA %1$f zbyt krótki - przyjmuję %2$f w zamian! + diff --git a/plugins/insulin/src/main/res/values-pt-rBR/strings.xml b/plugins/insulin/src/main/res/values-pt-rBR/strings.xml new file mode 100644 index 0000000000..b5d07bbb0e --- /dev/null +++ b/plugins/insulin/src/main/res/values-pt-rBR/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Predefinição de Insulina para Humalog e NovoRapid / NovoLog + Pré-ajuste de Insulina para Fiasp + Configuração pre-definida para a Insulina Lyumyev + Permite que você defina o pico da atividade de insulina, deve ser usado apenas por usuários avançados + INS + Tempo Pico da curva de IOB + Tempo Pico [min] + Oref Pico-Livre + Oref Ação Rápida + Duração de Acção da Insulina (DIA) de %1$f demasiado curto - corrigido para %2$f! + diff --git a/plugins/insulin/src/main/res/values-pt-rPT/strings.xml b/plugins/insulin/src/main/res/values-pt-rPT/strings.xml new file mode 100644 index 0000000000..590034c689 --- /dev/null +++ b/plugins/insulin/src/main/res/values-pt-rPT/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Predefinição de Insulina Humalog e NovoRapid / NovoLog + Predefinição de Insulina Fiasp + Predefinição para Insulina Lyumjev + Permite definir o pico de atividade da insulina e deve ser usado somente por usuários avançados + INS + Tempo do Pico da curva de IA + Tempo Pico [min] + Oref Pico-Livre + Oref Acção-Rápida + Duração de Acção da Insulina (DIA) de %1$f demasiado curto - corrigido para %2$f! + diff --git a/plugins/insulin/src/main/res/values-ro-rRO/strings.xml b/plugins/insulin/src/main/res/values-ro-rRO/strings.xml new file mode 100644 index 0000000000..202a838052 --- /dev/null +++ b/plugins/insulin/src/main/res/values-ro-rRO/strings.xml @@ -0,0 +1,4 @@ + + + + diff --git a/plugins/insulin/src/main/res/values-ru-rRU/strings.xml b/plugins/insulin/src/main/res/values-ru-rRU/strings.xml new file mode 100644 index 0000000000..34cce261e1 --- /dev/null +++ b/plugins/insulin/src/main/res/values-ru-rRU/strings.xml @@ -0,0 +1,18 @@ + + + + Lyumjev + Предустановки для Humalog и Novorapid / Novolog + Предустановки для Fiasp + Предустановки для Lyumjev + Позволяет самостоятельно задавать пик активности инсулина - только для опытных пользователей + ИНС + Время пика активного инс IOB + Время пика [min] + Свободный от пиков Oref + Быстро действующий Oref + Сверхбыстрый Oref + Значение времени действия инс %1$f слишком мало - применено %2$f! + Новорапид, Хумалог + Фиасп + diff --git a/plugins/insulin/src/main/res/values-sk-rSK/strings.xml b/plugins/insulin/src/main/res/values-sk-rSK/strings.xml new file mode 100644 index 0000000000..4afb8f4947 --- /dev/null +++ b/plugins/insulin/src/main/res/values-sk-rSK/strings.xml @@ -0,0 +1,18 @@ + + + + Lyumjev + Predvoľba pre inzulín Humalog a Novorapid + Predvoľba pre inzulín Fiasp + Predvoľba pre inzulín Lyumjev + Umožňuje definovať vrchol účinnosti inzulínu a malo by byť používané iba pokročilými užívateľmi + INZ + Čas vrcholu IOB krivky + Vrchol krivky [min] + Voliteľný vrchol - Oref + Rýchlo pôsobiaci - Oref + Ultra rýchly - Oref + DIA %1$f je príliš krátke - AAPS namiesto toho použilo %2$f ! + Novorapid, Novolog, Humalog + Fiasp + diff --git a/plugins/insulin/src/main/res/values-sr-rCS/strings.xml b/plugins/insulin/src/main/res/values-sr-rCS/strings.xml new file mode 100644 index 0000000000..72aa6dbdc2 --- /dev/null +++ b/plugins/insulin/src/main/res/values-sr-rCS/strings.xml @@ -0,0 +1,8 @@ + + + + Unapred podešena postavka insulina za Humalog i NovoRapid / NovoLog + Unapred podešena postavka insulina za Fiasp + Unapred podešena postavka insulina za Lyumjev + Omogućava definisanje vrhunca aktivnosti insulina i trebaju ga koriste samo napredni korisnici + diff --git a/plugins/insulin/src/main/res/values-sv-rSE/strings.xml b/plugins/insulin/src/main/res/values-sv-rSE/strings.xml new file mode 100644 index 0000000000..c067f3fa91 --- /dev/null +++ b/plugins/insulin/src/main/res/values-sv-rSE/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev + Insulininställning för vanliga direktverkande insuliner som Humalog, Lispro, Apidra och Novorapid/Novolog + Insulininställning för ultrasnabba insuliner, t ex Fiasp + Insulininställning för Lyumjev + Låter dig ställa in tidpunkten för toppen på insulinets aktivitet. Bör bara användas av avancerade användare + INS + Peaktid för IOB-kurvan + Peaktid [min] + Free-Peak Oref + Rapid-Acting Oref + %1$f tim DIA är för kort. Använder %2$f istället! + diff --git a/plugins/insulin/src/main/res/values-tr-rTR/strings.xml b/plugins/insulin/src/main/res/values-tr-rTR/strings.xml new file mode 100644 index 0000000000..18be9640f5 --- /dev/null +++ b/plugins/insulin/src/main/res/values-tr-rTR/strings.xml @@ -0,0 +1,11 @@ + + + + Lyumjev + Humalog ve NovoRapid / NovoLog için İnsülin Profili + Fiasp için insülin Profili + Lyumjev için insülin ayarı + İnsülin aktivitesinin zirvesini tanımlamanıza izin verir ve yalnızca ileri düzey kullanıcılar tarafından kullanılmalıdır. + İNS + DIA %1$f çok kısa - bunun yerine %2$f kullanıyor! + diff --git a/plugins/insulin/src/main/res/values-zh-rCN/strings.xml b/plugins/insulin/src/main/res/values-zh-rCN/strings.xml new file mode 100644 index 0000000000..fc0ef79491 --- /dev/null +++ b/plugins/insulin/src/main/res/values-zh-rCN/strings.xml @@ -0,0 +1,15 @@ + + + + Lyumjev(超速效赖脯胰岛素) + 胰岛素预设为 Humalog(优泌乐) 和 NovoRapid(门冬)/NovoLog(诺和锐) + Fiasp 胰岛素预设 + 预设为Lyumjev速效赖脯胰岛素 + 允许您定义胰岛素作用的峰值, 并且只应由高级用户使用 + INS + IOB 曲线峰值时间 + 峰值时间 [min] + Free-Peak Oref + 速效 Oref + DIA of %1$f 太短了,请使用 %2$f 代替 + diff --git a/plugins/main/src/main/res/values-af-rZA/strings.xml b/plugins/main/src/main/res/values-af-rZA/strings.xml index f9a4b38857..fde8d81627 100644 --- a/plugins/main/src/main/res/values-af-rZA/strings.xml +++ b/plugins/main/src/main/res/values-af-rZA/strings.xml @@ -47,19 +47,6 @@ Opgeskort (%1$d m) Lees status gefaal Profiel skakelaar geskep - - Insulien voorkeure vir Humalog en NovoRapid / NovoLog - Insulien voorkeure vir Fiasp - Laat jou toe om die piek van die insulien aktiwiteit definieer en behoort slegs gebruik te word deur gevorderde gebruikers - INS - IAB kurwe piek tyd - Piek tyd [min] - Vry-piek Oref - Snelaksie Oref - Ultra-Snel Oref - DIA van %1$f is te kort - %2$f in stede gebruik! - Novorapid, Novolog, Humalog - Fiasp xds @@ -89,19 +76,6 @@ Foute DIA BAS - - Voltooi, baie mooi gedoen! - Nog nie voltooi nie - Tydsverloop - Maksimum IAB behoorlik gestel - BG beskikbaar vanaf geselekteerde bron - Lus geaktiveer - APS gekies - Geslote modus geaktiveer - OBJ - Onderrig program - Volgende - Vorige Aksies \'n Paar knoppies vir vinnige algemene nutsfunskies @@ -112,17 +86,6 @@ Geskiedenis blaaier Sensor Insulien - - Verlengde bolus is beperk tot %1$.1f U as gevolg van %2$s - Beperk koolhidrate tot %1$d g agv %2$s - Pomp is nie tydelike basale bekwame - Geslote lus modus in voorkeure gedeaktiveer - Veranderende ontwikkelende weergawe. Geslote lus is gedeaktiveerd. - SMB is altyd na koolhidrate versper omdat aktiewe BG bron nie gevorderde filter ondersteun nie - SMB nie toegelaat in open lus modus - maks waarde in voorkeure - harde limiet - Behandelings veiligheid Wys status vlae op tuisskerm Drempel waarskuwings stoor vlak [U] @@ -204,36 +167,6 @@ ACT BEHANDEL SENS - - Virtuele Pomp - Pomp definisie - Bolus: Stap =%1$s\nVerlengde Bolus: [stap%2$s, duur = =%3$smin -%4$sh]\nBasal: stap =%5$s\nTBR: %6$s (deur %7$s), duur =%8$smin -%9$sh\n%10$s - VPOMP - Pomp integrasie vir pompe wat nog nie enige drywer het nie (oop lus) - VIRTUELE POMP - Virtuele pomp instellings - Oplaaistatus aan NS - - NSClient BG - Laai BG data af vanaf Nightscout - xDrip+ - Ontvang BG waardes vana xDrip+. - Eversense App (bygewerk) - Ontvang BG waardes uit die gelapte Eversense toep. - Glimp - Ontvang BG waardes vanaf Glimp. - MM640g - Onvang BG waardes vanaf die 600SeriesAndroidUploader. - Poctech - Ontvang BG waardes van Poctech toepassing - Tomato (MiaoMiao) - Tomato - Ontvang BG waardes vanaf Tomato toep (MiaoMiao toestel) - BG - Stuur BG data na xDrip+ - Xdrip+ kies 640g/Eversense data bron - BG oplaai instellings - Log sensor verander na NS diff --git a/plugins/main/src/main/res/values-bg-rBG/strings.xml b/plugins/main/src/main/res/values-bg-rBG/strings.xml index 782fcaa974..6c1d1ea0de 100644 --- a/plugins/main/src/main/res/values-bg-rBG/strings.xml +++ b/plugins/main/src/main/res/values-bg-rBG/strings.xml @@ -97,21 +97,6 @@ Четенето на статуса се провали Създаден запис - Промяна на профил Продължителността на временния база; трябва да бъде кратна на %1$d минути и по-голяма от 0. - - Lyumjev - Действие на инсулините Humalog и NovoRapid / NovoLog - Действие на инсулин Fiasp - Действие на инсулин Lyumjev - Позволява да зададете сами пика на инсулиновата активност (не използвайте, ако сте нови потребители) - ИНС - Пик на кривата на IOB - Време на пик [мин.] - Със свободен пик по Oref - Бързодействащ по Oref - Ултра бързодействащ по Oref - DIA от %1$f е твърде кратка - използвай %2$f вместо това! - Novorapid Novolog, Humalog - Fiasp xDrip+ линия със статута (часовник) @@ -158,22 +143,6 @@ DIA Цел БАЗА - - Приключихме, Браво! - Все още не сме неприключили - Изминало време - Максимален IOB е зададен правилно - Има данни за КЗ от избрания източник - APS разрешен - Избран APS - APS - Затворен кръг е позволен - Цел - Разучаване на програмата - Искате ли да нулирате прогреса си? - Следващ - Предишен - Изчисти приключение - Изчисти стартираните Действия Бутони за бърз достъп до основни функции @@ -190,18 +159,6 @@ Батерия на помпата Канюла Използване на удължен болус ще спре режим затворен цикъл за времето на болуса. Сигурни ли сте? - - Ограничение на удължен болус до %1$.1f Е поради %2$s - Ограничаване на въглехидрати до %1$d гр. поради %2$s - Помпата не поддържа временен базал - Затворения кръг е забранен в настройките - Използвате dev версия. Затворения кръг е недостъпен за Вас. - Затворен цикъл е недостъпен поради стартиран Удължен болус - SMB \"винаги включен\" и \"след въглехидрати\" е забранен, защото е активен източник на КЗ, който не поддържа необходимата филтрация - SMB не е позволен в режим Отворен кръг - макс. стойност в настройките - твърд лимит - Настройки на сигурността Покажи статус светлини на началния екран Праг за инсулинова възраст [часа] @@ -315,43 +272,6 @@ Леч ЧУВСТВ Графика - - Виртуална помпа тип - Описание на помпата - Болус: Стъпка =%1$s\Удължен болус: [стъпка =%2$s, продължителност =%3$smin -%4$sh] \nБазал: стъпка =%5$s\ nTBR: %6$s (от %7$s), продължителност =%8$sмин -%9$sh\n%10$s - ВП - За помпи, който все още не работят с AndroidAPS(Open Loop) - ВИРТУАЛНА ПОМПА - Настойки Виртуална Помпа - Качва статуса в NS - - КЗ от NS - NS КЗ - Изтегля стойности на КЗ от Nightscout - xDrip+ - Получаване на данни за КЗ от xDrip+. - BYODA - BYODA - Eversense приложение(модифицирано) - Получава данни за КЗ от модифицираното приложение на Eversense. - Glimp - Получава данни за КЗ от Glimp. - MM640g - Получават стойности на КЗ от 600SeriesAndroidUploader. - Poctech - Получавай данни за КЗ от Poctech апликацията. - Глуново - Получавай данните от Glunowo апликацията - Tomato(MяоМяо) - Tomato - Получавай КЗ от Tomato апликация (устройство МяоМяо) - Произволна КЗ - Генерира произволни захари(демо режим) - КЗ - Изпращай данни за КЗ към xDrip+ - В xDrip+ изберете 640g/Eversense за източник на данни - Настройки при качване на КЗ към Nightscout - Записвай смяната на сензор в NS Оригинален изглед Скин за ниска резолюция diff --git a/plugins/main/src/main/res/values-ca-rES/strings.xml b/plugins/main/src/main/res/values-ca-rES/strings.xml index ceb13e5ad8..a45d9d245f 100644 --- a/plugins/main/src/main/res/values-ca-rES/strings.xml +++ b/plugins/main/src/main/res/values-ca-rES/strings.xml @@ -97,21 +97,6 @@ Error en llegir estat Canvi de perfil creat La durada d\'una TBR ha de ser múltiple de %1$d minuts i més gran que 0. - - Lyumjev - Configuració preestablerta per insulina Humalog i NovoRapid/NovoLog - Configuració preestablerta per insulina Fiasp - Configuració preestablerta per insulina Lyumjev - Permet definir el pic d\'activitat de la insulina. A utilitzar només per usuaris avançats - INS - Pic de la corba IOB - Temps del pic [min] - Oref sense pic - Oref ràpida - Oref ultra ràpida - DIA de %1$f massa curt - utilitzant %2$f! - Novorapid, Novolog, Humalog - Fiasp Línia d\'estat d\'xDrip+ (rellotge) @@ -158,22 +143,6 @@ DIA OBJ BAS - - Enllestit, ben fet! - No finalitzat encara - Temps transcorregut - Màx IOB correctament configurada - Glucèmia disponible des de la font seleccionada - Llaç activat - APS seleccionat - Llaç tancat activat - OBJ - Programa d\'aprenentatge - Voleu reiniciar l\'objectiu? Podeu perdre el vostre progrés. - Següent - Previ - Cancel·lar finalització - Cancel·lar inici Accions Alguns botons per accedir ràpid a funcions habituals @@ -190,18 +159,6 @@ Pila de la bomba Cànula L\'ús d\'un bolus estès aturarà el mode llaç tancat mentre duri el bolus. Esteu segurs que voleu això? - - Limitant bolus estès a %1$.1f U a causa de %2$s - Limitant carbs a %1$d g a causa de %2$s - La bomba no té la funcionalitat de basals temporals - Mode llaç tancat desactivat a la configuració - Executant versió de desenvolupament. Llaç tancat no disponible. - Llaç tancat desactivat degut a bolus estès actiu - Les funcions \"SMB sempre\" i \"SMB després de carbohidrats\" estan desactivades pq la font de glucèmia no fa filtrat avançat - SMB no permès en mode llaç obert - valor màxim a la configuració - límit estricte - Seguretat tractaments Mostrar indicadors d\'estat a la pantalla d\'inici Llindar per avís d\'edat de l\'insulina [h] @@ -313,44 +270,6 @@ TRACT SENS Gràfica - - Tipus de bomba virtual - Definició de bomba - Bolus: Pas=%1$s\nBolus estès: [Pas=%2$s, Durada=%3$smin-%4$sh]\nBasal: Pas=%5$s\nTBR: %6$s (per %7$s), Durada=%8$smin-%9$sh\n%10$s - BOMBAV - Integració de bombes d\'insulina per les quals encara no existeix driver/controlador (Llaç obert) - BOMBA VIRTUAL - Configuració bomba virtual - Enviar estat a NS - - Glucèmia NSClient - Glucèmia NS - Descarrega dades de glucèmia des de Nightscout - xDrip+ - Rebre valors de glucèmia de xDrip+. - Dexcom (BYODA) - BYODA - Rebre els valors de glucosa de l\'aplicació Dexcom \'Build Your Own Device\'. - App Eversense (\"parxejada\") - Rebre valors de glucèmia de l\'app Eversense \"parxejada\". - Glimp - Rebre valors de glucèmia de Glimp. - MM640g - Rebre valors de glucèmia del 600SeriesAndroidUploader. - Poctech - Rebre valors de glucèmia de l\'app Poctech - Glunovo - Rebre valors de l\'app Glunovo - Tomato (MiaoMiao) - Tomato - Rebre valors de glucèmia de l\'app Tomato (dispositiu MiaoMiao) - Glucèmia aleatòria - Generar dades de glucèmia aleatòries (Només mode demo) - Glucèmia - Enviar dades de glucèmia a xDrip+ - A xDrip+ seleccionar font de dades 640g/Eversense - Configuració enviament dades glucèmia - Enregistrar canvi de sensor a NS Tema original Tema baixa resolució diff --git a/plugins/main/src/main/res/values-cs-rCZ/strings.xml b/plugins/main/src/main/res/values-cs-rCZ/strings.xml index 0c1a09254e..67f6bfc7cf 100644 --- a/plugins/main/src/main/res/values-cs-rCZ/strings.xml +++ b/plugins/main/src/main/res/values-cs-rCZ/strings.xml @@ -101,21 +101,6 @@ Přepnutí profilu vytvořeno Trvání dočasného bazálu musí být násobkem %1$d minut a musí být větší než 0. QR kód pro nastavení jednorázového hesla - - Lyumjev - Předvolba pro Novorapid - Předvolba pro Fiasp - Předvolba pro Lyumjev - Možnost definice vrcholu účinnosti inzulínu pro pokročilé uživatele - INZ - Čas vrcholu IOB křivky - Vrchol křivky [min] - Volitelný vrchol - Oref - Rychle působící - Oref - Ultra rychlý - Oref - DIA %1$f je příliš krátké - použito %2$f ! - Novorapid - Fiasp Stavová řádka xDrip+ (hodinky) @@ -171,23 +156,6 @@ DIA CÍL BAZ - - Hotovo, gratulujeme! - Nedokončeno - Čas - Maximální IOB nastaveno správně - Glykémie dostupné z vybraného zdroje - Služba synchronizace má oprávnění k zápisu - Smyčka povolena - APS vybráno - Uzavřená smyčka povolena - CÍLE - Výukový program - Chcete resetovat začátek cíle? Můžete přijít o svůj pokrok. - Další - Zpět - Vymazat dokončeno - Vymazat start Akce Tlačítka k běžně používaným úkonům @@ -198,7 +166,7 @@ Nástroje Prohlížeč historie Senzor - věk: + stáří: úroveň: Inzulín Baterie pumpy @@ -207,18 +175,6 @@ stáří kanyly stáří náplasťové pumpy Náplasťová pumpa - - Prodloužený bolus omezen na %1$.1f U: %2$s - Sacharidy omezeny na %1$d g: %2$s - Pumpa nepodporuje dočasné bazály - Uzavřená smyčka zakázána v nastavení - Běží DEV verze. Uzavřená smyčka je zakázána. - Uzavřená smyčka je zastavena kvůli běžícímu prodlouženému bolusu - \"SMB vždy\" a \"po jídle\" zakázáno protože zdroj glykémie nepodporuje rozšířené filtrování - SBM není povoleno v otevřené smyčce - maximální hodnota v nastavení - pevný limit - Bezpečnost zadání ošetřeni Zobrazit stavové indikátory na domovské obrazovce Úroveň varování stáří kanyly [h] @@ -345,50 +301,6 @@ SENZ Měřítko grafu Graf - - Typ virtuální pumpy - Definice pumpy - Bolus: Krok =%1$s\nProdl. bolus: [Krok=%2$s, Délka=%3$smin-%4$sh]\nBazál: Krok=%5$s\nDoč. bazál: %6$s (%7$s), Délka=%8$smin-%9$sh\n%10$s - VPUM - Ovladač pumpy pro uživatele bez podporované pumpy (Otevřená smyčka) - VIRTUÁLNÍ PUMPA - Nastavení virtuální pumpy - Nahrávat status do NS - - Glykémie z NS - NSGL - Příjem glykémií z Nightscoutu - xDrip+ - Příjem glykémií z xDripu+. - BYODA - BYODA - Příjem hodnot glykémií z upravené aplikace Dexcom (BYODA). - Eversense aplikace (upravená) - Příjem glykémií z modifikované Eversense aplikace. - Glimp - Příjem glykémií z Glimpu. - MM640g - Příjem glykémií z Uploaderu 640G. - Poctech - Získávat glykémie z aplikace Poctech - Glunovo - Získávat glykémie z aplikace Glunovo - Intelligo - Přijímat hodnoty z aplikace Intelligo - Tomato (MiaoMiao) - Tomato - Přijímat hodnoty glykémií z Tomato aplikace (MiaoMiao zařízení) - GlucoRx Aidex - Aidex - Přijímat hodnoty glykémie ze senzoru GlucoRx Aidex. - Náhodná glykémie - Generovat náhodná data glykémie (pouze režim Demo) - Gly - Odesílat data do xDrip+ - V xDrip+ vyberte zdroj dat 640g/Eversense - Nastavení nahrávání glykémií - Zaznamenávat výměnu senzoru do NS - Vytvořit událost \"Výměna senzoru\" v NS automaticky po spuštění senzoru Původní vzhled Vzhled pro nízké rozlišení diff --git a/plugins/main/src/main/res/values-da-rDK/strings.xml b/plugins/main/src/main/res/values-da-rDK/strings.xml index b1cfabde34..69a8eaad0a 100644 --- a/plugins/main/src/main/res/values-da-rDK/strings.xml +++ b/plugins/main/src/main/res/values-da-rDK/strings.xml @@ -100,21 +100,6 @@ Profil switch oprettet TBR-varigheden skal være et multiplum af %1$d minutter og større end 0. QR-kode til opsætning af engangs kodeord - - Lyumjev - Insulin forudindstillet til Humalog og NovoRapid / NovoLog - Insulinforudindstilling til Fiasp - Insulin forudindstillet til Lyumjev - Giver dig mulighed for at definere spidsbelastningen af insulin-aktiviteten og bør kun bruges af avancerede brugere - INS - IOB Kurve Peak-Tid - Spidstidspunkt [min] - Free-Peak Oref - Rapid-Acting Oref - Ultra-Rapid Oref - DIA af %1$f for kort - bruger %2$f i stedet! - Novorapid, Novolog, Humalog - Fiasp xDrip Statuslinje (ur) @@ -170,22 +155,6 @@ DIA MÅL BAS - - Fuldført, godt klaret! - Ikke afsluttet endnu - Tid forløbet - Maksimal IOB sat korrekt - BS tilgængelig fra valgte kilde - Loop aktiveret - APS valgt - Lukket tilstand aktiveret - OBJ - Oplæringsprogram - Vil du nulstille objektiv start? Du kan miste dine fremskridt. - Næste - Forrige - Ryd færdigt - Ryd startet Handlinger Nogle knapper til hurtigt at få adgang til almindelige funktioner @@ -205,18 +174,6 @@ Indstik alder patch pumpe alder Patch pumpe - - Begrænser udvidet bolus til %1$.1f IE på grund af %2$s - Begrænser kulhydrater til %1$d g på grund af %2$s - Pumpe er ikke egnet til midlertidig basal - Lukket loop tilstand deaktiveret i præferencer - Kører dev version. Lukket loop er deaktiveret. - Lukket loop deaktiveret på grund af kørsel af forlænget bolus - SMB altid og efter kulhydrater deaktiveret, fordi den aktive BS kilde ikke understøtter avanceret filtrering - SMB er ikke tilladt i åben loop mode - max værdi i præferencer - hård grænse - Behandlings sikkerhed Vis statuslys på startskærm Grænseværdi for insulin-alder [h] @@ -342,49 +299,6 @@ SENS Graf skala Graf - - Virtuel pumpe type - Pumpe Definition - Bolus: Trin=%1$s\nForlænget Bolus: [Trin=%2$s, Varighed=%3$smin-%4$sh]\nBasal: Trin=%5$s\nTBR: %6$s (by %7$s), Varighed=%8$smin-%9$sh\n%10$s - VPUMPE - Pumpeintegration til pumper, som endnu ikke har nogen driver (Åbent Loop) - VIRTUEL PUMPE - Indstillinger for virtuel pumpe - Upload status til NS - - NSClient BS - NS BS - Downloader BG data fra Nightscout - xDrip+ - Modtag BG-værdier fra xDrip+. - BYODA - BYODA - Modtag BS-værdier fra \'Byg din egen Dexcom App\'. - Eversense App (patched) - Modtag BG værdier fra den patchede Eversense app. - Glimp - Modtag BG-værdier fra Glimp. - MM640g - Modtag BG-værdier fra 600SeriesAndroidUploader. - Poctech - Modtag BS-værdier fra Poctech app - Glunovo - Modtag værdier fra Glunovo app - Intelligo - Modtag værdier fra Intelligo-appen - Tomato (MiaoMiao) - Tomato - Modtag BS-værdier fra Tomato-appen (MiaoMiao enhed) - GlucoRx Aidex - Aidex - Modtag BG-værdier fra GlucoRx Aidex CGMS. - Tilfældigt BS - Generér tilfældige BS-data (kun demotilstand) - BG - Seng BS data til xDrip+ - I xDrip+ vælg 640g/Eversense datakilde - BS upload indstillinger - Log sensor ændring til NS Original udseende Lav kvalitets udseende diff --git a/plugins/main/src/main/res/values-de-rDE/strings.xml b/plugins/main/src/main/res/values-de-rDE/strings.xml index 0bff22de4a..21ed1d0a1b 100644 --- a/plugins/main/src/main/res/values-de-rDE/strings.xml +++ b/plugins/main/src/main/res/values-de-rDE/strings.xml @@ -98,21 +98,6 @@ Profilwechsel wurde erstellt Die TBR-Dauer muss ein Vielfaches von %1$d Minuten und größer als 0 sein. QR Code für einmaliges Passwort einrichten - - Lyumjev - Insulinprofil für Humalog und NovoRapid / NovoLog - Insulinprofil für Fiasp - Insulin-Voreinstellung für Lyumjev - Erlaubt dir, das Wirkmaximum der Insulinaktivität zu definieren, und sollte nur von erfahrenen Anwendern genutzt werden - INS - Wirkungshoch der IOB-Kurve - Wirkungshoch [min] - Free-Peak Oref - Rapid-Acting Oref - Ultra-Rapid Oref - DIA von %1$f ist zu kurz - AAPS nutzt stattdessen %2$f! - NovoRapid, NovoLog, Humalog - Fiasp xDrip+ Statuszeile (Uhr) @@ -168,21 +153,6 @@ DIA ZIEL BAS - - Abgeschlossen, gut gemacht! - Verstrichene Zeit - Maximales IOB richtig gesetzt - BZ verfügbar von gewählter Quelle - Loop aktiviert - APS ausgewählt - Closed mode aktiviert - ZIEL - Das Programm kennenlernen - Möchtest Du den Start der Ziele zurücksetzen? Du verlierst Deine Fortschritte. - Weiter - Zurück - Ziel erneut öffnen - Ziel neu starten Aktionen Einige Schaltflächen, um auf häufig verwendete Funktionen zugreifen zu können. @@ -202,18 +172,6 @@ Kanülenalter Alter Patchpumpe Patch-Pumpe - - Begrenze verzögerten Bolus auf %1$.1f IE wegen %2$s - Begrenze Kohlenhydrate auf %1$d g wegen %2$s - Pumpe verfügt nicht über temporäre Basalraten - Closed-Loop-Modus in den Einstellungen deaktiviert - Entwickler-Version, Closed Loop ist nicht verfügbar. - Closed Loop wegen Verzögerungsbolus unterbrochen - SMB wird immer und nach Kohlenhydraten deaktiviert, weil die aktive BZ-Quelle keine geeignete Filterung der Werte unterstützt. - SMB sind im Open Loop Modus nicht erlaubt - Max. Wert in den Einstellungen - festem Grenzwert - Sicherheitseinstellungen der Behandlungen Statusanzeige auf Homescreen Warnschwelle Insulinalter [h] @@ -339,49 +297,6 @@ SENS Diagrammskala Diagramm - - Typ der virtuellen Pumpe - Pumpen-Definition - Bolus: Schritt=%1$s\nVerzögerter Bolus: [Schritt=%2$s, Dauer=%3$smin-%4$sh]\nBasal: Schritt=%5$s\nTBR: %6$s (bei %7$s), Dauer=%8$smin-%9$sh\n%10$s - VP - Pumpenintegration für Pumpen, die noch nicht über einen Treiber verfügen (Open Loop) - VIRTUELLE PUMPE - Einstellungen der virtuellen Pumpe - Status zu Nightscout hochladen - - Nightscout-Client BZ - NS BZ - Lade Blutzuckerdaten von Nightscout - xDrip+ - Empfange Blutzuckerwerte von xDrip+. - BYODA - BYODA - Erhalte BZ-Werte von der \'Build Your Own Dexcom App\'. - Eversense App (gepatcht) - Empfange BZ-Werte von der gepatchten Eversense-App. - Glimp - Empfange Blutzuckerwerte von Glimp. - MM640g - Empfange Blutzuckerwerte vom 600SeriesAndroidUploader. - Poctech - Empfange Blutzucker-Werte von der Poctech-App. - Glunovo - Werte von der Glunovo App erhalten - Intelligo - Empfange Werte von der Intelligo App - Tomato (MiaoMiao) - Tomato - Empfange Blutzucker-Werte von der Tomato-App (MiaoMiao-Geräte) - GlucoRx Aidex - Aidex - Erhalte BG-Werte von GlucoRx Aidex CGMS. - Zufalls-BZ - Zufalls-BZ Daten erstellen (nur Demo-Modus) - BZ - Sende BZ-Werte zu xDrip+ - Wähle in xDrip+ 640g/Eversense als Daten-Quelle. - BZ Upload Einstellungen - Speichere Sensor Wechsel in Nightscout Ursprüngliches Erscheinungsbild Darstellung niedrige Auflösung diff --git a/plugins/main/src/main/res/values-el-rGR/strings.xml b/plugins/main/src/main/res/values-el-rGR/strings.xml index 12066ace7b..db079c09e9 100644 --- a/plugins/main/src/main/res/values-el-rGR/strings.xml +++ b/plugins/main/src/main/res/values-el-rGR/strings.xml @@ -75,20 +75,6 @@ Αναστολή (%1$d m) Η ανάγνωση κατάστασης απέτυχε Δημιουργήθηκε αλλαγή προφίλ - - Η ινσουλίνη που ορίζεται Humalog και NovoRapid / NovoLog - Η ινσουλίνη που ορίζεται για Fiasp - Προκαθορισμός ινσουλίνης για την Lyumjev - Σας επιτρέπει να ορίσετε το μέγιστο της δράσης της ινσουλίνης και πρέπει να χρησιμοποιείται μόνο από προχωρημένους χρήστες - INS - Μέγιστη τιμή καμπύλης IOB - Μέγιστο καμπύλης [λεπτά] - Προαιρετικά-αιχμή Oref - Γρήγορη δράση - Oref - Έξτρα Γρήγορη δράση - Oref - DIA για %1$f πολύ μικρή - χρησιμοποιήστε %2$f! - Novorapid, Novolog, Humalog - Fiasp xds @@ -118,19 +104,6 @@ Σφάλματα DIA BAS - - Ολοκληρώθηκε, συγχαρητήρια! - Δεν ολοκληρώθηκε ακόμη - Ο χρόνος που πέρασε - Το μέγιστο IOB έχει ρυθμιστεί σωστά - BG διαθέσιμη από επιλεγμένη πηγή - Κύκλωμα ενεργοποιημένο - Επιλέχθηκε APS - Ενεργοποιήθηκε η κλειστή λειτουργία - ΣΤΟΧΟΙ - Πρόγραμμα εκμάθησης - Επόμενο - Προηγ Ενέργειες Ορισμένα πλήκτρα για γρήγορη πρόσβαση σε κοινά χαρακτηριστικά @@ -141,17 +114,6 @@ Ιστορικό περιήγησης Αισθητήρας Ινσουλίνη - - Περιορίζεται το εκτεταμένο bolus σε %1$.1f U λόγω %2$s - Περιορίζονται οι υδατάνθρακες σε %1$d g λόγω %2$s - Η αντλία δεν υποστηρίζει προσωρινό βασικό ρυθμό - Το κλειστό κύκλωμα είναι απενεργοποιημένο στις Επιλογές - Εκτελείται έκδοση Dev. Το κλειστό κύκλωμα είναι απενεργοποιημένο. - Το SMB πάντα και μετά το γεύμα απενεργοποιείται επειδή η ενεργή πηγή BG δεν υποστηρίζει προηγμένο φιλτράρισμα - To SMB δεν επιτρέπεται σε λειτουργία ανοιχτού κυκλώματος - μέγιστη τιμή στις Επιλογές - σταθερό όριο - Ασφάλεια Θεραπειών Εμφάνιση του φωτισμού κατάστασης στην αρχική οθόνη Όριο προειδοποίησης για την ηλικία της ινσουλίνης[h] @@ -245,36 +207,6 @@ -BGI ΘΕΡΑΠ SENS - - Τύπος εικονικής αντλίας - Ορισμός Αντλίας - Bolus: Άμεσο=%1$s\nΕκτεταμένο Bolus: [Άμεσο=%2$s, Διάρκεια=%3$smin-%4$sh]\nΒασικός: Άμεσο=%5$s\nTBR: %6$s (με %7$s), Διάρκεια=%8$smin-%9$sh\n%10$s - Εικ. αντλία - Ολοκλήρωση αντλίας για αντλίες που δεν έχουν κανέναν οδηγό ακόμα (Ανοιχτό Κύκλωμα) - ΕΙΚΟΝΙΚΗ ΑΝΤΛΙΑ - Ρυθμίσεις Εικονικής αντλίας - Φόρτωση κατάστασης στο NS - - NSClient BG - Λήψη δεδομένων BG από Nightscout - xDrip+ - Λάβετε τις τιμές BG από το xDrip+. - Eversense App (τροποποιημένη) - Λάβετε τις τιμές BG από την εφαρμογή του Eversense. - Glimp - Λάβετε τις τιμές BG από το Glimp. - MM640g - Λάβετε τις τιμές BG από το 600SeriesAndroidUploader. - Poctech - Λάβετε τις τιμές BG από την εφαρμογή Poctech - Tomato (MiaoMiao) - Tomato - Λάβετε τιμές BG από Tomato app (MiaoMiao) - BG - Αποστολή δεδομένων BG στο xDrip+ - Στο xDrip+, επιλέξτε την πηγή δεδομένων 640g / Eversense - Ανέβασμα ρυθμίσεων BG - Αλλαγή αρχείου αισθητήρα σε NS χρήσιμες συμβουλές: diff --git a/plugins/main/src/main/res/values-es-rES/strings.xml b/plugins/main/src/main/res/values-es-rES/strings.xml index 417b29c579..22be2dbe34 100644 --- a/plugins/main/src/main/res/values-es-rES/strings.xml +++ b/plugins/main/src/main/res/values-es-rES/strings.xml @@ -101,21 +101,6 @@ Cambio de perfil creado La duración de TBR debe ser un múltiplo de %1$d minutos y mayor a 0. Código QR para la configuración de la contraseña de un sólo uso - - Lyumjev - Ajustes de insulina preestablecidos para Humalog y NovoRapid/NovoLog - Ajuste de insulina preestablecido para Fiasp - Ajuste de insulina preestablecido para Lyumjev - Permite personalizar el pico de acción máxima de la insulina. Debe ser utilizado únicamente por usuarios avanzados - INS - Tiempo del pico máximo de la curva de IOB - Tiempo del pico máximo de acción de la insulina [min] - Personalizar Pico - Acción Rápida - Ultra-Rápido Oref - DIA de %1$f demasiado corto - usando %2$f! - Novorapid, Novolog, Humalog - Fiasp Línea de estado de xDrip+ (reloj) @@ -171,23 +156,6 @@ DIA OBJ BAS - - ¡Logrado, bien hecho! - No logrado - Tiempo agotado - Máximo IOB ajustado correctamente - Glucosa disponible desde la fuente seleccionada - El servicio de sincronización tiene permiso de escritura - Lazo activado - APS seleccionado - Lazo cerrado activado - OBJ - Programa de aprendizaje - ¿Desea reiniciar el objetivo? Puedes perder tu progreso. - Siguiente - Anterior - Limpieza finalizada - Limpieza iniciada Acciones Algunos botones para acceder rápidamente a funciones comunes @@ -207,18 +175,6 @@ edad de la cánula edad del parche de la bomba Bomba parche - - Limitando el bolo extendido a %1$.1f U debido a %2$s - Limitando carbohidratos a %1$d g debido a %2$s - La bomba no tiene capacidad basal temporal - Lazo cerrado deshabilitado en preferencias - Ejecutando la versión dev. Lazo cerrado no disponible. - Bucle cerrado inhabilitado debido a la ejecución del bolo extendido - SMB siempre y después de carbohidratos desactivados porque la fuente activa de BG no soporta filtrado avanzado - SMB no permitido en modo de lazo abierto - valor máximo en preferencias - límite estricto - Seguridad de tratamientos Mostrar luces de estado en la pantalla de inicio Umbral de advertencia de la edad de la cánula [h] @@ -346,50 +302,6 @@ Sens Escala gráfica Gráfico - - Tipo de bomba virtual - Definición de la bomba - Bolo: Paso =%1$s\nBolo Extendido: [paso =%2$s, Duración =%3$smin -%4$sh] \nBasal: Paso =%5$s\nTBR: %6$s ( %7$s), Duración =%8$sMin -%9$sh\n%10$s - BOMBAV - Integración de bombas de insulina que aún no tienen ningún controlador disponible (lazo abierto) - BOMBA VIRTUAL - Ajustes de bomba virtual - Subir estado a Nightscout - - NSClient BG - NS BG - Recibir los datos de glucosa de Nightscout - xDrip+ - Recibir los valores de glucosa de xDrip+ - Dexcom (BYODA) - BYODA - Recibir los valores de glucosa de la aplicación Dexcom \'Build Your Own Device\' - Eversense App (parcheada) - Recibir los valores de glucosa de la aplicación Eversense parcheada. - Glimp - Recibir valores de glucosa de Glimp. - MM640g - Recibir los valores de glucosa del 600SeriesAndroidUploader. - Poctech - Recibir los valores de glucosa de Poctech - Glunovo - Recibir los valores de glucosa de la aplicación Glunovo - Intelligo - Recibir los valores de glucosa de Intelligo - Tomato (MiaoMiao) - Tomato - Recibir los valores de glucosa de Tomato App (MiaoMiao) - GlucoRx Aidex - Aidex - Recibir los valores de glucosa de GlucoRx Aidex CGMS - Glucosa aleatoria - Generar datos aleatorios de glucosa (sólo modo Demo) - BG - Enviar datos de glucosa a xDrip+ - En xDrip+, selecciona 640G/Eversense como fuente de datos - Ajuste de subida de datos de glucosa - Registro de cambio de sensor en Nightscout - Crear evento \"Cambio de sensor\" en Nightscout automáticamente al iniciar el sensor Tema original Tema baja resolución diff --git a/plugins/main/src/main/res/values-fr-rFR/strings.xml b/plugins/main/src/main/res/values-fr-rFR/strings.xml index ef1ff49ccd..2e06af641d 100644 --- a/plugins/main/src/main/res/values-fr-rFR/strings.xml +++ b/plugins/main/src/main/res/values-fr-rFR/strings.xml @@ -101,21 +101,6 @@ Changement de profil effectué La durée du DBT doit être un multiple de %1$d minutes et supérieure à 0. QR Code pour configurer un mot de passe à usage unique - - Lyumjev - Réglages pour les insulines Humalog et NovoRapid / NovoLog - Réglages pour l\'insuline Fiasp - Réglages pour l\'insuline Lyumjev - Permet de définir le pic de l’activité de l’insuline et ne doit être utilisé que par les utilisateurs avancés - INS - Durée du Pic de la Courbe IA - Temps du Pic [min] - Profil d\'insuline ajustable Oref - Insuline à Action Rapide Oref - Insuline Ultra Rapide Oref - Durée d’Action pour %1$f trop courte - utiliser %2$f à la place ! - Novorapid, Novolog, Humalog - Fiasp Barre d\'état pour xDrip+ (Montre) @@ -171,23 +156,6 @@ DAI CIBLE BAS - - Terminé, félicitations ! - Pas encore terminé - Temps écoulé - Maximum IA réglé correctement - Glycémie disponible depuis la source sélectionnée - Le service de synchronisation a l\'autorisation d\'écriture - Boucle activée - APS Sélectionné - Mode boucle fermée activé - OBJ - Programme d’apprentissage - Voulez-vous réinitialiser le début de l\'objectif ? Vous risquez de perdre vos progrès. - Suivant - Préc - Refaire l\'objectif - Suppression démarrée Actions Quelques boutons pour accéder rapidement aux fonctions communes @@ -207,18 +175,6 @@ âge canule âge pompe patch Pompe patch - - Limiter les bolus prolongé à %1$.1f U à cause de %2$s - Limiter les glucides %1$d g à cause de %2$s - Pompe n’est pas capable de basals temporaires - Mode de Boucle Fermée désactivé dans les préférences - Version Dev. La Boucle Fermée est désactivée. - Boucle fermée désactivée à cause du bolus étendu - SMB toujours et post-ingestion de glucides désactivé car la source de glycémies actuelle ne supporte pas de filtrage avancé - SMB non autorisé en mode boucle ouverte - valeur Max dans les préférences - limite fixée - Traitements de sécurité Afficher les voyants d\'état sur l\'écran d\'accueil Seuil d\'alerte âge canule [h] @@ -345,50 +301,6 @@ SENS Échelle du graph. Graph - - Type de pompe virtuelle - Définition de pompe - Bolus : Étape =%1$s\nExtended Bolus : [Étape =%2$s, Durée =%3$smin -%4$sh]\nBasal : Étape =%5$s\nTBR : %6$s (par %7$s), Durée =%8$smin -%9$sh\n%10$s - POMPEV - Intégration pour les pompes qui n’ont pas encore de pilote (Boucle Ouverte) - POMPE VIRTUELLE - Paramètres pompe virtuelle - Remontée des informations vers NS - - Glycémie NSClient - Gly NS - Télécharge les glycémies depuis Nightscout - xDrip+ - Recevoir les glycémies depuis xDrip+. - BYODA - BYODA - Recevoir les valeurs de glycémie de l’application Dexcom patchée (BYODA). - App Eversense (patché) - Recevoir les valeurs de glycémie de l’app Eversense patchée. - Glimp - Recevoir les glycémies depuis Glimp. - Medtronic 640g - Recevoir les glycémies depuis le 600SeriesAndroidUploder. - Poctech - Recevoir les glycémies depuis l\'app Poctech - Glunovo - Recevoir des valeurs de l\'application Glunovo - Intelligo - Recevoir des valeurs depuis l\'application Intelligo - Tomato (MiaoMiao) - Tomato - Recevoir les valeurs de glycémie de l\'application Tomato (appareil MiaoMiao) - GlucoRx Aidex - Aidex - Recevoir les valeurs de glycémie du MGC GlucoRx Aidex. - Gly Aléatoire - Générer des glycémies aléatoires (mode démo uniquement) - Gly - Transmettre les Gly vers xDrip+ - Dans xDrip+ veuillez séléctionner 640g/Eversense comme source de données - Paramètres de téléchargement des glycémies - Enreg. du changement de capteur sur NS - Créer automatiquement un événement \"Changement de capteur\" dans NS au démarrage du capteur Thème d\'origine Basse résolution diff --git a/plugins/main/src/main/res/values-ga-rIE/strings.xml b/plugins/main/src/main/res/values-ga-rIE/strings.xml index 4f2cbd4ce3..e592d3d2be 100644 --- a/plugins/main/src/main/res/values-ga-rIE/strings.xml +++ b/plugins/main/src/main/res/values-ga-rIE/strings.xml @@ -16,13 +16,6 @@ Bunaidh: %1$dnóim ó shin Ar fionraí (%1$d nóim) - - Lyumjev - INS - Free-Peak Oref - Rapid-Acting Oref - Ultra-Rapid Oref - Fiasp xds @@ -42,11 +35,6 @@ Ainm Próifíle: DIA BUN - - Lúb cumasaithe - APS roghnaithe - Ar Aghaidh - Roimhe seo Gníomhartha GNÍ @@ -54,7 +42,6 @@ aois: Inslin Caidéil ceallraí - inslin CGM @@ -81,18 +68,6 @@ Bunaidhi BUN GNÍ - - - Sonraí a íoslódáil ó Nightscout - xDrip+ - Luachanna BG a fháil ó xDrip+. - Glimp - MM640g - Luachanna BG a fháil ón 600SeriesAndroidUploader. - Poctech - Tomato (MiaoMiao) - Tomato - BG diff --git a/plugins/main/src/main/res/values-hr-rHR/strings.xml b/plugins/main/src/main/res/values-hr-rHR/strings.xml index 5ee4b66e0c..aa8a7784cc 100644 --- a/plugins/main/src/main/res/values-hr-rHR/strings.xml +++ b/plugins/main/src/main/res/values-hr-rHR/strings.xml @@ -57,21 +57,6 @@ Bolus: Bazal: QR kod za postavljanje jednokratne lozinke - - Lyumjev - Unaprijed podešen predložak za inzulin Humalog i NovoRapid / NovoLog - Unaprijed podešen predložak za inzulin Fiasp - Unaprijed podešen predložak za inzulin Lyumjev - Omogućuje definiranje vrhunca aktivnosti inzulina i trebaju ga koristiti samo napredni korisnici - INS - Vršno vrijeme IOB krivulje - Špica [min] - Free-Peak Oref - Rapid-Acting Oref - Ultra-Rapid Oref - DIA od %1$f prekratak - umjesto njega koristite %2$f! - Novorapid, Novolog, Humalog - Fiasp xDrip+ Statusna linija (sat) @@ -127,18 +112,10 @@ DIA CILJ BAZAL - - Dovršeno, bravo! - Nije još dovršeno - Prošlo vrijeme - Program učenja - Sljedeći Nekoliko izbora za brzi pristup uobičajenim funkcijama Senzor Inzulin - - Sigurnosne postavke medikacije inzulin samo na satu @@ -159,28 +136,6 @@ Tretmani BAZAL Skala grafikona - - Vrsta virtualne pumpe - Definicija pumpe - Bolus: korak=%1$s\nProduženi bolus: [korak=%2$s, trajanje=%3$smin-%4$sh]\nBazal: korak=%5$s\nTBR: %6$s (do %7$s), Trajanje=%8$smin-%9$sh\n%10$s - VPUMP - Integracija pumpe za pumpe koje još nemaju upravljački program (otvorena petlja) - VIRTUALNA PUMPA - Postavke virtualne pumpe - Prijenos statusa u NS - - Preuzima podatke o GUK-u s Nightscout-a - Preuzima podatke o GUK-a s xDrip+. - Primajte vrijednosti GUK-a iz zakrpane aplikacije Eversense. - Primajte vrijednosti GUK-a od Glimpa. - Primajte vrijednosti glukoze u krvi od 600SeriesAndroidUploader. - Intelligo - Primite vrijednosti iz aplikacije Intelligo - GlucoRx Aidex - Aidex - Primite vrijednosti GK od GlucoRx Aidex CGMS. - GUK - Stvorite događaj \"Promjena senzora\" u NS-u automatski pri pokretanju senzora diff --git a/plugins/main/src/main/res/values-hu-rHU/strings.xml b/plugins/main/src/main/res/values-hu-rHU/strings.xml index 83d009bfe9..021b2ae5b0 100644 --- a/plugins/main/src/main/res/values-hu-rHU/strings.xml +++ b/plugins/main/src/main/res/values-hu-rHU/strings.xml @@ -6,11 +6,6 @@ VC: Bólus: Bázis: - - Lyumjev - Ultra-Rapid Oref - Novorapid, Novolog, Humalog - Fiasp @@ -26,11 +21,6 @@ Hibák DIA BÁZ - - Eltelt idő - APS kiválasztva - Tovább - Vissza Műveletek Eszközök @@ -38,7 +28,6 @@ kor: Inzulin Kanül - grafikon inzulin @@ -65,15 +54,6 @@ Inzulin összesen BÁZ Grafikon - - - Glimp - MM640g - Poctech - Tomato (MiaoMiao) - Tomato - Véletlenszerű VC - VC Eredeti megjelenés Alacsony felbontás diff --git a/plugins/main/src/main/res/values-it-rIT/strings.xml b/plugins/main/src/main/res/values-it-rIT/strings.xml index e9fe91f8af..e7a84bad9b 100644 --- a/plugins/main/src/main/res/values-it-rIT/strings.xml +++ b/plugins/main/src/main/res/values-it-rIT/strings.xml @@ -101,21 +101,6 @@ Cambio profilo creato La durata del TBR deve essere un multiplo di %1$d minuti e maggiore di 0. Codice QR per configurare OTP - - Lyumjev - Preset per insulina Humalog e NovoRapid / NovoLog - Preset per insulina Fiasp - Preset per insulina Lyumjev - Ti consente di definire il picco di attività dell\'insulina e dovrebbe essere usato solo dagli utenti avanzati - INS - Tempo picco Curva IOB - Tempo del picco [min] - Free-Peak Oref - Rapid-Acting Oref - Ultra-Rapid Oref - DIA di %1$f troppo breve - uso %2$f. - Novorapid, Novolog, Humalog - Fiasp Statusline xDrip+ (smartwatch) @@ -171,22 +156,6 @@ DIA TARG BAS - - Completato, ben fatto! - Non ancora completato - Tempo trascorso - Max IOB impostata correttamente - BG disponibile da sorgente selezionata - Loop abilitato - APS selezionato - Modalità chiusa abilitata - OBT - Programma di apprendimento - Vuoi resettare l\'avvio dell\'obiettivo? Potresti perdere i tuoi progressi. - Avanti - Indietro - Cancella completamento - Cancella avvio Azioni Alcuni tasti per accedere rapidamente alle funzioni comuni @@ -206,18 +175,6 @@ Età cannula età micro a patch Micro a patch - - Limitazione bolo esteso a %1$.1f U a causa di: %2$s - Limitazione carboidrati a %1$d g a causa di: %2$s - Micro non in grado di impostare la basale temporanea - Modalità loop chiuso disabilitata nelle preferenze - Versione sviluppatore in esecuzione. Loop chiuso disabilitato. - Loop chiuso disabilitato a causa dell\'esecuzione di un bolo esteso - Le funzioni \"SMB sempre\" e \"SMB dopo i CHO\" sono disabilitate perché l\'attuale sorgente delle glicemie non supporta il filtraggio avanzato - SMB non consentito in modalità loop aperto - valore max nelle preferenze - limite fisso - Sicurezza trattamenti Mostra indicatori di stato sulla home Età cannula: soglia di avviso [h] @@ -344,50 +301,6 @@ TRATT SENS Scala del grafico - - Tipo micro virtuale - Definizione micro - Bolo: Step=%1$s\nBolo Esteso: [Step=%2$s, Durata=%3$smin-%4$sh]\nBasale: Step=%5$s\nTBR: %6$s (di %7$s), Durata=%8$smin-%9$sh\n%10$s - MICROV - Per microinfusori che non hanno ancora alcun driver (Loop aperto) - MICRO VIRTUALE - Impostazioni micro virtuale - Carica stato in NS - - BG NSClient - BG NS - Scarica dati glicemia da Nightscout - xDrip+ - Ricevi valori glicemia da xDrip+. - BYODA - BYODA - Ricevi valori glicemia dall\'app Dexcom ottenuta con \'Build Your Own Dexcom App\'. - Eversense app (modificata) - Ricevi valori glicemia dall\'app Eversense modificata. - Glimp - Ricevi valori glicemia da Glimp. - MM640g - Ricevi valori glicemia da 600SeriesAndroidUploader. - Poctech - Ricevi valori glicemia da app Poctech - Glunovo - Ricevi valori glicemia da app Glunovo - Intelligo - Ricevi valori da app Intelligo - Tomato (MiaoMiao) - Tomato - Ricevi valori glicemia da app Tomato (dispositivo MiaoMiao) - GlucoRx Aidex - GlucoRx Aidex - Ricevi valori glicemia da CGM GlucoRx Aidex. - BG casuale - Genera dati glicemia casuali (solo modalità demo) - BG - Invia dati BG a xDrip+ - In xDrip+ seleziona origine dati 640g/Eversense - Impostazioni caricamento BG - Registra cambio sensore in NS - Crea evento \"Cambio Sensore\" in NS all\'avvio del sensore Tema originale Tema a bassa risoluzione diff --git a/plugins/main/src/main/res/values-iw-rIL/strings.xml b/plugins/main/src/main/res/values-iw-rIL/strings.xml index 235e5df6c3..a148bc7cd3 100644 --- a/plugins/main/src/main/res/values-iw-rIL/strings.xml +++ b/plugins/main/src/main/res/values-iw-rIL/strings.xml @@ -98,21 +98,6 @@ נוצרה החלפת פרופיל משך הבזאלי הזמני חייב להיות כפולה של %1$d דקות ויותר מ-0. ברקוד QR ליצירת סיסמה חד פעמית - - Lyumjev - הגדרת אינסולין ל-Humalog ו- NovoRapid / Novolog - הגדרת אינסולין מסוג Fiasp - הגדרת אינסולין מסוג Lyumjev - מאפשר להגדיר את שיא פעילות האינסולין, לשימוש על ידי משתמשים מתקדמים בלבד - אינסולין - שעת שיא של עקומת IOB - זמן שיא [min] - Oref שיא חופשי - Oref אינסולין מהיר - Oref אינסולין אולטרה מהיר - DIA במשך %1$f הוא קצר מדי - משתמש ב-%2$f במקום! - Novorapid, Novolog, Humalog - Fiasp שורת מצב xDrip (שעון) @@ -168,22 +153,6 @@ DIA ע\' מטרה בזאלי - - הושלם, כל הכבוד! - עוד לא הושלם - זמן שחלף - ערך IOB מקסימלי הוגדר כראוי - ערכי סוכר זמינים מהמקור הנבחר - הלולאה פעילה - נבחר APS - מצב סגור מופעל - OBJ - תוכנית הלימוד - האם ברצונכם לאפס את התחלת המשימה? אתם עלולים לאבד את התקדמותכם במשימה. - הבא - הקודם - ביטול השלמה - ביטול התחלה פעולות לחצנים לגישה מהירה לפונקציות שימושיות @@ -203,18 +172,6 @@ גיל הצינורית גיל משאבה משאבה ללא צינורית - - הגבלת בולוס ממושך ל- %1$.1f יח\' בגלל %2$s - הגבלת פחמימות ל-%1$d גר\' בגלל %2$s - המשאבה אינה מסוגלת לבצע בזאלי זמני - מצב לולאה סגור מושבת בהעדפות - זוהי גרסת פיתוח. לולאה סגורה אינה מורשת. - הלולאה הסגורה מופסקת עקב מתן בולוס ממושך - SMB תמידי ו-SMB לאחר פחמימות מושבתים כיוון שמקור ערכי הסוכר הפעיל אינו תומך בסינון נתונים מתקדם - SMB אינו פעיל במצב לולאה פתוחה - ערך מקסימלי בהעדפות - מגבלה קשיחה - בטיחות טיפולים הצגת אורות חיווי במסך הבית סף התראה לתוקף האינסולין [h] @@ -340,50 +297,6 @@ רגישות קנה מידה של הגרף גרף - - סוג משאבה וירטואלית - הגדרת משאבה - בולוס: צעד=%1$s\nבולוס ממושך: [צעד=%2$s, משך=%3$s מינ\'-%4$sש\']\nבזאלי: צעד=%5$s\nבזאלי זמני: %6$s (עם %7$s), משך=%8$s מינ\'-%9$sש\'\n%10$s - VPUMP - שימוש במשאבות אשר עדיין אין להם מנהל התקן כלשהו (לולאה פתוחה) - משאבה וירטואלית - הגדרות משאבה וירטואלית - טוען מצב ל-Nightscout - - נתוני סוכר מ-NSClient - סוכר NS - הורדת ערכי סוכר בדם מ-Nightscout - xDrip+ - קבלת ערכי סוכר מ-xDrip. - BYODA - BYODA - השתמש בנתוני הסוכר מאפליקציית \"בנה לעצמך דקסקום\" (BYODA). - אפליקלציית Eversense (עם פאץ\') - קבלת ערכי רמת סוכר מאפליקציית Eversense עם פאץ\'. - Glimp - קבלת ערכי סוכר בדם מאפליקציית Glimp. - Minimed 640G - קבלת ערכי סוכר בדם מ-600SeriesAndroidUploader. - Poctech - קבלת ערכי סוכר מיישום Poctech - Glunovo - קבלת ערכי סוכר מיישום Glunovo - Intelligo - קבלת ערכי סוכר מיישום Intelligo - Tomato (MiaoMiao) - Tomato - קבלת ערכי סוכר מאפליקציית Tomato (התקן MiaoMiao) - GlucoRx Aidex - Aidex - קבלת נתוני סוכר מחיישני GlucoRx Aidex. - נתוני סוכר אקראיים - הפקת נתוני גלוקוז אקראיים (מצב הדגמה בלבד) - BG - שליחת נתוני סוכר אל xDrip - ב-xDrip בחרו 640g/Eversense כמקור נתונים - הגדרות העלאת ערכי סוכר בדם - רישום החלפת סנסור ב-Nightscout - רישום אירוע \"החלפת סנסור\" ב-Nightscout באופן אוטומטי בעת הפעלת החיישן סקין מקורי סקין רזולוציה נמוכה diff --git a/plugins/main/src/main/res/values-ja-rJP/strings.xml b/plugins/main/src/main/res/values-ja-rJP/strings.xml index f51be367e7..c87f7b9426 100644 --- a/plugins/main/src/main/res/values-ja-rJP/strings.xml +++ b/plugins/main/src/main/res/values-ja-rJP/strings.xml @@ -8,7 +8,6 @@ リモートボーラスが利用できません。後でもう一度お試しください。 デルタ: ベーサル: - @@ -18,10 +17,8 @@ Units: DIA BAS - ACT - 概要 HOME @@ -79,8 +76,6 @@ ABS DEVSLOPE TREAT - - diff --git a/plugins/main/src/main/res/values-ko-rKR/strings.xml b/plugins/main/src/main/res/values-ko-rKR/strings.xml index 161384ca53..2f23445e84 100644 --- a/plugins/main/src/main/res/values-ko-rKR/strings.xml +++ b/plugins/main/src/main/res/values-ko-rKR/strings.xml @@ -97,21 +97,6 @@ 상태를 읽지 못했습니다. 프로파일 변경 생성됨 TBR 기간은 %1$d분의 배수가 되어야 하고 0보다 커야 함. - - Lyumjev - 휴마로그와 노보래피드에 대한 인슐린 설정 - 피아스프에 대한 인슐린 설정 - Lyumjev에 대한 인슐린 설정 - 인슐린활동의 피크를 직접 정의할 수 있습니다. 고급 사용자만 사용해야 합니다. - INS - IOB 커브 피크 시간 - 피크 시간 [min] - 사용자지정-피크 Oref - 초속효성 Oref - 초-초속효성 Oref - DIA %1$f는 너무 짧습니다. 대신 %2$f을 사용하세요! - 노보래피드, 휴마로그, 에피드라 - 피아스프(Fiasp) xDrip+ 상태표시라인 (워치) @@ -151,22 +136,6 @@ DIA TARG BAS - - 훌륭합니다. 완료되었습니다! - 아직 완료되지 않았습니다. - 경과 시간 - 최대 IOB가 바르게 설정됨 - 선택한 소스에서 혈당이 들어옵니다. - Loop 활성화됨 - APS 선택됨 - Closed 모드가 활성화됨 - OBJ - 프로그램 배우기 - 목표를 초기화하시겠습니까? 진행상황이 삭제됩니다. - 다음 - 이전 - 완료 초기화 - 시작 초기화 실행 일반 기능을 빠르게 실행시킬 버튼 @@ -183,18 +152,6 @@ 펌프 배터리 캐뉼라 확장 Bolus 기능을 사용하는 동안에는 Closed Loop 모드가 중지됩니다. 정말 원하십니까? - - %2$s로 인해 확장Bolus가 %1$.1f U로 제한됩니다. - %2$s로 인해 탄수화물이 %1$d g로 제한됩니다. - 이 펌프 임시Basal을 지원하지 않습니다. - 설정에서 Closed Loop 모드가 비활성화되었습니다. - 개발자버전을 실행중입니다. Closed Loop는 비활성화 됩니다. - 확장 Bolus 사용으로 인해 Closed Loop가 비활성화됨 - 선택한 혈당 출처가 고급 필터링을 지원하지 않기 때문에 SMB가 항상 비활성화됩니다. - Open Loop모드에선 SMB가 허용되지 않습니다. - 설정에서의 최대값 - 하드한계 - 관리 안전설정 홈화면에 상태 표시등 보여주기 인슐린 사용 기간 경고 기준 [h] @@ -303,38 +260,6 @@ TREAT 민감도 그래프 - - 가성펌프 종류 - 펌프 정의 - Bolus: 스텝=%1$s\n확장Bolus: [Step=%2$s, 기간=%3$s분-%4$s시]\nBasal: 스텝=%5$s\n임시Basal: %6$s (by %7$s), 기간=%8$s분-%9$s시\n%10$s - VPUMP - 가상용 펌프를 위한 설정(Open Loop) - 가상 펌프 - 가상펌프 설정 - NS에 상태 업로드하기 - - NSClient 혈당 - Nightscout에서 다운로드하여 혈당값 받기 - xDrip+ - xDrip+에서 혈당값 받기 - Eversense 앱(패치버전) - 패치된 Eversense 앱에서 혈당값 받기 - Glimp - Glimp에서 혈당값 받기 - 미니메드640g - 600SeriesAndroidUploader에서 혈당값 받기 - Poctech - Poctech 앱에서 혈당값 받기 - Tomato (MiaoMiao) - Tomato - 혈당값이 Tomato앱(MiaoMaio장치) 으로부터 수신되었습니다. - 무작위 혈당 - 무작위로 혈당을 생성합니다(데모 버전 전용) - 혈당 - 혈당 데이터를 xDrip+에 전송하기 - xDrip+ 데이터 소스에서 640g/Eversense을 선택하세요 - 혈당 업로드 설정 - 센서 교체 NS에 기록하기 기본 스킨 저해상도 스킨 diff --git a/plugins/main/src/main/res/values-lt-rLT/strings.xml b/plugins/main/src/main/res/values-lt-rLT/strings.xml index 4c4fa8a24b..6b2c5a707f 100644 --- a/plugins/main/src/main/res/values-lt-rLT/strings.xml +++ b/plugins/main/src/main/res/values-lt-rLT/strings.xml @@ -97,21 +97,6 @@ Būsenos nuskaityti nepavyko Profilio perjungimas sukurtas Laikinos bazės trukmė turi būti kartotinė %1$d minučių ir didesnė nei 0. - - Lyumjev - Nustatymai Humalog ir NovoRapid / NovoLog insulinams - Nustatymai Fiasp insulinui - Nustatymai Lyumjev insulinui - Leidžia pasirinkti insulino veikimo piką ir turėtų būti naudojama tik patyrusių vartotojų - INS - AIO kreivės pikas - Piko laikas [min] - Oref be piko - Greito veikimo Oref - Staigaus veikimo Oref - IVT %1$f per trumpa - bus naudojama %2$f! - Novorapid, Novolog, Humalog - Fiasp xDrip+ būsenos juosta (laikrodyje) @@ -161,22 +146,6 @@ IVT TIKSLAS VB - - Užbaigta, puiku! - Dar nebaigta - Praėjo laiko - Maksimalus AIO nustatytas tinkamai - KG šaltinis pasirinktas teisingai - Ciklas aktyvuotas - DKS pasirinkta - Uždaras ciklas aktyvus - TIKSL - Mokymosi programa - Ar norite iš naujo nustatyti tikslų pradžią? Jūs galite prarasti jau pasiektus. - Kitas - Ankstesnis - Išvalyti užbaigtus - Išvalyti pradėtus Veiksmai Mygtukai greitesniam pagrindinių funkcijų paleidimui @@ -194,18 +163,6 @@ Kaniulė Ištęsto boluso funkcija sustabdys uždaro ciklo režimą ištęsto boluso veikimo metu. Ar tikrai norite patvirtinti savo pasirinkimą? kateterio amžius - - Ištęstinis bolusas ribojamas iki %1$.1f vv dėl %2$s - Ribojami angliavandeniai iki %1$d g dėl %2$s - Pompa negali nustatyti laikinos bazės - Uždaro ciklo būsena išjungta nustatymuose - Naudojama neužbaigta versija. Uždaras ciklas neaktyvus. - Uždara ciklas išjungtas dėl ištęsto boluso veikimo - Funkcijos \"SMB visada\" ir \"SMB po angliavandenių\" išjungtos, nes kraujo gliukozės duomenų šaltinis neturi reikalingo filtravimo - SMB neleidžiami atviro ciklo režime - Maksimali reikšmė nustatymuose - Nekeičiama riba - Terapijos saugumas Pradžios ekrane rodyti spalvotus indikatorius Kaniulės ribinio laiko įspėjimas [h] @@ -324,49 +281,6 @@ ĮRAŠ JAUTR Grafikas - - Virtualios pompos tipas - Pompos nustatymas - Bolusas: Žingsnis=%1$s\nIštęstinis bolusas: [Žingsnis=%2$s, Trukmė=%3$smin-%4$sh]\nBazė: Žingsnis=%5$s\nLDB: %6$s (iš %7$s), Trukmė=%8$smin -%9$sh\n%10$s - VPompa - Integracija pompoms, kurios dar neturi reikalingo valdiklio (Atviras Ciklas) - Virtuali pompa - Virtualios pompos nustatymai - Perduoti būsenos duomenis į NS - - NSClient KG - NS KG - Gauti kraujo gliukozės vertes iš Nightscout - xDrip+ - Gauti kraujo gliukozės reikšmes iš xDrip+. - BYODA - BYODA - Gauti kraujo gliukozės reikšmes iš \'Build Your Own Dexcom App\'. - Eversense programėlė (modifikuota) - Gauti kraujo gliukozės vertes iš modifikuotos Eversense programėlės. - Glimp - Gauti kraujo gliukozės vertes iš Glimp. - MM640g - Gauti kraujo gliukozės vertes iš 600SeriesAndroidUploader. - Poctech - Gauti KG vertes iš Poctech programėlės - Glunovo - Gauti KG reikšmes iš Glunovo programos - Intelligo - Gauti KG reikšmes iš Intelligo programos - Tomato (MiaoMiao) - Tomato - Gauti KG vertes iš Tomato programėlės (MiaoMiao) - GlucoRx Aidex - Aidex - Gauti KG reikšmes iš GlucoRx Aidex CGMS programos. - Atsitiktinė KG - Generuoti atsitiktinių KG duomenis (demonstracinis režimas) - KG - Siųsti KG duomenis į xDrip+ - Xdrip+ pasirinkite 640g/Eversense duomenų šaltinį - KG duomenų perdavimo nustatymai - Registruoti sensoriaus keitimą NS Originali išvaizda Žemos rezoliucijos išvaizda diff --git a/plugins/main/src/main/res/values-nl-rNL/strings.xml b/plugins/main/src/main/res/values-nl-rNL/strings.xml index 9d6be96279..10e9b0829c 100644 --- a/plugins/main/src/main/res/values-nl-rNL/strings.xml +++ b/plugins/main/src/main/res/values-nl-rNL/strings.xml @@ -101,21 +101,6 @@ Profiel wissel aangemaakt Tijdelijk basaal duur moet een veelvoud van %1$d minuten en groter dan 0 zijn. QR Code voor het instellen van een eenmalig wachtwoord - - Lyumjev - Insuline instelling voor Humalog en NovoRapid / NovoLog - Insuline instelling voor Fiasp - Insuline instelling voor Lyumjev - Hiermee kan je de piek van de insulineactiviteit definiëren, mag alleen worden gebruikt door gevorderde gebruikers - INS - IOB curve piek tijd - Piek tijd [min] - Free-Peak Oref - Snel-werkende Oref - Ultra-Rapid Oref - DIA van %1$f te kort - %2$f wordt inplaats gebruikt! - Novorapid, Novolog, Humalog - Fiasp xDrip+ Statuslijn (horloge) @@ -171,23 +156,6 @@ DIA DOEL BAS - - Voltooid, goed gedaan! - Nog niet voltooid - Verstreken tijd - Maximum IOB juist ingesteld - BG beschikbaar op gekozen bron - Synchronisatieservice heeft schrijfrechten - Loop Actief - APS geslecteerd - Closed modus actief - DOEL - Leerprogramma - Wil je dit leerdoel opnieuw starten? Je kunt je voortgang verliezen. - Volgende - Vorige - Voltooiing wissen - Start wissen Acties Een aantal knoppen voor snelle toegang tot algemene functies @@ -207,18 +175,6 @@ canule leeftijd patchpomp leeftijd Patchpomp - - Beperken van extended bolus op %1$.1f E vanwege %2$s - Koolhydraten worden beperkt tot %1$d gr doordat %2$s - Pomp kan geen tijdelijk basaal aanvaarden - Closed Loop modus gedeactiveerd in de instellingen - Dev versie actief. Closed loop gedeactiveerd - Closed loop modus uitgeschakeld vanwege afgeven Vertraagde bolus - SMB altijd gedeactiveerd doordat de gekozen BG bron geen optimale filtering toepast - SMB niet toegestaan in Open Loop modus - Maximum waarde in instellingen - max limiet (SC) - Behandelingen veiligheid Toon statusindicatoren op startscherm Drempelwaarde waarschuwing canule leeftijd [h] @@ -345,50 +301,6 @@ SENS Grafiek schaal Grafiek - - Virtuele pomp Type - Pomp definitie - Bolus: Stap=%1$s\nExtended Bolus: [Stap=%2$s, Duur=%3$smin-%4$sh]\nBasaal: Stap=%5$s\nTBR: %6$s (by %7$s), Duur=%8$smin-%9$sh\n%10$s - VPUMP - Pomp integratie voor pompen, waar nog geen driver voor is (Open Loop) - VIRTUELE POMP - Virtuele pomp instellingen - Upload status naar NS - - NSClient BG - NS BG - Download BG waardes van Nightscout - xDrip+ - Ontvang BG waardes van xDrip+. - BYODA - BYODA - Ontvang BG waarden van de \'Build Your Own Dexcom App\' (BYODA). - Eversense App (aangepast) - Ontvang BG waardes van de aangepaste Eversense app. - Glimp - Ontvang BG waardes van Glimp. - MM640g - Ontvang BG waardes van 600SeriesAndroidUploader. - Poctech - Ontvang BG waardes van Poctech app - Glunovo - Ontvang waardes van Glunovo app - Intelligo - Ontvang waarden van de Intelligo app - Tomato (MiaoMiao) - Tomato - Ontvang BG waardes van Tomato app (MiaoMiao apparaatje) - GlucoRx Aidex - Aidex - Ontvang BG waarden van GlucoRx Aidex CGMS. - Willekeurige BG - Willekeurige BG gegevens genereren (alleen Demo modus) - BG - Stuur BG data naar xDrip+ - In xDrip+ kies 640g/Eversense data bron - BG upload instellingen - Noteer sensor wissel in NS - Noteer automatisch \"Sensor Wissel\" in NS bij starten van sensor Klassiek weergave thema Lage resolutie skin diff --git a/plugins/main/src/main/res/values-no-rNO/strings.xml b/plugins/main/src/main/res/values-no-rNO/strings.xml index 4e12025dd8..72f426a3dd 100644 --- a/plugins/main/src/main/res/values-no-rNO/strings.xml +++ b/plugins/main/src/main/res/values-no-rNO/strings.xml @@ -101,21 +101,6 @@ Profilbytte opprettet Temp basal varighet må oppgis i antall %1$d minutter og større enn 0. QR-kode for oppsett av engangspassord - - Lyumjev - Insulininnstillinger for Humalog og NovoRapid / NovoLog - Insulininnstillinger for Fiasp - Insulininnstillinger for Lyumjev - Lar deg definere toppen på insulinaktiviteten og skal kun brukes av avanserte brukere - INS - IOB-kurvens topptid - Topptid [min] - Egendefinert topp Oref - Hurtigvirkende Oref - Ultra-Rapid Oref - DIA på %1$f er for kort - bruker %2$f i stedet! - Novorapid, Novolog, Humalog - Fiasp xDrip+ statuslinje (klokke) @@ -171,23 +156,6 @@ DIA MÅL BAS - - Fullført, godt gjort! - Enda Ikke fullført - Tid brukt - Maks IOB er angitt riktig - BS tilgjengelig fra valgt kilde - Synkroniseringstjeneste har skriverettigheter - Loop er aktivert - APS valgt - Lukket loop aktivert - MÅL - Opplæringsprogram - Ønsker du å omstarte læringsmålet? Du vil miste fullførte trinn. - Neste - Forrige - Sletting ferdig - Sletting startet Handlinger Hurtigknapper for rask tilgang til ofte brukte funksjoner @@ -207,18 +175,6 @@ kanyle alder patch pumpe alder Patch pumpe - - Begrenser forlenget bolus til %1$.1f E på grunn av %2$s - Begrenser karbohydrater til %1$d g på grunn av %2$s - Pumpen støtter ikke temp basaler - Lukket Loop er eaktivert i innstillinger - Du kjører dev-versjonen. Lukket loop ikke aktivert. - Lukket loop deaktivert på grunn av forlenget bolus - SMB Alltid På og SMB Etter Karbohydrater er deaktivert fordi BS kilden ikke støtter avansert filtrering - SMB ikke tillatt i åpen loop - maks verdi i innstillingene - hard begrensning - Sikkerhet ved behandlinger Vis statusindikatorer på hjem-skjermen Terskel for advarsel om alder på slangesett [h] @@ -345,50 +301,6 @@ SENS Graf skala Graf - - Virtuell pumpetype - Pumpedefinisjon - Bolus: Step=%1$s\nForlenget bolus: [Step=%2$s, Varighet=%3$smin-%4$sh]\nBasal: Step=%5$s\nTBR: %6$s (av %7$s), Varighet=%8$smin-%9$sh\n%10$s - VPUMP - Integrasjon mot pumper som ikke støttes av AndroidAPS (åpen loop) - VIRTUELL PUMPE - Innstillinger for virtuell pumpe - Last opp status til Nightscout - - NSClient BS - NS BS - Last ned BS-verdier fra Nightscout - xDrip+ - Motta BS-verdier fra xDrip+. - BYODA - BYODA - Motta BS verdier fra \'Build Your Own Dexcom App\'. - Eversense App (patched) - Motta BS-verdier fra den modifiserte Eversense-appen. - Glimp - Motta BS-verdier fra Glimp. - MM640G - Motta BS-verdier fra 600SeriesAndroidUploader. - Poctech - Motta BS verdier fra Poctech app - Glunovo - Motta BS verdier fra Glunovo app - Intelligo - Motta BS-verdier fra Intelligo-app - Tomato (MiaoMiao) - Tomato - Motta BS verdier fra Tomato app (MiaoMiao enhet) - GlucoRx Aidex - Aidex - Motta BS verdier fra GlucoRx Aidex CGM. - Vilkårlig BS - Generer vilkårlige BS data (kun demo formål) - BS - Send BS data til xDrip+ - I xDrip+, velg 640G/Eversens som datakilde - Innstillinger for opplasting av BS - Logg sensor bytte til NS - Opprett hendelse \"Sensor bytte\" automatisk i NS ved start av sensoren Opprinnelig visningstema Tema for lav oppløsning diff --git a/plugins/main/src/main/res/values-pl-rPL/strings.xml b/plugins/main/src/main/res/values-pl-rPL/strings.xml index 48962bf2d3..12cff13632 100644 --- a/plugins/main/src/main/res/values-pl-rPL/strings.xml +++ b/plugins/main/src/main/res/values-pl-rPL/strings.xml @@ -97,21 +97,6 @@ Odczyt statusu nie powiódł się Zmiana profilu wykonana Czas trwania TBR musi być wielokrotnością %1$d minut i większy niż 0. - - Lyumjev - Profil insulinowy dla Humalog i Novorapid / NovoLog - Profil insulinowy dla Fiasp - Profil insulinowy dla Lyumjev - Pozwala na określenie czasu wartości szczytowej działania insuliny i powinno być używane tylko przez zaawansowanych użytkowników - INS - IOB Czas piku krzywej działania insuliny - Czas piku [min] - Swobodny-Pik Oref - Szybko-Działający Oref - Ultra-Szybki Oref - DIA %1$f zbyt krótki - przyjmuję %2$f w zamian! - Novorapid, Novolog, Humalog - Fiasp Linia Statusu xDrip+ (zegarek) @@ -158,22 +143,6 @@ DIA CEL BAS - - Ukończone, wspaniale! - Nie ukończono - Czas jaki upłynął - Maks. IOB ustawione poprawnie - BG dostępne z wybranego źródła - Pętla włączona - Wybrano APS - Tryb zamknięty włączony - OBJ - Program do nauki - Czy chcesz zresetować czas rozpoczęcia zadania? Możesz utracić postępy. - Dalej - Poprzedni - Wyczyść skończone - Wyczyść rozpoczęte Akcje Niektóre przyciski umożliwiające szybki dostęp do typowych funkcji @@ -190,18 +159,6 @@ Bateria pompy Kaniula Użycie funkcji Extended bolus spowoduje zatrzymanie trybu pętli zamkniętej na czas działania przedłużonego bolusa. Czy na pewno tego chcesz? - - Ograniczam bolus do %1$.1f U z uwagi na %2$s - Ograniczam węglow. do %1$d g z uwagi na %2$s - Pompa nie jest zdolna do wykonywania dawek bazowych tymczasowych - Tryb zamkniętej pętli wyłączony w ustawieniach - Uruchomiona jest wersja dev. Zamknięta pętla jest wyłączona. - Zamknięta pętla wyłączona, ponieważ działa Extended Bolus (bolus przedłużony) - SMB zawsze i po węglow. wyłączone z uwagi na brak źródła BG z zaawansowanym filtrowaniem - SMB nie dozwolone w trybie otwartej pętli - maks. wartość w ustawieniach - twarde ograniczenie - Bezpieczeństwo terapii Pokaż diody stanu na ekranie głównym Ostrzeżenie o czasie insuliny [h] @@ -315,44 +272,6 @@ TREAT SENS Wykres - - Pompa wirtualna - Definicja Pompy - Bolus: Krok =%1$s\nBolus Przedłużony: [krok =%2$s, czas trwania =%3$smin -%4$sh] \nBasal: krok =%5$s\nTBR: %6$s (przez %7$s), czas trwania =%8$smin -%9$sh\n%10$s - VPUMP - Integracja z pompami, które nie posiadają jeszcze żadnego sterownika (Open Loop) - POMPA WIRTUALNA - Ustawienia pompy wirtualnej - Przesyłaj status do NS - - NSClient BG - NS BG - Pobieraj wartości BG z Nightscout - xDrip+ - Pobieraj wartości BG z xDrip+. - Dexcom Patched - DEX.PATCH. - Pobieraj glikemię ze spatchowanej aplikacji Dexcom. - Apka Eversense (spatchowana) - Pobieraj wartości BG ze spatchowanej aplikacji Eversense. - Glimp - Pobieraj wartości BG z Glimp. - MM640g - Pobieraj wartości BG z uploadera pomp serii 600. - Poctech - Odczytuj wartości BG z aplikacji Poctech - Glunovo - Otrzymuj wartości z aplikacji Glunovo - Tomato (MiaoMiao) - Tomato - Otrzymuj poziomy cukru (BG) z Apki Tomato) (urządzenie MiaoMiao) - Losowa BG - Generuj losowe dane BG (tylko tryb demonstracyjny) - BG - Prześlij dane BG do xDrip+ - W xDrip+ wybierz źródło danych 640g/Eversense - Ustawienia wysyłania wartości BG (poziomów cukru) - Prześlij zmianę sensora do NS Motyw oryginalny Mały ekran diff --git a/plugins/main/src/main/res/values-pt-rBR/strings.xml b/plugins/main/src/main/res/values-pt-rBR/strings.xml index 55d8e79adc..3acb6d5014 100644 --- a/plugins/main/src/main/res/values-pt-rBR/strings.xml +++ b/plugins/main/src/main/res/values-pt-rBR/strings.xml @@ -101,21 +101,6 @@ Troca de perfil criada A duração da basal temporária deve ser um múltiplo de %1$d minutos e maior que 0. Código QR para configuração de senha de uso único - - Lyumjev - Predefinição de Insulina para Humalog e NovoRapid / NovoLog - Pré-ajuste de Insulina para Fiasp - Configuração pre-definida para a Insulina Lyumyev - Permite que você defina o pico da atividade de insulina, deve ser usado apenas por usuários avançados - INS - Tempo Pico da curva de IOB - Tempo Pico [min] - Oref Pico-Livre - Oref Ação Rápida - Ultra-Rapid Oref - Duração de Acção da Insulina (DIA) de %1$f demasiado curto - corrigido para %2$f! - Novorapid, Novolog, Humalog - Fiasp Linha do estado do Xdrip+ (relógio) @@ -171,22 +156,6 @@ DIA ALV BAS - - Terminado, parabéns! - Incompleto - Tempo decorrido - IOB máxima definida correctamente - Glicemia disponivel desde a fonte selecionada - Loop activado - APS seleccionado - Modo fechado ativado - OBJ - Programa de aprendizagem - Deseja reiniciar o objetivo? Pode perder seu progresso. - Seguinte - Anterior - Limpeza terminado - Limpeza iniciado Ações Alguns botões para acessar rapidamente a funções comuns @@ -206,18 +175,6 @@ idade da cânula Idade da bomba patch Bomba patch - - A limitar bólus estendido para %1$.1f U porque %2$s - A limitar hidratos para %1$d g porque %2$s - A bomba não é capaz de basais temporárias - Loop fecchado disabilitado nas preferências - A correr a versão dev. O Loop fechado está desabilitado. - Closed Loop desabilitado por causa da execução do Bólus Estendido - SMB sempre e depois dos hidratos desactivado por fonte da Glicemia activa não suportar filtro avançado - SMB não permitido no modo open loop - valor máx nas preferências - limite rígido - Segurança do Tratamento Mostrar luzes de estado no ecrã principal Aviso de limite da vida útil da insulina [h] @@ -343,50 +300,6 @@ SENS Escala do gráfico Gráfico - - Tipo da Bomba Virtual - Definição da Bomba - Bólus: Passo=%1$s\nBólus Estendido: [Passo=%2$s, Duração=%3$smin -%4$sh] \nBasal: Passo=%5$s\ nTBR: %6$s (por %7$s), Duração=%8$smin-%9$sh\n%10$s - BOMBAV - Integração para as bombas que não têm qualquer driver ainda (Open Loop) - BOMBA VIRTUAL - Definições da bomba virtual - Enviar estado para NS - - Glic NSCliente - NS glicemia - Downloads de dados de Glicose do Nightscout - xDrip+ - Receber valores de glicose do xDrip+. - BYODA - BYODA - Receber valores de glicemia do \'Build Your Own Dexcom App\'. - Aplicação Eversense (com patch) - Receber valores de Glicose da aplicação Eversense modificada. - Glimp - Receber valores BG do Glimp. - MM640g - Receber valores de Glucose do 600SeriesAndroidUploader. - Poctech - Receber valores Glucose da app Poctech - Glunovo - Receber valores GLIC do aplicativo Glunovo - Intelligo - Receber valores da app Intelligo - Tomato (MiaoMiao) - Tomato - Receber valores de Glicose da aplicação Tomato (dispositivo MiaoMiao) - GlucoRx Aidex - Aidex - Receber valores BG do GlucoRx Aidex CGMS. - Glic. Aleatória - Gerar dados de Glic. aleatórios (Somente modo de Demonstração) - GLIC - Enviar dados Glic. para xDrip+ - Seleccionar 640g/Eversense como fonte no xDrip+ - Configurações de upload de BG - Registar mudança de sensor para NS - Criar evento \"Mudança de Sensor\" no NS automaticamente ao iniciar o sensor. Tema original Design de baixa resolução diff --git a/plugins/main/src/main/res/values-pt-rPT/strings.xml b/plugins/main/src/main/res/values-pt-rPT/strings.xml index 046ee6fcd0..9554ee4b65 100644 --- a/plugins/main/src/main/res/values-pt-rPT/strings.xml +++ b/plugins/main/src/main/res/values-pt-rPT/strings.xml @@ -97,21 +97,6 @@ Erro na leitura de estado Troca de perfil criada A duração do DBT deve ser de um múltiplo de %1$d minutos e maior que 0. - - Lyumjev - Predefinição de Insulina Humalog e NovoRapid / NovoLog - Predefinição de Insulina Fiasp - Predefinição para Insulina Lyumjev - Permite definir o pico de atividade da insulina e deve ser usado somente por usuários avançados - INS - Tempo do Pico da curva de IA - Tempo Pico [min] - Oref Pico-Livre - Oref Acção-Rápida - Oref Ultra-Rápida - Duração de Acção da Insulina (DIA) de %1$f demasiado curto - corrigido para %2$f! - Novorapid, Novolog, Humalog - Fiasp Linha Estado xDrip+ (relógio) @@ -158,22 +143,6 @@ DIA ALV BAS - - Terminado, parabéns! - Não concluído ainda - Tempo decorrido - IA máxima definida corretamente - Glicose disponível da fonte seleccionada - Loop activado - APS seleccionado - Modo fechado ativado - OBJ - Programa de aprendizagem - Deseja reiniciar o objectivo? Pode perder seu progresso. - Seguinte - Anterior - Limpar terminado - Limpar iniciado Acções Alguns botões para aceder rapidamente a funções comuns @@ -190,18 +159,6 @@ Bateria da Bomba Cânula O uso do Bólus Prolongado irá parar o modo Loop Fechado durante o tempo do bólus prolongado. Quer realmente isso? - - A limitar bólus prolongado para %1$.1f U porque %2$s - A limitar hidratos para %1$d g porque %2$s - A bomba não é capaz de basais temporárias - Loop fechado desativado nas preferências - A correr a versão dev. O Loop fechado está desativado. - Loop Fechado desativado por causa da execução do Bólus Prolongado - SMB sempre e depois dos hidratos desactivado por fonte da Glicose activa não suportar filtro avançado - SMB não permitido no modo open loop - valor máx nas preferências - limite rígido - Segurança de Tratamentos Mostrar luzes de estado no ecrã principal Limite aviso idade insulina [h] @@ -318,44 +275,6 @@ TRATA SENS Gráfico - - Tipo da Bomba Virtual - Definição da Bomba - Bólus: Passo=%1$s\nBólus Prolongado: [Passo=%2$s, Duração=%3$smin -%4$sh] \nBasal: Passo=%5$s\ nDBT: %6$s (por %7$s), Duração=%8$smin-%9$sh\n%10$s - BOMBAV - Integração para as bombas que não têm qualquer driver ainda (Open Loop) - BOMBA VIRTUAL - Definições da bomba virtual - Enviar estado para NS - - Glicose ClienteNS - Glicemia do NS - Descarrega dados Glicose do Nightscout - xDrip+ - Receber valores Glicose do xDrip+. - BYODA - BYODA - Receber valores de glicemia do aplicativo BYODA. - Aplicação Eversense (com patch) - Receber valores Glicose da aplicação Eversense modificada. - Glimp - Receber valores Glicose do Glimp. - MM640g - Receber valores Glicose do 600SeriesAndroidUploader. - Poctech - Receber valores Glucose da app Poctech - Glunovo - Receber valores do aplicativo Glunovo - Tomato (MiaoMiao) - Tomato - Receber valores de Glicose da app Tomato (dispositivo MiaoMiao) - Glicose Aleatória - Gerar dados de Glic. aleatórios (Somente modo de Demonstração) - GLIC - Enviar dados Glicose para xDrip+ - Seleccionar 640g/Eversense como fonte no xDrip+ - Definições de Envio da Glicose - Registar mudança de sensor para NS Tema Gráfico Original Design de Baixa Resolução diff --git a/plugins/main/src/main/res/values-ro-rRO/strings.xml b/plugins/main/src/main/res/values-ro-rRO/strings.xml index 5c8fabc17c..8961ea29ec 100644 --- a/plugins/main/src/main/res/values-ro-rRO/strings.xml +++ b/plugins/main/src/main/res/values-ro-rRO/strings.xml @@ -97,21 +97,6 @@ Citire eșuată a stării Schimbare de profil creată Durata RBT trebuie să fie un multiplu de %1$d minute și mai mare de 0. - - Lyumjev - Setări prestabilite pentru insulinele Humalog sau NovoRapid / NovoLog - Setări prestabilite pentru Fiasp - Setări prestabilite pentru Lyumjev - Vă permite definirea vârfului activităţii insulinei şi ar trebui folosit doar de către utilizatorii avansaţi - INS - Curbă timp vârf IOB - Timp vârf [min] - Oref Vârf-Liber - Oref Insulină-Rapidă - Oref Insulină-UltraRapidă - DIA din %1$f prea scurtă - se folosește %2$f în schimb! - Novorapid, Novolog, Humalog - Fiasp Linie de stare xDrip+ (ceas) @@ -159,22 +144,6 @@ DIA TARG BZL - - Finalizat cu succes! - Încă incomplet - Timp scurs - IOB maxim configurat corect - Glicemie disponibilă din sursa selectată - Buclă activată - APS selectat - Mod buclă închisă activat - OBI - Program de învăţare - Doriți să reîncepeți obiectivul? Vă puteți pierde progresul. - Următor - Anterior - Șterge starea \"Terminat\" - Șterge starea \"Început\" Acțiuni Butoane pentru accesarea celor mai comune facilităţi @@ -192,18 +161,6 @@ Canula Utilizarea unui bolus extins va opri modul buclă închisă pe timpul livrării bolusului extins. Sigur doriți acest lucru? vechime canulă - - Se limitează bolusul extins la %1$.1f U datorită %2$s - Se limitează carbohidrații %1$d g datorită %2$s - Pompa nu suportă bazale temporare - Modul buclă închisă dezactivat în preferințe - Se folosește versiunea dev. Bucla închisă este dezactivată. - Bucla închisă dezactivată din cauza livrării bolusului extins - SMB dezactivat întotdeauna și după carbohidrați, deoarece sursa glicemiei nu suportă filtrare avansată - SMB nu este permis în mod buclă deschisă - valoare maximă în preferințe - limită fizică - Setări siguranță tratament Afișați indicatorii luminoși ai pompei pe ecranul de start Prag de avertizare vechime insulină [h] @@ -320,44 +277,6 @@ TRAT SENS Grafic - - Tipul pompei virtuale - Definirea pompei - Bolus: Pas=%1$s\nBolus Extins: [Pas=%2$s, Durată=%3$smin-%4$sh]\nBazală: Pas=%5$s\nRBT: %6$s (cu %7$s), Durată=%8$smin-%9$sh\n%10$s - POMPĂV - Integrare cu pompele ce nu au încă un driver software disponibil (Buclă Deschisă) - POMPĂ VIRTUALĂ - Setări pompă virtuală - Trimitere status către NS - - Glicemie NSClient - NS GL - Descarcă datele despre glicemii din Nightscout - xDrip+ - Primește valorile glicemiei din xDrip+. - BYODA - BYODA - Primește valori de glicemie de la aplicația Dexcom modificată. - Aplicația Eversense (modificată) - Primește valorile glicemiei din aplicația Eversense modificată. - Glimp - Primește valorile glicemiei din aplicația Glimp. - MM640g - Primește valorile glicemiei din aplicația 600SeriesAndroidUploader (Medtronic). - Poctech - Citire a valorii glicemiei din aplicația Poctech - Glunovo - Primiți glicemii de la aplicația Glunovo - Tomato (MiaoMiao) - Tomato - Înregistrează valorile glicemiei din aplicația Tomato (dispozitiv MiaoMIao) - Glicemie aleatoare - Generare glicemie aleator (doar mod Demo) - Gl - Trimite date glicemie la xDrip+ - Selectați 640g/Eversense ca sursă de date în xDrip+ - Setări înregistrare glicemie - Înregistrează schimbarea senzorului în NS Tema originală Skin de rezoluție redusă diff --git a/plugins/main/src/main/res/values-ru-rRU/strings.xml b/plugins/main/src/main/res/values-ru-rRU/strings.xml index e709cb0e8b..3c56618229 100644 --- a/plugins/main/src/main/res/values-ru-rRU/strings.xml +++ b/plugins/main/src/main/res/values-ru-rRU/strings.xml @@ -101,21 +101,6 @@ Переключатель профиля создан Длительность временного базала TBR должна быть кратной %1$d минутам и больше 0. QR код для создания одноразового пароля - - Lyumjev - Предустановки для Humalog и Novorapid / Novolog - Предустановки для Fiasp - Предустановки для Lyumjev - Позволяет самостоятельно задавать пик активности инсулина - только для опытных пользователей - ИНС - Время пика активного инс IOB - Время пика [min] - Свободный от пиков Oref - Быстро действующий Oref - Сверхбыстрый Oref - Значение времени действия инс %1$f слишком мало - применено %2$f! - Новорапид, Хумалог - Фиасп Cтрока состояния xDrip (часы) @@ -171,23 +156,6 @@ Время действия инсулина DIA ЦЕЛЬ БАЗАЛ - - Завершено, отлично! - Не завершено - Прошло времени - Максимум активного инсулина IOB установлен правильно - ГК доступна из выбранного источника - Служба синхронизации имеет разрешение на запись - Цикл активирован - Выбран APS - Режим замкнутого цикла включен - ЦЕЛИ - Обучающая программа - Хотите сбросить начатую цель? Можете потерять достигнутое. - Далее - Назад - Очистить завершенные - Очистить начатые Действия Кнопки быстрого доступа к некоторым распространенным настройкам @@ -207,18 +175,6 @@ время, отработанное катетером помпы время отработанное разовой помпой Разовая помпа - - Ограничение пролонгированного болюса до %1$.1f ед. из-за %2$s - Ограничение углеводов до %1$d г. из-за %2$s - Помпа не рассчитана на подачу временного базала - Режим замкнутого цикла отключен в настройках - Работает версия разработчика. Замкнутый цикл отключен. - Замкнутый цикл отключен из-за работы Пролонгированного Болюса - Опция супер микро болюс всегда и после углеводов отключена т. к. активный источник ГК не поддерживает комплексное фильтрование - В режиме незамкнутого цикла open loop супер микро болюс SMB не допускается - максимальное значение в настройках - жесткий предел - Безопасность терапии Показать индикаторы состояния на главном экране Порог предупреждения о времени, отработанном катетером [h] @@ -345,50 +301,6 @@ ЧУВСТВ Масштаб графика График - - Тип виртуальной помпы - Определение помпы - Болюс: Шаг =%1$s\n Пролонгированный Болюс: [Шаг =%2$s, Продолжительность =%3$sмин -%4$sh] \nБазал: Шаг =%5$s\n ВБС: %6$s (на %7$s), Продолжительность =%8$sмин -%9$sh\n%10$s - ВиртПомпа - Интеграция с помпами, еще не имеющими драйвера (незамкнутый цикл) - ВИРТУАЛЬНАЯ ПОМПА - настройки вирт помпы - статус передачи данных в NS - - СК с клиента Nightscout - ГК с NS - Получать данные гликемии с сайта Nightscout - xDrip + - Получать данные гликемии от xDrip+. - Самост собран прилож Dexcom - ССП DEXCOM - Получать данные ГК от \'Самостоятельно собранного приложения Dexcom\'. - Приложение Eversense (пропатченное) - Получать данные гликемии от пропатченного приложения Eversense. - Glimp - Получать данные гликемии от Glimp. - MM640g - Получать данные гликемии от 600SeriesAndroidUploader. - Poctech - Получать данные гликемии от приложения Poctech - Приложение Glunovo - Получать данные гликемии от приложения Glunovo - Приложение Intelligo - Получать данные гликемии от приложения Intelligo - Томато (MiaoMiao) - Томато - Получать значения ГК от приложения Tomato (устройство MiaoMiao) - Aidex GlucoRx - Aidex - Получить значения ГК от GlucoRx Aidex - Случайные значения ГК - Генерировать случайные данные ГК (только демо-режим) - ГК - Отправлять данные СК на xDrip+ - В xDrip + выберите источник данных 640g/Eversense - Параметры загрузки СК - Вносить запись о замене сенсора в NS - Автоматически создать событие \"Замена сенсора\" в NS при запуске сенсора Исходная тема оформления Тема для низкого разрешения diff --git a/plugins/main/src/main/res/values-sk-rSK/strings.xml b/plugins/main/src/main/res/values-sk-rSK/strings.xml index 05e2e9075c..abd63b9d3e 100644 --- a/plugins/main/src/main/res/values-sk-rSK/strings.xml +++ b/plugins/main/src/main/res/values-sk-rSK/strings.xml @@ -101,21 +101,6 @@ Prepnutie profilu vytvorené Trvanie dočasného bazálu musí byť násobkom %1$d minút a musí byť väčšie ako 0. QR kód pre nastavenie jednorázového hesla - - Lyumjev - Predvoľba pre inzulín Humalog a Novorapid - Predvoľba pre inzulín Fiasp - Predvoľba pre inzulín Lyumjev - Umožňuje definovať vrchol účinnosti inzulínu a malo by byť používané iba pokročilými užívateľmi - INZ - Čas vrcholu IOB krivky - Vrchol krivky [min] - Voliteľný vrchol - Oref - Rýchlo pôsobiaci - Oref - Ultra rýchly - Oref - DIA %1$f je príliš krátke - AAPS namiesto toho použilo %2$f ! - Novorapid, Novolog, Humalog - Fiasp Stavový riadok xDrip+ (hodinky) @@ -171,23 +156,6 @@ DIA CIEĽ BAZ - - Hotovo, gratulujeme! - Nedokončené - Uplynutý čas - Maximálne IOB nastavené správne - Glykémie dostupné z vybraného zdroja - Služba synchronizácie má oprávnenie k zápisu - Uzavretý okruh povolený - APS vybrané - Uzavretý okruh povolený - CIEĽ - Výukový program - Chcete resetovať začiatok cieľa? Môžete prísť o svoj pokrok. - Ďalej - Späť - Vymazanie dokončené - Vymazanie začaté Akcie Niektoré tlačidlá na rýchly prístup do spoločných funkcií @@ -207,18 +175,6 @@ vek kanyly vek náplasťovej pumpy Náplasťová pumpa - - Predĺžený bolus obmedzený na %1$.1f JI: %2$s - Sacharidy obmedzené na %1$d g: %2$s - Pumpa nepodporuje dočasné bazály - Uzavretý okruh zakázaný v nastaveniach - Bežiaca vývojárska verzia. Uzavretý okruh je zakázaný. - Uzavretý okruh je zastavený kvôli prebiehajúcemu predĺženému bolusu - \"SMB vždy\" a \"po jedle\" zakázané pretože zdroj glykémie nepodporuje rozšírené filtrovánie - SBM nie sú povolené pri otvorenom okruhu - maximálna hodnota v nastaveniach - pevný limit - Bezpečnosť zadania ošetrenia Zobraziť indikátory stavu na domovskej obrazovke Prah upozornenia na vek kanyly [h] @@ -346,50 +302,6 @@ SENZ Mierka grafu Graf - - Typ virtuálnej pumpy - Definícia pumpy - Bolus: Krok =%1$s\nPredl. bolus: [Krok=%2$s, Dĺžka=%3$smin-%4$sh]\nBazál: Krok=%5$s\nDoč. bazál: %6$s (%7$s), Dĺžka=%8$smin-%9$sh\n%10$s - VPUM - Ovládač pumpy pre užívateľov bez podporovanej pumpy (Otvorený okruh) - Virtuálna pumpa - Nastavenie virtuálnej pumpy - Nahrať stav do NS - - Glykémie z NS - NS GL - Získavať hodnoty glykémií z Nightscoutu - xDrip+ - Prijímať hodnoty glykémií z xDrip+. - BYODA - BYODA - Prijímať hodnoty glykémií z upravenej aplikácie Dexcom (BYODA). - Eversense aplikácia (upravená) - Získavať glykémie z upravenej Eversense aplikácie. - Glimp - Získavať hodnoty glykémií z aplikácie Glimp. - MM640g - Získavať hodnoty glykémií z 600SeriesAndroidUploader. - Poctech - Získavať glykémie z aplikácie Poctech - Glunovo - Získavať glykémie z aplikácie Glunovo - Intelligo - Prijímať hodnoty z aplikácie Intelligo - Tomato (MiaoMiao) - Tomato - Prijímať glykémie z aplikácie Tomato (zariadenie MiaoMiao) - GlucoRx Aidex - Aidex - Prijímať hodnoty glykémie zo senzora GlucoRx Aidex. - Náhodná glykémia - Vygeneruj náhodné dáta glykémií (iba Demo režim) - Gly - Odosielať glykémie do xDrip+ - V xDrip+ vyberte zdroj dát 640g/Eversense - Nastavenie nahrávania glykémie - Ulož výmenu senzora do NS - Vytvoriť udalosť \"Výmena senzora\" v NS automaticky pri spustení senzora Pôvodný vzhľad Vzhľad pre nízke rozlišenie diff --git a/plugins/main/src/main/res/values-sr-rCS/strings.xml b/plugins/main/src/main/res/values-sr-rCS/strings.xml index 2046cec927..e9e2429e2d 100644 --- a/plugins/main/src/main/res/values-sr-rCS/strings.xml +++ b/plugins/main/src/main/res/values-sr-rCS/strings.xml @@ -46,11 +46,6 @@ IOB: Bolus: Basal: - - Unapred podešena postavka insulina za Humalog i NovoRapid / NovoLog - Unapred podešena postavka insulina za Fiasp - Unapred podešena postavka insulina za Lyumjev - Omogućava definisanje vrhunca aktivnosti insulina i trebaju ga koriste samo napredni korisnici Prikažite informacije o tvom loop-u na tvom xDrip+ satu. @@ -62,16 +57,12 @@ Profil Definiši profil koji je dostupan bez internet veze. - - Program učenja Neke tipke za brzi pristup uobičajenim funkcijama Privremeni Basal Produženi Bolus Senzor Insulin - - Sigurnost tretmana insulin Prihvatite novi privremeni bazal: @@ -89,17 +80,6 @@ Tretmani Tretmani - - Integracija pumpe za pumpe koje još uvek nemaju upravljački program (Open Loop) - VIRTUALNA PUMPA - - Preuzimajte podatke GUK sa Nightscout-a - xDrip+ - Preuzimajte vrijednosti GUK od xDrip+. - Preuzimajte vrednosti GUK iz zakrpljene aplikacije Eversense. - Preuzimajte vrednosti GUK od Glimp-a. - Preuzimajte vrednosti GUK od 600SeriesAndroidUploader-a. - GUK diff --git a/plugins/main/src/main/res/values-sv-rSE/strings.xml b/plugins/main/src/main/res/values-sv-rSE/strings.xml index 2b858cf736..bc85bc3c5a 100644 --- a/plugins/main/src/main/res/values-sv-rSE/strings.xml +++ b/plugins/main/src/main/res/values-sv-rSE/strings.xml @@ -97,21 +97,6 @@ Statuskontroll misslyckad Skapade ett profilbyte Durationen måste vara större än 0 och en multipel av %1$d minuter. - - Lyumjev - Insulininställning för vanliga direktverkande insuliner som Humalog, Lispro, Apidra och Novorapid/Novolog - Insulininställning för ultrasnabba insuliner, t ex Fiasp - Insulininställning för Lyumjev - Låter dig ställa in tidpunkten för toppen på insulinets aktivitet. Bör bara användas av avancerade användare - INS - Peaktid för IOB-kurvan - Peaktid [min] - Free-Peak Oref - Rapid-Acting Oref - Ultra-Rapid Oref - %1$f tim DIA är för kort. Använder %2$f istället! - Novorapid, Novolog, Humalog, Apidra - Fiasp xDrip+ Statusrad (klocka) @@ -161,22 +146,6 @@ DIA Mål BAS - - Klart. Bra jobbat! - Inte slutfört ännu - Förfluten tid - Max IOB är korrekt angivet - BG tillgängligt från vald källa - Loop aktiverad - APS vald - Closed loop aktiverad - Mål - Inlärningsprogram - Vill du starta om målet? Du kan förlora de steg du gjort hittills. - Nästa - Föregående - Rensa avslutade - Rensa påbörjade Åtgärder Knappar för att snabbt komma åt vanliga funktioner @@ -196,18 +165,6 @@ kanylålder slanglös pump ålder Slanglös pump - - Begränsar bolus till %1$.1f enheter pga %2$s - Begränsar kolhydrater till %1$d g pga %2$s - Pumpen kan inte hantera temp basaler - Closed Loop inaktiverat i Inställningar - Du kör nu dev-versionen. Closed Loop inaktiverat. - Closed Loop-läget inaktiverat pga att en förlängd bolus är aktiv - SMB Alltid På och SMB Efter Kolhydrater är inaktiverat pga att den aktiva BG-källan inte stöder avancerad filtrering - SMB inte tillåtet i Open Loop - maxvärde i Inställningar - hård begränsning - Säkerhetsbegränsningar Visa \"statuslampor\" på hemskärmen Insulinålder - varning: [h] @@ -327,45 +284,6 @@ Beh SENS Graf - - Typ av virtuell pump - Pumpdefinition - Bolus: Steg =%1$s\nFörlängd bolus: [Steg=%2$s, duration =%3$smin -%4$sh] \nBasal: Steg=%5$s\nTempbasal: %6$s (av %7$s), duration =%8$smin -%9$sh\n%10$s - vPump - Integration för pumpar som ännu inte stöds av AndroidAPS (Open loop) - Virtuell pump - Inställningar för Virtuell pump - Ladda upp status till Nightscout - - NSClient BG - NS BG - Ladda ner BG-data från Nightscout - xDrip+ - Ta emot BG-data från xDrip+. - Patchad Dexcom-app - Dex - Ta emot BG-värden från \"Bygg din egen Dexcom-app\". - Eversense App (modifierad) - Ta emot BG-data från den modifierade -Eversense-appen. - Glimp - Ta emot BG-data från Glimp - Minimed 640G - Ta emot BG-data från 600SeriesAndroidUploader - Poctech - Ta emot BG-data från Poctechappen - Glunovo - Ta emot värden från Glunovo-appen - Tomato (MiaoMiao) - Tomato - Ta emot BG-data från tomato app (MiaoMiao-enhet) - Slumpgenerator för BG - Generera slumpmässiga BG-data (endast demo-läge) - BG - Skicka BG-data till xDrip+ - Välj \"640G/Eversense\" som datakälla i xDrip+ - Uppladdningsinställningar för BG - Logga sensorbyte till Nightscout Ursprungligt tema Lågupplöst tema diff --git a/plugins/main/src/main/res/values-tr-rTR/strings.xml b/plugins/main/src/main/res/values-tr-rTR/strings.xml index 8da2217a97..f13c29c1c6 100644 --- a/plugins/main/src/main/res/values-tr-rTR/strings.xml +++ b/plugins/main/src/main/res/values-tr-rTR/strings.xml @@ -101,21 +101,6 @@ Profil değiştirme yapıldı GBO süresi %1$d dakikanın katı ve 0\'dan büyük olmalıdır. Tek kullanımlık şifre kurulumu için QR Kodu - - Lyumjev - Humalog ve NovoRapid / NovoLog için İnsülin Profili - Fiasp için insülin Profili - Lyumjev için insülin ayarı - İnsülin aktivitesinin zirvesini tanımlamanıza izin verir ve yalnızca ileri düzey kullanıcılar tarafından kullanılmalıdır. - İNS - AİNS Eğrisi Tepe Zamanı - Tepe zamanı [min] - Serbest tepe Oref - Hızlı etkili Oref - Ultra Hızlı Oref - DIA %1$f çok kısa - bunun yerine %2$f kullanıyor! - Novorapid, Novolog, Humalog - Fiasp xDrip+ Durum Çizgisi (saat) @@ -171,23 +156,6 @@ İES HDF BAZ - - Tamamlandı, tebrikler! - Henüz tamamlanmadı - Geçen süre - Maksimal AİNS doğru şekilde ayarlandı - Seçili kaynaktan KŞ kullanılabilir - Senkronizasyon servisi yazma iznine sahip - Döngü etkin - APS Seçildi - Kapalı mod etkin - GRV - Eğitim programı - Görevleri sıfırlamak istiyor musunuz? Tüm yaptıklarınızı kaybedeceksiniz. - Sonraki - Geri - Komple tamamlandı - Yeniden Başla Eylemler Ortak özelliklere hızlıca erişmek için bazı düğmeler @@ -207,18 +175,6 @@ kanül yaşı yama pompa yaşı Yama pompa - - %2$s\'den dolayı yayma bolus %1$.1f Ü ile sınırlandırılıyor - %2$s\'den dolayı karbonhidratlar %1$d g ile sınırlandırılıyor - Pompa geçici bazal özellikli değil - Kapalı Döngü tercihlerde devre dışı bırakıldı - Geliştirici sürümü çalışıyor. Kapalı Döngü devre dışı. - Yayma bolus çalıştığı için kapalı döngü devre dışı bırakıldı - Aktif KŞ kaynağı gelişmiş filtrelemeyi desteklemediği için SMB (Super Micro Bolus) her zaman ve karbonhidratlardan sonra devre dışı bırakıldı - Açık Döngü modunda SMB\'ye (Super Micro Bolus) izin verilmiyor - tercihlerde maksimum değer - sert sınır - Tedavi güvenliği Ana ekranda durum ışıklarını göster Kanül ömrü uyarısı belirle (saat) [h] @@ -346,50 +302,6 @@ SENS Grafik ölçeği Grafik - - Sanal pompa tipi - Pompa tanımı - Bolus: Adım=%1$s\nYayma Bolus: [Adım=%2$s, Süre=%3$sdk-%4$ssa]\nBazal: Adım=%5$s\nGBO: %6$s (ile %7$s), Süre=%8$sdk-%9$ssa\n%10$s - VPOMP - Henüz herhangi bir sürücüye sahip olmayan pompalar için pompa entegrasyonu (Açık Döngü) - SANAL POMPA - Sanal pompa ayarları - Nightscout\'a durum aktar - - NSClient KŞ - NS KŞ - Nightscout\'tan KŞ verilerini yükler - xDrip+ - XDrip+\'ten KŞ değerlerini alır. - BYODA - BYODA - \'Kendi Dexcom Uygulamanızı Oluşturun\' uygulamasından KŞ değerlerini alın. - Eversense App (yamalı) - Yamalı Eversense uygulamasından KŞ değerleri alır. - Glimp - Glimp\'ten KŞ değerleri alır. - MM640g - 600SeriesAndroidUploader\'dan KŞ değerleri alır. - Poctech - Poctech uygulamasından KŞ değerlerini alır - Glunovo - Glunovo uygulamasından değerler alır - Intelligo - Intelligo uygulamasından değerler alır - Tomato (MiaoMiao) - Tomato - KŞ değerlerini Tomato uygulamasından (MiaoMiao Cihazından) al - GlucoRx Aidex - Aidex - GlucoRx Aidex CGMS\'den KŞ değerleri alır. - Rastgele KŞ - Rastgele KŞ verileri oluşturun (Yalnızca demo modunda) - - XDrip+\'a KŞ verilerini gönder - xDrip+ içerisinde 640g/Eversense veri kaynağı seç - KŞ yükleme ayarları - Sensör değişimlerini NS\'a kaydet - Sensör başlangıcında otomatik olarak NS\'de \"Sensör Değişimi\" olayı oluştur Orjinal görünüm Düşük çözünürlüklü görünüm diff --git a/plugins/main/src/main/res/values-zh-rCN/strings.xml b/plugins/main/src/main/res/values-zh-rCN/strings.xml index 25056e363a..fa3ba90a5e 100644 --- a/plugins/main/src/main/res/values-zh-rCN/strings.xml +++ b/plugins/main/src/main/res/values-zh-rCN/strings.xml @@ -98,21 +98,6 @@ 配置文件切换已创建 TBR(临时基础率) 的持续时间必须是 %1$d 分钟的倍数,且大于0。 用于安装一次性随机验证码的二维码 - - Lyumjev(超速效赖脯胰岛素) - 胰岛素预设为 Humalog(优泌乐) 和 NovoRapid(门冬)/NovoLog(诺和锐) - Fiasp 胰岛素预设 - 预设为Lyumjev速效赖脯胰岛素 - 允许您定义胰岛素作用的峰值, 并且只应由高级用户使用 - INS - IOB 曲线峰值时间 - 峰值时间 [min] - Free-Peak Oref - 速效 Oref - 超速效 Oref - DIA of %1$f 太短了,请使用 %2$f 代替 - 诺和锐, 门冬, 优泌乐 - Fiasp超速效 xDrip+状态线 (手表) @@ -168,22 +153,6 @@ DIA TARG 基础率 - - 完成了,做的好 - 尚未完成 - 已用时间 - 合理地设置最大 IOB - 所选的血糖值来源的血糖是可用的 - 闭环启用了 - APS已选择 - 闭环模式启用了 - 目标 - 学习计划 - 你想要重置已启动的目标? 你会失去已有的进度。 - 下一个 - 上一个 - 清除已完成 - 清除已启动 手动操作 一些快速访问常用功能的按钮 @@ -203,18 +172,6 @@ 导管年龄 patch 泵年龄 Patch 泵 - - 由于 %2$s, 将扩展大剂量限制为 %1$.1f U - 由于 %2$s, 将碳水化合物限制为 %1$d 克 - 这个泵无法设置临时基础率 - 在参数选项中禁用了闭环模式 - 正在运行开发版本,闭环被禁用了 - 由于运行扩展大剂量而禁用了闭环 - SMB always and after carbs disabled 因为实时的血糖来源不支持高级筛选 - 在开环模式下不允许使用SMB-微型大剂量 - 在参数选项里的最大值 - 硬限制 - 治疗安全 在主屏幕上显示状态指示灯 胰岛素状态灯警示阀值[小时] @@ -340,47 +297,6 @@ 灵敏度 图形缩放 绘图 - - 虚拟泵类型 - 泵定义 - 大剂量: Step=%1$s\n扩展大剂量: [Step=%2$s, 持续时间=%3$smin-%4$sh]\n基础率: Step=%5$s\nTBR临时基础率: %6$s (by %7$s), 持续时间=%8$smin-%9$sh\n%10$s - 虚拟泵 - 与我们还没有其驱动的泵集成(开环) - 虚拟泵 - 虚拟泵设置 - 将状态上传到 NS - - NSClient 血糖 - NS血糖 - 从 Nightscout 下载 血糖数据 - xDrip+ - 从 xDrip+ 接收血糖值。 - BYODA德康补丁版(构建你自己的德康应用Build Your Own Dexcom App) - BYODA - 从德康补丁版接收血糖数据(Build Your Own Dexcom App)。 - Everyang App (补丁) - 从 Eversense 补丁app接收血糖值。 - Glimp - 从 Glimp 接收血糖值。 - 美敦力640g - 从美敦力600Series 的AndroidUploader 接收血糖值。 - Poctech - 从 Poctech app 接收血糖值。 - Glunovo - 从Glunovo应用接收血糖数据。 - 番茄(喵喵) - 番茄 - 从番茄app(喵喵设备) 接收血糖值 - GlucoRx Aidex动泰 - Aidex动泰 - 从GlucoRx Aidex动泰持续葡萄糖监测系统接收血糖值。 - 随机血糖 - 生成随机血糖数据(仅限demo演示模式) - 血糖 - 将血糖数据发送到 xDrip + - 在 xDrip + 选择640g/Eversense 数据源 - 血糖上传设置 - 记录传感器更换至NS服务器 原始皮肤 低分辨率皮肤 diff --git a/plugins/source/src/main/res/values-af-rZA/strings.xml b/plugins/source/src/main/res/values-af-rZA/strings.xml new file mode 100644 index 0000000000..844c8e545d --- /dev/null +++ b/plugins/source/src/main/res/values-af-rZA/strings.xml @@ -0,0 +1,15 @@ + + + + Laai BG data af vanaf Nightscout + Eversense App (bygewerk) + Ontvang BG waardes uit die gelapte Eversense toep. + Ontvang BG waardes vanaf Glimp. + Onvang BG waardes vanaf die 600SeriesAndroidUploader. + Poctech + Ontvang BG waardes van Poctech toepassing + Tomato (MiaoMiao) + Tomato + Ontvang BG waardes vanaf Tomato toep (MiaoMiao toestel) + BG oplaai instellings + diff --git a/plugins/source/src/main/res/values-bg-rBG/strings.xml b/plugins/source/src/main/res/values-bg-rBG/strings.xml new file mode 100644 index 0000000000..0724dc5059 --- /dev/null +++ b/plugins/source/src/main/res/values-bg-rBG/strings.xml @@ -0,0 +1,21 @@ + + + + Изтегля стойности на КЗ от Nightscout + xDrip+ + Получаване на данни за КЗ от xDrip+. + BYODA + BYODA + Eversense приложение(модифицирано) + Получава данни за КЗ от модифицираното приложение на Eversense. + Получава данни за КЗ от Glimp. + Получават стойности на КЗ от 600SeriesAndroidUploader. + Poctech + Получавай данни за КЗ от Poctech апликацията. + Глуново + Получавай данните от Glunowo апликацията + Tomato(MяоМяо) + Tomato + Получавай КЗ от Tomato апликация (устройство МяоМяо) + Настройки при качване на КЗ към Nightscout + diff --git a/plugins/source/src/main/res/values-ca-rES/strings.xml b/plugins/source/src/main/res/values-ca-rES/strings.xml new file mode 100644 index 0000000000..f43b3c3f92 --- /dev/null +++ b/plugins/source/src/main/res/values-ca-rES/strings.xml @@ -0,0 +1,22 @@ + + + + Descarrega dades de glucèmia des de Nightscout + xDrip+ + Rebre valors de glucèmia de xDrip+. + Dexcom (BYODA) + BYODA + Rebre els valors de glucosa de l\'aplicació Dexcom \'Build Your Own Device\'. + App Eversense (\"parxejada\") + Rebre valors de glucèmia de l\'app Eversense \"parxejada\". + Rebre valors de glucèmia de Glimp. + Rebre valors de glucèmia del 600SeriesAndroidUploader. + Poctech + Rebre valors de glucèmia de l\'app Poctech + Glunovo + Rebre valors de l\'app Glunovo + Tomato (MiaoMiao) + Tomato + Rebre valors de glucèmia de l\'app Tomato (dispositiu MiaoMiao) + Configuració enviament dades glucèmia + diff --git a/plugins/source/src/main/res/values-cs-rCZ/strings.xml b/plugins/source/src/main/res/values-cs-rCZ/strings.xml new file mode 100644 index 0000000000..c6b21df27b --- /dev/null +++ b/plugins/source/src/main/res/values-cs-rCZ/strings.xml @@ -0,0 +1,39 @@ + + + + Glykémie z NS + NSGL + Příjem glykémií z Nightscoutu + xDrip+ + Příjem glykémií z xDripu+. + BYODA + BYODA + Příjem hodnot glykémií z upravené aplikace Dexcom (BYODA). + Eversense aplikace (upravená) + Příjem glykémií z modifikované Eversense aplikace. + Glimp + Příjem glykémií z Glimpu. + MM640g + Příjem glykémií z Uploaderu 640G. + Poctech + Získávat glykémie z aplikace Poctech + Glunovo + Získávat glykémie z aplikace Glunovo + Intelligo + Přijímat hodnoty z aplikace Intelligo + Tomato (MiaoMiao) + Tomato + Přijímat hodnoty glykémií z Tomato aplikace (MiaoMiao zařízení) + GlucoRx Aidex + Aidex + Přijímat hodnoty glykémie ze senzoru GlucoRx Aidex. + Náhodná glykémie + Generovat náhodná data glykémie (pouze režim Demo) + Gly + Odesílat data do xDrip+ + V xDrip+ vyberte zdroj dat 640g/Eversense + Nastavení nahrávání glykémií + Zaznamenávat výměnu senzoru do NS + Vytvořit událost \"Výměna senzoru\" v NS automaticky po spuštění senzoru + směr + diff --git a/plugins/source/src/main/res/values-da-rDK/strings.xml b/plugins/source/src/main/res/values-da-rDK/strings.xml new file mode 100644 index 0000000000..74831ff338 --- /dev/null +++ b/plugins/source/src/main/res/values-da-rDK/strings.xml @@ -0,0 +1,26 @@ + + + + Downloader BG data fra Nightscout + xDrip+ + Modtag BG-værdier fra xDrip+. + BYODA + BYODA + Modtag BS-værdier fra \'Byg din egen Dexcom App\'. + Eversense App (patched) + Modtag BG værdier fra den patchede Eversense app. + Modtag BG-værdier fra Glimp. + Modtag BG-værdier fra 600SeriesAndroidUploader. + Poctech + Modtag BS-værdier fra Poctech app + Glunovo + Modtag værdier fra Glunovo app + Intelligo + Modtag værdier fra Intelligo-appen + Tomato (MiaoMiao) + Tomato + Modtag BS-værdier fra Tomato-appen (MiaoMiao enhed) + Aidex + Modtag BG-værdier fra GlucoRx Aidex CGMS. + BS upload indstillinger + diff --git a/plugins/source/src/main/res/values-de-rDE/strings.xml b/plugins/source/src/main/res/values-de-rDE/strings.xml new file mode 100644 index 0000000000..f62cc41420 --- /dev/null +++ b/plugins/source/src/main/res/values-de-rDE/strings.xml @@ -0,0 +1,26 @@ + + + + Lade Blutzuckerdaten von Nightscout + xDrip+ + Empfange Blutzuckerwerte von xDrip+. + BYODA + BYODA + Erhalte BZ-Werte von der \'Build Your Own Dexcom App\'. + Eversense App (gepatcht) + Empfange BZ-Werte von der gepatchten Eversense-App. + Empfange Blutzuckerwerte von Glimp. + Empfange Blutzuckerwerte vom 600SeriesAndroidUploader. + Poctech + Empfange Blutzucker-Werte von der Poctech-App. + Glunovo + Werte von der Glunovo App erhalten + Intelligo + Empfange Werte von der Intelligo App + Tomato (MiaoMiao) + Tomato + Empfange Blutzucker-Werte von der Tomato-App (MiaoMiao-Geräte) + Aidex + Erhalte BG-Werte von GlucoRx Aidex CGMS. + BZ Upload Einstellungen + diff --git a/plugins/source/src/main/res/values-el-rGR/strings.xml b/plugins/source/src/main/res/values-el-rGR/strings.xml new file mode 100644 index 0000000000..0458c2f588 --- /dev/null +++ b/plugins/source/src/main/res/values-el-rGR/strings.xml @@ -0,0 +1,15 @@ + + + + Λήψη δεδομένων BG από Nightscout + Eversense App (τροποποιημένη) + Λάβετε τις τιμές BG από την εφαρμογή του Eversense. + Λάβετε τις τιμές BG από το Glimp. + Λάβετε τις τιμές BG από το 600SeriesAndroidUploader. + Poctech + Λάβετε τις τιμές BG από την εφαρμογή Poctech + Tomato (MiaoMiao) + Tomato + Λάβετε τιμές BG από Tomato app (MiaoMiao) + Ανέβασμα ρυθμίσεων BG + diff --git a/plugins/source/src/main/res/values-es-rES/strings.xml b/plugins/source/src/main/res/values-es-rES/strings.xml new file mode 100644 index 0000000000..d1e10c327d --- /dev/null +++ b/plugins/source/src/main/res/values-es-rES/strings.xml @@ -0,0 +1,38 @@ + + + + NSClient BG + NS BG + Recibir los datos de glucosa de Nightscout + xDrip+ + Recibir los valores de glucosa de xDrip+ + Dexcom (BYODA) + BYODA + Recibir los valores de glucosa de la aplicación Dexcom \'Build Your Own Device\' + Eversense App (parcheada) + Recibir los valores de glucosa de la aplicación Eversense parcheada. + Glimp + Recibir valores de glucosa de Glimp. + MM640g + Recibir los valores de glucosa del 600SeriesAndroidUploader. + Poctech + Recibir los valores de glucosa de Poctech + Glunovo + Recibir los valores de glucosa de la aplicación Glunovo + Intelligo + Recibir los valores de glucosa de Intelligo + Tomato (MiaoMiao) + Tomato + Recibir los valores de glucosa de Tomato App (MiaoMiao) + GlucoRx Aidex + Aidex + Recibir los valores de glucosa de GlucoRx Aidex CGMS + Glucosa aleatoria + Generar datos aleatorios de glucosa (sólo modo Demo) + BG + Enviar datos de glucosa a xDrip+ + En xDrip+, selecciona 640G/Eversense como fuente de datos + Ajuste de subida de datos de glucosa + Registro de cambio de sensor en Nightscout + Crear evento \"Cambio de sensor\" en Nightscout automáticamente al iniciar el sensor + diff --git a/plugins/source/src/main/res/values-fr-rFR/strings.xml b/plugins/source/src/main/res/values-fr-rFR/strings.xml new file mode 100644 index 0000000000..bfdf27b888 --- /dev/null +++ b/plugins/source/src/main/res/values-fr-rFR/strings.xml @@ -0,0 +1,38 @@ + + + + Glycémie NSClient + Gly NS + Télécharge les glycémies depuis Nightscout + xDrip+ + Recevoir les glycémies depuis xDrip+. + BYODA + BYODA + Recevoir les valeurs de glycémie de l’application Dexcom patchée (BYODA). + App Eversense (patché) + Recevoir les valeurs de glycémie de l’app Eversense patchée. + Glimp + Recevoir les glycémies depuis Glimp. + Medtronic 640g + Recevoir les glycémies depuis le 600SeriesAndroidUploder. + Poctech + Recevoir les glycémies depuis l\'app Poctech + Glunovo + Recevoir des valeurs de l\'application Glunovo + Intelligo + Recevoir des valeurs depuis l\'application Intelligo + Tomato (MiaoMiao) + Tomato + Recevoir les valeurs de glycémie de l\'application Tomato (appareil MiaoMiao) + GlucoRx Aidex + Aidex + Recevoir les valeurs de glycémie du MGC GlucoRx Aidex. + Gly Aléatoire + Générer des glycémies aléatoires (mode démo uniquement) + Gly + Transmettre les Gly vers xDrip+ + Dans xDrip+ veuillez séléctionner 640g/Eversense comme source de données + Paramètres de téléchargement des glycémies + Enreg. du changement de capteur sur NS + Créer automatiquement un événement \"Changement de capteur\" dans NS au démarrage du capteur + diff --git a/plugins/source/src/main/res/values-ga-rIE/strings.xml b/plugins/source/src/main/res/values-ga-rIE/strings.xml new file mode 100644 index 0000000000..ffb3c50b04 --- /dev/null +++ b/plugins/source/src/main/res/values-ga-rIE/strings.xml @@ -0,0 +1,11 @@ + + + + Sonraí a íoslódáil ó Nightscout + xDrip+ + Luachanna BG a fháil ó xDrip+. + Luachanna BG a fháil ón 600SeriesAndroidUploader. + Poctech + Tomato (MiaoMiao) + Tomato + diff --git a/plugins/source/src/main/res/values-hr-rHR/strings.xml b/plugins/source/src/main/res/values-hr-rHR/strings.xml new file mode 100644 index 0000000000..a2ed58684d --- /dev/null +++ b/plugins/source/src/main/res/values-hr-rHR/strings.xml @@ -0,0 +1,13 @@ + + + + Preuzima podatke o GUK-u s Nightscout-a + Preuzima podatke o GUK-a s xDrip+. + Primajte vrijednosti GUK-a iz zakrpane aplikacije Eversense. + Primajte vrijednosti GUK-a od Glimpa. + Primajte vrijednosti glukoze u krvi od 600SeriesAndroidUploader. + Intelligo + Primite vrijednosti iz aplikacije Intelligo + Aidex + Primite vrijednosti GK od GlucoRx Aidex CGMS. + diff --git a/plugins/source/src/main/res/values-hu-rHU/strings.xml b/plugins/source/src/main/res/values-hu-rHU/strings.xml new file mode 100644 index 0000000000..ec1117256e --- /dev/null +++ b/plugins/source/src/main/res/values-hu-rHU/strings.xml @@ -0,0 +1,7 @@ + + + + Poctech + Tomato (MiaoMiao) + Tomato + diff --git a/plugins/source/src/main/res/values-it-rIT/strings.xml b/plugins/source/src/main/res/values-it-rIT/strings.xml new file mode 100644 index 0000000000..2a8e8702d9 --- /dev/null +++ b/plugins/source/src/main/res/values-it-rIT/strings.xml @@ -0,0 +1,38 @@ + + + + BG NSClient + BG NS + Scarica dati glicemia da Nightscout + xDrip+ + Ricevi valori glicemia da xDrip+. + BYODA + BYODA + Ricevi valori glicemia dall\'app Dexcom ottenuta con \'Build Your Own Dexcom App\'. + Eversense app (modificata) + Ricevi valori glicemia dall\'app Eversense modificata. + Glimp + Ricevi valori glicemia da Glimp. + MM640g + Ricevi valori glicemia da 600SeriesAndroidUploader. + Poctech + Ricevi valori glicemia da app Poctech + Glunovo + Ricevi valori glicemia da app Glunovo + Intelligo + Ricevi valori da app Intelligo + Tomato (MiaoMiao) + Tomato + Ricevi valori glicemia da app Tomato (dispositivo MiaoMiao) + GlucoRx Aidex + GlucoRx Aidex + Ricevi valori glicemia da CGM GlucoRx Aidex. + BG casuale + Genera dati glicemia casuali (solo modalità demo) + BG + Invia dati BG a xDrip+ + In xDrip+ seleziona origine dati 640g/Eversense + Impostazioni caricamento BG + Registra cambio sensore in NS + Crea evento \"Cambio Sensore\" in NS all\'avvio del sensore + diff --git a/plugins/source/src/main/res/values-iw-rIL/strings.xml b/plugins/source/src/main/res/values-iw-rIL/strings.xml new file mode 100644 index 0000000000..88ad6ce57c --- /dev/null +++ b/plugins/source/src/main/res/values-iw-rIL/strings.xml @@ -0,0 +1,26 @@ + + + + הורדת ערכי סוכר בדם מ-Nightscout + xDrip+ + קבלת ערכי סוכר מ-xDrip. + BYODA + BYODA + השתמש בנתוני הסוכר מאפליקציית \"בנה לעצמך דקסקום\" (BYODA). + אפליקלציית Eversense (עם פאץ\') + קבלת ערכי רמת סוכר מאפליקציית Eversense עם פאץ\'. + קבלת ערכי סוכר בדם מאפליקציית Glimp. + קבלת ערכי סוכר בדם מ-600SeriesAndroidUploader. + Poctech + קבלת ערכי סוכר מיישום Poctech + Glunovo + קבלת ערכי סוכר מיישום Glunovo + Intelligo + קבלת ערכי סוכר מיישום Intelligo + Tomato (MiaoMiao) + Tomato + קבלת ערכי סוכר מאפליקציית Tomato (התקן MiaoMiao) + Aidex + קבלת נתוני סוכר מחיישני GlucoRx Aidex. + הגדרות העלאת ערכי סוכר בדם + diff --git a/plugins/source/src/main/res/values-ja-rJP/strings.xml b/plugins/source/src/main/res/values-ja-rJP/strings.xml new file mode 100644 index 0000000000..c1e70718e3 --- /dev/null +++ b/plugins/source/src/main/res/values-ja-rJP/strings.xml @@ -0,0 +1,4 @@ + + + + diff --git a/plugins/source/src/main/res/values-ko-rKR/strings.xml b/plugins/source/src/main/res/values-ko-rKR/strings.xml new file mode 100644 index 0000000000..d15c2e5f53 --- /dev/null +++ b/plugins/source/src/main/res/values-ko-rKR/strings.xml @@ -0,0 +1,17 @@ + + + + Nightscout에서 다운로드하여 혈당값 받기 + xDrip+ + xDrip+에서 혈당값 받기 + Eversense 앱(패치버전) + 패치된 Eversense 앱에서 혈당값 받기 + Glimp에서 혈당값 받기 + 600SeriesAndroidUploader에서 혈당값 받기 + Poctech + Poctech 앱에서 혈당값 받기 + Tomato (MiaoMiao) + Tomato + 혈당값이 Tomato앱(MiaoMaio장치) 으로부터 수신되었습니다. + 혈당 업로드 설정 + diff --git a/plugins/source/src/main/res/values-lt-rLT/strings.xml b/plugins/source/src/main/res/values-lt-rLT/strings.xml new file mode 100644 index 0000000000..049e5b41b2 --- /dev/null +++ b/plugins/source/src/main/res/values-lt-rLT/strings.xml @@ -0,0 +1,27 @@ + + + + Gauti kraujo gliukozės vertes iš Nightscout + xDrip+ + Gauti kraujo gliukozės reikšmes iš xDrip+. + BYODA + BYODA + Gauti kraujo gliukozės reikšmes iš \'Build Your Own Dexcom App\'. + Eversense programėlė (modifikuota) + Gauti kraujo gliukozės vertes iš modifikuotos Eversense programėlės. + Gauti kraujo gliukozės vertes iš Glimp. + Gauti kraujo gliukozės vertes iš 600SeriesAndroidUploader. + Poctech + Gauti KG vertes iš Poctech programėlės + Glunovo + Gauti KG reikšmes iš Glunovo programos + Intelligo + Gauti KG reikšmes iš Intelligo programos + Tomato (MiaoMiao) + Tomato + Gauti KG vertes iš Tomato programėlės (MiaoMiao) + GlucoRx Aidex + Aidex + Gauti KG reikšmes iš GlucoRx Aidex CGMS programos. + KG duomenų perdavimo nustatymai + diff --git a/plugins/source/src/main/res/values-nl-rNL/strings.xml b/plugins/source/src/main/res/values-nl-rNL/strings.xml new file mode 100644 index 0000000000..b798634790 --- /dev/null +++ b/plugins/source/src/main/res/values-nl-rNL/strings.xml @@ -0,0 +1,31 @@ + + + + NSClient BG + NS BG + Download BG waardes van Nightscout + xDrip+ + Ontvang BG waardes van xDrip+. + BYODA + BYODA + Ontvang BG waarden van de \'Build Your Own Dexcom App\' (BYODA). + Eversense App (aangepast) + Ontvang BG waardes van de aangepaste Eversense app. + Glimp + Ontvang BG waardes van Glimp. + MM640g + Ontvang BG waardes van 600SeriesAndroidUploader. + Poctech + Ontvang BG waardes van Poctech app + Glunovo + Ontvang waardes van Glunovo app + Intelligo + Ontvang waarden van de Intelligo app + Tomato (MiaoMiao) + Tomato + Ontvang BG waardes van Tomato app (MiaoMiao apparaatje) + GlucoRx Aidex + Aidex + Ontvang BG waarden van GlucoRx Aidex CGMS. + BG upload instellingen + diff --git a/plugins/source/src/main/res/values-no-rNO/strings.xml b/plugins/source/src/main/res/values-no-rNO/strings.xml new file mode 100644 index 0000000000..c8bac042bb --- /dev/null +++ b/plugins/source/src/main/res/values-no-rNO/strings.xml @@ -0,0 +1,38 @@ + + + + NSClient BS + NS BS + Last ned BS-verdier fra Nightscout + xDrip+ + Motta BS-verdier fra xDrip+. + BYODA + BYODA + Motta BS verdier fra \'Build Your Own Dexcom App\'. + Eversense App (patched) + Motta BS-verdier fra den modifiserte Eversense-appen. + Glimp + Motta BS-verdier fra Glimp. + MM640G + Motta BS-verdier fra 600SeriesAndroidUploader. + Poctech + Motta BS verdier fra Poctech app + Glunovo + Motta BS verdier fra Glunovo app + Intelligo + Motta BS-verdier fra Intelligo-app + Tomato (MiaoMiao) + Tomato + Motta BS verdier fra Tomato app (MiaoMiao enhet) + GlucoRx Aidex + Aidex + Motta BS verdier fra GlucoRx Aidex CGM. + Vilkårlig BS + Generer vilkårlige BS data (kun demo formål) + BS + Send BS data til xDrip+ + I xDrip+, velg 640G/Eversens som datakilde + Innstillinger for opplasting av BS + Logg sensor bytte til NS + Opprett hendelse \"Sensor bytte\" automatisk i NS ved start av sensoren + diff --git a/plugins/source/src/main/res/values-pl-rPL/strings.xml b/plugins/source/src/main/res/values-pl-rPL/strings.xml new file mode 100644 index 0000000000..38c9cad9c8 --- /dev/null +++ b/plugins/source/src/main/res/values-pl-rPL/strings.xml @@ -0,0 +1,22 @@ + + + + Pobieraj wartości BG z Nightscout + xDrip+ + Pobieraj wartości BG z xDrip+. + Dexcom Patched + DEX.PATCH. + Pobieraj glikemię ze spatchowanej aplikacji Dexcom. + Apka Eversense (spatchowana) + Pobieraj wartości BG ze spatchowanej aplikacji Eversense. + Pobieraj wartości BG z Glimp. + Pobieraj wartości BG z uploadera pomp serii 600. + Poctech + Odczytuj wartości BG z aplikacji Poctech + Glunovo + Otrzymuj wartości z aplikacji Glunovo + Tomato (MiaoMiao) + Tomato + Otrzymuj poziomy cukru (BG) z Apki Tomato) (urządzenie MiaoMiao) + Ustawienia wysyłania wartości BG (poziomów cukru) + diff --git a/plugins/source/src/main/res/values-pt-rBR/strings.xml b/plugins/source/src/main/res/values-pt-rBR/strings.xml new file mode 100644 index 0000000000..6766e32d0e --- /dev/null +++ b/plugins/source/src/main/res/values-pt-rBR/strings.xml @@ -0,0 +1,26 @@ + + + + Downloads de dados de Glicose do Nightscout + xDrip+ + Receber valores de glicose do xDrip+. + BYODA + BYODA + Receber valores de glicemia do \'Build Your Own Dexcom App\'. + Aplicação Eversense (com patch) + Receber valores de Glicose da aplicação Eversense modificada. + Receber valores BG do Glimp. + Receber valores de Glucose do 600SeriesAndroidUploader. + Poctech + Receber valores Glucose da app Poctech + Glunovo + Receber valores GLIC do aplicativo Glunovo + Intelligo + Receber valores da app Intelligo + Tomato (MiaoMiao) + Tomato + Receber valores de Glicose da aplicação Tomato (dispositivo MiaoMiao) + Aidex + Receber valores BG do GlucoRx Aidex CGMS. + Configurações de upload de BG + diff --git a/plugins/source/src/main/res/values-pt-rPT/strings.xml b/plugins/source/src/main/res/values-pt-rPT/strings.xml new file mode 100644 index 0000000000..072a4fa9b3 --- /dev/null +++ b/plugins/source/src/main/res/values-pt-rPT/strings.xml @@ -0,0 +1,22 @@ + + + + Descarrega dados Glicose do Nightscout + xDrip+ + Receber valores Glicose do xDrip+. + BYODA + BYODA + Receber valores de glicemia do aplicativo BYODA. + Aplicação Eversense (com patch) + Receber valores Glicose da aplicação Eversense modificada. + Receber valores Glicose do Glimp. + Receber valores Glicose do 600SeriesAndroidUploader. + Poctech + Receber valores Glucose da app Poctech + Glunovo + Receber valores do aplicativo Glunovo + Tomato (MiaoMiao) + Tomato + Receber valores de Glicose da app Tomato (dispositivo MiaoMiao) + Definições de Envio da Glicose + diff --git a/plugins/source/src/main/res/values-ro-rRO/strings.xml b/plugins/source/src/main/res/values-ro-rRO/strings.xml new file mode 100644 index 0000000000..a0be463419 --- /dev/null +++ b/plugins/source/src/main/res/values-ro-rRO/strings.xml @@ -0,0 +1,22 @@ + + + + Descarcă datele despre glicemii din Nightscout + xDrip+ + Primește valorile glicemiei din xDrip+. + BYODA + BYODA + Primește valori de glicemie de la aplicația Dexcom modificată. + Aplicația Eversense (modificată) + Primește valorile glicemiei din aplicația Eversense modificată. + Primește valorile glicemiei din aplicația Glimp. + Primește valorile glicemiei din aplicația 600SeriesAndroidUploader (Medtronic). + Poctech + Citire a valorii glicemiei din aplicația Poctech + Glunovo + Primiți glicemii de la aplicația Glunovo + Tomato (MiaoMiao) + Tomato + Înregistrează valorile glicemiei din aplicația Tomato (dispozitiv MiaoMIao) + Setări înregistrare glicemie + diff --git a/plugins/source/src/main/res/values-ru-rRU/strings.xml b/plugins/source/src/main/res/values-ru-rRU/strings.xml new file mode 100644 index 0000000000..75ade468d5 --- /dev/null +++ b/plugins/source/src/main/res/values-ru-rRU/strings.xml @@ -0,0 +1,33 @@ + + + + Получать данные гликемии с сайта Nightscout + xDrip + + Получать данные гликемии от xDrip+. + Самост собран прилож Dexcom + ССП DEXCOM + Получать данные ГК от \'Самостоятельно собранного приложения Dexcom\'. + Приложение Eversense (пропатченное) + Получать данные гликемии от пропатченного приложения Eversense. + Получать данные гликемии от Glimp. + Получать данные гликемии от 600SeriesAndroidUploader. + Poctech + Получать данные гликемии от приложения Poctech + Приложение Glunovo + Получать данные гликемии от приложения Glunovo + Приложение Intelligo + Получать данные гликемии от приложения Intelligo + Томато (MiaoMiao) + Томато + Получать значения ГК от приложения Tomato (устройство MiaoMiao) + Aidex + Получить значения ГК от GlucoRx Aidex + Случайные значения ГК + Генерировать случайные данные ГК (только демо-режим) + ГК + Отправлять данные СК на xDrip+ + В xDrip + выберите источник данных 640g/Eversense + Параметры загрузки СК + Вносить запись о замене сенсора в NS + Автоматически создать событие \"Замена сенсора\" в NS при запуске сенсора + diff --git a/plugins/source/src/main/res/values-sk-rSK/strings.xml b/plugins/source/src/main/res/values-sk-rSK/strings.xml new file mode 100644 index 0000000000..73aa3d2de6 --- /dev/null +++ b/plugins/source/src/main/res/values-sk-rSK/strings.xml @@ -0,0 +1,38 @@ + + + + Glykémie z NS + NS GL + Získavať hodnoty glykémií z Nightscoutu + xDrip+ + Prijímať hodnoty glykémií z xDrip+. + BYODA + BYODA + Prijímať hodnoty glykémií z upravenej aplikácie Dexcom (BYODA). + Eversense aplikácia (upravená) + Získavať glykémie z upravenej Eversense aplikácie. + Glimp + Získavať hodnoty glykémií z aplikácie Glimp. + MM640g + Získavať hodnoty glykémií z 600SeriesAndroidUploader. + Poctech + Získavať glykémie z aplikácie Poctech + Glunovo + Získavať glykémie z aplikácie Glunovo + Intelligo + Prijímať hodnoty z aplikácie Intelligo + Tomato (MiaoMiao) + Tomato + Prijímať glykémie z aplikácie Tomato (zariadenie MiaoMiao) + GlucoRx Aidex + Aidex + Prijímať hodnoty glykémie zo senzora GlucoRx Aidex. + Náhodná glykémia + Vygeneruj náhodné dáta glykémií (iba Demo režim) + Gly + Odosielať glykémie do xDrip+ + V xDrip+ vyberte zdroj dát 640g/Eversense + Nastavenie nahrávania glykémie + Ulož výmenu senzora do NS + Vytvoriť udalosť \"Výmena senzora\" v NS automaticky pri spustení senzora + diff --git a/plugins/source/src/main/res/values-sr-rCS/strings.xml b/plugins/source/src/main/res/values-sr-rCS/strings.xml new file mode 100644 index 0000000000..236ed456af --- /dev/null +++ b/plugins/source/src/main/res/values-sr-rCS/strings.xml @@ -0,0 +1,10 @@ + + + + Preuzimajte podatke GUK sa Nightscout-a + xDrip+ + Preuzimajte vrijednosti GUK od xDrip+. + Preuzimajte vrednosti GUK iz zakrpljene aplikacije Eversense. + Preuzimajte vrednosti GUK od Glimp-a. + Preuzimajte vrednosti GUK od 600SeriesAndroidUploader-a. + diff --git a/plugins/source/src/main/res/values-sv-rSE/strings.xml b/plugins/source/src/main/res/values-sv-rSE/strings.xml new file mode 100644 index 0000000000..6572f8a262 --- /dev/null +++ b/plugins/source/src/main/res/values-sv-rSE/strings.xml @@ -0,0 +1,23 @@ + + + + Ladda ner BG-data från Nightscout + xDrip+ + Ta emot BG-data från xDrip+. + Patchad Dexcom-app + Dex + Ta emot BG-värden från \"Bygg din egen Dexcom-app\". + Eversense App (modifierad) + Ta emot BG-data från den modifierade +Eversense-appen. + Ta emot BG-data från Glimp + Ta emot BG-data från 600SeriesAndroidUploader + Poctech + Ta emot BG-data från Poctechappen + Glunovo + Ta emot värden från Glunovo-appen + Tomato (MiaoMiao) + Tomato + Ta emot BG-data från tomato app (MiaoMiao-enhet) + Uppladdningsinställningar för BG + diff --git a/plugins/source/src/main/res/values-tr-rTR/strings.xml b/plugins/source/src/main/res/values-tr-rTR/strings.xml new file mode 100644 index 0000000000..0752cdddcf --- /dev/null +++ b/plugins/source/src/main/res/values-tr-rTR/strings.xml @@ -0,0 +1,38 @@ + + + + NSClient KŞ + NS KŞ + Nightscout\'tan KŞ verilerini yükler + xDrip+ + XDrip+\'ten KŞ değerlerini alır. + BYODA + BYODA + \'Kendi Dexcom Uygulamanızı Oluşturun\' uygulamasından KŞ değerlerini alın. + Eversense App (yamalı) + Yamalı Eversense uygulamasından KŞ değerleri alır. + Glimp + Glimp\'ten KŞ değerleri alır. + MM640g + 600SeriesAndroidUploader\'dan KŞ değerleri alır. + Poctech + Poctech uygulamasından KŞ değerlerini alır + Glunovo + Glunovo uygulamasından değerler alır + Intelligo + Intelligo uygulamasından değerler alır + Tomato (MiaoMiao) + Tomato + KŞ değerlerini Tomato uygulamasından (MiaoMiao Cihazından) al + GlucoRx Aidex + Aidex + GlucoRx Aidex CGMS\'den KŞ değerleri alır. + Rastgele KŞ + Rastgele KŞ verileri oluşturun (Yalnızca demo modunda) + + XDrip+\'a KŞ verilerini gönder + xDrip+ içerisinde 640g/Eversense veri kaynağı seç + KŞ yükleme ayarları + Sensör değişimlerini NS\'a kaydet + Sensör başlangıcında otomatik olarak NS\'de \"Sensör Değişimi\" olayı oluştur + diff --git a/plugins/source/src/main/res/values-zh-rCN/strings.xml b/plugins/source/src/main/res/values-zh-rCN/strings.xml new file mode 100644 index 0000000000..dedac905aa --- /dev/null +++ b/plugins/source/src/main/res/values-zh-rCN/strings.xml @@ -0,0 +1,24 @@ + + + + 从 Nightscout 下载 血糖数据 + xDrip+ + 从 xDrip+ 接收血糖值。 + BYODA德康补丁版(构建你自己的德康应用Build Your Own Dexcom App) + BYODA + 从德康补丁版接收血糖数据(Build Your Own Dexcom App)。 + Everyang App (补丁) + 从 Eversense 补丁app接收血糖值。 + 从 Glimp 接收血糖值。 + 从美敦力600Series 的AndroidUploader 接收血糖值。 + Poctech + 从 Poctech app 接收血糖值。 + Glunovo + 从Glunovo应用接收血糖数据。 + 番茄(喵喵) + 番茄 + 从番茄app(喵喵设备) 接收血糖值 + Aidex动泰 + 从GlucoRx Aidex动泰持续葡萄糖监测系统接收血糖值。 + 血糖上传设置 + diff --git a/pump/combov2/src/main/res/values-cs-rCZ/strings.xml b/pump/combov2/src/main/res/values-cs-rCZ/strings.xml index 7bda3a2d82..aaa7b846ff 100644 --- a/pump/combov2/src/main/res/values-cs-rCZ/strings.xml +++ b/pump/combov2/src/main/res/values-cs-rCZ/strings.xml @@ -94,6 +94,9 @@ Pokud po více než ~5 minutách není navázáno žádné spojení:\n\n V zásobníku je málo inzulínu Nastavení dočasného bazálu bylo úspěšné Nastavení dočasného bazálu selhalo + Nastavit emulovaný 100% dočasný bazál + Nechávám emulovaný 100% dočasný bazál dokončit + Ignorování požadavku 100% dočasného bazálu Při úpravě dočasného bazálu došlo k neočekávanému limitu: vyžadováno %1$d%%, dosažen limit %1$d%% Nelze nastavit absolutní dočasný bazál, pokud je bazální dávka nulová Párovat AndroidAPS a Android s momentálně nespárovanou pumpou Accu-Chek Combo diff --git a/pump/combov2/src/main/res/values-es-rES/strings.xml b/pump/combov2/src/main/res/values-es-rES/strings.xml index a2eab6735f..39da6729ad 100644 --- a/pump/combov2/src/main/res/values-es-rES/strings.xml +++ b/pump/combov2/src/main/res/values-es-rES/strings.xml @@ -94,6 +94,9 @@ Si no puedes establecer ninguna conexión después de unos ~5 minutos:\n\n El nivel del reservorio de bomba es bajo Configuración de TBR exitosa Configuración de TBR fallida + Establecer la emulación del TBR al 100% + Permitir finalizar la emulación del 100% del TBR en curso + Ignorar la solicitud del 100% del TBR redundate Límite inesperado encontrado al ajustar TBR: el porcentaje objetivo fue de %1$d%%, alcanzó un límite de %1$d%% No se puede establecer el TBR absoluto si la tasa basal base es cero Emparejar AndroidAPS y Android con una bomba Accu-Chek Combo actualmente no emparejada diff --git a/pump/combov2/src/main/res/values-no-rNO/strings.xml b/pump/combov2/src/main/res/values-no-rNO/strings.xml index 589be98136..e21b0400cf 100644 --- a/pump/combov2/src/main/res/values-no-rNO/strings.xml +++ b/pump/combov2/src/main/res/values-no-rNO/strings.xml @@ -95,6 +95,9 @@ knappene samtidig for å avbryte parringen)\n Pumpens reservoarnivå er lavt Innstilling av TBR var vellykket Innstilling av TBR mislyktes + Angi emulert 100% TBR + Lar aktive emulert 100% TBR få avslutte + Ignorerer redundant 100% TBR forespørsel Uventet begrensning oppsto ved justering av TBR: målprosenten var %1$d%%, nådde grense på %1$d%% Kan ikke sette absolutt TBR hvis basalraten er null Sammenkoble AndroidAPS og Android med en ikke-tilkoblet Accu-Chek Combo pumpe diff --git a/pump/virtual/src/main/res/values-af-rZA/strings.xml b/pump/virtual/src/main/res/values-af-rZA/strings.xml new file mode 100644 index 0000000000..accee86fc9 --- /dev/null +++ b/pump/virtual/src/main/res/values-af-rZA/strings.xml @@ -0,0 +1,6 @@ + + + + Pomp integrasie vir pompe wat nog nie enige drywer het nie (oop lus) + Virtuele pomp instellings + diff --git a/pump/virtual/src/main/res/values-bg-rBG/strings.xml b/pump/virtual/src/main/res/values-bg-rBG/strings.xml new file mode 100644 index 0000000000..c8ccd9ec77 --- /dev/null +++ b/pump/virtual/src/main/res/values-bg-rBG/strings.xml @@ -0,0 +1,6 @@ + + + + За помпи, който все още не работят с AndroidAPS(Open Loop) + Настойки Виртуална Помпа + diff --git a/pump/virtual/src/main/res/values-ca-rES/strings.xml b/pump/virtual/src/main/res/values-ca-rES/strings.xml new file mode 100644 index 0000000000..18af45c7b1 --- /dev/null +++ b/pump/virtual/src/main/res/values-ca-rES/strings.xml @@ -0,0 +1,6 @@ + + + + Integració de bombes d\'insulina per les quals encara no existeix driver/controlador (Llaç obert) + Configuració bomba virtual + diff --git a/pump/virtual/src/main/res/values-cs-rCZ/strings.xml b/pump/virtual/src/main/res/values-cs-rCZ/strings.xml new file mode 100644 index 0000000000..3619831597 --- /dev/null +++ b/pump/virtual/src/main/res/values-cs-rCZ/strings.xml @@ -0,0 +1,11 @@ + + + + Typ virtuální pumpy + Definice pumpy + Bolus: Krok =%1$s\nProdl. bolus: [Krok=%2$s, Délka=%3$smin-%4$sh]\nBazál: Krok=%5$s\nDoč. bazál: %6$s (%7$s), Délka=%8$smin-%9$sh\n%10$s + VPUM + Ovladač pumpy pro uživatele bez podporované pumpy (Otevřená smyčka) + VIRTUÁLNÍ PUMPA + Nastavení virtuální pumpy + diff --git a/pump/virtual/src/main/res/values-da-rDK/strings.xml b/pump/virtual/src/main/res/values-da-rDK/strings.xml new file mode 100644 index 0000000000..6518adaca0 --- /dev/null +++ b/pump/virtual/src/main/res/values-da-rDK/strings.xml @@ -0,0 +1,6 @@ + + + + Pumpeintegration til pumper, som endnu ikke har nogen driver (Åbent Loop) + Indstillinger for virtuel pumpe + diff --git a/pump/virtual/src/main/res/values-de-rDE/strings.xml b/pump/virtual/src/main/res/values-de-rDE/strings.xml new file mode 100644 index 0000000000..b80d97c397 --- /dev/null +++ b/pump/virtual/src/main/res/values-de-rDE/strings.xml @@ -0,0 +1,6 @@ + + + + Pumpenintegration für Pumpen, die noch nicht über einen Treiber verfügen (Open Loop) + Einstellungen der virtuellen Pumpe + diff --git a/pump/virtual/src/main/res/values-el-rGR/strings.xml b/pump/virtual/src/main/res/values-el-rGR/strings.xml new file mode 100644 index 0000000000..5c2408a953 --- /dev/null +++ b/pump/virtual/src/main/res/values-el-rGR/strings.xml @@ -0,0 +1,6 @@ + + + + Ολοκλήρωση αντλίας για αντλίες που δεν έχουν κανέναν οδηγό ακόμα (Ανοιχτό Κύκλωμα) + Ρυθμίσεις Εικονικής αντλίας + diff --git a/pump/virtual/src/main/res/values-es-rES/strings.xml b/pump/virtual/src/main/res/values-es-rES/strings.xml new file mode 100644 index 0000000000..e4a2c05fd9 --- /dev/null +++ b/pump/virtual/src/main/res/values-es-rES/strings.xml @@ -0,0 +1,10 @@ + + + + Definición de la bomba + Bolo: Paso =%1$s\nBolo Extendido: [paso =%2$s, Duración =%3$smin -%4$sh] \nBasal: Paso =%5$s\nTBR: %6$s ( %7$s), Duración =%8$sMin -%9$sh\n%10$s + BOMBAV + Integración de bombas de insulina que aún no tienen ningún controlador disponible (lazo abierto) + BOMBA VIRTUAL + Ajustes de bomba virtual + diff --git a/pump/virtual/src/main/res/values-fr-rFR/strings.xml b/pump/virtual/src/main/res/values-fr-rFR/strings.xml new file mode 100644 index 0000000000..a4d939ede6 --- /dev/null +++ b/pump/virtual/src/main/res/values-fr-rFR/strings.xml @@ -0,0 +1,10 @@ + + + + Définition de pompe + Bolus : Étape =%1$s\nExtended Bolus : [Étape =%2$s, Durée =%3$smin -%4$sh]\nBasal : Étape =%5$s\nTBR : %6$s (par %7$s), Durée =%8$smin -%9$sh\n%10$s + POMPEV + Intégration pour les pompes qui n’ont pas encore de pilote (Boucle Ouverte) + POMPE VIRTUELLE + Paramètres pompe virtuelle + diff --git a/pump/virtual/src/main/res/values-ga-rIE/strings.xml b/pump/virtual/src/main/res/values-ga-rIE/strings.xml new file mode 100644 index 0000000000..5f1fadd4ab --- /dev/null +++ b/pump/virtual/src/main/res/values-ga-rIE/strings.xml @@ -0,0 +1,4 @@ + + + + diff --git a/pump/virtual/src/main/res/values-hr-rHR/strings.xml b/pump/virtual/src/main/res/values-hr-rHR/strings.xml new file mode 100644 index 0000000000..aaefd79c4e --- /dev/null +++ b/pump/virtual/src/main/res/values-hr-rHR/strings.xml @@ -0,0 +1,9 @@ + + + + Definicija pumpe + Bolus: korak=%1$s\nProduženi bolus: [korak=%2$s, trajanje=%3$smin-%4$sh]\nBazal: korak=%5$s\nTBR: %6$s (do %7$s), Trajanje=%8$smin-%9$sh\n%10$s + VPUMP + Integracija pumpe za pumpe koje još nemaju upravljački program (otvorena petlja) + Postavke virtualne pumpe + diff --git a/pump/virtual/src/main/res/values-hu-rHU/strings.xml b/pump/virtual/src/main/res/values-hu-rHU/strings.xml new file mode 100644 index 0000000000..5f1fadd4ab --- /dev/null +++ b/pump/virtual/src/main/res/values-hu-rHU/strings.xml @@ -0,0 +1,4 @@ + + + + diff --git a/pump/virtual/src/main/res/values-it-rIT/strings.xml b/pump/virtual/src/main/res/values-it-rIT/strings.xml new file mode 100644 index 0000000000..a3d23e34a6 --- /dev/null +++ b/pump/virtual/src/main/res/values-it-rIT/strings.xml @@ -0,0 +1,10 @@ + + + + Definizione micro + Bolo: Step=%1$s\nBolo Esteso: [Step=%2$s, Durata=%3$smin-%4$sh]\nBasale: Step=%5$s\nTBR: %6$s (di %7$s), Durata=%8$smin-%9$sh\n%10$s + MICROV + Per microinfusori che non hanno ancora alcun driver (Loop aperto) + MICRO VIRTUALE + Impostazioni micro virtuale + diff --git a/pump/virtual/src/main/res/values-iw-rIL/strings.xml b/pump/virtual/src/main/res/values-iw-rIL/strings.xml new file mode 100644 index 0000000000..6ca6170d2b --- /dev/null +++ b/pump/virtual/src/main/res/values-iw-rIL/strings.xml @@ -0,0 +1,6 @@ + + + + שימוש במשאבות אשר עדיין אין להם מנהל התקן כלשהו (לולאה פתוחה) + הגדרות משאבה וירטואלית + diff --git a/pump/virtual/src/main/res/values-ja-rJP/strings.xml b/pump/virtual/src/main/res/values-ja-rJP/strings.xml new file mode 100644 index 0000000000..5f1fadd4ab --- /dev/null +++ b/pump/virtual/src/main/res/values-ja-rJP/strings.xml @@ -0,0 +1,4 @@ + + + + diff --git a/pump/virtual/src/main/res/values-ko-rKR/strings.xml b/pump/virtual/src/main/res/values-ko-rKR/strings.xml new file mode 100644 index 0000000000..b228a9b77c --- /dev/null +++ b/pump/virtual/src/main/res/values-ko-rKR/strings.xml @@ -0,0 +1,6 @@ + + + + 가상용 펌프를 위한 설정(Open Loop) + 가상펌프 설정 + diff --git a/pump/virtual/src/main/res/values-lt-rLT/strings.xml b/pump/virtual/src/main/res/values-lt-rLT/strings.xml new file mode 100644 index 0000000000..c187457587 --- /dev/null +++ b/pump/virtual/src/main/res/values-lt-rLT/strings.xml @@ -0,0 +1,6 @@ + + + + Integracija pompoms, kurios dar neturi reikalingo valdiklio (Atviras Ciklas) + Virtualios pompos nustatymai + diff --git a/pump/virtual/src/main/res/values-nl-rNL/strings.xml b/pump/virtual/src/main/res/values-nl-rNL/strings.xml new file mode 100644 index 0000000000..7cb784f1c0 --- /dev/null +++ b/pump/virtual/src/main/res/values-nl-rNL/strings.xml @@ -0,0 +1,10 @@ + + + + Pomp definitie + Bolus: Stap=%1$s\nExtended Bolus: [Stap=%2$s, Duur=%3$smin-%4$sh]\nBasaal: Stap=%5$s\nTBR: %6$s (by %7$s), Duur=%8$smin-%9$sh\n%10$s + VPUMP + Pomp integratie voor pompen, waar nog geen driver voor is (Open Loop) + VIRTUELE POMP + Virtuele pomp instellingen + diff --git a/pump/virtual/src/main/res/values-no-rNO/strings.xml b/pump/virtual/src/main/res/values-no-rNO/strings.xml new file mode 100644 index 0000000000..79f054be3d --- /dev/null +++ b/pump/virtual/src/main/res/values-no-rNO/strings.xml @@ -0,0 +1,10 @@ + + + + Pumpedefinisjon + Bolus: Step=%1$s\nForlenget bolus: [Step=%2$s, Varighet=%3$smin-%4$sh]\nBasal: Step=%5$s\nTBR: %6$s (av %7$s), Varighet=%8$smin-%9$sh\n%10$s + VPUMP + Integrasjon mot pumper som ikke støttes av AndroidAPS (åpen loop) + VIRTUELL PUMPE + Innstillinger for virtuell pumpe + diff --git a/pump/virtual/src/main/res/values-pl-rPL/strings.xml b/pump/virtual/src/main/res/values-pl-rPL/strings.xml new file mode 100644 index 0000000000..3032a51b19 --- /dev/null +++ b/pump/virtual/src/main/res/values-pl-rPL/strings.xml @@ -0,0 +1,6 @@ + + + + Integracja z pompami, które nie posiadają jeszcze żadnego sterownika (Open Loop) + Ustawienia pompy wirtualnej + diff --git a/pump/virtual/src/main/res/values-pt-rBR/strings.xml b/pump/virtual/src/main/res/values-pt-rBR/strings.xml new file mode 100644 index 0000000000..f4d49446e2 --- /dev/null +++ b/pump/virtual/src/main/res/values-pt-rBR/strings.xml @@ -0,0 +1,6 @@ + + + + Integração para as bombas que não têm qualquer driver ainda (Open Loop) + Definições da bomba virtual + diff --git a/pump/virtual/src/main/res/values-pt-rPT/strings.xml b/pump/virtual/src/main/res/values-pt-rPT/strings.xml new file mode 100644 index 0000000000..f4d49446e2 --- /dev/null +++ b/pump/virtual/src/main/res/values-pt-rPT/strings.xml @@ -0,0 +1,6 @@ + + + + Integração para as bombas que não têm qualquer driver ainda (Open Loop) + Definições da bomba virtual + diff --git a/pump/virtual/src/main/res/values-ro-rRO/strings.xml b/pump/virtual/src/main/res/values-ro-rRO/strings.xml new file mode 100644 index 0000000000..ce426b54c8 --- /dev/null +++ b/pump/virtual/src/main/res/values-ro-rRO/strings.xml @@ -0,0 +1,6 @@ + + + + Integrare cu pompele ce nu au încă un driver software disponibil (Buclă Deschisă) + Setări pompă virtuală + diff --git a/pump/virtual/src/main/res/values-ru-rRU/strings.xml b/pump/virtual/src/main/res/values-ru-rRU/strings.xml new file mode 100644 index 0000000000..2a771d664b --- /dev/null +++ b/pump/virtual/src/main/res/values-ru-rRU/strings.xml @@ -0,0 +1,6 @@ + + + + Интеграция с помпами, еще не имеющими драйвера (незамкнутый цикл) + настройки вирт помпы + diff --git a/pump/virtual/src/main/res/values-sk-rSK/strings.xml b/pump/virtual/src/main/res/values-sk-rSK/strings.xml new file mode 100644 index 0000000000..70113b0d89 --- /dev/null +++ b/pump/virtual/src/main/res/values-sk-rSK/strings.xml @@ -0,0 +1,10 @@ + + + + Definícia pumpy + Bolus: Krok =%1$s\nPredl. bolus: [Krok=%2$s, Dĺžka=%3$smin-%4$sh]\nBazál: Krok=%5$s\nDoč. bazál: %6$s (%7$s), Dĺžka=%8$smin-%9$sh\n%10$s + VPUM + Ovládač pumpy pre užívateľov bez podporovanej pumpy (Otvorený okruh) + Virtuálna pumpa + Nastavenie virtuálnej pumpy + diff --git a/pump/virtual/src/main/res/values-sr-rCS/strings.xml b/pump/virtual/src/main/res/values-sr-rCS/strings.xml new file mode 100644 index 0000000000..247064374a --- /dev/null +++ b/pump/virtual/src/main/res/values-sr-rCS/strings.xml @@ -0,0 +1,5 @@ + + + + Integracija pumpe za pumpe koje još uvek nemaju upravljački program (Open Loop) + diff --git a/pump/virtual/src/main/res/values-sv-rSE/strings.xml b/pump/virtual/src/main/res/values-sv-rSE/strings.xml new file mode 100644 index 0000000000..ccfd5d374a --- /dev/null +++ b/pump/virtual/src/main/res/values-sv-rSE/strings.xml @@ -0,0 +1,6 @@ + + + + Integration för pumpar som ännu inte stöds av AndroidAPS (Open loop) + Inställningar för Virtuell pump + diff --git a/pump/virtual/src/main/res/values-tr-rTR/strings.xml b/pump/virtual/src/main/res/values-tr-rTR/strings.xml new file mode 100644 index 0000000000..e34fdfe91b --- /dev/null +++ b/pump/virtual/src/main/res/values-tr-rTR/strings.xml @@ -0,0 +1,10 @@ + + + + Pompa tanımı + Bolus: Adım=%1$s\nYayma Bolus: [Adım=%2$s, Süre=%3$sdk-%4$ssa]\nBazal: Adım=%5$s\nGBO: %6$s (ile %7$s), Süre=%8$sdk-%9$ssa\n%10$s + VPOMP + Henüz herhangi bir sürücüye sahip olmayan pompalar için pompa entegrasyonu (Açık Döngü) + SANAL POMPA + Sanal pompa ayarları + diff --git a/pump/virtual/src/main/res/values-zh-rCN/strings.xml b/pump/virtual/src/main/res/values-zh-rCN/strings.xml new file mode 100644 index 0000000000..b3d2f3dbb0 --- /dev/null +++ b/pump/virtual/src/main/res/values-zh-rCN/strings.xml @@ -0,0 +1,6 @@ + + + + 与我们还没有其驱动的泵集成(开环) + 虚拟泵设置 + From 742e02ef3cebf6321a62800d0b7cfe3ed0f349da Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 23:26:15 +0100 Subject: [PATCH 26/48] NSCv3: reading is working --- .../nightscout/sdk/NSAndroidClientImpl.kt | 4 +- .../sdk/interfaces/NSAndroidClient.kt | 1 + .../sdk/localmodel/ApiPermissions.kt | 5 +- .../nightscout/source/BGSourceFragment.kt | 2 +- .../sync/nsclient/services/NSClientService.kt | 2 +- .../sync/nsclientV3/NSClientV3Plugin.kt | 93 +++++++++++++------ .../sync/nsclientV3/workers/LoadBgWorker.kt | 1 + plugins/sync/src/main/res/values/strings.xml | 4 + 8 files changed, 81 insertions(+), 31 deletions(-) diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt index 4a5b3ffa10..019c16a914 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt @@ -58,6 +58,8 @@ class NSAndroidClientImpl( accessToken = accessToken, logging = logging ) + override var lastStatus: Status? = null + private set /* * TODO: how should our result look like? @@ -81,7 +83,7 @@ class NSAndroidClientImpl( } override suspend fun getStatus(): Status = callWrapper(dispatcher) { - api.statusSimple().result!!.toLocal() + api.statusSimple().result!!.toLocal().also { lastStatus = it } } // TODO: return something better than a String diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt index 918f4e8538..e57144a74f 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt @@ -8,6 +8,7 @@ import info.nightscout.sdk.remotemodel.RemoteDeviceStatus interface NSAndroidClient { + val lastStatus: Status? suspend fun getVersion(): String suspend fun getStatus(): Status suspend fun getEntries(): String diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/ApiPermissions.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/ApiPermissions.kt index d78861667a..5eaa012fde 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/ApiPermissions.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/ApiPermissions.kt @@ -7,4 +7,7 @@ data class ApiPermissions( val profile: ApiPermission, val settings: ApiPermission, val treatments: ApiPermission -) +) { + fun isFull() = deviceStatus.full && entries.full && food.full && profile.full && settings.full && treatments.full + fun isRead() = deviceStatus.read && entries.read && food.read && profile.read && settings.read && treatments.read +} diff --git a/plugins/source/src/main/java/info/nightscout/source/BGSourceFragment.kt b/plugins/source/src/main/java/info/nightscout/source/BGSourceFragment.kt index 29808634f9..a308813c4e 100644 --- a/plugins/source/src/main/java/info/nightscout/source/BGSourceFragment.kt +++ b/plugins/source/src/main/java/info/nightscout/source/BGSourceFragment.kt @@ -140,7 +140,7 @@ class BGSourceFragment : DaggerFragment(), MenuProvider { val newDay = position == 0 || !dateUtil.isSameDay(glucoseValue.timestamp, glucoseValues[position - 1].timestamp) holder.binding.date.visibility = newDay.toVisibility() holder.binding.date.text = if (newDay) dateUtil.dateStringRelative(glucoseValue.timestamp, rh) else "" - holder.binding.time.text = dateUtil.timeString(glucoseValue.timestamp) + holder.binding.time.text = dateUtil.timeStringWithSeconds(glucoseValue.timestamp) holder.binding.value.text = glucoseValue.valueToUnitsString(profileFunction.getUnits()) holder.binding.direction.setImageResource(glucoseValue.trendArrow.directionToIcon()) if (position > 0) { diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt index 69f3fdd187..a8cc99ca1b 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt @@ -251,7 +251,7 @@ class NSClientService : DaggerService(), NsClient.NSClientService { } else if (!nsEnabled) { rxBus.send(EventNSClientNewLog("NSCLIENT", "disabled")) rxBus.send(EventNSClientStatus("Disabled")) - } else if (nsURL != "" && (config.isEngineeringMode() || nsURL.lowercase(Locale.getDefault()).startsWith("https://"))) { + } else if (nsURL != "" && (nsURL.lowercase(Locale.getDefault()).startsWith("https://"))) { try { rxBus.send(EventNSClientStatus("Connecting ...")) val opt = IO.Options() diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt index b7486c1bda..73f36a5d97 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt @@ -26,7 +26,6 @@ import info.nightscout.interfaces.utils.HtmlHelper import info.nightscout.plugins.sync.R import info.nightscout.plugins.sync.nsShared.NSClientFragment import info.nightscout.plugins.sync.nsShared.events.EventNSClientResend -import info.nightscout.plugins.sync.nsShared.events.EventNSClientStatus import info.nightscout.plugins.sync.nsShared.events.EventNSClientUpdateGUI import info.nightscout.plugins.sync.nsclient.NsClientReceiverDelegate import info.nightscout.plugins.sync.nsclient.data.AlarmAck @@ -87,21 +86,31 @@ class NSClientV3Plugin @Inject constructor( companion object { val JOB_NAME: String = this::class.java.simpleName + val REFRESH_INTERVAL = T.mins(5).msecs() } private val disposable = CompositeDisposable() + private lateinit var runLoop: Runnable private val handler = Handler(HandlerThread(this::class.simpleName + "Handler").also { it.start() }.looper) private val listLog: MutableList = ArrayList() - override var status = "" + override val status + get() = + when { + sp.getBoolean(R.string.key_ns_client_paused, false) -> rh.gs(info.nightscout.core.ui.R.string.paused) + isAllowed.not() -> blockingReason + nsAndroidClient.lastStatus == null -> rh.gs(R.string.not_connected) + workIsRunning(arrayOf(JOB_NAME)) -> rh.gs(R.string.working) + nsAndroidClient.lastStatus?.apiPermissions?.isFull() == true -> rh.gs(info.nightscout.shared.R.string.connected) + nsAndroidClient.lastStatus?.apiPermissions?.isRead() == true -> rh.gs(R.string.read_only) + else -> rh.gs(info.nightscout.core.ui.R.string.unknown) + } override val nsClientService: NSClientService? = null // service not needed internal lateinit var nsAndroidClient: NSAndroidClient // private lateinit var nsAndroidRxClient: NSAndroidRxClient - val isAllowed: Boolean - get() = nsClientReceiverDelegate.allowed - val blockingReason: String - get() = nsClientReceiverDelegate.blockingReason + val isAllowed get() = nsClientReceiverDelegate.allowed + val blockingReason get() = nsClientReceiverDelegate.blockingReason private val maxAge = T.days(77).msecs() internal var lastModified: LastModified? = null // timestamp of last modification for every collection @@ -133,31 +142,24 @@ class NSClientV3Plugin @Inject constructor( lastFetched.collections.profile = max(dateUtil.now() - maxAge, lastFetched.collections.profile) lastFetched.collections.devicestatus = max(dateUtil.now() - maxAge, lastFetched.collections.devicestatus) - nsAndroidClient = NSAndroidClientImpl( - baseUrl = sp.getString(info.nightscout.core.utils.R.string.key_nsclientinternal_url, "").lowercase().replace("https://", ""), - accessToken = sp.getString(R.string.key_ns_client_token, ""), - context = context, - logging = true - ) + setClient() nsClientReceiverDelegate.grabReceiversState() - disposable += rxBus - .toObservable(EventNSClientStatus::class.java) - .observeOn(aapsSchedulers.io) - .subscribe({ event -> - status = event.getStatus(context) - rxBus.send(EventNSClientUpdateGUI()) - // Pass to setup wizard - rxBus.send(EventSWSyncStatus(event.getStatus(context))) - }, fabricPrivacy::logException) disposable += rxBus .toObservable(EventNetworkChange::class.java) .observeOn(aapsSchedulers.io) - .subscribe({ ev -> nsClientReceiverDelegate.onStatusEvent(ev) }, fabricPrivacy::logException) + .subscribe({ ev -> + nsClientReceiverDelegate.onStatusEvent(ev) + setClient() + }, fabricPrivacy::logException) disposable += rxBus .toObservable(EventPreferenceChange::class.java) .observeOn(aapsSchedulers.io) - .subscribe({ ev -> nsClientReceiverDelegate.onStatusEvent(ev) }, fabricPrivacy::logException) + .subscribe({ ev -> + nsClientReceiverDelegate.onStatusEvent(ev) + if (ev.isChanged(rh.gs(R.string.key_ns_client_token)) || ev.isChanged(rh.gs(info.nightscout.core.utils.R.string.key_nsclientinternal_url))) + setClient() + }, fabricPrivacy::logException) // disposable += rxBus // .toObservable(EventAppExit::class.java) // .observeOn(aapsSchedulers.io) @@ -177,10 +179,18 @@ class NSClientV3Plugin @Inject constructor( .toObservable(EventNSClientResend::class.java) .observeOn(aapsSchedulers.io) .subscribe({ event -> resend(event.reason) }, fabricPrivacy::logException) + + runLoop = Runnable { + executeLoop() + handler.postDelayed(runLoop, REFRESH_INTERVAL) + } + handler.postDelayed(runLoop, REFRESH_INTERVAL) + executeLoop() } override fun onStop() { // context.applicationContext.unbindService(mConnection) + handler.removeCallbacksAndMessages(null) disposable.clear() super.onStop() } @@ -196,8 +206,8 @@ class NSClientV3Plugin @Inject constructor( preferenceFragment.findPreference(rh.gs(R.string.key_ns_receive_tbr_eb))?.isVisible = config.isEngineeringMode() } - override val hasWritePermission: Boolean get() = nsClientService?.hasWriteAuth ?: false - override val connected: Boolean get() = nsClientService?.isConnected ?: false + override val hasWritePermission: Boolean get() = nsAndroidClient.lastStatus?.apiPermissions?.isFull() ?: false + override val connected: Boolean get() = nsAndroidClient.lastStatus != null override fun clearLog() { handler.post { @@ -206,6 +216,16 @@ class NSClientV3Plugin @Inject constructor( } } + private fun setClient() { + nsAndroidClient = NSAndroidClientImpl( + baseUrl = sp.getString(info.nightscout.core.utils.R.string.key_nsclientinternal_url, "").lowercase().replace("https://", ""), + accessToken = sp.getString(R.string.key_ns_client_token, ""), + context = context, + logging = true + ) + rxBus.send(EventSWSyncStatus(status)) + } + private fun addToLog(ev: EventNSClientNewLog) { synchronized(listLog) { listLog.add(ev) @@ -239,8 +259,7 @@ class NSClientV3Plugin @Inject constructor( rxBus.send(EventPreferenceChange(rh.gs(R.string.key_ns_client_paused))) } - override val version: NsClient.Version - get() = NsClient.Version.V3 + override val version: NsClient.Version get() = NsClient.Version.V3 override val address: String get() = sp.getString(info.nightscout.core.utils.R.string.key_nsclientinternal_url, "") @@ -287,6 +306,26 @@ class NSClientV3Plugin @Inject constructor( } fun test() { + executeLoop() + } + + fun scheduleNewExecution() { + val toTime = lastFetched.collections.entries + T.mins(6).plus(T.secs(0)).msecs() + if (toTime > dateUtil.now()) { + handler.postDelayed({ executeLoop() }, toTime - dateUtil.now()) + rxBus.send(EventNSClientNewLog("NEXT", dateUtil.dateAndTimeAndSecondsString(toTime))) + } + } + + private fun executeLoop() { + if (sp.getBoolean(R.string.key_ns_client_paused, false)) { + rxBus.send(EventNSClientNewLog("NSCLIENT", "paused")) + return + } + if (!isAllowed) { + rxBus.send(EventNSClientNewLog("NSCLIENT", blockingReason)) + return + } if (workIsRunning(arrayOf(JOB_NAME))) rxBus.send(EventNSClientNewLog("RUN", "Already running")) else { diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadBgWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadBgWorker.kt index 8bccefe53f..99b9cbed8c 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadBgWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadBgWorker.kt @@ -76,6 +76,7 @@ class LoadBgWorker( } else { rxBus.send(EventNSClientNewLog("END", "No new SGVs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastFetched.collections.entries)}")) + nsClientV3Plugin.scheduleNewExecution() // Idea is to run after 5 min after last BG WorkManager.getInstance(context) .beginUniqueWork( NSClientV3Plugin.JOB_NAME, diff --git a/plugins/sync/src/main/res/values/strings.xml b/plugins/sync/src/main/res/values/strings.xml index 666d569463..9d6bdef502 100644 --- a/plugins/sync/src/main/res/values/strings.xml +++ b/plugins/sync/src/main/res/values/strings.xml @@ -143,4 +143,8 @@ Reset start Upload now + Not connected + Read only + Working + \ No newline at end of file From 479ceabe9d064f5a7cb16d9ef93f80ff5fa9567d Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 9 Dec 2022 23:27:04 +0100 Subject: [PATCH 27/48] DanaRS: pairing dialog fix --- .../nightscout/pump/danars/dialogs/PairingProgressDialog.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pump/danars/src/main/java/info/nightscout/pump/danars/dialogs/PairingProgressDialog.kt b/pump/danars/src/main/java/info/nightscout/pump/danars/dialogs/PairingProgressDialog.kt index 8fd988a3df..51d00909eb 100644 --- a/pump/danars/src/main/java/info/nightscout/pump/danars/dialogs/PairingProgressDialog.kt +++ b/pump/danars/src/main/java/info/nightscout/pump/danars/dialogs/PairingProgressDialog.kt @@ -53,7 +53,6 @@ class PairingProgressDialog : DaggerDialogFragment() { dialog?.window?.setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN) isCancelable = false dialog?.setCanceledOnTouchOutside(false) - setViews() return binding.root } @@ -84,6 +83,7 @@ class PairingProgressDialog : DaggerDialogFragment() { _binding?.ok?.visibility = View.VISIBLE } } + setViews() } override fun dismiss() { From 3a29e8d4f29738e306b27666e84874771fcb7318 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sat, 10 Dec 2022 00:15:46 +0100 Subject: [PATCH 28/48] eliminate NSCleintService interface --- .../nightscout/interfaces/sync/NsClient.kt | 8 +-- .../DataSyncSelectorImplementation.kt | 52 +++++++++---------- .../plugins/sync/nsclient/NSClientPlugin.kt | 11 +++- .../sync/nsclient/services/NSClientService.kt | 7 ++- .../sync/nsclientV3/NSClientV3Plugin.kt | 24 ++++++--- 5 files changed, 57 insertions(+), 45 deletions(-) diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt index 9b53c5f59b..6ef90a7c02 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt @@ -11,7 +11,6 @@ interface NsClient : Sync { val version: Version val address: String - val nsClientService: NSClientService? fun pause(newState: Boolean) fun resend(reason: String) @@ -24,9 +23,6 @@ interface NsClient : Sync { fun resetToFullSync() - interface NSClientService { - - fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) - fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) - } + fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) + fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt index cce42329b2..7536a783d9 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt @@ -159,7 +159,7 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new bolus.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd( + activePlugin.activeNsClient?.dbAdd( "treatments", bolus.first.toJson(true, dateUtil), DataSyncSelector.PairBolus(bolus.first, bolus.second.id), @@ -167,7 +167,7 @@ class DataSyncSelectorImplementation @Inject constructor( ) // with nsId = update if it's modified record bolus.first.interfaceIDs.nightscoutId != null && bolus.first.id != bolus.second.id -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", bolus.first.interfaceIDs.nightscoutId, bolus.first.toJson(false, dateUtil), @@ -222,10 +222,10 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new carb.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd("treatments", carb.first.toJson(true, dateUtil), DataSyncSelector.PairCarbs(carb.first, carb.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("treatments", carb.first.toJson(true, dateUtil), DataSyncSelector.PairCarbs(carb.first, carb.second.id), "$startId/$lastDbId") // with nsId = update if it's modified record carb.first.interfaceIDs.nightscoutId != null && carb.first.id != carb.second.id -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", carb.first.interfaceIDs.nightscoutId, carb.first.toJson(false, dateUtil), @@ -280,7 +280,7 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new bolusCalculatorResult.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd( + activePlugin.activeNsClient?.dbAdd( "treatments", bolusCalculatorResult.first.toJson(true, dateUtil, profileFunction), DataSyncSelector.PairBolusCalculatorResult(bolusCalculatorResult.first, bolusCalculatorResult.second.id), @@ -288,7 +288,7 @@ class DataSyncSelectorImplementation @Inject constructor( ) // with nsId = update if it's modified record bolusCalculatorResult.first.interfaceIDs.nightscoutId != null && bolusCalculatorResult.first.id != bolusCalculatorResult.second.id -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", bolusCalculatorResult.first.interfaceIDs.nightscoutId, bolusCalculatorResult.first.toJson(false, dateUtil, profileFunction), DataSyncSelector.PairBolusCalculatorResult(bolusCalculatorResult.first, bolusCalculatorResult.second.id), "$startId/$lastDbId" ) @@ -340,7 +340,7 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new tt.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd( + activePlugin.activeNsClient?.dbAdd( "treatments", tt.first.toJson(true, profileFunction.getUnits(), dateUtil), DataSyncSelector.PairTemporaryTarget(tt.first, tt.second.id), @@ -348,7 +348,7 @@ class DataSyncSelectorImplementation @Inject constructor( ) // existing with nsId = update tt.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", tt.first.interfaceIDs.nightscoutId, tt.first.toJson(false, profileFunction.getUnits(), dateUtil), @@ -403,10 +403,10 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new food.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd("food", food.first.toJson(true), DataSyncSelector.PairFood(food.first, food.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("food", food.first.toJson(true), DataSyncSelector.PairFood(food.first, food.second.id), "$startId/$lastDbId") // with nsId = update food.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "food", food.first.interfaceIDs.nightscoutId, food.first.toJson(false), @@ -462,10 +462,10 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new gv.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd("entries", gv.first.toJson(true, dateUtil), DataSyncSelector.PairGlucoseValue(gv.first, gv.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("entries", gv.first.toJson(true, dateUtil), DataSyncSelector.PairGlucoseValue(gv.first, gv.second.id), "$startId/$lastDbId") // with nsId = update else -> // gv.first.interfaceIDs.nightscoutId != null - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "entries", gv.first.interfaceIDs.nightscoutId, gv.first.toJson(false, dateUtil), @@ -524,10 +524,10 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new te.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd("treatments", te.first.toJson(true, dateUtil), DataSyncSelector.PairTherapyEvent(te.first, te.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("treatments", te.first.toJson(true, dateUtil), DataSyncSelector.PairTherapyEvent(te.first, te.second.id), "$startId/$lastDbId") // nsId = update te.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", te.first.interfaceIDs.nightscoutId, te.first.toJson(false, dateUtil), @@ -567,7 +567,7 @@ class DataSyncSelectorImplementation @Inject constructor( when { // without nsId = create new deviceStatus.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd("devicestatus", deviceStatus.toJson(dateUtil), deviceStatus, "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("devicestatus", deviceStatus.toJson(dateUtil), deviceStatus, "$startId/$lastDbId") // with nsId = ignore deviceStatus.interfaceIDs.nightscoutId != null -> Any() } @@ -620,7 +620,7 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new tb.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd( + activePlugin.activeNsClient?.dbAdd( "treatments", tb.first.toJson(true, profile, dateUtil), DataSyncSelector.PairTemporaryBasal(tb.first, tb.second.id), @@ -628,7 +628,7 @@ class DataSyncSelectorImplementation @Inject constructor( ) // with nsId = update tb.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", tb.first.interfaceIDs.nightscoutId, tb.first.toJson(false, profile, dateUtil), @@ -691,7 +691,7 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new eb.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd( + activePlugin.activeNsClient?.dbAdd( "treatments", eb.first.toJson(true, profile, dateUtil), DataSyncSelector.PairExtendedBolus(eb.first, eb.second.id), @@ -699,7 +699,7 @@ class DataSyncSelectorImplementation @Inject constructor( ) // with nsId = update eb.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", eb.first.interfaceIDs.nightscoutId, eb.first.toJson(false, profile, dateUtil), @@ -759,10 +759,10 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new ps.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd("treatments", ps.first.toJson(true, dateUtil), DataSyncSelector.PairProfileSwitch(ps.first, ps.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("treatments", ps.first.toJson(true, dateUtil), DataSyncSelector.PairProfileSwitch(ps.first, ps.second.id), "$startId/$lastDbId") // with nsId = update ps.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", ps.first.interfaceIDs.nightscoutId, ps.first.toJson(false, dateUtil), @@ -816,7 +816,7 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new ps.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd( + activePlugin.activeNsClient?.dbAdd( "treatments", ps.first.toJson(true, dateUtil), DataSyncSelector.PairEffectiveProfileSwitch(ps.first, ps.second.id), @@ -824,7 +824,7 @@ class DataSyncSelectorImplementation @Inject constructor( ) // with nsId = update ps.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", ps.first.interfaceIDs.nightscoutId, ps.first.toJson(false, dateUtil), @@ -879,10 +879,10 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new oe.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.nsClientService?.dbAdd("treatments", oe.first.toJson(true, dateUtil), DataSyncSelector.PairOfflineEvent(oe.first, oe.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("treatments", oe.first.toJson(true, dateUtil), DataSyncSelector.PairOfflineEvent(oe.first, oe.second.id), "$startId/$lastDbId") // existing with nsId = update oe.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.nsClientService?.dbUpdate( + activePlugin.activeNsClient?.dbUpdate( "treatments", oe.first.interfaceIDs.nightscoutId, oe.first.toJson(false, dateUtil), @@ -905,7 +905,7 @@ class DataSyncSelectorImplementation @Inject constructor( if (lastChange > lastSync) { if (activePlugin.activeProfileSource.profile?.allProfilesValid != true) return val profileJson = activePlugin.activeProfileSource.profile?.data ?: return - activePlugin.activeNsClient?.nsClientService?.dbAdd("profile", profileJson, DataSyncSelector.PairProfileStore(profileJson, dateUtil.now()), "") + activePlugin.activeNsClient?.dbAdd("profile", profileJson, DataSyncSelector.PairProfileStore(profileJson, dateUtil.now()), "") } } } diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt index be820c7839..a6dad603c0 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt @@ -47,6 +47,7 @@ import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP import io.reactivex.rxjava3.disposables.CompositeDisposable import io.reactivex.rxjava3.kotlin.plusAssign +import org.json.JSONObject import javax.inject.Inject import javax.inject.Singleton @@ -81,7 +82,7 @@ class NSClientPlugin @Inject constructor( private val handler = Handler(HandlerThread(this::class.simpleName + "Handler").also { it.start() }.looper) private val listLog: MutableList = ArrayList() override var status = "" - override var nsClientService: NSClientService? = null + var nsClientService: NSClientService? = null val isAllowed: Boolean get() = nsClientReceiverDelegate.allowed val blockingReason: String @@ -235,4 +236,12 @@ class NSClientPlugin @Inject constructor( override fun resetToFullSync() { dataSyncSelector.resetToNextFullSync() } + + override fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) { + nsClientService?.dbAdd(collection, data, originalObject, progress) + } + + override fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) { + nsClientService?.dbUpdate(collection, _id, data, originalObject, progress) + } } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt index a8cc99ca1b..6933b8bfee 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt @@ -25,7 +25,6 @@ import info.nightscout.interfaces.notifications.Notification import info.nightscout.interfaces.nsclient.NSAlarm import info.nightscout.interfaces.nsclient.NSSettingsStatus import info.nightscout.interfaces.sync.DataSyncSelector -import info.nightscout.interfaces.sync.NsClient import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.JsonHelper.safeGetString import info.nightscout.interfaces.utils.JsonHelper.safeGetStringAllowNull @@ -72,7 +71,7 @@ import java.net.URISyntaxException import java.util.Locale import javax.inject.Inject -class NSClientService : DaggerService(), NsClient.NSClientService { +class NSClientService : DaggerService() { @Inject lateinit var injector: HasAndroidInjector @Inject lateinit var aapsLogger: AAPSLogger @@ -598,7 +597,7 @@ class NSClientService : DaggerService(), NsClient.NSClientService { } } - override fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) { + fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) { try { if (_id == null) return if (!isConnected || !hasWriteAuth) return @@ -618,7 +617,7 @@ class NSClientService : DaggerService(), NsClient.NSClientService { } } - override fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) { + fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) { try { if (!isConnected || !hasWriteAuth) return val message = JSONObject() diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt index 73f36a5d97..9cc8242897 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt @@ -53,6 +53,7 @@ import io.reactivex.rxjava3.disposables.CompositeDisposable import io.reactivex.rxjava3.kotlin.plusAssign import kotlinx.serialization.decodeFromString import kotlinx.serialization.json.Json +import org.json.JSONObject import javax.inject.Inject import javax.inject.Singleton import kotlin.math.max @@ -104,7 +105,6 @@ class NSClientV3Plugin @Inject constructor( nsAndroidClient.lastStatus?.apiPermissions?.isRead() == true -> rh.gs(R.string.read_only) else -> rh.gs(info.nightscout.core.ui.R.string.unknown) } - override val nsClientService: NSClientService? = null // service not needed internal lateinit var nsAndroidClient: NSAndroidClient // private lateinit var nsAndroidRxClient: NSAndroidRxClient @@ -251,7 +251,7 @@ class NSClientV3Plugin @Inject constructor( } override fun resend(reason: String) { - nsClientService?.resend(reason) +// nsClientService?.resend(reason) } override fun pause(newState: Boolean) { @@ -269,12 +269,12 @@ class NSClientV3Plugin @Inject constructor( aapsLogger.debug(LTag.NSCLIENT, "Upload disabled. Message dropped") return } - nsClientService?.sendAlarmAck( - AlarmAck().also { ack -> - ack.level = originalAlarm.level() - ack.group = originalAlarm.group() - ack.silenceTime = silenceTimeInMilliseconds - }) + // nsClientService?.sendAlarmAck( + // AlarmAck().also { ack -> + // ack.level = originalAlarm.level() + // ack.group = originalAlarm.group() + // ack.silenceTime = silenceTimeInMilliseconds + // }) } override fun updateLatestBgReceivedIfNewer(latestReceived: Long) { @@ -301,6 +301,14 @@ class NSClientV3Plugin @Inject constructor( storeLastFetched() } + override fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) { + TODO("Not yet implemented") + } + + override fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) { + TODO("Not yet implemented") + } + private fun storeLastFetched() { sp.putString(R.string.key_ns_client_v3_last_modified, Json.encodeToString(LastModified.serializer(), lastFetched)) } From 6ecc1073df70d5476c548487796f4880431db181 Mon Sep 17 00:00:00 2001 From: Carlos Rafael Giani Date: Thu, 8 Dec 2022 19:19:35 +0100 Subject: [PATCH 29/48] comboctl-main: Finish reading profile by pressing BACK to avoid vibration When exiting the basal profile screens by pressing CHECK twice, a vibration happens. This can be avoided by instead pressing BACK until the main screen is reached. Signed-off-by: Carlos Rafael Giani --- .../kotlin/info/nightscout/comboctl/main/Pump.kt | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt b/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt index 745e23276c..9b4ee858ea 100644 --- a/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt +++ b/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt @@ -2826,14 +2826,12 @@ class Pump( } } - // All factors retrieved. Press CHECK once to get back to the total - // basal rate screen, and then CHECK again to return to the main menu. - - rtNavigationContext.shortPressButton(RTNavigationButton.CHECK) - waitUntilScreenAppears(rtNavigationContext, ParsedScreen.BasalRateTotalScreen::class) - - rtNavigationContext.shortPressButton(RTNavigationButton.CHECK) - waitUntilScreenAppears(rtNavigationContext, ParsedScreen.MainScreen::class) + // All factors retrieved. Press BACK repeatedly until we are back at the main menu. + cycleToRTScreen( + rtNavigationContext, + RTNavigationButton.BACK, + ParsedScreen.MainScreen::class + ) getBasalProfileReporter.setCurrentProgressStage(BasicProgressStage.Finished) From e06ecaa7d8c79a043038f89308a3f2b5614094e5 Mon Sep 17 00:00:00 2001 From: Carlos Rafael Giani Date: Sat, 10 Dec 2022 18:49:12 +0100 Subject: [PATCH 30/48] comboctl-android: Remove some obsolete / unnecessary / solved TODOs * device is unpaired while discovery is ongoing" does not happen because discovery only occurs if no device is paired. * Using the second offered BluetoothDevice works reliably on all tested phones so far. * AndroidBluetoothDevice throws a BluetoothException if all of its internal connect attempts fail. Signed-off-by: Carlos Rafael Giani --- .../nightscout/comboctl/android/AndroidBluetoothDevice.kt | 5 +++-- .../comboctl/android/AndroidBluetoothInterface.kt | 7 ------- 2 files changed, 3 insertions(+), 9 deletions(-) diff --git a/pump/combov2/comboctl/src/androidMain/kotlin/info/nightscout/comboctl/android/AndroidBluetoothDevice.kt b/pump/combov2/comboctl/src/androidMain/kotlin/info/nightscout/comboctl/android/AndroidBluetoothDevice.kt index 8f954ec0cb..ae154d22e0 100644 --- a/pump/combov2/comboctl/src/androidMain/kotlin/info/nightscout/comboctl/android/AndroidBluetoothDevice.kt +++ b/pump/combov2/comboctl/src/androidMain/kotlin/info/nightscout/comboctl/android/AndroidBluetoothDevice.kt @@ -67,8 +67,9 @@ class AndroidBluetoothDevice( // just yet (for example because the UI is still shown on the LCD), while // the retryBlocking loop here is in place because the _Android device_ // may not be ready to connect right away. - // TODO: Test and define what happens when all attempts failed. - // The user needs to be informed and given the choice to try again. + // When all attempts fail, retryBlocking() lets the exception pass through. + // That exception is wrapped in BluetoothException, which then needs to be + // handled by the caller. val totalNumAttempts = 5 retryBlocking(numberOfRetries = totalNumAttempts, delayBetweenRetries = 100) { attemptNumber, previousException -> if (abortConnectAttempt) diff --git a/pump/combov2/comboctl/src/androidMain/kotlin/info/nightscout/comboctl/android/AndroidBluetoothInterface.kt b/pump/combov2/comboctl/src/androidMain/kotlin/info/nightscout/comboctl/android/AndroidBluetoothInterface.kt index 3f2ee01dd0..e1dfee66dc 100644 --- a/pump/combov2/comboctl/src/androidMain/kotlin/info/nightscout/comboctl/android/AndroidBluetoothInterface.kt +++ b/pump/combov2/comboctl/src/androidMain/kotlin/info/nightscout/comboctl/android/AndroidBluetoothInterface.kt @@ -381,13 +381,6 @@ class AndroidBluetoothInterface(private val androidContext: Context) : Bluetooth // instance was already processed. This check here instead // verifies if we have seen the same Bluetooth address on // *different* Android Bluetooth device instances. - // TODO: Test how AndroidBluetoothInterface behaves if the - // device is unpaired while discovery is ongoing (manually by - // the user for example). In theory, this should be handled - // properly by the onBondStateChanged function below. - // TODO: This check may not be necessary on all Android - // devices. On some, it seems to also work if we use the - // first offered BluetoothDevice. if (comboctlBtAddress !in previouslyDiscoveredDevices) { previouslyDiscoveredDevices[comboctlBtAddress] = androidBtDevice logger(LogLevel.DEBUG) { From 16a3b74f503266977c426d3b3a83d32dc95d84f6 Mon Sep 17 00:00:00 2001 From: Carlos Rafael Giani Date: Sat, 10 Dec 2022 19:18:30 +0100 Subject: [PATCH 31/48] comboctl-main: Fix getBasalProfile() progress report and screen counting The previous behavior was reading the profile correctly, but the progress report was off by one factor. Also, blinking screens were considered as separate ones, causing the short button press based fallback to kick in unnecessarily often because that blinking screen behavior caused the main long button press based reading loop to miss the last profile factor. Signed-off-by: Carlos Rafael Giani --- .../info/nightscout/comboctl/main/Pump.kt | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt b/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt index 9b4ee858ea..68c7de77eb 100644 --- a/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt +++ b/pump/combov2/comboctl/src/commonMain/kotlin/info/nightscout/comboctl/main/Pump.kt @@ -2743,8 +2743,6 @@ class Pump( ) } - numObservedScreens++ - val factorIndexOnScreen = parsedScreen.beginTime.hour // numUnits null means the basal profile factor @@ -2752,6 +2750,11 @@ class Pump( if (parsedScreen.numUnits == null) return@longPressRTButtonUntil LongPressRTButtonsCommand.ContinuePressingButton + // Increase this _after_ checking for a blinking screen + // to not accidentally count the blinking and non-blinking + // screens as two separate ones. + numObservedScreens++ + // If the factor in the profile is >= 0, // it means it was already read earlier. if (basalProfileFactors[factorIndexOnScreen] >= 0) @@ -2759,14 +2762,16 @@ class Pump( val factor = parsedScreen.numUnits basalProfileFactors[factorIndexOnScreen] = factor - logger(LogLevel.DEBUG) { "Got basal profile factor #$factorIndexOnScreen : $factor" } + + numRetrievedFactors++ + logger(LogLevel.DEBUG) { + "Got basal profile factor #$factorIndexOnScreen : $factor; $numRetrievedFactors factor(s) read and $numObservedScreens screen(s) observed thus far" + } getBasalProfileReporter.setCurrentProgressStage( RTCommandProgressStage.GettingBasalProfile(numRetrievedFactors) ) - numRetrievedFactors++ - return@longPressRTButtonUntil if (numObservedScreens >= NUM_COMBO_BASAL_PROFILE_FACTORS) LongPressRTButtonsCommand.ReleaseButton else @@ -2819,10 +2824,10 @@ class Pump( } } + numRetrievedFactors++ getBasalProfileReporter.setCurrentProgressStage( RTCommandProgressStage.GettingBasalProfile(numRetrievedFactors) ) - numRetrievedFactors++ } } From 3f4527459a6c879a75d5f6d1b091d540c0d1404c Mon Sep 17 00:00:00 2001 From: Carlos Rafael Giani Date: Sat, 10 Dec 2022 20:33:23 +0100 Subject: [PATCH 32/48] combov2: Add documentation and replace previous small note about comboctl Signed-off-by: Carlos Rafael Giani --- pump/combov2/README.md | 153 ++++++++++++++++++++++++++++++ pump/combov2/comboctl-changes.txt | 14 --- 2 files changed, 153 insertions(+), 14 deletions(-) create mode 100644 pump/combov2/README.md delete mode 100644 pump/combov2/comboctl-changes.txt diff --git a/pump/combov2/README.md b/pump/combov2/README.md new file mode 100644 index 0000000000..17727f3561 --- /dev/null +++ b/pump/combov2/README.md @@ -0,0 +1,153 @@ +# Overview over combov2's and ComboCtl's architecture + +ComboCtl is the core driver. It uses Kotlin Multiplatform and is written in a platform agnostic +way. The code is located in `comboctl/`, and is also available in [its own separate repository] +(https://github.com/dv1/ComboCtl). That separate repository is kept in sync with the ComboCtl +copy in AndroidAPS as much as possible, with some notable changes (see below). "combov2" is the +name of the AndroidAPS driver. In short: combov2 = ComboCtl + extra AndroidAPS integration code. + +## Directory structure + +The directory structure of the local ComboCtl itself is: + +* `comboctl/src/commonMain/` : The platform agnostic portion of ComboCtl. The vast majority of + ComboCtl's logic is contained there. +* `comboctl/src/androidMain/` : The Android specific code. This in particular contains + implementations of the Bluetooth interfaces that are defined in `commonMain/`. +* `comboctl/src/jvmTest/` : Unit tests. This subdirectory is called `jvmTest` because in the + ComboCtl repository, there is also a `jvmMain/` subdirectory, and the unit tests are run + with the JVM. + +The AndroidAPS specific portion of the driver is located in `src/`. This connects ComboCtl with +AndroidAPS. In particular, this is where the `ComboV2Plugin` class is located. That's the main +entrypoint for the combov2 driver plugin. + +## Basic description of how ComboCtl communicates with the pump + +ComboCtl uses Kotlin coroutines. It uses [the Default dispatcher](https://kotlinlang. +org/api/kotlinx.coroutines/kotlinx-coroutines-core/kotlinx.coroutines/-dispatchers/-default.html), +with [a limitedParallelism](https://kotlinlang.org/api/kotlinx. +coroutines/kotlinx-coroutines-core/kotlinx.coroutines/-coroutine-dispatcher/limited-parallelism.html) +constraint to prevent actual parallelism, that is, to not let coroutine jobs run on multiple +threads concurrently. Coroutines are used in ComboCtl to greatly simplify the communication steps, +which normally require a number of state machines to be implemented manually. Stackless coroutines +like Kotlin's essentially are automatically generated state machines under the hood, and this is +what they are used for here. Enabling parallelism is not part of such a state machine. Furthermore, +communication with the Combo does not benefit from parallelism. + +The communication code in ComboCtl is split in higher level operations (in its `Pump` class) and +lower level ones (in its `PumpIO` class). `Pump` instantiates `PumpIO` internally, and focuses on +implementing functionality like reading basal profiles, setting TBRs etc. `PumpIO` implements the +building blocks for these higher level operations. In particular, `PumpIO` has an internal +coroutine scope that is used for sending data to the Combo and for running a "heartbeat" loop. +That "heartbeat" is a message that needs to be regularly sent to the Combo (unless other data is +sent to the Combo in time, like a command to press a button). If nothing is sent to a Combo for +some time, it will eventually disconnect. For this reason, that heartbeat loop is necessary. + +PumpIO also contains the code for performing the pump pairing. + +Going further down a level, `TransportLayer` implements the IO code to generate packets for the +Combo and parse packets coming from the Combo. This includes code for authenticating outgoing +packets and for checking incoming ones. `TransportLayer` also contains the `IO` subclass, which +actually transfers packets to and receives data from the Combo. + +One important detail to keep in mind about the `IO` class is that it enforces a packet send +interval of 200 ms. That is: The time between packet transmission is never shorter than 200 ms +(it is OK to be longer). The interval is important, because the Combo has a ring buffer for the +packet it receives, and transmitting packets to the Combo too quickly causes an overflow and a +subsequent error in the Combo, which then terminates the connection. + +The Combo can run in three modes. The first one is the "service" mode, which is only briefly +used for setting up the connection. Immediately after the connection is established, the pump +continues in the "command" or "remote terminal" (abbr. "RT") mode. The "command" mode is what the +remote control of the Combo uses for its direct commands (that is, delivering bolus and retrieving +the latest changes / activities from the history). The "remote terminal" mode replicates the LCD +on the pump itself along with the 4 Combo buttons. + +Only a few operations are possible in the command mode. In particular, the driver uses the bolus +delivery command from the command mode, the command to retrieve a history delta, and the command +for getting the pump's current date and time. But everything else (getting basal profile, setting +TBR, getting pump status...) is done in the remote terminal mode, by emulating a user pressing +buttons. This unfortunately means that these operations are performed slowly, but there is no +other choice. + +## Details about long-pressing RT buttons + +As part of operations like reading the pump's profile, an emulated long RT button press is sometimes +used. Such long presses cause more rapid changes compared to multiple short button presses. A +button press is "long" when the emulated user "holds down" the button, while a short button press +equals pressing and immediately releasing the emulated button. + +The greater speed of long button presses comes with a drawback though: "Overshoots" can happen. For +example, if long button pressing is used for adjusting a quantity on screen, then the quantity may +still get incremented/decremented after the emulated user "released" the button. It is therefore +necessary to check the quantity on screen, and finetune it with short button presses afterwards +if necessary. + +## Idempotent and non-idempotent high level commands + +A command is _idempotent_ if it can be repeated if the connection to the pump was lost. Most +commands are idempotent. For example, reading the basal profile can be repeated if during the +initial basal profile retrieval the connection was lost (for example because the user walked away +from the pump). After a few attempts to repeat the command, an error is produced (to avoid an +infinite loop). + +Currently, there is only one non-idempotent command: Delivering a bolus. This one _cannot_ be +repeated, otherwise there is a high risk of infusing too much insulin. Instead, in case of a +connection failure, the delivering bolus command fails immediately and is not automatically +attempted again. + +## Automatic datetime adjustments and timezone offset handling + +ComboCtl automatically adjusts the date and time of the Combo. This is done through the RT mode, +since there is no command-mode command to _set_ the current datetime (but there is one for +_getting_ the current datetime). But since the Combo cannot store a timezone offset (it only stores +localtime), the timezone offset that has been used so far is stored in a dedicated field in the +pump state store that ComboCtl uses. DST changes and timezone changes can be tracked properly with +this logic. + +The pump's current datetime is always retrieved (through the command mode) every time a connection +is established to it, and compared to the system's current datetime. If these two differ too much, +the pump's datetime is automatically adjusted. This keeps the pump's datetime in sync. + +## Notes about how TBRs are set + +TBRs are set through the remote terminal mode. The driver assumes that the Combo is configured +to use 15-minute TBR duration steps sizes and a TBR percentage maximum of 500%. There is code +in the driver to detect if the maximum is not set to 500%. If AndroidAPS tries to set a percentage +that is higher than the actually configured maximum, then eventually, an error is reported. + +:warning: The duration step size cannot be detected by the driver. The user _must_ make sure that +the step size is configured to 15 minutes. + +## Pairing with a Combo and the issue with pump queue connection timeouts + +When pairing, the pump queue's internal timeout is likely to be reached. Essentially, the queue +tries to connect to the pump right after the driver was selected in the configuration. But +a connection cannot be established because the pump is not yet paired. + +When the queue attempts to connect to the pump, it "thinks" that if the connect procedure does not +complete after 120 seconds, then the driver must be stuck somehow. The queue then hits a timeout. +The assumption about 120s is correct if the Combo is already paired (a connection should be set up +in far less time than 120s). But if it is currently being paired, the steps involved can take +about 2-3 minutes. + +For this reason, the driver automatically requests a pump update - which connects to the pump - +once pairing is done. + +## Changes to ComboCtl in the local copy + +The code in `comboctl/` is ComboCtl minus the `jvmMain/` code, which contains code for the Linux +platform. This includes C++ glue code to the BlueZ stack. Since none of this is useful to +AndroidAPS, it is better left out, especially since it consists of almost 9000 lines of code. + +Also, the original `comboctl/build.gradle.kts` files is replaced by `comboctl/build.gradle`, which +is much simpler, and builds ComboCtl as a kotlin-android project, not a Kotlin Multiplatform one. +This simplifies integration into AndroidAPS, and avoids multiplatform problems (after all, +Kotlin Multiplatform is still marked as an alpha version feature). + +When updating ComboCtl, it is important to keep these differences in mind. + +Differences between the copy in `comboctl/` and the original ComboCtl code must be kept as little +as possible, and preferably be transferred to the main ComboCtl project. This helps with keeping the +`comboctl/` copy and the main project in sync since transferring changes then is straightforward. diff --git a/pump/combov2/comboctl-changes.txt b/pump/combov2/comboctl-changes.txt deleted file mode 100644 index 728e9ec14c..0000000000 --- a/pump/combov2/comboctl-changes.txt +++ /dev/null @@ -1,14 +0,0 @@ -The code in comboctl/ is ComboCtl minus the jvmMain/ code, which contains code for the Linux platform. -This includes C++ glue code to the BlueZ stack. Since none of this is useful to AndroidAPS, it is better -left out, especially since it consists of almost 9000 lines of code. - -Also, the original comboctl/build.gradle.kts files is replaced by comboctl/build.gradle, which is -much simpler, and builds ComboCtl as a kotlin-android project, not a kotlin-multiplatform one. -This simplifies integration into AndroidAPS, and avoids multiplatform problems (after all, -Kotlin Multiplatform is still marked as an alpha version feature). - -When updating ComboCtl, it is important to keep these differences in mind. - -Differences between the copy in comboctl/ and the original ComboCtl code must be kept as little as -possible, and preferably be transferred to the main ComboCtl project. This helps keep the comboctl/ -copy and the main project in sync. From 1f4d958931a6fa64281d4c701a3bc082cddcc733 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sun, 11 Dec 2022 10:52:27 +0100 Subject: [PATCH 33/48] MDT: fix import after update --- .../info/nightscout/pump/common/sync/PumpSyncStorage.kt | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/pump/pump-common/src/main/java/info/nightscout/pump/common/sync/PumpSyncStorage.kt b/pump/pump-common/src/main/java/info/nightscout/pump/common/sync/PumpSyncStorage.kt index 1de834263e..548fad8665 100644 --- a/pump/pump-common/src/main/java/info/nightscout/pump/common/sync/PumpSyncStorage.kt +++ b/pump/pump-common/src/main/java/info/nightscout/pump/common/sync/PumpSyncStorage.kt @@ -66,8 +66,11 @@ class PumpSyncStorage @Inject constructor( if (jsonData.isNotBlank()) { @Suppress("UNCHECKED_CAST") - pumpSyncStorageTBR = xstream.fromXML(jsonData, MutableList::class.java) as - MutableList + pumpSyncStorageTBR = try { + xstream.fromXML(jsonData, MutableList::class.java) as MutableList + } catch (e: Exception) { + mutableListOf() + } aapsLogger.debug(LTag.PUMP, "Loading Pump Sync Storage: tbrs=${pumpSyncStorageTBR.size}.") aapsLogger.debug(LTag.PUMP, "DD: PumpSyncStorageTBR=$pumpSyncStorageTBR") From 80dd3b094baed0c4a5c18d2d35f036541e0b2dde Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sun, 11 Dec 2022 11:20:47 +0100 Subject: [PATCH 34/48] New Crowdin updates (#2273) * New translations strings.xml (Spanish) * New translations strings.xml (Spanish) * Update source file strings.xml * New translations strings.xml (Czech) * New translations strings.xml (Russian) * New translations strings.xml (Russian) * New translations strings.xml (Russian) * New translations strings.xml (Russian) * New translations strings.xml (Russian) * New translations strings.xml (Russian) * New translations exam.xml (Russian) * New translations strings.xml (Russian) * New translations strings.xml (Russian) * New translations strings.xml (Spanish) * New translations strings.xml (French) * New translations strings.xml (French) * New translations strings.xml (French) * New translations strings.xml (French) * New translations strings.xml (French) * New translations strings.xml (French) * New translations strings.xml (French) * New translations strings.xml (French) * New translations strings.xml (French) * New translations strings.xml (French) * New translations exam.xml (Spanish) * New translations strings.xml (Spanish) * New translations exam.xml (Spanish) * New translations strings.xml (French) * New translations exam.xml (Spanish) * New translations strings.xml (French) * New translations exam.xml (Spanish) * New translations exam.xml (Spanish) --- .../ui/src/main/res/values-fr-rFR/strings.xml | 4 + .../ui/src/main/res/values-ru-rRU/strings.xml | 2 + .../src/main/res/values-fr-rFR/strings.xml | 1 + .../src/main/res/values-ru-rRU/strings.xml | 1 + .../src/main/res/values-es-rES/exam.xml | 201 ++++++------------ .../src/main/res/values-fr-rFR/strings.xml | 17 +- .../src/main/res/values-ru-rRU/exam.xml | 1 + .../src/main/res/values-ru-rRU/strings.xml | 17 ++ .../src/main/res/values-fr-rFR/strings.xml | 10 + .../src/main/res/values-es-rES/strings.xml | 18 +- .../src/main/res/values-fr-rFR/strings.xml | 1 + .../src/main/res/values-ru-rRU/strings.xml | 6 + .../src/main/res/values-cs-rCZ/strings.xml | 3 + .../src/main/res/values-es-rES/strings.xml | 3 + .../src/main/res/values-fr-rFR/strings.xml | 3 + .../src/main/res/values-ru-rRU/strings.xml | 3 + .../src/main/res/values-fr-rFR/strings.xml | 3 + .../src/main/res/values-ru-rRU/strings.xml | 3 + .../src/main/res/values-fr-rFR/strings.xml | 1 + .../src/main/res/values-fr-rFR/strings.xml | 1 + .../src/main/res/values-es-rES/strings.xml | 1 + .../src/main/res/values-fr-rFR/strings.xml | 1 + .../src/main/res/values-ru-rRU/strings.xml | 5 + 23 files changed, 150 insertions(+), 156 deletions(-) diff --git a/core/ui/src/main/res/values-fr-rFR/strings.xml b/core/ui/src/main/res/values-fr-rFR/strings.xml index 4e0d6017eb..f36b0cea34 100644 --- a/core/ui/src/main/res/values-fr-rFR/strings.xml +++ b/core/ui/src/main/res/values-fr-rFR/strings.xml @@ -14,6 +14,7 @@ %1$.2f U/h Pompe non initialisée, profil non défini ! La mise à jour du profil basal a échouée + Bolus de %1$.2f U délivré avec succès Aucun débit basal valide lu depuis la pompe Limiter l’IA %1$.1f U en raison de la %2$s BOUCLE DÉSACTIVÉE PAR RESTRICTIONS @@ -161,6 +162,8 @@ DAI G/I SI + Echec de l\'annulation du basal temporaire + Échec de l\'annulation du Bolus étendu Remontée des informations vers NS Boucle désactivée/suspendue Insuline Active (IA) @@ -246,6 +249,7 @@ %1$dg de glucides requis dans %2$d min. + DTQ cumulée DTQ avec Pondération Exponentielle Basal Bolus diff --git a/core/ui/src/main/res/values-ru-rRU/strings.xml b/core/ui/src/main/res/values-ru-rRU/strings.xml index 90bb6dbab1..518a5d05cd 100644 --- a/core/ui/src/main/res/values-ru-rRU/strings.xml +++ b/core/ui/src/main/res/values-ru-rRU/strings.xml @@ -162,6 +162,8 @@ Время действия инсулина DIA IC углкоэф ГУ/инс ISF (чувствительность к инсулину) + Отмена врем базала не состоялась + Сбой отмены пролонгированного болюса статус передачи данных в NS Отключенный/приостановленный цикл Активный инсулин (IOB) diff --git a/plugins/automation/src/main/res/values-fr-rFR/strings.xml b/plugins/automation/src/main/res/values-fr-rFR/strings.xml index f93499276f..c0efca8739 100644 --- a/plugins/automation/src/main/res/values-fr-rFR/strings.xml +++ b/plugins/automation/src/main/res/values-fr-rFR/strings.xml @@ -127,5 +127,6 @@ S D + Il est temps de manger !\nExécutez l\'assistant Bolus et refaites le calcul. Il est temps de faire le bolus !\nExécutez l\'Assistant et faites de nouveau le calcul. diff --git a/plugins/automation/src/main/res/values-ru-rRU/strings.xml b/plugins/automation/src/main/res/values-ru-rRU/strings.xml index 94eb511d5d..08f70cf702 100644 --- a/plugins/automation/src/main/res/values-ru-rRU/strings.xml +++ b/plugins/automation/src/main/res/values-ru-rRU/strings.xml @@ -127,5 +127,6 @@ Сб Вс + Пора есть!\n Запустите помощник болюса снова для подсчета. Пора дать болюс!\nЗапустите помощник болюса и повторите расчет. diff --git a/plugins/constraints/src/main/res/values-es-rES/exam.xml b/plugins/constraints/src/main/res/values-es-rES/exam.xml index 090ccceaa9..22ddaba8ce 100644 --- a/plugins/constraints/src/main/res/values-es-rES/exam.xml +++ b/plugins/constraints/src/main/res/values-es-rES/exam.xml @@ -1,145 +1,68 @@ - ¿Qué es cierto acerca de DIA? - Duración de la acción de insulina (DIA) - Debes establecer el valor de DIA en tu perfil. - El valor mínimo permitido es 5 horas. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html?#insulin - Si estás satisfecho con el valor de DIA que utilizaste en tu bomba antes de utilizar AAPS y te funcionó bien, no hay necesidad de cambarlo cuando empieces a cerrar el lazo. - Deberías determinar por ti mismo el valor apropiado para DIA. - Objetivo temporal ante Hipoglucemia - ¿Cuál es la razón principal para establecer un objetivo temporal por hipoglucemia? - Para corregir hipoglucemias causadas por ajustes incorrectos de la tasa basal. - Para evitar que AAPS corrija de forma excesiva ante un aumento rápido de la glucosa por tomar carbohidratos rápidos para recuperarse de una hipoglucemia. - Para corregir una hipoglucemia que sucedió como resultando del ejercicio. - Para evitar que la glucosa sanguínea continue bajando si ya hay una tasa basal temporal igual a 0% en funcionamiento. - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html - ¿Qué perfil puede ser usado y configurado estando desconectado? - Tema: Perfil desconectado - El perfil que proviene de Nightscout (NS) puede ser utilizado, pero no configurado. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html#profile - Razones para aplicar \"Desconectar bomba\" en AAPS - ¿Qué se debe hacer al desconectar la bomba? - Esto es innecesario, ya que no se entregará insulina si la bomba está físicamente desconectada. - Evita que AAPS tenga en cuenta la insulina que no se administró cuando la bomba estaba físicamente desconectada - Si la bomba permanece conectada, no se detendrá el suministro de insulina. - Pasará AAPS a modo de lazo abierto + ¿Qué es cierto acerca de DAI? + Duración de la acción de insulina (DAI) + Debes establecer el valor de DAI en tu perfil. + El valor mínimo permitido es de 5 horas. + Si estás satisfecho con el valor de DAI que utilizas en tu bomba antes de utilizar AAPS y te funcionó bien, no hay necesidad de cambiarlo cuando empieces a usar el bucle cerrado. + Deberás determinar por ti mismo el valor apropiado para DAI. + Evita que AAPS considere la insulina que no se suministró cuando la bomba estaba físicamente desconectada + Se activará el modo de bucle abierto en AAPS. https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#other-settings - Ajustes de AAPS - Ajustes de AAPS - ¿Cuáles son las mejores prácticas para hacer copias de seguridad de sus configuraciones? - No necesita exportar sus configuraciones siempre que haga una nota de ellos. - Exporta tu configuración después de completar un objetivo. - Exportar la configuración después de cambiar cualquiera de sus ajustes. - Exportar la configuración una vez finalizada la configuración inicial y haber establecido sus preferencias. - Exportar la configuración localmente usando el menú de mantenimiento. - El archivo de configuración se encuentra en la carpeta Almacenamiento/AAPS/preferencias en el teléfono. - Copie el archivo de preferencias a una ubicación segura fuera de su teléfono (p.e. mediante el uso del alamacenamiento en la nube, conectándose con un cable a una computadora, correo electrónico, etc.) - Si su teléfono está dañado o perdido, hay formas fáciles de recuperar remotamente su configuración sin hacer una copia de seguridad. - https://androidaps.readthedocs.io/en/latest/EN/Usage/ExportImportSettings.html - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#what-emergency-equipment-is-recommended-to-take-with-me - Lecturas CGM ruidosas - ¿Qué se debe hacer si los datos de CGM tienen ruido? - No hacer nada: AAPS se ocupará de ello. - Deshabilita el lazo cerrado para evitar posibles sobredosis o subdosis. - Sustituya los sensores con valores ruidosos o inexactos. - Comprueba que tu aplicación del CGM proporciona datos suavizados. - https://androidaps.readthedocs.io/en/latest/EN/Usage/Smoothing-Blood-Glucose-Data-in-xDrip.html#smoothing-blood-glucose-data - Ejercicio y perfiles - ¿Cómo puede usar perfiles para ayudar mejor al sistema a hacer frente al ejercicio aeróbico? - Haga un cambio de perfil a menos de 100%. - Haga un cambio de perfil a más de 100%. - Dejar el perfil configurado al 100%. - Suspender el lazo - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - Ejercicios y objetivos temporales - ¿Cómo se puede usar objetivos temporales para ayudar mejor al sistema a hacer frente al ejercicio aeróbico? - Establece un objetivo de glucosa en la sangre actividad que comienza un tiempo adecuado antes de comenzar el ejercicio. - Establece un objetivo de glucosa en la sangre actividad después de finalizar el ejercicio. - Deja tu objetivo de glucosa sanguíneo sin cambios. - Espere hasta que la glucosa en sangre caiga por debajo de su objetivo de hipo temp y luego coma 15 g de hidratos de carbono de actividad rápida. - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target - ¿Recibo insulina cuando el lazo está desactivado/suspendido? - Sí, la insulina basal sigue siendo entregada. - No, la administración de la insulina está detenida. - Pruebas basales, ISF, e I:C - ¿Cuándo se deben validar estos valores? - Antes de empezar el lazo - Cuando se tienen valores de glucosa altos o bajos frecuentemente. - Al menos una vez a la semana. - Una vez fijados y validados, estos valores no debrían cambiar a lo largo del tiempo. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#androidaps-settings - Requisitos previos - ¿Qué es esencial para configurar y utilizar AAPS? - Información de perfil validada (Basal, IC, ISF, DIA). - Un ordenador con Android Studio instalado y configurado. - Un teléfono compatible. - Una bomba de insulina compatible, si planeas usar el sistema en modo \"lazo cerrado\". - Nightscout, para tener un registro de los datos y revisar los parámetros de configuración. - Una cuenta de Tidepool. - Una cuenta de Google. - Una cuenta de Github. - Experiencia programando o editando código. - Una bomba MiniMed 670G. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html - Un Smartwatch. - Un MCG soportado. - Requisitos previos - ¿Qué es esencial para configurar y utilizar AAPS? - Parámetros validados para poder configurar un perfil (ISF, I:C ratio, perfil basal, DIA etc.). - Un dispositivo Android compatible (e.j. un móvil, un smartwatch Android compatible o una tablet). - AAPS requiere una conexión a Internet para funcionar en modo lazo cerrado. - Un medidor continuo de glucosa (MCG) y una aplicación capaz de recibir los valores proporcionados por el medidor en el móvil o tablet. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html - Actualizando AAPS - Compruebe todas las respuestas correctas. - Es necesario tener Git instalado y configurado en el ordenador. - Cuando esté disponible una versión más reciente de AAPS, las funciones de las versiones anteriores pueden ser limitadas de forma remota después de una fecha determinada. - Se debe guardar en un lugar seguro la \"keystore\" que se ha empleado y usar la misma\"key\" para futuras actulizaciones. - Nunca actualice si el sistema está funcionando bien. - Si tienes problemas construyendo la aplicación (. apk), puedes instalar el mismo archivo. apk compilado por un amigo. - https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#update-to-a-new-version-or-branch - Solución de problemas - ¿Dónde puedes buscar ayuda con AAPS? - Puede solicitar asesoramiento en el grupo de usuarios de AAPS en Facebook. - Deberías leer (y volver a leer) la documentación de AAPS. - Puedes solicitar asesoramiento y registrar problemas técnicos o indidencias en el grupo de Discord de AAPS. - Debes preguntar a tu endocrino o educador diabetológico. - https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting - https://www.facebook.com/groups/AndroidAPSUsers/ - https://discord.gg/4fQUWHZ4Mw - Plugins de insulina - ¿Qué insulina debes usar con el plugin Ultra-Rapid Oref? - Fiasp® - NovoRapid®/Novolog® - Humalog® - Actrapid®/Humalin R®/\"insulina humana estándar\". - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html#insulin - Plugins de sensibilidad - Compruebe todas las respuestas correctas. - Los plugins de sensibilidad permiten a AAPS ajustarse para cambios temporales o de corta duración en la sensibilidad a la insulina (por ejemplo, cambios hormonales o problemas con la absorción en el sitio de infusión). - Los plugins de sensibilidad sugieren al usuario cambios en la cantidad de insulina basal a suministrar, en el factor de sensibiliad a la insulina (ISF) y en el ratio I:C y pueden ser incorporados al perfil definido. - Registrar el cámbio de cánula reseteará Autosens, dejándolo de nuevo al 100%. - Algunas de las opciones del plugin tienen rangos de tiempo configurables que pueden ser definidos por el usuario. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/es/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens - Error de entrada de Carbohidratos - ¿Qué deberías hacer si has hecho una entrada incorrecta de carbohidratos? - Elimina la entrada incorrecta en los tratamientos e introduce el valor correcto de carbohidratos. - Bolo con insulina usando el menú de llenado de la infusión. - No hacer nada - AAPS realizará los ajustes apropiados. - Bolo con insulina usando el botón de Insulina (bolus) en página general. - Errores de entrega/entrada de insulina - ¿Qué debes hacer si recibiste menos insulina de la que sugiere la historia de la bomba p.ej. debido a una oclusión, una cánula fallida o olvidarse de reponer la bomba después de una ducha? - Elimina los datos de insulina del portal de Nightscout Careportal para eliminarlos del historial de la bomba. - Comparar valores en AAPS con el historial de la bomba (si la bomba lo soporta). - Bolo una proporción de la insulina calculada “perdida” por jeringa/pluma o usando menú de llenado. - No hacer nada y permite que AAPS corrija cualquier resultado de nivel alto de glucosa en sangre. - Carbohidratos activos (COB) - ¿Cómo afecta el cambio del valor ISF al cálculo de COB? - Incrementar el ISF hará que los carbohidratos se absorban más lentamente - Incrementar el ISF hará que los carbohidratos se absorban más rápidamente - Incrementar el ISF no afectará la absorción calculada de carbohidratos + No necesita exportar sus configuraciones siempre que haga las tenga anotadas. + Exportar tu configuración después de completar un objetivo. + Exportar las configuraciones después de cambiar cualquiera de sus ajustes. + Exportar las configuraciones una vez finalizada la configuración inicial y haber establecido sus preferencias. + Copie el archivo de preferencias a una ubicación segura fuera de su teléfono (p.e. mediante el uso del almacenamiento en la nube, conectando su teléfono con un cable a una computadora, correo electrónico, etc.) + Si su teléfono es dañado o perdido, hay formas fáciles de recuperar remotamente su configuración sin hacer una copia de seguridad. + Lecturas CGM con mucha variabilidad + ¿Qué se debe hacer si los datos de CGM tienen mucha variabilidad? + Deshabilitar el bucle cerrado para evitar posibles sobredosis o subdosis. + Sustituya el sensor con valores muy variables o inexactos. + ¿Cómo puede usar los perfiles para mejorar el sistema durante el ejercicio aeróbico? + Cambie el perfil por un valor menor a 100%. + Cambie el perfil por un valor mayor a 100%. + Suspender el bucle. + ¿Cómo se puede usar el objetivo temporal de glucosa para ayudar al sistema durante los ejercicios aeróbicos? + Establezca el objetivo de tipo actividad antes de comenzar el ejercicio, considerando un tiempo razonable antes de la actividad. + Establezca un objetivo de tipo actividad después de finalizar el ejercicio. + Deja tu objetivo de glucosa sin cambios. + Espere hasta que los valores de glucosa se encuentren por debajo del valor definido en el objetivo de tipo hipoglicemia. Luego consuma 15 g de carbohidratos de rápida absorción. + ¿Puedo recibir insulina cuando el bucle está desactivado/suspendido? + Sí, la insulina basal sigue siendo suministrada. + No, la administración de la insulina se detiene. + Pruebas para basales, I:C y FSI + Antes de empezar cualquier bucle. + Cuando los valores de glucosa son muy altos o bajos de manera frecuente. + Una vez establecidos y validados, estos valores no deberían cambiar a lo largo del tiempo. + Información de perfil previamente validada (Basal, IC, FSI, DAI). + Una computadora con Android Studio instalado y configurado. + Una bomba de insulina compatible, si planeas usar el sistema en modo bucle cerrado. + AAPS requiere una conexión a Internet para funcionar con el modo bucle cerrado. + Seleccione todas las respuestas correctas. + Es necesario tener Git instalado y configurado en la computadora. + Cuando esté disponible una versión más reciente de AAPS, las funciones de las versiones anteriores pueden ser limitadas de forma remota después de una fecha especifica. + Se debe guardar en un lugar seguro de su computadora la \"keystore\" (archivo.jks) que se ha empleado previamente y usar la misma \"keystore\" para futuras actualizaciones. + Nunca se debe actualizar AAPS si el sistema está funcionando bien. + Puedes solicitar asesoramiento y registrar problemas técnicos o incidencias en el grupo de Discord de AAPS. + Debes preguntar a tu endocrinólogo o educador en diabetes. + Seleccione todas las respuestas correctas. + Los plugins de sensibilidad sugieren al usuario cambios en la cantidad de insulina basal a suministrar, en el factor de sensibilidad a la insulina (ISF) y en el ratio I:C y pueden ser incorporados al perfil definido. + Registrar el cámbio de cánula reinicia Autosens, volviendo de nuevo al 100%. + Error de ingreso de Carbohidratos + ¿Qué deberías hacer si has cometido un error al ingresar carbohidratos? + Elimina la entrada incorrecta en pestaña de tratamientos e introduce el valor correcto. + Darse un bolo desde el menú de llenado de la infusión. + No hacer nada - AAPS realizará los ajustes necesarios. + Darse un bolo usando el botón de Insulina (bolus) en página general. + Elimina los valores de insulina del portal de Nightscout o Careportal para eliminarlos del historial de la bomba. + Comparar valores en AAPS con el historial de la bomba (si la bomba los registra). + Bolo una proporción de la insulina calculada “perdida” por jeringa/pluma o usando menú de Insulina. + No hacer nada y permite que AAPS corrija cualquier resultado de nivel alto de glucosa. + ¿Cómo afecta el cambio del valor FSI al cálculo de COB? + Incrementar el FSI hará que los carbohidratos se absorban más lentamente + Incrementar el FSI hará que los carbohidratos se absorban más rápidamente + Incrementar el FSI no afectará la absorción calculada de carbohidratos ¿Cómo afecta cambiar los valores de IC a los cálculos de COB? Incrementar el IC hará que los carbohidratos se absorban más lentamente Incrementar el IC hará que los carbohidratos se absorban más rápidamente diff --git a/plugins/constraints/src/main/res/values-fr-rFR/strings.xml b/plugins/constraints/src/main/res/values-fr-rFR/strings.xml index 4e6f7bd219..668de616e0 100644 --- a/plugins/constraints/src/main/res/values-fr-rFR/strings.xml +++ b/plugins/constraints/src/main/res/values-fr-rFR/strings.xml @@ -2,12 +2,27 @@ + Changement d\'heure dans moins de 24 heures + Changement d\'heure dans moins de 3 heures - Boucle fermée désactivée + Boucle désactivée ! Libérez au moins %1$d Mo du stockage interne ! + ancienne version + très ancienne version + Application expirée + Nouvelle version disponible depuis %1$d jours ! Retour à Arrêt Glycémie Basse (AGB) dans %2$d jours, la boucle sera désactivée dans %3$d jours + Nous avons détecté que vous utilisez une version invalide. Boucle désactivée ! + Version %1$s disponible + La version %1$s expire le %2$s + Données recalculées utilisées + Gly trop proche :\n%1$s\n%2$s + recalculé + entrées doubles Données plates. Considérées comme incorrectes + Bolus étendu limité à %1$.1f U à cause de %2$s Limiter les glucides %1$d g à cause de %2$s Pompe n’est pas capable de basals temporaires Mode de Boucle Fermée désactivé dans les préférences @@ -17,7 +32,7 @@ SMB non autorisé en mode boucle ouverte valeur Max dans les préférences limite fixée - Traitements de sécurité + Sécurité des traitements Terminé, félicitations ! Pas encore terminé diff --git a/plugins/constraints/src/main/res/values-ru-rRU/exam.xml b/plugins/constraints/src/main/res/values-ru-rRU/exam.xml index 92a6e8f53b..9d2bed09e7 100644 --- a/plugins/constraints/src/main/res/values-ru-rRU/exam.xml +++ b/plugins/constraints/src/main/res/values-ru-rRU/exam.xml @@ -108,6 +108,7 @@ https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ https://discord.gg/4fQUWHZ4Mw + Модули для инсулинов Какой инсулин следует использовать с модулем Сверхбыстрый Oref? Fiasp® Novoapid ® /Novolog ® diff --git a/plugins/constraints/src/main/res/values-ru-rRU/strings.xml b/plugins/constraints/src/main/res/values-ru-rRU/strings.xml index 332dd41100..844423e9f1 100644 --- a/plugins/constraints/src/main/res/values-ru-rRU/strings.xml +++ b/plugins/constraints/src/main/res/values-ru-rRU/strings.xml @@ -2,11 +2,27 @@ + Переход на летнее/зимнее время через 24 часа или менее + Изменение сезонного времени произошло меньше 3 часов назад-Закрытый цикл выключен + Освободите по крайней мере %1$d MB из внутренней памяти! Цикл остановлен! + старая версия + очень старая версия + Истек срок действия приложения + Новая версия доступна уже %1$d дней! По истечении %2$d дн алгоритм переходит в режим работы только с остановкой при низкой гликемии LGS, замкнутый цикл будет отключен через %3$d дн + Мы обнаружили, что вы используете недопустимую версию. Цикл отключен! + Доступна версия %1$s + Версия: %1$s истекает %2$s + Используются пересчитанные данные + ГК слишком близко:\n%1$s\n%2$s + пересчитано + двойные записи + Неменяющиеся данные. Принимаю за неверные + Ограничиваю пролонгированный болюс до %1$.1f ед. из-за %2$s Ограничение углеводов до %1$d г. из-за %2$s Помпа не рассчитана на подачу временного базала Режим замкнутого цикла отключен в настройках @@ -18,6 +34,7 @@ жесткий предел Безопасность терапии + Завершено, отлично! Не завершено Прошло времени Максимум активного инсулина IOB установлен правильно diff --git a/plugins/insulin/src/main/res/values-fr-rFR/strings.xml b/plugins/insulin/src/main/res/values-fr-rFR/strings.xml index 9c694e762c..3554c0dc9d 100644 --- a/plugins/insulin/src/main/res/values-fr-rFR/strings.xml +++ b/plugins/insulin/src/main/res/values-fr-rFR/strings.xml @@ -1,8 +1,18 @@ + Lyumjev + Réglages pour les insulines Humalog et NovoRapid / NovoLog + Réglages pour l\'insuline Fiasp + Réglages pour l\'insuline Lyumjev + Permet de définir le pic de l’activité de l’insuline et ne doit être utilisé que par les utilisateurs avancés + INS + Délai du pic de la courbe IA + Délai du pic [min] Profil d\'insuline ajustable Oref Insuline à Action Rapide Oref Insuline Ultra Rapide Oref Durée d’Action pour %1$f trop courte - utiliser %2$f à la place ! + Novorapid, Novolog, Humalog + Fiasp diff --git a/plugins/source/src/main/res/values-es-rES/strings.xml b/plugins/source/src/main/res/values-es-rES/strings.xml index d1e10c327d..1af8d15dc1 100644 --- a/plugins/source/src/main/res/values-es-rES/strings.xml +++ b/plugins/source/src/main/res/values-es-rES/strings.xml @@ -1,22 +1,7 @@ - NSClient BG - NS BG - Recibir los datos de glucosa de Nightscout - xDrip+ - Recibir los valores de glucosa de xDrip+ - Dexcom (BYODA) - BYODA - Recibir los valores de glucosa de la aplicación Dexcom \'Build Your Own Device\' - Eversense App (parcheada) - Recibir los valores de glucosa de la aplicación Eversense parcheada. - Glimp - Recibir valores de glucosa de Glimp. - MM640g - Recibir los valores de glucosa del 600SeriesAndroidUploader. - Poctech - Recibir los valores de glucosa de Poctech + Eversense App (parchada) Glunovo Recibir los valores de glucosa de la aplicación Glunovo Intelligo @@ -35,4 +20,5 @@ Ajuste de subida de datos de glucosa Registro de cambio de sensor en Nightscout Crear evento \"Cambio de sensor\" en Nightscout automáticamente al iniciar el sensor + dirección diff --git a/plugins/source/src/main/res/values-fr-rFR/strings.xml b/plugins/source/src/main/res/values-fr-rFR/strings.xml index bfdf27b888..a9e7d5075c 100644 --- a/plugins/source/src/main/res/values-fr-rFR/strings.xml +++ b/plugins/source/src/main/res/values-fr-rFR/strings.xml @@ -35,4 +35,5 @@ Paramètres de téléchargement des glycémies Enreg. du changement de capteur sur NS Créer automatiquement un événement \"Changement de capteur\" dans NS au démarrage du capteur + direction diff --git a/plugins/source/src/main/res/values-ru-rRU/strings.xml b/plugins/source/src/main/res/values-ru-rRU/strings.xml index 75ade468d5..13210be58e 100644 --- a/plugins/source/src/main/res/values-ru-rRU/strings.xml +++ b/plugins/source/src/main/res/values-ru-rRU/strings.xml @@ -1,6 +1,8 @@ + ГК с клиента Nightscout + ГК с NS Получать данные гликемии с сайта Nightscout xDrip + Получать данные гликемии от xDrip+. @@ -9,7 +11,9 @@ Получать данные ГК от \'Самостоятельно собранного приложения Dexcom\'. Приложение Eversense (пропатченное) Получать данные гликемии от пропатченного приложения Eversense. + Glimp Получать данные гликемии от Glimp. + MM640g Получать данные гликемии от 600SeriesAndroidUploader. Poctech Получать данные гликемии от приложения Poctech @@ -20,6 +24,7 @@ Томато (MiaoMiao) Томато Получать значения ГК от приложения Tomato (устройство MiaoMiao) + Aidex GlucoRx Aidex Получить значения ГК от GlucoRx Aidex Случайные значения ГК @@ -30,4 +35,5 @@ Параметры загрузки СК Вносить запись о замене сенсора в NS Автоматически создать событие \"Замена сенсора\" в NS при запуске сенсора + направление diff --git a/plugins/sync/src/main/res/values-cs-rCZ/strings.xml b/plugins/sync/src/main/res/values-cs-rCZ/strings.xml index b1beabbc57..61cc0c4179 100644 --- a/plugins/sync/src/main/res/values-cs-rCZ/strings.xml +++ b/plugins/sync/src/main/res/values-cs-rCZ/strings.xml @@ -97,4 +97,7 @@ Odstranit vše Resetovat start Nahrát nyní + Nepřipojeno + Jen pro čtení + Pracuji diff --git a/plugins/sync/src/main/res/values-es-rES/strings.xml b/plugins/sync/src/main/res/values-es-rES/strings.xml index f1d46065f4..131b6173fc 100644 --- a/plugins/sync/src/main/res/values-es-rES/strings.xml +++ b/plugins/sync/src/main/res/values-es-rES/strings.xml @@ -97,4 +97,7 @@ Eliminar todos Restablecer inicio Subir ahora + No conectado + Sólo lectura + Funcionando diff --git a/plugins/sync/src/main/res/values-fr-rFR/strings.xml b/plugins/sync/src/main/res/values-fr-rFR/strings.xml index 5069f0dc37..de85e5002c 100644 --- a/plugins/sync/src/main/res/values-fr-rFR/strings.xml +++ b/plugins/sync/src/main/res/values-fr-rFR/strings.xml @@ -97,4 +97,7 @@ Supprimer tout Réinitialiser le démarrage Télécharger maintenant + Non connecté + Lecture seule + Opération en cours diff --git a/plugins/sync/src/main/res/values-ru-rRU/strings.xml b/plugins/sync/src/main/res/values-ru-rRU/strings.xml index b67a2c12aa..9fa4e3545d 100644 --- a/plugins/sync/src/main/res/values-ru-rRU/strings.xml +++ b/plugins/sync/src/main/res/values-ru-rRU/strings.xml @@ -97,4 +97,7 @@ Удалить всё Перезапустить старт Выгрузить (передать данные) сейчас + Нет подключения + Только чтение + Обработка diff --git a/pump/combov2/src/main/res/values-fr-rFR/strings.xml b/pump/combov2/src/main/res/values-fr-rFR/strings.xml index d95eac085e..05f6c80633 100644 --- a/pump/combov2/src/main/res/values-fr-rFR/strings.xml +++ b/pump/combov2/src/main/res/values-fr-rFR/strings.xml @@ -85,6 +85,9 @@ Niveau réservoir pompe bas Paramétrage du DBT réussi Échec du réglage du DBT + Définir l\'émulation 100% TBR + Laisser se terminer l\'émulation 100% TBR en cours + Requête 100% DBT redondante ignorée Limite inattendue lors de l’ajustement du DBT: le pourcentage cible de %1$d%%, a dépassé la limite de %1$d%% Impossible de définir le DBT absolu si le débit de basal est zéro Appairer AndroidAPS et Android avec une pompe Accu-Chek Combo non appariée diff --git a/pump/combov2/src/main/res/values-ru-rRU/strings.xml b/pump/combov2/src/main/res/values-ru-rRU/strings.xml index 43227b663f..c75a5f9604 100644 --- a/pump/combov2/src/main/res/values-ru-rRU/strings.xml +++ b/pump/combov2/src/main/res/values-ru-rRU/strings.xml @@ -95,6 +95,9 @@ Низкий уровень инсулина в картридже помпы Настройки TBR выполнены Не удалось установить TBR + Установить эмуляцию. временного базала TBR 100% + Позволить завершиться текущей эмуляции временного базала 100% TBR + Игнорирование избыточного запроса на 100% TBR Непредвиденный предел, встретившийся при настройке TBR: целевой процент составил %1$d%%, а достиг предела %1$d%% Невозможно установить абсолютный TBR, если базовая скорость равна нулю Выполнить сопряжение AndroidAPS и Android с помпой Accu-Chek Combo diff --git a/pump/pump-common/src/main/res/values-fr-rFR/strings.xml b/pump/pump-common/src/main/res/values-fr-rFR/strings.xml index fbb5a624e1..2083618893 100644 --- a/pump/pump-common/src/main/res/values-fr-rFR/strings.xml +++ b/pump/pump-common/src/main/res/values-fr-rFR/strings.xml @@ -5,6 +5,7 @@ Opération PAS ENCORE supportée par la pompe. OK Numéro de série de la pompe + %1$.2f U / %2$.2f U délivrés Non initialisé Initialisé diff --git a/pump/pump-core/src/main/res/values-fr-rFR/strings.xml b/pump/pump-core/src/main/res/values-fr-rFR/strings.xml index cef1881d71..452f916a90 100644 --- a/pump/pump-core/src/main/res/values-fr-rFR/strings.xml +++ b/pump/pump-core/src/main/res/values-fr-rFR/strings.xml @@ -1,6 +1,7 @@ + Jamais contacté En veille Réveil en cours Actif diff --git a/pump/virtual/src/main/res/values-es-rES/strings.xml b/pump/virtual/src/main/res/values-es-rES/strings.xml index e4a2c05fd9..0d7016149a 100644 --- a/pump/virtual/src/main/res/values-es-rES/strings.xml +++ b/pump/virtual/src/main/res/values-es-rES/strings.xml @@ -1,6 +1,7 @@ + Bomba virtual Definición de la bomba Bolo: Paso =%1$s\nBolo Extendido: [paso =%2$s, Duración =%3$smin -%4$sh] \nBasal: Paso =%5$s\nTBR: %6$s ( %7$s), Duración =%8$sMin -%9$sh\n%10$s BOMBAV diff --git a/pump/virtual/src/main/res/values-fr-rFR/strings.xml b/pump/virtual/src/main/res/values-fr-rFR/strings.xml index a4d939ede6..0d1d572148 100644 --- a/pump/virtual/src/main/res/values-fr-rFR/strings.xml +++ b/pump/virtual/src/main/res/values-fr-rFR/strings.xml @@ -1,6 +1,7 @@ + Type de pompe virtuelle Définition de pompe Bolus : Étape =%1$s\nExtended Bolus : [Étape =%2$s, Durée =%3$smin -%4$sh]\nBasal : Étape =%5$s\nTBR : %6$s (par %7$s), Durée =%8$smin -%9$sh\n%10$s POMPEV diff --git a/pump/virtual/src/main/res/values-ru-rRU/strings.xml b/pump/virtual/src/main/res/values-ru-rRU/strings.xml index 2a771d664b..988e7c4de3 100644 --- a/pump/virtual/src/main/res/values-ru-rRU/strings.xml +++ b/pump/virtual/src/main/res/values-ru-rRU/strings.xml @@ -1,6 +1,11 @@ + Тип виртуальной помпы + Определение помпы + Болюс: Шаг =%1$s\n Пролонгированный Болюс: [Шаг =%2$s, Продолжительность =%3$sмин -%4$sh] \nБазал: Шаг =%5$s\n ВБС: %6$s (на %7$s), Продолжительность =%8$sмин -%9$sh\n%10$s + ВиртПомпа Интеграция с помпами, еще не имеющими драйвера (незамкнутый цикл) + ВИРТУАЛЬНАЯ ПОМПА настройки вирт помпы From 02c1bd1e52e0df98283dd99c31245ab1f72c9bc6 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sun, 11 Dec 2022 12:57:19 +0100 Subject: [PATCH 35/48] lints --- .../comm/history/pump/PumpHistoryResult.kt | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/PumpHistoryResult.kt b/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/PumpHistoryResult.kt index d19e53b43d..b53cb342e4 100644 --- a/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/PumpHistoryResult.kt +++ b/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/comm/history/pump/PumpHistoryResult.kt @@ -3,7 +3,6 @@ package info.nightscout.androidaps.plugins.pump.medtronic.comm.history.pump import info.nightscout.core.utils.DateTimeUtil import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag -import java.util.Collections /** * History page contains data, sorted from newest to oldest (0=newest..n=oldest) @@ -18,19 +17,19 @@ class PumpHistoryResult(private val aapsLogger: AAPSLogger, searchEntry: PumpHis private val searchEntry: PumpHistoryEntry? = null private var searchDate: Long? = null private var searchType = SearchType.None - var unprocessedEntries: List = ArrayList() + var unprocessedEntries: MutableList = ArrayList() var validEntries: MutableList = ArrayList() - fun addHistoryEntries(entries: List /*, page: Int*/) { + fun addHistoryEntries(entries: MutableList /*, page: Int*/) { unprocessedEntries = entries //aapsLogger.debug(LTag.PUMPCOMM,"PumpHistoryResult. Unprocessed entries: {}", MedtronicUtil.getGsonInstance().toJson(entries)); processEntries() } // TODO Bug #145 need to check if we had timeChange that went -1, that situation needs to be evaluated separately - fun processEntries() { + private fun processEntries() { var olderEntries = 0 - Collections.reverse(unprocessedEntries) + unprocessedEntries.reverse() when (searchType) { SearchType.None -> //aapsLogger.debug(LTag.PUMPCOMM,"PE. None search"); validEntries.addAll(unprocessedEntries) @@ -42,7 +41,7 @@ class PumpHistoryResult(private val aapsLogger: AAPSLogger, searchEntry: PumpHis aapsLogger.debug(LTag.PUMPCOMM, "PE. PumpHistoryResult. Search entry date: " + searchEntry!!.atechDateTime) //val date = searchEntry.atechDateTime for (unprocessedEntry in unprocessedEntries) { - if (unprocessedEntry.equals(searchEntry)) { + if (unprocessedEntry == searchEntry) { //aapsLogger.debug(LTag.PUMPCOMM,"PE. Item found {}.", unprocessedEntry); isSearchFinished = true break @@ -56,7 +55,7 @@ class PumpHistoryResult(private val aapsLogger: AAPSLogger, searchEntry: PumpHis } SearchType.Date -> { - aapsLogger.debug(LTag.PUMPCOMM, "PE. Date search: Search date: " + searchDate) + aapsLogger.debug(LTag.PUMPCOMM, "PE. Date search: Search date: $searchDate") for (unprocessedEntry in unprocessedEntries) { if (unprocessedEntry.atechDateTime == 0L) { aapsLogger.debug(LTag.PUMPCOMM, "PE. PumpHistoryResult. Search entry date: Entry with no date: $unprocessedEntry") From d7a8323bc8e8a76b9e717b9a80c34ff1e6f51ef4 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sun, 11 Dec 2022 14:33:30 +0100 Subject: [PATCH 36/48] lints --- .../core/ui/extensions/RadioGroupExtension.kt | 2 +- .../core/utils/extensions/JSONObjectExt.kt | 2 +- .../plugins/general/autotune/AutotuneCore.kt | 4 +- .../plugins/general/autotune/AutotuneFS.kt | 8 +- .../general/autotune/AutotuneFragment.kt | 28 +-- .../general/autotune/AutotunePlugin.kt | 34 ++-- .../general/autotune/data/ATProfile.kt | 68 ++++--- .../constraints/safety/SafetyPlugin.kt | 12 +- .../insulin/InsulinOrefFreePeakPlugin.kt | 4 +- .../general/overview/OverviewPlugin.kt | 12 +- .../overview/dialogs/EditQuickWizardDialog.kt | 6 +- .../plugins/general/wear/WearFragment.kt | 2 +- .../general/wear/events/EventWearUpdateGui.kt | 2 +- .../DataLayerListenerServiceMobile.kt | 2 +- .../pump/combo/di/ComboActivitiesModule.kt | 2 +- .../nightscout/pump/combo/di/ComboModule.kt | 1 - .../packet/BasalLimitInquireResponsePacket.kt | 4 +- .../BigAPSMainInfoInquireResponsePacket.kt | 4 +- .../packet/BigLogInquireResponsePacket.kt | 178 +++++++++--------- .../BigMainInfoInquireResponsePacket.kt | 4 +- ...OG_ALARM_BATTERY.kt => LogAlarmBattery.kt} | 22 +-- .../{LOG_ALARM_BLOCK.kt => LogAlarmBlock.kt} | 30 +-- ..._ALARM_SHORTAGE.kt => LogAlarmShortAge.kt} | 28 +-- ...SUCCESS.kt => LogChangeInjectorSuccess.kt} | 22 +-- ...E_SUCCESS.kt => LogChangeNeedleSuccess.kt} | 23 +-- ...UBE_SUCCESS.kt => LogChangeTubeSuccess.kt} | 23 +-- ...JECT_DUAL_FAIL.kt => LogInjectDualFail.kt} | 27 +-- ...UAL_SUCCESS.kt => LogInjectDualSuccess.kt} | 27 +-- ...JECT_MEAL_FAIL.kt => LogInjectMealFail.kt} | 27 +-- ...EAL_SUCCESS.kt => LogInjectMealSuccess.kt} | 30 +-- ..._NORMAL_FAIL.kt => LogInjectNormalFail.kt} | 29 +-- ...L_SUCCESS.kt => LogInjectNormalSuccess.kt} | 27 +-- ..._SQUARE_FAIL.kt => LogInjectSquareFail.kt} | 25 +-- ...E_SUCCESS.kt => LogInjectSquareSuccess.kt} | 25 +-- ..._INJECTION_1DAY.kt => LogInjection1Day.kt} | 23 +-- ...1DAY_BASAL.kt => LogInjection1DayBasal.kt} | 21 ++- ...OUR_BASAL.kt => LogInjection1HourBasal.kt} | 25 +-- ...AL_NORMAL.kt => LogInjectionDualNormal.kt} | 27 +-- .../{LOG_RESET_SYS_V3.kt => LogResetSysV3.kt} | 29 +-- ...AL_INJECTION.kt => LogSetDualInjection.kt} | 27 +-- ..._INJECTION.kt => LogSetSquareInjection.kt} | 23 +-- ...D_RELEASE_V2.kt => LogSuspendReleaseV2.kt} | 23 +-- .../{LOG_SUSPEND_V2.kt => LogSuspendV2.kt} | 23 +-- .../{LOG_TB_START_V3.kt => LogTbStartV3.kt} | 25 +-- .../{LOG_TB_STOP_V3.kt => LogTbStopV3.kt} | 25 +-- .../{PumplogUtil.java => PumpLogUtil.java} | 9 +- .../pump/diaconn/service/DiaconnG8Service.kt | 4 +- .../pump/medtronic/MedtronicPumpPlugin.kt | 4 - .../pump/medtronic/util/MedtronicUtil.kt | 76 ++++---- .../dash/driver/comm/session/Milenage.kt | 9 +- .../state/OmnipodDashPodStateManagerImpl.kt | 5 +- .../eros/extensions/PumpStateExtension.kt | 2 +- .../eros/manager/AapsOmnipodErosManager.java | 2 +- .../pump/common/PumpPluginAbstract.kt | 29 ++- .../workflow/iob/CarbsInPastExtension.kt | 2 +- .../workflow/iob/IobCobOref1Worker.kt | 1 - .../workflow/iob/IobCobOrefWorker.kt | 1 - 57 files changed, 595 insertions(+), 564 deletions(-) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_ALARM_BATTERY.kt => LogAlarmBattery.kt} (68%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_ALARM_BLOCK.kt => LogAlarmBlock.kt} (66%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_ALARM_SHORTAGE.kt => LogAlarmShortAge.kt} (63%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_CHANGE_INJECTOR_SUCCESS.kt => LogChangeInjectorSuccess.kt} (67%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_CHANGE_NEEDLE_SUCCESS.kt => LogChangeNeedleSuccess.kt} (66%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_CHANGE_TUBE_SUCCESS.kt => LogChangeTubeSuccess.kt} (66%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECT_DUAL_FAIL.kt => LogInjectDualFail.kt} (71%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECT_DUAL_SUCCESS.kt => LogInjectDualSuccess.kt} (67%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECT_MEAL_FAIL.kt => LogInjectMealFail.kt} (71%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECT_MEAL_SUCCESS.kt => LogInjectMealSuccess.kt} (67%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECT_NORMAL_FAIL.kt => LogInjectNormalFail.kt} (68%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECT_NORMAL_SUCCESS.kt => LogInjectNormalSuccess.kt} (66%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECT_SQUARE_FAIL.kt => LogInjectSquareFail.kt} (70%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECT_SQUARE_SUCCESS.kt => LogInjectSquareSuccess.kt} (64%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECTION_1DAY.kt => LogInjection1Day.kt} (68%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECTION_1DAY_BASAL.kt => LogInjection1DayBasal.kt} (66%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECTION_1HOUR_BASAL.kt => LogInjection1HourBasal.kt} (74%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_INJECTION_DUAL_NORMAL.kt => LogInjectionDualNormal.kt} (67%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_RESET_SYS_V3.kt => LogResetSysV3.kt} (62%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_SET_DUAL_INJECTION.kt => LogSetDualInjection.kt} (66%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_SET_SQUARE_INJECTION.kt => LogSetSquareInjection.kt} (68%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_SUSPEND_RELEASE_V2.kt => LogSuspendReleaseV2.kt} (73%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_SUSPEND_V2.kt => LogSuspendV2.kt} (73%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_TB_START_V3.kt => LogTbStartV3.kt} (72%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{LOG_TB_STOP_V3.kt => LogTbStopV3.kt} (72%) rename pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/{PumplogUtil.java => PumpLogUtil.java} (96%) diff --git a/core/ui/src/main/java/info/nightscout/core/ui/extensions/RadioGroupExtension.kt b/core/ui/src/main/java/info/nightscout/core/ui/extensions/RadioGroupExtension.kt index 0bf51f656f..54b61b97db 100644 --- a/core/ui/src/main/java/info/nightscout/core/ui/extensions/RadioGroupExtension.kt +++ b/core/ui/src/main/java/info/nightscout/core/ui/extensions/RadioGroupExtension.kt @@ -1,4 +1,4 @@ -package info.nightscout.androidaps.utils.extensions +package info.nightscout.core.ui.extensions import android.widget.RadioGroup import androidx.appcompat.widget.AppCompatRadioButton diff --git a/core/utils/src/main/java/info/nightscout/core/utils/extensions/JSONObjectExt.kt b/core/utils/src/main/java/info/nightscout/core/utils/extensions/JSONObjectExt.kt index bfcf039497..8f38aab753 100644 --- a/core/utils/src/main/java/info/nightscout/core/utils/extensions/JSONObjectExt.kt +++ b/core/utils/src/main/java/info/nightscout/core/utils/extensions/JSONObjectExt.kt @@ -1,4 +1,4 @@ -package info.nightscout.core.extensions +package info.nightscout.core.utils.extensions import androidx.annotation.StringRes import info.nightscout.shared.interfaces.ResourceHelper diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneCore.kt b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneCore.kt index 3c0de91b51..a173b54a22 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneCore.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneCore.kt @@ -165,7 +165,7 @@ class AutotuneCore @Inject constructor( for (i in 0..23) { newHourlyBasalProfile[i] = hourlyBasalProfile[i] } - val basalUnTuned = previousAutotune.basalUntuned + val basalUnTuned = previousAutotune.basalUnTuned //autotune-core (lib/autotune/index.js) #210-#266 // look at net deviations for each hour @@ -484,7 +484,7 @@ class AutotuneCore @Inject constructor( previousAutotune.basal = basalProfile previousAutotune.isf = isf previousAutotune.ic = Round.roundTo(carbRatio, 0.001) - previousAutotune.basalUntuned = basalUnTuned + previousAutotune.basalUnTuned = basalUnTuned previousAutotune.dia = newDia previousAutotune.peak = newPeak val localInsulin = LocalInsulin("Ins_$newPeak-$newDia", newPeak, newDia) diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFS.kt b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFS.kt index fb32c8bb6f..69d655462d 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFS.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFS.kt @@ -89,14 +89,14 @@ class AutotuneFS @Inject constructor( } fun exportPumpProfile(profile: ATProfile) { - createAutotunefile(PUMPPROFILE, profile.profiletoOrefJSON(), true) - createAutotunefile(PUMPPROFILE, profile.profiletoOrefJSON()) + createAutotunefile(PUMPPROFILE, profile.profileToOrefJSON(), true) + createAutotunefile(PUMPPROFILE, profile.profileToOrefJSON()) } fun exportTunedProfile(tunedProfile: ATProfile) { - createAutotunefile(TUNEDPROFILE + formatDate(tunedProfile.from) + ".json", tunedProfile.profiletoOrefJSON()) + createAutotunefile(TUNEDPROFILE + formatDate(tunedProfile.from) + ".json", tunedProfile.profileToOrefJSON()) try { - createAutotunefile(rh.gs(info.nightscout.core.ui.R.string.autotune_tunedprofile_name) + ".json", tunedProfile.profiletoOrefJSON(), true) + createAutotunefile(rh.gs(info.nightscout.core.ui.R.string.autotune_tunedprofile_name) + ".json", tunedProfile.profileToOrefJSON(), true) } catch (e: JSONException) { } } diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFragment.kt b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFragment.kt index 2bfd3b5e14..be1c6f5f76 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFragment.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotuneFragment.kt @@ -28,9 +28,9 @@ import info.nightscout.interfaces.Constants import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.logging.UserEntryLogger import info.nightscout.interfaces.plugin.ActivePlugin +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileStore import info.nightscout.interfaces.ui.UiInteraction import info.nightscout.interfaces.utils.MidnightTime @@ -149,12 +149,12 @@ class AutotuneFragment : DaggerFragment() { } binding.autotuneUpdateProfile.setOnClickListener { - val localName = autotunePlugin.pumpProfile.profilename + val localName = autotunePlugin.pumpProfile.profileName OKDialog.showConfirmation(requireContext(), rh.gs(info.nightscout.core.ui.R.string.autotune_update_input_profile_button), rh.gs(info.nightscout.core.ui.R.string.autotune_update_local_profile_message, localName), Runnable { - autotunePlugin.tunedProfile?.profilename = localName + autotunePlugin.tunedProfile?.profileName = localName autotunePlugin.updateProfile(autotunePlugin.tunedProfile) autotunePlugin.updateButtonVisibility = View.GONE autotunePlugin.saveLastRun() @@ -169,12 +169,12 @@ class AutotuneFragment : DaggerFragment() { } binding.autotuneRevertProfile.setOnClickListener { - val localName = autotunePlugin.pumpProfile.profilename + val localName = autotunePlugin.pumpProfile.profileName OKDialog.showConfirmation(requireContext(), rh.gs(info.nightscout.core.ui.R.string.autotune_revert_input_profile_button), rh.gs(info.nightscout.core.ui.R.string.autotune_revert_local_profile_message, localName), Runnable { - autotunePlugin.tunedProfile?.profilename = "" + autotunePlugin.tunedProfile?.profileName = "" autotunePlugin.updateProfile(autotunePlugin.pumpProfile) autotunePlugin.updateButtonVisibility = View.VISIBLE autotunePlugin.saveLastRun() @@ -192,11 +192,11 @@ class AutotuneFragment : DaggerFragment() { val pumpProfile = profileFunction.getProfile()?.let { currentProfile -> profileStore.getSpecificProfile(profileName)?.let { specificProfile -> ATProfile(ProfileSealed.Pure(specificProfile), LocalInsulin(""), injector).also { - it.profilename = profileName + it.profileName = profileName } } ?: ATProfile(currentProfile, LocalInsulin(""), injector).also { - it.profilename = profileFunction.getProfileName() + it.profileName = profileFunction.getProfileName() } } pumpProfile?.let { @@ -205,7 +205,7 @@ class AutotuneFragment : DaggerFragment() { time = dateUtil.now(), mode = UiInteraction.Mode.CUSTOM_PROFILE, customProfile = pumpProfile.profile.toPureNsJson(dateUtil).toString(), - customProfileName = pumpProfile.profilename + customProfileName = pumpProfile.profileName ) } } @@ -219,7 +219,7 @@ class AutotuneFragment : DaggerFragment() { time = dateUtil.now(), mode = UiInteraction.Mode.PROFILE_COMPARE, customProfile = pumpProfile.profile.toPureNsJson(dateUtil).toString(), - customProfileName = pumpProfile.profilename + "\n" + rh.gs(info.nightscout.core.ui.R.string.autotune_tunedprofile_name), + customProfileName = pumpProfile.profileName + "\n" + rh.gs(info.nightscout.core.ui.R.string.autotune_tunedprofile_name), customProfile2 = tunedProfile?.toPureNsJson(dateUtil).toString() ) } @@ -231,17 +231,17 @@ class AutotuneFragment : DaggerFragment() { tunedProfile?.let { tunedP -> tunedP.profileStore(circadian)?.let { OKDialog.showConfirmation(requireContext(), - rh.gs(info.nightscout.core.ui.R.string.activate_profile) + ": " + tunedP.profilename + " ?", + rh.gs(info.nightscout.core.ui.R.string.activate_profile) + ": " + tunedP.profileName + " ?", { uel.log( UserEntry.Action.STORE_PROFILE, UserEntry.Sources.Autotune, - ValueWithUnit.SimpleString(tunedP.profilename) + ValueWithUnit.SimpleString(tunedP.profileName) ) val now = dateUtil.now() if (profileFunction.createProfileSwitch( it, - profileName = tunedP.profilename, + profileName = tunedP.profileName, durationInMinutes = 0, percentage = 100, timeShiftInHours = 0, @@ -252,7 +252,7 @@ class AutotuneFragment : DaggerFragment() { UserEntry.Action.PROFILE_SWITCH, UserEntry.Sources.Autotune, "Autotune AutoSwitch", - ValueWithUnit.SimpleString(autotunePlugin.tunedProfile!!.profilename) + ValueWithUnit.SimpleString(autotunePlugin.tunedProfile!!.profileName) ) } rxBus.send(EventLocalProfileChanged()) @@ -472,7 +472,7 @@ class AutotuneFragment : DaggerFragment() { val time = df.format(h.toLong()) + ":00" totalPump += autotunePlugin.pumpProfile.basal[h] totalTuned += tuned.basal[h] - layout.addView(toTableRowValue(context, time, autotunePlugin.pumpProfile.basal[h], tuned.basal[h], "%.3f", tuned.basalUntuned[h].toString())) + layout.addView(toTableRowValue(context, time, autotunePlugin.pumpProfile.basal[h], tuned.basal[h], "%.3f", tuned.basalUnTuned[h].toString())) } layout.addView(toTableRowValue(context, "∑", totalPump, totalTuned, "%.3f", " ")) } diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotunePlugin.kt b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotunePlugin.kt index 50c4ab61c2..461797ea48 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotunePlugin.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/AutotunePlugin.kt @@ -14,9 +14,9 @@ import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.utils.JsonHelper import info.nightscout.interfaces.utils.MidnightTime import info.nightscout.plugins.aps.R @@ -131,10 +131,10 @@ class AutotunePlugin @Inject constructor( val starttime = endTime - daysBack * 24 * 60 * 60 * 1000L autotuneFS.exportSettings(settings(lastRun, daysBack, starttime, endTime)) tunedProfile = ATProfile(profile, localInsulin, injector).also { - it.profilename = rh.gs(info.nightscout.core.ui.R.string.autotune_tunedprofile_name) + it.profileName = rh.gs(info.nightscout.core.ui.R.string.autotune_tunedprofile_name) } pumpProfile = ATProfile(profile, localInsulin, injector).also { - it.profilename = selectedProfile + it.profileName = selectedProfile } autotuneFS.exportPumpProfile(pumpProfile) @@ -195,31 +195,31 @@ class AutotunePlugin @Inject constructor( if (autoSwitch) { val circadian = sp.getBoolean(info.nightscout.core.utils.R.string.key_autotune_circadian_ic_isf, false) tunedProfile?.let { tunedP -> - tunedP.profilename = pumpProfile.profilename + tunedP.profileName = pumpProfile.profileName updateProfile(tunedP) uel.log( UserEntry.Action.STORE_PROFILE, UserEntry.Sources.Automation, rh.gs(info.nightscout.core.ui.R.string.autotune), - ValueWithUnit.SimpleString(tunedP.profilename) + ValueWithUnit.SimpleString(tunedP.profileName) ) updateButtonVisibility = View.GONE tunedP.profileStore(circadian)?.let { profilestore -> if (profileFunction.createProfileSwitch( profilestore, - profileName = tunedP.profilename, + profileName = tunedP.profileName, durationInMinutes = 0, percentage = 100, timeShiftInHours = 0, timestamp = dateUtil.now() ) ) { - log("Profile Switch succeed ${tunedP.profilename}") + log("Profile Switch succeed ${tunedP.profileName}") uel.log( UserEntry.Action.PROFILE_SWITCH, UserEntry.Sources.Automation, rh.gs(info.nightscout.core.ui.R.string.autotune), - ValueWithUnit.SimpleString(tunedP.profilename) + ValueWithUnit.SimpleString(tunedP.profileName) ) } rxBus.send(EventLocalProfileChanged()) @@ -262,7 +262,7 @@ class AutotunePlugin @Inject constructor( totalBasal += pumpProfile.basal[i] totalTuned += tunedProfile.basal[i] val percentageChangeValue = tunedProfile.basal[i] / pumpProfile.basal[i] * 100 - 100 - strResult += rh.gs(info.nightscout.core.ui.R.string.autotune_log_basal, i.toDouble(), pumpProfile.basal[i], tunedProfile.basal[i], tunedProfile.basalUntuned[i], percentageChangeValue) + strResult += rh.gs(info.nightscout.core.ui.R.string.autotune_log_basal, i.toDouble(), pumpProfile.basal[i], tunedProfile.basal[i], tunedProfile.basalUnTuned[i], percentageChangeValue) } strResult += line strResult += rh.gs(info.nightscout.core.ui.R.string.autotune_log_sum_basal, totalBasal, totalTuned) @@ -329,10 +329,10 @@ class AutotunePlugin @Inject constructor( val profileList: ArrayList = profileStore.getProfileList() var indexLocalProfile = -1 for (p in profileList.indices) - if (profileList[p] == newProfile.profilename) + if (profileList[p] == newProfile.profileName) indexLocalProfile = p if (indexLocalProfile == -1) { - profilePlugin.addProfile(profilePlugin.copyFrom(newProfile.getProfile(circadian), newProfile.profilename)) + profilePlugin.addProfile(profilePlugin.copyFrom(newProfile.getProfile(circadian), newProfile.profileName)) return } profilePlugin.currentProfileIndex = indexLocalProfile @@ -348,17 +348,17 @@ class AutotunePlugin @Inject constructor( json.put("lastNbDays", lastNbDays) json.put("lastRun", lastRun) json.put("pumpProfile", pumpProfile.profile.toPureNsJson(dateUtil)) - json.put("pumpProfileName", pumpProfile.profilename) + json.put("pumpProfileName", pumpProfile.profileName) json.put("pumpPeak", pumpProfile.peak) json.put("pumpDia", pumpProfile.dia) tunedProfile?.let { atProfile -> json.put("tunedProfile", atProfile.profile.toPureNsJson(dateUtil)) json.put("tunedCircadianProfile", atProfile.circadianProfile.toPureNsJson(dateUtil)) - json.put("tunedProfileName", atProfile.profilename) + json.put("tunedProfileName", atProfile.profileName) json.put("tunedPeak", atProfile.peak) json.put("tunedDia", atProfile.dia) for (i in 0..23) { - json.put("missingDays_$i", atProfile.basalUntuned[i]) + json.put("missingDays_$i", atProfile.basalUnTuned[i]) } } json.put("result", result) @@ -379,7 +379,7 @@ class AutotunePlugin @Inject constructor( selectedProfile = JsonHelper.safeGetString(json, "pumpProfileName", "") val profile = JsonHelper.safeGetJSONObject(json, "pumpProfile", null)?.let { pureProfileFromJson(it, dateUtil) } ?: return - pumpProfile = ATProfile(ProfileSealed.Pure(profile), localInsulin, injector).also { it.profilename = selectedProfile } + pumpProfile = ATProfile(ProfileSealed.Pure(profile), localInsulin, injector).also { it.profileName = selectedProfile } val tunedPeak = JsonHelper.safeGetInt(json, "tunedPeak") val tunedDia = JsonHelper.safeGetDouble(json, "tunedDia") localInsulin = LocalInsulin("PumpInsulin", tunedPeak, tunedDia) @@ -389,10 +389,10 @@ class AutotunePlugin @Inject constructor( val circadianTuned = JsonHelper.safeGetJSONObject(json, "tunedCircadianProfile", null)?.let { pureProfileFromJson(it, dateUtil) } ?: return tunedProfile = ATProfile(ProfileSealed.Pure(tuned), localInsulin, injector).also { atProfile -> - atProfile.profilename = tunedProfileName + atProfile.profileName = tunedProfileName atProfile.circadianProfile = ProfileSealed.Pure(circadianTuned) for (i in 0..23) { - atProfile.basalUntuned[i] = JsonHelper.safeGetInt(json, "missingDays_$i") + atProfile.basalUnTuned[i] = JsonHelper.safeGetInt(json, "missingDays_$i") } } result = JsonHelper.safeGetString(json, "result", "") diff --git a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/data/ATProfile.kt b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/data/ATProfile.kt index f8b139736a..e8861d37ef 100644 --- a/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/data/ATProfile.kt +++ b/plugins/aps/src/main/java/info/nightscout/plugins/general/autotune/data/ATProfile.kt @@ -10,13 +10,15 @@ import info.nightscout.interfaces.Config import info.nightscout.interfaces.GlucoseUnit import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.plugin.ActivePlugin +import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.Profile import info.nightscout.interfaces.profile.ProfileFunction -import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileStore import info.nightscout.interfaces.profile.PureProfile import info.nightscout.interfaces.utils.Round import info.nightscout.rx.bus.RxBus +import info.nightscout.rx.logging.AAPSLogger +import info.nightscout.rx.logging.LTag import info.nightscout.shared.SafeParse import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP @@ -28,6 +30,7 @@ import org.json.JSONObject import java.text.DecimalFormat import java.util.TimeZone import javax.inject.Inject +import kotlin.math.min class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: HasAndroidInjector) { @@ -39,30 +42,31 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: @Inject lateinit var rxBus: RxBus @Inject lateinit var rh: ResourceHelper @Inject lateinit var instantiator: Instantiator + @Inject lateinit var aapsLogger: AAPSLogger var profile: ProfileSealed var circadianProfile: ProfileSealed - lateinit var pumpProfile: ProfileSealed - var profilename: String = "" + private lateinit var pumpProfile: ProfileSealed + var profileName: String = "" var basal = DoubleArray(24) - var basalUntuned = IntArray(24) + var basalUnTuned = IntArray(24) var ic = 0.0 var isf = 0.0 var dia = 0.0 var peak = 0 var isValid: Boolean = false var from: Long = 0 - var pumpProfileAvgISF = 0.0 - var pumpProfileAvgIC = 0.0 + private var pumpProfileAvgISF = 0.0 + private var pumpProfileAvgIC = 0.0 val icSize: Int get() = profile.getIcsValues().size val isfSize: Int get() = profile.getIsfsMgdlValues().size - val avgISF: Double - get() = if (profile.getIsfsMgdlValues().size == 1) profile.getIsfsMgdlValues().get(0).value else Round.roundTo(averageProfileValue(profile.getIsfsMgdlValues()), 0.01) - val avgIC: Double - get() = if (profile.getIcsValues().size == 1) profile.getIcsValues().get(0).value else Round.roundTo(averageProfileValue(profile.getIcsValues()), 0.01) + private val avgISF: Double + get() = if (profile.getIsfsMgdlValues().size == 1) profile.getIsfsMgdlValues()[0].value else Round.roundTo(averageProfileValue(profile.getIsfsMgdlValues()), 0.01) + private val avgIC: Double + get() = if (profile.getIcsValues().size == 1) profile.getIcsValues()[0].value else Round.roundTo(averageProfileValue(profile.getIcsValues()), 0.01) fun getBasal(timestamp: Long): Double = basal[MidnightUtils.secondsFromMidnight(timestamp) / 3600] @@ -94,12 +98,12 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: //Export json string with oref0 format used for autotune // Include min_5m_carbimpact, insulin type, single value for carb_ratio and isf - fun profiletoOrefJSON(): String { + fun profileToOrefJSON(): String { var jsonString = "" val json = JSONObject() val insulinInterface: Insulin = activePlugin.activeInsulin try { - json.put("name", profilename) + json.put("name", profileName) json.put("min_5m_carbimpact", sp.getDouble("openapsama_min_5m_carbimpact", 3.0)) json.put("dia", dia) if (insulinInterface.id === Insulin.InsulinType.OREF_ULTRA_RAPID_ACTING) json.put( @@ -110,32 +114,31 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: json.put("useCustomPeakTime", true) json.put("insulinPeakTime", 45) } else if (insulinInterface.id === Insulin.InsulinType.OREF_FREE_PEAK) { - val peaktime: Int = sp.getInt(rh.gs(info.nightscout.core.utils.R.string.key_insulin_oref_peak), 75) - json.put("curve", if (peaktime > 50) "rapid-acting" else "ultra-rapid") + val peakTime: Int = sp.getInt(rh.gs(info.nightscout.core.utils.R.string.key_insulin_oref_peak), 75) + json.put("curve", if (peakTime > 50) "rapid-acting" else "ultra-rapid") json.put("useCustomPeakTime", true) - json.put("insulinPeakTime", peaktime) + json.put("insulinPeakTime", peakTime) } val basals = JSONArray() for (h in 0..23) { - val secondfrommidnight = h * 60 * 60 - var time: String - time = DecimalFormat("00").format(h) + ":00:00" + val secondFromMidnight = h * 60 * 60 + val time: String = DecimalFormat("00").format(h) + ":00:00" basals.put( JSONObject() .put("start", time) .put("minutes", h * 60) .put( - "rate", profile.getBasalTimeFromMidnight(secondfrommidnight) + "rate", profile.getBasalTimeFromMidnight(secondFromMidnight) ) ) } json.put("basalprofile", basals) - val isfvalue = Round.roundTo(avgISF, 0.001) + val isfValue = Round.roundTo(avgISF, 0.001) json.put( "isfProfile", JSONObject().put( "sensitivities", - JSONArray().put(JSONObject().put("i", 0).put("start", "00:00:00").put("sensitivity", isfvalue).put("offset", 0).put("x", 0).put("endoffset", 1440)) + JSONArray().put(JSONObject().put("i", 0).put("start", "00:00:00").put("sensitivity", isfValue).put("offset", 0).put("x", 0).put("endoffset", 1440)) ) ) json.put("carb_ratio", avgIC) @@ -145,6 +148,7 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: json.put("timezone", TimeZone.getDefault().id) jsonString = json.toString(2).replace("\\/", "/") } catch (e: JSONException) { + aapsLogger.error(LTag.CORE, e.stackTraceToString()) } return jsonString @@ -163,6 +167,7 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: } json.put("basal", jsonArray(basal)) } catch (e: JSONException) { + aapsLogger.error(LTag.CORE, e.stackTraceToString()) } return pureProfileFromJson(json, dateUtil, profile.units.asText) } @@ -172,36 +177,37 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: val json = JSONObject() val store = JSONObject() val tunedProfile = if (circadian) circadianProfile else profile - if (profilename.isEmpty()) - profilename = rh.gs(info.nightscout.core.ui.R.string.autotune_tunedprofile_name) + if (profileName.isEmpty()) + profileName = rh.gs(info.nightscout.core.ui.R.string.autotune_tunedprofile_name) try { - store.put(profilename, tunedProfile.toPureNsJson(dateUtil)) - json.put("defaultProfile", profilename) + store.put(profileName, tunedProfile.toPureNsJson(dateUtil)) + json.put("defaultProfile", profileName) json.put("store", store) json.put("startDate", dateUtil.toISOAsUTC(dateUtil.now())) profileStore = instantiator.provideProfileStore(json) } catch (e: JSONException) { + aapsLogger.error(LTag.CORE, e.stackTraceToString()) } return profileStore } - fun jsonArray(values: DoubleArray): JSONArray { + private fun jsonArray(values: DoubleArray): JSONArray { val json = JSONArray() for (h in 0..23) { - val secondfrommidnight = h * 60 * 60 + val secondFromMidnight = h * 60 * 60 val df = DecimalFormat("00") val time = df.format(h.toLong()) + ":00" json.put( JSONObject() .put("time", time) - .put("timeAsSeconds", secondfrommidnight) + .put("timeAsSeconds", secondFromMidnight) .put("value", values[h]) ) } return json } - fun jsonArray(value: Double) = + private fun jsonArray(value: Double): JSONArray = JSONArray().put( JSONObject() .put("time", "00:00") @@ -209,7 +215,7 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: .put("value", value) ) - fun jsonArray(values: List, multiplier: Double = 1.0): JSONArray { + private fun jsonArray(values: List, multiplier: Double = 1.0): JSONArray { val json = JSONArray() var elapsedHours = 0L values.forEach { @@ -249,7 +255,7 @@ class ATProfile(profile: Profile, var localInsulin: LocalInsulin, val injector: var minBasal = 1.0 for (h in 0..23) { basal[h] = Round.roundTo(profile.basalBlocks.blockValueBySeconds(T.hours(h.toLong()).secs().toInt(), 1.0, 0), 0.001) - minBasal = Math.min(minBasal, basal[h]) + minBasal = min(minBasal, basal[h]) } ic = avgIC isf = avgISF diff --git a/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt index 7dfaa68fcb..c748fa957b 100644 --- a/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt +++ b/plugins/constraints/src/main/java/info/nightscout/plugins/constraints/safety/SafetyPlugin.kt @@ -1,12 +1,12 @@ package info.nightscout.plugins.constraints.safety import dagger.android.HasAndroidInjector -import info.nightscout.core.extensions.putDouble -import info.nightscout.core.extensions.putInt -import info.nightscout.core.extensions.putString -import info.nightscout.core.extensions.storeDouble -import info.nightscout.core.extensions.storeInt -import info.nightscout.core.extensions.storeString +import info.nightscout.core.utils.extensions.putDouble +import info.nightscout.core.utils.extensions.putInt +import info.nightscout.core.utils.extensions.putString +import info.nightscout.core.utils.extensions.storeDouble +import info.nightscout.core.utils.extensions.storeInt +import info.nightscout.core.utils.extensions.storeString import info.nightscout.interfaces.Config import info.nightscout.interfaces.constraints.Constraint import info.nightscout.interfaces.constraints.Constraints diff --git a/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefFreePeakPlugin.kt b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefFreePeakPlugin.kt index 30ed94d058..60582ac68f 100644 --- a/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefFreePeakPlugin.kt +++ b/plugins/insulin/src/main/java/info/nightscout/insulin/InsulinOrefFreePeakPlugin.kt @@ -1,8 +1,8 @@ package info.nightscout.insulin import dagger.android.HasAndroidInjector -import info.nightscout.core.extensions.putInt -import info.nightscout.core.extensions.storeInt +import info.nightscout.core.utils.extensions.putInt +import info.nightscout.core.utils.extensions.storeInt import info.nightscout.interfaces.Config import info.nightscout.interfaces.insulin.Insulin import info.nightscout.interfaces.profile.ProfileFunction diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewPlugin.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewPlugin.kt index be8198fd6c..09facd21a8 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewPlugin.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/OverviewPlugin.kt @@ -7,14 +7,14 @@ import androidx.preference.SwitchPreference import dagger.android.HasAndroidInjector import info.nightscout.core.events.EventIobCalculationProgress import info.nightscout.core.events.EventNewNotification -import info.nightscout.core.extensions.putDouble -import info.nightscout.core.extensions.putInt -import info.nightscout.core.extensions.putString -import info.nightscout.core.extensions.storeDouble -import info.nightscout.core.extensions.storeInt -import info.nightscout.core.extensions.storeString import info.nightscout.core.graph.OverviewData import info.nightscout.core.ui.dialogs.OKDialog +import info.nightscout.core.utils.extensions.putDouble +import info.nightscout.core.utils.extensions.putInt +import info.nightscout.core.utils.extensions.putString +import info.nightscout.core.utils.extensions.storeDouble +import info.nightscout.core.utils.extensions.storeInt +import info.nightscout.core.utils.extensions.storeString import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.interfaces.Config import info.nightscout.interfaces.Overview diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/dialogs/EditQuickWizardDialog.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/dialogs/EditQuickWizardDialog.kt index 78e3fac0f1..217b5adc92 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/overview/dialogs/EditQuickWizardDialog.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/overview/dialogs/EditQuickWizardDialog.kt @@ -10,9 +10,9 @@ import android.view.WindowManager import com.google.android.material.timepicker.MaterialTimePicker import com.google.android.material.timepicker.TimeFormat import dagger.android.support.DaggerDialogFragment -import info.nightscout.androidaps.utils.extensions.selectedItemPosition -import info.nightscout.androidaps.utils.extensions.setEnableForChildren -import info.nightscout.androidaps.utils.extensions.setSelection +import info.nightscout.core.ui.extensions.selectedItemPosition +import info.nightscout.core.ui.extensions.setEnableForChildren +import info.nightscout.core.ui.extensions.setSelection import info.nightscout.core.wizard.QuickWizard import info.nightscout.core.wizard.QuickWizardEntry import info.nightscout.plugins.R diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/wear/WearFragment.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/wear/WearFragment.kt index 12d516917d..57cd89ec9d 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/wear/WearFragment.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/wear/WearFragment.kt @@ -5,9 +5,9 @@ import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import dagger.android.support.DaggerFragment -import info.nightscout.androidaps.plugins.general.wear.events.EventWearUpdateGui import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.plugins.databinding.WearFragmentBinding +import info.nightscout.plugins.general.wear.events.EventWearUpdateGui import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventMobileToWear diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/wear/events/EventWearUpdateGui.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/wear/events/EventWearUpdateGui.kt index e7cb807f01..b8c4761358 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/wear/events/EventWearUpdateGui.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/wear/events/EventWearUpdateGui.kt @@ -1,4 +1,4 @@ -package info.nightscout.androidaps.plugins.general.wear.events +package info.nightscout.plugins.general.wear.events import info.nightscout.rx.events.Event diff --git a/plugins/main/src/main/java/info/nightscout/plugins/general/wear/wearintegration/DataLayerListenerServiceMobile.kt b/plugins/main/src/main/java/info/nightscout/plugins/general/wear/wearintegration/DataLayerListenerServiceMobile.kt index 8e9696e0f4..13a8ff47f9 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/general/wear/wearintegration/DataLayerListenerServiceMobile.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/general/wear/wearintegration/DataLayerListenerServiceMobile.kt @@ -15,7 +15,6 @@ import com.google.android.gms.wearable.PutDataMapRequest import com.google.android.gms.wearable.Wearable import com.google.android.gms.wearable.WearableListenerService import dagger.android.AndroidInjection -import info.nightscout.androidaps.plugins.general.wear.events.EventWearUpdateGui import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.database.impl.AppRepository import info.nightscout.interfaces.Config @@ -27,6 +26,7 @@ import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.receivers.ReceiverStatusStore import info.nightscout.plugins.R import info.nightscout.plugins.general.wear.WearPlugin +import info.nightscout.plugins.general.wear.events.EventWearUpdateGui import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventMobileToWear diff --git a/pump/combo/src/main/java/info/nightscout/pump/combo/di/ComboActivitiesModule.kt b/pump/combo/src/main/java/info/nightscout/pump/combo/di/ComboActivitiesModule.kt index ea71e7d0b1..832893dd2c 100644 --- a/pump/combo/src/main/java/info/nightscout/pump/combo/di/ComboActivitiesModule.kt +++ b/pump/combo/src/main/java/info/nightscout/pump/combo/di/ComboActivitiesModule.kt @@ -1,4 +1,4 @@ -package info.nightscout.androidaps.danars.di +package info.nightscout.pump.combo.di import dagger.Module import dagger.android.ContributesAndroidInjector diff --git a/pump/combo/src/main/java/info/nightscout/pump/combo/di/ComboModule.kt b/pump/combo/src/main/java/info/nightscout/pump/combo/di/ComboModule.kt index d31494715d..405589340f 100644 --- a/pump/combo/src/main/java/info/nightscout/pump/combo/di/ComboModule.kt +++ b/pump/combo/src/main/java/info/nightscout/pump/combo/di/ComboModule.kt @@ -1,7 +1,6 @@ package info.nightscout.pump.combo.di import dagger.Module -import info.nightscout.androidaps.danars.di.ComboActivitiesModule @Module(includes = [ ComboActivitiesModule::class diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BasalLimitInquireResponsePacket.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BasalLimitInquireResponsePacket.kt index 0d2f428178..0089294c28 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BasalLimitInquireResponsePacket.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BasalLimitInquireResponsePacket.kt @@ -3,7 +3,7 @@ package info.nightscout.pump.diaconn.packet import dagger.android.HasAndroidInjector import info.nightscout.pump.diaconn.DiaconnG8Pump import info.nightscout.pump.diaconn.R -import info.nightscout.pump.diaconn.pumplog.PumplogUtil +import info.nightscout.pump.diaconn.pumplog.PumpLogUtil import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP @@ -39,7 +39,7 @@ class BasalLimitInquireResponsePacket(injector: HasAndroidInjector) : DiaconnG8P } diaconnG8Pump.maxBasalPerHours = getShortToInt(bufferData).toDouble() / 100.0 // not include tempbasal limit val pumpFirmwareVersion = sp.getString(rh.gs(R.string.pumpversion), "") - if(pumpFirmwareVersion.isNotEmpty() && PumplogUtil.isPumpVersionGe(pumpFirmwareVersion, 3, 0)) { + if(pumpFirmwareVersion.isNotEmpty() && PumpLogUtil.isPumpVersionGe(pumpFirmwareVersion, 3, 0)) { diaconnG8Pump.maxBasal = diaconnG8Pump.maxBasalPerHours * 2.5 // include tempbasal } else { diaconnG8Pump.maxBasal = diaconnG8Pump.maxBasalPerHours * 2.0 // include tempbasal diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigAPSMainInfoInquireResponsePacket.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigAPSMainInfoInquireResponsePacket.kt index 0408aa03a1..975e8edade 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigAPSMainInfoInquireResponsePacket.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigAPSMainInfoInquireResponsePacket.kt @@ -3,7 +3,7 @@ package info.nightscout.pump.diaconn.packet import dagger.android.HasAndroidInjector import info.nightscout.pump.diaconn.DiaconnG8Pump import info.nightscout.pump.diaconn.R -import info.nightscout.pump.diaconn.pumplog.PumplogUtil +import info.nightscout.pump.diaconn.pumplog.PumpLogUtil import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP @@ -214,7 +214,7 @@ class BigAPSMainInfoInquireResponsePacket( diaconnG8Pump.pumpProfiles!![diaconnG8Pump.activeProfile][23] = diaconnG8Pump.baseAmount24 //incarnation no 처리 - diaconnG8Pump.isPumpVersionGe2_63 = PumplogUtil.isPumpVersionGe(sp.getString(rh.gs(R.string.pumpversion), ""), 2, 63) + diaconnG8Pump.isPumpVersionGe2_63 = PumpLogUtil.isPumpVersionGe(sp.getString(rh.gs(R.string.pumpversion), ""), 2, 63) aapsLogger.debug(LTag.PUMPCOMM, "result > " + diaconnG8Pump.result) aapsLogger.debug(LTag.PUMPCOMM, "systemRemainInsulin > " + diaconnG8Pump.systemRemainInsulin) diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigLogInquireResponsePacket.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigLogInquireResponsePacket.kt index cc99c8b9f8..23c00cf689 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigLogInquireResponsePacket.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigLogInquireResponsePacket.kt @@ -19,32 +19,32 @@ import info.nightscout.pump.diaconn.api.PumpLogDto import info.nightscout.pump.diaconn.common.RecordTypes import info.nightscout.pump.diaconn.database.DiaconnHistoryRecord import info.nightscout.pump.diaconn.database.DiaconnHistoryRecordDao -import info.nightscout.pump.diaconn.pumplog.LOG_ALARM_BATTERY -import info.nightscout.pump.diaconn.pumplog.LOG_ALARM_BLOCK -import info.nightscout.pump.diaconn.pumplog.LOG_ALARM_SHORTAGE -import info.nightscout.pump.diaconn.pumplog.LOG_CHANGE_INJECTOR_SUCCESS -import info.nightscout.pump.diaconn.pumplog.LOG_CHANGE_NEEDLE_SUCCESS -import info.nightscout.pump.diaconn.pumplog.LOG_CHANGE_TUBE_SUCCESS -import info.nightscout.pump.diaconn.pumplog.LOG_INJECTION_1DAY -import info.nightscout.pump.diaconn.pumplog.LOG_INJECTION_1DAY_BASAL -import info.nightscout.pump.diaconn.pumplog.LOG_INJECTION_1HOUR_BASAL -import info.nightscout.pump.diaconn.pumplog.LOG_INJECTION_DUAL_NORMAL -import info.nightscout.pump.diaconn.pumplog.LOG_INJECT_DUAL_FAIL -import info.nightscout.pump.diaconn.pumplog.LOG_INJECT_DUAL_SUCCESS -import info.nightscout.pump.diaconn.pumplog.LOG_INJECT_MEAL_FAIL -import info.nightscout.pump.diaconn.pumplog.LOG_INJECT_MEAL_SUCCESS -import info.nightscout.pump.diaconn.pumplog.LOG_INJECT_NORMAL_FAIL -import info.nightscout.pump.diaconn.pumplog.LOG_INJECT_NORMAL_SUCCESS -import info.nightscout.pump.diaconn.pumplog.LOG_INJECT_SQUARE_FAIL -import info.nightscout.pump.diaconn.pumplog.LOG_INJECT_SQUARE_SUCCESS -import info.nightscout.pump.diaconn.pumplog.LOG_RESET_SYS_V3 -import info.nightscout.pump.diaconn.pumplog.LOG_SET_DUAL_INJECTION -import info.nightscout.pump.diaconn.pumplog.LOG_SET_SQUARE_INJECTION -import info.nightscout.pump.diaconn.pumplog.LOG_SUSPEND_RELEASE_V2 -import info.nightscout.pump.diaconn.pumplog.LOG_SUSPEND_V2 -import info.nightscout.pump.diaconn.pumplog.LOG_TB_START_V3 -import info.nightscout.pump.diaconn.pumplog.LOG_TB_STOP_V3 -import info.nightscout.pump.diaconn.pumplog.PumplogUtil +import info.nightscout.pump.diaconn.pumplog.LogAlarmBattery +import info.nightscout.pump.diaconn.pumplog.LogAlarmBlock +import info.nightscout.pump.diaconn.pumplog.LogAlarmShortAge +import info.nightscout.pump.diaconn.pumplog.LogChangeInjectorSuccess +import info.nightscout.pump.diaconn.pumplog.LogChangeNeedleSuccess +import info.nightscout.pump.diaconn.pumplog.LogChangeTubeSuccess +import info.nightscout.pump.diaconn.pumplog.LogInjectDualFail +import info.nightscout.pump.diaconn.pumplog.LogInjectDualSuccess +import info.nightscout.pump.diaconn.pumplog.LogInjectMealFail +import info.nightscout.pump.diaconn.pumplog.LogInjectMealSuccess +import info.nightscout.pump.diaconn.pumplog.LogInjectNormalFail +import info.nightscout.pump.diaconn.pumplog.LogInjectNormalSuccess +import info.nightscout.pump.diaconn.pumplog.LogInjectSquareFail +import info.nightscout.pump.diaconn.pumplog.LogInjectSquareSuccess +import info.nightscout.pump.diaconn.pumplog.LogInjection1Day +import info.nightscout.pump.diaconn.pumplog.LogInjection1DayBasal +import info.nightscout.pump.diaconn.pumplog.LogInjection1HourBasal +import info.nightscout.pump.diaconn.pumplog.LogInjectionDualNormal +import info.nightscout.pump.diaconn.pumplog.LogResetSysV3 +import info.nightscout.pump.diaconn.pumplog.LogSetDualInjection +import info.nightscout.pump.diaconn.pumplog.LogSetSquareInjection +import info.nightscout.pump.diaconn.pumplog.LogSuspendReleaseV2 +import info.nightscout.pump.diaconn.pumplog.LogSuspendV2 +import info.nightscout.pump.diaconn.pumplog.LogTbStartV3 +import info.nightscout.pump.diaconn.pumplog.LogTbStopV3 +import info.nightscout.pump.diaconn.pumplog.PumpLogUtil import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventPumpStatusChanged import info.nightscout.rx.logging.LTag @@ -113,22 +113,22 @@ class BigLogInquireResponsePacket( val logNum = getShortToInt(bufferData) // 2byte // log Data Parsing val logData = byteArrayOf( - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData), - PumplogUtil.getByte(bufferData) + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData), + PumpLogUtil.getByte(bufferData) ) // process Log to DB val logDataToHexString = toNarrowHex(logData) - val pumpLogKind: Byte = PumplogUtil.getKind(logDataToHexString) + val pumpLogKind: Byte = PumpLogUtil.getKind(logDataToHexString) var status: String val diaconnG8HistoryRecord = DiaconnHistoryRecord(0) @@ -151,8 +151,8 @@ class BigLogInquireResponsePacket( when (pumpLogKind) { - LOG_INJECT_MEAL_SUCCESS.LOG_KIND -> { - val logItem = LOG_INJECT_MEAL_SUCCESS.parse(logDataToHexString) + LogInjectMealSuccess.LOG_KIND -> { + val logItem = LogInjectMealSuccess.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -186,8 +186,8 @@ class BigLogInquireResponsePacket( status = "MEAL_BOLUS_SUCCESS" + dateUtil.timeString(logDateTime) } - LOG_INJECT_MEAL_FAIL.LOG_KIND -> { - val logItem = LOG_INJECT_MEAL_FAIL.parse(logDataToHexString) + LogInjectMealFail.LOG_KIND -> { + val logItem = LogInjectMealFail.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -221,8 +221,8 @@ class BigLogInquireResponsePacket( status = "MEAL_BOLUS_FAIL " + dateUtil.timeString(logDateTime) } - LOG_INJECT_NORMAL_SUCCESS.LOG_KIND -> { - val logItem = LOG_INJECT_NORMAL_SUCCESS.parse(logDataToHexString) + LogInjectNormalSuccess.LOG_KIND -> { + val logItem = LogInjectNormalSuccess.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") @@ -257,8 +257,8 @@ class BigLogInquireResponsePacket( status = "BOLUS_SUCCESS" + dateUtil.timeString(logDateTime) } - LOG_INJECT_NORMAL_FAIL.LOG_KIND -> { - val logItem = LOG_INJECT_NORMAL_FAIL.parse(logDataToHexString) + LogInjectNormalFail.LOG_KIND -> { + val logItem = LogInjectNormalFail.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -295,8 +295,8 @@ class BigLogInquireResponsePacket( status = "BOLUS_FAIL " + dateUtil.timeString(logDateTime) } - LOG_SET_SQUARE_INJECTION.LOG_KIND -> { - val logItem = LOG_SET_SQUARE_INJECTION.parse(logDataToHexString) + LogSetSquareInjection.LOG_KIND -> { + val logItem = LogSetSquareInjection.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -326,8 +326,8 @@ class BigLogInquireResponsePacket( status = "EXTENDED_BOLUS_START " + dateUtil.timeString(logDateTime) } - LOG_INJECT_SQUARE_SUCCESS.LOG_KIND -> { - val logItem = LOG_INJECT_SQUARE_SUCCESS.parse(logDataToHexString) + LogInjectSquareSuccess.LOG_KIND -> { + val logItem = LogInjectSquareSuccess.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -343,8 +343,8 @@ class BigLogInquireResponsePacket( status = "EXTENDED_BOLUS_END " + dateUtil.timeString(logDateTime) } - LOG_INJECT_SQUARE_FAIL.LOG_KIND -> { - val logItem = LOG_INJECT_SQUARE_FAIL.parse(logDataToHexString) + LogInjectSquareFail.LOG_KIND -> { + val logItem = LogInjectSquareFail.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -371,8 +371,8 @@ class BigLogInquireResponsePacket( status = "EXTENDED_BOLUS_FAIL " + dateUtil.timeString(logDateTime) } - LOG_SET_DUAL_INJECTION.LOG_KIND -> { - val logItem = LOG_SET_DUAL_INJECTION.parse(logDataToHexString) + LogSetDualInjection.LOG_KIND -> { + val logItem = LogSetDualInjection.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -405,8 +405,8 @@ class BigLogInquireResponsePacket( status = "DUAL_EXTENDED_START " + dateUtil.timeString(logDateTime) } - LOG_INJECTION_DUAL_NORMAL.LOG_KIND -> { - val logItem = LOG_INJECTION_DUAL_NORMAL.parse(logDataToHexString) + LogInjectionDualNormal.LOG_KIND -> { + val logItem = LogInjectionDualNormal.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -445,8 +445,8 @@ class BigLogInquireResponsePacket( status = "DUAL_BOLUS" + dateUtil.timeString(logDateTime) } - LOG_INJECT_DUAL_SUCCESS.LOG_KIND -> { - val logItem = LOG_INJECT_DUAL_SUCCESS.parse(logDataToHexString) + LogInjectDualSuccess.LOG_KIND -> { + val logItem = LogInjectDualSuccess.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -464,8 +464,8 @@ class BigLogInquireResponsePacket( status = "DUAL_BOLUS_SQUARE_SUCCESS " + dateUtil.timeString(logDateTime) } - LOG_INJECT_DUAL_FAIL.LOG_KIND -> { - val logItem = LOG_INJECT_DUAL_FAIL.parse(logDataToHexString) + LogInjectDualFail.LOG_KIND -> { + val logItem = LogInjectDualFail.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -493,8 +493,8 @@ class BigLogInquireResponsePacket( status = "DUAL_BOLUS FAIL " + dateUtil.timeString(logDateTime) } - LOG_INJECTION_1HOUR_BASAL.LOG_KIND -> { - val logItem = LOG_INJECTION_1HOUR_BASAL.parse(logDataToHexString) + LogInjection1HourBasal.LOG_KIND -> { + val logItem = LogInjection1HourBasal.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -509,8 +509,8 @@ class BigLogInquireResponsePacket( status = "1HOUR BASAL " + dateUtil.dateAndTimeString(logDateTime) } - LOG_SUSPEND_V2.LOG_KIND -> { - val logItem = LOG_SUSPEND_V2.parse(logDataToHexString) + LogSuspendV2.LOG_KIND -> { + val logItem = LogSuspendV2.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -524,8 +524,8 @@ class BigLogInquireResponsePacket( status = "SUSPEND " + dateUtil.timeString(logDateTime) } - LOG_SUSPEND_RELEASE_V2.LOG_KIND -> { - val logItem = LOG_SUSPEND_RELEASE_V2.parse(logDataToHexString) + LogSuspendReleaseV2.LOG_KIND -> { + val logItem = LogSuspendReleaseV2.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -539,8 +539,8 @@ class BigLogInquireResponsePacket( status = "SUSPEND_RELEASE " + dateUtil.timeString(logDateTime) } - LOG_CHANGE_INJECTOR_SUCCESS.LOG_KIND -> { - val logItem = LOG_CHANGE_INJECTOR_SUCCESS.parse(logDataToHexString) + LogChangeInjectorSuccess.LOG_KIND -> { + val logItem = LogChangeInjectorSuccess.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -568,8 +568,8 @@ class BigLogInquireResponsePacket( status = "INSULIN_CHANGE " + dateUtil.timeString(logDateTime) } - LOG_CHANGE_TUBE_SUCCESS.LOG_KIND -> { - val logItem = LOG_CHANGE_TUBE_SUCCESS.parse(logDataToHexString) + LogChangeTubeSuccess.LOG_KIND -> { + val logItem = LogChangeTubeSuccess.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -600,8 +600,8 @@ class BigLogInquireResponsePacket( status = "TUBE_CHANGE " + dateUtil.timeString(logDateTime) } - LOG_INJECTION_1DAY.LOG_KIND -> { // Daily Bolus Log - val logItem = LOG_INJECTION_1DAY.parse(logDataToHexString) + LogInjection1Day.LOG_KIND -> { // Daily Bolus Log + val logItem = LogInjection1Day.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -649,8 +649,8 @@ class BigLogInquireResponsePacket( status = "DAILY_BOLUS " + dateUtil.timeString(logDateTime) } - LOG_INJECTION_1DAY_BASAL.LOG_KIND -> { // Daily Basal Log - val logItem = LOG_INJECTION_1DAY_BASAL.parse(logDataToHexString) + LogInjection1DayBasal.LOG_KIND -> { // Daily Basal Log + val logItem = LogInjection1DayBasal.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -698,8 +698,8 @@ class BigLogInquireResponsePacket( status = "DAILY_BASAL " + dateUtil.timeString(logDateTime) } - LOG_CHANGE_NEEDLE_SUCCESS.LOG_KIND -> { - val logItem = LOG_CHANGE_NEEDLE_SUCCESS.parse(logDataToHexString) + LogChangeNeedleSuccess.LOG_KIND -> { + val logItem = LogChangeNeedleSuccess.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -728,8 +728,8 @@ class BigLogInquireResponsePacket( status = "NEEDLE_CHANGE " + dateUtil.timeString(logDateTime) } - LOG_TB_START_V3.LOG_KIND -> { - val logItem = LOG_TB_START_V3.parse(logDataToHexString) + LogTbStartV3.LOG_KIND -> { + val logItem = LogTbStartV3.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") @@ -772,8 +772,8 @@ class BigLogInquireResponsePacket( status = "TEMP_START " + dateUtil.timeString(logDateTime) } - LOG_TB_STOP_V3.LOG_KIND -> { - val logItem = LOG_TB_STOP_V3.parse(logDataToHexString) + LogTbStopV3.LOG_KIND -> { + val logItem = LogTbStopV3.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -806,8 +806,8 @@ class BigLogInquireResponsePacket( status = "TEMP_STOP " + dateUtil.timeString(logDateTime) } - LOG_ALARM_BATTERY.LOG_KIND -> { // BATTERY SHORTAGE ALARM - val logItem = LOG_ALARM_BATTERY.parse(logDataToHexString) + LogAlarmBattery.LOG_KIND -> { // BATTERY SHORTAGE ALARM + val logItem = LogAlarmBattery.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") val logDateTime = logStartDate.time @@ -822,8 +822,8 @@ class BigLogInquireResponsePacket( status = "BATTERY_ALARM " + dateUtil.timeString(logDateTime) } - LOG_ALARM_BLOCK.LOG_KIND -> { // INJECTION BLOCKED ALARM - val logItem = LOG_ALARM_BLOCK.parse(logDataToHexString) + LogAlarmBlock.LOG_KIND -> { // INJECTION BLOCKED ALARM + val logItem = LogAlarmBlock.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") @@ -840,8 +840,8 @@ class BigLogInquireResponsePacket( status = "BLOCK_ALARM " + dateUtil.timeString(logDateTime) } - LOG_ALARM_SHORTAGE.LOG_KIND -> { // INSULIN SHORTAGE ALARM - val logItem = LOG_ALARM_SHORTAGE.parse(logDataToHexString) + LogAlarmShortAge.LOG_KIND -> { // INSULIN SHORTAGE ALARM + val logItem = LogAlarmShortAge.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") @@ -858,8 +858,8 @@ class BigLogInquireResponsePacket( status = "SHORT_AGE_ALARM " + dateUtil.timeString(logDateTime) } - LOG_RESET_SYS_V3.LOG_KIND -> { - val logItem = LOG_RESET_SYS_V3.parse(logDataToHexString) + LogResetSysV3.LOG_KIND -> { + val logItem = LogResetSysV3.parse(logDataToHexString) aapsLogger.debug(LTag.PUMPCOMM, "$logItem ") val logStartDate = DateUtils.parseDate(logItem.dttm, "yyyy-MM-dd HH:mm:ss") diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigMainInfoInquireResponsePacket.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigMainInfoInquireResponsePacket.kt index 7ee93e9a1f..ce67dc789d 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigMainInfoInquireResponsePacket.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/packet/BigMainInfoInquireResponsePacket.kt @@ -5,7 +5,7 @@ import info.nightscout.interfaces.pump.defs.PumpDescription import info.nightscout.interfaces.pump.defs.PumpType import info.nightscout.pump.diaconn.DiaconnG8Pump import info.nightscout.pump.diaconn.R -import info.nightscout.pump.diaconn.pumplog.PumplogUtil +import info.nightscout.pump.diaconn.pumplog.PumpLogUtil import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP @@ -213,7 +213,7 @@ class BigMainInfoInquireResponsePacket( diaconnG8Pump.pumpProfiles!![diaconnG8Pump.activeProfile][23] = diaconnG8Pump.baseAmount24 //incarnation no 처리 - diaconnG8Pump.isPumpVersionGe2_63 = PumplogUtil.isPumpVersionGe(sp.getString(rh.gs(R.string.pumpversion), ""), 2, 63) + diaconnG8Pump.isPumpVersionGe2_63 = PumpLogUtil.isPumpVersionGe(sp.getString(rh.gs(R.string.pumpversion), ""), 2, 63) aapsLogger.debug(LTag.PUMPCOMM, "result > " + diaconnG8Pump.result) aapsLogger.debug(LTag.PUMPCOMM, "systemRemainInsulin > " + diaconnG8Pump.systemRemainInsulin) diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_BATTERY.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmBattery.kt similarity index 68% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_BATTERY.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmBattery.kt index faf98ff078..75ad61dce4 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_BATTERY.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmBattery.kt @@ -6,7 +6,7 @@ import java.nio.ByteOrder /* * Battery Shortage Alarm Log */ -class LOG_ALARM_BATTERY private constructor( +class LogAlarmBattery private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 1=INFO, 2=WARNING, 3=MAJOR, 4=CRITICAL @@ -15,8 +15,8 @@ class LOG_ALARM_BATTERY private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_ALARM_BATTERY{") @@ -35,17 +35,17 @@ class LOG_ALARM_BATTERY private constructor( companion object { const val LOG_KIND: Byte = 0x28 - fun parse(data: String): LOG_ALARM_BATTERY { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogAlarmBattery { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_ALARM_BATTERY( + return LogAlarmBattery( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_BLOCK.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmBlock.kt similarity index 66% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_BLOCK.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmBlock.kt index 5b794a8843..dcfc0b8397 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_BLOCK.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmBlock.kt @@ -6,19 +6,19 @@ import java.nio.ByteOrder /* * Injection Blocked Alarm Log */ -class LOG_ALARM_BLOCK private constructor( +class LogAlarmBlock private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 1=INFO, 2=WARNING, 3=MAJOR, 4=CRITICAL - val alarmLevel: Byte, // 1=OCCUR - val ack: Byte, + private val alarmLevel: Byte, // 1=OCCUR + private val ack: Byte, val amount: Short, // 1=BASE, 2=Meal, 3=snack , 4=square, 5=dual, 6=tube change, 7=needle change, 8=insulin change val reason: Byte, val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_ALARM_BLOCK{") @@ -39,19 +39,19 @@ class LOG_ALARM_BLOCK private constructor( companion object { const val LOG_KIND: Byte = 0x29 - fun parse(data: String): LOG_ALARM_BLOCK { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogAlarmBlock { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_ALARM_BLOCK( + return LogAlarmBlock( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_SHORTAGE.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmShortAge.kt similarity index 63% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_SHORTAGE.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmShortAge.kt index 827d2a6622..89c6329332 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_ALARM_SHORTAGE.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogAlarmShortAge.kt @@ -6,18 +6,18 @@ import java.nio.ByteOrder /* * Insulin shortage alarm */ -class LOG_ALARM_SHORTAGE private constructor( +class LogAlarmShortAge private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 1=INFO, 2=WARNING, 3=MAJOR, 4=CRITICAL - val alarmLevel: Byte, // 1=OCCUR, 2=STOP - val ack: Byte, // (1~100U) + private val alarmLevel: Byte, // 1=OCCUR, 2=STOP + private val ack: Byte, // (1~100U) val remain: Byte, val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_ALARM_SHORTAGE{") @@ -37,18 +37,18 @@ class LOG_ALARM_SHORTAGE private constructor( companion object { const val LOG_KIND: Byte = 0x2A - fun parse(data: String): LOG_ALARM_SHORTAGE { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogAlarmShortAge { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_ALARM_SHORTAGE( + return LogAlarmShortAge( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_INJECTOR_SUCCESS.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeInjectorSuccess.kt similarity index 67% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_INJECTOR_SUCCESS.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeInjectorSuccess.kt index e0ae6a26c4..26ba1b3150 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_INJECTOR_SUCCESS.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeInjectorSuccess.kt @@ -6,7 +6,7 @@ import java.nio.ByteOrder /* * 주사기 교체 성공 */ -class LOG_CHANGE_INJECTOR_SUCCESS private constructor( +class LogChangeInjectorSuccess private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 @@ -15,8 +15,8 @@ class LOG_CHANGE_INJECTOR_SUCCESS private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_CHANGE_INJECTOR_SUCCESS{") @@ -35,17 +35,17 @@ class LOG_CHANGE_INJECTOR_SUCCESS private constructor( companion object { const val LOG_KIND: Byte = 0x1A - fun parse(data: String): LOG_CHANGE_INJECTOR_SUCCESS { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogChangeInjectorSuccess { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_CHANGE_INJECTOR_SUCCESS( + return LogChangeInjectorSuccess( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_NEEDLE_SUCCESS.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeNeedleSuccess.kt similarity index 66% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_NEEDLE_SUCCESS.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeNeedleSuccess.kt index 045a28e302..f69320fcc9 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_NEEDLE_SUCCESS.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeNeedleSuccess.kt @@ -6,7 +6,8 @@ import java.nio.ByteOrder /* * 바늘 공기빼기 성공 */ -class LOG_CHANGE_NEEDLE_SUCCESS private constructor( +@Suppress("SpellCheckingInspection") +class LogChangeNeedleSuccess private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 @@ -15,8 +16,8 @@ class LOG_CHANGE_NEEDLE_SUCCESS private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_CHANGE_NEEDLE_SUCCESS{") @@ -35,17 +36,17 @@ class LOG_CHANGE_NEEDLE_SUCCESS private constructor( companion object { const val LOG_KIND: Byte = 0x1C - fun parse(data: String): LOG_CHANGE_NEEDLE_SUCCESS { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogChangeNeedleSuccess { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_CHANGE_NEEDLE_SUCCESS( + return LogChangeNeedleSuccess( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_TUBE_SUCCESS.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeTubeSuccess.kt similarity index 66% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_TUBE_SUCCESS.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeTubeSuccess.kt index 84b57d3e87..d3a6025de9 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_CHANGE_TUBE_SUCCESS.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogChangeTubeSuccess.kt @@ -6,7 +6,8 @@ import java.nio.ByteOrder /* * 튜브 공기빼기 성공 */ -class LOG_CHANGE_TUBE_SUCCESS private constructor( +@Suppress("SpellCheckingInspection") +class LogChangeTubeSuccess private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 @@ -15,8 +16,8 @@ class LOG_CHANGE_TUBE_SUCCESS private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_CHANGE_TUBE_SUCCESS{") @@ -35,17 +36,17 @@ class LOG_CHANGE_TUBE_SUCCESS private constructor( companion object { const val LOG_KIND: Byte = 0x18 - fun parse(data: String): LOG_CHANGE_TUBE_SUCCESS { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogChangeTubeSuccess { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_CHANGE_TUBE_SUCCESS( + return LogChangeTubeSuccess( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_DUAL_FAIL.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectDualFail.kt similarity index 71% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_DUAL_FAIL.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectDualFail.kt index 8aa28434d7..c9197f2854 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_DUAL_FAIL.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectDualFail.kt @@ -7,7 +7,8 @@ import java.nio.ByteOrder /* * Dual Injection Fail Log */ -class LOG_INJECT_DUAL_FAIL private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectDualFail private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 @@ -18,8 +19,8 @@ class LOG_INJECT_DUAL_FAIL private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff @@ -44,19 +45,19 @@ class LOG_INJECT_DUAL_FAIL private constructor( companion object { const val LOG_KIND: Byte = 0x11 - fun parse(data: String): LOG_INJECT_DUAL_FAIL { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectDualFail { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECT_DUAL_FAIL( + return LogInjectDualFail( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_DUAL_SUCCESS.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectDualSuccess.kt similarity index 67% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_DUAL_SUCCESS.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectDualSuccess.kt index f5dd9d1638..3e0acd0b80 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_DUAL_SUCCESS.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectDualSuccess.kt @@ -7,18 +7,19 @@ import java.nio.ByteOrder /* * 듀얼주입 성공 */ -class LOG_INJECT_DUAL_SUCCESS private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectDualSuccess private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 - val injectNormAmount: Short, // 47.5=4750 + private val injectNormAmount: Short, // 47.5=4750 val injectSquareAmount: Short, // 1분단위 주입시간(124=124분=2시간4분) private val injectTime: Byte, val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff } @@ -41,18 +42,18 @@ class LOG_INJECT_DUAL_SUCCESS private constructor( companion object { const val LOG_KIND: Byte = 0x10 - fun parse(data: String): LOG_INJECT_DUAL_SUCCESS { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectDualSuccess { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECT_DUAL_SUCCESS( + return LogInjectDualSuccess( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_MEAL_FAIL.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectMealFail.kt similarity index 71% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_MEAL_FAIL.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectMealFail.kt index ab046f0e9f..a01640f6d1 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_MEAL_FAIL.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectMealFail.kt @@ -7,7 +7,8 @@ import java.nio.ByteOrder /* * 식사주입 실패 */ -class LOG_INJECT_MEAL_FAIL private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectMealFail private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 @@ -18,8 +19,8 @@ class LOG_INJECT_MEAL_FAIL private constructor( val reason: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff @@ -44,19 +45,19 @@ class LOG_INJECT_MEAL_FAIL private constructor( companion object { const val LOG_KIND: Byte = 0x09 - fun parse(data: String): LOG_INJECT_MEAL_FAIL { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectMealFail { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECT_MEAL_FAIL( + return LogInjectMealFail( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_MEAL_SUCCESS.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectMealSuccess.kt similarity index 67% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_MEAL_SUCCESS.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectMealSuccess.kt index e1292aae47..23cda27c74 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_MEAL_SUCCESS.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectMealSuccess.kt @@ -7,7 +7,8 @@ import java.nio.ByteOrder /* * 식사주입 성공 */ -class LOG_INJECT_MEAL_SUCCESS private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectMealSuccess private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 @@ -15,12 +16,11 @@ class LOG_INJECT_MEAL_SUCCESS private constructor( val injectAmount: Short, // 1분단위 주입시간(124=124분=2시간4분) private val injectTime: Byte, // 아침=1, 점심=2, 저녁=3 val time: Byte, - batteryRemain: Byte + val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) - val batteryRemain: Byte = batteryRemain + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff } @@ -44,19 +44,19 @@ class LOG_INJECT_MEAL_SUCCESS private constructor( companion object { const val LOG_KIND: Byte = 0x08 - fun parse(data: String): LOG_INJECT_MEAL_SUCCESS { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectMealSuccess { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECT_MEAL_SUCCESS( + return LogInjectMealSuccess( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_NORMAL_FAIL.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectNormalFail.kt similarity index 68% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_NORMAL_FAIL.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectNormalFail.kt index 71b0beb1d4..ca4e156085 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_NORMAL_FAIL.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectNormalFail.kt @@ -7,19 +7,20 @@ import java.nio.ByteOrder /* * 일반주입 실패 */ -class LOG_INJECT_NORMAL_FAIL private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectNormalFail private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 - val setAmount: Short, // 47.5=4750 + private val setAmount: Short, // 47.5=4750 val injectAmount: Short, // 1분단위 주입시간(124=124분=2시간4분) val injectTime: Byte, // 1=주입막힘, 2=배터리잔량부족, 3=약물부족, 4=사용자중지, 5=시스템리셋, 6=기타, 7=긴급정지 val reason: Byte, val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff @@ -44,19 +45,19 @@ class LOG_INJECT_NORMAL_FAIL private constructor( companion object { const val LOG_KIND: Byte = 0x0B - fun parse(data: String): LOG_INJECT_NORMAL_FAIL { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectNormalFail { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECT_NORMAL_FAIL( + return LogInjectNormalFail( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_NORMAL_SUCCESS.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectNormalSuccess.kt similarity index 66% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_NORMAL_SUCCESS.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectNormalSuccess.kt index 4692b7b8a0..6725145414 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_NORMAL_SUCCESS.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectNormalSuccess.kt @@ -7,18 +7,19 @@ import java.nio.ByteOrder /* * 일반주입 성공 */ -class LOG_INJECT_NORMAL_SUCCESS private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectNormalSuccess private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 - val setAmount: Short, // 47.5=4750 + private val setAmount: Short, // 47.5=4750 val injectAmount: Short, // 1분단위 주입시간(124=124분=2시간4분) val injectTime: Byte, val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff } @@ -41,18 +42,18 @@ class LOG_INJECT_NORMAL_SUCCESS private constructor( companion object { const val LOG_KIND: Byte = 0x0A - fun parse(data: String): LOG_INJECT_NORMAL_SUCCESS { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectNormalSuccess { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECT_NORMAL_SUCCESS( + return LogInjectNormalSuccess( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_SQUARE_FAIL.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectSquareFail.kt similarity index 70% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_SQUARE_FAIL.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectSquareFail.kt index c815dfec45..31c910307d 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_SQUARE_FAIL.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectSquareFail.kt @@ -7,7 +7,8 @@ import java.nio.ByteOrder /* * 스퀘어주입 실패 */ -class LOG_INJECT_SQUARE_FAIL private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectSquareFail private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 @@ -17,8 +18,8 @@ class LOG_INJECT_SQUARE_FAIL private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff @@ -42,18 +43,18 @@ class LOG_INJECT_SQUARE_FAIL private constructor( companion object { const val LOG_KIND: Byte = 0x0E - fun parse(data: String): LOG_INJECT_SQUARE_FAIL { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectSquareFail { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECT_SQUARE_FAIL( + return LogInjectSquareFail( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_SQUARE_SUCCESS.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectSquareSuccess.kt similarity index 64% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_SQUARE_SUCCESS.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectSquareSuccess.kt index e76fe57c06..0d1a2181e2 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECT_SQUARE_SUCCESS.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectSquareSuccess.kt @@ -7,17 +7,18 @@ import java.nio.ByteOrder /* * 스퀘어주입 성공 */ -class LOG_INJECT_SQUARE_SUCCESS private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectSquareSuccess private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 - val injectAmount: Short, // 1분단위 주입시간(124=124분=2시간4분) + private val injectAmount: Short, // 1분단위 주입시간(124=124분=2시간4분) private val injectTime: Byte, val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff } @@ -39,17 +40,17 @@ class LOG_INJECT_SQUARE_SUCCESS private constructor( companion object { const val LOG_KIND: Byte = 0x0D - fun parse(data: String): LOG_INJECT_SQUARE_SUCCESS { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectSquareSuccess { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECT_SQUARE_SUCCESS( + return LogInjectSquareSuccess( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1DAY.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1Day.kt similarity index 68% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1DAY.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1Day.kt index 4d536a6194..2dc31d9e47 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1DAY.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1Day.kt @@ -6,7 +6,8 @@ import java.nio.ByteOrder /* * 당일 주입 총량 (식사, 추가) */ -class LOG_INJECTION_1DAY private constructor( +@Suppress("SpellCheckingInspection") +class LogInjection1Day private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 당일 식사주입 총량 47.5=4750 @@ -15,8 +16,8 @@ class LOG_INJECTION_1DAY private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_INJECTION_1DAY{") @@ -35,17 +36,17 @@ class LOG_INJECTION_1DAY private constructor( companion object { const val LOG_KIND: Byte = 0x2F - fun parse(data: String): LOG_INJECTION_1DAY { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjection1Day { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECTION_1DAY( + return LogInjection1Day( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1DAY_BASAL.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1DayBasal.kt similarity index 66% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1DAY_BASAL.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1DayBasal.kt index 9c8a47fc37..2c90363850 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1DAY_BASAL.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1DayBasal.kt @@ -6,7 +6,8 @@ import java.nio.ByteOrder /* * 당일 주입 총량 (기저) */ -class LOG_INJECTION_1DAY_BASAL private constructor( +@Suppress("SpellCheckingInspection") +class LogInjection1DayBasal private constructor( val data: String, val dttm: String, typeAndKind: Byte, @@ -15,8 +16,8 @@ class LOG_INJECTION_1DAY_BASAL private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_INJECTION_1DAY_BASAL{") @@ -33,16 +34,16 @@ class LOG_INJECTION_1DAY_BASAL private constructor( companion object { const val LOG_KIND: Byte = 0x2E - fun parse(data: String): LOG_INJECTION_1DAY_BASAL { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjection1DayBasal { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECTION_1DAY_BASAL( + return LogInjection1DayBasal( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1HOUR_BASAL.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1HourBasal.kt similarity index 74% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1HOUR_BASAL.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1HourBasal.kt index ea0663d07b..c09820b992 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_1HOUR_BASAL.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjection1HourBasal.kt @@ -6,7 +6,8 @@ import java.nio.ByteOrder /* * 1시간 단위 기저 주입량 */ -class LOG_INJECTION_1HOUR_BASAL private constructor( +@Suppress("SpellCheckingInspection") +class LogInjection1HourBasal private constructor( val data: String, val dttm: String, typeAndKind: Byte, @@ -17,8 +18,8 @@ class LOG_INJECTION_1HOUR_BASAL private constructor( private val remainTotalAmount: Short ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) val beforeAmount // 해당시간의 임시기저 계산 전 기저주입량: 기저주입막힘 발생 시 기저주입 막힘량 제외, 기저정지로 인해 주입되지 않은 량 제외, 리셋으로 인해 주입되지 않은 량 제외(47.5=4750) : Short = tbBeforeAmount val afterAmount // 해당시간의 임시기저 계산 후 기저주입량: 기저주입막힘 발생 시 기저주입 막힘량 제외, 기저정지로 인해 주입되지 않은 량 제외, 리셋으로 인해 주입되지 않은 량 제외(47.5=4750) @@ -42,18 +43,18 @@ class LOG_INJECTION_1HOUR_BASAL private constructor( companion object { const val LOG_KIND: Byte = 0x2C - fun parse(data: String): LOG_INJECTION_1HOUR_BASAL { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjection1HourBasal { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECTION_1HOUR_BASAL( + return LogInjection1HourBasal( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_DUAL_NORMAL.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectionDualNormal.kt similarity index 67% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_DUAL_NORMAL.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectionDualNormal.kt index ce46ea8bfd..95f9fb19b5 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_INJECTION_DUAL_NORMAL.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogInjectionDualNormal.kt @@ -7,18 +7,19 @@ import java.nio.ByteOrder /* * 듀얼(일반) 주입량: 듀얼(일반) 주입 완료 시 기록하는 방식 */ -class LOG_INJECTION_DUAL_NORMAL private constructor( +@Suppress("SpellCheckingInspection") +class LogInjectionDualNormal private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 설정량 47.5=4750 - val setAmount: Short, // 주입량 47.5=4750 + private val setAmount: Short, // 주입량 47.5=4750 val injectAmount: Short, // 1분 단위 주입 시간 Ex) 124 = 124분 = 2시간 4분 private val injectTime: Byte, val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff } @@ -41,18 +42,18 @@ class LOG_INJECTION_DUAL_NORMAL private constructor( companion object { const val LOG_KIND: Byte = 0x35 - fun parse(data: String): LOG_INJECTION_DUAL_NORMAL { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogInjectionDualNormal { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_INJECTION_DUAL_NORMAL( + return LogInjectionDualNormal( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_RESET_SYS_V3.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogResetSysV3.kt similarity index 62% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_RESET_SYS_V3.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogResetSysV3.kt index 491fdf04bb..a47ba43e0d 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_RESET_SYS_V3.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogResetSysV3.kt @@ -6,18 +6,19 @@ import java.nio.ByteOrder /* * System Reset Log */ -class LOG_RESET_SYS_V3 private constructor( +@Suppress("SpellCheckingInspection") +class LogResetSysV3 private constructor( val data: String, val dttm: String, typeAndKind: Byte, val batteryRemain: Byte, val reason: Byte, // 사유(1:공장초기화 후 리셋, 2:긴급정지 해제 후 리셋, 3:사용자 배터리 교체 후 리셋, 4:캘리브레이션 후 리셋, 9:예상치 못한 시스템 리셋) - val rcon1: Short, // PIC 데이터 시트 내 정의된 2바이트 값 - val rcon2: Short // PIC 데이터 시트 내 정의된 2바이트 값 + private val rcon1: Short, // PIC 데이터 시트 내 정의된 2바이트 값 + private val rcon2: Short // PIC 데이터 시트 내 정의된 2바이트 값 ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_RESET_SYS_V3{") @@ -37,18 +38,18 @@ class LOG_RESET_SYS_V3 private constructor( companion object { const val LOG_KIND: Byte = 0x01 - fun parse(data: String): LOG_RESET_SYS_V3 { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogResetSysV3 { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_RESET_SYS_V3( + return LogResetSysV3( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SET_DUAL_INJECTION.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSetDualInjection.kt similarity index 66% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SET_DUAL_INJECTION.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSetDualInjection.kt index c90acc008b..daedf5c04c 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SET_DUAL_INJECTION.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSetDualInjection.kt @@ -7,18 +7,19 @@ import java.nio.ByteOrder /* * 듀얼주입 설정(시작) */ -class LOG_SET_DUAL_INJECTION private constructor( +@Suppress("SpellCheckingInspection") +class LogSetDualInjection private constructor( val data: String, val dttm: String, typeAndKind: Byte, - val setNormAmount: Short, // 47.5=4750 + private val setNormAmount: Short, // 47.5=4750 val setSquareAmount: Short, // 47.5=4750 private val injectTime: Byte, // 1~30( 1: 10min ) val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff } @@ -41,18 +42,18 @@ class LOG_SET_DUAL_INJECTION private constructor( companion object { const val LOG_KIND: Byte = 0x0F - fun parse(data: String): LOG_SET_DUAL_INJECTION { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogSetDualInjection { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_SET_DUAL_INJECTION( + return LogSetDualInjection( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SET_SQUARE_INJECTION.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSetSquareInjection.kt similarity index 68% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SET_SQUARE_INJECTION.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSetSquareInjection.kt index 4c315da683..6ad23e0439 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SET_SQUARE_INJECTION.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSetSquareInjection.kt @@ -7,7 +7,8 @@ import java.nio.ByteOrder /* * 스퀘어주입 설정(시작) */ -class LOG_SET_SQUARE_INJECTION private constructor( +@Suppress("SpellCheckingInspection") +class LogSetSquareInjection private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 47.5=4750 @@ -16,8 +17,8 @@ class LOG_SET_SQUARE_INJECTION private constructor( val batteryRemain: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getInjectTime(): Int { return injectTime and 0xff } @@ -39,17 +40,17 @@ class LOG_SET_SQUARE_INJECTION private constructor( companion object { const val LOG_KIND: Byte = 0x0C - fun parse(data: String): LOG_SET_SQUARE_INJECTION { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogSetSquareInjection { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_SET_SQUARE_INJECTION( + return LogSetSquareInjection( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SUSPEND_RELEASE_V2.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSuspendReleaseV2.kt similarity index 73% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SUSPEND_RELEASE_V2.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSuspendReleaseV2.kt index b10961e883..e53445912c 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SUSPEND_RELEASE_V2.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSuspendReleaseV2.kt @@ -6,7 +6,8 @@ import java.nio.ByteOrder /* * 일시정지 중지 (기저정지 해제) */ -class LOG_SUSPEND_RELEASE_V2 private constructor( +@Suppress("SpellCheckingInspection") +class LogSuspendReleaseV2 private constructor( val data: String, val dttm: String, typeAndKind: Byte, @@ -17,7 +18,7 @@ class LOG_SUSPEND_RELEASE_V2 private constructor( val type: Byte val kind: Byte val batteryRemain: Byte - val patternType // 1=기본, 2=생활1, 3=생활2, 4=생활3, 5=닥터1, 6=닥터2 + private val patternType // 1=기본, 2=생활1, 3=생활2, 4=생활3, 5=닥터1, 6=닥터2 : Byte override fun toString(): String { @@ -48,23 +49,23 @@ class LOG_SUSPEND_RELEASE_V2 private constructor( companion object { const val LOG_KIND: Byte = 0x04 - fun parse(data: String): LOG_SUSPEND_RELEASE_V2 { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogSuspendReleaseV2 { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_SUSPEND_RELEASE_V2( + return LogSuspendReleaseV2( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } init { - type = PumplogUtil.getType(typeAndKind) - kind = PumplogUtil.getKind(typeAndKind) + type = PumpLogUtil.getType(typeAndKind) + kind = PumpLogUtil.getKind(typeAndKind) this.batteryRemain = batteryRemain this.patternType = patternType } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SUSPEND_V2.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSuspendV2.kt similarity index 73% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SUSPEND_V2.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSuspendV2.kt index 7a1dc061c8..0daf0acaea 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_SUSPEND_V2.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogSuspendV2.kt @@ -6,16 +6,17 @@ import java.nio.ByteOrder /* * 일시정지 시작 (기저정지) */ -class LOG_SUSPEND_V2 private constructor( +@Suppress("SpellCheckingInspection") +class LogSuspendV2 private constructor( val data: String, val dttm: String, typeAndKind: Byte, val batteryRemain: Byte, // 1=기본, 2=생활1, 3=생활2, 4=생활3, 5=닥터1, 6=닥터2 - val patternType: Byte + private val patternType: Byte ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) override fun toString(): String { val sb = StringBuilder("LOG_SUSPEND_V2{") @@ -46,16 +47,16 @@ class LOG_SUSPEND_V2 private constructor( companion object { const val LOG_KIND: Byte = 0x03 - fun parse(data: String): LOG_SUSPEND_V2 { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogSuspendV2 { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_SUSPEND_V2( + return LogSuspendV2( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_TB_START_V3.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogTbStartV3.kt similarity index 72% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_TB_START_V3.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogTbStartV3.kt index 8f54222df8..09d3e7897f 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_TB_START_V3.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogTbStartV3.kt @@ -8,7 +8,8 @@ import java.nio.ByteOrder /* * 임시기저 설정(시작) */ -class LOG_TB_START_V3 private constructor( +@Suppress("SpellCheckingInspection") +class LogTbStartV3 private constructor( val data: String, val dttm: String, typeAndKind: Byte, // 임시기저 시간(30분 ~ 24시간, 2 ~ 96, 1당 15분 단위 증감) @@ -17,8 +18,8 @@ class LOG_TB_START_V3 private constructor( private val tbDttm: String // 앱에서 생성 전달한 임시기저 시작(요청) 시간 ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getTbInjectRateRatio(): Int { return tbInjectRateRatio and 0xffff @@ -33,7 +34,7 @@ class LOG_TB_START_V3 private constructor( sb.append(", kind=").append(kind.toInt()) sb.append(", tbTime=").append(tbTime.toInt()) sb.append(", tbInjectRateRatio=").append(tbInjectRateRatio and 0xffff) - if (!StringUtils.equals(tbDttm, PumplogUtil.getDttm("ffffffff"))) { + if (!StringUtils.equals(tbDttm, PumpLogUtil.getDttm("ffffffff"))) { sb.append(", tbDttm=").append(tbDttm) } sb.append('}') @@ -43,17 +44,17 @@ class LOG_TB_START_V3 private constructor( companion object { const val LOG_KIND: Byte = 0x12 - fun parse(data: String): LOG_TB_START_V3 { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogTbStartV3 { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_TB_START_V3( + return LogTbStartV3( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getDttm(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getDttm(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_TB_STOP_V3.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogTbStopV3.kt similarity index 72% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_TB_STOP_V3.kt rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogTbStopV3.kt index 51080f95bb..1b4bff1be5 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LOG_TB_STOP_V3.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/LogTbStopV3.kt @@ -8,7 +8,8 @@ import java.nio.ByteOrder /* * 임시기저 중지(완료) */ -class LOG_TB_STOP_V3 private constructor( +@Suppress("SpellCheckingInspection") +class LogTbStopV3 private constructor( val data: String, val dttm: String, typeAndKind: Byte, @@ -20,8 +21,8 @@ class LOG_TB_STOP_V3 private constructor( private val tbDttm: String ) { - val type: Byte = PumplogUtil.getType(typeAndKind) - val kind: Byte = PumplogUtil.getKind(typeAndKind) + val type: Byte = PumpLogUtil.getType(typeAndKind) + val kind: Byte = PumpLogUtil.getKind(typeAndKind) fun getTbInjectRateRatio(): Int { return tbInjectRateRatio and 0xffff @@ -36,7 +37,7 @@ class LOG_TB_STOP_V3 private constructor( sb.append(", kind=").append(kind.toInt()) sb.append(", tbInjectRateRatio=").append(tbInjectRateRatio and 0xffff) sb.append(", reason=").append(reason.toInt()) - if (!StringUtils.equals(tbDttm, PumplogUtil.getDttm("ffffffff"))) { + if (!StringUtils.equals(tbDttm, PumpLogUtil.getDttm("ffffffff"))) { sb.append(", tbDttm=").append(tbDttm) } sb.append('}') @@ -46,17 +47,17 @@ class LOG_TB_STOP_V3 private constructor( companion object { const val LOG_KIND: Byte = 0x13 - fun parse(data: String): LOG_TB_STOP_V3 { - val bytes = PumplogUtil.hexStringToByteArray(data) + fun parse(data: String): LogTbStopV3 { + val bytes = PumpLogUtil.hexStringToByteArray(data) val buffer = ByteBuffer.wrap(bytes) buffer.order(ByteOrder.LITTLE_ENDIAN) - return LOG_TB_STOP_V3( + return LogTbStopV3( data, - PumplogUtil.getDttm(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getShort(buffer), - PumplogUtil.getByte(buffer), - PumplogUtil.getDttm(buffer) + PumpLogUtil.getDttm(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getShort(buffer), + PumpLogUtil.getByte(buffer), + PumpLogUtil.getDttm(buffer) ) } } diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/PumplogUtil.java b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/PumpLogUtil.java similarity index 96% rename from pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/PumplogUtil.java rename to pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/PumpLogUtil.java index c458aba743..27ea305112 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/PumplogUtil.java +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/pumplog/PumpLogUtil.java @@ -13,7 +13,8 @@ import java.util.TimeZone; /* * 디아콘 G8 펌프 로그 유틸리티 클래스 */ -public class PumplogUtil { +@SuppressWarnings({"CommentedOutCode", "SpellCheckingInspection"}) +public class PumpLogUtil { /* * 바이트버퍼에서 4바이트 날짜를 구한다. * @param buffer 바이트버퍼 @@ -39,7 +40,7 @@ public class PumplogUtil { */ @SuppressLint("SimpleDateFormat") public static String getDttm(String data) { - byte[] bytes = PumplogUtil.hexStringToByteArray(data); + byte[] bytes = PumpLogUtil.hexStringToByteArray(data); byte b0 = bytes[0]; byte b1 = bytes[1]; byte b2 = bytes[2]; @@ -74,9 +75,11 @@ public class PumplogUtil { * @param buffer 바이트버퍼 * @return int */ + /* public static int getInt(ByteBuffer buffer) { return buffer.getInt(); } + */ /* * 로그데이터에서 로그 타입 바이트를 구한다. @@ -136,12 +139,14 @@ public class PumplogUtil { * @param data 1970.1.1이후 경과한 초 * @return 날짜(GMT기준) */ + /* public static Date pumpTimeToGMTDate(Integer data) { long epochTime = new Date(0).getTime(); // 1970-01-01 long pumpTime = data.longValue() * 1000; // 초를 밀리초 단위로 변환 int timeZoneOffset = TimeZone.getDefault().getRawOffset(); // GMT와 로컬 타임존 사이의 차이 return new Date(epochTime + pumpTime - timeZoneOffset); } + */ /* * 펌프 버전이 해당 버전보다 크거나 같은지 여부 확인(새로운 기능이 추가된 버전을 체크하기 위함) diff --git a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/DiaconnG8Service.kt b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/DiaconnG8Service.kt index ca627bb3fd..d412ab138f 100644 --- a/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/DiaconnG8Service.kt +++ b/pump/diaconn/src/main/java/info/nightscout/pump/diaconn/service/DiaconnG8Service.kt @@ -57,7 +57,7 @@ import info.nightscout.pump.diaconn.packet.TempBasalInquirePacket import info.nightscout.pump.diaconn.packet.TempBasalSettingPacket import info.nightscout.pump.diaconn.packet.TimeInquirePacket import info.nightscout.pump.diaconn.packet.TimeSettingPacket -import info.nightscout.pump.diaconn.pumplog.PumplogUtil +import info.nightscout.pump.diaconn.pumplog.PumpLogUtil import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventAppExit @@ -168,7 +168,7 @@ class DiaconnG8Service : DaggerService() { val pumpFirmwareVersion = sp.getString(rh.gs(R.string.pumpversion), "") - if (pumpFirmwareVersion.isNotEmpty() && PumplogUtil.isPumpVersionGe(pumpFirmwareVersion, 3, 0)) { + if (pumpFirmwareVersion.isNotEmpty() && PumpLogUtil.isPumpVersionGe(pumpFirmwareVersion, 3, 0)) { sendMessage(BigAPSMainInfoInquirePacket(injector)) // APS Pump Main Info } else { sendMessage(BasalLimitInquirePacket(injector)) // basal Limit diff --git a/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicPumpPlugin.kt b/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicPumpPlugin.kt index 5aa76055f7..defdbf9c45 100644 --- a/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicPumpPlugin.kt +++ b/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/MedtronicPumpPlugin.kt @@ -216,10 +216,6 @@ class MedtronicPumpPlugin @Inject constructor( } } - override fun hasService(): Boolean { - return true - } - override fun onStartScheduledPumpActions() { // check status every minute (if any status needs refresh we send readStatus command) diff --git a/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/util/MedtronicUtil.kt b/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/util/MedtronicUtil.kt index 34fe0eafa5..2e53e74990 100644 --- a/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/util/MedtronicUtil.kt +++ b/pump/medtronic/src/main/java/info/nightscout/androidaps/plugins/pump/medtronic/util/MedtronicUtil.kt @@ -1,5 +1,6 @@ package info.nightscout.androidaps.plugins.pump.medtronic.util +import com.google.gson.Gson import com.google.gson.GsonBuilder import info.nightscout.androidaps.plugins.pump.common.events.EventRileyLinkDeviceStatusChange import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.RileyLinkUtil @@ -18,13 +19,13 @@ import info.nightscout.rx.events.EventDismissNotification import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper -import org.joda.time.LocalTime import java.nio.ByteBuffer import java.nio.ByteOrder import java.util.Locale import javax.inject.Inject import javax.inject.Singleton import kotlin.experimental.or +import kotlin.math.abs /** * Created by andy on 5/9/18. @@ -38,39 +39,41 @@ class MedtronicUtil @Inject constructor( private val uiInteraction: UiInteraction ) { + @Suppress("PrivatePropertyName") private val ENVELOPE_SIZE = 4 // 0xA7 S1 S2 S3 CMD PARAM_COUNT [PARAMS] //private MedtronicDeviceType medtronicPumpModel; private var currentCommand: MedtronicCommandType? = null var settings: Map? = null + @Suppress("PrivatePropertyName") private val BIG_FRAME_LENGTH = 65 - private val doneBit = 1 shl 7 + //private val doneBit = 1 shl 7 var pumpTime: ClockDTO? = null - var gsonInstance = GsonBuilder().excludeFieldsWithoutExposeAnnotation().create() + var gsonInstance: Gson = GsonBuilder().excludeFieldsWithoutExposeAnnotation().create() - fun getTimeFrom30MinInterval(interval: Int): LocalTime { - return if (interval % 2 == 0) { - LocalTime(interval / 2, 0) - } else { - LocalTime((interval - 1) / 2, 30) - } - } + // fun getTimeFrom30MinInterval(interval: Int): LocalTime { + // return if (interval % 2 == 0) { + // LocalTime(interval / 2, 0) + // } else { + // LocalTime((interval - 1) / 2, 30) + // } + // } - fun decodeBasalInsulin(i: Int, j: Int): Double { - return decodeBasalInsulin(makeUnsignedShort(i, j)) - } + // fun decodeBasalInsulin(i: Int, j: Int): Double { + // return decodeBasalInsulin(makeUnsignedShort(i, j)) + // } - fun decodeBasalInsulin(i: Int): Double { - return i.toDouble() / 40.0 - } + // fun decodeBasalInsulin(i: Int): Double { + // return i.toDouble() / 40.0 + // } - fun getBasalStrokes(amount: Double): ByteArray { - return getBasalStrokes(amount, false) - } + // fun getBasalStrokes(amount: Double): ByteArray { + // return getBasalStrokes(amount, false) + // } - fun getBasalStrokesInt(amount: Double): Int { - return getStrokesInt(amount, 40) - } + // fun getBasalStrokesInt(amount: Double): Int { + // return getStrokesInt(amount, 40) + // } fun getBolusStrokes(amount: Double): ByteArray { val strokesPerUnit = medtronicPumpStatus.medtronicDeviceType.bolusStrokes @@ -89,17 +92,17 @@ class MedtronicUtil @Inject constructor( return ByteUtil.fromHexString(String.format("%02x%0" + 2 * length + "x", length, strokes)) } - fun createCommandBody(input: ByteArray): ByteArray { - return ByteUtil.concat(input.size.toByte(), input) - } + // fun createCommandBody(input: ByteArray): ByteArray { + // return ByteUtil.concat(input.size.toByte(), input) + // } - fun sendNotification(notificationType: MedtronicNotificationType, rh: ResourceHelper) { - uiInteraction.addNotification( - notificationType.notificationType, - rh.gs(notificationType.resourceId), - notificationType.notificationUrgency - ) - } + // fun sendNotification(notificationType: MedtronicNotificationType, rh: ResourceHelper) { + // uiInteraction.addNotification( + // notificationType.notificationType, + // rh.gs(notificationType.resourceId), + // notificationType.notificationUrgency + // ) + // } fun sendNotification(notificationType: MedtronicNotificationType, rh: ResourceHelper, vararg parameters: Any?) { uiInteraction.addNotification( @@ -117,7 +120,7 @@ class MedtronicUtil @Inject constructor( return buildCommandPayload(rileyLinkServiceData, commandType.commandCode, parameters) } - fun buildCommandPayload(rileyLinkServiceData: RileyLinkServiceData, commandType: Byte, parameters: ByteArray?): ByteArray { + private fun buildCommandPayload(rileyLinkServiceData: RileyLinkServiceData, commandType: Byte, parameters: ByteArray?): ByteArray { // A7 31 65 51 C0 00 52 val commandLength = (if (parameters == null) 2 else 2 + parameters.size).toByte() val sendPayloadBuffer = ByteBuffer.allocate(ENVELOPE_SIZE + commandLength) // + CRC_SIZE @@ -283,12 +286,13 @@ class MedtronicUtil @Inject constructor( return getStrokes(amount, 40, returnFixedSize) } - fun getStrokes(amount: Double, strokesPerUnit: Int, returnFixedSize: Boolean): ByteArray { + @Suppress("SameParameterValue") + private fun getStrokes(amount: Double, strokesPerUnit: Int, returnFixedSize: Boolean): ByteArray { val strokes = getStrokesInt(amount, strokesPerUnit) return getByteArrayFromUnsignedShort(strokes, returnFixedSize) } - fun getStrokesInt(amount: Double, strokesPerUnit: Int): Int { + private fun getStrokesInt(amount: Double, strokesPerUnit: Int): Int { //var length = 1 var scrollRate = 1 if (strokesPerUnit >= 40) { @@ -304,7 +308,7 @@ class MedtronicUtil @Inject constructor( fun isSame(d1: Double, d2: Double): Boolean { val diff = d1 - d2 - return Math.abs(diff) <= 0.000001 + return abs(diff) <= 0.000001 } } diff --git a/pump/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/session/Milenage.kt b/pump/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/session/Milenage.kt index c06c5a3410..15e6477d15 100644 --- a/pump/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/session/Milenage.kt +++ b/pump/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/session/Milenage.kt @@ -1,5 +1,6 @@ package info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.comm.session +import android.annotation.SuppressLint import info.nightscout.core.utils.toHex import info.nightscout.interfaces.Config import info.nightscout.rx.logging.AAPSLogger @@ -10,8 +11,8 @@ import javax.crypto.Cipher import javax.crypto.spec.SecretKeySpec class Milenage( - private val aapsLogger: AAPSLogger, - private val config: Config, + aapsLogger: AAPSLogger, + config: Config, private val k: ByteArray, val sqn: ByteArray, randParam: ByteArray? = null, @@ -30,6 +31,7 @@ class Milenage( } private val secretKeySpec = SecretKeySpec(k, "AES") + @SuppressLint("GetInstance") private val cipher: Cipher = Cipher.getInstance("AES/ECB/NoPadding") init { @@ -123,9 +125,10 @@ class Milenage( } } + @Suppress("SpellCheckingInspection") companion object { - val RESYNC_AMF = Hex.decode("0000") + val RESYNC_AMF: ByteArray = Hex.decode("0000") private val MILENAGE_OP = Hex.decode("cdc202d5123e20f62b6d676ac72cb318") private val MILENAGE_AMF = Hex.decode("b9b9") const val KEY_SIZE = 16 diff --git a/pump/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/pod/state/OmnipodDashPodStateManagerImpl.kt b/pump/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/pod/state/OmnipodDashPodStateManagerImpl.kt index b28bbc8036..9eef681ae6 100644 --- a/pump/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/pod/state/OmnipodDashPodStateManagerImpl.kt +++ b/pump/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/pod/state/OmnipodDashPodStateManagerImpl.kt @@ -2,7 +2,6 @@ package info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.pod.state import android.os.SystemClock import com.google.gson.Gson -import info.nightscout.interfaces.pump.DetailedBolusInfo import info.nightscout.androidaps.plugins.pump.omnipod.dash.EventOmnipodDashPumpValuesChanged import info.nightscout.androidaps.plugins.pump.omnipod.dash.R import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.comm.Id @@ -20,6 +19,7 @@ import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.pod.response. import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.pod.response.DefaultStatusResponse import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.pod.response.SetUniqueIdResponse import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.pod.response.VersionResponse +import info.nightscout.interfaces.pump.DetailedBolusInfo import info.nightscout.interfaces.utils.Round import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.AAPSLogger @@ -437,7 +437,7 @@ class OmnipodDashPodStateManagerImpl @Inject constructor( } @Synchronized - override fun updateActiveCommand() = Maybe.create { source -> + override fun updateActiveCommand(): Maybe = Maybe.create { source -> val activeCommand = podState.activeCommand if (activeCommand == null) { logger.error(LTag.PUMPCOMM, "No active command to update") @@ -515,6 +515,7 @@ class OmnipodDashPodStateManagerImpl @Inject constructor( "lastResponse=$lastStatusResponseReceived " + "$sequenceNumberOfLastProgrammingCommand $historyId" ) + @Suppress("KotlinConstantConditions") when { createdRealtime <= podState.lastStatusResponseReceived && sequence == podState.sequenceNumberOfLastProgrammingCommand -> diff --git a/pump/omnipod-eros/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/eros/extensions/PumpStateExtension.kt b/pump/omnipod-eros/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/eros/extensions/PumpStateExtension.kt index a12532c9de..001440a4f4 100644 --- a/pump/omnipod-eros/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/eros/extensions/PumpStateExtension.kt +++ b/pump/omnipod-eros/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/eros/extensions/PumpStateExtension.kt @@ -1,4 +1,4 @@ -package info.nightscout.core.pump +package info.nightscout.androidaps.plugins.pump.omnipod.eros.extensions import info.nightscout.interfaces.pump.PumpSync import kotlin.math.ceil diff --git a/pump/omnipod-eros/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/eros/manager/AapsOmnipodErosManager.java b/pump/omnipod-eros/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/eros/manager/AapsOmnipodErosManager.java index 8c1584c2c9..8af0a35161 100644 --- a/pump/omnipod-eros/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/eros/manager/AapsOmnipodErosManager.java +++ b/pump/omnipod-eros/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/eros/manager/AapsOmnipodErosManager.java @@ -56,12 +56,12 @@ import info.nightscout.androidaps.plugins.pump.omnipod.eros.driver.manager.ErosP import info.nightscout.androidaps.plugins.pump.omnipod.eros.driver.manager.OmnipodManager; import info.nightscout.androidaps.plugins.pump.omnipod.eros.event.EventOmnipodErosPumpValuesChanged; import info.nightscout.androidaps.plugins.pump.omnipod.eros.extensions.DetailedBolusInfoExtensionKt; +import info.nightscout.androidaps.plugins.pump.omnipod.eros.extensions.PumpStateExtensionKt; import info.nightscout.androidaps.plugins.pump.omnipod.eros.history.ErosHistory; import info.nightscout.androidaps.plugins.pump.omnipod.eros.history.database.ErosHistoryRecordEntity; import info.nightscout.androidaps.plugins.pump.omnipod.eros.rileylink.manager.OmnipodRileyLinkCommunicationManager; import info.nightscout.androidaps.plugins.pump.omnipod.eros.util.AapsOmnipodUtil; import info.nightscout.androidaps.plugins.pump.omnipod.eros.util.OmnipodAlertUtil; -import info.nightscout.core.pump.PumpStateExtensionKt; import info.nightscout.interfaces.notifications.Notification; import info.nightscout.interfaces.profile.Profile; import info.nightscout.interfaces.pump.DetailedBolusInfo; diff --git a/pump/pump-common/src/main/java/info/nightscout/pump/common/PumpPluginAbstract.kt b/pump/pump-common/src/main/java/info/nightscout/pump/common/PumpPluginAbstract.kt index 22a21e56df..25b3957678 100644 --- a/pump/pump-common/src/main/java/info/nightscout/pump/common/PumpPluginAbstract.kt +++ b/pump/pump-common/src/main/java/info/nightscout/pump/common/PumpPluginAbstract.kt @@ -4,6 +4,7 @@ import android.content.Context import android.content.Intent import android.content.ServiceConnection import android.text.format.DateFormat +import com.google.gson.Gson import com.google.gson.GsonBuilder import dagger.android.HasAndroidInjector import info.nightscout.core.utils.fabric.FabricPrivacy @@ -26,6 +27,7 @@ import info.nightscout.interfaces.utils.DecimalFormatter.to2Decimal import info.nightscout.pump.common.data.PumpStatus import info.nightscout.pump.common.defs.PumpDriverState import info.nightscout.pump.common.sync.PumpDbEntryCarbs +import info.nightscout.pump.common.sync.PumpSyncEntriesCreator import info.nightscout.pump.common.sync.PumpSyncStorage import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus @@ -61,7 +63,7 @@ abstract class PumpPluginAbstract protected constructor( var aapsSchedulers: AapsSchedulers, var pumpSync: PumpSync, var pumpSyncStorage: PumpSyncStorage -) : PumpPluginBase(pluginDescription, injector, aapsLogger, rh, commandQueue), Pump, Constraints, info.nightscout.pump.common.sync.PumpSyncEntriesCreator { +) : PumpPluginBase(pluginDescription, injector, aapsLogger, rh, commandQueue), Pump, Constraints, PumpSyncEntriesCreator { protected val disposable = CompositeDisposable() @@ -80,24 +82,21 @@ abstract class PumpPluginAbstract protected constructor( pumpDescription.fillFor(value) } - protected var gson = GsonBuilder().excludeFieldsWithoutExposeAnnotation().create() + protected var gson: Gson = GsonBuilder().excludeFieldsWithoutExposeAnnotation().create() abstract fun initPumpStatusData() - open fun hasService(): Boolean { - return true - } - override fun onStart() { super.onStart() initPumpStatusData() - if (hasService()) { + serviceConnection?.let { serviceConnection -> val intent = Intent(context, serviceClass) - context.bindService(intent, serviceConnection!!, Context.BIND_AUTO_CREATE) - disposable.add(rxBus - .toObservable(EventAppExit::class.java) - .observeOn(aapsSchedulers.io) - .subscribe({ _ -> context.unbindService(serviceConnection!!) }) { throwable: Throwable? -> fabricPrivacy.logException(throwable!!) } + context.bindService(intent, serviceConnection, Context.BIND_AUTO_CREATE) + disposable.add( + rxBus + .toObservable(EventAppExit::class.java) + .observeOn(aapsSchedulers.io) + .subscribe({ context.unbindService(serviceConnection) }, fabricPrivacy::logException) ) } serviceRunning = true @@ -106,8 +105,8 @@ abstract class PumpPluginAbstract protected constructor( override fun onStop() { aapsLogger.debug(LTag.PUMP, model().model + " onStop()") - if (hasService()) { - context.unbindService(serviceConnection!!) + serviceConnection?.let { serviceConnection -> + context.unbindService(serviceConnection) } serviceRunning = false disposable.clear() @@ -334,7 +333,7 @@ abstract class PumpPluginAbstract protected constructor( rxBus.send(EventCustomActionsChanged()) } - override fun manufacturer(): ManufacturerType = pumpType.manufacturer!! + override fun manufacturer(): ManufacturerType = pumpType.manufacturer ?: ManufacturerType.AAPS override fun model(): PumpType = pumpType override fun canHandleDST(): Boolean = false diff --git a/workflow/src/main/java/info/nightscout/workflow/iob/CarbsInPastExtension.kt b/workflow/src/main/java/info/nightscout/workflow/iob/CarbsInPastExtension.kt index 23e7a93780..d675ffa3a0 100644 --- a/workflow/src/main/java/info/nightscout/workflow/iob/CarbsInPastExtension.kt +++ b/workflow/src/main/java/info/nightscout/workflow/iob/CarbsInPastExtension.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.iob.iobCobCalculator +package info.nightscout.workflow.iob import info.nightscout.database.entities.Carbs import info.nightscout.interfaces.Constants diff --git a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt index 95657f8da3..9ce169cf21 100644 --- a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt +++ b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOref1Worker.kt @@ -23,7 +23,6 @@ import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.profiling.Profiler import info.nightscout.interfaces.utils.DecimalFormatter -import info.nightscout.plugins.iob.iobCobCalculator.fromCarbs import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.Event import info.nightscout.rx.events.EventAutosensCalculationFinished diff --git a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt index 39b02048fe..538c179fe0 100644 --- a/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt +++ b/workflow/src/main/java/info/nightscout/workflow/iob/IobCobOrefWorker.kt @@ -21,7 +21,6 @@ import info.nightscout.interfaces.profile.Instantiator import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.profiling.Profiler import info.nightscout.interfaces.utils.DecimalFormatter -import info.nightscout.plugins.iob.iobCobCalculator.fromCarbs import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.Event import info.nightscout.rx.events.EventAutosensCalculationFinished From e1cc42635cf205f230835f1fab3e3eae44af5fc1 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sun, 11 Dec 2022 17:52:29 +0100 Subject: [PATCH 37/48] NSTreatment -> RemoteTreatment conversion --- .../nightscout/sdk/NSAndroidClientImpl.kt | 20 ++ .../InvalidFormatNightscoutException.kt | 3 + .../UnknownResponseNightscoutException.kt | 3 + .../sdk/interfaces/NSAndroidClient.kt | 2 + .../treatment/CreateUpdateResponse.kt | 8 + .../sdk/localmodel/treatment/NSBolus.kt | 4 +- .../sdk/localmodel/treatment/NSBolusWizard.kt | 4 +- .../sdk/localmodel/treatment/NSCarbs.kt | 4 +- .../treatment/NSEffectiveProfileSwitch.kt | 4 +- .../localmodel/treatment/NSExtendedBolus.kt | 6 +- .../localmodel/treatment/NSOfflineEvent.kt | 4 +- .../localmodel/treatment/NSProfileSwitch.kt | 4 +- .../localmodel/treatment/NSTemporaryBasal.kt | 10 +- .../localmodel/treatment/NSTemporaryTarget.kt | 4 +- .../localmodel/treatment/NSTherapyEvent.kt | 4 +- .../sdk/localmodel/treatment/NSTreatment.kt | 4 +- .../nightscout/sdk/mapper/TreatmentMapper.kt | 264 +++++++++++++++++- .../sdk/networking/NightscoutRemoteService.kt | 10 + .../sdk/remotemodel/RemoteStatusResponse.kt | 7 + .../sdk/remotemodel/RemoteTreatment.kt | 111 ++++---- .../extensions/ProfileSwitchExtension.kt | 3 +- .../extensions/ExtendedBolusExtension.kt | 2 +- 22 files changed, 400 insertions(+), 85 deletions(-) create mode 100644 core/ns-sdk/src/main/java/info/nightscout/sdk/exceptions/InvalidFormatNightscoutException.kt create mode 100644 core/ns-sdk/src/main/java/info/nightscout/sdk/exceptions/UnknownResponseNightscoutException.kt create mode 100644 core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/CreateUpdateResponse.kt diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt index 019c16a914..183c8e09ca 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt @@ -3,12 +3,16 @@ package info.nightscout.sdk import android.content.Context import info.nightscout.sdk.exceptions.DateHeaderOutOfToleranceException import info.nightscout.sdk.exceptions.InvalidAccessTokenException +import info.nightscout.sdk.exceptions.InvalidFormatNightscoutException import info.nightscout.sdk.exceptions.TodoNightscoutException +import info.nightscout.sdk.exceptions.UnknownResponseNightscoutException import info.nightscout.sdk.interfaces.NSAndroidClient import info.nightscout.sdk.localmodel.Status import info.nightscout.sdk.localmodel.entry.NSSgvV3 +import info.nightscout.sdk.localmodel.treatment.CreateUpdateResponse import info.nightscout.sdk.localmodel.treatment.NSTreatment import info.nightscout.sdk.mapper.toLocal +import info.nightscout.sdk.mapper.toRemoteTreatment import info.nightscout.sdk.mapper.toSgv import info.nightscout.sdk.mapper.toTreatment import info.nightscout.sdk.networking.NetworkStackBuilder @@ -154,6 +158,22 @@ class NSAndroidClientImpl( } } + override suspend fun createTreatment(nsTreatment: NSTreatment): CreateUpdateResponse = callWrapper(dispatcher) { + + val remoteTreatment = nsTreatment.toRemoteTreatment() ?: throw InvalidFormatNightscoutException() + val response = api.createTreatment(remoteTreatment) + if (response.isSuccessful) { + return@callWrapper CreateUpdateResponse( + identifier = response.body()?.result?.identifier ?: throw UnknownResponseNightscoutException(), + isDeduplication = response.body()?.result?.isDeduplication ?: false, + deduplicatedIdentifier = response.body()?.result?.deduplicatedIdentifier, + lastModified = response.body()?.result?.lastModified + ) + } else { + throw TodoNightscoutException() // TODO: react to response errors (offline, ...) + } + } + private suspend fun callWrapper(dispatcher: CoroutineDispatcher, block: suspend () -> T): T = withContext(dispatcher) { retry( diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/exceptions/InvalidFormatNightscoutException.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/exceptions/InvalidFormatNightscoutException.kt new file mode 100644 index 0000000000..80ab0f019e --- /dev/null +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/exceptions/InvalidFormatNightscoutException.kt @@ -0,0 +1,3 @@ +package info.nightscout.sdk.exceptions + +class InvalidFormatNightscoutException : NightscoutException() diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/exceptions/UnknownResponseNightscoutException.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/exceptions/UnknownResponseNightscoutException.kt new file mode 100644 index 0000000000..f706d499b9 --- /dev/null +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/exceptions/UnknownResponseNightscoutException.kt @@ -0,0 +1,3 @@ +package info.nightscout.sdk.exceptions + +class UnknownResponseNightscoutException : NightscoutException() diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt index e57144a74f..bfb07f1490 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt @@ -2,6 +2,7 @@ package info.nightscout.sdk.interfaces import info.nightscout.sdk.localmodel.Status import info.nightscout.sdk.localmodel.entry.NSSgvV3 +import info.nightscout.sdk.localmodel.treatment.CreateUpdateResponse import info.nightscout.sdk.localmodel.treatment.NSTreatment import info.nightscout.sdk.remotemodel.LastModified import info.nightscout.sdk.remotemodel.RemoteDeviceStatus @@ -19,4 +20,5 @@ interface NSAndroidClient { suspend fun getSgvsNewerThan(from: Long, limit: Long): List suspend fun getTreatmentsModifiedSince(from: Long, limit: Long): List suspend fun getDeviceStatusModifiedSince(from: Long): List + suspend fun createTreatment(NsTreatment: NSTreatment): CreateUpdateResponse } \ No newline at end of file diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/CreateUpdateResponse.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/CreateUpdateResponse.kt new file mode 100644 index 0000000000..ad7a3835a2 --- /dev/null +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/CreateUpdateResponse.kt @@ -0,0 +1,8 @@ +package info.nightscout.sdk.localmodel.treatment + +class CreateUpdateResponse( + val identifier: String?, + val isDeduplication: Boolean? = false, + val deduplicatedIdentifier: String? = null, + val lastModified: Long? = null +) \ No newline at end of file diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt index 76d482f222..dbc9f63408 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt @@ -7,8 +7,8 @@ data class NSBolus( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt index 11a1ab3a48..d192577c70 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt @@ -8,8 +8,8 @@ data class NSBolusWizard( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt index 9f3dd66be2..b3069a4a1d 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt @@ -7,8 +7,8 @@ data class NSCarbs( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt index 4fa8b1e322..731048b678 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt @@ -8,8 +8,8 @@ data class NSEffectiveProfileSwitch( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt index 0fc041d9e5..cb179b70d2 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt @@ -7,8 +7,8 @@ data class NSExtendedBolus( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, @@ -21,5 +21,5 @@ data class NSExtendedBolus( override val pumpSerial: String?, val duration: Long, val enteredinsulin: Double, - val isEmulatingTempbasal: Boolean + val isEmulatingTempBasal: Boolean? ) : NSTreatment diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt index 1abffef44c..1d64e0c6cd 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt @@ -7,8 +7,8 @@ data class NSOfflineEvent( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt index c97e5de38c..d36056eebd 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt @@ -8,8 +8,8 @@ data class NSProfileSwitch( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt index 8a025e7097..b3dabf908a 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt @@ -8,8 +8,8 @@ data class NSTemporaryBasal( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, @@ -21,9 +21,11 @@ data class NSTemporaryBasal( override val pumpType: String?, override val pumpSerial: String?, val duration: Long, - val rate: Double, + val rate: Double, // when sending to NS always convertedToAbsolute(timestamp, profile) val isAbsolute: Boolean, - val type: Type + val type: Type, + val percent: Double? = null, // when sending to NS (rate - 100) + val absolute: Double? = null // when sending to NS (rate) ) : NSTreatment { enum class Type { diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt index c4a03bca18..77276096db 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt @@ -7,8 +7,8 @@ data class NSTemporaryTarget( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt index 503c9ee65f..1fe671107c 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt @@ -8,8 +8,8 @@ data class NSTherapyEvent( override val device: String?, override val identifier: String, override val units: NsUnits?, - override val srvModified: Long, - override val srvCreated: Long, + override val srvModified: Long?, + override val srvCreated: Long?, override val utcOffset: Long, override val subject: String?, override var isReadOnly: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt index f522b0673c..04a10c17eb 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt @@ -8,8 +8,8 @@ interface NSTreatment { val identifier: String val units: NsUnits? val eventType: EventType - val srvModified: Long - val srvCreated: Long + val srvModified: Long? + val srvCreated: Long? val utcOffset: Long val subject: String? var isReadOnly: Boolean diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/mapper/TreatmentMapper.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/mapper/TreatmentMapper.kt index 7af6badcbb..47cb5e7b2a 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/mapper/TreatmentMapper.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/mapper/TreatmentMapper.kt @@ -117,7 +117,7 @@ internal fun RemoteTreatment.toTreatment(): NSTreatment? { pumpSerial = extendedEmulated.pumpSerial, enteredinsulin = extendedEmulated.enteredinsulin ?: 0.0, duration = extendedEmulated.durationInMilliseconds ?: TimeUnit.MINUTES.toMillis(extendedEmulated.duration ?: 0L), - isEmulatingTempbasal = extendedEmulated.isEmulatingTempBasal + isEmulatingTempBasal = extendedEmulated.isEmulatingTempBasal ) } @@ -329,10 +329,270 @@ internal fun RemoteTreatment.toTreatment(): NSTreatment? { pumpSerial = this.pumpSerial, enteredinsulin = this.enteredinsulin, duration = this.durationInMilliseconds ?: TimeUnit.MINUTES.toMillis(this.duration ?: 0L), - isEmulatingTempbasal = this.isEmulatingTempBasal + isEmulatingTempBasal = this.isEmulatingTempBasal ) } } return null } + +internal fun NSTreatment.toRemoteTreatment(): RemoteTreatment? = + when (this) { + is NSBolus -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + insulin = insulin, + type = type.name + ) + + is NSCarbs -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + carbs = carbs, + duration = duration + ) + + is NSTemporaryTarget -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + duration = TimeUnit.MILLISECONDS.toMinutes(duration), + durationInMilliseconds = duration, + targetBottom = targetBottom, + targetTop = targetTop, + reason = reason.text + ) + /* + // Convert back emulated TBR -> EB + eventType == EventType.TEMPORARY_BASAL && extendedEmulated != null -> + + return RemoteTreatment( + date = treatmentTimestamp, + device = device, + identifier = identifier, + units = NsUnits.fromString(extendedEmulated.units), + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset ?: 0, + subject = subject, + isReadOnly = extendedEmulated.isReadOnly ?: false, + isValid = extendedEmulated.isValid ?: true, + eventType = extendedEmulated.eventType, + notes = extendedEmulated.notes, + pumpId = extendedEmulated.pumpId, + endId = extendedEmulated.endId, + pumpType = extendedEmulated.pumpType, + pumpSerial = extendedEmulated.pumpSerial, + enteredinsulin = extendedEmulated.enteredinsulin ?: 0.0, + duration = extendedEmulated.durationInMilliseconds ?: TimeUnit.MINUTES.toMillis(extendedEmulated.duration ?: 0L), + isEmulatingTempbasal = extendedEmulated.isEmulatingTempBasal + ) + } + */ + is NSTemporaryBasal -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + duration = TimeUnit.MILLISECONDS.toMinutes(duration), + durationInMilliseconds = duration, + absolute = absolute, + percent = percent, + rate = absolute, + type = type.name + ) + + is NSEffectiveProfileSwitch -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + profileJson = profileJson.toString(), + originalProfileName = originalProfileName, + originalCustomizedName = originalCustomizedName, + originalTimeshift = originalTimeshift, + originalPercentage = originalPercentage, + originalDuration = originalDuration, + originalEnd = originalEnd + ) + + is NSProfileSwitch -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + profileJson = profileJson.toString(), // must be de-customized + profile = profileName, + originalProfileName = originalProfileName, + originalDuration = originalDuration, + duration = duration, + timeshift = timeShift, + percentage = percentage, + ) + + is NSBolusWizard -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + bolusCalculatorResult = bolusCalculatorResult, + glucose = glucose + ) + + is NSTherapyEvent -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + duration = TimeUnit.MILLISECONDS.toMinutes(duration), + durationInMilliseconds = duration, + glucose = glucose, + enteredBy = enteredBy, + glucoseType = glucoseType?.text + ) + + is NSOfflineEvent -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + duration = TimeUnit.MILLISECONDS.toMinutes(duration), + durationInMilliseconds = duration, + reason = reason.name + ) + + is NSExtendedBolus -> RemoteTreatment( + date = date, + device = device, + identifier = identifier, + units = units?.value, + srvModified = srvModified, + srvCreated = srvCreated, + utcOffset = utcOffset, + subject = subject, + isReadOnly = isReadOnly, + isValid = isValid, + eventType = eventType, + notes = notes, + pumpId = pumpId, + endId = endId, + pumpType = pumpType, + pumpSerial = pumpSerial, + enteredinsulin = enteredinsulin, + duration = TimeUnit.MILLISECONDS.toMinutes(duration), + durationInMilliseconds = duration, + isEmulatingTempBasal = isEmulatingTempBasal + ) + + else -> null + } diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt index 4619aef0c0..3ae740d2db 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt @@ -4,11 +4,17 @@ import com.google.gson.JsonElement import info.nightscout.sdk.remotemodel.LastModified import info.nightscout.sdk.remotemodel.RemoteDeviceStatus import info.nightscout.sdk.remotemodel.NSResponse +import info.nightscout.sdk.remotemodel.RemoteCreateUpdateResponse import info.nightscout.sdk.remotemodel.RemoteEntry import info.nightscout.sdk.remotemodel.RemoteStatusResponse import info.nightscout.sdk.remotemodel.RemoteTreatment +import okhttp3.RequestBody +import retrofit2.Call import retrofit2.Response +import retrofit2.http.Body import retrofit2.http.GET +import retrofit2.http.Header +import retrofit2.http.POST import retrofit2.http.Path import retrofit2.http.Query @@ -48,4 +54,8 @@ internal interface NightscoutRemoteService { @GET("v3/devicestatus/history/{from}") suspend fun getDeviceStatusModifiedSince(@Path("from") from: Long): Response>> + + @POST("v3/treatments") + fun createTreatment(@Body remoteTreatment: RemoteTreatment): Response> + } diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteStatusResponse.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteStatusResponse.kt index 15055f9051..be313118ba 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteStatusResponse.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteStatusResponse.kt @@ -17,6 +17,13 @@ internal data class RemoteStorage( @SerializedName("version") val version: String ) +internal data class RemoteCreateUpdateResponse( + @SerializedName("identifier") val identifier: String?, + @SerializedName("isDeduplication") val isDeduplication: Boolean?, + @SerializedName("deduplicatedIdentifier") val deduplicatedIdentifier: String?, + @SerializedName("lastModified") val lastModified: Long? +) + internal data class RemoteApiPermissions( @SerializedName("devicestatus") val deviceStatus: RemoteApiPermission, @SerializedName("entries") val entries: RemoteApiPermission, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt index 80929a2133..d73f0098fc 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt @@ -18,72 +18,71 @@ import org.json.JSONObject * */ internal data class RemoteTreatment( @SerializedName("identifier") val identifier: String, // string Main addressing, required field that identifies document in the collection. The client should not create the identifier, the server automatically assigns it when the document is inserted. - @SerializedName("date") val date: Long?, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix epoch in milliseconds (1525383610088), Unix epoch in seconds (1525383610), ISO 8601 with optional timezone ('2018-05-03T21:40:10.088Z' or '2018-05-03T23:40:10.088+02:00') - @SerializedName("mills") val mills: Long?, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix - @SerializedName("timestamp") val timestamp: Long?, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix epoch in milliseconds (1525383610088), Unix epoch in seconds (1525383610), ISO 8601 with optional timezone ('2018-05-03T21:40:10.088Z' or '2018-05-03T23:40:10.088+02:00') - @SerializedName("created_at") val created_at: String, // integer($int64) or string timestamp on previous version of api, in my examples, a lot of treatments don't have date, only created_at, some of them with string others with long... - @SerializedName("utcOffset") val utcOffset: Long?, // integer Local UTC offset (timezone) of the event in minutes. This field can be set either directly by the client (in the incoming - // document) or it is automatically parsed from the date field. + @SerializedName("date") val date: Long? = null, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix epoch in milliseconds (1525383610088), Unix epoch in seconds (1525383610), ISO 8601 with optional timezone ('2018-05-03T21:40:10.088Z' or '2018-05-03T23:40:10.088+02:00') + @SerializedName("mills") val mills: Long? = null, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix + @SerializedName("timestamp") val timestamp: Long? = null, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix epoch in milliseconds (1525383610088), Unix epoch in seconds (1525383610), ISO 8601 with optional timezone ('2018-05-03T21:40:10.088Z' or '2018-05-03T23:40:10.088+02:00') + @SerializedName("created_at") val created_at: String? = null, // integer($int64) or string timestamp on previous version of api, in my examples, a lot of treatments don't have date, only created_at, some of them with string others with long... + @SerializedName("utcOffset") val utcOffset: Long? = null, // integer Local UTC offset (timezone) of the event in minutes. This field can be set either directly by the client (in the incoming document) or it is automatically parsed from the date field. // @SerializedName("app") val app : String, // TODO required ? Application or system in which the record was entered by human or device for the first time. - @SerializedName("device") val device: String?, // string The device from which the data originated (including serial number of the device, if it is relevant and safe). - @SerializedName("srvCreated") val srvCreated: Long, // integer($int64) example: 1525383610088 The server's timestamp of document insertion into the database (Unix epoch in ms). This field appears only for documents which were inserted by API v3. - @SerializedName("subject") val subject: String?, // string Name of the security subject (within Nightscout scope) which has created the document. This field is automatically set by the server from the passed token or JWT. - @SerializedName("srvModified") val srvModified: Long, // integer($int64) example: 1525383610088 The server's timestamp of the last document modification in the database (Unix epoch in ms). This field appears only for documents which were somehow modified by API v3 (inserted, updated or deleted). - @SerializedName("modifiedBy") val modifiedBy: String?, // string Name of the security subject (within Nightscout scope) which has patched or deleted the document for the last time. This field is automatically set by the server. - @SerializedName("isValid") val isValid: Boolean?, // boolean A flag set by the server only for deleted documents. This field appears only within history operation and for documents which were deleted by API v3 (and they always have a false value) - @SerializedName("isReadOnly") val isReadOnly: Boolean?, // boolean A flag set by client that locks the document from any changes. Every document marked with isReadOnly=true is forever immutable and cannot even be deleted. + @SerializedName("device") val device: String? = null, // string The device from which the data originated (including serial number of the device, if it is relevant and safe). + @SerializedName("srvCreated") val srvCreated: Long? = null, // integer($int64) example: 1525383610088 The server's timestamp of document insertion into the database (Unix epoch in ms). This field appears only for documents which were inserted by API v3. + @SerializedName("subject") val subject: String? = null, // string Name of the security subject (within Nightscout scope) which has created the document. This field is automatically set by the server from the passed token or JWT. + @SerializedName("srvModified") val srvModified: Long? = null, // integer($int64) example: 1525383610088 The server's timestamp of the last document modification in the database (Unix epoch in ms). This field appears only for documents which were somehow modified by API v3 (inserted, updated or deleted). + @SerializedName("modifiedBy") val modifiedBy: String? = null, // string Name of the security subject (within Nightscout scope) which has patched or deleted the document for the last time. This field is automatically set by the server. + @SerializedName("isValid") val isValid: Boolean? = null, // boolean A flag set by the server only for deleted documents. This field appears only within history operation and for documents which were deleted by API v3 (and they always have a false value) + @SerializedName("isReadOnly") val isReadOnly: Boolean? = null, // boolean A flag set by client that locks the document from any changes. Every document marked with isReadOnly=true is forever immutable and cannot even be deleted. @SerializedName("eventType") val eventType: EventType, // string "BG Check", "Snack Bolus", "Meal Bolus", "Correction Bolus", "Carb Correction", "Combo Bolus", "Announcement", "Note", "Question", "Exercise", "Site Change", "Sensor Start", "Sensor Change", "Pump Battery Change", "Insulin Change", "Temp Basal", "Profile Switch", "D.A.D. Alert", "Temporary Target", "OpenAPS Offline", "Bolus Wizard" - @SerializedName("glucose") val glucose: Double?, // double Current glucose - @SerializedName("glucoseType") val glucoseType: String?, // string example: "Sensor", "Finger", "Manual" - @SerializedName("units") val units: String?, // string The units for the glucose value, mg/dl or mmol/l. It is strongly recommended to fill in this field. - @SerializedName("carbs") val carbs: Double?, // number... Amount of carbs given. - @SerializedName("protein") val protein: Int?, // number... Amount of protein given. - @SerializedName("fat") val fat: Int?, // number... Amount of fat given. - @SerializedName("insulin") val insulin: Double?, // number... Amount of insulin, if any. - @SerializedName("duration") val duration: Long?, // number... Duration in minutes. - @SerializedName("durationInMilliseconds") val durationInMilliseconds: Long?, // number... Duration in milliseconds. - @SerializedName("preBolus") val preBolus: Int?, // number... How many minutes the bolus was given before the meal started. - @SerializedName("splitNow") val splitNow: Int?, // number... Immediate part of combo bolus (in percent). - @SerializedName("splitExt") val splitExt: Int?, // number... Extended part of combo bolus (in percent). - @SerializedName("percent") val percent: Double?, // number... Eventual basal change in percent. - @SerializedName("absolute") val absolute: Double?, // number... Eventual basal change in absolute value (insulin units per hour). - @SerializedName("targetTop") val targetTop: Double?, // number... Top limit of temporary target. - @SerializedName("targetBottom") val targetBottom: Double?, // number... Bottom limit of temporary target. - @SerializedName("profile") val profile: String?, // string Name of the profile to which the pump has been switched. - @SerializedName("reason") val reason: String?, // string For example the reason why the profile has been switched or why the temporary target has been set. - @SerializedName("notes") val notes: String?, // string Description/notes of treatment. - @SerializedName("enteredBy") val enteredBy: String?, // string Who entered the treatment. + @SerializedName("glucose") val glucose: Double? = null, // double Current glucose + @SerializedName("glucoseType") val glucoseType: String? = null, // string example: "Sensor", "Finger", "Manual" + @SerializedName("units") val units: String? = null, // string The units for the glucose value, mg/dl or mmol/l. It is strongly recommended to fill in this field. + @SerializedName("carbs") val carbs: Double? = null, // number... Amount of carbs given. + @SerializedName("protein") val protein: Int? = null, // number... Amount of protein given. + @SerializedName("fat") val fat: Int? = null, // number... Amount of fat given. + @SerializedName("insulin") val insulin: Double? = null, // number... Amount of insulin, if any. + @SerializedName("duration") val duration: Long? = null, // number... Duration in minutes. + @SerializedName("durationInMilliseconds") val durationInMilliseconds: Long? = null, // number... Duration in milliseconds. + @SerializedName("preBolus") val preBolus: Int? = null, // number... How many minutes the bolus was given before the meal started. + @SerializedName("splitNow") val splitNow: Int? = null, // number... Immediate part of combo bolus (in percent). + @SerializedName("splitExt") val splitExt: Int? = null, // number... Extended part of combo bolus (in percent). + @SerializedName("percent") val percent: Double? = null, // number... Eventual basal change in percent. + @SerializedName("absolute") val absolute: Double? = null, // number... Eventual basal change in absolute value (insulin units per hour). + @SerializedName("targetTop") val targetTop: Double? = null, // number... Top limit of temporary target. + @SerializedName("targetBottom") val targetBottom: Double? = null, // number... Bottom limit of temporary target. + @SerializedName("profile") val profile: String? = null, // string Name of the profile to which the pump has been switched. + @SerializedName("reason") val reason: String? = null, // string For example the reason why the profile has been switched or why the temporary target has been set. + @SerializedName("notes") val notes: String? = null, // string Description/notes of treatment. + @SerializedName("enteredBy") val enteredBy: String? = null, // string Who entered the treatment. - @SerializedName("endId") val endId: Long?, // long id of record which ended this - @SerializedName("pumpId") val pumpId: Long?, // long or "Meal Bolus", "Correction Bolus", "Combo Bolus" ex 4102 not sure if long or int - @SerializedName("pumpType") val pumpType: String?, // string "Meal Bolus", "Correction Bolus", "Combo Bolus" ex "ACCU_CHEK_INSIGHT_BLUETOOTH", - @SerializedName("pumpSerial") val pumpSerial: String?, // string "Meal Bolus", "Correction Bolus", "Combo Bolus" "33013206", + @SerializedName("endId") val endId: Long? = null, // long id of record which ended this + @SerializedName("pumpId") val pumpId: Long? = null, // long or "Meal Bolus", "Correction Bolus", "Combo Bolus" ex 4102 not sure if long or int + @SerializedName("pumpType") val pumpType: String? = null, // string "Meal Bolus", "Correction Bolus", "Combo Bolus" ex "ACCU_CHEK_INSIGHT_BLUETOOTH", + @SerializedName("pumpSerial") val pumpSerial: String? = null, // string "Meal Bolus", "Correction Bolus", "Combo Bolus" "33013206", // other fields found in examples but not in documentation - @SerializedName("profileJson") val profileJson: String?, // string "Profile Switch" ex json toString "{\"units\":\"mg\\/dl\",\"dia\":5,\"timezone\":\"Africa\\/Cairo\", + @SerializedName("profileJson") val profileJson: String? = null, // string "Profile Switch" ex json toString "{\"units\":\"mg\\/dl\",\"dia\":5,\"timezone\":\"Africa\\/Cairo\", // \"sens\":[{\"time\":\"00:00\",\"timeAsSeconds\":0,\"value\":60},{\"time\":\"07:00\",\"timeAsSeconds\":25200,\"value\":60},{\"time\":\"08:00\",\"timeAsSeconds\":28800,\"value\":61.33333333333333},{\"time\":\"09:00\",\"timeAsSeconds\":32400,\"value\":65.33333333333333},{\"time\":\"10:00\",\"timeAsSeconds\":36000,\"value\":69.33333333333333},{\"time\":\"11:00\",\"timeAsSeconds\":39600,\"value\":73.33333333333333},{\"time\":\"13:00\",\"timeAsSeconds\":46800,\"value\":72},{\"time\":\"14:00\",\"timeAsSeconds\":50400,\"value\":68},{\"time\":\"15:00\",\"timeAsSeconds\":54000,\"value\":65.33333333333333},{\"time\":\"16:00\",\"timeAsSeconds\":57600,\"value\":65.33333333333333}],\"carbratio\":[{\"time\":\"00:00\",\"timeAsSeconds\":0,\"value\":5.7333333333333325},{\"time\":\"11:00\",\"timeAsSeconds\":39600,\"value\":7.333333333333333},{\"time\":\"16:00\",\"timeAsSeconds\":57600,\"value\":6.666666666666666}],\"basal\":[{\"time\":\"00:00\",\"timeAsSeconds\":0,\"value\":0.5249999999999999},{\"time\":\"01:00\",\"timeAsSeconds\":3600,\"value\":0.585},{\"time\":\"02:00\",\"timeAsSeconds\":7200,\"value\":0.6375},{\"time\":\"03:00\",\"timeAsSeconds\":10800,\"value\":0.5625},{\"time\":\"04:00\",\"timeAsSeconds\":14400,\"value\":0.4575},{\"time\":\"05:00\",\"timeAsSeconds\":18000,\"value\":0.5175},{\"time\":\"06:00\",\"timeAsSeconds\":21600,\"value\":0.48},{\"time\":\"07:00\",\"timeAsSeconds\":25200,\"value\":0.51},{\"time\":\"08:00\",\"timeAsSeconds\":28800,\"value\":0.48750000000000004},{\"time\":\"09:00\",\"timeAsSeconds\":32400,\"value\":0.48},{\"time\":\"10:00\",\"timeAsSeconds\":36000,\"value\":0.48750000000000004},{\"time\":\"11:00\",\"timeAsSeconds\":39600,\"value\":0.5025000000000001},{\"time\":\"12:00\",\"timeAsSeconds\":43200,\"value\":0.5549999999999999},{\"time\":\"13:00\",\"timeAsSeconds\":46800,\"value\":0.5700000000000001},{\"time\":\"14:00\",\"timeAsSeconds\":50400,\"value\":0.5700000000000001},{\"time\":\"15:00\",\"timeAsSeconds\":54000,\"value\":0.5775},{\"time\":\"16:00\",\"timeAsSeconds\":57600,\"value\":0.51},{\"time\":\"17:00\",\"timeAsSeconds\":61200,\"value\":0.54},{\"time\":\"18:00\",\"timeAsSeconds\":64800,\"value\":0.48750000000000004},{\"time\":\"19:00\",\"timeAsSeconds\":68400,\"value\":0.5249999999999999},{\"time\":\"20:00\",\"timeAsSeconds\":72000,\"value\":0.46499999999999997},{\"time\":\"21:00\",\"timeAsSeconds\":75600,\"value\":0.46499999999999997},{\"time\":\"22:00\",\"timeAsSeconds\":79200,\"value\":0.43499999999999994},{\"time\":\"23:00\",\"timeAsSeconds\":82800,\"value\":0.41250000000000003}],\"target_low\":[{\"time\":\"00:00\",\"timeAsSeconds\":0,\"value\":100},{\"time\":\"06:00\",\"timeAsSeconds\":21600,\"value\":90},{\"time\":\"09:00\",\"timeAsSeconds\":32400,\"value\":100},{\"time\":\"11:00\",\"timeAsSeconds\":39600,\"value\":90},{\"time\":\"14:00\",\"timeAsSeconds\":50400,\"value\":100},{\"time\":\"18:00\",\"timeAsSeconds\":64800,\"value\":90},{\"time\":\"21:00\",\"timeAsSeconds\":75600,\"value\":100}],\"target_high\":[{\"time\":\"00:00\",\"timeAsSeconds\":0,\"value\":100},{\"time\":\"06:00\",\"timeAsSeconds\":21600,\"value\":90},{\"time\":\"09:00\",\"timeAsSeconds\":32400,\"value\":100},{\"time\":\"11:00\",\"timeAsSeconds\":39600,\"value\":90},{\"time\":\"14:00\",\"timeAsSeconds\":50400,\"value\":100},{\"time\":\"18:00\",\"timeAsSeconds\":64800,\"value\":90},{\"time\":\"21:00\",\"timeAsSeconds\":75600,\"value\":100}]}", - @SerializedName("originalProfileName") val originalProfileName: String?, // string "Effective Profile Switch" - @SerializedName("originalCustomizedName") val originalCustomizedName: String?, // string "Effective Profile Switch" - @SerializedName("originalTimeshift") val originalTimeshift: Long?, // long "Effective Profile Switch" - @SerializedName("originalPercentage") val originalPercentage: Int?, // int "Effective Profile Switch" - @SerializedName("originalDuration") val originalDuration: Long?, // long "Effective Profile Switch" - @SerializedName("originalEnd") val originalEnd: Long?, // long "Effective Profile Switch" + @SerializedName("originalProfileName") val originalProfileName: String? = null, // string "Effective Profile Switch" + @SerializedName("originalCustomizedName") val originalCustomizedName: String? = null, // string "Effective Profile Switch" + @SerializedName("originalTimeshift") val originalTimeshift: Long? = null, // long "Effective Profile Switch" + @SerializedName("originalPercentage") val originalPercentage: Int? = null, // int "Effective Profile Switch" + @SerializedName("originalDuration") val originalDuration: Long? = null, // long "Effective Profile Switch" + @SerializedName("originalEnd") val originalEnd: Long? = null, // long "Effective Profile Switch" - @SerializedName("bolusCalculatorResult") val bolusCalculatorResult: String?, // string "Bolus Wizard" json toString ex "bolusCalculatorResult": "{\"basalIOB\":-0.247,\"bolusIOB\":-1.837,\"carbs\":45.0,\"carbsInsulin\":9.0,\"cob\":0.0,\"cobInsulin\":0.0,\"dateCreated\":1626202788810,\"glucoseDifference\":44.0,\"glucoseInsulin\":0.8979591836734694,\"glucoseTrend\":5.5,\"glucoseValue\":134.0,\"ic\":5.0,\"id\":331,\"interfaceIDs_backing\":{\"nightscoutId\":\"60ede2a4c574da0004a3869d\"},\"isValid\":true,\"isf\":49.0,\"note\":\"\",\"otherCorrection\":0.0,\"percentageCorrection\":90,\"profileName\":\"Tuned 13/01 90%Lyum\",\"superbolusInsulin\":0.0,\"targetBGHigh\":90.0,\"targetBGLow\":90.0,\"timestamp\":1626202783325,\"totalInsulin\":7.34,\"trendInsulin\":0.336734693877551,\"utcOffset\":7200000,\"version\":1,\"wasBasalIOBUsed\":true,\"wasBolusIOBUsed\":true,\"wasCOBUsed\":true,\"wasGlucoseUsed\":true,\"wasSuperbolusUsed\":false,\"wasTempTargetUsed\":false,\"wasTrendUsed\":true,\"wereCarbsUsed\":false}", - @SerializedName("type") val type: String?, // string "Meal Bolus", "Correction Bolus", "Combo Bolus", "Temp Basal" type of bolus "NORMAL", "SMB", "FAKE_EXTENDED" - @SerializedName("isSMB") val isSMB: Boolean, // boolean "Meal Bolus", "Correction Bolus", "Combo Bolus" - @SerializedName("enteredinsulin") val enteredinsulin: Double?, // number... "Combo Bolus" insulin is missing only enteredinsulin field found - @SerializedName("relative") val relative: Double?, // number... "Combo Bolus", "extendedEmulated" (not in doc see below) - @SerializedName("isEmulatingTempBasal") val isEmulatingTempBasal: Boolean, // boolean "Combo Bolus", "extendedEmulated" (not in doc see below) - @SerializedName("isAnnouncement") val isAnnouncement: Boolean, // boolean "Announcement" - @SerializedName("rate") val rate: Double?, // Double "Temp Basal" absolute rate (could be calculated with percent and profile information...) - @SerializedName("extendedEmulated") val extendedEmulated: RemoteTreatment?, // Gson of emulated EB - @SerializedName("timeshift") val timeshift: Long, // integer "Profile Switch" - @SerializedName("percentage") val percentage: Int?, // integer "Profile Switch" + @SerializedName("bolusCalculatorResult") val bolusCalculatorResult: String? = null, // string "Bolus Wizard" json toString ex "bolusCalculatorResult": "{\"basalIOB\":-0.247,\"bolusIOB\":-1.837,\"carbs\":45.0,\"carbsInsulin\":9.0,\"cob\":0.0,\"cobInsulin\":0.0,\"dateCreated\":1626202788810,\"glucoseDifference\":44.0,\"glucoseInsulin\":0.8979591836734694,\"glucoseTrend\":5.5,\"glucoseValue\":134.0,\"ic\":5.0,\"id\":331,\"interfaceIDs_backing\":{\"nightscoutId\":\"60ede2a4c574da0004a3869d\"},\"isValid\":true,\"isf\":49.0,\"note\":\"\",\"otherCorrection\":0.0,\"percentageCorrection\":90,\"profileName\":\"Tuned 13/01 90%Lyum\",\"superbolusInsulin\":0.0,\"targetBGHigh\":90.0,\"targetBGLow\":90.0,\"timestamp\":1626202783325,\"totalInsulin\":7.34,\"trendInsulin\":0.336734693877551,\"utcOffset\":7200000,\"version\":1,\"wasBasalIOBUsed\":true,\"wasBolusIOBUsed\":true,\"wasCOBUsed\":true,\"wasGlucoseUsed\":true,\"wasSuperbolusUsed\":false,\"wasTempTargetUsed\":false,\"wasTrendUsed\":true,\"wereCarbsUsed\":false}", + @SerializedName("type") val type: String? = null, // string "Meal Bolus", "Correction Bolus", "Combo Bolus", "Temp Basal" type of bolus "NORMAL", "SMB", "FAKE_EXTENDED" + @SerializedName("isSMB") val isSMB: Boolean? = null, // boolean "Meal Bolus", "Correction Bolus", "Combo Bolus" + @SerializedName("enteredinsulin") val enteredinsulin: Double? = null, // number... "Combo Bolus" insulin is missing only enteredinsulin field found + @SerializedName("relative") val relative: Double? = null, // number... "Combo Bolus", "extendedEmulated" (not in doc see below) + @SerializedName("isEmulatingTempBasal") val isEmulatingTempBasal: Boolean? = null, // boolean "Combo Bolus", "extendedEmulated" (not in doc see below) + @SerializedName("isAnnouncement") val isAnnouncement: Boolean? = null, // boolean "Announcement" + @SerializedName("rate") val rate: Double? = null, // Double "Temp Basal" absolute rate (could be calculated with percent and profile information...) + @SerializedName("extendedEmulated") val extendedEmulated: RemoteTreatment? = null, // Gson of emulated EB + @SerializedName("timeshift") val timeshift: Long? = null, // integer "Profile Switch" + @SerializedName("percentage") val percentage: Int? = null // integer "Profile Switch" ) { fun timestamp(): Long { - return date ?: mills ?: timestamp ?: fromISODateString(created_at) + return date ?: mills ?: timestamp ?: created_at?. let { fromISODateString(created_at) } ?: 0L } private fun fromISODateString(isoDateString: String): Long = diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/ProfileSwitchExtension.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/ProfileSwitchExtension.kt index 09bc1e7f48..6975c1febb 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/ProfileSwitchExtension.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/ProfileSwitchExtension.kt @@ -5,6 +5,7 @@ import info.nightscout.core.extensions.getCustomizedName import info.nightscout.core.extensions.pureProfileFromJson import info.nightscout.core.profile.ProfileSealed import info.nightscout.database.entities.ProfileSwitch +import info.nightscout.database.entities.TherapyEvent import info.nightscout.database.entities.embedments.InterfaceIDs import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.utils.JsonHelper @@ -23,7 +24,7 @@ fun ProfileSwitch.toJson(isAdd: Boolean, dateUtil: DateUtil): JSONObject = .put("created_at", dateUtil.toISOString(timestamp)) .put("enteredBy", "openaps://" + "AndroidAPS") .put("isValid", isValid) - .put("eventType", info.nightscout.database.entities.TherapyEvent.Type.PROFILE_SWITCH.text) + .put("eventType", TherapyEvent.Type.PROFILE_SWITCH.text) .also { // remove customization to store original profileJson in toPureNsJson call timeshift = 0 percentage = 100 diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/extensions/ExtendedBolusExtension.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/extensions/ExtendedBolusExtension.kt index c2dfeaa81b..090b71f7b2 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/extensions/ExtendedBolusExtension.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/extensions/ExtendedBolusExtension.kt @@ -11,6 +11,6 @@ fun NSExtendedBolus.toExtendedBolus(): ExtendedBolus = utcOffset = utcOffset, amount = enteredinsulin, duration = duration, - isEmulatingTempBasal = isEmulatingTempbasal, + isEmulatingTempBasal = isEmulatingTempBasal ?: false, interfaceIDs_backing = InterfaceIDs(nightscoutId = identifier, pumpId = pumpId, pumpType = InterfaceIDs.PumpType.fromString(pumpType), pumpSerial = pumpSerial, endId = endId) ) From 1d1c47db1be5f12fb86717bc044cdacb9874bfe6 Mon Sep 17 00:00:00 2001 From: Lorelai L Date: Sun, 11 Dec 2022 18:39:42 +0100 Subject: [PATCH 38/48] cancelTempBasal does not set success flag to true --- .../java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java index 57760a5663..8d4dcfdb0d 100644 --- a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java +++ b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java @@ -345,7 +345,7 @@ public class DanaRv2Plugin extends AbstractDanaRPlugin { PumpEnactResult result = new PumpEnactResult(getInjector()); if (danaPump.isTempBasalInProgress()) { sExecutionService.tempBasalStop(); - result.enacted(true).isTempCancel(true); + result.success(true).enacted(true).isTempCancel(true); } else { result.success(true).isTempCancel(true).comment(info.nightscout.core.ui.R.string.ok); aapsLogger.debug(LTag.PUMP, "cancelRealTempBasal: OK"); From 97c11bc3e135665c14fb86147c6fcc9e36cbed45 Mon Sep 17 00:00:00 2001 From: Lorelai L Date: Sun, 11 Dec 2022 19:29:38 +0100 Subject: [PATCH 39/48] lastEventTimeLoaded is never updated - causes full fetch on each communication attempt --- .../nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt index a904ff0d12..6bc89b0077 100644 --- a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt +++ b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt @@ -277,7 +277,7 @@ class MsgHistoryEventsV2 constructor( status = "UNKNOWN " + dateUtil.timeString(datetime) } } - if (datetime > danaPump.lastEventTimeLoaded) danaPump.lastEventTimeLoaded = datetime + if (datetime > danaRv2Plugin.lastEventTimeLoaded) danaRv2Plugin.lastEventTimeLoaded = datetime rxBus.send(EventPumpStatusChanged(rh.gs(info.nightscout.pump.dana.R.string.processinghistory) + ": " + status)) } } \ No newline at end of file From 856f35dae688c9c7bb07b0a8a0fa0c90deb4b9ed Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sun, 11 Dec 2022 20:54:01 +0100 Subject: [PATCH 40/48] New Crowdin updates (#2279) * New translations strings.xml (Afrikaans) * New translations strings.xml (Russian) * New translations strings.xml (Chinese Simplified) * New translations strings.xml (Portuguese, Brazilian) --- core/ui/src/main/res/values-pt-rBR/strings.xml | 2 +- core/ui/src/main/res/values-ru-rRU/strings.xml | 1 - core/ui/src/main/res/values-zh-rCN/strings.xml | 2 +- pump/medtronic/src/main/res/values-af-rZA/strings.xml | 2 +- 4 files changed, 3 insertions(+), 4 deletions(-) diff --git a/core/ui/src/main/res/values-pt-rBR/strings.xml b/core/ui/src/main/res/values-pt-rBR/strings.xml index add6078c4b..70eb1193f6 100644 --- a/core/ui/src/main/res/values-pt-rBR/strings.xml +++ b/core/ui/src/main/res/values-pt-rBR/strings.xml @@ -419,7 +419,7 @@ Aviso : Selecione o perfil para ajustar O perfil selecionado tem %1$d valores de IC. Autotune vai usar %2$.2f g/U - O perfil selecionado tem %1$d valores de ISF. Autotune vai usar %2$.1f g/U + O perfil selecionado tem %1$d valores de ISF. Autotune usará %2$.1f %3$s/U Erro nos dados de entrada, tente executar novamente autotune ou reduza o número de dias Cálculos do Autotune iniciados, por favor aguarde Verifique os resultados cuidadosamente antes de usá-los! diff --git a/core/ui/src/main/res/values-ru-rRU/strings.xml b/core/ui/src/main/res/values-ru-rRU/strings.xml index 518a5d05cd..3ee938b1fc 100644 --- a/core/ui/src/main/res/values-ru-rRU/strings.xml +++ b/core/ui/src/main/res/values-ru-rRU/strings.xml @@ -428,7 +428,6 @@ Парам % Отсутствует - Профиль авто тюн Выполнить Autotune Проверьте профиль ввода Сравнить профили diff --git a/core/ui/src/main/res/values-zh-rCN/strings.xml b/core/ui/src/main/res/values-zh-rCN/strings.xml index 1c13a48a4c..afe0f6964f 100644 --- a/core/ui/src/main/res/values-zh-rCN/strings.xml +++ b/core/ui/src/main/res/values-zh-rCN/strings.xml @@ -483,7 +483,7 @@ 最大基础率被限定为 %1$.2f U/h 由于 %2$s 泵限制 - 由于 %2$s, 将最大百分比限制为 %1$d% + 由于 %2$s, 将最大百分比限制为 %1$d%% 它必须是正数 由于 %2$s, 将大剂量限制为 %1$.1f U diff --git a/pump/medtronic/src/main/res/values-af-rZA/strings.xml b/pump/medtronic/src/main/res/values-af-rZA/strings.xml index 88bff175b8..01d2cbc61d 100644 --- a/pump/medtronic/src/main/res/values-af-rZA/strings.xml +++ b/pump/medtronic/src/main/res/values-af-rZA/strings.xml @@ -35,7 +35,7 @@ Basale profiel is verkeerd op pomp (moet STD wees). Verkeerde TBR op pomp (Moet Absoluut wees). Verkeerde Maks Bolus gestel op Pomp(moet %1$.2f wees). - Verkeerde Maks Basale op Pomp (moet %1$.2f %1$.2f wees),. + Verkeerde Maks Basale op Pomp (moet %1$.2f wees). Operasie nie moontlik.\n\n Jy moet jou Medtronic pomp opstel voordat jy die operasie kan gebruik. Oor 24h Tyd was versoek. From 3bb7c331d7cb20727a5adaecd40ce14146ee2150 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sun, 11 Dec 2022 21:17:59 +0100 Subject: [PATCH 41/48] lints --- plugins/main/src/main/AndroidManifest.xml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/plugins/main/src/main/AndroidManifest.xml b/plugins/main/src/main/AndroidManifest.xml index aff7ae7188..1bcf09f595 100644 --- a/plugins/main/src/main/AndroidManifest.xml +++ b/plugins/main/src/main/AndroidManifest.xml @@ -1,11 +1,14 @@ + + - From 0da75f1d69f3e2a29bc52d4ee5361f334c137460 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Sun, 11 Dec 2022 21:36:30 +0100 Subject: [PATCH 42/48] Dana: cleanup --- .../java/info/nightscout/pump/dana/DanaPump.kt | 4 ++-- .../androidaps/danaRv2/DanaRv2Plugin.java | 2 -- .../androidaps/danaRv2/comm/MsgHistoryEventsV2.kt | 2 +- .../danaRv2/services/DanaRv2ExecutionService.java | 13 ++++++------- .../pump/danars/services/DanaRSService.kt | 14 ++++---------- pump/eopatch/src/main/res/values-ko/strings.xml | 1 - 6 files changed, 13 insertions(+), 23 deletions(-) diff --git a/pump/dana/src/main/java/info/nightscout/pump/dana/DanaPump.kt b/pump/dana/src/main/java/info/nightscout/pump/dana/DanaPump.kt index f266dae18e..35764163a6 100644 --- a/pump/dana/src/main/java/info/nightscout/pump/dana/DanaPump.kt +++ b/pump/dana/src/main/java/info/nightscout/pump/dana/DanaPump.kt @@ -55,7 +55,7 @@ class DanaPump @Inject constructor( var lastConnection: Long = 0 var lastSettingsRead: Long = 0 - @JvmField var lastHistoryFetched: Long = 0 + @JvmField var readHistoryFrom: Long = 0 // start next history read from this timestamp @JvmField var historyDoneReceived: Boolean = false // true when last history message is received // Info @@ -410,7 +410,7 @@ class DanaPump @Inject constructor( aapsLogger.debug(LTag.PUMP, "DanaRPump reset") lastConnection = 0 lastSettingsRead = 0 - lastHistoryFetched = 0 + readHistoryFrom = 0 } fun modelFriendlyName(): String = diff --git a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java index 8d4dcfdb0d..3ab6863eb7 100644 --- a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java +++ b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/DanaRv2Plugin.java @@ -57,8 +57,6 @@ public class DanaRv2Plugin extends AbstractDanaRPlugin { private final TemporaryBasalStorage temporaryBasalStorage; private final FabricPrivacy fabricPrivacy; - public long lastEventTimeLoaded = 0; - @Inject public DanaRv2Plugin( HasAndroidInjector injector, diff --git a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt index 6bc89b0077..a904ff0d12 100644 --- a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt +++ b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/comm/MsgHistoryEventsV2.kt @@ -277,7 +277,7 @@ class MsgHistoryEventsV2 constructor( status = "UNKNOWN " + dateUtil.timeString(datetime) } } - if (datetime > danaRv2Plugin.lastEventTimeLoaded) danaRv2Plugin.lastEventTimeLoaded = datetime + if (datetime > danaPump.lastEventTimeLoaded) danaPump.lastEventTimeLoaded = datetime rxBus.send(EventPumpStatusChanged(rh.gs(info.nightscout.pump.dana.R.string.processinghistory) + ": " + status)) } } \ No newline at end of file diff --git a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/services/DanaRv2ExecutionService.java b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/services/DanaRv2ExecutionService.java index 18eabcdf03..f723ac765d 100644 --- a/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/services/DanaRv2ExecutionService.java +++ b/pump/danar/src/main/java/info/nightscout/androidaps/danaRv2/services/DanaRv2ExecutionService.java @@ -346,7 +346,7 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService { MsgSetHistoryEntry_v2 msgSetHistoryEntry_v2 = new MsgSetHistoryEntry_v2(injector, DanaPump.HistoryEntry.CARBS.getValue(), carbtime, carbs, 0); mSerialIOThread.sendMessage(msgSetHistoryEntry_v2); - danaPump.lastHistoryFetched = Math.min(danaPump.lastHistoryFetched, carbtime - T.Companion.mins(1).msecs()); + danaPump.readHistoryFrom = Math.min(danaPump.readHistoryFrom, carbtime - T.Companion.mins(1).msecs()); if (!msgSetHistoryEntry_v2.isReceived() || msgSetHistoryEntry_v2.getFailed()) uiInteraction.runAlarm(rh.gs(info.nightscout.pump.dana.R.string.carbs_store_error), rh.gs(info.nightscout.core.ui.R.string.error), info.nightscout.core.ui.R.raw.boluserror); } @@ -418,7 +418,7 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService { MsgSetHistoryEntry_v2 msgSetHistoryEntry_v2 = new MsgSetHistoryEntry_v2(injector, DanaPump.HistoryEntry.CARBS.getValue(), time, amount, 0); mSerialIOThread.sendMessage(msgSetHistoryEntry_v2); - danaPump.lastHistoryFetched = Math.min(danaPump.lastHistoryFetched, time - T.Companion.mins(1).msecs()); + danaPump.readHistoryFrom = Math.min(danaPump.readHistoryFrom, time - T.Companion.mins(1).msecs()); return true; } @@ -433,18 +433,17 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService { if (!isConnected()) return new PumpEnactResult(injector).success(false); SystemClock.sleep(300); - MsgHistoryEventsV2 msg = new MsgHistoryEventsV2(injector, danaPump.lastHistoryFetched); - aapsLogger.debug(LTag.PUMP, "Loading event history from: " + dateUtil.dateAndTimeString(danaPump.lastHistoryFetched)); + MsgHistoryEventsV2 msg = new MsgHistoryEventsV2(injector, danaPump.readHistoryFrom); + aapsLogger.debug(LTag.PUMP, "Loading event history from: " + dateUtil.dateAndTimeString(danaPump.readHistoryFrom)); mSerialIOThread.sendMessage(msg); while (!danaPump.historyDoneReceived && mRfcommSocket.isConnected()) { SystemClock.sleep(100); } SystemClock.sleep(200); - if (danaRv2Plugin.lastEventTimeLoaded != 0) - danaPump.lastHistoryFetched = danaRv2Plugin.lastEventTimeLoaded - T.Companion.mins(1).msecs(); + if (danaPump.getLastEventTimeLoaded() != 0) danaPump.readHistoryFrom = danaPump.getLastEventTimeLoaded() - T.Companion.mins(1).msecs(); else - danaPump.lastHistoryFetched = 0; + danaPump.readHistoryFrom = 0; danaPump.setLastConnection(System.currentTimeMillis()); return new PumpEnactResult(injector).success(true); } diff --git a/pump/danars/src/main/java/info/nightscout/pump/danars/services/DanaRSService.kt b/pump/danars/src/main/java/info/nightscout/pump/danars/services/DanaRSService.kt index 0b43f17b02..88a5ea63df 100644 --- a/pump/danars/src/main/java/info/nightscout/pump/danars/services/DanaRSService.kt +++ b/pump/danars/src/main/java/info/nightscout/pump/danars/services/DanaRSService.kt @@ -262,19 +262,13 @@ class DanaRSService : DaggerService() { return result } SystemClock.sleep(1000) - val msg: DanaRSPacketAPSHistoryEvents - if (danaPump.lastHistoryFetched == 0L) { - msg = DanaRSPacketAPSHistoryEvents(injector, 0) - aapsLogger.debug(LTag.PUMPCOMM, "Loading complete event history") - } else { - msg = DanaRSPacketAPSHistoryEvents(injector, danaPump.lastHistoryFetched) - aapsLogger.debug(LTag.PUMPCOMM, "Loading event history from: " + dateUtil.dateAndTimeString(danaPump.lastHistoryFetched)) - } + val msg = DanaRSPacketAPSHistoryEvents(injector, danaPump.readHistoryFrom) + aapsLogger.debug(LTag.PUMPCOMM, "Loading event history from: " + dateUtil.dateAndTimeString(danaPump.readHistoryFrom)) sendMessage(msg) while (!danaPump.historyDoneReceived && bleComm.isConnected) { SystemClock.sleep(100) } - danaPump.lastHistoryFetched = if (danaPump.lastEventTimeLoaded != 0L) danaPump.lastEventTimeLoaded - T.mins(1).msecs() else 0 + danaPump.readHistoryFrom = if (danaPump.lastEventTimeLoaded != 0L) danaPump.lastEventTimeLoaded - T.mins(1).msecs() else 0 aapsLogger.debug(LTag.PUMPCOMM, "Events loaded") rxBus.send(EventPumpStatusChanged(rh.gs(info.nightscout.pump.dana.R.string.gettingpumpstatus))) sendMessage(DanaRSPacketGeneralInitialScreenInformation(injector)) @@ -305,7 +299,7 @@ class DanaRSService : DaggerService() { // sendMessage(msg); val msgSetHistoryEntryV2 = DanaRSPacketAPSSetEventHistory(injector, DanaPump.HistoryEntry.CARBS.value, carbTime, carbs, 0) sendMessage(msgSetHistoryEntryV2) - danaPump.lastHistoryFetched = min(danaPump.lastHistoryFetched, carbTime - T.mins(1).msecs()) + danaPump.readHistoryFrom = min(danaPump.readHistoryFrom, carbTime - T.mins(1).msecs()) if (!msgSetHistoryEntryV2.isReceived || msgSetHistoryEntryV2.failed) uiInteraction.runAlarm(rh.gs(info.nightscout.pump.dana.R.string.carbs_store_error), rh.gs(info.nightscout.core.ui.R.string.error), info.nightscout.core.ui.R.raw.boluserror) } diff --git a/pump/eopatch/src/main/res/values-ko/strings.xml b/pump/eopatch/src/main/res/values-ko/strings.xml index b6a4b40c9d..a22c51e5b8 100644 --- a/pump/eopatch/src/main/res/values-ko/strings.xml +++ b/pump/eopatch/src/main/res/values-ko/strings.xml @@ -9,7 +9,6 @@ 패치 버저 알림 h:mm a - 볼루스 %1$.2f U의 주입이 완료되었습니다. BLE 상태 일련 번호 로트 번호 From 63215c778a5aa15217e850e5130c7beb19e564bc Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 12 Dec 2022 08:57:14 +0100 Subject: [PATCH 43/48] NSCv3: updateTreatment --- .../info/nightscout/sdk/NSAndroidClientImpl.kt | 16 ++++++++++++++++ .../nightscout/sdk/interfaces/NSAndroidClient.kt | 3 ++- .../sdk/networking/NightscoutRemoteService.kt | 4 ++++ 3 files changed, 22 insertions(+), 1 deletion(-) diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt index 183c8e09ca..e5ef49e3c4 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt @@ -174,6 +174,22 @@ class NSAndroidClientImpl( } } + override suspend fun updateTreatment(nsTreatment: NSTreatment): CreateUpdateResponse = callWrapper(dispatcher) { + + val remoteTreatment = nsTreatment.toRemoteTreatment() ?: throw InvalidFormatNightscoutException() + val response = api.updateTreatment(remoteTreatment) + if (response.isSuccessful) { + return@callWrapper CreateUpdateResponse( + identifier = response.body()?.result?.identifier ?: throw UnknownResponseNightscoutException(), + isDeduplication = response.body()?.result?.isDeduplication ?: false, + deduplicatedIdentifier = response.body()?.result?.deduplicatedIdentifier, + lastModified = response.body()?.result?.lastModified + ) + } else { + throw TodoNightscoutException() // TODO: react to response errors (offline, ...) + } + } + private suspend fun callWrapper(dispatcher: CoroutineDispatcher, block: suspend () -> T): T = withContext(dispatcher) { retry( diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt index bfb07f1490..2e4f24f0d6 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt @@ -20,5 +20,6 @@ interface NSAndroidClient { suspend fun getSgvsNewerThan(from: Long, limit: Long): List suspend fun getTreatmentsModifiedSince(from: Long, limit: Long): List suspend fun getDeviceStatusModifiedSince(from: Long): List - suspend fun createTreatment(NsTreatment: NSTreatment): CreateUpdateResponse + suspend fun createTreatment(nsTreatment: NSTreatment): CreateUpdateResponse + suspend fun updateTreatment(nsTreatment: NSTreatment): CreateUpdateResponse } \ No newline at end of file diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt index 3ae740d2db..1fc95dfe24 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt @@ -15,6 +15,7 @@ import retrofit2.http.Body import retrofit2.http.GET import retrofit2.http.Header import retrofit2.http.POST +import retrofit2.http.PUT import retrofit2.http.Path import retrofit2.http.Query @@ -58,4 +59,7 @@ internal interface NightscoutRemoteService { @POST("v3/treatments") fun createTreatment(@Body remoteTreatment: RemoteTreatment): Response> + @PUT("v3/treatments") + fun updateTreatment(@Body remoteTreatment: RemoteTreatment): Response> + } From 114710b2920c815486ec4f1a98244e928e2d7488 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 12 Dec 2022 10:54:55 +0100 Subject: [PATCH 44/48] NSC: simplify db interface --- .../interfaces/sync/DataSyncSelector.kt | 28 +++-- .../nightscout/interfaces/sync/NsClient.kt | 4 +- .../DataSyncSelectorImplementation.kt | 114 ++++++------------ .../plugins/sync/nsclient/NSClientPlugin.kt | 66 +++++++++- .../extensions/ExtendedBolusExtension.kt | 15 ++- .../extensions/TemporaryBasalExtension.kt | 40 +++--- .../nsclient/workers/NSClientAddAckWorker.kt | 11 +- .../sync/nsclientV3/NSClientV3Plugin.kt | 9 +- 8 files changed, 156 insertions(+), 131 deletions(-) diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt index dc097f6b8f..2be5a884e2 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt @@ -17,19 +17,21 @@ import org.json.JSONObject interface DataSyncSelector { - data class PairTemporaryTarget(val value: TemporaryTarget, val updateRecordId: Long) - data class PairGlucoseValue(val value: GlucoseValue, val updateRecordId: Long) - data class PairTherapyEvent(val value: TherapyEvent, val updateRecordId: Long) - data class PairFood(val value: Food, val updateRecordId: Long) - data class PairBolus(val value: Bolus, val updateRecordId: Long) - data class PairCarbs(val value: Carbs, val updateRecordId: Long) - data class PairBolusCalculatorResult(val value: BolusCalculatorResult, val updateRecordId: Long) - data class PairTemporaryBasal(val value: TemporaryBasal, val updateRecordId: Long) - data class PairExtendedBolus(val value: ExtendedBolus, val updateRecordId: Long) - data class PairProfileSwitch(val value: ProfileSwitch, val updateRecordId: Long) - data class PairEffectiveProfileSwitch(val value: EffectiveProfileSwitch, val updateRecordId: Long) - data class PairOfflineEvent(val value: OfflineEvent, val updateRecordId: Long) - data class PairProfileStore(val value: JSONObject, val timestampSync: Long) + interface DataPair + data class PairTemporaryTarget(val value: TemporaryTarget, val updateRecordId: Long): DataPair + data class PairGlucoseValue(val value: GlucoseValue, val updateRecordId: Long): DataPair + data class PairTherapyEvent(val value: TherapyEvent, val updateRecordId: Long): DataPair + data class PairFood(val value: Food, val updateRecordId: Long): DataPair + data class PairBolus(val value: Bolus, val updateRecordId: Long): DataPair + data class PairCarbs(val value: Carbs, val updateRecordId: Long): DataPair + data class PairBolusCalculatorResult(val value: BolusCalculatorResult, val updateRecordId: Long): DataPair + data class PairTemporaryBasal(val value: TemporaryBasal, val updateRecordId: Long): DataPair + data class PairExtendedBolus(val value: ExtendedBolus, val updateRecordId: Long): DataPair + data class PairProfileSwitch(val value: ProfileSwitch, val updateRecordId: Long): DataPair + data class PairEffectiveProfileSwitch(val value: EffectiveProfileSwitch, val updateRecordId: Long): DataPair + data class PairOfflineEvent(val value: OfflineEvent, val updateRecordId: Long): DataPair + data class PairProfileStore(val value: JSONObject, val timestampSync: Long): DataPair + data class PairDeviceStatus(val value: DeviceStatus, val unused: Long?): DataPair fun queueSize(): Long diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt index 6ef90a7c02..83af92e514 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt @@ -23,6 +23,6 @@ interface NsClient : Sync { fun resetToFullSync() - fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) - fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) + fun dbAdd(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) + fun dbUpdate(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt index 7536a783d9..6b290067c8 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt @@ -1,6 +1,5 @@ package info.nightscout.plugins.sync.nsclient -import info.nightscout.core.extensions.toJson import info.nightscout.database.ValueWrapper import info.nightscout.database.entities.Bolus import info.nightscout.database.entities.BolusCalculatorResult @@ -20,7 +19,6 @@ import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.sync.DataSyncSelector import info.nightscout.plugins.sync.R -import info.nightscout.plugins.sync.nsclient.extensions.toJson import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.sharedPreferences.SP @@ -161,7 +159,6 @@ class DataSyncSelectorImplementation @Inject constructor( bolus.first.interfaceIDs.nightscoutId == null -> activePlugin.activeNsClient?.dbAdd( "treatments", - bolus.first.toJson(true, dateUtil), DataSyncSelector.PairBolus(bolus.first, bolus.second.id), " $startId/$lastDbId" ) @@ -169,8 +166,6 @@ class DataSyncSelectorImplementation @Inject constructor( bolus.first.interfaceIDs.nightscoutId != null && bolus.first.id != bolus.second.id -> activePlugin.activeNsClient?.dbUpdate( "treatments", - bolus.first.interfaceIDs.nightscoutId, - bolus.first.toJson(false, dateUtil), DataSyncSelector.PairBolus(bolus.first, bolus.second.id), "$startId/$lastDbId" ) @@ -222,13 +217,11 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new carb.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd("treatments", carb.first.toJson(true, dateUtil), DataSyncSelector.PairCarbs(carb.first, carb.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("treatments", DataSyncSelector.PairCarbs(carb.first, carb.second.id), "$startId/$lastDbId") // with nsId = update if it's modified record carb.first.interfaceIDs.nightscoutId != null && carb.first.id != carb.second.id -> activePlugin.activeNsClient?.dbUpdate( "treatments", - carb.first.interfaceIDs.nightscoutId, - carb.first.toJson(false, dateUtil), DataSyncSelector.PairCarbs(carb.first, carb.second.id), "$startId/$lastDbId" ) @@ -282,14 +275,13 @@ class DataSyncSelectorImplementation @Inject constructor( bolusCalculatorResult.first.interfaceIDs.nightscoutId == null -> activePlugin.activeNsClient?.dbAdd( "treatments", - bolusCalculatorResult.first.toJson(true, dateUtil, profileFunction), DataSyncSelector.PairBolusCalculatorResult(bolusCalculatorResult.first, bolusCalculatorResult.second.id), "$startId/$lastDbId" ) // with nsId = update if it's modified record bolusCalculatorResult.first.interfaceIDs.nightscoutId != null && bolusCalculatorResult.first.id != bolusCalculatorResult.second.id -> activePlugin.activeNsClient?.dbUpdate( - "treatments", bolusCalculatorResult.first.interfaceIDs.nightscoutId, bolusCalculatorResult.first.toJson(false, dateUtil, profileFunction), + "treatments", DataSyncSelector.PairBolusCalculatorResult(bolusCalculatorResult.first, bolusCalculatorResult.second.id), "$startId/$lastDbId" ) } @@ -342,7 +334,6 @@ class DataSyncSelectorImplementation @Inject constructor( tt.first.interfaceIDs.nightscoutId == null -> activePlugin.activeNsClient?.dbAdd( "treatments", - tt.first.toJson(true, profileFunction.getUnits(), dateUtil), DataSyncSelector.PairTemporaryTarget(tt.first, tt.second.id), "$startId/$lastDbId" ) @@ -350,8 +341,6 @@ class DataSyncSelectorImplementation @Inject constructor( tt.first.interfaceIDs.nightscoutId != null -> activePlugin.activeNsClient?.dbUpdate( "treatments", - tt.first.interfaceIDs.nightscoutId, - tt.first.toJson(false, profileFunction.getUnits(), dateUtil), DataSyncSelector.PairTemporaryTarget(tt.first, tt.second.id), "$startId/$lastDbId" ) @@ -403,13 +392,11 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new food.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd("food", food.first.toJson(true), DataSyncSelector.PairFood(food.first, food.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("food", DataSyncSelector.PairFood(food.first, food.second.id), "$startId/$lastDbId") // with nsId = update food.first.interfaceIDs.nightscoutId != null -> activePlugin.activeNsClient?.dbUpdate( "food", - food.first.interfaceIDs.nightscoutId, - food.first.toJson(false), DataSyncSelector.PairFood(food.first, food.second.id), "$startId/$lastDbId" ) @@ -462,13 +449,11 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new gv.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd("entries", gv.first.toJson(true, dateUtil), DataSyncSelector.PairGlucoseValue(gv.first, gv.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("entries", DataSyncSelector.PairGlucoseValue(gv.first, gv.second.id), "$startId/$lastDbId") // with nsId = update else -> // gv.first.interfaceIDs.nightscoutId != null activePlugin.activeNsClient?.dbUpdate( "entries", - gv.first.interfaceIDs.nightscoutId, - gv.first.toJson(false, dateUtil), DataSyncSelector.PairGlucoseValue(gv.first, gv.second.id), "$startId/$lastDbId" ) @@ -524,13 +509,11 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new te.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd("treatments", te.first.toJson(true, dateUtil), DataSyncSelector.PairTherapyEvent(te.first, te.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("treatments", DataSyncSelector.PairTherapyEvent(te.first, te.second.id), "$startId/$lastDbId") // nsId = update te.first.interfaceIDs.nightscoutId != null -> activePlugin.activeNsClient?.dbUpdate( "treatments", - te.first.interfaceIDs.nightscoutId, - te.first.toJson(false, dateUtil), DataSyncSelector.PairTherapyEvent(te.first, te.second.id), "$startId/$lastDbId" ) @@ -567,7 +550,7 @@ class DataSyncSelectorImplementation @Inject constructor( when { // without nsId = create new deviceStatus.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd("devicestatus", deviceStatus.toJson(dateUtil), deviceStatus, "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("devicestatus", DataSyncSelector.PairDeviceStatus(deviceStatus, null), "$startId/$lastDbId") // with nsId = ignore deviceStatus.interfaceIDs.nightscoutId != null -> Any() } @@ -601,48 +584,37 @@ class DataSyncSelectorImplementation @Inject constructor( queueCounter.tbrsRemaining = lastDbId - startId appRepository.getNextSyncElementTemporaryBasal(startId).blockingGet()?.let { tb -> aapsLogger.info(LTag.NSCLIENT, "Loading TemporaryBasal data Start: $startId ID: ${tb.first.id} HistoryID: ${tb.second} ") - val profile = profileFunction.getProfile(tb.first.timestamp) - if (profile != null) { - when { - // new record with existing NS id => must be coming from NS => ignore - tb.first.id == tb.second.id && tb.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. Loaded from NS: ${tb.first.id} HistoryID: ${tb.second.id} ") - confirmLastTemporaryBasalIdIfGreater(tb.second.id) - processChangedTemporaryBasalsCompat() - return - } - // only NsId changed, no need to upload - tb.first.onlyNsIdAdded(tb.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. Only NS id changed ID: ${tb.first.id} HistoryID: ${tb.second.id} ") - confirmLastTemporaryBasalIdIfGreater(tb.second.id) - processChangedTemporaryBasalsCompat() - return - } - // without nsId = create new - tb.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd( - "treatments", - tb.first.toJson(true, profile, dateUtil), - DataSyncSelector.PairTemporaryBasal(tb.first, tb.second.id), - "$startId/$lastDbId" - ) - // with nsId = update - tb.first.interfaceIDs.nightscoutId != null -> - activePlugin.activeNsClient?.dbUpdate( - "treatments", - tb.first.interfaceIDs.nightscoutId, - tb.first.toJson(false, profile, dateUtil), - DataSyncSelector.PairTemporaryBasal(tb.first, tb.second.id), - "$startId/$lastDbId" - ) + when { + // new record with existing NS id => must be coming from NS => ignore + tb.first.id == tb.second.id && tb.first.interfaceIDs.nightscoutId != null -> { + aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. Loaded from NS: ${tb.first.id} HistoryID: ${tb.second.id} ") + confirmLastTemporaryBasalIdIfGreater(tb.second.id) + processChangedTemporaryBasalsCompat() + return } - return - } else { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. No profile: ${tb.first.id} HistoryID: ${tb.second.id} ") - confirmLastTemporaryBasalIdIfGreater(tb.second.id) - processChangedTemporaryBasalsCompat() - return + // only NsId changed, no need to upload + tb.first.onlyNsIdAdded(tb.second) -> { + aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. Only NS id changed ID: ${tb.first.id} HistoryID: ${tb.second.id} ") + confirmLastTemporaryBasalIdIfGreater(tb.second.id) + processChangedTemporaryBasalsCompat() + return + } + // without nsId = create new + tb.first.interfaceIDs.nightscoutId == null -> + activePlugin.activeNsClient?.dbAdd( + "treatments", + DataSyncSelector.PairTemporaryBasal(tb.first, tb.second.id), + "$startId/$lastDbId" + ) + // with nsId = update + tb.first.interfaceIDs.nightscoutId != null -> + activePlugin.activeNsClient?.dbUpdate( + "treatments", + DataSyncSelector.PairTemporaryBasal(tb.first, tb.second.id), + "$startId/$lastDbId" + ) } + return } } @@ -693,7 +665,6 @@ class DataSyncSelectorImplementation @Inject constructor( eb.first.interfaceIDs.nightscoutId == null -> activePlugin.activeNsClient?.dbAdd( "treatments", - eb.first.toJson(true, profile, dateUtil), DataSyncSelector.PairExtendedBolus(eb.first, eb.second.id), "$startId/$lastDbId" ) @@ -701,8 +672,6 @@ class DataSyncSelectorImplementation @Inject constructor( eb.first.interfaceIDs.nightscoutId != null -> activePlugin.activeNsClient?.dbUpdate( "treatments", - eb.first.interfaceIDs.nightscoutId, - eb.first.toJson(false, profile, dateUtil), DataSyncSelector.PairExtendedBolus(eb.first, eb.second.id), "$startId/$lastDbId" ) @@ -759,13 +728,11 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new ps.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd("treatments", ps.first.toJson(true, dateUtil), DataSyncSelector.PairProfileSwitch(ps.first, ps.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("treatments", DataSyncSelector.PairProfileSwitch(ps.first, ps.second.id), "$startId/$lastDbId") // with nsId = update ps.first.interfaceIDs.nightscoutId != null -> activePlugin.activeNsClient?.dbUpdate( "treatments", - ps.first.interfaceIDs.nightscoutId, - ps.first.toJson(false, dateUtil), DataSyncSelector.PairProfileSwitch(ps.first, ps.second.id), "$startId/$lastDbId" ) @@ -818,7 +785,6 @@ class DataSyncSelectorImplementation @Inject constructor( ps.first.interfaceIDs.nightscoutId == null -> activePlugin.activeNsClient?.dbAdd( "treatments", - ps.first.toJson(true, dateUtil), DataSyncSelector.PairEffectiveProfileSwitch(ps.first, ps.second.id), "$startId/$lastDbId" ) @@ -826,8 +792,6 @@ class DataSyncSelectorImplementation @Inject constructor( ps.first.interfaceIDs.nightscoutId != null -> activePlugin.activeNsClient?.dbUpdate( "treatments", - ps.first.interfaceIDs.nightscoutId, - ps.first.toJson(false, dateUtil), DataSyncSelector.PairEffectiveProfileSwitch(ps.first, ps.second.id), "$startId/$lastDbId" ) @@ -879,13 +843,11 @@ class DataSyncSelectorImplementation @Inject constructor( } // without nsId = create new oe.first.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd("treatments", oe.first.toJson(true, dateUtil), DataSyncSelector.PairOfflineEvent(oe.first, oe.second.id), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("treatments", DataSyncSelector.PairOfflineEvent(oe.first, oe.second.id), "$startId/$lastDbId") // existing with nsId = update oe.first.interfaceIDs.nightscoutId != null -> activePlugin.activeNsClient?.dbUpdate( "treatments", - oe.first.interfaceIDs.nightscoutId, - oe.first.toJson(false, dateUtil), DataSyncSelector.PairOfflineEvent(oe.first, oe.second.id), "$startId/$lastDbId" ) @@ -905,7 +867,7 @@ class DataSyncSelectorImplementation @Inject constructor( if (lastChange > lastSync) { if (activePlugin.activeProfileSource.profile?.allProfilesValid != true) return val profileJson = activePlugin.activeProfileSource.profile?.data ?: return - activePlugin.activeNsClient?.dbAdd("profile", profileJson, DataSyncSelector.PairProfileStore(profileJson, dateUtil.now()), "") + activePlugin.activeNsClient?.dbAdd("profile", DataSyncSelector.PairProfileStore(profileJson, dateUtil.now()), "") } } } diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt index a6dad603c0..31bdf18474 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt @@ -12,6 +12,7 @@ import androidx.preference.PreferenceFragmentCompat import androidx.preference.PreferenceScreen import androidx.preference.SwitchPreference import dagger.android.HasAndroidInjector +import info.nightscout.core.extensions.toJson import info.nightscout.core.utils.fabric.FabricPrivacy import info.nightscout.interfaces.Config import info.nightscout.interfaces.Constants @@ -20,6 +21,7 @@ import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType +import info.nightscout.interfaces.profile.ProfileFunction import info.nightscout.interfaces.source.DoingOwnUploadSource import info.nightscout.interfaces.sync.DataSyncSelector import info.nightscout.interfaces.sync.NsClient @@ -32,6 +34,7 @@ import info.nightscout.plugins.sync.nsShared.events.EventNSClientResend import info.nightscout.plugins.sync.nsShared.events.EventNSClientStatus import info.nightscout.plugins.sync.nsShared.events.EventNSClientUpdateGUI import info.nightscout.plugins.sync.nsclient.data.AlarmAck +import info.nightscout.plugins.sync.nsclient.extensions.toJson import info.nightscout.plugins.sync.nsclient.services.NSClientService import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus @@ -45,9 +48,9 @@ import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag import info.nightscout.shared.interfaces.ResourceHelper import info.nightscout.shared.sharedPreferences.SP +import info.nightscout.shared.utils.DateUtil import io.reactivex.rxjava3.disposables.CompositeDisposable import io.reactivex.rxjava3.kotlin.plusAssign -import org.json.JSONObject import javax.inject.Inject import javax.inject.Singleton @@ -65,7 +68,9 @@ class NSClientPlugin @Inject constructor( private val config: Config, private val dataSyncSelector: DataSyncSelector, private val uiInteraction: UiInteraction, - private val activePlugin: ActivePlugin + private val activePlugin: ActivePlugin, + private val dateUtil: DateUtil, + private val profileFunction: ProfileFunction ) : NsClient, Sync, PluginBase( PluginDescription() .mainType(PluginType.SYNC) @@ -237,11 +242,60 @@ class NSClientPlugin @Inject constructor( dataSyncSelector.resetToNextFullSync() } - override fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) { - nsClientService?.dbAdd(collection, data, originalObject, progress) + override fun dbAdd(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) { + when (originalObject) { + is DataSyncSelector.PairBolus -> originalObject.value.toJson(true, dateUtil) + is DataSyncSelector.PairCarbs -> originalObject.value.toJson(true, dateUtil) + is DataSyncSelector.PairBolusCalculatorResult -> originalObject.value.toJson(true, dateUtil, profileFunction) + is DataSyncSelector.PairTemporaryTarget -> originalObject.value.toJson(true, profileFunction.getUnits(), dateUtil) + is DataSyncSelector.PairFood -> originalObject.value.toJson(true) + is DataSyncSelector.PairGlucoseValue -> originalObject.value.toJson(true, dateUtil) + is DataSyncSelector.PairTherapyEvent -> originalObject.value.toJson(true, dateUtil) + is DataSyncSelector.PairDeviceStatus -> originalObject.value.toJson(dateUtil) + is DataSyncSelector.PairTemporaryBasal -> originalObject.value.toJson(true, profileFunction.getProfile(originalObject.value.timestamp), dateUtil) + is DataSyncSelector.PairExtendedBolus -> originalObject.value.toJson(true, profileFunction.getProfile(originalObject.value.timestamp), dateUtil) + is DataSyncSelector.PairProfileSwitch -> originalObject.value.toJson(true, dateUtil) + is DataSyncSelector.PairEffectiveProfileSwitch -> originalObject.value.toJson(true, dateUtil) + is DataSyncSelector.PairOfflineEvent -> originalObject.value.toJson(true, dateUtil) + is DataSyncSelector.PairProfileStore -> originalObject.value + else -> null + }?.let { data -> + nsClientService?.dbAdd(collection, data, originalObject, progress) + } } - override fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) { - nsClientService?.dbUpdate(collection, _id, data, originalObject, progress) + override fun dbUpdate(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) { + val id = when (originalObject) { + is DataSyncSelector.PairBolus -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairCarbs -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairBolusCalculatorResult -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairTemporaryTarget -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairFood -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairGlucoseValue -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairTherapyEvent -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairTemporaryBasal -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairExtendedBolus -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairProfileSwitch -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairEffectiveProfileSwitch -> originalObject.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairOfflineEvent -> originalObject.value.interfaceIDs.nightscoutId + else -> throw IllegalStateException() + } + when (originalObject) { + is DataSyncSelector.PairBolus -> originalObject.value.toJson(false, dateUtil) + is DataSyncSelector.PairCarbs -> originalObject.value.toJson(false, dateUtil) + is DataSyncSelector.PairBolusCalculatorResult -> originalObject.value.toJson(false, dateUtil, profileFunction) + is DataSyncSelector.PairTemporaryTarget -> originalObject.value.toJson(false, profileFunction.getUnits(), dateUtil) + is DataSyncSelector.PairFood -> originalObject.value.toJson(false) + is DataSyncSelector.PairGlucoseValue -> originalObject.value.toJson(false, dateUtil) + is DataSyncSelector.PairTherapyEvent -> originalObject.value.toJson(false, dateUtil) + is DataSyncSelector.PairTemporaryBasal -> originalObject.value.toJson(false, profileFunction.getProfile(originalObject.value.timestamp), dateUtil) + is DataSyncSelector.PairExtendedBolus -> originalObject.value.toJson(false, profileFunction.getProfile(originalObject.value.timestamp), dateUtil) + is DataSyncSelector.PairProfileSwitch -> originalObject.value.toJson(false, dateUtil) + is DataSyncSelector.PairEffectiveProfileSwitch -> originalObject.value.toJson(false, dateUtil) + is DataSyncSelector.PairOfflineEvent -> originalObject.value.toJson(false, dateUtil) + else -> null + }?.let { data -> + nsClientService?.dbUpdate(collection, id, data, originalObject, progress) + } } } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/ExtendedBolusExtension.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/ExtendedBolusExtension.kt index 22ad91b616..5e2f62df7d 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/ExtendedBolusExtension.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/ExtendedBolusExtension.kt @@ -9,12 +9,15 @@ import info.nightscout.shared.utils.DateUtil import info.nightscout.shared.utils.T import org.json.JSONObject -fun ExtendedBolus.toJson(isAdd: Boolean, profile: Profile, dateUtil: DateUtil): JSONObject = - if (isEmulatingTempBasal) - toTemporaryBasal(profile) - .toJson(isAdd, profile, dateUtil) - .put("extendedEmulated", toRealJson(isAdd, dateUtil)) - else toRealJson(isAdd, dateUtil) +fun ExtendedBolus.toJson(isAdd: Boolean, profile: Profile?, dateUtil: DateUtil): JSONObject? = + profile?.let { + if (isEmulatingTempBasal) + toTemporaryBasal(profile) + .toJson(isAdd, profile, dateUtil) + ?.put("extendedEmulated", toRealJson(isAdd, dateUtil)) + else toRealJson(isAdd, dateUtil) + } + fun ExtendedBolus.toRealJson(isAdd: Boolean, dateUtil: DateUtil): JSONObject = JSONObject() diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/TemporaryBasalExtension.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/TemporaryBasalExtension.kt index e79e2ce859..79d8e32b23 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/TemporaryBasalExtension.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/extensions/TemporaryBasalExtension.kt @@ -10,25 +10,27 @@ import info.nightscout.shared.utils.DateUtil import info.nightscout.shared.utils.T import org.json.JSONObject -fun TemporaryBasal.toJson(isAdd: Boolean, profile: Profile, dateUtil: DateUtil): JSONObject = - JSONObject() - .put("created_at", dateUtil.toISOString(timestamp)) - .put("enteredBy", "openaps://" + "AndroidAPS") - .put("eventType", info.nightscout.database.entities.TherapyEvent.Type.TEMPORARY_BASAL.text) - .put("isValid", isValid) - .put("duration", T.msecs(duration).mins()) - .put("durationInMilliseconds", duration) // rounded duration leads to different basal IOB - .put("type", type.name) - .put("rate", convertedToAbsolute(timestamp, profile)) // generated by OpenAPS, for compatibility - .also { - if (isAbsolute) it.put("absolute", rate) - else it.put("percent", rate - 100) - if (interfaceIDs.pumpId != null) it.put("pumpId", interfaceIDs.pumpId) - if (interfaceIDs.endId != null) it.put("endId", interfaceIDs.endId) - if (interfaceIDs.pumpType != null) it.put("pumpType", interfaceIDs.pumpType!!.name) - if (interfaceIDs.pumpSerial != null) it.put("pumpSerial", interfaceIDs.pumpSerial) - if (isAdd && interfaceIDs.nightscoutId != null) it.put("_id", interfaceIDs.nightscoutId) - } +fun TemporaryBasal.toJson(isAdd: Boolean, profile: Profile?, dateUtil: DateUtil): JSONObject? = + profile?.let { + JSONObject() + .put("created_at", dateUtil.toISOString(timestamp)) + .put("enteredBy", "openaps://" + "AndroidAPS") + .put("eventType", info.nightscout.database.entities.TherapyEvent.Type.TEMPORARY_BASAL.text) + .put("isValid", isValid) + .put("duration", T.msecs(duration).mins()) + .put("durationInMilliseconds", duration) // rounded duration leads to different basal IOB + .put("type", type.name) + .put("rate", convertedToAbsolute(timestamp, profile)) // generated by OpenAPS, for compatibility + .also { + if (isAbsolute) it.put("absolute", rate) + else it.put("percent", rate - 100) + if (interfaceIDs.pumpId != null) it.put("pumpId", interfaceIDs.pumpId) + if (interfaceIDs.endId != null) it.put("endId", interfaceIDs.endId) + if (interfaceIDs.pumpType != null) it.put("pumpType", interfaceIDs.pumpType!!.name) + if (interfaceIDs.pumpSerial != null) it.put("pumpSerial", interfaceIDs.pumpSerial) + if (isAdd && interfaceIDs.nightscoutId != null) it.put("_id", interfaceIDs.nightscoutId) + } + } fun temporaryBasalFromJson(jsonObject: JSONObject): TemporaryBasal? { val timestamp = JsonHelper.safeGetLongAllowNull(jsonObject, "mills", null) ?: return null diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt index ad0e5946cd..6ed89f0e81 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt @@ -6,7 +6,6 @@ import androidx.work.WorkerParameters import androidx.work.workDataOf import info.nightscout.core.utils.receivers.DataWorkerStorage import info.nightscout.core.utils.worker.LoggingWorker -import info.nightscout.database.entities.DeviceStatus import info.nightscout.database.impl.AppRepository import info.nightscout.database.impl.transactions.UpdateNsIdBolusCalculatorResultTransaction import info.nightscout.database.impl.transactions.UpdateNsIdBolusTransaction @@ -274,10 +273,10 @@ class NSClientAddAckWorker( dataSyncSelector.processChangedEffectiveProfileSwitchesCompat() } - is DeviceStatus -> { + is DataSyncSelector.PairDeviceStatus -> { val deviceStatus = ack.originalObject - deviceStatus.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdDeviceStatusTransaction(deviceStatus)) + deviceStatus.value.interfaceIDs.nightscoutId = ack.id + repository.runTransactionForResult(UpdateNsIdDeviceStatusTransaction(deviceStatus.value)) .doOnError { error -> aapsLogger.error(LTag.DATABASE, "Updated ns id of DeviceStatus failed", error) ret = Result.failure((workDataOf("Error" to error.toString()))) @@ -285,10 +284,10 @@ class NSClientAddAckWorker( .doOnSuccess { ret = Result.success(workDataOf("ProcessedData" to deviceStatus.toString())) aapsLogger.debug(LTag.DATABASE, "Updated ns id of DeviceStatus $deviceStatus") - dataSyncSelector.confirmLastDeviceStatusIdIfGreater(deviceStatus.id) + dataSyncSelector.confirmLastDeviceStatusIdIfGreater(deviceStatus.value.id) } .blockingGet() - rxBus.send(EventNSClientNewLog("DBADD", "Acked DeviceStatus " + deviceStatus.interfaceIDs.nightscoutId)) + rxBus.send(EventNSClientNewLog("DBADD", "Acked DeviceStatus " + deviceStatus.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedDeviceStatusesCompat() } diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt index 9cc8242897..339ca53626 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt @@ -19,6 +19,7 @@ import info.nightscout.interfaces.nsclient.NSAlarm import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType +import info.nightscout.interfaces.sync.DataSyncSelector import info.nightscout.interfaces.sync.NsClient import info.nightscout.interfaces.sync.Sync import info.nightscout.interfaces.ui.UiInteraction @@ -301,11 +302,13 @@ class NSClientV3Plugin @Inject constructor( storeLastFetched() } - override fun dbAdd(collection: String, data: JSONObject, originalObject: Any, progress: String) { - TODO("Not yet implemented") + override fun dbAdd(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) { + if (collection == "treatments") { + //val result = nsAndroidClient.createTreatment() + } } - override fun dbUpdate(collection: String, _id: String?, data: JSONObject?, originalObject: Any, progress: String) { + override fun dbUpdate(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) { TODO("Not yet implemented") } From 85f170f17d5af3a117257da0e91743730166d8cc Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 12 Dec 2022 17:21:31 +0100 Subject: [PATCH 45/48] NSC: process nsId updates at once --- .../interfaces/nsclient/StoreDataForDb.kt | 41 ++++ .../interfaces/sync/DataSyncSelector.kt | 39 ---- .../nightscout/interfaces/sync/NsClient.kt | 5 +- .../sdk/localmodel/treatment/NSBolus.kt | 14 +- .../sdk/localmodel/treatment/NSBolusWizard.kt | 2 +- .../sdk/localmodel/treatment/NSCarbs.kt | 2 +- .../treatment/NSEffectiveProfileSwitch.kt | 2 +- .../localmodel/treatment/NSExtendedBolus.kt | 2 +- .../localmodel/treatment/NSOfflineEvent.kt | 2 +- .../localmodel/treatment/NSProfileSwitch.kt | 2 +- .../localmodel/treatment/NSTemporaryBasal.kt | 2 +- .../localmodel/treatment/NSTemporaryTarget.kt | 2 +- .../localmodel/treatment/NSTherapyEvent.kt | 2 +- .../sdk/localmodel/treatment/NSTreatment.kt | 2 +- .../sdk/remotemodel/RemoteTreatment.kt | 2 +- ...ateNsIdBolusCalculatorResultTransaction.kt | 22 +- .../UpdateNsIdBolusTransaction.kt | 22 +- .../UpdateNsIdCarbsTransaction.kt | 22 +- .../UpdateNsIdDeviceStatusTransaction.kt | 22 +- ...teNsIdEffectiveProfileSwitchTransaction.kt | 22 +- .../UpdateNsIdExtendedBolusTransaction.kt | 22 +- .../transactions/UpdateNsIdFoodTransaction.kt | 23 +- .../UpdateNsIdGlucoseValueTransaction.kt | 22 +- .../UpdateNsIdOfflineEventTransaction.kt | 22 +- .../UpdateNsIdProfileSwitchTransaction.kt | 22 +- .../UpdateNsIdTemporaryBasalTransaction.kt | 22 +- .../UpdateNsIdTemporaryTargetTransaction.kt | 22 +- .../UpdateNsIdTherapyEventTransaction.kt | 22 +- .../sync/nsShared/StoreDataForDbImpl.kt | 218 ++++++++++++++++-- .../DataSyncSelectorImplementation.kt | 193 +++------------- .../plugins/sync/nsclient/NSClientPlugin.kt | 90 ++++---- .../plugins/sync/nsclient/acks/NSAddAck.kt | 23 +- .../plugins/sync/nsclient/acks/NSUpdateAck.kt | 19 +- .../sync/nsclient/services/NSClientService.kt | 34 +-- .../nsclient/workers/NSClientAddAckWorker.kt | 207 ++++------------- .../workers/NSClientAddUpdateWorker.kt | 4 +- .../nsclient/workers/NSClientMbgWorker.kt | 4 +- .../sync/nsclientV3/NSClientV3Plugin.kt | 31 ++- .../nsclientV3/extensions/BolusExtension.kt | 26 +++ .../workers/LoadTreatmentsWorker.kt | 4 +- .../workers/ProcessTreatmentsWorker.kt | 4 +- 41 files changed, 700 insertions(+), 565 deletions(-) diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/nsclient/StoreDataForDb.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/nsclient/StoreDataForDb.kt index d01b23f829..7bb85952c0 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/nsclient/StoreDataForDb.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/nsclient/StoreDataForDb.kt @@ -1,7 +1,48 @@ package info.nightscout.interfaces.nsclient +import info.nightscout.database.entities.Bolus +import info.nightscout.database.entities.BolusCalculatorResult +import info.nightscout.database.entities.Carbs +import info.nightscout.database.entities.DeviceStatus +import info.nightscout.database.entities.EffectiveProfileSwitch +import info.nightscout.database.entities.ExtendedBolus +import info.nightscout.database.entities.Food +import info.nightscout.database.entities.GlucoseValue +import info.nightscout.database.entities.OfflineEvent +import info.nightscout.database.entities.ProfileSwitch +import info.nightscout.database.entities.TemporaryBasal +import info.nightscout.database.entities.TemporaryTarget +import info.nightscout.database.entities.TherapyEvent import info.nightscout.database.transactions.TransactionGlucoseValue interface StoreDataForDb { val glucoseValues: MutableList + val boluses: MutableList + val carbs: MutableList + val temporaryTargets: MutableList + val effectiveProfileSwitches: MutableList + val bolusCalculatorResults: MutableList + val therapyEvents: MutableList + val extendedBoluses: MutableList + val temporaryBasals: MutableList + val profileSwitches: MutableList + val offlineEvents: MutableList + + val nsIdGlucoseValues: MutableList + val nsIdBoluses: MutableList + val nsIdCarbs: MutableList + val nsIdFoods: MutableList + val nsIdTemporaryTargets: MutableList + val nsIdEffectiveProfileSwitches: MutableList + val nsIdBolusCalculatorResults: MutableList + val nsIdTherapyEvents: MutableList + val nsIdExtendedBoluses: MutableList + val nsIdTemporaryBasals: MutableList + val nsIdProfileSwitches: MutableList + val nsIdOfflineEvents: MutableList + val nsIdDeviceStatuses: MutableList + + fun storeTreatmentsToDb() + fun storeGlucoseValuesToDb() + fun scheduleNsIdUpdate() } \ No newline at end of file diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt index 2be5a884e2..73ae9bd313 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt @@ -40,81 +40,42 @@ interface DataSyncSelector { fun resetToNextFullSync() fun confirmLastBolusIdIfGreater(lastSynced: Long) - fun changedBoluses(): List - - // Until NS v3 fun processChangedBolusesCompat() fun confirmLastCarbsIdIfGreater(lastSynced: Long) - fun changedCarbs(): List - - // Until NS v3 fun processChangedCarbsCompat() fun confirmLastBolusCalculatorResultsIdIfGreater(lastSynced: Long) - fun changedBolusCalculatorResults(): List - - // Until NS v3 fun processChangedBolusCalculatorResultsCompat() fun confirmLastTempTargetsIdIfGreater(lastSynced: Long) - fun changedTempTargets(): List - - // Until NS v3 fun processChangedTempTargetsCompat() fun confirmLastGlucoseValueIdIfGreater(lastSynced: Long) - fun changedGlucoseValues(): List - - // Until NS v3 fun processChangedGlucoseValuesCompat() fun confirmLastTherapyEventIdIfGreater(lastSynced: Long) - fun changedTherapyEvents(): List - - // Until NS v3 fun processChangedTherapyEventsCompat() fun confirmLastFoodIdIfGreater(lastSynced: Long) - fun changedFoods(): List - - // Until NS v3 fun processChangedFoodsCompat() fun confirmLastDeviceStatusIdIfGreater(lastSynced: Long) - fun changedDeviceStatuses(): List - - // Until NS v3 fun processChangedDeviceStatusesCompat() fun confirmLastTemporaryBasalIdIfGreater(lastSynced: Long) - fun changedTemporaryBasals(): List - - // Until NS v3 fun processChangedTemporaryBasalsCompat() fun confirmLastExtendedBolusIdIfGreater(lastSynced: Long) - fun changedExtendedBoluses(): List - - // Until NS v3 fun processChangedExtendedBolusesCompat() fun confirmLastProfileSwitchIdIfGreater(lastSynced: Long) - fun changedProfileSwitch(): List - - // Until NS v3 fun processChangedProfileSwitchesCompat() fun confirmLastEffectiveProfileSwitchIdIfGreater(lastSynced: Long) - fun changedEffectiveProfileSwitch(): List - - // Until NS v3 fun processChangedEffectiveProfileSwitchesCompat() fun confirmLastOfflineEventIdIfGreater(lastSynced: Long) - fun changedOfflineEvents(): List - - // Until NS v3 fun processChangedOfflineEventsCompat() fun confirmLastProfileStore(lastSynced: Long) diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt index 83af92e514..f45013aa16 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/NsClient.kt @@ -2,7 +2,6 @@ package info.nightscout.interfaces.sync import android.text.Spanned import info.nightscout.interfaces.nsclient.NSAlarm -import org.json.JSONObject interface NsClient : Sync { enum class Version { @@ -23,6 +22,6 @@ interface NsClient : Sync { fun resetToFullSync() - fun dbAdd(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) - fun dbUpdate(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) + fun dbAdd(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) + fun dbUpdate(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) } \ No newline at end of file diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt index dbc9f63408..f7cda2174e 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt @@ -4,14 +4,14 @@ import info.nightscout.sdk.localmodel.entry.NsUnits data class NSBolus( override val date: Long, - override val device: String?, - override val identifier: String, - override val units: NsUnits?, - override val srvModified: Long?, - override val srvCreated: Long?, + override val device: String?= null, + override val identifier: String?, + override val units: NsUnits?= null, + override val srvModified: Long? = null, + override val srvCreated: Long? = null, override val utcOffset: Long, - override val subject: String?, - override var isReadOnly: Boolean, + override val subject: String? = null, + override var isReadOnly: Boolean = false, override val isValid: Boolean, override val eventType: EventType, override val notes: String?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt index d192577c70..01be68e231 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt @@ -6,7 +6,7 @@ import org.json.JSONObject data class NSBolusWizard( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt index b3069a4a1d..15003a02f3 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt @@ -5,7 +5,7 @@ import info.nightscout.sdk.localmodel.entry.NsUnits data class NSCarbs( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt index 731048b678..312d542daf 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt @@ -6,7 +6,7 @@ import org.json.JSONObject data class NSEffectiveProfileSwitch( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt index cb179b70d2..8228c45200 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt @@ -5,7 +5,7 @@ import info.nightscout.sdk.localmodel.entry.NsUnits data class NSExtendedBolus( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt index 1d64e0c6cd..dd95c02c3b 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt @@ -5,7 +5,7 @@ import info.nightscout.sdk.localmodel.entry.NsUnits data class NSOfflineEvent( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt index d36056eebd..bd6fa96888 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt @@ -6,7 +6,7 @@ import org.json.JSONObject data class NSProfileSwitch( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt index b3dabf908a..3592c25135 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt @@ -6,7 +6,7 @@ import org.json.JSONObject data class NSTemporaryBasal( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt index 77276096db..cf9158d3b2 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt @@ -5,7 +5,7 @@ import info.nightscout.sdk.localmodel.entry.NsUnits data class NSTemporaryTarget( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt index 1fe671107c..a893fb447d 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt @@ -6,7 +6,7 @@ import info.nightscout.sdk.localmodel.entry.NsUnits data class NSTherapyEvent( override val date: Long, override val device: String?, - override val identifier: String, + override val identifier: String?, override val units: NsUnits?, override val srvModified: Long?, override val srvCreated: Long?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt index 04a10c17eb..55bb153732 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt @@ -5,7 +5,7 @@ import info.nightscout.sdk.localmodel.entry.NsUnits interface NSTreatment { val date: Long val device: String? - val identifier: String + val identifier: String? val units: NsUnits? val eventType: EventType val srvModified: Long? diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt index d73f0098fc..5f29c0f96b 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt @@ -17,7 +17,7 @@ import org.json.JSONObject * * */ internal data class RemoteTreatment( - @SerializedName("identifier") val identifier: String, // string Main addressing, required field that identifies document in the collection. The client should not create the identifier, the server automatically assigns it when the document is inserted. + @SerializedName("identifier") val identifier: String?, // string Main addressing, required field that identifies document in the collection. The client should not create the identifier, the server automatically assigns it when the document is inserted. @SerializedName("date") val date: Long? = null, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix epoch in milliseconds (1525383610088), Unix epoch in seconds (1525383610), ISO 8601 with optional timezone ('2018-05-03T21:40:10.088Z' or '2018-05-03T23:40:10.088+02:00') @SerializedName("mills") val mills: Long? = null, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix @SerializedName("timestamp") val timestamp: Long? = null, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix epoch in milliseconds (1525383610088), Unix epoch in seconds (1525383610), ISO 8601 with optional timezone ('2018-05-03T21:40:10.088Z' or '2018-05-03T23:40:10.088+02:00') diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdBolusCalculatorResultTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdBolusCalculatorResultTransaction.kt index 99c9329a9c..d0796b6c70 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdBolusCalculatorResultTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdBolusCalculatorResultTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.BolusCalculatorResult -class UpdateNsIdBolusCalculatorResultTransaction(val bolusCalculatorResult: BolusCalculatorResult) : Transaction() { +class UpdateNsIdBolusCalculatorResultTransaction(private val bolusCalculatorResults: List) : Transaction() { - override fun run() { - val current = database.bolusCalculatorResultDao.findById(bolusCalculatorResult.id) - if (current != null && current.interfaceIDs.nightscoutId != bolusCalculatorResult.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = bolusCalculatorResult.interfaceIDs.nightscoutId - database.bolusCalculatorResultDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (bolusCalculatorResult in bolusCalculatorResults) { + val current = database.bolusCalculatorResultDao.findById(bolusCalculatorResult.id) + if (current != null && current.interfaceIDs.nightscoutId != bolusCalculatorResult.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = bolusCalculatorResult.interfaceIDs.nightscoutId + database.bolusCalculatorResultDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdBolusTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdBolusTransaction.kt index 1075094e0b..b75b15f303 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdBolusTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdBolusTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.Bolus -class UpdateNsIdBolusTransaction(val bolus: Bolus) : Transaction() { +class UpdateNsIdBolusTransaction(private val boluses: List) : Transaction() { - override fun run() { - val current = database.bolusDao.findById(bolus.id) - if (current != null && current.interfaceIDs.nightscoutId != bolus.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = bolus.interfaceIDs.nightscoutId - database.bolusDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (bolus in boluses) { + val current = database.bolusDao.findById(bolus.id) + if (current != null && current.interfaceIDs.nightscoutId != bolus.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = bolus.interfaceIDs.nightscoutId + database.bolusDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdCarbsTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdCarbsTransaction.kt index 2c6ae614e3..15b376ef47 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdCarbsTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdCarbsTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.Carbs -class UpdateNsIdCarbsTransaction(val carbs: Carbs) : Transaction() { +class UpdateNsIdCarbsTransaction(private val carbs: List) : Transaction() { - override fun run() { - val current = database.carbsDao.findById(carbs.id) - if (current != null && current.interfaceIDs.nightscoutId != carbs.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = carbs.interfaceIDs.nightscoutId - database.carbsDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (carb in carbs) { + val current = database.carbsDao.findById(carb.id) + if (current != null && current.interfaceIDs.nightscoutId != carb.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = carb.interfaceIDs.nightscoutId + database.carbsDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdDeviceStatusTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdDeviceStatusTransaction.kt index fc582722a3..5b63815049 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdDeviceStatusTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdDeviceStatusTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.DeviceStatus -class UpdateNsIdDeviceStatusTransaction(val deviceStatus: DeviceStatus) : Transaction() { +class UpdateNsIdDeviceStatusTransaction(private val deviceStatuses: List) : Transaction() { - override fun run() { - val current = database.deviceStatusDao.findById(deviceStatus.id) - if (current != null && current.interfaceIDs.nightscoutId != deviceStatus.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = deviceStatus.interfaceIDs.nightscoutId - database.deviceStatusDao.update(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (deviceStatus in deviceStatuses) { + val current = database.deviceStatusDao.findById(deviceStatus.id) + if (current != null && current.interfaceIDs.nightscoutId != deviceStatus.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = deviceStatus.interfaceIDs.nightscoutId + database.deviceStatusDao.update(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdEffectiveProfileSwitchTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdEffectiveProfileSwitchTransaction.kt index d76205f75b..89cb509d40 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdEffectiveProfileSwitchTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdEffectiveProfileSwitchTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.EffectiveProfileSwitch -class UpdateNsIdEffectiveProfileSwitchTransaction(val effectiveProfileSwitch: EffectiveProfileSwitch) : Transaction() { +class UpdateNsIdEffectiveProfileSwitchTransaction(private val effectiveProfileSwitches: List) : Transaction() { - override fun run() { - val current = database.effectiveProfileSwitchDao.findById(effectiveProfileSwitch.id) - if (current != null && current.interfaceIDs.nightscoutId != effectiveProfileSwitch.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = effectiveProfileSwitch.interfaceIDs.nightscoutId - database.effectiveProfileSwitchDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (effectiveProfileSwitch in effectiveProfileSwitches) { + val current = database.effectiveProfileSwitchDao.findById(effectiveProfileSwitch.id) + if (current != null && current.interfaceIDs.nightscoutId != effectiveProfileSwitch.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = effectiveProfileSwitch.interfaceIDs.nightscoutId + database.effectiveProfileSwitchDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdExtendedBolusTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdExtendedBolusTransaction.kt index 6d070a6516..43beaebd3d 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdExtendedBolusTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdExtendedBolusTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.ExtendedBolus -class UpdateNsIdExtendedBolusTransaction(val bolus: ExtendedBolus) : Transaction() { +class UpdateNsIdExtendedBolusTransaction(val boluses: List) : Transaction() { - override fun run() { - val current = database.extendedBolusDao.findById(bolus.id) - if (current != null && current.interfaceIDs.nightscoutId != bolus.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = bolus.interfaceIDs.nightscoutId - database.extendedBolusDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (bolus in boluses) { + val current = database.extendedBolusDao.findById(bolus.id) + if (current != null && current.interfaceIDs.nightscoutId != bolus.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = bolus.interfaceIDs.nightscoutId + database.extendedBolusDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdFoodTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdFoodTransaction.kt index f35b5a3efe..228d8665ff 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdFoodTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdFoodTransaction.kt @@ -2,13 +2,24 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.Food -class UpdateNsIdFoodTransaction(val food: Food) : Transaction() { +class UpdateNsIdFoodTransaction(private val foods: List) : Transaction() { - override fun run() { - val current = database.foodDao.findById(food.id) - if (current != null && current.interfaceIDs.nightscoutId != food.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = food.interfaceIDs.nightscoutId - database.foodDao.updateExistingEntry(current) + val result = TransactionResult() + + override fun run(): TransactionResult { + for (food in foods) { + val current = database.foodDao.findById(food.id) + if (current != null && current.interfaceIDs.nightscoutId != food.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = food.interfaceIDs.nightscoutId + database.foodDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdGlucoseValueTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdGlucoseValueTransaction.kt index eb047a377b..073b7f2fcf 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdGlucoseValueTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdGlucoseValueTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.GlucoseValue -class UpdateNsIdGlucoseValueTransaction(val glucoseValue: GlucoseValue) : Transaction() { +class UpdateNsIdGlucoseValueTransaction(private val glucoseValues: List) : Transaction() { - override fun run() { - val current = database.glucoseValueDao.findById(glucoseValue.id) - if (current != null && current.interfaceIDs.nightscoutId != glucoseValue.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = glucoseValue.interfaceIDs.nightscoutId - database.glucoseValueDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (glucoseValue in glucoseValues) { + val current = database.glucoseValueDao.findById(glucoseValue.id) + if (current != null && current.interfaceIDs.nightscoutId != glucoseValue.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = glucoseValue.interfaceIDs.nightscoutId + database.glucoseValueDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdOfflineEventTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdOfflineEventTransaction.kt index 48f8676d44..b568b5b3f9 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdOfflineEventTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdOfflineEventTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.OfflineEvent -class UpdateNsIdOfflineEventTransaction(val offlineEvent: OfflineEvent) : Transaction() { +class UpdateNsIdOfflineEventTransaction(private val offlineEvents: List) : Transaction() { - override fun run() { - val current = database.offlineEventDao.findById(offlineEvent.id) - if (current != null && current.interfaceIDs.nightscoutId != offlineEvent.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = offlineEvent.interfaceIDs.nightscoutId - database.offlineEventDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (offlineEvent in offlineEvents) { + val current = database.offlineEventDao.findById(offlineEvent.id) + if (current != null && current.interfaceIDs.nightscoutId != offlineEvent.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = offlineEvent.interfaceIDs.nightscoutId + database.offlineEventDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdProfileSwitchTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdProfileSwitchTransaction.kt index b8886ed610..d15421d316 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdProfileSwitchTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdProfileSwitchTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.ProfileSwitch -class UpdateNsIdProfileSwitchTransaction(val profileSwitch: ProfileSwitch) : Transaction() { +class UpdateNsIdProfileSwitchTransaction(val profileSwitches: List) : Transaction() { - override fun run() { - val current = database.profileSwitchDao.findById(profileSwitch.id) - if (current != null && current.interfaceIDs.nightscoutId != profileSwitch.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = profileSwitch.interfaceIDs.nightscoutId - database.profileSwitchDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (profileSwitch in profileSwitches) { + val current = database.profileSwitchDao.findById(profileSwitch.id) + if (current != null && current.interfaceIDs.nightscoutId != profileSwitch.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = profileSwitch.interfaceIDs.nightscoutId + database.profileSwitchDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTemporaryBasalTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTemporaryBasalTransaction.kt index 1daa83442f..667daae619 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTemporaryBasalTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTemporaryBasalTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.TemporaryBasal -class UpdateNsIdTemporaryBasalTransaction(val temporaryBasal: TemporaryBasal) : Transaction() { +class UpdateNsIdTemporaryBasalTransaction(private val temporaryBasals: List) : Transaction() { - override fun run() { - val current = database.temporaryBasalDao.findById(temporaryBasal.id) - if (current != null && current.interfaceIDs.nightscoutId != temporaryBasal.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = temporaryBasal.interfaceIDs.nightscoutId - database.temporaryBasalDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (temporaryBasal in temporaryBasals) { + val current = database.temporaryBasalDao.findById(temporaryBasal.id) + if (current != null && current.interfaceIDs.nightscoutId != temporaryBasal.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = temporaryBasal.interfaceIDs.nightscoutId + database.temporaryBasalDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTemporaryTargetTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTemporaryTargetTransaction.kt index 0b4a369708..f629302486 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTemporaryTargetTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTemporaryTargetTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.TemporaryTarget -class UpdateNsIdTemporaryTargetTransaction(val temporaryTarget: TemporaryTarget) : Transaction() { +class UpdateNsIdTemporaryTargetTransaction(private val temporaryTargets: List) : Transaction() { - override fun run() { - val current = database.temporaryTargetDao.findById(temporaryTarget.id) - if (current != null && current.interfaceIDs.nightscoutId != temporaryTarget.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = temporaryTarget.interfaceIDs.nightscoutId - database.temporaryTargetDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (temporaryTarget in temporaryTargets) { + val current = database.temporaryTargetDao.findById(temporaryTarget.id) + if (current != null && current.interfaceIDs.nightscoutId != temporaryTarget.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = temporaryTarget.interfaceIDs.nightscoutId + database.temporaryTargetDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTherapyEventTransaction.kt b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTherapyEventTransaction.kt index e310f1c1d3..d82086e9b1 100644 --- a/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTherapyEventTransaction.kt +++ b/database/impl/src/main/java/info/nightscout/database/impl/transactions/UpdateNsIdTherapyEventTransaction.kt @@ -2,13 +2,23 @@ package info.nightscout.database.impl.transactions import info.nightscout.database.entities.TherapyEvent -class UpdateNsIdTherapyEventTransaction(val therapyEvent: TherapyEvent) : Transaction() { +class UpdateNsIdTherapyEventTransaction(val therapyEvents: List) : Transaction() { - override fun run() { - val current = database.therapyEventDao.findById(therapyEvent.id) - if (current != null && current.interfaceIDs.nightscoutId != therapyEvent.interfaceIDs.nightscoutId) { - current.interfaceIDs.nightscoutId = therapyEvent.interfaceIDs.nightscoutId - database.therapyEventDao.updateExistingEntry(current) + val result = TransactionResult() + override fun run(): TransactionResult { + for (therapyEvent in therapyEvents) { + val current = database.therapyEventDao.findById(therapyEvent.id) + if (current != null && current.interfaceIDs.nightscoutId != therapyEvent.interfaceIDs.nightscoutId) { + current.interfaceIDs.nightscoutId = therapyEvent.interfaceIDs.nightscoutId + database.therapyEventDao.updateExistingEntry(current) + result.updatedNsId.add(current) + } } + return result + } + + class TransactionResult { + + val updatedNsId = mutableListOf() } } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt index 15cfa0b514..49d666c0c6 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt @@ -7,8 +7,10 @@ import info.nightscout.core.utils.worker.LoggingWorker import info.nightscout.database.entities.Bolus import info.nightscout.database.entities.BolusCalculatorResult import info.nightscout.database.entities.Carbs +import info.nightscout.database.entities.DeviceStatus import info.nightscout.database.entities.EffectiveProfileSwitch import info.nightscout.database.entities.ExtendedBolus +import info.nightscout.database.entities.Food import info.nightscout.database.entities.GlucoseValue import info.nightscout.database.entities.OfflineEvent import info.nightscout.database.entities.ProfileSwitch @@ -29,6 +31,19 @@ import info.nightscout.database.impl.transactions.SyncNsProfileSwitchTransaction import info.nightscout.database.impl.transactions.SyncNsTemporaryBasalTransaction import info.nightscout.database.impl.transactions.SyncNsTemporaryTargetTransaction import info.nightscout.database.impl.transactions.SyncNsTherapyEventTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdBolusCalculatorResultTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdBolusTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdCarbsTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdDeviceStatusTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdEffectiveProfileSwitchTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdExtendedBolusTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdFoodTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdGlucoseValueTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdOfflineEventTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdProfileSwitchTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdTemporaryBasalTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdTemporaryTargetTransaction +import info.nightscout.database.impl.transactions.UpdateNsIdTherapyEventTransaction import info.nightscout.database.transactions.TransactionGlucoseValue import info.nightscout.interfaces.Config import info.nightscout.interfaces.Constants @@ -55,6 +70,8 @@ import info.nightscout.sdk.localmodel.treatment.NSTemporaryTarget import info.nightscout.sdk.localmodel.treatment.NSTherapyEvent import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil +import java.util.concurrent.Executors +import java.util.concurrent.ScheduledFuture import java.util.concurrent.TimeUnit import javax.inject.Inject import javax.inject.Singleton @@ -75,17 +92,30 @@ class StoreDataForDbImpl @Inject constructor( ) : StoreDataForDb { override val glucoseValues: MutableList = mutableListOf() + override val boluses: MutableList = mutableListOf() + override val carbs: MutableList = mutableListOf() + override val temporaryTargets: MutableList = mutableListOf() + override val effectiveProfileSwitches: MutableList = mutableListOf() + override val bolusCalculatorResults: MutableList = mutableListOf() + override val therapyEvents: MutableList = mutableListOf() + override val extendedBoluses: MutableList = mutableListOf() + override val temporaryBasals: MutableList = mutableListOf() + override val profileSwitches: MutableList = mutableListOf() + override val offlineEvents: MutableList = mutableListOf() - val boluses: MutableList = mutableListOf() - val carbs: MutableList = mutableListOf() - val temporaryTargets: MutableList = mutableListOf() - val effectiveProfileSwitches: MutableList = mutableListOf() - val bolusCalculatorResults: MutableList = mutableListOf() - val therapyEvents: MutableList = mutableListOf() - val extendedBoluses: MutableList = mutableListOf() - val temporaryBasals: MutableList = mutableListOf() - val profileSwitches: MutableList = mutableListOf() - val offlineEvents: MutableList = mutableListOf() + override val nsIdGlucoseValues: MutableList = mutableListOf() + override val nsIdBoluses: MutableList = mutableListOf() + override val nsIdCarbs: MutableList = mutableListOf() + override val nsIdFoods: MutableList = mutableListOf() + override val nsIdTemporaryTargets: MutableList = mutableListOf() + override val nsIdEffectiveProfileSwitches: MutableList = mutableListOf() + override val nsIdBolusCalculatorResults: MutableList = mutableListOf() + override val nsIdTherapyEvents: MutableList = mutableListOf() + override val nsIdExtendedBoluses: MutableList = mutableListOf() + override val nsIdTemporaryBasals: MutableList = mutableListOf() + override val nsIdProfileSwitches: MutableList = mutableListOf() + override val nsIdOfflineEvents: MutableList = mutableListOf() + override val nsIdDeviceStatuses: MutableList = mutableListOf() private val userEntries: MutableList = mutableListOf() @@ -103,7 +133,7 @@ class StoreDataForDbImpl @Inject constructor( params: WorkerParameters ) : LoggingWorker(context, params) { - @Inject lateinit var storeDataForDb: StoreDataForDbImpl + @Inject lateinit var storeDataForDb: StoreDataForDb override fun doWorkAndLog(): Result { storeDataForDb.storeGlucoseValuesToDb() @@ -115,7 +145,7 @@ class StoreDataForDbImpl @Inject constructor( if (containsKey(key)) merge(key, 1, Long::plus) else put(key, 1) - private fun storeGlucoseValuesToDb() { + override fun storeGlucoseValuesToDb() { rxBus.send(EventNSClientNewLog("PROCESSING BG", "")) if (glucoseValues.isNotEmpty()) @@ -151,7 +181,7 @@ class StoreDataForDbImpl @Inject constructor( rxBus.send(EventNSClientNewLog("DONE BG", "")) } - fun storeTreatmentsToDb() { + override fun storeTreatmentsToDb() { rxBus.send(EventNSClientNewLog("PROCESSING TR", "")) if (boluses.isNotEmpty()) @@ -731,6 +761,168 @@ class StoreDataForDbImpl @Inject constructor( rxBus.send(EventNSClientNewLog("DONE TR", "")) } + private val eventWorker = Executors.newSingleThreadScheduledExecutor() + private var scheduledEventPost: ScheduledFuture<*>? = null + override fun scheduleNsIdUpdate() { + class PostRunnable : Runnable { + + override fun run() { + aapsLogger.debug(LTag.CORE, "Firing updateNsIds") + scheduledEventPost = null + updateNsIds() + } + } + // cancel waiting task to prevent sending multiple posts + scheduledEventPost?.cancel(false) + val task: Runnable = PostRunnable() + scheduledEventPost = eventWorker.schedule(task, 30, TimeUnit.SECONDS) + } + + private fun updateNsIds() { + repository.runTransactionForResult(UpdateNsIdTemporaryTargetTransaction(nsIdTemporaryTargets)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of TemporaryTarget failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of TemporaryTarget $it") + } + } + + repository.runTransactionForResult(UpdateNsIdGlucoseValueTransaction(nsIdGlucoseValues)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of GlucoseValue failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of GlucoseValue $it") + } + } + + repository.runTransactionForResult(UpdateNsIdFoodTransaction(nsIdFoods)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of Food failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of Food $it") + } + } + + repository.runTransactionForResult(UpdateNsIdTherapyEventTransaction(nsIdTherapyEvents)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of TherapyEvent failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of TherapyEvent $it") + } + } + + repository.runTransactionForResult(UpdateNsIdBolusTransaction(nsIdBoluses)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of Bolus failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of Bolus $it") + } + } + + repository.runTransactionForResult(UpdateNsIdCarbsTransaction(nsIdCarbs)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of Carbs failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of Carbs $it") + } + } + + repository.runTransactionForResult(UpdateNsIdBolusCalculatorResultTransaction(nsIdBolusCalculatorResults)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of BolusCalculatorResult failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of BolusCalculatorResult $it") + } + } + + repository.runTransactionForResult(UpdateNsIdTemporaryBasalTransaction(nsIdTemporaryBasals)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of TemporaryBasal failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of TemporaryBasal $it") + } + } + + repository.runTransactionForResult(UpdateNsIdExtendedBolusTransaction(nsIdExtendedBoluses)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of ExtendedBolus failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of ExtendedBolus $it") + } + } + + repository.runTransactionForResult(UpdateNsIdProfileSwitchTransaction(nsIdProfileSwitches)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of ProfileSwitch failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of ProfileSwitch $it") + } + } + + repository.runTransactionForResult(UpdateNsIdEffectiveProfileSwitchTransaction(nsIdEffectiveProfileSwitches)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of EffectiveProfileSwitch failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of EffectiveProfileSwitch $it") + } + } + + repository.runTransactionForResult(UpdateNsIdDeviceStatusTransaction(nsIdDeviceStatuses)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of DeviceStatus failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of DeviceStatus $it") + } + } + + repository.runTransactionForResult(UpdateNsIdOfflineEventTransaction(nsIdOfflineEvents)) + .doOnError { error -> + aapsLogger.error(LTag.DATABASE, "Updated nsId of OfflineEvent failed", error) + } + .blockingGet() + .also { result -> + result.updatedNsId.forEach { + aapsLogger.debug(LTag.DATABASE, "Updated nsId of OfflineEvent $it") + } + } + } + private fun sendLog(item: String, clazz: String) { inserted[clazz]?.let { rxBus.send(EventNSClientNewLog("INSERT", "$item $it")) diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt index 6b290067c8..d83541dfa8 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt @@ -1,19 +1,6 @@ package info.nightscout.plugins.sync.nsclient import info.nightscout.database.ValueWrapper -import info.nightscout.database.entities.Bolus -import info.nightscout.database.entities.BolusCalculatorResult -import info.nightscout.database.entities.Carbs -import info.nightscout.database.entities.DeviceStatus -import info.nightscout.database.entities.EffectiveProfileSwitch -import info.nightscout.database.entities.ExtendedBolus -import info.nightscout.database.entities.Food -import info.nightscout.database.entities.GlucoseValue -import info.nightscout.database.entities.OfflineEvent -import info.nightscout.database.entities.ProfileSwitch -import info.nightscout.database.entities.TemporaryBasal -import info.nightscout.database.entities.TemporaryTarget -import info.nightscout.database.entities.TherapyEvent import info.nightscout.database.impl.AppRepository import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.profile.ProfileFunction @@ -118,17 +105,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedBoluses(): List { - val startId = sp.getLong(R.string.key_ns_bolus_last_synced_id, 0) - return appRepository.getModifiedBolusesDataFromId(startId) - .blockingGet() - .filter { it.type != Bolus.Type.PRIMING } - .also { - aapsLogger.debug(LTag.NSCLIENT, "Loading Bolus data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedBolusesCompat() { val lastDbIdWrapped = appRepository.getLastBolusIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -139,18 +115,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.bolusesRemaining = lastDbId - startId appRepository.getNextSyncElementBolus(startId).blockingGet()?.let { bolus -> - aapsLogger.info(LTag.NSCLIENT, "Loading Bolus data Start: $startId ID: ${bolus.first.id} HistoryID: ${bolus.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Loading Bolus data Start: $startId ${bolus.first} forID: ${bolus.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore bolus.first.id == bolus.second.id && bolus.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring Bolus. Loaded from NS: ${bolus.first.id} HistoryID: ${bolus.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring Bolus. Loaded from NS: ${bolus.second.id} ") confirmLastBolusIdIfGreater(bolus.second.id) processChangedBolusesCompat() return } // only NsId changed, no need to upload bolus.first.onlyNsIdAdded(bolus.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring Bolus. Only NS id changed ID: ${bolus.first.id} HistoryID: ${bolus.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring Bolus. Only NS id changed: ${bolus.second.id} ") confirmLastBolusIdIfGreater(bolus.second.id) processChangedBolusesCompat() return @@ -181,14 +157,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedCarbs(): List { - val startId = sp.getLong(R.string.key_ns_carbs_last_synced_id, 0) - return appRepository.getModifiedCarbsDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading Carbs data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedCarbsCompat() { val lastDbIdWrapped = appRepository.getLastCarbsIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -199,18 +167,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.carbsRemaining = lastDbId - startId appRepository.getNextSyncElementCarbs(startId).blockingGet()?.let { carb -> - aapsLogger.info(LTag.NSCLIENT, "Loading Carbs data Start: $startId ID: ${carb.first.id} HistoryID: ${carb.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Loading Carbs data Start: $startId ${carb.first} forID: ${carb.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore carb.first.id == carb.second.id && carb.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring Carbs. Loaded from NS: ${carb.first.id} HistoryID: ${carb.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring Carbs. Loaded from NS: ${carb.second.id} ") confirmLastCarbsIdIfGreater(carb.second.id) processChangedCarbsCompat() return } // only NsId changed, no need to upload carb.first.onlyNsIdAdded(carb.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring Carbs. Only NS id changed ID: ${carb.first.id} HistoryID: ${carb.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring Carbs. Only NS id changed ID: ${carb.second.id} ") confirmLastCarbsIdIfGreater(carb.second.id) processChangedCarbsCompat() return @@ -237,14 +205,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedBolusCalculatorResults(): List { - val startId = sp.getLong(R.string.key_ns_bolus_calculator_result_last_synced_id, 0) - return appRepository.getModifiedBolusCalculatorResultsDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading BolusCalculatorResult data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedBolusCalculatorResultsCompat() { val lastDbIdWrapped = appRepository.getLastBolusCalculatorResultIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -255,18 +215,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.bcrRemaining = lastDbId - startId appRepository.getNextSyncElementBolusCalculatorResult(startId).blockingGet()?.let { bolusCalculatorResult -> - aapsLogger.info(LTag.NSCLIENT, "Loading BolusCalculatorResult data Start: $startId ID: ${bolusCalculatorResult.first.id} HistoryID: ${bolusCalculatorResult.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Loading BolusCalculatorResult data Start: $startId ${bolusCalculatorResult.first} forID: ${bolusCalculatorResult.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore bolusCalculatorResult.first.id == bolusCalculatorResult.second.id && bolusCalculatorResult.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring BolusCalculatorResult. Loaded from NS: ${bolusCalculatorResult.first.id} HistoryID: ${bolusCalculatorResult.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring BolusCalculatorResult. Loaded from NS: ${bolusCalculatorResult.second.id} ") confirmLastBolusCalculatorResultsIdIfGreater(bolusCalculatorResult.second.id) processChangedBolusCalculatorResultsCompat() return } // only NsId changed, no need to upload bolusCalculatorResult.first.onlyNsIdAdded(bolusCalculatorResult.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring BolusCalculatorResult. Only NS id changed ID: ${bolusCalculatorResult.first.id} HistoryID: ${bolusCalculatorResult.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring BolusCalculatorResult. Only NS id changed ID: ${bolusCalculatorResult.second.id} ") confirmLastBolusCalculatorResultsIdIfGreater(bolusCalculatorResult.second.id) processChangedBolusCalculatorResultsCompat() return @@ -296,14 +256,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedTempTargets(): List { - val startId = sp.getLong(R.string.key_ns_temporary_target_last_synced_id, 0) - return appRepository.getModifiedTemporaryTargetsDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading TemporaryTarget data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedTempTargetsCompat() { val lastDbIdWrapped = appRepository.getLastTempTargetIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -314,18 +266,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.ttsRemaining = lastDbId - startId appRepository.getNextSyncElementTemporaryTarget(startId).blockingGet()?.let { tt -> - aapsLogger.info(LTag.NSCLIENT, "Loading TemporaryTarget data Start: $startId ID: ${tt.first.id} HistoryID: ${tt.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Loading TemporaryTarget data Start: $startId ${tt.first} forID: ${tt.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore tt.first.id == tt.second.id && tt.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryTarget. Loaded from NS: ${tt.first.id} HistoryID: ${tt.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryTarget. Loaded from NS: ${tt.second.id} ") confirmLastTempTargetsIdIfGreater(tt.second.id) processChangedTempTargetsCompat() return } // only NsId changed, no need to upload tt.first.onlyNsIdAdded(tt.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryTarget. Only NS id changed ID: ${tt.first.id} HistoryID: ${tt.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryTarget. Only NS id changed ID: ${tt.second.id} ") confirmLastTempTargetsIdIfGreater(tt.second.id) processChangedTempTargetsCompat() return @@ -356,14 +308,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedFoods(): List { - val startId = sp.getLong(R.string.key_ns_food_last_synced_id, 0) - return appRepository.getModifiedFoodDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading Food data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedFoodsCompat() { val lastDbIdWrapped = appRepository.getLastFoodIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -374,18 +318,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.foodsRemaining = lastDbId - startId appRepository.getNextSyncElementFood(startId).blockingGet()?.let { food -> - aapsLogger.info(LTag.NSCLIENT, "Loading Food data Start: $startId ID: ${food.first.id} HistoryID: ${food.second} ") + aapsLogger.info(LTag.NSCLIENT, "Loading Food data Start: $startId ${food.first} forID: ${food.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore food.first.id == food.second.id && food.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring Food. Loaded from NS: ${food.first.id} HistoryID: ${food.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring Food. Loaded from NS: ${food.second.id} ") confirmLastFoodIdIfGreater(food.second.id) processChangedFoodsCompat() return } // only NsId changed, no need to upload food.first.onlyNsIdAdded(food.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring Food. Only NS id changed ID: ${food.first.id} HistoryID: ${food.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring Food. Only NS id changed ID: ${food.second.id} ") confirmLastFoodIdIfGreater(food.second.id) processChangedFoodsCompat() return @@ -412,14 +356,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedGlucoseValues(): List { - val startId = sp.getLong(R.string.key_ns_glucose_value_last_synced_id, 0) - return appRepository.getModifiedBgReadingsDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading GlucoseValue data for sync from $startId . Records ${it.size}") - } - } - override tailrec fun processChangedGlucoseValuesCompat() { val lastDbIdWrapped = appRepository.getLastGlucoseValueIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -430,19 +366,19 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.gvsRemaining = lastDbId - startId appRepository.getNextSyncElementGlucoseValue(startId).blockingGet()?.let { gv -> - aapsLogger.info(LTag.NSCLIENT, "Loading GlucoseValue data ID: ${gv.first.id} HistoryID: ${gv.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Loading GlucoseValue data Start: $startId ${gv.first} forID: ${gv.second.id} ") if (activePlugin.activeBgSource.shouldUploadToNs(gv.first)) { when { // new record with existing NS id => must be coming from NS => ignore gv.first.id == gv.second.id && gv.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring GlucoseValue. Loaded from NS: ${gv.first.id} HistoryID: ${gv.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring GlucoseValue. Loaded from NS: ${gv.second.id} ") confirmLastGlucoseValueIdIfGreater(gv.second.id) processChangedGlucoseValuesCompat() return } // only NsId changed, no need to upload gv.first.onlyNsIdAdded(gv.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring GlucoseValue. Only NS id changed ID: ${gv.first.id} HistoryID: ${gv.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring GlucoseValue. Only NS id changed ID: ${gv.second.id} ") confirmLastGlucoseValueIdIfGreater(gv.second.id) processChangedGlucoseValuesCompat() return @@ -473,14 +409,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedTherapyEvents(): List { - val startId = sp.getLong(R.string.key_ns_therapy_event_last_synced_id, 0) - return appRepository.getModifiedTherapyEventDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading TherapyEvents data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedTherapyEventsCompat() { val lastDbIdWrapped = appRepository.getLastTherapyEventIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -491,18 +419,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.tesRemaining = lastDbId - startId appRepository.getNextSyncElementTherapyEvent(startId).blockingGet()?.let { te -> - aapsLogger.info(LTag.NSCLIENT, "Loading TherapyEvents data Start: $startId ID: ${te.first.id} HistoryID: ${te.second} ") + aapsLogger.info(LTag.NSCLIENT, "Loading TherapyEvents data Start: $startId ${te.first} forID: ${te.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore te.first.id == te.second.id && te.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TherapyEvent. Loaded from NS: ${te.first.id} HistoryID: ${te.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring TherapyEvent. Loaded from NS: ${te.second.id} ") confirmLastTherapyEventIdIfGreater(te.second.id) processChangedTherapyEventsCompat() return } // only NsId changed, no need to upload te.first.onlyNsIdAdded(te.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TherapyEvent. Only NS id changed ID: ${te.first.id} HistoryID: ${te.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring TherapyEvent. Only NS id changed ID: ${te.second.id} ") confirmLastTherapyEventIdIfGreater(te.second.id) processChangedTherapyEventsCompat() return @@ -529,13 +457,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - override fun changedDeviceStatuses(): List { - val startId = sp.getLong(R.string.key_ns_device_status_last_synced_id, 0) - return appRepository.getModifiedDeviceStatusDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading DeviceStatus data for sync from $startId. Records ${it.size}") - } - } - override fun processChangedDeviceStatusesCompat() { val lastDbIdWrapped = appRepository.getLastDeviceStatusIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -546,7 +467,7 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.dssRemaining = lastDbId - startId appRepository.getNextSyncElementDeviceStatus(startId).blockingGet()?.let { deviceStatus -> - aapsLogger.info(LTag.NSCLIENT, "Loading DeviceStatus data Start: $startId ID: ${deviceStatus.id}") + aapsLogger.info(LTag.NSCLIENT, "Loading DeviceStatus data Start: $startId $deviceStatus") when { // without nsId = create new deviceStatus.interfaceIDs.nightscoutId == null -> @@ -565,14 +486,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedTemporaryBasals(): List { - val startId = sp.getLong(R.string.key_ns_temporary_basal_last_synced_id, 0) - return appRepository.getModifiedTemporaryBasalDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading TemporaryBasal data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedTemporaryBasalsCompat() { val lastDbIdWrapped = appRepository.getLastTemporaryBasalIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -583,18 +496,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.tbrsRemaining = lastDbId - startId appRepository.getNextSyncElementTemporaryBasal(startId).blockingGet()?.let { tb -> - aapsLogger.info(LTag.NSCLIENT, "Loading TemporaryBasal data Start: $startId ID: ${tb.first.id} HistoryID: ${tb.second} ") + aapsLogger.info(LTag.NSCLIENT, "Loading TemporaryBasal data Start: $startId ${tb.first} forID: ${tb.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore tb.first.id == tb.second.id && tb.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. Loaded from NS: ${tb.first.id} HistoryID: ${tb.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. Loaded from NS: ${tb.second.id} ") confirmLastTemporaryBasalIdIfGreater(tb.second.id) processChangedTemporaryBasalsCompat() return } // only NsId changed, no need to upload tb.first.onlyNsIdAdded(tb.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. Only NS id changed ID: ${tb.first.id} HistoryID: ${tb.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring TemporaryBasal. Only NS id changed ID: ${tb.second.id} ") confirmLastTemporaryBasalIdIfGreater(tb.second.id) processChangedTemporaryBasalsCompat() return @@ -625,14 +538,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedExtendedBoluses(): List { - val startId = sp.getLong(R.string.key_ns_extended_bolus_last_synced_id, 0) - return appRepository.getModifiedExtendedBolusDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading ExtendedBolus data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedExtendedBolusesCompat() { val lastDbIdWrapped = appRepository.getLastExtendedBolusIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -643,20 +548,20 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.ebsRemaining = lastDbId - startId appRepository.getNextSyncElementExtendedBolus(startId).blockingGet()?.let { eb -> - aapsLogger.info(LTag.NSCLIENT, "Loading ExtendedBolus data Start: $startId ID: ${eb.first.id} HistoryID: ${eb.second} ") + aapsLogger.info(LTag.NSCLIENT, "Loading ExtendedBolus data Start: $startId ${eb.first} forID: ${eb.second.id} ") val profile = profileFunction.getProfile(eb.first.timestamp) if (profile != null) { when { // new record with existing NS id => must be coming from NS => ignore eb.first.id == eb.second.id && eb.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring ExtendedBolus. Loaded from NS: ${eb.first.id} HistoryID: ${eb.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring ExtendedBolus. Loaded from NS: ${eb.second.id} ") confirmLastExtendedBolusIdIfGreater(eb.second.id) processChangedExtendedBolusesCompat() return } // only NsId changed, no need to upload eb.first.onlyNsIdAdded(eb.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring ExtendedBolus. Only NS id changed ID: ${eb.first.id} HistoryID: ${eb.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring ExtendedBolus. Only NS id changed ID: ${eb.second.id} ") confirmLastExtendedBolusIdIfGreater(eb.second.id) processChangedExtendedBolusesCompat() return @@ -678,7 +583,7 @@ class DataSyncSelectorImplementation @Inject constructor( } return } else { - aapsLogger.info(LTag.NSCLIENT, "Ignoring ExtendedBolus. No profile: ${eb.first.id} HistoryID: ${eb.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring ExtendedBolus. No profile: ${eb.second.id} ") confirmLastExtendedBolusIdIfGreater(eb.second.id) processChangedExtendedBolusesCompat() return @@ -693,13 +598,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - override fun changedProfileSwitch(): List { - val startId = sp.getLong(R.string.key_ns_profile_switch_last_synced_id, 0) - return appRepository.getModifiedProfileSwitchDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading ProfileSwitch data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedProfileSwitchesCompat() { val lastDbIdWrapped = appRepository.getLastProfileSwitchIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -710,18 +608,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.pssRemaining = lastDbId - startId appRepository.getNextSyncElementProfileSwitch(startId).blockingGet()?.let { ps -> - aapsLogger.info(LTag.NSCLIENT, "Loading ProfileSwitch data Start: $startId ID: ${ps.first.id} HistoryID: ${ps.second} ") + aapsLogger.info(LTag.NSCLIENT, "Loading ProfileSwitch data Start: $startId ${ps.first} forID: ${ps.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore ps.first.id == ps.second.id && ps.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring ProfileSwitch. Loaded from NS: ${ps.first.id} HistoryID: ${ps.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring ProfileSwitch. Loaded from NS: ${ps.second.id} ") confirmLastProfileSwitchIdIfGreater(ps.second.id) processChangedProfileSwitchesCompat() return } // only NsId changed, no need to upload ps.first.onlyNsIdAdded(ps.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring ProfileSwitch. Only NS id changed ID: ${ps.first.id} HistoryID: ${ps.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring ProfileSwitch. Only NS id changed ID: ${ps.second.id} ") confirmLastProfileSwitchIdIfGreater(ps.second.id) processChangedProfileSwitchesCompat() return @@ -748,13 +646,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - override fun changedEffectiveProfileSwitch(): List { - val startId = sp.getLong(R.string.key_ns_effective_profile_switch_last_synced_id, 0) - return appRepository.getModifiedEffectiveProfileSwitchDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading EffectiveProfileSwitch data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedEffectiveProfileSwitchesCompat() { val lastDbIdWrapped = appRepository.getLastEffectiveProfileSwitchIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -765,18 +656,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.epssRemaining = lastDbId - startId appRepository.getNextSyncElementEffectiveProfileSwitch(startId).blockingGet()?.let { ps -> - aapsLogger.info(LTag.NSCLIENT, "Loading EffectiveProfileSwitch data Start: $startId ID: ${ps.first.id} HistoryID: ${ps.second} ") + aapsLogger.info(LTag.NSCLIENT, "Loading EffectiveProfileSwitch data Start: $startId ${ps.first} forID: ${ps.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore ps.first.id == ps.second.id && ps.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring EffectiveProfileSwitch. Loaded from NS: ${ps.first.id} HistoryID: ${ps.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring EffectiveProfileSwitch. Loaded from NS: ${ps.second.id} ") confirmLastEffectiveProfileSwitchIdIfGreater(ps.second.id) processChangedEffectiveProfileSwitchesCompat() return } // only NsId changed, no need to upload ps.first.onlyNsIdAdded(ps.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring EffectiveProfileSwitch. Only NS id changed ID: ${ps.first.id} HistoryID: ${ps.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring EffectiveProfileSwitch. Only NS id changed ID: ${ps.second.id} ") confirmLastEffectiveProfileSwitchIdIfGreater(ps.second.id) processChangedEffectiveProfileSwitchesCompat() return @@ -807,14 +698,6 @@ class DataSyncSelectorImplementation @Inject constructor( } } - // Prepared for v3 (returns all modified after) - override fun changedOfflineEvents(): List { - val startId = sp.getLong(R.string.key_ns_offline_event_last_synced_id, 0) - return appRepository.getModifiedOfflineEventsDataFromId(startId).blockingGet().also { - aapsLogger.debug(LTag.NSCLIENT, "Loading OfflineEvent data for sync from $startId. Records ${it.size}") - } - } - override tailrec fun processChangedOfflineEventsCompat() { val lastDbIdWrapped = appRepository.getLastOfflineEventIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L @@ -825,18 +708,18 @@ class DataSyncSelectorImplementation @Inject constructor( } queueCounter.oesRemaining = lastDbId - startId appRepository.getNextSyncElementOfflineEvent(startId).blockingGet()?.let { oe -> - aapsLogger.info(LTag.NSCLIENT, "Loading OfflineEvent data Start: $startId ID: ${oe.first.id} HistoryID: ${oe.second} ") + aapsLogger.info(LTag.NSCLIENT, "Loading OfflineEvent data Start: $startId ${oe.first} forID: ${oe.second.id} ") when { // new record with existing NS id => must be coming from NS => ignore oe.first.id == oe.second.id && oe.first.interfaceIDs.nightscoutId != null -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring OfflineEvent. Loaded from NS: ${oe.first.id} HistoryID: ${oe.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring OfflineEvent. Loaded from NS: ${oe.second.id} ") confirmLastOfflineEventIdIfGreater(oe.second.id) processChangedOfflineEventsCompat() return } // only NsId changed, no need to upload oe.first.onlyNsIdAdded(oe.second) -> { - aapsLogger.info(LTag.NSCLIENT, "Ignoring OfflineEvent. Only NS id changed ID: ${oe.first.id} HistoryID: ${oe.second.id} ") + aapsLogger.info(LTag.NSCLIENT, "Ignoring OfflineEvent. Only NS id changed ID: ${oe.second.id} ") confirmLastOfflineEventIdIfGreater(oe.second.id) processChangedOfflineEventsCompat() return diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt index 31bdf18474..67e6885aba 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/NSClientPlugin.kt @@ -242,60 +242,60 @@ class NSClientPlugin @Inject constructor( dataSyncSelector.resetToNextFullSync() } - override fun dbAdd(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) { - when (originalObject) { - is DataSyncSelector.PairBolus -> originalObject.value.toJson(true, dateUtil) - is DataSyncSelector.PairCarbs -> originalObject.value.toJson(true, dateUtil) - is DataSyncSelector.PairBolusCalculatorResult -> originalObject.value.toJson(true, dateUtil, profileFunction) - is DataSyncSelector.PairTemporaryTarget -> originalObject.value.toJson(true, profileFunction.getUnits(), dateUtil) - is DataSyncSelector.PairFood -> originalObject.value.toJson(true) - is DataSyncSelector.PairGlucoseValue -> originalObject.value.toJson(true, dateUtil) - is DataSyncSelector.PairTherapyEvent -> originalObject.value.toJson(true, dateUtil) - is DataSyncSelector.PairDeviceStatus -> originalObject.value.toJson(dateUtil) - is DataSyncSelector.PairTemporaryBasal -> originalObject.value.toJson(true, profileFunction.getProfile(originalObject.value.timestamp), dateUtil) - is DataSyncSelector.PairExtendedBolus -> originalObject.value.toJson(true, profileFunction.getProfile(originalObject.value.timestamp), dateUtil) - is DataSyncSelector.PairProfileSwitch -> originalObject.value.toJson(true, dateUtil) - is DataSyncSelector.PairEffectiveProfileSwitch -> originalObject.value.toJson(true, dateUtil) - is DataSyncSelector.PairOfflineEvent -> originalObject.value.toJson(true, dateUtil) - is DataSyncSelector.PairProfileStore -> originalObject.value + override fun dbAdd(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) { + when (dataPair) { + is DataSyncSelector.PairBolus -> dataPair.value.toJson(true, dateUtil) + is DataSyncSelector.PairCarbs -> dataPair.value.toJson(true, dateUtil) + is DataSyncSelector.PairBolusCalculatorResult -> dataPair.value.toJson(true, dateUtil, profileFunction) + is DataSyncSelector.PairTemporaryTarget -> dataPair.value.toJson(true, profileFunction.getUnits(), dateUtil) + is DataSyncSelector.PairFood -> dataPair.value.toJson(true) + is DataSyncSelector.PairGlucoseValue -> dataPair.value.toJson(true, dateUtil) + is DataSyncSelector.PairTherapyEvent -> dataPair.value.toJson(true, dateUtil) + is DataSyncSelector.PairDeviceStatus -> dataPair.value.toJson(dateUtil) + is DataSyncSelector.PairTemporaryBasal -> dataPair.value.toJson(true, profileFunction.getProfile(dataPair.value.timestamp), dateUtil) + is DataSyncSelector.PairExtendedBolus -> dataPair.value.toJson(true, profileFunction.getProfile(dataPair.value.timestamp), dateUtil) + is DataSyncSelector.PairProfileSwitch -> dataPair.value.toJson(true, dateUtil) + is DataSyncSelector.PairEffectiveProfileSwitch -> dataPair.value.toJson(true, dateUtil) + is DataSyncSelector.PairOfflineEvent -> dataPair.value.toJson(true, dateUtil) + is DataSyncSelector.PairProfileStore -> dataPair.value else -> null }?.let { data -> - nsClientService?.dbAdd(collection, data, originalObject, progress) + nsClientService?.dbAdd(collection, data, dataPair, progress) } } - override fun dbUpdate(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) { - val id = when (originalObject) { - is DataSyncSelector.PairBolus -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairCarbs -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairBolusCalculatorResult -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairTemporaryTarget -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairFood -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairGlucoseValue -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairTherapyEvent -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairTemporaryBasal -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairExtendedBolus -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairProfileSwitch -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairEffectiveProfileSwitch -> originalObject.value.interfaceIDs.nightscoutId - is DataSyncSelector.PairOfflineEvent -> originalObject.value.interfaceIDs.nightscoutId + override fun dbUpdate(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) { + val id = when (dataPair) { + is DataSyncSelector.PairBolus -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairCarbs -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairBolusCalculatorResult -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairTemporaryTarget -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairFood -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairGlucoseValue -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairTherapyEvent -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairTemporaryBasal -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairExtendedBolus -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairProfileSwitch -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairEffectiveProfileSwitch -> dataPair.value.interfaceIDs.nightscoutId + is DataSyncSelector.PairOfflineEvent -> dataPair.value.interfaceIDs.nightscoutId else -> throw IllegalStateException() } - when (originalObject) { - is DataSyncSelector.PairBolus -> originalObject.value.toJson(false, dateUtil) - is DataSyncSelector.PairCarbs -> originalObject.value.toJson(false, dateUtil) - is DataSyncSelector.PairBolusCalculatorResult -> originalObject.value.toJson(false, dateUtil, profileFunction) - is DataSyncSelector.PairTemporaryTarget -> originalObject.value.toJson(false, profileFunction.getUnits(), dateUtil) - is DataSyncSelector.PairFood -> originalObject.value.toJson(false) - is DataSyncSelector.PairGlucoseValue -> originalObject.value.toJson(false, dateUtil) - is DataSyncSelector.PairTherapyEvent -> originalObject.value.toJson(false, dateUtil) - is DataSyncSelector.PairTemporaryBasal -> originalObject.value.toJson(false, profileFunction.getProfile(originalObject.value.timestamp), dateUtil) - is DataSyncSelector.PairExtendedBolus -> originalObject.value.toJson(false, profileFunction.getProfile(originalObject.value.timestamp), dateUtil) - is DataSyncSelector.PairProfileSwitch -> originalObject.value.toJson(false, dateUtil) - is DataSyncSelector.PairEffectiveProfileSwitch -> originalObject.value.toJson(false, dateUtil) - is DataSyncSelector.PairOfflineEvent -> originalObject.value.toJson(false, dateUtil) + when (dataPair) { + is DataSyncSelector.PairBolus -> dataPair.value.toJson(false, dateUtil) + is DataSyncSelector.PairCarbs -> dataPair.value.toJson(false, dateUtil) + is DataSyncSelector.PairBolusCalculatorResult -> dataPair.value.toJson(false, dateUtil, profileFunction) + is DataSyncSelector.PairTemporaryTarget -> dataPair.value.toJson(false, profileFunction.getUnits(), dateUtil) + is DataSyncSelector.PairFood -> dataPair.value.toJson(false) + is DataSyncSelector.PairGlucoseValue -> dataPair.value.toJson(false, dateUtil) + is DataSyncSelector.PairTherapyEvent -> dataPair.value.toJson(false, dateUtil) + is DataSyncSelector.PairTemporaryBasal -> dataPair.value.toJson(false, profileFunction.getProfile(dataPair.value.timestamp), dateUtil) + is DataSyncSelector.PairExtendedBolus -> dataPair.value.toJson(false, profileFunction.getProfile(dataPair.value.timestamp), dateUtil) + is DataSyncSelector.PairProfileSwitch -> dataPair.value.toJson(false, dateUtil) + is DataSyncSelector.PairEffectiveProfileSwitch -> dataPair.value.toJson(false, dateUtil) + is DataSyncSelector.PairOfflineEvent -> dataPair.value.toJson(false, dateUtil) else -> null }?.let { data -> - nsClientService?.dbUpdate(collection, id, data, originalObject, progress) + nsClientService?.dbUpdate(collection, id, data, dataPair, progress) } } } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/acks/NSAddAck.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/acks/NSAddAck.kt index 0b68f3c8e9..7163a77321 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/acks/NSAddAck.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/acks/NSAddAck.kt @@ -1,10 +1,15 @@ package info.nightscout.plugins.sync.nsclient.acks +import androidx.work.OneTimeWorkRequest +import info.nightscout.core.utils.receivers.DataWorkerStorage +import info.nightscout.plugins.sync.nsclient.services.NSClientService +import info.nightscout.plugins.sync.nsclient.workers.NSClientAddAckWorker import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.Event import info.nightscout.rx.events.EventNSClientRestart import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag +import info.nightscout.shared.utils.DateUtil import io.socket.client.Ack import org.json.JSONArray import org.json.JSONObject @@ -12,11 +17,13 @@ import org.json.JSONObject class NSAddAck( private val aapsLogger: AAPSLogger, private val rxBus: RxBus, + private val nsClientService: NSClientService, + private val dateUtil: DateUtil, + private val dataWorkerStorage: DataWorkerStorage, val originalObject: Any? = null ) : Event(), Ack { var id: String? = null - private var nsClientID: String? = null var json: JSONObject? = null override fun call(vararg args: Any) { // Regular response @@ -27,11 +34,8 @@ class NSAddAck( response = responseArray.getJSONObject(0) id = response.getString("_id") json = response - if (response.has("NSCLIENT_ID")) { - nsClientID = response.getString("NSCLIENT_ID") - } } - rxBus.send(this) + processAddAck() return } catch (e: Exception) { aapsLogger.error("Unhandled exception", e) @@ -51,4 +55,13 @@ class NSAddAck( aapsLogger.error("Unhandled exception", e) } } + + private fun processAddAck() { + nsClientService.lastAckTime = dateUtil.now() + dataWorkerStorage.enqueue( + OneTimeWorkRequest.Builder(NSClientAddAckWorker::class.java) + .setInputData(dataWorkerStorage.storeInputData(this)) + .build() + ) + } } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/acks/NSUpdateAck.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/acks/NSUpdateAck.kt index fd07b22ce5..5abd391fa9 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/acks/NSUpdateAck.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/acks/NSUpdateAck.kt @@ -1,9 +1,14 @@ package info.nightscout.plugins.sync.nsclient.acks +import androidx.work.OneTimeWorkRequest +import info.nightscout.core.utils.receivers.DataWorkerStorage +import info.nightscout.plugins.sync.nsclient.services.NSClientService +import info.nightscout.plugins.sync.nsclient.workers.NSClientUpdateRemoveAckWorker import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.Event import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag +import info.nightscout.shared.utils.DateUtil import io.socket.client.Ack import org.json.JSONException import org.json.JSONObject @@ -16,6 +21,9 @@ class NSUpdateAck( var _id: String, private val aapsLogger: AAPSLogger, private val rxBus: RxBus, + private val nsClientService: NSClientService, + private val dateUtil: DateUtil, + private val dataWorkerStorage: DataWorkerStorage, val originalObject: Any? = null ) : Event(), Ack { @@ -29,9 +37,18 @@ class NSUpdateAck( result = true aapsLogger.debug(LTag.NSCLIENT, "Internal error: Missing _id returned on dbUpdate ack") } - rxBus.send(this) + processUpdateAck() } catch (e: JSONException) { aapsLogger.error("Unhandled exception", e) } } + + private fun processUpdateAck() { + nsClientService.lastAckTime = dateUtil.now() + dataWorkerStorage.enqueue( + OneTimeWorkRequest.Builder(NSClientUpdateRemoveAckWorker::class.java) + .setInputData(dataWorkerStorage.storeInputData(this)) + .build() + ) + } } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt index 6933b8bfee..4887884cbb 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt @@ -39,10 +39,8 @@ import info.nightscout.plugins.sync.nsclient.acks.NSAuthAck import info.nightscout.plugins.sync.nsclient.acks.NSUpdateAck import info.nightscout.plugins.sync.nsclient.data.AlarmAck import info.nightscout.plugins.sync.nsclient.data.NSDeviceStatusHandler -import info.nightscout.plugins.sync.nsclient.workers.NSClientAddAckWorker import info.nightscout.plugins.sync.nsclient.workers.NSClientAddUpdateWorker import info.nightscout.plugins.sync.nsclient.workers.NSClientMbgWorker -import info.nightscout.plugins.sync.nsclient.workers.NSClientUpdateRemoveAckWorker import info.nightscout.plugins.sync.nsclientV3.NSClientV3Plugin import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus @@ -110,7 +108,7 @@ class NSClientService : DaggerService() { private var nsAPISecret = "" private var nsDevice = "" private val nsHours = 48 - private var lastAckTime: Long = 0 + internal var lastAckTime: Long = 0 private var nsApiHashCode = "" private val reconnections = ArrayList() @@ -167,14 +165,6 @@ class NSClientService : DaggerService() { .toObservable(NSAuthAck::class.java) .observeOn(aapsSchedulers.io) .subscribe({ ack -> processAuthAck(ack) }, fabricPrivacy::logException) - disposable += rxBus - .toObservable(NSUpdateAck::class.java) - .observeOn(aapsSchedulers.io) - .subscribe({ ack -> processUpdateAck(ack) }, fabricPrivacy::logException) - disposable += rxBus - .toObservable(NSAddAck::class.java) - .observeOn(aapsSchedulers.io) - .subscribe({ ack -> processAddAck(ack) }, fabricPrivacy::logException) } override fun onDestroy() { @@ -183,24 +173,6 @@ class NSClientService : DaggerService() { if (wakeLock?.isHeld == true) wakeLock?.release() } - private fun processAddAck(ack: NSAddAck) { - lastAckTime = dateUtil.now() - dataWorkerStorage.enqueue( - OneTimeWorkRequest.Builder(NSClientAddAckWorker::class.java) - .setInputData(dataWorkerStorage.storeInputData(ack)) - .build() - ) - } - - private fun processUpdateAck(ack: NSUpdateAck) { - lastAckTime = dateUtil.now() - dataWorkerStorage.enqueue( - OneTimeWorkRequest.Builder(NSClientUpdateRemoveAckWorker::class.java) - .setInputData(dataWorkerStorage.storeInputData(ack)) - .build() - ) - } - private fun processAuthAck(ack: NSAuthAck) { var connectionStatus = "Authenticated (" if (ack.read) connectionStatus += "R" @@ -605,7 +577,7 @@ class NSClientService : DaggerService() { message.put("collection", collection) message.put("_id", _id) message.put("data", data) - socket?.emit("dbUpdate", message, NSUpdateAck("dbUpdate", _id, aapsLogger, rxBus, originalObject)) + socket?.emit("dbUpdate", message, NSUpdateAck("dbUpdate", _id, aapsLogger, rxBus, this, dateUtil, dataWorkerStorage, originalObject)) rxBus.send( EventNSClientNewLog( "DBUPDATE $collection", "Sent " + originalObject.javaClass.simpleName + " " + @@ -623,7 +595,7 @@ class NSClientService : DaggerService() { val message = JSONObject() message.put("collection", collection) message.put("data", data) - socket?.emit("dbAdd", message, NSAddAck(aapsLogger, rxBus, originalObject)) + socket?.emit("dbAdd", message, NSAddAck(aapsLogger, rxBus, this, dateUtil, dataWorkerStorage, originalObject)) rxBus.send(EventNSClientNewLog("DBADD $collection", "Sent " + originalObject.javaClass.simpleName + " " + data + " " + progress)) } catch (e: JSONException) { aapsLogger.error("Unhandled exception", e) diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt index 6ed89f0e81..3119fa5e74 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt @@ -7,19 +7,7 @@ import androidx.work.workDataOf import info.nightscout.core.utils.receivers.DataWorkerStorage import info.nightscout.core.utils.worker.LoggingWorker import info.nightscout.database.impl.AppRepository -import info.nightscout.database.impl.transactions.UpdateNsIdBolusCalculatorResultTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdBolusTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdCarbsTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdDeviceStatusTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdEffectiveProfileSwitchTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdExtendedBolusTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdFoodTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdGlucoseValueTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdOfflineEventTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdProfileSwitchTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdTemporaryBasalTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdTemporaryTargetTransaction -import info.nightscout.database.impl.transactions.UpdateNsIdTherapyEventTransaction +import info.nightscout.interfaces.nsclient.StoreDataForDb import info.nightscout.interfaces.sync.DataSyncSelector import info.nightscout.interfaces.sync.DataSyncSelector.PairBolus import info.nightscout.interfaces.sync.DataSyncSelector.PairBolusCalculatorResult @@ -39,7 +27,6 @@ import info.nightscout.plugins.sync.nsclient.acks.NSAddAck import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventNSClientNewLog -import info.nightscout.rx.logging.LTag import info.nightscout.shared.sharedPreferences.SP import javax.inject.Inject @@ -54,30 +41,22 @@ class NSClientAddAckWorker( @Inject lateinit var dataSyncSelector: DataSyncSelector @Inject lateinit var aapsSchedulers: AapsSchedulers @Inject lateinit var sp: SP + @Inject lateinit var storeDataForDb: StoreDataForDb override fun doWorkAndLog(): Result { - var ret = Result.success() - val ack = dataWorkerStorage.pickupObject(inputData.getLong(DataWorkerStorage.STORE_KEY, -1)) as NSAddAck? ?: return Result.failure(workDataOf("Error" to "missing input data")) if (sp.getBoolean(R.string.key_ns_sync_slow, false)) SystemClock.sleep(1000) + val ret = Result.success(workDataOf("ProcessedData" to ack.originalObject.toString())) when (ack.originalObject) { is PairTemporaryTarget -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdTemporaryTargetTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of TemporaryTarget failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of TemporaryTarget " + pair.value) - dataSyncSelector.confirmLastTempTargetsIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdTemporaryTargets.add(pair.value) + dataSyncSelector.confirmLastTempTargetsIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked TemporaryTarget " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedTempTargetsCompat() @@ -86,17 +65,9 @@ class NSClientAddAckWorker( is PairGlucoseValue -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdGlucoseValueTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of GlucoseValue failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of GlucoseValue " + pair.value) - dataSyncSelector.confirmLastGlucoseValueIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdGlucoseValues.add(pair.value) + dataSyncSelector.confirmLastGlucoseValueIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked GlucoseValue " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedGlucoseValuesCompat() @@ -105,17 +76,9 @@ class NSClientAddAckWorker( is PairFood -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdFoodTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of Food failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of Food " + pair.value) - dataSyncSelector.confirmLastFoodIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdFoods.add(pair.value) + dataSyncSelector.confirmLastFoodIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked Food " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedFoodsCompat() @@ -124,17 +87,9 @@ class NSClientAddAckWorker( is PairTherapyEvent -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdTherapyEventTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of TherapyEvent failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of TherapyEvent " + pair.value) - dataSyncSelector.confirmLastTherapyEventIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdTherapyEvents.add(pair.value) + dataSyncSelector.confirmLastTherapyEventIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked TherapyEvent " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedTherapyEventsCompat() @@ -143,17 +98,9 @@ class NSClientAddAckWorker( is PairBolus -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdBolusTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of Bolus failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of Bolus " + pair.value) - dataSyncSelector.confirmLastBolusIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdBoluses.add(pair.value) + dataSyncSelector.confirmLastBolusIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked Bolus " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedBolusesCompat() @@ -162,17 +109,9 @@ class NSClientAddAckWorker( is PairCarbs -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdCarbsTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of Carbs failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of Carbs " + pair.value) - dataSyncSelector.confirmLastCarbsIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdCarbs.add(pair.value) + dataSyncSelector.confirmLastCarbsIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked Carbs " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedCarbsCompat() @@ -181,17 +120,9 @@ class NSClientAddAckWorker( is PairBolusCalculatorResult -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdBolusCalculatorResultTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of BolusCalculatorResult failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of BolusCalculatorResult " + pair.value) - dataSyncSelector.confirmLastBolusCalculatorResultsIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdBolusCalculatorResults.add(pair.value) + dataSyncSelector.confirmLastBolusCalculatorResultsIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked BolusCalculatorResult " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedBolusCalculatorResultsCompat() @@ -200,17 +131,9 @@ class NSClientAddAckWorker( is PairTemporaryBasal -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdTemporaryBasalTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of TemporaryBasal failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of TemporaryBasal " + pair.value) - dataSyncSelector.confirmLastTemporaryBasalIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdTemporaryBasals.add(pair.value) + dataSyncSelector.confirmLastTemporaryBasalIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked TemporaryBasal " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedTemporaryBasalsCompat() @@ -219,17 +142,9 @@ class NSClientAddAckWorker( is PairExtendedBolus -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdExtendedBolusTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of ExtendedBolus failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of ExtendedBolus " + pair.value) - dataSyncSelector.confirmLastExtendedBolusIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdExtendedBoluses.add(pair.value) + dataSyncSelector.confirmLastExtendedBolusIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked ExtendedBolus " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedExtendedBolusesCompat() @@ -238,17 +153,9 @@ class NSClientAddAckWorker( is PairProfileSwitch -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdProfileSwitchTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of ProfileSwitch failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of ProfileSwitch " + pair.value) - dataSyncSelector.confirmLastProfileSwitchIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdProfileSwitches.add(pair.value) + dataSyncSelector.confirmLastProfileSwitchIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked ProfileSwitch " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedProfileSwitchesCompat() @@ -257,37 +164,21 @@ class NSClientAddAckWorker( is PairEffectiveProfileSwitch -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdEffectiveProfileSwitchTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of EffectiveProfileSwitch failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of EffectiveProfileSwitch " + pair.value) - dataSyncSelector.confirmLastEffectiveProfileSwitchIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdEffectiveProfileSwitches.add(pair.value) + dataSyncSelector.confirmLastEffectiveProfileSwitchIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked EffectiveProfileSwitch " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedEffectiveProfileSwitchesCompat() } is DataSyncSelector.PairDeviceStatus -> { - val deviceStatus = ack.originalObject - deviceStatus.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdDeviceStatusTransaction(deviceStatus.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of DeviceStatus failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to deviceStatus.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of DeviceStatus $deviceStatus") - dataSyncSelector.confirmLastDeviceStatusIdIfGreater(deviceStatus.value.id) - } - .blockingGet() - rxBus.send(EventNSClientNewLog("DBADD", "Acked DeviceStatus " + deviceStatus.value.interfaceIDs.nightscoutId)) + val pair = ack.originalObject + pair.value.interfaceIDs.nightscoutId = ack.id + storeDataForDb.nsIdDeviceStatuses.add(pair.value) + dataSyncSelector.confirmLastDeviceStatusIdIfGreater(pair.value.id) + storeDataForDb.scheduleNsIdUpdate() + rxBus.send(EventNSClientNewLog("DBADD", "Acked DeviceStatus " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedDeviceStatusesCompat() } @@ -300,17 +191,9 @@ class NSClientAddAckWorker( is PairOfflineEvent -> { val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id - repository.runTransactionForResult(UpdateNsIdOfflineEventTransaction(pair.value)) - .doOnError { error -> - aapsLogger.error(LTag.DATABASE, "Updated ns id of OfflineEvent failed", error) - ret = Result.failure((workDataOf("Error" to error.toString()))) - } - .doOnSuccess { - ret = Result.success(workDataOf("ProcessedData" to pair.toString())) - aapsLogger.debug(LTag.DATABASE, "Updated ns id of OfflineEvent " + pair.value) - dataSyncSelector.confirmLastOfflineEventIdIfGreater(pair.updateRecordId) - } - .blockingGet() + storeDataForDb.nsIdOfflineEvents.add(pair.value) + dataSyncSelector.confirmLastOfflineEventIdIfGreater(pair.updateRecordId) + storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked OfflineEvent " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting dataSyncSelector.processChangedOfflineEventsCompat() diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddUpdateWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddUpdateWorker.kt index 7c79f38715..ee941fab59 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddUpdateWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddUpdateWorker.kt @@ -11,11 +11,11 @@ import info.nightscout.database.impl.AppRepository import info.nightscout.interfaces.Config import info.nightscout.interfaces.XDripBroadcast import info.nightscout.interfaces.logging.UserEntryLogger +import info.nightscout.interfaces.nsclient.StoreDataForDb import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.interfaces.pump.VirtualPump import info.nightscout.interfaces.utils.JsonHelper import info.nightscout.plugins.sync.R -import info.nightscout.plugins.sync.nsShared.StoreDataForDbImpl import info.nightscout.plugins.sync.nsclient.extensions.bolusFromJson import info.nightscout.plugins.sync.nsclient.extensions.carbsFromJson import info.nightscout.plugins.sync.nsclient.extensions.effectiveProfileSwitchFromJson @@ -46,7 +46,7 @@ class NSClientAddUpdateWorker( @Inject lateinit var rxBus: RxBus @Inject lateinit var uel: UserEntryLogger @Inject lateinit var xDripBroadcast: XDripBroadcast - @Inject lateinit var storeDataForDb: StoreDataForDbImpl + @Inject lateinit var storeDataForDb: StoreDataForDb override fun doWorkAndLog(): Result { val treatments = dataWorkerStorage.pickupJSONArray(inputData.getLong(DataWorkerStorage.STORE_KEY, -1)) diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientMbgWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientMbgWorker.kt index 26cb5321b0..4ba8f44dc9 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientMbgWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientMbgWorker.kt @@ -6,7 +6,7 @@ import androidx.work.workDataOf import info.nightscout.core.utils.receivers.DataWorkerStorage import info.nightscout.core.utils.worker.LoggingWorker import info.nightscout.interfaces.Config -import info.nightscout.plugins.sync.nsShared.StoreDataForDbImpl +import info.nightscout.interfaces.nsclient.StoreDataForDb import info.nightscout.plugins.sync.nsclient.data.NSMbg import info.nightscout.plugins.sync.nsclient.extensions.therapyEventFromNsMbg import info.nightscout.shared.sharedPreferences.SP @@ -20,7 +20,7 @@ class NSClientMbgWorker( @Inject lateinit var dataWorkerStorage: DataWorkerStorage @Inject lateinit var sp: SP @Inject lateinit var config: Config - @Inject lateinit var storeDataForDb: StoreDataForDbImpl + @Inject lateinit var storeDataForDb: StoreDataForDb override fun doWorkAndLog(): Result { val ret = Result.success() diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt index 339ca53626..9d2ac4c637 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt @@ -29,8 +29,7 @@ import info.nightscout.plugins.sync.nsShared.NSClientFragment import info.nightscout.plugins.sync.nsShared.events.EventNSClientResend import info.nightscout.plugins.sync.nsShared.events.EventNSClientUpdateGUI import info.nightscout.plugins.sync.nsclient.NsClientReceiverDelegate -import info.nightscout.plugins.sync.nsclient.data.AlarmAck -import info.nightscout.plugins.sync.nsclient.services.NSClientService +import info.nightscout.plugins.sync.nsclientV3.extensions.toNSBolus import info.nightscout.plugins.sync.nsclientV3.workers.LoadBgWorker import info.nightscout.plugins.sync.nsclientV3.workers.LoadLastModificationWorker import info.nightscout.plugins.sync.nsclientV3.workers.LoadStatusWorker @@ -52,9 +51,9 @@ import info.nightscout.shared.utils.DateUtil import info.nightscout.shared.utils.T import io.reactivex.rxjava3.disposables.CompositeDisposable import io.reactivex.rxjava3.kotlin.plusAssign +import kotlinx.coroutines.runBlocking import kotlinx.serialization.decodeFromString import kotlinx.serialization.json.Json -import org.json.JSONObject import javax.inject.Inject import javax.inject.Singleton import kotlin.math.max @@ -302,13 +301,31 @@ class NSClientV3Plugin @Inject constructor( storeLastFetched() } - override fun dbAdd(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) { - if (collection == "treatments") { - //val result = nsAndroidClient.createTreatment() + override fun dbAdd(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) { + when (dataPair) { + is DataSyncSelector.PairBolus -> dataPair.value.toNSBolus() + // is DataSyncSelector.PairCarbs -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairBolusCalculatorResult -> dataPair.value.toJson(false, dateUtil, profileFunction) + // is DataSyncSelector.PairTemporaryTarget -> dataPair.value.toJson(false, profileFunction.getUnits(), dateUtil) + // is DataSyncSelector.PairFood -> dataPair.value.toJson(false) + // is DataSyncSelector.PairGlucoseValue -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairTherapyEvent -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairTemporaryBasal -> dataPair.value.toJson(false, profileFunction.getProfile(dataPair.value.timestamp), dateUtil) + // is DataSyncSelector.PairExtendedBolus -> dataPair.value.toJson(false, profileFunction.getProfile(dataPair.value.timestamp), dateUtil) + // is DataSyncSelector.PairProfileSwitch -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairEffectiveProfileSwitch -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairOfflineEvent -> dataPair.value.toJson(false, dateUtil) + else -> null + }?.let { data -> + runBlocking { + if (collection == "treatments") { + val result = nsAndroidClient.createTreatment(data) + } + } } } - override fun dbUpdate(collection: String, originalObject: DataSyncSelector.DataPair, progress: String) { + override fun dbUpdate(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) { TODO("Not yet implemented") } diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/extensions/BolusExtension.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/extensions/BolusExtension.kt index 23746cd94c..9b901ac7dd 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/extensions/BolusExtension.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/extensions/BolusExtension.kt @@ -1,7 +1,9 @@ package info.nightscout.plugins.sync.nsclientV3.extensions import info.nightscout.database.entities.Bolus +import info.nightscout.database.entities.TherapyEvent import info.nightscout.database.entities.embedments.InterfaceIDs +import info.nightscout.sdk.localmodel.treatment.EventType import info.nightscout.sdk.localmodel.treatment.NSBolus fun NSBolus.toBolus(): Bolus = @@ -21,4 +23,28 @@ fun NSBolus.BolusType?.toBolusType(): Bolus.Type = NSBolus.BolusType.SMB -> Bolus.Type.SMB NSBolus.BolusType.PRIMING -> Bolus.Type.PRIMING null -> Bolus.Type.NORMAL + } + +fun Bolus.toNSBolus(): NSBolus = + NSBolus( + eventType = EventType.fromString(if (type == Bolus.Type.SMB) TherapyEvent.Type.CORRECTION_BOLUS.text else TherapyEvent.Type.MEAL_BOLUS.text), + isValid = isValid, + date = timestamp, + utcOffset = utcOffset, + insulin = amount, + type = type.toBolusType(), + notes = notes, + identifier = interfaceIDs.nightscoutId, + pumpId = interfaceIDs.pumpId, + pumpType = interfaceIDs.pumpType?.name, + pumpSerial = interfaceIDs.pumpSerial, + endId = interfaceIDs.endId + ) + +fun Bolus.Type?.toBolusType(): NSBolus.BolusType = + when (this) { + Bolus.Type.NORMAL -> NSBolus.BolusType.NORMAL + Bolus.Type.SMB -> NSBolus.BolusType.SMB + Bolus.Type.PRIMING -> NSBolus.BolusType.PRIMING + null -> NSBolus.BolusType.NORMAL } \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadTreatmentsWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadTreatmentsWorker.kt index 21ac3717fb..70ec2be334 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadTreatmentsWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadTreatmentsWorker.kt @@ -8,7 +8,7 @@ import androidx.work.WorkerParameters import androidx.work.workDataOf import info.nightscout.core.utils.receivers.DataWorkerStorage import info.nightscout.core.utils.worker.LoggingWorker -import info.nightscout.plugins.sync.nsShared.StoreDataForDbImpl +import info.nightscout.interfaces.nsclient.StoreDataForDb import info.nightscout.plugins.sync.nsclientV3.NSClientV3Plugin import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventNSClientNewLog @@ -26,7 +26,7 @@ class LoadTreatmentsWorker( @Inject lateinit var context: Context @Inject lateinit var nsClientV3Plugin: NSClientV3Plugin @Inject lateinit var dateUtil: DateUtil - @Inject lateinit var storeDataForDb: StoreDataForDbImpl + @Inject lateinit var storeDataForDb: StoreDataForDb override fun doWorkAndLog(): Result { var ret = Result.success() diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/ProcessTreatmentsWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/ProcessTreatmentsWorker.kt index 096f746e20..2d433f5845 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/ProcessTreatmentsWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/ProcessTreatmentsWorker.kt @@ -10,9 +10,9 @@ import info.nightscout.interfaces.Config import info.nightscout.interfaces.Constants import info.nightscout.interfaces.XDripBroadcast import info.nightscout.interfaces.logging.UserEntryLogger +import info.nightscout.interfaces.nsclient.StoreDataForDb import info.nightscout.interfaces.plugin.ActivePlugin import info.nightscout.plugins.sync.R -import info.nightscout.plugins.sync.nsShared.StoreDataForDbImpl import info.nightscout.plugins.sync.nsclientV3.extensions.toBolus import info.nightscout.plugins.sync.nsclientV3.extensions.toBolusCalculatorResult import info.nightscout.plugins.sync.nsclientV3.extensions.toCarbs @@ -54,7 +54,7 @@ class ProcessTreatmentsWorker( @Inject lateinit var rxBus: RxBus @Inject lateinit var uel: UserEntryLogger @Inject lateinit var xDripBroadcast: XDripBroadcast - @Inject lateinit var storeDataForDb: StoreDataForDbImpl + @Inject lateinit var storeDataForDb: StoreDataForDb override fun doWorkAndLog(): Result { @Suppress("UNCHECKED_CAST") From 25aa907c995a35ddcdd2f92f8addaa6b1ca489e6 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 12 Dec 2022 19:46:28 +0100 Subject: [PATCH 46/48] NSC: better logging --- .../sync/nsShared/StoreDataForDbImpl.kt | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt index 49d666c0c6..e24d4f36d8 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt @@ -787,6 +787,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of TemporaryTarget $it") + nsIdUpdated.inc(TemporaryTarget::class.java.simpleName) } } @@ -798,6 +799,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of GlucoseValue $it") + nsIdUpdated.inc(GlucoseValue::class.java.simpleName) } } @@ -809,6 +811,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of Food $it") + nsIdUpdated.inc(Food::class.java.simpleName) } } @@ -820,6 +823,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of TherapyEvent $it") + nsIdUpdated.inc(TherapyEvent::class.java.simpleName) } } @@ -831,6 +835,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of Bolus $it") + nsIdUpdated.inc(Bolus::class.java.simpleName) } } @@ -842,6 +847,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of Carbs $it") + nsIdUpdated.inc(Carbs::class.java.simpleName) } } @@ -853,6 +859,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of BolusCalculatorResult $it") + nsIdUpdated.inc(BolusCalculatorResult::class.java.simpleName) } } @@ -864,6 +871,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of TemporaryBasal $it") + nsIdUpdated.inc(TemporaryBasal::class.java.simpleName) } } @@ -875,6 +883,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of ExtendedBolus $it") + nsIdUpdated.inc(ExtendedBolus::class.java.simpleName) } } @@ -886,6 +895,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of ProfileSwitch $it") + nsIdUpdated.inc(ProfileSwitch::class.java.simpleName) } } @@ -897,6 +907,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of EffectiveProfileSwitch $it") + nsIdUpdated.inc(EffectiveProfileSwitch::class.java.simpleName) } } @@ -908,6 +919,7 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of DeviceStatus $it") + nsIdUpdated.inc(DeviceStatus::class.java.simpleName) } } @@ -919,8 +931,21 @@ class StoreDataForDbImpl @Inject constructor( .also { result -> result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of OfflineEvent $it") + nsIdUpdated.inc(OfflineEvent::class.java.simpleName) } } + sendLog("GlucoseValue", GlucoseValue::class.java.simpleName) + sendLog("Bolus", NSBolus::class.java.simpleName) + sendLog("Carbs", NSCarbs::class.java.simpleName) + sendLog("TemporaryTarget", NSTemporaryTarget::class.java.simpleName) + sendLog("TemporaryBasal", NSTemporaryBasal::class.java.simpleName) + sendLog("EffectiveProfileSwitch", NSEffectiveProfileSwitch::class.java.simpleName) + sendLog("ProfileSwitch", NSProfileSwitch::class.java.simpleName) + sendLog("BolusCalculatorResult", NSBolusWizard::class.java.simpleName) + sendLog("TherapyEvent", NSTherapyEvent::class.java.simpleName) + sendLog("OfflineEvent", NSOfflineEvent::class.java.simpleName) + sendLog("ExtendedBolus", NSExtendedBolus::class.java.simpleName) + rxBus.send(EventNSClientNewLog("DONE NSIDs", "")) } private fun sendLog(item: String, clazz: String) { From 6937a61694e8b33a9703ca949ea364c11d737919 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 12 Dec 2022 20:17:43 +0100 Subject: [PATCH 47/48] NSC: cleanup --- .../nightscout/androidaps/MainActivity.kt | 1 + .../sync/nsShared/StoreDataForDbImpl.kt | 132 ++++++++---------- 2 files changed, 62 insertions(+), 71 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/MainActivity.kt b/app/src/main/java/info/nightscout/androidaps/MainActivity.kt index 1eca9dadd1..6e3f5de1c2 100644 --- a/app/src/main/java/info/nightscout/androidaps/MainActivity.kt +++ b/app/src/main/java/info/nightscout/androidaps/MainActivity.kt @@ -349,6 +349,7 @@ class MainActivity : DaggerAppCompatActivityWithResult() { message += "Flavor: ${BuildConfig.FLAVOR}${BuildConfig.BUILD_TYPE}\n" message += "${rh.gs(info.nightscout.configuration.R.string.configbuilder_nightscoutversion_label)} ${nsSettingsStatus.getVersion()}" if (config.isEngineeringMode()) message += "\n${rh.gs(info.nightscout.configuration.R.string.engineering_mode_enabled)}" + if (config.isUnfinishedMode()) message += "\nUnfinished mode enabled" if (!fabricPrivacy.fabricEnabled()) message += "\n${rh.gs(R.string.fabric_upload_disabled)}" message += rh.gs(info.nightscout.pump.combo.R.string.about_link_urls) val messageSpanned = SpannableString(message) diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt index e24d4f36d8..dd1241c8d7 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/StoreDataForDbImpl.kt @@ -58,16 +58,6 @@ import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventNSClientNewLog import info.nightscout.rx.logging.AAPSLogger import info.nightscout.rx.logging.LTag -import info.nightscout.sdk.localmodel.treatment.NSBolus -import info.nightscout.sdk.localmodel.treatment.NSBolusWizard -import info.nightscout.sdk.localmodel.treatment.NSCarbs -import info.nightscout.sdk.localmodel.treatment.NSEffectiveProfileSwitch -import info.nightscout.sdk.localmodel.treatment.NSExtendedBolus -import info.nightscout.sdk.localmodel.treatment.NSOfflineEvent -import info.nightscout.sdk.localmodel.treatment.NSProfileSwitch -import info.nightscout.sdk.localmodel.treatment.NSTemporaryBasal -import info.nightscout.sdk.localmodel.treatment.NSTemporaryTarget -import info.nightscout.sdk.localmodel.treatment.NSTherapyEvent import info.nightscout.shared.sharedPreferences.SP import info.nightscout.shared.utils.DateUtil import java.util.concurrent.Executors @@ -203,7 +193,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Inserted bolus $it") - inserted.inc(NSBolus::class.java.simpleName) + inserted.inc(Bolus::class.java.simpleName) } result.invalidated.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -216,19 +206,19 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated bolus $it") - invalidated.inc(NSBolus::class.java.simpleName) + invalidated.inc(Bolus::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId of bolus $it") - nsIdUpdated.inc(NSBolus::class.java.simpleName) + nsIdUpdated.inc(Bolus::class.java.simpleName) } result.updated.forEach { aapsLogger.debug(LTag.DATABASE, "Updated amount of bolus $it") - updated.inc(NSBolus::class.java.simpleName) + updated.inc(Bolus::class.java.simpleName) } } - sendLog("Bolus", NSBolus::class.java.simpleName) + sendLog("Bolus", Bolus::class.java.simpleName) SystemClock.sleep(pause) if (carbs.isNotEmpty()) @@ -250,7 +240,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Inserted carbs $it") - inserted.inc(NSCarbs::class.java.simpleName) + inserted.inc(Carbs::class.java.simpleName) } result.invalidated.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -263,7 +253,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated carbs $it") - invalidated.inc(NSCarbs::class.java.simpleName) + invalidated.inc(Carbs::class.java.simpleName) } result.updated.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -276,16 +266,16 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Updated carbs $it") - updated.inc(NSCarbs::class.java.simpleName) + updated.inc(Carbs::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId carbs $it") - nsIdUpdated.inc(NSCarbs::class.java.simpleName) + nsIdUpdated.inc(Carbs::class.java.simpleName) } } - sendLog("Carbs", NSCarbs::class.java.simpleName) + sendLog("Carbs", Carbs::class.java.simpleName) SystemClock.sleep(pause) if (temporaryTargets.isNotEmpty()) @@ -312,7 +302,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Inserted TemporaryTarget $tt") - inserted.inc(NSTemporaryTarget::class.java.simpleName) + inserted.inc(TemporaryTarget::class.java.simpleName) } result.invalidated.forEach { tt -> if (config.NSCLIENT.not()) userEntries.add( @@ -330,7 +320,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated TemporaryTarget $tt") - invalidated.inc(NSTemporaryTarget::class.java.simpleName) + invalidated.inc(TemporaryTarget::class.java.simpleName) } result.ended.forEach { tt -> if (config.NSCLIENT.not()) userEntries.add( @@ -348,19 +338,19 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Updated TemporaryTarget $tt") - ended.inc(NSTemporaryTarget::class.java.simpleName) + ended.inc(TemporaryTarget::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId TemporaryTarget $it") - nsIdUpdated.inc(NSTemporaryTarget::class.java.simpleName) + nsIdUpdated.inc(TemporaryTarget::class.java.simpleName) } result.updatedDuration.forEach { aapsLogger.debug(LTag.DATABASE, "Updated duration TemporaryTarget $it") - durationUpdated.inc(NSTemporaryTarget::class.java.simpleName) + durationUpdated.inc(TemporaryTarget::class.java.simpleName) } } - sendLog("TemporaryTarget", NSTemporaryTarget::class.java.simpleName) + sendLog("TemporaryTarget", TemporaryTarget::class.java.simpleName) SystemClock.sleep(pause) if (temporaryBasals.isNotEmpty()) @@ -386,7 +376,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Inserted TemporaryBasal $it") - inserted.inc(NSTemporaryBasal::class.java.simpleName) + inserted.inc(TemporaryBasal::class.java.simpleName) } result.invalidated.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -403,7 +393,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated TemporaryBasal $it") - invalidated.inc(NSTemporaryBasal::class.java.simpleName) + invalidated.inc(TemporaryBasal::class.java.simpleName) } result.ended.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -420,19 +410,19 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Ended TemporaryBasal $it") - ended.inc(NSTemporaryBasal::class.java.simpleName) + ended.inc(TemporaryBasal::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId TemporaryBasal $it") - nsIdUpdated.inc(NSTemporaryBasal::class.java.simpleName) + nsIdUpdated.inc(TemporaryBasal::class.java.simpleName) } result.updatedDuration.forEach { aapsLogger.debug(LTag.DATABASE, "Updated duration TemporaryBasal $it") - durationUpdated.inc(NSTemporaryBasal::class.java.simpleName) + durationUpdated.inc(TemporaryBasal::class.java.simpleName) } } - sendLog("TemporaryBasal", NSTemporaryBasal::class.java.simpleName) + sendLog("TemporaryBasal", TemporaryBasal::class.java.simpleName) SystemClock.sleep(pause) if (effectiveProfileSwitches.isNotEmpty()) @@ -454,7 +444,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Inserted EffectiveProfileSwitch $it") - inserted.inc(NSEffectiveProfileSwitch::class.java.simpleName) + inserted.inc(EffectiveProfileSwitch::class.java.simpleName) } result.invalidated.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -467,15 +457,15 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated EffectiveProfileSwitch $it") - invalidated.inc(NSEffectiveProfileSwitch::class.java.simpleName) + invalidated.inc(EffectiveProfileSwitch::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId EffectiveProfileSwitch $it") - nsIdUpdated.inc(NSEffectiveProfileSwitch::class.java.simpleName) + nsIdUpdated.inc(EffectiveProfileSwitch::class.java.simpleName) } } - sendLog("EffectiveProfileSwitch", NSEffectiveProfileSwitch::class.java.simpleName) + sendLog("EffectiveProfileSwitch", EffectiveProfileSwitch::class.java.simpleName) SystemClock.sleep(pause) if (profileSwitches.isNotEmpty()) @@ -497,7 +487,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Inserted ProfileSwitch $it") - inserted.inc(NSProfileSwitch::class.java.simpleName) + inserted.inc(ProfileSwitch::class.java.simpleName) } result.invalidated.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -510,15 +500,15 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated ProfileSwitch $it") - invalidated.inc(NSProfileSwitch::class.java.simpleName) + invalidated.inc(ProfileSwitch::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId ProfileSwitch $it") - nsIdUpdated.inc(NSProfileSwitch::class.java.simpleName) + nsIdUpdated.inc(ProfileSwitch::class.java.simpleName) } } - sendLog("ProfileSwitch", NSProfileSwitch::class.java.simpleName) + sendLog("ProfileSwitch", ProfileSwitch::class.java.simpleName) SystemClock.sleep(pause) if (bolusCalculatorResults.isNotEmpty()) @@ -531,19 +521,19 @@ class StoreDataForDbImpl @Inject constructor( bolusCalculatorResults.clear() result.inserted.forEach { aapsLogger.debug(LTag.DATABASE, "Inserted BolusCalculatorResult $it") - inserted.inc(NSBolusWizard::class.java.simpleName) + inserted.inc(BolusCalculatorResult::class.java.simpleName) } result.invalidated.forEach { aapsLogger.debug(LTag.DATABASE, "Invalidated BolusCalculatorResult $it") - invalidated.inc(NSBolusWizard::class.java.simpleName) + invalidated.inc(BolusCalculatorResult::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId BolusCalculatorResult $it") - nsIdUpdated.inc(NSBolusWizard::class.java.simpleName) + nsIdUpdated.inc(BolusCalculatorResult::class.java.simpleName) } } - sendLog("BolusCalculatorResult", NSBolusWizard::class.java.simpleName) + sendLog("BolusCalculatorResult", BolusCalculatorResult::class.java.simpleName) SystemClock.sleep(pause) if (sp.getBoolean(info.nightscout.core.utils.R.string.key_ns_receive_therapy_events, false) || config.NSCLIENT) @@ -583,7 +573,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Inserted TherapyEvent $therapyEvent") - inserted.inc(NSTherapyEvent::class.java.simpleName) + inserted.inc(TherapyEvent::class.java.simpleName) } result.invalidated.forEach { therapyEvent -> if (config.NSCLIENT.not()) userEntries.add( @@ -599,19 +589,19 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated TherapyEvent $therapyEvent") - invalidated.inc(NSTherapyEvent::class.java.simpleName) + invalidated.inc(TherapyEvent::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId TherapyEvent $it") - nsIdUpdated.inc(NSTherapyEvent::class.java.simpleName) + nsIdUpdated.inc(TherapyEvent::class.java.simpleName) } result.updatedDuration.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId TherapyEvent $it") - durationUpdated.inc(NSTherapyEvent::class.java.simpleName) + durationUpdated.inc(TherapyEvent::class.java.simpleName) } } - sendLog("TherapyEvent", NSTherapyEvent::class.java.simpleName) + sendLog("TherapyEvent", TherapyEvent::class.java.simpleName) SystemClock.sleep(pause) if (offlineEvents.isNotEmpty()) @@ -635,7 +625,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Inserted OfflineEvent $oe") - inserted.inc(NSOfflineEvent::class.java.simpleName) + inserted.inc(OfflineEvent::class.java.simpleName) } result.invalidated.forEach { oe -> if (config.NSCLIENT.not()) userEntries.add( @@ -651,7 +641,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated OfflineEvent $oe") - invalidated.inc(NSOfflineEvent::class.java.simpleName) + invalidated.inc(OfflineEvent::class.java.simpleName) } result.ended.forEach { oe -> if (config.NSCLIENT.not()) userEntries.add( @@ -667,19 +657,19 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Updated OfflineEvent $oe") - ended.inc(NSOfflineEvent::class.java.simpleName) + ended.inc(OfflineEvent::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId OfflineEvent $it") - nsIdUpdated.inc(NSOfflineEvent::class.java.simpleName) + nsIdUpdated.inc(OfflineEvent::class.java.simpleName) } result.updatedDuration.forEach { aapsLogger.debug(LTag.DATABASE, "Updated duration OfflineEvent $it") - durationUpdated.inc(NSOfflineEvent::class.java.simpleName) + durationUpdated.inc(OfflineEvent::class.java.simpleName) } } - sendLog("OfflineEvent", NSOfflineEvent::class.java.simpleName) + sendLog("OfflineEvent", OfflineEvent::class.java.simpleName) SystemClock.sleep(pause) if (extendedBoluses.isNotEmpty()) @@ -706,7 +696,7 @@ class StoreDataForDbImpl @Inject constructor( ) if (it.isEmulatingTempBasal) virtualPump.fakeDataDetected = true aapsLogger.debug(LTag.DATABASE, "Inserted ExtendedBolus $it") - inserted.inc(NSExtendedBolus::class.java.simpleName) + inserted.inc(ExtendedBolus::class.java.simpleName) } result.invalidated.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -724,7 +714,7 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Invalidated ExtendedBolus $it") - invalidated.inc(NSExtendedBolus::class.java.simpleName) + invalidated.inc(ExtendedBolus::class.java.simpleName) } result.ended.forEach { if (config.NSCLIENT.not()) userEntries.add( @@ -742,19 +732,19 @@ class StoreDataForDbImpl @Inject constructor( ) ) aapsLogger.debug(LTag.DATABASE, "Updated ExtendedBolus $it") - ended.inc(NSExtendedBolus::class.java.simpleName) + ended.inc(ExtendedBolus::class.java.simpleName) } result.updatedNsId.forEach { aapsLogger.debug(LTag.DATABASE, "Updated nsId ExtendedBolus $it") - nsIdUpdated.inc(NSExtendedBolus::class.java.simpleName) + nsIdUpdated.inc(ExtendedBolus::class.java.simpleName) } result.updatedDuration.forEach { aapsLogger.debug(LTag.DATABASE, "Updated duration ExtendedBolus $it") - durationUpdated.inc(NSExtendedBolus::class.java.simpleName) + durationUpdated.inc(ExtendedBolus::class.java.simpleName) } } - sendLog("ExtendedBolus", NSExtendedBolus::class.java.simpleName) + sendLog("ExtendedBolus", ExtendedBolus::class.java.simpleName) SystemClock.sleep(pause) uel.log(userEntries) @@ -935,16 +925,16 @@ class StoreDataForDbImpl @Inject constructor( } } sendLog("GlucoseValue", GlucoseValue::class.java.simpleName) - sendLog("Bolus", NSBolus::class.java.simpleName) - sendLog("Carbs", NSCarbs::class.java.simpleName) - sendLog("TemporaryTarget", NSTemporaryTarget::class.java.simpleName) - sendLog("TemporaryBasal", NSTemporaryBasal::class.java.simpleName) - sendLog("EffectiveProfileSwitch", NSEffectiveProfileSwitch::class.java.simpleName) - sendLog("ProfileSwitch", NSProfileSwitch::class.java.simpleName) - sendLog("BolusCalculatorResult", NSBolusWizard::class.java.simpleName) - sendLog("TherapyEvent", NSTherapyEvent::class.java.simpleName) - sendLog("OfflineEvent", NSOfflineEvent::class.java.simpleName) - sendLog("ExtendedBolus", NSExtendedBolus::class.java.simpleName) + sendLog("Bolus", Bolus::class.java.simpleName) + sendLog("Carbs", Carbs::class.java.simpleName) + sendLog("TemporaryTarget", TemporaryTarget::class.java.simpleName) + sendLog("TemporaryBasal", TemporaryBasal::class.java.simpleName) + sendLog("EffectiveProfileSwitch", EffectiveProfileSwitch::class.java.simpleName) + sendLog("ProfileSwitch", ProfileSwitch::class.java.simpleName) + sendLog("BolusCalculatorResult", BolusCalculatorResult::class.java.simpleName) + sendLog("TherapyEvent", TherapyEvent::class.java.simpleName) + sendLog("OfflineEvent", OfflineEvent::class.java.simpleName) + sendLog("ExtendedBolus", ExtendedBolus::class.java.simpleName) rxBus.send(EventNSClientNewLog("DONE NSIDs", "")) } From bd84d3a2f7ebe693228fcbb156d2c6af7dbb3f1c Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Tue, 13 Dec 2022 23:22:22 +0100 Subject: [PATCH 48/48] NSCv3: upload bolus, srvLastModified for treatments --- .../interfaces/sync/DataSyncSelector.kt | 33 +++--- .../nightscout/sdk/NSAndroidClientImpl.kt | 9 +- .../nightscout/sdk/NSAndroidRxClientImpl.kt | 2 +- .../sdk/interfaces/NSAndroidClient.kt | 7 +- .../sdk/interfaces/NSAndroidRxClient.kt | 2 +- .../treatment/CreateUpdateResponse.kt | 1 + .../sdk/localmodel/treatment/NSBolus.kt | 1 + .../sdk/localmodel/treatment/NSBolusWizard.kt | 2 +- .../sdk/localmodel/treatment/NSCarbs.kt | 1 + .../treatment/NSEffectiveProfileSwitch.kt | 1 + .../localmodel/treatment/NSExtendedBolus.kt | 1 + .../localmodel/treatment/NSOfflineEvent.kt | 1 + .../localmodel/treatment/NSProfileSwitch.kt | 1 + .../localmodel/treatment/NSTemporaryBasal.kt | 2 +- .../localmodel/treatment/NSTemporaryTarget.kt | 1 + .../localmodel/treatment/NSTherapyEvent.kt | 1 + .../sdk/localmodel/treatment/NSTreatment.kt | 1 + .../sdk/networking/NightscoutRemoteService.kt | 9 +- .../sdk/remotemodel/RemoteTreatment.kt | 4 +- .../nightscout/plugins/sync/di/SyncModule.kt | 4 +- .../DataSyncSelectorImplementation.kt | 25 ++++- .../plugins/sync/nsShared/NSClientFragment.kt | 9 -- .../sync/nsclient/services/NSClientService.kt | 4 +- .../nsclient/workers/NSClientAddAckWorker.kt | 26 ++--- .../workers/NSClientUpdateRemoveAckWorker.kt | 24 ++--- .../sync/nsclientV3/NSClientV3Plugin.kt | 101 ++++++++++++++---- .../sync/nsclientV3/workers/DataSyncWorker.kt | 21 ++++ .../sync/nsclientV3/workers/LoadBgWorker.kt | 10 +- .../workers/LoadDeviceStatusWorker.kt | 9 ++ .../workers/LoadLastModificationWorker.kt | 4 +- .../workers/LoadTreatmentsWorker.kt | 12 +-- .../workers/ProcessTreatmentsWorker.kt | 12 +-- 32 files changed, 224 insertions(+), 117 deletions(-) rename plugins/sync/src/main/java/info/nightscout/plugins/sync/{nsclient => nsShared}/DataSyncSelectorImplementation.kt (98%) create mode 100644 plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/DataSyncWorker.kt diff --git a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt index 73ae9bd313..9ae892c854 100644 --- a/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt +++ b/core/interfaces/src/main/java/info/nightscout/interfaces/sync/DataSyncSelector.kt @@ -17,21 +17,24 @@ import org.json.JSONObject interface DataSyncSelector { - interface DataPair - data class PairTemporaryTarget(val value: TemporaryTarget, val updateRecordId: Long): DataPair - data class PairGlucoseValue(val value: GlucoseValue, val updateRecordId: Long): DataPair - data class PairTherapyEvent(val value: TherapyEvent, val updateRecordId: Long): DataPair - data class PairFood(val value: Food, val updateRecordId: Long): DataPair - data class PairBolus(val value: Bolus, val updateRecordId: Long): DataPair - data class PairCarbs(val value: Carbs, val updateRecordId: Long): DataPair - data class PairBolusCalculatorResult(val value: BolusCalculatorResult, val updateRecordId: Long): DataPair - data class PairTemporaryBasal(val value: TemporaryBasal, val updateRecordId: Long): DataPair - data class PairExtendedBolus(val value: ExtendedBolus, val updateRecordId: Long): DataPair - data class PairProfileSwitch(val value: ProfileSwitch, val updateRecordId: Long): DataPair - data class PairEffectiveProfileSwitch(val value: EffectiveProfileSwitch, val updateRecordId: Long): DataPair - data class PairOfflineEvent(val value: OfflineEvent, val updateRecordId: Long): DataPair - data class PairProfileStore(val value: JSONObject, val timestampSync: Long): DataPair - data class PairDeviceStatus(val value: DeviceStatus, val unused: Long?): DataPair + interface DataPair { + val value: Any + val id: Long + } + data class PairTemporaryTarget(override val value: TemporaryTarget, override val id: Long): DataPair + data class PairGlucoseValue(override val value: GlucoseValue, override val id: Long): DataPair + data class PairTherapyEvent(override val value: TherapyEvent, override val id: Long): DataPair + data class PairFood(override val value: Food, override val id: Long): DataPair + data class PairBolus(override val value: Bolus, override val id: Long): DataPair + data class PairCarbs(override val value: Carbs, override val id: Long): DataPair + data class PairBolusCalculatorResult(override val value: BolusCalculatorResult, override val id: Long): DataPair + data class PairTemporaryBasal(override val value: TemporaryBasal, override val id: Long): DataPair + data class PairExtendedBolus(override val value: ExtendedBolus, override val id: Long): DataPair + data class PairProfileSwitch(override val value: ProfileSwitch, override val id: Long): DataPair + data class PairEffectiveProfileSwitch(override val value: EffectiveProfileSwitch, override val id: Long): DataPair + data class PairOfflineEvent(override val value: OfflineEvent, override val id: Long): DataPair + data class PairProfileStore(override val value: JSONObject, override val id: Long): DataPair + data class PairDeviceStatus(override val value: DeviceStatus, override val id: Long): DataPair fun queueSize(): Long diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt index e5ef49e3c4..cb76bf8351 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidClientImpl.kt @@ -138,11 +138,13 @@ class NSAndroidClientImpl( } } - override suspend fun getTreatmentsModifiedSince(from: Long, limit: Long): List = callWrapper(dispatcher) { + override suspend fun getTreatmentsModifiedSince(from: Long, limit: Long): NSAndroidClient.ReadResponse> = callWrapper(dispatcher) { val response = api.getTreatmentsModifiedSince(from, limit) + val eTagString = response.headers()["ETag"] + val eTag = eTagString?.substring(3, eTagString.length - 1)?.toLong() ?: throw TodoNightscoutException() if (response.isSuccessful) { - return@callWrapper response.body()?.result?.map(RemoteTreatment::toTreatment).toNotNull() + return@callWrapper NSAndroidClient.ReadResponse(eTag, response.body()?.result?.map(RemoteTreatment::toTreatment).toNotNull()) } else { throw TodoNightscoutException() // TODO: react to response errors (offline, ...) } @@ -161,9 +163,11 @@ class NSAndroidClientImpl( override suspend fun createTreatment(nsTreatment: NSTreatment): CreateUpdateResponse = callWrapper(dispatcher) { val remoteTreatment = nsTreatment.toRemoteTreatment() ?: throw InvalidFormatNightscoutException() + remoteTreatment.app = "AAPS" val response = api.createTreatment(remoteTreatment) if (response.isSuccessful) { return@callWrapper CreateUpdateResponse( + response = response.code(), identifier = response.body()?.result?.identifier ?: throw UnknownResponseNightscoutException(), isDeduplication = response.body()?.result?.isDeduplication ?: false, deduplicatedIdentifier = response.body()?.result?.deduplicatedIdentifier, @@ -180,6 +184,7 @@ class NSAndroidClientImpl( val response = api.updateTreatment(remoteTreatment) if (response.isSuccessful) { return@callWrapper CreateUpdateResponse( + response = response.code(), identifier = response.body()?.result?.identifier ?: throw UnknownResponseNightscoutException(), isDeduplication = response.body()?.result?.isDeduplication ?: false, deduplicatedIdentifier = response.body()?.result?.deduplicatedIdentifier, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidRxClientImpl.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidRxClientImpl.kt index 93b11ca0ce..1d4cb3c02c 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidRxClientImpl.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/NSAndroidRxClientImpl.kt @@ -16,7 +16,7 @@ class NSAndroidRxClientImpl(private val client: NSAndroidClient) : NSAndroidRxCl override fun getStatus(): Single = rxSingle { client.getStatus() } override fun getLastModified(): Single = rxSingle { client.getLastModified() } override fun getSgvsModifiedSince(from: Long): Single> = rxSingle { client.getSgvsModifiedSince(from) } - override fun getTreatmentsModifiedSince(from: Long, limit: Long): Single> = + override fun getTreatmentsModifiedSince(from: Long, limit: Long): Single>> = rxSingle { client.getTreatmentsModifiedSince(from, limit) } override fun getDeviceStatusModifiedSince(from: Long): Single> = rxSingle { client.getDeviceStatusModifiedSince(from) } diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt index 2e4f24f0d6..d29b959080 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidClient.kt @@ -9,6 +9,11 @@ import info.nightscout.sdk.remotemodel.RemoteDeviceStatus interface NSAndroidClient { + class ReadResponse( + val lastServerModified: Long, + val values: T + ) + val lastStatus: Status? suspend fun getVersion(): String suspend fun getStatus(): Status @@ -18,7 +23,7 @@ interface NSAndroidClient { suspend fun getSgvs(): List suspend fun getSgvsModifiedSince(from: Long): List suspend fun getSgvsNewerThan(from: Long, limit: Long): List - suspend fun getTreatmentsModifiedSince(from: Long, limit: Long): List + suspend fun getTreatmentsModifiedSince(from: Long, limit: Long): ReadResponse> suspend fun getDeviceStatusModifiedSince(from: Long): List suspend fun createTreatment(nsTreatment: NSTreatment): CreateUpdateResponse suspend fun updateTreatment(nsTreatment: NSTreatment): CreateUpdateResponse diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidRxClient.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidRxClient.kt index 77a88358a1..01b365b6f5 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidRxClient.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/interfaces/NSAndroidRxClient.kt @@ -13,7 +13,7 @@ interface NSAndroidRxClient { fun getStatus(): Single fun getLastModified(): Single fun getSgvsModifiedSince(from: Long): Single> - fun getTreatmentsModifiedSince(from: Long, limit: Long): Single> + fun getTreatmentsModifiedSince(from: Long, limit: Long): Single>> fun getDeviceStatusModifiedSince(from: Long): Single> } diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/CreateUpdateResponse.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/CreateUpdateResponse.kt index ad7a3835a2..4799277f2b 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/CreateUpdateResponse.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/CreateUpdateResponse.kt @@ -1,6 +1,7 @@ package info.nightscout.sdk.localmodel.treatment class CreateUpdateResponse( + val response: Int, val identifier: String?, val isDeduplication: Boolean? = false, val deduplicatedIdentifier: String? = null, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt index f7cda2174e..c9f143f1ea 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolus.kt @@ -19,6 +19,7 @@ data class NSBolus( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val insulin: Double, val type: BolusType diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt index 01be68e231..5418175fe1 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSBolusWizard.kt @@ -1,7 +1,6 @@ package info.nightscout.sdk.localmodel.treatment import info.nightscout.sdk.localmodel.entry.NsUnits -import org.json.JSONObject data class NSBolusWizard( override val date: Long, @@ -20,6 +19,7 @@ data class NSBolusWizard( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val bolusCalculatorResult: String?, val glucose: Double?, ) : NSTreatment \ No newline at end of file diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt index 15003a02f3..27c976ab4e 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSCarbs.kt @@ -19,6 +19,7 @@ data class NSCarbs( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val carbs: Double, val duration: Long ) : NSTreatment \ No newline at end of file diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt index 312d542daf..65662e5058 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSEffectiveProfileSwitch.kt @@ -20,6 +20,7 @@ data class NSEffectiveProfileSwitch( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val profileJson: JSONObject, val originalProfileName: String, val originalCustomizedName: String, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt index 8228c45200..eb140215fb 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSExtendedBolus.kt @@ -19,6 +19,7 @@ data class NSExtendedBolus( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val duration: Long, val enteredinsulin: Double, val isEmulatingTempBasal: Boolean? diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt index dd95c02c3b..64b7607b17 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSOfflineEvent.kt @@ -19,6 +19,7 @@ data class NSOfflineEvent( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val duration: Long, val reason: Reason ) : NSTreatment { diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt index bd6fa96888..afd55d90b3 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSProfileSwitch.kt @@ -20,6 +20,7 @@ data class NSProfileSwitch( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val profileJson: JSONObject?, val profileName: String, val originalProfileName: String?, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt index 3592c25135..88d588aca2 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryBasal.kt @@ -1,7 +1,6 @@ package info.nightscout.sdk.localmodel.treatment import info.nightscout.sdk.localmodel.entry.NsUnits -import org.json.JSONObject data class NSTemporaryBasal( override val date: Long, @@ -20,6 +19,7 @@ data class NSTemporaryBasal( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val duration: Long, val rate: Double, // when sending to NS always convertedToAbsolute(timestamp, profile) val isAbsolute: Boolean, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt index cf9158d3b2..4e151dab37 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTemporaryTarget.kt @@ -19,6 +19,7 @@ data class NSTemporaryTarget( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val duration: Long, val targetBottom: Double, val targetTop: Double, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt index a893fb447d..03d47013ad 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTherapyEvent.kt @@ -20,6 +20,7 @@ data class NSTherapyEvent( override val endId: Long?, override val pumpType: String?, override val pumpSerial: String?, + override var app: String? = null, val duration: Long, var enteredBy: String? = null, var glucose: Double? = null, diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt index 55bb153732..17b4037b5e 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/localmodel/treatment/NSTreatment.kt @@ -19,6 +19,7 @@ interface NSTreatment { val endId: Long? val pumpType: String? val pumpSerial: String? + var app: String? fun Double.asMgdl() = when (units) { diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt index 1fc95dfe24..fc52b14891 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/networking/NightscoutRemoteService.kt @@ -2,18 +2,15 @@ package info.nightscout.sdk.networking import com.google.gson.JsonElement import info.nightscout.sdk.remotemodel.LastModified -import info.nightscout.sdk.remotemodel.RemoteDeviceStatus import info.nightscout.sdk.remotemodel.NSResponse import info.nightscout.sdk.remotemodel.RemoteCreateUpdateResponse +import info.nightscout.sdk.remotemodel.RemoteDeviceStatus import info.nightscout.sdk.remotemodel.RemoteEntry import info.nightscout.sdk.remotemodel.RemoteStatusResponse import info.nightscout.sdk.remotemodel.RemoteTreatment -import okhttp3.RequestBody -import retrofit2.Call import retrofit2.Response import retrofit2.http.Body import retrofit2.http.GET -import retrofit2.http.Header import retrofit2.http.POST import retrofit2.http.PUT import retrofit2.http.Path @@ -57,9 +54,9 @@ internal interface NightscoutRemoteService { suspend fun getDeviceStatusModifiedSince(@Path("from") from: Long): Response>> @POST("v3/treatments") - fun createTreatment(@Body remoteTreatment: RemoteTreatment): Response> + suspend fun createTreatment(@Body remoteTreatment: RemoteTreatment): Response> @PUT("v3/treatments") - fun updateTreatment(@Body remoteTreatment: RemoteTreatment): Response> + suspend fun updateTreatment(@Body remoteTreatment: RemoteTreatment): Response> } diff --git a/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt b/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt index 5f29c0f96b..df11416054 100644 --- a/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt +++ b/core/ns-sdk/src/main/java/info/nightscout/sdk/remotemodel/RemoteTreatment.kt @@ -1,11 +1,9 @@ package info.nightscout.sdk.remotemodel -import com.google.gson.Gson import com.google.gson.annotations.SerializedName import info.nightscout.sdk.localmodel.treatment.EventType import org.joda.time.DateTime import org.joda.time.format.ISODateTimeFormat -import org.json.JSONObject /* * Depending on the type, different other fields are present. @@ -23,7 +21,7 @@ internal data class RemoteTreatment( @SerializedName("timestamp") val timestamp: Long? = null, // integer($int64) or string required timestamp when the record or event occurred, you can choose from three input formats Unix epoch in milliseconds (1525383610088), Unix epoch in seconds (1525383610), ISO 8601 with optional timezone ('2018-05-03T21:40:10.088Z' or '2018-05-03T23:40:10.088+02:00') @SerializedName("created_at") val created_at: String? = null, // integer($int64) or string timestamp on previous version of api, in my examples, a lot of treatments don't have date, only created_at, some of them with string others with long... @SerializedName("utcOffset") val utcOffset: Long? = null, // integer Local UTC offset (timezone) of the event in minutes. This field can be set either directly by the client (in the incoming document) or it is automatically parsed from the date field. - // @SerializedName("app") val app : String, // TODO required ? Application or system in which the record was entered by human or device for the first time. + @SerializedName("app") var app : String? = null, // Application or system in which the record was entered by human or device for the first time. @SerializedName("device") val device: String? = null, // string The device from which the data originated (including serial number of the device, if it is relevant and safe). @SerializedName("srvCreated") val srvCreated: Long? = null, // integer($int64) example: 1525383610088 The server's timestamp of document insertion into the database (Unix epoch in ms). This field appears only for documents which were inserted by API v3. @SerializedName("subject") val subject: String? = null, // string Name of the security subject (within Nightscout scope) which has created the document. This field is automatically set by the server from the passed token or JWT. diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/di/SyncModule.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/di/SyncModule.kt index f1d0bac4e8..6ecb8a379a 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/di/SyncModule.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/di/SyncModule.kt @@ -7,9 +7,9 @@ import info.nightscout.interfaces.nsclient.NSSettingsStatus import info.nightscout.interfaces.nsclient.ProcessedDeviceStatusData import info.nightscout.interfaces.nsclient.StoreDataForDb import info.nightscout.interfaces.sync.DataSyncSelector +import info.nightscout.plugins.sync.nsShared.DataSyncSelectorImplementation import info.nightscout.plugins.sync.nsShared.NSClientFragment import info.nightscout.plugins.sync.nsShared.StoreDataForDbImpl -import info.nightscout.plugins.sync.nsclient.DataSyncSelectorImplementation import info.nightscout.plugins.sync.nsclient.data.NSSettingsStatusImpl import info.nightscout.plugins.sync.nsclient.data.ProcessedDeviceStatusDataImpl import info.nightscout.plugins.sync.nsclient.services.NSClientService @@ -17,6 +17,7 @@ import info.nightscout.plugins.sync.nsclient.workers.NSClientAddAckWorker import info.nightscout.plugins.sync.nsclient.workers.NSClientAddUpdateWorker import info.nightscout.plugins.sync.nsclient.workers.NSClientMbgWorker import info.nightscout.plugins.sync.nsclient.workers.NSClientUpdateRemoveAckWorker +import info.nightscout.plugins.sync.nsclientV3.workers.DataSyncWorker import info.nightscout.plugins.sync.nsclientV3.workers.LoadBgWorker import info.nightscout.plugins.sync.nsclientV3.workers.LoadDeviceStatusWorker import info.nightscout.plugins.sync.nsclientV3.workers.LoadLastModificationWorker @@ -49,6 +50,7 @@ abstract class SyncModule { @ContributesAndroidInjector abstract fun contributesTreatmentWorker(): LoadTreatmentsWorker @ContributesAndroidInjector abstract fun contributesProcessTreatmentsWorker(): ProcessTreatmentsWorker @ContributesAndroidInjector abstract fun contributesLoadDeviceStatusWorker(): LoadDeviceStatusWorker + @ContributesAndroidInjector abstract fun contributesDataSyncWorker(): DataSyncWorker @ContributesAndroidInjector abstract fun contributesTidepoolFragment(): TidepoolFragment diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/DataSyncSelectorImplementation.kt similarity index 98% rename from plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt rename to plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/DataSyncSelectorImplementation.kt index d83541dfa8..b38d6eea6b 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/DataSyncSelectorImplementation.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/DataSyncSelectorImplementation.kt @@ -1,4 +1,4 @@ -package info.nightscout.plugins.sync.nsclient +package info.nightscout.plugins.sync.nsShared import info.nightscout.database.ValueWrapper import info.nightscout.database.impl.AppRepository @@ -56,11 +56,12 @@ class DataSyncSelectorImplementation @Inject constructor( } private val queueCounter = QueueCounter() + private val isPaused get() = sp.getBoolean(R.string.key_ns_client_paused, false) override fun queueSize(): Long = queueCounter.size() override fun doUpload() { - if (sp.getBoolean(R.string.key_ns_upload, true)) { + if (sp.getBoolean(R.string.key_ns_upload, true) && !isPaused) { processChangedBolusesCompat() processChangedCarbsCompat() processChangedBolusCalculatorResultsCompat() @@ -106,6 +107,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedBolusesCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastBolusIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_bolus_last_synced_id, 0) @@ -158,6 +160,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedCarbsCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastCarbsIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_carbs_last_synced_id, 0) @@ -206,6 +209,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedBolusCalculatorResultsCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastBolusCalculatorResultIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_bolus_calculator_result_last_synced_id, 0) @@ -257,6 +261,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedTempTargetsCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastTempTargetIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_temporary_target_last_synced_id, 0) @@ -309,6 +314,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedFoodsCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastFoodIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_food_last_synced_id, 0) @@ -357,6 +363,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedGlucoseValuesCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastGlucoseValueIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_glucose_value_last_synced_id, 0) @@ -369,7 +376,7 @@ class DataSyncSelectorImplementation @Inject constructor( aapsLogger.info(LTag.NSCLIENT, "Loading GlucoseValue data Start: $startId ${gv.first} forID: ${gv.second.id} ") if (activePlugin.activeBgSource.shouldUploadToNs(gv.first)) { when { - // new record with existing NS id => must be coming from NS => ignore + // new record with existing NS id => must be coming from NS => ignore gv.first.id == gv.second.id && gv.first.interfaceIDs.nightscoutId != null -> { aapsLogger.info(LTag.NSCLIENT, "Ignoring GlucoseValue. Loaded from NS: ${gv.second.id} ") confirmLastGlucoseValueIdIfGreater(gv.second.id) @@ -410,6 +417,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedTherapyEventsCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastTherapyEventIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_therapy_event_last_synced_id, 0) @@ -458,6 +466,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override fun processChangedDeviceStatusesCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastDeviceStatusIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_device_status_last_synced_id, 0) @@ -471,7 +480,7 @@ class DataSyncSelectorImplementation @Inject constructor( when { // without nsId = create new deviceStatus.interfaceIDs.nightscoutId == null -> - activePlugin.activeNsClient?.dbAdd("devicestatus", DataSyncSelector.PairDeviceStatus(deviceStatus, null), "$startId/$lastDbId") + activePlugin.activeNsClient?.dbAdd("devicestatus", DataSyncSelector.PairDeviceStatus(deviceStatus, 0), "$startId/$lastDbId") // with nsId = ignore deviceStatus.interfaceIDs.nightscoutId != null -> Any() } @@ -487,6 +496,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedTemporaryBasalsCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastTemporaryBasalIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_temporary_basal_last_synced_id, 0) @@ -539,6 +549,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedExtendedBolusesCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastExtendedBolusIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_extended_bolus_last_synced_id, 0) @@ -599,6 +610,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedProfileSwitchesCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastProfileSwitchIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_profile_switch_last_synced_id, 0) @@ -647,6 +659,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedEffectiveProfileSwitchesCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastEffectiveProfileSwitchIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_effective_profile_switch_last_synced_id, 0) @@ -699,6 +712,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override tailrec fun processChangedOfflineEventsCompat() { + if (isPaused) return val lastDbIdWrapped = appRepository.getLastOfflineEventIdWrapped().blockingGet() val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L var startId = sp.getLong(R.string.key_ns_offline_event_last_synced_id, 0) @@ -744,6 +758,7 @@ class DataSyncSelectorImplementation @Inject constructor( } override fun processChangedProfileStore() { + if (isPaused) return val lastSync = sp.getLong(R.string.key_ns_profile_store_last_synced_timestamp, 0) val lastChange = sp.getLong(info.nightscout.core.utils.R.string.key_local_profile_last_change, 0) if (lastChange == 0L) return @@ -753,4 +768,4 @@ class DataSyncSelectorImplementation @Inject constructor( activePlugin.activeNsClient?.dbAdd("profile", DataSyncSelector.PairProfileStore(profileJson, dateUtil.now()), "") } } -} +} \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/NSClientFragment.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/NSClientFragment.kt index 02fe44799b..aadc32a8b0 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/NSClientFragment.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsShared/NSClientFragment.kt @@ -26,7 +26,6 @@ import info.nightscout.interfaces.sync.NsClient import info.nightscout.plugins.sync.R import info.nightscout.plugins.sync.databinding.NsClientFragmentBinding import info.nightscout.plugins.sync.nsShared.events.EventNSClientUpdateGUI -import info.nightscout.plugins.sync.nsclientV3.NSClientV3Plugin import info.nightscout.rx.AapsSchedulers import info.nightscout.rx.bus.RxBus import info.nightscout.rx.events.EventNSClientRestart @@ -56,7 +55,6 @@ class NSClientFragment : DaggerFragment(), MenuProvider, PluginFragment { const val ID_MENU_RESTART = 508 const val ID_MENU_SEND_NOW = 509 const val ID_MENU_FULL_SYNC = 510 - const val ID_MENU_TEST = 601 } override var plugin: PluginBase? = null @@ -97,8 +95,6 @@ class NSClientFragment : DaggerFragment(), MenuProvider, PluginFragment { } override fun onCreateMenu(menu: Menu, inflater: MenuInflater) { - if (config.isUnfinishedMode()) - menu.add(Menu.FIRST, ID_MENU_TEST, 0, "Test").setShowAsAction(MenuItem.SHOW_AS_ACTION_NEVER) menu.add(Menu.FIRST, ID_MENU_CLEAR_LOG, 0, rh.gs(R.string.clear_log)).setShowAsAction(MenuItem.SHOW_AS_ACTION_NEVER) menu.add(Menu.FIRST, ID_MENU_RESTART, 0, rh.gs(R.string.restart)).setShowAsAction(MenuItem.SHOW_AS_ACTION_NEVER) menu.add(Menu.FIRST, ID_MENU_SEND_NOW, 0, rh.gs(R.string.deliver_now)).setShowAsAction(MenuItem.SHOW_AS_ACTION_NEVER) @@ -133,11 +129,6 @@ class NSClientFragment : DaggerFragment(), MenuProvider, PluginFragment { true } - ID_MENU_TEST -> { - nsClientPlugin?.let { plugin -> if (plugin is NSClientV3Plugin) handler.post { plugin.test() } } - true - } - else -> false } diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt index 4887884cbb..5c4d1506d3 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/services/NSClientService.kt @@ -580,7 +580,7 @@ class NSClientService : DaggerService() { socket?.emit("dbUpdate", message, NSUpdateAck("dbUpdate", _id, aapsLogger, rxBus, this, dateUtil, dataWorkerStorage, originalObject)) rxBus.send( EventNSClientNewLog( - "DBUPDATE $collection", "Sent " + originalObject.javaClass.simpleName + " " + + "UPDATE $collection", "Sent " + originalObject.javaClass.simpleName + " " + "" + _id + " " + data + progress ) ) @@ -596,7 +596,7 @@ class NSClientService : DaggerService() { message.put("collection", collection) message.put("data", data) socket?.emit("dbAdd", message, NSAddAck(aapsLogger, rxBus, this, dateUtil, dataWorkerStorage, originalObject)) - rxBus.send(EventNSClientNewLog("DBADD $collection", "Sent " + originalObject.javaClass.simpleName + " " + data + " " + progress)) + rxBus.send(EventNSClientNewLog("ADD $collection", "Sent " + originalObject.javaClass.simpleName + " " + data + " " + progress)) } catch (e: JSONException) { aapsLogger.error("Unhandled exception", e) } diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt index 3119fa5e74..ed3065b845 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientAddAckWorker.kt @@ -55,7 +55,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdTemporaryTargets.add(pair.value) - dataSyncSelector.confirmLastTempTargetsIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastTempTargetsIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked TemporaryTarget " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -66,7 +66,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdGlucoseValues.add(pair.value) - dataSyncSelector.confirmLastGlucoseValueIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastGlucoseValueIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked GlucoseValue " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -77,7 +77,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdFoods.add(pair.value) - dataSyncSelector.confirmLastFoodIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastFoodIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked Food " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -88,7 +88,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdTherapyEvents.add(pair.value) - dataSyncSelector.confirmLastTherapyEventIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastTherapyEventIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked TherapyEvent " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -99,7 +99,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdBoluses.add(pair.value) - dataSyncSelector.confirmLastBolusIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastBolusIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked Bolus " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -110,7 +110,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdCarbs.add(pair.value) - dataSyncSelector.confirmLastCarbsIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastCarbsIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked Carbs " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -121,7 +121,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdBolusCalculatorResults.add(pair.value) - dataSyncSelector.confirmLastBolusCalculatorResultsIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastBolusCalculatorResultsIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked BolusCalculatorResult " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -132,7 +132,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdTemporaryBasals.add(pair.value) - dataSyncSelector.confirmLastTemporaryBasalIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastTemporaryBasalIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked TemporaryBasal " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -143,7 +143,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdExtendedBoluses.add(pair.value) - dataSyncSelector.confirmLastExtendedBolusIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastExtendedBolusIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked ExtendedBolus " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -154,7 +154,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdProfileSwitches.add(pair.value) - dataSyncSelector.confirmLastProfileSwitchIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastProfileSwitchIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked ProfileSwitch " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -165,7 +165,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdEffectiveProfileSwitches.add(pair.value) - dataSyncSelector.confirmLastEffectiveProfileSwitchIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastEffectiveProfileSwitchIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked EffectiveProfileSwitch " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting @@ -184,7 +184,7 @@ class NSClientAddAckWorker( } is PairProfileStore -> { - dataSyncSelector.confirmLastProfileStore(ack.originalObject.timestampSync) + dataSyncSelector.confirmLastProfileStore(ack.originalObject.id) rxBus.send(EventNSClientNewLog("DBADD", "Acked ProfileStore " + ack.id)) } @@ -192,7 +192,7 @@ class NSClientAddAckWorker( val pair = ack.originalObject pair.value.interfaceIDs.nightscoutId = ack.id storeDataForDb.nsIdOfflineEvents.add(pair.value) - dataSyncSelector.confirmLastOfflineEventIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastOfflineEventIdIfGreater(pair.id) storeDataForDb.scheduleNsIdUpdate() rxBus.send(EventNSClientNewLog("DBADD", "Acked OfflineEvent " + pair.value.interfaceIDs.nightscoutId)) // Send new if waiting diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientUpdateRemoveAckWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientUpdateRemoveAckWorker.kt index bf000d9c03..3536329da1 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientUpdateRemoveAckWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclient/workers/NSClientUpdateRemoveAckWorker.kt @@ -46,7 +46,7 @@ class NSClientUpdateRemoveAckWorker( when (ack.originalObject) { is PairTemporaryTarget -> { val pair = ack.originalObject - dataSyncSelector.confirmLastTempTargetsIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastTempTargetsIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked TemporaryTarget" + ack._id)) // Send new if waiting dataSyncSelector.processChangedTempTargetsCompat() @@ -55,7 +55,7 @@ class NSClientUpdateRemoveAckWorker( is PairGlucoseValue -> { val pair = ack.originalObject - dataSyncSelector.confirmLastGlucoseValueIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastGlucoseValueIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked GlucoseValue " + ack._id)) // Send new if waiting dataSyncSelector.processChangedGlucoseValuesCompat() @@ -64,7 +64,7 @@ class NSClientUpdateRemoveAckWorker( is PairFood -> { val pair = ack.originalObject - dataSyncSelector.confirmLastFoodIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastFoodIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked Food " + ack._id)) // Send new if waiting dataSyncSelector.processChangedFoodsCompat() @@ -73,7 +73,7 @@ class NSClientUpdateRemoveAckWorker( is PairTherapyEvent -> { val pair = ack.originalObject - dataSyncSelector.confirmLastTherapyEventIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastTherapyEventIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked TherapyEvent " + ack._id)) // Send new if waiting dataSyncSelector.processChangedTherapyEventsCompat() @@ -82,7 +82,7 @@ class NSClientUpdateRemoveAckWorker( is PairBolus -> { val pair = ack.originalObject - dataSyncSelector.confirmLastBolusIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastBolusIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked Bolus " + ack._id)) // Send new if waiting dataSyncSelector.processChangedBolusesCompat() @@ -91,7 +91,7 @@ class NSClientUpdateRemoveAckWorker( is PairCarbs -> { val pair = ack.originalObject - dataSyncSelector.confirmLastCarbsIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastCarbsIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked Carbs " + ack._id)) // Send new if waiting dataSyncSelector.processChangedCarbsCompat() @@ -100,7 +100,7 @@ class NSClientUpdateRemoveAckWorker( is PairBolusCalculatorResult -> { val pair = ack.originalObject - dataSyncSelector.confirmLastBolusCalculatorResultsIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastBolusCalculatorResultsIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked BolusCalculatorResult " + ack._id)) // Send new if waiting dataSyncSelector.processChangedBolusCalculatorResultsCompat() @@ -109,7 +109,7 @@ class NSClientUpdateRemoveAckWorker( is PairTemporaryBasal -> { val pair = ack.originalObject - dataSyncSelector.confirmLastTemporaryBasalIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastTemporaryBasalIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked TemporaryBasal " + ack._id)) // Send new if waiting dataSyncSelector.processChangedTemporaryBasalsCompat() @@ -118,7 +118,7 @@ class NSClientUpdateRemoveAckWorker( is PairExtendedBolus -> { val pair = ack.originalObject - dataSyncSelector.confirmLastExtendedBolusIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastExtendedBolusIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked ExtendedBolus " + ack._id)) // Send new if waiting dataSyncSelector.processChangedExtendedBolusesCompat() @@ -127,7 +127,7 @@ class NSClientUpdateRemoveAckWorker( is PairProfileSwitch -> { val pair = ack.originalObject - dataSyncSelector.confirmLastProfileSwitchIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastProfileSwitchIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked ProfileSwitch " + ack._id)) // Send new if waiting dataSyncSelector.processChangedProfileSwitchesCompat() @@ -136,7 +136,7 @@ class NSClientUpdateRemoveAckWorker( is PairEffectiveProfileSwitch -> { val pair = ack.originalObject - dataSyncSelector.confirmLastEffectiveProfileSwitchIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastEffectiveProfileSwitchIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked EffectiveProfileSwitch " + ack._id)) // Send new if waiting dataSyncSelector.processChangedEffectiveProfileSwitchesCompat() @@ -145,7 +145,7 @@ class NSClientUpdateRemoveAckWorker( is PairOfflineEvent -> { val pair = ack.originalObject - dataSyncSelector.confirmLastOfflineEventIdIfGreater(pair.updateRecordId) + dataSyncSelector.confirmLastOfflineEventIdIfGreater(pair.id) rxBus.send(EventNSClientNewLog("DBUPDATE", "Acked OfflineEvent" + ack._id)) // Send new if waiting dataSyncSelector.processChangedOfflineEventsCompat() diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt index 9d2ac4c637..7c98627f2e 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/NSClientV3Plugin.kt @@ -11,11 +11,15 @@ import androidx.work.ExistingWorkPolicy import androidx.work.OneTimeWorkRequest import androidx.work.WorkInfo import androidx.work.WorkManager +import com.google.gson.Gson +import com.google.gson.GsonBuilder import dagger.android.HasAndroidInjector import info.nightscout.core.utils.fabric.FabricPrivacy +import info.nightscout.database.entities.interfaces.TraceableDBEntry import info.nightscout.interfaces.Config import info.nightscout.interfaces.Constants import info.nightscout.interfaces.nsclient.NSAlarm +import info.nightscout.interfaces.nsclient.StoreDataForDb import info.nightscout.interfaces.plugin.PluginBase import info.nightscout.interfaces.plugin.PluginDescription import info.nightscout.interfaces.plugin.PluginType @@ -71,7 +75,9 @@ class NSClientV3Plugin @Inject constructor( private val nsClientReceiverDelegate: NsClientReceiverDelegate, private val config: Config, private val dateUtil: DateUtil, - private val uiInteraction: UiInteraction + private val uiInteraction: UiInteraction, + private val storeDataForDb: StoreDataForDb, + private val dataSyncSelector: DataSyncSelector ) : NsClient, Sync, PluginBase( PluginDescription() .mainType(PluginType.SYNC) @@ -113,8 +119,8 @@ class NSClientV3Plugin @Inject constructor( val blockingReason get() = nsClientReceiverDelegate.blockingReason private val maxAge = T.days(77).msecs() - internal var lastModified: LastModified? = null // timestamp of last modification for every collection - internal var lastFetched = + internal var newestDataOnServer: LastModified? = null // timestamp of last modification for every collection + internal var lastLoadedSrvModified = LastModified( LastModified.Collections( dateUtil.now() - maxAge, @@ -128,7 +134,7 @@ class NSClientV3Plugin @Inject constructor( // context.bindService(Intent(context, NSClientService::class.java), mConnection, Context.BIND_AUTO_CREATE) super.onStart() - lastFetched = Json.decodeFromString( + lastLoadedSrvModified = Json.decodeFromString( sp.getString( R.string.key_ns_client_v3_last_modified, Json.encodeToString( @@ -137,10 +143,10 @@ class NSClientV3Plugin @Inject constructor( ) ) ) - lastFetched.collections.entries = max(dateUtil.now() - maxAge, lastFetched.collections.entries) - lastFetched.collections.treatments = max(dateUtil.now() - maxAge, lastFetched.collections.treatments) - lastFetched.collections.profile = max(dateUtil.now() - maxAge, lastFetched.collections.profile) - lastFetched.collections.devicestatus = max(dateUtil.now() - maxAge, lastFetched.collections.devicestatus) + lastLoadedSrvModified.collections.entries = max(dateUtil.now() - maxAge, lastLoadedSrvModified.collections.entries) + lastLoadedSrvModified.collections.treatments = max(dateUtil.now() - maxAge, lastLoadedSrvModified.collections.treatments) + lastLoadedSrvModified.collections.profile = max(dateUtil.now() - maxAge, lastLoadedSrvModified.collections.profile) + lastLoadedSrvModified.collections.devicestatus = max(dateUtil.now() - maxAge, lastLoadedSrvModified.collections.devicestatus) setClient() @@ -251,7 +257,7 @@ class NSClientV3Plugin @Inject constructor( } override fun resend(reason: String) { -// nsClientService?.resend(reason) + executeLoop() } override fun pause(newState: Boolean) { @@ -278,19 +284,19 @@ class NSClientV3Plugin @Inject constructor( } override fun updateLatestBgReceivedIfNewer(latestReceived: Long) { - if (latestReceived > lastFetched.collections.entries) { - lastFetched.collections.entries = latestReceived + if (latestReceived > lastLoadedSrvModified.collections.entries) { + lastLoadedSrvModified.collections.entries = latestReceived storeLastFetched() } } override fun updateLatestTreatmentReceivedIfNewer(latestReceived: Long) { - lastFetched.collections.treatments = latestReceived + lastLoadedSrvModified.collections.treatments = latestReceived storeLastFetched() } override fun resetToFullSync() { - lastFetched = LastModified( + lastLoadedSrvModified = LastModified( LastModified.Collections( dateUtil.now() - maxAge, dateUtil.now() - maxAge, @@ -302,6 +308,20 @@ class NSClientV3Plugin @Inject constructor( } override fun dbAdd(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) { + dbOperation(collection, dataPair, progress, Operation.CREATE) + } + + override fun dbUpdate(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) { + dbOperation(collection, dataPair, progress, Operation.UPDATE) + } + + enum class Operation { CREATE, UPDATE } + private val gson: Gson = GsonBuilder().create() + private fun dbOperation(collection: String, dataPair: DataSyncSelector.DataPair, progress: String, operation: Operation) { + val call = when(operation) { + Operation.CREATE -> nsAndroidClient::createTreatment + Operation.UPDATE -> nsAndroidClient::updateTreatment + } when (dataPair) { is DataSyncSelector.PairBolus -> dataPair.value.toNSBolus() // is DataSyncSelector.PairCarbs -> dataPair.value.toJson(false, dateUtil) @@ -319,18 +339,51 @@ class NSClientV3Plugin @Inject constructor( }?.let { data -> runBlocking { if (collection == "treatments") { - val result = nsAndroidClient.createTreatment(data) + try { + val id = if (dataPair.value is TraceableDBEntry) (dataPair.value as TraceableDBEntry).interfaceIDs.nightscoutId else "" + rxBus.send( + EventNSClientNewLog( + when(operation) { + Operation.CREATE -> "ADD $collection" + Operation.UPDATE -> "UPDATE $collection" + }, + when(operation) { + Operation.CREATE -> "Sent ${dataPair.javaClass.simpleName} ${gson.toJson(data)} $progress" + Operation.UPDATE -> "Sent ${dataPair.javaClass.simpleName} $id ${gson.toJson(data)} $progress" + } + ) + ) + val result = call(data) + when (dataPair) { + is DataSyncSelector.PairBolus -> { + if (result.response == 201) { // created + dataPair.value.interfaceIDs.nightscoutId = result.identifier + storeDataForDb.nsIdBoluses.add(dataPair.value) + storeDataForDb.scheduleNsIdUpdate() + } + dataSyncSelector.confirmLastBolusIdIfGreater(dataPair.id) + } + // is DataSyncSelector.PairCarbs -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairBolusCalculatorResult -> dataPair.value.toJson(false, dateUtil, profileFunction) + // is DataSyncSelector.PairTemporaryTarget -> dataPair.value.toJson(false, profileFunction.getUnits(), dateUtil) + // is DataSyncSelector.PairFood -> dataPair.value.toJson(false) + // is DataSyncSelector.PairGlucoseValue -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairTherapyEvent -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairTemporaryBasal -> dataPair.value.toJson(false, profileFunction.getProfile(dataPair.value.timestamp), dateUtil) + // is DataSyncSelector.PairExtendedBolus -> dataPair.value.toJson(false, profileFunction.getProfile(dataPair.value.timestamp), dateUtil) + // is DataSyncSelector.PairProfileSwitch -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairEffectiveProfileSwitch -> dataPair.value.toJson(false, dateUtil) + // is DataSyncSelector.PairOfflineEvent -> dataPair.value.toJson(false, dateUtil) + } + } catch (e: Exception) { + aapsLogger.error(LTag.NSCLIENT, "Upload exception", e) + } } } } } - - override fun dbUpdate(collection: String, dataPair: DataSyncSelector.DataPair, progress: String) { - TODO("Not yet implemented") - } - private fun storeLastFetched() { - sp.putString(R.string.key_ns_client_v3_last_modified, Json.encodeToString(LastModified.serializer(), lastFetched)) + sp.putString(R.string.key_ns_client_v3_last_modified, Json.encodeToString(LastModified.serializer(), lastLoadedSrvModified)) } fun test() { @@ -338,7 +391,7 @@ class NSClientV3Plugin @Inject constructor( } fun scheduleNewExecution() { - val toTime = lastFetched.collections.entries + T.mins(6).plus(T.secs(0)).msecs() + val toTime = lastLoadedSrvModified.collections.entries + T.mins(6).plus(T.secs(0)).msecs() if (toTime > dateUtil.now()) { handler.postDelayed({ executeLoop() }, toTime - dateUtil.now()) rxBus.send(EventNSClientNewLog("NEXT", dateUtil.dateAndTimeAndSecondsString(toTime))) @@ -366,8 +419,10 @@ class NSClientV3Plugin @Inject constructor( ) .then(OneTimeWorkRequest.Builder(LoadLastModificationWorker::class.java).build()) .then(OneTimeWorkRequest.Builder(LoadBgWorker::class.java).build()) - // LoadTreatmentsWorker is enqueued after BG finish - //.then(OneTimeWorkRequest.Builder(LoadTreatmentsWorker::class.java).build()) + // Other Workers are enqueued after BG finish + // LoadTreatmentsWorker + // LoadDeviceStatusWorker + // DataSyncWorker .enqueue() } } diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/DataSyncWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/DataSyncWorker.kt new file mode 100644 index 0000000000..dcd0f6dcef --- /dev/null +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/DataSyncWorker.kt @@ -0,0 +1,21 @@ +package info.nightscout.plugins.sync.nsclientV3.workers + +import android.content.Context +import androidx.work.WorkerParameters +import info.nightscout.core.utils.worker.LoggingWorker +import info.nightscout.interfaces.plugin.ActivePlugin +import info.nightscout.interfaces.sync.DataSyncSelector +import javax.inject.Inject + +class DataSyncWorker( + context: Context, params: WorkerParameters +) : LoggingWorker(context, params) { + + @Inject lateinit var dataSyncSelector: DataSyncSelector + @Inject lateinit var activePlugin: ActivePlugin + + override fun doWorkAndLog(): Result { + if (activePlugin.activeNsClient?.hasWritePermission == true) dataSyncSelector.doUpload() + return Result.success() + } +} \ No newline at end of file diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadBgWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadBgWorker.kt index 99b9cbed8c..f381913e58 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadBgWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadBgWorker.kt @@ -39,16 +39,16 @@ class LoadBgWorker( var ret = Result.success() runBlocking { - if ((nsClientV3Plugin.lastModified?.collections?.entries ?: Long.MAX_VALUE) > nsClientV3Plugin.lastFetched.collections.entries) + if ((nsClientV3Plugin.newestDataOnServer?.collections?.entries ?: Long.MAX_VALUE) > nsClientV3Plugin.lastLoadedSrvModified.collections.entries) try { //val sgvs = nsClientV3Plugin.nsAndroidClient.getSgvsModifiedSince(nsClientV3Plugin.lastFetched.collections.entries) - val sgvs = nsClientV3Plugin.nsAndroidClient.getSgvsNewerThan(nsClientV3Plugin.lastFetched.collections.entries, 500) + val sgvs = nsClientV3Plugin.nsAndroidClient.getSgvsNewerThan(nsClientV3Plugin.lastLoadedSrvModified.collections.entries, 500) aapsLogger.debug("SGVS: $sgvs") if (sgvs.isNotEmpty()) { rxBus.send( EventNSClientNewLog( "RCV", - "${sgvs.size} SVGs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastFetched.collections.entries)}" + "${sgvs.size} SVGs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastLoadedSrvModified.collections.entries)}" ) ) // Objective0 @@ -60,7 +60,7 @@ class LoadBgWorker( OneTimeWorkRequest.Builder(workerClasses.nsClientSourceWorker).setInputData(dataWorkerStorage.storeInputData(sgvs)).build() ).then(OneTimeWorkRequest.Builder(LoadBgWorker::class.java).build()).enqueue() } else { - rxBus.send(EventNSClientNewLog("END", "No SGVs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastFetched.collections.entries)}")) + rxBus.send(EventNSClientNewLog("END", "No SGVs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastLoadedSrvModified.collections.entries)}")) WorkManager.getInstance(context) .beginUniqueWork( NSClientV3Plugin.JOB_NAME, @@ -75,7 +75,7 @@ class LoadBgWorker( ret = Result.failure(workDataOf("Error" to error.toString())) } else { - rxBus.send(EventNSClientNewLog("END", "No new SGVs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastFetched.collections.entries)}")) + rxBus.send(EventNSClientNewLog("END", "No new SGVs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastLoadedSrvModified.collections.entries)}")) nsClientV3Plugin.scheduleNewExecution() // Idea is to run after 5 min after last BG WorkManager.getInstance(context) .beginUniqueWork( diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadDeviceStatusWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadDeviceStatusWorker.kt index 693ea1374a..80d2cc4661 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadDeviceStatusWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadDeviceStatusWorker.kt @@ -1,6 +1,9 @@ package info.nightscout.plugins.sync.nsclientV3.workers import android.content.Context +import androidx.work.ExistingWorkPolicy +import androidx.work.OneTimeWorkRequest +import androidx.work.WorkManager import androidx.work.WorkerParameters import androidx.work.workDataOf import info.nightscout.core.utils.receivers.DataWorkerStorage @@ -40,6 +43,12 @@ class LoadDeviceStatusWorker( } else { rxBus.send(EventNSClientNewLog("END", "No DSs from ${dateUtil.dateAndTimeAndSecondsString(from)}")) } + WorkManager.getInstance(context) + .enqueueUniqueWork( + NSClientV3Plugin.JOB_NAME, + ExistingWorkPolicy.APPEND_OR_REPLACE, + OneTimeWorkRequest.Builder(DataSyncWorker::class.java).build() + ) } catch (error: Exception) { aapsLogger.error("Error: ", error) ret = Result.failure(workDataOf("Error" to error.toString())) diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadLastModificationWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadLastModificationWorker.kt index 1dbf94d6a7..8c897985e0 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadLastModificationWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadLastModificationWorker.kt @@ -20,8 +20,8 @@ class LoadLastModificationWorker( runBlocking { try { val lm = nsClientV3Plugin.nsAndroidClient.getLastModified() - nsClientV3Plugin.lastModified = lm - aapsLogger.debug("LAST MODIFIED: ${nsClientV3Plugin.lastModified}") + nsClientV3Plugin.newestDataOnServer = lm + aapsLogger.debug("LAST MODIFIED: ${nsClientV3Plugin.newestDataOnServer}") } catch (error: Exception) { aapsLogger.error("Error: ", error) ret = Result.failure(workDataOf("Error" to error.toString())) diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadTreatmentsWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadTreatmentsWorker.kt index 70ec2be334..39dd4663de 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadTreatmentsWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/LoadTreatmentsWorker.kt @@ -32,15 +32,15 @@ class LoadTreatmentsWorker( var ret = Result.success() runBlocking { - if ((nsClientV3Plugin.lastModified?.collections?.treatments ?: Long.MAX_VALUE) > nsClientV3Plugin.lastFetched.collections.treatments) + if ((nsClientV3Plugin.newestDataOnServer?.collections?.treatments ?: Long.MAX_VALUE) > nsClientV3Plugin.lastLoadedSrvModified.collections.treatments) try { - val treatments = nsClientV3Plugin.nsAndroidClient.getTreatmentsModifiedSince(nsClientV3Plugin.lastFetched.collections.treatments, 500) + val treatments = nsClientV3Plugin.nsAndroidClient.getTreatmentsModifiedSince(nsClientV3Plugin.lastLoadedSrvModified.collections.treatments, 500) aapsLogger.debug("TREATMENTS: $treatments") - if (treatments.isNotEmpty()) { + if (treatments.values.isNotEmpty()) { rxBus.send( EventNSClientNewLog( "RCV", - "${treatments.size} TRs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastFetched.collections.treatments)}" + "${treatments.values.size} TRs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastLoadedSrvModified.collections.treatments)}" ) ) // Schedule processing of fetched data and continue of loading @@ -56,7 +56,7 @@ class LoadTreatmentsWorker( } else { rxBus.send( EventNSClientNewLog( - "END", "No TRs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastFetched.collections.treatments)}" + "END", "No TRs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastLoadedSrvModified.collections.treatments)}" ) ) storeDataForDb.storeTreatmentsToDb() @@ -72,7 +72,7 @@ class LoadTreatmentsWorker( ret = Result.failure(workDataOf("Error" to error.toString())) } else { - rxBus.send(EventNSClientNewLog("END", "No new TRs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastFetched.collections.treatments)}")) + rxBus.send(EventNSClientNewLog("END", "No new TRs from ${dateUtil.dateAndTimeAndSecondsString(nsClientV3Plugin.lastLoadedSrvModified.collections.treatments)}")) storeDataForDb.storeTreatmentsToDb() WorkManager.getInstance(context) .enqueueUniqueWork( diff --git a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/ProcessTreatmentsWorker.kt b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/ProcessTreatmentsWorker.kt index 2d433f5845..6859805e5d 100644 --- a/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/ProcessTreatmentsWorker.kt +++ b/plugins/sync/src/main/java/info/nightscout/plugins/sync/nsclientV3/workers/ProcessTreatmentsWorker.kt @@ -25,6 +25,7 @@ import info.nightscout.plugins.sync.nsclientV3.extensions.toTemporaryTarget import info.nightscout.plugins.sync.nsclientV3.extensions.toTherapyEvent import info.nightscout.rx.bus.RxBus import info.nightscout.rx.logging.LTag +import info.nightscout.sdk.interfaces.NSAndroidClient import info.nightscout.sdk.localmodel.treatment.NSBolus import info.nightscout.sdk.localmodel.treatment.NSBolusWizard import info.nightscout.sdk.localmodel.treatment.NSCarbs @@ -58,20 +59,15 @@ class ProcessTreatmentsWorker( override fun doWorkAndLog(): Result { @Suppress("UNCHECKED_CAST") - val treatments = dataWorkerStorage.pickupObject(inputData.getLong(DataWorkerStorage.STORE_KEY, -1)) as List? + val treatments = dataWorkerStorage.pickupObject(inputData.getLong(DataWorkerStorage.STORE_KEY, -1)) as NSAndroidClient.ReadResponse>? ?: return Result.failure(workDataOf("Error" to "missing input data")) val ret = Result.success() - var latestDateInReceivedData = 0L - - for (treatment in treatments) { + for (treatment in treatments.values) { aapsLogger.debug(LTag.DATABASE, "Received NS treatment: $treatment") //Find latest date in treatment val mills = treatment.date - if (mills != 0L && mills < dateUtil.now()) - if (mills > latestDateInReceivedData) latestDateInReceivedData = mills - when (treatment) { is NSBolus -> if (sp.getBoolean(info.nightscout.core.utils.R.string.key_ns_receive_insulin, false) || config.NSCLIENT) @@ -140,7 +136,7 @@ class ProcessTreatmentsWorker( } } } - activePlugin.activeNsClient?.updateLatestTreatmentReceivedIfNewer(latestDateInReceivedData) + activePlugin.activeNsClient?.updateLatestTreatmentReceivedIfNewer(treatments.lastServerModified) // xDripBroadcast.sendTreatments(treatments) return ret }