add upvote and downvote metatags

This commit is contained in:
r888888888
2016-09-08 17:48:50 -07:00
parent e56d71a7d2
commit c10176e64d
4 changed files with 25 additions and 3 deletions

View File

@@ -348,6 +348,18 @@ class PostQueryBuilder
end end
end end
if q[:upvote].present?
user_id = q[:upvote]
post_ids = PostVote.where(:user_id => user_id).where("score > 0").limit(400).pluck(:post_id)
relation = relation.where("posts.id in (?)", post_ids)
end
if q[:downvote].present?
user_id = q[:downvote]
post_ids = PostVote.where(:user_id => user_id).where("score < 0").limit(400).pluck(:post_id)
relation = relation.where("posts.id in (?)", post_ids)
end
if q[:ordfav].present? if q[:ordfav].present?
user_id = q[:ordfav].to_i user_id = q[:ordfav].to_i
user = User.find(user_id) user = User.find(user_id)

View File

@@ -12,7 +12,7 @@ module Reports
User.find(user_id) User.find(user_id)
end end
def prime_similar_users(endpoint = "user_similarity") def prime(endpoint = "user_similarity")
10.times do 10.times do
result = fetch_similar_user_ids(endpoint) result = fetch_similar_user_ids(endpoint)
if result == NOT_READY_STRING if result == NOT_READY_STRING

View File

@@ -14,7 +14,7 @@ class SuperVoter < ActiveRecord::Base
def self.init! def self.init!
prune! prune!
report = Reports::UserSimilarity.new(User.admins.first.id) report = Reports::UserSimilarity.new(User.admins.first.id)
report.prime_similar_users("post_vote_similarity") report.prime("post_vote_similarity")
report.result.scan(/\S+/).in_groups_of(2).each do |user_id, score| report.result.scan(/\S+/).in_groups_of(2).each do |user_id, score|
unless where("user_id = ?", user_id.to_i).exists? unless where("user_id = ?", user_id.to_i).exists?

View File

@@ -1,6 +1,6 @@
class Tag < ActiveRecord::Base class Tag < ActiveRecord::Base
COSINE_SIMILARITY_RELATED_TAG_THRESHOLD = 1000 COSINE_SIMILARITY_RELATED_TAG_THRESHOLD = 1000
METATAGS = "-user|user|-approver|approver|commenter|comm|noter|noteupdater|artcomm|-pool|pool|ordpool|-favgroup|favgroup|-fav|fav|ordfav|sub|md5|-rating|rating|-locked|locked|width|height|mpixels|ratio|score|favcount|filesize|source|-source|id|-id|date|age|order|limit|-status|status|tagcount|gentags|arttags|chartags|copytags|parent|-parent|child|pixiv_id|pixiv|search" METATAGS = "-user|user|-approver|approver|commenter|comm|noter|noteupdater|artcomm|-pool|pool|ordpool|-favgroup|favgroup|-fav|fav|ordfav|sub|md5|-rating|rating|-locked|locked|width|height|mpixels|ratio|score|favcount|filesize|source|-source|id|-id|date|age|order|limit|-status|status|tagcount|gentags|arttags|chartags|copytags|parent|-parent|child|pixiv_id|pixiv|search|upvote|downvote"
SUBQUERY_METATAGS = "commenter|comm|noter|noteupdater|artcomm" SUBQUERY_METATAGS = "commenter|comm|noter|noteupdater|artcomm"
attr_accessible :category, :as => [:moderator, :janitor, :gold, :member, :anonymous, :default, :builder, :admin] attr_accessible :category, :as => [:moderator, :janitor, :gold, :member, :anonymous, :default, :builder, :admin]
attr_accessible :is_locked, :as => [:moderator, :admin] attr_accessible :is_locked, :as => [:moderator, :admin]
@@ -591,6 +591,16 @@ class Tag < ActiveRecord::Base
when "pixiv_id", "pixiv" when "pixiv_id", "pixiv"
q[:pixiv_id] = parse_helper($2) q[:pixiv_id] = parse_helper($2)
when "upvote"
if CurrentUser.user.is_janitor?
q[:upvote] = User.name_to_id($2)
end
when "downvote"
if CurrentUser.user.is_janitor?
q[:downvote] = User.name_to_id($2)
end
end end
else else