How To Send Email from Your Joomla Extension

January 26, 2010 | by Brian Edgerton

Because of it ubiquitous nature, automatic emailing is something that many clients expect. People want to be notified immediately of changes on their sites -- when a new article has been submitted, or a blog comment has been posted. Joomla! already provides some of this functionality out of the box by notifying administrators when a user has registered on their site. You, however, may find yourself needing to implement emailing in your own components. As you may have already guessed, Joomla! provides a very helpful class for this: JMail.

With just a few lines of code, you can send your first email:

# Set some variables for the email message
$subject = "You have a new message";
$body = "Here is the body of your message.";
$to = "someone@yourdomain.com";
$from = array("me@mydomain.com", "Brian Edgerton");
 
# Invoke JMail Class
$mailer = JFactory::getMailer();
 
# Set sender array so that my name will show up neatly in your inbox
$mailer->setSender($from);
 
# Add a recipient -- this can be a single address (string) or an array of addresses
$mailer->addRecipient($to);
 
$mailer->setSubject($subject);
$mailer->setBody($subject);
 
# If you would like to send as HTML, include this line; otherwise, leave it out
$mailer->isHTML();
 
# Send once you have set all of your options
$mailer->send();
 

That's all there is to it for sending a simple email. If you would like to add carbon copy recipients, include the following before sending the email:

$mailer->addCC("carboncopy@yourdomain.com");
 
# Add a blind carbon copy
$mailer->addBCC("blindcopy@yourdomain.com");
 

Need to add an attachment? No problem:

 

$file = JPATH_SITE."/path/to/file.doc";
$mailer->addAttachment($file);
 

As you can see, it really can't get much simpler or straightforward for sending an email. There are several more methods available in JMail. You should also check out JMailHelper. It provides several functions to help you secure input from users before passing it along in an email. Consider the following:

# Import JMailHelper
jimport('joomla.mail.helper');
 
$to = JRequest::getVar('to', '', 'post');
$subject = JRequest::getVar('subject', '', 'post');
$body = JRequest::getVar('body', '', 'post');
$from = JRequest::getVar('from', '', 'post');
 
if (!JMailHelper::isEmailAddress($to) || !JMailHelper::isEmailAddress($from)) :
    return false;
endif;
 
if (!JMailHelper::cleanAddress($to) || !JMailHelper::cleanAddress($from)) :
    return false;
endif;
 
$subject = JMailHelper::cleanSubject($subject);
$body = JMailHelper::cleanText($body); 
 

The above code has checked to make sure that the "to" and "from" email addresses are valid and that the addresses, subject, and body are clean (they do not have any extra headers injected). These checks are important if the emails being send back and forth will be heavily user-controlled.

Next time your client requests email alerts when someone fills out your custom form, don't panic. JMail has done all the hard work for you. Figure what information is going to be sent, and use these few lines of code send it via email.

About the Author

Brian EdgertonBrian Edgerton is a full time web developer born, raised, and currently residing in Burlington, North Carolina. A Computer Science major in college, he developed a curiosity for all things electronic at a young age. When he is not furiously coding away in front of his computer, Brian enjoys sports, movies, books, and falling asleep in his recliner. Brian is a Zend Certified PHP5 Engineer. He is also currently working on a Master's of Software Engineering degree through Auburn University. In addition to PHP, Brian is also proficient in Javascript and CSS/XHTML and likes to pretend he knows a few things about Linux server administration as well.

You can check out Brian's website at EdgeWebWorks.com or follow him on Twitter @brian_edgerton.

Read More

blog comments powered by Disqus