Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/rofl0r/proxychains-ng.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrofl0r <retnyg@gmx.net>2012-01-24 11:26:37 +0400
committerrofl0r <retnyg@gmx.net>2012-01-24 11:26:37 +0400
commit8fd0d95bc3b79626893b30e76a62dfa62e754b8e (patch)
tree36fc8adb170814ef5ffa5db41884da1c719cf2df
parentb20106ce2eaa32f3b6763641bf676299774ea374 (diff)
add quiet mode to proxychains launcherremote-dns
this will be passed on to the DLL via a env variable - additionally, now everything prints to stderr - fixes a bug which would print DLL init even in quiet mode - fixed a couple of bugs in argv parsing
-rw-r--r--src/common.h1
-rw-r--r--src/libproxychains.c11
-rw-r--r--src/main.c42
3 files changed, 34 insertions, 20 deletions
diff --git a/src/common.h b/src/common.h
index 5ba648c..ecfc33c 100644
--- a/src/common.h
+++ b/src/common.h
@@ -1,3 +1,4 @@
#define PROXYCHAINS_CONF_FILE_ENV_VAR "PROXYCHAINS_CONF_FILE"
+#define PROXYCHAINS_QUIET_MODE_ENV_VAR "PROXYCHAINS_QUIET_MODE"
#define PROXYCHAINS_CONF_FILE "proxychains.conf"
#define LOG_PREFIX "[proxychains] "
diff --git a/src/libproxychains.c b/src/libproxychains.c
index b1ef2fd..2e7b1cc 100644
--- a/src/libproxychains.c
+++ b/src/libproxychains.c
@@ -65,9 +65,11 @@ static void init_lib(void)
#ifdef THREAD_SAFE
pthread_mutex_init(&internal_ips_lock, NULL);
#endif
+ /* read the config file */
+ get_chain_data(proxychains_pd, &proxychains_proxy_count, &proxychains_ct);
+
proxychains_write_log(LOG_PREFIX "DLL init\n");
- get_chain_data(proxychains_pd, &proxychains_proxy_count, &proxychains_ct);
true_connect = (connect_t) dlsym(RTLD_NEXT, "connect");
if (!true_connect) {
@@ -180,8 +182,6 @@ static inline void get_chain_data(
tcp_connect_time_out = 10*1000;
*ct = DYNAMIC_TYPE;
- env = NULL;
-
/*
* Get path to configuration file from env this file has priority
* if it's defined.
@@ -190,7 +190,7 @@ static inline void get_chain_data(
snprintf(buff,256,"%s/.proxychains/proxychains.conf",getenv("HOME"));
- if(!(file=fopen(env,"r")))
+ if(!env || (!(file=fopen(env,"r"))))
if(!(file=fopen("./proxychains.conf","r")))
if(!(file=fopen(buff,"r")))
if(!(file=fopen("/etc/proxychains.conf","r")))
@@ -198,6 +198,9 @@ static inline void get_chain_data(
perror("Can't locate proxychains.conf");
exit(1);
}
+
+ env = getenv(PROXYCHAINS_QUIET_MODE_ENV_VAR);
+ if(env && *env == '1') proxychains_quiet_mode = 1;
while(fgets(buff,sizeof(buff),file)) {
if(buff[0] != '\n' && buff[strspn(buff," ")]!='#') {
diff --git a/src/main.c b/src/main.c
index b126d9d..aad499c 100644
--- a/src/main.c
+++ b/src/main.c
@@ -31,10 +31,13 @@ extern int optind, opterr, optopt;
#include "common.h"
-static void usage(char** argv) {
- printf("\nUsage: %s [h] [f] config_file program_name [arguments]\n"
- "\t for example : proxychains telnet somehost.com\n"
- "More help in README file\n", argv[0]);
+static int usage(char** argv) {
+ printf( "\nUsage:\t%s -q -f config_file program_name [arguments]\n"
+ "\t-q makes proxychains quiet - this overrides the config setting\n"
+ "\t-t allows to manually specify a configfile to use\n"
+ "\tfor example : proxychains telnet somehost.com\n"
+ "More help in README file\n\n", argv[0]);
+ return EXIT_FAILURE;
}
int check_path(char* path) {
@@ -73,25 +76,30 @@ int main(int argc, char *argv[]) {
char pbuf[256];
int opt;
int start_argv = 1;
+ int quiet = 0;
+
+ if(argc == 1) return usage(argv);
- while ((opt = getopt(argc, argv, "hf:")) != -1) {
+ while ((opt = getopt(argc, argv, "qf:")) != -1) {
switch (opt) {
- case 'h':
- usage(argv);
- return EXIT_SUCCESS;
+ case 'q':
+ quiet = 1;
+ start_argv++;
+ break;
case 'f':
path = (char *)optarg;
if(!path) {
- printf("error: no path supplied.\n");
- return(EXIT_FAILURE);
+ fprintf(stderr, "error: no path supplied.\n");
+ return EXIT_FAILURE;
}
- start_argv = 3;
+ start_argv += 2;
break;
default: /* '?' */
- usage(argv);
- exit(EXIT_FAILURE);
+ return usage(argv);
}
}
+
+ if(start_argv >= argc) return usage(argv);
/* check if path of config file has not been passed via command line */
if(!path) {
@@ -120,10 +128,12 @@ int main(int argc, char *argv[]) {
have:
- printf(LOG_PREFIX "config file found: %s\n", path);
+ if(!quiet) fprintf(stderr, LOG_PREFIX "config file found: %s\n", path);
/* Set PROXYCHAINS_CONF_FILE to get proxychains lib to use new config file. */
setenv(PROXYCHAINS_CONF_FILE_ENV_VAR, path, 1);
+
+ if(quiet) setenv(PROXYCHAINS_QUIET_MODE_ENV_VAR, "1", 1);
// search DLL
@@ -142,10 +152,10 @@ int main(int argc, char *argv[]) {
}
if(!prefix) {
- printf("couldnt locate %s\n", dll_name);
+ fprintf(stderr, "couldnt locate %s\n", dll_name);
return EXIT_FAILURE;
}
- printf(LOG_PREFIX "preloading %s/%s\n", prefix, dll_name);
+ if(!quiet) fprintf(stderr, LOG_PREFIX "preloading %s/%s\n", prefix, dll_name);
snprintf(buf, sizeof(buf), "LD_PRELOAD=%s/%s", prefix, dll_name);