forked from tualatrix/django-profile
/
models.py
194 lines (165 loc) · 6.24 KB
/
models.py
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
# coding=UTF-8
from django.db import models
from django.contrib.sites.models import Site
from django.contrib.auth.models import User
from django.template.defaultfilters import slugify
from django.utils.translation import ugettext as _
from django.template import loader, Context
from django.core.urlresolvers import reverse
from django.core.mail import send_mail
from django.conf import settings
from userprofile.countries import CountryField
from django.core.files.storage import default_storage
if hasattr(settings, "AWS_SECRET_ACCESS_KEY"):
try:
from backends.S3Storage import S3Storage
storage = S3Storage()
except ImportError:
raise S3BackendNotFound
else:
storage = default_storage
import datetime
import cPickle as pickle
import base64
import urllib
import os.path
try:
from PIL import Image, ImageFilter
except ImportError:
import Image, ImageFilter
AVATAR_SIZES = (128, 96, 64, 48, 32, 24, 16)
class BaseProfile(models.Model):
"""
User profile model
"""
user = models.ForeignKey(User, unique=True)
creation_date = models.DateTimeField(default=datetime.datetime.now)
country = CountryField(null=True, blank=True)
latitude = models.DecimalField(max_digits=10, decimal_places=6, blank=True, null=True)
longitude = models.DecimalField(max_digits=10, decimal_places=6, blank=True, null=True)
location = models.CharField(max_length=255, blank=True)
class Meta:
abstract = True
def has_avatar(self):
return Avatar.objects.filter(user=self.user, valid=True).count()
def __unicode__(self):
return _("%s's profile") % self.user
def get_absolute_url(self):
return reverse("profile_public", args=[self.user])
class Avatar(models.Model):
"""
Avatar model
"""
image = models.ImageField(upload_to="avatars/%Y/%b/%d", storage=storage)
user = models.ForeignKey(User)
date = models.DateTimeField(auto_now_add=True)
valid = models.BooleanField()
class Meta:
unique_together = (('user', 'valid'),)
def __unicode__(self):
return _("%s's Avatar") % self.user
def delete(self):
if hasattr(settings, "AWS_SECRET_ACCESS_KEY"):
path = urllib.unquote(self.image.name)
else:
path = self.image.path
base, filename = os.path.split(path)
name, extension = os.path.splitext(filename)
for key in AVATAR_SIZES:
try:
storage.delete(os.path.join(base, "%s.%s%s" % (name, key, extension)))
except:
pass
super(Avatar, self).delete()
def save(self):
for avatar in Avatar.objects.filter(user=self.user, valid=self.valid).exclude(id=self.id):
if hasattr(settings, "AWS_SECRET_ACCESS_KEY"):
path = urllib.unquote(self.image.name)
else:
path = avatar.image.path
base, filename = os.path.split(path)
name, extension = os.path.splitext(filename)
for key in AVATAR_SIZES:
try:
storage.delete(os.path.join(base, "%s.%s%s" % (name, key, extension)))
except:
pass
avatar.delete()
super(Avatar, self).save()
class EmailValidationManager(models.Manager):
"""
Email validation manager
"""
def verify(self, key):
try:
verify = self.get(key=key)
if not verify.is_expired():
verify.user.email = verify.email
if hasattr(settings, "REQUIRE_EMAIL_CONFIRMATION") and settings.REQUIRE_EMAIL_CONFIRMATION:
verify.user.is_active = True
verify.user.save()
verify.delete()
return True
else:
verify.delete()
return False
except:
return False
def getuser(self, key):
try:
return self.get(key=key).user
except:
return False
def add(self, user, email):
"""
Add a new validation process entry
"""
while True:
key = User.objects.make_random_password(70)
try:
EmailValidation.objects.get(key=key)
except EmailValidation.DoesNotExist:
self.key = key
break
template_body = "userprofile/email/validation.txt"
template_subject = "userprofile/email/validation_subject.txt"
site_name, domain = Site.objects.get_current().name, Site.objects.get_current().domain
body = loader.get_template(template_body).render(Context(locals()))
subject = loader.get_template(template_subject).render(Context(locals())).strip()
send_mail(subject=subject, message=body, from_email=None, recipient_list=[email])
user = User.objects.get(username=str(user))
self.filter(user=user).delete()
return self.create(user=user, key=key, email=email)
class EmailValidation(models.Model):
"""
Email Validation model
"""
user = models.ForeignKey(User, unique=True)
email = models.EmailField(blank=True)
key = models.CharField(max_length=70, unique=True, db_index=True)
created = models.DateTimeField(auto_now_add=True)
objects = EmailValidationManager()
def __unicode__(self):
return _("Email validation process for %(user)s") % { 'user': self.user }
def is_expired(self):
return (datetime.datetime.today() - self.created).days > 0
def resend(self):
"""
Resend validation email
"""
template_body = "userprofile/email/validation.txt"
template_subject = "userprofile/email/validation_subject.txt"
site_name, domain = Site.objects.get_current().name, Site.objects.get_current().domain
key = self.key
body = loader.get_template(template_body).render(Context(locals()))
subject = loader.get_template(template_subject).render(Context(locals())).strip()
send_mail(subject=subject, message=body, from_email=None, recipient_list=[self.email])
self.created = datetime.datetime.now()
self.save()
return True
class UserProfileMediaNotFound(Exception):
pass
class S3BackendNotFound(Exception):
pass
class GoogleDataAPINotFound(Exception):
pass