优化代码
This commit is contained in:
@@ -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);
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
<# } #>
|
<# } #>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,12 +18,6 @@ namespace Yi.Framework.Service
|
|||||||
{
|
{
|
||||||
_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)
|
||||||
{
|
{
|
||||||
@@ -36,16 +30,14 @@ namespace Yi.Framework.Service
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<IEnumerable<user>> GetAllEntitiesTrueAsync()
|
/// <summary>
|
||||||
{
|
/// 大优化,直接传用户id即可
|
||||||
return await GetEntitiesAsync(u => u.is_delete == (short)Common.Enum.DelFlagEnum.Normal);
|
/// </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,18 +45,22 @@ 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)
|
||||||
@@ -78,9 +74,7 @@ namespace Yi.Framework.Service
|
|||||||
{
|
{
|
||||||
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)
|
||||||
@@ -93,25 +87,35 @@ namespace Yi.Framework.Service
|
|||||||
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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 有可简化的GetUserById
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="_user"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public async Task<List<menu>> GetMenuByUser(user _user)
|
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)
|
||||||
{
|
{
|
||||||
@@ -121,18 +125,32 @@ namespace Yi.Framework.Service
|
|||||||
}
|
}
|
||||||
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();
|
||||||
@@ -161,6 +179,12 @@ namespace Yi.Framework.Service
|
|||||||
|
|
||||||
return TopMenuBuild2(TopMenuBuild(endMenu, allMenuIds));
|
return TopMenuBuild2(TopMenuBuild(endMenu, 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)
|
private List<menu> TopMenuBuild(List<menu> menu_data, List<int> allMenuIds)
|
||||||
{
|
{
|
||||||
|
|
||||||
@@ -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)
|
||||||
{
|
{
|
||||||
|
|
||||||
@@ -217,7 +246,6 @@ namespace Yi.Framework.Service
|
|||||||
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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user