ubuntu server, FreeRadius 2.1.6, Active Directory Win2K3, Cisco Aironet AG1242

Petar Marinkovic highl1 at gmail.com
Wed Jun 24 15:12:45 CEST 2009


I've read several threads, but none of them helped me. I saw that few users
had similar problems as mine, but somehow I can't get it to work. We're
using FreeRadius for testing purposes.

Story goes like this, I installed freeradius and managed to get it work with
test user in users file and PEAP. Problems begin when I started to try to
use AD to authenticate users. I followed this tutorial
http://deployingradius.com/documents/configuration/active_directory.html,
and everything works great, until the last part . I managed to add the
machine to domain, kinit command worked, wbinfo also, same as ntlm_auth, it
says NT_USER_OK or similar. Thing is that when I try to connect an XP SP3
user via WiFI, authentication doesnt work.

Here's the server debug, when it starts

petar at freeradius:~$ sudo freeradius -X
FreeRADIUS Version 2.1.6, for host i486-pc-linux-gnu, built on Jun 18
2009 at 14:35:49

Copyright (C) 1999-2009 The FreeRADIUS server project and contributors.
There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE.
You may redistribute copies of FreeRADIUS under the terms of the
GNU General Public License v2.
Starting - reading configuration files ...
including configuration file /etc/freeradius/radiusd.conf
including configuration file /etc/freeradius/proxy.conf
including configuration file /etc/freeradius/clients.conf
including files in directory /etc/freeradius/modules/
including configuration file /etc/freeradius/modules/perl
including configuration file /etc/freeradius/modules/smsotp
including configuration file /etc/freeradius/modules/detail.log
including configuration file /etc/freeradius/modules/detail
including configuration file /etc/freeradius/modules/inner-eap
including configuration file /etc/freeradius/modules/unix
including configuration file /etc/freeradius/modules/always
including configuration file /etc/freeradius/modules/detail.example.com
including configuration file /etc/freeradius/modules/mschap
including configuration file /etc/freeradius/modules/chap
including configuration file /etc/freeradius/modules/files
including configuration file /etc/freeradius/modules/expiration
including configuration file /etc/freeradius/modules/digest
including configuration file /etc/freeradius/modules/realm
including configuration file /etc/freeradius/modules/linelog
including configuration file /etc/freeradius/modules/passwd
including configuration file /etc/freeradius/modules/checkval
including configuration file /etc/freeradius/modules/otp
including configuration file /etc/freeradius/modules/counter
including configuration file /etc/freeradius/modules/sqlcounter_expire_on_login

including configuration file /etc/freeradius/modules/attr_rewrite
including configuration file /etc/freeradius/modules/attr_filter
including configuration file /etc/freeradius/modules/radutmp
including configuration file /etc/freeradius/modules/pam
including configuration file /etc/freeradius/modules/krb5
including configuration file /etc/freeradius/modules/smbpasswd
including configuration file /etc/freeradius/modules/mac2ip
including configuration file /etc/freeradius/modules/wimax
including configuration file /etc/freeradius/modules/sradutmp
including configuration file /etc/freeradius/modules/sql_log
including configuration file /etc/freeradius/modules/logintime
including configuration file /etc/freeradius/modules/echo
including configuration file /etc/freeradius/modules/etc_group
including configuration file /etc/freeradius/modules/acct_unique
including configuration file /etc/freeradius/modules/policy
including configuration file /etc/freeradius/modules/ippool
including configuration file /etc/freeradius/modules/pap
including configuration file /etc/freeradius/modules/preprocess
including configuration file /etc/freeradius/modules/expr
including configuration file /etc/freeradius/modules/exec
including configuration file /etc/freeradius/modules/ldap
including configuration file /etc/freeradius/modules/mac2vlan
including configuration file /etc/freeradius/eap.conf
including configuration file /etc/freeradius/policy.conf
including files in directory /etc/freeradius/sites-enabled/
including configuration file /etc/freeradius/sites-enabled/inner-tunnel
including configuration file /etc/freeradius/sites-enabled/default
including configuration file /etc/freeradius/sites-enabled/control-socket
group = freerad
user = freerad
including dictionary file /etc/freeradius/dictionary
main {
    prefix = "/usr"
    localstatedir = "/var"
    logdir = "/var/log/freeradius"
    libdir = "/usr/lib/freeradius"
    radacctdir = "/var/log/freeradius/radacct"
    hostname_lookups = no
    max_request_time = 30
    cleanup_delay = 5
    max_requests = 1024
    allow_core_dumps = no
    pidfile = "/var/run/freeradius/freeradius.pid"
    checkrad = "/usr/sbin/checkrad"
    debug_level = 0
    proxy_requests = yes
 log {
    stripped_names = no
    auth = no
    auth_badpass = no
    auth_goodpass = no
 }
 security {
    max_attributes = 200
    reject_delay = 1
    status_server = yes
 }
}
radiusd: #### Loading Realms and Home Servers ####
 proxy server {
    retry_delay = 5
    retry_count = 3
    default_fallback = no
    dead_time = 120
    wake_all_if_all_dead = no
 }
 home_server localhost {
    ipaddr = 127.0.0.1
    port = 1812
    type = "auth"
    secret = "testing123"
    response_window = 20
    max_outstanding = 65536
    require_message_authenticator = no
    zombie_period = 40
    status_check = "status-server"
    ping_interval = 30
    check_interval = 30
    num_answers_to_alive = 3
    num_pings_to_alive = 3
    revive_interval = 120
    status_check_timeout = 4
    irt = 2
    mrt = 16
    mrc = 5
    mrd = 30
 }
 home_server_pool my_auth_failover {
    type = fail-over
    home_server = localhost
 }
 realm example.com {
    auth_pool = my_auth_failover
 }
 realm LOCAL {
 }
radiusd: #### Loading Clients ####
 client localhost {
    ipaddr = 127.0.0.1
    require_message_authenticator = no
    secret = "testing123"
    nastype = "other"
 }
 client 172.17.0.93 {
    require_message_authenticator = no
    secret = "testing123"
    shortname = "172.17.0.93"
    nastype = "cisco"
 }
 client 172.17.0.0/24 {
    require_message_authenticator = no
    secret = "testing123"
 }
radiusd: #### Instantiating modules ####
 instantiate {
 Module: Linked to module rlm_exec
 Module: Instantiating exec
  exec {
    wait = no
    input_pairs = "request"
    shell_escape = yes
  }
 Module: Linked to module rlm_expr
 Module: Instantiating expr
 Module: Linked to module rlm_expiration
 Module: Instantiating expiration
  expiration {
    reply-message = "Password Has Expired  "
  }
 Module: Linked to module rlm_logintime
 Module: Instantiating logintime
  logintime {
    reply-message = "You are calling outside your allowed timespan  "
    minimum-timeout = 60
  }
 }
radiusd: #### Loading Virtual Servers ####
server inner-tunnel {
 modules {
 Module: Checking authenticate {...} for more modules to load
 Module: Linked to module rlm_pap
 Module: Instantiating pap
  pap {
    encryption_scheme = "auto"
    auto_header = no
  }
 Module: Linked to module rlm_chap
 Module: Instantiating chap
 Module: Instantiating ntlm_auth
  exec ntlm_auth {
    wait = yes
    program = "/usr/bin/ntlm_auth --request-nt-key --domain=EXCHANGE
--username=%{mschap:User-Name} --password=%{User-Password}"

    input_pairs = "request"
    shell_escape = yes
  }
 Module: Linked to module rlm_mschap
 Module: Instantiating mschap
  mschap {
    use_mppe = yes
    require_encryption = no
    require_strong = no
    with_ntdomain_hack = yes
    ntlm_auth = "/usr/bin/ntlm_auth --request-nt-key
--username=%{mschap:User-Name:-None}
--domain=%{mschap:NT-Domain:-EXCHANGE}--challenge=%{mschap:Challenge:-00}
--nt-response=%{mschap:NT-Response:-00}"

  }
 Module: Linked to module rlm_unix
 Module: Instantiating unix
  unix {
    radwtmp = "/var/log/freeradius/radwtmp"
  }
 Module: Linked to module rlm_eap
 Module: Instantiating eap
  eap {
    default_eap_type = "peap"
    timer_expire = 60
    ignore_unknown_eap_types = no
    cisco_accounting_username_bug = no
    max_sessions = 2048
  }
 Module: Linked to sub-module rlm_eap_md5
 Module: Instantiating eap-md5
 Module: Linked to sub-module rlm_eap_leap
 Module: Instantiating eap-leap
 Module: Linked to sub-module rlm_eap_gtc
 Module: Instantiating eap-gtc
   gtc {
    challenge = "Password: "
    auth_type = "PAP"
   }
 Module: Linked to sub-module rlm_eap_tls
 Module: Instantiating eap-tls
   tls {
    rsa_key_exchange = no
    dh_key_exchange = yes
    rsa_key_length = 512
    dh_key_length = 512
    verify_depth = 0
    pem_file_type = yes
    private_key_file = "/etc/freeradius/certs/server.pem"
    certificate_file = "/etc/freeradius/certs/server.pem"
    CA_file = "/etc/freeradius/certs/ca.pem"
    private_key_password = "whatever"
    dh_file = "/etc/freeradius/certs/dh"
    random_file = "/etc/freeradius/certs/random"
    fragment_size = 1024
    include_length = yes
    check_crl = no
    cipher_list = "DEFAULT"
    make_cert_command = "/etc/freeradius/certs/bootstrap"
    cache {
    enable = no
    lifetime = 24
    max_entries = 255
    }
   }
 Module: Linked to sub-module rlm_eap_ttls
 Module: Instantiating eap-ttls
   ttls {
    default_eap_type = "md5"
    copy_request_to_tunnel = no
    use_tunneled_reply = no
    virtual_server = "inner-tunnel"
    include_length = yes
   }
 Module: Linked to sub-module rlm_eap_peap
 Module: Instantiating eap-peap
   peap {
    default_eap_type = "mschapv2"
    copy_request_to_tunnel = no
    use_tunneled_reply = no
    proxy_tunneled_request_as_eap = yes
    virtual_server = "inner-tunnel"
   }
 Module: Linked to sub-module rlm_eap_mschapv2
 Module: Instantiating eap-mschapv2
   mschapv2 {
    with_ntdomain_hack = no
   }
 Module: Checking authorize {...} for more modules to load
 Module: Linked to module rlm_realm
 Module: Instantiating suffix
  realm suffix {
    format = "suffix"
    delimiter = "@"
    ignore_default = no
    ignore_null = no
  }
 Module: Linked to module rlm_files
 Module: Instantiating files
  files {
    usersfile = "/etc/freeradius/users"
    acctusersfile = "/etc/freeradius/acct_users"
    preproxy_usersfile = "/etc/freeradius/preproxy_users"
    compat = "no"
  }
 Module: Checking session {...} for more modules to load
 Module: Linked to module rlm_radutmp
 Module: Instantiating radutmp
  radutmp {
    filename = "/var/log/freeradius/radutmp"
    username = "%{User-Name}"
    case_sensitive = yes
    check_with_nas = yes
    perm = 384
    callerid = yes
  }
 Module: Checking post-proxy {...} for more modules to load
 Module: Checking post-auth {...} for more modules to load
 Module: Linked to module rlm_attr_filter
 Module: Instantiating attr_filter.access_reject
  attr_filter attr_filter.access_reject {
    attrsfile = "/etc/freeradius/attrs.access_reject"
    key = "%{User-Name}"
  }
 } # modules
} # server
server {
 modules {
 Module: Checking authenticate {...} for more modules to load
 Module: Checking authorize {...} for more modules to load
 Module: Linked to module rlm_preprocess
 Module: Instantiating preprocess
  preprocess {
    huntgroups = "/etc/freeradius/huntgroups"
    hints = "/etc/freeradius/hints"
    with_ascend_hack = no
    ascend_channels_per_line = 23
    with_ntdomain_hack = no
    with_specialix_jetstream_hack = no
    with_cisco_vsa_hack = no
    with_alvarion_vsa_hack = no
  }
 Module: Checking preacct {...} for more modules to load
 Module: Linked to module rlm_acct_unique
 Module: Instantiating acct_unique
  acct_unique {
    key = "User-Name, Acct-Session-Id, NAS-IP-Address,
Client-IP-Address, NAS-Port"

  }
 Module: Checking accounting {...} for more modules to load
 Module: Linked to module rlm_detail
 Module: Instantiating detail
  detail {
    detailfile =
"/var/log/freeradius/radacct/%{Client-IP-Address}/detail-%Y%m%d"

    header = "%t"
    detailperm = 384
    dirperm = 493
    locking = no
    log_packet_header = no
  }
 Module: Instantiating attr_filter.accounting_response
  attr_filter attr_filter.accounting_response {
    attrsfile = "/etc/freeradius/attrs.accounting_response"
    key = "%{User-Name}"
  }
 Module: Checking session {...} for more modules to load
 Module: Checking post-proxy {...} for more modules to load
 Module: Checking post-auth {...} for more modules to load
 } # modules
} # server
radiusd: #### Opening IP addresses and Ports ####
listen {
    type = "auth"
    ipaddr = *
    port = 0
}
listen {
    type = "acct"
    ipaddr = *
    port = 0
}
listen {
    type = "control"
 listen {
    socket = "/var/run/freeradius/freeradius.sock"
 }
}
Listening on authentication address * port 1812
Listening on accounting address * port 1813
Listening on command file /var/run/freeradius/freeradius.sock
Listening on proxy address * port 1814
Ready to process requests.

Here is the output when user with domen credentials try to connect via WiFi.
For setting up that I checked last part of "old" tutorial
http://wiki.freeradius.org/FreeRADIUS_Active_Directory_Integration_HOWTO

rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=87, length=153

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0xd325a4d6017bfc77cf5bd3c213ae1745
    EAP-Message = 0x020200190145584348414e47455c706d6172696e6b6f766963
    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18204
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 2 length 25
[eap] No EAP Start, assuming it's an on-going EAP conversation
++[eap] returns updated
++[unix] returns notfound
++[files] returns noop
++[expiration] returns noop
++[logintime] returns noop
[pap] WARNING! No "known good" password found for the user.
Authentication may fail because of this.

++[pap] returns noop
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] EAP Identity
[eap] processing type tls
[tls] Initiate
[tls] Start returned 1
++[eap] returns handled
Sending Access-Challenge of id 87 to 172.17.0.93 port 1645
    EAP-Message = 0x010300061920
    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0x68aa16cc68a90f2af50a0ba6abea9d5a
Finished request 0.
Going to the next request
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=88, length=226

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0xd65c918a92d5de6981b0fa3bc0aaea39
    EAP-Message =
0x0203005019800000004616030100410100003d03014a4213d23c2079e6582ef6c7470d2013dd975aca0d5227311929f95487d0594a00001600040005000a000900640062000300060013001200630100

    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18204
    State = 0x68aa16cc68a90f2af50a0ba6abea9d5a
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 3 length 80
[eap] Continuing tunnel setup.
++[eap] returns ok
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] Request found, released from the list
[eap] EAP/peap
[eap] processing type peap
[peap] processing EAP-TLS
  TLS Length 70
[peap] Length Included
[peap] eaptls_verify returned 11
[peap]     (other): before/accept initialization
[peap]     TLS_accept: before/accept initialization
[peap] <<< TLS 1.0 Handshake [length 0041], ClientHello
[peap]     TLS_accept: SSLv3 read client hello A
[peap] >>> TLS 1.0 Handshake [length 002a], ServerHello
[peap]     TLS_accept: SSLv3 write server hello A
[peap] >>> TLS 1.0 Handshake [length 085e], Certificate
[peap]     TLS_accept: SSLv3 write certificate A
[peap] >>> TLS 1.0 Handshake [length 0004], ServerHelloDone
[peap]     TLS_accept: SSLv3 write server done A
[peap]     TLS_accept: SSLv3 flush data
[peap]     TLS_accept: Need to read more data: SSLv3 read client certificate A

In SSL Handshake Phase
In SSL Accept mode
[peap] eaptls_process returned 13
[peap] EAPTLS_HANDLED
++[eap] returns handled
Sending Access-Challenge of id 88 to 172.17.0.93 port 1645
    EAP-Message =
0x0104040019c00000089b160301002a0200002603014a42140726eb8f99c597f39a57ae4a007cbeca5e9a6da4f6d53570dc77b8fee500000400160301085e0b00085a0008570003a6308203a23082028aa003020102020101300d06092a864886f70d0101040500308193310b3009060355040613024652310f300d060355040813065261646975733112301006035504071309536f6d65776865726531153013060355040a130c4578616d706c6520496e632e3120301e06092a864886f70d010901161161646d696e406578616d706c652e636f6d312630240603550403131d4578616d706c6520436572746966696361746520417574686f72697479

    EAP-Message =
0x301e170d3039303631383132343133375a170d3130303631383132343133375a307c310b3009060355040613024652310f300d0603550408130652616469757331153013060355040a130c4578616d706c6520496e632e312330210603550403131a4578616d706c65205365727665722043657274696669636174653120301e06092a864886f70d010901161161646d696e406578616d706c652e636f6d30820122300d06092a864886f70d01010105000382010f003082010a0282010100b9cff9695c7b6e0a56aa0b242cb9a07bd57b0718d52c01564d0b68b3555965ce9d43d45b041c53daee6a8c4b2324801cd6ba4364c52b174ba9f39d4fd6b2

    EAP-Message =
0xf78ba7fb9c98f95fa6be789fdeac4f17fe237a5abb8370700b78aeb53c7924e0ac26a8808c49e76f7671eb031d1f24718bc7d4058c5c674271362cecf28fa3169541031775ad716871d104c35c868d64644395fec87b58f2965d2b6629c8b2730bcc6cab8ab74c6b7a85ac5ba9fa1b2ff67763428c90078fc0d2150a41716fdd2bf8f9f915e72732c1ca643d671fea89ff55cc5d2aeb49a0266c14fb9573941fb7e2b986b750e7c830cb7a6ded5f5965726337fc24196ebfdd624c5ea40242e51d570203010001a317301530130603551d25040c300a06082b06010505070301300d06092a864886f70d010104050003820101009565721e4e1cc2fb33

    EAP-Message =
0x69d5d123852116d311bae5d9450fbbe6c195ea05acc84bd39d93d4d7acf00af9586947734b42d259696db4f6f96005c210907daefa0831362db018b64943e26e0bddcb663901f686b7f94183255294e6520e271e9cf932a74dba38890cb829fffe4a86a8dc33a34ef8ee3b7fbf64beeca7d75975ea3556cf9689e6042582a600ccfd40ef4a1e62bef677b09c3f2875298c3c7b8b62e552e7b19c083353f5b042cc68f42d9edbfc40452e7f5153f91d4aa80be64cb1e96e7585b031935467ded8d12599c5e89824ba64112b9e67c508d67c48cbee5dcbf20bc80a360a005ecb707833bb16850616e39dd34ec35542ff9613b80aaa53f2940004ab308204

    EAP-Message = 0xa73082038fa0030201020209
    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0x68aa16cc69ae0f2af50a0ba6abea9d5a
Finished request 1.
Going to the next request
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=89, length=152

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0x54bc861048eda2e22203034f3eb31f02
    EAP-Message = 0x020400061900
    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18204
    State = 0x68aa16cc69ae0f2af50a0ba6abea9d5a
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 4 length 6
[eap] Continuing tunnel setup.
++[eap] returns ok
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] Request found, released from the list
[eap] EAP/peap
[eap] processing type peap
[peap] processing EAP-TLS
[peap] Received TLS ACK
[peap] ACK handshake fragment handler
[peap] eaptls_verify returned 1
[peap] eaptls_process returned 13
[peap] EAPTLS_HANDLED
++[eap] returns handled
Sending Access-Challenge of id 89 to 172.17.0.93 port 1645
    EAP-Message =
0x010503fc1940008be5093fd724bf3b300d06092a864886f70d0101050500308193310b3009060355040613024652310f300d060355040813065261646975733112301006035504071309536f6d65776865726531153013060355040a130c4578616d706c6520496e632e3120301e06092a864886f70d010901161161646d696e406578616d706c652e636f6d312630240603550403131d4578616d706c6520436572746966696361746520417574686f72697479301e170d3039303631383132343133375a170d3130303631383132343133375a308193310b3009060355040613024652310f300d060355040813065261646975733112301006035504

    EAP-Message =
0x071309536f6d65776865726531153013060355040a130c4578616d706c6520496e632e3120301e06092a864886f70d010901161161646d696e406578616d706c652e636f6d312630240603550403131d4578616d706c6520436572746966696361746520417574686f7269747930820122300d06092a864886f70d01010105000382010f003082010a0282010100b2387b926b71c0b483fae83d644f512ec4cf31cc22a456786ad78fe9260c5ad0ed084803a53005e711af4e38320cae4dabddc4f308e2397c67f27b65fb66b59a1b3ca469d271dbe63d1d68b5fe19bd9964d623a97719b25f469cab10ab905d2f259659d4f95d1068be55d3c88d7e47

    EAP-Message =
0xb3c4c05b8d93ec53a8bfa9776ded03ff64317ef6ce04722c73e63f4672ba3131c3a818c994c100481195bd4d620850b5b6cea036976ead412ac077e8fb58142517ef53fae5ccd3380ae57a873659f144b9bf9204b092741dc4f6d3d6a5f478f6ec2a0ada457778edaffec26bd36be9e28ab59ad1817ac5902692dc6a574946d6dfadd0ff18b13e329980ad23d8d1e43e450203010001a381fb3081f8301d0603551d0e041604141eebd5a29c221e94740f672acf7ee98a2fd82b303081c80603551d230481c03081bd80141eebd5a29c221e94740f672acf7ee98a2fd82b30a18199a48196308193310b3009060355040613024652310f300d06035504

    EAP-Message =
0x0813065261646975733112301006035504071309536f6d65776865726531153013060355040a130c4578616d706c6520496e632e3120301e06092a864886f70d010901161161646d696e406578616d706c652e636f6d312630240603550403131d4578616d706c6520436572746966696361746520417574686f726974798209008be5093fd724bf3b300c0603551d13040530030101ff300d06092a864886f70d0101050500038201010005525a77c2eafa9426fb81adb9f5b755abdcfdcd797a140c2ed7752ea621ac4e7fe59b15e9b032ab9c01ca92e400010dae6b00ce089dc026510221a7408b77373469311bf4c79e16c9cbc51a4e8bdbfc1048

    EAP-Message = 0xc3be21b792c4ed44
    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0x68aa16cc6aaf0f2af50a0ba6abea9d5a
Finished request 2.
Going to the next request
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=90, length=152

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0x4aa0ce893551d6796e4ad98991f72c7a
    EAP-Message = 0x020500061900
    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18204
    State = 0x68aa16cc6aaf0f2af50a0ba6abea9d5a
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 5 length 6
[eap] Continuing tunnel setup.
++[eap] returns ok
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] Request found, released from the list
[eap] EAP/peap
[eap] processing type peap
[peap] processing EAP-TLS
[peap] Received TLS ACK
[peap] ACK handshake fragment handler
[peap] eaptls_verify returned 1
[peap] eaptls_process returned 13
[peap] EAPTLS_HANDLED
++[eap] returns handled
Sending Access-Challenge of id 90 to 172.17.0.93 port 1645
    EAP-Message =
0x010600b51900a73433974eaca7174e319cb9708968c1efee2e5560ed1a98add3ff825b9c9b01472a7cd67c0c4f4b12b3a0d8751b039683fc88ce04b8da5ea71539a4a489ae0e19db05e4c410c1c9efef5233c0a5c28c1301b72a583bb952ec8ab7da466464a7e61a7227ece5fcf9ffcf230642c011a1140916315783367053fb2b974be359082c462e7d067ef710d750c9646b8b704fd5b36454f10af7b5e8cb999e9bcd7007448ac284613a16030100040e000000

    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0x68aa16cc6bac0f2af50a0ba6abea9d5a
Finished request 3.
Going to the next request
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=91, length=468

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0x8e5ddf0e25d2b052a6f94a88d0263087
    EAP-Message =
0x0206014019800000013616030101061000010201007797e2f40c6e89796600ce543bfe70485622255a8239b73db3550a7f3ba9f341d8af63e1894d913c58f507ea0457daf79a5f1f12588fec8ea52d9a8c3172aaf276930ba07116d21b1ed3d5768626a0b26ac5e1b1f41887ee1667f0cf2c050ba8cedc7fbe027c0efa9b11e92dac089fa628e0badfca2b566eb512104092565bd115a2c46c4fb4f1d6a4b879bfdf25401f16652e3fb1db6d197db077e90c7a0b931634e028163d79755c7b1da3552261b05e5ebff1d5e960ac4272ea661a7609b46a07ffdc00f31a09e2a77facbec3df95ae49ef109da80cf3053abe22d1c91a9db97faa5efb071463

    EAP-Message =
0xf5d409faec2a51aae45678227398f4dc93a53b33e6e509a41403010001011603010020a595650d85d9d8ebbd4b935212b306389ea4ff1e4a3678ac25505e59abdead87

    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18204
    State = 0x68aa16cc6bac0f2af50a0ba6abea9d5a
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 6 length 253
[eap] Continuing tunnel setup.
++[eap] returns ok
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] Request found, released from the list
[eap] EAP/peap
[eap] processing type peap
[peap] processing EAP-TLS
  TLS Length 310
[peap] Length Included
[peap] eaptls_verify returned 11
[peap] <<< TLS 1.0 Handshake [length 0106], ClientKeyExchange
[peap]     TLS_accept: SSLv3 read client key exchange A
[peap] <<< TLS 1.0 ChangeCipherSpec [length 0001]
[peap] <<< TLS 1.0 Handshake [length 0010], Finished
[peap]     TLS_accept: SSLv3 read finished A
[peap] >>> TLS 1.0 ChangeCipherSpec [length 0001]
[peap]     TLS_accept: SSLv3 write change cipher spec A
[peap] >>> TLS 1.0 Handshake [length 0010], Finished
[peap]     TLS_accept: SSLv3 write finished A
[peap]     TLS_accept: SSLv3 flush data
[peap]     (other): SSL negotiation finished successfully
SSL Connection Established
[peap] eaptls_process returned 13
[peap] EAPTLS_HANDLED
++[eap] returns handled
Sending Access-Challenge of id 91 to 172.17.0.93 port 1645
    EAP-Message =
0x0107003119001403010001011603010020b47e0fc66abd9d43a1963f41f8c6d6c072b3cb66001a7793c1581bc6fcbc7963

    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0x68aa16cc6cad0f2af50a0ba6abea9d5a
Finished request 4.
Going to the next request
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=92, length=152

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0xa98a256c4a390756a51eaad4cb7a3bdb
    EAP-Message = 0x020700061900
    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18204
    State = 0x68aa16cc6cad0f2af50a0ba6abea9d5a
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 7 length 6
[eap] Continuing tunnel setup.
++[eap] returns ok
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] Request found, released from the list
[eap] EAP/peap
[eap] processing type peap
[peap] processing EAP-TLS
[peap] Received TLS ACK
[peap] ACK handshake is finished
[peap] eaptls_verify returned 3
[peap] eaptls_process returned 3
[peap] EAPTLS_SUCCESS
++[eap] returns handled
Sending Access-Challenge of id 92 to 172.17.0.93 port 1645
    EAP-Message =
0x0108002019001703010015eb32b973d50fe1c93287e0a62f7994c2bceb4eeec3

    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0x68aa16cc6da20f2af50a0ba6abea9d5a
Finished request 5.
Going to the next request
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=93, length=194

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0x4b39bbfb00cd8a8dc76be1b73cde14f1
    EAP-Message =
0x0208003019001703010025374f8bdd2c4915fbbdc65f26eea29db863d44902cf2accbf135038d640c8d84cca815269fd

    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18204
    State = 0x68aa16cc6da20f2af50a0ba6abea9d5a
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 8 length 48
[eap] Continuing tunnel setup.
++[eap] returns ok
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] Request found, released from the list
[eap] EAP/peap
[eap] processing type peap
[peap] processing EAP-TLS
[peap] eaptls_verify returned 7
[peap] Done initial handshake
[peap] eaptls_process returned 7
[peap] EAPTLS_OK
[peap] Session established.  Decoding tunneled attributes.
[peap] Identity - EXCHANGE\pmarinkovic
[peap] Got tunneled request
    EAP-Message = 0x020800190145584348414e47455c706d6172696e6b6f766963
server  {
  PEAP: Got tunneled identity of EXCHANGE\pmarinkovic
  PEAP: Setting default EAP type for tunneled EAP session.
  PEAP: Setting User-Name to EXCHANGE\pmarinkovic
Sending tunneled request
    EAP-Message = 0x020800190145584348414e47455c706d6172696e6b6f766963
    FreeRADIUS-Proxied-To = 127.0.0.1
    User-Name = "EXCHANGE\\pmarinkovic"
server inner-tunnel {
+- entering group authorize {...}
++[chap] returns noop
++[mschap] returns noop
++[unix] returns notfound
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
++[control] returns noop
[eap] EAP packet type response id 8 length 25
[eap] No EAP Start, assuming it's an on-going EAP conversation
++[eap] returns updated
++[files] returns noop
++[expiration] returns noop
++[logintime] returns noop
++[pap] returns noop
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] EAP Identity
[eap] processing type mschapv2
rlm_eap_mschapv2: Issuing Challenge
++[eap] returns handled
} # server inner-tunnel
[peap] Got tunneled reply code 11
    EAP-Message =
0x0109002e1a01090029103033c05ef4057d06db43e3671ec5892545584348414e47455c706d6172696e6b6f766963

    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0xe9cb5785e9c24dc02f0c5b9856abc538
[peap] Got tunneled reply RADIUS code 11
    EAP-Message =
0x0109002e1a01090029103033c05ef4057d06db43e3671ec5892545584348414e47455c706d6172696e6b6f766963

    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0xe9cb5785e9c24dc02f0c5b9856abc538
[peap] Got tunneled Access-Challenge
++[eap] returns handled
Sending Access-Challenge of id 93 to 172.17.0.93 port 1645
    EAP-Message =
0x010900451900170301003a35147e663ad6ef2afe346252613a6f70209cdaed1e90d5822ab86c68687b785cf52bfc7354a7174beec2771f73838369d9b46276ba297e4e8b4b

    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0x68aa16cc6ea30f2af50a0ba6abea9d5a
Finished request 6.
Going to the next request
Waking up in 4.8 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=94, length=248

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0xcbb6232d980618716e1e9bf37945d32c
    EAP-Message =
0x020900661900170301005b9b97402e1842ca116277c3402b4a3ade8705ca8fcd85040733779bcfde103f1ef8083fcf9dec676da34bfe97b6dd7b5337e2120b8d6cf6ed07486b89846b5ec8e0a2a1c66a40444210ed213bbeeb04ba75c171bf0073e33da7e5fd

    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18204
    State = 0x68aa16cc6ea30f2af50a0ba6abea9d5a
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 9 length 102
[eap] Continuing tunnel setup.
++[eap] returns ok
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] Request found, released from the list
[eap] EAP/peap
[eap] processing type peap
[peap] processing EAP-TLS
[peap] eaptls_verify returned 7
[peap] Done initial handshake
[peap] eaptls_process returned 7
[peap] EAPTLS_OK
[peap] Session established.  Decoding tunneled attributes.
[peap] EAP type mschapv2
[peap] Got tunneled request
    EAP-Message =
0x0209004f1a0209004a31eede92de63d6b5c0e2fa83f3c0307c7f00000000000000007d955691d4b353ed671b109278a02de0ceabec8cdde2eb930045584348414e47455c706d6172696e6b6f766963

server  {
  PEAP: Setting User-Name to EXCHANGE\pmarinkovic
Sending tunneled request
    EAP-Message =
0x0209004f1a0209004a31eede92de63d6b5c0e2fa83f3c0307c7f00000000000000007d955691d4b353ed671b109278a02de0ceabec8cdde2eb930045584348414e47455c706d6172696e6b6f766963

    FreeRADIUS-Proxied-To = 127.0.0.1
    User-Name = "EXCHANGE\\pmarinkovic"
    State = 0xe9cb5785e9c24dc02f0c5b9856abc538
server inner-tunnel {
+- entering group authorize {...}
++[chap] returns noop
++[mschap] returns noop
++[unix] returns notfound
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
++[control] returns noop
[eap] EAP packet type response id 9 length 79
[eap] No EAP Start, assuming it's an on-going EAP conversation
++[eap] returns updated
++[files] returns noop
++[expiration] returns noop
++[logintime] returns noop
++[pap] returns noop
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] Request found, released from the list
[eap] EAP/mschapv2
[eap] processing type mschapv2
[mschapv2] +- entering group MS-CHAP {...}
[mschap] No Cleartext-Password configured.  Cannot create LM-Password.
[mschap] No Cleartext-Password configured.  Cannot create NT-Password.
[mschap] Told to do MS-CHAPv2 for pmarinkovic with NT-Password
[mschap]     expand: --username=%{mschap:User-Name:-None} ->
--username=pmarinkovic

[mschap]  mschap2: 30
[mschap]     expand:
--domain=%{mschap:NT-Domain:-EXCHANGE}--challenge=%{mschap:Challenge:-00}
-> --domain=EXCHANGE--challenge=73e442d7ccbf38a0

[mschap]     expand: --nt-response=%{mschap:NT-Response:-00} ->
--nt-response=7d955691d4b353ed671b109278a02de0ceabec8cdde2eb93

password:

It asks me for a password? When I enter password of that domain account, it
gives following output

 Exec-Program output: NT_STATUS_NO_SUCH_USER: No such user (0xc0000064)
Exec-Program-Wait: plaintext: NT_STATUS_NO_SUCH_USER: No such user
(0xc0000064)

Exec-Program: returned: 1
[mschap] External script failed.
[mschap] FAILED: MS-CHAP2-Response is incorrect
++[mschap] returns reject
[eap] Freeing handler
++[eap] returns reject
Failed to authenticate the user.
} # server inner-tunnel
[peap] Got tunneled reply code 3
    MS-CHAP-Error = "\tE=691 R=1"
    EAP-Message = 0x04090004
    Message-Authenticator = 0x00000000000000000000000000000000
[peap] Got tunneled reply RADIUS code 3
    MS-CHAP-Error = "\tE=691 R=1"
    EAP-Message = 0x04090004
    Message-Authenticator = 0x00000000000000000000000000000000
[peap] Tunneled authentication was rejected.
[peap] FAILURE
++[eap] returns handled
Sending Access-Challenge of id 94 to 172.17.0.93 port 1645
    EAP-Message =
0x010a00261900170301001bc119cd9925061d59f4967693d64f29c70171a0a82c0c0c8d92602c

    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0x68aa16cc6fa00f2af50a0ba6abea9d5a
Finished request 7.
Going to the next request
Cleaning up request 0 ID 87 with timestamp +276
Cleaning up request 1 ID 88 with timestamp +276
Cleaning up request 2 ID 89 with timestamp +276
Cleaning up request 3 ID 90 with timestamp +276
Cleaning up request 4 ID 91 with timestamp +276
Cleaning up request 5 ID 92 with timestamp +276
Cleaning up request 6 ID 93 with timestamp +276
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=94, length=248

Sending duplicate reply to client 172.17.0.93 port 1645 - ID: 94
Sending Access-Challenge of id 94 to 172.17.0.93 port 1645
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=94, length=248

Sending duplicate reply to client 172.17.0.93 port 1645 - ID: 94
Sending Access-Challenge of id 94 to 172.17.0.93 port 1645
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=94, length=248

Sending duplicate reply to client 172.17.0.93 port 1645 - ID: 94
Sending Access-Challenge of id 94 to 172.17.0.93 port 1645
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=94, length=248

Sending duplicate reply to client 172.17.0.93 port 1645 - ID: 94
Sending Access-Challenge of id 94 to 172.17.0.93 port 1645
Waking up in 4.9 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=95, length=153

    User-Name = "EXCHANGE\\pmarinkovic"
    Framed-MTU = 1400
    Called-Station-Id = "0014.1cde.6ab0"
    Calling-Station-Id = "0016.ead8.3812"
    Service-Type = Login-User
    Message-Authenticator = 0xc80201228ec35028d9ce888dc15f8ac3
    EAP-Message = 0x020200190145584348414e47455c706d6172696e6b6f766963
    NAS-Port-Type = Wireless-802.11
    NAS-Port = 18206
    NAS-IP-Address = 172.17.0.93
    NAS-Identifier = "ap"
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
[suffix] No '@' in User-Name = "EXCHANGE\pmarinkovic", looking up realm NULL

[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] EAP packet type response id 2 length 25
[eap] No EAP Start, assuming it's an on-going EAP conversation
++[eap] returns updated
++[unix] returns notfound
++[files] returns noop
++[expiration] returns noop
++[logintime] returns noop
[pap] WARNING! No "known good" password found for the user.
Authentication may fail because of this.

++[pap] returns noop
Found Auth-Type = EAP
+- entering group authenticate {...}
[eap] EAP Identity
[eap] processing type tls
[tls] Initiate
[tls] Start returned 1
++[eap] returns handled
Sending Access-Challenge of id 95 to 172.17.0.93 port 1645
    EAP-Message = 0x010300061920
    Message-Authenticator = 0x00000000000000000000000000000000
    State = 0xebca9fefebc98666206fed83e0de5375
Finished request 8.
Going to the next request
Waking up in 4.8 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=95, length=153

Sending duplicate reply to client 172.17.0.93 port 1645 - ID: 95
Sending Access-Challenge of id 95 to 172.17.0.93 port 1645
Waking up in 4.8 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=95, length=153

Sending duplicate reply to client 172.17.0.93 port 1645 - ID: 95
Sending Access-Challenge of id 95 to 172.17.0.93 port 1645
Waking up in 4.8 seconds.
rad_recv: Access-Request packet from host 172.17.0.93 port 1645,
id=95, length=153

Sending duplicate reply to client 172.17.0.93 port 1645 - ID: 95
Sending Access-Challenge of id 95 to 172.17.0.93 port 1645
Waking up in 4.8 seconds.
Cleaning up request 7 ID 94 with timestamp +276
Waking up in 0.1 seconds.
Cleaning up request 8 ID 95 with timestamp +531
Ready to process requests.

In radiusd.conf, I only added exec lines to modules section from the
tutorial

exec ntlm_auth {
                wait = yes
                program = "*/*usr/bin/ntlm_auth ntlm_auth --request-nt-key
--domain=EXCHANGE --username=%{mschap:User-Name}
--password=%{User-Password}"
        }


And mschap file in modules dir. I left those 3 commented lines, I tried also
with them, but no luck.

mschap {
    with_ntdomain_hack = yes
    #use_mppe = yes
    #require_encryption = yes
    #require_strong = no

    ntlm_auth = "/usr/bin/ntlm_auth --request-nt-key
--username=%{mschap:User-Name:-None}
--domain=%{mschap:NT-Domain:-EXCHANGE}--challenge=%{mschap:Challenge:-00}
--nt-response=%{mschap:NT-Response:-00}"

}

What I am doing wrong here? In eap.conf I only changed default_auth_type to
PEAP, and that's all. Many thanks for your help, and I would appreaciate it
a lot if you can help me, cause this thing is driving me crazy for last 2-3
days. I read bunch of topics, but none helped..
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.freeradius.org/pipermail/freeradius-users/attachments/20090624/57ee27a7/attachment.html>


More information about the Freeradius-Users mailing list