예제 #1
0
파일: SelectSql.cs 프로젝트: mathewsun/My
 /// <summary>
 /// Поиск по группе абонентов
 /// </summary>
 /// <param name="idDepNumber">Номер департамента</param>
 /// <param name="nameGroup">Наименование группы</param>
 /// <returns></returns>
 public UserLotus FindUserGroup(int?idDepNumber = null, string nameGroup = null)
 {
     try
     {
         UserLotus   userLotus = new UserLotus();
         ModelSelect model     = new ModelSelect {
             LogicaSelect = SqlSelectModel(26)
         };
         if (idDepNumber != null)
         {
             userLotus.User = Inventory.Database.SqlQuery <EfDatabaseXsdLotusUser.User>(model.LogicaSelect.SelectUser,
                                                                                        new SqlParameter(model.LogicaSelect.SelectedParametr.Split(',')[0], idDepNumber),
                                                                                        new SqlParameter(model.LogicaSelect.SelectedParametr.Split(',')[1], DBNull.Value)).ToArray();
         }
         else
         {
             userLotus.User = Inventory.Database.SqlQuery <EfDatabaseXsdLotusUser.User>(model.LogicaSelect.SelectUser,
                                                                                        new SqlParameter(model.LogicaSelect.SelectedParametr.Split(',')[0], DBNull.Value),
                                                                                        new SqlParameter(model.LogicaSelect.SelectedParametr.Split(',')[1], nameGroup)).ToArray();
         }
         return(userLotus);
     }
     catch (Exception e)
     {
         Loggers.Log4NetLogger.Error(e);
     }
     return(null);
 }
예제 #2
0
파일: SelectSql.cs 프로젝트: mathewsun/My
 /// <summary>
 /// Поиск пользователя идентификатора пользователя в БД Инвентаризация
 /// </summary>
 /// <param name="keyUser">Идентификаторы пользователей</param>
 /// <returns></returns>
 public UserLotus FindUserSqlKey(string[] keyUser)
 {
     try
     {
         UserLotus userLotus = new UserLotus
         {
             User = (from id in Inventory.MailIdentifiers
                     join user in Inventory.Users on id.IdUser equals user.IdUser
                     join otdel in Inventory.Otdels on user.IdOtdel equals otdel.IdOtdel
                     where keyUser.Any(idUser => idUser.Contains(id.IdentifierUser))
                     select
                     new EfDatabaseXsdLotusUser.User
             {
                 Name = user.Name,
                 TabelNumber = user.TabelNumber,
                 NameOtdel = otdel.NameOtdel,
                 IdentifierUser = id.IdentifierUser
             }).ToArray()
         };
         return(userLotus);
     }
     catch (Exception e)
     {
         Loggers.Log4NetLogger.Error(e);
     }
     return(null);
 }
예제 #3
0
파일: SelectSql.cs 프로젝트: mathewsun/My
 /// <summary>
 /// Поиск пользователя или группы по алгоритму
 /// </summary>
 /// <param name="userDefault">Пользователь по умолчанию</param>
 /// <param name="nameFindTextGroupOnUser">Параметры поиска пользователя или группы по умолчанию возвращает пользователя</param>
 /// <returns></returns>
 public UserLotus FindUserOnUserGroup(UserLotus userDefault, string nameFindTextGroupOnUser)
 {
     if (nameFindTextGroupOnUser != null)
     {
         UserLotus userSql = null;
         if (nameFindTextGroupOnUser.Length <= 2 && Regex.IsMatch(nameFindTextGroupOnUser, @"\d"))
         {
             //Ищем группу по номеру группы
             userSql = FindUserGroup(Convert.ToInt32(nameFindTextGroupOnUser));
         }
         //Ищем пользователя
         if (nameFindTextGroupOnUser.Length >= 5)
         {
             var userFindSender = Regex.Matches(nameFindTextGroupOnUser, @"(0[0-1][0-9]{3})").Cast <Match>().Select(m => m.Value).ToArray();
             if (userFindSender.Length > 0)
             {
                 userSql = FindUserSqlKey(userFindSender);
             }
         }
         //Если нашли не дефектных пользователей
         if (userSql?.User != null && userSql.User.Length > 0)
         {
             userDefault = userSql;
         }
         else
         {
             Loggers.Log4NetLogger.Info(new Exception($"Пользователь или группы с идентификаторами ' {nameFindTextGroupOnUser} ' не найден в БД Sql Инвентаризация идет рассылка на стандартную группу (OIT)"));
         }
     }
     return(userDefault);
 }
예제 #4
0
        /// <summary>
        /// Пересылка с почты oit на пользователей Lotus
        /// </summary>
        /// <param name="parameters"></param>
        public void StartMessageOit(ConfigFile.ConfigFile parameters)
        {
            try
            {
                int            count = 0;
                ZipAttachments zip   = new ZipAttachments();
                using (Pop3Client client = new Pop3Client())
                {
                    client.CheckCertificateRevocation = false;
                    client.Connect(parameters.Pop3Address, 995, true);
                    MailSender mail = new MailSender();
                    Loggers.Log4NetLogger.Info(new Exception($"Соединение с сервером eups.tax.nalog.ru установлено (OIT)"));
                    client.Authenticate(parameters.LoginOit, parameters.PasswordOit);
                    Loggers.Log4NetLogger.Info(new Exception($"Пользователь проверен (OIT)"));
                    if (client.IsConnected)
                    {
                        MailLogicLotus mailSave       = new MailLogicLotus();
                        SelectSql      select         = new SelectSql();
                        UserLotus      userSqlDefault = select.FindUserGroup(7);
                        int            messageCount   = client.GetMessageCount();

                        for (int i = 0; i < messageCount; i++)
                        {
                            MimeMessage message             = client.GetMessage(i);
                            var         messageAttaches     = message.Attachments as List <MimeEntity> ?? new List <MimeEntity>();
                            var         messageBodyAttaches = new List <MimeEntity>();
                            messageBodyAttaches.AddRange(message.BodyParts);
                            var calendar = messageBodyAttaches.Where(x => x.ContentType.MimeType == "text/calendar").ToList();
                            var file     = messageBodyAttaches.Where(x =>
                                                                     x.ContentType.MediaType == "image" ||
                                                                     x.ContentType.MediaType == "application").ToList();

                            if (file.Count > 0)
                            {
                                messageAttaches.AddRange(file);
                            }
                            string body;
                            var    isHtmlMime = false;
                            if (string.IsNullOrWhiteSpace(message.TextBody))
                            {
                                body       = message.HtmlBody;
                                isHtmlMime = true;
                            }
                            else
                            {
                                body = message.TextBody;
                            }
                            var date = message.Date;
                            if (date.Date >= DateTime.Now.Date)
                            {
                                if (!mailSave.IsExistsBdMail(message.MessageId))
                                {
                                    if (calendar.Count > 0)
                                    {
                                        var calendarVks = new CalendarVks();
                                        body = calendarVks.CalendarParser(calendar, message);
                                    }
                                    var address    = (MailboxAddress)message.From[0];
                                    var mailSender = address.Address;
                                    var nameFile   = date.ToString("dd.MM.yyyy_HH.mm.ss") + "_" + mailSender.Split('@')[0] + ".zip";
                                    var fullPath   = Path.Combine(parameters.PathSaveArchive, nameFile);
                                    MailLotusOutlookIn mailMessage = new MailLotusOutlookIn()
                                    {
                                        IdMail          = message.MessageId,
                                        MailAdressSend  = parameters.LoginOit,
                                        SubjectMail     = message.Subject,
                                        Body            = body,
                                        MailAdress      = mailSender,
                                        DateInputServer = date.DateTime,
                                        NameFile        = nameFile,
                                        FullPathFile    = fullPath,
                                        FileMail        = zip.StartZipArchive(messageAttaches, fullPath)
                                    };
                                    mailSave.AddModelMailIn(mailMessage);
                                    var mailUsers = mail.FindUserLotusMail(select.FindUserOnUserGroup(userSqlDefault, mailMessage.SubjectMail), "(OIT)");
                                    if (!string.IsNullOrWhiteSpace(message.HtmlBody))
                                    {
                                        var math = Regex.Match(body, @"CN=(.+)МНС");
                                        if (!string.IsNullOrWhiteSpace(math.Value))
                                        {
                                            mailUsers.Add(math.Value);
                                        }
                                    }
                                    if (isHtmlMime)
                                    {
                                        mail.SendMailMimeHtml(mailMessage, mailUsers);
                                    }
                                    else
                                    {
                                        mail.SendMailIn(mailMessage, mailUsers);
                                    }
                                    count++;
                                    Loggers.Log4NetLogger.Info(new Exception($"УН: {mailMessage.IdMail} Дата/Время: {date} От кого: {mailMessage.MailAdress}"));
                                }
                            }
                            else
                            {
                                //Удаление сообщения/письма
                                client.DeleteMessage(i);
                            }
                        }
                        mailSave.Dispose();
                        Loggers.Log4NetLogger.Info(new Exception("Количество пришедшей (OIT) почты:" + count));
                    }
                    mail.Dispose();
                    client.Disconnect(true);
                }
                //Очистить временную папку с файлами
                zip.DropAllFileToPath(parameters.PathSaveArchive);
                foreach (FileInfo file in new DirectoryInfo(parameters.PathSaveArchive).GetFiles())
                {
                    Loggers.Log4NetLogger.Info(new Exception($"Наименование удаленных файлов: {file.FullName}"));
                    file.Delete();
                }
                Loggers.Log4NetLogger.Info(new Exception("Очистили папку от файлов (OIT)!"));
                Loggers.Log4NetLogger.Info(new Exception("Перерыв 5 минут (OIT)"));
            }
            catch (Exception x)
            {
                Loggers.Log4NetLogger.Debug(x);
            }
        }