* Windows IPSec/L2TP VPN client and Linux server with RADIUS, and PPP.
@ 2005-09-05 9:46 Jim Barber
2005-09-06 0:15 ` Windows IPSec/L2TP VPN client and Linux server with RADIUS, and Jim Barber
` (4 more replies)
0 siblings, 5 replies; 6+ messages in thread
From: Jim Barber @ 2005-09-05 9:46 UTC (permalink / raw)
To: linux-ppp
I am hoping that someone can help me.
I have been working on this problem for days now and I've read so much
online documentation, how-tos, etc that my eyes are ready to fall out of
my head. :)
I have been trying to set up a Linux VPN server that will support the
IPSec/L2TP VPN client that is available with Microsoft Windows 2000
onwards.
I first tried the 'testing' distribution of Debian, but after failing to
get it to work with lt2pns, I moved to the 'unstable' distribution so
that I had new software available, and so I could use lt2pd with the
pppd daemon.
The infrastructure that I've been using to try and support this is:
- FreeRADIUS 1.0.4 for user authentication.
- Linux 2.6 kernel for the IPSec tunnel.
- Racoon 0.6.1 for the IPSec Key exchange.
- l2tpd 0.7-pre20031121 for the L2TP daemon.
- pppd 2.4.3-20050321+2 for the PPP daemon.
- radiusclient 0.3.2 for the PPP radius.so plugin configuration.
- openssl 0.9.7g for the generation and signing of certificates and keys.
I have had some limited success...
If I don't use the radius.so ppp plugin, and define a test user in the
/etc/ppp/chap-secrets file, then VPNs from my Windows XP client works
perfectly.
If I enable the use of the radius.so plugin, then users will no longer
authenticate.
However if I change the properties in the client's VPN security settings
so that all of the CHAP, MSCHAP, MSCHAPv2 options are disabled, and
only the PAP connection is enabled, then authentication via the radius
server works perfectly.
I don't want to post full logs at this stage unless someone requests
them since they are huge. I will post what I think is relevent at this
stage...
I believe that the RADIUS authentication isn't happening with MSCHAPv2
enabled because it doesn't have enough information passed to it.
The debugging part of the RADIUS server shows the following incoming
information:
rad_recv: Access-Request packet from host 10.10.0.218:1024, id\x107, lengthQ
Service-Type = Framed-User
Framed-Protocol = PPP
User-Name = "user1"
NAS-IP-Address = 10.10.0.216
NAS-Port = 0
From my research I believe that I should also see MS-CHAP-Challenge and
MS-CHAP2-Response entries in the output above.
I believe that the MS-CHAPv2 information is reaching the ppp daemon
because I see entries in it's debugging output like so:
sent [LCP ConfReq id=0x1 <mru 1400> <asyncmap 0x0> <auth chap MD5> <magic 0x9d821c9a> <pcomp> <accomp>]
rcvd [LCP ConfNak id=0x1 <auth chap MS-v2>]
sent [LCP ConfReq id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2> <magic 0x9d821c9a> <pcomp> <accomp>]
rcvd [LCP ConfAck id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2> <magic 0x9d821c9a> <pcomp> <accomp>]
rcvd [LCP ConfReq id=0x1 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp> <callback CBCP>]
sent [LCP ConfRej id=0x1 <callback CBCP>]
rcvd [LCP ConfReq id=0x2 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp>]
sent [LCP ConfAck id=0x2 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp>]
sent [LCP EchoReq id=0x0 magic=0x9d821c9a]
sent [CHAP Challenge id=0x29 <0e8e59d6606f7233d9fc0ef7e3e66301>, name = "research"]
rcvd [LCP Ident id=0x3 magic=0x5b52779d "MSRASV5.10"]
rcvd [LCP Ident id=0x4 magic=0x5b52779d "MSRAS-0-MICROBEE"]
rcvd [LCP EchoRep id=0x0 magic=0x5b52779d]
rcvd [CHAP Response id=0x29 <2f9bc1d22db3ecd79957616fd713c9080000000000000000b8f4c19d7d7edc1fbecfb562edc55cf3d5c17c8644b03cd500>,
name = "user1"]
sent [CHAP Failure id=0x29 ""]
sent [LCP TermReq id=0x3 "Authentication failed"]
So either the ppp radius plugin isn't correctly seeing this MSCHAPv2
information and so failing to pass it on to the FreeRADIUS server, or it
is passing the information to the radius server, but the radius server
is failing to interpret it as MS-CHAP-Challenge and MS-CHAP2-Response
entries.
My configuration for the l2tpd daemon is as follows:
[global]
listen-addr = 10.10.0.219
port = 1701
[lns default]
ip range = 10.10.0.248 - 10.10.0.254
local ip = 10.10.0.220
require chap = yes
refuse pap = yes
require authentication = yes
hostname = vpn1
ppp debug = yes
pppoptfile = /etc/ppp/options.l2tpd
length bit = yes
My configuration in the /etc/ppp/options.l2tpd file is as follows:
ms-dns 10.10.0.100
ms-wins 10.10.0.100
auth
crtscts
lock
mru 1400
mtu 1400
nodetach
debug
proxyarp
ipcp-accept-local
ipcp-accept-remote
idle 1800
connect-delay 5000
nodefaultroute
refuse-pap
refuse-chap
refuse-mschap
require-mschap-v2
nologfd
plugin radius.so
I've configured the /etc/radiusclient/servers file with the correct
passwords for the radius server.
I've configured the /etc/radiusclient/radiusclient.conf with IP address
of the radius server.
In the modules section of the /etc/freeradius/radiusd.conf file I have
the following entry:
mschap {
authtype = MS-CHAP
}
In the authorize section of the /etc/freeradius/radiusd.conf file I have
the following entry:
mschap
In the authenticate section of the /etc/freeradius/radiusd.conf file I
have the following entry:
Auth-Type MS-CHAP {
mschap
}
At one stage I was wondering if MPPE support was required, but I
couldn't see how since that is only for encryption of the PPP layer
which isn't necessary. But having tried all sorts of different
configuration combinations, I decided to compile up a kernel with
the MPPE patches along with enabling the MPPE directives in the
FreeRADIUS config and the options.l2tp file. This made no difference,
which I am happy with as that is what I expected.
I tried rebuilding the ppp Debian Package to see if it is compiled with
MS-CHAP support out of the box, and it does appear that it is. My custom
version of ppp didn't fair any better.
So I'm stuck now.
Does anyone know where I can go from here?
If necessary, I can post up complete logs, and even full configuration
files, but I thought I'd spare you all for the moment.
Any help is very much appreciated.
Regards,
--
----------
Jim Barber
DDI Health
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Windows IPSec/L2TP VPN client and Linux server with RADIUS, and
2005-09-05 9:46 Windows IPSec/L2TP VPN client and Linux server with RADIUS, and PPP Jim Barber
@ 2005-09-06 0:15 ` Jim Barber
2005-09-06 1:21 ` Jim Barber
` (3 subsequent siblings)
4 siblings, 0 replies; 6+ messages in thread
From: Jim Barber @ 2005-09-06 0:15 UTC (permalink / raw)
To: linux-ppp
First of all, thanks for taking the time to reply to my post.
Okay. I'll post the log this time. :)
But first I'll address your points.
1. radtest works perfectly:
root@research:~# radtest user1 password1 10.10.0.218 1812 radius_secret
Sending Access-Request of id 30 to 10.10.0.218:1812
User-Name = "user1"
User-Password = "password1"
NAS-IP-Address = research
NAS-Port = 1812
rad_recv: Access-Accept packet from host 10.10.0.218:1812, id0, length
Also authenticating the Windows VPN client works against radius if I
just use PAP authentication in the security settings.
Therefore I believe the radius server to be working correctly
(except perhaps MSCHAPv2)
3. My client is definately setup to use MSCHAPv2.
For the VPN connection, under:
Properties -> Security -> Advanced (custom settings) -> Settings...
I have the following settings:
Data encryption (dropdown box): "Require encryption (disconnect if server declines)"
I've chosen the "Allow these protocols" radio button, and the
only check-boxes that are ticked are:
"Microsoft CHAP (MS-CHAP)" and "Microsoft CHAP Version 2 (MS-CHAP v2)"
But with these options I am not seeing the MS-CHAP-Challenge and
MS-CHAP2-Response in the Radius output.
Note though as per my original email that you see the MSCHAPv2
traffic in the PPP logs (auth chap MS-v2).
eg.
sent [LCP ConfReq id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2> <magic> 0x9d821c9a> <pcomp> <accomp>]
rcvd [LCP ConfAck id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2> <magic> 0x9d821c9a> <pcomp> <accomp>]
4. Do you mean setting the "Data encryption:" drop down box to be
"Optional encryption (connect even if no encryption)"?
I just tried that but it still fails.
But it was something that I didn't think of trying. Thanks.
I've also tried with the MPPE patches and it makes no difference.
5. Radius is using the sql backend with a mysql database.
It has the bare-minimum in it to operate
(one test user called "user1" with a password of "password1"):
mysql> select * from radcheck;
+----+----------+---------------+----+-----------+
| id | UserName | Attribute | op | Value |
+----+----------+---------------+----+-----------+
| 1 | user1 | User-Password | = | password1 |
+----+----------+---------------+----+-----------+
mysql> select * from usergroup;
+----+----------+-----------+
| id | UserName | GroupName |
+----+----------+-----------+
| 1 | user1 | dynamic |
+----+----------+-----------+
mysql> select * from radgroupcheck;
+----+-----------+-----------+----+-------+
| id | GroupName | Attribute | op | Value |
+----+-----------+-----------+----+-------+
| 1 | dynamic | Auth-Type | := | Local |
+----+-----------+-----------+----+-------+
I've also tried without any entries in the usergroup and radgroupcheck
tables since if the mschapv2 module detects an incoming MS-CHAPv2
connection, then it should set 'Auth-Type := MS-CHAP' anyway.
Note that setting it to MS-CHAP manually doesn't work due to the missing
incoming MS-CHAP-Challenge and MS-CHAP2-Response strings.
I know that you shouldn't override it at all, and I think that when
I get MS-CHAPv2 authorisation working against the radius server that I
can probably truncate the usergroup and radgroupcheck tables again.
Again note that the above setup works fine when authentication the user
via PAP.
6. Okay here is the log of the RADIUS server starting up and then trying
to accept an incoming MS-CHAPv2 connection.
Sorry for flooding everyone's email inboxes.
root@research:~# freeradius -X
Starting - reading configuration files ...
reread_config: reading radiusd.conf
Config: including file: /etc/freeradius/proxy.conf
Config: including file: /etc/freeradius/clients.conf
Config: including file: /etc/freeradius/snmp.conf
Config: including file: /etc/freeradius/eap.conf
Config: including file: /etc/freeradius/sql.conf
main: prefix = "/usr"
main: localstatedir = "/var"
main: logdir = "/var/log/freeradius"
main: libdir = "/usr/lib/freeradius"
main: radacctdir = "/var/log/freeradius/radacct"
main: hostname_lookups = no
main: max_request_time = 30
main: cleanup_delay = 5
main: max_requests = 1024
main: delete_blocked_requests = 0
main: port = 1812
main: allow_core_dumps = no
main: log_stripped_names = no
main: log_file = "/var/log/freeradius/radius.log"
main: log_auth = no
main: log_auth_badpass = no
main: log_auth_goodpass = no
main: pidfile = "/var/run/freeradius/freeradius.pid"
main: user = "freerad"
main: group = "freerad"
main: usercollide = no
main: lower_user = "no"
main: lower_pass = "no"
main: nospace_user = "no"
main: nospace_pass = "no"
main: checkrad = "/usr/sbin/checkrad"
main: proxy_requests = yes
proxy: retry_delay = 5
proxy: retry_count = 3
proxy: synchronous = no
proxy: default_fallback = yes
proxy: dead_time = 120
proxy: post_proxy_authorize = yes
proxy: wake_all_if_all_dead = no
security: max_attributes = 200
security: reject_delay = 1
security: status_server = no
main: debug_level = 0
read_config_files: reading dictionary
read_config_files: reading naslist
Using deprecated naslist file. Support for this will go away soon.
read_config_files: reading clients
read_config_files: reading realms
listen: ipaddr = 127.0.0.1 IP address [127.0.0.1]
listen: port = 0
listen: type = "auth"
listen: ipaddr = 127.0.0.1 IP address [127.0.0.1]
listen: port = 0
listen: type = "acct"
listen: ipaddr = 10.10.0.218 IP address [10.10.0.218]
listen: port = 0
listen: type = "auth"
listen: ipaddr = 10.10.0.218 IP address [10.10.0.218]
listen: port = 0
listen: type = "acct"
radiusd: entering modules setup
Module: Library search path is /usr/lib/freeradius
Module: Loaded exec
exec: wait = yes
exec: program = "(null)"
exec: input_pairs = "request"
exec: output_pairs = "(null)"
exec: packet_type = "(null)"
rlm_exec: Wait=yes but no output defined. Did you mean output=none?
Module: Instantiated exec (exec)
Module: Loaded expr
Module: Instantiated expr (expr)
Module: Loaded PAP
pap: encryption_scheme = "crypt"
Module: Instantiated pap (pap)
Module: Loaded CHAP
Module: Instantiated chap (chap)
Module: Loaded MS-CHAP
mschap: use_mppe = no
mschap: require_encryption = yes
mschap: require_strong = yes
mschap: with_ntdomain_hack = no
mschap: passwd = "(null)"
mschap: authtype = "MS-CHAP"
mschap: ntlm_auth = "(null)"
Module: Instantiated mschap (mschap)
Module: Loaded System
unix: cache = no
unix: passwd = "(null)"
unix: shadow = "/etc/shadow"
unix: group = "(null)"
unix: radwtmp = "/var/log/freeradius/radwtmp"
unix: usegroup = no
unix: cache_reload = 600
Module: Instantiated unix (unix)
Module: Loaded eap
eap: default_eap_type = "md5"
eap: timer_expire = 60
eap: ignore_unknown_eap_types = no
eap: cisco_accounting_username_bug = no
rlm_eap: Loaded and initialized type md5
rlm_eap: Loaded and initialized type leap
gtc: challenge = "Password: "
gtc: auth_type = "PAP"
rlm_eap: Loaded and initialized type gtc
mschapv2: with_ntdomain_hack = no
rlm_eap: Loaded and initialized type mschapv2
Module: Instantiated eap (eap)
Module: Loaded preprocess
preprocess: huntgroups = "/etc/freeradius/huntgroups"
preprocess: hints = "/etc/freeradius/hints"
preprocess: with_ascend_hack = no
preprocess: ascend_channels_per_line = 23
preprocess: with_ntdomain_hack = no
preprocess: with_specialix_jetstream_hack = no
preprocess: with_cisco_vsa_hack = no
Module: Instantiated preprocess (preprocess)
Module: Loaded realm
realm: format = "suffix"
realm: delimiter = "@"
realm: ignore_default = no
realm: ignore_null = no
Module: Instantiated realm (suffix)
Module: Loaded files
files: usersfile = "/etc/freeradius/users"
files: acctusersfile = "/etc/freeradius/acct_users"
files: preproxy_usersfile = "/etc/freeradius/preproxy_users"
files: compat = "no"
Module: Instantiated files (files)
Module: Loaded SQL
sql: driver = "rlm_sql_mysql"
sql: server = "mysql1.ddihealth.com"
sql: port = ""
sql: login = "radius"
sql: password = "radius_password"
sql: radius_db = "radius"
sql: acct_table = "radacct"
sql: acct_table2 = "radacct"
sql: authcheck_table = "radcheck"
sql: authreply_table = "radreply"
sql: groupcheck_table = "radgroupcheck"
sql: groupreply_table = "radgroupreply"
sql: usergroup_table = "usergroup"
sql: nas_table = "nas"
sql: dict_table = "dictionary"
sql: sqltrace = no
sql: sqltracefile = "/var/log/freeradius/sqltrace.sql"
sql: readclients = no
sql: deletestalesessions = yes
sql: num_sql_socks = 5
sql: sql_user_name = "%{User-Name}"
sql: default_user_profile = ""
sql: query_on_not_found = no
sql: authorize_check_query = "SELECT id,UserName,Attribute,Value,op FROM radcheck WHERE Username = '%{SQL-User-Name}' ORDER BY id"
sql: authorize_reply_query = "SELECT id,UserName,Attribute,Value,op FROM radreply WHERE Username = '%{SQL-User-Name}' ORDER BY id"
sql: authorize_group_check_query = "SELECT
radgroupcheck.id,radgroupcheck.GroupName,radgroupcheck.Attribute,radgroupcheck.Value,radgroupcheck.op FROM radgroupcheck,usergroup
WHERE usergroup.Username = '%{SQL-User-Name}' AND usergroup.GroupName = radgroupcheck.GroupName ORDER BY radgroupcheck.id"
sql: authorize_group_reply_query = "SELECT
radgroupreply.id,radgroupreply.GroupName,radgroupreply.Attribute,radgroupreply.Value,radgroupreply.op FROM radgroupreply,usergroup
WHERE usergroup.Username = '%{SQL-User-Name}' AND usergroup.GroupName = radgroupreply.GroupName ORDER BY radgroupreply.id"
sql: accounting_onoff_query = "UPDATE radacct SET AcctStopTime='%S', AcctSessionTime=unix_timestamp('%S') -
unix_timestamp(AcctStartTime), AcctTerminateCause='%{Acct-Terminate-Cause}', AcctStopDelay = '%{Acct-Delay-Time}' WHERE
AcctSessionTime=0 AND AcctStopTime=0 AND NASIPAddress= '%{NAS-IP-Address}' AND AcctStartTime <= '%S'"
sql: accounting_update_query = "UPDATE radacct ? SET FramedIPAddress = '%{Framed-IP-Address}', ? AcctSessionTime =
'%{Acct-Session-Time}', ? AcctInputOctets = '%{Acct-Input-Octets}', ? AcctOutputOctets = '%{Acct-Output-Octets}' ? WHERE
AcctSessionId = '%{Acct-Session-Id}' ? AND UserName = '%{SQL-User-Name}' ? AND NASIPAddress= '%{NAS-IP-Address}'"
sql: accounting_update_query_alt = "INSERT into radacct (AcctSessionId, AcctUniqueId, UserName, Realm, NASIPAddress, NASPortId,
NASPortType, AcctStartTime, AcctSessionTime, AcctAuthentic, ConnectInfo_start, AcctInputOctets, AcctOutputOctets, CalledStationId,
CallingStationId, ServiceType, FramedProtocol, FramedIPAddress, AcctStartDelay) values('%{Acct-Session-Id}',
'%{Acct-Unique-Session-Id}', '%{SQL-User-Name}', '%{Realm}', '%{NAS-IP-Address}', '%{NAS-Port}', '%{NAS-Port-Type}',
DATE_SUB('%S',INTERVAL (%{Acct-Session-Time:-0} + %{Acct-Delay-Time:-0}) SECOND), '%{Acct-Session-Time}', '%{Acct-Authentic}', '',
'%{Acct-Input-Octets}', '%{Acct-Output-Octets}', '%{Called-Station-Id}', '%{Calling-Station-Id}', '%{Service-Type}',
'%{Framed-Protocol}', '%{Framed-IP-Address}', '0')"
sql: accounting_start_query = "INSERT into radacct (AcctSessionId, AcctUniqueId, UserName, Realm, NASIPAddress, NASPortId,
NASPortType, AcctStartTime, AcctStopTime, AcctSessionTime, AcctAuthentic, ConnectInfo_start, ConnectInfo_stop, AcctInputOctets,
AcctOutputOctets, CalledStationId, CallingStationId, AcctTerminateCause, ServiceType, FramedProtocol, FramedIPAddress,
AcctStartDelay, AcctStopDelay) values('%{Acct-Session-Id}', '%{Acct-Unique-Session-Id}', '%{SQL-User-Name}', '%{Realm}',
'%{NAS-IP-Address}', '%{NAS-Port}','%{NAS-Port-Type}', '%S', '0', '0', '%{Acct-Authentic}', '%{Connect-Info}', '', '0', '0',
'%{Called-Station-Id}', '%{Calling-Station-Id}', '', '%{Service-Type}', '%{Framed-Protocol}', '%{Framed-IP-Address}',
'%{Acct-Delay-Time}', '0')"
sql: accounting_start_query_alt = "UPDATE radacct SET AcctStartTime = '%S', AcctStartDelay = '%{Acct-Delay-Time}',
ConnectInfo_start = '%{Connect-Info}' WHERE AcctSessionId = '%{Acct-Session-Id}' AND UserName = '%{SQL-User-Name}' AND NASIPAddress
= '%{NAS-IP-Address}'"
sql: accounting_stop_query = "UPDATE radacct SET AcctStopTime = '%S', AcctSessionTime = '%{Acct-Session-Time}', AcctInputOctets =
'%{Acct-Input-Octets}', AcctOutputOctets = '%{Acct-Output-Octets}', AcctTerminateCause = '%{Acct-Terminate-Cause}', AcctStopDelay =
'%{Acct-Delay-Time}', ConnectInfo_stop = '%{Connect-Info}' WHERE AcctSessionId = '%{Acct-Session-Id}' AND UserName =
'%{SQL-User-Name}' AND NASIPAddress = '%{NAS-IP-Address}'"
sql: accounting_stop_query_alt = "INSERT into radacct (AcctSessionId, AcctUniqueId, UserName, Realm, NASIPAddress, NASPortId,
NASPortType, AcctStartTime, AcctStopTime, AcctSessionTime, AcctAuthentic, ConnectInfo_start, ConnectInfo_stop, AcctInputOctets,
AcctOutputOctets, CalledStationId, CallingStationId, AcctTerminateCause, ServiceType, FramedProtocol, FramedIPAddress,
AcctStartDelay, AcctStopDelay) values('%{Acct-Session-Id}', '%{Acct-Unique-Session-Id}', '%{SQL-User-Name}', '%{Realm}',
'%{NAS-IP-Address}', '%{NAS-Port}', '%{NAS-Port-Type}', DATE_SUB('%S', INTERVAL (%{Acct-Session-Time:-0} + %{Acct-Delay-Time:-0})
SECOND), '%S', '%{Acct-Session-Time}', '%{Acct-Authentic}', '', '%{Connect-Info}', '%{Acct-Input-Octets}', '%{Acct-Output-Octets}',
'%{Called-Station-Id}', '%{Calling-Station-Id}', '%{Acct-Terminate-Cause}', '%{Service-Type}', '%{Framed-Protocol}',
'%{Framed-IP-Address}', '0', '%{Acct-Delay-Time}')"
sql: group_membership_query = "SELECT GroupName FROM usergroup WHERE UserName='%{SQL-User-Name}'"
sql: connect_failure_retry_delay = 60
sql: simul_count_query = ""
sql: simul_verify_query = "SELECT RadAcctId, AcctSessionId, UserName, NASIPAddress, NASPortId, FramedIPAddress, CallingStationId,
FramedProtocol FROM radacct WHERE UserName='%{SQL-User-Name}' AND AcctStopTime = 0"
sql: postauth_table = "radpostauth"
sql: postauth_query = "INSERT into radpostauth (id, user, pass, reply, date) values ('', '%{User-Name}',
'%{User-Password:-Chap-Password}', '%{reply:Packet-Type}', NOW())"
sql: safe-characters = "@abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789.-_: /"
rlm_sql (sql): Driver rlm_sql_mysql (module rlm_sql_mysql) loaded and linked
rlm_sql (sql): Attempting to connect to radius@mysql1.ddihealth.com:/radius
rlm_sql (sql): starting 0
rlm_sql (sql): Attempting to connect rlm_sql_mysql #0
rlm_sql_mysql: Starting connect to MySQL server for #0
rlm_sql (sql): Connected new DB handle, #0
rlm_sql (sql): starting 1
rlm_sql (sql): Attempting to connect rlm_sql_mysql #1
rlm_sql_mysql: Starting connect to MySQL server for #1
rlm_sql (sql): Connected new DB handle, #1
rlm_sql (sql): starting 2
rlm_sql (sql): Attempting to connect rlm_sql_mysql #2
rlm_sql_mysql: Starting connect to MySQL server for #2
rlm_sql (sql): Connected new DB handle, #2
rlm_sql (sql): starting 3
rlm_sql (sql): Attempting to connect rlm_sql_mysql #3
rlm_sql_mysql: Starting connect to MySQL server for #3
rlm_sql (sql): Connected new DB handle, #3
rlm_sql (sql): starting 4
rlm_sql (sql): Attempting to connect rlm_sql_mysql #4
rlm_sql_mysql: Starting connect to MySQL server for #4
rlm_sql (sql): Connected new DB handle, #4
Module: Instantiated sql (sql)
Module: Loaded Acct-Unique-Session-Id
acct_unique: key = "User-Name, Acct-Session-Id, NAS-IP-Address, Client-IP-Address, NAS-Port"
Module: Instantiated acct_unique (acct_unique)
Module: Loaded detail
detail: detailfile = "/var/log/freeradius/radacct/%{Client-IP-Address}/detail-%Y%m%d"
detail: detailperm = 384
detail: dirperm = 493
detail: locking = no
Module: Instantiated detail (detail)
Listening on authentication 127.0.0.1:1812
Listening on accounting 127.0.0.1:1813
Listening on authentication 10.10.0.218:1812
Listening on accounting 10.10.0.218:1813
Listening on proxy *:1814
Ready to process requests.
rad_recv: Access-Request packet from host 10.10.0.218:1024, id\x110, lengthQ
Service-Type = Framed-User
Framed-Protocol = PPP
User-Name = "user1"
NAS-IP-Address = 10.10.0.216
NAS-Port = 0
Processing the authorize section of radiusd.conf
modcall: entering group authorize for request 0
modcall[authorize]: module "preprocess" returns ok for request 0
modcall[authorize]: module "chap" returns noop for request 0
modcall[authorize]: module "mschap" returns noop for request 0
rlm_realm: No '@' in User-Name = "user1", looking up realm NULL
rlm_realm: No such realm "NULL"
modcall[authorize]: module "suffix" returns noop for request 0
rlm_eap: No EAP-Message, not doing EAP
modcall[authorize]: module "eap" returns noop for request 0
users: Matched entry DEFAULT at line 152
users: Matched entry DEFAULT at line 171
users: Matched entry DEFAULT at line 183
modcall[authorize]: module "files" returns ok for request 0
radius_xlat: 'user1'
rlm_sql (sql): sql_set_user escaped user --> 'user1'
radius_xlat: 'SELECT id,UserName,Attribute,Value,op FROM radcheck WHERE Username = 'user1' ORDER BY id'
rlm_sql (sql): Reserving sql socket id: 4
radius_xlat: 'SELECT radgroupcheck.id,radgroupcheck.GroupName,radgroupcheck.Attribute,radgroupcheck.Value,radgroupcheck.op FROM ra
dgroupcheck,usergroup WHERE usergroup.Username = 'user1' AND usergroup.GroupName = radgroupcheck.GroupName ORDER BY radgroupcheck.id
'
radius_xlat: 'SELECT id,UserName,Attribute,Value,op FROM radreply WHERE Username = 'user1' ORDER BY id'
radius_xlat: 'SELECT radgroupreply.id,radgroupreply.GroupName,radgroupreply.Attribute,radgroupreply.Value,radgroupreply.op FROM ra
dgroupreply,usergroup WHERE usergroup.Username = 'user1' AND usergroup.GroupName = radgroupreply.GroupName ORDER BY radgroupreply.id
'
rlm_sql (sql): Released sql socket id: 4
modcall[authorize]: module "sql" returns ok for request 0
modcall: group authorize returns ok for request 0
rad_check_password: Found Auth-Type Local
auth: type Local
auth: No User-Password or CHAP-Password attribute in the request
auth: Failed to validate the user.
Delaying request 0 for 1 seconds
Finished request 0
Going to the next request
--- Walking the entire request list ---
Waking up in 1 seconds...
--- Walking the entire request list ---
Waking up in 1 seconds...
--- Walking the entire request list ---
Sending Access-Reject of id 110 to 10.10.0.218:1024
Waking up in 4 seconds...
--- Walking the entire request list ---
Cleaning up request 0 ID 110 with timestamp 431cdc94
Nothing to do. Sleeping until we see a request.
Regards,
----------
Jim Barber
DDI Health
Seferovic Edvin wrote:
> Hi,
>
> this seems like a RADIUS error.
>
> 1. try testing your RADIUS configuration with radtest ( see man radtest )
>
> 2. next time start radius with radiusd -Xxa and copy the main parts of the
> log into the mail.
>
> 3. it seems that your VPN daemon is not set to use MSCHAPv2 or your client
> isnt configured either... so you are right.. you should see something like
> this:
>
> rad_recv: Access-Request packet from host xx, id\x180, length\x146
> Service-Type = Framed-User
> Framed-Protocol = PPP
> User-Name = "xxxxxxx"
> MS-CHAP-Challenge = 0xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx9
> MS-CHAP2-Response = xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
> Calling-Station-Id = "xxxx"
> NAS-IP-Address = xxxxxxxxxxx
> NAS-Port = 0
>
> 4. check the client -> Connection properties -> security -> setting -> check
> the box with MSCHAPv2, and choose NO ENCRYPTION ( you said you dont have
> that module .. sooo.. )
>
> 5. radius is using which backend ( file/sql/ldap/etc?? ) ? You need
> clear-text passwords for the MSCHAPv2 auth, or LM/NT Hashes !
>
> 6. post the logs next time ;)
>
> Regards,
>
> Edvin Seferovic
>
>
> -----Original Message-----
> From: linux-ppp-owner@vger.kernel.org
> [mailto:linux-ppp-owner@vger.kernel.org] On Behalf Of Jim Barber
> Sent: Montag, 05. September 2005 11:46
> To: linux-ppp@vger.kernel.org
> Subject: Windows IPSec/L2TP VPN client and Linux server with RADIUS, and
> PPP.
>
> I am hoping that someone can help me.
> I have been working on this problem for days now and I've read so much
> online documentation, how-tos, etc that my eyes are ready to fall out of
> my head. :)
>
> I have been trying to set up a Linux VPN server that will support the
> IPSec/L2TP VPN client that is available with Microsoft Windows 2000
> onwards.
>
> I first tried the 'testing' distribution of Debian, but after failing to
> get it to work with lt2pns, I moved to the 'unstable' distribution so
> that I had new software available, and so I could use lt2pd with the
> pppd daemon.
>
> The infrastructure that I've been using to try and support this is:
>
> - FreeRADIUS 1.0.4 for user authentication.
> - Linux 2.6 kernel for the IPSec tunnel.
> - Racoon 0.6.1 for the IPSec Key exchange.
> - l2tpd 0.7-pre20031121 for the L2TP daemon.
> - pppd 2.4.3-20050321+2 for the PPP daemon.
> - radiusclient 0.3.2 for the PPP radius.so plugin configuration.
> - openssl 0.9.7g for the generation and signing of certificates and keys.
>
> I have had some limited success...
>
> If I don't use the radius.so ppp plugin, and define a test user in the
> /etc/ppp/chap-secrets file, then VPNs from my Windows XP client works
> perfectly.
>
> If I enable the use of the radius.so plugin, then users will no longer
> authenticate.
> However if I change the properties in the client's VPN security settings
> so that all of the CHAP, MSCHAP, MSCHAPv2 options are disabled, and
> only the PAP connection is enabled, then authentication via the radius
> server works perfectly.
>
> I don't want to post full logs at this stage unless someone requests
> them since they are huge. I will post what I think is relevent at this
> stage...
>
> I believe that the RADIUS authentication isn't happening with MSCHAPv2
> enabled because it doesn't have enough information passed to it.
> The debugging part of the RADIUS server shows the following incoming
> information:
>
> rad_recv: Access-Request packet from host 10.10.0.218:1024, id\x107,
> lengthQ
> Service-Type = Framed-User
> Framed-Protocol = PPP
> User-Name = "user1"
> NAS-IP-Address = 10.10.0.216
> NAS-Port = 0
>
> From my research I believe that I should also see MS-CHAP-Challenge and
> MS-CHAP2-Response entries in the output above.
>
> I believe that the MS-CHAPv2 information is reaching the ppp daemon
> because I see entries in it's debugging output like so:
>
> sent [LCP ConfReq id=0x1 <mru 1400> <asyncmap 0x0> <auth chap MD5> <magic
> 0x9d821c9a> <pcomp> <accomp>]
> rcvd [LCP ConfNak id=0x1 <auth chap MS-v2>]
> sent [LCP ConfReq id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2> <magic
> 0x9d821c9a> <pcomp> <accomp>]
> rcvd [LCP ConfAck id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2> <magic
> 0x9d821c9a> <pcomp> <accomp>]
> rcvd [LCP ConfReq id=0x1 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp>
> <callback CBCP>]
> sent [LCP ConfRej id=0x1 <callback CBCP>]
> rcvd [LCP ConfReq id=0x2 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp>]
> sent [LCP ConfAck id=0x2 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp>]
> sent [LCP EchoReq id=0x0 magic=0x9d821c9a]
> sent [CHAP Challenge id=0x29 <0e8e59d6606f7233d9fc0ef7e3e66301>, name > "research"]
> rcvd [LCP Ident id=0x3 magic=0x5b52779d "MSRASV5.10"]
> rcvd [LCP Ident id=0x4 magic=0x5b52779d "MSRAS-0-MICROBEE"]
> rcvd [LCP EchoRep id=0x0 magic=0x5b52779d]
> rcvd [CHAP Response id=0x29
> <2f9bc1d22db3ecd79957616fd713c9080000000000000000b8f4c19d7d7edc1fbecfb562edc
> 55cf3d5c17c8644b03cd500>,
> name = "user1"]
> sent [CHAP Failure id=0x29 ""]
> sent [LCP TermReq id=0x3 "Authentication failed"]
>
> So either the ppp radius plugin isn't correctly seeing this MSCHAPv2
> information and so failing to pass it on to the FreeRADIUS server, or it
> is passing the information to the radius server, but the radius server
> is failing to interpret it as MS-CHAP-Challenge and MS-CHAP2-Response
> entries.
>
> My configuration for the l2tpd daemon is as follows:
>
> [global]
> listen-addr = 10.10.0.219
> port = 1701
>
> [lns default]
> ip range = 10.10.0.248 - 10.10.0.254
> local ip = 10.10.0.220
> require chap = yes
> refuse pap = yes
> require authentication = yes
> hostname = vpn1
> ppp debug = yes
> pppoptfile = /etc/ppp/options.l2tpd
> length bit = yes
>
> My configuration in the /etc/ppp/options.l2tpd file is as follows:
>
> ms-dns 10.10.0.100
> ms-wins 10.10.0.100
> auth
> crtscts
> lock
> mru 1400
> mtu 1400
> nodetach
> debug
> proxyarp
> ipcp-accept-local
> ipcp-accept-remote
> idle 1800
> connect-delay 5000
> nodefaultroute
> refuse-pap
> refuse-chap
> refuse-mschap
> require-mschap-v2
> nologfd
> plugin radius.so
>
> I've configured the /etc/radiusclient/servers file with the correct
> passwords for the radius server.
> I've configured the /etc/radiusclient/radiusclient.conf with IP address
> of the radius server.
>
> In the modules section of the /etc/freeradius/radiusd.conf file I have
> the following entry:
>
> mschap {
> authtype = MS-CHAP
> }
>
> In the authorize section of the /etc/freeradius/radiusd.conf file I have
> the following entry:
>
> mschap
>
> In the authenticate section of the /etc/freeradius/radiusd.conf file I
> have the following entry:
>
> Auth-Type MS-CHAP {
> mschap
> }
>
> At one stage I was wondering if MPPE support was required, but I
> couldn't see how since that is only for encryption of the PPP layer
> which isn't necessary. But having tried all sorts of different
> configuration combinations, I decided to compile up a kernel with
> the MPPE patches along with enabling the MPPE directives in the
> FreeRADIUS config and the options.l2tp file. This made no difference,
> which I am happy with as that is what I expected.
>
> I tried rebuilding the ppp Debian Package to see if it is compiled with
> MS-CHAP support out of the box, and it does appear that it is. My custom
> version of ppp didn't fair any better.
>
> So I'm stuck now.
> Does anyone know where I can go from here?
>
> If necessary, I can post up complete logs, and even full configuration
> files, but I thought I'd spare you all for the moment.
>
> Any help is very much appreciated.
>
> Regards,
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Windows IPSec/L2TP VPN client and Linux server with RADIUS, and
2005-09-05 9:46 Windows IPSec/L2TP VPN client and Linux server with RADIUS, and PPP Jim Barber
2005-09-06 0:15 ` Windows IPSec/L2TP VPN client and Linux server with RADIUS, and Jim Barber
@ 2005-09-06 1:21 ` Jim Barber
2005-09-08 0:24 ` Jim Barber
` (2 subsequent siblings)
4 siblings, 0 replies; 6+ messages in thread
From: Jim Barber @ 2005-09-06 1:21 UTC (permalink / raw)
To: linux-ppp
Thanks Edvin.
I am using the Debian 'unstable' distribution.
I've chosen 'unstable' because I couldn't get it working with the
'testing' distribution of Debian either, so I figured I'd use the
distribution that had the newest versions all the software that I
wanted just incase they had bug fixes or features added that I required.
All versions of the software used are in my original post.
As far as I can tell, all of the Debian packages I've installed seem to
have support for ms-chap enabled (since they all seem to talk about it
in the logs).
The radiusclient1 package that I installed does not have a
/etc/radiusclient/dictionary.microsoft file.
Nor does it's existing dictionary files have any entries for
MS-CHAP-Challenge or any of the other attributes.
I suppose I should have mentioned that I also played around with this.
Steps I tried were:
1. Create the symlink /etc/radiusclient/dictionary.microsoft to point to
/usr/share/freeradius/dictionary.microsoft.
The file is in the format:
VENDOR Microsoft 311
BEGIN-VENDOR Microsoft
.
ATTRIBUTE MS-CHAP-Challenge 11 octets
.
VALUE MS-Acct-Auth-Type MS-CHAP-2 4
.
END-VENDOR Microsoft
2. Still leaving the symlink, I added an entry to the top of the
existing /etc/radiusclient/dictionary file like so:
$INCLUDE dictionary.microsoft
3. I got rid of the symlink to dictionary.microsoft and copied the file
in so that I could edit it.
I changed the format of the file to be:
VENDOR Microsoft 311
.
ATTRIBUTE MS-CHAP-Challenge 11 octets Microsoft
.
VALUE MS-Acct-Auth-Type MS-CHAP-2 4
.
4. I got rid of the $INCLUDE directive in /etc/radiusclient/dictionary
and merged the dictionary.microsoft file into it.
5. Same as above, but merged in the original format of the
dictionary.microsoft file instead.
None of the these steps solved the problem, and at no stage did I see
the MS-CHAP-Challenge, MS-CHAP2-Response strings that I was hoping to
see in the RADIUS debugging output.
Hmmm a log of the l2tpd daemon. Okay...
Here are the l2tpd entries that end up in my /var/log/daemon log after
a fresh start of the l2tpd daemon, followed by a connection attempt by
the VPN client:
l2tpd[7505]: This binary does not support kernel L2TP.
l2tpd[7506]: l2tpd version 0.69 started on research PID:7506
l2tpd[7506]: Linux version 2.6.12-research on a i686, listening on IP address 10.10.0.219, port 1701
l2tpd[7506]: ourtid = 15706, entropy_buf = 3d5a
l2tpd[7506]: check_control: control, cid = 0, Ns = 0, Nr = 0
l2tpd[7506]: handle_avps: handling avp's for tunnel 15706, call 0
l2tpd[7506]: message_type_avp: message type 1 (Start-Control-Connection-Request)
l2tpd[7506]: protocol_version_avp: peer is using version 1, revision 0.
l2tpd[7506]: framing_caps_avp: supported peer frames: sync
l2tpd[7506]: bearer_caps_avp: supported peer bearers:
l2tpd[7506]: firmware_rev_avp: peer reports firmware version 1280 (0x0500)
l2tpd[7506]: hostname_avp: peer reports hostname 'microbee.ddihealth.com'
l2tpd[7506]: vendor_avp: peer reports vendor 'Microsoft'
l2tpd[7506]: assigned_tunnel_avp: using peer's tunnel 160
l2tpd[7506]: receive_window_size_avp: peer wants RWS of 8. Will use flow control.
l2tpd[7506]: check_control: control, cid = 0, Ns = 1, Nr = 1
l2tpd[7506]: handle_avps: handling avp's for tunnel 15706, call 0
l2tpd[7506]: message_type_avp: message type 3 (Start-Control-Connection-Connected)
l2tpd[7506]: control_finish: Connection established to 10.10.0.38, 1701. Local: 15706, Remote: 160. LNS session is 'default'
l2tpd[7506]: check_control: control, cid = 0, Ns = 2, Nr = 1
l2tpd[7506]: handle_avps: handling avp's for tunnel 15706, call 0
l2tpd[7506]: message_type_avp: message type 10 (Incoming-Call-Request)
l2tpd[7506]: message_type_avp: new incoming call
l2tpd[7506]: ourcid = 11366, entropy_buf = 2c66
l2tpd[7506]: assigned_session_avp: assigned session id: 1
l2tpd[7506]: call_serno_avp: serial number is 0
l2tpd[7506]: bearer_type_avp: peer bears: analog
l2tpd[7506]: check_control: control, cid = 1, Ns = 3, Nr = 2
l2tpd[7506]: handle_avps: handling avp's for tunnel 15706, call 11366
l2tpd[7506]: message_type_avp: message type 12 (Incoming-Call-Connected)
l2tpd[7506]: tx_speed_avp: transmit baud rate is 100000000
l2tpd[7506]: frame_type_avp: peer uses:sync frames
l2tpd[7506]: ignore_avp : Ignoring AVP
l2tpd[7506]: start_pppd: I'm running:
l2tpd[7506]: "/usr/sbin/pppd"
l2tpd[7506]: "passive"
l2tpd[7506]: "-detach"
l2tpd[7506]: "10.10.0.220:10.10.0.248"
l2tpd[7506]: "refuse-pap"
l2tpd[7506]: "auth"
l2tpd[7506]: "require-chap"
l2tpd[7506]: "debug"
l2tpd[7506]: "file"
l2tpd[7506]: "/etc/ppp/options.l2tpd"
l2tpd[7506]: "/dev/ttyp0"
l2tpd[7506]:
l2tpd[7506]: control_finish: Call established with 10.10.0.38, Local: 11366, Remote: 1, Serial: 0
l2tpd[7506]: check_control: control, cid = 1, Ns = 4, Nr = 2
l2tpd[7506]: handle_avps: handling avp's for tunnel 15706, call 11366
l2tpd[7506]: message_type_avp: message type 14 (Call-Disconnect-Notify)
l2tpd[7506]: result_code_avp: peer closing for reason 3 (Call disconnected for administrative reasons), error = 0 ()
l2tpd[7506]: assigned_session_avp: assigned session id: 1
l2tpd[7506]: control_finish: Peer tried to disconnect without specifying call ID
l2tpd[7506]: check_control: control, cid = 0, Ns = 5, Nr = 2
l2tpd[7506]: handle_avps: handling avp's for tunnel 15706, call 0
l2tpd[7506]: message_type_avp: message type 4 (Stop-Control-Connection-Notification)
l2tpd[7506]: assigned_tunnel_avp: using peer's tunnel 160
l2tpd[7506]: result_code_avp: peer closing for reason 6 (Requester is being shut down), error = 0 ()
l2tpd[7506]: control_finish: Connection closed to 10.10.0.38, port 1701 (), Local: 15706, Remote: 160
The configuration of the l2tpd daemon is in my orignal post.
Well being in Western Australia, it looks like I'm about 8 hours ahead
of you. The time gap makes it difficult for rapid communications :)
Now that there is a lot of log detail up, hopefully someone can spot a
solution to my problem.
*fingers crossed*
Regards,
----------
Jim Barber
DDI Health
Seferovic Edvin wrote:
> Hi,
>
> Ill be short this time.. its almost 3 AM at my place ;) If it is not Radius
> ( you have "cleared" all my questions ), maybe it is the radiusclient.
> Radiusclient uses dictionary file where attributes are defined. There should
> be /etc/radiusclient/dictionary.microsoft which contains MS-CHAP-Challenge
> and other attributes. Please make sure that this file is included, and tell
> me next time how the attributes in dictionary.microsoft "look like" .. just
> i.e. "integer" or "integer Microsoft" ?
>
> What distro are you using?
>
> Could you post the whole log of lt2p-daemon?
>
> See ya in the morning ;)
>
> Regards,
>
> Edvin Seferovic
>
> -----Original Message-----
> From: Jim Barber [mailto:jim.barber@ddihealth.com]
> Sent: Dienstag, 06. September 2005 02:15
> To: edvin.seferovic@kolp.at
> Cc: linux-ppp@vger.kernel.org
> Subject: Re: Windows IPSec/L2TP VPN client and Linux server with RADIUS, and PPP.
>
> First of all, thanks for taking the time to reply to my post.
> Okay. I'll post the log this time. :)
>
> But first I'll address your points.
>
> 1. radtest works perfectly:
>
> root@research:~# radtest user1 password1 10.10.0.218 1812 radius_secret
> Sending Access-Request of id 30 to 10.10.0.218:1812
> User-Name = "user1"
> User-Password = "password1"
> NAS-IP-Address = research
> NAS-Port = 1812
> rad_recv: Access-Accept packet from host 10.10.0.218:1812, id0, length
>
> Also authenticating the Windows VPN client works against radius if I
> just use PAP authentication in the security settings.
> Therefore I believe the radius server to be working correctly
> (except perhaps MSCHAPv2)
>
> 3. My client is definately setup to use MSCHAPv2.
> For the VPN connection, under:
> Properties -> Security -> Advanced (custom settings) -> Settings...
> I have the following settings:
>
> Data encryption (dropdown box): "Require encryption (disconnect if server declines)"
> I've chosen the "Allow these protocols" radio button, and the
> only check-boxes that are ticked are:
> "Microsoft CHAP (MS-CHAP)" and "Microsoft CHAP Version 2 (MS-CHAP v2)"
>
> But with these options I am not seeing the MS-CHAP-Challenge and
> MS-CHAP2-Response in the Radius output.
> Note though as per my original email that you see the MSCHAPv2
> traffic in the PPP logs (auth chap MS-v2).
> eg.
> sent [LCP ConfReq id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2> <magic> 0x9d821c9a> <pcomp> <accomp>]
> rcvd [LCP ConfAck id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2> <magic> 0x9d821c9a> <pcomp> <accomp>]
>
> 4. Do you mean setting the "Data encryption:" drop down box to be
> "Optional encryption (connect even if no encryption)"?
> I just tried that but it still fails.
> But it was something that I didn't think of trying. Thanks.
> I've also tried with the MPPE patches and it makes no difference.
>
> 5. Radius is using the sql backend with a mysql database.
> It has the bare-minimum in it to operate
> (one test user called "user1" with a password of "password1"):
>
> mysql> select * from radcheck;
> +----+----------+---------------+----+-----------+
> | id | UserName | Attribute | op | Value |
> +----+----------+---------------+----+-----------+
> | 1 | user1 | User-Password | = | password1 |
> +----+----------+---------------+----+-----------+
>
> mysql> select * from usergroup;
> +----+----------+-----------+
> | id | UserName | GroupName |
> +----+----------+-----------+
> | 1 | user1 | dynamic |
> +----+----------+-----------+
>
> mysql> select * from radgroupcheck;
> +----+-----------+-----------+----+-------+
> | id | GroupName | Attribute | op | Value |
> +----+-----------+-----------+----+-------+
> | 1 | dynamic | Auth-Type | := | Local |
> +----+-----------+-----------+----+-------+
>
> I've also tried without any entries in the usergroup and radgroupcheck
> tables since if the mschapv2 module detects an incoming MS-CHAPv2
> connection, then it should set 'Auth-Type := MS-CHAP' anyway.
> Note that setting it to MS-CHAP manually doesn't work due to the missing
> incoming MS-CHAP-Challenge and MS-CHAP2-Response strings.
> I know that you shouldn't override it at all, and I think that when
> I get MS-CHAPv2 authorisation working against the radius server that I
> can probably truncate the usergroup and radgroupcheck tables again.
> Again note that the above setup works fine when authentication the user
> via PAP.
>
> 6. Okay here is the log of the RADIUS server starting up and then trying
> to accept an incoming MS-CHAPv2 connection.
> Sorry for flooding everyone's email inboxes.
>
> root@research:~# freeradius -X
> Starting - reading configuration files ...
> reread_config: reading radiusd.conf
> Config: including file: /etc/freeradius/proxy.conf
> Config: including file: /etc/freeradius/clients.conf
> Config: including file: /etc/freeradius/snmp.conf
> Config: including file: /etc/freeradius/eap.conf
> Config: including file: /etc/freeradius/sql.conf
> main: prefix = "/usr"
> main: localstatedir = "/var"
> main: logdir = "/var/log/freeradius"
> main: libdir = "/usr/lib/freeradius"
> main: radacctdir = "/var/log/freeradius/radacct"
> main: hostname_lookups = no
> main: max_request_time = 30
> main: cleanup_delay = 5
> main: max_requests = 1024
> main: delete_blocked_requests = 0
> main: port = 1812
> main: allow_core_dumps = no
> main: log_stripped_names = no
> main: log_file = "/var/log/freeradius/radius.log"
> main: log_auth = no
> main: log_auth_badpass = no
> main: log_auth_goodpass = no
> main: pidfile = "/var/run/freeradius/freeradius.pid"
> main: user = "freerad"
> main: group = "freerad"
> main: usercollide = no
> main: lower_user = "no"
> main: lower_pass = "no"
> main: nospace_user = "no"
> main: nospace_pass = "no"
> main: checkrad = "/usr/sbin/checkrad"
> main: proxy_requests = yes
> proxy: retry_delay = 5
> proxy: retry_count = 3
> proxy: synchronous = no
> proxy: default_fallback = yes
> proxy: dead_time = 120
> proxy: post_proxy_authorize = yes
> proxy: wake_all_if_all_dead = no
> security: max_attributes = 200
> security: reject_delay = 1
> security: status_server = no
> main: debug_level = 0
> read_config_files: reading dictionary
> read_config_files: reading naslist
> Using deprecated naslist file. Support for this will go away soon.
> read_config_files: reading clients
> read_config_files: reading realms
> listen: ipaddr = 127.0.0.1 IP address [127.0.0.1]
> listen: port = 0
> listen: type = "auth"
> listen: ipaddr = 127.0.0.1 IP address [127.0.0.1]
> listen: port = 0
> listen: type = "acct"
> listen: ipaddr = 10.10.0.218 IP address [10.10.0.218]
> listen: port = 0
> listen: type = "auth"
> listen: ipaddr = 10.10.0.218 IP address [10.10.0.218]
> listen: port = 0
> listen: type = "acct"
> radiusd: entering modules setup
> Module: Library search path is /usr/lib/freeradius
> Module: Loaded exec
> exec: wait = yes
> exec: program = "(null)"
> exec: input_pairs = "request"
> exec: output_pairs = "(null)"
> exec: packet_type = "(null)"
> rlm_exec: Wait=yes but no output defined. Did you mean output=none?
> Module: Instantiated exec (exec)
> Module: Loaded expr
> Module: Instantiated expr (expr)
> Module: Loaded PAP
> pap: encryption_scheme = "crypt"
> Module: Instantiated pap (pap)
> Module: Loaded CHAP
> Module: Instantiated chap (chap)
> Module: Loaded MS-CHAP
> mschap: use_mppe = no
> mschap: require_encryption = yes
> mschap: require_strong = yes
> mschap: with_ntdomain_hack = no
> mschap: passwd = "(null)"
> mschap: authtype = "MS-CHAP"
> mschap: ntlm_auth = "(null)"
> Module: Instantiated mschap (mschap)
> Module: Loaded System
> unix: cache = no
> unix: passwd = "(null)"
> unix: shadow = "/etc/shadow"
> unix: group = "(null)"
> unix: radwtmp = "/var/log/freeradius/radwtmp"
> unix: usegroup = no
> unix: cache_reload = 600
> Module: Instantiated unix (unix)
> Module: Loaded eap
> eap: default_eap_type = "md5"
> eap: timer_expire = 60
> eap: ignore_unknown_eap_types = no
> eap: cisco_accounting_username_bug = no
> rlm_eap: Loaded and initialized type md5
> rlm_eap: Loaded and initialized type leap
> gtc: challenge = "Password: "
> gtc: auth_type = "PAP"
> rlm_eap: Loaded and initialized type gtc
> mschapv2: with_ntdomain_hack = no
> rlm_eap: Loaded and initialized type mschapv2
> Module: Instantiated eap (eap)
> Module: Loaded preprocess
> preprocess: huntgroups = "/etc/freeradius/huntgroups"
> preprocess: hints = "/etc/freeradius/hints"
> preprocess: with_ascend_hack = no
> preprocess: ascend_channels_per_line = 23
> preprocess: with_ntdomain_hack = no
> preprocess: with_specialix_jetstream_hack = no
> preprocess: with_cisco_vsa_hack = no
> Module: Instantiated preprocess (preprocess)
> Module: Loaded realm
> realm: format = "suffix"
> realm: delimiter = "@"
> realm: ignore_default = no
> realm: ignore_null = no
> Module: Instantiated realm (suffix)
> Module: Loaded files
> files: usersfile = "/etc/freeradius/users"
> files: acctusersfile = "/etc/freeradius/acct_users"
> files: preproxy_usersfile = "/etc/freeradius/preproxy_users"
> files: compat = "no"
> Module: Instantiated files (files)
> Module: Loaded SQL
> sql: driver = "rlm_sql_mysql"
> sql: server = "mysql1.ddihealth.com"
> sql: port = ""
> sql: login = "radius"
> sql: password = "radius_password"
> sql: radius_db = "radius"
> sql: acct_table = "radacct"
> sql: acct_table2 = "radacct"
> sql: authcheck_table = "radcheck"
> sql: authreply_table = "radreply"
> sql: groupcheck_table = "radgroupcheck"
> sql: groupreply_table = "radgroupreply"
> sql: usergroup_table = "usergroup"
> sql: nas_table = "nas"
> sql: dict_table = "dictionary"
> sql: sqltrace = no
> sql: sqltracefile = "/var/log/freeradius/sqltrace.sql"
> sql: readclients = no
> sql: deletestalesessions = yes
> sql: num_sql_socks = 5
> sql: sql_user_name = "%{User-Name}"
> sql: default_user_profile = ""
> sql: query_on_not_found = no
> sql: authorize_check_query = "SELECT id,UserName,Attribute,Value,op FROM
> radcheck WHERE Username = '%{SQL-User-Name}' ORDER BY id"
> sql: authorize_reply_query = "SELECT id,UserName,Attribute,Value,op FROM
> radreply WHERE Username = '%{SQL-User-Name}' ORDER BY id"
> sql: authorize_group_check_query = "SELECT
> radgroupcheck.id,radgroupcheck.GroupName,radgroupcheck.Attribute,radgroupche
> ck.Value,radgroupcheck.op FROM radgroupcheck,usergroup
> WHERE usergroup.Username = '%{SQL-User-Name}' AND usergroup.GroupName > radgroupcheck.GroupName ORDER BY radgroupcheck.id"
> sql: authorize_group_reply_query = "SELECT
> radgroupreply.id,radgroupreply.GroupName,radgroupreply.Attribute,radgrouprep
> ly.Value,radgroupreply.op FROM radgroupreply,usergroup
> WHERE usergroup.Username = '%{SQL-User-Name}' AND usergroup.GroupName > radgroupreply.GroupName ORDER BY radgroupreply.id"
> sql: accounting_onoff_query = "UPDATE radacct SET AcctStopTime='%S',
> AcctSessionTime=unix_timestamp('%S') -
> unix_timestamp(AcctStartTime), AcctTerminateCause='%{Acct-Terminate-Cause}',
> AcctStopDelay = '%{Acct-Delay-Time}' WHERE
> AcctSessionTime=0 AND AcctStopTime=0 AND NASIPAddress= '%{NAS-IP-Address}'
> AND AcctStartTime <= '%S'"
> sql: accounting_update_query = "UPDATE radacct ? SET FramedIPAddress > '%{Framed-IP-Address}', ? AcctSessionTime =
> '%{Acct-Session-Time}', ? AcctInputOctets = '%{Acct-Input-Octets}', ?
> AcctOutputOctets = '%{Acct-Output-Octets}' ? WHERE
> AcctSessionId = '%{Acct-Session-Id}' ? AND UserName = '%{SQL-User-Name}' ?
> AND NASIPAddress= '%{NAS-IP-Address}'"
> sql: accounting_update_query_alt = "INSERT into radacct (AcctSessionId,
> AcctUniqueId, UserName, Realm, NASIPAddress, NASPortId,
> NASPortType, AcctStartTime, AcctSessionTime, AcctAuthentic,
> ConnectInfo_start, AcctInputOctets, AcctOutputOctets, CalledStationId,
> CallingStationId, ServiceType, FramedProtocol, FramedIPAddress,
> AcctStartDelay) values('%{Acct-Session-Id}',
> '%{Acct-Unique-Session-Id}', '%{SQL-User-Name}', '%{Realm}',
> '%{NAS-IP-Address}', '%{NAS-Port}', '%{NAS-Port-Type}',
> DATE_SUB('%S',INTERVAL (%{Acct-Session-Time:-0} + %{Acct-Delay-Time:-0})
> SECOND), '%{Acct-Session-Time}', '%{Acct-Authentic}', '',
> '%{Acct-Input-Octets}', '%{Acct-Output-Octets}', '%{Called-Station-Id}',
> '%{Calling-Station-Id}', '%{Service-Type}',
> '%{Framed-Protocol}', '%{Framed-IP-Address}', '0')"
> sql: accounting_start_query = "INSERT into radacct (AcctSessionId,
> AcctUniqueId, UserName, Realm, NASIPAddress, NASPortId,
> NASPortType, AcctStartTime, AcctStopTime, AcctSessionTime, AcctAuthentic,
> ConnectInfo_start, ConnectInfo_stop, AcctInputOctets,
> AcctOutputOctets, CalledStationId, CallingStationId, AcctTerminateCause,
> ServiceType, FramedProtocol, FramedIPAddress,
> AcctStartDelay, AcctStopDelay) values('%{Acct-Session-Id}',
> '%{Acct-Unique-Session-Id}', '%{SQL-User-Name}', '%{Realm}',
> '%{NAS-IP-Address}', '%{NAS-Port}','%{NAS-Port-Type}', '%S', '0', '0',
> '%{Acct-Authentic}', '%{Connect-Info}', '', '0', '0',
> '%{Called-Station-Id}', '%{Calling-Station-Id}', '', '%{Service-Type}',
> '%{Framed-Protocol}', '%{Framed-IP-Address}',
> '%{Acct-Delay-Time}', '0')"
> sql: accounting_start_query_alt = "UPDATE radacct SET AcctStartTime > '%S', AcctStartDelay = '%{Acct-Delay-Time}',
> ConnectInfo_start = '%{Connect-Info}' WHERE AcctSessionId > '%{Acct-Session-Id}' AND UserName = '%{SQL-User-Name}' AND NASIPAddress
> = '%{NAS-IP-Address}'"
> sql: accounting_stop_query = "UPDATE radacct SET AcctStopTime = '%S',
> AcctSessionTime = '%{Acct-Session-Time}', AcctInputOctets =
> '%{Acct-Input-Octets}', AcctOutputOctets = '%{Acct-Output-Octets}',
> AcctTerminateCause = '%{Acct-Terminate-Cause}', AcctStopDelay =
> '%{Acct-Delay-Time}', ConnectInfo_stop = '%{Connect-Info}' WHERE
> AcctSessionId = '%{Acct-Session-Id}' AND UserName =
> '%{SQL-User-Name}' AND NASIPAddress = '%{NAS-IP-Address}'"
> sql: accounting_stop_query_alt = "INSERT into radacct (AcctSessionId,
> AcctUniqueId, UserName, Realm, NASIPAddress, NASPortId,
> NASPortType, AcctStartTime, AcctStopTime, AcctSessionTime, AcctAuthentic,
> ConnectInfo_start, ConnectInfo_stop, AcctInputOctets,
> AcctOutputOctets, CalledStationId, CallingStationId, AcctTerminateCause,
> ServiceType, FramedProtocol, FramedIPAddress,
> AcctStartDelay, AcctStopDelay) values('%{Acct-Session-Id}',
> '%{Acct-Unique-Session-Id}', '%{SQL-User-Name}', '%{Realm}',
> '%{NAS-IP-Address}', '%{NAS-Port}', '%{NAS-Port-Type}', DATE_SUB('%S',
> INTERVAL (%{Acct-Session-Time:-0} + %{Acct-Delay-Time:-0})
> SECOND), '%S', '%{Acct-Session-Time}', '%{Acct-Authentic}', '',
> '%{Connect-Info}', '%{Acct-Input-Octets}', '%{Acct-Output-Octets}',
> '%{Called-Station-Id}', '%{Calling-Station-Id}', '%{Acct-Terminate-Cause}',
> '%{Service-Type}', '%{Framed-Protocol}',
> '%{Framed-IP-Address}', '0', '%{Acct-Delay-Time}')"
> sql: group_membership_query = "SELECT GroupName FROM usergroup WHERE
> UserName='%{SQL-User-Name}'"
> sql: connect_failure_retry_delay = 60
> sql: simul_count_query = ""
> sql: simul_verify_query = "SELECT RadAcctId, AcctSessionId, UserName,
> NASIPAddress, NASPortId, FramedIPAddress, CallingStationId,
> FramedProtocol FROM radacct WHERE UserName='%{SQL-User-Name}' AND
> AcctStopTime = 0"
> sql: postauth_table = "radpostauth"
> sql: postauth_query = "INSERT into radpostauth (id, user, pass, reply,
> date) values ('', '%{User-Name}',
> '%{User-Password:-Chap-Password}', '%{reply:Packet-Type}', NOW())"
> sql: safe-characters > "@abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789.-_: /"
> rlm_sql (sql): Driver rlm_sql_mysql (module rlm_sql_mysql) loaded and linked
> rlm_sql (sql): Attempting to connect to radius@mysql1.ddihealth.com:/radius
> rlm_sql (sql): starting 0
> rlm_sql (sql): Attempting to connect rlm_sql_mysql #0
> rlm_sql_mysql: Starting connect to MySQL server for #0
> rlm_sql (sql): Connected new DB handle, #0
> rlm_sql (sql): starting 1
> rlm_sql (sql): Attempting to connect rlm_sql_mysql #1
> rlm_sql_mysql: Starting connect to MySQL server for #1
> rlm_sql (sql): Connected new DB handle, #1
> rlm_sql (sql): starting 2
> rlm_sql (sql): Attempting to connect rlm_sql_mysql #2
> rlm_sql_mysql: Starting connect to MySQL server for #2
> rlm_sql (sql): Connected new DB handle, #2
> rlm_sql (sql): starting 3
> rlm_sql (sql): Attempting to connect rlm_sql_mysql #3
> rlm_sql_mysql: Starting connect to MySQL server for #3
> rlm_sql (sql): Connected new DB handle, #3
> rlm_sql (sql): starting 4
> rlm_sql (sql): Attempting to connect rlm_sql_mysql #4
> rlm_sql_mysql: Starting connect to MySQL server for #4
> rlm_sql (sql): Connected new DB handle, #4
> Module: Instantiated sql (sql)
> Module: Loaded Acct-Unique-Session-Id
> acct_unique: key = "User-Name, Acct-Session-Id, NAS-IP-Address,
> Client-IP-Address, NAS-Port"
> Module: Instantiated acct_unique (acct_unique)
> Module: Loaded detail
> detail: detailfile > "/var/log/freeradius/radacct/%{Client-IP-Address}/detail-%Y%m%d"
> detail: detailperm = 384
> detail: dirperm = 493
> detail: locking = no
> Module: Instantiated detail (detail)
> Listening on authentication 127.0.0.1:1812
> Listening on accounting 127.0.0.1:1813
> Listening on authentication 10.10.0.218:1812
> Listening on accounting 10.10.0.218:1813
> Listening on proxy *:1814
> Ready to process requests.
> rad_recv: Access-Request packet from host 10.10.0.218:1024, id\x110,
> lengthQ
> Service-Type = Framed-User
> Framed-Protocol = PPP
> User-Name = "user1"
> NAS-IP-Address = 10.10.0.216
> NAS-Port = 0
> Processing the authorize section of radiusd.conf
> modcall: entering group authorize for request 0
> modcall[authorize]: module "preprocess" returns ok for request 0
> modcall[authorize]: module "chap" returns noop for request 0
> modcall[authorize]: module "mschap" returns noop for request 0
> rlm_realm: No '@' in User-Name = "user1", looking up realm NULL
> rlm_realm: No such realm "NULL"
> modcall[authorize]: module "suffix" returns noop for request 0
> rlm_eap: No EAP-Message, not doing EAP
> modcall[authorize]: module "eap" returns noop for request 0
> users: Matched entry DEFAULT at line 152
> users: Matched entry DEFAULT at line 171
> users: Matched entry DEFAULT at line 183
> modcall[authorize]: module "files" returns ok for request 0
> radius_xlat: 'user1'
> rlm_sql (sql): sql_set_user escaped user --> 'user1'
> radius_xlat: 'SELECT id,UserName,Attribute,Value,op FROM radcheck WHERE
> Username = 'user1' ORDER BY id'
> rlm_sql (sql): Reserving sql socket id: 4
> radius_xlat: 'SELECT
> radgroupcheck.id,radgroupcheck.GroupName,radgroupcheck.Attribute,radgroupche
> ck.Value,radgroupcheck.op FROM ra
> dgroupcheck,usergroup WHERE usergroup.Username = 'user1' AND
> usergroup.GroupName = radgroupcheck.GroupName ORDER BY radgroupcheck.id
> '
> radius_xlat: 'SELECT id,UserName,Attribute,Value,op FROM radreply WHERE
> Username = 'user1' ORDER BY id'
> radius_xlat: 'SELECT
> radgroupreply.id,radgroupreply.GroupName,radgroupreply.Attribute,radgrouprep
> ly.Value,radgroupreply.op FROM ra
> dgroupreply,usergroup WHERE usergroup.Username = 'user1' AND
> usergroup.GroupName = radgroupreply.GroupName ORDER BY radgroupreply.id
> '
> rlm_sql (sql): Released sql socket id: 4
> modcall[authorize]: module "sql" returns ok for request 0
> modcall: group authorize returns ok for request 0
> rad_check_password: Found Auth-Type Local
> auth: type Local
> auth: No User-Password or CHAP-Password attribute in the request
> auth: Failed to validate the user.
> Delaying request 0 for 1 seconds
> Finished request 0
> Going to the next request
> --- Walking the entire request list ---
> Waking up in 1 seconds...
> --- Walking the entire request list ---
> Waking up in 1 seconds...
> --- Walking the entire request list ---
> Sending Access-Reject of id 110 to 10.10.0.218:1024
> Waking up in 4 seconds...
> --- Walking the entire request list ---
> Cleaning up request 0 ID 110 with timestamp 431cdc94
> Nothing to do. Sleeping until we see a request.
>
> Regards,
>
> ----------
> Jim Barber
> DDI Health
>
>
> Seferovic Edvin wrote:
>
>>Hi,
>>
>>this seems like a RADIUS error.
>>
>>1. try testing your RADIUS configuration with radtest ( see man radtest )
>>
>>2. next time start radius with radiusd -Xxa and copy the main parts of the
>>log into the mail.
>>
>>3. it seems that your VPN daemon is not set to use MSCHAPv2 or your client
>>isnt configured either... so you are right.. you should see something like
>>this:
>>
>>rad_recv: Access-Request packet from host xx, id\x180, length\x146
>> Service-Type = Framed-User
>> Framed-Protocol = PPP
>> User-Name = "xxxxxxx"
>> MS-CHAP-Challenge = 0xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx9
>> MS-CHAP2-Response = xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
>> Calling-Station-Id = "xxxx"
>> NAS-IP-Address = xxxxxxxxxxx
>> NAS-Port = 0
>>
>>4. check the client -> Connection properties -> security -> setting ->
>
> check
>
>>the box with MSCHAPv2, and choose NO ENCRYPTION ( you said you dont have
>>that module .. sooo.. )
>>
>>5. radius is using which backend ( file/sql/ldap/etc?? ) ? You need
>>clear-text passwords for the MSCHAPv2 auth, or LM/NT Hashes !
>>
>>6. post the logs next time ;)
>>
>>Regards,
>>
>>Edvin Seferovic
>>
>>
>>-----Original Message-----
>>From: linux-ppp-owner@vger.kernel.org
>>[mailto:linux-ppp-owner@vger.kernel.org] On Behalf Of Jim Barber
>>Sent: Montag, 05. September 2005 11:46
>>To: linux-ppp@vger.kernel.org
>>Subject: Windows IPSec/L2TP VPN client and Linux server with RADIUS, and
>>PPP.
>>
>>I am hoping that someone can help me.
>>I have been working on this problem for days now and I've read so much
>>online documentation, how-tos, etc that my eyes are ready to fall out of
>>my head. :)
>>
>>I have been trying to set up a Linux VPN server that will support the
>>IPSec/L2TP VPN client that is available with Microsoft Windows 2000
>>onwards.
>>
>>I first tried the 'testing' distribution of Debian, but after failing to
>>get it to work with lt2pns, I moved to the 'unstable' distribution so
>>that I had new software available, and so I could use lt2pd with the
>>pppd daemon.
>>
>>The infrastructure that I've been using to try and support this is:
>>
>>- FreeRADIUS 1.0.4 for user authentication.
>>- Linux 2.6 kernel for the IPSec tunnel.
>>- Racoon 0.6.1 for the IPSec Key exchange.
>>- l2tpd 0.7-pre20031121 for the L2TP daemon.
>>- pppd 2.4.3-20050321+2 for the PPP daemon.
>>- radiusclient 0.3.2 for the PPP radius.so plugin configuration.
>>- openssl 0.9.7g for the generation and signing of certificates and keys.
>>
>>I have had some limited success...
>>
>>If I don't use the radius.so ppp plugin, and define a test user in the
>>/etc/ppp/chap-secrets file, then VPNs from my Windows XP client works
>>perfectly.
>>
>>If I enable the use of the radius.so plugin, then users will no longer
>>authenticate.
>>However if I change the properties in the client's VPN security settings
>>so that all of the CHAP, MSCHAP, MSCHAPv2 options are disabled, and
>>only the PAP connection is enabled, then authentication via the radius
>>server works perfectly.
>>
>>I don't want to post full logs at this stage unless someone requests
>>them since they are huge. I will post what I think is relevent at this
>>stage...
>>
>>I believe that the RADIUS authentication isn't happening with MSCHAPv2
>>enabled because it doesn't have enough information passed to it.
>>The debugging part of the RADIUS server shows the following incoming
>>information:
>>
>>rad_recv: Access-Request packet from host 10.10.0.218:1024, id\x107,
>>lengthQ
>> Service-Type = Framed-User
>> Framed-Protocol = PPP
>> User-Name = "user1"
>> NAS-IP-Address = 10.10.0.216
>> NAS-Port = 0
>>
>> From my research I believe that I should also see MS-CHAP-Challenge and
>>MS-CHAP2-Response entries in the output above.
>>
>>I believe that the MS-CHAPv2 information is reaching the ppp daemon
>>because I see entries in it's debugging output like so:
>>
>>sent [LCP ConfReq id=0x1 <mru 1400> <asyncmap 0x0> <auth chap MD5> <magic
>>0x9d821c9a> <pcomp> <accomp>]
>>rcvd [LCP ConfNak id=0x1 <auth chap MS-v2>]
>>sent [LCP ConfReq id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2>
>
> <magic
>
>>0x9d821c9a> <pcomp> <accomp>]
>>rcvd [LCP ConfAck id=0x2 <mru 1400> <asyncmap 0x0> <auth chap MS-v2>
>
> <magic
>
>>0x9d821c9a> <pcomp> <accomp>]
>>rcvd [LCP ConfReq id=0x1 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp>
>><callback CBCP>]
>>sent [LCP ConfRej id=0x1 <callback CBCP>]
>>rcvd [LCP ConfReq id=0x2 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp>]
>>sent [LCP ConfAck id=0x2 <mru 1400> <magic 0x5b52779d> <pcomp> <accomp>]
>>sent [LCP EchoReq id=0x0 magic=0x9d821c9a]
>>sent [CHAP Challenge id=0x29 <0e8e59d6606f7233d9fc0ef7e3e66301>, name >>"research"]
>>rcvd [LCP Ident id=0x3 magic=0x5b52779d "MSRASV5.10"]
>>rcvd [LCP Ident id=0x4 magic=0x5b52779d "MSRAS-0-MICROBEE"]
>>rcvd [LCP EchoRep id=0x0 magic=0x5b52779d]
>>rcvd [CHAP Response id=0x29
>>
>
> <2f9bc1d22db3ecd79957616fd713c9080000000000000000b8f4c19d7d7edc1fbecfb562edc
>
>>55cf3d5c17c8644b03cd500>,
>>name = "user1"]
>>sent [CHAP Failure id=0x29 ""]
>>sent [LCP TermReq id=0x3 "Authentication failed"]
>>
>>So either the ppp radius plugin isn't correctly seeing this MSCHAPv2
>>information and so failing to pass it on to the FreeRADIUS server, or it
>>is passing the information to the radius server, but the radius server
>>is failing to interpret it as MS-CHAP-Challenge and MS-CHAP2-Response
>>entries.
>>
>>My configuration for the l2tpd daemon is as follows:
>>
>> [global]
>> listen-addr = 10.10.0.219
>> port = 1701
>>
>> [lns default]
>> ip range = 10.10.0.248 - 10.10.0.254
>> local ip = 10.10.0.220
>> require chap = yes
>> refuse pap = yes
>> require authentication = yes
>> hostname = vpn1
>> ppp debug = yes
>> pppoptfile = /etc/ppp/options.l2tpd
>> length bit = yes
>>
>>My configuration in the /etc/ppp/options.l2tpd file is as follows:
>>
>> ms-dns 10.10.0.100
>> ms-wins 10.10.0.100
>> auth
>> crtscts
>> lock
>> mru 1400
>> mtu 1400
>> nodetach
>> debug
>> proxyarp
>> ipcp-accept-local
>> ipcp-accept-remote
>> idle 1800
>> connect-delay 5000
>> nodefaultroute
>> refuse-pap
>> refuse-chap
>> refuse-mschap
>> require-mschap-v2
>> nologfd
>> plugin radius.so
>>
>>I've configured the /etc/radiusclient/servers file with the correct
>>passwords for the radius server.
>>I've configured the /etc/radiusclient/radiusclient.conf with IP address
>>of the radius server.
>>
>>In the modules section of the /etc/freeradius/radiusd.conf file I have
>>the following entry:
>>
>> mschap {
>> authtype = MS-CHAP
>> }
>>
>>In the authorize section of the /etc/freeradius/radiusd.conf file I have
>>the following entry:
>>
>> mschap
>>
>>In the authenticate section of the /etc/freeradius/radiusd.conf file I
>>have the following entry:
>>
>> Auth-Type MS-CHAP {
>> mschap
>> }
>>
>>At one stage I was wondering if MPPE support was required, but I
>>couldn't see how since that is only for encryption of the PPP layer
>>which isn't necessary. But having tried all sorts of different
>>configuration combinations, I decided to compile up a kernel with
>>the MPPE patches along with enabling the MPPE directives in the
>>FreeRADIUS config and the options.l2tp file. This made no difference,
>>which I am happy with as that is what I expected.
>>
>>I tried rebuilding the ppp Debian Package to see if it is compiled with
>>MS-CHAP support out of the box, and it does appear that it is. My custom
>>version of ppp didn't fair any better.
>>
>>So I'm stuck now.
>>Does anyone know where I can go from here?
>>
>>If necessary, I can post up complete logs, and even full configuration
>>files, but I thought I'd spare you all for the moment.
>>
>>Any help is very much appreciated.
>>
>>Regards,
>>
>>----------
>>Jim Barber
>>DDI Health
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Windows IPSec/L2TP VPN client and Linux server with RADIUS, and
2005-09-05 9:46 Windows IPSec/L2TP VPN client and Linux server with RADIUS, and PPP Jim Barber
2005-09-06 0:15 ` Windows IPSec/L2TP VPN client and Linux server with RADIUS, and Jim Barber
2005-09-06 1:21 ` Jim Barber
@ 2005-09-08 0:24 ` Jim Barber
2005-09-08 2:40 ` Jim Barber
2005-09-08 3:03 ` Jim Barber
4 siblings, 0 replies; 6+ messages in thread
From: Jim Barber @ 2005-09-08 0:24 UTC (permalink / raw)
To: linux-ppp
I decided to comment out the following entries in the
/etc/ppp/options.l2tpd file:
#refuse-chap
#refuse-mschap
#require-mschap-v2
Then I changed the security settings in the VPN client software to
untick everything except for plain CHAP.
Now when I connect I see the following in the freeradius logs, and the
VPN successful establishes a connection.
rad_recv: Accounting-Request packet from host 10.10.0.218:1026, id\x127, length\x133
Acct-Session-Id = "431F80CF7EB000"
User-Name = "user1"
Acct-Status-Type = Stop
Service-Type = Framed-User
Framed-Protocol = PPP
Acct-Authentic = RADIUS
Acct-Session-Time = 18
Acct-Output-Octets = 33
Acct-Input-Octets = 785
Acct-Output-Packets = 2
Acct-Input-Packets = 8
NAS-Port-Type = Async
Acct-Terminate-Cause = User-Request
Framed-IP-Address = 10.10.0.248
NAS-IP-Address = 10.10.0.216
NAS-Port = 0
Acct-Delay-Time = 0
But then I did something that was strange.
I turned on the refuse-chap, refuse-mschap, and require-mschap-v2
options in the options.l2tpd file again, and then tried to connect with
VPN client again, expecting it to fail...
But it didn't. With the VPN client still configured to only use CHAP,
it was allowed to log in despite the 'require-mschap-v2' directive.
I had bounced all daemons to make sure that the changes were picked up.
Does that give anyone some clues?
----------
Jim Barber
DDI Health
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Windows IPSec/L2TP VPN client and Linux server with RADIUS, and
2005-09-05 9:46 Windows IPSec/L2TP VPN client and Linux server with RADIUS, and PPP Jim Barber
` (2 preceding siblings ...)
2005-09-08 0:24 ` Jim Barber
@ 2005-09-08 2:40 ` Jim Barber
2005-09-08 3:03 ` Jim Barber
4 siblings, 0 replies; 6+ messages in thread
From: Jim Barber @ 2005-09-08 2:40 UTC (permalink / raw)
To: linux-ppp
Success!
Finally it's been solved.
There were a couple of things wrong.
Here is what I had to change:
My /etc/l2tpd/l2tpd.conf file now looks like:
[global]
listen-addr = 10.10.0.219
port = 1701
[lns default]
ip range = 10.10.0.248 - 10.10.0.254
local ip = 10.10.0.220
hostname = vpn1
ppp debug = yes
pppoptfile = /etc/ppp/options.l2tpd
length bit = yes
I had to get rid of the following lines from the [lns default] section:
refuse pap = yes
require chap = yes
require authentication = yes
This is because they overrided all of the following options in the
/etc/ppp/options.l2tpd file:
refuse-pap
refuse-chap
refuse-mschap
require-mschap-v2
No matter how the above options were set, I was able to connect using
PAP, etc despite it being refused. (Refusing PAP in the l2tpd.conf file
didn't have any effect).
Next, my dictonary files in the /etc/radiusclient/ directory.
The debian radiusclient1 package doesn't come with a
dictionary.microsoft file.
The file I needed is not in the same format as the dictionary.microsoft
supplied with the freeradius package.
The format I need doesn't have the "BEGIN-VENDOR Microsoft",
"END-VENDOR" Microsoft directives, but instead has the word "Microsoft"
at the end of each line.
Also I was using the wrong syntax when including the
dictionary.microsoft file.
I put into the /etc/radiusclient/dictionary file the following directive
$INCLUDE dictionary.microsoft
This seems to be the format that the freeradius dictionary files use
to include other dictionaries.
THIS DOES NOT WORK for the radiusclient dictionaries.
The directive must look like:
INCLUDE /etc/radiusclient/dictionary.microsoft
The leading $ sign must be removed from the INCLUDE directive and a
full path to the dictionary file MUST be used. If either of these things
are wrong, then my VPN client will fail to connect.
What is annoying is that in the top of the dictionary.ascend file that
is supplied as part of radiusclient the comment says:
#
# Ascend dictionary.
#
# Enable by putting the line "$INCLUDE dictionary.ascend" into
# the main dictionary file.
#
# Version: 1.00 21-Jul-1997 Jens Glaser <jens@regio.net>
#
There is it there in the wrong syntax.
So I'm not sure if the problem is with the radiusclient package, or
perhaps the ppp radius.so plugin itself?
Does the radius.so plugin parse the dictionary files itself?
I'm thinking that I need to log a bug somewhere so that this doesn't
catch anyone else out in the future, because this problem is VERY obscure.
Thanks for the help, and hopefully this helps someone else in the future.
--
----------
Jim Barber
DDI Health
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Windows IPSec/L2TP VPN client and Linux server with RADIUS, and
2005-09-05 9:46 Windows IPSec/L2TP VPN client and Linux server with RADIUS, and PPP Jim Barber
` (3 preceding siblings ...)
2005-09-08 2:40 ` Jim Barber
@ 2005-09-08 3:03 ` Jim Barber
4 siblings, 0 replies; 6+ messages in thread
From: Jim Barber @ 2005-09-08 3:03 UTC (permalink / raw)
To: linux-ppp
Further to below, I compared the freeradius dictionary.microsoft file
with the one I've been supplied with.
Apart from the differences I described below, also the word "octects"
in the freeradius file is "string" in the dictionary file for
radiusclient.
Also, some of the entries in the freeradius dictionary have strings
like "encrypt=1" or "encrypt=2". These strings don't exist in the
radiusclient dictionary file.
Regards,
Jim Barber.
---------
Success!
Finally it's been solved.
There were a couple of things wrong.
Here is what I had to change:
My /etc/l2tpd/l2tpd.conf file now looks like:
[global]
listen-addr = 10.10.0.219
port = 1701
[lns default]
ip range = 10.10.0.248 - 10.10.0.254
local ip = 10.10.0.220
hostname = vpn1
ppp debug = yes
pppoptfile = /etc/ppp/options.l2tpd
length bit = yes
I had to get rid of the following lines from the [lns default] section:
refuse pap = yes
require chap = yes
require authentication = yes
This is because they overrided all of the following options in the
/etc/ppp/options.l2tpd file:
refuse-pap
refuse-chap
refuse-mschap
require-mschap-v2
No matter how the above options were set, I was able to connect using
PAP, etc despite it being refused. (Refusing PAP in the l2tpd.conf file
didn't have any effect).
Next, my dictonary files in the /etc/radiusclient/ directory.
The debian radiusclient1 package doesn't come with a
dictionary.microsoft file.
The file I needed is not in the same format as the dictionary.microsoft
supplied with the freeradius package.
The format I need doesn't have the "BEGIN-VENDOR Microsoft",
"END-VENDOR" Microsoft directives, but instead has the word "Microsoft"
at the end of each line.
Also I was using the wrong syntax when including the
dictionary.microsoft file.
I put into the /etc/radiusclient/dictionary file the following directive
$INCLUDE dictionary.microsoft
This seems to be the format that the freeradius dictionary files use
to include other dictionaries.
THIS DOES NOT WORK for the radiusclient dictionaries.
The directive must look like:
INCLUDE /etc/radiusclient/dictionary.microsoft
The leading $ sign must be removed from the INCLUDE directive and a
full path to the dictionary file MUST be used. If either of these things
are wrong, then my VPN client will fail to connect.
What is annoying is that in the top of the dictionary.ascend file that
is supplied as part of radiusclient the comment says:
#
# Ascend dictionary.
#
# Enable by putting the line "$INCLUDE dictionary.ascend" into
# the main dictionary file.
#
# Version: 1.00 21-Jul-1997 Jens Glaser <jens@regio.net>
#
There is it there in the wrong syntax.
So I'm not sure if the problem is with the radiusclient package, or
perhaps the ppp radius.so plugin itself?
Does the radius.so plugin parse the dictionary files itself?
I'm thinking that I need to log a bug somewhere so that this doesn't
catch anyone else out in the future, because this problem is VERY obscure.
Thanks for the help, and hopefully this helps someone else in the future.
--
----------
Jim Barber
DDI Health
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2005-09-08 3:03 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-09-05 9:46 Windows IPSec/L2TP VPN client and Linux server with RADIUS, and PPP Jim Barber
2005-09-06 0:15 ` Windows IPSec/L2TP VPN client and Linux server with RADIUS, and Jim Barber
2005-09-06 1:21 ` Jim Barber
2005-09-08 0:24 ` Jim Barber
2005-09-08 2:40 ` Jim Barber
2005-09-08 3:03 ` Jim Barber
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.