diff options
author | Matthew Wong <mawong@redhat.com> | 2016-12-26 05:19:49 -0500 |
---|---|---|
committer | Matthew Wong <mawong@redhat.com> | 2016-12-26 05:19:49 -0500 |
commit | 57be6f5e14925bae9f8b0b01c9aebe9f4592e1f2 (patch) | |
tree | 7f7e7765d96f564f7b54946b33ac47104429d213 | |
parent | 0a050bbe03f1c864a53c1c0167e5f7794c910e43 (diff) |
Fix #247: avoid npe getting accessibility event package name
-rw-r--r-- | app/src/main/java/com/zeapo/pwdstore/autofill/AutofillService.java | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/app/src/main/java/com/zeapo/pwdstore/autofill/AutofillService.java b/app/src/main/java/com/zeapo/pwdstore/autofill/AutofillService.java index 58bbbe4c..f4bbddc4 100644 --- a/app/src/main/java/com/zeapo/pwdstore/autofill/AutofillService.java +++ b/app/src/main/java/com/zeapo/pwdstore/autofill/AutofillService.java @@ -97,7 +97,8 @@ public class AutofillService extends AccessibilityService { // if returning to the source app from a successful AutofillActivity if (event.getEventType() == AccessibilityEvent.TYPE_WINDOW_STATE_CHANGED - && event.getPackageName().equals(packageName) && resultData != null) { + && event.getPackageName() != null && event.getPackageName().equals(packageName) + && resultData != null) { bindDecryptAndVerify(); } @@ -105,9 +106,9 @@ public class AutofillService extends AccessibilityService { // or if page changes in chrome if (event.getEventType() == AccessibilityEvent.TYPE_WINDOW_STATE_CHANGED || (event.getEventType() == AccessibilityEvent.TYPE_WINDOW_CONTENT_CHANGED - && event.getSource() != null && event.getSource().getPackageName() != null - && (event.getSource().getPackageName().equals("com.android.chrome") - || event.getSource().getPackageName().equals("com.android.browser")))) { + && event.getPackageName() != null + && (event.getPackageName().equals("com.android.chrome") + || event.getPackageName().equals("com.android.browser")))) { // there is a chance for getRootInActiveWindow() to return null at any time. save it. AccessibilityNodeInfo root = getRootInActiveWindow(); webViewTitle = searchWebView(root); @@ -136,8 +137,8 @@ public class AutofillService extends AccessibilityService { // nothing to do if not password field focus, field is keychain app if (!event.isPassword() || event.getEventType() == AccessibilityEvent.TYPE_WINDOW_CONTENT_CHANGED - || event.getPackageName().equals("org.sufficientlysecure.keychain") - || event.getPackageName().equals("com.android.systemui")) { + || event.getPackageName() != null && event.getPackageName().equals("org.sufficientlysecure.keychain") + || event.getPackageName() != null && event.getPackageName().equals("com.android.systemui")) { dismissDialog(event); return; } |