[tpop3d-discuss] Memory leak?

Marc Lewis marc at blarg.net
Thu, 9 May 2002 14:43:50 -0700


On Thu, May 09, 2002 at 09:14:03PM +0100, Chris Lightfoot wrote:
> On Thu, May 09, 2002 at 12:08:41PM -0700, Marc Lewis wrote:
> > On Thu, May 09, 2002 at 11:20:45AM +0100, Chris Lightfoot wrote:
>     [...]
> > > Cheers. I'll see if I can reproduce anything with my test
> > > OpenLDAP installation.
> > 
> > I'm very interested to hear your results.  
> 
> OK, I've discovered a few SNAFUs; the following patch
> ought to fix them:
[snip]
> 
> -- I could have sworn that the last documentation I read
> told me that I'd got this right before.

I'll test this out on a test setup and we'll see what happens.

> I can't comment on the PAM trouble you're having, except
> for my earlier snide comments about PAM itself. I shall
> try to dig out a more recent RedHat machine to test it
> on, but I can't see myself installing the PAM LDAP stuff.
> 
> You mentioned that you'd had some spurious failed
> authentications. What error message is logged in these
> cases?

After much grepping, I found this (IP/username removed):

May  8 18:50:32 floyd tpop3d[31919]: auth_ldap_new_user_pass: ldap_search_s: Can't contact LDAP server
May  8 18:50:32 floyd tpop3d[31919]: connection_do: client `[7]xxx.xxx.xxx.xxx/floyd.blarg.net': username `xxxxxx': 1 authentication failures

Looking through the code leads me here:

    /* Look for DN of user in the directory. */
    if ((ret = ldap_search_s(ldapinfo.ldap, ldapinfo.dn, LDAP_SCOPE_SUBTREE, filter, NULL, 0, &ldapres)) != LDAP_SUCCESS) {
        log_print(LOG_ERR, "auth_ldap_new_user_pass: ldap_search_s: %s", ldap_err2string(ret));
        goto fail;
    }

Shouldn't this also been in a "for (i = 0; i < 3; ++i) {" loop as well?
This particular error doesn't make a shole lot of sense to me since by the
time it gets to this point in the code, it should have already done a bind
to the server and have a connection.

In 5 hours, from 2pm (when I switched to LDAP authentication) until 7pm,
which I switched back to PAM.  There were 456 of these recorded, and about
16500 valid connections in that 5 hour period.


Thanks.

 - Marc


-- 
Marc Lewis
Network Administrator
Blarg! Online Services, Inc.
http://www.blarg.net/~marc