Official Sinch API skills for AI coding agents — SMS, Voice, Verification, Numbers, Mailgun email, and more.
71
89%
Does it follow best practices?
Impact
—
No eval scenarios have been run
Advisory
Suggest reviewing before use
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.
"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.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"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.
--user except via a variable (as in the example above).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).skills
sinch-10dlc
references
sinch-authentication
sinch-conversation-api
sinch-elastic-sip-trunking
references
sinch-fax-api
sinch-imported-numbers-hosting-orders
references
sinch-in-app-calling
sinch-mailgun
references
sinch-mailgun-inspect
references
sinch-mailgun-optimize
references
sinch-mailgun-validate
sinch-number-lookup-api
sinch-number-order-api
sinch-numbers-api
references
sinch-porting-api
sinch-provisioning-api
sinch-sdks
sinch-verification-api