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      * @brief Rename the module directory from temporaily path to the real path.
74      * @param oldPath Indicates the old path name.
75      * @param newPath Indicates the new path name.
76      * @return Returns ERR_OK if the module directory renamed successfully; returns error code otherwise.
77      */
78     virtual ErrCode RenameModuleDir(const std::string &oldPath, const std::string &newPath) override;
79     /**
80      * @brief Create a bundle data directory.
81      * @param createDirParam Indicates param to be set to the directory.
82      * @return Returns ERR_OK if the bundle data directory created successfully; returns error code otherwise.
83      */
84     virtual ErrCode CreateBundleDataDir(const CreateDirParam &createDirParam) override;
85 
86     virtual ErrCode CreateBundleDataDirWithVector(const std::vector<CreateDirParam> &createDirParams) override;
87     /**
88      * @brief Remove a bundle data directory.
89      * @param bundleName Indicates the bundleName data directory path that to be created.
90      * @param userid Indicates userid to be set to the directory.
91      * @return Returns ERR_OK if the bundle data directory created successfully; returns error code otherwise.
92      */
93     virtual ErrCode RemoveBundleDataDir(
94         const std::string &bundleName, const int32_t userId, bool isAtomicService = false) override;
95     /**
96      * @brief Remove a module data directory.
97      * @param ModuleDir Indicates the module data directory path that to be created.
98      * @param userid Indicates userid to be set to the directory.
99      * @return Returns ERR_OK if the data directories created successfully; returns error code otherwise.
100      */
101     virtual ErrCode RemoveModuleDataDir(const std::string &ModuleDir, const int userid) override;
102     /**
103      * @brief Remove a directory.
104      * @param dir Indicates the directory path that to be removed.
105      * @return Returns ERR_OK if the  directory removed successfully; returns error code otherwise.
106      */
107     virtual ErrCode RemoveDir(const std::string &dir) override;
108     /**
109      * @brief Get disk usage for dir.
110      * @param dir Indicates the directory.
111      * @param isRealPath Indicates isRealPath.
112      * @return Returns true if successfully; returns false otherwise.
113      */
114     virtual int64_t GetDiskUsage(const std::string &dir, bool isRealPath = false) override;
115     /**
116      * @brief Clean all files in a bundle data directory.
117      * @param bundleDir Indicates the data directory path that to be cleaned.
118      * @return Returns ERR_OK if the data directory cleaned successfully; returns error code otherwise.
119      */
120     virtual ErrCode CleanBundleDataDir(const std::string &bundleDir) override;
121     /**
122      * @brief Clean a bundle data directory.
123      * @param bundleName Indicates the bundleName data directory path that to be cleaned.
124      * @param userid Indicates userid to be set to the directory.
125      * @param appIndex Indicates app index to be set to the directory.
126      * @return Returns ERR_OK if the bundle data directory cleaned successfully; returns error code otherwise.
127      */
128     virtual ErrCode CleanBundleDataDirByName(const std::string &bundleName, const int userid,
129         const int appIndex = 0) override;
130     /**
131      * @brief Get bundle Stats.
132      * @param bundleName Indicates the bundle name.
133      * @param userId Indicates the user Id.
134      * @param bundleStats Indicates the bundle Stats.
135      * @return Returns ERR_OK if get stats successfully; returns error code otherwise.
136      */
137     virtual ErrCode GetBundleStats(const std::string &bundleName, const int32_t userId,
138         std::vector<int64_t> &bundleStats, const int32_t uid = Constants::INVALID_UID,
139         const int32_t appIndex = 0) override;
140 
141     virtual ErrCode GetAllBundleStats(const int32_t userId,
142         std::vector<int64_t> &bundleStats, const std::vector<int32_t> &uids) override;
143     /**
144      * @brief Set dir apl.
145      * @param dir Indicates the data dir.
146      * @param bundleName Indicates the bundle name.
147      * @param apl Indicates the apl type.
148      * @param isPreInstallApp Indicates the bundle install type.
149      * @param debug Indicates the bundle debug mode.
150      * @return Returns ERR_OK if set apl successfully; returns error code otherwise.
151      */
152     virtual ErrCode SetDirApl(const std::string &dir, const std::string &bundleName, const std::string &apl,
153         bool isPreInstallApp, bool debug) override;
154 
155     /**
156      * @brief Get all cache file path.
157      * @param dir Indicates the data dir.
158      * @param cachesPath Indicates the cache file path.
159      * @return Returns ERR_OK if get cache file path successfully; returns error code otherwise.
160      */
161     virtual ErrCode GetBundleCachePath(const std::string &dir, std::vector<std::string> &cachePath) override;
162 
163     virtual ErrCode ScanDir(
164         const std::string &dir, ScanMode scanMode, ResultMode resultMode, std::vector<std::string> &paths) override;
165 
166     virtual ErrCode MoveFile(const std::string &oldPath, const std::string &newPath) override;
167 
168     virtual ErrCode CopyFile(const std::string &oldPath, const std::string &newPath,
169         const std::string &signatureFilePath = "") override;
170 
171     virtual ErrCode Mkdir(
172         const std::string &dir, const int32_t mode, const int32_t uid, const int32_t gid) override;
173 
174     virtual ErrCode GetFileStat(const std::string &file, FileStat &fileStat) override;
175 
176     virtual ErrCode ExtractDiffFiles(const std::string &filePath, const std::string &targetPath,
177         const std::string &cpuAbi) override;
178 
179     virtual ErrCode ApplyDiffPatch(const std::string &oldSoPath, const std::string &diffFilePath,
180         const std::string &newSoPath, int32_t uid) override;
181 
182     virtual ErrCode IsExistDir(const std::string &dir, bool &isExist) override;
183 
184     virtual ErrCode IsExistFile(const std::string &path, bool &isExist) override;
185 
186     virtual ErrCode IsExistApFile(const std::string &path, bool &isExist) override;
187 
188     virtual ErrCode IsDirEmpty(const std::string &dir, bool &isDirEmpty) override;
189 
190     virtual ErrCode ObtainQuickFixFileDir(const std::string &dir, std::vector<std::string> &dirVec) override;
191 
192     virtual ErrCode CopyFiles(const std::string &sourceDir, const std::string &destinationDir) override;
193 
194     virtual ErrCode GetNativeLibraryFileNames(const std::string &filePath, const std::string &cpuAbi,
195         std::vector<std::string> &fileNames) override;
196 
197     virtual ErrCode VerifyCodeSignature(const CodeSignatureParam &codeSignatureParam) override;
198 
199     virtual ErrCode CheckEncryption(const CheckEncryptionParam &checkEncryptionParam, bool &isEncryption) override;
200 
201     virtual ErrCode MoveFiles(const std::string &srcDir, const std::string &desDir) override;
202 
203     virtual ErrCode ExtractDriverSoFiles(const std::string &srcPath,
204         const std::unordered_multimap<std::string, std::string> &dirMap) override;
205 
206     virtual ErrCode ExtractEncryptedSoFiles(const std::string &hapPath, const std::string &realSoFilesPath,
207         const std::string &cpuAbi, const std::string &tmpSoPath, int32_t uid) override;
208 
209 #if defined(CODE_SIGNATURE_ENABLE)
210     ErrCode PrepareEntryMap(const CodeSignatureParam &codeSignatureParam, Security::CodeSign::EntryMap &entryMap);
211 #endif
212 
213     virtual ErrCode VerifyCodeSignatureForHap(const CodeSignatureParam &codeSignatureParam) override;
214 
215     virtual ErrCode DeliverySignProfile(const std::string &bundleName, int32_t profileBlockLength,
216         const unsigned char *profileBlock) override;
217 
218     virtual ErrCode RemoveSignProfile(const std::string &bundleName) override;
219 
220     virtual ErrCode SetEncryptionPolicy(int32_t uid, const std::string &bundleName,
221         const int32_t userId, std::string &keyId) override;
222 
223     virtual ErrCode DeleteEncryptionKeyId(const std::string &bundleName, const int32_t userId) override;
224 
225     virtual ErrCode RemoveExtensionDir(int32_t userId, const std::vector<std::string> &extensionBundleDirs) override;
226 
227     virtual ErrCode IsExistExtensionDir(int32_t userId, const std::string &extensionBundleDir, bool &isExist) override;
228 
229     virtual ErrCode CreateExtensionDataDir(const CreateDirParam &createDirParam) override;
230 
231     virtual ErrCode GetExtensionSandboxTypeList(std::vector<std::string> &typeList) override;
232 
233     virtual ErrCode AddUserDirDeleteDfx(int32_t userId) override;
234 
235     virtual ErrCode MoveHapToCodeDir(const std::string &originPath, const std::string &targetPath) override;
236 
237 private:
238     std::string GetExtensionConfigPath() const;
239     void LoadNeedCreateSandbox(const nlohmann::json &object, std::vector<std::string> &typeList);
240     bool LoadExtensionNeedCreateSandbox(const nlohmann::json &object, std::string extensionTypeName);
241     bool ReadFileIntoJson(const std::string &filePath, nlohmann::json &jsonBuf);
242     ErrCode CreateExtensionDir(const CreateDirParam &createDirParam, const std::string& parentDir,
243         int32_t mode, int32_t gid, bool isLog = false);
244     ErrCode RemoveExtensionDir(int32_t userId, const std::string &extensionBundleDir);
245     std::string GetBundleDataDir(const std::string &el, const int userid) const;
246     bool CheckPathValid(const std::string &path, const std::string &prefix);
247     ErrCode SetDirApl(const std::string &dir, const std::string &bundleName, const std::string &apl,
248         unsigned int hapFlags);
249     unsigned int GetHapFlags(const bool isPreInstallApp, const bool debug, const bool isDlpSandbox);
250     ErrCode InnerRemoveAtomicServiceBundleDataDir(const std::string &bundleName, const int32_t userId);
251     ErrCode InnerRemoveBundleDataDir(const std::string &bundleName, const int32_t userId);
252 };
253 }  // namespace AppExecFwk
254 }  // namespace OHOS
255 #endif  // FOUNDATION_APPEXECFWK_SERVICES_BUNDLEMGR_INCLUDE_INSTALLD_HOST_IMPL_H