Как я могу перечислить всех пользователей, которые были назначены на роль.Вот моя модель.
namespace Comtrex_ICU.Models
{
public class UsersContext : DbContext
{
public UsersContext()
: base("DefaultConnection")
{
}
public DbSet<UserProfile> UserProfiles { get; set; }
public DbSet<Membership> Membership { get; set; }
public DbSet<Role> Roles { get; set; }
}
[Table("UserProfile")]
public class UserProfile
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int UserId { get; set; }
public string UserName { get; set; }
public string Email { get; set; }
}
[Table("webpages_Roles")]
public class Role
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int RoleId { get; set; }
public string RoleName { get; set; }
}
Вот мой контроллер на данный момент: когда я нажимаю на роль, он возвращает представление с правильным названием роли в этом представлении:
//List all users for a role
[HttpGet]
public ActionResult List(string UserName, string RoleName)
{
using (UsersContext db = new UsersContext())
{
var roleSelect = db.Roles.Where(r => r.RoleName.Equals(RoleName)).FirstOrDefault();
return View(roleSelect);
}
}
Это представление, которое отображает список всех ролей, сохраненных со ссылкой для редактирования, удаления и перечисления этой конкретной роли.
@{
ViewBag.Title = "RoleIndex";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<div class="spacerBody">
<h2 class="admin-home-link">@Html.ActionLink("Roles", "AdminIndex")</h2>
@Html.ActionLink("Create New Role", "RoleCreate") |
@Html.ActionLink("Manage User Roles", "RoleAddToUser")
<p> </p>
<div>
@foreach (string s in Model)
{
<div id="userRolesList">
<p class="role-p">
@s
|<span onclick="return confirm('Are you sure to
delete?')">
<a href="/Account/RoleDelete?RoleName=@s"
class="delLink"> <span style="color:
#f05322">Delete</span>
</a>
</span>
|<a href="/Account/Edit?RoleName=@s">Edit</a>
|<a href="/Account/List?RoleName=@s">List</a>
</p>
</div>
<div>
</div>
}
</div>
</div>
Then when I click the List link it takes me to this view:
@model Comtrex_ICU.Models.Role
@{
ViewBag.Title = "List";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2 class="admin-home-link">@Html.ActionLink("List", "AdminIndex")</h2>
<hr/>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
@Html.HiddenFor(m => m.RoleId)
<p>
@Model.RoleName
</p>
}
How will i be able to list the specific users that corresponds to the right role?