2018-10-30 13:07:29 +08:00
|
|
|
|
using MongoDB.Driver;
|
|
|
|
|
using System.Collections.Generic;
|
2018-10-31 11:15:43 +08:00
|
|
|
|
using System.Linq;
|
2018-10-30 13:07:29 +08:00
|
|
|
|
|
|
|
|
|
namespace Bootstrap.DataAccess.MongoDB
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
public class Role : DataAccess.Role
|
|
|
|
|
{
|
2018-10-31 14:13:37 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// 此角色关联的所有菜单
|
|
|
|
|
/// </summary>
|
|
|
|
|
public IEnumerable<string> Menus { get; set; }
|
|
|
|
|
|
2018-10-31 11:15:43 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="id"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override IEnumerable<DataAccess.Role> RetrieveRoles()
|
|
|
|
|
{
|
2018-10-31 14:13:37 +08:00
|
|
|
|
return MongoDbAccessManager.Roles.Find(FilterDefinition<Role>.Empty).ToList();
|
2018-10-31 11:15:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="p"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override bool SaveRole(DataAccess.Role p)
|
|
|
|
|
{
|
|
|
|
|
if (p.Id == "0")
|
|
|
|
|
{
|
|
|
|
|
p.Id = null;
|
2018-10-31 14:13:37 +08:00
|
|
|
|
MongoDbAccessManager.Roles.InsertOne(p as Role);
|
2018-10-31 11:15:43 +08:00
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2018-10-31 14:13:37 +08:00
|
|
|
|
MongoDbAccessManager.Roles.UpdateOne(md => md.Id == p.Id, Builders<Role>.Update.Set(md => md.RoleName, p.RoleName).Set(md => md.Description, p.Description));
|
2018-10-31 11:15:43 +08:00
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="value"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override bool DeleteRole(IEnumerable<string> value)
|
|
|
|
|
{
|
2018-10-31 14:13:37 +08:00
|
|
|
|
var list = new List<WriteModel<Role>>();
|
2018-10-31 11:15:43 +08:00
|
|
|
|
foreach (var id in value)
|
|
|
|
|
{
|
2018-10-31 14:13:37 +08:00
|
|
|
|
list.Add(new DeleteOneModel<Role>(Builders<Role>.Filter.Eq(g => g.Id, id)));
|
2018-10-31 11:15:43 +08:00
|
|
|
|
}
|
|
|
|
|
MongoDbAccessManager.Roles.BulkWrite(list);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-30 13:07:29 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="userName"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override IEnumerable<string> RetrieveRolesByUserName(string userName)
|
|
|
|
|
{
|
2018-10-31 11:15:43 +08:00
|
|
|
|
var roles = new List<string>();
|
|
|
|
|
var user = UserHelper.RetrieveUsers().Cast<User>().FirstOrDefault(u => u.UserName == userName);
|
|
|
|
|
var role = RoleHelper.RetrieveRoles();
|
|
|
|
|
|
|
|
|
|
roles.AddRange(user.Roles.Select(r => role.FirstOrDefault(rl => rl.Id == r).RoleName));
|
|
|
|
|
if (roles.Count == 0) roles.Add("Default");
|
|
|
|
|
return roles;
|
2018-10-30 13:07:29 +08:00
|
|
|
|
}
|
2018-10-31 11:15:43 +08:00
|
|
|
|
|
2018-10-30 13:07:29 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
2018-10-31 11:15:43 +08:00
|
|
|
|
/// <param name="userId"></param>
|
2018-10-30 13:07:29 +08:00
|
|
|
|
/// <returns></returns>
|
2018-10-31 11:15:43 +08:00
|
|
|
|
public override IEnumerable<DataAccess.Role> RetrieveRolesByUserId(string userId)
|
|
|
|
|
{
|
|
|
|
|
var roles = RoleHelper.RetrieveRoles();
|
|
|
|
|
var user = UserHelper.RetrieveUsers().Cast<User>().FirstOrDefault(u => u.Id == userId);
|
|
|
|
|
roles.ToList().ForEach(r => r.Checked = user.Roles.Any(id => id == r.Id) ? "checked" : "");
|
|
|
|
|
return roles;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="userId"></param>
|
|
|
|
|
/// <param name="roleIds"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override bool SaveRolesByUserId(string userId, IEnumerable<string> roleIds)
|
2018-10-30 13:07:29 +08:00
|
|
|
|
{
|
2018-10-31 11:15:43 +08:00
|
|
|
|
MongoDbAccessManager.Users.FindOneAndUpdate(u => u.Id == userId, Builders<User>.Update.Set(u => u.Roles, roleIds));
|
|
|
|
|
return true;
|
2018-10-30 13:07:29 +08:00
|
|
|
|
}
|
2018-10-31 14:13:37 +08:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="menuId"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override IEnumerable<DataAccess.Role> RetrieveRolesByMenuId(string menuId)
|
|
|
|
|
{
|
|
|
|
|
var roles = RoleHelper.RetrieveRoles().Cast<Role>().ToList();
|
|
|
|
|
roles.ForEach(r => r.Checked = (r.Menus != null && r.Menus.Contains(menuId)) ? "checked" : "");
|
|
|
|
|
roles.ForEach(r => r.Menus = null);
|
|
|
|
|
return roles;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="menuId"></param>
|
|
|
|
|
/// <param name="roleIds"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override bool SavaRolesByMenuId(string menuId, IEnumerable<string> roleIds)
|
|
|
|
|
{
|
|
|
|
|
roleIds.ToList().ForEach(rId =>
|
|
|
|
|
{
|
|
|
|
|
var role = MongoDbAccessManager.Roles.Find(md => md.Id == rId).FirstOrDefault();
|
|
|
|
|
var menus = role.Menus == null ? new List<string>() : role.Menus.ToList();
|
|
|
|
|
if (!menus.Contains(menuId))
|
|
|
|
|
{
|
|
|
|
|
menus.Add(menuId);
|
|
|
|
|
MongoDbAccessManager.Roles.UpdateOne(md => md.Id == rId, Builders<Role>.Update.Set(md => md.Menus, menus));
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="url"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public override IEnumerable<string> RetrieveRolesByUrl(string url)
|
|
|
|
|
{
|
|
|
|
|
// TODO: 需要菜单完成后处理此函数
|
|
|
|
|
return new List<string>() { "Administrators" };
|
|
|
|
|
}
|
2018-10-30 13:07:29 +08:00
|
|
|
|
}
|
|
|
|
|
}
|