-
Notifications
You must be signed in to change notification settings - Fork 674
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into config-aggregator-terraform-changes
- Loading branch information
Showing
8 changed files
with
397 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
173 changes: 173 additions & 0 deletions
173
ibm/service/globaltagging/resource_ibm_iam_access_tag.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,173 @@ | ||
// Copyright IBM Corp. 2017, 2024 All Rights Reserved. | ||
// Licensed under the Mozilla Public License v2.0 | ||
|
||
package globaltagging | ||
|
||
import ( | ||
"context" | ||
"encoding/json" | ||
"fmt" | ||
"log" | ||
|
||
"github.com/IBM-Cloud/terraform-provider-ibm/ibm/conns" | ||
"github.com/IBM-Cloud/terraform-provider-ibm/ibm/flex" | ||
"github.com/IBM-Cloud/terraform-provider-ibm/ibm/validate" | ||
"github.com/IBM/platform-services-go-sdk/globaltaggingv1" | ||
"github.com/hashicorp/terraform-plugin-sdk/v2/diag" | ||
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" | ||
) | ||
|
||
func ResourceIBMIamAccessTag() *schema.Resource { | ||
return &schema.Resource{ | ||
CreateContext: resourceIBMIamAccessTagCreate, | ||
ReadContext: resourceIBMIamAccessTagRead, | ||
DeleteContext: resourceIBMIamAccessTagDelete, | ||
Importer: &schema.ResourceImporter{}, | ||
|
||
Schema: map[string]*schema.Schema{ | ||
|
||
"name": { | ||
Type: schema.TypeString, | ||
Required: true, | ||
ForceNew: true, | ||
ValidateFunc: validate.InvokeValidator("ibm_iam_access_tag", "name"), | ||
Set: flex.ResourceIBMVPCHash, | ||
Description: "Name of the access tag", | ||
}, | ||
tagType: { | ||
Type: schema.TypeString, | ||
Computed: true, | ||
Description: "Type of the tag(access)", | ||
}, | ||
}, | ||
} | ||
} | ||
|
||
func ResourceIBMIamAccessTagValidator() *validate.ResourceValidator { | ||
|
||
validateSchema := make([]validate.ValidateSchema, 0) | ||
|
||
validateSchema = append(validateSchema, | ||
validate.ValidateSchema{ | ||
Identifier: "name", | ||
ValidateFunctionIdentifier: validate.ValidateRegexpLen, | ||
Type: validate.TypeString, | ||
Required: true, | ||
Regexp: `^([A-Za-z0-9_.-]|[A-Za-z0-9_.-][A-Za-z0-9_ .-]*[A-Za-z0-9_.-]):([A-Za-z0-9_.-]|[A-Za-z0-9_.-][A-Za-z0-9_ .-]*[A-Za-z0-9_.-])$`, | ||
MinValueLength: 1, | ||
MaxValueLength: 128}) | ||
|
||
ibmIamAccessTagValidator := validate.ResourceValidator{ResourceName: "ibm_iam_access_tag", Schema: validateSchema} | ||
return &ibmIamAccessTagValidator | ||
} | ||
|
||
func resourceIBMIamAccessTagCreate(context context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics { | ||
|
||
gtClient, err := meta.(conns.ClientSession).GlobalTaggingAPIv1() | ||
if err != nil { | ||
tfErr := flex.TerraformErrorf(err, err.Error(), "ibm_iam_access_tag", "create") | ||
log.Printf("[DEBUG]\n%s", tfErr.GetDebugMessage()) | ||
return tfErr.GetDiag() | ||
} | ||
|
||
tagName := d.Get("name").(string) | ||
add := make([]string, 0) | ||
add = append(add, tagName) | ||
accessTagType := "access" | ||
createTagOptions := &globaltaggingv1.CreateTagOptions{ | ||
TagType: &accessTagType, | ||
TagNames: add, | ||
} | ||
results, _, err := gtClient.CreateTagWithContext(context, createTagOptions) | ||
if err != nil { | ||
tfErr := flex.TerraformErrorf(err, err.Error(), "ibm_iam_access_tag", "create") | ||
return tfErr.GetDiag() | ||
} | ||
if results != nil { | ||
errMap := make([]globaltaggingv1.CreateTagResultsResultsItem, 0) | ||
for _, res := range results.Results { | ||
if res.IsError != nil && *res.IsError { | ||
errMap = append(errMap, res) | ||
} | ||
} | ||
if len(errMap) > 0 { | ||
output, _ := json.MarshalIndent(errMap, "", " ") | ||
return diag.FromErr(fmt.Errorf("Error while creating access tag(%s) : %s", tagName, string(output))) | ||
} | ||
} | ||
|
||
d.SetId(tagName) | ||
d.Set(tagType, accessTagType) | ||
|
||
return nil | ||
} | ||
|
||
func resourceIBMIamAccessTagRead(context context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics { | ||
tagName := d.Id() | ||
gtClient, err := meta.(conns.ClientSession).GlobalTaggingAPIv1() | ||
if err != nil { | ||
tfErr := flex.TerraformErrorf(err, err.Error(), "ibm_iam_access_tag", "read") | ||
log.Printf("[DEBUG]\n%s", tfErr.GetDebugMessage()) | ||
return tfErr.GetDiag() | ||
} | ||
accessTagType := "access" | ||
listTagsOptions := &globaltaggingv1.ListTagsOptions{ | ||
TagType: &accessTagType, | ||
} | ||
taggingResult, _, err := gtClient.ListTagsWithContext(context, listTagsOptions) | ||
if err != nil { | ||
tfErr := flex.TerraformErrorf(err, err.Error(), "ibm_iam_access_tag", "read") | ||
return tfErr.GetDiag() | ||
} | ||
|
||
var taglist []string | ||
for _, item := range taggingResult.Items { | ||
taglist = append(taglist, *item.Name) | ||
} | ||
existingAccessTags := flex.NewStringSet(flex.ResourceIBMVPCHash, taglist) | ||
if !existingAccessTags.Contains(tagName) { | ||
d.SetId("") | ||
return nil | ||
} | ||
d.Set("name", tagName) | ||
d.Set(tagType, accessTagType) | ||
return nil | ||
} | ||
|
||
func resourceIBMIamAccessTagDelete(context context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics { | ||
|
||
gtClient, err := meta.(conns.ClientSession).GlobalTaggingAPIv1() | ||
if err != nil { | ||
tfErr := flex.TerraformErrorf(err, err.Error(), "ibm_iam_access_tag", "update") | ||
log.Printf("[DEBUG]\n%s", tfErr.GetDebugMessage()) | ||
return tfErr.GetDiag() | ||
} | ||
tagName := d.Get("name").(string) | ||
accessTagType := "access" | ||
|
||
deleteTagOptions := &globaltaggingv1.DeleteTagOptions{ | ||
TagName: &tagName, | ||
TagType: &accessTagType, | ||
} | ||
|
||
results, resp, err := gtClient.DeleteTagWithContext(context, deleteTagOptions) | ||
|
||
if err != nil { | ||
return diag.FromErr(fmt.Errorf("Error while deleting access tag calling api (%s) : %v\n%v", tagName, err, resp)) | ||
} | ||
if results != nil { | ||
errMap := make([]globaltaggingv1.DeleteTagResultsItem, 0) | ||
for _, res := range results.Results { | ||
if res.IsError != nil && *res.IsError { | ||
errMap = append(errMap, res) | ||
} | ||
} | ||
if len(errMap) > 0 { | ||
output, _ := json.MarshalIndent(errMap, "", " ") | ||
return diag.FromErr(fmt.Errorf("Error while deleting access tag in results (%s) : %s", tagName, string(output))) | ||
} | ||
} | ||
|
||
d.SetId("") | ||
return nil | ||
} |
147 changes: 147 additions & 0 deletions
147
ibm/service/globaltagging/resource_ibm_iam_access_tag_test.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,147 @@ | ||
// Copyright IBM Corp. 2017, 2024 All Rights Reserved. | ||
// Licensed under the Mozilla Public License v2.0 | ||
|
||
package globaltagging_test | ||
|
||
import ( | ||
"fmt" | ||
"regexp" | ||
"testing" | ||
|
||
acc "github.com/IBM-Cloud/terraform-provider-ibm/ibm/acctest" | ||
"github.com/IBM-Cloud/terraform-provider-ibm/ibm/conns" | ||
"github.com/IBM-Cloud/terraform-provider-ibm/ibm/flex" | ||
"github.com/IBM/platform-services-go-sdk/globaltaggingv1" | ||
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/acctest" | ||
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" | ||
"github.com/hashicorp/terraform-plugin-sdk/v2/terraform" | ||
) | ||
|
||
const ( | ||
iamAccessTagRegex = "^([A-Za-z0-9_.-]|[A-Za-z0-9_.-][A-Za-z0-9_ .-]*[A-Za-z0-9_.-]):([A-Za-z0-9_.-]|[A-Za-z0-9_.-][A-Za-z0-9_ .-]*[A-Za-z0-9_.-])$" | ||
) | ||
|
||
func TestAccIamAccessTag_Basic(t *testing.T) { | ||
name := fmt.Sprintf("tf%d:iam-access%d", acctest.RandIntRange(10, 100), acctest.RandIntRange(10, 100)) | ||
|
||
resource.Test(t, resource.TestCase{ | ||
PreCheck: func() { acc.TestAccPreCheck(t) }, | ||
Providers: acc.TestAccProviders, | ||
Steps: []resource.TestStep{ | ||
|
||
resource.TestStep{ | ||
Config: testAccCheckIamAccessTagCreate(name), | ||
Check: resource.ComposeAggregateTestCheckFunc( | ||
testAccCheckIamAccessTagExists("ibm_iam_access_tag.tag"), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "id", name), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "name", name), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "tag_type", "access"), | ||
), | ||
}, | ||
}, | ||
}) | ||
} | ||
func TestAccIamAccessTag_Usage(t *testing.T) { | ||
name := fmt.Sprintf("tf%d:iam-access%d", acctest.RandIntRange(10, 100), acctest.RandIntRange(10, 100)) | ||
resource.Test(t, resource.TestCase{ | ||
PreCheck: func() { acc.TestAccPreCheck(t) }, | ||
Providers: acc.TestAccProviders, | ||
Steps: []resource.TestStep{ | ||
|
||
resource.TestStep{ | ||
Config: testAccCheckIamAccessTagCreate(name), | ||
Check: resource.ComposeAggregateTestCheckFunc( | ||
testAccCheckIamAccessTagExists("ibm_iam_access_tag.tag"), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "id", name), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "name", name), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "tag_type", "access"), | ||
), | ||
}, | ||
resource.TestStep{ | ||
Config: testAccCheckIamAccessTagUsage(name), | ||
Check: resource.ComposeAggregateTestCheckFunc( | ||
testAccCheckIamAccessTagExists("ibm_iam_access_tag.tag"), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "id", name), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "name", name), | ||
resource.TestCheckResourceAttr("ibm_iam_access_tag.tag", "tag_type", "access"), | ||
testAccCheckResourceTagExists("ibm_resource_tag.tag"), | ||
resource.TestCheckResourceAttr("ibm_resource_tag.tag", "tags.#", "1"), | ||
resource.TestCheckResourceAttr("ibm_resource_tag.tag", "tags.0", name), | ||
resource.TestCheckResourceAttr("ibm_resource_tag.tag", "tag_type", "access"), | ||
), | ||
}, | ||
}, | ||
}) | ||
} | ||
|
||
func testAccCheckIamAccessTagExists(n string) resource.TestCheckFunc { | ||
return func(s *terraform.State) error { | ||
var tagName string | ||
rs, ok := s.RootModule().Resources[n] | ||
if !ok { | ||
return fmt.Errorf("Not found: %s", n) | ||
} | ||
|
||
iamAccessTagRegex, err := regexp.Compile(iamAccessTagRegex) | ||
if err != nil { | ||
return err | ||
} | ||
|
||
if iamAccessTagRegex.MatchString(rs.Primary.ID) { | ||
tagName = rs.Primary.ID | ||
} | ||
|
||
gtClient, err := acc.TestAccProvider.Meta().(conns.ClientSession).GlobalTaggingAPIv1() | ||
if err != nil { | ||
return fmt.Errorf("Error getting global tagging client settings: %s", err) | ||
} | ||
accessTagType := "access" | ||
listTagsOptions := &globaltaggingv1.ListTagsOptions{ | ||
TagType: &accessTagType, | ||
} | ||
taggingResult, _, err := gtClient.ListTags(listTagsOptions) | ||
if err != nil { | ||
return err | ||
} | ||
|
||
var taglist []string | ||
for _, item := range taggingResult.Items { | ||
taglist = append(taglist, *item.Name) | ||
} | ||
existingAccessTags := flex.NewStringSet(flex.ResourceIBMVPCHash, taglist) | ||
if !existingAccessTags.Contains(tagName) { | ||
return fmt.Errorf( | ||
"Error on get of resource tags (%s) : %s", tagName, err) | ||
} | ||
return nil | ||
} | ||
} | ||
|
||
func testAccCheckIamAccessTagCreate(name string) string { | ||
return fmt.Sprintf(` | ||
resource "ibm_iam_access_tag" "tag" { | ||
name = "%s" | ||
} | ||
`, name) | ||
} | ||
func testAccCheckIamAccessTagUsage(name string) string { | ||
resource_group_name := fmt.Sprintf("tf%d-iam-access%d", acctest.RandIntRange(10, 100), acctest.RandIntRange(10, 100)) | ||
return fmt.Sprintf(` | ||
data "ibm_resource_group" "group" { | ||
name = "Default" | ||
} | ||
resource "ibm_iam_access_tag" "tag" { | ||
name = "%s" | ||
} | ||
resource "ibm_cd_toolchain" "cd_toolchain_instance" { | ||
description = "Terraform test" | ||
name = "%s-toolchain" | ||
resource_group_id = data.ibm_resource_group.group.id | ||
} | ||
resource "ibm_resource_tag" "tag" { | ||
resource_id = ibm_cd_toolchain.cd_toolchain_instance.crn | ||
tags = [ibm_iam_access_tag.tag.name] | ||
tag_type = "access" | ||
} | ||
`, name, resource_group_name) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.