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:
Johan Danielsson
1999-08-27 09:02:23 +00:00
parent daebb89321
commit 92c4c345c6

View File

@@ -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);
} }
/* /*