Use XDG Desktop Portal to autostart the flatpak

This commit is contained in:
Mathieu Oriol 2024-04-08 00:10:19 +02:00 committed by Jonathan White
parent 5b123e7944
commit d0e9f133b1
4 changed files with 59 additions and 0 deletions

View File

@ -97,6 +97,9 @@ static const QHash<Config::ConfigKey, ConfigDirective> configStrings = {
{Config::GUI_HidePreviewPanel, {QS("GUI/HidePreviewPanel"), Roaming, false}}, {Config::GUI_HidePreviewPanel, {QS("GUI/HidePreviewPanel"), Roaming, false}},
{Config::GUI_AlwaysOnTop, {QS("GUI/GUI_AlwaysOnTop"), Local, false}}, {Config::GUI_AlwaysOnTop, {QS("GUI/GUI_AlwaysOnTop"), Local, false}},
{Config::GUI_ToolButtonStyle, {QS("GUI/ToolButtonStyle"), Roaming, Qt::ToolButtonIconOnly}}, {Config::GUI_ToolButtonStyle, {QS("GUI/ToolButtonStyle"), Roaming, Qt::ToolButtonIconOnly}},
#ifdef KEEPASSXC_DIST_FLATPAK
{Config::GUI_LaunchAtStartup, {QS("GUI/LaunchAtStartup"), Roaming, false}},
#endif
{Config::GUI_ShowTrayIcon, {QS("GUI/ShowTrayIcon"), Roaming, false}}, {Config::GUI_ShowTrayIcon, {QS("GUI/ShowTrayIcon"), Roaming, false}},
{Config::GUI_TrayIconAppearance, {QS("GUI/TrayIconAppearance"), Roaming, {}}}, {Config::GUI_TrayIconAppearance, {QS("GUI/TrayIconAppearance"), Roaming, {}}},
{Config::GUI_MinimizeToTray, {QS("GUI/MinimizeToTray"), Roaming, false}}, {Config::GUI_MinimizeToTray, {QS("GUI/MinimizeToTray"), Roaming, false}},

View File

@ -79,6 +79,9 @@ public:
GUI_HidePreviewPanel, GUI_HidePreviewPanel,
GUI_AlwaysOnTop, GUI_AlwaysOnTop,
GUI_ToolButtonStyle, GUI_ToolButtonStyle,
#ifdef KEEPASSXC_DIST_FLATPAK
GUI_LaunchAtStartup,
#endif
GUI_ShowTrayIcon, GUI_ShowTrayIcon,
GUI_TrayIconAppearance, GUI_TrayIconAppearance,
GUI_MinimizeToTray, GUI_MinimizeToTray,

View File

@ -27,6 +27,10 @@
#include <QStandardPaths> #include <QStandardPaths>
#include <QStyle> #include <QStyle>
#include <QTextStream> #include <QTextStream>
#ifdef KEEPASSXC_DIST_FLATPAK
#include "core/Config.h"
#include <QRandomGenerator>
#endif
#ifdef WITH_XC_X11 #ifdef WITH_XC_X11
#include <QX11Info> #include <QX11Info>
@ -123,12 +127,17 @@ QString NixUtils::getAutostartDesktopFilename(bool createDirs) const
bool NixUtils::isLaunchAtStartupEnabled() const bool NixUtils::isLaunchAtStartupEnabled() const
{ {
#if !defined(KEEPASSXC_DIST_FLATPAK)
return QFile::exists(getAutostartDesktopFilename()); return QFile::exists(getAutostartDesktopFilename());
; ;
#else
return config()->get(Config::GUI_LaunchAtStartup).toBool();
#endif
} }
void NixUtils::setLaunchAtStartup(bool enable) void NixUtils::setLaunchAtStartup(bool enable)
{ {
#if !defined(KEEPASSXC_DIST_FLATPAK)
if (enable) { if (enable) {
QFile desktopFile(getAutostartDesktopFilename(true)); QFile desktopFile(getAutostartDesktopFilename(true));
if (!desktopFile.open(QIODevice::WriteOnly)) { if (!desktopFile.open(QIODevice::WriteOnly)) {
@ -163,6 +172,49 @@ void NixUtils::setLaunchAtStartup(bool enable)
} else if (isLaunchAtStartupEnabled()) { } else if (isLaunchAtStartupEnabled()) {
QFile::remove(getAutostartDesktopFilename()); QFile::remove(getAutostartDesktopFilename());
} }
#else
QDBusConnection sessionBus = QDBusConnection::sessionBus();
QDBusMessage msg = QDBusMessage::createMethodCall("org.freedesktop.portal.Desktop",
"/org/freedesktop/portal/desktop",
"org.freedesktop.portal.Background",
"RequestBackground");
QMap<QString, QVariant> options;
options["autostart"] = QVariant(enable);
options["reason"] = QVariant("Launch KeePassXC at startup");
int token = QRandomGenerator::global()->bounded(1000, 9999);
options["handle_token"] = QVariant(QString("org/keepassxc/KeePassXC/%1").arg(token));
msg << "" << options;
QDBusMessage response = sessionBus.call(msg);
QDBusObjectPath handle = response.arguments().at(0).value<QDBusObjectPath>();
bool res = sessionBus.connect("org.freedesktop.portal.Desktop",
handle.path(),
"org.freedesktop.portal.Request",
"Response",
this,
SLOT(launchAtStartupRequested(uint, QVariantMap)));
if (!res) {
qDebug() << "Could not connect to org.freedesktop.portal.Request::Response signal";
}
#endif
}
void NixUtils::launchAtStartupRequested(uint response, const QVariantMap& results)
{
if (response > 0) {
qDebug() << "The interaction was cancelled";
return;
}
bool isLauchedAtStartup = results["autostart"].value<bool>();
qDebug() << "The autostart value is set to:" << isLauchedAtStartup;
#if defined(KEEPASSXC_DIST_FLATPAK)
config()->set(Config::GUI_LaunchAtStartup, isLauchedAtStartup);
#endif
} }
bool NixUtils::isCapslockEnabled() bool NixUtils::isCapslockEnabled()

View File

@ -54,6 +54,7 @@ public:
private slots: private slots:
void handleColorSchemeRead(QDBusVariant value); void handleColorSchemeRead(QDBusVariant value);
void handleColorSchemeChanged(QString ns, QString key, QDBusVariant value); void handleColorSchemeChanged(QString ns, QString key, QDBusVariant value);
void launchAtStartupRequested(uint response, const QVariantMap& results);
private: private:
explicit NixUtils(QObject* parent = nullptr); explicit NixUtils(QObject* parent = nullptr);