1 /*
2  * Copyright (c) 2022-2023 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 I_PRIVACY_MANAGER_H
17 #define I_PRIVACY_MANAGER_H
18 
19 #include <string>
20 
21 #include "access_token.h"
22 #include "add_perm_param_info_parcel.h"
23 #include "errors.h"
24 #include "iremote_broker.h"
25 
26 #include "on_permission_used_record_callback.h"
27 #include "privacy_service_ipc_interface_code.h"
28 #include "permission_used_request_parcel.h"
29 #include "permission_used_result_parcel.h"
30 #include "permission_used_type_info_parcel.h"
31 #include "privacy_param.h"
32 #ifdef SECURITY_COMPONENT_ENHANCE_ENABLE
33 #include "sec_comp_enhance_data_parcel.h"
34 #endif
35 
36 /* SAID:3505 */
37 namespace OHOS {
38 namespace Security {
39 namespace AccessToken {
40 class IPrivacyManager : public IRemoteBroker {
41 public:
42     static const int32_t SA_ID_PRIVACY_MANAGER_SERVICE = 3505;
43 
44     DECLARE_INTERFACE_DESCRIPTOR(u"ohos.security.accesstoken.IPrivacyManager");
45 
46     virtual int32_t AddPermissionUsedRecord(const AddPermParamInfoParcel& infoParcel, bool asyncMode = false) = 0;
47     virtual int32_t StartUsingPermission(AccessTokenID tokenID, int32_t pid, const std::string& permissionName) = 0;
48     virtual int32_t StartUsingPermission(AccessTokenID tokenID, int32_t pid, const std::string& permissionName,
49         const sptr<IRemoteObject>& callback) = 0;
50     virtual int32_t StopUsingPermission(AccessTokenID tokenID, int32_t pid, const std::string& permissionName) = 0;
51     virtual int32_t RemovePermissionUsedRecords(AccessTokenID tokenID, const std::string& deviceID) = 0;
52     virtual int32_t GetPermissionUsedRecords(
53         const PermissionUsedRequestParcel& request, PermissionUsedResultParcel& result) = 0;
54     virtual int32_t GetPermissionUsedRecords(
55         const PermissionUsedRequestParcel& request, const sptr<OnPermissionUsedRecordCallback>& callback) = 0;
56     virtual int32_t RegisterPermActiveStatusCallback(
57         std::vector<std::string>& permList, const sptr<IRemoteObject>& callback) = 0;
58     virtual int32_t UnRegisterPermActiveStatusCallback(const sptr<IRemoteObject>& callback) = 0;
59     virtual bool IsAllowedUsingPermission(AccessTokenID tokenID, const std::string& permissionName) = 0;
60     virtual int32_t SetMutePolicy(uint32_t policyType, uint32_t callerType, bool isMute) = 0;
61     virtual int32_t SetHapWithFGReminder(uint32_t tokenId, bool isAllowed) = 0;
62 #ifdef SECURITY_COMPONENT_ENHANCE_ENABLE
63     virtual int32_t RegisterSecCompEnhance(const SecCompEnhanceDataParcel& enhanceParcel) = 0;
64     virtual int32_t UpdateSecCompEnhance(int32_t pid, uint32_t seqNum) = 0;
65     virtual int32_t GetSecCompEnhance(int32_t pid, SecCompEnhanceDataParcel& enhanceParcel) = 0;
66     virtual int32_t GetSpecialSecCompEnhance(const std::string& bundleName,
67         std::vector<SecCompEnhanceDataParcel>& enhanceParcelList) = 0;
68 #endif
69     virtual int32_t GetPermissionUsedTypeInfos(const AccessTokenID tokenId, const std::string& permissionName,
70         std::vector<PermissionUsedTypeInfoParcel>& resultsParcel) = 0;
71 };
72 } // namespace AccessToken
73 } // namespace Security
74 } // namespace OHOS
75 
76 #endif // I_PRIVACY_MANAGER_H
77