NewsLab
Jun 28 17:20 UTC

Enhancing x11 Application Security with LXC (2025) (dobrowolski.dev)

72 points|by shirozuki||60 comments|Read full story on dobrowolski.dev

Comments (60)

60 shown
  1. 1. LtWorf||context
    Or one could just use firejail, which comes with a number of pre made profiles for common applications.
  2. 2. nosioptar||context
    The sandbox command works well on systems using SELinux.

    https://docs.redhat.com/en/documentation/red_hat_enterprise_...

  3. 3. calvinmorrison||context
    Xlibre (the only current actively developed implementation of a X11 server) has a new extension - XNamespace to address some challenges as well.

    https://github.com/X11Libre/xserver/blob/master/doc/Xnamespa...

  4. 4. Chu4eeno||context
    Not the only one, there's also a new one (written in zig) I've forgot the name of.

    edit: phoenix was the name: https://github.com/external-mirrors/phoenix#phoenix

  5. 5. mappu||context
    There's also this new one: https://github.com/joske/yserver
  6. 6. asveikau||context
    Hard for me to take that one seriously.. For example they call out byte swapping for endianness as the type of cruft holding back X11. Such a trivial thing to be concerned enough to put in the readme... (I guess Phoenix is also putting this..) Seems like mostly authored by Claude too.
  7. 7. shevy-java||context
    > Seems like mostly authored by Claude too.

    This is a problem in many projects now. xserver and mruby for instance also succumbed to claude. It seems claude is the ultimate virus. It leaks into almost every project now. So I am not sure it can be used as differentiating criterium here merely for being claude AI slop. I've noticed a lot of documentation is now totally useless though; claude slop is just unreadable to me. It's like a person who is not able to think, wrote the documentation. I did not have this issue back when real humans wrote documentation, even though high quality documentation was always rare anyway. But, for instance, Jeremy Evans in his projects tends to write high-quality documentation in general, and I can understand it fine, whereas if you look at matz spinel, I have no idea what the AI slop in the README is really trying to convey. Or on ffmpeg, a german dev used AI slop to try to create some proposal, and someone else pointed out that this is pointless and impossible to read and understand, yet the original guy did not understand why real people don't want to be AI slop spammed. It's very strange.

  8. 8. lotharcable||context
    XWayland is actively developed.

    XFree86, which is the "standalone DDX" you see on X11 desktops, is being actively maintained.

  9. 9. sunshine-o||context
    This is a great article.

    I have little experience with lxc but I guess waypipe could be an option too.

  10. 10. mid-kid||context
    For an article written late last year I hoped for a little more awareness of how massive a security hole granting full, unfiltered access to the X11 server is. Granted, any sandboxing is better than none, but firefox is one of the few apps that already sandboxes itself really well, and with a blog title like that it might be good to touch upon things like nested X servers such as Xephyr.
  11. 11. BobbyTables2||context
    Yeah, sadly Firefox and Chrome want almost full privileges so that they can sandbox themselves.

    X itself always bothers me. Xeyes is cute until one considers the practical implications…

  12. 12. enriquto||context
    > Xeyes is cute until one considers the practical implications…

    what's the problem with xeyes? it reads data on your computer and displays it. Just like vim or cat.

    If, for some reason, you want to run a program that you don't trust, you should sandbox it from the outside. But granting full rights to distro-provided programs like vim or xeyes is perfectly sane. Just like you trust your kernel.

  13. 13. throwaway7356||context
    > But granting full rights to distro-provided programs like vim or xeyes is perfectly sane.

    You mean run everything distro-provided as root?

    There are reasons systems don't do that any more. Even distro-provided services are often setup in a way to no run with full rights. Can you imaging reasons why this is done?

    What was neglected is doing the same on user level, which should be done for pretty much the same reasons.

  14. 14. orangeboats||context
    > But granting full rights to distro-provided programs like vim or xeyes is perfectly sane

    Saying this after the whole XZ utils ordeal has happened is quite interesting.

    Can you really guarantee that your distro is not compromised? And if it is compromised, how can you easily _discover_ that a program is doing something strange?

    X11 (the one that most people are familiar with, not the locked down one with X security -- because the latter introduces compatibility issues) does not have an access control model where programs can request for specific permissions.

    In other words, xeyes would just work(TM) without the user granting it permission to read global mouse pointer position. And simultaneously, the same is true for $compromised_distro_provided_program.

  15. 15. TZubiri||context
    > the whole XZ ordeal

    1 malicious package almost got distributed in 20 years of debian history?

    >granting full rights to vim or xeyes

    I'm not sure I get what's being discussed here. Standard Xorg runs without root already. And Xeyes definitely 100% run without root, I get why you would you run vim on root, to edit root files, but also don't? Especially if you have plugins, run simple programs like echo>> , ed, grep or nano.

  16. 16. orangeboats||context
    Obviously, XZ happened on Debian. But $malware can occur on any Linux distribution at any time. For a recent example just look at Arch Linux.

    Also, are we still assuming that we would still get only one attack over 20 years, instead of the frequency increasing to, say, one attack per year?

    ---

    But those are not my original point, XZ utils was just an example.

    My original point is that: why should we not practice defense-in-depth, where we make sure malwares have to jump through multiple hoops (and hope that they trip on one of them!) in order to launch an attack?

    >I'm not sure I get what's being discussed here

    I think it's the implication that any GUI program running under X can see any other GUI program and watch the user's interaction with the other programs. Vim is a CLI program though though...

  17. 17. uecker||context
    It is the same issue with all sandboxing solutions. If your program does not work without giving it excessive permissions, it does not work. If we want to move to a version with minimal privileges, X would still seem like a good platform to work on this. But one would have to work on it, not decide that everything needs to be rewritten all the time.
  18. 18. orangeboats||context
    > If we want to move to a version with minimal privileges

    Then you would have to cut everything provided by the X protocol into many, smaller, controllable pieces. Because if the permission control is just a switch that says "ability to communicate with the X server", then the whole exercise is rather moot, isn't it.

    And when you cut the protocol into smaller pieces...

  19. 19. uecker||context
    No, there is already a secure mode which in the past worked fine but was bit too restrictive for modern clients, and there already exist hooks for fine grained access control.
  20. 20. hulitu||context
    > Saying this after the whole XZ utils ordeal has happened is quite interesting.

    You do realize that XZ was on github. (Microsoft, PRISM etc.)

  21. 21. mike_hock||context
    > until one considers the practical implications

    You failed at that step.

    The practical implication is that every other X11 app can also read your input even when it's not in the foreground.

  22. 22. throw_await||context
    Every program can listen to keypresses via /dev/input
  23. 23. nsingh2||context
    This is false. A process needs read permission on the relevant `/dev/input/` device, typically by running as root or as a user in a group like `input`. Normal desktop users generally should not be in the input group. Regular applications receive keyboard input through the compositor/windowing system.
  24. 24. jcelerier||context
    What's your opinion on software like https://www.autohotkey.com/ then?
  25. 25. hulitu||context
    > firefox is one of the few apps that already sandboxes itself really well,

    while being one of the few apps that executes Remote Code really well.

  26. 26. ChocolateGod||context
    Correct me if I'm wrong, but passing through the X socket gives a giant sandbox escape as any application can control/see any other application, including a root terminal in a GUI app.
  27. 27. Chu4eeno||context
    No, X11 supports pretty detailed per-application access control, similar to selinux (XACE).

    The author of the phoenix x server has blogged about it, iirc.

  28. 28. ChocolateGod||context
    > XACE

    Which is configured by default on what distros?

  29. 29. lotharcable||context
    Nowhere (and everywhere).

    It is my understanding that XACE doesn't actually provide any security features itself. It just provides the "hooks" to implement security extensions. Like LSM feature in Linux kernel. You have to install a additional X11 extension to do something useful with it.

    So the most common X11 security extension is going to be xcsecurity which enables the SECURITY extension. It allows a course permission model were applications can be designated as "Trusted" or "Untrusted". That is going to show up in many Linux distributions.

    However all applications default to "trusted" because if they are untrusted they tend to cause lots of other annoying problems and crashes a lot of apps, apparently.

    In practice the only place it shows up is if you are using "ssh -X". That uses the security extension by default. Which is why there is also a "ssh -Y" that disables it for applications that it breaks.

    This sort of thing is why to fix X11 security you have to give up backwards compatibility and create a new X version.

    Oh, wait, that is what the X developers did with Wayland.

  30. 30. froh||context
    except Wayland dropped the baby with the bathtub?

    for example standardized window management, left as an exercise to the GUI lib and the compositor? and woop woop X11 GUI apps need to be rewritten to support window management on WSL (Wayland based) and the network reconnect on hybernate also broke.

    But at least Games are faster, aren't they...

  31. 31. onli||context
    No, slower. And with compatibility issues as well as additional latency.
  32. 32. shevy-java||context
    > that is what the X developers did with Wayland

    This is rather incomplete. For instance, gtk devs already threw out tons of old code in GTK4. Wayland also has fewer features than xorg; and there are also fewer choices available. I noticed this with regards to WMs/DEs. I am not even going to issues wayland has with regards to certain video graphics - that's another not mentioned issue here.

    You are trying to pick individual cherries.

    > This sort of thing is why to fix X11 security you have to give up backwards compatibility and create a new X version.

    I don't think so: https://github.com/X11Libre/xserver

    Let's have a look in a little while. I myself hope for better and more transparent information at all times. Probably others want better security overall. Would it not be somewhat interesting if wayland were to be abandoned eventually due to having too few useful features compared to xserver?

  33. 33. fluffybucktsnek||context
    > Wayland also has fewer features than xorg; and there are also fewer choices available

    Because Wayland is a strictly a window management protocol focused on policy over mechanism.

    > I am not even going to issues wayland has with regards to certain video graphics - that's another not mentioned issue here.

    We also aren't going to mention issues Xorg or XLibre have with some graphics setups, because that's neither here nor there. This is a thread about security.

    > I don't think so: <XLibre github repo link>

    Didn't XLibre break some applications when launched?

    > Would it not be somewhat interesting if wayland were to be abandoned eventually due to having too few useful features compared to xserver?

    It would be interesting to see Wayland abandoned for a better protocol/set of protocols, xserver is neither a protocol nor really better.

  34. 34. yjftsjthsd-h||context
    > Didn't XLibre break some applications when launched?

    It can't have broken as many things as Wayland

  35. 35. ChocolateGod||context
    > Wayland also has fewer features than xorg

    I don't want my display server/compositor to have a print server.

  36. 36. yjftsjthsd-h||context
    And I do want mine to tell a11y programs what windows exist.
  37. 37. throwaway7356||context
    > In practice the only place it shows up is if you are using "ssh -X". That uses the security extension by default. Which is why there is also a "ssh -Y" that disables it for applications that it breaks.

    Unless your distro changes the default to make "ssh -X" and "ssh -Y" behave the same which popular distributions do.

  38. 38. uecker||context
    Most of the time applications can read each other's memory, so protecting the display does not make much sense.

    Basic X client isolation (not using XACE just Xsecurity) would have worked for sandboxed applications with some minor changes (allowing access to some basic modern extensions, I had a local patch for this once). There is really not fundamental issue in X that could now allow isolation of clients.

  39. 39. ChocolateGod||context
    > Most of the time applications can read each other's memory, so protecting the display does not make much sense.

    Unless you're running everything as root, applications can not read eachothers memory.

  40. 40. uecker||context
    Of course they can! How do you think a debugger works?
  41. 41. waynecochran||context
    I wish I lived in a world were you didn't have to sign contracts, lock your doors, or have X11 security. It is so fun to run xmeltdown a new user's display.
  42. 42. ElijahLynn||context
    Is X11 going to be like IE6. Still around in another 10 years after it was intended to be deprecated across all major distros (2025/2026).
  43. 43. shevy-java||context
    I don't think it is "just around" - it is actively maintained still:

    https://github.com/X11Libre/xserver

    In the end Red Hat failed to kill off X11. Let's see what happens next. The GTK devs already rejected patches for maintaining the toolkit further for the xorg platform, following their "GTK5 will no longer support x11" agenda. Would be kind of great to have a universal GUI toolkit that would work rather than have toolkits controlled de-facto by private companies who just willy-nilly throw out support for this or that platform at their own selfish discretion. Though, someone else now helps maintain gtk2, though most of the patches are in regards to fixing bugs, ensuring that it can be compiled and so forth. https://git.devuan.org/Daemonratte/gtk2-ng

  44. 44. kstrauser||context
    Real question: is X11Libre widely used by anyone but its maintainers?
  45. 45. PowerElectronix||context
    Several distros have gone XLibre as their default display manager. I installed Artix on a bc-250 just last week and XLibre was the default there.
  46. 46. oneshtein||context
    See also yserver[0]: A modern X11 server written from scratch in Rust.

    0: https://github.com/joske/yserver

  47. 47. toenail||context
    Is wayland going to be aroud in another 10 years, or it it the new pulseaudio?
  48. 48. trollbridge||context
    I’m pretty certain X11 will be!
  49. 49. porridgeraisin||context
    It's gonna be like ipv4. Still around in a thousand years.
  50. 50. _jackdk_||context
    The problem is that Wayland just isn't a compelling alternative for many people, so they don't move. For me, I see no benefit because I got used to avoiding HiDPI and don't have a mixed-DPI workspace. For some bizarre reason they made each compositor implement input-handling separately, so for example artists might have to switch compositor just to use their tablet of choice. And worse yet, some people with input accessibility needs are just going to get straight up locked out of libre computing. See https://nocoffei.com/?p=451 for one example.
  51. 51. mike_hock||context
    > I like my cozy Plasma DE [...] clean, all free of ads and bad UI redesigns and AI injected into every corner.

    Plasma itself is an example of bad UI redesign (but a far cry from Gnome).

  52. 52. nosioptar||context
    Yeah, new plasma looks like a dollar store knockoff of windows 11.
  53. 53. adrian_b||context
    I have used only HiDPI monitors with X11 on Linux for about a dozen years and it has always worked perfectly.

    However I use XFCE, where you can set directly the DPI values of the monitors, so that everything will work fine. I have heard Gnome users complaining about problems with HiDPI, but those are not caused by X11, but by a bad Gnome UI for desktop settings.

    So HiDPI is not something at which Wayland is better than X11 and there is no reason to avoid HiDPI. At a higher DPI, OTF/TTF typefaces are rendered much more beautifully and reading becomes more comfortable.

    I do not know if Wayland has any advantage at mixed DPI, because I have rarely used such configurations.

  54. 54. TZubiri||context
    X11 fine

    Youngins just don't wanna learn it

  55. 55. yjftsjthsd-h||context
    Well, that's a bit far. X11 sucks, even if its would-be successor sucks in other ways.
  56. 56. Asooka||context
    Wayland was started 18 years ago. When it was conceived, X11 was 20 years old. In 2 years, we should probably start talking about replacing Wayland with a modern display server...

    In all seriousness, it is another stark reminder why you never rewrite from the ground up. Especially when you're replacing a foundational technology like the display server. In the same time Microsoft reworked their display driver model twice without requiring a single change from application developers. The Linux world doesn't have that many application developers, we should not be asking them to continually chase newer and newer APIs. A rolling stone gathers no moss.

  57. 57. orangeboats||context
    >Wayland was started 18 years ago.

    Oh no, not this again. The design of Wayland started 18 years ago, but the stabilization happened 14 years ago, and the _convincing_ across the ecosystem obviously happened way later than that.

    I would put the year closer to 2016, when distros started to consider Wayland as an option.

  58. 58. sedatk||context
    Putting apps in a container sounds like a great idea until you need to access your files.
  59. 59. mike_hock||context
    Or until you realize X11 is one giant escape hatch. You might not have (convenient) access to your files but the attacker does.
  60. 60. ddapperd||context
    In terms of attack surface, how does this compare to just using AppArmor or SELinux, without containers?