forked from shaba/openuds
Fixed login url
This commit is contained in:
parent
ddc2699774
commit
a4353dde86
@ -135,13 +135,13 @@ class GlobalRequestMiddleware:
|
|||||||
request.ip = request.META['REMOTE_ADDR']
|
request.ip = request.META['REMOTE_ADDR']
|
||||||
except Exception:
|
except Exception:
|
||||||
logger.exception('Request ip not found!!')
|
logger.exception('Request ip not found!!')
|
||||||
request.ip = '0.0.0.0' # No remote addr?? set this IP to a "basic" one, anyway, this should never ocur
|
request.ip = '' # No remote addr?? ...
|
||||||
|
|
||||||
try:
|
try:
|
||||||
proxies = request.META['HTTP_X_FORWARDED_FOR'].split(",")
|
proxies = request.META['HTTP_X_FORWARDED_FOR'].split(",")
|
||||||
request.ip_proxy = proxies[0]
|
request.ip_proxy = proxies[0]
|
||||||
|
|
||||||
if request.ip is None or behind_proxy is True: # Request.IP will be None in case of nginx & gunicorn
|
if not request.ip or behind_proxy is True: # Request.IP will be None in case of nginx & gunicorn
|
||||||
request.ip = request.ip_proxy # Stores the ip
|
request.ip = request.ip_proxy # Stores the ip
|
||||||
# will raise "list out of range", leaving ip_proxy = proxy in case of no other proxy apart of nginx
|
# will raise "list out of range", leaving ip_proxy = proxy in case of no other proxy apart of nginx
|
||||||
request.ip_proxy = proxies[1]
|
request.ip_proxy = proxies[1]
|
||||||
|
@ -64,12 +64,12 @@ urlpatterns = [
|
|||||||
|
|
||||||
# Login/logout
|
# Login/logout
|
||||||
path(r'uds/page/login/', uds.web.views.modern.login, name='page.login'),
|
path(r'uds/page/login/', uds.web.views.modern.login, name='page.login'),
|
||||||
re_path(r'^uds/page/login/(?P<tag>[a-zA-Z0-9-])$', uds.web.views.modern.login, name='page.login.tag'),
|
re_path(r'^uds/page/login/(?P<tag>[a-zA-Z0-9-]+)$', uds.web.views.modern.login, name='page.login.tag'),
|
||||||
|
|
||||||
path(r'uds/page/logout/', uds.web.views.modern.logout, name='page.logout'),
|
path(r'uds/page/logout/', uds.web.views.modern.logout, name='page.logout'),
|
||||||
|
|
||||||
# Error URL (just a placeholder, calls index with data on url for angular)
|
# Error URL (just a placeholder, calls index with data on url for angular)
|
||||||
re_path(r'^uds/page/error/(?P<error>[a-zA-Z0-9=-]+)$', uds.web.views.error, name='page.error'),
|
re_path(r'^uds/page/error/(?P<err>[a-zA-Z0-9=-]+)$', uds.web.views.error, name='page.error'),
|
||||||
# Download plugins URL (just a placeholder, calls index with data on url for angular)
|
# Download plugins URL (just a placeholder, calls index with data on url for angular)
|
||||||
path(r'uds/page/client-download', uds.web.views.modern.index, name='page.client-download'),
|
path(r'uds/page/client-download', uds.web.views.modern.index, name='page.client-download'),
|
||||||
|
|
||||||
|
@ -72,6 +72,8 @@ def udsJs(request: 'HttpRequest') -> str:
|
|||||||
if csrf_token is not None:
|
if csrf_token is not None:
|
||||||
csrf_token = str(csrf_token)
|
csrf_token = str(csrf_token)
|
||||||
|
|
||||||
|
tag = request.session.get('tag', None)
|
||||||
|
|
||||||
if GlobalConfig.DISALLOW_GLOBAL_LOGIN.getBool(False) is True:
|
if GlobalConfig.DISALLOW_GLOBAL_LOGIN.getBool(False) is True:
|
||||||
try:
|
try:
|
||||||
authenticators = [Authenticator.objects.get(small_name=auth_host)]
|
authenticators = [Authenticator.objects.get(small_name=auth_host)]
|
||||||
@ -83,6 +85,9 @@ def udsJs(request: 'HttpRequest') -> str:
|
|||||||
else:
|
else:
|
||||||
authenticators = Authenticator.objects.all().exclude(visible=False)
|
authenticators = Authenticator.objects.all().exclude(visible=False)
|
||||||
|
|
||||||
|
if tag:
|
||||||
|
authenticators = [x for x in authenticators if x.small_name == tag]
|
||||||
|
|
||||||
# the auths for client
|
# the auths for client
|
||||||
def getAuthInfo(auth: Authenticator):
|
def getAuthInfo(auth: Authenticator):
|
||||||
theType = auth.getType()
|
theType = auth.getType()
|
||||||
|
@ -76,6 +76,7 @@ def login(request: HttpRequest, tag: typing.Optional[str] = None) -> HttpRespons
|
|||||||
request.session['errors'] = [data]
|
request.session['errors'] = [data]
|
||||||
return index(request)
|
return index(request)
|
||||||
else:
|
else:
|
||||||
|
request.session['tag'] = tag
|
||||||
response = index(request)
|
response = index(request)
|
||||||
|
|
||||||
return response
|
return response
|
||||||
|
Loading…
x
Reference in New Issue
Block a user