/usr/lib/python3/dist-packages/social/apps/cherrypy_app/utils.py is in python3-social-auth 1:0.2.21+dfsg-1.
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 | import warnings
from functools import wraps
import cherrypy
from social.utils import setting_name, module_member
from social.strategies.utils import get_strategy
from social.backends.utils import get_backend, user_backends_data
DEFAULTS = {
'STRATEGY': 'social.strategies.cherrypy_strategy.CherryPyStrategy',
'STORAGE': 'social.apps.cherrypy_app.models.CherryPyStorage'
}
def get_helper(name):
return cherrypy.config.get(setting_name(name), DEFAULTS.get(name, None))
def load_backend(strategy, name, redirect_uri):
backends = get_helper('AUTHENTICATION_BACKENDS')
Backend = get_backend(backends, name)
return Backend(strategy=strategy, redirect_uri=redirect_uri)
def psa(redirect_uri=None):
def decorator(func):
@wraps(func)
def wrapper(self, backend=None, *args, **kwargs):
uri = redirect_uri
if uri and backend and '%(backend)s' in uri:
uri = uri % {'backend': backend}
self.strategy = get_strategy(get_helper('STRATEGY'),
get_helper('STORAGE'))
self.backend = load_backend(self.strategy, backend, uri)
return func(self, backend, *args, **kwargs)
return wrapper
return decorator
def backends(user):
"""Load Social Auth current user data to context under the key 'backends'.
Will return the output of social.backends.utils.user_backends_data."""
return user_backends_data(user, get_helper('AUTHENTICATION_BACKENDS'),
module_member(get_helper('STORAGE')))
def strategy(*args, **kwargs):
warnings.warn('@strategy decorator is deprecated, use @psa instead')
return psa(*args, **kwargs)
|