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&lt;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