|
|
cdf651 |
From 4b1137562c3446e85a6383010702850f9532a4f2 Mon Sep 17 00:00:00 2001
|
|
|
cdf651 |
From: Sumit Bose <sbose@redhat.com>
|
|
|
cdf651 |
Date: Fri, 24 Feb 2017 13:55:47 +0100
|
|
|
cdf651 |
Subject: [PATCH] krb5 locator: add support for multiple addresses
|
|
|
cdf651 |
|
|
|
cdf651 |
Read multiple addresses from the kdcinfo files add call the provided
|
|
|
cdf651 |
callback with each of them.
|
|
|
cdf651 |
|
|
|
cdf651 |
Related to https://pagure.io/SSSD/sssd/issue/941
|
|
|
cdf651 |
Reviewed-by: Jakub Hrozek <jhrozek@redhat.com>
|
|
|
cdf651 |
|
|
|
cdf651 |
(cherry picked from commit efae9509cb05648357e9b4c10a93c0d38558bed4)
|
|
|
cdf651 |
|
|
|
cdf651 |
DOWNSTREAM:
|
|
|
cdf651 |
Resolves: rhbz#1494690 - kdcinfo files are not created for subdomains of a directly joined AD client
|
|
|
cdf651 |
---
|
|
|
cdf651 |
src/krb5_plugin/sssd_krb5_locator_plugin.c | 344 +++++++++++++++------
|
|
|
cdf651 |
1 file changed, 246 insertions(+), 98 deletions(-)
|
|
|
cdf651 |
|
|
|
cdf651 |
diff --git a/src/krb5_plugin/sssd_krb5_locator_plugin.c b/src/krb5_plugin/sssd_krb5_locator_plugin.c
|
|
|
cdf651 |
index 7c17fcb33373293fbbbe2be967dca57b31ef13de..82fb5c7b2ffa319ed250e54cdf9a0b6798d4ff51 100644
|
|
|
cdf651 |
--- a/src/krb5_plugin/sssd_krb5_locator_plugin.c
|
|
|
cdf651 |
+++ b/src/krb5_plugin/sssd_krb5_locator_plugin.c
|
|
|
cdf651 |
@@ -42,7 +42,7 @@
|
|
|
cdf651 |
#define DEFAULT_KADMIN_PORT 749
|
|
|
cdf651 |
#define DEFAULT_KPASSWD_PORT 464
|
|
|
cdf651 |
|
|
|
cdf651 |
-#define BUFSIZE 512
|
|
|
cdf651 |
+#define BUFSIZE 4096
|
|
|
cdf651 |
#define PORT_STR_SIZE 7
|
|
|
cdf651 |
#define SSSD_KRB5_LOCATOR_DEBUG "SSSD_KRB5_LOCATOR_DEBUG"
|
|
|
cdf651 |
#define SSSD_KRB5_LOCATOR_DISABLE "SSSD_KRB5_LOCATOR_DISABLE"
|
|
|
cdf651 |
@@ -53,12 +53,15 @@
|
|
|
cdf651 |
} \
|
|
|
cdf651 |
} while(0)
|
|
|
cdf651 |
|
|
|
cdf651 |
+struct addr_port {
|
|
|
cdf651 |
+ char *addr;
|
|
|
cdf651 |
+ uint16_t port;
|
|
|
cdf651 |
+};
|
|
|
cdf651 |
+
|
|
|
cdf651 |
struct sssd_ctx {
|
|
|
cdf651 |
char *sssd_realm;
|
|
|
cdf651 |
- char *kdc_addr;
|
|
|
cdf651 |
- uint16_t kdc_port;
|
|
|
cdf651 |
- char *kpasswd_addr;
|
|
|
cdf651 |
- uint16_t kpasswd_port;
|
|
|
cdf651 |
+ struct addr_port *kdc_addr;
|
|
|
cdf651 |
+ struct addr_port *kpasswd_addr;
|
|
|
cdf651 |
bool debug;
|
|
|
cdf651 |
bool disabled;
|
|
|
cdf651 |
};
|
|
|
cdf651 |
@@ -82,6 +85,186 @@ void plugin_debug_fn(const char *format, ...)
|
|
|
cdf651 |
free(s);
|
|
|
cdf651 |
}
|
|
|
cdf651 |
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+static void free_addr_port_list(struct addr_port **list)
|
|
|
cdf651 |
+{
|
|
|
cdf651 |
+ size_t c;
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ if (list == NULL || *list == NULL) {
|
|
|
cdf651 |
+ return;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ for (c = 0; (*list)[c].addr != NULL; c++) {
|
|
|
cdf651 |
+ free((*list)[c].addr);
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ free(*list);
|
|
|
cdf651 |
+ *list = NULL;
|
|
|
cdf651 |
+}
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+static int copy_addr_port_list(struct addr_port *src, bool clear_port,
|
|
|
cdf651 |
+ struct addr_port **dst)
|
|
|
cdf651 |
+{
|
|
|
cdf651 |
+ size_t c;
|
|
|
cdf651 |
+ struct addr_port *d = NULL;
|
|
|
cdf651 |
+ int ret;
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ /* only copy if dst is initialized to NULL */
|
|
|
cdf651 |
+ if (dst == NULL || *dst != NULL) {
|
|
|
cdf651 |
+ return EINVAL;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ if (src == NULL) {
|
|
|
cdf651 |
+ return 0;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ for (c = 0; src[c].addr != NULL; c++);
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ d = calloc((c + 1), sizeof(struct addr_port));
|
|
|
cdf651 |
+ if (d == NULL) {
|
|
|
cdf651 |
+ return ENOMEM;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ for (c = 0; src[c].addr != NULL; c++) {
|
|
|
cdf651 |
+ d[c].addr = strdup(src[c].addr);
|
|
|
cdf651 |
+ if (d[c].addr == NULL) {
|
|
|
cdf651 |
+ ret = ENOMEM;
|
|
|
cdf651 |
+ goto done;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ if (clear_port) {
|
|
|
cdf651 |
+ d[c].port = 0;
|
|
|
cdf651 |
+ } else {
|
|
|
cdf651 |
+ d[c].port = src[c].port;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ ret = EOK;
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+done:
|
|
|
cdf651 |
+ if (ret != EOK) {
|
|
|
cdf651 |
+ free_addr_port_list(&d);
|
|
|
cdf651 |
+ } else {
|
|
|
cdf651 |
+ *dst = d;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ return ret;
|
|
|
cdf651 |
+}
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+static int buf_to_addr_port_list(struct sssd_ctx *ctx,
|
|
|
cdf651 |
+ uint8_t *buf, size_t buf_size,
|
|
|
cdf651 |
+ struct addr_port **list)
|
|
|
cdf651 |
+{
|
|
|
cdf651 |
+ struct addr_port *l = NULL;
|
|
|
cdf651 |
+ int ret;
|
|
|
cdf651 |
+ uint8_t *p;
|
|
|
cdf651 |
+ uint8_t *pn;
|
|
|
cdf651 |
+ size_t c;
|
|
|
cdf651 |
+ size_t len;
|
|
|
cdf651 |
+ char *tmp = NULL;
|
|
|
cdf651 |
+ char *port_str;
|
|
|
cdf651 |
+ long port;
|
|
|
cdf651 |
+ char *endptr;
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ /* only create if list is initialized to NULL */
|
|
|
cdf651 |
+ if (buf == NULL || buf_size == 0 || list == NULL || *list != NULL) {
|
|
|
cdf651 |
+ return EINVAL;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ c = 1; /* to account for a missing \n at the very end */
|
|
|
cdf651 |
+ p = buf;
|
|
|
cdf651 |
+ while ((p - buf) < buf_size
|
|
|
cdf651 |
+ && (p = memchr(p, '\n', buf_size - (p - buf))) != NULL) {
|
|
|
cdf651 |
+ p++;
|
|
|
cdf651 |
+ c++;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ l = calloc((c + 1), sizeof(struct addr_port));
|
|
|
cdf651 |
+ if (l == NULL) {
|
|
|
cdf651 |
+ return ENOMEM;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ c = 0;
|
|
|
cdf651 |
+ p = buf;
|
|
|
cdf651 |
+ do {
|
|
|
cdf651 |
+ pn = memchr(p, '\n', buf_size - (p - buf));
|
|
|
cdf651 |
+ if (pn != NULL) {
|
|
|
cdf651 |
+ len = pn - p;
|
|
|
cdf651 |
+ } else {
|
|
|
cdf651 |
+ len = buf_size - (p - buf);
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ if (len == 0) {
|
|
|
cdf651 |
+ /* empty line no more processing */
|
|
|
cdf651 |
+ break;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ free(tmp);
|
|
|
cdf651 |
+ tmp = strndup((char *) p, len);
|
|
|
cdf651 |
+ if (tmp == NULL) {
|
|
|
cdf651 |
+ ret = ENOMEM;
|
|
|
cdf651 |
+ goto done;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ port_str = strrchr(tmp, ':');
|
|
|
cdf651 |
+ if (port_str == NULL) {
|
|
|
cdf651 |
+ port = 0;
|
|
|
cdf651 |
+ } else {
|
|
|
cdf651 |
+ *port_str = '\0';
|
|
|
cdf651 |
+ ++port_str;
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ if (isdigit(*port_str)) {
|
|
|
cdf651 |
+ errno = 0;
|
|
|
cdf651 |
+ port = strtol(port_str, &endptr, 10);
|
|
|
cdf651 |
+ if (errno != 0) {
|
|
|
cdf651 |
+ ret = errno;
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("strtol failed on [%s]: [%d][%s], "
|
|
|
cdf651 |
+ "assuming default.\n", port_str, ret,
|
|
|
cdf651 |
+ strerror(ret)));
|
|
|
cdf651 |
+ port = 0;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ if (*endptr != '\0') {
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("Found additional characters [%s] in port "
|
|
|
cdf651 |
+ "number [%s], assuming default.\n", endptr,
|
|
|
cdf651 |
+ port_str));
|
|
|
cdf651 |
+ port = 0;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ if (port < 0 || port > 65535) {
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("Illegal port number [%ld], assuming "
|
|
|
cdf651 |
+ "default.\n", port));
|
|
|
cdf651 |
+ port = 0;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ } else {
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("Illegal port number [%s], assuming default.\n",
|
|
|
cdf651 |
+ port_str));
|
|
|
cdf651 |
+ port = 0;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("Found [%s][%d].\n", tmp, port));
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ l[c].addr = strdup(tmp);
|
|
|
cdf651 |
+ if (l[c].addr == NULL) {
|
|
|
cdf651 |
+ ret = ENOMEM;
|
|
|
cdf651 |
+ goto done;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ l[c].port = port;
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ c++;
|
|
|
cdf651 |
+ p = pn == NULL ? NULL : (pn + 1);
|
|
|
cdf651 |
+ } while (p != NULL);
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ ret = EOK;
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+done:
|
|
|
cdf651 |
+ free(tmp);
|
|
|
cdf651 |
+ if (ret != EOK) {
|
|
|
cdf651 |
+ free_addr_port_list(&l);
|
|
|
cdf651 |
+ } else {
|
|
|
cdf651 |
+ *list = l;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ return ret;
|
|
|
cdf651 |
+}
|
|
|
cdf651 |
+
|
|
|
cdf651 |
static int get_krb5info(const char *realm, struct sssd_ctx *ctx,
|
|
|
cdf651 |
enum locate_service_type svc)
|
|
|
cdf651 |
{
|
|
|
cdf651 |
@@ -91,9 +274,6 @@ static int get_krb5info(const char *realm, struct sssd_ctx *ctx,
|
|
|
cdf651 |
uint8_t buf[BUFSIZE + 1];
|
|
|
cdf651 |
int fd = -1;
|
|
|
cdf651 |
const char *name_tmpl = NULL;
|
|
|
cdf651 |
- char *port_str;
|
|
|
cdf651 |
- long port;
|
|
|
cdf651 |
- char *endptr;
|
|
|
cdf651 |
|
|
|
cdf651 |
switch (svc) {
|
|
|
cdf651 |
case locate_service_kdc:
|
|
|
cdf651 |
@@ -148,62 +328,21 @@ static int get_krb5info(const char *realm, struct sssd_ctx *ctx,
|
|
|
cdf651 |
PLUGIN_DEBUG(("Content of krb5info file [%s] is [%d] or larger.\n",
|
|
|
cdf651 |
krb5info_name, BUFSIZE));
|
|
|
cdf651 |
}
|
|
|
cdf651 |
- PLUGIN_DEBUG(("Found [%s] in [%s].\n", buf, krb5info_name));
|
|
|
cdf651 |
-
|
|
|
cdf651 |
- port_str = strrchr((char *) buf, ':');
|
|
|
cdf651 |
- if (port_str == NULL) {
|
|
|
cdf651 |
- port = 0;
|
|
|
cdf651 |
- } else {
|
|
|
cdf651 |
- *port_str = '\0';
|
|
|
cdf651 |
- ++port_str;
|
|
|
cdf651 |
-
|
|
|
cdf651 |
- if (isdigit(*port_str)) {
|
|
|
cdf651 |
- errno = 0;
|
|
|
cdf651 |
- port = strtol(port_str, &endptr, 10);
|
|
|
cdf651 |
- if (errno != 0) {
|
|
|
cdf651 |
- ret = errno;
|
|
|
cdf651 |
- PLUGIN_DEBUG(("strtol failed on [%s]: [%d][%s], "
|
|
|
cdf651 |
- "assuming default.\n", port_str, ret, strerror(ret)));
|
|
|
cdf651 |
- port = 0;
|
|
|
cdf651 |
- }
|
|
|
cdf651 |
- if (*endptr != '\0') {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("Found additional characters [%s] in port number "
|
|
|
cdf651 |
- "[%s], assuming default.\n", endptr, port_str));
|
|
|
cdf651 |
- port = 0;
|
|
|
cdf651 |
- }
|
|
|
cdf651 |
-
|
|
|
cdf651 |
- if (port < 0 || port > 65535) {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("Illegal port number [%ld], assuming default.\n",
|
|
|
cdf651 |
- port));
|
|
|
cdf651 |
- port = 0;
|
|
|
cdf651 |
- }
|
|
|
cdf651 |
- } else {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("Illegal port number [%s], assuming default.\n",
|
|
|
cdf651 |
- port_str));
|
|
|
cdf651 |
- port = 0;
|
|
|
cdf651 |
- }
|
|
|
cdf651 |
- }
|
|
|
cdf651 |
|
|
|
cdf651 |
switch (svc) {
|
|
|
cdf651 |
case locate_service_kdc:
|
|
|
cdf651 |
- free(ctx->kdc_addr);
|
|
|
cdf651 |
- ctx->kdc_addr = strdup((char *) buf);
|
|
|
cdf651 |
- if (ctx->kdc_addr == NULL) {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("strdup failed.\n"));
|
|
|
cdf651 |
- ret = ENOMEM;
|
|
|
cdf651 |
+ free_addr_port_list(&(ctx->kdc_addr));
|
|
|
cdf651 |
+ ret = buf_to_addr_port_list(ctx, buf, len, &(ctx->kdc_addr));
|
|
|
cdf651 |
+ if (ret != EOK) {
|
|
|
cdf651 |
goto done;
|
|
|
cdf651 |
}
|
|
|
cdf651 |
- ctx->kdc_port = (uint16_t) port;
|
|
|
cdf651 |
break;
|
|
|
cdf651 |
case locate_service_kpasswd:
|
|
|
cdf651 |
- free(ctx->kpasswd_addr);
|
|
|
cdf651 |
- ctx->kpasswd_addr = strdup((char *) buf);
|
|
|
cdf651 |
- if (ctx->kpasswd_addr == NULL) {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("strdup failed.\n"));
|
|
|
cdf651 |
- ret = ENOMEM;
|
|
|
cdf651 |
+ free_addr_port_list(&(ctx->kpasswd_addr));
|
|
|
cdf651 |
+ ret = buf_to_addr_port_list(ctx, buf, len, &(ctx->kpasswd_addr));
|
|
|
cdf651 |
+ if (ret != EOK) {
|
|
|
cdf651 |
goto done;
|
|
|
cdf651 |
}
|
|
|
cdf651 |
- ctx->kpasswd_port = (uint16_t) port;
|
|
|
cdf651 |
break;
|
|
|
cdf651 |
default:
|
|
|
cdf651 |
PLUGIN_DEBUG(("Unsupported service [%d].\n", svc));
|
|
|
cdf651 |
@@ -256,8 +395,8 @@ void sssd_krb5_locator_close(void *private_data)
|
|
|
cdf651 |
ctx = (struct sssd_ctx *) private_data;
|
|
|
cdf651 |
PLUGIN_DEBUG(("sssd_krb5_locator_close called\n"));
|
|
|
cdf651 |
|
|
|
cdf651 |
- free(ctx->kdc_addr);
|
|
|
cdf651 |
- free(ctx->kpasswd_addr);
|
|
|
cdf651 |
+ free_addr_port_list(&(ctx->kdc_addr));
|
|
|
cdf651 |
+ free_addr_port_list(&(ctx->kpasswd_addr));
|
|
|
cdf651 |
free(ctx->sssd_realm);
|
|
|
cdf651 |
free(ctx);
|
|
|
cdf651 |
|
|
|
cdf651 |
@@ -277,8 +416,10 @@ krb5_error_code sssd_krb5_locator_lookup(void *private_data,
|
|
|
cdf651 |
struct sssd_ctx *ctx;
|
|
|
cdf651 |
struct addrinfo ai_hints;
|
|
|
cdf651 |
uint16_t port = 0;
|
|
|
cdf651 |
- const char *addr = NULL;
|
|
|
cdf651 |
+ uint16_t default_port = 0;
|
|
|
cdf651 |
+ struct addr_port *addr = NULL;
|
|
|
cdf651 |
char port_str[PORT_STR_SIZE];
|
|
|
cdf651 |
+ size_t c;
|
|
|
cdf651 |
|
|
|
cdf651 |
if (private_data == NULL) return KRB5_PLUGIN_NO_HANDLE;
|
|
|
cdf651 |
ctx = (struct sssd_ctx *) private_data;
|
|
|
cdf651 |
@@ -308,9 +449,13 @@ krb5_error_code sssd_krb5_locator_lookup(void *private_data,
|
|
|
cdf651 |
if (ret != EOK) {
|
|
|
cdf651 |
PLUGIN_DEBUG(("reading kpasswd address failed, "
|
|
|
cdf651 |
"using kdc address.\n"));
|
|
|
cdf651 |
- free(ctx->kpasswd_addr);
|
|
|
cdf651 |
- ctx->kpasswd_addr = strdup(ctx->kdc_addr);
|
|
|
cdf651 |
- ctx->kpasswd_port = 0;
|
|
|
cdf651 |
+ free_addr_port_list(&(ctx->kpasswd_addr));
|
|
|
cdf651 |
+ ret = copy_addr_port_list(ctx->kdc_addr, true,
|
|
|
cdf651 |
+ &(ctx->kpasswd_addr));
|
|
|
cdf651 |
+ if (ret != EOK) {
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("copying address list failed.\n"));
|
|
|
cdf651 |
+ return KRB5_PLUGIN_NO_HANDLE;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
}
|
|
|
cdf651 |
}
|
|
|
cdf651 |
}
|
|
|
cdf651 |
@@ -322,19 +467,19 @@ krb5_error_code sssd_krb5_locator_lookup(void *private_data,
|
|
|
cdf651 |
switch (svc) {
|
|
|
cdf651 |
case locate_service_kdc:
|
|
|
cdf651 |
addr = ctx->kdc_addr;
|
|
|
cdf651 |
- port = ctx->kdc_port ? ctx->kdc_port : DEFAULT_KERBEROS_PORT;
|
|
|
cdf651 |
+ default_port = DEFAULT_KERBEROS_PORT;
|
|
|
cdf651 |
break;
|
|
|
cdf651 |
case locate_service_master_kdc:
|
|
|
cdf651 |
addr = ctx->kpasswd_addr;
|
|
|
cdf651 |
- port = DEFAULT_KERBEROS_PORT;
|
|
|
cdf651 |
+ default_port = DEFAULT_KERBEROS_PORT;
|
|
|
cdf651 |
break;
|
|
|
cdf651 |
case locate_service_kadmin:
|
|
|
cdf651 |
addr = ctx->kpasswd_addr;
|
|
|
cdf651 |
- port = DEFAULT_KADMIN_PORT;
|
|
|
cdf651 |
+ default_port = DEFAULT_KADMIN_PORT;
|
|
|
cdf651 |
break;
|
|
|
cdf651 |
case locate_service_kpasswd:
|
|
|
cdf651 |
addr = ctx->kpasswd_addr;
|
|
|
cdf651 |
- port = ctx->kpasswd_port ? ctx->kpasswd_port : DEFAULT_KPASSWD_PORT;
|
|
|
cdf651 |
+ default_port = DEFAULT_KPASSWD_PORT;
|
|
|
cdf651 |
break;
|
|
|
cdf651 |
case locate_service_krb524:
|
|
|
cdf651 |
return KRB5_PLUGIN_NO_HANDLE;
|
|
|
cdf651 |
@@ -362,46 +507,49 @@ krb5_error_code sssd_krb5_locator_lookup(void *private_data,
|
|
|
cdf651 |
if (strcmp(realm, ctx->sssd_realm) != 0)
|
|
|
cdf651 |
return KRB5_PLUGIN_NO_HANDLE;
|
|
|
cdf651 |
|
|
|
cdf651 |
- memset(port_str, 0, PORT_STR_SIZE);
|
|
|
cdf651 |
- ret = snprintf(port_str, PORT_STR_SIZE-1, "%u", port);
|
|
|
cdf651 |
- if (ret < 0 || ret >= (PORT_STR_SIZE-1)) {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("snprintf failed.\n"));
|
|
|
cdf651 |
- return KRB5_PLUGIN_NO_HANDLE;
|
|
|
cdf651 |
- }
|
|
|
cdf651 |
-
|
|
|
cdf651 |
- memset(&ai_hints, 0, sizeof(struct addrinfo));
|
|
|
cdf651 |
- ai_hints.ai_flags = AI_NUMERICHOST|AI_NUMERICSERV;
|
|
|
cdf651 |
- ai_hints.ai_socktype = socktype;
|
|
|
cdf651 |
-
|
|
|
cdf651 |
- ret = getaddrinfo(addr, port_str, &ai_hints, &ai;;
|
|
|
cdf651 |
- if (ret != 0) {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("getaddrinfo failed [%d][%s].\n", ret,
|
|
|
cdf651 |
- gai_strerror(ret)));
|
|
|
cdf651 |
- if (ret == EAI_SYSTEM) {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("getaddrinfo failed [%d][%s].\n", errno,
|
|
|
cdf651 |
- strerror(errno)));
|
|
|
cdf651 |
+ for (c = 0; addr[c].addr != NULL; c++) {
|
|
|
cdf651 |
+ port = (addr[c].port == 0 ? default_port : addr[c].port);
|
|
|
cdf651 |
+ memset(port_str, 0, PORT_STR_SIZE);
|
|
|
cdf651 |
+ ret = snprintf(port_str, PORT_STR_SIZE-1, "%u", port);
|
|
|
cdf651 |
+ if (ret < 0 || ret >= (PORT_STR_SIZE-1)) {
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("snprintf failed.\n"));
|
|
|
cdf651 |
+ return KRB5_PLUGIN_NO_HANDLE;
|
|
|
cdf651 |
}
|
|
|
cdf651 |
- return KRB5_PLUGIN_NO_HANDLE;
|
|
|
cdf651 |
- }
|
|
|
cdf651 |
|
|
|
cdf651 |
- PLUGIN_DEBUG(("addr[%s:%s] family[%d] socktype[%d]\n", addr, port_str,
|
|
|
cdf651 |
- ai->ai_family, ai->ai_socktype));
|
|
|
cdf651 |
+ memset(&ai_hints, 0, sizeof(struct addrinfo));
|
|
|
cdf651 |
+ ai_hints.ai_flags = AI_NUMERICHOST|AI_NUMERICSERV;
|
|
|
cdf651 |
+ ai_hints.ai_socktype = socktype;
|
|
|
cdf651 |
|
|
|
cdf651 |
- if ((family == AF_UNSPEC || ai->ai_family == family) &&
|
|
|
cdf651 |
- ai->ai_socktype == socktype) {
|
|
|
cdf651 |
-
|
|
|
cdf651 |
- ret = cbfunc(cbdata, socktype, ai->ai_addr);
|
|
|
cdf651 |
+ ret = getaddrinfo(addr[c].addr, port_str, &ai_hints, &ai;;
|
|
|
cdf651 |
if (ret != 0) {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("cbfunc failed\n"));
|
|
|
cdf651 |
- freeaddrinfo(ai);
|
|
|
cdf651 |
- return ret;
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("getaddrinfo failed [%d][%s].\n", ret,
|
|
|
cdf651 |
+ gai_strerror(ret)));
|
|
|
cdf651 |
+ if (ret == EAI_SYSTEM) {
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("getaddrinfo failed [%d][%s].\n",
|
|
|
cdf651 |
+ errno, strerror(errno)));
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+ return KRB5_PLUGIN_NO_HANDLE;
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("addr[%s:%s] family[%d] socktype[%d]\n", addr[c].addr,
|
|
|
cdf651 |
+ port_str, ai->ai_family, ai->ai_socktype));
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ if ((family == AF_UNSPEC || ai->ai_family == family) &&
|
|
|
cdf651 |
+ ai->ai_socktype == socktype) {
|
|
|
cdf651 |
+
|
|
|
cdf651 |
+ ret = cbfunc(cbdata, socktype, ai->ai_addr);
|
|
|
cdf651 |
+ if (ret != 0) {
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("cbfunc failed\n"));
|
|
|
cdf651 |
+ freeaddrinfo(ai);
|
|
|
cdf651 |
+ return ret;
|
|
|
cdf651 |
+ } else {
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("[%s] used\n", addr[c].addr));
|
|
|
cdf651 |
+ }
|
|
|
cdf651 |
} else {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("[%s] used\n", addr));
|
|
|
cdf651 |
+ PLUGIN_DEBUG(("[%s] NOT used\n", addr[c].addr));
|
|
|
cdf651 |
}
|
|
|
cdf651 |
- } else {
|
|
|
cdf651 |
- PLUGIN_DEBUG(("[%s] NOT used\n", addr));
|
|
|
cdf651 |
+ freeaddrinfo(ai);
|
|
|
cdf651 |
}
|
|
|
cdf651 |
- freeaddrinfo(ai);
|
|
|
cdf651 |
|
|
|
cdf651 |
return 0;
|
|
|
cdf651 |
}
|
|
|
cdf651 |
--
|
|
|
cdf651 |
2.17.1
|
|
|
cdf651 |
|