2013-03-29 01:02:59 +08:00
|
|
|
require_dependency 'score_calculator'
|
|
|
|
|
|
|
|
module Jobs
|
|
|
|
|
|
|
|
# This job will run on a regular basis to update statistics and denormalized data.
|
|
|
|
# If it does not run, the site will not function properly.
|
2013-08-08 01:25:05 +08:00
|
|
|
class PeriodicalUpdates < Jobs::Scheduled
|
2014-02-06 07:14:41 +08:00
|
|
|
every 15.minutes
|
2013-03-29 01:02:59 +08:00
|
|
|
|
2016-07-22 07:48:26 +08:00
|
|
|
def self.should_update_long_topics?
|
|
|
|
@call_count ||= 0
|
|
|
|
@call_count += 1
|
|
|
|
|
|
|
|
# once every 6 hours
|
|
|
|
(@call_count % 24) == 1
|
|
|
|
end
|
|
|
|
|
2019-01-09 05:57:20 +08:00
|
|
|
def execute(args = nil)
|
2013-03-29 01:02:59 +08:00
|
|
|
# Feature topics in categories
|
2017-12-20 10:42:29 +08:00
|
|
|
CategoryFeaturedTopic.feature_topics(batched: true)
|
2013-03-29 01:02:59 +08:00
|
|
|
|
|
|
|
# Update the scores of posts
|
2017-07-28 09:20:09 +08:00
|
|
|
args = { min_topic_age: 1.day.ago }
|
2016-07-22 07:48:26 +08:00
|
|
|
args[:max_topic_length] = 500 unless self.class.should_update_long_topics?
|
|
|
|
ScoreCalculator.new.calculate(args)
|
2013-12-24 07:50:36 +08:00
|
|
|
|
2017-03-22 11:12:02 +08:00
|
|
|
# Re-run stuff that we missed
|
2017-05-12 06:23:18 +08:00
|
|
|
TopicTimer.ensure_consistency!
|
2014-05-28 10:30:43 +08:00
|
|
|
|
2014-05-28 14:54:21 +08:00
|
|
|
# Forces rebake of old posts where needed, as long as no system avatars need updating
|
2018-12-07 14:03:22 +08:00
|
|
|
if !SiteSetting.automatically_download_gravatars || !UserAvatar.where("last_gravatar_download_attempt IS NULL").limit(1).first
|
2019-01-17 11:53:09 +08:00
|
|
|
problems = Post.rebake_old(SiteSetting.rebake_old_posts_count, priority: :ultra_low)
|
2014-07-18 04:22:46 +08:00
|
|
|
problems.each do |hash|
|
2015-06-12 18:02:36 +08:00
|
|
|
post_id = hash[:post].id
|
|
|
|
Discourse.handle_job_exception(hash[:ex], error_context(args, "Rebaking post id #{post_id}", post_id: post_id))
|
2014-07-18 04:22:46 +08:00
|
|
|
end
|
2014-05-28 14:54:21 +08:00
|
|
|
end
|
2014-06-24 15:10:56 +08:00
|
|
|
|
2014-08-05 14:37:56 +08:00
|
|
|
# rebake out of date user profiles
|
|
|
|
problems = UserProfile.rebake_old(250)
|
|
|
|
problems.each do |hash|
|
|
|
|
user_id = hash[:profile].user_id
|
2015-02-10 04:47:46 +08:00
|
|
|
Discourse.handle_job_exception(hash[:ex], error_context(args, "Rebaking user id #{user_id}", user_id: user_id))
|
2014-08-05 14:37:56 +08:00
|
|
|
end
|
2015-09-07 09:57:50 +08:00
|
|
|
|
2015-10-01 15:17:15 +08:00
|
|
|
offset = (SiteSetting.max_new_topics).to_i
|
2015-09-07 09:57:50 +08:00
|
|
|
last_new_topic = Topic.order('created_at desc').offset(offset).select(:created_at).first
|
|
|
|
if last_new_topic
|
|
|
|
SiteSetting.min_new_topics_time = last_new_topic.created_at.to_i
|
|
|
|
end
|
|
|
|
|
2018-07-17 07:33:33 +08:00
|
|
|
Category.auto_bump_topic!
|
2018-07-16 16:10:22 +08:00
|
|
|
|
2015-09-07 09:57:50 +08:00
|
|
|
nil
|
2013-03-29 01:02:59 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|