invoiceninja/app/Jobs/RecurringInvoice/SendRecurring.php

142 lines
4.6 KiB
PHP
Raw Normal View History

2019-05-23 15:08:31 +10:00
<?php
/**
* Invoice Ninja (https://invoiceninja.com).
2019-05-23 15:08:31 +10:00
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
2019-05-23 15:08:31 +10:00
*
2021-06-16 16:58:16 +10:00
* @license https://www.elastic.co/licensing/elastic-license
2019-05-23 15:08:31 +10:00
*/
namespace App\Jobs\RecurringInvoice;
2020-10-07 14:00:32 +11:00
use App\DataMapper\Analytics\SendRecurringFailure;
2020-09-08 20:34:14 +10:00
use App\Events\Invoice\InvoiceWasEmailed;
2019-05-23 15:08:31 +10:00
use App\Factory\RecurringInvoiceToInvoiceFactory;
2020-10-28 17:58:15 +11:00
use App\Jobs\Entity\EmailEntity;
2019-05-23 16:15:06 +10:00
use App\Models\Invoice;
2019-05-23 15:08:31 +10:00
use App\Models\RecurringInvoice;
2020-09-24 21:03:59 +10:00
use App\Utils\Ninja;
use App\Utils\Traits\GeneratesCounter;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
2020-10-07 14:00:32 +11:00
use Turbo124\Beacon\Facades\LightLogs;
2019-05-23 15:08:31 +10:00
class SendRecurring implements ShouldQueue
2019-05-23 15:08:31 +10:00
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
use GeneratesCounter;
2019-05-23 15:08:31 +10:00
public $recurring_invoice;
2019-05-24 08:37:47 +10:00
protected $db;
2021-03-30 12:28:49 +11:00
public $tries = 1;
2019-05-23 15:08:31 +10:00
/**
* Create a new job instance.
*
2020-10-28 21:10:49 +11:00
* @param RecurringInvoice $recurring_invoice
* @param string $db
2019-05-23 15:08:31 +10:00
*/
2019-05-24 08:37:47 +10:00
public function __construct(RecurringInvoice $recurring_invoice, string $db = 'db-ninja-01')
2019-05-23 15:08:31 +10:00
{
$this->recurring_invoice = $recurring_invoice;
2019-05-24 08:37:47 +10:00
$this->db = $db;
2019-05-23 15:08:31 +10:00
}
/**
* Execute the job.
*
* @return void
*/
public function handle() : void
{
// Generate Standard Invoice
$invoice = RecurringInvoiceToInvoiceFactory::create($this->recurring_invoice, $this->recurring_invoice->client);
2020-10-07 14:00:32 +11:00
$invoice->date = now()->format('Y-m-d');
2021-08-06 09:34:45 +10:00
$invoice->due_date = $this->recurring_invoice->calculateDueDate(now()->format('Y-m-d'));
if($invoice->client->getSetting('auto_email_invoice'))
{
$invoice = $invoice->service()
->markSent()
->applyNumber()
->createInvitations()
->fillDefaults()
->save();
}
else{
$invoice = $invoice->service()
->fillDefaults()
->save();
}
2019-05-23 15:08:31 +10:00
2020-12-30 08:10:03 +11:00
nlog("updating recurring invoice dates");
2020-09-08 20:34:14 +10:00
/* Set next date here to prevent a recurring loop forming */
2021-06-11 08:20:46 +10:00
$this->recurring_invoice->next_send_date = $this->recurring_invoice->nextSendDate();
2020-09-08 20:34:14 +10:00
$this->recurring_invoice->remaining_cycles = $this->recurring_invoice->remainingCycles();
2021-06-11 08:20:46 +10:00
$this->recurring_invoice->last_sent_date = now();
2019-05-23 15:08:31 +10:00
2020-09-08 20:34:14 +10:00
/* Set completed if we don't have any more cycles remaining*/
2020-11-25 15:19:52 +01:00
if ($this->recurring_invoice->remaining_cycles == 0) {
2019-05-23 15:08:31 +10:00
$this->recurring_invoice->setCompleted();
2020-11-25 15:19:52 +01:00
}
2020-12-30 08:10:03 +11:00
nlog("next send date = " . $this->recurring_invoice->next_send_date);
nlog("remaining cycles = " . $this->recurring_invoice->remaining_cycles);
nlog("last send date = " . $this->recurring_invoice->last_sent_date);
2020-09-26 09:48:42 +10:00
$this->recurring_invoice->save();
2021-03-30 12:28:49 +11:00
//Admin notification for recurring invoice sent.
if ($invoice->invitations->count() >= 1 ) {
2021-03-30 12:28:49 +11:00
$invoice->entityEmailEvent($invoice->invitations->first(), 'invoice', 'email_template_invoice');
}
2021-04-21 13:54:10 +10:00
nlog("Invoice {$invoice->number} created");
$invoice->invitations->each(function ($invitation) use ($invoice) {
if ($invitation->contact && strlen($invitation->contact->email) >=1 && $invoice->client->getSetting('auto_email_invoice')) {
2021-04-30 09:01:56 +10:00
try{
2021-06-13 14:19:40 +10:00
EmailEntity::dispatch($invitation, $invoice->company);
2021-04-30 09:01:56 +10:00
}
catch(\Exception $e) {
nlog($e->getMessage());
}
2021-04-21 13:54:10 +10:00
nlog("Firing email for invoice {$invoice->number}");
}
});
2021-03-30 12:28:49 +11:00
if ($invoice->client->getSetting('auto_bill_date') == 'on_send_date' && $this->recurring_invoice->auto_bill_enabled) {
nlog("attempting to autobill {$invoice->number}");
$invoice->service()->autoBill()->save();
}
2019-05-23 15:08:31 +10:00
}
2020-09-08 20:34:14 +10:00
2020-10-07 14:00:32 +11:00
public function failed($exception = null)
{
2020-12-30 08:10:03 +11:00
nlog('the job failed');
2020-10-07 14:00:32 +11:00
$job_failure = new SendRecurringFailure();
$job_failure->string_metric5 = get_class($this);
$job_failure->string_metric6 = $exception->getMessage();
LightLogs::create($job_failure)
->batch();
2020-12-30 08:10:03 +11:00
nlog(print_r($exception->getMessage(), 1));
2020-10-07 14:00:32 +11:00
}
2019-05-23 15:08:31 +10:00
}