aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Web/Tango.MachineService/Controllers/AccountController.cs
diff options
context:
space:
mode:
authorAvi Levkovich <avi@twine-s.com>2019-02-26 17:36:05 +0200
committerAvi Levkovich <avi@twine-s.com>2019-02-26 17:36:05 +0200
commit4eb8307f3cf9b24ddbed2958e3c0a9115a07d5d4 (patch)
tree6b7bc4ce6456ab7dc0247ecd1d351c8fe1f80488 /Software/Visual_Studio/Web/Tango.MachineService/Controllers/AccountController.cs
parenteea8c70b9c076f4ff70283c0ce21908d18d46244 (diff)
parent6f62fafb2ef10b11189e9474ab13f531e614cf49 (diff)
downloadTango-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.cs57
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