X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=src%2Fget_ip_addr.c;h=6ddd35a125ef6c6d50e9ea522f1eff29bfa10b4e;hb=112512c546c8d9a46b503b5e4b9cc10afb1a248e;hp=de03d8c2ba846d65efc155046642304d622585a0;hpb=6fda988f360b3145d5772b6964f336dd652357ea;p=i3%2Fi3status diff --git a/src/get_ip_addr.c b/src/get_ip_addr.c index de03d8c..6ddd35a 100644 --- a/src/get_ip_addr.c +++ b/src/get_ip_addr.c @@ -1,11 +1,13 @@ -#include +// vim:ts=8:expandtab +#include #include -#include #include #include #include #include #include +#include +#include #include "i3status.h" @@ -16,28 +18,50 @@ */ const char *get_ip_addr(const char *interface) { static char part[512]; - struct ifreq ifr; socklen_t len = sizeof(struct sockaddr_in); memset(part, 0, sizeof(part)); - /* First check if the interface is running */ - (void)strcpy(ifr.ifr_name, interface); - if (ioctl(general_socket, SIOCGIFFLAGS, &ifr) < 0 || - !(ifr.ifr_flags & IFF_RUNNING)) - return NULL; + struct ifaddrs *ifaddr, *addrp; + + getifaddrs(&ifaddr); + + if (ifaddr == NULL) { + (void)snprintf(part, sizeof(part), "E: down"); + return part; + } + + addrp = ifaddr; - /* Interface is up, get the IP address */ - (void)strcpy(ifr.ifr_name, interface); - ifr.ifr_addr.sa_family = AF_INET; - if (ioctl(general_socket, SIOCGIFADDR, &ifr) < 0) + /* Skip until we are at the AF_INET address of interface */ + for (addrp = ifaddr; + + (addrp != NULL && + (strcmp(addrp->ifa_name, interface) != 0 || + addrp->ifa_addr == NULL || + addrp->ifa_addr->sa_family != AF_INET)); + + addrp = addrp->ifa_next) { + /* Check if the interface is down */ + if (strcmp(addrp->ifa_name, interface) == 0 && + (addrp->ifa_flags & IFF_RUNNING) == 0) { + freeifaddrs(ifaddr); + return NULL; + } + } + + if (addrp == NULL) { + freeifaddrs(ifaddr); return "no IP"; + } - int ret; - if ((ret = getnameinfo(&ifr.ifr_addr, len, part, sizeof(part), NULL, 0, NI_NUMERICHOST)) != 0) { - fprintf(stderr, "getnameinfo(): %s\n", gai_strerror(ret)); - return "no IP"; - } + int ret; + if ((ret = getnameinfo(addrp->ifa_addr, len, part, sizeof(part), NULL, 0, NI_NUMERICHOST)) != 0) { + fprintf(stderr, "getnameinfo(): %s\n", gai_strerror(ret)); + freeifaddrs(ifaddr); + return "no IP"; + } + freeifaddrs(ifaddr); return part; }