blob: 751bae9ebc7c4b1b24868200963456c0838c9e77 [file] [log] [blame]
Svet Ganovadc1cf42015-06-15 16:36:24 -07001/*
2 * Copyright (C) 2015 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
17package com.android.server.pm;
18
19import android.Manifest;
Dianne Hackbornca8e6da2015-06-24 15:19:17 -070020import android.app.DownloadManager;
Dianne Hackborn388cd2c2015-06-26 17:32:36 -070021import android.app.admin.DevicePolicyManager;
Svet Ganovadc1cf42015-06-15 16:36:24 -070022import android.content.Intent;
23import android.content.pm.ApplicationInfo;
24import android.content.pm.PackageManager;
25import android.content.pm.PackageManagerInternal.PackagesProvider;
26import android.content.pm.PackageParser;
Dianne Hackbornca8e6da2015-06-24 15:19:17 -070027import android.content.pm.ProviderInfo;
Svet Ganovadc1cf42015-06-15 16:36:24 -070028import android.content.pm.ResolveInfo;
29import android.net.Uri;
30import android.os.Build;
31import android.os.UserHandle;
Dianne Hackborn388cd2c2015-06-26 17:32:36 -070032import android.provider.CalendarContract;
33import android.provider.ContactsContract;
Svet Ganovadc1cf42015-06-15 16:36:24 -070034import android.provider.MediaStore;
35import android.util.ArraySet;
36import android.util.Log;
37
38import java.io.File;
39import java.util.ArrayList;
40import java.util.List;
41import java.util.Set;
42
43import static android.os.Process.FIRST_APPLICATION_UID;
44
45/**
46 * This class is the policy for granting runtime permissions to
47 * platform components and default handlers in the system such
48 * that the device is usable out-of-the-box. For example, the
49 * shell UID is a part of the system and the Phone app should
50 * have phone related permission by default.
51 */
52final class DefaultPermissionGrantPolicy {
Jeff Davidson2a880312015-06-22 16:54:34 -070053 private static final String TAG = "DefaultPermGrantPolicy"; // must be <= 23 chars
Svet Ganovadc1cf42015-06-15 16:36:24 -070054 private static final boolean DEBUG = false;
55
56 private static final String PACKAGE_MIME_TYPE = "application/vnd.android.package-archive";
57
58 private static final Set<String> PHONE_PERMISSIONS = new ArraySet<>();
59 static {
60 PHONE_PERMISSIONS.add(Manifest.permission.READ_PHONE_STATE);
61 PHONE_PERMISSIONS.add(Manifest.permission.CALL_PHONE);
Dianne Hackborn388cd2c2015-06-26 17:32:36 -070062 PHONE_PERMISSIONS.add(Manifest.permission.READ_CALL_LOG);
Svet Ganovadc1cf42015-06-15 16:36:24 -070063 PHONE_PERMISSIONS.add(Manifest.permission.WRITE_CALL_LOG);
64 PHONE_PERMISSIONS.add(Manifest.permission.ADD_VOICEMAIL);
65 PHONE_PERMISSIONS.add(Manifest.permission.USE_SIP);
66 PHONE_PERMISSIONS.add(Manifest.permission.PROCESS_OUTGOING_CALLS);
67 }
68
69 private static final Set<String> CONTACTS_PERMISSIONS = new ArraySet<>();
70 static {
71 CONTACTS_PERMISSIONS.add(Manifest.permission.READ_CONTACTS);
72 CONTACTS_PERMISSIONS.add(Manifest.permission.WRITE_CONTACTS);
73 }
74
75 private static final Set<String> LOCATION_PERMISSIONS = new ArraySet<>();
76 static {
77 LOCATION_PERMISSIONS.add(Manifest.permission.ACCESS_FINE_LOCATION);
78 LOCATION_PERMISSIONS.add(Manifest.permission.ACCESS_COARSE_LOCATION);
79 }
80
81 private static final Set<String> CALENDAR_PERMISSIONS = new ArraySet<>();
82 static {
83 CALENDAR_PERMISSIONS.add(Manifest.permission.READ_CALENDAR);
84 CALENDAR_PERMISSIONS.add(Manifest.permission.WRITE_CALENDAR);
85 }
86
87 private static final Set<String> SMS_PERMISSIONS = new ArraySet<>();
88 static {
89 SMS_PERMISSIONS.add(Manifest.permission.SEND_SMS);
90 SMS_PERMISSIONS.add(Manifest.permission.RECEIVE_SMS);
91 SMS_PERMISSIONS.add(Manifest.permission.READ_SMS);
92 SMS_PERMISSIONS.add(Manifest.permission.RECEIVE_WAP_PUSH);
93 SMS_PERMISSIONS.add(Manifest.permission.RECEIVE_MMS);
94 SMS_PERMISSIONS.add(Manifest.permission.READ_CELL_BROADCASTS);
95 }
96
97 private static final Set<String> MICROPHONE_PERMISSIONS = new ArraySet<>();
98 static {
99 MICROPHONE_PERMISSIONS.add(Manifest.permission.RECORD_AUDIO);
100 }
101
102 private static final Set<String> CAMERA_PERMISSIONS = new ArraySet<>();
103 static {
104 CAMERA_PERMISSIONS.add(Manifest.permission.CAMERA);
105 }
106
107 private static final Set<String> SENSORS_PERMISSIONS = new ArraySet<>();
108 static {
109 SENSORS_PERMISSIONS.add(Manifest.permission.BODY_SENSORS);
110 }
111
112 private static final Set<String> STORAGE_PERMISSIONS = new ArraySet<>();
113 static {
Svet Ganov975fa472015-06-22 20:45:31 -0700114 STORAGE_PERMISSIONS.add(Manifest.permission.READ_EXTERNAL_STORAGE);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700115 STORAGE_PERMISSIONS.add(Manifest.permission.WRITE_EXTERNAL_STORAGE);
116 }
117
Dianne Hackborn388cd2c2015-06-26 17:32:36 -0700118 private static final Set<String> ACCOUNTS_PERMISSIONS = new ArraySet<>();
119 static {
120 ACCOUNTS_PERMISSIONS.add(Manifest.permission.GET_ACCOUNTS);
121 }
122
Svet Ganovadc1cf42015-06-15 16:36:24 -0700123 private static final Set<String> SETTINGS_PERMISSIONS = new ArraySet<>();
124 static {
125 SETTINGS_PERMISSIONS.add(Manifest.permission.WRITE_SETTINGS);
126 }
127
128 private static final Set<String> INSTALLER_PERMISSIONS = new ArraySet<>();
129 static {
130 INSTALLER_PERMISSIONS.add(Manifest.permission.GRANT_REVOKE_PERMISSIONS);
131 INSTALLER_PERMISSIONS.add(Manifest.permission.INTERACT_ACROSS_USERS_FULL);
132 INSTALLER_PERMISSIONS.add(Manifest.permission.CLEAR_APP_USER_DATA);
133 INSTALLER_PERMISSIONS.add(Manifest.permission.KILL_UID);
134 }
135
136 private static final Set<String> VERIFIER_PERMISSIONS = new ArraySet<>();
137 static {
138 INSTALLER_PERMISSIONS.add(Manifest.permission.GRANT_REVOKE_PERMISSIONS);
139 }
140
141 private final PackageManagerService mService;
142
143 private PackagesProvider mImePackagesProvider;
144 private PackagesProvider mLocationPackagesProvider;
145 private PackagesProvider mVoiceInteractionPackagesProvider;
Svetoslavcdfd2302015-06-25 19:07:31 -0700146 private PackagesProvider mSmsAppPackagesProvider;
147 private PackagesProvider mDialerAppPackagesProvider;
Svet Ganovadc1cf42015-06-15 16:36:24 -0700148
149 public DefaultPermissionGrantPolicy(PackageManagerService service) {
150 mService = service;
151 }
152
153 public void setImePackagesProviderLPr(PackagesProvider provider) {
154 mImePackagesProvider = provider;
155 }
156
157 public void setLocationPackagesProviderLPw(PackagesProvider provider) {
158 mLocationPackagesProvider = provider;
159 }
160
161 public void setVoiceInteractionPackagesProviderLPw(PackagesProvider provider) {
162 mVoiceInteractionPackagesProvider = provider;
163 }
164
Svetoslavcdfd2302015-06-25 19:07:31 -0700165 public void setSmsAppPackagesProviderLPw(PackagesProvider provider) {
166 mSmsAppPackagesProvider = provider;
167 }
168
169 public void setDialerAppPackagesProviderLPw(PackagesProvider provider) {
170 mDialerAppPackagesProvider = provider;
Jeff Davidson2a880312015-06-22 16:54:34 -0700171 }
172
Svet Ganovadc1cf42015-06-15 16:36:24 -0700173 public void grantDefaultPermissions(int userId) {
174 grantPermissionsToSysComponentsAndPrivApps(userId);
175 grantDefaultSystemHandlerPermissions(userId);
176 }
177
178 private void grantPermissionsToSysComponentsAndPrivApps(int userId) {
Svetoslavcdfd2302015-06-25 19:07:31 -0700179 Log.i(TAG, "Granting permissions to platform components for user" + userId);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700180
181 synchronized (mService.mPackages) {
182 for (PackageParser.Package pkg : mService.mPackages.values()) {
183 if (!isSysComponentOrPersistentPrivApp(pkg)
184 || !doesPackageSupportRuntimePermissions(pkg)) {
185 continue;
186 }
187 final int permissionCount = pkg.requestedPermissions.size();
188 for (int i = 0; i < permissionCount; i++) {
189 String permission = pkg.requestedPermissions.get(i);
190 BasePermission bp = mService.mSettings.mPermissions.get(permission);
191 if (bp != null && bp.isRuntime()) {
192 final int flags = mService.getPermissionFlags(permission,
193 pkg.packageName, userId);
194 if ((flags & PackageManager.FLAG_PERMISSION_SYSTEM_FIXED) == 0) {
195 mService.grantRuntimePermission(pkg.packageName, permission, userId);
196 mService.updatePermissionFlags(permission, pkg.packageName,
197 PackageManager.MASK_PERMISSION_FLAGS,
198 PackageManager.FLAG_PERMISSION_SYSTEM_FIXED, userId);
199 if (DEBUG) {
200 Log.i(TAG, "Granted " + permission + " to system component "
201 + pkg.packageName);
202 }
203 }
204 }
205 }
206 }
207 }
208 }
209
210 private void grantDefaultSystemHandlerPermissions(int userId) {
Svetoslavcdfd2302015-06-25 19:07:31 -0700211 Log.i(TAG, "Granting permissions to default platform handlers for user:" + userId);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700212
213 final PackagesProvider imePackagesProvider;
214 final PackagesProvider locationPackagesProvider;
215 final PackagesProvider voiceInteractionPackagesProvider;
Svetoslavcdfd2302015-06-25 19:07:31 -0700216 final PackagesProvider smsAppPackagesProvider;
217 final PackagesProvider dialerAppPackagesProvider;
Svet Ganovadc1cf42015-06-15 16:36:24 -0700218
219 synchronized (mService.mPackages) {
220 imePackagesProvider = mImePackagesProvider;
221 locationPackagesProvider = mLocationPackagesProvider;
222 voiceInteractionPackagesProvider = mVoiceInteractionPackagesProvider;
Svetoslavcdfd2302015-06-25 19:07:31 -0700223 smsAppPackagesProvider = mSmsAppPackagesProvider;
224 dialerAppPackagesProvider = mDialerAppPackagesProvider;
Svet Ganovadc1cf42015-06-15 16:36:24 -0700225 }
226
227 String[] imePackageNames = (imePackagesProvider != null)
228 ? imePackagesProvider.getPackages(userId) : null;
229 String[] voiceInteractPackageNames = (voiceInteractionPackagesProvider != null)
230 ? voiceInteractionPackagesProvider.getPackages(userId) : null;
231 String[] locationPackageNames = (locationPackagesProvider != null)
232 ? locationPackagesProvider.getPackages(userId) : null;
Svetoslavcdfd2302015-06-25 19:07:31 -0700233 String[] smsAppPackageNames = (smsAppPackagesProvider != null)
234 ? smsAppPackagesProvider.getPackages(userId) : null;
235 String[] dialerAppPackageNames = (dialerAppPackagesProvider != null)
236 ? dialerAppPackagesProvider.getPackages(userId) : null;
Svet Ganovadc1cf42015-06-15 16:36:24 -0700237
238 synchronized (mService.mPackages) {
239 // Installers
240 Intent installerIntent = new Intent(Intent.ACTION_INSTALL_PACKAGE);
241 installerIntent.addCategory(Intent.CATEGORY_DEFAULT);
242 installerIntent.setDataAndType(Uri.fromFile(new File("foo.apk")),
243 PACKAGE_MIME_TYPE);
244 List<PackageParser.Package> installerPackages =
245 getPrivilegedHandlerActivityPackagesLPr(installerIntent, userId);
246 final int installerCount = installerPackages.size();
247 for (int i = 0; i < installerCount; i++) {
248 PackageParser.Package installPackage = installerPackages.get(i);
249 grantInstallPermissionsLPw(installPackage, INSTALLER_PERMISSIONS, userId);
Dianne Hackbornca8e6da2015-06-24 15:19:17 -0700250 grantRuntimePermissionsLPw(installPackage, STORAGE_PERMISSIONS, userId);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700251 }
252
253 // Verifiers
254 Intent verifierIntent = new Intent(Intent.ACTION_PACKAGE_NEEDS_VERIFICATION);
255 verifierIntent.setType(PACKAGE_MIME_TYPE);
256 List<PackageParser.Package> verifierPackages =
257 getPrivilegedHandlerReceiverPackagesLPr(verifierIntent, userId);
258 final int verifierCount = verifierPackages.size();
259 for (int i = 0; i < verifierCount; i++) {
260 PackageParser.Package verifierPackage = verifierPackages.get(i);
261 grantInstallPermissionsLPw(verifierPackage, VERIFIER_PERMISSIONS, userId);
Dianne Hackbornca8e6da2015-06-24 15:19:17 -0700262 grantRuntimePermissionsLPw(verifierPackage, STORAGE_PERMISSIONS, userId);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700263 }
264
265 // SetupWizard
266 Intent setupIntent = new Intent(Intent.ACTION_MAIN);
267 setupIntent.addCategory(Intent.CATEGORY_HOME);
Svetoslavcdfd2302015-06-25 19:07:31 -0700268 PackageParser.Package setupPackage = getDefaultSystemHandlerActivityPackageLPr(
Svet Ganovadc1cf42015-06-15 16:36:24 -0700269 setupIntent, userId);
270 if (setupPackage != null
271 && doesPackageSupportRuntimePermissions(setupPackage)) {
272 grantRuntimePermissionsLPw(setupPackage, PHONE_PERMISSIONS, userId);
273 grantRuntimePermissionsLPw(setupPackage, CONTACTS_PERMISSIONS, userId);
274 grantRuntimePermissionsLPw(setupPackage, SETTINGS_PERMISSIONS, userId);
275 }
276
Svetoslavcdfd2302015-06-25 19:07:31 -0700277 // Dialer
278 if (dialerAppPackageNames != null) {
279 for (String dialerAppPackageName : dialerAppPackageNames) {
280 PackageParser.Package dialerPackage = getPackageLPr(dialerAppPackageName);
281 if (dialerPackage != null
282 && doesPackageSupportRuntimePermissions(dialerPackage)) {
283 grantRuntimePermissionsLPw(dialerPackage, PHONE_PERMISSIONS, userId);
284 grantRuntimePermissionsLPw(dialerPackage, CONTACTS_PERMISSIONS, userId);
285 grantRuntimePermissionsLPw(dialerPackage, SMS_PERMISSIONS, userId);
286 grantRuntimePermissionsLPw(dialerPackage, MICROPHONE_PERMISSIONS, userId);
287 }
288 }
Svet Ganovadc1cf42015-06-15 16:36:24 -0700289 }
290
291 // Camera
292 Intent cameraIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
Svetoslavcdfd2302015-06-25 19:07:31 -0700293 PackageParser.Package cameraPackage = getDefaultSystemHandlerActivityPackageLPr(
Svet Ganovadc1cf42015-06-15 16:36:24 -0700294 cameraIntent, userId);
295 if (cameraPackage != null
296 && doesPackageSupportRuntimePermissions(cameraPackage)) {
297 grantRuntimePermissionsLPw(cameraPackage, CAMERA_PERMISSIONS, userId);
298 grantRuntimePermissionsLPw(cameraPackage, MICROPHONE_PERMISSIONS, userId);
Dianne Hackbornca8e6da2015-06-24 15:19:17 -0700299 grantRuntimePermissionsLPw(cameraPackage, STORAGE_PERMISSIONS, userId);
300 }
301
302 // Media provider
303 PackageParser.Package mediaStorePackage = getDefaultProviderAuthorityPackageLPr(
304 MediaStore.AUTHORITY, userId);
305 if (mediaStorePackage != null) {
306 grantRuntimePermissionsLPw(mediaStorePackage, STORAGE_PERMISSIONS, userId);
307 }
308
309 // Downloads provider
310 PackageParser.Package downloadsPackage = getDefaultProviderAuthorityPackageLPr(
311 "downloads", userId);
312 if (downloadsPackage != null) {
313 grantRuntimePermissionsLPw(downloadsPackage, STORAGE_PERMISSIONS, userId);
314 }
315
316 // Downloads UI
317 Intent downloadsUiIntent = new Intent(DownloadManager.ACTION_VIEW_DOWNLOADS);
Svetoslavcdfd2302015-06-25 19:07:31 -0700318 PackageParser.Package downloadsUiPackage = getDefaultSystemHandlerActivityPackageLPr(
Dianne Hackbornca8e6da2015-06-24 15:19:17 -0700319 downloadsUiIntent, userId);
320 if (downloadsUiPackage != null
321 && doesPackageSupportRuntimePermissions(downloadsUiPackage)) {
322 grantRuntimePermissionsLPw(downloadsUiPackage, STORAGE_PERMISSIONS, userId);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700323 }
324
Svetoslavcdfd2302015-06-25 19:07:31 -0700325 // SMS
326 if (smsAppPackageNames != null) {
327 for (String smsPackageName : smsAppPackageNames) {
328 PackageParser.Package smsPackage = getPackageLPr(smsPackageName);
329 if (smsPackage != null
330 && doesPackageSupportRuntimePermissions(smsPackage)) {
331 grantRuntimePermissionsLPw(smsPackage, PHONE_PERMISSIONS, userId);
332 grantRuntimePermissionsLPw(smsPackage, CONTACTS_PERMISSIONS, userId);
333 grantRuntimePermissionsLPw(smsPackage, SMS_PERMISSIONS, userId);
334 }
335 }
Svet Ganovadc1cf42015-06-15 16:36:24 -0700336 }
337
338 // Calendar
339 Intent calendarIntent = new Intent(Intent.ACTION_MAIN);
340 calendarIntent.addCategory(Intent.CATEGORY_APP_CALENDAR);
Svetoslavcdfd2302015-06-25 19:07:31 -0700341 PackageParser.Package calendarPackage = getDefaultSystemHandlerActivityPackageLPr(
Svet Ganovadc1cf42015-06-15 16:36:24 -0700342 calendarIntent, userId);
343 if (calendarPackage != null
344 && doesPackageSupportRuntimePermissions(calendarPackage)) {
345 grantRuntimePermissionsLPw(calendarPackage, CALENDAR_PERMISSIONS, userId);
346 grantRuntimePermissionsLPw(calendarPackage, CONTACTS_PERMISSIONS, userId);
Dianne Hackborn388cd2c2015-06-26 17:32:36 -0700347 grantRuntimePermissionsLPw(calendarPackage, ACCOUNTS_PERMISSIONS, userId);
348 }
349
350 // Calendar provider
351 PackageParser.Package calendarProviderPackage = getDefaultProviderAuthorityPackageLPr(
352 CalendarContract.AUTHORITY, userId);
353 if (calendarProviderPackage != null) {
354 grantRuntimePermissionsLPw(calendarProviderPackage, CONTACTS_PERMISSIONS, userId);
355 grantRuntimePermissionsLPw(calendarProviderPackage, CALENDAR_PERMISSIONS, userId);
356 grantRuntimePermissionsLPw(calendarProviderPackage, ACCOUNTS_PERMISSIONS, userId);
357 grantRuntimePermissionsLPw(calendarProviderPackage, STORAGE_PERMISSIONS, userId);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700358 }
359
360 // Contacts
361 Intent contactsIntent = new Intent(Intent.ACTION_MAIN);
362 contactsIntent.addCategory(Intent.CATEGORY_APP_CONTACTS);
Svetoslavcdfd2302015-06-25 19:07:31 -0700363 PackageParser.Package contactsPackage = getDefaultSystemHandlerActivityPackageLPr(
Svet Ganovadc1cf42015-06-15 16:36:24 -0700364 contactsIntent, userId);
365 if (contactsPackage != null
366 && doesPackageSupportRuntimePermissions(contactsPackage)) {
367 grantRuntimePermissionsLPw(contactsPackage, CONTACTS_PERMISSIONS, userId);
368 grantRuntimePermissionsLPw(contactsPackage, PHONE_PERMISSIONS, userId);
Dianne Hackborn388cd2c2015-06-26 17:32:36 -0700369 grantRuntimePermissionsLPw(contactsPackage, ACCOUNTS_PERMISSIONS, userId);
370 }
371
372 // Contacts provider
373 PackageParser.Package contactsProviderPackage = getDefaultProviderAuthorityPackageLPr(
374 ContactsContract.AUTHORITY, userId);
375 if (contactsProviderPackage != null) {
376 grantRuntimePermissionsLPw(contactsProviderPackage, CONTACTS_PERMISSIONS, userId);
377 grantRuntimePermissionsLPw(contactsProviderPackage, ACCOUNTS_PERMISSIONS, userId);
378 grantRuntimePermissionsLPw(contactsProviderPackage, STORAGE_PERMISSIONS, userId);
379 }
380
381 // Device provisioning
382 Intent deviceProvisionIntent = new Intent(
383 DevicePolicyManager.ACTION_PROVISION_MANAGED_DEVICE);
Svet Ganovb6e00132015-06-29 20:19:25 -0700384 PackageParser.Package deviceProvisionPackage =
385 getDefaultSystemHandlerActivityPackageLPr(deviceProvisionIntent, userId);
Dianne Hackborn388cd2c2015-06-26 17:32:36 -0700386 if (deviceProvisionPackage != null
387 && doesPackageSupportRuntimePermissions(deviceProvisionPackage)) {
388 grantRuntimePermissionsLPw(contactsPackage, ACCOUNTS_PERMISSIONS, userId);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700389 }
390
391 // Maps
392 Intent mapsIntent = new Intent(Intent.ACTION_MAIN);
393 mapsIntent.addCategory(Intent.CATEGORY_APP_MAPS);
Svetoslavcdfd2302015-06-25 19:07:31 -0700394 PackageParser.Package mapsPackage = getDefaultSystemHandlerActivityPackageLPr(
Svet Ganovadc1cf42015-06-15 16:36:24 -0700395 mapsIntent, userId);
396 if (mapsPackage != null
397 && doesPackageSupportRuntimePermissions(mapsPackage)) {
398 grantRuntimePermissionsLPw(mapsPackage, LOCATION_PERMISSIONS, userId);
399 }
400
401 // Email
402 Intent emailIntent = new Intent(Intent.ACTION_MAIN);
403 emailIntent.addCategory(Intent.CATEGORY_APP_EMAIL);
Svetoslavcdfd2302015-06-25 19:07:31 -0700404 PackageParser.Package emailPackage = getDefaultSystemHandlerActivityPackageLPr(
Svet Ganovadc1cf42015-06-15 16:36:24 -0700405 emailIntent, userId);
406 if (emailPackage != null
407 && doesPackageSupportRuntimePermissions(emailPackage)) {
408 grantRuntimePermissionsLPw(emailPackage, CONTACTS_PERMISSIONS, userId);
409 }
410
411 // Browser
Svetoslavcdfd2302015-06-25 19:07:31 -0700412 PackageParser.Package browserPackage = null;
413 String defaultBrowserPackage = mService.getDefaultBrowserPackageName(userId);
414 if (defaultBrowserPackage != null) {
415 browserPackage = getPackageLPr(defaultBrowserPackage);
416 }
417 if (browserPackage == null) {
418 Intent browserIntent = new Intent(Intent.ACTION_MAIN);
419 browserIntent.addCategory(Intent.CATEGORY_APP_BROWSER);
420 browserPackage = getDefaultSystemHandlerActivityPackageLPr(
421 browserIntent, userId);
422 }
Svet Ganovadc1cf42015-06-15 16:36:24 -0700423 if (browserPackage != null
424 && doesPackageSupportRuntimePermissions(browserPackage)) {
425 grantRuntimePermissionsLPw(browserPackage, LOCATION_PERMISSIONS, userId);
426 }
427
428 // IME
429 if (imePackageNames != null) {
430 for (String imePackageName : imePackageNames) {
431 PackageParser.Package imePackage = getSystemPackageLPr(imePackageName);
432 if (imePackage != null
433 && doesPackageSupportRuntimePermissions(imePackage)) {
434 grantRuntimePermissionsLPw(imePackage, CONTACTS_PERMISSIONS, userId);
435 }
436 }
437 }
438
439 // Voice interaction
440 if (voiceInteractPackageNames != null) {
441 for (String voiceInteractPackageName : voiceInteractPackageNames) {
442 PackageParser.Package voiceInteractPackage = getSystemPackageLPr(
443 voiceInteractPackageName);
444 if (voiceInteractPackage != null
445 && doesPackageSupportRuntimePermissions(voiceInteractPackage)) {
446 grantRuntimePermissionsLPw(voiceInteractPackage,
447 CONTACTS_PERMISSIONS, userId);
448 grantRuntimePermissionsLPw(voiceInteractPackage,
449 CALENDAR_PERMISSIONS, userId);
450 grantRuntimePermissionsLPw(voiceInteractPackage,
451 MICROPHONE_PERMISSIONS, userId);
452 grantRuntimePermissionsLPw(voiceInteractPackage,
453 PHONE_PERMISSIONS, userId);
454 grantRuntimePermissionsLPw(voiceInteractPackage,
455 SMS_PERMISSIONS, userId);
456 grantRuntimePermissionsLPw(voiceInteractPackage,
457 LOCATION_PERMISSIONS, userId);
458 }
459 }
460 }
461
462 // Location
463 if (locationPackageNames != null) {
464 for (String packageName : locationPackageNames) {
465 PackageParser.Package locationPackage = getSystemPackageLPr(packageName);
466 if (locationPackage != null
467 && doesPackageSupportRuntimePermissions(locationPackage)) {
468 grantRuntimePermissionsLPw(locationPackage, CONTACTS_PERMISSIONS, userId);
469 grantRuntimePermissionsLPw(locationPackage, CALENDAR_PERMISSIONS, userId);
470 grantRuntimePermissionsLPw(locationPackage, MICROPHONE_PERMISSIONS, userId);
471 grantRuntimePermissionsLPw(locationPackage, PHONE_PERMISSIONS, userId);
472 grantRuntimePermissionsLPw(locationPackage, SMS_PERMISSIONS, userId);
473 grantRuntimePermissionsLPw(locationPackage, LOCATION_PERMISSIONS, userId);
474 grantRuntimePermissionsLPw(locationPackage, CAMERA_PERMISSIONS, userId);
475 grantRuntimePermissionsLPw(locationPackage, SENSORS_PERMISSIONS, userId);
476 grantRuntimePermissionsLPw(locationPackage, STORAGE_PERMISSIONS, userId);
477 }
478 }
479 }
Jeff Davidson2a880312015-06-22 16:54:34 -0700480
Svet Ganovba3ba812015-06-26 10:54:06 -0700481 mService.mSettings.onDefaultRuntimePermissionsGrantedLPr(userId);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700482 }
483 }
484
Svetoslavcdfd2302015-06-25 19:07:31 -0700485 public void grantDefaultPermissionsToDefaultSmsAppLPr(String packageName, int userId) {
486 Log.i(TAG, "Granting permissions to default sms app for user:" + userId);
487 if (packageName == null) {
488 return;
489 }
490 PackageParser.Package smsPackage = getPackageLPr(packageName);
491 if (smsPackage != null && doesPackageSupportRuntimePermissions(smsPackage)) {
492 grantRuntimePermissionsLPw(smsPackage, PHONE_PERMISSIONS, userId);
493 grantRuntimePermissionsLPw(smsPackage, CONTACTS_PERMISSIONS, userId);
494 grantRuntimePermissionsLPw(smsPackage, SMS_PERMISSIONS, userId);
495 }
496 }
497
498 public void grantDefaultPermissionsToDefaultDialerAppLPr(String packageName, int userId) {
499 Log.i(TAG, "Granting permissions to default dialer app for user:" + userId);
500 if (packageName == null) {
501 return;
502 }
503 PackageParser.Package dialerPackage = getPackageLPr(packageName);
504 if (dialerPackage != null
505 && doesPackageSupportRuntimePermissions(dialerPackage)) {
506 grantRuntimePermissionsLPw(dialerPackage, PHONE_PERMISSIONS, userId);
507 grantRuntimePermissionsLPw(dialerPackage, CONTACTS_PERMISSIONS, userId);
508 grantRuntimePermissionsLPw(dialerPackage, SMS_PERMISSIONS, userId);
509 grantRuntimePermissionsLPw(dialerPackage, MICROPHONE_PERMISSIONS, userId);
510 }
511 }
512
513 public void grantDefaultPermissionsToEnabledCarrierAppsLPr(String[] packageNames, int userId) {
514 Log.i(TAG, "Granting permissions to enabled carrier apps for user:" + userId);
515 if (packageNames == null) {
516 return;
517 }
518 for (String packageName : packageNames) {
519 PackageParser.Package carrierPackage = getSystemPackageLPr(packageName);
520 if (carrierPackage != null
521 && doesPackageSupportRuntimePermissions(carrierPackage)) {
522 grantRuntimePermissionsLPw(carrierPackage, PHONE_PERMISSIONS, userId);
523 grantRuntimePermissionsLPw(carrierPackage, LOCATION_PERMISSIONS, userId);
524 }
525 }
526 }
527
528 public void grantDefaultPermissionsToDefaultBrowserLPr(String packageName, int userId) {
529 Log.i(TAG, "Granting permissions to default browser for user:" + userId);
530 if (packageName == null) {
531 return;
532 }
533 PackageParser.Package browserPackage = getSystemPackageLPr(packageName);
534 if (browserPackage != null
535 && doesPackageSupportRuntimePermissions(browserPackage)) {
536 grantRuntimePermissionsLPw(browserPackage, LOCATION_PERMISSIONS, userId);
537 }
538 }
539
Svet Ganovadc1cf42015-06-15 16:36:24 -0700540 private List<PackageParser.Package> getPrivilegedHandlerReceiverPackagesLPr(
541 Intent intent, int userId) {
542 List<ResolveInfo> handlers = mService.queryIntentReceivers(
543 intent, intent.resolveTypeIfNeeded(mService.mContext.getContentResolver()),
544 0, userId);
545 return getPrivilegedPackages(handlers);
546 }
547
548 private List<PackageParser.Package> getPrivilegedHandlerActivityPackagesLPr(
549 Intent intent, int userId) {
550 List<ResolveInfo> handlers = mService.queryIntentActivities(
551 intent, intent.resolveTypeIfNeeded(mService.mContext.getContentResolver()),
552 0, userId);
553 return getPrivilegedPackages(handlers);
554 }
555
556 private List<PackageParser.Package> getPrivilegedPackages(List<ResolveInfo> resolveInfos) {
557 List<PackageParser.Package> handlerPackages = new ArrayList<>();
558 final int handlerCount = resolveInfos.size();
559 for (int i = 0; i < handlerCount; i++) {
560 ResolveInfo handler = resolveInfos.get(i);
561 PackageParser.Package handlerPackage = getPrivilegedPackageLPr(
562 handler.activityInfo.packageName);
563 if (handlerPackage != null) {
564 handlerPackages.add(handlerPackage);
565 }
566 }
567 return handlerPackages;
568 }
569
Svetoslavcdfd2302015-06-25 19:07:31 -0700570 private PackageParser.Package getDefaultSystemHandlerActivityPackageLPr(
Svet Ganovadc1cf42015-06-15 16:36:24 -0700571 Intent intent, int userId) {
572 List<ResolveInfo> handlers = mService.queryIntentActivities(intent, null, 0, userId);
573 final int handlerCount = handlers.size();
574 for (int i = 0; i < handlerCount; i++) {
575 ResolveInfo handler = handlers.get(i);
576 // TODO: This is a temporary hack to figure out the setup app.
577 PackageParser.Package handlerPackage = getSystemPackageLPr(
578 handler.activityInfo.packageName);
579 if (handlerPackage != null) {
580 return handlerPackage;
581 }
582 }
583 return null;
584 }
585
Dianne Hackbornca8e6da2015-06-24 15:19:17 -0700586 private PackageParser.Package getDefaultProviderAuthorityPackageLPr(
587 String authority, int userId) {
588 ProviderInfo provider = mService.resolveContentProvider(authority, 0, userId);
589 if (provider != null) {
590 return getSystemPackageLPr(provider.packageName);
591 }
592 return null;
593 }
594
Svetoslavcdfd2302015-06-25 19:07:31 -0700595 private PackageParser.Package getPackageLPr(String packageName) {
596 return mService.mPackages.get(packageName);
597 }
598
Svet Ganovadc1cf42015-06-15 16:36:24 -0700599 private PackageParser.Package getSystemPackageLPr(String packageName) {
Svetoslavcdfd2302015-06-25 19:07:31 -0700600 PackageParser.Package pkg = getPackageLPr(packageName);
Svet Ganovadc1cf42015-06-15 16:36:24 -0700601 if (pkg != null && pkg.isSystemApp()) {
602 return !isSysComponentOrPersistentPrivApp(pkg) ? pkg : null;
603 }
604 return null;
605 }
606
607 private PackageParser.Package getPrivilegedPackageLPr(String packageName) {
608 PackageParser.Package pkg = mService.mPackages.get(packageName);
609 if (pkg != null && pkg.applicationInfo.isPrivilegedApp()) {
610 return !isSysComponentOrPersistentPrivApp(pkg) ? pkg : null;
611 }
612 return null;
613 }
614
615 private void grantRuntimePermissionsLPw(PackageParser.Package pkg, Set<String> permissions,
616 int userId) {
617 List<String> requestedPermissions = pkg.requestedPermissions;
618
619 if (pkg.isUpdatedSystemApp()) {
620 PackageSetting sysPs = mService.mSettings.getDisabledSystemPkgLPr(pkg.packageName);
621 if (sysPs != null) {
622 requestedPermissions = sysPs.pkg.requestedPermissions;
623 }
624 }
625
626 final int permissionCount = requestedPermissions.size();
627 for (int i = 0; i < permissionCount; i++) {
628 String permission = requestedPermissions.get(i);
629 if (permissions.contains(permission)) {
630 final int flags = mService.getPermissionFlags(permission, pkg.packageName, userId);
631
632 // If any flags are set to the permission, then it is either set in
633 // its current state by the system or device/profile owner or the user.
634 // In all these cases we do not want to clobber the current state.
635 if (flags == 0) {
636 mService.grantRuntimePermission(pkg.packageName, permission, userId);
637 if (DEBUG) {
638 Log.i(TAG, "Granted " + permission + " to default handler "
639 + pkg.packageName);
640 }
641 }
642 }
643 }
644 }
645
646 private void grantInstallPermissionsLPw(PackageParser.Package pkg, Set<String> permissions,
647 int userId) {
648 List<String> requestedPermissions = pkg.requestedPermissions;
649
650 if (pkg.isUpdatedSystemApp()) {
651 PackageSetting sysPs = mService.mSettings.getDisabledSystemPkgLPr(pkg.packageName);
652 if (sysPs != null) {
653 requestedPermissions = sysPs.pkg.requestedPermissions;
654 }
655 }
656
657 final int permissionCount = requestedPermissions.size();
658 for (int i = 0; i < permissionCount; i++) {
659 String permission = requestedPermissions.get(i);
660 if (permissions.contains(permission)) {
661 final int flags = mService.getPermissionFlags(permission, pkg.packageName, userId);
662
663 // If any flags are set to the permission, then it is either set in
664 // its current state by the system or device/profile owner or the user.
665 // In all these cases we do not want to clobber the current state.
666 if (flags == 0) {
667 mService.grantInstallPermissionLPw(permission, pkg);
668 if (DEBUG) {
669 Log.i(TAG, "Granted install " + permission + " to " + pkg.packageName);
670 }
671 }
672 }
673 }
674 }
675
676 private static boolean isSysComponentOrPersistentPrivApp(PackageParser.Package pkg) {
677 return UserHandle.getAppId(pkg.applicationInfo.uid) < FIRST_APPLICATION_UID
678 || ((pkg.applicationInfo.privateFlags
679 & ApplicationInfo.PRIVATE_FLAG_PRIVILEGED) != 0
680 && (pkg.applicationInfo.flags & ApplicationInfo.FLAG_PERSISTENT) != 0);
681 }
682
683 private static boolean doesPackageSupportRuntimePermissions(PackageParser.Package pkg) {
684 return pkg.applicationInfo.targetSdkVersion > Build.VERSION_CODES.LOLLIPOP_MR1;
685 }
686}