Если я попытаюсь использовать sudo kate
для редактирования системного файла, я получаю сообщение:
Выполнение Кейт как root невозможно.
Итак, как мне отредактировать системный файл?
Попробуйте SUDO_EDITOR = kate sudo -e / путь / к / / файл
. Это заставит sudo скопировать файл во временный каталог, ваш редактор будет вызываться как ваш непривилегированный пользователь, а затем, когда редактор вернется (т.е. когда он будет закрыт), он будет скопирован в любое привилегированное место.
Он также работает с любой другой редактор. sudo -e
также может быть записано как sudoedit
.
Просто отредактируйте файл без sudo
. Когда вы закончите, сохраните его как обычно. Вы получите запрос на ввод системного пароля. Поставьте его, и все готово. (Однако это может не работать для некоторых выпусков Ubuntu.)
Вы можете попробовать следующий код и вставить его в сценарий bash. Мотивация была gksudo
с Wayland на Debian Buster.
Я сейчас еще не использую Ubuntu 20.04, поэтому я не тестировал его.
#!/usr/bin/env bash
#
# Enable root access to x-windows system.
#
# Motivation: Trying to run a graphical application as root via su, sudo in a
# Wayland session (e.g. GParted or Gedit), will fail. Apps which use polkit to
# request administrator permissions for just certain operations and only when
# needed are not affected (they are not started as root right away).
# [1] https://bugzilla.redhat.com/show_bug.cgi?id=1274451
#
# Based on a Reddit comment.
# [2] https://www.reddit.com/r/Fedora/comments/5eb633/solution_running_graphical_app_with_sudo_in/
if (( $# != 1 )); then
echo "Illegal number of parameters."
echo
echo "Usage: wsudo [command]"
exit 1
fi
for cmd in sudo xhost; do
if ! type -P $cmd &>/dev/null; then
echo "$cmd it's not installed. Aborting." >&2
exit 1
fi
done
xhost +SI:localuser:root
sudo $1
#disable root access after application terminates
xhost -SI:localuser:root
#print access status to allow verification that root access was removed
xhost