IPackageManager.aidl revision 8a2ed1d7c0c4f6476e39cc37d9ebd29c7562ce01
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;
25ceb1b0bfaea56251796b08c07b963de7403d84ebAnonymous Cowardimport android.content.pm.ContainerEncryptionParams;
2649237345d83e62fdb9eb8d50b13ad086636a04faDianne Hackbornimport android.content.pm.FeatureInfo;
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.IPackageInstallObserver;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.IPackageDeleteObserver;
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.IPackageDataObserver;
308946dd3355fc1dcbad872c0546e356474d4cc5deSuchi Amalapurapuimport android.content.pm.IPackageMoveObserver;
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.IPackageStatsObserver;
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.InstrumentationInfo;
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.PackageInfo;
345ab2157bf1f105b02d3e2913cd3a33f9765b74caKenny Rootimport android.content.pm.ManifestDigest;
357767eac3232ba2fb9828766813cdb481d6a97584Dianne Hackbornimport android.content.pm.PackageCleanItem;
360e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Rootimport android.content.pm.ParceledListSlice;
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ProviderInfo;
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.PermissionGroupInfo;
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.PermissionInfo;
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ResolveInfo;
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ServiceInfo;
420b285499db739ba50f2f839d633e763c70e67f96Amith Yamasaniimport android.content.pm.UserInfo;
43706e8ba26bf0de19ad5f736516dae40c4c88c2d7rich canningsimport android.content.pm.VerificationParams;
440aaa0d931716e9f57a1d84d795fab2df75092756Kenny Rootimport android.content.pm.VerifierDeviceIdentity;
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.Uri;
46b8151ecd6ef4faa5c16d0a4c3abb45ec84d1f97aAmith Yamasaniimport android.os.ParcelFileDescriptor;
471ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapuimport android.content.IntentSender;
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  See {@link PackageManager} for documentation on most of the APIs
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  here.
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  {@hide}
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectinterface IPackageManager {
56483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    PackageInfo getPackageInfo(String packageName, int flags, int userId);
57483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    int getPackageUid(String packageName, int userId);
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int[] getPackageGids(String packageName);
59470969346d7958f859d97d1a136b4ecc11e2a464Dianne Hackborn
60470969346d7958f859d97d1a136b4ecc11e2a464Dianne Hackborn    String[] currentToCanonicalPackageNames(in String[] names);
61470969346d7958f859d97d1a136b4ecc11e2a464Dianne Hackborn    String[] canonicalToCurrentPackageNames(in String[] names);
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    PermissionInfo getPermissionInfo(String name, int flags);
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<PermissionInfo> queryPermissionsByGroup(String group, int flags);
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    PermissionGroupInfo getPermissionGroupInfo(String name, int flags);
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<PermissionGroupInfo> getAllPermissionGroups(int flags);
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
71483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    ApplicationInfo getApplicationInfo(String packageName, int flags ,int userId);
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
73483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    ActivityInfo getActivityInfo(in ComponentName className, int flags, int userId);
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
75483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    ActivityInfo getReceiverInfo(in ComponentName className, int flags, int userId);
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
77483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    ServiceInfo getServiceInfo(in ComponentName className, int flags, int userId);
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
79483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    ProviderInfo getProviderInfo(in ComponentName className, int flags, int userId);
80361199b5e742c6635d4d7a03de6cf37b31cf442cDianne Hackborn
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int checkPermission(String permName, String pkgName);
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int checkUidPermission(String permName, int uid);
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean addPermission(in PermissionInfo info);
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void removePermission(String name);
88e639da7baa23121e35aa06d6e182558e0e755696Dianne Hackborn
89e639da7baa23121e35aa06d6e182558e0e755696Dianne Hackborn    void grantPermission(String packageName, String permissionName);
90e639da7baa23121e35aa06d6e182558e0e755696Dianne Hackborn
91e639da7baa23121e35aa06d6e182558e0e755696Dianne Hackborn    void revokePermission(String packageName, String permissionName);
92e639da7baa23121e35aa06d6e182558e0e755696Dianne Hackborn
93854060af30f928c0a65591e9c8314ae17056e6b8Dianne Hackborn    boolean isProtectedBroadcast(String actionName);
94854060af30f928c0a65591e9c8314ae17056e6b8Dianne Hackborn
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int checkSignatures(String pkg1, String pkg2);
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
97766cbfe44be3c5013a6a22bd6cd8ad1055a37256Dianne Hackborn    int checkUidSignatures(int uid1, int uid2);
98766cbfe44be3c5013a6a22bd6cd8ad1055a37256Dianne Hackborn
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    String[] getPackagesForUid(int uid);
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    String getNameForUid(int uid);
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int getUidForSharedUser(String sharedUserName);
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
105483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    ResolveInfo resolveIntent(in Intent intent, String resolvedType, int flags, int userId);
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<ResolveInfo> queryIntentActivities(in Intent intent,
108483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani            String resolvedType, int flags, int userId);
1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<ResolveInfo> queryIntentActivityOptions(
1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            in ComponentName caller, in Intent[] specifics,
1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            in String[] specificTypes, in Intent intent,
113483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani            String resolvedType, int flags, int userId);
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<ResolveInfo> queryIntentReceivers(in Intent intent,
116483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani            String resolvedType, int flags, int userId);
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    ResolveInfo resolveService(in Intent intent,
119483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani            String resolvedType, int flags, int userId);
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<ResolveInfo> queryIntentServices(in Intent intent,
122483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani            String resolvedType, int flags, int userId);
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1240e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root    /**
1250e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     * This implements getInstalledPackages via a "last returned row"
1260e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     * mechanism that is not exposed in the API. This is to get around the IPC
1270e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     * limit that kicks in when flags are included that bloat up the data
1280e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     * returned.
1290e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     */
130d8e1dbb6bc1fbaf4f2e38c3ba92ced94270deaacDianne Hackborn    ParceledListSlice getInstalledPackages(int flags, in int userId);
1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1320e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root    /**
133e799175b6ba3aadd972f4b861758d675d1f93987Dianne Hackborn     * This implements getPackagesHoldingPermissions via a "last returned row"
134e799175b6ba3aadd972f4b861758d675d1f93987Dianne Hackborn     * mechanism that is not exposed in the API. This is to get around the IPC
135e799175b6ba3aadd972f4b861758d675d1f93987Dianne Hackborn     * limit that kicks in when flags are included that bloat up the data
136e799175b6ba3aadd972f4b861758d675d1f93987Dianne Hackborn     * returned.
137e799175b6ba3aadd972f4b861758d675d1f93987Dianne Hackborn     */
138e799175b6ba3aadd972f4b861758d675d1f93987Dianne Hackborn    ParceledListSlice getPackagesHoldingPermissions(in String[] permissions,
139d8e1dbb6bc1fbaf4f2e38c3ba92ced94270deaacDianne Hackborn            int flags, int userId);
140e799175b6ba3aadd972f4b861758d675d1f93987Dianne Hackborn
141e799175b6ba3aadd972f4b861758d675d1f93987Dianne Hackborn    /**
1420e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     * This implements getInstalledApplications via a "last returned row"
1430e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     * mechanism that is not exposed in the API. This is to get around the IPC
1440e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     * limit that kicks in when flags are included that bloat up the data
1450e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     * returned.
1460e2c0f37d98bb5539b0fe41865aaf1add0ff1bb3Kenny Root     */
147d8e1dbb6bc1fbaf4f2e38c3ba92ced94270deaacDianne Hackborn    ParceledListSlice getInstalledApplications(int flags, int userId);
1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Retrieve all applications that are marked as persistent.
1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return A List&lt;applicationInfo> containing one entry for each persistent
1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         application.
1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<ApplicationInfo> getPersistentApplications(int flags);
1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
157483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    ProviderInfo resolveContentProvider(String name, int flags, int userId);
1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Retrieve sync information for all content providers.
1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param outNames Filled in with a list of the root names of the content
1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *                 providers that can sync.
1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param outInfo Filled in with a list of the ProviderInfo for each
1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *                name in 'outNames'.
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void querySyncProviders(inout List<String> outNames,
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            inout List<ProviderInfo> outInfo);
1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<ProviderInfo> queryContentProviders(
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            String processName, int uid, int flags);
1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    InstrumentationInfo getInstrumentationInfo(
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            in ComponentName className, int flags);
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<InstrumentationInfo> queryInstrumentation(
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            String targetPackage, int flags);
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Install a package.
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param packageURI The location of the package file to install.
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param observer a callback to use to notify when the package installation in finished.
1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param flags - possible values: {@link #FORWARD_LOCK_PACKAGE},
1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #REPLACE_EXISITING_PACKAGE}
18665e13171e12cb9e9fc2f608d0c8a92cd3c098648Jacek Surazski     * @param installerPackageName Optional package name of the application that is performing the
18765e13171e12cb9e9fc2f608d0c8a92cd3c098648Jacek Surazski     * installation. This identifies which market the package came from.
1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
18965e13171e12cb9e9fc2f608d0c8a92cd3c098648Jacek Surazski    void installPackage(in Uri packageURI, IPackageInstallObserver observer, int flags,
19065e13171e12cb9e9fc2f608d0c8a92cd3c098648Jacek Surazski            in String installerPackageName);
1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1921bb6906c7a903ee6427c8ff37bdc5896c386ff73Christopher Tate    void finishPackageInstall(int token);
1931bb6906c7a903ee6427c8ff37bdc5896c386ff73Christopher Tate
194880119bf43d738ca632b5d3861eb52d655c1c0fcDianne Hackborn    void setInstallerPackageName(in String targetPackage, in String installerPackageName);
195880119bf43d738ca632b5d3861eb52d655c1c0fcDianne Hackborn
1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Delete a package.
1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param packageName The fully qualified name of the package to delete.
2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param observer a callback to use to notify when the package deletion in finished.
2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param flags - possible values: {@link #DONT_DELETE_DATA}
2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void deletePackage(in String packageName, IPackageDeleteObserver observer, int flags);
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
20565e13171e12cb9e9fc2f608d0c8a92cd3c098648Jacek Surazski    String getInstallerPackageName(in String packageName);
20665e13171e12cb9e9fc2f608d0c8a92cd3c098648Jacek Surazski
2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void addPackageToPreferred(String packageName);
2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void removePackageFromPreferred(String packageName);
2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    List<PackageInfo> getPreferredPackages(int flags);
2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2138a2ed1d7c0c4f6476e39cc37d9ebd29c7562ce01Dianne Hackborn    void resetPreferredActivities(int userId);
2148a2ed1d7c0c4f6476e39cc37d9ebd29c7562ce01Dianne Hackborn
2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void addPreferredActivity(in IntentFilter filter, int match,
216a3f133afe885f9e005dfc0584cb7b3b90f75f665Amith Yamasani            in ComponentName[] set, in ComponentName activity, int userId);
2178dbe612dc60526d635e57257b58627b33a099678Satish Sampath
2188dbe612dc60526d635e57257b58627b33a099678Satish Sampath    void replacePreferredActivity(in IntentFilter filter, int match,
2198dbe612dc60526d635e57257b58627b33a099678Satish Sampath            in ComponentName[] set, in ComponentName activity);
2208dbe612dc60526d635e57257b58627b33a099678Satish Sampath
2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void clearPackagePreferredActivities(String packageName);
2228dbe612dc60526d635e57257b58627b33a099678Satish Sampath
2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int getPreferredActivities(out List<IntentFilter> outFilters,
2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            out List<ComponentName> outActivities, String packageName);
2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * As per {@link android.content.pm.PackageManager#setComponentEnabledSetting}.
2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void setComponentEnabledSetting(in ComponentName componentName,
230483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani            in int newState, in int flags, int userId);
2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * As per {@link android.content.pm.PackageManager#getComponentEnabledSetting}.
2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
235483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    int getComponentEnabledSetting(in ComponentName componentName, int userId);
2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * As per {@link android.content.pm.PackageManager#setApplicationEnabledSetting}.
2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
240483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    void setApplicationEnabledSetting(in String packageName, in int newState, int flags, int userId);
2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * As per {@link android.content.pm.PackageManager#getApplicationEnabledSetting}.
2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
245483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    int getApplicationEnabledSetting(in String packageName, int userId);
2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
248e7f972122db87dc54e41ed1a6e417534d43bca3aDianne Hackborn     * Set whether the given package should be considered stopped, making
249e7f972122db87dc54e41ed1a6e417534d43bca3aDianne Hackborn     * it not visible to implicit intents that filter out stopped packages.
250e7f972122db87dc54e41ed1a6e417534d43bca3aDianne Hackborn     */
251483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    void setPackageStoppedState(String packageName, boolean stopped, int userId);
252e7f972122db87dc54e41ed1a6e417534d43bca3aDianne Hackborn
253e7f972122db87dc54e41ed1a6e417534d43bca3aDianne Hackborn    /**
2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Free storage by deleting LRU sorted list of cache files across
2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * all applications. If the currently available free storage
2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * on the device is greater than or equal to the requested
2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * free storage, no cache files are cleared. If the currently
2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * available storage on the device is less than the requested
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * free storage, some or all of the cache files across
2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * all applications are deleted (based on last accessed time)
2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to increase the free storage space on the device to
2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the requested value. There is no guarantee that clearing all
2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the cache files from all applications will clear up
2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * enough storage to achieve the desired value.
2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param freeStorageSize The number of bytes of storage to be
2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * freed by the system. Say if freeStorageSize is XX,
2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * and the current free storage is YY,
2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * if XX is less than YY, just return. if not free XX-YY number
2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * of bytes if possible.
2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param observer call back used to notify when
2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the operation is completed
2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     void freeStorageAndNotify(in long freeStorageSize,
2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             IPackageDataObserver observer);
2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Free storage by deleting LRU sorted list of cache files across
2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * all applications. If the currently available free storage
2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * on the device is greater than or equal to the requested
2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * free storage, no cache files are cleared. If the currently
2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * available storage on the device is less than the requested
2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * free storage, some or all of the cache files across
2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * all applications are deleted (based on last accessed time)
2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to increase the free storage space on the device to
2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the requested value. There is no guarantee that clearing all
2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the cache files from all applications will clear up
2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * enough storage to achieve the desired value.
2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param freeStorageSize The number of bytes of storage to be
2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * freed by the system. Say if freeStorageSize is XX,
2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * and the current free storage is YY,
2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * if XX is less than YY, just return. if not free XX-YY number
2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * of bytes if possible.
2931ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu     * @param pi IntentSender call back used to
2941ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu     * notify when the operation is completed.May be null
2951ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu     * to indicate that no call back is desired.
2961ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu     */
297bc806f65edc33f6eda0f475ac84e5e037a013a90Suchi Amalapurapu     void freeStorage(in long freeStorageSize,
2981ccac75e1f1b97eccb916a8de04fc1012b30f6e5Suchi Amalapurapu             in IntentSender pi);
2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Delete all the cache files in an applications cache directory
3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param packageName The package name of the application whose cache
3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * files need to be deleted
3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param observer a callback used to notify when the deletion is finished.
3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void deleteApplicationCacheFiles(in String packageName, IPackageDataObserver observer);
3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Clear the user data directory of an application.
3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param packageName The package name of the application whose cache
3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * files need to be deleted
3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param observer a callback used to notify when the operation is completed.
3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
314483f3b06ea84440a082e21b68ec2c2e54046f5a6Amith Yamasani    void clearApplicationUserData(in String packageName, IPackageDataObserver observer, int userId);
3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project   /**
3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Get package statistics including the code, data and cache size for
3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * an already installed package
3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param packageName The package name of the application
3200c3804950236fe170ebf6cc7a5f1e3e305b8f315Dianne Hackborn     * @param userHandle Which user the size should be retrieved for
3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param observer a callback to use to notify when the asynchronous
3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * retrieval of information is complete.
3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3240c3804950236fe170ebf6cc7a5f1e3e305b8f315Dianne Hackborn    void getPackageSizeInfo(in String packageName, int userHandle, IPackageStatsObserver observer);
3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Get a list of shared libraries that are available on the
3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * system.
3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    String[] getSystemSharedLibraryNames();
3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
33249237345d83e62fdb9eb8d50b13ad086636a04faDianne Hackborn    /**
33349237345d83e62fdb9eb8d50b13ad086636a04faDianne Hackborn     * Get a list of features that are available on the
33449237345d83e62fdb9eb8d50b13ad086636a04faDianne Hackborn     * system.
33549237345d83e62fdb9eb8d50b13ad086636a04faDianne Hackborn     */
33649237345d83e62fdb9eb8d50b13ad086636a04faDianne Hackborn    FeatureInfo[] getSystemAvailableFeatures();
33749237345d83e62fdb9eb8d50b13ad086636a04faDianne Hackborn
338039c68e75606e837cf021815a0210836724574adDianne Hackborn    boolean hasSystemFeature(String name);
339039c68e75606e837cf021815a0210836724574adDianne Hackborn
3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void enterSafeMode();
3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean isSafeMode();
3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void systemReady();
3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean hasSystemUidErrors();
344661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn
345661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn    /**
346661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn     * Ask the package manager to perform boot-time dex-opt of all
347661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn     * existing packages.
348661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn     */
349661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn    void performBootDexOpt();
350661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn
3515c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn    /**
3525c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn     * Ask the package manager to perform dex-opt (if needed) on the given
3535c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn     * package, if it already hasn't done mode.  Only does this if running
3545c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn     * in the special development "no pre-dexopt" mode.
3555c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn     */
3565c1e00b14d2ef10ec76abf3e951fa8003a67f558Dianne Hackborn    boolean performDexOpt(String packageName);
357af8e9f4805643f90a9dc0ecfa119e0a860c12f8aSuchi Amalapurapu
358af8e9f4805643f90a9dc0ecfa119e0a860c12f8aSuchi Amalapurapu    /**
359af8e9f4805643f90a9dc0ecfa119e0a860c12f8aSuchi Amalapurapu     * Update status of external media on the package manager to scan and
360af8e9f4805643f90a9dc0ecfa119e0a860c12f8aSuchi Amalapurapu     * install packages installed on the external media. Like say the
361af8e9f4805643f90a9dc0ecfa119e0a860c12f8aSuchi Amalapurapu     * MountService uses this to call into the package manager to update
362af8e9f4805643f90a9dc0ecfa119e0a860c12f8aSuchi Amalapurapu     * status of sdcard.
363af8e9f4805643f90a9dc0ecfa119e0a860c12f8aSuchi Amalapurapu     */
364e99bb5f10b90736d10cee9729b56cba156fc0921Suchi Amalapurapu    void updateExternalMediaStatus(boolean mounted, boolean reportStatus);
365af8e9f4805643f90a9dc0ecfa119e0a860c12f8aSuchi Amalapurapu
3667767eac3232ba2fb9828766813cdb481d6a97584Dianne Hackborn    PackageCleanItem nextPackageToClean(in PackageCleanItem lastPackage);
3678946dd3355fc1dcbad872c0546e356474d4cc5deSuchi Amalapurapu
3688946dd3355fc1dcbad872c0546e356474d4cc5deSuchi Amalapurapu    void movePackage(String packageName, IPackageMoveObserver observer, int flags);
369e1d7c711df3e3a2d2f195457882aa4ddb5626167Rich Cannings
370d7c096845dee7616095eda0fe9e7aa08f0ba9c20Dianne Hackborn    boolean addPermissionAsync(in PermissionInfo info);
37140e472521a544f26cb6956995788f7c36fff1404Suchi Amalapurapu
37240e472521a544f26cb6956995788f7c36fff1404Suchi Amalapurapu    boolean setInstallLocation(int loc);
37340e472521a544f26cb6956995788f7c36fff1404Suchi Amalapurapu    int getInstallLocation();
3740b285499db739ba50f2f839d633e763c70e67f96Amith Yamasani
3755ab2157bf1f105b02d3e2913cd3a33f9765b74caKenny Root    void installPackageWithVerification(in Uri packageURI, in IPackageInstallObserver observer,
3765ab2157bf1f105b02d3e2913cd3a33f9765b74caKenny Root            int flags, in String installerPackageName, in Uri verificationURI,
377e1d7c711df3e3a2d2f195457882aa4ddb5626167Rich Cannings            in ManifestDigest manifestDigest, in ContainerEncryptionParams encryptionParams);
3785ab2157bf1f105b02d3e2913cd3a33f9765b74caKenny Root
379706e8ba26bf0de19ad5f736516dae40c4c88c2d7rich cannings    void installPackageWithVerificationAndEncryption(in Uri packageURI,
380706e8ba26bf0de19ad5f736516dae40c4c88c2d7rich cannings            in IPackageInstallObserver observer, int flags, in String installerPackageName,
381706e8ba26bf0de19ad5f736516dae40c4c88c2d7rich cannings            in VerificationParams verificationParams,
382706e8ba26bf0de19ad5f736516dae40c4c88c2d7rich cannings            in ContainerEncryptionParams encryptionParams);
383706e8ba26bf0de19ad5f736516dae40c4c88c2d7rich cannings
3847767eac3232ba2fb9828766813cdb481d6a97584Dianne Hackborn    int installExistingPackage(String packageName);
3857767eac3232ba2fb9828766813cdb481d6a97584Dianne Hackborn
3863a9b5fbb97e65019abec97f172b4cbf2100d1225Kenny Root    void verifyPendingInstall(int id, int verificationCode);
387d9ef3e5495db1c46bcfcc1a2d4386af8db6deb0crich cannings    void extendVerificationTimeout(int id, int verificationCodeAtTimeout, long millisecondsToDelay);
3880aaa0d931716e9f57a1d84d795fab2df75092756Kenny Root
3890aaa0d931716e9f57a1d84d795fab2df75092756Kenny Root    VerifierDeviceIdentity getVerifierDeviceIdentity();
39058f42a59bda3bc912d0d2f81dc65a9d31d140eaaDianne Hackborn
39158f42a59bda3bc912d0d2f81dc65a9d31d140eaaDianne Hackborn    boolean isFirstBoot();
39213579ed3305bf89b41a9fa88e1347f0e0769d279Dianne Hackborn    boolean isOnlyCoreApps();
393742a67127366c376fdf188ff99ba30b27d3bf90cAmith Yamasani
3945d32e772b3a19c1ac84e665f2885755427d590c8Jeff Sharkey    void setPermissionEnforced(String permission, boolean enforced);
3955d32e772b3a19c1ac84e665f2885755427d590c8Jeff Sharkey    boolean isPermissionEnforced(String permission);
396f6f7f1d2dc6e8fad5d6ff9a56af9929488873b4fJeff Sharkey
397f6f7f1d2dc6e8fad5d6ff9a56af9929488873b4fJeff Sharkey    /** Reflects current DeviceStorageMonitorService state */
398f6f7f1d2dc6e8fad5d6ff9a56af9929488873b4fJeff Sharkey    boolean isStorageLow();
3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
400