Sample code for 30+ languages & platforms
VBScript

hacienda.go.cr Recepción de comprobantes electrónicos y respuestas del receptor.

See more hacienda.go.cr Examples

Comprobantes Electrónicos API version v1 -- Recepción de comprobantes electrónicos y respuestas del receptor.

Chilkat VBScript Downloads

VBScript
Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)

success = 0

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

set http = CreateObject("Chilkat.Http")

' Implements the following CURL command:

' curl -X POST -H "Content-Type: application / json" \
'   -H 'authorization: Bearer {access_token}' \
'   -d '{
'   "clave": "50601011600310112345600100010100000000011999999999",
'   "fecha": "2016-01-01T00:00:00-0600",
'   "emisor": {
'     "tipoIdentificacion": "02",
'     "numeroIdentificacion": "003101123456"
'   },
'   "receptor": {
'     "tipoIdentificacion": "02",
'     "numeroIdentificacion": "003101123456"
'   },
'   "comprobanteXml": "PD94..."
' }' https://api.comprobanteselectronicos.go.cr/recepcion/v1/recepcion

' Use the following online tool to generate HTTP code from a CURL command
' Convert a cURL Command to HTTP Source Code

' Use this online tool to generate code from sample JSON:
' Generate Code to Create JSON

' The following JSON is sent in the request body.

' {
'   "clave": "50601011600310112345600100010100000000011999999999",
'   "fecha": "2016-01-01T00:00:00-0600",
'   "emisor": {
'     "tipoIdentificacion": "02",
'     "numeroIdentificacion": "003101123456"
'   },
'   "receptor": {
'     "tipoIdentificacion": "02",
'     "numeroIdentificacion": "003101123456"
'   },
'   "comprobanteXml": "PD94b..."
' }

' Load the previously signed XML.
set bdSignedXml = CreateObject("Chilkat.BinData")
success = bdSignedXml.LoadFile("someDir/signed.xml")
If (success = 0) Then
    outFile.WriteLine("Failed to load the XAdES signed XML.")
    WScript.Quit
End If

set json = CreateObject("Chilkat.JsonObject")
success = json.UpdateString("clave","50601011600310112345600100010100000000011999999999")
success = json.UpdateString("fecha","2016-01-01T00:00:00-0600")
success = json.UpdateString("emisor.tipoIdentificacion","02")
success = json.UpdateString("emisor.numeroIdentificacion","003101123456")
success = json.UpdateString("receptor.tipoIdentificacion","02")
success = json.UpdateString("receptor.numeroIdentificacion","003101123456")
' Add the base64 encoded representation of the signed XML.
success = json.UpdateString("comprobanteXml",bdSignedXml.GetEncoded("base64"))

' Load our previously obtained OAuth2 access token.
set jsonToken = CreateObject("Chilkat.JsonObject")
success = jsonToken.LoadFile("qa_data/tokens/hacienda_cr.json")
If (success <> 1) Then
    outFile.WriteLine("Failed to load constantContact.json")
    WScript.Quit
End If

' Adds the "Authorization: Bearer {access_token}" header.
http.AuthToken = jsonToken.StringOf("access_token")

http.SetRequestHeader "Content-Type","application / json"

set resp = CreateObject("Chilkat.HttpResponse")
success = http.HttpJson("POST","https://api.comprobanteselectronicos.go.cr/recepcion/v1/recepcion",json,"application/json",resp)
If (success = 0) Then
    outFile.WriteLine(http.LastErrorText)
    WScript.Quit
End If

' A 201 status code indicates success.
outFile.WriteLine("Response status code: " & resp.StatusCode)

outFile.WriteLine("Response body:")
outFile.WriteLine(resp.BodyStr)

outFile.Close