Move Dockerfile and assets, add labels for MicroBadger
This commit is contained in:
94
seafile-client/docker-entrypoint.sh
Normal file
94
seafile-client/docker-entrypoint.sh
Normal file
@@ -0,0 +1,94 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Docker Seafile client, help you mount a Seafile library as a volume.
|
||||
# Copyright (C) 2019-2020, flow.gunso@gmail.com
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# Check mandatory Seafile configuration have been properly set.
|
||||
if [ -z $SEAF_SERVER_URL ]; then
|
||||
echo "The \$SEAF_SERVER_URL is not defined. Stopping container..."
|
||||
exit 1
|
||||
fi
|
||||
if [ -z $SEAF_USERNAME ]; then
|
||||
echo "The \$SEAF_USERNAME is not defined. Stopping container..."
|
||||
exit 1
|
||||
fi
|
||||
if [ -z $SEAF_PASSWORD ]; then
|
||||
echo "The \$SEAF_PASSWORD is not defined. Stopping container..."
|
||||
exit 1
|
||||
fi
|
||||
if [ -z $SEAF_LIBRARY_UUID ]; then
|
||||
echo "The \$SEAF_LIBRARY_UUID is not defined. Stopping container..."
|
||||
exit 1
|
||||
fi
|
||||
if [[ -n "$SEAF_UPLOAD_LIMIT"
|
||||
&& $SEAF_UPLOAD_LIMIT =~ ^[0-9]+$
|
||||
&& "$SEAF_UPLOAD_LIMIT" -gt 0 ]]; then
|
||||
echo "The \$SEAF_UPLOAD_LIMIT is not an integer greater than 0. Stopping container..."
|
||||
exit 1
|
||||
fi
|
||||
if [[ -n "$SEAF_DOWNLOAD_LIMIT"
|
||||
&& $SEAF_DOWNLOAD_LIMIT =~ ^[0-9]+$
|
||||
&& "$SEAF_DOWNLOAD_LIMIT" -gt 0 ]]; then
|
||||
echo "The \$SEAF_DOWNLOAD_LIMIT is not an integer greater than 0. Stopping container..."
|
||||
exit 1
|
||||
fi
|
||||
if [ -n "$SEAF_2FA_SECRET" ]; then
|
||||
curl -X POST http://2fa:1880/auth \
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"secret":"YWAMNW7YTTB2QDU6ENTJ4LIPUYFUG4SW","key":"docker-seaf-cli","desc":"/"}'
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Could create an 2FA token provider at $SEAF_2FA_PROVIDER. curl error $?"
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
# Update the user ID, if the $UID changed.
|
||||
if [ "$UID" != "1000" ]; then
|
||||
usermod -u $UID $UNAME
|
||||
# What if the $UID already exists ?
|
||||
fi
|
||||
|
||||
# Change the group, if the $GID changed.
|
||||
if [ "$GID" != "1000" ]; then
|
||||
getent group | grep ":$GID:" >/dev/null
|
||||
if [ $? -eq 0 ]; then
|
||||
usermod -g $GID -G 1000 $UNAME
|
||||
else
|
||||
groupmod -g $GID $UNAME
|
||||
fi
|
||||
fi
|
||||
|
||||
# Set the files ownership.
|
||||
chown $UID.$GID /home/seafuser/seafile-healthcheck.sh
|
||||
chown $UID.$GID /home/seafuser/entrypoint.sh
|
||||
chown $UID.$GID -R /volume
|
||||
|
||||
# Run the Seafile client as the container user.
|
||||
su - $UNAME << EO
|
||||
export SEAF_SERVER_URL=$SEAF_SERVER_URL
|
||||
export SEAF_USERNAME=$SEAF_USERNAME
|
||||
export SEAF_PASSWORD=$SEAF_PASSWORD
|
||||
export SEAF_LIBRARY_UUID=$SEAF_LIBRARY_UUID
|
||||
export SEAF_SKIP_SSL_CERT=$SEAF_SKIP_SSL_CERT
|
||||
test -n "$SEAF_UPLOAD_LIMIT" && export SEAF_UPLOAD_LIMIT=$SEAF_UPLOAD_LIMIT
|
||||
test -n "$SEAF_DOWNLOAD_LIMIT" && export SEAF_DOWNLOAD_LIMIT=$SEAF_DOWNLOAD_LIMIT
|
||||
test -n "$SEAF_2FA_SECRET" && export SEAF_2FA_SECRET=$SEAF_2FA_SECRET
|
||||
test -n "$SEAF_LIBRARY_PASSWORD" && export SEAF_LIBRARY_PASSWORD=$SEAF_LIBRARY_PASSWORD
|
||||
export UNAME=$UNAME
|
||||
/bin/bash /home/seafuser/entrypoint.sh
|
||||
EO
|
||||
|
||||
cron -f
|
||||
Reference in New Issue
Block a user