shadowsocks-android plugin framework
Support library for easier development on shadowsocks plugin for Android. Also includes some useful resources to easily get consistent styling with the main app.
Official plugins
These are some plugins ready to use on shadowsocks-android.
Developer's guide
This library is designed with Java interoperability in mind so theoretically you can use this library with other languages and/or build tools but there isn't documentation for that yet. This guide is written for Scala + SBT. Contributions are welcome.
Package name
There are no arbitrary restrictions/requirements on package name, component name and content provider authority, but you're suggested to follow the format in this documentations. For package name, use com.github.shadowsocks.plugin.$PLUGIN_ID
if it only contains a single plugin to prevent duplicated plugins. In some places hyphens are not accepted, for example package name. In that case, hyphens -
should be changed into underscores _
. For example, the package name for obfs-local
would probably be com.github.shadowsocks.plugin.obfs_local
.
Add dependency
First you need to add this library to your dependencies. This library is written mostly in Kotlin but can also work with Java-only projects:
Native binary configuration
First you need to get your native binary compiling on Android platform.
In addition to functionalities of a normal plugin, it has to support these additional flags that may get passed through arguments:
-V
: VPN mode. In this case, the plugin should pass all file descriptors that needs protectingfrom VPN connections (i.e. its traffic will not be forwarded through the VPN) through an
ancillary message to
./protect_path
;--fast-open
: TCP fast open enabled.
Implement a binary provider
You just need to implement two or three methods. For example for v2ray
:
Then add it to your manifest:
Add user interfaces
You should add to your plugin app a configuration activity or a help activity or both if you're going to use ConfigurationActivity.fallbackToManualEditor
.
Configuration activity
This is used if found instead of a manual input dialog when user clicks "Configure..." in the main app. This gives you maximum freedom of the user interface. To implement this, you need to extend ConfigurationActivity
and you will get current options via onInitializePluginOptions(PluginOptions)
and you can invoke saveChanges(PluginOptions)
or discardChanges()
before finish()
or fallbackToManualEditor()
. Then add it to your manifest:
Help activity/callback
This is started when user taps "?" in manual editor. To implement this, you need to extend HelpCallback
if you want a simple dialog with help message as CharSequence
or HelpActivity
if you want to provide custom user interface, implement the required methods, then add it to your manifest:
Great. Now your plugin is ready to use.
Last updated