X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/3e276f49505e607b72892b40d18ac2cef194497e..154468a29ddb2a3ea4a078888be55c303a5239bb:/apps/cover/forms.py diff --git a/apps/cover/forms.py b/apps/cover/forms.py index fab0bb62..628cb63e 100755 --- a/apps/cover/forms.py +++ b/apps/cover/forms.py @@ -12,6 +12,24 @@ from cover.models import Image class ImageAddForm(forms.ModelForm): class Meta: model = Image + exclude = [] + + def __init__(self, *args, **kwargs): + super(ImageAddForm, self).__init__(*args, **kwargs) + self.fields['file'].required = self.fields['download_url'].required = self.fields['source_url'].required = False + + def clean_download_url(self): + return self.cleaned_data['download_url'] or None + + def clean_source_url(self): + return self.cleaned_data['source_url'] or None + + def clean(self): + cleaned_data = super(ImageAddForm, self).clean() + if not cleaned_data.get('download_url', None) and not cleaned_data.get('file', None): + raise forms.ValidationError('No image specified') + return cleaned_data + class ImageEditForm(forms.ModelForm): """Form used for editing a Book.""" @@ -37,15 +55,18 @@ class FlickrForm(forms.Form): source_url = forms.URLField(label=_('Flickr URL')) def clean_source_url(self): + def normalize_html(html): + return re.sub('[\t\n]', '', html) + url = self.cleaned_data['source_url'] - m = re.match(r'(https?://)?(www.)?flickr.com/photos/(?P[^/]+)/(?P\d+)', url) + m = re.match(r'(https?://)?(www\.|secure\.)?flickr\.com/photos/(?P[^/]+)/(?P\d+)/?', url) if not m: raise forms.ValidationError("It doesn't look like Flickr URL.") author_slug, img_id = m.group('author'), m.group('img') base_url = "https://www.flickr.com/photos/%s/%s/" % (author_slug, img_id) try: - html = urlopen(url).read().decode('utf-8') + html = normalize_html(urlopen(url).read().decode('utf-8')) except: raise forms.ValidationError('Error reading page.') match = re.search(r'Some rights reserved', html) @@ -60,7 +81,7 @@ class FlickrForm(forms.Form): except AssertionError: raise forms.ValidationError('Error reading license name.') - m = re.search(r'By ([^<]*)', html) + m = re.search(r'"ownername":"([^"]*)', html) if m: self.cleaned_data['author'] = "%s@Flickr" % m.group(1) else: @@ -72,7 +93,7 @@ class FlickrForm(forms.Form): self.cleaned_data['title'] = m.group(1) url_size = base_url + "sizes/o/" - html = urlopen(url_size).read().decode('utf-8') + html = normalize_html(urlopen(url_size).read().decode('utf-8')) m = re.search(r'
\s*