2011-09-04 07:45:16 +08:00
|
|
|
#
|
|
|
|
# Makefile for proxychains (requires GNU make), stolen from musl
|
|
|
|
#
|
|
|
|
# Use config.mak to override any of the following variables.
|
|
|
|
# Do not make changes here.
|
|
|
|
#
|
|
|
|
|
|
|
|
exec_prefix = /usr/local
|
|
|
|
bindir = $(exec_prefix)/bin
|
|
|
|
|
|
|
|
prefix = /usr/local/
|
|
|
|
includedir = $(prefix)/include
|
|
|
|
libdir = $(prefix)/lib
|
2022-03-30 14:16:06 +08:00
|
|
|
sysconfdir = $(prefix)/etc
|
2023-12-03 05:28:35 +08:00
|
|
|
zshcompletiondir = $(prefix)/share/zsh/site-functions
|
2011-09-04 07:45:16 +08:00
|
|
|
|
experimental new feature: proxy_dns_daemon
since many users complain about issues with modern, ultracomplex
clusterfuck software such as chromium, nodejs, etc, i've reconsidered
one of my original ideas how to implement remote dns lookup support.
instead of having a background thread serving requests via a pipe,
the user manually starts a background daemon process before running
proxychains, and the two processes then communicate via UDP.
this requires much less hacks (like hooking of close() to prevent
pipes from getting closed) and doesn't need to call any async-signal
unsafe code like malloc(). this means it should be much more compatible
than the previous method, however it's not as practical and slightly
slower.
it's recommended that the proxychains4-daemon runs on localhost, and
if you use proxychains-ng a lot you might want to set ip up as a service
that starts on boot. a single proxychains4-daemon should theoretically
be able to serve many parallel proxychains4 instances, but this has not
yet been tested so far. it's also possible to run the daemon on other
computers, even over internet, but currently there is no error-checking/
timeout code at all; that means the UDP connection needs to be very
stable.
the library code used for the daemon sources are from my projects
libulz[0] and htab[1], and the server code is loosely based on
microsocks[2]. their licenses are all compatible with the GPL.
if not otherwise mentioned, they're released for this purpose under
the standard proxychains-ng license (see COPYING).
[0]: https://github.com/rofl0r/libulz
[1]: https://github.com/rofl0r/htab
[2]: https://github.com/rofl0r/microsocks
2020-09-24 05:00:29 +08:00
|
|
|
OBJS = src/common.o src/main.o
|
|
|
|
|
|
|
|
DOBJS = src/daemon/hsearch.o \
|
|
|
|
src/daemon/sblist.o src/daemon/sblist_delete.o \
|
|
|
|
src/daemon/daemon.o src/daemon/udpserver.o
|
|
|
|
|
2021-12-13 01:51:25 +08:00
|
|
|
LOBJS = src/version.o \
|
2015-06-06 18:41:36 +08:00
|
|
|
src/core.o src/common.o src/libproxychains.o \
|
experimental new feature: proxy_dns_daemon
since many users complain about issues with modern, ultracomplex
clusterfuck software such as chromium, nodejs, etc, i've reconsidered
one of my original ideas how to implement remote dns lookup support.
instead of having a background thread serving requests via a pipe,
the user manually starts a background daemon process before running
proxychains, and the two processes then communicate via UDP.
this requires much less hacks (like hooking of close() to prevent
pipes from getting closed) and doesn't need to call any async-signal
unsafe code like malloc(). this means it should be much more compatible
than the previous method, however it's not as practical and slightly
slower.
it's recommended that the proxychains4-daemon runs on localhost, and
if you use proxychains-ng a lot you might want to set ip up as a service
that starts on boot. a single proxychains4-daemon should theoretically
be able to serve many parallel proxychains4 instances, but this has not
yet been tested so far. it's also possible to run the daemon on other
computers, even over internet, but currently there is no error-checking/
timeout code at all; that means the UDP connection needs to be very
stable.
the library code used for the daemon sources are from my projects
libulz[0] and htab[1], and the server code is loosely based on
microsocks[2]. their licenses are all compatible with the GPL.
if not otherwise mentioned, they're released for this purpose under
the standard proxychains-ng license (see COPYING).
[0]: https://github.com/rofl0r/libulz
[1]: https://github.com/rofl0r/htab
[2]: https://github.com/rofl0r/microsocks
2020-09-24 05:00:29 +08:00
|
|
|
src/allocator_thread.o src/rdns.o \
|
2014-11-14 19:33:58 +08:00
|
|
|
src/hostsreader.o src/hash.o src/debug.o
|
2011-09-04 07:45:16 +08:00
|
|
|
|
experimental new feature: proxy_dns_daemon
since many users complain about issues with modern, ultracomplex
clusterfuck software such as chromium, nodejs, etc, i've reconsidered
one of my original ideas how to implement remote dns lookup support.
instead of having a background thread serving requests via a pipe,
the user manually starts a background daemon process before running
proxychains, and the two processes then communicate via UDP.
this requires much less hacks (like hooking of close() to prevent
pipes from getting closed) and doesn't need to call any async-signal
unsafe code like malloc(). this means it should be much more compatible
than the previous method, however it's not as practical and slightly
slower.
it's recommended that the proxychains4-daemon runs on localhost, and
if you use proxychains-ng a lot you might want to set ip up as a service
that starts on boot. a single proxychains4-daemon should theoretically
be able to serve many parallel proxychains4 instances, but this has not
yet been tested so far. it's also possible to run the daemon on other
computers, even over internet, but currently there is no error-checking/
timeout code at all; that means the UDP connection needs to be very
stable.
the library code used for the daemon sources are from my projects
libulz[0] and htab[1], and the server code is loosely based on
microsocks[2]. their licenses are all compatible with the GPL.
if not otherwise mentioned, they're released for this purpose under
the standard proxychains-ng license (see COPYING).
[0]: https://github.com/rofl0r/libulz
[1]: https://github.com/rofl0r/htab
[2]: https://github.com/rofl0r/microsocks
2020-09-24 05:00:29 +08:00
|
|
|
|
2014-07-22 20:10:08 +08:00
|
|
|
GENH = src/version.h
|
|
|
|
|
2012-11-08 04:28:09 +08:00
|
|
|
CFLAGS += -Wall -O0 -g -std=c99 -D_GNU_SOURCE -pipe
|
2012-12-16 09:39:28 +08:00
|
|
|
NO_AS_NEEDED = -Wl,--no-as-needed
|
2021-04-30 23:15:30 +08:00
|
|
|
LDFLAGS = -fPIC $(NO_AS_NEEDED) $(LIBDL) $(PTHREAD)
|
2011-09-04 07:45:16 +08:00
|
|
|
INC =
|
2012-01-24 14:29:34 +08:00
|
|
|
PIC = -fPIC
|
2011-09-04 07:45:16 +08:00
|
|
|
AR = $(CROSS_COMPILE)ar
|
|
|
|
RANLIB = $(CROSS_COMPILE)ranlib
|
2018-01-11 00:41:57 +08:00
|
|
|
SOCKET_LIBS =
|
2011-09-04 07:45:16 +08:00
|
|
|
|
2012-01-28 03:30:44 +08:00
|
|
|
LDSO_SUFFIX = so
|
2012-01-28 03:48:24 +08:00
|
|
|
LD_SET_SONAME = -Wl,-soname=
|
2014-07-22 20:32:27 +08:00
|
|
|
INSTALL = ./tools/install.sh
|
2012-01-28 03:30:44 +08:00
|
|
|
|
|
|
|
LDSO_PATHNAME = libproxychains4.$(LDSO_SUFFIX)
|
2011-11-06 21:07:38 +08:00
|
|
|
|
|
|
|
SHARED_LIBS = $(LDSO_PATHNAME)
|
2011-09-04 07:45:16 +08:00
|
|
|
ALL_LIBS = $(SHARED_LIBS)
|
2011-11-06 21:07:38 +08:00
|
|
|
PXCHAINS = proxychains4
|
experimental new feature: proxy_dns_daemon
since many users complain about issues with modern, ultracomplex
clusterfuck software such as chromium, nodejs, etc, i've reconsidered
one of my original ideas how to implement remote dns lookup support.
instead of having a background thread serving requests via a pipe,
the user manually starts a background daemon process before running
proxychains, and the two processes then communicate via UDP.
this requires much less hacks (like hooking of close() to prevent
pipes from getting closed) and doesn't need to call any async-signal
unsafe code like malloc(). this means it should be much more compatible
than the previous method, however it's not as practical and slightly
slower.
it's recommended that the proxychains4-daemon runs on localhost, and
if you use proxychains-ng a lot you might want to set ip up as a service
that starts on boot. a single proxychains4-daemon should theoretically
be able to serve many parallel proxychains4 instances, but this has not
yet been tested so far. it's also possible to run the daemon on other
computers, even over internet, but currently there is no error-checking/
timeout code at all; that means the UDP connection needs to be very
stable.
the library code used for the daemon sources are from my projects
libulz[0] and htab[1], and the server code is loosely based on
microsocks[2]. their licenses are all compatible with the GPL.
if not otherwise mentioned, they're released for this purpose under
the standard proxychains-ng license (see COPYING).
[0]: https://github.com/rofl0r/libulz
[1]: https://github.com/rofl0r/htab
[2]: https://github.com/rofl0r/microsocks
2020-09-24 05:00:29 +08:00
|
|
|
PXCHAINS_D = proxychains4-daemon
|
|
|
|
ALL_TOOLS = $(PXCHAINS) $(PXCHAINS_D)
|
2014-07-22 20:32:27 +08:00
|
|
|
ALL_CONFIGS = src/proxychains.conf
|
2022-09-19 16:42:49 +08:00
|
|
|
ZSH_COMPLETION = completions/zsh/_proxychains4
|
2011-09-04 07:45:16 +08:00
|
|
|
|
2013-01-07 02:26:01 +08:00
|
|
|
-include config.mak
|
2011-09-04 07:45:16 +08:00
|
|
|
|
2016-12-24 20:49:14 +08:00
|
|
|
CFLAGS+=$(USER_CFLAGS) $(MAC_CFLAGS)
|
2012-01-31 01:29:35 +08:00
|
|
|
CFLAGS_MAIN=-DLIB_DIR=\"$(libdir)\" -DSYSCONFDIR=\"$(sysconfdir)\" -DDLL_NAME=\"$(LDSO_PATHNAME)\"
|
2011-09-04 07:45:16 +08:00
|
|
|
|
|
|
|
|
|
|
|
all: $(ALL_LIBS) $(ALL_TOOLS)
|
|
|
|
|
2014-07-22 20:32:27 +08:00
|
|
|
install: install-libs install-tools
|
2012-07-16 08:29:04 +08:00
|
|
|
|
2014-07-22 20:32:27 +08:00
|
|
|
$(DESTDIR)$(bindir)/%: %
|
|
|
|
$(INSTALL) -D -m 755 $< $@
|
|
|
|
|
|
|
|
$(DESTDIR)$(libdir)/%: %
|
|
|
|
$(INSTALL) -D -m 644 $< $@
|
|
|
|
|
2014-07-22 23:21:11 +08:00
|
|
|
$(DESTDIR)$(sysconfdir)/%: src/%
|
2014-07-22 20:32:27 +08:00
|
|
|
$(INSTALL) -D -m 644 $< $@
|
|
|
|
|
2022-09-19 16:42:49 +08:00
|
|
|
$(DESTDIR)$(zshcompletiondir)/%: completions/zsh/%
|
2022-03-30 14:16:06 +08:00
|
|
|
$(INSTALL) -D -m 644 $< $@
|
|
|
|
|
2014-07-22 20:32:27 +08:00
|
|
|
install-libs: $(ALL_LIBS:%=$(DESTDIR)$(libdir)/%)
|
|
|
|
install-tools: $(ALL_TOOLS:%=$(DESTDIR)$(bindir)/%)
|
|
|
|
install-config: $(ALL_CONFIGS:src/%=$(DESTDIR)$(sysconfdir)/%)
|
2022-09-19 16:42:49 +08:00
|
|
|
install-zsh-completion: $(ZSH_COMPLETION:completions/zsh/%=$(DESTDIR)$(zshcompletiondir)/%)
|
2011-09-04 07:45:16 +08:00
|
|
|
|
|
|
|
clean:
|
2012-01-24 14:29:34 +08:00
|
|
|
rm -f $(ALL_LIBS)
|
|
|
|
rm -f $(ALL_TOOLS)
|
experimental new feature: proxy_dns_daemon
since many users complain about issues with modern, ultracomplex
clusterfuck software such as chromium, nodejs, etc, i've reconsidered
one of my original ideas how to implement remote dns lookup support.
instead of having a background thread serving requests via a pipe,
the user manually starts a background daemon process before running
proxychains, and the two processes then communicate via UDP.
this requires much less hacks (like hooking of close() to prevent
pipes from getting closed) and doesn't need to call any async-signal
unsafe code like malloc(). this means it should be much more compatible
than the previous method, however it's not as practical and slightly
slower.
it's recommended that the proxychains4-daemon runs on localhost, and
if you use proxychains-ng a lot you might want to set ip up as a service
that starts on boot. a single proxychains4-daemon should theoretically
be able to serve many parallel proxychains4 instances, but this has not
yet been tested so far. it's also possible to run the daemon on other
computers, even over internet, but currently there is no error-checking/
timeout code at all; that means the UDP connection needs to be very
stable.
the library code used for the daemon sources are from my projects
libulz[0] and htab[1], and the server code is loosely based on
microsocks[2]. their licenses are all compatible with the GPL.
if not otherwise mentioned, they're released for this purpose under
the standard proxychains-ng license (see COPYING).
[0]: https://github.com/rofl0r/libulz
[1]: https://github.com/rofl0r/htab
[2]: https://github.com/rofl0r/microsocks
2020-09-24 05:00:29 +08:00
|
|
|
rm -f $(OBJS) $(LOBJS) $(DOBJS)
|
2014-07-22 20:10:08 +08:00
|
|
|
rm -f $(GENH)
|
|
|
|
|
|
|
|
src/version.h: $(wildcard VERSION .git)
|
|
|
|
printf '#define VERSION "%s"\n' "$$(sh tools/version.sh)" > $@
|
|
|
|
|
|
|
|
src/version.o: src/version.h
|
2011-09-04 07:45:16 +08:00
|
|
|
|
|
|
|
%.o: %.c
|
2014-02-02 16:49:21 +08:00
|
|
|
$(CC) $(CPPFLAGS) $(CFLAGS) $(CFLAGS_MAIN) $(INC) $(PIC) -c -o $@ $<
|
2011-09-04 07:45:16 +08:00
|
|
|
|
2011-11-06 21:07:38 +08:00
|
|
|
$(LDSO_PATHNAME): $(LOBJS)
|
2022-06-01 07:53:23 +08:00
|
|
|
$(CC) $(LDFLAGS) $(FAT_LDFLAGS) $(LD_SET_SONAME)$(LDSO_PATHNAME) \
|
|
|
|
$(USER_LDFLAGS) -shared -o $@ $^ $(SOCKET_LIBS)
|
experimental new feature: proxy_dns_daemon
since many users complain about issues with modern, ultracomplex
clusterfuck software such as chromium, nodejs, etc, i've reconsidered
one of my original ideas how to implement remote dns lookup support.
instead of having a background thread serving requests via a pipe,
the user manually starts a background daemon process before running
proxychains, and the two processes then communicate via UDP.
this requires much less hacks (like hooking of close() to prevent
pipes from getting closed) and doesn't need to call any async-signal
unsafe code like malloc(). this means it should be much more compatible
than the previous method, however it's not as practical and slightly
slower.
it's recommended that the proxychains4-daemon runs on localhost, and
if you use proxychains-ng a lot you might want to set ip up as a service
that starts on boot. a single proxychains4-daemon should theoretically
be able to serve many parallel proxychains4 instances, but this has not
yet been tested so far. it's also possible to run the daemon on other
computers, even over internet, but currently there is no error-checking/
timeout code at all; that means the UDP connection needs to be very
stable.
the library code used for the daemon sources are from my projects
libulz[0] and htab[1], and the server code is loosely based on
microsocks[2]. their licenses are all compatible with the GPL.
if not otherwise mentioned, they're released for this purpose under
the standard proxychains-ng license (see COPYING).
[0]: https://github.com/rofl0r/libulz
[1]: https://github.com/rofl0r/htab
[2]: https://github.com/rofl0r/microsocks
2020-09-24 05:00:29 +08:00
|
|
|
|
|
|
|
$(PXCHAINS): $(OBJS)
|
2022-07-22 07:00:15 +08:00
|
|
|
$(CC) $^ $(FAT_BIN_LDFLAGS) $(USER_LDFLAGS) $(LIBDL) -o $@
|
2011-09-04 07:45:16 +08:00
|
|
|
|
experimental new feature: proxy_dns_daemon
since many users complain about issues with modern, ultracomplex
clusterfuck software such as chromium, nodejs, etc, i've reconsidered
one of my original ideas how to implement remote dns lookup support.
instead of having a background thread serving requests via a pipe,
the user manually starts a background daemon process before running
proxychains, and the two processes then communicate via UDP.
this requires much less hacks (like hooking of close() to prevent
pipes from getting closed) and doesn't need to call any async-signal
unsafe code like malloc(). this means it should be much more compatible
than the previous method, however it's not as practical and slightly
slower.
it's recommended that the proxychains4-daemon runs on localhost, and
if you use proxychains-ng a lot you might want to set ip up as a service
that starts on boot. a single proxychains4-daemon should theoretically
be able to serve many parallel proxychains4 instances, but this has not
yet been tested so far. it's also possible to run the daemon on other
computers, even over internet, but currently there is no error-checking/
timeout code at all; that means the UDP connection needs to be very
stable.
the library code used for the daemon sources are from my projects
libulz[0] and htab[1], and the server code is loosely based on
microsocks[2]. their licenses are all compatible with the GPL.
if not otherwise mentioned, they're released for this purpose under
the standard proxychains-ng license (see COPYING).
[0]: https://github.com/rofl0r/libulz
[1]: https://github.com/rofl0r/htab
[2]: https://github.com/rofl0r/microsocks
2020-09-24 05:00:29 +08:00
|
|
|
$(PXCHAINS_D): $(DOBJS)
|
2022-07-22 07:00:15 +08:00
|
|
|
$(CC) $^ $(FAT_BIN_LDFLAGS) $(USER_LDFLAGS) -o $@
|
2011-09-04 07:45:16 +08:00
|
|
|
|
|
|
|
|
2022-03-30 14:16:06 +08:00
|
|
|
.PHONY: all clean install install-config install-libs install-tools install-zsh-completion
|