diff options
author | 2015-04-29 16:50:41 -0700 | |
---|---|---|
committer | 2015-05-01 13:51:45 -0700 | |
commit | b412f6e203b38f8047f760261a5e3dc6d0722f08 (patch) | |
tree | f4e06f90090581c0efcff50602145ff11d0ea753 /libs/binder/IPermissionController.cpp | |
parent | 61a3c8dec90acebef15ef56cae14efea69279f69 (diff) |
Add body sensors app op - framework native
Change-Id: I727a2bb1e28ae9158f2df9c74dd0aee977dfd47f
Diffstat (limited to 'libs/binder/IPermissionController.cpp')
-rw-r--r-- | libs/binder/IPermissionController.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/libs/binder/IPermissionController.cpp b/libs/binder/IPermissionController.cpp index 67dac27b8d..6bba9968bc 100644 --- a/libs/binder/IPermissionController.cpp +++ b/libs/binder/IPermissionController.cpp @@ -67,6 +67,17 @@ public: packages.push(reply.readString16()); } } + + virtual bool isRuntimePermission(const String16& permission) + { + Parcel data, reply; + data.writeInterfaceToken(IPermissionController::getInterfaceDescriptor()); + data.writeString16(permission); + remote()->transact(IS_RUNTIME_PERMISSION_TRANSACTION, data, &reply); + // fail on exception + if (reply.readExceptionCode() != 0) return false; + return reply.readInt32() != 0; + } }; IMPLEMENT_META_INTERFACE(PermissionController, "android.os.IPermissionController"); @@ -102,6 +113,15 @@ status_t BnPermissionController::onTransact( return NO_ERROR; } break; + case IS_RUNTIME_PERMISSION_TRANSACTION: { + CHECK_INTERFACE(IPermissionController, data, reply); + String16 permission = data.readString16(); + const bool res = isRuntimePermission(permission); + reply->writeNoException(); + reply->writeInt32(res ? 1 : 0); + return NO_ERROR; + } break; + default: return BBinder::onTransact(code, data, reply, flags); } |