mirror of
https://github.com/bol-van/zapret.git
synced 2024-12-22 14:26:03 +00:00
tpws: --dry-run
This commit is contained in:
parent
b14ff9b647
commit
d4ff423add
126
tpws/tpws.c
126
tpws/tpws.c
@ -175,6 +175,7 @@ static void exithelp(void)
|
|||||||
#endif
|
#endif
|
||||||
" --debug=0|1|2|syslog|@<filename>\t; 1 and 2 means log to console and set debug level. for other targets use --debug-level.\n"
|
" --debug=0|1|2|syslog|@<filename>\t; 1 and 2 means log to console and set debug level. for other targets use --debug-level.\n"
|
||||||
" --debug-level=0|1|2\t\t\t; specify debug level\n"
|
" --debug-level=0|1|2\t\t\t; specify debug level\n"
|
||||||
|
" --dry-run\t\t\t\t; verify parameters and exit with code 0 if successful\n"
|
||||||
"\nMULTI-STRATEGY:\n"
|
"\nMULTI-STRATEGY:\n"
|
||||||
" --new\t\t\t\t\t; begin new strategy\n"
|
" --new\t\t\t\t\t; begin new strategy\n"
|
||||||
" --skip\t\t\t\t\t; do not use this strategy\n"
|
" --skip\t\t\t\t\t; do not use this strategy\n"
|
||||||
@ -569,7 +570,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
int option_index = 0;
|
int option_index = 0;
|
||||||
int v, i;
|
int v, i;
|
||||||
bool bSkip=false;
|
bool bSkip=false, bDry=false;
|
||||||
struct hostlist_file *anon_hl = NULL, *anon_hl_exclude = NULL;
|
struct hostlist_file *anon_hl = NULL, *anon_hl_exclude = NULL;
|
||||||
struct ipset_file *anon_ips = NULL, *anon_ips_exclude = NULL;
|
struct ipset_file *anon_ips = NULL, *anon_ips_exclude = NULL;
|
||||||
|
|
||||||
@ -667,40 +668,41 @@ void parse_params(int argc, char *argv[])
|
|||||||
{ "pidfile",required_argument,0,0 },// optidx=44
|
{ "pidfile",required_argument,0,0 },// optidx=44
|
||||||
{ "debug",optional_argument,0,0 },// optidx=45
|
{ "debug",optional_argument,0,0 },// optidx=45
|
||||||
{ "debug-level",required_argument,0,0 },// optidx=46
|
{ "debug-level",required_argument,0,0 },// optidx=46
|
||||||
{ "local-rcvbuf",required_argument,0,0 },// optidx=47
|
{ "dry-run",no_argument,0,0 },// optidx=47
|
||||||
{ "local-sndbuf",required_argument,0,0 },// optidx=48
|
{ "local-rcvbuf",required_argument,0,0 },// optidx=48
|
||||||
{ "remote-rcvbuf",required_argument,0,0 },// optidx=49
|
{ "local-sndbuf",required_argument,0,0 },// optidx=49
|
||||||
{ "remote-sndbuf",required_argument,0,0 },// optidx=50
|
{ "remote-rcvbuf",required_argument,0,0 },// optidx=50
|
||||||
{ "socks",no_argument,0,0 },// optidx=51
|
{ "remote-sndbuf",required_argument,0,0 },// optidx=51
|
||||||
{ "no-resolve",no_argument,0,0 },// optidx=52
|
{ "socks",no_argument,0,0 },// optidx=52
|
||||||
{ "resolver-threads",required_argument,0,0 },// optidx=53
|
{ "no-resolve",no_argument,0,0 },// optidx=53
|
||||||
{ "skip-nodelay",no_argument,0,0 },// optidx=54
|
{ "resolver-threads",required_argument,0,0 },// optidx=54
|
||||||
{ "tamper-start",required_argument,0,0 },// optidx=55
|
{ "skip-nodelay",no_argument,0,0 },// optidx=55
|
||||||
{ "tamper-cutoff",required_argument,0,0 },// optidx=56
|
{ "tamper-start",required_argument,0,0 },// optidx=56
|
||||||
{ "connect-bind-addr",required_argument,0,0 },// optidx=57
|
{ "tamper-cutoff",required_argument,0,0 },// optidx=57
|
||||||
|
{ "connect-bind-addr",required_argument,0,0 },// optidx=58
|
||||||
|
|
||||||
{ "new",no_argument,0,0 }, // optidx=58
|
{ "new",no_argument,0,0 }, // optidx=59
|
||||||
{ "skip",no_argument,0,0 }, // optidx=59
|
{ "skip",no_argument,0,0 }, // optidx=60
|
||||||
{ "filter-l3",required_argument,0,0 }, // optidx=60
|
{ "filter-l3",required_argument,0,0 }, // optidx=61
|
||||||
{ "filter-tcp",required_argument,0,0 }, // optidx=61
|
{ "filter-tcp",required_argument,0,0 }, // optidx=63
|
||||||
{ "filter-l7",required_argument,0,0 }, // optidx=62
|
{ "filter-l7",required_argument,0,0 }, // optidx=64
|
||||||
{ "ipset",required_argument,0,0 }, // optidx=63
|
{ "ipset",required_argument,0,0 }, // optidx=65
|
||||||
{ "ipset-ip",required_argument,0,0 }, // optidx=64
|
{ "ipset-ip",required_argument,0,0 }, // optidx=66
|
||||||
{ "ipset-exclude",required_argument,0,0 }, // optidx=65
|
{ "ipset-exclude",required_argument,0,0 }, // optidx=67
|
||||||
{ "ipset-exclude-ip",required_argument,0,0 }, // optidx=66
|
{ "ipset-exclude-ip",required_argument,0,0 }, // optidx=68
|
||||||
|
|
||||||
#if defined(__FreeBSD__)
|
#if defined(__FreeBSD__)
|
||||||
{ "enable-pf",no_argument,0,0 },// optidx=67
|
{ "enable-pf",no_argument,0,0 },// optidx=68
|
||||||
#elif defined(__APPLE__)
|
#elif defined(__APPLE__)
|
||||||
{ "local-tcp-user-timeout",required_argument,0,0 }, // optidx=67
|
{ "local-tcp-user-timeout",required_argument,0,0 }, // optidx=68
|
||||||
{ "remote-tcp-user-timeout",required_argument,0,0 }, // optidx=68
|
{ "remote-tcp-user-timeout",required_argument,0,0 }, // optidx=69
|
||||||
#elif defined(__linux__)
|
#elif defined(__linux__)
|
||||||
{ "local-tcp-user-timeout",required_argument,0,0 }, // optidx=67
|
{ "local-tcp-user-timeout",required_argument,0,0 }, // optidx=68
|
||||||
{ "remote-tcp-user-timeout",required_argument,0,0 }, // optidx=68
|
{ "remote-tcp-user-timeout",required_argument,0,0 }, // optidx=69
|
||||||
{ "mss",required_argument,0,0 }, // optidx=69
|
{ "mss",required_argument,0,0 }, // optidx=70
|
||||||
{ "fix-seg",optional_argument,0,0 }, // optidx=70
|
{ "fix-seg",optional_argument,0,0 }, // optidx=71
|
||||||
#ifdef SPLICE_PRESENT
|
#ifdef SPLICE_PRESENT
|
||||||
{ "nosplice",no_argument,0,0 }, // optidx=71
|
{ "nosplice",no_argument,0,0 }, // optidx=72
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
{ "hostlist-auto-retrans-threshold",optional_argument,0,0}, // ignored. for nfqws command line compatibility
|
{ "hostlist-auto-retrans-threshold",optional_argument,0,0}, // ignored. for nfqws command line compatibility
|
||||||
@ -708,7 +710,11 @@ void parse_params(int argc, char *argv[])
|
|||||||
};
|
};
|
||||||
while ((v = getopt_long_only(argc, argv, "", long_options, &option_index)) != -1)
|
while ((v = getopt_long_only(argc, argv, "", long_options, &option_index)) != -1)
|
||||||
{
|
{
|
||||||
if (v) exithelp_clean();
|
if (v)
|
||||||
|
if (bDry)
|
||||||
|
exit_clean(1);
|
||||||
|
else
|
||||||
|
exithelp_clean();
|
||||||
switch (option_index)
|
switch (option_index)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
@ -1142,41 +1148,44 @@ void parse_params(int argc, char *argv[])
|
|||||||
case 46: /* debug-level */
|
case 46: /* debug-level */
|
||||||
params.debug = atoi(optarg);
|
params.debug = atoi(optarg);
|
||||||
break;
|
break;
|
||||||
case 47: /* local-rcvbuf */
|
case 47: /* dry-run */
|
||||||
|
bDry = true;
|
||||||
|
break;
|
||||||
|
case 48: /* local-rcvbuf */
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
params.local_rcvbuf = atoi(optarg)/2;
|
params.local_rcvbuf = atoi(optarg)/2;
|
||||||
#else
|
#else
|
||||||
params.local_rcvbuf = atoi(optarg);
|
params.local_rcvbuf = atoi(optarg);
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case 48: /* local-sndbuf */
|
case 49: /* local-sndbuf */
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
params.local_sndbuf = atoi(optarg)/2;
|
params.local_sndbuf = atoi(optarg)/2;
|
||||||
#else
|
#else
|
||||||
params.local_sndbuf = atoi(optarg);
|
params.local_sndbuf = atoi(optarg);
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case 49: /* remote-rcvbuf */
|
case 50: /* remote-rcvbuf */
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
params.remote_rcvbuf = atoi(optarg)/2;
|
params.remote_rcvbuf = atoi(optarg)/2;
|
||||||
#else
|
#else
|
||||||
params.remote_rcvbuf = atoi(optarg);
|
params.remote_rcvbuf = atoi(optarg);
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case 50: /* remote-sndbuf */
|
case 51: /* remote-sndbuf */
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
params.remote_sndbuf = atoi(optarg)/2;
|
params.remote_sndbuf = atoi(optarg)/2;
|
||||||
#else
|
#else
|
||||||
params.remote_sndbuf = atoi(optarg);
|
params.remote_sndbuf = atoi(optarg);
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case 51: /* socks */
|
case 52: /* socks */
|
||||||
params.proxy_type = CONN_TYPE_SOCKS;
|
params.proxy_type = CONN_TYPE_SOCKS;
|
||||||
break;
|
break;
|
||||||
case 52: /* no-resolve */
|
case 53: /* no-resolve */
|
||||||
params.no_resolve = true;
|
params.no_resolve = true;
|
||||||
break;
|
break;
|
||||||
case 53: /* resolver-threads */
|
case 54: /* resolver-threads */
|
||||||
params.resolver_threads = atoi(optarg);
|
params.resolver_threads = atoi(optarg);
|
||||||
if (params.resolver_threads<1 || params.resolver_threads>300)
|
if (params.resolver_threads<1 || params.resolver_threads>300)
|
||||||
{
|
{
|
||||||
@ -1184,10 +1193,10 @@ void parse_params(int argc, char *argv[])
|
|||||||
exit_clean(1);
|
exit_clean(1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 54: /* skip-nodelay */
|
case 55: /* skip-nodelay */
|
||||||
params.skip_nodelay = true;
|
params.skip_nodelay = true;
|
||||||
break;
|
break;
|
||||||
case 55: /* tamper-start */
|
case 56: /* tamper-start */
|
||||||
{
|
{
|
||||||
const char *p=optarg;
|
const char *p=optarg;
|
||||||
if (*p=='n')
|
if (*p=='n')
|
||||||
@ -1201,7 +1210,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
params.tamper_lim = true;
|
params.tamper_lim = true;
|
||||||
break;
|
break;
|
||||||
case 56: /* tamper-cutoff */
|
case 57: /* tamper-cutoff */
|
||||||
{
|
{
|
||||||
const char *p=optarg;
|
const char *p=optarg;
|
||||||
if (*p=='n')
|
if (*p=='n')
|
||||||
@ -1215,7 +1224,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
params.tamper_lim = true;
|
params.tamper_lim = true;
|
||||||
break;
|
break;
|
||||||
case 57: /* connect-bind-addr */
|
case 58: /* connect-bind-addr */
|
||||||
{
|
{
|
||||||
char *p = strchr(optarg,'%');
|
char *p = strchr(optarg,'%');
|
||||||
if (p) *p++=0;
|
if (p) *p++=0;
|
||||||
@ -1243,7 +1252,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
||||||
case 58: /* new */
|
case 59: /* new */
|
||||||
if (bSkip)
|
if (bSkip)
|
||||||
{
|
{
|
||||||
dp_clear(dp);
|
dp_clear(dp);
|
||||||
@ -1264,31 +1273,31 @@ void parse_params(int argc, char *argv[])
|
|||||||
anon_hl = anon_hl_exclude = NULL;
|
anon_hl = anon_hl_exclude = NULL;
|
||||||
anon_ips = anon_ips_exclude = NULL;
|
anon_ips = anon_ips_exclude = NULL;
|
||||||
break;
|
break;
|
||||||
case 59: /* skip */
|
case 60: /* skip */
|
||||||
bSkip = true;
|
bSkip = true;
|
||||||
break;
|
break;
|
||||||
case 60: /* filter-l3 */
|
case 61: /* filter-l3 */
|
||||||
if (!wf_make_l3(optarg,&dp->filter_ipv4,&dp->filter_ipv6))
|
if (!wf_make_l3(optarg,&dp->filter_ipv4,&dp->filter_ipv6))
|
||||||
{
|
{
|
||||||
DLOG_ERR("bad value for --filter-l3\n");
|
DLOG_ERR("bad value for --filter-l3\n");
|
||||||
exit_clean(1);
|
exit_clean(1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 61: /* filter-tcp */
|
case 62: /* filter-tcp */
|
||||||
if (!parse_pf_list(optarg,&dp->pf_tcp))
|
if (!parse_pf_list(optarg,&dp->pf_tcp))
|
||||||
{
|
{
|
||||||
DLOG_ERR("Invalid port filter : %s\n",optarg);
|
DLOG_ERR("Invalid port filter : %s\n",optarg);
|
||||||
exit_clean(1);
|
exit_clean(1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 62: /* filter-l7 */
|
case 63: /* filter-l7 */
|
||||||
if (!parse_l7_list(optarg,&dp->filter_l7))
|
if (!parse_l7_list(optarg,&dp->filter_l7))
|
||||||
{
|
{
|
||||||
DLOG_ERR("Invalid l7 filter : %s\n",optarg);
|
DLOG_ERR("Invalid l7 filter : %s\n",optarg);
|
||||||
exit_clean(1);
|
exit_clean(1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 63: /* ipset */
|
case 64: /* ipset */
|
||||||
if (bSkip) break;
|
if (bSkip) break;
|
||||||
if (!RegisterIpset(dp, false, optarg))
|
if (!RegisterIpset(dp, false, optarg))
|
||||||
{
|
{
|
||||||
@ -1297,7 +1306,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
params.tamper = true;
|
params.tamper = true;
|
||||||
break;
|
break;
|
||||||
case 64: /* ipset-ip */
|
case 65: /* ipset-ip */
|
||||||
if (bSkip) break;
|
if (bSkip) break;
|
||||||
if (!anon_ips && !(anon_ips=RegisterIpset(dp, false, NULL)))
|
if (!anon_ips && !(anon_ips=RegisterIpset(dp, false, NULL)))
|
||||||
{
|
{
|
||||||
@ -1311,7 +1320,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
params.tamper = true;
|
params.tamper = true;
|
||||||
break;
|
break;
|
||||||
case 65: /* ipset-exclude */
|
case 66: /* ipset-exclude */
|
||||||
if (bSkip) break;
|
if (bSkip) break;
|
||||||
if (!RegisterIpset(dp, true, optarg))
|
if (!RegisterIpset(dp, true, optarg))
|
||||||
{
|
{
|
||||||
@ -1320,7 +1329,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
params.tamper = true;
|
params.tamper = true;
|
||||||
break;
|
break;
|
||||||
case 66: /* ipset-exclude-ip */
|
case 67: /* ipset-exclude-ip */
|
||||||
if (bSkip) break;
|
if (bSkip) break;
|
||||||
if (!anon_ips_exclude && !(anon_ips_exclude=RegisterIpset(dp, true, NULL)))
|
if (!anon_ips_exclude && !(anon_ips_exclude=RegisterIpset(dp, true, NULL)))
|
||||||
{
|
{
|
||||||
@ -1336,11 +1345,11 @@ void parse_params(int argc, char *argv[])
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
#if defined(__FreeBSD__)
|
#if defined(__FreeBSD__)
|
||||||
case 67: /* enable-pf */
|
case 68: /* enable-pf */
|
||||||
params.pf_enable = true;
|
params.pf_enable = true;
|
||||||
break;
|
break;
|
||||||
#elif defined(__linux__) || defined(__APPLE__)
|
#elif defined(__linux__) || defined(__APPLE__)
|
||||||
case 67: /* local-tcp-user-timeout */
|
case 68: /* local-tcp-user-timeout */
|
||||||
params.tcp_user_timeout_local = atoi(optarg);
|
params.tcp_user_timeout_local = atoi(optarg);
|
||||||
if (params.tcp_user_timeout_local<0 || params.tcp_user_timeout_local>86400)
|
if (params.tcp_user_timeout_local<0 || params.tcp_user_timeout_local>86400)
|
||||||
{
|
{
|
||||||
@ -1348,7 +1357,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
exit_clean(1);
|
exit_clean(1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 68: /* remote-tcp-user-timeout */
|
case 69: /* remote-tcp-user-timeout */
|
||||||
params.tcp_user_timeout_remote = atoi(optarg);
|
params.tcp_user_timeout_remote = atoi(optarg);
|
||||||
if (params.tcp_user_timeout_remote<0 || params.tcp_user_timeout_remote>86400)
|
if (params.tcp_user_timeout_remote<0 || params.tcp_user_timeout_remote>86400)
|
||||||
{
|
{
|
||||||
@ -1359,7 +1368,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__linux__)
|
#if defined(__linux__)
|
||||||
case 69: /* mss */
|
case 70: /* mss */
|
||||||
// this option does not work in any BSD and MacOS. OS may accept but it changes nothing
|
// this option does not work in any BSD and MacOS. OS may accept but it changes nothing
|
||||||
dp->mss = atoi(optarg);
|
dp->mss = atoi(optarg);
|
||||||
if (dp->mss<88 || dp->mss>32767)
|
if (dp->mss<88 || dp->mss>32767)
|
||||||
@ -1368,7 +1377,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
exit_clean(1);
|
exit_clean(1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 70: /* fix-seg */
|
case 71: /* fix-seg */
|
||||||
if (!params.fix_seg_avail)
|
if (!params.fix_seg_avail)
|
||||||
{
|
{
|
||||||
DLOG_ERR("--fix-seg is supported since kernel 4.6\n");
|
DLOG_ERR("--fix-seg is supported since kernel 4.6\n");
|
||||||
@ -1388,7 +1397,7 @@ void parse_params(int argc, char *argv[])
|
|||||||
params.fix_seg = FIX_SEG_DEFAULT_MAX_WAIT;
|
params.fix_seg = FIX_SEG_DEFAULT_MAX_WAIT;
|
||||||
break;
|
break;
|
||||||
#ifdef SPLICE_PRESENT
|
#ifdef SPLICE_PRESENT
|
||||||
case 71: /* nosplice */
|
case 72: /* nosplice */
|
||||||
params.nosplice = true;
|
params.nosplice = true;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
@ -1463,6 +1472,11 @@ void parse_params(int argc, char *argv[])
|
|||||||
// do not need args from file anymore
|
// do not need args from file anymore
|
||||||
cleanup_args();
|
cleanup_args();
|
||||||
#endif
|
#endif
|
||||||
|
if (bDry)
|
||||||
|
{
|
||||||
|
DLOG_CONDUP("command line parameters verified\n");
|
||||||
|
exit_clean(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user