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

sshd: label sshd-session as sshd_exec_t #793

Merged
merged 1 commit into from
Jul 10, 2024

Conversation

0xC0ncord
Copy link
Contributor

OpenSSH 9.8 splits out much of the session code from the main sshd binary into a new sshd-session binary. Allow the sshd server to execute this binary by labeling it as sshd_exec_t.

OpenSSH 9.8 splits out much of the session code from the main sshd
binary into a new sshd-session binary. Allow the sshd server to execute
this binary by labeling it as sshd_exec_t.

Signed-off-by: Kenton Groombridge <[email protected]>
@pebenito
Copy link
Member

pebenito commented Jul 9, 2024

I'm not clear what specifically what the session parts are. If the login/password checking and SELinux login context lookup+setexeccon() are separated from the networking code, it could be worth making a more significant policy revision.

@0xC0ncord
Copy link
Contributor Author

From the changelog:

  • sshd(8): the server has been split into a listener binary, sshd(8),
    and a per-session binary "sshd-session". This allows for a much
    smaller listener binary, as it no longer needs to support the SSH
    protocol. As part of this work, support for disabling privilege
    separation (which previously required code changes to disable) and
    disabling re-execution of sshd(8) has been removed. Further
    separation of sshd-session into additional, minimal binaries is
    planned for the future.

In short, historically the sshd binary would fork a copy of itself when a user logs into a system. This still happens, but the forked binary is now a separate one which lacks any privileged code.

If the login/password checking and SELinux login context lookup+setexeccon() are separated from the networking code, it could be worth making a more significant policy revision.

I haven't looked into all the exact behavior that sshd-session does yet, but if this is the case I agree. However, I strongly recommend we merge this for now and we can make a Github issue to track a possible larger policy revision. Without this change, ssh login is completely broken with OpenSSH 9.8 on refpolicy.

@pebenito pebenito merged commit b65469f into SELinuxProject:main Jul 10, 2024
117 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants