示例#1
0
 private void CreateEmailNotification(AlertaDTO dto)
 {
     try
     {
         var rol       = dto.Rol.Split("$");
         var countries = dto.Pais.Split("$");
         var toUsers   = (from u in _context.Usuario
                          join r in _context.Rol on u.Rol equals r
                          where countries.Contains(u.Pais) && rol.Contains(r.Id)
                          select u).ToArray();
         var user = _context.Usuario.Single(u => u.Id == dto.CodigoUsuario);
         if (toUsers.Length <= 0)
         {
             return;
         }
         var message = new EmailMessage();
         message.ToAddresses.AddRange(toUsers.Select(x => new EmailAddress(x.ApellidoPersonal, x.Email)));
         message.FromAddresses.Add(new EmailAddress("SIMEPADF: Servicio de Notificaciones", "*****@*****.**"));
         message.Subject = dto.Titulo;
         message.Content = $@"
                 <div style='margin: auto; width: 100%;'>
                                 <div style='border: solid 2px steelblue;border-radius: 25px; padding: 0 20px 10px 20px;'>
                                         <div style='background-color: snow;border-radius: 25px 25px 0 0;'>
                                                 <img style='display: block;margin-left: auto;margin-right: auto;width: 15%;' alt='Logo' src=''/>
                                             </div>                
                                             <div style='background-color:white;padding: 40;border-radius: 0 0 25px 25px;font-family: Arial, Helvetica, sans-serif;'>
                                                 <h1 style='color:#0275d8;'>SIMEPADF</h1>
                                                 <br>
                                                 <h3>Notificación: {dto.Titulo}.</h3>
                                                 <p>Por: {user.NombrePersonal} {user.ApellidoPersonal} ({user.Email})</p>
                                                 <p>
                                                     {dto.Mensaje}
                                                 </p>
                                                 <p>Fecha: {DateTime.Now.ToString()}</p>
                                                 <div style='margin-top: 20px;font-family: cursive;font-size: 8px;text-align: center;'>                                    
                                                     <p>SIMEPADF - {DateTime.Now.Year}</p>                        
                                                 </div>
                                             </div>
                                 </div>
                             </div>
                                     ";
         _emailService.Send(message);
     }
     catch (Exception e)
     {
         Console.WriteLine(e);
         throw;
     }
 }
示例#2
0
 public bool CreateAlert(AlertaDTO dto)
 {
     try
     {
         var title   = dto.Titulo.Length > 50 ? dto.Titulo.Substring(0, 50) : dto.Titulo;
         var content = dto.Mensaje.Length > 150 ? dto.Mensaje.Substring(0, 150) : dto.Mensaje;
         foreach (var s in dto.Rol.Split('$'))
         {
             foreach (var s1 in dto.Pais.Split('$'))
             {
                 _context.Alertas.Add(new Alerta(title, content, dto.Tipo, s, s1, dto.NombreUsuario));
                 _context.SaveChanges();
             }
         }
         CreateEmailNotification(dto);
         return(true);
     }
     catch (Exception e)
     {
         Console.WriteLine(e);
         return(false);
     }
 }
示例#3
0
 public IActionResult Add([FromBody] AlertaDTO model)
 {
     return(Ok(_service.CreateAlert(model)));
 }
示例#4
0
        public async Task <IEnumerable <AlertaServicioDTO> > ListAlertsFor(UsuarioDTO currUser)
        {
            if (!currUser.IdRecursoHumano.HasValue)
            {
                return(null);
            }
            var alertServices = new List <AlertaServicioDTO>();
            var alerts        = await this._alertaRepository.ListBy(s => s.Active &&
                                                                    s.IdRequisitoNavigation.IdServicioNavigation.IdRecursoHumano1.Value == currUser.IdRecursoHumano.Value,
                                                                    s => s.IdRequisitoNavigation,
                                                                    s => s.IdRequisitoNavigation.IdServicioNavigation,
                                                                    s => s.IdRequisitoNavigation.IdServicioNavigation.IdRecursoHumano1Navigation,
                                                                    s => s.IdRequisitoNavigation.IdServicioNavigation.IdClienteNavigation,
                                                                    s => s.IdRequisitoNavigation.IdTipoRecurso1Navigation,
                                                                    s => s.IdRequisitoNavigation.IdTipoRecursoMaterial1Navigation,
                                                                    s => s.IdRequisitoNavigation.IdTipoRecursoMaterial2Navigation,
                                                                    s => s.IdRequisitoNavigation.IdTipoRecursoRenovableNavigation,
                                                                    s => s.IdRecurso1Navigation,
                                                                    s => s.IdRecurso1Navigation.RecursoMaterial,
                                                                    s => s.IdRecurso1Navigation.RecursoHumano
                                                                    );

            var alertsGroupedByService = alerts.GroupBy(k => k.IdRequisitoNavigation.IdServicioNavigation, v => v);

            foreach (var item in alertsGroupedByService.ToDictionary(k => k.Key, v => v.ToList()))
            {
                var service = item.Key;
                if (service == null)
                {
                    continue;
                }
                var alService = new AlertaServicioDTO();
                alService.Servicio = _mapper.Map <ServicioDTO>(service);
                var alertsGroupedByRequisito = item.Value.GroupBy(k => k.IdRequisitoNavigation, v => v).ToDictionary(k => k.Key, v => v.ToList());
                foreach (var alRequisito in alertsGroupedByRequisito)
                {
                    var alertDto     = new AlertaDTO();
                    var dtoRequisito = _mapper.Map <RequisitoDTO>(alRequisito.Key);
                    dtoRequisito.TranscripcionRegla = GetDescription(alRequisito.Key);
                    alertDto.Requisito = dtoRequisito;
                    var alertsGroupedByResources = alRequisito.Value.GroupBy(k => k.IdRecurso1Navigation, v => v).Where(s => s.Key.Active == true).Select(s => s.Key).ToList();
                    foreach (var resource in alertsGroupedByResources)
                    {
                        var alertDate   = alerts.FirstOrDefault(s => s.IdRequisito == alertDto.Requisito.Id && s.IdRecurso1 == resource.Id)?.CreationDate;
                        var resourceDto = _mapper.Map <RecursoDTO>(resource);
                        if (resource.RecursoHumano.Any())
                        {
                            var rrhh = resource.RecursoHumano.FirstOrDefault();
                            resourceDto.Descripcion  = $"{rrhh.Apellido}, {rrhh.Nombre} - {rrhh.Cuil}";
                            resourceDto.CreationDate = alertDate;
                            alertDto.Recursos.Add(resourceDto);
                        }
                        else if (resource.RecursoMaterial.Any())
                        {
                            var rrMat = resource.RecursoMaterial.FirstOrDefault();
                            resourceDto.Descripcion  = $"{rrMat.Marca}, {rrMat.Modelo}";
                            resourceDto.CreationDate = alertDate;
                            alertDto.Recursos.Add(resourceDto);
                        }
                    }
                    alService.Alertas.Add(alertDto);
                }
                alertServices.Add(alService);
            }
            return(alertServices);
        }