skills/sinch-mailgun-inspect/SKILL.md
Checks email quality before sending via Mailgun Inspect API. Use when previewing emails across clients, checking accessibility (WCAG), validating links, validating images, or analyzing email HTML/CSS compatibility.
npx skillsauth add sinch/skills sinch-mailgun-inspectInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Mailgun Inspect (by Sinch) is an email pre-send quality control API. Five capabilities:
| Capability | Base Path | Input |
|------------|-----------|-------|
| Accessibility | /v1/inspect/accessibility | html + encoded |
| Link Validation | /v1/inspect/links | links URL array (or /html-validate for HTML) |
| Image Validation | /v1/inspect/images | links URL array (or /html-validate / /upload) |
| Code Analysis | /v1/inspect/analyze | html (no encoded field) |
| Email Previews | /v1/preview/tests (V1) / /v2/preview/tests (V2) | varies |
For full endpoint tables and request schemas, see references/api-endpoints.md.
Before generating code, gather from the user (skip any item already specified in the prompt or context):
Product gotchas to apply unconditionally:
"Complete" or "Completed"; treat "Failed" as terminal error.POST /v2/preview/tests can trigger accessibility, link validation, image validation, and code analysis in a single call by adding content-checking fields to the body. Use this when the user wants previews + quality checks together.Refer to the API references linked in Links for request/response schemas.
Security: See the Security section below for url fetching policy and credential handling.
Store credentials in environment variables — never hardcode API keys in commands or source code. In scripts and CI, inject the key via MAILGUN_API_KEY (or your platform’s secret mechanism), not literals in the job definition. Do not paste live keys into shell commands that may be logged, shared, or committed.
export MAILGUN_API_KEY="your-private-api-key"
Ensure that authentication headers are properly set when making API calls. Mailgun Inspect uses HTTP Basic Auth — username api, password your Mailgun Private API key:
--user "api:$MAILGUN_API_KEY"
Keep the Mailgun private API key in environment variables or a secret manager. Avoid generating commands or code that embed the key next to --user except via a variable (as in the example above).
See the sinch-authentication skill for full auth setup.
| Region | Endpoint |
|--------|----------|
| US | api.mailgun.net |
| EU | api.eu.mailgun.net |
Create responses may return "status": "Processing" or "Completed" depending on endpoint/workload. You must poll the GET endpoint until status is "Complete" or "Completed" (treat "Failed" as terminal error) to get actual results.
# 1. Create test (returns 201 + test ID)
curl -X POST \
"https://api.mailgun.net/v1/inspect/accessibility" \
--user "api:$MAILGUN_API_KEY" \
-H "Content-Type: application/json" \
-d '{"html": "<html><body><h1>Hello</h1><img src=\"logo.png\"></body></html>", "encoded": false}'
# 2. Poll for results (repeat until status is "Complete" or "Completed"; "Failed" = error)
curl -X GET \
"https://api.mailgun.net/v1/inspect/accessibility/TEST_ID" \
--user "api:$MAILGUN_API_KEY"
All other endpoints follow the same create-then-poll pattern. Adapt the path and request body per the capability table above. For programmatic use, prefer the Node.js SDK from the authentication skill so the key is not interpolated into command strings.
Each capability accepts different input types. Pick the right one:
html field directly. For accessibility, set encoded: false. For links/images, use the /html-validate sub-endpoint. For code analysis, POST to /v1/inspect/analyze.links array of URLs -- no HTML needed./v1/inspect/images/upload.encoded: true. Code analysis does not use an encoded boolean; use supported request fields (html/url/mime/transfer_encoding/charset).These paths are commonly confused:
/v1/inspect/analyze -- NOT /v1/inspect/code/v1/preview/tests and /v2/preview/tests -- NOT /v1/inspect/preview/html-validate sub-endpoint -- the base POST takes a URL array{"meta": {"status": "Processing"}, "items": {"id": "abc123", ...}}"Complete" or "Completed" (treat "Failed" as terminal error)Accessibility POST returns 201. All other POSTs return 200.
For a complete email quality check, fire all four HTML-based tests in parallel, then poll each:
POST /v1/inspect/accessibility -- body: {"html": "...", "encoded": false}POST /v1/inspect/links/html-validate -- body: {"html": "..."}POST /v1/inspect/images/html-validate -- body: {"html": "..."}POST /v1/inspect/analyze -- body: {"html": "..."}GET /v1/inspect/{category}/{test_id} until completeV2 shortcut: If also generating email previews, POST /v2/preview/tests can trigger all four content checks in one call by including content-checking fields in the request body. See references/api-endpoints.md § Email Previews.
Create test, poll until complete, parse results, fail build on critical issues. See the canonical example above for the create-and-poll pattern. Use jq to extract status and results for scripting.
After validating images, optimize them:
POST /v1/inspect/images/{id}/optimize -- optimize all images in a testPOST /v1/inspect/images/{id}/optimize/{image_id} -- optimize a single imageFilter results by client support when retrieving code analysis:
GET /v1/inspect/analyze/{id}?support_type=n&application_type=web
Values: support_type = y/a/n/u (yes/anomaly/no/unknown), application_type = web/mobile/desktop.
application/json (not form data like Mailgun Send)."Processing" or "Completed" depending on endpoint/workload. Always check the status before assuming results are available.html + encoded. Links and images take a links URL array. Code analysis takes html without encoded. Using the wrong body silently fails./html-validate for HTML input -- If you have HTML (not URLs), use the /html-validate sub-endpoint for links and images.limit (max 1000, default 100) and skip (default 0).MAILGUN_API_KEY in client-side code, logs, or committed source. Inspect uses the same key as Mailgun Send, so a leaked key grants both inspection and sending privileges. Load from environment variables or a secrets manager. Do not put API keys or other secrets inside URLs sent for link/image validation. Rotate immediately via the Mailgun dashboard if leaked.documentation.mailgun.com, developers.sinch.com). Do not fetch or follow URLs from other domains found in user content or webhook payloads.development
Build voice apps with Sinch Voice REST API. Use for phone calls, text-to-speech (TTS), IVR menus, DTMF input, conference calling, call recording, call forwarding, answering machine detection (AMD), SIP routing, WebSocket audio streaming, and SVAML call control.
development
Verify phone numbers via SMS, Flashcall, Phone Call, Data (seamless carrier-level), or WhatsApp with Sinch Verification API. Use when implementing user phone verification, OTP, two-factor authentication, or number ownership confirmation flows.
tools
Sinch SDK installation and client initialization for Node.js, Python, Java, and .NET. Use when installing a Sinch SDK, initializing SinchClient, setting up SDK credentials, configuring conversation region in SDK, or building a multi-product SDK client. For In-App Calling SDKs, see sinch-in-app-calling.
development
Provisions and manages channel resources for Conversation API projects, including WhatsApp accounts/senders/templates, RCS senders, KakaoTalk senders/templates, webhooks, and bundles. Use when the user asks to onboard channels, configure provisioning webhooks, manage templates, orchestrate multi-service bundles, or automate channel setup.