diff options
author | Filipp Lepalaan <f@230.to> | 2013-11-17 19:15:30 +0200 |
---|---|---|
committer | Filipp Lepalaan <f@230.to> | 2013-11-17 19:15:30 +0200 |
commit | 297419f370ea87458017ee506a2e551e9068b66b (patch) | |
tree | 429d3e1b6c7f2facfb3e361b4b708f0d36e8aac8 /apps/core/views.py | |
parent | f077badf3163fc36c111dc45fe8d7d6f57d8712a (diff) | |
download | motor.old-297419f370ea87458017ee506a2e551e9068b66b.tar.gz motor.old-297419f370ea87458017ee506a2e551e9068b66b.tar.bz2 motor.old-297419f370ea87458017ee506a2e551e9068b66b.zip |
Swicthing machines
Diffstat (limited to 'apps/core/views.py')
-rw-r--r-- | apps/core/views.py | 79 |
1 files changed, 71 insertions, 8 deletions
diff --git a/apps/core/views.py b/apps/core/views.py index fc8f941..9e875e8 100644 --- a/apps/core/views.py +++ b/apps/core/views.py @@ -1,17 +1,80 @@ -from django.shortcuts import render -from django.views.generic.edit import FormView +from django.contrib import auth +from django.contrib import messages +from django.shortcuts import redirect from django.views.generic.list import ListView -from apps.core.forms import LoginForm +from django.views.generic.edit import FormView, CreateView, UpdateView +from apps.core.forms import LoginForm, EditProviderForm, UserEditForm +from django.utils.translation import ugettext as _ -from apps.core.models import ServiceProvider +from apps.core.models import ServiceProvider, User +from apps.docs.models import Article + +class DefaultListView(ListView): + template_name = 'core/list.html' + + +class DefaultEditView(UpdateView): + template_name = 'core/form.html' + def get_context_data(self, **kwargs): + context = super(DefaultEditView, self).get_context_data(**kwargs) + context['object_list'] = self.model.objects.all() + return context + + +class CreateSiteView(CreateView): + model = ServiceProvider + form_class = EditProviderForm + template_name = 'core/form.html' + success_url = '/manage/sites/' class LoginView(FormView): - template_name = 'login.html' form_class = LoginForm - success_url = '/manage/sites/' + template_name = 'login.html' + success_url = '/manage/providers/' + + def form_valid(self, form): + auth.login(self.request, form.cleaned_data['user']) + return super(LoginView, self).form_valid(form) + + +class ProvidersListView(DefaultListView): + model = ServiceProvider -class SitesListView(ListView): +class ProviderEditView(DefaultEditView): model = ServiceProvider - template_name = 'manage/sites.html' + + +class UserListView(DefaultListView): + model = User + + +class UserEditView(DefaultEditView): + model = User + form_class = UserEditForm + + +class UserCreateView(CreateView): + model = User + form_class = UserEditForm + template_name = 'core/form.html' + + +class ArticleListView(DefaultListView): + model = Article + + +class ArticleEditView(DefaultEditView): + model = Article + + +class ArticleCreateView(CreateView): + model = Article + template_name = 'core/form.html' + + +def logout(request): + auth.logout(request) + messages.success(request, _('You have signed out')) + return redirect('/manage/') |