Do all your games need access to your documents, browser history, SSH private keys?
... No? Just run
ego steam
!
Ego is a tool to run Linux desktop applications under a different local user. Currently
integrates with Wayland, Xorg, PulseAudio and xdg-desktop-portal. You may think of it as xhost
for Wayland and PulseAudio. This is done using filesystem ACLs and xhost
command.
Work in progress. :)
Disclaimer: DO NOT RUN UNTRUSTED PROGRAMS VIA EGO. However, using ego is more secure than running applications directly under your primary user.
The goal of ego is to come with sane defaults and be as easy as possible to set up.
Make sure you have Rust installed and run:
cargo install ego sudo cp ~/.cargo/bin/ego /usr/local/bin/
Create local user named "ego": [1]
sudo useradd ego --uid 155 --create-home
That's all, try it:
ego --machinectl xdg-open .
[1] No extra groups are needed by the ego user. UID below 1000 hides this user on the login screen.
If using "machinectl" mode, you need the rather new systemd version >=247 and polkit >=0.106 to do this securely.
Create file /etc/polkit-1/rules.d/50-ego-machinectl.rules
, polkit will automatically load it
(replace <myname>
with your own username):
js
polkit.addRule(function(action, subject) {
if (action.id == "org.freedesktop.machine1.host-shell" &&
action.lookup("user") == "ego" &&
subject.user == "<myname>") {
return polkit.Result.YES;
}
});
For sudo, add the following to /etc/sudoers
(replace <myname>
with your own username):
<myname> ALL=(ego) NOPASSWD:ALL
--machinectl
on Ubuntu, Debian with dash shell (#42)--machinectl-bare
switch.--machinectl
) (#8)--verbose
flag (#4)--user
argument and command-line parsing (#3)Initial version
Ego is licensed under the MIT License (see the LICENSE
file). Ego was created by Marti Raudsepp.
Ego's primary website is at https://github.com/intgr/ego
Thanks to Alexander Payne (myrrlyn) for relinquishing the unused "ego" crate name.