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]")] [ApiController] public class UsersController : ControllerBase { /// /// /// /// /// [HttpGet] public QueryData Get([FromQuery]QueryUserOption value) { return value.RetrieveData(); } /// /// /// /// /// /// [HttpPost("{id}")] public IEnumerable Post(string id, [FromQuery]string type) { IEnumerable ret = null; switch (type) { case "role": ret = UserHelper.RetrievesByRoleId(id).Select(p => new { p.Id, p.DisplayName, p.UserName, p.Checked }); break; case "group": ret = UserHelper.RetrievesByGroupId(id); break; case "reset": ret = UserHelper.RetrieveResetReasonsByUserName(id).Select(u => new { u.Key, u.Value }); break; } return ret; } /// /// 前台User View调用,新建/更新用户 /// /// [HttpPost] [ButtonAuthorize(Url = "~/Admin/Users", Auth = "add,edit")] public bool Post([FromBody]User value) { var ret = false; if (string.IsNullOrEmpty(value.Id)) { value.Description = string.Format("管理员{0}创建用户", User.Identity.Name); value.ApprovedBy = User.Identity.Name; value.ApprovedTime = DateTime.Now; ret = UserHelper.Save(value); } else { ret = UserHelper.Update(value.Id, value.Password, value.DisplayName); } return ret; } /// /// /// /// /// /// /// [HttpPut("{id}")] [ButtonAuthorize(Url = "~/Admin/Users", Auth = "assignRole,assignGroup")] public bool Put(string id, [FromBody]IEnumerable values, [FromQuery]string type) { var ret = false; switch (type) { case "role": ret = RoleHelper.SaveByUserId(id, values); break; case "group": ret = GroupHelper.SaveByUserId(id, values); break; } return ret; } /// /// /// /// [HttpDelete] [ButtonAuthorize(Url = "~/Admin/Users", Auth = "del")] public bool Delete([FromBody]IEnumerable value) { return UserHelper.Delete(value); } /// /// /// /// [AllowAnonymous] [HttpOptions] public string Options() { return null; } } }