Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fuel/email

Fuel PHP Framework - Fuel v1.x Email library
https://github.com/fuel/email

fuel-v1 php

Last synced: 5 days ago
JSON representation

Fuel PHP Framework - Fuel v1.x Email library

Awesome Lists containing this project

README

        

# Fuel Email Package.

A full fledged email class for Fuel. Send mails using php's mail function, sendmail or SMTP.

# Summary

* Send plain/text or html with (optional) alternative plain/text bodies using mail, sendmail or SMTP.
* Add attachments, normal or inline and string or file.
* Automatic inline file attachments for html bodies.
* Configurable attachment paths.

# Usage

$mail = Email::forge();
$mail->from('[email protected]', 'Your Name Here');

// Set to
$mail->to('[email protected]');

// Set with name
$mail->to('[email protected]', 'His/Her Name');

// Set as array
$mail->to(array(
// Without name
'[email protected]',

// With name
'[email protected]' => 'His/Her Name',
));

// Work the same for ->cc and ->bcc and ->reply_to


// Set a body message
$email->body('My email body');

// Set a html body message
$email->html_body(\View::forge('email/template', $email_data));

/**

By default this will also generate an alt body from the html,
and attach any inline files (not paths like http://...)

**/

// Set an alt body
$email->alt_body('This is my alt body, for non-html viewers.');

// Set a subject
$email->subject('This is the subject');

// Change the priority
$email->priority(\Email::P_HIGH);

// And send it
$result = $email->send();

# Exceptions

+ \EmailValidationFailedException, thrown when one or more email addresses doesn't pass validation
+ \EmailSendingFailedException, thrown when the driver failed to send the exception

Example:

// Use the default config and change the driver
$email = \Email::forge('default', array('driver' => 'smtp'));
$email->subject('My Subject');
$email->html_body(\View::forge('email/template', $email_data));
$email->from('[email protected]', 'It's Me!');
$email->to('[email protected]', 'It's the Other!');

try
{
$email->send();
}
catch(\EmailValidationFailedException $e)
{
// The validation failed
}
catch(\EmailSendingFailedException $e)
{
// The driver could not send the email
}

# Priorities

These can me one of the following:

+ \Email::P_LOWEST - 1 (lowest)
+ \Email::P_LOW - 2 (low)
+ \Email::P_NORMAL - 3 (normal) - this is the default
+ \Email::P_HIGH - 4 (high)
+ \Email::P_HIGHEST - 5 (highest)

# Attachments

There are multiple ways to add attachments:

$email = Email::forge();

// Add an attachment
$email->attach(DOCROOT.'dir/my_img.png');

// Add an inline attachment
// Add a cid here to point to the html
$email->attach(DOCROOT.'dir/my_img.png', true, 'cid:my_conten_id');

You can also add string attachments

$contents = file_get_contents($my_file);
$email->string_attach($contents, $filename);

By default html images are auto included, but it only includes local files.
Look at the following html to see how it works.

// This is included


// This is not included

Drivers
=======
The drivers allow the use of this library with mostly anything that can send mails.

### Mailgun
Mailgun is an online service by Rackspace (http://www.mailgun.com/) that allows you to send emails by demand. You will need to install the mailgun library (https://github.com/mailgun/mailgun-php) with composer in your FuelPHP.

Once you have installed the package you will have to set up the config for your App:

```php
array(
'driver' => 'mailgun',
'mailgun' => array(
'key' => 'YOUR KEY',
'domain' => 'YOUR DOMAIN',
'endpoint' => null | 'OPTIONAL ALT. API ENDPOINT URL' // e.g. 'https://api.eu.mailgun.net/v3'
),
),
);
```

# That's it. Questions?