forked from jan/debianmemberportfolio
Merge branch 'feature/cleanup' into develop
* feature/cleanup: PEP-8 compliance add missing import of response from pylons
This commit is contained in:
commit
5fcacf4ab2
16 changed files with 165 additions and 130 deletions
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service environment configuration
|
# DDPortfolio service environment configuration
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -31,9 +31,10 @@ import ddportfolioservice.lib.app_globals as app_globals
|
||||||
import ddportfolioservice.lib.helpers
|
import ddportfolioservice.lib.helpers
|
||||||
from ddportfolioservice.config.routing import make_map
|
from ddportfolioservice.config.routing import make_map
|
||||||
|
|
||||||
|
|
||||||
def load_environment(global_conf, app_conf):
|
def load_environment(global_conf, app_conf):
|
||||||
"""Configure the Pylons environment via the ``pylons.config``
|
"""
|
||||||
object
|
Configure the Pylons environment via the ``pylons.config`` object
|
||||||
"""
|
"""
|
||||||
config = PylonsConfig()
|
config = PylonsConfig()
|
||||||
|
|
||||||
|
@ -45,7 +46,8 @@ def load_environment(global_conf, app_conf):
|
||||||
templates=[os.path.join(root, 'templates')])
|
templates=[os.path.join(root, 'templates')])
|
||||||
|
|
||||||
# Initialize config with the basic options
|
# Initialize config with the basic options
|
||||||
config.init_app(global_conf, app_conf, package='ddportfolioservice', paths=paths)
|
config.init_app(
|
||||||
|
global_conf, app_conf, package='ddportfolioservice', paths=paths)
|
||||||
|
|
||||||
config['routes.map'] = make_map(config)
|
config['routes.map'] = make_map(config)
|
||||||
config['pylons.app_globals'] = app_globals.Globals(config)
|
config['pylons.app_globals'] = app_globals.Globals(config)
|
||||||
|
@ -54,7 +56,6 @@ def load_environment(global_conf, app_conf):
|
||||||
# Setup cache object as early as possible
|
# Setup cache object as early as possible
|
||||||
import pylons
|
import pylons
|
||||||
pylons.cache._push_object(config['pylons.app_globals'].cache)
|
pylons.cache._push_object(config['pylons.app_globals'].cache)
|
||||||
|
|
||||||
|
|
||||||
# Create the Mako TemplateLookup, with the default auto-escaping
|
# Create the Mako TemplateLookup, with the default auto-escaping
|
||||||
config['pylons.app_globals'].mako_lookup = TemplateLookup(
|
config['pylons.app_globals'].mako_lookup = TemplateLookup(
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service middleware configuration
|
# DDPortfolio service middleware configuration
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -32,6 +32,7 @@ from routes.middleware import RoutesMiddleware
|
||||||
|
|
||||||
from ddportfolioservice.config.environment import load_environment
|
from ddportfolioservice.config.environment import load_environment
|
||||||
|
|
||||||
|
|
||||||
def make_app(global_conf, full_stack=True, static_files=True, **app_conf):
|
def make_app(global_conf, full_stack=True, static_files=True, **app_conf):
|
||||||
"""Create a Pylons WSGI application and return it
|
"""Create a Pylons WSGI application and return it
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service routing configuration
|
# DDPortfolio service routing configuration
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -28,6 +28,7 @@ refer to the routes manual at http://routes.groovie.org/docs/
|
||||||
"""
|
"""
|
||||||
from routes import Mapper
|
from routes import Mapper
|
||||||
|
|
||||||
|
|
||||||
def make_map(config):
|
def make_map(config):
|
||||||
"""Create, configure and return the routes Mapper"""
|
"""Create, configure and return the routes Mapper"""
|
||||||
map = Mapper(directory=config['pylons.paths']['controllers'],
|
map = Mapper(directory=config['pylons.paths']['controllers'],
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
import logging
|
import logging
|
||||||
import simplejson
|
import simplejson
|
||||||
|
|
||||||
from pylons import request, tmpl_context as c
|
from pylons import request, response, tmpl_context as c
|
||||||
from pylons.i18n import N_, _
|
from pylons.i18n import N_, _
|
||||||
import formencode.api
|
import formencode.api
|
||||||
import formencode.validators
|
import formencode.validators
|
||||||
|
@ -35,91 +35,92 @@ from ddportfolioservice.model import dddatabuilder
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class DdportfolioController(BaseController):
|
class DdportfolioController(BaseController):
|
||||||
_LABELS = {
|
_LABELS = {
|
||||||
'overview' : {
|
'overview': {
|
||||||
'label' : N_('Overview'),
|
'label': N_('Overview'),
|
||||||
'ddpo' : N_("Debian Member's Package Overview"),
|
'ddpo': N_("Debian Member's Package Overview"),
|
||||||
'alladdresses' : N_("""Debian Member's Package Overview
|
'alladdresses': N_("""Debian Member's Package Overview
|
||||||
... showing all email addresses"""),
|
... showing all email addresses"""),
|
||||||
},
|
},
|
||||||
'bugs' : {
|
'bugs': {
|
||||||
'label' : N_('Bugs'),
|
'label': N_('Bugs'),
|
||||||
'received' : N_('''bugs received
|
'received': N_('''bugs received
|
||||||
(note: co-maintainers not listed, see \
|
(note: co-maintainers not listed, see \
|
||||||
<a href="http://bugs.debian.org/cgi-bin/bugreport.cgi?\
|
<a href="http://bugs.debian.org/cgi-bin/bugreport.cgi?\
|
||||||
bug=430986">#430986</a>)'''),
|
bug=430986">#430986</a>)'''),
|
||||||
'reported' : N_('bugs reported'),
|
'reported': N_('bugs reported'),
|
||||||
'bugstats' : N_('bugstats AKA <em>karma</em>'),
|
'bugstats': N_('bugstats AKA <em>karma</em>'),
|
||||||
'usertags' : N_('user tags'),
|
'usertags': N_('user tags'),
|
||||||
'searchall' : N_('all messages (i.e., full text search for \
|
'searchall': N_('all messages (i.e., full text search for \
|
||||||
developer name on all bug logs)'),
|
developer name on all bug logs)'),
|
||||||
'wnpp' : N_('<a href="http://wiki.debian.org/WNPP">WNPP</a>'),
|
'wnpp': N_('<a href="http://wiki.debian.org/WNPP">WNPP</a>'),
|
||||||
'correspondent' : N_('correspondent for bugs'),
|
'correspondent': N_('correspondent for bugs'),
|
||||||
'graph' : N_('one year open bug history graph'),
|
'graph': N_('one year open bug history graph'),
|
||||||
},
|
},
|
||||||
'build' : {
|
'build': {
|
||||||
'label' : N_('Build'),
|
'label': N_('Build'),
|
||||||
'buildd' : N_('buildd.d.o'),
|
'buildd': N_('buildd.d.o'),
|
||||||
'igloo' : N_('igloo'),
|
'igloo': N_('igloo'),
|
||||||
},
|
},
|
||||||
'qa' : {
|
'qa': {
|
||||||
'label' : N_('Quality Assurance'),
|
'label': N_('Quality Assurance'),
|
||||||
'lintian' : N_('lintian reports'),
|
'lintian': N_('lintian reports'),
|
||||||
'lintianfull' : N_('full lintian reports (i.e. including \
|
'lintianfull': N_('full lintian reports (i.e. including \
|
||||||
"info"-level messages)'),
|
"info"-level messages)'),
|
||||||
'dehs' : N_('DEHS (Debian External Health Status)'),
|
'dehs': N_('DEHS (Debian External Health Status)'),
|
||||||
'piuparts' : N_('piuparts'),
|
'piuparts': N_('piuparts'),
|
||||||
'patchtracker' : N_('Debian patch tracking system'),
|
'patchtracker': N_('Debian patch tracking system'),
|
||||||
},
|
},
|
||||||
'upload' : {
|
'upload': {
|
||||||
'label' : N_('Upload'),
|
'label': N_('Upload'),
|
||||||
'keylog' : N_('''keylog (per-key upload list)
|
'keylog': N_('''keylog (per-key upload list)
|
||||||
(note: uses key fingerprint)'''),
|
(note: uses key fingerprint)'''),
|
||||||
},
|
},
|
||||||
'lists' : {
|
'lists': {
|
||||||
'label' : N_('Mailing Lists'),
|
'label': N_('Mailing Lists'),
|
||||||
'dolists' : N_('lists.d.o'),
|
'dolists': N_('lists.d.o'),
|
||||||
'adolists' : N_('lists.a.d.o'),
|
'adolists': N_('lists.a.d.o'),
|
||||||
'gmane' : N_('gmane'),
|
'gmane': N_('gmane'),
|
||||||
},
|
},
|
||||||
'files' : {
|
'files': {
|
||||||
'label' : N_('Files'),
|
'label': N_('Files'),
|
||||||
'people' : N_('people.d.o'),
|
'people': N_('people.d.o'),
|
||||||
'oldpeople' : N_('oldpeople'),
|
'oldpeople': N_('oldpeople'),
|
||||||
'alioth' : N_('Alioth'),
|
'alioth': N_('Alioth'),
|
||||||
},
|
},
|
||||||
'membership' : {
|
'membership': {
|
||||||
'label' : N_('Membership'),
|
'label': N_('Membership'),
|
||||||
'nm' : N_('NM'),
|
'nm': N_('NM'),
|
||||||
'dbfinger' : N_('DB information via finger'),
|
'dbfinger': N_('DB information via finger'),
|
||||||
'db' : N_('DB information via HTTP'),
|
'db': N_('DB information via HTTP'),
|
||||||
'alioth' : N_('Alioth'),
|
'alioth': N_('Alioth'),
|
||||||
'wiki' : N_('Wiki'),
|
'wiki': N_('Wiki'),
|
||||||
'forum' : N_('Forum'),
|
'forum': N_('Forum'),
|
||||||
},
|
},
|
||||||
'miscellaneous' : {
|
'miscellaneous': {
|
||||||
'label' : N_('Miscellaneous'),
|
'label': N_('Miscellaneous'),
|
||||||
'debtags' : N_('debtags'),
|
'debtags': N_('debtags'),
|
||||||
'links' : N_('links'),
|
'links': N_('links'),
|
||||||
'website' : N_('Debian website'),
|
'website': N_('Debian website'),
|
||||||
'search' : N_('Debian search'),
|
'search': N_('Debian search'),
|
||||||
'gpgfinger' : N_('GPG public key via finger'),
|
'gpgfinger': N_('GPG public key via finger'),
|
||||||
'gpgweb' : N_('GPG public key via HTTP'),
|
'gpgweb': N_('GPG public key via HTTP'),
|
||||||
},
|
},
|
||||||
'ssh' : {
|
'ssh': {
|
||||||
'label' : N_('Information reachable via ssh (for Debian Members)'),
|
'label': N_('Information reachable via ssh (for Debian Members)'),
|
||||||
'owndndoms' : N_('owned debian.net domains'),
|
'owndndoms': N_('owned debian.net domains'),
|
||||||
'miainfo' : N_('<a href="http://wiki.debian.org/qa.debian.org/MIATeam">MIA</a> database information'),
|
'miainfo': N_('<a href="http://wiki.debian.org/qa.debian.org/'
|
||||||
'groupinfo' : N_('Group membership information'),
|
'MIATeam">MIA</a> database information'),
|
||||||
|
'groupinfo': N_('Group membership information'),
|
||||||
},
|
},
|
||||||
'ubuntu' : {
|
'ubuntu': {
|
||||||
'label' : N_('Ubuntu'),
|
'label': N_('Ubuntu'),
|
||||||
'ubuntudiff' : N_('Available patches from Ubuntu'),
|
'ubuntudiff': N_('Available patches from Ubuntu'),
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def _get_label(self, section, url=None):
|
def _get_label(self, section, url=None):
|
||||||
if section in self._LABELS:
|
if section in self._LABELS:
|
||||||
if url:
|
if url:
|
||||||
|
@ -131,11 +132,10 @@ developer name on all bug logs)'),
|
||||||
return "%s.%s" % (section, url)
|
return "%s.%s" % (section, url)
|
||||||
return section
|
return section
|
||||||
|
|
||||||
|
|
||||||
def index(self):
|
def index(self):
|
||||||
# Return a rendered template
|
"""
|
||||||
# return render('/some/template.mako')
|
Render the input form.
|
||||||
# or, Return a response
|
"""
|
||||||
return render('/showform.mako')
|
return render('/showform.mako')
|
||||||
|
|
||||||
def urllist(self):
|
def urllist(self):
|
||||||
|
@ -147,7 +147,7 @@ developer name on all bug logs)'),
|
||||||
languages=[lang[0:2] for lang in request.languages])
|
languages=[lang[0:2] for lang in request.languages])
|
||||||
form_result = schema.to_python(request.params)
|
form_result = schema.to_python(request.params)
|
||||||
except formencode.validators.Invalid, error:
|
except formencode.validators.Invalid, error:
|
||||||
c.messages = { 'errors' : error.unpack_errors() }
|
c.messages = {'errors': error.unpack_errors()}
|
||||||
return render('/showform.mako')
|
return render('/showform.mako')
|
||||||
fields = dddatabuilder.build_data(form_result['email'])
|
fields = dddatabuilder.build_data(form_result['email'])
|
||||||
rp = request.params.copy()
|
rp = request.params.copy()
|
||||||
|
@ -174,7 +174,7 @@ developer name on all bug logs)'),
|
||||||
languages=[lang[0:2] for lang in request.languages])
|
languages=[lang[0:2] for lang in request.languages])
|
||||||
form_result = schema.to_python(rp)
|
form_result = schema.to_python(rp)
|
||||||
except formencode.validators.Invalid, error:
|
except formencode.validators.Invalid, error:
|
||||||
c.messages = { 'errors' : error.unpack_errors() }
|
c.messages = {'errors': error.unpack_errors()}
|
||||||
return render('/showform.mako')
|
return render('/showform.mako')
|
||||||
if form_result['wikihomepage'] is None:
|
if form_result['wikihomepage'] is None:
|
||||||
log.debug('generate wikihomepage from name')
|
log.debug('generate wikihomepage from name')
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service ErrorController
|
# DDPortfolio service ErrorController
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -30,8 +30,8 @@ from webhelpers.html.builder import literal
|
||||||
|
|
||||||
from ddportfolioservice.lib.base import BaseController
|
from ddportfolioservice.lib.base import BaseController
|
||||||
|
|
||||||
class ErrorController(BaseController):
|
|
||||||
|
|
||||||
|
class ErrorController(BaseController):
|
||||||
"""Generates error documents as and when they are required.
|
"""Generates error documents as and when they are required.
|
||||||
|
|
||||||
The ErrorDocuments middleware forwards to ErrorController when error
|
The ErrorDocuments middleware forwards to ErrorController when error
|
||||||
|
@ -39,16 +39,17 @@ class ErrorController(BaseController):
|
||||||
|
|
||||||
This behaviour can be altered by changing the parameters to the
|
This behaviour can be altered by changing the parameters to the
|
||||||
ErrorDocuments middleware in your config/middleware.py file.
|
ErrorDocuments middleware in your config/middleware.py file.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def document(self):
|
def document(self):
|
||||||
"""Render the error document"""
|
"""Render the error document"""
|
||||||
resp = request.environ.get('pylons.original_response')
|
resp = request.environ.get('pylons.original_response')
|
||||||
content = literal(resp.body) or cgi.escape(request.GET.get('message', ''))
|
content = literal(resp.body) or cgi.escape(
|
||||||
|
request.GET.get('message', ''))
|
||||||
page = error_document_template % \
|
page = error_document_template % \
|
||||||
dict(prefix=request.environ.get('SCRIPT_NAME', ''),
|
dict(prefix=request.environ.get('SCRIPT_NAME', ''),
|
||||||
code=cgi.escape(request.GET.get('code', str(resp.status_int))),
|
code=cgi.escape(
|
||||||
|
request.GET.get('code', str(resp.status_int))),
|
||||||
message=content)
|
message=content)
|
||||||
return page
|
return page
|
||||||
|
|
||||||
|
@ -61,8 +62,9 @@ class ErrorController(BaseController):
|
||||||
return self._serve_file('/'.join(['media/style', id]))
|
return self._serve_file('/'.join(['media/style', id]))
|
||||||
|
|
||||||
def _serve_file(self, path):
|
def _serve_file(self, path):
|
||||||
"""Call Paste's FileApp (a WSGI application) to serve the file
|
"""
|
||||||
at the specified path
|
Call Paste's FileApp (a WSGI application) to serve the file at
|
||||||
|
the specified path
|
||||||
"""
|
"""
|
||||||
request.environ['PATH_INFO'] = '/%s' % path
|
request.environ['PATH_INFO'] = '/%s' % path
|
||||||
return forward(PkgResourcesParser('pylons', 'pylons'))
|
return forward(PkgResourcesParser('pylons', 'pylons'))
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service ShowformscriptController.
|
# DDPortfolio service ShowformscriptController.
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -34,6 +34,7 @@ from ddportfolioservice.model import dddatabuilder
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class ShowformscriptsController(BaseController):
|
class ShowformscriptsController(BaseController):
|
||||||
"""This controller is used to support data entry in showform.
|
"""This controller is used to support data entry in showform.
|
||||||
|
|
||||||
|
@ -41,12 +42,17 @@ class ShowformscriptsController(BaseController):
|
||||||
responses for autocompletion of fields."""
|
responses for autocompletion of fields."""
|
||||||
|
|
||||||
def index(self):
|
def index(self):
|
||||||
"""This action generates the helper script for the showform
|
"""
|
||||||
page."""
|
This action generates the helper script for the showform page.
|
||||||
|
"""
|
||||||
response.headers['Content-Type'] = 'text/javascript; charset=utf-8'
|
response.headers['Content-Type'] = 'text/javascript; charset=utf-8'
|
||||||
return render('/showformscript.mako')
|
return render('/showformscript.mako')
|
||||||
|
|
||||||
def fetchdddata(self):
|
def fetchdddata(self):
|
||||||
|
"""
|
||||||
|
This action fetches the data for a given mail address and
|
||||||
|
returns them as JSON.
|
||||||
|
"""
|
||||||
schema = DDDataRequest()
|
schema = DDDataRequest()
|
||||||
try:
|
try:
|
||||||
formencode.api.set_stdtranslation(
|
formencode.api.set_stdtranslation(
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service TemplateController
|
# DDPortfolio service TemplateController
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -22,6 +22,7 @@
|
||||||
#
|
#
|
||||||
from ddportfolioservice.lib.base import BaseController
|
from ddportfolioservice.lib.base import BaseController
|
||||||
|
|
||||||
|
|
||||||
class TemplateController(BaseController):
|
class TemplateController(BaseController):
|
||||||
|
|
||||||
def view(self, url):
|
def view(self, url):
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service application Globals
|
# DDPortfolio service application Globals
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -25,17 +25,17 @@
|
||||||
from beaker.cache import CacheManager
|
from beaker.cache import CacheManager
|
||||||
from beaker.util import parse_cache_config_options
|
from beaker.util import parse_cache_config_options
|
||||||
|
|
||||||
|
|
||||||
class Globals(object):
|
class Globals(object):
|
||||||
|
"""
|
||||||
"""Globals acts as a container for objects available throughout the
|
Globals acts as a container for objects available throughout the
|
||||||
life of the application
|
life of the application
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, config):
|
def __init__(self, config):
|
||||||
"""One instance of Globals is created during application
|
"""
|
||||||
|
One instance of Globals is created during application
|
||||||
initialization and is available during requests via the
|
initialization and is available during requests via the
|
||||||
'app_globals' variable
|
'app_globals' variable
|
||||||
|
|
||||||
"""
|
"""
|
||||||
self.cache = CacheManager(**parse_cache_config_options(config))
|
self.cache = CacheManager(**parse_cache_config_options(config))
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service base controller
|
# DDPortfolio service base controller
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -29,6 +29,7 @@ from pylons.controllers import WSGIController
|
||||||
from pylons.i18n import add_fallback
|
from pylons.i18n import add_fallback
|
||||||
from pylons.templating import render_mako as render
|
from pylons.templating import render_mako as render
|
||||||
|
|
||||||
|
|
||||||
class BaseController(WSGIController):
|
class BaseController(WSGIController):
|
||||||
|
|
||||||
def __call__(self, environ, start_response):
|
def __call__(self, environ, start_response):
|
||||||
|
@ -42,5 +43,5 @@ class BaseController(WSGIController):
|
||||||
add_fallback(lang)
|
add_fallback(lang)
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
c.messages = { 'errors': [], 'messages': [] }
|
c.messages = {'errors': [], 'messages': []}
|
||||||
return WSGIController.__call__(self, environ, start_response)
|
return WSGIController.__call__(self, environ, start_response)
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service form handling model
|
# DDPortfolio service form handling model
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -22,6 +22,7 @@
|
||||||
#
|
#
|
||||||
import formencode
|
import formencode
|
||||||
|
|
||||||
|
|
||||||
class DeveloperData(formencode.Schema):
|
class DeveloperData(formencode.Schema):
|
||||||
"""Validation schema for DeveloperData."""
|
"""Validation schema for DeveloperData."""
|
||||||
allow_extra_fields = True
|
allow_extra_fields = True
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service key finder module
|
# DDPortfolio service key finder module
|
||||||
# Copyright (c) 2009 Jan Dittberner <jan@dittberner.info>
|
# Copyright (c) 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -30,6 +30,7 @@ import time
|
||||||
db = None
|
db = None
|
||||||
cachetimestamp = 0
|
cachetimestamp = 0
|
||||||
|
|
||||||
|
|
||||||
def _get_keyring_cache():
|
def _get_keyring_cache():
|
||||||
global db, cachetimestamp
|
global db, cachetimestamp
|
||||||
if db is None or (time.time() - cachetimestamp) > 86300:
|
if db is None or (time.time() - cachetimestamp) > 86300:
|
||||||
|
@ -44,6 +45,7 @@ def _get_keyring_cache():
|
||||||
cachetimestamp = time.time()
|
cachetimestamp = time.time()
|
||||||
return db
|
return db
|
||||||
|
|
||||||
|
|
||||||
def _get_cached(cachekey):
|
def _get_cached(cachekey):
|
||||||
cache = _get_keyring_cache()
|
cache = _get_keyring_cache()
|
||||||
logging.debug('cache lookup for %s', cachekey)
|
logging.debug('cache lookup for %s', cachekey)
|
||||||
|
@ -52,25 +54,33 @@ def _get_cached(cachekey):
|
||||||
return cache[cachekey]
|
return cache[cachekey]
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
def getFingerprintByEmail(email):
|
def getFingerprintByEmail(email):
|
||||||
"""Gets the fingerprints associated with the given email address
|
"""
|
||||||
if available."""
|
Gets the fingerprints associated with the given email address if
|
||||||
|
available.
|
||||||
|
"""
|
||||||
return _get_cached('fpr:email:%s' % email)
|
return _get_cached('fpr:email:%s' % email)
|
||||||
|
|
||||||
|
|
||||||
def getRealnameByEmail(email):
|
def getRealnameByEmail(email):
|
||||||
"""Gets the real names associated with the given email address if
|
"""
|
||||||
available."""
|
Gets the real names associated with the given email address if
|
||||||
|
available.
|
||||||
|
"""
|
||||||
return _get_cached('name:email:%s' % email)
|
return _get_cached('name:email:%s' % email)
|
||||||
|
|
||||||
|
|
||||||
def getLoginByEmail(email):
|
def getLoginByEmail(email):
|
||||||
"""Gets the logins associated with the given email address if
|
"""
|
||||||
available."""
|
Gets the logins associated with the given email address if
|
||||||
|
available.
|
||||||
|
"""
|
||||||
return _get_cached('login:email:%s' % email)
|
return _get_cached('login:email:%s' % email)
|
||||||
|
|
||||||
|
|
||||||
def getLoginByFingerprint(fpr):
|
def getLoginByFingerprint(fpr):
|
||||||
"""Gets the login associated with the given fingerprint if
|
"""
|
||||||
available."""
|
Gets the login associated with the given fingerprint if available.
|
||||||
|
"""
|
||||||
return _get_cached('login:fpr:%s' % fpr)
|
return _get_cached('login:fpr:%s' % fpr)
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service application key ring analyzer tool
|
# DDPortfolio service application key ring analyzer tool
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -38,10 +38,13 @@ import sys
|
||||||
|
|
||||||
|
|
||||||
def _get_keyrings():
|
def _get_keyrings():
|
||||||
"""Gets the available keyring files from the keyring directory
|
"""
|
||||||
configured in ddportfolio.ini."""
|
Gets the available keyring files from the keyring directory
|
||||||
|
configured in ddportfolio.ini.
|
||||||
|
"""
|
||||||
my_config = ConfigParser.ConfigParser()
|
my_config = ConfigParser.ConfigParser()
|
||||||
my_config.readfp(pkg_resources.resource_stream(__name__, 'ddportfolio.ini'))
|
my_config.readfp(pkg_resources.resource_stream(
|
||||||
|
__name__, 'ddportfolio.ini'))
|
||||||
keyringdir = os.path.expanduser(my_config.get('DEFAULT', 'keyring.dir'))
|
keyringdir = os.path.expanduser(my_config.get('DEFAULT', 'keyring.dir'))
|
||||||
logging.debug("keyring dir is %s", keyringdir)
|
logging.debug("keyring dir is %s", keyringdir)
|
||||||
keyrings = glob.glob(os.path.join(keyringdir, '*.gpg'))
|
keyrings = glob.glob(os.path.join(keyringdir, '*.gpg'))
|
||||||
|
@ -51,20 +54,22 @@ def _get_keyrings():
|
||||||
|
|
||||||
|
|
||||||
def _parse_uid(uid):
|
def _parse_uid(uid):
|
||||||
"""Parse a uid of the form 'Real Name <email@example.com>' into
|
"""
|
||||||
email and realname parts."""
|
Parse a uid of the form 'Real Name <email@example.com>' into email
|
||||||
|
and realname parts.
|
||||||
|
"""
|
||||||
uid = uid.strip()
|
uid = uid.strip()
|
||||||
# First, strip comment
|
# First, strip comment
|
||||||
s = uid.find('(')
|
s = uid.find('(')
|
||||||
e = uid.find(')')
|
e = uid.find(')')
|
||||||
if s >= 0 and e >= 0:
|
if s >= 0 and e >= 0:
|
||||||
uid = uid[:s] + uid[e+1:]
|
uid = uid[:s] + uid[e + 1:]
|
||||||
s = uid.find('<')
|
s = uid.find('<')
|
||||||
e = uid.find('>')
|
e = uid.find('>')
|
||||||
email = None
|
email = None
|
||||||
if s >= 0 and e >= 0:
|
if s >= 0 and e >= 0:
|
||||||
email = uid[s+1:e]
|
email = uid[s + 1:e]
|
||||||
uid = uid[:s] + uid[e+1:]
|
uid = uid[:s] + uid[e + 1:]
|
||||||
uid = uid.strip()
|
uid = uid.strip()
|
||||||
if not email and uid.find('@') >= 0:
|
if not email and uid.find('@') >= 0:
|
||||||
email, uid = uid, email
|
email, uid = uid, email
|
||||||
|
@ -72,6 +77,7 @@ def _parse_uid(uid):
|
||||||
|
|
||||||
resultdict = {}
|
resultdict = {}
|
||||||
|
|
||||||
|
|
||||||
def _get_canonical(key):
|
def _get_canonical(key):
|
||||||
if not key in resultdict:
|
if not key in resultdict:
|
||||||
resultdict[key] = []
|
resultdict[key] = []
|
||||||
|
@ -96,7 +102,7 @@ def process_keyrings():
|
||||||
stdout=subprocess.PIPE)
|
stdout=subprocess.PIPE)
|
||||||
fpr = None
|
fpr = None
|
||||||
entry = None
|
entry = None
|
||||||
lastpub = None
|
lastpub = None
|
||||||
for line in proc.stdout.readlines():
|
for line in proc.stdout.readlines():
|
||||||
items = line.split(':')
|
items = line.split(':')
|
||||||
uid = None
|
uid = None
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf8 -*-
|
# -*- coding: utf8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service url builder
|
# DDPortfolio service url builder
|
||||||
# Copyright © 2009, 2010, 2012 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -37,12 +37,12 @@ my_config = ConfigParser()
|
||||||
my_config.readfp(pkg_resources.resource_stream(__name__, 'ddportfolio.ini'))
|
my_config.readfp(pkg_resources.resource_stream(__name__, 'ddportfolio.ini'))
|
||||||
|
|
||||||
_FIELDNAMES_MAP = {
|
_FIELDNAMES_MAP = {
|
||||||
'email' : N_('Email address'),
|
'email': N_('Email address'),
|
||||||
'name' : N_('Name'),
|
'name': N_('Name'),
|
||||||
'gpgfp' : N_('GPG fingerprint'),
|
'gpgfp': N_('GPG fingerprint'),
|
||||||
'username' : N_('Debian user name'),
|
'username': N_('Debian user name'),
|
||||||
'nonddemail' : N_('Non Debian email address'),
|
'nonddemail': N_('Non Debian email address'),
|
||||||
'aliothusername' : N_('Alioth user name'),
|
'aliothusername': N_('Alioth user name'),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -82,8 +82,9 @@ def build_urls(fields):
|
||||||
'urlbuilder.sections').split(',')]:
|
'urlbuilder.sections').split(',')]:
|
||||||
data.append(['section', section])
|
data.append(['section', section])
|
||||||
if my_config.has_option(section, 'urls'):
|
if my_config.has_option(section, 'urls'):
|
||||||
for entry in ([DDPortfolioEntry(my_config, section, url) for url in \
|
for entry in ([
|
||||||
my_config.get(section, 'urls').split(',')]):
|
DDPortfolioEntry(my_config, section, url) for url in \
|
||||||
|
my_config.get(section, 'urls').split(',')]):
|
||||||
try:
|
try:
|
||||||
data.append(
|
data.append(
|
||||||
['url', section, entry,
|
['url', section, entry,
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service tests package
|
# DDPortfolio service tests package
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -49,6 +49,7 @@ SetupCommand('setup-app').run([pylons.test.pylonsapp.config['__file__']])
|
||||||
|
|
||||||
environ = {}
|
environ = {}
|
||||||
|
|
||||||
|
|
||||||
class TestController(TestCase):
|
class TestController(TestCase):
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service DdportfolioController test
|
# DDPortfolio service DdportfolioController test
|
||||||
# Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info>
|
# Copyright © 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -22,8 +22,10 @@
|
||||||
#
|
#
|
||||||
from ddportfolioservice.tests import TestController, url
|
from ddportfolioservice.tests import TestController, url
|
||||||
|
|
||||||
|
|
||||||
class TestShowformscriptsController(TestController):
|
class TestShowformscriptsController(TestController):
|
||||||
|
|
||||||
def test_index(self):
|
def test_index(self):
|
||||||
response = self.app.get(url(controller='showformscripts', action='index'))
|
response = self.app.get(
|
||||||
|
url(controller='showformscripts', action='index'))
|
||||||
# Test response...
|
# Test response...
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# DDPortfolio service websetup
|
# DDPortfolio service websetup
|
||||||
# Copyright (c) 2009 Jan Dittberner <jan@dittberner.info>
|
# Copyright (c) 2009, 2010, 2011, 2012 Jan Dittberner <jan@dittberner.info>
|
||||||
#
|
#
|
||||||
# This file is part of DDPortfolio service.
|
# This file is part of DDPortfolio service.
|
||||||
#
|
#
|
||||||
|
@ -31,6 +31,7 @@ from ddportfolioservice.config.environment import load_environment
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
def setup_config(command, filename, section, vars):
|
def setup_config(command, filename, section, vars):
|
||||||
"""Place any commands to setup ddportfolioservice here"""
|
"""Place any commands to setup ddportfolioservice here"""
|
||||||
conf = appconfig('config:' + filename)
|
conf = appconfig('config:' + filename)
|
||||||
|
|
Loading…
Reference in a new issue