示例#1
0
        protected void odsMailConfig_Updating(object sender, ObjectDataSourceMethodEventArgs e)
        {
            try
            {
                MailAccountService mailAccountService = new MailAccountService();
                MailUser           mu = e.InputParameters[0] as MailUser;
                if (!IsValidEmailDesc(mu.EmailAddress))
                {
                    e.Cancel = true;
                    info.AddMessage("Errore nel formato della mail", Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                    return;
                }
                mailAccountService.Update(mu);
                info.AddMessage("Operazione effettauata", Com.Delta.Messaging.MapperMessages.LivelloMessaggio.OK);
            }
            catch (Exception ex)
            {
                if (ex.GetType() != typeof(ManagedException))
                {
                    ManagedException mEx = new ManagedException("Errore nel caricamento della configurazione della mail", "CM008",
                                                                string.Empty, string.Empty, ex.InnerException);
                    ErrorLogInfo err = new ErrorLogInfo(mEx);
                    err.loggingAppCode = "WEB_MAIL";
                    err.objectID       = this.Context.Session.SessionID;
                    log.Error(err);

                    info.AddMessage(mEx.Message, Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                }
                else
                {
                    info.AddMessage(ex.Message, Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                }
            }
            e.Cancel = true;
        }
示例#2
0
        protected void odsMailConfig_Inserting(object sender, ObjectDataSourceMethodEventArgs e)
        {
            MailUser           mu = e.InputParameters[0] as MailUser;
            MailAccountService mailAccountService = new MailAccountService();

            mu.IdResponsabile = decimal.Parse(MySecurityProvider.CurrentPrincipal.MyIdentity.Id);
            if (!IsValidEmailDesc(mu.EmailAddress))
            {
                e.Cancel = true;
                info.AddMessage("Errore nel formato della mail", Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                return;
            }
            try
            {
                mu.FlgManaged = (mu.FlgManagedInsert == true) ? 1 : 0;
                string serverId = (fvEmail.FindControl("ddlListaServers") as DropDownList).SelectedValue;
                int    serverid = 0;
                int.TryParse(serverId, out serverid);
                if (mailAccountService.GetUserByServerAndUsername(serverid, mu.EmailAddress.ToLower()).FirstOrDefault().Id > 0)
                {
                    info.AddMessage("Attenzione email già esistente", Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                    e.Cancel = true;
                    return;
                }
                else
                {
                    mailAccountService.Insert(mu);
                    this.IdSender_ViewState = mu.UserId;
                    BackendUserService buservice = new BackendUserService();
                    _bUser = (BackendUser)buservice.GetByUserName(MySecurityProvider.CurrentPrincipal.MyIdentity.UserName);
                    popolaGridElencoEmailsShared();
                    SessionManager <BackendUser> .set(SessionKeys.BACKEND_USER, _bUser);

                    info.AddMessage("Operazione effettuata", Com.Delta.Messaging.MapperMessages.LivelloMessaggio.OK);
                }
            }
            catch (Exception ex)
            {
                if (ex.GetType() != typeof(ManagedException))
                {
                    ManagedException mEx = new ManagedException("Errore nell'inserimento della nuova configurazione mail", "CM009",
                                                                string.Empty, string.Empty, ex.InnerException);
                    ErrorLogInfo err = new ErrorLogInfo(mEx);
                    err.loggingAppCode = "WEB_MAIL";
                    err.objectID       = this.Context.Session.SessionID;
                    log.Error(err);

                    info.AddMessage(mEx.Message, Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                }
                else
                {
                    info.AddMessage(ex.Message, Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                }
            }
            e.Cancel = true;
        }
示例#3
0
        public async Task <ServiceResult <object> > Register([FromBody] MailRegisterForm mailRegisterForm)
        {
            var result = await MailAccountService.RegisterByMailAndPassword(mailRegisterForm.MailAddress, mailRegisterForm.Password);

            if (result.State == ServiceResultEnum.Success)
            {
                return(Success(result.Detail));
            }
            else
            {
                return(Result(result.State, result.Detail));
            }
        }
示例#4
0
        public async Task <ViewResult> ResetPassword(string token)
        {
            var result = await MailAccountService.ResetPasswordRequestExist(token);

            if (result.ExtraData == null)
            {
                return(View(ServiceResultViewName, ServiceMessage.NotFound("您要查看的页面不存在")));
            }
            if (result.State == ServiceResultEnum.TimedOut)
            {
                return(View(ServiceResultViewName, TimedOut("该链接已失效")));
            }
            return(View(new ResetPasswordForm {
                EmailAddress = result.ExtraData.EmailAddress
            }));
        }
示例#5
0
        public async Task <ViewResult> ResetPassword([FromForm] ResetPasswordForm form)
        {
            if (!MyForm.ReflectCheck(form))
            {
                return(View(ServiceResultViewName, Invalid("参数非法")));
            }
            if (form.Password != form.ConfirmPassword)
            {
                return(View(form));
            }
            var result = await MailAccountService.ResetPasswordWithResetTokenAndPassword(form.Token, form.Password);

            if (result.State != ServiceResultEnum.Success)
            {
                return(View(ServiceResultViewName, Fail(result.Detail)));
            }
            return(View(ServiceResultViewName, Success()));
        }
示例#6
0
        protected void odsMailConfig_Inserting(object sender, ObjectDataSourceMethodEventArgs e)
        {
            MailUser           mu = e.InputParameters[0] as MailUser;
            MailAccountService mailAccountService = new MailAccountService();

            if (!IsValidEmailDesc(mu.EmailAddress))
            {
                e.Cancel = true;
                info.AddMessage("Errore nel formato della mail", Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                return;
            }
            try
            {
                mailAccountService.Insert(mu);
                this.IdSender_ViewState = mu.UserId;
                BackendUserService buservice = new BackendUserService();
                _bUser = (BackendUser)buservice.GetByUserName(MySecurityProvider.CurrentPrincipal.MyIdentity.UserName);
                popolaGridElencoEmailsShared();
                info.AddMessage("Operazione effettuata", Com.Delta.Messaging.MapperMessages.LivelloMessaggio.OK);
            }
            catch (Exception ex)
            {
                if (ex.GetType() != typeof(ManagedException))
                {
                    ManagedException mEx = new ManagedException("Errore nell'inserimento della nuova configurazione mail", "CM009",
                                                                string.Empty, string.Empty, ex.InnerException);
                    ErrorLogInfo err = new ErrorLogInfo(mEx);
                    err.loggingAppCode = "WEB_MAIL";
                    err.objectID       = this.Context.Session.SessionID;
                    log.Error(err);

                    info.AddMessage(mEx.Message, Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                }
                else
                {
                    info.AddMessage(ex.Message, Com.Delta.Messaging.MapperMessages.LivelloMessaggio.ERROR);
                }
            }
            e.Cancel = true;
        }
示例#7
0
 public async Task <ServiceResult <object> > ForgetPassword([FromBody] ForgetPasswordForm form)
 {
     return(await MailAccountService.RequireResetPasswordByMail(form.MailAddress));
 }
示例#8
0
        public async Task <ServiceResult <bool> > Login([FromBody] MailLoginForm mailLoginForm)
        {
            var result = await MailAccountService.VerifyMailPassword(mailLoginForm.MailAddress, mailLoginForm.Password);

            return(result);
        }
示例#9
0
        public async Task <ViewResult> ConfirmRegister(string token)
        {
            var result = await MailAccountService.AuthMailAddress(token);

            return(View(nameof(ServiceMessage), result));
        }
示例#10
0
 public AccountController(MailAccountService mailAccountService, AccountService accountService)
 {
     MailAccountService = mailAccountService;
     AccountService     = accountService;
 }
示例#11
0
 public async Task <ServiceResult <int?> > UserIdOfMail(string mail)
 {
     return(await MailAccountService.UserIdOfMail(mail));
 }
示例#12
0
        public static void Receive(string mail)
        {
            ApplicationCodeConfigSection configSection =
                (ApplicationCodeConfigSection)ConfigurationManager.GetSection("ApplicationCode");

            if (configSection != null)
            {
                APP_CODE = configSection.AppCode;
            }

            IList <ActiveUp.Net.Mail.DeltaExt.MailUser> listUsers = null;

            try
            {
                //listUsers = ServiceLocator.GetServiceFactory().MailAccountService.GetAllManaged();
                List <string> mails = new List <string>();
                mails.Add(mail);
                MailAccountService mailaccountservice = new MailAccountService();
                listUsers = mailaccountservice.GetUsersByMails(mails);
                listUsers = listUsers.Where(x => x.FlgManaged != 0).ToList();
            }
            catch (Exception ex)
            {
                if (ex.GetType() != typeof(ManagedException))
                {
                    ManagedException mEx = new ManagedException("Errore nel caricamento degli utenti di posta dettagli: " + ex.Message,
                                                                "RMA_001",
                                                                string.Empty,
                                                                string.Empty,
                                                                ex.InnerException);
                    ErrorLogInfo err = new ErrorLogInfo(mEx);
                    _log.Error(err);
                }
            }

            // IMailServerService mailService = null
            MailServerService mailService        = new MailServerService();
            MailLocalService  mailMessageService = null;

            foreach (ActiveUp.Net.Mail.DeltaExt.MailUser user in listUsers)
            {
                _log.Info(new MailLogInfo(APP_CODE, "", user.DisplayName,
                                          user.EmailAddress, (string)null));
                try
                {
                    mailService        = MailServerService.Instance.GetInstance(user);
                    mailMessageService = MailLocalService.Instance;
                }
                catch (Exception e)
                {
                    //TASK: Allineamento log - Ciro
                    if (e.GetType() != typeof(ManagedException))
                    {
                        ManagedException mEx = new ManagedException("Errore nel caricamento degli utenti di posta dettagli: " + e.Message,
                                                                    "RMA_002",
                                                                    string.Empty,
                                                                    string.Empty,
                                                                    e.InnerException);
                        ErrorLogInfo err = new ErrorLogInfo(mEx);
                        _log.Error(err);
                    }
                    //ManagedException mEx = new ManagedException(String.Format("Account {0} non valido", user.EmailAddress), "RMA_002", "", "", e);
                    //ErrorLog err = new ErrorLog(APP_CODE, mEx);
                    //_log.Error(err);
                    continue;
                }
                user.Validated = true;

                Console.ForegroundColor = ConsoleColor.Yellow;
                Console.WriteLine("Account: " + user.EmailAddress);
                Console.ResetColor();
                int retries = 0;
                do
                {
                    mailService.IncomingConnect();
                    if (mailService.IsIncomingConnected())
                    {
                        break;
                    }
                    ++retries;
                }while (retries <= 5);

                if (!mailService.IsIncomingConnected())
                {
                    //TASK: Allineamento log - Ciro
                    ManagedException mEx = new ManagedException("Impossibile connettersi al server remoto",
                                                                "RMA_022",
                                                                string.Empty,
                                                                string.Empty,
                                                                null);
                    ErrorLogInfo err = new ErrorLogInfo(mEx);
                    err.loggingAppCode = string.Empty;
                    err.objectID       = mail.ToString() + " - " + System.DateTime.Now.Date + "_" + System.DateTime.Now.Ticks;
                    err.userID         = user.UserId.ToString();
                    _log.Error(err);
                    //_log.Error(new ErrorLogInfo(APP_CODE, "RMA_002", "Impossibile connettersi al server remoto.",
                    //    user.EmailAddress, null, null, null, null, null, null,
                    //    null, null, null));
                    continue;
                }
                ///pensiamo a qualcosa di più decente che così non si può vedere
                System.Threading.Thread.Sleep(500);
                List <MessageUniqueId> listUIds = mailService.RetrieveUIds();
                if (listUIds == null || listUIds.Count == 0)
                {
                    if (mailService.IsIncomingConnected())
                    {
                        Disconnect(mailService);
                    }
                    _log.Info(new MailLogInfo(APP_CODE, "", user.DisplayName,
                                              user.EmailAddress, "Nessun messaggio da scaricare"));
                    Console.ForegroundColor = ConsoleColor.Red;
                    Console.WriteLine("Non vi sono messaggi da scaricare");
                    Console.ResetColor();
                    continue;
                }

                listUIds = listUIds.OrderBy(x => x.Ordinal).ToList();
                Console.ForegroundColor = ConsoleColor.Red;
                Console.WriteLine(String.Format("Vi sono {0} messaggi da scaricare", listUIds.Count()));
                Console.ResetColor();
                List <ActiveUp.Net.Common.DeltaExt.MailStatusServer> stSer = new List <ActiveUp.Net.Common.DeltaExt.MailStatusServer>();
                stSer.Add(ActiveUp.Net.Common.DeltaExt.MailStatusServer.PRESENTE);
                stSer.Add(ActiveUp.Net.Common.DeltaExt.MailStatusServer.DA_NON_CANCELLARE);
                Dictionary <ActiveUp.Net.Common.DeltaExt.MailStatusServer, List <string> > savedUidsAll = (Dictionary <ActiveUp.Net.Common.DeltaExt.MailStatusServer, List <string> >)mailMessageService.GetAllUIDsByAccount(user.EmailAddress, stSer);
                List <string> savedUids = null;
                if (savedUidsAll != null && savedUidsAll.Count > 0)
                {
                    savedUids = savedUidsAll.SelectMany(x => x.Value).ToList();
                }
                else
                {
                    savedUids = new List <string>();
                }
                //cancello dal server
                bool   toCancel  = false;
                string cancelKey = System.Configuration.ConfigurationManager.AppSettings.Get("DeleteFromServer");
                bool.TryParse(cancelKey, out toCancel);
                int idx = 0;
                //se abilitato alla cancellazione
                if (user.FlgManaged == 2 && toCancel)
                {
                    //se ci sono email da cencellare
                    if (savedUidsAll != null && savedUidsAll.ContainsKey(ActiveUp.Net.Common.DeltaExt.MailStatusServer.PRESENTE) && savedUidsAll[ActiveUp.Net.Common.DeltaExt.MailStatusServer.PRESENTE].Count != 0)
                    {
                        try
                        {
                            //seleziona gli uid da cancellare
                            var mailToCancel = listUIds.Where(x =>
                                                              savedUidsAll[ActiveUp.Net.Common.DeltaExt.MailStatusServer.PRESENTE].Contains(x.UId.Replace(',', '§')));
                            foreach (var uid in mailToCancel)
                            {
                                //cancella dal server
                                mailService.DeleteMessageFromServer(uid.UId);
                                Disconnect(mailService);
                                Connect(mailService);
                                mailMessageService.UpdateMessageServerStatus(user.EmailAddress, uid.UId, ActiveUp.Net.Common.DeltaExt.MailStatusServer.CANCELLATA);
                                idx = mailToCancel.IndexOf(uid) + 1;
                                //disconnect ogni 10 mail per committare sul server
                                if ((idx % 10) == 0)
                                {
                                    Console.ForegroundColor = ConsoleColor.Red;
                                    Console.WriteLine("Cancellati " + idx + " messaggi");
                                    Console.ResetColor();
                                    if (Disconnect(mailService))
                                    {
                                        if (!Connect(mailService))
                                        {
                                            break;
                                        }
                                    }
                                }
                            }
                            _log.Info(new MailLogInfo(APP_CODE, "", user.DisplayName,
                                                      user.EmailAddress, "Cancellati " + idx + " messaggi"));
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("Cancellati " + idx + " messaggi");
                            Console.ResetColor();
                            if (Disconnect(mailService))
                            {
                                if (!Connect(mailService))
                                {
                                    continue;
                                }
                            }
                            //aggiorna gli uid dal server di posta
                            listUIds = mailService.RetrieveUIds();
                            if (listUIds == null || listUIds.Count == 0)
                            {
                                if (mailService.IsIncomingConnected())
                                {
                                    Disconnect(mailService);
                                }
                                _log.Info(new MailLogInfo(APP_CODE, "", user.DisplayName,
                                                          user.EmailAddress, "Nessun messaggio da scaricare"));
                                Console.ForegroundColor = ConsoleColor.Red;
                                Console.WriteLine("Non vi sono messaggi da scaricare");
                                Console.ResetColor();
                                continue;
                            }
                            //esclude quelli da già in banca dati, se vi sono
                            var lUids = listUIds.Where(x => !savedUidsAll[ActiveUp.Net.Common.DeltaExt.MailStatusServer.PRESENTE].Contains(x.UId));
                            if (lUids.Count() == 0)
                            {
                                continue;
                            }
                            listUIds = lUids.OrderBy(x => x.Ordinal).ToList();
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine(String.Format("Vi sono {0} messaggi da scaricare", listUIds.Count()));
                            Console.ResetColor();
                            _log.Info(new MailLogInfo(APP_CODE, "", user.DisplayName,
                                                      user.EmailAddress, "Vi sono " + listUIds.Count + " messaggi da scaricare"));
                        }
                        catch
                        {
                            continue;
                        }
                    }
                }
                idx = 0;
                foreach (MessageUniqueId uId in listUIds)
                {
                    if (!savedUids.Contains(uId.UId.Replace(',', '§')))
                    {
                        _log.Debug("WORKING UID:" + uId.UId);
                        _log.Debug("WORKING ORDINAL:" + uId.Ordinal);
                        List <ActiveUp.Net.Mail.DeltaExt.MailHeader> ml = ((MailServerService)mailService).Pop3.RetrieveHeaders(uId.Ordinal, 1);
                        if (ml == null || ml.Count == 0)
                        {
                            ml = new List <ActiveUp.Net.Mail.DeltaExt.MailHeader>();
                            ml.Add(new ActiveUp.Net.Mail.DeltaExt.MailHeader {
                                UniqueId = uId.UId
                            });
                        }
                        _log.Debug(string.Format("WORKING HEADER: FROM - {0} ; SUBJECT - {1} ; UID - {2}", ml[0].From, ml[0].Subject, ml[0].UniqueId));
                        //maxSize da configurazione
                        int    maxSize         = 0;
                        string confMaxMailSize = ConfigurationManager.AppSettings.Get("MaxMailSizeInMB");
                        if (!String.IsNullOrEmpty(confMaxMailSize))
                        {
                            int.TryParse(confMaxMailSize, out maxSize);
                            // limite alzato a 8 mega
                            //     maxSize *= (int)Math.Pow(1024, 2);
                            maxSize *= (int)Math.Pow(1024, 8);
                        }
                        if (maxSize > 0)//se è definito un maxSize positivo
                        {
                            //dimensione del messaggio in byte
                            int size = mailService.GetMessageSize(uId.UId);
                            if (size > maxSize) // 4MB
                            {
                                //TASK: Allineamento log - Ciro
                                ManagedException mEx = new ManagedException(string.Format("Messaggio: {0} - Mail superiore a {1}MB! Controllare sul server", uId.UId, ConfigurationManager.AppSettings.Get("MaxMailSizeInMB")),
                                                                            "RMA_031",
                                                                            string.Empty,
                                                                            string.Empty,
                                                                            null);
                                ErrorLogInfo err = new ErrorLogInfo(mEx);
                                _log.Error(err);
                                //_log.Error(new ErrorLogInfo(APP_CODE, "RMA_003",
                                //    string.Format("Messaggio: {0} - Mail superiore a {1}MB! Controllare sul server",
                                //    uId.UId,
                                //    ConfigurationManager.AppSettings.Get("MaxMailSizeInMB")),
                                //    user.EmailAddress, null, null, null, null,
                                //    null, null, null, null, null));
                                Console.ForegroundColor = ConsoleColor.Cyan;
                                Console.WriteLine("WORKING HEADER: FROM - {0} ; SUBJECT - {1} ; UID - {2} ; SIZE - {3} ", ml[0].From, ml[0].Subject, ml[0].UniqueId, size);
                                Console.ResetColor();
                                continue;
                            }
                        }

                        ActiveUp.Net.Mail.Message m = mailService.getMessage(uId.UId, false);

                        if (m == null) //messaggio non trovato dall'UID!!!!
                        {
                            byte[] msx;
                            try
                            {
                                //provo a prendere il messaggio per progressivo
                                if (!mailService.IsIncomingConnected())
                                {
                                    Connect(mailService);
                                }
                                msx = ((MailServerService)mailService).Pop3.Pop3Client.RetrieveMessage(uId.Ordinal);
                                if (mailService.IsIncomingConnected())
                                {
                                    mailService.IncomingDisconnect();
                                }
                            }
                            catch (Exception ex)
                            {
                                _log.Info(new MailLogInfo(APP_CODE, "", user.DisplayName, user.EmailAddress,
                                                          "Messaggio " + uId.UId + " non trovato"));
                                msx = null;
                            }
                            if (msx == null || msx.Length == 0)
                            {
                                continue;
                            }
                            ActiveUp.Net.Mail.Message msg = new Message();
                            try
                            {
                                //provo il parser dal binary content
                                //Parser.BodyParsed += new Parser.OnBodyParsedEvent(Parser_BodyParsed);
                                //Parser.ErrorParsing += new Parser.OnErrorParsingEvent(Parser_ErrorParsing);
                                msg     = Parser.ParseMessage(msx);
                                msg.Uid = uId.UId;
                            }
                            catch (Exception ex)
                            {
                                //costruisco il messaggio a mano
                                msg.OriginalData = msx;
                                msg.Uid          = uId.UId;
                                msg.From         = new Address();
                                msg.From.Email   = ml[0].From ?? "UNDEFINED";
                                if (!String.IsNullOrEmpty(ml[0].To))
                                {
                                    msg.To = new AddressCollection();
                                    string[] to_emails = ml[0].To.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
                                    msg.To.AddRange(to_emails.Select(to => new Address(to.Trim())));
                                }
                                msg.Subject = ml[0].Subject;
                                msg.Date    = ml[0].Date;

                                if (ex.GetType() != typeof(ManagedException))
                                {
                                    ManagedException mEx = new ManagedException("Messaggio costruito a mano: " + ex.Message,
                                                                                "ERR_H100",
                                                                                string.Empty,
                                                                                string.Empty,
                                                                                ex);
                                    ErrorLogInfo er = new ErrorLogInfo(mEx);
                                    _log.Error(er);
                                }
                            }
                            //assegno il messaggio al messaggio in lavorazione
                            m = msg;
                        }

                        try
                        {
                            if (savedUidsAll != null && savedUidsAll.ContainsKey(ActiveUp.Net.Common.DeltaExt.MailStatusServer.DA_NON_CANCELLARE) && savedUidsAll[ActiveUp.Net.Common.DeltaExt.MailStatusServer.DA_NON_CANCELLARE].Contains(m.Uid))
                            {
                                mailMessageService.Update(user, m);
                            }
                            else
                            {
                                mailMessageService.Insert(user, m);
                            }

                            if (!String.IsNullOrEmpty(m.HeaderFields["X-Ricevuta"]))
                            {
                                string ric = m.HeaderFields["X-Ricevuta"].ToLower();
                                ActiveUp.Net.Common.DeltaExt.MailStatus newSt = ActiveUp.Net.Common.DeltaExt.MailStatus.UNKNOWN;

                                switch (ric)
                                {
                                case "accettazione":
                                    newSt = ActiveUp.Net.Common.DeltaExt.MailStatus.ACCETTAZIONE;
                                    break;

                                case "non-accettazione":
                                    newSt = ActiveUp.Net.Common.DeltaExt.MailStatus.NON_ACCETTAZIONE;
                                    break;

                                case "presa-in-carico":
                                    break;

                                case "avvenuta-consegna":
                                    newSt = ActiveUp.Net.Common.DeltaExt.MailStatus.AVVENUTA_CONSEGNA;
                                    break;

                                case "posta-certificata":
                                    break;

                                case "errore-consegna":
                                    newSt = ActiveUp.Net.Common.DeltaExt.MailStatus.ERRORE_CONSEGNA;
                                    break;

                                case "preavviso-errore-consegna":
                                    newSt = ActiveUp.Net.Common.DeltaExt.MailStatus.ERRORE_CONSEGNA;
                                    break;

                                case "rilevazione-virus":
                                    newSt = ActiveUp.Net.Common.DeltaExt.MailStatus.ERROR;
                                    break;
                                }

                                if (newSt != ActiveUp.Net.Common.DeltaExt.MailStatus.UNKNOWN)
                                {
                                    string idOldString = m.HeaderFields["X-Riferimento-Message-ID"];
                                    if (idOldString.StartsWith("<"))
                                    {
                                        idOldString = idOldString.Substring(1);
                                    }
                                    if (idOldString.EndsWith(">"))
                                    {
                                        idOldString = idOldString.Substring(0, idOldString.Length - 1);
                                    }
                                    string[] idOldStr = idOldString.Split('.');
                                    Int64    idOld    = -1;
                                    if (idOldStr.Length > 0 && Int64.TryParse(idOldStr[0], out idOld))
                                    {
                                        //IComunicazioniService comS = ServiceLocator.GetServiceFactory().ComunicazioniService;
                                        ComunicazioniService comS = new ComunicazioniService();
                                        SendMail.Model.ComunicazioniMapping.Comunicazioni com = comS.LoadComunicazioneByIdMail(idOld);
                                        if (com != null)
                                        {
                                            SendMail.Model.ComunicazioniMapping.ComFlusso flusso = com.ComFlussi[SendMail.Model.TipoCanale.MAIL].Last();

                                            //se si trova in stato di errore non aggiorno
                                            if (flusso.StatoComunicazioneNew == ActiveUp.Net.Common.DeltaExt.MailStatus.ERROR ||
                                                flusso.StatoComunicazioneNew == ActiveUp.Net.Common.DeltaExt.MailStatus.CANCELLED ||
                                                flusso.StatoComunicazioneNew == ActiveUp.Net.Common.DeltaExt.MailStatus.NON_ACCETTAZIONE ||
                                                flusso.StatoComunicazioneNew == ActiveUp.Net.Common.DeltaExt.MailStatus.ERRORE_CONSEGNA)
                                            {
                                                idx = listUIds.ToList().IndexOf(uId);
                                                if ((idx != 0) && ((idx % 50) == 0))
                                                {
                                                    Console.ForegroundColor = ConsoleColor.Red;
                                                    Console.WriteLine("Inseriti " + idx + " messaggi");
                                                    Console.ResetColor();
                                                    _log.Info(new MailLogInfo(APP_CODE,
                                                                              "", user.DisplayName, user.EmailAddress,
                                                                              "Inseriti " + idx + " messaggi"));
                                                }
                                                continue;
                                            }

                                            SendMail.Model.ComunicazioniMapping.ComFlusso newFl = new SendMail.Model.ComunicazioniMapping.ComFlusso();
                                            newFl.Canale                = SendMail.Model.TipoCanale.MAIL;
                                            newFl.DataOperazione        = m.Date;
                                            newFl.RefIdComunicazione    = flusso.RefIdComunicazione;
                                            newFl.StatoComunicazioneNew = newSt;
                                            newFl.StatoComunicazioneOld = flusso.StatoComunicazioneNew;
                                            newFl.UtenteOperazione      = "SYSTEM";
                                            com.ComFlussi[SendMail.Model.TipoCanale.MAIL].Add(newFl);
                                            comS.UpdateFlussoComunicazione(SendMail.Model.TipoCanale.MAIL, com);
                                        }
                                        else
                                        {
                                            try
                                            {
                                                Message msg = mailMessageService.GetById(idOld);
                                                if (msg != null)
                                                {
                                                    List <string> uidMails = new List <string>();
                                                    uidMails.Add(msg.Uid);
                                                    mailMessageService.UpdateMailStatus(user.EmailAddress, uidMails, newSt, null, null, "I");
                                                }
                                            }
                                            catch
                                            {
                                                continue;
                                            }
                                        }
                                    }
                                }
                            }
                        }
                        catch (ManagedException mEx)
                        {
                            if (mEx.CodiceEccezione.Equals("WRN_INS_ML_001"))
                            {
                                mailService.DeleteMessageFromServer(uId.UId);
                            }
                        }
                        catch (Exception ex)
                        {
                            //TASK: Allineamento log - Ciro
                            if (ex.GetType() != typeof(ManagedException))
                            {
                                ManagedException mEx = new ManagedException(String.Format("Errore nel salvataggio della mail uid: {0} from: {1} subject:{2} dell'account {3}", m.Uid, m.From.Email, m.Subject, user.EmailAddress),
                                                                            "RMA_003",
                                                                            string.Empty,
                                                                            string.Empty,
                                                                            ex.InnerException);
                                ErrorLogInfo err = new ErrorLogInfo(mEx);
                                _log.Error(err);
                            }
                            //ManagedException mEx = new ManagedException(
                            //    String.Format("Errore nel salvataggio della mail uid: {0} from: {1} subject:{2} dell'account {3}", m.Uid, m.From.Email, m.Subject, user.EmailAddress),
                            //    "RCV_MAIL_003", "", "", ex);
                            //ErrorLog err = new ErrorLog(APP_CODE, mEx);
                            //_log.Error(err);
                        }

                        idx = listUIds.IndexOf(uId) + 1;
                        if ((idx % 50) == 0)
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("Inseriti " + idx + " messaggi");
                            Console.ResetColor();
                            _log.Info(new MailLogInfo(APP_CODE, "", user.DisplayName,
                                                      user.EmailAddress, "Inseriti " + idx + " messaggi"));
                        }
                    }
                }
                if (mailService.IsIncomingConnected())
                {
                    Disconnect(mailService);
                }
                Console.ForegroundColor = ConsoleColor.Red;
                Console.WriteLine("Inseriti " + listUIds.Count + " messaggi");
                Console.ResetColor();
                _log.Info(new MailLogInfo(APP_CODE, "", user.DisplayName,
                                          user.EmailAddress, "Inseriti " + listUIds.Count + " messaggi"));
            }
        }
示例#13
0
        public static void Send(string mail, int maxNrMail)
        {
            Console.WriteLine("Invio mail");
            MailMessage email = new MailMessage();
            List <SendMail.Model.ComunicazioniMapping.Comunicazioni> listComunicazioni = null;
            ComunicazioniService service = new ComunicazioniService();

            listComunicazioni = (List <SendMail.Model.ComunicazioniMapping.Comunicazioni>)service.LoadComunicazioniDaInviare(CANALE_INVIO, 0, maxNrMail, mail);
            if (listComunicazioni == null || listComunicazioni.Count == 0)
            {
                _log.Info(new MailLogInfo(APP_CODE, "", "BATCH", mail,
                                          "Nessuna comunicazione da inviare"));
                return;
            }
#if TEST
            // listComunicazioni = listComunicazioni.Where(c => c.IdComunicazione == 54373).ToList();
#endif
            Console.WriteLine("Trovate {0} comunicazioni", listComunicazioni.Count);
            _log.Info(new MailLogInfo(APP_CODE, "", "BACTH", mail,
                                      string.Format("Trovate {0} comunicazioni", listComunicazioni.Count)));
            List <String> mails = null;
            var           accs  = from c in listComunicazioni
                                  where c.MailComunicazione != null
                                  let mc = c.MailComunicazione
                                           where !String.IsNullOrEmpty(mc.MailSender)
                                           select mc.MailSender;

            if (accs != null && accs.Count() != 0)
            {
                mails = accs.Distinct().ToList();
            }
            IList <MailUser> mUs = null;
            if (mails != null)
            {
                MailAccountService accS = new MailAccountService();
                mUs = accS.GetUsersByMails(mails);
            }
            if (mUs == null)
            {
                ManagedException mEx = new ManagedException("Nessun account mappato per invio mail",
                                                            "SND_ERR_011",
                                                            string.Empty,
                                                            string.Empty,
                                                            null);
                ErrorLogInfo err = new ErrorLogInfo(mEx);
                _log.Error(err);
                return;
            }

            foreach (SendMail.Model.ComunicazioniMapping.Comunicazioni comun in listComunicazioni)
            {
                Console.WriteLine("Id comunicazione: {0}", comun.IdComunicazione);
                SendMail.Model.ComunicazioniMapping.ComFlusso nuovoFlusso = null;
                IOrderedEnumerable <SendMail.Model.ComunicazioniMapping.ComFlusso> flusso = comun.ComFlussi[CANALE_INVIO].OrderBy(f => !f.DataOperazione.HasValue).ThenBy(f => f.DataOperazione);
                if (flusso.Last().StatoComunicazioneOld == MailStatus.SEND_AGAIN)
                {
                    nuovoFlusso = flusso.Last();
                }
                else
                {
                    nuovoFlusso =
                        new SendMail.Model.ComunicazioniMapping.ComFlusso()
                    {
                        Canale                = CANALE_INVIO,
                        RefIdComunicazione    = comun.IdComunicazione,
                        StatoComunicazioneOld = flusso.Last().StatoComunicazioneNew,
                        StatoComunicazioneNew = MailStatus.UNKNOWN,
                        UtenteOperazione      = flusso.Last().UtenteOperazione
                    };
                    comun.ComFlussi[CANALE_INVIO].Add(nuovoFlusso);
                }

                if (!comun.IsValid)
                {
                    nuovoFlusso.StatoComunicazioneNew = MailStatus.ERROR;
                    UpdateFlusso(comun);
                    continue;
                }

                MailUser us = mUs.SingleOrDefault(x => x.EmailAddress == comun.MailComunicazione.MailSender);
                if (us == null)
                {
                    nuovoFlusso.StatoComunicazioneNew = MailStatus.CANCELLED;
                    UpdateFlusso(comun);
                    continue;
                }

                List <SendMail.Model.ComunicazioniMapping.ComAllegato> allegatiList =
                    (List <SendMail.Model.ComunicazioniMapping.ComAllegato>)comun.ComAllegati;
                try
                {
                    foreach (SendMail.Model.ComunicazioniMapping.ComAllegato allegato in allegatiList)
                    {
                        try
                        {
                            switch (allegato.AllegatoExt)
                            {
                            case "XSL":
                            case "xsl":
                                System.IO.MemoryStream sXML = new System.IO.MemoryStream(allegato.AllegatoFile);
                                XmlDocument            xml  = new XmlDocument();
                                xml.Load(sXML);
                                string   xslUri    = System.IO.Path.Combine(ConfigurationManager.AppSettings.Get("pathFolderTpu"), allegato.AllegatoTpu);
                                string[] separator = new string[1] {
                                    ".tpu"
                                };
                                string[]    appo = xslUri.Split(separator, StringSplitOptions.RemoveEmptyEntries);
                                XmlDocument xsl  = new XmlDocument();
                                xsl.Load(appo[0].Trim());
                                // modificato per usare itextsharp
                                PdfFormatterITEXT      fo   = FormatterProvider.formatDocumentitext("PDF");
                                System.IO.MemoryStream mPdf = fo.formatData(xml, xsl);
                                // fine modifica
                                IDictionary <string, string> d = new Dictionary <string, string>();
                                d.Add("subject", "VERIFICA ABITAZIONE");
                                d.Add("author", "ROMA CAPITALE");
                                d.Add("creator", "Certificati Online");
                                byte[] bdoc = fo.SetMetadati(mPdf, d);
                                allegato.AllegatoFile = bdoc;
                                allegato.AllegatoExt  = "PDF";
                                break;

                            default:
                                break;
                            }
                        }
                        catch (Exception ex)
                        {
                            if (!ex.GetType().Equals(typeof(ManagedException)))
                            {
                                ManagedException mEx = new ManagedException("Errore nella generazione del pdf",
                                                                            "SEN_012",
                                                                            string.Empty,
                                                                            string.Empty,
                                                                            ex.InnerException);
                                mEx.addEnanchedInfosTag("REQUEST", new XElement("Mail",
                                                                                new XAttribute("IdComunicazione", comun.IdComunicazione),
                                                                                new XElement("Status", nuovoFlusso.StatoComunicazioneNew.ToString()),
                                                                                new XElement("IdMail",
                                                                                             (comun.MailComunicazione.IdMail != null) ? comun.MailComunicazione.IdMail.ToString():" vuoto ")).ToString());
                                ErrorLogInfo err = new ErrorLogInfo(mEx);
                                err.objectID = (comun.UniqueId != null) ? comun.UniqueId : comun.IdComunicazione.ToString();
                                _log.Error(err);
                                throw mEx;
                            }
                            else
                            {
                                throw;
                            }
                        }
                    }
                }
                catch
                {
                    nuovoFlusso.StatoComunicazioneNew = MailStatus.ERROR;
                    UpdateFlusso(comun);
                    continue;
                }

                try
                {
                    service.UpdateAllegati(CANALE_INVIO, comun);
                }
                catch (Exception ex)
                {
                    if (!ex.GetType().Equals(typeof(ManagedException)))
                    {
                        ManagedException mEx = new ManagedException("Errore aggiornamento della mail",
                                                                    "SEN_002",
                                                                    string.Empty,
                                                                    string.Empty,
                                                                    ex.InnerException);
                        mEx.addEnanchedInfosTag("REQUEST", new XElement("Mail",
                                                                        new XAttribute("IdMail", comun.IdComunicazione),
                                                                        new XElement("Status", nuovoFlusso.StatoComunicazioneNew.ToString())).ToString());
                        ErrorLogInfo err = new ErrorLogInfo(mEx);
                        err.objectID = (comun.UniqueId != null) ? comun.UniqueId : comun.IdComunicazione.ToString();
                        _log.Error(err);
                    }
                }
                try
                {
                    email = ComunicazioniExtensionMethods.ConvertToEmail(comun);
                    if (null == email)
                    {
                        throw new ArgumentNullException("email non creata");
                    }
                    //carica le immagini
                    HtmlAgilityPack.HtmlDocument htmlDoc = new HtmlAgilityPack.HtmlDocument();
                    htmlDoc.LoadHtml(email.Body);
                    var imgs = from img in htmlDoc.DocumentNode.Descendants("img")
                               where img.Attributes["src"].Value.StartsWith("file:///")
                               select img;
                    if (imgs.Count() > 0)
                    {
                        foreach (var img in imgs)
                        {
                            string rootPath = ConfigurationManager.AppSettings.Get("pathFolderTpu");
                            string pathImg  = Path.Combine(rootPath, img.Attributes["src"].Value.Substring(8));
                            string ext      = Path.GetExtension(pathImg).Substring(1);
                            byte[] imgBytes = File.ReadAllBytes(pathImg);
                            img.Attributes["src"].Value = "data:image/" + ext + ";base64,"
                                                          + Convert.ToBase64String(imgBytes);
                        }

                        using (Stream ms = new MemoryStream())
                        {
                            htmlDoc.Save(ms, new UTF8Encoding(false));
                            ms.Position = 0;
                            byte[] buffer = new byte[ms.Length];
                            ms.Read(buffer, 0, (int)ms.Length);
                            email.Body = new UTF8Encoding(false).GetString(buffer);
                            service.UpdateMailBody(comun.MailComunicazione.IdMail.Value, email.Body);
                        }
                    }
                    foreach (ComAllegato t in comun.ComAllegati)
                    {
                        email.Attachments.Add(ComunicazioniExtensionMethods.ConvertToAttachment(t));
                    }
                }
                catch (Exception ex)
                {
                    if (!ex.GetType().Equals(typeof(ManagedException)))
                    {
                        ManagedException mEx = new ManagedException("Errore nella creazione della mail per il metabus",
                                                                    "SEN_003",
                                                                    string.Empty,
                                                                    string.Empty,
                                                                    ex.InnerException);
                        mEx.addEnanchedInfosTag("REQUEST", new XElement("Mail",
                                                                        new XAttribute("IdMail", comun.MailComunicazione.IdMail)).ToString());
                        ErrorLogInfo err = new ErrorLogInfo(mEx);
                        err.objectID = (comun.UniqueId != null) ? comun.UniqueId : comun.IdComunicazione.ToString();
                        _log.Error(err);
                    }

                    nuovoFlusso.StatoComunicazioneNew = MailStatus.ERROR;
                    UpdateFlusso(comun);
                    continue;
                }
                try
                {
                    MailUser user = MailServerConfigFacade.GetInstance().GetManagedUserByAccount(email.From.Address);
                    System.Net.Mail.SmtpClient smtpMail = new System.Net.Mail.SmtpClient();
                    smtpMail                       = new System.Net.Mail.SmtpClient(user.OutgoingServer, user.PortOutgoingServer);
                    smtpMail.EnableSsl             = user.IsOutgoingSecureConnection;
                    smtpMail.DeliveryMethod        = SmtpDeliveryMethod.Network;
                    smtpMail.UseDefaultCredentials = false;
                    if (user.LoginId != null && user.Password != null && user.LoginId.Length > 0)
                    {
                        smtpMail.Credentials = new NetworkCredential(user.LoginId, user.Password);
                    }
                    smtpMail.Send(email);
                    nuovoFlusso.StatoComunicazioneNew = MailStatus.SENT;
                    UpdateFlusso(comun);
                }
                catch (Exception ex)
                {
                    XElement details = new XElement("comunicazione",
                                                    new XAttribute("uniqueId", comun.UniqueId));
                    if (ex != null)
                    {
                        System.Xml.Serialization.XmlSerializer ser =
                            new System.Xml.Serialization.XmlSerializer(typeof(Exception));
                        MemoryStream ms = new MemoryStream();
                        ser.Serialize(ms, ex);
                        ms.Seek(0, SeekOrigin.Begin);
                        details.Add(XElement.Load(XmlReader.Create(ms)));
                    }

                    if (!ex.GetType().Equals(typeof(ManagedException)))
                    {
                        //TASK: Allineamento log - Ciro
                        ManagedException mEx = new ManagedException(String.Format("Errore: {0}", ex.Message),
                                                                    "SND_ERR_107",
                                                                    string.Empty,
                                                                    string.Empty,
                                                                    ex.InnerException);
                        mEx.addEnanchedInfosTag("REQUEST", new XElement("Mail",
                                                                        new XAttribute("IdMail", comun.IdComunicazione)).ToString());
                        ErrorLogInfo err = new ErrorLogInfo(mEx);
                        err.objectID = (comun.UniqueId != null) ? comun.UniqueId : comun.IdComunicazione.ToString();
                        _log.Error(err);
                    }
                    nuovoFlusso.StatoComunicazioneNew = MailStatus.SEND_AGAIN;
                    UpdateFlusso(comun);
                }
            }
        }