discourse/lib/tasks/posts.rake

52 lines
1.4 KiB
Ruby
Raw Normal View History

2013-06-19 15:20:30 +08:00
desc 'Update each post with latest markdown'
task 'posts:rebake' => :environment do
ENV['RAILS_DB'] ? rebake_posts : rebake_posts_all_sites
2013-06-19 15:20:30 +08:00
end
desc 'Update each post with latest markdown and refresh oneboxes'
task 'posts:refresh_oneboxes' => :environment do
ENV['RAILS_DB'] ? rebake_posts(invalidate_oneboxes: true) : rebake_posts_all_sites(invalidate_oneboxes: true)
2013-06-19 15:20:30 +08:00
end
def rebake_post(post,opts)
cooked = post.cook(
post.raw,
topic_id: post.topic_id,
invalidate_oneboxes: opts.fetch(:invalidate_oneboxes, false)
)
if cooked != post.cooked
2013-11-22 08:52:26 +08:00
Post.exec_sql('update posts set cooked = ? where id = ?', cooked, post.id)
post.cooked = cooked
putc "#"
else
putc "."
end
2013-11-22 08:52:26 +08:00
# Extracts urls from the body
TopicLink.extract_from post
# make sure we trigger the post process
post.trigger_post_process(true)
2013-11-22 08:52:26 +08:00
rescue => e
puts "\n\nFailed to bake topic_id #{post.topic_id} post_id #{post.id} #{e}\n#{e.backtrace.join("\n")} \n\n"
end
def rebake_posts_all_sites(opts = {})
2013-02-06 03:16:51 +08:00
RailsMultisite::ConnectionManagement.each_connection do |db|
rebake_posts(opts)
end
end
2013-06-19 15:20:30 +08:00
def rebake_posts(opts = {})
puts "Re baking post markdown for #{RailsMultisite::ConnectionManagement.current_db}, changes are denoted with #, no change with ."
2013-02-06 03:16:51 +08:00
total = 0
Post.find_each do |post|
rebake_post(post,opts)
total += 1
2013-02-06 03:16:51 +08:00
end
puts "\n\n#{total} posts done!\n#{'-' * 50}\n"
2013-02-06 03:16:51 +08:00
end