From: Tom Hughes Date: Tue, 28 Nov 2023 22:21:50 +0000 (+0000) Subject: Merge remote-tracking branch 'upstream/pull/4329' X-Git-Tag: live~398 X-Git-Url: https://git.openstreetmap.org/rails.git/commitdiff_plain/45f0589e624f111ffe85cf9c17bf43be8b839f2c?hp=64c9ff08e3e06ebaae41ad79f96848bdf08c5f6b Merge remote-tracking branch 'upstream/pull/4329' --- diff --git a/app/controllers/users_controller.rb b/app/controllers/users_controller.rb index 36c9f4e22..f79c284e3 100644 --- a/app/controllers/users_controller.rb +++ b/app/controllers/users_controller.rb @@ -197,19 +197,7 @@ class UsersController < ApplicationController flash[:matomo_goal] = Settings.matomo["goals"]["signup"] if defined?(Settings.matomo) - referer = welcome_path - - begin - uri = URI(session[:referer]) - %r{map=(.*)/(.*)/(.*)}.match(uri.fragment) do |m| - editor = Rack::Utils.parse_query(uri.query).slice("editor") - referer = welcome_path({ "zoom" => m[1], - "lat" => m[2], - "lon" => m[3] }.merge(editor)) - end - rescue StandardError - # Use default - end + referer = welcome_path(welcome_options) if current_user.status == "active" session[:referer] = referer @@ -321,6 +309,21 @@ class UsersController < ApplicationController private + def welcome_options + uri = URI(session[:referer]) if session[:referer].present? + + return { "oauth_return_url" => uri&.to_s } if uri&.path == oauth_authorization_path + + begin + %r{map=(.*)/(.*)/(.*)}.match(uri.fragment) do |m| + editor = Rack::Utils.parse_query(uri.query).slice("editor") + return { "zoom" => m[1], "lat" => m[2], "lon" => m[3] }.merge(editor) + end + rescue StandardError + # Use default + end + end + ## # ensure that there is a "user" instance variable def lookup_user_by_name diff --git a/app/views/site/welcome.html.erb b/app/views/site/welcome.html.erb index b05620f59..8ec32ea9c 100644 --- a/app/views/site/welcome.html.erb +++ b/app/views/site/welcome.html.erb @@ -60,7 +60,13 @@
-

<%= t ".start_mapping" %>

+

+<% if params[:oauth_return_url] %> + <%= t ".continue_authorization" %> +<% else %> + <%= t ".start_mapping" %> +<% end %> +

diff --git a/config/locales/en.yml b/config/locales/en.yml index 546bf669c..8b0745118 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -2383,6 +2383,7 @@ en: automated_edits: Automated Edits automated_edits_url: https://wiki.openstreetmap.org/wiki/Automated_Edits_code_of_conduct start_mapping: Start Mapping + continue_authorization: Continue Authorization add_a_note: title: No Time To Edit? Add a Note! para_1: |