passdb.c revision 517d1e7142d57299c733b30423e35e7e1f8d01d6
/* Copyright (C) 2002-2003 Timo Sirainen */
#include "common.h"
#include "auth-module.h"
#include "password-scheme.h"
#include "passdb.h"
#include "passdb-cache.h"
#include <stdlib.h>
#ifdef HAVE_MODULES
#endif
struct passdb_module *passdbs[] = {
#ifdef PASSDB_PASSWD
#endif
#ifdef PASSDB_BSDAUTH
#endif
#ifdef PASSDB_PASSWD_FILE
#endif
#ifdef PASSDB_PAM
#endif
#ifdef PASSDB_CHECKPASSWORD
#endif
#ifdef PASSDB_SHADOW
#endif
#ifdef PASSDB_VPOPMAIL
#endif
#ifdef PASSDB_LDAP
#endif
#ifdef PASSDB_SQL
#endif
};
struct passdb_module *passdb;
static char *passdb_args;
static const char *
{
switch (credentials) {
break;
return "PLAIN";
case PASSDB_CREDENTIALS_CRYPT:
return "CRYPT";
return "HMAC-MD5";
return "DIGEST-MD5";
return "LANMAN";
case PASSDB_CREDENTIALS_NTLM:
return "NTLM";
case PASSDB_CREDENTIALS_RPA:
return "RPA";
}
return "??";
}
struct auth_request *auth_request)
{
const char *wanted_scheme;
if (result != PASSDB_RESULT_OK) {
return;
}
if (credentials == PASSDB_CREDENTIALS_CRYPT) {
/* anything goes */
return;
}
if (verbose) {
i_info("password(%s): Requested %s "
"scheme, but we have only %s",
}
NULL, auth_request);
return;
}
/* we can generate anything out of plaintext passwords */
}
}
void passdb_preinit(void)
{
struct passdb_module **p;
i_fatal("PASSDB environment is unset");
args++;
passdb = *p;
break;
}
}
#ifdef HAVE_MODULES
if (passdb_module != NULL) {
}
#endif
}
void passdb_init(void)
{
}
void passdb_deinit(void)
{
#ifdef HAVE_MODULES
if (passdb_module != NULL)
#endif
}