From b5092c6c5cda6487925ce57ecf9a7dd24673c640 Mon Sep 17 00:00:00 2001 From: carlosrodgut Date: Thu, 8 Aug 2024 08:30:53 +0000 Subject: [PATCH 1/5] Extend 'aws_grafana_license_association' to accept ENTERPRISE license with GrafanaToken (GrafanaLabs). --- internal/service/grafana/grafana_test.go | 3 +- .../service/grafana/license_association.go | 12 ++++- .../grafana/license_association_test.go | 44 +++++++++++++++++++ 3 files changed, 56 insertions(+), 3 deletions(-) diff --git a/internal/service/grafana/grafana_test.go b/internal/service/grafana/grafana_test.go index 9023f1171bf..a2447d73fa9 100644 --- a/internal/service/grafana/grafana_test.go +++ b/internal/service/grafana/grafana_test.go @@ -46,7 +46,8 @@ func TestAccGrafana_serial(t *testing.T) { acctest.CtBasic: testAccWorkspaceDataSource_basic, }, "LicenseAssociation": { - "enterpriseFreeTrial": testAccLicenseAssociation_freeTrial, + "enterpriseFreeTrial": testAccLicenseAssociation_freeTrial, + "enterpriseGrafanaToken": testAccLicenseAssociation_enterpriseToken, }, "SamlConfiguration": { acctest.CtBasic: testAccWorkspaceSAMLConfiguration_basic, diff --git a/internal/service/grafana/license_association.go b/internal/service/grafana/license_association.go index 1a5aabf5150..1621eb30646 100644 --- a/internal/service/grafana/license_association.go +++ b/internal/service/grafana/license_association.go @@ -14,6 +14,7 @@ import ( "github.com/hashicorp/terraform-plugin-sdk/v2/diag" "github.com/hashicorp/terraform-plugin-sdk/v2/helper/retry" "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/validation" "github.com/hashicorp/terraform-provider-aws/internal/conns" "github.com/hashicorp/terraform-provider-aws/internal/enum" "github.com/hashicorp/terraform-provider-aws/internal/errs" @@ -42,6 +43,12 @@ func resourceLicenseAssociation() *schema.Resource { Type: schema.TypeString, Computed: true, }, + "grafana_token": { + Type: schema.TypeString, + Optional: true, + ForceNew: true, + ValidateFunc: validation.IsUUID, + }, "license_expiration": { Type: schema.TypeString, Computed: true, @@ -67,8 +74,9 @@ func resourceLicenseAssociationCreate(ctx context.Context, d *schema.ResourceDat workspaceID := d.Get("workspace_id").(string) input := &grafana.AssociateLicenseInput{ - LicenseType: awstypes.LicenseType(d.Get("license_type").(string)), - WorkspaceId: aws.String(workspaceID), + GrafanaToken: aws.String(d.Get("grafana_token").(string)), + LicenseType: awstypes.LicenseType(d.Get("license_type").(string)), + WorkspaceId: aws.String(workspaceID), } output, err := conn.AssociateLicense(ctx, input) diff --git a/internal/service/grafana/license_association_test.go b/internal/service/grafana/license_association_test.go index 5cae0e194f6..ac54bea7155 100644 --- a/internal/service/grafana/license_association_test.go +++ b/internal/service/grafana/license_association_test.go @@ -8,7 +8,9 @@ import ( "fmt" "testing" + "github.com/YakDriver/regexache" awstypes "github.com/aws/aws-sdk-go-v2/service/grafana/types" + uuid "github.com/hashicorp/go-uuid" sdkacctest "github.com/hashicorp/terraform-plugin-testing/helper/acctest" "github.com/hashicorp/terraform-plugin-testing/helper/resource" "github.com/hashicorp/terraform-plugin-testing/terraform" @@ -16,6 +18,7 @@ import ( "github.com/hashicorp/terraform-provider-aws/internal/conns" tfgrafana "github.com/hashicorp/terraform-provider-aws/internal/service/grafana" "github.com/hashicorp/terraform-provider-aws/internal/tfresource" + "github.com/hashicorp/terraform-provider-aws/internal/verify" "github.com/hashicorp/terraform-provider-aws/names" ) @@ -60,6 +63,47 @@ resource "aws_grafana_license_association" "test" { `, licenseType)) } +func testAccLicenseAssociation_enterpriseToken(t *testing.T) { + ctx := acctest.Context(t) + rName := sdkacctest.RandomWithPrefix(acctest.ResourcePrefix) + resourceName := "aws_grafana_license_association.test" + workspaceResourceName := "aws_grafana_workspace.test" + uuidGrafanaToken, _ := uuid.GenerateUUID() + + resource.Test(t, resource.TestCase{ + PreCheck: func() { acctest.PreCheck(ctx, t); acctest.PreCheckPartitionHasService(t, names.GrafanaEndpointID) }, + ErrorCheck: acctest.ErrorCheck(t, names.GrafanaServiceID), + CheckDestroy: testAccCheckLicenseAssociationDestroy(ctx), + ProtoV5ProviderFactories: acctest.ProtoV5ProviderFactories, + Steps: []resource.TestStep{ + { + Config: testAccLicenseAssociationConfig_enterpriseToken(rName, string(awstypes.LicenseTypeEnterprise), uuidGrafanaToken), + Check: resource.ComposeAggregateTestCheckFunc( + testAccCheckLicenseAssociationExists(ctx, resourceName), + resource.TestMatchResourceAttr(resourceName, "grafana_token", regexache.MustCompile(fmt.Sprintf(`^%s$`, verify.UUIDRegexPattern))), + resource.TestCheckResourceAttr(resourceName, "license_type", string(awstypes.LicenseTypeEnterprise)), + resource.TestCheckResourceAttrPair(resourceName, "workspace_id", workspaceResourceName, names.AttrID), + ), + }, + { + ResourceName: resourceName, + ImportState: true, + ImportStateVerify: true, + }, + }, + }) +} + +func testAccLicenseAssociationConfig_enterpriseToken(rName string, licenseType string, grafanaToken string) string { + return acctest.ConfigCompose(testAccWorkspaceConfig_authenticationProvider(rName, "SAML"), fmt.Sprintf(` +resource "aws_grafana_license_association" "test" { + workspace_id = aws_grafana_workspace.test.id + license_type = %[1]q + grafana_token = %[2]q +} +`, licenseType, grafanaToken)) +} + func testAccCheckLicenseAssociationExists(ctx context.Context, name string) resource.TestCheckFunc { return func(s *terraform.State) error { rs, ok := s.RootModule().Resources[name] From 17dcda327f75bc1a55abe4b87db6e4fb94cc4232 Mon Sep 17 00:00:00 2001 From: carlosrodgut Date: Thu, 8 Aug 2024 09:02:07 +0000 Subject: [PATCH 2/5] Skip 'Grafana token is invalid' result on Acceptance Test. Tokens are generated on GrafanaLabs side. --- internal/service/grafana/license_association_test.go | 2 ++ 1 file changed, 2 insertions(+) diff --git a/internal/service/grafana/license_association_test.go b/internal/service/grafana/license_association_test.go index ac54bea7155..b8f45a27852 100644 --- a/internal/service/grafana/license_association_test.go +++ b/internal/service/grafana/license_association_test.go @@ -64,6 +64,8 @@ resource "aws_grafana_license_association" "test" { } func testAccLicenseAssociation_enterpriseToken(t *testing.T) { + acctest.Skip(t, "Grafana token is invalid") + ctx := acctest.Context(t) rName := sdkacctest.RandomWithPrefix(acctest.ResourcePrefix) resourceName := "aws_grafana_license_association.test" From 7a68adf919a22dc2b57608a9ef80c44f2fbdf975 Mon Sep 17 00:00:00 2001 From: Kit Ewbank Date: Thu, 8 Aug 2024 11:52:12 -0400 Subject: [PATCH 3/5] Add CHANGELOG entry. --- .changelog/38743.txt | 3 +++ 1 file changed, 3 insertions(+) create mode 100644 .changelog/38743.txt diff --git a/.changelog/38743.txt b/.changelog/38743.txt new file mode 100644 index 00000000000..405963f2034 --- /dev/null +++ b/.changelog/38743.txt @@ -0,0 +1,3 @@ +```release-note:enhancement +resource/aws_grafana_license_association: Add `grafana_token` argument +``` \ No newline at end of file From 9131cb5181ed44ad30a0e44bff78df5f27caebef Mon Sep 17 00:00:00 2001 From: Kit Ewbank Date: Thu, 8 Aug 2024 11:53:33 -0400 Subject: [PATCH 4/5] Fix terrafmt error. --- internal/service/grafana/license_association.go | 10 +++++++--- internal/service/grafana/license_association_test.go | 4 ++-- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/internal/service/grafana/license_association.go b/internal/service/grafana/license_association.go index 1621eb30646..32b4871dff2 100644 --- a/internal/service/grafana/license_association.go +++ b/internal/service/grafana/license_association.go @@ -74,9 +74,12 @@ func resourceLicenseAssociationCreate(ctx context.Context, d *schema.ResourceDat workspaceID := d.Get("workspace_id").(string) input := &grafana.AssociateLicenseInput{ - GrafanaToken: aws.String(d.Get("grafana_token").(string)), - LicenseType: awstypes.LicenseType(d.Get("license_type").(string)), - WorkspaceId: aws.String(workspaceID), + LicenseType: awstypes.LicenseType(d.Get("license_type").(string)), + WorkspaceId: aws.String(workspaceID), + } + + if v, ok := d.GetOk("grafana_token"); ok { + input.GrafanaToken = aws.String(v.(string)) } output, err := conn.AssociateLicense(ctx, input) @@ -115,6 +118,7 @@ func resourceLicenseAssociationRead(ctx context.Context, d *schema.ResourceData, } else { d.Set("free_trial_expiration", nil) } + d.Set("grafana_token", workspace.GrafanaToken) if workspace.LicenseExpiration != nil { d.Set("license_expiration", workspace.LicenseExpiration.Format(time.RFC3339)) } else { diff --git a/internal/service/grafana/license_association_test.go b/internal/service/grafana/license_association_test.go index b8f45a27852..7799c23b860 100644 --- a/internal/service/grafana/license_association_test.go +++ b/internal/service/grafana/license_association_test.go @@ -99,8 +99,8 @@ func testAccLicenseAssociation_enterpriseToken(t *testing.T) { func testAccLicenseAssociationConfig_enterpriseToken(rName string, licenseType string, grafanaToken string) string { return acctest.ConfigCompose(testAccWorkspaceConfig_authenticationProvider(rName, "SAML"), fmt.Sprintf(` resource "aws_grafana_license_association" "test" { - workspace_id = aws_grafana_workspace.test.id - license_type = %[1]q + workspace_id = aws_grafana_workspace.test.id + license_type = %[1]q grafana_token = %[2]q } `, licenseType, grafanaToken)) From bdbc7e4ca002921b821b16bee7d5d9032eb0ca11 Mon Sep 17 00:00:00 2001 From: Kit Ewbank Date: Thu, 8 Aug 2024 11:55:38 -0400 Subject: [PATCH 5/5] Add documentation. --- website/docs/r/grafana_license_association.html.markdown | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/website/docs/r/grafana_license_association.html.markdown b/website/docs/r/grafana_license_association.html.markdown index 07f9854114a..c49cf652789 100644 --- a/website/docs/r/grafana_license_association.html.markdown +++ b/website/docs/r/grafana_license_association.html.markdown @@ -47,8 +47,9 @@ resource "aws_iam_role" "assume" { ## Argument Reference -The following arguments are required: +This resource supports the following arguments: +* `grafana_token` - (Optional) A token from Grafana Labs that ties your AWS account with a Grafana Labs account. * `license_type` - (Required) The type of license for the workspace license association. Valid values are `ENTERPRISE` and `ENTERPRISE_FREE_TRIAL`. * `workspace_id` - (Required) The workspace id.