mirror of
https://github.com/postgres/postgres.git
synced 2025-11-21 00:42:43 +03:00
Allow ldaps when using ldap authentication
While ldaptls=1 provides an RFC 4513 conforming way to do LDAP authentication with TLS encryption, there was an earlier de facto standard way to do LDAP over SSL called LDAPS. Even though it's not enshrined in a standard, it's still widely used and sometimes required by organizations' network policies. There seems to be no reason not to support it when available in the client library. Therefore, add support when using OpenLDAP 2.4+ or Windows. It can be configured with ldapscheme=ldaps or ldapurl=ldaps://... Add tests for both ways of requesting LDAPS and a test for the pre-existing ldaptls=1. Modify the 001_auth.pl test for "diagnostic messages", which was previously relying on the server rejecting ldaptls=1. Author: Thomas Munro Reviewed-By: Peter Eisentraut Discussion: https://postgr.es/m/CAEepm=1s+pA-LZUjQ-9GQz0Z4rX_eK=DFXAF1nBQ+ROPimuOYQ@mail.gmail.com
This commit is contained in:
@@ -2355,22 +2355,61 @@ static int errdetail_for_ldap(LDAP *ldap);
|
||||
static int
|
||||
InitializeLDAPConnection(Port *port, LDAP **ldap)
|
||||
{
|
||||
const char *scheme;
|
||||
int ldapversion = LDAP_VERSION3;
|
||||
int r;
|
||||
|
||||
*ldap = ldap_init(port->hba->ldapserver, port->hba->ldapport);
|
||||
scheme = port->hba->ldapscheme;
|
||||
if (scheme == NULL)
|
||||
scheme = "ldap";
|
||||
#ifdef WIN32
|
||||
*ldap = ldap_sslinit(port->hba->ldapserver,
|
||||
port->hba->ldapport,
|
||||
strcmp(scheme, "ldaps") == 0);
|
||||
if (!*ldap)
|
||||
{
|
||||
#ifndef WIN32
|
||||
ereport(LOG,
|
||||
(errmsg("could not initialize LDAP: %m")));
|
||||
#else
|
||||
ereport(LOG,
|
||||
(errmsg("could not initialize LDAP: error code %d",
|
||||
(int) LdapGetLastError())));
|
||||
#endif
|
||||
|
||||
return STATUS_ERROR;
|
||||
}
|
||||
#else
|
||||
#ifdef HAVE_LDAP_INITIALIZE
|
||||
{
|
||||
char *uri;
|
||||
|
||||
uri = psprintf("%s://%s:%d", scheme, port->hba->ldapserver,
|
||||
port->hba->ldapport);
|
||||
r = ldap_initialize(ldap, uri);
|
||||
pfree(uri);
|
||||
if (r != LDAP_SUCCESS)
|
||||
{
|
||||
ereport(LOG,
|
||||
(errmsg("could not initialize LDAP: %s",
|
||||
ldap_err2string(r))));
|
||||
|
||||
return STATUS_ERROR;
|
||||
}
|
||||
}
|
||||
#else
|
||||
if (strcmp(scheme, "ldaps") == 0)
|
||||
{
|
||||
ereport(LOG,
|
||||
(errmsg("ldaps not supported with this LDAP library")));
|
||||
|
||||
return STATUS_ERROR;
|
||||
}
|
||||
*ldap = ldap_init(port->hba->ldapserver, port->hba->ldapport);
|
||||
if (!*ldap)
|
||||
{
|
||||
ereport(LOG,
|
||||
(errmsg("could not initialize LDAP: %m")));
|
||||
|
||||
return STATUS_ERROR;
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
|
||||
if ((r = ldap_set_option(*ldap, LDAP_OPT_PROTOCOL_VERSION, &ldapversion)) != LDAP_SUCCESS)
|
||||
{
|
||||
@@ -2493,7 +2532,13 @@ CheckLDAPAuth(Port *port)
|
||||
}
|
||||
|
||||
if (port->hba->ldapport == 0)
|
||||
port->hba->ldapport = LDAP_PORT;
|
||||
{
|
||||
if (port->hba->ldapscheme != NULL &&
|
||||
strcmp(port->hba->ldapscheme, "ldaps") == 0)
|
||||
port->hba->ldapport = LDAPS_PORT;
|
||||
else
|
||||
port->hba->ldapport = LDAP_PORT;
|
||||
}
|
||||
|
||||
sendAuthRequest(port, AUTH_REQ_PASSWORD, NULL, 0);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user