aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain/src/main
diff options
context:
space:
mode:
authorNikita Mikhailov <nikita.s.mikhailov@gmail.com>2016-04-10 23:44:52 +0600
committerNikita Mikhailov <nikita.s.mikhailov@gmail.com>2016-04-14 22:48:01 +0600
commit4e543e5368ae37afd474ebf0f04bd869d12be755 (patch)
tree0f577383a2540d394c6227d03bcfca6feab17fe6 /OpenKeychain/src/main
parent8cb94c446bf1d490978cfe49adcefb29d2fbca5b (diff)
downloadopen-keychain-4e543e5368ae37afd474ebf0f04bd869d12be755.tar.gz
open-keychain-4e543e5368ae37afd474ebf0f04bd869d12be755.tar.bz2
open-keychain-4e543e5368ae37afd474ebf0f04bd869d12be755.zip
OTG: rescan devices before next operation
Diffstat (limited to 'OpenKeychain/src/main')
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/smartcard/UsbTransport.java14
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/base/BaseSecurityTokenNfcActivity.java10
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/UsbConnectionDispatcher.java53
3 files changed, 58 insertions, 19 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/smartcard/UsbTransport.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/smartcard/UsbTransport.java
index 43496b31c..8d661b9fa 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/smartcard/UsbTransport.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/smartcard/UsbTransport.java
@@ -130,9 +130,13 @@ public class UsbTransport implements Transport {
*/
@Override
public void release() {
- mConnection.releaseInterface(mUsbInterface);
- mConnection.close();
- mConnection = null;
+ if (mConnection != null) {
+ mConnection.releaseInterface(mUsbInterface);
+ mConnection.close();
+ mConnection = null;
+ }
+
+ Log.d(Constants.TAG, "Usb transport disconnected");
}
/**
@@ -292,4 +296,8 @@ public class UsbTransport implements Transport {
public int hashCode() {
return mUsbDevice != null ? mUsbDevice.hashCode() : 0;
}
+
+ public UsbDevice getUsbDevice() {
+ return mUsbDevice;
+ }
}
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/base/BaseSecurityTokenNfcActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/base/BaseSecurityTokenNfcActivity.java
index c8022a776..5ad542526 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/base/BaseSecurityTokenNfcActivity.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/base/BaseSecurityTokenNfcActivity.java
@@ -24,7 +24,6 @@ package org.sufficientlysecure.keychain.ui.base;
import android.app.Activity;
import android.content.Intent;
import android.content.pm.PackageManager;
-import android.hardware.usb.UsbDevice;
import android.hardware.usb.UsbManager;
import android.nfc.NfcAdapter;
import android.nfc.Tag;
@@ -144,13 +143,12 @@ public abstract class BaseSecurityTokenNfcActivity extends BaseActivity
smartcardDiscovered(new NfcTransport(tag));
}
- public void usbDeviceDiscovered(final UsbDevice device) {
+ public void usbDeviceDiscovered(final UsbTransport transport) {
// Actual USB operations are executed in doInBackground to not block the UI thread
if (!mTagHandlingEnabled)
return;
- UsbManager usbManager = (UsbManager) getSystemService(USB_SERVICE);
- smartcardDiscovered(new UsbTransport(device, usbManager));
+ smartcardDiscovered(transport);
}
public void smartcardDiscovered(final Transport transport) {
@@ -481,8 +479,6 @@ public abstract class BaseSecurityTokenNfcActivity extends BaseActivity
* persistent connections
*/
protected void checkDeviceConnection() {
- if (mSmartcardDevice.isConnected() && mSmartcardDevice.isPersistentConnectionAllowed()) {
- this.smartcardDiscovered(mSmartcardDevice.getTransport());
- }
+ mUsbDispatcher.rescanDevices();
}
}
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/UsbConnectionDispatcher.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/UsbConnectionDispatcher.java
index 697db0811..09b029523 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/UsbConnectionDispatcher.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/UsbConnectionDispatcher.java
@@ -26,13 +26,15 @@ import android.hardware.usb.UsbDevice;
import android.hardware.usb.UsbManager;
import org.sufficientlysecure.keychain.Constants;
+import org.sufficientlysecure.keychain.smartcard.UsbTransport;
import org.sufficientlysecure.keychain.ui.UsbEventReceiverActivity;
-import org.sufficientlysecure.keychain.util.Log;
public class UsbConnectionDispatcher {
private Activity mActivity;
private OnDiscoveredUsbDeviceListener mListener;
+ private UsbTransport mLastUsedUsbTransport;
+ private UsbManager mUsbManager;
/**
* Receives broadcast when a supported USB device get permission.
*/
@@ -41,13 +43,27 @@ public class UsbConnectionDispatcher {
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
- if (UsbEventReceiverActivity.ACTION_USB_PERMISSION.equals(action)) {
- UsbDevice usbDevice = intent.getParcelableExtra(UsbManager.EXTRA_DEVICE);
- boolean permission = intent.getBooleanExtra(UsbManager.EXTRA_PERMISSION_GRANTED,
- false);
- if (permission) {
- Log.d(Constants.TAG, "Got permission for " + usbDevice.getDeviceName());
- mListener.usbDeviceDiscovered(usbDevice);
+ switch (action) {
+ case UsbEventReceiverActivity.ACTION_USB_PERMISSION: {
+ UsbDevice usbDevice = intent.getParcelableExtra(UsbManager.EXTRA_DEVICE);
+ boolean permission = intent.getBooleanExtra(UsbManager.EXTRA_PERMISSION_GRANTED,
+ false);
+ if (permission) {
+ Log.d(Constants.TAG, "Got permission for " + usbDevice.getDeviceName());
+
+ mLastUsedUsbTransport = new UsbTransport(usbDevice, mUsbManager);
+ mListener.usbDeviceDiscovered(mLastUsedUsbTransport);
+ }
+ break;
+ }
+ case UsbManager.ACTION_USB_DEVICE_DETACHED: {
+ UsbDevice usbDevice = intent.getParcelableExtra(UsbManager.EXTRA_DEVICE);
+
+ if (mLastUsedUsbTransport != null && mLastUsedUsbTransport.getUsbDevice().equals(usbDevice)) {
+ mLastUsedUsbTransport.release();
+ mLastUsedUsbTransport = null;
+ }
+ break;
}
}
}
@@ -56,11 +72,13 @@ public class UsbConnectionDispatcher {
public UsbConnectionDispatcher(final Activity activity, final OnDiscoveredUsbDeviceListener listener) {
this.mActivity = activity;
this.mListener = listener;
+ this.mUsbManager = (UsbManager) activity.getSystemService(Context.USB_SERVICE);
}
public void onStart() {
final IntentFilter intentFilter = new IntentFilter();
intentFilter.addAction(UsbEventReceiverActivity.ACTION_USB_PERMISSION);
+ intentFilter.addAction(UsbManager.ACTION_USB_DEVICE_DETACHED);
mActivity.registerReceiver(mUsbReceiver, intentFilter);
}
@@ -69,7 +87,24 @@ public class UsbConnectionDispatcher {
mActivity.unregisterReceiver(mUsbReceiver);
}
+ /**
+ * Rescans devices and triggers {@link OnDiscoveredUsbDeviceListener}
+ */
+ public void rescanDevices() {
+ // Note: we don't check devices VID/PID because
+ // we check for permisssion instead.
+ // We should have permission only for matching devices
+ for (UsbDevice device : mUsbManager.getDeviceList().values()) {
+ if (mUsbManager.hasPermission(device)) {
+ if (mListener != null) {
+ mListener.usbDeviceDiscovered(new UsbTransport(device, mUsbManager));
+ }
+ break;
+ }
+ }
+ }
+
public interface OnDiscoveredUsbDeviceListener {
- void usbDeviceDiscovered(UsbDevice usbDevice);
+ void usbDeviceDiscovered(UsbTransport usbTransport);
}
}