Exemple #1
0
        public async Task <UserLoginReturn> Login(LoginInfoResources loginInfoResources)
        {
            var responseMessage = await _httpClientService.SendHttpPostRequest(loginInfoResources, "users/login");

            if (string.IsNullOrEmpty(responseMessage))
            {
                return(null);
            }

            var UserData = JsonConvert.DeserializeObject <UserLoginReturn>(responseMessage);



            return(UserData);
        }
Exemple #2
0
        public async Task <IActionResult> Login(LoginInfoResources loginInfoResources)
        {
            try
            {
                if (!ModelState.IsValid)
                {
                    return(View(loginInfoResources));
                }
                else
                {
                    var userInfo = await _accountService.Login(loginInfoResources);

                    if (userInfo == null)
                    {
                        ViewBag.userFounded    = false;
                        ViewBag.userAuthorized = false;
                        return(View());
                    }

                    if (userInfo.RoleName.Equals("Hospital"))
                    {
                        var recieptionistData = await _recieptionistService.GetRecieptionistFullData(userInfo.Id);

                        TempData["recieptionistData"] = JsonConvert.SerializeObject(recieptionistData);
                        TempData.Keep();

                        _session.SetString(Email, userInfo.Email);
                        _session.SetString(UserId, userInfo.Id.ToString());
                        _session.SetString(RoleName, userInfo.RoleName);
                        _session.SetString(Hospital, recieptionistData.HospitalData.HospitalData.Id.ToString());


                        User.AddIdentity(new System.Security.Claims.ClaimsIdentity
                        {
                            Label = _session.GetString(Email)
                        });



                        ViewBag.userEmail = userInfo.Email;
                        return(RedirectToAction("Index", "Home"));
                    }
                    else if (userInfo.RoleName.Equals("Authority"))
                    {
                        var authorityData = await _authorityService.AuthorityFullData(userInfo.Id);

                        TempData["authorityData"] = JsonConvert.SerializeObject(authorityData);
                        TempData.Keep();

                        _session.SetString(Email, userInfo.Email);
                        _session.SetString(UserId, userInfo.Id.ToString());
                        _session.SetString(RoleName, userInfo.RoleName);
                        _session.SetString(Authority, authorityData.AuthorityFullData.Id.ToString());

                        ViewBag.userEmail = userInfo.Email;
                        return(RedirectToAction("Index", "Home"));
                    }
                    else
                    {
                        ViewBag.userFounded    = true;
                        ViewBag.userAuthorized = false;
                        return(View());
                    }
                }
            }

            catch
            {
                ViewBag.userFounded    = true;
                ViewBag.userAuthorized = false;
                return(View());
            }
        }