Python

A continuación encontrara los ejemplos para consumir los servicios de SmartWeb; cabe resaltar que todos los ejemplos fueron probados exitosamente mediante la librería suds para Python 2 o suds-jurko para Python 3. De igual manera puede descargar los proyectos con los código de ejemplo de la pagina de github para SmarterWeb.

Todas las URLs mostradas en esta documentación apuntan al servicio de pruebas, para obtener las URLs del servicio productivo es necesario contratar un paquete.

Autenticación

Antes de realizar cualquier otra operación es necesario autenticarse, para consumir este servicio se usa la URL: http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL.

El servicio de autenticación básico recibe un usuario y una contraseña, si ambos son correctos devuelve un token de autenticación, en caso contrario se lanza una excepción.

from suds.client import Client

urlAutentica = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL'
autentica = Client(urlAutentica, faults = False)
try:
    token = autentica.service.AutenticarBasico('demo', '123456789')
    print(token[1])
except Exception as e:
    print(e)

Timbrado

Para el servicio de timbrado se usa la URL: http://pruebascfdi.smartweb.com.mx/Timbrado/wsTimbrado.asmx?WSDL

TimbrarXML

TimbrarXML Recive el contenido de una factura en string y el token de autenticación, si la factura y el token son correctos devuelve el complemento timbre en un string, en caso contrario lanza una excepción.

from suds.client import Client

urlAutentica = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL'
urlTimbrado = 'http://pruebascfdi.smartweb.com.mx/Timbrado/wsTimbrado.asmx?WSDL'
autentica = Client(urlAutentica, faults = False)
timbrado = Client(urlTimbrado, faults = False)

try:
    token = autentica.service.AutenticarBasico('demo', '123456789')[1]
    f = open('factura1peso.xml')
    xml = f.read()
    f.close()
    result = timbrado.service.TimbrarXML(xml, token)[1]
    print(result)
except Exception as e:
    print(e)

TimbrarXMLV2

TimbrarXMLV2 es muy similar a TimbrarXML, con la diferencia de que el resultado en lugar de ser solo el complemento timbre, es la factura ya timbrada.

from suds.client import Client

urlAutentica = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL'
urlTimbrado = 'http://pruebascfdi.smartweb.com.mx/Timbrado/wsTimbrado.asmx?WSDL'
autentica = Client(urlAutentica, faults = False)
timbrado = Client(urlTimbrado, faults = False)

try:
    token = autentica.service.AutenticarBasico('demo', '123456789')[1]
    f = open('factura1peso.xml')
    xml = f.read()
    f.close()
    result = timbrado.service.TimbrarXMLV2(xml, token)[1]
    print(result)
except Exception as e:
    print(e)

Cancelación

Para el servicio de cancelación se usa el servicio con la URL: http://pruebascfdi.smartweb.com.mx/Cancelacion/wsCancelacion.asmx?WSDL.

CancelarCSD

Este servicio recibe los archivos *.cer y *.key en base 64, la contraseña del archivo *.key, el RFC del emisor que desea cancelar la facturas, los UUIDs de las facturas a cancelar (estos se encuentran dentro del complemento timbre) y el token de autentificación.

from suds.client import Client
import base64

urlAutentica = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL'
urlCancelacion = 'http://pruebascfdi.smartweb.com.mx/Cancelacion/wsCancelacion.asmx?WSDL'
autentica = Client(urlAutentica, faults = False)
cancelacion = Client(urlCancelacion, faults = False)

try:
    token = autentica.service.AutenticarBasico('demo', '123456789')[1]
    cerFile = open('aad990814bp7_1210261233s.cer', 'rb')
    keyFile = open('aad990814bp7_1210261233s.key', 'rb')
    cer = cerFile.read()
    key = keyFile.read()
    cerB64 = base64.b64encode(cer).decode()
    keyB64 = base64.b64encode(key).decode()
    cerFile.close()
    keyFile.close()
    # Los UUIDs para este ejemplo fueron generados de manera aleatoria
    uuids = ['17aeeccc-6ec0-49af-b786-0878d34e0b27', 'a3216283-078c-418e-bf2c-2fb62e418d45']
    uuidsSuds = cancelacion.factory.create('ArrayOfString')
    uuidsSuds.string = uuids
    acuse = cancelacion.service.CancelarCSD(cerB64, keyB64, "12345678a", "AAD990814BP7", uuidsSuds, token)[1]
    print(acuse)
except Exception as e:
    print(e)

CancelarPEM

Este servicio es muy similar a “CancelarCSD”, con la diferencia de que deben de mandarse el certificado y el key en formato *.pem, ademas de que no se envia la contraseña del key, ya que no es requerida.

from suds.client import Client
import base64

urlAutentica = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL'
urlCancelacion = 'http://pruebascfdi.smartweb.com.mx/Cancelacion/wsCancelacion.asmx?WSDL'
autentica = Client(urlAutentica, faults = False)
cancelacion = Client(urlCancelacion, faults = False)

try:
    token = autentica.service.AutenticarBasico('demo', '123456789')[1]
    cerFile = open('aad990814bp7_1210261233s.cer.pem', 'rb')
    keyFile = open('aad990814bp7_1210261233s.key.pem', 'rb')
    cer = cerFile.read()
    key = keyFile.read()
    cerB64 = base64.b64encode(cer).decode()
    keyB64 = base64.b64encode(key).decode()
    cerFile.close()
    keyFile.close()
    # Los UUIDs para este ejemplo fueron generados de manera aleatoria
    uuids = ['17aeeccc-6ec0-49af-b786-0878d34e0b27', 'a3216283-078c-418e-bf2c-2fb62e418d45']
    uuidsSuds = cancelacion.factory.create('ArrayOfString')
    uuidsSuds.string = uuids
    acuse = cancelacion.service.CancelarPEM(cerB64, keyB64, "AAD990814BP7", uuidsSuds, token)[1]
    print(acuse)
except Exception as e:
    print(e)

Timbres disponibles

Para obtener los timbres disponibles es necesario agregar el servicio que corresponde a la siguiente URL: https://pruebascfdi.smartweb.com.mx/Account/wsAccount.svc?wsdl. Notese que esta URL trabaja con HTTP seguro.

from suds.client import Client
import base64

urlAccount = 'https://pruebascfdi.smartweb.com.mx/Account/wsAccount.svc?wsdl'
urlAutentica = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL'
autentica = Client(urlAutentica, faults = False)

try:
    token = autentica.service.AutenticarBasico('demo', '123456789')[1]
    account = Client(urlAccount, faults = False, headers = {'token' : token})
    cliente = account.service.GetClientById()[1]
    saldoCliente = account.service.GetSaldoClientById(cliente.IdCliente)[1]
    print(saldoCliente.SaldoTimbres)
    print(saldoCliente.TimbresUtilizados)
except Exception as e:
    print(e)

lenguajes/python.txt · Última modificación: 2016/08/10 09:34 (editor externo)
Volver arriba
CC Attribution-Share Alike 3.0 Unported
Driven by DokuWiki Recent changes RSS feed Valid CSS Valid XHTML 1.0