]> git.sur5r.net Git - i3/i3status/blobdiff - src/get_ip_addr.c
Add debian changelog entry to keep updates from overwriting local versions
[i3/i3status] / src / get_ip_addr.c
index ba39a3d4bc1152867e797b6bc6459d59f1d58af8..6ddd35a125ef6c6d50e9ea522f1eff29bfa10b4e 100644 (file)
@@ -1,12 +1,13 @@
 // vim:ts=8:expandtab
-#include <net/if.h>
+#include <netinet/in.h>
 #include <sys/socket.h>
-#include <sys/ioctl.h>
 #include <sys/types.h>
 #include <stdlib.h>
 #include <stdio.h>
 #include <string.h>
 #include <netdb.h>
+#include <ifaddrs.h>
+#include <net/if.h>
 
 #include "i3status.h"
 
  */
 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) {
+        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;
 }