#include <fcntl.h>
#include <ifaddrs.h>
#include <limits.h>
+#include <linux/wireless.h>
#include <locale.h>
#include <netdb.h>
#include <pwd.h>
#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>
setlocale(LC_TIME, "");
if(!strftime(buf, bufsize, timeformat, localtime(&tm))) {
setlocale(LC_TIME, "C");
+ free(buf);
fprintf(stderr, "Strftime failed.\n");
return smprintf("n/a");
}
char *
run_command(const char* command)
{
+ int good;
FILE *fp;
char buffer[64];
pclose(fp);
/* add nullchar at the end */
- buffer[strlen(buffer) - 1] = '\0';
+ for (int i = 0 ; i != sizeof(buffer) ; i++) {
+ if (buffer[i] == '\0') {
+ good = 1;
+ break;
+ }
+ }
+ if (good) {
+ buffer[strlen(buffer) - 1] = '\0';
+ }
/* return the output */
return smprintf("%s", buffer);
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)
argument = args[i];
char *res = argument.func(argument.args);
char *element = smprintf(argument.format, res);
+ if (element == NULL) {
+ element = smprintf("n/a");
+ fprintf(stderr, "Failed to format output.");
+ }
strcat(status_string, element);
free(res);
free(element);