krb5_get_all_server_addrs shouldn't return extra addresses
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@6879 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -87,9 +87,9 @@ gethostname_fallback (krb5_addresses *res)
|
|||||||
}
|
}
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
NOLOOP = 0, /* don't include loopback interfaces */
|
LOOP = 1, /* do include loopback interfaces */
|
||||||
LOOP = 1, /* do include loopback interfaces */
|
LOOP_IF_NONE = 2, /* include loopback if no other if's */
|
||||||
LOOP_IF_NONE = 2 /* include loopback if no other if's */
|
EXTRA_ADDRESSES = 4 /* include extra addresses */
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -99,7 +99,7 @@ enum {
|
|||||||
|
|
||||||
static krb5_error_code
|
static krb5_error_code
|
||||||
find_all_addresses (krb5_context context,
|
find_all_addresses (krb5_context context,
|
||||||
krb5_addresses *res, int loop,
|
krb5_addresses *res, int flags,
|
||||||
int af, int siocgifconf, int siocgifflags,
|
int af, int siocgifconf, int siocgifflags,
|
||||||
size_t ifreq_sz)
|
size_t ifreq_sz)
|
||||||
{
|
{
|
||||||
@@ -186,15 +186,14 @@ find_all_addresses (krb5_context context,
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (ifreq.ifr_flags & IFF_LOOPBACK) {
|
if (ifreq.ifr_flags & IFF_LOOPBACK) {
|
||||||
if (loop == NOLOOP)
|
if (flags & LOOP_IF_NONE) {
|
||||||
continue;
|
|
||||||
else if (loop == LOOP_IF_NONE) {
|
|
||||||
ret = krb5_sockaddr2address (sa, &lo_addr);
|
ret = krb5_sockaddr2address (sa, &lo_addr);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto error_out;
|
goto error_out;
|
||||||
got_lo = TRUE;
|
got_lo = TRUE;
|
||||||
continue;
|
continue;
|
||||||
}
|
} else if((flags & LOOP) == 0)
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = krb5_sockaddr2address (sa, &res->val[j]);
|
ret = krb5_sockaddr2address (sa, &res->val[j]);
|
||||||
@@ -202,7 +201,7 @@ find_all_addresses (krb5_context context,
|
|||||||
goto error_out;
|
goto error_out;
|
||||||
++j;
|
++j;
|
||||||
}
|
}
|
||||||
if (loop == LOOP_IF_NONE && got_lo) {
|
if ((flags & LOOP_IF_NONE) && got_lo) {
|
||||||
if (j == 0)
|
if (j == 0)
|
||||||
res->val[j++] = lo_addr;
|
res->val[j++] = lo_addr;
|
||||||
else
|
else
|
||||||
@@ -237,31 +236,31 @@ cleanup:
|
|||||||
}
|
}
|
||||||
|
|
||||||
static krb5_error_code
|
static krb5_error_code
|
||||||
get_addrs_int (krb5_context context, krb5_addresses *res, int loop)
|
get_addrs_int (krb5_context context, krb5_addresses *res, int flags)
|
||||||
{
|
{
|
||||||
krb5_error_code ret = -1;
|
krb5_error_code ret = -1;
|
||||||
|
|
||||||
#if defined(AF_INET6) && defined(SIOCGIF6CONF) && defined(SIOCGIF6FLAGS)
|
#if defined(AF_INET6) && defined(SIOCGIF6CONF) && defined(SIOCGIF6FLAGS)
|
||||||
if (ret)
|
if (ret)
|
||||||
ret = find_all_addresses (context, res, loop,
|
ret = find_all_addresses (context, res, flags,
|
||||||
AF_INET6, SIOCGIF6CONF, SIOCGIF6FLAGS,
|
AF_INET6, SIOCGIF6CONF, SIOCGIF6FLAGS,
|
||||||
sizeof(struct in6_ifreq));
|
sizeof(struct in6_ifreq));
|
||||||
#endif
|
#endif
|
||||||
#if defined(HAVE_IPV6) && defined(SIOCGIFCONF)
|
#if defined(HAVE_IPV6) && defined(SIOCGIFCONF)
|
||||||
if (ret)
|
if (ret)
|
||||||
ret = find_all_addresses (context, res, loop,
|
ret = find_all_addresses (context, res, flags,
|
||||||
AF_INET6, SIOCGIFCONF, SIOCGIFFLAGS,
|
AF_INET6, SIOCGIFCONF, SIOCGIFFLAGS,
|
||||||
sizeof(struct ifreq));
|
sizeof(struct ifreq));
|
||||||
#endif
|
#endif
|
||||||
#if defined(AF_INET) && defined(SIOCGIFCONF) && defined(SIOCGIFFLAGS)
|
#if defined(AF_INET) && defined(SIOCGIFCONF) && defined(SIOCGIFFLAGS)
|
||||||
if (ret)
|
if (ret)
|
||||||
ret = find_all_addresses (context, res, loop,
|
ret = find_all_addresses (context, res, flags,
|
||||||
AF_INET, SIOCGIFCONF, SIOCGIFFLAGS,
|
AF_INET, SIOCGIFCONF, SIOCGIFFLAGS,
|
||||||
sizeof(struct ifreq));
|
sizeof(struct ifreq));
|
||||||
#endif
|
#endif
|
||||||
if(ret || res->len == 0)
|
if(ret || res->len == 0)
|
||||||
ret = gethostname_fallback (res);
|
ret = gethostname_fallback (res);
|
||||||
if(ret == 0) {
|
if(ret == 0 && (flags & EXTRA_ADDRESSES)) {
|
||||||
/* append user specified addresses */
|
/* append user specified addresses */
|
||||||
krb5_addresses a;
|
krb5_addresses a;
|
||||||
ret = krb5_get_extra_addresses(context, &a);
|
ret = krb5_get_extra_addresses(context, &a);
|
||||||
@@ -290,7 +289,7 @@ get_addrs_int (krb5_context context, krb5_addresses *res, int loop)
|
|||||||
krb5_error_code
|
krb5_error_code
|
||||||
krb5_get_all_client_addrs (krb5_context context, krb5_addresses *res)
|
krb5_get_all_client_addrs (krb5_context context, krb5_addresses *res)
|
||||||
{
|
{
|
||||||
return get_addrs_int (context, res, LOOP_IF_NONE);
|
return get_addrs_int (context, res, LOOP_IF_NONE | EXTRA_ADDRESSES);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Reference in New Issue
Block a user