public ActionResult Login(AccountModel Account) { try { if (ModelState.IsValid) { if (MvcApplication.ObjVersion.NumeroDeVersion.Contains("Demo")) { MoSesion.Demo = true; } else { MoSesion.Demo = false; } Account.IP = ClsAdicional.ClsGetHostNameAndIP.GetIPv4Address(Request.UserHostAddress); Account.Terminal = ClsAdicional.ClsGetHostNameAndIP.GetHostName(Request.UserHostAddress); ViewData["Informacion"] = String.Empty; List <ClsUsuarios> lstUsuario = (from q in ClsUsuarios.getList() where q.NombreDeUsuario == Account.NombreDeUsuario && MoCifrado.Descifrado(q.PasswordUsuario) == Account.Password && q.CveDeEstatus == 1 select q).ToList(); if (lstUsuario.Count == 1) { if (!MoSesion.Demo) { List <ClsParametros> ParametroV = (from q in ClsParametros.getList() where q.NombreDeParametro == "FechaVencimientoKuup" select q).ToList(); if (ParametroV.Count() != 0) { if (DateTime.Now.ToString("yyyy-MM-dd") == ParametroV.FirstOrDefault().ValorDeParametro) { return(RedirectToAction("Vencimiento", "Account", new { lstUsuario.FirstOrDefault().NumeroDeUsuario })); } } } List <ClsParametros> Parametro = (from q in ClsParametros.getList() where q.NombreDeParametro == "ValidaIP" select q).ToList(); if (Parametro.Count() == 1) { List <ClsIPRegistradas> lstIPRegistrada = (from q in ClsIPRegistradas.getList() where q.NumeroDeUsuario == lstUsuario.FirstOrDefault().NumeroDeUsuario&& q.Terminal.ToUpper() == Account.Terminal.ToUpper() && q.IP == Account.IP select q).ToList(); if (Parametro.FirstOrDefault().ValorDeParametro == "SI") { if (lstIPRegistrada.Count == 1) { List <ClsUsuariosPerfil> lstUsuarioPerfil = (from q in ClsUsuariosPerfil.getList() where q.NumeroDeUsuario == lstUsuario.FirstOrDefault().NumeroDeUsuario select q).ToList(); if (lstUsuarioPerfil.Count == 1) { MoSesion.NumeroDeUsuario = lstUsuario.FirstOrDefault().NumeroDeUsuario; MoSesion.NombreDeUsuario = lstUsuario.FirstOrDefault().NombreDeUsuario; MoSesion.NombreDePersona = lstUsuario.FirstOrDefault().NombreDePersona; MoSesion.ApellidoPaterno = lstUsuario.FirstOrDefault().ApellidoPaterno; MoSesion.ApellidoMaterno = lstUsuario.FirstOrDefault().ApellidoMaterno; MoSesion.IPDeUsuario = lstIPRegistrada.FirstOrDefault().IP; MoSesion.TerminalDeUsuario = lstIPRegistrada.FirstOrDefault().Terminal; MoSesion.CveTipoDeAcceso = lstIPRegistrada.FirstOrDefault().CveTipoDeAcceso; MoSesion.TextoTipoDeAccedo = lstIPRegistrada.FirstOrDefault().TextoTipoDeAccedo; MoSesion.NumeroDePerfil = lstUsuarioPerfil.FirstOrDefault().NumeroDePerfil; MoSesion.NombreDePerfil = lstUsuarioPerfil.FirstOrDefault().NombreDePerfil; MoSesion.Browser = Request.Browser.Browser + " " + Request.Browser.Version; if (!MvcApplication.ListaDeSesionesActivas.ContainsKey(MoSesion.IDSesion)) { MvcApplication.ListaDeSesionesActivas.Add(MoSesion.IDSesion, new SesionActiva() { NumeroDeUsuario = MoSesion.NumeroDeUsuario, NumeroDePerfil = MoSesion.NumeroDePerfil, Deslogueado = false }); } return(RedirectToAction("Index", "Home")); } else { ViewData["Informacion"] = Recursos.Textos.Account_ValidaPerfil; } } else { ViewData["Informacion"] = String.Format(Recursos.Textos.Account_ValidaEquipo, Account.Terminal, Account.IP); } } else { lstIPRegistrada = new List <ClsIPRegistradas>(); ClsIPRegistradas Ips = new ClsIPRegistradas { IP = Account.IP, Terminal = Account.Terminal, CveTipoDeAcceso = 1 }; List <ClsUsuariosPerfil> lstUsuarioPerfil = (from q in ClsUsuariosPerfil.getList() where q.NumeroDeUsuario == lstUsuario.FirstOrDefault().NumeroDeUsuario select q).ToList(); if (lstUsuarioPerfil.Count == 1) { MoSesion.NumeroDeUsuario = lstUsuario.FirstOrDefault().NumeroDeUsuario; Ips.NumeroDeUsuario = MoSesion.NumeroDeUsuario; lstIPRegistrada.Add(Ips); MoSesion.NombreDeUsuario = lstUsuario.FirstOrDefault().NombreDeUsuario; MoSesion.NombreDePersona = lstUsuario.FirstOrDefault().NombreDePersona; MoSesion.ApellidoPaterno = lstUsuario.FirstOrDefault().ApellidoPaterno; MoSesion.ApellidoMaterno = lstUsuario.FirstOrDefault().ApellidoMaterno; MoSesion.IPDeUsuario = lstIPRegistrada.FirstOrDefault().IP; MoSesion.TerminalDeUsuario = lstIPRegistrada.FirstOrDefault().Terminal; MoSesion.CveTipoDeAcceso = lstIPRegistrada.FirstOrDefault().CveTipoDeAcceso; MoSesion.TextoTipoDeAccedo = lstIPRegistrada.FirstOrDefault().TextoTipoDeAccedo; MoSesion.NumeroDePerfil = lstUsuarioPerfil.FirstOrDefault().NumeroDePerfil; MoSesion.NombreDePerfil = lstUsuarioPerfil.FirstOrDefault().NombreDePerfil; MoSesion.Browser = Request.Browser.Browser + " " + Request.Browser.Version; if (!MvcApplication.ListaDeSesionesActivas.ContainsKey(MoSesion.IDSesion)) { MvcApplication.ListaDeSesionesActivas.Add(MoSesion.IDSesion, new SesionActiva() { NumeroDeUsuario = MoSesion.NumeroDeUsuario, NumeroDePerfil = MoSesion.NumeroDePerfil, Deslogueado = false }); } return(RedirectToAction("Index", "Home")); } else { ViewData["Informacion"] = Recursos.Textos.Account_ValidaPerfil; } } } } else { ViewData["Informacion"] = Recursos.Textos.Account_ValidaUsuarioContraseña; } } } catch (Exception e) { ViewData["Informacion"] = Recursos.Textos.Bitacora_TextoTryCatchGenerico; ClsBitacora.GeneraBitacora(NumeroDePantalla, 1, "Login", String.Format(Recursos.Textos.Bitacora_TextoDeError, e.GetType().ToString(), e.Message.Trim(), e.GetHashCode().ToString())); MoSesion.LimpiaSesion(); } return(View()); }
public ActionResult Contacto(Contacto Registro) { if (ModelState.IsValid) { ClsAdicional.ClsResultado Resultado = new ClsAdicional.ClsResultado(true, String.Empty); List <ClsParametros> Parametro = (from q in ClsParametros.getList() where q.CveTipo == 3 select q).ToList(); ClsAdicional.EnvioDeCorreos envio = new ClsAdicional.EnvioDeCorreos(Parametro.Where(x => x.NombreDeParametro == "CorreosContacto").Select(y => y.ValorDeParametro).FirstOrDefault(), Registro.Asunto, Registro.Mensaje); String ContenidoPlantilla = envio.PlantillaHtml("EnvioKuup.html"); if (!String.IsNullOrEmpty(ContenidoPlantilla)) { ContenidoPlantilla = ContenidoPlantilla.Replace("#Contenido#", Registro.Mensaje); ContenidoPlantilla = ContenidoPlantilla.Replace("#DeclaratoriaFooter#", Parametro.Where(x => x.NombreDeParametro == "DeclaratoriaFooter").Select(y => y.Descripcion).FirstOrDefault()); ContenidoPlantilla = ContenidoPlantilla.Replace("#DireccionWebEmpresa#", Parametro.Where(x => x.NombreDeParametro == "DireccionWebEmpresa").Select(y => y.ValorDeParametro).FirstOrDefault()); ContenidoPlantilla = ContenidoPlantilla.Replace("#NombreDeLaEmpresa#", Parametro.Where(x => x.NombreDeParametro == "NombreDeLaEmpresa").Select(y => y.ValorDeParametro).FirstOrDefault()); ContenidoPlantilla = ContenidoPlantilla.Replace("#RutaDeLogoParaReportes#", Parametro.Where(x => x.NombreDeParametro == "RutaDeLogoParaReportes").Select(y => y.ValorDeParametro).FirstOrDefault()); envio.Mensaje = ContenidoPlantilla; } Dictionary <String, String> imagen = new Dictionary <string, string>(); imagen.Add("RutaDeLogoParaReportes", Server.MapPath("~/Content/Imagenes/Kuup/Firma correo.png")); Resultado = envio.EnviarCorreo(imagen); if (Resultado.Resultado) { ClsUsuarios usuario = new ClsUsuarios(); usuario.NombreDeUsuario = usuario.UsuarioParaDemo();//Registro.ApellidoPaterno.ToCharArray()[0].ToString().ToUpper() + Registro.Nombre.Split(' ')[0].ToUpper(); usuario.NombreDePersona = Registro.Nombre.Trim(); usuario.ApellidoPaterno = Registro.ApellidoPaterno.Trim(); usuario.ApellidoMaterno = Registro.ApellidoMaterno.Trim(); usuario.CorreoDeUsuario = Registro.Correo.Trim(); usuario.FechaDeRegistro = DateTime.Now; usuario.PasswordUsuario = MoCifrado.Cifrado(Registro.Nombre.Trim().ToCharArray()[0].ToString().ToUpper() + Registro.ApellidoPaterno.Trim().ToCharArray()[0].ToString().ToUpper() + Registro.ApellidoPaterno.Trim().Substring(1, Registro.ApellidoPaterno.Trim().Length - 1) + "001"); usuario.CveDeEstatus = 1; if (usuario.Insert()) { byte PerfilDemo = (from q in ClsPerfiles.getList() where q.NombreDePerfil.ToUpper() == "DEMO" select q.NumeroDePerfil).FirstOrDefault(); ClsUsuariosPerfil AsignaPerfil = new ClsUsuariosPerfil() { NumeroDePerfil = PerfilDemo, NumeroDeUsuario = usuario.NumeroDeUsuario, CveDeEstatus = 1 }; if (AsignaPerfil.Insert()) { envio = new ClsAdicional.EnvioDeCorreos(Registro.Correo, Registro.Asunto, Registro.Mensaje); ContenidoPlantilla = envio.PlantillaHtml("EnvioKuup.html"); if (!String.IsNullOrEmpty(ContenidoPlantilla)) { ContenidoPlantilla = ContenidoPlantilla.Replace("#Contenido#", String.Format(Parametro.Where(x => x.NombreDeParametro == "MensajeParaUsuario").Select(y => y.Descripcion).FirstOrDefault(), usuario.NombreDeUsuario, MoCifrado.Descifrado(usuario.PasswordUsuario))); ContenidoPlantilla = ContenidoPlantilla.Replace("#DeclaratoriaFooter#", Parametro.Where(x => x.NombreDeParametro == "DeclaratoriaFooter").Select(y => y.Descripcion).FirstOrDefault()); ContenidoPlantilla = ContenidoPlantilla.Replace("#DireccionWebEmpresa#", Parametro.Where(x => x.NombreDeParametro == "DireccionWebEmpresa").Select(y => y.ValorDeParametro).FirstOrDefault()); ContenidoPlantilla = ContenidoPlantilla.Replace("#NombreDeLaEmpresa#", Parametro.Where(x => x.NombreDeParametro == "NombreDeLaEmpresa").Select(y => y.ValorDeParametro).FirstOrDefault()); ContenidoPlantilla = ContenidoPlantilla.Replace("#RutaDeLogoParaReportes#", Parametro.Where(x => x.NombreDeParametro == "RutaDeLogoParaReportes").Select(y => y.ValorDeParametro).FirstOrDefault()); envio.Mensaje = ContenidoPlantilla; } imagen = new Dictionary <string, string>(); imagen.Add("RutaDeLogoParaReportes", Server.MapPath("~/Content/Imagenes/Kuup/Firma correo.png")); Resultado = envio.EnviarCorreo(imagen); if (Resultado.Resultado) { ViewData["Informacion"] = "Se le ha enviado usuario y contraseña para el acceso a la Demo"; return(View("EnvioDeSolicitud")); } else { ViewData["Informacion"] = "No fue posible realizar el envió de usuario y contraseña para su acceso a la Demo"; } } } } if (!Resultado.Resultado) { ClsBitacora.GeneraBitacora(NumeroDePantalla, 1, "EnviorCorreo", Resultado.Mensaje); } } else { ViewData["Informacion"] = "Los registros no son válidos para la solicitud"; } return(View(Registro)); }