|
|
@ -1,48 +1,25 @@ |
|
|
|
import asyncio |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
from django.http import Http404 |
|
|
|
from django.http import Http404 |
|
|
|
|
|
|
|
from django.utils.deprecation import MiddlewareMixin |
|
|
|
from django_scopes import scope |
|
|
|
from django_scopes import scope |
|
|
|
|
|
|
|
|
|
|
|
from scopedsites.models import Domain |
|
|
|
from scopedsites.models import Domain |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class DomainScopeMiddleware: |
|
|
|
class DomainScopeMiddleware(MiddlewareMixin): |
|
|
|
async_capable = True |
|
|
|
def __call__(self, request): |
|
|
|
|
|
|
|
|
|
|
|
def __init__(self, get_response): |
|
|
|
|
|
|
|
self.get_response = get_response |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
self.is_async = asyncio.iscoroutinefunction(get_response) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
self.__call__ = self._ahandler if self.is_async else self._handler |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async def _ahandler(self, request): |
|
|
|
|
|
|
|
d = Domain.get_from_request(request) |
|
|
|
d = Domain.get_from_request(request) |
|
|
|
|
|
|
|
|
|
|
|
with scope(domain=d): |
|
|
|
with scope(domain=d): |
|
|
|
return await self.get_response(request) |
|
|
|
return super()(request) |
|
|
|
|
|
|
|
|
|
|
|
def _handler(self, request): |
|
|
|
|
|
|
|
d = Domain.get_from_request(request) # technically does hit the db layer, but should get caught in memcache |
|
|
|
|
|
|
|
# TODO: performance testing |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
with scope(domain=d): |
|
|
|
|
|
|
|
return self.get_response(request) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class DomainAutoCreateMiddleware: |
|
|
|
class DomainAutoCreateMiddleware(MiddlewareMixin): |
|
|
|
async_capable = True |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def __init__(self, get_response): |
|
|
|
def __init__(self, get_response): |
|
|
|
self.get_response = get_response |
|
|
|
super().__init__(get_response) |
|
|
|
|
|
|
|
|
|
|
|
self.is_async = asyncio.iscoroutinefunction(get_response) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
self.__call__ = self._ahandler if self.is_async else self._handler |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
self.cache = set() |
|
|
|
self.cache = set() |
|
|
|
|
|
|
|
|
|
|
|
def ensure_exists(self, r): |
|
|
|
def process_request(self, r): |
|
|
|
if (host := r.META.get("HTTP_HOST")) in self.cache: |
|
|
|
if (host := r.META.get("HTTP_HOST")) in self.cache: |
|
|
|
return |
|
|
|
return |
|
|
|
|
|
|
|
|
|
|
@ -51,11 +28,3 @@ class DomainAutoCreateMiddleware: |
|
|
|
self.cache.add(host) |
|
|
|
self.cache.add(host) |
|
|
|
except Http404: |
|
|
|
except Http404: |
|
|
|
Domain.objects.create(fqdn=r.META.get('HTTP_HOST')) |
|
|
|
Domain.objects.create(fqdn=r.META.get('HTTP_HOST')) |
|
|
|
|
|
|
|
|
|
|
|
def _handler(self, req): |
|
|
|
|
|
|
|
self.ensure_exists(req) |
|
|
|
|
|
|
|
return self.get_response(req) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async def _ahandler(self, req): |
|
|
|
|
|
|
|
self.ensure_exists(req) |
|
|
|
|
|
|
|
return await self.get_response(req) |
|
|
|
|
|
|
|