schon/scripts/Windows/restart.ps1
2026-01-25 23:16:38 +03:00

87 lines
2.4 KiB
PowerShell

Set-StrictMode -Version Latest
$ErrorActionPreference = 'Stop'
# Load shared utilities
$utilsPath = Join-Path $PSScriptRoot '..\lib\utils.ps1'
. $utilsPath
.\scripts\Windows\starter.ps1
if ($LASTEXITCODE -ne 0) {
exit $LASTEXITCODE
}
# Shutdown services
Write-Step "Shutting down..."
$output = docker compose down 2>&1
if ($LASTEXITCODE -ne 0) {
Write-Error-Custom "Failed to shut down services"
Write-Host $output
exit $LASTEXITCODE
}
Write-Success "Services were shut down successfully!"
# Rebuild and start services
Write-Step "Spinning services up with rebuild..."
$output = docker compose up -d --build --wait 2>&1
if ($LASTEXITCODE -ne 0) {
Write-Error-Custom "Failed to start services"
Write-Host $output
exit $LASTEXITCODE
}
Write-Success "Services are up and healthy!"
# Run pre-run tasks
Write-Step "Completing pre-run tasks..."
Write-Info " Running migrations..."
$output = docker compose exec -T app uv run manage.py migrate --no-input --verbosity 0 2>&1
if ($LASTEXITCODE -ne 0) {
Write-Error-Custom "Migrations failed"
Write-Host $output
exit $LASTEXITCODE
}
Write-Info " Initializing..."
$output = docker compose exec -T app uv run manage.py initialize 2>&1
if ($LASTEXITCODE -ne 0) {
Write-Error-Custom "Initialization failed"
Write-Host $output
exit $LASTEXITCODE
}
Write-Info " Setting default caches..."
$output = docker compose exec -T app uv run manage.py set_default_caches 2>&1
if ($LASTEXITCODE -ne 0) {
Write-Error-Custom "Cache setup failed"
Write-Host $output
exit $LASTEXITCODE
}
Write-Info " Rebuilding search index..."
$output = docker compose exec -T app uv run manage.py search_index --rebuild -f 2>&1
if ($LASTEXITCODE -ne 0) {
Write-Error-Custom "Search index rebuild failed"
Write-Host $output
exit $LASTEXITCODE
}
Write-Info " Collecting static files..."
$output = docker compose exec -T app uv run manage.py collectstatic --clear --no-input --verbosity 0 2>&1
if ($LASTEXITCODE -ne 0) {
Write-Error-Custom "Static files collection failed"
Write-Host $output
exit $LASTEXITCODE
}
Write-Success "Pre-run tasks completed successfully!"
# Cleanup
Write-Step "Cleaning up unused Docker data..."
docker system prune -f *>$null
if ($LASTEXITCODE -ne 0) {
Write-Warning-Custom "Docker cleanup had issues, but continuing..."
}
Write-Success "Unused Docker data cleaned successfully!"
Write-Result ""
Write-Result "All done! Schon is up and running!"