mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-10 21:22:58 +01:00
19080933b6
Shift automatically applies the Laravel coding style - which uses the PSR-2 coding style as a base with some minor additions. You may customize the code style applied by adding a [PHP CS Fixer][1] or [PHP CodeSniffer][2] ruleset to your project root. Feel free to use [Shift's Laravel ruleset][3] to help you get started. For more information on customizing the code style applied by Shift, [watch this short video][4]. [1]: https://github.com/FriendsOfPHP/PHP-CS-Fixer [2]: https://github.com/squizlabs/PHP_CodeSniffer [3]: https://gist.github.com/laravel-shift/cab527923ed2a109dda047b97d53c200 [4]: https://laravelshift.com/videos/shift-code-style
213 lines
6.9 KiB
PHP
213 lines
6.9 KiB
PHP
<?php
|
|
/**
|
|
* Entity Ninja (https://entityninja.com).
|
|
*
|
|
* @link https://github.com/entityninja/entityninja source repository
|
|
*
|
|
* @copyright Copyright (c) 2022. Entity Ninja LLC (https://entityninja.com)
|
|
*
|
|
* @license https://www.elastic.co/licensing/elastic-license
|
|
*/
|
|
|
|
namespace App\Jobs\Entity;
|
|
|
|
use App\Exceptions\FilePermissionsFailure;
|
|
use App\Libraries\MultiDB;
|
|
use App\Models\Account;
|
|
use App\Models\Credit;
|
|
use App\Models\CreditInvitation;
|
|
use App\Models\Design;
|
|
use App\Models\Invoice;
|
|
use App\Models\InvoiceInvitation;
|
|
use App\Models\Quote;
|
|
use App\Models\QuoteInvitation;
|
|
use App\Models\RecurringInvoice;
|
|
use App\Models\RecurringInvoiceInvitation;
|
|
use App\Services\PdfMaker\Design as PdfDesignModel;
|
|
use App\Services\PdfMaker\Design as PdfMakerDesign;
|
|
use App\Services\PdfMaker\PdfMaker as PdfMakerService;
|
|
use App\Utils\HostedPDF\NinjaPdf;
|
|
use App\Utils\HtmlEngine;
|
|
use App\Utils\Ninja;
|
|
use App\Utils\PhantomJS\Phantom;
|
|
use App\Utils\Traits\MakesHash;
|
|
use App\Utils\Traits\MakesInvoiceHtml;
|
|
use App\Utils\Traits\NumberFormatter;
|
|
use App\Utils\Traits\Pdf\PageNumbering;
|
|
use App\Utils\Traits\Pdf\PdfMaker;
|
|
use Illuminate\Bus\Queueable;
|
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
|
use Illuminate\Foundation\Bus\Dispatchable;
|
|
use Illuminate\Queue\InteractsWithQueue;
|
|
use Illuminate\Queue\SerializesModels;
|
|
use Illuminate\Support\Facades\App;
|
|
use Illuminate\Support\Facades\Lang;
|
|
use Illuminate\Support\Facades\Storage;
|
|
|
|
class CreateRawPdf implements ShouldQueue
|
|
{
|
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels, NumberFormatter, MakesInvoiceHtml, PdfMaker, MakesHash, PageNumbering;
|
|
|
|
public $entity;
|
|
|
|
public $company;
|
|
|
|
public $contact;
|
|
|
|
public $invitation;
|
|
|
|
public $entity_string = '';
|
|
|
|
/**
|
|
* Create a new job instance.
|
|
*
|
|
* @param $invitation
|
|
*/
|
|
public function __construct($invitation, $db)
|
|
{
|
|
MultiDB::setDb($db);
|
|
|
|
$this->invitation = $invitation;
|
|
|
|
if ($invitation instanceof InvoiceInvitation) {
|
|
$this->entity = $invitation->invoice;
|
|
$this->entity_string = 'invoice';
|
|
} elseif ($invitation instanceof QuoteInvitation) {
|
|
$this->entity = $invitation->quote;
|
|
$this->entity_string = 'quote';
|
|
} elseif ($invitation instanceof CreditInvitation) {
|
|
$this->entity = $invitation->credit;
|
|
$this->entity_string = 'credit';
|
|
} elseif ($invitation instanceof RecurringInvoiceInvitation) {
|
|
$this->entity = $invitation->recurring_invoice;
|
|
$this->entity_string = 'recurring_invoice';
|
|
}
|
|
|
|
$this->company = $invitation->company;
|
|
|
|
$this->contact = $invitation->contact;
|
|
}
|
|
|
|
public function handle()
|
|
{
|
|
|
|
/* Forget the singleton*/
|
|
App::forgetInstance('translator');
|
|
|
|
/* Init a new copy of the translator*/
|
|
$t = app('translator');
|
|
/* Set the locale*/
|
|
App::setLocale($this->contact->preferredLocale());
|
|
|
|
/* Set customized translations _NOW_ */
|
|
$t->replace(Ninja::transformTranslations($this->entity->client->getMergedSettings()));
|
|
|
|
$entity_design_id = '';
|
|
|
|
if ($this->entity instanceof Invoice) {
|
|
$path = $this->entity->client->invoice_filepath($this->invitation);
|
|
$entity_design_id = 'invoice_design_id';
|
|
} elseif ($this->entity instanceof Quote) {
|
|
$path = $this->entity->client->quote_filepath($this->invitation);
|
|
$entity_design_id = 'quote_design_id';
|
|
} elseif ($this->entity instanceof Credit) {
|
|
$path = $this->entity->client->credit_filepath($this->invitation);
|
|
$entity_design_id = 'credit_design_id';
|
|
} elseif ($this->entity instanceof RecurringInvoice) {
|
|
$path = $this->entity->client->recurring_invoice_filepath($this->invitation);
|
|
$entity_design_id = 'invoice_design_id';
|
|
}
|
|
|
|
$file_path = $path.$this->entity->numberFormatter().'.pdf';
|
|
|
|
$entity_design_id = $this->entity->design_id ? $this->entity->design_id : $this->decodePrimaryKey($this->entity->client->getSetting($entity_design_id));
|
|
|
|
$design = Design::find($entity_design_id);
|
|
|
|
/* Catch all in case migration doesn't pass back a valid design */
|
|
if (! $design) {
|
|
$design = Design::find(2);
|
|
}
|
|
|
|
$html = new HtmlEngine($this->invitation);
|
|
|
|
if ($design->is_custom) {
|
|
$options = [
|
|
'custom_partials' => json_decode(json_encode($design->design), true),
|
|
];
|
|
$template = new PdfMakerDesign(PdfDesignModel::CUSTOM, $options);
|
|
} else {
|
|
$template = new PdfMakerDesign(strtolower($design->name));
|
|
}
|
|
|
|
$variables = $html->generateLabelsAndValues();
|
|
|
|
$state = [
|
|
'template' => $template->elements([
|
|
'client' => $this->entity->client,
|
|
'entity' => $this->entity,
|
|
'pdf_variables' => (array) $this->entity->company->settings->pdf_variables,
|
|
'$product' => $design->design->product,
|
|
'variables' => $variables,
|
|
]),
|
|
'variables' => $variables,
|
|
'options' => [
|
|
'all_pages_header' => $this->entity->client->getSetting('all_pages_header'),
|
|
'all_pages_footer' => $this->entity->client->getSetting('all_pages_footer'),
|
|
],
|
|
'process_markdown' => $this->entity->client->company->markdown_enabled,
|
|
];
|
|
|
|
$maker = new PdfMakerService($state);
|
|
|
|
$maker
|
|
->design($template)
|
|
->build();
|
|
|
|
$pdf = null;
|
|
|
|
try {
|
|
if (config('ninja.invoiceninja_hosted_pdf_generation') || config('ninja.pdf_generator') == 'hosted_ninja') {
|
|
$pdf = (new NinjaPdf())->build($maker->getCompiledHTML(true));
|
|
|
|
$finfo = new \finfo(FILEINFO_MIME);
|
|
|
|
//fallback in case hosted PDF fails.
|
|
if ($finfo->buffer($pdf) != 'application/pdf; charset=binary') {
|
|
$pdf = $this->makePdf(null, null, $maker->getCompiledHTML(true));
|
|
|
|
$numbered_pdf = $this->pageNumbering($pdf, $this->company);
|
|
|
|
if ($numbered_pdf) {
|
|
$pdf = $numbered_pdf;
|
|
}
|
|
}
|
|
} else {
|
|
$pdf = $this->makePdf(null, null, $maker->getCompiledHTML(true));
|
|
|
|
$numbered_pdf = $this->pageNumbering($pdf, $this->company);
|
|
|
|
if ($numbered_pdf) {
|
|
$pdf = $numbered_pdf;
|
|
}
|
|
}
|
|
} catch (\Exception $e) {
|
|
nlog(print_r($e->getMessage(), 1));
|
|
}
|
|
|
|
if (config('ninja.log_pdf_html')) {
|
|
info($maker->getCompiledHTML());
|
|
}
|
|
|
|
if ($pdf) {
|
|
return $pdf;
|
|
}
|
|
|
|
throw new FilePermissionsFailure('Unable to generate the raw PDF');
|
|
}
|
|
|
|
public function failed($e)
|
|
{
|
|
}
|
|
}
|