The internal name for the Outline server is "Shadowbox". It is a server set up that runs a user management API and starts Shadowsocks instances on demand.
It aims to make it as easy as possible to set up and share a Shadowsocks server. It's managed by the Outline Manager and used as proxy by the Outline client apps. Shadowbox is also compatible with standard Shadowsocks clients.
To install and run Shadowbox on your own server, run
sudo bash -c "$(wget -qO- https://raw.githubusercontent.com/Jigsaw-Code/outline-server/master/src/server_manager/install_scripts/install_server.sh)"
You can specify flags to customize the installation. For example, to use hostname myserver.com
and the port 443 for access keys, you can run:
sudo bash -c "$(wget -qO- https://raw.githubusercontent.com/Jigsaw-Code/outline-server/master/src/server_manager/install_scripts/install_server.sh)" install_server.sh --hostname=myserver.com --keys-port=443
Use sudo --preserve-env
if you need to pass environment variables. Use bash -x
if you need to debug the installation.
Shadowbox supports running on linux and macOS hosts.
Besides Node you will also need:
Build and run the server as a Node.js app:
npm run action shadowbox/server/start
The output will be at build/shadowbox/app
.
Build the image and run server:
npm run action shadowbox/docker/start
You should be able to successfully query the management API:
curl --insecure https://[::]:8081/TestApiPrefix/server
To build the image only:
npm run action shadowbox/docker/build
Debug image:
docker run --rm -it --entrypoint=sh outline/shadowbox
Or a running container:
docker exec -it shadowbox sh
Delete dangling images:
docker rmi $(docker images -f dangling=true -q)
In order to utilize the Management API, you'll need to know the apiUrl for your Outline server. You can obtain this information from the "Settings" tab of the server page in the Outline Manager. Alternatively, you can check the 'access.txt' file under the '/opt/outline' directory of an Outline server. An example apiUrl is: https://1.2.3.4:1234/3pQ4jf6qSr5WVeMO0XOo4z.
See Full API Documentation. The OpenAPI specification can be found at api.yml.
Start by storing the apiURL you see see in that file, as a variable. For example:
API_URL=https://1.2.3.4:1234/3pQ4jf6qSr5WVeMO0XOo4z
You can then perform the following operations on the server, remotely.
List access keys
curl --insecure $API_URL/access-keys/
Create an access key
curl --insecure -X POST $API_URL/access-keys
Rename an access key (e.g. rename access key 2 to 'albion')
curl --insecure -X PUT curl -F 'name=albion' $API_URL/access-keys/2/name
Remove an access key (e.g. remove access key 2)
curl --insecure -X DELETE $API_URL/access-keys/2
Set a data limit for all access keys (e.g. limit outbound data transfer access keys to 1MB over 30 days)
curl -v --insecure -X PUT -H "Content-Type: application/json" -d '{"limit": {"bytes": 1000}}' $API_URL/experimental/access-key-data-limit
Remove the access key data limit
curl -v --insecure -X DELETE $API_URL/experimental/access-key-data-limit
After building a docker image with some local changes, upload it to your favorite registry (e.g. Docker Hub, quay.io, etc.).
Then set your SB_IMAGE
environment variable to point to the image you just
uploaded (e.g. export SB_IMAGE=yourdockerhubusername/shadowbox
) and
run npm run action server_manager/electron_app/start
and your droplet should be created with your
modified image.
To run the integration test:
npm run action shadowbox/integration_test/start
This will set up three containers and two networks:
client <-> shadowbox <-> target
client
can only access target
via shadowbox. We create a user on shadowbox
then connect using the Shadowsocks client.
To test clients that rely on fetching a docker image from Dockerhub, you can push an image to your account and modify the client to use your image. To push your own image:
npm run action shadowbox/docker/build && docker tag quay.io/outline/shadowbox $USER/shadowbox && docker push $USER/shadowbox
If you need to test an unsigned image (e.g. your dev one):
DOCKER_CONTENT_TRUST=0 SB_IMAGE=$USER/shadowbox npm run action shadowbox/integration_test/start
You can add tags if you need different versions in different clients.
If your change includes new fields in the server config which are needed at server start-up time, then you mey need to remove the pre-existing test config:
rm /tmp/outline/persisted-state/shadowbox_server_config.json
This will warn about deleting a write-protected file, which is okay to ignore. You will then need to hand-edit the JSON string in src/shadowbox/docker/start.action.sh.