我正在尝试检索我的帐户中的所有组织,但在文档中API调用始终需要一个组织。
https://dev.azure.com/{organization}/_apis/...
https://dev.azure.com/{organization}/_apis/...
Post https://dev.azure.com/{organization1}/_apis/Contribution/HierarchyQuery?api-version=5.0-preview.1
正文:
{
"contributionIds": ["ms.vss-features.my-organizations-data-provider"],
"dataProviderContext":
{
"properties":{}
}
}
回应:
{
"dataProviderSharedData": {},
"dataProviders": {
"ms.vss-web.component-data": {},
"ms.vss-web.shared-data": null,
"ms.vss-features.my-organizations-data-provider": {
"organizations": [
{
"id": "{redacted id}",
"name": "{organization1}",
"url": "https://{organization1}.visualstudio.com/"
},
{
"id": "{redacted id}",
"name": "{organization2}",
"url": "https://dev.azure.com/{organization2}/"
}
],
"createNewOrgUrl": "https://app.vsaex.visualstudio.com/go/signup?account=true"
}
} }
您可以通过调用获取所有您是成员/所有者的帐户来简单地完成此操作。但是,需要您的ID才能实现这一点,它可以通过进行 get profile API 调用轻松获取。以下是步骤:
https://app.vssps.visualstudio.com/_apis/profile/profiles/me?api-version=5.1
这将返回您的 ID:
{
"displayName": "xxxx",
"publicAlias": "xxx",
"emailAddress": "xxx",
"coreRevision": xxx,
"timeStamp": "2019-06-17T09:29:11.1917804+00:00",
"id": "{{We need this}}",
"revision": 298459751
}
https://app.vssps.visualstudio.com/_apis/accounts?api-version=5.1&memberId={{你的 Id}}
响应:
{
"count": 1,
"value": [
{
"accountId": "xxx",
"accountUri": "xxx",
"accountName": "xxx",
"properties": {}
}
]
}
一个REST API的请求/响应可以分为五个组成部分:
请求URI,格式如下:
VERB https://{instance}[/{team-project}]/_apis[/{area}]/{resource}?api-version={version}
dev.azure.com/{organization}
REST API是特定于组织的。目前尚未记录此内容。您可以在此处提交功能请求:https://developercommunity.visualstudio.com/spaces/21/index.html
我们的PM和产品团队将会审查您的建议。对此造成任何不便,敬请谅解。我同时收到了“app.vssps.visualstudio.com/_apis/accounts”和Post https://dev.azure.com/{organization1}/_apis/Contribution/HierarchyQuery?api-version=5.0-preview.1的登录响应。
状态码:203 状态描述:非权威信息
编辑: 没关系,使用静态MSA客户端ID和回复URL可以正常工作:
internal const string clientId = "872cd9fa-d31f-45e0-9eab-6e460a02d1f1"; //change to your app registration's Application ID, unless you are an MSA backed account
internal const string replyUri = "urn:ietf:wg:oauth:2.0:oob"; //change to your app registration's reply URI, unless you are an MSA backed account
//PromptBehavior.RefreshSession will enforce an authn prompt every time. NOTE: Auto will take your windows login state if possible
result = ctx.AcquireTokenAsync(azureDevOpsResourceId, clientId, new Uri(replyUri), promptBehavior).Result;
Console.WriteLine("Token expires on: " + result.ExpiresOn);
var bearerAuthHeader = new AuthenticationHeaderValue("Bearer", result.AccessToken);
// Headers
client.DefaultRequestHeaders.Accept.Clear();
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
client.DefaultRequestHeaders.Add("User-Agent", "ManagedClientConsoleAppSample");
client.DefaultRequestHeaders.Add("X-TFS-FedAuthRedirect", "Suppress");
client.DefaultRequestHeaders.Authorization = authHeader;
//Get Organizations
client.BaseAddress = new Uri("https://app.vssps.visualstudio.com/");
HttpResponseMessage response1 = client.GetAsync("_apis/accounts").Result;