public void GuardarRecogida(ERecogida recogida, ref Dictionary <string, string> IdsAcumulados, string tipo, ETerminal terminal, EUsuario usuario, EMedioPago medioPago, string contenido, string modeloImpresora, out Respuesta respuesta) { //1. Creamos el encabezado de la venta. string idVenta = Guid.NewGuid().ToString(); RRecogida rRecogida = new RRecogida(); respuesta = new Respuesta(false); try { using (TransactionScope scope = new TransactionScope()) { if (rRecogida.CrearRecogida(idVenta, recogida.Valor, terminal.Codigo, tipo, 1, terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, usuario.IdUsuario) == 1) { rRecogida.CrearVentaRecogida(recogida.CodigoRecogida.Codigo, recogida.CodigoRecogida.Descripcion, idVenta); //3. Creamos totales de venta(registro_venta). if (IdsAcumulados == null) { IdsAcumulados = new Dictionary <string, string>(); IdsAcumulados.Add("idRegistroVenta", Guid.NewGuid().ToString()); //Creamos el registro venta rRecogida.CrearRegistroVenta(IdsAcumulados["idRegistroVenta"], terminal.Codigo, usuario.IdUsuario); } //Actualizo registro venta rRecogida.ActualizarRegistroVenta(IdsAcumulados["idRegistroVenta"], recogida.Valor); //4. Creamos el detalle de los medios de pago. //List<EPago> pagos = re // prestamo.Pagos; rRecogida.CrearMedioPago(medioPago.Codigo, terminal.Codigo, (long)terminal.NumeroUltimaTransaccion + 1, recogida.Valor, idVenta); //Actualizamos el terminal rRecogida.ActualizarTerminal(terminal.Codigo, (long)terminal.NumeroUltimaFactura, (long)terminal.NumeroUltimaTransaccion + 1); rVenta.ActualizarTerminal(terminal.Codigo, (long)terminal.NumeroUltimaFactura, (long)terminal.NumeroUltimaTransaccion + 1); rVenta.CrearCopiaImpresion("00", terminal.Localidad.Codigo, terminal.Codigo, tipo, usuario.IdUsuario, contenido, terminal.Localidad.Codigo, modeloImpresora, (long)terminal.NumeroUltimaFactura, (int)terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, terminal.Codigo, tipo, usuario.IdUsuario); respuesta.Valida = true; respuesta.Mensaje = idVenta; } else { throw new Exception("[GuardarRecogida]: Transaccion no pudo ser guardada."); } scope.Complete(); } } catch (SqlException e) { if (e.Number == -2 || e.Number == 121) { respuesta.Valida = false; respuesta.Mensaje = "Se perdió la conexión con el servidor."; log.Error("[GuardarRecogida]: No pudo ser guardada la transaccion: " + e.Message); } else { respuesta.Valida = false; respuesta.Mensaje = "Hubo un problema al momento de guardar la transaccion. Por favor contacte al administrador del sistema."; log.Error("[Guardarrecogida]: No pudo ser guardada la venta: " + e.Message); } Telemetria.Instancia.AgregaMetrica(new Excepcion(e)); } catch (Exception ex) { respuesta.Documentar(false, " No pudo ser guardada la recogida."); log.Error("[GuardarRecogida]: No pudo ser guardada la recogida. " + ex.Message); Telemetria.Instancia.AgregaMetrica(new Excepcion(ex)); } }
public static void GenerarTransaccionApertura() { try { bool generaTransAperturaCajon = Entorno.Instancia.Parametros.ObtenerValorParametro <bool>("pdv.imprime_transaccion_abrir_cajon"); // ¿debe generar transacción? if (!generaTransAperturaCajon) { return; } string motivoIntervencion = string.Empty; if (Entorno.Instancia.Recogida != null) { ERecogida recogidaActual = Entorno.Instancia.Recogida; if (recogidaActual != null) { if (recogidaActual.listRecogidas.Count > 0 && recogidaActual.Valor > 0) { return; } } motivoIntervencion = "Intervención Recogida"; } else if (Entorno.Instancia.Prestamo != null) { EPrestamo prestamoActual = Entorno.Instancia.Prestamo; if (prestamoActual != null) { if (prestamoActual.ListPrestamos.Count > 0 && prestamoActual.Valor > 0) { return; } } motivoIntervencion = "Intervención Prestamo"; } // log.Info("[GenerarTransaccionApertura] Guardando transacción apertura cajón ..."); PCajon pCajon = new PCajon(); Dictionary <string, string> idsAcumulados = Entorno.Instancia.IdsAcumulados; // Generar tirilla de apertura de cajón Respuesta respuesta = new Respuesta(); string factura = ProcesarPlantilla.AperturaCajon(); var tiempoGuardarAperturaCajon = new MetricaTemporizador("AperturaCajon"); pCajon.GuardarAperturaCajon(ref idsAcumulados, ((int)TipoTransaccion.AbrirCajon).ToString(), Entorno.Instancia.Terminal, Entorno.Instancia.Usuario, factura ?? "contenido", out respuesta); string idVentaApertCajon = respuesta.Mensaje; if (!respuesta.Valida) { Telemetria.Instancia.AgregaMetrica(tiempoGuardarAperturaCajon.Para().AgregarPropiedad("Exitoso", false).AgregarPropiedad("Transaccion", (Entorno.Instancia.Terminal.NumeroUltimaTransaccion + 1)).AgregarPropiedad("Error", respuesta.Mensaje)); } else { Telemetria.Instancia.AgregaMetrica(tiempoGuardarAperturaCajon.Para().AgregarPropiedad("Exitoso", true).AgregarPropiedad("Transaccion", (Entorno.Instancia.Terminal.NumeroUltimaTransaccion + 1)).AgregarPropiedad("CajonAbierto", respuesta.Mensaje)); respuesta = new Respuesta(false); ETerminal terminal = new PTerminal().BuscarTerminalPorCodigo(Config.Terminal, out respuesta); if (respuesta.Valida == true) { // guardar transacción si hubo if (Entorno.Instancia.Usuario.UsuarioSupervisor != null) { PIntervencion pInterv = new PIntervencion(); EIntervencion eInterv = new EIntervencion(); eInterv.id_venta = idVentaApertCajon; eInterv.claveSupervisor = Entorno.Instancia.Usuario.UsuarioSupervisor.ClaveSupervisor; eInterv.motivo = motivoIntervencion; eInterv.nro_transac = Convert.ToInt32(Entorno.Instancia.Terminal.NumeroUltimaTransaccion + 1); pInterv.GuardarIntervencion(eInterv, Entorno.Instancia.Terminal, Entorno.Instancia.Usuario, out respuesta); } Entorno.Instancia.Terminal = terminal; Entorno.Instancia.IdsAcumulados = idsAcumulados; Entorno.Instancia.Usuario.UsuarioSupervisor = null; Entorno.Instancia.Recogida = null; Entorno.Instancia.Prestamo = null; // Imprimir Entorno.Instancia.Impresora.Imprimir(factura, cortarPapel: true, abrirCajon: false); log.Info("[GenerarTransaccionApertura.AbrirCajon] Imprimir Operación: " + factura); } } } catch (Exception ex) { log.Info($"[GenerarTransaccionApertura] Error: {ex.Message}"); } }