Exemple #1
0
        public async Task <IActionResult> Edit(int id, [Bind("Id,Title,Description,CreatedBy,CreatedAt,UpdatedBy,UpdatedAt")] Role role)
        {
            if (id != role.Id)
            {
                return(NotFound());
            }

            if (ModelState.IsValid)
            {
                try
                {
                    role.UpdatedAt = DateTime.Now;
                    role.UpdatedBy = userData.GetUser(HttpContext).Id.ToString();
                    _context.Update(role);
                    await _context.SaveChangesAsync();
                }
                catch (DbUpdateConcurrencyException)
                {
                    if (!RoleExists(role.Id))
                    {
                        return(NotFound());
                    }
                    else
                    {
                        throw;
                    }
                }
                return(RedirectToAction(nameof(Index)));
            }
            return(View(role));
        }
        public ActionResult RecoverPassword([FromBody] UserLoginDTO userLoginDTO, [FromQuery] string code)
        {
            User user = db.Users.Include(x => x.ProfilePhotos).Where(s => s.Email == userLoginDTO.Email && s.IsDeleted == false).FirstOrDefault();

            if (user == null)
            {
                return(Json(new { statusCode = ResponseStatus.ValidationError, responseMessage = ValidationMessages.EmailNotExsist }));
            }
            if (user.RecoveryCode.ToString() != code)
            {
                return(Json(new { statusCode = ResponseStatus.ValidationError, responseMessage = ValidationMessages.WrongCode }));
            }
            if (userLoginDTO.Password.Length < 5)
            {
                return(Json(new { statusCode = ResponseStatus.ValidationError, responseMessage = ValidationMessages.ShortPassword }));
            }
            user.Password     = Encription.Encrypt(userLoginDTO.Password, "SecretCode_hamed");
            user.RecoveryCode = null;
            db.Update(user);
            db.SaveChanges();
            userData.SetUser(HttpContext, user);
            return(Json(new { statusCode = ResponseStatus.Success }));
        }