Initial delta: full developer manual + DB bootstrap

Generated from finetuning-plattform develop @ 70b203c on 2026-05-14.

Contents:
- MANUAL.md       — full developer manual, setup at front (28 sections)
- bootstrap-db.sh — one-command DB initialization
- db/01-schema.sql       — MariaDB schema, no data
- db/02-seed.sql         — reference data (ACL, email templates, API registry)
- db/03-default-users.sql — admin + test user, argon2id hashes

Drop-in package for new developers joining the platform.
This commit is contained in:
2026-05-14 12:44:47 +02:00
commit 8932534623
6 changed files with 1922 additions and 0 deletions

58
bootstrap-db.sh Executable file
View File

@@ -0,0 +1,58 @@
#!/usr/bin/env bash
# Bootstrap the Neuronetz Finetuning Platform database from a fresh container.
# Run AFTER `docker compose up -d` has started and mariadb is healthy.
#
# Usage:
# ./bootstrap-db.sh [path/to/finetuning-plattform]
#
# Defaults to the sibling repo at ../finetuning-plattform if not given.
set -euo pipefail
DELTA_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PLATFORM_DIR="${1:-$DELTA_DIR/../finetuning-plattform}"
if [[ ! -f "$PLATFORM_DIR/local/.env" ]]; then
echo "ERROR: Could not find $PLATFORM_DIR/local/.env"
echo " Pass the platform repo path as the first argument."
echo " e.g. $0 ~/PhpstormProjects/finetuning-plattform"
exit 1
fi
# shellcheck disable=SC1091
set -a; . "$PLATFORM_DIR/local/.env"; set +a
CONTAINER="neuro-finetuning-platform-mariadb-1"
if ! docker ps --format '{{.Names}}' | grep -q "^${CONTAINER}$"; then
echo "ERROR: ${CONTAINER} is not running. Run 'docker compose up -d' in $PLATFORM_DIR/local first."
exit 2
fi
echo "[1/4] Waiting for MariaDB to accept connections..."
for i in {1..30}; do
if docker exec "$CONTAINER" mariadb -u "$MARIADB_USER" -p"$MARIADB_PASSWORD" -e "SELECT 1" "$MARIADB_DATABASE" >/dev/null 2>&1; then
break
fi
sleep 1
done
echo "[2/4] Loading schema (01-schema.sql)..."
docker exec -i "$CONTAINER" mariadb -u "$MARIADB_USER" -p"$MARIADB_PASSWORD" "$MARIADB_DATABASE" \
< "$DELTA_DIR/db/01-schema.sql"
echo "[3/4] Loading seed data (02-seed.sql)..."
docker exec -i "$CONTAINER" mariadb -u "$MARIADB_USER" -p"$MARIADB_PASSWORD" "$MARIADB_DATABASE" \
< "$DELTA_DIR/db/02-seed.sql"
echo "[4/4] Loading default users (03-default-users.sql)..."
docker exec -i "$CONTAINER" mariadb -u "$MARIADB_USER" -p"$MARIADB_PASSWORD" "$MARIADB_DATABASE" \
< "$DELTA_DIR/db/03-default-users.sql"
echo
echo "✓ Database bootstrapped."
echo
echo " admin@finetune.ai / admin123 (superuser)"
echo " testuser@example.com / test123 (user)"
echo
echo "Open: http://local.finetune.neuronetz.ai/auth/login"