blob: 461b08a75220c94e05cb5fdf48194de3c4d51658 [file] [log] [blame]
Mike Lockwood94afecf2012-10-24 10:45:23 -07001/*
2**
3** Copyright 2008, The Android Open Source Project
4**
5** Licensed under the Apache License, Version 2.0 (the "License");
6** you may not use this file except in compliance with the License.
7** You may obtain a copy of the License at
8**
9** http://www.apache.org/licenses/LICENSE-2.0
10**
11** Unless required by applicable law or agreed to in writing, software
12** distributed under the License is distributed on an "AS IS" BASIS,
13** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14** See the License for the specific language governing permissions and
15** limitations under the License.
16*/
17
18#define LOG_TAG "installd"
19
20#include <stdio.h>
21#include <stdlib.h>
22#include <stdint.h>
23#include <inttypes.h>
24#include <sys/stat.h>
25#include <dirent.h>
26#include <unistd.h>
27#include <ctype.h>
28#include <fcntl.h>
29#include <errno.h>
30#include <utime.h>
31#include <sys/socket.h>
32#include <sys/types.h>
33#include <sys/wait.h>
Jeff Sharkeyc03de092015-04-07 18:14:05 -070034#include <string>
Jeff Sharkeye3637242015-04-08 20:56:42 -070035#include <vector>
Mike Lockwood94afecf2012-10-24 10:45:23 -070036
37#include <cutils/fs.h>
38#include <cutils/sockets.h>
39#include <cutils/log.h>
40#include <cutils/properties.h>
41#include <cutils/multiuser.h>
42
43#include <private/android_filesystem_config.h>
44
Elliott Hughes9a4e7f42014-11-20 12:54:21 -080045#if defined(__APPLE__)
Mike Lockwood94afecf2012-10-24 10:45:23 -070046#include <sys/mount.h>
47#else
48#include <sys/statfs.h>
49#endif
50
51#define SOCKET_PATH "installd"
52
53
54/* elements combined with a valid package name to form paths */
55
56#define PRIMARY_USER_PREFIX "data/"
57#define SECONDARY_USER_PREFIX "user/"
58
59#define PKG_DIR_POSTFIX ""
60
61#define PKG_LIB_POSTFIX "/lib"
62
63#define CACHE_DIR_POSTFIX "/cache"
Jeff Sharkeyc796b682014-07-15 21:49:51 -070064#define CODE_CACHE_DIR_POSTFIX "/code_cache"
Mike Lockwood94afecf2012-10-24 10:45:23 -070065
66#define APP_SUBDIR "app/" // sub-directory under ANDROID_DATA
Jeff Sharkey770180a2014-09-08 17:14:26 -070067#define PRIV_APP_SUBDIR "priv-app/" // sub-directory under ANDROID_DATA
Mike Lockwood94afecf2012-10-24 10:45:23 -070068
69#define APP_LIB_SUBDIR "app-lib/" // sub-directory under ANDROID_DATA
70
71#define MEDIA_SUBDIR "media/" // sub-directory under ANDROID_DATA
72
73/* other handy constants */
74
75#define PRIVATE_APP_SUBDIR "app-private/" // sub-directory under ANDROID_DATA
76
77#define DALVIK_CACHE_PREFIX "/data/dalvik-cache/"
78#define DALVIK_CACHE_POSTFIX "/classes.dex"
79
80#define UPDATE_COMMANDS_DIR_PREFIX "/system/etc/updatecmds/"
81
Mårten Kongstad63568b12014-01-31 14:42:59 +010082#define IDMAP_PREFIX "/data/resource-cache/"
83#define IDMAP_SUFFIX "@idmap"
84
Mike Lockwood94afecf2012-10-24 10:45:23 -070085#define PKG_NAME_MAX 128 /* largest allowed package name */
86#define PKG_PATH_MAX 256 /* max size of any path we use */
87
Richard Uhlerc92fb622015-03-26 15:47:38 -070088/* dexopt needed flags matching those in dalvik.system.DexFile */
89#define DEXOPT_DEX2OAT_NEEDED 1
90#define DEXOPT_PATCHOAT_NEEDED 2
91#define DEXOPT_SELF_PATCHOAT_NEEDED 3
92
Todd Kennedy76e767c2015-09-25 07:47:47 -070093/****************************************************************************
94 * IMPORTANT: These values are passed from Java code. Keep them in sync with
95 * frameworks/base/services/core/java/com/android/server/pm/Installer.java
96 ***************************************************************************/
97#define DEXOPT_PUBLIC (1 << 1)
98#define DEXOPT_SAFEMODE (1 << 2)
99#define DEXOPT_DEBUGGABLE (1 << 3)
100#define DEXOPT_BOOTCOMPLETE (1 << 4)
101#define DEXOPT_MASK (DEXOPT_PUBLIC | DEXOPT_SAFEMODE | DEXOPT_DEBUGGABLE | DEXOPT_BOOTCOMPLETE)
102
Jeff Sharkeye3637242015-04-08 20:56:42 -0700103#define ARRAY_SIZE(a) (sizeof(a) / sizeof(*(a)))
104
Mike Lockwood94afecf2012-10-24 10:45:23 -0700105/* data structures */
106
107typedef struct {
108 char* path;
109 size_t len;
110} dir_rec_t;
111
112typedef struct {
113 size_t count;
114 dir_rec_t* dirs;
115} dir_rec_array_t;
116
117extern dir_rec_t android_app_dir;
118extern dir_rec_t android_app_private_dir;
119extern dir_rec_t android_app_lib_dir;
120extern dir_rec_t android_data_dir;
121extern dir_rec_t android_asec_dir;
122extern dir_rec_t android_media_dir;
Jeff Sharkeye23a1322015-04-06 16:19:39 -0700123extern dir_rec_t android_mnt_expand_dir;
Mike Lockwood94afecf2012-10-24 10:45:23 -0700124extern dir_rec_array_t android_system_dirs;
125
126typedef struct cache_dir_struct {
127 struct cache_dir_struct* parent;
128 int32_t childCount;
129 int32_t hiddenCount;
130 int32_t deleted;
131 char name[];
132} cache_dir_t;
133
134typedef struct {
135 cache_dir_t* dir;
136 time_t modTime;
137 char name[];
138} cache_file_t;
139
140typedef struct {
141 size_t numDirs;
142 size_t availDirs;
143 cache_dir_t** dirs;
144 size_t numFiles;
145 size_t availFiles;
146 cache_file_t** files;
147 size_t numCollected;
148 void* memBlocks;
149 int8_t* curMemBlockAvail;
150 int8_t* curMemBlockEnd;
151} cache_t;
152
153/* util.c */
154
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700155// TODO: rename to create_data_user_package_path
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700156std::string create_package_data_path(const char* volume_uuid,
157 const char* package_name, userid_t user);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700158
159int create_pkg_path(char path[PKG_PATH_MAX],
160 const char *pkgname,
161 const char *postfix,
Jeff Sharkeyabe4fe52013-07-10 16:55:46 -0700162 userid_t userid);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700163
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700164std::string create_data_path(const char* volume_uuid);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700165
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700166std::string create_data_user_path(const char* volume_uuid, userid_t userid);
167
168std::string create_data_media_path(const char* volume_uuid, userid_t userid);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700169
Jeff Sharkeye3637242015-04-08 20:56:42 -0700170std::vector<userid_t> get_known_users(const char* volume_uuid);
171
Robin Lee095c7632014-04-25 15:05:19 +0100172int create_user_config_path(char path[PKG_PATH_MAX], userid_t userid);
173
Mike Lockwood94afecf2012-10-24 10:45:23 -0700174int create_move_path(char path[PKG_PATH_MAX],
175 const char* pkgname,
176 const char* leaf,
Jeff Sharkeyabe4fe52013-07-10 16:55:46 -0700177 userid_t userid);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700178
179int is_valid_package_name(const char* pkgname);
180
Narayan Kamath1b400322014-04-11 13:17:00 +0100181int create_cache_path(char path[PKG_PATH_MAX], const char *src,
182 const char *instruction_set);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700183
184int delete_dir_contents(const char *pathname,
185 int also_delete_dir,
Narayan Kamath3aee2c52014-06-10 13:16:47 +0100186 int (*exclusion_predicate)(const char *name, const int is_dir));
Mike Lockwood94afecf2012-10-24 10:45:23 -0700187
188int delete_dir_contents_fd(int dfd, const char *name);
189
Robin Lee60fd3fe2014-10-07 16:55:02 +0100190int copy_dir_files(const char *srcname, const char *dstname, uid_t owner, gid_t group);
191
Mike Lockwood94afecf2012-10-24 10:45:23 -0700192int lookup_media_dir(char basepath[PATH_MAX], const char *dir);
193
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700194int64_t data_disk_free(const std::string& data_path);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700195
196cache_t* start_cache_collection();
197
198void add_cache_files(cache_t* cache, const char *basepath, const char *cachedir);
199
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700200void clear_cache_files(const std::string& data_path, cache_t* cache, int64_t free_size);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700201
202void finish_cache_collection(cache_t* cache);
203
204int validate_system_app_path(const char* path);
205
206int get_path_from_env(dir_rec_t* rec, const char* var);
207
208int get_path_from_string(dir_rec_t* rec, const char* path);
209
210int copy_and_append(dir_rec_t* dst, const dir_rec_t* src, const char* suffix);
211
212int validate_apk_path(const char *path);
213
214int append_and_increment(char** dst, const char* src, size_t* dst_size);
215
Jeff Sharkey19803802015-04-07 12:44:51 -0700216char *build_string2(const char *s1, const char *s2);
217char *build_string3(const char *s1, const char *s2, const char *s3);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700218
219int ensure_dir(const char* path, mode_t mode, uid_t uid, gid_t gid);
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700220int ensure_media_user_dirs(const char* uuid, userid_t userid);
Robin Lee095c7632014-04-25 15:05:19 +0100221int ensure_config_user_dirs(userid_t userid);
Dave Allisond9370732014-01-30 14:19:23 -0800222int create_profile_file(const char *pkgname, gid_t gid);
223void remove_profile_file(const char *pkgname);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700224
225/* commands.c */
226
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700227int install(const char *uuid, const char *pkgname, uid_t uid, gid_t gid, const char *seinfo);
228int uninstall(const char *uuid, const char *pkgname, userid_t userid);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700229int renamepkg(const char *oldpkgname, const char *newpkgname);
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700230int fix_uid(const char *uuid, const char *pkgname, uid_t uid, gid_t gid);
231int delete_user_data(const char *uuid, const char *pkgname, userid_t userid);
Jeff Sharkeye3637242015-04-08 20:56:42 -0700232int make_user_data(const char *uuid, const char *pkgname, uid_t uid,
233 userid_t userid, const char* seinfo);
234int move_user_data(const char* from_uuid, const char *to_uuid,
235 const char *package_name, appid_t appid, const char* seinfo);
Robin Lee7c8bec02014-06-10 18:46:26 +0100236int make_user_config(userid_t userid);
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700237int delete_user(const char *uuid, userid_t userid);
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700238int delete_cache(const char *uuid, const char *pkgname, userid_t userid);
239int delete_code_cache(const char *uuid, const char *pkgname, userid_t userid);
Narayan Kamath1b400322014-04-11 13:17:00 +0100240int move_dex(const char *src, const char *dst, const char *instruction_set);
241int rm_dex(const char *path, const char *instruction_set);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700242int protect(char *pkgname, gid_t gid);
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700243int get_size(const char *uuid, const char *pkgname, userid_t userid, const char *apkpath, const char *libdirpath,
Narayan Kamath1b400322014-04-11 13:17:00 +0100244 const char *fwdlock_apkpath, const char *asecpath, const char *instruction_set,
245 int64_t *codesize, int64_t *datasize, int64_t *cachesize, int64_t *asecsize);
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700246int free_cache(const char *uuid, int64_t free_size);
Todd Kennedy76e767c2015-09-25 07:47:47 -0700247int dexopt(const char *apk_path, uid_t uid, const char *pkgName, const char *instruction_set,
248 int dexopt_needed, const char* oat_dir, int dexopt_flags);
Narayan Kamath091ea772014-11-10 15:03:46 +0000249int mark_boot_complete(const char *instruction_set);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700250int movefiles();
Jeff Sharkey6fe28a02015-04-09 13:10:03 -0700251int linklib(const char* uuid, const char* pkgname, const char* asecLibDir, int userId);
Mårten Kongstad63568b12014-01-31 14:42:59 +0100252int idmap(const char *target_path, const char *overlay_path, uid_t uid);
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700253int restorecon_data(const char *uuid, const char* pkgName, const char* seinfo, uid_t uid);
Fyodor Kupolov88ce4ff2015-03-03 12:25:29 -0800254int create_oat_dir(const char* oat_dir, const char *instruction_set);
255int rm_package_dir(const char* apk_path);
256int calculate_oat_file_path(char path[PKG_PATH_MAX], const char *oat_dir, const char *apk_path,
Jeff Sharkeye23a1322015-04-06 16:19:39 -0700257 const char *instruction_set);
Jeff Sharkeye3637242015-04-08 20:56:42 -0700258int move_package_dir(char path[PKG_PATH_MAX], const char *oat_dir, const char *apk_path,
259 const char *instruction_set);