about summary refs log tree commit diff
path: root/app/lib/activitypub/serializer.rb
diff options
context:
space:
mode:
authorThibG <thib@sitedethib.com>2019-09-03 22:52:32 +0200
committerEugen Rochko <eugen@zeonfederated.com>2019-09-03 22:52:32 +0200
commit692c5b439ae8659e459da692cf9e6b8e6f29d2a1 (patch)
treed2017e07bc174ad55a910f4c4c85c03f8c7f1407 /app/lib/activitypub/serializer.rb
parentec1dd865fb09de2505e24001bdb5f3ac82f34a43 (diff)
Fix ActivityPub context not being dynamically computed (#11746)
* Fix contexts not being dynamically included

Fixes #11649

* Refactor Note context in serializer

* Refactor Actor serializer
Diffstat (limited to 'app/lib/activitypub/serializer.rb')
-rw-r--r--app/lib/activitypub/serializer.rb8
1 files changed, 8 insertions, 0 deletions
diff --git a/app/lib/activitypub/serializer.rb b/app/lib/activitypub/serializer.rb
index 07bd8c494..1fdc79310 100644
--- a/app/lib/activitypub/serializer.rb
+++ b/app/lib/activitypub/serializer.rb
@@ -27,4 +27,12 @@ class ActivityPub::Serializer < ActiveModel::Serializer
       _context_extensions[extension_name] = true
     end
   end
+
+  def serializable_hash(adapter_options = nil, options = {}, adapter_instance = self.class.serialization_adapter_instance)
+    unless adapter_options&.fetch(:named_contexts, nil).nil?
+      adapter_options[:named_contexts].merge!(_named_contexts)
+      adapter_options[:context_extensions].merge!(_context_extensions)
+    end
+    super(adapter_options, options, adapter_instance)
+  end
 end