Psiphon is a circumvention tool from Psiphon Inc. that utilizes VPN, SSH and HTTP Proxy technology to provide you with uncensored access to Internet content. Your Psiphon client will automatically learn about new access points to maximize your chances of bypassing censorship.
Psiphon is designed to provide you with open access to online content. Psiphon does not increase your online privacy, and should not be considered or used as an online security tool. This is a multifunctional modified linux version of the original tool by Psiphon Inc.
Forked the pyclient from https://bitbucket.org/psiphon/psiphon-circumvention-system/
Getting Started (Linux and Mac OS X 10.11 or older) (For Mac OS X (After 10.12) and Windows, instructions are at the end of this README)
$ git clone <repo url>
$ cd psiphon
Things needed to get it working.
- python 2.7 and above
- python-pip
$ sudo apt-get install python-pip
A step by step guide :
-
However an ssh binary is provided for ubuntu 14.04, it is highly recommended to compile your ssh binary to remove compatibility issues.
psiphon$ cd openssh-5.9p1 openssh-5.9p1$ ./configure
Install the required dependencies if error occurs. Use make command after successful verification of dependencies.
openssh-5.9p1$ make
A ssh binary will be created on successful completion of make command. After removing existing binary file, copy the new binary to main psiphon folder.
openssh-5.9p1$ cd .. psiphon$ rm ssh psiphon$ cp openssh-5.9p1/ssh .
Your binary is ready for running.
-
However a server list has been provided, it is highly recommended to update servers from time to time.
psiphon$ python psi_client.py -u
It requires Internet connection. If error occurs in the script, Use pip to install required packages.
If error is "ImportError: No module named wget", Run the following command:
$ sudo pip install wget
etc.
Upon successful completion, Use the following command to list all the servers.
For obfuscated ssh (OSSH) servers only :
psiphon$ python psi_client.py -s
For All servers including non obfuscated ssh ones :
psiphon$ python psi_client.py -s -a
For further filtering region wise, add -r filter to the above commands. Ex, For India Servers (only ossh ones) :
psiphon$ python psi_client.py -s -r IN
-
Use the Following command to run psiphon:
psiphon$ python psi_client.py
Connecting region wise (Lets say India):
psiphon$ python psi_client.py -r IN
These commands will establish a socks proxy on default port 1080. To change the default port use -p flag:
psiphon$ python psi_client.py -r IN -p 1234
To see all India servers add -s flag to the above commands:
psiphon$ python psi_client.py -r IN -p 1234 -s
To Connect to specific ip server with a serial number 2 from the above result:
psiphon$ python psi_client.py -r IN -p 1234 -i 2
In case of error: example- "ImportError: No module named pexpect"
$ sudo pip install pexpect
Make alias for convenience:
$ echo 'alias psiphon="cd ~/psiphon && python psi_client.py"' >> ~/.bashrc
Now on a new terminal:
$ psiphon -h $ psiphon
Psiphon should now be running successfully on your machine.
psiphon$ python psi_client.py -h
Usage: psi_client.py [options]
Options:
-h, --help show this help message and exit
-e, --expose Expose SOCKS proxy to the network
-t, --test-servers Test all servers
-r REGION, --reg=REGION
Regions
-s, --show Show available servers
-p PORT, --port=PORT Local Port
-u, --update Update Servers
-i SID, --sid=SID Server number
-a, --all Include Non OSSH servers also
psiphon$ python psi_client.py -t
psiphon$ python psi_client.py -t -r IN
This can be used to share socks proxy created over a specific port.
psiphon$ python psi_client.py -e
psiphon$ python psi_client.py -e -p 1234
You can use the docker image of the psiphon client and run psiphon on any OS.
Get Docker https://www.docker.com
docker pull thepsiphonguys/psiphon
docker run -d -it -p 127.0.0.1:1080:1080 --name psiphon thepsiphonguys/psiphon
docker start psiphon
docker exec -it psiphon bash
After that you will get access to the shell and can use all the psiphon commands. This method forwards all the docker's traffic on port 1080 (psiphon's default port) to the machine's 1080 port.
To stop psiphon
docker stop psiphon
PS: remember to use the -e option of psiphon otherwise it will not work
PPS: You can also use docker on linux if you do not wan't to compile your own ssh binary. Docker is system independent.
PPPS: If you do not want to use our docker image, it is totally fine. You can create your own docker image with the help of the Dockerfile. Refer to https://docs.docker.com/engine/reference/commandline/build/ for more details on how to build the docker image.
docker build -t psiphon .