1bc2ed2b3Sopenharmony_ci/* 2bc2ed2b3Sopenharmony_ci * Copyright (C) 2022 Huawei Device Co., Ltd. 3bc2ed2b3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4bc2ed2b3Sopenharmony_ci * you may not use this file except in compliance with the License. 5bc2ed2b3Sopenharmony_ci * You may obtain a copy of the License at 6bc2ed2b3Sopenharmony_ci * 7bc2ed2b3Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8bc2ed2b3Sopenharmony_ci * 9bc2ed2b3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10bc2ed2b3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11bc2ed2b3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12bc2ed2b3Sopenharmony_ci * See the License for the specific language governing permissions and 13bc2ed2b3Sopenharmony_ci * limitations under the License. 14bc2ed2b3Sopenharmony_ci */ 15bc2ed2b3Sopenharmony_ci#include "nfc_controller_stub.h" 16bc2ed2b3Sopenharmony_ci 17bc2ed2b3Sopenharmony_ci#include "ipc_skeleton.h" 18bc2ed2b3Sopenharmony_ci#include "loghelper.h" 19bc2ed2b3Sopenharmony_ci#include "ndef_msg_callback_proxy.h" 20bc2ed2b3Sopenharmony_ci#include "nfc_sdk_common.h" 21bc2ed2b3Sopenharmony_ci#include "nfc_service_ipc_interface_code.h" 22bc2ed2b3Sopenharmony_ci#include "nfc_controller_death_recipient.h" 23bc2ed2b3Sopenharmony_ci#include "nfc_permission_checker.h" 24bc2ed2b3Sopenharmony_ci#ifdef VENDOR_APPLICATIONS_ENABLED 25bc2ed2b3Sopenharmony_ci#include "on_card_emulation_notify_cb_proxy.h" 26bc2ed2b3Sopenharmony_ci#include "query_app_info_callback_proxy.h" 27bc2ed2b3Sopenharmony_ci#endif 28bc2ed2b3Sopenharmony_ci#include "external_deps_proxy.h" 29bc2ed2b3Sopenharmony_ci 30bc2ed2b3Sopenharmony_cinamespace OHOS { 31bc2ed2b3Sopenharmony_cinamespace NFC { 32bc2ed2b3Sopenharmony_ciint NfcControllerStub::OnRemoteRequest(uint32_t code, /* [in] */ 33bc2ed2b3Sopenharmony_ci MessageParcel& data, /* [in] */ 34bc2ed2b3Sopenharmony_ci MessageParcel& reply, /* [out] */ 35bc2ed2b3Sopenharmony_ci MessageOption& option) /* [in] */ 36bc2ed2b3Sopenharmony_ci{ 37bc2ed2b3Sopenharmony_ci InfoLog("NfcControllerStub OnRemoteRequest occur, code is %{public}d", code); 38bc2ed2b3Sopenharmony_ci if (data.ReadInterfaceToken() != GetDescriptor()) { 39bc2ed2b3Sopenharmony_ci ErrorLog("NfcControllerStub OnRemoteRequest GetDescriptor failed"); 40bc2ed2b3Sopenharmony_ci return KITS::ERR_NFC_PARAMETERS; 41bc2ed2b3Sopenharmony_ci } 42bc2ed2b3Sopenharmony_ci switch (code) { 43bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_GET_STATE): 44bc2ed2b3Sopenharmony_ci return HandleGetState(data, reply); 45bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_TURN_ON): 46bc2ed2b3Sopenharmony_ci return HandleTurnOn(data, reply); 47bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_TURN_OFF): 48bc2ed2b3Sopenharmony_ci return HandleTurnOff(data, reply); 49bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_REGISTER_CALLBACK): 50bc2ed2b3Sopenharmony_ci return HandleRegisterCallBack(data, reply); 51bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_UNREGISTER_CALLBACK): 52bc2ed2b3Sopenharmony_ci return HandleUnRegisterCallBack(data, reply); 53bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_IS_NFC_OPEN): 54bc2ed2b3Sopenharmony_ci return HandleIsNfcOpen(data, reply); 55bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_GET_TAG_INTERFACE): 56bc2ed2b3Sopenharmony_ci return HandleGetNfcTagInterface(data, reply); 57bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_REG_NDEF_MSG_CALLBACK): 58bc2ed2b3Sopenharmony_ci return HandleRegNdefMsgCb(data, reply); 59bc2ed2b3Sopenharmony_ci#ifdef VENDOR_APPLICATIONS_ENABLED 60bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_QUERY_APP_INFO_MSG_CALLBACK): 61bc2ed2b3Sopenharmony_ci return HandleRegQueryApplicationCb(data, reply); 62bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_ON_CARD_EMULATION_NOTIFY): 63bc2ed2b3Sopenharmony_ci return HandleRegCardEmulationNotifyCb(data, reply); 64bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_VENDOR_NOTIFY): 65bc2ed2b3Sopenharmony_ci return HandleNotifyEventStatus(data, reply); 66bc2ed2b3Sopenharmony_ci#endif 67bc2ed2b3Sopenharmony_ci case static_cast<uint32_t>(NfcServiceIpcInterfaceCode::COMMAND_GET_HCE_INTERFACE): 68bc2ed2b3Sopenharmony_ci return HandleGetNfcHceInterface(data, reply); 69bc2ed2b3Sopenharmony_ci default: 70bc2ed2b3Sopenharmony_ci return IPCObjectStub::OnRemoteRequest(code, data, reply, option); 71bc2ed2b3Sopenharmony_ci } 72bc2ed2b3Sopenharmony_ci} 73bc2ed2b3Sopenharmony_ci 74bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleGetState(MessageParcel& data, MessageParcel& reply) 75bc2ed2b3Sopenharmony_ci{ 76bc2ed2b3Sopenharmony_ci int state = GetState(); 77bc2ed2b3Sopenharmony_ci reply.WriteInt32(state); 78bc2ed2b3Sopenharmony_ci return ERR_NONE; 79bc2ed2b3Sopenharmony_ci} 80bc2ed2b3Sopenharmony_ci 81bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleTurnOn(MessageParcel& data, MessageParcel& reply) 82bc2ed2b3Sopenharmony_ci{ 83bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::SYS_PERM)) { 84bc2ed2b3Sopenharmony_ci ErrorLog("HandleTurnOn no permission"); 85bc2ed2b3Sopenharmony_ci reply.WriteInt32(KITS::ErrorCode::ERR_NO_PERMISSION); 86bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 87bc2ed2b3Sopenharmony_ci } 88bc2ed2b3Sopenharmony_ci std::string appPackageName = ExternalDepsProxy::GetInstance().GetBundleNameByUid(IPCSkeleton::GetCallingUid()); 89bc2ed2b3Sopenharmony_ci ExternalDepsProxy::GetInstance().WriteAppBehaviorHiSysEvent(SubErrorCode::TURN_ON_NFC, appPackageName); 90bc2ed2b3Sopenharmony_ci int statusCode = TurnOn(); 91bc2ed2b3Sopenharmony_ci reply.WriteInt32(statusCode); 92bc2ed2b3Sopenharmony_ci return statusCode; 93bc2ed2b3Sopenharmony_ci} 94bc2ed2b3Sopenharmony_ci 95bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleTurnOff(MessageParcel& data, MessageParcel& reply) 96bc2ed2b3Sopenharmony_ci{ 97bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::SYS_PERM)) { 98bc2ed2b3Sopenharmony_ci ErrorLog("HandleTurnOff no permission"); 99bc2ed2b3Sopenharmony_ci reply.WriteInt32(KITS::ErrorCode::ERR_NO_PERMISSION); 100bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 101bc2ed2b3Sopenharmony_ci } 102bc2ed2b3Sopenharmony_ci std::string appPackageName = ExternalDepsProxy::GetInstance().GetBundleNameByUid(IPCSkeleton::GetCallingUid()); 103bc2ed2b3Sopenharmony_ci ExternalDepsProxy::GetInstance().WriteAppBehaviorHiSysEvent(SubErrorCode::TURN_OFF_NFC, appPackageName); 104bc2ed2b3Sopenharmony_ci int statusCode = TurnOff(); 105bc2ed2b3Sopenharmony_ci reply.WriteInt32(statusCode); 106bc2ed2b3Sopenharmony_ci return statusCode; 107bc2ed2b3Sopenharmony_ci} 108bc2ed2b3Sopenharmony_ci 109bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleIsNfcOpen(MessageParcel& data, MessageParcel& reply) 110bc2ed2b3Sopenharmony_ci{ 111bc2ed2b3Sopenharmony_ci bool isOpen = false; 112bc2ed2b3Sopenharmony_ci int statusCode = IsNfcOpen(isOpen); 113bc2ed2b3Sopenharmony_ci reply.WriteBool(isOpen); 114bc2ed2b3Sopenharmony_ci return statusCode; 115bc2ed2b3Sopenharmony_ci} 116bc2ed2b3Sopenharmony_ci 117bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleRegisterCallBack(MessageParcel &data, MessageParcel &reply) 118bc2ed2b3Sopenharmony_ci{ 119bc2ed2b3Sopenharmony_ci std::string type = data.ReadString(); 120bc2ed2b3Sopenharmony_ci int exception = data.ReadInt32(); 121bc2ed2b3Sopenharmony_ci if (exception) { 122bc2ed2b3Sopenharmony_ci return KITS::ERR_NFC_PARAMETERS; 123bc2ed2b3Sopenharmony_ci } 124bc2ed2b3Sopenharmony_ci KITS::ErrorCode ret = KITS::ERR_NFC_PARAMETERS; 125bc2ed2b3Sopenharmony_ci do { 126bc2ed2b3Sopenharmony_ci sptr<IRemoteObject> remote = data.ReadRemoteObject(); 127bc2ed2b3Sopenharmony_ci if (remote == nullptr) { 128bc2ed2b3Sopenharmony_ci DebugLog("Failed to readRemoteObject!"); 129bc2ed2b3Sopenharmony_ci break; 130bc2ed2b3Sopenharmony_ci } 131bc2ed2b3Sopenharmony_ci 132bc2ed2b3Sopenharmony_ci std::unique_ptr<NfcControllerDeathRecipient> recipient 133bc2ed2b3Sopenharmony_ci = std::make_unique<NfcControllerDeathRecipient>(this, IPCSkeleton::GetCallingTokenID()); 134bc2ed2b3Sopenharmony_ci if (recipient == nullptr) { 135bc2ed2b3Sopenharmony_ci ErrorLog("recipient is null"); 136bc2ed2b3Sopenharmony_ci return ERR_NONE; 137bc2ed2b3Sopenharmony_ci } 138bc2ed2b3Sopenharmony_ci sptr<IRemoteObject::DeathRecipient> dr(recipient.release()); 139bc2ed2b3Sopenharmony_ci if ((remote->IsProxyObject()) && (!remote->AddDeathRecipient(dr))) { 140bc2ed2b3Sopenharmony_ci ErrorLog("Failed to add death recipient"); 141bc2ed2b3Sopenharmony_ci return ERR_NONE; 142bc2ed2b3Sopenharmony_ci } 143bc2ed2b3Sopenharmony_ci 144bc2ed2b3Sopenharmony_ci { 145bc2ed2b3Sopenharmony_ci std::lock_guard<std::mutex> guard(mutex_); 146bc2ed2b3Sopenharmony_ci deathRecipient_ = dr; 147bc2ed2b3Sopenharmony_ci callback_ = iface_cast<INfcControllerCallback>(remote); 148bc2ed2b3Sopenharmony_ci if (callback_ == nullptr) { 149bc2ed2b3Sopenharmony_ci callback_ = new (std::nothrow) NfcControllerCallBackProxy(remote); 150bc2ed2b3Sopenharmony_ci DebugLog("create new `NfcControllerCallBackProxy`!"); 151bc2ed2b3Sopenharmony_ci } 152bc2ed2b3Sopenharmony_ci ret = RegisterCallBack(callback_, type); 153bc2ed2b3Sopenharmony_ci } 154bc2ed2b3Sopenharmony_ci } while (0); 155bc2ed2b3Sopenharmony_ci 156bc2ed2b3Sopenharmony_ci reply.WriteInt32(ret); 157bc2ed2b3Sopenharmony_ci return ERR_NONE; 158bc2ed2b3Sopenharmony_ci} 159bc2ed2b3Sopenharmony_ci 160bc2ed2b3Sopenharmony_civoid NfcControllerStub::RemoveNfcDeathRecipient(const wptr<IRemoteObject> &remote) 161bc2ed2b3Sopenharmony_ci{ 162bc2ed2b3Sopenharmony_ci std::lock_guard<std::mutex> guard(mutex_); 163bc2ed2b3Sopenharmony_ci if (callback_ == nullptr) { 164bc2ed2b3Sopenharmony_ci ErrorLog("OnRemoteDied callback_ is nullptr"); 165bc2ed2b3Sopenharmony_ci return; 166bc2ed2b3Sopenharmony_ci } 167bc2ed2b3Sopenharmony_ci auto serviceRemote = callback_->AsObject(); 168bc2ed2b3Sopenharmony_ci if ((serviceRemote != nullptr) && (serviceRemote == remote.promote())) { 169bc2ed2b3Sopenharmony_ci serviceRemote->RemoveDeathRecipient(deathRecipient_); 170bc2ed2b3Sopenharmony_ci callback_ = nullptr; 171bc2ed2b3Sopenharmony_ci ErrorLog("on remote died"); 172bc2ed2b3Sopenharmony_ci } 173bc2ed2b3Sopenharmony_ci} 174bc2ed2b3Sopenharmony_ci 175bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleUnRegisterCallBack(MessageParcel &data, MessageParcel &reply) 176bc2ed2b3Sopenharmony_ci{ 177bc2ed2b3Sopenharmony_ci InfoLog("OnUnRegisterCallBack"); 178bc2ed2b3Sopenharmony_ci std::string type = data.ReadString(); 179bc2ed2b3Sopenharmony_ci int exception = data.ReadInt32(); 180bc2ed2b3Sopenharmony_ci if (exception) { 181bc2ed2b3Sopenharmony_ci return KITS::ERR_NFC_PARAMETERS; 182bc2ed2b3Sopenharmony_ci } 183bc2ed2b3Sopenharmony_ci KITS::ErrorCode ret = UnRegisterCallBack(type); 184bc2ed2b3Sopenharmony_ci DebugLog("OnUnRegisterCallBack::OnUnRegisterCallBack end##ret=%{public}d\n", ret); 185bc2ed2b3Sopenharmony_ci reply.WriteInt32(ret); 186bc2ed2b3Sopenharmony_ci return ERR_NONE; 187bc2ed2b3Sopenharmony_ci} 188bc2ed2b3Sopenharmony_ci 189bc2ed2b3Sopenharmony_ciKITS::ErrorCode NfcControllerStub::RegisterCallBack(const sptr<INfcControllerCallback> &callback, 190bc2ed2b3Sopenharmony_ci const std::string& type) 191bc2ed2b3Sopenharmony_ci{ 192bc2ed2b3Sopenharmony_ci return RegisterCallBack(callback, type, IPCSkeleton::GetCallingTokenID()); 193bc2ed2b3Sopenharmony_ci} 194bc2ed2b3Sopenharmony_ci 195bc2ed2b3Sopenharmony_ciKITS::ErrorCode NfcControllerStub::UnRegisterCallBack(const std::string& type) 196bc2ed2b3Sopenharmony_ci{ 197bc2ed2b3Sopenharmony_ci return UnRegisterCallBack(type, IPCSkeleton::GetCallingTokenID()); 198bc2ed2b3Sopenharmony_ci} 199bc2ed2b3Sopenharmony_ci 200bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleGetNfcTagInterface(MessageParcel& data, MessageParcel& reply) 201bc2ed2b3Sopenharmony_ci{ 202bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::TAG_PERM)) { 203bc2ed2b3Sopenharmony_ci ErrorLog("HandleGetNfcTagInterface no permission"); 204bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 205bc2ed2b3Sopenharmony_ci } 206bc2ed2b3Sopenharmony_ci OHOS::sptr<IRemoteObject> remoteOjbect = GetTagServiceIface(); 207bc2ed2b3Sopenharmony_ci if (remoteOjbect == nullptr) { 208bc2ed2b3Sopenharmony_ci ErrorLog("HandleGetNfcTagInterface remoteOjbect null!"); 209bc2ed2b3Sopenharmony_ci return KITS::ERR_NFC_PARAMETERS; 210bc2ed2b3Sopenharmony_ci } 211bc2ed2b3Sopenharmony_ci 212bc2ed2b3Sopenharmony_ci reply.WriteRemoteObject(remoteOjbect); 213bc2ed2b3Sopenharmony_ci return ERR_NONE; 214bc2ed2b3Sopenharmony_ci} 215bc2ed2b3Sopenharmony_ci 216bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleGetNfcHceInterface(MessageParcel& data, MessageParcel& reply) 217bc2ed2b3Sopenharmony_ci{ 218bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::CARD_EMU_PERM)) { 219bc2ed2b3Sopenharmony_ci ErrorLog("HandleGetNfcHceInterface no permission"); 220bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 221bc2ed2b3Sopenharmony_ci } 222bc2ed2b3Sopenharmony_ci OHOS::sptr<IRemoteObject> remoteOjbect = GetHceServiceIface(); 223bc2ed2b3Sopenharmony_ci if (remoteOjbect == nullptr) { 224bc2ed2b3Sopenharmony_ci ErrorLog("HandleGetNfcHceInterface remoteOjbect null!"); 225bc2ed2b3Sopenharmony_ci return KITS::ERR_NFC_PARAMETERS; 226bc2ed2b3Sopenharmony_ci } 227bc2ed2b3Sopenharmony_ci 228bc2ed2b3Sopenharmony_ci reply.WriteRemoteObject(remoteOjbect); 229bc2ed2b3Sopenharmony_ci return ERR_NONE; 230bc2ed2b3Sopenharmony_ci} 231bc2ed2b3Sopenharmony_ci 232bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleRegNdefMsgCb(MessageParcel& data, MessageParcel& reply) 233bc2ed2b3Sopenharmony_ci{ 234bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::TAG_PERM)) { 235bc2ed2b3Sopenharmony_ci ErrorLog("HandleRegNdefMsgCb no permission"); 236bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 237bc2ed2b3Sopenharmony_ci } 238bc2ed2b3Sopenharmony_ci InfoLog("NfcControllerStub::HandleRegNdefMsgCb"); 239bc2ed2b3Sopenharmony_ci KITS::ErrorCode ret = KITS::ERR_NFC_PARAMETERS; 240bc2ed2b3Sopenharmony_ci do { 241bc2ed2b3Sopenharmony_ci sptr<IRemoteObject> remote = data.ReadRemoteObject(); 242bc2ed2b3Sopenharmony_ci if (remote == nullptr) { 243bc2ed2b3Sopenharmony_ci DebugLog("Failed to readRemoteObject!"); 244bc2ed2b3Sopenharmony_ci break; 245bc2ed2b3Sopenharmony_ci } 246bc2ed2b3Sopenharmony_ci { 247bc2ed2b3Sopenharmony_ci std::lock_guard<std::mutex> guard(mutex_); 248bc2ed2b3Sopenharmony_ci ndefCallback_ = iface_cast<INdefMsgCallback>(remote); 249bc2ed2b3Sopenharmony_ci if (ndefCallback_ == nullptr) { 250bc2ed2b3Sopenharmony_ci ndefCallback_ = new (std::nothrow) NdefMsgCallbackProxy(remote); 251bc2ed2b3Sopenharmony_ci DebugLog("NfcControllerStub::HandleRegNdefMsgCb, create new `NdefMsgCallbackProxy`!"); 252bc2ed2b3Sopenharmony_ci } 253bc2ed2b3Sopenharmony_ci ret = RegNdefMsgCallback(ndefCallback_); 254bc2ed2b3Sopenharmony_ci } 255bc2ed2b3Sopenharmony_ci } while (0); 256bc2ed2b3Sopenharmony_ci reply.WriteInt32(ret); 257bc2ed2b3Sopenharmony_ci return ERR_NONE; 258bc2ed2b3Sopenharmony_ci} 259bc2ed2b3Sopenharmony_ci 260bc2ed2b3Sopenharmony_ci#ifdef VENDOR_APPLICATIONS_ENABLED 261bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleRegQueryApplicationCb(MessageParcel& data, MessageParcel& reply) 262bc2ed2b3Sopenharmony_ci{ 263bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::CARD_EMU_PERM)) { 264bc2ed2b3Sopenharmony_ci ErrorLog("HandleRegQueryApplicationCb no permission"); 265bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 266bc2ed2b3Sopenharmony_ci } 267bc2ed2b3Sopenharmony_ci InfoLog("NfcControllerStub::HandleRegQueryApplicationCb"); 268bc2ed2b3Sopenharmony_ci sptr<IRemoteObject> remote = data.ReadRemoteObject(); 269bc2ed2b3Sopenharmony_ci if (remote == nullptr) { 270bc2ed2b3Sopenharmony_ci ErrorLog("Failed to readRemoteObject!"); 271bc2ed2b3Sopenharmony_ci return KITS::ERR_NFC_PARAMETERS; 272bc2ed2b3Sopenharmony_ci } 273bc2ed2b3Sopenharmony_ci { 274bc2ed2b3Sopenharmony_ci std::lock_guard<std::mutex> guard(mutex_); 275bc2ed2b3Sopenharmony_ci queryAppInfoCallback_ = iface_cast<IQueryAppInfoCallback>(remote); 276bc2ed2b3Sopenharmony_ci if (queryAppInfoCallback_ == nullptr) { 277bc2ed2b3Sopenharmony_ci queryAppInfoCallback_ = new (std::nothrow) QueryAppInfoCallbackProxy(remote); 278bc2ed2b3Sopenharmony_ci DebugLog("NfcControllerStub::HandleRegQueryApplicationCb, create new `QueryAppInfoCallbackProxy`!"); 279bc2ed2b3Sopenharmony_ci } 280bc2ed2b3Sopenharmony_ci int ret = RegQueryApplicationCb(queryAppInfoCallback_); 281bc2ed2b3Sopenharmony_ci reply.WriteInt32(ret); 282bc2ed2b3Sopenharmony_ci } 283bc2ed2b3Sopenharmony_ci return ERR_NONE; 284bc2ed2b3Sopenharmony_ci} 285bc2ed2b3Sopenharmony_ci 286bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleRegCardEmulationNotifyCb(MessageParcel& data, MessageParcel& reply) 287bc2ed2b3Sopenharmony_ci{ 288bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::CARD_EMU_PERM)) { 289bc2ed2b3Sopenharmony_ci ErrorLog("HandleRegCardEmulationNotifyCb no permission"); 290bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 291bc2ed2b3Sopenharmony_ci } 292bc2ed2b3Sopenharmony_ci InfoLog("NfcControllerStub::HandleRegCardEmulationNotifyCb"); 293bc2ed2b3Sopenharmony_ci sptr<IRemoteObject> remote = data.ReadRemoteObject(); 294bc2ed2b3Sopenharmony_ci if (remote == nullptr) { 295bc2ed2b3Sopenharmony_ci ErrorLog("Failed to readRemoteObject!"); 296bc2ed2b3Sopenharmony_ci return KITS::ERR_NFC_PARAMETERS; 297bc2ed2b3Sopenharmony_ci } 298bc2ed2b3Sopenharmony_ci { 299bc2ed2b3Sopenharmony_ci std::lock_guard<std::mutex> guard(mutex_); 300bc2ed2b3Sopenharmony_ci onCardEmulationNotifyCb_ = iface_cast<IOnCardEmulationNotifyCb>(remote); 301bc2ed2b3Sopenharmony_ci if (onCardEmulationNotifyCb_ == nullptr) { 302bc2ed2b3Sopenharmony_ci onCardEmulationNotifyCb_ = new (std::nothrow) OnCardEmulationNotifyCbProxy(remote); 303bc2ed2b3Sopenharmony_ci DebugLog("NfcControllerStub::HandleRegCardEmulationNotifyCb, create new `OnCardEmulationNotifyCbProxy`!"); 304bc2ed2b3Sopenharmony_ci } 305bc2ed2b3Sopenharmony_ci int ret = RegCardEmulationNotifyCb(onCardEmulationNotifyCb_); 306bc2ed2b3Sopenharmony_ci reply.WriteInt32(ret); 307bc2ed2b3Sopenharmony_ci } 308bc2ed2b3Sopenharmony_ci return ERR_NONE; 309bc2ed2b3Sopenharmony_ci} 310bc2ed2b3Sopenharmony_ciint NfcControllerStub::HandleNotifyEventStatus(MessageParcel& data, MessageParcel& reply) 311bc2ed2b3Sopenharmony_ci{ 312bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::CARD_EMU_PERM)) { 313bc2ed2b3Sopenharmony_ci ErrorLog("HandleNotifyEventStatus no permission"); 314bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 315bc2ed2b3Sopenharmony_ci } 316bc2ed2b3Sopenharmony_ci int eventType = data.ReadInt32(); 317bc2ed2b3Sopenharmony_ci int arg1 = data.ReadInt32(); 318bc2ed2b3Sopenharmony_ci std::string arg2 = data.ReadString(); 319bc2ed2b3Sopenharmony_ci int exception = data.ReadInt32(); 320bc2ed2b3Sopenharmony_ci if (exception) { 321bc2ed2b3Sopenharmony_ci ErrorLog("HandleNotifyEventStatus::read param failed."); 322bc2ed2b3Sopenharmony_ci return KITS::ERR_NFC_PARAMETERS; 323bc2ed2b3Sopenharmony_ci } 324bc2ed2b3Sopenharmony_ci KITS::ErrorCode ret = NotifyEventStatus(eventType, arg1, arg2); 325bc2ed2b3Sopenharmony_ci reply.WriteInt32(ret); 326bc2ed2b3Sopenharmony_ci return ERR_NONE; 327bc2ed2b3Sopenharmony_ci} 328bc2ed2b3Sopenharmony_ci#endif 329bc2ed2b3Sopenharmony_ci 330bc2ed2b3Sopenharmony_ciKITS::ErrorCode NfcControllerStub::RegNdefMsgCb(const sptr<INdefMsgCallback> &callback) 331bc2ed2b3Sopenharmony_ci{ 332bc2ed2b3Sopenharmony_ci if (!ExternalDepsProxy::GetInstance().IsGranted(OHOS::NFC::TAG_PERM)) { 333bc2ed2b3Sopenharmony_ci ErrorLog("RegNdefMsgCb no permission"); 334bc2ed2b3Sopenharmony_ci return KITS::ErrorCode::ERR_NO_PERMISSION; 335bc2ed2b3Sopenharmony_ci } 336bc2ed2b3Sopenharmony_ci InfoLog("NfcControllerStub::RegNdefMsgCb"); 337bc2ed2b3Sopenharmony_ci return RegNdefMsgCallback(callback); 338bc2ed2b3Sopenharmony_ci} 339bc2ed2b3Sopenharmony_ci} // namespace NFC 340bc2ed2b3Sopenharmony_ci} // namespace OHOS 341