From: Marco Bettini Date: Mon, 9 Dec 2024 09:56:21 +0000 (+0000) Subject: lib-dict-backend: switch to ldap_client_init_auto() X-Git-Tag: 2.4.0~137 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=bb93ffe66db90c499fba92437984b855d535985e;p=thirdparty%2Fdovecot%2Fcore.git lib-dict-backend: switch to ldap_client_init_auto() --- diff --git a/src/lib-dict-backend/dict-ldap-settings.c b/src/lib-dict-backend/dict-ldap-settings.c index 2eb2209a28..94e473a5dc 100644 --- a/src/lib-dict-backend/dict-ldap-settings.c +++ b/src/lib-dict-backend/dict-ldap-settings.c @@ -179,51 +179,6 @@ parse_setting(const char *key, const char *value, switch (ctx->type) { case SECTION_ROOT: - if (strcmp(key, "uri") == 0) { - ctx->set->uri = p_strdup(ctx->pool, value); - return NULL; - } - if (strcmp(key, "bind_dn") == 0) { - ctx->set->bind_dn = p_strdup(ctx->pool, value); - return NULL; - } - if (strcmp(key, "password") == 0) { - ctx->set->password = p_strdup(ctx->pool, value); - return NULL; - } - if (strcmp(key, "timeout") == 0) { - if (str_to_uint(value, &ctx->set->timeout) != 0) { - return "Invalid timeout value"; - } - return NULL; - } - if (strcmp(key, "max_idle_time") == 0) { - if (str_to_uint(value, &ctx->set->max_idle_time) != 0) { - return "Invalid max_idle_time value"; - } - return NULL; - } - if (strcmp(key, "debug") == 0) { - if (str_to_uint(value, &ctx->set->debug) != 0) { - return "invalid debug value"; - } - return NULL; - } - if (strcmp(key, "tls") == 0) { - if (strcasecmp(value, "yes") == 0) { - ctx->set->require_ssl = TRUE; - ctx->set->start_tls = TRUE; - } else if (strcasecmp(value, "no") == 0) { - ctx->set->require_ssl = FALSE; - ctx->set->start_tls = FALSE; - } else if (strcasecmp(value, "try") == 0) { - ctx->set->require_ssl = FALSE; - ctx->set->start_tls = TRUE; - } else { - return "tls must be yes, try or no"; - } - return NULL; - } break; case SECTION_MAP: return parse_setting_from_defs(ctx->pool, @@ -290,20 +245,9 @@ dict_ldap_settings_read(pool_t pool, const char *path, const char **error_r) t_array_init(&ctx.cur_attributes, 16); p_array_init(&ctx.set->parsed_maps, pool, 8); - ctx.set->timeout = 30; /* default timeout */ - ctx.set->require_ssl = FALSE; /* try to start SSL */ - ctx.set->start_tls = TRUE; - if (!settings_read(path, NULL, parse_setting, parse_section, &ctx, error_r)) return NULL; - - if (ctx.set->uri == NULL) { - *error_r = t_strdup_printf("Error in configuration file %s: " - "Missing ldap uri", path); - return NULL; - } - return ctx.set; } diff --git a/src/lib-dict-backend/dict-ldap-settings.h b/src/lib-dict-backend/dict-ldap-settings.h index 5f78fcee4e..74835265b1 100644 --- a/src/lib-dict-backend/dict-ldap-settings.h +++ b/src/lib-dict-backend/dict-ldap-settings.h @@ -18,14 +18,6 @@ struct dict_ldap_map_settings { }; struct dict_ldap_settings { - const char *uri; - const char *bind_dn; - const char *password; - unsigned int timeout; - unsigned int max_idle_time; - unsigned int debug; - bool require_ssl; - bool start_tls; ARRAY(struct dict_ldap_map_settings) parsed_maps; }; diff --git a/src/lib-dict-backend/dict-ldap.c b/src/lib-dict-backend/dict-ldap.c index 80adf97843..be140f1bd7 100644 --- a/src/lib-dict-backend/dict-ldap.c +++ b/src/lib-dict-backend/dict-ldap.c @@ -121,18 +121,7 @@ ldap_dict_find_map(struct ldap_dict *dict, const char *path, static int dict_ldap_connect(struct ldap_dict *dict, const char **error_r) { - struct ldap_client_settings set; - i_zero(&set); - set.uris = dict->set->uri; - set.auth_dn = dict->set->bind_dn; - set.auth_dn_password = dict->set->password; - set.timeout_secs = dict->set->timeout; - set.max_idle_time_secs = dict->set->max_idle_time; - set.debug_level = dict->set->debug; - set.require_ssl = dict->set->require_ssl; - set.starttls = dict->set->start_tls; - set.event_parent = dict->event; - return ldap_client_init(&set, &dict->client, error_r); + return ldap_client_init_auto(dict->event, &dict->client, error_r); } #define IS_LDAP_ESCAPED_CHAR(c) \