public DatiCondomini Get([FromUri] SearchCriteria json) { var service = new SferaService(); var info = new UserInfo(0, json.Azienda); var rate = service.GetRateByPersonaCondominio(json.Condominio, json.Persona, info).Where(item => item.ImportoRata > 0).ToList(); var ratePerEsercizi = rate.OrderBy(item => item.DataScadenza).GroupBy(item => item.IdEsercizio); var esercizi = ratePerEsercizi.Select(kvp => new EsercizioDTO {ID = kvp.Key, Descrizione = kvp.ToList()[0].DescrizioneEsercizio}).ToList(); var soggetti = service.GetSoggettiByPersona(json.Persona, info); var saldiSoggetto = new List<SaldoSoggettoVersamentoDTO>(); foreach (var esercizioDTO in esercizi) { var importoRata = 0m; var importoVersamento = 0m; foreach (var soggettoCondominioDTO in soggetti) { var rateVersamenti = service.GetVersatoBySoggetto(esercizioDTO.ID, soggettoCondominioDTO.ID, DateTime.Today, info); importoRata += rateVersamenti.Sum(item => item.Importo.GetValueOrDefault()); importoVersamento += rateVersamenti.Sum(item => item.ImportoPagato.GetValueOrDefault()); } saldiSoggetto.Add(new SaldoSoggettoVersamentoDTO { IdEsercizio = esercizioDTO.ID, ImportoRate = importoRata, ImportoVersamenti = importoVersamento }); } return new DatiCondomini { Esercizi = esercizi, Rate = rate, SaldiSoggetto = saldiSoggetto}; }
public static PersonaCondomini AuthenticateUser(string user, string password, int azienda) { var log = LogManager.GetLogger("Sfera"); try { var service = new SferaService(); var info = new UserInfo(0, azienda); var result = new PersonaCondomini(); decimal codiceFiscale; var isCodiceFiscale = decimal.TryParse(password, out codiceFiscale); if (!isCodiceFiscale) { result.TipoAutenticazione = "SOGGETTO"; var persona = service.VerificaUtentePersona(user, password, info); if (persona != null) { HttpContext.Current.Session.Add("utente", persona); var soggetti = service.GetSoggettiByPersona(persona.ID, info); if (soggetti.Count == 1) { var soggetto = soggetti.SingleOrDefault(); if (soggetto != null) { result.NumeroCondomini = 1; result.Persona = persona; result.Condomini = new Dictionary<string, string> { { soggetto.IdCondominio.ToString(), soggetto.DescrizioneUnitaImmobiliare } }; // Contatti result.Contatti = getContatti(persona); HttpContext.Current.Session.Add("azienda", azienda); HttpContext.Current.Session.Add("condomino", soggetto); HttpContext.Current.Session.Add("condominio", soggetto.IdCondominio); log.Info("Utente autenticato - " + Utility.GetMethodDescription() + " - username:"******"azienda", azienda); HttpContext.Current.Session.Add("condomino", soggetto); HttpContext.Current.Session.Add("condominio", soggetto.IdCondominio); } } } } else { result.TipoAutenticazione = "CONDOMINIO"; var condominio = service.AutenticazioneCondominio(user, password, info); if (condominio != null) { HttpContext.Current.Session.Add("azienda", condominio.AziendaID); HttpContext.Current.Session.Add("condominio", condominio.ID); result.Condominio = condominio; } else return new PersonaCondomini { TipoAutenticazione = "FALLITA", ExceptionMessage = "Utente o password non riconosciuti"}; } return result; } catch (Exception ex) { log.ErrorException(string.Format("Autenticazione fallita - user:{0} - password:{1} - azienda:{2}", user, password, azienda), ex); return new PersonaCondomini{TipoAutenticazione = "FALLITA", ExceptionMessage = ex.Message + Environment.NewLine + ex.StackTrace}; } }