using Bootstrap.Admin.Query; using Bootstrap.DataAccess; using Longbow.Web.Mvc; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using System; using System.Collections.Generic; using System.Linq; namespace Bootstrap.Admin.Controllers.Api { /// /// /// [Route("api/[controller]")] public class UsersController : Controller { /// /// /// /// /// [HttpGet] public QueryData Get(QueryUserOption value) { return value.RetrieveData(); } /// /// /// /// [HttpPut] public bool Put([FromBody]User value) { if (User.IsInRole("Administrators")) return false; var ret = false; if (value.UserStatus == UserStates.ChangeTheme) { return UserHelper.SaveUserCssByName(value.UserName, value.Css); } if (value.UserName.Equals(User.Identity.Name, System.StringComparison.OrdinalIgnoreCase)) { if (value.UserStatus == UserStates.ChangeDisplayName) ret = UserHelper.SaveDisplayName(value.UserName, value.DisplayName); else if (value.UserStatus == UserStates.ChangePassword) ret = UserHelper.ChangePassword(value.UserName, value.Password, value.NewPassword); } return ret; } /// /// /// /// /// /// [HttpPost("{id}")] public IEnumerable Post(int id, [FromQuery]string type) { var ret = new List(); switch (type) { case "role": ret = UserHelper.RetrieveUsersByRoleId(id).ToList(); break; case "group": ret = UserHelper.RetrieveUsersByGroupId(id).ToList(); break; default: break; } return ret; } /// /// /// /// [HttpPost] public bool Post([FromBody]User value) { var ret = false; if (value.Id == 0) { value.Description = string.Format("管理员{0}创建用户", User.Identity.Name); value.ApprovedBy = User.Identity.Name; ret = UserHelper.SaveUser(value); } else { ret = UserHelper.UpdateUser(value.Id, value.Password, value.DisplayName); } return ret; } /// /// /// /// /// /// /// [HttpPut("{id}")] public bool Put(int id, [FromBody]IEnumerable userIds, [FromQuery]string type) { var ret = false; switch (type) { case "role": ret = UserHelper.SaveUsersByRoleId(id, userIds); break; case "group": ret = UserHelper.SaveUsersByGroupId(id, userIds); break; default: break; } return ret; } /// /// /// /// [HttpDelete] public bool Delete([FromBody]IEnumerable value) { return UserHelper.DeleteUser(value); } /// /// /// /// [AllowAnonymous] [HttpOptions] public string Options() { return null; } } }