对BuildHttpClientBase.GetBuildWorkItemsRefsAsync的调用不返回具有利益相关者访问权限的用户创建的工作项

问题描述 投票:2回答:1

我正在使用Microsoft.TeamFoundationServer.Client Nuget package来获取与某些构建相关联的工作项列表。为此我使用以下代码:

using Microsoft.VisualStudio.Services.Common;
using Microsoft.VisualStudio.Services.WebApi;
using Microsoft.TeamFoundation.Build.WebApi;

public async Task<IEnumerable<ResourceRef>> GetBuildWorkItems(string vstsUrl, string teamProjectName, int buildId, string pat)
{
    VssConnection connection = new VssConnection(new Uri(vstsUrl), new VssBasicCredential(string.Empty, pat));
    using (var buildClient = connection.GetClient<BuildHttpClient>())
    {
        var workItems = await buildClient.GetBuildWorkItemsRefsAsync(teamProjectName, buildId);                
        return workItems;
    }
}

这工作正常,除非工作项由具有利益相关者访问级别的用户创建。特别是这些工作项不是由GetBuildWorkItemsRefsAsync方法返回的。

这是设计的吗?我是否可以在VSTS管理员设置中配置有关利益相关方用户的内容,以便不会发生这种情况?

为了澄清,我在我的团队项目中使用TFVC而不是Git。我不知道这是否与这个问题有关。

c# azure-devops azure-devops-rest-api
1个回答
1
投票

尝试了GetBuildWorkItemsRefsAsync方法,并没有弄清楚问题。

但是,您只需使用REST API即可获取与特定构建关联的工作项列表:

GET https://{accountName}.visualstudio.com/{project}/_apis/build/builds/{buildId}/workitems?api-version=4.1

有关详细信息,请参阅Builds - Get Build Work Items Refs

PowerShell例如:

Param(
   [string]$collectionurl = "https://{account}.visualstudio.com",
   [string]$project = "ProjectName",
   [string]$BuildID = "283",
   [string]$user = "username",
   [string]$token = "password"
)

# Base64-encodes the Personal Access Token (PAT) appropriately
$base64AuthInfo = [Convert]::ToBase64String([Text.Encoding]::ASCII.GetBytes(("{0}:{1}" -f $user,$token)))

$WITbaseUrl = "$collectionurl/$project/_apis/build/builds/$($BuildID)/workitems"

#Response           
$WITresponse = (Invoke-RestMethod -Uri $WITbaseUrl -Method Get -Headers @{Authorization=("Basic {0}" -f $base64AuthInfo)}).value

$WITrequests = @()

foreach($WITrequest in $WITresponse){

    $customObject = new-object PSObject -property @{
          "WorkitemID" = $WITrequest.id
          "WorkitemURL" = $WITrequest.url
        } 

    $WITrequests += $customObject       
}

$WITrequests | Select `
               WorkitemID,
               WorkitemURL
© www.soinside.com 2019 - 2024. All rights reserved.