The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

форумы  помощь  поиск  регистрация  вход/выход  слежка  RSS
"freeradius + ldap + mschap"
Вариант для распечатки  
Пред. тема | След. тема 
Форум Открытые системы на сервере (Др. сетевые сервисы / Linux)
Изначальное сообщение [ Отслеживать ]

"freeradius + ldap + mschap"  +/
Сообщение от nettro (ok) on 22-Апр-15, 16:05 
Добрый день.

Помогите пожалуйста подружить freeradius2 + chap/mschapv2.
Цель: что бы при подключении к vpn-серверу, который авторизует пользователей через radius в ldap, пароль не передавался в открытом виде.

Конфиги freeradius2:

radius.conf

prefix = /usr
exec_prefix = /usr
sysconfdir = /etc
localstatedir = /var
sbindir = /usr/sbin
logdir = ${localstatedir}/log/radius
raddbdir = ${sysconfdir}/raddb
radacctdir = ${logdir}/radacct
name = radiusd
confdir = ${raddbdir}
run_dir = ${localstatedir}/run/${name}
db_dir = ${raddbdir}
libdir = /usr/lib64/freeradius
pidfile = ${run_dir}/${name}.pid
user = radiusd
group = radiusd
max_request_time = 30
cleanup_delay = 5
max_requests = 1024
listen {
    type = auth
    ipaddr = *
    port = 0
}
listen {
    ipaddr = *
    port = 0
    type = acct
}
hostname_lookups = no
allow_core_dumps = no
regular_expressions     = yes
extended_expressions    = yes
log {
    destination = files
    file = ${logdir}/radius.log
    syslog_facility = daemon
    stripped_names = no
    auth = yes
    auth_badpass = yes
    auth_goodpass = no
}
checkrad = ${sbindir}/checkrad
security {
    max_attributes = 200
    reject_delay = 1
    status_server = yes
}
proxy_requests = yes
$INCLUDE proxy.conf
$INCLUDE clients.conf
thread pool {
    start_servers = 5
    max_servers = 32
    min_spare_servers = 3
    max_spare_servers = 10
    max_requests_per_server = 0
}
modules {
    $INCLUDE ${confdir}/modules/
    $INCLUDE eap.conf
}
instantiate {
    exec
    expr
    expiration
    logintime
}
$INCLUDE policy.conf
$INCLUDE sites-enabled/

modules/ldap

ldap {
    server = "ldap.domain.ru"
    port = 1111
    identity = "cn=user1,ou=Testportal,ou=People,dc=domain,dc=ru"
    password = "user1_pass"
    basedn = "dc=domain,dc=ru"
    base_filter = "(&(cn=*)(objectclass=person))"
    ldap_connections_number = 5
    timeout = 4
    timelimit = 3
    net_timeout = 1
    tls {
        start_tls = no
    }
    access_attr = "cn"
    dictionary_mapping = ${confdir}/ldap.attrmap
    edir_account_policy_check = no
    groupname_attribute = cn
    groupmembership_filter = "(&(cn=*)(|(objectclass=groupofNames)(objectclass=orcldynamicgroup)))"
    keepalive {
        idle = 60
        probes = 3
        interval = 3
    }
}

modules/mschap

mschap {
    authtype = MS-CHAP
    use_mppe = yes
    require_encryption = yes
    require_strong = yes
    with_ntdomain_hack = yes
}

sites-available/default

authorize {
    preprocess
    chap
    mschap
    digest
    suffix
    eap {
        ok = return
    }
    files
    ldap
    expiration
    logintime
    pap
}
authenticate {
    Auth-Type PAP {
        pap
    }
    Auth-Type CHAP {
        chap
    }
    Auth-Type MS-CHAP {
        mschap
    }
    digest
    unix
    Auth-Type LDAP {
        ldap
    }
    eap
}
preacct {
    preprocess
    acct_unique
    suffix
    files
}
accounting {
    detail
    unix
    radutmp
    exec
}
session {
    radutmp
}
post-auth {
#   ldap
    exec
    Post-Auth-Type REJECT {
        attr_filter.access_reject
    }
}
pre-proxy {
}
post-proxy {
    eap
}

sites-available/inner-tunnel

server inner-tunnel {
listen {
    ipaddr = 127.0.0.1
    port = 18120
    type = auth
}
authorize {
    chap
    mschap
    suffix
#   ntdomain
    update control {
        Proxy-To-Realm := LOCAL
    }
    eap {
        ok = return
    }
#   files
    ldap
#   expiration
#   logintime
    pap
}
authenticate {
    Auth-Type PAP {
        pap
    }
    Auth-Type CHAP {
        chap
    }
    Auth-Type MS-CHAP {
        mschap
    }
#   unix
    Auth-Type LDAP {
        ldap
    }
    eap
}
session {
    radutmp
}
post-auth {
#   ldap
    Post-Auth-Type REJECT {
        attr_filter.access_reject
    }
}
pre-proxy {
}
post-proxy {
    eap
}

} # inner-tunnel server block

При подключении по PAP всё проходит нормально

radtest -t pap user1 user1_pass localhost 5 testing123
Sending Access-Request of id 213 to 127.0.0.1 port 1812
    User-Name = "user1"
    User-Password = "user1"
    NAS-IP-Address = 172.31.14.18
    NAS-Port = 5
    Message-Authenticator = 0x00000000000000000000000000000000
rad_recv: Access-Accept packet from host 127.0.0.1 port 1812, id=213, length=20


log radius:
---------------------
main {
    user = "radiusd"
    group = "radiusd"
    allow_core_dumps = no
}
including dictionary file /etc/raddb/dictionary
main {
    name = "radiusd"
    prefix = "/usr"
    localstatedir = "/var"
    sbindir = "/usr/sbin"
    logdir = "/var/log/radius"
    run_dir = "/var/run/radiusd"
    libdir = "/usr/lib64/freeradius"
    radacctdir = "/var/log/radius/radacct"
    hostname_lookups = no
    max_request_time = 30
    cleanup_delay = 5
    max_requests = 1024
    pidfile = "/var/run/radiusd/radiusd.pid"
    checkrad = "/usr/sbin/checkrad"
    debug_level = 0
    proxy_requests = yes
log {
    stripped_names = no
    auth = yes
    auth_badpass = yes
    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 = yes
    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
  coa {
    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"
    shortname = "localhost"
    nastype = "other"
}
radiusd: #### Loading Virtual Servers ####
server { # from file /etc/raddb/radiusd.conf
modules {
  Module: Creating Auth-Type = digest
  Module: Creating Auth-Type = LDAP
  Module: Creating Post-Auth-Type = REJECT
Module: Checking authenticate {...} for more modules to load
Module: Linked to module rlm_pap
Module: Instantiating module "pap" from file /etc/raddb/modules/pap
  pap {
    encryption_scheme = "auto"
    auto_header = no
  }
Module: Linked to module rlm_chap
Module: Instantiating module "chap" from file /etc/raddb/modules/chap
Module: Linked to module rlm_mschap
Module: Instantiating module "mschap" from file /etc/raddb/modules/mschap
  mschap {
    use_mppe = yes
    require_encryption = yes
    require_strong = yes
    with_ntdomain_hack = yes
    allow_retry = yes
  }
Module: Linked to module rlm_digest
Module: Instantiating module "digest" from file /etc/raddb/modules/digest
Module: Linked to module rlm_unix
Module: Instantiating module "unix" from file /etc/raddb/modules/unix
  unix {
    radwtmp = "/var/log/radius/radwtmp"
  }
Module: Linked to module rlm_ldap
Module: Instantiating module "ldap" from file /etc/raddb/modules/ldap
  ldap {
    server = "ldap.domain.ru"
    port = 1111
    password = "user1_pass"
    identity = "cn=user1,ou=Testportal,ou=People,dc=domain,dc=ru"
    net_timeout = 1
    timeout = 4
    timelimit = 3
    tls_mode = no
    start_tls = no
    tls_require_cert = "allow"
   tls {
    start_tls = no
    require_cert = "allow"
   }
    basedn = "dc=domain,dc=ru"
    filter = "(uid=%u)"
    base_filter = "(&(cn=*)(objectclass=person))"
    auto_header = no
    access_attr = "cn"
    access_attr_used_for_allow = yes
    groupname_attribute = "cn"
    groupmembership_filter = "(&(cn=*)(|(objectclass=groupofNames)(objectclass=orcldynamicgroup)))"
    dictionary_mapping = "/etc/raddb/ldap.attrmap"
    ldap_debug = 0
    ldap_connections_number = 5
    compare_check_items = no
    do_xlat = yes
    set_auth_type = yes
   keepalive {
    interval = 3
   }
  }
Module: Linked to module rlm_eap
Module: Instantiating module "eap" from file /etc/raddb/eap.conf
  eap {
    default_eap_type = "peap"
    timer_expire = 60
    ignore_unknown_eap_types = no
    cisco_accounting_username_bug = no
    max_sessions = 4096
  }
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
    CA_path = "/etc/raddb/certs"
    pem_file_type = yes
    private_key_file = "/etc/raddb/certs/server.pem"
    certificate_file = "/etc/raddb/certs/server.pem"
    CA_file = "/etc/raddb/certs/ca.pem"
    private_key_password = "whatever"
    dh_file = "/etc/raddb/certs/dh"
    random_file = "/etc/raddb/certs/random"
    fragment_size = 1024
    include_length = yes
    check_crl = no
    cipher_list = "DEFAULT"
    cache {
    enable = no
    lifetime = 24
    max_entries = 255
    }
    verify {
    }
    ocsp {
    enable = no
    override_cert_url = yes
    url = "http://127.0.0.1/ocsp/"
    }
   }
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"
    soh = no
   }
Module: Linked to sub-module rlm_eap_mschapv2
Module: Instantiating eap-mschapv2
   mschapv2 {
    with_ntdomain_hack = no
    send_error = no
   }
Module: Checking authorize {...} for more modules to load
Module: Linked to module rlm_preprocess
Module: Instantiating module "preprocess" from file /etc/raddb/modules/preprocess
  preprocess {
    huntgroups = "/etc/raddb/huntgroups"
    hints = "/etc/raddb/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: Linked to module rlm_realm
Module: Instantiating module "suffix" from file /etc/raddb/modules/realm
  realm suffix {
    format = "suffix"
    delimiter = "@"
    ignore_default = no
    ignore_null = no
  }
Module: Linked to module rlm_files
Module: Instantiating module "files" from file /etc/raddb/modules/files
  files {
    usersfile = "/etc/raddb/users"
    acctusersfile = "/etc/raddb/acct_users"
    preproxy_usersfile = "/etc/raddb/preproxy_users"
    compat = "no"
  }
Module: Checking preacct {...} for more modules to load
Module: Linked to module rlm_acct_unique
Module: Instantiating module "acct_unique" from file /etc/raddb/modules/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 module "detail" from file /etc/raddb/modules/detail
  detail {
    detailfile = "/var/log/radius/radacct/%{%{Packet-Src-IP-Address}:-%{Packet-Src-IPv6-Address}}/detail-%Y%m%d"
    header = "%t"
    detailperm = 384
    dirperm = 493
    locking = no
    log_packet_header = no
  }
Module: Linked to module rlm_radutmp
Module: Instantiating module "radutmp" from file /etc/raddb/modules/radutmp
  radutmp {
    filename = "/var/log/radius/radutmp"
    username = "%{User-Name}"
    case_sensitive = yes
    check_with_nas = yes
    perm = 384
    callerid = yes
  }
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
Module: Linked to module rlm_attr_filter
Module: Instantiating module "attr_filter.access_reject" from file /etc/raddb/modules/attr_filter
  attr_filter attr_filter.access_reject {
    attrsfile = "/etc/raddb/attrs.access_reject"
    key = "%{User-Name}"
    relaxed = no
  }
} # modules
} # server
server inner-tunnel { # from file /etc/raddb/sites-enabled/inner-tunnel
modules {
Module: Checking authenticate {...} for more modules to load
Module: Checking authorize {...} for more modules to load
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/radiusd/radiusd.sock"
}
}
listen {
    type = "auth"
    ipaddr = 127.0.0.1
    port = 18120
}
... adding new socket proxy address * port 29249
Listening on authentication address * port 1812
Listening on accounting address * port 1813
Listening on command file /var/run/radiusd/radiusd.sock
Listening on authentication address 127.0.0.1 port 18120 as server inner-tunnel
Listening on proxy address * port 1814
Ready to process requests.
rad_recv: Access-Request packet from host 127.0.0.1 port 11203, id=183, length=74
    User-Name = "user1"
    User-Password = "user1_pass"
    NAS-IP-Address = 172.31.14.18
    NAS-Port = 5
    Message-Authenticator = 0xabf99da12ccdcd91b0b9fbd94be6c4e1
# Executing section authorize from file /etc/raddb/sites-enabled/default
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
++[mschap] returns noop
++[digest] returns noop
[suffix] No '@' in User-Name = "user1", looking up realm NULL
[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] No EAP-Message, not doing EAP
++[eap] returns noop
++[files] returns noop
[ldap] performing user authorization for user1
[ldap]     expand: (uid=%u) -> (uid=user1)
[ldap]     expand: dc=domain,dc=ru -> dc=domain,dc=ru
  [ldap] ldap_get_conn: Checking Id: 0
  [ldap] ldap_get_conn: Got Id: 0
  [ldap] attempting LDAP reconnection
  [ldap] (re)connect to ldap.domain.ru:3060, authentication 0
  [ldap] bind as cn=user1,ou=Testportal,ou=People,dc=domain,dc=ru/user1_pass to ldap.domain.ru:3060
  [ldap] waiting for bind result ...
  [ldap] Bind was successful
  [ldap] performing search in dc=domain,dc=ru, with filter (uid=user1)
[ldap] checking if remote access for user1 is allowed by cn
[ldap] looking for check items in directory...
  [ldap] userPassword -> Password-With-Header == "{SSHA}1wkmwUAV6mCykDBEfqFyZ09h30GL+B0XwfGUOg=="
  [ldap] userPassword -> Cleartext-Password == "{SSHA}1wkmwUAV6mCykDBEfqFyZ09h30GL+B0XwfGUOg=="
[ldap] looking for reply items in directory...
[ldap] Setting Auth-Type = LDAP
[ldap] user user1 authorized to use remote access
  [ldap] ldap_release_conn: Release Id: 0
++[ldap] returns ok
++[expiration] returns noop
++[logintime] returns noop
[pap] Normalizing SSHA1-Password from base64 encoding
[pap] WARNING: Auth-Type already set.  Not setting to PAP
++[pap] returns noop
Found Auth-Type = LDAP
# Executing group from file /etc/raddb/sites-enabled/default
+- entering group LDAP {...}
[ldap] login attempt by "user1" with password "user1_pass"
[ldap] user DN: cn=user1,ou=Testportal,ou=People,dc=domain,dc=ru
  [ldap] (re)connect to ldap.domain.ru:3060, authentication 1
  [ldap] bind as cn=user1,ou=Testportal,ou=People,dc=domain,dc=ru/user1_pass to ldap.domain.ru:3060
  [ldap] waiting for bind result ...
  [ldap] Bind was successful
[ldap] user user1 authenticated succesfully
++[ldap] returns ok
Login OK: [user1] (from client localhost port 5)
# Executing section post-auth from file /etc/raddb/sites-enabled/default
+- entering group post-auth {...}
++[exec] returns noop
Sending Access-Accept of id 183 to 127.0.0.1 port 11203
Finished request 0.
Going to the next request
Waking up in 4.9 seconds.
---------------------

При попытки подключится по mschap тесты не проходят

radtest -t mschap user1 user1_pass localhost 5 testing123
Sending Access-Request of id 74 to 127.0.0.1 port 1812
    User-Name = "user1"
    NAS-IP-Address = 172.31.14.18
    NAS-Port = 5
    Message-Authenticator = 0x00000000000000000000000000000000
    MS-CHAP-Challenge = 0xe1658223d0a66125
    MS-CHAP-Response = 0x000100000000000000000000000000000000000000000000000041e2c67f8ffaf21ffd6c2dc1e4750de7e88a28f062d1284a
rad_recv: Access-Reject packet from host 127.0.0.1 port 1812, id=74, length=38
    MS-CHAP-Error = "\000E=691 R=1"


log radius:
----------------------
main {
    user = "radiusd"
    group = "radiusd"
    allow_core_dumps = no
}
including dictionary file /etc/raddb/dictionary
main {
    name = "radiusd"
    prefix = "/usr"
    localstatedir = "/var"
    sbindir = "/usr/sbin"
    logdir = "/var/log/radius"
    run_dir = "/var/run/radiusd"
    libdir = "/usr/lib64/freeradius"
    radacctdir = "/var/log/radius/radacct"
    hostname_lookups = no
    max_request_time = 30
    cleanup_delay = 5
    max_requests = 1024
    pidfile = "/var/run/radiusd/radiusd.pid"
    checkrad = "/usr/sbin/checkrad"
    debug_level = 0
    proxy_requests = yes
log {
    stripped_names = no
    auth = yes
    auth_badpass = yes
    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 = yes
    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
  coa {
    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"
    shortname = "localhost"
    nastype = "other"
}
radiusd: #### Loading Virtual Servers ####
server { # from file /etc/raddb/radiusd.conf
modules {
  Module: Creating Auth-Type = digest
  Module: Creating Auth-Type = LDAP
  Module: Creating Post-Auth-Type = REJECT
Module: Checking authenticate {...} for more modules to load
Module: Linked to module rlm_pap
Module: Instantiating module "pap" from file /etc/raddb/modules/pap
  pap {
    encryption_scheme = "auto"
    auto_header = no
  }
Module: Linked to module rlm_chap
Module: Instantiating module "chap" from file /etc/raddb/modules/chap
Module: Linked to module rlm_mschap
Module: Instantiating module "mschap" from file /etc/raddb/modules/mschap
  mschap {
    use_mppe = yes
    require_encryption = yes
    require_strong = yes
    with_ntdomain_hack = yes
    allow_retry = yes
  }
Module: Linked to module rlm_digest
Module: Instantiating module "digest" from file /etc/raddb/modules/digest
Module: Linked to module rlm_unix
Module: Instantiating module "unix" from file /etc/raddb/modules/unix
  unix {
    radwtmp = "/var/log/radius/radwtmp"
  }
Module: Linked to module rlm_ldap
Module: Instantiating module "ldap" from file /etc/raddb/modules/ldap
  ldap {
    server = "ldap.domain.ru"
    port = 1111
    password = "user1_pass"
    identity = "cn=user1,ou=Testportal,ou=People,dc=domain,dc=ru"
    net_timeout = 1
    timeout = 4
    timelimit = 3
    tls_mode = no
    start_tls = no
    tls_require_cert = "allow"
   tls {
    start_tls = no
    require_cert = "allow"
   }
    basedn = "dc=domain,dc=ru"
    filter = "(uid=%u)"
    base_filter = "(&(cn=*)(objectclass=person))"
    auto_header = no
    access_attr = "cn"
    access_attr_used_for_allow = yes
    groupname_attribute = "cn"
    groupmembership_filter = "(&(cn=*)(|(objectclass=groupofNames)(objectclass=orcldynamicgroup)))"
    dictionary_mapping = "/etc/raddb/ldap.attrmap"
    ldap_debug = 0
    ldap_connections_number = 5
    compare_check_items = no
    do_xlat = yes
    set_auth_type = yes
   keepalive {
    interval = 3
   }
  }

<...>  

Module: Linked to module rlm_eap
Module: Instantiating module "eap" from file /etc/raddb/eap.conf
  eap {
    default_eap_type = "peap"
    timer_expire = 60
    ignore_unknown_eap_types = no
    cisco_accounting_username_bug = no
    max_sessions = 4096
  }
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
    CA_path = "/etc/raddb/certs"
    pem_file_type = yes
    private_key_file = "/etc/raddb/certs/server.pem"
    certificate_file = "/etc/raddb/certs/server.pem"
    CA_file = "/etc/raddb/certs/ca.pem"
    private_key_password = "whatever"
    dh_file = "/etc/raddb/certs/dh"
    random_file = "/etc/raddb/certs/random"
    fragment_size = 1024
    include_length = yes
    check_crl = no
    cipher_list = "DEFAULT"
    cache {
    enable = no
    lifetime = 24
    max_entries = 255
    }
    verify {
    }
    ocsp {
    enable = no
    override_cert_url = yes
    url = "http://127.0.0.1/ocsp/"
    }
   }
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"
    soh = no
   }
Module: Linked to sub-module rlm_eap_mschapv2
Module: Instantiating eap-mschapv2
   mschapv2 {
    with_ntdomain_hack = no
    send_error = no
   }
Module: Checking authorize {...} for more modules to load
Module: Linked to module rlm_preprocess
Module: Instantiating module "preprocess" from file /etc/raddb/modules/preprocess
  preprocess {
    huntgroups = "/etc/raddb/huntgroups"
    hints = "/etc/raddb/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: Linked to module rlm_realm
Module: Instantiating module "suffix" from file /etc/raddb/modules/realm
  realm suffix {
    format = "suffix"
    delimiter = "@"
    ignore_default = no
    ignore_null = no
  }
Module: Linked to module rlm_files
Module: Instantiating module "files" from file /etc/raddb/modules/files
  files {
    usersfile = "/etc/raddb/users"
    acctusersfile = "/etc/raddb/acct_users"
    preproxy_usersfile = "/etc/raddb/preproxy_users"
    compat = "no"
  }
Module: Checking preacct {...} for more modules to load
Module: Linked to module rlm_acct_unique
Module: Instantiating module "acct_unique" from file /etc/raddb/modules/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 module "detail" from file /etc/raddb/modules/detail
  detail {
    detailfile = "/var/log/radius/radacct/%{%{Packet-Src-IP-Address}:-%{Packet-Src-IPv6-Address}}/detail-%Y%m%d"
    header = "%t"
    detailperm = 384
    dirperm = 493
    locking = no
    log_packet_header = no
  }
Module: Linked to module rlm_radutmp
Module: Instantiating module "radutmp" from file /etc/raddb/modules/radutmp
  radutmp {
    filename = "/var/log/radius/radutmp"
    username = "%{User-Name}"
    case_sensitive = yes
    check_with_nas = yes
    perm = 384
    callerid = yes
  }
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
Module: Linked to module rlm_attr_filter
Module: Instantiating module "attr_filter.access_reject" from file /etc/raddb/modules/attr_filter
  attr_filter attr_filter.access_reject {
    attrsfile = "/etc/raddb/attrs.access_reject"
    key = "%{User-Name}"
    relaxed = no
  }
} # modules
} # server
server inner-tunnel { # from file /etc/raddb/sites-enabled/inner-tunnel
modules {
Module: Checking authenticate {...} for more modules to load
Module: Checking authorize {...} for more modules to load
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/radiusd/radiusd.sock"
}
}
listen {
    type = "auth"
    ipaddr = 127.0.0.1
    port = 18120
}
... adding new socket proxy address * port 56524
Listening on authentication address * port 1812
Listening on accounting address * port 1813
Listening on command file /var/run/radiusd/radiusd.sock
Listening on authentication address 127.0.0.1 port 18120 as server inner-tunnel
Listening on proxy address * port 1814
Ready to process requests.
rad_recv: Access-Request packet from host 127.0.0.1 port 46583, id=74, length=130
    User-Name = "user1"
    NAS-IP-Address = 172.31.14.18
    NAS-Port = 5
    Message-Authenticator = 0x6a9dae186a4139d50b601397ee5d93bb
    MS-CHAP-Challenge = 0xe1658223d0a66125
    MS-CHAP-Response = 0x000100000000000000000000000000000000000000000000000041e2c67f8ffaf21ffd6c2dc1e4750de7e88a28f062d1284a
# Executing section authorize from file /etc/raddb/sites-enabled/default
+- entering group authorize {...}
++[preprocess] returns ok
++[chap] returns noop
[mschap] Found MS-CHAP attributes.  Setting 'Auth-Type  = mschap'
++[mschap] returns ok
++[digest] returns noop
[suffix] No '@' in User-Name = "user1", looking up realm NULL
[suffix] No such realm "NULL"
++[suffix] returns noop
[eap] No EAP-Message, not doing EAP
++[eap] returns noop
++[files] returns noop
[ldap] performing user authorization for user1
[ldap]     expand: (uid=%u) -> (uid=user1)
[ldap]     expand: dc=domain,dc=ru -> dc=domain,dc=ru
  [ldap] ldap_get_conn: Checking Id: 0
  [ldap] ldap_get_conn: Got Id: 0
  [ldap] attempting LDAP reconnection
  [ldap] (re)connect to ldap.domain.ru:3060, authentication 0
  [ldap] bind as cn=user1,ou=Testportal,ou=People,dc=domain,dc=ru/user1_pass to ldap.domain.ru:3060
  [ldap] waiting for bind result ...
  [ldap] Bind was successful
  [ldap] performing search in dc=domain,dc=ru, with filter (uid=user1)
[ldap] checking if remote access for user1 is allowed by cn
[ldap] looking for check items in directory...
  [ldap] userPassword -> Password-With-Header == "{SSHA}1wkmwUAV6mCykDBEfqFyZ09h30GL+B0XwfGUOg=="
  [ldap] userPassword -> Cleartext-Password == "{SSHA}1wkmwUAV6mCykDBEfqFyZ09h30GL+B0XwfGUOg=="
[ldap] looking for reply items in directory...
[ldap] user user1 authorized to use remote access
  [ldap] ldap_release_conn: Release Id: 0
++[ldap] returns ok
++[expiration] returns noop
++[logintime] returns noop
[pap] Normalizing SSHA1-Password from base64 encoding
[pap] WARNING: Auth-Type already set.  Not setting to PAP
++[pap] returns noop
Found Auth-Type = MSCHAP
# Executing group from file /etc/raddb/sites-enabled/default
+- entering group MS-CHAP {...}
[mschap] Told to do MS-CHAPv1 with NT-Password
[mschap] MS-CHAP-Response is incorrect.
++[mschap] returns reject
Failed to authenticate the user.
Login incorrect: [user1/<via Auth-Type = mschap>] (from client localhost port 5)
Using Post-Auth-Type Reject
# Executing group from file /etc/raddb/sites-enabled/default
+- entering group REJECT {...}
[attr_filter.access_reject]     expand: %{User-Name} -> user1
attr_filter: Matched entry DEFAULT at line 11
++[attr_filter.access_reject] returns updated
Delaying reject of request 0 for 1 seconds
Going to the next request
Waking up in 0.7 seconds.
Sending delayed reject for request 0
Sending Access-Reject of id 74 to 127.0.0.1 port 46583
    MS-CHAP-Error = "\000E=691 R=1"
Waking up in 4.9 seconds.
Cleaning up request 0 ID 74 with timestamp +3
Ready to process requests.
----------------------

Ответить | Правка | Cообщить модератору

Оглавление

Сообщения по теме [Сортировка по времени | RSS]


1. "freeradius + ldap + mschap"  +1 +/
Сообщение от pavel_simple (ok) on 22-Апр-15, 16:44 

вы либо должны хранить пароль в LDAP в cleartext либо NT-Password -- иначе авторизация не реальна в принципе, что вообще-то должно быть понятно -- ибо mschap -- это challenge-response а к S/SHA -- челенж mschap'а никак не прикрутить, даже если сильно захотеть.

Ответить | Правка | ^ к родителю #0 | Наверх | Cообщить модератору

2. "freeradius + ldap + mschap"  +/
Сообщение от nettro (ok) on 27-Апр-15, 12:18 

> вы либо должны хранить пароль в LDAP в cleartext либо NT-Password --
> иначе авторизация не реальна в принципе, что вообще-то должно быть понятно
> -- ибо mschap -- это challenge-response а к S/SHA -- челенж
> mschap'а никак не прикрутить, даже если сильно захотеть.

Большое спасибо!
Проблема и правда была в том, что ldap хранил пароли в шифрованном виде.

Подскажите пожалуйста, а есть какие-то варианты настройки связки vpn+radius+ldap, но при условии, что бы пароли в открытом виде вообще нигде не фигурировали и не передавались?

Ответить | Правка | ^ к родителю #1 | Наверх | Cообщить модератору

3. "freeradius + ldap + mschap"  +/
Сообщение от pavel_simple (ok) on 27-Апр-15, 12:27 
>> вы либо должны хранить пароль в LDAP в cleartext либо NT-Password --
>> иначе авторизация не реальна в принципе, что вообще-то должно быть понятно
>> -- ибо mschap -- это challenge-response а к S/SHA -- челенж
>> mschap'а никак не прикрутить, даже если сильно захотеть.
> Большое спасибо!
> Проблема и правда была в том, что ldap хранил пароли в шифрованном
> виде.
> Подскажите пожалуйста, а есть какие-то варианты настройки связки vpn+radius+ldap, но при
> условии, что бы пароли в открытом виде вообще нигде не фигурировали
> и не передавались?

ды я же уже сказал, что для того что-бы работал mschap и не cleartext -- то нужно хранить пароли в виже nt-password
вот тут напрамер можно взглянуть схемы http://freeradius.org/radiusd/man/rlm_pap.txt

Ответить | Правка | ^ к родителю #2 | Наверх | Cообщить модератору

4. "freeradius + ldap + mschap"  +/
Сообщение от Andrey Mitrofanov on 27-Апр-15, 12:35 
>> Большое спасибо!
>> Проблема и правда была в том, что ldap хранил пароли в шифрованном
>> виде.
>> Подскажите пожалуйста, а есть какие-то варианты настройки связки vpn+radius+ldap, но при
>> условии, что бы пароли в открытом виде вообще нигде не фигурировали
>> и не передавались?
> ды я же уже сказал, что для того что-бы работал mschap и
> не cleartext -- то нужно хранить пароли в виже nt-password

Не, не так. Чтобы пароли не _передавались и не _хранились открытым текстом, надо же сделать беспарольную/пусто-парольную [не-]авторизацию.

Ну или чтобы демон расшифровывал зашифрованные на диске открыто-текстовые пароли только в память при  запуске (как при полном шифровании всего диска, например). Но таких демонов не существует, вроде.

Ответить | Правка | ^ к родителю #3 | Наверх | Cообщить модератору

5. "freeradius + ldap + mschap"  +/
Сообщение от letnab (ok) on 30-Июн-16, 09:10 
>> вы либо должны хранить пароль в LDAP в cleartext либо NT-Password --
>> иначе авторизация не реальна в принципе, что вообще-то должно быть понятно
>> -- ибо mschap -- это challenge-response а к S/SHA -- челенж
>> mschap'а никак не прикрутить, даже если сильно захотеть.
> Большое спасибо!
> Проблема и правда была в том, что ldap хранил пароли в шифрованном
> виде.
> Подскажите пожалуйста, а есть какие-то варианты настройки связки vpn+radius+ldap, но при
> условии, что бы пароли в открытом виде вообще нигде не фигурировали
> и не передавались?

nettro, есть вопрос

Ответить | Правка | ^ к родителю #2 | Наверх | Cообщить модератору

Архив | Удалить

Рекомендовать для помещения в FAQ | Индекс форумов | Темы | Пред. тема | След. тема




Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2025 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру