问题描述
我正在致力于自动化 Azure Active Directory 应用注册和 Azure Devops 服务连接,但遇到了障碍。
我想通过服务主体 ID(或至少获取 ID)查询 Azure DevOps 服务连接(服务终结点)。这在使用 Azure CLI 时是可能的:
az devops service-endpoint list --query "[?authorization.parameters.serviceprincipalid=='xxx']"
但由于我在 Azure 自动化帐户中将此作为 powershell 运行手册运行,因此不支持 Azure CLI。
然后我尝试了 Azure DevOps REST API,并从 powershell 调用它,但响应不包含服务主体 ID,而只是这样:
authorization : @{parameters=; scheme=ServicePrincipal}
有人知道如何解决这个问题吗?
更新
我像这样调用其余的 API:
$uriAccount = $UriOrg + "_apis/serviceendpoint/endpoints?endpointNames={name}&api-version=6.1-preview.4"
$result = Invoke-RestMethod -Uri $uriAccount -Method get -Headers $AzureDevOpsAuthenicationHeader
$result.value 给了我这个:
authorization : @{parameters=; scheme=ServicePrincipal}
解决方法
您可以尝试 REST API Endpoints - Get Service Endpoints By Names。
GET https://dev.azure.com/{organization}/{project}/_apis/serviceendpoint/endpoints?endpointNames={endpointNames}&api-version=6.0-preview.4
在此 REST API 中,您可以通过服务连接的名称找到 id 和详细信息。
以下是在 PowerShell 中使用 REST API 的示例:
$token = "{pat}"
$token = [System.Convert]::ToBase64String([System.Text.Encoding]::ASCII.GetBytes(":$($token)"))
$url="https://dev.azure.com/{organization}/{project}/_apis/serviceendpoint/endpoints?endpointNames={endpointNames}&api-version=6.0-preview.4"
$head = @{ Authorization =" Basic $token" }
Invoke-RestMethod -Uri $url -Method GET -Headers $head
更新:
这个问题的原因是你以错误的方式输出了result
。
对于 JSON 响应体,如果不指定最后一层,就没有直观的方法来获取结果。
这是我修改后的代码,注意我如何打印 result
:
$token = "{pat}"
$token = [System.Convert]::ToBase64String([System.Text.Encoding]::ASCII.GetBytes(":$($token)"))
$url="https://dev.azure.com/{organization}/{project}/_apis/serviceendpoint/endpoints?endpointNames={endpointNames}&api-version=6.0-preview.4"
$head = @{ Authorization =" Basic $token" }
$reslut = Invoke-RestMethod -Uri $url -Method GET -Headers $head
echo $result.value.authorization.parameters