FIX: Ruby 2 backward compatible plugin logout redirect (#19845)

This is a very subtle one. Setting the redirect URL is done by passing
a hash through a Discourse event. This is broken on Ruby 2 since the
support for keyword arguments in events was added.

In Ruby 2 the last argument is cast to keyword arguments if it is a
hash. The key point here is that creates a new copy of the hash, so
what the plugin is modifying is not the hash that was passed.
This commit is contained in:
Ted Johansson 2023-01-12 19:12:20 +08:00 committed by Bianca Nenciu
parent 3044fca9b2
commit 051db5e958
2 changed files with 4 additions and 1 deletions

View File

@ -594,7 +594,7 @@ class SessionController < ApplicationController
client_ip: request&.ip,
user_agent: request&.user_agent,
}
DiscourseEvent.trigger(:before_session_destroy, event_data)
DiscourseEvent.trigger(:before_session_destroy, event_data, **Discourse::Utils::EMPTY_KEYWORDS)
redirect_url = event_data[:redirect_url]
reset_session

View File

@ -12,6 +12,9 @@ module Discourse
class Utils
URI_REGEXP ||= URI.regexp(%w[http https])
# TODO: Remove this once we drop support for Ruby 2.
EMPTY_KEYWORDS ||= {}
# Usage:
# Discourse::Utils.execute_command("pwd", chdir: 'mydirectory')
# or with a block