Невозможно запустить polkit-mate-authentication-agent

Невозможно запустить polkit-mate-authentication-agent

Я использую Mate на Parabola GNU/Linux (на основе Arch). У меня установлен polkit-mate-authentication-agent, и он должен автоматически запускаться при входе в систему; однако, похоже, он не запускается ни автоматически, ни вручную. В моем ~/.xsession-errorsфайле я вижу следующую ошибку:

(polkit-mate-authentication-agent-1:24207): dbind-WARNING **: 07:13:53.904: Couldn't register with
accessibility bus: Did not receive a reply. Possible causes include: the remote application did
not send a reply, the message bus security policy blocked the reply, the reply timeout expired, or 
the network connection was broken.
Cannot register authentication agent: GDBus.Error:org.freedesktop.PolicyKit1.Error.Failed: Cannot 
determine user of subject

Я вижу очень похожую ошибку, если пытаюсь запустить его из терминала, как обычный пользователь или как root. Файл ошибок также показывает предупреждения dbind для многих других пакетов - не знаю, связано ли это как-то. Я использую openrc, а не systemd.

Проблема, похоже, похожа на этот существующий вопрос; однако запуск вручную, похоже, работает, поэтому основная проблема может быть другой:

polkit-gnome-authentication-agent-1 не запускается автоматически после обновления

Есть идеи или предложения?

Редактировать:

Вывод, ps -Af | grep dbusпо-видимому, показывает, что dbus запущен, а демон принадлежит вошедшему в систему пользователю:

$ ps -Af | grep dbus
dbus      1332     1  0 Mar21 ?        00:00:14 /usr/bin/dbus-daemon --system
john     15835 26842  0 10:18 pts/0    00:00:00 grep --color=auto dbus
lightdm  24087     1  0 07:13 ?        00:00:00 dbus-launch --autolaunch 91d1384971b9deaa251b73355e5436ad --binary-syntax --close-stderr
lightdm  24088     1  0 07:13 ?        00:00:00 /usr/bin/dbus-daemon --syslog-only --fork --print-pid 5 --print-address 7 --session
lightdm  24096 24090  0 07:13 ?        00:00:00 /usr/bin/dbus-daemon --config-file=/usr/share/defaults/at-spi2/accessibility.conf --nofork --print-address 3
john     24117     1  0 07:13 ?        00:00:00 dbus-launch --exit-with-session mate-session
john     24118     1  0 07:13 ?        00:00:00 /usr/bin/dbus-daemon --syslog --fork --print-pid 5 --print-address 7 --session

Судя по выходным данным, dbus также, похоже, запущен и работает busctl.

Я также попробовал установить агент аутентификации Gnome ( polkit-gnome) и получаю точно такую ​​же ошибку при попытке запустить его из терминала.

решение1

Я решил эту проблему благодаря совету одного из разработчиков elogind и хочу закрыть эту тему на случай, если у кого-то еще возникнут подобные проблемы:

Проблема была в неправильной конфигурации PAM для менеджера отображения при запуске с elogind, а не с systemd. Конфигурация по умолчанию для моего дистрибутива, похоже, несовместима с elogind. Файлы sddm-greeterи system-loginнеобходимо /etc/pam.dизменить для вызова elogind, а не systemd:

session optional pam_elogind.so

Например, я изменил sddm-greeter на:

#%PAM-1.0

# Load environment from /etc/environment and ~/.pam_environment
auth            required pam_env.so

# Always let the greeter start without authentication
auth            required pam_permit.so

# No action required for account management
account         required pam_permit.so

# Can't change password
password        required pam_deny.so

# Setup session
session         required pam_unix.so
#-session               optional pam_systemd.so
session         optional pam_elogind.so
sddm-greeter (END)

и войдите в систему:

#%PAM-1.0

auth       required   pam_tally2.so        onerr=succeed file=/var/log/tallylog
auth       required   pam_shells.so
auth       requisite  pam_nologin.so
auth       include    system-auth

account    required   pam_tally2.so 
account    required   pam_access.so
account    required   pam_nologin.so
account    include    system-auth

password   include    system-auth

session    optional   pam_loginuid.so
session    optional   pam_keyinit.so       force revoke
session    include    system-auth
session    optional   pam_motd.so          motd=/etc/motd
session    optional   pam_mail.so          dir=/var/spool/mail standard quiet
#-session   optional   pam_systemd.so
session    optional   pam_elogind.so
session    required   pam_env.so
system-login (END)

По сути, я закомментировал строки systemd и заменил их эквивалентами elogind. После этого аутентификация агента polkit заработала нормально.

Связанный контент