Psiphon client and server components implemented in Go. These components provides core tunnel functionality, handling all aspects of evading blocking and relaying traffic through Psiphon. In the client, local proxies provide an interface for routing traffic through the tunnel.
The client component does not include a UI and does not handle capturing or routing local traffic. These major aspects are handled by other parts of Psiphon client applications.
This project is in production and used as the tunneling engine in our Windows and Android clients, which are available at our Psiphon 3 repository.
- Go 1.9 (or higher) is required.
- This project builds and runs on recent versions of Windows, Linux, and Mac OS X.
- Note that the
psiphon
package is imported using the absolute pathgithub.com/Psiphon-Labs/psiphon-tunnel-core/psiphon
; without further local configuration,go
will use this version of the code and not the local copy in the repository. - In this repository, run
go build
inConsoleClient
to make theConsoleClient
binary, a console Psiphon client application.-
Build versioning info may be configured as follows, and passed to
go build
in the-ldflags
argument:BUILDDATE=$(date --iso-8601=seconds) BUILDREPO=$(git config --get remote.origin.url) BUILDREV=$(git rev-parse --short HEAD) GOVERSION=$(go version | perl -ne '/go version (.*?) / && print $1') DEPENDENCIES=$(echo -n "{" && go list -f '{{range $dep := .Deps}}{{printf "%s\n" $dep}}{{end}}' | xargs go list -f '{{if not .Standard}}{{.ImportPath}}{{end}}' | xargs -I pkg bash -c 'cd $GOPATH/src/pkg && echo -n "\"pkg\":\"$(git rev-parse --short HEAD)\","' | sed 's/,$/}/') LDFLAGS="\ -X github.com/Psiphon-Labs/psiphon-tunnel-core/psiphon/common.buildDate=$BUILDDATE \ -X github.com/Psiphon-Labs/psiphon-tunnel-core/psiphon/common.buildRepo=$BUILDREPO \ -X github.com/Psiphon-Labs/psiphon-tunnel-core/psiphon/common.buildRev=$BUILDREV \ -X github.com/Psiphon-Labs/psiphon-tunnel-core/psiphon/common.goVersion=$GOVERSION \ -X github.com/Psiphon-Labs/psiphon-tunnel-core/psiphon/common.dependencies=$DEPENDENCIES \ "
-
- Configuration files are standard text files containing a valid JSON object. Example:
{
"PropagationChannelId" : "<placeholder>",
"SponsorId" : "<placeholder>",
"LocalHttpProxyPort" : 8080,
"LocalSocksProxyPort" : 1080
}
Note: The lines <!--BEGIN-SAMPLE-CONFIG-->
and <--END-SAMPLE-CONFIG-->
(visible in the raw Markdown) are used by the config test. Do not remove them.
- All config file parameters are documented here.
- Replace each
<placeholder>
with a value from your Psiphon server. The Psiphon server-side stack is open source and can be found in our Psiphon 3 repository.
- Run
./ConsoleClient --config psiphon.config
wherepsiphon.config
is created as described in the Configure section above
- The project builds and runs on Android. See the Android Library README for more information about building the Go component, and the Android Sample App README for a sample Android app that uses it.
Psiphon Tunnel Core uses:
- Go
- boltdb/bolt
- patrickmn/go-cache
- miekg/dns
- ThomsonReutersEikon/go-ntlm
- Yawning/goptlib
- zach-klippenstein/goregen
- creack/goselect
- Sirupsen/logrus
- grafov/m3u8
- oschwald/maxminddb-golang
- goarista/monotime
- spacemonkeygo/openssl
- kardianos/osext
- mitchellh/panicwrap
- juju/ratelimit
- codahale/sss
- marusama/semaphore
- refraction-networking/utls
- lucas-clemente/quic-go
- cloudflare/tls-tris
- Yawning/chacha20
Please see the LICENSE file.
We maintain a developer mailing list at [email protected]. For more information about Psiphon Inc., please visit our web site at www.psiphon.ca.