I have elegantly shown how to set up a WPA Enterprise architecture using PEAP-MSCHAPv2 🤢 and EAP-TLS 🥰. The configuration works without a hitch. However, in my network, there are different user profiles for Wi-Fi access, each requiring access to specific VLANs. But how can I ensure that some users are directed to the ADMINS VLAN, while others are assigned to the USERS VLAN?
There are two strategies for achieving this: the first is to configure multiple SSIDs (one for each VLAN), which requires a separate RADIUS server to manage each VLAN. However, this approach can be complex and impractical. The more efficient solution is to exploit RADIUS attributes such as Tunnel-Private-Group-ID, Tunnel Medium Type, and Tunnel Type to enable dynamic VLAN assignment. By doing so, we can manage all VLANs from a single NPS server, and users will only need to connect to a single SSID. In this guide, we'll look at the latter method.
- For the rest of this guide, we'll make the following assumptions:
- We have successfully configured a working PEAP-MSCHAPv2 or EAP-TLS installation.
- The VLANs have been set up correctly in our network.
data:image/s3,"s3://crabby-images/8ce16/8ce16f552050cfd2ec453d9fd11e1c13582b412e" alt="Network diagram showing VLAN management with RADIUS NPS server, UniFi access points, and WPA-Enterprise WiFi setup."
UniFi Network Server
We need to configure several parameters in the UniFi Network Server. Let's take a closer look at the process.
In this scenario, let's consider a configuration with three distinct networks: 192.168.1.0/24 designated for Servers and WiFi access points, 192.168.10.0/24 allocated to Users, and 192.168.100.0/24 specifically reserved for Administrators.
- In the RADIUS profile, activate RADIUS Assigned VLAN Support for Wireless Networks:
data:image/s3,"s3://crabby-images/d7f48/d7f48fbf56f47577ce8fcb9c87e898ca8e4440eb" alt="UniFi Network settings for RADIUS showing VLAN support enabled for wireless networks"
- Make sure that your VLANs are correctly configured:
data:image/s3,"s3://crabby-images/c3dbc/c3dbcdf62771efa7aa31452fc1f3a592e602cd59" alt="UniFi Network settings displaying virtual networks for VLANs with Admins and Users configurations"
Authentication Server (NPS)
- Open the Network Policy Server Console:
data:image/s3,"s3://crabby-images/86815/86815ad8ead373affe0c9c776446bf065cb6dc67" alt="Windows Run dialog box with nps.msc command for opening Network Policy Server"
You need to set up two separate Network Policies: one for ADMINS and another for USERS.
- Click on New in the Network Policies folder:
data:image/s3,"s3://crabby-images/44292/44292776bc95e17a633bc4ec36bf001c2045f161" alt="Network Policy Server window showing the creation of a new network policy on Windows Server"
- Give Policy a name:
data:image/s3,"s3://crabby-images/232bd/232bd3b97d2952c29071a7fbb139d2f811052d2e" alt="New Network Policy setup on Windows Server with policy name 'ADMINS' and connection type options"
- Click on Add to specify the condition:
data:image/s3,"s3://crabby-images/6010e/6010eed5452841e34351d995a6f54447db5e68b3" alt="New Network Policy window on Windows Server with option to add conditions for policy evaluation"
- Select User Groups, and click on Add Groups…:
data:image/s3,"s3://crabby-images/ca8b6/ca8b62c8cb8bacd60f9a312c39c608ebe605db40" alt="New Network Policy window on Windows Server showing User Groups condition with option to add groups"
- Add an Active Directory user group, e.g. Domain Admins for ADMINS:
data:image/s3,"s3://crabby-images/fd6d0/fd6d07f4244d693031a30ccd89f8b7060437969d" alt="New Network Policy window on Windows Server showing selection of Domain Admins group for policy condition"
- Click on Next:
data:image/s3,"s3://crabby-images/040a6/040a6fc60d1dc76d0fdfa7e4c903edf412fe647d" alt="New Network Policy window on Windows Server displaying User Groups condition set to Domain Admins"
- Select Access granted:
data:image/s3,"s3://crabby-images/06d90/06d90e984b196907dc2cdba6c03539dd315972c3" alt="New Network Policy window on Windows Server showing access permission set to 'Access granted'"
- In the Configure Settings section, you can delete the pre-existing entry for Framed-Protocol PPP and then click on Add…:
data:image/s3,"s3://crabby-images/18c47/18c47cf089755d5ffe033651280709f7646f01d1" alt="New Network Policy configuration on Windows Server with RADIUS attributes, including Framed-Protocol set to PPP"
- Now let's add these three entries:
- Tunnel-Type: Virtual LANs (VLAN)
- Tunnel-Pvt-Group-ID: 100 for ADMINS or 10 for USERS
- Tunnel-Medium-Type: 802 (including all 802 media as well as the canonical Ethernet format)
- Add Tunnel-Type parameter:
data:image/s3,"s3://crabby-images/5fe23/5fe2335ff66420ebfb8df4658fc729c65f05606d" alt="Adding Standard RADIUS Attribute for Tunnel-Type in Windows Server Network Policy with VLAN setting"
- Add Tunnel-Pvt-Group-ID parameter:
data:image/s3,"s3://crabby-images/dbfa9/dbfa9d714785c8fbb1878bf137e04de1d3961da4" alt="Adding Standard RADIUS Attribute for Tunnel-Pvt-Group-ID in Windows Server Network Policy with Group ID set to 100"
- Add Tunnel-Medium-Type parameter:
data:image/s3,"s3://crabby-images/8a434/8a434478379eb6577b137ac310e106f253eb1ff6" alt="Adding Standard RADIUS Attribute for Tunnel-Medium-Type in Windows Server Network Policy with 802 media setting"
- Once you have entered all the parameters, click Next…:
data:image/s3,"s3://crabby-images/6237f/6237ff3bbc6872af637cce99ceaff54536a0b04c" alt="New Network Policy configuration on Windows Server with RADIUS attributes including VLAN and Tunnel settings"
- Finally, click on Finish to finalize the creation of the Policy:
data:image/s3,"s3://crabby-images/a6dbd/a6dbd7497ff88a448b9cf50e45ae5377c5dda1cc" alt="UniFi Network settings displaying virtual networks for VLANs with Admins and Users configurations"
- All you have to do is repeat the same process for the USERS VLANs, and you're done!