Usar web services de ARCA en Ruby
Con pocas líneas de código

Instalación
Lo primero es instalar la librería Afip.rb
Gemfile
gem 'afip.rb', '~> 1.0', '>= 1.0.1'
Gem
gem install afip.rb
Creamos una instancia de la clase Afip
Para usar los web services de ARCA, se requiere un certificado digital, con Afip SDK puedes integrarte en modo desarrollo usando el CUIT 20409378472
sin necesidad de obtener un certificado, para poder integrarte lo más rápido posible.
Te dejo este enlace por si luego quieres usar tu propio certificado para desarrollo.
require "afip"
# CUIT vinculado al certificado
CUIT = 20409378472
afip = Afip.new({ "CUIT": CUIT })
Creamos una instancia del web service
# URL al archivo WSDL de test
#
# Esta URL la podes encontrar en el manual del web service
WSDL_TEST = "https://fwshomo.afip.gov.ar/wsct/CTService?wsdl"
# URL al archivo WSDL de produccion
#
# Esta URL la podes encontrar en el manual del web service
WSDL = "https://serviciosjava.afip.gob.ar/wsct/CTService?wsdl"
# URL del Web service de produccion
#
# Esta URL la podes encontrar en el manual del web service
URL = "https://serviciosjava.afip.gob.ar/wsct/CTService"
# URL del Web service de test
#
# Esta URL la podes encontrar en el manual del web service
URL_TEST = "https://fwshomo.afip.gov.ar/wsct/CTService"
# Seterar en true si el web service requiere usar soap v1.2
#
# Si no estas seguro de que necesita v1.2 proba con ambas opciones
soapV1_2 = false
# Nombre del web service.
#
# El nombre por el cual se llama al web service en ARCA.
# Esto lo podes encontrar en el manual correspondiente.
# Por ej. el de factura electronica se llama "wsfe", el de
# comprobantes T se llama "wsct"
servicio = "wsct"
# A partir de aca ya no debes cambiar ninguna variable
# Preparamos las opciones para el web service
options = {
"WSDL": WSDL,
"WSDL_TEST": WSDL_TEST,
"URL": URL,
"URL_TEST": URL_TEST,
"soapV1_2": soapV1_2
}
# Creamos el web service
genericWebService = afip.webService(servicio, options)
Llamamos al web service
Este es un ejemplo de como utilizar el wsct para obtener el ultimo comprobante autorizado.
Aquí veras como obtener un Token Authorization para el web service que acabamos de crear y como ejecutar un request básico
# Obtenemos el Token Authorizataion
ta = genericWebService.getTokenAuthorization
# Preparamos los datos que nos pide el web service
#
# Este ejemplo es especifico para el wsct. En el manual
# del web service que quieras utilizar encontraras que
# datos requiere cada metodo
data = {
"authRequest": {
"token": ta["token"],
"sign": ta["sign"],
"cuitRepresentada": afip.CUIT
},
"codigoTipoComprobante": 195,
"numeroPuntoVenta": 1
}
begin
# Ejecutamos la request al web service
#
# consultarUltimoComprobanteAutorizado es un metodo
# de wsct, esto debes cambiarlo por el metodo que
# quieras utilizar
result = genericWebService.executeRequest("consultarUltimoComprobanteAutorizado", data)
# Mostramos el resultado
puts result unless result["arrayErrores"]
# Checkeamos si devolvio error en el resultado.
#
# arrayErrores es especifico de este web service.
# Esto deberas adaptarlo al web service que estes integrando
err = result["arrayErrores"]["codigoDescripcion"].is_a?(Array) ? result["arrayErrores"]["codigoDescripcion"][0] : result["arrayErrores"]["codigoDescripcion"]
raise "(#{err["codigo"]}) #{err["descripcion"]}"
rescue => e
# Mostramos el error
puts e
end
Con esto ya podemos acceder a todos los web servicies de ARCA en Ruby.
Lo único que nos queda es pasar a modo producción.
Ante cualquier duda o pregunta al respecto, pueden resolverla rápidamente dentro de la Comunidad Afip SDK. Además, puedes unirte para estar al tanto de las novedades y problemas técnicos al usar los servicios de ARCA.