kdeconnect-kde/plugins/lockdevice/lockdeviceplugin.cpp

133 lines
4.5 KiB
C++
Raw Normal View History

/**
* 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_lockdevice_debug.h"
#include <QDebug>
#include <core/daemon.h>
#include <core/device.h>
2019-06-09 16:28:49 +01:00
#include <dbushelper.h>
2019-06-12 21:16:54 +01:00
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_LOCKDEVICE) << "Could not connect to logind interface" << m_login1Interface.lastError();
}
if (!m_propertiesInterface.isValid()) {
qCWarning(KDECONNECT_PLUGIN_LOCKDEVICE) << "Could not connect to logind properties interface" << m_propertiesInterface.lastError();
}
connect(&m_propertiesInterface,
&OrgFreedesktopDBusPropertiesInterface::PropertiesChanged,
this,
[this](const QString &interface, const QVariantMap &properties) {
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);
}
void 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();
}
}
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"