2021-10-11 21:50:50 +08:00
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
|
using System;
|
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
using System.Linq;
|
|
|
|
|
|
using System.Linq.Expressions;
|
|
|
|
|
|
using System.Text;
|
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
using Yi.Framework.Interface;
|
2021-10-12 18:05:01 +08:00
|
|
|
|
using Yi.Framework.Model;
|
2021-10-11 21:50:50 +08:00
|
|
|
|
using Yi.Framework.Model.Models;
|
|
|
|
|
|
|
|
|
|
|
|
namespace Yi.Framework.Service
|
|
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
public partial class UserService : BaseService<user>, IUserService
|
2021-10-11 21:50:50 +08:00
|
|
|
|
{
|
2021-10-17 17:35:18 +08:00
|
|
|
|
private IRoleService _roleService;
|
2021-10-25 16:52:09 +08:00
|
|
|
|
public UserService(DbContext Db, IRoleService roleService) : base(Db)
|
2021-10-12 18:05:01 +08:00
|
|
|
|
{
|
2021-10-17 17:35:18 +08:00
|
|
|
|
_roleService = roleService;
|
2021-10-11 21:50:50 +08:00
|
|
|
|
}
|
2021-10-12 13:45:24 +08:00
|
|
|
|
|
2021-10-13 23:08:42 +08:00
|
|
|
|
public async Task<bool> EmailIsExsit(string emailAddress)
|
|
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var userList = await GetAllEntitiesTrueAsync();
|
|
|
|
|
|
var is_email = userList.Where(u => u.email == emailAddress).FirstOrDefault();
|
2021-10-13 23:08:42 +08:00
|
|
|
|
if (is_email == null)
|
|
|
|
|
|
{
|
|
|
|
|
|
return true;
|
|
|
|
|
|
}
|
2021-10-25 16:52:09 +08:00
|
|
|
|
return false;
|
2021-10-12 18:05:01 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-10-25 16:52:09 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 大优化,直接传用户id即可
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="_user"></param>
|
|
|
|
|
|
/// <returns></returns>
|
2021-10-12 18:05:01 +08:00
|
|
|
|
public async Task<List<menu>> GetMenusByUser(user _user)
|
|
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var role_data = await GetRolesByUser(_user);
|
2021-10-19 18:30:56 +08:00
|
|
|
|
var menuList = new List<menu>();
|
|
|
|
|
|
role_data.ForEach(u =>
|
|
|
|
|
|
{
|
|
|
|
|
|
var menu_data = _roleService.GetMenusByRole(u);
|
2021-10-22 17:28:55 +08:00
|
|
|
|
menuList = menuList.Concat(menu_data.GetAwaiter().GetResult()).ToList();
|
2021-10-19 18:30:56 +08:00
|
|
|
|
});
|
2021-10-22 17:28:55 +08:00
|
|
|
|
menuList.ForEach(u => u.roles = null);
|
|
|
|
|
|
return menuList;
|
2021-10-12 18:05:01 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-10-25 16:52:09 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 大优化只用id即可,这个方法和GetMenusByUser几乎没有任何区别
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="_user"></param>
|
|
|
|
|
|
/// <returns></returns>
|
2021-10-12 18:05:01 +08:00
|
|
|
|
public async Task<List<mould>> GetMouldByUser(user _user)
|
2021-10-25 16:52:09 +08:00
|
|
|
|
{
|
|
|
|
|
|
var menu = await GetMenusByUser(_user);
|
|
|
|
|
|
var mouldList = menu.Select(u => u.mould).ToList();
|
2021-10-19 18:30:56 +08:00
|
|
|
|
return mouldList;
|
2021-10-12 18:05:01 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-10-25 16:52:09 +08:00
|
|
|
|
|
2021-10-12 18:05:01 +08:00
|
|
|
|
public async Task<List<role>> GetRolesByUser(user _user)
|
|
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var user_data = await _Db.Set<user>().Include(u => u.roles)
|
2021-10-15 14:45:16 +08:00
|
|
|
|
.Where(u => u.id == _user.id && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync();
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var roleList = user_data.roles.Where(u => u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).ToList();
|
2021-10-19 17:33:55 +08:00
|
|
|
|
roleList.ForEach(u => u.users = null);
|
2021-10-15 14:45:16 +08:00
|
|
|
|
return roleList;
|
2021-10-12 18:05:01 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-10-16 17:50:55 +08:00
|
|
|
|
public async Task<user> Login(user _user)
|
2021-10-12 18:05:01 +08:00
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var user_data = await _Db.Set<user>().Include(u => u.roles).Where(u => u.username == _user.username && u.password == _user.password &&
|
|
|
|
|
|
u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync();
|
2021-10-16 17:50:55 +08:00
|
|
|
|
return user_data;
|
2021-10-12 18:05:01 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public async Task<bool> Register(user _user)
|
|
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var user_data = await GetEntity(u => u.username == _user.username);
|
2021-10-12 18:05:01 +08:00
|
|
|
|
if (user_data != null)
|
|
|
|
|
|
{
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
2021-10-25 16:52:09 +08:00
|
|
|
|
return await AddAsync(_user);
|
2021-10-12 18:05:01 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-10-25 16:52:09 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 优化,如果是传的id,或者是传一个对象,不是要返回全部信息,那么可知直接认为该id一定存在
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="roleIds"></param>
|
|
|
|
|
|
/// <param name="userIds"></param>
|
|
|
|
|
|
/// <returns></returns>
|
2021-10-15 17:50:56 +08:00
|
|
|
|
public async Task<bool> SetRolesByUser(List<int> roleIds, List<int> userIds)
|
2021-10-12 18:05:01 +08:00
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var user_data = await _Db.Set<user>().Include(u => u.roles).Where(u => userIds.Contains(u.id) ).ToListAsync();
|
2021-10-12 18:05:01 +08:00
|
|
|
|
if (user_data == null)
|
|
|
|
|
|
{
|
|
|
|
|
|
return false;
|
2021-10-25 16:52:09 +08:00
|
|
|
|
}
|
|
|
|
|
|
var roleList = await _Db.Set<role>().Where(u => roleIds.Contains(u.id)).ToListAsync();
|
|
|
|
|
|
foreach (var item in user_data)
|
2021-10-15 17:50:56 +08:00
|
|
|
|
{
|
|
|
|
|
|
item.roles = roleList;
|
|
|
|
|
|
}
|
|
|
|
|
|
return await UpdateListAsync(user_data);
|
2021-10-11 21:50:50 +08:00
|
|
|
|
}
|
2021-10-25 16:52:09 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 有可简化的GetUserById
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="_user"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
public async Task<List<menu>> GetMenuByUser(user _user)
|
2021-10-17 17:35:18 +08:00
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var user_data = await _Db.Set<user>().Include(u => u.roles).ThenInclude(u => u.menus).Where(u => u.id == _user.id ).FirstOrDefaultAsync();
|
|
|
|
|
|
List<menu> menu_data = new();
|
2021-10-24 19:36:44 +08:00
|
|
|
|
foreach (var role in user_data.roles)
|
2021-10-17 17:35:18 +08:00
|
|
|
|
{
|
2021-10-24 17:13:28 +08:00
|
|
|
|
var menu = role.menus.ToList();
|
2021-10-25 16:52:09 +08:00
|
|
|
|
menu.ForEach(u => u.roles = null);
|
|
|
|
|
|
menu_data = menu_data.Concat(menu).ToList();
|
|
|
|
|
|
}
|
2021-10-18 21:54:40 +08:00
|
|
|
|
return menu_data;
|
2021-10-17 17:35:18 +08:00
|
|
|
|
}
|
2021-10-25 16:52:09 +08:00
|
|
|
|
|
|
|
|
|
|
|
2021-10-19 14:50:26 +08:00
|
|
|
|
public async Task<user> GetUserInfoById(int user_id)
|
|
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var user_data = await GetUserById(user_id);
|
2021-10-20 16:23:57 +08:00
|
|
|
|
user_data.roles.ToList().ForEach(u => u.users = null);
|
2021-10-19 14:50:26 +08:00
|
|
|
|
return user_data;
|
|
|
|
|
|
}
|
2021-10-25 16:52:09 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 这个方法可以被超级多个其他方法利用,这个是重要的
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="user_id"></param>
|
|
|
|
|
|
/// <returns></returns>
|
2021-10-22 16:48:03 +08:00
|
|
|
|
public async Task<user> GetUserById(int user_id)
|
|
|
|
|
|
{
|
|
|
|
|
|
var user_data = await _Db.Set<user>().Include(u => u.roles)
|
|
|
|
|
|
.Where(u => u.id == user_id && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync();
|
|
|
|
|
|
return user_data;
|
|
|
|
|
|
}
|
2021-10-25 16:52:09 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 有可简化的GetUserById
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="user_id"></param>
|
|
|
|
|
|
/// <returns></returns>
|
2021-10-23 15:47:15 +08:00
|
|
|
|
public async Task<List<menu>> GetMenuById(int user_id)
|
|
|
|
|
|
{
|
2021-10-24 00:51:09 +08:00
|
|
|
|
var user_data = await _Db.Set<user>().Include(u => u.roles).Where(u => u.id == user_id).FirstOrDefaultAsync();
|
2021-10-23 15:47:15 +08:00
|
|
|
|
List<menu> menu_data = new();
|
2021-10-25 16:52:09 +08:00
|
|
|
|
|
2021-10-24 00:51:09 +08:00
|
|
|
|
foreach (var role in user_data.roles)
|
2021-10-23 15:47:15 +08:00
|
|
|
|
{
|
|
|
|
|
|
var menu = await _roleService.GetMenusByRole(role);
|
|
|
|
|
|
menu.ForEach(u => u.roles = null);
|
2021-10-23 20:23:44 +08:00
|
|
|
|
menu_data = menu_data.Union(menu).OrderByDescending(u => u.sort).ToList();
|
2021-10-23 15:47:15 +08:00
|
|
|
|
}
|
2021-10-24 00:51:09 +08:00
|
|
|
|
//menu_data为角色所有的菜单,不是一个递归的啊
|
|
|
|
|
|
|
|
|
|
|
|
var allMenuIds = menu_data.Select(u => u.id).ToList();
|
|
|
|
|
|
var topMenu = menu_data.Where(u => u.is_top == (short)Common.Enum.ShowFlagEnum.Show);
|
|
|
|
|
|
|
|
|
|
|
|
//现在要开始关联菜单了
|
|
|
|
|
|
|
|
|
|
|
|
List<menu> endMenu = new List<menu>();
|
|
|
|
|
|
foreach (var item in topMenu)
|
|
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var p = await _Db.Set<menu>().Where(u => u.id == item.id).Include(u => u.children).ThenInclude(u => u.children).ThenInclude(u => u.children).ThenInclude(u => u.children).ThenInclude(u => u.children).ToListAsync();
|
2021-10-24 00:51:09 +08:00
|
|
|
|
endMenu = endMenu.Union(p).ToList();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return TopMenuBuild2(TopMenuBuild(endMenu, allMenuIds));
|
2021-10-23 15:47:15 +08:00
|
|
|
|
}
|
2021-10-25 16:52:09 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 这种就命名的话,改成MenuIconAndShowBuild
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="menu_data"></param>
|
|
|
|
|
|
/// <param name="allMenuIds"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
private List<menu> TopMenuBuild(List<menu> menu_data, List<int> allMenuIds)
|
2021-10-23 15:47:15 +08:00
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = menu_data.Count() - 1; i >= 0; i--)
|
|
|
|
|
|
{
|
2021-10-23 20:23:44 +08:00
|
|
|
|
|
|
|
|
|
|
if (menu_data[i].icon == null)
|
2021-10-23 15:47:15 +08:00
|
|
|
|
{
|
2021-10-23 20:23:44 +08:00
|
|
|
|
menu_data[i].icon = "Yi";
|
2021-10-23 15:47:15 +08:00
|
|
|
|
}
|
2021-10-23 20:23:44 +08:00
|
|
|
|
|
2021-10-25 16:52:09 +08:00
|
|
|
|
if (!allMenuIds.Contains(menu_data[i].id) || menu_data[i].is_delete == (short)Common.Enum.DelFlagEnum.Deleted || menu_data[i].is_show == (short)Common.Enum.ShowFlagEnum.NoShow)
|
2021-10-23 15:47:15 +08:00
|
|
|
|
{
|
2021-10-23 20:23:44 +08:00
|
|
|
|
menu_data.Remove(menu_data[i]);
|
2021-10-23 15:47:15 +08:00
|
|
|
|
}
|
|
|
|
|
|
else if (menu_data[i].children != null)
|
|
|
|
|
|
{
|
2021-10-24 00:51:09 +08:00
|
|
|
|
menu_data[i].children = TopMenuBuild(menu_data[i].children.ToList(), allMenuIds);
|
2021-10-23 15:47:15 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return menu_data;
|
|
|
|
|
|
}
|
2021-10-23 20:23:44 +08:00
|
|
|
|
|
2021-10-25 16:52:09 +08:00
|
|
|
|
/// <summary>
|
2021-10-26 00:59:06 +08:00
|
|
|
|
/// 这种就命名的话,改成MenuChildrenBuild,这个方法应该可以提到core层,这是一个公用的方法
|
2021-10-25 16:52:09 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="menu_data"></param>
|
|
|
|
|
|
/// <returns></returns>
|
2021-10-23 20:23:44 +08:00
|
|
|
|
private List<menu> TopMenuBuild2(List<menu> menu_data)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = menu_data.Count() - 1; i >= 0; i--)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (menu_data[i].children.Count() == 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
menu_data[i].children = null;
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (menu_data[i].children != null)
|
|
|
|
|
|
{
|
|
|
|
|
|
menu_data[i].children = TopMenuBuild2(menu_data[i].children.ToList());
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return menu_data;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2021-10-25 16:52:09 +08:00
|
|
|
|
public async Task<List<menu>> GetMenuByUserId(string router, int userId, List<int> menuIds)
|
2021-10-24 14:33:04 +08:00
|
|
|
|
{
|
2021-10-25 16:52:09 +08:00
|
|
|
|
var user_data = await _Db.Set<user>().Include(u => u.roles).ThenInclude(u => u.menus).ThenInclude(u => u.children)
|
|
|
|
|
|
.ThenInclude(u => u.mould).Where(u => u.id == userId).FirstOrDefaultAsync();
|
|
|
|
|
|
var roleList = user_data.roles.ToList();
|
|
|
|
|
|
roleList.ForEach(u => u.users = null);
|
|
|
|
|
|
List<menu> menu_data = new();
|
|
|
|
|
|
foreach (var item in roleList)
|
2021-10-24 17:13:28 +08:00
|
|
|
|
{
|
|
|
|
|
|
item.menus.ToList().ForEach(u => u.roles = null);
|
2021-10-24 17:24:00 +08:00
|
|
|
|
var menuData = item.menus.Where(u => u.router.ToUpper() == router.ToUpper()).FirstOrDefault();
|
2021-10-25 16:52:09 +08:00
|
|
|
|
menu_data = menuData.children?.Where(u => menuIds.Contains(u.id) && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).ToList();
|
2021-10-24 17:13:28 +08:00
|
|
|
|
if (menu_data != null) { break; }
|
2021-10-24 14:33:04 +08:00
|
|
|
|
}
|
2021-10-25 16:52:09 +08:00
|
|
|
|
return menu_data;
|
2021-10-23 18:46:07 +08:00
|
|
|
|
}
|
2021-10-22 16:48:03 +08:00
|
|
|
|
}
|
2021-10-11 21:50:50 +08:00
|
|
|
|
}
|