2009-11-29 20:18:47 +02:00
|
|
|
/*
|
|
|
|
* hostapd / State dump
|
|
|
|
* Copyright (c) 2002-2009, Jouni Malinen <j@w1.fi>
|
|
|
|
*
|
2012-02-11 16:46:35 +02:00
|
|
|
* This software may be distributed under the terms of the BSD license.
|
|
|
|
* See README for more details.
|
2009-11-29 20:18:47 +02:00
|
|
|
*/
|
|
|
|
|
2009-12-26 00:05:40 +02:00
|
|
|
#include "utils/includes.h"
|
2011-09-12 22:15:13 +03:00
|
|
|
#include <time.h>
|
2009-11-29 20:18:47 +02:00
|
|
|
|
2009-12-26 00:05:40 +02:00
|
|
|
#include "utils/common.h"
|
2009-11-29 20:18:47 +02:00
|
|
|
#include "eapol_auth/eapol_auth_sm.h"
|
2009-11-29 23:16:04 +02:00
|
|
|
#include "eapol_auth/eapol_auth_sm_i.h"
|
2009-11-29 20:18:47 +02:00
|
|
|
#include "eap_server/eap.h"
|
2009-12-25 01:12:50 +02:00
|
|
|
#include "ap/hostapd.h"
|
2009-12-26 00:05:40 +02:00
|
|
|
#include "ap/ap_config.h"
|
2009-12-25 01:12:50 +02:00
|
|
|
#include "ap/sta_info.h"
|
2009-12-25 14:20:35 +02:00
|
|
|
#include "dump_state.h"
|
2013-01-06 20:39:30 +02:00
|
|
|
#include "ap/ap_drv_ops.h"
|
2009-11-29 20:18:47 +02:00
|
|
|
|
|
|
|
|
|
|
|
static void ieee802_1x_dump_state(FILE *f, const char *prefix,
|
|
|
|
struct sta_info *sta)
|
|
|
|
{
|
|
|
|
struct eapol_state_machine *sm = sta->eapol_sm;
|
|
|
|
if (sm == NULL)
|
|
|
|
return;
|
|
|
|
eapol_auth_dump_state(f, prefix, sm);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* hostapd_dump_state - SIGUSR1 handler to dump hostapd state to a text file
|
|
|
|
*/
|
|
|
|
static void hostapd_dump_state(struct hostapd_data *hapd)
|
|
|
|
{
|
|
|
|
FILE *f;
|
|
|
|
time_t now;
|
|
|
|
struct sta_info *sta;
|
|
|
|
|
|
|
|
if (!hapd->conf->dump_log_name) {
|
|
|
|
wpa_printf(MSG_DEBUG, "Dump file not defined - ignoring dump "
|
|
|
|
"request");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
wpa_printf(MSG_DEBUG, "Dumping hostapd state to '%s'",
|
|
|
|
hapd->conf->dump_log_name);
|
|
|
|
f = fopen(hapd->conf->dump_log_name, "w");
|
|
|
|
if (f == NULL) {
|
|
|
|
wpa_printf(MSG_WARNING, "Could not open dump file '%s' for "
|
|
|
|
"writing.", hapd->conf->dump_log_name);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
time(&now);
|
|
|
|
fprintf(f, "hostapd state dump - %s", ctime(&now));
|
|
|
|
|
|
|
|
for (sta = hapd->sta_list; sta != NULL; sta = sta->next) {
|
|
|
|
fprintf(f, "\nSTA=" MACSTR "\n", MAC2STR(sta->addr));
|
|
|
|
ieee802_1x_dump_state(f, " ", sta);
|
|
|
|
}
|
|
|
|
|
|
|
|
fclose(f);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int handle_dump_state_iface(struct hostapd_iface *iface, void *ctx)
|
|
|
|
{
|
|
|
|
size_t i;
|
|
|
|
|
|
|
|
for (i = 0; i < iface->num_bss; i++)
|
|
|
|
hostapd_dump_state(iface->bss[i]);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|