passdb-ldap.c revision 9a3f0c5b641a14083e8383054ee5c32d17adda1c
/* Copyright (c) 2003-2010 Dovecot authors, see the included COPYING file */
#include "auth-common.h"
#include "passdb.h"
#include "ioloop.h"
#include "hash.h"
#include "str.h"
#include "var-expand.h"
#include "password-scheme.h"
#include "auth-cache.h"
#include "db-ldap.h"
#include <ldap.h>
#include <stdlib.h>
struct ldap_passdb_module {
struct passdb_module module;
struct ldap_connection *conn;
};
struct passdb_ldap_request {
union {
struct ldap_request ldap;
struct ldap_request_search search;
struct ldap_request_bind bind;
} request;
const char *dn;
union {
} callback;
unsigned int entries;
};
static void
{
struct db_ldap_result_iterate_context *ldap_iter;
}
}
static void
struct passdb_ldap_request *ldap_request,
{
enum passdb_result passdb_result;
int ret;
} else if (ldap_request->entries == 0) {
"unknown user");
"pass_filter matched multiple objects, aborting");
!auth_request->no_password) {
"No password returned (and no nopassword)");
} else {
/* passdb_password may change on the way,
so we'll need to strdup. */
}
/* auth_request_set_field() sets scheme */
} else {
}
}
}
static void
{
struct passdb_ldap_request *ldap_request =
(struct passdb_ldap_request *)request;
return;
}
if (ldap_request->entries++ == 0) {
/* first entry */
}
}
static void
{
struct passdb_ldap_request *passdb_ldap_request =
(struct passdb_ldap_request *)ldap_request;
enum passdb_result passdb_result;
const char *str;
int ret;
if (ret == LDAP_SUCCESS)
else if (ret == LDAP_INVALID_CREDENTIALS) {
str = "invalid credentials";
")", NULL);
}
} else {
"ldap_bind() failed: %s",
}
}
}
struct ldap_request_bind *brequest)
{
struct passdb_ldap_request *passdb_ldap_request =
(struct passdb_ldap_request *)brequest;
/* Assume that empty password fails. This is especially
important with Windows 2003 AD, which always returns success
with empty passwords. */
"Login attempt with empty password");
return;
}
}
static void
struct passdb_ldap_request *request,
{
enum passdb_result passdb_result;
"unknown user");
} else {
"pass_filter matched multiple objects, aborting");
}
} else {
}
}
struct ldap_request *ldap_request,
{
struct passdb_ldap_request *passdb_ldap_request =
(struct passdb_ldap_request *)ldap_request;
struct ldap_request_bind *brequest;
char *dn;
if (passdb_ldap_request->entries++ > 0) {
/* too many replies */
return;
}
/* first entry */
/* save dn */
/* failure */
} else {
/* convert search request to bind request */
}
}
struct passdb_ldap_request *request)
{
struct ldap_passdb_module *module =
(struct ldap_passdb_module *)_module;
const struct var_expand_table *vars;
str_truncate(str, 0);
"base=%s scope=%s filter=%s fields=%s",
}
struct passdb_ldap_request *request)
{
struct ldap_passdb_module *module =
(struct ldap_passdb_module *)_module;
const struct var_expand_table *vars;
str_truncate(str, 0);
/* we don't need the attributes to perform authentication, but they
may contain some extra parameters. if a password is returned,
it's just ignored. */
"bind search: base=%s filter=%s",
}
static void
struct passdb_ldap_request *request)
{
struct ldap_passdb_module *module =
(struct ldap_passdb_module *)_module;
const struct var_expand_table *vars;
}
static void
const char *password ATTR_UNUSED,
{
struct ldap_passdb_module *module =
(struct ldap_passdb_module *)_module;
struct passdb_ldap_request *ldap_request;
/* reconnect if needed. this is also done by db_ldap_search(), but
with auth binds we'll have to do it ourself */
if (db_ldap_connect(conn)< 0) {
return;
}
else
}
{
struct passdb_ldap_request *ldap_request;
}
static struct passdb_module *
{
struct ldap_passdb_module *module;
struct ldap_connection *conn;
}
{
struct ldap_passdb_module *module =
(struct ldap_passdb_module *)_module;
/* Credential lookups can't be done with authentication binds */
}
}
{
struct ldap_passdb_module *module =
(struct ldap_passdb_module *)_module;
}
#ifndef PLUGIN_BUILD
struct passdb_module_interface passdb_ldap =
#else
#endif
{
"ldap",
};
#else
struct passdb_module_interface passdb_ldap = {
.name = "ldap"
};
#endif