PERFORMSTUN => PERFORMSTUNMASK. allow to specify stun using -o option

This commit is contained in:
Thomas Bernard 2018-07-06 13:23:22 +02:00
parent 8c91ff515e
commit 8bc6d6f556
2 changed files with 15 additions and 9 deletions

View File

@ -1182,7 +1182,7 @@ init(int argc, char * * argv, struct runtime_vars * v)
break; break;
case UPNPEXT_PERFORM_STUN: case UPNPEXT_PERFORM_STUN:
if(strcmp(ary_options[i].value, "yes") == 0) if(strcmp(ary_options[i].value, "yes") == 0)
SETFLAG(PERFORMSTUN); SETFLAG(PERFORMSTUNMASK);
break; break;
case UPNPEXT_STUN_HOST: case UPNPEXT_STUN_HOST:
ext_stun_host = ary_options[i].value; ext_stun_host = ary_options[i].value;
@ -1386,7 +1386,7 @@ init(int argc, char * * argv, struct runtime_vars * v)
return 1; return 1;
} }
#endif /* ENABLE_PCP */ #endif /* ENABLE_PCP */
if (GETFLAG(PERFORMSTUN) && !ext_stun_host) { if (GETFLAG(PERFORMSTUNMASK) && !ext_stun_host) {
fprintf(stderr, "You must specify ext_stun_host= when ext_perform_stun=yes\n"); fprintf(stderr, "You must specify ext_stun_host= when ext_perform_stun=yes\n");
return 1; return 1;
} }
@ -1414,9 +1414,14 @@ init(int argc, char * * argv, struct runtime_vars * v)
fprintf(stderr, "Option -%c takes one argument.\n", argv[i][1]); fprintf(stderr, "Option -%c takes one argument.\n", argv[i][1]);
break; break;
case 'o': case 'o':
if(i+1 < argc) if(i+1 < argc) {
use_ext_ip_addr = argv[++i]; i++;
else if (0 == strncasecmp(argv[i], "STUN:", 5)) {
SETFLAG(PERFORMSTUNMASK);
ext_stun_host = argv[i] + 5;
} else
use_ext_ip_addr = argv[i];
} else
fprintf(stderr, "Option -%c takes one argument.\n", argv[i][1]); fprintf(stderr, "Option -%c takes one argument.\n", argv[i][1]);
break; break;
case 't': case 't':
@ -1666,7 +1671,7 @@ init(int argc, char * * argv, struct runtime_vars * v)
goto print_usage; goto print_usage;
} }
if (use_ext_ip_addr && GETFLAG(PERFORMSTUN)) { if (use_ext_ip_addr && GETFLAG(PERFORMSTUNMASK)) {
fprintf(stderr, "Error: options ext_ip= and ext_perform_stun=yes cannot be specified together\n"); fprintf(stderr, "Error: options ext_ip= and ext_perform_stun=yes cannot be specified together\n");
return 1; return 1;
} }
@ -1854,6 +1859,7 @@ print_usage:
"\tDefault pid file is '%s'.\n" "\tDefault pid file is '%s'.\n"
"\tDefault config file is '%s'.\n" "\tDefault config file is '%s'.\n"
"\tWith -d miniupnpd will run as a standard program.\n" "\tWith -d miniupnpd will run as a standard program.\n"
"\t-o argument is either an IPv4 address or \"STUN:xx.xx.xx.xx\".\n"
#if defined(USE_PF) || defined(USE_IPF) #if defined(USE_PF) || defined(USE_IPF)
"\t-L sets packet log in pf and ipf on.\n" "\t-L sets packet log in pf and ipf on.\n"
#endif #endif
@ -1999,7 +2005,7 @@ main(int argc, char * * argv)
GETFLAG(ENABLEUPNPMASK) ? "UPnP-IGD " : "", GETFLAG(ENABLEUPNPMASK) ? "UPnP-IGD " : "",
ext_if_name, upnp_bootid); ext_if_name, upnp_bootid);
if(GETFLAG(PERFORMSTUN)) if(GETFLAG(PERFORMSTUNMASK))
{ {
int ret = update_ext_ip_addr_from_stun(1); int ret = update_ext_ip_addr_from_stun(1);
if (ret != 0) { if (ret != 0) {
@ -2214,7 +2220,7 @@ main(int argc, char * * argv)
if(should_send_public_address_change_notif) if(should_send_public_address_change_notif)
{ {
syslog(LOG_INFO, "should send external iface address change notification(s)"); syslog(LOG_INFO, "should send external iface address change notification(s)");
if(GETFLAG(PERFORMSTUN)) if(GETFLAG(PERFORMSTUNMASK))
update_ext_ip_addr_from_stun(0); update_ext_ip_addr_from_stun(0);
if (!use_ext_ip_addr) if (!use_ext_ip_addr)
{ {

View File

@ -77,7 +77,7 @@ extern int runtime_flags;
#define FORCEIGDDESCV1MASK 0x0800 #define FORCEIGDDESCV1MASK 0x0800
#endif #endif
#define PERFORMSTUN 0x1000 #define PERFORMSTUNMASK 0x1000
#define SETFLAG(mask) runtime_flags |= mask #define SETFLAG(mask) runtime_flags |= mask
#define GETFLAG(mask) (runtime_flags & mask) #define GETFLAG(mask) (runtime_flags & mask)