better check for RS v3 failed encryption
This commit is contained in:
parent
4bacfad0db
commit
272f91d90b
2 changed files with 16 additions and 14 deletions
|
@ -21,6 +21,7 @@ import info.nightscout.androidaps.danars.activities.EnterPinActivity
|
|||
import info.nightscout.androidaps.danars.activities.PairingHelperActivity
|
||||
import info.nightscout.androidaps.danars.comm.DanaRSMessageHashTable
|
||||
import info.nightscout.androidaps.danars.comm.DanaRS_Packet
|
||||
import info.nightscout.androidaps.danars.comm.DanaRS_Packet_Etc_Keep_Connection
|
||||
import info.nightscout.androidaps.danars.encryption.BleEncryption
|
||||
import info.nightscout.androidaps.danars.events.EventDanaRSPairingSuccess
|
||||
import info.nightscout.androidaps.utils.T
|
||||
|
@ -131,6 +132,7 @@ class BLEComm @Inject internal constructor(
|
|||
if (!encryptedDataRead && encryptedCommandSent && v3Encryption) {
|
||||
// there was no response from pump after started encryption
|
||||
// assume pairing keys are invalid
|
||||
aapsLogger.error("Clearing pairing keys !!!")
|
||||
sp.remove(resourceHelper.gs(R.string.key_danars_v3_randompairingkey) + danaRSPlugin.mDeviceName)
|
||||
sp.remove(resourceHelper.gs(R.string.key_danars_v3_pairingkey) + danaRSPlugin.mDeviceName)
|
||||
sp.remove(resourceHelper.gs(R.string.key_danars_v3_randomsynckey) + danaRSPlugin.mDeviceName)
|
||||
|
@ -705,6 +707,9 @@ class BLEComm @Inject internal constructor(
|
|||
aapsLogger.warn(LTag.PUMPBTCOMM, "Reply not received " + message.friendlyName)
|
||||
message.handleMessageNotReceived()
|
||||
}
|
||||
// verify encryption for v3
|
||||
if (message is DanaRS_Packet_Etc_Keep_Connection)
|
||||
if (!message.isReceived) disconnect("KeepAlive not received")
|
||||
}
|
||||
|
||||
// process common packet response
|
||||
|
|
|
@ -116,8 +116,8 @@ class DanaRSService : DaggerService() {
|
|||
try {
|
||||
val now = System.currentTimeMillis()
|
||||
val pump = activePlugin.activePump
|
||||
if (danaPump.lastSettingsRead + 60 * 60 * 1000L < now || !pump.isInitialized) {
|
||||
rxBus.send(EventPumpStatusChanged(resourceHelper.gs(R.string.gettingpumpsettings)))
|
||||
sendMessage(DanaRS_Packet_Etc_Keep_Connection(injector)) // test encryption for v3
|
||||
sendMessage(DanaRS_Packet_General_Get_Shipping_Information(injector)) // serial no
|
||||
sendMessage(DanaRS_Packet_General_Get_Pump_Check(injector)) // firmware
|
||||
sendMessage(DanaRS_Packet_Basal_Get_Profile_Number(injector))
|
||||
|
@ -127,8 +127,6 @@ class DanaRSService : DaggerService() {
|
|||
if (danaPump.profile24) sendMessage(DanaRS_Packet_Bolus_Get_24_CIR_CF_Array(injector))
|
||||
else sendMessage(DanaRS_Packet_Bolus_Get_CIR_CF_Array(injector))
|
||||
sendMessage(DanaRS_Packet_Option_Get_User_Option(injector)) // Getting user options
|
||||
danaPump.lastSettingsRead = now
|
||||
}
|
||||
rxBus.send(EventPumpStatusChanged(resourceHelper.gs(R.string.gettingpumpstatus)))
|
||||
sendMessage(DanaRS_Packet_General_Initial_Screen_Information(injector))
|
||||
rxBus.send(EventPumpStatusChanged(resourceHelper.gs(R.string.gettingextendedbolusstatus)))
|
||||
|
@ -414,7 +412,6 @@ class DanaRSService : DaggerService() {
|
|||
sendMessage(msgSet)
|
||||
val msgActivate = DanaRS_Packet_Basal_Set_Profile_Number(injector, 0)
|
||||
sendMessage(msgActivate)
|
||||
danaPump.lastSettingsRead = 0 // force read full settings
|
||||
readPumpStatus()
|
||||
rxBus.send(EventPumpStatusChanged(EventPumpStatusChanged.Status.DISCONNECTING))
|
||||
return true
|
||||
|
|
Loading…
Reference in a new issue