示例#1
0
        public ActionResult Recovery(Models.ViewModel.RecoveryPasswordViewModel model)
        {
            try
            {
                if (!ModelState.IsValid)
                {
                    return(View(model));
                }

                using (Models.plataformaEntities db = new Models.plataformaEntities())
                {
                    var oUser = db.usuario.Where(d => d.TokenRecovery == model.token).FirstOrDefault();

                    if (oUser != null)
                    {
                        oUser.Contraseña      = model.Password;
                        oUser.TokenRecovery   = null;
                        db.Entry(oUser).State = System.Data.Entity.EntityState.Modified;
                        db.SaveChanges();
                    }
                }
            }
            catch (Exception ex)
            {
                throw new Exception(ex.Message);
            }
            ViewBag.Message = "Contraseña modificada con exito";
            return(View("Index", "Logueo"));
        }
示例#2
0
        public ActionResult StartRecovery(Models.ViewModel.RecoveryViewModel model)
        {
            try
            {
                if (!ModelState.IsValid)
                {
                    return(View(model));
                }

                string token = GetSha256(Guid.NewGuid().ToString());

                using (Models.plataformaEntities db = new Models.plataformaEntities())
                {
                    var oUser = db.usuario.Where(d => d.Correo == model.Email).FirstOrDefault();
                    if (oUser != null)
                    {
                        oUser.TokenRecovery   = token;
                        db.Entry(oUser).State = System.Data.Entity.EntityState.Modified;
                        db.SaveChanges();

                        //enviamos email
                        SendEmail(oUser.Correo, token);
                    }
                }
                return(View());
            }
            catch (Exception es)
            {
                throw new Exception(es.Message);
            }
        }
示例#3
0
        public ActionResult Recovery(string token)
        {
            Models.ViewModel.RecoveryPasswordViewModel model = new Models.ViewModel.RecoveryPasswordViewModel();
            model.token = token;
            using (Models.plataformaEntities db = new Models.plataformaEntities())
            {
                if (model.token == null || model.token.Trim().Equals(""))
                {
                    return(View("Index", "Logueo"));
                }
                var oUser = db.usuario.Where(d => d.TokenRecovery == model.token).FirstOrDefault();
                if (oUser == null)
                {
                    ViewBag.Error = "Token incorrecto contacte al administrador";
                    return(View("Index", "Logueo"));
                }
            }

            return(View(model));
        }