Чому pkexec віддається перевагу над gksudo для графічних додатків?


10

Будь ласка, надайте документацію Ubuntu, яка спростовує це: https://help.ubuntu.com/community/RootSudo Чому в моїй повністю оновленій системі 13.04 pkexec не функціонує?

$ pkexec gedit somefile.txt
No protocol specified

** (gedit:13135): WARNING **: Could not open X display
Cannot open display: 
Run '/usr/bin/gedit --help' to see a full list of available command line options


pkexec не є краплею заміни gksu. Ви не призначені для того, щоб ви вручну бігали так.
psusi

2
Я не питав ні про гксу.
chili555

Дуже хороша відповідь про створення pkexecграфічного інтерфейсу без налаштування: askubuntu.com/a/332847/89385
akostadinov

Встановіть policykit-1-gnome. Дивіться тут для подробиць і пояснень.
user303371

Відповіді:


7

Чому це не працює?

За замовчуванням pkexecне дозволяє запускати графічні програми (X11). На чоловіковій сторінці:

 The environment that PROGRAM will run it, will be set to a minimal
 known and safe environment in order to avoid injecting code through
 LD_LIBRARY_PATH or similar mechanisms. In addition the PKEXEC_UID
 environment variable is set to the user id of the process invoking
 pkexec.
     As a result, pkexec will not allow you to run X11 applications
     as another user since the $DISPLAY and $XAUTHORITY environment
     variables are not set.
 These two variables will be retained if the
 org.freedesktop.policykit.exec.allow_gui annotation on an action is set
 to a nonempty value; this is discouraged, though, and should only be
 used for legacy programs.

Як зазначено на сторінці чоловіка, ви можете змусити його працювати, хоча я справді не знаю, чи це якось небезпечно чи рекомендується .

Наприклад, щоб увімкнути gedit, ви можете створити /usr/share/polkit-1/actions/com.ubuntu.gedit.policyтакий вміст:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE policyconfig PUBLIC
 "-//freedesktop//DTD PolicyKit Policy Configuration 1.0//EN"
 "http://www.freedesktop.org/standards/PolicyKit/1.0/policyconfig.dtd">
<policyconfig>
  <vendor>gedit</vendor>
  <vendor_url>gedit</vendor_url>
  <icon_name>accessories-text-editor</icon_name>
  <action id="org.freedesktop.policykit.pkexec.gedit">
   <description>Run "gedit"</description>
   <message>Authentication is required to run Text Editor</message>
   <defaults>
     <allow_any>auth_admin</allow_any>
     <allow_inactive>auth_admin</allow_inactive>
     <allow_active>auth_admin</allow_active>
   </defaults>
     <annotate key="org.freedesktop.policykit.exec.path">/usr/bin/gedit</annotate>
     <annotate key="org.freedesktop.policykit.exec.allow_gui">true</annotate>
   </action>  
</policyconfig>

Тоді pkexec geditслід працювати, як очікувалося:

введіть тут опис зображення

Як ви здогадаєтесь, це лише зробить geditроботу. Теоретично, якщо ви додали allow_guiдо "org.freedesktop.policykit.exec" (дію за замовчуванням), це повинно працювати для всіх програм, але в моїх тестах я отримав такий же результат, як і ваш.

Чому pkexec кращий?

Тут ви можете знайти дискусію про сильні сторони pkexec.


3
Отже, для графічних застосувань переважним є gksudo, а НЕ pkexec?
chili555

1
Я так гадаю. Якщо gksudoвін доступний, використовувати його набагато простіше, а не створювати окремі дії для кожного додатка, який потрібно використовувати (якщо немає "глобального" способу зробити це).
Салем

1
@ Salem - Тоді мені цікаво, чому моя відповідь була відредагована та схвалена для використання pkexec, коли вона не призначена для використання у графічних додатках і, як ви можете прочитати, не працювала. askubuntu.com/questions/313619/… Має бути щось, чого я не розумію.
chili555

@ chili555 Якщо ця редакція мотивувала ваше запитання, ви повинні задати це питання в Meta. У 13.04 вам або доведеться встановити gksudoабо налаштувати pkexec(ви також можете використовувати, sudo -iале це не буде працювати з Alt + F2 aka "Run"). Перше МНЕ простіше. Якщо хтось думає інакше добре ... Мені здається неправильним підказувати щось, що не працюватиме за призначенням, але я можу щось пропустити ...
Салем

1
pkexecнасправді можна запустити графічний інтерфейс без конфігурації: askubuntu.com/a/332847/89385
akostadinov
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.