mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-17 02:51:36 -05:00
Fix error when getting subscriptions for all tenants (#16837)
This commit is contained in:
@@ -15,10 +15,10 @@ export interface IAzureResourceSubscriptionService {
|
|||||||
* Gets subscriptions for the given account. Any errors that occur while fetching the subscriptions for each tenant
|
* Gets subscriptions for the given account. Any errors that occur while fetching the subscriptions for each tenant
|
||||||
* will be displayed to the user, but this function will only throw an error if it's unable to fetch any subscriptions.
|
* will be displayed to the user, but this function will only throw an error if it's unable to fetch any subscriptions.
|
||||||
* @param account The account to get the subscriptions for
|
* @param account The account to get the subscriptions for
|
||||||
* @param tenants The list of tenants to get subscriptions for - if undefined then subscriptions for all tenants will be retrieved
|
* @param tenantIds The list of tenant IDs to get subscriptions for - if undefined then subscriptions for all tenants will be retrieved
|
||||||
* @returns The list of all subscriptions on this account that were able to be retrieved
|
* @returns The list of all subscriptions on this account that were able to be retrieved
|
||||||
*/
|
*/
|
||||||
getSubscriptions(account: Account, tenants?: string[] | undefined): Promise<azureResource.AzureResourceSubscription[]>;
|
getSubscriptions(account: AzureAccount, tenantIds?: string[] | undefined): Promise<azureResource.AzureResourceSubscription[]>;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface IAzureResourceSubscriptionFilterService {
|
export interface IAzureResourceSubscriptionFilterService {
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import { AzureSubscriptionError } from '../errors';
|
|||||||
import { AzureResourceErrorMessageUtil } from '../utils';
|
import { AzureResourceErrorMessageUtil } from '../utils';
|
||||||
|
|
||||||
import * as nls from 'vscode-nls';
|
import * as nls from 'vscode-nls';
|
||||||
|
import { AzureAccount } from 'azurecore';
|
||||||
const localize = nls.loadMessageBundle();
|
const localize = nls.loadMessageBundle();
|
||||||
|
|
||||||
export class AzureResourceSubscriptionService implements IAzureResourceSubscriptionService {
|
export class AzureResourceSubscriptionService implements IAzureResourceSubscriptionService {
|
||||||
@@ -21,29 +22,29 @@ export class AzureResourceSubscriptionService implements IAzureResourceSubscript
|
|||||||
* Gets subscriptions for the given account. Any errors that occur while fetching the subscriptions for each tenant
|
* Gets subscriptions for the given account. Any errors that occur while fetching the subscriptions for each tenant
|
||||||
* will be displayed to the user, but this function will only throw an error if it's unable to fetch any subscriptions.
|
* will be displayed to the user, but this function will only throw an error if it's unable to fetch any subscriptions.
|
||||||
* @param account The account to get the subscriptions for
|
* @param account The account to get the subscriptions for
|
||||||
* @param tenants The list of tenants to get subscriptions for - if undefined then subscriptions for all tenants will be retrieved
|
* @param tenantIds The list of tenants to get subscriptions for - if undefined then subscriptions for all tenants will be retrieved
|
||||||
* @returns The list of all subscriptions on this account that were able to be retrieved
|
* @returns The list of all subscriptions on this account that were able to be retrieved
|
||||||
*/
|
*/
|
||||||
public async getSubscriptions(account: azdata.Account, tenants?: string[]): Promise<azureResource.AzureResourceSubscription[]> {
|
public async getSubscriptions(account: AzureAccount, tenantIds?: string[]): Promise<azureResource.AzureResourceSubscription[]> {
|
||||||
const subscriptions: azureResource.AzureResourceSubscription[] = [];
|
const subscriptions: azureResource.AzureResourceSubscription[] = [];
|
||||||
let gotSubscriptions = false;
|
let gotSubscriptions = false;
|
||||||
const errors: Error[] = [];
|
const errors: Error[] = [];
|
||||||
|
|
||||||
for (const tenant of tenants ?? account.properties.tenants) {
|
for (const tenantId of tenantIds ?? account.properties.tenants.map(t => t.id)) {
|
||||||
try {
|
try {
|
||||||
const token = await azdata.accounts.getAccountSecurityToken(account, tenant.id, azdata.AzureResource.ResourceManagement);
|
const token = await azdata.accounts.getAccountSecurityToken(account, tenantId, azdata.AzureResource.ResourceManagement);
|
||||||
const subClient = new SubscriptionClient(new TokenCredentials(token.token, token.tokenType), { baseUri: account.properties.providerSettings.settings.armResource.endpoint });
|
const subClient = new SubscriptionClient(new TokenCredentials(token.token, token.tokenType), { baseUri: account.properties.providerSettings.settings.armResource.endpoint });
|
||||||
const newSubs = await subClient.subscriptions.list();
|
const newSubs = await subClient.subscriptions.list();
|
||||||
subscriptions.push(...newSubs.map(newSub => {
|
subscriptions.push(...newSubs.map(newSub => {
|
||||||
return {
|
return {
|
||||||
id: newSub.subscriptionId,
|
id: newSub.subscriptionId,
|
||||||
name: newSub.displayName,
|
name: newSub.displayName,
|
||||||
tenant: tenant.id
|
tenant: tenantId
|
||||||
};
|
};
|
||||||
}));
|
}));
|
||||||
gotSubscriptions = true;
|
gotSubscriptions = true;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
const errorMsg = localize('azure.resource.tenantSubscriptionsError', "Failed to get subscriptions for account {0} (tenant '{1}'). {2}", account.key.accountId, tenant.id, AzureResourceErrorMessageUtil.getErrorMessage(error));
|
const errorMsg = localize('azure.resource.tenantSubscriptionsError', "Failed to get subscriptions for account {0} (tenant '{1}'). {2}", account.key.accountId, tenantId, AzureResourceErrorMessageUtil.getErrorMessage(error));
|
||||||
console.warn(errorMsg);
|
console.warn(errorMsg);
|
||||||
errors.push(error);
|
errors.push(error);
|
||||||
vscode.window.showWarningMessage(errorMsg);
|
vscode.window.showWarningMessage(errorMsg);
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ import { ResourceGraphClient } from '@azure/arm-resourcegraph';
|
|||||||
import { TokenCredentials } from '@azure/ms-rest-js';
|
import { TokenCredentials } from '@azure/ms-rest-js';
|
||||||
import axios, { AxiosRequestConfig } from 'axios';
|
import axios, { AxiosRequestConfig } from 'axios';
|
||||||
import * as azdata from 'azdata';
|
import * as azdata from 'azdata';
|
||||||
import { AzureRestResponse, GetResourceGroupsResult, GetSubscriptionsResult, ResourceQueryResult, GetBlobContainersResult, GetFileSharesResult, HttpRequestMethod, GetLocationsResult, GetManagedDatabasesResult, CreateResourceGroupResult, GetBlobsResult, GetStorageAccountAccessKeyResult } from 'azurecore';
|
import { AzureRestResponse, GetResourceGroupsResult, GetSubscriptionsResult, ResourceQueryResult, GetBlobContainersResult, GetFileSharesResult, HttpRequestMethod, GetLocationsResult, GetManagedDatabasesResult, CreateResourceGroupResult, GetBlobsResult, GetStorageAccountAccessKeyResult, AzureAccount } from 'azurecore';
|
||||||
import { azureResource } from 'azureResource';
|
import { azureResource } from 'azureResource';
|
||||||
import { EOL } from 'os';
|
import { EOL } from 'os';
|
||||||
import * as nls from 'vscode-nls';
|
import * as nls from 'vscode-nls';
|
||||||
@@ -262,7 +262,7 @@ export async function runResourceQuery<T extends azureResource.AzureGraphResourc
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getSubscriptions(appContext: AppContext, account?: azdata.Account, ignoreErrors: boolean = false): Promise<GetSubscriptionsResult> {
|
export async function getSubscriptions(appContext: AppContext, account?: AzureAccount, ignoreErrors: boolean = false): Promise<GetSubscriptionsResult> {
|
||||||
const result: GetSubscriptionsResult = { subscriptions: [], errors: [] };
|
const result: GetSubscriptionsResult = { subscriptions: [], errors: [] };
|
||||||
if (!account?.properties?.tenants || !Array.isArray(account.properties.tenants)) {
|
if (!account?.properties?.tenants || !Array.isArray(account.properties.tenants)) {
|
||||||
const error = new Error(invalidAzureAccount);
|
const error = new Error(invalidAzureAccount);
|
||||||
|
|||||||
@@ -143,7 +143,7 @@ export async function activate(context: vscode.ExtensionContext): Promise<azurec
|
|||||||
});
|
});
|
||||||
|
|
||||||
return {
|
return {
|
||||||
getSubscriptions(account?: azdata.Account, ignoreErrors?: boolean, selectedOnly: boolean = false): Promise<azurecore.GetSubscriptionsResult> {
|
getSubscriptions(account?: azurecore.AzureAccount, ignoreErrors?: boolean, selectedOnly: boolean = false): Promise<azurecore.GetSubscriptionsResult> {
|
||||||
return selectedOnly
|
return selectedOnly
|
||||||
? azureResourceUtils.getSelectedSubscriptions(appContext, account, ignoreErrors)
|
? azureResourceUtils.getSelectedSubscriptions(appContext, account, ignoreErrors)
|
||||||
: azureResourceUtils.getSubscriptions(appContext, account, ignoreErrors);
|
: azureResourceUtils.getSubscriptions(appContext, account, ignoreErrors);
|
||||||
|
|||||||
Reference in New Issue
Block a user