mirror of
https://github.com/ENSL/ensl.org.git
synced 2024-12-31 23:10:44 +00:00
99 lines
2.5 KiB
Ruby
Executable file
99 lines
2.5 KiB
Ruby
Executable file
# == Schema Information
|
|
#
|
|
# Table name: bans
|
|
#
|
|
# id :integer not null, primary key
|
|
# steamid :string(255)
|
|
# user_id :integer
|
|
# addr :string(255)
|
|
# server_id :integer
|
|
# expiry :datetime
|
|
# reason :string(255)
|
|
# created_at :datetime
|
|
# updated_at :datetime
|
|
# ban_type :integer
|
|
# ip :string(255)
|
|
# creator_id :integer
|
|
|
|
class Ban < ActiveRecord::Base
|
|
include Extra
|
|
|
|
TYPE_SITE = 0
|
|
TYPE_MUTE = 1
|
|
TYPE_LEAGUE = 2
|
|
TYPE_SERVER = 3
|
|
TYPE_VENT = 4
|
|
TYPE_GATHER = 5
|
|
VENT_BANS = "tmp/bans.txt"
|
|
|
|
attr_protected :id, :created_at, :updated_at
|
|
attr_accessor :len, :user_name
|
|
|
|
scope :ordered, -> {order("created_at DESC")}
|
|
scope :effective, -> {where("expiry > UTC_TIMESTAMP()")}
|
|
scope :ineffective, -> {where("expiry < UTC_TIMESTAMP()")}
|
|
|
|
before_validation :check_user
|
|
|
|
validate :validate_type
|
|
validate :validate_ventban
|
|
validate :validate_permission
|
|
validates :steamid, length: {maximum: 14}, format: /\A0:[01]:[0-9]{1,10}\Z/, allow_blank: true
|
|
validates :addr, format: /\A([0-9]{1,3}\.){3}[0-9]{1,3}:?[0-9]{0,5}\z/, allow_blank: true
|
|
validates :reason, length: {maximum: 255}, allow_blank: true
|
|
|
|
belongs_to :user
|
|
belongs_to :server
|
|
|
|
belongs_to :creator, foreign_key: 'creator_id', class_name: 'User'
|
|
|
|
def color
|
|
expiry.past? ? "green" : "red"
|
|
end
|
|
|
|
def types
|
|
{TYPE_SITE => "Website Logon",
|
|
TYPE_MUTE => "Commenting",
|
|
TYPE_LEAGUE => "Contests",
|
|
TYPE_SERVER => "NS Servers",
|
|
TYPE_VENT => "Ventrilo",
|
|
TYPE_GATHER => "Gather"}
|
|
end
|
|
|
|
def validate_type
|
|
errors.add :ban_type, I18n.t(:invalid_ban_type) unless types.include? ban_type
|
|
end
|
|
|
|
def validate_ventban
|
|
if ban_type == TYPE_VENT and !ip.match(/\A([0-9]{1,3}\.){3}[0-9]{1,3}\z/)
|
|
errors.add :ip, I18n.t(:ventrilos_ip_ban)
|
|
end
|
|
end
|
|
|
|
def validate_permission
|
|
unless creator.nil? or creator.admin? or (creator.gather_moderator? and self.ban_type == TYPE_GATHER)
|
|
errors.add :ban_type, 'Gather Moderators can only create gather bans'
|
|
end
|
|
end
|
|
|
|
def check_user
|
|
if user_name
|
|
self.user = User.find_by_username(user_name)
|
|
else
|
|
self.user = User.first(conditions: { steamid: steamid })
|
|
self.server = Server.first(conditions: ["CONCAT(ip, ':', port) = ?", addr])
|
|
end
|
|
end
|
|
|
|
def can_create? cuser
|
|
cuser and cuser.allowed_to_ban?
|
|
end
|
|
|
|
def can_update? cuser
|
|
cuser and (cuser.admin? or (self.creator == cuser and cuser.allowed_to_ban?))
|
|
end
|
|
|
|
def can_destroy? cuser
|
|
cuser and (cuser.admin? or (self.creator == cuser and cuser.allowed_to_ban?))
|
|
end
|
|
end
|