2018-10-30 13:07:29 +08:00
|
|
|
|
using Bootstrap.Security;
|
|
|
|
|
using MongoDB.Driver;
|
|
|
|
|
using System.Collections.Generic;
|
2018-10-31 12:08:57 +08:00
|
|
|
|
using System.Linq;
|
2018-10-30 13:07:29 +08:00
|
|
|
|
|
|
|
|
|
namespace Bootstrap.DataAccess.MongoDB
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
2019-08-10 17:12:45 +08:00
|
|
|
|
/// 菜单实体类
|
2018-10-30 13:07:29 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
public class Menu : DataAccess.Menu
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
2019-08-10 17:12:45 +08:00
|
|
|
|
/// 获取指定用户的所有菜单
|
2018-10-30 13:07:29 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="userName"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override IEnumerable<BootstrapMenu> RetrieveAllMenus(string userName)
|
|
|
|
|
{
|
2018-10-31 12:08:57 +08:00
|
|
|
|
var dicts = DictHelper.RetrieveDicts().Where(m => m.Category == "菜单");
|
|
|
|
|
|
2019-01-15 12:52:09 +08:00
|
|
|
|
var menus = DbManager.Menus.Find(FilterDefinition<BootstrapMenu>.Empty).ToList();
|
2018-10-31 12:08:57 +08:00
|
|
|
|
menus.ForEach(m =>
|
|
|
|
|
{
|
|
|
|
|
m.CategoryName = dicts.FirstOrDefault(d => d.Code == m.Category)?.Name;
|
|
|
|
|
if (m.ParentId != "0") m.ParentName = menus.FirstOrDefault(p => p.Id == m.ParentId)?.Name;
|
|
|
|
|
});
|
|
|
|
|
return menus;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-08-10 17:12:45 +08:00
|
|
|
|
/// 保存菜单
|
2018-10-31 12:08:57 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="p"></param>
|
|
|
|
|
/// <returns></returns>
|
2019-01-11 23:20:28 +08:00
|
|
|
|
public override bool Save(BootstrapMenu p)
|
2018-10-31 12:08:57 +08:00
|
|
|
|
{
|
2019-05-14 15:08:46 +08:00
|
|
|
|
if (string.IsNullOrEmpty(p.Id))
|
2018-10-31 12:08:57 +08:00
|
|
|
|
{
|
|
|
|
|
p.Id = null;
|
2019-01-15 12:52:09 +08:00
|
|
|
|
DbManager.Menus.InsertOne(p);
|
2019-05-18 21:21:03 +08:00
|
|
|
|
p.Id = DbManager.Menus.Find(m => m.Name == p.Name && m.Category == p.Category && m.ParentId == p.ParentId && m.Url == p.Url).FirstOrDefault().Id;
|
2018-10-31 12:08:57 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
var update = Builders<BootstrapMenu>.Update.Set(md => md.ParentId, p.ParentId)
|
|
|
|
|
.Set(md => md.Name, p.Name)
|
|
|
|
|
.Set(md => md.Order, p.Order)
|
|
|
|
|
.Set(md => md.Icon, p.Icon)
|
|
|
|
|
.Set(md => md.Url, p.Url)
|
|
|
|
|
.Set(md => md.Category, p.Category)
|
|
|
|
|
.Set(md => md.Target, p.Target)
|
|
|
|
|
.Set(md => md.IsResource, p.IsResource)
|
2019-01-11 23:20:28 +08:00
|
|
|
|
.Set(md => md.Application, p.Application);
|
2019-01-15 12:52:09 +08:00
|
|
|
|
DbManager.Menus.UpdateOne(md => md.Id == p.Id, update);
|
2018-10-31 12:08:57 +08:00
|
|
|
|
}
|
2019-05-18 21:21:03 +08:00
|
|
|
|
return true;
|
2018-10-31 12:08:57 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-08-10 17:12:45 +08:00
|
|
|
|
/// 删除菜单
|
2018-10-31 12:08:57 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="value"></param>
|
|
|
|
|
/// <returns></returns>
|
2019-01-11 23:20:28 +08:00
|
|
|
|
public override bool Delete(IEnumerable<string> value)
|
2018-10-31 12:08:57 +08:00
|
|
|
|
{
|
|
|
|
|
var list = new List<WriteModel<BootstrapMenu>>();
|
|
|
|
|
foreach (var id in value)
|
|
|
|
|
{
|
|
|
|
|
list.Add(new DeleteOneModel<BootstrapMenu>(Builders<BootstrapMenu>.Filter.Eq(g => g.Id, id)));
|
|
|
|
|
}
|
2019-01-15 12:52:09 +08:00
|
|
|
|
DbManager.Menus.BulkWrite(list);
|
2018-10-31 12:08:57 +08:00
|
|
|
|
return true;
|
2018-10-30 13:07:29 +08:00
|
|
|
|
}
|
2018-10-31 16:50:55 +08:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-08-10 17:12:45 +08:00
|
|
|
|
/// 获取指定角色相关菜单
|
2018-10-31 16:50:55 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="roleId"></param>
|
|
|
|
|
/// <returns></returns>
|
2019-08-10 17:12:45 +08:00
|
|
|
|
public override IEnumerable<string> RetrieveMenusByRoleId(string roleId) => DbManager.Roles.Find(md => md.Id == roleId).FirstOrDefault().Menus;
|
2018-10-31 16:50:55 +08:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2019-08-10 17:12:45 +08:00
|
|
|
|
/// 保存指定角色相关菜单
|
2018-10-31 16:50:55 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="roleId"></param>
|
|
|
|
|
/// <param name="menuIds"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override bool SaveMenusByRoleId(string roleId, IEnumerable<string> menuIds)
|
|
|
|
|
{
|
2019-01-15 12:52:09 +08:00
|
|
|
|
DbManager.Roles.FindOneAndUpdate(md => md.Id == roleId, Builders<Role>.Update.Set(md => md.Menus, menuIds));
|
2018-10-31 16:50:55 +08:00
|
|
|
|
return true;
|
|
|
|
|
}
|
2018-10-30 13:07:29 +08:00
|
|
|
|
}
|
|
|
|
|
}
|