The Outline Client is a cross-platform VPN or proxy client for Windows, macOS, iOS, Android, and ChromeOS. The Outline Client is designed for use with the Outline Server software, but it is fully compatible with any Shadowsocks server.
The client's user interface is implemented in Polymer 2.0. Platform support is provided by Cordova and Electron, with additional native components in this repository.
All builds require yarn, in addition to other per-platform requirements. After cloning this repo, you should run "yarn" to install all dependencies.
Outline clients share the same web app across all platforms. This code is located in the src/www directory. If you are making changes to the shared web app and do not need to test platform-specific functionality, you can test in a desktop browser by running:
yarn build --platform=browser
yarn serve
The latter command will open a browser instance running the app. Browser platform development will use fake servers to test successful and unsuccessful connections.
UI components are located in src/www/ui_components. The app logic is located in src/www/app.
Additional requirements for Android:
- Android Studio
- Android SDK 28
- Gradle (
brew install gradle
)
Update your .bashrc/.bash_profile to include the following paths:
JAVA_HOME="/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home”
ANDROID_HOME="/Users/billdean/Library/Android/sdk"
ANDROID_SDK_ROOT="/Users/billdean/Library/Android/sdk"
PATH=${PATH}:$ANDROID_HOME/tools:$ANDROID_HOME/platform-tools
To build for android, run:
yarn gulp build --platform=android
To rebuild after modifying platform dependent files, run:
yarn cordova platform rm android && yarn gulp build --platform=android
If this gives you unexpected Cordova errors, run:
yarn run clean && yarn && yarn gulp build --platform=android
To install to a connected Android device (with developer mode enabled):
yarn install-android-debug
Cordova will generate a new Android project in the platforms/android directory. Install the built apk by platforms/android/build/outputs/apk/android-armv7-debug.apk
To learn more about developing for Android, see docs/android-development.
Set the BEEPASS_DEV_BROWSER_NAME
environment variable to the name of your development browser (note that Firefox will not work since it can’t be reloaded via AppleScript) and BEEPASS_DEV_SHOULD_AUTO_RELOAD
environment to true
, then:
# In shell 1 (rebuilds and reloads browser if JS or component HTML changes):
yarn build --platform=browser
yarn watch-html-js --platform=browser
# In shell 2 (watches and rebuilds TypeScript files, which will trigger above watch):
yarn watch-typescript-cordova
# In shell 3 (development web server)
yarn serve
watch-html-js
will watch for changes in www/ui_components/*.html
and www/app/*.js
, rebuild the affected parts of the code, and (on macOS) auto-reload the browser specified in BEEPASS_DEV_BROWSER_NAME
. It deliberately excludes parts of the rebuild process (e.g. transpileBowerComponents) to reduce the build time, so some changes will require a new build.
- Set
BEEPASS_ANDROID_KEYALIAS
,BEEPASS_ANDROID_KEYSTORE
,BEEPASS_ANDROID_KEYPASS
, andBEEPASS_ANDROID_STOREPASS
environment variables.
yarn build-android-release
A Docker image with all pre-requisites for Android builds is included. To build:
- Install dependencies with
./tools/build/build.sh yarn
- Then build with
./tools/build/build.sh yarn gulp build --platform=android
Additional requirements for Apple:
- An Apple Developer Account. You will need to be invited to join the "Jigsaw Operations LLC" team
- XCode 11+ (download)
- XCode command line tools
To build for macOS (OS X), run:
yarn run clean && yarn && yarn gulp build --platform=osx
To build for iOS, run:
yarn run clean && yarn && yarn gulp build --platform=ios
To learn more about developing for Apple, see docs/apple-development
Unlike the Android and Apple clients, the Windows and Linux clients use the Electron framework, rather than Cordova.
Additional requirements for building on Windows:
- Cygwin. It provides the "missing Unix pieces" required by build system such as rsync (and many others). It may be necessary to manually choose to install
rsync
in the Cygwin installer.
To build the Electron clients, run:
yarn do src/electron/build
To run the Electron clients, run:
yarn do src/electron/run
To package the Electron clients into an installer executable, run:
yarn do src/electron/package_[linux|windows]
To enable error reporting through Sentry for local builds, run:
export SENTRY_DSN=[Sentry development API key]
[platform-specific build command]
Release builds on CI are configured with a production Sentry API key.