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