sentry-create-alert

von sentry

Sentry-Benachrichtigungen mithilfe der Workflow-Engine-API erstellen. Verwenden, wenn aufgefordert, Benachrichtigungen zu erstellen, Mitteilungen einzurichten, Problemprioritätswarnungen zu konfigurieren oder Workflows zu erstellen…

npx skills add https://github.com/getsentry/agent-skills --skill sentry-create-alert

Create Sentry Alert

Create alerts via Sentry's workflow engine API.

Note: This API is currently in beta and may be subject to change. It is part of New Monitors and Alerts and may not be viewable in the legacy Alerts UI.

Invoke This Skill When

  • User asks to "create a Sentry alert" or "set up notifications"
  • User wants to be emailed or notified when issues match certain conditions
  • User mentions priority alerts, de-escalation alerts, or workflow automations
  • User wants to configure Slack, PagerDuty, or email notifications for Sentry issues

Prerequisites

  • curl available in shell
  • Sentry org auth token with alerts:write scope (also accepts org:admin or org:write)

Phase 1: Gather Configuration

Ask the user for any missing details:

DetailRequiredExample
Org slugYessentry, my-org
Auth tokenYessntryu_... (needs alerts:write scope)
RegionYes (default: us)usus.sentry.io, dede.sentry.io
Alert nameYes"High Priority De-escalation Alert"
Trigger eventsYesWhich issue events fire the workflow
ConditionsOptionalFilter conditions before actions execute
Action typeYesemail, slack, or pagerduty
Action targetYesUser email, team, channel, or service

Phase 2: Look Up IDs

Use these API calls to resolve names to IDs as needed.

API="https://{region}.sentry.io/api/0/organizations/{org}"
AUTH="Authorization: Bearer {token}"

# Find user ID by email
curl -s "$API/members/" -H "$AUTH" | python3 -c "
import json,sys
for m in json.load(sys.stdin):
  if m.get('email')=='USER_EMAIL' or m.get('user',{}).get('email')=='USER_EMAIL':
    print(m['user']['id']); break"

# List teams
curl -s "$API/teams/" -H "$AUTH" | python3 -c "
import json,sys
for t in json.load(sys.stdin):
  print(t['id'], t['slug'])"

# List integrations (for Slack/PagerDuty)
curl -s "$API/integrations/" -H "$AUTH" | python3 -c "
import json,sys
for i in json.load(sys.stdin):
  print(i['id'], i['provider']['key'], i['name'])"

Phase 3: Build Payload

Trigger Events

Pick which issue events fire the workflow. Use logicType: "any-short" (triggers must always use this).

TypeFires when
first_seen_eventNew issue created
regression_eventResolved issue recurs
reappeared_eventArchived issue reappears
issue_resolved_triggerIssue is resolved

Filter Conditions

Conditions that must pass before actions execute. Use logicType: "all", "any-short", or "none".

The comparison field is polymorphic — its shape depends on the condition type:

Typecomparison formatDescription
issue_priority_greater_or_equal75 (bare integer)Priority >= Low(25)/Medium(50)/High(75)
issue_priority_deescalatingtrue (bare boolean)Priority dropped below peak
event_frequency_count{"value": 100, "interval": "1hr"}Event count in time window
event_unique_user_frequency_count{"value": 50, "interval": "1hr"}Affected users in time window
tagged_event{"key": "level", "match": "eq", "value": "error"}Event tag matches
assigned_to{"targetType": "Member", "targetIdentifier": 123}Issue assigned to target
level{"level": 40, "match": "gte"}Event level (fatal=50, error=40, warning=30)
age_comparison{"time": "hour", "value": 24, "comparisonType": "older"}Issue age
issue_category{"value": 1}Category (1=Error, 6=Feedback)
issue_occurrences{"value": 100}Total occurrence count

Interval options: "1min", "5min", "15min", "1hr", "1d", "1w", "30d"

Tag match types: "co" (contains), "nc" (not contains), "eq", "ne", "sw" (starts with), "ew" (ends with), "is" (set), "ns" (not set)

Set conditionResult to false to invert (fire when condition is NOT met).

Actions

TypeKey Config
emailconfig.targetType: "user" / "team" / "issue_owners", config.targetIdentifier: <id>
slackintegrationId: <id>, config.targetDisplay: "#channel-name"
pagerdutyintegrationId: <id>, config.targetDisplay: <service_name>, data.priority: "critical"
discordintegrationId: <id>, data.tags: tag list
msteamsintegrationId: <id>, config.targetDisplay: <channel>
opsgenieintegrationId: <id>, data.priority: "P1"-"P5"
jiraintegrationId: <id>, data: project/issue config
githubintegrationId: <id>, data: repo/issue config

Full Payload Structure

{
  "name": "<Alert Name>",
  "enabled": true,
  "environment": null,
  "config": { "frequency": 30 },
  "triggers": {
    "logicType": "any-short",
    "conditions": [
      { "type": "first_seen_event", "comparison": true, "conditionResult": true }
    ],
    "actions": []
  },
  "actionFilters": [{
    "logicType": "all",
    "conditions": [
      { "type": "issue_priority_greater_or_equal", "comparison": 75, "conditionResult": true },
      { "type": "event_frequency_count", "comparison": {"value": 50, "interval": "1hr"}, "conditionResult": true }
    ],
    "actions": [{
      "type": "email",
      "integrationId": null,
      "data": {},
      "config": {
        "targetType": "user",
        "targetIdentifier": "<user_id>",
        "targetDisplay": null
      },
      "status": "active"
    }]
  }]
}

frequency: minutes between repeated notifications. Allowed values: 0, 5, 10, 30, 60, 180, 720, 1440.

Structure note: triggers.actions is always [] — actions live inside actionFilters[].actions.

Phase 4: Create the Alert

curl -s -w "\n%{http_code}" -X POST \
  "https://{region}.sentry.io/api/0/organizations/{org}/workflows/" \
  -H "Authorization: Bearer {token}" \
  -H "Content-Type: application/json" \
  -d '{payload}'

Expect HTTP 201. The response contains the workflow id.

Phase 5: Verify

Confirm the alert was created and provide the UI link:

https://{org_slug}.sentry.io/monitors/alerts/{workflow_id}/

If the org lacks the workflow-engine-ui feature flag, the alert appears at:

https://{org_slug}.sentry.io/alerts/rules/

Managing Alerts

# List all workflows
curl -s "$API/workflows/" -H "$AUTH"

# Get one workflow
curl -s "$API/workflows/{id}/" -H "$AUTH"

# Update a workflow
curl -s -X PUT "$API/workflows/{id}/" -H "$AUTH" -H "Content-Type: application/json" -d '{payload}'

# Delete a workflow
curl -s -X DELETE "$API/workflows/{id}/" -H "$AUTH"
# Expect 204

Troubleshooting

IssueSolution
401 UnauthorizedToken needs alerts:write scope
403 ForbiddenToken must belong to the target org
404 Not FoundCheck org slug and region (us vs de)
400 Bad RequestValidate payload JSON structure, check required fields
User ID not foundVerify email matches a member of the org

Mehr Skills von sentry

sentry-cli
sentry
Leitfaden zur Verwendung der Sentry-CLI zur Interaktion mit Sentry über die Befehlszeile. Verwenden Sie dies, wenn der Benutzer nach dem Anzeigen von Issues, Events, Projekten, Organisationen, dem Tätigen von API-Aufrufen oder der Authentifizierung mit Sentry über die CLI fragt.
developmentapidevops
sentry-cocoa-sdk
sentry
Vollständiges Sentry SDK-Setup für Apple-Plattformen (iOS, macOS, tvOS, watchOS, visionOS). Verwenden, wenn aufgefordert wird, "Sentry zu iOS hinzufügen", "Sentry zu Swift hinzufügen", "installieren…
official
sentry-dotnet-sdk
sentry
Vollständige Sentry SDK-Einrichtung für .NET. Verwenden, wenn aufgefordert wird, "Sentry zu .NET hinzuzufügen", "Sentry für C# zu installieren" oder Fehlerüberwachung, Tracing, Profiling, Logging oder… zu konfigurieren.
official
sentry-fix-issues
sentry
Finde und behebe Probleme aus Sentry mit MCP. Verwende, wenn du aufgefordert wirst, Sentry-Fehler zu beheben, Produktionsprobleme zu debuggen, Ausnahmen zu untersuchen oder Bugs zu beheben, die in… gemeldet wurden.
official
sentry-go-sdk
sentry
Vollständige Sentry-SDK-Einrichtung für Go. Verwenden, wenn aufgefordert, "Sentry zu Go hinzuzufügen", "sentry-go zu installieren", "Sentry in Go einzurichten" oder Fehlerüberwachung, Tracing, Protokollierung zu konfigurieren,…
official
sentry-ios-swift-setup
sentry
Richte Sentry in iOS/Swift-Apps ein. Verwende dies, wenn du aufgefordert wirst, Sentry zu iOS hinzuzufügen, das sentry-cocoa SDK zu installieren oder die Fehlerüberwachung für iOS-Anwendungen mit Swift zu konfigurieren…
official
sentry-nextjs-sdk
sentry
Vollständige Sentry-SDK-Einrichtung für Next.js. Verwenden, wenn aufgefordert wird, "Sentry zu Next.js hinzuzufügen", "@sentry/nextjs zu installieren" oder Fehlerüberwachung, Tracing, Session Replay zu konfigurieren,…
official
sentry-otel-exporter-setup
sentry
Konfigurieren Sie den OpenTelemetry Collector mit Sentry Exporter für Multi-Projekt-Routing und automatische Projekterstellung. Verwenden Sie dies beim Einrichten von OTel mit Sentry,…
official