blob: b13d6d7580ef024f3212fdfba6145f2199edcc07 [file] [log] [blame]
Andreas Gampe02d0de52015-11-11 20:43:16 -08001/*
2**
3** Copyright 2008, The Android Open Source Project
4**
Jeff Sharkeyf3e30b92016-12-09 17:06:57 -07005** 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
Andreas Gampe02d0de52015-11-11 20:43:16 -08008**
Jeff Sharkeyf3e30b92016-12-09 17:06:57 -07009** http://www.apache.org/licenses/LICENSE-2.0
Andreas Gampe02d0de52015-11-11 20:43:16 -080010**
Jeff Sharkeyf3e30b92016-12-09 17:06:57 -070011** 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
Andreas Gampe02d0de52015-11-11 20:43:16 -080015** limitations under the License.
16*/
17
18#ifndef COMMANDS_H_
19#define COMMANDS_H_
20
21#include <inttypes.h>
Victor Hsiehc7ab5642023-07-28 15:07:55 -070022#include <sys/stat.h>
Andreas Gampe02d0de52015-11-11 20:43:16 -080023#include <unistd.h>
24
Alex Buynytskyyfcd5bf32021-11-23 11:31:34 -080025#include <shared_mutex>
Jeff Sharkey66b1a122017-01-16 20:57:45 -070026#include <unordered_map>
Alex Buynytskyyfcd5bf32021-11-23 11:31:34 -080027#include <vector>
Jeff Sharkey0274c972016-12-06 09:32:04 -070028
Jeff Sharkey88ddd942017-01-17 18:05:54 -070029#include <android-base/macros.h>
Jeff Sharkey0274c972016-12-06 09:32:04 -070030#include <binder/BinderService.h>
Andreas Gampe02d0de52015-11-11 20:43:16 -080031#include <cutils/multiuser.h>
32
Jeff Sharkey0274c972016-12-06 09:32:04 -070033#include "android/os/BnInstalld.h"
34#include "installd_constants.h"
Andreas Gampe02d0de52015-11-11 20:43:16 -080035
36namespace android {
37namespace installd {
38
Victor Hsiehc7ab5642023-07-28 15:07:55 -070039using IFsveritySetupAuthToken = android::os::IInstalld::IFsveritySetupAuthToken;
40
Jeff Sharkey0274c972016-12-06 09:32:04 -070041class InstalldNativeService : public BinderService<InstalldNativeService>, public os::BnInstalld {
42public:
Victor Hsiehc7ab5642023-07-28 15:07:55 -070043 class FsveritySetupAuthToken : public os::IInstalld::BnFsveritySetupAuthToken {
44 public:
45 FsveritySetupAuthToken() : mStatFromAuthFd() {}
46
Victor Hsieh93366142024-01-09 15:46:00 -080047 binder::Status authenticate(const android::os::ParcelFileDescriptor& authFd, int32_t uid);
Victor Hsiehc7ab5642023-07-28 15:07:55 -070048 bool isSameStat(const struct stat& st) const;
49
50 private:
51 // Not copyable or movable
52 FsveritySetupAuthToken(const FsveritySetupAuthToken&) = delete;
53 FsveritySetupAuthToken& operator=(const FsveritySetupAuthToken&) = delete;
54
55 struct stat mStatFromAuthFd;
56 };
57
Jeff Sharkey0274c972016-12-06 09:32:04 -070058 static status_t start();
59 static char const* getServiceName() { return "installd"; }
60 virtual status_t dump(int fd, const Vector<String16> &args) override;
Andreas Gamped089ca12016-06-27 14:25:30 -070061
Jooyung Han2d5878e2020-01-23 12:45:10 +090062 binder::Status createUserData(const std::optional<std::string>& uuid, int32_t userId,
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -070063 int32_t userSerial, int32_t flags);
Jooyung Han2d5878e2020-01-23 12:45:10 +090064 binder::Status destroyUserData(const std::optional<std::string>& uuid, int32_t userId,
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -070065 int32_t flags);
Jeff Sharkey8d3848b2020-08-13 14:16:46 -060066
Jooyung Han2d5878e2020-01-23 12:45:10 +090067 binder::Status createAppData(const std::optional<std::string>& uuid,
Samiul Islamc40dff52022-01-14 16:24:48 +000068 const std::string& packageName, int32_t userId, int32_t flags,
69 int32_t appId, int32_t previousAppId, const std::string& seInfo,
Songchun Fancb567f92023-09-11 17:04:47 +000070 int32_t targetSdkVersion, int64_t* ceDataInode,
71 int64_t* deDataInode);
Jeff Sharkey8d3848b2020-08-13 14:16:46 -060072
73 binder::Status createAppData(
74 const android::os::CreateAppDataArgs& args,
75 android::os::CreateAppDataResult* _aidl_return);
76 binder::Status createAppDataBatched(
77 const std::vector<android::os::CreateAppDataArgs>& args,
78 std::vector<android::os::CreateAppDataResult>* _aidl_return);
79
Samiul Islam92f5cf02022-02-03 12:45:51 +000080 binder::Status reconcileSdkData(const android::os::ReconcileSdkDataArgs& args);
81
Jooyung Han2d5878e2020-01-23 12:45:10 +090082 binder::Status restoreconAppData(const std::optional<std::string>& uuid,
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -070083 const std::string& packageName, int32_t userId, int32_t flags, int32_t appId,
84 const std::string& seInfo);
Mohammad Samiul Islame7634ba2022-03-07 20:27:30 +000085
Jooyung Han2d5878e2020-01-23 12:45:10 +090086 binder::Status migrateAppData(const std::optional<std::string>& uuid,
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -070087 const std::string& packageName, int32_t userId, int32_t flags);
Jooyung Han2d5878e2020-01-23 12:45:10 +090088 binder::Status clearAppData(const std::optional<std::string>& uuid,
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -070089 const std::string& packageName, int32_t userId, int32_t flags, int64_t ceDataInode);
Jooyung Han2d5878e2020-01-23 12:45:10 +090090 binder::Status destroyAppData(const std::optional<std::string>& uuid,
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -070091 const std::string& packageName, int32_t userId, int32_t flags, int64_t ceDataInode);
Jeff Sharkeydf2d7542017-01-07 09:19:35 -070092
Jooyung Han2d5878e2020-01-23 12:45:10 +090093 binder::Status fixupAppData(const std::optional<std::string>& uuid, int32_t flags);
Jeff Sharkeye12d5962017-04-03 16:41:02 -060094
Jooyung Han2d5878e2020-01-23 12:45:10 +090095 binder::Status snapshotAppData(const std::optional<std::string>& volumeUuid,
Nikita Ioffeb68f0d12019-02-04 11:06:37 +000096 const std::string& packageName, const int32_t user, const int32_t snapshotId,
97 int32_t storageFlags, int64_t* _aidl_return);
Jooyung Han2d5878e2020-01-23 12:45:10 +090098 binder::Status restoreAppDataSnapshot(const std::optional<std::string>& volumeUuid,
Nikita Ioffeb68f0d12019-02-04 11:06:37 +000099 const std::string& packageName, const int32_t appId, const std::string& seInfo,
100 const int32_t user, const int32_t snapshotId, int32_t storageFlags);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900101 binder::Status destroyAppDataSnapshot(const std::optional<std::string> &volumeUuid,
Nikita Ioffe77be2ed2019-01-25 13:54:43 +0000102 const std::string& packageName, const int32_t user, const int64_t ceSnapshotInode,
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000103 const int32_t snapshotId, int32_t storageFlags);
Oli Lan035abbb2020-03-16 18:18:41 +0000104 binder::Status destroyCeSnapshotsNotSpecified(const std::optional<std::string> &volumeUuid,
105 const int32_t user, const std::vector<int32_t>& retainSnapshotIds);
Narayan Kamathe63ca7d2019-01-14 15:21:52 +0000106
Jooyung Han2d5878e2020-01-23 12:45:10 +0900107 binder::Status getAppSize(const std::optional<std::string>& uuid,
Jeff Sharkeydf2d7542017-01-07 09:19:35 -0700108 const std::vector<std::string>& packageNames, int32_t userId, int32_t flags,
109 int32_t appId, const std::vector<int64_t>& ceDataInodes,
110 const std::vector<std::string>& codePaths, std::vector<int64_t>* _aidl_return);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900111 binder::Status getUserSize(const std::optional<std::string>& uuid,
Jeff Sharkeydf2d7542017-01-07 09:19:35 -0700112 int32_t userId, int32_t flags, const std::vector<int32_t>& appIds,
113 std::vector<int64_t>* _aidl_return);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900114 binder::Status getExternalSize(const std::optional<std::string>& uuid,
Jeff Sharkeya084fcd2017-04-17 16:44:41 -0600115 int32_t userId, int32_t flags, const std::vector<int32_t>& appIds,
116 std::vector<int64_t>* _aidl_return);
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -0700117
Jooyung Han2d5878e2020-01-23 12:45:10 +0900118 binder::Status getAppCrates(const std::optional<std::string>& uuid,
Felka Chang2a0a2462019-11-20 14:20:40 +0800119 const std::vector<std::string>& packageNames,
120 int32_t userId,
Jooyung Han2d5878e2020-01-23 12:45:10 +0900121 std::optional<std::vector<std::optional<android::os::storage::CrateMetadata>>>*
Felka Chang2a0a2462019-11-20 14:20:40 +0800122 _aidl_return);
123 binder::Status getUserCrates(
Jooyung Han2d5878e2020-01-23 12:45:10 +0900124 const std::optional<std::string>& uuid, int32_t userId,
125 std::optional<std::vector<std::optional<android::os::storage::CrateMetadata>>>*
Felka Chang2a0a2462019-11-20 14:20:40 +0800126 _aidl_return);
127
Jooyung Han2d5878e2020-01-23 12:45:10 +0900128 binder::Status setAppQuota(const std::optional<std::string>& uuid,
Jeff Sharkey88ddd942017-01-17 18:05:54 -0700129 int32_t userId, int32_t appId, int64_t cacheQuota);
130
Jooyung Han2d5878e2020-01-23 12:45:10 +0900131 binder::Status moveCompleteApp(const std::optional<std::string>& fromUuid,
132 const std::optional<std::string>& toUuid, const std::string& packageName,
Songchun Fandc2083f2020-02-18 17:45:46 -0800133 int32_t appId, const std::string& seInfo,
Songchun Fanaed33372020-02-05 12:02:22 -0800134 int32_t targetSdkVersion, const std::string& fromCodePath);
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700135
Alex Buynytskyy44036e22021-11-19 08:58:23 -0800136 binder::Status dexopt(const std::string& apkPath, int32_t uid, const std::string& packageName,
137 const std::string& instructionSet, int32_t dexoptNeeded,
138 const std::optional<std::string>& outputPath, int32_t dexFlags,
139 const std::string& compilerFilter, const std::optional<std::string>& uuid,
140 const std::optional<std::string>& classLoaderContext,
141 const std::optional<std::string>& seInfo, bool downgrade,
142 int32_t targetSdkVersion, const std::optional<std::string>& profileName,
143 const std::optional<std::string>& dexMetadataPath,
144 const std::optional<std::string>& compilationReason, bool* aidl_return);
Keun young Park65578d62021-06-28 17:52:05 -0700145
146 binder::Status controlDexOptBlocking(bool block);
Jeff Sharkey6c2c0562016-12-07 12:12:00 -0700147
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700148 binder::Status rmdex(const std::string& codePath, const std::string& instructionSet);
149
Calin Juravle562de812018-01-20 23:34:18 -0800150 binder::Status mergeProfiles(int32_t uid, const std::string& packageName,
Calin Juravlee90de862021-06-08 08:04:52 -0700151 const std::string& profileName, int* _aidl_return);
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700152 binder::Status dumpProfiles(int32_t uid, const std::string& packageName,
Martin Stjernholmfd000402022-04-11 18:04:59 +0100153 const std::string& profileName, const std::string& codePath,
154 bool dumpClassesAndMethods, bool* _aidl_return);
Mathieu Chartierf966f2a2017-05-10 12:48:37 -0700155 binder::Status copySystemProfile(const std::string& systemProfile,
Calin Juravle562de812018-01-20 23:34:18 -0800156 int32_t uid, const std::string& packageName, const std::string& profileName,
157 bool* _aidl_return);
158 binder::Status clearAppProfiles(const std::string& packageName, const std::string& profileName);
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700159 binder::Status destroyAppProfiles(const std::string& packageName);
Jiakai Zhangee00e3b2022-03-24 15:03:04 +0000160 binder::Status deleteReferenceProfile(const std::string& packageName,
161 const std::string& profileName);
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700162
Calin Juravlec41dac22017-12-05 12:29:15 -0800163 binder::Status createProfileSnapshot(int32_t appId, const std::string& packageName,
Calin Juravlee61189e2018-01-23 19:54:11 -0800164 const std::string& profileName, const std::string& classpath, bool* _aidl_return);
Calin Juravle29591732017-11-20 17:46:19 -0800165 binder::Status destroyProfileSnapshot(const std::string& packageName,
Calin Juravle562de812018-01-20 23:34:18 -0800166 const std::string& profileName);
Calin Juravle29591732017-11-20 17:46:19 -0800167
Alex Buynytskyy44036e22021-11-19 08:58:23 -0800168 binder::Status rmPackageDir(const std::string& packageName, const std::string& packageDir);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900169 binder::Status freeCache(const std::optional<std::string>& uuid, int64_t targetFreeBytes,
Neharika Jali0e542312021-10-25 06:41:24 +0000170 int32_t flags);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900171 binder::Status linkNativeLibraryDirectory(const std::optional<std::string>& uuid,
Jeff Sharkey6c2c0562016-12-07 12:12:00 -0700172 const std::string& packageName, const std::string& nativeLibPath32, int32_t userId);
Alex Buynytskyy44036e22021-11-19 08:58:23 -0800173 binder::Status createOatDir(const std::string& packageName, const std::string& oatDir,
174 const std::string& instructionSet);
175 binder::Status linkFile(const std::string& packageName, const std::string& relativePath,
176 const std::string& fromBase, const std::string& toBase);
177 binder::Status moveAb(const std::string& packageName, const std::string& apkPath,
178 const std::string& instructionSet, const std::string& outputPath);
179 binder::Status deleteOdex(const std::string& packageName, const std::string& apkPath,
180 const std::string& instructionSet,
181 const std::optional<std::string>& outputPath, int64_t* _aidl_return);
Calin Juravlebd968362017-01-25 01:17:17 -0800182 binder::Status reconcileSecondaryDexFile(const std::string& dexPath,
183 const std::string& packageName, int32_t uid, const std::vector<std::string>& isa,
Jooyung Han2d5878e2020-01-23 12:45:10 +0900184 const std::optional<std::string>& volumeUuid, int32_t storage_flag, bool* _aidl_return);
Alan Stokes753dc712017-10-16 10:56:00 +0100185 binder::Status hashSecondaryDexFile(const std::string& dexPath,
Jooyung Han2d5878e2020-01-23 12:45:10 +0900186 const std::string& packageName, int32_t uid, const std::optional<std::string>& volumeUuid,
Alan Stokes753dc712017-10-16 10:56:00 +0100187 int32_t storageFlag, std::vector<uint8_t>* _aidl_return);
Jeff Sharkey7a9059e2017-01-16 19:07:18 -0700188
Jeff Sharkey66b1a122017-01-16 20:57:45 -0700189 binder::Status invalidateMounts();
Shikha Malhotra976ae002022-02-26 15:39:53 +0000190 binder::Status setFirstBoot();
Jooyung Han2d5878e2020-01-23 12:45:10 +0900191 binder::Status isQuotaSupported(const std::optional<std::string>& volumeUuid,
Jeff Sharkey325b8c92017-02-21 10:00:53 -0700192 bool* _aidl_return);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900193 binder::Status tryMountDataMirror(const std::optional<std::string>& volumeUuid);
194 binder::Status onPrivateVolumeRemoved(const std::optional<std::string>& volumeUuid);
Jeff Sharkey66b1a122017-01-16 20:57:45 -0700195
Calin Juravlebc5ab872018-01-18 22:32:58 -0800196 binder::Status prepareAppProfile(const std::string& packageName,
197 int32_t userId, int32_t appId, const std::string& profileName,
Jooyung Han2d5878e2020-01-23 12:45:10 +0900198 const std::string& codePath, const std::optional<std::string>& dexMetadata,
Calin Juravlebc5ab872018-01-18 22:32:58 -0800199 bool* _aidl_return);
200
Narayan Kamath28ab93b2019-05-15 18:29:44 +0100201 binder::Status migrateLegacyObbData();
202
Alex Buynytskyy58a73092022-02-14 13:15:53 -0800203 binder::Status cleanupInvalidPackageDirs(const std::optional<std::string>& uuid, int32_t userId,
204 int32_t flags);
Alex Buynytskyy038a19b2022-02-09 19:51:52 -0800205
Jiakai Zhangf515a1b2022-02-23 18:33:26 +0000206 binder::Status getOdexVisibility(const std::string& packageName, const std::string& apkPath,
207 const std::string& instructionSet,
208 const std::optional<std::string>& outputPath,
209 int32_t* _aidl_return);
210
Victor Hsiehc7ab5642023-07-28 15:07:55 -0700211 binder::Status createFsveritySetupAuthToken(const android::os::ParcelFileDescriptor& authFd,
Victor Hsieh93366142024-01-09 15:46:00 -0800212 int32_t uid,
Victor Hsiehc7ab5642023-07-28 15:07:55 -0700213 android::sp<IFsveritySetupAuthToken>* _aidl_return);
214 binder::Status enableFsverity(const android::sp<IFsveritySetupAuthToken>& authToken,
215 const std::string& filePath, const std::string& packageName,
216 int32_t* _aidl_return);
217
Jeff Sharkey7a9059e2017-01-16 19:07:18 -0700218private:
219 std::recursive_mutex mLock;
Alex Buynytskyyfcd5bf32021-11-23 11:31:34 -0800220 std::unordered_map<userid_t, std::weak_ptr<std::shared_mutex>> mUserIdLock;
Alex Buynytskyy4fef8862021-11-21 16:09:33 -0800221 std::unordered_map<std::string, std::weak_ptr<std::recursive_mutex>> mPackageNameLock;
222
Jeff Sharkeyd712f0c2017-05-03 11:36:42 -0600223 std::recursive_mutex mMountsLock;
224 std::recursive_mutex mQuotasLock;
Jeff Sharkeyb26786d2017-03-11 19:40:29 -0700225
Jeff Sharkeyd712f0c2017-05-03 11:36:42 -0600226 /* Map of all storage mounts from source to target */
227 std::unordered_map<std::string, std::string> mStorageMounts;
Jeff Sharkeyd712f0c2017-05-03 11:36:42 -0600228
Jeff Sharkey88ddd942017-01-17 18:05:54 -0700229 /* Map from UID to cache quota size */
230 std::unordered_map<uid_t, int64_t> mCacheQuotas;
Jeff Sharkey66b1a122017-01-16 20:57:45 -0700231
Jooyung Han2d5878e2020-01-23 12:45:10 +0900232 std::string findDataMediaPath(const std::optional<std::string>& uuid, userid_t userid);
Samiul Islamc40dff52022-01-14 16:24:48 +0000233
234 binder::Status createAppDataLocked(const std::optional<std::string>& uuid,
235 const std::string& packageName, int32_t userId,
236 int32_t flags, int32_t appId, int32_t previousAppId,
237 const std::string& seInfo, int32_t targetSdkVersion,
Songchun Fancb567f92023-09-11 17:04:47 +0000238 int64_t* ceDataInode, int64_t* deDataInode);
Mohammad Samiul Islame7634ba2022-03-07 20:27:30 +0000239 binder::Status restoreconAppDataLocked(const std::optional<std::string>& uuid,
240 const std::string& packageName, int32_t userId,
241 int32_t flags, int32_t appId, const std::string& seInfo);
Samiul Islamc40dff52022-01-14 16:24:48 +0000242
Rishabh Singhe84b0b12022-02-02 20:56:13 +0000243 binder::Status createSdkSandboxDataPackageDirectory(const std::optional<std::string>& uuid,
244 const std::string& packageName,
245 int32_t userId, int32_t appId,
Mohammad Samiul Islam5288b052022-03-09 17:04:38 +0000246 int32_t flags);
Rishabh Singhe84b0b12022-02-02 20:56:13 +0000247 binder::Status clearSdkSandboxDataPackageDirectory(const std::optional<std::string>& uuid,
248 const std::string& packageName,
249 int32_t userId, int32_t flags);
250 binder::Status destroySdkSandboxDataPackageDirectory(const std::optional<std::string>& uuid,
251 const std::string& packageName,
252 int32_t userId, int32_t flags);
Mohammad Samiul Islame7634ba2022-03-07 20:27:30 +0000253 binder::Status reconcileSdkData(const std::optional<std::string>& uuid,
254 const std::string& packageName,
Mohammad Samiul Islam5288b052022-03-09 17:04:38 +0000255 const std::vector<std::string>& subDirNames, int32_t userId,
Mohammad Samiul Islame7634ba2022-03-07 20:27:30 +0000256 int32_t appId, int32_t previousAppId, const std::string& seInfo,
257 int flags);
258 binder::Status restoreconSdkDataLocked(const std::optional<std::string>& uuid,
259 const std::string& packageName, int32_t userId,
260 int32_t flags, int32_t appId, const std::string& seInfo);
Jeff Sharkey0274c972016-12-06 09:32:04 -0700261};
262
Andreas Gampe02d0de52015-11-11 20:43:16 -0800263} // namespace installd
264} // namespace android
265
266#endif // COMMANDS_H_