Files
MuditaOS/module-apps/application-settings-new/ApplicationSettings.cpp
lblach 76dc6f9f5b [EGD-5771] Create post update info window
Add post update info window.
2021-03-02 09:30:15 +01:00

588 lines
28 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 "ApplicationSettings.hpp"
#include "windows/AddDeviceWindow.hpp"
#include "windows/AllDevicesWindow.hpp"
#include "windows/ApnSettingsWindow.hpp"
#include "windows/ApnOptionsWindow.hpp"
#include "windows/BluetoothWindow.hpp"
#include "windows/SettingsMainWindow.hpp"
#include "windows/DisplayAndKeypadWindow.hpp"
#include "windows/InputLanguageWindow.hpp"
#include "windows/LockedScreenWindow.hpp"
#include "windows/FontSizeWindow.hpp"
#include "windows/DisplayLightWindow.hpp"
#include "windows/KeypadLightWindow.hpp"
#include "windows/AppsAndToolsWindow.hpp"
#include "windows/NightshiftWindow.hpp"
#include "windows/NetworkWindow.hpp"
#include "windows/MessagesWindow.hpp"
#include "windows/PhoneNameWindow.hpp"
#include "windows/AutolockWindow.hpp"
#include "windows/TorchWindow.hpp"
#include "windows/WallpaperWindow.hpp"
#include "windows/QuotesMainWindow.hpp"
#include "windows/QuotesAddWindow.hpp"
#include "windows/SecurityMainWindow.hpp"
#include "windows/QuotesOptionsWindow.hpp"
#include "windows/ChangePasscodeWindow.hpp"
#include "windows/SystemMainWindow.hpp"
#include "windows/NewApnWindow.hpp"
#include "windows/LanguagesWindow.hpp"
#include "windows/DateAndTimeMainWindow.hpp"
#include "windows/ChangeTimeZone.hpp"
#include "windows/ChangeDateAndTimeWindow.hpp"
#include <application-settings-new/models/QuotesRepository.hpp>
#include "Dialog.hpp"
#include "DialogMetadataMessage.hpp"
#include <service-evtmgr/EventManagerServiceAPI.hpp>
#include <service-cellular/CellularServiceAPI.hpp>
#include <service-bluetooth/BluetoothMessage.hpp>
#include <service-bluetooth/Constants.hpp>
#include <service-bluetooth/messages/Status.hpp>
#include <service-bluetooth/messages/BondedDevices.hpp>
#include <service-bluetooth/messages/Connect.hpp>
#include <service-bluetooth/messages/DeviceName.hpp>
#include <service-bluetooth/messages/Passkey.hpp>
#include <service-bluetooth/messages/ResponseVisibleDevices.hpp>
#include <service-bluetooth/messages/Unpair.hpp>
#include <service-db/agents/settings/SystemSettings.hpp>
#include <application-settings-new/data/ApnListData.hpp>
#include <application-settings-new/data/BondedDevicesData.hpp>
#include <application-settings-new/data/BluetoothStatusData.hpp>
#include <application-settings-new/data/DeviceData.hpp>
#include <application-settings-new/data/LanguagesData.hpp>
#include <application-settings-new/data/PhoneNameData.hpp>
#include <module-services/service-db/agents/settings/SystemSettings.hpp>
#include <service-db/Settings.hpp>
#include <i18n/i18n.hpp>
#include <module-services/service-evtmgr/service-evtmgr/ScreenLightControlMessage.hpp>
#include <module-services/service-evtmgr/service-evtmgr/Constants.hpp>
#include <module-services/service-evtmgr/service-evtmgr/EVMessages.hpp>
#include <module-services/service-appmgr/service-appmgr/messages/Message.hpp>
#include <module-services/service-appmgr/service-appmgr/model/ApplicationManager.hpp>
#include <module-apps/application-desktop/windows/PinLockWindow.hpp>
#include <module-apps/application-desktop/windows/Names.hpp>
namespace app
{
namespace settings
{
constexpr inline auto operators_on = "operators_on";
const std::string quotesPath =
purefs::createPath(purefs::dir::getUserDiskPath(), "data/applications/settings/quotes.json");
auto getQuotesModel(Application *app) -> std::unique_ptr<QuotesModel>
{
auto repo = std::make_unique<QuotesJsonRepository>(settings::quotesPath);
return std::make_unique<QuotesModel>(app, std::move(repo));
}
} // namespace settings
ApplicationSettingsNew::ApplicationSettingsNew(std::string name,
std::string parent,
StartInBackground startInBackground)
: Application(std::move(name), std::move(parent), startInBackground)
{
if ((Store::GSM::SIM::SIM1 == selectedSim || Store::GSM::SIM::SIM2 == selectedSim) &&
Store::GSM::get()->sim == selectedSim) {
selectedSimNumber = CellularServiceAPI::GetOwnNumber(this);
}
}
ApplicationSettingsNew::~ApplicationSettingsNew()
{}
// Invoked upon receiving data message
auto ApplicationSettingsNew::DataReceivedHandler(sys::DataMessage *msgl,
[[maybe_unused]] sys::ResponseMessage *resp) -> sys::MessagePointer
{
auto retMsg = Application::DataReceivedHandler(msgl);
// if message was handled by application's template there is no need to process further.
auto rm = dynamic_cast<sys::ResponseMessage *>(retMsg.get());
if (nullptr != rm && sys::ReturnCodes::Success == rm->retCode) {
return retMsg;
}
if (auto phoneMsg = dynamic_cast<CellularNotificationMessage *>(msgl); nullptr != phoneMsg) {
selectedSim = Store::GSM::get()->selected;
if (CellularNotificationMessage::Type::SIM_READY == phoneMsg->type) {
selectedSimNumber = CellularServiceAPI::GetOwnNumber(this);
}
else if (CellularNotificationMessage::Type::SIM_NOT_READY == phoneMsg->type) {
selectedSimNumber = {};
}
auto currentWindow = getCurrentWindow();
if (gui::window::name::network == currentWindow->getName()) {
currentWindow->rebuild();
}
}
return sys::MessageNone{};
}
// Invoked during initialization
auto ApplicationSettingsNew::InitHandler() -> sys::ReturnCodes
{
board = EventManagerServiceAPI::GetBoard(this);
auto ret = Application::InitHandler();
if (ret != sys::ReturnCodes::Success) {
return ret;
}
connect(typeid(::message::bluetooth::ResponseStatus), [&](sys::Message *msg) {
auto responseStatusMsg = static_cast<::message::bluetooth::ResponseStatus *>(msg);
if (gui::window::name::bluetooth == getCurrentWindow()->getName()) {
const auto status = responseStatusMsg->getStatus();
auto btStatusData = std::make_unique<gui::BluetoothStatusData>(status.state, status.visibility);
switchWindow(gui::window::name::bluetooth, std::move(btStatusData));
}
return sys::MessageNone{};
});
connect(typeid(::message::bluetooth::ResponseDeviceName), [&](sys::Message *msg) {
auto responseDeviceNameMsg = static_cast<::message::bluetooth::ResponseDeviceName *>(msg);
if (gui::window::name::phone_name == getCurrentWindow()->getName()) {
auto phoneNameData = std::make_unique<gui::PhoneNameData>(responseDeviceNameMsg->getName());
switchWindow(gui::window::name::phone_name, std::move(phoneNameData));
}
return sys::MessageNone{};
});
connect(typeid(::message::bluetooth::ResponseBondedDevices), [&](sys::Message *msg) {
auto responseBondedDevicesMsg = static_cast<::message::bluetooth::ResponseBondedDevices *>(msg);
if (gui::window::name::all_devices == getCurrentWindow()->getName()) {
auto bondedDevicesData = std::make_unique<gui::BondedDevicesData>(
responseBondedDevicesMsg->getDevices(), responseBondedDevicesMsg->getAddressOfConnectedDevice());
switchWindow(gui::window::name::all_devices, std::move(bondedDevicesData));
}
return sys::MessageNone{};
});
connect(typeid(::message::bluetooth::ResponseVisibleDevices), [&](sys::Message *msg) {
auto responseVisibleDevicesMsg = static_cast<::message::bluetooth::ResponseVisibleDevices *>(msg);
if (gui::window::name::add_device == getCurrentWindow()->getName() ||
gui::window::name::dialog_settings == getCurrentWindow()->getName()) {
auto visibleDevicesData = std::make_unique<gui::DeviceData>(responseVisibleDevicesMsg->getDevices());
if (gui::window::name::dialog_settings == getCurrentWindow()->getName()) {
visibleDevicesData->ignoreCurrentWindowOnStack = true;
}
switchWindow(gui::window::name::add_device, std::move(visibleDevicesData));
}
return sys::MessageNone{};
});
connect(typeid(BluetoothPairResultMessage), [&](sys::Message *msg) {
auto bluetoothPairResultMsg = static_cast<BluetoothPairResultMessage *>(msg);
if (bluetoothPairResultMsg->status) {
return sys::MessageNone{};
}
const std::string toReplace = "%NAME";
std::string pairingErrorMessage = utils::localize.get("app_settings_bluetooth_pairing_error_message");
pairingErrorMessage.replace(
pairingErrorMessage.find(toReplace), toReplace.size(), bluetoothPairResultMsg->name);
switchWindow(
gui::window::name::dialog_retry,
gui::ShowMode::GUI_SHOW_INIT,
std::make_unique<gui::DialogMetadataMessage>(gui::DialogMetadata{
utils::localize.get("app_settings_bt"), "search_big", pairingErrorMessage, "", [=]() -> bool {
bus.sendUnicast(std::make_shared<BluetoothPairMessage>(std::move(bluetoothPairResultMsg->addr)),
service::name::bluetooth);
return true;
}}));
return sys::MessageNone{};
});
connect(typeid(::message::bluetooth::RequestPasskey), [&](sys::Message *msg) {
switchWindow(gui::window::name::bluetooth_check_passkey);
return sys::MessageNone{};
});
connect(typeid(::message::bluetooth::UnpairResult), [&](sys::Message *msg) {
auto unpairResultMsg = static_cast<::message::bluetooth::UnpairResult *>(msg);
if (unpairResultMsg->isSucceed()) {
return sys::MessageNone{};
}
bus.sendUnicast(std::make_shared<::message::bluetooth::RequestBondedDevices>(), service::name::bluetooth);
switchWindow(gui::window::name::dialog_retry,
gui::ShowMode::GUI_SHOW_INIT,
std::make_unique<gui::DialogMetadataMessage>(
gui::DialogMetadata{utils::localize.get("app_settings_bt"),
"search_big",
utils::localize.get("app_settings_bluetooth_unpairing_error_message"),
"",
[=]() -> bool {
bus.sendUnicast(std::make_shared<message::bluetooth::Unpair>(
unpairResultMsg->getAddr()),
service::name::bluetooth);
return true;
}}));
return sys::MessageNone{};
});
connect(typeid(::message::bluetooth::ConnectResult), [&](sys::Message *msg) {
auto connectResultMsg = static_cast<::message::bluetooth::ConnectResult *>(msg);
if (connectResultMsg->isSucceed()) {
bus.sendUnicast(std::make_shared<::message::bluetooth::RequestBondedDevices>(),
service::name::bluetooth);
return sys::MessageNone{};
}
switchWindow(gui::window::name::dialog_retry,
gui::ShowMode::GUI_SHOW_INIT,
std::make_unique<gui::DialogMetadataMessage>(
gui::DialogMetadata{utils::localize.get("app_settings_bt"),
"search_big",
utils::localize.get("app_settings_bluetooth_connecting_error_message"),
"",
[=]() -> bool {
bus.sendUnicast(std::make_shared<message::bluetooth::Connect>(
connectResultMsg->getAddr()),
service::name::bluetooth);
return true;
}}));
return sys::MessageNone{};
});
connect(typeid(CellularGetAPNResponse), [&](sys::Message *msg) {
if (gui::window::name::apn_settings == getCurrentWindow()->getName()) {
auto apns = dynamic_cast<CellularGetAPNResponse *>(msg);
if (apns != nullptr) {
auto apnsData = std::make_unique<gui::ApnListData>(apns->getAPNs());
switchWindow(gui::window::name::apn_settings, std::move(apnsData));
}
}
return sys::MessageNone{};
});
connect(typeid(manager::GetCurrentDisplayLanguageResponse), [&](sys::Message *msg) {
if (gui::window::name::languages == getCurrentWindow()->getName()) {
auto response = dynamic_cast<manager::GetCurrentDisplayLanguageResponse *>(msg);
if (response != nullptr) {
auto languagesData = std::make_unique<LanguagesData>(response->getLanguage());
switchWindow(gui::window::name::languages, std::move(languagesData));
}
}
return sys::MessageNone{};
});
createUserInterface();
setActiveWindow(gui::name::window::main_window);
settings->registerValueChange(settings::operators_on,
[this](const std::string &value) { operatorOnChanged(value); });
settings->registerValueChange(
::settings::Cellular::volte_on,
[this](const std::string &value) { volteChanged(value); },
::settings::SettingsScope::Global);
settings->registerValueChange(
::settings::SystemProperties::lockPassHash,
[this](const std::string &value) { lockPassHash = utils::getNumericValue<unsigned int>(value); },
::settings::SettingsScope::Global);
settings->registerValueChange(
::settings::Bluetooth::state,
[this](const std::string &value) {
if (gui::window::name::bluetooth == getCurrentWindow()->getName()) {
const auto isBtOn = utils::getNumericValue<bool>(value);
auto btStatusData = std::make_unique<gui::BluetoothStatusData>(
isBtOn ? BluetoothStatus::State::On : BluetoothStatus::State::Off);
switchWindow(gui::window::name::bluetooth, std::move(btStatusData));
}
},
::settings::SettingsScope::Global);
settings->registerValueChange(
::settings::Bluetooth::deviceVisibility,
[this](const std::string &value) {
if (gui::window::name::bluetooth == getCurrentWindow()->getName()) {
const auto isVisible = utils::getNumericValue<bool>(value);
auto btStatusData = std::make_unique<gui::BluetoothStatusData>(isVisible);
switchWindow(gui::window::name::bluetooth, std::move(btStatusData));
}
},
::settings::SettingsScope::Global);
/*
settings->registerValueChange(
::settings::SystemProperties::usbSecurity,
[this](std::string value) { usbSecured = utils::getNumericValue<bool>(value); },
::settings::SettingsScope::Global);
*/
return ret;
}
void ApplicationSettingsNew::createUserInterface()
{
windowsFactory.attach(gui::name::window::main_window, [](Application *app, const std::string &name) {
return std::make_unique<gui::OptionWindow>(
app, utils::localize.get("app_settings_title_main"), mainWindowOptionsNew(app));
});
windowsFactory.attach(gui::window::name::bluetooth, [](Application *app, const std::string &name) {
return std::make_unique<gui::BluetoothWindow>(app);
});
windowsFactory.attach(gui::window::name::add_device, [](Application *app, const std::string &name) {
return std::make_unique<gui::AddDeviceWindow>(app);
});
windowsFactory.attach(gui::window::name::all_devices, [](Application *app, const std::string &name) {
return std::make_unique<gui::AllDevicesWindow>(app);
});
windowsFactory.attach(gui::window::name::dialog_settings, [](Application *app, const std::string &name) {
return std::make_unique<gui::Dialog>(app, name);
});
windowsFactory.attach(gui::window::name::display_and_keypad, [](Application *app, const std::string &name) {
return std::make_unique<gui::DisplayAndKeypadWindow>(app);
});
windowsFactory.attach(gui::window::name::input_language, [](Application *app, const std::string &name) {
return std::make_unique<gui::InputLanguageWindow>(app);
});
windowsFactory.attach(gui::window::name::locked_screen, [](Application *app, const std::string &name) {
return std::make_unique<gui::LockedScreenWindow>(app);
});
windowsFactory.attach(gui::window::name::keypad_light, [](Application *app, const std::string &name) {
return std::make_unique<gui::KeypadLightWindow>(app, static_cast<ApplicationSettingsNew *>(app));
});
windowsFactory.attach(gui::window::name::font_size, [](Application *app, const std::string &name) {
return std::make_unique<gui::FontSizeWindow>(app);
});
windowsFactory.attach(gui::window::name::display_light, [](Application *app, const std::string &name) {
return std::make_unique<gui::DisplayLightWindow>(app, static_cast<ApplicationSettingsNew *>(app));
});
windowsFactory.attach(gui::window::name::apps_and_tools, [](Application *app, const std::string &name) {
return std::make_unique<gui::AppsAndToolsWindow>(app);
});
windowsFactory.attach(gui::window::name::nightshift, [](Application *app, const std::string &name) {
return std::make_unique<gui::NightshiftWindow>(app);
});
windowsFactory.attach(gui::window::name::network, [](Application *app, const std::string &name) {
return std::make_unique<gui::NetworkWindow>(
app, static_cast<ApplicationSettingsNew *>(app), static_cast<ApplicationSettingsNew *>(app));
});
windowsFactory.attach(gui::window::name::apn_settings, [](Application *app, const std::string &name) {
return std::make_unique<gui::ApnSettingsWindow>(app);
});
windowsFactory.attach(gui::window::name::apn_options, [](Application *app, const std::string &name) {
return std::make_unique<gui::ApnOptionsWindow>(app);
});
windowsFactory.attach(gui::window::name::messages, [](Application *app, const std::string &name) {
return std::make_unique<gui::MessagesWindow>(app);
});
windowsFactory.attach(gui::window::name::phone_name, [](Application *app, const std::string &name) {
return std::make_unique<gui::PhoneNameWindow>(app);
});
windowsFactory.attach(gui::window::name::autolock, [](Application *app, const std::string &name) {
return std::make_unique<gui::AutolockWindow>(app);
});
windowsFactory.attach(gui::window::name::torch, [](Application *app, const std::string &name) {
return std::make_unique<gui::TorchWindow>(app);
});
windowsFactory.attach(gui::window::name::wallpaper, [](Application *app, const std::string &name) {
return std::make_unique<gui::WallpaperWindow>(app);
});
windowsFactory.attach(gui::window::name::quotes_dialog_yes_no, [](Application *app, const std::string &name) {
return std::make_unique<gui::DialogYesNo>(app, name);
});
windowsFactory.attach(gui::window::name::security, [](Application *app, const std::string &name) {
return std::make_unique<gui::SecurityMainWindow>(app, static_cast<ApplicationSettingsNew *>(app));
});
windowsFactory.attach(app::window::name::desktop_pin_lock, [&](Application *app, const std::string newname) {
return std::make_unique<gui::PinLockWindow>(app, app::window::name::desktop_pin_lock);
});
windowsFactory.attach(gui::window::name::change_passcode, [](Application *app, const std::string &name) {
return std::make_unique<gui::ChangePasscodeWindow>(app);
});
windowsFactory.attach(gui::window::name::dialog_confirm, [](Application *app, const std::string &name) {
return std::make_unique<gui::DialogConfirm>(app, gui::window::name::dialog_confirm);
});
windowsFactory.attach(gui::window::name::system, [](Application *app, const std::string &name) {
return std::make_unique<gui::SystemMainWindow>(app);
});
windowsFactory.attach(gui::window::name::new_apn, [](Application *app, const std::string &name) {
return std::make_unique<gui::NewApnWindow>(app);
});
windowsFactory.attach(gui::window::name::languages, [](Application *app, const std::string &name) {
return std::make_unique<gui::LanguagesWindow>(app);
});
windowsFactory.attach(gui::window::name::date_and_time, [](Application *app, const std::string &name) {
return std::make_unique<gui::DateAndTimeMainWindow>(app);
});
windowsFactory.attach(gui::window::name::change_time_zone, [](Application *app, const std::string &name) {
return std::make_unique<gui::ChangeTimeZone>(app);
});
windowsFactory.attach(gui::window::name::change_date_and_time, [](Application *app, const std::string &name) {
return std::make_unique<gui::ChangeDateAndTimeWindow>(app);
});
windowsFactory.attach(gui::window::name::dialog_retry, [](Application *app, const std::string &name) {
return std::make_unique<gui::DialogRetry>(app, name);
});
windowsFactory.attach(gui::window::name::quotes, [](Application *app, const std::string &name) {
return std::make_unique<gui::QuotesMainWindow>(app, std::move(settings::getQuotesModel(app)));
});
windowsFactory.attach(gui::window::name::new_quote, [](Application *app, const std::string &name) {
return std::make_unique<gui::QuoteAddEditWindow>(app, std::move(settings::getQuotesModel(app)));
});
windowsFactory.attach(gui::window::name::options_quote, [](Application *app, const std::string &name) {
return std::make_unique<gui::QuotesOptionsWindow>(app, std::move(settings::getQuotesModel(app)));
});
}
void ApplicationSettingsNew::destroyUserInterface()
{}
std::string ApplicationSettingsNew::getNumber()
{
return selectedSimNumber;
}
void ApplicationSettingsNew::setSim(Store::GSM::SIM sim)
{
CellularServiceAPI::SetSimCard(this, sim);
}
Store::GSM::SIM ApplicationSettingsNew::getSim()
{
return selectedSim;
}
void ApplicationSettingsNew::operatorOnChanged(const std::string &value)
{
LOG_DEBUG("[ApplicationSettingsNew::operatorOnChanged] value=%s", value.c_str());
if (!value.empty()) {
operatorsOn = utils::getNumericValue<bool>(value);
}
}
bool ApplicationSettingsNew::getOperatorsOn() const noexcept
{
LOG_DEBUG("[ApplicationSettingsNew::getOperatorsOn] %d", operatorsOn);
return operatorsOn;
}
void ApplicationSettingsNew::setOperatorsOn(bool value)
{
operatorsOn = value;
LOG_DEBUG("[ApplicationSettingsNew::setOperatorsOn] to %d", operatorsOn);
settings->setValue(settings::operators_on, std::to_string(static_cast<int>(value)));
}
void ApplicationSettingsNew::setVoLTEOn(bool value)
{
voLteStateOn = value;
CellularServiceAPI::SetVoLTE(this, voLteStateOn);
};
bool ApplicationSettingsNew::getVoLTEOn() const noexcept
{
return voLteStateOn;
}
void ApplicationSettingsNew::volteChanged(const std::string &value)
{
if (!value.empty()) {
voLteStateOn = utils::getNumericValue<bool>(value);
}
}
void ApplicationSettingsNew::setOsUpdateVersion(const std::string &value)
{
LOG_DEBUG("[ApplicationSettingsNew::setOsUpdateVersion] to value=%s", value.c_str());
settings->setValue(::settings::SystemProperties::osUpdateVersion, value, ::settings::SettingsScope::Global);
}
void ApplicationSettingsNew::setLockPassHash(unsigned int value)
{
lockPassHash = value;
settings->setValue(
::settings::SystemProperties::lockPassHash, std::to_string(value), ::settings::SettingsScope::Global);
}
auto ApplicationSettingsNew::getCurrentValues() -> settingsInterface::ScreenLightSettings::Values
{
constexpr int timeout = pdMS_TO_TICKS(1500);
auto response = bus.sendUnicast(
std::make_shared<sevm::ScreenLightControlRequestParameters>(), service::name::evt_manager, timeout);
if (response.first == sys::ReturnCodes::Success) {
auto msgState = dynamic_cast<sevm::ScreenLightControlParametersResponse *>(response.second.get());
if (msgState == nullptr) {
return {};
}
return {msgState->lightOn, msgState->mode, msgState->parameters};
}
return {};
}
void ApplicationSettingsNew::setBrightness(bsp::eink_frontlight::BrightnessPercentage value)
{
screen_light_control::Parameters parameters{value};
bus.sendUnicast(std::make_shared<sevm::ScreenLightControlMessage>(
screen_light_control::Action::setManualModeBrightness, parameters),
service::name::evt_manager);
}
void ApplicationSettingsNew::setMode(bool isAutoLightSwitchOn)
{
bus.sendUnicast(std::make_shared<sevm::ScreenLightControlMessage>(
isAutoLightSwitchOn ? screen_light_control::Action::enableAutomaticMode
: screen_light_control::Action::disableAutomaticMode),
service::name::evt_manager);
}
void ApplicationSettingsNew::setStatus(bool isDisplayLightSwitchOn)
{
bus.sendUnicast(std::make_shared<sevm::ScreenLightControlMessage>(isDisplayLightSwitchOn
? screen_light_control::Action::turnOn
: screen_light_control::Action::turnOff),
service::name::evt_manager);
}
auto ApplicationSettingsNew::isKeypadBacklightOn() -> bool
{
constexpr int timeout = pdMS_TO_TICKS(1500);
auto response =
bus.sendUnicast(std::make_shared<sevm::KeypadBacklightMessage>(bsp::keypad_backlight::Action::checkState),
service::name::evt_manager,
timeout);
if (response.first == sys::ReturnCodes::Success) {
auto msgState = dynamic_cast<sevm::KeypadBacklightResponseMessage *>(response.second.get());
if (msgState == nullptr) {
return false;
}
return msgState->success;
}
return false;
}
void ApplicationSettingsNew::setKeypadBacklightState(bool newState)
{
bus.sendUnicast(std::make_shared<sevm::KeypadBacklightMessage>(
newState ? bsp::keypad_backlight::Action::turnOn : bsp::keypad_backlight::Action::turnOff),
service::name::evt_manager);
}
bool ApplicationSettingsNew::isUSBSecured() const
{
return usbSecured;
}
void ApplicationSettingsNew::setUSBSecurity(bool security)
{
usbSecured = security;
settings->setValue(
::settings::SystemProperties::usbSecurity, std::to_string(security), ::settings::SettingsScope::Global);
}
} /* namespace app */