Files
invoiceninja/app/Http/ValidationRules/EInvoice/ValidCreditScheme.php
2026-01-19 12:10:34 +11:00

107 lines
3.2 KiB
PHP

<?php
/**
* Invoice Ninja (https://invoiceninja.com).
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2025. Invoice Ninja LLC (https://invoiceninja.com)
*1`
* @license https://www.elastic.co/licensing/elastic-license
*/
namespace App\Http\ValidationRules\EInvoice;
use App\Services\EDocument\Standards\Validation\Peppol\CreditLevel;
use Closure;
use InvoiceNinja\EInvoice\EInvoice;
use Illuminate\Validation\Validator;
use InvoiceNinja\EInvoice\Models\Peppol\Invoice;
use Illuminate\Contracts\Validation\ValidationRule;
use Illuminate\Contracts\Validation\ValidatorAwareRule;
/**
* Class ValidScheme.
*/
class ValidCreditScheme implements ValidationRule, ValidatorAwareRule
{
/**
* The validator instance.
*
* @var Validator
*/
protected $validator;
public function validate(string $attribute, mixed $value, Closure $fail): void
{
if (isset($value['CreditNote'])) {
$r = new EInvoice();
if (data_get($value, 'CreditNote.BillingReference.0.InvoiceDocumentReference.IssueDate') === null ||
data_get($value, 'CreditNote.BillingReference.0.InvoiceDocumentReference.IssueDate') === '') {
unset($value['CreditNote']['BillingReference'][0]['InvoiceDocumentReference']['IssueDate']);
}
$errors = $r->validateRequest($value['CreditNote'], CreditLevel::class);
foreach ($errors as $key => $msg) {
$this->validator->errors()->add(
"e_invoice.{$key}",
"{$key} - {$msg}"
);
}
if (data_get($value, 'CreditNote.BillingReference.0.InvoiceDocumentReference.ID') === null ||
data_get($value, 'CreditNote.BillingReference.0.InvoiceDocumentReference.ID') === '') {
$this->validator->errors()->add(
"e_invoice.BillingReference.0.InvoiceDocumentReference.ID",
"Invoice Reference/Number is required"
);
}
if (isset($value['CreditNote']['BillingReference'][0]['InvoiceDocumentReference']['IssueDate']) && strlen($value['CreditNote']['BillingReference'][0]['InvoiceDocumentReference']['IssueDate']) > 1 && !$this->isValidDateSyntax($value['CreditNote']['BillingReference'][0]['InvoiceDocumentReference']['IssueDate'])) {
$this->validator->errors()->add(
"e_invoice.BillingReference.0.InvoiceDocumentReference.IssueDate",
"Invoice Issue Date is required"
);
}
}
}
private function isValidDateSyntax(string $date_string): bool
{
// Strict format validation: must be exactly Y-m-d
$date = \DateTime::createFromFormat('Y-m-d', $date_string);
if ($date === false) {
return false;
}
// Ensure the formatted date matches the input (catches overflow)
return $date->format('Y-m-d') === $date_string;
}
/**
* Set the current validator.
*/
public function setValidator(Validator $validator): static
{
$this->validator = $validator;
return $this;
}
}