The Mailgun API is built on HTTP. Our API is RESTful and it:
- Uses predictable, resource-oriented URLs.
- Uses built-in HTTP capabilities for passing parameters and authentication.
- Responds with standard HTTP response codes to indicate errors.
- Returns JSON.
Mailgun has published Libraries for various languages. You may use our libraries, or your favorite HTTP/REST library available for your programming language, to make HTTP calls to Mailgun. Visit our Libraries page to see HTTP REST libraries we recommend.
To give you an idea of how to use the API, we have annotated our documentation with code samples written in several popular programming languages. Use the language selector at the top to switch between them.
All API URLs referenced in this documentation start with a base part. For non EU customers the base URL is:
For EU customers the base URL is:
Your Mailgun account may contain several email domains. To avoid passing the domain name as a query parameter, most API URLs must include the name of the domain you’re interested in:
When you sign up for an account, you are given an API key. You authenticate to the Mailgun API by providing your API key in the request. You can manage your API key in the “Security” tab under the Account section of the Control Panel.
Authentication to the API occurs via HTTP Basic Auth. Use
api as the user
name and your API key is the password. Here is how you use basic HTTP auth with curl:
curl --user 'api:YOUR_API_KEY'
Or you can try the following API call right from your browser:
Keep your API key secret!
'Thu, 13 Oct 2011 18:02:00 GMT'
Mailgun returns standard HTTP response codes.
|200||Everything worked as expected|
|400||Bad Request - Often missing a required parameter|
|401||Unauthorized - No valid API key provided|
|402||Request Failed - Parameters were valid but request failed|
|404||Not Found - The requested item doesn’t exist|
|413||Request Entity Too Large - Attachment size is too big|
|500, 502, 503, 504||Server Errors - something is wrong on Mailgun’s end|
Using a single account and billing plan, you can choose to provision new sending domains in the EU environment. Message data never leaves the region in which it is processed. Only a limited amount of account data is replicated globally, giving you a single account from which to manage domains in both the US and the EU. Here are the specifics on the type of data that is replicated globally versus what is region-bound.
|Global||Region-Bound (US / EU)|
|Account Information, User Accounts, Billing Details (invoices/plan information), API Keys, Domain Names||Domain Metadata (e.g. SMTP credentials), Messages, Event Logs, Suppressions, Mailing Lists, Tags, Statistics, Routes, IP Addresses|
Below are the endpoints you will use for sending/receiving/tracking messages in the EU:
|Service||US Endpoint||EU Endpoint|
|Outgoing SMTP Server||smtp.mailgun.org||smtp.eu.mailgun.org|
|Inbound SMTP Server (Routes)||mxa.mailgun.org||mxa.eu.mailgun.org|
|Inbound SMTP Server (Routes)||mxb.mailgun.org||mxb.eu.mailgun.org|
|Open/Click Tracking Endpoint||mailgun.org||eu.mailgun.org|
Mailgun has a Postman Collection available for quick and easy exercise of our REST-based APIs. Included in the collection is a Mailgun Environment for easy changing of domains, regions and API keys. Use the button below for easy import into Postman. Don’t have Postman? Click here.
Read more about Mailgun and Postman on our blog.