Files
MuditaOS/module-bluetooth/Bluetooth/CommandHandler.cpp
SP2FET fa24dcc829 [EGD-5483] Updated BT harness tests
Added harness test for BT scan in order to be able
to test regression
2021-02-11 11:48:07 +01:00

110 lines
3.5 KiB
C++

// Copyright (c) 2017-2021, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
#include "CommandHandler.hpp"
#include <utility>
#include <service-bluetooth/ServiceBluetooth.hpp>
#include "Device.hpp"
#include "BtCommand.hpp"
namespace bluetooth
{
namespace
{
[[nodiscard]] auto toString(bluetooth::Error::Code code) -> std::string
{
return utils::enumToString(code);
}
} // namespace
CommandHandler::CommandHandler(sys::Service *service,
std::shared_ptr<bluetooth::SettingsHolder> settings,
std::shared_ptr<bluetooth::Profile> currentProfile,
std::shared_ptr<bluetooth::Driver> driver)
: service{service}, settings{std::move(settings)}, currentProfile{std::move(currentProfile)}, driver{std::move(
driver)}
{}
Error::Code CommandHandler::handle(Command command)
{
switch (command) {
case bluetooth::PowerOn:
return Error::Success;
case bluetooth::StartScan:
return scan();
case bluetooth::StopScan:
return stopScan();
case bluetooth::StartPan:
return startPan();
case bluetooth::VisibilityOn:
return setVisibility(true);
case bluetooth::VisibilityOff:
return setVisibility(false);
case bluetooth::ConnectAudio:
return establishAudioConnection();
case bluetooth::DisconnectAudio:
return disconnectAudioConnection();
case bluetooth::PowerOff:
return Error::Success;
}
return Error::LibraryError;
}
Error::Code CommandHandler::scan()
{
if (const auto ret = driver->scan(); ret.err != bluetooth::Error::Success) {
LOG_ERROR("Cant start scan!: %s %" PRIu32 "", toString(ret.err).c_str(), ret.lib_code);
return ret.err;
}
LOG_INFO("Scan started!");
static_cast<ServiceBluetooth *>(service)->scanStartedCallback();
// open new scan window
return Error::Success;
}
Error::Code CommandHandler::stopScan()
{
driver->stopScan();
static_cast<ServiceBluetooth *>(service)->scanStoppedCallback();
return Error::Success;
}
Error::Code CommandHandler::startPan()
{
bluetooth::PAN::bnep_setup();
if (const auto err = bluetooth::PAN::bnep_start(); err.err != bluetooth::Error::Success) {
LOG_ERROR("PAN setup error: %s %" PRIu32, toString(err.err).c_str(), err.lib_code);
return err.err;
}
return bluetooth::Error::Success;
}
Error::Code CommandHandler::setVisibility(bool visibility)
{
driver->setVisibility(visibility);
settings->setValue(bluetooth::Settings::Visibility, static_cast<int>(visibility));
return Error::Success;
}
Error::Code CommandHandler::establishAudioConnection()
{
currentProfile->setOwnerService(service);
if (const auto status = currentProfile->init(); status != bluetooth::Error::Success) {
return status;
}
currentProfile->connect();
return Error::Success;
}
Error::Code CommandHandler::disconnectAudioConnection()
{
currentProfile->disconnect();
return Error::Success;
}
} // namespace bluetooth