Роли FBA с группами пользователей SharePoint - PullRequest
1 голос
/ 20 марта 2009

Я создал пользовательские поставщики членства и ролей. Пользователи - это клиенты, принадлежащие компании, и я использую компанию в качестве роли.

Я хотел бы создать группу SharePoint и добавить в нее больше компаний (например, тип отрасли), а затем выполнить перенаправление и защиту с помощью SPGroup.

Как мне получить SPGroup для текущего вошедшего в систему пользователя?
Я хотел бы сделать это на своей странице входа в систему, поэтому еще одна проблема - как мне получить SPUser или SPGroup, зная имя пользователя?

Вот что у меня сейчас:


private List GetGroupsForUser(List roleAccounts)
{
    List groups = new List();
    SPSecurity.RunWithElevatedPrivileges(
     delegate()
     {
         using (SPSite site = new SPSite(SPContext.Current.Web.Site.ID))
         {
             SPUserCollection users = site.RootWeb.SiteUsers;
             foreach (string account in roleAccounts)
             {
                 SPGroupCollection accGroups = users[account].Groups;
                 foreach (SPGroup spg in groups)
                 {
                     groups.Add(spg);
                 }
             }
         }
     }
     );

    return groups;

}

private string GetRoleManagerName()
{
    foreach (KeyValuePair setting in SPContext.Current.Site.WebApplication.IisSettings)
    {
        if (string.IsNullOrEmpty(setting.Value.RoleManager) == false)
            return setting.Value.RoleManager.ToLower();
    }
    return null;
}

private List GetSpAccounts()
{
    List roleAccounts = new List();
    string roleProviderName = GetRoleManagerName();
    foreach (string role in Roles.GetRolesForUser(login.UserName))
    {
        roleAccounts.Add(roleProviderName + ":" + role.ToLower());
    }

    return roleAccounts;
}


// and now I can use it
List roleAccounts = GetSpAccounts();
List groups = GetGroupsForUser(roleAccounts);

Но у меня есть чувство, что я не должен делать это вручную, как это. Как будет работать Целевая аудитория, если в группу будет добавлена ​​только роль?

1 Ответ

2 голосов
/ 20 марта 2009

Используйте свойство OwnedGroups класса SPUser, чтобы вернуть коллекцию групп, принадлежащих пользователю.

Обновление неправильно понял вопрос:

  1. Получите текущего пользователя: SPContext.Current.Web.CurrentUser
  2. Добавьте это использование в группу: SPGroup.Users.Add ([имя пользователя], [электронная почта], [имя], [заметки]);

Обновление, третий раз очарование. Итак, вы хотите узнать, в какую группу входит пользователь, основываясь на ролях, которые у него есть? Это комбинация двух вышеупомянутых попыток ответить на него:

var matched = from r in SPContext.Current.Web.CurrentUser.Roles
              where r.Name = [Role]
              select r.Groups;

Важное замечание: свойство Roles не будет работать в следующей версии SharePoint! Лично я думаю, что SPContext.Current.Web.CurrentUser.Groups был бы более простым способом выяснить, в какие группы входит пользователь, но он игнорирует требование вашей роли.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...