new magic flag to get loopback address if there are no other

addresses.
(krb5_get_all_client_addrs): use that flag


git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@6301 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
Assar Westerlund
1999-06-09 06:17:36 +00:00
parent 6decfa4dc7
commit 02689992d9

View File

@@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1997, 1998 Kungliga Tekniska H<>gskolan * Copyright (c) 1997 - 1999 Kungliga Tekniska H<>gskolan
* (Royal Institute of Technology, Stockholm, Sweden). * (Royal Institute of Technology, Stockholm, Sweden).
* All rights reserved. * All rights reserved.
* *
@@ -86,15 +86,20 @@ gethostname_fallback (krb5_addresses *res)
return 0; return 0;
} }
enum {
NOLOOP = 0, /* don't include loopback interfaces */
LOOP = 1, /* do include loopback interfaces */
LOOP_IF_NONE = 2 /* include loopback if no other if's */
};
/* /*
*
* Try to figure out the addresses of all configured interfaces with a * Try to figure out the addresses of all configured interfaces with a
* lot of magic ioctls. * lot of magic ioctls.
* Include loopback interfaces iff loop.
*/ */
static krb5_error_code static krb5_error_code
find_all_addresses (krb5_addresses *res, int loop, find_all_addresses (krb5_context context,
krb5_addresses *res, int loop,
int af, int siocgifconf, int siocgifflags, int af, int siocgifconf, int siocgifflags,
size_t ifreq_sz) size_t ifreq_sz)
{ {
@@ -108,6 +113,8 @@ find_all_addresses (krb5_addresses *res, int loop,
size_t sz; size_t sz;
struct sockaddr sa_zero; struct sockaddr sa_zero;
struct ifreq *ifr; struct ifreq *ifr;
krb5_address lo_addr;
int got_lo = FALSE;
buf = NULL; buf = NULL;
res->val = NULL; res->val = NULL;
@@ -169,19 +176,37 @@ find_all_addresses (krb5_addresses *res, int loop,
goto error_out; goto error_out;
} }
if(!(ifreq.ifr_flags & IFF_UP) if (!(ifreq.ifr_flags & IFF_UP))
|| (!loop && (ifreq.ifr_flags & IFF_LOOPBACK)) continue;
|| memcmp (sa, &sa_zero, sizeof(sa_zero)) == 0) if (memcmp (sa, &sa_zero, sizeof(sa_zero)) == 0)
continue; continue;
if (krb5_sockaddr_uninteresting (sa)) if (krb5_sockaddr_uninteresting (sa))
continue; continue;
if (ifreq.ifr_flags & IFF_LOOPBACK) {
if (loop == NOLOOP)
continue;
else if (loop == LOOP_IF_NONE) {
ret = krb5_sockaddr2address (sa, &lo_addr);
if (ret)
goto error_out;
got_lo = TRUE;
continue;
}
}
ret = krb5_sockaddr2address (sa, &res->val[j]); ret = krb5_sockaddr2address (sa, &res->val[j]);
if (ret) if (ret)
goto error_out; goto error_out;
++j; ++j;
} }
if (loop == LOOP_IF_NONE && got_lo) {
if (j == 0)
res->val[j++] = lo_addr;
else
krb5_free_address (context, &lo_addr);
}
if (j != num) { if (j != num) {
void *tmp; void *tmp;
@@ -197,8 +222,10 @@ find_all_addresses (krb5_addresses *res, int loop,
goto cleanup; goto cleanup;
error_out: error_out:
if (got_lo)
krb5_free_address (context, &lo_addr);
while(j--) { while(j--) {
krb5_data_free (&res->val[j].address); krb5_free_address (context, &res->val[j]);
} }
free (res->val); free (res->val);
cleanup: cleanup:
@@ -212,11 +239,11 @@ get_addrs_int (krb5_context context, krb5_addresses *res, int loop)
{ {
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)
ret = find_all_addresses (res, 1, ret = find_all_addresses (context, res, loop,
AF_INET6, SIOCGIF6CONF, SIOCGIF6FLAGS, AF_INET6, SIOCGIF6CONF, SIOCGIF6FLAGS,
sizeof(struct in6_ifreq)); sizeof(struct in6_ifreq));
#elif defined(AF_INET) && defined(SIOCGIFCONF) && defined(SIOCGIFFLAGS) #elif defined(AF_INET) && defined(SIOCGIFCONF) && defined(SIOCGIFFLAGS)
ret = find_all_addresses (res, loop, ret = find_all_addresses (context, res, loop,
AF_INET, SIOCGIFCONF, SIOCGIFFLAGS, AF_INET, SIOCGIFCONF, SIOCGIFFLAGS,
sizeof(struct ifreq)); sizeof(struct ifreq));
#endif #endif
@@ -251,7 +278,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, 0); return get_addrs_int (context, res, LOOP_IF_NONE);
} }
/* /*
@@ -262,5 +289,5 @@ krb5_get_all_client_addrs (krb5_context context, krb5_addresses *res)
krb5_error_code krb5_error_code
krb5_get_all_server_addrs (krb5_context context, krb5_addresses *res) krb5_get_all_server_addrs (krb5_context context, krb5_addresses *res)
{ {
return get_addrs_int (context, res, 1); return get_addrs_int (context, res, LOOP);
} }