2014-04-28 14:33:04 +02:00
|
|
|
import sys
|
|
|
|
|
2016-02-12 17:22:48 +01:00
|
|
|
|
2014-04-28 14:33:04 +02:00
|
|
|
class AppSettings(object):
|
|
|
|
__PREFIX = 'MELLON_'
|
|
|
|
__DEFAULTS = {
|
2016-02-26 13:28:49 +01:00
|
|
|
'DISCOVERY_SERVICE_URL': None,
|
2016-02-12 17:22:48 +01:00
|
|
|
'PUBLIC_KEYS': (),
|
|
|
|
'PRIVATE_KEY': None,
|
|
|
|
'PRIVATE_KEYS': (),
|
|
|
|
'PRIVATE_KEY_PASSWORD': None,
|
|
|
|
'NAME_ID_FORMATS': (),
|
|
|
|
'NAME_ID_POLICY_FORMAT': None,
|
|
|
|
'NAME_ID_POLICY_ALLOW_CREATE': True,
|
|
|
|
'FORCE_AUTHN': False,
|
|
|
|
'ADAPTER': (
|
|
|
|
'mellon.adapters.DefaultAdapter',
|
|
|
|
),
|
|
|
|
'REALM': 'saml',
|
|
|
|
'PROVISION': True,
|
|
|
|
'USERNAME_TEMPLATE': '{attributes[name_id_content]}@{realm}',
|
|
|
|
'ATTRIBUTE_MAPPING': {},
|
|
|
|
'SUPERUSER_MAPPING': {},
|
|
|
|
'AUTHN_CLASSREF': (),
|
|
|
|
'GROUP_ATTRIBUTE': None,
|
|
|
|
'CREATE_GROUP': True,
|
|
|
|
'ERROR_URL': None,
|
|
|
|
'ERROR_REDIRECT_AFTER_TIMEOUT': 120,
|
|
|
|
'DEFAULT_ASSERTION_CONSUMER_BINDING': 'post', # or artifact
|
|
|
|
'VERIFY_SSL_CERTIFICATE': True,
|
|
|
|
'OPENED_SESSION_COOKIE_NAME': None,
|
|
|
|
'OPENED_SESSION_COOKIE_DOMAIN': None,
|
2016-02-26 13:15:42 +01:00
|
|
|
'ORGANIZATION': None,
|
|
|
|
'CONTACT_PERSONS': [],
|
2016-04-11 19:20:05 +02:00
|
|
|
'TRANSIENT_FEDERATION_ATTRIBUTE': None,
|
2016-05-10 09:07:02 +02:00
|
|
|
'LOGIN_URL': 'mellon_login',
|
|
|
|
'LOGOUT_URL': 'mellon_logout',
|
2017-08-22 15:30:09 +02:00
|
|
|
'ARTIFACT_RESOLVE_TIMEOUT': 10.0,
|
2014-04-28 14:33:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@property
|
|
|
|
def IDENTITY_PROVIDERS(self):
|
|
|
|
from django.conf import settings
|
|
|
|
try:
|
2018-01-09 21:43:25 +01:00
|
|
|
idps = settings.MELLON_IDENTITY_PROVIDERS
|
2014-04-28 14:33:04 +02:00
|
|
|
except AttributeError:
|
2016-02-26 13:18:36 +01:00
|
|
|
from django.core.exceptions import ImproperlyConfigured
|
2018-01-09 21:43:25 +01:00
|
|
|
raise ImproperlyConfigured('The MELLON_IDENTITY_PROVIDERS setting is mandatory')
|
2014-04-28 14:33:04 +02:00
|
|
|
if isinstance(idps, dict):
|
|
|
|
idps = [idps]
|
|
|
|
return idps
|
|
|
|
|
|
|
|
def __getattr__(self, name):
|
|
|
|
from django.conf import settings
|
|
|
|
if name not in self.__DEFAULTS:
|
|
|
|
raise AttributeError
|
|
|
|
return getattr(settings, self.__PREFIX + name, self.__DEFAULTS[name])
|
|
|
|
|
|
|
|
app_settings = AppSettings()
|
|
|
|
app_settings.__name__ = __name__
|
|
|
|
sys.modules[__name__] = app_settings
|