Linux namespaces and seccomp-bpf sandbox
Find a file
2015-10-25 14:39:07 -04:00
etc default Firefox whitelisting 2015-10-25 10:45:25 -04:00
platform 0.9.30 2015-10-21 12:47:14 -04:00
src libtrace: only include fopen64, freopen64 and stat64 if __GLIBC__ is defined 2015-10-25 16:28:35 +01:00
test ignore option testing 2015-10-25 08:22:21 -04:00
.gitignore Add tags file and vim temporary files to .gitignore 2015-09-01 09:09:29 +10:00
configure small fixes in config.ac 2015-10-25 14:39:07 -04:00
configure.ac small fixes in config.ac 2015-10-25 14:39:07 -04:00
COPYING Baseline firejail 0.9.28 2015-08-08 19:12:30 -04:00
firefox-whitelist.png default Firefox whitelisting 2015-10-25 10:45:25 -04:00
install.sh Baseline firejail 0.9.28 2015-08-08 19:12:30 -04:00
Makefile.in release 0.9.32-rc1 2015-10-14 08:09:02 -04:00
mkdeb.sh Copyright headers 2015-10-24 12:21:35 -04:00
mkman.sh Baseline firejail 0.9.28 2015-08-08 19:12:30 -04:00
README small fixes in config.ac 2015-10-25 14:39:07 -04:00
README.md readme.md 2015-10-25 10:50:22 -04:00
RELNOTES implemented --ignore option 2015-10-25 07:58:04 -04:00
todo renamed ERRNO to BLACKLIST_ERRNO in seccomp.c 2015-10-24 09:33:19 -04:00

Firejail

Firejail is a SUID sandbox program that reduces the risk of security breaches by restricting the running environment of untrusted applications using Linux namespaces, seccomp-bpf and Linux capabilities. It allows a process and all its descendants to have their own private view of the globally shared kernel resources, such as the network stack, process table, mount table. Firejail can work in a SELinux or AppArmor environment, and it is integrated with Linux Control Groups.

Written in C with virtually no dependencies, the software runs on any Linux computer with a 3.x kernel version or newer. It can sandbox any type of processes: servers, graphical applications, and even user login sessions. The software includes sandbox profiles for a number of more common Linux programs, such as Mozilla Firefox, Chromium, VLC, Transmission etc.

The sandbox is lightweight, the overhead is low. There are no complicated configuration files to edit, no socket connections open, no daemons running in the background. All security features are implemented directly in Linux kernel and available on any Linux computer. To start the sandbox, prefix your command with “firejail”:

$ firejail firefox            # starting Mozilla Firefox
$ firejail transmission-gtk   # starting Transmission BitTorrent 
$ firejail vlc                # starting VideoLAN Client
$ sudo firejail "/etc/init.d/nginx start && sleep inf"

Project webpage: https://l3net.wordpress.com/projects/firejail/

Download and Installation: https://l3net.wordpress.com/projects/firejail/firejail-download-and-install/

Features: https://l3net.wordpress.com/projects/firejail/firejail-features/

Usage: https://l3net.wordpress.com/projects/firejail/firejail-usage/

FAQ: https://l3net.wordpress.com/projects/firejail/firejail-faq/

New features in the development version

Whitelisting in default Firefox profile

The next release will bring in default whitelisting for Firefox files and folders under /home/user. If you start the sandbox without any other options, this is what you'll get:

Whitelisted home directory

The code is located in etc/firefox.inc file:

whitelist ~/.mozilla
whitelist ~/Downloads
whitelist ~/dwhelper
whitelist ~/.zotero
whitelist ~/.lastpass

I intend to bring in all files and directories used by Firefox addons and plugins. So far I have Video DownloadHelper, Zotero and LastPass. If you're using a anything else, please let me know.

--ignore option

Ignore commands in profile files. Example:

$ firejail --ignore=seccomp wine