Sample code for 30+ languages & platforms
PowerShell

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 PowerShell Downloads

PowerShell
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"

$success = $false

# 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-----

$pem = New-Object Chilkat.Pem
$success = $pem.LoadPemFile("c:/aaworkarea/zatca/onboarding/taxpayer.csr","")
if ($success -eq $false) {
    $($pem.LastErrorText)
    exit
}

# Get the base64 from the CSR in a single line.
$sbCsrBase64 = New-Object Chilkat.StringBuilder
$sbCsrBase64.Append($pem.GetEncodedItem("csr","","base64",0))
$numReplaced = $sbCsrBase64.Replace("`r","")
$numReplaced = $sbCsrBase64.Replace("`n","")
$csrBase64 = $sbCsrBase64.GetAsString()
$($csrBase64)

$json = New-Object Chilkat.JsonObject
$json.EmitCompact = $false
$json.UpdateSb("csr",$sbCsrBase64)

$http = New-Object Chilkat.Http
$http.Accept = "application/json"
$http.SetRequestHeader("OTP",$otp)
$http.SetRequestHeader("Accept-Version","V2")
$resp = New-Object Chilkat.HttpResponse
$success = $http.HttpJson("POST","https://gw-apic-gov.gazt.gov.sa/e-invoicing/core/compliance",$json,"application/json",$resp)
if ($success -eq $false) {
    $($http.LastErrorText)
    exit
}

if ($resp.StatusCode -ne 200) {
    $($resp.BodyStr)
    $("response status code = " + $resp.StatusCode)
    $("Failed")
    exit
}

$jsonResp = New-Object Chilkat.JsonObject
$resp.GetBodyJson($jsonResp)

$jsonResp.EmitCompact = $false
$("JSON response:")
$($jsonResp.Emit())