Anil wrote:
LDAP will return whatever the LDAP schema is defined as (for the
case), which is "uid".

I took out the pass_attrs, but didn't appear to be working.

I then added:
pass_attrs = uid

then, it was able to find the domain!

http://wiki.dovecot.org/AuthDatabase/LDAP
is a bit confusing in the documentation of pass_attrs.


IMO, pass_attrs_map is a better name, since its used for mapping
attributes from LDAP attributes to Dovecot names.

But, if "pass_attrs = uid" is working, what exactly is getting mapped to what?

I _think_ i was having a similar problem to you. I was trying to login with [EMAIL PROTECTED] and in the ldap directory i have the ou=people with uid=user. When i had

pass_attrs = uid

in the logs i saw

Jan 4 16:17:45 slayer dovecot: auth(default): master out: USER^I2^Iiain^Igid=XXX^Ihome=/home/iain^Iuid=XXXX Jan 4 16:17:45 slayer dovecot: imap-login: Login: user=<iain>, method=PLAIN, rip=X.X.X.X, lip=X.X.X.X, TLS Jan 4 16:17:45 slayer dovecot: IMAP(iain): Ambiguous mail location setting, don't know what to do with it: /opt/mail//iain/ (try prefixing it with mbox: or maildir:)


I changed this to be

pass_attrs = [EMAIL PROTECTED]

And now i see

Jan 4 17:11:11 slayer dovecot: auth(default): master out: [EMAIL PROTECTED]/home/iain^Iuid=XXXX Jan 4 17:11:11 slayer dovecot: imap-login: Login: user=<[EMAIL PROTECTED]>, method=PLAIN, rip=X.X.X.X, lip=X.X.X.X, TLS Jan 4 17:11:11 slayer dovecot: IMAP([EMAIL PROTECTED]): Ambiguous mail location setting, don't know what to do with it: /opt/mail/shihad.org/iain/ (try prefixing it with mbox: or maildir:)

Please note that the "ambiguous mail location setting" is because i was daft enough to have

mail_location: /opt/mail/%d/%n/

And changing this to

mail_location: maildir:/opt/mail/%d/%n/

sorted the problem :) Also IP's etc change to protect the guilty ;)


So basically my ldap settings are now

#user_attrs = homeDirectory=home,uidNumber=uid,gidNumber=gid
user_filter = (&(objectClass=posixAccount)(uid=%n))
pass_attrs = [EMAIL PROTECTED],userPassword=password
pass_filter = (&(objectClass=posixAccount)(uid=%n))

and this seems to return the information i want

So perhaps you could try

pass_attrs = [EMAIL PROTECTED]

Cheers

Iain






On Jan 4, 2008 4:04 PM, Timo Sirainen <[EMAIL PROTECTED]> wrote:
On Fri, 2008-01-04 at 08:12 -0800, Anil wrote:
pass_attrs = uid=user
pass_filter = uid=%n
uid=user makes Dovecot change the full username to uid's value, which
means it drops the domain. You could probably just leave pass_attrs
empty. I don't remember if LDAP lookups are case-insensitive though. If
they are, use %Ln and %Ld in your home and mail_location to avoid
getting "user" and "User" and "uSer" directories.



Reply via email to