mirror of
https://github.com/yarrick/iodine.git
synced 2024-11-23 00:29:20 +02:00
#36, Use -r to skip raw mode
This commit is contained in:
parent
e5370ad95b
commit
ebc1b2f7f8
20
src/iodine.c
20
src/iodine.c
|
@ -712,8 +712,7 @@ handshake_raw_udp(int dns_fd, int seed)
|
||||||
unsigned remoteaddr = 0;
|
unsigned remoteaddr = 0;
|
||||||
struct in_addr server;
|
struct in_addr server;
|
||||||
|
|
||||||
fprintf(stderr, "Testing raw UDP data to the server");
|
fprintf(stderr, "Testing raw UDP data to the server (skip with -r)\n");
|
||||||
fflush(stderr);
|
|
||||||
for (i=0; running && i<3 ;i++) {
|
for (i=0; running && i<3 ;i++) {
|
||||||
tv.tv_sec = i + 1;
|
tv.tv_sec = i + 1;
|
||||||
tv.tv_usec = 0;
|
tv.tv_usec = 0;
|
||||||
|
@ -749,7 +748,7 @@ handshake_raw_udp(int dns_fd, int seed)
|
||||||
fprintf(stderr, " failed to get IP.\n");
|
fprintf(stderr, " failed to get IP.\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
fprintf(stderr, " at %s: ", inet_ntoa(server));
|
fprintf(stderr, "Server is at %s, trying login: ", inet_ntoa(server));
|
||||||
fflush(stderr);
|
fflush(stderr);
|
||||||
|
|
||||||
/* Store address to iodined server */
|
/* Store address to iodined server */
|
||||||
|
@ -1031,7 +1030,7 @@ handshake_set_fragsize(int dns_fd, int fragsize)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
handshake(int dns_fd, int autodetect_frag_size, int fragsize)
|
handshake(int dns_fd, int raw_mode, int autodetect_frag_size, int fragsize)
|
||||||
{
|
{
|
||||||
int seed;
|
int seed;
|
||||||
int case_preserved;
|
int case_preserved;
|
||||||
|
@ -1047,9 +1046,12 @@ handshake(int dns_fd, int autodetect_frag_size, int fragsize)
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (handshake_raw_udp(dns_fd, seed)) {
|
if (raw_mode && handshake_raw_udp(dns_fd, seed)) {
|
||||||
conn = CONN_RAW_UDP;
|
conn = CONN_RAW_UDP;
|
||||||
} else {
|
} else {
|
||||||
|
if (raw_mode == 0) {
|
||||||
|
fprintf(stderr, "Skipping raw mode\n");
|
||||||
|
}
|
||||||
case_preserved = handshake_case_check(dns_fd);
|
case_preserved = handshake_case_check(dns_fd);
|
||||||
|
|
||||||
if (case_preserved) {
|
if (case_preserved) {
|
||||||
|
@ -1194,6 +1196,7 @@ main(int argc, char **argv)
|
||||||
int max_downstream_frag_size;
|
int max_downstream_frag_size;
|
||||||
int autodetect_frag_size;
|
int autodetect_frag_size;
|
||||||
int retval;
|
int retval;
|
||||||
|
int raw_mode;
|
||||||
|
|
||||||
memset(password, 0, 33);
|
memset(password, 0, 33);
|
||||||
username = NULL;
|
username = NULL;
|
||||||
|
@ -1208,6 +1211,7 @@ main(int argc, char **argv)
|
||||||
|
|
||||||
autodetect_frag_size = 1;
|
autodetect_frag_size = 1;
|
||||||
max_downstream_frag_size = 3072;
|
max_downstream_frag_size = 3072;
|
||||||
|
raw_mode = 1;
|
||||||
|
|
||||||
b32 = get_base32_encoder();
|
b32 = get_base32_encoder();
|
||||||
dataenc = get_base32_encoder();
|
dataenc = get_base32_encoder();
|
||||||
|
@ -1230,7 +1234,7 @@ main(int argc, char **argv)
|
||||||
__progname++;
|
__progname++;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
while ((choice = getopt(argc, argv, "vfhu:t:d:P:m:")) != -1) {
|
while ((choice = getopt(argc, argv, "vfhru:t:d:P:m:")) != -1) {
|
||||||
switch(choice) {
|
switch(choice) {
|
||||||
case 'v':
|
case 'v':
|
||||||
version();
|
version();
|
||||||
|
@ -1243,6 +1247,8 @@ main(int argc, char **argv)
|
||||||
help();
|
help();
|
||||||
/* NOTREACHED */
|
/* NOTREACHED */
|
||||||
break;
|
break;
|
||||||
|
case 'r':
|
||||||
|
raw_mode = 0;
|
||||||
case 'u':
|
case 'u':
|
||||||
username = optarg;
|
username = optarg;
|
||||||
break;
|
break;
|
||||||
|
@ -1341,7 +1347,7 @@ main(int argc, char **argv)
|
||||||
signal(SIGINT, sighandler);
|
signal(SIGINT, sighandler);
|
||||||
signal(SIGTERM, sighandler);
|
signal(SIGTERM, sighandler);
|
||||||
|
|
||||||
if (handshake(dns_fd, autodetect_frag_size, max_downstream_frag_size)) {
|
if (handshake(dns_fd, raw_mode, autodetect_frag_size, max_downstream_frag_size)) {
|
||||||
retval = 1;
|
retval = 1;
|
||||||
goto cleanup2;
|
goto cleanup2;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue