mirror of
https://gitlab.com/crafty-controller/crafty-4.git
synced 2025-01-18 09:05:15 +01:00
34 lines
1.2 KiB
Bash
34 lines
1.2 KiB
Bash
#!/bin/sh
|
|
|
|
# Check if config exists from existing installation (venv or previous docker launch)
|
|
if [ ! "$(ls -A --ignore=.gitkeep ./app/config)" ]; then
|
|
echo "Wrapper | Config not found, pulling defaults..."
|
|
mkdir ./app/config/ 2> /dev/null
|
|
cp -r ./app/config_original/* ./app/config/
|
|
fi
|
|
|
|
|
|
if [ $(id -u) -eq 0 ]; then
|
|
# We're running as root;
|
|
# Need to ensure all dirs are owned by the root group,
|
|
# This fixes bind mounts that may have incorrect perms.
|
|
|
|
# Look for files & dirs that require group permissions to be fixed
|
|
echo "Wrapper | Looking for problem bind mount permissions"
|
|
find . ! -group root -exec chgrp root {} \;
|
|
find . ! -perm g+rw -exec chmod g+rw {} \;
|
|
find . -type d ! -perm g+s -exec chmod g+s {} \;
|
|
|
|
# Switch user, activate our prepared venv and lauch crafty
|
|
args="$@"
|
|
echo "Wrapper | Launching crafty with [$args]"
|
|
exec sudo -u crafty bash -c "source ./.venv/bin/activate && exec python3 main.py $args"
|
|
else
|
|
# Activate our prepared venv
|
|
echo "Wrapper | Non-root host detected, using normal exec"
|
|
. ./.venv/bin/activate
|
|
# Use exec as our perms are already correct
|
|
# This is likely if using Kubernetes/OpenShift etc
|
|
exec python3 main.py $@
|
|
fi
|