Changelog #89
Alert webhooks
Receive a webhook alert when runs fail, deploys fail, or deploys succeed.
data:image/s3,"s3://crabby-images/39aa3/39aa3236ddaefcd38aec3e9373a183f561ec7964" alt="Matt Aitken"
CEO, Trigger.dev
data:image/s3,"s3://crabby-images/68e46/68e463a94522811acb582896c01d34fd83518c6b" alt="Image for Alert webhooks"
We've added support for webhook alerts in Trigger.dev. Now you can receive alerts via webhooks when runs fail, deployments fail, or deployments succeed. This complements our existing email and Slack notification options.
How it works
You can now setup webhook alerts through our dashboard and handle them in your application using our SDK. When an alert is triggered, we'll send a POST request to your specified endpoint with details about the event.
Setting up webhook alerts
- Navigate to the "Alerts" section in the dashboard
- Click "New alert"
- Select "Webhook" as your alert method
- Choose which events you want to receive alerts for:
- Run failures
- Deployment failures
- Deployment successes
- Enter your webhook URL
- Copy the generated webhook secret - you'll need this to verify webhooks
Handling webhooks
Here's how to handle webhook alerts in your application using the Trigger.dev SDK. In this exammple, we're using the Remix framework:
import { ActionFunctionArgs, json } from "@remix-run/server-runtime";import { webhooks, WebhookError } from "@trigger.dev/sdk/v3";export async function action({ request }: ActionFunctionArgs) { if (request.method !== "POST") { return json({ error: "Method not allowed" }, { status: 405 }); } try { const event = await webhooks.constructEvent(request, process.env.ALERT_WEBHOOK_SECRET!); // Handle different alert types switch (event.type) { case "alert.run.failed": { console.log("Run failed alert received", { event }); break; } case "alert.deployment.success": { console.log("Deployment succeeded alert received", { event }); break; } case "alert.deployment.failed": { console.log("Deployment failed alert received", { event }); break; } } return json({ received: true }); } catch (err) { if (err instanceof WebhookError) { return json({ error: err.message }, { status: 400 }); } return json({ error: "Internal server error" }, { status: 500 }); }}
Why is this useful?
Webhook alerts allow you to:
- Build custom alert handling logic
- Integrate alerts with your existing monitoring systems
- Automate responses to failed runs or deployments
- Track deployment success/failure rates
Next steps
Check out our Alerts documentation to learn more about setting up alerts. If you have questions or need help, join us on Discord or reach out on Twitter.