### 🚨 CRITICAL Security Fixes - **🔒 Open Redirect Protection**: Добавлена строгая валидация redirect_uri против whitelist доменов - **🔒 Rate Limiting**: Защита OAuth endpoints от брутфорса (10 попыток за 5 минут на IP) - **🔒 Logout Endpoint**: Критически важный endpoint для безопасного отзыва httpOnly cookies - **🔒 Provider Validation**: Усиленная валидация OAuth провайдеров с логированием атак - **🚨 GlitchTip Alerts**: Автоматические алерты безопасности в GlitchTip при критических событиях ### 🛡️ Security Modules - **auth/oauth_security.py**: Модуль безопасности OAuth с валидацией и rate limiting + GlitchTip алерты - **auth/logout.py**: Безопасный logout с поддержкой JSON API и browser redirect - **tests/test_oauth_security.py**: Комплексные тесты безопасности (11 тестов) - **tests/test_oauth_glitchtip_alerts.py**: Тесты интеграции с GlitchTip (8 тестов) ### 🔧 OAuth Improvements - **Minimal Flow**: Упрощен до минимума - только httpOnly cookie, нет JWT в URL - **Simple Logic**: Нет error параметра = успех, максимальная простота - **DRY Refactoring**: Устранено дублирование кода в logout и валидации ### 🎯 OAuth Endpoints - **Старт**: `v3.dscrs.site/oauth/{provider}` - с rate limiting и валидацией - **Callback**: `v3.dscrs.site/oauth/{provider}/callback` - безопасный redirect_uri - **Logout**: `v3.dscrs.site/auth/logout` - отзыв httpOnly cookies - **Финализация**: `testing.discours.io/oauth?redirect_url=...` - минимальная схема ### 📊 Security Test Coverage - ✅ Open redirect attack prevention - ✅ Rate limiting protection - ✅ Provider validation - ✅ Safe fallback mechanisms - ✅ Cookie security (httpOnly + Secure + SameSite) - ✅ GlitchTip integration (8 тестов алертов) ### 📝 Documentation - Создан `docs/oauth-minimal-flow.md` - полное описание минимального flow - Обновлена документация OAuth в `docs/auth/oauth.md` - Добавлены security best practices
This commit is contained in:
@@ -81,6 +81,8 @@ jobs:
|
||||
npm ci
|
||||
|
||||
- name: Build Frontend
|
||||
env:
|
||||
CI: "true" # 🚨 Указываем что это CI сборка для codegen
|
||||
run: |
|
||||
npm run build
|
||||
|
||||
@@ -94,10 +96,11 @@ jobs:
|
||||
- name: Run Tests
|
||||
env:
|
||||
PLAYWRIGHT_HEADLESS: "true"
|
||||
timeout-minutes: 7
|
||||
run: |
|
||||
# Запускаем тесты, но позволяем им фейлиться
|
||||
# Запускаем тесты с таймаутом для предотвращения зависания
|
||||
# continue-on-error: true не работает в Gitea Actions, поэтому используем || true
|
||||
uv run pytest tests/ -v || echo "⚠️ Тесты завершились с ошибками, но продолжаем деплой"
|
||||
timeout 900 uv run pytest tests/ -v --timeout=300 || echo "⚠️ Тесты завершились с ошибками/таймаутом, но продолжаем деплой"
|
||||
continue-on-error: true
|
||||
|
||||
- name: Restore Git Repository
|
||||
|
||||
Reference in New Issue
Block a user