Как получить список всех пользователей из Office 365 Organization в C#, используя CSOM? - PullRequest
0 голосов
/ 06 января 2020

В моей организации Office 365 более 4000 пользователей, и я хочу добавить всех этих пользователей на мой дочерний сайт SharePoint в C# с помощью CSOM. Я знаю, что могу добиться этого с помощью кодов PowerShell, но я хочу сделать это в C# с использованием CSOM. Я могу добавить конкретного пользователя с помощью следующего кода, но как добавить всех 4000+ пользователей в один код? Есть ли способ перебрать объект в al oop, в котором есть все 4000+ пользователей?

using System;
using System.Security;
using Microsoft.Online.SharePoint.TenantAdministration;
using Microsoft.SharePoint.Client;
namespace Basic_Site_Subsite_Group_User_Creation
{
    class Program
    {
        static void Main(string[] args)
        {
            //Opens the Admin URL 
            using (ClientContext ctx = new ClientContext("https://developer19.sharepoint.com/sites/Created_with_Communication_site"))
            {
                //Authenticating with Tenant Admin
                SecureString password = new SecureString();
                foreach (char c in "password".ToCharArray())
                    password.AppendChar(c);
                ctx.Credentials = new SharePointOnlineCredentials("kailash@kailash.cf", password);
                    Group gru = ctx.Web.SiteGroups.GetByName("subsite1");
                    User use = ctx.Web.EnsureUser("anil@kailash.cf");
                    gru.Users.AddUser(use);
                    ctx.ExecuteQuery();

Ответы [ 2 ]

0 голосов
/ 07 января 2020

См. этот проект , чтобы зарегистрировать свое приложение, чтобы вы могли вызывать Graph API для получения пользователей из AD.

if (graphServiceClient != null)
                {
                    var users= await graphServiceClient.Users.Request().GetAsync();

enter image description here

При добавлении пользователей в SharePoint, рекомендуется сделать этот пакет (отправить 100 пользователей за один запрос, чтобы избежать проблемы).

Поддельный код:

for(var i = 1; i <= users.Count; i++)
                    {
                        User use = ctx.Web.EnsureUser(users[i].Mail);
                        gru.Users.AddUser(use);
                        if (i % 100 == 0)
                        {
                            ctx.ExecuteQuery();
                        }
                    }
0 голосов
/ 06 января 2020

Вы можете использовать это, если в вашей организации есть AD (я так думаю)

string groupName = "Domain Users";
string domainName = "your domainName";
PrincipalContext ctx = new PrincipalContext(ContextType.Domain, domainName);
GroupPrincipal grp = GroupPrincipal.FindByIdentity(ctx, IdentityType.SamAccountName, groupName);
if (grp != null)
{
     foreach (Principal p in grp.GetMembers(false))
        {
            p.DisplayName //do your action here
        }


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