Linux
From Wikipedia, the free encyclopedia
Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).
Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.
Rules
- Posts must be relevant to operating systems running the Linux kernel. GNU/Linux or otherwise.
- No misinformation
- No NSFW content
- No hate speech, bigotry, etc
Related Communities
Community icon by Alpár-Etele Méder, licensed under CC BY 3.0
There are several Linux distributions specifically made for "kiosk" type applications. I don't have any specific ones to suggest, but if you search "Linux distro for kiosk" that should return plenty of results. Might be easier to use one of those to suit your needs than modifying a normal distro like Debian, Fedora, Ubuntu, etc
I'll have to see if they'll fit better. It all really depends what way the project ends up going. Thanks for the suggestion!
Yeah, came here to also say this is called Kiosk mode. You can also not have the filesystem writable and only have user files in (volatile/temporary) memory and everything set back to default once the user logs out. This is used in libraries and on computers in schools. Like a "Live-CD". And in my library the computer just logs out the user after 5 minutes of inactivity. Clears everything, sets everything back to default, opens the browser fresh with the homepage of the library.
The concept with the files in RAM ins usually called 'ramdisk'. It is a virtual filesystem on top of the write-protected one that doesn't ever change.
I think you can also prevent write access in general, but there are some caveats to that. Depends on the use-case.
Along with the restrictions others have mentioned, you could look at running your system as a "live" install:
- Actual OS boots directly off media like a USB stick or DVD
- Operating system is mounted "read only" - even the super admin can't change files in the root partition
- Even if a clever user finds a way to run programs, their changes don't persist after a reboot
- If you need some persistence (eg, allowing users to save documents) you could mount a network share as the /home partition, but mount it "noexec" so if users manage to download programs from the internet, they aren't able to run them
Gnome has a feature in the settings for selecting which current applications can be made available to other users. I think it may be a flatpak only feature though.
Also another user will not be able to access another user's files if they are encrypted with LUKS or systemd-homed.
Thanks! I'll check out Gnome too.
"Cannot even browse files" could imply being unable to run binaries like a shell. Could you expand a bit on your desired use case?
Poor wording on my part. Simply don't want them to excecute anything I don't want them to or get into some directories. Access to something like My Files would be fine and in some cases may be needed, but nothing past that.
Check out bash restricted mode. Try running man bash
and find the section RESTRICTED SHELL