You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

295 lines
7.9 KiB
C#

using System;
using System.Threading.Tasks;
using Infrastructure;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using OpenAuth.App;
using OpenAuth.App.Request;
using OpenAuth.App.Response;
using OpenAuth.WebApi.Model.CustomAttribute;
namespace OpenAuth.WebApi.Controllers
{
/// <summary>
/// 用户操作
/// </summary>
[Route("api/[controller]/[action]")]
[ApiController]
//[ApiExplorerSettings(GroupName = "用户管理_Users")]
public class UsersController : ControllerBase
{
private readonly UserManagerApp _app;
public UsersController(UserManagerApp app)
{
_app = app;
}
#region 查询
#region 实体
/// <summary>
/// 实体
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpGet]
public Response<UserView> Get(long id)
{
var result = new Response<UserView>();
try
{
result.Result = _app.Get(id);
}
catch (Exception ex)
{
result.Code = 500;
result.Message = ex.InnerException?.Message ?? ex.Message;
}
return result;
}
#endregion
#region 用户列表
/// <summary>
/// 用户列表
/// 根据选中部门及其下子部门过滤Account和Name包含key值的用户列表
/// orgId 为空,查全部 User
/// </summary>
[HttpGet]
[AllData("Users", "LoadAll")]
public async Task<Response<PageInfo<List<dynamic>>>> Load([FromQuery] QueryUserListReq request)
{
return await _app.LoadUsers(request);
}
[HttpGet]
[ApiExplorerSettings(IgnoreApi = true)]
public async Task<Response<PageInfo<List<dynamic>>>> LoadAll([FromQuery] QueryUserListReq request)
{
return await _app.LoadAll(request);
}
#endregion
#region 加载指定角色的用户
/// <summary>
/// 加载指定角色的用户
/// </summary>
[HttpGet]
public async Task<Response<PageInfo<List<UserView>>>> LoadByRole([FromQuery] QueryUserListByRoleReq request)
{
return await _app.LoadByRole(request);
}
#endregion
#region 加载指定部门的用户
/// <summary>
/// 加载指定部门的用户
/// 不包含下级部门的用户
/// </summary>
[HttpGet]
public async Task<TableData> LoadByOrg([FromQuery] QueryUserListByOrgReq request)
{
return await _app.LoadByOrg(request);
}
#endregion
#endregion
#region 修改用户资料
/// <summary>
/// 修改用户资料
/// </summary>
/// <param name="request"></param>
/// <returns></returns>
[HttpPost]
public Response ChangeProfile(ChangeProfileReq request)
{
var result = new Response();
try
{
_app.ChangeProfile(request);
result.Message = "修改成功,重新登录生效";
}
catch (Exception ex)
{
result.Code = 500;
result.Message = ex.InnerException?.Message ?? ex.Message;
}
return result;
}
#endregion
#region 修改密码
/// <summary>
/// 修改密码
/// </summary>
/// <param name="request"></param>
/// <returns></returns>
[HttpPost]
public Response ChangePassword(ChangePasswordReq request)
{
var result = new Response();
try
{
_app.ChangePassword(request);
}
catch (Exception ex)
{
result.Code = 500;
result.Message = ex.InnerException?.Message ?? ex.Message;
}
return result;
}
#endregion
#region 新增/修改
/// <summary>
/// 新增/修改
/// </summary>
/// <param name="obj"></param>
/// <returns></returns>
[HttpPost]
public Response<bool> AddOrUpdate(UpdateUserReq obj)
{
var result = new Response<bool>();
try
{
result = _app.AddOrUpdate(obj);
}
catch (Exception ex)
{
result.Code = 500;
result.Message = ex.InnerException?.Message ?? ex.Message;
}
return result;
}
#endregion
#region 删除
/// <summary>
/// 删除
/// </summary>
/// <param name="ids"></param>
/// <returns></returns>
[HttpPost]
public Response<bool> Delete([FromBody] long[] ids)
{
var result = new Response<bool>();
try
{
result = _app.Delete(ids);
}
catch (Exception ex)
{
result.Code = 500;
result.Message = ex.InnerException?.Message ?? ex.Message;
}
return result;
}
#endregion
#region 为用户分配角色
/// <summary>
/// 为用户分配角色
/// </summary>
/// <param name="userRoles"></param>
/// <returns></returns>
[HttpPost]
public async Task<Response<bool>> UserRoles(AssignUserRoles userRoles)
{
var result = new Response<bool>();
try
{
result = await _app.UserRoles(userRoles);
}
catch (Exception ex)
{
result.Code = 500;
result.Message = ex.InnerException?.Message ?? ex.Message;
}
return result;
}
#endregion
#region 为用户分配部门
/// <summary>
/// 为用户分配部门
/// </summary>
/// <param name="userRoles"></param>
/// <returns></returns>
[HttpPost]
public async Task<Response<bool>> UserOrgs(AssignUserOrgs userOrgs)
{
var result = new Response<bool>();
try
{
result = await _app.UserOrgs(userOrgs);
}
catch (Exception ex)
{
result.Code = 500;
result.Message = ex.InnerException?.Message ?? ex.Message;
}
return result;
}
#endregion
#region 未启用/后台使用
/// <summary>
/// 更新数据库实体类
/// </summary>
[HttpPost]
[AllowAnonymous]
//[ApiExplorerSettings(IgnoreApi = true)]
public Response AddEntity()
{
var result = new Response();
try
{
result.Message = _app.AddEntity();
}
catch (Exception ex)
{
result.Code = 500;
result.Message = ex.InnerException?.Message ?? ex.Message;
}
return result;
}
#endregion
#region user数据表导入
/// <summary>
/// 上传用户信息
/// </summary>
/// <param name="formFiles">文件</param>
/// <returns></returns>
[HttpPost]
public Response<bool> ImportUserInfo(IFormFileCollection formFiles)
{
Response<bool> response = new Response<bool>();
try
{
response = _app.ImportUserInfo(formFiles);
}
catch (Exception ex)
{
response.Code = 500;
response.Message = ex.InnerException?.Message ?? ex.Message;
}
return response;
}
#endregion
}
}