X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/002577cf05a6730e8b1c97d1931d79758cbcbfdc..ae60b2a3949e96357477cc04f90fd0873cee8a92:/apps/wolnelektury_core/views.py diff --git a/apps/wolnelektury_core/views.py b/apps/wolnelektury_core/views.py deleted file mode 100644 index 77cd01681..000000000 --- a/apps/wolnelektury_core/views.py +++ /dev/null @@ -1,125 +0,0 @@ -from datetime import datetime -import feedparser - -from django.contrib import auth -from django.contrib.auth.decorators import login_required -from django.contrib.auth.forms import UserCreationForm, AuthenticationForm -from django.core.cache import cache -from django.http import HttpResponse, HttpResponseRedirect -from django.shortcuts import render_to_response -from django.template import RequestContext -from django.utils.http import urlquote_plus -from django.utils.translation import ugettext_lazy as _ -from django.views.decorators.cache import never_cache - -from django.conf import settings -from ajaxable.utils import AjaxableFormView -from catalogue.models import Book -from ajaxable.utils import placeholdized -from social.templatetags.social_tags import choose_cite - - -def main_page(request): - last_published = Book.objects.filter(parent=None).order_by('-created_at')[:4] - cite = choose_cite(RequestContext(request)) - - return render_to_response("main_page.html", locals(), - context_instance=RequestContext(request)) - - -class LoginFormView(AjaxableFormView): - form_class = AuthenticationForm - template = "auth/login.html" - placeholdize = True - title = _('Sign in') - submit = _('Sign in') - ajax_redirect = True - - def __call__(self, request): - if request.user.is_authenticated(): - return self.redirect_or_refresh(request, '/', - message=_('Already logged in as user %(user)s', ) % - {'user': request.user.username}) - return super(LoginFormView, self).__call__(request) - - def success(self, form, request): - auth.login(request, form.get_user()) - - -class RegisterFormView(AjaxableFormView): - form_class = UserCreationForm - template = "auth/register.html" - placeholdize = True - title = _('Register') - submit = _('Register') - ajax_redirect = True - form_prefix = 'register' - honeypot = True - - def __call__(self, request): - if request.user.is_authenticated(): - return self.redirect_or_refresh(request, '/', - message=_('Already logged in as user %(user)s', ) % - {'user': request.user.username}) - return super(RegisterFormView, self).__call__(request) - - def success(self, form, request): - form.save() - user = auth.authenticate( - username=form.cleaned_data['username'], - password=form.cleaned_data['password1'] - ) - auth.login(request, user) - - -class LoginRegisterFormView(LoginFormView): - template = 'auth/login_register.html' - title = _('You have to be logged in to continue') - - def extra_context(self, request, obj): - return { - "register_form": placeholdized(UserCreationForm(prefix='register')), - "register_submit": _('Register'), - } - - -@never_cache -def logout_then_redirect(request): - auth.logout(request) - return HttpResponseRedirect(urlquote_plus(request.GET.get('next', '/'), safe='/?=')) - - -@never_cache -def clock(request): - """ Provides server UTC time for jquery.countdown, - in a format suitable for Date.parse() - """ - return HttpResponse(datetime.utcnow().strftime('%Y/%m/%d %H:%M:%S UTC')) - - -def publish_plan(request): - cache_key = "publish_plan" - plan = cache.get(cache_key) - - if plan is None: - plan = [] - try: - feed = feedparser.parse(settings.PUBLISH_PLAN_FEED) - except: - pass - else: - for i in range(len(feed['entries'])): - plan.append({ - 'title': feed['entries'][i].title, - 'link': feed['entries'][i].link, - }) - cache.set(cache_key, plan, 1800) - - return render_to_response("publish_plan.html", {'plan': plan}, - context_instance=RequestContext(request)) - - -@login_required -def user_settings(request): - return render_to_response("user.html", - context_instance=RequestContext(request))