[Listener] Add option -G (dump configuration)

This new option is just like Aggregator's -G option.
This commit is contained in:
Matteo Cypriani 2013-06-12 13:58:22 -04:00
parent 94e5c5cbab
commit a29a43a6fa
2 changed files with 38 additions and 11 deletions

View File

@ -31,6 +31,7 @@
#include <owlps.h> #include <owlps.h>
#include <owlps-client.h> #include <owlps-client.h>
#include <stdio.h>
#include <pcap.h> #include <pcap.h>
#include <sys/param.h> #include <sys/param.h>
@ -70,7 +71,7 @@
/* Arguments & program configuration */ /* Arguments & program configuration */
#define OPTIONS "ADf:hH:i:I:Kl:m:n:O:p:P:qr:R:t:T:vVw:" // getopt string #define OPTIONS "ADf:GhH:i:I:Kl:m:n:O:p:P:qr:R:t:T:vVw:" // getopt string
#define DEFAULT_CONFIG_FILE OWL_CONFIG_PREFIX "/owlps-listener.conf" #define DEFAULT_CONFIG_FILE OWL_CONFIG_PREFIX "/owlps-listener.conf"
enum {MODE_ACTIVE = 'a', MODE_PASSIVE = 'p', MODE_MIXED = 'm'} ; enum {MODE_ACTIVE = 'a', MODE_PASSIVE = 'p', MODE_MIXED = 'm'} ;
#define DEFAULT_AUTOCALIBRATION_HELLO_DELAY 15 // seconds #define DEFAULT_AUTOCALIBRATION_HELLO_DELAY 15 // seconds
@ -174,7 +175,7 @@ int parse_main_options(int argc, char **argv) ;
int parse_calibration_data(int argc, char **argv) ; int parse_calibration_data(int argc, char **argv) ;
#endif // OWLPS_LISTENER_USES_PTHREAD #endif // OWLPS_LISTENER_USES_PTHREAD
int check_configuration(void) ; int check_configuration(void) ;
void print_configuration(void) ; void print_configuration(FILE *stream) ;
#ifdef OWLPS_LISTENER_KEEPS_MONITOR #ifdef OWLPS_LISTENER_KEEPS_MONITOR
void* keep_mode_monitor(void *iface) ; void* keep_mode_monitor(void *iface) ;

View File

@ -20,7 +20,6 @@
#include "owlps-listener.h" #include "owlps-listener.h"
#include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <unistd.h> #include <unistd.h>
#include <inttypes.h> #include <inttypes.h>
@ -56,6 +55,13 @@ char *program_name = NULL ;
uint8_t my_mac_bytes[ETHER_ADDR_LEN] ; // AP MAC address uint8_t my_mac_bytes[ETHER_ADDR_LEN] ; // AP MAC address
char my_ip[INET_ADDRSTRLEN] ; // AP IP address char my_ip[INET_ADDRSTRLEN] ; // AP IP address
/* Will we dump the configuration?
* Note that we declare this option as a global variable because
* it must not appear in Confuse's options (to avoid dumping the
* dump_configuration option itself).
*/
bool dump_configuration = false ;
pcap_t *capture_handler = NULL ; // Packet capture descriptor pcap_t *capture_handler = NULL ; // Packet capture descriptor
int aggregation_sockfd ; int aggregation_sockfd ;
struct sockaddr_in aggregation_server ; struct sockaddr_in aggregation_server ;
@ -316,8 +322,20 @@ int initialise_configuration(int argc, char **argv)
if (! owl_run) if (! owl_run)
return ret ; return ret ;
/* Configuration dumping */
if (dump_configuration)
{
print_configuration(stdout) ;
owl_run = false ;
return 0 ;
}
/* Configuration printing */
if (VERBOSE_INFO) if (VERBOSE_INFO)
print_configuration() ; {
fprintf(stderr, "Configuration:\n") ;
print_configuration(stderr) ;
}
return 0 ; return 0 ;
} }
@ -515,6 +533,11 @@ int parse_main_options(int argc, char **argv)
break ; break ;
case 'f' : // Config file case 'f' : // Config file
break ; // (already parsed) break ; // (already parsed)
case 'G' :
dump_configuration = true ;
/* We must not turn owl_run false here, to avoid the default
* check on its value in initialise_configuration(). */
break ;
case 'H' : case 'H' :
#ifdef OWLPS_LISTENER_USES_PTHREAD #ifdef OWLPS_LISTENER_USES_PTHREAD
SET_AUTOCALIBRATION_HELLO_PORT(strtol(optarg, NULL, 0)) ; SET_AUTOCALIBRATION_HELLO_PORT(strtol(optarg, NULL, 0)) ;
@ -770,13 +793,12 @@ int check_configuration()
void print_configuration() void print_configuration(FILE *stream)
{ {
fprintf(stderr, "Configuration:\n") ;
#ifdef OWLPS_LISTENER_USES_CONFIG_FILE #ifdef OWLPS_LISTENER_USES_CONFIG_FILE
cfg_print(cfg, stderr) ; cfg_print(cfg, stream) ;
#else // OWLPS_LISTENER_USES_CONFIG_FILE #else // OWLPS_LISTENER_USES_CONFIG_FILE
fprintf(stderr, fprintf(stream,
"mode = %c\n" "mode = %c\n"
"aggregation_ip = \"%s\"\n" "aggregation_ip = \"%s\"\n"
"aggregation_port = %"PRIuFAST16"\n" "aggregation_port = %"PRIuFAST16"\n"
@ -1617,6 +1639,7 @@ void print_usage()
printf("Usage :\n" printf("Usage :\n"
"\t%s" "\t%s"
" [-f config_file]" " [-f config_file]"
" [-G]"
" [-D]" " [-D]"
" [-v[v[v[v]]] | -q]" " [-v[v[v[v]]] | -q]"
"\n\t" "\n\t"
@ -1644,11 +1667,14 @@ void print_usage()
"\t%s -V\n" "\t%s -V\n"
"Main options:\n" "Main options:\n"
"\t-h\t\tPrint this help.\n" "\t-h\t\tPrint this help message and exit.\n"
"\t-V\t\tShow version information.\n" "\t-V\t\tShow version information and exit.\n"
"\t-f config_file\tUse 'config_file' instead of the default" "\t-f config_file\tUse 'config_file' instead of the default"
" configuration\n\t\t\tfile (%s).\n\t\t\tAvailable only if the" " configuration\n\t\t\tfile (%s).\n\t\t\tAvailable only if the"
" program was linked against\n\t\t\tlibconfuse.\n" " program was linked against\n\t\t\tlibconfuse.\n"
"\t-G\t\tDump the configuration on the standard output and exit"
"\n\t\t\t(useful to generate a configuration file from the"
"\n\t\t\tcurrent set of options).\n"
"\t-D\t\tDaemon mode.\n" "\t-D\t\tDaemon mode.\n"
"\t-v\t\tBe verbose. You can use this option up to 4 times to" "\t-v\t\tBe verbose. You can use this option up to 4 times to"
"\n\t\t\tincrease the level of verbosity (1 = warnings," "\n\t\t\tincrease the level of verbosity (1 = warnings,"
@ -1699,7 +1725,7 @@ void print_usage()
"\t-K\tKeep the monitor mode up on wifi_iface. Use it with" "\t-K\tKeep the monitor mode up on wifi_iface. Use it with"
" buggy\n\t\tdrivers that disable monitor mode periodically." " buggy\n\t\tdrivers that disable monitor mode periodically."
" Available only\n\t\tif the program was compiled with the" " Available only\n\t\tif the program was compiled with the"
" option OWLPS_LISTENER_KEEPS_MONITOR.\n" " option\n\t\tOWLPS_LISTENER_KEEPS_MONITOR.\n"
, ,
program_name, program_name,
program_name, program_name,