1 /* 2 * Copyright (C) 2006 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 17 package android.content.pm; 18 19 import android.annotation.IntDef; 20 import android.annotation.NonNull; 21 import android.annotation.SdkConstant; 22 import android.annotation.SdkConstant.SdkConstantType; 23 import android.annotation.SystemApi; 24 import android.app.PackageDeleteObserver; 25 import android.app.PackageInstallObserver; 26 import android.app.admin.DevicePolicyManager; 27 import android.content.ComponentName; 28 import android.content.Context; 29 import android.content.Intent; 30 import android.content.IntentFilter; 31 import android.content.IntentSender; 32 import android.content.pm.PackageParser.PackageParserException; 33 import android.content.res.Resources; 34 import android.content.res.XmlResourceParser; 35 import android.graphics.Rect; 36 import android.graphics.drawable.Drawable; 37 import android.net.Uri; 38 import android.os.Bundle; 39 import android.os.Environment; 40 import android.os.RemoteException; 41 import android.os.UserHandle; 42 import android.util.AndroidException; 43 44 import java.io.File; 45 import java.lang.annotation.Retention; 46 import java.lang.annotation.RetentionPolicy; 47 import java.util.List; 48 49 /** 50 * Class for retrieving various kinds of information related to the application 51 * packages that are currently installed on the device. 52 * 53 * You can find this class through {@link Context#getPackageManager}. 54 */ 55 public abstract class PackageManager { 56 57 /** 58 * This exception is thrown when a given package, application, or component 59 * name cannot be found. 60 */ 61 public static class NameNotFoundException extends AndroidException { NameNotFoundException()62 public NameNotFoundException() { 63 } 64 NameNotFoundException(String name)65 public NameNotFoundException(String name) { 66 super(name); 67 } 68 } 69 70 /** 71 * {@link PackageInfo} flag: return information about 72 * activities in the package in {@link PackageInfo#activities}. 73 */ 74 public static final int GET_ACTIVITIES = 0x00000001; 75 76 /** 77 * {@link PackageInfo} flag: return information about 78 * intent receivers in the package in 79 * {@link PackageInfo#receivers}. 80 */ 81 public static final int GET_RECEIVERS = 0x00000002; 82 83 /** 84 * {@link PackageInfo} flag: return information about 85 * services in the package in {@link PackageInfo#services}. 86 */ 87 public static final int GET_SERVICES = 0x00000004; 88 89 /** 90 * {@link PackageInfo} flag: return information about 91 * content providers in the package in 92 * {@link PackageInfo#providers}. 93 */ 94 public static final int GET_PROVIDERS = 0x00000008; 95 96 /** 97 * {@link PackageInfo} flag: return information about 98 * instrumentation in the package in 99 * {@link PackageInfo#instrumentation}. 100 */ 101 public static final int GET_INSTRUMENTATION = 0x00000010; 102 103 /** 104 * {@link PackageInfo} flag: return information about the 105 * intent filters supported by the activity. 106 */ 107 public static final int GET_INTENT_FILTERS = 0x00000020; 108 109 /** 110 * {@link PackageInfo} flag: return information about the 111 * signatures included in the package. 112 */ 113 public static final int GET_SIGNATURES = 0x00000040; 114 115 /** 116 * {@link ResolveInfo} flag: return the IntentFilter that 117 * was matched for a particular ResolveInfo in 118 * {@link ResolveInfo#filter}. 119 */ 120 public static final int GET_RESOLVED_FILTER = 0x00000040; 121 122 /** 123 * {@link ComponentInfo} flag: return the {@link ComponentInfo#metaData} 124 * data {@link android.os.Bundle}s that are associated with a component. 125 * This applies for any API returning a ComponentInfo subclass. 126 */ 127 public static final int GET_META_DATA = 0x00000080; 128 129 /** 130 * {@link PackageInfo} flag: return the 131 * {@link PackageInfo#gids group ids} that are associated with an 132 * application. 133 * This applies for any API returning a PackageInfo class, either 134 * directly or nested inside of another. 135 */ 136 public static final int GET_GIDS = 0x00000100; 137 138 /** 139 * {@link PackageInfo} flag: include disabled components in the returned info. 140 */ 141 public static final int GET_DISABLED_COMPONENTS = 0x00000200; 142 143 /** 144 * {@link ApplicationInfo} flag: return the 145 * {@link ApplicationInfo#sharedLibraryFiles paths to the shared libraries} 146 * that are associated with an application. 147 * This applies for any API returning an ApplicationInfo class, either 148 * directly or nested inside of another. 149 */ 150 public static final int GET_SHARED_LIBRARY_FILES = 0x00000400; 151 152 /** 153 * {@link ProviderInfo} flag: return the 154 * {@link ProviderInfo#uriPermissionPatterns URI permission patterns} 155 * that are associated with a content provider. 156 * This applies for any API returning a ProviderInfo class, either 157 * directly or nested inside of another. 158 */ 159 public static final int GET_URI_PERMISSION_PATTERNS = 0x00000800; 160 /** 161 * {@link PackageInfo} flag: return information about 162 * permissions in the package in 163 * {@link PackageInfo#permissions}. 164 */ 165 public static final int GET_PERMISSIONS = 0x00001000; 166 167 /** 168 * Flag parameter to retrieve some information about all applications (even 169 * uninstalled ones) which have data directories. This state could have 170 * resulted if applications have been deleted with flag 171 * {@code DONT_DELETE_DATA} with a possibility of being replaced or 172 * reinstalled in future. 173 * <p> 174 * Note: this flag may cause less information about currently installed 175 * applications to be returned. 176 */ 177 public static final int GET_UNINSTALLED_PACKAGES = 0x00002000; 178 179 /** 180 * {@link PackageInfo} flag: return information about 181 * hardware preferences in 182 * {@link PackageInfo#configPreferences PackageInfo.configPreferences}, 183 * and requested features in {@link PackageInfo#reqFeatures} and 184 * {@link PackageInfo#featureGroups}. 185 */ 186 public static final int GET_CONFIGURATIONS = 0x00004000; 187 188 /** 189 * {@link PackageInfo} flag: include disabled components which are in 190 * that state only because of {@link #COMPONENT_ENABLED_STATE_DISABLED_UNTIL_USED} 191 * in the returned info. Note that if you set this flag, applications 192 * that are in this disabled state will be reported as enabled. 193 */ 194 public static final int GET_DISABLED_UNTIL_USED_COMPONENTS = 0x00008000; 195 196 /** 197 * Resolution and querying flag: if set, only filters that support the 198 * {@link android.content.Intent#CATEGORY_DEFAULT} will be considered for 199 * matching. This is a synonym for including the CATEGORY_DEFAULT in your 200 * supplied Intent. 201 */ 202 public static final int MATCH_DEFAULT_ONLY = 0x00010000; 203 204 /** 205 * Flag for {@link addCrossProfileIntentFilter}: if this flag is set: 206 * when resolving an intent that matches the {@link CrossProfileIntentFilter}, the current 207 * profile will be skipped. 208 * Only activities in the target user can respond to the intent. 209 * @hide 210 */ 211 public static final int SKIP_CURRENT_PROFILE = 0x00000002; 212 213 /** @hide */ 214 @IntDef({PERMISSION_GRANTED, PERMISSION_DENIED}) 215 @Retention(RetentionPolicy.SOURCE) 216 public @interface PermissionResult {} 217 218 /** 219 * Permission check result: this is returned by {@link #checkPermission} 220 * if the permission has been granted to the given package. 221 */ 222 public static final int PERMISSION_GRANTED = 0; 223 224 /** 225 * Permission check result: this is returned by {@link #checkPermission} 226 * if the permission has not been granted to the given package. 227 */ 228 public static final int PERMISSION_DENIED = -1; 229 230 /** 231 * Signature check result: this is returned by {@link #checkSignatures} 232 * if all signatures on the two packages match. 233 */ 234 public static final int SIGNATURE_MATCH = 0; 235 236 /** 237 * Signature check result: this is returned by {@link #checkSignatures} 238 * if neither of the two packages is signed. 239 */ 240 public static final int SIGNATURE_NEITHER_SIGNED = 1; 241 242 /** 243 * Signature check result: this is returned by {@link #checkSignatures} 244 * if the first package is not signed but the second is. 245 */ 246 public static final int SIGNATURE_FIRST_NOT_SIGNED = -1; 247 248 /** 249 * Signature check result: this is returned by {@link #checkSignatures} 250 * if the second package is not signed but the first is. 251 */ 252 public static final int SIGNATURE_SECOND_NOT_SIGNED = -2; 253 254 /** 255 * Signature check result: this is returned by {@link #checkSignatures} 256 * if not all signatures on both packages match. 257 */ 258 public static final int SIGNATURE_NO_MATCH = -3; 259 260 /** 261 * Signature check result: this is returned by {@link #checkSignatures} 262 * if either of the packages are not valid. 263 */ 264 public static final int SIGNATURE_UNKNOWN_PACKAGE = -4; 265 266 /** 267 * Flag for {@link #setApplicationEnabledSetting(String, int, int)} 268 * and {@link #setComponentEnabledSetting(ComponentName, int, int)}: This 269 * component or application is in its default enabled state (as specified 270 * in its manifest). 271 */ 272 public static final int COMPONENT_ENABLED_STATE_DEFAULT = 0; 273 274 /** 275 * Flag for {@link #setApplicationEnabledSetting(String, int, int)} 276 * and {@link #setComponentEnabledSetting(ComponentName, int, int)}: This 277 * component or application has been explictily enabled, regardless of 278 * what it has specified in its manifest. 279 */ 280 public static final int COMPONENT_ENABLED_STATE_ENABLED = 1; 281 282 /** 283 * Flag for {@link #setApplicationEnabledSetting(String, int, int)} 284 * and {@link #setComponentEnabledSetting(ComponentName, int, int)}: This 285 * component or application has been explicitly disabled, regardless of 286 * what it has specified in its manifest. 287 */ 288 public static final int COMPONENT_ENABLED_STATE_DISABLED = 2; 289 290 /** 291 * Flag for {@link #setApplicationEnabledSetting(String, int, int)} only: The 292 * user has explicitly disabled the application, regardless of what it has 293 * specified in its manifest. Because this is due to the user's request, 294 * they may re-enable it if desired through the appropriate system UI. This 295 * option currently <strong>cannot</strong> be used with 296 * {@link #setComponentEnabledSetting(ComponentName, int, int)}. 297 */ 298 public static final int COMPONENT_ENABLED_STATE_DISABLED_USER = 3; 299 300 /** 301 * Flag for {@link #setApplicationEnabledSetting(String, int, int)} only: This 302 * application should be considered, until the point where the user actually 303 * wants to use it. This means that it will not normally show up to the user 304 * (such as in the launcher), but various parts of the user interface can 305 * use {@link #GET_DISABLED_UNTIL_USED_COMPONENTS} to still see it and allow 306 * the user to select it (as for example an IME, device admin, etc). Such code, 307 * once the user has selected the app, should at that point also make it enabled. 308 * This option currently <strong>can not</strong> be used with 309 * {@link #setComponentEnabledSetting(ComponentName, int, int)}. 310 */ 311 public static final int COMPONENT_ENABLED_STATE_DISABLED_UNTIL_USED = 4; 312 313 /** 314 * Flag parameter for {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} to 315 * indicate that this package should be installed as forward locked, i.e. only the app itself 316 * should have access to its code and non-resource assets. 317 * @hide 318 */ 319 public static final int INSTALL_FORWARD_LOCK = 0x00000001; 320 321 /** 322 * Flag parameter for {@link #installPackage} to indicate that you want to replace an already 323 * installed package, if one exists. 324 * @hide 325 */ 326 public static final int INSTALL_REPLACE_EXISTING = 0x00000002; 327 328 /** 329 * Flag parameter for {@link #installPackage} to indicate that you want to 330 * allow test packages (those that have set android:testOnly in their 331 * manifest) to be installed. 332 * @hide 333 */ 334 public static final int INSTALL_ALLOW_TEST = 0x00000004; 335 336 /** 337 * Flag parameter for {@link #installPackage} to indicate that this 338 * package has to be installed on the sdcard. 339 * @hide 340 */ 341 public static final int INSTALL_EXTERNAL = 0x00000008; 342 343 /** 344 * Flag parameter for {@link #installPackage} to indicate that this package 345 * has to be installed on the sdcard. 346 * @hide 347 */ 348 public static final int INSTALL_INTERNAL = 0x00000010; 349 350 /** 351 * Flag parameter for {@link #installPackage} to indicate that this install 352 * was initiated via ADB. 353 * 354 * @hide 355 */ 356 public static final int INSTALL_FROM_ADB = 0x00000020; 357 358 /** 359 * Flag parameter for {@link #installPackage} to indicate that this install 360 * should immediately be visible to all users. 361 * 362 * @hide 363 */ 364 public static final int INSTALL_ALL_USERS = 0x00000040; 365 366 /** 367 * Flag parameter for {@link #installPackage} to indicate that it is okay 368 * to install an update to an app where the newly installed app has a lower 369 * version code than the currently installed app. 370 * 371 * @hide 372 */ 373 public static final int INSTALL_ALLOW_DOWNGRADE = 0x00000080; 374 375 /** 376 * Flag parameter for 377 * {@link #setComponentEnabledSetting(android.content.ComponentName, int, int)} to indicate 378 * that you don't want to kill the app containing the component. Be careful when you set this 379 * since changing component states can make the containing application's behavior unpredictable. 380 */ 381 public static final int DONT_KILL_APP = 0x00000001; 382 383 /** 384 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 385 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} on success. 386 * @hide 387 */ 388 @SystemApi 389 public static final int INSTALL_SUCCEEDED = 1; 390 391 /** 392 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 393 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if the package is 394 * already installed. 395 * @hide 396 */ 397 @SystemApi 398 public static final int INSTALL_FAILED_ALREADY_EXISTS = -1; 399 400 /** 401 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 402 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if the package archive 403 * file is invalid. 404 * @hide 405 */ 406 @SystemApi 407 public static final int INSTALL_FAILED_INVALID_APK = -2; 408 409 /** 410 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 411 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if the URI passed in 412 * is invalid. 413 * @hide 414 */ 415 @SystemApi 416 public static final int INSTALL_FAILED_INVALID_URI = -3; 417 418 /** 419 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 420 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if the package manager 421 * service found that the device didn't have enough storage space to install the app. 422 * @hide 423 */ 424 @SystemApi 425 public static final int INSTALL_FAILED_INSUFFICIENT_STORAGE = -4; 426 427 /** 428 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 429 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if a 430 * package is already installed with the same name. 431 * @hide 432 */ 433 @SystemApi 434 public static final int INSTALL_FAILED_DUPLICATE_PACKAGE = -5; 435 436 /** 437 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 438 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 439 * the requested shared user does not exist. 440 * @hide 441 */ 442 @SystemApi 443 public static final int INSTALL_FAILED_NO_SHARED_USER = -6; 444 445 /** 446 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 447 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 448 * a previously installed package of the same name has a different signature 449 * than the new package (and the old package's data was not removed). 450 * @hide 451 */ 452 @SystemApi 453 public static final int INSTALL_FAILED_UPDATE_INCOMPATIBLE = -7; 454 455 /** 456 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 457 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 458 * the new package is requested a shared user which is already installed on the 459 * device and does not have matching signature. 460 * @hide 461 */ 462 @SystemApi 463 public static final int INSTALL_FAILED_SHARED_USER_INCOMPATIBLE = -8; 464 465 /** 466 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 467 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 468 * the new package uses a shared library that is not available. 469 * @hide 470 */ 471 @SystemApi 472 public static final int INSTALL_FAILED_MISSING_SHARED_LIBRARY = -9; 473 474 /** 475 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 476 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 477 * the new package uses a shared library that is not available. 478 * @hide 479 */ 480 @SystemApi 481 public static final int INSTALL_FAILED_REPLACE_COULDNT_DELETE = -10; 482 483 /** 484 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 485 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 486 * the new package failed while optimizing and validating its dex files, 487 * either because there was not enough storage or the validation failed. 488 * @hide 489 */ 490 @SystemApi 491 public static final int INSTALL_FAILED_DEXOPT = -11; 492 493 /** 494 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 495 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 496 * the new package failed because the current SDK version is older than 497 * that required by the package. 498 * @hide 499 */ 500 @SystemApi 501 public static final int INSTALL_FAILED_OLDER_SDK = -12; 502 503 /** 504 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 505 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 506 * the new package failed because it contains a content provider with the 507 * same authority as a provider already installed in the system. 508 * @hide 509 */ 510 @SystemApi 511 public static final int INSTALL_FAILED_CONFLICTING_PROVIDER = -13; 512 513 /** 514 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 515 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 516 * the new package failed because the current SDK version is newer than 517 * that required by the package. 518 * @hide 519 */ 520 @SystemApi 521 public static final int INSTALL_FAILED_NEWER_SDK = -14; 522 523 /** 524 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 525 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 526 * the new package failed because it has specified that it is a test-only 527 * package and the caller has not supplied the {@link #INSTALL_ALLOW_TEST} 528 * flag. 529 * @hide 530 */ 531 @SystemApi 532 public static final int INSTALL_FAILED_TEST_ONLY = -15; 533 534 /** 535 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 536 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 537 * the package being installed contains native code, but none that is 538 * compatible with the device's CPU_ABI. 539 * @hide 540 */ 541 @SystemApi 542 public static final int INSTALL_FAILED_CPU_ABI_INCOMPATIBLE = -16; 543 544 /** 545 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 546 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 547 * the new package uses a feature that is not available. 548 * @hide 549 */ 550 @SystemApi 551 public static final int INSTALL_FAILED_MISSING_FEATURE = -17; 552 553 // ------ Errors related to sdcard 554 /** 555 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 556 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 557 * a secure container mount point couldn't be accessed on external media. 558 * @hide 559 */ 560 @SystemApi 561 public static final int INSTALL_FAILED_CONTAINER_ERROR = -18; 562 563 /** 564 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 565 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 566 * the new package couldn't be installed in the specified install 567 * location. 568 * @hide 569 */ 570 @SystemApi 571 public static final int INSTALL_FAILED_INVALID_INSTALL_LOCATION = -19; 572 573 /** 574 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 575 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 576 * the new package couldn't be installed in the specified install 577 * location because the media is not available. 578 * @hide 579 */ 580 @SystemApi 581 public static final int INSTALL_FAILED_MEDIA_UNAVAILABLE = -20; 582 583 /** 584 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 585 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 586 * the new package couldn't be installed because the verification timed out. 587 * @hide 588 */ 589 @SystemApi 590 public static final int INSTALL_FAILED_VERIFICATION_TIMEOUT = -21; 591 592 /** 593 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 594 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 595 * the new package couldn't be installed because the verification did not succeed. 596 * @hide 597 */ 598 @SystemApi 599 public static final int INSTALL_FAILED_VERIFICATION_FAILURE = -22; 600 601 /** 602 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 603 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 604 * the package changed from what the calling program expected. 605 * @hide 606 */ 607 @SystemApi 608 public static final int INSTALL_FAILED_PACKAGE_CHANGED = -23; 609 610 /** 611 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 612 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 613 * the new package is assigned a different UID than it previously held. 614 * @hide 615 */ 616 public static final int INSTALL_FAILED_UID_CHANGED = -24; 617 618 /** 619 * Installation return code: this is passed to the {@link IPackageInstallObserver} by 620 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} if 621 * the new package has an older version code than the currently installed package. 622 * @hide 623 */ 624 public static final int INSTALL_FAILED_VERSION_DOWNGRADE = -25; 625 626 /** 627 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 628 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 629 * if the parser was given a path that is not a file, or does not end with the expected 630 * '.apk' extension. 631 * @hide 632 */ 633 @SystemApi 634 public static final int INSTALL_PARSE_FAILED_NOT_APK = -100; 635 636 /** 637 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 638 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 639 * if the parser was unable to retrieve the AndroidManifest.xml file. 640 * @hide 641 */ 642 @SystemApi 643 public static final int INSTALL_PARSE_FAILED_BAD_MANIFEST = -101; 644 645 /** 646 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 647 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 648 * if the parser encountered an unexpected exception. 649 * @hide 650 */ 651 @SystemApi 652 public static final int INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION = -102; 653 654 /** 655 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 656 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 657 * if the parser did not find any certificates in the .apk. 658 * @hide 659 */ 660 @SystemApi 661 public static final int INSTALL_PARSE_FAILED_NO_CERTIFICATES = -103; 662 663 /** 664 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 665 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 666 * if the parser found inconsistent certificates on the files in the .apk. 667 * @hide 668 */ 669 @SystemApi 670 public static final int INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES = -104; 671 672 /** 673 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 674 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 675 * if the parser encountered a CertificateEncodingException in one of the 676 * files in the .apk. 677 * @hide 678 */ 679 @SystemApi 680 public static final int INSTALL_PARSE_FAILED_CERTIFICATE_ENCODING = -105; 681 682 /** 683 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 684 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 685 * if the parser encountered a bad or missing package name in the manifest. 686 * @hide 687 */ 688 @SystemApi 689 public static final int INSTALL_PARSE_FAILED_BAD_PACKAGE_NAME = -106; 690 691 /** 692 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 693 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 694 * if the parser encountered a bad shared user id name in the manifest. 695 * @hide 696 */ 697 @SystemApi 698 public static final int INSTALL_PARSE_FAILED_BAD_SHARED_USER_ID = -107; 699 700 /** 701 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 702 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 703 * if the parser encountered some structural problem in the manifest. 704 * @hide 705 */ 706 @SystemApi 707 public static final int INSTALL_PARSE_FAILED_MANIFEST_MALFORMED = -108; 708 709 /** 710 * Installation parse return code: this is passed to the {@link IPackageInstallObserver} by 711 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 712 * if the parser did not find any actionable tags (instrumentation or application) 713 * in the manifest. 714 * @hide 715 */ 716 @SystemApi 717 public static final int INSTALL_PARSE_FAILED_MANIFEST_EMPTY = -109; 718 719 /** 720 * Installation failed return code: this is passed to the {@link IPackageInstallObserver} by 721 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 722 * if the system failed to install the package because of system issues. 723 * @hide 724 */ 725 @SystemApi 726 public static final int INSTALL_FAILED_INTERNAL_ERROR = -110; 727 728 /** 729 * Installation failed return code: this is passed to the {@link IPackageInstallObserver} by 730 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 731 * if the system failed to install the package because the user is restricted from installing 732 * apps. 733 * @hide 734 */ 735 public static final int INSTALL_FAILED_USER_RESTRICTED = -111; 736 737 /** 738 * Installation failed return code: this is passed to the {@link IPackageInstallObserver} by 739 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 740 * if the system failed to install the package because it is attempting to define a 741 * permission that is already defined by some existing package. 742 * 743 * <p>The package name of the app which has already defined the permission is passed to 744 * a {@link PackageInstallObserver}, if any, as the {@link #EXTRA_EXISTING_PACKAGE} 745 * string extra; and the name of the permission being redefined is passed in the 746 * {@link #EXTRA_EXISTING_PERMISSION} string extra. 747 * @hide 748 */ 749 public static final int INSTALL_FAILED_DUPLICATE_PERMISSION = -112; 750 751 /** 752 * Installation failed return code: this is passed to the {@link IPackageInstallObserver} by 753 * {@link #installPackage(android.net.Uri, IPackageInstallObserver, int)} 754 * if the system failed to install the package because its packaged native code did not 755 * match any of the ABIs supported by the system. 756 * 757 * @hide 758 */ 759 public static final int INSTALL_FAILED_NO_MATCHING_ABIS = -113; 760 761 /** 762 * Internal return code for NativeLibraryHelper methods to indicate that the package 763 * being processed did not contain any native code. This is placed here only so that 764 * it can belong to the same value space as the other install failure codes. 765 * 766 * @hide 767 */ 768 public static final int NO_NATIVE_LIBRARIES = -114; 769 770 /** {@hide} */ 771 public static final int INSTALL_FAILED_ABORTED = -115; 772 773 /** 774 * Flag parameter for {@link #deletePackage} to indicate that you don't want to delete the 775 * package's data directory. 776 * 777 * @hide 778 */ 779 public static final int DELETE_KEEP_DATA = 0x00000001; 780 781 /** 782 * Flag parameter for {@link #deletePackage} to indicate that you want the 783 * package deleted for all users. 784 * 785 * @hide 786 */ 787 public static final int DELETE_ALL_USERS = 0x00000002; 788 789 /** 790 * Flag parameter for {@link #deletePackage} to indicate that, if you are calling 791 * uninstall on a system that has been updated, then don't do the normal process 792 * of uninstalling the update and rolling back to the older system version (which 793 * needs to happen for all users); instead, just mark the app as uninstalled for 794 * the current user. 795 * 796 * @hide 797 */ 798 public static final int DELETE_SYSTEM_APP = 0x00000004; 799 800 /** 801 * Return code for when package deletion succeeds. This is passed to the 802 * {@link IPackageDeleteObserver} by {@link #deletePackage()} if the system 803 * succeeded in deleting the package. 804 * 805 * @hide 806 */ 807 public static final int DELETE_SUCCEEDED = 1; 808 809 /** 810 * Deletion failed return code: this is passed to the 811 * {@link IPackageDeleteObserver} by {@link #deletePackage()} if the system 812 * failed to delete the package for an unspecified reason. 813 * 814 * @hide 815 */ 816 public static final int DELETE_FAILED_INTERNAL_ERROR = -1; 817 818 /** 819 * Deletion failed return code: this is passed to the 820 * {@link IPackageDeleteObserver} by {@link #deletePackage()} if the system 821 * failed to delete the package because it is the active DevicePolicy 822 * manager. 823 * 824 * @hide 825 */ 826 public static final int DELETE_FAILED_DEVICE_POLICY_MANAGER = -2; 827 828 /** 829 * Deletion failed return code: this is passed to the 830 * {@link IPackageDeleteObserver} by {@link #deletePackage()} if the system 831 * failed to delete the package since the user is restricted. 832 * 833 * @hide 834 */ 835 public static final int DELETE_FAILED_USER_RESTRICTED = -3; 836 837 /** 838 * Deletion failed return code: this is passed to the 839 * {@link IPackageDeleteObserver} by {@link #deletePackage()} if the system 840 * failed to delete the package because a profile 841 * or device owner has marked the package as uninstallable. 842 * 843 * @hide 844 */ 845 public static final int DELETE_FAILED_OWNER_BLOCKED = -4; 846 847 /** {@hide} */ 848 public static final int DELETE_FAILED_ABORTED = -5; 849 850 /** 851 * Return code that is passed to the {@link IPackageMoveObserver} by 852 * {@link #movePackage(android.net.Uri, IPackageMoveObserver)} when the 853 * package has been successfully moved by the system. 854 * 855 * @hide 856 */ 857 public static final int MOVE_SUCCEEDED = 1; 858 /** 859 * Error code that is passed to the {@link IPackageMoveObserver} by 860 * {@link #movePackage(android.net.Uri, IPackageMoveObserver)} 861 * when the package hasn't been successfully moved by the system 862 * because of insufficient memory on specified media. 863 * @hide 864 */ 865 public static final int MOVE_FAILED_INSUFFICIENT_STORAGE = -1; 866 867 /** 868 * Error code that is passed to the {@link IPackageMoveObserver} by 869 * {@link #movePackage(android.net.Uri, IPackageMoveObserver)} 870 * if the specified package doesn't exist. 871 * @hide 872 */ 873 public static final int MOVE_FAILED_DOESNT_EXIST = -2; 874 875 /** 876 * Error code that is passed to the {@link IPackageMoveObserver} by 877 * {@link #movePackage(android.net.Uri, IPackageMoveObserver)} 878 * if the specified package cannot be moved since its a system package. 879 * @hide 880 */ 881 public static final int MOVE_FAILED_SYSTEM_PACKAGE = -3; 882 883 /** 884 * Error code that is passed to the {@link IPackageMoveObserver} by 885 * {@link #movePackage(android.net.Uri, IPackageMoveObserver)} 886 * if the specified package cannot be moved since its forward locked. 887 * @hide 888 */ 889 public static final int MOVE_FAILED_FORWARD_LOCKED = -4; 890 891 /** 892 * Error code that is passed to the {@link IPackageMoveObserver} by 893 * {@link #movePackage(android.net.Uri, IPackageMoveObserver)} 894 * if the specified package cannot be moved to the specified location. 895 * @hide 896 */ 897 public static final int MOVE_FAILED_INVALID_LOCATION = -5; 898 899 /** 900 * Error code that is passed to the {@link IPackageMoveObserver} by 901 * {@link #movePackage(android.net.Uri, IPackageMoveObserver)} 902 * if the specified package cannot be moved to the specified location. 903 * @hide 904 */ 905 public static final int MOVE_FAILED_INTERNAL_ERROR = -6; 906 907 /** 908 * Error code that is passed to the {@link IPackageMoveObserver} by 909 * {@link #movePackage(android.net.Uri, IPackageMoveObserver)} if the 910 * specified package already has an operation pending in the 911 * {@link PackageHandler} queue. 912 * 913 * @hide 914 */ 915 public static final int MOVE_FAILED_OPERATION_PENDING = -7; 916 917 /** 918 * Flag parameter for {@link #movePackage} to indicate that 919 * the package should be moved to internal storage if its 920 * been installed on external media. 921 * @hide 922 */ 923 public static final int MOVE_INTERNAL = 0x00000001; 924 925 /** 926 * Flag parameter for {@link #movePackage} to indicate that 927 * the package should be moved to external media. 928 * @hide 929 */ 930 public static final int MOVE_EXTERNAL_MEDIA = 0x00000002; 931 932 /** 933 * Usable by the required verifier as the {@code verificationCode} argument 934 * for {@link PackageManager#verifyPendingInstall} to indicate that it will 935 * allow the installation to proceed without any of the optional verifiers 936 * needing to vote. 937 * 938 * @hide 939 */ 940 public static final int VERIFICATION_ALLOW_WITHOUT_SUFFICIENT = 2; 941 942 /** 943 * Used as the {@code verificationCode} argument for 944 * {@link PackageManager#verifyPendingInstall} to indicate that the calling 945 * package verifier allows the installation to proceed. 946 */ 947 public static final int VERIFICATION_ALLOW = 1; 948 949 /** 950 * Used as the {@code verificationCode} argument for 951 * {@link PackageManager#verifyPendingInstall} to indicate the calling 952 * package verifier does not vote to allow the installation to proceed. 953 */ 954 public static final int VERIFICATION_REJECT = -1; 955 956 /** 957 * Can be used as the {@code millisecondsToDelay} argument for 958 * {@link PackageManager#extendVerificationTimeout}. This is the 959 * maximum time {@code PackageManager} waits for the verification 960 * agent to return (in milliseconds). 961 */ 962 public static final long MAXIMUM_VERIFICATION_TIMEOUT = 60*60*1000; 963 964 /** 965 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: The device's 966 * audio pipeline is low-latency, more suitable for audio applications sensitive to delays or 967 * lag in sound input or output. 968 */ 969 @SdkConstant(SdkConstantType.FEATURE) 970 public static final String FEATURE_AUDIO_LOW_LATENCY = "android.hardware.audio.low_latency"; 971 972 /** 973 * Feature for {@link #getSystemAvailableFeatures} and 974 * {@link #hasSystemFeature}: The device includes at least one form of audio 975 * output, such as speakers, audio jack or streaming over bluetooth 976 */ 977 @SdkConstant(SdkConstantType.FEATURE) 978 public static final String FEATURE_AUDIO_OUTPUT = "android.hardware.audio.output"; 979 980 /** 981 * Feature for {@link #getSystemAvailableFeatures} and 982 * {@link #hasSystemFeature}: The device is capable of communicating with 983 * other devices via Bluetooth. 984 */ 985 @SdkConstant(SdkConstantType.FEATURE) 986 public static final String FEATURE_BLUETOOTH = "android.hardware.bluetooth"; 987 988 /** 989 * Feature for {@link #getSystemAvailableFeatures} and 990 * {@link #hasSystemFeature}: The device is capable of communicating with 991 * other devices via Bluetooth Low Energy radio. 992 */ 993 @SdkConstant(SdkConstantType.FEATURE) 994 public static final String FEATURE_BLUETOOTH_LE = "android.hardware.bluetooth_le"; 995 996 /** 997 * Feature for {@link #getSystemAvailableFeatures} and 998 * {@link #hasSystemFeature}: The device has a camera facing away 999 * from the screen. 1000 */ 1001 @SdkConstant(SdkConstantType.FEATURE) 1002 public static final String FEATURE_CAMERA = "android.hardware.camera"; 1003 1004 /** 1005 * Feature for {@link #getSystemAvailableFeatures} and 1006 * {@link #hasSystemFeature}: The device's camera supports auto-focus. 1007 */ 1008 @SdkConstant(SdkConstantType.FEATURE) 1009 public static final String FEATURE_CAMERA_AUTOFOCUS = "android.hardware.camera.autofocus"; 1010 1011 /** 1012 * Feature for {@link #getSystemAvailableFeatures} and 1013 * {@link #hasSystemFeature}: The device has at least one camera pointing in 1014 * some direction, or can support an external camera being connected to it. 1015 */ 1016 @SdkConstant(SdkConstantType.FEATURE) 1017 public static final String FEATURE_CAMERA_ANY = "android.hardware.camera.any"; 1018 1019 /** 1020 * Feature for {@link #getSystemAvailableFeatures} and 1021 * {@link #hasSystemFeature}: The device can support having an external camera connected to it. 1022 * The external camera may not always be connected or available to applications to use. 1023 */ 1024 @SdkConstant(SdkConstantType.FEATURE) 1025 public static final String FEATURE_CAMERA_EXTERNAL = "android.hardware.camera.external"; 1026 1027 /** 1028 * Feature for {@link #getSystemAvailableFeatures} and 1029 * {@link #hasSystemFeature}: The device's camera supports flash. 1030 */ 1031 @SdkConstant(SdkConstantType.FEATURE) 1032 public static final String FEATURE_CAMERA_FLASH = "android.hardware.camera.flash"; 1033 1034 /** 1035 * Feature for {@link #getSystemAvailableFeatures} and 1036 * {@link #hasSystemFeature}: The device has a front facing camera. 1037 */ 1038 @SdkConstant(SdkConstantType.FEATURE) 1039 public static final String FEATURE_CAMERA_FRONT = "android.hardware.camera.front"; 1040 1041 /** 1042 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: At least one 1043 * of the cameras on the device supports the 1044 * {@link android.hardware.camera2.CameraCharacteristics#INFO_SUPPORTED_HARDWARE_LEVEL full hardware} 1045 * capability level. 1046 */ 1047 @SdkConstant(SdkConstantType.FEATURE) 1048 public static final String FEATURE_CAMERA_LEVEL_FULL = "android.hardware.camera.level.full"; 1049 1050 /** 1051 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: At least one 1052 * of the cameras on the device supports the 1053 * {@link android.hardware.camera2.CameraMetadata#REQUEST_AVAILABLE_CAPABILITIES_MANUAL_SENSOR manual sensor} 1054 * capability level. 1055 */ 1056 @SdkConstant(SdkConstantType.FEATURE) 1057 public static final String FEATURE_CAMERA_CAPABILITY_MANUAL_SENSOR = 1058 "android.hardware.camera.capability.manual_sensor"; 1059 1060 /** 1061 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: At least one 1062 * of the cameras on the device supports the 1063 * {@link android.hardware.camera2.CameraMetadata#REQUEST_AVAILABLE_CAPABILITIES_MANUAL_POST_PROCESSING manual post-processing} 1064 * capability level. 1065 */ 1066 @SdkConstant(SdkConstantType.FEATURE) 1067 public static final String FEATURE_CAMERA_CAPABILITY_MANUAL_POST_PROCESSING = 1068 "android.hardware.camera.capability.manual_post_processing"; 1069 1070 /** 1071 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: At least one 1072 * of the cameras on the device supports the 1073 * {@link android.hardware.camera2.CameraMetadata#REQUEST_AVAILABLE_CAPABILITIES_RAW RAW} 1074 * capability level. 1075 */ 1076 @SdkConstant(SdkConstantType.FEATURE) 1077 public static final String FEATURE_CAMERA_CAPABILITY_RAW = 1078 "android.hardware.camera.capability.raw"; 1079 1080 /** 1081 * Feature for {@link #getSystemAvailableFeatures} and 1082 * {@link #hasSystemFeature}: The device is capable of communicating with 1083 * consumer IR devices. 1084 */ 1085 @SdkConstant(SdkConstantType.FEATURE) 1086 public static final String FEATURE_CONSUMER_IR = "android.hardware.consumerir"; 1087 1088 /** 1089 * Feature for {@link #getSystemAvailableFeatures} and 1090 * {@link #hasSystemFeature}: The device supports one or more methods of 1091 * reporting current location. 1092 */ 1093 @SdkConstant(SdkConstantType.FEATURE) 1094 public static final String FEATURE_LOCATION = "android.hardware.location"; 1095 1096 /** 1097 * Feature for {@link #getSystemAvailableFeatures} and 1098 * {@link #hasSystemFeature}: The device has a Global Positioning System 1099 * receiver and can report precise location. 1100 */ 1101 @SdkConstant(SdkConstantType.FEATURE) 1102 public static final String FEATURE_LOCATION_GPS = "android.hardware.location.gps"; 1103 1104 /** 1105 * Feature for {@link #getSystemAvailableFeatures} and 1106 * {@link #hasSystemFeature}: The device can report location with coarse 1107 * accuracy using a network-based geolocation system. 1108 */ 1109 @SdkConstant(SdkConstantType.FEATURE) 1110 public static final String FEATURE_LOCATION_NETWORK = "android.hardware.location.network"; 1111 1112 /** 1113 * Feature for {@link #getSystemAvailableFeatures} and 1114 * {@link #hasSystemFeature}: The device can record audio via a 1115 * microphone. 1116 */ 1117 @SdkConstant(SdkConstantType.FEATURE) 1118 public static final String FEATURE_MICROPHONE = "android.hardware.microphone"; 1119 1120 /** 1121 * Feature for {@link #getSystemAvailableFeatures} and 1122 * {@link #hasSystemFeature}: The device can communicate using Near-Field 1123 * Communications (NFC). 1124 */ 1125 @SdkConstant(SdkConstantType.FEATURE) 1126 public static final String FEATURE_NFC = "android.hardware.nfc"; 1127 1128 /** 1129 * Feature for {@link #getSystemAvailableFeatures} and 1130 * {@link #hasSystemFeature}: The device supports host- 1131 * based NFC card emulation. 1132 * 1133 * TODO remove when depending apps have moved to new constant. 1134 * @hide 1135 * @deprecated 1136 */ 1137 @Deprecated 1138 @SdkConstant(SdkConstantType.FEATURE) 1139 public static final String FEATURE_NFC_HCE = "android.hardware.nfc.hce"; 1140 1141 /** 1142 * Feature for {@link #getSystemAvailableFeatures} and 1143 * {@link #hasSystemFeature}: The device supports host- 1144 * based NFC card emulation. 1145 */ 1146 @SdkConstant(SdkConstantType.FEATURE) 1147 public static final String FEATURE_NFC_HOST_CARD_EMULATION = "android.hardware.nfc.hce"; 1148 1149 /** 1150 * Feature for {@link #getSystemAvailableFeatures} and 1151 * {@link #hasSystemFeature}: The device supports the OpenGL ES 1152 * <a href="http://www.khronos.org/registry/gles/extensions/ANDROID/ANDROID_extension_pack_es31a.txt"> 1153 * Android Extension Pack</a>. 1154 */ 1155 @SdkConstant(SdkConstantType.FEATURE) 1156 public static final String FEATURE_OPENGLES_EXTENSION_PACK = "android.hardware.opengles.aep"; 1157 1158 /** 1159 * Feature for {@link #getSystemAvailableFeatures} and 1160 * {@link #hasSystemFeature}: The device includes an accelerometer. 1161 */ 1162 @SdkConstant(SdkConstantType.FEATURE) 1163 public static final String FEATURE_SENSOR_ACCELEROMETER = "android.hardware.sensor.accelerometer"; 1164 1165 /** 1166 * Feature for {@link #getSystemAvailableFeatures} and 1167 * {@link #hasSystemFeature}: The device includes a barometer (air 1168 * pressure sensor.) 1169 */ 1170 @SdkConstant(SdkConstantType.FEATURE) 1171 public static final String FEATURE_SENSOR_BAROMETER = "android.hardware.sensor.barometer"; 1172 1173 /** 1174 * Feature for {@link #getSystemAvailableFeatures} and 1175 * {@link #hasSystemFeature}: The device includes a magnetometer (compass). 1176 */ 1177 @SdkConstant(SdkConstantType.FEATURE) 1178 public static final String FEATURE_SENSOR_COMPASS = "android.hardware.sensor.compass"; 1179 1180 /** 1181 * Feature for {@link #getSystemAvailableFeatures} and 1182 * {@link #hasSystemFeature}: The device includes a gyroscope. 1183 */ 1184 @SdkConstant(SdkConstantType.FEATURE) 1185 public static final String FEATURE_SENSOR_GYROSCOPE = "android.hardware.sensor.gyroscope"; 1186 1187 /** 1188 * Feature for {@link #getSystemAvailableFeatures} and 1189 * {@link #hasSystemFeature}: The device includes a light sensor. 1190 */ 1191 @SdkConstant(SdkConstantType.FEATURE) 1192 public static final String FEATURE_SENSOR_LIGHT = "android.hardware.sensor.light"; 1193 1194 /** 1195 * Feature for {@link #getSystemAvailableFeatures} and 1196 * {@link #hasSystemFeature}: The device includes a proximity sensor. 1197 */ 1198 @SdkConstant(SdkConstantType.FEATURE) 1199 public static final String FEATURE_SENSOR_PROXIMITY = "android.hardware.sensor.proximity"; 1200 1201 /** 1202 * Feature for {@link #getSystemAvailableFeatures} and 1203 * {@link #hasSystemFeature}: The device includes a hardware step counter. 1204 */ 1205 @SdkConstant(SdkConstantType.FEATURE) 1206 public static final String FEATURE_SENSOR_STEP_COUNTER = "android.hardware.sensor.stepcounter"; 1207 1208 /** 1209 * Feature for {@link #getSystemAvailableFeatures} and 1210 * {@link #hasSystemFeature}: The device includes a hardware step detector. 1211 */ 1212 @SdkConstant(SdkConstantType.FEATURE) 1213 public static final String FEATURE_SENSOR_STEP_DETECTOR = "android.hardware.sensor.stepdetector"; 1214 1215 /** 1216 * Feature for {@link #getSystemAvailableFeatures} and 1217 * {@link #hasSystemFeature}: The device includes a heart rate monitor. 1218 */ 1219 @SdkConstant(SdkConstantType.FEATURE) 1220 public static final String FEATURE_SENSOR_HEART_RATE = "android.hardware.sensor.heartrate"; 1221 1222 /** 1223 * Feature for {@link #getSystemAvailableFeatures} and 1224 * {@link #hasSystemFeature}: The heart rate sensor on this device is an Electrocargiogram. 1225 */ 1226 @SdkConstant(SdkConstantType.FEATURE) 1227 public static final String FEATURE_SENSOR_HEART_RATE_ECG = 1228 "android.hardware.sensor.heartrate.ecg"; 1229 1230 /** 1231 * Feature for {@link #getSystemAvailableFeatures} and 1232 * {@link #hasSystemFeature}: The device includes a relative humidity sensor. 1233 */ 1234 @SdkConstant(SdkConstantType.FEATURE) 1235 public static final String FEATURE_SENSOR_RELATIVE_HUMIDITY = 1236 "android.hardware.sensor.relative_humidity"; 1237 1238 /** 1239 * Feature for {@link #getSystemAvailableFeatures} and 1240 * {@link #hasSystemFeature}: The device includes an ambient temperature sensor. 1241 */ 1242 @SdkConstant(SdkConstantType.FEATURE) 1243 public static final String FEATURE_SENSOR_AMBIENT_TEMPERATURE = 1244 "android.hardware.sensor.ambient_temperature"; 1245 1246 /** 1247 * Feature for {@link #getSystemAvailableFeatures} and 1248 * {@link #hasSystemFeature}: The device has a telephony radio with data 1249 * communication support. 1250 */ 1251 @SdkConstant(SdkConstantType.FEATURE) 1252 public static final String FEATURE_TELEPHONY = "android.hardware.telephony"; 1253 1254 /** 1255 * Feature for {@link #getSystemAvailableFeatures} and 1256 * {@link #hasSystemFeature}: The device has a CDMA telephony stack. 1257 */ 1258 @SdkConstant(SdkConstantType.FEATURE) 1259 public static final String FEATURE_TELEPHONY_CDMA = "android.hardware.telephony.cdma"; 1260 1261 /** 1262 * Feature for {@link #getSystemAvailableFeatures} and 1263 * {@link #hasSystemFeature}: The device has a GSM telephony stack. 1264 */ 1265 @SdkConstant(SdkConstantType.FEATURE) 1266 public static final String FEATURE_TELEPHONY_GSM = "android.hardware.telephony.gsm"; 1267 1268 /** 1269 * Feature for {@link #getSystemAvailableFeatures} and 1270 * {@link #hasSystemFeature}: The device supports connecting to USB devices 1271 * as the USB host. 1272 */ 1273 @SdkConstant(SdkConstantType.FEATURE) 1274 public static final String FEATURE_USB_HOST = "android.hardware.usb.host"; 1275 1276 /** 1277 * Feature for {@link #getSystemAvailableFeatures} and 1278 * {@link #hasSystemFeature}: The device supports connecting to USB accessories. 1279 */ 1280 @SdkConstant(SdkConstantType.FEATURE) 1281 public static final String FEATURE_USB_ACCESSORY = "android.hardware.usb.accessory"; 1282 1283 /** 1284 * Feature for {@link #getSystemAvailableFeatures} and 1285 * {@link #hasSystemFeature}: The SIP API is enabled on the device. 1286 */ 1287 @SdkConstant(SdkConstantType.FEATURE) 1288 public static final String FEATURE_SIP = "android.software.sip"; 1289 1290 /** 1291 * Feature for {@link #getSystemAvailableFeatures} and 1292 * {@link #hasSystemFeature}: The device supports SIP-based VOIP. 1293 */ 1294 @SdkConstant(SdkConstantType.FEATURE) 1295 public static final String FEATURE_SIP_VOIP = "android.software.sip.voip"; 1296 1297 /** 1298 * Feature for {@link #getSystemAvailableFeatures} and 1299 * {@link #hasSystemFeature}: The Connection Service API is enabled on the device. 1300 */ 1301 @SdkConstant(SdkConstantType.FEATURE) 1302 public static final String FEATURE_CONNECTION_SERVICE = "android.software.connectionservice"; 1303 1304 /** 1305 * Feature for {@link #getSystemAvailableFeatures} and 1306 * {@link #hasSystemFeature}: The device's display has a touch screen. 1307 */ 1308 @SdkConstant(SdkConstantType.FEATURE) 1309 public static final String FEATURE_TOUCHSCREEN = "android.hardware.touchscreen"; 1310 1311 /** 1312 * Feature for {@link #getSystemAvailableFeatures} and 1313 * {@link #hasSystemFeature}: The device's touch screen supports 1314 * multitouch sufficient for basic two-finger gesture detection. 1315 */ 1316 @SdkConstant(SdkConstantType.FEATURE) 1317 public static final String FEATURE_TOUCHSCREEN_MULTITOUCH = "android.hardware.touchscreen.multitouch"; 1318 1319 /** 1320 * Feature for {@link #getSystemAvailableFeatures} and 1321 * {@link #hasSystemFeature}: The device's touch screen is capable of 1322 * tracking two or more fingers fully independently. 1323 */ 1324 @SdkConstant(SdkConstantType.FEATURE) 1325 public static final String FEATURE_TOUCHSCREEN_MULTITOUCH_DISTINCT = "android.hardware.touchscreen.multitouch.distinct"; 1326 1327 /** 1328 * Feature for {@link #getSystemAvailableFeatures} and 1329 * {@link #hasSystemFeature}: The device's touch screen is capable of 1330 * tracking a full hand of fingers fully independently -- that is, 5 or 1331 * more simultaneous independent pointers. 1332 */ 1333 @SdkConstant(SdkConstantType.FEATURE) 1334 public static final String FEATURE_TOUCHSCREEN_MULTITOUCH_JAZZHAND = "android.hardware.touchscreen.multitouch.jazzhand"; 1335 1336 /** 1337 * Feature for {@link #getSystemAvailableFeatures} and 1338 * {@link #hasSystemFeature}: The device does not have a touch screen, but 1339 * does support touch emulation for basic events. For instance, the 1340 * device might use a mouse or remote control to drive a cursor, and 1341 * emulate basic touch pointer events like down, up, drag, etc. All 1342 * devices that support android.hardware.touchscreen or a sub-feature are 1343 * presumed to also support faketouch. 1344 */ 1345 @SdkConstant(SdkConstantType.FEATURE) 1346 public static final String FEATURE_FAKETOUCH = "android.hardware.faketouch"; 1347 1348 /** 1349 * Feature for {@link #getSystemAvailableFeatures} and 1350 * {@link #hasSystemFeature}: The device does not have a touch screen, but 1351 * does support touch emulation for basic events that supports distinct 1352 * tracking of two or more fingers. This is an extension of 1353 * {@link #FEATURE_FAKETOUCH} for input devices with this capability. Note 1354 * that unlike a distinct multitouch screen as defined by 1355 * {@link #FEATURE_TOUCHSCREEN_MULTITOUCH_DISTINCT}, these kinds of input 1356 * devices will not actually provide full two-finger gestures since the 1357 * input is being transformed to cursor movement on the screen. That is, 1358 * single finger gestures will move a cursor; two-finger swipes will 1359 * result in single-finger touch events; other two-finger gestures will 1360 * result in the corresponding two-finger touch event. 1361 */ 1362 @SdkConstant(SdkConstantType.FEATURE) 1363 public static final String FEATURE_FAKETOUCH_MULTITOUCH_DISTINCT = "android.hardware.faketouch.multitouch.distinct"; 1364 1365 /** 1366 * Feature for {@link #getSystemAvailableFeatures} and 1367 * {@link #hasSystemFeature}: The device does not have a touch screen, but 1368 * does support touch emulation for basic events that supports tracking 1369 * a hand of fingers (5 or more fingers) fully independently. 1370 * This is an extension of 1371 * {@link #FEATURE_FAKETOUCH} for input devices with this capability. Note 1372 * that unlike a multitouch screen as defined by 1373 * {@link #FEATURE_TOUCHSCREEN_MULTITOUCH_JAZZHAND}, not all two finger 1374 * gestures can be detected due to the limitations described for 1375 * {@link #FEATURE_FAKETOUCH_MULTITOUCH_DISTINCT}. 1376 */ 1377 @SdkConstant(SdkConstantType.FEATURE) 1378 public static final String FEATURE_FAKETOUCH_MULTITOUCH_JAZZHAND = "android.hardware.faketouch.multitouch.jazzhand"; 1379 1380 /** 1381 * Feature for {@link #getSystemAvailableFeatures} and 1382 * {@link #hasSystemFeature}: The device supports portrait orientation 1383 * screens. For backwards compatibility, you can assume that if neither 1384 * this nor {@link #FEATURE_SCREEN_LANDSCAPE} is set then the device supports 1385 * both portrait and landscape. 1386 */ 1387 @SdkConstant(SdkConstantType.FEATURE) 1388 public static final String FEATURE_SCREEN_PORTRAIT = "android.hardware.screen.portrait"; 1389 1390 /** 1391 * Feature for {@link #getSystemAvailableFeatures} and 1392 * {@link #hasSystemFeature}: The device supports landscape orientation 1393 * screens. For backwards compatibility, you can assume that if neither 1394 * this nor {@link #FEATURE_SCREEN_PORTRAIT} is set then the device supports 1395 * both portrait and landscape. 1396 */ 1397 @SdkConstant(SdkConstantType.FEATURE) 1398 public static final String FEATURE_SCREEN_LANDSCAPE = "android.hardware.screen.landscape"; 1399 1400 /** 1401 * Feature for {@link #getSystemAvailableFeatures} and 1402 * {@link #hasSystemFeature}: The device supports live wallpapers. 1403 */ 1404 @SdkConstant(SdkConstantType.FEATURE) 1405 public static final String FEATURE_LIVE_WALLPAPER = "android.software.live_wallpaper"; 1406 /** 1407 * Feature for {@link #getSystemAvailableFeatures} and 1408 * {@link #hasSystemFeature}: The device supports app widgets. 1409 */ 1410 @SdkConstant(SdkConstantType.FEATURE) 1411 public static final String FEATURE_APP_WIDGETS = "android.software.app_widgets"; 1412 1413 /** 1414 * @hide 1415 * Feature for {@link #getSystemAvailableFeatures} and 1416 * {@link #hasSystemFeature}: The device supports 1417 * {@link android.service.voice.VoiceInteractionService} and 1418 * {@link android.app.VoiceInteractor}. 1419 */ 1420 @SdkConstant(SdkConstantType.FEATURE) 1421 public static final String FEATURE_VOICE_RECOGNIZERS = "android.software.voice_recognizers"; 1422 1423 1424 /** 1425 * Feature for {@link #getSystemAvailableFeatures} and 1426 * {@link #hasSystemFeature}: The device supports a home screen that is replaceable 1427 * by third party applications. 1428 */ 1429 @SdkConstant(SdkConstantType.FEATURE) 1430 public static final String FEATURE_HOME_SCREEN = "android.software.home_screen"; 1431 1432 /** 1433 * Feature for {@link #getSystemAvailableFeatures} and 1434 * {@link #hasSystemFeature}: The device supports adding new input methods implemented 1435 * with the {@link android.inputmethodservice.InputMethodService} API. 1436 */ 1437 @SdkConstant(SdkConstantType.FEATURE) 1438 public static final String FEATURE_INPUT_METHODS = "android.software.input_methods"; 1439 1440 /** 1441 * Feature for {@link #getSystemAvailableFeatures} and 1442 * {@link #hasSystemFeature}: The device supports device policy enforcement via device admins. 1443 */ 1444 @SdkConstant(SdkConstantType.FEATURE) 1445 public static final String FEATURE_DEVICE_ADMIN = "android.software.device_admin"; 1446 1447 /** 1448 * Feature for {@link #getSystemAvailableFeatures} and 1449 * {@link #hasSystemFeature}: The device supports leanback UI. This is 1450 * typically used in a living room television experience, but is a software 1451 * feature unlike {@link #FEATURE_TELEVISION}. Devices running with this 1452 * feature will use resources associated with the "television" UI mode. 1453 */ 1454 @SdkConstant(SdkConstantType.FEATURE) 1455 public static final String FEATURE_LEANBACK = "android.software.leanback"; 1456 1457 /** 1458 * Feature for {@link #getSystemAvailableFeatures} and 1459 * {@link #hasSystemFeature}: The device supports only leanback UI. Only 1460 * applications designed for this experience should be run, though this is 1461 * not enforced by the system. 1462 * @hide 1463 */ 1464 @SdkConstant(SdkConstantType.FEATURE) 1465 public static final String FEATURE_LEANBACK_ONLY = "android.software.leanback_only"; 1466 1467 /** 1468 * Feature for {@link #getSystemAvailableFeatures} and 1469 * {@link #hasSystemFeature}: The device supports live TV and can display 1470 * contents from TV inputs implemented with the 1471 * {@link android.media.tv.TvInputService} API. 1472 */ 1473 @SdkConstant(SdkConstantType.FEATURE) 1474 public static final String FEATURE_LIVE_TV = "android.software.live_tv"; 1475 1476 /** 1477 * Feature for {@link #getSystemAvailableFeatures} and 1478 * {@link #hasSystemFeature}: The device supports WiFi (802.11) networking. 1479 */ 1480 @SdkConstant(SdkConstantType.FEATURE) 1481 public static final String FEATURE_WIFI = "android.hardware.wifi"; 1482 1483 /** 1484 * Feature for {@link #getSystemAvailableFeatures} and 1485 * {@link #hasSystemFeature}: The device supports Wi-Fi Direct networking. 1486 */ 1487 @SdkConstant(SdkConstantType.FEATURE) 1488 public static final String FEATURE_WIFI_DIRECT = "android.hardware.wifi.direct"; 1489 1490 /** 1491 * Feature for {@link #getSystemAvailableFeatures} and 1492 * {@link #hasSystemFeature}: This is a device dedicated to showing UI 1493 * on a television. Television here is defined to be a typical living 1494 * room television experience: displayed on a big screen, where the user 1495 * is sitting far away from it, and the dominant form of input will be 1496 * something like a DPAD, not through touch or mouse. 1497 * @deprecated use {@link #FEATURE_LEANBACK} instead. 1498 */ 1499 @Deprecated 1500 @SdkConstant(SdkConstantType.FEATURE) 1501 public static final String FEATURE_TELEVISION = "android.hardware.type.television"; 1502 1503 /** 1504 * Feature for {@link #getSystemAvailableFeatures} and 1505 * {@link #hasSystemFeature}: This is a device dedicated to showing UI 1506 * on a watch. A watch here is defined to be a device worn on the body, perhaps on 1507 * the wrist. The user is very close when interacting with the device. 1508 */ 1509 @SdkConstant(SdkConstantType.FEATURE) 1510 public static final String FEATURE_WATCH = "android.hardware.type.watch"; 1511 1512 /** 1513 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: 1514 * The device supports printing. 1515 */ 1516 @SdkConstant(SdkConstantType.FEATURE) 1517 public static final String FEATURE_PRINTING = "android.software.print"; 1518 1519 /** 1520 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: 1521 * The device can perform backup and restore operations on installed applications. 1522 */ 1523 @SdkConstant(SdkConstantType.FEATURE) 1524 public static final String FEATURE_BACKUP = "android.software.backup"; 1525 1526 /** 1527 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: 1528 * The device supports creating secondary users and managed profiles via 1529 * {@link DevicePolicyManager}. 1530 */ 1531 @SdkConstant(SdkConstantType.FEATURE) 1532 public static final String FEATURE_MANAGED_USERS = "android.software.managed_users"; 1533 1534 /** 1535 * @hide 1536 * TODO: Remove after dependencies updated b/17392243 1537 */ 1538 public static final String FEATURE_MANAGED_PROFILES = "android.software.managed_users"; 1539 1540 /** 1541 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: 1542 * The device supports verified boot. 1543 */ 1544 @SdkConstant(SdkConstantType.FEATURE) 1545 public static final String FEATURE_VERIFIED_BOOT = "android.software.verified_boot"; 1546 1547 /** 1548 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: 1549 * The device supports secure removal of users. When a user is deleted the data associated 1550 * with that user is securely deleted and no longer available. 1551 */ 1552 @SdkConstant(SdkConstantType.FEATURE) 1553 public static final String FEATURE_SECURELY_REMOVES_USERS 1554 = "android.software.securely_removes_users"; 1555 1556 /** 1557 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: 1558 * The device has a full implementation of the android.webkit.* APIs. Devices 1559 * lacking this feature will not have a functioning WebView implementation. 1560 */ 1561 @SdkConstant(SdkConstantType.FEATURE) 1562 public static final String FEATURE_WEBVIEW = "android.software.webview"; 1563 1564 /** 1565 * Feature for {@link #getSystemAvailableFeatures} and 1566 * {@link #hasSystemFeature}: This device supports ethernet. 1567 * @hide 1568 */ 1569 @SdkConstant(SdkConstantType.FEATURE) 1570 public static final String FEATURE_ETHERNET = "android.hardware.ethernet"; 1571 1572 /** 1573 * Feature for {@link #getSystemAvailableFeatures} and 1574 * {@link #hasSystemFeature}: This device supports HDMI-CEC. 1575 * @hide 1576 */ 1577 @SdkConstant(SdkConstantType.FEATURE) 1578 public static final String FEATURE_HDMI_CEC = "android.hardware.hdmi.cec"; 1579 1580 /** 1581 * Feature for {@link #getSystemAvailableFeatures} and {@link #hasSystemFeature}: 1582 * The device has all of the inputs necessary to be considered a compatible game controller, or 1583 * includes a compatible game controller in the box. 1584 */ 1585 @SdkConstant(SdkConstantType.FEATURE) 1586 public static final String FEATURE_GAMEPAD = "android.hardware.gamepad"; 1587 1588 1589 /** 1590 * Action to external storage service to clean out removed apps. 1591 * @hide 1592 */ 1593 public static final String ACTION_CLEAN_EXTERNAL_STORAGE 1594 = "android.content.pm.CLEAN_EXTERNAL_STORAGE"; 1595 1596 /** 1597 * Extra field name for the URI to a verification file. Passed to a package 1598 * verifier. 1599 * 1600 * @hide 1601 */ 1602 public static final String EXTRA_VERIFICATION_URI = "android.content.pm.extra.VERIFICATION_URI"; 1603 1604 /** 1605 * Extra field name for the ID of a package pending verification. Passed to 1606 * a package verifier and is used to call back to 1607 * {@link PackageManager#verifyPendingInstall(int, int)} 1608 */ 1609 public static final String EXTRA_VERIFICATION_ID = "android.content.pm.extra.VERIFICATION_ID"; 1610 1611 /** 1612 * Extra field name for the package identifier which is trying to install 1613 * the package. 1614 * 1615 * @hide 1616 */ 1617 public static final String EXTRA_VERIFICATION_INSTALLER_PACKAGE 1618 = "android.content.pm.extra.VERIFICATION_INSTALLER_PACKAGE"; 1619 1620 /** 1621 * Extra field name for the requested install flags for a package pending 1622 * verification. Passed to a package verifier. 1623 * 1624 * @hide 1625 */ 1626 public static final String EXTRA_VERIFICATION_INSTALL_FLAGS 1627 = "android.content.pm.extra.VERIFICATION_INSTALL_FLAGS"; 1628 1629 /** 1630 * Extra field name for the uid of who is requesting to install 1631 * the package. 1632 * 1633 * @hide 1634 */ 1635 public static final String EXTRA_VERIFICATION_INSTALLER_UID 1636 = "android.content.pm.extra.VERIFICATION_INSTALLER_UID"; 1637 1638 /** 1639 * Extra field name for the package name of a package pending verification. 1640 * 1641 * @hide 1642 */ 1643 public static final String EXTRA_VERIFICATION_PACKAGE_NAME 1644 = "android.content.pm.extra.VERIFICATION_PACKAGE_NAME"; 1645 /** 1646 * Extra field name for the result of a verification, either 1647 * {@link #VERIFICATION_ALLOW}, or {@link #VERIFICATION_REJECT}. 1648 * Passed to package verifiers after a package is verified. 1649 */ 1650 public static final String EXTRA_VERIFICATION_RESULT 1651 = "android.content.pm.extra.VERIFICATION_RESULT"; 1652 1653 /** 1654 * Extra field name for the version code of a package pending verification. 1655 * 1656 * @hide 1657 */ 1658 public static final String EXTRA_VERIFICATION_VERSION_CODE 1659 = "android.content.pm.extra.VERIFICATION_VERSION_CODE"; 1660 1661 /** 1662 * The action used to request that the user approve a permission request 1663 * from the application. 1664 * 1665 * @hide 1666 */ 1667 public static final String ACTION_REQUEST_PERMISSION 1668 = "android.content.pm.action.REQUEST_PERMISSION"; 1669 1670 /** 1671 * Extra field name for the list of permissions, which the user must approve. 1672 * 1673 * @hide 1674 */ 1675 public static final String EXTRA_REQUEST_PERMISSION_PERMISSION_LIST 1676 = "android.content.pm.extra.PERMISSION_LIST"; 1677 1678 /** 1679 * String extra for {@link PackageInstallObserver} in the 'extras' Bundle in case of 1680 * {@link #INSTALL_FAILED_DUPLICATE_PERMISSION}. This extra names the package which provides 1681 * the existing definition for the permission. 1682 * @hide 1683 */ 1684 public static final String EXTRA_FAILURE_EXISTING_PACKAGE 1685 = "android.content.pm.extra.FAILURE_EXISTING_PACKAGE"; 1686 1687 /** 1688 * String extra for {@link PackageInstallObserver} in the 'extras' Bundle in case of 1689 * {@link #INSTALL_FAILED_DUPLICATE_PERMISSION}. This extra names the permission that is 1690 * being redundantly defined by the package being installed. 1691 * @hide 1692 */ 1693 public static final String EXTRA_FAILURE_EXISTING_PERMISSION 1694 = "android.content.pm.extra.FAILURE_EXISTING_PERMISSION"; 1695 1696 /** 1697 * Retrieve overall information about an application package that is 1698 * installed on the system. 1699 * <p> 1700 * Throws {@link NameNotFoundException} if a package with the given name can 1701 * not be found on the system. 1702 * 1703 * @param packageName The full name (i.e. com.google.apps.contacts) of the 1704 * desired package. 1705 * @param flags Additional option flags. Use any combination of 1706 * {@link #GET_ACTIVITIES}, {@link #GET_GIDS}, 1707 * {@link #GET_CONFIGURATIONS}, {@link #GET_INSTRUMENTATION}, 1708 * {@link #GET_PERMISSIONS}, {@link #GET_PROVIDERS}, 1709 * {@link #GET_RECEIVERS}, {@link #GET_SERVICES}, 1710 * {@link #GET_SIGNATURES}, {@link #GET_UNINSTALLED_PACKAGES} to 1711 * modify the data returned. 1712 * @return Returns a PackageInfo object containing information about the 1713 * package. If flag GET_UNINSTALLED_PACKAGES is set and if the 1714 * package is not found in the list of installed applications, the 1715 * package information is retrieved from the list of uninstalled 1716 * applications (which includes installed applications as well as 1717 * applications with data directory i.e. applications which had been 1718 * deleted with {@code DONT_DELETE_DATA} flag set). 1719 * @see #GET_ACTIVITIES 1720 * @see #GET_GIDS 1721 * @see #GET_CONFIGURATIONS 1722 * @see #GET_INSTRUMENTATION 1723 * @see #GET_PERMISSIONS 1724 * @see #GET_PROVIDERS 1725 * @see #GET_RECEIVERS 1726 * @see #GET_SERVICES 1727 * @see #GET_SIGNATURES 1728 * @see #GET_UNINSTALLED_PACKAGES 1729 */ getPackageInfo(String packageName, int flags)1730 public abstract PackageInfo getPackageInfo(String packageName, int flags) 1731 throws NameNotFoundException; 1732 1733 /** 1734 * Map from the current package names in use on the device to whatever 1735 * the current canonical name of that package is. 1736 * @param names Array of current names to be mapped. 1737 * @return Returns an array of the same size as the original, containing 1738 * the canonical name for each package. 1739 */ currentToCanonicalPackageNames(String[] names)1740 public abstract String[] currentToCanonicalPackageNames(String[] names); 1741 1742 /** 1743 * Map from a packages canonical name to the current name in use on the device. 1744 * @param names Array of new names to be mapped. 1745 * @return Returns an array of the same size as the original, containing 1746 * the current name for each package. 1747 */ canonicalToCurrentPackageNames(String[] names)1748 public abstract String[] canonicalToCurrentPackageNames(String[] names); 1749 1750 /** 1751 * Returns a "good" intent to launch a front-door activity in a package. 1752 * This is used, for example, to implement an "open" button when browsing 1753 * through packages. The current implementation looks first for a main 1754 * activity in the category {@link Intent#CATEGORY_INFO}, and next for a 1755 * main activity in the category {@link Intent#CATEGORY_LAUNCHER}. Returns 1756 * <code>null</code> if neither are found. 1757 * 1758 * @param packageName The name of the package to inspect. 1759 * 1760 * @return A fully-qualified {@link Intent} that can be used to launch the 1761 * main activity in the package. Returns <code>null</code> if the package 1762 * does not contain such an activity, or if <em>packageName</em> is not 1763 * recognized. 1764 */ getLaunchIntentForPackage(String packageName)1765 public abstract Intent getLaunchIntentForPackage(String packageName); 1766 1767 /** 1768 * Return a "good" intent to launch a front-door Leanback activity in a 1769 * package, for use for example to implement an "open" button when browsing 1770 * through packages. The current implementation will look for a main 1771 * activity in the category {@link Intent#CATEGORY_LEANBACK_LAUNCHER}, or 1772 * return null if no main leanback activities are found. 1773 * <p> 1774 * Throws {@link NameNotFoundException} if a package with the given name 1775 * cannot be found on the system. 1776 * 1777 * @param packageName The name of the package to inspect. 1778 * @return Returns either a fully-qualified Intent that can be used to launch 1779 * the main Leanback activity in the package, or null if the package 1780 * does not contain such an activity. 1781 */ getLeanbackLaunchIntentForPackage(String packageName)1782 public abstract Intent getLeanbackLaunchIntentForPackage(String packageName); 1783 1784 /** 1785 * Return an array of all of the secondary group-ids that have been assigned 1786 * to a package. 1787 * <p> 1788 * Throws {@link NameNotFoundException} if a package with the given name 1789 * cannot be found on the system. 1790 * 1791 * @param packageName The full name (i.e. com.google.apps.contacts) of the 1792 * desired package. 1793 * @return Returns an int array of the assigned gids, or null if there are 1794 * none. 1795 */ getPackageGids(String packageName)1796 public abstract int[] getPackageGids(String packageName) 1797 throws NameNotFoundException; 1798 1799 /** 1800 * @hide Return the uid associated with the given package name for the 1801 * given user. 1802 * 1803 * <p>Throws {@link NameNotFoundException} if a package with the given 1804 * name can not be found on the system. 1805 * 1806 * @param packageName The full name (i.e. com.google.apps.contacts) of the 1807 * desired package. 1808 * @param userHandle The user handle identifier to look up the package under. 1809 * 1810 * @return Returns an integer uid who owns the given package name. 1811 */ getPackageUid(String packageName, int userHandle)1812 public abstract int getPackageUid(String packageName, int userHandle) 1813 throws NameNotFoundException; 1814 1815 /** 1816 * Retrieve all of the information we know about a particular permission. 1817 * 1818 * <p>Throws {@link NameNotFoundException} if a permission with the given 1819 * name cannot be found on the system. 1820 * 1821 * @param name The fully qualified name (i.e. com.google.permission.LOGIN) 1822 * of the permission you are interested in. 1823 * @param flags Additional option flags. Use {@link #GET_META_DATA} to 1824 * retrieve any meta-data associated with the permission. 1825 * 1826 * @return Returns a {@link PermissionInfo} containing information about the 1827 * permission. 1828 */ getPermissionInfo(String name, int flags)1829 public abstract PermissionInfo getPermissionInfo(String name, int flags) 1830 throws NameNotFoundException; 1831 1832 /** 1833 * Query for all of the permissions associated with a particular group. 1834 * 1835 * <p>Throws {@link NameNotFoundException} if the given group does not 1836 * exist. 1837 * 1838 * @param group The fully qualified name (i.e. com.google.permission.LOGIN) 1839 * of the permission group you are interested in. Use null to 1840 * find all of the permissions not associated with a group. 1841 * @param flags Additional option flags. Use {@link #GET_META_DATA} to 1842 * retrieve any meta-data associated with the permissions. 1843 * 1844 * @return Returns a list of {@link PermissionInfo} containing information 1845 * about all of the permissions in the given group. 1846 */ queryPermissionsByGroup(String group, int flags)1847 public abstract List<PermissionInfo> queryPermissionsByGroup(String group, 1848 int flags) throws NameNotFoundException; 1849 1850 /** 1851 * Retrieve all of the information we know about a particular group of 1852 * permissions. 1853 * 1854 * <p>Throws {@link NameNotFoundException} if a permission group with the given 1855 * name cannot be found on the system. 1856 * 1857 * @param name The fully qualified name (i.e. com.google.permission_group.APPS) 1858 * of the permission you are interested in. 1859 * @param flags Additional option flags. Use {@link #GET_META_DATA} to 1860 * retrieve any meta-data associated with the permission group. 1861 * 1862 * @return Returns a {@link PermissionGroupInfo} containing information 1863 * about the permission. 1864 */ getPermissionGroupInfo(String name, int flags)1865 public abstract PermissionGroupInfo getPermissionGroupInfo(String name, 1866 int flags) throws NameNotFoundException; 1867 1868 /** 1869 * Retrieve all of the known permission groups in the system. 1870 * 1871 * @param flags Additional option flags. Use {@link #GET_META_DATA} to 1872 * retrieve any meta-data associated with the permission group. 1873 * 1874 * @return Returns a list of {@link PermissionGroupInfo} containing 1875 * information about all of the known permission groups. 1876 */ getAllPermissionGroups(int flags)1877 public abstract List<PermissionGroupInfo> getAllPermissionGroups(int flags); 1878 1879 /** 1880 * Retrieve all of the information we know about a particular 1881 * package/application. 1882 * 1883 * <p>Throws {@link NameNotFoundException} if an application with the given 1884 * package name cannot be found on the system. 1885 * 1886 * @param packageName The full name (i.e. com.google.apps.contacts) of an 1887 * application. 1888 * @param flags Additional option flags. Use any combination of 1889 * {@link #GET_META_DATA}, {@link #GET_SHARED_LIBRARY_FILES}, 1890 * {@link #GET_UNINSTALLED_PACKAGES} to modify the data returned. 1891 * 1892 * @return {@link ApplicationInfo} Returns ApplicationInfo object containing 1893 * information about the package. 1894 * If flag GET_UNINSTALLED_PACKAGES is set and if the package is not 1895 * found in the list of installed applications, 1896 * the application information is retrieved from the 1897 * list of uninstalled applications(which includes 1898 * installed applications as well as applications 1899 * with data directory ie applications which had been 1900 * deleted with {@code DONT_DELETE_DATA} flag set). 1901 * 1902 * @see #GET_META_DATA 1903 * @see #GET_SHARED_LIBRARY_FILES 1904 * @see #GET_UNINSTALLED_PACKAGES 1905 */ getApplicationInfo(String packageName, int flags)1906 public abstract ApplicationInfo getApplicationInfo(String packageName, 1907 int flags) throws NameNotFoundException; 1908 1909 /** 1910 * Retrieve all of the information we know about a particular activity 1911 * class. 1912 * 1913 * <p>Throws {@link NameNotFoundException} if an activity with the given 1914 * class name cannot be found on the system. 1915 * 1916 * @param component The full component name (i.e. 1917 * com.google.apps.contacts/com.google.apps.contacts.ContactsList) of an Activity 1918 * class. 1919 * @param flags Additional option flags. Use any combination of 1920 * {@link #GET_META_DATA}, {@link #GET_SHARED_LIBRARY_FILES}, 1921 * to modify the data (in ApplicationInfo) returned. 1922 * 1923 * @return {@link ActivityInfo} containing information about the activity. 1924 * 1925 * @see #GET_INTENT_FILTERS 1926 * @see #GET_META_DATA 1927 * @see #GET_SHARED_LIBRARY_FILES 1928 */ getActivityInfo(ComponentName component, int flags)1929 public abstract ActivityInfo getActivityInfo(ComponentName component, 1930 int flags) throws NameNotFoundException; 1931 1932 /** 1933 * Retrieve all of the information we know about a particular receiver 1934 * class. 1935 * 1936 * <p>Throws {@link NameNotFoundException} if a receiver with the given 1937 * class name cannot be found on the system. 1938 * 1939 * @param component The full component name (i.e. 1940 * com.google.apps.calendar/com.google.apps.calendar.CalendarAlarm) of a Receiver 1941 * class. 1942 * @param flags Additional option flags. Use any combination of 1943 * {@link #GET_META_DATA}, {@link #GET_SHARED_LIBRARY_FILES}, 1944 * to modify the data returned. 1945 * 1946 * @return {@link ActivityInfo} containing information about the receiver. 1947 * 1948 * @see #GET_INTENT_FILTERS 1949 * @see #GET_META_DATA 1950 * @see #GET_SHARED_LIBRARY_FILES 1951 */ getReceiverInfo(ComponentName component, int flags)1952 public abstract ActivityInfo getReceiverInfo(ComponentName component, 1953 int flags) throws NameNotFoundException; 1954 1955 /** 1956 * Retrieve all of the information we know about a particular service 1957 * class. 1958 * 1959 * <p>Throws {@link NameNotFoundException} if a service with the given 1960 * class name cannot be found on the system. 1961 * 1962 * @param component The full component name (i.e. 1963 * com.google.apps.media/com.google.apps.media.BackgroundPlayback) of a Service 1964 * class. 1965 * @param flags Additional option flags. Use any combination of 1966 * {@link #GET_META_DATA}, {@link #GET_SHARED_LIBRARY_FILES}, 1967 * to modify the data returned. 1968 * 1969 * @return ServiceInfo containing information about the service. 1970 * 1971 * @see #GET_META_DATA 1972 * @see #GET_SHARED_LIBRARY_FILES 1973 */ getServiceInfo(ComponentName component, int flags)1974 public abstract ServiceInfo getServiceInfo(ComponentName component, 1975 int flags) throws NameNotFoundException; 1976 1977 /** 1978 * Retrieve all of the information we know about a particular content 1979 * provider class. 1980 * 1981 * <p>Throws {@link NameNotFoundException} if a provider with the given 1982 * class name cannot be found on the system. 1983 * 1984 * @param component The full component name (i.e. 1985 * com.google.providers.media/com.google.providers.media.MediaProvider) of a 1986 * ContentProvider class. 1987 * @param flags Additional option flags. Use any combination of 1988 * {@link #GET_META_DATA}, {@link #GET_SHARED_LIBRARY_FILES}, 1989 * to modify the data returned. 1990 * 1991 * @return ProviderInfo containing information about the service. 1992 * 1993 * @see #GET_META_DATA 1994 * @see #GET_SHARED_LIBRARY_FILES 1995 */ getProviderInfo(ComponentName component, int flags)1996 public abstract ProviderInfo getProviderInfo(ComponentName component, 1997 int flags) throws NameNotFoundException; 1998 1999 /** 2000 * Return a List of all packages that are installed 2001 * on the device. 2002 * 2003 * @param flags Additional option flags. Use any combination of 2004 * {@link #GET_ACTIVITIES}, 2005 * {@link #GET_GIDS}, 2006 * {@link #GET_CONFIGURATIONS}, 2007 * {@link #GET_INSTRUMENTATION}, 2008 * {@link #GET_PERMISSIONS}, 2009 * {@link #GET_PROVIDERS}, 2010 * {@link #GET_RECEIVERS}, 2011 * {@link #GET_SERVICES}, 2012 * {@link #GET_SIGNATURES}, 2013 * {@link #GET_UNINSTALLED_PACKAGES} to modify the data returned. 2014 * 2015 * @return A List of PackageInfo objects, one for each package that is 2016 * installed on the device. In the unlikely case of there being no 2017 * installed packages, an empty list is returned. 2018 * If flag GET_UNINSTALLED_PACKAGES is set, a list of all 2019 * applications including those deleted with {@code DONT_DELETE_DATA} 2020 * (partially installed apps with data directory) will be returned. 2021 * 2022 * @see #GET_ACTIVITIES 2023 * @see #GET_GIDS 2024 * @see #GET_CONFIGURATIONS 2025 * @see #GET_INSTRUMENTATION 2026 * @see #GET_PERMISSIONS 2027 * @see #GET_PROVIDERS 2028 * @see #GET_RECEIVERS 2029 * @see #GET_SERVICES 2030 * @see #GET_SIGNATURES 2031 * @see #GET_UNINSTALLED_PACKAGES 2032 */ getInstalledPackages(int flags)2033 public abstract List<PackageInfo> getInstalledPackages(int flags); 2034 2035 /** 2036 * Return a List of all installed packages that are currently 2037 * holding any of the given permissions. 2038 * 2039 * @param flags Additional option flags. Use any combination of 2040 * {@link #GET_ACTIVITIES}, 2041 * {@link #GET_GIDS}, 2042 * {@link #GET_CONFIGURATIONS}, 2043 * {@link #GET_INSTRUMENTATION}, 2044 * {@link #GET_PERMISSIONS}, 2045 * {@link #GET_PROVIDERS}, 2046 * {@link #GET_RECEIVERS}, 2047 * {@link #GET_SERVICES}, 2048 * {@link #GET_SIGNATURES}, 2049 * {@link #GET_UNINSTALLED_PACKAGES} to modify the data returned. 2050 * 2051 * @return Returns a List of PackageInfo objects, one for each installed 2052 * application that is holding any of the permissions that were provided. 2053 * 2054 * @see #GET_ACTIVITIES 2055 * @see #GET_GIDS 2056 * @see #GET_CONFIGURATIONS 2057 * @see #GET_INSTRUMENTATION 2058 * @see #GET_PERMISSIONS 2059 * @see #GET_PROVIDERS 2060 * @see #GET_RECEIVERS 2061 * @see #GET_SERVICES 2062 * @see #GET_SIGNATURES 2063 * @see #GET_UNINSTALLED_PACKAGES 2064 */ getPackagesHoldingPermissions( String[] permissions, int flags)2065 public abstract List<PackageInfo> getPackagesHoldingPermissions( 2066 String[] permissions, int flags); 2067 2068 /** 2069 * Return a List of all packages that are installed on the device, for a specific user. 2070 * Requesting a list of installed packages for another user 2071 * will require the permission INTERACT_ACROSS_USERS_FULL. 2072 * @param flags Additional option flags. Use any combination of 2073 * {@link #GET_ACTIVITIES}, 2074 * {@link #GET_GIDS}, 2075 * {@link #GET_CONFIGURATIONS}, 2076 * {@link #GET_INSTRUMENTATION}, 2077 * {@link #GET_PERMISSIONS}, 2078 * {@link #GET_PROVIDERS}, 2079 * {@link #GET_RECEIVERS}, 2080 * {@link #GET_SERVICES}, 2081 * {@link #GET_SIGNATURES}, 2082 * {@link #GET_UNINSTALLED_PACKAGES} to modify the data returned. 2083 * @param userId The user for whom the installed packages are to be listed 2084 * 2085 * @return A List of PackageInfo objects, one for each package that is 2086 * installed on the device. In the unlikely case of there being no 2087 * installed packages, an empty list is returned. 2088 * If flag GET_UNINSTALLED_PACKAGES is set, a list of all 2089 * applications including those deleted with {@code DONT_DELETE_DATA} 2090 * (partially installed apps with data directory) will be returned. 2091 * 2092 * @see #GET_ACTIVITIES 2093 * @see #GET_GIDS 2094 * @see #GET_CONFIGURATIONS 2095 * @see #GET_INSTRUMENTATION 2096 * @see #GET_PERMISSIONS 2097 * @see #GET_PROVIDERS 2098 * @see #GET_RECEIVERS 2099 * @see #GET_SERVICES 2100 * @see #GET_SIGNATURES 2101 * @see #GET_UNINSTALLED_PACKAGES 2102 * 2103 * @hide 2104 */ getInstalledPackages(int flags, int userId)2105 public abstract List<PackageInfo> getInstalledPackages(int flags, int userId); 2106 2107 /** 2108 * Check whether a particular package has been granted a particular 2109 * permission. 2110 * 2111 * @param permName The name of the permission you are checking for, 2112 * @param pkgName The name of the package you are checking against. 2113 * 2114 * @return If the package has the permission, PERMISSION_GRANTED is 2115 * returned. If it does not have the permission, PERMISSION_DENIED 2116 * is returned. 2117 * 2118 * @see #PERMISSION_GRANTED 2119 * @see #PERMISSION_DENIED 2120 */ checkPermission(String permName, String pkgName)2121 public abstract int checkPermission(String permName, String pkgName); 2122 2123 /** 2124 * Add a new dynamic permission to the system. For this to work, your 2125 * package must have defined a permission tree through the 2126 * {@link android.R.styleable#AndroidManifestPermissionTree 2127 * <permission-tree>} tag in its manifest. A package can only add 2128 * permissions to trees that were defined by either its own package or 2129 * another with the same user id; a permission is in a tree if it 2130 * matches the name of the permission tree + ".": for example, 2131 * "com.foo.bar" is a member of the permission tree "com.foo". 2132 * 2133 * <p>It is good to make your permission tree name descriptive, because you 2134 * are taking possession of that entire set of permission names. Thus, it 2135 * must be under a domain you control, with a suffix that will not match 2136 * any normal permissions that may be declared in any applications that 2137 * are part of that domain. 2138 * 2139 * <p>New permissions must be added before 2140 * any .apks are installed that use those permissions. Permissions you 2141 * add through this method are remembered across reboots of the device. 2142 * If the given permission already exists, the info you supply here 2143 * will be used to update it. 2144 * 2145 * @param info Description of the permission to be added. 2146 * 2147 * @return Returns true if a new permission was created, false if an 2148 * existing one was updated. 2149 * 2150 * @throws SecurityException if you are not allowed to add the 2151 * given permission name. 2152 * 2153 * @see #removePermission(String) 2154 */ addPermission(PermissionInfo info)2155 public abstract boolean addPermission(PermissionInfo info); 2156 2157 /** 2158 * Like {@link #addPermission(PermissionInfo)} but asynchronously 2159 * persists the package manager state after returning from the call, 2160 * allowing it to return quicker and batch a series of adds at the 2161 * expense of no guarantee the added permission will be retained if 2162 * the device is rebooted before it is written. 2163 */ addPermissionAsync(PermissionInfo info)2164 public abstract boolean addPermissionAsync(PermissionInfo info); 2165 2166 /** 2167 * Removes a permission that was previously added with 2168 * {@link #addPermission(PermissionInfo)}. The same ownership rules apply 2169 * -- you are only allowed to remove permissions that you are allowed 2170 * to add. 2171 * 2172 * @param name The name of the permission to remove. 2173 * 2174 * @throws SecurityException if you are not allowed to remove the 2175 * given permission name. 2176 * 2177 * @see #addPermission(PermissionInfo) 2178 */ removePermission(String name)2179 public abstract void removePermission(String name); 2180 2181 /** 2182 * Returns an {@link Intent} suitable for passing to {@code startActivityForResult} 2183 * which prompts the user to grant {@code permissions} to this application. 2184 * @hide 2185 * 2186 * @throws NullPointerException if {@code permissions} is {@code null}. 2187 * @throws IllegalArgumentException if {@code permissions} contains {@code null}. 2188 */ buildPermissionRequestIntent(String... permissions)2189 public Intent buildPermissionRequestIntent(String... permissions) { 2190 if (permissions == null) { 2191 throw new NullPointerException("permissions cannot be null"); 2192 } 2193 for (String permission : permissions) { 2194 if (permission == null) { 2195 throw new IllegalArgumentException("permissions cannot contain null"); 2196 } 2197 } 2198 2199 Intent i = new Intent(ACTION_REQUEST_PERMISSION); 2200 i.putExtra(EXTRA_REQUEST_PERMISSION_PERMISSION_LIST, permissions); 2201 i.setPackage("com.android.packageinstaller"); 2202 return i; 2203 } 2204 2205 /** 2206 * Grant a permission to an application which the application does not 2207 * already have. The permission must have been requested by the application, 2208 * but as an optional permission. If the application is not allowed to 2209 * hold the permission, a SecurityException is thrown. 2210 * @hide 2211 * 2212 * @param packageName The name of the package that the permission will be 2213 * granted to. 2214 * @param permissionName The name of the permission. 2215 */ grantPermission(String packageName, String permissionName)2216 public abstract void grantPermission(String packageName, String permissionName); 2217 2218 /** 2219 * Revoke a permission that was previously granted by {@link #grantPermission}. 2220 * @hide 2221 * 2222 * @param packageName The name of the package that the permission will be 2223 * granted to. 2224 * @param permissionName The name of the permission. 2225 */ revokePermission(String packageName, String permissionName)2226 public abstract void revokePermission(String packageName, String permissionName); 2227 2228 /** 2229 * Compare the signatures of two packages to determine if the same 2230 * signature appears in both of them. If they do contain the same 2231 * signature, then they are allowed special privileges when working 2232 * with each other: they can share the same user-id, run instrumentation 2233 * against each other, etc. 2234 * 2235 * @param pkg1 First package name whose signature will be compared. 2236 * @param pkg2 Second package name whose signature will be compared. 2237 * 2238 * @return Returns an integer indicating whether all signatures on the 2239 * two packages match. The value is >= 0 ({@link #SIGNATURE_MATCH}) if 2240 * all signatures match or < 0 if there is not a match ({@link 2241 * #SIGNATURE_NO_MATCH} or {@link #SIGNATURE_UNKNOWN_PACKAGE}). 2242 * 2243 * @see #checkSignatures(int, int) 2244 * @see #SIGNATURE_MATCH 2245 * @see #SIGNATURE_NO_MATCH 2246 * @see #SIGNATURE_UNKNOWN_PACKAGE 2247 */ checkSignatures(String pkg1, String pkg2)2248 public abstract int checkSignatures(String pkg1, String pkg2); 2249 2250 /** 2251 * Like {@link #checkSignatures(String, String)}, but takes UIDs of 2252 * the two packages to be checked. This can be useful, for example, 2253 * when doing the check in an IPC, where the UID is the only identity 2254 * available. It is functionally identical to determining the package 2255 * associated with the UIDs and checking their signatures. 2256 * 2257 * @param uid1 First UID whose signature will be compared. 2258 * @param uid2 Second UID whose signature will be compared. 2259 * 2260 * @return Returns an integer indicating whether all signatures on the 2261 * two packages match. The value is >= 0 ({@link #SIGNATURE_MATCH}) if 2262 * all signatures match or < 0 if there is not a match ({@link 2263 * #SIGNATURE_NO_MATCH} or {@link #SIGNATURE_UNKNOWN_PACKAGE}). 2264 * 2265 * @see #checkSignatures(String, String) 2266 * @see #SIGNATURE_MATCH 2267 * @see #SIGNATURE_NO_MATCH 2268 * @see #SIGNATURE_UNKNOWN_PACKAGE 2269 */ checkSignatures(int uid1, int uid2)2270 public abstract int checkSignatures(int uid1, int uid2); 2271 2272 /** 2273 * Retrieve the names of all packages that are associated with a particular 2274 * user id. In most cases, this will be a single package name, the package 2275 * that has been assigned that user id. Where there are multiple packages 2276 * sharing the same user id through the "sharedUserId" mechanism, all 2277 * packages with that id will be returned. 2278 * 2279 * @param uid The user id for which you would like to retrieve the 2280 * associated packages. 2281 * 2282 * @return Returns an array of one or more packages assigned to the user 2283 * id, or null if there are no known packages with the given id. 2284 */ getPackagesForUid(int uid)2285 public abstract String[] getPackagesForUid(int uid); 2286 2287 /** 2288 * Retrieve the official name associated with a user id. This name is 2289 * guaranteed to never change, though it is possibly for the underlying 2290 * user id to be changed. That is, if you are storing information about 2291 * user ids in persistent storage, you should use the string returned 2292 * by this function instead of the raw user-id. 2293 * 2294 * @param uid The user id for which you would like to retrieve a name. 2295 * @return Returns a unique name for the given user id, or null if the 2296 * user id is not currently assigned. 2297 */ getNameForUid(int uid)2298 public abstract String getNameForUid(int uid); 2299 2300 /** 2301 * Return the user id associated with a shared user name. Multiple 2302 * applications can specify a shared user name in their manifest and thus 2303 * end up using a common uid. This might be used for new applications 2304 * that use an existing shared user name and need to know the uid of the 2305 * shared user. 2306 * 2307 * @param sharedUserName The shared user name whose uid is to be retrieved. 2308 * @return Returns the uid associated with the shared user, or NameNotFoundException 2309 * if the shared user name is not being used by any installed packages 2310 * @hide 2311 */ getUidForSharedUser(String sharedUserName)2312 public abstract int getUidForSharedUser(String sharedUserName) 2313 throws NameNotFoundException; 2314 2315 /** 2316 * Return a List of all application packages that are installed on the 2317 * device. If flag GET_UNINSTALLED_PACKAGES has been set, a list of all 2318 * applications including those deleted with {@code DONT_DELETE_DATA} (partially 2319 * installed apps with data directory) will be returned. 2320 * 2321 * @param flags Additional option flags. Use any combination of 2322 * {@link #GET_META_DATA}, {@link #GET_SHARED_LIBRARY_FILES}, 2323 * {@link #GET_UNINSTALLED_PACKAGES} to modify the data returned. 2324 * 2325 * @return Returns a List of ApplicationInfo objects, one for each application that 2326 * is installed on the device. In the unlikely case of there being 2327 * no installed applications, an empty list is returned. 2328 * If flag GET_UNINSTALLED_PACKAGES is set, a list of all 2329 * applications including those deleted with {@code DONT_DELETE_DATA} 2330 * (partially installed apps with data directory) will be returned. 2331 * 2332 * @see #GET_META_DATA 2333 * @see #GET_SHARED_LIBRARY_FILES 2334 * @see #GET_UNINSTALLED_PACKAGES 2335 */ getInstalledApplications(int flags)2336 public abstract List<ApplicationInfo> getInstalledApplications(int flags); 2337 2338 /** 2339 * Get a list of shared libraries that are available on the 2340 * system. 2341 * 2342 * @return An array of shared library names that are 2343 * available on the system, or null if none are installed. 2344 * 2345 */ getSystemSharedLibraryNames()2346 public abstract String[] getSystemSharedLibraryNames(); 2347 2348 /** 2349 * Get a list of features that are available on the 2350 * system. 2351 * 2352 * @return An array of FeatureInfo classes describing the features 2353 * that are available on the system, or null if there are none(!!). 2354 */ getSystemAvailableFeatures()2355 public abstract FeatureInfo[] getSystemAvailableFeatures(); 2356 2357 /** 2358 * Check whether the given feature name is one of the available 2359 * features as returned by {@link #getSystemAvailableFeatures()}. 2360 * 2361 * @return Returns true if the devices supports the feature, else 2362 * false. 2363 */ hasSystemFeature(String name)2364 public abstract boolean hasSystemFeature(String name); 2365 2366 /** 2367 * Determine the best action to perform for a given Intent. This is how 2368 * {@link Intent#resolveActivity} finds an activity if a class has not 2369 * been explicitly specified. 2370 * 2371 * <p><em>Note:</em> if using an implicit Intent (without an explicit ComponentName 2372 * specified), be sure to consider whether to set the {@link #MATCH_DEFAULT_ONLY} 2373 * only flag. You need to do so to resolve the activity in the same way 2374 * that {@link android.content.Context#startActivity(Intent)} and 2375 * {@link android.content.Intent#resolveActivity(PackageManager) 2376 * Intent.resolveActivity(PackageManager)} do.</p> 2377 * 2378 * @param intent An intent containing all of the desired specification 2379 * (action, data, type, category, and/or component). 2380 * @param flags Additional option flags. The most important is 2381 * {@link #MATCH_DEFAULT_ONLY}, to limit the resolution to only 2382 * those activities that support the {@link android.content.Intent#CATEGORY_DEFAULT}. 2383 * 2384 * @return Returns a ResolveInfo containing the final activity intent that 2385 * was determined to be the best action. Returns null if no 2386 * matching activity was found. If multiple matching activities are 2387 * found and there is no default set, returns a ResolveInfo 2388 * containing something else, such as the activity resolver. 2389 * 2390 * @see #MATCH_DEFAULT_ONLY 2391 * @see #GET_INTENT_FILTERS 2392 * @see #GET_RESOLVED_FILTER 2393 */ resolveActivity(Intent intent, int flags)2394 public abstract ResolveInfo resolveActivity(Intent intent, int flags); 2395 2396 /** 2397 * Determine the best action to perform for a given Intent for a given user. This 2398 * is how {@link Intent#resolveActivity} finds an activity if a class has not 2399 * been explicitly specified. 2400 * 2401 * <p><em>Note:</em> if using an implicit Intent (without an explicit ComponentName 2402 * specified), be sure to consider whether to set the {@link #MATCH_DEFAULT_ONLY} 2403 * only flag. You need to do so to resolve the activity in the same way 2404 * that {@link android.content.Context#startActivity(Intent)} and 2405 * {@link android.content.Intent#resolveActivity(PackageManager) 2406 * Intent.resolveActivity(PackageManager)} do.</p> 2407 * 2408 * @param intent An intent containing all of the desired specification 2409 * (action, data, type, category, and/or component). 2410 * @param flags Additional option flags. The most important is 2411 * {@link #MATCH_DEFAULT_ONLY}, to limit the resolution to only 2412 * those activities that support the {@link android.content.Intent#CATEGORY_DEFAULT}. 2413 * @param userId The user id. 2414 * 2415 * @return Returns a ResolveInfo containing the final activity intent that 2416 * was determined to be the best action. Returns null if no 2417 * matching activity was found. If multiple matching activities are 2418 * found and there is no default set, returns a ResolveInfo 2419 * containing something else, such as the activity resolver. 2420 * 2421 * @see #MATCH_DEFAULT_ONLY 2422 * @see #GET_INTENT_FILTERS 2423 * @see #GET_RESOLVED_FILTER 2424 * 2425 * @hide 2426 */ resolveActivityAsUser(Intent intent, int flags, int userId)2427 public abstract ResolveInfo resolveActivityAsUser(Intent intent, int flags, int userId); 2428 2429 /** 2430 * Retrieve all activities that can be performed for the given intent. 2431 * 2432 * @param intent The desired intent as per resolveActivity(). 2433 * @param flags Additional option flags. The most important is 2434 * {@link #MATCH_DEFAULT_ONLY}, to limit the resolution to only 2435 * those activities that support the {@link android.content.Intent#CATEGORY_DEFAULT}. 2436 * 2437 * @return A List<ResolveInfo> containing one entry for each matching 2438 * Activity. These are ordered from best to worst match -- that 2439 * is, the first item in the list is what is returned by 2440 * {@link #resolveActivity}. If there are no matching activities, an empty 2441 * list is returned. 2442 * 2443 * @see #MATCH_DEFAULT_ONLY 2444 * @see #GET_INTENT_FILTERS 2445 * @see #GET_RESOLVED_FILTER 2446 */ queryIntentActivities(Intent intent, int flags)2447 public abstract List<ResolveInfo> queryIntentActivities(Intent intent, 2448 int flags); 2449 2450 /** 2451 * Retrieve all activities that can be performed for the given intent, for a specific user. 2452 * 2453 * @param intent The desired intent as per resolveActivity(). 2454 * @param flags Additional option flags. The most important is 2455 * {@link #MATCH_DEFAULT_ONLY}, to limit the resolution to only 2456 * those activities that support the {@link android.content.Intent#CATEGORY_DEFAULT}. 2457 * 2458 * @return A List<ResolveInfo> containing one entry for each matching 2459 * Activity. These are ordered from best to worst match -- that 2460 * is, the first item in the list is what is returned by 2461 * {@link #resolveActivity}. If there are no matching activities, an empty 2462 * list is returned. 2463 * 2464 * @see #MATCH_DEFAULT_ONLY 2465 * @see #GET_INTENT_FILTERS 2466 * @see #GET_RESOLVED_FILTER 2467 * @hide 2468 */ queryIntentActivitiesAsUser(Intent intent, int flags, int userId)2469 public abstract List<ResolveInfo> queryIntentActivitiesAsUser(Intent intent, 2470 int flags, int userId); 2471 2472 2473 /** 2474 * Retrieve a set of activities that should be presented to the user as 2475 * similar options. This is like {@link #queryIntentActivities}, except it 2476 * also allows you to supply a list of more explicit Intents that you would 2477 * like to resolve to particular options, and takes care of returning the 2478 * final ResolveInfo list in a reasonable order, with no duplicates, based 2479 * on those inputs. 2480 * 2481 * @param caller The class name of the activity that is making the 2482 * request. This activity will never appear in the output 2483 * list. Can be null. 2484 * @param specifics An array of Intents that should be resolved to the 2485 * first specific results. Can be null. 2486 * @param intent The desired intent as per resolveActivity(). 2487 * @param flags Additional option flags. The most important is 2488 * {@link #MATCH_DEFAULT_ONLY}, to limit the resolution to only 2489 * those activities that support the {@link android.content.Intent#CATEGORY_DEFAULT}. 2490 * 2491 * @return A List<ResolveInfo> containing one entry for each matching 2492 * Activity. These are ordered first by all of the intents resolved 2493 * in <var>specifics</var> and then any additional activities that 2494 * can handle <var>intent</var> but did not get included by one of 2495 * the <var>specifics</var> intents. If there are no matching 2496 * activities, an empty list is returned. 2497 * 2498 * @see #MATCH_DEFAULT_ONLY 2499 * @see #GET_INTENT_FILTERS 2500 * @see #GET_RESOLVED_FILTER 2501 */ queryIntentActivityOptions( ComponentName caller, Intent[] specifics, Intent intent, int flags)2502 public abstract List<ResolveInfo> queryIntentActivityOptions( 2503 ComponentName caller, Intent[] specifics, Intent intent, int flags); 2504 2505 /** 2506 * Retrieve all receivers that can handle a broadcast of the given intent. 2507 * 2508 * @param intent The desired intent as per resolveActivity(). 2509 * @param flags Additional option flags. 2510 * 2511 * @return A List<ResolveInfo> containing one entry for each matching 2512 * Receiver. These are ordered from first to last in priority. If 2513 * there are no matching receivers, an empty list is returned. 2514 * 2515 * @see #MATCH_DEFAULT_ONLY 2516 * @see #GET_INTENT_FILTERS 2517 * @see #GET_RESOLVED_FILTER 2518 */ queryBroadcastReceivers(Intent intent, int flags)2519 public abstract List<ResolveInfo> queryBroadcastReceivers(Intent intent, 2520 int flags); 2521 2522 /** 2523 * Retrieve all receivers that can handle a broadcast of the given intent, for a specific 2524 * user. 2525 * 2526 * @param intent The desired intent as per resolveActivity(). 2527 * @param flags Additional option flags. 2528 * @param userId The userId of the user being queried. 2529 * 2530 * @return A List<ResolveInfo> containing one entry for each matching 2531 * Receiver. These are ordered from first to last in priority. If 2532 * there are no matching receivers, an empty list is returned. 2533 * 2534 * @see #MATCH_DEFAULT_ONLY 2535 * @see #GET_INTENT_FILTERS 2536 * @see #GET_RESOLVED_FILTER 2537 * @hide 2538 */ queryBroadcastReceivers(Intent intent, int flags, int userId)2539 public abstract List<ResolveInfo> queryBroadcastReceivers(Intent intent, 2540 int flags, int userId); 2541 2542 /** 2543 * Determine the best service to handle for a given Intent. 2544 * 2545 * @param intent An intent containing all of the desired specification 2546 * (action, data, type, category, and/or component). 2547 * @param flags Additional option flags. 2548 * 2549 * @return Returns a ResolveInfo containing the final service intent that 2550 * was determined to be the best action. Returns null if no 2551 * matching service was found. 2552 * 2553 * @see #GET_INTENT_FILTERS 2554 * @see #GET_RESOLVED_FILTER 2555 */ resolveService(Intent intent, int flags)2556 public abstract ResolveInfo resolveService(Intent intent, int flags); 2557 2558 /** 2559 * Retrieve all services that can match the given intent. 2560 * 2561 * @param intent The desired intent as per resolveService(). 2562 * @param flags Additional option flags. 2563 * 2564 * @return A List<ResolveInfo> containing one entry for each matching 2565 * ServiceInfo. These are ordered from best to worst match -- that 2566 * is, the first item in the list is what is returned by 2567 * resolveService(). If there are no matching services, an empty 2568 * list is returned. 2569 * 2570 * @see #GET_INTENT_FILTERS 2571 * @see #GET_RESOLVED_FILTER 2572 */ queryIntentServices(Intent intent, int flags)2573 public abstract List<ResolveInfo> queryIntentServices(Intent intent, 2574 int flags); 2575 2576 /** 2577 * Retrieve all services that can match the given intent for a given user. 2578 * 2579 * @param intent The desired intent as per resolveService(). 2580 * @param flags Additional option flags. 2581 * @param userId The user id. 2582 * 2583 * @return A List<ResolveInfo> containing one entry for each matching 2584 * ServiceInfo. These are ordered from best to worst match -- that 2585 * is, the first item in the list is what is returned by 2586 * resolveService(). If there are no matching services, an empty 2587 * list is returned. 2588 * 2589 * @see #GET_INTENT_FILTERS 2590 * @see #GET_RESOLVED_FILTER 2591 * 2592 * @hide 2593 */ queryIntentServicesAsUser(Intent intent, int flags, int userId)2594 public abstract List<ResolveInfo> queryIntentServicesAsUser(Intent intent, 2595 int flags, int userId); 2596 2597 /** {@hide} */ queryIntentContentProvidersAsUser( Intent intent, int flags, int userId)2598 public abstract List<ResolveInfo> queryIntentContentProvidersAsUser( 2599 Intent intent, int flags, int userId); 2600 2601 /** 2602 * Retrieve all providers that can match the given intent. 2603 * 2604 * @param intent An intent containing all of the desired specification 2605 * (action, data, type, category, and/or component). 2606 * @param flags Additional option flags. 2607 * @return A List<ResolveInfo> containing one entry for each matching 2608 * ProviderInfo. These are ordered from best to worst match. If 2609 * there are no matching providers, an empty list is returned. 2610 * @see #GET_INTENT_FILTERS 2611 * @see #GET_RESOLVED_FILTER 2612 */ queryIntentContentProviders(Intent intent, int flags)2613 public abstract List<ResolveInfo> queryIntentContentProviders(Intent intent, int flags); 2614 2615 /** 2616 * Find a single content provider by its base path name. 2617 * 2618 * @param name The name of the provider to find. 2619 * @param flags Additional option flags. Currently should always be 0. 2620 * 2621 * @return ContentProviderInfo Information about the provider, if found, 2622 * else null. 2623 */ resolveContentProvider(String name, int flags)2624 public abstract ProviderInfo resolveContentProvider(String name, 2625 int flags); 2626 2627 /** 2628 * Find a single content provider by its base path name. 2629 * 2630 * @param name The name of the provider to find. 2631 * @param flags Additional option flags. Currently should always be 0. 2632 * @param userId The user id. 2633 * 2634 * @return ContentProviderInfo Information about the provider, if found, 2635 * else null. 2636 * @hide 2637 */ resolveContentProviderAsUser(String name, int flags, int userId)2638 public abstract ProviderInfo resolveContentProviderAsUser(String name, int flags, int userId); 2639 2640 /** 2641 * Retrieve content provider information. 2642 * 2643 * <p><em>Note: unlike most other methods, an empty result set is indicated 2644 * by a null return instead of an empty list.</em> 2645 * 2646 * @param processName If non-null, limits the returned providers to only 2647 * those that are hosted by the given process. If null, 2648 * all content providers are returned. 2649 * @param uid If <var>processName</var> is non-null, this is the required 2650 * uid owning the requested content providers. 2651 * @param flags Additional option flags. Currently should always be 0. 2652 * 2653 * @return A List<ContentProviderInfo> containing one entry for each 2654 * content provider either patching <var>processName</var> or, if 2655 * <var>processName</var> is null, all known content providers. 2656 * <em>If there are no matching providers, null is returned.</em> 2657 */ queryContentProviders( String processName, int uid, int flags)2658 public abstract List<ProviderInfo> queryContentProviders( 2659 String processName, int uid, int flags); 2660 2661 /** 2662 * Retrieve all of the information we know about a particular 2663 * instrumentation class. 2664 * 2665 * <p>Throws {@link NameNotFoundException} if instrumentation with the 2666 * given class name cannot be found on the system. 2667 * 2668 * @param className The full name (i.e. 2669 * com.google.apps.contacts.InstrumentList) of an 2670 * Instrumentation class. 2671 * @param flags Additional option flags. Currently should always be 0. 2672 * 2673 * @return InstrumentationInfo containing information about the 2674 * instrumentation. 2675 */ getInstrumentationInfo( ComponentName className, int flags)2676 public abstract InstrumentationInfo getInstrumentationInfo( 2677 ComponentName className, int flags) throws NameNotFoundException; 2678 2679 /** 2680 * Retrieve information about available instrumentation code. May be used 2681 * to retrieve either all instrumentation code, or only the code targeting 2682 * a particular package. 2683 * 2684 * @param targetPackage If null, all instrumentation is returned; only the 2685 * instrumentation targeting this package name is 2686 * returned. 2687 * @param flags Additional option flags. Currently should always be 0. 2688 * 2689 * @return A List<InstrumentationInfo> containing one entry for each 2690 * matching available Instrumentation. Returns an empty list if 2691 * there is no instrumentation available for the given package. 2692 */ queryInstrumentation( String targetPackage, int flags)2693 public abstract List<InstrumentationInfo> queryInstrumentation( 2694 String targetPackage, int flags); 2695 2696 /** 2697 * Retrieve an image from a package. This is a low-level API used by 2698 * the various package manager info structures (such as 2699 * {@link ComponentInfo} to implement retrieval of their associated 2700 * icon. 2701 * 2702 * @param packageName The name of the package that this icon is coming from. 2703 * Cannot be null. 2704 * @param resid The resource identifier of the desired image. Cannot be 0. 2705 * @param appInfo Overall information about <var>packageName</var>. This 2706 * may be null, in which case the application information will be retrieved 2707 * for you if needed; if you already have this information around, it can 2708 * be much more efficient to supply it here. 2709 * 2710 * @return Returns a Drawable holding the requested image. Returns null if 2711 * an image could not be found for any reason. 2712 */ getDrawable(String packageName, int resid, ApplicationInfo appInfo)2713 public abstract Drawable getDrawable(String packageName, int resid, 2714 ApplicationInfo appInfo); 2715 2716 /** 2717 * Retrieve the icon associated with an activity. Given the full name of 2718 * an activity, retrieves the information about it and calls 2719 * {@link ComponentInfo#loadIcon ComponentInfo.loadIcon()} to return its icon. 2720 * If the activity cannot be found, NameNotFoundException is thrown. 2721 * 2722 * @param activityName Name of the activity whose icon is to be retrieved. 2723 * 2724 * @return Returns the image of the icon, or the default activity icon if 2725 * it could not be found. Does not return null. 2726 * @throws NameNotFoundException Thrown if the resources for the given 2727 * activity could not be loaded. 2728 * 2729 * @see #getActivityIcon(Intent) 2730 */ getActivityIcon(ComponentName activityName)2731 public abstract Drawable getActivityIcon(ComponentName activityName) 2732 throws NameNotFoundException; 2733 2734 /** 2735 * Retrieve the icon associated with an Intent. If intent.getClassName() is 2736 * set, this simply returns the result of 2737 * getActivityIcon(intent.getClassName()). Otherwise it resolves the intent's 2738 * component and returns the icon associated with the resolved component. 2739 * If intent.getClassName() cannot be found or the Intent cannot be resolved 2740 * to a component, NameNotFoundException is thrown. 2741 * 2742 * @param intent The intent for which you would like to retrieve an icon. 2743 * 2744 * @return Returns the image of the icon, or the default activity icon if 2745 * it could not be found. Does not return null. 2746 * @throws NameNotFoundException Thrown if the resources for application 2747 * matching the given intent could not be loaded. 2748 * 2749 * @see #getActivityIcon(ComponentName) 2750 */ getActivityIcon(Intent intent)2751 public abstract Drawable getActivityIcon(Intent intent) 2752 throws NameNotFoundException; 2753 2754 /** 2755 * Retrieve the banner associated with an activity. Given the full name of 2756 * an activity, retrieves the information about it and calls 2757 * {@link ComponentInfo#loadIcon ComponentInfo.loadIcon()} to return its 2758 * banner. If the activity cannot be found, NameNotFoundException is thrown. 2759 * 2760 * @param activityName Name of the activity whose banner is to be retrieved. 2761 * @return Returns the image of the banner, or null if the activity has no 2762 * banner specified. 2763 * @throws NameNotFoundException Thrown if the resources for the given 2764 * activity could not be loaded. 2765 * @see #getActivityBanner(Intent) 2766 */ getActivityBanner(ComponentName activityName)2767 public abstract Drawable getActivityBanner(ComponentName activityName) 2768 throws NameNotFoundException; 2769 2770 /** 2771 * Retrieve the banner associated with an Intent. If intent.getClassName() 2772 * is set, this simply returns the result of 2773 * getActivityBanner(intent.getClassName()). Otherwise it resolves the 2774 * intent's component and returns the banner associated with the resolved 2775 * component. If intent.getClassName() cannot be found or the Intent cannot 2776 * be resolved to a component, NameNotFoundException is thrown. 2777 * 2778 * @param intent The intent for which you would like to retrieve a banner. 2779 * @return Returns the image of the banner, or null if the activity has no 2780 * banner specified. 2781 * @throws NameNotFoundException Thrown if the resources for application 2782 * matching the given intent could not be loaded. 2783 * @see #getActivityBanner(ComponentName) 2784 */ getActivityBanner(Intent intent)2785 public abstract Drawable getActivityBanner(Intent intent) 2786 throws NameNotFoundException; 2787 2788 /** 2789 * Return the generic icon for an activity that is used when no specific 2790 * icon is defined. 2791 * 2792 * @return Drawable Image of the icon. 2793 */ getDefaultActivityIcon()2794 public abstract Drawable getDefaultActivityIcon(); 2795 2796 /** 2797 * Retrieve the icon associated with an application. If it has not defined 2798 * an icon, the default app icon is returned. Does not return null. 2799 * 2800 * @param info Information about application being queried. 2801 * 2802 * @return Returns the image of the icon, or the default application icon 2803 * if it could not be found. 2804 * 2805 * @see #getApplicationIcon(String) 2806 */ getApplicationIcon(ApplicationInfo info)2807 public abstract Drawable getApplicationIcon(ApplicationInfo info); 2808 2809 /** 2810 * Retrieve the icon associated with an application. Given the name of the 2811 * application's package, retrieves the information about it and calls 2812 * getApplicationIcon() to return its icon. If the application cannot be 2813 * found, NameNotFoundException is thrown. 2814 * 2815 * @param packageName Name of the package whose application icon is to be 2816 * retrieved. 2817 * 2818 * @return Returns the image of the icon, or the default application icon 2819 * if it could not be found. Does not return null. 2820 * @throws NameNotFoundException Thrown if the resources for the given 2821 * application could not be loaded. 2822 * 2823 * @see #getApplicationIcon(ApplicationInfo) 2824 */ getApplicationIcon(String packageName)2825 public abstract Drawable getApplicationIcon(String packageName) 2826 throws NameNotFoundException; 2827 2828 /** 2829 * Retrieve the banner associated with an application. 2830 * 2831 * @param info Information about application being queried. 2832 * @return Returns the image of the banner or null if the application has no 2833 * banner specified. 2834 * @see #getApplicationBanner(String) 2835 */ getApplicationBanner(ApplicationInfo info)2836 public abstract Drawable getApplicationBanner(ApplicationInfo info); 2837 2838 /** 2839 * Retrieve the banner associated with an application. Given the name of the 2840 * application's package, retrieves the information about it and calls 2841 * getApplicationIcon() to return its banner. If the application cannot be 2842 * found, NameNotFoundException is thrown. 2843 * 2844 * @param packageName Name of the package whose application banner is to be 2845 * retrieved. 2846 * @return Returns the image of the banner or null if the application has no 2847 * banner specified. 2848 * @throws NameNotFoundException Thrown if the resources for the given 2849 * application could not be loaded. 2850 * @see #getApplicationBanner(ApplicationInfo) 2851 */ getApplicationBanner(String packageName)2852 public abstract Drawable getApplicationBanner(String packageName) 2853 throws NameNotFoundException; 2854 2855 /** 2856 * Retrieve the logo associated with an activity. Given the full name of an 2857 * activity, retrieves the information about it and calls 2858 * {@link ComponentInfo#loadLogo ComponentInfo.loadLogo()} to return its 2859 * logo. If the activity cannot be found, NameNotFoundException is thrown. 2860 * 2861 * @param activityName Name of the activity whose logo is to be retrieved. 2862 * @return Returns the image of the logo or null if the activity has no logo 2863 * specified. 2864 * @throws NameNotFoundException Thrown if the resources for the given 2865 * activity could not be loaded. 2866 * @see #getActivityLogo(Intent) 2867 */ getActivityLogo(ComponentName activityName)2868 public abstract Drawable getActivityLogo(ComponentName activityName) 2869 throws NameNotFoundException; 2870 2871 /** 2872 * Retrieve the logo associated with an Intent. If intent.getClassName() is 2873 * set, this simply returns the result of 2874 * getActivityLogo(intent.getClassName()). Otherwise it resolves the intent's 2875 * component and returns the logo associated with the resolved component. 2876 * If intent.getClassName() cannot be found or the Intent cannot be resolved 2877 * to a component, NameNotFoundException is thrown. 2878 * 2879 * @param intent The intent for which you would like to retrieve a logo. 2880 * 2881 * @return Returns the image of the logo, or null if the activity has no 2882 * logo specified. 2883 * 2884 * @throws NameNotFoundException Thrown if the resources for application 2885 * matching the given intent could not be loaded. 2886 * 2887 * @see #getActivityLogo(ComponentName) 2888 */ getActivityLogo(Intent intent)2889 public abstract Drawable getActivityLogo(Intent intent) 2890 throws NameNotFoundException; 2891 2892 /** 2893 * Retrieve the logo associated with an application. If it has not specified 2894 * a logo, this method returns null. 2895 * 2896 * @param info Information about application being queried. 2897 * 2898 * @return Returns the image of the logo, or null if no logo is specified 2899 * by the application. 2900 * 2901 * @see #getApplicationLogo(String) 2902 */ getApplicationLogo(ApplicationInfo info)2903 public abstract Drawable getApplicationLogo(ApplicationInfo info); 2904 2905 /** 2906 * Retrieve the logo associated with an application. Given the name of the 2907 * application's package, retrieves the information about it and calls 2908 * getApplicationLogo() to return its logo. If the application cannot be 2909 * found, NameNotFoundException is thrown. 2910 * 2911 * @param packageName Name of the package whose application logo is to be 2912 * retrieved. 2913 * 2914 * @return Returns the image of the logo, or null if no application logo 2915 * has been specified. 2916 * 2917 * @throws NameNotFoundException Thrown if the resources for the given 2918 * application could not be loaded. 2919 * 2920 * @see #getApplicationLogo(ApplicationInfo) 2921 */ getApplicationLogo(String packageName)2922 public abstract Drawable getApplicationLogo(String packageName) 2923 throws NameNotFoundException; 2924 2925 /** 2926 * If the target user is a managed profile of the calling user or the caller 2927 * is itself a managed profile, then this returns a badged copy of the given 2928 * icon to be able to distinguish it from the original icon. For badging an 2929 * arbitrary drawable use {@link #getUserBadgedDrawableForDensity( 2930 * android.graphics.drawable.Drawable, UserHandle, android.graphics.Rect, int)}. 2931 * <p> 2932 * If the original drawable is a BitmapDrawable and the backing bitmap is 2933 * mutable as per {@link android.graphics.Bitmap#isMutable()}, the badging 2934 * is performed in place and the original drawable is returned. 2935 * </p> 2936 * 2937 * @param icon The icon to badge. 2938 * @param user The target user. 2939 * @return A drawable that combines the original icon and a badge as 2940 * determined by the system. 2941 */ getUserBadgedIcon(Drawable icon, UserHandle user)2942 public abstract Drawable getUserBadgedIcon(Drawable icon, UserHandle user); 2943 2944 /** 2945 * If the target user is a managed profile of the calling user or the caller 2946 * is itself a managed profile, then this returns a badged copy of the given 2947 * drawable allowing the user to distinguish it from the original drawable. 2948 * The caller can specify the location in the bounds of the drawable to be 2949 * badged where the badge should be applied as well as the density of the 2950 * badge to be used. 2951 * <p> 2952 * If the original drawable is a BitmapDrawable and the backing bitmap is 2953 * mutable as per {@link android.graphics.Bitmap#isMutable()}, the bading 2954 * is performed in place and the original drawable is returned. 2955 * </p> 2956 * 2957 * @param drawable The drawable to badge. 2958 * @param user The target user. 2959 * @param badgeLocation Where in the bounds of the badged drawable to place 2960 * the badge. If not provided, the badge is applied on top of the entire 2961 * drawable being badged. 2962 * @param badgeDensity The optional desired density for the badge as per 2963 * {@link android.util.DisplayMetrics#densityDpi}. If not provided, 2964 * the density of the display is used. 2965 * @return A drawable that combines the original drawable and a badge as 2966 * determined by the system. 2967 */ getUserBadgedDrawableForDensity(Drawable drawable, UserHandle user, Rect badgeLocation, int badgeDensity)2968 public abstract Drawable getUserBadgedDrawableForDensity(Drawable drawable, 2969 UserHandle user, Rect badgeLocation, int badgeDensity); 2970 2971 /** 2972 * If the target user is a managed profile of the calling user or the caller 2973 * is itself a managed profile, then this returns a drawable to use as a small 2974 * icon to include in a view to distinguish it from the original icon. 2975 * 2976 * @param user The target user. 2977 * @param density The optional desired density for the badge as per 2978 * {@link android.util.DisplayMetrics#densityDpi}. If not provided 2979 * the density of the current display is used. 2980 * @return the drawable or null if no drawable is required. 2981 * @hide 2982 */ getUserBadgeForDensity(UserHandle user, int density)2983 public abstract Drawable getUserBadgeForDensity(UserHandle user, int density); 2984 2985 /** 2986 * If the target user is a managed profile of the calling user or the caller 2987 * is itself a managed profile, then this returns a copy of the label with 2988 * badging for accessibility services like talkback. E.g. passing in "Email" 2989 * and it might return "Work Email" for Email in the work profile. 2990 * 2991 * @param label The label to change. 2992 * @param user The target user. 2993 * @return A label that combines the original label and a badge as 2994 * determined by the system. 2995 */ getUserBadgedLabel(CharSequence label, UserHandle user)2996 public abstract CharSequence getUserBadgedLabel(CharSequence label, UserHandle user); 2997 2998 /** 2999 * Retrieve text from a package. This is a low-level API used by 3000 * the various package manager info structures (such as 3001 * {@link ComponentInfo} to implement retrieval of their associated 3002 * labels and other text. 3003 * 3004 * @param packageName The name of the package that this text is coming from. 3005 * Cannot be null. 3006 * @param resid The resource identifier of the desired text. Cannot be 0. 3007 * @param appInfo Overall information about <var>packageName</var>. This 3008 * may be null, in which case the application information will be retrieved 3009 * for you if needed; if you already have this information around, it can 3010 * be much more efficient to supply it here. 3011 * 3012 * @return Returns a CharSequence holding the requested text. Returns null 3013 * if the text could not be found for any reason. 3014 */ getText(String packageName, int resid, ApplicationInfo appInfo)3015 public abstract CharSequence getText(String packageName, int resid, 3016 ApplicationInfo appInfo); 3017 3018 /** 3019 * Retrieve an XML file from a package. This is a low-level API used to 3020 * retrieve XML meta data. 3021 * 3022 * @param packageName The name of the package that this xml is coming from. 3023 * Cannot be null. 3024 * @param resid The resource identifier of the desired xml. Cannot be 0. 3025 * @param appInfo Overall information about <var>packageName</var>. This 3026 * may be null, in which case the application information will be retrieved 3027 * for you if needed; if you already have this information around, it can 3028 * be much more efficient to supply it here. 3029 * 3030 * @return Returns an XmlPullParser allowing you to parse out the XML 3031 * data. Returns null if the xml resource could not be found for any 3032 * reason. 3033 */ getXml(String packageName, int resid, ApplicationInfo appInfo)3034 public abstract XmlResourceParser getXml(String packageName, int resid, 3035 ApplicationInfo appInfo); 3036 3037 /** 3038 * Return the label to use for this application. 3039 * 3040 * @return Returns the label associated with this application, or null if 3041 * it could not be found for any reason. 3042 * @param info The application to get the label of. 3043 */ getApplicationLabel(ApplicationInfo info)3044 public abstract CharSequence getApplicationLabel(ApplicationInfo info); 3045 3046 /** 3047 * Retrieve the resources associated with an activity. Given the full 3048 * name of an activity, retrieves the information about it and calls 3049 * getResources() to return its application's resources. If the activity 3050 * cannot be found, NameNotFoundException is thrown. 3051 * 3052 * @param activityName Name of the activity whose resources are to be 3053 * retrieved. 3054 * 3055 * @return Returns the application's Resources. 3056 * @throws NameNotFoundException Thrown if the resources for the given 3057 * application could not be loaded. 3058 * 3059 * @see #getResourcesForApplication(ApplicationInfo) 3060 */ getResourcesForActivity(ComponentName activityName)3061 public abstract Resources getResourcesForActivity(ComponentName activityName) 3062 throws NameNotFoundException; 3063 3064 /** 3065 * Retrieve the resources for an application. Throws NameNotFoundException 3066 * if the package is no longer installed. 3067 * 3068 * @param app Information about the desired application. 3069 * 3070 * @return Returns the application's Resources. 3071 * @throws NameNotFoundException Thrown if the resources for the given 3072 * application could not be loaded (most likely because it was uninstalled). 3073 */ getResourcesForApplication(ApplicationInfo app)3074 public abstract Resources getResourcesForApplication(ApplicationInfo app) 3075 throws NameNotFoundException; 3076 3077 /** 3078 * Retrieve the resources associated with an application. Given the full 3079 * package name of an application, retrieves the information about it and 3080 * calls getResources() to return its application's resources. If the 3081 * appPackageName cannot be found, NameNotFoundException is thrown. 3082 * 3083 * @param appPackageName Package name of the application whose resources 3084 * are to be retrieved. 3085 * 3086 * @return Returns the application's Resources. 3087 * @throws NameNotFoundException Thrown if the resources for the given 3088 * application could not be loaded. 3089 * 3090 * @see #getResourcesForApplication(ApplicationInfo) 3091 */ getResourcesForApplication(String appPackageName)3092 public abstract Resources getResourcesForApplication(String appPackageName) 3093 throws NameNotFoundException; 3094 3095 /** @hide */ getResourcesForApplicationAsUser(String appPackageName, int userId)3096 public abstract Resources getResourcesForApplicationAsUser(String appPackageName, int userId) 3097 throws NameNotFoundException; 3098 3099 /** 3100 * Retrieve overall information about an application package defined 3101 * in a package archive file 3102 * 3103 * @param archiveFilePath The path to the archive file 3104 * @param flags Additional option flags. Use any combination of 3105 * {@link #GET_ACTIVITIES}, 3106 * {@link #GET_GIDS}, 3107 * {@link #GET_CONFIGURATIONS}, 3108 * {@link #GET_INSTRUMENTATION}, 3109 * {@link #GET_PERMISSIONS}, 3110 * {@link #GET_PROVIDERS}, 3111 * {@link #GET_RECEIVERS}, 3112 * {@link #GET_SERVICES}, 3113 * {@link #GET_SIGNATURES}, to modify the data returned. 3114 * 3115 * @return Returns the information about the package. Returns 3116 * null if the package could not be successfully parsed. 3117 * 3118 * @see #GET_ACTIVITIES 3119 * @see #GET_GIDS 3120 * @see #GET_CONFIGURATIONS 3121 * @see #GET_INSTRUMENTATION 3122 * @see #GET_PERMISSIONS 3123 * @see #GET_PROVIDERS 3124 * @see #GET_RECEIVERS 3125 * @see #GET_SERVICES 3126 * @see #GET_SIGNATURES 3127 * 3128 */ getPackageArchiveInfo(String archiveFilePath, int flags)3129 public PackageInfo getPackageArchiveInfo(String archiveFilePath, int flags) { 3130 final PackageParser parser = new PackageParser(); 3131 final File apkFile = new File(archiveFilePath); 3132 try { 3133 PackageParser.Package pkg = parser.parseMonolithicPackage(apkFile, 0); 3134 if ((flags & GET_SIGNATURES) != 0) { 3135 parser.collectCertificates(pkg, 0); 3136 parser.collectManifestDigest(pkg); 3137 } 3138 PackageUserState state = new PackageUserState(); 3139 return PackageParser.generatePackageInfo(pkg, null, flags, 0, 0, null, state); 3140 } catch (PackageParserException e) { 3141 return null; 3142 } 3143 } 3144 3145 /** 3146 * @hide Install a package. Since this may take a little while, the result 3147 * will be posted back to the given observer. An installation will 3148 * fail if the calling context lacks the 3149 * {@link android.Manifest.permission#INSTALL_PACKAGES} permission, if 3150 * the package named in the package file's manifest is already 3151 * installed, or if there's no space available on the device. 3152 * @param packageURI The location of the package file to install. This can 3153 * be a 'file:' or a 'content:' URI. 3154 * @param observer An observer callback to get notified when the package 3155 * installation is complete. 3156 * {@link IPackageInstallObserver#packageInstalled(String, int)} 3157 * will be called when that happens. This parameter must not be 3158 * null. 3159 * @param flags - possible values: {@link #INSTALL_FORWARD_LOCK}, 3160 * {@link #INSTALL_REPLACE_EXISTING}, 3161 * {@link #INSTALL_ALLOW_TEST}. 3162 * @param installerPackageName Optional package name of the application that 3163 * is performing the installation. This identifies which market 3164 * the package came from. 3165 * @deprecated Use {@link #installPackage(Uri, PackageInstallObserver, int, 3166 * String)} instead. This method will continue to be supported 3167 * but the older observer interface will not get additional 3168 * failure details. 3169 */ 3170 // @SystemApi installPackage( Uri packageURI, IPackageInstallObserver observer, int flags, String installerPackageName)3171 public abstract void installPackage( 3172 Uri packageURI, IPackageInstallObserver observer, int flags, 3173 String installerPackageName); 3174 3175 /** 3176 * Similar to 3177 * {@link #installPackage(Uri, IPackageInstallObserver, int, String)} but 3178 * with an extra verification file provided. 3179 * 3180 * @param packageURI The location of the package file to install. This can 3181 * be a 'file:' or a 'content:' URI. 3182 * @param observer An observer callback to get notified when the package 3183 * installation is complete. 3184 * {@link IPackageInstallObserver#packageInstalled(String, int)} 3185 * will be called when that happens. This parameter must not be 3186 * null. 3187 * @param flags - possible values: {@link #INSTALL_FORWARD_LOCK}, 3188 * {@link #INSTALL_REPLACE_EXISTING}, 3189 * {@link #INSTALL_ALLOW_TEST}. 3190 * @param installerPackageName Optional package name of the application that 3191 * is performing the installation. This identifies which market 3192 * the package came from. 3193 * @param verificationURI The location of the supplementary verification 3194 * file. This can be a 'file:' or a 'content:' URI. May be 3195 * {@code null}. 3196 * @param manifestDigest an object that holds the digest of the package 3197 * which can be used to verify ownership. May be {@code null}. 3198 * @param encryptionParams if the package to be installed is encrypted, 3199 * these parameters describing the encryption and authentication 3200 * used. May be {@code null}. 3201 * @hide 3202 * @deprecated Use {@link #installPackageWithVerification(Uri, 3203 * PackageInstallObserver, int, String, Uri, ManifestDigest, 3204 * ContainerEncryptionParams)} instead. This method will 3205 * continue to be supported but the older observer interface 3206 * will not get additional failure details. 3207 */ 3208 // @SystemApi installPackageWithVerification(Uri packageURI, IPackageInstallObserver observer, int flags, String installerPackageName, Uri verificationURI, ManifestDigest manifestDigest, ContainerEncryptionParams encryptionParams)3209 public abstract void installPackageWithVerification(Uri packageURI, 3210 IPackageInstallObserver observer, int flags, String installerPackageName, 3211 Uri verificationURI, ManifestDigest manifestDigest, 3212 ContainerEncryptionParams encryptionParams); 3213 3214 /** 3215 * Similar to 3216 * {@link #installPackage(Uri, IPackageInstallObserver, int, String)} but 3217 * with an extra verification information provided. 3218 * 3219 * @param packageURI The location of the package file to install. This can 3220 * be a 'file:' or a 'content:' URI. 3221 * @param observer An observer callback to get notified when the package 3222 * installation is complete. 3223 * {@link IPackageInstallObserver#packageInstalled(String, int)} 3224 * will be called when that happens. This parameter must not be 3225 * null. 3226 * @param flags - possible values: {@link #INSTALL_FORWARD_LOCK}, 3227 * {@link #INSTALL_REPLACE_EXISTING}, 3228 * {@link #INSTALL_ALLOW_TEST}. 3229 * @param installerPackageName Optional package name of the application that 3230 * is performing the installation. This identifies which market 3231 * the package came from. 3232 * @param verificationParams an object that holds signal information to 3233 * assist verification. May be {@code null}. 3234 * @param encryptionParams if the package to be installed is encrypted, 3235 * these parameters describing the encryption and authentication 3236 * used. May be {@code null}. 3237 * @hide 3238 * @deprecated Use {@link #installPackageWithVerificationAndEncryption(Uri, 3239 * PackageInstallObserver, int, String, VerificationParams, 3240 * ContainerEncryptionParams)} instead. This method will 3241 * continue to be supported but the older observer interface 3242 * will not get additional failure details. 3243 */ 3244 @Deprecated installPackageWithVerificationAndEncryption(Uri packageURI, IPackageInstallObserver observer, int flags, String installerPackageName, VerificationParams verificationParams, ContainerEncryptionParams encryptionParams)3245 public abstract void installPackageWithVerificationAndEncryption(Uri packageURI, 3246 IPackageInstallObserver observer, int flags, String installerPackageName, 3247 VerificationParams verificationParams, 3248 ContainerEncryptionParams encryptionParams); 3249 3250 // Package-install variants that take the new, expanded form of observer interface. 3251 // Note that these *also* take the original observer type and will redundantly 3252 // report the same information to that observer if supplied; but it is not required. 3253 3254 /** 3255 * @hide 3256 * 3257 * Install a package. Since this may take a little while, the result will 3258 * be posted back to the given observer. An installation will fail if the calling context 3259 * lacks the {@link android.Manifest.permission#INSTALL_PACKAGES} permission, if the 3260 * package named in the package file's manifest is already installed, or if there's no space 3261 * available on the device. 3262 * 3263 * @param packageURI The location of the package file to install. This can be a 'file:' or a 3264 * 'content:' URI. 3265 * @param observer An observer callback to get notified when the package installation is 3266 * complete. {@link PackageInstallObserver#packageInstalled(String, Bundle, int)} will be 3267 * called when that happens. This parameter must not be null. 3268 * @param flags - possible values: {@link #INSTALL_FORWARD_LOCK}, 3269 * {@link #INSTALL_REPLACE_EXISTING}, {@link #INSTALL_ALLOW_TEST}. 3270 * @param installerPackageName Optional package name of the application that is performing the 3271 * installation. This identifies which market the package came from. 3272 */ installPackage( Uri packageURI, PackageInstallObserver observer, int flags, String installerPackageName)3273 public abstract void installPackage( 3274 Uri packageURI, PackageInstallObserver observer, 3275 int flags, String installerPackageName); 3276 3277 /** 3278 * Similar to 3279 * {@link #installPackage(Uri, IPackageInstallObserver, int, String)} but 3280 * with an extra verification file provided. 3281 * 3282 * @param packageURI The location of the package file to install. This can 3283 * be a 'file:' or a 'content:' URI. 3284 * @param observer An observer callback to get notified when the package installation is 3285 * complete. {@link PackageInstallObserver#packageInstalled(String, Bundle, int)} will be 3286 * called when that happens. This parameter must not be null. 3287 * @param flags - possible values: {@link #INSTALL_FORWARD_LOCK}, 3288 * {@link #INSTALL_REPLACE_EXISTING}, {@link #INSTALL_ALLOW_TEST}. 3289 * @param installerPackageName Optional package name of the application that 3290 * is performing the installation. This identifies which market 3291 * the package came from. 3292 * @param verificationURI The location of the supplementary verification 3293 * file. This can be a 'file:' or a 'content:' URI. May be 3294 * {@code null}. 3295 * @param manifestDigest an object that holds the digest of the package 3296 * which can be used to verify ownership. May be {@code null}. 3297 * @param encryptionParams if the package to be installed is encrypted, 3298 * these parameters describing the encryption and authentication 3299 * used. May be {@code null}. 3300 * @hide 3301 */ installPackageWithVerification(Uri packageURI, PackageInstallObserver observer, int flags, String installerPackageName, Uri verificationURI, ManifestDigest manifestDigest, ContainerEncryptionParams encryptionParams)3302 public abstract void installPackageWithVerification(Uri packageURI, 3303 PackageInstallObserver observer, int flags, String installerPackageName, 3304 Uri verificationURI, ManifestDigest manifestDigest, 3305 ContainerEncryptionParams encryptionParams); 3306 3307 /** 3308 * Similar to 3309 * {@link #installPackage(Uri, IPackageInstallObserver, int, String)} but 3310 * with an extra verification information provided. 3311 * 3312 * @param packageURI The location of the package file to install. This can 3313 * be a 'file:' or a 'content:' URI. 3314 * @param observer An observer callback to get notified when the package installation is 3315 * complete. {@link PackageInstallObserver#packageInstalled(String, Bundle, int)} will be 3316 * called when that happens. This parameter must not be null. 3317 * @param flags - possible values: {@link #INSTALL_FORWARD_LOCK}, 3318 * {@link #INSTALL_REPLACE_EXISTING}, {@link #INSTALL_ALLOW_TEST}. 3319 * @param installerPackageName Optional package name of the application that 3320 * is performing the installation. This identifies which market 3321 * the package came from. 3322 * @param verificationParams an object that holds signal information to 3323 * assist verification. May be {@code null}. 3324 * @param encryptionParams if the package to be installed is encrypted, 3325 * these parameters describing the encryption and authentication 3326 * used. May be {@code null}. 3327 * 3328 * @hide 3329 */ installPackageWithVerificationAndEncryption(Uri packageURI, PackageInstallObserver observer, int flags, String installerPackageName, VerificationParams verificationParams, ContainerEncryptionParams encryptionParams)3330 public abstract void installPackageWithVerificationAndEncryption(Uri packageURI, 3331 PackageInstallObserver observer, int flags, String installerPackageName, 3332 VerificationParams verificationParams, ContainerEncryptionParams encryptionParams); 3333 3334 /** 3335 * If there is already an application with the given package name installed 3336 * on the system for other users, also install it for the calling user. 3337 * @hide 3338 */ 3339 // @SystemApi installExistingPackage(String packageName)3340 public abstract int installExistingPackage(String packageName) 3341 throws NameNotFoundException; 3342 3343 /** 3344 * Allows a package listening to the 3345 * {@link Intent#ACTION_PACKAGE_NEEDS_VERIFICATION package verification 3346 * broadcast} to respond to the package manager. The response must include 3347 * the {@code verificationCode} which is one of 3348 * {@link PackageManager#VERIFICATION_ALLOW} or 3349 * {@link PackageManager#VERIFICATION_REJECT}. 3350 * 3351 * @param id pending package identifier as passed via the 3352 * {@link PackageManager#EXTRA_VERIFICATION_ID} Intent extra. 3353 * @param verificationCode either {@link PackageManager#VERIFICATION_ALLOW} 3354 * or {@link PackageManager#VERIFICATION_REJECT}. 3355 * @throws SecurityException if the caller does not have the 3356 * PACKAGE_VERIFICATION_AGENT permission. 3357 */ verifyPendingInstall(int id, int verificationCode)3358 public abstract void verifyPendingInstall(int id, int verificationCode); 3359 3360 /** 3361 * Allows a package listening to the 3362 * {@link Intent#ACTION_PACKAGE_NEEDS_VERIFICATION package verification 3363 * broadcast} to extend the default timeout for a response and declare what 3364 * action to perform after the timeout occurs. The response must include 3365 * the {@code verificationCodeAtTimeout} which is one of 3366 * {@link PackageManager#VERIFICATION_ALLOW} or 3367 * {@link PackageManager#VERIFICATION_REJECT}. 3368 * 3369 * This method may only be called once per package id. Additional calls 3370 * will have no effect. 3371 * 3372 * @param id pending package identifier as passed via the 3373 * {@link PackageManager#EXTRA_VERIFICATION_ID} Intent extra. 3374 * @param verificationCodeAtTimeout either 3375 * {@link PackageManager#VERIFICATION_ALLOW} or 3376 * {@link PackageManager#VERIFICATION_REJECT}. If 3377 * {@code verificationCodeAtTimeout} is neither 3378 * {@link PackageManager#VERIFICATION_ALLOW} or 3379 * {@link PackageManager#VERIFICATION_REJECT}, then 3380 * {@code verificationCodeAtTimeout} will default to 3381 * {@link PackageManager#VERIFICATION_REJECT}. 3382 * @param millisecondsToDelay the amount of time requested for the timeout. 3383 * Must be positive and less than 3384 * {@link PackageManager#MAXIMUM_VERIFICATION_TIMEOUT}. If 3385 * {@code millisecondsToDelay} is out of bounds, 3386 * {@code millisecondsToDelay} will be set to the closest in 3387 * bounds value; namely, 0 or 3388 * {@link PackageManager#MAXIMUM_VERIFICATION_TIMEOUT}. 3389 * @throws SecurityException if the caller does not have the 3390 * PACKAGE_VERIFICATION_AGENT permission. 3391 */ extendVerificationTimeout(int id, int verificationCodeAtTimeout, long millisecondsToDelay)3392 public abstract void extendVerificationTimeout(int id, 3393 int verificationCodeAtTimeout, long millisecondsToDelay); 3394 3395 /** 3396 * Change the installer associated with a given package. There are limitations 3397 * on how the installer package can be changed; in particular: 3398 * <ul> 3399 * <li> A SecurityException will be thrown if <var>installerPackageName</var> 3400 * is not signed with the same certificate as the calling application. 3401 * <li> A SecurityException will be thrown if <var>targetPackage</var> already 3402 * has an installer package, and that installer package is not signed with 3403 * the same certificate as the calling application. 3404 * </ul> 3405 * 3406 * @param targetPackage The installed package whose installer will be changed. 3407 * @param installerPackageName The package name of the new installer. May be 3408 * null to clear the association. 3409 */ setInstallerPackageName(String targetPackage, String installerPackageName)3410 public abstract void setInstallerPackageName(String targetPackage, 3411 String installerPackageName); 3412 3413 /** 3414 * Attempts to delete a package. Since this may take a little while, the result will 3415 * be posted back to the given observer. A deletion will fail if the calling context 3416 * lacks the {@link android.Manifest.permission#DELETE_PACKAGES} permission, if the 3417 * named package cannot be found, or if the named package is a "system package". 3418 * (TODO: include pointer to documentation on "system packages") 3419 * 3420 * @param packageName The name of the package to delete 3421 * @param observer An observer callback to get notified when the package deletion is 3422 * complete. {@link android.content.pm.IPackageDeleteObserver#packageDeleted(boolean)} will be 3423 * called when that happens. observer may be null to indicate that no callback is desired. 3424 * @param flags - possible values: {@link #DELETE_KEEP_DATA}, 3425 * {@link #DELETE_ALL_USERS}. 3426 * 3427 * @hide 3428 */ 3429 // @SystemApi deletePackage( String packageName, IPackageDeleteObserver observer, int flags)3430 public abstract void deletePackage( 3431 String packageName, IPackageDeleteObserver observer, int flags); 3432 3433 /** 3434 * Retrieve the package name of the application that installed a package. This identifies 3435 * which market the package came from. 3436 * 3437 * @param packageName The name of the package to query 3438 */ getInstallerPackageName(String packageName)3439 public abstract String getInstallerPackageName(String packageName); 3440 3441 /** 3442 * Attempts to clear the user data directory of an application. 3443 * Since this may take a little while, the result will 3444 * be posted back to the given observer. A deletion will fail if the 3445 * named package cannot be found, or if the named package is a "system package". 3446 * 3447 * @param packageName The name of the package 3448 * @param observer An observer callback to get notified when the operation is finished 3449 * {@link android.content.pm.IPackageDataObserver#onRemoveCompleted(String, boolean)} 3450 * will be called when that happens. observer may be null to indicate that 3451 * no callback is desired. 3452 * 3453 * @hide 3454 */ clearApplicationUserData(String packageName, IPackageDataObserver observer)3455 public abstract void clearApplicationUserData(String packageName, 3456 IPackageDataObserver observer); 3457 /** 3458 * Attempts to delete the cache files associated with an application. 3459 * Since this may take a little while, the result will 3460 * be posted back to the given observer. A deletion will fail if the calling context 3461 * lacks the {@link android.Manifest.permission#DELETE_CACHE_FILES} permission, if the 3462 * named package cannot be found, or if the named package is a "system package". 3463 * 3464 * @param packageName The name of the package to delete 3465 * @param observer An observer callback to get notified when the cache file deletion 3466 * is complete. 3467 * {@link android.content.pm.IPackageDataObserver#onRemoveCompleted(String, boolean)} 3468 * will be called when that happens. observer may be null to indicate that 3469 * no callback is desired. 3470 * 3471 * @hide 3472 */ deleteApplicationCacheFiles(String packageName, IPackageDataObserver observer)3473 public abstract void deleteApplicationCacheFiles(String packageName, 3474 IPackageDataObserver observer); 3475 3476 /** 3477 * Free storage by deleting LRU sorted list of cache files across 3478 * all applications. If the currently available free storage 3479 * on the device is greater than or equal to the requested 3480 * free storage, no cache files are cleared. If the currently 3481 * available storage on the device is less than the requested 3482 * free storage, some or all of the cache files across 3483 * all applications are deleted (based on last accessed time) 3484 * to increase the free storage space on the device to 3485 * the requested value. There is no guarantee that clearing all 3486 * the cache files from all applications will clear up 3487 * enough storage to achieve the desired value. 3488 * @param freeStorageSize The number of bytes of storage to be 3489 * freed by the system. Say if freeStorageSize is XX, 3490 * and the current free storage is YY, 3491 * if XX is less than YY, just return. if not free XX-YY number 3492 * of bytes if possible. 3493 * @param observer call back used to notify when 3494 * the operation is completed 3495 * 3496 * @hide 3497 */ 3498 // @SystemApi freeStorageAndNotify(long freeStorageSize, IPackageDataObserver observer)3499 public abstract void freeStorageAndNotify(long freeStorageSize, IPackageDataObserver observer); 3500 3501 /** 3502 * Free storage by deleting LRU sorted list of cache files across 3503 * all applications. If the currently available free storage 3504 * on the device is greater than or equal to the requested 3505 * free storage, no cache files are cleared. If the currently 3506 * available storage on the device is less than the requested 3507 * free storage, some or all of the cache files across 3508 * all applications are deleted (based on last accessed time) 3509 * to increase the free storage space on the device to 3510 * the requested value. There is no guarantee that clearing all 3511 * the cache files from all applications will clear up 3512 * enough storage to achieve the desired value. 3513 * @param freeStorageSize The number of bytes of storage to be 3514 * freed by the system. Say if freeStorageSize is XX, 3515 * and the current free storage is YY, 3516 * if XX is less than YY, just return. if not free XX-YY number 3517 * of bytes if possible. 3518 * @param pi IntentSender call back used to 3519 * notify when the operation is completed.May be null 3520 * to indicate that no call back is desired. 3521 * 3522 * @hide 3523 */ freeStorage(long freeStorageSize, IntentSender pi)3524 public abstract void freeStorage(long freeStorageSize, IntentSender pi); 3525 3526 /** 3527 * Retrieve the size information for a package. 3528 * Since this may take a little while, the result will 3529 * be posted back to the given observer. The calling context 3530 * should have the {@link android.Manifest.permission#GET_PACKAGE_SIZE} permission. 3531 * 3532 * @param packageName The name of the package whose size information is to be retrieved 3533 * @param userHandle The user whose size information should be retrieved. 3534 * @param observer An observer callback to get notified when the operation 3535 * is complete. 3536 * {@link android.content.pm.IPackageStatsObserver#onGetStatsCompleted(PackageStats, boolean)} 3537 * The observer's callback is invoked with a PackageStats object(containing the 3538 * code, data and cache sizes of the package) and a boolean value representing 3539 * the status of the operation. observer may be null to indicate that 3540 * no callback is desired. 3541 * 3542 * @hide 3543 */ getPackageSizeInfo(String packageName, int userHandle, IPackageStatsObserver observer)3544 public abstract void getPackageSizeInfo(String packageName, int userHandle, 3545 IPackageStatsObserver observer); 3546 3547 /** 3548 * Like {@link #getPackageSizeInfo(String, int, IPackageStatsObserver)}, but 3549 * returns the size for the calling user. 3550 * 3551 * @hide 3552 */ getPackageSizeInfo(String packageName, IPackageStatsObserver observer)3553 public void getPackageSizeInfo(String packageName, IPackageStatsObserver observer) { 3554 getPackageSizeInfo(packageName, UserHandle.myUserId(), observer); 3555 } 3556 3557 /** 3558 * @deprecated This function no longer does anything; it was an old 3559 * approach to managing preferred activities, which has been superseded 3560 * by (and conflicts with) the modern activity-based preferences. 3561 */ 3562 @Deprecated addPackageToPreferred(String packageName)3563 public abstract void addPackageToPreferred(String packageName); 3564 3565 /** 3566 * @deprecated This function no longer does anything; it was an old 3567 * approach to managing preferred activities, which has been superseded 3568 * by (and conflicts with) the modern activity-based preferences. 3569 */ 3570 @Deprecated removePackageFromPreferred(String packageName)3571 public abstract void removePackageFromPreferred(String packageName); 3572 3573 /** 3574 * Retrieve the list of all currently configured preferred packages. The 3575 * first package on the list is the most preferred, the last is the 3576 * least preferred. 3577 * 3578 * @param flags Additional option flags. Use any combination of 3579 * {@link #GET_ACTIVITIES}, 3580 * {@link #GET_GIDS}, 3581 * {@link #GET_CONFIGURATIONS}, 3582 * {@link #GET_INSTRUMENTATION}, 3583 * {@link #GET_PERMISSIONS}, 3584 * {@link #GET_PROVIDERS}, 3585 * {@link #GET_RECEIVERS}, 3586 * {@link #GET_SERVICES}, 3587 * {@link #GET_SIGNATURES}, to modify the data returned. 3588 * 3589 * @return Returns a list of PackageInfo objects describing each 3590 * preferred application, in order of preference. 3591 * 3592 * @see #GET_ACTIVITIES 3593 * @see #GET_GIDS 3594 * @see #GET_CONFIGURATIONS 3595 * @see #GET_INSTRUMENTATION 3596 * @see #GET_PERMISSIONS 3597 * @see #GET_PROVIDERS 3598 * @see #GET_RECEIVERS 3599 * @see #GET_SERVICES 3600 * @see #GET_SIGNATURES 3601 */ getPreferredPackages(int flags)3602 public abstract List<PackageInfo> getPreferredPackages(int flags); 3603 3604 /** 3605 * @deprecated This is a protected API that should not have been available 3606 * to third party applications. It is the platform's responsibility for 3607 * assigning preferred activities and this cannot be directly modified. 3608 * 3609 * Add a new preferred activity mapping to the system. This will be used 3610 * to automatically select the given activity component when 3611 * {@link Context#startActivity(Intent) Context.startActivity()} finds 3612 * multiple matching activities and also matches the given filter. 3613 * 3614 * @param filter The set of intents under which this activity will be 3615 * made preferred. 3616 * @param match The IntentFilter match category that this preference 3617 * applies to. 3618 * @param set The set of activities that the user was picking from when 3619 * this preference was made. 3620 * @param activity The component name of the activity that is to be 3621 * preferred. 3622 */ 3623 @Deprecated addPreferredActivity(IntentFilter filter, int match, ComponentName[] set, ComponentName activity)3624 public abstract void addPreferredActivity(IntentFilter filter, int match, 3625 ComponentName[] set, ComponentName activity); 3626 3627 /** 3628 * Same as {@link #addPreferredActivity(IntentFilter, int, 3629 ComponentName[], ComponentName)}, but with a specific userId to apply the preference 3630 to. 3631 * @hide 3632 */ addPreferredActivity(IntentFilter filter, int match, ComponentName[] set, ComponentName activity, int userId)3633 public void addPreferredActivity(IntentFilter filter, int match, 3634 ComponentName[] set, ComponentName activity, int userId) { 3635 throw new RuntimeException("Not implemented. Must override in a subclass."); 3636 } 3637 3638 /** 3639 * @deprecated This is a protected API that should not have been available 3640 * to third party applications. It is the platform's responsibility for 3641 * assigning preferred activities and this cannot be directly modified. 3642 * 3643 * Replaces an existing preferred activity mapping to the system, and if that were not present 3644 * adds a new preferred activity. This will be used 3645 * to automatically select the given activity component when 3646 * {@link Context#startActivity(Intent) Context.startActivity()} finds 3647 * multiple matching activities and also matches the given filter. 3648 * 3649 * @param filter The set of intents under which this activity will be 3650 * made preferred. 3651 * @param match The IntentFilter match category that this preference 3652 * applies to. 3653 * @param set The set of activities that the user was picking from when 3654 * this preference was made. 3655 * @param activity The component name of the activity that is to be 3656 * preferred. 3657 * @hide 3658 */ 3659 @Deprecated replacePreferredActivity(IntentFilter filter, int match, ComponentName[] set, ComponentName activity)3660 public abstract void replacePreferredActivity(IntentFilter filter, int match, 3661 ComponentName[] set, ComponentName activity); 3662 3663 /** 3664 * @hide 3665 */ 3666 @Deprecated replacePreferredActivityAsUser(IntentFilter filter, int match, ComponentName[] set, ComponentName activity, int userId)3667 public void replacePreferredActivityAsUser(IntentFilter filter, int match, 3668 ComponentName[] set, ComponentName activity, int userId) { 3669 throw new RuntimeException("Not implemented. Must override in a subclass."); 3670 } 3671 3672 /** 3673 * Remove all preferred activity mappings, previously added with 3674 * {@link #addPreferredActivity}, from the 3675 * system whose activities are implemented in the given package name. 3676 * An application can only clear its own package(s). 3677 * 3678 * @param packageName The name of the package whose preferred activity 3679 * mappings are to be removed. 3680 */ clearPackagePreferredActivities(String packageName)3681 public abstract void clearPackagePreferredActivities(String packageName); 3682 3683 /** 3684 * Retrieve all preferred activities, previously added with 3685 * {@link #addPreferredActivity}, that are 3686 * currently registered with the system. 3687 * 3688 * @param outFilters A list in which to place the filters of all of the 3689 * preferred activities, or null for none. 3690 * @param outActivities A list in which to place the component names of 3691 * all of the preferred activities, or null for none. 3692 * @param packageName An option package in which you would like to limit 3693 * the list. If null, all activities will be returned; if non-null, only 3694 * those activities in the given package are returned. 3695 * 3696 * @return Returns the total number of registered preferred activities 3697 * (the number of distinct IntentFilter records, not the number of unique 3698 * activity components) that were found. 3699 */ getPreferredActivities(List<IntentFilter> outFilters, List<ComponentName> outActivities, String packageName)3700 public abstract int getPreferredActivities(List<IntentFilter> outFilters, 3701 List<ComponentName> outActivities, String packageName); 3702 3703 /** 3704 * Ask for the set of available 'home' activities and the current explicit 3705 * default, if any. 3706 * @hide 3707 */ getHomeActivities(List<ResolveInfo> outActivities)3708 public abstract ComponentName getHomeActivities(List<ResolveInfo> outActivities); 3709 3710 /** 3711 * Set the enabled setting for a package component (activity, receiver, service, provider). 3712 * This setting will override any enabled state which may have been set by the component in its 3713 * manifest. 3714 * 3715 * @param componentName The component to enable 3716 * @param newState The new enabled state for the component. The legal values for this state 3717 * are: 3718 * {@link #COMPONENT_ENABLED_STATE_ENABLED}, 3719 * {@link #COMPONENT_ENABLED_STATE_DISABLED} 3720 * and 3721 * {@link #COMPONENT_ENABLED_STATE_DEFAULT} 3722 * The last one removes the setting, thereby restoring the component's state to 3723 * whatever was set in it's manifest (or enabled, by default). 3724 * @param flags Optional behavior flags: {@link #DONT_KILL_APP} or 0. 3725 */ setComponentEnabledSetting(ComponentName componentName, int newState, int flags)3726 public abstract void setComponentEnabledSetting(ComponentName componentName, 3727 int newState, int flags); 3728 3729 3730 /** 3731 * Return the enabled setting for a package component (activity, 3732 * receiver, service, provider). This returns the last value set by 3733 * {@link #setComponentEnabledSetting(ComponentName, int, int)}; in most 3734 * cases this value will be {@link #COMPONENT_ENABLED_STATE_DEFAULT} since 3735 * the value originally specified in the manifest has not been modified. 3736 * 3737 * @param componentName The component to retrieve. 3738 * @return Returns the current enabled state for the component. May 3739 * be one of {@link #COMPONENT_ENABLED_STATE_ENABLED}, 3740 * {@link #COMPONENT_ENABLED_STATE_DISABLED}, or 3741 * {@link #COMPONENT_ENABLED_STATE_DEFAULT}. The last one means the 3742 * component's enabled state is based on the original information in 3743 * the manifest as found in {@link ComponentInfo}. 3744 */ getComponentEnabledSetting(ComponentName componentName)3745 public abstract int getComponentEnabledSetting(ComponentName componentName); 3746 3747 /** 3748 * Set the enabled setting for an application 3749 * This setting will override any enabled state which may have been set by the application in 3750 * its manifest. It also overrides the enabled state set in the manifest for any of the 3751 * application's components. It does not override any enabled state set by 3752 * {@link #setComponentEnabledSetting} for any of the application's components. 3753 * 3754 * @param packageName The package name of the application to enable 3755 * @param newState The new enabled state for the component. The legal values for this state 3756 * are: 3757 * {@link #COMPONENT_ENABLED_STATE_ENABLED}, 3758 * {@link #COMPONENT_ENABLED_STATE_DISABLED} 3759 * and 3760 * {@link #COMPONENT_ENABLED_STATE_DEFAULT} 3761 * The last one removes the setting, thereby restoring the applications's state to 3762 * whatever was set in its manifest (or enabled, by default). 3763 * @param flags Optional behavior flags: {@link #DONT_KILL_APP} or 0. 3764 */ setApplicationEnabledSetting(String packageName, int newState, int flags)3765 public abstract void setApplicationEnabledSetting(String packageName, 3766 int newState, int flags); 3767 3768 /** 3769 * Return the enabled setting for an application. This returns 3770 * the last value set by 3771 * {@link #setApplicationEnabledSetting(String, int, int)}; in most 3772 * cases this value will be {@link #COMPONENT_ENABLED_STATE_DEFAULT} since 3773 * the value originally specified in the manifest has not been modified. 3774 * 3775 * @param packageName The package name of the application to retrieve. 3776 * @return Returns the current enabled state for the application. May 3777 * be one of {@link #COMPONENT_ENABLED_STATE_ENABLED}, 3778 * {@link #COMPONENT_ENABLED_STATE_DISABLED}, or 3779 * {@link #COMPONENT_ENABLED_STATE_DEFAULT}. The last one means the 3780 * application's enabled state is based on the original information in 3781 * the manifest as found in {@link ComponentInfo}. 3782 * @throws IllegalArgumentException if the named package does not exist. 3783 */ getApplicationEnabledSetting(String packageName)3784 public abstract int getApplicationEnabledSetting(String packageName); 3785 3786 /** 3787 * Puts the package in a hidden state, which is almost like an uninstalled state, 3788 * making the package unavailable, but it doesn't remove the data or the actual 3789 * package file. Application can be unhidden by either resetting the hidden state 3790 * or by installing it, such as with {@link #installExistingPackage(String)} 3791 * @hide 3792 */ setApplicationHiddenSettingAsUser(String packageName, boolean hidden, UserHandle userHandle)3793 public abstract boolean setApplicationHiddenSettingAsUser(String packageName, boolean hidden, 3794 UserHandle userHandle); 3795 3796 /** 3797 * Returns the hidden state of a package. 3798 * @see #setApplicationHiddenSettingAsUser(String, boolean, UserHandle) 3799 * @hide 3800 */ getApplicationHiddenSettingAsUser(String packageName, UserHandle userHandle)3801 public abstract boolean getApplicationHiddenSettingAsUser(String packageName, 3802 UserHandle userHandle); 3803 3804 /** 3805 * Return whether the device has been booted into safe mode. 3806 */ isSafeMode()3807 public abstract boolean isSafeMode(); 3808 3809 /** 3810 * Return the {@link KeySet} associated with the String alias for this 3811 * application. 3812 * 3813 * @param alias The alias for a given {@link KeySet} as defined in the 3814 * application's AndroidManifest.xml. 3815 * @hide 3816 */ getKeySetByAlias(String packageName, String alias)3817 public abstract KeySet getKeySetByAlias(String packageName, String alias); 3818 3819 /** Return the signing {@link KeySet} for this application. 3820 * @hide 3821 */ getSigningKeySet(String packageName)3822 public abstract KeySet getSigningKeySet(String packageName); 3823 3824 /** 3825 * Return whether the package denoted by packageName has been signed by all 3826 * of the keys specified by the {@link KeySet} ks. This will return true if 3827 * the package has been signed by additional keys (a superset) as well. 3828 * Compare to {@link #isSignedByExactly(String packageName, KeySet ks)}. 3829 * @hide 3830 */ isSignedBy(String packageName, KeySet ks)3831 public abstract boolean isSignedBy(String packageName, KeySet ks); 3832 3833 /** 3834 * Return whether the package denoted by packageName has been signed by all 3835 * of, and only, the keys specified by the {@link KeySet} ks. Compare to 3836 * {@link #isSignedBy(String packageName, KeySet ks)}. 3837 * @hide 3838 */ isSignedByExactly(String packageName, KeySet ks)3839 public abstract boolean isSignedByExactly(String packageName, KeySet ks); 3840 3841 /** 3842 * Attempts to move package resources from internal to external media or vice versa. 3843 * Since this may take a little while, the result will 3844 * be posted back to the given observer. This call may fail if the calling context 3845 * lacks the {@link android.Manifest.permission#MOVE_PACKAGE} permission, if the 3846 * named package cannot be found, or if the named package is a "system package". 3847 * 3848 * @param packageName The name of the package to delete 3849 * @param observer An observer callback to get notified when the package move is 3850 * complete. {@link android.content.pm.IPackageMoveObserver#packageMoved(boolean)} will be 3851 * called when that happens. observer may be null to indicate that no callback is desired. 3852 * @param flags To indicate install location {@link #MOVE_INTERNAL} or 3853 * {@link #MOVE_EXTERNAL_MEDIA} 3854 * 3855 * @hide 3856 */ movePackage( String packageName, IPackageMoveObserver observer, int flags)3857 public abstract void movePackage( 3858 String packageName, IPackageMoveObserver observer, int flags); 3859 3860 /** 3861 * Returns the device identity that verifiers can use to associate their scheme to a particular 3862 * device. This should not be used by anything other than a package verifier. 3863 * 3864 * @return identity that uniquely identifies current device 3865 * @hide 3866 */ getVerifierDeviceIdentity()3867 public abstract VerifierDeviceIdentity getVerifierDeviceIdentity(); 3868 3869 /** 3870 * Return interface that offers the ability to install, upgrade, and remove 3871 * applications on the device. 3872 */ getPackageInstaller()3873 public abstract @NonNull PackageInstaller getPackageInstaller(); 3874 3875 /** 3876 * Returns the data directory for a particular user and package, given the uid of the package. 3877 * @param uid uid of the package, including the userId and appId 3878 * @param packageName name of the package 3879 * @return the user-specific data directory for the package 3880 * @hide 3881 */ getDataDirForUser(int userId, String packageName)3882 public static String getDataDirForUser(int userId, String packageName) { 3883 // TODO: This should be shared with Installer's knowledge of user directory 3884 return Environment.getDataDirectory().toString() + "/user/" + userId 3885 + "/" + packageName; 3886 } 3887 3888 /** 3889 * Adds a {@link CrossProfileIntentFilter}. After calling this method all intents sent from the 3890 * user with id sourceUserId can also be be resolved by activities in the user with id 3891 * targetUserId if they match the specified intent filter. 3892 * @param filter The {@link IntentFilter} the intent has to match 3893 * @param sourceUserId The source user id. 3894 * @param targetUserId The target user id. 3895 * @param flags The only possible value is {@link SKIP_CURRENT_PROFILE} 3896 * @hide 3897 */ addCrossProfileIntentFilter(IntentFilter filter, int sourceUserId, int targetUserId, int flags)3898 public abstract void addCrossProfileIntentFilter(IntentFilter filter, int sourceUserId, 3899 int targetUserId, int flags); 3900 3901 /** 3902 * Clearing {@link CrossProfileIntentFilter}s which have the specified user as their 3903 * source, and have been set by the app calling this method. 3904 * @param sourceUserId The source user id. 3905 * @hide 3906 */ clearCrossProfileIntentFilters(int sourceUserId)3907 public abstract void clearCrossProfileIntentFilters(int sourceUserId); 3908 3909 /** 3910 * @hide 3911 */ loadItemIcon(PackageItemInfo itemInfo, ApplicationInfo appInfo)3912 public abstract Drawable loadItemIcon(PackageItemInfo itemInfo, ApplicationInfo appInfo); 3913 3914 /** {@hide} */ isPackageAvailable(String packageName)3915 public abstract boolean isPackageAvailable(String packageName); 3916 3917 /** {@hide} */ installStatusToString(int status, String msg)3918 public static String installStatusToString(int status, String msg) { 3919 final String str = installStatusToString(status); 3920 if (msg != null) { 3921 return str + ": " + msg; 3922 } else { 3923 return str; 3924 } 3925 } 3926 3927 /** {@hide} */ installStatusToString(int status)3928 public static String installStatusToString(int status) { 3929 switch (status) { 3930 case INSTALL_SUCCEEDED: return "INSTALL_SUCCEEDED"; 3931 case INSTALL_FAILED_ALREADY_EXISTS: return "INSTALL_FAILED_ALREADY_EXISTS"; 3932 case INSTALL_FAILED_INVALID_APK: return "INSTALL_FAILED_INVALID_APK"; 3933 case INSTALL_FAILED_INVALID_URI: return "INSTALL_FAILED_INVALID_URI"; 3934 case INSTALL_FAILED_INSUFFICIENT_STORAGE: return "INSTALL_FAILED_INSUFFICIENT_STORAGE"; 3935 case INSTALL_FAILED_DUPLICATE_PACKAGE: return "INSTALL_FAILED_DUPLICATE_PACKAGE"; 3936 case INSTALL_FAILED_NO_SHARED_USER: return "INSTALL_FAILED_NO_SHARED_USER"; 3937 case INSTALL_FAILED_UPDATE_INCOMPATIBLE: return "INSTALL_FAILED_UPDATE_INCOMPATIBLE"; 3938 case INSTALL_FAILED_SHARED_USER_INCOMPATIBLE: return "INSTALL_FAILED_SHARED_USER_INCOMPATIBLE"; 3939 case INSTALL_FAILED_MISSING_SHARED_LIBRARY: return "INSTALL_FAILED_MISSING_SHARED_LIBRARY"; 3940 case INSTALL_FAILED_REPLACE_COULDNT_DELETE: return "INSTALL_FAILED_REPLACE_COULDNT_DELETE"; 3941 case INSTALL_FAILED_DEXOPT: return "INSTALL_FAILED_DEXOPT"; 3942 case INSTALL_FAILED_OLDER_SDK: return "INSTALL_FAILED_OLDER_SDK"; 3943 case INSTALL_FAILED_CONFLICTING_PROVIDER: return "INSTALL_FAILED_CONFLICTING_PROVIDER"; 3944 case INSTALL_FAILED_NEWER_SDK: return "INSTALL_FAILED_NEWER_SDK"; 3945 case INSTALL_FAILED_TEST_ONLY: return "INSTALL_FAILED_TEST_ONLY"; 3946 case INSTALL_FAILED_CPU_ABI_INCOMPATIBLE: return "INSTALL_FAILED_CPU_ABI_INCOMPATIBLE"; 3947 case INSTALL_FAILED_MISSING_FEATURE: return "INSTALL_FAILED_MISSING_FEATURE"; 3948 case INSTALL_FAILED_CONTAINER_ERROR: return "INSTALL_FAILED_CONTAINER_ERROR"; 3949 case INSTALL_FAILED_INVALID_INSTALL_LOCATION: return "INSTALL_FAILED_INVALID_INSTALL_LOCATION"; 3950 case INSTALL_FAILED_MEDIA_UNAVAILABLE: return "INSTALL_FAILED_MEDIA_UNAVAILABLE"; 3951 case INSTALL_FAILED_VERIFICATION_TIMEOUT: return "INSTALL_FAILED_VERIFICATION_TIMEOUT"; 3952 case INSTALL_FAILED_VERIFICATION_FAILURE: return "INSTALL_FAILED_VERIFICATION_FAILURE"; 3953 case INSTALL_FAILED_PACKAGE_CHANGED: return "INSTALL_FAILED_PACKAGE_CHANGED"; 3954 case INSTALL_FAILED_UID_CHANGED: return "INSTALL_FAILED_UID_CHANGED"; 3955 case INSTALL_FAILED_VERSION_DOWNGRADE: return "INSTALL_FAILED_VERSION_DOWNGRADE"; 3956 case INSTALL_PARSE_FAILED_NOT_APK: return "INSTALL_PARSE_FAILED_NOT_APK"; 3957 case INSTALL_PARSE_FAILED_BAD_MANIFEST: return "INSTALL_PARSE_FAILED_BAD_MANIFEST"; 3958 case INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION: return "INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION"; 3959 case INSTALL_PARSE_FAILED_NO_CERTIFICATES: return "INSTALL_PARSE_FAILED_NO_CERTIFICATES"; 3960 case INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES: return "INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES"; 3961 case INSTALL_PARSE_FAILED_CERTIFICATE_ENCODING: return "INSTALL_PARSE_FAILED_CERTIFICATE_ENCODING"; 3962 case INSTALL_PARSE_FAILED_BAD_PACKAGE_NAME: return "INSTALL_PARSE_FAILED_BAD_PACKAGE_NAME"; 3963 case INSTALL_PARSE_FAILED_BAD_SHARED_USER_ID: return "INSTALL_PARSE_FAILED_BAD_SHARED_USER_ID"; 3964 case INSTALL_PARSE_FAILED_MANIFEST_MALFORMED: return "INSTALL_PARSE_FAILED_MANIFEST_MALFORMED"; 3965 case INSTALL_PARSE_FAILED_MANIFEST_EMPTY: return "INSTALL_PARSE_FAILED_MANIFEST_EMPTY"; 3966 case INSTALL_FAILED_INTERNAL_ERROR: return "INSTALL_FAILED_INTERNAL_ERROR"; 3967 case INSTALL_FAILED_USER_RESTRICTED: return "INSTALL_FAILED_USER_RESTRICTED"; 3968 case INSTALL_FAILED_DUPLICATE_PERMISSION: return "INSTALL_FAILED_DUPLICATE_PERMISSION"; 3969 case INSTALL_FAILED_NO_MATCHING_ABIS: return "INSTALL_FAILED_NO_MATCHING_ABIS"; 3970 case INSTALL_FAILED_ABORTED: return "INSTALL_FAILED_ABORTED"; 3971 default: return Integer.toString(status); 3972 } 3973 } 3974 3975 /** {@hide} */ installStatusToPublicStatus(int status)3976 public static int installStatusToPublicStatus(int status) { 3977 switch (status) { 3978 case INSTALL_SUCCEEDED: return PackageInstaller.STATUS_SUCCESS; 3979 case INSTALL_FAILED_ALREADY_EXISTS: return PackageInstaller.STATUS_FAILURE_CONFLICT; 3980 case INSTALL_FAILED_INVALID_APK: return PackageInstaller.STATUS_FAILURE_INVALID; 3981 case INSTALL_FAILED_INVALID_URI: return PackageInstaller.STATUS_FAILURE_INVALID; 3982 case INSTALL_FAILED_INSUFFICIENT_STORAGE: return PackageInstaller.STATUS_FAILURE_STORAGE; 3983 case INSTALL_FAILED_DUPLICATE_PACKAGE: return PackageInstaller.STATUS_FAILURE_CONFLICT; 3984 case INSTALL_FAILED_NO_SHARED_USER: return PackageInstaller.STATUS_FAILURE_CONFLICT; 3985 case INSTALL_FAILED_UPDATE_INCOMPATIBLE: return PackageInstaller.STATUS_FAILURE_CONFLICT; 3986 case INSTALL_FAILED_SHARED_USER_INCOMPATIBLE: return PackageInstaller.STATUS_FAILURE_CONFLICT; 3987 case INSTALL_FAILED_MISSING_SHARED_LIBRARY: return PackageInstaller.STATUS_FAILURE_INCOMPATIBLE; 3988 case INSTALL_FAILED_REPLACE_COULDNT_DELETE: return PackageInstaller.STATUS_FAILURE_CONFLICT; 3989 case INSTALL_FAILED_DEXOPT: return PackageInstaller.STATUS_FAILURE_INVALID; 3990 case INSTALL_FAILED_OLDER_SDK: return PackageInstaller.STATUS_FAILURE_INCOMPATIBLE; 3991 case INSTALL_FAILED_CONFLICTING_PROVIDER: return PackageInstaller.STATUS_FAILURE_CONFLICT; 3992 case INSTALL_FAILED_NEWER_SDK: return PackageInstaller.STATUS_FAILURE_INCOMPATIBLE; 3993 case INSTALL_FAILED_TEST_ONLY: return PackageInstaller.STATUS_FAILURE_INVALID; 3994 case INSTALL_FAILED_CPU_ABI_INCOMPATIBLE: return PackageInstaller.STATUS_FAILURE_INCOMPATIBLE; 3995 case INSTALL_FAILED_MISSING_FEATURE: return PackageInstaller.STATUS_FAILURE_INCOMPATIBLE; 3996 case INSTALL_FAILED_CONTAINER_ERROR: return PackageInstaller.STATUS_FAILURE_STORAGE; 3997 case INSTALL_FAILED_INVALID_INSTALL_LOCATION: return PackageInstaller.STATUS_FAILURE_STORAGE; 3998 case INSTALL_FAILED_MEDIA_UNAVAILABLE: return PackageInstaller.STATUS_FAILURE_STORAGE; 3999 case INSTALL_FAILED_VERIFICATION_TIMEOUT: return PackageInstaller.STATUS_FAILURE_ABORTED; 4000 case INSTALL_FAILED_VERIFICATION_FAILURE: return PackageInstaller.STATUS_FAILURE_ABORTED; 4001 case INSTALL_FAILED_PACKAGE_CHANGED: return PackageInstaller.STATUS_FAILURE_INVALID; 4002 case INSTALL_FAILED_UID_CHANGED: return PackageInstaller.STATUS_FAILURE_INVALID; 4003 case INSTALL_FAILED_VERSION_DOWNGRADE: return PackageInstaller.STATUS_FAILURE_INVALID; 4004 case INSTALL_PARSE_FAILED_NOT_APK: return PackageInstaller.STATUS_FAILURE_INVALID; 4005 case INSTALL_PARSE_FAILED_BAD_MANIFEST: return PackageInstaller.STATUS_FAILURE_INVALID; 4006 case INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION: return PackageInstaller.STATUS_FAILURE_INVALID; 4007 case INSTALL_PARSE_FAILED_NO_CERTIFICATES: return PackageInstaller.STATUS_FAILURE_INVALID; 4008 case INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES: return PackageInstaller.STATUS_FAILURE_INVALID; 4009 case INSTALL_PARSE_FAILED_CERTIFICATE_ENCODING: return PackageInstaller.STATUS_FAILURE_INVALID; 4010 case INSTALL_PARSE_FAILED_BAD_PACKAGE_NAME: return PackageInstaller.STATUS_FAILURE_INVALID; 4011 case INSTALL_PARSE_FAILED_BAD_SHARED_USER_ID: return PackageInstaller.STATUS_FAILURE_INVALID; 4012 case INSTALL_PARSE_FAILED_MANIFEST_MALFORMED: return PackageInstaller.STATUS_FAILURE_INVALID; 4013 case INSTALL_PARSE_FAILED_MANIFEST_EMPTY: return PackageInstaller.STATUS_FAILURE_INVALID; 4014 case INSTALL_FAILED_INTERNAL_ERROR: return PackageInstaller.STATUS_FAILURE; 4015 case INSTALL_FAILED_USER_RESTRICTED: return PackageInstaller.STATUS_FAILURE_INCOMPATIBLE; 4016 case INSTALL_FAILED_DUPLICATE_PERMISSION: return PackageInstaller.STATUS_FAILURE_CONFLICT; 4017 case INSTALL_FAILED_NO_MATCHING_ABIS: return PackageInstaller.STATUS_FAILURE_INCOMPATIBLE; 4018 case INSTALL_FAILED_ABORTED: return PackageInstaller.STATUS_FAILURE_ABORTED; 4019 default: return PackageInstaller.STATUS_FAILURE; 4020 } 4021 } 4022 4023 /** {@hide} */ deleteStatusToString(int status, String msg)4024 public static String deleteStatusToString(int status, String msg) { 4025 final String str = deleteStatusToString(status); 4026 if (msg != null) { 4027 return str + ": " + msg; 4028 } else { 4029 return str; 4030 } 4031 } 4032 4033 /** {@hide} */ deleteStatusToString(int status)4034 public static String deleteStatusToString(int status) { 4035 switch (status) { 4036 case DELETE_SUCCEEDED: return "DELETE_SUCCEEDED"; 4037 case DELETE_FAILED_INTERNAL_ERROR: return "DELETE_FAILED_INTERNAL_ERROR"; 4038 case DELETE_FAILED_DEVICE_POLICY_MANAGER: return "DELETE_FAILED_DEVICE_POLICY_MANAGER"; 4039 case DELETE_FAILED_USER_RESTRICTED: return "DELETE_FAILED_USER_RESTRICTED"; 4040 case DELETE_FAILED_OWNER_BLOCKED: return "DELETE_FAILED_OWNER_BLOCKED"; 4041 case DELETE_FAILED_ABORTED: return "DELETE_FAILED_ABORTED"; 4042 default: return Integer.toString(status); 4043 } 4044 } 4045 4046 /** {@hide} */ deleteStatusToPublicStatus(int status)4047 public static int deleteStatusToPublicStatus(int status) { 4048 switch (status) { 4049 case DELETE_SUCCEEDED: return PackageInstaller.STATUS_SUCCESS; 4050 case DELETE_FAILED_INTERNAL_ERROR: return PackageInstaller.STATUS_FAILURE; 4051 case DELETE_FAILED_DEVICE_POLICY_MANAGER: return PackageInstaller.STATUS_FAILURE_BLOCKED; 4052 case DELETE_FAILED_USER_RESTRICTED: return PackageInstaller.STATUS_FAILURE_BLOCKED; 4053 case DELETE_FAILED_OWNER_BLOCKED: return PackageInstaller.STATUS_FAILURE_BLOCKED; 4054 case DELETE_FAILED_ABORTED: return PackageInstaller.STATUS_FAILURE_ABORTED; 4055 default: return PackageInstaller.STATUS_FAILURE; 4056 } 4057 } 4058 4059 /** {@hide} */ 4060 public static class LegacyPackageInstallObserver extends PackageInstallObserver { 4061 private final IPackageInstallObserver mLegacy; 4062 LegacyPackageInstallObserver(IPackageInstallObserver legacy)4063 public LegacyPackageInstallObserver(IPackageInstallObserver legacy) { 4064 mLegacy = legacy; 4065 } 4066 4067 @Override onPackageInstalled(String basePackageName, int returnCode, String msg, Bundle extras)4068 public void onPackageInstalled(String basePackageName, int returnCode, String msg, 4069 Bundle extras) { 4070 if (mLegacy == null) return; 4071 try { 4072 mLegacy.packageInstalled(basePackageName, returnCode); 4073 } catch (RemoteException ignored) { 4074 } 4075 } 4076 } 4077 4078 /** {@hide} */ 4079 public static class LegacyPackageDeleteObserver extends PackageDeleteObserver { 4080 private final IPackageDeleteObserver mLegacy; 4081 LegacyPackageDeleteObserver(IPackageDeleteObserver legacy)4082 public LegacyPackageDeleteObserver(IPackageDeleteObserver legacy) { 4083 mLegacy = legacy; 4084 } 4085 4086 @Override onPackageDeleted(String basePackageName, int returnCode, String msg)4087 public void onPackageDeleted(String basePackageName, int returnCode, String msg) { 4088 if (mLegacy == null) return; 4089 try { 4090 mLegacy.packageDeleted(basePackageName, returnCode); 4091 } catch (RemoteException ignored) { 4092 } 4093 } 4094 } 4095 } 4096