1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-03 12:11:33 +01:00

dirmngr: New server flag "areconly" (A-record-only)

* dirmngr/dirmngr.h (struct ldap_server_s): Add field areconly.
* dirmngr/ldapserver.c (ldapserver_parse_one): Parse "areconly"
* dirmngr/ks-engine-ldap.c (my_ldap_connect): Implement this flag.
* dirmngr/dirmngr_ldap.c: Add option --areconly
(connect_ldap): Implement option.
* dirmngr/ldap.c (run_ldap_wrapper): Add and pass that option.
--

This flag is used to pass the Windows specific option
LDAP_OPT_AREC_EXCLUSIVE.  It is ignored on other systems.

Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
Werner Koch 2022-09-28 09:43:25 +02:00
parent 05b7e4a405
commit 6300035ba1
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B
6 changed files with 51 additions and 3 deletions

View File

@ -54,6 +54,7 @@ struct ldap_server_s
unsigned int starttls:1; /* Use STARTTLS. */ unsigned int starttls:1; /* Use STARTTLS. */
unsigned int ldap_over_tls:1; /* Use LDAP over an TLS tunnel */ unsigned int ldap_over_tls:1; /* Use LDAP over an TLS tunnel */
unsigned int ntds:1; /* Use Active Directory authentication. */ unsigned int ntds:1; /* Use Active Directory authentication. */
unsigned int areconly:1; /* Set LDAP_OPT_AREC_EXCLUSIVE. */
}; };
typedef struct ldap_server_s *ldap_server_t; typedef struct ldap_server_s *ldap_server_t;

View File

@ -92,6 +92,7 @@ enum
oStartTLS, oStartTLS,
oLdapTLS, oLdapTLS,
oNtds, oNtds,
oARecOnly,
oOnlySearchTimeout, oOnlySearchTimeout,
oLogWithPID oLogWithPID
@ -110,6 +111,7 @@ static ARGPARSE_OPTS opts[] = {
{ oStartTLS, "starttls", 0, "use STARTLS for the conenction"}, { oStartTLS, "starttls", 0, "use STARTLS for the conenction"},
{ oLdapTLS, "ldaptls", 0, "use a TLS for the connection"}, { oLdapTLS, "ldaptls", 0, "use a TLS for the connection"},
{ oNtds, "ntds", 0, "authenticate using AD"}, { oNtds, "ntds", 0, "authenticate using AD"},
{ oARecOnly, "areconly", 0, "do only an A record lookup"},
{ oHost, "host", 2, "|NAME|connect to host NAME"}, { oHost, "host", 2, "|NAME|connect to host NAME"},
{ oPort, "port", 1, "|N|connect to port N"}, { oPort, "port", 1, "|N|connect to port N"},
{ oUser, "user", 2, "|NAME|use NAME for authentication"}, { oUser, "user", 2, "|NAME|use NAME for authentication"},
@ -135,6 +137,7 @@ static struct
int starttls; int starttls;
int ldaptls; int ldaptls;
int ntds; int ntds;
int areconly;
estream_t outstream; /* Send output to this stream. */ estream_t outstream; /* Send output to this stream. */
@ -235,6 +238,7 @@ main (int argc, char **argv)
case oStartTLS: opt.starttls = 1; opt.ldaptls = 0; break; case oStartTLS: opt.starttls = 1; opt.ldaptls = 0; break;
case oLdapTLS: opt.starttls = 0; opt.ldaptls = 1; break; case oLdapTLS: opt.starttls = 0; opt.ldaptls = 1; break;
case oNtds: opt.ntds = 1; break; case oNtds: opt.ntds = 1; break;
case oARecOnly: opt.areconly = 1; break;
case oMulti: opt.multi = 1; break; case oMulti: opt.multi = 1; break;
case oUser: opt.user = pargs.r.ret_str; break; case oUser: opt.user = pargs.r.ret_str; break;
case oPass: opt.pass = pargs.r.ret_str; break; case oPass: opt.pass = pargs.r.ret_str; break;
@ -437,6 +441,17 @@ connect_ldap (LDAP **r_ld)
opt.host, opt.port, ldap_err2string (lerr)); opt.host, opt.port, ldap_err2string (lerr));
goto leave; goto leave;
} }
if (opt.areconly)
{
lerr = ldap_set_option (ld, LDAP_OPT_AREC_EXCLUSIVE, LDAP_OPT_ON);
if (lerr != LDAP_SUCCESS)
{
log_error ("ldap: unable to set AREC_EXLUSIVE: %s\n",
ldap_err2string (lerr));
err = ldap_err_to_gpg_err (lerr);
goto leave;
}
}
#else /* Unix */ #else /* Unix */
tmpstr = xtryasprintf ("%s://%s:%d", tmpstr = xtryasprintf ("%s://%s:%d",
opt.ldaptls? "ldaps" : "ldap", opt.ldaptls? "ldaps" : "ldap",

View File

@ -338,6 +338,7 @@ my_ldap_connect (parsed_uri_t uri, LDAP **ldap_connp,
int port; /* Port to use. */ int port; /* Port to use. */
int use_tls; /* 1 = starttls, 2 = ldap-over-tls */ int use_tls; /* 1 = starttls, 2 = ldap-over-tls */
int use_ntds; /* Use Active Directory authentication. */ int use_ntds; /* Use Active Directory authentication. */
int use_areconly; /* Lookup only via A record (Windows). */
const char *bindname; const char *bindname;
const char *password; const char *password;
const char *basedn_arg; const char *basedn_arg;
@ -365,6 +366,7 @@ my_ldap_connect (parsed_uri_t uri, LDAP **ldap_connp,
basedn_arg = server->base; basedn_arg = server->base;
use_tls = server->starttls? 1 : server->ldap_over_tls? 2 : 0; use_tls = server->starttls? 1 : server->ldap_over_tls? 2 : 0;
use_ntds = server->ntds; use_ntds = server->ntds;
use_areconly = server->areconly;
} }
else else
{ {
@ -375,6 +377,7 @@ my_ldap_connect (parsed_uri_t uri, LDAP **ldap_connp,
basedn_arg = uri->path; basedn_arg = uri->path;
use_tls = uri->use_tls ? 1 : 0; use_tls = uri->use_tls ? 1 : 0;
use_ntds = uri->ad_current; use_ntds = uri->ad_current;
use_areconly = 0;
} }
if (!port) if (!port)
@ -392,13 +395,14 @@ my_ldap_connect (parsed_uri_t uri, LDAP **ldap_connp,
} }
if (opt.verbose) if (opt.verbose)
log_info ("ldap connect to '%s:%d:%s:%s:%s:%s%s'\n", log_info ("ldap connect to '%s:%d:%s:%s:%s:%s%s%s'\n",
host, port, host, port,
basedn_arg ? basedn_arg : "", basedn_arg ? basedn_arg : "",
bindname ? bindname : "", bindname ? bindname : "",
password ? "*****" : "", password ? "*****" : "",
use_tls == 1? "starttls" : use_tls == 2? "ldaptls" : "plain", use_tls == 1? "starttls" : use_tls == 2? "ldaptls" : "plain",
use_ntds ? ",ntds":""); use_ntds ? ",ntds":"",
use_areconly? ",areconly":"");
/* If the uri specifies a secure connection and we don't support /* If the uri specifies a secure connection and we don't support
@ -427,6 +431,18 @@ my_ldap_connect (parsed_uri_t uri, LDAP **ldap_connp,
host, port, ldap_err2string (lerr)); host, port, ldap_err2string (lerr));
goto out; goto out;
} }
if (use_areconly)
{
lerr = ldap_set_option (ldap_conn, LDAP_OPT_AREC_EXCLUSIVE, LDAP_OPT_ON);
if (lerr != LDAP_SUCCESS)
{
log_error ("ks-ldap: unable to set LDAP_OPT_AREC_EXLUSIVE: %s\n",
ldap_err2string (lerr));
err = ldap_err_to_gpg_err (lerr);
goto out;
}
}
#else /* Unix */ #else /* Unix */
tmpstr = xtryasprintf ("%s://%s:%d", tmpstr = xtryasprintf ("%s://%s:%d",
use_tls == 2? "ldaps" : "ldap", use_tls == 2? "ldaps" : "ldap",

View File

@ -119,13 +119,14 @@ run_ldap_wrapper (ctrl_t ctrl,
int multi_mode, int multi_mode,
int tls_mode, int tls_mode,
int ntds, int ntds,
int areconly,
const char *proxy, const char *proxy,
const char *host, int port, const char *host, int port,
const char *user, const char *pass, const char *user, const char *pass,
const char *base, const char *filter, const char *attr, const char *base, const char *filter, const char *attr,
ksba_reader_t *reader) ksba_reader_t *reader)
{ {
const char *argv[50]; const char *argv[51];
int argc; int argc;
char portbuf[30], timeoutbuf[30]; char portbuf[30], timeoutbuf[30];
@ -156,6 +157,9 @@ run_ldap_wrapper (ctrl_t ctrl,
if (ntds) if (ntds)
argv[argc++] = "--ntds"; argv[argc++] = "--ntds";
if (areconly)
argv[argc++] = "--areconly";
if (opt.ldaptimeout) if (opt.ldaptimeout)
{ {
snprintf (timeoutbuf, sizeof timeoutbuf, "%u", opt.ldaptimeout); snprintf (timeoutbuf, sizeof timeoutbuf, "%u", opt.ldaptimeout);
@ -246,6 +250,7 @@ url_fetch_ldap (ctrl_t ctrl, const char *url, ksba_reader_t *reader)
0, /* No Multi-mode. */ 0, /* No Multi-mode. */
tls_mode, tls_mode,
0, /* No AD authentication. */ 0, /* No AD authentication. */
0, /* No areconly. */
opt.ldap_proxy, opt.ldap_proxy,
ludp->lud_host, ludp->lud_port, ludp->lud_host, ludp->lud_port,
NULL, NULL, /* user, password */ NULL, NULL, /* user, password */
@ -292,6 +297,7 @@ url_fetch_ldap (ctrl_t ctrl, const char *url, ksba_reader_t *reader)
0, /* No Multi-mode */ 0, /* No Multi-mode */
tls_mode, tls_mode,
server->ntds, server->ntds,
server->areconly,
NULL, NULL,
server->host, server->port, server->host, server->port,
server->user, server->pass, server->user, server->pass,
@ -342,6 +348,7 @@ attr_fetch_ldap (ctrl_t ctrl,
0, 0,
tls_mode, tls_mode,
server->ntds, server->ntds,
server->areconly,
opt.ldap_proxy, opt.ldap_proxy,
server->host, server->port, server->host, server->port,
server->user, server->pass, server->user, server->pass,
@ -609,6 +616,7 @@ start_cacert_fetch_ldap (ctrl_t ctrl, cert_fetch_context_t *r_context,
1, /* --multi (record format) */ 1, /* --multi (record format) */
0, /* No TLS */ 0, /* No TLS */
0, /* No AD authentication. */ 0, /* No AD authentication. */
server->areconly,
opt.ldap_proxy, opt.ldap_proxy,
server->host, server->port, server->host, server->port,
server->user, server->pass, server->user, server->pass,

View File

@ -64,6 +64,7 @@ ldapserver_list_free (ldap_server_t servers)
plain := Switch to plain unsecured LDAP. plain := Switch to plain unsecured LDAP.
(The last of these 3 flags is the effective one) (The last of these 3 flags is the effective one)
ntds := Use Active Directory authentication ntds := Use Active Directory authentication
areconly := Use option LDAP_OPT_AREC_EXCLUSIVE
FILENAME and LINENO are used for diagnostic purposes only. FILENAME and LINENO are used for diagnostic purposes only.
*/ */
@ -175,6 +176,10 @@ ldapserver_parse_one (char *line,
{ {
server->ntds = 1; server->ntds = 1;
} }
else if (!ascii_strcasecmp (s, "areconly"))
{
server->areconly = 1;
}
else else
{ {
if (filename) if (filename)

View File

@ -485,6 +485,9 @@ Tunnel LDAP through a TLS connection; the default port is 636.
@item ntds @item ntds
On Windows authenticate the LDAP connection using the Active Directory On Windows authenticate the LDAP connection using the Active Directory
with the current user. with the current user.
@item areconly
On Windows use only the A or AAAA record when resolving the LDAP
server name.
@end table @end table
Note that in an URL style specification the scheme @code{ldaps://} Note that in an URL style specification the scheme @code{ldaps://}