On 11/19/2012 09:48 AM, Angel L. Mateo wrote:

ldap  {
   ...
   filter = "(&(mail=%{User-Name})(schacUserStatus=<urn prefix>:
%{X-Atica-Service}:enabled))"
   ...
}


DEFAULT X-Actica-Service = 'vpn', Auth-Type = LDAP, Realm == um.es
     User-Name := `%{User-Name}`,
     Fall-Through = No

     But this does not work.

It's important to understand how the "users" file works. The line you've written above says:

set "X-Actica-Service" to "vpn" in the "control" items if it's not already set (= operator)

set "Auth-Type" to "LDAP" in the "control" items if it's not already set (= operatgor)

*if* Realm == um.es

and then

set "User-Name" to "%{User-Name}" on the "reply" items *always* (:= operator)

set "Fall-Through" to "No" in the "reply" items if it's not already set (= operator)

So, any variable you set on that first line goes in the control items, so must be referred to there.

Either modify your LDAP filter to reference:

  "...%{control:X-Actica-Service}..."

...or better yet, convert the logic to an "unlang" stanza which is more flexible and more explicit / less "magic", hence easier to understand, *and* lets you set variables in any list. Like so:

authorize {
  ...
  if (Realm == um.es) {
    update request {
      X-Actica-Service = "..."
    }
  }
  else {
    ...
  }

  ldap
}

Also: I note you are setting "Auth-Type". This is almost always wrong, and almost certainly so in your case. Correct config of the LDAP module should mean you don't need to set Auth-Type, and it's usually harmful to do so. If it's not causing you a problem it's probably because you're using the "=" rather than ":=" operator.

Cheers,
Phil
-
List info/subscribe/unsubscribe? See http://www.freeradius.org/list/users.html

Reply via email to