Duo Security Graphic

Protect Your Network with Multi-Factor Authentication

download pdf

History of the Password

In 1960, the Massachusetts Institute of Technology (MIT) developed a computer called Compatible Time-Sharing System (CTSS) that all researchers had access to. However, they shared a common mainframe as well as a single disk file. So, to help keep individual files private, the concept of a password was developed so that users could only access their own specific files for their allotted time.

After many decades, there have been several improvements to protect the password in rest, in use, and in transit using sophisticated encryption and hashing techniques. However, the concept itself has not changed. If your password is leaked or compromised, we have the same problem that we did on day one.

In 2019, an anonymous creator released 2.2 billion usernames and passwords freely across attacker forums, known at that time to be the largest collection of breaches.

So, it’s quite obvious that a single password has not stood the test of time.

Beyond Passwords

We need something more than a single password…

  1. In addition to the password (which will eventually be deprecated), you need to use something that you already have: a device (such as your cell phone).
  2. The device needs to unlock using Face ID to ensure the best security.
  3. In order to receive a one-time password (OTP) or a push notification, your device needs to have updated software and not be jailbroken.

“By 2022, 60% of large and global enterprises and 90% of midsize enterprises (MSEs), will implement passwordless methods in more than 50% of use cases.” -Gartner Research

One of the use cases we are going to talk about is protecting our network device login with Multi-Factor Authentication.

Let’s Talk Multi-Factor Authentication

90% of customers that I encounter today still use their LOCAL, RADIUS, or TACACS enabled username and password to protect their critical network infrastructure. What we’ll see in the remainder of this article is how easy it is to deploy Multi-Factor Authentication (MFA) to your existing infrastructure to protect your network devices.

This is where Cisco Duo does a great Job. The application is not limited to only protecting network device logins; however, this is one area that I am often concerned about. Compromising one network device can lead to compromising the entire network. [Complete List of Duo Capabilities]

So, if you’re interested in protecting your network device logins with MFA, then please continue reading!

Setting Up MFA

Flow of Events:

Packet Flow for Multi-Factor Authentication
  1. Primary authentication initiated to ISE from user to access network device
  2. ISE sends auth request to Duo auth proxy
  3. Auth proxy server validates username/password from AD
  4. Upon validation, auth proxy makes an API call to Duo security for second factor
  5. Duo security sends push notification to end user’s registered device
  6. Device accepts Duo push notification; in turn, Duo responds back to auth proxy
  7. Auth proxy informs send user validation to ISE; ISE assigned configured authorization profile and assigned Priv 15 level access in this case

Now that we understand the basic flow of events, we clearly see there are four key components involved here:

  1. Duo proxy server (in my case, installed on Win Server)
  2. Radius/TACACS server and user identity database (in this case, I’m using ISE and Windows AD)
  3. Network Infrastructure device we are trying to protect (in this case, Cisco 9800-CL controller)
  4. End users who will use Duo for login

Our process will involve configuring these four components.

1. Duo Proxy Configuration

Start by creating a free Duo account, logging in, and clicking on the application you want to protect for TACACS login protection. I will select RADIUS.

Radius Application for Multi-Factor Authentication

This will generate three keys:

  • Integration Key: Secure API call between auth proxy server and Duo security
  • Shared Secret: Secure trust between auth proxy and Duo cloud app
  • API hostname: API call destination unique for the application

Make note of these keys in a secure location because we will be using them soon. These credentials should never be stored or transmitted in unsecure systems such as email, internal documentation / wiki pages, source code repositories, etc. They should only exist on the system(s) being protected by Duo.

Now we can download and install Duo proxy, which can be supported on variety of endpoints. In my case, I’m using Win Server 2012 (a lot of old stuff in my home lab, but it does the job!). [Supported Devices and How to Install Duo Proxy]

Once proxy is installed, configure it to be the bridge between your network and the Duo server by configuring the AuthProxy file. This is where we will use those three keys we talked about.

AuthProxy File for Multi-Factor Authentication

Start the Duo Authentication Proxy Service and check logs to ensure connectivity.

Duo Multi-Factor Authentication Proxy Service

Let’s now configure our TACACS Server (ISE) to send request to Duo proxy server.

2. Configure ISE and User Identity

We will start by creating a new radius token named Duo (can be any name) with assigned Duo proxy server IP and shared secret (not the same as Secret Key used between Auth Proxy and Duo app). If you prefer, you can configure multiple servers as primary and backup.

Radius Token

Create an Identity Source Sequence

Identity Source Sequence

Integrate AD and Import Groups

Integrate AD Import Groups

Built normal TACACS authentication and authorization policy pointing to the source sequence created above. You can get creative here; all I want is to give a user belonging to IT group privilege level 15 if the user passes MFA.

Authentication Policy

3. Configure Network Infrastructure Device

I’m using basic TACACS config for AAA; you can get as creative as you want. I’m using a very basic TACACS configuration below:

TACACS Configuration

4. Provision End User to Use Duo for TACACS Login

In my case, I’m configuring a user manually on Duo. However, if you want to sync AD group with Duo, you can follow instructions here.

It’s a three-step process to activate a user:

  1. Add the user account with phone number
  2. Send activation instructions on phone
  3. Install Duo app and follow intrusions to onboard device

Start Adding User Account and Phone Number

Add User
Add Phone

Send Activation Instructions to Phone

Activation Instructions

User Receives Instructions and Installs the Duo App

There are multiple ways to authenticate a user; we are using push notification.

User Receives Instructions
User Installs Duo

Verify on the Duo Admin Portal that User is Onboarded

Admin Portal

We are ready to access our device using MFA! As we do, we can verify the logs on ISE, Auth Proxy and Duo.

On ISE under TACACS live logs we see authentication and authorization logs.

TACACS Live Logs

AuthProxy Logs Returning Access-Accept

Auth Proxy Logs Accepted

On Duo ituser2 Granted Access

Authentication Logs

Conclusion

You saw in this article how to start protecting your critical infrastructure in a few simple steps. However, this is just the tip of the iceberg!

If you have any questions or would like help setting up MFA, please reach out to your DSI account manager or email [email protected]. They can put you in touch with me directly and we can discuss how to protect your applications/users and network infrastructure with Cisco Duo.

Thank you for reading and we look forward to discussing a new topic in the next newsletter!

About the Author

Ambuj M. is a Cisco Certified Internetwork Expert (CCIE) and Certified Wireless Network Expert (CWNE) with 15 years of industry experience. He currently works as a Network Solutions Architect for DISYS Solutions Inc. (DSI Tech).