SysRoleApp.cs
2.84 KB
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
using Infrastructure;
using System;
using System.Collections.Generic;
using System.Linq;
using WebRepository;
namespace WebApp
{
public class SysRoleApp : WebApp<SysRole>
{
private SysRevelanceApp _revelanceApp;
private IAuth _auth;
public SysRoleApp(IUnitWork unitWork, IRepository<SysRole> repository,
SysRevelanceApp app, IAuth auth) : base(unitWork, repository)
{
_revelanceApp = app;
_auth = auth;
}
public SysRoleApp SetLoginInfo(LoginInfo loginInfo)
{
Repository._loginInfo = loginInfo;
return this;
}
/// <summary>
/// 加载当前登录用户可访问的一个部门及子部门全部角色
/// </summary>
public TableData Load(PageReq pageRequest)
{
var roles = UnitWork.Find<SysRole>(exp:null)
.OrderBy(u => u.Name)
.Skip((pageRequest.page - 1) * pageRequest.limit)
.Take(pageRequest.limit);
var records = Repository.GetCount();
var roleViews = roles.MapToList<SysRoleView>();
return new TableData
{
count = records,
data = roleViews,
};
}
/// <summary>
/// 加载角色的所有机构
/// </summary>
public IEnumerable<SysDept> LoadByRole(int roleId)
{
var result = from userorg in UnitWork.Find<SysRelevance>(null)
join org in UnitWork.Find<SysDept>(null) on userorg.SecondId equals org.Id
where userorg.FirstId == roleId && userorg.RelKey == Define.ROLEORG
select org;
return result;
}
public void Add(SysRoleView obj)
{
if (UnitWork.IsExist<SysRole>(u => u.Name == obj.Name))
{
throw new Exception("角色已存在");
}
SysRole role = obj;
role.CreateTime = DateTime.Now;
role.IsAssignModule = false;
Repository.Add(role);
obj.Id = role.Id; //要把保存后的ID存入view
}
public void Update(SysRoleView obj)
{
SysRole role = obj;
SysRole sysRole = Repository.FindSingle(u => u.Id == obj.Id);
sysRole.Name = role.Name;
sysRole.Status = role.Status;
sysRole.UpdateBy = Repository._loginInfo.Account;
sysRole.UpdateTime = DateTime.Now;
Repository.Update(sysRole);
//Repository.Update(u => u.Id == obj.Id, u => new SysRole
//{
// Name = role.Name,
// Status = role.Status,
// UpdateBy = Repository._loginInfo.Account,
// UpdateTime = DateTime.Now
//});
}
}
}