116751e4ba
We're going to move to using ISO 2 character codes via django countries, so start by moving the old data out of the way first. Signed-off-by: Dan McGee <dan@archlinux.org>
121 lines
4.3 KiB
Python
121 lines
4.3 KiB
Python
from datetime import datetime
|
|
|
|
from django.conf import settings
|
|
from django.contrib.auth.models import User
|
|
from django.db.models import Count, Q
|
|
from django.http import Http404
|
|
from django.views.decorators.cache import cache_control
|
|
from django.views.generic import list_detail
|
|
from django.views.generic.simple import direct_to_template
|
|
|
|
from devel.models import MasterKey, PGPSignature
|
|
from main.models import Arch, Repo, Donor
|
|
from mirrors.models import MirrorUrl
|
|
from news.models import News
|
|
from .utils import get_recent_updates
|
|
|
|
@cache_control(max_age=300)
|
|
def index(request):
|
|
pkgs = get_recent_updates()
|
|
context = {
|
|
'news_updates': News.objects.order_by('-postdate', '-id')[:15],
|
|
'pkg_updates': pkgs,
|
|
}
|
|
return direct_to_template(request, 'public/index.html', context)
|
|
|
|
USER_LISTS = {
|
|
'devs': {
|
|
'user_type': 'Developers',
|
|
'description': "This is a list of the current Arch Linux Developers. They maintain the [core] and [extra] package repositories in addition to doing any other developer duties.",
|
|
},
|
|
'tus': {
|
|
'user_type': 'Trusted Users',
|
|
'description': "Here are all your friendly Arch Linux Trusted Users who are in charge of the [community] repository.",
|
|
},
|
|
'fellows': {
|
|
'user_type': 'Fellows',
|
|
'description': "Below you can find a list of ex-developers (aka project fellows). These folks helped make Arch what it is today. Thanks!",
|
|
},
|
|
}
|
|
|
|
@cache_control(max_age=300)
|
|
def userlist(request, user_type='devs'):
|
|
users = User.objects.order_by(
|
|
'first_name', 'last_name').select_related('userprofile')
|
|
if user_type == 'devs':
|
|
users = users.filter(is_active=True, groups__name="Developers")
|
|
elif user_type == 'tus':
|
|
users = users.filter(is_active=True, groups__name="Trusted Users")
|
|
elif user_type == 'fellows':
|
|
users = users.filter(is_active=False,
|
|
groups__name__in=["Developers", "Trusted Users"])
|
|
else:
|
|
raise Http404
|
|
|
|
users = users.distinct()
|
|
context = USER_LISTS[user_type].copy()
|
|
context['users'] = users
|
|
return direct_to_template(request, 'public/userlist.html', context)
|
|
|
|
@cache_control(max_age=300)
|
|
def donate(request):
|
|
context = {
|
|
'donors': Donor.objects.filter(visible=True).order_by('name'),
|
|
}
|
|
return direct_to_template(request, 'public/donate.html', context)
|
|
|
|
@cache_control(max_age=300)
|
|
def download(request):
|
|
qset = MirrorUrl.objects.select_related('mirror', 'protocol').filter(
|
|
protocol__is_download=True,
|
|
mirror__public=True, mirror__active=True, mirror__isos=True
|
|
)
|
|
context = {
|
|
'releng_iso_url': settings.ISO_LIST_URL,
|
|
'releng_pxeboot_url': settings.PXEBOOT_URL,
|
|
}
|
|
return list_detail.object_list(request,
|
|
qset.order_by('mirror__country_old', 'mirror__name', 'protocol'),
|
|
template_name="public/download.html",
|
|
template_object_name="mirror_url",
|
|
extra_context=context)
|
|
|
|
@cache_control(max_age=300)
|
|
def feeds(request):
|
|
context = {
|
|
'arches': Arch.objects.all(),
|
|
'repos': Repo.objects.all(),
|
|
}
|
|
return direct_to_template(request, 'public/feeds.html', context)
|
|
|
|
@cache_control(max_age=300)
|
|
def keys(request):
|
|
not_expired = Q(expires__gt=datetime.utcnow) | Q(expires__isnull=True)
|
|
master_keys = MasterKey.objects.select_related('owner', 'revoker',
|
|
'owner__userprofile', 'revoker__userprofile').filter(
|
|
revoked__isnull=True)
|
|
|
|
sig_counts = PGPSignature.objects.filter(
|
|
not_expired, valid=True).values_list('signer').annotate(
|
|
Count('signer'))
|
|
sig_counts = dict((key_id[-16:], ct) for key_id, ct in sig_counts)
|
|
|
|
for key in master_keys:
|
|
key.signature_count = sig_counts.get(key.pgp_key[-16:], 0)
|
|
|
|
users = User.objects.filter(is_active=True).select_related(
|
|
'userprofile__pgp_key').order_by('first_name', 'last_name')
|
|
|
|
# frozenset because we are going to do lots of __contains__ lookups
|
|
signatures = frozenset(PGPSignature.objects.filter(
|
|
not_expired, valid=True).values_list('signer', 'signee'))
|
|
|
|
context = {
|
|
'keys': master_keys,
|
|
'active_users': users,
|
|
'signatures': signatures,
|
|
}
|
|
return direct_to_template(request, 'public/keys.html', context)
|
|
|
|
# vim: set ts=4 sw=4 et:
|