From 093f39df23da146cc88e9987469081e5b3016cfe Mon Sep 17 00:00:00 2001
From: Aaron Marcher <info@nulltime.net>
Date: Mon, 15 Aug 2016 14:43:29 +0200
Subject: [PATCH] added wifi essid

---
 README.md    |  2 +-
 config.def.h |  3 ++-
 slstatus.c   | 43 ++++++++++++++++++++++++++++++++++++++++++-
 slstatus.h   |  1 +
 4 files changed, 46 insertions(+), 3 deletions(-)

diff --git a/README.md b/README.md
index 404977f..8e3002d 100644
--- a/README.md
+++ b/README.md
@@ -20,7 +20,7 @@ The following information is included:
 - ram numbers (free ram, percentage, total ram and used ram)
 - temperature
 - volume percentage (alsa)
-- wifi percentage
+- wifi percentage and essid
 
 Multiple entries per function are supported and everything can be reordered and customized via the C header file config.h (similar to DWM).
 
diff --git a/config.def.h b/config.def.h
index c9da314..5576936 100644
--- a/config.def.h
+++ b/config.def.h
@@ -32,7 +32,8 @@ static unsigned int update_interval = 1;
 - uid (uid of current user) [argument: NULL]
 - username (username of current user) [argument: NULL]
 - vol_perc (alsa volume and mute status in percent) [argument: soundcard]
-- wifi_perc (wifi signal in percent) [argument: wifi card interface name] */
+- wifi_perc (wifi signal in percent) [argument: wifi card interface name]
+- wifi_essid (wifi essid) [argument: wifi card interface name] */
 static const struct arg args[] = {
     /* function     format          argument */
     { wifi_perc,    "wifi %4s | ",  "wlp3s0" },
diff --git a/slstatus.c b/slstatus.c
index b74faa6..505f25d 100644
--- a/slstatus.c
+++ b/slstatus.c
@@ -6,6 +6,7 @@
 #include <fcntl.h>
 #include <ifaddrs.h>
 #include <limits.h>
+#include <linux/wireless.h>
 #include <locale.h>
 #include <netdb.h>
 #include <pwd.h>
@@ -13,10 +14,11 @@
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
-#include <sys/types.h>
+#include <sys/ioctl.h>
 #include <sys/stat.h>
 #include <sys/statvfs.h>
 #include <sys/socket.h>
+#include <sys/types.h>
 #include <time.h>
 #include <unistd.h>
 #include <X11/Xlib.h>
@@ -666,6 +668,45 @@ wifi_perc(const char *wificard)
     return smprintf("%d%%", strength);
 }
 
+/* wifi essid */
+char *
+wifi_essid(const char *wificard)
+{
+    char *id = malloc(IW_ESSID_MAX_SIZE+1);
+    if (id == NULL) {
+        fprintf(stderr, "Cannot get ESSID.");
+        return smprintf("n/a");
+    }
+    int sockfd;
+    struct iwreq wreq;
+
+    /* prepare */
+    memset(&wreq, 0, sizeof(struct iwreq));
+    wreq.u.essid.length = IW_ESSID_MAX_SIZE+1;
+
+    /* set the interface */
+    sprintf(wreq.ifr_name, wificard);
+
+    /* check */
+    if((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) == -1) {
+        fprintf(stderr, "Cannot open socket for interface: %s\n", wificard);
+        return smprintf("n/a");
+    }
+    wreq.u.essid.pointer = id;
+    if (ioctl(sockfd,SIOCGIWESSID, &wreq) == -1) {
+        fprintf(stderr, "Get ESSID ioctl failed for interface %s\n", wificard);
+        return smprintf("n/a");
+    }
+
+    /* return the essid */
+    if (strcmp((char *)wreq.u.essid.pointer, "") == 0) {
+        return smprintf("n/a");
+    }
+    else {
+        return smprintf("%s", (char *)wreq.u.essid.pointer);
+    }
+}
+
 /* main function */
 int
 main(void)
diff --git a/slstatus.h b/slstatus.h
index 6f70a7b..7d0d887 100644
--- a/slstatus.h
+++ b/slstatus.h
@@ -35,3 +35,4 @@ char *uid(const char*);
 char *username(const char*);
 char *vol_perc(const char *);
 char *wifi_perc(const char *);
+char *wifi_essid(const char *);