Estou tentando usar um CAS externo para autenticar usuários.
Eu uso isso para fazer a tarefa:
auth = Auth(db, cas_provider = 'https://some_url')
E ao acessar o URL http://127.0.0.1:8000/app/default/user/login
Eu recebo o seguinte erro:
web2py™ Version 2.9.11-stable+timestamp.2014.09.15.23.35.11
Traceback
Traceback (most recent call last):
File "web2py/gluon/restricted.py", line 224, in restricted
exec ccode in environment
File "web2py/applications/webuser/controllers/default.py", line 101, in <module>
File "/web2py/gluon/globals.py", line 392, in <lambda>
self._caller = lambda f: f()
File "web2py/applications/webuser/controllers/default.py", line 63, in user
form = auth()
File "web2py/gluon/tools.py", line 1437, in __call__
return getattr(self, args[0])()
File "gluon/tools.py", line 2511, in login
cas_user = cas.get_user()
File "gluon/contrib/login_methods/cas_auth.py", line 80, in get_user
d[key] = self.maps[key](user)
File "gluon/tools.py", line 1984, in <lambda>
maps = dict((name, lambda v, n=name: v.get(n, None)) for name in
AttributeError: 'str' object has no attribute 'get'
Eu gostaria que o usuário fosse redirecionado para o URL "cas_provider" para autorizar o usuário e, em seguida, voltar para o aplicativo ...
Qualquer ajuda seria abençoada, mesmo que seja um django ou qualquer solução de fraturamento da web, que possa ajudar a descobrir isso ...
ps: Eu poderia autenticar clientes com sucesso usando um servidor externo Ldap editando o auth.login_method
, mas estou realmente preso ao redirecionamento de autenticação cas ...
Tags authentication cas