Blog.Core/Blog.Core.Services/RoleModulePermissionServices.cs
anjoy a623ada3d3 Multi-table query -> Role Module Map
将授权处理器中的角色菜单关系改造成多表查询。
2019-12-12 18:39:09 +08:00

77 lines
2.7 KiB
C#

using Blog.Core.Services.BASE;
using Blog.Core.Model.Models;
using Blog.Core.IServices;
using Blog.Core.IRepository;
using System.Threading.Tasks;
using System.Collections.Generic;
using Blog.Core.Common;
using System.Linq;
namespace Blog.Core.Services
{
/// <summary>
/// RoleModulePermissionServices 应用服务
/// </summary>
public class RoleModulePermissionServices : BaseServices<RoleModulePermission>, IRoleModulePermissionServices
{
readonly IRoleModulePermissionRepository _dal;
readonly IModuleRepository _moduleRepository;
readonly IRoleRepository _roleRepository;
// 将多个仓储接口注入
public RoleModulePermissionServices(IRoleModulePermissionRepository dal, IModuleRepository moduleRepository, IRoleRepository roleRepository)
{
this._dal = dal;
this._moduleRepository = moduleRepository;
this._roleRepository = roleRepository;
base.BaseDal = dal;
}
/// <summary>
/// 获取全部 角色接口(按钮)关系数据
/// </summary>
/// <returns></returns>
[Caching(AbsoluteExpiration = 10)]
public async Task<List<RoleModulePermission>> GetRoleModule()
{
var roleModulePermissions = await base.Query(a => a.IsDeleted == false);
var roles = await _roleRepository.Query(a => a.IsDeleted == false);
var modules = await _moduleRepository.Query(a => a.IsDeleted == false);
//var roleModulePermissionsAsync = base.Query(a => a.IsDeleted == false);
//var rolesAsync = _roleRepository.Query(a => a.IsDeleted == false);
//var modulesAsync = _moduleRepository.Query(a => a.IsDeleted == false);
//var roleModulePermissions = await roleModulePermissionsAsync;
//var roles = await rolesAsync;
//var modules = await modulesAsync;
if (roleModulePermissions.Count > 0)
{
foreach (var item in roleModulePermissions)
{
item.Role = roles.FirstOrDefault(d => d.Id == item.RoleId);
item.Module = modules.FirstOrDefault(d => d.Id == item.ModuleId);
}
}
return roleModulePermissions;
}
public async Task<List<RoleModulePermission>> TestModelWithChildren()
{
return await _dal.WithChildrenModel();
}
public async Task<List<TestMuchTableResult>> QueryMuchTable()
{
return await _dal.QueryMuchTable();
}
public async Task<List<RoleModulePermission>> RoleModuleMaps()
{
return await _dal.RoleModuleMaps();
}
}
}