2014-08-01 11:23:47 +02:00
|
|
|
class ApplicationController < ActionController::Base
|
|
|
|
# Prevent CSRF attacks by raising an exception.
|
|
|
|
# For APIs, you may want to use :null_session instead.
|
|
|
|
protect_from_forgery with: :exception
|
2015-05-05 18:09:26 +02:00
|
|
|
|
2021-12-28 19:19:05 +01:00
|
|
|
before_action :sentry_user_context
|
2020-04-19 01:45:50 +02:00
|
|
|
before_action :configure_permitted_parameters, if: :devise_controller?
|
|
|
|
before_action :check_locale
|
|
|
|
before_action :banned?
|
2020-04-19 22:38:21 +02:00
|
|
|
before_action :find_active_announcements
|
2015-01-12 22:44:13 +01:00
|
|
|
|
2015-05-26 05:31:06 +02:00
|
|
|
# check if user wants to read
|
2015-05-26 05:26:40 +02:00
|
|
|
def check_locale
|
2015-06-07 02:57:21 +02:00
|
|
|
return I18n.locale = 'en' if Rails.env.test?
|
|
|
|
|
2015-07-04 09:31:46 +02:00
|
|
|
I18n.locale = 'en'
|
|
|
|
|
2015-05-26 05:26:40 +02:00
|
|
|
if params[:hl].nil?
|
|
|
|
if current_user.present?
|
|
|
|
I18n.locale = current_user.locale
|
2015-06-11 04:06:33 +02:00
|
|
|
elsif not cookies[:lang].nil?
|
|
|
|
I18n.locale = cookies[:lang]
|
2015-06-09 21:36:47 +02:00
|
|
|
else
|
|
|
|
I18n.locale = 'en'
|
2015-05-26 05:26:40 +02:00
|
|
|
end
|
|
|
|
else
|
|
|
|
I18n.locale = params[:hl]
|
|
|
|
if current_user.present?
|
|
|
|
current_user.locale = I18n.locale
|
|
|
|
current_user.save!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-07-04 09:31:46 +02:00
|
|
|
cookies[:lang] = I18n.locale
|
2015-05-26 05:26:40 +02:00
|
|
|
end
|
|
|
|
|
2015-05-26 05:31:06 +02:00
|
|
|
# check if user got hit by the banhammer of doom
|
2015-01-12 22:44:13 +01:00
|
|
|
def banned?
|
|
|
|
if current_user.present? && current_user.banned?
|
|
|
|
name = current_user.screen_name
|
|
|
|
# obligatory '2001: A Space Odyssey' reference
|
2015-06-07 19:03:57 +02:00
|
|
|
flash[:notice] = t('flash.ban.error', name: name)
|
2015-05-05 18:09:26 +02:00
|
|
|
unless current_user.ban_reason.nil?
|
2015-06-07 19:03:57 +02:00
|
|
|
flash[:notice] += "\n#{t('flash.ban.reason', reason: current_user.ban_reason)}"
|
2015-04-23 02:56:29 +02:00
|
|
|
end
|
|
|
|
if not current_user.permanently_banned?
|
|
|
|
# TODO format banned_until
|
2015-06-07 19:03:57 +02:00
|
|
|
flash[:notice] += "\n#{t('flash.ban.until', time: current_user.banned_until)}"
|
2015-04-23 02:56:29 +02:00
|
|
|
end
|
2015-01-12 22:44:13 +01:00
|
|
|
sign_out current_user
|
|
|
|
redirect_to new_user_session_path
|
|
|
|
end
|
|
|
|
end
|
2014-12-28 21:14:10 +01:00
|
|
|
|
2020-04-19 22:38:21 +02:00
|
|
|
def find_active_announcements
|
|
|
|
@active_announcements ||= Announcement.find_active
|
|
|
|
end
|
|
|
|
|
2014-12-28 21:14:10 +01:00
|
|
|
include ApplicationHelper
|
|
|
|
|
2014-08-01 15:27:08 +02:00
|
|
|
protected
|
|
|
|
|
|
|
|
def configure_permitted_parameters
|
2019-03-29 22:37:10 +01:00
|
|
|
devise_parameter_sanitizer.permit(:sign_up) { |u| u.permit(:screen_name, :email, :password, :password_confirmation, :remember_me) }
|
|
|
|
devise_parameter_sanitizer.permit(:sign_in) { |u| u.permit(:login, :screen_name, :email, :password, :remember_me) }
|
|
|
|
devise_parameter_sanitizer.permit(:account_update) { |u| u.permit(:screen_name, :email, :password, :password_confirmation, :current_password) }
|
2014-08-01 15:27:08 +02:00
|
|
|
end
|
2021-12-28 19:19:05 +01:00
|
|
|
|
|
|
|
def sentry_user_context
|
|
|
|
if current_user.present?
|
|
|
|
Sentry.set_user({ id: current_user.id })
|
|
|
|
else
|
|
|
|
Sentry.set_user({ ip_address: request.ip })
|
|
|
|
end
|
|
|
|
end
|
2014-08-01 11:23:47 +02:00
|
|
|
end
|