1*ec779b8eSAndroid Build Coastguard Worker /* 2*ec779b8eSAndroid Build Coastguard Worker * Copyright (C) 2023 The Android Open Source Project 3*ec779b8eSAndroid Build Coastguard Worker * 4*ec779b8eSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*ec779b8eSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*ec779b8eSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*ec779b8eSAndroid Build Coastguard Worker * 8*ec779b8eSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*ec779b8eSAndroid Build Coastguard Worker * 10*ec779b8eSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*ec779b8eSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*ec779b8eSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*ec779b8eSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*ec779b8eSAndroid Build Coastguard Worker * limitations under the License. 15*ec779b8eSAndroid Build Coastguard Worker */ 16*ec779b8eSAndroid Build Coastguard Worker 17*ec779b8eSAndroid Build Coastguard Worker #define LOG_TAG "Permission" 18*ec779b8eSAndroid Build Coastguard Worker //#define LOG_NDEBUG 0 19*ec779b8eSAndroid Build Coastguard Worker 20*ec779b8eSAndroid Build Coastguard Worker #include "Permission.h" 21*ec779b8eSAndroid Build Coastguard Worker 22*ec779b8eSAndroid Build Coastguard Worker #include <binder/PermissionController.h> 23*ec779b8eSAndroid Build Coastguard Worker #include <media/AidlConversionCppNdk.h> 24*ec779b8eSAndroid Build Coastguard Worker #include <utils/Log.h> 25*ec779b8eSAndroid Build Coastguard Worker 26*ec779b8eSAndroid Build Coastguard Worker namespace android::afutils { 27*ec779b8eSAndroid Build Coastguard Worker 28*ec779b8eSAndroid Build Coastguard Worker // TODO b/182392769: use attribution source util checkAttributionSourcePackage(const content::AttributionSourceState & attributionSource)29*ec779b8eSAndroid Build Coastguard Workercontent::AttributionSourceState checkAttributionSourcePackage( 30*ec779b8eSAndroid Build Coastguard Worker const content::AttributionSourceState& attributionSource) { 31*ec779b8eSAndroid Build Coastguard Worker Vector<String16> packages; 32*ec779b8eSAndroid Build Coastguard Worker PermissionController{}.getPackagesForUid(attributionSource.uid, packages); 33*ec779b8eSAndroid Build Coastguard Worker 34*ec779b8eSAndroid Build Coastguard Worker content::AttributionSourceState checkedAttributionSource = attributionSource; 35*ec779b8eSAndroid Build Coastguard Worker if (!attributionSource.packageName.has_value() 36*ec779b8eSAndroid Build Coastguard Worker || attributionSource.packageName.value().size() == 0) { 37*ec779b8eSAndroid Build Coastguard Worker if (!packages.isEmpty()) { 38*ec779b8eSAndroid Build Coastguard Worker checkedAttributionSource.packageName = 39*ec779b8eSAndroid Build Coastguard Worker std::move(legacy2aidl_String16_string(packages[0]).value()); 40*ec779b8eSAndroid Build Coastguard Worker } 41*ec779b8eSAndroid Build Coastguard Worker } else { 42*ec779b8eSAndroid Build Coastguard Worker const String16 opPackageLegacy = VALUE_OR_FATAL( 43*ec779b8eSAndroid Build Coastguard Worker aidl2legacy_string_view_String16(attributionSource.packageName.value_or(""))); 44*ec779b8eSAndroid Build Coastguard Worker if (std::find_if(packages.begin(), packages.end(), 45*ec779b8eSAndroid Build Coastguard Worker [&opPackageLegacy](const auto& package) { 46*ec779b8eSAndroid Build Coastguard Worker return opPackageLegacy == package; }) == packages.end()) { 47*ec779b8eSAndroid Build Coastguard Worker ALOGW("The package name(%s) provided does not correspond to the uid %d", 48*ec779b8eSAndroid Build Coastguard Worker attributionSource.packageName.value_or("").c_str(), attributionSource.uid); 49*ec779b8eSAndroid Build Coastguard Worker } 50*ec779b8eSAndroid Build Coastguard Worker } 51*ec779b8eSAndroid Build Coastguard Worker return checkedAttributionSource; 52*ec779b8eSAndroid Build Coastguard Worker } 53*ec779b8eSAndroid Build Coastguard Worker 54*ec779b8eSAndroid Build Coastguard Worker } // namespace android::afutils 55