discourse/app/models/badge.rb

168 lines
4.3 KiB
Ruby
Raw Normal View History

2014-03-05 20:52:20 +08:00
class Badge < ActiveRecord::Base
# badge ids
Welcome = 5
NicePost = 6
GoodPost = 7
GreatPost = 8
Autobiographer = 9
2014-07-07 15:55:25 +08:00
Editor = 10
FirstLike = 11
FirstShare = 12
FirstFlag = 13
# other consts
AutobiographerMinBioLength = 10
module Queries
FirstShare = <<SQL
SELECT views.user_id, p2.id post_id, i2.created_at granted_at
FROM
(
SELECT i.user_id, MIN(i.id) i_id
FROM incoming_links i
JOIN topics t on t.id = i.topic_id
JOIN posts p on p.topic_id = t.id AND p.post_number = i.post_number
WHERE i.user_id IS NOT NULL AND
p.deleted_at IS NULL AND
t.deleted_at IS NULL AND
t.visible
GROUP BY i.user_id
) as views
JOIN incoming_links i2 ON i2.id = views.i_id
JOIN posts p2 on p2.topic_id = i2.topic_id AND p2.post_number = i2.post_number
SQL
FirstFlag = <<SQL
SELECT pa.user_id, min(pa.created_at) granted_at
FROM post_actions pa
JOIN posts p on p.id = pa.post_id
JOIN topics t on t.id = p.topic_id
WHERE p.deleted_at IS NULL AND
t.deleted_at IS NULL AND
t.visible AND
post_action_type_id IN (#{PostActionType.flag_types.values.join(",")})
GROUP BY pa.user_id
SQL
FirstLike = <<SQL
2014-07-08 12:26:53 +08:00
SELECT pa.user_id, min(post_id) post_id, min(pa.created_at) granted_at
FROM post_actions pa
JOIN posts p on p.id = pa.post_id
JOIN topics t on t.id = p.topic_id
WHERE p.deleted_at IS NULL AND
t.deleted_at IS NULL AND
t.visible AND
post_action_type_id = 2
GROUP BY pa.user_id
SQL
2014-07-07 15:55:25 +08:00
Editor = <<SQL
SELECT p.user_id, min(p.id) post_id, min(p.created_at) granted_at
FROM posts p
JOIN topics t on t.id = p.topic_id
WHERE p.deleted_at IS NULL AND
t.deleted_at IS NULL AND
t.visible AND
p.self_edits > 0
GROUP BY p.user_id
SQL
Welcome = <<SQL
SELECT p.user_id, min(post_id) post_id, min(pa.created_at) granted_at
FROM post_actions pa
JOIN posts p on p.id = pa.post_id
JOIN topics t on t.id = p.topic_id
WHERE p.deleted_at IS NULL AND
t.deleted_at IS NULL AND
t.visible AND
post_action_type_id = 2
GROUP BY p.user_id
SQL
Autobiographer = <<SQL
SELECT u.id user_id, current_timestamp granted_at
FROM users u
JOIN user_profiles up on u.id = up.user_id
WHERE bio_raw IS NOT NULL AND LENGTH(TRIM(bio_raw)) > #{Badge::AutobiographerMinBioLength} AND
uploaded_avatar_id IS NOT NULL
SQL
def self.like_badge(count)
# we can do better with dates, but its hard work
"
SELECT p.user_id, p.id post_id, p.updated_at granted_at FROM posts p
JOIN topics t on p.topic_id = t.id
WHERE p.deleted_at IS NULL AND
t.deleted_at IS NULL AND
t.visible AND
p.like_count >= #{count.to_i}
"
end
def self.trust_level(level)
# we can do better with dates, but its hard work figuring this out historically
"
SELECT u.id user_id, current_timestamp granted_at FROM users u
WHERE trust_level >= #{level.to_i}
"
end
end
2014-03-05 20:52:20 +08:00
belongs_to :badge_type
has_many :user_badges, dependent: :destroy
2014-03-05 20:52:20 +08:00
validates :name, presence: true, uniqueness: true
validates :badge_type, presence: true
validates :allow_title, inclusion: [true, false]
2014-05-24 10:33:46 +08:00
validates :multiple_grant, inclusion: [true, false]
def self.trust_level_badge_ids
(1..4).to_a
end
def self.like_badge_counts
@like_badge_counts ||= {
NicePost => 10,
GoodPost => 25,
GreatPost => 50
}
end
def reset_grant_count!
self.grant_count = UserBadge.where(badge_id: id).count
save!
end
2014-05-21 15:22:42 +08:00
def single_grant?
!self.multiple_grant?
end
2014-03-05 20:52:20 +08:00
end
# == Schema Information
#
# Table name: badges
#
2014-05-21 15:22:42 +08: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-24 10:33:46 +08:00
# multiple_grant :boolean default(FALSE), not null
# icon :string(255) default("fa-certificate")
# listable :boolean default(TRUE)
# target_posts :boolean default(FALSE)
# query :text
2014-03-05 20:52:20 +08:00
#
# Indexes
#
# index_badges_on_name (name) UNIQUE
2014-03-05 20:52:20 +08:00
#