| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using System.Web.Mvc;
- using GreenTree.Nachtragsmanagement.Core.Authentication;
- using GreenTree.Nachtragsmanagement.Services.User;
- using GreenTree.Nachtragsmanagement.Web.Models.Admin.User;
- using GreenTree.Nachtragsmanagement.Core.Domain.User;
- using Newtonsoft.Json;
- using GreenTree.Nachtragsmanagement.Core;
- namespace GreenTree.Nachtragsmanagement.Web.Controllers
- {
- public class AdminController : Controller
- {
- private readonly IUserService _userService;
- private readonly IUserHelper _userHelper;
- public AdminController(
- IUserService userService,
- IUserHelper userHelper)
- {
- _userService = userService;
- _userHelper = userHelper;
- ViewData["AllRoles"] = _userService.GetAllRoles();
- }
- #region Users
- /// <summary>
- /// Basic user view function
- /// </summary>
- public ActionResult ViewUsers()
- {
- var users = _userService.GetAllUsers();
- var userModels = users
- .Select(u => UserDataModel.FromUser(u, false))
- .ToList();
- return View("~/Views/Admin/Users/View.cshtml", userModels);
- }
- /// <summary>
- /// Get JSON data of specific user
- /// </summary>
- /// <param name="id">User id.</param>
- public ActionResult GetUser(int id = -1)
- {
- var user = _userService.GetUserById(id);
- if (user == null)
- return new JsonResult
- {
- Data = "notFound",
- JsonRequestBehavior = JsonRequestBehavior.AllowGet
- };
- var userModel = UserDataModel.FromUser(user, false);
- return new JsonResult
- {
- Data = JsonConvert.SerializeObject(userModel),
- JsonRequestBehavior = JsonRequestBehavior.AllowGet
- };
- }
- /// <summary>
- /// Callback result for user grid
- /// </summary>
- public ActionResult PartialUsers()
- {
- var users = _userService.GetAllUsers();
- var userModels = users
- .Select(u => UserDataModel.FromUser(u, false))
- .ToList();
- return PartialView("~/Views/Admin/Users/_UserGridPartial.cshtml", userModels);
- }
- /// <summary>
- /// Partial edit for editing of existing or for new user
- /// </summary>
- /// <param name="id">Id for existing user, otherweise -1.</param>
- public ActionResult EditUser(int id = -1)
- {
- var user = _userService.GetUserById(id);
- var userModel = UserDataModel.FromUser(user, true);
- return PartialView("~/Views/Admin/Users/_UserEditPartial.cshtml", userModel);
- }
- /// <summary>
- /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
- /// </summary>
- /// <param name="userModel">User model to be saved.</param>
- [HttpPost, ValidateInput(false)]
- public ActionResult EditUser(UserDataModel userModel)
- {
- if (!ModelState.IsValid)
- {
- foreach (var role in userModel.RoleValues)
- userModel.RoleDescriptions.Add(
- ((IList<Role>)ViewData["AllRoles"])
- .First(r => r.Id == role).Description);
- return PartialView("~/Views/Admin/Users/_UserEditPartial.cshtml", userModel);
- }
- var selectedRoles = _userService.GetRolesByIds(userModel.RoleValues.ToArray());
- if (userModel.Id == -1)
- {
- var user = userModel.ToUser();
- user.SetRoles(selectedRoles);
- user.Password = StaticHelper.GetMD5Hash(userModel.Password);
- _userService.InsertUser(user);
- }
- else
- {
- var user = _userService.GetUserById(userModel.Id);
- user.CustomNumber = userModel.CustomerNumber;
- user.Forename = userModel.Forename;
- user.Lastname = userModel.Lastname;
- user.MailAddress = userModel.MailAddress;
- if (!String.IsNullOrEmpty(userModel.Password))
- user.Password = StaticHelper.GetMD5Hash(userModel.Password);
- user.SetRoles(selectedRoles);
- _userService.UpdateUser(user);
- }
- return new JsonResult
- {
- Data = "success"
- };
- }
- /// <summary>
- /// Simple JSON result for deleting a specific user
- /// </summary>
- /// <param name="id">User id.</param>
- [HttpPost]
- public ActionResult DeleteUser(int id)
- {
- var user = _userService.GetUserById(id);
- if (user != null)
- _userService.DeleteUser(user);
- return new JsonResult
- {
- Data = "success"
- };
- }
- #endregion
- #region Roles
- /// <summary>
- /// Basic role view function
- /// </summary>
- public ActionResult ViewRoles()
- {
- return View("~/Views/Admin/Roles/View.cshtml");
- }
- #endregion
- #region Plugins
- /// <summary>
- /// Basic plugin view function
- /// </summary>
- public ActionResult ViewPlugins()
- {
- return View("~/Views/Admin/Plugins/View.cshtml");
- }
- #endregion
- }
- }
|