141 lines
3.9 KiB
Plaintext
141 lines
3.9 KiB
Plaintext
$OpenBSD: patch-src_print_wireless_info_c,v 1.4 2012/10/10 07:20:16 jasper Exp $
|
|
|
|
From 794151cfe76f80fb2c7eebb8d3fbbce8fc5ccb09 Mon Sep 17 00:00:00 2001
|
|
From: Jasper Lievisse Adriaanse <jasper@humppa.nl>
|
|
Date: Mon, 08 Oct 2012 20:15:14 +0000
|
|
Subject: Implement %essid and %signal for wireless on OpenBSD.
|
|
|
|
|
|
|
|
- handle down wireless interfaces just like ethernet interfaces (e.g. colors!)
|
|
(added bonus of this approach is that you still get nwid and signal strength
|
|
info of the interface, for example when it's part of a trunk device.)
|
|
|
|
--- src/print_wireless_info.c.orig Wed Oct 3 13:44:44 2012
|
|
+++ src/print_wireless_info.c Tue Oct 9 15:25:03 2012
|
|
@@ -25,6 +25,17 @@
|
|
#define IW_ESSID_MAX_SIZE IEEE80211_NWID_LEN
|
|
#endif
|
|
|
|
+#ifdef __OpenBSD__
|
|
+#include <sys/ioctl.h>
|
|
+#include <sys/socket.h>
|
|
+#include <net/if.h>
|
|
+#include <sys/types.h>
|
|
+#include <netinet/in.h>
|
|
+#include <netinet/if_ether.h>
|
|
+#include <net80211/ieee80211.h>
|
|
+#include <net80211/ieee80211_ioctl.h>
|
|
+#endif
|
|
+
|
|
#include "i3status.h"
|
|
|
|
#define WIRELESS_INFO_FLAG_HAS_ESSID (1 << 0)
|
|
@@ -220,6 +231,70 @@ static int get_wireless_info(const char *interface, wi
|
|
|
|
return 1;
|
|
#endif
|
|
+#ifdef __OpenBSD__
|
|
+ struct ifreq ifr;
|
|
+ struct ieee80211_bssid bssid;
|
|
+ struct ieee80211_nwid nwid;
|
|
+ struct ieee80211_nodereq nr;
|
|
+
|
|
+ struct ether_addr ea;
|
|
+
|
|
+ int s, len, ibssid, inwid;
|
|
+ u_int8_t zero_bssid[IEEE80211_ADDR_LEN];
|
|
+
|
|
+ if ((s = socket(AF_INET, SOCK_DGRAM, 0)) == -1)
|
|
+ return (0);
|
|
+
|
|
+ memset(&ifr, 0, sizeof(ifr));
|
|
+ ifr.ifr_data = (caddr_t)&nwid;
|
|
+ (void)strlcpy(ifr.ifr_name, interface, sizeof(ifr.ifr_name));
|
|
+ inwid = ioctl(s, SIOCG80211NWID, (caddr_t)&ifr);
|
|
+
|
|
+ memset(&bssid, 0, sizeof(bssid));
|
|
+ strlcpy(bssid.i_name, interface, sizeof(bssid.i_name));
|
|
+ ibssid = ioctl(s, SIOCG80211BSSID, &bssid);
|
|
+
|
|
+ if (ibssid != 0 || inwid != 0) {
|
|
+ close(s);
|
|
+ return 0;
|
|
+ }
|
|
+
|
|
+ /* NWID */
|
|
+ {
|
|
+ if (nwid.i_len <= IEEE80211_NWID_LEN)
|
|
+ len = nwid.i_len + 1;
|
|
+ else
|
|
+ len = IEEE80211_NWID_LEN + 1;
|
|
+
|
|
+ strncpy(&info->essid[0], nwid.i_nwid, len);
|
|
+ info->essid[IW_ESSID_MAX_SIZE] = '\0';
|
|
+ info->flags |= WIRELESS_INFO_FLAG_HAS_ESSID;
|
|
+ }
|
|
+
|
|
+ /* Signal strength */
|
|
+ {
|
|
+ memset(&zero_bssid, 0, sizeof(zero_bssid));
|
|
+ if (ibssid == 0 && memcmp(bssid.i_bssid, zero_bssid, IEEE80211_ADDR_LEN) != 0) {
|
|
+ memcpy(&ea.ether_addr_octet, bssid.i_bssid, sizeof(ea.ether_addr_octet));
|
|
+
|
|
+ bzero(&nr, sizeof(nr));
|
|
+ bcopy(bssid.i_bssid, &nr.nr_macaddr, sizeof(nr.nr_macaddr));
|
|
+ strlcpy(nr.nr_ifname, interface, sizeof(nr.nr_ifname));
|
|
+
|
|
+ if (ioctl(s, SIOCG80211NODE, &nr) == 0 && nr.nr_rssi) {
|
|
+ if (nr.nr_max_rssi)
|
|
+ info->signal_level_max = IEEE80211_NODEREQ_RSSI(&nr);
|
|
+ else
|
|
+ info->signal_level = nr.nr_rssi;
|
|
+
|
|
+ info->flags |= WIRELESS_INFO_FLAG_HAS_SIGNAL;
|
|
+ }
|
|
+ }
|
|
+ }
|
|
+
|
|
+ close(s);
|
|
+ return 1;
|
|
+#endif
|
|
return 0;
|
|
}
|
|
|
|
@@ -230,6 +305,15 @@ void print_wireless_info(yajl_gen json_gen, char *buff
|
|
|
|
INSTANCE(interface);
|
|
|
|
+ const char *ip_address = get_ip_addr(interface);
|
|
+ if (ip_address == NULL) {
|
|
+ START_COLOR("color_bad");
|
|
+ outwalk += sprintf(outwalk, "%s", format_down);
|
|
+ goto out;
|
|
+ } else {
|
|
+ START_COLOR("color_good");
|
|
+ }
|
|
+
|
|
if (get_wireless_info(interface, &info)) {
|
|
walk = format_up;
|
|
if (info.flags & WIRELESS_INFO_FLAG_HAS_QUALITY)
|
|
@@ -291,9 +375,8 @@ void print_wireless_info(yajl_gen json_gen, char *buff
|
|
}
|
|
|
|
if (BEGINS_WITH(walk+1, "ip")) {
|
|
- const char *ip_address = get_ip_addr(interface);
|
|
- outwalk += sprintf(outwalk, "%s", (ip_address ? ip_address : "no IP"));
|
|
- walk += strlen("ip");
|
|
+ outwalk += sprintf(outwalk, "%s", ip_address);
|
|
+ walk += strlen("ip");
|
|
}
|
|
|
|
#ifdef LINUX
|
|
@@ -308,6 +391,7 @@ void print_wireless_info(yajl_gen json_gen, char *buff
|
|
#endif
|
|
}
|
|
|
|
+out:
|
|
END_COLOR;
|
|
OUTPUT_FULL_TEXT(buffer);
|
|
}
|