2019-05-02 18:17:27 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-31 00:06:56 -04:00
|
|
|
class FixLinkPostId < ActiveRecord::Migration[4.2]
|
2013-02-05 14:16:51 -05:00
|
|
|
def up
|
|
|
|
to_remove = []
|
|
|
|
|
|
|
|
TopicLink.where('internal = TRUE AND link_post_id IS NULL').each do |tl|
|
2013-02-25 11:42:20 -05:00
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
begin
|
|
|
|
parsed = URI.parse(tl.url)
|
|
|
|
route = Rails.application.routes.recognize_path(parsed.path)
|
|
|
|
if route[:topic_id].present?
|
2014-05-06 09:41:59 -04:00
|
|
|
post = Post.find_by(topic_id: route[:topic_id], post_number: (route[:post_number] || 1))
|
2013-02-05 14:16:51 -05:00
|
|
|
tl.update_column(:link_post_id, post.id) if post.present?
|
|
|
|
end
|
|
|
|
|
|
|
|
rescue ActionController::RoutingError
|
|
|
|
to_remove << tl.id
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
2017-08-31 00:06:56 -04:00
|
|
|
TopicLink.where("id in (?)", to_remove).delete_all
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def down
|
|
|
|
end
|
|
|
|
end
|