<?php

/**
 * This example shows how to send a message to a whole list of recipients efficiently.
 */

//Import the PHPMailer class into the global namespace
use PHPMailer\PHPMailer\PHPMailer;
use 
PHPMailer\PHPMailer\Exception;

error_reporting(E_ALL);

date_default_timezone_set('Etc/UTC');

require 
'../vendor/autoload.php';

//Passing `true` enables PHPMailer exceptions
$mail = new PHPMailer(true);

$body file_get_contents('contents.html');

$mail->isSMTP();
$mail->Host 'smtp.example.com';
$mail->SMTPAuth true;
$mail->SMTPKeepAlive true//SMTP connection will not close after each email sent, reduces SMTP overhead
$mail->Port 25;
$mail->Username 'yourname@example.com';
$mail->Password 'yourpassword';
$mail->setFrom('list@example.com''List manager');
$mail->addReplyTo('list@example.com''List manager');
$mail->addCustomHeader(
    
'List-Unsubscribe',
    
'<mailto:unsubscribes@example.com>, <https://www.example.com/unsubscribe.php>'
);
$mail->Subject 'PHPMailer Simple database mailing list test';

//Same body for all messages, so set this before the sending loop
//If you generate a different body for each recipient (e.g. you're using a templating system),
//set it inside the loop
$mail->msgHTML($body);
//msgHTML also sets AltBody, but if you want a custom one, set it afterwards
$mail->AltBody 'To view the message, please use an HTML compatible email viewer!';

//Connect to the database and select the recipients from your mailing list that have not yet been sent to
//You'll need to alter this to match your database
$mysql mysqli_connect('localhost''username''password');
mysqli_select_db($mysql'mydb');
$result mysqli_query($mysql'SELECT full_name, email, photo FROM mailinglist WHERE sent = FALSE');

foreach (
$result as $row) {
    try {
        
$mail->addAddress($row['email'], $row['full_name']);
    } catch (
Exception $e) {
        
printf(
            
'Invalid address skipped: %s<br>',
            
htmlspecialchars($row['email'], ENT_QUOTES ENT_SUBSTITUTE ENT_HTML401)
        );
        continue;
    }
    if (!empty(
$row['photo'])) {
        
//Assumes the image data is stored in the DB
        
$mail->addStringAttachment($row['photo'], 'YourPhoto.jpg');
    }
    
$mail->replaceCustomHeader(
        
'List-Unsubscribe',
        
'<mailto:unsubscribes@example.com>, <https://www.example.com/unsubscribe.php?email=' .
        
rawurlencode($row['email']) . '>'
    
);

    try {
        
$mail->send();
        
printf(
            
'Message sent to : %s (%s)<br>',
            
htmlspecialchars($row['full_name'], ENT_QUOTES ENT_SUBSTITUTE ENT_HTML401),
            
htmlspecialchars($row['email'], ENT_QUOTES ENT_SUBSTITUTE ENT_HTML401)
        );
        
//Mark it as sent in the DB
        
mysqli_query(
            
$mysql,
            
"UPDATE mailinglist SET sent = TRUE WHERE email = '" .
            
mysqli_real_escape_string($mysql$row['email']) . "'"
        
);
    } catch (
Exception $e) {
        
printf(
            
'Mailer Error (%s) %s<br>',
            
htmlspecialchars($row['email'], ENT_QUOTES ENT_SUBSTITUTE ENT_HTML401),
            
$mail->ErrorInfo
        
);
        
//Reset the connection to abort sending this message
        //The loop will continue trying to send to the rest of the list
        
$mail->getSMTPInstance()->reset();
    }
    
//Clear all addresses and attachments for the next iteration
    
$mail->clearAddresses();
    
$mail->clearAttachments();
}