From f6bad231b307dd8ccee09f7abe0f402764287f39 Mon Sep 17 00:00:00 2001 From: magodo Date: Mon, 11 Nov 2024 15:12:07 +1100 Subject: [PATCH] RG mode: uses `azlist` with rg included, with special handling for empty rg --- internal/meta/meta_rg.go | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/internal/meta/meta_rg.go b/internal/meta/meta_rg.go index 50aea25..cf8a197 100644 --- a/internal/meta/meta_rg.go +++ b/internal/meta/meta_rg.go @@ -96,7 +96,7 @@ func (meta MetaResourceGroup) queryResourceSet(ctx context.Context, rg string) ( ClientOpt: meta.azureSDKClientOpt, Parallelism: meta.parallelism, Recursive: true, - IncludeResourceGroup: false, + IncludeResourceGroup: true, ExtensionResourceTypes: extBuilder{includeRoleAssignment: meta.includeRoleAssignment}.Build(), } lister, err := azlist.NewLister(opt) @@ -117,13 +117,16 @@ func (meta MetaResourceGroup) queryResourceSet(ctx context.Context, rg string) ( rl = append(rl, res) } - // Especially, adding the resoruce group itself to the resource set - rl = append(rl, - resourceset.AzureResource{Id: &armid.ResourceGroup{ - SubscriptionId: meta.subscriptionId, - Name: meta.resourceGroup, - }}, - ) + // Especially, if there is no resource within the resource group, the azlist will return an empty list. + // In this case, we'll have to add the resource group manually. + if len(rl) == 0 { + rl = append(rl, + resourceset.AzureResource{Id: &armid.ResourceGroup{ + SubscriptionId: meta.subscriptionId, + Name: meta.resourceGroup, + }}, + ) + } return &resourceset.AzureResourceSet{Resources: rl}, nil }