]> cat aescling's git repositories - mastodon.git/commitdiff
Fix URL search not returning private toots user has access to (#12742)
authorThibG <thib@sitedethib.com>
Fri, 3 Jan 2020 04:01:45 +0000 (05:01 +0100)
committerEugen Rochko <eugen@zeonfederated.com>
Fri, 3 Jan 2020 04:01:45 +0000 (05:01 +0100)
app/services/resolve_url_service.rb

index 79b1bad0c2b7c4f2d4368db47d94d963697720cf..1a2b0d60cbc61c4eba037b2d903cbbe8d67a2a48 100644 (file)
@@ -12,6 +12,8 @@ class ResolveURLService < BaseService
       process_local_url
     elsif !fetched_resource.nil?
       process_url
+    elsif @on_behalf_of.present?
+      process_url_from_db
     end
   end
 
@@ -24,15 +26,19 @@ class ResolveURLService < BaseService
       status = FetchRemoteStatusService.new.call(resource_url, body)
       authorize_with @on_behalf_of, status, :show? unless status.nil?
       status
-    elsif fetched_resource.nil? && @on_behalf_of.present?
-      # It may happen that the resource is a private toot, and thus not fetchable,
-      # but we can return the toot if we already know about it.
-      status = Status.find_by(uri: @url) || Status.find_by(url: @url)
-      authorize_with @on_behalf_of, status, :show? unless status.nil?
-      status
     end
   end
 
+  def process_url_from_db
+    # It may happen that the resource is a private toot, and thus not fetchable,
+    # but we can return the toot if we already know about it.
+    status = Status.find_by(uri: @url) || Status.find_by(url: @url)
+    authorize_with @on_behalf_of, status, :show? unless status.nil?
+    status
+  rescue Mastodon::NotPermittedError
+    nil
+  end
+
   def fetched_resource
     @fetched_resource ||= FetchResourceService.new.call(@url)
   end