X-Git-Url: https://git.mdrn.pl/edumed.git/blobdiff_plain/5dba732eeee324e084e0b6c03fbb64c487fb5bd1..0c7887c5e358a6af808e9bf5f86efb56465e3605:/contact/models.py?ds=sidebyside diff --git a/contact/models.py b/contact/models.py index f23fddf..dbc48b9 100644 --- a/contact/models.py +++ b/contact/models.py @@ -1,8 +1,8 @@ # -*- coding: utf-8 -*- import yaml -from django.core.files.storage import FileSystemStorage +from hashlib import sha1 from django.db import models -from django.utils.encoding import smart_unicode +from django.utils.encoding import smart_unicode, force_str from django.utils.translation import ugettext_lazy as _ from jsonfield import JSONField from . import app_settings @@ -18,9 +18,7 @@ class Contact(models.Model): @staticmethod def pretty_print(value, for_html=False): if type(value) in (tuple, list, dict): - value = yaml.safe_dump(value, - allow_unicode=True, - default_flow_style=False) + value = yaml.safe_dump(value, allow_unicode=True, default_flow_style=False) if for_html: value = smart_unicode(value).replace(u" ", unichr(160)) return value @@ -33,6 +31,12 @@ class Contact(models.Model): def __unicode__(self): return unicode(self.created_at) + def digest(self): + serialized_body = ';'.join(sorted('%s:%s' % item for item in self.body.iteritems())) + data = '%s%s%s%s%s' % (self.id, self.contact, serialized_body, self.ip, self.form_tag) + data = force_str(data) + return sha1(data).hexdigest() + class Attachment(models.Model): contact = models.ForeignKey(Contact) @@ -41,7 +45,7 @@ class Attachment(models.Model): @models.permalink def get_absolute_url(self): - return ('contact_attachment', [self.contact_id, self.tag]) + return 'contact_attachment', [self.contact_id, self.tag] __import__(app_settings.FORMS_MODULE)