Как редактировать системные файлы с помощью редактора Kate?

Если я попытаюсь использовать sudo kate для редактирования системного файла, я получаю сообщение:

Выполнение Кейт как root невозможно.

Итак, как мне отредактировать системный файл?

3
задан 11 August 2020 в 03:09

3 ответа

Попробуйте SUDO_EDITOR = kate sudo -e / путь / к / / файл . Это заставит sudo скопировать файл во временный каталог, ваш редактор будет вызываться как ваш непривилегированный пользователь, а затем, когда редактор вернется (т.е. когда он будет закрыт), он будет скопирован в любое привилегированное место.

Он также работает с любой другой редактор. sudo -e также может быть записано как sudoedit .

6
ответ дан 11 August 2020 в 20:05

Просто отредактируйте файл без sudo . Когда вы закончите, сохраните его как обычно. Вы получите запрос на ввод системного пароля. Поставьте его, и все готово. (Однако это может не работать для некоторых выпусков Ubuntu.)

9
ответ дан 11 August 2020 в 20:05

Вы можете попробовать следующий код и вставить его в сценарий 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
1
ответ дан 11 August 2020 в 20:05

Другие вопросы по тегам:

Похожие вопросы: