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