mirror of
https://github.com/ENSL/ensl.org.git
synced 2025-01-27 19:50:56 +00:00
139 lines
4.5 KiB
Ruby
139 lines
4.5 KiB
Ruby
# == Schema Information
|
||
#
|
||
# Table name: teams
|
||
#
|
||
# id :integer not null, primary key
|
||
# active :boolean default(TRUE), not null
|
||
# comment :string(255)
|
||
# country :string(255)
|
||
# irc :string(255)
|
||
# logo :string(255)
|
||
# name :string(255)
|
||
# recruiting :string(255)
|
||
# tag :string(255)
|
||
# teamers_count :integer
|
||
# web :string(255)
|
||
# created_at :datetime
|
||
# updated_at :datetime
|
||
# founder_id :integer
|
||
#
|
||
# Indexes
|
||
#
|
||
# index_teams_on_founder_id (founder_id)
|
||
#
|
||
|
||
class Team < ActiveRecord::Base
|
||
include Extra
|
||
|
||
LOGOS = "logos"
|
||
STATUS_INACTIVE = 0
|
||
STATUS_ACTIVE = 1
|
||
|
||
#attr_protected :id, :active, :founder_id, :created_at, :updated_at
|
||
|
||
validates_presence_of :name, :tag
|
||
validates_length_of :name, :tag, :in => 2..20
|
||
validates_length_of :irc, :maximum => 60, :allow_blank => true
|
||
validates_length_of :web, :maximum => 50, :allow_blank => true
|
||
validates_format_of :country, :with => /\A[A-Z]{2}\z/, :allow_blank => true
|
||
validates_length_of [:comment, :recruiting], :in => 0..75, :allow_blank => true
|
||
|
||
scope :with_teamers_num, -> (num) {
|
||
select("teams.*, COUNT(T.id) AS teamers_num").
|
||
joins("LEFT JOIN teamers T ON T.team_id = teams.id AND T.rank >= #{Teamer::RANK_MEMBER}").
|
||
group("teams.id").
|
||
having("teamers_num >= ?", num) }
|
||
scope :non_empty_teams, -> { joins(:teamers).where("teamers.rank >= #{Teamer::RANK_MEMBER}").distinct }
|
||
scope :with_teamers, -> { includes(:teamers) }
|
||
scope :active, -> { where(active: true) }
|
||
scope :inactive, -> { where(active: false) }
|
||
scope :ordered, -> { order("name") }
|
||
scope :recruiting, -> { where("recruiting IS NOT NULL AND recruiting != ''") }
|
||
scope :not_in_contest, -> (contest) { joins(:contests).where.not('contests.id': contest.id) }
|
||
|
||
belongs_to :founder, :class_name => "User", :optional => true
|
||
|
||
has_many :active_teamers, -> { where("rank >= ?", Teamer::RANK_MEMBER) }
|
||
has_many :teamers, :dependent => :destroy, :counter_cache => true
|
||
has_many :leaders, -> { where("rank = ?", Teamer::RANK_LEADER) }, :class_name => "Teamer"
|
||
has_many :contesters, :dependent => :destroy
|
||
has_many :contests, -> { where("contesters.active", true) }, :through => :contesters
|
||
has_many :received_messages, :class_name => "Message", :as => "recipient"
|
||
has_many :sent_messages, :class_name => "Message", :as => "sender"
|
||
has_many :matches, :through => :contesters
|
||
has_many :matches_finished, -> { where("(score1 != 0 OR score2 != 0)") },
|
||
:through => :contesters, :source => :matches
|
||
has_many :matches_won, -> { where("((score1 > score2 AND contester1_id = contesters.id) OR (score2 > score1 AND contester2_id = contesters.id)) AND (score1 != 0 OR score2 != 0)") },
|
||
:through => :contesters, :source => :matches
|
||
has_many :matches_lost, -> { where("((score1 < score2 AND contester1_id = contesters.id) OR (score2 < score1 AND contester2_id = contesters.id)) AND (score1 != 0 OR score2 != 0)") },
|
||
:through => :contesters, :source => :matches
|
||
has_many :matches_draw, -> { where("(score1 = score2 AND score1 > 0) AND (score1 != 0 OR score2 != 0)") },
|
||
:through => :contesters, :source => :matches
|
||
|
||
mount_uploader :logo, TeamUploader
|
||
|
||
before_create :init_variables
|
||
after_create :add_leader
|
||
|
||
def to_s
|
||
name
|
||
end
|
||
|
||
def leaders_s
|
||
leaders.join(", ")
|
||
end
|
||
|
||
def init_variables
|
||
self.active = true
|
||
self.recruiting = nil
|
||
end
|
||
|
||
def add_leader
|
||
teamer = Teamer.new
|
||
teamer.user = founder
|
||
teamer.team = self
|
||
teamer.rank = Teamer::RANK_LEADER
|
||
teamer.save
|
||
founder.update_attribute :team_id, self.id
|
||
end
|
||
|
||
def self.search(search)
|
||
search ? where("LOWER(name) LIKE LOWER(?)", "%#{search}%") : all
|
||
end
|
||
|
||
def destroy
|
||
User.where(team_id: self.id).each do |user|
|
||
user.update_attribute(:team_id, nil)
|
||
end
|
||
if matches.count > 0
|
||
update_attribute :active, false
|
||
teamers.update_all ["rank = ?", Teamer::RANK_REMOVED]
|
||
else
|
||
super
|
||
end
|
||
end
|
||
|
||
def recover
|
||
update_attribute :active, true
|
||
end
|
||
|
||
def is_leader? user
|
||
teamers.leaders.exists?(:user_id => user.id)
|
||
end
|
||
|
||
def can_create? cuser
|
||
cuser and !cuser.banned?(Ban::TYPE_MUTE)
|
||
end
|
||
|
||
def can_update? cuser
|
||
cuser and (is_leader? cuser or cuser.admin?)
|
||
end
|
||
|
||
def can_destroy? cuser
|
||
cuser and cuser.admin?
|
||
end
|
||
|
||
def self.params(params, cuser)
|
||
params.permit(:team).except(:id, :active, :founder_id, :created_at, :updated_at).permit!
|
||
end
|
||
end
|