From 1e796f2608b345247864b9e1b512118499b15763 Mon Sep 17 00:00:00 2001 From: wai-wong-edb <119956756+wai-wong-edb@users.noreply.github.com> Date: Fri, 6 Oct 2023 16:25:19 +0100 Subject: [PATCH] fix: PGD BAH service/principle ids fix (#357) --- pkg/provider/resource_pgd.go | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/pkg/provider/resource_pgd.go b/pkg/provider/resource_pgd.go index 447f3d59..b664547d 100644 --- a/pkg/provider/resource_pgd.go +++ b/pkg/provider/resource_pgd.go @@ -1366,23 +1366,23 @@ func (p pgdResource) ImportState(ctx context.Context, req resource.ImportStateRe func buildApiBah(ctx context.Context, client *api.PGDClient, diags *diag.Diagnostics, projectId string, dg terraform.DataGroup) (svAccIds, principalIds *[]string) { if strings.Contains(*dg.Provider.CloudProviderId, "bah") { - if !dg.ServiceAccountIds.IsNull() { - elemDiag := dg.ServiceAccountIds.ElementsAs(ctx, &svAccIds, false) + if !dg.PeAllowedPrincipalIds.IsNull() { + elemDiag := dg.PeAllowedPrincipalIds.ElementsAs(ctx, &principalIds, false) if elemDiag.HasError() { diags.Append(elemDiag...) return nil, nil } } else { - sids, err := client.GetServiceAccountIds(ctx, projectId, *dg.Provider.CloudProviderId, dg.Region.RegionId) + pids, err := client.GetPeAllowedPrincipalIds(ctx, projectId, *dg.Provider.CloudProviderId, dg.Region.RegionId) if err != nil { - diags.AddError("pgd get service account ids error", err.Error()) + diags.AddError("pgd get pe allowed principal ids error", err.Error()) return nil, nil } - svAccIds = utils.ToPointer(sids.Data) + principalIds = utils.ToPointer(pids.Data) // if it doesn't have any existing service account ids then use config - if svAccIds != nil && len(*svAccIds) == 0 { - elemDiag := dg.ServiceAccountIds.ElementsAs(ctx, &svAccIds, false) + if principalIds != nil && len(*principalIds) == 0 { + elemDiag := dg.PeAllowedPrincipalIds.ElementsAs(ctx, &principalIds, false) if elemDiag.HasError() { diags.Append(elemDiag...) return nil, nil @@ -1391,23 +1391,23 @@ func buildApiBah(ctx context.Context, client *api.PGDClient, diags *diag.Diagnos } if strings.Contains(*dg.Provider.CloudProviderId, "bah:gcp") { - if !dg.PeAllowedPrincipalIds.IsNull() { - elemDiag := dg.PeAllowedPrincipalIds.ElementsAs(ctx, &principalIds, false) + if !dg.ServiceAccountIds.IsNull() { + elemDiag := dg.ServiceAccountIds.ElementsAs(ctx, &svAccIds, false) if elemDiag.HasError() { diags.Append(elemDiag...) return nil, nil } } else { - pids, err := client.GetPeAllowedPrincipalIds(ctx, projectId, *dg.Provider.CloudProviderId, dg.Region.RegionId) + sids, err := client.GetServiceAccountIds(ctx, projectId, *dg.Provider.CloudProviderId, dg.Region.RegionId) if err != nil { - diags.AddError("pgd get pe allowed principal ids error", err.Error()) + diags.AddError("pgd get service account ids error", err.Error()) return nil, nil } - principalIds = utils.ToPointer(pids.Data) + svAccIds = utils.ToPointer(sids.Data) // if it doesn't have any existing service account ids then use config - if principalIds != nil && len(*principalIds) == 0 { - elemDiag := dg.PeAllowedPrincipalIds.ElementsAs(ctx, &principalIds, false) + if svAccIds != nil && len(*svAccIds) == 0 { + elemDiag := dg.ServiceAccountIds.ElementsAs(ctx, &svAccIds, false) if elemDiag.HasError() { diags.Append(elemDiag...) return nil, nil