Automatizaciones
Crear punto de venta
Crear punto de venta
Esta automatización crea un nuevo punto de venta en ARCA (Puntos de Venta y Domicilios).
Requisitos previos
Para poder usar esta automatización, primero necesitarás:
Nombre
create-sales-point
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.numerointeger
Número de punto de venta a crear.sistemastring
Sistema asociado al punto de venta. Valores permitidos (valor=nombre): BFERCEL=Bonos Fiscales Electrónicos - Factura en Línea, BFEWS=Bonos Fiscales Electrónicos - Web Services, CF=Controlador Fiscal, FEERCEL=Comprobantes de Exportación - Factura en Línea, FEERCELP=Comprobantes de Exportación - Facturador Plus, FEEWS=Comprobantes de Exportación - Web Services, II=Factuweb (Imprenta) - Responsable Inscripto, IM=Factuweb (Imprenta) - Monotributo, MAW=Factura Electrónica - Monotributo - Web Services, RAW=RECE para aplicativo y web services, REL=Remito Electrónico en Línea, REW=Remito Electrónico Web Services, RLI=Factura en Línea - Responsable Inscripto, RLM=Factura en Línea - Monotributo.nombreFantasiastring
Nombre de fantasía del punto de venta (obligatorio).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 create-sales-point,
* puede que algun valor sea opcional.
LOCAL loDataObject
loDataObject = CREATEOBJECT("JSONObject")
loDataObject.set("automation", "create-sales-point")
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("numero", 9)
params.set("sistema", "FEEWS")
params.set("nombreFantasia", "Mi Sucursal Centro")
* 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)
ENDDORespuesta
{
"id": "0c31d74f-d672-4677-a00b-7dc865396c69",
"status": "complete",
"data": {
"status": "created"
}
}