109 Commits

Author SHA1 Message Date
3ae675c52c auth-fix
All checks were successful
Deploy on push / deploy (push) Successful in 5m44s
2025-09-30 19:20:41 +03:00
752e2dcbdc [0.9.28] - 2025-09-28
All checks were successful
Deploy on push / deploy (push) Successful in 2m46s
### 🍪 CRITICAL Cross-Origin Auth
- **🔧 SESSION_COOKIE_DOMAIN**: Добавлена поддержка поддоменов `.discours.io` для cross-origin cookies
- **🌐 Cross-Origin SSE**: Исправлена работа Server-Sent Events с httpOnly cookies между поддоменами
- **🔐 Unified Auth**: Унифицированы настройки cookies для OAuth, login, refresh, logout операций
- **📝 MyPy Compliance**: Исправлена типизация `SESSION_COOKIE_SAMESITE` с использованием `cast()`

### 🛠️ Technical Changes
- **settings.py**: Добавлен `SESSION_COOKIE_DOMAIN` с типобезопасной настройкой SameSite
- **auth/oauth.py**: Обновлены все `set_cookie` вызовы с `domain` параметром
- **auth/middleware.py**: Добавлена поддержка `SESSION_COOKIE_DOMAIN` в logout операциях
- **resolvers/auth.py**: Унифицированы cookie настройки в login/refresh/logout resolvers
- **auth/__init__.py**: Обновлены cookie операции с domain поддержкой

### 📚 Documentation
- **docs/auth/sse-httponly-integration.md**: Новая документация по SSE + httpOnly cookies интеграции
- **docs/auth/architecture.md**: Обновлены диаграммы для unified httpOnly cookie архитектуры

### 🎯 Impact
-  **GraphQL API** (`v3.discours.io`) теперь работает с httpOnly cookies cross-origin
-  **SSE сервер** (`connect.discours.io`) работает с теми же cookies
-  **Безопасность**: httpOnly cookies защищают от XSS атак
-  **UX**: Автоматическая аутентификация без управления токенами в JavaScript
2025-09-28 13:06:03 +03:00
fb98a1c6c8 [0.9.28] - OAuth/Auth with httpOnly cookie
All checks were successful
Deploy on push / deploy (push) Successful in 4m32s
2025-09-28 12:22:37 +03:00
f3fc6c34ae e2e-improved
Some checks failed
Deploy on push / deploy (push) Failing after 7s
2025-08-27 18:31:51 +03:00
1b48675b92 [0.9.7] - 2025-08-18
Some checks failed
Deploy on push / deploy (push) Failing after 2m22s
### 🔄 Изменения
- **SQLAlchemy KeyError** - исправление ошибки `KeyError: Reaction` при инициализации
- **Исправлена ошибка SQLAlchemy**: Устранена проблема `InvalidRequestError: When initializing mapper Mapper[Shout(shout)], expression Reaction failed to locate a name (Reaction)`

### 🧪 Тестирование
- **Исправление тестов** - адаптация к новой структуре моделей
- **RBAC инициализация** - добавление `rbac.initialize_rbac()` в `conftest.py`
- **Создан тест для getSession**: Добавлен комплексный тест `test_getSession_cookies.py` с проверкой всех сценариев
- **Покрытие edge cases**: Тесты проверяют работу с валидными/невалидными токенами, отсутствующими пользователями
- **Мокирование зависимостей**: Использование unittest.mock для изоляции тестируемого кода

### 🔧 Рефакторинг
- **Упрощена архитектура**: Убраны сложные конструкции с отложенными импортами, заменены на чистую архитектуру
- **Перемещение моделей** - `Author` и связанные модели перенесены в `orm/author.py`: Вынесены базовые модели пользователей (`Author`, `AuthorFollower`, `AuthorBookmark`, `AuthorRating`) из `orm.author` в отдельный модуль
- **Устранены циклические импорты**: Разорван цикл между `auth.core` → `orm.community` → `orm.author` через реструктуризацию архитектуры
- **Создан модуль `utils/password.py`**: Класс `Password` вынесен в utils для избежания циклических зависимостей
- **Оптимизированы импорты моделей**: Убран прямой импорт `Shout` из `orm/community.py`, заменен на строковые ссылки

### 🔧 Авторизация с cookies
- **getSession теперь работает с cookies**: Мутация `getSession` теперь может получать токен из httpOnly cookies даже без заголовка Authorization
- **Убрано требование авторизации**: `getSession` больше не требует декоратор `@login_required`, работает автономно
- **Поддержка dual-авторизации**: Токен может быть получен как из заголовка Authorization, так и из cookie `session_token`
- **Автоматическая установка cookies**: Middleware автоматически устанавливает httpOnly cookies при успешном `getSession`
- **Обновлена GraphQL схема**: `SessionInfo` теперь содержит поля `success`, `error` и опциональные `token`, `author`
- **Единообразная обработка токенов**: Все модули теперь используют централизованные функции для работы с токенами
- **Улучшена обработка ошибок**: Добавлена детальная валидация токенов и пользователей в `getSession`
- **Логирование операций**: Добавлены подробные логи для отслеживания процесса авторизации

### 📝 Документация
- **Обновлена схема GraphQL**: `SessionInfo` тип теперь соответствует новому формату ответа
- Обновлена документация RBAC
- Обновлена документация авторизации с cookies
2025-08-18 14:25:25 +03:00
9a2b792f08 refactored
Some checks failed
Deploy on push / deploy (push) Failing after 6s
2025-08-17 17:56:31 +03:00
e78e12eeee circular-fix
Some checks failed
Deploy on push / deploy (push) Failing after 17s
2025-08-17 16:33:54 +03:00
e7230ba63c tests-passed 2025-07-31 18:55:59 +03:00
243367134b panel-auth-fixes
Some checks failed
Deploy on push / deploy (push) Failing after 5s
2025-07-25 09:46:52 +03:00
441cca8045 0.7.5-topicfix 2025-07-03 00:20:10 +03:00
82111ed0f6 Squashed new RBAC
All checks were successful
Deploy on push / deploy (push) Successful in 7s
2025-07-02 22:30:21 +03:00
21d28a0d8b token-storage-refactored
Some checks failed
Deploy on push / type-check (push) Failing after 8s
Deploy on push / deploy (push) Has been skipped
2025-06-02 21:50:58 +03:00
3327976586 Improve topic sorting: add popular sorting by publications and authors count 2025-06-02 02:56:11 +03:00
f8ad73571c author-followers-fix 2025-05-30 13:48:02 +03:00
4070f4fcde linted+fmt
All checks were successful
Deploy on push / deploy (push) Successful in 6s
2025-05-29 12:37:39 +03:00
ab39b534fe auth fixes, search connected 2025-05-22 04:34:30 +03:00
5874d3ccae create_draft fix 2025-05-21 18:29:46 +03:00
f6156ccfa3 fix manage roles 2025-05-21 10:35:27 +03:00
d3a760b6ba auth-wip 2025-05-21 01:34:02 +03:00
1d64811880 userlist-demo-ready
All checks were successful
Deploy on push / deploy (push) Successful in 6s
2025-05-20 00:00:24 +03:00
dc5ad46df9 wip 2025-05-19 11:25:41 +03:00
bf241a8fbd merged-isolated-core
Some checks failed
deploy / deploy (push) Failing after 1m46s
2023-10-23 17:47:11 +03:00
7cd5929df2 token-type-tolerance 2023-10-13 14:47:31 +03:00
e9f68c8fb1 token-type-tolerance 2023-10-13 14:45:24 +03:00
45d187786b fix-imports 2023-10-05 22:59:50 +03:00
deac939ed8 restructured,inbox-removed 2023-10-05 21:46:18 +03:00
Igor Lobanov
b4e14cce93 added lead field to shout, new table event (#71)
* added lead field to shout, new table event

* repurposed unused notifications table
2023-08-06 22:01:40 +02:00
2b91f5a529 draft2shout 2023-02-17 17:30:38 +03:00
a01371a670 fix-session 2023-01-31 09:57:35 +03:00
Igor Lobanov
25924ac136 context user fix 2022-12-01 15:47:41 +01:00
Igor Lobanov
8464398aaf fixes 2022-12-01 14:24:05 +01:00
11655b31ae load fixed, auth wip 2022-12-01 11:12:48 +03:00
8377043286 hotfix-loadchats 2022-11-27 16:14:47 +03:00
839485873a frontend url setting 2022-11-26 02:49:02 +03:00
152c3362a0 fixes-for-inbox-auth-and-startup-faster 2022-11-26 01:35:42 +03:00
b2b8cf747f fix getSession, fix getAuthor 2022-11-24 18:19:58 +03:00
84600308ad refresh-token 2022-11-24 17:31:52 +03:00
786bd20275 init 2022-11-24 11:27:01 +03:00
94a31e29e5 try timezones 2022-11-23 17:09:35 +03:00
c6128ac641 viewed fixed 2022-11-23 14:30:44 +03:00
2cb152bdb1 some-fixes-chats 2022-11-23 12:57:58 +03:00
Igor Lobanov
8963781ca3 auth and minor fixes 2022-11-22 04:11:26 +01:00
5ad8328c03 fixes-api 2022-11-21 11:13:57 +03:00
1d05ff86a0 fix-slugname 2022-11-11 10:07:53 +03:00
0b7adfb0eb fix-slug-generator 2022-11-11 09:45:45 +03:00
503d6daa93 imports-format+id-fix+remigrate 2022-11-10 08:53:19 +03:00
e68272bcc2 test-jwt 2022-10-31 21:02:06 +03:00
764899d580 fix scheme and reactions subscriptions 2022-10-23 15:48:08 +03:00
4c3439d241 confirm-token-fix 2022-10-23 12:33:28 +03:00
20d01a49ec Merge remote-tracking branch 'origin/email-confirm' into main 2022-10-22 15:42:25 +03:00