PARA.AI / scripts /docker-entrypoint.sh
caarleexx's picture
Rename docker-entrypoint.sh to scripts/docker-entrypoint.sh
35cee90 verified
raw
history blame
5 kB
#!/bin/bash
# ============================================================================
# Docker Entrypoint - para.AI API v3.0
# Inicializa PostgreSQL local + API FastAPI
# ============================================================================
set -e
echo ""
echo "╔══════════════════════════════════════════════════════════════╗"
echo "β•‘ para.AI API v3.0 β•‘"
echo "β•‘ AnΓ‘lise Jurisprudencial com IA β•‘"
echo "β•šβ•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•"
echo ""
# ============================================================================
# FASE 1: VERIFICAR AMBIENTE
# ============================================================================
echo "πŸ” Verificando ambiente..."
# Mostrar informaΓ§Γ΅es do sistema
echo " Python: $(python --version)"
echo " PostgreSQL: $(su - postgres -c 'psql --version' | head -1)"
echo " DiretΓ³rio: $(pwd)"
echo ""
# ============================================================================
# FASE 2: INICIALIZAR POSTGRESQL
# ============================================================================
echo "🐘 Inicializando PostgreSQL local..."
/init-postgres.sh
# Verificar se PostgreSQL estΓ‘ rodando
if ! pg_isready -h localhost -p 5432 &> /dev/null; then
echo "❌ PostgreSQL não estÑ rodando!"
exit 1
fi
echo "βœ… PostgreSQL OK"
echo ""
# ============================================================================
# FASE 3: CONFIGURAR VARIÁVEIS DE AMBIENTE
# ============================================================================
echo "βš™οΈ Configurando variΓ‘veis de ambiente..."
# Se DATABASE_URL nΓ£o foi fornecida, usar a local
if [ -z "$DATABASE_URL" ] || [ "$DATABASE_URL" = "postgresql://para_ai:para_ai_temp@localhost:5432/para_ai" ]; then
export DATABASE_URL="postgresql://${POSTGRES_USER:-para_ai}:${POSTGRES_PASSWORD:-para_ai_temp}@localhost:5432/${POSTGRES_DB:-para_ai}"
echo " DATABASE_URL configurada para PostgreSQL local"
fi
# ConfiguraΓ§Γ΅es padrΓ£o para HF Spaces
export APP_ENV="${APP_ENV:-production}"
export DEBUG="${DEBUG:-false}"
export HOST="${HOST:-0.0.0.0}"
export PORT="${PORT:-7860}"
echo " APP_ENV: $APP_ENV"
echo " PORT: $PORT"
echo " DATABASE: PostgreSQL local"
echo ""
# ============================================================================
# FASE 4: TESTAR CONEXÃO COM BANCO
# ============================================================================
echo "πŸ”— Testando conexΓ£o com banco de dados..."
python3 << 'PYTHON_TEST'
import sys
from api.config import get_settings
try:
settings = get_settings()
print(f" βœ… ConfiguraΓ§Γ΅es carregadas")
print(f" βœ… Environment: {settings.APP_ENV}")
print(f" βœ… Database URL configurada")
except Exception as e:
print(f" ❌ Erro ao carregar configuraçáes: {e}")
sys.exit(1)
# Testar conexΓ£o com DB
try:
from database.db_manager import get_db_manager
db = get_db_manager()
if db.health_check():
print(f" βœ… ConexΓ£o com PostgreSQL OK")
else:
print(f" ❌ Falha no health check do DB")
sys.exit(1)
except Exception as e:
print(f" ❌ Erro ao conectar com DB: {e}")
sys.exit(1)
PYTHON_TEST
if [ $? -ne 0 ]; then
echo "❌ Falha ao testar conexão com banco!"
exit 1
fi
echo ""
# ============================================================================
# FASE 5: INICIALIZAR API
# ============================================================================
echo "πŸš€ Iniciando API FastAPI..."
echo ""
echo "╔══════════════════════════════════════════════════════════════╗"
echo "β•‘ API ONLINE β•‘"
echo "β•šβ•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•β•"
echo ""
echo "πŸ“ Endpoints disponΓ­veis:"
echo " β€’ DocumentaΓ§Γ£o: http://localhost:$PORT/api/docs"
echo " β€’ Health Check: http://localhost:$PORT/api/v1/health"
echo " β€’ Upload: http://localhost:$PORT/api/v1/process/upload"
echo ""
echo "πŸ’‘ PostgreSQL rodando localmente (temporΓ‘rio)"
echo "⚠️ ATENÇÃO: Dados sΓ£o perdidos ao reiniciar o container!"
echo ""
echo "πŸ”§ Para banco persistente, configure DATABASE_URL nas Secrets"
echo " Recomendado: Neon (https://neon.tech) ou Supabase"
echo ""
echo "=================================================="
echo ""
# Executar comando passado (geralmente uvicorn)
exec "$@"