Ethical Hacking - Cisco HSRP with Kali linux - Example Demonstration and Security precautions
The Hot Swappable Router Protocol (HSRP) is a way to build redundancy into your network by allowing two or more routers to continuously test each other for connectivity, and take over if a router fails.As multiple routers can participate in the HSRP group, there has to be an election to determine who's the primary router.
This HSRP election is based on a priority value (0 to 255) that is configured on each router in the group. By default, the priority is 100. The router with the highest priority value (255 is highest) becomes the active router for the group. If all router priorities are equal or set to the default value, the router with the highest IP address on the HSRP interface becomes the active router.
In this post, we are going to make our Kali machine a HSRP participant and to become the active router by setting the highest priority to it. Yersinia tool (in built in Kali) helps us to perform this test with ease. For more information on HSRP, please refer RFC 2281
Yersinia is a layer 2- attack toolkit designed to take advantage of weaknesses in various network protocols. One of these protocols is HSRP, with yersinia you can perform below attacks on a HSRP environment.
<0> NONDOS attack sending raw HSRP packet
<1> NONDOS attack becoming ACTIVE router
<2> NONDOS attack becoming ACTIVE router (MITM)
These options are self explanatory, We are going with option 1 in this post.
Hacking HSRP with Kali (or) Backtrack
As illustrated in the snap below, I have crated a simple GNS3 topolgy with 2 HSRP enabled routers and a Kali linux machine which is connected to the same network.
Router 1: (Before Attempt)
R1#sh standby br P indicates configured to preempt. | Interface Grp Pri P State Active Standby Virtual IP Fa0/0 1 110 P Active local 18.104.22.168 22.214.171.124 R1#sh standby fastEthernet 0/0 FastEthernet0/0 - Group 1 State is Active 2 state changes, last state change 00:07:31 Virtual IP address is 126.96.36.199 Active virtual MAC address is 0000.0c07.ac01 Local virtual MAC address is 0000.0c07.ac01 (v1 default) Hello time 3 sec, hold time 10 sec Next hello sent in 1.300 secs Preemption enabled Active router is local Standby router is 188.8.131.52, priority 100 (expires in 7.452 sec) Priority 110 (configured 110) Group name is "hsrp-Fa0/0-1" (default)
Router 2: (Before Attempt)
R2#sh standby br P indicates configured to preempt. | Interface Grp Pri P State Active Standby Virtual IP Fa0/0 1 100 Standby 184.108.40.206 local 220.127.116.11 R2#sh stand fa0/0 FastEthernet0/0 - Group 1 State is Standby 1 state change, last state change 00:07:09 Virtual IP address is 18.104.22.168 Active virtual MAC address is 0000.0c07.ac01 Local virtual MAC address is 0000.0c07.ac01 (v1 default) Hello time 3 sec, hold time 10 sec Next hello sent in 2.096 secs Preemption disabled Active router is 22.214.171.124, priority 110 (expires in 9.960 sec) Standby router is local Priority 100 (default 100) Group name is "hsrp-Fa0/0-1" (default)
Open Terminal window in your Kali machine. Type the below command and press enter,
This opens the yerginia tool in a Graphical window, the same task can be performed by using interactive text based window also (yersinia -I). In this particular post, we'll go with -G.
Click on 'Launch Attack', Select the HSRP tab.
Note: If you have multiple network adapters in your Kali box, you may have to ensure which interface is selected by default (Click on Edit Interfaces).
As we have already mentioned this gives us three options, we'll go with option 2. Check Option 2 (becoming ACTIVE router), and press OK. A window would appear, you can enter and IP and press OK. This doesn't have to be on same subnet. You can enter any.
That's it, within seconds you'll see your routers becoming standby, your Kali will takeover and become the blackhole in your network.
Below are some of the logs taken after the attack,
Router 1 (After):
R1# *Mar 1 00:12:43.567: %HSRP-5-STATECHANGE: FastEthernet0/0 Grp 1 state Speak -> Standby R1#sh standby br P indicates configured to preempt. | Interface Grp Pri P State Active Standby Virtual IP Fa0/0 1 110 P Standby 126.96.36.199 local 188.8.131.52
Router 2 (After):
R2# *Mar 1 00:12:33.587: %HSRP-5-STATECHANGE: FastEthernet0/0 Grp 1 state Standby -> Listen R2#sh standby br P indicates configured to preempt. | Interface Grp Pri P State Active Standby Virtual IP Fa0/0 1 100 Listen 184.108.40.206 220.127.116.11 18.104.22.168
Mitigation:You have two options to prevent these kind of attacks,
1) Use an ACL to drop HSRP messages from unknown IPs
2) Use HSRP Authentication
To enable HSRP authentication with a MD5 key-chain, enter the following configuration:
(config)# key chain <NAME> (config-keychain)# key <ID_number> (config-keychain-key)# key-string <passphrase> (config-if)# standby 1 authentication md5 key-chain <NAME>
This has to be configured on all HSRP participants, Now when the attacker performs this attack, you'll see below logs on your routers.
%HSRP-4-BADAUTH: Bad authentication from 192.168.0.22, group 1, remote state Active
Access Control Lists (ACLs), are also recommended to mitigate these attacks. By only allowing certain IP addresses to access 22.214.171.124 or 126.96.36.199, it becomes much harder for the attacker to pull off a successful strike. To enable an ACL that sets up these restrictions, use the following:
(config)# interface <interface> (config-if)# ip access-group 101 in (config-if)# access-list 101 permit udp host <ip> host 188.8.131.52 eq 1985 (config-if)# access-list 101 deny udp any any eq 1985 (config-if)# access-list 101 permit ip any any
Note: Replace <ip> with a valid host IP address. This line should be used for each router that participates in the HSRP process.
Note: 1985 is the UDP port number that HSRP runs on.
I hope this post is helpful, let me know if you have any queries through comments section.