1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-11 13:42:49 +01:00
invoiceninja/app/Services/Recurring/RecurringService.php

188 lines
5.0 KiB
PHP
Raw Normal View History

<?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)
*
2021-06-16 08:58:16 +02:00
* @license https://www.elastic.co/licensing/elastic-license
*/
namespace App\Services\Recurring;
2023-10-26 04:57:44 +02:00
use App\Utils\Ninja;
2024-01-13 08:04:03 +01:00
use App\Models\Subscription;
use App\Models\RecurringQuote;
2023-10-26 04:57:44 +02:00
use Illuminate\Support\Carbon;
2024-01-13 08:04:03 +01:00
use App\Utils\Traits\MakesHash;
use App\Models\RecurringExpense;
use App\Models\RecurringInvoice;
2023-06-30 07:43:28 +02:00
use Illuminate\Support\Facades\Storage;
2024-01-13 08:04:03 +01:00
use App\Jobs\RecurringInvoice\SendRecurring;
class RecurringService
{
2024-01-13 08:04:03 +01:00
use MakesHash;
2024-01-14 05:05:00 +01:00
2023-04-26 13:18:01 +02:00
public function __construct(public RecurringInvoice | RecurringExpense | RecurringQuote $recurring_entity)
{
}
//set schedules - update next_send_dates
2024-01-14 05:05:00 +01:00
2020-09-24 02:57:44 +02:00
/**
2020-11-25 15:19:52 +01:00
* Stops a recurring invoice
*
2020-09-24 02:57:44 +02:00
* @return $this RecurringService object
*/
public function stop()
{
2023-02-16 02:36:09 +01:00
if ($this->recurring_entity->status_id < RecurringInvoice::STATUS_PAUSED) {
2021-02-01 21:14:38 +01:00
$this->recurring_entity->status_id = RecurringInvoice::STATUS_PAUSED;
2023-02-16 02:36:09 +01:00
}
2020-09-24 02:57:44 +02:00
return $this;
}
2020-10-04 23:55:52 +02:00
public function createInvitations()
{
$this->recurring_entity = (new CreateRecurringInvitations($this->recurring_entity))->run();
return $this;
}
2020-09-24 02:57:44 +02:00
public function start()
{
if ($this->recurring_entity->remaining_cycles == 0 || $this->recurring_entity->is_deleted) {
2020-10-07 02:20:28 +02:00
return $this;
2020-11-25 15:19:52 +01:00
}
2024-01-14 05:05:00 +01:00
2023-03-18 08:24:56 +01:00
if ($this->recurring_entity->trashed()) {
$this->recurring_entity->restore();
2023-03-18 08:24:56 +01:00
}
2020-09-24 02:57:44 +02:00
$this->setStatus(RecurringInvoice::STATUS_ACTIVE);
2024-01-14 05:05:00 +01:00
2020-11-25 15:19:52 +01:00
return $this;
2020-09-24 02:57:44 +02:00
}
2020-10-09 03:59:59 +02:00
public function setStatus($status)
{
$this->recurring_entity->status_id = $status;
return $this;
}
2020-10-05 23:46:47 +02:00
/**
* Applies the invoice number.
* @return $this InvoiceService object
*/
public function applyNumber()
{
$this->recurring_entity = (new ApplyNumber($this->recurring_entity->client, $this->recurring_entity))->run();
return $this;
}
public function getInvoicePdf($contact = null)
{
return (new GetInvoicePdf($this->recurring_entity, $contact))->run();
}
2021-03-01 00:40:18 +01:00
public function deletePdf()
{
2023-02-16 02:36:09 +01:00
$this->recurring_entity->invitations->each(function ($invitation) {
2023-06-30 07:43:28 +02:00
//30-06-2023
try {
Storage::disk(config('filesystems.default'))->delete($this->recurring_entity->client->recurring_invoice_filepath($invitation) . $this->recurring_entity->numberFormatter().'.pdf');
2023-10-26 04:57:44 +02:00
Storage::disk('public')->delete($this->recurring_entity->client->recurring_invoice_filepath($invitation) . $this->recurring_entity->numberFormatter().'.pdf');
2023-06-30 07:43:28 +02:00
if (Ninja::isHosted()) {
}
} catch (\Exception $e) {
nlog($e->getMessage());
}
2021-06-12 13:50:01 +02:00
});
2021-03-01 00:40:18 +01:00
return $this;
}
2024-01-14 05:05:00 +01:00
public function triggeredActions($request)
{
if ($request->has('start') && $request->input('start') == 'true') {
$this->start();
}
if ($request->has('stop') && $request->input('stop') == 'true') {
$this->stop();
}
2024-01-14 05:05:00 +01:00
if ($request->has('send_now') && $request->input('send_now') == 'true' && $this->recurring_entity->invoices()->count() == 0) {
$this->sendNow();
return $this;
}
2023-02-16 02:36:09 +01:00
if (isset($this->recurring_entity->client)) {
$offset = $this->recurring_entity->client->timezone_offset();
$this->recurring_entity->next_send_date = Carbon::parse($this->recurring_entity->next_send_date_client)->startOfDay()->addSeconds($offset);
}
return $this;
}
public function sendNow()
{
2023-02-16 02:36:09 +01:00
if ($this->recurring_entity instanceof RecurringInvoice && $this->recurring_entity->status_id == RecurringInvoice::STATUS_DRAFT) {
2022-07-12 12:47:17 +02:00
$this->start()->save();
2023-02-16 02:36:09 +01:00
(new SendRecurring($this->recurring_entity, $this->recurring_entity->company->db))->handle();
2022-07-12 12:47:17 +02:00
}
$this->recurring_entity = $this->recurring_entity->fresh();
return $this;
}
2021-09-25 01:26:27 +02:00
public function fillDefaults()
{
return $this;
}
2023-03-15 07:01:55 +01:00
public function increasePrice(float $percentage)
{
2023-03-15 07:01:55 +01:00
(new IncreasePrice($this->recurring_entity, $percentage))->run();
2024-01-14 05:05:00 +01:00
2023-03-15 07:01:55 +01:00
return $this;
}
2023-03-15 07:01:55 +01:00
public function updatePrice()
{
2023-03-15 07:01:55 +01:00
(new UpdatePrice($this->recurring_entity))->run();
2023-03-15 07:01:55 +01:00
return $this;
}
2024-01-14 05:05:00 +01:00
2024-01-13 08:04:03 +01:00
public function setPaymentLink(string $subscription_id): self
{
$sub_id = $this->decodePrimaryKey($subscription_id);
if(Subscription::withTrashed()->where('id', $sub_id)->where('company_id', $this->recurring_entity->company_id)->exists()) {
$this->recurring_entity->subscription_id = $sub_id;
}
return $this;
}
2020-09-24 02:57:44 +02:00
public function save()
{
$this->recurring_entity->saveQuietly();
2020-09-24 02:57:44 +02:00
2020-11-25 15:19:52 +01:00
return $this->recurring_entity;
2020-09-24 02:57:44 +02:00
}
}