Настройка ядра powershell из ядра .net для предоставления одного диска - PullRequest
0 голосов
/ 30 ноября 2018

Я пытаюсь выделить один диск в приложении ядра dotnet, используя ядро ​​powershell.Запуск powershell Мне удалось успешно подготовить один диск из командной строки powershell, следуя приведенным ниже инструкциям:

https://docs.microsoft.com/en-us/onedrive/pre-provision-accounts

Запуск его программно в ядре .net, как это выглядитон использует отдельный PowerShell, встроенный в ядро ​​.net 2.1

. Я считаю, что неудачные попытки запуска приложения связаны с неправильной настройкой PowerSLL в комплекте с ядром, а именно первые 3 шага по ссылке выше:

1.Загрузите последнюю командную консоль SharePoint Online.

2.Загрузите и установите SDK клиентских компонентов SharePoint Online.

3. Подключитесь к SharePoint Online в качестве глобального администратора или SharePointadmin в Office 365. Чтобы узнать, как это сделать, см. Начало работы с Командная консоль SharePoint Online.

Как настроить PowerShell, который запускается моим приложением, для зеркального отображения этих шагов?

Мой код выглядит следующим образом:

using System.IO;
using System.Management.Automation;

namespace PowerShellApp
{
    class Program
    {
        public static int Main(string[] args)
        {
            using (PowerShell ps = PowerShell.Create(
            {
                ps.AddScript(File.ReadAllText(<scriptLocation>))
                    .Invoke();
            }
        }
        return 0;
    }
}

Как мне выполнить эти шаги, когда execИспользование ядра приложения .net

Сценарий powershell, который я запускаю, приведен ниже, а также по ссылке выше:

<#
.SYNOPSIS
 This script adds an entry for each user specified in the input file 
 into the OneDrive provisioning queue

.DESCRIPTION
 This script reads a text file with a line for each user. 
 Provide the User Principal Name of each user on a new line.
 An entry will be made in the OneDrive provisioning queue for each
 user up to 200 users.
.EXAMPLE
 .\BulkEnqueueOneDriveSite.ps1 -SPOAdminUrl https://contoso-    admin.sharepoint.com -InputfilePath C:\users.txt 
.PARAMETER SPOAdminUrl
 The URL for the SharePoint Admin center
 https://contoso-admin.sharepoint.com
.PARAMETER InputFilePath
 The path to the input file.
 The file must contain 1 to 200 users
 C:\users.txt
.NOTES
 This script needs to be run by a global or SharePoint administrator in Office 365
 This script will prompt for the username and password of the administrator
#>
param
(
    #Must be SharePoint Administrator URL
    [Parameter(Mandatory = $true)]
    [ValidateNotNullOrEmpty()]
    [string] $SPOAdminUrl,

    [Parameter(Mandatory = $true)]
    [ValidateNotNullOrEmpty()]
    [string] $InputFilePath
)
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client")     | Out-Null
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client.R    untime") | Out-Null
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client.U    serProfiles") | Out-Null
$ctx = New-Object Microsoft.SharePoint.Client.ClientContext($SPOAdminUrl)
$Users = Get-Content -Path $InputFilePath
if ($Users.Count -eq 0 -or $Users.Count -gt 200)
{
    Write-Host $("Unexpected user count: [{0}]" -f $Users.Count) -    ForegroundColor Red
    return 
}
$web = $ctx.Web
Write-Host "Enter an admin username" -ForegroundColor Green
$username = Read-Host
Write-Host "Enter your password" -ForegroundColor Green
$password = Read-Host -AsSecureString
$ctx.Credentials = New-Object     Microsoft.SharePoint.Client.SharePointOnlineCredentials($username,$password )
$ctx.Load($web)
$ctx.ExecuteQuery()
$loader =     [Microsoft.SharePoint.Client.UserProfiles.ProfileLoader]::GetProfileLoader($ctx)
$ctx.ExecuteQuery()
$loader.CreatePersonalSiteEnqueueBulk($Users)
$loader.Context.ExecuteQuery()
Write-Host "Script Completed"

1 Ответ

0 голосов
/ 04 декабря 2018

Боюсь, что SP Online Management Shell зависит от .Net Framework и не будет работать с Core ( отметьте это ).С другой стороны, этот модуль казался оберткой поверх их REST API.Поэтому, если вы хотите интегрировать его с основным приложением, вы можете попробовать заменить его HTTP-запросами.Проверьте эту документацию

Также ниже приведен базовый скрипт powershell для работы с этими конечными точками REST API.Я протестировал это на своем сайте:

$baseUrl = "http://sharepoint.com/sites/yourSite/_api"
$cred = Get-Credential

# retreive digest
$r = Invoke-WebRequest -Uri "$baseUrl/contextinfo" -Method Post -Credential $cred -SessionVariable sp
$digest = ([xml]$r.content).GetContextWebInformation.FormDigestvalue

# calling endpoint

$endpoint = "sp.userprofiles.profileloader.getprofileloader/getuserprofile"

$head = @{
 "Accept" = "application/json;odata=verbose"
 "X-RequestDigest" = $digest
 }

$re = Invoke-WebRequest -Uri "$baseUrl/$endpoint" -Headers $head -Method Post -WebSession $sp

Write-Host $re.Content

Это фрагмент кода для createpersonalsiteenqueuebulk, но я не могу его протестировать, так как я не являюсь администратором домена.Надеюсь, это сработает для вас

 #--- sample 2 (didn't test it since I'm not domain admin). Might need separate session/digest

$endpoint2 = "https://<domain>-admin.sharepoint.com/_api/sp.userprofiles.profileloader.getprofileloader/createpersonalsiteenqueuebulk"

$head = @{
 "Accept" = "application/json;odata=verbose"
 "X-RequestDigest" = $digest
 }

$body =  "{ 'emailIDs': ['usera@domain.onmicrosoft.com', 'userb@domain.onmicrosoft.com'] }"
$re2 = Invoke-WebRequest -Uri "$endpoint2" -Headers $head -body $body -Method Post -WebSession $sp
Write-Host $re2.Content
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...