Adds a rake task for applying auto-close to old topics
This commit is contained in:
parent
e582e86da3
commit
26d10370c6
lib/tasks
|
@ -0,0 +1,53 @@
|
|||
def print_status(label, current, max)
|
||||
print "\r%s%9d / %d (%5.1f%%)" % [label, current, max, ((current.to_f / max.to_f) * 100).round(1)]
|
||||
end
|
||||
|
||||
def close_old_topics(category)
|
||||
topics = Topic.where(closed: false, category_id: category.id)
|
||||
|
||||
if category.auto_close_based_on_last_post
|
||||
topics = topics.where('last_posted_at < ?', category.auto_close_hours.hours.ago)
|
||||
else
|
||||
topics = topics.where('created_at < ?', category.auto_close_hours.hours.ago)
|
||||
end
|
||||
|
||||
topics_closed = 0
|
||||
total = topics.count
|
||||
|
||||
topics.find_each do |topic|
|
||||
topic.update_status("closed", true, Discourse.system_user)
|
||||
print_status("\tClosing topics: ", topics_closed += 1, total)
|
||||
end
|
||||
end
|
||||
|
||||
def apply_auto_close(category)
|
||||
topics = Topic.where(closed: false, category_id: category.id)
|
||||
.where(<<-SQL, TopicTimer.types[:close])
|
||||
NOT EXISTS (
|
||||
SELECT 1
|
||||
FROM topic_timers
|
||||
WHERE topic_timers.topic_id = topics.id
|
||||
AND topic_timers.status_type = ?
|
||||
)
|
||||
SQL
|
||||
|
||||
topics_closed = 0
|
||||
total = topics.count
|
||||
|
||||
topics.find_each do |topic|
|
||||
topic.inherit_auto_close_from_category
|
||||
print_status("\tApplying auto-close to topics: ", topics_closed += 1, total)
|
||||
end
|
||||
end
|
||||
|
||||
task "topics:apply_autoclose" => :environment do
|
||||
categories = Category.where("auto_close_hours > 0")
|
||||
|
||||
categories.find_each do |category|
|
||||
puts "", "Applying auto-close to category '#{category.name}' ..."
|
||||
close_old_topics(category)
|
||||
apply_auto_close(category)
|
||||
end
|
||||
|
||||
puts "", "Done"
|
||||
end
|
Loading…
Reference in New Issue