Webhook retry failure logs for agent-bot now include the event payload,
making it easier to identify which event failed when debugging transient
upstream errors (429/500).
Previously the log only showed:
`[AgentBots::WebhookJob] attempt 1 failed
RestClient::InternalServerError`
Now it includes the payload:
`[AgentBots::WebhookJob] attempt 1 failed
RestClient::InternalServerError payload={"event":"message_created",...}`
Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
15 lines
645 B
Ruby
15 lines
645 B
Ruby
class AgentBots::WebhookJob < WebhookJob
|
|
queue_as :high
|
|
retry_on RestClient::TooManyRequests, RestClient::InternalServerError, wait: 3.seconds, attempts: 3 do |job, error|
|
|
url, payload, webhook_type = job.arguments
|
|
Webhooks::Trigger.new(url, payload, webhook_type || :agent_bot_webhook).handle_failure(error)
|
|
end
|
|
|
|
def perform(url, payload, webhook_type = :agent_bot_webhook)
|
|
super(url, payload, webhook_type)
|
|
rescue RestClient::TooManyRequests, RestClient::InternalServerError => e
|
|
Rails.logger.warn("[AgentBots::WebhookJob] attempt #{executions} failed #{e.class.name} payload=#{payload.to_json}")
|
|
raise
|
|
end
|
|
end
|