I want to override login
function in __init__.py
of django.contrib.auth
I did steps:
urls.py
url(r'^login/$', 'my_login'),
views.py
from django.contrib import auth
def login(request, user, backend=None):
# do some stuff
settings.py
INSTALLED_APPS = [
#'django.contrib.auth',
'my_auth_app'
]
But I feel it's the wrong approach.
Actually I want to get default contrib.auth
with overidden login
method
Done this approach.
urls.py
# separate my custom login from django default auth
path('accounts/login/', CustomLoginView.as_view(), name='login'),
path('accounts/', include('django.contrib.auth.urls')),
views.py
def custom_login(request, user, backend=None):
"""
modificated generic.auth login.
Send signal with extra parameter: previous [session_key]
"""
# get previous seesion_key for signal
prev_session_key = request.session.session_key
"""
original code
"""
# send extra argument prev_session_key
user_logged_in.send(sender=user.__class__, request=request, user=user, prev_session_key=prev_session_key)
# custom class-based view overriden on LoginView
class CustomLoginView(LoginView):
def form_valid(self, form):
"""Security check complete. Log the user in."""
# changed default login
custom_login(self.request, form.get_user())
return HttpResponseRedirect(self.get_success_url())
When I make custom_login based on default login(), I am afraid that it is no best approach, because i am copying a part of original code. Maybe it's better to use a decorator here?
Collected from the Internet
Please contact [email protected] to delete if infringement.
Comments