/* * Copyright (c) 2023-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 "ability_auto_startup_client.h" #include "hilog_tag_wrapper.h" #include "iservice_registry.h" #include "system_ability_definition.h" namespace OHOS { namespace AAFwk { std::shared_ptr AbilityAutoStartupClient::instance_ = nullptr; std::recursive_mutex AbilityAutoStartupClient::mutex_; #define CHECK_POINTER_RETURN_NOT_CONNECTED(object) \ if (!(object)) { \ TAG_LOGE(AAFwkTag::AUTO_STARTUP, "null proxy"); \ return ABILITY_SERVICE_NOT_CONNECTED; \ } std::shared_ptr AbilityAutoStartupClient::GetInstance() { if (instance_ == nullptr) { std::lock_guard lock_l(mutex_); if (instance_ == nullptr) { instance_ = std::make_shared(); } } return instance_; } AbilityAutoStartupClient::AbilityAutoStartupClient() {} AbilityAutoStartupClient::~AbilityAutoStartupClient() {} sptr AbilityAutoStartupClient::GetAbilityManager() { std::lock_guard lock(mutex_); if (!proxy_) { (void)Connect(); } return proxy_; } ErrCode AbilityAutoStartupClient::Connect() { std::lock_guard lock(mutex_); if (proxy_ != nullptr) { return ERR_OK; } sptr systemManager = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager(); if (systemManager == nullptr) { TAG_LOGE(AAFwkTag::AUTO_STARTUP, "Get registry failed"); return GET_ABILITY_SERVICE_FAILED; } sptr remoteObj = systemManager->GetSystemAbility(ABILITY_MGR_SERVICE_ID); if (remoteObj == nullptr) { TAG_LOGE(AAFwkTag::AUTO_STARTUP, "Connect AbilityManagerService failed"); return GET_ABILITY_SERVICE_FAILED; } deathRecipient_ = sptr(new AbilityMgrDeathRecipient()); if (deathRecipient_ == nullptr) { TAG_LOGE(AAFwkTag::AUTO_STARTUP, "Create AbilityMgrDeathRecipient failed"); return GET_ABILITY_SERVICE_FAILED; } if ((remoteObj->IsProxyObject()) && (!remoteObj->AddDeathRecipient(deathRecipient_))) { TAG_LOGE(AAFwkTag::AUTO_STARTUP, "Add death recipient to AbilityManagerService failed"); return GET_ABILITY_SERVICE_FAILED; } proxy_ = iface_cast(remoteObj); TAG_LOGD(AAFwkTag::AUTO_STARTUP, "Connect AbilityManagerService success"); return ERR_OK; } ErrCode AbilityAutoStartupClient::SetApplicationAutoStartupByEDM(const AutoStartupInfo &info, bool flag) { TAG_LOGD(AAFwkTag::AUTO_STARTUP, "called"); auto abms = GetAbilityManager(); CHECK_POINTER_RETURN_NOT_CONNECTED(abms); return abms->SetApplicationAutoStartupByEDM(info, flag); } ErrCode AbilityAutoStartupClient::CancelApplicationAutoStartupByEDM(const AutoStartupInfo &info, bool flag) { TAG_LOGD(AAFwkTag::AUTO_STARTUP, "called"); auto abms = GetAbilityManager(); CHECK_POINTER_RETURN_NOT_CONNECTED(abms); return abms->CancelApplicationAutoStartupByEDM(info, flag); } ErrCode AbilityAutoStartupClient::QueryAllAutoStartupApplications(std::vector &infoList) { TAG_LOGD(AAFwkTag::AUTO_STARTUP, "called"); auto abms = GetAbilityManager(); CHECK_POINTER_RETURN_NOT_CONNECTED(abms); return abms->QueryAllAutoStartupApplications(infoList); } void AbilityAutoStartupClient::AbilityMgrDeathRecipient::OnRemoteDied(const wptr& remote) { TAG_LOGI(AAFwkTag::AUTO_STARTUP, "Handle remote died"); AbilityAutoStartupClient::GetInstance()->ResetProxy(remote); } void AbilityAutoStartupClient::ResetProxy(wptr remote) { std::lock_guard lock(mutex_); if (!proxy_) { return; } auto serviceRemote = proxy_->AsObject(); if ((serviceRemote != nullptr) && (serviceRemote == remote.promote())) { TAG_LOGD(AAFwkTag::AUTO_STARTUP, "Remove death recipient"); serviceRemote->RemoveDeathRecipient(deathRecipient_); proxy_ = nullptr; } } } // namespace AAFwk } // namespace OHOS