Webhook do evento de tópico quebrado - mensagens falsas de topic_created

Quero tomar uma ação quando houver um novo tópico. Portanto, tenho um webhook ativado para Eventos de Tópico. Verifico os cabeçalhos para ver se é um evento topic_created e, se for, tomo uma ação.

Isso funcionou por muitos meses, mas agora falha às vezes, possivelmente após a atualização na semana passada. Agora, às vezes, recebo topic_created nos cabeçalhos, no entanto, o tópico é na verdade antigo e alguém simplesmente respondeu ao tópico.

Meu código:

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

Exemplo de payload de uma solicitação que tinha event == ‘topic_created’ nos cabeçalhos. Observe que o suposto “novo” tópico na verdade foi criado em 2017 e tem 306 respostas.

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 curtidas

Há algumas evidências de que as mensagens falsas de topic_created são acionadas quando alguém responde por e-mail.

Eu adicionei uma correção aqui

1 curtida

Este tópico foi fechado automaticamente após 18 horas. Novas respostas não são mais permitidas.