using Bootstrap.Admin.Query; using Bootstrap.DataAccess; using Bootstrap.Security; using Longbow.Web.Mvc; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Newtonsoft.Json.Linq; 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 (value.UserStatus == 3) { return UserHelper.SaveUserCssByName(value.UserName, value.Css); } if (value.UserStatus == 9) { // vlaidate userName return BootstrapUser.RetrieveUserByUserName(value.UserName) == null && !UserHelper.RetrieveNewUsers().Any(u => u.UserName == value.UserName); } var ret = false; if (value.UserName.Equals(User.Identity.Name, System.StringComparison.OrdinalIgnoreCase)) { if (value.UserStatus == 1) ret = BootstrapUser.SaveUserInfoByName(value.UserName, value.DisplayName); else if (value.UserStatus == 2) ret = BootstrapUser.ChangePassword(value.UserName, value.Password, value.NewPassword); } return ret; } /// /// /// /// /// /// [HttpPost("{id}")] public IEnumerable Post(int id, [FromBody]JObject value) { var ret = new List(); dynamic json = value; switch ((string)json.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) { value.Description = string.Format("管理员{0}创建用户", User.Identity.Name); value.ApprovedBy = User.Identity.Name; return UserHelper.SaveUser(value); } /// /// /// /// /// /// [HttpPut("{id}")] public bool Put(int id, [FromBody]JObject value) { var ret = false; dynamic json = value; string userIds = json.userIds; switch ((string)json.type) { case "role": ret = UserHelper.SaveUsersByRoleId(id, userIds); break; case "group": ret = UserHelper.SaveUsersByGroupId(id, userIds); break; case "user": // 此时 userIds 存储的信息是操作结果 1 标示同意 0 标示拒绝 var user = new User() { Id = id, UserStatus = 2 }; if (userIds == "1") { user.ApprovedBy = User.Identity.Name; } else { user.RejectedReason = "无原因"; user.RejectedBy = User.Identity.Name; } ret = UserHelper.SaveUser(user); break; default: break; } return ret; } /// /// /// /// [HttpDelete] public bool Delete(string value) { return UserHelper.DeleteUser(value); } /// /// /// /// [AllowAnonymous] [HttpOptions] public string Options() { return null; } } }