/rclone-samba-server

Fork https://gitlab.com/encircle360-oss/rclone-samba-server

Primary LanguageDockerfile

Rclone-Samba-Server

This docker image provides you with a small samba-server that exposes your rclone remote. You can then access all your rclones remote files via SMB/CIFS.

Quickstart

Your rclone.conf file in the directory you mount into the docker container needs to contain a remote with the name remote. Only this remote will be mounted and exposed via SMB/CIFS.

git clone https://github.com/CevreMuhendisi/rclone-samba-server rsc/ && cd rsc
docker build . -t rclonesambaserver

docker run -dit --name=rclonesambaserver --privileged --cap-add SYS_ADMIN --device /dev/fuse --restart always -v /root:/rclone/config -e SHARE="remote;/mnt/remote" -p 0.0.0.0:139:139 -p 0.0.0.0:445:445 rclonesambaserver:latest
[remote] # the name here is important
type = crypt
remote = gdrive:storage/rclone-path
filename_encryption = standard
directory_name_encryption = true
... further settings
docker run -v /path/to/rclone/confdir:/rclone/config -e SHARE="remote;/mnt/remote" -p 0.0.0.0:139:139 -p 0.0.0.0:445:445 registry.gitlab.com/encircle360-oss/rclone-samba-server:latest

Afterwards just use the Samba client or tool you want to connect to the host you binded. In case of the example it's the host which runs docker (10.10.10.10).

mkdir -p /mnt/test
sudo mount -t cifs //10.10.10.10/<share> /mnt/test

Complete Mac OS example (public share without credentials)

docker run -e NMBD=true -e SHARE="public;/mnt/remote" -p 139:139 -p 445:445 -p 137:137/udp -p 138:138/udp --cap-add SYS_ADMIN --device /dev/fuse -d --name samba  --restart always -v /path/to/rclone/confdir:/rclone/config registry.gitlab.com/encircle360-oss/rclone-samba-server:latest
sudo mkdir -p /Volumes/smbshare
sudo mount_smbfs -N //guest@localhost/public /Volumes/smbshare

Customization

You can customize many settings in the underlying samba-server. For example it's also possible to restrict access to shares to some created users.

You can find all customization options and environment variables here. Please be aware that mostly only the environment variables work with this image.

Ideas & Improvements

  • Make rclone mount configurable
  • Multiple rcloune mounts and samba exports