1 /*
2  * Copyright (c) 2021-2024 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #ifndef FOUNDATION_APPEXECFWK_SERVICES_BUNDLEMGR_INCLUDE_INSTALLD_HOST_IMPL_H
17 #define FOUNDATION_APPEXECFWK_SERVICES_BUNDLEMGR_INCLUDE_INSTALLD_HOST_IMPL_H
18 
19 #include "bundle_constants.h"
20 #include "code_sign_helper.h"
21 #include "ipc/installd_host.h"
22 #include "installd/installd_operator.h"
23 #include "nlohmann/json.hpp"
24 
25 namespace OHOS {
26 namespace AppExecFwk {
27 class InstalldHostImpl : public InstalldHost {
28 public:
29     InstalldHostImpl();
30     virtual ~InstalldHostImpl();
31     /**
32      * @brief Create a bundle code directory.
33      * @param bundleDir Indicates the bundle code directory path that to be created.
34      * @return Returns ERR_OK if the bundle directory created successfully; returns error code otherwise.
35      */
36     virtual ErrCode CreateBundleDir(const std::string &bundleDir) override;
37     /**
38      * @brief Extract the files of a HAP module to the code directory.
39      * @param srcModulePath Indicates the HAP file path.
40      * @param targetPath normal files decompression path.
41      * @param targetSoPath so files decompression path.
42      * @param cpuAbi cpuAbi.
43      * @return Returns ERR_OK if the HAP file extracted successfully; returns error code otherwise.
44      */
45     virtual ErrCode ExtractModuleFiles(const std::string &srcModulePath, const std::string &targetPath,
46         const std::string &targetSoPath, const std::string &cpuAbi) override;
47     /**
48      * @brief Extract the files.
49      * @param extractParam Indicates the extractParam.
50      * @return Returns ERR_OK if the HAP file extracted successfully; returns error code otherwise.
51      */
52     virtual ErrCode ExtractFiles(const ExtractParam &extractParam) override;
53 
54     /**
55      * @brief Extract the hnpFiles.
56      * @param hnpPackageInfo Indicates the hnpPackageInfo.
57      * @param extractParam Indicates the extractParam.
58      * @return Returns ERR_OK if the HAP file extracted successfully; returns error code otherwise.
59      */
60     virtual ErrCode ExtractHnpFiles(const std::string &hnpPackageInfo, const ExtractParam &extractParam) override;
61 
62     virtual ErrCode ProcessBundleInstallNative(const std::string &userId, const std::string &hnpRootPath,
63         const std::string &hapPath, const std::string &cpuAbi, const std::string &packageName) override;
64 
65     virtual ErrCode ProcessBundleUnInstallNative(const std::string &userId, const std::string &bundleName) override;
66 
67     virtual ErrCode ExecuteAOT(const AOTArgs &aotArgs, std::vector<uint8_t> &pendSignData) override;
68 
69     virtual ErrCode PendSignAOT(const std::string &anFileName, const std::vector<uint8_t> &signData) override;
70 
71     virtual ErrCode StopAOT() override;
72 
73     virtual ErrCode DeleteUninstallTmpDirs(const std::vector<std::string> &dirs) override;
74     /**
75      * @brief Rename the module directory from temporaily path to the real path.
76      * @param oldPath Indicates the old path name.
77      * @param newPath Indicates the new path name.
78      * @return Returns ERR_OK if the module directory renamed successfully; returns error code otherwise.
79      */
80     virtual ErrCode RenameModuleDir(const std::string &oldPath, const std::string &newPath) override;
81     /**
82      * @brief Create a bundle data directory.
83      * @param createDirParam Indicates param to be set to the directory.
84      * @return Returns ERR_OK if the bundle data directory created successfully; returns error code otherwise.
85      */
86     virtual ErrCode CreateBundleDataDir(const CreateDirParam &createDirParam) override;
87 
88     virtual ErrCode CreateBundleDataDirWithVector(const std::vector<CreateDirParam> &createDirParams) override;
89     /**
90      * @brief Remove a bundle data directory.
91      * @param bundleName Indicates the bundleName data directory path that to be created.
92      * @param userid Indicates userid to be set to the directory.
93      * @return Returns ERR_OK if the bundle data directory created successfully; returns error code otherwise.
94      */
95     virtual ErrCode RemoveBundleDataDir(const std::string &bundleName, const int32_t userId,
96         bool isAtomicService = false, const bool async = false) override;
97     /**
98      * @brief Remove a module data directory.
99      * @param ModuleDir Indicates the module data directory path that to be created.
100      * @param userid Indicates userid to be set to the directory.
101      * @return Returns ERR_OK if the data directories created successfully; returns error code otherwise.
102      */
103     virtual ErrCode RemoveModuleDataDir(const std::string &ModuleDir, const int userid) override;
104     /**
105      * @brief Remove a directory.
106      * @param dir Indicates the directory path that to be removed.
107      * @return Returns ERR_OK if the  directory removed successfully; returns error code otherwise.
108      */
109     virtual ErrCode RemoveDir(const std::string &dir) override;
110     /**
111      * @brief Get disk usage for dir.
112      * @param dir Indicates the directory.
113      * @param isRealPath Indicates isRealPath.
114      * @return Returns true if successfully; returns false otherwise.
115      */
116     virtual int64_t GetDiskUsage(const std::string &dir, bool isRealPath = false) override;
117     /**
118      * @brief Clean all files in a bundle data directory.
119      * @param bundleDir Indicates the data directory path that to be cleaned.
120      * @return Returns ERR_OK if the data directory cleaned successfully; returns error code otherwise.
121      */
122     virtual ErrCode CleanBundleDataDir(const std::string &bundleDir) override;
123     /**
124      * @brief Clean a bundle data directory.
125      * @param bundleName Indicates the bundleName data directory path that to be cleaned.
126      * @param userid Indicates userid to be set to the directory.
127      * @param appIndex Indicates app index to be set to the directory.
128      * @return Returns ERR_OK if the bundle data directory cleaned successfully; returns error code otherwise.
129      */
130     virtual ErrCode CleanBundleDataDirByName(const std::string &bundleName, const int userid,
131         const int appIndex = 0) override;
132     /**
133      * @brief Get bundle Stats.
134      * @param bundleName Indicates the bundle name.
135      * @param userId Indicates the user Id.
136      * @param bundleStats Indicates the bundle Stats.
137      * @return Returns ERR_OK if get stats successfully; returns error code otherwise.
138      */
139     virtual ErrCode GetBundleStats(const std::string &bundleName, const int32_t userId,
140         std::vector<int64_t> &bundleStats, const int32_t uid = Constants::INVALID_UID,
141         const int32_t appIndex = 0, const uint32_t statFlag = 0,
142         const std::vector<std::string> &moduleNameList = {}) override;
143 
144     virtual ErrCode GetAllBundleStats(const int32_t userId,
145         std::vector<int64_t> &bundleStats, const std::vector<int32_t> &uids) override;
146     /**
147      * @brief Set dir apl.
148      * @param dir Indicates the data dir.
149      * @param bundleName Indicates the bundle name.
150      * @param apl Indicates the apl type.
151      * @param isPreInstallApp Indicates the bundle install type.
152      * @param debug Indicates the bundle debug mode.
153      * @return Returns ERR_OK if set apl successfully; returns error code otherwise.
154      */
155     virtual ErrCode SetDirApl(const std::string &dir, const std::string &bundleName, const std::string &apl,
156         bool isPreInstallApp, bool debug) override;
157 
158     /**
159      * @brief Get all cache file path.
160      * @param dir Indicates the data dir.
161      * @param cachesPath Indicates the cache file path.
162      * @return Returns ERR_OK if get cache file path successfully; returns error code otherwise.
163      */
164     virtual ErrCode GetBundleCachePath(const std::string &dir, std::vector<std::string> &cachePath) override;
165 
166     virtual ErrCode ScanDir(
167         const std::string &dir, ScanMode scanMode, ResultMode resultMode, std::vector<std::string> &paths) override;
168 
169     virtual ErrCode MoveFile(const std::string &oldPath, const std::string &newPath) override;
170 
171     virtual ErrCode CopyFile(const std::string &oldPath, const std::string &newPath,
172         const std::string &signatureFilePath = "") override;
173 
174     virtual ErrCode Mkdir(
175         const std::string &dir, const int32_t mode, const int32_t uid, const int32_t gid) override;
176 
177     virtual ErrCode GetFileStat(const std::string &file, FileStat &fileStat) override;
178 
179     virtual ErrCode ExtractDiffFiles(const std::string &filePath, const std::string &targetPath,
180         const std::string &cpuAbi) override;
181 
182     virtual ErrCode ApplyDiffPatch(const std::string &oldSoPath, const std::string &diffFilePath,
183         const std::string &newSoPath, int32_t uid) override;
184 
185     virtual ErrCode IsExistDir(const std::string &dir, bool &isExist) override;
186 
187     virtual ErrCode IsExistFile(const std::string &path, bool &isExist) override;
188 
189     virtual ErrCode IsExistApFile(const std::string &path, bool &isExist) override;
190 
191     virtual ErrCode IsDirEmpty(const std::string &dir, bool &isDirEmpty) override;
192 
193     virtual ErrCode ObtainQuickFixFileDir(const std::string &dir, std::vector<std::string> &dirVec) override;
194 
195     virtual ErrCode CopyFiles(const std::string &sourceDir, const std::string &destinationDir) override;
196 
197     virtual ErrCode GetNativeLibraryFileNames(const std::string &filePath, const std::string &cpuAbi,
198         std::vector<std::string> &fileNames) override;
199 
200     virtual ErrCode VerifyCodeSignature(const CodeSignatureParam &codeSignatureParam) override;
201 
202     virtual ErrCode CheckEncryption(const CheckEncryptionParam &checkEncryptionParam, bool &isEncryption) override;
203 
204     virtual ErrCode MoveFiles(const std::string &srcDir, const std::string &desDir) override;
205 
206     virtual ErrCode ExtractDriverSoFiles(const std::string &srcPath,
207         const std::unordered_multimap<std::string, std::string> &dirMap) override;
208 
209     virtual ErrCode ExtractEncryptedSoFiles(const std::string &hapPath, const std::string &realSoFilesPath,
210         const std::string &cpuAbi, const std::string &tmpSoPath, int32_t uid) override;
211 
212 #if defined(CODE_SIGNATURE_ENABLE)
213     ErrCode PrepareEntryMap(const CodeSignatureParam &codeSignatureParam, Security::CodeSign::EntryMap &entryMap);
214 #endif
215 
216     virtual ErrCode VerifyCodeSignatureForHap(const CodeSignatureParam &codeSignatureParam) override;
217 
218     virtual ErrCode DeliverySignProfile(const std::string &bundleName, int32_t profileBlockLength,
219         const unsigned char *profileBlock) override;
220 
221     virtual ErrCode RemoveSignProfile(const std::string &bundleName) override;
222 
223     virtual ErrCode SetEncryptionPolicy(int32_t uid, const std::string &bundleName,
224         const int32_t userId, std::string &keyId) override;
225 
226     virtual ErrCode DeleteEncryptionKeyId(const std::string &bundleName, const int32_t userId) override;
227 
228     virtual ErrCode RemoveExtensionDir(int32_t userId, const std::vector<std::string> &extensionBundleDirs) override;
229 
230     virtual ErrCode IsExistExtensionDir(int32_t userId, const std::string &extensionBundleDir, bool &isExist) override;
231 
232     virtual ErrCode CreateExtensionDataDir(const CreateDirParam &createDirParam) override;
233 
234     virtual ErrCode GetExtensionSandboxTypeList(std::vector<std::string> &typeList) override;
235 
236     virtual ErrCode MoveHapToCodeDir(const std::string &originPath, const std::string &targetPath) override;
237 
238 private:
239     std::string GetAppDataPath(const std::string &bundleName, const std::string &el,
240         const int32_t userId, const int32_t appIndex);
241     int64_t HandleAppDataSizeStats(const std::string &bundleName, const int32_t userId, const int32_t appIndex);
242     std::string GetExtensionConfigPath() const;
243     void LoadNeedCreateSandbox(const nlohmann::json &object, std::vector<std::string> &typeList);
244     bool LoadExtensionNeedCreateSandbox(const nlohmann::json &object, std::string extensionTypeName);
245     bool ReadFileIntoJson(const std::string &filePath, nlohmann::json &jsonBuf);
246     ErrCode CreateExtensionDir(const CreateDirParam &createDirParam, const std::string& parentDir,
247         int32_t mode, int32_t gid, bool isLog = false);
248     ErrCode RemoveExtensionDir(int32_t userId, const std::string &extensionBundleDir);
249     std::string GetBundleDataDir(const std::string &el, const int userid) const;
250     bool CheckPathValid(const std::string &path, const std::string &prefix);
251     ErrCode SetDirApl(const std::string &dir, const std::string &bundleName, const std::string &apl,
252         unsigned int hapFlags);
253     unsigned int GetHapFlags(const bool isPreInstallApp, const bool debug, const bool isDlpSandbox);
254     ErrCode InnerRemoveAtomicServiceBundleDataDir(
255         const std::string &bundleName, const int32_t userId, const bool async);
256     ErrCode InnerRemoveBundleDataDir(const std::string &bundleName, const int32_t userId, const bool async);
257     ErrCode AclSetDir(bool debug, const std::string &dir, bool setAccess, bool setDefault);
258     ErrCode AclSetExtensionDirs(bool debug, const std::string &parentDir,
259         const std::vector<std::string> &extensionDirs, bool setAccess, bool setDefault);
260     int64_t GetAppCacheSize(const std::string &bundleName, const int32_t userId,
261         const int32_t appIndex, const std::vector<std::string> &moduleNames = {});
262 };
263 }  // namespace AppExecFwk
264 }  // namespace OHOS
265 #endif  // FOUNDATION_APPEXECFWK_SERVICES_BUNDLEMGR_INCLUDE_INSTALLD_HOST_IMPL_H