GlobalController.cs 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. using GreenTree.Nachtragsmanagement.Core.Authentication;
  2. using GreenTree.Nachtragsmanagement.Services.User;
  3. using GreenTree.Nachtragsmanagement.Web.Models.Global;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Linq;
  7. using System.Web;
  8. using System.Web.Mvc;
  9. namespace GreenTree.Nachtragsmanagement.Web.Controllers
  10. {
  11. public class GlobalController : Controller
  12. {
  13. private readonly IUserHelper _userHelper;
  14. private readonly IUserService _userService;
  15. public GlobalController(
  16. IUserHelper userHelper,
  17. IUserService userService)
  18. {
  19. _userHelper = userHelper;
  20. _userService = userService;
  21. }
  22. /// <summary>
  23. /// Represents the global Footer
  24. /// </summary>
  25. public ActionResult Footer()
  26. {
  27. var cookieUser = _userHelper.FromCookies();
  28. if (cookieUser == null)
  29. return View("~/Views/Shared/_Footer.cshtml", null);
  30. var dbUser = _userService.GetUserById(cookieUser.Id);
  31. if (dbUser == null)
  32. return View("~/Views/Shared/_Footer.cshtml", null);
  33. var footerModel = new FooterModel
  34. {
  35. CustomNumber = dbUser.CustomNumber,
  36. Forename = dbUser.Forename,
  37. Lastname = dbUser.Lastname,
  38. RoleDescription = dbUser.CurrentRole.Description
  39. };
  40. ViewData["Roles"] =
  41. dbUser.Roles
  42. .Select(r => new
  43. {
  44. r.Id,
  45. r.Description
  46. });
  47. return View("~/Views/Shared/_Footer.cshtml", footerModel);
  48. }
  49. /// <summary>
  50. /// Sets the current role of the logged in user and redirects to the home page
  51. /// </summary>
  52. /// <param name="roleId">The id of the new role.</param>
  53. public ActionResult SetRole(int roleId)
  54. {
  55. var user = _userHelper.FromCookies();
  56. var role = _userService.GetRoleById(roleId);
  57. user.CurrentRole = role;
  58. _userHelper.ToCookies(user);
  59. return RedirectToAction("Index", "Home");
  60. }
  61. /// <summary>
  62. /// Shows an unauthorized message
  63. /// </summary>
  64. public ActionResult NotAuthorized()
  65. {
  66. return View("~/Views/Global/NotAuthorized.cshtml");
  67. }
  68. }
  69. }