Add initial implementations for forms and organization apps with serializers, factories, and admin configurations
Some checks failed
CI/CD Pipeline / Run Tests (push) Failing after 45s
CI/CD Pipeline / Code Quality Checks (push) Failing after 48s
CI/CD Pipeline / Build Docker Images (push) Has been skipped
CI/CD Pipeline / Push to Gitea Registry (push) Has been skipped
CI/CD Pipeline / Deploy to Server (push) Has been skipped
Some checks failed
CI/CD Pipeline / Run Tests (push) Failing after 45s
CI/CD Pipeline / Code Quality Checks (push) Failing after 48s
CI/CD Pipeline / Build Docker Images (push) Has been skipped
CI/CD Pipeline / Push to Gitea Registry (push) Has been skipped
CI/CD Pipeline / Deploy to Server (push) Has been skipped
This commit is contained in:
23
docker/scripts/check-deps.sh
Executable file
23
docker/scripts/check-deps.sh
Executable file
@@ -0,0 +1,23 @@
|
||||
#!/usr/bin/env sh
|
||||
set -eu
|
||||
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.dev}"
|
||||
export STARTUP_COMPONENT="${STARTUP_COMPONENT:-container}"
|
||||
|
||||
case "${DJANGO_SETTINGS_MODULE}" in
|
||||
settings.dev|settings.production|settings.test)
|
||||
;;
|
||||
esac
|
||||
|
||||
python - <<'PY'
|
||||
import os
|
||||
|
||||
import django
|
||||
|
||||
django.setup()
|
||||
|
||||
from apps.core.startup_checks import run_startup_checks
|
||||
|
||||
run_startup_checks(component=os.environ["STARTUP_COMPONENT"])
|
||||
print(f"[startup:{os.environ['STARTUP_COMPONENT']}] dependency checks passed")
|
||||
PY
|
||||
110
docker/scripts/entrypoint.sh
Normal file
110
docker/scripts/entrypoint.sh
Normal file
@@ -0,0 +1,110 @@
|
||||
#!/usr/bin/env sh
|
||||
set -eu
|
||||
|
||||
COMMAND_NAME="${1:-web}"
|
||||
COMMAND_BASENAME="${COMMAND_NAME##*/}"
|
||||
|
||||
log() {
|
||||
printf '%s\n' "$*" >&2
|
||||
}
|
||||
|
||||
validate_settings_module() {
|
||||
case "${DJANGO_SETTINGS_MODULE}" in
|
||||
settings.dev|settings.production|settings.test)
|
||||
;;
|
||||
*)
|
||||
log "[startup] unsupported DJANGO_SETTINGS_MODULE=${DJANGO_SETTINGS_MODULE}"
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
run_dependency_checks() {
|
||||
/app/docker/scripts/check-deps.sh
|
||||
}
|
||||
|
||||
run_migrations_if_enabled() {
|
||||
default_value="$1"
|
||||
if [ "${RUN_MIGRATIONS:-$default_value}" = "1" ]; then
|
||||
log "[startup:${STARTUP_COMPONENT}] applying migrations"
|
||||
python src/manage.py migrate --noinput
|
||||
fi
|
||||
}
|
||||
|
||||
run_collectstatic_on_migrate() {
|
||||
if [ "${COLLECTSTATIC_ON_MIGRATE:-0}" = "1" ]; then
|
||||
log "[startup:${STARTUP_COMPONENT}] collecting static files"
|
||||
python src/manage.py collectstatic --noinput
|
||||
fi
|
||||
}
|
||||
|
||||
start_web() {
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.production}"
|
||||
export STARTUP_COMPONENT="${STARTUP_COMPONENT:-web}"
|
||||
validate_settings_module
|
||||
run_dependency_checks
|
||||
run_migrations_if_enabled 1
|
||||
shift
|
||||
exec /app/docker/scripts/start-web.sh "$@"
|
||||
}
|
||||
|
||||
start_web_dev() {
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.dev}"
|
||||
export STARTUP_COMPONENT="${STARTUP_COMPONENT:-web}"
|
||||
validate_settings_module
|
||||
run_dependency_checks
|
||||
run_migrations_if_enabled 1
|
||||
shift
|
||||
exec /app/docker/scripts/start-web-dev.sh "$@"
|
||||
}
|
||||
|
||||
start_celery_worker() {
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.production}"
|
||||
export STARTUP_COMPONENT="${STARTUP_COMPONENT:-celery_worker}"
|
||||
validate_settings_module
|
||||
run_dependency_checks
|
||||
run_migrations_if_enabled 0
|
||||
shift
|
||||
exec /app/docker/scripts/start-celery-worker.sh "$@"
|
||||
}
|
||||
|
||||
start_celery_beat() {
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.production}"
|
||||
export STARTUP_COMPONENT="${STARTUP_COMPONENT:-celery_beat}"
|
||||
validate_settings_module
|
||||
run_dependency_checks
|
||||
run_migrations_if_enabled 0
|
||||
shift
|
||||
exec /app/docker/scripts/start-celery-beat.sh "$@"
|
||||
}
|
||||
|
||||
run_migrate() {
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.production}"
|
||||
export STARTUP_COMPONENT="${STARTUP_COMPONENT:-migrate}"
|
||||
validate_settings_module
|
||||
run_dependency_checks
|
||||
run_migrations_if_enabled 1
|
||||
run_collectstatic_on_migrate
|
||||
log "[startup:${STARTUP_COMPONENT}] migrations completed"
|
||||
}
|
||||
|
||||
case "${COMMAND_BASENAME}" in
|
||||
web|start-web.sh)
|
||||
start_web "$@"
|
||||
;;
|
||||
web-dev|start-web-dev.sh)
|
||||
start_web_dev "$@"
|
||||
;;
|
||||
celery-worker|start-celery-worker.sh)
|
||||
start_celery_worker "$@"
|
||||
;;
|
||||
celery-beat|start-celery-beat.sh)
|
||||
start_celery_beat "$@"
|
||||
;;
|
||||
migrate|migrate.sh)
|
||||
run_migrate
|
||||
;;
|
||||
*)
|
||||
exec "$@"
|
||||
;;
|
||||
esac
|
||||
20
docker/scripts/migrate.sh
Executable file
20
docker/scripts/migrate.sh
Executable file
@@ -0,0 +1,20 @@
|
||||
#!/usr/bin/env sh
|
||||
set -eu
|
||||
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.dev}"
|
||||
export STARTUP_COMPONENT="migrate"
|
||||
|
||||
case "${DJANGO_SETTINGS_MODULE}" in
|
||||
settings.dev|settings.production|settings.test)
|
||||
;;
|
||||
esac
|
||||
|
||||
/app/docker/scripts/check-deps.sh
|
||||
|
||||
python src/manage.py migrate --noinput
|
||||
|
||||
if [ "${COLLECTSTATIC_ON_MIGRATE:-0}" = "1" ]; then
|
||||
python src/manage.py collectstatic --noinput
|
||||
fi
|
||||
|
||||
echo "[startup:migrate] migrations completed"
|
||||
13
docker/scripts/start-celery-beat.sh
Executable file
13
docker/scripts/start-celery-beat.sh
Executable file
@@ -0,0 +1,13 @@
|
||||
#!/usr/bin/env sh
|
||||
set -eu
|
||||
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.production}"
|
||||
|
||||
case "${DJANGO_SETTINGS_MODULE}" in
|
||||
settings.dev|settings.production|settings.test)
|
||||
;;
|
||||
esac
|
||||
|
||||
exec celery -A core beat \
|
||||
--loglevel="${CELERY_LOG_LEVEL:-INFO}" \
|
||||
--scheduler django_celery_beat.schedulers:DatabaseScheduler
|
||||
14
docker/scripts/start-celery-worker.sh
Executable file
14
docker/scripts/start-celery-worker.sh
Executable file
@@ -0,0 +1,14 @@
|
||||
#!/usr/bin/env sh
|
||||
set -eu
|
||||
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.production}"
|
||||
|
||||
case "${DJANGO_SETTINGS_MODULE}" in
|
||||
settings.dev|settings.production|settings.test)
|
||||
;;
|
||||
esac
|
||||
|
||||
exec celery -A core worker \
|
||||
--loglevel="${CELERY_LOG_LEVEL:-INFO}" \
|
||||
--concurrency="${CELERY_WORKER_CONCURRENCY:-1}" \
|
||||
--max-memory-per-child="${CELERY_WORKER_MAX_MEMORY_PER_CHILD_KB:-3145728}"
|
||||
11
docker/scripts/start-web-dev.sh
Executable file
11
docker/scripts/start-web-dev.sh
Executable file
@@ -0,0 +1,11 @@
|
||||
#!/usr/bin/env sh
|
||||
set -eu
|
||||
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.dev}"
|
||||
|
||||
case "${DJANGO_SETTINGS_MODULE}" in
|
||||
settings.dev|settings.production|settings.test)
|
||||
;;
|
||||
esac
|
||||
|
||||
exec python src/manage.py runserver "0.0.0.0:${PORT:-8000}"
|
||||
17
docker/scripts/start-web.sh
Executable file
17
docker/scripts/start-web.sh
Executable file
@@ -0,0 +1,17 @@
|
||||
#!/usr/bin/env sh
|
||||
set -eu
|
||||
|
||||
export DJANGO_SETTINGS_MODULE="${DJANGO_SETTINGS_MODULE:-settings.production}"
|
||||
export STARTUP_COMPONENT="${STARTUP_COMPONENT:-web}"
|
||||
|
||||
case "${DJANGO_SETTINGS_MODULE}" in
|
||||
settings.dev|settings.production|settings.test)
|
||||
;;
|
||||
esac
|
||||
|
||||
exec gunicorn core.wsgi:application \
|
||||
--bind "0.0.0.0:${PORT:-8000}" \
|
||||
--workers "${GUNICORN_WORKERS:-3}" \
|
||||
--timeout "${GUNICORN_TIMEOUT:-60}" \
|
||||
--access-logfile "-" \
|
||||
--error-logfile "-"
|
||||
Reference in New Issue
Block a user