FIX: Do not redirect to `/auth/*` urls after authentication

When using the login confirmation screen, the referrer URL is `/auth/{provider}`. That means that the user is redirected back to the confirmation screen after logging in, even though login was successful. This is very confusing. Instead, they should be redirected to the homepage.
This commit is contained in:
David Taylor 2020-01-08 17:06:03 +00:00
parent e616b92511
commit 5eda44f8f2
2 changed files with 14 additions and 1 deletions

View File

@ -53,7 +53,9 @@ class Users::OmniauthCallbacksController < ApplicationController
rescue URI::Error rescue URI::Error
end end
if parsed && (parsed.host == nil || parsed.host == Discourse.current_hostname) if parsed && # Valid
(parsed.host == nil || parsed.host == Discourse.current_hostname) && # Local
!parsed.path.starts_with?(Discourse.base_uri("/auth/")) # Not /auth URL
@origin = +"#{parsed.path}" @origin = +"#{parsed.path}"
@origin << "?#{parsed.query}" if parsed.query @origin << "?#{parsed.query}" if parsed.query
end end

View File

@ -459,6 +459,17 @@ RSpec.describe Users::OmniauthCallbacksController do
expect(cookie_data["destination_url"]).to eq('/t/123') expect(cookie_data["destination_url"]).to eq('/t/123')
end end
it "never redirects to /auth/ origin" do
post "/auth/google_oauth2?origin=http://test.localhost/auth/google_oauth2"
get "/auth/google_oauth2/callback"
expect(response.status).to eq 302
expect(response.location).to eq "http://test.localhost/"
cookie_data = JSON.parse(response.cookies['authentication_data'])
expect(cookie_data["destination_url"]).to eq('/')
end
it "redirects to relative origin" do it "redirects to relative origin" do
post "/auth/google_oauth2?origin=/t/123" post "/auth/google_oauth2?origin=/t/123"
get "/auth/google_oauth2/callback" get "/auth/google_oauth2/callback"