blob: 4f691c91271ddd5fc51ab5aafb08863d2301c8a5 [file] [log] [blame]
Mike Lockwood94afecf2012-10-24 10:45:23 -07001/*
2** Copyright 2008, The Android Open Source Project
3**
Jeff Sharkey19803802015-04-07 12:44:51 -07004** 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
Mike Lockwood94afecf2012-10-24 10:45:23 -07007**
Jeff Sharkey19803802015-04-07 12:44:51 -07008** http://www.apache.org/licenses/LICENSE-2.0
Mike Lockwood94afecf2012-10-24 10:45:23 -07009**
Jeff Sharkey19803802015-04-07 12:44:51 -070010** 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
Mike Lockwood94afecf2012-10-24 10:45:23 -070014** limitations under the License.
15*/
Mark Salyzyna5e161b2016-09-29 08:08:05 -070016#define LOG_TAG "installd"
Mike Lockwood94afecf2012-10-24 10:45:23 -070017
Andreas Gampe02d0de52015-11-11 20:43:16 -080018#include <fcntl.h>
Stephen Smalleybd558d62013-04-16 12:16:50 -040019#include <selinux/android.h>
20#include <selinux/avc.h>
Andreas Gampe02d0de52015-11-11 20:43:16 -080021#include <sys/capability.h>
Jeff Sharkeyc7d1b222016-01-11 13:07:09 -070022#include <sys/fsuid.h>
Andreas Gampe02d0de52015-11-11 20:43:16 -080023#include <sys/prctl.h>
Andreas Gampe02d0de52015-11-11 20:43:16 -080024#include <sys/stat.h>
25
26#include <android-base/logging.h>
27#include <cutils/fs.h>
Andreas Gampe02d0de52015-11-11 20:43:16 -080028#include <cutils/properties.h>
Mark Salyzyna5e161b2016-09-29 08:08:05 -070029#include <log/log.h> // TODO: Move everything to base::logging.
Andreas Gampe02d0de52015-11-11 20:43:16 -080030#include <private/android_filesystem_config.h>
31
Jeff Sharkeyf3e30b92016-12-09 17:06:57 -070032#include "InstalldNativeService.h"
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060033#include "dexopt.h"
Jeff Sharkeyf3e30b92016-12-09 17:06:57 -070034#include "globals.h"
35#include "installd_constants.h"
36#include "installd_deps.h" // Need to fill in requirements of commands.
37#include "utils.h"
Andreas Gampe02d0de52015-11-11 20:43:16 -080038
Andreas Gampe02d0de52015-11-11 20:43:16 -080039namespace android {
40namespace installd {
41
42// Check that installd-deps sizes match cutils sizes.
43static_assert(kPropertyKeyMax == PROPERTY_KEY_MAX, "Size mismatch.");
44static_assert(kPropertyValueMax == PROPERTY_VALUE_MAX, "Size mismatch.");
45
46////////////////////////
47// Plug-in functions. //
48////////////////////////
49
50int get_property(const char *key, char *value, const char *default_value) {
51 return property_get(key, value, default_value);
52}
53
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060054bool calculate_oat_file_path(char path[PKG_PATH_MAX], const char *oat_dir, const char *apk_path,
55 const char *instruction_set) {
56 return calculate_oat_file_path_default(path, oat_dir, apk_path, instruction_set);
Andreas Gampe02d0de52015-11-11 20:43:16 -080057}
58
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060059bool calculate_odex_file_path(char path[PKG_PATH_MAX], const char *apk_path,
60 const char *instruction_set) {
61 return calculate_odex_file_path_default(path, apk_path, instruction_set);
Andreas Gampe02d0de52015-11-11 20:43:16 -080062}
63
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060064bool create_cache_path(char path[PKG_PATH_MAX], const char *src, const char *instruction_set) {
65 return create_cache_path_default(path, src, instruction_set);
Andreas Gampe02d0de52015-11-11 20:43:16 -080066}
67
Jiakai Zhang6af6b972023-03-13 10:10:18 +000068bool force_compile_without_image() {
69 return false;
70}
71
Andreas Gamped089ca12016-06-27 14:25:30 -070072static bool initialize_globals() {
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060073 return init_globals_from_data_and_root();
Mike Lockwood94afecf2012-10-24 10:45:23 -070074}
75
Andreas Gampe02d0de52015-11-11 20:43:16 -080076static int initialize_directories() {
Mike Lockwood94afecf2012-10-24 10:45:23 -070077 int res = -1;
78
79 // Read current filesystem layout version to handle upgrade paths
80 char version_path[PATH_MAX];
Paul Crowley3dfd55f2019-08-16 15:12:23 -070081 snprintf(version_path, PATH_MAX, "%smisc/installd/layout_version", android_data_dir.c_str());
Mike Lockwood94afecf2012-10-24 10:45:23 -070082
83 int oldVersion;
84 if (fs_read_atomic_int(version_path, &oldVersion) == -1) {
85 oldVersion = 0;
86 }
87 int version = oldVersion;
88
Jeff Sharkeye02657d2016-01-13 09:37:46 -070089 if (version < 2) {
90 SLOGD("Assuming that device has multi-user storage layout; upgrade no longer supported");
Mike Lockwood94afecf2012-10-24 10:45:23 -070091 version = 2;
92 }
93
Robin Lee07053fc2014-04-29 19:42:01 +010094 if (ensure_config_user_dirs(0) == -1) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -070095 SLOGE("Failed to setup misc for user 0");
Robin Lee07053fc2014-04-29 19:42:01 +010096 goto fail;
97 }
98
Robin Lee095c7632014-04-25 15:05:19 +010099 if (version == 2) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700100 SLOGD("Upgrading to /data/misc/user directories");
Robin Lee095c7632014-04-25 15:05:19 +0100101
Robin Lee60fd3fe2014-10-07 16:55:02 +0100102 char misc_dir[PATH_MAX];
Jeff Sharkeyc1149c92017-09-21 14:51:09 -0600103 snprintf(misc_dir, PATH_MAX, "%smisc", android_data_dir.c_str());
Robin Lee60fd3fe2014-10-07 16:55:02 +0100104
105 char keychain_added_dir[PATH_MAX];
106 snprintf(keychain_added_dir, PATH_MAX, "%s/keychain/cacerts-added", misc_dir);
107
108 char keychain_removed_dir[PATH_MAX];
109 snprintf(keychain_removed_dir, PATH_MAX, "%s/keychain/cacerts-removed", misc_dir);
110
Robin Lee095c7632014-04-25 15:05:19 +0100111 DIR *dir;
112 struct dirent *dirent;
Jeff Sharkeye02657d2016-01-13 09:37:46 -0700113 dir = opendir("/data/user");
Yi Kong954cf642018-07-17 16:16:24 -0700114 if (dir != nullptr) {
Robin Lee095c7632014-04-25 15:05:19 +0100115 while ((dirent = readdir(dir))) {
Robin Lee60fd3fe2014-10-07 16:55:02 +0100116 const char *name = dirent->d_name;
Robin Lee095c7632014-04-25 15:05:19 +0100117
Robin Lee60fd3fe2014-10-07 16:55:02 +0100118 // skip "." and ".."
119 if (name[0] == '.') {
120 if (name[1] == 0) continue;
121 if ((name[1] == '.') && (name[2] == 0)) continue;
122 }
123
Jeff Sharkeyc1149c92017-09-21 14:51:09 -0600124 uint32_t user_id = std::stoi(name);
Robin Lee60fd3fe2014-10-07 16:55:02 +0100125
126 // /data/misc/user/<user_id>
127 if (ensure_config_user_dirs(user_id) == -1) {
128 goto fail;
129 }
130
131 char misc_added_dir[PATH_MAX];
132 snprintf(misc_added_dir, PATH_MAX, "%s/user/%s/cacerts-added", misc_dir, name);
133
134 char misc_removed_dir[PATH_MAX];
135 snprintf(misc_removed_dir, PATH_MAX, "%s/user/%s/cacerts-removed", misc_dir, name);
136
137 uid_t uid = multiuser_get_uid(user_id, AID_SYSTEM);
138 gid_t gid = uid;
139 if (access(keychain_added_dir, F_OK) == 0) {
140 if (copy_dir_files(keychain_added_dir, misc_added_dir, uid, gid) != 0) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700141 SLOGE("Some files failed to copy");
Robin Lee095c7632014-04-25 15:05:19 +0100142 }
Robin Lee60fd3fe2014-10-07 16:55:02 +0100143 }
144 if (access(keychain_removed_dir, F_OK) == 0) {
145 if (copy_dir_files(keychain_removed_dir, misc_removed_dir, uid, gid) != 0) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700146 SLOGE("Some files failed to copy");
Robin Lee095c7632014-04-25 15:05:19 +0100147 }
148 }
149 }
150 closedir(dir);
Robin Lee095c7632014-04-25 15:05:19 +0100151
Robin Lee60fd3fe2014-10-07 16:55:02 +0100152 if (access(keychain_added_dir, F_OK) == 0) {
Yi Kong954cf642018-07-17 16:16:24 -0700153 delete_dir_contents(keychain_added_dir, 1, nullptr);
Robin Lee07053fc2014-04-29 19:42:01 +0100154 }
Robin Lee60fd3fe2014-10-07 16:55:02 +0100155 if (access(keychain_removed_dir, F_OK) == 0) {
Yi Kong954cf642018-07-17 16:16:24 -0700156 delete_dir_contents(keychain_removed_dir, 1, nullptr);
Robin Lee07053fc2014-04-29 19:42:01 +0100157 }
158 }
159
160 version = 3;
Robin Lee095c7632014-04-25 15:05:19 +0100161 }
162
Mike Lockwood94afecf2012-10-24 10:45:23 -0700163 // Persist layout version if changed
164 if (version != oldVersion) {
165 if (fs_write_atomic_int(version_path, version) == -1) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700166 SLOGE("Failed to save version to %s: %s", version_path, strerror(errno));
Mike Lockwood94afecf2012-10-24 10:45:23 -0700167 goto fail;
168 }
169 }
170
171 // Success!
172 res = 0;
173
174fail:
Mike Lockwood94afecf2012-10-24 10:45:23 -0700175 return res;
176}
177
Jeff Sharkeyc1149c92017-09-21 14:51:09 -0600178static int log_callback(int type, const char *fmt, ...) { // NOLINT
Stephen Smalley7abb52b2014-03-26 09:30:37 -0400179 va_list ap;
180 int priority;
181
182 switch (type) {
183 case SELINUX_WARNING:
184 priority = ANDROID_LOG_WARN;
185 break;
186 case SELINUX_INFO:
187 priority = ANDROID_LOG_INFO;
188 break;
189 default:
190 priority = ANDROID_LOG_ERROR;
191 break;
192 }
193 va_start(ap, fmt);
194 LOG_PRI_VA(priority, "SELinux", fmt, ap);
195 va_end(ap);
196 return 0;
197}
198
Andreas Gampe02d0de52015-11-11 20:43:16 -0800199static int installd_main(const int argc ATTRIBUTE_UNUSED, char *argv[]) {
Jeff Sharkey6c2c0562016-12-07 12:12:00 -0700200 int ret;
Stephen Smalleybd558d62013-04-16 12:16:50 -0400201 int selinux_enabled = (is_selinux_enabled() > 0);
Mike Lockwood94afecf2012-10-24 10:45:23 -0700202
Jeff Sharkeye3637242015-04-08 20:56:42 -0700203 setenv("ANDROID_LOG_TAGS", "*:v", 1);
204 android::base::InitLogging(argv);
205
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700206 SLOGI("installd firing up");
Mike Lockwood94afecf2012-10-24 10:45:23 -0700207
Stephen Smalley7abb52b2014-03-26 09:30:37 -0400208 union selinux_callback cb;
209 cb.func_log = log_callback;
210 selinux_set_callback(SELINUX_CB_LOG, cb);
211
Andreas Gampe02d0de52015-11-11 20:43:16 -0800212 if (!initialize_globals()) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700213 SLOGE("Could not initialize globals; exiting.\n");
Mike Lockwood94afecf2012-10-24 10:45:23 -0700214 exit(1);
215 }
216
217 if (initialize_directories() < 0) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700218 SLOGE("Could not create directories; exiting.\n");
Mike Lockwood94afecf2012-10-24 10:45:23 -0700219 exit(1);
220 }
221
Stephen Smalleybd558d62013-04-16 12:16:50 -0400222 if (selinux_enabled && selinux_status_open(true) < 0) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700223 SLOGE("Could not open selinux status; exiting.\n");
Stephen Smalleybd558d62013-04-16 12:16:50 -0400224 exit(1);
225 }
226
Jeff Sharkey90874002016-12-05 11:18:55 -0700227 if ((ret = InstalldNativeService::start()) != android::OK) {
Mark Salyzyna5e161b2016-09-29 08:08:05 -0700228 SLOGE("Unable to start InstalldNativeService: %d", ret);
Jeff Sharkey90874002016-12-05 11:18:55 -0700229 exit(1);
230 }
231
Jeff Sharkey6c2c0562016-12-07 12:12:00 -0700232 IPCThreadState::self()->joinThreadPool();
Mike Lockwood94afecf2012-10-24 10:45:23 -0700233
Jeff Sharkey6c2c0562016-12-07 12:12:00 -0700234 LOG(INFO) << "installd shutting down";
Mike Lockwood94afecf2012-10-24 10:45:23 -0700235
236 return 0;
237}
Andreas Gampe02d0de52015-11-11 20:43:16 -0800238
239} // namespace installd
240} // namespace android
241
242int main(const int argc, char *argv[]) {
243 return android::installd::installd_main(argc, argv);
244}