-
Notifications
You must be signed in to change notification settings - Fork 142
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
Add ability to drop privileges when launching X server #127
base: main
Are you sure you want to change the base?
Conversation
* NULL is not required by section 6.3.2.3(3-4) of the C99 standard
Just a note that it doesn't look like that CI build test failure was an issue with this pull request. The Fedora build was fine. The Ubuntu build seems to have hung configuring the build environment without ever actually reaching the build step. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The polling for the socket is a bit flaky, there's actually another method supported by Xorg:
-displayfd fd file descriptor to write display number to when ready to connect
Will this work in your case? I didn't implement this originally because the feature was relatively new and not necessarily supported. But it might be reasonable to expect if you're already requiring X to work with dropped privileges.
This change should also have a test case, but I'm happy to help out with that if you have trouble working out how to do that.
GStatBuf statbuf; | ||
g_autofree gchar *socketpath = g_strdup_printf ("/tmp/.X11-unix/X%d", priv->display_number); | ||
|
||
if ( g_stat (socketpath, &statbuf) == 0 ) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Extra whitespace here doesn't match existing code.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe you mean blank like 405. I've deleted it. Please let me know if this wasn't it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I mean it should change from if ( g_stat (socketpath, &statbuf) == 0 )
to if (g_stat (socketpath, &statbuf) == 0)
Hi, as a Debian maintainer I'll try to test the patch and report back, not for the XVnc part but rather for the whole “deprivilege X” thing. We have https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=809067 opened which I fowarded to https://bugs.launchpad.net/lightdm/+bug/1292324 on Launchpad but that bug was never migrated to github I think (although there is #18 ) |
* A depriviledged X cannot send back a SIGUSR1 when it is ready
85af646
to
1e59ef4
Compare
@corsac-s Although most of the changes were made at the A similar configuration option and |
@robert-ancell I think it is reasonable if this requires a newer Xorg. I'll see what I can do with regard to the |
Just a note that the
|
Looking at the xorg source: else if (argv[i][0] == ':') {
/* initialize display */
display = argv[i];
explicit_display = TRUE; else if ((displayfd < 0) || explicit_display) {
if (TryCreateSocket(atoi(display), &partial) &&
ListenTransCount >= 1)
if (!PartialNetwork && partial)
FatalError ("Failed to establish all listening sockets");
}
else { /* -displayfd and no explicit display number */
Bool found = 0;
for (i = 0; i < 65536 - X_TCP_PORT; i++) {
if (TryCreateSocket(i, &partial) && !partial) {
found = 1;
break;
} If you pass a display number (as we do in LightDM) it won't try to pick it's own. I'm pretty sure I got this to work in the past so it should work fine. |
Thanks for looking into that Robert. I will work to incorporate this as the display-server-has-started check instead of polling for the socket file. Just a heads up that it may take awhile as I am now heavily involved in another project, but I will push the results here when done. 😄 |
@corsac-s I spent a bit of time reading up on how the whole seat thing and such is all done. The best resource I found was this https://dvdhrm.wordpress.com/2013/08/24/session-management-on-linux/ and combined with the fact that I believe I saw session dbus calls in the lightdm code, I think there is a reasonable chance that my device ownership and such concerns are null and void. |
So that would only leave the specific option and the |
When is this shipping? :( I had to uninstall lightdm to make xorg run as nonroot. |
is it possible to use the |
The developers wanted a better detection for when X11 is ready for connections than socket polling (see above comment about Hopefully I'll have some time at some point in the future here. It likely won't be in the nearish future, though, so, if anyone else is feeling up for it, go for it! |
@twhitehead Hi! Is there still any effort on this? |
@zWhdmB5T it is something I would like to do sometime, not sure if it will ever get up high enough on my priority list to get done though... |
We recently experienced a local root escalation issue, and our security team identified one possible avenue for the issue having been one of these security bugs in the tigervnc server along with the fact that it was running as root despite just being a glorified in memory frame buffer
https://access.redhat.com/errata/RHSA-2020:1497
We've patched it, but, to protect against any further such attacks in the future, I also went ahead and added the ability for lightdm to drop privileges when forking local X servers
The option is exposed as a
[VNCServer]
user
setting, it's not VNC specific. The mechanism was added entirely to the x-server-local and process infrastructures, so it would be pretty trivial to apply it to the X sever proper too (which I've heard can now run without root in some cases too).I did have to rebase my original commits (which I tested) due to a recent commit that removed the cached priv pointers x-server-local and process, changing many lines of
sever->priv->...
to justpriv->...
. It was a pretty trivial fix, so I haven't verified it beyond that fact that it compiles.