Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/malik12tree/zatca
PHP implementation of ZATCA E-Invoicing standards. 🛡️💸
https://github.com/malik12tree/zatca
composer e-invoicing php qrcode zatca
Last synced: 6 days ago
JSON representation
PHP implementation of ZATCA E-Invoicing standards. 🛡️💸
- Host: GitHub
- URL: https://github.com/malik12tree/zatca
- Owner: Malik12tree
- License: mit
- Created: 2024-11-10T00:48:39.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2024-11-17T14:37:30.000Z (2 months ago)
- Last Synced: 2024-11-17T15:30:01.667Z (2 months ago)
- Topics: composer, e-invoicing, php, qrcode, zatca
- Language: PHP
- Homepage:
- Size: 175 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.MD
- License: LICENSE
Awesome Lists containing this project
README
malik12tree/zatca
PHP implementation of ZATCA E-Invoicing standards.
## Table of Contents
- [Installation](#installation)
- [Glossary](#glossary)
- [Usage](#usage)
- [Register EGS](#register-egs)
- [Saving/Loading EGS](#savingloading-egs)
- [Invoicing](#invoicing)
- [PDF/A-3 Invoice](#pdfa-3-invoice)
- [License](#license)
- [Acknowledgments](#acknowledgments)
- [Disclaimer](#disclaimer)
- [Non-Affiliation Disclaimer](#non-affiliation-disclaimer)## Installation
### Composer
```bash
composer require malik12tree/zatca
```## Glossary
| Term | Definition |
| ---- | ------------------------------- |
| EGS | E-Invoicing Generation Solution |## Usage
### Register EGS
```php
use Malik12tree\ZATCA;
use Malik12tree\ZATCA\EGS;
use Malik12tree\ZATCA\Utils\Encoding\Crypto;// Your must set the EGS environment or else initiating an EGS will throw an exception.
// Possible values are sandbox, simulation and production.
// - sandbox:
// - For testing purposes only.
// - Validation only.
// - No web-based portal.
// - Known Fixed OTPs:
// - Valid: 123345
// - Invalid: 111111
// - Expired: 222222
// - simulation:
// - For testing purposes only.
// - Connects to the Fatoora portal.
// - Generate OTPs.
// - Simulates real validation and storing of EGSs and invoices at the simulation database.
// - Accessing Portal:
// - Head to https://fatoora.zatca.gov.sa
// - Login with your credentials.
// - Click "Fatoora Simulation Portal".
// - production:
// - For live production use.
// - Exercise caution when using this environment.
// - Connects to the Fatoora portal.
// - Generate OTPs
// - Real validation and storing of EGSs and invoices at the production database.
// - Accessing Portal:
// - Head to https://fatoora.zatca.gov.sa
// - Login with your credentials.
// - Click "Fatoora Simulation Portal".
//
// - simulation: This is for testing purposes containing real validation with a real database storing EGSs and invoices. It does connect to a portal. You can generate OTPs from the Fatoora portal. You can view generate EGSs and invoices at the portal.
// - production: This is used dangerously in production.
EGS::setEnv('sandbox');$egs = new EGS([
// EGS Serial Number
// You should generate a unique UUID for each EGS
// Use Crypto::uuid4() to generate a secure UUID
'uuid' => '00000000-0000-0000-0000-000000000000','common_name' => 'Cashier #1',
'model' => 'Windows Vista',// Known as CRN Number, License Number or Contract Number
'crn_number' => '1234567890',
// Known as VAT Name or Taxpayer Name
'vat_name' => 'My Totally Existing Company',
// Known as VAT Registration Number
// Should be a valid 15 digits number starting and ending with "3"
'vat_number' => '300001234500003',
'branch_name' => 'My Really Profound Branch',
'branch_industry' => 'Trading','location' => [
'building' => 'Al Yamama Tower',
'street' => 'King Fahd Rd',
'city_subdivision' => 'Al Olaya',
'city' => 'Riyadh',
'plot_identification' => '0000',
'postal_zone' => '00000',
],
]);// Obtain an OTP (One-Time Password) from the Fatoora portal https://fatoora.zatca.gov.sa/onboard-solution for each EGS registration.
$otp = '123345';
$solutionName = 'My POS System\'s Name';try {
$egs->register($solutionName, $otp);
} catch (ZATCA\Exceptions\APIException $e) {
// Handle API Exceptions gracefully
// If you believe a bug occurred, please report it at https://github.com/Malik12tree/zatca/issues
// $e->getCode()
// $e->getMessage()
// $e->getResponse()
throw $e;
}// ...
```### Saving/Loading EGS
```php
use Malik12tree\ZATCA\EGSDatabases\EGSFileDatabase;// Store the EGS object and its credentials for later use.
// Be mindful to locate the EGS database to a safe place$database = new EGSFileDatabase(__DIR__.'/private-secure-storage/solutions');
// Option 1
$database->save($egs);
// Option 2
$egs->setDatabase($database);
$egs->save();// Retrieve a previously saved EGS using its UUID
$loadedEgs = $database->load('00000000-0000-0000-0000-000000000000');// ...
```### Invoicing
```php
use Malik12tree\ZATCA\Invoice;
use Malik12tree\ZATCA\Invoice\Enums\InvoiceCode;
use Malik12tree\ZATCA\Invoice\Enums\InvoiceType;$invoice = $egs->invoice([
'invoice_code' => InvoiceCode::TAX,
'invoice_type' => InvoiceType::INVOICE,// To your heart's desire
// Even uuids are acceptable
'invoice_serial_number' => 'INV-0000001',
'invoice_counter_number' => 0,'issue_date' => date('Y-m-d'),
'issue_time' => date('H:i:s'),
'actual_delivery_date' => date('Y-m-d', strtotime('tomorrow')),'previous_invoice_hash' => Invoice::INITIAL_PREVIOUS_HASH,
'customer_info' => [
'vat_number' => '300000000000003',
'buyer_name' => 'Mahmoud 3gwa','building' => 'Juice Stand',
'street' => 'Abaseya Tunnel',
'city_subdivision' => '',
'city' => 'Dammam',
'plot_identification' => '0000',
'postal_zone' => '00000',
],'line_items' => [
[
'id' => "sugarcane_juicer_metal",
'name' => 'Metal Sugarcane Juicer',
'quantity' => 1.0,
'unit_price' => 525.0,
'vat_percent' => 0.15,
'discounts' => [
[
'amount' => 100.0,
'reason' => 'Special Customer',
],
],
],
],
]);try {
$signedInvoice = $egs->signInvoice($invoice);// Throws an exception if the EGS is not compliant
// Even if the EGS is compliant, $response may contain warnings
$response = $egs->checkInvoiceCompliance($signedInvoice);$response = $egs->reportInvoice($signedInvoice);
} catch (ZATCA\Exceptions\APIException $e) {
// Handle API Exceptions gracefully
// If you believe a bug occurred, please report it at https://github.com/Malik12tree/zatca/issues
// $e->getCode()
// $e->getMessage()
// $e->getResponse()
throw $e;
} catch (Exception $e) {
// Handle Exceptions gracefully
// If you believe a bug occurred, please report it at https://github.com/Malik12tree/zatca/issues
throw $e;
}// ...
```### PDF/A-3 Invoice
ZATCA rules that each invoice must be converted into a
standardized PDF/A-3 format containing all essential information.
Additionally, a signed XML invoice attachment must be included within the PDF.Fortunately, this library simplifies this process significantly by utilizing a built-in PDF builder.
```php
$pdfInvoice = $signedInvoice->toPDF([
// Optional Logo
"logo" => __DIR__ . "/assets"
]);// Save at directory.
// saveAt(...) automatically appends the PDF name according to
// ZATCA's naming convention.
$pdfInvoice->saveAt(__DIR__ . "/private-secure-storage/invoices");// Alternatively, You can store the binary data.
$binaryData = $pdfInvoice->getPDF();
```## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details
## Acknowledgments
Special thanks to [zatca-xml-js](https://github.com/Repzo/zatca-xml-js).
## Disclaimer
This library is developed by humans and may contain errors or inaccuracies, despite its purpose of facilitating government invoicing processes. While we strive to ensure the highest quality and accuracy, we cannot guarantee the absolute correctness of all information and functionalities.
**Please note that we are not liable for any consequences arising from the use of this library, including but not limited to financial losses, legal issues, or system failures.**
It is strongly recommended to thoroughly test and validate all outputs generated by this library before relying on them for critical business decisions or government submissions.
## Non-Affiliation Disclaimer
This library is not affiliated with ZATCA or any of its subsidiaries or affiliates. The library's development and maintenance are independent of ZATCA. Any references to ZATCA or its standards are for informational purposes only and do not imply endorsement or sponsorship by ZATCA.