/* * Copyright (c) 2022 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 SCAN_CALLBACK_H #define SCAN_CALLBACK_H #define TDD_ENABLE 1 #include #include #include #include "napi/native_api.h" #include "scan_callback_stub.h" namespace OHOS::Scan { struct CallbackParam { napi_env env; napi_ref ref; std::mutex* mutexPtr; uint32_t state; bool isGetSucc; int32_t sizeRead; std::string message; ScanDeviceInfoTCP deviceInfoTCP; ScanDeviceInfo deviceInfo; ScanDeviceInfoSync deviceInfoSync; void InitialCallbackParam(napi_env &env_, napi_ref &ref_, std::mutex &mutex_); void SetCallbackParam(uint32_t &state, const ScanDeviceInfo &deviceInfo); void SetCallbackSyncParam(uint32_t &state, const ScanDeviceInfoSync &deviceInfoSync); }; struct Param { napi_env env; napi_ref callbackRef; }; class ScanCallback : public ScanCallbackStub { public: ScanCallback(napi_env env, napi_ref ref); explicit ScanCallback(std::function &infos)> callbackFunction); virtual ~ScanCallback(); bool OnCallback(uint32_t state, const ScanDeviceInfo &info) override; bool OnCallbackSync(uint32_t state, const ScanDeviceInfoSync &info) override; bool OnGetDevicesList(std::vector &info) override; #ifndef TDD_ENABLE private: #endif bool ExecuteNapiEventWork(CallbackParam* param, std::function workFunc); void NapiCallFunction(CallbackParam* cbParam, size_t argcCount, napi_value* callbackValues); napi_env env_; napi_ref ref_; std::function &infos)> callbackFunction_; std::mutex mutex_; }; } // namespace OHOS::Scan #endif // SCAN_CALLBACK_H