/* * Copyright (C) 2021-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 LOG_TAG #define LOG_TAG "bt_napi_a2dp_snk" #endif #include "bluetooth_a2dp_snk.h" #include "bluetooth_errorcode.h" #include "napi_bluetooth_profile.h" #include "napi_bluetooth_a2dp_snk.h" #include "napi_bluetooth_event.h" #include "napi_bluetooth_error.h" namespace OHOS { namespace Bluetooth { using namespace std; std::shared_ptr NapiA2dpSink::observer_ = std::make_shared(); bool NapiA2dpSink::isRegistered_ = false; void NapiA2dpSink::DefineA2dpSinkJSClass(napi_env env) { napi_value constructor; napi_property_descriptor properties[] = { DECLARE_NAPI_FUNCTION("on", On), DECLARE_NAPI_FUNCTION("off", Off), DECLARE_NAPI_FUNCTION("getConnectionDevices", GetConnectionDevices), DECLARE_NAPI_FUNCTION("getDeviceState", GetDeviceState), DECLARE_NAPI_FUNCTION("getPlayingState", getPlayingState), DECLARE_NAPI_FUNCTION("connect", Connect), DECLARE_NAPI_FUNCTION("disconnect", Disconnect), }; napi_define_class(env, "A2dpSink", NAPI_AUTO_LENGTH, A2dpSinkConstructor, nullptr, sizeof(properties) / sizeof(properties[0]), properties, &constructor); napi_value napiProfile; napi_new_instance(env, constructor, 0, nullptr, &napiProfile); NapiProfile::SetProfile(env, ProfileId::PROFILE_A2DP_SINK, napiProfile); } napi_value NapiA2dpSink::A2dpSinkConstructor(napi_env env, napi_callback_info info) { napi_value thisVar = nullptr; napi_get_cb_info(env, info, nullptr, nullptr, &thisVar, nullptr); return thisVar; } napi_value NapiA2dpSink::On(napi_env env, napi_callback_info info) { if (observer_) { auto status = observer_->eventSubscribe_.Register(env, info); NAPI_BT_ASSERT_RETURN_UNDEF(env, status == napi_ok, BT_ERR_INVALID_PARAM); } if (!isRegistered_) { A2dpSink *profile = A2dpSink::GetProfile(); profile->RegisterObserver(observer_); isRegistered_ = true; } return NapiGetUndefinedRet(env); } napi_value NapiA2dpSink::Off(napi_env env, napi_callback_info info) { if (observer_) { auto status = observer_->eventSubscribe_.Deregister(env, info); NAPI_BT_ASSERT_RETURN_UNDEF(env, status == napi_ok, BT_ERR_INVALID_PARAM); } return NapiGetUndefinedRet(env); } napi_value NapiA2dpSink::GetConnectionDevices(napi_env env, napi_callback_info info) { HILOGI("enter"); napi_value ret = nullptr; napi_create_array(env, &ret); A2dpSink *profile = A2dpSink::GetProfile(); vector states; states.push_back(1); vector devices = profile->GetDevicesByStates(states); vector deviceVector; for (auto &device: devices) { deviceVector.push_back(device.GetDeviceAddr()); } ConvertStringVectorToJS(env, ret, deviceVector); return ret; } napi_value NapiA2dpSink::GetDeviceState(napi_env env, napi_callback_info info) { HILOGI("enter"); size_t expectedArgsCount = ARGS_SIZE_ONE; size_t argc = expectedArgsCount; napi_value argv[ARGS_SIZE_ONE] = {0}; napi_value thisVar = nullptr; napi_value ret = nullptr; napi_get_undefined(env, &ret); napi_get_cb_info(env, info, &argc, argv, &thisVar, nullptr); if (argc != expectedArgsCount) { HILOGE("Requires 1 argument."); return ret; } string deviceId; if (!ParseString(env, deviceId, argv[PARAM0])) { HILOGE("string expected."); return ret; } A2dpSink *profile = A2dpSink::GetProfile(); BluetoothRemoteDevice device(deviceId, 1); int state = profile->GetDeviceState(device); napi_value result = nullptr; int status = GetProfileConnectionState(state); napi_create_int32(env, status, &result); HILOGI("status: %{public}d", status); return result; } napi_value NapiA2dpSink::Connect(napi_env env, napi_callback_info info) { HILOGI("enter"); size_t expectedArgsCount = ARGS_SIZE_ONE; size_t argc = expectedArgsCount; napi_value argv[ARGS_SIZE_ONE] = {0}; napi_value thisVar = nullptr; napi_value ret = nullptr; napi_get_undefined(env, &ret); napi_get_cb_info(env, info, &argc, argv, &thisVar, nullptr); if (argc != expectedArgsCount) { HILOGE("Requires 1 argument."); return ret; } string deviceId; if (!ParseString(env, deviceId, argv[PARAM0])) { HILOGE("string expected."); return ret; } A2dpSink *profile = A2dpSink::GetProfile(); BluetoothRemoteDevice device(deviceId, 1); bool res = profile->Connect(device); napi_value result = nullptr; napi_get_boolean(env, res, &result); HILOGI("res: %{public}d", res); return result; } napi_value NapiA2dpSink::Disconnect(napi_env env, napi_callback_info info) { HILOGI("enter"); size_t expectedArgsCount = ARGS_SIZE_ONE; size_t argc = expectedArgsCount; napi_value argv[ARGS_SIZE_ONE] = {0}; napi_value thisVar = nullptr; napi_value ret = nullptr; napi_get_undefined(env, &ret); napi_get_cb_info(env, info, &argc, argv, &thisVar, nullptr); if (argc != expectedArgsCount) { HILOGE("Requires 1 argument."); return ret; } string deviceId; if (!ParseString(env, deviceId, argv[PARAM0])) { HILOGE("string expected."); return ret; } A2dpSink *profile = A2dpSink::GetProfile(); BluetoothRemoteDevice device(deviceId, 1); bool res = profile->Disconnect(device); napi_value result = nullptr; napi_get_boolean(env, res, &result); HILOGI("res: %{public}d", res); return result; } napi_value NapiA2dpSink::getPlayingState(napi_env env, napi_callback_info info) { HILOGI("enter"); size_t expectedArgsCount = ARGS_SIZE_ONE; size_t argc = expectedArgsCount; napi_value argv[ARGS_SIZE_ONE] = {0}; napi_value thisVar = nullptr; napi_value ret = nullptr; napi_get_undefined(env, &ret); napi_get_cb_info(env, info, &argc, argv, &thisVar, nullptr); if (argc != expectedArgsCount) { HILOGE("Requires 1 argument."); return ret; } string deviceId; if (!ParseString(env, deviceId, argv[PARAM0])) { HILOGE("string expected."); return ret; } A2dpSink *profile = A2dpSink::GetProfile(); BluetoothRemoteDevice device(deviceId, 1); int res = profile->GetPlayingState(device); napi_value result = nullptr; napi_create_int32(env, res, &result); HILOGI("res: %{public}d", res); return result; } } // namespace Bluetooth } // namespace OHOS