|
Adam Tkac |
45783c |
--- bind-9.4.1/contrib/sdb/ldap/ldapdb.c.new-api 2004-08-27 02:10:25.000000000 +0200
|
|
Adam Tkac |
af78c8 |
+++ bind-9.4.1/contrib/sdb/ldap/ldapdb.c 2007-05-22 16:50:16.000000000 +0200
|
|
Adam Tkac |
45783c |
@@ -58,9 +58,13 @@
|
|
Adam Tkac |
45783c |
static dns_sdbimplementation_t *ldapdb = NULL;
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
struct ldapdb_data {
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION >= 3001
|
|
Adam Tkac |
45783c |
+ LDAPURLDesc *lud;
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
char *hostport;
|
|
Adam Tkac |
45783c |
char *hostname;
|
|
Adam Tkac |
45783c |
int portno;
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
char *base;
|
|
Adam Tkac |
45783c |
int defaultttl;
|
|
Adam Tkac |
45783c |
char *filterall;
|
|
Adam Tkac |
45783c |
@@ -135,7 +139,11 @@ ldapdb_getconn(struct ldapdb_data *data)
|
|
Adam Tkac |
45783c |
conndata = threaddata->data;
|
|
Adam Tkac |
45783c |
free(conndata->index);
|
|
Adam Tkac |
45783c |
if (conndata->data != NULL)
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
ldap_unbind((LDAP *)conndata->data);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ ldap_unbind_ext((LDAP *)conndata->data, NULL, NULL);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
threaddata->data = conndata->next;
|
|
Adam Tkac |
45783c |
free(conndata);
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
af78c8 |
@@ -172,14 +180,23 @@ ldapdb_getconn(struct ldapdb_data *data)
|
|
Adam Tkac |
45783c |
/* threaddata points at the connection list for current thread */
|
|
Adam Tkac |
45783c |
/* look for existing connection to our server */
|
|
Adam Tkac |
45783c |
conndata = ldapdb_find((struct ldapdb_entry *)threaddata->data,
|
|
Adam Tkac |
45783c |
- data->hostport, strlen(data->hostport));
|
|
Adam Tkac |
af78c8 |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
af78c8 |
+ data->hostport, strlen(data->hostport));
|
|
Adam Tkac |
af78c8 |
+#else
|
|
Adam Tkac |
af78c8 |
+ data->lud->lud_host, strlen(data->lud->lud_host));
|
|
Adam Tkac |
af78c8 |
+#endif
|
|
Adam Tkac |
45783c |
if (conndata == NULL) {
|
|
Adam Tkac |
45783c |
/* no connection data structure for this server, create one */
|
|
Adam Tkac |
45783c |
conndata = malloc(sizeof(*conndata));
|
|
Adam Tkac |
45783c |
if (conndata == NULL)
|
|
Adam Tkac |
45783c |
return (NULL);
|
|
Adam Tkac |
af78c8 |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
af78c8 |
conndata->index = data->hostport;
|
|
Adam Tkac |
af78c8 |
conndata->size = strlen(data->hostport);
|
|
Adam Tkac |
af78c8 |
+#else
|
|
Adam Tkac |
45783c |
+ conndata->index = data->lud->lud_host;
|
|
Adam Tkac |
45783c |
+ conndata->size = strlen(data->lud->lud_host);
|
|
Adam Tkac |
af78c8 |
+#endif
|
|
Adam Tkac |
45783c |
conndata->data = NULL;
|
|
Adam Tkac |
45783c |
ldapdb_insert((struct ldapdb_entry **)&threaddata->data,
|
|
Adam Tkac |
45783c |
conndata);
|
|
Adam Tkac |
af78c8 |
@@ -196,9 +213,15 @@ ldapdb_bind(struct ldapdb_data *data, LD
|
|
Adam Tkac |
45783c |
#endif
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
if (*ldp != NULL)
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
ldap_unbind(*ldp);
|
|
Adam Tkac |
45783c |
*ldp = ldap_open(data->hostname, data->portno);
|
|
Adam Tkac |
45783c |
if (*ldp == NULL)
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ ldap_unbind_ext (*ldp, NULL, NULL);
|
|
Adam Tkac |
45783c |
+ int res = ldap_initialize(ldp, ldap_url_desc2str(data->lud));
|
|
Adam Tkac |
45783c |
+ if (res != LDAP_SUCCESS)
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
return;
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
#ifndef LDAPDB_RFC1823API
|
|
Adam Tkac |
af78c8 |
@@ -211,8 +234,17 @@ ldapdb_bind(struct ldapdb_data *data, LD
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
#endif
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
if (ldap_simple_bind_s(*ldp, data->bindname, data->bindpw) != LDAP_SUCCESS) {
|
|
Adam Tkac |
45783c |
ldap_unbind(*ldp);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ struct berval ber;
|
|
Adam Tkac |
45783c |
+ ber.bv_val = data->bindpw;
|
|
Adam Tkac |
45783c |
+ ber.bv_len = (data->bindpw == NULL) ? 0 : strlen(data->bindpw);
|
|
Adam Tkac |
45783c |
+
|
|
Adam Tkac |
45783c |
+ if (ldap_sasl_bind_s(*ldp, data->base, LDAP_SASL_SIMPLE, &ber, NULL, NULL, NULL) != LDAP_SUCCESS) {
|
|
Adam Tkac |
45783c |
+ ldap_unbind_ext(*ldp, NULL, NULL);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
*ldp = NULL;
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
af78c8 |
@@ -224,14 +256,19 @@ ldapdb_search(const char *zone, const ch
|
|
Adam Tkac |
45783c |
isc_result_t result = ISC_R_NOTFOUND;
|
|
Adam Tkac |
45783c |
LDAP **ldp;
|
|
Adam Tkac |
45783c |
LDAPMessage *res, *e;
|
|
Adam Tkac |
45783c |
- char *fltr, *a, **vals = NULL, **names = NULL;
|
|
Adam Tkac |
45783c |
+ char *fltr, *a;
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
+ char **names, **vals;
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ struct berval **names, **vals;
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
char type[64];
|
|
Adam Tkac |
45783c |
#ifdef LDAPDB_RFC1823API
|
|
Adam Tkac |
45783c |
void *ptr;
|
|
Adam Tkac |
45783c |
#else
|
|
Adam Tkac |
45783c |
BerElement *ptr;
|
|
Adam Tkac |
45783c |
#endif
|
|
Adam Tkac |
45783c |
- int i, j, errno, msgid;
|
|
Adam Tkac |
45783c |
+ int i, j, errno, msgid, ldap_res;
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
ldp = ldapdb_getconn(data);
|
|
Adam Tkac |
45783c |
if (ldp == NULL)
|
|
Adam Tkac |
af78c8 |
@@ -256,12 +293,21 @@ ldapdb_search(const char *zone, const ch
|
|
Adam Tkac |
45783c |
sprintf(data->filtername, "%s))", name);
|
|
Adam Tkac |
45783c |
fltr = data->filterone;
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
-
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
msgid = ldap_search(*ldp, data->base, LDAP_SCOPE_SUBTREE, fltr, NULL, 0);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ ldap_res = ldap_search_ext(*ldp, data->base, LDAP_SCOPE_SUBTREE, fltr, NULL, 0,
|
|
Adam Tkac |
45783c |
+ NULL, NULL, NULL, 65535, &msgid);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
if (msgid == -1) {
|
|
Adam Tkac |
45783c |
ldapdb_bind(data, ldp);
|
|
Adam Tkac |
45783c |
if (*ldp != NULL)
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
msgid = ldap_search(*ldp, data->base, LDAP_SCOPE_SUBTREE, fltr, NULL, 0);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ ldap_res = ldap_search_ext(*ldp, data->base, LDAP_SCOPE_SUBTREE, fltr, NULL, 0,
|
|
Adam Tkac |
45783c |
+ NULL, NULL, NULL, 65535, &msgid);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
if (*ldp == NULL || msgid == -1) {
|
|
Adam Tkac |
af78c8 |
@@ -293,15 +339,27 @@ ldapdb_search(const char *zone, const ch
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
if (name == NULL) {
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
names = ldap_get_values(ld, e, "relativeDomainName");
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ names = ldap_get_values_len(ld, e, "relativeDomainName");
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
if (names == NULL)
|
|
Adam Tkac |
45783c |
continue;
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
-
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
vals = ldap_get_values(ld, e, "dNSTTL");
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ vals = ldap_get_values_len(ld, e, "dNSTTL");
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
if (vals != NULL) {
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
ttl = atoi(vals[0]);
|
|
Adam Tkac |
45783c |
ldap_value_free(vals);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ ttl = atoi(vals[0]->bv_val);
|
|
Adam Tkac |
45783c |
+ ldap_value_free_len(vals);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
for (a = ldap_first_attribute(ld, e, &ptr); a != NULL; a = ldap_next_attribute(ld, e, ptr)) {
|
|
Adam Tkac |
af78c8 |
@@ -319,34 +377,60 @@ ldapdb_search(const char *zone, const ch
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
strncpy(type, a, s - a);
|
|
Adam Tkac |
45783c |
type[s - a] = '\0';
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
vals = ldap_get_values(ld, e, a);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ vals = ldap_get_values_len(ld, e, a);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
if (vals != NULL) {
|
|
Adam Tkac |
45783c |
for (i = 0; vals[i] != NULL; i++) {
|
|
Adam Tkac |
45783c |
if (name != NULL) {
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
result = dns_sdb_putrr(retdata, type, ttl, vals[i]);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ result = dns_sdb_putrr(retdata, type, ttl, vals[i]->bv_val);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
} else {
|
|
Adam Tkac |
45783c |
for (j = 0; names[j] != NULL; j++) {
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
result = dns_sdb_putnamedrr(retdata, names[j], type, ttl, vals[i]);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ result = dns_sdb_putnamedrr(retdata, names[j]->bv_val, type, ttl, vals[i]->bv_val);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
if (result != ISC_R_SUCCESS)
|
|
Adam Tkac |
45783c |
break;
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
-; if (result != ISC_R_SUCCESS) {
|
|
Adam Tkac |
45783c |
+ if (result != ISC_R_SUCCESS) {
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
isc_log_write(ns_g_lctx, NS_LOGCATEGORY_GENERAL, NS_LOGMODULE_SERVER, ISC_LOG_ERROR,
|
|
Adam Tkac |
45783c |
"LDAP sdb zone '%s': dns_sdb_put... failed for %s", zone, vals[i]);
|
|
Adam Tkac |
45783c |
ldap_value_free(vals);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ isc_log_write(ns_g_lctx, NS_LOGCATEGORY_GENERAL, NS_LOGMODULE_SERVER, ISC_LOG_ERROR,
|
|
Adam Tkac |
45783c |
+ "LDAP sdb zone '%s': dns_sdb_put... failed for %s", zone, vals[i]->bv_val);
|
|
Adam Tkac |
45783c |
+ ldap_value_free_len(vals);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
#ifndef LDAPDB_RFC1823API
|
|
Adam Tkac |
45783c |
ldap_memfree(a);
|
|
Adam Tkac |
45783c |
if (ptr != NULL)
|
|
Adam Tkac |
45783c |
ber_free(ptr, 0);
|
|
Adam Tkac |
45783c |
#endif
|
|
Adam Tkac |
45783c |
if (name == NULL)
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
ldap_value_free(names);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ ldap_value_free_len(names);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
ldap_msgfree(res);
|
|
Adam Tkac |
45783c |
return (ISC_R_FAILURE);
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
ldap_value_free(vals);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ ldap_value_free_len(vals);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
#ifndef LDAPDB_RFC1823API
|
|
Adam Tkac |
45783c |
ldap_memfree(a);
|
|
Adam Tkac |
af78c8 |
@@ -357,7 +441,11 @@ ldapdb_search(const char *zone, const ch
|
|
Adam Tkac |
45783c |
ber_free(ptr, 0);
|
|
Adam Tkac |
45783c |
#endif
|
|
Adam Tkac |
45783c |
if (name == NULL)
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
ldap_value_free(names);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ ldap_value_free_len(names);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
/* free this result */
|
|
Adam Tkac |
45783c |
ldap_msgfree(res);
|
|
Adam Tkac |
af78c8 |
@@ -460,10 +548,15 @@ parseextensions(char *extensions, struct
|
|
Adam Tkac |
45783c |
static void
|
|
Adam Tkac |
45783c |
free_data(struct ldapdb_data *data)
|
|
Adam Tkac |
45783c |
{
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
if (data->hostport != NULL)
|
|
Adam Tkac |
45783c |
isc_mem_free(ns_g_mctx, data->hostport);
|
|
Adam Tkac |
45783c |
if (data->hostname != NULL)
|
|
Adam Tkac |
45783c |
isc_mem_free(ns_g_mctx, data->hostname);
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ if (data->lud != NULL)
|
|
Adam Tkac |
45783c |
+ ldap_free_urldesc(data->lud);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
if (data->filterall != NULL)
|
|
Adam Tkac |
45783c |
isc_mem_put(ns_g_mctx, data->filterall, data->filteralllen);
|
|
Adam Tkac |
45783c |
if (data->filterone != NULL)
|
|
Adam Tkac |
af78c8 |
@@ -478,7 +571,7 @@ ldapdb_create(const char *zone, int argc
|
|
Adam Tkac |
45783c |
{
|
|
Adam Tkac |
45783c |
struct ldapdb_data *data;
|
|
Adam Tkac |
45783c |
char *s, *filter = NULL, *extensions = NULL;
|
|
Adam Tkac |
45783c |
- int defaultttl;
|
|
Adam Tkac |
45783c |
+ int defaultttl, i;
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
UNUSED(driverdata);
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
af78c8 |
@@ -486,7 +579,10 @@ ldapdb_create(const char *zone, int argc
|
|
Adam Tkac |
45783c |
/* want to do this only once for all instances */
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
if ((argc < 2)
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
+ /* Could be ldap[is]:// */
|
|
Adam Tkac |
45783c |
|| (argv[0] != strstr( argv[0], "ldap://"))
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
|| ((defaultttl = atoi(argv[1])) < 1))
|
|
Adam Tkac |
45783c |
return (ISC_R_FAILURE);
|
|
Adam Tkac |
45783c |
data = isc_mem_get(ns_g_mctx, sizeof(struct ldapdb_data));
|
|
Adam Tkac |
af78c8 |
@@ -494,14 +590,15 @@ ldapdb_create(const char *zone, int argc
|
|
Adam Tkac |
45783c |
return (ISC_R_NOMEMORY);
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
memset(data, 0, sizeof(struct ldapdb_data));
|
|
Adam Tkac |
45783c |
+
|
|
Adam Tkac |
45783c |
+ data->defaultttl = defaultttl;
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
data->hostport = isc_mem_strdup(ns_g_mctx, argv[0] + strlen("ldap://"));
|
|
Adam Tkac |
45783c |
if (data->hostport == NULL) {
|
|
Adam Tkac |
45783c |
free_data(data);
|
|
Adam Tkac |
45783c |
return (ISC_R_NOMEMORY);
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
- data->defaultttl = defaultttl;
|
|
Adam Tkac |
45783c |
-
|
|
Adam Tkac |
45783c |
s = strchr(data->hostport, '/');
|
|
Adam Tkac |
45783c |
if (s != NULL) {
|
|
Adam Tkac |
45783c |
*s++ = '\0';
|
|
Adam Tkac |
af78c8 |
@@ -544,11 +641,26 @@ ldapdb_create(const char *zone, int argc
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
+ if (ldap_url_parse (argv[0], &data->lud) != LDAP_URL_SUCCESS) {
|
|
Adam Tkac |
45783c |
+ free_data (data);
|
|
Adam Tkac |
45783c |
+ return (ISC_R_FAILURE);
|
|
Adam Tkac |
45783c |
+ }
|
|
Adam Tkac |
45783c |
+
|
|
Adam Tkac |
45783c |
+ data->base = data->lud->lud_dn;
|
|
Adam Tkac |
45783c |
+
|
|
Adam Tkac |
45783c |
+ for (i = 0; data->lud->lud_exts[i] != NULL; i++) {
|
|
Adam Tkac |
45783c |
+ extensions = strdup (data->lud->lud_exts[i]);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
+
|
|
Adam Tkac |
45783c |
/* parse extensions */
|
|
Adam Tkac |
45783c |
if (extensions != NULL) {
|
|
Adam Tkac |
45783c |
int err;
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
err = parseextensions(extensions, data);
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION >= 3001
|
|
Adam Tkac |
45783c |
+ free (extensions);
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
if (err < 0) {
|
|
Adam Tkac |
45783c |
/* err should be -1 or -2 */
|
|
Adam Tkac |
45783c |
free_data(data);
|
|
Adam Tkac |
af78c8 |
@@ -562,6 +674,14 @@ ldapdb_create(const char *zone, int argc
|
|
Adam Tkac |
45783c |
return (ISC_R_FAILURE);
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION >= 3001
|
|
Adam Tkac |
45783c |
+ else {
|
|
Adam Tkac |
45783c |
+ free_data (data);
|
|
Adam Tkac |
45783c |
+ return (ISC_R_NOMEMORY);
|
|
Adam Tkac |
45783c |
+ }
|
|
Adam Tkac |
45783c |
+ }
|
|
Adam Tkac |
45783c |
+ filter = data->lud->lud_filter;
|
|
Adam Tkac |
45783c |
+#else
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
if ((data->base != NULL && unhex(data->base) == NULL) ||
|
|
Adam Tkac |
45783c |
(filter != NULL && unhex(filter) == NULL) ||
|
|
Adam Tkac |
af78c8 |
@@ -572,6 +692,7 @@ ldapdb_create(const char *zone, int argc
|
|
Adam Tkac |
45783c |
"LDAP sdb zone '%s': URL: bad hex values", zone);
|
|
Adam Tkac |
45783c |
return (ISC_R_FAILURE);
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
/* compute filterall and filterone once and for all */
|
|
Adam Tkac |
45783c |
if (filter == NULL) {
|
|
Adam Tkac |
af78c8 |
@@ -602,6 +723,7 @@ ldapdb_create(const char *zone, int argc
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
data->filtername = data->filterone + strlen(data->filterone);
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
+#if LDAP_API_VERSION < 3001
|
|
Adam Tkac |
45783c |
/* support URLs with literal IPv6 addresses */
|
|
Adam Tkac |
45783c |
data->hostname = isc_mem_strdup(ns_g_mctx, data->hostport + (*data->hostport == '[' ? 1 : 0));
|
|
Adam Tkac |
45783c |
if (data->hostname == NULL) {
|
|
Adam Tkac |
af78c8 |
@@ -620,8 +742,10 @@ ldapdb_create(const char *zone, int argc
|
|
Adam Tkac |
45783c |
data->portno = atoi(s);
|
|
Adam Tkac |
45783c |
} else
|
|
Adam Tkac |
45783c |
data->portno = LDAP_PORT;
|
|
Adam Tkac |
45783c |
+#endif
|
|
Adam Tkac |
45783c |
|
|
Adam Tkac |
45783c |
*dbdata = data;
|
|
Adam Tkac |
45783c |
+
|
|
Adam Tkac |
45783c |
return (ISC_R_SUCCESS);
|
|
Adam Tkac |
45783c |
}
|
|
Adam Tkac |
45783c |
|