예제 #1
0
        static void Main(string[] args)
        {
            var log = new SIR.Common.Log.Logger("SIR.Sync", new Common.Log.LoggerConfig()
            {
                Console = new Common.Log.LoggerConfig.ConsoleConfig()
                {
                    ShowInConsole = true
                }
            });

            try
            {
                log.Info("== Inicio de Procesamiento de SIR.Sync ==");
                log.Info($"Version: {System.Reflection.Assembly.GetExecutingAssembly().GetName().Version}");
                log.Info($"Command: {AppDomain.CurrentDomain.FriendlyName} {string.Join(' ', args)}");

                var optionsRes = new ParseArgs().Parse <Arguments>(args);
                if (optionsRes.ExistsErrorMessages)
                {
                    log.Log(optionsRes);
                    Console.ReadLine();
                    return;
                }
                var options = optionsRes.Data;

                if (options.ShowHelp)
                {
                    Console.WriteLine("Listado de Parámetros válidos para la aplicación");
                    Console.WriteLine(new ParseArgs().GetHelpText <Arguments>());
                    return;
                }

                var config = Newtonsoft.Json.JsonConvert.DeserializeObject <Application>(System.IO.File.ReadAllText("SIR.Sync.Config.json"));

                if (options.ProcesarSync)
                {
                    var procesador = new BLL.ProcesadorSync(log, config);

                    procesador.ProcesarNotificaciones(options.FechaDesde, options.FechaHasta);
                    procesador.ProcesarAnulaciones(options.FechaDesde, options.FechaHasta);
                    procesador.ProcesarVencimientos();
                    procesador.ProcesarNotificacionesPE();
                }

                if (options.ProcesarRendicion)
                {
                    var procesador = new BLL.ProcesadorRendiciones(log, config);

                    procesador.ProcesarRendicionDAI(options.FechaRendicion, options.DiasRendicion);
                }
            }
            catch (Exception ex)
            {
                log.Error(ex);
            }
            finally
            {
                log.Info("== Fin de Procesamiento de SIR.Sync ==");
            }
        }
예제 #2
0
        internal void ProcesarNotificaciones(DateTime desde, DateTime hasta)
        {
            IList <DTO.StoredProcedures.Pendiente> pendientes = new DTO.StoredProcedures.Pendiente[0];

            try
            {
                var parms = new SIR.Common.DAL.SP.Parameters()
                            .AddParam("pFechaDesde", desde)
                            .AddParam("pFechaHasta", hasta);

                pendientes = DAO.ExecProcedure <DTO.StoredProcedures.Pendiente>("SIR.GETBUIPENDNOTIF", parms);
            }
            catch (Exception ex)
            {
                Logger.Error($"Error al obtener las boletas pendientes de notificación desde la base de datos.");
                Logger.Error(ex);
            }

            var notificaciones = new Queue <Task>();

            foreach (var notif in pendientes)
            {
                notificaciones.Enqueue(new Task <bool>((obj) => {
                    var _logger    = (SIR.Common.Log.Logger)((dynamic)obj).Logger;
                    var _notif     = (DTO.StoredProcedures.Pendiente)((dynamic)obj).notif;
                    var _connector = (SIR.Common.Connector.VEPConnector)((dynamic)obj).connector;
                    try
                    {
                        var res = _connector.NotificarPago(new VEP.Request.NotificarPagoRequest()
                        {
                            Numero     = _notif.Numero,
                            Traza      = _notif.IdCobro,
                            AConfirmar = _notif.AConfirmar
                        });
                        _logger.Log(res);

                        if (res.Success)
                        {
                            _logger.Info($"Se estableció la Traza {_notif.IdCobro} para la Boleta {_notif.Numero}({_notif.Id})");
                        }
                        else
                        {
                            _logger.Error($"Ocurrió un error al establecer la Traza {_notif.IdCobro} para la Boleta {_notif.Numero}({_notif.Id}).");
                        }

                        if (res.Success && _notif.AConfirmar)
                        {
                            var baja = _connector.BajaFacturaPMC(new VEP.Request.BajaFacturaPMCRequest()
                            {
                                NroFactura = _notif.Numero,
                                NroUsuario = string.Empty
                            });
                            _logger.Log(baja);

                            if (baja.Success)
                            {
                                _logger.Info($"Baja PMC para la boleta {_notif.Numero}({_notif.Id}): {baja.Data}");
                            }
                        }
                    }
                    catch (Exception ex)
                    {
                        _logger.Error($"Error al procesar la Notificación de Pago de la Boleta {_notif.Numero}({_notif.Id})");
                        _logger.Error(ex);
                    }

                    return(true);
                }, new { notif, Logger, connector = this.VEPConnector }));
            }

            Logger.Info($"Se han encontrado {notificaciones.Count} Boletas a Notificar.");
            var async = new SIR.Common.Thread.TaskManager();

            async.ProcesarEnParalelo(notificaciones, this.Config.NotificacionesBUI_Paralelismo);
        }