ee40e339c8
Fix all instances of "Netbox". ```Shell git ls-files -z . | xargs --null -I '{}' find './{}' -type f -print0 | xargs --null sed --in-place --regexp-extended 's#Netbox#NetBox#g;' ``` Ref: https://netbox.readthedocs.io/en/stable/development/style-guide/#branding
73 lines
2.2 KiB
Bash
Executable File
73 lines
2.2 KiB
Bash
Executable File
#!/bin/bash
|
|
# Runs on every start of the NetBox Docker container
|
|
|
|
# Stop when an error occures
|
|
set -e
|
|
|
|
# Allows NetBox to be run as non-root users
|
|
umask 002
|
|
|
|
# Load correct Python3 env
|
|
source /opt/netbox/venv/bin/activate
|
|
|
|
# Try to connect to the DB
|
|
DB_WAIT_TIMEOUT=${DB_WAIT_TIMEOUT-3}
|
|
MAX_DB_WAIT_TIME=${MAX_DB_WAIT_TIME-30}
|
|
CUR_DB_WAIT_TIME=0
|
|
while ! ./manage.py migrate 2>&1 && [ "${CUR_DB_WAIT_TIME}" -lt "${MAX_DB_WAIT_TIME}" ]; do
|
|
echo "⏳ Waiting on DB... (${CUR_DB_WAIT_TIME}s / ${MAX_DB_WAIT_TIME}s)"
|
|
sleep "${DB_WAIT_TIMEOUT}"
|
|
CUR_DB_WAIT_TIME=$(( CUR_DB_WAIT_TIME + DB_WAIT_TIMEOUT ))
|
|
done
|
|
if [ "${CUR_DB_WAIT_TIME}" -ge "${MAX_DB_WAIT_TIME}" ]; then
|
|
echo "❌ Waited ${MAX_DB_WAIT_TIME}s or more for the DB to become ready."
|
|
exit 1
|
|
fi
|
|
|
|
# Create Superuser if required
|
|
if [ "$SKIP_SUPERUSER" == "true" ]; then
|
|
echo "↩️ Skip creating the superuser"
|
|
else
|
|
if [ -z ${SUPERUSER_NAME+x} ]; then
|
|
SUPERUSER_NAME='admin'
|
|
fi
|
|
if [ -z ${SUPERUSER_EMAIL+x} ]; then
|
|
SUPERUSER_EMAIL='admin@example.com'
|
|
fi
|
|
if [ -f "/run/secrets/superuser_password" ]; then
|
|
SUPERUSER_PASSWORD="$(< /run/secrets/superuser_password)"
|
|
elif [ -z ${SUPERUSER_PASSWORD+x} ]; then
|
|
SUPERUSER_PASSWORD='admin'
|
|
fi
|
|
if [ -f "/run/secrets/superuser_api_token" ]; then
|
|
SUPERUSER_API_TOKEN="$(< /run/secrets/superuser_api_token)"
|
|
elif [ -z ${SUPERUSER_API_TOKEN+x} ]; then
|
|
SUPERUSER_API_TOKEN='0123456789abcdef0123456789abcdef01234567'
|
|
fi
|
|
|
|
./manage.py shell --interface python << END
|
|
from django.contrib.auth.models import User
|
|
from users.models import Token
|
|
if not User.objects.filter(username='${SUPERUSER_NAME}'):
|
|
u=User.objects.create_superuser('${SUPERUSER_NAME}', '${SUPERUSER_EMAIL}', '${SUPERUSER_PASSWORD}')
|
|
Token.objects.create(user=u, key='${SUPERUSER_API_TOKEN}')
|
|
END
|
|
|
|
echo "💡 Superuser Username: ${SUPERUSER_NAME}, E-Mail: ${SUPERUSER_EMAIL}"
|
|
fi
|
|
|
|
# Run the startup scripts (and initializers)
|
|
if [ "$SKIP_STARTUP_SCRIPTS" == "true" ]; then
|
|
echo "↩️ Skipping startup scripts"
|
|
else
|
|
echo "import runpy; runpy.run_path('../startup_scripts')" | ./manage.py shell --interface python
|
|
fi
|
|
|
|
echo "✅ Initialisation is done."
|
|
|
|
# Launch whatever is passed by docker
|
|
# (i.e. the RUN instruction in the Dockerfile)
|
|
#
|
|
# shellcheck disable=SC2068
|
|
exec $@
|