#!/bin/sh # # Manage samba shares # - after mounting: add the new samba share # - before umounting: disable and remove the samba share # # The following line _must_ be added to your /etc/samba/smb.conf: # include = /etc/cryptobox/samba-include.conf # # # Params: $event $volume_name $volume_type $mount_dir # # event: premount | postmount | preumount | postumount # device: name of the device # volume_name: name of the volume # volume_type: plain | luks # mount_dir: mount directory # set -eu SAMBA_CONTROL=smbcontrol SAMBA_CONF_DIR=/var/cache/cryptobox/samba.conf.d TEMPLATE_CONF_FILE=/etc/cryptobox/samba-share.conf-template MAIN_SAMBA_CONF_FILE=/etc/cryptobox/samba-include.conf # check if samba is installed test -z "$(which $SAMBA_CONTROL)" && exit 0 # create include-file directory mkdir -p "$SAMBA_CONF_DIR" # check event argument if test "$#" -eq 0 then echo "Syntax: $(basename $0) EVENT [EVENT_INFORMATION]" >&2 exit 1 fi event=$1 # ------------=-=-=- some functions -=-=-=----------------- update_include_conf_file() { ( echo "# this file was automatically generated by the CryptoBox" echo "# DO NOT EDIT - all changes will get lost!" find "$SAMBA_CONF_DIR" -type f -name "*.conf" | while read fname do echo "include = $fname" done ) >"$MAIN_SAMBA_CONF_FILE" } send_reload_command() { # reload config files "$SAMBA_CONTROL" smbd reload-config } send_close_share_command() { # close all connections and deny further requests "$SAMBA_CONTROL" smbd close-share "$1" } # -----------------=-=-=- main -=-=-=---------------------- case "$event" in premount|postumount ) ;; postmount ) vol_name=$3 mount_dir=$5 sed "s#_SHARE_DIR_#$mount_dir#g; s#_VOLUME_NAME_#$vol_name#g" "$TEMPLATE_CONF_FILE" >"$SAMBA_CONF_DIR/${vol_name}.conf" update_include_conf_file send_reload_command ;; preumount ) vol_name=$3 send_close_share_command "$vol_name" rm "$SAMBA_CONF_DIR/${vol_name}.conf" || true update_include_conf_file send_reload_command ;; * ) # ignore all events that we do not support exit 0 ;; esac exit 0