blob: 0f2823442235c924139ebba6ba583cee7bb4d290 [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
47 binder::Status authenticate(const android::os::ParcelFileDescriptor& authFd, int32_t appUid,
48 int32_t userId);
49 bool isSameStat(const struct stat& st) const;
50
51 private:
52 // Not copyable or movable
53 FsveritySetupAuthToken(const FsveritySetupAuthToken&) = delete;
54 FsveritySetupAuthToken& operator=(const FsveritySetupAuthToken&) = delete;
55
56 struct stat mStatFromAuthFd;
57 };
58
Jeff Sharkey0274c972016-12-06 09:32:04 -070059 static status_t start();
60 static char const* getServiceName() { return "installd"; }
61 virtual status_t dump(int fd, const Vector<String16> &args) override;
Andreas Gamped089ca12016-06-27 14:25:30 -070062
Jooyung Han2d5878e2020-01-23 12:45:10 +090063 binder::Status createUserData(const std::optional<std::string>& uuid, int32_t userId,
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -070064 int32_t userSerial, int32_t flags);
Jooyung Han2d5878e2020-01-23 12:45:10 +090065 binder::Status destroyUserData(const std::optional<std::string>& uuid, int32_t userId,
Jeff Sharkeyc1e93e72016-12-05 23:39:32 -070066 int32_t flags);
Jeff Sharkey8d3848b2020-08-13 14:16:46 -060067
Jooyung Han2d5878e2020-01-23 12:45:10 +090068 binder::Status createAppData(const std::optional<std::string>& uuid,
Samiul Islamc40dff52022-01-14 16:24:48 +000069 const std::string& packageName, int32_t userId, int32_t flags,
70 int32_t appId, int32_t previousAppId, const std::string& seInfo,
71 int32_t targetSdkVersion, int64_t* _aidl_return);
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
Eric Holk0ebbe0f2019-01-09 18:17:27 -0800148 binder::Status compileLayouts(const std::string& apkPath, const std::string& packageName,
149 const std::string& outDexFile, int uid, bool* _aidl_return);
150
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700151 binder::Status rmdex(const std::string& codePath, const std::string& instructionSet);
152
Calin Juravle562de812018-01-20 23:34:18 -0800153 binder::Status mergeProfiles(int32_t uid, const std::string& packageName,
Calin Juravlee90de862021-06-08 08:04:52 -0700154 const std::string& profileName, int* _aidl_return);
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700155 binder::Status dumpProfiles(int32_t uid, const std::string& packageName,
Martin Stjernholmfd000402022-04-11 18:04:59 +0100156 const std::string& profileName, const std::string& codePath,
157 bool dumpClassesAndMethods, bool* _aidl_return);
Mathieu Chartierf966f2a2017-05-10 12:48:37 -0700158 binder::Status copySystemProfile(const std::string& systemProfile,
Calin Juravle562de812018-01-20 23:34:18 -0800159 int32_t uid, const std::string& packageName, const std::string& profileName,
160 bool* _aidl_return);
161 binder::Status clearAppProfiles(const std::string& packageName, const std::string& profileName);
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700162 binder::Status destroyAppProfiles(const std::string& packageName);
Jiakai Zhangee00e3b2022-03-24 15:03:04 +0000163 binder::Status deleteReferenceProfile(const std::string& packageName,
164 const std::string& profileName);
Jeff Sharkey475c6f92016-12-07 10:37:27 -0700165
Calin Juravlec41dac22017-12-05 12:29:15 -0800166 binder::Status createProfileSnapshot(int32_t appId, const std::string& packageName,
Calin Juravlee61189e2018-01-23 19:54:11 -0800167 const std::string& profileName, const std::string& classpath, bool* _aidl_return);
Calin Juravle29591732017-11-20 17:46:19 -0800168 binder::Status destroyProfileSnapshot(const std::string& packageName,
Calin Juravle562de812018-01-20 23:34:18 -0800169 const std::string& profileName);
Calin Juravle29591732017-11-20 17:46:19 -0800170
Alex Buynytskyy44036e22021-11-19 08:58:23 -0800171 binder::Status rmPackageDir(const std::string& packageName, const std::string& packageDir);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900172 binder::Status freeCache(const std::optional<std::string>& uuid, int64_t targetFreeBytes,
Neharika Jali0e542312021-10-25 06:41:24 +0000173 int32_t flags);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900174 binder::Status linkNativeLibraryDirectory(const std::optional<std::string>& uuid,
Jeff Sharkey6c2c0562016-12-07 12:12:00 -0700175 const std::string& packageName, const std::string& nativeLibPath32, int32_t userId);
Alex Buynytskyy44036e22021-11-19 08:58:23 -0800176 binder::Status createOatDir(const std::string& packageName, const std::string& oatDir,
177 const std::string& instructionSet);
178 binder::Status linkFile(const std::string& packageName, const std::string& relativePath,
179 const std::string& fromBase, const std::string& toBase);
180 binder::Status moveAb(const std::string& packageName, const std::string& apkPath,
181 const std::string& instructionSet, const std::string& outputPath);
182 binder::Status deleteOdex(const std::string& packageName, const std::string& apkPath,
183 const std::string& instructionSet,
184 const std::optional<std::string>& outputPath, int64_t* _aidl_return);
Calin Juravlebd968362017-01-25 01:17:17 -0800185 binder::Status reconcileSecondaryDexFile(const std::string& dexPath,
186 const std::string& packageName, int32_t uid, const std::vector<std::string>& isa,
Jooyung Han2d5878e2020-01-23 12:45:10 +0900187 const std::optional<std::string>& volumeUuid, int32_t storage_flag, bool* _aidl_return);
Alan Stokes753dc712017-10-16 10:56:00 +0100188 binder::Status hashSecondaryDexFile(const std::string& dexPath,
Jooyung Han2d5878e2020-01-23 12:45:10 +0900189 const std::string& packageName, int32_t uid, const std::optional<std::string>& volumeUuid,
Alan Stokes753dc712017-10-16 10:56:00 +0100190 int32_t storageFlag, std::vector<uint8_t>* _aidl_return);
Jeff Sharkey7a9059e2017-01-16 19:07:18 -0700191
Jeff Sharkey66b1a122017-01-16 20:57:45 -0700192 binder::Status invalidateMounts();
Shikha Malhotra976ae002022-02-26 15:39:53 +0000193 binder::Status setFirstBoot();
Jooyung Han2d5878e2020-01-23 12:45:10 +0900194 binder::Status isQuotaSupported(const std::optional<std::string>& volumeUuid,
Jeff Sharkey325b8c92017-02-21 10:00:53 -0700195 bool* _aidl_return);
Jooyung Han2d5878e2020-01-23 12:45:10 +0900196 binder::Status tryMountDataMirror(const std::optional<std::string>& volumeUuid);
197 binder::Status onPrivateVolumeRemoved(const std::optional<std::string>& volumeUuid);
Jeff Sharkey66b1a122017-01-16 20:57:45 -0700198
Calin Juravlebc5ab872018-01-18 22:32:58 -0800199 binder::Status prepareAppProfile(const std::string& packageName,
200 int32_t userId, int32_t appId, const std::string& profileName,
Jooyung Han2d5878e2020-01-23 12:45:10 +0900201 const std::string& codePath, const std::optional<std::string>& dexMetadata,
Calin Juravlebc5ab872018-01-18 22:32:58 -0800202 bool* _aidl_return);
203
Narayan Kamath28ab93b2019-05-15 18:29:44 +0100204 binder::Status migrateLegacyObbData();
205
Alex Buynytskyy58a73092022-02-14 13:15:53 -0800206 binder::Status cleanupInvalidPackageDirs(const std::optional<std::string>& uuid, int32_t userId,
207 int32_t flags);
Alex Buynytskyy038a19b2022-02-09 19:51:52 -0800208
Jiakai Zhangf515a1b2022-02-23 18:33:26 +0000209 binder::Status getOdexVisibility(const std::string& packageName, const std::string& apkPath,
210 const std::string& instructionSet,
211 const std::optional<std::string>& outputPath,
212 int32_t* _aidl_return);
213
Victor Hsiehc7ab5642023-07-28 15:07:55 -0700214 binder::Status createFsveritySetupAuthToken(const android::os::ParcelFileDescriptor& authFd,
215 int32_t appUid, int32_t userId,
216 android::sp<IFsveritySetupAuthToken>* _aidl_return);
217 binder::Status enableFsverity(const android::sp<IFsveritySetupAuthToken>& authToken,
218 const std::string& filePath, const std::string& packageName,
219 int32_t* _aidl_return);
220
Jeff Sharkey7a9059e2017-01-16 19:07:18 -0700221private:
222 std::recursive_mutex mLock;
Alex Buynytskyyfcd5bf32021-11-23 11:31:34 -0800223 std::unordered_map<userid_t, std::weak_ptr<std::shared_mutex>> mUserIdLock;
Alex Buynytskyy4fef8862021-11-21 16:09:33 -0800224 std::unordered_map<std::string, std::weak_ptr<std::recursive_mutex>> mPackageNameLock;
225
Jeff Sharkeyd712f0c2017-05-03 11:36:42 -0600226 std::recursive_mutex mMountsLock;
227 std::recursive_mutex mQuotasLock;
Jeff Sharkeyb26786d2017-03-11 19:40:29 -0700228
Jeff Sharkeyd712f0c2017-05-03 11:36:42 -0600229 /* Map of all storage mounts from source to target */
230 std::unordered_map<std::string, std::string> mStorageMounts;
Jeff Sharkeyd712f0c2017-05-03 11:36:42 -0600231
Jeff Sharkey88ddd942017-01-17 18:05:54 -0700232 /* Map from UID to cache quota size */
233 std::unordered_map<uid_t, int64_t> mCacheQuotas;
Jeff Sharkey66b1a122017-01-16 20:57:45 -0700234
Jooyung Han2d5878e2020-01-23 12:45:10 +0900235 std::string findDataMediaPath(const std::optional<std::string>& uuid, userid_t userid);
Samiul Islamc40dff52022-01-14 16:24:48 +0000236
237 binder::Status createAppDataLocked(const std::optional<std::string>& uuid,
238 const std::string& packageName, int32_t userId,
239 int32_t flags, int32_t appId, int32_t previousAppId,
240 const std::string& seInfo, int32_t targetSdkVersion,
241 int64_t* _aidl_return);
Mohammad Samiul Islame7634ba2022-03-07 20:27:30 +0000242 binder::Status restoreconAppDataLocked(const std::optional<std::string>& uuid,
243 const std::string& packageName, int32_t userId,
244 int32_t flags, int32_t appId, const std::string& seInfo);
Samiul Islamc40dff52022-01-14 16:24:48 +0000245
Rishabh Singhe84b0b12022-02-02 20:56:13 +0000246 binder::Status createSdkSandboxDataPackageDirectory(const std::optional<std::string>& uuid,
247 const std::string& packageName,
248 int32_t userId, int32_t appId,
Mohammad Samiul Islam5288b052022-03-09 17:04:38 +0000249 int32_t flags);
Rishabh Singhe84b0b12022-02-02 20:56:13 +0000250 binder::Status clearSdkSandboxDataPackageDirectory(const std::optional<std::string>& uuid,
251 const std::string& packageName,
252 int32_t userId, int32_t flags);
253 binder::Status destroySdkSandboxDataPackageDirectory(const std::optional<std::string>& uuid,
254 const std::string& packageName,
255 int32_t userId, int32_t flags);
Mohammad Samiul Islame7634ba2022-03-07 20:27:30 +0000256 binder::Status reconcileSdkData(const std::optional<std::string>& uuid,
257 const std::string& packageName,
Mohammad Samiul Islam5288b052022-03-09 17:04:38 +0000258 const std::vector<std::string>& subDirNames, int32_t userId,
Mohammad Samiul Islame7634ba2022-03-07 20:27:30 +0000259 int32_t appId, int32_t previousAppId, const std::string& seInfo,
260 int flags);
261 binder::Status restoreconSdkDataLocked(const std::optional<std::string>& uuid,
262 const std::string& packageName, int32_t userId,
263 int32_t flags, int32_t appId, const std::string& seInfo);
Jeff Sharkey0274c972016-12-06 09:32:04 -0700264};
265
Andreas Gampe02d0de52015-11-11 20:43:16 -0800266} // namespace installd
267} // namespace android
268
269#endif // COMMANDS_H_