tubearchivist-frontend/run.sh

56 lines
1.5 KiB
Bash
Raw Normal View History

2021-09-05 17:10:14 +00:00
#!/bin/bash
# startup script inside the container for tubearchivist
# check environment
if [[ -z "$DJANGO_DEBUG" ]]; then
export DJANGO_DEBUG=False
fi
2021-10-28 08:49:58 +00:00
if [[ -z "$ELASTIC_USER" ]]; then
export ELASTIC_USER=elastic
fi
ENV_VARS=("TA_USERNAME" "TA_PASSWORD" "ELASTIC_PASSWORD" "ELASTIC_USER")
for each in "${ENV_VARS[@]}"; do
if ! [[ -v $each ]]; then
echo "missing environment variable $each"
exit 1
fi
done
# ugly nginx and uwsgi port overwrite with env vars
if [[ -n "$TA_PORT" ]]; then
sed -i "s/8000/$TA_PORT/g" /etc/nginx/conf.d/nginx.conf
fi
if [[ -n "$TA_UWSGI_PORT" ]]; then
sed -i "s/8080/$TA_UWSGI_PORT/g" /etc/nginx/conf.d/nginx.conf
sed -i "s/8080/$TA_UWSGI_PORT/g" /app/uwsgi.ini
fi
# wait for elasticsearch
2021-09-05 17:10:14 +00:00
counter=0
2021-10-28 08:49:58 +00:00
until curl -u "$ELASTIC_USER":"$ELASTIC_PASSWORD" "$ES_URL" -fs; do
2021-09-05 17:10:14 +00:00
echo "waiting for elastic search to start"
counter=$((counter+1))
if [[ $counter -eq 12 ]]; then
2021-10-25 06:23:54 +00:00
# fail after 2 min
2021-09-05 17:10:14 +00:00
echo "failed to connect to elastic search, exiting..."
exit 1
fi
2021-10-25 06:23:54 +00:00
sleep 10
2021-09-05 17:10:14 +00:00
done
# start python application
python manage.py makemigrations
2021-09-05 17:10:14 +00:00
python manage.py migrate
2021-10-25 12:28:05 +00:00
export DJANGO_SUPERUSER_PASSWORD=$TA_PASSWORD && \
python manage.py createsuperuser --noinput --name "$TA_USERNAME"
python manage.py collectstatic --noinput -c
2021-09-05 17:10:14 +00:00
nginx &
celery -A home.tasks worker --loglevel=INFO &
2021-12-08 09:15:25 +00:00
celery -A home beat --loglevel=INFO \
-s "${BEAT_SCHEDULE_PATH:-/cache/celerybeat-schedule}" &
2021-09-05 17:10:14 +00:00
uwsgi --ini uwsgi.ini