FEATURE: Add topic and category context to post webhook payload (#8110)
Adds additional fields topic_archetype and category_slug to the post webhook so that handlers have some context about the post event without having to call back to the API. Discussed [here](https://meta.discourse.org/t/webhooks-how-best-to-differentiate-a-pm-from-a-public-post/76363/13).
This commit is contained in:
parent
3ee6e859ec
commit
b7ebe574df
|
@ -2,7 +2,9 @@
|
||||||
|
|
||||||
class WebHookPostSerializer < PostSerializer
|
class WebHookPostSerializer < PostSerializer
|
||||||
|
|
||||||
attributes :topic_posts_count
|
attributes :topic_posts_count,
|
||||||
|
:topic_archetype,
|
||||||
|
:category_slug
|
||||||
|
|
||||||
def include_topic_title?
|
def include_topic_title?
|
||||||
true
|
true
|
||||||
|
@ -32,6 +34,18 @@ class WebHookPostSerializer < PostSerializer
|
||||||
object.topic ? object.topic.posts_count : 0
|
object.topic ? object.topic.posts_count : 0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def topic_archetype
|
||||||
|
object.topic ? object.topic.archetype : ''
|
||||||
|
end
|
||||||
|
|
||||||
|
def include_category_slug?
|
||||||
|
object.topic && object.topic.category
|
||||||
|
end
|
||||||
|
|
||||||
|
def category_slug
|
||||||
|
object.topic && object.topic.category ? object.topic.category.slug_for_url : ''
|
||||||
|
end
|
||||||
|
|
||||||
def include_readers_count?
|
def include_readers_count?
|
||||||
false
|
false
|
||||||
end
|
end
|
||||||
|
|
|
@ -12,7 +12,7 @@ RSpec.describe WebHookPostSerializer do
|
||||||
|
|
||||||
it 'should only include the required keys' do
|
it 'should only include the required keys' do
|
||||||
count = serialized_for_user(admin).keys.count
|
count = serialized_for_user(admin).keys.count
|
||||||
difference = count - 36
|
difference = count - 38
|
||||||
|
|
||||||
expect(difference).to eq(0), lambda {
|
expect(difference).to eq(0), lambda {
|
||||||
message = +""
|
message = +""
|
||||||
|
|
Loading…
Reference in New Issue