//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; }
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); }
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; }
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(); }
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(); } }