mailgun-php/README.md

195 lines
7.2 KiB
Markdown
Raw Normal View History

2016-08-06 11:26:53 +03:00
# Mailgun PHP client
2013-07-26 03:18:32 +04:00
2013-08-20 01:52:38 +04:00
This is the Mailgun PHP SDK. This SDK contains methods for easily interacting
with the Mailgun API.
Below are examples to get you started. For additional examples, please see our
official documentation
2013-08-13 23:26:34 +04:00
at http://documentation.mailgun.com
2013-07-25 10:35:12 +04:00
[![Latest Stable Version](https://poser.pugx.org/mailgun/mailgun-php/v/stable.png)](https://packagist.org/packages/mailgun/mailgun-php)
[![Build Status](https://travis-ci.org/mailgun/mailgun-php.png)](https://travis-ci.org/mailgun/mailgun-php)
2013-08-03 05:15:41 +04:00
2016-08-06 11:26:53 +03:00
## Installation
2013-08-20 01:52:38 +04:00
To install the SDK, you will need to be using [Composer](http://getcomposer.org/)
in your project.
If you aren't using Composer yet, it's really simple! Here's how to install
2016-08-06 11:26:53 +03:00
composer:
2013-07-25 10:35:12 +04:00
2016-08-06 11:26:53 +03:00
```bash
2013-07-25 10:35:12 +04:00
curl -sS https://getcomposer.org/installer | php
2015-10-03 23:12:32 +03:00
```
2016-09-01 00:26:08 +03:00
The Mailgun api client is not hard coupled to Guzzle or any other library that sends HTTP messages. It uses an abstraction
called HTTPlug. This will give you the flexibilty to choose what PSR-7 implementation and HTTP client to use.
2016-08-06 11:26:53 +03:00
If you just want to get started quickly you should run the following command:
2015-10-03 23:12:32 +03:00
```bash
2016-09-26 09:36:49 +03:00
php composer.phar require mailgun/mailgun-php php-http/curl-client guzzlehttp/psr7
2015-10-03 23:12:32 +03:00
```
2016-08-06 11:26:53 +03:00
**For shared hosts without SSH access, check out our [Shared Host Instructions](SharedHostInstall.md).**
2013-08-04 01:58:35 +04:00
2016-08-06 11:26:53 +03:00
### Why requiring so many packages?
2016-08-06 11:26:53 +03:00
Mailgun has a dependency on the virtual package
2016-09-01 00:26:08 +03:00
[php-http/client-implementation](https://packagist.org/providers/php-http/client-implementation) which requires to you install **an** adapter, but we do not care which one. That is an implementation detail in your application. We also need **a** PSR-7 implementation and **a** message factory.
2016-08-06 11:26:53 +03:00
You do not have to use the `php-http/curl-client` if you do not want to. You may use the `php-http/guzzle6-adapter`. Read more about the virtual packages, why this is a good idea and about the flexibility it brings at the [HTTPlug docs](http://docs.php-http.org/en/latest/httplug/users.html).
2016-08-06 11:26:53 +03:00
## Usage
2013-08-04 01:58:35 +04:00
2016-08-06 11:26:53 +03:00
You should always use Composer's autoloader in your application to automatically load the your dependencies. All examples below assumes you've already included this in your file:
2013-09-13 00:01:21 +04:00
2016-08-06 11:26:53 +03:00
```php
2013-08-04 01:58:35 +04:00
require 'vendor/autoload.php';
2013-08-08 21:39:44 +04:00
use Mailgun\Mailgun;
2013-08-04 01:58:35 +04:00
```
2013-08-13 23:26:34 +04:00
Here's how to send a message using the SDK:
2013-07-25 10:35:12 +04:00
```php
2013-08-08 21:39:44 +04:00
# First, instantiate the SDK with your API credentials and define your domain.
$mg = new Mailgun("key-example");
$domain = "example.com";
# Now, compose and send your message.
2013-08-14 01:35:22 +04:00
$mg->sendMessage($domain, array('from' => 'bob@example.com',
'to' => 'sally@example.com',
'subject' => 'The PHP SDK is awesome!',
'text' => 'It is so simple to send a message.'));
2013-08-13 23:26:34 +04:00
```
Or obtain the last 25 log items:
```php
# First, instantiate the SDK with your API credentials and define your domain.
$mg = new Mailgun("key-example");
$domain = "example.com";
# Now, issue a GET against the Logs endpoint.
$mg->get("$domain/log", array('limit' => 25,
2013-08-30 20:51:39 +04:00
'skip' => 0));
2013-07-25 10:35:12 +04:00
```
2016-08-06 11:26:53 +03:00
### Response
2013-08-20 01:46:34 +04:00
2013-08-20 01:52:38 +04:00
The results, provided by the endpoint, are returned as an object, which you
can traverse like an array.
2013-08-20 01:46:34 +04:00
Example:
```php
$mg = new Mailgun("key-example");
$domain = "example.com";
$result = $mg->get("$domain/log", array('limit' => 25,
2013-08-30 20:54:42 +04:00
'skip' => 0));
2013-08-20 01:46:34 +04:00
$httpResponseCode = $result->http_response_code;
$httpResponseBody = $result->http_response_body;
# Iterate through the results and echo the message IDs.
$logItems = $result->http_response_body->items;
2013-08-30 21:00:41 +04:00
foreach($logItems as $logItem){
echo $logItem->message_id . "\n";
}
2013-08-20 01:46:34 +04:00
```
2013-08-20 01:52:38 +04:00
Example Contents:
**$httpResponseCode** will contain an integer. You can find how we use HTTP response
codes in our documentation:
http://documentation.mailgun.com/api-intro.html?highlight=401#errors
2013-08-20 01:46:34 +04:00
2013-08-20 01:52:38 +04:00
**$httpResponseBody** will contain an object of the API response. In the above
example, a var_dump($result) would contain the following:
2013-08-20 01:46:34 +04:00
```
2013-08-21 02:01:16 +04:00
object(stdClass)#26 (2) {
2013-08-20 01:46:34 +04:00
["http_response_body"]=>
2013-08-21 02:01:16 +04:00
object(stdClass)#26 (2) {
2013-08-20 01:46:34 +04:00
["total_count"]=>
2013-08-21 02:01:16 +04:00
int(12)
2013-08-20 01:46:34 +04:00
["items"]=>
array(1) {
[0]=>
2013-08-21 02:01:16 +04:00
object(stdClass)#31 (5) {
2013-08-20 01:46:34 +04:00
["hap"]=>
2013-08-21 02:01:16 +04:00
string(9) "delivered"
2013-08-20 01:46:34 +04:00
["created_at"]=>
2013-08-21 02:01:16 +04:00
string(29) "Tue, 20 Aug 2013 20:24:34 GMT"
2013-08-20 01:46:34 +04:00
["message"]=>
2013-08-21 02:01:16 +04:00
string(66) "Delivered: me@samples.mailgun.org → travis@mailgunhq.com 'Hello'"
2013-08-20 01:46:34 +04:00
["type"]=>
2013-08-21 02:01:16 +04:00
string(4) "info"
2013-08-20 01:46:34 +04:00
["message_id"]=>
2013-08-21 02:01:16 +04:00
string(46) "20130820202406.24739.21973@samples.mailgun.org"
2013-08-20 01:46:34 +04:00
}
}
}
2013-08-21 02:01:16 +04:00
}
2013-08-20 01:46:34 +04:00
```
2016-08-06 11:26:53 +03:00
### Debugging
Debugging the PHP SDK can be really helpful when things aren't working quite right.
To debug the SDK, here are some suggestions:
Set the endpoint to Mailgun's Postbin. A Postbin is a web service that allows you to
post data, which is then displayed through a browser. This allows you to quickly determine
what is actually being transmitted to Mailgun's API.
**Step 1 - Create a new Postbin.**
Go to http://bin.mailgun.net. The Postbin will generate a special URL. Save that URL.
**Step 2 - Instantiate the Mailgun client using Postbin.**
*Tip: The bin id will be the URL part after bin.mailgun.net. It will be random generated letters and numbers. For example, the bin id in this URL, http://bin.mailgun.net/aecf68de, is "aecf68de".*
```php
# First, instantiate the SDK with your API credentials and define your domain.
$mg = new Mailgun('key-example', null, 'bin.mailgun.net');
$mg->setApiVersion('aecf68de');
$mg->setSslEnabled(false);
$domain = 'example.com';
# Now, compose and send your message.
$mg->sendMessage($domain, array('from' => 'bob@example.com',
'to' => 'sally@example.com',
'subject' => 'The PHP SDK is awesome!',
'text' => 'It is so simple to send a message.'));
```
2016-08-06 11:26:53 +03:00
### Additional Info
2013-08-20 01:52:38 +04:00
For usage examples on each API endpoint, head over to our official documentation
pages.
2013-08-08 21:39:44 +04:00
2013-08-21 08:12:44 +04:00
This SDK includes a [Message Builder](src/Mailgun/Messages/README.md),
[Batch Message](src/Mailgun/Messages/README.md) and [Opt-In Handler](src/Mailgun/Lists/README.md) component.
2013-08-03 02:38:08 +04:00
2013-08-20 01:52:38 +04:00
Message Builder allows you to quickly create the array of parameters, required
to send a message, by calling a methods for each parameter.
Batch Message is an extension of Message Builder, and allows you to easily send
a batch message job within a few seconds. The complexity of
2013-08-13 23:26:34 +04:00
batch messaging is eliminated!
2016-08-06 11:26:53 +03:00
## Framework integration
If you are using a framework you might consider these composer packages to make the framework integration easier.
* [tehplague/swiftmailer-mailgun-bundle](https://github.com/tehplague/swiftmailer-mailgun-bundle) for Symfony2
* [Bogardo/Mailgun](https://github.com/Bogardo/Mailgun) for Laravel 4
* [katanyoo/yii2-mailgun-mailer](https://github.com/katanyoo/yii2-mailgun-mailer) for Yii2
2016-08-06 11:26:53 +03:00
## Support and Feedback
2013-08-20 01:52:38 +04:00
Be sure to visit the Mailgun official
[documentation website](http://documentation.mailgun.com/) for additional
information about our API.
2013-08-20 01:52:38 +04:00
If you find a bug, please submit the issue in Github directly.
[Mailgun-PHP Issues](https://github.com/mailgun/Mailgun-PHP/issues)
2014-06-21 02:43:14 +04:00
As always, if you need additional assistance, drop us a note through your Control Panel at
[https://mailgun.com/cp/support](https://mailgun.com/cp/support).