- Legacy-Id: 2626 Note: SVN reference [2614] has been migrated to Git commit 6a65978a52dff343754e557dd9d094e4385c6af1
94 lines
4.7 KiB
Python
94 lines
4.7 KiB
Python
# Copyright The IETF Trust 2008, All Rights Reserved
|
|
|
|
# Portion Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
|
|
# All rights reserved. Contact: Pasi Eronen <pasi.eronen@nokia.com>
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions
|
|
# are met:
|
|
#
|
|
# * Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
#
|
|
# * Redistributions in binary form must reproduce the above
|
|
# copyright notice, this list of conditions and the following
|
|
# disclaimer in the documentation and/or other materials provided
|
|
# with the distribution.
|
|
#
|
|
# * Neither the name of the Nokia Corporation and/or its
|
|
# subsidiary(-ies) nor the names of its contributors may be used
|
|
# to endorse or promote products derived from this software
|
|
# without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
from ietf.idtracker.models import Area, IETFWG
|
|
from django.shortcuts import get_object_or_404, render_to_response
|
|
from django.template import RequestContext, loader
|
|
from django.http import HttpResponse
|
|
from ietf.idrfc.views_search import SearchForm, search_query
|
|
from ietf.idrfc.idrfc_wrapper import IdRfcWrapper
|
|
from ietf.ipr.models import IprDetail
|
|
|
|
|
|
def wg_summary_acronym(request):
|
|
areas = Area.active_areas()
|
|
wgs = IETFWG.objects.filter(status=IETFWG.ACTIVE)
|
|
return HttpResponse(loader.render_to_string('wginfo/1wg-summary-by-acronym.txt', {'area_list': areas, 'wg_list': wgs}),mimetype='text/plain; charset=UTF-8')
|
|
|
|
def wg_summary_area(request):
|
|
wgs = IETFWG.objects.filter(status='1',start_date__isnull=False)
|
|
return HttpResponse(loader.render_to_string('wginfo/1wg-summary.txt', {'wg_list': wgs}),mimetype='text/plain; charset=UTF-8')
|
|
|
|
def wg_charters(request):
|
|
wgs = IETFWG.objects.filter(status='1',start_date__isnull=False)
|
|
return HttpResponse(loader.render_to_string('wginfo/1wg-charters.txt', {'wg_list': wgs}),mimetype='text/plain; charset=UTF-8')
|
|
|
|
def wg_charters_by_acronym(request):
|
|
wgs = IETFWG.objects.filter(status='1',start_date__isnull=False)
|
|
return HttpResponse(loader.render_to_string('wginfo/1wg-charters-by-acronym.txt', {'wg_list': wgs}),mimetype='text/plain; charset=UTF-8')
|
|
|
|
def wg_dir(request):
|
|
areas = Area.active_areas()
|
|
return render_to_response('wginfo/wg-dir.html', {'areas':areas}, RequestContext(request))
|
|
|
|
def wg_documents(request, acronym):
|
|
wg = get_object_or_404(IETFWG, group_acronym__acronym=acronym, group_type=1)
|
|
concluded = (wg.status_id != 1)
|
|
form = SearchForm({'by':'group', 'group':str(wg.group_acronym.acronym),
|
|
'rfcs':'on', 'activeDrafts':'on'})
|
|
if not form.is_valid():
|
|
raise ValueError("form did not validate")
|
|
(docs,meta) = search_query(form.cleaned_data)
|
|
|
|
# get the related docs
|
|
form_related = SearchForm({'by':'group', 'name':'-'+str(wg.group_acronym.acronym)+'-', 'activeDrafts':'on'})
|
|
if not form_related.is_valid():
|
|
raise ValueError("form_related did not validate")
|
|
(docs_related,meta_related) = search_query(form_related.cleaned_data)
|
|
docs_related_pruned = []
|
|
for d in docs_related:
|
|
parts = d.id.draft_name.split("-", 2);
|
|
# canonical form draft-<name|ietf>-wg-etc
|
|
if ( len(parts) >= 3):
|
|
if parts[1] != "ietf" and parts[2].startswith(wg.group_acronym.acronym+"-"):
|
|
docs_related_pruned.append(d)
|
|
|
|
return render_to_response('wginfo/wg_documents.html', {'wg': wg, 'concluded':concluded, 'selected':'documents', 'docs':docs, 'meta':meta,
|
|
'docs_related':docs_related_pruned, 'meta_related':meta_related}, RequestContext(request))
|
|
|
|
def wg_charter(request, acronym):
|
|
wg = get_object_or_404(IETFWG, group_acronym__acronym=acronym, group_type=1)
|
|
concluded = (wg.status_id != 1)
|
|
return render_to_response('wginfo/wg_charter.html', {'wg': wg, 'concluded':concluded, 'selected':'charter'}, RequestContext(request))
|