summaryrefslogtreecommitdiff
path: root/services/accessibility
diff options
context:
space:
mode:
Diffstat (limited to 'services/accessibility')
-rw-r--r--services/accessibility/java/com/android/server/accessibility/AbstractAccessibilityServiceConnection.java22
1 files changed, 9 insertions, 13 deletions
diff --git a/services/accessibility/java/com/android/server/accessibility/AbstractAccessibilityServiceConnection.java b/services/accessibility/java/com/android/server/accessibility/AbstractAccessibilityServiceConnection.java
index aae8879e9199..4e0db2282ffd 100644
--- a/services/accessibility/java/com/android/server/accessibility/AbstractAccessibilityServiceConnection.java
+++ b/services/accessibility/java/com/android/server/accessibility/AbstractAccessibilityServiceConnection.java
@@ -16,6 +16,7 @@
package com.android.server.accessibility;
+import static android.Manifest.permission.ACCESSIBILITY_MOTION_EVENT_OBSERVING;
import static android.accessibilityservice.AccessibilityService.ACCESSIBILITY_TAKE_SCREENSHOT_REQUEST_INTERVAL_TIMES_MS;
import static android.accessibilityservice.AccessibilityService.KEY_ACCESSIBILITY_SCREENSHOT_COLORSPACE;
import static android.accessibilityservice.AccessibilityService.KEY_ACCESSIBILITY_SCREENSHOT_HARDWAREBUFFER;
@@ -420,19 +421,7 @@ abstract class AbstractAccessibilityServiceConnection extends IAccessibilityServ
mNotificationTimeout = info.notificationTimeout;
mIsDefault = (info.flags & DEFAULT) != 0;
mGenericMotionEventSources = info.getMotionEventSources();
- if (android.view.accessibility.Flags.motionEventObserving()) {
- if (mContext.checkCallingOrSelfPermission(
- android.Manifest.permission.ACCESSIBILITY_MOTION_EVENT_OBSERVING)
- == PackageManager.PERMISSION_GRANTED) {
- mObservedMotionEventSources = info.getObservedMotionEventSources();
- } else {
- Slog.e(
- LOG_TAG,
- "Observing motion events requires"
- + " android.Manifest.permission.ACCESSIBILITY_MOTION_EVENT_OBSERVING.");
- mObservedMotionEventSources = 0;
- }
- }
+ mObservedMotionEventSources = info.getObservedMotionEventSources();
if (supportsFlagForNotImportantViews(info)) {
if ((info.flags & AccessibilityServiceInfo.FLAG_INCLUDE_NOT_IMPORTANT_VIEWS) != 0) {
@@ -531,6 +520,13 @@ abstract class AbstractAccessibilityServiceConnection extends IAccessibilityServ
throw new IllegalStateException(
"Cannot update service info: size is larger than safe parcelable limits.");
}
+ if (info.getObservedMotionEventSources() != 0
+ && mContext.checkCallingPermission(ACCESSIBILITY_MOTION_EVENT_OBSERVING)
+ != PackageManager.PERMISSION_GRANTED) {
+ Slog.e(LOG_TAG, "Observing motion events requires permission "
+ + ACCESSIBILITY_MOTION_EVENT_OBSERVING);
+ info.setObservedMotionEventSources(0);
+ }
final long identity = Binder.clearCallingIdentity();
try {
synchronized (mLock) {