2e67f95017
The rationale is explained in https://planet.kde.org/friedrich-kossebau-2023-06-28-include-also-moc-files-of-headers/ In case of KDEConnect, it impressively speeds up compilation. Before it took 390 seconds on a clean build and with this change it took 330 seconds. This is due to the mocs_compilation having to include the header files and thus all their headers. Due to the lots of small plugins we have, this means that the same headers must be compiled plenty of times. When we include the moc files directly in the C++ file, they are already available.
136 lines
4.6 KiB
C++
136 lines
4.6 KiB
C++
/**
|
|
* SPDX-FileCopyrightText: 2015 Aleix Pol Gonzalez <aleixpol@kde.org>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only OR LicenseRef-KDE-Accepted-GPL
|
|
*/
|
|
|
|
#include "lockdeviceplugin.h"
|
|
|
|
#include <KLocalizedString>
|
|
#include <KPluginFactory>
|
|
|
|
#include "plugin_lock_debug.h"
|
|
#include <QDebug>
|
|
|
|
#include <core/daemon.h>
|
|
#include <core/device.h>
|
|
#include <dbushelper.h>
|
|
|
|
K_PLUGIN_CLASS_WITH_JSON(LockDevicePlugin, "kdeconnect_lockdevice.json")
|
|
|
|
LockDevicePlugin::LockDevicePlugin(QObject *parent, const QVariantList &args)
|
|
: KdeConnectPlugin(parent, args)
|
|
, m_remoteLocked(false)
|
|
, m_login1Interface(QStringLiteral("org.freedesktop.login1"), QStringLiteral("/org/freedesktop/login1/session/auto"), QDBusConnection::systemBus())
|
|
// Connect on all paths since the PropertiesChanged signal is only emitted
|
|
// from /org/freedesktop/login1/session/<sessionId> and not /org/freedesktop/login1/session/auto
|
|
, m_propertiesInterface(QStringLiteral("org.freedesktop.login1"), QString(), QDBusConnection::systemBus())
|
|
{
|
|
if (!m_login1Interface.isValid()) {
|
|
qCWarning(KDECONNECT_PLUGIN_LOCKREMOTE) << "Could not connect to logind interface" << m_login1Interface.lastError();
|
|
}
|
|
|
|
if (!m_propertiesInterface.isValid()) {
|
|
qCWarning(KDECONNECT_PLUGIN_LOCKREMOTE) << "Could not connect to logind properties interface" << m_propertiesInterface.lastError();
|
|
}
|
|
|
|
connect(&m_propertiesInterface,
|
|
&OrgFreedesktopDBusPropertiesInterface::PropertiesChanged,
|
|
this,
|
|
[this](const QString &interface, const QVariantMap &properties, QStringList invalidatedProperties) {
|
|
Q_UNUSED(invalidatedProperties);
|
|
|
|
if (interface != QLatin1String("org.freedesktop.login1.Session")) {
|
|
return;
|
|
}
|
|
|
|
if (!properties.contains(QStringLiteral("LockedHint"))) {
|
|
return;
|
|
}
|
|
|
|
m_localLocked = properties.value(QStringLiteral("LockedHint")).toBool();
|
|
sendState();
|
|
});
|
|
|
|
m_localLocked = m_login1Interface.lockedHint();
|
|
}
|
|
|
|
bool LockDevicePlugin::isLocked() const
|
|
{
|
|
return m_remoteLocked;
|
|
}
|
|
|
|
void LockDevicePlugin::setLocked(bool locked)
|
|
{
|
|
NetworkPacket np(PACKET_TYPE_LOCK_REQUEST, {{QStringLiteral("setLocked"), locked}});
|
|
sendPacket(np);
|
|
}
|
|
|
|
bool LockDevicePlugin::receivePacket(const NetworkPacket &np)
|
|
{
|
|
if (np.has(QStringLiteral("isLocked"))) {
|
|
bool locked = np.get<bool>(QStringLiteral("isLocked"));
|
|
if (m_remoteLocked != locked) {
|
|
m_remoteLocked = locked;
|
|
Q_EMIT lockedChanged(locked);
|
|
}
|
|
}
|
|
|
|
if (np.has(QStringLiteral("requestLocked"))) {
|
|
sendState();
|
|
}
|
|
|
|
// Receiving result of setLocked
|
|
if (np.has(QStringLiteral("lockResult"))) {
|
|
bool lockSuccess = np.get<bool>(QStringLiteral("lockResult"));
|
|
if (lockSuccess) {
|
|
Daemon::instance()->sendSimpleNotification(QStringLiteral("remoteLockSuccess"),
|
|
device()->name(),
|
|
i18n("Remote lock successful"),
|
|
QStringLiteral("lock"));
|
|
} else {
|
|
Daemon::instance()->sendSimpleNotification(QStringLiteral("remoteLockFailure"),
|
|
device()->name(),
|
|
i18n("Remote lock failed"),
|
|
QStringLiteral("error"));
|
|
Daemon::instance()->reportError(device()->name(), i18n("Remote lock failed"));
|
|
}
|
|
}
|
|
|
|
if (np.has(QStringLiteral("setLocked"))) {
|
|
const bool lock = np.get<bool>(QStringLiteral("setLocked"));
|
|
bool success = false;
|
|
if (lock) {
|
|
m_login1Interface.Lock();
|
|
success = m_login1Interface.lockedHint();
|
|
NetworkPacket np(PACKET_TYPE_LOCK, {{QStringLiteral("lockResult"), success}});
|
|
sendPacket(np);
|
|
} else {
|
|
m_login1Interface.Unlock();
|
|
}
|
|
|
|
sendState();
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
void LockDevicePlugin::sendState()
|
|
{
|
|
NetworkPacket np(PACKET_TYPE_LOCK, {{QStringLiteral("isLocked"), m_localLocked}});
|
|
sendPacket(np);
|
|
}
|
|
|
|
void LockDevicePlugin::connected()
|
|
{
|
|
NetworkPacket np(PACKET_TYPE_LOCK_REQUEST, {{QStringLiteral("requestLocked"), QVariant()}});
|
|
sendPacket(np);
|
|
}
|
|
|
|
QString LockDevicePlugin::dbusPath() const
|
|
{
|
|
return QStringLiteral("/modules/kdeconnect/devices/") + device()->id() + QStringLiteral("/lockdevice");
|
|
}
|
|
|
|
#include "lockdeviceplugin.moc"
|
|
#include "moc_lockdeviceplugin.cpp"
|