summaryrefslogtreecommitdiff
path: root/src/nss-myhostname/legacy.c
diff options
context:
space:
mode:
authorTom Gundersen <teg@jklm.no>2013-01-07 15:14:01 +0100
committerTom Gundersen <teg@jklm.no>2013-01-07 15:14:01 +0100
commitf274ece0f76b5709408821e317e87aef76123db6 (patch)
treea14933a1d5bc8fa902f0d191cb358c4e06ea9461 /src/nss-myhostname/legacy.c
parentd7ae18eea511caa6f1af63b7f07abebf2436fded (diff)
parent8e6640f0fe9eebde5a6cc9f1c0a20a289b8ad9c8 (diff)
Merge nss-myhostname
Diffstat (limited to 'src/nss-myhostname/legacy.c')
-rw-r--r--src/nss-myhostname/legacy.c92
1 files changed, 92 insertions, 0 deletions
diff --git a/src/nss-myhostname/legacy.c b/src/nss-myhostname/legacy.c
new file mode 100644
index 0000000000..9c0bcadb65
--- /dev/null
+++ b/src/nss-myhostname/legacy.c
@@ -0,0 +1,92 @@
+/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
+
+/***
+ This file is part of nss-myhostname.
+
+ Copyright 2008-2011 Lennart Poettering
+ Copyright 2011 Robert millan
+
+ nss-myhostname is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public License
+ as published by the Free Software Foundation; either version 2.1 of
+ the License, or (at your option) any later version.
+
+ nss-myhostname is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with nss-myhostname; If not, see
+ <http://www.gnu.org/licenses/>.
+***/
+
+#include <sys/types.h>
+#include <errno.h>
+#include <ifaddrs.h>
+#include <stdlib.h>
+#include <string.h>
+#include <netinet/in.h>
+
+#include "ifconf.h"
+
+int ifconf_acquire_addresses(struct address **_list, unsigned *_n_list) {
+ struct address *list = NULL;
+ unsigned n_list = 0;
+ struct ifaddrs *ifa = NULL;
+ int r = 1;
+ struct ifaddrs *i;
+ int ifindex = 0;
+
+ if (getifaddrs(&ifa) == -1) {
+ r = -errno;
+ goto finish;
+ }
+
+ for (i = ifa; i != NULL; i = i->ifa_next) {
+ int af;
+ const void *cp;
+ struct sockaddr_in6 *in6 = (struct sockaddr_in6 *) i->ifa_addr;
+ struct sockaddr_in *in = (struct sockaddr_in *) i->ifa_addr;
+
+ if (! i->ifa_addr)
+ continue;
+
+ af = i->ifa_addr->sa_family;
+
+ if (af != AF_INET && af != AF_INET6)
+ continue;
+
+ list = realloc(list, (n_list+1) * sizeof(struct address));
+ if (!list) {
+ r = -ENOMEM;
+ goto finish;
+ }
+
+ if (af == AF_INET6)
+ cp = &in6->sin6_addr;
+ else
+ cp = &in->sin_addr;
+
+ list[n_list].family = af;
+ list[n_list].scope = 0;
+ memcpy(list[n_list].address, cp, PROTO_ADDRESS_SIZE(af));
+ list[n_list].ifindex = ifindex++;
+ n_list++;
+ }
+
+finish:
+ if (ifa)
+ freeifaddrs(ifa);
+
+ if (r < 0)
+ free(list);
+ else {
+ qsort(list, n_list, sizeof(struct address), address_compare);
+
+ *_list = list;
+ *_n_list = n_list;
+ }
+
+ return r;
+}