Beispiel #1
0
 public async Task <ActionResult> Login(LoginModel model)
 {
     try
     {
         IdentityRepository.RemoveUsers(new TimeSpan(0, 30, 0));
         var password = $"{Random.Instance.Next(100000, 1000000)}";
         IdentityRepository.CreateUser(
             new AccountModel {
             AccountName = model.Account, IsActivate = true, Role = ERoles.User
         }, password);
         if (WebSecurity.Login(model.Account, password))
         {
             SystemMessagesRepository.Send($"Пользователь {model.Account} вошел в чат.");
             var result = TempData["ReturnUrl"] != null
                 ? (ActionResult)Redirect((string)TempData["ReturnUrl"])
                 : RedirectToAction("Index", "Home");
             return(await GetAsyncResult(result));
         }
     }
     catch (Exception exception)
     {
         ModelState.AddModelError("", exception.Message);
     }
     return(await GeneratorActionResult("~/Accounts/Login/action.cshtml", new LoginModel()));
 }
Beispiel #2
0
        public async Task <RedirectToRouteResult> Logout()
        {
            var userName = User.Identity.Name;

            WebSecurity.Logout();
            IdentityRepository.DeleteUser(userName);
            var action = RedirectToAction("Index", "Home");

            return(await GetAsyncResult(action));
        }