优化代码

This commit is contained in:
橙子
2021-10-25 16:52:09 +08:00
parent 07a74c83d8
commit adeb2ead7e
6 changed files with 152 additions and 95 deletions

View File

@@ -20,18 +20,6 @@ namespace Yi.Framework.Service
return menu_data; return menu_data;
} }
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var menuList = await GetEntitiesAsync(u=>_ids.Contains(u.id));
menuList.ToList().ForEach(u => u.is_delete = (short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(menuList);
}
public async Task<IEnumerable<menu>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u=> u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
}
public async Task<List<menu>> GetChildrenByMenu(menu _menu) public async Task<List<menu>> GetChildrenByMenu(menu _menu)
{ {
var menu_data = await GetEntity(u=>u.id==_menu.id&& u.is_delete == (short)Common.Enum.DelFlagEnum.Normal); var menu_data = await GetEntity(u=>u.id==_menu.id&& u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);

View File

@@ -11,21 +11,8 @@ namespace Yi.Framework.Service
{ {
public partial class MouldService:BaseService<mould>, IMouldService public partial class MouldService:BaseService<mould>, IMouldService
{ {
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var mouldList =await GetEntitiesAsync(u => _ids.Contains(u.id));
mouldList.ToList().ForEach(u => u.is_delete = (short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(mouldList);
}
public async Task<IEnumerable<mould>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u => u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
}
public async Task<menu> GetMenuByMould(mould _mould) public async Task<menu> GetMenuByMould(mould _mould)
{ {
var menu_data = await _Db.Set<menu>().Include(u => u.mould) var menu_data = await _Db.Set<menu>().Include(u => u.mould)
.Where(u => u.mould == _mould && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync(); .Where(u => u.mould == _mould && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync();
return menu_data; return menu_data;

View File

@@ -11,17 +11,6 @@ namespace Yi.Framework.Service
{ {
public partial class RoleService:BaseService<role>, IRoleService public partial class RoleService:BaseService<role>, IRoleService
{ {
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var userList = await GetEntitiesAsync(u=>_ids.Contains(u.id));
userList.ToList().ForEach(u => u.is_delete =(short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(userList);
}
public async Task<IEnumerable<role>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u => u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
}
public async Task<List<menu>> GetMenusByRole(role _role) public async Task<List<menu>> GetMenusByRole(role _role)
{ {
var role_data =await _Db.Set<role>().Include(u => u.menus) var role_data =await _Db.Set<role>().Include(u => u.menus)

View File

@@ -13,20 +13,72 @@ namespace Yi.Framework.Service
public partial class MenuService:BaseService<menu>,IMenuService public partial class MenuService:BaseService<menu>,IMenuService
{ {
public MenuService(DbContext Db):base(Db){ } public MenuService(DbContext Db):base(Db){ }
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var menuList = await GetEntitiesAsync(u=>_ids.Contains(u.id));
menuList.ToList().ForEach(u => u.is_delete = (short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(menuList);
}
public async Task<IEnumerable<menu>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u=> u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
}
} }
public partial class MouldService:BaseService<mould>,IMouldService public partial class MouldService:BaseService<mould>,IMouldService
{ {
public MouldService(DbContext Db):base(Db){ } public MouldService(DbContext Db):base(Db){ }
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var mouldList = await GetEntitiesAsync(u=>_ids.Contains(u.id));
mouldList.ToList().ForEach(u => u.is_delete = (short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(mouldList);
}
public async Task<IEnumerable<mould>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u=> u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
}
} }
public partial class RoleService:BaseService<role>,IRoleService public partial class RoleService:BaseService<role>,IRoleService
{ {
public RoleService(DbContext Db):base(Db){ } public RoleService(DbContext Db):base(Db){ }
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var roleList = await GetEntitiesAsync(u=>_ids.Contains(u.id));
roleList.ToList().ForEach(u => u.is_delete = (short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(roleList);
}
public async Task<IEnumerable<role>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u=> u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
}
} }
public partial class UserService:BaseService<user>,IUserService public partial class UserService:BaseService<user>,IUserService
{ {
public UserService(DbContext Db):base(Db){ } public UserService(DbContext Db):base(Db){ }
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var userList = await GetEntitiesAsync(u=>_ids.Contains(u.id));
userList.ToList().ForEach(u => u.is_delete = (short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(userList);
}
public async Task<IEnumerable<user>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u=> u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
}
} }
} }

View File

@@ -39,6 +39,19 @@ namespace Yi.Framework.Service
public partial class <#= fn #>Service:BaseService<<#= k #>>,I<#= fn #>Service public partial class <#= fn #>Service:BaseService<<#= k #>>,I<#= fn #>Service
{ {
public <#= fn #>Service(DbContext Db):base(Db){ } public <#= fn #>Service(DbContext Db):base(Db){ }
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var <#= k #>List = await GetEntitiesAsync(u=>_ids.Contains(u.id));
<#= k #>List.ToList().ForEach(u => u.is_delete = (short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(<#= k #>List);
}
public async Task<IEnumerable<<#= k #>>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u=> u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
}
} }
<# } #> <# } #>
} }

View File

@@ -11,41 +11,33 @@ using Yi.Framework.Model.Models;
namespace Yi.Framework.Service namespace Yi.Framework.Service
{ {
public partial class UserService: BaseService<user>,IUserService public partial class UserService : BaseService<user>, IUserService
{ {
private IRoleService _roleService; private IRoleService _roleService;
public UserService(DbContext Db, IRoleService roleService) :base(Db) public UserService(DbContext Db, IRoleService roleService) : base(Db)
{ {
_roleService = roleService; _roleService = roleService;
} }
public async Task<bool> DelListByUpdateAsync(List<int> _ids)
{
var userList = await GetEntitiesAsync(u => _ids.Contains(u.id));
userList.ToList().ForEach(u => u.is_delete = (short)Common.Enum.DelFlagEnum.Deleted);
return await UpdateListAsync(userList);
}
public async Task<bool> EmailIsExsit(string emailAddress) public async Task<bool> EmailIsExsit(string emailAddress)
{ {
var userList=await GetAllEntitiesTrueAsync(); var userList = await GetAllEntitiesTrueAsync();
var is_email= userList.Where(u=>u.email==emailAddress).FirstOrDefault(); var is_email = userList.Where(u => u.email == emailAddress).FirstOrDefault();
if (is_email == null) if (is_email == null)
{ {
return true; return true;
} }
return false; return false;
}
public async Task<IEnumerable<user>> GetAllEntitiesTrueAsync()
{
return await GetEntitiesAsync(u => u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
} }
/// <summary>
/// 大优化直接传用户id即可
/// </summary>
/// <param name="_user"></param>
/// <returns></returns>
public async Task<List<menu>> GetMenusByUser(user _user) public async Task<List<menu>> GetMenusByUser(user _user)
{ {
var user_data= await _Db.Set<user>().Include(u => u.roles).ThenInclude(u=>u.menus).ThenInclude(u=>u.mould) var role_data = await GetRolesByUser(_user);
.Where(u=>u.id==_user.id&& u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync();
var role_data =await GetRolesByUser(user_data);
var menuList = new List<menu>(); var menuList = new List<menu>();
role_data.ForEach(u => role_data.ForEach(u =>
{ {
@@ -53,86 +45,112 @@ namespace Yi.Framework.Service
menuList = menuList.Concat(menu_data.GetAwaiter().GetResult()).ToList(); menuList = menuList.Concat(menu_data.GetAwaiter().GetResult()).ToList();
}); });
menuList.ForEach(u => u.roles = null); menuList.ForEach(u => u.roles = null);
return menuList; return menuList;
} }
/// <summary>
/// 大优化只用id即可这个方法和GetMenusByUser几乎没有任何区别
/// </summary>
/// <param name="_user"></param>
/// <returns></returns>
public async Task<List<mould>> GetMouldByUser(user _user) public async Task<List<mould>> GetMouldByUser(user _user)
{ {
var user_data = await GetEntity(u => u.id == _user.id && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal); var menu = await GetMenusByUser(_user);
var menu = await GetMenusByUser(user_data); var mouldList = menu.Select(u => u.mould).ToList();
var mouldList = menu.Select(u=>u.mould).ToList();
return mouldList; return mouldList;
} }
public async Task<List<role>> GetRolesByUser(user _user) public async Task<List<role>> GetRolesByUser(user _user)
{ {
var user_data = await _Db.Set<user>().Include(u=>u.roles) 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(); .Where(u => u.id == _user.id && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync();
var roleList = user_data.roles.Where(u=> u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).ToList(); var roleList = user_data.roles.Where(u => u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).ToList();
roleList.ForEach(u => u.users = null); roleList.ForEach(u => u.users = null);
return roleList; return roleList;
} }
public async Task<user> Login(user _user) public async Task<user> Login(user _user)
{ {
var user_data =await _Db.Set<user>().Include(u=>u.roles).Where(u => u.username == _user.username&&u.password==_user.password&& 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(); u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync();
return user_data; return user_data;
} }
public async Task<bool> Register(user _user) public async Task<bool> Register(user _user)
{ {
var user_data =await GetEntity(u => u.username == _user.username); var user_data = await GetEntity(u => u.username == _user.username);
if (user_data != null) if (user_data != null)
{ {
return false; return false;
} }
return await AddAsync(_user); return await AddAsync(_user);
} }
/// <summary>
/// 优化如果是传的id或者是传一个对象不是要返回全部信息那么可知直接认为该id一定存在
/// </summary>
/// <param name="roleIds"></param>
/// <param name="userIds"></param>
/// <returns></returns>
public async Task<bool> SetRolesByUser(List<int> roleIds, List<int> userIds) public async Task<bool> SetRolesByUser(List<int> roleIds, List<int> userIds)
{ {
var user_data =await _Db.Set<user>().Include(u=>u.roles).Where(u =>userIds.Contains(u.id) &&u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).ToListAsync(); var user_data = await _Db.Set<user>().Include(u => u.roles).Where(u => userIds.Contains(u.id) ).ToListAsync();
if (user_data == null) if (user_data == null)
{ {
return false; return false;
} }
var roleList =await _Db.Set<role>().Where(u => roleIds.Contains(u.id) && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).ToListAsync(); var roleList = await _Db.Set<role>().Where(u => roleIds.Contains(u.id)).ToListAsync();
foreach(var item in user_data) foreach (var item in user_data)
{ {
item.roles = roleList; item.roles = roleList;
} }
return await UpdateListAsync(user_data); return await UpdateListAsync(user_data);
} }
public async Task <List<menu>> GetMenuByUser(user _user)
/// <summary>
/// 有可简化的GetUserById
/// </summary>
/// <param name="_user"></param>
/// <returns></returns>
public async Task<List<menu>> GetMenuByUser(user _user)
{ {
var user_data = await _Db.Set<user>().Include(u => u.roles).ThenInclude(u => u.menus) var user_data = await _Db.Set<user>().Include(u => u.roles).ThenInclude(u => u.menus).Where(u => u.id == _user.id ).FirstOrDefaultAsync();
.Where(u => u.id == _user.id && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync(); List<menu> menu_data = new();
List<menu> menu_data = new ();
foreach (var role in user_data.roles) foreach (var role in user_data.roles)
{ {
var menu = role.menus.ToList(); var menu = role.menus.ToList();
menu.ForEach(u=>u.roles=null); menu.ForEach(u => u.roles = null);
menu_data = menu_data.Concat(menu).ToList(); menu_data = menu_data.Concat(menu).ToList();
} }
return menu_data; return menu_data;
} }
public async Task<user> GetUserInfoById(int user_id) public async Task<user> GetUserInfoById(int user_id)
{ {
var user_data=await GetUserById(user_id); var user_data = await GetUserById(user_id);
user_data.roles.ToList().ForEach(u => u.users = null); user_data.roles.ToList().ForEach(u => u.users = null);
return user_data; return user_data;
} }
/// <summary>
/// 这个方法可以被超级多个其他方法利用,这个是重要的
/// </summary>
/// <param name="user_id"></param>
/// <returns></returns>
public async Task<user> GetUserById(int user_id) public async Task<user> GetUserById(int user_id)
{ {
var user_data = await _Db.Set<user>().Include(u => u.roles) 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(); .Where(u => u.id == user_id && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).FirstOrDefaultAsync();
return user_data; return user_data;
} }
/// <summary>
/// 有可简化的GetUserById
/// </summary>
/// <param name="user_id"></param>
/// <returns></returns>
public async Task<List<menu>> GetMenuById(int user_id) public async Task<List<menu>> GetMenuById(int user_id)
{ {
var user_data = await _Db.Set<user>().Include(u => u.roles).Where(u => u.id == user_id).FirstOrDefaultAsync(); var user_data = await _Db.Set<user>().Include(u => u.roles).Where(u => u.id == user_id).FirstOrDefaultAsync();
@@ -154,14 +172,20 @@ namespace Yi.Framework.Service
List<menu> endMenu = new List<menu>(); List<menu> endMenu = new List<menu>();
foreach (var item in topMenu) foreach (var item in topMenu)
{ {
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(); 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();
endMenu = endMenu.Union(p).ToList(); endMenu = endMenu.Union(p).ToList();
} }
return TopMenuBuild2(TopMenuBuild(endMenu, allMenuIds)); return TopMenuBuild2(TopMenuBuild(endMenu, allMenuIds));
} }
private List<menu> TopMenuBuild(List<menu> menu_data,List<int> allMenuIds) /// <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)
{ {
for (int i = menu_data.Count() - 1; i >= 0; i--) for (int i = menu_data.Count() - 1; i >= 0; i--)
@@ -172,7 +196,7 @@ namespace Yi.Framework.Service
menu_data[i].icon = "Yi"; menu_data[i].icon = "Yi";
} }
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) 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)
{ {
menu_data.Remove(menu_data[i]); menu_data.Remove(menu_data[i]);
} }
@@ -184,6 +208,11 @@ namespace Yi.Framework.Service
return menu_data; return menu_data;
} }
/// <summary>
/// 这种就命名的话改成MenuChildrenBuild
/// </summary>
/// <param name="menu_data"></param>
/// <returns></returns>
private List<menu> TopMenuBuild2(List<menu> menu_data) private List<menu> TopMenuBuild2(List<menu> menu_data)
{ {
@@ -203,22 +232,21 @@ namespace Yi.Framework.Service
public async Task<List<menu>> GetMenuByUserId(string router,int userId,List<int> menuIds) public async Task<List<menu>> GetMenuByUserId(string router, int userId, List<int> menuIds)
{ {
var user_data= await _Db.Set<user>().Include(u => u.roles).ThenInclude(u => u.menus).ThenInclude(u => u.children) 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(); .ThenInclude(u => u.mould).Where(u => u.id == userId).FirstOrDefaultAsync();
var roleList= user_data.roles.ToList(); var roleList = user_data.roles.ToList();
roleList.ForEach(u => u.users = null); roleList.ForEach(u => u.users = null);
List<menu> menu_data =new(); List<menu> menu_data = new();
foreach(var item in roleList) foreach (var item in roleList)
{ {
item.menus.ToList().ForEach(u => u.roles = null); item.menus.ToList().ForEach(u => u.roles = null);
var menuData = item.menus.Where(u => u.router.ToUpper() == router.ToUpper()).FirstOrDefault(); var menuData = item.menus.Where(u => u.router.ToUpper() == router.ToUpper()).FirstOrDefault();
menu_data= menuData.children?.Where(u => menuIds.Contains(u.id)&& u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).ToList(); menu_data = menuData.children?.Where(u => menuIds.Contains(u.id) && u.is_delete == (short)Common.Enum.DelFlagEnum.Normal).ToList();
if (menu_data != null) { break; } if (menu_data != null) { break; }
} }
return menu_data;
return menu_data;
} }
} }
} }