pmaports/kde/kwin/D6291.patch

359 lines
19 KiB
Diff
Raw Normal View History

diff --git a/logind.h b/logind.h
--- a/logind.h
+++ b/logind.h
@@ -78,6 +78,11 @@
explicit LogindIntegration(const QDBusConnection &connection, QObject *parent = nullptr);
void logindServiceRegistered();
void connectSessionPropertiesChanged();
+ enum SessionController {
+ SessionControllerLogind,
+ SessionControllerConsoleKit,
+ };
+ void setupSessionController(SessionController controller);
void getSeat();
QDBusConnection m_bus;
QDBusServiceWatcher *m_logindServiceWatcher;
@@ -87,6 +92,13 @@
bool m_sessionActive;
int m_vt = -1;
QString m_seatPath;
+ QString m_sessionControllerName;
+ QString m_sessionControllerService;
+ QString m_sessionControllerPath;
+ QString m_sessionControllerManagerInterface;
+ QString m_sessionControllerSeatInterface;
+ QString m_sessionControllerSessionInterface;
+ QString m_sessionControllerActivateProperty;
KWIN_SINGLETON(LogindIntegration)
};
diff --git a/logind.cpp b/logind.cpp
--- a/logind.cpp
+++ b/logind.cpp
@@ -58,12 +58,26 @@
namespace KWin
{
+const static QString s_login1Name = QStringLiteral("logind");
const static QString s_login1Service = QStringLiteral("org.freedesktop.login1");
const static QString s_login1Path = QStringLiteral("/org/freedesktop/login1");
const static QString s_login1ManagerInterface = QStringLiteral("org.freedesktop.login1.Manager");
+const static QString s_login1SeatInterface = QStringLiteral("org.freedesktop.login1.Seat");
const static QString s_login1SessionInterface = QStringLiteral("org.freedesktop.login1.Session");
+const static QString s_login1ActivateProperty = QStringLiteral("Activate");
+
+const static QString s_ck2Name = QStringLiteral("ConsoleKit");
+const static QString s_ck2Service = QStringLiteral("org.freedesktop.ConsoleKit");
+const static QString s_ck2Path = QStringLiteral("/org/freedesktop/ConsoleKit/Manager");
+const static QString s_ck2ManagerInterface = QStringLiteral("org.freedesktop.ConsoleKit.Manager");
+const static QString s_ck2SeatInterface = QStringLiteral("org.freedesktop.ConsoleKit.Seat");
+const static QString s_ck2SessionInterface = QStringLiteral("org.freedesktop.ConsoleKit.Session");
+const static QString s_ck2ActivateProperty = QStringLiteral("activate");
+
const static QString s_dbusPropertiesInterface = QStringLiteral("org.freedesktop.DBus.Properties");
+
+
LogindIntegration *LogindIntegration::s_self = nullptr;
LogindIntegration *LogindIntegration::create(QObject *parent)
@@ -76,22 +90,10 @@
LogindIntegration::LogindIntegration(const QDBusConnection &connection, QObject *parent)
: QObject(parent)
, m_bus(connection)
- , m_logindServiceWatcher(new QDBusServiceWatcher(s_login1Service,
- m_bus,
- QDBusServiceWatcher::WatchForUnregistration | QDBusServiceWatcher::WatchForRegistration,
- this))
, m_connected(false)
, m_sessionControl(false)
, m_sessionActive(false)
{
- connect(m_logindServiceWatcher, &QDBusServiceWatcher::serviceRegistered, this, &LogindIntegration::logindServiceRegistered);
- connect(m_logindServiceWatcher, &QDBusServiceWatcher::serviceUnregistered, this,
- [this]() {
- m_connected = false;
- emit connectedChanged();
- }
- );
-
// check whether the logind service is registered
QDBusMessage message = QDBusMessage::createMethodCall(QStringLiteral("org.freedesktop.DBus"),
QStringLiteral("/"),
@@ -107,8 +109,11 @@
return;
}
if (reply.value().contains(s_login1Service)) {
- logindServiceRegistered();
+ setupSessionController(SessionControllerLogind);
+ } else if (reply.value().contains(s_ck2Service)) {
+ setupSessionController(SessionControllerConsoleKit);
}
+
}
);
}
@@ -123,6 +128,53 @@
s_self = nullptr;
}
+void LogindIntegration::setupSessionController(SessionController controller)
+{
+ if (controller == SessionControllerLogind) {
+ // We have the logind serivce, set it up and use it
+ m_sessionControllerName = s_login1Name;
+ m_sessionControllerService = s_login1Service;
+ m_sessionControllerPath = s_login1Path;
+ m_sessionControllerManagerInterface = s_login1ManagerInterface;
+ m_sessionControllerSeatInterface = s_login1SeatInterface;
+ m_sessionControllerSessionInterface = s_login1SessionInterface;
+ m_sessionControllerActivateProperty = s_login1ActivateProperty;
+ m_logindServiceWatcher = new QDBusServiceWatcher(m_sessionControllerService,
+ m_bus,
+ QDBusServiceWatcher::WatchForUnregistration | QDBusServiceWatcher::WatchForRegistration,
+ this);
+ connect(m_logindServiceWatcher, &QDBusServiceWatcher::serviceRegistered, this, &LogindIntegration::logindServiceRegistered);
+ connect(m_logindServiceWatcher, &QDBusServiceWatcher::serviceUnregistered, this,
+ [this]() {
+ m_connected = false;
+ emit connectedChanged();
+ }
+ );
+ logindServiceRegistered();
+ } else if (controller == SessionControllerConsoleKit) {
+ // We have the ConsoleKit serivce, set it up and use it
+ m_sessionControllerName = s_ck2Name;
+ m_sessionControllerService = s_ck2Service;
+ m_sessionControllerPath = s_ck2Path;
+ m_sessionControllerManagerInterface = s_ck2ManagerInterface;
+ m_sessionControllerSeatInterface = s_ck2SeatInterface;
+ m_sessionControllerSessionInterface = s_ck2SessionInterface;
+ m_sessionControllerActivateProperty = s_ck2ActivateProperty;
+ m_logindServiceWatcher = new QDBusServiceWatcher(m_sessionControllerService,
+ m_bus,
+ QDBusServiceWatcher::WatchForUnregistration | QDBusServiceWatcher::WatchForRegistration,
+ this);
+ connect(m_logindServiceWatcher, &QDBusServiceWatcher::serviceRegistered, this, &LogindIntegration::logindServiceRegistered);
+ connect(m_logindServiceWatcher, &QDBusServiceWatcher::serviceUnregistered, this,
+ [this]() {
+ m_connected = false;
+ emit connectedChanged();
+ }
+ );
+ logindServiceRegistered();
+ }
+}
+
void LogindIntegration::logindServiceRegistered()
{
const QByteArray sessionId = qgetenv("XDG_SESSION_ID");
@@ -136,9 +188,9 @@
args << QString::fromLocal8Bit(sessionId);
}
// get the current session
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
- s_login1Path,
- s_login1ManagerInterface,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
+ m_sessionControllerPath,
+ m_sessionControllerManagerInterface,
methodName);
message.setArguments(args);
QDBusPendingReply<QDBusObjectPath> session = m_bus.asyncCall(message);
@@ -151,17 +203,17 @@
return;
}
if (!reply.isValid()) {
- qCDebug(KWIN_CORE) << "The session is not registered with logind" << reply.error().message();
+ qCDebug(KWIN_CORE) << "The session is not registered with " << m_sessionControllerName << " " << reply.error().message();
return;
}
m_sessionPath = reply.value().path();
qCDebug(KWIN_CORE) << "Session path:" << m_sessionPath;
m_connected = true;
connectSessionPropertiesChanged();
// activate the session, in case we are not on it
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_sessionPath,
- s_login1SessionInterface,
+ m_sessionControllerSessionInterface,
QStringLiteral("Activate"));
// blocking on purpose
m_bus.call(message);
@@ -176,13 +228,13 @@
void LogindIntegration::connectSessionPropertiesChanged()
{
- m_bus.connect(s_login1Service,
+ m_bus.connect(m_sessionControllerService,
m_sessionPath,
s_dbusPropertiesInterface,
QStringLiteral("PropertiesChanged"),
this,
SLOT(getSessionActive()));
- m_bus.connect(s_login1Service,
+ m_bus.connect(m_sessionControllerService,
m_sessionPath,
s_dbusPropertiesInterface,
QStringLiteral("PropertiesChanged"),
@@ -195,19 +247,19 @@
if (!m_connected || m_sessionPath.isEmpty()) {
return;
}
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_sessionPath,
s_dbusPropertiesInterface,
QStringLiteral("Get"));
- message.setArguments(QVariantList({s_login1SessionInterface, QStringLiteral("Active")}));
+ message.setArguments(QVariantList({m_sessionControllerSessionInterface, m_sessionControllerActivateProperty}));
QDBusPendingReply<QVariant> reply = m_bus.asyncCall(message);
QDBusPendingCallWatcher *watcher = new QDBusPendingCallWatcher(reply, this);
connect(watcher, &QDBusPendingCallWatcher::finished, this,
[this](QDBusPendingCallWatcher *self) {
QDBusPendingReply<QVariant> reply = *self;
self->deleteLater();
if (!reply.isValid()) {
- qCDebug(KWIN_CORE) << "Failed to get Active Property of logind session:" << reply.error().message();
+ qCDebug(KWIN_CORE) << "Failed to get Active Property of " << m_sessionControllerName << " session:" << reply.error().message();
return;
}
const bool active = reply.value().toBool();
@@ -224,19 +276,19 @@
if (!m_connected || m_sessionPath.isEmpty()) {
return;
}
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_sessionPath,
s_dbusPropertiesInterface,
QStringLiteral("Get"));
- message.setArguments(QVariantList({s_login1SessionInterface, QStringLiteral("VTNr")}));
+ message.setArguments(QVariantList({m_sessionControllerSessionInterface, QStringLiteral("VTNr")}));
QDBusPendingReply<QVariant> reply = m_bus.asyncCall(message);
QDBusPendingCallWatcher *watcher = new QDBusPendingCallWatcher(reply, this);
connect(watcher, &QDBusPendingCallWatcher::finished, this,
[this](QDBusPendingCallWatcher *self) {
QDBusPendingReply<QVariant> reply = *self;
self->deleteLater();
if (!reply.isValid()) {
- qCDebug(KWIN_CORE) << "Failed to get VTNr Property of logind session:" << reply.error().message();
+ qCDebug(KWIN_CORE) << "Failed to get VTNr Property of " << m_sessionControllerName << " session:" << reply.error().message();
return;
}
const int vt = reply.value().toUInt();
@@ -259,9 +311,9 @@
}
s_recursionCheck = true;
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_sessionPath,
- s_login1SessionInterface,
+ m_sessionControllerSessionInterface,
QStringLiteral("TakeControl"));
message.setArguments(QVariantList({QVariant(false)}));
QDBusPendingReply<void> session = m_bus.asyncCall(message);
@@ -279,8 +331,8 @@
qCDebug(KWIN_CORE) << "Gained session control";
m_sessionControl = true;
emit hasSessionControlChanged(true);
- m_bus.connect(s_login1Service, m_sessionPath,
- s_login1SessionInterface, QStringLiteral("PauseDevice"),
+ m_bus.connect(m_sessionControllerService, m_sessionPath,
+ m_sessionControllerSessionInterface, QStringLiteral("PauseDevice"),
this, SLOT(pauseDevice(uint,uint,QString)));
}
);
@@ -292,9 +344,9 @@
return;
}
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_sessionPath,
- s_login1SessionInterface,
+ m_sessionControllerSessionInterface,
QStringLiteral("ReleaseControl"));
m_bus.asyncCall(message);
m_sessionControl = false;
@@ -308,9 +360,9 @@
qCDebug(KWIN_CORE) << "Could not stat the path";
return -1;
}
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_sessionPath,
- s_login1SessionInterface,
+ m_sessionControllerSessionInterface,
QStringLiteral("TakeDevice"));
message.setArguments(QVariantList({QVariant(major(st.st_rdev)), QVariant(minor(st.st_rdev))}));
// intended to be a blocking call
@@ -329,9 +381,9 @@
qCDebug(KWIN_CORE) << "Could not stat the file descriptor";
return;
}
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_sessionPath,
- s_login1SessionInterface,
+ m_sessionControllerSessionInterface,
QStringLiteral("ReleaseDevice"));
message.setArguments(QVariantList({QVariant(major(st.st_rdev)), QVariant(minor(st.st_rdev))}));
m_bus.asyncCall(message);
@@ -341,7 +393,7 @@
{
if (QString::compare(type, QStringLiteral("pause"), Qt::CaseInsensitive) == 0) {
// unconditionally call complete
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service, m_sessionPath, s_login1SessionInterface, QStringLiteral("PauseDeviceComplete"));
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService, m_sessionPath, m_sessionControllerSessionInterface, QStringLiteral("PauseDeviceComplete"));
message.setArguments(QVariantList({QVariant(devMajor), QVariant(devMinor)}));
m_bus.asyncCall(message);
}
@@ -353,24 +405,26 @@
return;
}
qDBusRegisterMetaType<DBusLogindSeat>();
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_sessionPath,
s_dbusPropertiesInterface,
QStringLiteral("Get"));
- message.setArguments(QVariantList({s_login1SessionInterface, QStringLiteral("Seat")}));
+ message.setArguments(QVariantList({m_sessionControllerSessionInterface, QStringLiteral("Seat")}));
+ message.setArguments(QVariantList({m_sessionControllerSessionInterface, QStringLiteral("Seat")}));
QDBusPendingReply<QVariant> reply = m_bus.asyncCall(message);
QDBusPendingCallWatcher *watcher = new QDBusPendingCallWatcher(reply, this);
connect(watcher, &QDBusPendingCallWatcher::finished, this,
[this](QDBusPendingCallWatcher *self) {
QDBusPendingReply<QVariant> reply = *self;
self->deleteLater();
if (!reply.isValid()) {
- qCDebug(KWIN_CORE) << "Failed to get Seat Property of logind session:" << reply.error().message();
+ qCDebug(KWIN_CORE) << "Failed to get Seat Property of " << m_sessionControllerName << " session:" << reply.error().message();
return;
}
DBusLogindSeat seat = qdbus_cast<DBusLogindSeat>(reply.value().value<QDBusArgument>());
const QString seatPath = seat.path.path();
- qCDebug(KWIN_CORE) << "Logind seat:" << seat.name << "/" << seatPath;
+ qCDebug(KWIN_CORE) << m_sessionControllerName << " seat:" << seat.name << "/" << seatPath;
+ qCDebug(KWIN_CORE) << m_sessionControllerName << " seat:" << seat.name << "/" << seatPath;
if (m_seatPath != seatPath) {
m_seatPath = seatPath;
}
@@ -383,9 +437,9 @@
if (!m_connected || m_seatPath.isEmpty()) {
return;
}
- QDBusMessage message = QDBusMessage::createMethodCall(s_login1Service,
+ QDBusMessage message = QDBusMessage::createMethodCall(m_sessionControllerService,
m_seatPath,
- QStringLiteral("org.freedesktop.login1.Seat"),
+ m_sessionControllerSeatInterface,
QStringLiteral("SwitchTo"));
message.setArguments(QVariantList{vtNr});
m_bus.asyncCall(message);