summaryrefslogtreecommitdiff
path: root/source4/ldap_server/ldap_bind.c
diff options
context:
space:
mode:
authorAndrew Bartlett <abartlet@samba.org>2006-07-04 03:32:39 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 14:09:46 -0500
commit9da5d4fd69d1e3a0c3129a41d185abcb1744d8be (patch)
tree3a44a74b3462e15883b4446b483ae61d937198d4 /source4/ldap_server/ldap_bind.c
parent3c9281f0148c7aa9dfe7d4fd2184e749604321b6 (diff)
downloadsamba-9da5d4fd69d1e3a0c3129a41d185abcb1744d8be.tar.gz
samba-9da5d4fd69d1e3a0c3129a41d185abcb1744d8be.tar.bz2
samba-9da5d4fd69d1e3a0c3129a41d185abcb1744d8be.zip
r16795: Fix crash found by Dave Fenwick <djf@samba.org>.
The session_info was not being attached to the connection, so subsequent checks in the kludge_acl module were looking at free()ed memory. Andrew Bartlett (This used to be commit 7e9079ac7af0bcd5d22040c7418cf58f86a72a1d)
Diffstat (limited to 'source4/ldap_server/ldap_bind.c')
-rw-r--r--source4/ldap_server/ldap_bind.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/source4/ldap_server/ldap_bind.c b/source4/ldap_server/ldap_bind.c
index 5341b9f741..35b6ad5fbf 100644
--- a/source4/ldap_server/ldap_bind.c
+++ b/source4/ldap_server/ldap_bind.c
@@ -60,6 +60,7 @@ static NTSTATUS ldapsrv_BindSimple(struct ldapsrv_call *call)
talloc_free(call->conn->session_info);
call->conn->session_info = session_info;
+ talloc_steal(call->conn, session_info);
/* don't leak the old LDB */
talloc_free(call->conn->ldb);
@@ -187,6 +188,7 @@ static NTSTATUS ldapsrv_BindSASL(struct ldapsrv_call *call)
errstr = talloc_asprintf(reply, "SASL:[%s]: Failed to get session info: %s", req->creds.SASL.mechanism, nt_errstr(status));
} else {
talloc_free(old_session_info);
+ talloc_steal(conn, conn->session_info);
/* don't leak the old LDB */
talloc_free(conn->ldb);