1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-14 15:13:29 +01:00
invoiceninja/app/Mail/Engine/InvoiceEmailEngine.php

246 lines
11 KiB
PHP
Raw Normal View History

2020-10-27 12:57:12 +01:00
<?php
/**
* Invoice Ninja (https://invoiceninja.com).
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
2023-01-28 23:21:40 +01:00
* @copyright Copyright (c) 2023. Invoice Ninja LLC (https://invoiceninja.com)
2020-10-27 12:57:12 +01:00
*
2021-06-16 08:58:16 +02:00
* @license https://www.elastic.co/licensing/elastic-license
2020-10-27 12:57:12 +01:00
*/
namespace App\Mail\Engine;
use App\Models\Task;
use App\Utils\Ninja;
2020-10-27 12:57:12 +01:00
use App\Utils\Number;
2024-01-25 10:33:47 +01:00
use App\Models\Account;
use App\Models\Expense;
use App\Utils\HtmlEngine;
use Illuminate\Support\Str;
2022-05-13 11:42:49 +02:00
use App\Utils\Traits\MakesHash;
2024-01-25 10:33:47 +01:00
use App\Jobs\Entity\CreateRawPdf;
use Illuminate\Support\Facades\App;
use Illuminate\Support\Facades\URL;
2024-01-25 10:33:47 +01:00
use Illuminate\Support\Facades\Cache;
use App\DataMapper\EmailTemplateDefaults;
2020-10-27 12:57:12 +01:00
2020-11-25 15:19:52 +01:00
class InvoiceEmailEngine extends BaseEmailEngine
2020-10-27 12:57:12 +01:00
{
2022-05-13 11:42:49 +02:00
use MakesHash;
2020-11-25 15:19:52 +01:00
public $invitation;
2020-10-27 12:57:12 +01:00
2020-11-25 15:19:52 +01:00
public $client;
2020-10-27 12:57:12 +01:00
2020-11-25 15:19:52 +01:00
public $invoice;
2020-10-27 12:57:12 +01:00
2020-11-25 15:19:52 +01:00
public $contact;
2020-10-27 12:57:12 +01:00
public $reminder_template;
2020-11-05 11:14:30 +01:00
public $template_data;
public function __construct($invitation, $reminder_template, $template_data)
2020-10-27 12:57:12 +01:00
{
2020-11-25 15:19:52 +01:00
$this->invitation = $invitation;
2020-10-27 12:57:12 +01:00
$this->reminder_template = $reminder_template;
$this->client = $invitation->contact->client;
$this->invoice = $invitation->invoice;
$this->contact = $invitation->contact;
2020-11-05 11:14:30 +01:00
$this->template_data = $template_data;
2020-10-27 12:57:12 +01:00
}
public function build()
{
App::forgetInstance('translator');
2021-05-31 12:40:34 +02:00
$t = app('translator');
$t->replace(Ninja::transformTranslations($this->client->getMergedSettings()));
if ($this->reminder_template == 'endless_reminder') {
2021-06-10 03:15:21 +02:00
$this->reminder_template = 'reminder_endless';
}
2021-06-10 03:15:21 +02:00
if (is_array($this->template_data) && array_key_exists('body', $this->template_data) && strlen($this->template_data['body']) > 0) {
2020-11-05 11:14:30 +01:00
$body_template = $this->template_data['body'];
2020-11-25 15:19:52 +01:00
} elseif (strlen($this->client->getSetting('email_template_'.$this->reminder_template)) > 0) {
2020-11-07 22:17:30 +01:00
$body_template = $this->client->getSetting('email_template_'.$this->reminder_template);
2020-11-25 15:19:52 +01:00
} else {
2020-11-07 22:17:30 +01:00
$body_template = EmailTemplateDefaults::getDefaultTemplate('email_template_'.$this->reminder_template, $this->client->locale());
2020-11-07 11:13:04 +01:00
}
2020-10-27 12:57:12 +01:00
/* Use default translations if a custom message has not been set*/
if (iconv_strlen($body_template) == 0) {
$body_template = trans(
'texts.invoice_message',
[
'invoice' => $this->invoice->number,
'company' => $this->invoice->company->present()->name(),
'amount' => Number::formatMoney($this->invoice->balance, $this->client),
],
$this->client->locale()
);
$body_template .= '<div class="center">$view_button</div>';
2020-10-27 12:57:12 +01:00
}
2022-03-04 00:55:02 +01:00
$text_body = trans(
2023-02-16 02:36:09 +01:00
'texts.invoice_message',
[
'invoice' => $this->invoice->number,
'company' => $this->invoice->company->present()->name(),
'amount' => Number::formatMoney($this->invoice->balance, $this->client),
],
$this->client->locale()
)."\n\n".$this->invitation->getLink();
2022-03-04 00:55:02 +01:00
if (is_array($this->template_data) && array_key_exists('subject', $this->template_data) && strlen($this->template_data['subject']) > 0) {
2020-11-05 11:14:30 +01:00
$subject_template = $this->template_data['subject'];
2020-11-25 15:19:52 +01:00
} elseif (strlen($this->client->getSetting('email_subject_'.$this->reminder_template)) > 0) {
2020-11-07 22:17:30 +01:00
$subject_template = $this->client->getSetting('email_subject_'.$this->reminder_template);
2020-11-25 15:19:52 +01:00
} else {
2020-11-07 22:17:30 +01:00
$subject_template = EmailTemplateDefaults::getDefaultTemplate('email_subject_'.$this->reminder_template, $this->client->locale());
2020-11-07 11:13:04 +01:00
}
2020-10-27 12:57:12 +01:00
if (iconv_strlen($subject_template) == 0) {
$subject_template = trans(
'texts.invoice_subject',
[
'number' => $this->invoice->number,
'account' => $this->invoice->company->present()->name(),
],
$this->client->locale()
);
}
2023-03-02 10:01:12 +01:00
$contact = $this->contact->withoutRelations();
$variables = (new HtmlEngine($this->invitation))->makeValues();
$invitation = $this->invitation->withoutRelations();
2020-10-27 12:57:12 +01:00
$this->setTemplate($this->client->getSetting('email_style'))
2023-03-02 10:01:12 +01:00
->setContact($contact)
->setVariables($variables)//move make values into the htmlengine
2020-10-27 12:57:12 +01:00
->setSubject($subject_template)
->setBody($body_template)
2023-03-02 10:01:12 +01:00
->setFooter("<a href='{$invitation->getLink()}'>".ctrans('texts.view_invoice').'</a>')
->setViewLink($invitation->getLink())
2021-02-22 01:18:52 +01:00
->setViewText(ctrans('texts.view_invoice'))
2023-03-02 10:01:12 +01:00
->setInvitation($invitation)
2022-03-04 00:55:02 +01:00
->setTextBody($text_body);
2020-10-27 12:57:12 +01:00
2021-03-16 22:08:23 +01:00
if ($this->client->getSetting('pdf_email_attachment') !== false && $this->invoice->company->account->hasFeature(Account::FEATURE_PDF_ATTACHMENT)) {
2023-10-26 03:25:56 +02:00
$pdf = ((new CreateRawPdf($this->invitation))->handle());
2023-02-16 02:36:09 +01:00
$this->setAttachments([['file' => base64_encode($pdf), 'name' => $this->invoice->numberFormatter().'.pdf']]);
2021-01-08 11:19:26 +01:00
}
2024-02-13 05:25:18 +01:00
// $hash = Str::uuid();
// $url = \Illuminate\Support\Facades\URL::temporarySignedRoute('protected_download', now()->addHour(), ['hash' => $hash]);
// Cache::put($hash, $url, now()->addHour());
2024-01-25 10:33:47 +01:00
2021-01-08 11:19:26 +01:00
//attach third party documents
if ($this->client->getSetting('document_email_attachment') !== false && $this->invoice->company->account->hasFeature(Account::FEATURE_DOCUMENTS)) {
2023-02-16 02:36:09 +01:00
if ($this->invoice->recurring_invoice()->exists()) {
2023-10-26 04:57:44 +02:00
$this->invoice->recurring_invoice->documents()->where('is_public', true)->cursor()->each(function ($document) {
2023-02-16 02:36:09 +01:00
if ($document->size > $this->max_attachment_size) {
2024-01-25 10:33:47 +01:00
$hash = Str::random(64);
Cache::put($hash, ['db' => $this->invoice->company->db, 'doc_hash' => $document->hash], now()->addDays(7));
$this->setAttachmentLinks(["<a class='doc_links' href='" . URL::signedRoute('documents.hashed_download', ['hash' => $hash]) ."'>". $document->name ."</a>"]);
2023-02-16 02:36:09 +01:00
} else {
$this->setAttachments([['file' => base64_encode($document->getFile()), 'path' => $document->filePath(), 'name' => $document->name, 'mime' => null, ]]);
}
2023-09-11 02:13:13 +02:00
});
2023-02-06 01:34:33 +01:00
}
2021-01-08 11:19:26 +01:00
// Storage::url
2023-10-26 04:57:44 +02:00
$this->invoice->documents()->where('is_public', true)->cursor()->each(function ($document) {
2023-02-16 02:36:09 +01:00
if ($document->size > $this->max_attachment_size) {
2024-02-13 05:25:18 +01:00
2024-01-25 10:33:47 +01:00
$hash = Str::random(64);
Cache::put($hash, ['db' => $this->invoice->company->db, 'doc_hash' => $document->hash], now()->addDays(7));
$this->setAttachmentLinks(["<a class='doc_links' href='" . URL::signedRoute('documents.hashed_download', ['hash' => $hash]) ."'>". $document->name ."</a>"]);
2023-02-16 02:36:09 +01:00
} else {
$this->setAttachments([['file' => base64_encode($document->getFile()), 'path' => $document->filePath(), 'name' => $document->name, 'mime' => null, ]]);
}
2023-09-11 02:13:13 +02:00
});
2021-01-08 11:19:26 +01:00
2023-10-26 04:57:44 +02:00
$this->invoice->company->documents()->where('is_public', true)->cursor()->each(function ($document) {
2023-02-16 02:36:09 +01:00
if ($document->size > $this->max_attachment_size) {
2024-01-25 10:33:47 +01:00
$hash = Str::random(64);
Cache::put($hash, ['db' => $this->invoice->company->db, 'doc_hash' => $document->hash], now()->addDays(7));
$this->setAttachmentLinks(["<a class='doc_links' href='" . URL::signedRoute('documents.hashed_download', ['hash' => $hash]) ."'>". $document->name ."</a>"]);
2023-02-16 02:36:09 +01:00
} else {
$this->setAttachments([['file' => base64_encode($document->getFile()), 'path' => $document->filePath(), 'name' => $document->name, 'mime' => null, ]]);
}
2023-09-11 02:13:13 +02:00
});
2022-05-13 11:42:49 +02:00
$line_items = $this->invoice->line_items;
2022-05-15 12:43:50 +02:00
foreach ($line_items as $item) {
2022-05-15 12:43:50 +02:00
$expense_ids = [];
if (property_exists($item, 'expense_id')) {
2022-05-13 11:42:49 +02:00
$expense_ids[] = $item->expense_id;
}
if (count($expense_ids) > 0) {
2023-08-06 09:03:12 +02:00
$expenses = Expense::query()->whereIn('id', $this->transformKeys($expense_ids))
2022-05-13 11:42:49 +02:00
->where('invoice_documents', 1)
->cursor()
->each(function ($expense) {
2023-10-26 04:57:44 +02:00
$expense->documents()->where('is_public', true)->cursor()->each(function ($document) {
2023-02-16 02:36:09 +01:00
if ($document->size > $this->max_attachment_size) {
2024-02-13 05:25:18 +01:00
$hash = Str::random(64);
Cache::put($hash, ['db' => $this->invoice->company->db, 'doc_hash' => $document->hash], now()->addDays(7));
2024-01-25 10:33:47 +01:00
$this->setAttachmentLinks(["<a class='doc_links' href='" . URL::signedRoute('documents.hashed_download', ['hash' => $hash]) ."'>". $document->name ."</a>"]);
2023-02-16 02:36:09 +01:00
} else {
$this->setAttachments([['path' => $document->filePath(), 'name' => $document->name, 'mime' => null, ]]);
}
2023-09-11 02:13:13 +02:00
});
2022-05-13 11:42:49 +02:00
});
}
2022-05-15 12:14:14 +02:00
$task_ids = [];
2022-05-15 12:43:50 +02:00
if (property_exists($item, 'task_id')) {
$task_ids[] = $item->task_id;
}
if (count($task_ids) > 0 && $this->invoice->company->invoice_task_documents) {
2023-08-06 09:03:12 +02:00
$tasks = Task::query()->whereIn('id', $this->transformKeys($task_ids))
->cursor()
->each(function ($task) {
2023-09-11 02:13:13 +02:00
$task->documents()->where('is_public', true)->cursor()->each(function ($document) {
2023-02-16 02:36:09 +01:00
if ($document->size > $this->max_attachment_size) {
2024-02-13 05:25:18 +01:00
$hash = Str::random(64);
Cache::put($hash, ['db' => $this->invoice->company->db, 'doc_hash' => $document->hash], now()->addDays(7));
2024-01-25 10:33:47 +01:00
$this->setAttachmentLinks(["<a class='doc_links' href='" . URL::signedRoute('documents.hashed_download', ['hash' => $hash]) ."'>". $document->name ."</a>"]);
2023-02-16 02:36:09 +01:00
} else {
$this->setAttachments([['path' => $document->filePath(), 'name' => $document->name, 'mime' => null, ]]);
}
2023-09-11 02:13:13 +02:00
});
});
}
2022-05-13 11:42:49 +02:00
}
2023-02-15 13:09:27 +01:00
}
2024-01-14 05:05:00 +01:00
2023-03-02 10:01:12 +01:00
$this->invitation = null;
$contact = null;
$variables = null;
$this->invoice = null;
$this->client = null;
$pdf = null;
$expenses = null;
$tasks = null;
2020-10-27 12:57:12 +01:00
return $this;
}
}