Annotation of embedaddon/coova-chilli/src/options.c, revision 1.1

1.1     ! misho       1: /* 
        !             2:  *
        !             3:  * chilli - ChilliSpot.org. A Wireless LAN Access Point Controller.
        !             4:  * Copyright (C) 2003, 2004, 2005 Mondru AB.
        !             5:  * Copyright (C) 2006 PicoPoint B.V.
        !             6:  * Copyright (c) 2006-2007 David Bird <david@coova.com>
        !             7:  *
        !             8:  * The contents of this file may be used under the terms of the GNU
        !             9:  * General Public License Version 2, provided that the above copyright
        !            10:  * notice and this permission notice is included in all copies or
        !            11:  * substantial portions of the software.
        !            12:  * 
        !            13:  */
        !            14: 
        !            15: #include "system.h"
        !            16: #include "tun.h"
        !            17: #include "ippool.h"
        !            18: #include "radius.h"
        !            19: #include "radius_wispr.h"
        !            20: #include "radius_chillispot.h"
        !            21: #include "redir.h"
        !            22: #include "syserr.h"
        !            23: #include "dhcp.h"
        !            24: #include "cmdline.h"
        !            25: #include "chilli.h"
        !            26: #include "options.h"
        !            27: 
        !            28: struct options_t options;
        !            29: 
        !            30: char *STRDUP(char *s) {
        !            31:   if (!s) return 0;
        !            32:   while (isspace(*s)) s++;
        !            33:   if (!*s) return 0;
        !            34:   return strdup(s);
        !            35: }
        !            36: 
        !            37: /* Get IP address and mask */
        !            38: int option_aton(struct in_addr *addr, struct in_addr *mask,
        !            39:                char *pool, int number) {
        !            40: 
        !            41:   /* Parse only first instance of network for now */
        !            42:   /* Eventually "number" will indicate the token which we want to parse */
        !            43: 
        !            44:   unsigned int a1, a2, a3, a4;
        !            45:   unsigned int m1, m2, m3, m4;
        !            46:   unsigned int m;
        !            47:   int masklog;
        !            48:   int c;
        !            49: 
        !            50:   c = sscanf(pool, "%u.%u.%u.%u/%u.%u.%u.%u",
        !            51:             &a1, &a2, &a3, &a4,
        !            52:             &m1, &m2, &m3, &m4);
        !            53: 
        !            54:   switch (c) {
        !            55:   case 4:
        !            56:     mask->s_addr = 0xffffffff;
        !            57:     break;
        !            58:   case 5:
        !            59:     if (m1 > 32) {
        !            60:       log_err(0, "Invalid mask");
        !            61:       return -1; /* Invalid mask */
        !            62:     }
        !            63:     mask->s_addr = htonl(0xffffffff << (32 - m1));
        !            64:     break;
        !            65:   case 8:
        !            66:     if (m1 >= 256 ||  m2 >= 256 || m3 >= 256 || m4 >= 256) {
        !            67:       log_err(0, "Invalid mask");
        !            68:       return -1; /* Wrong mask format */
        !            69:     }
        !            70:     m = m1 * 0x1000000 + m2 * 0x10000 + m3 * 0x100 + m4;
        !            71:     for (masklog = 0; ((1 << masklog) < ((~m)+1)); masklog++);
        !            72:     if (((~m)+1) != (1 << masklog)) {
        !            73:       log_err(0, "Invalid mask");
        !            74:       return -1; /* Wrong mask format (not all ones followed by all zeros)*/
        !            75:     }
        !            76:     mask->s_addr = htonl(m);
        !            77:     break;
        !            78:   default:
        !            79:     log_err(0, "Invalid mask");
        !            80:     return -1; /* Invalid mask */
        !            81:   }
        !            82: 
        !            83:   if (a1 >= 256 ||  a2 >= 256 || a3 >= 256 || a4 >= 256) {
        !            84:     log_err(0, "Wrong IP address format");
        !            85:     return -1;
        !            86:   }
        !            87:   else
        !            88:     addr->s_addr = htonl(a1 * 0x1000000 + a2 * 0x10000 + a3 * 0x100 + a4);
        !            89: 
        !            90:   return 0;
        !            91: }
        !            92: 
        !            93: static const char *description = 
        !            94:   "CoovaChilli - A Wireless LAN Access Point Controller.\n"
        !            95:   "  For more information on this project, visit: \n"
        !            96:   "  http://coova.org/wiki/index.php/CoovaChilli\n";
        !            97: 
        !            98: static const char *copyright = 
        !            99:   "Copyright (c) 2003-2005 Mondru AB., 2006-2007 David Bird, and others.\n"
        !           100:   "Licensed under the Gnu Public License (GPL).\n";
        !           101: 
        !           102: static const char *usage = \
        !           103:   "Usage: chilli [OPTIONS]...\n";
        !           104: 
        !           105: extern const char *gengetopt_args_info_help[];
        !           106: 
        !           107: static void
        !           108: options_print_version (void) {
        !           109:   printf ("%s %s\n", CMDLINE_PARSER_PACKAGE, CMDLINE_PARSER_VERSION);
        !           110: }
        !           111: 
        !           112: static void
        !           113: options_print_help (void) {
        !           114:   int i = 0;
        !           115:   options_print_version();
        !           116: 
        !           117:   printf("\n%s", description);
        !           118:   printf("\n%s\n", usage);
        !           119: 
        !           120:   while (gengetopt_args_info_help[i])
        !           121:     printf("%s\n", gengetopt_args_info_help[i++]);
        !           122: 
        !           123:   printf("\n%s\n", copyright);
        !           124: }
        !           125: 
        !           126: 
        !           127: /* Extract domain name and port from URL */
        !           128: int static get_namepart(char *src, char *host, int hostsize, int *port) {
        !           129:   char *slashslash = NULL;
        !           130:   char *slash = NULL;
        !           131:   char *colon = NULL;
        !           132:   int hostlen;
        !           133:   
        !           134:   *port = 0;
        !           135: 
        !           136:   if (!memcmp(src, "http://", 7)) {
        !           137:     *port = DHCP_HTTP;
        !           138:   }
        !           139:   else   if (!memcmp(src, "https://", 8)) {
        !           140:     *port = DHCP_HTTPS;
        !           141:   }
        !           142:   else {
        !           143:     log_err(0, "URL must start with http:// or https:// %s!", src);
        !           144:     return -1;
        !           145:   }
        !           146:   
        !           147:   /* The host name must be initiated by "//" and terminated by /, :  or \0 */
        !           148:   if (!(slashslash = strstr(src, "//"))) {
        !           149:     log_err(0, "// not found in url: %s!", src);
        !           150:     return -1;
        !           151:   }
        !           152:   slashslash+=2;
        !           153:   
        !           154:   slash = strstr(slashslash, "/");
        !           155:   colon = strstr(slashslash, ":");
        !           156:   
        !           157:   if ((slash != NULL) && (colon != NULL) &&
        !           158:       (slash < colon)) {
        !           159:     hostlen = slash - slashslash;
        !           160:   }
        !           161:   else if ((slash != NULL) && (colon == NULL)) {
        !           162:     hostlen = slash - slashslash;
        !           163:   }
        !           164:   else if (colon != NULL) {
        !           165:     hostlen = colon - slashslash;
        !           166:     if (1 != sscanf(colon+1, "%d", port)) {
        !           167:       log_err(0, "Not able to parse URL port: %s!", src);
        !           168:       return -1;
        !           169:     }
        !           170:   }
        !           171:   else {
        !           172:     hostlen = strlen(src);
        !           173:   }
        !           174: 
        !           175:   if (hostlen > (hostsize-1)) {
        !           176:     log_err(0, "URL hostname larger than %d: %s!", hostsize-1, src);
        !           177:     return -1;
        !           178:   }
        !           179: 
        !           180:   strncpy(host, slashslash, hostsize);
        !           181:   host[hostlen] = 0;
        !           182: 
        !           183:   return 0;
        !           184: }
        !           185: 
        !           186: int process_options(int argc, char **argv, int minimal) {
        !           187:   int reconfiguring = options.initialized;
        !           188:   struct gengetopt_args_info args_info;
        !           189:   struct hostent *host;
        !           190:   char hostname[USERURLSIZE];
        !           191:   int numargs;
        !           192:   int ret = -1;
        !           193: 
        !           194:   if (!reconfiguring)
        !           195:     memset(&options, 0, sizeof(options));
        !           196: 
        !           197:   memset(&args_info, 0, sizeof(args_info));
        !           198: 
        !           199:   if (cmdline_parser(argc, argv, &args_info) != 0) {
        !           200:     log_err(0, "Failed to parse command line options");
        !           201:     goto end_processing;
        !           202:   }
        !           203: 
        !           204:   if (args_info.version_given) {
        !           205:     options_print_version();
        !           206:     exit(0);
        !           207:   }
        !           208: 
        !           209:   if (args_info.help_given) {
        !           210:     options_print_help();
        !           211:     exit(0);
        !           212:   }
        !           213: 
        !           214:   if (cmdline_parser_configfile(args_info.conf_arg ? 
        !           215:                                args_info.conf_arg : 
        !           216:                                DEFCHILLICONF, 
        !           217:                                &args_info, 0, 0, 0)) {
        !           218:     log_err(0, "Failed to parse configuration file: %s!", 
        !           219:            args_info.conf_arg);
        !           220:     goto end_processing;
        !           221:   }
        !           222: 
        !           223:   /* Get the system default DNS entries */
        !           224:   if (!reconfiguring && res_init()) {
        !           225:     log_err(0, "Failed to update system DNS settings (res_init()!");
        !           226:     goto end_processing;
        !           227:   }
        !           228: 
        !           229:   /* Handle each option */
        !           230:   options.initialized = 1;
        !           231: 
        !           232:   if (args_info.debug_flag) 
        !           233:     options.debug = args_info.debugfacility_arg;
        !           234:   else 
        !           235:     options.debug = 0;
        !           236: 
        !           237:   /** simple configuration parameters **/
        !           238:   options.usetap = args_info.usetap_flag;
        !           239:   options.foreground = args_info.fg_flag;
        !           240:   options.interval = args_info.interval_arg;
        !           241:   options.lease = args_info.lease_arg;
        !           242:   options.dhcpstart = args_info.dhcpstart_arg;
        !           243:   options.dhcpend = args_info.dhcpend_arg;
        !           244:   options.eapolenable = args_info.eapolenable_flag;
        !           245:   options.swapoctets = args_info.swapoctets_flag;
        !           246:   options.usestatusfile = args_info.usestatusfile_flag;
        !           247:   options.logfacility = args_info.logfacility_arg;
        !           248:   options.chillixml = args_info.chillixml_flag;
        !           249:   options.macauth = args_info.macauth_flag;
        !           250:   options.macauthdeny = args_info.macauthdeny_flag;
        !           251:   options.uamport = args_info.uamport_arg;
        !           252:   options.uamuiport = args_info.uamuiport_arg;
        !           253:   options.macallowlocal = args_info.macallowlocal_flag;
        !           254:   options.no_uamsuccess = args_info.nouamsuccess_flag;
        !           255:   options.no_uamwispr = args_info.nouamwispr_flag;
        !           256:   options.wpaguests = args_info.wpaguests_flag;
        !           257:   options.openidauth = args_info.openidauth_flag;
        !           258:   options.defsessiontimeout = args_info.defsessiontimeout_arg;
        !           259:   options.definteriminterval = args_info.definteriminterval_arg;
        !           260:   options.defbandwidthmaxdown = args_info.defbandwidthmaxdown_arg;
        !           261:   options.defbandwidthmaxup = args_info.defbandwidthmaxup_arg;
        !           262:   options.defidletimeout = args_info.defidletimeout_arg;
        !           263:   options.radiusnasporttype = args_info.radiusnasporttype_arg;
        !           264:   options.radiusauthport = args_info.radiusauthport_arg;
        !           265:   options.radiusacctport = args_info.radiusacctport_arg;
        !           266:   options.coaport = args_info.coaport_arg;
        !           267:   options.coanoipcheck = args_info.coanoipcheck_flag;
        !           268:   options.radiustimeout = args_info.radiustimeout_arg;
        !           269:   options.radiusretry = args_info.radiusretry_arg;
        !           270:   options.radiusretrysec = args_info.radiusretrysec_arg;
        !           271:   options.proxyport = args_info.proxyport_arg;
        !           272:   options.txqlen = args_info.txqlen_arg;
        !           273:   options.postauth_proxyport = args_info.postauthproxyport_arg;
        !           274:   options.pap_always_ok = args_info.papalwaysok_flag;
        !           275:   options.acct_update = args_info.acctupdate_flag;
        !           276:   options.dhcpradius = args_info.dhcpradius_flag;
        !           277:   options.dhcpgwport = args_info.dhcpgatewayport_arg;
        !           278: 
        !           279:   if (args_info.dhcpgateway_arg &&
        !           280:       !inet_aton(args_info.dhcpgateway_arg, &options.dhcpgwip)) {
        !           281:     log_err(0, "Invalid DHCP gateway IP address: %s!", args_info.dhcpgateway_arg);
        !           282:     goto end_processing;
        !           283:   }
        !           284: 
        !           285:   if (args_info.dhcprelayagent_arg &&
        !           286:       !inet_aton(args_info.dhcprelayagent_arg, &options.dhcprelayip)) {
        !           287:     log_err(0, "Invalid DHCP gateway relay IP address: %s!", args_info.dhcprelayagent_arg);
        !           288:     goto end_processing;
        !           289:   }
        !           290: 
        !           291:   if (!reconfiguring) {
        !           292:     options.dhcpif = STRDUP(args_info.dhcpif_arg);
        !           293:   }
        !           294: 
        !           295:   if (!args_info.radiussecret_arg) {
        !           296:     log_err(0, "radiussecret must be specified!");
        !           297:     goto end_processing;
        !           298:   }
        !           299: 
        !           300:   if (!args_info.dhcpmac_arg) {
        !           301:     memset(options.dhcpmac, 0, PKT_ETH_ALEN);
        !           302:     options.dhcpusemac  = 0;
        !           303:   }
        !           304:   else {
        !           305:     unsigned int temp[PKT_ETH_ALEN];
        !           306:     char macstr[RADIUS_ATTR_VLEN];
        !           307:     int macstrlen;
        !           308:     int        i;
        !           309: 
        !           310:     if ((macstrlen = strlen(args_info.dhcpmac_arg)) >= (RADIUS_ATTR_VLEN-1)) {
        !           311:       log_err(0,
        !           312:              "MAC address too long");
        !           313:       goto end_processing;
        !           314:     }
        !           315: 
        !           316:     memcpy(macstr, args_info.dhcpmac_arg, macstrlen);
        !           317:     macstr[macstrlen] = 0;
        !           318: 
        !           319:     /* Replace anything but hex with space */
        !           320:     for (i=0; i<macstrlen; i++) 
        !           321:       if (!isxdigit(macstr[i])) macstr[i] = 0x20;
        !           322: 
        !           323:     if (sscanf (macstr, "%2x %2x %2x %2x %2x %2x", 
        !           324:                &temp[0], &temp[1], &temp[2], 
        !           325:                &temp[3], &temp[4], &temp[5]) != 6) {
        !           326:       log_err(0, "MAC conversion failed!");
        !           327:       return -1;
        !           328:     }
        !           329:     
        !           330:     for(i = 0; i < PKT_ETH_ALEN; i++) 
        !           331:       options.dhcpmac[i] = temp[i];
        !           332: 
        !           333:     options.dhcpusemac  = 1;
        !           334:   }
        !           335: 
        !           336:   if (!reconfiguring) {
        !           337:     if (args_info.net_arg) {
        !           338:       if (option_aton(&options.net, &options.mask, args_info.net_arg, 0)) {
        !           339:        log_err(0, "Invalid network address: %s!", args_info.net_arg);
        !           340:        goto end_processing;
        !           341:       }
        !           342:       if (!args_info.uamlisten_arg) {
        !           343:        options.uamlisten.s_addr = htonl(ntohl(options.net.s_addr)+1);
        !           344:       }
        !           345:       else if (!inet_aton(args_info.uamlisten_arg, &options.uamlisten)) {
        !           346:        log_err(0, "Invalid UAM IP address: %s!", args_info.uamlisten_arg);
        !           347:        goto end_processing;
        !           348:       }
        !           349:       options.dhcplisten.s_addr = options.uamlisten.s_addr;
        !           350:     }
        !           351:     else if (!minimal) {
        !           352:       log_err(0, "Network address must be specified ('net' parameter)!");
        !           353:       goto end_processing;
        !           354:     }
        !           355:   }
        !           356: 
        !           357:   log_dbg("DHCP Listen: %s", inet_ntoa(options.dhcplisten));
        !           358:   log_dbg("UAM Listen: %s", inet_ntoa(options.uamlisten));
        !           359: 
        !           360:   if (!args_info.uamserver_arg && !minimal) {
        !           361:     log_err(0, "WARNING: No uamserver defiend!");
        !           362:   }
        !           363: 
        !           364:   if (args_info.uamserver_arg) {
        !           365:     if (options.debug & DEBUG_CONF) {
        !           366:       log_dbg("Uamserver: %s\n", args_info.uamserver_arg);
        !           367:     }
        !           368:     memset(options.uamserver, 0, sizeof(options.uamserver));
        !           369:     options.uamserverlen = 0;
        !           370:     if (get_namepart(args_info.uamserver_arg, hostname, USERURLSIZE, 
        !           371:                     &options.uamserverport)) {
        !           372:       log_err(0, "Failed to parse uamserver: %s!", args_info.uamserver_arg);
        !           373:       goto end_processing;
        !           374:     }
        !           375:   
        !           376:     if (!(host = gethostbyname(hostname))) {
        !           377:       log_err(0, 
        !           378:              "Could not resolve IP address of uamserver: %s! [%s]", 
        !           379:              args_info.uamserver_arg, strerror(errno));
        !           380:       goto end_processing;
        !           381:     }
        !           382:     else {
        !           383:       int j = 0;
        !           384:       while (host->h_addr_list[j] != NULL) {
        !           385:        if (options.debug & DEBUG_CONF) {
        !           386:          log_dbg("Uamserver IP address #%d: %s\n", j,
        !           387:                 inet_ntoa(*(struct in_addr*) host->h_addr_list[j]));
        !           388:        }
        !           389:        if (options.uamserverlen>=UAMSERVER_MAX) {
        !           390:          log_err(0,
        !           391:                  "Too many IPs in uamserver %s!",
        !           392:                  args_info.uamserver_arg);
        !           393:          goto end_processing;
        !           394:        }
        !           395:        else {
        !           396:          options.uamserver[options.uamserverlen++] = 
        !           397:            *((struct in_addr*) host->h_addr_list[j++]);
        !           398:        }
        !           399:       }
        !           400:     }
        !           401:   }
        !           402: 
        !           403:   if (args_info.uamhomepage_arg) {
        !           404:     if (get_namepart(args_info.uamhomepage_arg, hostname, USERURLSIZE, 
        !           405:                     &options.uamhomepageport)) {
        !           406:       log_err(0,
        !           407:              "Failed to parse uamhomepage: %s!", args_info.uamhomepage_arg);
        !           408:       goto end_processing;
        !           409:     }
        !           410: 
        !           411:     if (!(host = gethostbyname(hostname))) {
        !           412:       log_err(0, 
        !           413:              "Invalid uamhomepage: %s! [%s]", 
        !           414:              args_info.uamhomepage_arg, strerror(errno));
        !           415:       goto end_processing;
        !           416:     }
        !           417:     else {
        !           418:       int j = 0;
        !           419:       while (host->h_addr_list[j] != NULL) {
        !           420:        if (options.uamserverlen>=UAMSERVER_MAX) {
        !           421:          log_err(0,
        !           422:                  "Too many IPs in uamhomepage %s!",
        !           423:                  args_info.uamhomepage_arg);
        !           424:          goto end_processing;
        !           425:        }
        !           426:        else {
        !           427:          options.uamserver[options.uamserverlen++] = 
        !           428:            *((struct in_addr*) host->h_addr_list[j++]);
        !           429:        }
        !           430:       }
        !           431:     }
        !           432:   }
        !           433: 
        !           434:   options.uamanydns = args_info.uamanydns_flag;
        !           435:   options.uamanyip = args_info.uamanyip_flag;
        !           436:   options.dnsparanoia = args_info.dnsparanoia_flag;
        !           437:   options.radiusoriginalurl = args_info.radiusoriginalurl_flag;
        !           438: 
        !           439:   /* pass-throughs */
        !           440:   memset(options.pass_throughs, 0, sizeof(options.pass_throughs));
        !           441:   options.num_pass_throughs = 0;
        !           442: 
        !           443:   for (numargs = 0; numargs < args_info.uamallowed_given; ++numargs) {
        !           444:     pass_throughs_from_string(options.pass_throughs,
        !           445:                              MAX_PASS_THROUGHS,
        !           446:                              &options.num_pass_throughs,
        !           447:                              args_info.uamallowed_arg[numargs]);
        !           448:   }
        !           449: 
        !           450:   if (options.uamdomains) {
        !           451:     for (numargs = 0; options.uamdomains[numargs]; ++numargs) 
        !           452:       free(options.uamdomains[numargs]);
        !           453:     free(options.uamdomains);
        !           454:   }
        !           455:   options.uamdomains=0;
        !           456: 
        !           457:   if (args_info.uamdomain_given) {
        !           458:     options.uamdomains = calloc(args_info.uamdomain_given+1, sizeof(char *));
        !           459:     for (numargs = 0; numargs < args_info.uamdomain_given; ++numargs) 
        !           460:       options.uamdomains[numargs] = STRDUP(args_info.uamdomain_arg[numargs]);
        !           461:   }
        !           462: 
        !           463:   if (!reconfiguring) {
        !           464:     options.allowdyn = 1;
        !           465: 
        !           466:     if (args_info.nodynip_flag) {
        !           467:       options.allowdyn = 0;
        !           468:     } else {
        !           469:       if (!args_info.dynip_arg) {
        !           470:        options.dynip = STRDUP(args_info.net_arg);
        !           471:       }
        !           472:       else {
        !           473:        struct in_addr addr;
        !           474:        struct in_addr mask;
        !           475:        options.dynip = STRDUP(args_info.dynip_arg);
        !           476:        if (option_aton(&addr, &mask, options.dynip, 0)) {
        !           477:          log_err(0, "Failed to parse dynamic IP address pool!");
        !           478:          goto end_processing;
        !           479:        }
        !           480:       }
        !           481:     }
        !           482:     
        !           483:     /* statip */
        !           484:     if (args_info.statip_arg) {
        !           485:       struct in_addr addr;
        !           486:       struct in_addr mask;
        !           487:       options.statip = STRDUP(args_info.statip_arg);
        !           488:       if (option_aton(&addr, &mask, options.statip, 0)) {
        !           489:        log_err(0, "Failed to parse static IP address pool!");
        !           490:        return -1;
        !           491:       }
        !           492:       options.allowstat = 1;
        !           493:     } else {
        !           494:       options.allowstat = 0;
        !           495:     }
        !           496:   }
        !           497: 
        !           498:   if (args_info.dns1_arg) {
        !           499:     if (!inet_aton(args_info.dns1_arg, &options.dns1)) {
        !           500:       log_err(0,
        !           501:              "Invalid primary DNS address: %s!", 
        !           502:              args_info.dns1_arg);
        !           503:       goto end_processing;
        !           504:     }
        !           505:   }
        !           506:   else if (_res.nscount >= 1) {
        !           507:     options.dns1 = _res.nsaddr_list[0].sin_addr;
        !           508:   }
        !           509:   else {
        !           510:     options.dns1.s_addr = 0;
        !           511:   }
        !           512: 
        !           513:   if (args_info.dns2_arg) {
        !           514:     if (!inet_aton(args_info.dns2_arg, &options.dns2)) {
        !           515:       log_err(0,
        !           516:              "Invalid secondary DNS address: %s!", 
        !           517:              args_info.dns1_arg);
        !           518:       goto end_processing;
        !           519:     }
        !           520:   }
        !           521:   else if (_res.nscount >= 2) {
        !           522:     options.dns2 = _res.nsaddr_list[1].sin_addr;
        !           523:   }
        !           524:   else {
        !           525:     options.dns2.s_addr = options.dns1.s_addr;
        !           526:   }
        !           527: 
        !           528: 
        !           529:   /* If no listen option is specified listen to any local port    */
        !           530:   /* Do hostname lookup to translate hostname to IP address       */
        !           531:   if (!reconfiguring) {
        !           532:     if (args_info.radiuslisten_arg) {
        !           533:       if (!(host = gethostbyname(args_info.radiuslisten_arg))) {
        !           534:        log_err(0, "Invalid listening address: %s! [%s]", 
        !           535:                args_info.radiuslisten_arg, strerror(errno));
        !           536:        goto end_processing;
        !           537:       }
        !           538:       else {
        !           539:        memcpy(&options.radiuslisten.s_addr, host->h_addr, host->h_length);
        !           540:       }
        !           541:     }
        !           542:     else {
        !           543:       options.radiuslisten.s_addr = htonl(INADDR_ANY);
        !           544:     }
        !           545:   }
        !           546: 
        !           547:   if (args_info.uamlogoutip_arg) {
        !           548:     if (!(host = gethostbyname(args_info.uamlogoutip_arg))) {
        !           549:       log_warn(0, "Invalid uamlogoutup address: %s! [%s]", 
        !           550:               args_info.uamlogoutip_arg, strerror(errno));
        !           551:     }
        !           552:     else {
        !           553:       memcpy(&options.uamlogout.s_addr, host->h_addr, host->h_length);
        !           554:     }
        !           555:   }
        !           556: 
        !           557:   if (args_info.postauthproxy_arg) {
        !           558:     if (!(host = gethostbyname(args_info.postauthproxy_arg))) {
        !           559:       log_warn(0, "Invalid postauthproxy address: %s! [%s]", 
        !           560:               args_info.postauthproxy_arg, strerror(errno));
        !           561:     }
        !           562:     else {
        !           563:       memcpy(&options.postauth_proxyip.s_addr, host->h_addr, host->h_length);
        !           564:     }
        !           565:   }
        !           566: 
        !           567:   /* If no option is specified terminate                          */
        !           568:   /* Do hostname lookup to translate hostname to IP address       */
        !           569:   if (args_info.radiusserver1_arg) {
        !           570:     if (!(host = gethostbyname(args_info.radiusserver1_arg))) {
        !           571:       log_err(0, "Invalid radiusserver1 address: %s! [%s]", 
        !           572:              args_info.radiusserver1_arg, strerror(errno));
        !           573:       goto end_processing;
        !           574:     }
        !           575:     else {
        !           576:       memcpy(&options.radiusserver1.s_addr, host->h_addr, host->h_length);
        !           577:     }
        !           578:   }
        !           579:   else {
        !           580:     log_err(0,
        !           581:            "No radiusserver1 address given!");
        !           582:     goto end_processing;
        !           583:   }
        !           584: 
        !           585:   /* radiusserver2 */
        !           586:   /* If no option is specified terminate                          */
        !           587:   /* Do hostname lookup to translate hostname to IP address       */
        !           588:   if (args_info.radiusserver2_arg) {
        !           589:     if (!(host = gethostbyname(args_info.radiusserver2_arg))) {
        !           590:       log_err(0, "Invalid radiusserver2 address: %s! [%s]", 
        !           591:              args_info.radiusserver2_arg, strerror(errno));
        !           592:       goto end_processing;
        !           593:     }
        !           594:     else {
        !           595:       memcpy(&options.radiusserver2.s_addr, host->h_addr, host->h_length);
        !           596:     }
        !           597:   }
        !           598:   else {
        !           599:     options.radiusserver2.s_addr = 0;
        !           600:   }
        !           601: 
        !           602:   /* If no listen option is specified listen to any local port    */
        !           603:   /* Do hostname lookup to translate hostname to IP address       */
        !           604:   if (!reconfiguring) {
        !           605:     if (args_info.proxylisten_arg) {
        !           606:       if (!(host = gethostbyname(args_info.proxylisten_arg))) {
        !           607:        log_err(0, 
        !           608:                "Invalid listening address: %s! [%s]", 
        !           609:                args_info.proxylisten_arg, strerror(errno));
        !           610:        goto end_processing;
        !           611:       }
        !           612:       else {
        !           613:        memcpy(&options.proxylisten.s_addr, host->h_addr, host->h_length);
        !           614:       }
        !           615:     }
        !           616:     else {
        !           617:       options.proxylisten.s_addr = htonl(INADDR_ANY);
        !           618:     }
        !           619: 
        !           620:     /* Store proxyclient as in_addr net and mask                       */
        !           621:     if (args_info.proxyclient_arg) {
        !           622:       if(option_aton(&options.proxyaddr, &options.proxymask, 
        !           623:                     args_info.proxyclient_arg, 0)) {
        !           624:        log_err(0,
        !           625:                "Invalid proxy client address: %s!", args_info.proxyclient_arg);
        !           626:        goto end_processing;
        !           627:       }
        !           628:     }
        !           629:     else {
        !           630:       options.proxyaddr.s_addr = ~0; /* Let nobody through */
        !           631:       options.proxymask.s_addr = 0; 
        !           632:     }
        !           633:   }
        !           634: 
        !           635: 
        !           636:   memset(options.macok, 0, sizeof(options.macok));
        !           637:   options.macoklen = 0;
        !           638:   for (numargs = 0; numargs < args_info.macallowed_given; ++numargs) {
        !           639:     if (options.debug & DEBUG_CONF) {
        !           640:       log_dbg("Macallowed #%d: %s\n", numargs, 
        !           641:              args_info.macallowed_arg[numargs]);
        !           642:     }
        !           643:     char *p1 = NULL;
        !           644:     char *p2 = NULL;
        !           645:     char *p3 = malloc(strlen(args_info.macallowed_arg[numargs])+1);
        !           646:     int i;
        !           647:     strcpy(p3, args_info.macallowed_arg[numargs]);
        !           648:     p1 = p3;
        !           649:     if ((p2 = strchr(p1, ','))) {
        !           650:       *p2 = '\0';
        !           651:     }
        !           652:     while (p1) {
        !           653:       if (options.macoklen>=MACOK_MAX) {
        !           654:        log_err(0,
        !           655:                "Too many addresses in macallowed %s!",
        !           656:                args_info.macallowed_arg);
        !           657:       }
        !           658:       else {
        !           659:        /* Replace anything but hex and comma with space */
        !           660:        for (i=0; i<strlen(p1); i++) 
        !           661:          if (!isxdigit(p1[i])) p1[i] = 0x20;
        !           662:       
        !           663:        if (sscanf (p1, "%2x %2x %2x %2x %2x %2x",
        !           664:                    &options.macok[options.macoklen][0], 
        !           665:                    &options.macok[options.macoklen][1], 
        !           666:                    &options.macok[options.macoklen][2], 
        !           667:                    &options.macok[options.macoklen][3], 
        !           668:                    &options.macok[options.macoklen][4], 
        !           669:                    &options.macok[options.macoklen][5]) != 6) {
        !           670:          log_err(0, "Failed to convert macallowed option to MAC Address");
        !           671:        }
        !           672:        else {
        !           673:          if (options.debug & DEBUG_CONF) {
        !           674:            log_dbg("Macallowed address #%d: %.2X-%.2X-%.2X-%.2X-%.2X-%.2X\n", 
        !           675:                   options.macoklen,
        !           676:                   options.macok[options.macoklen][0],
        !           677:                   options.macok[options.macoklen][1],
        !           678:                   options.macok[options.macoklen][2],
        !           679:                   options.macok[options.macoklen][3],
        !           680:                   options.macok[options.macoklen][4],
        !           681:                   options.macok[options.macoklen][5]);
        !           682:          }
        !           683:          options.macoklen++;
        !           684:        }
        !           685:       }
        !           686:       
        !           687:       if (p2) {
        !           688:        p1 = p2+1;
        !           689:        if ((p2 = strchr(p1, ','))) {
        !           690:          *p2 = '\0';
        !           691:        }
        !           692:       }
        !           693:       else {
        !           694:        p1 = NULL;
        !           695:       }
        !           696:     }
        !           697:     free(p3);
        !           698:   }
        !           699: 
        !           700:   /** string parameters **/
        !           701:   if (options.routeif) free(options.routeif);
        !           702:   options.routeif = STRDUP(args_info.routeif_arg);
        !           703: 
        !           704:   if (options.wwwdir) free(options.wwwdir);
        !           705:   options.wwwdir = STRDUP(args_info.wwwdir_arg);
        !           706: 
        !           707:   if (options.wwwbin) free(options.wwwbin);
        !           708:   options.wwwbin = STRDUP(args_info.wwwbin_arg);
        !           709: 
        !           710:   if (options.uamui) free(options.uamui);
        !           711:   options.uamui = STRDUP(args_info.uamui_arg);
        !           712: 
        !           713:   if (options.localusers) free(options.localusers);
        !           714:   options.localusers = STRDUP(args_info.localusers_arg);
        !           715: 
        !           716:   if (options.uamurl) free(options.uamurl);
        !           717:   options.uamurl = STRDUP(args_info.uamserver_arg);
        !           718: 
        !           719:   if (options.uamhomepage) free(options.uamhomepage);
        !           720:   options.uamhomepage = STRDUP(args_info.uamhomepage_arg);
        !           721: 
        !           722:   if (options.wisprlogin) free(options.wisprlogin);
        !           723:   options.wisprlogin = STRDUP(args_info.wisprlogin_arg);
        !           724: 
        !           725:   if (options.uamsecret) free(options.uamsecret);
        !           726:   options.uamsecret = STRDUP(args_info.uamsecret_arg);
        !           727: 
        !           728:   if (options.proxysecret) free(options.proxysecret);
        !           729:   if (!args_info.proxysecret_arg) {
        !           730:     options.proxysecret = STRDUP(args_info.radiussecret_arg);
        !           731:   }
        !           732:   else {
        !           733:     options.proxysecret = STRDUP(args_info.proxysecret_arg);
        !           734:   }
        !           735: 
        !           736:   if (options.macsuffix) free(options.macsuffix);
        !           737:   options.macsuffix = STRDUP(args_info.macsuffix_arg);
        !           738: 
        !           739:   if (options.macpasswd) free(options.macpasswd);
        !           740:   options.macpasswd = STRDUP(args_info.macpasswd_arg);
        !           741: 
        !           742:   if (options.adminuser) free(options.adminuser);
        !           743:   options.adminuser = STRDUP(args_info.adminuser_arg);
        !           744: 
        !           745:   if (options.adminpasswd) free(options.adminpasswd);
        !           746:   options.adminpasswd = STRDUP(args_info.adminpasswd_arg);
        !           747: 
        !           748:   if (options.ssid) free(options.ssid);
        !           749:   options.ssid = STRDUP(args_info.ssid_arg);
        !           750: 
        !           751:   if (options.nasmac) free(options.nasmac);
        !           752:   options.nasmac = STRDUP(args_info.nasmac_arg);
        !           753: 
        !           754:   if (options.nasip) free(options.nasip);
        !           755:   options.nasip = STRDUP(args_info.nasip_arg);
        !           756: 
        !           757:   if (options.tundev) free(options.tundev);
        !           758:   options.tundev = STRDUP(args_info.tundev_arg);
        !           759: 
        !           760:   if (options.radiusnasid) free(options.radiusnasid);
        !           761:   options.radiusnasid = STRDUP(args_info.radiusnasid_arg);
        !           762: 
        !           763:   if (options.radiuslocationid) free(options.radiuslocationid);
        !           764:   options.radiuslocationid = STRDUP(args_info.radiuslocationid_arg);
        !           765: 
        !           766:   if (options.radiuslocationname) free(options.radiuslocationname);
        !           767:   options.radiuslocationname = STRDUP(args_info.radiuslocationname_arg);
        !           768: 
        !           769:   if (options.locationname) free(options.locationname);
        !           770:   options.locationname = STRDUP(args_info.locationname_arg);
        !           771: 
        !           772:   if (options.radiussecret) free(options.radiussecret);
        !           773:   options.radiussecret = STRDUP(args_info.radiussecret_arg);
        !           774: 
        !           775:   if (options.cmdsocket) free(options.cmdsocket);
        !           776:   options.cmdsocket = STRDUP(args_info.cmdsocket_arg);
        !           777: 
        !           778:   if (options.domain) free(options.domain);
        !           779:   options.domain = STRDUP(args_info.domain_arg);
        !           780: 
        !           781:   if (options.ipup) free(options.ipup);
        !           782:   options.ipup = STRDUP(args_info.ipup_arg);
        !           783: 
        !           784:   if (options.ipdown) free(options.ipdown);
        !           785:   options.ipdown = STRDUP(args_info.ipdown_arg);
        !           786: 
        !           787:   if (options.conup) free(options.conup);
        !           788:   options.conup = STRDUP(args_info.conup_arg);
        !           789: 
        !           790:   if (options.condown) free(options.condown);
        !           791:   options.condown = STRDUP(args_info.condown_arg);
        !           792: 
        !           793:   if (options.pidfile) free(options.pidfile);
        !           794:   options.pidfile = STRDUP(args_info.pidfile_arg);
        !           795: 
        !           796:   if (options.statedir) free(options.statedir);
        !           797:   options.statedir = STRDUP(args_info.statedir_arg);
        !           798: 
        !           799:   ret = 0;
        !           800: 
        !           801:  end_processing:
        !           802:   cmdline_parser_free (&args_info);
        !           803: 
        !           804:   return ret;
        !           805: }
        !           806: 
        !           807: void reprocess_options(int argc, char **argv) {
        !           808:   struct options_t options2;
        !           809:   log_err(0, "Rereading configuration file and doing DNS lookup");
        !           810: 
        !           811:   memcpy(&options2, &options, sizeof(options)); /* Save original */
        !           812:   if (process_options(argc, argv, 0)) {
        !           813:     log_err(0, "Error reading configuration file!");
        !           814:     memcpy(&options, &options2, sizeof(options));
        !           815:   }
        !           816: }
        !           817: 

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>