Arie/serveme

View on GitHub
app/controllers/application_controller.rb

Summary

Maintainability
A
35 mins
Test Coverage
# frozen_string_literal: true

class ApplicationController < ActionController::Base
  include ApplicationHelper

  protect_from_forgery
  before_action :authenticate_user!
  before_action :set_time_zone
  before_action :redirect_if_country_banned
  before_action :store_current_location, unless: :devise_controller?

  def set_time_zone
    set_time_zone_from_current_user || set_time_zone_from_cookie || set_default_time_zone
  end

  private

  def set_time_zone_from_current_user
    return if current_user&.time_zone.blank?

    Time.zone = current_user.time_zone
  end

  def set_time_zone_from_cookie
    Time.zone = time_zone_from_cookie
    current_user&.update(time_zone: time_zone_from_cookie)
  rescue ArgumentError
    set_default_time_zone
  end

  def set_default_time_zone
    Time.zone = Rails.configuration.time_zone
  end

  def time_zone_from_cookie
    cookies[:time_zone]
  end
  helper_method :time_zone_from_cookie

  def current_admin
    @current_admin ||= current_user&.admin? && current_user
  end
  helper_method :current_admin

  def current_league_admin
    @current_league_admin ||= current_user&.league_admin? && current_user
  end
  helper_method :current_league_admin

  def current_streamer
    @current_streamer ||= current_user&.streamer? && current_user
  end
  helper_method :current_streamer

  def current_trusted_api
    @current_trusted_api ||= current_user&.trusted_api? && current_user
  end
  helper_method :current_trusted_api

  def require_admin
    redirect_to root_path unless current_admin
  end

  def require_admin_or_streamer
    redirect_to root_path unless current_admin || current_league_admin || current_streamer
  end

  def require_site_or_league_admin
    redirect_to root_path unless current_admin || current_league_admin
  end

  def require_donator
    return if current_user&.donator?

    flash[:alert] = 'Only donators can do that...'
    redirect_to root_path
  end

  protected

  def authenticate_user!
    if user_signed_in?
      if current_user.banned?
        Rails.logger.info "Logging out banned player with user id #{current_user.id} steam uid #{current_user.uid}, IP #{current_user.current_sign_in_ip}, name #{current_user.name}"
        sign_out_and_redirect(current_user)
      elsif current_user.current_sign_in_ip && ReservationPlayer.banned_asn_ip?(current_user.current_sign_in_ip) && !current_user.admin?
        Rails.logger.info "Logging out player on VPN with user id #{current_user.id} steam uid #{current_user.uid}, IP #{current_user.current_sign_in_ip}, name #{current_user.name}"
        flash[:notice] = 'You appear to be on a VPN, please log in without it'
        sign_out_and_redirect(current_user)
      else
        super
      end
    else
      session[:user_return_to] = request.url
      flash[:notice] = 'Please log in first'
      redirect_to new_session_path
    end
  end

  def redirect_if_country_banned
    return if cookies['not_a_vatnik'] == 'true' || current_user&.donator? || ReservationPlayer.whitelisted_uid?(current_user&.uid)

    redirect_to no_to_war_path if current_user&.banned_country? || ReservationPlayer.banned_country?(request.remote_ip) || recent_banned_country_ips?
  end

  def recent_banned_country_ips?
    return false unless current_user

    current_user
      .reservation_players
      .joins(:reservation)
      .where('reservations.created_at > ?', Date.new(2022, 1, 1))
      .pluck(:ip)
      .compact
      .uniq
      .any? { |ip| ReservationPlayer.banned_country?(ip) }
  end

  def store_current_location
    store_location_for(:user, request.url)
  end
end