//Terminar
        public FECAEResponse AutorizarFactura(Venta ventaFactura)
        {
            var FECabeceraReq = new FECAECabRequest();

            FECabeceraReq.CantReg  = 1;                                             // Cantidad de Registros.
            FECabeceraReq.CbteTipo = (int)ventaFactura.Comprobante.TipoComprobante; //tipo de factura
            FECabeceraReq.PtoVta   = ventaFactura.PtoDeVenta.NroPuntoDeVenta;       // Numero del Punto de venta.

            var FEDetalleReq = new FECAEDetRequest();

            FEDetalleReq.DocTipo    = (int)ventaFactura.Cliente.DocTipo;                                   //Tipo de Identificación del comprado.
            FEDetalleReq.DocNro     = ventaFactura.Cliente.Cuil;                                           //Nro. De identificación del comprador
            FEDetalleReq.MonId      = ServiceConect.FEParamGetTiposMonedas(AuthAutorizar).ResultGet[0].Id; //Codigo Moneda (PES)
            FEDetalleReq.MonCotiz   = 1;                                                                   //Cotización de la moneda informada. Para PES, pesos argentinos la misma debe ser 1
            FEDetalleReq.CbteDesde  = ventaFactura.Comprobante.NroComprobante + 1;                         //Nro. De comprobante desde
            FEDetalleReq.CbteHasta  = ventaFactura.Comprobante.NroComprobante + 1;                         //Nro. De comprobante registrado hasta
            FEDetalleReq.Concepto   = (int)ventaFactura.TipoConcepto;                                      //Concepto (De producto)
            FEDetalleReq.ImpTotal   = ventaFactura.Total;                                                  // Importe total del comprobante
            FEDetalleReq.ImpNeto    = ventaFactura.Total;                                                  //Para comprobantes tipo C este campo corresponde al Importe del Sub Total (SIN IMPUESTO)
            FEDetalleReq.ImpTotConc = 0;                                                                   //Para comprobantes tipo C debe ser igual a cero(0).
            FEDetalleReq.ImpOpEx    = 0;                                                                   //Importe Externo. Para comprobantes tipo C debe ser igual a cero (0).
            FEDetalleReq.ImpIVA     = 0;                                                                   //Importes Array IVa. Para comprobantes tipo C debe ser igual a cero (0).
            FEDetalleReq.ImpTrib    = 0;                                                                   //Suma importes Array tributo.

            var FECAEreq = new FECAERequest();

            FECAEreq.FeCabReq = FECabeceraReq;
            FECAEreq.FeDetReq = new FECAEDetRequest[] { FEDetalleReq };

            return(ServiceConect.FECAESolicitar(AuthAutorizar, FECAEreq));
        }
        private FECAECabRequest ConvertirCabecera( FeCabecera cabFe )
        {
            FECAECabRequest cab = new FECAECabRequest();
            cab.CantReg = cabFe.CantidadDeRegistros;
            cab.CbteTipo = (int)cabFe.TipoComprobante;
            cab.PtoVta = cabFe.PuntoDeVenta;

            return cab;
        }
        private FECAECabRequest GetCabecera(FacturaTemplate factura, WSFE.Service servicio, WSFE.FEAuthRequest authRequest)
        {
            WSFE.FECAECabRequest cabecera = new FECAECabRequest();
            try
            {

                Commons commonUtilities = new Commons(servicio, authRequest);
                int? id = commonUtilities.GetTipoComprobanteId(factura.Comprobante, factura.TipoComprobante);
                cabecera.CbteTipo = id.Value;
                cabecera.CantReg = 1; //factura.Items.Count(); //Siempre enviamos uno solo. Como mejora a futuro se habla para procesamiento por lotes
                cabecera.PtoVta = commonUtilities.GetPuntoDeVentaId(factura.ComprobanteRelacionado).Value;
            }
            catch (Exception ex)
            {
                LoggerManager.Error("Ha ocurrido un error al generar la cabecera", ex);
            }
            return cabecera;
        }
示例#4
0
        private static string consultarAfip(int p_pv, int p_codigo, double p_importe, double p_iva, double p_total, DateTime p_fecha, long doc, int concepto, int tipo_doc, int tipo_iva, string moneda)
        {
            numero_comprobante = 0;
            cae_comprobante    = "";
            cae_vencimiento    = "";
            mensaje_afip       = "";
            mensaje_obs        = "";
            mensaje_error      = "";
            string m = "";

            resultado = "R";

            try
            {
                if (Main.authRequest == null)
                {
                    Main.authRequest       = new FEAuthRequest();
                    Main.authRequest.Cuit  = Main.CUIT;
                    Main.authRequest.Sign  = Main.SING;
                    Main.authRequest.Token = Main.TOKEN;
                }

                AFIP.TEST.WSFE.Service service = getServicio();
                service.ClientCertificates.Add(Main.certificado);

                /*
                 * if (Main.Testing == 1)
                 * {
                 *  AFIP.TEST.WSFE.Service service = getServicioTest();
                 *  service.ClientCertificates.Add(Main.certificado);
                 * }
                 * else
                 * {
                 *  AFIP.WSFE.Service service = getServicioProducion();
                 *  service.ClientCertificates.Add(Main.certificado);
                 * }*/
                //PtoVenta pvObj = ptos_venta_cm.SelectedItem;
                //int pv = p_pv;//pvObj.Nro;
                //CbteTipo cm = p_codigo;//TiposComprobantesCMB.SelectedItem;

                FECAERequest    req = new FECAERequest();
                FECAECabRequest cab = new FECAECabRequest();
                FECAEDetRequest det = new FECAEDetRequest();

                cab.CantReg  = 1;
                cab.PtoVta   = p_pv;
                cab.CbteTipo = p_codigo;//cm.Id;
                req.FeCabReq = cab;

                FECAEDetRequest bar = det;
                //ConceptoTipo concepto = TipoConcepto.SelectedItem;
                bar.Concepto = concepto; //concepto.ID;
                //DocTipo doctipo = TipoDocCMB.SelectedItem;
                bar.DocTipo = tipo_doc;  //doctipo.Id
                bar.DocNro  = doc;       //long.Parse(DocTX.Text)

                //Buscar el ultimo numero
                try
                {
                    FERecuperaLastCbteResponse lastRes = service.FECompUltimoAutorizado(Main.authRequest, p_pv, p_codigo);
                    int last = lastRes.CbteNro;

                    bar.CbteDesde = last + 1;
                    bar.CbteHasta = last + 1;
                }
                catch
                {
                    bar.CbteDesde = p_codigo;
                    bar.CbteHasta = p_codigo;
                }

                bar.CbteFch = p_fecha.ToString("yyyyMMdd");              //FechaDTP.Value.ToString("yyyyMMdd");

                bar.ImpNeto  = Double.Parse(p_importe.ToString("0.00")); //NetoTX.Text;
                bar.ImpIVA   = Double.Parse(p_iva.ToString("0.00"));     // ImpIvaTx.Text;
                bar.ImpTotal = Double.Parse(p_total.ToString("0.00"));   // TotalTx.Text;

                bar.ImpTotConc = 0;
                bar.ImpOpEx    = 0;
                bar.ImpTrib    = 0;

                //Moneda mon = MonedaCMB.SelectedItem;
                bar.MonId    = moneda;// mon.Id
                bar.MonCotiz = 1;

                AlicIva alicuota = new AlicIva();
                //IvaTipo ivat = TipoIVACmb.SelectedItem;
                alicuota.Id      = tipo_iva;                             // ivat.Id
                alicuota.BaseImp = p_importe;                            // NetoTX.Text
                alicuota.Importe = Double.Parse(p_iva.ToString("0.00")); // ImpIvaTx.Text

                bar.Iva = new AlicIva[] { alicuota };
                //bar.Iva.Append(alicuota);

                req.FeDetReq = new FECAEDetRequest[] { bar };
                //req.FeDetReq.Append(bar);


                try
                {
                    FECAEResponse r      = service.FECAESolicitar(Main.authRequest, req);
                    string        vbCrLf = "\n";

                    resultado = r.FeDetResp[0].Resultado;

                    m  = "Estado Cabecera: " + r.FeCabResp.Resultado + vbCrLf;
                    m += "Estado Detalle: " + r.FeDetResp[0].Resultado;
                    m += vbCrLf;
                    m += "CAE: " + r.FeDetResp[0].CAE;
                    m += vbCrLf;
                    m += "Vto: " + r.FeDetResp[0].CAEFchVto;
                    m += vbCrLf;
                    m += "Numero de comprobante: " + r.FeDetResp[0].CbteDesde;
                    m += vbCrLf;

                    numero_comprobante = r.FeDetResp[0].CbteDesde;
                    cae_comprobante    = r.FeDetResp[0].CAE;
                    cae_vencimiento    = r.FeDetResp[0].CAEFchVto;

                    if (r.FeDetResp[0].Observaciones != null)
                    {
                        foreach (var o in r.FeDetResp[0].Observaciones)
                        {
                            mensaje_obs += string.Format("Obs: {0} ({1})", o.Msg, o.Code) + vbCrLf;
                            m           += mensaje_obs;
                        }
                    }
                    if (r.Errors != null)
                    {
                        foreach (var er in r.Errors)
                        {
                            mensaje_error += string.Format("Er: {0}: {1}", er.Code, er.Msg) + vbCrLf;
                            m             += mensaje_error;
                        }
                    }
                    if (r.Events != null)
                    {
                        foreach (var ev in r.Events)
                        {
                            mensaje_afip += string.Format("Ev: {0}: {1}", ev.Code, ev.Msg) + vbCrLf;
                            m            += mensaje_afip;
                        }
                    }
                }
                catch (Exception e)
                {
                    LogHelper.Log(LogTarget.File, DateTime.Now.ToString() + " - ERROR COMPROBANTE AFIP: " + e.Message + " - " + e.StackTrace);
                    m = "ERROR";
                    return(m);
                }



                //Resultado.Text = m
                LogHelper.Log(LogTarget.File, DateTime.Now.ToString() + " - Consultando en AFIP: " + resultado);
            }
            catch (Exception e)
            {
                LogHelper.Log(LogTarget.File, DateTime.Now.ToString() + " - ERROR COMPROBANTE AFIP: " + e.Message + " - " + e.StackTrace);
                //MessageBox.Show("ERROR: "+e.Message+"\n"+e.StackTrace);
            }

            return(m);
        }
示例#5
0
        public static void ConectarAfip(int cantReg,
                                        TextBox txtTOTALFactura,
                                        TextBox txtSubTotalFactura)
        {
            var codigoAfipService      = "C88DFF36-99E6-4BF6-8A98-31FDCB8E016B";
            var fechaActual            = DateTime.Now;
            var numeroUltimoAutorizado = 0;

            FEAuthRequest feAuth = new FEAuthRequest();

            using (var service = new LoginServiceClient())
            {
                var auth = service.SolicitarAutorizacion(codigoAfipService);

                feAuth.Cuit  = auth.Cuit;
                feAuth.Sign  = auth.Sign;
                feAuth.Token = auth.Token;
            }

            FECAERequest    FECAEReq = new FECAERequest();
            FECAECabRequest FeCabReq = new FECAECabRequest();
            FECAEDetRequest FeDetReq = new FECAEDetRequest();

            FeCabReq.CantReg  = cantReg;
            FeCabReq.CbteTipo = 11; //Factura C
            FeCabReq.PtoVta   = 1;

            FeDetReq.Concepto  = 1;  //Productos
            FeDetReq.DocTipo   = 99; //Sin identificar/Venta global diaria
            FeDetReq.DocNro    = 5;  //PREGUNTAR PROFE
            FeDetReq.CbteDesde = 1;
            FeDetReq.CbteHasta = 99999999;
            //FeDetReq.CbteFch = string.Format("{0}{1}{2}", fechaActual.Year, fechaActual.Month, fechaActual.Day);
            FeDetReq.ImpTotal   = double.Parse(txtTOTALFactura.Text);
            FeDetReq.ImpTotConc = 0;
            FeDetReq.ImpNeto    = double.Parse(txtSubTotalFactura.Text);
            FeDetReq.ImpOpEx    = 0;
            FeDetReq.ImpIVA     = 0;
            FeDetReq.ImpTrib    = 0; //PREGUNTAR PROFE
            FeDetReq.MonId      = "PES";
            FeDetReq.MonCotiz   = 1;

            FECAEReq.FeCabReq = FeCabReq;
            //Este es el error. No en la instanciación del servicio. La colección FeDetReq es nula.
            //FECAEReq.FeDetReq[0] = FeDetReq;
            FECAEReq.FeDetReq = new FECAEDetRequest[] { FeDetReq };

            using (var service2 = new ServiceSoapClient())
            {
                var ultimoAutorizado = service2.FECompUltimoAutorizado(feAuth, 1, 11);

                if (ultimoAutorizado.Errors == null)
                {
                    numeroUltimoAutorizado = ultimoAutorizado.CbteNro + 1;

                    //caeSolicitar
                    service2.FECAESolicitar(feAuth, FECAEReq);
                }
                else
                {
                    MessageBox.Show("Error conexión Afip Service");
                }
            }
        }
        public string comprobante_electronico(int tipocomprobante, long nrodoc, double total, double neto21, double civa21, double neto105, double civa105, ref string cae, ref string fechavto, ref string tipofactura, ref string puntoventa)
        {
            try
            {
                LoginClass miloginclase = new LoginClass("wsfe", NegocioConfigEmpresa.urllogin, @"C:\CertificadodonVito\certificado.pfx", "");
                miloginclase.hacerLogin(miloginclase);
                int doctipoid = 96;
                authRequest       = new FEAuthRequest();
                authRequest.Cuit  = NegocioConfigEmpresa.emcuit;
                authRequest.Sign  = miloginclase.Sing;
                authRequest.Token = miloginclase.Token;

                Service servicio = new Service();
                servicio     = getServicio();
                servicio.Url = NegocioConfigEmpresa.urlservicio;
                //servicio.ClientCertificates.Add(certificado);

                //ver conceptoid
                int conceptoid = CONCEPTO_PRODUCTO;
                if (nrodoc.ToString().Length == 11)
                {
                    doctipoid = 80;
                }


                //  Service service = getServicio();
                servicio.ClientCertificates.Add(miloginclase.Certificado);
                FECAERequest    req = new FECAERequest();
                FECAECabRequest cab = new FECAECabRequest();
                FECAEDetRequest det = new FECAEDetRequest();

                cab.CantReg  = 1;
                cab.PtoVta   = Convert.ToInt32(NegocioConfigEmpresa.puntoventa);
                cab.CbteTipo = tipocomprobante;
                req.FeCabReq = cab;

                det.Concepto = conceptoid;
                det.DocTipo  = doctipoid;
                det.DocNro   = nrodoc;

                // ultimo comprobante autorizado

                FERecuperaLastCbteResponse lastres = servicio.FECompUltimoAutorizado(authRequest, 3, tipocomprobante);
                int last = lastres.CbteNro;
                det.CbteDesde = last + 1;
                det.CbteHasta = last + 1;
                int nrocomprobante = last + 1;

                det.CbteFch = DateTime.Now.ToString("yyyyMMdd");
                if (tipocomprobante == 1 || tipocomprobante == 6)
                {
                    decimal totalneto = decimal.Round(Convert.ToDecimal(neto21 + neto105), 2);
                    decimal totaliva  = decimal.Round(Convert.ToDecimal(civa21 + civa105), 2);
                    det.ImpNeto = Convert.ToDouble(totalneto);
                    det.ImpIVA  = Convert.ToDouble(totaliva);
                }
                else
                {
                    det.ImpNeto = total;
                    det.ImpIVA  = 0;
                }

                det.ImpTotal = total;

                det.ImpTotConc = 0.00;
                det.ImpOpEx    = 0.00;
                det.ImpTrib    = 0.00;

                det.MonId    = "PES";
                det.MonCotiz = 1;
                int     tipoalicuota = ID_TASA_IVA_NINGUNO;
                AlicIva alicuota     = new AlicIva();
                if (tipocomprobante == TIPOCOMPROBANTE_FACTURA_A || tipocomprobante == TIPOCOMPROBANTE_FACTURA_B)
                {
                    tipoalicuota     = ID_TASA_IVA_21_00;
                    alicuota.Id      = tipoalicuota;
                    alicuota.BaseImp = neto21;
                    alicuota.Importe = civa21;
                    if (neto105 > 0)
                    {
                        AlicIva alicuota2 = new AlicIva();
                        tipoalicuota      = ID_TASA_IVA_10_50;
                        alicuota2.Id      = tipoalicuota;
                        alicuota2.BaseImp = neto105;
                        alicuota2.Importe = civa105;
                        det.Iva           = new[] { alicuota, alicuota2 };
                    }
                    else
                    {
                        det.Iva = new[] { alicuota };
                    }
                }
                else
                {
                    alicuota.Id      = tipoalicuota;
                    alicuota.BaseImp = 0;
                    alicuota.Importe = 0;
                    det.Iva          = new[] { alicuota };
                }



                req.FeDetReq = new[] { det };

                FECAEResponse r = servicio.FECAESolicitar(authRequest, req);
                cae = r.FeDetResp[0].CAE; //string CAE
                string ESTADO    = r.FeCabResp.Resultado;
                string resultado = r.FeDetResp[0].Resultado;
                fechavto = r.FeDetResp[0].CAEFchVto;//string vto

                puntoventa  = NegocioConfigEmpresa.puntoventa;
                tipofactura = tipocomprobante.ToString("00");


                string m = "ok";

                {
                    if (r.FeDetResp[0].Observaciones is object)
                    {
                        foreach (var o in r.FeDetResp[0].Observaciones)
                        {
                            m += string.Format("Obs: {0} ({1})", o.Msg, o.Code) + Constants.vbCrLf;
                        }
                    }
                }
                {
                    if (r.Errors is object)
                    {
                        foreach (var er in r.Errors)
                        {
                            m += string.Format("Er: {0}: {1}", er.Code, er.Msg) + Constants.vbCrLf;
                        }
                    }
                }
                {
                    if (r.Events is object)
                    {
                        foreach (var ev in r.Events)
                        {
                            m += string.Format("Ev: {0}: {1}", ev.Code, ev.Msg) + Constants.vbCrLf;
                        }
                    }
                }
                if (m == "ok")
                {
                    m = m + nrocomprobante.ToString();
                }
                return(m);
            }
            catch (Exception)
            {
                throw;
            }


            // string error = r.error;
            //  string desde = r.FeDetResp[0].CbteDesde;
            //  string hasta = r.FeDetResp[0].CbteHasta;
            // string OBSERVACION = r.FeDetResp[0].Observaciones;
        }
示例#7
0
        public static void SolicitarCAE(this IComprobanteElectronico comprobante, string ta_path, Hamekoz.Core.ICallBack callback)
        {
            var service = new Service();

            //HACK para cambiar de produccion a homologacion
                        #if DEBUG
            service = new Service(homo_url);
                        #endif
            var ta = TA(ta_path);

            //TODO ahora podria utilizar comprobante.Tipo.Codigo validando que sea un valor adecuado
            int tipo           = ComprobanteTipo(comprobante);
            int punto_de_venta = int.Parse(comprobante.Tipo.Pre);

            var fECompUltimoAutorizado = service.FECompUltimoAutorizado(ta, punto_de_venta, tipo);
            int numero = fECompUltimoAutorizado.CbteNro;
            numero++;

            var feCabReq = new FECAECabRequest {
                CantReg  = 1,
                CbteTipo = tipo,
                PtoVta   = punto_de_venta
            };

            var fEDetRequest = new FECAEDetRequest {
                CbteDesde   = numero,
                CbteFch     = comprobante.Emision.ToString("yyyyMMdd"),
                CbteHasta   = numero,
                CbtesAsoc   = null,               //TODO en caso de que sean comprobantes vinculados
                Compradores = null,               //TODO revisar porque no encuentro documentacion
                //HACK producto
                Concepto = 1,
                DocNro   = long.Parse(comprobante.Responsable.CUIT.Limpiar()),
                //HACK CUIT
                DocTipo  = 80,
                ImpIVA   = (double)comprobante.IVA,               //TODO debe excluirse el importe exento, para tipo C debe ser 0
                ImpNeto  = (double)(comprobante.Gravado - comprobante.Exento),
                ImpOpEx  = (double)comprobante.Exento,
                ImpTotal = (double)comprobante.Total,
                //TODO en caso de ser de tipo C debe ser siempre 0
                ImpTotConc = (double)comprobante.NoGravado,
                ImpTrib    = (double)comprobante.Tributos,
                Iva        = comprobante.FEIVAS().ToArray(),
                MonCotiz   = 1,               //TODO pasar la cotizacion correcta
                MonId      = "PES",           //TODO pasar la moneda correcta
                Opcionales = null,
                Tributos   = comprobante.Tributos > 0 ? comprobante.FETributos().ToArray() : null,
            };

            var feDetReq = new List <FECAEDetRequest> ();
            feDetReq.Add(fEDetRequest);

            var solicitud = new  FECAERequest {
                FeCabReq = feCabReq,
                FeDetReq = feDetReq.ToArray()
            };

            FECAEResponse fECAEResponse = service.FECAESolicitar(ta, solicitud);

            if (fECAEResponse.Events != null)
            {
                foreach (var evento in fECAEResponse.Events)
                {
                    string mensaje = string.Format("Código: {0}. Mensaje: {1}", evento.Code, evento.Msg);
                    callback.CallBack.OnMessage("Evento AFIP", mensaje);
                }
            }

            if (fECAEResponse.Errors != null)
            {
                var errores = new StringBuilder();
                foreach (var error in fECAEResponse.Errors)
                {
                    errores.AppendFormat("Código: {0}. Mensaje: {1}", error.Code, error.Msg);
                    errores.AppendLine();
                }
                throw new AFIPException(errores.ToString());
            }

            //TODO refactorizar para soportar un lote de comprobantes

            var observaciones = new StringBuilder();
            if (fECAEResponse.FeDetResp [0].Observaciones != null)
            {
                foreach (var observacion in fECAEResponse.FeDetResp[0].Observaciones)
                {
                    observaciones.AppendFormat("Código: {0}. Mensaje: {1}", observacion.Code, observacion.Msg);
                    observaciones.AppendLine();
                }

                callback.CallBack.OnWarning("Comprobante con observaciones", observaciones.ToString());
            }

            if (fECAEResponse.FeDetResp [0].Resultado == "R")
            {
                string errorAfip = string.Format("Comprobante rechazado.\n{0}", observaciones);
                throw new AFIPException(errorAfip);
            }

            //TODO ver si el formato seria correcto
            comprobante.Tipo.UltimoNumero = numero;
            comprobante.NumeroAFIP        = string.Format("{0:0000}-{1:00000000}", punto_de_venta, numero);
            comprobante.Numero            = comprobante.NumeroAFIP;
            comprobante.CAE             = fECAEResponse.FeDetResp [0].CAE;
            comprobante.VencimientoCAE  = fECAEResponse.FeDetResp [0].CAEFchVto;
            comprobante.ComentariosAFIP = observaciones.ToString();
        }
示例#8
0
        private bool GetCae()
        {
            try
            {
                lblStatus.Text      = @"Importando registros";
                barProgress.Style   = ProgressBarStyle.Continuous;
                barProgress.Maximum = _dataAfip.Facturas.Count;

                _db.Connect();

                var wsaa = new WsaaClient();

                var pass = new SecureString();

                foreach (var c in ConfigInfo.PfxPass)
                {
                    pass.AppendChar(c);
                }

                pass.MakeReadOnly();

                wsaa.ObtenerLoginTicketResponse("wsfe", ConfigInfo.WsaaUrl, ConfigInfo.PfxPath, pass, null, null, null, true);

                var authRequest = new FEAuthRequest
                {
                    Token = wsaa.Token,
                    Sign  = wsaa.Sign,
                    Cuit  = ConfigInfo.CUIT
                };

                var svcWsfe = new Afip.Wsfe.Service
                {
                    Url = ConfigInfo.WsfeUrl
                };

                var sb = new StringBuilder();

                foreach (var f in _dataAfip.Facturas)
                {
                    var cab = new FECAECabRequest
                    {
                        CantReg  = 1,
                        PtoVta   = f.PuntoVenta,
                        CbteTipo = f.TipoComprobante
                    };

                    var det = new FECAEDetRequest
                    {
                        Concepto     = 1,
                        DocTipo      = f.CodigoDocumento,
                        DocNro       = f.IdComprador,
                        CbteDesde    = f.NumeroComprobante,
                        CbteHasta    = f.NumeroComprobanteRegistrado,
                        CbteFch      = f.FechaComprobante.ToString(),
                        ImpTotal     = f.ImporteTotal,
                        ImpTotConc   = f.ImporteTotalSinNetoGravado,
                        ImpNeto      = f.ImporteNetoGravado,
                        ImpOpEx      = f.ImporteOperacionesExentas,
                        ImpTrib      = f.ImportePagosCuentaImpuestos,
                        ImpIVA       = f.ImpuestoLiquidado,
                        FchServDesde = f.FechaDesde.ToString(),
                        FchServHasta = f.FechaHasta.ToString(),
                        FchVtoPago   = f.FechaVencimientoPago.ToString(),
                        MonId        = "PES",
                        MonCotiz     = 1
                    };

                    var req = new FECAERequest
                    {
                        FeCabReq = cab,
                        FeDetReq = new[]
                        {
                            det
                        }
                    };

                    var response = svcWsfe.FECAESolicitar(authRequest, req);

                    var saveData = true;

                    if (response.FeDetResp[0].Observaciones != null)
                    {
                        foreach (var o in response.FeDetResp[0].Observaciones)
                        {
                            sb.AppendLine($"Obs: {o.Code} - {o.Msg}");
                        }

                        saveData = false;
                    }

                    if (response.Errors != null)
                    {
                        foreach (var o in response.Errors)
                        {
                            sb.AppendLine($"Err: {o.Code} - {o.Msg}");
                        }

                        saveData = false;
                    }

                    if (response.Events != null)
                    {
                        foreach (var o in response.Events)
                        {
                            sb.AppendLine($"Evt: {o.Code} - {o.Msg}");
                        }

                        saveData = false;
                    }

                    if (saveData)
                    {
                        var query = "UPDATE Facturas SET Cae = @Cae, CaeVto = @CaeVto WHERE IdArchivo = @IdArchivo AND Id = @Id";

                        var parameters = new Hashtable
                        {
                            { "@Cae", response.FeDetResp[0].CAE },
                            { "@CaeVto", response.FeDetResp[0].CAEFchVto },
                            { "@IdArchivo", f.IdArchivo },
                            { "@Id", f.Id }
                        };

                        _db.ExecuteNonQuery(query, parameters);
                    }

                    lblStatus.Text = $@"Registro {barProgress.Value}/{barProgress.Maximum}";
                    barProgress.PerformStep();

                    Application.DoEvents();
                }

                if (sb.Length > 0)
                {
                    throw new ApplicationException(sb.ToString());
                }

                return(true);
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);

                return(false);
            }
            finally
            {
                lblStatus.Text    = string.Empty;
                barProgress.Value = 0;

                _db.Disconnect();
            }
        }