lavaloon-eg / ksa_compliance

KSA Compliance App for KSA E-invoice
https://www.lavaloon.com/
GNU Affero General Public License v3.0
26 stars 16 forks source link

Zatca Status #103

Closed saud-2 closed 1 week ago

saud-2 commented 2 weeks ago

zatca status is appearing for reported invoices and empty for cleared invoices as you can see in photo , I think there is something missing

IMG_3200

mhaggag commented 2 weeks ago

Can you open one of the integration logs with missing status and share the ZATCA response? We've had issues in the past where the ZATCA JSON response wasn't in line with the documented OpenAPI schema, so the code extracting the status was unable to do so. It's either that, or a regression in our response parsing logic.

saud-2 commented 2 weeks ago
Details

"status": null, "invoice_hash": null, "cleared_invoice": "<?xml version="1.0" encoding="UTF-8"?>
<Invoice xmlns="urn:oasis:names:specification:ubl:schema:xsd:Invoice-2" xmlns:cac="urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2" xmlns:cbc="urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2" xmlns:ext="urn:oasis:names:specification:ubl:schema:xsd:CommonExtensionComponents-2"><ext:UBLExtensions>
    <ext:UBLExtension>
        <ext:ExtensionURI>urn:oasis:names:specification:ubl:dsig:enveloped:xades</ext:ExtensionURI>
        <ext:ExtensionContent>
            <sig:UBLDocumentSignatures xmlns:sig="urn:oasis:names:specification:ubl:schema:xsd:CommonSignatureComponents-2" xmlns:sac="urn:oasis:names:specification:ubl:schema:xsd:SignatureAggregateComponents-2" xmlns:sbc="urn:oasis:names:specification:ubl:schema:xsd:SignatureBasicComponents-2">
                <sac:SignatureInformation> 
                    <cbc:ID>urn:oasis:names:specification:ubl:signature:1</cbc:ID>
                    <sbc:ReferencedSignatureID>urn:oasis:names:specification:ubl:signature:Invoice</sbc:ReferencedSignatureID>
                    <ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#" Id="signature">
                        <ds:SignedInfo>
                            <ds:CanonicalizationMethod Algorithm="http://www.w3.org/2006/12/xml-c14n11"/>
                            <ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#ecdsa-sha256"/>
                            <ds:Reference Id="invoiceSignedData" URI="">
                                <ds:Transforms>
                                    <ds:Transform Algorithm="http://www.w3.org/TR/1999/REC-xpath-19991116">
                                        <ds:XPath>not(//ancestor-or-self::ext:UBLExtensions)</ds:XPath>
                                    </ds:Transform>
                                    <ds:Transform Algorithm="http://www.w3.org/TR/1999/REC-xpath-19991116">
                                        <ds:XPath>not(//ancestor-or-self::cac:Signature)</ds:XPath>
                                    </ds:Transform>
                                    <ds:Transform Algorithm="http://www.w3.org/TR/1999/REC-xpath-19991116">
                                        <ds:XPath>not(//ancestor-or-self::cac:AdditionalDocumentReference[cbc:ID='QR'])</ds:XPath>
                                    </ds:Transform>
                                    <ds:Transform Algorithm="http://www.w3.org/2006/12/xml-c14n11"/>
                                </ds:Transforms>
                                <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
                                <ds:DigestValue>dUdPiieZwau2ZZq3AwMffDkHI/QKtQ2VNou2HWR4k/8=</ds:DigestValue>
                            </ds:Reference>
                            <ds:Reference Type="http://www.w3.org/2000/09/xmldsig#SignatureProperties" URI="#xadesSignedProperties">
                                <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
                                <ds:DigestValue>NjViZGI5YWVkMDBlZjdjZWI2NDY4ZjI4YzJmYmUyNzU4Mjc4M2E1YWFhNWZkNzY1ZDBlNTkzYWQ2YzU0MmU1OQ==</ds:DigestValue>
                            </ds:Reference>
                        </ds:SignedInfo>
                        <ds:SignatureValue>MEUCIGzqj41sCFkooRMqg3/zVsPWXq0Y1rkayrWN4qe4Dm6cAiEA/JI7efa7kE9BsR1W4fam2qLpi+9JFB0JSE2bHZSMNuc=</ds:SignatureValue>
                        <ds:KeyInfo>
                            <ds:X509Data>
                                <ds:X509Certificate>MIIFCzCCBLKgAwIBAgITeAAASe6SKtbOiJEHxQABAABJ7jAKBggqhkjOPQQDAjBiMRUwEwYKCZImiZPyLGQBGRYFbG9jYWwxEzARBgoJkiaJk/IsZAEZFgNnb3YxFzAVBgoJkiaJk/IsZAEZFgdleHRnYXp0MRswGQYDVQQDExJQRVpFSU5WT0lDRVNDQTQtQ0EwHhcNMjQwODI3MTEzMjA2WhcNMjYwODI3MTE0MjA2WjBnMQswCQYDVQQGEwJTQTEcMBoGA1UECgwT2KfZhNmG2LHYrNizIChEZW1vKTEcMBoGA1UECwwT2LLZitiqINin2YTZhtix2KzYszEcMBoGA1UEAwwT2LLZitiqINin2YTZhtix2KzYszBWMBAGByqGSM49AgEGBSuBBAAKA0IABD86a9g1tqUGY6P/kHtmLPIaSTCIrkV/7z+YOAeDgYD7+fWicrxi3Tj40mucfjPPnGENPwD7d7+CgtT+9pzCkOSjggNDMIIDPzCBrQYDVR0RBIGlMIGipIGfMIGcMRswGQYDVQQEDBIxLUVSUE5leHR8Mi0xNXwzLTExHzAdBgoJkiaJk/IsZAEBDA8zMTAxNjkyMDA2MDAwMDMxDTALBgNVBAwMBDEwMDAxPDA6BgNVBBoMMzI4NzUgMjg3NSBHaGlybmF0YWggc3RyZWV0IDIzLCDYutix2YbYp9i32KksIFJpeWFkaDEPMA0GA1UEDwwGUmV0YWlsMB0GA1UdDgQWBBTCmk5VILkxNhtIO3OjPqhUFuAEZzAfBgNVHSMEGDAWgBTHwOa3qd0Syk89bWiCliFF8wF1pDCB5QYDVR0fBIHdMIHaMIHXoIHUoIHRhoHObGRhcDovLy9DTj1QRVpFSU5WT0lDRVNDQTQtQ0EoMSksQ049UFJaRUlOVk9JQ0VQS0k0LENOPUNEUCxDTj1QdWJsaWMlMjBLZXklMjBTZXJ2aWNlcyxDTj1TZXJ2aWNlcyxDTj1Db25maWd1cmF0aW9uLERDPWV4dHphdGNhLERDPWdvdixEQz1sb2NhbD9jZXJ0aWZpY2F0ZVJldm9jYXRpb25MaXN0P2Jhc2U/b2JqZWN0Q2xhc3M9Y1JMRGlzdHJpYnV0aW9uUG9pbnQwgc4GCCsGAQUFBwEBBIHBMIG+MIG7BggrBgEFBQcwAoaBrmxkYXA6Ly8vQ049UEVaRUlOVk9JQ0VTQ0E0LUNBLENOPUFJQSxDTj1QdWJsaWMlMjBLZXklMjBTZXJ2aWNlcyxDTj1TZXJ2aWNlcyxDTj1Db25maWd1cmF0aW9uLERDPWV4dHphdGNhLERDPWdvdixEQz1sb2NhbD9jQUNlcnRpZmljYXRlP2Jhc2U/b2JqZWN0Q2xhc3M9Y2VydGlmaWNhdGlvbkF1dGhvcml0eTAOBgNVHQ8BAf8EBAMCB4AwPAYJKwYBBAGCNxUHBC8wLQYlKwYBBAGCNxUIgYaoHYTQ+xKG7Z0kh877GdPAVWaBnNgtg+XFXQIBZAIBEDAdBgNVHSUEFjAUBggrBgEFBQcDAgYIKwYBBQUHAwMwJwYJKwYBBAGCNxUKBBowGDAKBggrBgEFBQcDAjAKBggrBgEFBQcDAzAKBggqhkjOPQQDAgNHADBEAiADg6HF2BLbgrFD0LFoi9pD909f4OSVN8+qQR6zxoJTGAIgJWY9D3GJzf++WYSaaG80c/GYHnsYtYeAJhMsCQ7fZIY=</ds:X509Certificate>
                            </ds:X509Data>
                        </ds:KeyInfo>
                        <ds:Object>
                            <xades:QualifyingProperties xmlns:xades="http://uri.etsi.org/01903/v1.3.2#" Target="signature">
                                <xades:SignedProperties Id="xadesSignedProperties">
                                    <xades:SignedSignatureProperties>
                                        <xades:SigningTime>2024-08-28T07:13:25</xades:SigningTime>
                                        <xades:SigningCertificate>
                                            <xades:Cert>
                                                <xades:CertDigest>
                                                    <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
                                                    <ds:DigestValue>YWM0YmQ5ZWEzODk0NTA2YjU0MGIwMDg4OWQwZDAwNThlNGZjNWUyNDU4YWNmMmZiZjllMjllMGVhMDNkMDkyOQ==</ds:DigestValue>
                                                </xades:CertDigest>
                                                <xades:IssuerSerial>
                                                    <ds:X509IssuerName>CN=PEZEINVOICESCA4-CA, DC=extgazt, DC=gov, DC=local</ds:X509IssuerName>
                                                    <ds:X509SerialNumber>2676089522096049747478868371057925144770005486</ds:X509SerialNumber>
                                                </xades:IssuerSerial>
                                            </xades:Cert>
                                        </xades:SigningCertificate>
                                    </xades:SignedSignatureProperties>
                                </xades:SignedProperties>
                            </xades:QualifyingProperties>
                        </ds:Object>
                    </ds:Signature>
                </sac:SignatureInformation>
            </sig:UBLDocumentSignatures>
        </ext:ExtensionContent>
    </ext:UBLExtension>
</ext:UBLExtensions>
    <cbc:ProfileID>reporting:1.0</cbc:ProfileID>
    <cbc:ID>ACC-SINV-2024-00013</cbc:ID>
    <cbc:UUID>995d2a6c-f091-4eb8-9ac6-d4fa7d3877ad</cbc:UUID>
    <cbc:IssueDate>2024-08-28</cbc:IssueDate>
    <cbc:IssueTime>07:13:23</cbc:IssueTime>
    <cbc:InvoiceTypeCode name="0100000">388</cbc:InvoiceTypeCode>
    <cbc:DocumentCurrencyCode>SAR</cbc:DocumentCurrencyCode>
    <cbc:TaxCurrencyCode>SAR</cbc:TaxCurrencyCode>
    
    
    <cac:AdditionalDocumentReference>
        <cbc:ID>ICV</cbc:ID>
        <cbc:UUID>4</cbc:UUID>
    </cac:AdditionalDocumentReference>
    <cac:AdditionalDocumentReference>
        <cbc:ID>PIH</cbc:ID>
        <cac:Attachment>
            <cbc:EmbeddedDocumentBinaryObject mimeCode="text/plain">7gbqFpMW3WfgUpYaMG7bXd2q2214KhXTy0ey854n29M=</cbc:EmbeddedDocumentBinaryObject>
        </cac:Attachment>
    </cac:AdditionalDocumentReference>
    <!-- Seller info -->
    <cac:AdditionalDocumentReference>
        <cbc:ID>QR</cbc:ID>
        <cac:Attachment>
            <cbc:EmbeddedDocumentBinaryObject mimeCode="text/plain">ARPYstmK2Kog2KfZhNmG2LHYrNizAg8zMTAxNjkyMDA2MDAwMDMDEzIwMjQtMDgtMjhUMDc6MTM6MjMEBDM0LjUFAzQuNQYsZFVkUGlpZVp3YXUyWlpxM0F3TWZmRGtISS9RS3RRMlZOb3UySFdSNGsvOD0HYE1FVUNJR3pxajQxc0NGa29vUk1xZzMvelZzUFdYcTBZMXJrYXlyV040cWU0RG02Y0FpRUEvSkk3ZWZhN2tFOUJzUjFXNGZhbTJxTHBpKzlKRkIwSlNFMmJIWlNNTnVjPQhYMFYwEAYHKoZIzj0CAQYFK4EEAAoDQgAEPzpr2DW2pQZjo/+Qe2Ys8hpJMIiuRX/vP5g4B4OBgPv59aJyvGLdOPjSa5x+M8+cYQ0/APt3v4KC1P72nMKQ5A==</cbc:EmbeddedDocumentBinaryObject>
        </cac:Attachment>
</cac:AdditionalDocumentReference><cac:Signature>
      <cbc:ID>urn:oasis:names:specification:ubl:signature:Invoice</cbc:ID>
      <cbc:SignatureMethod>urn:oasis:names:specification:ubl:dsig:enveloped:xades</cbc:SignatureMethod>
</cac:Signature><cac:AccountingSupplierParty>
        <cac:Party>
            <!-- Additional seller IDs -->
            
            
            <cac:PartyIdentification>
                <cbc:ID schemeID="CRN">310169200600003</cbc:ID>
            </cac:PartyIdentification>
            
            
            <cac:PostalAddress>
                <cbc:StreetName>2875 Ghirnatah street 23</cbc:StreetName>
                <cbc:BuildingNumber>2875</cbc:BuildingNumber>
                
                <cbc:CitySubdivisionName>غرناطة</cbc:CitySubdivisionName>
                <cbc:CityName>Riyadh</cbc:CityName>
                
                <cbc:PostalZone>13241</cbc:PostalZone>
                
                
                <cac:Country>
                    <cbc:IdentificationCode>SA</cbc:IdentificationCode>
                </cac:Country>
            </cac:PostalAddress>
            <cac:PartyTaxScheme>
                <!-- Vat Registration Number -->
                <cbc:CompanyID>310169200600003</cbc:CompanyID>
                <cac:TaxScheme>
                    <cbc:ID>VAT</cbc:ID>
                </cac:TaxScheme>
            </cac:PartyTaxScheme>
            <cac:PartyLegalEntity>
                <cbc:RegistrationName>زيت النرجس</cbc:RegistrationName>
            </cac:PartyLegalEntity>
        </cac:Party>
    </cac:AccountingSupplierParty>
    <!-- Buyer info -->
    <cac:AccountingCustomerParty>
        <cac:Party>
            
            <cac:PostalAddress>
                
                <cbc:StreetName>2875 Ghirnatah street 23</cbc:StreetName>
                
                
                <cbc:BuildingNumber>2875</cbc:BuildingNumber>
                
                
                
                <cbc:CitySubdivisionName>غرناطة</cbc:CitySubdivisionName>
                
                
                <cbc:CityName>Riyadh</cbc:CityName>
                
                
                <cbc:PostalZone>13241</cbc:PostalZone>
                
                
                
                <cac:Country>
                    <cbc:IdentificationCode>SA</cbc:IdentificationCode>
                </cac:Country>
                
            </cac:PostalAddress>
            
            <cac:PartyTaxScheme>
                <cbc:CompanyID>310145987200003</cbc:CompanyID>
                <cac:TaxScheme>
                    <cbc:ID>VAT</cbc:ID>
                </cac:TaxScheme>
            </cac:PartyTaxScheme>
            
            
            <cac:PartyLegalEntity>
                <cbc:RegistrationName>West View Software Ltd.</cbc:RegistrationName>
            </cac:PartyLegalEntity>
            
        </cac:Party>
    </cac:AccountingCustomerParty>
    
    <cac:Delivery>
        <cbc:ActualDeliveryDate>2024-08-28</cbc:ActualDeliveryDate>
    </cac:Delivery>
    
    
    <cac:AllowanceCharge>
        <cbc:ChargeIndicator>false</cbc:ChargeIndicator>
        <cbc:AllowanceChargeReason>Discount</cbc:AllowanceChargeReason>
        <cbc:Amount currencyID="SAR">0.0</cbc:Amount>
        <cac:TaxCategory>
            <cbc:ID>S</cbc:ID>
            
            <cbc:Percent>15.0</cbc:Percent>
            
            
            
            <cac:TaxScheme>
                <cbc:ID>VAT</cbc:ID>
            </cac:TaxScheme>
        </cac:TaxCategory>
    </cac:AllowanceCharge>
    <cac:TaxTotal>
        <cbc:TaxAmount currencyID="SAR">4.5</cbc:TaxAmount>
        <cac:TaxSubtotal>
            <cbc:TaxableAmount currencyID="SAR">30.0</cbc:TaxableAmount>
            <cbc:TaxAmount currencyID="SAR">4.5</cbc:TaxAmount>
            <cac:TaxCategory>
                <cbc:ID>S</cbc:ID>
                <cbc:Percent>15.0</cbc:Percent>
                
                
                <cac:TaxScheme>
                    <cbc:ID>VAT</cbc:ID>
                </cac:TaxScheme>
            </cac:TaxCategory>
        </cac:TaxSubtotal>
    </cac:TaxTotal>
    <cac:TaxTotal>
        <cbc:TaxAmount currencyID="SAR">4.5</cbc:TaxAmount>
    </cac:TaxTotal>
    <cac:LegalMonetaryTotal>
        <cbc:LineExtensionAmount currencyID="SAR">30.0</cbc:LineExtensionAmount>
        <cbc:TaxExclusiveAmount currencyID="SAR">30.0</cbc:TaxExclusiveAmount>
        <cbc:TaxInclusiveAmount currencyID="SAR">34.5</cbc:TaxInclusiveAmount>
        <cbc:AllowanceTotalAmount currencyID="SAR">0.0</cbc:AllowanceTotalAmount>
        
        <cbc:PayableAmount currencyID="SAR">34.5</cbc:PayableAmount>
    </cac:LegalMonetaryTotal>

    <!-- Invoice item lines -->
    
    <cac:InvoiceLine>
        <cbc:ID>1</cbc:ID>
        <cbc:Note>خدمة شغل</cbc:Note>
        <cbc:InvoicedQuantity unitCode="PCE">1.0</cbc:InvoicedQuantity>
        <cbc:LineExtensionAmount currencyID="SAR">30.0</cbc:LineExtensionAmount>
        <cac:TaxTotal>
            
            <cbc:TaxAmount currencyID="SAR">4.5</cbc:TaxAmount>
            
            <cbc:RoundingAmount currencyID="SAR">34.5</cbc:RoundingAmount>
            <cac:TaxSubtotal>
                <cbc:TaxableAmount currencyID="SAR">30.0</cbc:TaxableAmount>
                
                <cbc:TaxAmount currencyID="SAR">4.5</cbc:TaxAmount>
                
                <cac:TaxCategory>
                    <cbc:ID>S</cbc:ID>
                    <cbc:Percent>15.0</cbc:Percent>
                    
                    
                    <cac:TaxScheme>
                        <cbc:ID>VAT</cbc:ID>
                    </cac:TaxScheme>
                </cac:TaxCategory>
            </cac:TaxSubtotal>
        </cac:TaxTotal>
        <cac:Item>
            <cbc:Name>خدمة شغل</cbc:Name>
            

            

            <cac:ClassifiedTaxCategory>
                <cbc:ID>S</cbc:ID>
                
                <cbc:Percent>15.0</cbc:Percent>
                
                <cac:TaxScheme>
                    <cbc:ID>VAT</cbc:ID>
                </cac:TaxScheme>
            </cac:ClassifiedTaxCategory>
        </cac:Item>
        <cac:Price>
            <cbc:PriceAmount currencyID="SAR">30.0</cbc:PriceAmount>
            <cbc:BaseQuantity unitCode="PCE">1.0</cbc:BaseQuantity>
        </cac:Price>
    </cac:InvoiceLine>
    
</Invoice>", "warnings": [ { "category": "KSA", "code": "BR-KSA-80", "message": " The Pre-Paid amount (BT-113) must be equal to the sum total of the Prepayment VAT category Taxable Amount (KSA-31) and the Prepayment VAT Category Tax Amount (KSA-32)." } ], "errors": [] }

mhaggag commented 2 weeks ago

The shared details are a JSON serialization of the parsed response (not the raw response), so unfortunately it doesn't rule out whether it's a parsing bug on our end or not. We're able to reproduce it on our test instances, so we'll look into it and keep you updated.

mhaggag commented 1 week ago

This was merged into master a few minutes ago in 0.30.2. The fix affects new integration logs only, We'll look into writing a patch to update historical records (logs created with blank status) in a future update if possible.

We've also fixed the integration log to store the raw response returned from ZATCA as is without any parsing to make it easier to troubleshoot any future problems.

saud-2 commented 1 week ago

Thank a lot .