2012-04-30 01:58:00 +08:00
|
|
|
import json
|
|
|
|
|
2011-06-01 21:47:00 +08:00
|
|
|
from django.core.signing import BadSignature
|
|
|
|
|
2013-05-16 07:14:28 +08:00
|
|
|
from django.contrib.formtools.exceptions import WizardViewCookieModified
|
2011-06-01 21:47:00 +08:00
|
|
|
from django.contrib.formtools.wizard import storage
|
|
|
|
|
|
|
|
|
|
|
|
class CookieStorage(storage.BaseStorage):
|
|
|
|
encoder = json.JSONEncoder(separators=(',', ':'))
|
|
|
|
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super(CookieStorage, self).__init__(*args, **kwargs)
|
|
|
|
self.data = self.load_data()
|
|
|
|
if self.data is None:
|
|
|
|
self.init_data()
|
|
|
|
|
|
|
|
def load_data(self):
|
|
|
|
try:
|
|
|
|
data = self.request.get_signed_cookie(self.prefix)
|
|
|
|
except KeyError:
|
|
|
|
data = None
|
|
|
|
except BadSignature:
|
2013-05-16 07:14:28 +08:00
|
|
|
raise WizardViewCookieModified('WizardView cookie manipulated')
|
2011-06-01 21:47:00 +08:00
|
|
|
if data is None:
|
|
|
|
return None
|
|
|
|
return json.loads(data, cls=json.JSONDecoder)
|
|
|
|
|
|
|
|
def update_response(self, response):
|
|
|
|
if self.data:
|
|
|
|
response.set_signed_cookie(self.prefix, self.encoder.encode(self.data))
|
|
|
|
else:
|
|
|
|
response.delete_cookie(self.prefix)
|