1 /*
2  * Copyright (C) 2010 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 /**
18  * @addtogroup Storage
19  * @{
20  */
21 
22 /**
23  * @file storage_manager.h
24  */
25 
26 #ifndef ANDROID_STORAGE_MANAGER_H
27 #define ANDROID_STORAGE_MANAGER_H
28 
29 #include <stdint.h>
30 
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
34 
35 struct AStorageManager;
36 /**
37  * {@link AStorageManager} manages application OBB storage, a pointer
38  * can be obtained with AStorageManager_new().
39  */
40 typedef struct AStorageManager AStorageManager;
41 
42 /**
43  * The different states of a OBB storage passed to AStorageManager_obbCallbackFunc().
44  */
45 enum {
46     /**
47      * The OBB container is now mounted and ready for use. Can be returned
48      * as the status for callbacks made during asynchronous OBB actions.
49      */
50     AOBB_STATE_MOUNTED = 1,
51 
52     /**
53      * The OBB container is now unmounted and not usable. Can be returned
54      * as the status for callbacks made during asynchronous OBB actions.
55      */
56     AOBB_STATE_UNMOUNTED = 2,
57 
58     /**
59      * There was an internal system error encountered while trying to
60      * mount the OBB. Can be returned as the status for callbacks made
61      * during asynchronous OBB actions.
62      */
63     AOBB_STATE_ERROR_INTERNAL = 20,
64 
65     /**
66      * The OBB could not be mounted by the system. Can be returned as the
67      * status for callbacks made during asynchronous OBB actions.
68      */
69     AOBB_STATE_ERROR_COULD_NOT_MOUNT = 21,
70 
71     /**
72      * The OBB could not be unmounted. This most likely indicates that a
73      * file is in use on the OBB. Can be returned as the status for
74      * callbacks made during asynchronous OBB actions.
75      */
76     AOBB_STATE_ERROR_COULD_NOT_UNMOUNT = 22,
77 
78     /**
79      * A call was made to unmount the OBB when it was not mounted. Can be
80      * returned as the status for callbacks made during asynchronous OBB
81      * actions.
82      */
83     AOBB_STATE_ERROR_NOT_MOUNTED = 23,
84 
85     /**
86      * The OBB has already been mounted. Can be returned as the status for
87      * callbacks made during asynchronous OBB actions.
88      */
89     AOBB_STATE_ERROR_ALREADY_MOUNTED = 24,
90 
91     /**
92      * The current application does not have permission to use this OBB.
93      * This could be because the OBB indicates it's owned by a different
94      * package. Can be returned as the status for callbacks made during
95      * asynchronous OBB actions.
96      */
97     AOBB_STATE_ERROR_PERMISSION_DENIED = 25,
98 };
99 
100 /**
101  * Obtains a new instance of AStorageManager.
102  */
103 AStorageManager* AStorageManager_new();
104 
105 /**
106  * Release AStorageManager instance.
107  */
108 void AStorageManager_delete(AStorageManager* mgr);
109 
110 /**
111  * Callback function for asynchronous calls made on OBB files.
112  *
113  * "state" is one of the following constants:
114  * - {@link AOBB_STATE_MOUNTED}
115  * - {@link AOBB_STATE_UNMOUNTED}
116  * - {@link AOBB_STATE_ERROR_INTERNAL}
117  * - {@link AOBB_STATE_ERROR_COULD_NOT_MOUNT}
118  * - {@link AOBB_STATE_ERROR_COULD_NOT_UNMOUNT}
119  * - {@link AOBB_STATE_ERROR_NOT_MOUNTED}
120  * - {@link AOBB_STATE_ERROR_ALREADY_MOUNTED}
121  * - {@link AOBB_STATE_ERROR_PERMISSION_DENIED}
122  */
123 typedef void (*AStorageManager_obbCallbackFunc)(const char* filename, const int32_t state, void* data);
124 
125 /**
126  * Attempts to mount an OBB file. This is an asynchronous operation.
127  *
128  * Since API level 33, this function can only be used to mount unencrypted OBBs,
129  * i.e. the {@code key} parameter must be {@code null} or an empty string. Note
130  * that even before API level 33, mounting encrypted OBBs didn't work on many
131  * Android device implementations. Applications should not assume any particular
132  * behavior when {@code key} is nonempty.
133  */
134 void AStorageManager_mountObb(AStorageManager* mgr, const char* filename, const char* key,
135         AStorageManager_obbCallbackFunc cb, void* data);
136 
137 /**
138  * Attempts to unmount an OBB file. This is an asynchronous operation.
139  */
140 void AStorageManager_unmountObb(AStorageManager* mgr, const char* filename, const int force,
141         AStorageManager_obbCallbackFunc cb, void* data);
142 
143 /**
144  * Check whether an OBB is mounted.
145  */
146 int AStorageManager_isObbMounted(AStorageManager* mgr, const char* filename);
147 
148 /**
149  * Get the mounted path for an OBB.
150  */
151 const char* AStorageManager_getMountedObbPath(AStorageManager* mgr, const char* filename);
152 
153 
154 #ifdef __cplusplus
155 };
156 #endif
157 
158 #endif      // ANDROID_STORAGE_MANAGER_H
159 
160 /** @} */
161