blob: eb065c8bc4e286d7b94b86cdfa2d3105cd5b416b [file] [log] [blame]
#!/usr/bin/env python2.5
# 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 org applications.
from django import forms as django_forms
from django.utils.translation import ugettext
from soc.views import forms
from soc.views import survey
from soc.views.helper import lists
from soc.logic import cleaning
from soc.models.org_app_record import OrgAppRecord
from soc.models.org_app_survey import OrgAppSurvey
from soc.views.readonly_template import SurveyRecordReadOnlyTemplate
class OrgAppEditForm(forms.SurveyEditForm):
"""Form to create/edit organization application survey.
class Meta:
model = OrgAppSurvey
css_prefix = 'org-app-edit'
exclude = ['scope', 'author', 'program', 'created_by', 'modified_by']
class OrgAppTakeForm(forms.SurveyTakeForm):
"""Form for would-be organization admins to apply for the program.
backup_admin_id = django_forms.CharField(
label=ugettext('Backup Admin'), required=True,
help_text=ugettext('The Link ID of the user who will serve as the '
'backup admin for this organization.'))
def __init__(self, survey, tos_content, bound_class_field, *args, **kwargs):
super(OrgAppTakeForm, self).__init__(survey, bound_class_field, *args,
if self.instance:
self.fields['backup_admin_id'].initial = \
# not marked required by data model for backwards compatibility
self.fields['org_id'].required = True
self.fields['agreed_to_admin_agreement'].widget = forms.TOSWidget(
class Meta:
model = OrgAppRecord
css_prefix = 'org-app-record'
exclude = ['main_admin', 'backup_admin', 'status', 'user', 'survey',
'created', 'modified', 'program']
widgets = forms.choiceWidgets(model,
def clean_org_id(self):
org_id = cleaning.clean_link_id('org_id')(self)
if not org_id:
# manual required check, see Issue 1291
raise django_forms.ValidationError('This field is required.')
q = OrgAppRecord.all()
q.filter('survey', self.survey)
q.filter('org_id', org_id)
org_app = q.get()
if org_app:
# If we are creating a new org app it is a duplicate, if we are editing
# an org app we must check if the one we found has a different key.
if (not self.instance) or (org_app.key() != self.instance.key()):
raise django_forms.ValidationError('This ID has already been taken.')
return org_id
def clean_backup_admin_id(self):
backup_admin = cleaning.clean_existing_user('backup_admin_id')(self)
if not self.instance:
elif self.instance.main_admin.key() == backup_admin.key():
raise django_forms.ValidationError(
'You cannot enter the person who created the application here.')
self.cleaned_data['backup_admin'] = backup_admin
return backup_admin
def clean(self):
cleaned_data = self.cleaned_data
# pop our custom id field if exists
if 'backup_admin_id' in cleaned_data:
return cleaned_data
class OrgAppRecordsList(object):
"""View for listing all records of a Organization Applications.
def __init__(self, read_only_view):
"""Initializes the OrgAppRecordsList.
read_only_view: Name of the url pattern for the read only view of a
self.read_only_view = read_only_view
def checkAccess(self):
"""Defines access checks for this list, all hosts should be able to see it.
def context(self):
"""Returns the context of the page to render.
record_list = self._createOrgAppsList()
page_name = ugettext('Records - %s' % (
context = {
'page_name': page_name,
'record_list': record_list,
return context
def jsonContext(self):
"""Handler for JSON requests.
idx = lists.getListIndex(self.request)
if idx == 0:
record_list = self._createOrgAppsList()
return record_list.listContentResponse(self.request).content()
super(OrgAppRecordsList, self).jsonContext()
def _createOrgAppsList(self):
"""Creates a SurveyRecordList for the requested survey.
record_list = survey.SurveyRecordList(,, OrgAppRecord, idx=0)
record_list.list_config.addSimpleColumn('name', 'Name')
record_list.list_config.addSimpleColumn('org_id', 'Organization ID')
# TODO(ljvderijk): Poke Mario during all-hands to see if we can separate
# "search options" and in-line selection options.
options = [
('', 'All'),
('(needs review)', 'needs review'),
('(pre-accepted)', 'pre-accepted'),
#('(accepted)', 'accepted'),
('(pre-rejected)', 'pre-rejected'),
#('(rejected)', 'rejected'),
('(ignored)', 'ignored'),
record_list.list_config.addSimpleColumn('status', 'Status', options=options)
record_list.list_config.setColumnEditable('status', True, 'select')
record_list.list_config.addPostEditButton('save', 'Save')
lambda e, *args:
return record_list
def templatePath(self):
return 'v2/soc/org_app/records.html'
class OrgAppReadOnlyTemplate(SurveyRecordReadOnlyTemplate):
"""Template to construct readonly organization application record.
class Meta:
model = OrgAppRecord
css_prefix = 'org-app-show'
fields = ['org_id', 'name', 'description', 'home_page', 'license',
survey_name = 'Organization Application'