/* kcmsmserver.cpp SPDX-FileCopyrightText: 2000, 2002 Oswald Buddenhagen based on kcmtaskbar.cpp SPDX-FileCopyrightText: 2000 Kurt Granroth SPDX-FileCopyrightText: 2019 Kevin Ottens SPDX-FileCopyrightText: 2020 Carl Schwan SPDX-License-Identifier: GPL-2.0-or-later */ #include #include #include #include #include #include #include #include #include #include "kcmsmserver.h" #include "smserverdata.h" #include "smserversettings.h" #include #include #include "login1_manager.h" K_PLUGIN_FACTORY_WITH_JSON(SMServerConfigFactory, "kcm_smserver.json", registerPlugin(); registerPlugin();) SMServerConfig::SMServerConfig(QObject *parent, const KPluginMetaData &metaData) : KQuickManagedConfigModule(parent, metaData) , m_login1Manager(new OrgFreedesktopLogin1ManagerInterface(QStringLiteral("org.freedesktop.login1"), QStringLiteral("/org/freedesktop/login1"), QDBusConnection::systemBus(), this)) { auto settings = new SMServerSettings(this); qmlRegisterSingletonInstance("org.kde.desktopsession.private", 1, 0, "Settings", settings); checkFirmwareSetupRequested(); m_restartInSetupScreenInitial = m_restartInSetupScreen; setButtons(Help | Apply | Default); const QString canFirmwareSetup = m_login1Manager->CanRebootToFirmwareSetup().value(); if (canFirmwareSetup == QLatin1String("yes") || canFirmwareSetup == QLatin1String("challenge")) { m_canFirmwareSetup = true; // now check whether we're UEFI to provide a more descriptive button label if (QFileInfo(QStringLiteral("/sys/firmware/efi")).isDir()) { m_isUefi = true; } } } SMServerConfig::~SMServerConfig() = default; bool SMServerConfig::isUefi() const { return m_isUefi; } bool SMServerConfig::restartInSetupScreen() const { return m_restartInSetupScreen; } void SMServerConfig::setRestartInSetupScreen(bool restartInSetupScreen) { if (m_restartInSetupScreen == restartInSetupScreen) { return; } QDBusMessage message = QDBusMessage::createMethodCall(m_login1Manager->service(), m_login1Manager->path(), m_login1Manager->interface(), QStringLiteral("SetRebootToFirmwareSetup")); message.setArguments({restartInSetupScreen}); // This cannot be set through a generated DBus interface, so we have to create the message ourself. message.setInteractiveAuthorizationAllowed(true); QDBusPendingReply call = m_login1Manager->connection().asyncCall(message); QDBusPendingCallWatcher *callWatcher = new QDBusPendingCallWatcher(call, this); connect(callWatcher, &QDBusPendingCallWatcher::finished, this, [this, restartInSetupScreen](QDBusPendingCallWatcher *watcher) { QDBusPendingReply reply = *watcher; watcher->deleteLater(); checkFirmwareSetupRequested(); settingsChanged(); if (reply.isError()) { // User likely canceled the PolKit prompt, don't show an error in this case if (reply.error().type() != QDBusError::AccessDenied) { m_error = reply.error().message(); Q_EMIT errorChanged(); } return; } else if (m_error.length() > 0) { m_error = QString(); Q_EMIT errorChanged(); } m_restartInSetupScreen = restartInSetupScreen; Q_EMIT restartInSetupScreenChanged(); if (!restartInSetupScreen) { return; } }); } QString SMServerConfig::error() const { return m_error; } void SMServerConfig::reboot() { auto sm = new SessionManagement(this); auto doShutdown = [sm]() { sm->requestReboot(); delete sm; }; if (sm->state() == SessionManagement::State::Loading) { connect(sm, &SessionManagement::stateChanged, this, doShutdown); } else { doShutdown(); } } void SMServerConfig::checkFirmwareSetupRequested() { m_restartInSetupScreen = m_login1Manager->property("RebootToFirmwareSetup").toBool(); Q_EMIT restartInSetupScreenChanged(); } bool SMServerConfig::canFirmwareSetup() const { return m_canFirmwareSetup; } bool SMServerConfig::isSaveNeeded() const { return m_restartInSetupScreen != m_restartInSetupScreenInitial; } bool SMServerConfig::isDefaults() const { return !m_restartInSetupScreen; } void SMServerConfig::defaults() { KQuickManagedConfigModule::defaults(); setRestartInSetupScreen(false); } void SMServerConfig::save() { KQuickManagedConfigModule::save(); Q_EMIT ksmserverSettingsChanged(); } #include "kcmsmserver.moc"