Fix preview card image not being re-fetched even if link is re-posted (#11981)

Fix #11956
master
Eugen Rochko 5 years ago committed by GitHub
parent 32ff78f749
commit 3ec80c7aec
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 4
      app/models/preview_card.rb
  2. 2
      app/services/fetch_link_card_service.rb

@ -47,6 +47,10 @@ class PreviewCard < ApplicationRecord
before_save :extract_dimensions, if: :link? before_save :extract_dimensions, if: :link?
def missing_image?
width.present? && height.present? && image_file_name.blank?
end
def save_with_optional_image! def save_with_optional_image!
save! save!
rescue ActiveRecord::RecordInvalid rescue ActiveRecord::RecordInvalid

@ -22,7 +22,7 @@ class FetchLinkCardService < BaseService
RedisLock.acquire(lock_options) do |lock| RedisLock.acquire(lock_options) do |lock|
if lock.acquired? if lock.acquired?
@card = PreviewCard.find_by(url: @url) @card = PreviewCard.find_by(url: @url)
process_url if @card.nil? || @card.updated_at <= 2.weeks.ago process_url if @card.nil? || @card.updated_at <= 2.weeks.ago || @card.missing_image?
else else
raise Mastodon::RaceConditionError raise Mastodon::RaceConditionError
end end

Loading…
Cancel
Save