Some tweaks for the dev navigation
[archweb_dev-nj.git] / devel / views.py
blob2c92906a5b9b9d61b9237aa98b884ce355151c14
1 from django.http import HttpResponse, HttpResponseRedirect
2 from django.contrib.auth.decorators import login_required
3 from django.contrib.auth.models import User
4 from django.core import validators
5 from archweb_dev.lib.utils import render_response
6 from archweb_dev.packages.models import Package, Repo
7 from archweb_dev.todolists.models import Todolist, TodolistPkg
8 from archweb_dev.lib.utils import validate
9 from archweb_dev.devel.models import UserProfile
10 from archweb_dev.news.models import News
11 from archweb_dev.devel.models import Donator, Mirror
12 from django.http import HttpResponse
13 from django.template import Context, loader
16 @login_required
17 def index(request):
18 try:
19 thismaint = User.objects.get(username=request.user.username)
20 except User.DoesNotExist:
21 # weird, we don't have a maintainer record for this logged-in user
22 thismaint = None
24 # get a list of incomplete package todo lists
25 todos = Todolist.objects.get_incomplete()
26 # get flagged-package stats for all maintainers
27 stats = Package.objects.get_flag_stats()
28 if thismaint:
29 # get list of flagged packages for this maintainer
30 pkgs = Package.objects.filter(maintainer=thismaint.id).filter(needupdate=True).order_by('repo', 'pkgname')
31 else:
32 pkgs = None
34 repo_stats = []
35 for repo in Repo.objects.all():
36 repo_stats.append({
37 'name': repo.name,
38 'count': Package.objects.filter(repo__exact = repo).count(),
39 'flagged': Package.objects.filter(repo__exact = repo).filter(needupdate=True).count()
42 return render_response(request, 'devel/index.html',
43 {'stats':stats,
44 'pkgs':pkgs,
45 'todos':todos,
46 'maint':thismaint,
47 'repos': repo_stats})
49 @login_required
50 #@is_maintainer
51 def change_notify(request):
52 maint = User.objects.get(username=request.user.username)
53 notify = request.POST.get('notify', 'no')
54 try:
55 maint.get_profile().notify = notify == 'yes'
56 except UserProfile.DoesNotExist:
57 UserProfile(user_id=maint.id ,notify=notify == 'yes').save()
58 maint.get_profile().save()
59 return HttpResponseRedirect('/devel/')
61 @login_required
62 def change_profile(request):
63 errors = {}
64 if request.POST:
65 passwd1, passwd2 = request.POST['passwd'], request.POST['passwd2']
66 email = request.POST['email']
67 # validate
68 if passwd1 != passwd2:
69 errors['password'] = [' Passwords do not match. ']
70 validate(errors, 'Email', email, validators.isValidEmail, False, request)
71 # apply changes
72 if not errors:
73 request.user.email = email
74 if passwd1:
75 request.user.set_password(passwd1)
76 request.user.save()
77 return HttpResponseRedirect('/devel/')
78 return render_response(request, 'devel/profile.html', {'errors':errors,'email':request.user.email})
80 @login_required
81 def guide(request):
82 t = loader.get_template('devel/pkgmaint_guide.txt')
83 c = Context()
84 return HttpResponse(t.render(c), mimetype="text/plain")
85 #return render_response(request, 'devel/pkgmaint_guide.txt',
86 # mimetype='text/plain')
88 def siteindex(request):
89 # get the most recent 10 news items
90 news = News.objects.order_by('-postdate', '-id')[:10]
91 pkgs = Package.objects.exclude(repo__name__exact='Testing').order_by('-last_update')[:15]
92 repos = Repo.objects.order_by('name')
93 return render_response(request, 'devel/siteindex.html', {'news_updates':news,'pkg_updates':pkgs,'repos':repos})
95 def cvs(request):
96 return render_response(request, 'devel/cvs.html')
98 def developers(request):
99 devs = User.objects.order_by('username')
100 return render_response(request, 'devel/developers.html', {'devs':devs})
102 def donate(request):
103 donor_count = Donator.objects.count()
104 splitval = donor_count / 4
105 slice1 = Donator.objects.all()[:splitval]
106 slice2 = Donator.objects.all()[(splitval):(splitval*2)]
107 slice3 = Donator.objects.all()[(splitval*2):(donor_count-splitval)]
108 slice4 = Donator.objects.all()[(donor_count-splitval):donor_count]
109 return render_response(request, 'devel/donate.html',
110 {'slice1':slice1,'slice2':slice2,'slice3':slice3,'slice4':slice4})
112 def download(request):
113 mirrors = Mirror.objects.order_by('country', 'domain')
114 return render_response(request, 'devel/download.html', {'mirrors':mirrors})
116 def projects(request):
117 return render_response(request, 'devel/projects.html')
119 def robots(request):
120 return HttpResponse("User-agent: *\nDisallow: /\n", mimetype="text/plain")
122 def denied(request):
123 return render_response(request, 'devel/denied.html')
125 # vim: set ts=4 sw=4 et: