/usr/share/pyshared/repoze/who/config.py is in python-repoze.who 1.0.18-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 | """ Configuration parser
"""
from ConfigParser import ConfigParser
from StringIO import StringIO
import logging
from pkg_resources import EntryPoint
import sys
from repoze.who.interfaces import IAuthenticator
from repoze.who.interfaces import IChallengeDecider
from repoze.who.interfaces import IChallenger
from repoze.who.interfaces import IIdentifier
from repoze.who.interfaces import IMetadataProvider
from repoze.who.interfaces import IPlugin
from repoze.who.interfaces import IRequestClassifier
from repoze.who.middleware import PluggableAuthenticationMiddleware
def _resolve(name):
if name:
return EntryPoint.parse('x=%s' % name).load(False)
class WhoConfig:
def __init__(self, here):
self.here = here
self.request_classifier = None
self.challenge_decider = None
self.plugins = {}
self.identifiers = []
self.authenticators = []
self.challengers = []
self.mdproviders = []
self.remote_user_key = 'REMOTE_USER'
def _makePlugin(self, name, iface, options=None):
if options is None:
options = {}
obj = _resolve(name)
if not iface.providedBy(obj):
obj = obj(**options)
return obj
def _getPlugin(self, name, iface):
obj = self.plugins.get(name)
if obj is None:
obj = self._makePlugin(name, iface)
return obj
def _parsePluginSequence(self, attr, proptext, iface):
lines = proptext.split()
for line in lines:
if ';' in line:
plugin_name, classifier = line.split(';')
else:
plugin_name = line
classifier = None
plugin = self._getPlugin(plugin_name, iface)
if classifier is not None:
classifications = getattr(plugin, 'classifications', None)
if classifications is None:
classifications = plugin.classifications = {}
classifications[iface] = classifier
attr.append((plugin_name, plugin))
def parse(self, text):
if getattr(text, 'readline', None) is None:
text = StringIO(text)
cp = ConfigParser(defaults={'here': self.here})
cp.readfp(text)
for s_id in [x for x in cp.sections() if x.startswith('plugin:')]:
plugin_id = s_id[len('plugin:'):]
options = dict(cp.items(s_id))
if 'use' in options:
name = options.pop('use')
del options['here']
obj = self._makePlugin(name, IPlugin, options)
self.plugins[plugin_id] = obj
if 'general' in cp.sections():
general = dict(cp.items('general'))
rc = general.get('request_classifier')
if rc is not None:
rc = self._getPlugin(rc, IRequestClassifier)
self.request_classifier = rc
cd = general.get('challenge_decider')
if cd is not None:
cd = self._getPlugin(cd, IChallengeDecider)
self.challenge_decider = cd
ru = general.get('remote_user_key')
if ru is not None:
self.remote_user_key = ru
if 'identifiers' in cp.sections():
identifiers = dict(cp.items('identifiers'))
self._parsePluginSequence(self.identifiers,
identifiers['plugins'],
IIdentifier,
)
if 'authenticators' in cp.sections():
authenticators = dict(cp.items('authenticators'))
self._parsePluginSequence(self.authenticators,
authenticators['plugins'],
IAuthenticator,
)
if 'challengers' in cp.sections():
challengers = dict(cp.items('challengers'))
self._parsePluginSequence(self.challengers,
challengers['plugins'],
IChallenger,
)
if 'mdproviders' in cp.sections():
mdproviders = dict(cp.items('mdproviders'))
self._parsePluginSequence(self.mdproviders,
mdproviders['plugins'],
IMetadataProvider,
)
_LEVELS = {'debug': logging.DEBUG,
'info': logging.INFO,
'warning': logging.WARNING,
'error': logging.ERROR,
}
def make_middleware_with_config(app, global_conf, config_file,
log_file=None, log_level=None):
parser = WhoConfig(global_conf['here'])
parser.parse(open(config_file))
log_stream = None
if log_file is not None:
if log_file.lower() == 'stdout':
log_stream = sys.stdout
else:
log_stream = open(log_file, 'wb')
if log_level is None:
log_level = logging.INFO
else:
log_level = _LEVELS[log_level.lower()]
return PluggableAuthenticationMiddleware(
app,
parser.identifiers,
parser.authenticators,
parser.challengers,
parser.mdproviders,
parser.request_classifier,
parser.challenge_decider,
log_stream,
log_level,
parser.remote_user_key,
)
|