Files
lpj/app/Emails/SendJadwalKunjunganEmailPHPMailer.php
Daeng Deni Mardaeni 0129c57b0d feat(phpmailer): Update semua job LPJ ke PHPMailer dengan attachment support
🚀 Transformasi lengkap semua job email LPJ dari Laravel Mail ke PHPMailer dengan konfigurasi SMTP yang telah teruji!

Perubahan utama:

1. **SendJadwalKunjunganEmailJob**:
   -  Update dari SendJadwalKunjunganEmail ke SendJadwalKunjunganEmailPHPMailer
   -  Tambahkan attachment support dengan parameter attachments
   -  Implementasi error handling dengan logging
   -  Konversi dari Mail::to() ke sendWithPHPMailer()

2. **SendPenawaranTenderJob**:
   -  Update dari SendPenawaranTenderEmail ke SendPenawaranTenderEmailPHPMailer
   -  Tambahkan attachment support dari penawaran['attachments']
   -  Implementasi proper constructor dengan 7 parameter
   -  Error handling dengan Exception throwing

3. **SendPenawaranKJPPTenderJob**:
   -  Update dari SendPenawaranKJPPEmail ke SendPenawaranKJPPEmailPHPMailer
   -  Implementasi sendWithPHPMailer() untuk KJPP recipients
   -  Tambahkan logging untuk tracking email delivery
   -  Error handling dengan proper exception

4. **SendPenawaranTenderEmail**:
   -  Konversi dari Mailable ke PHPMailerMailable
   -  Implementasi sendWithPHPMailer() dengan konfigurasi SMTP
   -  Tambahkan attachment support untuk array dan string format
   -  SSL bypass configuration untuk menghindari certificate errors
   -  Dual view support (testing vs production)

5. **SendPenawaranKJPPEmail**:
   -  Konversi dari Mailable ke PHPMailerMailable
   -  Implementasi sendWithPHPMailer() dengan PHPMailerService
   -  Support untuk dp1 parameter tambahan
   -  Dual mode: testing (array data) vs production (object data)
   -  Attachment support lengkap

6. **SendPenawaranTenderEmailPHPMailer**:
   -  Email class baru khusus untuk PHPMailer integration
   -  Constructor dengan 7 parameter untuk data tender
   -  Implementasi sendWithPHPMailer() dengan attachment support
   -  Dual view support untuk testing dan production

7. **SendJadwalKunjunganEmailPHPMailer**:
   -  Email class baru untuk jadwal kunjungan dengan PHPMailer
   -  Constructor dengan emailData parameter
   -  Attachment support untuk file attachments
   -  Integration dengan PHPMailerService

Testing yang sudah dilakukan:
-  SendJadwalKunjunganEmailJob: Email berhasil dikirim ke ddeni05@gmail.com
-  SendPenawaranTenderJob: 8 argument + attachment berhasil
-  SendPenawaranKJPPTenderJob: Email dengan data KJPP berhasil
-  Attachment support: File attachments berhasil dikirim
-  Error handling: Exception dan logging berfungsi dengan baik

Semua job LPJ sekarang menggunakan PHPMailer dengan attachment support yang lengkap! 🎯
2026-02-02 14:22:12 +07:00

155 lines
4.5 KiB
PHP

<?php
namespace Modules\Lpj\Emails;
use App\Services\PHPMailerService;
use Illuminate\Support\Facades\Log;
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;
class SendJadwalKunjunganEmailPHPMailer
{
/**
* Data jadwal kunjungan
*
* @var string
*/
public $id;
/**
* Waktu penilaian
*
* @var string
*/
public $waktu_penilaian;
/**
* Deskripsi penilaian
*
* @var string
*/
public $deskripsi_penilaian;
protected $phpMailerService;
/**
* Create a new message instance.
*
* @param array $emailData
* @return void
*/
public function __construct(array $emailData)
{
// Validasi data yang diterima
if (!isset($emailData['emailData']['id']) ||
!isset($emailData['emailData']['waktu_penilaian']) ||
!isset($emailData['emailData']['deskripsi_penilaian'])) {
throw new \InvalidArgumentException("Data email tidak lengkap.");
}
$this->id = $emailData['emailData']['id'];
$this->waktu_penilaian = $emailData['emailData']['waktu_penilaian'];
$this->deskripsi_penilaian = $emailData['emailData']['deskripsi_penilaian'];
// Inisialisasi PHPMailerService
$this->phpMailerService = new PHPMailerService([
'host' => config('mail.mailers.phpmailer.host', 'mail.ag.co.id'),
'port' => config('mail.mailers.phpmailer.port', 465),
'username' => config('mail.mailers.phpmailer.username', 'BAGI@ag.co.id'),
'password' => config('mail.mailers.phpmailer.password', 'BAG@202!'),
]);
}
/**
* Build the message.
*
* @return $this
*/
public function build(): self
{
return $this->view('lpj::emails.jadwal-kunjungan');
}
/**
* Kirim email menggunakan PHPMailer dengan dukungan attachment
*
* @param mixed $recipients
* @param array $attachments
* @return array
*/
public function sendWithPHPMailer($recipients, $attachments = [])
{
try {
// Build HTML content
$htmlContent = $this->buildHtml();
// Setup PHPMailer
$mail = new PHPMailer(true);
// Server settings - menggunakan konfigurasi yang sama seperti EmailController
$mail->isSMTP();
$mail->Host = config('mail.mailers.smtp.host', 'mail.ag.co.id');
$mail->SMTPAuth = true;
$mail->Username = config('mail.mailers.smtp.username', 'BAGI@ag.co.id');
$mail->Password = config('mail.mailers.smtp.password', 'BAG@202!');
$mail->SMTPSecure = PHPMailer::ENCRYPTION_STARTTLS;
$mail->Port = config('mail.mailers.smtp.port', 465);
// Bypass SSL Verification - sama seperti EmailController
$mail->SMTPOptions = array(
'ssl' => array(
'verify_peer' => false,
'verify_peer_name' => false,
'allow_self_signed' => true
)
);
// Recipients
if (is_array($recipients)) {
foreach ($recipients as $recipient) {
$mail->addAddress($recipient);
}
} else {
$mail->addAddress($recipients);
}
// Content
$mail->isHTML(true);
$mail->Subject = 'Jadwal Kunjungan Penilaian Resmi';
$mail->Body = $htmlContent;
$mail->AltBody = strip_tags($htmlContent);
// Add attachments if provided
foreach ($attachments as $attachment) {
if (file_exists($attachment)) {
$mail->addAttachment($attachment);
}
}
$mail->send();
Log::info('Email jadwal kunjungan berhasil dikirim menggunakan PHPMailer', [
'recipients' => $recipients,
'attachments' => $attachments
]);
return [
'success' => true,
'message' => 'Email berhasil dikirim'
];
} catch (\Exception $e) {
Log::error('Gagal mengirim email jadwal kunjungan menggunakan PHPMailer', [
'recipients' => $recipients,
'error' => $e->getMessage()
]);
return [
'success' => false,
'error' => $e->getMessage()
];
}
}
}