You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
73 lines
2.1 KiB
73 lines
2.1 KiB
6 months ago
|
From 840944e26f734bb03d925f26c4ef11a6cedcbb9c Mon Sep 17 00:00:00 2001
|
||
|
From: Howard Chu <hyc@openldap.org>
|
||
|
Date: Thu, 25 Aug 2022 16:13:21 +0100
|
||
|
Subject: [PATCH] ITS#9904 ldap_url_parsehosts: check for strdup failure
|
||
|
|
||
|
Avoid unnecessary strdup in IPv6 addr parsing, check for strdup
|
||
|
failure when dup'ing scheme.
|
||
|
|
||
|
Code present since 2000, 8da110a9e726dbc612b302feafe0109271e6bc59
|
||
|
---
|
||
|
libraries/libldap/url.c | 21 ++++++++++++---------
|
||
|
1 file changed, 12 insertions(+), 9 deletions(-)
|
||
|
|
||
|
diff --git a/libraries/libldap/url.c b/libraries/libldap/url.c
|
||
|
index dcf2aac9e8..493fd7ce47 100644
|
||
|
--- a/libraries/libldap/url.c
|
||
|
+++ b/libraries/libldap/url.c
|
||
|
@@ -1385,24 +1385,22 @@ ldap_url_parsehosts(
|
||
|
}
|
||
|
ludp->lud_port = port;
|
||
|
ludp->lud_host = specs[i];
|
||
|
- specs[i] = NULL;
|
||
|
p = strchr(ludp->lud_host, ':');
|
||
|
if (p != NULL) {
|
||
|
/* more than one :, IPv6 address */
|
||
|
if ( strchr(p+1, ':') != NULL ) {
|
||
|
/* allow [address] and [address]:port */
|
||
|
if ( *ludp->lud_host == '[' ) {
|
||
|
- p = LDAP_STRDUP(ludp->lud_host+1);
|
||
|
- /* copied, make sure we free source later */
|
||
|
- specs[i] = ludp->lud_host;
|
||
|
- ludp->lud_host = p;
|
||
|
- p = strchr( ludp->lud_host, ']' );
|
||
|
+ p = strchr( ludp->lud_host+1, ']' );
|
||
|
if ( p == NULL ) {
|
||
|
LDAP_FREE(ludp);
|
||
|
ldap_charray_free(specs);
|
||
|
return LDAP_PARAM_ERROR;
|
||
|
}
|
||
|
- *p++ = '\0';
|
||
|
+ /* Truncate trailing ']' and shift hostname down 1 char */
|
||
|
+ *p = '\0';
|
||
|
+ AC_MEMCPY( ludp->lud_host, ludp->lud_host+1, p - ludp->lud_host );
|
||
|
+ p++;
|
||
|
if ( *p != ':' ) {
|
||
|
if ( *p != '\0' ) {
|
||
|
LDAP_FREE(ludp);
|
||
|
@@ -1428,14 +1426,19 @@ ldap_url_parsehosts(
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
- ldap_pvt_hex_unescape(ludp->lud_host);
|
||
|
ludp->lud_scheme = LDAP_STRDUP("ldap");
|
||
|
+ if ( ludp->lud_scheme == NULL ) {
|
||
|
+ LDAP_FREE(ludp);
|
||
|
+ ldap_charray_free(specs);
|
||
|
+ return LDAP_NO_MEMORY;
|
||
|
+ }
|
||
|
+ specs[i] = NULL;
|
||
|
+ ldap_pvt_hex_unescape(ludp->lud_host);
|
||
|
ludp->lud_next = *ludlist;
|
||
|
*ludlist = ludp;
|
||
|
}
|
||
|
|
||
|
/* this should be an array of NULLs now */
|
||
|
- /* except entries starting with [ */
|
||
|
ldap_charray_free(specs);
|
||
|
return LDAP_SUCCESS;
|
||
|
}
|
||
|
--
|
||
|
2.44.0
|
||
|
|