2022-10-06 03:26:34 +03:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module WebAppControllerConcern
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
|
|
|
included do
|
2023-01-05 14:40:27 +02:00
|
|
|
prepend_before_action :redirect_unauthenticated_to_permalinks!
|
2022-10-28 12:36:25 +03:00
|
|
|
before_action :set_pack
|
2022-10-20 15:35:29 +03:00
|
|
|
before_action :set_app_body_class
|
2023-04-23 23:27:24 +03:00
|
|
|
|
|
|
|
vary_by 'Accept, Accept-Language, Cookie'
|
2022-10-06 03:26:34 +03:00
|
|
|
end
|
|
|
|
|
2023-04-25 17:51:38 +03:00
|
|
|
def skip_csrf_meta_tags?
|
2023-09-12 14:04:51 +03:00
|
|
|
!(ENV['ONE_CLICK_SSO_LOGIN'] == 'true' && ENV['OMNIAUTH_ONLY'] == 'true' && Devise.omniauth_providers.length == 1) && current_user.nil?
|
2022-10-06 03:26:34 +03:00
|
|
|
end
|
|
|
|
|
2022-10-20 15:35:29 +03:00
|
|
|
def set_app_body_class
|
2022-10-06 03:26:34 +03:00
|
|
|
@body_classes = 'app-body'
|
|
|
|
end
|
|
|
|
|
2022-10-20 15:35:29 +03:00
|
|
|
def redirect_unauthenticated_to_permalinks!
|
2023-01-05 15:16:25 +02:00
|
|
|
return if user_signed_in? # NOTE: Different from upstream because we allow moved users to log in
|
2022-10-20 15:35:29 +03:00
|
|
|
|
|
|
|
redirect_path = PermalinkRedirector.new(request.path).redirect_path
|
|
|
|
|
|
|
|
redirect_to(redirect_path) if redirect_path.present?
|
|
|
|
end
|
2022-10-28 12:36:25 +03:00
|
|
|
|
|
|
|
def set_pack
|
|
|
|
use_pack 'home'
|
|
|
|
end
|
2022-10-06 03:26:34 +03:00
|
|
|
end
|