2016-04-14 2 views
2

Я использую PowerShell и API OneDrive для этого. Я могу получить все папки/файлы/etc, но мне трудно найти, где я могу перечислить всех пользователей, которым был предоставлен определенный файл. В моей области уже есть wl.skydrive_contacts, и теперь у меня есть список всех папок/файлов с использованием API. Может ли кто-нибудь дать мне некоторое представление?Файлы списка файлов API Onedrive, совместно используемые с внешними пользователями

+0

Что вы пробовали? Можете ли вы поделиться своим кодом и ошибкой, которую вы получите при запуске? – TheMadTechnician

+0

Я использую это, чтобы получить свой корень диска и выберет папки/файлы, вызвав различные идентификаторы папок. Часть, которая меня озадачивает, получает разрешения для этих общих файлов. Когда я запускаю это, я вижу, что $ _. Shared_with показывает Access = Shared. $ Root = Invoke-RestMethod -Uri "$ ApiUri/me/skydrive? Access_token = $ AccessToken" – jheinikel

+0

Кроме того, ошибка, которую я получаю при запуске invoke-restmethod -Method GET -URI "$ APIURI/$ FileID/Permissions? access_token = $ accesstoken заключается в том, что URL-адрес содержит недопустимые разрешения пути. – jheinikel

ответ

1

Вы можете использовать OneDrive Rest API для отображения всех разделяемых элементов.

До этого, вам необходимо зарегистрировать приложение, чтобы получить надлежащий доступ к OneDrive согласно https://dev.onedrive.com/app-registration.htm

Затем вы можете использовать код, приведенный ниже.

$ClientId = "<Your application client id>" # your application clientid 
$SecrectKey = "<Your application key>" # the secrect key for your application 
$RedirectURI = "<Your web app redirect url>" # the re-direct url of your application 

Function List-SharedItem 
{ 
    [CmdletBinding()] 
    Param 
    ( 
     [Parameter(Mandatory=$true)][String]$ClientId, 
     [Parameter(Mandatory=$true)][String]$SecrectKey, 
     [Parameter(Mandatory=$true)][String]$RedirectURI 
    ) 

    # import the utils module 
    Import-Module ".\OneDriveAuthentication.psm1" 

    # get token 
    $Token = New-AccessTokenAndRefreshToken -ClientId $ClientId -RedirectURI $RedirectURI -SecrectKey $SecrectKey 

    # you can store the token somewhere for the later usage, however the token will expired 
    # if the token is expired, please call Update-AccessTokenAndRefreshToken to update token 
    # e.g. 
    # $RefreshedToken = Update-AccessTokenAndRefreshToken -ClientId $ClientId -RedirectURI $RedirectURI -RefreshToken $Token.RefreshToken -SecrectKey $SecrectKey 

    # construct authentication header 
    $Header = Get-AuthenticateHeader -AccessToken $Token.AccessToken 

    # api root 
    $ApiRootUrl = "https://api.onedrive.com/v1.0" 

    # call api 
    $Response = Invoke-RestMethod -Headers $Header -Method GET -Uri "$ApiRootUrl/drive/shared" 

    RETURN $Response.value 
} 

# call method to do job 
$Results = List-SharedItem -ClientId $ClientId -SecrectKey $SecrectKey -RedirectURI $RedirectURI 

# print results 
$Results | ForEach-Object { 
    Write-Host "ID: $($_.id)" 
    Write-Host "Name: $($_.name)" 
    Write-Host "ParentReference: $($_.parentReference)" 
    Write-Host "Size: $($_.size)" 
    Write-Host "WebURL: $($_.webUrl)" 
    Write-Host 
} 

Полные инструкции, вы можете увидеть образец в https://gallery.technet.microsoft.com/How-to-use-OneDrive-Rest-5b31cf78

Смежные вопросы