desc 'Update each post with latest markdown'
task 'posts:rebake' => :environment do
  ENV['RAILS_DB'] ? rebake_posts : rebake_posts_all_sites
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)
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
    Post.exec_sql('update posts set cooked = ? where id = ?', cooked, post.id)
    post.cooked = cooked
    putc "#"
  else
    putc "."
  end

  # Extracts urls from the body
  TopicLink.extract_from post
  # make sure we trigger the post process
  post.trigger_post_process(true)

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 = {})
  RailsMultisite::ConnectionManagement.each_connection do |db|
    rebake_posts(opts)
  end
end

def rebake_posts(opts = {})
  puts "Re baking post markdown for #{RailsMultisite::ConnectionManagement.current_db}, changes are denoted with #, no change with ."

  total = 0
  Post.find_each do |post|
    rebake_post(post,opts)
    total += 1
  end

  puts "\n\n#{total} posts done!\n#{'-' * 50}\n"
end