2014-03-05 07:52:20 -05:00
|
|
|
class Badge < ActiveRecord::Base
|
|
|
|
belongs_to :badge_type
|
2014-03-21 08:26:06 -04:00
|
|
|
has_many :user_badges, dependent: :destroy
|
2014-03-05 07:52:20 -05:00
|
|
|
|
|
|
|
validates :name, presence: true, uniqueness: true
|
|
|
|
validates :badge_type, presence: true
|
2014-04-25 14:25:29 -04:00
|
|
|
validates :allow_title, inclusion: [true, false]
|
2014-05-23 22:33:46 -04:00
|
|
|
validates :multiple_grant, inclusion: [true, false]
|
2014-05-04 14:15:38 -04:00
|
|
|
|
|
|
|
def self.trust_level_badge_ids
|
|
|
|
(1..4).to_a
|
|
|
|
end
|
2014-05-15 20:34:06 -04:00
|
|
|
|
|
|
|
def reset_grant_count!
|
|
|
|
self.grant_count = UserBadge.where(badge_id: id).count
|
|
|
|
save!
|
|
|
|
end
|
|
|
|
|
2014-05-21 03:22:42 -04:00
|
|
|
def single_grant?
|
|
|
|
!self.multiple_grant?
|
|
|
|
end
|
|
|
|
|
2014-03-05 07:52:20 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: badges
|
|
|
|
#
|
2014-05-21 03:22:42 -04:00
|
|
|
# id :integer not null, primary key
|
|
|
|
# name :string(255) not null
|
|
|
|
# description :text
|
|
|
|
# badge_type_id :integer not null
|
|
|
|
# grant_count :integer default(0), not null
|
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
|
|
|
# allow_title :boolean default(FALSE), not null
|
2014-05-23 22:33:46 -04:00
|
|
|
# multiple_grant :boolean default(FALSE), not null
|
2014-06-17 01:59:28 -04:00
|
|
|
# icon :string(255) default("fa-certificate")
|
2014-03-05 07:52:20 -05:00
|
|
|
#
|
|
|
|
# Indexes
|
|
|
|
#
|
2014-05-21 03:22:42 -04:00
|
|
|
# index_badges_on_badge_type_id (badge_type_id)
|
|
|
|
# index_badges_on_name (name) UNIQUE
|
2014-03-05 07:52:20 -05:00
|
|
|
#
|