This PHP Library, Aslamhus/Email, is convenient and flexible wrapper for interacting with the SendGrid API v3.0.0. It is designed to provide a fluent interface for sending emails via SendGrid, making it simple to integrate email functionality into your PHP projects. The class includes methods for composing and sending emails with features such as dynamic template data, attachments, and more.
To use this class in your project, follow these steps:
- 
Create an account with Sendgrid. 
- 
Create an API Key in your new sendgrid account. In the sidebar of your dashboard, choose EmailApi, then selectIntegration Guidefrom the dropdown. Choose WebApi -> Php, then create your api key. You do not need to install sendgrid through composer, installing this class will do that for you. The last step in the integration guide is to send a verification email. Before we do that, install the library.
- 
Create a single sender identity. This will allow you to send emails from an authenticated email. In the sidebar choose Sender Authentication, thenVerify a Single Sender. Follow the steps. You'll use this email in thefrommethod when sending emails.
- 
Install Aslamhus/Emailcomposer require aslamhus/sendgrid-email-wrapper
- 
Send verficiation email (optional) // add your api key $email = new Email('your-sendgrid-api-key'); // make sure to add your single sender identity email and name $didSend = $email->sendVerifyIntegrationEmail(['[email protected]', 'Verified User']); // $didSend will return true if everything is set up correctly. 
- 
Confirm verification. Go back to the integration guide in your Sendgrid account, and at the bottom of the page choose Verify Integration. You should get a confirmation that your integration was successful.
$email = new Email('your-sendgrid-api-key')
    ->setFrom('[email protected]', 'Sender Name')
    ->addTo('[email protected]', 'Recipient Name')
    ->setSubject('Test email')
    ->addContent('text/plain', 'Hello world!')
    ->send();Dynamic template data variables can be set using handlebars {{my_var}}.
For more info see https://docs.sendgrid.com/for-developers/sending-email/using-handlebars
$email = new Email('your-sendgrid-api-key')
    ->setFrom('[email protected]', 'Sender Name')
    ->addTo('[email protected]', 'Recipient Name')
    ->setSubject('Test email')
    ->setTemplateId('your-template-id')
    ->addDynamicTemplateDatas([
        'subject' => 'My dynamic template email'
        'name' => '2020-01-01',
        'link' => 'https://www.example.com',
    ])
    ->send();- 
Add Attachments: $email->addAttachment('path/to/file.pdf', 'application/pdf', 'document.pdf'); 
- 
Add Content: $email->addContent('text/plain', 'This is the plain text content'); $email->addContent('text/html', '<p>This is the HTML content</p>'); 
- 
Get email response: // retrieve the response body, headers and status code after sending $response = $email->getResponse(); print_r($response->headers()); echo $response->statusCode() echo $response->body() 
If you encounter any issues or would like to contribute to the development of this class, please visit the GitHub repository: Aslamhus\Email.
To run tests on this library, follow these steps:
- Set your sample.env file with the require fields, then rename sample.env to .env
- Run tests
composer run testThis class is open-source and released under the MIT License. Feel free to use, modify, and distribute it according to your project's needs.