ahmedabdelnaby/zatca-tools 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

ahmedabdelnaby/zatca-tools

Composer 安装命令:

composer require ahmedabdelnaby/zatca-tools

包简介

A helper to generate the QR code and signed it for ZATCA e-invoicing

README 文档

README

🧾 ZATCA (Fatoora) QR-Code & Invoice Signing

A PHP library to generate QR codes and sign invoices for ZATCA e-invoicing compliance in Saudi Arabia.
🐛 Report Bug · ✨ Request Feature

✅ Requirements

  • 🐘 PHP >= 8.0
  • 🔡 mbstring extension
  • 📜 ext-dom extension

📦 Installation

Install the package via Composer:

composer require ahmedabdelnaby/zatca-tools

🚀 Usage

This package supports both Phase 1 and Phase 2 of ZATCA compliance.

  • Phase 1: 🔲 QR code generation.
  • Phase 2: ✍️ Invoice signing & 🏢 System integration with ZATCA.

1️⃣ Generating CSR (Certificate Signing Request)

Before signing invoices, you need to generate a CSR and register your merchant in ZATCA APIs.

use ZATCA\Tools\GenerateCSR;
use ZATCA\Tools\Models\CSRRequest;

$data = CSRRequest::make()
    ->setUID('string $OrganizationIdentifier')
    ->setSerialNumber('string $solutionName', 'string $version', 'string $serialNumber')
    ->setCommonName('string $commonName')
    ->setCountryName('SA')
    ->setOrganizationName('string $organizationName')
    ->setOrganizationalUnitName('string $organizationalUnitName')
    ->setRegisteredAddress('string $registeredAddress')
    ->setInvoiceType(true, true) // invoice types, default is true, true
    ->setCurrentZatcaEnv('sandbox') // Supports ['sandbox', 'simulation', 'core']
    ->setBusinessCategory('string $businessCategory');

$CSR = GenerateCSR::fromRequest($data)->initialize()->generate();

// Save 🔑 private key
openssl_pkey_export_to_file($CSR->getPrivateKey(), 'private-key.pem');

// Save 📝 CSR content
file_put_contents('csr.pem', $CSR->getCsrContent());

🔹 Now, submit the CSR to ZATCA APIs to receive your certificate.

2️⃣ Signing Invoices & Generating QR Code

After receiving a certificate from ZATCA, you can sign invoices and generate QR codes.

use ZATCA\Tools\Helpers\Certificate;
use ZATCA\Tools\Models\InvoiceSign;

$xmlInvoice = 'xml invoice text';

$certificate = (new Certificate(
    'certificate plain text (base64 decoded)', // 📜 Get from ZATCA
    'private key plain text' // 🔑 Generated in CSR step
))->setSecretKey('🔒 secret key text'); // 🔑 Get from ZATCA

$invoice = (new InvoiceSign($xmlInvoice, $certificate))->sign();

// Get invoice details 📄
$invoice->getHash();      // 🏷️ Invoice Hash
$invoice->getInvoice();   // 📝 Signed XML Invoice
$invoice->getQRCode();    // 🔲 QR Code in Base64 format

3️⃣ Generating QR Code from Invoice Data

use ZATCA\Tools\GenerateQrCode;
use ZATCA\Tools\Helpers\UXML;
use ZATCA\Tools\Helpers\Certificate;

$xmlInvoice = 'xml invoice text';

$certificate = (new Certificate(
    'certificate plain text (base64 decoded)',
    'private key plain text'
))->setSecretKey('secret key text');

$tags = UXML::fromString($xmlInvoice)->toTagsArray($certificate);

$QRCodeAsBase64 = GenerateQrCode::fromArray($tags)->toBase64();

4️⃣ Generating Basic QR Code (Phase 1)

use ZATCA\Tools\GenerateQrCode;
use ZATCA\Tools\Tags\InvoiceDate;
use ZATCA\Tools\Tags\InvoiceTaxAmount;
use ZATCA\Tools\Tags\InvoiceTotalAmount;
use ZATCA\Tools\Tags\Seller;
use ZATCA\Tools\Tags\TaxNumber;

$generatedString = GenerateQrCode::fromArray([
    new Seller('Company Name'),
    new TaxNumber('1234567891'),
    new InvoiceDate('2024-02-17T14:25:09Z'),
    new InvoiceTotalAmount('500.00'),
    new InvoiceTaxAmount('75.00')
])->toBase64();

5️⃣ Display QR Code in HTML

$displayQRCodeAsBase64 = GenerateQrCode::fromArray([
    new Seller('Company Name'),
    new TaxNumber('1234567891'),
    new InvoiceDate('2024-02-17T14:25:09Z'),
    new InvoiceTotalAmount('500.00'),
    new InvoiceTaxAmount('75.00')
])->render();

Now, use it in an <img> tag:

<img src="<?php echo $displayQRCodeAsBase64; ?>" alt="Invoice QR Code" />

🔎 Reading the QR Code

The QR code follows ZATCA's TLV format, making it unreadable by normal scanners.
To check your QR code, use this online scanner:
🔗 📸 Online QR Code Reader

🧪 Running Tests

Run the tests using:

composer test

🔒 Security

If you discover security vulnerabilities, please do not open an issue. Instead, email:
📧 ahmedabdelnabyfahmy1@gmail.com

统计信息

  • 总下载量: 1.84k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 73
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-02-17