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.os.storage;
18 
19 /**
20  * Mount service local interface.
21  *
22  * @hide Only for use within the system server.
23  */
24 public abstract class StorageManagerInternal {
25 
26     /**
27      * Policy that influences how external storage is mounted and reported.
28      */
29     public interface ExternalStorageMountPolicy {
30         /**
31          * Gets the external storage mount mode for the given uid.
32          *
33          * @param uid The UID for which to determine mount mode.
34          * @param packageName The package in the UID for making the call.
35          * @return The mount mode.
36          *
37          * @see com.android.internal.os.Zygote#MOUNT_EXTERNAL_NONE
38          * @see com.android.internal.os.Zygote#MOUNT_EXTERNAL_DEFAULT
39          * @see com.android.internal.os.Zygote#MOUNT_EXTERNAL_READ
40          * @see com.android.internal.os.Zygote#MOUNT_EXTERNAL_WRITE
41          */
getMountMode(int uid, String packageName)42         public int getMountMode(int uid, String packageName);
43 
44         /**
45          * Gets whether external storage should be reported to the given UID.
46          *
47          * @param uid The UID for which to determine whether it has external storage.
48          * @param packageName The package in the UID for making the call.
49          * @return Weather to report external storage.
50          * @return True to report the state of external storage, false to
51          *     report it as unmounted.
52          */
hasExternalStorage(int uid, String packageName)53         public boolean hasExternalStorage(int uid, String packageName);
54     }
55 
56     /**
57      * Adds a policy for determining how external storage is mounted and reported.
58      * The mount mode is the most conservative result from querying all registered
59      * policies. Similarly, the reported state is the most conservative result from
60      * querying all registered policies.
61      *
62      * @param policy The policy to add.
63      */
addExternalStoragePolicy(ExternalStorageMountPolicy policy)64     public abstract void addExternalStoragePolicy(ExternalStorageMountPolicy policy);
65 
66     /**
67      * Notify the mount service that the mount policy for a UID changed.
68      * @param uid The UID for which policy changed.
69      * @param packageName The package in the UID for making the call.
70      */
onExternalStoragePolicyChanged(int uid, String packageName)71     public abstract void onExternalStoragePolicyChanged(int uid, String packageName);
72 
73     /**
74      * Gets the mount mode to use for a given UID as determined by consultin all
75      * policies.
76      *
77      * @param uid The UID for which to get mount mode.
78      * @param packageName The package in the UID for making the call.
79      * @return The mount mode.
80      */
getExternalStorageMountMode(int uid, String packageName)81     public abstract int getExternalStorageMountMode(int uid, String packageName);
82 }
83