Sistema Integral de Retenciones Electrónicas


Solicitud
LOCAL loHttp, loUrl, loData, loResponse

* Deben cambiar los datos de "params" por los que correspondan. 
* Esta request de ejemplo incluye todos posibles valores para 
* llamar al metodo anular, puede que algun valor sea opcional.
LOCAL loDataObject
loDataObject = CREATEOBJECT("JSONObject")
    loDataObject.set("environment", "prod")
    loDataObject.set("method", "anular")
    loDataObject.set("wsid", "sire-ws")
    LOCAL params
    params = CREATEOBJECT("JSONObject")
    loDataObject.set("params", params)
        params.set("token", "string")
        params.set("sign", "string")
        params.set("cuitAgente", 1)
        LOCAL certificadoAnulacion
        certificadoAnulacion = CREATEOBJECT("JSONObject")
        params.set("certificadoAnulacion", certificadoAnulacion)
            certificadoAnulacion.set("version", 1)
            certificadoAnulacion.set("codigoTrazabilidad", "string")
            certificadoAnulacion.set("impuesto", 1)
            certificadoAnulacion.set("numeroCertificado", "string")
            certificadoAnulacion.set("motivoAnulacion", 1)

* Convertimos el objeto en JSON
loData = json_encode(loDataObject)

* Creamos un cliente HTTP para llamar a la API
loHttp = CREATEOBJECT("Msxml2.XMLHTTP")
loUrl = "https://app.afipsdk.com/api/v1/afip/requests"

* Realizamos la llamada a la API
loHttp.Open("POST", loUrl, .F.)
loHttp.setRequestHeader("Content-Type", "application/json")

* Reemplazar con tu access_token obtenido de https://app.afipsdk.com
LOCAL accessToken
accessToken = "TU_TOKEN_AQUI"
loHttp.setRequestHeader("Authorization", "Bearer " + accessToken)

loHttp.Send(loData)

* En caso de error lo mostramos por pantalla
IF loHttp.Status <> 200
    ? STR(loHttp.responseText)
    RETURN
ENDIF

* Convertimos la respuesta en un objeto
loResponse = json_decode(loHttp.responseText)

* Mostramos la respuesta por pantalla
? loHttp.responseText
Respuesta
{
    "certificadoNro": "string",
    "codigoSeguridad": "string"
}