root/trunk/wifidog/src/util.c @ 478

Revision 478, 6.0 KB (checked in by minaguib, 8 years ago)

Better logging of details and calling of mark_* (auth+online/offline)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1/********************************************************************\
2 * This program is free software; you can redistribute it and/or    *
3 * modify it under the terms of the GNU General Public License as   *
4 * published by the Free Software Foundation; either version 2 of   *
5 * the License, or (at your option) any later version.              *
6 *                                                                  *
7 * This program is distributed in the hope that it will be useful,  *
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of   *
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the    *
10 * GNU General Public License for more details.                     *
11 *                                                                  *
12 * You should have received a copy of the GNU General Public License*
13 * along with this program; if not, contact:                        *
14 *                                                                  *
15 * Free Software Foundation           Voice:  +1-617-542-5942       *
16 * 59 Temple Place - Suite 330        Fax:    +1-617-542-2652       *
17 * Boston, MA  02111-1307,  USA       gnu@gnu.org                   *
18 *                                                                  *
19 \********************************************************************/
20
21/*
22 * $Header$
23 */
24/**
25  @file util.c
26  @brief Misc utility functions
27  @author Copyright (C) 2004 Philippe April <papril777@yahoo.com>
28 */
29
30#define _GNU_SOURCE
31
32#include <stdio.h>
33#include <stdlib.h>
34#include <syslog.h>
35#include <errno.h>
36#include <pthread.h>
37#include <sys/wait.h>
38#include <sys/types.h>
39#include <sys/unistd.h>
40#include <netinet/in.h>
41#include <sys/ioctl.h>
42#include <net/if.h>
43
44#include <string.h>
45#include <pthread.h>
46#include <netdb.h>
47
48#include "safe.h"
49#include "util.h"
50#include "conf.h"
51#include "debug.h"
52
53static pthread_mutex_t ghbn_mutex = PTHREAD_MUTEX_INITIALIZER;
54
55/* XXX Do these need to be locked ? */
56static time_t last_online_time = 0;
57static time_t last_offline_time = 0;
58static time_t last_auth_online_time = 0;
59static time_t last_auth_offline_time = 0;
60
61/** Fork a child and execute a shell command, the parent
62 * process waits for the child to return and returns the child's exit()
63 * value.
64 * @return Return code of the command
65 */
66int
67execute(char *cmd_line, int quiet)
68{
69    int pid,
70        status,
71        rc;
72
73    const char *new_argv[4];
74    new_argv[0] = "/bin/sh";
75    new_argv[1] = "-c";
76    new_argv[2] = cmd_line;
77    new_argv[3] = NULL;
78
79    if ((pid = fork()) < 0) {    /* fork a child process           */
80        debug(LOG_ERR, "fork(): %s", strerror(errno));
81        exit(1);
82    } else if (pid == 0) {    /* for the child process:         */
83        /* We don't want to see any errors if quiet flag is on */
84        if (quiet) close(2);
85        if (execvp("/bin/sh", (char *const *)new_argv) < 0) {    /* execute the command  */
86            debug(LOG_ERR, "execvp(): %s", strerror(errno));
87            exit(1);
88        }
89    } else {        /* for the parent:      */
90        do {
91            rc = wait(&status);
92        } while (rc != pid && rc != -1);    /* wait for completion  */
93    }
94
95    return (WEXITSTATUS(status));
96}
97
98struct in_addr *
99wd_gethostbyname(const char *name)
100{
101        struct hostent *he;
102        struct in_addr *h_addr, *in_addr_temp;
103
104        /* XXX Calling function is reponsible for free() */
105
106        h_addr = safe_malloc(sizeof(struct in_addr));
107       
108        LOCK_GHBN();
109
110        he = gethostbyname(name);
111
112        if (he == NULL) {
113                free(h_addr);
114                UNLOCK_GHBN();
115                return NULL;
116        }
117
118        mark_online();
119
120        in_addr_temp = (struct in_addr *)he->h_addr_list[0];
121        h_addr->s_addr = in_addr_temp->s_addr;
122       
123        UNLOCK_GHBN();
124
125        return h_addr;
126}
127
128char *get_iface_ip(char *ifname) {
129    struct ifreq if_data;
130    struct in_addr in;
131    char *ip_str;
132    int sockd;
133    u_int32_t ip;
134
135    /* Create a socket */
136    if ((sockd = socket (AF_INET, SOCK_PACKET, htons(0x8086))) < 0) {
137        debug(LOG_ERR, "socket(): %s", strerror(errno));
138        return NULL;
139    }
140
141    /* Get IP of internal interface */
142    strcpy (if_data.ifr_name, ifname);
143
144    /* Get the IP address */
145    if (ioctl (sockd, SIOCGIFADDR, &if_data) < 0) {
146        debug(LOG_ERR, "ioctl(): SIOCGIFADDR %s", strerror(errno));
147        return NULL;
148    }
149    memcpy ((void *) &ip, (void *) &if_data.ifr_addr.sa_data + 2, 4);
150    in.s_addr = ip;
151
152    ip_str = (char *)inet_ntoa(in);
153    return safe_strdup(ip_str);
154}
155
156void mark_online() {
157        int before;
158        int after;
159
160        before = is_online();
161        time(&last_online_time);
162        after = is_online();
163
164        if (before != after) {
165                debug(LOG_INFO, "ONLINE status became %s", (after ? "ON" : "OFF"));
166        }
167
168}
169
170void mark_offline() {
171        int before;
172        int after;
173
174        before = is_online();
175        time(&last_offline_time);
176        after = is_online();
177
178        if (before != after) {
179                debug(LOG_INFO, "ONLINE status became %s", (after ? "ON" : "OFF"));
180        }
181
182        /* If we're offline it definately means the auth server is offline */
183        mark_auth_offline();
184
185}
186
187int is_online() {
188        if (last_online_time == 0 || (last_offline_time - last_online_time) >= (config_get_config()->checkinterval * 2) ) {
189                /* We're probably offline */
190                return (0);
191        }
192        else {
193                /* We're probably online */
194                return (1);
195        }
196}
197
198void mark_auth_online() {
199        int before;
200        int after;
201
202        before = is_auth_online();
203        time(&last_auth_online_time);
204        after = is_auth_online();
205
206        if (before != after) {
207                debug(LOG_INFO, "AUTH_ONLINE status became %s", (after ? "ON" : "OFF"));
208        }
209
210        /* If auth server is online it means we're definately online */
211        mark_online();
212
213}
214
215void mark_auth_offline() {
216        int before;
217        int after;
218
219        before = is_auth_online();
220        time(&last_auth_offline_time);
221        after = is_auth_online();
222
223        if (before != after) {
224                debug(LOG_INFO, "AUTH_ONLINE status became %s", (after ? "ON" : "OFF"));
225        }
226
227}
228
229int is_auth_online() {
230        if (!is_online()) {
231                /* If we're not online auth is definately not online :) */
232                return (0);
233        }
234        else if (last_auth_online_time == 0 || (last_auth_offline_time - last_auth_online_time) >= (config_get_config()->checkinterval * 2) ) {
235                /* Auth is  probably offline */
236                return (0);
237        }
238        else {
239                /* Auth is probably online */
240                return (1);
241        }
242}
243
Note: See TracBrowser for help on using the browser.