1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
/*
* $Id: radstatus.c,v 1.8 2007/04/13 14:20:44 pnixon Exp $
*
* Copyright (C) 1995,1996 Lars Fenneberg
*
* See the file COPYRIGHT for the respective terms and conditions.
* If the file is missing contact me at lf@elemental.net
* and I'll send you a copy.
*
*/
/* FIX ME FIX ME FIX ME
* This is broken, now that send_server requires the secret to be passed
* It will need to be collected as an additional argument on command line
*/
#define FIX_ME_SECRET "fixme"
static char rcsid[] =
"$Id: radstatus.c,v 1.8 2007/04/13 14:20:44 pnixon Exp $";
#include <config.h>
#include <includes.h>
#include <freeradius-client.h>
#include <pathnames.h>
#include <messages.h>
static char *pname;
void usage(void)
{
fprintf(stderr,"Usage: %s [-Vh] [-f <config_file>] [server[:port[:secret]] ...\n\n", pname);
fprintf(stderr," -V output version information\n");
fprintf(stderr," -h output this text\n");
fprintf(stderr," -f filename of alternate config file\n");
exit(ERROR_RC);
}
void version(void)
{
fprintf(stderr,"%s: %s\n", pname ,rcsid);
exit(ERROR_RC);
}
int main (int argc, char **argv)
{
int result = ERROR_RC;
int c,i;
char *p, msg[4096];
SERVER *srv;
char *path_radiusclient_conf = RC_CONFIG_FILE;
rc_handle *rh;
extern int optind;
pname = (pname = strrchr(argv[0],'/'))?pname+1:argv[0];
rc_openlog(pname);
while ((c = getopt(argc,argv,"hVf:")) > 0)
{
switch(c) {
case 'f':
path_radiusclient_conf = optarg;
break;
case 'V':
version();
break;
case 'h':
usage();
break;
default:
exit(ERROR_RC);
break;
}
}
argc -= optind;
argv += optind;
if ((rh = rc_read_config(path_radiusclient_conf)) == NULL)
exit(ERROR_RC);
if (rc_read_dictionary(rh, rc_conf_str(rh, "dictionary")) != 0)
exit (ERROR_RC);
if (argc > 0) {
for (i = 0; i < argc; i++) {
if ((p = strchr(argv[i], ':')) == NULL) {
result = rc_check(rh, argv[i],FIX_ME_SECRET,rc_getport(AUTH), msg);
} else if (!strcmp(p+1, "auth")) {
*p = '\0';
result = rc_check(rh, argv[i],FIX_ME_SECRET,rc_getport(AUTH), msg);
} else if (!strcmp(p+1, "acct")) {
*p = '\0';
result = rc_check(rh, argv[i],FIX_ME_SECRET,rc_getport(ACCT), msg);
} else {
*p = '\0';
result = rc_check(rh, argv[i],FIX_ME_SECRET,atoi(p+1), msg);
}
if (result == OK_RC)
fputs(msg, stdout);
else
printf(SC_STATUS_FAILED);
}
} else {
srv = rc_conf_srv(rh, "authserver");
for(i=0; i<srv->max ; i++)
{
result = rc_check(rh, srv->name[i], srv->secret[i], srv->port[i], msg);
fputs(msg, stdout);
}
srv = rc_conf_srv(rh, "acctserver");
for(i=0; i<srv->max ; i++)
{
result = rc_check(rh, srv->name[i], srv->secret[i], srv->port[i], msg);
fputs(msg, stdout);
}
}
return 0;
}
|