From af1d505e360ecfaf0163d945fc69bf3702c6e386 Mon Sep 17 00:00:00 2001 From: Andrei Vereha Date: Thu, 25 Feb 2021 19:19:06 +0100 Subject: [PATCH] ble: - address review comments: renames and removed unused vars - implement serialization for BlePackets - improve logging, add .toHex() where we have []byte ``` INFO[0009] Received SP1 SP2 payload 5350313d0004024200032c5350323d000bffc32dbd20030e01000016 TRAC[0009] Read field: SP1= :: 02420003 :: 4 TRAC[0009] Read field: ,SP2= :: ffc32dbd20030e01000016 :: 11 INFO[0009] Received SP1 SP2: 02420003 :: ffc32dbd20030e01000016 ``` --- .../driver/comm/callbacks/BleCommCallbacks.kt | 11 ++--- .../pump/omnipod/dash/driver/comm/io/BleIO.kt | 4 +- .../dash/driver/comm/io/PayloadJoiner.kt | 1 - .../dash/driver/comm/io/PayloadSplitter.kt | 2 +- .../dash/driver/comm/ltk/LTKExchanger.kt | 2 +- .../dash/driver/comm/message/Message.kt | 6 +-- .../dash/driver/comm/message/MessageIO.kt | 10 ++--- .../dash/driver/comm/packet/BlePacket.kt | 40 ++++++++++++++++--- .../action/DashInitializePodViewModel.kt | 6 ++- 9 files changed, 58 insertions(+), 24 deletions(-) diff --git a/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/callbacks/BleCommCallbacks.kt b/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/callbacks/BleCommCallbacks.kt index 491f26c326..5580ef31ca 100644 --- a/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/callbacks/BleCommCallbacks.kt +++ b/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/callbacks/BleCommCallbacks.kt @@ -11,6 +11,7 @@ import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.comm.io.Chara import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.comm.io.CharacteristicType.Companion.byValue import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.comm.exceptions.CouldNotConfirmDescriptorWriteException import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.comm.exceptions.CouldNotConfirmWriteException +import info.nightscout.androidaps.utils.extensions.toHex import java.util.concurrent.BlockingQueue import java.util.concurrent.CountDownLatch import java.util.concurrent.LinkedBlockingQueue @@ -63,10 +64,10 @@ class BleCommCallbacks(private val aapsLogger: AAPSLogger, private val incomingP private fun confirmWritePayload(expectedPayload: ByteArray, received: CharacteristicWriteConfirmationPayload) { if (!expectedPayload.contentEquals(received.payload)) { - aapsLogger.warn(LTag.PUMPBTCOMM, "Could not confirm write. Got " + received.payload + ".Excepted: " + expectedPayload) + aapsLogger.warn(LTag.PUMPBTCOMM, "Could not confirm write. Got " + received.payload.toHex() + ".Excepted: " + expectedPayload.toHex()) throw CouldNotConfirmWriteException(expectedPayload, received.payload) } - aapsLogger.debug(LTag.PUMPBTCOMM, "Confirmed write with value: " + received.payload) + aapsLogger.debug(LTag.PUMPBTCOMM, "Confirmed write with value: " + received.payload.toHex()) } override fun onCharacteristicWrite(gatt: BluetoothGatt, characteristic: BluetoothGattCharacteristic, status: Int) { @@ -77,7 +78,7 @@ class BleCommCallbacks(private val aapsLogger: AAPSLogger, private val incomingP CharacteristicWriteConfirmationError(status) } aapsLogger.debug(LTag.PUMPBTCOMM, "OnCharacteristicWrite with status/char/value " + - status + "/" + byValue(characteristic.uuid.toString()) + "/" + characteristic.value) + status + "/" + byValue(characteristic.uuid.toString()) + "/" + characteristic.value.toHex()) try { if (writeQueue.size > 0) { aapsLogger.warn(LTag.PUMPBTCOMM, "Write confirm queue should be empty. found: " + writeQueue.size) @@ -98,7 +99,7 @@ class BleCommCallbacks(private val aapsLogger: AAPSLogger, private val incomingP val characteristicType = byValue(characteristic.uuid.toString()) aapsLogger.debug(LTag.PUMPBTCOMM, "OnCharacteristicChanged with char/value " + characteristicType + "/" + - payload) + payload.toHex()) incomingPackets[characteristicType]!!.add(payload) } @@ -120,7 +121,7 @@ class BleCommCallbacks(private val aapsLogger: AAPSLogger, private val incomingP override fun onDescriptorWrite(gatt: BluetoothGatt, descriptor: BluetoothGattDescriptor, status: Int) { super.onDescriptorWrite(gatt, descriptor, status) val writeConfirmation = if (status == BluetoothGatt.GATT_SUCCESS) { - aapsLogger.debug(LTag.PUMPBTCOMM, "OnDescriptor value " + descriptor.value) + aapsLogger.debug(LTag.PUMPBTCOMM, "OnDescriptor value " + descriptor.value.toHex()) DescriptorWriteConfirmationUUID(descriptor.uuid.toString()) } else { DescriptorWriteConfirmationError(status) diff --git a/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/io/BleIO.kt b/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/io/BleIO.kt index c1f2c89aef..a763193b77 100644 --- a/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/io/BleIO.kt +++ b/omnipod-dash/src/main/java/info/nightscout/androidaps/plugins/pump/omnipod/dash/driver/comm/io/BleIO.kt @@ -7,6 +7,7 @@ import info.nightscout.androidaps.logging.AAPSLogger import info.nightscout.androidaps.logging.LTag import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.comm.callbacks.BleCommCallbacks import info.nightscout.androidaps.plugins.pump.omnipod.dash.driver.comm.exceptions.* +import info.nightscout.androidaps.utils.extensions.toHex import java.util.concurrent.BlockingQueue import java.util.concurrent.TimeUnit import java.util.concurrent.TimeoutException @@ -48,7 +49,8 @@ class BleIO(private val aapsLogger: AAPSLogger, private val chars: Map