mirror of
https://github.com/discourse/discourse.git
synced 2024-12-12 15:33:55 +08:00
821bb1e8cb
The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
94 lines
3.9 KiB
Ruby
94 lines
3.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module SiteSettings; end
|
|
|
|
module SiteSettings::DeprecatedSettings
|
|
SETTINGS = [
|
|
['show_email_on_profile', 'moderators_view_emails', true, '2.4'],
|
|
['allow_moderators_to_create_categories', 'moderators_create_categories', true, '2.4'],
|
|
['disable_edit_notifications', 'disable_system_edit_notifications', true, '2.4'],
|
|
['enable_category_group_review', 'enable_category_group_moderation', true, '2.7'],
|
|
['newuser_max_images', 'newuser_max_embedded_media', true, '2.7'],
|
|
['min_trust_to_post_images', 'min_trust_to_post_embedded_media', true, '2.7'],
|
|
['moderators_create_categories', 'moderators_manage_categories_and_groups', '2.7'],
|
|
|
|
['enable_sso', 'enable_discourse_connect', true, '2.8'],
|
|
['sso_allows_all_return_paths', 'discourse_connect_allows_all_return_paths', true, '2.8'],
|
|
['enable_sso_provider', 'enable_discourse_connect_provider', true, '2.8'],
|
|
['verbose_sso_logging', 'verbose_discourse_connect_logging', true, '2.8'],
|
|
['sso_url', 'discourse_connect_url', true, '2.8'],
|
|
['sso_secret', 'discourse_connect_secret', true, '2.8'],
|
|
['sso_provider_secrets', 'discourse_connect_provider_secrets', true, '2.8'],
|
|
['sso_overrides_groups', 'discourse_connect_overrides_groups', true, '2.8'],
|
|
['sso_overrides_bio', 'discourse_connect_overrides_bio', true, '2.8'],
|
|
['sso_overrides_email', 'auth_overrides_email', true, '2.8'],
|
|
['sso_overrides_username', 'auth_overrides_username', true, '2.8'],
|
|
['sso_overrides_name', 'auth_overrides_name', true, '2.8'],
|
|
['sso_overrides_avatar', 'discourse_connect_overrides_avatar', true, '2.8'],
|
|
['sso_overrides_profile_background', 'discourse_connect_overrides_profile_background', true, '2.8'],
|
|
['sso_overrides_location', 'discourse_connect_overrides_location', true, '2.8'],
|
|
['sso_overrides_website', 'discourse_connect_overrides_website', true, '2.8'],
|
|
['sso_overrides_card_background', 'discourse_connect_overrides_card_background', true, '2.8'],
|
|
['external_auth_skip_create_confirm', 'auth_skip_create_confirm', true, '2.8'],
|
|
['external_auth_immediately', 'auth_immediately', true, '2.8'],
|
|
]
|
|
|
|
def setup_deprecated_methods
|
|
SETTINGS.each do |old_setting, new_setting, override, version|
|
|
unless override
|
|
SiteSetting.singleton_class.public_send(
|
|
:alias_method, :"_#{old_setting}", :"#{old_setting}"
|
|
)
|
|
end
|
|
|
|
define_singleton_method old_setting do |warn: true|
|
|
if warn
|
|
logger.warn(
|
|
"`SiteSetting.#{old_setting}` has been deprecated and will be " +
|
|
"removed in the #{version} Release. Please use " +
|
|
"`SiteSetting.#{new_setting}` instead"
|
|
)
|
|
end
|
|
|
|
self.public_send(override ? new_setting : "_#{old_setting}")
|
|
end
|
|
|
|
unless override
|
|
SiteSetting.singleton_class.public_send(
|
|
:alias_method, :"_#{old_setting}?", :"#{old_setting}?"
|
|
)
|
|
end
|
|
|
|
define_singleton_method "#{old_setting}?" do |warn: true|
|
|
if warn
|
|
logger.warn(
|
|
"`SiteSetting.#{old_setting}?` has been deprecated and will be " +
|
|
"removed in the #{version} Release. Please use " +
|
|
"`SiteSetting.#{new_setting}?` instead"
|
|
)
|
|
end
|
|
|
|
self.public_send("#{override ? new_setting : "_" + old_setting}?")
|
|
end
|
|
|
|
unless override
|
|
SiteSetting.singleton_class.public_send(
|
|
:alias_method, :"_#{old_setting}=", :"#{old_setting}="
|
|
)
|
|
end
|
|
|
|
define_singleton_method "#{old_setting}=" do |val, warn: true|
|
|
if warn
|
|
logger.warn(
|
|
"`SiteSetting.#{old_setting}=` has been deprecated and will be " +
|
|
"removed in the #{version} Release. Please use " +
|
|
"`SiteSetting.#{new_setting}=` instead"
|
|
)
|
|
end
|
|
|
|
self.public_send("#{override ? new_setting : "_" + old_setting}=", val)
|
|
end
|
|
end
|
|
end
|
|
end
|