Событие вебхука темы не работает: ложные сообщения topic_created

Я хочу выполнять какое-то действие, когда появляется новая тема. Для этого я включил вебхук для событий тем. Я проверяю заголовки, чтобы определить, является ли событие событием создания темы (topic_created), и если да, то выполняю действие.

Это работало в течение многих месяцев, но теперь иногда не срабатывает, возможно, после обновления на прошлой неделе. Теперь иногда в заголовках приходит событие topic_created, однако тема на самом деле старая, и кто-то просто ответил на неё.

Мой код:

    event_type = request.headers['X-Discourse-Event-Type']
    event = request.headers['X-Discourse-Event']
    if event_type == 'topic' and event == 'topic_created':
         take_action()

Пример полезной нагрузки (payload) из запроса, в котором в заголовках было событие event == ‘topic_created’. Обратите внимание, что предполагаемая «новая» тема была на самом деле создана в 2017 году и имеет 306 ответов.

payload
{
	'bookmarked': False,
	'word_count': 272108,
	'visible': True,
	'like_count': 567,
	'highest_post_number': 758,
	'has_deleted': True,
	'tags_descriptions': {},
	'deleted_at': None,
	'archetype': 'regular',
	'id': 1357,
	'pinned_until': None,
	'archived': False,
	'user_id': 4,
	'title': 'Tax Time! Discussions of Taxes and Accountants',
	'last_posted_at': '2022-01-05T01:41:26.000Z',
	'tags': [],
	'created_by': {
		'username': 'redacted',
		'avatar_template': '/user_avatar/forum.redacted.com/redacted/{size}/45_2.png',
		'id': 4,
		'name': 'redacted'
	},
	'pinned': False,
	'queued_posts_count': 0,
	'closed': False,
	'unpinned': None,
	'participant_count': 162,
	'views': 19557,
	'pinned_at': None,
	'last_poster': {
		'username': 'redacted',
		'avatar_template': '/letter_avatar_proxy/v4/letter/j/45deac/{size}.png',
		'id': 142,
		'name': 'JohnJacobs'
	},
	'pending_posts': [],
	'posts_count': 744,
	'slug': 'tax-time-discussions-of-taxes-and-accountants',
	'thumbnails': None,
	'created_at': '2017-01-21T00:25:01.000Z',
	'deleted_by': None,
	'featured_link': None,
	'reply_count': 306,
	'pinned_globally': False,
	'category_id': 16,
	'fancy_title': 'Tax Time! Discussions of Taxes and Accountants'
}
2 лайка

Существуют свидетельства того, что ложные сообщения topic_created генерируются, когда кто-то отвечает по электронной почте.

Я добавил исправление здесь

1 лайк

Эта тема была автоматически закрыта через 18 часов. Новые ответы больше не принимаются.