blob: a22cf25671afccf047a7b514d8bee19f3b050b83 [file] [log] [blame]
Dianne Hackborn5da5ca52013-02-12 15:12:21 -08001/*
2 * Copyright (C) 2013 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Christopher Wiley5975c002016-02-12 15:41:08 -080017#include <mutex>
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080018#include <binder/AppOpsManager.h>
Dianne Hackborn913b63d2013-07-17 17:26:15 -070019#include <binder/Binder.h>
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080020#include <binder/IServiceManager.h>
21
22#include <utils/SystemClock.h>
23
Philip P. Moltmann66a87772019-06-24 16:30:00 -070024#include <sys/types.h>
25
26#ifdef LOG_TAG
27#undef LOG_TAG
28#endif
29#define LOG_TAG "AppOpsManager"
30
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080031namespace android {
32
Philip P. Moltmannc52e1fc2019-11-26 15:18:09 -080033static const sp<IBinder>& getClientId() {
Steven Moreland1e219c12020-02-27 16:27:49 -080034 static pthread_mutex_t gClientIdMutex = PTHREAD_MUTEX_INITIALIZER;
35 static sp<IBinder> gClientId;
36
Philip P. Moltmannc52e1fc2019-11-26 15:18:09 -080037 pthread_mutex_lock(&gClientIdMutex);
38 if (gClientId == nullptr) {
39 gClientId = new BBinder();
Dianne Hackborn913b63d2013-07-17 17:26:15 -070040 }
Philip P. Moltmannc52e1fc2019-11-26 15:18:09 -080041 pthread_mutex_unlock(&gClientIdMutex);
42 return gClientId;
Dianne Hackborn913b63d2013-07-17 17:26:15 -070043}
Philip P. Moltmann66a87772019-06-24 16:30:00 -070044
45thread_local uint64_t notedAppOpsInThisBinderTransaction[2];
46thread_local int32_t uidOfThisBinderTransaction = -1;
47
48// Whether an appop should be collected: 0 == not initialized, 1 == don't note, 2 == note
Philip P. Moltmann66a87772019-06-24 16:30:00 -070049uint8_t appOpsToNote[AppOpsManager::_NUM_OP] = {0};
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080050
51AppOpsManager::AppOpsManager()
52{
53}
54
55sp<IAppOpsService> AppOpsManager::getService()
56{
Steven Moreland1e219c12020-02-27 16:27:49 -080057 static String16 _appops("appops");
Christopher Wiley8ed42702016-02-05 09:08:23 -080058
Christopher Wiley5975c002016-02-12 15:41:08 -080059 std::lock_guard<Mutex> scoped_lock(mLock);
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080060 int64_t startTime = 0;
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080061 sp<IAppOpsService> service = mService;
Yi Kong91635562018-06-07 14:38:36 -070062 while (service == nullptr || !IInterface::asBinder(service)->isBinderAlive()) {
Eino-Ville Talvalae88a85e2013-02-19 12:54:57 -080063 sp<IBinder> binder = defaultServiceManager()->checkService(_appops);
Yi Kong91635562018-06-07 14:38:36 -070064 if (binder == nullptr) {
Eino-Ville Talvalae88a85e2013-02-19 12:54:57 -080065 // Wait for the app ops service to come back...
66 if (startTime == 0) {
67 startTime = uptimeMillis();
68 ALOGI("Waiting for app ops service");
69 } else if ((uptimeMillis()-startTime) > 10000) {
70 ALOGW("Waiting too long for app ops service, giving up");
Yi Kong91635562018-06-07 14:38:36 -070071 service = nullptr;
Christopher Wiley6dd45522016-02-05 09:06:30 -080072 break;
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080073 }
Eino-Ville Talvalae88a85e2013-02-19 12:54:57 -080074 sleep(1);
75 } else {
76 service = interface_cast<IAppOpsService>(binder);
77 mService = service;
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080078 }
79 }
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080080 return service;
81}
82
83int32_t AppOpsManager::checkOp(int32_t op, int32_t uid, const String16& callingPackage)
84{
85 sp<IAppOpsService> service = getService();
Yi Kong91635562018-06-07 14:38:36 -070086 return service != nullptr
Christopher Wiley8ed42702016-02-05 09:08:23 -080087 ? service->checkOperation(op, uid, callingPackage)
Steven Moreland15a63a82020-02-27 16:31:13 -080088 : AppOpsManager::MODE_IGNORED;
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080089}
90
Jean-Michel Trivi94a566d2019-02-25 12:16:02 -080091int32_t AppOpsManager::checkAudioOpNoThrow(int32_t op, int32_t usage, int32_t uid,
92 const String16& callingPackage) {
93 sp<IAppOpsService> service = getService();
94 return service != nullptr
95 ? service->checkAudioOperation(op, usage, uid, callingPackage)
Steven Moreland15a63a82020-02-27 16:31:13 -080096 : AppOpsManager::MODE_IGNORED;
Jean-Michel Trivi94a566d2019-02-25 12:16:02 -080097}
98
Dianne Hackborn5da5ca52013-02-12 15:12:21 -080099int32_t AppOpsManager::noteOp(int32_t op, int32_t uid, const String16& callingPackage) {
Philip P. Moltmannaeaaf1c2019-11-05 12:34:36 -0800100 return noteOp(op, uid, callingPackage, std::unique_ptr<String16>(),
101 String16("Legacy AppOpsManager.noteOp call"));
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700102}
103
104int32_t AppOpsManager::noteOp(int32_t op, int32_t uid, const String16& callingPackage,
Philip P. Moltmannaeaaf1c2019-11-05 12:34:36 -0800105 const std::unique_ptr<String16>& featureId, const String16& message) {
Dianne Hackborn5da5ca52013-02-12 15:12:21 -0800106 sp<IAppOpsService> service = getService();
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700107 int32_t mode = service != nullptr
Philip P. Moltmann3879cf62019-12-20 11:22:37 -0800108 ? service->noteOperation(op, uid, callingPackage, featureId, shouldCollectNotes(op),
109 message)
Steven Moreland15a63a82020-02-27 16:31:13 -0800110 : AppOpsManager::MODE_IGNORED;
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700111
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700112 return mode;
Dianne Hackborn5da5ca52013-02-12 15:12:21 -0800113}
114
Svet Ganov616554c2018-02-26 13:27:26 -0800115int32_t AppOpsManager::startOpNoThrow(int32_t op, int32_t uid, const String16& callingPackage,
116 bool startIfModeDefault) {
Philip P. Moltmannaeaaf1c2019-11-05 12:34:36 -0800117 return startOpNoThrow(op, uid, callingPackage, startIfModeDefault, std::unique_ptr<String16>(),
118 String16("Legacy AppOpsManager.startOpNoThrow call"));
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700119}
120
121int32_t AppOpsManager::startOpNoThrow(int32_t op, int32_t uid, const String16& callingPackage,
Philip P. Moltmannaeaaf1c2019-11-05 12:34:36 -0800122 bool startIfModeDefault, const std::unique_ptr<String16>& featureId,
123 const String16& message) {
Dianne Hackborn5da5ca52013-02-12 15:12:21 -0800124 sp<IAppOpsService> service = getService();
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700125 int32_t mode = service != nullptr
Philip P. Moltmannc52e1fc2019-11-26 15:18:09 -0800126 ? service->startOperation(getClientId(), op, uid, callingPackage,
Philip P. Moltmann3879cf62019-12-20 11:22:37 -0800127 featureId, startIfModeDefault, shouldCollectNotes(op), message)
Steven Moreland15a63a82020-02-27 16:31:13 -0800128 : AppOpsManager::MODE_IGNORED;
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700129
130 return mode;
Dianne Hackborn5da5ca52013-02-12 15:12:21 -0800131}
132
133void AppOpsManager::finishOp(int32_t op, int32_t uid, const String16& callingPackage) {
Philip P. Moltmannaeaaf1c2019-11-05 12:34:36 -0800134 finishOp(op, uid, callingPackage, std::unique_ptr<String16>());
135}
136
137void AppOpsManager::finishOp(int32_t op, int32_t uid, const String16& callingPackage,
138 const std::unique_ptr<String16>& callingFeatureId) {
Dianne Hackborn5da5ca52013-02-12 15:12:21 -0800139 sp<IAppOpsService> service = getService();
Yi Kong91635562018-06-07 14:38:36 -0700140 if (service != nullptr) {
Philip P. Moltmannc52e1fc2019-11-26 15:18:09 -0800141 service->finishOperation(getClientId(), op, uid, callingPackage, callingFeatureId);
Dianne Hackborn5da5ca52013-02-12 15:12:21 -0800142 }
143}
144
145void AppOpsManager::startWatchingMode(int32_t op, const String16& packageName,
146 const sp<IAppOpsCallback>& callback) {
147 sp<IAppOpsService> service = getService();
Yi Kong91635562018-06-07 14:38:36 -0700148 if (service != nullptr) {
Dianne Hackborn5da5ca52013-02-12 15:12:21 -0800149 service->startWatchingMode(op, packageName, callback);
150 }
151}
152
153void AppOpsManager::stopWatchingMode(const sp<IAppOpsCallback>& callback) {
154 sp<IAppOpsService> service = getService();
Yi Kong91635562018-06-07 14:38:36 -0700155 if (service != nullptr) {
Dianne Hackborn5da5ca52013-02-12 15:12:21 -0800156 service->stopWatchingMode(callback);
157 }
158}
159
Svetoslavb412f6e2015-04-29 16:50:41 -0700160int32_t AppOpsManager::permissionToOpCode(const String16& permission) {
161 sp<IAppOpsService> service = getService();
Yi Kong91635562018-06-07 14:38:36 -0700162 if (service != nullptr) {
Svetoslavb412f6e2015-04-29 16:50:41 -0700163 return service->permissionToOpCode(permission);
164 }
165 return -1;
166}
167
Yin-Chia Yeh8e95ee82019-08-13 12:24:25 -0700168void AppOpsManager::setCameraAudioRestriction(int32_t mode) {
169 sp<IAppOpsService> service = getService();
170 if (service != nullptr) {
171 service->setCameraAudioRestriction(mode);
172 }
173}
174
Philip P. Moltmann3879cf62019-12-20 11:22:37 -0800175// check it the appops needs to be collected and cache result
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700176bool AppOpsManager::shouldCollectNotes(int32_t opcode) {
Philip P. Moltmann3879cf62019-12-20 11:22:37 -0800177 if (appOpsToNote[opcode] == 0) {
178 if (getService()->shouldCollectNotes(opcode)) {
179 appOpsToNote[opcode] = 2;
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700180 } else {
Philip P. Moltmann3879cf62019-12-20 11:22:37 -0800181 appOpsToNote[opcode] = 1;
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700182 }
183 }
184
Philip P. Moltmann3879cf62019-12-20 11:22:37 -0800185 return appOpsToNote[opcode] == 2;
Philip P. Moltmann66a87772019-06-24 16:30:00 -0700186}
Svetoslavb412f6e2015-04-29 16:50:41 -0700187
Steven Moreland6511af52019-09-26 16:05:45 -0700188} // namespace android