summaryrefslogtreecommitdiff
path: root/libs/binder/IAppOpsService.cpp
diff options
context:
space:
mode:
author Steven Moreland <smoreland@google.com> 2021-04-13 01:01:32 +0000
committer Steven Moreland <smoreland@google.com> 2021-04-19 23:39:58 +0000
commitd40497186cff7cbb891d67ea4bde818e0dde4a4d (patch)
tree0a8c226f3d58fb1211622d7a11167d2eafd41ac8 /libs/binder/IAppOpsService.cpp
parente4d7d43dd2a079e6ac89264c417fa58ce6ae8d7b (diff)
libbinder->libpermission: appops
Since libbinder is used in many places, lightening it up (vtables in these classes contribute to private dirty memory). Bug: 183654927 Test: boot Change-Id: I79aa34c023074862c6c568be1f8e3503cd4a24eb
Diffstat (limited to 'libs/binder/IAppOpsService.cpp')
-rw-r--r--libs/binder/IAppOpsService.cpp292
1 files changed, 0 insertions, 292 deletions
diff --git a/libs/binder/IAppOpsService.cpp b/libs/binder/IAppOpsService.cpp
deleted file mode 100644
index d59f44562e..0000000000
--- a/libs/binder/IAppOpsService.cpp
+++ /dev/null
@@ -1,292 +0,0 @@
-/*
- * Copyright (C) 2013 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-#define LOG_TAG "AppOpsService"
-
-#include <binder/IAppOpsService.h>
-
-#include <binder/Parcel.h>
-#include <utils/Log.h>
-#include <utils/String8.h>
-
-#include <optional>
-
-namespace android {
-
-// ----------------------------------------------------------------------
-
-class BpAppOpsService : public BpInterface<IAppOpsService>
-{
-public:
- explicit BpAppOpsService(const sp<IBinder>& impl)
- : BpInterface<IAppOpsService>(impl)
- {
- }
-
- virtual int32_t checkOperation(int32_t code, int32_t uid, const String16& packageName) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeInt32(code);
- data.writeInt32(uid);
- data.writeString16(packageName);
- remote()->transact(CHECK_OPERATION_TRANSACTION, data, &reply);
- // fail on exception
- if (reply.readExceptionCode() != 0) return MODE_ERRORED;
- return reply.readInt32();
- }
-
- virtual int32_t noteOperation(int32_t code, int32_t uid, const String16& packageName,
- const std::optional<String16>& attributionTag, bool shouldCollectAsyncNotedOp,
- const String16& message, bool shouldCollectMessage) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeInt32(code);
- data.writeInt32(uid);
- data.writeString16(packageName);
- data.writeString16(attributionTag);
- data.writeBool(shouldCollectAsyncNotedOp);
- data.writeString16(message);
- data.writeBool(shouldCollectMessage);
- remote()->transact(NOTE_OPERATION_TRANSACTION, data, &reply);
- // fail on exception
- if (reply.readExceptionCode() != 0) return MODE_ERRORED;
- // TODO b/184855056: extract to class
- reply.readInt32();
- reply.readByte();
- return reply.readInt32();
- }
-
- virtual int32_t startOperation(const sp<IBinder>& token, int32_t code, int32_t uid,
- const String16& packageName, const std::optional<String16>& attributionTag,
- bool startIfModeDefault, bool shouldCollectAsyncNotedOp, const String16& message,
- bool shouldCollectMessage) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeStrongBinder(token);
- data.writeInt32(code);
- data.writeInt32(uid);
- data.writeString16(packageName);
- data.writeString16(attributionTag);
- data.writeBool(startIfModeDefault);
- data.writeBool(shouldCollectAsyncNotedOp);
- data.writeString16(message);
- data.writeBool(shouldCollectMessage);
- remote()->transact(START_OPERATION_TRANSACTION, data, &reply);
- // fail on exception
- if (reply.readExceptionCode() != 0) return MODE_ERRORED;
- // TODO b/184855056: extract to class
- reply.readInt32();
- reply.readByte();
- return reply.readInt32();
- }
-
- virtual void finishOperation(const sp<IBinder>& token, int32_t code, int32_t uid,
- const String16& packageName, const std::optional<String16>& attributionTag) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeStrongBinder(token);
- data.writeInt32(code);
- data.writeInt32(uid);
- data.writeString16(packageName);
- data.writeString16(attributionTag);
- remote()->transact(FINISH_OPERATION_TRANSACTION, data, &reply);
- }
-
- virtual void startWatchingMode(int32_t op, const String16& packageName,
- const sp<IAppOpsCallback>& callback) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeInt32(op);
- data.writeString16(packageName);
- data.writeStrongBinder(IInterface::asBinder(callback));
- remote()->transact(START_WATCHING_MODE_TRANSACTION, data, &reply);
- }
-
- virtual void stopWatchingMode(const sp<IAppOpsCallback>& callback) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeStrongBinder(IInterface::asBinder(callback));
- remote()->transact(STOP_WATCHING_MODE_TRANSACTION, data, &reply);
- }
-
- virtual int32_t permissionToOpCode(const String16& permission) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeString16(permission);
- remote()->transact(PERMISSION_TO_OP_CODE_TRANSACTION, data, &reply);
- // fail on exception
- if (reply.readExceptionCode() != 0) return -1;
- return reply.readInt32();
- }
-
- virtual int32_t checkAudioOperation(int32_t code, int32_t usage,
- int32_t uid, const String16& packageName) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeInt32(code);
- data.writeInt32(usage);
- data.writeInt32(uid);
- data.writeString16(packageName);
- remote()->transact(CHECK_AUDIO_OPERATION_TRANSACTION, data, &reply);
- // fail on exception
- if (reply.readExceptionCode() != 0) {
- return MODE_ERRORED;
- }
- return reply.readInt32();
- }
-
- virtual void setCameraAudioRestriction(int32_t mode) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeInt32(mode);
- remote()->transact(SET_CAMERA_AUDIO_RESTRICTION_TRANSACTION, data, &reply);
- }
-
- virtual bool shouldCollectNotes(int32_t opCode) {
- Parcel data, reply;
- data.writeInterfaceToken(IAppOpsService::getInterfaceDescriptor());
- data.writeInt32(opCode);
- remote()->transact(SHOULD_COLLECT_NOTES_TRANSACTION, data, &reply);
- // fail on exception
- if (reply.readExceptionCode() != 0) {
- return false;
- }
- return reply.readBool();
- }
-};
-
-IMPLEMENT_META_INTERFACE(AppOpsService, "com.android.internal.app.IAppOpsService")
-
-// ----------------------------------------------------------------------
-
-// NOLINTNEXTLINE(google-default-arguments)
-status_t BnAppOpsService::onTransact(
- uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags)
-{
- //printf("AppOpsService received: "); data.print();
- switch(code) {
- case CHECK_OPERATION_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- int32_t code = data.readInt32();
- int32_t uid = data.readInt32();
- String16 packageName = data.readString16();
- int32_t res = checkOperation(code, uid, packageName);
- reply->writeNoException();
- reply->writeInt32(res);
- return NO_ERROR;
- } break;
- case NOTE_OPERATION_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- int32_t code = data.readInt32();
- int32_t uid = data.readInt32();
- String16 packageName = data.readString16();
- std::optional<String16> attributionTag;
- data.readString16(&attributionTag);
- bool shouldCollectAsyncNotedOp = data.readBool();
- String16 message = data.readString16();
- bool shouldCollectMessage = data.readBool();
- int32_t res = noteOperation(code, uid, packageName, attributionTag,
- shouldCollectAsyncNotedOp, message, shouldCollectMessage);
- reply->writeNoException();
- reply->writeInt32(res);
- return NO_ERROR;
- } break;
- case START_OPERATION_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- sp<IBinder> token = data.readStrongBinder();
- int32_t code = data.readInt32();
- int32_t uid = data.readInt32();
- String16 packageName = data.readString16();
- std::optional<String16> attributionTag;
- data.readString16(&attributionTag);
- bool startIfModeDefault = data.readBool();
- bool shouldCollectAsyncNotedOp = data.readBool();
- String16 message = data.readString16();
- bool shouldCollectMessage = data.readBool();
- int32_t res = startOperation(token, code, uid, packageName, attributionTag,
- startIfModeDefault, shouldCollectAsyncNotedOp, message, shouldCollectMessage);
- reply->writeNoException();
- reply->writeInt32(res);
- return NO_ERROR;
- } break;
- case FINISH_OPERATION_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- sp<IBinder> token = data.readStrongBinder();
- int32_t code = data.readInt32();
- int32_t uid = data.readInt32();
- String16 packageName = data.readString16();
- std::optional<String16> attributionTag;
- data.readString16(&attributionTag);
- finishOperation(token, code, uid, packageName, attributionTag);
- reply->writeNoException();
- return NO_ERROR;
- } break;
- case START_WATCHING_MODE_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- int32_t op = data.readInt32();
- String16 packageName = data.readString16();
- sp<IAppOpsCallback> callback = interface_cast<IAppOpsCallback>(data.readStrongBinder());
- startWatchingMode(op, packageName, callback);
- reply->writeNoException();
- return NO_ERROR;
- } break;
- case STOP_WATCHING_MODE_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- sp<IAppOpsCallback> callback = interface_cast<IAppOpsCallback>(data.readStrongBinder());
- stopWatchingMode(callback);
- reply->writeNoException();
- return NO_ERROR;
- } break;
- case PERMISSION_TO_OP_CODE_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- String16 permission = data.readString16();
- const int32_t opCode = permissionToOpCode(permission);
- reply->writeNoException();
- reply->writeInt32(opCode);
- return NO_ERROR;
- } break;
- case CHECK_AUDIO_OPERATION_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- const int32_t code = data.readInt32();
- const int32_t usage = data.readInt32();
- const int32_t uid = data.readInt32();
- const String16 packageName = data.readString16();
- const int32_t res = checkAudioOperation(code, usage, uid, packageName);
- reply->writeNoException();
- reply->writeInt32(res);
- return NO_ERROR;
- } break;
- case SET_CAMERA_AUDIO_RESTRICTION_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- const int32_t mode = data.readInt32();
- setCameraAudioRestriction(mode);
- reply->writeNoException();
- return NO_ERROR;
- } break;
- case SHOULD_COLLECT_NOTES_TRANSACTION: {
- CHECK_INTERFACE(IAppOpsService, data, reply);
- int32_t opCode = data.readInt32();
- bool shouldCollect = shouldCollectNotes(opCode);
- reply->writeNoException();
- reply->writeBool(shouldCollect);
- return NO_ERROR;
- } break;
- default:
- return BBinder::onTransact(code, data, reply, flags);
- }
-}
-
-} // namespace android