blob: acae524638a799d4275b84b0d7898e2f25011e03 [file] [log] [blame]
# Copyright 2011 the Melange authors.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# See the License for the specific language governing permissions and
# limitations under the License.
"""Module for the site global pages."""
import httplib
import os
from google.appengine.api import users
from django import http
from django.conf.urls.defaults import url as django_url
from django.forms import widgets as django_widgets
from django.utils.translation import ugettext
from soc.logic import cleaning
from soc.logic import exceptions
from soc.logic import site as site_logic
from soc.models import document
from soc.models import site
from soc.views import base
from soc.views import forms as views_forms
DEF_NO_DEVELOPER = ugettext(
'This page is only accessible to developers.')
def getProgramMap():
# TODO(nathaniel): Magic string? This isn't a program.
choices = [('', '-----')]
# TODO(nathaniel): Eliminate the circularity behind this non-top-level
# import.
from soc.modules import callback
choices += callback.getCore().getProgramMap()
return choices
class SiteForm(views_forms.ModelForm):
"""Django form for the site settings."""
class Meta:
model = site.Site
exclude = ['link_id', 'scope', 'xsrf_secret_key']
# NOTE(nathaniel): There aren't really no choices, it's just that we
# can't know what the choices are at module-load-time. For the moment
# we have to set the available choices below in EditSitePage.context.
widgets = {'active_program': django_widgets.Select(choices=[])}
def clean_tos(self):
return '' if self.cleaned_data['tos'] is None else self.cleaned_data['tos']
def templatePath(self):
return 'v2/modules/gsoc/_form.html'
clean_noreply_email = cleaning.clean_empty_field('noreply_email')
class EditSitePage(base.SiteRequestHandler):
"""View for the participant profile."""
def djangoURLPatterns(self):
return [
django_url(r'^site/edit$', self, name='edit_site_settings'),
def jsonContext(self, data, check, mutator):
entities = document.Document.all().filter('prefix', 'site')
json_data = [{'key': str(i.key()),
'link_id': i.link_id,
'label': i.title}
for i in entities]
return {'data': json_data}
def checkAccess(self, data, check, mutator):
if not data.is_developer:
raise exceptions.AccessViolation(DEF_NO_DEVELOPER)
def templatePath(self):
# TODO: make this specific to the current active program
return 'soc/site/base.html'
def context(self, data, check, mutator):
# TODO: suboptimal
from soc.modules.gsoc.views.forms import GSoCBoundField
site_form = SiteForm(GSoCBoundField, data.POST or None,
# NOTE(nathaniel): This is an unfortunate workaround for the fact
# that in its current form the SiteForm class will only ever present
# to the user those choices that were discoverable at module-load time.
site_form.fields['active_program'].widget = django_widgets.Select(
return {
'app_version': os.environ.get('CURRENT_VERSION_ID', '').split('.')[0],
'page_name': 'Edit site settings',
'site_form': site_form,
def validate(self, data):
from soc.modules.gsoc.views.forms import GSoCBoundField
site_form = SiteForm(GSoCBoundField, data.POST,
if site_form.is_valid():
return True
return False
def post(self, data, check, mutator):
"""Handler for HTTP POST request."""
post_accepted = self.validate(data)
context = self.context(data, check, mutator)
template_path = self.templatePath()
response_content = self.render(data, template_path, context)
return http.HttpResponse(
status=httplib.OK if post_accepted else httplib.BAD_REQUEST,
class SiteHomepage(base.SiteRequestHandler):
"""View for the site home page."""
def djangoURLPatterns(self):
return [
django_url(r'^$', self, name='site_home'),
django_url(r'^(login)$', self, name='login'),
django_url(r'^(logout)$', self, name='logout'),
def __call__(self, request, *args, **kwargs):
"""Custom call implementation that avoids looking up unneeded data."""
data, _, _ = self.init(request, args, kwargs)
action = args[0] if args else ''
if action == 'login':
return data.redirect.toUrl(users.create_login_url('/'))
elif action == 'logout':
return data.redirect.toUrl(users.create_logout_url('/'))
settings = site_logic.singleton()
program = settings.active_program
if program:
program_url = self.linker.program(program, program.homepage_url_name)
return http.HttpResponseRedirect(program_url)
except exceptions.Error, e:
return self.error(data, e.status, message=e.args[0])