blob: c7ff05bceab789a7e1e6b047bf3e188527a06c2f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
from django.http import HttpResponseRedirect
from django_authopenid.util import get_next_url
from user_messages import create_message, get_and_delete_messages
import logging
class AnonymousMessageManager(object):
def __init__(self,request):
self.request = request
def create(self,message=''):
create_message(self.request,message)
def get_and_delete(self):
messages = get_and_delete_messages(self.request)
return messages
def dummy_deepcopy(*arg):
"""this is necessary to prevent deepcopy() on anonymous user object
that now contains reference to request, which cannot be deepcopied
"""
return None
class ConnectToSessionMessagesMiddleware(object):
def process_request(self, request):
if not request.user.is_authenticated():
request.user.__deepcopy__ = dummy_deepcopy #plug on deepcopy which may be called by django db "driver"
request.user.message_set = AnonymousMessageManager(request) #here request is linked to anon user
request.user.get_and_delete_messages = request.user.message_set.get_and_delete
|