Skip to content

biyuhao/ShadowsocksX-NG

This branch is 187 commits behind shadowsocks/ShadowsocksX-NG:develop.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

3b724d7 · Dec 5, 2017
Oct 20, 2017
Oct 25, 2017
Oct 24, 2017
Mar 18, 2017
Dec 5, 2017
Aug 1, 2017
Nov 26, 2017
Jun 14, 2016
Oct 20, 2017
Mar 11, 2017
Jan 13, 2017
Oct 24, 2017
Oct 25, 2017
Dec 5, 2017
Jan 17, 2017
Jun 10, 2016

Repository files navigation

ShadowsocksX-NG

Current version is 1.7.0

Build Status

Next Generation of ShadowsocksX

Why?

It's hard to maintain the original implementation as there is too much unused code in it. It also embeds the ss-local source. It's crazy to maintain dependencies of ss-local. So it's hard to update the ss-local version.

Now I just copied the ss-local from Homebrew. Run ss-local executable as a Launch Agent in the background. Serve PAC JS file as a file URL. So there is only some source code related to GUI left. Then I will rewrite the GUI code in Swift.

Requirements

Running

  • macOS 10.11+

Building

  • Xcode 9.1+
  • CocoaPods 1.2+

Download

From here

Features

  • Uses ss-local from shadowsocks-libev 3.0.5
  • Could update PAC by download GFW List from GitHub.
  • Shows QRCode for current server profile.
  • Scans QRCode from screen.
  • Auto launch at login.
  • User rules for PAC.
  • Support for AEAD Ciphers
  • HTTP Proxy by privoxy
  • Over kcptun. Version 20170322
  • Export/Import configure file.
  • An advanced preferences panel for configuring:
    • Local SOCKS5 listen address.
    • Local SOCKS5 listen port.
    • Local SOCKS5 timeout.
    • If enable UDP relay.
    • GFW List URL.
  • Manually specify network service profiles which would be used to configure the proxy.
  • Could reorder shadowsocks profiles by drag-&-dropping in servers preferences panel.
  • Configurable global shortcuts for toggle running and switch proxy mode.

Difference from original ShadowsocksX

ss-local is run as a background service through launchd, not as an in-app process. So after you quit the app, the ss-local might be still running.

Added a manual mode which won't configure the system proxy settings, so that you could configure your apps to use the SOCKS5 proxy manually.

Contributing

Contributions must be available on a separately named branch based on the latest version of the main branch develop.

ref: GitFlow

License

The project is released under the terms of the GPLv3.

About

Next Generation of ShadowsocksX

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Swift 68.1%
  • Objective-C 24.7%
  • Python 3.7%
  • Shell 2.9%
  • Other 0.6%