[tor-commits] [torsocks/master] Add --address and --port for torsocks.

dgoulet at torproject.org dgoulet at torproject.org
Mon Jun 13 21:14:03 UTC 2016


commit 4073958481faaf3220b09a3a499e1f104d969d29
Author: Alexander Færøy <ahf at 0x90.dk>
Date:   Mon Oct 12 23:21:25 2015 +0200

    Add --address and --port for torsocks.
    
    This patch adds two new arguments for the torsocks script: --address
    (-a), for specifying the address of the Tor instance to use, and --port
    (-P), for specifying the port of the Tor instance to use.
---
 doc/torsocks.1        |  6 ++++++
 doc/torsocks.8        |  8 ++++++++
 src/bin/torsocks.in   | 38 ++++++++++++++++++++++++++++----------
 src/common/defaults.h |  4 ++++
 src/lib/torsocks.c    | 18 +++++++++++++++++-
 5 files changed, 63 insertions(+), 11 deletions(-)

diff --git a/doc/torsocks.1 b/doc/torsocks.1
index 0e3c341..e4ac628 100644
--- a/doc/torsocks.1
+++ b/doc/torsocks.1
@@ -47,6 +47,12 @@ Set password for the SOCKS5 authentication. Use for circuit isolation in Tor.
 Note that you MUST have a username set either by the command line, environment
 variable or configuration file (torsocks.conf(5)).
 .TP
+.BR "\-a, \-\-address"
+Set Tor address.
+.TP
+.BR "\-P, \-\-port"
+Set Tor port.
+.TP
 .BR "\-i, \-\-isolate"
 Automatic tor isolation. Set the username and password for the SOCKS5
 authentication method to a PID/current time based value automatically. Username
diff --git a/doc/torsocks.8 b/doc/torsocks.8
index ac3863a..c3f477f 100644
--- a/doc/torsocks.8
+++ b/doc/torsocks.8
@@ -95,6 +95,14 @@ Set the password for the SOCKS5 authentication method. Username MUST be set
 also with the variable above.
 
 .PP
+.IP TORSOCKS_TOR_ADDRESS
+Set the Tor address. (default: 127.0.0.1)
+
+.PP
+.IP TORSOCKS_TOR_PORT
+Set the Tor port. (default: 9050)
+
+.PP
 .IP TORSOCKS_ALLOW_INBOUND
 Allow inbound connections so the application can accept and listen for
 connections.
diff --git a/src/bin/torsocks.in b/src/bin/torsocks.in
index 5102fdc..b030ad2 100644
--- a/src/bin/torsocks.in
+++ b/src/bin/torsocks.in
@@ -140,16 +140,18 @@ usage ()
 	echo "usage: $0 command args"
 	echo ""
 	echo "Options:"
-	echo "  -h, --help      Show this help"
-	echo "      --shell     Spawn a torified shell"
-	echo "      --version   Show version"
-	echo "  -d, --debug     Set debug mode."
-	echo "  -u, --user NAME Username for the SOCKS5 authentication"
-	echo "  -p, --pass NAME Password for the SOCKS5 authentication"
-	echo "  -i, --isolate   Automatic tor isolation. Can't be used with -u/-p"
-	echo "  on, off         Set/Unset your shell to use Torsocks by default"
-	echo "                  Make sure to source the call when using this option. (See Examples)"
-	echo "  show, sh        Show the current value of the LD_PRELOAD"
+	echo "  -h, --help         Show this help"
+	echo "      --shell        Spawn a torified shell"
+	echo "      --version      Show version"
+	echo "  -d, --debug        Set debug mode."
+	echo "  -u, --user NAME    Username for the SOCKS5 authentication"
+	echo "  -p, --pass NAME    Password for the SOCKS5 authentication"
+	echo "  -i, --isolate      Automatic tor isolation. Can't be used with -u/-p"
+	echo "  -a, --address HOST Specify Tor address"
+	echo "  -P, --port PORT    Specify Tor port"
+	echo "  on, off            Set/Unset your shell to use Torsocks by default"
+	echo "                     Make sure to source the call when using this option. (See Examples)"
+	echo "  show, sh           Show the current value of the LD_PRELOAD"
 	echo ""
 	echo "Examples:"
 	echo ""
@@ -230,6 +232,22 @@ do
 			export TORSOCKS_PASSWORD=$2
 			shift
 			;;
+		-a|--address)
+			if [ -z $2 ]; then
+				echo "Missing address to -a" >&2
+				exit 1
+			fi
+			export TORSOCKS_TOR_ADDRESS=$2
+			shift
+			;;
+		-P|--port)
+			if [ -z $2 ]; then
+				echo "Missing port to -P" >&2
+				exit 1
+			fi
+			export TORSOCKS_TOR_PORT=$2
+			shift
+			;;
 		-i|--isolate)
 			export TORSOCKS_ISOLATE_PID=1
 			;;
diff --git a/src/common/defaults.h b/src/common/defaults.h
index ab51690..958e7cd 100644
--- a/src/common/defaults.h
+++ b/src/common/defaults.h
@@ -63,6 +63,10 @@
 #define DEFAULT_SOCKS5_USER_ENV     "TORSOCKS_USERNAME"
 #define DEFAULT_SOCKS5_PASS_ENV     "TORSOCKS_PASSWORD"
 
+/* Env. variable for Tor hostname and port. */
+#define DEFAULT_TOR_ADDRESS_ENV     "TORSOCKS_TOR_ADDRESS"
+#define DEFAULT_TOR_PORT_ENV        "TORSOCKS_TOR_PORT"
+
 /* Control if torsocks allows inbound connection or not. */
 #define DEFAULT_ALLOW_INBOUND_ENV   "TORSOCKS_ALLOW_INBOUND"
 
diff --git a/src/lib/torsocks.c b/src/lib/torsocks.c
index 7944e57..731b33c 100644
--- a/src/lib/torsocks.c
+++ b/src/lib/torsocks.c
@@ -75,7 +75,7 @@ static void clean_exit(int status)
 static void read_env(void)
 {
 	int ret;
-	const char *username, *password, *allow_in, *isolate_pid;
+	const char *username, *password, *allow_in, *isolate_pid, *tor_address, *tor_port;
 
 	if (is_suid) {
 		goto end;
@@ -97,6 +97,22 @@ static void read_env(void)
 		}
 	}
 
+	tor_address = getenv(DEFAULT_TOR_ADDRESS_ENV);
+	if (tor_address) {
+		ret = conf_file_set_tor_address(tor_address, &tsocks_config);
+		if (ret < 0) {
+			goto error;
+		}
+	}
+
+	tor_port = getenv(DEFAULT_TOR_PORT_ENV);
+	if (tor_port) {
+		ret = conf_file_set_tor_port(tor_port, &tsocks_config);
+		if (ret < 0) {
+			goto error;
+		}
+	}
+
 	username = getenv(DEFAULT_SOCKS5_USER_ENV);
 	password = getenv(DEFAULT_SOCKS5_PASS_ENV);
 	if (!username && !password) {





More information about the tor-commits mailing list