From b41495c2b85bf53f60ea2020950d610d4dc65e87 Mon Sep 17 00:00:00 2001 From: Daniel Dakhno Date: Tue, 11 Feb 2020 00:20:11 +0100 Subject: [PATCH] device should not connect with invalid key anymore --- .../adapter/fossil/FossilWatchAdapter.java | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/qhybrid/adapter/fossil/FossilWatchAdapter.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/qhybrid/adapter/fossil/FossilWatchAdapter.java index 66dc818a2..4f8ff123b 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/qhybrid/adapter/fossil/FossilWatchAdapter.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/qhybrid/adapter/fossil/FossilWatchAdapter.java @@ -132,6 +132,11 @@ public class FossilWatchAdapter extends WatchAdapter { @Override public void onCharacteristicWrite(BluetoothGatt gatt, BluetoothGattCharacteristic characteristic, int status) { if(status != BluetoothGatt.GATT_SUCCESS){ + if(characteristic.getUuid().toString().equals("3dda0005-957f-7d4a-34a6-74696673696d")){ + GB.log("authentication failed", GB.ERROR, null); + setDeviceState(GBDevice.State.AUTHENTICATION_REQUIRED); + requestQueue.clear(); + } log("characteristic write failed: " + status); fossilRequest = null; @@ -483,8 +488,9 @@ public class FossilWatchAdapter extends WatchAdapter { fossilRequest.handleResponse(characteristic); requestFinished = fossilRequest.isFinished(); } catch (RuntimeException e) { - if(fossilRequest instanceof VerifyPrivateKeyRequest){ - getDeviceSupport().getDevice().setState(GBDevice.State.AUTHENTICATION_REQUIRED); + if(characteristic.getUuid().toString().equals("3dda0005-957f-7d4a-34a6-74696673696d")){ + GB.log("authentication failed", GB.ERROR, null); + setDeviceState(GBDevice.State.AUTHENTICATION_REQUIRED); requestQueue.clear(); } @@ -608,11 +614,15 @@ public class FossilWatchAdapter extends WatchAdapter { return; } log("setting device state: " + request.getDeviceState()); - getDeviceSupport().getDevice().setState(request.getDeviceState()); - getDeviceSupport().getDevice().sendDeviceUpdateIntent(getContext()); + setDeviceState(request.getDeviceState()); queueNextRequest(); } + private void setDeviceState(GBDevice.State state){ + getDeviceSupport().getDevice().setState(state); + getDeviceSupport().getDevice().sendDeviceUpdateIntent(getContext()); + } + public void queueWrite(FossilRequest request, boolean priorise) { log("is connected: " + getDeviceSupport().isConnected()); if(!getDeviceSupport().isConnected()){