Difference between revisions of "CLI - ufw"

 
(37 intermediate revisions by the same user not shown)
Line 8: Line 8:
  
 
We introduce basic syntax and examples. For more details, Please visit the https://help.ubuntu.com/community/UFW. or http://manpages.ubuntu.com/manpages/bionic/man8/ufw.8.html.
 
We introduce basic syntax and examples. For more details, Please visit the https://help.ubuntu.com/community/UFW. or http://manpages.ubuntu.com/manpages/bionic/man8/ufw.8.html.
 
  
 
==== Verifying ufw ====
 
==== Verifying ufw ====
 
<pre>
 
<pre>
LYSH@MyHostName# show ufw // ufw is in disable
+
LYSH@MyHostName# show ufw
Status: inactive
+
Status: inactive // ufw is in disable
 
</pre>
 
</pre>
  
The following example is a typical configuration when ufw is in enable.
+
The following example is a typical configuration when ufw is in enable. The default "incoming" rule is "deny". It means that all traffic will be denied except for the allowed rules.
 
<pre>
 
<pre>
LYSH@MyHostName# show ufw // ufw is in enable
+
LYSH@MyHostName# show ufw
Status: active
+
Status: active // ufw is in enable
 
Logging: on (low)
 
Logging: on (low)
 
Default: deny (incoming), allow (outgoing), disabled (routed)
 
Default: deny (incoming), allow (outgoing), disabled (routed)
Line 36: Line 35:
 
  ufw allow from 192.168.0.11 to any port 22
 
  ufw allow from 192.168.0.11 to any port 22
 
  ufw allow from 192.168.0.12 to any port 22
 
  ufw allow from 192.168.0.12 to any port 22
 
 
==== ufw blocking log ====
 
If you want to see the ufw blocked logs, enter the <code>show log ufw</code>.
 
LYSH@MyHostName# show log ufw
 
If you use -w option, you can see the ufw blocked logs in real-time
 
LYSH@MyHostName# show log ufw -w
 
2021-04-26 14:55:27 4 0 MyHostName kernel: [7282110.099052] [UFW BLOCK] IN=eth0 
 
OUT=MAC=00:15:5d:03:1e:57:00:04:96:34:b5:e9:08:00 SRC=192.168.0.100 DST=192.168.0.200...
 
 
  
 
==== Enable / Disable ====
 
==== Enable / Disable ====
You can enable or disable ufw in the configuration mode. '''Remember that you must change the default incoming rule to "allow" before enabling ufw and change the default incoming rule as "deny" after adding all rules'''. <span style="color:red;">If not, Current or existing ssh connections are disrupted and some imRAD services can be blocked.</span>
+
You can enable or disable ufw in the configuration mode.  
 +
{{note | Remember that you must change the default incoming rule to "allow" before enabling ufw and change the default incoming rule as "deny" after adding all rules. If not, Current or existing ssh connections are disrupted and some imRAD services can be blocked.}}
  
 
  LYSH@MyHostName# configure
 
  LYSH@MyHostName# configure
Line 54: Line 44:
 
  configure# ufw enable
 
  configure# ufw enable
 
  configure# exit
 
  configure# exit
  LYSH@MyHostName# show ufw // ufw is in disable
+
  LYSH@MyHostName# show ufw
 
  Status: active
 
  Status: active
 
  Logging: on (low)
 
  Logging: on (low)
Line 65: Line 55:
 
  configure# exit
 
  configure# exit
  
Note that you'd better add "allow" rules and set the default incoming rule to "deny".  If you set the default incoming rule to "allow", there are too many rules to deny.
+
{{note | Note that you'd better add "allow" rules and set the default incoming rule to "deny".  If you set the default incoming rule to "allow", there are too many rules to deny. Therefore, you have to change the incoming rule to "deny" after all rules}}
Therefore, you have to change the incoming rule to "deny" after all rules
 
 
===== Enable Summary =====
 
===== Enable Summary =====
 
{| class="wikitable"
 
{| class="wikitable"
Line 79: Line 68:
 
| configuration || <code>ufw allow {syntax}</code> || Add a "allow" rule.<br>Remember that you should add all rules including the Required rules.
 
| configuration || <code>ufw allow {syntax}</code> || Add a "allow" rule.<br>Remember that you should add all rules including the Required rules.
 
|-
 
|-
| user|| <code>show ufw</code> || verify the status of ufw
+
| user|| <code>show ufw added</code> || verify the status of ufw and rules,
 
|-
 
|-
 
| configuration || <code>ufw default deny</code> || change the default incoming rule to "deny"
 
| configuration || <code>ufw default deny</code> || change the default incoming rule to "deny"
 
|-
 
|-
| user|| <code>show ufw</code> || verify the status of ufw
+
| user|| <code>show ufw added</code> || verify the status of ufw and rules,
 
|-
 
|-
 
|}
 
|}
  
 
==== rules ====
 
==== rules ====
You can add a rule at the end of existing rule and can insert a rule at the specific position.
+
You can configure rules in the configuration mode.  
  
 
===== Basic syntax =====
 
===== Basic syntax =====
 +
If you add a rule, the new rule will be added at the end of the existing rule(s). If you insert a rule, the new rule will be inserted corresponding RULE as rule number NUM.
 +
{{note | Rule ordering is important and the first match wins. Therefore when adding rules, add the more specific rules first with more general rules later<ref>http://manpages.ubuntu.com/manpages/impish/en/man8/ufw.8.html</ref>.}}
 +
 +
To delete a rule, use the <code>ufw delete</code> command.<br>
 +
A rule can be either "allow", "deny", or "reject". The "deny" rule means that it discards incoming packets. The "reject" rule means that it sends back an error packet to the sender.<ref>https://stackoverflow.com/questions/4907173/ufw-linux-firewall-difference-between-reject-and-deny</ref>
 +
 
<pre>
 
<pre>
 
LYSH@MyHostName# configure
 
LYSH@MyHostName# configure
 
configure# ufw allow 22 // To allow incoming tcp and udp packet on port 22.
 
configure# ufw allow 22 // To allow incoming tcp and udp packet on port 22.
 
configure# ufw allow 23/tcp // To allow incoming tcp packet on port 23.
 
configure# ufw allow 23/tcp // To allow incoming tcp packet on port 23.
configure# ufw allow 24/udp // To allow incoming udp packet on port 24.
+
configure# ufw deny 24/udp // To deny incoming udp packet on port 24.
 
configure# ufw allow ssh // To allow ssh by name.
 
configure# ufw allow ssh // To allow ssh by name.
configure# ufw allow from 192.168.0.1 // To allow packets from 192.168.0.1.
+
configure# ufw allow from 192.168.0.1 // To allow packets from 192.168.0.1.
configure# ufw allow from 192.168.0.1/24 // To allow packets from 192.168.0.1/24.
+
configure# ufw deny from 192.168.0.1/24 // To deny packets from 192.168.0.1/24.
 
</pre>
 
</pre>
  
To allow IP address 192.168.0.4 access to port 22 for all protocols.
+
To allow access to port 22 from 192.168.0.4.
 
  configure# ufw allow from 192.168.0.4 to any port 22
 
  configure# ufw allow from 192.168.0.4 to any port 22
  
To allow IP address 192.168.0.4 access to port 22 for all protocols using TCP.
+
To allow access to port 22 from 192.168.0.4 using TCP.
 
  configure# ufw allow from 192.168.0.4 to any port 22 proto tcp
 
  configure# ufw allow from 192.168.0.4 to any port 22 proto tcp
  
To allow IP address 192.168.0.4/24 access to port 22 for all protocols using TCP.
+
To allow access to port 22 from 192.168.0.x IPs using TCP.
 
  configure# ufw allow from 192.168.0.4/24 to any port 22 proto tcp
 
  configure# ufw allow from 192.168.0.4/24 to any port 22 proto tcp
  
===== Adding rules =====
+
===== Add or Insert rules =====
 
You can add a "allow" rule at the end by type the command <code>ufw allow {syntax}</code>.  
 
You can add a "allow" rule at the end by type the command <code>ufw allow {syntax}</code>.  
 
If you want to insert a rule before existing rule. enter the <code>ufw insert {number} allow {syntax}</code>.  
 
If you want to insert a rule before existing rule. enter the <code>ufw insert {number} allow {syntax}</code>.  
Line 149: Line 144:
 
  configure# exit
 
  configure# exit
  
Now if the host(i.e. 192.168.0.100) connect to the device via ssh, you can see the "BLOCK" log.
+
Now if the host(i.e. 192.168.0.100) connects to the device via ssh, you can see the "BLOCK" log.
 
  LYSH@MyHostName# show log ufw
 
  LYSH@MyHostName# show log ufw
 
  2021-04-26 14:55:27 4 0 MyHostName kernel: [7282110.099052] [UFW BLOCK] IN=eth0   
 
  2021-04-26 14:55:27 4 0 MyHostName kernel: [7282110.099052] [UFW BLOCK] IN=eth0   
Line 155: Line 150:
  
 
===== Required rules =====
 
===== Required rules =====
You must specify these rules to have all imRAD services work properly. You'd better copy all the following rules and then paste them. Note that if your system does not need to serve some services, you can ignore their rules. Please refer to the [[ImRAD port]] to verify what the port number means.
+
You must specify these rules to have all imRAD services work properly. You'd better copy all the following rules and then paste them. {{note|Note that if your system does not need to serve some services, you can ignore their rules. Please refer to the [[ImRAD port]] to verify what the port number means.}}
 
  LYSH@MyHostName# show ufw added
 
  LYSH@MyHostName# show ufw added
 
  ufw allow 80/tcp
 
  ufw allow 80/tcp
Line 167: Line 162:
 
  ufw allow 67/udp
 
  ufw allow 67/udp
 
  ufw allow 68/udp
 
  ufw allow 68/udp
ufw allow 77/tcp
 
ufw allow 647/tcp
 
 
  ufw allow 547/udp
 
  ufw allow 547/udp
 
  ufw allow 546/udp
 
  ufw allow 546/udp
Line 176: Line 169:
 
  configure# ufw allow from {your ip address} to any port 22 proto tcp
 
  configure# ufw allow from {your ip address} to any port 22 proto tcp
  
===== Deny/Reject =====
+
===== Deleting rules =====
You can block from a host using by the "deny" or "reject" rule.
+
To delete a rule, simply prefix the original rule with delete or specify the rule number.
 +
LYSH@MyHostName# show ufw
 +
Status: active
 +
Logging: on (low)
 +
Default: allow (incoming), allow (outgoing), disabled (routed)
 +
New profiles: skip
 +
To                        Action      From
 +
--                        ------      ----
 +
[ 1] 22                    ALLOW IN    192.168.0.10
 +
[ 2] 22                    ALLOW IN    192.168.0.15
 +
[ 3] 22                    ALLOW IN    192.168.0.20 // shift down
 +
 
  LYSH@MyHostName# configure
 
  LYSH@MyHostName# configure
  configure# ufw deny log from 192.168.0.50 to any port 22 proto tcp
+
  configure# ufw delete 2
configure# ufw reject log from 192.168.0.60 to any port 22 proto tcp
+
configure# exit
Note that If you use "deny", the ufw silently discards incoming packets. If you use "reject", the ufw sends back an error packet to the sender of the rejected packet. You'd better using the deny rule because the client must not know why the connection is not established.
+
 
 
==== Deleting rules ====
 
To delete a rule, simply prefix the original rule with delete or specify the rule number.
 
<pre>
 
LYSH@MyHostName# configure
 
configure# ufw delete allow from 192.168.0.15 to any port 22
 
or
 
configure# ufw delete 2
 
configure# exit
 
</pre>
 
 
  LYSH@MyHostName# show ufw
 
  LYSH@MyHostName# show ufw
 
  Status: active
 
  Status: active
Line 202: Line 196:
 
  [ 2] 22                    ALLOW IN    192.168.0.20
 
  [ 2] 22                    ALLOW IN    192.168.0.20
  
You can also delete a rule using added rule.
+
You can also delete a rule using the original rule.
 
  LYSH@MyHostName# show ufw added
 
  LYSH@MyHostName# show ufw added
 
  ufw allow from 192.168.0.10 to any port 22
 
  ufw allow from 192.168.0.10 to any port 22
Line 219: Line 213:
 
  [ 1] 22                    ALLOW IN    192.168.0.10
 
  [ 1] 22                    ALLOW IN    192.168.0.10
  
 +
===== default rule TO "deny" =====
 +
If you definitely added all "allow" rules including the Required rules, change the default incoming rule to "deny". '''Be sure that there is a rule to access the SSH from your IP address before changing the default rule to "deny".'''
  
==== default rule TO "deny" ====
 
If you definitely added all rules including the Required rules, change the default incoming rule to "deny". '''Be sure that there is a rule to access the SSH from your IP address before changing the default rule to "deny".'''
 
 
  LYSH@MyHostName# configure
 
  LYSH@MyHostName# configure
 
  configure# ufw default deny
 
  configure# ufw default deny
Line 236: Line 230:
 
  [ 2] 22                    ALLOW IN    192.168.0.20
 
  [ 2] 22                    ALLOW IN    192.168.0.20
  
 +
{{note|If your SSH connection was disrupted because you missed a "allow" rule from your device after changing the default rule to "deny", you should connect the device using the "console" and add an "allow" rule.}}
  
 
==== reset ====
 
==== reset ====
If you reset the ufw, all rules are deleting, default incoming rule is changed to "allow", and the ufw status is change to "disable".
+
If you reset the ufw, all rules are deleting. Also, the default incoming rule is changed to "allow", and the ufw status is changed to "disable".
 
  LYSH@MyHostName# configure
 
  LYSH@MyHostName# configure
 
  configure# ufw reset
 
  configure# ufw reset
Line 246: Line 241:
 
  LYSH@MyHostName# show ufw added
 
  LYSH@MyHostName# show ufw added
 
  (None)
 
  (None)
 +
 +
==== log ====
 +
The ufw logs blocked packets not matching the defined policy and you can see them by the [[CLI - Log | <code>show log ufw</code>]] in the user mode.
  
 
=== References ===
 
=== References ===

Latest revision as of 11:39, 15 September 2023

ufw

The imRAD system uses "ufw" as a default firewall configuration.[1] UFW is a front-end for iptables and is particularly well-suited for host-based firewalls. Users can therefore configure the firewall to allow certain types of network traffic to pass into and out of a system (for instance SSH or web server traffic). This is done by opening and closing TCP and UDP "ports" in the firewall. Additionally, firewalls can be configured to allow or restrict access to specific IP addresses (or IP address ranges).[2]

You can enable or disable using the ufw enable or ufw disable command in the configuration mode. The status of ufw is initially in disable. Therefore, you may enable it if necessary.

We introduce basic syntax and examples. For more details, Please visit the https://help.ubuntu.com/community/UFW. or http://manpages.ubuntu.com/manpages/bionic/man8/ufw.8.html.

Verifying ufw

LYSH@MyHostName# show ufw
Status: inactive	// ufw is in disable

The following example is a typical configuration when ufw is in enable. The default "incoming" rule is "deny". It means that all traffic will be denied except for the allowed rules.

LYSH@MyHostName# show ufw
Status: active		// ufw is in enable
Logging: on (low)
Default: deny (incoming), allow (outgoing), disabled (routed)
New profiles: skip

To                         Action      From
--                         ------      ----
[ 1] 22                         ALLOW IN    192.168.0.10
[ 2] 22                         ALLOW IN    192.168.0.11
[ 3] 22                         ALLOW IN    192.168.0.12

Even if the ufw is disabled, you can see the rules by input the show ufw added.

LYSH@MyHostName# show ufw added
ufw allow from 192.168.0.10 to any port 22
ufw allow from 192.168.0.11 to any port 22
ufw allow from 192.168.0.12 to any port 22

Enable / Disable

You can enable or disable ufw in the configuration mode.

Remember that you must change the default incoming rule to "allow" before enabling ufw and change the default incoming rule as "deny" after adding all rules. If not, Current or existing ssh connections are disrupted and some imRAD services can be blocked.

LYSH@MyHostName# configure
configure# ufw default allow
configure# ufw enable
configure# exit
LYSH@MyHostName# show ufw
Status: active
Logging: on (low)
Default: allow (incoming), allow (outgoing), disabled (routed)
New profiles: skip

To disable, just enter ufw disable.

LYSH@MyHostName# configure
configure# ufw disable
configure# exit

Note that you'd better add "allow" rules and set the default incoming rule to "deny". If you set the default incoming rule to "allow", there are too many rules to deny. Therefore, you have to change the incoming rule to "deny" after all rules

Enable Summary
mode command Description
configuration ufw default allow change the default incoming rule to "allow"
configuration ufw enable enable ufw
user show ufw verify the status of ufw
configuration ufw allow {syntax} Add a "allow" rule.
Remember that you should add all rules including the Required rules.
user show ufw added verify the status of ufw and rules,
configuration ufw default deny change the default incoming rule to "deny"
user show ufw added verify the status of ufw and rules,

rules

You can configure rules in the configuration mode.

Basic syntax

If you add a rule, the new rule will be added at the end of the existing rule(s). If you insert a rule, the new rule will be inserted corresponding RULE as rule number NUM.

Rule ordering is important and the first match wins. Therefore when adding rules, add the more specific rules first with more general rules later[3].

To delete a rule, use the ufw delete command.
A rule can be either "allow", "deny", or "reject". The "deny" rule means that it discards incoming packets. The "reject" rule means that it sends back an error packet to the sender.[4]

LYSH@MyHostName# configure
configure# ufw allow 22			// To allow incoming tcp and udp packet on port 22.
configure# ufw allow 23/tcp		// To allow incoming tcp packet on port 23.
configure# ufw deny 24/udp		// To deny incoming udp packet on port 24.
configure# ufw allow ssh		// To allow ssh by name.
configure# ufw allow from 192.168.0.1	// To allow packets from 192.168.0.1.
configure# ufw deny from 192.168.0.1/24	// To deny packets from 192.168.0.1/24.

To allow access to port 22 from 192.168.0.4.

configure# ufw allow from 192.168.0.4 to any port 22

To allow access to port 22 from 192.168.0.4 using TCP.

configure# ufw allow from 192.168.0.4 to any port 22 proto tcp

To allow access to port 22 from 192.168.0.x IPs using TCP.

configure# ufw allow from 192.168.0.4/24 to any port 22 proto tcp
Add or Insert rules

You can add a "allow" rule at the end by type the command ufw allow {syntax}. If you want to insert a rule before existing rule. enter the ufw insert {number} allow {syntax}.

LYSH@MyHostName# configure
configure#  ufw allow from 192.168.0.10 to any port 22
configure#  ufw allow from 192.168.0.20 to any port 22
configure# exit

You can see the "ALLOW" rules that entered later has a higher number. In other words, If you add a rule, the rule is located at the end.

LYSH@MyHostName# show ufw
Status: active
Logging: on (low)
Default: allow (incoming), allow (outgoing), disabled (routed)
New profiles: skip
To                         Action      From
--                         ------      ----
[ 1] 22                    ALLOW IN    192.168.0.10
[ 2] 22                    ALLOW IN    192.168.0.20

If you want to add a rule at the specific number, enter the ufw insert {number} allow {syntax}. This will shift down the rules whose number is equal to or greater than the {number}.

LYSH@MyHostName# configure
configure#  ufw insert 2 allow from 192.168.0.15 to any port 22
configure# exit
LYSH@MyHostName# show ufw
Status: active
Logging: on (low)
Default: allow (incoming), allow (outgoing), disabled (routed)
New profiles: skip
To                         Action      From
--                         ------      ----
[ 1] 22                    ALLOW IN    192.168.0.10
[ 2] 22                    ALLOW IN    192.168.0.15
[ 3] 22                    ALLOW IN    192.168.0.20		// shift down

By default, no logging is performed when a packet matches a rule. Specifying log will log all new connections matching the rule, and log-all will log all packets matching the rule. For example, to deny and log the specific rules

LYSH@MyHostName# configure
configure# ufw deny log from 192.168.0.100 to any port 22 proto tcp
configure# exit

Now if the host(i.e. 192.168.0.100) connects to the device via ssh, you can see the "BLOCK" log.

LYSH@MyHostName# show log ufw
2021-04-26 14:55:27 4 0 MyHostName kernel: [7282110.099052] [UFW BLOCK] IN=eth0  
OUT=MAC=00:15:5d:03:1e:57:00:04:96:34:b5:e9:08:00 SRC=192.168.0.100 DST=192.168.0.200...
Required rules

You must specify these rules to have all imRAD services work properly. You'd better copy all the following rules and then paste them.

Note that if your system does not need to serve some services, you can ignore their rules. Please refer to the ImRAD port to verify what the port number means.

LYSH@MyHostName# show ufw added
ufw allow 80/tcp
ufw allow 443/tcp
ufw allow 6710/tcp
ufw allow 1812/udp
ufw allow 1813/udp
ufw allow 1813/tcp
ufw allow 1812/tcp
ufw allow 18123/udp
ufw allow 67/udp
ufw allow 68/udp
ufw allow 547/udp
ufw allow 546/udp
ufw allow 6010/udp

Specify your IP address to access via SSH.

configure# ufw allow from {your ip address} to any port 22 proto tcp
Deleting rules

To delete a rule, simply prefix the original rule with delete or specify the rule number.

LYSH@MyHostName# show ufw
Status: active
Logging: on (low)
Default: allow (incoming), allow (outgoing), disabled (routed)
New profiles: skip
To                         Action      From
--                         ------      ----
[ 1] 22                    ALLOW IN    192.168.0.10
[ 2] 22                    ALLOW IN    192.168.0.15
[ 3] 22                    ALLOW IN    192.168.0.20		// shift down

LYSH@MyHostName# configure
configure# ufw delete 2
configure# exit

LYSH@MyHostName# show ufw
Status: active
Logging: on (low)
Default: allow (incoming), allow (outgoing), disabled (routed)
New profiles: skip
To                         Action      From
--                         ------      ----
[ 1] 22                    ALLOW IN    192.168.0.10
[ 2] 22                    ALLOW IN    192.168.0.20

You can also delete a rule using the original rule.

LYSH@MyHostName# show ufw added
ufw allow from 192.168.0.10 to any port 22
ufw allow from 192.168.0.20 to any port 22

LYSH@MyHostName# configure
configure# ufw delete allow from 192.168.0.20 to any port 22
configure# exit
LYSH@MyHostName# show ufw
Status: active
Logging: on (low)
Default: allow (incoming), allow (outgoing), disabled (routed)
New profiles: skip
To                         Action      From
--                         ------      ----
[ 1] 22                    ALLOW IN    192.168.0.10
default rule TO "deny"

If you definitely added all "allow" rules including the Required rules, change the default incoming rule to "deny". Be sure that there is a rule to access the SSH from your IP address before changing the default rule to "deny".

LYSH@MyHostName# configure
configure# ufw default deny
configure# exit
LYSH@MyHostName# show ufw
Status: active
Logging: on (low)
Default: deny (incoming), allow (outgoing), disabled (routed)
New profiles: skip
To                         Action      From
--                         ------      ----
[ 1] 22                    ALLOW IN    192.168.0.10
[ 2] 22                    ALLOW IN    192.168.0.20

If your SSH connection was disrupted because you missed a "allow" rule from your device after changing the default rule to "deny", you should connect the device using the "console" and add an "allow" rule.

reset

If you reset the ufw, all rules are deleting. Also, the default incoming rule is changed to "allow", and the ufw status is changed to "disable".

LYSH@MyHostName# configure
configure# ufw reset
configure# exit
LYSH@MyHostName# show ufw
Status: inactive
LYSH@MyHostName# show ufw added
(None)

log

The ufw logs blocked packets not matching the defined policy and you can see them by the show log ufw in the user mode.

References