Sample code for 30+ languages & platforms
Classic ASP

ZATCA Onboarding Get Compliance CSID

See more ZATCA Examples

Demonstrates sending a POST to get a compliance CSID, which is two parts: A binary security token, and a secret.

Chilkat Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

' It is assumed you've already generated a CSR.
' Also, you'll need an OTP code, valid for 1 hour, which is generated online in the Fatoora portal.  See 
' https://zatca.gov.sa/ar/E-Invoicing/Introduction/Guidelines/Documents/E-invoicing%20Detailed%20Technical%20Guidelines.pdf

' Manually replace this with the OTP code you interactively obtained in a browser session from the Fatoora portal.
' The OTP code is valid for 1 hour.
otp = "123434"

' You should already have a CSR in a file containing something that looks like this:

' -----BEGIN CERTIFICATE REQUEST-----
' MIIB5DCCAYsCAQAwTDELMAkGA1UEBhMCU0ExFTATBgNVBAsMDFJpeWFkIEJyYW5j
' aDEQMA4GA1UECgwHQ29udG9zbzEUMBIGA1UEAwwLRUExMjM0NTY3ODkwVjAQBgcq
' hkjOPQIBBgUrgQQACgNCAAQI6op+6GQ4Gmn9oy0DpGxX0lFtUIvj+4Jtnp0VyEsH
' +ZO7lpgksbRC484R3fAsO0v+Ly24ZIUIOYEIAeJ1f6AooIHfMIHcBgkqhkiG9w0B
' CQ4xgc4wgcswIQYJKwYBBAGCNxQCBBQTElpBVENBLUNvZGUtU2lnbmluZzCBpQYD
' VR0RBIGdMIGapIGXMIGUMTswOQYDVQQEDDIxLVRTVHwyLVRTVHwzLWVkMjJmMWQ4
' LWU2YTItMTExOC05YjU4LWQ5YThmMTFlNDQ1ZjEfMB0GCgmSJomT8ixkAQEMDzMx
' MDEyMjM5MzUwMDAwMzENMAsGA1UEDAwEMTEwMDESMBAGA1UEGgwJTXlBZGRyZXNz
' MREwDwYDVQQPDAhJbmR1c3RyeTAKBggqhkjOPQQDAgNHADBEAiBurm6KdAeHfXzt
' h/jk8xSMBP4TAkkFrg+hWDhfI0/SuAIgJi8ectM7YwBIBCmf0tdFcVTU7GBbvjnK
' xValZCAO39M=
' -----END CERTIFICATE REQUEST-----

set pem = Server.CreateObject("Chilkat.Pem")
success = pem.LoadPemFile("c:/aaworkarea/zatca/onboarding/taxpayer.csr","")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( pem.LastErrorText) & "</pre>"
    Response.End
End If

' Get the base64 from the CSR in a single line.
set sbCsrBase64 = Server.CreateObject("Chilkat.StringBuilder")
success = sbCsrBase64.Append(pem.GetEncodedItem("csr","","base64",0))
numReplaced = sbCsrBase64.Replace(vbCr,"")
numReplaced = sbCsrBase64.Replace(vbLf,"")
csrBase64 = sbCsrBase64.GetAsString()
Response.Write "<pre>" & Server.HTMLEncode( csrBase64) & "</pre>"

set json = Server.CreateObject("Chilkat.JsonObject")
json.EmitCompact = 0
success = json.UpdateSb("csr",sbCsrBase64)

set http = Server.CreateObject("Chilkat.Http")
http.Accept = "application/json"
http.SetRequestHeader "OTP",otp
http.SetRequestHeader "Accept-Version","V2"
set resp = Server.CreateObject("Chilkat.HttpResponse")
success = http.HttpJson("POST","https://gw-apic-gov.gazt.gov.sa/e-invoicing/core/compliance",json,"application/json",resp)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
    Response.End
End If

If (resp.StatusCode <> 200) Then
    Response.Write "<pre>" & Server.HTMLEncode( resp.BodyStr) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( "response status code = " & resp.StatusCode) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( "Failed") & "</pre>"
    Response.End
End If

set jsonResp = Server.CreateObject("Chilkat.JsonObject")
success = resp.GetBodyJson(jsonResp)

jsonResp.EmitCompact = 0
Response.Write "<pre>" & Server.HTMLEncode( "JSON response:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( jsonResp.Emit()) & "</pre>"

%>
</body>
</html>