2020-07-16 14:08:58 -04:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# detect userid:groupid of contents of data folder
|
|
|
|
DATA_DIR="${DATA_DIR:-/data}"
|
|
|
|
ARCHIVEBOX_USER="${ARCHIVEBOX_USER:-archivebox}"
|
|
|
|
|
|
|
|
# Autodetect UID and GID of host user based on ownership of files in the volume
|
|
|
|
USID=$(stat --format="%u" "$DATA_DIR")
|
|
|
|
GRID=$(stat --format="%g" "$DATA_DIR")
|
|
|
|
COMMAND="$@"
|
|
|
|
|
|
|
|
# run django as the host user's uid:gid so that any files touched have the same permissions as outside the container
|
|
|
|
# e.g. ./manage.py runserver
|
|
|
|
|
|
|
|
chown "$USID":"$GRID" "$DATA_DIR"
|
2020-07-21 13:47:21 -04:00
|
|
|
|
2020-07-21 16:14:54 -04:00
|
|
|
if [[ "$USID" != 0 && "$GRID" != 0 ]]; then
|
|
|
|
usermod -u $USID $ARCHIVEBOX_USER
|
|
|
|
groupmod -g $GRID $ARCHIVEBOX_USER
|
|
|
|
chown -R "$USID":"$GRID" "/home/$ARCHIVEBOX_USER"
|
2020-07-21 13:47:21 -04:00
|
|
|
fi
|
2020-07-20 22:25:01 -04:00
|
|
|
gosu $ARCHIVEBOX_USER bash -c "$COMMAND"
|