• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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     PermissionOper GetSelfPermissionsState(std::vector<PermissionListStateParcel>& permListParcel,
61         PermissionGrantInfoParcel& infoParcel) override;
62     int32_t GetPermissionsStatus(
63         AccessTokenID tokenID, std::vector<PermissionListStateParcel>& permListParcel) override;
64     int ClearUserGrantedPermissionState(AccessTokenID tokenID) override;
65     int GetTokenType(AccessTokenID tokenID) override;
66     int CheckNativeDCap(AccessTokenID tokenID, const std::string& dcap) override;
67     AccessTokenIDEx GetHapTokenID(int32_t userID, const std::string& bundleName, int32_t instIndex) override;
68     AccessTokenID AllocLocalTokenID(const std::string& remoteDeviceID, AccessTokenID remoteTokenID) override;
69     AccessTokenIDEx AllocHapToken(const HapInfoParcel& hapInfo, const HapPolicyParcel& policyParcel) override;
70     int32_t InitHapToken(const HapInfoParcel& hapInfoParcel, HapPolicyParcel& policyParcel,
71         AccessTokenIDEx& fullTokenId) override;
72     int DeleteToken(AccessTokenID tokenID) override;
73     int32_t UpdateHapToken(
74         AccessTokenIDEx& tokenIdEx, const UpdateHapInfoParams& info, const HapPolicyParcel& policyParcel) override;
75     int GetHapTokenInfo(AccessTokenID tokenID, HapTokenInfoParcel& hapTokenInfoRes) override;
76     int GetNativeTokenInfo(AccessTokenID tokenID, NativeTokenInfoParcel& nativeTokenInfoRes) override;
77 #ifndef ATM_BUILD_VARIANT_USER_ENABLE
78     int32_t ReloadNativeTokenInfo() override;
79 #endif
80     int32_t RegisterPermStateChangeCallback(
81         const PermStateChangeScopeParcel& scope, const sptr<IRemoteObject>& callback) override;
82     int32_t UnRegisterPermStateChangeCallback(const sptr<IRemoteObject>& callback) override;
83     AccessTokenID GetNativeTokenId(const std::string& processName) override;
84 
85 #ifdef TOKEN_SYNC_ENABLE
86     int GetHapTokenInfoFromRemote(AccessTokenID tokenID, HapTokenInfoForSyncParcel& hapSyncParcel) override;
87     int GetAllNativeTokenInfo(std::vector<NativeTokenInfoForSyncParcel>& nativeTokenInfoRes) override;
88     int SetRemoteHapTokenInfo(const std::string& deviceID, HapTokenInfoForSyncParcel& hapSyncParcel) override;
89     int SetRemoteNativeTokenInfo(const std::string& deviceID,
90         std::vector<NativeTokenInfoForSyncParcel>& nativeTokenInfoForSyncParcel) override;
91     int DeleteRemoteToken(const std::string& deviceID, AccessTokenID tokenID) override;
92     AccessTokenID GetRemoteNativeTokenID(const std::string& deviceID, AccessTokenID tokenID) override;
93     int DeleteRemoteDeviceTokens(const std::string& deviceID) override;
94     int32_t RegisterTokenSyncCallback(const sptr<IRemoteObject>& callback) override;
95     int32_t UnRegisterTokenSyncCallback() override;
96 #endif
97 
98     int32_t SetPermDialogCap(const HapBaseInfoParcel& hapBaseInfo, bool enable) override;
99     void DumpTokenInfo(const AtmToolsParamInfoParcel& infoParcel, std::string& dumpInfo) override;
100     int32_t DumpPermDefInfo(std::string& dumpInfo) override;
101     int32_t GetVersion(uint32_t& version) override;
102 
103 private:
104     bool SendRequest(AccessTokenInterfaceCode code, MessageParcel& data, MessageParcel& reply);
105     static inline BrokerDelegator<AccessTokenManagerProxy> delegator_;
106 };
107 } // namespace AccessToken
108 } // namespace Security
109 } // namespace OHOS
110 #endif // ACCESSTOKEN_MANAGER_PROXY_H
111