Initital Commit
This commit is contained in:
commit
e0b47ab989
24
Dockerfile
Normal file
24
Dockerfile
Normal file
|
@ -0,0 +1,24 @@
|
|||
############################################################
|
||||
# Dockerfile to build borgbackup server images
|
||||
# Based on Debian
|
||||
############################################################
|
||||
FROM debian:latest
|
||||
|
||||
# Volume for SSH-Keys
|
||||
VOLUME /sshkeys
|
||||
|
||||
# Volume for borg repositories
|
||||
VOLUME /backup
|
||||
|
||||
RUN apt-get update && apt-get -y install borgbackup openssh-server
|
||||
RUN useradd -s /bin/bash -m borg
|
||||
RUN mkdir /home/borg/.ssh && chmod 700 /home/borg/.ssh && chown borg: /home/borg/.ssh
|
||||
RUN mkdir /run/sshd
|
||||
|
||||
COPY ./data/run.sh /run.sh
|
||||
COPY ./data/sshd_config /etc/ssh/sshd_config
|
||||
|
||||
CMD /bin/bash -x /run.sh
|
||||
|
||||
# Default SSH-Port for clients
|
||||
EXPOSE 22
|
42
data/run.sh
Normal file
42
data/run.sh
Normal file
|
@ -0,0 +1,42 @@
|
|||
#!/bin/bash
|
||||
# Init borg-users .ssh/authorized_keys
|
||||
|
||||
BORG_DATA_DIR=/backup
|
||||
BORG_CMD='cd ${BORG_DATA_DIR}/${client_name}; borg serve --append-only --restrict-to-path ${BORG_DATA_DIR}/${client_name}'
|
||||
SSH_KEY_DIR=/sshkeys
|
||||
|
||||
# add all sshkeys to borg-user's authorized_keys & create repositories
|
||||
echo "########################################################"
|
||||
for dir in BORG_DATA_DIR SSH_KEY_DIR ; do
|
||||
dirpath=$(eval echo '$'$dir)
|
||||
echo "Testing Volume $dir: $dirpath"
|
||||
if [ ! -d "$dirpath" ] ; then
|
||||
echo " ERROR: $dirpath is no directory!"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ $(find $SSH_KEY_DIR -type f | wc -l) == 0 ] ; then
|
||||
echo "ERROR: No SSH-Pubkey file found in $SSH_KEY_DIR"
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
echo "########################################################"
|
||||
|
||||
echo "Starting SSH-Key import..."
|
||||
for keyfile in $(find $SSH_KEY_DIR -type f); do
|
||||
client_name=$(basename $keyfile)
|
||||
echo "Adding client ${client_name} with repo path ${BORG_DATA_DIR}/${client_name}"
|
||||
mkdir ${BORG_DATA_DIR}/${client_name} 2>/dev/null
|
||||
echo -n "command=\"$(eval echo -n \"$BORG_CMD\")\" " >> /home/borg/.ssh/authorized_keys
|
||||
cat $keyfile >> /home/borg/.ssh/authorized_keys
|
||||
done
|
||||
|
||||
chown -R borg: /backup
|
||||
chown borg: /home/borg/.ssh/authorized_keys
|
||||
chmod 600 /home/borg/.ssh/authorized_keys
|
||||
|
||||
echo "Init done!"
|
||||
echo "########################################################"
|
||||
echo "Starting SSH-Daemon"
|
||||
|
||||
/usr/sbin/sshd -D -e
|
30
data/sshd_config
Normal file
30
data/sshd_config
Normal file
|
@ -0,0 +1,30 @@
|
|||
Port 22
|
||||
AddressFamily any
|
||||
ListenAddress 0.0.0.0
|
||||
ListenAddress ::
|
||||
|
||||
HostKey /etc/ssh/ssh_host_rsa_key
|
||||
HostKey /etc/ssh/ssh_host_ecdsa_key
|
||||
HostKey /etc/ssh/ssh_host_ed25519_key
|
||||
|
||||
PermitRootLogin no
|
||||
StrictModes yes
|
||||
MaxSessions 20
|
||||
|
||||
PubkeyAuthentication yes
|
||||
AuthorizedKeysFile .ssh/authorized_keys
|
||||
|
||||
LogLevel INFO
|
||||
#LogLevel DEBUG
|
||||
|
||||
PasswordAuthentication no
|
||||
ChallengeResponseAuthentication no
|
||||
UsePAM yes
|
||||
AllowAgentForwarding no
|
||||
AllowTcpForwarding no
|
||||
X11Forwarding no
|
||||
PermitTTY no
|
||||
PrintMotd no
|
||||
UsePrivilegeSeparation sandbox
|
||||
PermitTunnel no
|
||||
Subsystem sftp /bin/false
|
Loading…
Reference in a new issue