JavaScript con node.js

A continuación encontrara los ejemplos para consumir los servicios de SmartWeb; cabe resaltar que todos los ejemplos fueron probados exitosamente con la versión 0.12.0 de node.js usando la libreria node-soap. 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.

var soap = require('soap')

function printResult(value) {
    console.log(value);
}

function Autentica(args, extractToken) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractToken(result.AutenticarBasicoResult);
    }
    
    var request = function(err, client) {
        client.AutenticarBasico(args, response);
    }
    
    soap.createClient(url, request);
}

var credentials = { usuario: 'demo', password: '123456789' };
try {
    var autentica = new Autentica(credentials, printResult);
} catch(err) {
    console.log(err);
}

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.

var fs = require('fs');
var soap = require('soap');

function printResult(value) {
    console.log(value);
}

function Autentica(args, extractToken) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractToken(result.AutenticarBasicoResult);
    }
    
    var request = function(err, client) {
        client.AutenticarBasico(args, response);
    }
    
    soap.createClient(url, request);
}

function Timbrado(args, extractResult) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Timbrado/wsTimbrado.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractResult(result.TimbrarXMLResult);
    }
    
    var request = function(err, client) {
        client.TimbrarXML(args, response);
    }
    
    this.init = function(token) {
        args['tokenAutenticacion'] = token;
        soap.createClient(url, request);
    }
}

var credentials = { usuario: 'demo', password: '123456789' };
var args = { xmlComprobante: fs.readFileSync('factura1peso.xml').toString() };
try {
    var timbrado = new Timbrado(args, printResult);
    var autentica = new Autentica(credentials, timbrado.init);
} catch(err) {
    console.log(err);
}

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.

var fs = require('fs');
var soap = require('soap');

function printResult(value) {
    console.log(value);
}

function Autentica(args, extractToken) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractToken(result.AutenticarBasicoResult);
    }
    
    var request = function(err, client) {
        client.AutenticarBasico(args, response);
    }
    
    soap.createClient(url, request);
}

function Timbrado(args, extractResult) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Timbrado/wsTimbrado.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractResult(result.TimbrarXMLV2Result);
    }
    
    var request = function(err, client) {
        client.TimbrarXMLV2(args, response);
    }
    
    this.init = function(token) {
        args['tokenAutenticacion'] = token;
        soap.createClient(url, request);
    }
}

var credentials = { usuario: 'demo', password: '123456789' };
var args = { xmlComprobante: fs.readFileSync('factura1peso.xml').toString() };
try {
    var timbrado = new Timbrado(args, printResult);
    var autentica = new Autentica(credentials, timbrado.init);
} catch(err) {
    console.log(err);
}

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.

var fs = require('fs');
var soap = require('soap');

function printResult(value) {
    console.log(value);
}

function Autentica(args, extractToken) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractToken(result.AutenticarBasicoResult);
    }
    
    var request = function(err, client) {
        client.AutenticarBasico(args, response);
    }
    
    soap.createClient(url, request);
}

function Cancelacion(args, extractResult) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Cancelacion/wsCancelacion.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractResult(result.CancelarCSDResult);
    }
    
    var request = function(err, client) {
        client.CancelarCSD(args, response);
    }
    
    this.init = function(token) {
        args['tokenAutenticacion'] = token;
        soap.createClient(url, request);
    }
}

var credentials = { usuario: 'demo', password: '123456789' };
var cerB64 = fs.readFileSync('aad990814bp7_1210261233s.cer').toString('base64');
var keyB64 = fs.readFileSync('aad990814bp7_1210261233s.key').toString('base64');
var uuids = ['17aeeccc-6ec0-49af-b786-0878d34e0b27', 'a3216283-078c-418e-bf2c-2fb62e418d45'];
var args = {
    CSDCer: cerB64,
    CSDKey: keyB64,
    password: '12345678a',
    RFCEmisor: 'AAD990814BP7',
    UUIDs: { string: uuids }
};
try {
    var cancelacion = new Cancelacion(args, printResult);
    var autentica = new Autentica(credentials, cancelacion.init);
} catch(err) {
    console.log(err);
}

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.

var fs = require('fs');
var soap = require('soap');

function printResult(value) {
    console.log(value);
}

function Autentica(args, extractToken) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractToken(result.AutenticarBasicoResult);
    }
    
    var request = function(err, client) {
        client.AutenticarBasico(args, response);
    }
    
    soap.createClient(url, request);
}

function Cancelacion(args, extractResult) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Cancelacion/wsCancelacion.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractResult(result.CancelarPEMResult);
    }
    
    var request = function(err, client) {
        client.CancelarPEM(args, response);
    }
    
    this.init = function(token) {
        args['tokenAutenticacion'] = token;
        soap.createClient(url, request);
    }
}

var credentials = { usuario: 'demo', password: '123456789' };
var cerB64 = fs.readFileSync('aad990814bp7_1210261233s.cer.pem').toString('base64');
var keyB64 = fs.readFileSync('aad990814bp7_1210261233s.key.pem').toString('base64');
var uuids = ['17aeeccc-6ec0-49af-b786-0878d34e0b27', 'a3216283-078c-418e-bf2c-2fb62e418d45'];
var args = {
    CSDCer: cerB64,
    CSDKey: keyB64,
    RFCEmisor: 'AAD990814BP7',
    UUIDs: { string: uuids }
};
try {
    var cancelacion = new Cancelacion(args, printResult);
    var autentica = new Autentica(credentials, cancelacion.init);
} catch(err) {
    console.log(err);
}

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.

var soap = require('soap');

process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0";

function printResult(value) {
    console.log(value);
}

function Autentica(args, extractToken) {
    var url = 'http://pruebascfdi.smartweb.com.mx/Autenticacion/wsAutenticacion.asmx?WSDL';
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractToken(result.AutenticarBasicoResult);
    }
    
    var request = function(err, client) {
        client.AutenticarBasico(args, response);
    }
    
    soap.createClient(url, request);
}

function Account(extractResult) {
    var url = 'https://pruebascfdi.smartweb.com.mx/Account/wsAccount.svc?WSDL';
    var header = null;
    var _client = null
    
    var response = function(err, result) {
        if (err != null)
            throw err.body;
        extractResult(result.GetSaldoClientByIdResult.SaldoTimbres);
        extractResult(result.GetSaldoClientByIdResult.TimbresUtilizados);
    }
    
    var request = function(err, client) {
        _client = client;
        client.addSoapHeader(header, 'token', null, 'http://soapinterop.org/echoheader/');
        client.GetSaldoClientById({}, response);
    }
    
    this.init = function(token) {
        header = { token: token };
        soap.createClient(url, request);
    }
}

var credentials = { usuario: 'demo', password: '123456789' };
try {
    var account = new Account(printResult);
    var autentica = new Autentica(credentials, account.init);
} catch(err) {
    console.log(err);
}

lenguajes/node.js.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