• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2016 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package android.content.pm;
18 
19 import android.annotation.NonNull;
20 import android.annotation.Nullable;
21 import android.annotation.UserIdInt;
22 import android.appwidget.AppWidgetProviderInfo;
23 import android.content.ComponentName;
24 import android.content.Intent;
25 import android.content.IntentFilter;
26 import android.content.IntentSender;
27 import android.content.LocusId;
28 import android.content.pm.LauncherApps.ShortcutQuery;
29 import android.os.Bundle;
30 import android.os.ParcelFileDescriptor;
31 
32 import com.android.internal.infra.AndroidFuture;
33 
34 import java.util.List;
35 
36 /**
37  * Entry points used by {@link LauncherApps}.
38  *
39  * <p>No permission / argument checks will be performed inside.
40  * Callers must check the calling app permission and the calling package name.
41  * @hide
42  */
43 public abstract class ShortcutServiceInternal {
44     public interface ShortcutChangeListener {
onShortcutChanged(@onNull String packageName, @UserIdInt int userId)45         void onShortcutChanged(@NonNull String packageName, @UserIdInt int userId);
46     }
47 
48     public abstract List<ShortcutInfo>
getShortcuts(int launcherUserId, @NonNull String callingPackage, long changedSince, @Nullable String packageName, @Nullable List<String> shortcutIds, @Nullable List<LocusId> locusIds, @Nullable ComponentName componentName, @ShortcutQuery.QueryFlags int flags, int userId, int callingPid, int callingUid)49             getShortcuts(int launcherUserId,
50             @NonNull String callingPackage, long changedSince,
51             @Nullable String packageName, @Nullable List<String> shortcutIds,
52             @Nullable List<LocusId> locusIds, @Nullable ComponentName componentName,
53             @ShortcutQuery.QueryFlags int flags, int userId, int callingPid, int callingUid);
54 
55     public abstract boolean
isPinnedByCaller(int launcherUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull String id, int userId)56             isPinnedByCaller(int launcherUserId, @NonNull String callingPackage,
57             @NonNull String packageName, @NonNull String id, int userId);
58 
pinShortcuts(int launcherUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull List<String> shortcutIds, int userId)59     public abstract void pinShortcuts(int launcherUserId,
60             @NonNull String callingPackage, @NonNull String packageName,
61             @NonNull List<String> shortcutIds, int userId);
62 
createShortcutIntents( int launcherUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull String shortcutId, int userId, int callingPid, int callingUid)63     public abstract Intent[] createShortcutIntents(
64             int launcherUserId, @NonNull String callingPackage,
65             @NonNull String packageName, @NonNull String shortcutId, int userId,
66             int callingPid, int callingUid);
67 
addListener(@onNull ShortcutChangeListener listener)68     public abstract void addListener(@NonNull ShortcutChangeListener listener);
69 
addShortcutChangeCallback( @onNull LauncherApps.ShortcutChangeCallback callback)70     public abstract void addShortcutChangeCallback(
71             @NonNull LauncherApps.ShortcutChangeCallback callback);
72 
removeShortcutChangeCallback( @onNull LauncherApps.ShortcutChangeCallback callback)73     public abstract void removeShortcutChangeCallback(
74             @NonNull LauncherApps.ShortcutChangeCallback callback);
75 
getShortcutIconResId(int launcherUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull String shortcutId, int userId)76     public abstract int getShortcutIconResId(int launcherUserId, @NonNull String callingPackage,
77             @NonNull String packageName, @NonNull String shortcutId, int userId);
78 
79     /**
80      * Get the theme res ID of the starting window, it can be 0 if not specified.
81      */
getShortcutStartingThemeResName(int launcherUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull String shortcutId, int userId)82     public abstract @Nullable String getShortcutStartingThemeResName(int launcherUserId,
83             @NonNull String callingPackage, @NonNull String packageName, @NonNull String shortcutId,
84             int userId);
85 
getShortcutIconFd(int launcherUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull String shortcutId, int userId)86     public abstract ParcelFileDescriptor getShortcutIconFd(int launcherUserId,
87             @NonNull String callingPackage,
88             @NonNull String packageName, @NonNull String shortcutId, int userId);
89 
hasShortcutHostPermission(int launcherUserId, @NonNull String callingPackage, int callingPid, int callingUid)90     public abstract boolean hasShortcutHostPermission(int launcherUserId,
91             @NonNull String callingPackage, int callingPid, int callingUid);
92 
93     /**
94      * Returns whether or not Shortcuts are supported on Launcher Home Screen.
95      */
areShortcutsSupportedOnHomeScreen(@serIdInt int userId)96     public abstract boolean areShortcutsSupportedOnHomeScreen(@UserIdInt int userId);
97 
setShortcutHostPackage(@onNull String type, @Nullable String packageName, int userId)98     public abstract void setShortcutHostPackage(@NonNull String type, @Nullable String packageName,
99             int userId);
100 
requestPinAppWidget(@onNull String callingPackage, @NonNull AppWidgetProviderInfo appWidget, @Nullable Bundle extras, @Nullable IntentSender resultIntent, int userId)101     public abstract boolean requestPinAppWidget(@NonNull String callingPackage,
102             @NonNull AppWidgetProviderInfo appWidget, @Nullable Bundle extras,
103             @Nullable IntentSender resultIntent, int userId);
104 
isRequestPinItemSupported(int callingUserId, int requestType)105     public abstract boolean isRequestPinItemSupported(int callingUserId, int requestType);
106 
isForegroundDefaultLauncher(@onNull String callingPackage, int callingUid)107     public abstract boolean isForegroundDefaultLauncher(@NonNull String callingPackage,
108             int callingUid);
109 
cacheShortcuts(int launcherUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull List<String> shortcutIds, int userId, int cacheFlags)110     public abstract void cacheShortcuts(int launcherUserId,
111             @NonNull String callingPackage, @NonNull String packageName,
112             @NonNull List<String> shortcutIds, int userId, int cacheFlags);
uncacheShortcuts(int launcherUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull List<String> shortcutIds, int userId, int cacheFlags)113     public abstract void uncacheShortcuts(int launcherUserId,
114             @NonNull String callingPackage, @NonNull String packageName,
115             @NonNull List<String> shortcutIds, int userId, int cacheFlags);
116 
117     /**
118      * Retrieves all of the direct share targets that match the given IntentFilter for the specified
119      * user.
120      */
getShareTargets( @onNull String callingPackage, @NonNull IntentFilter intentFilter, int userId)121     public abstract List<ShortcutManager.ShareShortcutInfo> getShareTargets(
122             @NonNull String callingPackage, @NonNull IntentFilter intentFilter, int userId);
123 
124     /**
125      * Returns the icon Uri of the shortcut, and grants Uri read permission to the caller.
126      */
getShortcutIconUri(int launcherUserId, @NonNull String launcherPackage, @NonNull String packageName, @NonNull String shortcutId, int userId)127     public abstract String getShortcutIconUri(int launcherUserId, @NonNull String launcherPackage,
128             @NonNull String packageName, @NonNull String shortcutId, int userId);
129 
isSharingShortcut(int callingUserId, @NonNull String callingPackage, @NonNull String packageName, @NonNull String shortcutId, int userId, @NonNull IntentFilter filter)130     public abstract boolean isSharingShortcut(int callingUserId, @NonNull String callingPackage,
131             @NonNull String packageName, @NonNull String shortcutId, int userId,
132             @NonNull IntentFilter filter);
133 }
134