2026-01-30 13:41:32 +01:00
|
|
|
#!/bin/sh
|
2026-02-11 13:20:52 +01:00
|
|
|
set -eu
|
2026-01-30 13:41:32 +01:00
|
|
|
|
2026-02-11 13:20:52 +01:00
|
|
|
MAX_MIGRATION_RETRIES="${MIGRATION_MAX_RETRIES:-30}"
|
|
|
|
|
MIGRATION_RETRY_DELAY_SECONDS="${MIGRATION_RETRY_DELAY_SECONDS:-2}"
|
|
|
|
|
ATTEMPT=1
|
|
|
|
|
|
|
|
|
|
echo "==> Running database migrations (with retry)..."
|
|
|
|
|
until npx prisma migrate deploy; do
|
|
|
|
|
if [ "$ATTEMPT" -ge "$MAX_MIGRATION_RETRIES" ]; then
|
|
|
|
|
echo "ERROR: Migration failed after ${MAX_MIGRATION_RETRIES} attempts."
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
echo "Migration attempt ${ATTEMPT} failed. Retrying in ${MIGRATION_RETRY_DELAY_SECONDS}s..."
|
|
|
|
|
ATTEMPT=$((ATTEMPT + 1))
|
|
|
|
|
sleep "$MIGRATION_RETRY_DELAY_SECONDS"
|
|
|
|
|
done
|
2026-01-30 13:41:32 +01:00
|
|
|
|
2026-02-11 00:29:21 +01:00
|
|
|
echo "==> Generating Prisma client..."
|
|
|
|
|
npx prisma generate
|
|
|
|
|
|
Round system redesign: Phases 1-7 complete
Full pipeline/track/stage architecture replacing the legacy round system.
Schema: 11 new models (Pipeline, Track, Stage, StageTransition,
ProjectStageState, RoutingRule, Cohort, CohortProject, LiveProgressCursor,
OverrideAction, AudienceVoter) + 8 new enums.
Backend: 9 new routers (pipeline, stage, routing, stageFiltering,
stageAssignment, cohort, live, decision, award) + 6 new services
(stage-engine, routing-engine, stage-filtering, stage-assignment,
stage-notifications, live-control).
Frontend: Pipeline wizard (17 components), jury stage pages (7),
applicant pipeline pages (3), public stage pages (2), admin pipeline
pages (5), shared stage components (3), SSE route, live hook.
Phase 6 refit: 23 routers/services migrated from roundId to stageId,
all frontend components refitted. Deleted round.ts (985 lines),
roundTemplate.ts, round-helpers.ts, round-settings.ts, round-type-settings.tsx,
10 legacy admin pages, 7 legacy jury pages, 3 legacy dialogs.
Phase 7 validation: 36 tests (10 unit + 8 integration files) all passing,
TypeScript 0 errors, Next.js build succeeds, 13 integrity checks,
legacy symbol sweep clean, auto-seed on first Docker startup.
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-13 13:57:09 +01:00
|
|
|
# Auto-seed on first startup: check if Users table is empty
|
|
|
|
|
USER_COUNT=$(node -e "
|
|
|
|
|
const { PrismaClient } = require('@prisma/client');
|
|
|
|
|
const p = new PrismaClient();
|
|
|
|
|
p.user.count().then(c => { console.log(c); p.\$disconnect(); }).catch(() => { console.log('0'); p.\$disconnect(); });
|
|
|
|
|
" 2>/dev/null || echo "0")
|
|
|
|
|
|
|
|
|
|
if [ "$USER_COUNT" = "0" ]; then
|
|
|
|
|
echo "==> Empty database detected — running seed..."
|
|
|
|
|
npx prisma db seed || echo "WARNING: Seed script failed."
|
|
|
|
|
else
|
|
|
|
|
echo "==> Database already seeded ($USER_COUNT users found), skipping seed."
|
|
|
|
|
fi
|
|
|
|
|
|
2026-01-30 13:41:32 +01:00
|
|
|
echo "==> Starting application..."
|
|
|
|
|
exec node server.js
|