1 /* 2 * Copyright (C) 2015 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.content.om; 18 19 import android.content.om.OverlayIdentifier; 20 import android.content.om.OverlayInfo; 21 import android.content.om.OverlayManagerTransaction; 22 23 /** 24 * Api for getting information about overlay packages. 25 * 26 * {@hide} 27 */ 28 interface IOverlayManager { 29 /** 30 * Returns information about all installed overlay packages for the 31 * specified user. If there are no installed overlay packages for this user, 32 * an empty map is returned (i.e. null is never returned). The returned map is a 33 * mapping of target package names to lists of overlays. Each list for a 34 * given target package is sorted in priority order, with the overlay with 35 * the highest priority at the end of the list. 36 * 37 * @param userId The user to get the OverlayInfos for. 38 * @return A Map<String, List<OverlayInfo>> with target package names 39 * mapped to lists of overlays; if no overlays exist for the 40 * requested user, an empty map is returned. 41 */ 42 @UnsupportedAppUsage(maxTargetSdk = 30, trackingBug = 170729553) getAllOverlays(in int userId)43 Map<String, List<OverlayInfo>> getAllOverlays(in int userId); 44 45 /** 46 * Returns information about all overlays for the given target package for 47 * the specified user. The returned list is ordered according to the 48 * overlay priority with the highest priority at the end of the list. 49 * 50 * @param targetPackageName The name of the target package. 51 * @param userId The user to get the OverlayInfos for. 52 * @return A list of OverlayInfo objects; if no overlays exist for the 53 * requested package, an empty list is returned. 54 */ getOverlayInfosForTarget(in String targetPackageName, in int userId)55 List<OverlayInfo> getOverlayInfosForTarget(in String targetPackageName, in int userId); 56 57 /** 58 * Returns information about the overlay with the given package name for the 59 * specified user. 60 * 61 * @param packageName The name of the overlay package. 62 * @param userId The user to get the OverlayInfo for. 63 * @return The OverlayInfo for the overlay package; or null if no such 64 * overlay package exists. 65 */ 66 @UnsupportedAppUsage(maxTargetSdk = 30, trackingBug = 170729553) getOverlayInfo(in String packageName, in int userId)67 OverlayInfo getOverlayInfo(in String packageName, in int userId); 68 69 /** 70 * Returns information about the overlay with the given package name for the 71 * specified user. 72 * 73 * @param packageName The name of the overlay package. 74 * @param userId The user to get the OverlayInfo for. 75 * @return The OverlayInfo for the overlay package; or null if no such 76 * overlay package exists. 77 */ getOverlayInfoByIdentifier(in OverlayIdentifier packageName, in int userId)78 OverlayInfo getOverlayInfoByIdentifier(in OverlayIdentifier packageName, in int userId); 79 80 /** 81 * Request that an overlay package be enabled or disabled when possible to 82 * do so. 83 * 84 * It is always possible to disable an overlay, but due to technical and 85 * security reasons it may not always be possible to enable an overlay. An 86 * example of the latter is when the related target package is not 87 * installed. If the technical obstacle is later overcome, the overlay is 88 * automatically enabled at that point in time. 89 * 90 * An enabled overlay is a part of target package's resources, i.e. it will 91 * be part of any lookups performed via {@link android.content.res.Resources} 92 * and {@link android.content.res.AssetManager}. A disabled overlay will no 93 * longer affect the resources of the target package. If the target is 94 * currently running, its outdated resources will be replaced by new ones. 95 * This happens the same way as when an application enters or exits split 96 * window mode. 97 * 98 * @param packageName The name of the overlay package. 99 * @param enable true to enable the overlay, false to disable it. 100 * @param userId The user for which to change the overlay. 101 * @return true if the system successfully registered the request, false otherwise. 102 */ setEnabled(in String packageName, in boolean enable, in int userId)103 boolean setEnabled(in String packageName, in boolean enable, in int userId); 104 105 /** 106 * Request that an overlay package is enabled and any other overlay packages with the same 107 * target package are disabled. 108 * 109 * See {@link #setEnabled} for the details on overlay packages. 110 * 111 * @param packageName the name of the overlay package to enable. 112 * @param enabled must be true, otherwise the operation fails. 113 * @param userId The user for which to change the overlay. 114 * @return true if the system successfully registered the request, false otherwise. 115 */ setEnabledExclusive(in String packageName, in boolean enable, in int userId)116 boolean setEnabledExclusive(in String packageName, in boolean enable, in int userId); 117 118 /** 119 * Request that an overlay package is enabled and any other overlay packages with the same 120 * target package and category are disabled. 121 * 122 * See {@link #setEnabled} for the details on overlay packages. 123 * 124 * @param packageName the name of the overlay package to enable. 125 * @param userId The user for which to change the overlay. 126 * @return true if the system successfully registered the request, false otherwise. 127 */ setEnabledExclusiveInCategory(in String packageName, in int userId)128 boolean setEnabledExclusiveInCategory(in String packageName, in int userId); 129 130 /** 131 * Change the priority of the given overlay to be just higher than the 132 * overlay with package name newParentPackageName. Both overlay packages 133 * must have the same target and user. 134 * 135 * @see getOverlayInfosForTarget 136 * 137 * @param packageName The name of the overlay package whose priority should 138 * be adjusted. 139 * @param newParentPackageName The name of the overlay package the newly 140 * adjusted overlay package should just outrank. 141 * @param userId The user for which to change the overlay. 142 */ setPriority(in String packageName, in String newParentPackageName, in int userId)143 boolean setPriority(in String packageName, in String newParentPackageName, in int userId); 144 145 /** 146 * Change the priority of the given overlay to the highest priority relative to 147 * the other overlays with the same target and user. 148 * 149 * @see getOverlayInfosForTarget 150 * 151 * @param packageName The name of the overlay package whose priority should 152 * be adjusted. 153 * @param userId The user for which to change the overlay. 154 */ setHighestPriority(in String packageName, in int userId)155 boolean setHighestPriority(in String packageName, in int userId); 156 157 /** 158 * Change the priority of the overlay to the lowest priority relative to 159 * the other overlays for the same target and user. 160 * 161 * @see getOverlayInfosForTarget 162 * 163 * @param packageName The name of the overlay package whose priority should 164 * be adjusted. 165 * @param userId The user for which to change the overlay. 166 */ setLowestPriority(in String packageName, in int userId)167 boolean setLowestPriority(in String packageName, in int userId); 168 169 /** 170 * Returns the list of default overlay packages, or an empty array if there are none. 171 */ getDefaultOverlayPackages()172 String[] getDefaultOverlayPackages(); 173 174 /** 175 * Invalidates and removes the idmap for an overlay, 176 * @param packageName The name of the overlay package whose idmap should be deleted. 177 */ invalidateCachesForOverlay(in String packageName, in int userId)178 void invalidateCachesForOverlay(in String packageName, in int userId); 179 180 /** 181 * Perform a series of requests related to overlay packages. This is an 182 * atomic operation: either all requests were performed successfully and 183 * the changes were propagated to the rest of the system, or at least one 184 * request could not be performed successfully and nothing is changed and 185 * nothing is propagated to the rest of the system. 186 * 187 * @see OverlayManagerTransaction 188 * 189 * @param transaction the series of overlay related requests to perform 190 * @throws SecurityException if the transaction failed 191 */ commit(in OverlayManagerTransaction transaction)192 void commit(in OverlayManagerTransaction transaction); 193 194 /** 195 * Returns a String of a list of partitions from low priority to high. 196 */ getPartitionOrder()197 String getPartitionOrder(); 198 199 /** 200 * Returns a boolean which represent whether the partition list is sorted by default. 201 * If not then it should be sorted by /product/overlay/partition_order.xml. 202 */ isDefaultPartitionOrder()203 boolean isDefaultPartitionOrder(); 204 } 205