baotian
2024-06-04 b959135a1139fb66646523d92e5bd20c5910f283
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
using iWare.Wms.Core;
using Furion.DatabaseAccessor;
using Furion.DependencyInjection;
using Microsoft.EntityFrameworkCore;
 
namespace iWare.Wms.Application
{
    /// <summary>
    /// 角色数据范围服务
    /// </summary>
    public class SysRoleDataScopeService : ISysRoleDataScopeService, ITransient
    {
        private readonly IRepository<SysRoleDataScope> _sysRoleDataScopeRep;  // 角色数据范围表仓储
 
        public SysRoleDataScopeService(IRepository<SysRoleDataScope> sysRoleDataScopeRep)
        {
            _sysRoleDataScopeRep = sysRoleDataScopeRep;
        }
 
        /// <summary>
        /// 授权角色数据范围
        /// </summary>
        /// <param name="input"></param>
        /// <returns></returns>
        [UnitOfWork]
        public async Task GrantDataScope(GrantRoleDataInput input)
        {
            var dataScopes = await _sysRoleDataScopeRep.DetachedEntities.Where(u => u.SysRoleId == input.Id).ToListAsync();
            await _sysRoleDataScopeRep.DeleteAsync(dataScopes);
 
            var roleDataScopes = input.GrantOrgIdList.Select(u => new SysRoleDataScope
            {
                SysRoleId = input.Id,
                SysOrgId = u
            }).ToList();
            await _sysRoleDataScopeRep.InsertAsync(roleDataScopes);
        }
 
        /// <summary>
        /// 根据角色Id集合获取角色数据范围集合
        /// </summary>
        /// <param name="roleIdList"></param>
        /// <returns></returns>
        public async Task<List<long>> GetRoleDataScopeIdList(List<long> roleIdList)
        {
            return await _sysRoleDataScopeRep.DetachedEntities
                                             .Where(u => roleIdList.Contains(u.SysRoleId))
                                             .Select(u => u.SysOrgId).ToListAsync();
        }
 
        /// <summary>
        /// 根据机构Id集合删除对应的角色-数据范围关联信息
        /// </summary>
        /// <param name="orgIdList"></param>
        /// <returns></returns>
        public async Task DeleteRoleDataScopeListByOrgIdList(List<long> orgIdList)
        {
            var dataScopes = await _sysRoleDataScopeRep.DetachedEntities.Where(u => orgIdList.Contains(u.SysOrgId)).ToListAsync();
            await _sysRoleDataScopeRep.DeleteAsync(dataScopes);
        }
 
        /// <summary>
        /// 根据角色Id删除对应的角色-数据范围关联信息
        /// </summary>
        /// <param name="roleId"></param>
        /// <returns></returns>
        public async Task DeleteRoleDataScopeListByRoleId(long roleId)
        {
            var dataScopes = await _sysRoleDataScopeRep.DetachedEntities.Where(u => u.SysRoleId == roleId).ToListAsync();
            await _sysRoleDataScopeRep.DeleteAsync(dataScopes);
        }
    }
}