2010-06-26 17:01:22 +00:00
|
|
|
import os
|
|
|
|
|
|
2008-08-12 08:12:38 +00:00
|
|
|
from django import forms
|
|
|
|
|
from django.forms import widgets
|
2013-09-13 15:23:31 +00:00
|
|
|
from django.utils import six
|
2008-08-12 08:12:38 +00:00
|
|
|
from django.utils.safestring import mark_safe
|
2010-02-02 11:57:13 +00:00
|
|
|
from django.utils.translation import ugettext_lazy as _
|
2010-06-26 17:01:22 +00:00
|
|
|
from django.template.defaultfilters import filesizeformat
|
2008-08-12 08:12:38 +00:00
|
|
|
|
2013-09-13 15:59:52 +00:00
|
|
|
from avatar.conf import settings
|
2010-01-22 11:48:42 +00:00
|
|
|
from avatar.models import Avatar
|
2010-01-22 10:59:58 +00:00
|
|
|
|
2010-02-01 18:32:15 +00:00
|
|
|
|
2008-08-12 08:12:38 +00:00
|
|
|
def avatar_img(avatar, size):
|
|
|
|
|
if not avatar.thumbnail_exists(size):
|
|
|
|
|
avatar.create_thumbnail(size)
|
2013-08-01 11:12:49 +00:00
|
|
|
return mark_safe('<img src="%s" alt="%s" width="%s" height="%s" />' %
|
2013-09-13 15:59:52 +00:00
|
|
|
(avatar.avatar_url(size), six.text_type(avatar),
|
|
|
|
|
size, size))
|
2013-08-01 11:12:49 +00:00
|
|
|
|
2008-08-12 08:12:38 +00:00
|
|
|
|
2010-01-22 10:59:58 +00:00
|
|
|
class UploadAvatarForm(forms.Form):
|
|
|
|
|
|
2014-07-19 16:07:59 +00:00
|
|
|
avatar = forms.ImageField(label=_("Avatar"))
|
2013-08-01 11:12:49 +00:00
|
|
|
|
2010-01-22 10:59:58 +00:00
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
|
self.user = kwargs.pop('user')
|
|
|
|
|
super(UploadAvatarForm, self).__init__(*args, **kwargs)
|
2013-08-01 11:12:49 +00:00
|
|
|
|
2010-01-22 10:59:58 +00:00
|
|
|
def clean_avatar(self):
|
2010-01-22 11:48:42 +00:00
|
|
|
data = self.cleaned_data['avatar']
|
2013-09-13 15:59:52 +00:00
|
|
|
|
2014-07-19 15:39:03 +00:00
|
|
|
if settings.AVATAR_ALLOWED_MIMETYPES:
|
2013-07-18 22:34:57 +00:00
|
|
|
try:
|
|
|
|
|
import magic
|
|
|
|
|
except ImportError:
|
2014-07-19 15:39:03 +00:00
|
|
|
raise ImportError("python-magic library must be installed in "
|
|
|
|
|
"order to use uploaded file content "
|
|
|
|
|
"limitation")
|
2013-07-18 22:34:57 +00:00
|
|
|
|
|
|
|
|
# Construct 256 bytes needed for mime validation
|
2014-12-30 13:40:51 +00:00
|
|
|
magic_buffer = six.b('')
|
2013-07-18 22:34:57 +00:00
|
|
|
for chunk in data.chunks():
|
|
|
|
|
magic_buffer += chunk
|
|
|
|
|
if len(magic_buffer) >= 256:
|
|
|
|
|
break
|
|
|
|
|
|
|
|
|
|
# https://github.com/ahupp/python-magic#usage
|
|
|
|
|
mime = magic.from_buffer(magic_buffer, mime=True)
|
2014-12-30 13:40:51 +00:00
|
|
|
if six.PY3:
|
|
|
|
|
mime = mime.decode('utf-8')
|
2014-07-19 15:39:03 +00:00
|
|
|
if mime not in settings.AVATAR_ALLOWED_MIMETYPES:
|
2014-07-19 16:07:59 +00:00
|
|
|
err = _(
|
2014-07-20 08:53:48 +00:00
|
|
|
"File content is invalid. Detected: %(mimetype)s "
|
2014-07-19 16:07:59 +00:00
|
|
|
"Allowed content types are: %(valid_mime_list)s"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
conf = {
|
|
|
|
|
'valid_mime_list': ", ".join(settings.AVATAR_ALLOWED_MIMETYPES),
|
|
|
|
|
'mimetype': mime
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
raise forms.ValidationError(err % conf)
|
2014-07-19 15:39:03 +00:00
|
|
|
|
2013-09-13 15:59:52 +00:00
|
|
|
if settings.AVATAR_ALLOWED_FILE_EXTS:
|
|
|
|
|
root, ext = os.path.splitext(data.name.lower())
|
|
|
|
|
if ext not in settings.AVATAR_ALLOWED_FILE_EXTS:
|
|
|
|
|
valid_exts = ", ".join(settings.AVATAR_ALLOWED_FILE_EXTS)
|
|
|
|
|
error = _("%(ext)s is an invalid file extension. "
|
|
|
|
|
"Authorized extensions are : %(valid_exts_list)s")
|
|
|
|
|
raise forms.ValidationError(error %
|
|
|
|
|
{'ext': ext,
|
|
|
|
|
'valid_exts_list': valid_exts})
|
|
|
|
|
|
|
|
|
|
if data.size > settings.AVATAR_MAX_SIZE:
|
2013-08-01 11:12:49 +00:00
|
|
|
error = _("Your file is too big (%(size)s), "
|
|
|
|
|
"the maximum allowed size is %(max_valid_size)s")
|
|
|
|
|
raise forms.ValidationError(error % {
|
|
|
|
|
'size': filesizeformat(data.size),
|
2013-09-13 15:59:52 +00:00
|
|
|
'max_valid_size': filesizeformat(settings.AVATAR_MAX_SIZE)
|
2013-08-01 11:12:49 +00:00
|
|
|
})
|
|
|
|
|
|
2010-01-22 11:48:42 +00:00
|
|
|
count = Avatar.objects.filter(user=self.user).count()
|
2013-09-13 15:59:52 +00:00
|
|
|
if (settings.AVATAR_MAX_AVATARS_PER_USER > 1 and
|
|
|
|
|
count >= settings.AVATAR_MAX_AVATARS_PER_USER):
|
2013-08-01 11:12:49 +00:00
|
|
|
error = _("You already have %(nb_avatars)d avatars, "
|
|
|
|
|
"and the maximum allowed is %(nb_max_avatars)d.")
|
|
|
|
|
raise forms.ValidationError(error % {
|
|
|
|
|
'nb_avatars': count,
|
2013-09-13 15:59:52 +00:00
|
|
|
'nb_max_avatars': settings.AVATAR_MAX_AVATARS_PER_USER,
|
2013-08-01 11:12:49 +00:00
|
|
|
})
|
2014-07-19 15:39:03 +00:00
|
|
|
|
2013-08-01 11:12:49 +00:00
|
|
|
return
|
|
|
|
|
|
2010-01-22 10:59:58 +00:00
|
|
|
|
2008-08-12 08:12:38 +00:00
|
|
|
class PrimaryAvatarForm(forms.Form):
|
2013-08-01 11:12:49 +00:00
|
|
|
|
2008-08-12 08:12:38 +00:00
|
|
|
def __init__(self, *args, **kwargs):
|
2013-08-01 11:12:49 +00:00
|
|
|
kwargs.pop('user')
|
2013-09-13 15:59:52 +00:00
|
|
|
size = kwargs.pop('size', settings.AVATAR_DEFAULT_SIZE)
|
2010-01-21 16:45:27 +00:00
|
|
|
avatars = kwargs.pop('avatars')
|
2008-08-12 08:12:38 +00:00
|
|
|
super(PrimaryAvatarForm, self).__init__(*args, **kwargs)
|
2013-09-13 15:59:52 +00:00
|
|
|
choices = [(avatar.id, avatar_img(avatar, size)) for avatar in avatars]
|
2013-09-09 23:30:19 +00:00
|
|
|
self.fields['choice'] = forms.ChoiceField(label=_("Available avatars:"),
|
2013-09-13 15:59:52 +00:00
|
|
|
choices=choices,
|
|
|
|
|
widget=widgets.RadioSelect)
|
2008-08-12 08:12:38 +00:00
|
|
|
|
2013-08-01 11:12:49 +00:00
|
|
|
|
2008-08-12 08:12:38 +00:00
|
|
|
class DeleteAvatarForm(forms.Form):
|
|
|
|
|
|
|
|
|
|
def __init__(self, *args, **kwargs):
|
2013-08-01 11:12:49 +00:00
|
|
|
kwargs.pop('user')
|
2013-09-13 15:59:52 +00:00
|
|
|
size = kwargs.pop('size', settings.AVATAR_DEFAULT_SIZE)
|
2010-01-21 16:45:27 +00:00
|
|
|
avatars = kwargs.pop('avatars')
|
2008-08-12 08:12:38 +00:00
|
|
|
super(DeleteAvatarForm, self).__init__(*args, **kwargs)
|
2013-09-13 15:59:52 +00:00
|
|
|
choices = [(avatar.id, avatar_img(avatar, size)) for avatar in avatars]
|
2013-09-09 23:30:19 +00:00
|
|
|
self.fields['choices'] = forms.MultipleChoiceField(label=_("Available avatars:"),
|
2013-09-13 15:59:52 +00:00
|
|
|
choices=choices,
|
|
|
|
|
widget=widgets.CheckboxSelectMultiple)
|