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