103 lines
4.0 KiB
103 lines
4.0 KiB
#! /bin/sh /usr/share/dpatch/dpatch-run
|
|
## 06_fallback.dpatch by Tamas SZERB <toma@rulez.org>
|
|
##
|
|
## All lines beginning with `## DP:' are a description of the patch.
|
|
## DP: Establish direct connection instead of sockified if
|
|
## DP: there is no default server specified and the
|
|
## DP: fallback = yes.
|
|
|
|
--- a/parser.h
|
|
+++ b/parser.h
|
|
@@ -33,6 +33,7 @@ struct parsedfile {
|
|
struct netent *localnets;
|
|
struct serverent defaultserver;
|
|
struct serverent *paths;
|
|
+ int fallback;
|
|
};
|
|
|
|
/* Functions provided by parser module */
|
|
--- a/parser.c
|
|
+++ b/parser.c
|
|
@@ -35,6 +35,7 @@ static int handle_local(struct parsedfil
|
|
static int handle_defuser(struct parsedfile *, int, char *);
|
|
static int handle_defpass(struct parsedfile *, int, char *);
|
|
static int make_netent(char *value, struct netent **ent);
|
|
+static int handle_fallback(struct parsedfile *, int, char *);
|
|
|
|
char __attribute__ ((visibility ("hidden")))
|
|
*find_config(char *line) {
|
|
@@ -181,6 +182,8 @@ static int handle_line(struct parsedfile
|
|
handle_defpass(config, lineno, words[2]);
|
|
} else if (!strcmp(words[0], "local")) {
|
|
handle_local(config, lineno, words[2]);
|
|
+ } else if (!strcmp(words[0], "fallback")) {
|
|
+ handle_fallback(config, lineno, words[2]);
|
|
} else {
|
|
show_msg(MSGERR, "Invalid pair type (%s) specified "
|
|
"on line %d in configuration file, "
|
|
@@ -512,6 +515,19 @@ static int handle_local(struct parsedfil
|
|
return(0);
|
|
}
|
|
|
|
+static int handle_fallback(struct parsedfile *config, int lineno, char *value) {
|
|
+ char *v = strsplit(NULL, &value, " ");
|
|
+ if (config->fallback !=0) {
|
|
+ show_msg(MSGERR, "Fallback may only be specified "
|
|
+ "once in configuration file.\n",
|
|
+ lineno, currentcontext->lineno);
|
|
+ } else {
|
|
+ if(!strcmp(v, "yes")) config->fallback = 1;
|
|
+ if(!strcmp(v, "no")) config->fallback = 0;
|
|
+ }
|
|
+ return(0);
|
|
+}
|
|
+
|
|
/* Construct a netent given a string like */
|
|
/* "198.126.0.1[:portno[-portno]]/255.255.255.0" */
|
|
int make_netent(char *value, struct netent **ent) {
|
|
--- a/tsocks.c
|
|
+++ b/tsocks.c
|
|
@@ -294,11 +294,20 @@ int connect(CONNECT_SIGNATURE) {
|
|
(path->address ? path->address : "(Not Provided)"));
|
|
if (path->address == NULL) {
|
|
if (path == &(config->defaultserver)) {
|
|
- show_msg(MSGERR, "Connection needs to be made "
|
|
- "via default server but "
|
|
- "the default server has not "
|
|
- "been specified. Falling back to direct connection.\n");
|
|
- return(realconnect(__fd, __addr, __len));
|
|
+ if (config->fallback) {
|
|
+ show_msg(MSGERR, "Connection needs to be made "
|
|
+ "via default server but "
|
|
+ "the default server has not "
|
|
+ "been specified. Fallback is 'yes' so "
|
|
+ "Falling back to direct connection.\n");
|
|
+ return(realconnect(__fd, __addr, __len));
|
|
+ } else {
|
|
+ show_msg(MSGERR, "Connection needs to be made "
|
|
+ "via default server but "
|
|
+ "the default server has not "
|
|
+ "been specified. Fallback is 'no' so "
|
|
+ "coudln't establish the connection.\n");
|
|
+ }
|
|
}
|
|
else
|
|
show_msg(MSGERR, "Connection needs to be made "
|
|
--- a/tsocks.conf.5
|
|
+++ b/tsocks.conf.5
|
|
@@ -135,6 +135,15 @@ tsocks gives an error message and aborts
|
|
This parameter protects the user against accidentally establishing
|
|
unwanted unsockified (ie. direct) connection.
|
|
|
|
+.TP
|
|
+.I fallback
|
|
+This directive allows to fall back to direct connection if no default
|
|
+server present in the configuration and fallback = yes.
|
|
+If fallback = no or not specified and there is no default server, the
|
|
+tsocks gives an error message and aborts.
|
|
+This parameter protects the user against accidentally establishing
|
|
+unwanted unsockified (ie. direct) connection.
|
|
+
|
|
.SH UTILITIES
|
|
tsocks comes with two utilities that can be useful in creating and verifying
|
|
the tsocks configuration file.
|
|
|