2007-11-03 00:45:10 -07:00
|
|
|
from django.http import HttpResponse, HttpResponseRedirect
|
|
|
|
from django.contrib.auth.decorators import login_required
|
|
|
|
from django.contrib.auth.models import User
|
|
|
|
from django.core import validators
|
2008-03-08 00:13:41 -08:00
|
|
|
from archweb_dev.main.utils import render_response, validate
|
|
|
|
from archweb_dev.main.models import Package, Repo, Todolist, TodolistPkg
|
|
|
|
from archweb_dev.main.models import UserProfile, News, Donator, Mirror
|
2008-01-03 11:37:43 -08:00
|
|
|
from django.http import HttpResponse
|
|
|
|
from django.template import Context, loader
|
2007-12-29 18:25:03 -08:00
|
|
|
|
2007-11-03 00:45:10 -07:00
|
|
|
|
|
|
|
@login_required
|
|
|
|
def index(request):
|
2007-12-29 15:34:02 -08:00
|
|
|
try:
|
|
|
|
thismaint = User.objects.get(username=request.user.username)
|
|
|
|
except User.DoesNotExist:
|
|
|
|
# weird, we don't have a maintainer record for this logged-in user
|
|
|
|
thismaint = None
|
2007-11-03 00:45:10 -07:00
|
|
|
|
2007-12-29 15:34:02 -08:00
|
|
|
# get a list of incomplete package todo lists
|
|
|
|
todos = Todolist.objects.get_incomplete()
|
|
|
|
# get flagged-package stats for all maintainers
|
|
|
|
stats = Package.objects.get_flag_stats()
|
|
|
|
if thismaint:
|
|
|
|
# get list of flagged packages for this maintainer
|
|
|
|
pkgs = Package.objects.filter(maintainer=thismaint.id).filter(needupdate=True).order_by('repo', 'pkgname')
|
|
|
|
else:
|
|
|
|
pkgs = None
|
2007-11-03 00:45:10 -07:00
|
|
|
|
2007-12-30 12:13:47 -08:00
|
|
|
repo_stats = []
|
|
|
|
for repo in Repo.objects.all():
|
|
|
|
repo_stats.append({
|
|
|
|
'name': repo.name,
|
|
|
|
'count': Package.objects.filter(repo__exact = repo).count(),
|
|
|
|
'flagged': Package.objects.filter(repo__exact = repo).filter(needupdate=True).count()
|
|
|
|
})
|
|
|
|
|
2007-12-29 15:34:02 -08:00
|
|
|
return render_response(request, 'devel/index.html',
|
2007-12-30 12:13:47 -08:00
|
|
|
{'stats':stats,
|
|
|
|
'pkgs':pkgs,
|
|
|
|
'todos':todos,
|
|
|
|
'maint':thismaint,
|
|
|
|
'repos': repo_stats})
|
2007-11-03 00:45:10 -07:00
|
|
|
|
|
|
|
@login_required
|
|
|
|
#@is_maintainer
|
|
|
|
def change_notify(request):
|
2007-12-29 15:34:02 -08:00
|
|
|
maint = User.objects.get(username=request.user.username)
|
|
|
|
notify = request.POST.get('notify', 'no')
|
|
|
|
try:
|
|
|
|
maint.get_profile().notify = notify == 'yes'
|
|
|
|
except UserProfile.DoesNotExist:
|
|
|
|
UserProfile(user_id=maint.id ,notify=notify == 'yes').save()
|
|
|
|
maint.get_profile().save()
|
|
|
|
return HttpResponseRedirect('/devel/')
|
2007-11-03 00:45:10 -07:00
|
|
|
|
|
|
|
@login_required
|
|
|
|
def change_profile(request):
|
2007-12-29 15:34:02 -08:00
|
|
|
errors = {}
|
|
|
|
if request.POST:
|
|
|
|
passwd1, passwd2 = request.POST['passwd'], request.POST['passwd2']
|
|
|
|
email = request.POST['email']
|
|
|
|
# validate
|
|
|
|
if passwd1 != passwd2:
|
|
|
|
errors['password'] = [' Passwords do not match. ']
|
|
|
|
validate(errors, 'Email', email, validators.isValidEmail, False, request)
|
|
|
|
# apply changes
|
|
|
|
if not errors:
|
|
|
|
request.user.email = email
|
|
|
|
if passwd1:
|
|
|
|
request.user.set_password(passwd1)
|
|
|
|
request.user.save()
|
|
|
|
return HttpResponseRedirect('/devel/')
|
|
|
|
return render_response(request, 'devel/profile.html', {'errors':errors,'email':request.user.email})
|
2007-11-03 00:45:10 -07:00
|
|
|
|
|
|
|
@login_required
|
|
|
|
def guide(request):
|
2008-01-03 11:37:43 -08:00
|
|
|
t = loader.get_template('devel/pkgmaint_guide.txt')
|
|
|
|
c = Context()
|
|
|
|
return HttpResponse(t.render(c), mimetype="text/plain")
|
|
|
|
#return render_response(request, 'devel/pkgmaint_guide.txt',
|
|
|
|
# mimetype='text/plain')
|
2007-12-29 18:25:03 -08:00
|
|
|
|
|
|
|
def siteindex(request):
|
|
|
|
# get the most recent 10 news items
|
|
|
|
news = News.objects.order_by('-postdate', '-id')[:10]
|
|
|
|
pkgs = Package.objects.exclude(repo__name__exact='Testing').order_by('-last_update')[:15]
|
|
|
|
repos = Repo.objects.order_by('name')
|
2007-12-29 18:42:50 -08:00
|
|
|
return render_response(request, 'devel/siteindex.html', {'news_updates':news,'pkg_updates':pkgs,'repos':repos})
|
2007-12-29 18:25:03 -08:00
|
|
|
|
|
|
|
def cvs(request):
|
2007-12-29 18:42:50 -08:00
|
|
|
return render_response(request, 'devel/cvs.html')
|
2007-12-29 18:25:03 -08:00
|
|
|
|
|
|
|
def developers(request):
|
2008-01-06 20:56:19 -08:00
|
|
|
devs = User.objects.filter(is_active=True).order_by('username')
|
2007-12-29 18:42:50 -08:00
|
|
|
return render_response(request, 'devel/developers.html', {'devs':devs})
|
2007-12-29 18:25:03 -08:00
|
|
|
|
|
|
|
def donate(request):
|
|
|
|
donor_count = Donator.objects.count()
|
|
|
|
splitval = donor_count / 4
|
|
|
|
slice1 = Donator.objects.all()[:splitval]
|
|
|
|
slice2 = Donator.objects.all()[(splitval):(splitval*2)]
|
|
|
|
slice3 = Donator.objects.all()[(splitval*2):(donor_count-splitval)]
|
|
|
|
slice4 = Donator.objects.all()[(donor_count-splitval):donor_count]
|
2007-12-29 18:42:50 -08:00
|
|
|
return render_response(request, 'devel/donate.html',
|
2007-12-29 18:25:03 -08:00
|
|
|
{'slice1':slice1,'slice2':slice2,'slice3':slice3,'slice4':slice4})
|
|
|
|
|
|
|
|
def download(request):
|
|
|
|
mirrors = Mirror.objects.order_by('country', 'domain')
|
2007-12-29 18:42:50 -08:00
|
|
|
return render_response(request, 'devel/download.html', {'mirrors':mirrors})
|
2007-12-29 18:25:03 -08:00
|
|
|
|
|
|
|
def projects(request):
|
2007-12-29 18:42:50 -08:00
|
|
|
return render_response(request, 'devel/projects.html')
|
2007-12-29 18:25:03 -08:00
|
|
|
|
|
|
|
def robots(request):
|
|
|
|
return HttpResponse("User-agent: *\nDisallow: /\n", mimetype="text/plain")
|
|
|
|
|
|
|
|
def denied(request):
|
2007-12-29 18:42:50 -08:00
|
|
|
return render_response(request, 'devel/denied.html')
|
2007-12-29 16:42:55 -08:00
|
|
|
|
|
|
|
# vim: set ts=4 sw=4 et:
|
|
|
|
|