- What's new
InboxReady x Salesforce: The Key to a Stronger Email Deliverability
This is a guest post by Mihály Sáróy, Developer at EDMdesigner.
It’s been a while since the Mailgun PHP SDK came around, and we’ve seen lots of changes: new functionalities, new integrations built on top, new API endpoints…yet the core of PHP is the same. Since it was the first SDK for the Mailgun API, it’s had time to mature and go through iterations that make it easy to use – which we realized when we gave it a try.
In this post we’re going to show how you can implement the Mailgun API using PHP with PEAR.
We’re going to kick off this how-to by saying that transactional email is everywhere, and it’s important we get it right. Not getting email to work properly could mean losing revenue for your business and just overall creates an unpleasant experience for customers.
As a developer, you’re always looking to find the most simple (time-efficient) and powerful way to solve a problem. You often achieve this by fulfilling two conditions:
Using external libraries that apply to your solution.
Designing scalable applications.
No need to explain the first condition – you wouldn’t start to write an OS before coding an application, right? Throughout the post, we’ll look at how to use pre-written packages to send email. But now, on to my second point: read on.
For scalable design, this is where you look for services like Mailgun. You can expect a feature-rich solution that meets requirements for high-volume email sending.
If you care about delivery (and you should), Mailgun offers high reliability as it’s designed to handle transactional email very well. You can set up multiple domains and choose if you want to share IPs or build your own reputation. To protect your email headers, Mailgun requires DKIM and SPF be added to the account, and that they pass their checks at the authentication and alignment level. All of these things work together to help you with email delivery.
Now to the good stuff: setting up a PHP wrapper script for Mailgun. First, we’ll use the package manager and then see examples of how to apply it.
PEAR is a community driven initiative that lets us reuse PHP code components, while the dependent code is also added and maintained.
First, you will need PHP, and the package manager to continue. They’re best installed by Debian Advanced Package Manager (APT) if you’re using Linux.
Although PEAR is an older solution, it’s still widely used and it’s short for PHP Extension and Application Repository. Based on the installed PHP version, you probably already have PEAR available. You can check by running pear
command without arguments. If you receive a warning that your system doesn’t have it, just run: sudo apt install php-pear. Now, we’re ready to install third-party PHP code with PEAR.
If you follow this article by coding along, this is the point where you should open your Mailgun account to have access to the API. If you get stuck, just check these getting started bits of advice.
The steps with PEAR apply in the following way:
Installing project dependencies and including the packages by requiring the main class or the vendor/autoloader.php script
Provide API related variables
Instantiating the Mail class/client
Make function call to send the email(s)
Simple, right?
We can install the Mail package by typing sudo pear install Mail
. After it’s finished installing, the next step is to include that in a script file:
require_once "Mail.php";
Save yourself some time and do as our boilerplate suggests, then provide the API specific variables.
If you head to your API dashboard, you can find these necessary pieces of information under the domain tab:
We need the host
, account user
and password
variables, and the port
to use:
1$host = "smtp.mailgun.org";2$username = "postmaster@sandbox21a78f8...3eb160ebc79.mailgun.org";3$password = "75b958a6a0b...dd417c80133";4$port = "587";
We use SMTP connection to send email through our Mailgun account.
We gather the above parameters into an array and instantiate the Mail
class with this:
1$params = array ('host' => $host,2 'port' => $port,3 'auth' => true,4 'username' => $username,5 'password' => $password);67$smtp = Mail::factory ('smtp', $params);
The final step is to call the send()
method of the Mail
class and we are good to go:
1 $mail = $smtp->send($to, $headers, $email_body);
Here, the $to
variable holds the value for the recipient address, while the $headers
variable is an array, containing additional fields for delivery.
At this point, you may want to check out the full final code:
1<?php2require_once "Mail.php";34$host = "smtp.mailgun.org";5$username = "postmaster@sandbox21a78f8...3eb160ebc79.mailgun.org";6$password = "75b958a6a0b...dd417c80133";7$port = "587";8$to = "recipient@address.com";910$email_from = "example@sender.com";11$email_subject = "Awesome Subject line" ;12$email_body = "This is the message body" ;13$email_address = "replyto@sender.com";14$content = "text/html; charset=utf-8";15$mime = "1.0";1617$headers = array ('From' => $email_from,18'To' => $to,19'Subject' => $email_subject,20'Reply-To' => $email_address,21'MIME-Version' => $mime,22'Content-type' => $content);2324$params = array ('host' => $host,25'port' => $port,26'auth' => true,27'username' => $username,28'password' => $password);2930$smtp = Mail::factory ('smtp', $params);31$mail = $smtp->send($to, $headers, $email_body);3233if (PEAR::isError($mail)) {34echo("<p>" . $mail->getMessage() . "</p>");35} else {36echo("<p>Message sent successfully!</p>");37}
You can download the full source code here.
Moving on, if you set up everything, you can try to run the script: php mailer.php.
You run it, and receive an ugly error stack trace! Examine it closely:
PHP Fatal error: Uncaught Error: Class 'Net_SMTP' not found in /usr/share/php/Mail/smtp>php:366.
This means that we forgot to add another project dependency that’s necessary to use PEAR Mail. Run sudo pear install Net_SMTP
and try again!
The output is:
Message sent successfully!
If you followed along, then your message should have arrived to the specified mailbox, and I’m silent clapping for you. Bravo!
We saw the sample script to get started using Mailgun with the PEAR package manager, and we created PHP scripts to send an email with SMTP and the HTTP API. But there are other options you could use if PEAR isn’t your go-to choice. You could actually replicate the same outcome using Composer, and Mailgun has gone into detail about this previously on the blog.
And of course, if you wish to improve your skills with PHP, these are a few of my favorite resources that I would recommend for sending email with PHP and dealing with email HTML in general.
Learn about our Deliverability Services
Looking to send a high volume of emails? Our email experts can supercharge your email performance. See how we've helped companies like Lyft, Shopify, Github increase their email delivery rates to an average of 97%.
Last updated on March 17, 2022
InboxReady x Salesforce: The Key to a Stronger Email Deliverability
Implementing Dmarc – A Step-by-Step Guide
Email Bounces: What To Do About Them
How To Improve Your Email Deliverability In 2022
How to Conduct a Comprehensive Email Deliverability Audit
How to Improve the Way WordPress Websites Send Email
How To Prepare Your Infrastructure For Black Friday
Happy Festivus: Email Deliverability Guide For The Holiday Season
Spam Filters & Deliverability: Staying on the Good Side of Mailbox Providers
Meet Our Amazing Pathwire Mavericks!
InboxReady x Salesforce: The Key to a Stronger Email Deliverability
Become an Email Pro With Our Templates API
Google Postmaster Tools: Understanding Sender Reputation
Navigating Your Career as a Woman in Tech
Implementing Dmarc – A Step-by-Step Guide
Email Bounces: What To Do About Them
Announcing InboxReady: The deliverability suite you need to hit the inbox
Black History Month in Tech: 7 Visionaries Who Shaped The Future
How To Create a Successful Triggered Email Program
Designing HTML Email Templates For Transactional Emails
InboxReady x Salesforce: The Key to a Stronger Email Deliverability
Implementing Dmarc – A Step-by-Step Guide
Announcing InboxReady: The deliverability suite you need to hit the inbox
Designing HTML Email Templates For Transactional Emails
Email Security Best Practices: How To Keep Your Email Program Safe
Mailgun’s Active Defense Against Log4j
Email Blasts: The Dos And Many Don’ts Of Mass Email Sending
Email's Best of 2021
5 Ideas For Better Developer-Designer Collaboration
Mailgun Joins Sinch: The Future of Customer Communications Is Here
Always be in the know and grab free email resources!
By sending this form, I agree that Mailgun may contact me and process my data in accordance with its Privacy Policy.