Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Feature Request] Support matching by user name (not just user ID) and/or cgroup name #1116

Open
quentinmit opened this issue Apr 5, 2024 · 1 comment
Labels
feature a whole new feature

Comments

@quentinmit
Copy link

Summary:

systemd often uses dynamically-chosen UIDs for services (DynamicUser=yes). This means that rules matching with the uid operand will no longer match when a service/the system is next restarted and the process gets a newly-assigned uid. As a consequence, I have to allow a binary for all users on the system, instead of just allowing a daemon user to make connections with a binary.

At process discovery, OpenSnitch should use user.LookupId(uid) to look up the name currently assigned to a uid, and allow the result to be matched with an operand.

In addition, or perhaps in lieu, it would be helpful to match by a process's cgroup name. systemd will assign a unique cgroup to each service, so this would ensure that even if a process happens to somehow be launched as the correct user, it will still not be able to evade rules. This information is available in /proc/$pid/cgroup. For example:

$ cat /proc/$(systemctl show -P ExecMainPID sshd)/cgroup
0::/system.slice/sshd.service
$ cat /proc/self/cgroup 
0::/user.slice/user-1000.slice/user@1000.service/app.slice/app-konsole-3d42e27e456a4ce9a1ad5982ed8f6a33.scope

This could be especially useful for desktop apps, because you could allow wget to be used from Konsole without also allowing it to be used by Spotify.

@gustavo-iniguez-goya
Copy link
Collaborator

I've added option to filter by user name.

However in the scenario described, using DynamicUser=, it won't work. On the one hand because usernames are allocated dynamically and doesn't exist in the system, so user.LookupId() won't find it when loading the rule.

On the other hand, if User= is specified and it doesn't exist in the system, user.LookupId() won't find the UID for the same reason.

https://cs.opensource.google/go/go/+/master:src/os/user/lookup_unix.go;l=218?q=lookupUser&sq=&ss=go%2Fgo
https://cs.opensource.google/go/go/+/master:src/os/user/lookup.go;l=10?q=userFile&ss=go%2Fgo

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature a whole new feature
Projects
None yet
Development

No branches or pull requests

2 participants