48
I also was having this problem, and found this github issue it said we need to add
url(r'^', include('django.contrib.auth.urls')),
on the urlpatterns.
As stated there it says that The PasswordReset view depends on django.contrib.auth.views.password_reset_confirm
view.
20
As Roar Skullestad pointed out, the problem is with the default email template, which tries to resolve URL by reversing viewname “password_reset_confirm”, which is undefined.
It is enough to register a viewname “password_reset_confirm” with a custom route and then default email template rendering will work fine.
You can register viewname with custom route by adding a path to urls.py:
urlpatterns = [
...,
path('password-reset/<uidb64>/<token>/', empty_view, name='password_reset_confirm'),
]
password-reset – custom route that password reset confirmation view. If you have SPA (Angular) – it will be the URL of your SPA view (such as the route to Angular component) that will handle the password reset.
This is the URL that will be resolved and embedded in the email. For this example it will be something like:
http://my-spa.com/app-name/password-reset/Nw/51v-490d4b372ec930e49049/
empty_view – in case of SPA (Angular), you don’t really need server-side implementation, because the front end will actually handle this route. I used this implementation of a view, but it can be anything else:
from django.http import HttpResponse
def empty_view(request):
return HttpResponse('')
And since I’m using Angular, this is the route for my Angular component:
{
path: 'password-reset/:uid/:token',
component: PasswordRecoveryComponent
}
- [Django]-Django – why is the request.POST object immutable?
- [Django]-Django – Create A Zip of Multiple Files and Make It Downloadable
- [Django]-Django IntegerField with Choice Options (how to create 0-10 integer options)
6
For me the problem was this line in site-packages/django/contrib/admin/templates/registration/password_reset_email.html:
{{ protocol }}://{{ domain }}{% url 'password_reset_confirm' uidb64=uid token=token %}
From what I understand the problem is caused by reverse lookup not working for this line in contrib/auth/urls.py:
url(r'^reset/(?P<uidb64>[0-9A-Za-z_\-]+)/(?P<token>[0-9A-Za-z]{1,13}-[0-9A-Za-z]{1,20})/$',
'django.contrib.auth.views.password_reset_confirm',
name='password_reset_confirm'),
My (at least temporarily) solution was to override the template and hardcode the reverse lookup part of the url for the link in the email.
The path to the new template is specified in settings.py:
TEMPLATE_DIRS =(
"/absolute/path/to/my/templates/directory",
)
Since I am using angular front end, I also changed the link so that it triggers password reset confirmation via the angular client:
{{ protocol }}://{{ domain }}/#/passwordResetConfirm/{{ uid }}/{{ token }}
- [Django]-Empty Label ChoiceField Django
- [Django]-Django rest framework override page_size in ViewSet
- [Django]-When should I use a custom Manager versus a custom QuerySet in Django?
3
@AbimaelCarrasquillo’s solutions works but you probably do not want to expose those endpoints as @dpstart mentioned in the comments.
I solved this by overriding the PasswordResetSerializer of rest-auth
and simply replacing the reset form:
password_reset_form_class = PasswordResetForm
from the internal django.contrib.auth.forms.PasswordResetForm
to allauth.account.forms.ResetPasswordForm
Make sure to add the following to your settings:
REST_AUTH_SERIALIZERS = {
'PASSWORD_RESET_SERIALIZER':'path.to.PasswordResetSerializer'
}
- [Django]-How can I handle Exceptions raised by dango-social-auth?
- [Django]-What is the best approach to change primary keys in an existing Django app?
- [Django]-Django "get() got an unexpected keyword argument 'pk'" error
1
For those who are still struggling with this issue, I found that the reverse look up internal view looks for reverse lookup within the core project urls and not within any application. It could work within application with some tweak, but I am not sure. But it works creating the reset urls directly on core project urls.py
{
path(r'password_reset/', PasswordResetView.as_view(template_name='password_reset_form.html'), name='password_reset'),
path(r'password_reset_done/', PasswordResetDoneView.as_view(template_name='password_reset_done.html'), name='password_reset_done'),
path(r'password_reset_confirm/<uidb64>/<token>/', PasswordResetConfirmView.as_view(template_name='password_reset_confirm.html'), name='password_reset_confirm'),
path(r'password_reset_complete/', PasswordResetCompleteView.as_view(template_name='password_reset_complete.html'), name='password_reset_complete'),
}
- [Django]-How can I display a Django admin inline model within a fieldset?
- [Django]-How to express a One-To-Many relationship in Django?
- [Django]-Saving image/file through django shell
1
Well I was also facing this problem. Every time I entered my email and pressed the button it took me to NoReverseMatch url, and I am using:
re_path(r'^password-reset/confirm/(?P<uidb64>[0-9A-Za-z_\-]+)/(?P<token>[0-9A-Za-z]{1,13}-[0-9A-Za-z]{1,20})/$',
TemplateView.as_view(template_name="password_reset_confirm.html"),name='password_reset_confirm')
(url is not used to match regex in django anymore re_path is used)
My solution is to change the regex a little bit because the "csrf token" is longer than 20 words – that’s why I was getting an error and you should try the same.
re_path(r'^password-reset/confirm/(?P<uidb64>[0-9A-Za-z_\-]+)/(?P<token>[0-9A-Za-z]{1,13}-[0-9A-Za-z]{1,40})/$',
TemplateView.as_view(template_name="password_reset_confirm.html"),
name='password_reset_confirm')
You can either use +
(in regex it means one or more) or {1,40}
(in regex it means match from 1 to 40)
- [Django]-Celery missed heartbeat (on_node_lost)
- [Django]-'function' object has no attribute 'as_view'
- [Django]-How do I use Django's logger to log a traceback when I tell it to?
0
Add this to your project url.py file
url(r'^o/', include('oauth2_provider.urls', namespace='oauth2_provider')),
url('', include('social.apps.django_app.urls', namespace='social')),
- [Django]-Django {{ MEDIA_URL }} blank @DEPRECATED
- [Django]-Where is a good place to work on accounts/profile in Django with the Django registration app?
- [Django]-Unable to connect to server: PgAdmin 4
0
Check out the FAQ: It explains this error and how to fix it. It references you to the demo program which contains:
# this url is used to generate email content
url(r'^password-reset/confirm/(?P<uidb64>[0-9A-Za-z_\-]+)/(?P<token>[0-9A-Za-z]{1,13}-[0-9A-Za-z]{1,20})/$',
TemplateView.as_view(template_name="password_reset_confirm.html"),
name='password_reset_confirm'),
- [Django]-Adding links to full change forms for inline items in django admin?
- [Django]-How to create table during Django tests with managed = False
- [Django]-Django-rest-framework accept JSON data?
0
My solution was to override the email template that calls the reverse of “password_reset_confirm”. Make sure email template sends a URL to your frontend app with the UID and Token in the URL (instead of trying to reverse “password_reset_confirm”).
Your frontend’s route should take the URL, parse it and then with the updated user’s password and send it back as an API call to your backend to confirm.
- [Django]-Django form resubmitted upon refresh
- [Django]-Django template filters, tags, simple_tags, and inclusion_tags
- [Django]-Microsoft Visual C++ 14.0 is required. Get it with "Microsoft Visual C++ Build Tools": http://landinghub.visualstudio.com/visual-cpp-build-tools
0
I resolved this issue by moving these:
path('reset_password/', auth_views.PasswordResetView.as_view(), name='password_reset'),
path('reset/<uidb64>/<token>/', auth_views.PasswordResetConfirmView.as_view(), name='password_reset_confirm'),
path('reset_password_sent/', auth_views.PasswordResetDoneView.as_view(), name='password_reset_done'),
path('reset_password_complete/', auth_views.PasswordResetCompleteView.as_view(), name='password_reset_complete'),
from accounts/urls.py to yourProjectName/urls.py.
I guess that path('', include("accounts.urls")),
was causing the problem.
- [Django]-Auto-reloading of code changes with Django development in Docker with Gunicorn
- [Django]-Add a custom button to a Django application's admin page
- [Django]-Difference between values() and only()
0
I have a headless backend, so adding or renaming URLs only for this was not a good option.
The issue is on the email template, you can override it. Just take care that you have the correct path on the settings.
In my case I have all this logic inside users app. So I have something like this.
users/templates/registration/password_reset_email.html
Inside this template I have a new custom message without the reverse URL call.
If you need more than just override the template, or maybe you need to send additional data to the template. You must override the serializer also. To do that you have to create your new serializer
from dj_rest_auth.serializers import PasswordResetSerializer as RestPasswordResetSerializer
class PasswordResetSerializer(RestPasswordResetSerializer):
def get_email_options(self):
return {
'html_email_template_name': 'registration/password_reset_email_html.html', # if you want to use an HTML template you can declare here
'extra_email_context': {'custom_key': 'custom value for my template',}
}
and add to settings.
REST_AUTH_SERIALIZERS = {
'PASSWORD_RESET_SERIALIZER':'path.to.PasswordResetSerializer'
}
On the serializer you can add custom validation if needed also.
- [Django]-Is it OK to use multiple inheritance with Django abstract models?
- [Django]-Access django models inside of Scrapy
- [Django]-"Fixed default value provided" after upgrading to Django 1.8
0
In your views.py, if you have set a token, pass it along with the path similar to:
path('resetpassword_validate/<uidb64>/<token>/', views.resetpassword_validate, name='resetpassword_validate'),
- [Django]-Django: Adding "NULLS LAST" to query
- [Django]-Django – Getting last object created, simultaneous filters
- [Django]-How do you log server errors on django sites