IPackageManager.aidl revision 5c1e00b14d2ef10ec76abf3e951fa8003a67f558
19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/* 29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** 39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** Copyright 2007, The Android Open Source Project 49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** 59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** Licensed under the Apache License, Version 2.0 (the "License"); 69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** you may not use this file except in compliance with the License. 79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** You may obtain a copy of the License at 89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** 99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** http://www.apache.org/licenses/LICENSE-2.0 109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** 119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** Unless required by applicable law or agreed to in writing, software 129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** distributed under the License is distributed on an "AS IS" BASIS, 139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** See the License for the specific language governing permissions and 159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** limitations under the License. 169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project*/ 179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.content.pm; 199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.ComponentName; 219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.Intent; 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.IntentFilter; 239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ActivityInfo; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ApplicationInfo; 259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.IPackageInstallObserver; 269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.IPackageDeleteObserver; 279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.IPackageDataObserver; 289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.IPackageStatsObserver; 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.InstrumentationInfo; 309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.PackageInfo; 319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ProviderInfo; 329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.PermissionGroupInfo; 339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.PermissionInfo; 349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ResolveInfo; 359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ServiceInfo; 369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.Uri; 379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.app.PendingIntent; 381ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapuimport android.content.IntentSender; 399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See {@link PackageManager} for documentation on most of the APIs 429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * here. 439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@hide} 459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectinterface IPackageManager { 479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PackageInfo getPackageInfo(String packageName, int flags); 489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int getPackageUid(String packageName); 499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int[] getPackageGids(String packageName); 509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PermissionInfo getPermissionInfo(String name, int flags); 529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<PermissionInfo> queryPermissionsByGroup(String group, int flags); 549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PermissionGroupInfo getPermissionGroupInfo(String name, int flags); 569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<PermissionGroupInfo> getAllPermissionGroups(int flags); 589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project ApplicationInfo getApplicationInfo(String packageName, int flags); 609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project ActivityInfo getActivityInfo(in ComponentName className, int flags); 629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project ActivityInfo getReceiverInfo(in ComponentName className, int flags); 649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project ServiceInfo getServiceInfo(in ComponentName className, int flags); 669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int checkPermission(String permName, String pkgName); 689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int checkUidPermission(String permName, int uid); 709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean addPermission(in PermissionInfo info); 729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void removePermission(String name); 749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int checkSignatures(String pkg1, String pkg2); 769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String[] getPackagesForUid(int uid); 789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String getNameForUid(int uid); 809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int getUidForSharedUser(String sharedUserName); 829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project ResolveInfo resolveIntent(in Intent intent, String resolvedType, int flags); 849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<ResolveInfo> queryIntentActivities(in Intent intent, 869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String resolvedType, int flags); 879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<ResolveInfo> queryIntentActivityOptions( 899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project in ComponentName caller, in Intent[] specifics, 909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project in String[] specificTypes, in Intent intent, 919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String resolvedType, int flags); 929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<ResolveInfo> queryIntentReceivers(in Intent intent, 949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String resolvedType, int flags); 959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project ResolveInfo resolveService(in Intent intent, 979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String resolvedType, int flags); 989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<ResolveInfo> queryIntentServices(in Intent intent, 1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String resolvedType, int flags); 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<PackageInfo> getInstalledPackages(int flags); 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<ApplicationInfo> getInstalledApplications(int flags); 1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieve all applications that are marked as persistent. 1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return A List<applicationInfo> containing one entry for each persistent 1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application. 1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<ApplicationInfo> getPersistentApplications(int flags); 1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project ProviderInfo resolveContentProvider(String name, int flags); 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieve sync information for all content providers. 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param outNames Filled in with a list of the root names of the content 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * providers that can sync. 1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param outInfo Filled in with a list of the ProviderInfo for each 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * name in 'outNames'. 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void querySyncProviders(inout List<String> outNames, 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project inout List<ProviderInfo> outInfo); 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<ProviderInfo> queryContentProviders( 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String processName, int uid, int flags); 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project InstrumentationInfo getInstrumentationInfo( 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project in ComponentName className, int flags); 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<InstrumentationInfo> queryInstrumentation( 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String targetPackage, int flags); 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Install a package. 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param packageURI The location of the package file to install. 1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param observer a callback to use to notify when the package installation in finished. 1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param flags - possible values: {@link #FORWARD_LOCK_PACKAGE}, 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #REPLACE_EXISITING_PACKAGE} 143c64322c35212e919906ffd66118c7d5d3ad36636Jacek Surazski * @param installerPackageName Optional package name of the application that is performing the 144c64322c35212e919906ffd66118c7d5d3ad36636Jacek Surazski * installation. This identifies which market the package came from. 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 146c64322c35212e919906ffd66118c7d5d3ad36636Jacek Surazski void installPackage(in Uri packageURI, IPackageInstallObserver observer, int flags, 147c64322c35212e919906ffd66118c7d5d3ad36636Jacek Surazski in String installerPackageName); 1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Delete a package. 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param packageName The fully qualified name of the package to delete. 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param observer a callback to use to notify when the package deletion in finished. 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param flags - possible values: {@link #DONT_DELETE_DATA} 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void deletePackage(in String packageName, IPackageDeleteObserver observer, int flags); 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 158c64322c35212e919906ffd66118c7d5d3ad36636Jacek Surazski String getInstallerPackageName(in String packageName); 159c64322c35212e919906ffd66118c7d5d3ad36636Jacek Surazski 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void addPackageToPreferred(String packageName); 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void removePackageFromPreferred(String packageName); 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project List<PackageInfo> getPreferredPackages(int flags); 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void addPreferredActivity(in IntentFilter filter, int match, 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project in ComponentName[] set, in ComponentName activity); 1688dbe612dc60526d635e57257b58627b33a099678Satish Sampath 1698dbe612dc60526d635e57257b58627b33a099678Satish Sampath void replacePreferredActivity(in IntentFilter filter, int match, 1708dbe612dc60526d635e57257b58627b33a099678Satish Sampath in ComponentName[] set, in ComponentName activity); 1718dbe612dc60526d635e57257b58627b33a099678Satish Sampath 1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void clearPackagePreferredActivities(String packageName); 1738dbe612dc60526d635e57257b58627b33a099678Satish Sampath 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int getPreferredActivities(out List<IntentFilter> outFilters, 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out List<ComponentName> outActivities, String packageName); 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * As per {@link android.content.pm.PackageManager#setComponentEnabledSetting}. 1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void setComponentEnabledSetting(in ComponentName componentName, 1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project in int newState, in int flags); 1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * As per {@link android.content.pm.PackageManager#getComponentEnabledSetting}. 1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int getComponentEnabledSetting(in ComponentName componentName); 1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * As per {@link android.content.pm.PackageManager#setApplicationEnabledSetting}. 1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void setApplicationEnabledSetting(in String packageName, in int newState, int flags); 1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * As per {@link android.content.pm.PackageManager#getApplicationEnabledSetting}. 1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int getApplicationEnabledSetting(in String packageName); 1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Free storage by deleting LRU sorted list of cache files across 2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * all applications. If the currently available free storage 2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * on the device is greater than or equal to the requested 2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * free storage, no cache files are cleared. If the currently 2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * available storage on the device is less than the requested 2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * free storage, some or all of the cache files across 2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * all applications are deleted (based on last accessed time) 2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to increase the free storage space on the device to 2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the requested value. There is no guarantee that clearing all 2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the cache files from all applications will clear up 2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * enough storage to achieve the desired value. 2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param freeStorageSize The number of bytes of storage to be 2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * freed by the system. Say if freeStorageSize is XX, 2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and the current free storage is YY, 2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * if XX is less than YY, just return. if not free XX-YY number 2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of bytes if possible. 2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param observer call back used to notify when 2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the operation is completed 2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void freeStorageAndNotify(in long freeStorageSize, 2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project IPackageDataObserver observer); 2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Free storage by deleting LRU sorted list of cache files across 2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * all applications. If the currently available free storage 2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * on the device is greater than or equal to the requested 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * free storage, no cache files are cleared. If the currently 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * available storage on the device is less than the requested 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * free storage, some or all of the cache files across 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * all applications are deleted (based on last accessed time) 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to increase the free storage space on the device to 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the requested value. There is no guarantee that clearing all 2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the cache files from all applications will clear up 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * enough storage to achieve the desired value. 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param freeStorageSize The number of bytes of storage to be 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * freed by the system. Say if freeStorageSize is XX, 2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and the current free storage is YY, 2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * if XX is less than YY, just return. if not free XX-YY number 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of bytes if possible. 2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param opFinishedIntent PendingIntent call back used to 2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * notify when the operation is completed.May be null 2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to indicate that no call back is desired. 2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void freeStorage(in long freeStorageSize, 2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project in PendingIntent opFinishedIntent); 2441ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu 2451ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu /** 2461ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * Free storage by deleting LRU sorted list of cache files across 2471ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * all applications. If the currently available free storage 2481ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * on the device is greater than or equal to the requested 2491ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * free storage, no cache files are cleared. If the currently 2501ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * available storage on the device is less than the requested 2511ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * free storage, some or all of the cache files across 2521ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * all applications are deleted (based on last accessed time) 2531ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * to increase the free storage space on the device to 2541ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * the requested value. There is no guarantee that clearing all 2551ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * the cache files from all applications will clear up 2561ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * enough storage to achieve the desired value. 2571ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * @param freeStorageSize The number of bytes of storage to be 2581ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * freed by the system. Say if freeStorageSize is XX, 2591ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * and the current free storage is YY, 2601ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * if XX is less than YY, just return. if not free XX-YY number 2611ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * of bytes if possible. 2621ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * @param pi IntentSender call back used to 2631ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * notify when the operation is completed.May be null 2641ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu * to indicate that no call back is desired. 2651ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu */ 2661ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu void freeStorageWithIntent(in long freeStorageSize, 2671ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu in IntentSender pi); 2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Delete all the cache files in an applications cache directory 2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param packageName The package name of the application whose cache 2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * files need to be deleted 2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param observer a callback used to notify when the deletion is finished. 2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void deleteApplicationCacheFiles(in String packageName, IPackageDataObserver observer); 2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Clear the user data directory of an application. 2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param packageName The package name of the application whose cache 2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * files need to be deleted 2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param observer a callback used to notify when the operation is completed. 2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void clearApplicationUserData(in String packageName, IPackageDataObserver observer); 2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Get package statistics including the code, data and cache size for 2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an already installed package 2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param packageName The package name of the application 2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param observer a callback to use to notify when the asynchronous 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * retrieval of information is complete. 2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void getPackageSizeInfo(in String packageName, IPackageStatsObserver observer); 2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Get a list of shared libraries that are available on the 2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * system. 2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String[] getSystemSharedLibraryNames(); 2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void enterSafeMode(); 3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isSafeMode(); 3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void systemReady(); 3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean hasSystemUidErrors(); 3045c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn 3055c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn /** 3065c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn * Ask the package manager to perform dex-opt (if needed) on the given 3075c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn * package, if it already hasn't done mode. Only does this if running 3085c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn * in the special development "no pre-dexopt" mode. 3095c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn */ 3105c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn boolean performDexOpt(String packageName); 3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 312