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 ACCESSTOKEN_MANAGER_PROXY_H 17 #define ACCESSTOKEN_MANAGER_PROXY_H 18 19 #include <string> 20 #include <vector> 21 22 #include "access_token.h" 23 #include "atm_tools_param_info_parcel.h" 24 #include "hap_info_parcel.h" 25 #include "hap_base_info_parcel.h" 26 #include "hap_policy_parcel.h" 27 #include "hap_token_info_parcel.h" 28 #include "hap_token_info_for_sync_parcel.h" 29 #include "i_accesstoken_manager.h" 30 #include "iremote_proxy.h" 31 #include "native_token_info_for_sync_parcel.h" 32 #include "native_token_info_parcel.h" 33 #include "permission_def_parcel.h" 34 #include "permission_grant_info_parcel.h" 35 #include "permission_list_state_parcel.h" 36 #include "permission_state_full_parcel.h" 37 38 namespace OHOS { 39 namespace Security { 40 namespace AccessToken { 41 class AccessTokenManagerProxy : public IRemoteProxy<IAccessTokenManager> { 42 public: 43 explicit AccessTokenManagerProxy(const sptr<IRemoteObject>& impl); 44 ~AccessTokenManagerProxy() override; 45 46 PermUsedTypeEnum GetUserGrantedPermissionUsedType( 47 AccessTokenID tokenID, const std::string& permissionName) override; 48 int VerifyAccessToken(AccessTokenID tokenID, const std::string& permissionName) override; 49 int GetDefPermission(const std::string& permissionName, PermissionDefParcel& permissionDefResult) override; 50 int GetDefPermissions(AccessTokenID tokenID, std::vector<PermissionDefParcel>& permList) override; 51 int GetReqPermissions( 52 AccessTokenID tokenID, std::vector<PermissionStateFullParcel>& reqPermList, bool isSystemGrant) override; 53 int GetPermissionFlag(AccessTokenID tokenID, const std::string& permissionName, uint32_t& flag) override; 54 int32_t SetPermissionRequestToggleStatus(const std::string& permissionName, uint32_t status, 55 int32_t userID) override; 56 int32_t GetPermissionRequestToggleStatus(const std::string& permissionName, uint32_t& status, 57 int32_t userID) override; 58 int GrantPermission(AccessTokenID tokenID, const std::string& permissionName, uint32_t flag) override; 59 int RevokePermission(AccessTokenID tokenID, const std::string& permissionName, uint32_t flag) override; 60 int GrantPermissionForSpecifiedTime( 61 AccessTokenID tokenID, const std::string& permissionName, uint32_t onceTime) override; 62 PermissionOper GetSelfPermissionsState(std::vector<PermissionListStateParcel>& permListParcel, 63 PermissionGrantInfoParcel& infoParcel) override; 64 int32_t GetPermissionsStatus( 65 AccessTokenID tokenID, std::vector<PermissionListStateParcel>& permListParcel) override; 66 int ClearUserGrantedPermissionState(AccessTokenID tokenID) override; 67 int GetTokenType(AccessTokenID tokenID) override; 68 int CheckNativeDCap(AccessTokenID tokenID, const std::string& dcap) override; 69 AccessTokenIDEx GetHapTokenID(int32_t userID, const std::string& bundleName, int32_t instIndex) override; 70 AccessTokenID AllocLocalTokenID(const std::string& remoteDeviceID, AccessTokenID remoteTokenID) override; 71 AccessTokenIDEx AllocHapToken(const HapInfoParcel& hapInfo, const HapPolicyParcel& policyParcel) override; 72 int32_t InitHapToken(const HapInfoParcel& hapInfoParcel, HapPolicyParcel& policyParcel, 73 AccessTokenIDEx& fullTokenId) override; 74 int DeleteToken(AccessTokenID tokenID) override; 75 int32_t UpdateHapToken( 76 AccessTokenIDEx& tokenIdEx, const UpdateHapInfoParams& info, const HapPolicyParcel& policyParcel) override; 77 int GetHapTokenInfo(AccessTokenID tokenID, HapTokenInfoParcel& hapTokenInfoRes) override; 78 int GetNativeTokenInfo(AccessTokenID tokenID, NativeTokenInfoParcel& nativeTokenInfoRes) override; 79 #ifndef ATM_BUILD_VARIANT_USER_ENABLE 80 int32_t ReloadNativeTokenInfo() override; 81 #endif 82 int32_t RegisterPermStateChangeCallback( 83 const PermStateChangeScopeParcel& scope, const sptr<IRemoteObject>& callback) override; 84 int32_t UnRegisterPermStateChangeCallback(const sptr<IRemoteObject>& callback) override; 85 AccessTokenID GetNativeTokenId(const std::string& processName) override; 86 87 #ifdef TOKEN_SYNC_ENABLE 88 int GetHapTokenInfoFromRemote(AccessTokenID tokenID, HapTokenInfoForSyncParcel& hapSyncParcel) override; 89 int SetRemoteHapTokenInfo(const std::string& deviceID, HapTokenInfoForSyncParcel& hapSyncParcel) override; 90 int DeleteRemoteToken(const std::string& deviceID, AccessTokenID tokenID) override; 91 AccessTokenID GetRemoteNativeTokenID(const std::string& deviceID, AccessTokenID tokenID) override; 92 int DeleteRemoteDeviceTokens(const std::string& deviceID) override; 93 int32_t RegisterTokenSyncCallback(const sptr<IRemoteObject>& callback) override; 94 int32_t UnRegisterTokenSyncCallback() override; 95 #endif 96 97 int32_t SetPermDialogCap(const HapBaseInfoParcel& hapBaseInfo, bool enable) override; 98 void DumpTokenInfo(const AtmToolsParamInfoParcel& infoParcel, std::string& dumpInfo) override; 99 int32_t GetVersion(uint32_t& version) override; 100 void GetPermissionManagerInfo(PermissionGrantInfoParcel& infoParcel) override; 101 102 private: 103 bool SendRequest(AccessTokenInterfaceCode code, MessageParcel& data, MessageParcel& reply); 104 static inline BrokerDelegator<AccessTokenManagerProxy> delegator_; 105 }; 106 } // namespace AccessToken 107 } // namespace Security 108 } // namespace OHOS 109 #endif // ACCESSTOKEN_MANAGER_PROXY_H 110