Add a new notifications app (models, serializers, views, admin, tasks, consumers, routing, urls, tests) with Notification.notify for in-app websocket pushes and optional email delivery. Centralize email sending in notifications.tasks.send_email_with_context and re-export it from account.tasks for compatibility. Update account and commerce and advertisement tasks to use Notification.notify/_notify_order and the new email helper; adjust order/notification tasks to consolidate logic. Wire notifications into ASGI routing, settings and URL conf. Misc: handle OSError when importing weasyprint, add tmp/ to .gitignore, add local .claude PowerShell checks, add social.blog skeleton, and remove legacy ews-component test files.
35 lines
1.0 KiB
Python
35 lines
1.0 KiB
Python
"""
|
|
ASGI config for vontor_cz project.
|
|
|
|
It exposes the ASGI callable as a module-level variable named ``application``.
|
|
|
|
For more information on this file, see
|
|
https://docs.djangoproject.com/en/5.2/howto/deployment/asgi/
|
|
"""
|
|
|
|
import os
|
|
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'vontor_cz.settings')
|
|
|
|
from django.core.asgi import get_asgi_application
|
|
|
|
# Initialize Django app registry before importing any models/routing.
|
|
django_asgi_app = get_asgi_application()
|
|
|
|
from channels.routing import ProtocolTypeRouter, URLRouter
|
|
from social.chat.routing import websocket_urlpatterns as social_ws
|
|
from thirdparty.downloader.routing import websocket_urlpatterns as downloader_ws
|
|
from notifications.routing import websocket_urlpatterns as notifications_ws
|
|
from vontor_cz.middleware import JWTAuthMiddleware
|
|
|
|
websocket_urlpatterns = downloader_ws + social_ws + notifications_ws
|
|
|
|
application = ProtocolTypeRouter({
|
|
"http": django_asgi_app,
|
|
"websocket": JWTAuthMiddleware(
|
|
URLRouter(
|
|
websocket_urlpatterns
|
|
)
|
|
),
|
|
})
|
|
|