clue / psocksd
The SOCKS tunnel / proxy server daemon written in PHP
Installs: 193
Dependents: 0
Suggesters: 0
Security: 0
Stars: 54
Watchers: 9
Forks: 12
Open Issues: 1
Type:project
Requires
- php: >=5.3
- clue/arguments: ^1.0
- clue/commander: ^1.2
- clue/connection-manager-extra: ^0.3
- clue/socks-react: ^0.4
- clue/stdio-react: ^0.4
- react/dns: ^0.4 || ^0.3
- react/event-loop: ^0.4 || ^0.3
- react/socket: ^0.4 || ^0.3
- react/socket-client: ^0.5 || ^0.4
- react/stream: ^0.4 || 0.3
README
The SOCKS tunnel / proxy server daemon written in PHP
Features
The SOCKS protocol family can be used to easily tunnel TCP connections independent of the actual application level protocol, such as HTTP, SMTP, IMAP, Telnet, etc. In this mode, a SOCKS server acts as a generic proxy allowing higher level application protocols to work through it.
- SOCKS proxy server with support for SOCKS4, SOCKS4a and SOCKS5 protocol versions (all at the same time)
- Optionally require username / password authentication (SOCKS5 only)
- Zero configuration, easy to use command line interface (CLI) to change settings without restarting server
- Incoming SOCKS requests can be forwarded to another SOCKS server to act as a tunnel gateway,
perform transparent protocol translation or add SOCKS authentication for clients not capable of doing it themselves.
- Tunnel endpoint can be changed during runtime (
via
CLI command). - Particularly useful when used as an intermediary server and using ever-changing public SOCKS tunnel end points.
- Tunnel endpoint can be changed during runtime (
- Using an async event-loop, it is capable of handling multiple concurrent connections in a non-blocking fashion
- Built upon the shoulders of reactphp/react and clue/socks, it uses well-tested dependencies instead of reinventing the wheel.
Usage
Once installed, you can start psocksd
and listen for incoming SOCKS connections by running:
$ php psocksd.phar
Using this command, psocksd
will start listening on the default adress localhost:9050
.
Listen address
If you want to listen on another address, you can supply an explicit listen address like this:
# start SOCKS daemon on port 9051 instead $ php psocksd.phar 9051 # explicitly listen on the given interface $ php psocksd.phar 192.168.1.2:9050 # listen on all interfaces (allow access to SOCKS server from the outside) $ php psocksd.phar *:9050 # explicitly only support SOCKS5 and reject other protocol versions $ php psocksd.phar socks5://localhost:9050 # require client to send the given authentication information $ php psocksd.phar socks5://username:password@localhost:9051
Interactive CLI
By default, psocksd
will run an interactive command line interface.
This means that it keeps running in the foreground and accepts commands from
STDIN
.
You can pass the --no-interaction
argument to disable this interactive mode
so that it does not accept any commands from STDIN
.
The interactive mode is always disabled on Windows, because it's impossible to
read from STDIN
without blocking the whole daemon.
You can run the help
command in order to see all available commands and their
usage:
> help
psocksd help:
[…]
You can run the ping
command in order to test creating a TCP/IP connection
through the given SOCKS server:
> ping 192.168.1.200:1080
ping www.google.com:80
ping test OK (⌚ 0.378s)
You can run the exit
or quit
command (or hit CTRL+D
or CTRL-C
) in
order to exit the program:
> exit
exiting...
Client configuration
Once psocksd
is started, it accepts incoming SOCKS client connections.
Therefor, you have to configure your client program (webbrowser, email client etc.) to actually use the SOCKS server.
The exact configuration depends on your program, but quite a few programs allow you to use a SOCKS proxy. So depending on the above list address, supply the following information:
Proxy-Type: SOCKS4 or SOCKS5
Socks-Host: localhost
Socks-Port: 9050
Install
You can grab a copy of clue/psocksd in either of the following ways.
As a phar (recommended)
You can simply download a pre-compiled and ready-to-use version as a Phar
to any directory.
Simply download the latest psocksd.phar
file from our
releases page:
That's it already. You can now verify everything works by running this:
$ cd ~/Downloads $ php psocksd.phar
If you prefer a global (system-wide) installation without having to type the
.phar
extension each time, you may invoke:$ chmod 0755 psocksd.phar $ sudo mv psocksd.phar /usr/local/bin/psocksdYou can verify everything works by running:
$ psocksd
Updating phar
There's no separate update
procedure, simply overwrite the existing phar with the new version downloaded.
Manual Installation from Source
The manual way to install psocksd
is to clone (or download) this repository
and use composer to download its dependencies.
Obviously, for this to work, you'll need PHP, git and curl installed:
$ sudo apt-get install php5-cli git curl
$ git clone https://github.com/clue/psocksd.git
$ curl -s https://getcomposer.org/installer | php
$ php composer.phar install
If you want to build the above mentioned
psocksd.phar
yourself, you have to install clue/phar-composer and can simply invoke:$ php phar-composer.phar build ~/workspace/psocksd
Updating manually
If you have followed the above install instructions, you can update psocksd
by issuing the following two commands:
$ git pull $ php composer.phar install
Docker
This project is also available as a docker image. Using the clue/psocksd image is as easy as running this:
$ docker run -d -p 9050:9050 clue/psocksd
License
MIT-licensed