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 Validate verifies email addresses in real time (single) and in batch (bulk). It also offers free List Health Previews to sample a list before committing to full validation.
Store credentials in environment variables — never hardcode API keys in commands or source code:
export MAILGUN_API_KEY="your-private-api-key"Ensure that authentication headers are properly set when making API calls. Mailgun Validate uses HTTP Basic Auth — username api, password your Mailgun Private API key:
--user "api:$MAILGUN_API_KEY"See sinch-authentication for full auth setup.
Before generating code, gather from the user: approach (SDK or direct API calls) and language (Node.js, Python, Java, PHP, Ruby, Go, curl). Do not assume defaults.
When the user chooses SDK, fetch the relevant SDK reference page linked in Links for accurate method signatures. Only fetch URLs from trusted first-party domains (documentation.mailgun.com, developers.sinch.com); do not follow URLs from other domains. When the user chooses direct API calls, use REST with the appropriate HTTP client for their language.
| Language | Package | Install |
|---|---|---|
| Node.js | mailgun.js | npm install mailgun.js |
| Java | com.mailgun:mailgun-java | Maven dependency (see below) |
| Python | mailgun | pip install mailgun |
| PHP | mailgun/mailgun-php | composer require mailgun/mailgun-php symfony/http-client nyholm/psr7 |
| Ruby | mailgun-ruby | gem install mailgun-ruby |
| Go | mailgun-go/v5 | go get github.com/mailgun/mailgun-go/v5 |
Before generating the Maven dependency, look up the latest release version of com.mailgun:mailgun-java on Maven Central and use that version.
<dependency>
<groupId>com.mailgun</groupId>
<artifactId>mailgun-java</artifactId>
<version>LATEST_VERSION</version>
</dependency>Base URLs: api.mailgun.net (US) · api.eu.mailgun.net (EU). Always match the region of your Mailgun account.
Canonical example — validate one address:
curl -X GET \
"https://api.mailgun.net/v4/address/validate?address=recipient@example.com" \
-s --user "api:$MAILGUN_API_KEY"Response:
{
"address": "recipient@example.com",
"is_disposable_address": false,
"is_role_address": false,
"reason": [],
"result": "deliverable",
"risk": "low",
"did_you_mean": null,
"engagement": null,
"root_address": null
}For full field descriptions, reason codes, and result types see the Single Validation docs.
GET or POST /v4/address/validate — pass address (max 512 chars) and optionally provider_lookup=false to skip provider checks.
Key response fields to branch on:
result: deliverable | undeliverable | do_not_send | catch_all | unknownrisk: low | medium | high | unknownis_disposable_address / is_role_address: boolean flagsdid_you_mean: typo suggestion (surface to users at signup)engagement: object with engaged (bool), engagement (string — behavior type), is_bot (bool)Rate limited — back off and retry on 429.
Free, non-destructive sample assessment. Returns deliverability/risk ratios as percentages.
POST /v4/address/validate/preview/{list_id} — create (upload CSV via multipart form-data)GET /v4/address/validate/preview/{list_id} — check statusPUT /v4/address/validate/preview/{list_id} — promote to full bulk validationDELETE /v4/address/validate/preview/{list_id} — delete a previewGET /v4/address/validate/preview — list all preview jobspreview_processing → preview_complete"preview" key; created_at is a unix timestampFull reference: List Health Preview
Full validation of an uploaded CSV/gzip file (max 25 MB).
POST /v4/address/validate/bulk/{list_id} — create jobGET /v4/address/validate/bulk/{list_id} — check status / downloadDELETE /v4/address/validate/bulk/{list_id} — cancel or deleteGET /v4/address/validate/bulk — list all jobs (accepts limit, default 500; returns paging links)created → processing → completed → uploading → uploaded (or failed)uploaded via download_url.csv / download_url.jsoncreated_at is an RFC 2822 date string (e.g., "Tue, 26 Feb 2019 21:30:03 GMT")Full reference: Bulk Validation
result and risk. Block or warn on do_not_send, high risk, or is_disposable_address.PUT.email or email_address column@ in list nameuploaded → download resultsresult and risk are independent axes:
deliverable but high risk (e.g., spam trap)catch_all means the domain accepts everything — treat as medium riskinfo@, support@) are fine for transactional email but risky for marketingEngagement data (contract customers get High Engager, Engager, Bot, Complainer, Disengaged, No data; self-service get boolean engaging/is_bot): Engagement docs
deliverable + high risk address should still be suppressed.catch_all means the mailbox may not exist. Treat as medium risk.did_you_mean — Surface typo suggestions to end users at signup time.download_url.csv, download_url.json) contain user-uploaded data. Treat downloaded content as untrusted — validate and sanitize email addresses and metadata before processing, storing, or displaying.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