aboutsummaryrefslogtreecommitdiffstats
path: root/README.md
blob: 36cebdcba08af37bc203f1e83f812bfdb800f9bb (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
# 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](firefox-whitelist.png?raw=true)

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

`````
whitelist ~/.mozilla
whitelist ~/Downloads
whitelist ~/dwhelper
whitelist ~/.zotero
whitelist ~/.lastpass
whitelist ~/.gtkrc-2.0
whitelist ~/.vimperatorrc
whitelist ~/.vimperator
`````

I intend to bring in all files and directories used by Firefox addons and plugins. So far I have
[Video DownloadHelper](https://addons.mozilla.org/en-US/firefox/addon/video-downloadhelper/),
[Zotero](https://www.zotero.org/download/), 
[LastPass](https://addons.mozilla.org/en-US/firefox/addon/lastpass-password-manager/),
and [Vimperator](https://addons.mozilla.org/en-US/firefox/addon/vimperator/)
If you're using a anything else, please let me know.

### Whitelisting in default Chromium profile

![Whitelisted home directory](chromium-whitelist.png?raw=true)

### --ignore option

Ignore commands in profile files. Example:
`````
$ firejail --ignore=seccomp wine
`````

### --protocol option

Enable protocol filter. It is based on seccomp and it filters the first argument to socket system call.
If the value is not recognized, seccomp will kill the process.
Valid values: unix, inet, inet6, netlink and packet.

Example:
`````
$ firejail --protocol=unix,inet,inet6
`````

"unix" describes the regular Unix socket connections,
and "inet" and "inet6" describe the regular IPv4 and IPv6 traffic. Most GUI applications need "unix,inet,inet6". "netlink" is the protocol
used to talk to Linux kernel. You'll only need this for applications such as [iproute2](http://www.linuxfoundation.org/collaborate/workgroups/networking/iproute2)
used in system administration, and "packet" is used by sniffers to talk directly with the Ethernet layer.

Protocol filter is enabled in all default security profiles for GUI applications ("protocol unix,inet,inet6").

### Dual i386/amd64 seccomp filter

--seccomp option now installs a dual i386/amd64 default filter.
32bit applications, such as Skype, running on regular 64bit computers, are protected by i386 seccomp filter.

### New security profiles

Steam, Skype, Wine. The dual seccomp filter is enabled by default for these applications.