mirror of
https://github.com/discourse/discourse.git
synced 2025-01-08 00:43:53 +08:00
f8d9f09370
Previosly, if the topic embed request had a missing username parameter, and SiteSetting.embed_by_username was empty we would fail to create the new topic and not show any errors. Now we will fallback using the priority: 1. Username parameter 2. SiteSetting.embed_by_username 3. SiteSetting.site_contact_username 4. system user
56 lines
1.3 KiB
Ruby
56 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class TopicRetriever
|
|
|
|
def initialize(embed_url, opts = nil)
|
|
@embed_url = embed_url
|
|
@opts = opts || {}
|
|
@author_username = @opts[:author_username]
|
|
end
|
|
|
|
def retrieve
|
|
perform_retrieve unless (invalid_url? || retrieved_recently?)
|
|
end
|
|
|
|
private
|
|
|
|
def invalid_url?
|
|
!EmbeddableHost.url_allowed?(@embed_url.strip)
|
|
end
|
|
|
|
def retrieved_recently?
|
|
# We can disable the throttle for some users, such as staff
|
|
return false if @opts[:no_throttle]
|
|
|
|
# Throttle other users to once every 60 seconds
|
|
retrieved_key = "retrieved_topic"
|
|
if Discourse.redis.setnx(retrieved_key, "1")
|
|
Discourse.redis.expire(retrieved_key, 60)
|
|
return false
|
|
end
|
|
|
|
true
|
|
end
|
|
|
|
def perform_retrieve
|
|
# It's possible another process or job found the embed already. So if that happened bail out.
|
|
return if TopicEmbed.where(embed_url: @embed_url).exists?
|
|
|
|
fetch_http
|
|
end
|
|
|
|
def fetch_http
|
|
if @author_username.nil?
|
|
username = SiteSetting.embed_by_username.presence || SiteSetting.site_contact_username.presence || Discourse.system_user.username
|
|
else
|
|
username = @author_username
|
|
end
|
|
|
|
user = User.where(username_lower: username.downcase).first
|
|
return if user.blank?
|
|
|
|
TopicEmbed.import_remote(user, @embed_url)
|
|
end
|
|
|
|
end
|