Sem descrição

Rod Hynes 326c0d5c2d Attempt to fix TravisCI build error há 8 anos atrás
ConsoleClient 9682b1bf39 Add simple packet tunnel mode to console client há 8 anos atrás
MobileLibrary 4d8b0208bb Optional delegate method onServerTimestamp há 8 anos atrás
Server 0cc668adf8 Use Go 1.9 há 8 anos atrás
contributors 29c17a7832 Signed CLA há 10 anos atrás
openssl 4f05313337 Updated builds to use openssl-1.0.2h. há 9 anos atrás
psiphon 9e418d62dd Add more memory-monitoring stress tests há 8 anos atrás
.gitignore 96236d0c8b Refactored streaming embedded server list into its own function há 8 anos atrás
.travis.yml 326c0d5c2d Attempt to fix TravisCI build error há 8 anos atrás
CLA-entity.md 39d02d38f5 Fix Contributor License Agreement há 10 anos atrás
CLA-individual.md 39d02d38f5 Fix Contributor License Agreement há 10 anos atrás
CONTRIBUTING.md ac381d0f93 Added Contributor License Agreement há 10 anos atrás
LICENSE 878ccd5658 initial version há 11 anos atrás
README.md 1250beae63 Display package owner in acknowledgements há 8 anos atrás

README.md

Build Status Coverage Status

Psiphon 3 Tunnel Core README

Overview

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.

Status

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.

Client Setup

Build

  • Go 1.8 (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 path github.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 in ConsoleClient to make the ConsoleClient 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 \
      "
      

Platform-specific instructions

macOS

Building without OpenSSL support (that is, without indistinguishable TLS support) requires no extra steps. To compile with OpenSSL support, follow these steps:

  1. You must have Homebrew installed.

  2. brew install openssl pkg-config

  3. Find out where Homebrew put the pkgconfig files for OpenSSL -- the location depends on your Homebrew installation. Run this command:

    $ brew info openssl
    

Make note of the "build variable" path for PKG_CONFIG_PATH.

  1. Set PKG_CONFIG_PATH=<path discovered above> when building, and provide the -tags OPENSSL flag. This can be easily done on the build command line like so:

    $ PKG_CONFIG_PATH=<path discovered above> go build -tags OPENSSL
    

Configure

  • 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

  • Run ./ConsoleClient --config psiphon.config where psiphon.config is created as described in the Configure section above

Other Platforms

Acknowledgements

Psiphon Tunnel Core uses:

Licensing

Please see the LICENSE file.

Contacts

We maintain a developer mailing list at psiphon3-developers@googlegroups.com. For more information about Psiphon Inc., please visit our web site at www.psiphon.ca.