2019-03-22 15:46:32 +08:00
|
|
|
|
using Bootstrap.Admin.Query;
|
2018-06-07 00:45:47 +08:00
|
|
|
|
using Bootstrap.DataAccess;
|
|
|
|
|
using Longbow.Web.Mvc;
|
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace Bootstrap.Admin.Controllers.Api
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
[Route("api/[controller]")]
|
2018-11-24 15:12:44 +08:00
|
|
|
|
[ApiController]
|
|
|
|
|
public class RolesController : ControllerBase
|
2018-06-07 00:45:47 +08:00
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="value"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
[HttpGet]
|
2018-11-24 15:12:44 +08:00
|
|
|
|
public QueryData<object> Get([FromQuery]QueryRoleOption value)
|
2018-06-07 00:45:47 +08:00
|
|
|
|
{
|
|
|
|
|
return value.RetrieveData();
|
|
|
|
|
}
|
|
|
|
|
/// <summary>
|
2018-10-31 17:08:55 +08:00
|
|
|
|
/// 通过指定用户ID/部门ID/菜单ID获得所有角色集合,已经授权的有checked标记
|
2018-06-07 00:45:47 +08:00
|
|
|
|
/// </summary>
|
2018-09-13 19:21:35 +08:00
|
|
|
|
/// <param name="id">用户ID/部门ID/菜单ID</param>
|
|
|
|
|
/// <param name="type">类型</param>
|
2018-06-07 00:45:47 +08:00
|
|
|
|
/// <returns></returns>
|
|
|
|
|
[HttpPost("{id}")]
|
2018-10-31 17:08:55 +08:00
|
|
|
|
public IEnumerable<object> Post(string id, [FromQuery]string type)
|
2018-06-07 00:45:47 +08:00
|
|
|
|
{
|
2018-10-31 17:08:55 +08:00
|
|
|
|
IEnumerable<Role> ret = new List<Role>();
|
2018-09-13 19:21:35 +08:00
|
|
|
|
switch (type)
|
2018-06-07 00:45:47 +08:00
|
|
|
|
{
|
|
|
|
|
case "user":
|
2019-01-11 23:20:28 +08:00
|
|
|
|
ret = RoleHelper.RetrievesByUserId(id);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
break;
|
|
|
|
|
case "group":
|
2019-01-11 23:20:28 +08:00
|
|
|
|
ret = RoleHelper.RetrievesByGroupId(id);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
break;
|
|
|
|
|
case "menu":
|
2019-01-11 23:20:28 +08:00
|
|
|
|
ret = RoleHelper.RetrievesByMenuId(id);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
2018-10-31 17:08:55 +08:00
|
|
|
|
return ret.Select(m => new { m.Id, m.Checked, m.RoleName, m.Description });
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
2018-09-13 19:21:35 +08:00
|
|
|
|
/// <summary>
|
2018-10-31 17:08:55 +08:00
|
|
|
|
/// 保存角色
|
2018-06-07 00:45:47 +08:00
|
|
|
|
/// </summary>
|
2019-03-22 15:46:32 +08:00
|
|
|
|
/// <param name="id">角色ID</param>
|
|
|
|
|
/// <param name="values">选中的ID集合</param>
|
2018-10-31 17:08:55 +08:00
|
|
|
|
/// <param name="type">type=menu时,菜单维护页面对角色授权弹框保存按钮调用</param>
|
2018-06-07 00:45:47 +08:00
|
|
|
|
/// <returns></returns>
|
|
|
|
|
[HttpPut("{id}")]
|
2019-03-22 15:46:32 +08:00
|
|
|
|
[ButtonAuthorize(Url = "~/Admin/Roles", Auth = "assignUser,assignGroup,assignMenu,assignApp")]
|
|
|
|
|
public bool Put(string id, [FromBody]IEnumerable<string> values, [FromQuery]string type)
|
2018-06-07 00:45:47 +08:00
|
|
|
|
{
|
|
|
|
|
var ret = false;
|
2018-09-13 19:21:35 +08:00
|
|
|
|
switch (type)
|
2018-06-07 00:45:47 +08:00
|
|
|
|
{
|
|
|
|
|
case "user":
|
2019-03-22 15:46:32 +08:00
|
|
|
|
ret = UserHelper.SaveByRoleId(id, values);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
break;
|
|
|
|
|
case "group":
|
2019-03-22 15:46:32 +08:00
|
|
|
|
ret = GroupHelper.SaveByRoleId(id, values);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
break;
|
|
|
|
|
case "menu":
|
2019-03-22 15:46:32 +08:00
|
|
|
|
ret = MenuHelper.SaveMenusByRoleId(id, values);
|
|
|
|
|
break;
|
|
|
|
|
case "app":
|
|
|
|
|
ret = AppHelper.SaveByRoleId(id, values);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="value"></param>
|
|
|
|
|
[HttpPost]
|
2019-03-22 15:46:32 +08:00
|
|
|
|
[ButtonAuthorize(Url = "~/Admin/Roles", Auth = "add,edit")]
|
2018-06-07 14:39:45 +08:00
|
|
|
|
public bool Post([FromBody]Role value)
|
2018-06-07 00:45:47 +08:00
|
|
|
|
{
|
2019-01-11 23:20:28 +08:00
|
|
|
|
return RoleHelper.Save(value);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="value"></param>
|
|
|
|
|
[HttpDelete]
|
2019-03-22 15:46:32 +08:00
|
|
|
|
[ButtonAuthorize(Url = "~/Admin/Roles", Auth = "del")]
|
2018-10-30 13:07:29 +08:00
|
|
|
|
public bool Delete([FromBody]IEnumerable<string> value)
|
2018-06-07 00:45:47 +08:00
|
|
|
|
{
|
2019-01-11 23:20:28 +08:00
|
|
|
|
return RoleHelper.Delete(value);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|