/* * Copyright (c) 2021-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. */ #include "distributed_input_sink_handler.h" #include "dinput_errcode.h" #include "dinput_log.h" #include "hisysevent_util.h" #include "i_distributed_sink_input.h" #include "load_d_input_sink_callback.h" namespace OHOS { namespace DistributedHardware { namespace DistributedInput { IMPLEMENT_SINGLE_INSTANCE(DistributedInputSinkHandler); DistributedInputSinkHandler::DistributedInputSinkHandler() { DHLOGI("DInputSinkHandler construct."); std::lock_guard lock(proxyMutex_); if (sinkSvrRecipient_ == nullptr) { sinkSvrRecipient_ = new (std::nothrow) DInputSinkSvrRecipient(); } } DistributedInputSinkHandler::~DistributedInputSinkHandler() { DHLOGI("~DistributedInputSinkHandler"); } int32_t DistributedInputSinkHandler::InitSink(const std::string ¶ms) { DHLOGI("DistributedInputSinkHandler InitSink begin"); std::unique_lock lock(proxyMutex_); sptr samgr = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager(); if (!samgr) { DHLOGE("Failed to get system ability mgr."); return ERR_DH_INPUT_SINK_HANDLER_INIT_SINK_SA_FAIL; } sptr loadCallback(new LoadDInputSinkCallback(params)); HisyseventUtil::GetInstance().SysEventWriteBehavior(DINPUT_INIT, "dinput sink LoadSystemAbility call"); int32_t ret = samgr->LoadSystemAbility(DISTRIBUTED_HARDWARE_INPUT_SINK_SA_ID, loadCallback); if (ret != ERR_OK) { DHLOGE("Failed to Load systemAbility, systemAbilityId:%{public}d, ret code:%{public}d", DISTRIBUTED_HARDWARE_INPUT_SINK_SA_ID, ret); return ERR_DH_INPUT_SINK_HANDLER_INIT_SINK_SA_FAIL; } auto waitStatus = proxyConVar_.wait_for(lock, std::chrono::milliseconds(INPUT_LOAD_SA_TIMEOUT_MS), [this]() { return (DInputSAManager::GetInstance().HasDInputSinkProxy()); }); if (!waitStatus) { DHLOGE("dinput load sink sa timeout."); return ERR_DH_INPUT_SINK_HANDLER_INIT_SINK_SA_FAIL; } DHLOGI("DistributedInputSinkHandler InitSink end"); return DH_SUCCESS; } void DistributedInputSinkHandler::FinishStartSA(const std::string ¶ms, const sptr &remoteObject) { DHLOGI("DInputSinkHandler FinishStartSA"); std::lock_guard lock(proxyMutex_); if (sinkSvrRecipient_ == nullptr) { DHLOGE("sinkSvrRecipient is nullptr."); return; } remoteObject->AddDeathRecipient(sinkSvrRecipient_); dInputSinkProxy_ = iface_cast(remoteObject); DInputSAManager::GetInstance().SetDInputSinkProxy(remoteObject); if ((dInputSinkProxy_ == nullptr) || (dInputSinkProxy_->AsObject() == nullptr)) { DHLOGE("Faild to get input sink proxy."); return; } DistributedInputClient::GetInstance().InitSink(); proxyConVar_.notify_all(); } int32_t DistributedInputSinkHandler::ReleaseSink() { return DistributedInputClient::GetInstance().ReleaseSink(); } int32_t DistributedInputSinkHandler::SubscribeLocalHardware(const std::string &dhId, const std::string ¶ms) { return DH_SUCCESS; } int32_t DistributedInputSinkHandler::UnsubscribeLocalHardware(const std::string &dhId) { return DH_SUCCESS; } void DistributedInputSinkHandler::SALoadSinkCb::OnLoadSystemAbilitySuccess(int32_t systemAbilityId, const OHOS::sptr &remoteObject) { currSystemAbilityId = systemAbilityId; currRemoteObject = remoteObject; DHLOGI("DistributedInputSinkHandler OnLoadSystemAbilitySuccess. systemAbilityId=%{public}d", systemAbilityId); } void DistributedInputSinkHandler::SALoadSinkCb::OnLoadSystemAbilityFail(int32_t systemAbilityId) { currSystemAbilityId = systemAbilityId; DHLOGE("DistributedInputSinkHandler OnLoadSystemAbilityFail. systemAbilityId=%{public}d", systemAbilityId); } void DistributedInputSinkHandler::DInputSinkSvrRecipient::OnRemoteDied(const wptr &remote) { if (remote == nullptr) { DHLOGE("OnRemoteDied remote is nullptr."); return; } DHLOGI("DInputSinkSvrRecipient OnRemoteDied."); DistributedInputSinkHandler::GetInstance().OnRemoteSinkSvrDied(remote); } void DistributedInputSinkHandler::OnRemoteSinkSvrDied(const wptr &remote) { DHLOGI("DInputSinkHandle OnRemoteSinkSvrDied."); std::lock_guard lock(proxyMutex_); if (dInputSinkProxy_ == nullptr) { DHLOGE("dInputSinkProxy_ is nullptr."); return; } if (dInputSinkProxy_->AsObject() == nullptr) { DHLOGE("AsObject is nullptr."); return; } sptr remoteObject = remote.promote(); if (remoteObject == nullptr) { DHLOGE("OnRemoteDied remote promoted failed"); return; } if (dInputSinkProxy_->AsObject() != remoteObject) { DHLOGE("OnRemoteSinkSvrDied not found remote object."); return; } dInputSinkProxy_->AsObject()->RemoveDeathRecipient(sinkSvrRecipient_); dInputSinkProxy_ = nullptr; } int32_t DistributedInputSinkHandler::RegisterPrivacyResources(std::shared_ptr listener) { return DH_SUCCESS; } int32_t DistributedInputSinkHandler::PauseDistributedHardware(const std::string &networkId) { return DH_SUCCESS; } int32_t DistributedInputSinkHandler::ResumeDistributedHardware(const std::string &networkId) { return DH_SUCCESS; } int32_t DistributedInputSinkHandler::StopDistributedHardware(const std::string &networkId) { return DH_SUCCESS; } IDistributedHardwareSink *GetSinkHardwareHandler() { return &DistributedInputSinkHandler::GetInstance(); } } // namespace DistributedInput } // namespace DistributedHardware } // namespace OHOS