|
|
@@ -13,7 +13,7 @@ Basket = get_model('basket', 'basket')
|
|
13
|
13
|
class BasketMiddleware(object):
|
|
14
|
14
|
|
|
15
|
15
|
def process_request(self, request):
|
|
16
|
|
- self.cookies_to_delete = []
|
|
|
16
|
+ request.cookies_to_delete = []
|
|
17
|
17
|
basket = self.get_basket(request)
|
|
18
|
18
|
self.apply_offers_to_basket(request, basket)
|
|
19
|
19
|
request.basket = basket
|
|
|
@@ -23,7 +23,7 @@ class BasketMiddleware(object):
|
|
23
|
23
|
cookie_basket = self.get_cookie_basket(settings.OSCAR_BASKET_COOKIE_OPEN,
|
|
24
|
24
|
request, manager)
|
|
25
|
25
|
|
|
26
|
|
- if request.user.is_authenticated():
|
|
|
26
|
+ if hasattr(request, 'user') and request.user.is_authenticated():
|
|
27
|
27
|
# Signed-in user: if they have a cookie basket too, it means
|
|
28
|
28
|
# that they have just signed in and we need to merge their cookie
|
|
29
|
29
|
# basket into their user basket, then delete the cookie
|
|
|
@@ -31,7 +31,7 @@ class BasketMiddleware(object):
|
|
31
|
31
|
basket, _ = manager.get_or_create(owner=request.user)
|
|
32
|
32
|
except Basket.MultipleObjectsReturned:
|
|
33
|
33
|
# Not sure quite how we end up here with multiple baskets
|
|
34
|
|
- # We merge any them and create a fresh one
|
|
|
34
|
+ # We merge them and create a fresh one
|
|
35
|
35
|
old_baskets = list(manager.filter(owner=request.user))
|
|
36
|
36
|
basket = old_baskets[0]
|
|
37
|
37
|
for other_basket in old_baskets[1:]:
|
|
|
@@ -39,7 +39,7 @@ class BasketMiddleware(object):
|
|
39
|
39
|
|
|
40
|
40
|
if cookie_basket:
|
|
41
|
41
|
self.merge_baskets(basket, cookie_basket)
|
|
42
|
|
- self.cookies_to_delete.append(settings.OSCAR_BASKET_COOKIE_OPEN)
|
|
|
42
|
+ request.cookies_to_delete.append(settings.OSCAR_BASKET_COOKIE_OPEN)
|
|
43
|
43
|
elif cookie_basket:
|
|
44
|
44
|
# Anonymous user with a basket tied to the cookie
|
|
45
|
45
|
basket = cookie_basket
|
|
|
@@ -59,8 +59,8 @@ class BasketMiddleware(object):
|
|
59
|
59
|
|
|
60
|
60
|
def process_response(self, request, response):
|
|
61
|
61
|
# Delete any surplus cookies
|
|
62
|
|
- if hasattr(self, 'cookies_to_delete'):
|
|
63
|
|
- for cookie_key in self.cookies_to_delete:
|
|
|
62
|
+ if hasattr(request, 'cookies_to_delete'):
|
|
|
63
|
+ for cookie_key in request.cookies_to_delete:
|
|
64
|
64
|
response.delete_cookie(cookie_key)
|
|
65
|
65
|
|
|
66
|
66
|
# If a basket has had products added to it, but the user is anonymous
|
|
|
@@ -100,9 +100,9 @@ class BasketMiddleware(object):
|
|
100
|
100
|
basket = Basket.objects.get(pk=basket_id, owner=None,
|
|
101
|
101
|
status=OPEN)
|
|
102
|
102
|
except Basket.DoesNotExist:
|
|
103
|
|
- self.cookies_to_delete.append(cookie_key)
|
|
|
103
|
+ request.cookies_to_delete.append(cookie_key)
|
|
104
|
104
|
else:
|
|
105
|
|
- self.cookies_to_delete.append(cookie_key)
|
|
|
105
|
+ request.cookies_to_delete.append(cookie_key)
|
|
106
|
106
|
return basket
|
|
107
|
107
|
|
|
108
|
108
|
def apply_offers_to_basket(self, request, basket):
|