sol*_*iCe 6 notification updates apt
我想将具有管理员权限的用户降级为普通用户。
但我想让她继续像以前一样通过 GUI 进行更新。明确地,允许在通过更新通知程序对话框要求时进行更新。
我不知道这是否可能,如果可能,我应该使用哪些 sudo 规则,以便该用户可以进行更新。
我只熟悉apt命令。什么命令/软件用于获取有关更新的通知,然后运行更新过程?
是不是太复杂了,毕竟需要管理权限?
GUI 使用 Polkit 进行身份验证和授权。对于 apt,相关的 Polkit 操作似乎是:
org.debian.apt.cancel-foreign
org.debian.apt.change-config
org.debian.apt.change-repository
org.debian.apt.clean
org.debian.apt.get-trusted-vendor-keys
org.debian.apt.install-file
org.debian.apt.install-or-remove-packages
org.debian.apt.install-packages-from-new-repo
org.debian.apt.install-packages.high-trust-repo
org.debian.apt.install-purchased-packages
org.debian.apt.set-proxy
org.debian.apt.update-cache
org.debian.apt.upgrade-packages
Run Code Online (Sandbox Code Playgroud)
对于快照,您可能还需要以下内容:
io.snapcraft.login
io.snapcraft.snapd.login
io.snapcraft.snapd.manage
io.snapcraft.snapd.manage-interfaces
Run Code Online (Sandbox Code Playgroud)
此外,Ubuntu 软件通过 PackageKit 执行各种操作,因此也可以执行以下操作:
org.freedesktop.packagekit.cancel-foreign
org.freedesktop.packagekit.clear-offline-update
org.freedesktop.packagekit.device-rebind
org.freedesktop.packagekit.package-downgrade
org.freedesktop.packagekit.package-eula-accept
org.freedesktop.packagekit.package-install
org.freedesktop.packagekit.package-install-untrusted
org.freedesktop.packagekit.package-reinstall
org.freedesktop.packagekit.package-remove
org.freedesktop.packagekit.repair-system
org.freedesktop.packagekit.system-network-proxy-configure
org.freedesktop.packagekit.system-sources-configure
org.freedesktop.packagekit.system-sources-refresh
org.freedesktop.packagekit.system-trust-signing-key
org.freedesktop.packagekit.system-update
org.freedesktop.packagekit.trigger-offline-update
org.freedesktop.packagekit.trigger-offline-upgrade
org.freedesktop.packagekit.upgrade-system
Run Code Online (Sandbox Code Playgroud)
对于更新管理器:
com.ubuntu.update-notifier.pkexec.cddistupgrader
com.ubuntu.update-notifier.pkexec.package-system-locked
Run Code Online (Sandbox Code Playgroud)
对于突触:
com.ubuntu.pkexec.synaptic
Run Code Online (Sandbox Code Playgroud)
要配置 Polkit 权限,请.pkla在 / 中创建一个文件etc/polkit-1/localauthority/50-local.d,例如allow-pkg-mgmt.pkla,包含:
[Allow Package Management to user foo]
Identity=unix-user:foo
Action=org.debian.apt.*;io.snapcraft.*;org.freedesktop.packagekit.*;com.ubuntu.update-notifier.*
ResultActive=auth_self
Run Code Online (Sandbox Code Playgroud)
有关man 8 pklocalauthority配置 Polkit 权限的更多信息,以及pkaction更多操作的输出,请参见。出于某种原因,我不得不使用ResultActive而不是ResultAny在它要求非特权用户的密码之前。