Para mas automatizaciones [email protected]
Automatizaciones
Habilitar Administración de Certificados Digitales

Habilitar Administración de Certificados Digitales

Esta automatización sirve para habilitar el servicio de Administración de Certificados Digitales.


Requisitos previos

Para poder usar esta automatización, primero necesitarás:


Nombre

add-relation

Parametros

cuitstring
CUIT a usar en la página de ARCA.
usernamestring
CUIT para loguearse en la página de ARCA. Normalmente es el mismo CUIT que el parámetro 'cuit', pero si administrás una sociedad, el CUIT que usás para loguearte es tu propio CUIT.
passwordstring
Contraseña para loguearse en la página de ARCA.
servicestring
ID del servicio a habilitar. En este caso, usar web://arfe_certificado
delegate_tostring
CUIT al cual habilitar el servicio. En este caso, debe ser el mismo que el username.
Solicitud
LOCAL loHttp, loUrl, loData, loResponse
DECLARE Sleep IN kernel32 INTEGER

* Aqui deben cambiar los datos de params por los que correspondan. 
* Esta request de ejemplo incluye todos posibles 
* valores para ejecutar la automatizacion add-relation, 
* puede que algun valor sea opcional.
LOCAL loDataObject
loDataObject = CREATEOBJECT("JSONObject")
    loDataObject.set("automation", "add-relation")
    LOCAL params
    params = CREATEOBJECT("JSONObject")
    loDataObject.set("params", params)
        params.set("cuit", "20111111112")
        params.set("username", "20111111112")
        params.set("password", "contraseña#segura?")
        params.set("service", "web://arfe_certificado")
        params.set("delegate_to", "20111111112")

* 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/automations"

* 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
    ? loHttp.responseText
    RETURN
ENDIF

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

* Mostramos la respuesta por pantalla
? loHttp.responseText

* Expera maxima de 120 segundos (5 segundos * 24)
lnRetries = 24

DO WHILE lnRetries >= 0
    lnRetries = lnRetries - 1

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

    * Realizamos la llamada a la API
    loHttp.Open("GET", loUrl, .F.)
    loHttp.setRequestHeader("Content-Type", "application/json")
    loHttp.setRequestHeader("Authorization", "Bearer " + accessToken)
    loHttp.Send()

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

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

    * Checkeamos si se ya finalizo
    IF loResponse.get("status") == "complete"
        * Mostramos la respuesta por pantalla
        ? loHttp.responseText

        EXIT
    ENDIF

    * Esperamos 5 segundos antes de volver a pedir los detalles
    Sleep(5000)
ENDDO
Respuesta
{
    "id": "0c31d74f-d672-4677-a00b-7dc865396c69",
    "status": "complete",
    "data": {
        "status": "created"
    }
}