# frozen_string_literal: true

class ReactController < ApplicationController
  include Authorization

  before_action :authenticate_user!, only: [:react, :home]

  before_action :set_account, only: [:status_embed, :status_show, :account_show]
  before_action :set_status, only: [:status_embed, :status_show]
  before_action :check_account_suspension, only: [:status_embed, :status_show, :account_show]
  before_action :redirect_to_original, only: [:status_show]

  before_action :set_referrer_policy_header, only: [:react, :home, :status_embed, :status_show, :account_show]
  before_action :set_initial_state_json, only: [:react, :home, :status_embed, :status_show, :account_show]
  before_action :set_data_for_meta, only: [:react, :home, :status_embed, :status_show, :account_show]

  before_action :set_instance_presenter

  def react
    # 
  end
  
  def groupBySlug
    @group = Group.where(slug: params[:groupSlug], is_archived: false).first
    unless @group.nil?
      return redirect_to "/groups/#{@group.id}"
    end

    return not_found 
  end

  def status_show
    return process(:react)
  end

  def status_embed
    # : todo :
  end

  def account_show
    return process(:react)
  end

  private

  def set_account
    @account = Account.find_acct!(params[:username])
  end

  def set_status
    @status = @account.statuses.find(params[:statusId])

    authorize @status, :show?
  rescue GabSocial::NotPermittedError
    # Reraise in order to get a 404
    raise ActiveRecord::RecordNotFound
  end

  def check_account_suspension
    gone if @account.suspended?
  end

  def redirect_to_original
    if @status.reblog?
      redirect_to ::TagManager.instance.url_for(@status.reblog) 
    end
  end

  def set_data_for_meta
    return if find_route_matches && current_account

    if request.path.include?("/groups/")
      groupIdFromPath = request.path.sub("/groups", "").gsub("/", "")
      @group = Group.where(id: groupIdFromPath, is_archived: false).first
    elsif find_public_route_matches
      return
    elsif request.path.count("/") == 1 && request.path.length === 1
      # 
    elsif request.path.count("/") == 1 && !request.path.include?("@")
      acctFromPath = request.path.sub("/", "")
      @account = Account.find_local!(acctFromPath)
    end
  end

  def authenticate_user!
    return if user_signed_in?
    if find_public_route_matches
      return
    elsif find_route_matches
      # if no current user, dont allow to navigate to these paths
      redirect_to(homepage_path)
    end

    return false
  end

  def find_route_matches
    request.path.match(/\A\/(home|news|api|deck|suggestions|links|chat_conversations|chat_conversation_accounts|messages|shortcuts|group|groups|list|lists|notifications|tags|compose|follow_requests|admin|account|settings|filters|timeline|blocks|mutes)/)
  end

  def find_public_route_matches
    request.path.match(/\A\/(about|news|search|groups|explore)/)
  end

  def set_initial_state_json
    serializable_resource = ActiveModelSerializers::SerializableResource.new(InitialStatePresenter.new(initial_state_params), serializer: InitialStateSerializer)
    @initial_state_json = serializable_resource.to_json
  end

  def initial_state_params
    if !current_user.nil?
      {
        settings: Web::Setting.find_by(user: current_user)&.data || {},
        push_subscription: current_account.user.web_push_subscription(current_session),
        current_account: current_account,
        token: current_session.token,
      }
    else 
      return {}
    end
  end

  def set_referrer_policy_header
    unless @status.nil?
      return if @status.public_visibility? || @status.unlisted_visibility?
    end
    response.headers['Referrer-Policy'] = 'origin'
  end

  def set_instance_presenter
    @instance_presenter = InstancePresenter.new
  end
end