/* * Copyright (c) 2022-2024 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef OS_ACCOUNT_SERVICES_ACCOUNTMGR_INCLUDE_ACCOUNT_IAM_CALLBACK_H #define OS_ACCOUNT_SERVICES_ACCOUNTMGR_INCLUDE_ACCOUNT_IAM_CALLBACK_H #include #include #include "account_file_operator.h" #include "account_iam_info.h" #include "domain_account_callback.h" #include "iaccount_iam_callback.h" #include "iremote_object.h" namespace OHOS { namespace AccountSA { class AuthCallbackDeathRecipient : public IRemoteObject::DeathRecipient { public: AuthCallbackDeathRecipient() = default; ~AuthCallbackDeathRecipient() override = default; void SetContextId(uint16_t context); void OnRemoteDied(const wptr &remote) override; private: uint64_t contextId_ = 0; }; class AuthCallback : public AuthenticationCallback { public: AuthCallback(uint32_t userId, AuthType authType, AuthIntent authIntent, const sptr &callback); AuthCallback(uint32_t userId, AuthType authType, AuthIntent authIntent, bool isRemoteAuth, const sptr &callback); virtual ~AuthCallback() = default; void SetDeathRecipient(const sptr &deathRecipient); void OnAcquireInfo(int32_t module, uint32_t acquireInfo, const Attributes &extraInfo) override; void OnResult(int32_t result, const Attributes &extraInfo) override; private: ErrCode UnlockAccount(int32_t accountId, const std::vector &token, const std::vector &secret, bool &isUpdateVerifiedStatus); ErrCode HandleAuthResult(const Attributes &extraInfo, int32_t accountId, bool &isUpdateVerifiedStatus); private: uint32_t userId_; AuthType authType_; AuthIntent authIntent_; bool isRemoteAuth_ = false; sptr innerCallback_ = nullptr; sptr deathRecipient_ = nullptr; }; class IDMCallbackDeathRecipient : public IRemoteObject::DeathRecipient { public: IDMCallbackDeathRecipient(uint32_t userId); void OnRemoteDied(const wptr &remote) override; private: uint32_t userId_ = 0; }; class AddCredCallback : public UserIdmClientCallback { public: AddCredCallback(uint32_t userId, const CredentialParameters &credInfo, const sptr &callback); virtual ~AddCredCallback() = default; void SetDeathRecipient(const sptr &deathRecipient); void OnResult(int32_t result, const Attributes &extraInfo) override; void OnAcquireInfo(int32_t module, uint32_t acquireInfo, const Attributes &extraInfo) override; private: std::uint32_t userId_; CredentialParameters credInfo_; sptr deathRecipient_ = nullptr; sptr innerCallback_ = nullptr; }; class UpdateCredCallback : public UserIdmClientCallback { public: UpdateCredCallback(uint32_t userId, const CredentialParameters &credInfo, const sptr &callback); virtual ~UpdateCredCallback() = default; void SetDeathRecipient(const sptr &deathRecipient); void OnResult(int32_t result, const Attributes &extraInfo) override; void OnAcquireInfo(int32_t module, uint32_t acquireInfo, const Attributes &extraInfo) override; private: std::uint32_t userId_; CredentialParameters credInfo_; sptr deathRecipient_ = nullptr; const sptr innerCallback_ = nullptr; }; #ifdef HAS_PIN_AUTH_PART class DelUserInputer : public IInputer { public: DelUserInputer() = default; virtual ~DelUserInputer() = default; void OnGetData(int32_t authSubType, std::vector challenge, std::shared_ptr inputerData) override; }; class CommitDelCredCallback : public UserIdmClientCallback { public: CommitDelCredCallback() {} virtual ~CommitDelCredCallback() {} void OnResult(int32_t result, const UserIam::UserAuth::Attributes &extraInfo) override; void OnAcquireInfo(int32_t module, uint32_t acquireInfo, const UserIam::UserAuth::Attributes &extraInfo) override; public: bool isCalled_ = false; int32_t resultCode_ = -1; std::mutex mutex_; std::condition_variable onResultCondition_; }; class DelUserCallback : public UserIdmClientCallback { public: DelUserCallback(uint32_t userId, const std::vector &token, const sptr &callback); virtual ~DelUserCallback(); void OnResult(int32_t result, const Attributes &extraInfo) override; void OnAcquireInfo(int32_t module, uint32_t acquireInfo, const Attributes &extraInfo) override {}; private: std::uint32_t userId_; std::vector token_; const sptr innerCallback_ = nullptr; }; #endif // HAS_PIN_AUTH_PART struct UpdateCredInfo { uint64_t credentialId = 0; uint64_t secureUid = 0; std::vector token; std::vector newSecret; }; class CommitCredUpdateCallback : public UserIdmClientCallback { public: CommitCredUpdateCallback(int32_t userId, const UpdateCredInfo &extraUpdateInfo, const sptr &callback); virtual ~CommitCredUpdateCallback() = default; void OnResult(int32_t result, const Attributes &extraInfo) override; void OnAcquireInfo(int32_t module, uint32_t acquireInfo, const Attributes &extraInfo) override; private: int32_t userId_; UpdateCredInfo extraUpdateInfo_; sptr innerCallback_ = nullptr; }; class DelCredCallback : public UserIdmClientCallback { public: DelCredCallback(int32_t userId, bool isPIN, std::vector token, const sptr &callback); virtual ~DelCredCallback() = default; void OnResult(int32_t result, const Attributes &extraInfo) override; void OnAcquireInfo(int32_t module, uint32_t acquireInfo, const Attributes &extraInfo) override; private: int32_t userId_; bool isPIN_; std::vector token_; sptr innerCallback_ = nullptr; }; class GetCredInfoCallbackWrapper : public GetCredentialInfoCallback { public: GetCredInfoCallbackWrapper(int32_t userId, int32_t authType, const sptr &callback); virtual ~GetCredInfoCallbackWrapper() = default; void OnCredentialInfo(const std::vector &infoList) override; private: int32_t userId_; int32_t authType_; sptr innerCallback_ = nullptr; }; class GetPropCallbackWrapper : public GetPropCallback { public: GetPropCallbackWrapper(int32_t userId, const sptr &callback); virtual ~GetPropCallbackWrapper() = default; void OnResult(int32_t result, const Attributes &extraInfo) override; private: int32_t userId_; sptr innerCallback_; }; class SetPropCallbackWrapper : public SetPropCallback { public: SetPropCallbackWrapper(int32_t userId, const sptr &callback); virtual ~SetPropCallbackWrapper() = default; void OnResult(int32_t result, const Attributes &extraInfo) override; private: int32_t userId_; sptr innerCallback_; }; class GetSecUserInfoCallbackWrapper : public GetSecUserInfoCallback { public: GetSecUserInfoCallbackWrapper(AuthType authType, const sptr &callback); virtual ~GetSecUserInfoCallbackWrapper() = default; void OnSecUserInfo(const SecUserInfo &info) override; private: AuthType authType_; sptr innerCallback_; }; class GetSecureUidCallback final : public GetSecUserInfoCallback { public: GetSecureUidCallback(int32_t userId); void OnSecUserInfo(const SecUserInfo &info) override; public: int32_t userId_; uint64_t secureUid_ = 0; std::mutex secureMtx_; std::condition_variable secureCv_; }; class PrepareRemoteAuthCallbackWrapper : public PrepareRemoteAuthCallback { public: PrepareRemoteAuthCallbackWrapper(const sptr &callback); virtual ~PrepareRemoteAuthCallbackWrapper() = default; void OnResult(int32_t result) override; private: sptr innerCallback_; }; class GetDomainAuthStatusInfoCallback final : public DomainAccountCallback { public: GetDomainAuthStatusInfoCallback(const GetPropertyRequest &request, const sptr &callback); void OnResult(int32_t result, Parcel &parcel) override; private: GetPropertyRequest request_; sptr innerCallback_; }; } // namespace AccountSA } // namespace OHOS #endif // OS_ACCOUNT_SERVICES_ACCOUNTMGR_INCLUDE_ACCOUNT_IAM_CALLBACK_H