Visual FoxPro
Visual FoxPro
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 Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loHttp
LOCAL loBdSignedXml
LOCAL loJson
LOCAL loJsonToken
LOCAL loResp
lnSuccess = 0
* This example assumes the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
loHttp = 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.
loBdSignedXml = CreateObject('Chilkat.BinData')
lnSuccess = loBdSignedXml.LoadFile("someDir/signed.xml")
IF (lnSuccess = 0) THEN
? "Failed to load the XAdES signed XML."
RELEASE loHttp
RELEASE loBdSignedXml
CANCEL
ENDIF
loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("clave","50601011600310112345600100010100000000011999999999")
loJson.UpdateString("fecha","2016-01-01T00:00:00-0600")
loJson.UpdateString("emisor.tipoIdentificacion","02")
loJson.UpdateString("emisor.numeroIdentificacion","003101123456")
loJson.UpdateString("receptor.tipoIdentificacion","02")
loJson.UpdateString("receptor.numeroIdentificacion","003101123456")
* Add the base64 encoded representation of the signed XML.
loJson.UpdateString("comprobanteXml",loBdSignedXml.GetEncoded("base64"))
* Load our previously obtained OAuth2 access token.
loJsonToken = CreateObject('Chilkat.JsonObject')
lnSuccess = loJsonToken.LoadFile("qa_data/tokens/hacienda_cr.json")
IF (lnSuccess <> 1) THEN
? "Failed to load constantContact.json"
RELEASE loHttp
RELEASE loBdSignedXml
RELEASE loJson
RELEASE loJsonToken
CANCEL
ENDIF
* Adds the "Authorization: Bearer {access_token}" header.
loHttp.AuthToken = loJsonToken.StringOf("access_token")
loHttp.SetRequestHeader("Content-Type","application / json")
loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpJson("POST","https://api.comprobanteselectronicos.go.cr/recepcion/v1/recepcion",loJson,"application/json",loResp)
IF (lnSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
RELEASE loBdSignedXml
RELEASE loJson
RELEASE loJsonToken
RELEASE loResp
CANCEL
ENDIF
* A 201 status code indicates success.
? "Response status code: " + STR(loResp.StatusCode)
? "Response body:"
? loResp.BodyStr
RELEASE loHttp
RELEASE loBdSignedXml
RELEASE loJson
RELEASE loJsonToken
RELEASE loResp