diff --git a/CHANGELOG.md b/CHANGELOG.md index 76713dc7..2c5122d5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,7 @@ All notable changes to this project will be documented in this file. ### Bug Fixes - Fix badges for tags containing special characters (#240, #237) - Fix the "Integrations" page for when the user has no active project +- Prevent email clients from opening the one-time login links (#255) ## 1.7.0 - 2019-05-02 diff --git a/hc/accounts/views.py b/hc/accounts/views.py index 0b037197..f434b5cb 100644 --- a/hc/accounts/views.py +++ b/hc/accounts/views.py @@ -119,7 +119,12 @@ def login(request): profile = Profile.objects.for_user(magic_form.user) profile.send_instant_login_link(redirect_url=redirect_url) - return redirect("hc-login-link-sent") + response = redirect("hc-login-link-sent") + + # check_token_submit looks for this cookie to decide if + # it needs to do the extra POST step. + response.set_cookie("auto-login", "1", max_age=300, httponly=True) + return response bad_link = request.session.pop("bad_link", None) ctx = { @@ -169,12 +174,13 @@ def check_token(request, username, token): return _redirect_after_login(request) # Some email servers open links in emails to check for malicious content. - # To work around this, we sign user in if the method is POST. + # To work around this, we sign user in if the method is POST + # *or* if the browser presents a cookie we had set when sending the login link. # # If the method is GET, we instead serve a HTML form and a piece # of Javascript to automatically submit it. - if request.method == "POST": + if request.method == "POST" or "auto-login" in request.COOKIES: user = authenticate(username=username, token=token) if user is not None and user.is_active: user.profile.token = "" diff --git a/templates/accounts/check_token_submit.html b/templates/accounts/check_token_submit.html index 60615075..3631025e 100644 --- a/templates/accounts/check_token_submit.html +++ b/templates/accounts/check_token_submit.html @@ -8,9 +8,6 @@
- - - - +You are about to log into {% site_name %}.
+Please press the button below to continue:
+