mirror of
https://github.com/funamitech/mastodon
synced 2024-12-05 10:18:45 +09:00
3622110778
Conflicts: - `streaming/index.js`: Filtering code for streaming notifications has been refactored upstream, but glitch-soc had similar code for local-only toots in the same places. Ported upstream changes, but did not refactor local-only filtering.
40 lines
880 B
Ruby
40 lines
880 B
Ruby
# frozen_string_literal: true
|
|
|
|
class HomeController < ApplicationController
|
|
before_action :redirect_unauthenticated_to_permalinks!
|
|
before_action :authenticate_user!
|
|
|
|
before_action :set_pack
|
|
before_action :set_referrer_policy_header
|
|
|
|
def index
|
|
@body_classes = 'app-body'
|
|
end
|
|
|
|
private
|
|
|
|
def redirect_unauthenticated_to_permalinks!
|
|
return if user_signed_in?
|
|
|
|
redirect_to(PermalinkRedirector.new(request.path).redirect_path || default_redirect_path)
|
|
end
|
|
|
|
def set_pack
|
|
use_pack 'home'
|
|
end
|
|
|
|
def default_redirect_path
|
|
if request.path.start_with?('/web') || whitelist_mode?
|
|
new_user_session_path
|
|
elsif single_user_mode?
|
|
short_account_path(Account.local.without_suspended.where('id > 0').first)
|
|
else
|
|
about_path
|
|
end
|
|
end
|
|
|
|
def set_referrer_policy_header
|
|
response.headers['Referrer-Policy'] = 'origin'
|
|
end
|
|
end
|