diff options
author | NIIBE Yutaka <gniibe@fsij.org> | 2022-09-29 02:48:30 +0200 |
---|---|---|
committer | NIIBE Yutaka <gniibe@fsij.org> | 2022-09-29 02:48:30 +0200 |
commit | 4b2066afb4988c32a030330acf51b7b0dc190041 (patch) | |
tree | 7b6636341171b5e5e99388b41c3acdf489a720e7 /dirmngr/ks-engine-ldap.c | |
parent | dirmngr: Interrogate LDAP server when base DN specified. (diff) | |
download | gnupg2-4b2066afb4988c32a030330acf51b7b0dc190041.tar.xz gnupg2-4b2066afb4988c32a030330acf51b7b0dc190041.zip |
dirmngr: Change interrogate_ldap_dn for better memory semantics.
* dirmngr/ks-engine-ldap.c (interrogate_ldap_dn): Return BASEDN found,
memory allocated.
(my_ldap_connect): Follow the change, removing needless allocation.
--
GnuPG-bug-id: 6047
Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
Diffstat (limited to 'dirmngr/ks-engine-ldap.c')
-rw-r--r-- | dirmngr/ks-engine-ldap.c | 40 |
1 files changed, 12 insertions, 28 deletions
diff --git a/dirmngr/ks-engine-ldap.c b/dirmngr/ks-engine-ldap.c index fbbd5d6f1..fae2af5f8 100644 --- a/dirmngr/ks-engine-ldap.c +++ b/dirmngr/ks-engine-ldap.c @@ -288,10 +288,9 @@ keyspec_to_ldap_filter (const char *keyspec, char **filter, int only_exact, } -/* Returns 1 if R_BASEDDN is substituted, 0 if not. */ -static int +static char * interrogate_ldap_dn (LDAP *ldap_conn, const char *basedn_search, - unsigned int *r_serverinfo, char **r_basedn) + unsigned int *r_serverinfo) { int lerr; char **vals; @@ -349,19 +348,7 @@ interrogate_ldap_dn (LDAP *ldap_conn, const char *basedn_search, freed with ldap_msgfree() regardless of return value of these functions. */ ldap_msgfree (si_res); - if (r_basedn && basedn) - { - if (*r_basedn) - xfree (*r_basedn); - *r_basedn = basedn; - return 1; - } - else - { - if (basedn) - xfree (basedn); - return 0; - } + return basedn; } /* Connect to an LDAP server and interrogate it. @@ -654,23 +641,20 @@ my_ldap_connect (parsed_uri_t uri, LDAP **ldap_connp, { /* User specified base DN. In this case we know the server is a * real LDAP server. */ - basedn = xtrystrdup (basedn_arg); - if (!basedn) - { - err = gpg_error_from_syserror (); - goto out; - } + const char *user_basedn = basedn_arg; + *r_serverinfo |= SERVERINFO_REALLDAP; /* First try with provided basedn, else retry up one level. * Retry assumes that provided entry is for keyspace, * matching old behavior */ - if (!interrogate_ldap_dn (ldap_conn, basedn, r_serverinfo, &basedn)) + basedn = interrogate_ldap_dn (ldap_conn, user_basedn, r_serverinfo); + if (!basedn) { - const char *basedn_parent = strchr (basedn, ','); + const char *basedn_parent = strchr (user_basedn, ','); if (basedn_parent) - interrogate_ldap_dn (ldap_conn, basedn_parent + 1, r_serverinfo, - &basedn); + basedn = interrogate_ldap_dn (ldap_conn, basedn_parent + 1, + r_serverinfo); } } else @@ -701,8 +685,8 @@ my_ldap_connect (parsed_uri_t uri, LDAP **ldap_connp, *r_serverinfo |= SERVERINFO_REALLDAP; for (i = 0; context[i] && !basedn; i++) - interrogate_ldap_dn (ldap_conn, context[i], r_serverinfo, - &basedn); + basedn = interrogate_ldap_dn (ldap_conn, context[i], + r_serverinfo); ldap_value_free (context); } |