2021-07-01 15:13:41 +00:00
|
|
|
# Firewall {#sec-firewall}
|
|
|
|
|
|
|
|
NixOS has a simple stateful firewall that blocks incoming connections
|
|
|
|
and other unexpected packets. The firewall applies to both IPv4 and IPv6
|
|
|
|
traffic. It is enabled by default. It can be disabled as follows:
|
|
|
|
|
|
|
|
```nix
|
2024-03-27 18:10:27 +00:00
|
|
|
{
|
|
|
|
networking.firewall.enable = false;
|
|
|
|
}
|
2021-07-01 15:13:41 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
If the firewall is enabled, you can open specific TCP ports to the
|
|
|
|
outside world:
|
|
|
|
|
|
|
|
```nix
|
2024-03-27 18:10:27 +00:00
|
|
|
{
|
|
|
|
networking.firewall.allowedTCPPorts = [ 80 443 ];
|
|
|
|
}
|
2021-07-01 15:13:41 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Note that TCP port 22 (ssh) is opened automatically if the SSH daemon is
|
|
|
|
enabled (`services.openssh.enable = true`). UDP ports can be opened through
|
2021-07-04 01:56:26 +00:00
|
|
|
[](#opt-networking.firewall.allowedUDPPorts).
|
2021-07-01 15:13:41 +00:00
|
|
|
|
|
|
|
To open ranges of TCP ports:
|
|
|
|
|
|
|
|
```nix
|
2024-03-27 18:10:27 +00:00
|
|
|
{
|
|
|
|
networking.firewall.allowedTCPPortRanges = [
|
|
|
|
{ from = 4000; to = 4007; }
|
|
|
|
{ from = 8000; to = 8010; }
|
|
|
|
];
|
|
|
|
}
|
2021-07-01 15:13:41 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Similarly, UDP port ranges can be opened through
|
2021-07-04 01:56:26 +00:00
|
|
|
[](#opt-networking.firewall.allowedUDPPortRanges).
|