GitXplorerGitXplorer
f

docker-rpi-syncthing

public
33 stars
16 forks
1 issues

Commits

List of commits on branch master.
Verified
d582af02d9fda627e5a4e7e8925c67c7ac4b9d6b

Bump to v1.18.0 (#12)

aaltaris committed 3 years ago
Unverified
414e0eb0032e8178f793aacf1b2678eec7f5569d

Updates to 1.7.1

ffunkyfuture committed 4 years ago
Unverified
cc2d137620e95f5e24c20d1232f44b8a5c50570c

Updates to 1.3.1

ffunkyfuture committed 5 years ago
Unverified
6a3b430e351131833e14ea03989103d2a45e385e

README: Updates build instructions and port exposure

ffunkyfuture committed 5 years ago
Unverified
cb0abda38ebb88ee5feaf070a9d13ba0947f3c44

Makefile: Fixes image name and removes run target

ffunkyfuture committed 5 years ago
Unverified
46f82fb2a3c4588e8304c7b4725e677dcc57de2b

Adds a Makefile for builds

ffunkyfuture committed 5 years ago

README

The README file for this repository.

RPi-Syncthing

This is a Docker image targeting Raspberry Pi hosts containing Syncthing which describes itself:

Syncthing replaces proprietary sync and cloud services with something open, trustworthy and decentralized. Your data is your data alone and you deserve to choose where it is stored, if it is shared with some third party and how it's transmitted over the Internet.

What's the current latest version?

Contributions are welcome.

Pull

docker pull funkyfuture/rpi-syncthing

Build

git clone https://github.com/funkyfuture/docker-rpi-syncthing
make -C docker-rpi-syncthing

Run

Here's an example configuration that is suited to manage an instance with docker-compose:

version: '2'

services:
  client:
    image: funkyfuture/rpi-syncthing
    restart: unless-stopped
    ports:
      - "8384:8384"
      - "22000:22000"
      - "21027:21027/udp"
    volumes:
      - ./config:/syncthing/config
      - ./data:/syncthing/data
    environment:
      - GUI_USERNAME=ziggy
      - GUI_PASSWORD_PLAIN=stardust

For those eager to quickly test this image:

docker run --rm --network=host funkyfuture/rpi-syncthing

Configuration

The numeric user and group id of the user running the client are set with the environment variables UID and GID. Both default to 1000. This affects the ownership of the stored data in /syncthing and $CONFIG_DIR.

You can pass these environment variables to configure the client:

  • CONFIG_DIR (default: /syncthing/config)
  • DEBUG can be set to on
  • GUI_ADDRESS (default: [::]:8384)
  • GUI_APIKEY
  • GUI_ENABLED (default: true)
  • GUI_PASSWORD_PLAIN
  • GUI_PASSWORD_BCRYPT (takes precedence over ..._PLAIN)
  • GUI_TLS (default: false)
  • GUI_USERNAME

Further customization

To further customize the configuration you can provide your own $CONFIG_DIR/config.xml to the container. Note that the configuration values resp. their defaults above will be applied on it (but this is going to be more sensible at some point).

You may also add a /pre-launch.sh that will be run (by sourceing) after the configuration values have been applied. For convenient xml-manipulation you can use xmlstarlet, see start.sh for examples and a wrapper function. The user context at this point is still root, the designated user context to run syncthing is available as $UID, $GID, $USER_NAME and $GROUP_NAME.

Resources

Docker Hub repository

https://registry.hub.docker.com/u/funkyfuture/rpi-syncthing/

Source repository

https://github.com/funkyfuture/docker-rpi-syncthing

Syncthing configuration docs

https://docs.syncthing.net/users/config.html

xmlstarlet documentation

http://xmlstar.sourceforge.net/doc/UG/