This assignment requires a slightly different network topology and an additional fourth machine. The network is represented in the following diagram.
In case you want to create the network from scratch, we created a script for VirtualBox that configures each machine network interfaces accordingly.
Even though the native firewall software in Linux is part of the kernel it is possible to manage its rules
using iptables
.
Let's try some simple rules in machine 2.
First verify that for instance machine 3 can query machine 2 with a simple ping request:
user@machine3:~$ ping machine2
PING machine2 (192.168.3.1) 56(84) bytes of data.
64 bytes from machine2 (192.168.3.1): icmp_seq=1 ttl=64 time=0.571 ms
Now run the following command in machine 2 to specify that icmp packets should be dropped:
sudo iptables -A INPUT -p icmp -j DROP
More specifically, this command appends a rule to the INPUT chain in the IPv4 packet filtering table, (the default table) stating that packets with the icmp protocol should be handled with a jump to the DROP action. This will result in the matching packets being ignored in the configured machine.
Verify that a ping request from machine 3 will now fail. You can check the list of existing rules in machine 2 by executing:
user@machine2:~$ sudo iptables -L
Chain INPUT (policy ACCEPT)
target prot opt source destination
DROP icmp -- anywhere anywhere
Now remove the rule in machine 2 by using one of the two commands:
sudo iptables -D INPUT 1 # Deletes the first rule from the INPUT chain
sudo iptables -D INPUT -p icmp -j DROP # Deletes the ICMP rule specifically
First make sure you can establish a telnet connection with machine 2. If not, refer to the troubleshooting guide on telnet.
Now, in machine 2 add a rule to drop all packets with the destination port equal to 23 (telnet):
sudo iptables -A INPUT -p tcp --dport 23 -j DROP
Upon trying a telnet connection, the origin machine will now hang and fail. Remove the rule in machine 2 with:
sudo iptables -D INPUT -p tcp --dport 23 -j DROP
You can even specify you wish to ignore connections from a given IP address. On machine 2 run:
sudo iptables -A INPUT -p tcp -s 192.168.1.1 --dport 23 -j DROP
Verify that only machine 1 will fail to establish a telnet connection.
Furthermore, it is possible to block a specific subnet (which corresponds to a specific set of IP addresses) The following command will block every machine in the subnet through which machine 4 can communicate with machine 2.
sudo iptables -A INPUT -p tcp -s 192.168.4.0/24 --dport 23 -j DROP
Verify that machine 4 will now be unable to establish a telnet connection.
In fact, it will be presented with a Connection refused
error.
Delete all of the rules in machine 2 with:
sudo iptables -F # flush all the chains in the filter table, deleting every rule
The previous exercises used the INPUT chain from the filter table. We will now use the PREROUTING chain in the NAT table to redirect network packets. On machine 2 run:
sudo iptables -t nat -A PREROUTING --dst 192.168.1.2 -p tcp --dport 23 -j DNAT --to-destination 192.168.3.2
This will append a rule to the nat table's PREROUTING chain that specifies that tcp packets directed to port 23 of machine 2 are to be redirected to machine 3 instead. The DNAT extension specifies "A virtual state, matching if the original destination differs from the reply source.", as per the man page.
The rule seems correct, but I could not get it to work :( . Keep getting connection refused error
You can examine that indeed a connection is established between 1 and 3 (UPDATE IF YOU GET IT TO WORK):
user@machine1:~$ netstat -t
Active Internet connections (w/o servers)
Proto Recv-Q Send-Q Local Address Foreign Address State
tcp 0 1 machine1:42658 machine2:telnet SYN_SENT
It is also possible to redirect http traffic to machine 3. On machine 2:
sudo iptables -t nat -A PREROUTING --dst 192.168.1.2 -p tcp --dport 80 -j DNAT --to-destination 192.168.3.2
Now, on machine 1 go to a browser and request http://192.168.1.2 . You should get the default Apache server page from machine 3, indicating that the redirection was a sucess.
Finally clean all the rules on machine 2 with:
iptables -F
iptables -t nat -F
iptables -X