Please consider donating: https://www.corelan.be/index.php/donate/


27,023 views

Juniper : Netscreen Remote Dial-UP VPN with AD Radius Authentication and route based VPN / tunnel interface

The following procedure explains how to set up a Juniper ScreenOS based firewall to accept Netscreen Remote Client VPN connections and authenticate users using Active Directory (Radius via Windows 2003 IAS or Windows 2008 NPS). 

We’ll assume that all traffic to from the client to the 192.168.0.0/16 networks needs to pass via the client VPN tunnel.  Clients will use dynamic IP addresses (either public or behind a nat router that is capable of handling IPSec passthrough)

The VPN connection must use the following encryption and hashing parameters  and PSK :

  • Phase 1 :  aes-128, sha-1, DH Group2, PSK : This1sNot4GoodPSK3y
  • Phase 2 :  aes-128, sha-1, replay protection, PFS with DH Group2

Network layout :

image

The Juniper firewall has 3 zones : Public (eth2, connected to the internet, static public IP), LAN (eth1, connected to the LAN) and a separate zone called VPNBuffer, not attached to any interface.  This is just an empty zone, a placeholder, so we can create proper policies (instead of defining policies from Public to LAN, we will be able to use policies from VPNBuffer to LAN, thus separating the internet-to-lan traffic policies from the vpn-to-lan policies.  It just looks better… )

All interfaces are in route mode.

In the LAN network, there is a Domain Controller at 192.168.0.6, which will be configured as IAS (Radius) server. (The IAS does not need to be a DC, just a domain member will do)

This is what needs to be done

  • Juniper : Configure an auth server (Radius)
  • Windows : Set up Radius 
    • IAS on Windows 2003  or
    • NPS on Windows 2008
  • Juniper : Define IP Pool / Subnet
  • Juniper : Create tunnel interface
  • Juniper : Set up routing
  • Juniper : Define IKE user/group and External Group for XAuth (Radius)
  • Juniper : Set XAuth defaults
  • Juniper : Configure Phase 1
  • Juniper : Configure Phase 2
  • Juniper : Configure policies
  • Client : Configure Netscreen Remote
  • Client : Connect

 

Configure auth server

Configuration – Auth – Auth Servers – New

image

  • Set a name for the Auth Server
  • Set IP address of server that will be running IAS (Radius)
  • Set account type to XAuth
  • Set Source Interface to the LAN interface (eth1)
  • Enable Radius and set Shared Secret
  • Save new Auth Server

 

Windows 2003 : Set up IAS/Radius

As explained in one of my previous blog posts, IAS is a part of Windows Server. At this point, I will assume you have been able to install the IAS Component on your server, and that you have changed the authentication port to 1645, and the accounting port to 1646 (and that you have restarted the IAS service)

Under IAS, open “Radius Clients”, right-click and add a new Radius client. Enter the IP address of the LAN interface of the firewall (192.168.0.30 in our case. Note : if you have defined a manage-ip that is different than the interface IP, you will need to use this IP).  Client-Vendor is Radius Standard.  Enter the Shared Secret that was entered in the Juniper Auth Server definition. Press Finish to complete the creation of the client.

The final step is to create a policy where you will determine whether a given user should be granted access to VPN or not. You can use Windows AD Groups for this.   First, in AD, create a group that will contain your VPN users. 

Let’s say we’ll use a group called Juniper.VPN.Users, and added a couple of user accounts in there.

image

The idea is now to create an IAS policy that will allow members of this group to be granted access.

In IAS, open “Remote Access Policies” and remove any default policies that may be in there.  (Just don’t delete the “Use Windows authentication for all users” under “Connection Request Policies” (which can be found under “Connection Request Processing”.

In the “Remote Access Policies” section, right-click and choose “New remote access policy”.

Click next at the welcome screen.  Next, choose “Set up a custom policy” and provide a relevant name

image

In the Policy Conditions Window, click “Add”. Select “Windows-Groups” and click “Add”. Click “Add” to add your newly created AD group. Click OK to save.

Click next. Select “grant remote access permission” and click next. 

Click “Edit profile”. Go to the authentication tab. Make sure only PAP/SPAP is selected.  In the Advanced Tab, remove the default attributes (Service-Type and Framed Protocol"). Click “Add” to add a new attribute. Select “Vendor-specific” and click Add to add a new attribute.   Click Add to add a new value.  Set Vendor Code to 3224, select “Yes, it conforms” and Click “Configure Attribute”

In the Configure VSA (RFC Compliant) screen, set Vendor-assigned attribute number to 3, set Attribute format to “string” and enter a string that will be sent to the Juniper firewall upon succesfull authentication. This string needs to match with the name of an external group that will be created on the Juniper. You are free to pick whatever string you like, but I usually use the name of the AD group (so I know that this group matches with an AD group).  So we’ll set the string to “Juniper.VPN.Users”

image

Click OK to save, Click OK, click Close, click OK. Accept the warning. Click next and click Finish.

image

At this point, the Windows environment is ready to authenticate VPN users.  If you want to set up Radius on a Windows 2008 server instead of 2003, read the next chapter (otherwise, you can skip the next chapter and jump right back to the Juniper configuration)

 

Windows 2008 : Set up NPS/Radius

Of course, if you are running Windows 2008, you can also use NPS (which replaces IAS) to achieve the same goal. This is how it works :

First, add the required roles on the server that will acts as Radius server. This does not need to be a DC. If the server is part of the domain, it will work just fine

Open Server Manager and add a role

image

Select Network Policy and Access Services and click next

image

Click next again

Select Network Policy Server (NPS) and click next

image

Click Install. Click ‘close’ when the installation has completed.

Open a MMC and add the NPS snap-in (Local Computer)

image

First, change the Radius port to 1645. Right-click on NPS (Local) and choose properties

image

Go to the ports tabsheet and set Authentication to port 1645 only,  and accounting to port 1646 only. Click OK to save. use the Action pane on the right to stop and start the NPS service (or use “Services” to restart the NPS service)

Open Radius Clients under NPS (Local) – RADIUS Clients and Servers, right-click and choose ‘New Radius Client’

image

Fill out the name, IP address of the Juniper firewall and set the Shared Secret. Leave the Vendor name as Radius Standard

image

Open “Network Policies” under “Policies” and remove the 2 default policies called “Connections to Microsoft Routing and Remote Access server” and “Connections to other access servers” (or just make sure they are disabled)

Then, add a new policy

image

Set a name and leave the type of network access server to Unspecified

image

Click Next

Under “Specify Conditions”, click “Add” and select “Windows Groups”. Click “Add” again

image

Click “Add Groups” and add the AD Group that contains the VPN users (Juniper.VPN.Users in my case)

image

Click OK

Click Next

Set Access Permission to “Access granted” and click Next

image

Authentication methods : deselect everything, except PAP, SPAP

image

Click Next. Click “No” when asked to see the corresponding Help Topic

Constraints : do not set constraints (unless you know what you are doing). Just Click next

Configure Settings :  Under “Standard”, remove the Framed-Protocol and Service-Type Attributes

image

Go to Vendor Specific and click Add

image

Set Vendor to All and select “Vendor-Specific” from the list. Click Add

image

Click Add again

Set Vendor Code to 3224. Select Yes. It Conforms

image

Click “Configure Attribute”

Set attribute number to 3, set format to String, and set Value to Juniper.VPN.Users

image

Click OK

Click OK again

Verify that the new attribute is in the list and click OK again

image

Click Close

image

Click Next. Review the configuration settings

image

Click Finish

That’s it

 

 

Juniper : Define IP Pool / Subnet

The goal is to assign IP addresses to Netscreen remote clients upon connecting to the Juniper via VPN. We’ll have to create an IP Pool for this.  We will use 192.168.99.1-192.168.99.254 (which is in fact the 192.168.99.0/24 network) :

Objects – IP Pools – New

image

image 

Note : this IP Pool should not overlap with any addresses in your network !

 

Juniper : create tunnel interface

We will use route based VPN, so we need to create a tunnel interface.  This will allow us maximum flexibility, will allow us to put the VPN endpoint in the VPNBuffer zone, etc :

set int tunnel.3 zone VPNBuffer
set int tunnel.3 ip unnumbered interface eth0/2

get int tun.3
Interface tunnel.3:
  description tunnel.3
  number 20, if_info 1784, if_index 3, mode route
  link down
  vsys Root, zone VPNBuffer, vr trust-vr
  admin mtu 1500, operating mtu 1500, default mtu 1500
  *ip 0.0.0.0/0  unnumbered, source interface ethernet0/2
  *manage ip 0.0.0.0
  pmtu-v4 disabled
  ping disabled, telnet disabled, SSH disabled, SNMP disabled
  web disabled, ident-reset disabled, SSL disabled

  OSPF disabled  BGP disabled  RIP disabled  RIPng disabled  mtrace disabled
  PIM: not configured  IGMP not configured
  MLD not configured
  NHRP disabled
  bandwidth: physical 0kbps, configured egress [gbw 0kbps mbw 0kbps]
             configured ingress mbw 0kbps, current bw 0kbps
             total allocated gbw 0kbps

 

Juniper : set up routing

The IP Pool that we have created needs to be reachable.  So we need to create proper routing.  In fact, we need to send traffic towards the 192.168.99.0/24 network towards the new tunnel interface :

fw03-> set route 192.168.99.0/24 int tun.3
fw03-> get route | incl 192.168.99
         91    192.168.99.0/24          tun.3         0.0.0.0   S   20      1     Root

In addition to the route on the Juniper, all networks behind the Juniper need to be able to route back to the Juniper firewall in order to be communicate with hosts in the 192.168.99.0/24 network.  We’ll assume that all hosts in the 192.168.1.0/24 network use the Cisco router as default gateway, and the Cisco is configured to route everything to the Juniper firewall.  The Juniper firewall, in return, must have a route towards the 192.168.1.0/24 network, pointing to the Cisco.

fw03-> get route ip 192.168.1.1
 Dest for 192.168.1.1
--------------------------------------------------------------------------------------
trust-vr       : => 192.168.1.0/24 (id=87) via 192.168.0.8 (vr: trust-vr)
                    Interface ethernet0/1 , metric 0

Ok, routing looks good, let’s continue with the Juniper setup

 

Juniper : Define IKE user/group and External Group for XAuth via Radius

We’ll have to define an IKE user which will be used/shared by all Netscreen Remote clients. This will allow the client to set up Phase 1 of the VPN connection.  Since we want to allow multiple users to use the same IKE user at the same time, we’ll need to put this IKE user in a user group and set the number of simultaneous connections to a number larger than 1

This is how it works :

Objects – Users – Local – New

image

Set the username, select IKE User and Simple Identity.  Make sure the User Name and IKE Identity are the same.

Set the number of multiple logins to something higher than 1 (max. value is 25, if you need more, you’ll need to create multiple IKE users and spread the IKE users over your remote user base)

Set IKE ID Type to AUTO. Click OK to save

Next, create a group and place the ike user(s) in the group

Objects – Users – Local Groups – New

image

 

Next, go to Objects – Users – External Groups – New

The name of the group needs to match exactly with the value of the string that will be passed back from the Radius server upon authenticating.  This may or may not be the same name as the AD group (depending on how you have configured the attributes in IAS).  We have chosen to use the same name as the AD group name, which is Juniper.VPN.Users

image

Set the type to XAuth and press OK to save

 

Juniper : set XAuth Defaults

VPNs – AutoKey Advances – XAuth Settings

Set Authentication server to the Auth Server entry that was created earlier

image

Select the IP Pool and enter DNS/WINS settings. You need to set this because there is no other way to assign IP addresses to your VPN clients. If you don’t assign IP addresses, you will have lots of troubles getting the routing between VPN clients and your hosts to work properly.

 

 

Juniper : Configure Phase 1

VPNs – AutoKey Advanced – Gateway – New

Pick a name, select Dialup User Group and select the newly created IKE group

image

Click Advanced

Set the PreShared Key

Select the outgoing interface (which needs to be the public interface, so in our case this is eth0/2).  Set the Security Level to custom and select “pre-g2-aes128-sha).

Set the Mode to Aggressive. Enable NAT-T (this may not be required though – it depends on your setup)

image

Click Return and then OK to save

You may receive a similar warning :

image

Click OK to accept.  You should see the new Phase1 definition now.  Click on the Xauth link next to your new Phase1

image

image

Select XAuth Server, and set the Authentication type to Generic.

Enable External Authentication and pick the Auth server (for Radius) from the list

Select User Group and fill out the group name

Click OK to save

 

Juniper : Configure Phase 2

Go to VPNs – Autokey IKE – New

Set a new name and pick the Predefined Phase 1 that was created earlier

image

Click Advanced

image

Security Level : set to Custom and select g2-esp-aes128-sha from the list.

Enable Replay protection.  Bind the VPN to the tunnel interface that was created earlier. (tunnel.3 in our case)

Enable proxy ID. Set Local IP to 192.168.0.0/16 and Remote IP to 255.255.255.255/32

Make sure Service is set to ANY

Click Return and then OK to save

 

Juniper : Configure Policies

We want to allow remote clients to access 192.168.0.6 and 192.168.1.8

Since the tunnel interface is in zone VPN, we need a policy from VPNBuffer to LAN

We’ll create some objects first

fw03-> set address VPNBuffer NetscreenRemoteUsers 192.168.99.0/24
fw03-> set address LAN Server1 192.168.0.6/32
fw03-> set address LAN Server2 192.168.1.8/32

Next, create the policy (from VPNBuffer to LAN)

image

image

Source : NetscreenRemoteUsers

Destination : server1 (don’t add server2 yet)

Action : Permit (not tunnel !  We are using route based VPN, so action must be permit)

image

(screenshot contains entry for server2, but let’s assume it’s not there yet)

That’s it. We are now ready to configure the Netscreen Remote clients

 

 

Client : Configure Netscreen Remote

In the Security Policy Editor, create a new connection

image

Give the new connection a name (such as VPN to company)

Set the connection security settings to “Secure” and enable “Only connect manually”

image

Remote party ID : enter the IP subnet that is used in the Local IP Proxy ID of Phase 2

Enable Use Secure Gateway Tunnel and Set the IP Address to the public IP of the Juniper VPN (which is 1.1.1.1) in our case

Next, click on the + (plus) symbol next to the new “VPN to company” connection and select “My Identity”

image

Set Certificate to None. Set ID Type to Domain Name and fill out the IKE identity/IKE username string from the IKE user that was created earlier.

Click Pre-Shared Key and enter the Pre-Shared Key that was used when defining Phase 1

image

On the left hand side, select Security Policy

image

Select “Aggressive Mode”, enable PFS (DH Group2) and Enable Replay Detection

Open “Authentication (Phase 1)”, and select Proposal 1

image

Set authentication mode to Pre-Shared Key and Extended Authentication

Set Encrypt Alg to AES-128 and Hash alg to SHA-1

Set SA Life to seconds and enter 28800

Set Key Group to DH Group 2

On the left side, open “Key Exchange (Phase 2)” and select Proposal 1

image

Set SA Life to Seconds and enter 3600

Leave compression to none.  Enable ESP, set Encrypt Alg to AES-128 and Hash alg to SHA-1. Encapsulation = Tunnel. Leave AH (Authentication Protocol) disabled

Save the settings

 

Client : Connect

Try to connect : right-click on the Netscreen Remote Icon, choose “Connect” and select the new connection

image

You should get a User Authentication prompt. Enter a username (DOMAIN\User  or just the username) and the password of an account that is member of the AD Group

image

image

If you would have done a “debug auth radius” on the firewall while the Radius authentication took place, you should see that authentication was successful and that the XAuth group matches with the group that was passed back by the Radius server.

## 2009-01-22 21:41:12 : rad_parse() = rad_msg=0x02f50874{code=2, id=6, ...}
## 2009-01-22 21:41:12 : RadiusRecv: checking j:socket 75, socipv6 -1, sock 75, j:rad_id 6, rad_msg->id 6
## 2009-01-22 21:41:12 : RadiusRecv: Breaking for sock 75
## 2009-01-22 21:41:12 : is_resp_authenticator_valid: Valid Response authenticator
## 2009-01-22 21:41:12 : RadiusRecv: data on socket 75 for aq_ent 0x428db94, state 0x2, curr_server 1, curr_active 1
## 2009-01-22 21:41:12 : >>> rad_recv_auth(soc=3965916)
## 2009-01-22 21:41:12 : rad_attr_store_groups:adding first Juniper.VPN.Users
## 2009-01-22 21:41:12 : <<< rad_recv_auth() = rad_auth_resp=0x043123b0{authed=1 priv=0 role=0 id=6}
## 2009-01-22 21:41:12 : is_resp_authenticator_valid: Valid Response authenticator
## 2009-01-22 21:41:12 : radius_recv_auth_resp: RESPONSE AUTH VALID (was a Accept)
## 2009-01-22 21:41:12 : group_check_ok: ugx_name Juniper.VPN.Users, group_item_ptr 0x2c4f914, username corelan\peter
## 2009-01-22 21:41:12 : is_rad_group_in: compare Juniper.VPN.Users with Juniper.VPN.Users
## 2009-01-22 21:41:12 :  MATCHED
## 2009-01-22 21:41:12 : group_check_ok: ext group Juniper.VPN.Users present
## 2009-01-22 21:41:12 : radius_recv_auth_resp: auth 0x428db94, id 6,  GROUP MATCHED have Juniper.VPN.Users
## 2009-01-22 21:41:12 : radius_recv_auth_resp: auth 0x428db94, id 6,  AUTHENTICATED
## 2009-01-22 21:41:12 : rad_groups_free: freeing: next_item_ptr->group_name Juniper.VPN.Users
## 2009-01-22 21:41:12 : >>> RadiusRecv(aq_ent={un='corelan\peter', fl=3, as_id=2, rt=0, rt1=0, rt2=0})
## 2009-01-22 21:41:12 : <<< RadiusRecv(aq_ent={rad_state=7}) = 1
## 2009-01-22 21:41:12 : RadiusRecv: result 1
## 2009-01-22 21:41:12 : get_auth_radius_clnt_session_id: entered

 

Verify the VPN connection on the Juniper :

fw03-> get ike cookies 

IKEv1 SA -- Active: 1, Dead: 0, Total 1

1097182f/0006, 1.1.1.2:500->1.1.1.1:500, PRESHR/grp2/AES128/SHA, xchg(5) (IKE_NetscreenRemote/grp7/usr10)
resent-tmr 322 lifetime 28800 lt-recv 28800 nxt_rekey 28484 cert-expire 0
responder, err cnt 0, send dir 1, cond 0x30
nat-traversal map not available
ike heartbeat              : disabled
ike heartbeat last rcv time: 0
ike heartbeat last snd time: 0
XAUTH status: 100
DPD seq local 0, peer 762132764

IKEv2 SA -- Active: 0, Dead: 0, Total 0

fw03-> get sa active
Total active sa: 1
total configured sa: 2
HEX ID    Gateway         Port Algorithm     SPI      Life:sec kb Sta   PID vsys
00008001<         1.1.1.2  500 esp:a128/sha1 a12260dd  3289 unlim A/-    -1 0
00008001>         1.1.1.2  500 esp:a128/sha1 1259e395  3289 unlim A/-    -1 0

fw03-> get sa id 0x8001
index 2, name ESP_NetscreenRemote, peer gateway ip 1.1.1.2. vsys<Root>
auto key. tunnel if binding node, tunnel mode, policy id in:<-1> out:<-1>
id hash: >00>ce>69>fb>fb>e3>2d>0e>76>44>4b>67>3c>9a>fa>0d>43>79>6d>b1
 vpngrp:<-1>. sa_list_nxt:<8>. parent_sa_id:<8>.
tunnel id 32769, peer id 0, NSRP Local.     dialup, dynamic member.   site-to-site. Local interface is ethernet0/2 <1.1.1.1>.
  esp, group 2, a128 encryption, sha1 authentication
  autokey, IN active, OUT active
  monitor<0>, latency: 0, availability: 0
  DF bit: clear
  app_sa_flags: 0x2400437
  proxy id: local 192.168.0.0/255.255.0.0, remote 192.168.99.1/255.255.255.255, proto 0, port 0
  ike activity timestamp: 887422404
  DSCP-mark : disabled
nat-traversal map not available
incoming: SPI a12260dd, flag 00004000, tunnel info 40008001, pipeline
  life 3600 sec, 3282 remain, 0 kb, 0 bytes remain
  anti-replay on, last 0x6, window 0x3f, idle timeout value <0>, idled 280 seconds
  next pak sequence number: 0x0
  bytes/paks:360/6; sw bytes/paks:360/6
outgoing: SPI 1259e395, flag 00000000, tunnel info 40008001, pipeline
  life 3600 sec, 3282 remain, 0 kb, 0 bytes remain
  anti-replay on, last 0x0, window 0x0, idle timeout value <0>, idled 318 seconds
  next pak sequence number: 0x0
  bytes/paks:0/0; sw bytes/paks:0/0

 

Verify the XAuth sessions and verify that an IP was assigned to the VPN session :

fw03-> get xauth active

GW Name              Login           Auth By    GW IP           Private IP      Last Login     Session Timeout   Idle Timeout
IKE_NetscreenRemote   corelan\peter  AD Radius         1.1.1.2    192.168.99.1 255.255.255.255  2009-01-22 21:13:10         0      0 

 

Verify that the client can access resources in all networks :

image

image

Verify that it cannot access networks that are not allowed by the policy

image

Adjust the policy, add the 192.168.1.8/32 host (Server2) as allowed destination and see if traffic to the second network works as well :

image

image

© 2009 – 2021, Peter Van Eeckhoutte (corelanc0d3r). All rights reserved.

3 Responses to Juniper : Netscreen Remote Dial-UP VPN with AD Radius Authentication and route based VPN / tunnel interface

Corelan Training

We have been teaching our win32 exploit dev classes at various security cons and private companies & organizations since 2011

Check out our schedules page here and sign up for one of our classes now!

Donate

Want to support the Corelan Team community ? Click here to go to our donations page.

Want to donate BTC to Corelan Team?



Your donation will help funding server hosting.

Corelan Team Merchandise

You can support Corelan Team by donating or purchasing items from the official Corelan Team merchandising store.

Protected by Copyscape Web Plagiarism Tool

Corelan on Slack

You can chat with us and our friends on our Slack workspace:

  • Go to our facebook page
  • Browse through the posts and find the invite to Slack
  • Use the invite to access our Slack workspace
  • Categories