mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-05-10 08:45:42 -04:00
* fix: Add missing $img_tag variable in Sales::getSendPdf() The receipt_email.php view expects $img_tag but getSendPdf() wasn't passing it. This caused 'Undefined variable $img_tag' error when sending receipt emails. Closes #4514 * refactor: Extract img_tag building into helper method Refactored duplicate img_tag building code into _build_img_tag helper method. Both getSendPdf and getSendReceipt now use this shared method. * refactor: Move logo-related methods to Email_lib Moved buildLogoImgTag and getLogoMimeType methods to Email_lib library where they logically belong alongside email-related functionality. This removes duplicate code and centralizes email-related helpers. Sales controller now uses email_lib->buildLogoImgTag() and email_lib->getLogoMimeType() instead of private methods. * fix: Address CodeRabbit review comments - buildLogoImgTag now uses getLogoMimeType for actual MIME type instead of hardcoding image/png - getLogoMimeType returns empty string instead of false for consistency - Consolidated logo path/exists check logic between both methods --------- Co-authored-by: Ollama <ollama@steganos.dev>
122 lines
3.5 KiB
PHP
122 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace app\Libraries;
|
|
|
|
use CodeIgniter\Email\Email;
|
|
use CodeIgniter\Encryption\Encryption;
|
|
use CodeIgniter\Encryption\EncrypterInterface;
|
|
use CodeIgniter\Encryption\Exceptions\EncryptionException;
|
|
use Config\OSPOS;
|
|
use Config\Services;
|
|
|
|
|
|
/**
|
|
* Email library
|
|
*
|
|
* Library with utilities to configure and send emails
|
|
*/
|
|
|
|
class Email_lib
|
|
{
|
|
private Email $email;
|
|
private array $config;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->email = new Email();
|
|
$this->config = config(OSPOS::class)->settings;
|
|
|
|
$encrypter = Services::encrypter();
|
|
|
|
$smtp_pass = $this->config['smtp_pass'];
|
|
if (!empty($smtp_pass) && check_encryption()) {
|
|
try {
|
|
$smtp_pass = $encrypter->decrypt($smtp_pass);
|
|
} catch (\EncryptionException $e) {
|
|
// Decryption failed, use the original value
|
|
log_message('error', 'SMTP password decryption failed: ' . $e->getMessage());
|
|
$smtp_pass = '';
|
|
}
|
|
|
|
}
|
|
|
|
$email_config = [
|
|
'mailType' => 'html',
|
|
'userAgent' => 'OSPOS',
|
|
'validate' => true,
|
|
'protocol' => $this->config['protocol'],
|
|
'mailPath' => $this->config['mailpath'],
|
|
'SMTPHost' => $this->config['smtp_host'],
|
|
'SMTPUser' => $this->config['smtp_user'],
|
|
'SMTPPass' => $smtp_pass,
|
|
'SMTPPort' => (int)$this->config['smtp_port'],
|
|
'SMTPTimeout' => (int)$this->config['smtp_timeout'],
|
|
'SMTPCrypto' => $this->config['smtp_crypto']
|
|
];
|
|
$this->email->initialize($email_config);
|
|
}
|
|
|
|
/**
|
|
* Email sending function
|
|
* Example of use: $response = sendEmail('john@doe.com', 'Hello', 'This is a message', $filename);
|
|
*/
|
|
public function sendEmail(string $to, string $subject, string $message, ?string $attachment = null): bool
|
|
{
|
|
$email = $this->email;
|
|
|
|
$email->setFrom($this->config['email'], $this->config['company']);
|
|
$email->setTo($to);
|
|
$email->setSubject($subject);
|
|
$email->setMessage($message);
|
|
|
|
if (!empty($attachment)) {
|
|
$email->attach($attachment);
|
|
$email->setAttachmentCID($attachment);
|
|
}
|
|
|
|
$result = $email->send();
|
|
|
|
if (!$result) {
|
|
log_message('error', $email->printDebugger());
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Gets the mime type of the company logo file.
|
|
*
|
|
* @return string Mime type or empty string if logo doesn't exist
|
|
*/
|
|
public function getLogoMimeType(): string
|
|
{
|
|
$logo_path = FCPATH . 'uploads/' . $this->config['company_logo'];
|
|
|
|
if (!empty($this->config['company_logo']) && file_exists($logo_path)) {
|
|
$mimeType = mime_content_type($logo_path);
|
|
return $mimeType !== false ? $mimeType : '';
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* Builds an img tag for the company logo to use in email templates.
|
|
*
|
|
* @return string HTML img tag with base64-encoded logo, or empty string if no logo
|
|
*/
|
|
public function buildLogoImgTag(): string
|
|
{
|
|
$mimeType = $this->getLogoMimeType();
|
|
|
|
if ($mimeType === '') {
|
|
return '';
|
|
}
|
|
|
|
$logo_path = FCPATH . 'uploads/' . $this->config['company_logo'];
|
|
$logo_data = base64_encode(file_get_contents($logo_path));
|
|
|
|
return '<img id="image" src="data:' . $mimeType . ';base64,' . $logo_data . '" alt="company_logo">';
|
|
}
|
|
}
|