diff options
| author | Avi Levkovich <avi@twine-s.com> | 2019-02-26 17:36:05 +0200 |
|---|---|---|
| committer | Avi Levkovich <avi@twine-s.com> | 2019-02-26 17:36:05 +0200 |
| commit | 4eb8307f3cf9b24ddbed2958e3c0a9115a07d5d4 (patch) | |
| tree | 6b7bc4ce6456ab7dc0247ecd1d351c8fe1f80488 /Software/Visual_Studio/Web/Tango.MachineService/Controllers/AccountController.cs | |
| parent | eea8c70b9c076f4ff70283c0ce21908d18d46244 (diff) | |
| parent | 6f62fafb2ef10b11189e9474ab13f531e614cf49 (diff) | |
| download | Tango-4eb8307f3cf9b24ddbed2958e3c0a9115a07d5d4.tar.gz Tango-4eb8307f3cf9b24ddbed2958e3c0a9115a07d5d4.zip | |
Merge branch 'master' of https://twinetfs.visualstudio.com/_git/Tango
Diffstat (limited to 'Software/Visual_Studio/Web/Tango.MachineService/Controllers/AccountController.cs')
| -rw-r--r-- | Software/Visual_Studio/Web/Tango.MachineService/Controllers/AccountController.cs | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Web/Tango.MachineService/Controllers/AccountController.cs b/Software/Visual_Studio/Web/Tango.MachineService/Controllers/AccountController.cs new file mode 100644 index 000000000..0a395b00e --- /dev/null +++ b/Software/Visual_Studio/Web/Tango.MachineService/Controllers/AccountController.cs @@ -0,0 +1,57 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Net; +using System.Security.Authentication; +using System.Web; +using System.Web.Mvc; +using System.Web.Security; +using Tango.BL; +using Tango.MachineService.Models; +using Tango.Web.ActiveDirectory; +using Tango.Web.Helpers; + +namespace Tango.MachineService.Controllers +{ + public class AccountController : Controller + { + private ActiveDirectoryManager _ad_manager; + + public AccountController() + { + _ad_manager = new ActiveDirectoryManager(); + } + + public ActionResult Login() + { + if (HttpContext.User.Identity.IsAuthenticated) + { + return RedirectToAction("Index", "Downloads", null); + } + + return View(); + } + + [HttpPost] + public ActionResult Login(AccountLogin request) + { + var authResult = _ad_manager.ValidateUserCredentials(request.Email, request.Password); + + if (!_ad_manager.CanUserAccessCurrentEnvironment(request.Email)) + { + throw new AuthenticationException($"You do not have permissions to access the {MachineServiceConfig.DEPLOYMENT_SLOT.ToDescription()} environment."); + } + + + FormsAuthentication.SetAuthCookie(request.Email, true); + return new HttpStatusCodeResult(HttpStatusCode.OK); + } + + [Authorize] + public ActionResult Logout() + { + FormsAuthentication.SignOut(); + return Login(); + } + } +}
\ No newline at end of file |
